Nicolas Pitre | 23121ca | 2016-01-26 21:50:18 -0500 | [diff] [blame] | 1 | #!/bin/sh |
Thomas Gleixner | d2912cb | 2019-06-04 10:11:33 +0200 | [diff] [blame] | 2 | # SPDX-License-Identifier: GPL-2.0-only |
Nicolas Pitre | 23121ca | 2016-01-26 21:50:18 -0500 | [diff] [blame] | 3 | |
| 4 | # Script to create/update include/generated/autoksyms.h and dependency files |
| 5 | # |
| 6 | # Copyright: (C) 2016 Linaro Limited |
| 7 | # Created by: Nicolas Pitre, January 2016 |
| 8 | # |
Nicolas Pitre | 23121ca | 2016-01-26 21:50:18 -0500 | [diff] [blame] | 9 | |
| 10 | # Create/update the include/generated/autoksyms.h file from the list |
Masahiro Yamada | 60ae1b1 | 2019-07-17 15:17:58 +0900 | [diff] [blame] | 11 | # of all module's needed symbols as recorded on the second line of *.mod files. |
Nicolas Pitre | 23121ca | 2016-01-26 21:50:18 -0500 | [diff] [blame] | 12 | # |
| 13 | # For each symbol being added or removed, the corresponding dependency |
| 14 | # file's timestamp is updated to force a rebuild of the affected source |
| 15 | # file. All arguments passed to this script are assumed to be a command |
| 16 | # to be exec'd to trigger a rebuild of those files. |
| 17 | |
| 18 | set -e |
| 19 | |
| 20 | cur_ksyms_file="include/generated/autoksyms.h" |
| 21 | new_ksyms_file="include/generated/autoksyms.h.tmpnew" |
| 22 | |
| 23 | info() { |
| 24 | if [ "$quiet" != "silent_" ]; then |
| 25 | printf " %-7s %s\n" "$1" "$2" |
| 26 | fi |
| 27 | } |
| 28 | |
| 29 | info "CHK" "$cur_ksyms_file" |
| 30 | |
| 31 | # Use "make V=1" to debug this script. |
| 32 | case "$KBUILD_VERBOSE" in |
| 33 | *1*) |
| 34 | set -x |
| 35 | ;; |
| 36 | esac |
| 37 | |
| 38 | # We need access to CONFIG_ symbols |
Masahiro Yamada | 94cf8ac | 2019-03-08 14:49:10 +0900 | [diff] [blame] | 39 | . include/config/auto.conf |
Nicolas Pitre | 23121ca | 2016-01-26 21:50:18 -0500 | [diff] [blame] | 40 | |
Quentin Perret | 1518c63 | 2020-02-28 17:20:13 +0000 | [diff] [blame^] | 41 | ksym_wl=/dev/null |
| 42 | if [ -n "$CONFIG_UNUSED_KSYMS_WHITELIST" ]; then |
| 43 | # Use 'eval' to expand the whitelist path and check if it is relative |
| 44 | eval ksym_wl="$CONFIG_UNUSED_KSYMS_WHITELIST" |
| 45 | [ "${ksym_wl}" != "${ksym_wl#/}" ] || ksym_wl="$abs_srctree/$ksym_wl" |
| 46 | if [ ! -f "$ksym_wl" ] || [ ! -r "$ksym_wl" ]; then |
| 47 | echo "ERROR: '$ksym_wl' whitelist file not found" >&2 |
| 48 | exit 1 |
| 49 | fi |
| 50 | fi |
| 51 | |
Nicolas Pitre | 23121ca | 2016-01-26 21:50:18 -0500 | [diff] [blame] | 52 | # Generate a new ksym list file with symbols needed by the current |
| 53 | # set of modules. |
| 54 | cat > "$new_ksyms_file" << EOT |
| 55 | /* |
| 56 | * Automatically generated file; DO NOT EDIT. |
| 57 | */ |
| 58 | |
| 59 | EOT |
Masahiro Yamada | b7dca6d | 2019-07-17 15:17:57 +0900 | [diff] [blame] | 60 | sed 's/ko$/mod/' modules.order | |
Masahiro Yamada | 60ae1b1 | 2019-07-17 15:17:58 +0900 | [diff] [blame] | 61 | xargs -n1 sed -n -e '2{s/ /\n/g;/^$/!p;}' -- | |
Quentin Perret | 1518c63 | 2020-02-28 17:20:13 +0000 | [diff] [blame^] | 62 | cat - "$ksym_wl" | |
Masahiro Yamada | b7dca6d | 2019-07-17 15:17:57 +0900 | [diff] [blame] | 63 | sort -u | |
| 64 | sed -e 's/\(.*\)/#define __KSYM_\1 1/' >> "$new_ksyms_file" |
Nicolas Pitre | 23121ca | 2016-01-26 21:50:18 -0500 | [diff] [blame] | 65 | |
| 66 | # Special case for modversions (see modpost.c) |
| 67 | if [ -n "$CONFIG_MODVERSIONS" ]; then |
| 68 | echo "#define __KSYM_module_layout 1" >> "$new_ksyms_file" |
| 69 | fi |
| 70 | |
| 71 | # Extract changes between old and new list and touch corresponding |
| 72 | # dependency files. |
| 73 | changed=$( |
| 74 | count=0 |
| 75 | sort "$cur_ksyms_file" "$new_ksyms_file" | uniq -u | |
| 76 | sed -n 's/^#define __KSYM_\(.*\) 1/\1/p' | tr "A-Z_" "a-z/" | |
| 77 | while read sympath; do |
| 78 | if [ -z "$sympath" ]; then continue; fi |
Masahiro Yamada | fbfa9be | 2018-03-16 16:37:14 +0900 | [diff] [blame] | 79 | depfile="include/ksym/${sympath}.h" |
Nicolas Pitre | 23121ca | 2016-01-26 21:50:18 -0500 | [diff] [blame] | 80 | mkdir -p "$(dirname "$depfile")" |
| 81 | touch "$depfile" |
Nicolas Pitre | 825d487 | 2018-03-15 16:56:20 -0400 | [diff] [blame] | 82 | # Filesystems with coarse time precision may create timestamps |
| 83 | # equal to the one from a file that was very recently built and that |
| 84 | # needs to be rebuild. Let's guard against that by making sure our |
| 85 | # dep files are always newer than the first file we created here. |
| 86 | while [ ! "$depfile" -nt "$new_ksyms_file" ]; do |
| 87 | touch "$depfile" |
| 88 | done |
Nicolas Pitre | 23121ca | 2016-01-26 21:50:18 -0500 | [diff] [blame] | 89 | echo $((count += 1)) |
| 90 | done | tail -1 ) |
| 91 | changed=${changed:-0} |
| 92 | |
| 93 | if [ $changed -gt 0 ]; then |
| 94 | # Replace the old list with tne new one |
| 95 | old=$(grep -c "^#define __KSYM_" "$cur_ksyms_file" || true) |
| 96 | new=$(grep -c "^#define __KSYM_" "$new_ksyms_file" || true) |
| 97 | info "KSYMS" "symbols: before=$old, after=$new, changed=$changed" |
| 98 | info "UPD" "$cur_ksyms_file" |
| 99 | mv -f "$new_ksyms_file" "$cur_ksyms_file" |
| 100 | # Then trigger a rebuild of affected source files |
| 101 | exec $@ |
| 102 | else |
| 103 | rm -f "$new_ksyms_file" |
| 104 | fi |