> new file mode 100644 > index 0000000..f22a4f8 > --- /dev/null > +++ b/arch/x86/realmode/Makefile > @@ -0,0 +1,20 @@ > +# > +# arch/x86/realmode/Makefile Drop filename inside files - they will get wrong. > +# > +# This file is subject to the terms and conditions of the GNU General Public > +# License. See the file "COPYING" in the main directory of this archive > +# for more details. This is useless boilerplate. > --- /dev/null > +++ b/arch/x86/realmode/rm/.gitignore > @@ -0,0 +1,3 @@ > +pasyms.h > +realmode.lds > +realmode.relocs > diff --git a/arch/x86/realmode/rm/Makefile b/arch/x86/realmode/rm/Makefile > new file mode 100644 > index 0000000..7c3f202 > --- /dev/null > +++ b/arch/x86/realmode/rm/Makefile > @@ -0,0 +1,63 @@ > +# > +# arch/x86/realmode/Makefile And I think you proved my point concerning the filename here :-) > +# > +# This file is subject to the terms and conditions of the GNU General Public > +# License. See the file "COPYING" in the main directory of this archive > +# for more details. > +# > +# > + > +subdir- := wakeup > + > +always := realmode.bin > + > +realmode-y += header.o I see no reason to use the "-y" variant of the name here. > + > +targets += $(realmode-y) > + > +REALMODE_OBJS = $(addprefix $(obj)/,$(realmode-y)) We try to avoid ALL_CAPS stuff in linux makefiles. It is unreadable. > + > +sed-pasyms := -n -r -e 's/^([0-9a-fA-F]+) [ABCDGRSTVW] (.+)$$/pa_\2 = \2;/p' > + > +quiet_cmd_pasyms = PASYMS $@ > + cmd_pasyms = $(NM) $(filter-out FORCE,$^) | \ > + sed $(sed-pasyms) | sort | uniq > $@ > + > +$(obj)/pasyms.h: $(REALMODE_OBJS) FORCE > + $(call if_changed,pasyms) > + > +$(obj)/realmode.lds: $(obj)/pasyms.h > + > +LDFLAGS_realmode.elf := --emit-relocs -T > +CPPFLAGS_realmode.lds += -P -C -I$(obj) > + > +$(obj)/realmode.elf: $(obj)/realmode.lds $(REALMODE_OBJS) FORCE > + $(call if_changed,ld) > + > +OBJCOPYFLAGS_realmode.bin := -O binary > + > +$(obj)/realmode.bin: $(obj)/realmode.elf > + $(call if_changed,objcopy) > + > +quiet_cmd_relocs = RELOCS $@ > + cmd_relocs = scripts/x86-relocs --realmode $< > $@ > +$(obj)/realmode.relocs: $(obj)/realmode.elf FORCE > + $(call if_changed,relocs) > + > +# --------------------------------------------------------------------------- > + > +# How to compile the 16-bit code. Note we always compile for -march=i386, > +# that way we can complain to the user if the CPU is insufficient. > +KBUILD_CFLAGS := $(LINUXINCLUDE) -m32 -g -Os -D_SETUP -D__KERNEL__ \ > + -DDISABLE_BRANCH_PROFILING \ > + -Wall -Wstrict-prototypes \ > + -march=i386 -mregparm=3 \ > + -include $(srctree)/$(src)/../../boot/code16gcc.h \ > + -fno-strict-aliasing -fomit-frame-pointer \ > + $(call cc-option, -ffreestanding) \ > + $(call cc-option, -fno-toplevel-reorder,\ > + $(call cc-option, -fno-unit-at-a-time)) \ > + $(call cc-option, -fno-stack-protector) \ > + $(call cc-option, -mpreferred-stack-boundary=2) > +KBUILD_AFLAGS := $(KBUILD_CFLAGS) -D__ASSEMBLY__ How much is needed to avoid this misuse of kernel-internal build rules? This was and is an ugly hack. Sam -- 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