OSDN Git Service

- only strip if cc compiled fine
[uclinux-h8/uClibc.git] / Makerules
1 #
2 # Licensed under LGPL v2.1, see the file COPYING.LIB in this tarball for details.
3 #
4
5 .SUFFIXES: .c .S .o .os .oS .so .a .s .i
6
7 PHONY := FORCE
8
9 .PHONY: dummy $(PHONY) \
10         all check test $(clean_targets) \
11         config dist menuconfig oldconfig release \
12         subdirs utils help
13
14 # order is important, the stripping uses STRIP_FLAGS for lib-so, but not for lib-a
15 ifeq ($(HAVE_SHARED),y)
16 .LIBPATTERNS: "lib%.so"
17 libs: $(lib-so-y) $(lib-a-y)
18 $(lib-so-y): | $(interp)
19 else
20 .LIBPATTERNS: "lib%.a"
21 ifeq ($(UCLIBC_FORMAT_SHARED_FLAT),y)
22 libs: $(lib-gdb-y)
23 endif
24 libs: $(lib-a-y)
25 endif
26 objs: all_objs
27
28 shared_objs = $(libc-y:.o=.os) $(libc-shared-y) $(libc-nonshared-y) \
29         $(libcrypt-so-y) $(libdl-so-y) \
30         $(libintl-so-y) $(libm-so-y) $(libnsl-so-y) \
31         $(libpthread-so-y) $(libpthread-nonshared-y) $(libthread_db-so-y) \
32         $(libresolv-so-y) $(librt-so-y) \
33         $(ldso-y) \
34         $(libutil-so-y)
35
36 ar_objs =  $(libc-y) $(libc-static-y) $(libcrypt-a-y) \
37         $(libdl-a-y) $(libintl-a-y) $(libm-a-y) $(libnsl-a-y) \
38         $(libpthread-a-y) $(libthread_db-a-y) \
39         $(libresolv-a-y) $(librt-a-y) $(libutil-a-y)
40 ifeq ($(DOPIC),y)
41 ar_objs := $(ar_objs:.o=.os)
42 endif
43 flat_objs = $(lib-gdb-y)
44
45 ifeq ($(HAVE_SHARED),y)
46 all_objs: $(sort $(shared_objs) $(ar_objs))
47 else
48 all_objs: $(ar_objs)
49 endif
50 $(shared_objs) $(ar_objs): | $(sub_headers)
51
52 headers-y: $(headers-y)
53         @true
54
55 MAKEFLAGS += --no-print-directory
56 SHELL_SET_X := set +x
57 ifneq ($(findstring s,$(MAKEFLAGS)),)
58 export MAKE_IS_SILENT := y
59 SECHO := -@false
60 DISP := sil
61 Q := @
62 else
63 export MAKE_IS_SILENT := n
64 SECHO := @echo
65 ifneq ($(V)$(VERBOSE),)
66 SHELL_SET_X := set -x
67 DISP := ver
68 Q :=
69 else
70 DISP := pur
71 Q := @
72 endif
73 endif
74
75 show_objs = $(subst ../,,$@)
76
77 pur_disp_compile.c = echo "  "CC $(show_objs)
78 pur_disp_compile.i = echo "  "CPP $(show_objs)
79 pur_disp_compile.s = echo "  "CC-S $(show_objs)
80 pur_disp_compile.u = echo "  "CC $(show_objs)
81 pur_disp_compile.S = echo "  "AS $(show_objs)
82 pur_disp_compile.m = $(pur_disp_compile.c)
83 pur_disp_compile-m = echo "  "CC-m $(show_objs)
84 pur_disp_hcompile.u= echo "  "HOSTCC $(show_objs)
85 pur_disp_hcompile.o= echo "  "HOSTCC-o $(show_objs)
86 pur_disp_strip     = echo "  "STRIP $(STRIP_FLAGS) $@
87 pur_disp_t_strip   = echo "  "STRIP $(STRIP_FLAGS) $@
88 pur_disp_ar        = echo "  "AR $(ARFLAGS) $@
89 pur_disp_ld        = echo "  "LD $(1)
90 pur_disp_ln        = echo "  "LN $@
91 pur_disp_mkdir     = echo "  "MKDIR $@
92 pur_disp_gen       = echo "  "GEN $@
93 pur_disp_unifdef   = echo "  "UNIFDEF $@
94 pur_disp_rm        = echo "  "CLEAN $(@:_clean=)
95
96 sil_disp_compile.c = true
97 sil_disp_compile.i = true
98 sil_disp_compile.s = true
99 sil_disp_compile.u = true
100 sil_disp_compile.S = true
101 sil_disp_compile.m = true
102 sil_disp_compile-m = true
103 sil_disp_hcompile.u= true
104 sil_disp_hcompile.o= true
105 sil_disp_strip     = true
106 sil_disp_t_strip   = true
107 sil_disp_ar        = true
108 sil_disp_ld        = true
109 sil_disp_ln        = true
110 sil_disp_mkdir     = true
111 sil_disp_gen       = true
112 sil_disp_unifdef   = true
113 sil_disp_rm        = true
114
115 ver_disp_compile.c = echo $(cmd_compile.c)
116 ver_disp_compile.i = echo $(cmd_compile.i)
117 ver_disp_compile.s = echo $(cmd_compile.s)
118 ver_disp_compile.u = echo $(cmd_compile.u)
119 ver_disp_compile.S = echo $(cmd_compile.S)
120 ver_disp_compile.m = echo $(cmd_compile.m)
121 ver_disp_compile-m = echo $(cmd_compile-m)
122 ver_disp_hcompile.u= echo $(cmd_hcompile.u)
123 ver_disp_hcompile.o= echo $(cmd_hcompile.o)
124 ver_disp_strip     = echo $(cmd_strip)
125 ver_disp_t_strip   = echo $(cmd_t_strip)
126 ver_disp_ar        = echo $(cmd_ar)
127 ver_disp_ld        =
128 ver_disp_ln        =
129 ver_disp_mkdir     =
130 ver_disp_gen       =
131 ver_disp_unifdef   = echo $(cmd_unifdef)
132 ver_disp_rm        =
133
134 disp_compile.c = $($(DISP)_disp_compile.c)
135 disp_compile.i = $($(DISP)_disp_compile.i)
136 disp_compile.s = $($(DISP)_disp_compile.s)
137 disp_compile.u = $($(DISP)_disp_compile.u)
138 disp_compile.S = $($(DISP)_disp_compile.S)
139 disp_compile.m = $($(DISP)_disp_compile.m)
140 disp_compile-m = $($(DISP)_disp_compile-m)
141 disp_hcompile.u= $($(DISP)_disp_hcompile.u)
142 disp_hcompile.o= $($(DISP)_disp_hcompile.o)
143 disp_strip     = $($(DISP)_disp_strip)
144 disp_t_strip   = $($(DISP)_disp_t_strip)
145 disp_ar        = $($(DISP)_disp_ar)
146 disp_ld        = $($(DISP)_disp_ld)
147 disp_ln        = $($(DISP)_disp_ln)
148 disp_mkdir     = $($(DISP)_disp_mkdir)
149 disp_gen       = $($(DISP)_disp_gen)
150 disp_unifdef   = $($(DISP)_disp_unifdef)
151 disp_rm        = $($(DISP)_disp_rm)
152
153 any-prereq = $(filter-out $(PHONY),$?) $(filter-out $(PHONY) $(wildcard $^),$^)
154
155 # ../foo/bar/baz.ext -> foo_bar_baz.ext
156 variablify = $(subst /,_,$(subst $(top_builddir),,$(1)))
157 # strip the top_builddir off everything to make the *string* idempotent for -C
158 dirify = $(subst $(top_builddir),,$(patsubst -L$(top_builddir)%,-L%,$(patsubst -I$(top_builddir)%,-I%,$(1))))
159
160 # True if not identical. Neither order nor whitespace nor identical flags
161 # matter.
162 compare_flags = \
163         $(strip $(filter-out $(call dirify,$(cmd_$(call variablify,$(1)))), \
164                                 $(call dirify,$(cmd_$(call variablify,$(@))))) \
165                 $(filter-out $(call dirify,$(cmd_$(call variablify,$(@)))), \
166                                 $(call dirify,$(cmd_$(call variablify,$(1))))))
167
168 # Rebuild if any prerequisite, the used CC or flags changed.
169 # Previously used flags are stored in the corresponding .%.dep files
170 maybe_exec = \
171                 $(if $(strip $(compare_flags) $(any-prereq)), \
172                 @set -e; \
173                 $(disp_$(1)); \
174                 $(cmd_$(1)); \
175                 echo 'cmd_$(call variablify,$@) := $(call dirify,$(cmd_$(call variablify,$1)))' >> $(dir $@).$(notdir $@).dep)
176
177
178 CFLAGS_gen.dep = -MT $@ -MD -MP -MF $(dir $@).$(notdir $@).dep
179
180 cmd_compile.c = $(CC) -c $< -o $@ $(CFLAGS) $(ARCH_CFLAGS) \
181         $(CFLAGS-$(suffix $@)) \
182         $(filter-out $(CFLAGS-OMIT-$(notdir $<)),$(CFLAGS-$(notdir $(<D)))) \
183         $(CFLAGS-$(subst $(top_srcdir),,$(dir $<))) \
184         $(CFLAGS-$(notdir $<)) \
185         $(CFLAGS-$(notdir $@)) \
186         $(CFLAGS_gen.dep)
187 cmd_compile.i = $(cmd_compile.c:-c=-E -dD $(EXTRA_CPPFLAGS))
188 cmd_compile.s = $(cmd_compile.c:-c=-S)
189 cmd_compile.u = $(CC) $^ $(DEPS-$(notdir $@)) -o $@ $(CFLAGS) $(CFLAGS-$(notdir $(^D))) $(CFLAGS-$(notdir $@)) $(CFLAGS_gen.dep)
190 cmd_compile.S = $(filter-out -std=gnu99, $(cmd_compile.c)) -D__ASSEMBLER__ $(ASFLAGS) $(ARCH_ASFLAGS) $(ASFLAGS-$(suffix $@)) $(ASFLAGS-$(notdir $<)) $(ASFLAGS-$(notdir $@))
191 cmd_compile.m = $(cmd_compile.c) -DL_$(patsubst %$(suffix $(notdir $@)),%,$(notdir $@))
192
193 cmd_compile-m = $(CC) $^ -c -o $@ $(CFLAGS) $(ARCH_CFLAGS) $(CFLAGS-$(suffix $@)) $(CFLAGS-$(notdir $(@D))) $(CFLAGS-$(notdir $@))
194 cmd_strip     = $(STRIPTOOL) $(STRIP_FLAGS) $^
195 cmd_t_strip   = $(STRIPTOOL) $(STRIP_FLAGS) $@
196 cmd_ar        = $(AR) $(ARFLAGS) $@ $^
197
198 define do_ln
199         @$(disp_ln)
200         $(Q)$(LN) -fs
201 endef
202
203
204 define do_rm
205         @$(disp_rm)
206         $(Q)$(RM)
207 endef
208
209 define do_awk
210         @$(disp_gen)
211         $(Q)$(AWK) -f
212 endef
213
214 compile.c = @$(call maybe_exec,compile.c)
215 compile.i =  $(call maybe_exec,compile.i)
216 compile.s =  $(call maybe_exec,compile.s)
217 compile.S = @$(call maybe_exec,compile.S)
218 compile.m = @$(call maybe_exec,compile.m)
219 compile-m = @$(disp_compile-m) ; $(cmd_compile-m) && $(cmd_t_strip)
220 do_strip  = @$(disp_strip)     ; $(cmd_strip)
221 do_t_strip= @$(disp_t_strip)   ; $(cmd_t_strip)
222 do_unifdef= @$(disp_unifdef)   ; $(cmd_unifdef)
223 hcompile.u= @$(disp_hcompile.u); $(cmd_hcompile.u)
224 hcompile.o= @$(disp_hcompile.o); $(cmd_hcompile.o)
225
226 define do_ar
227         @$(disp_ar) ; $(cmd_ar)
228         @$(do_t_strip)
229 endef
230 define compile.u
231         @$(disp_compile.u) ; $(cmd_compile.u)
232         @$(disp_t_strip)
233 endef
234 cmd_hcompile.u = $(HOSTCC) $^ $(DEPS-$(notdir $@)) -o $@ $(BUILD_LDFLAGS) $(BUILD_LDFLAGS-$(notdir $(^D))) $(BUILD_LDFLAGS-$(notdir $@)) $(BUILD_CFLAGS) $(BUILD_CFLAGS-$(notdir $(^D))) $(BUILD_CFLAGS-$(notdir $@))
235 cmd_hcompile.o = $(HOSTCC) $^ $(DEPS-$(notdir $@)) -c -o $@ $(BUILD_CFLAGS) $(BUILD_CFLAGS-$(notdir $(^D))) $(BUILD_CFLAGS-$(notdir $@))
236
237 define link.so
238         $(Q)$(INSTALL) -d $(dir $@)
239         $(Q)$(RM) $@ $@.$(2) $(dir $@)$(1)
240         @$(disp_ld)
241         $(Q)$(CC) $(LDFLAGS-$(notdir $@)) -Wl,-soname=$(notdir $@).$(2) \
242                 $(NOSTDLIB_CFLAGS) -o $(dir $@)$(1) $(START_FILE-$(notdir $@)) \
243                 -Wl,--whole-archive $(firstword $^) -Wl,--no-whole-archive \
244                 $(LIBS-$(notdir $@)) $(LIBGCC) $(END_FILE-$(notdir $@))
245         $(Q)$(LN) -sf $(1) $@.$(2)
246         $(Q)$(LN) -sf $(1) $@
247 endef
248
249 # CRT files needed by link-flat.so
250 LINK_FLAT_CRTS := $(top_builddir)lib/Scrt1.o $(top_builddir)lib/crti.o \
251         $(top_builddir)lib/crtn.o
252
253 # Create a shared flat library from the archive named by the first dependency.
254 # $@ names the shared library's .gdb file, not the flat file itself.
255 # (This is because the .gdb suffix makes the ELF file more distinctive
256 # than the suffixless flat file.)
257 #
258 # Argument 1 is the shared library file -- i.e. $(@:.gdb=) -- and argument 2
259 # is the shared library identifier.  If it wasn't for $(disp_ld), we could
260 # avoid passing $(@:.gdb=) as an argument and use $(@:.gdb=) instead of $(1).
261 #
262 # This is so far only used for libc, for which we want to link the entire
263 # libgcc into the shared object.
264 define link-flat.so
265         $(Q)$(INSTALL) -d $(dir $@)
266         $(Q)$(RM) $(1) $@
267         @$(disp_ld)
268         $(Q)$(CC) $(LDFLAGS-$(notdir $@)) $(NOSTDLIB_CFLAGS) -o $(1) \
269                 -Wl,-elf2flt -Wl,-shared-lib-id,$(2) $(top_builddir)lib/Scrt1.o \
270                 $(top_builddir)/lib/crti.o -Wl,--whole-archive $(firstword $^) \
271                 $(LIBGCC) -Wl,--no-whole-archive $(LIBS-$(notdir $@)) $(LIBGCC) \
272                 $(top_builddir)/lib/crtn.o
273 endef
274
275 define linkm.so
276         $(Q)$(INSTALL) -d $(dir $@)
277         $(Q)$(RM) $@ $@.$(2) $(dir $@)$(1)
278         $(do_strip)
279         @$(disp_ld)
280         $(Q)$(CC) $(LDFLAGS-$(notdir $@)) -Wl,-soname=$(notdir $@).$(2) \
281                 $(NOSTDLIB_CFLAGS) -o $(dir $@)$(1) $(START_FILE-$(notdir $@)) \
282                 $^ \
283                 $(LIBS-$(notdir $@)) $(LIBGCC) $(END_FILE-$(notdir $@))
284         $(Q)$(LN) -sf $(1) $@.$(2)
285         $(Q)$(LN) -sf $(1) $@
286 endef
287
288 CFLAGS-.os+=$(PICFLAG)
289 CFLAGS-.oS+=$(PICFLAG) -DSHARED
290
291 %.o:  %.c FORCE ; $(compile.c)
292 %.os: %.c FORCE ; $(compile.c)
293 %.oS: %.c FORCE ; $(compile.c)
294 %.o:  %.S FORCE ; $(compile.S)
295 %.os: %.S FORCE ; $(compile.S)
296 %.oS: %.S FORCE ; $(compile.S)
297 %.o:  %.s FORCE ; $(compile.S)
298 %.os: %.s FORCE ; $(compile.S)
299 %.oS: %.s FORCE ; $(compile.S)
300 %.i:  %.c FORCE ; $(compile.i)
301 %.i:  %.S FORCE ; $(compile.i)
302 %.s:  %.c FORCE ; $(compile.s)
303 %.s:  %.S FORCE ; $(compile.s)
304 %.dep:
305
306 $(top_builddir)lib/interp.c: | $(sub_headers)
307         $(Q)$(INSTALL) -d $(dir $@)
308         $(Q)echo "/* Force shared libraries to know about the correct library loader */" > $@
309         $(Q)echo "#include <features.h>" >> $@
310         $(Q)echo "const char __dl_ldso__[] __attribute__ ((section " \
311                 "(\".interp\"))) =\""$(SHARED_LIB_LOADER_PREFIX)/$(UCLIBC_LDSO)"\";" >> $@
312
313 $(interp): $(top_builddir)lib/interp.c
314         $(compile.c)
315         $(Q)$(STRIPTOOL) -x -R .note -R .comment $@
316
317 $(ldso):
318         @cd $(top_builddir); $(MAKE) lib/$(patsubst %.$(MAJOR_VERSION),%,$(notdir $@))
319
320 $(libc):
321         @cd $(top_builddir); $(MAKE) lib/$(patsubst %.$(MAJOR_VERSION),%,$(notdir $@))
322
323 CRT := crt1
324
325 ifeq ($(HAVE_SHARED)$(UCLIBC_FORMAT_SHARED_FLAT),y)
326 CRTS=$(top_builddir)lib/$(CRT).o $(top_builddir)lib/S$(CRT).o
327 else
328 CRTS=$(top_builddir)lib/$(CRT).o
329 endif
330
331 ASFLAGS-$(CRT).o := -DL_$(CRT)
332 ASFLAGS-S$(CRT).o := $(PIEFLAG) -DL_S$(CRT)
333 $(CRTS): $(top_srcdir)libc/sysdeps/linux/$(TARGET_ARCH)/$(CRT).S
334         $(Q)$(INSTALL) -d $(dir $@)
335         $(compile.S)
336         $(Q)$(STRIPTOOL) -x -R .note -R .comment $@
337
338 ifeq ($(UCLIBC_CTOR_DTOR),y)
339 CTOR_TARGETS=$(top_builddir)lib/crti.o $(top_builddir)lib/crtn.o
340 else
341 CTOR_TARGETS:=
342 endif
343
344 ifeq ($(UCLIBC_FORMAT_FDPIC_ELF),y)
345 CRTRELOC=$(top_builddir)lib/crtreloc.o
346 $(CRTRELOC): $(top_builddir)lib/%.o : $(top_srcdir)libc/sysdeps/linux/$(TARGET_ARCH)/%.c
347         $(Q)$(INSTALL) -d $(dir $@)
348         $(compile.c)
349 endif
350
351 ifneq ($(wildcard $(top_srcdir)libc/sysdeps/linux/$(TARGET_ARCH)/initfini.c),)
352 CFLAGS-initfini.s := -S -g0 $(PICFLAG) -fno-inline-functions -finhibit-size-directive
353 $(top_builddir)lib/initfini.s: $(top_srcdir)libc/sysdeps/linux/$(TARGET_ARCH)/initfini.c
354         $(compile.c)
355
356 $(top_builddir)lib/defs.h: $(top_builddir)lib/initfini.s
357         $(Q)sed -n -e '/@TESTS_BEGIN/,/@TESTS_END/p' $< | \
358                 gawk -f $(top_srcdir)extra/scripts/defs.awk > $@.tmp
359         $(Q)mv $@.tmp $@
360
361 $(top_builddir)lib/crti.S: $(top_builddir)lib/initfini.s $(top_builddir)lib/defs.h
362         $(Q)sed -n -e '1,/@HEADER_ENDS/p' \
363                 -e '/@_.*_PROLOG_BEGINS/,/@_.*_PROLOG_ENDS/p' \
364                 -e '/@TRAILER_BEGINS/,$$p' $< > $@
365
366 $(top_builddir)lib/crtn.S: $(top_builddir)lib/initfini.s
367         $(Q)sed -n -e '1,/@HEADER_ENDS/p' \
368                 -e '/@_.*_EPILOG_BEGINS/,/@_.*_EPILOG_ENDS/p' \
369                 -e '/@TRAILER_BEGINS/,$$p' $< > $@
370
371 $(CTOR_TARGETS): $(top_builddir)lib/%.o : $(top_builddir)lib/%.S
372         $(Q)$(INSTALL) -d $(dir $@)
373         $(compile.S) $(PICFLAG) $(SSP_DISABLE_FLAGS)
374 else
375 $(CTOR_TARGETS): $(top_builddir)lib/%.o : $(top_srcdir)libc/sysdeps/linux/$(TARGET_ARCH)/%.S
376         $(Q)$(INSTALL) -d $(dir $@)
377         $(compile.S) $(PICFLAG) $(SSP_DISABLE_FLAGS)
378 endif
379
380 #ifeq ($(TARGET_ARCH),nios)
381 #CRTS_COMPAT := $(top_builddir)lib/crt0.o
382 #$(CRTS_COMPAT):
383 #       ln -fs crt1.o $(top_builddir)lib/crt0.o
384 #else
385 CRTS_COMPAT :=
386 #endif
387
388 $(crt-y): $(CRTS) $(CTOR_TARGETS) $(CRTS_COMPAT) $(CRTRELOC)
389 $(CRTS) $(CTOR_TARGETS) $(CRTS_COMPAT) $(CRTRELOC): | headers
390
391 $(top_builddir)lib/$(NONSHARED_LIBNAME): $(libc-nonshared-y)
392         $(Q)$(INSTALL) -d $(dir $@)
393         $(Q)$(RM) $@
394         $(do_ar)
395
396 $(top_builddir)lib/libpthread_nonshared.a: $(libpthread-nonshared-y)
397         $(Q)$(INSTALL) -d $(dir $@)
398         $(Q)$(RM) $@
399         $(do_ar)
400
401 files.dep := $(libc-a-y) $(libc-so-y) $(libc-nonshared-y) \
402         $(libm-a-y) $(libm-so-y) \
403         $(libpthread-a-y) $(libpthread-so-y) $(libpthread-nonshared-y) \
404         $(libthread_db-a-y) $(libthread_db-so-y) \
405         $(librt-a-y) $(librt-so-y)  $(libresolv-a-y) $(libresolv-so-y) \
406         $(libcrypt-a-y) $(libcrypt-so-y) $(libutil-a-y) $(libutil-so-y) \
407         $(libnsl-a-y) $(libnsl-so-y) $(ldso-y) $(libdl-a-y) $(libdl-so-y)
408 .depends.dep := \
409         $(patsubst %.o,%.o.dep,$(filter %.o,$(files.dep))) \
410         $(patsubst %.os,%.os.dep,$(filter %.os,$(files.dep))) \
411         $(patsubst %.oS,%.oS.dep,$(filter %.oS,$(files.dep)))
412 # Oh, and prepend a dot to the basename so i don't have to change my habit of
413 # calling 'size thefile.o*'
414 .depends.dep := $(foreach f,$(.depends.dep),$(dir $(f)).$(notdir $(f)))
415 .depends.dep := $(wildcard $(.depends.dep))
416
417 FORCE:
418
419 clean: objclean-y headers_clean-y
420 realclean: clean
421         $(Q)$(RM) $(.depends.dep)
422
423 objclean-y: $(objclean-y)
424 headers_clean-y: $(headers_clean-y)
425
426 ifeq ($(filter $(noconfig_targets),$(MAKECMDGOALS)),)
427 ifneq ($(strip $(.depends.dep)),)
428 .NOEXPORT:
429 -include $(.depends.dep)
430 endif
431 endif
432
433 # vi: ft=make :