Merge branch 'for-4.20/apple' into for-linus
[linux-2.6-block.git] / tools / perf / check-headers.sh
CommitLineData
aeafd623 1#!/bin/sh
b2441318 2# SPDX-License-Identifier: GPL-2.0
aeafd623
JO
3
4HEADERS='
c1737f2b
ACM
5include/uapi/drm/drm.h
6include/uapi/drm/i915_drm.h
67ef2879 7include/uapi/linux/fcntl.h
735e215e 8include/uapi/linux/kcmp.h
3ce97513 9include/uapi/linux/kvm.h
a4b20612 10include/uapi/linux/in.h
aeafd623 11include/uapi/linux/perf_event.h
43372794 12include/uapi/linux/prctl.h
450c86c9 13include/uapi/linux/sched.h
67ef2879 14include/uapi/linux/stat.h
d02b395e 15include/uapi/linux/vhost.h
a215684e 16include/uapi/sound/asound.h
aeafd623
JO
17include/linux/hash.h
18include/uapi/linux/hw_breakpoint.h
19arch/x86/include/asm/disabled-features.h
20arch/x86/include/asm/required-features.h
21arch/x86/include/asm/cpufeatures.h
22arch/arm/include/uapi/asm/perf_regs.h
23arch/arm64/include/uapi/asm/perf_regs.h
24arch/powerpc/include/uapi/asm/perf_regs.h
10b9baa7 25arch/s390/include/uapi/asm/perf_regs.h
aeafd623
JO
26arch/x86/include/uapi/asm/perf_regs.h
27arch/x86/include/uapi/asm/kvm.h
28arch/x86/include/uapi/asm/kvm_perf.h
29arch/x86/include/uapi/asm/svm.h
047726d1 30arch/x86/include/uapi/asm/unistd.h
aeafd623
JO
31arch/x86/include/uapi/asm/vmx.h
32arch/powerpc/include/uapi/asm/kvm.h
33arch/s390/include/uapi/asm/kvm.h
34arch/s390/include/uapi/asm/kvm_perf.h
a81c4213 35arch/s390/include/uapi/asm/ptrace.h
aeafd623
JO
36arch/s390/include/uapi/asm/sie.h
37arch/arm/include/uapi/asm/kvm.h
38arch/arm64/include/uapi/asm/kvm.h
34b009cf 39arch/arm64/include/uapi/asm/unistd.h
95f28190
HB
40arch/alpha/include/uapi/asm/errno.h
41arch/mips/include/asm/errno.h
42arch/mips/include/uapi/asm/errno.h
43arch/parisc/include/uapi/asm/errno.h
44arch/powerpc/include/uapi/asm/errno.h
45arch/sparc/include/uapi/asm/errno.h
46arch/x86/include/uapi/asm/errno.h
1350fb7d 47arch/powerpc/include/uapi/asm/unistd.h
aeafd623
JO
48include/asm-generic/bitops/arch_hweight.h
49include/asm-generic/bitops/const_hweight.h
50include/asm-generic/bitops/__fls.h
51include/asm-generic/bitops/fls.h
52include/asm-generic/bitops/fls64.h
53include/linux/coresight-pmu.h
28b8f954
HB
54include/uapi/asm-generic/errno.h
55include/uapi/asm-generic/errno-base.h
6375f0ab 56include/uapi/asm-generic/ioctls.h
aeafd623 57include/uapi/asm-generic/mman-common.h
34b009cf 58include/uapi/asm-generic/unistd.h
aeafd623
JO
59'
60
58247297
JO
61check_2 () {
62 file1=$1
63 file2=$2
aeafd623 64
58247297 65 shift
aeafd623 66 shift
aeafd623 67
58247297 68 cmd="diff $* $file1 $file2 > /dev/null"
aeafd623 69
51d8aac2
AK
70 test -f $file2 && {
71 eval $cmd || {
7ea6e983
JO
72 echo "Warning: Kernel ABI header at '$file1' differs from latest version at '$file2'" >&2
73 echo diff -u $file1 $file2
51d8aac2
AK
74 }
75 }
aeafd623
JO
76}
77
58247297
JO
78check () {
79 file=$1
80
81 shift
82
7ea6e983 83 check_2 tools/$file $file $*
58247297 84}
aeafd623 85
d7e05cea
ACM
86# Check if we have the kernel headers (tools/perf/../../include), else
87# we're probably on a detached tarball, so no point in trying to check
88# differences.
89test -d ../../include || exit 0
90
7ea6e983
JO
91cd ../..
92
aeafd623
JO
93# simple diff check
94for i in $HEADERS; do
95 check $i -B
96done
97
98# diff with extra ignore lines
15019e98
JO
99check arch/x86/lib/memcpy_64.S '-I "^EXPORT_SYMBOL" -I "^#include <asm/export.h>"'
100check arch/x86/lib/memset_64.S '-I "^EXPORT_SYMBOL" -I "^#include <asm/export.h>"'
101check include/uapi/asm-generic/mman.h '-I "^#include <\(uapi/\)*asm-generic/mman-common.h>"'
102check include/uapi/linux/mman.h '-I "^#include <\(uapi/\)*asm/mman.h>"'
7ea6e983 103
c9b51a01
JO
104# diff non-symmetric files
105check_2 tools/perf/arch/x86/entry/syscalls/syscall_64.tbl arch/x86/entry/syscalls/syscall_64.tbl
106
7ea6e983 107cd tools/perf