On Sat, Mar 11, 2017 at 10:34:50PM +0900, Masahiro Yamada wrote: >Hi Wei, > > >2017-02-23 0:08 GMT+09:00 Wei Yang : >> Current kbuild will build the target again if we run "make M=dir" and "make >> M=dir/" by turns, since if_changed will see the prerequisite is changed. >> The behavior may confuse the user a little, since actually we are building >> the same target and no difference. >> >> According to current implementation in scripts/Makefile.build, the obj >> passed to next level is a directory name with last slash stripped. This >> patch strips the last slash in KBUILD_EXTMOD which is assigned from "M=". >> >> Signed-off-by: Wei Yang >> --- >> Makefile | 6 ++++-- >> 1 file changed, 4 insertions(+), 2 deletions(-) >> >> diff --git a/Makefile b/Makefile >> index b1037774e8e8..db6ed60928ab 100644 >> --- a/Makefile >> +++ b/Makefile >> @@ -184,13 +184,15 @@ endif >> # Old syntax make ... SUBDIRS=$PWD is still supported >> # Setting the environment variable KBUILD_EXTMOD take precedence >> ifdef SUBDIRS >> - KBUILD_EXTMOD ?= $(SUBDIRS) >> + __KBUILD_EXTMOD ?= $(SUBDIRS) >> endif >> >> ifeq ("$(origin M)", "command line") >> - KBUILD_EXTMOD := $(M) >> + __KBUILD_EXTMOD := $(M) >> endif >> >> +KBUILD_EXTMOD = $(patsubst %/,%,$(__KBUILD_EXTMOD)) >> + >> # If building an external module we do not care about the all: rule >> # but instead _all depend on modules >> PHONY += all > >This patch would break a use-case >where KBUILD_EXTMOD is given as an environment. > Hi, Masahiro Thanks for your comment. Got your point, you are right. > > >Maybe adding the following should be enough? > >KBUILD_EXTMOD := $(patsubst %/,%,$(KBUILD_EXTMOD)) > Yep, it looks good. BTW, I found another interesting thing. make M=dir//// is also a valid target in kbuild. Even this is a very rare case, I plan to use this to handle it. KBUILD_EXTMOD := $(subst $(CURDIR)/,,$(KBUILD_EXTMOD)) This also works for an out tree build. I would send out v2 soon, hope you like this. > >-- >Best Regards >Masahiro Yamada -- Wei Yang Help you, Help me