mirror of
				https://git.proxmox.com/git/mirror_zfs
				synced 2025-10-27 21:07:53 +00:00 
			
		
		
		
	 836136961a
			
		
	
	
		836136961a
		
			
		
	
	
	
	
		
			
			Strengthen static code analysis for shell scripts. Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: John Kennedy <john.kennedy@delphix.com> Signed-off-by: szubersk <szuberskidamian@gmail.com> Closes #12914
		
			
				
	
	
		
			44 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| if ! command -v scanelf > /dev/null; then
 | |
|     echo "scanelf (from pax-utils) is required for these checks." >&2
 | |
|     exit 3
 | |
| fi
 | |
| 
 | |
| RET=0
 | |
| 
 | |
| # check for exec stacks
 | |
| OUT=$(scanelf -qyRAF '%e %p' "$1")
 | |
| 
 | |
| if [ x"${OUT}" != x ]; then
 | |
|     RET=2
 | |
|     echo "The following files contain writable and executable sections"
 | |
|     echo " Files with such sections will not work properly (or at all!) on some"
 | |
|     echo " architectures/operating systems."
 | |
|     echo " For more information, see:"
 | |
|     echo "   https://wiki.gentoo.org/wiki/Hardened/GNU_stack_quickstart"
 | |
|     echo
 | |
|     echo "${OUT}"
 | |
|     echo
 | |
| fi
 | |
| 
 | |
| 
 | |
| # check for TEXTRELS
 | |
| OUT=$(scanelf -qyRAF '%T %p' "$1")
 | |
| 
 | |
| if [ x"${OUT}" != x ]; then
 | |
|     RET=2
 | |
|     echo "The following files contain runtime text relocations"
 | |
|     echo " Text relocations force the dynamic linker to perform extra"
 | |
|     echo " work at startup, waste system resources, and may pose a security"
 | |
|     echo " risk.  On some architectures, the code may not even function"
 | |
|     echo " properly, if at all."
 | |
|     echo " For more information, see:"
 | |
|     echo "   https://wiki.gentoo.org/wiki/Hardened/HOWTO_locate_and_fix_textrels"
 | |
|     echo
 | |
|     echo "${OUT}"
 | |
|     echo
 | |
| fi
 | |
| 
 | |
| exit "$RET"
 |