#!/bin/bash # SPDX-License-Identifier: GPL-2.0 # (c) 2014, Sasha Levin <sasha.levin@oracle.com> #set -x usage() { echo "Usage:" echo " $0 -r <release> | <vmlinux> [<base path>|auto] [<modules path>]" } # Try to find a Rust demangler if type llvm-cxxfilt >/dev/null 2>&1 ; then cppfilt=llvm-cxxfilt elif type c++filt >/dev/null 2>&1 ; then cppfilt=c++filt cppfilt_opts=-i fi UTIL_SUFFIX= if [[ -z ${LLVM:-} ]]; then UTIL_PREFIX=${CROSS_COMPILE:-} else UTIL_PREFIX=llvm- if [[ ${LLVM} == */ ]]; then UTIL_PREFIX=${LLVM}${UTIL_PREFIX} elif [[ ${LLVM} == -* ]]; then UTIL_SUFFIX=${LLVM} fi fi READELF=${UTIL_PREFIX}readelf${UTIL_SUFFIX} ADDR2LINE=${UTIL_PREFIX}addr2line${UTIL_SUFFIX} if [[ $1 == "-r" ]] ; then vmlinux="" basepath="auto" modpath="" release=$2 for fn in {,/usr/lib/debug}/boot/vmlinux-$release{,.debug} /lib/modules/$release{,/build}/vmlinux ; do if [ -e "$fn" ] ; then vmlinux=$fn break fi done if [[ $vmlinux == "" ]] ; then echo "ERROR! vmlinux image for release $release is not found" >&2 usage exit 2 fi else vmlinux=$1 basepath=${2-auto} modpath=$3 release="" debuginfod= # Can we use debuginfod-find? if type debuginfod-find >/dev/null 2>&1 ; then debuginfod=${1-only} fi if [[ $vmlinux == "" && -z $debuginfod ]] ; then echo "ERROR! vmlinux image must be specified" >&2 usage exit 1 fi fi declare aarray_support=true declare -A cache 2>/dev/null if [[ $? != 0 ]]; then aarray_support=false else declare -A modcache fi find_module() { if [[ -n $debuginfod ]] ; then if [[ -n $modbuildid ]] ; then debuginfod-find debuginfo $modbuildid && return fi # Only using debuginfod so don't try to find vmlinux module path if [[ $debuginfod == "only" ]] ; then return fi fi if [[ "$modpath" != "" ]] ; then for fn in $(find "$modpath" -name "${module//_/[-_]}.ko*") ; do if ${READELF} -WS "$fn" | grep -qwF .debug_line ; then echo $fn return fi done return 1 fi modpath=$(dirname "$vmlinux") find_module && return if [[ $release == "" ]] ; then release=$(gdb -ex 'print init_uts_ns.name.release' -ex 'quit' -quiet -batch "$vmlinux" 2>/dev/null | sed -n 's/\$1 = "\(.*\)".*/\1/p') fi for dn in {/usr/lib/debug,}/lib/modules/$release ; do if [ -e "$dn" ] ; then modpath="$dn" find_module && return fi done modpath="" return 1 } parse_symbol() { # The structure of symbol at this point is: # ([name]+[offset]/[total length]) # # For example: # do_basic_setup+0x9c/0xbf if [[ $module == "" ]] ; then local objfile=$vmlinux elif [[ $aarray_support == true && "${modcache[$module]+isset}" == "isset" ]]; then local objfile=${modcache[$module]} else local objfile=$(find_module) if [[ $objfile == "" ]] ; then echo "WARNING! Modules path isn't set, but is needed to parse this symbol" >&2 return fi if [[ $aarray_support == true ]]; then modcache[$module]=$objfile fi fi # Remove the englobing parenthesis symbol=${symbol#\(} symbol=${symbol%\)} # Strip segment local segment if [[ $symbol == *:* ]] ; then segment=${symbol%%:*}: symbol=${symbol#*:} fi # Strip the symbol name so that we could look it up local name=${symbol%+*} # Use 'nm vmlinux' to figure out the base address of said symbol. # It's actually faster to call it every time than to load it # all into bash. if [[ $aarray_support == true && "${cache[$module,$name]+isset}" == "isset" ]]; then local base_addr=${cache[$module,$name]} else local base_addr=$(nm "$objfile" 2>/dev/null | awk '$3 == "'$name'" && ($2 == "t" || $2 == "T") {print $1; exit}') if [[ $base_addr == "" ]] ; then # address not found return fi if [[ $aarray_support == true ]]; then cache[$module,$name]="$base_addr" fi fi # Let's start doing the math to get the exact address into the # symbol. First, strip out the symbol total length. local expr=${symbol%/*} # Now, replace the symbol name with the base address we found # before. expr=${expr/$name/0x$base_addr} # Evaluate it to find the actual address expr=$((expr)) local address=$(printf "%x\n" "$expr") # Pass it to addr2line to get filename and line number # Could get more than one result if [[ $aarray_support == true && "${cache[$module,$address]+isset}" == "isset" ]]; then local code=${cache[$module,$address]} else local code=$(${ADDR2LINE} -i -e "$objfile" "$address" 2>/dev/null) if [[ $aarray_support == true ]]; then cache[$module,$address]=$code fi fi # addr2line doesn't return a proper error code if it fails, so # we detect it using the value it prints so that we could preserve # the offset/size into the function and bail out if [[ $code == "??:0" ]]; then return fi # Strip out the base of the path on each line code=$(while read -r line; do echo "${line#$basepath/}"; done <<< "$code") # In the case of inlines, move everything to same line code=${code//$'\n'/' '} # Demangle if the name looks like a Rust symbol and if # we got a Rust demangler if [[ $name =~ ^_R && $cppfilt != "" ]] ; then name=$("$cppfilt" "$cppfilt_opts" "$name") fi # Replace old address with pretty line numbers symbol="$segment$name ($code)" } debuginfod_get_vmlinux() { local vmlinux_buildid=${1##* } if [[ $vmlinux != "" ]]; then return fi if [[ $vmlinux_buildid =~ ^[0-9a-f]+ ]]; then vmlinux=$(debuginfod-find debuginfo $vmlinux_buildid) if [[ $? -ne 0 ]] ; then echo "ERROR! vmlinux image not found via debuginfod-find" >&2 usage exit 2 fi return fi echo "ERROR! Build ID for vmlinux not found. Try passing -r or specifying vmlinux" >&2 usage exit 2 } decode_code() { local scripts=`dirname "${BASH_SOURCE[0]}"` echo "$1" | $scripts/decodecode } handle_line() { if [[ $basepath == "auto" && $vmlinux != "" ]] ; then module="" symbol="kernel_init+0x0/0x0" parse_symbol basepath=${symbol#kernel_init (} basepath=${basepath%/init/main.c:*)} fi local words # Tokenize read -a words <<<"$1" # Remove hex numbers. Do it ourselves until it happens in the # kernel # We need to know the index of the last element before we # remove elements because arrays are sparse local last=$(( ${#words[@]} - 1 )) for i in "${!words[@]}"; do # Remove the address if [[ ${words[$i]} =~ \[\<([^]]+)\>\] ]]; then unset words[$i] fi # Format timestamps with tabs if [[ ${words[$i]} == \[ && ${words[$i+1]} == *\] ]]; then unset words[$i] words[$i+1]=$(printf "[%13s\n" "${words[$i+1]}") fi done if [[ ${words[$last]} =~ ^[0-9a-f]+\] ]]; then words[$last-1]="${words[$last-1]} ${words[$last]}" unset words[$last] last=$(( $last - 1 )) fi if [[ ${words[$last]} =~ \[([^]]+)\] ]]; then module=${words[$last]} module=${module#\[} module=${module%\]} modbuildid=${module#* } module=${module% *} if [[ $modbuildid == $module ]]; then modbuildid= fi symbol=${words[$last-1]} unset words[$last-1] else # The symbol is the last element, process it symbol=${words[$last]} module= modbuildid= fi unset words[$last] parse_symbol # modifies $symbol # Add up the line number to the symbol echo "${words[@]}" "$symbol $module" } while read line; do # Let's see if we have an address in the line if [[ $line =~ \[\<([^]]+)\>\] ]] || [[ $line =~ [^+\ ]+\+0x[0-9a-f]+/0x[0-9a-f]+ ]]; then # Translate address to line numbers handle_line "$line" # Is it a code line? elif [[ $line == *Code:* ]]; then decode_code "$line" # Is it a version line? elif [[ -n $debuginfod && $line =~ PID:\ [0-9]+\ Comm: ]]; then debuginfod_get_vmlinux "$line" else # Nothing special in this line, show it as is echo "$line" fi done
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
atomic | Folder | 0755 |
|
|
basic | Folder | 0755 |
|
|
clang-tools | Folder | 0755 |
|
|
coccinelle | Folder | 0755 |
|
|
dtc | Folder | 0755 |
|
|
dummy-tools | Folder | 0755 |
|
|
gcc-plugins | Folder | 0755 |
|
|
gdb | Folder | 0755 |
|
|
genksyms | Folder | 0755 |
|
|
kconfig | Folder | 0755 |
|
|
ksymoops | Folder | 0755 |
|
|
mod | Folder | 0755 |
|
|
package | Folder | 0755 |
|
|
selinux | Folder | 0755 |
|
|
tracing | Folder | 0755 |
|
|
.asn1_compiler.cmd | File | 726 B | 0644 |
|
.bin2c.cmd | File | 421 B | 0644 |
|
.extract-cert.cmd | File | 499 B | 0644 |
|
.insert-sys-cert.cmd | File | 521 B | 0644 |
|
.kallsyms.cmd | File | 451 B | 0644 |
|
.sign-file.cmd | File | 469 B | 0644 |
|
.sorttable.cmd | File | 782 B | 0644 |
|
Kbuild.include | File | 10.15 KB | 0644 |
|
Kconfig.include | File | 2.56 KB | 0644 |
|
Lindent | File | 502 B | 0755 |
|
Makefile | File | 1.64 KB | 0644 |
|
Makefile.asm-generic | File | 1.82 KB | 0644 |
|
Makefile.build | File | 19.66 KB | 0644 |
|
Makefile.clang | File | 1.59 KB | 0644 |
|
Makefile.clean | File | 2.2 KB | 0644 |
|
Makefile.compiler | File | 2.54 KB | 0644 |
|
Makefile.dtbinst | File | 1007 B | 0644 |
|
Makefile.extrawarn | File | 2.99 KB | 0644 |
|
Makefile.gcc-plugins | File | 2.71 KB | 0644 |
|
Makefile.headersinst | File | 2.88 KB | 0644 |
|
Makefile.host | File | 4.63 KB | 0644 |
|
Makefile.kasan | File | 1.67 KB | 0644 |
|
Makefile.kcov | File | 333 B | 0644 |
|
Makefile.kcsan | File | 739 B | 0644 |
|
Makefile.lib | File | 18.02 KB | 0644 |
|
Makefile.modfinal | File | 2.73 KB | 0644 |
|
Makefile.modinst | File | 2.51 KB | 0644 |
|
Makefile.modpost | File | 4.37 KB | 0644 |
|
Makefile.package | File | 6.61 KB | 0644 |
|
Makefile.ubsan | File | 770 B | 0644 |
|
Makefile.userprogs | File | 1.57 KB | 0644 |
|
adjust_autoksyms.sh | File | 2.07 KB | 0755 |
|
as-version.sh | File | 2.02 KB | 0755 |
|
asn1_compiler | File | 35.11 KB | 0755 |
|
asn1_compiler.c | File | 35.33 KB | 0644 |
|
bin2c | File | 16.44 KB | 0755 |
|
bin2c.c | File | 743 B | 0644 |
|
bloat-o-meter | File | 3.36 KB | 0755 |
|
bootgraph.pl | File | 5.64 KB | 0755 |
|
bpf_doc.py | File | 24.98 KB | 0755 |
|
cc-can-link.sh | File | 166 B | 0755 |
|
cc-version.sh | File | 1.51 KB | 0755 |
|
check-sysctl-docs | File | 4.37 KB | 0755 |
|
check_extable.sh | File | 4.93 KB | 0755 |
|
checkdeclares.pl | File | 1.1 KB | 0755 |
|
checkincludes.pl | File | 1.94 KB | 0755 |
|
checkkconfigsymbols.py | File | 15.75 KB | 0755 |
|
checkpatch.pl | File | 223.75 KB | 0755 |
|
checkstack.pl | File | 5.86 KB | 0755 |
|
checksyscalls.sh | File | 7.42 KB | 0755 |
|
checkversion.pl | File | 2.16 KB | 0755 |
|
cleanfile | File | 3.46 KB | 0755 |
|
cleanpatch | File | 5.06 KB | 0755 |
|
coccicheck | File | 7.89 KB | 0755 |
|
config | File | 4.67 KB | 0755 |
|
const_structs.checkpatch | File | 1009 B | 0644 |
|
decode_stacktrace.sh | File | 7.51 KB | 0755 |
|
decodecode | File | 2.88 KB | 0755 |
|
depmod.sh | File | 1.41 KB | 0755 |
|
dev-needs.sh | File | 6.07 KB | 0755 |
|
diffconfig | File | 4.12 KB | 0755 |
|
documentation-file-ref-check | File | 5.55 KB | 0755 |
|
export_report.pl | File | 4.5 KB | 0755 |
|
extract-cert | File | 17.89 KB | 0755 |
|
extract-cert.c | File | 3.63 KB | 0644 |
|
extract-ikconfig | File | 1.69 KB | 0755 |
|
extract-module-sig.pl | File | 3.66 KB | 0755 |
|
extract-sys-certs.pl | File | 3.75 KB | 0755 |
|
extract-vmlinux | File | 1.66 KB | 0755 |
|
extract_xc3028.pl | File | 44.62 KB | 0755 |
|
faddr2line | File | 8.17 KB | 0755 |
|
file-size.sh | File | 86 B | 0755 |
|
find-unused-docs.sh | File | 1.27 KB | 0755 |
|
gcc-goto.sh | File | 511 B | 0755 |
|
gcc-ld | File | 711 B | 0755 |
|
gcc-x86_32-has-stack-protector.sh | File | 405 B | 0755 |
|
gcc-x86_64-has-stack-protector.sh | File | 195 B | 0755 |
|
gen_autoksyms.sh | File | 1.47 KB | 0755 |
|
gen_ksymdeps.sh | File | 556 B | 0755 |
|
generate_initcall_order.pl | File | 5.95 KB | 0755 |
|
get_abi.pl | File | 15.1 KB | 0755 |
|
get_dvb_firmware | File | 24.54 KB | 0755 |
|
get_feat.pl | File | 14.34 KB | 0755 |
|
get_maintainer.pl | File | 67.13 KB | 0755 |
|
gfp-translate | File | 1.69 KB | 0755 |
|
headerdep.pl | File | 3.5 KB | 0755 |
|
headers_check.pl | File | 3.73 KB | 0755 |
|
headers_install.sh | File | 3.35 KB | 0755 |
|
insert-sys-cert | File | 22.21 KB | 0755 |
|
insert-sys-cert.c | File | 13.08 KB | 0644 |
|
jobserver-exec | File | 2.16 KB | 0755 |
|
kallsyms | File | 22.47 KB | 0755 |
|
kallsyms.c | File | 18.06 KB | 0644 |
|
kernel-doc | File | 68.74 KB | 0755 |
|
ld-version.sh | File | 1.82 KB | 0755 |
|
leaking_addresses.pl | File | 12.8 KB | 0755 |
|
link-vmlinux.sh | File | 10.92 KB | 0755 |
|
makelst | File | 808 B | 0755 |
|
markup_oops.pl | File | 7.92 KB | 0755 |
|
min-tool-version.sh | File | 558 B | 0755 |
|
mkcompile_h | File | 2.48 KB | 0755 |
|
mksysmap | File | 1.34 KB | 0755 |
|
mkuboot.sh | File | 414 B | 0755 |
|
module.lds | File | 597 B | 0644 |
|
module.lds.S | File | 1.65 KB | 0644 |
|
modules-check.sh | File | 427 B | 0755 |
|
nsdeps | File | 1.72 KB | 0644 |
|
objdiff | File | 2.84 KB | 0755 |
|
pahole-flags.sh | File | 749 B | 0755 |
|
pahole-version.sh | File | 269 B | 0755 |
|
parse-maintainers.pl | File | 4.54 KB | 0755 |
|
patch-kernel | File | 9.95 KB | 0755 |
|
profile2linkerlist.pl | File | 414 B | 0755 |
|
prune-kernel | File | 708 B | 0755 |
|
recordmcount.c | File | 16.75 KB | 0644 |
|
recordmcount.h | File | 19.37 KB | 0644 |
|
recordmcount.pl | File | 17.63 KB | 0755 |
|
remove-stale-files | File | 1.3 KB | 0755 |
|
setlocalversion | File | 3.5 KB | 0755 |
|
show_delta | File | 3.01 KB | 0755 |
|
sign-file | File | 26.52 KB | 0755 |
|
sign-file.c | File | 9.93 KB | 0644 |
|
sorttable | File | 21.51 KB | 0755 |
|
sorttable.c | File | 8.74 KB | 0644 |
|
sorttable.h | File | 9.65 KB | 0644 |
|
spdxcheck-test.sh | File | 277 B | 0644 |
|
spdxcheck.py | File | 10.09 KB | 0755 |
|
spelling.txt | File | 31.88 KB | 0644 |
|
sphinx-pre-install | File | 24.45 KB | 0755 |
|
split-man.pl | File | 604 B | 0755 |
|
stackdelta | File | 1.84 KB | 0755 |
|
stackusage | File | 794 B | 0755 |
|
subarch.include | File | 619 B | 0644 |
|
syscallhdr.sh | File | 1.89 KB | 0755 |
|
syscallnr.sh | File | 1.45 KB | 0755 |
|
syscalltbl.sh | File | 1.45 KB | 0755 |
|
tags.sh | File | 9.87 KB | 0755 |
|
tools-support-relr.sh | File | 546 B | 0755 |
|
ubuntu-retpoline-extract-one | File | 7.26 KB | 0644 |
|
unifdef.c | File | 34.8 KB | 0644 |
|
ver_linux | File | 2.59 KB | 0755 |
|
xen-hypercalls.sh | File | 386 B | 0755 |
|
xz_wrap.sh | File | 563 B | 0755 |
|