forked from Minki/linux
locking/atomics: Check generated headers are up-to-date
Now that all the generated atomic headers are in place, it would be good to ensure that: a) the headers are up-to-date when scripting changes. b) developers don't directly modify the generated headers. To ensure both of these properties, let's add a Kbuild step to check that the generated headers are up-to-date. Signed-off-by: Mark Rutland <mark.rutland@arm.com> Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Cc: linux-arm-kernel@lists.infradead.org Cc: catalin.marinas@arm.com Cc: Will Deacon <will.deacon@arm.com> Cc: linuxdrivers@attotech.com Cc: dvyukov@google.com Cc: Boqun Feng <boqun.feng@gmail.com> Cc: arnd@arndb.de Cc: aryabinin@virtuozzo.com Cc: glider@google.com Link: http://lkml.kernel.org/r/20180904104830.2975-6-mark.rutland@arm.com Signed-off-by: Ingo Molnar <mingo@kernel.org>
This commit is contained in:
parent
aa525d0638
commit
8d32588077
18
Kbuild
18
Kbuild
@ -6,7 +6,8 @@
|
|||||||
# 2) Generate timeconst.h
|
# 2) Generate timeconst.h
|
||||||
# 3) Generate asm-offsets.h (may need bounds.h and timeconst.h)
|
# 3) Generate asm-offsets.h (may need bounds.h and timeconst.h)
|
||||||
# 4) Check for missing system calls
|
# 4) Check for missing system calls
|
||||||
# 5) Generate constants.py (may need bounds.h)
|
# 5) check atomics headers are up-to-date
|
||||||
|
# 6) Generate constants.py (may need bounds.h)
|
||||||
|
|
||||||
#####
|
#####
|
||||||
# 1) Generate bounds.h
|
# 1) Generate bounds.h
|
||||||
@ -72,7 +73,20 @@ missing-syscalls: scripts/checksyscalls.sh $(offsets-file) FORCE
|
|||||||
$(call cmd,syscalls)
|
$(call cmd,syscalls)
|
||||||
|
|
||||||
#####
|
#####
|
||||||
# 5) Generate constants for Python GDB integration
|
# 5) Check atomic headers are up-to-date
|
||||||
|
#
|
||||||
|
|
||||||
|
always += old-atomics
|
||||||
|
targets += old-atomics
|
||||||
|
|
||||||
|
quiet_cmd_atomics = CALL $<
|
||||||
|
cmd_atomics = $(CONFIG_SHELL) scripts/atomic/check-atomics.sh
|
||||||
|
|
||||||
|
old-atomics: scripts/atomic/check-atomics.sh FORCE
|
||||||
|
$(call cmd,atomics)
|
||||||
|
|
||||||
|
#####
|
||||||
|
# 6) Generate constants for Python GDB integration
|
||||||
#
|
#
|
||||||
|
|
||||||
extra-$(CONFIG_GDB_SCRIPTS) += build_constants_py
|
extra-$(CONFIG_GDB_SCRIPTS) += build_constants_py
|
||||||
|
19
scripts/atomic/check-atomics.sh
Normal file
19
scripts/atomic/check-atomics.sh
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
#
|
||||||
|
# Check if atomic headers are up-to-date
|
||||||
|
|
||||||
|
ATOMICDIR=$(dirname $0)
|
||||||
|
ATOMICTBL=${ATOMICDIR}/atomics.tbl
|
||||||
|
LINUXDIR=${ATOMICDIR}/../..
|
||||||
|
|
||||||
|
cat <<EOF |
|
||||||
|
gen-atomic-instrumented.sh asm-generic/atomic-instrumented.h
|
||||||
|
gen-atomic-long.sh asm-generic/atomic-long.h
|
||||||
|
gen-atomic-fallback.sh linux/atomic-fallback.h
|
||||||
|
EOF
|
||||||
|
while read script header; do
|
||||||
|
if ! (${ATOMICDIR}/${script} ${ATOMICTBL} | diff - ${LINUXDIR}/include/${header} > /dev/null); then
|
||||||
|
printf "warning: include/${header} is out-of-date.\n"
|
||||||
|
fi
|
||||||
|
done
|
Loading…
Reference in New Issue
Block a user