xref: /linux/tools/perf/arch/arm64/tests/cpuid-match.c (revision 03c11eb3b16dc0058589751dfd91f254be2be613)
1 // SPDX-License-Identifier: GPL-2.0
2 #include <linux/compiler.h>
3 
4 #include "arch-tests.h"
5 #include "tests/tests.h"
6 #include "util/header.h"
7 
test__cpuid_match(struct test_suite * test __maybe_unused,int subtest __maybe_unused)8 int test__cpuid_match(struct test_suite *test __maybe_unused,
9 			     int subtest __maybe_unused)
10 {
11 	/* midr with no leading zeros matches */
12 	if (strcmp_cpuid_str("0x410fd0c0", "0x00000000410fd0c0"))
13 		return -1;
14 	/* Upper case matches */
15 	if (strcmp_cpuid_str("0x410fd0c0", "0x00000000410FD0C0"))
16 		return -1;
17 	/* r0p0 = r0p0 matches */
18 	if (strcmp_cpuid_str("0x00000000410fd480", "0x00000000410fd480"))
19 		return -1;
20 	/* r0p1 > r0p0 matches */
21 	if (strcmp_cpuid_str("0x00000000410fd480", "0x00000000410fd481"))
22 		return -1;
23 	/* r1p0 > r0p0 matches*/
24 	if (strcmp_cpuid_str("0x00000000410fd480", "0x00000000411fd480"))
25 		return -1;
26 	/* r0p0 < r0p1 doesn't match */
27 	if (!strcmp_cpuid_str("0x00000000410fd481", "0x00000000410fd480"))
28 		return -1;
29 	/* r0p0 < r1p0 doesn't match */
30 	if (!strcmp_cpuid_str("0x00000000411fd480", "0x00000000410fd480"))
31 		return -1;
32 	/* Different CPU doesn't match */
33 	if (!strcmp_cpuid_str("0x00000000410fd4c0", "0x00000000430f0af0"))
34 		return -1;
35 
36 	return 0;
37 }
38