2 # Acess2 Module/Driver Templater Makefile
5 _CPPFLAGS := $(CPPFLAGS)
8 CFGFILES += $(shell test -f ../../../Makefile.cfg && echo ../../../Makefile.cfg)
9 CFGFILES += $(shell test -f ../../Makefile.cfg && echo ../../Makefile.cfg)
10 CFGFILES += $(shell test -f ../Makefile.cfg && echo ../Makefile.cfg)
11 CFGFILES += $(shell test -f Makefile.cfg && echo Makefile.cfg)
14 CPPFLAGS = -I$(ACESSDIR)/Kernel/include -I$(ACESSDIR)/Kernel/arch/$(ARCHDIR)/include -DARCH=$(ARCH) $(_CPPFLAGS)
15 CFLAGS = -Wall -Werror -fno-stack-protector $(CPPFLAGS) -O3
17 OBJ := $(addsuffix .$(ARCH),$(OBJ))
19 BIN := ../$(CATEGORY)_$(NAME).kmd.$(ARCH)
21 BIN := ../$(NAME).kmd.$(ARCH)
23 KOBJ = ../$(NAME).xo.$(ARCH)
25 DEPFILES = $(filter %.o.$(ARCH),$(OBJ))
26 DEPFILES := $(DEPFILES:%.o.$(ARCH)=%.d.$(ARCH))
33 $(RM) $(BIN) $(BIN).dsm $(KOBJ) $(OBJ) $(DEPFILES)
36 $(xCP) $(BIN) $(DISTROOT)/Modules/$(NAME).kmd
40 @$(LD) -T $(ACESSDIR)/Modules/link.ld -shared -nostdlib -o $@ $(OBJ)
41 @$(OBJDUMP) -d $(BIN) > $(BIN).dsm
42 @echo --- $(LD) -o $(KOBJ)
43 @$(CC) -Wl,-r -nostdlib -o $(KOBJ) $(OBJ)
45 %.o.$(ARCH): %.c Makefile ../Makefile.tpl $(CFGFILES)
47 @$(CC) $(CFLAGS) -o $@ -c $<
48 @$(CC) -M $(CPPFLAGS) -MT $@ -o $*.d.$(ARCH) $<