ae6d57484dc502068509005a0aacb99d7eae2164
[tpg/acess2.git] / Modules / Makefile.tpl
1
2 # Acess2 Module/Driver Templater Makefile
3 # Makefile.tpl
4
5 _CPPFLAGS := $(CPPFLAGS)
6
7 CFGFILES = 
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 -include $(CFGFILES)
12
13 CPPFLAGS = -I$(ACESSDIR)/Kernel/include -I$(ACESSDIR)/Kernel/arch/$(ARCHDIR)/include -DARCH=$(ARCH) $(_CPPFLAGS)
14 CFLAGS = -Wall -Werror -fno-stack-protector $(CPPFLAGS)
15
16 OBJ := $(addsuffix .$(ARCH),$(OBJ))
17 BIN = ../$(NAME).kmd.$(ARCH)
18 KOBJ = ../$(NAME).xo.$(ARCH)
19
20 DEPFILES  = $(filter %.o.$(ARCH),$(OBJ))
21 DEPFILES := $(DEPFILES:%.o.$(ARCH)=%.d.$(ARCH))
22
23 .PHONY: all clean
24
25 all: $(BIN)
26
27 clean:
28         $(RM) $(BIN) $(BIN).dsm $(KOBJ) $(OBJ) $(DEPFILES)
29
30 install: $(BIN)
31         $(xCP) $(BIN) $(DISTROOT)/Modules/$(NAME).kmd
32
33 $(BIN): $(OBJ)
34         @echo --- $(LD) -o $@
35         @$(LD) -T $(ACESSDIR)/Modules/link.ld -shared -nostdlib -o $@ $(OBJ)
36         @$(OBJDUMP) -d $(BIN) > $(BIN).dsm
37         @echo --- $(LD) -o $(KOBJ)
38         @$(CC) -Wl,-r -nostdlib -o $(KOBJ) $(OBJ)
39
40 %.o.$(ARCH): %.c Makefile ../Makefile.tpl $(CFGFILES)
41         @echo --- $(CC) -o $@
42         @$(CC) $(CFLAGS) -o $@ -c $<
43         @$(CC) -M $(CPPFLAGS) -MT $@ -o $*.d.$(ARCH) $<
44
45 -include $(DEPFILES)

UCC git Repository :: git.ucc.asn.au