turbostat: Don't attempt to printf an off_t with %zx
authorJosh Triplett <josh@joshtriplett.org>
Wed, 21 Aug 2013 00:20:13 +0000 (17:20 -0700)
committerLen Brown <len.brown@intel.com>
Sun, 19 Jan 2014 03:34:08 +0000 (22:34 -0500)
turbostat uses the format %zx to print an off_t.  However, %zx wants a
size_t, not an off_t.  On 32-bit targets, those refer to different
types, potentially even with different sizes.  Use %llx and a cast
instead, since printf does not have a length modifier for off_t.

Without this patch, when compiling for a 32-bit target:

turbostat.c: In function 'get_msr':
turbostat.c:231:3: warning: format '%zx' expects argument of type 'size_t', but argument 4 has type 'off_t' [-Wformat]

Signed-off-by: Josh Triplett <josh@joshtriplett.org>
Signed-off-by: Len Brown <len.brown@intel.com>
tools/power/x86/turbostat/turbostat.c

index 93cbef56e876c153ef376a92e590327f3b5c5b78..dbcbf27a4d8bf0d3acc0861ba71db8ca67ed55d6 100644 (file)
@@ -234,7 +234,7 @@ int get_msr(int cpu, off_t offset, unsigned long long *msr)
        close(fd);
 
        if (retval != sizeof *msr) {
-               fprintf(stderr, "%s offset 0x%zx read failed\n", pathname, offset);
+               fprintf(stderr, "%s offset 0x%llx read failed\n", pathname, (unsigned long long)offset);
                return -1;
        }