source: mainline/uspace/Makefile.common@ 120d5bc

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 120d5bc was 94c5bc1, checked in by Jiri Svoboda <jiri@…>, 8 years ago

Build disassembly files for test binaries.

  • Property mode set to 100644
File size: 12.6 KB
Line 
1#
2# Copyright (c) 2005 Martin Decky
3# Copyright (c) 2007 Jakub Jermar
4# All rights reserved.
5#
6# Redistribution and use in source and binary forms, with or without
7# modification, are permitted provided that the following conditions
8# are met:
9#
10# - Redistributions of source code must retain the above copyright
11# notice, this list of conditions and the following disclaimer.
12# - Redistributions in binary form must reproduce the above copyright
13# notice, this list of conditions and the following disclaimer in the
14# documentation and/or other materials provided with the distribution.
15# - The name of the author may not be used to endorse or promote products
16# derived from this software without specific prior written permission.
17#
18# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28#
29
30# Individual makefiles set:
31#
32# USPACE_PREFIX (*) relative path to uspace/ directory
33# SOURCES (*) list of source files
34# LIBS libraries to link with
35# DEFS compiler defines
36# EXTRA_CFLAGS additional flags to pass to C compiler
37# LINKER_SCRIPT linker script
38# PRE_DEPEND targets required for dependency check
39#
40# BINARY (/) binary output name (like appname)
41# LIBRARY (/) library output name (like libname)
42#
43# EXTRA_OUTPUT additional output targets
44# EXTRA_CLEAN additional cleanup targets
45#
46# MATH set to 'y' to use the math library
47# POSIX_COMPAT set to 'y' to use POSIX compatibility layer
48#
49# Optionally, for a binary:
50# STATIC_NEEDED set to 'y' for init binaries, will build statically
51# linked version
52# STATIC_ONLY set to 'y' if binary cannot be linked dynamically
53# (e.g. uses thread-local variables)
54#
55# Optionally, for a libary:
56# SLIBRARY Name with full version, e.g. libfoo.so.0.0
57# LSONAME Soname / name with short version, e.g. libfoo.so.0
58#
59# (x) required variables
60# (/) exactly one of the variables must be defined
61#
62
63ROOT_PATH = $(USPACE_PREFIX)/..
64
65VERSION_DEF = $(ROOT_PATH)/version
66
67COMMON_MAKEFILE = $(ROOT_PATH)/Makefile.common
68COMMON_HEADER = $(ROOT_PATH)/common.h
69
70CONFIG_MAKEFILE = $(ROOT_PATH)/Makefile.config
71CONFIG_HEADER = $(ROOT_PATH)/config.h
72
73-include $(VERSION_DEF)
74-include $(COMMON_MAKEFILE)
75-include $(CONFIG_MAKEFILE)
76
77ifneq ($(BINARY),)
78 JOB = $(BINARY).job
79 OUTPUT = $(BINARY)
80 TEST_BINARY = test-$(BINARY)
81 EXTRA_OUTPUT += $(BINARY).disasm
82 EXTRA_CLEAN += $(BINARY).map
83endif
84
85ifneq ($(LIBRARY),)
86 JOB = $(LIBRARY).job
87 OUTPUT = $(LIBRARY).a
88 TEST_BINARY = test-$(LIBRARY)
89endif
90
91ifeq ($(CONFIG_BUILD_SHARED_LIBS),y)
92 ifneq ($(SLIBRARY),)
93 LARCHIVE = $(LIBRARY).la
94 LOUTPUT = $(SLIBRARY)
95 EXTRA_OUTPUT += $(LOUTPUT).disasm $(LIBRARY).so $(LSONAME)
96 EXTRA_CLEAN += $(LOUTPUT).map $(LOUTPUT).ldisasm \
97 $(LIBC_PREFIX)/shared/arch/$(UARCH)/_lib.ld \
98 $(LIBRARY).so $(LSONAME)
99 endif
100endif
101
102DEPEND = Makefile.depend
103DEPEND_PREV = $(DEPEND).prev
104
105LIB_PREFIX = $(USPACE_PREFIX)/lib
106
107LIBC_PREFIX = $(LIB_PREFIX)/c
108LIBC_INCLUDES_FLAGS = \
109 -I$(LIBC_PREFIX)/include \
110 -I$(LIBC_PREFIX)/arch/$(UARCH)/include \
111 -I$(ROOT_PATH)/abi/include
112LIBSOFTFLOAT_PREFIX = $(LIB_PREFIX)/softfloat
113LIBSOFTINT_PREFIX = $(LIB_PREFIX)/softint
114
115LIBMATH_PREFIX = $(LIB_PREFIX)/math
116LIBMATH_INCLUDES_FLAGS = \
117 -I$(LIBMATH_PREFIX)/include \
118 -I$(LIBMATH_PREFIX)/arch/$(UARCH)/include
119
120LIBPOSIX_PREFIX = $(LIB_PREFIX)/posix
121
122LIBCRYPTO_PREFIX = $(LIB_PREFIX)/crypto
123LIBBLOCK_PREFIX = $(LIB_PREFIX)/block
124LIBFDISK_PREFIX = $(LIB_PREFIX)/fdisk
125LIBLABEL_PREFIX = $(LIB_PREFIX)/label
126LIBFS_PREFIX = $(LIB_PREFIX)/fs
127LIBCLUI_PREFIX = $(LIB_PREFIX)/clui
128LIBFMTUTIL_PREFIX = $(LIB_PREFIX)/fmtutil
129
130LIBGRAPH_PREFIX = $(LIB_PREFIX)/graph
131LIBSOFTREND_PREFIX = $(LIB_PREFIX)/softrend
132LIBDRAW_PREFIX = $(LIB_PREFIX)/draw
133LIBGUI_PREFIX = $(LIB_PREFIX)/gui
134
135LIBEXT4_PREFIX = $(LIB_PREFIX)/ext4
136
137LIBUSB_PREFIX = $(LIB_PREFIX)/usb
138LIBUSBHOST_PREFIX = $(LIB_PREFIX)/usbhost
139LIBUSBDEV_PREFIX = $(LIB_PREFIX)/usbdev
140LIBUSBHID_PREFIX = $(LIB_PREFIX)/usbhid
141LIBUSBVIRT_PREFIX = $(LIB_PREFIX)/usbvirt
142
143LIBDRV_PREFIX = $(LIB_PREFIX)/drv
144LIBHOUND_PREFIX = $(LIB_PREFIX)/hound
145LIBPCM_PREFIX = $(LIB_PREFIX)/pcm
146LIBNIC_PREFIX = $(LIB_PREFIX)/nic
147LIBIEEE80211_PREFIX = $(LIB_PREFIX)/ieee80211
148LIBMINIX_PREFIX = $(LIB_PREFIX)/minix
149LIBCOMPRESS_PREFIX = $(LIB_PREFIX)/compress
150LIBDLTEST_PREFIX = $(LIB_PREFIX)/dltest
151
152LIBSCSI_PREFIX = $(LIB_PREFIX)/scsi
153LIBTRACKMOD_PREFIX = $(LIB_PREFIX)/trackmod
154
155LIBBITHENGE_PREFIX = $(LIB_PREFIX)/bithenge
156
157LIBHTTP_PREFIX = $(LIB_PREFIX)/http
158LIBURI_PREFIX = $(LIB_PREFIX)/uri
159
160LIBNETTL_PREFIX = $(LIB_PREFIX)/nettl
161
162AFLAGS = --fatal-warnings
163LFLAGS = --fatal-warnings
164
165ifeq ($(STATIC_NEEDED),y)
166 STATIC_BUILD = y
167else
168 ifeq ($(STATIC_ONLY),y)
169 STATIC_BUILD = y
170 else
171 ifeq ($(CONFIG_USE_SHARED_LIBS),y)
172 STATIC_BUILD = n
173 else
174 STATIC_BUILD = y
175 endif
176 endif
177endif
178
179ifeq ($(STATIC_BUILD),y)
180 BASE_LIBS = $(LIBC_PREFIX)/libc.a $(LIBSOFTINT_PREFIX)/libsoftint.a
181 ifeq ($(MATH),y)
182 BASE_LIBS += $(LIBMATH_PREFIX)/libmath.a
183 endif
184else
185 BASE_LIBS = $(LIBC_PREFIX)/libc.so.0 $(LIBSOFTINT_PREFIX)/libsoftint.so.0
186 LINK_DYNAMIC = y
187 ifeq ($(MATH),y)
188 BASE_LIBS += $(LIBMATH_PREFIX)/libmath.so.0
189 endif
190endif
191
192ifeq ($(LINK_DYNAMIC),y)
193 LFLAGS += -Bdynamic
194 LINKER_SCRIPT ?= $(LIBC_PREFIX)/arch/$(UARCH)/_link-dlexe.ld
195else
196 LINKER_SCRIPT ?= $(LIBC_PREFIX)/arch/$(UARCH)/_link.ld
197endif
198
199ifeq ($(MATH),y)
200 INCLUDES_FLAGS = $(LIBC_INCLUDES_FLAGS) $(LIBMATH_INCLUDES_FLAGS)
201else
202 INCLUDES_FLAGS = $(LIBC_INCLUDES_FLAGS)
203endif
204
205ifeq ($(CONFIG_OPTIMIZE_FOR_SIZE),y)
206 OPTIMIZATION = s
207else
208 OPTIMIZATION = 3
209endif
210
211# PCUT-based unit tests
212ifneq ($(TEST_SOURCES),)
213 TEST_OUTPUT = $(TEST_BINARY)
214 TEST_DISASM = $(TEST_BINARY).disasm
215 TEST_CFLAGS = -I$(LIB_PREFIX)/pcut/include -D__helenos__
216 TEST_OUTPUT_LIBS = $(LIB_PREFIX)/pcut/libpcut.a
217 EXTRA_CLEAN += $(TEST_OUTPUT) $(TEST_OUTPUT).map $(TEST_DISASM)
218ifneq ($(LIBRARY),)
219 TEST_OUTPUT_LIBS += $(OUTPUT)
220endif
221 TEST_OUTPUT_LIBS += $(TEST_LIBS)
222endif
223
224.PHONY: all clean
225
226all: $(VERSION_DEF) $(COMMON_MAKEFILE) $(CONFIG_MAKEFILE) $(CONFIG_HEADER) $(LIBS) $(OUTPUT) $(LOUTPUT) $(EXTRA_OUTPUT)
227 -[ -f $(DEPEND) ] && cp -a $(DEPEND) $(DEPEND_PREV)
228
229all-test: $(TEST_OUTPUT) $(TEST_DISASM)
230
231clean:
232 rm -f $(DEPEND) $(DEPEND_PREV) $(JOB) $(OUTPUT) $(LARCHIVE) $(LOUTPUT) $(EXTRA_OUTPUT) $(EXTRA_CLEAN)
233 find . -name '*.o' -follow -exec rm \{\} \;
234 find . -name '*.lo' -follow -exec rm \{\} \;
235
236GCC_CFLAGS = $(INCLUDES_FLAGS) -O$(OPTIMIZATION) -imacros $(CONFIG_HEADER) \
237 -fexec-charset=UTF-8 -fwide-exec-charset=UTF-32$(ENDIANESS) \
238 -finput-charset=UTF-8 -ffreestanding -fno-builtin -ffunction-sections \
239 -nostdlib -nostdinc -Wall -Wextra -Wno-clobbered -Wno-unused-parameter \
240 -Wmissing-prototypes -std=gnu99 -Werror-implicit-function-declaration \
241 -Wwrite-strings -pipe -ggdb -D__$(ENDIANESS)__
242
243ICC_CFLAGS = $(INCLUDES_FLAGS) -O$(OPTIMIZATION) -imacros $(CONFIG_HEADER) \
244 -fexec-charset=UTF-8 -fwide-exec-charset=UTF-32$(ENDIANESS) \
245 -finput-charset=UTF-8 -ffreestanding -fno-builtin -nostdlib -nostdinc \
246 -Wall -Wextra -Wno-clobbered -Wno-unused-parameter -Wmissing-prototypes \
247 -Werror-implicit-function-declaration -Wwrite-strings \
248 -pipe -g -D__$(ENDIANESS)__
249
250# clang does not support following options but I am not sure whether
251# something won't break because of that:
252# -fexec-charset=UTF-8 -fwide-exec-charset=UTF-32$(ENDIANESS) -finput-charset=UTF-8
253CLANG_CFLAGS = $(INCLUDES_FLAGS) -O$(OPTIMIZATION) -imacros $(CONFIG_HEADER) \
254 -ffreestanding -fno-builtin -nostdlib -nostdinc \
255 -Wall -Wextra -Wno-unused-parameter -Wmissing-prototypes \
256 -std=gnu99 -Werror-implicit-function-declaration -Wwrite-strings \
257 -integrated-as -pipe -g -target $(CLANG_TARGET) -D__$(ENDIANESS)__
258
259LIB_CFLAGS = $(CFLAGS) -fPIC
260LIB_LFLAGS = $(LFLAGS) -shared -soname $(LSONAME) --whole-archive
261
262ifeq ($(CONFIG_DEBUG),y)
263 GCC_CFLAGS += -Werror
264 ICC_CFLAGS += -Werror
265endif
266
267ifeq ($(CONFIG_LINE_DEBUG),y)
268 GCC_CFLAGS += -ggdb
269 ICC_CFLAGS += -g
270 CLANG_CFLAGS += -g
271endif
272
273# Prepare for POSIX before including platform specific stuff
274ifeq ($(POSIX_COMPAT),y)
275 CFLAGS = -I$(LIBPOSIX_PREFIX)/include/posix -I$(LIBPOSIX_PREFIX)/include/
276 BASE_LIBS = $(LIBPOSIX_PREFIX)/libposixaslibc.a $(LIBPOSIX_PREFIX)/libc4posix.a $(LIBSOFTINT_PREFIX)/libsoftint.a
277endif
278
279## Setup platform configuration
280#
281
282-include $(LIBC_PREFIX)/arch/$(UARCH)/Makefile.common
283
284## Compilation options
285#
286
287JOBFILE = $(LIBC_PREFIX)/../../../tools/jobfile.py
288
289ifeq ($(COMPILER),gcc_cross)
290 CFLAGS += $(GCC_CFLAGS)
291 DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
292endif
293
294ifeq ($(COMPILER),gcc_helenos)
295 CFLAGS += $(GCC_CFLAGS)
296 DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
297endif
298
299ifeq ($(COMPILER),gcc_native)
300 CFLAGS += $(GCC_CFLAGS)
301 DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
302endif
303
304ifeq ($(COMPILER),icc)
305 CFLAGS += $(ICC_CFLAGS)
306 DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
307endif
308
309ifeq ($(COMPILER),clang)
310 CFLAGS += $(CLANG_CFLAGS)
311 DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
312endif
313
314ifneq ($(MAKECMDGOALS),clean)
315-include $(DEPEND)
316endif
317
318OBJECTS := $(addsuffix .o,$(basename $(SOURCES)))
319LOBJECTS := $(addsuffix .lo,$(basename $(SOURCES)))
320TEST_OBJECTS := $(addsuffix .test.o,$(basename $(TEST_SOURCES)))
321
322ifneq ($(BINARY),)
323$(BINARY).disasm: $(BINARY)
324ifeq ($(CONFIG_LINE_DEBUG),y)
325 $(OBJDUMP) -d -S $< > $@
326else
327 $(OBJDUMP) -d $< > $@
328endif
329
330$(BINARY): $(LINKER_SCRIPT) $(OBJECTS) $(LIBS) $(BASE_LIBS)
331 $(LD) -n $(LFLAGS) -T $(LINKER_SCRIPT) -M -Map $(BINARY).map -o $(BINARY) $(OBJECTS) $(LIBS) $(BASE_LIBS)
332ifeq ($(CONFIG_STRIP_BINARIES),y)
333 $(STRIP) $(BINARY)
334endif
335endif
336
337ifneq ($(SLIBRARY),)
338$(LOUTPUT).disasm: $(LOUTPUT)
339ifeq ($(CONFIG_LINE_DEBUG),y)
340 $(OBJDUMP) -d -S $< > $@
341else
342 $(OBJDUMP) -d $< > $@
343endif
344
345$(LOUTPUT): $(LARCHIVE) $(LIBC_PREFIX)/arch/$(UARCH)/_link-shlib.ld
346 $(LD) -T $(LIBC_PREFIX)/arch/$(UARCH)/_link-shlib.ld $(LIB_LFLAGS) $(LARCHIVE) -o $@ -Map $(LOUTPUT).map
347
348$(LIBRARY).so:
349 ln -s $(SLIBRARY) $@
350
351$(LSONAME):
352 ln -s $(SLIBRARY) $@
353endif
354
355ifneq ($(LIBRARY),)
356$(LIBRARY).a: $(OBJECTS)
357 $(AR) rc $@ $(OBJECTS)
358endif
359
360ifneq ($(LARCHIVE),)
361$(LARCHIVE): $(LOBJECTS)
362 $(AR) rc $@ $(LOBJECTS)
363endif
364
365ifneq ($(TEST_OUTPUT),)
366$(TEST_OUTPUT): $(LINKER_SCRIPT) $(TEST_OBJECTS) $(TEST_OUTPUT_LIBS)
367 $(LD) -n $(LFLAGS) -T $(LINKER_SCRIPT) -M -Map $(TEST_OUTPUT).map -o $@ $(TEST_OBJECTS) $(TEST_OUTPUT_LIBS) $(LIBS) $(BASE_LIBS)
368ifeq ($(CONFIG_STRIP_BINARIES),y)
369 $(STRIP) $(TEST_OUTPUT)
370endif
371$(TEST_BINARY).disasm: $(TEST_BINARY)
372ifeq ($(CONFIG_LINE_DEBUG),y)
373 $(OBJDUMP) -d -S $< > $@
374else
375 $(OBJDUMP) -d $< > $@
376endif
377endif
378
379%.o: %.S $(DEPEND)
380 $(GCC) $(DEFS) $(GCC_CFLAGS) $(EXTRA_CFLAGS) -D__ASM__ -c $< -o $@
381ifeq ($(PRECHECK),y)
382 $(JOBFILE) $(JOB) $< $@ as asm/preproc $(DEFS) $(CFLAGS) $(EXTRA_CFLAGS) -D__ASM__
383endif
384
385%.o: %.s $(DEPEND)
386 $(AS) $(AFLAGS) -o $@ $<
387ifeq ($(PRECHECK),y)
388 $(JOBFILE) $(JOB) $< $@ as asm
389endif
390
391%.o: %.c $(DEPEND)
392 $(CC) $(DEFS) $(CFLAGS) $(EXTRA_CFLAGS) -c $< -o $@
393ifeq ($(PRECHECK),y)
394 $(JOBFILE) $(JOB) $< $@ cc core $(DEFS) $(CFLAGS) $(EXTRA_CFLAGS)
395endif
396
397%.test.o: %.c $(DEPEND)
398 $(CC) $(DEFS) $(CFLAGS) $(EXTRA_CFLAGS) $(TEST_CFLAGS) -c $< -o $@
399ifeq ($(PRECHECK),y)
400 $(JOBFILE) $(JOB) $< $@ cc core $(DEFS) $(CFLAGS) $(EXTRA_CFLAGS) $(TEST_CFLAGS)
401endif
402
403%.lo: %.S $(DEPEND)
404 $(CC) $(DEFS) $(LIB_CFLAGS) $(EXTRA_CFLAGS) -D__ASM__ -c $< -o $@
405ifeq ($(PRECHECK),y)
406 $(JOBFILE) $(JOB) $< $@ as asm/preproc $(DEFS) $(LIB_CFLAGS) $(EXTRA_CFLAGS) -D__ASM__
407endif
408
409%.lo: %.s $(DEPEND)
410 $(AS) $(AFLAGS) -o $@ $<
411ifeq ($(PRECHECK),y)
412 $(JOBFILE) $(JOB) $< $@ as asm
413endif
414
415%.lo: %.c $(DEPEND)
416 $(CC) $(DEFS) $(LIB_CFLAGS) $(EXTRA_CFLAGS) -c $< -o $@
417ifeq ($(PRECHECK),y)
418 $(JOBFILE) $(JOB) $< $@ cc core $(DEFS) $(LIB_CFLAGS) $(EXTRA_CFLAGS)
419endif
420
421$(DEPEND): $(PRE_DEPEND)
422 makedepend -f - -- $(DEPEND_DEFS) $(CFLAGS) $(EXTRA_CFLAGS) -- $(SOURCES) > $@ 2> /dev/null
423 makedepend -f - -o.test.o -- $(DEPEND_DEFS) $(CFLAGS) $(EXTRA_CFLAGS) $(TEST_CFLAGS) -- $(TEST_SOURCES) >> $@ 2> /dev/null
424 -[ -f $(DEPEND_PREV) ] && diff -q $(DEPEND_PREV) $@ && mv -f $(DEPEND_PREV) $@
425
426##
427# This explicit dependecy of the output binary on the object files seems to be
428# necessary to prevent parallel build failures (GNU make bug #26893 ???).
429$(OUTPUT): $(OBJECTS)
430
431$(LARCHIVE): $(LOBJECTS)
Note: See TracBrowser for help on using the repository browser.