X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=Modules%2FMakefile.tpl;h=b31943e6ee0039b5aa6d95ece773a0f0465d9475;hb=f42e912b8bc615c2009b795ce12d4c54cef4ee8b;hp=7d20cd3dfed3406101ff1e789caf601997de43a7;hpb=77ed20ce9d7e25654215980d0f89e63b8dd366f0;p=tpg%2Facess2.git diff --git a/Modules/Makefile.tpl b/Modules/Makefile.tpl index 7d20cd3d..b31943e6 100644 --- a/Modules/Makefile.tpl +++ b/Modules/Makefile.tpl @@ -2,35 +2,74 @@ # 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) +-include $(dir $(lastword $(MAKEFILE_LIST)))../Makefile.cfg -OBJ := $(addsuffix .$(ARCH),$(OBJ)) -BIN = ../$(NAME).kmd.$(ARCH) -KOBJ = ../$(NAME).xo.$(ARCH) +LIBINCLUDES := $(addprefix -I$(ACESSDIR)/Modules/,$(DEPS)) +LIBINCLUDES := $(addsuffix /include,$(LIBINCLUDES)) -DEPFILES = $(filter %.o.$(ARCH),$(OBJ)) -DEPFILES := $(DEPFILES:%.o.$(ARCH)=%.d.$(ARCH)) +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 -Werror -fno-stack-protector -g -O3 -fno-builtin + +ifneq ($(CATEGORY),) + FULLNAME := $(CATEGORY)_$(NAME) +else + FULLNAME := $(NAME) +endif + +CPPFLAGS += -D_MODULE_NAME_=\"$(FULLNAME)\" + +ifneq ($(BUILDTYPE),static) + _SUFFIX := dyn_$(ARCH) + BIN := ../$(FULLNAME).kmd.$(ARCH) + CFLAGS += $(DYNMOD_CFLAGS) -fPIC +else + _SUFFIX := st_$(ARCH) + CFLAGS += $(KERNEL_CFLAGS) + BIN := ../$(NAME).xo.$(ARCH) +endif + +OBJ := $(addprefix obj-$(_SUFFIX)/,$(OBJ)) +#OBJ := $(addsuffix .$(_SUFFIX),$(OBJ)) + +DEPFILES := $(filter %.o,$(OBJ)) +DEPFILES := $(DEPFILES:%.o=%.d) .PHONY: all clean all: $(BIN) clean: - $(RM) $(BIN) $(KOBJ) $(OBJ) $(DEPFILES) + $(RM) $(BIN) $(BIN).dsm $(KOBJ) $(OBJ) $(DEPFILES) $(EXTRA) + $(RM) -r obj-$(_SUFFIX) + +install: $(BIN) +ifneq ($(BUILDTYPE),static) + @$(xMKDIR) $(DISTROOT)/Modules/$(ARCH); true + $(xCP) $(BIN) $(DISTROOT)/Modules/$(ARCH)/$(NAME).kmd +else +endif -$(BIN): $(OBJ) + +ifneq ($(BUILDTYPE),static) +$(BIN): %.kmd.$(ARCH): $(OBJ) + @echo --- $(LD) -o $@ + @$(LD) --allow-shlib-undefined -shared -nostdlib -o $@ $(OBJ) -defsym=DriverInfo=_DriverInfo_$(FULLNAME) + @$(DISASM) $(BIN) > $(BIN).dsm +else +$(BIN): %.xo.$(ARCH): $(OBJ) @echo --- $(LD) -o $@ - @$(LD) -T ../link.ld -shared -nostdlib -o $@ $(OBJ) -# @$(LD) -shared -nostdlib -o $@ $(OBJ) - @echo --- $(LD) -o $(KOBJ) - @$(CC) -Wl,-r -nostdlib -o $(KOBJ) $(OBJ) + @$(LD) -r -o $@ $(OBJ) +endif -%.o.$(ARCH): %.c Makefile ../Makefile.tpl ../../Makefile.cfg +obj-$(_SUFFIX)/%.o: %.c Makefile $(CFGFILES) @echo --- $(CC) -o $@ - @$(CC) $(CFLAGS) -o $@ -c $< - @$(CC) -M $(CPPFLAGS) -MT $@ -o $*.d.$(ARCH) $< + @mkdir -p $(dir $@) + @$(CC) $(CFLAGS) $(CPPFLAGS) -o $@ -c $< + @$(CC) -M $(CPPFLAGS) -MT $@ -o obj-$(_SUFFIX)/$*.d $< -include $(DEPFILES)