.PHONY: __modinst
__modinst:
-include scripts/Makefile.lib
+include scripts/Kbuild.include
#
-__modules := $(shell head -q -n1 /dev/null $(wildcard $(MODVERDIR)/*.mod))
+__modules := $(sort $(shell grep -h '\.ko' /dev/null $(wildcard $(MODVERDIR)/*.mod)))
modules := $(patsubst %.o,%.ko,$(wildcard $(__modules:.ko=.o)))
.PHONY: $(modules)
__modinst: $(modules)
@:
-# Modules built within the kernel tree
-
quiet_cmd_modules_install = INSTALL $@
- cmd_modules_install = mkdir -p $(MODLIB)/kernel/$(@D); \
- cp $@ $(MODLIB)/kernel/$(@D)
-
-$(filter-out ../% /%,$(modules)):
- $(call cmd,modules_install)
+ cmd_modules_install = mkdir -p $(2); cp $@ $(2)
-# Modules built outside just go into extra
+# Modules built outside the kernel source tree go into extra by default
+INSTALL_MOD_DIR ?= extra
+ext-mod-dir = $(INSTALL_MOD_DIR)$(subst $(KBUILD_EXTMOD),,$(@D))
-quiet_cmd_modules_install_extra = INSTALL $(obj-m:.o=.ko)
- cmd_modules_install_extra = mkdir -p $(MODLIB)/extra; \
- cp $@ $(MODLIB)/extra
+modinst_dir = $(if $(KBUILD_EXTMOD),$(ext-mod-dir),kernel/$(@D))
-$(filter ../% /%,$(modules)):
- $(call cmd,modules_install_extra)
+$(modules):
+ $(call cmd,modules_install,$(MODLIB)/$(modinst_dir))