blob: b0cb89e73bc56200a6f1c41df2e5192caf5cf890 [file] [log] [blame]
Michal Marekfc4da9a2011-06-09 15:35:22 +02001#!/bin/sh
2#
3# A depmod wrapper used by the toplevel Makefile
4
James Hogan8937e892013-02-06 12:56:59 +00005if test $# -ne 3; then
6 echo "Usage: $0 /sbin/depmod <kernelrelease> <symbolprefix>" >&2
Michal Marekfc4da9a2011-06-09 15:35:22 +02007 exit 1
8fi
9DEPMOD=$1
10KERNELRELEASE=$2
James Hogan8937e892013-02-06 12:56:59 +000011SYMBOL_PREFIX=$3
Michal Marekfc4da9a2011-06-09 15:35:22 +020012
Randy Dunlap2d43ff02018-07-01 19:46:06 -070013if ! test -r System.map ; then
Michal Marekfc4da9a2011-06-09 15:35:22 +020014 exit 0
15fi
James Hogan8937e892013-02-06 12:56:59 +000016
Linus Torvaldsf679fa02020-12-28 11:40:22 -080017# legacy behavior: "depmod" in /sbin, no /sbin in PATH
18PATH="$PATH:/sbin"
Randy Dunlap2d43ff02018-07-01 19:46:06 -070019if [ -z $(command -v $DEPMOD) ]; then
Randy Dunlapa7522802018-08-28 12:59:10 -070020 echo "Warning: 'make modules_install' requires $DEPMOD. Please install it." >&2
Randy Dunlap2d43ff02018-07-01 19:46:06 -070021 echo "This is probably in the kmod package." >&2
Randy Dunlapa7522802018-08-28 12:59:10 -070022 exit 0
Randy Dunlap2d43ff02018-07-01 19:46:06 -070023fi
24
James Hogan8937e892013-02-06 12:56:59 +000025# older versions of depmod don't support -P <symbol-prefix>
26# support was added in module-init-tools 3.13
27if test -n "$SYMBOL_PREFIX"; then
28 release=$("$DEPMOD" --version)
29 package=$(echo "$release" | cut -d' ' -f 1)
30 if test "$package" = "module-init-tools"; then
31 version=$(echo "$release" | cut -d' ' -f 2)
32 later=$(printf '%s\n' "$version" "3.13" | sort -V | tail -n 1)
33 if test "$later" != "$version"; then
34 # module-init-tools < 3.13, drop the symbol prefix
35 SYMBOL_PREFIX=""
36 fi
37 fi
38 if test -n "$SYMBOL_PREFIX"; then
39 SYMBOL_PREFIX="-P $SYMBOL_PREFIX"
40 fi
41fi
42
Michal Marekbfe54242011-06-09 16:35:41 +020043# older versions of depmod require the version string to start with three
44# numbers, so we cheat with a symlink here
45depmod_hack_needed=true
Michal Marek8fc62e52011-07-12 11:54:48 +020046tmp_dir=$(mktemp -d ${TMPDIR:-/tmp}/depmod.XXXXXX)
47mkdir -p "$tmp_dir/lib/modules/$KERNELRELEASE"
48if "$DEPMOD" -b "$tmp_dir" $KERNELRELEASE 2>/dev/null; then
49 if test -e "$tmp_dir/lib/modules/$KERNELRELEASE/modules.dep" -o \
50 -e "$tmp_dir/lib/modules/$KERNELRELEASE/modules.dep.bin"; then
Michal Marekbfe54242011-06-09 16:35:41 +020051 depmod_hack_needed=false
52 fi
53fi
Michal Marek8fc62e52011-07-12 11:54:48 +020054rm -rf "$tmp_dir"
Michal Marekbfe54242011-06-09 16:35:41 +020055if $depmod_hack_needed; then
56 symlink="$INSTALL_MOD_PATH/lib/modules/99.98.$KERNELRELEASE"
57 ln -s "$KERNELRELEASE" "$symlink"
58 KERNELRELEASE=99.98.$KERNELRELEASE
59fi
60
Michal Marekfc4da9a2011-06-09 15:35:22 +020061set -- -ae -F System.map
62if test -n "$INSTALL_MOD_PATH"; then
63 set -- "$@" -b "$INSTALL_MOD_PATH"
64fi
James Hogan8937e892013-02-06 12:56:59 +000065"$DEPMOD" "$@" "$KERNELRELEASE" $SYMBOL_PREFIX
Michal Marekbfe54242011-06-09 16:35:41 +020066ret=$?
67
68if $depmod_hack_needed; then
69 rm -f "$symlink"
70fi
71
72exit $ret