Cleaning up debug (and set modules to build with debug)
[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 CFGFILES += $(shell test -f Makefile.cfg && echo Makefile.cfg)
12 -include $(CFGFILES)
13
14 CPPFLAGS := -I$(ACESSDIR)/Kernel/include -I$(ACESSDIR)/Kernel/arch/$(ARCHDIR)/include -DARCH=$(ARCH) $(_CPPFLAGS)
15 CFLAGS = -Wall -Werror -fno-stack-protector $(CPPFLAGS) -g -O3 -fno-builtin
16
17 ifneq ($(CATEGORY),)
18         FULLNAME := $(CATEGORY)_$(NAME)
19 else
20         FULLNAME := $(NAME)
21 endif
22
23 CPPFLAGS += -D_MODULE_NAME_=\"$(FULLNAME)\"
24
25 ifneq ($(BUILDTYPE),static)
26         _SUFFIX := dyn_$(ARCH)
27         BIN := ../$(FULLNAME).kmd.$(ARCH)
28         CFLAGS += $(DYNMOD_CFLAGS) -fPIC
29 else
30         _SUFFIX := st_$(ARCH)
31         CFLAGS += $(KERNEL_CFLAGS)
32         BIN := ../$(NAME).xo.$(ARCH)
33 endif
34
35 OBJ := $(addsuffix .$(_SUFFIX),$(OBJ))
36
37 DEPFILES := $(filter %.o.$(_SUFFIX),$(OBJ))
38 DEPFILES := $(DEPFILES:%.o.$(_SUFFIX)=%.d.$(ARCH))
39
40 .PHONY: all clean
41
42 all: $(BIN)
43
44 clean:
45         $(RM) $(BIN) $(BIN).dsm $(KOBJ) $(OBJ) $(DEPFILES) $(EXTRA)
46
47 install: $(BIN)
48 ifneq ($(BUILDTYPE),static)
49         $(xCP) $(BIN) $(DISTROOT)/Modules/$(NAME).kmd.$(ARCH)
50 else
51 endif
52
53 ifneq ($(BUILDTYPE),static)
54 $(BIN): %.kmd.$(ARCH): $(OBJ)
55         @echo --- $(LD) -o $@
56 #       @$(LD) -T $(ACESSDIR)/Modules/link.ld --allow-shlib-undefined -shared -nostdlib -o $@ $(OBJ)
57         @$(LD) --allow-shlib-undefined -shared -nostdlib -o $@ $(OBJ) -defsym=DriverInfo=_DriverInfo_$(FULLNAME)
58         @$(DISASM) $(BIN) > $(BIN).dsm
59 else
60 $(BIN): %.xo.$(ARCH): $(OBJ)
61         @echo --- $(LD) -o $@
62         @$(LD) -r -o $@ $(OBJ)
63 endif
64
65 %.o.$(_SUFFIX): %.c Makefile ../Makefile.tpl $(CFGFILES)
66         @echo --- $(CC) -o $@
67         @$(CC) $(CFLAGS) -o $@ -c $<
68         @$(CC) -M $(CPPFLAGS) -MT $@ -o $*.d.$(ARCH) $<
69
70 -include $(DEPFILES)

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