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