perf tools: Fix is_compat_mode build break in ppc64
authorLikhitha Korrapati <likhitha@linux.ibm.com>
Fri, 21 Mar 2025 10:07:26 +0000 (15:37 +0530)
committerNamhyung Kim <namhyung@kernel.org>
Mon, 24 Mar 2025 06:14:19 +0000 (23:14 -0700)
Commit 54f9aa1092457 ("tools/perf/powerpc/util: Add support to
handle compatible mode PVR for perf json events") introduced
to select proper JSON events in case of compat mode using
auxiliary vector. But this caused a compilation error in ppc64
Big Endian.

arch/powerpc/util/header.c: In function 'is_compat_mode':
arch/powerpc/util/header.c:20:21: error: cast to pointer from
integer of different size [-Werror=int-to-pointer-cast]
   20 |         if (!strcmp((char *)platform, (char *)base_platform))
      |                     ^
arch/powerpc/util/header.c:20:39: error: cast to pointer from
integer of different size [-Werror=int-to-pointer-cast]
   20 |         if (!strcmp((char *)platform, (char *)base_platform))
      |

Commit saved the getauxval(AT_BASE_PLATFORM) and getauxval(AT_PLATFORM)
return values in u64 which causes the compilation error.

Patch fixes this issue by changing u64 to "unsigned long".

Fixes: 54f9aa1092457 ("tools/perf/powerpc/util: Add support to handle compatible mode PVR for perf json events")
Signed-off-by: Likhitha Korrapati <likhitha@linux.ibm.com>
Reviewed-by: Athira Rajeev <atrajeev@linux.ibm.com>
Link: https://lore.kernel.org/r/20250321100726.699956-1-likhitha@linux.ibm.com
Signed-off-by: Namhyung Kim <namhyung@kernel.org>
tools/perf/arch/powerpc/util/header.c

index c7df534dbf8f845a00faf639c4d3c7f82e1287d1..0be74f048f964b971fc3dea373a1e50d19c8dce1 100644 (file)
@@ -14,8 +14,8 @@
 
 static bool is_compat_mode(void)
 {
-       u64 base_platform = getauxval(AT_BASE_PLATFORM);
-       u64 platform = getauxval(AT_PLATFORM);
+       unsigned long base_platform = getauxval(AT_BASE_PLATFORM);
+       unsigned long platform = getauxval(AT_PLATFORM);
 
        if (!strcmp((char *)platform, (char *)base_platform))
                return false;