kbuild: fix make -rR breakage
make failed to supply the filename when using make -rR and using $(*F) to get target filename without extension. This bug was not reproduceable in small scale but using: $(basename $(notdir $@)) fixes it with same functionality. Signed-off-by: Sam Ravnborg <sam@ravnborg.org>
This commit is contained in:
parent
216b2f1f71
commit
e5c44fd88c
@ -12,6 +12,11 @@ space := $(empty) $(empty)
|
|||||||
# contain a comma
|
# contain a comma
|
||||||
depfile = $(subst $(comma),_,$(@D)/.$(@F).d)
|
depfile = $(subst $(comma),_,$(@D)/.$(@F).d)
|
||||||
|
|
||||||
|
###
|
||||||
|
# basetarget equals the filename of the target with no extension.
|
||||||
|
# So 'foo/bar.o' becomes 'bar'
|
||||||
|
basetarget = $(basename $(notdir $@))
|
||||||
|
|
||||||
###
|
###
|
||||||
# Escape single quote for use in echo statements
|
# Escape single quote for use in echo statements
|
||||||
escsq = $(subst $(squote),'\$(squote)',$1)
|
escsq = $(subst $(squote),'\$(squote)',$1)
|
||||||
|
@ -117,7 +117,7 @@ $(real-objs-m:.o=.lst): quiet_modtag := [M]
|
|||||||
$(obj-m) : quiet_modtag := [M]
|
$(obj-m) : quiet_modtag := [M]
|
||||||
|
|
||||||
# Default for not multi-part modules
|
# Default for not multi-part modules
|
||||||
modname = $(*F)
|
modname = $(basetarget)
|
||||||
|
|
||||||
$(multi-objs-m) : modname = $(modname-multi)
|
$(multi-objs-m) : modname = $(modname-multi)
|
||||||
$(multi-objs-m:.o=.i) : modname = $(modname-multi)
|
$(multi-objs-m:.o=.i) : modname = $(modname-multi)
|
||||||
|
@ -80,8 +80,10 @@ obj-dirs += $(host-objdirs)
|
|||||||
#####
|
#####
|
||||||
# Handle options to gcc. Support building with separate output directory
|
# Handle options to gcc. Support building with separate output directory
|
||||||
|
|
||||||
_hostc_flags = $(HOSTCFLAGS) $(HOST_EXTRACFLAGS) $(HOSTCFLAGS_$(*F).o)
|
_hostc_flags = $(HOSTCFLAGS) $(HOST_EXTRACFLAGS) \
|
||||||
_hostcxx_flags = $(HOSTCXXFLAGS) $(HOST_EXTRACXXFLAGS) $(HOSTCXXFLAGS_$(*F).o)
|
$(HOSTCFLAGS_$(basetarget).o)
|
||||||
|
_hostcxx_flags = $(HOSTCXXFLAGS) $(HOST_EXTRACXXFLAGS) \
|
||||||
|
$(HOSTCXXFLAGS_$(basetarget).o)
|
||||||
|
|
||||||
ifeq ($(KBUILD_SRC),)
|
ifeq ($(KBUILD_SRC),)
|
||||||
__hostc_flags = $(_hostc_flags)
|
__hostc_flags = $(_hostc_flags)
|
||||||
|
@ -82,12 +82,12 @@ obj-dirs := $(addprefix $(obj)/,$(obj-dirs))
|
|||||||
# than one module. In that case KBUILD_MODNAME will be set to foo_bar,
|
# than one module. In that case KBUILD_MODNAME will be set to foo_bar,
|
||||||
# where foo and bar are the name of the modules.
|
# where foo and bar are the name of the modules.
|
||||||
name-fix = $(subst $(comma),_,$(subst -,_,$1))
|
name-fix = $(subst $(comma),_,$(subst -,_,$1))
|
||||||
basename_flags = -D"KBUILD_BASENAME=KBUILD_STR($(call name-fix,$(*F)))"
|
basename_flags = -D"KBUILD_BASENAME=KBUILD_STR($(call name-fix,$(basetarget)))"
|
||||||
modname_flags = $(if $(filter 1,$(words $(modname))),\
|
modname_flags = $(if $(filter 1,$(words $(modname))),\
|
||||||
-D"KBUILD_MODNAME=KBUILD_STR($(call name-fix,$(modname)))")
|
-D"KBUILD_MODNAME=KBUILD_STR($(call name-fix,$(modname)))")
|
||||||
|
|
||||||
_c_flags = $(CFLAGS) $(EXTRA_CFLAGS) $(CFLAGS_$(*F).o)
|
_c_flags = $(CFLAGS) $(EXTRA_CFLAGS) $(CFLAGS_$(basetarget).o)
|
||||||
_a_flags = $(AFLAGS) $(EXTRA_AFLAGS) $(AFLAGS_$(*F).o)
|
_a_flags = $(AFLAGS) $(EXTRA_AFLAGS) $(AFLAGS_$(basetarget).o)
|
||||||
_cpp_flags = $(CPPFLAGS) $(EXTRA_CPPFLAGS) $(CPPFLAGS_$(@F))
|
_cpp_flags = $(CPPFLAGS) $(EXTRA_CPPFLAGS) $(CPPFLAGS_$(@F))
|
||||||
|
|
||||||
# If building the kernel in a separate objtree expand all occurrences
|
# If building the kernel in a separate objtree expand all occurrences
|
||||||
|
@ -72,7 +72,7 @@ $(modules:.ko=.mod.c): __modpost ;
|
|||||||
# Step 5), compile all *.mod.c files
|
# Step 5), compile all *.mod.c files
|
||||||
|
|
||||||
# modname is set to make c_flags define KBUILD_MODNAME
|
# modname is set to make c_flags define KBUILD_MODNAME
|
||||||
modname = $(*F)
|
modname = $(basetarget)
|
||||||
|
|
||||||
quiet_cmd_cc_o_c = CC $@
|
quiet_cmd_cc_o_c = CC $@
|
||||||
cmd_cc_o_c = $(CC) $(c_flags) $(CFLAGS_MODULE) \
|
cmd_cc_o_c = $(CC) $(c_flags) $(CFLAGS_MODULE) \
|
||||||
|
Loading…
Reference in New Issue
Block a user