diff options
| -rw-r--r-- | Makefile | 2 | ||||
| -rwxr-xr-x | scripts/depmod.sh | 26 |
2 files changed, 24 insertions, 4 deletions
| @@ -1396,7 +1396,7 @@ quiet_cmd_rmfiles = $(if $(wildcard $(rm-files)),CLEAN $(wildcard $(rm-files)) | |||
| 1396 | # Run depmod only if we have System.map and depmod is executable | 1396 | # Run depmod only if we have System.map and depmod is executable |
| 1397 | quiet_cmd_depmod = DEPMOD $(KERNELRELEASE) | 1397 | quiet_cmd_depmod = DEPMOD $(KERNELRELEASE) |
| 1398 | cmd_depmod = $(CONFIG_SHELL) $(srctree)/scripts/depmod.sh $(DEPMOD) \ | 1398 | cmd_depmod = $(CONFIG_SHELL) $(srctree)/scripts/depmod.sh $(DEPMOD) \ |
| 1399 | $(KERNELRELEASE) | 1399 | $(KERNELRELEASE) "$(patsubst "%",%,$(CONFIG_SYMBOL_PREFIX))" |
| 1400 | 1400 | ||
| 1401 | # Create temporary dir for module support files | 1401 | # Create temporary dir for module support files |
| 1402 | # clean it up only when building all modules | 1402 | # clean it up only when building all modules |
diff --git a/scripts/depmod.sh b/scripts/depmod.sh index 2ae481703141..122599b1c13b 100755 --- a/scripts/depmod.sh +++ b/scripts/depmod.sh | |||
| @@ -2,16 +2,36 @@ | |||
| 2 | # | 2 | # |
| 3 | # A depmod wrapper used by the toplevel Makefile | 3 | # A depmod wrapper used by the toplevel Makefile |
| 4 | 4 | ||
| 5 | if test $# -ne 2; then | 5 | if test $# -ne 3; then |
| 6 | echo "Usage: $0 /sbin/depmod <kernelrelease>" >&2 | 6 | echo "Usage: $0 /sbin/depmod <kernelrelease> <symbolprefix>" >&2 |
| 7 | exit 1 | 7 | exit 1 |
| 8 | fi | 8 | fi |
| 9 | DEPMOD=$1 | 9 | DEPMOD=$1 |
| 10 | KERNELRELEASE=$2 | 10 | KERNELRELEASE=$2 |
| 11 | SYMBOL_PREFIX=$3 | ||
| 11 | 12 | ||
| 12 | if ! test -r System.map -a -x "$DEPMOD"; then | 13 | if ! test -r System.map -a -x "$DEPMOD"; then |
| 13 | exit 0 | 14 | exit 0 |
| 14 | fi | 15 | fi |
| 16 | |||
| 17 | # older versions of depmod don't support -P <symbol-prefix> | ||
| 18 | # support was added in module-init-tools 3.13 | ||
| 19 | if test -n "$SYMBOL_PREFIX"; then | ||
| 20 | release=$("$DEPMOD" --version) | ||
| 21 | package=$(echo "$release" | cut -d' ' -f 1) | ||
| 22 | if test "$package" = "module-init-tools"; then | ||
| 23 | version=$(echo "$release" | cut -d' ' -f 2) | ||
| 24 | later=$(printf '%s\n' "$version" "3.13" | sort -V | tail -n 1) | ||
| 25 | if test "$later" != "$version"; then | ||
| 26 | # module-init-tools < 3.13, drop the symbol prefix | ||
| 27 | SYMBOL_PREFIX="" | ||
| 28 | fi | ||
| 29 | fi | ||
| 30 | if test -n "$SYMBOL_PREFIX"; then | ||
| 31 | SYMBOL_PREFIX="-P $SYMBOL_PREFIX" | ||
| 32 | fi | ||
| 33 | fi | ||
| 34 | |||
| 15 | # older versions of depmod require the version string to start with three | 35 | # older versions of depmod require the version string to start with three |
| 16 | # numbers, so we cheat with a symlink here | 36 | # numbers, so we cheat with a symlink here |
| 17 | depmod_hack_needed=true | 37 | depmod_hack_needed=true |
| @@ -34,7 +54,7 @@ set -- -ae -F System.map | |||
| 34 | if test -n "$INSTALL_MOD_PATH"; then | 54 | if test -n "$INSTALL_MOD_PATH"; then |
| 35 | set -- "$@" -b "$INSTALL_MOD_PATH" | 55 | set -- "$@" -b "$INSTALL_MOD_PATH" |
| 36 | fi | 56 | fi |
| 37 | "$DEPMOD" "$@" "$KERNELRELEASE" | 57 | "$DEPMOD" "$@" "$KERNELRELEASE" $SYMBOL_PREFIX |
| 38 | ret=$? | 58 | ret=$? |
| 39 | 59 | ||
| 40 | if $depmod_hack_needed; then | 60 | if $depmod_hack_needed; then |
