mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 10:40:15 +02:00 
			
		
		
		
	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
					
				
					 2 changed files with 35 additions and 2 deletions
				
			
		
							
								
								
									
										18
									
								
								Kbuild
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								Kbuild
									
									
									
									
									
								
							| 
						 | 
				
			
			@ -6,7 +6,8 @@
 | 
			
		|||
# 2) Generate timeconst.h
 | 
			
		||||
# 3) Generate asm-offsets.h (may need bounds.h and timeconst.h)
 | 
			
		||||
# 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
 | 
			
		||||
| 
						 | 
				
			
			@ -72,7 +73,20 @@ missing-syscalls: scripts/checksyscalls.sh $(offsets-file) FORCE
 | 
			
		|||
	$(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
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										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 a new issue