X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=Modules%2FMakefile.tpl;h=de3b36ab59577ddc6ed6ce0c5cac1e5879eab74e;hb=1237804b2b164486009d1dbc23bb9843bfbe2400;hp=103e8d8a10e0c3d081d236e3bfe225fd3b7d39b0;hpb=1499c9eb8aa167dff5354a25c5a5bd2d00672a54;p=tpg%2Facess2.git diff --git a/Modules/Makefile.tpl b/Modules/Makefile.tpl index 103e8d8a..de3b36ab 100644 --- a/Modules/Makefile.tpl +++ b/Modules/Makefile.tpl @@ -4,26 +4,26 @@ _CPPFLAGS := $(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) +-include $(dir $(lastword $(MAKEFILE_LIST)))../Makefile.cfg CPPFLAGS := -I$(ACESSDIR)/Kernel/include -I$(ACESSDIR)/Kernel/arch/$(ARCHDIR)/include -DARCH=$(ARCH) $(_CPPFLAGS) -CFLAGS := $(KERNEL_CFLAGS) -Wall -Werror -fno-stack-protector $(CPPFLAGS) -O3 -fno-builtin +CFLAGS := -Wall -Werror -fno-stack-protector -g -O3 -fno-builtin -ifeq ($(BUILDTYPE),dynamic) +ifneq ($(CATEGORY),) + FULLNAME := $(CATEGORY)_$(NAME) +else + FULLNAME := $(NAME) +endif + +CPPFLAGS += -D_MODULE_NAME_=\"$(FULLNAME)\" + +ifneq ($(BUILDTYPE),static) _SUFFIX := dyn_$(ARCH) - ifneq ($(CATEGORY),) - BIN := ../$(CATEGORY)_$(NAME).kmd.$(ARCH) - else - BIN := ../$(NAME).kmd.$(ARCH) - endif - CFLAGS += -fPIC + BIN := ../$(FULLNAME).kmd.$(ARCH) + CFLAGS += $(DYNMOD_CFLAGS) -fPIC else _SUFFIX := st_$(ARCH) + CFLAGS += $(KERNEL_CFLAGS) BIN := ../$(NAME).xo.$(ARCH) endif @@ -37,29 +37,30 @@ DEPFILES := $(DEPFILES:%.o.$(_SUFFIX)=%.d.$(ARCH)) all: $(BIN) clean: - $(RM) $(BIN) $(BIN).dsm $(KOBJ) $(OBJ) $(DEPFILES) + $(RM) $(BIN) $(BIN).dsm $(KOBJ) $(OBJ) $(DEPFILES) $(EXTRA) install: $(BIN) -ifeq ($(BUILDTYPE),dynamic) - $(xCP) $(BIN) $(DISTROOT)/Modules/$(NAME).kmd.$(ARCH) +ifneq ($(BUILDTYPE),static) + @$(xMKDIR) $(DISTROOT)/Modules/$(ARCH); true + $(xCP) $(BIN) $(DISTROOT)/Modules/$(ARCH)/$(NAME).kmd else endif -ifeq ($(BUILDTYPE),dynamic) +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) - @$(OBJDUMP) -d $(BIN) > $(BIN).dsm +# @$(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) + @$(DISASM) $(BIN) > $(BIN).dsm else $(BIN): %.xo.$(ARCH): $(OBJ) @echo --- $(LD) -o $@ @$(LD) -r -o $@ $(OBJ) endif -%.o.$(_SUFFIX): %.c Makefile ../Makefile.tpl $(CFGFILES) +%.o.$(_SUFFIX): %.c Makefile $(CFGFILES) @echo --- $(CC) -o $@ - @$(CC) $(CFLAGS) -o $@ -c $< + @$(CC) $(CFLAGS) $(CPPFLAGS) -o $@ -c $< @$(CC) -M $(CPPFLAGS) -MT $@ -o $*.d.$(ARCH) $< -include $(DEPFILES)