]> rtime.felk.cvut.cz Git - omk/sssa.git/blob - snippets/vxworks
config.target is included already in base.
[omk/sssa.git] / snippets / vxworks
1 #                   Version for vxWorks builds.
2 #
3 #
4 # input variables
5 # lib_LIBRARIES    .. list of the user-space 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 # test_PROGRAMS    .. list of the test programs
11 # utils_PROGRAMS   .. list of the development utility programs
12 # xxx_SOURCES      .. list of specific target sources
13 # INCLUDES         .. additional include directories and defines for user-space
14
15 ifndef WRENV
16 $(error $(shell $(call canttest,WRENV is not defined in config.target)))
17 endif
18 ifndef WRPACKAGE
19 $(error $(shell $(call canttest,WRPACKAGE is not defined in config.target)))
20 endif
21 ifndef CPU
22 $(error $(shell $(call canttest,CPU is not defined in config.target)))
23 endif
24 ifndef TOOL
25 $(error $(shell $(call canttest,TOOL is not defined in config.target)))
26 endif
27
28 BUILD_DIR_NAME = _build/$(CPU)$(TOOL)
29 COMPILED_DIR_NAME = _compiled/$(CPU)$(TOOL)
30 GROUP_DIR_NAME =
31
32
33 USER_INCLUDE_DIR := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/include
34 USER_LIB_DIR     := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/lib
35 USER_UTILS_DIR   := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/bin-utils
36 USER_TESTS_DIR   := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/bin-tests
37 USER_BIN_DIR     := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/bin
38 USER_BUILD_DIR   := $(MAKERULES_DIR)/$(BUILD_DIR_NAME)/rtp
39
40 # Note the use of "recursive" =. That's because RELATIVE_DIR is
41 # sometimes defined later in 'base'.
42 USER_OBJS_DIR    = $(USER_BUILD_DIR)/$(RELATIVE_DIR)
43 LOCAL_BUILD_DIR  = $(USER_OBJS_DIR)
44
45 .PHONY: check-dir
46
47 # Some support to serialize some targets for parallel make
48 ifneq ($(OMK_SERIALIZE_INCLUDED),y)
49 include-pass: check-dir
50 library-pass: include-pass
51 binary-pass: library-pass
52 kernel-lib-pass: include-pass
53 kernel-mod-pass: kernel-lib-pass
54 kernel-modpost-pass: kernel-mod-pass
55 kernel-pass: kernel-mod-pass kernel-modpost-pass
56
57 override OMK_SERIALIZE_INCLUDED = y
58 endif
59
60 # Checks for OMK tester
61 ifdef OMK_TESTSROOT
62 default-config-pass-check include-pass-check:
63 library-pass-check binary-pass-check:
64         @[ -x "$(shell which $(CC))" ] || $(call canttest,Cannot file compiler: $(CC))
65         @[ -x "$(WRENV)" ] || $(call canttest,Cannot execute wrenv script)
66 endif
67
68
69 # Export some variables to VxWorks makefiles
70 CPPFLAGS  += -I $(USER_INCLUDE_DIR)
71
72 ADDED_CFLAGS = $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
73         $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -DOMK_FOR_VXWORKS -DOMK_FOR_USER
74
75 ADDED_C++FLAGS = $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
76         $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -DOMK_FOR_VXWORKS -DOMK_FOR_USER
77
78 export ADDED_CFLAGS ADDED_C++FLAGS
79
80
81 USER_SOURCES2OBJS = .o/.c .o/.cc .o/.cxx .o/.o
82
83 # Syntax: $(call PROGRAM_template,<executable-name>,<dir>,<link-variant>)
84 define PROGRAM_template
85
86 USER_IDLS  += $$($(1)_SERVER_IDL) $$($(1)_CLIENT_IDL) $$($(1)_IDL)
87 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_SERVER_IDL:%.idl=%-skels.c))
88 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_SERVER_IDL:%.idl=%-common.c))
89 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_CLIENT_IDL:%.idl=%-stubs.c))
90 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_CLIENT_IDL:%.idl=%-common.c))
91 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_IDL:%.idl=%.c))
92 USER_GEN_SOURCES += $$($(1)_GEN_SOURCES)
93
94 $(foreach x, $(USER_SOURCES2OBJS),
95 $(1)_OBJS += $$(patsubst %$(notdir $(x)),%$(dir $(x)),$$(filter %$(notdir $(x)),\
96                 $$($(1)_SOURCES) $$($(1)_GEN_SOURCES)))
97 )
98 $(1)_OBJS := $$(sort $$($(1)_OBJS:%/=%))
99
100 USER_OBJS  += $$($(1)_OBJS)
101 USER_SOURCES += $$($(1)_SOURCES)
102
103 # I hope dependedcies are solved in vxWorks makefiles
104 .PHONY: $(2)/$(1).vxe
105 $(2)/$(1).vxe:
106         @$(QUIET_CMD_ECHO) "  LINK    $$@"
107 # In rules.rtp (on line 265), dep generation depends on Makefile so we must create one
108 #       @[ ! -f Makefile ] && touch Makefile 
109         @touch Makefile
110         @echo 'EXE = $(1).vxe' > Makefile.vxe.$(1); \
111         echo 'OBJS = $$($(1)_OBJS)' >> Makefile.vxe.$(1); \
112         echo 'VXE_DIR = $(2)' >> Makefile.vxe.$(1); \
113         echo 'OBJ_DIR = $(USER_OBJS_DIR)' >> Makefile.vxe.$(1); \
114         echo 'LIB_ROOT = $(USER_LIB_DIR)' >> Makefile.vxe.$(1); \
115         echo 'OMK_LIB_PATH = $$$$(LIB_ROOT)/$$$$(VX_CPU_FAMILY)/$$$$(CPU)/$$$$(TOOL_COMMON_DIR)$$$$(LIB_DIR_TAG)/' >> Makefile.vxe.$(1); \
116         echo 'ADDED_LIBS = -L$$$$(OMK_LIB_PATH) $(lib_LOADLIBES:%=-l%) $$($(1)_LIBS:%=-l%)' >> Makefile.vxe.$(1); \
117         echo 'VPATH = $(SOURCES_DIR)' >> Makefile.vxe.$(1); \
118         echo 'include $$$$(WIND_USR)/make/rules.rtp' >> Makefile.vxe.$(1); \
119         $(WRENV) -p $(WRPACKAGE) $(MAKE)  CPU=$(CPU) TOOL=$(TOOL) -f Makefile.vxe.$(1)
120 #       echo 'ADDED_C++FLAGS += -L$(USER_LIB_DIR)' >> Makefile.vxe.$(1); \
121 #       echo 'ADDED_CFLAGS += -L$(USER_LIB_DIR)' >> Makefile.vxe.$(1); \
122 #       $(Q) $$(shell if [ -z "$$(filter %.cc,$$($(1)_SOURCES:%.cxx=%.cc))" ] ; then echo $$(CC) ; else echo $$(CXX) ; fi) \
123 #         $$($(1)_OBJS) $$($(1)_LIBS:%=-l%) $$(LOADLIBES) $$(LDFLAGS) -Wl,-Map,$(USER_OBJS_DIR)/$(1).exe.map -o $(2)/$(1)
124 #       @echo "$(2)/$(1): \\" >$(USER_OBJS_DIR)/$(1).exe.d
125 #       @sed -n -e 's/^LOAD \(.*\)$$$$/  \1  \\/p' $(USER_OBJS_DIR)/$(1).exe.map  >>$(USER_OBJS_DIR)/$(1).exe.d
126 #       @echo >>$(USER_OBJS_DIR)/$(1).exe.d
127 endef
128
129
130 # Syntax: $(call LIBRARY_template,<library-name>)
131 define LIBRARY_template
132
133 USER_IDLS  += $$($(1)_SERVER_IDL) $$($(1)_CLIENT_IDL) $$($(1)_IDL)
134 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_SERVER_IDL:%.idl=%-skels.c))
135 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_SERVER_IDL:%.idl=%-common.c))
136 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_CLIENT_IDL:%.idl=%-stubs.c))
137 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_CLIENT_IDL:%.idl=%-common.c))
138 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_IDL:%.idl=%.c))
139 USER_GEN_SOURCES += $$($(1)_GEN_SOURCES)
140
141 $(foreach x, $(USER_SOURCES2OBJS),
142 $(1)_OBJS += $$(patsubst %$(notdir $(x)),%$(dir $(x)),$$(filter %$(notdir $(x)),\
143                 $$($(1)_SOURCES) $$($(1)_GEN_SOURCES)))
144 )
145 $(1)_OBJS := $$(sort $$($(1)_OBJS:%/=%))
146 USER_OBJS  += $$($(1)_OBJS)
147 USER_SOURCES += $$($(1)_SOURCES)
148
149 # I hope dependedcies are solved in vxWorks makefiles
150 .PHONY: $(USER_LIB_DIR)/lib$(1).a
151 $(USER_LIB_DIR)/lib$(1).a: #$$($(1)_OBJS)
152         @$(QUIET_CMD_ECHO) "  LIB     $$@"
153         @echo 'LIB_BASE_NAME = $(1)' > Makefile.lib.$(1); \
154         echo 'OBJS = $$($(1)_OBJS)' >> Makefile.lib.$(1); \
155         echo 'OBJ_DIR = $(USER_OBJS_DIR)' >> Makefile.lib.$(1); \
156         echo 'LIB_ROOT = $(USER_LIB_DIR)' >> Makefile.lib.$(1); \
157         echo 'VPATH = $(SOURCES_DIR)' >> Makefile.lib.$(1); \
158 #       echo 'LIBDIRBASE = ' >> Makefile.lib.$(1); \
159         echo 'include $$$$(WIND_USR)/make/rules.library' >> Makefile.lib.$(1); 
160         $(WRENV) -p $(WRPACKAGE) $(MAKE) CPU=$(CPU) TOOL=$(TOOL) -f Makefile.lib.$(1)
161 endef
162
163
164
165
166 # Generate rules for compilation of programs and libraries
167
168 $(foreach prog,$(utils_PROGRAMS),$(eval $(call PROGRAM_template,$(prog),$(USER_UTILS_DIR))))
169
170 $(foreach prog,$(test_PROGRAMS),$(eval $(call PROGRAM_template,$(prog),$(USER_TESTS_DIR))))
171
172 $(foreach prog,$(bin_PROGRAMS),$(eval $(call PROGRAM_template,$(prog),$(USER_BIN_DIR))))
173
174 $(foreach lib,$(lib_LIBRARIES),$(eval $(call LIBRARY_template,$(lib))))
175
176 $(foreach lib,$(shared_LIBRARIES),$(eval $(call SOLIB_template,$(lib))))
177
178 OTHER_PASSES = clean install include-pass
179 $(eval $(call omk_pass_template,$(OTHER_PASSES),$(USER_OBJS_DIR),,always))
180
181 include-pass-local:
182         $(call include-pass-template,$(USER_INCLUDE_DIR),include)
183
184 library-pass-local: $(addprefix $(USER_INCLUDE_DIR)/,$(cmetric_include_HEADERS)) \
185                     $(lib_LIBRARIES:%=$(USER_LIB_DIR)/lib%.a) $(shared_LIBRARIES:%=$(USER_LIB_DIR)/lib%.$(SOLIB_EXT))
186
187 binary-pass-local: $(bin_PROGRAMS:%=$(USER_BIN_DIR)/%.vxe) $(test_PROGRAMS:%=$(USER_TESTS_DIR)/%.vxe) $(utils_PROGRAMS:%=$(USER_UTILS_DIR)/%.vxe)
188
189 clean-local:
190         @echo Cleaning in $(USER_OBJS_DIR)
191         @rm -f $(USER_OBJS_DIR)/*.o $(USER_OBJS_DIR)/*.lo \
192                $(USER_OBJS_DIR)/*.d \
193                $(USER_OBJS_DIR)/*.map \
194                $(LOCAL_CONFIG_H:%=$(USER_OBJS_DIR)/%)
195
196 $(eval $(call omk_pass_template, library-pass,$(USER_OBJS_DIR),USER_RULE_TEMPLATES=y,$(lib_LIBRARIES)$(shared_LIBRARIES)))
197 $(eval $(call omk_pass_template, binary-pass, $(USER_OBJS_DIR),USER_RULE_TEMPLATES=y,$(bin_PROGRAMS)$(utils_PROGRAMS)$(test_PROGRAMS)))
198
199 check-dir:
200         @$(call mkdir_def,$(USER_BUILD_DIR))
201         @$(call mkdir_def,$(USER_INCLUDE_DIR))
202         @$(call mkdir_def,$(USER_LIB_DIR))
203         @$(call mkdir_def,$(USER_BIN_DIR))
204         @$(call mkdir_def,$(USER_UTILS_DIR))
205         @$(call mkdir_def,$(USER_TESTS_DIR))
206
207
208 default: include-pass library-pass binary-pass
209
210 # Local Variables:
211 # mode:makefile
212 # End: