source: mainline/uspace/Makefile.common@ 16b2ea8

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 16b2ea8 was cf5e86e, checked in by Martin Sucha <sucha14@…>, 14 years ago

Merge mainline changes

  • Property mode set to 100644
File size: 9.0 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# Optionally, for a binary:
47# STATIC_NEEDED set to 'y' for init binaries, will build statically
48# linked version
49# STATIC_ONLY set to 'y' if binary cannot be linked dynamically
50# (e.g. uses thread-local variables)
51#
52# Optionally, for a libary:
53# SLIBRARY Name with full version, e.g. libfoo.so.0.0
54# LSONAME Soname / name with short version, e.g. libfoo.so.0
55#
56# (x) required variables
57# (/) exactly one of the variables must be defined
58#
59
60ROOT_PATH = $(USPACE_PREFIX)/..
61
62VERSION_DEF = $(ROOT_PATH)/version
63
64COMMON_MAKEFILE = $(ROOT_PATH)/Makefile.common
65COMMON_HEADER = $(ROOT_PATH)/common.h
66
67CONFIG_MAKEFILE = $(ROOT_PATH)/Makefile.config
68CONFIG_HEADER = $(ROOT_PATH)/config.h
69
70-include $(VERSION_DEF)
71-include $(COMMON_MAKEFILE)
72-include $(CONFIG_MAKEFILE)
73
74ifneq ($(BINARY),)
75 JOB = $(BINARY).job
76 OUTPUT = $(BINARY)
77 EXTRA_OUTPUT += $(BINARY).disasm
78 EXTRA_CLEAN += $(BINARY).map
79endif
80
81ifneq ($(LIBRARY),)
82 JOB = $(LIBRARY).job
83 OUTPUT = $(LIBRARY).a
84endif
85
86ifeq ($(CONFIG_BUILD_SHARED_LIBS), y)
87 ifneq ($(SLIBRARY),)
88 LARCHIVE = $(LIBRARY).la
89 LOUTPUT = $(SLIBRARY)
90 EXTRA_OUTPUT += $(LOUTPUT).disasm $(LIBRARY).so $(LSONAME)
91 EXTRA_CLEAN += $(LOUTPUT).map $(LOUTPUT).ldisasm \
92 $(LIBC_PREFIX)/shared/arch/$(UARCH)/_lib.ld \
93 $(LIBRARY).so $(LSONAME)
94 endif
95endif
96
97DEPEND = Makefile.depend
98DEPEND_PREV = $(DEPEND).prev
99
100LIB_PREFIX = $(USPACE_PREFIX)/lib
101
102LIBC_PREFIX = $(LIB_PREFIX)/c
103LIBSOFTFLOAT_PREFIX = $(LIB_PREFIX)/softfloat
104LIBSOFTINT_PREFIX = $(LIB_PREFIX)/softint
105
106LIBBLOCK_PREFIX = $(LIB_PREFIX)/block
107LIBFS_PREFIX = $(LIB_PREFIX)/fs
108LIBCLUI_PREFIX = $(LIB_PREFIX)/clui
109
110LIBEXT2_PREFIX = $(LIB_PREFIX)/ext2
111
112LIBDRV_PREFIX = $(LIB_PREFIX)/drv
113LIBPACKET_PREFIX = $(LIB_PREFIX)/packet
114LIBNET_PREFIX = $(LIB_PREFIX)/net
115
116ifeq ($(STATIC_NEEDED),y)
117 STATIC_BUILD = y
118else
119 ifeq ($(STATIC_ONLY),y)
120 STATIC_BUILD = y
121 else
122 ifeq ($(CONFIG_USE_SHARED_LIBS), y)
123 STATIC_BUILD = n
124 else
125 STATIC_BUILD = y
126 endif
127 endif
128endif
129
130ifeq ($(STATIC_BUILD), y)
131BASE_LIBS = $(LIBC_PREFIX)/libc.a $(LIBSOFTINT_PREFIX)/libsoftint.a
132LINKER_SCRIPT ?= $(LIBC_PREFIX)/arch/$(UARCH)/_link.ld
133else
134BASE_LIBS = $(LIBC_PREFIX)/libc.so0 $(LIBSOFTINT_PREFIX)/libsofti.so0
135LFLAGS = -Bdynamic
136LINKER_SCRIPT ?= $(LIBC_PREFIX)/arch/$(UARCH)/_link-dlexe.ld
137endif
138
139ifeq ($(CONFIG_OPTIMIZE_FOR_SIZE),y)
140 OPTIMIZATION = s
141else
142 OPTIMIZATION = 3
143endif
144
145.PHONY: all clean
146
147all: $(VERSION_DEF) $(COMMON_MAKEFILE) $(CONFIG_MAKEFILE) $(CONFIG_HEADER) $(LIBS) $(OUTPUT) $(LOUTPUT) $(EXTRA_OUTPUT)
148 -[ -f $(DEPEND) ] && cp -a $(DEPEND) $(DEPEND_PREV)
149
150clean:
151 rm -f $(DEPEND) $(DEPEND_PREV) $(JOB) $(OUTPUT) $(LARCHIVE) $(LOUTPUT) $(EXTRA_OUTPUT) $(EXTRA_CLEAN)
152 find . -name '*.o' -follow -exec rm \{\} \;
153 find . -name '*.lo' -follow -exec rm \{\} \;
154
155GCC_CFLAGS = -I$(LIBC_PREFIX)/include -O$(OPTIMIZATION) -imacros $(CONFIG_HEADER) \
156 -fexec-charset=UTF-8 -fwide-exec-charset=UTF-32$(ENDIANESS) \
157 -finput-charset=UTF-8 -ffreestanding -fno-builtin -nostdlib -nostdinc \
158 -Wall -Wextra -Wno-clobbered -Wno-unused-parameter -Wmissing-prototypes \
159 -std=gnu99 -Werror-implicit-function-declaration -Wwrite-strings \
160 -pipe -g -D__$(ENDIANESS)__
161
162ICC_CFLAGS = -I$(LIBC_PREFIX)/include -O$(OPTIMIZATION) -imacros $(CONFIG_HEADER) \
163 -fexec-charset=UTF-8 -fwide-exec-charset=UTF-32$(ENDIANESS) \
164 -finput-charset=UTF-8 -ffreestanding -fno-builtin -nostdlib -nostdinc \
165 -Wall -Wextra -Wno-clobbered -Wno-unused-parameter -Wmissing-prototypes \
166 -Werror-implicit-function-declaration -Wwrite-strings \
167 -pipe -g -D__$(ENDIANESS)__
168
169CLANG_CFLAGS = -I$(LIBC_PREFIX)/include -O$(OPTIMIZATION) -imacros $(CONFIG_HEADER) \
170 -fexec-charset=UTF-8 -fwide-exec-charset=UTF-32$(ENDIANESS) \
171 -finput-charset=UTF-8 -ffreestanding -fno-builtin -nostdlib -nostdinc \
172 -Wall -Wextra -Wno-unused-parameter -Wmissing-prototypes \
173 -Werror-implicit-function-declaration -Wwrite-strings \
174 -pipe -g -arch $(CLANG_ARCH) -D__$(ENDIANESS)__
175
176LIB_CFLAGS = $(CFLAGS) -fPIC -D__IN_SHARED_LIBC__
177LIB_LFLAGS = $(LFLAGS) -shared -soname $(LSONAME) --whole-archive
178
179ifeq ($(CONFIG_DEBUG),y)
180 GCC_CFLAGS += -Werror
181 ICC_CFLAGS += -Werror
182endif
183
184ifeq ($(CONFIG_LINE_DEBUG),y)
185 GCC_CFLAGS += -g
186 ICC_CFLAGS += -g
187 SUNCC_CFLAGS += -g
188 CLANG_CFLAGS += -g
189endif
190
191## Setup platform configuration
192#
193
194-include $(LIBC_PREFIX)/arch/$(UARCH)/Makefile.common
195
196## Compilation options
197#
198
199JOBFILE = $(LIBC_PREFIX)/../../../tools/jobfile.py
200
201ifeq ($(COMPILER),gcc_cross)
202 CFLAGS = $(GCC_CFLAGS) $(EXTRA_CFLAGS)
203 DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
204endif
205
206ifeq ($(COMPILER),gcc_native)
207 CFLAGS = $(GCC_CFLAGS) $(EXTRA_CFLAGS)
208 DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
209endif
210
211ifeq ($(COMPILER),icc)
212 CFLAGS = $(ICC_CFLAGS) $(EXTRA_CFLAGS)
213 DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
214endif
215
216ifeq ($(COMPILER),clang)
217 CFLAGS = $(CLANG_CFLAGS) $(EXTRA_CFLAGS)
218 DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
219endif
220
221-include $(DEPEND)
222
223OBJECTS := $(addsuffix .o,$(basename $(SOURCES)))
224LOBJECTS := $(addsuffix .lo,$(basename $(SOURCES)))
225
226ifneq ($(BINARY),)
227%.disasm: $(BINARY)
228ifeq ($(CONFIG_LINE_DEBUG),y)
229 $(OBJDUMP) -d -S $< > $@
230else
231 $(OBJDUMP) -d $< > $@
232endif
233
234$(BINARY): $(LINKER_SCRIPT) $(OBJECTS) $(LIBS) $(BASE_LIBS)
235 $(LD) -n $(LFLAGS) -T $(LINKER_SCRIPT) -M -Map $(BINARY).map -o $(BINARY) $(OBJECTS) $(LIBS) $(BASE_LIBS)
236ifeq ($(CONFIG_STRIP_BINARIES),y)
237 $(STRIP) $(BINARY)
238endif
239endif
240
241ifneq ($(SLIBRARY),)
242%.disasm: $(LOUTPUT)
243ifeq ($(CONFIG_LINE_DEBUG),y)
244 $(OBJDUMP) -d -S $< > $@
245else
246 $(OBJDUMP) -d $< > $@
247endif
248
249$(LOUTPUT): $(LARCHIVE) $(LIBC_PREFIX)/arch/$(UARCH)/_link-shlib.ld
250 $(LD) -T $(LIBC_PREFIX)/arch/$(UARCH)/_link-shlib.ld $(LIB_LFLAGS) $(LARCHIVE) -o $@ -Map $(LOUTPUT).map
251
252$(LIBRARY).so:
253 ln -s $(SLIBRARY) $@
254
255$(LSONAME):
256 ln -s $(SLIBRARY) $@
257endif
258
259ifneq ($(LIBRARY),)
260%.a: $(OBJECTS)
261 $(AR) rc $@ $(OBJECTS)
262endif
263
264ifneq ($(SLIBRARY),)
265%.la: $(LOBJECTS)
266 $(AR) rc $@ $(LOBJECTS)
267endif
268
269%.o: %.S $(DEPEND)
270 $(CC) $(DEFS) $(CFLAGS) -D__ASM__ -c $< -o $@
271ifeq ($(PRECHECK),y)
272 $(JOBFILE) $(JOB) $< $@ as asm/preproc $(DEFS) $(CFLAGS) -D__ASM__
273endif
274
275%.o: %.s $(DEPEND)
276 $(AS) $(AFLAGS) -o $@ $<
277ifeq ($(PRECHECK),y)
278 $(JOBFILE) $(JOB) $< $@ as asm
279endif
280
281%.o: %.c $(DEPEND)
282 $(CC) $(DEFS) $(CFLAGS) -c $< -o $@
283ifeq ($(PRECHECK),y)
284 $(JOBFILE) $(JOB) $< $@ cc core $(DEFS) $(CFLAGS)
285endif
286
287%.lo: %.S $(DEPEND)
288 $(CC) $(DEFS) $(LIB_CFLAGS) -D__ASM__ -c $< -o $@
289ifeq ($(PRECHECK),y)
290 $(JOBFILE) $(JOB) $< $@ as asm/preproc $(DEFS) $(CFLAGS) -D__ASM__
291endif
292
293%.lo: %.s $(DEPEND)
294 $(AS) $(AFLAGS) -o $@ $<
295ifeq ($(PRECHECK),y)
296 $(JOBFILE) $(JOB) $< $@ as asm
297endif
298
299%.lo: %.c $(DEPEND)
300 $(CC) $(DEFS) $(LIB_CFLAGS) -c $< -o $@
301ifeq ($(PRECHECK),y)
302 $(JOBFILE) $(JOB) $< $@ cc core $(DEFS) $(CFLAGS)
303endif
304
305$(DEPEND): $(PRE_DEPEND)
306 makedepend -f - -- $(DEPEND_DEFS) $(CFLAGS) -- $(SOURCES) > $@ 2> /dev/null
307 -[ -f $(DEPEND_PREV) ] && diff -q $(DEPEND_PREV) $@ && mv -f $(DEPEND_PREV) $@
308
309##
310# This explicit dependecy of the output binary on the object files seems to be
311# necessary to prevent parallel build failures (GNU make bug #26893 ???).
312$(OUTPUT): $(OBJECTS)
313
314$(LARCHIVE): $(LOBJECTS)
Note: See TracBrowser for help on using the repository browser.