]> rtime.felk.cvut.cz Git - omk.git/blob - snippets/rtems.omk
Use wvtool for testing instead of wvtestrun
[omk.git] / snippets / rtems.omk
1 #                   This version is adapted for RTEMS build
2 #
3 #
4 # lib_LIBRARIES    .. list of the user-space libraries
5 # shared_LIBRARIES .. list of the user-space shared libraries
6 # include_HEADERS  .. list of the user-space public header files
7 # nobase_include_HEADERS .. public headers copied even with directory part
8 # renamed_include_HEADERS .. public headers copied to the different target name
9 # bin_PROGRAMS     .. list of the require binary programs
10 # utils_PROGRAMS   .. list of the development utility programs
11 # test_PROGRAMS    .. list of the test programs
12 # xxx_SOURCES      .. list of specific target sources
13 # xxx_LIBS         .. list of specific target libraries
14 # INCLUDES         .. additional include directories and defines for user-space
15 # tar_EMBEDFILES   .. list of tars with embedded files
16
17 include $(RTEMS_MAKEFILE_PATH)/Makefile.inc
18 include $(RTEMS_CUSTOM)
19 include $(CONFIG.CC)
20
21 BUILD_DIR_NAME = _build/$(RTEMS_BSP)
22 COMPILED_DIR_NAME = _compiled/$(RTEMS_BSP)
23 GROUP_DIR_NAME =
24
25
26 USER_INCLUDE_DIR := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/include
27 USER_LIB_DIR     := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/lib
28 USER_UTILS_DIR   := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/bin-utils
29 USER_TESTS_DIR   := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/bin-tests
30 USER_BIN_DIR     := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/bin
31 USER_BUILD_DIR   := $(MAKERULES_DIR)/$(BUILD_DIR_NAME)/user
32
33 LOCAL_BUILD_DIR  = $(USER_OBJS_DIR)
34
35
36 DEFAULT_INCLUDES = -I $(PROJECT_INCLUDE)
37
38 CPPFLAGS  += -I $(USER_INCLUDE_DIR)
39
40 CPPFLAGS  += $(CONFIG_OMK_DEFINES)
41
42 #CPPFLAGS  += $(OMK_CPPFLAGS)
43 #CFLAGS    += $(OMK_CFLAGS)
44 #CXXFLAGS  += $(OMK_CXXFLAGS)
45 #LDFLAGS   += $(CFLAGS) $(OMK_CFLAGS) $(LD_PATHS:%=-L%)
46
47 LOADLIBES += -L$(USER_LIB_DIR)
48
49 LOADLIBES += $(lib_LOADLIBES:%=-l%)
50
51 SOLIB_PICFLAGS += -shared -fpic
52
53 ifndef RELATIVE_DIR
54 RELATIVE_DIR := $(SOURCES_DIR:$(MAKERULES_DIR)%=%)
55 endif
56 override RELATIVE_DIR := $(RELATIVE_DIR:/%=%)
57 override RELATIVE_DIR := $(RELATIVE_DIR:\\%=%)
58 #$(warning  RELATIVE_DIR $(RELATIVE_DIR))
59
60 #$(warning SOURCES_DIR = $(SOURCES_DIR))
61 #$(warning MAKERULES_DIR = $(MAKERULES_DIR))
62 #$(warning RELATIVE_DIR = $(RELATIVE_DIR))
63
64 #vpath %.c $(SOURCES_DIR)
65 #vpath %.cc $(SOURCES_DIR)
66 #vpath %.cxx $(SOURCES_DIR)
67
68 USER_OBJS_DIR = $(USER_BUILD_DIR)/$(RELATIVE_DIR)
69
70 .PHONY: check-dir
71
72 # Some support to serialize some targets for parallel make
73 ifneq ($(OMK_SERIALIZE_INCLUDED),y)
74 include-pass: check-dir
75 library-pass: include-pass
76 binary-pass: library-pass
77
78 override OMK_SERIALIZE_INCLUDED = y
79 MAKEOVERRIDES := $(filter-out OMK_SERIALIZE_INCLUDED=n,$(MAKEOVERRIDES))
80 endif
81
82 #=====================================================================
83 # Special rules for target filesystem and data preparation
84
85 # Syntax: $(call TARFILE_template,<filename>,<filename2>,<directory>) FIXME: Is this correct?
86 define TARFILE_template
87
88 .PHONY: $(2)
89
90 $(2):
91         $(Q) ABSOLUTETARFILE=`cd $$(dir $$@) ; pwd`/$$@ ; \
92              ( test -e $$$$ABSOLUTETARFILE && ( cd  $(3) && tar $$(TARFLAGS) -df $$$$ABSOLUTETARFILE ) ) || \
93              ( cd  $(3) && tar $$(TARFLAGS) -cf $$$$ABSOLUTETARFILE . )
94
95 $(2).o: $(2)
96         @$(QUIET_CMD_ECHO) "  TARFILE $$@"
97         $(Q) $(LD) -r --accept-unknown-input-arch -b binary -o $$@.tmp $$^
98         $(Q) $(OBJCOPY) --rename-section .data=.rodata,alloc,load,readonly,data,contents $$@.tmp $$@
99
100 endef
101
102 #=====================================================================
103 # User-space rules and templates to compile programs, libraries etc.
104
105 ifdef USER_RULE_TEMPLATES
106
107
108 #%.lo: %.c
109 #       $(CC) -o $@ $(LCFLAGS) -c $<
110
111 c_o_COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(OMK_CPPFLAGS) \
112         $(CPPFLAGS) $(OMK_CFLAGS) $(CFLAGS) $(INCLUDES) -DOMK_FOR_USER
113
114 cc_o_COMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(OMK_CPPFLAGS) \
115         $(CPPFLAGS) $(OMK_CXXFLAGS) $(CFLAGS) $(CXXFLAGS) $(INCLUDES) -DOMK_FOR_USER
116
117 S_o_COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(OMK_CPPFLAGS) \
118         $(CPPFLAGS) $(OMK_CFLAGS) $(CFLAGS) $(ASFLAGS) -DOMK_FOR_USER
119
120 # Check GCC version for user build
121 ifndef CC_MAJOR_VERSION
122 CC_MAJOR_VERSION := $(shell $(CC) -dumpversion | $(SED4OMK) -e 's/\([^.]\)\..*/\1/')
123 endif
124 # Prepare suitable define for dependency building
125 ifeq ($(CC_MAJOR_VERSION),2)
126 CC_DEPFLAGS = -Wp,-MD,"$@.d.tmp"
127 else
128 CC_DEPFLAGS = -MT $@ -MD -MP -MF "$@.d.tmp"
129 endif
130
131
132 # Syntax: $(call COMPILE_c_o_template,<source>,<target>,<additional c-flags>)
133 define COMPILE_c_o_template
134 $(2): $(1) $$(GEN_HEADERS)
135         @$(QUIET_CMD_ECHO) "  CC      $$@"
136         $(Q) if $$(c_o_COMPILE) $$(CC_DEPFLAGS) $(3) -o $$@ -c $$< ; \
137         then mv -f "$$@.d.tmp" "$$@.d" ; \
138         else rm -f "$$@.d.tmp" ; exit 1; \
139         fi
140 endef
141
142
143 # Syntax: $(call COMPILE_cc_o_template,<source>,<target>,<additional c-flags>)
144 define COMPILE_cc_o_template
145 $(2): $(1) $$(GEN_HEADERS)
146         @$(QUIET_CMD_ECHO) "  CXX     $$@"
147         $(Q) if $$(cc_o_COMPILE) $$(CC_DEPFLAGS) $(3) -o $$@ -c $$< ; \
148         then mv -f "$$@.d.tmp" "$$@.d" ; \
149         else rm -f "$$@.d.tmp" ; exit 1; \
150         fi
151 endef
152
153
154 # Syntax: $(call COMPILE_S_o_template,<source>,<target>,<additional c-flags>)
155 define COMPILE_S_o_template
156 $(2): $(1) $$(GEN_HEADERS)
157         @$(QUIET_CMD_ECHO) "  AS      $$@"
158         $(Q) if $$(S_o_COMPILE) -D__ASSEMBLY__ $$(CC_DEPFLAGS) $(3) -o $$@ -c $$< ; \
159         then if [ -e "$$@.d.tmp" ] ; then mv -f "$$@.d.tmp" "$$@.d" ; fi ; \
160         else rm -f "$$@.d.tmp" ; exit 1; \
161         fi
162 endef
163
164 idl_COMPILE = $(IDL_COMPILER)
165
166 define COMPILE_idl_template
167 $(2).c $(2)-stubs.c $(2)-skels.c $(2)-common.c $(2).h: $(1) $$(wildcard $$(firstword $$(idl_COMPILE)))
168         @$(QUIET_CMD_ECHO) "  IDL     $$@"
169         $(Q) $$(idl_COMPILE) $$($(2)_IDLFLAGS) $(1)
170 endef
171
172 # Syntax: $(call PROGRAM_template,<executable-name>,<dir>,<link-variant>)
173 define PROGRAM_template
174 USER_IDLS  += $$($(1)_SERVER_IDL) $$($(1)_CLIENT_IDL) $$($(1)_IDL)
175 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_SERVER_IDL:%.idl=%-skels.c))
176 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_SERVER_IDL:%.idl=%-common.c))
177 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_CLIENT_IDL:%.idl=%-stubs.c))
178 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_CLIENT_IDL:%.idl=%-common.c))
179 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_IDL:%.idl=%.c))
180 USER_GEN_SOURCES += $$($(1)_GEN_SOURCES)
181
182 $(1)_OBJS += $$(filter %.o,$$($(1)_SOURCES:%.c=%.o) $$($(1)_GEN_SOURCES:%.c=%.o))
183 $(1)_OBJS += $$(filter %.o,$$($(1)_SOURCES:%.cc=%.o) $$($(1)_GEN_SOURCES:%.c=%.o))
184 $(1)_OBJS += $$(filter %.o,$$($(1)_SOURCES:%.cxx=%.o) $$($(1)_GEN_SOURCES:%.c=%.o))
185 $(1)_OBJS += $$(filter %.o,$$($(1)_SOURCES:%.S=%.o) $$($(1)_GEN_SOURCES:%.c=%.o))
186 $(1)_OBJS += $$($(1)_EMBEDTARFILES:%=%_tarfile.o)
187 $(1)_OBJS := $$(sort $$($(1)_OBJS))
188
189 USER_OBJS  += $$($(1)_OBJS)
190 USER_SOURCES += $$($(1)_SOURCES)
191 USER_EMBEDTARFILES += $$($(1)_EMBEDTARFILES)
192
193 $(2)/$(1): $(USER_LIB_DIR)/timestamp
194 $(2)/$(1): $$($(1)_OBJS)
195         @$(QUIET_CMD_ECHO) "  LINK    $$@"
196         $(Q) $$(shell if [ -z "$$(filter %.cc,$$($(1)_SOURCES))" ] ; \
197           then echo $$(CC)  $$(CPPFLAGS) $$(OMK_CPPFLAGS) $$(OMK_CFLAGS) $$(CFLAGS) ; \
198           else echo $$(CXX) $$(CPPFLAGS) $$(OMK_CPPFLAGS) $$(OMK_CXXFLAGS) $$(CXXFLAGS) ; fi) \
199           $$(OMK_LDFLAGS) $$(LDFLAGS) $$($(1)_OBJS) $$(LOADLIBES) $$($(1)_LIBS:%=-l%) \
200           -o $(2)/$(1)
201 #@echo "$(2)/$(1): \\" >$(USER_OBJS_DIR)/$(1).exe.d
202 #@$(SED4OMK) -n -e 's/^LOAD \(.*\)$$$$/  \1  \\/p' $(USER_OBJS_DIR)/$(1).exe.map  >>$(USER_OBJS_DIR)/$(1).exe.d
203 #@echo >>$(USER_OBJS_DIR)/$(1).exe.d
204 #-Wl,-Map,$(USER_OBJS_DIR)/$(1).exe.map
205 # FIXME: Why the map file was commented out?
206 endef
207
208
209
210 # Syntax: $(call LIBRARY_template,<library-name>)
211 define LIBRARY_template
212 USER_IDLS  += $$($(1)_SERVER_IDL) $$($(1)_CLIENT_IDL) $$($(1)_IDL)
213 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_SERVER_IDL:%.idl=%-skels.c))
214 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_SERVER_IDL:%.idl=%-common.c))
215 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_CLIENT_IDL:%.idl=%-stubs.c))
216 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_CLIENT_IDL:%.idl=%-common.c))
217 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_IDL:%.idl=%.c))
218 USER_GEN_SOURCES += $$($(1)_GEN_SOURCES)
219
220 $(1)_OBJS += $$(filter %.o,$$($(1)_SOURCES:%.c=%.o) $$($(1)_GEN_SOURCES:%.c=%.o))
221 $(1)_OBJS += $$(filter %.o,$$($(1)_SOURCES:%.cc=%.o) $$($(1)_GEN_SOURCES:%.c=%.o))
222 $(1)_OBJS += $$(filter %.o,$$($(1)_SOURCES:%.cxx=%.o) $$($(1)_GEN_SOURCES:%.c=%.o))
223 $(1)_OBJS += $$(filter %.o,$$($(1)_SOURCES:%.S=%.o) $$($(1)_GEN_SOURCES:%.c=%.o))
224 $(1)_OBJS += $$($(1)_EMBEDTARFILES:%=%_tarfile.o)
225 $(1)_OBJS := $$(sort $$($(1)_OBJS))
226
227 USER_OBJS  += $$($(1)_OBJS)
228 USER_SOURCES += $$($(1)_SOURCES)
229 USER_EMBEDTARFILES += $$($(1)_EMBEDTARFILES)
230
231 $(USER_LIB_DIR)/lib$(1).a: $$($(1)_OBJS)
232         @$(QUIET_CMD_ECHO) "  AR      $$@"
233         $(Q) $(AR) rcs $$@ $$^
234         @touch $(USER_LIB_DIR)/timestamp
235 endef
236
237 $(USER_LIB_DIR)/timestamp:
238         $(Q)touch $@
239
240 # Syntax: $(call SOLIB_template,<library-name>)
241 define SOLIB_template
242 USER_IDLS  += $$($(1)_SERVER_IDL) $$($(1)_CLIENT_IDL) $$($(1)_IDL)
243 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_SERVER_IDL:%.idl=%-skels.c))
244 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_SERVER_IDL:%.idl=%-common.c))
245 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_CLIENT_IDL:%.idl=%-stubs.c))
246 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_CLIENT_IDL:%.idl=%-common.c))
247 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_IDL:%.idl=%.c))
248 SOLIB_GEN_SOURCES += $$($(1)_GEN_SOURCES)
249
250 $(1)_OBJSLO += $$(filter %.lo,$$($(1)_SOURCES:%.c=%.lo) $$($(1)_GEN_SOURCES:%.c=%.lo))
251 $(1)_OBJSLO += $$(filter %.lo,$$($(1)_SOURCES:%.cc=%.lo) $$($(1)_GEN_SOURCES:%.c=%.lo))
252 $(1)_OBJSLO += $$(filter %.lo,$$($(1)_SOURCES:%.cxx=%.lo) $$($(1)_GEN_SOURCES:%.c=%.lo))
253 $(1)_OBJSLO += $$(filter %.lo,$$($(1)_SOURCES:%.S=%.lo) $$($(1)_GEN_SOURCES:%.c=%.lo))
254 $(1)_OBJS += $$($(1)_EMBEDTARFILES:%=%_tarfile.o)
255 $(1)_OBJSLO := $$(sort $$($(1)_OBJSLO))
256
257 SOLIB_OBJS  += $$($(1)_OBJSLO)
258 SOLIB_SOURCES += $$($(1)_SOURCES)
259 USER_EMBEDTARFILES += $$($(1)_EMBEDTARFILES)
260
261 $(USER_LIB_DIR)/lib$(1).so: $$($(1)_OBJSLO)
262         @$(QUIET_CMD_ECHO) "  LINK    $$@"
263         $(Q) $(LD) --shared --soname=lib$(1).so -o $$@ $$^
264 endef
265
266
267
268 library-pass-local: $(lib_LIBRARIES:%=$(USER_LIB_DIR)/lib%.a) $(shared_LIBRARIES:%=$(USER_LIB_DIR)/lib%.so)
269
270 binary-pass-local: $(bin_PROGRAMS:%=$(USER_BIN_DIR)/%) $(utils_PROGRAMS:%=$(USER_UTILS_DIR)/%) $(test_PROGRAMS:%=$(USER_TESTS_DIR)/%)
271
272 GEN_HEADERS+=$(filter %.h,$(USER_IDLS:%.idl=%.h))
273
274 # Generate rules for compilation of programs and libraries
275
276 $(foreach prog,$(utils_PROGRAMS),$(eval $(call PROGRAM_template,$(prog),$(USER_UTILS_DIR))))
277
278 $(foreach prog,$(test_PROGRAMS),$(eval $(call PROGRAM_template,$(prog),$(USER_TESTS_DIR))))
279
280 $(foreach prog,$(bin_PROGRAMS),$(eval $(call PROGRAM_template,$(prog),$(USER_BIN_DIR))))
281
282 $(foreach lib,$(lib_LIBRARIES),$(eval $(call LIBRARY_template,$(lib))))
283
284 $(foreach lib,$(shared_LIBRARIES),$(eval $(call SOLIB_template,$(lib))))
285
286 # IDL compilation
287 USER_IDLS := $(sort $(USER_IDLS))
288 $(foreach src,$(filter %.idl,$(USER_IDLS)),$(eval $(call COMPILE_idl_template,$(SOURCES_DIR)/$(src),$(src:%.idl=%))))
289
290
291 -include $(USER_OBJS_DIR)/*.d
292
293 endif
294
295 #=====================================================================
296
297
298 $(eval $(call omk_pass_template, include-pass,$(USER_OBJS_DIR),USER_RULE_TEMPLATES=y,$(include_HEADERS)$(nobase_include_HEADERS)$(renamed_include_HEADERS)$(config_include_HEADERS)$(LOCAL_CONFIG_H)))
299 $(eval $(call omk_pass_template, library-pass,$(USER_OBJS_DIR),USER_RULE_TEMPLATES=y,$(lib_LIBRARIES)$(shared_LIBRARIES)))
300 $(eval $(call omk_pass_template, binary-pass, $(USER_OBJS_DIR),USER_RULE_TEMPLATES=y,$(bin_PROGRAMS)$(utils_PROGRAMS)$(test_PROGRAMS)))
301
302 $(eval $(call omk_pass_template,clean,$(USER_OBJS_DIR),,always))
303
304 check-dir::
305         @$(call mkdir_def,$(USER_INCLUDE_DIR))
306         @$(call mkdir_def,$(USER_LIB_DIR))
307         @$(call mkdir_def,$(USER_BIN_DIR))
308         @$(call mkdir_def,$(USER_UTILS_DIR))
309         @$(call mkdir_def,$(USER_TESTS_DIR))
310
311 $(eval $(call include-pass-template,$(USER_INCLUDE_DIR),include))
312
313 ifdef USER_RULE_TEMPLATES
314
315 # User-space static libraries and applications object files
316
317 USER_SOURCES := $(sort $(USER_SOURCES))
318 USER_GEN_SOURCES := $(sort $(USER_GEN_SOURCES))
319
320 #$(warning USER_SOURCES = $(USER_SOURCES))
321
322 $(foreach src,$(filter %.c,$(USER_SOURCES)),$(eval $(call COMPILE_c_o_template,$(SOURCES_DIR)/$(src),$(src:%.c=%.o),)))
323
324 $(foreach src,$(filter %.cc,$(USER_SOURCES)),$(eval $(call COMPILE_cc_o_template,$(SOURCES_DIR)/$(src),$(src:%.cc=%.o),)))
325
326 $(foreach src,$(filter %.cxx,$(USER_SOURCES)),$(eval $(call COMPILE_cc_o_template,$(SOURCES_DIR)/$(src),$(src:%.cxx=%.o),)))
327
328 $(foreach src,$(filter %.S,$(USER_SOURCES)),$(eval $(call COMPILE_S_o_template,$(SOURCES_DIR)/$(src),$(src:%.S=%.o),)))
329
330 $(foreach src,$(filter %.c,$(USER_GEN_SOURCES)),$(eval $(call COMPILE_c_o_template,$(src),$(src:%.c=%.o),)))
331
332 # User-space shared libraries object files
333
334 SOLIB_SOURCES := $(sort $(SOLIB_SOURCES))
335
336 #$(warning SOLIB_SOURCES = $(SOLIB_SOURCES))
337
338 $(foreach src,$(filter %.c,$(SOLIB_SOURCES)),$(eval $(call COMPILE_c_o_template,$(SOURCES_DIR)/$(src),$(src:%.c=%.lo),$(SOLIB_PICFLAGS))))
339
340 $(foreach src,$(filter %.cc,$(SOLIB_SOURCES)),$(eval $(call COMPILE_cc_o_template,$(SOURCES_DIR)/$(src),$(src:%.cc=%.lo),$(SOLIB_PICFLAGS))))
341
342 $(foreach src,$(filter %.cxx,$(SOLIB_SOURCES)),$(eval $(call COMPILE_cc_o_template,$(SOURCES_DIR)/$(src),$(src:%.cxx=%.lo),$(SOLIB_PICFLAGS))))
343
344 $(foreach src,$(filter %.S,$(SOLIB_SOURCES)),$(eval $(call COMPILE_S_o_template,$(SOURCES_DIR)/$(src),$(src:%.S=%.lo),$(SOLIB_PICFLAGS))))
345
346 $(foreach tarfile,$(USER_EMBEDTARFILES),$(eval $(call TARFILE_template,$(tarfile),$(tarfile)_tarfile,$(SOURCES_DIR)/$(tarfile))))
347
348 endif
349
350
351 clean-local::
352         @echo Cleaning in $(USER_OBJS_DIR)
353         @rm -f $(USER_OBJS_DIR)/*.o $(USER_OBJS_DIR)/*.lo \
354                $(USER_OBJS_DIR)/*.d \
355                $(USER_OBJS_DIR)/*.map \
356                $(LOCAL_CONFIG_H:%=$(USER_OBJS_DIR)/%) \
357                $(tar_EMBEDFILES:%=$(USER_OBJS_DIR)/%_tarfile)
358
359
360 default: include-pass library-pass binary-pass
361
362 include-pass-submakes: extra-rules-subdirs
363
364 # We must go to EXTRA_RULES_SUBDIRS before going to any other
365 # directory, since the executables compiled in EXTRA_RULES_SUBDIRS
366 # might be needed there.
367 include-pass-this-dir $(foreach subdir,$(SUBDIRS),include-pass-$(subdir)-subdir): extra-rules-subdirs