X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=Modules%2FMakefile.tpl;h=9a1b6e82ec7987b5f927a772ba371555fb181f62;hb=ac6a86c2fa8d8d7459020e709ce5407d7b66f306;hp=6d22b4c3f0912a69b335737d57ce6bd62bc3442d;hpb=a8067bafb36f98612767060db856cd6bf36ef940;p=tpg%2Facess2.git diff --git a/Modules/Makefile.tpl b/Modules/Makefile.tpl index 6d22b4c3..9a1b6e82 100644 --- a/Modules/Makefile.tpl +++ b/Modules/Makefile.tpl @@ -2,28 +2,49 @@ # Acess2 Module/Driver Templater Makefile # Makefile.tpl --include ../../Makefile.cfg +_CPPFLAGS := $(CPPFLAGS) -CPPFLAGS = -I../../Kernel/include -I../../Kernel/arch/$(ARCHDIR)/include -DARCH=$(ARCH) -CFLAGS = -Wall -Werror $(CPPFLAGS) +CFGFILES = +CFGFILES += $(shell test -f ../../../Makefile.cfg && echo ../../../Makefile.cfg) +CFGFILES += $(shell test -f ../../Makefile.cfg && echo ../../Makefile.cfg) +CFGFILES += $(shell test -f ../Makefile.cfg && echo ../Makefile.cfg) +CFGFILES += $(shell test -f Makefile.cfg && echo Makefile.cfg) +-include $(CFGFILES) + +CPPFLAGS = -I$(ACESSDIR)/Kernel/include -I$(ACESSDIR)/Kernel/arch/$(ARCHDIR)/include -DARCH=$(ARCH) $(_CPPFLAGS) +CFLAGS = -Wall -Werror -fno-stack-protector $(CPPFLAGS) -O3 OBJ := $(addsuffix .$(ARCH),$(OBJ)) -BIN = ../$(NAME).kmd.$(ARCH) +ifneq ($(CATEGORY),) + BIN := ../$(CATEGORY)_$(NAME).kmd.$(ARCH) +else + BIN := ../$(NAME).kmd.$(ARCH) +endif +KOBJ = ../$(NAME).xo.$(ARCH) + +DEPFILES = $(filter %.o.$(ARCH),$(OBJ)) +DEPFILES := $(DEPFILES:%.o.$(ARCH)=%.d.$(ARCH)) .PHONY: all clean all: $(BIN) clean: - $(RM) $(BIN) $(OBJ) + $(RM) $(BIN) $(BIN).dsm $(KOBJ) $(OBJ) $(DEPFILES) + +install: $(BIN) + $(xCP) $(BIN) $(DISTROOT)/Modules/$(NAME).kmd $(BIN): $(OBJ) @echo --- $(LD) -o $@ - @$(LD) -T ../link.ld -shared -o $@ $(OBJ) - @echo --- $(LD) -o ../$(NAME).o.$(ARCH) - @$(CC) -Wl,-r -nostdlib -o ../$(NAME).o.$(ARCH) $(OBJ) + @$(LD) -T $(ACESSDIR)/Modules/link.ld -shared -nostdlib -o $@ $(OBJ) + @$(OBJDUMP) -d $(BIN) > $(BIN).dsm + @echo --- $(LD) -o $(KOBJ) + @$(CC) -Wl,-r -nostdlib -o $(KOBJ) $(OBJ) -%.o.$(ARCH): %.c Makefile ../Makefile.tpl ../../Makefile.cfg +%.o.$(ARCH): %.c Makefile ../Makefile.tpl $(CFGFILES) @echo --- $(CC) -o $@ @$(CC) $(CFLAGS) -o $@ -c $< - @$(CC) -M $(CPPFLAGS) -MT $@ -o $*.d $< + @$(CC) -M $(CPPFLAGS) -MT $@ -o $*.d.$(ARCH) $< + +-include $(DEPFILES)