mirror of
				https://github.com/torvalds/linux.git
				synced 2025-10-31 08:38:45 +02:00 
			
		
		
		
	 c2a756891b
			
		
	
	
		c2a756891b
		
	
	
	
	
		
			
			The uAPI stddef header includes compiler_types.h, a kernel-only header, to make sure that kernel definitions of annotations like __counted_by() take precedence. There is a hack in scripts/headers_install.sh which strips includes of compiler.h and compiler_types.h when installing uAPI headers. While explicit handling makes sense for compiler.h, which is included all over the uAPI, compiler_types.h is only included by stddef.h (within the uAPI, obviously it's included in kernel code a lot). Remove the stripping from scripts/headers_install.sh and wrap the include of compiler_types.h in #ifdef __KERNEL__ instead. This should be equivalent functionally, but is easier to understand to a casual reader of the code. It also makes it easier to work with kernel headers directly from under tools/ Signed-off-by: Jakub Kicinski <kuba@kernel.org> Reviewed-by: Simon Horman <horms@kernel.org> Link: https://patch.msgid.link/20250825201828.2370083-1-kuba@kernel.org Signed-off-by: Paolo Abeni <pabeni@redhat.com>
		
			
				
	
	
		
			102 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable file
		
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable file
		
	
	
	
	
| #!/bin/sh
 | |
| # SPDX-License-Identifier: GPL-2.0
 | |
| 
 | |
| if [ $# -ne 2 ]
 | |
| then
 | |
| 	echo "Usage: headers_install.sh INFILE OUTFILE"
 | |
| 	echo
 | |
| 	echo "Prepares kernel header files for use by user space, by removing"
 | |
| 	echo "all compiler.h definitions and #includes, removing any"
 | |
| 	echo "#ifdef __KERNEL__ sections, and putting __underscores__ around"
 | |
| 	echo "asm/inline/volatile keywords."
 | |
| 	echo
 | |
| 	echo "INFILE: header file to operate on"
 | |
| 	echo "OUTFILE: output file which the processed header is written to"
 | |
| 
 | |
| 	exit 1
 | |
| fi
 | |
| 
 | |
| # Grab arguments
 | |
| INFILE=$1
 | |
| OUTFILE=$2
 | |
| TMPFILE=$OUTFILE.tmp
 | |
| 
 | |
| trap 'rm -f $OUTFILE $TMPFILE' EXIT
 | |
| 
 | |
| # SPDX-License-Identifier with GPL variants must have "WITH Linux-syscall-note"
 | |
| if [ -n "$(sed -n -e "/SPDX-License-Identifier:.*GPL-/{/WITH Linux-syscall-note/!p}" $INFILE)" ]; then
 | |
| 	echo "error: $INFILE: missing \"WITH Linux-syscall-note\" for SPDX-License-Identifier" >&2
 | |
| 	exit 1
 | |
| fi
 | |
| 
 | |
| sed -E -e '
 | |
| 	s/([[:space:](])(__user|__force|__iomem)[[:space:]]/\1/g
 | |
| 	s/__attribute_const__([[:space:]]|$)/\1/g
 | |
| 	s@^#include <linux/compiler.h>@@
 | |
| 	s/(^|[^a-zA-Z0-9])__packed([^a-zA-Z0-9_]|$)/\1__attribute__((packed))\2/g
 | |
| 	s/(^|[[:space:](])(inline|asm|volatile)([[:space:](]|$)/\1__\2__\3/g
 | |
| 	s@#(ifndef|define|endif[[:space:]]*/[*])[[:space:]]*_UAPI@#\1 @
 | |
| ' $INFILE > $TMPFILE || exit 1
 | |
| 
 | |
| scripts/unifdef -U__KERNEL__ -D__EXPORTED_HEADERS__ $TMPFILE > $OUTFILE
 | |
| [ $? -gt 1 ] && exit 1
 | |
| 
 | |
| # Remove /* ... */ style comments, and find CONFIG_ references in code
 | |
| configs=$(sed -e '
 | |
| :comment
 | |
| 	s:/\*[^*][^*]*:/*:
 | |
| 	s:/\*\*\**\([^/]\):/*\1:
 | |
| 	t comment
 | |
| 	s:/\*\*/: :
 | |
| 	t comment
 | |
| 	/\/\*/! b check
 | |
| 	N
 | |
| 	b comment
 | |
| :print
 | |
| 	P
 | |
| 	D
 | |
| :check
 | |
| 	s:^\(CONFIG_[[:alnum:]_]*\):\1\n:
 | |
| 	t print
 | |
| 	s:^[[:alnum:]_][[:alnum:]_]*::
 | |
| 	s:^[^[:alnum:]_][^[:alnum:]_]*::
 | |
| 	t check
 | |
| 	d
 | |
| ' $OUTFILE)
 | |
| 
 | |
| # The entries in the following list do not result in an error.
 | |
| # Please do not add a new entry. This list is only for existing ones.
 | |
| # The list will be reduced gradually, and deleted eventually. (hopefully)
 | |
| #
 | |
| # The format is <file-name>:<CONFIG-option> in each line.
 | |
| config_leak_ignores="
 | |
| arch/arc/include/uapi/asm/page.h:CONFIG_ARC_PAGE_SIZE_16K
 | |
| arch/arc/include/uapi/asm/page.h:CONFIG_ARC_PAGE_SIZE_4K
 | |
| arch/arc/include/uapi/asm/swab.h:CONFIG_ARC_HAS_SWAPE
 | |
| arch/arm/include/uapi/asm/ptrace.h:CONFIG_CPU_ENDIAN_BE8
 | |
| arch/nios2/include/uapi/asm/swab.h:CONFIG_NIOS2_CI_SWAB_NO
 | |
| arch/nios2/include/uapi/asm/swab.h:CONFIG_NIOS2_CI_SWAB_SUPPORT
 | |
| arch/x86/include/uapi/asm/auxvec.h:CONFIG_IA32_EMULATION
 | |
| arch/x86/include/uapi/asm/auxvec.h:CONFIG_X86_64
 | |
| "
 | |
| 
 | |
| for c in $configs
 | |
| do
 | |
| 	leak_error=1
 | |
| 
 | |
| 	for ignore in $config_leak_ignores
 | |
| 	do
 | |
| 		if echo "$INFILE:$c" | grep -q "$ignore$"; then
 | |
| 			leak_error=
 | |
| 			break
 | |
| 		fi
 | |
| 	done
 | |
| 
 | |
| 	if [ "$leak_error" = 1 ]; then
 | |
| 		echo "error: $INFILE: leak $c to user-space" >&2
 | |
| 		exit 1
 | |
| 	fi
 | |
| done
 | |
| 
 | |
| rm -f $TMPFILE
 | |
| trap - EXIT
 |