diff options
Diffstat (limited to 'scripts')
| -rw-r--r-- | scripts/Makefile.build | 14 | ||||
| -rwxr-xr-x | scripts/bloat-o-meter | 7 | ||||
| -rwxr-xr-x | scripts/checkpatch.pl | 24 | ||||
| -rwxr-xr-x | scripts/decodecode | 8 | ||||
| -rwxr-xr-x | scripts/faddr2line | 21 | ||||
| -rw-r--r-- | scripts/gdb/linux/tasks.py | 2 | ||||
| -rw-r--r-- | scripts/genksyms/.gitignore | 1 | ||||
| -rw-r--r-- | scripts/kconfig/expr.c | 5 | ||||
| -rwxr-xr-x | scripts/kernel-doc | 2 | 
9 files changed, 45 insertions, 39 deletions
| diff --git a/scripts/Makefile.build b/scripts/Makefile.build index cb8997ed0149..47cddf32aeba 100644 --- a/scripts/Makefile.build +++ b/scripts/Makefile.build @@ -265,12 +265,18 @@ else  objtool_args += $(call cc-ifversion, -lt, 0405, --no-unreachable)  endif +ifdef CONFIG_MODVERSIONS +objtool_o = $(@D)/.tmp_$(@F) +else +objtool_o = $(@) +endif +  # 'OBJECT_FILES_NON_STANDARD := y': skip objtool checking for a directory  # 'OBJECT_FILES_NON_STANDARD_foo.o := 'y': skip objtool checking for a file  # 'OBJECT_FILES_NON_STANDARD_foo.o := 'n': override directory skip for a file  cmd_objtool = $(if $(patsubst y%,, \  	$(OBJECT_FILES_NON_STANDARD_$(basetarget).o)$(OBJECT_FILES_NON_STANDARD)n), \ -	$(__objtool_obj) $(objtool_args) "$(@)";) +	$(__objtool_obj) $(objtool_args) "$(objtool_o)";)  objtool_obj = $(if $(patsubst y%,, \  	$(OBJECT_FILES_NON_STANDARD_$(basetarget).o)$(OBJECT_FILES_NON_STANDARD)n), \  	$(__objtool_obj)) @@ -286,16 +292,16 @@ objtool_dep = $(objtool_obj)					\  define rule_cc_o_c  	$(call echo-cmd,checksrc) $(cmd_checksrc)			  \  	$(call cmd_and_fixdep,cc_o_c)					  \ -	$(cmd_modversions_c)						  \  	$(cmd_checkdoc)							  \  	$(call echo-cmd,objtool) $(cmd_objtool)				  \ +	$(cmd_modversions_c)						  \  	$(call echo-cmd,record_mcount) $(cmd_record_mcount)  endef  define rule_as_o_S  	$(call cmd_and_fixdep,as_o_S)					  \ -	$(cmd_modversions_S)						  \ -	$(call echo-cmd,objtool) $(cmd_objtool) +	$(call echo-cmd,objtool) $(cmd_objtool)				  \ +	$(cmd_modversions_S)  endef  # List module undefined symbols (or empty line if not enabled) diff --git a/scripts/bloat-o-meter b/scripts/bloat-o-meter index 6f099f915dcf..94b664817ad9 100755 --- a/scripts/bloat-o-meter +++ b/scripts/bloat-o-meter @@ -83,8 +83,11 @@ def print_result(symboltype, symbolformat, argc):      for d, n in delta:          if d: print("%-40s %7s %7s %+7d" % (n, old.get(n,"-"), new.get(n,"-"), d)) -    print("Total: Before=%d, After=%d, chg %+.2f%%" % \ -        (otot, ntot, (ntot - otot)*100.0/otot)) +    if otot: +        percent = (ntot - otot) * 100.0 / otot +    else: +        percent = 0 +    print("Total: Before=%d, After=%d, chg %+.2f%%" % (otot, ntot, percent))  if sys.argv[1] == "-c":      print_result("Function", "tT", 3) diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl index 95cda3ecc66b..31031f10fe56 100755 --- a/scripts/checkpatch.pl +++ b/scripts/checkpatch.pl @@ -5753,7 +5753,7 @@ sub process {  		        for (my $count = $linenr; $count <= $lc; $count++) {  				my $fmt = get_quoted_string($lines[$count - 1], raw_line($count, 0));  				$fmt =~ s/%%//g; -				if ($fmt =~ /(\%[\*\d\.]*p(?![\WFfSsBKRraEhMmIiUDdgVCbGNO]).)/) { +				if ($fmt =~ /(\%[\*\d\.]*p(?![\WFfSsBKRraEhMmIiUDdgVCbGNOx]).)/) {  					$bad_extension = $1;  					last;  				} @@ -6233,28 +6233,6 @@ sub process {  			}  		} -# whine about ACCESS_ONCE -		if ($^V && $^V ge 5.10.0 && -		    $line =~ /\bACCESS_ONCE\s*$balanced_parens\s*(=(?!=))?\s*($FuncArg)?/) { -			my $par = $1; -			my $eq = $2; -			my $fun = $3; -			$par =~ s/^\(\s*(.*)\s*\)$/$1/; -			if (defined($eq)) { -				if (WARN("PREFER_WRITE_ONCE", -					 "Prefer WRITE_ONCE(<FOO>, <BAR>) over ACCESS_ONCE(<FOO>) = <BAR>\n" . $herecurr) && -				    $fix) { -					$fixed[$fixlinenr] =~ s/\bACCESS_ONCE\s*\(\s*\Q$par\E\s*\)\s*$eq\s*\Q$fun\E/WRITE_ONCE($par, $fun)/; -				} -			} else { -				if (WARN("PREFER_READ_ONCE", -					 "Prefer READ_ONCE(<FOO>) over ACCESS_ONCE(<FOO>)\n" . $herecurr) && -				    $fix) { -					$fixed[$fixlinenr] =~ s/\bACCESS_ONCE\s*\(\s*\Q$par\E\s*\)/READ_ONCE($par)/; -				} -			} -		} -  # check for mutex_trylock_recursive usage  		if ($line =~ /mutex_trylock_recursive/) {  			ERROR("LOCKING", diff --git a/scripts/decodecode b/scripts/decodecode index 438120da1361..5ea071099330 100755 --- a/scripts/decodecode +++ b/scripts/decodecode @@ -59,6 +59,14 @@ disas() {  		${CROSS_COMPILE}strip $1.o  	fi +	if [ "$ARCH" = "arm64" ]; then +		if [ $width -eq 4 ]; then +			type=inst +		fi + +		${CROSS_COMPILE}strip $1.o +	fi +  	${CROSS_COMPILE}objdump $OBJDUMPFLAGS -S $1.o | \  		grep -v "/tmp\|Disassembly\|\.text\|^$" > $1.dis 2>&1  } diff --git a/scripts/faddr2line b/scripts/faddr2line index 1f5ce959f596..7721d5b2b0c0 100755 --- a/scripts/faddr2line +++ b/scripts/faddr2line @@ -44,9 +44,16 @@  set -o errexit  set -o nounset +READELF="${CROSS_COMPILE:-}readelf" +ADDR2LINE="${CROSS_COMPILE:-}addr2line" +SIZE="${CROSS_COMPILE:-}size" +NM="${CROSS_COMPILE:-}nm" +  command -v awk >/dev/null 2>&1 || die "awk isn't installed" -command -v readelf >/dev/null 2>&1 || die "readelf isn't installed" -command -v addr2line >/dev/null 2>&1 || die "addr2line isn't installed" +command -v ${READELF} >/dev/null 2>&1 || die "readelf isn't installed" +command -v ${ADDR2LINE} >/dev/null 2>&1 || die "addr2line isn't installed" +command -v ${SIZE} >/dev/null 2>&1 || die "size isn't installed" +command -v ${NM} >/dev/null 2>&1 || die "nm isn't installed"  usage() {  	echo "usage: faddr2line <object file> <func+offset> <func+offset>..." >&2 @@ -69,10 +76,10 @@ die() {  find_dir_prefix() {  	local objfile=$1 -	local start_kernel_addr=$(readelf -sW $objfile | awk '$8 == "start_kernel" {printf "0x%s", $2}') +	local start_kernel_addr=$(${READELF} -sW $objfile | awk '$8 == "start_kernel" {printf "0x%s", $2}')  	[[ -z $start_kernel_addr ]] && return -	local file_line=$(addr2line -e $objfile $start_kernel_addr) +	local file_line=$(${ADDR2LINE} -e $objfile $start_kernel_addr)  	[[ -z $file_line ]] && return  	local prefix=${file_line%init/main.c:*} @@ -104,7 +111,7 @@ __faddr2line() {  	# Go through each of the object's symbols which match the func name.  	# In rare cases there might be duplicates. -	file_end=$(size -Ax $objfile | awk '$1 == ".text" {print $2}') +	file_end=$(${SIZE} -Ax $objfile | awk '$1 == ".text" {print $2}')  	while read symbol; do  		local fields=($symbol)  		local sym_base=0x${fields[0]} @@ -156,10 +163,10 @@ __faddr2line() {  		# pass real address to addr2line  		echo "$func+$offset/$sym_size:" -		addr2line -fpie $objfile $addr | sed "s; $dir_prefix\(\./\)*; ;" +		${ADDR2LINE} -fpie $objfile $addr | sed "s; $dir_prefix\(\./\)*; ;"  		DONE=1 -	done < <(nm -n $objfile | awk -v fn=$func -v end=$file_end '$3 == fn { found=1; line=$0; start=$1; next } found == 1 { found=0; print line, "0x"$1 } END {if (found == 1) print line, end; }') +	done < <(${NM} -n $objfile | awk -v fn=$func -v end=$file_end '$3 == fn { found=1; line=$0; start=$1; next } found == 1 { found=0; print line, "0x"$1 } END {if (found == 1) print line, end; }')  }  [[ $# -lt 2 ]] && usage diff --git a/scripts/gdb/linux/tasks.py b/scripts/gdb/linux/tasks.py index 1bf949c43b76..f6ab3ccf698f 100644 --- a/scripts/gdb/linux/tasks.py +++ b/scripts/gdb/linux/tasks.py @@ -96,6 +96,8 @@ def get_thread_info(task):          thread_info_addr = task.address + ia64_task_size          thread_info = thread_info_addr.cast(thread_info_ptr_type)      else: +        if task.type.fields()[0].type == thread_info_type.get_type(): +            return task['thread_info']          thread_info = task['stack'].cast(thread_info_ptr_type)      return thread_info.dereference() diff --git a/scripts/genksyms/.gitignore b/scripts/genksyms/.gitignore index 86dc07a01b43..e7836b47f060 100644 --- a/scripts/genksyms/.gitignore +++ b/scripts/genksyms/.gitignore @@ -1,4 +1,3 @@ -*.hash.c  *.lex.c  *.tab.c  *.tab.h diff --git a/scripts/kconfig/expr.c b/scripts/kconfig/expr.c index cbf4996dd9c1..8cee597d33a5 100644 --- a/scripts/kconfig/expr.c +++ b/scripts/kconfig/expr.c @@ -893,7 +893,10 @@ static enum string_value_kind expr_parse_string(const char *str,  	switch (type) {  	case S_BOOLEAN:  	case S_TRISTATE: -		return k_string; +		val->s = !strcmp(str, "n") ? 0 : +			 !strcmp(str, "m") ? 1 : +			 !strcmp(str, "y") ? 2 : -1; +		return k_signed;  	case S_INT:  		val->s = strtoll(str, &tail, 10);  		kind = k_signed; diff --git a/scripts/kernel-doc b/scripts/kernel-doc index bd29a92b4b48..df0f045a9a89 100755 --- a/scripts/kernel-doc +++ b/scripts/kernel-doc @@ -3248,4 +3248,4 @@ if ($verbose && $warnings) {    print STDERR "$warnings warnings\n";  } -exit($errors); +exit($output_mode eq "none" ? 0 : $errors); |