X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=Modules%2FMakefile.tpl;h=f1c31a57fa11fd0a610c8732f7d6f2db1841d634;hb=94418f4f7faa651d7746bf5b858880845f8cc611;hp=de3b36ab59577ddc6ed6ce0c5cac1e5879eab74e;hpb=c8e606164e7bb405295b2f14e6949d0812cfa342;p=tpg%2Facess2.git diff --git a/Modules/Makefile.tpl b/Modules/Makefile.tpl index de3b36ab..f1c31a57 100644 --- a/Modules/Makefile.tpl +++ b/Modules/Makefile.tpl @@ -6,8 +6,14 @@ _CPPFLAGS := $(CPPFLAGS) -include $(dir $(lastword $(MAKEFILE_LIST)))../Makefile.cfg -CPPFLAGS := -I$(ACESSDIR)/Kernel/include -I$(ACESSDIR)/Kernel/arch/$(ARCHDIR)/include -DARCH=$(ARCH) $(_CPPFLAGS) -CFLAGS := -Wall -Werror -fno-stack-protector -g -O3 -fno-builtin +LIBINCLUDES := $(addprefix -I$(ACESSDIR)/Modules/,$(DEPS)) +LIBINCLUDES := $(addsuffix /include,$(LIBINCLUDES)) + +CPPFLAGS := -I$(ACESSDIR)/Kernel/include -I$(ACESSDIR)/Kernel/arch/$(ARCHDIR)/include +CPPFLAGS += -DARCH=$(ARCH) -DARCH_is_$(ARCH) -DARCHDIR_is_$(ARCHDIR) +CPPFLAGS += $(_CPPFLAGS) +CPPFLAGS += $(LIBINCLUDES) +CFLAGS := -std=gnu99 -Wall -fno-stack-protector -g -O3 ifneq ($(CATEGORY),) FULLNAME := $(CATEGORY)_$(NAME) @@ -27,10 +33,11 @@ else BIN := ../$(NAME).xo.$(ARCH) endif -OBJ := $(addsuffix .$(_SUFFIX),$(OBJ)) +OBJ := $(addprefix obj-$(_SUFFIX)/,$(OBJ)) +#OBJ := $(addsuffix .$(_SUFFIX),$(OBJ)) -DEPFILES := $(filter %.o.$(_SUFFIX),$(OBJ)) -DEPFILES := $(DEPFILES:%.o.$(_SUFFIX)=%.d.$(ARCH)) +DEPFILES := $(filter %.o,$(OBJ)) +DEPFILES := $(DEPFILES:%.o=%.d) .PHONY: all clean @@ -38,6 +45,7 @@ all: $(BIN) clean: $(RM) $(BIN) $(BIN).dsm $(KOBJ) $(OBJ) $(DEPFILES) $(EXTRA) + $(RM) -r obj-$(_SUFFIX) install: $(BIN) ifneq ($(BUILDTYPE),static) @@ -46,21 +54,22 @@ ifneq ($(BUILDTYPE),static) else endif + ifneq ($(BUILDTYPE),static) $(BIN): %.kmd.$(ARCH): $(OBJ) @echo --- $(LD) -o $@ -# @$(LD) -T $(ACESSDIR)/Modules/link.ld --allow-shlib-undefined -shared -nostdlib -o $@ $(OBJ) - @$(LD) --allow-shlib-undefined -shared -nostdlib -o $@ $(OBJ) -defsym=DriverInfo=_DriverInfo_$(FULLNAME) + @$(LD) --allow-shlib-undefined -shared -nostdlib -o $@ $(OBJ) -defsym=DriverInfo=_DriverInfo_$(FULLNAME) $(LDFLAGS) @$(DISASM) $(BIN) > $(BIN).dsm else $(BIN): %.xo.$(ARCH): $(OBJ) @echo --- $(LD) -o $@ - @$(LD) -r -o $@ $(OBJ) + @$(LD) -r -o $@ $(OBJ) $(LDFLAGS) endif -%.o.$(_SUFFIX): %.c Makefile $(CFGFILES) +obj-$(_SUFFIX)/%.o: %.c Makefile $(CFGFILES) @echo --- $(CC) -o $@ + @mkdir -p $(dir $@) @$(CC) $(CFLAGS) $(CPPFLAGS) -o $@ -c $< - @$(CC) -M $(CPPFLAGS) -MT $@ -o $*.d.$(ARCH) $< + @$(CC) -M $(CPPFLAGS) -MT $@ -o obj-$(_SUFFIX)/$*.d $< -include $(DEPFILES)