blob: 660ed931afb74103d4f6dae73ed1a5b544f5c596 [file] [log] [blame]
Benny Prijonoeb4cf912007-04-09 17:13:10 +00001ifeq ($(LIBDIR),)
Benny Prijonodd859a62005-11-01 16:42:51 +00002LIBDIR = ../lib
Benny Prijonoeb4cf912007-04-09 17:13:10 +00003endif
4ifeq ($(BINDIR),)
Benny Prijonodd859a62005-11-01 16:42:51 +00005BINDIR = ../bin
Benny Prijonoeb4cf912007-04-09 17:13:10 +00006endif
Benny Prijonodd859a62005-11-01 16:42:51 +00007
8#
9# The full path of output lib file (e.g. ../lib/libapp.a).
10#
11LIB = $($(APP)_LIB)
12
13#
14# The full path of output executable file (e.g. ../bin/app.exe).
15#
16EXE = $($(APP)_EXE)
17
18#
19# Source directory
20#
21SRCDIR = $($(APP)_SRCDIR)
22
23#
24# Output directory for object files (i.e. output/target)
25#
Benny Prijono0382cd82006-05-04 08:43:02 +000026OBJDIR = output/$(app)-$(TARGET_NAME)
Benny Prijonodd859a62005-11-01 16:42:51 +000027
28ifeq ($(OS_NAME),linux-kernel)
29export $(APP)_CFLAGS += -DKBUILD_MODNAME=$(app) -DKBUILD_BASENAME=$(app)
30endif
31
32
33#
34# OBJS is ./output/target/file.o
35#
36OBJS = $(foreach file, $($(APP)_OBJS), $(OBJDIR)/$(file))
37OBJDIRS := $(sort $(dir $(OBJS)))
38
39#
40# FULL_SRCS is ../src/app/file1.c ../src/app/file1.S
41#
Sauw Ming6e6c2152010-12-14 13:03:10 +000042FULL_SRCS = $(foreach file, $($(APP)_OBJS), $(SRCDIR)/$(basename $(file)).m $(SRCDIR)/$(basename $(file)).c $(SRCDIR)/$(basename $(file)).cpp $(SRCDIR)/$(basename $(file)).S)
Benny Prijonodd859a62005-11-01 16:42:51 +000043
44#
45# When generating dependency (gcc -MM), ideally we use only either
46# CFLAGS or CXXFLAGS (not both). But I just couldn't make if/ifeq to work.
47#
48DEPFLAGS = $($(APP)_CXXFLAGS) $($(APP)_CFLAGS)
49
50# Dependency file
Benny Prijono0382cd82006-05-04 08:43:02 +000051DEP_FILE := .$(app)-$(TARGET_NAME).depend
Benny Prijonodd859a62005-11-01 16:42:51 +000052
53
54print_common:
55 @echo "###"
56 @echo "### DUMPING MAKE VARIABLES (I WON'T DO ANYTHING ELSE):"
57 @echo "###"
58 @echo APP=$(APP)
59 @echo OBJDIR=$(OBJDIR)
60 @echo OBJDIRS=$(OBJDIRS)
61 @echo OBJS=$(OBJS)
62 @echo SRCDIR=$(SRCDIR)
63 @echo FULL_SRCS=$(FULL_SRCS)
64 @echo $(APP)_CFLAGS=$($(APP)_CFLAGS)
65 @echo $(APP)_CXXFLAGS=$($(APP)_CXXFLAGS)
66 @echo $(APP)_LDFLAGS=$($(APP)_LDFLAGS)
67 @echo DEPFLAGS=$(DEPFLAGS)
Benny Prijono8ec5eae2010-05-12 10:59:20 +000068 @echo CC=$(CC)
69 @echo AR=$(AR)
70 @echo RANLIB=$(RANLIB)
Benny Prijonodd859a62005-11-01 16:42:51 +000071
72print_bin: print_common
73 @echo EXE=$(EXE)
74 @echo BINDIR=$(BINDIR)
75
76print_lib: print_common
77 @echo LIB=$(LIB)
78 @echo LIBDIR=$(LIBDIR)
79
Benny Prijonob1c62042008-07-29 11:42:20 +000080$(LIB): $(OBJDIRS) $(OBJS) $($(APP)_EXTRA_DEP)
81 if test ! -d $(LIBDIR); then $(subst @@,$(subst /,$(HOST_PSEP),$(LIBDIR)),$(HOST_MKDIR)); fi
Benny Prijonoeb4cf912007-04-09 17:13:10 +000082 $(AR) $(LIB) $(OBJS)
Benny Prijonodd859a62005-11-01 16:42:51 +000083 $(RANLIB) $(LIB)
84
Benny Prijonob1c62042008-07-29 11:42:20 +000085$(EXE): $(OBJDIRS) $(OBJS) $($(APP)_EXTRA_DEP)
86 if test ! -d $(BINDIR); then $(subst @@,$(subst /,$(HOST_PSEP),$(BINDIR)),$(HOST_MKDIR)); fi
Benny Prijonodd859a62005-11-01 16:42:51 +000087 $(LD) $(LDOUT)$(subst /,$(HOST_PSEP),$(EXE)) \
88 $(subst /,$(HOST_PSEP),$(OBJS)) $($(APP)_LDFLAGS)
89
90$(OBJDIR)/$(app).o: $(OBJDIRS) $(OBJS)
91 $(CROSS_COMPILE)ld -r -o $@ $(OBJS)
92
93$(OBJDIR)/$(app).ko: $(OBJDIR)/$(app).o
94 @echo Creating kbuild Makefile...
95 @echo "# Our module name:" > $(OBJDIR)/Makefile
96 @echo 'obj-m += $(app).o' >> $(OBJDIR)/Makefile
97 @echo >> $(OBJDIR)/Makefile
98 @echo "# Object members:" >> $(OBJDIR)/Makefile
99 @echo -n '$(app)-objs += ' >> $(OBJDIR)/Makefile
100 @for file in $($(APP)_OBJS); do \
101 echo -n "$$file " >> $(OBJDIR)/Makefile; \
102 done
103 @echo >> $(OBJDIR)/Makefile
104 @echo >> $(OBJDIR)/Makefile
105 @echo "# Prevent .o files to be built by kbuild:" >> $(OBJDIR)/Makefile
106 @for file in $($(APP)_OBJS); do \
107 echo ".PHONY: `pwd`/$(OBJDIR)/$$file" >> $(OBJDIR)/Makefile; \
108 done
109 @echo >> $(OBJDIR)/Makefile
110 @echo all: >> $(OBJDIR)/Makefile
111 @echo -e "\tmake -C $(KERNEL_DIR) M=`pwd`/$(OBJDIR) modules $(KERNEL_ARCH)" >> $(OBJDIR)/Makefile
112 @echo Invoking kbuild...
113 make -C $(OBJDIR)
114
115../lib/$(app).ko: $(LIB) $(OBJDIR)/$(app).ko
116 cp $(OBJDIR)/$(app).ko ../lib
117
Sauw Ming6e6c2152010-12-14 13:03:10 +0000118$(OBJDIR)/%$(OBJEXT): $(SRCDIR)/%.m
119 $(CC) $($(APP)_CFLAGS) \
120 $(CC_OUT)$(subst /,$(HOST_PSEP),$@) \
121 $(subst /,$(HOST_PSEP),$<)
122
Benny Prijonodd859a62005-11-01 16:42:51 +0000123$(OBJDIR)/%$(OBJEXT): $(SRCDIR)/%.c
124 $(CC) $($(APP)_CFLAGS) \
125 $(CC_OUT)$(subst /,$(HOST_PSEP),$@) \
126 $(subst /,$(HOST_PSEP),$<)
127
128$(OBJDIR)/%$(OBJEXT): $(SRCDIR)/%.S
129 $(CC) $($(APP)_CFLAGS) \
130 $(CC_OUT)$(subst /,$(HOST_PSEP),$@) \
131 $(subst /,$(HOST_PSEP),$<)
132
133$(OBJDIR)/%$(OBJEXT): $(SRCDIR)/%.cpp
134 $(CC) $($(APP)_CXXFLAGS) \
135 $(CC_OUT)$(subst /,$(HOST_PSEP),$@) \
136 $(subst /,$(HOST_PSEP),$<)
137
138$(OBJDIRS):
139 $(subst @@,$(subst /,$(HOST_PSEP),$@),$(HOST_MKDIR))
140
141$(LIBDIR):
142 $(subst @@,$(subst /,$(HOST_PSEP),$(LIBDIR)),$(HOST_MKDIR))
143
144$(BINDIR):
145 $(subst @@,$(subst /,$(HOST_PSEP),$(BINDIR)),$(HOST_MKDIR))
146
147clean:
148 $(subst @@,$(subst /,$(HOST_PSEP),$(OBJDIR)/*),$(HOST_RMR))
149 $(subst @@,$(subst /,$(HOST_PSEP),$(OBJDIR)),$(HOST_RMDIR))
150ifeq ($(OS_NAME),linux-kernel)
151 rm -f ../lib/$(app).o
152endif
153
Benny Prijono7d433ec2006-02-03 15:23:28 +0000154gcov-report:
155 for file in $(FULL_SRCS); do \
156 gcov $$file -n -o $(OBJDIR); \
157 done
158
Benny Prijonodd859a62005-11-01 16:42:51 +0000159realclean: clean
160 $(subst @@,$(subst /,$(HOST_PSEP),$(LIB)) $(subst /,$(HOST_PSEP),$(EXE)),$(HOST_RM))
161 $(subst @@,$(DEP_FILE),$(HOST_RM))
162ifeq ($(OS_NAME),linux-kernel)
163 rm -f ../lib/$(app).ko
164endif
165
166depend:
167 $(subst @@,$(DEP_FILE),$(HOST_RM))
168 for F in $(FULL_SRCS); do \
169 if test -f $$F; then \
Benny Prijono4fca27b2006-03-23 18:04:15 +0000170 echo "$(OBJDIR)/" | tr -d '\n' >> $(DEP_FILE); \
Benny Prijono0c59fea2006-05-27 13:11:32 +0000171 if $(CC) -M $(DEPFLAGS) $$F | sed '/^#/d' >> $(DEP_FILE); then \
Benny Prijonodd859a62005-11-01 16:42:51 +0000172 true; \
173 else \
174 echo 'err:' >> $(DEP_FILE); \
175 rm -f $(DEP_FILE); \
176 exit 1; \
177 fi; \
178 fi; \
179 done;
180
181dep: depend
182
183-include $(DEP_FILE)
184