source: mainline/uspace/Makefile.common@ 628d548

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 628d548 was 0e9b512, checked in by Jiri Svoboda <jiri@…>, 14 years ago

Fix mips32 and ppc32 builds.

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