Merge branch 'core-objtool-for-linus' of git://git.kernel.org/pub/scm/linux/kernel...
[linux-block.git] / tools / perf / check-headers.sh
CommitLineData
aeafd623 1#!/bin/sh
b2441318 2# SPDX-License-Identifier: GPL-2.0
aeafd623 3
00a26390 4FILES='
aaa6ef8a 5include/uapi/linux/const.h
c1737f2b
ACM
6include/uapi/drm/drm.h
7include/uapi/drm/i915_drm.h
f9cdd63e 8include/uapi/linux/fadvise.h
67ef2879 9include/uapi/linux/fcntl.h
f443f38c 10include/uapi/linux/fs.h
0ae40612 11include/uapi/linux/fscrypt.h
735e215e 12include/uapi/linux/kcmp.h
3ce97513 13include/uapi/linux/kvm.h
a4b20612 14include/uapi/linux/in.h
250bfc87 15include/uapi/linux/mount.h
c4528333 16include/uapi/linux/openat2.h
aeafd623 17include/uapi/linux/perf_event.h
43372794 18include/uapi/linux/prctl.h
450c86c9 19include/uapi/linux/sched.h
67ef2879 20include/uapi/linux/stat.h
2bd71d11 21include/uapi/linux/usbdevice_fs.h
d02b395e 22include/uapi/linux/vhost.h
a215684e 23include/uapi/sound/asound.h
ba4aa02b 24include/linux/bits.h
aaa6ef8a 25include/linux/const.h
aeafd623
JO
26include/linux/hash.h
27include/uapi/linux/hw_breakpoint.h
28arch/x86/include/asm/disabled-features.h
29arch/x86/include/asm/required-features.h
30arch/x86/include/asm/cpufeatures.h
00a26390 31arch/x86/include/asm/inat_types.h
4d65adfc 32arch/x86/include/asm/emulate_prefix.h
d2b72b72 33arch/x86/include/asm/irq_vectors.h
444e2ff3 34arch/x86/include/asm/msr-index.h
c22e2683 35arch/x86/include/uapi/asm/prctl.h
00a26390
JP
36arch/x86/lib/x86-opcode-map.txt
37arch/x86/tools/gen-insn-attr-x86.awk
aeafd623
JO
38arch/arm/include/uapi/asm/perf_regs.h
39arch/arm64/include/uapi/asm/perf_regs.h
40arch/powerpc/include/uapi/asm/perf_regs.h
10b9baa7 41arch/s390/include/uapi/asm/perf_regs.h
aeafd623
JO
42arch/x86/include/uapi/asm/perf_regs.h
43arch/x86/include/uapi/asm/kvm.h
44arch/x86/include/uapi/asm/kvm_perf.h
45arch/x86/include/uapi/asm/svm.h
047726d1 46arch/x86/include/uapi/asm/unistd.h
aeafd623
JO
47arch/x86/include/uapi/asm/vmx.h
48arch/powerpc/include/uapi/asm/kvm.h
49arch/s390/include/uapi/asm/kvm.h
50arch/s390/include/uapi/asm/kvm_perf.h
a81c4213 51arch/s390/include/uapi/asm/ptrace.h
aeafd623
JO
52arch/s390/include/uapi/asm/sie.h
53arch/arm/include/uapi/asm/kvm.h
54arch/arm64/include/uapi/asm/kvm.h
34b009cf 55arch/arm64/include/uapi/asm/unistd.h
95f28190
HB
56arch/alpha/include/uapi/asm/errno.h
57arch/mips/include/asm/errno.h
58arch/mips/include/uapi/asm/errno.h
59arch/parisc/include/uapi/asm/errno.h
60arch/powerpc/include/uapi/asm/errno.h
61arch/sparc/include/uapi/asm/errno.h
62arch/x86/include/uapi/asm/errno.h
aeafd623
JO
63include/asm-generic/bitops/arch_hweight.h
64include/asm-generic/bitops/const_hweight.h
65include/asm-generic/bitops/__fls.h
66include/asm-generic/bitops/fls.h
67include/asm-generic/bitops/fls64.h
68include/linux/coresight-pmu.h
28b8f954
HB
69include/uapi/asm-generic/errno.h
70include/uapi/asm-generic/errno-base.h
6375f0ab 71include/uapi/asm-generic/ioctls.h
aeafd623 72include/uapi/asm-generic/mman-common.h
34b009cf 73include/uapi/asm-generic/unistd.h
aeafd623
JO
74'
75
58247297
JO
76check_2 () {
77 file1=$1
78 file2=$2
aeafd623 79
58247297 80 shift
aeafd623 81 shift
aeafd623 82
58247297 83 cmd="diff $* $file1 $file2 > /dev/null"
aeafd623 84
51d8aac2
AK
85 test -f $file2 && {
86 eval $cmd || {
7ea6e983
JO
87 echo "Warning: Kernel ABI header at '$file1' differs from latest version at '$file2'" >&2
88 echo diff -u $file1 $file2
51d8aac2
AK
89 }
90 }
aeafd623
JO
91}
92
58247297
JO
93check () {
94 file=$1
95
96 shift
97
7ea6e983 98 check_2 tools/$file $file $*
58247297 99}
aeafd623 100
d7e05cea
ACM
101# Check if we have the kernel headers (tools/perf/../../include), else
102# we're probably on a detached tarball, so no point in trying to check
103# differences.
104test -d ../../include || exit 0
105
7ea6e983
JO
106cd ../..
107
aeafd623 108# simple diff check
00a26390 109for i in $FILES; do
aeafd623
JO
110 check $i -B
111done
112
113# diff with extra ignore lines
bd5c6b81
ACM
114check arch/x86/lib/memcpy_64.S '-I "^EXPORT_SYMBOL" -I "^#include <asm/export.h>" -I"^SYM_FUNC_START\(_LOCAL\)*(memcpy_\(erms\|orig\))"'
115check arch/x86/lib/memset_64.S '-I "^EXPORT_SYMBOL" -I "^#include <asm/export.h>" -I"^SYM_FUNC_START\(_LOCAL\)*(memset_\(erms\|orig\))"'
be709d48 116check include/uapi/asm-generic/mman.h '-I "^#include <\(uapi/\)*asm-generic/mman-common\(-tools\)*.h>"'
15019e98 117check include/uapi/linux/mman.h '-I "^#include <\(uapi/\)*asm/mman.h>"'
3052ba56
ACM
118check include/linux/ctype.h '-I "isdigit("'
119check lib/ctype.c '-I "^EXPORT_SYMBOL" -I "^#include <linux/export.h>" -B'
87a682a7
ACM
120check arch/x86/include/asm/inat.h '-I "^#include [\"<]\(asm/\)*inat_types.h[\">]"'
121check arch/x86/include/asm/insn.h '-I "^#include [\"<]\(asm/\)*inat.h[\">]"'
122check arch/x86/lib/inat.c '-I "^#include [\"<]\(../include/\)*asm/insn.h[\">]"'
4d65adfc 123check arch/x86/lib/insn.c '-I "^#include [\"<]\(../include/\)*asm/in\(at\|sn\).h[\">]" -I "^#include [\"<]\(../include/\)*asm/emulate_prefix.h[\">]"'
7ea6e983 124
c9b51a01
JO
125# diff non-symmetric files
126check_2 tools/perf/arch/x86/entry/syscalls/syscall_64.tbl arch/x86/entry/syscalls/syscall_64.tbl
127
7ea6e983 128cd tools/perf