On Tue, Jul 8, 2014 at 2:47 PM, Michal Marek <mmarek@xxxxxxx> wrote: > Commit 5180d5f4 ("firmware: Simplify directory creation") broke > including firmware specified in CONFIG_EXTRA_FIRMWARE: > > MK_FW firmware/amd-ucode/microcode_amd.bin.gen.S > /bin/sh: firmware/amd-ucode/microcode_amd.bin.gen.S: No such file or directory > ... > firmware/Makefile:185: recipe for target > 'firmware/amd-ucode/microcode_amd.bin.gen.S' failed > > It works with O= builds, because the directory is created by > Makefile.build. Create the directory in firmware/Makefile in non-O > builds. > > Reported-by: Ronald <ronald645@xxxxxxxxx> > Reported-by: Torsten Kaiser <just.for.lkml@xxxxxxxxxxxxxx> > Signed-off-by: Michal Marek <mmarek@xxxxxxx> > --- > > Can you try this patch? Works fine for me. Thanks for the quick patch! Torsten > Ronald, can you tell me your full name for the Reported-by: line? > > Thanks. > --- > > firmware/Makefile | 6 ++++++ > 1 file changed, 6 insertions(+) > > diff --git a/firmware/Makefile b/firmware/Makefile > index 5747417..0862d34 100644 > --- a/firmware/Makefile > +++ b/firmware/Makefile > @@ -219,6 +219,12 @@ $(obj)/%.fw: $(obj)/%.H16 $(ihex2fw_dep) > obj-y += $(patsubst %,%.gen.o, $(fw-external-y)) > obj-$(CONFIG_FIRMWARE_IN_KERNEL) += $(patsubst %,%.gen.o, $(fw-shipped-y)) > > +ifeq ($(KBUILD_SRC),) > +# Makefile.build only creates subdirectories for O= builds, but external > +# firmware might live outside the kernel source tree > +_dummy := $(foreach d,$(addprefix $(obj)/,$(dir $(fw-external-y))), $(shell [ -d $(d) ] || mkdir -p $(d))) > +endif > + > # Remove .S files and binaries created from ihex > # (during 'make clean' .config isn't included so they're all in $(fw-shipped-)) > targets := $(fw-shipped-) $(patsubst $(obj)/%,%, \ > -- > 1.8.4.5 > -- To unsubscribe from this list: send the line "unsubscribe linux-kbuild" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html