xref: /haiku/build/jam/BuildSetup (revision a1d79e238ede4132e674c76d0a987f80160ccb66)
1# Variable naming conventions:
2# TARGET_*:	A build system variable specifying a property for building for
3#			the target platform (usually Haiku). E.g. TARGET_CC specifies the
4#			compiler when building a target for the target platform.
5# HOST_*:	A build system variable specifying a property of the platform
6#			hosting the build. E.g. HOST_CC specifies the compiler when
7#			building a target for the host platform (a build tool for
8#			instance).
9# HAIKU_*:	A build system variable specifying a build system property. Usually
10#			directory paths and the like.
11
12
13# The Haiku (base) version. For development builds the revision will be
14# attached.
15HAIKU_VERSION = r1~beta5 ;
16
17
18#pragma mark - container settings
19
20# Haiku image
21HAIKU_IMAGE_CONTAINER_NAME = haiku-image-container ;
22HAIKU_CONTAINER_GRIST on $(HAIKU_IMAGE_CONTAINER_NAME) = HaikuImage ;
23HAIKU_INCLUDE_IN_CONTAINER_VAR on $(HAIKU_IMAGE_CONTAINER_NAME)
24	= HAIKU_INCLUDE_IN_IMAGE ;
25HAIKU_INSTALL_TARGETS_VAR on $(HAIKU_IMAGE_CONTAINER_NAME)
26	= HAIKU_IMAGE_INSTALL_TARGETS ;
27HAIKU_CONTAINER_SYSTEM_DIR_TOKENS on $(HAIKU_IMAGE_CONTAINER_NAME)
28	= system non-packaged ;
29
30# network boot archive
31HAIKU_NET_BOOT_ARCHIVE_CONTAINER_NAME = haiku-netboot-archive-container ;
32HAIKU_CONTAINER_GRIST on $(HAIKU_NET_BOOT_ARCHIVE_CONTAINER_NAME)
33	= NetBootArchive ;
34# HAIKU_INCLUDE_IN_CONTAINER_VAR -- update only mode not supported
35HAIKU_INSTALL_TARGETS_VAR on $(HAIKU_NET_BOOT_ARCHIVE_CONTAINER_NAME)
36	= HAIKU_NET_BOOT_ARCHIVE_INSTALL_TARGETS ;
37HAIKU_CONTAINER_SYSTEM_DIR_TOKENS on $(HAIKU_NET_BOOT_ARCHIVE_CONTAINER_NAME)
38	= system ;
39
40# boot floppy
41HAIKU_FLOPPY_BOOT_IMAGE_CONTAINER_NAME = haiku-boot-floppy-container ;
42HAIKU_CONTAINER_GRIST on $(HAIKU_FLOPPY_BOOT_IMAGE_CONTAINER_NAME)
43	= FloppyBootImage ;
44# HAIKU_INCLUDE_IN_CONTAINER_VAR -- update only mode not supported
45HAIKU_INSTALL_TARGETS_VAR on $(HAIKU_FLOPPY_BOOT_IMAGE_CONTAINER_NAME)
46	= HAIKU_FLOPPY_BOOT_IMAGE_INSTALL_TARGETS ;
47HAIKU_CONTAINER_SYSTEM_DIR_TOKENS on $(HAIKU_FLOPPY_BOOT_IMAGE_CONTAINER_NAME)
48	= system ;
49
50# boot CD image
51HAIKU_CD_BOOT_IMAGE_CONTAINER_NAME = haiku-boot-cd-container ;
52HAIKU_CONTAINER_GRIST on $(HAIKU_CD_BOOT_IMAGE_CONTAINER_NAME) = CDBootImage ;
53# HAIKU_INCLUDE_IN_CONTAINER_VAR -- update only mode not supported
54HAIKU_INSTALL_TARGETS_VAR on $(HAIKU_CD_BOOT_IMAGE_CONTAINER_NAME)
55	= HAIKU_CD_BOOT_IMAGE_INSTALL_TARGETS ;
56HAIKU_CONTAINER_SYSTEM_DIR_TOKENS on $(HAIKU_CD_BOOT_IMAGE_CONTAINER_NAME)
57	= system ;
58
59# boot MMC image
60HAIKU_MMC_BOOT_IMAGE_CONTAINER_NAME = haiku-boot-mmc-container ;
61HAIKU_CONTAINER_GRIST on $(HAIKU_MMC_BOOT_IMAGE_CONTAINER_NAME) = MMCImage ;
62# HAIKU_INCLUDE_IN_CONTAINER_VAR -- update only mode not supported
63HAIKU_INSTALL_TARGETS_VAR on $(HAIKU_MMC_BOOT_IMAGE_CONTAINER_NAME)
64	= HAIKU_MMC_BOOT_IMAGE_INSTALL_TARGETS ;
65HAIKU_CONTAINER_SYSTEM_DIR_TOKENS on $(HAIKU_MMC_BOOT_IMAGE_CONTAINER_NAME)
66	= system ;
67
68# Haiku image/install defaults
69HAIKU_DEFAULT_IMAGE_NAME = haiku.image ;
70HAIKU_DEFAULT_IMAGE_DIR = $(HAIKU_OUTPUT_DIR) ;
71HAIKU_DEFAULT_VMWARE_IMAGE_NAME = haiku.vmdk ;
72HAIKU_DEFAULT_INSTALL_DIR = /Haiku ;
73HAIKU_DEFAULT_IMAGE_SIZE ?= 300 ; # 300 MB
74HAIKU_DEFAULT_IMAGE_LABEL ?= Haiku ;
75
76# Haiku CD defaults
77HAIKU_DEFAULT_CD_NAME = haiku-cd.iso ;
78HAIKU_DEFAULT_CD_DIR = $(HAIKU_OUTPUT_DIR) ;
79HAIKU_DEFAULT_CD_LABEL = Haiku ;
80
81# Haiku Anyboot defaults
82HAIKU_DEFAULT_ANYBOOT_NAME = haiku-anyboot.iso ;
83HAIKU_DEFAULT_ANYBOOT_DIR = $(HAIKU_OUTPUT_DIR) ;
84HAIKU_DEFAULT_ANYBOOT_LABEL ?= Haiku ;
85
86# Haiku MMC defaults
87HAIKU_DEFAULT_MMC_NAME = haiku-mmc.image ;
88HAIKU_DEFAULT_MMC_DIR = $(HAIKU_OUTPUT_DIR) ;
89HAIKU_DEFAULT_MMC_LABEL ?= Haiku ;
90
91# analyze and optionally replace jam's target parameters
92ProcessCommandLineArguments ;
93
94
95# supported debug levels
96HAIKU_DEBUG_LEVELS = 0 1 2 3 4 5 ;
97
98# configuration header directories
99HAIKU_CONFIG_HEADERS = [ FDirName $(HAIKU_TOP) build user_config_headers ]
100	[ FDirName $(HAIKU_TOP) build config_headers ] ;
101
102
103# object directories common to all architectures
104HAIKU_OBJECT_BASE_DIR = [ FDirName $(HAIKU_OBJECT_DIR) haiku ] ;
105HAIKU_COMMON_ARCH_OBJECT_DIR = [ FDirName $(HAIKU_OBJECT_BASE_DIR) common ] ;
106
107
108#pragma mark - haiku target platform settings
109
110
111local architecture ;
112for architecture in $(HAIKU_PACKAGING_ARCHS) {
113	ArchitectureSetup $(architecture) ;
114}
115
116if $(HAIKU_PACKAGING_ARCH) {
117	local kernelArch = $(HAIKU_PACKAGING_ARCH) ;
118	# Always use the non-legacy GCC for the kernel.
119	if $(kernelArch) = x86_gcc2 {
120		kernelArch = x86 ;
121	}
122	KernelArchitectureSetup $(kernelArch) ;
123}
124
125# define primary packaging architecture macro
126HAIKU_DEFINES = __HAIKU_PRIMARY_PACKAGING_ARCH=\\\"$(HAIKU_PACKAGING_ARCH)\\\" ;
127
128
129# distro compatibility level defines
130HAIKU_DISTRO_COMPATIBILITY ?= "default" ;
131switch $(HAIKU_DISTRO_COMPATIBILITY) {
132	case official :
133		HAIKU_DEFINES += HAIKU_DISTRO_COMPATIBILITY_OFFICIAL ;
134		HAIKU_INCLUDE_TRADEMARKS = "" ;
135	case compatible :
136		HAIKU_DEFINES += HAIKU_DISTRO_COMPATIBILITY_COMPATIBLE ;
137		HAIKU_INCLUDE_TRADEMARKS = "" ;
138	case "default" :
139		HAIKU_DEFINES += HAIKU_DISTRO_COMPATIBILITY_DEFAULT ;
140		HAIKU_INCLUDE_TRADEMARKS = ;
141	case * :
142		Exit "Invalid value for HAIKU_DISTRO_COMPATIBILITY:"
143			$(HAIKU_DISTRO_COMPATIBILITY) ;
144}
145
146# network libraries
147HAIKU_NETWORK_LIBS = network ;
148HAIKU_NETAPI_LIB = bnetapi ;
149HAIKU_SELECT_UNAME_ETC_LIB = ;	# libroot, against which we link anyway
150
151HAIKU_EXECUTABLE_MIME_TYPE = "application/x-vnd.Be-elfexecutable" ;
152
153# TODO: The version stuff should probably go into a separate file and be made
154# available as macro, too.
155# Set our version number if not already set and mark it as a developer build
156if ! $(HAIKU_BUILD_VERSION) {
157	HAIKU_BUILD_VERSION ?= "1 0 0 a 1" ;
158	HAIKU_BUILD_DESCRIPTION ?= "Developer Build" ;
159}
160
161# If HAIKU_BUILD_VERSION is set, but HAIKU_BUILD_DESCRIPTION isn't, mark it as
162# an unknown build.
163HAIKU_BUILD_DESCRIPTION ?= "Unknown Build" ;
164
165
166#pragma mark - host platform settings
167
168
169# analyze the host gcc machine spec to find out about 64-bitness
170HOST_PLATFORM_IS_64_BIT = ;
171switch $(HOST_GCC_MACHINE) {
172	case i686-apple-darwin10 :	HOST_PLATFORM_IS_64_BIT = 1 ;
173	case i686-apple-darwin11 :	HOST_PLATFORM_IS_64_BIT = 1 ;
174	case x86_64-* :				HOST_PLATFORM_IS_64_BIT = 1 ;
175	case amd64-* :				HOST_PLATFORM_IS_64_BIT = 1 ;
176
177	case arm64-* :				HOST_PLATFORM_IS_64_BIT = 1 ;
178	case aarch64-* :			HOST_PLATFORM_IS_64_BIT = 1 ;
179	case riscv64-* :			HOST_PLATFORM_IS_64_BIT = 1 ;
180}
181
182# If HAIKU_HOST_USE_32BIT is set, add the required gcc base flag (the LD flag
183# is set later), or, if the architecture isn't actually 64 bit, clear
184# HAIKU_HOST_USE_32BIT.
185# Afterwards HOST_PLATFORM_IS_64_BIT will indicate whether the architecture is
186# effectively (i.e. when using the compiler/linker flags) 64 bit and
187# HAIKU_HOST_USE_32BIT will be set, iff the architecture is really 64 bit and
188# 32 bit mode was requested.
189if $(HAIKU_HOST_USE_32BIT) = 1 {
190	if $(HOST_PLATFORM_IS_64_BIT) {
191		# enable GCC -m32 option
192		HOST_GCC_BASE_FLAGS = -m32 ;
193		HOST_PLATFORM_IS_64_BIT = ;
194	} else {
195		HAIKU_HOST_USE_32BIT = 0 ;
196	}
197}
198
199
200# save jam's variables for the build platform
201HOST_AR				?= $(AR) ;
202HOST_ARFLAGS		?= $(ARFLAGS) ;
203HOST_CC				?= $(CC) ;
204HOST_C++			?= $(HOST_CC) ;
205HOST_LINK			?= $(HOST_CC) ;
206HOST_RANLIB			?= $(RANLIB) ;
207HOST_CPPFLAGS		?= $(CPPFLAGS) ;
208HOST_CCFLAGS		?= $(HOST_GCC_BASE_FLAGS) $(CCFLAGS) ;
209HOST_C++FLAGS		?= $(HOST_GCC_BASE_FLAGS) $(C++FLAGS) ;
210HOST_LDFLAGS		?= $(LDFLAGS) ;
211HOST_LINKFLAGS		?= $(HOST_GCC_BASE_FLAGS) $(LINKFLAGS) ;
212HOST_DEFINES		?= $(DEFINES) ;
213HOST_HDRS			?= $(HDRS) ;
214
215
216# split up HOST_AR into the command name and flags
217HOST_AR				= [ Match "([^ ]*) *(.*)" : $(HOST_AR[1]) ]
218					  $(HOST_AR[2-]) ;
219HOST_ARFLAGS		= $(HOST_AR[2-]) $(HOST_ARFLAGS) ;
220HOST_AR				= $(HOST_AR[1]) ;
221HOST_UNARFLAGS		?= x ;
222
223# check the host platform compatibility
224SetPlatformCompatibilityFlagVariables HOST_PLATFORM : HOST : host
225	: linux openbsd freebsd darwin ;
226HOST_PLATFORM_(host)_COMPATIBLE = 1 ;
227
228if $(HOST_PLATFORM) = linux || $(HOST_PLATFORM) = freebsd
229	|| $(HOST_PLATFORM) = darwin || $(HOST_PLATFORM) = openbsd {
230	# don't use lex: otherwise rc will not work correctly
231	if $(LEX) = lex {
232		LEX = flex ;
233	}
234}
235
236HOST_CPU ?= $(OSPLAT:L) ;
237
238# Jam doesn't know x86_64, so override HOST_CPU, if 64 bit.
239if $(HOST_CPU) = x86 && $(HOST_PLATFORM_IS_64_BIT) {
240	HOST_CPU = x86_64 ;
241}
242
243HOST_ARCH ?= $(HOST_CPU) ;
244HOST_ARCHS = $(HOST_ARCH) ;
245HOST_KERNEL_ARCH = host ;
246
247# set packaging architecture
248HOST_PACKAGING_ARCH		?= $(HOST_CPU) ;
249HOST_PACKAGING_ARCHS = $(HOST_PACKAGING_ARCH) ;
250
251# directories
252HOST_OBJECT_BASE_DIR = [ FDirName $(HAIKU_OBJECT_DIR) $(HOST_PLATFORM) ] ;
253HOST_COMMON_ARCH_OBJECT_DIR = [ FDirName $(HOST_OBJECT_BASE_DIR) common ] ;
254HOST_ARCH_OBJECT_DIR
255	= [ FDirName $(HOST_OBJECT_BASE_DIR) $(HOST_PACKAGING_ARCH) ] ;
256HOST_COMMON_DEBUG_OBJECT_DIR = [ FDirName $(HOST_ARCH_OBJECT_DIR) common ] ;
257HOST_DEBUG_0_OBJECT_DIR = [ FDirName $(HOST_ARCH_OBJECT_DIR) release ] ;
258
259local level ;
260for level in $(HAIKU_DEBUG_LEVELS[2-]) {
261	HOST_DEBUG_$(level)_OBJECT_DIR
262		= [ FDirName $(HOST_ARCH_OBJECT_DIR) debug_$(level) ] ;
263}
264
265# set variables for gcc header options
266SetIncludePropertiesVariables HOST ;
267
268# assembler flags
269HOST_ASFLAGS = ;
270
271# C/C++ flags
272HOST_CCFLAGS += -Wno-multichar ;
273HOST_C++FLAGS += -Wno-multichar ;
274
275HOST_PIC_CCFLAGS += -fPIC ;
276HOST_PIC_C++FLAGS += -fPIC ;
277
278HOST_GCC_BASE_FLAGS += -fno-strict-aliasing -fno-delete-null-pointer-checks ;
279
280HOST_KERNEL_CCFLAGS += $(HOST_GCC_BASE_FLAGS) -finline -fno-builtin
281	-D_KERNEL_MODE ;
282HOST_KERNEL_C++FLAGS += $(HOST_GCC_BASE_FLAGS) -finline -fno-builtin
283	-fno-exceptions -D_KERNEL_MODE ;
284HOST_KERNEL_DEFINES += _KERNEL_MODE ;
285
286HOST_KERNEL_PIC_CCFLAGS = -fno-pic ;
287HOST_KERNEL_PIC_LINKFLAGS = ;
288if $(HOST_ARCH) = ppc {
289	# Build a position independent PPC kernel. We need to be able to relocate
290	# the kernel, since the virtual address space layout at boot time is not
291	# fixed.
292	HOST_KERNEL_PIC_CCFLAGS = -fPIE ;
293	HOST_KERNEL_PIC_LINKFLAGS = -shared -fPIE ;
294}
295if $(HOST_ARCH) = m68k {
296	# Build a position independent M68K kernel. We need to be able to relocate
297	# the kernel, since the virtual address space layout at boot time is not
298	# fixed.
299	HOST_KERNEL_PIC_CCFLAGS = $(HAIKU_KERNEL_PIC_CCFLAGS) ;
300	HOST_KERNEL_PIC_LINKFLAGS = $(HAIKU_KERNEL_PIC_LINKFLAGS) ;
301}
302
303if $(HOST_PLATFORM) != darwin {
304	# fix for new changes to DSO linking policies
305	HOST_LINKFLAGS += -Xlinker --no-as-needed ;
306	HOST_LINKFLAGS += -Wl,--copy-dt-needed-entries ;
307}
308
309
310# warning flags
311HOST_WARNING_CCFLAGS = -Wall -Wno-trigraphs -Wmissing-prototypes -Wpointer-arith
312	-Wcast-align -Wsign-compare ;
313HOST_WARNING_C++FLAGS = -Wall -Wno-trigraphs -Wno-ctor-dtor-privacy
314	-Woverloaded-virtual -Wpointer-arith -Wcast-align -Wsign-compare ;
315
316HOST_KERNEL_WARNING_CCFLAGS = -Wall -Wno-trigraphs -Wmissing-prototypes ;
317HOST_KERNEL_WARNING_C++FLAGS = -Wall -Wno-trigraphs ;
318
319HOST_WERROR_FLAGS = ;
320
321# debug flags
322local hostDebugFlags ;
323switch $(HOST_PLATFORM) {
324	case haiku		: hostDebugFlags ?= -ggdb ;
325	case haiku_host	: hostDebugFlags ?= -ggdb ;
326	case linux		: hostDebugFlags ?= -ggdb ;
327	case freebsd	: hostDebugFlags ?= -ggdb ;
328	case darwin		: hostDebugFlags ?= -ggdb ;
329	case *			: hostDebugFlags ?= -g ;
330}
331
332# debug 0: suppress asserts
333HOST_DEBUG_0_CCFLAGS = [ FDefines NDEBUG=$(NDEBUG) ] ;
334HOST_DEBUG_0_C++FLAGS = [ FDefines NDEBUG=$(NDEBUG) ] ;
335
336HOST_KERNEL_DEBUG_0_CCFLAGS = [ FDefines NDEBUG=$(NDEBUG) ] ;
337HOST_KERNEL_DEBUG_0_C++FLAGS = [ FDefines NDEBUG=$(NDEBUG) ] ;
338
339local level ;
340for level in $(HAIKU_DEBUG_LEVELS[2-]) {
341	local flags = $(hostDebugFlags) [ FDefines DEBUG=$(level) ] ;
342	HOST_DEBUG_$(level)_CCFLAGS			= $(flags) ;
343	HOST_DEBUG_$(level)_C++FLAGS		= $(flags) ;
344	HOST_KERNEL_DEBUG_$(level)_CCFLAGS	= $(flags) ;
345	HOST_KERNEL_DEBUG_$(level)_C++FLAGS	= $(flags) ;
346}
347
348# ld flags
349if $(HAIKU_HOST_USE_32BIT) = 1 {
350	HOST_LDFLAGS += -melf_i386 ;
351}
352
353# private kernel headers do be used when compiling kernel code
354HOST_PRIVATE_KERNEL_HEADERS = ;
355
356# private shared kernel/libroot headers
357HOST_PRIVATE_SYSTEM_HEADERS = ;
358
359# under Haiku use copyattr instead of cp
360if $(HOST_PLATFORM_HAIKU_COMPATIBLE) {
361	CP = copyattr --data ;
362}
363
364HOST_DEFINES += ARCH_$(HOST_CPU) ;
365HOST_DEFINES += _NO_INLINE_ASM __NO_INLINE__ ;
366
367# for builds of tools in the current environment
368HOST_BUILD_COMPATIBILITY_LIB_DIR = [ FDirName $(PWD) $(HOST_OBJECT_BASE_DIR) lib ] ;
369
370# For the generic attributes emulation: Target rm_attrs -- rm replacement that
371# also removes the attributes.
372HOST_RM_ATTRS_TARGET = ;
373
374HOST_LIBROOT = libroot_build_function_remapper.a libroot_build.so ;
375HOST_STATIC_LIBROOT = libroot_build_function_remapper.a libroot_build.a ;
376HOST_LIBBE = libbe_build.so ;
377
378# adding rpath allows directly invoking host tools without specifying
379# a library search path
380if $(HOST_PLATFORM) != darwin {
381	HOST_LINKFLAGS += -Wl,-rpath,$(HOST_BUILD_COMPATIBILITY_LIB_DIR) ;
382}
383
384if $(HOST_PLATFORM_HAIKU_COMPATIBLE) {
385	# the C++ standard and support libraries
386	HOST_LIBSTDC++ = stdc++ ;
387	HOST_LIBSUPC++ = supc++ ;
388
389	HOST_ADD_BUILD_COMPATIBILITY_LIB_DIR
390		= "LIBRARY_PATH=\"$LIBRARY_PATH:$(HOST_BUILD_COMPATIBILITY_LIB_DIR)\"" ;
391	HOST_PTHREAD_LINKFLAGS = ;
392	HOST_LINKFLAGS += -lbsd ;
393	HOST_LIBRARY_NAME_MAP_input_server = /system/servers/input_server ;
394	HOST_DEFINES += __STDC_FORMAT_MACROS __STDC_LIMIT_MACROS ;
395
396	local compatibilityHeader = -include [ FDirName $(HAIKU_TOP) headers build
397		HaikuBuildCompatibility.h ] ;
398	HOST_CCFLAGS += $(compatibilityHeader) ;
399	HOST_C++FLAGS += $(compatibilityHeader) ;
400} else {
401	HOST_LINKFLAGS += -lm -ldl ;
402	HOST_LIBSTDC++ = stdc++ ;
403	if $(HOST_PLATFORM) = darwin {
404		HOST_ADD_BUILD_COMPATIBILITY_LIB_DIR
405			= "DYLD_LIBRARY_PATH=\"$DYLD_LIBRARY_PATH:$(HOST_BUILD_COMPATIBILITY_LIB_DIR)\"" ;
406	} else {
407		HOST_ADD_BUILD_COMPATIBILITY_LIB_DIR
408			= "LD_LIBRARY_PATH=\"$LD_LIBRARY_PATH:$(HOST_BUILD_COMPATIBILITY_LIB_DIR)\"" ;
409	}
410
411	HOST_PTHREAD_LINKFLAGS = -pthread ;
412
413	# the C++ support library
414	HOST_LIBSUPC++ = supc++ ;
415
416	if $(HOST_PLATFORM) = darwin {
417		# part of the C++ runtime lives in libstdc++ on Darwin
418		HOST_LIBSUPC++ = gcc_s.1 stdc++ ;
419		HOST_LIBSTDC++ = ;
420	} else if $(HOST_PLATFORM) = freebsd {
421		if $(HOST_CPU) = x86_64 {
422			# amd64 FreeBSD 8 doesn't come without a shared libsupc++, and the
423			# static one prevents us from building shared libraries. So we have
424			# to work around by using the shared libstdc++.
425			HOST_LIBSUPC++ = stdc++ ;
426			HOST_LIBSTDC++ = ;
427		}
428	}
429
430	# Supposing this is a glibc platform, let's try to get features like large
431	# file support, ISO C 99 definitions, etc. On some platforms we need to
432	# request 64 bit off_t support explicitely.
433	HOST_DEFINES += _GNU_SOURCE _FILE_OFFSET_BITS=64 __STDC_FORMAT_MACROS
434		__STDC_LIMIT_MACROS ;
435}
436
437if $(HAIKU_HOST_USE_XATTR) = 1 {
438	HOST_DEFINES += HAIKU_HOST_USE_XATTR ;
439} else {
440	# Otherwise the generic attribute emulation is used, which uses a
441	# directory per file to store its attribute. We need to redefine RM so
442	# that the attributes are removed as well. We use a wrapper script,
443	# which invokes a build tool. If the build tool hasn't been built yet,
444	# the normal "rm" is used and the attributes are leaked (likely there
445	# aren't any yet).
446	RM = $(HOST_ADD_BUILD_COMPATIBILITY_LIB_DIR)
447		[ FDirName $(HAIKU_TOP) build scripts rm_attrs ]
448		[ FDirName $(HAIKU_OBJECT_DIR) $(HOST_PLATFORM) $(HOST_ARCH) release
449			tools rm_attrs ] -f ;
450		# assumes that rm_attrs is built with debugging disabled
451	HOST_RM_ATTRS_TARGET = <build>rm_attrs ;
452
453	# If specified, use xattr support to tag files with unique IDs.
454	if $(HAIKU_HOST_USE_XATTR_REF) = 1 {
455		HOST_DEFINES += HAIKU_HOST_USE_XATTR_REF ;
456	}
457}
458
459# network libraries
460if $(HOST_PLATFORM_HAIKU_COMPATIBLE) {
461	HOST_NETWORK_LIBS = network ;
462	HOST_NETAPI_LIB = bnetapi ;
463	HOST_SELECT_UNAME_ETC_LIB = ;	# libroot
464} else {
465	# Linux, ...
466	HOST_NETWORK_LIBS = ;
467	HOST_NETAPI_LIB = ;
468	HOST_SELECT_UNAME_ETC_LIB = ;
469}
470
471# define the executable MIME type
472HOST_EXECUTABLE_MIME_TYPE = "application/x-vnd.Be-elfexecutable" ;
473
474if $(METROWERKS) {
475	# at least parts of Haiku still can be compiled with
476	# the Metrowerks compiler on BeOS/PPC
477	HOST_EXECUTABLE_MIME_TYPE = "application/x-be-executable" ;
478}
479
480# Be API compatibility
481HOST_BE_API_HEADERS = ;
482HOST_BE_API_CCFLAGS = ;
483HOST_BE_API_C++FLAGS = ;
484
485# Add directory with system headers we need when building something for the host
486# platform, e.g. containing missing POSIX/GNU headers.
487HOST_HDRS += [ FDirName $(HAIKU_TOP) headers build host $(HOST_PLATFORM) ] ;
488
489if $(HOST_PLATFORM) = freebsd {
490	# FreeBSD's gcc doesn't include /usr/local/* in its search paths,
491	# though that's where most things from ports wind up being installed.
492	HOST_HDRS += /usr/local/include /usr/include/gnu ;
493	HOST_LINKFLAGS += -L/usr/local/lib ;
494}
495
496if $(HOST_PLATFORM) = darwin {
497	HOST_HDRS += [ FDirName $(HAIKU_TOP) src build libgnuregex ] ;
498
499	# Mac OS X users may be using macports libraries, in which case the headers
500	# and the libs are located in /opt/local/.
501	HOST_HDRS += /opt/local/include ;
502	HOST_LINKFLAGS += -L/opt/local/lib ;
503
504	# Mac OS X users may be using homebrew libraries, in which case the headers
505	# and the libs are locted in the /usr/local/.
506	HOST_HDRS += /usr/local/include ;
507	HOST_LINKFLAGS += -L/usr/local/lib ;
508}
509
510HOST_BE_API_HEADERS =
511	[ FDirName $(HAIKU_TOP) headers build ]
512	[ FDirName $(HAIKU_TOP) headers build os ]
513	[ FDirName $(HAIKU_TOP) headers build os add-ons registrar ]
514	[ FDirName $(HAIKU_TOP) headers build os app ]
515	[ FDirName $(HAIKU_TOP) headers build os bluetooth ]
516	[ FDirName $(HAIKU_TOP) headers build os drivers ]
517	[ FDirName $(HAIKU_TOP) headers build os kernel ]
518	[ FDirName $(HAIKU_TOP) headers build os interface ]
519	[ FDirName $(HAIKU_TOP) headers build os locale ]
520	[ FDirName $(HAIKU_TOP) headers build os storage ]
521	[ FDirName $(HAIKU_TOP) headers build os support ]
522	[ FDirName $(HAIKU_TOP) headers build private ]
523;
524HOST_BE_API_CCFLAGS = -include [ FDirName $(HAIKU_TOP) headers build
525	BeOSBuildCompatibility.h ] ;
526HOST_BE_API_C++FLAGS = $(HOST_BE_API_CCFLAGS) ;
527
528if ! $(HOST_PYTHON) {
529	Echo "HOST_PYTHON variable not defined --> will default to 'python'" ;
530	HOST_PYTHON ?= "python" ;
531}
532
533#pragma mark - target platform settings
534
535
536# check the target platform compatibility
537SetPlatformCompatibilityFlagVariables TARGET_PLATFORM : TARGET : target ;
538
539# Haiku architecture is undefined on host-only builds
540# set here to host arch to prevent recusive loops.
541if $(HAIKU_HOST_BUILD_ONLY) = 1 {
542	Echo "Host tools build for $(HOST_ARCH)" ;
543	HAIKU_ARCH = $(HOST_ARCH) ;
544	HAIKU_KERNEL_ARCH = $(HOST_ARCH) ;
545	HAIKU_KERNEL_ARCH_DIR = $(HAIKU_KERNEL_ARCH) ;
546}
547
548# Set TARGET_* variables either from HAIKU_* or HOST_* depending on the
549# specified TARGET_PLATFORM. Some variables are package architecture dependent
550# and their name gets a respective suffix. A few variables exist both with and
551# without suffix. The latter is either equivalent to the variable with the
552# primary architecture suffix (e.g. TARGET_ARCH) or is (additionally) applicable
553# for all architectures (e.g. TARGET_DEFINES).
554
555local buildVars =
556	ARCH ARCHS KERNEL_ARCH KERNEL_ARCH_DIR PACKAGING_ARCH PACKAGING_ARCHS
557
558	DEFINES
559	KERNEL_DEFINES
560	BOOT_DEFINES
561
562	KERNEL_CCFLAGS KERNEL_C++FLAGS
563	KERNEL_PIC_CCFLAGS KERNEL_PIC_LINKFLAGS KERNEL_ADDON_LINKFLAGS
564	BOOT_CCFLAGS BOOT_C++FLAGS BOOT_LINKFLAGS BOOT_LDFLAGS
565
566	KERNEL_WARNING_CCFLAGS KERNEL_WARNING_C++FLAGS
567
568	KERNEL_DEBUG_$(HAIKU_DEBUG_LEVELS)_CCFLAGS
569	KERNEL_DEBUG_$(HAIKU_DEBUG_LEVELS)_C++FLAGS
570
571	PRIVATE_KERNEL_HEADERS
572
573	NETWORK_LIBS NETAPI_LIB SELECT_UNAME_ETC_LIB
574
575	EXECUTABLE_MIME_TYPE
576
577	OBJECT_BASE_DIR COMMON_ARCH_OBJECT_DIR
578	;
579
580local archDependentBuildVars =
581	ARCH CPU
582
583	AR CC C++ ELFEDIT LD OBJCOPY RANLIB STRIP
584
585	CC_IS_LEGACY_GCC CC_IS_CLANG
586
587	ARFLAGS ASFLAGS UNARFLAGS CPPFLAGS CCFLAGS C++FLAGS HDRS LDFLAGS
588	LINK LINKFLAGS
589
590	WARNING_CCFLAGS WARNING_C++FLAGS WERROR_FLAGS
591
592	DEBUG_$(HAIKU_DEBUG_LEVELS)_CCFLAGS DEBUG_$(HAIKU_DEBUG_LEVELS)_C++FLAGS
593
594	INCLUDES_SEPARATOR LOCAL_INCLUDES_OPTION SYSTEM_INCLUDES_OPTION
595
596	PRIVATE_SYSTEM_HEADERS
597
598	ARCH_OBJECT_DIR COMMON_DEBUG_OBJECT_DIR
599	DEBUG_$(HAIKU_DEBUG_LEVELS)_OBJECT_DIR
600	;
601
602# target platform setup
603local var ;
604for var in $(buildVars) {
605	TARGET_$(var) = $(HAIKU_$(var)) ;
606}
607
608for var in $(archDependentBuildVars)_$(TARGET_PACKAGING_ARCHS) {
609	TARGET_$(var) = $(HAIKU_$(var)) ;
610}
611
612TARGET_BOOT_LIBGCC		= $(HAIKU_BOOT_LIBGCC_$(TARGET_PACKAGING_ARCH)) ;
613TARGET_BOOT_LIBSUPC++	= $(HAIKU_BOOT_LIBSUPC++_$(TARGET_PACKAGING_ARCH)) ;
614TARGET_BOOT_32_LIBGCC		= $(HAIKU_BOOT_32_LIBGCC_$(TARGET_PACKAGING_ARCH)) ;
615TARGET_BOOT_32_LIBSUPC++	= $(HAIKU_BOOT_32_LIBSUPC++_$(TARGET_PACKAGING_ARCH)) ;
616
617TARGET_KERNEL_PLATFORM	?= $(HAIKU_KERNEL_PLATFORM) ;
618
619local architecture ;
620for architecture in $(TARGET_PACKAGING_ARCHS) {
621	TARGET_DEFINES_$(architecture) = $(HAIKU_DEFINES_$(architecture)) ;
622	TARGET_LIBRARY_NAME_MAP_$(architecture)
623		= HAIKU_LIBRARY_NAME_MAP_$(architecture) ;
624}
625
626# define macro, for identifying the platform
627switch $(TARGET_PLATFORM) {
628	case haiku		: TARGET_DEFINES	+= HAIKU_TARGET_PLATFORM_HAIKU ;
629	case libbe_test	: TARGET_DEFINES	+= HAIKU_TARGET_PLATFORM_LIBBE_TEST ;
630}
631
632# define macro, for identifying the host platform
633switch $(HOST_PLATFORM) {
634	case haiku_host	: HOST_DEFINES	+= HAIKU_HOST_PLATFORM_HAIKU ;
635	case linux		: HOST_DEFINES	+= HAIKU_HOST_PLATFORM_LINUX ;
636	case freebsd	: HOST_DEFINES	+= HAIKU_HOST_PLATFORM_FREEBSD ;
637	case darwin		: HOST_DEFINES	+= HAIKU_HOST_PLATFORM_DARWIN ;
638}
639
640# define host platform 64 bit macro
641if $(HOST_PLATFORM_IS_64_BIT) {
642	HOST_DEFINES += HAIKU_HOST_PLATFORM_64_BIT ;
643}
644
645# define Haiku packaging architecture macro for host build
646HOST_DEFINES += HAIKU_PACKAGING_ARCH=\\\"$(HAIKU_PACKAGING_ARCH)\\\" ;
647
648
649#pragma mark -
650
651# special target libbe_test
652
653if $(TARGET_PLATFORM) = libbe_test {
654	# headers and flags
655	TARGET_HDRS_$(TARGET_PACKAGING_ARCH) +=
656		[ PublicHeaders $(DOT) app drivers game interface kernel locale storage
657			support ]
658		[ PrivateHeaders $(DOT) ] ;
659	TARGET_DEFINES += __HAIKU__ ;
660
661	TARGET_PRIVATE_SYSTEM_HEADERS_$(TARGET_PACKAGING_ARCH) =
662		[ PrivateHeaders $(DOT) system system/arch/$(TARGET_ARCH) ] ;
663
664	# directories
665	TARGET_OBJECT_BASE_DIR
666		= [ FDirName $(HAIKU_OBJECT_DIR) $(TARGET_PLATFORM) ] ;
667	TARGET_COMMON_ARCH_OBJECT_DIR
668		= [ FDirName $(TARGET_OBJECT_BASE_DIR) common ] ;
669	TARGET_ARCH_OBJECT_DIR_$(TARGET_PACKAGING_ARCH)
670		= [ FDirName $(TARGET_OBJECT_BASE_DIR) $(TARGET_ARCH) ] ;
671	TARGET_COMMON_DEBUG_OBJECT_DIR_$(TARGET_PACKAGING_ARCH)
672		= [ FDirName $(TARGET_ARCH_OBJECT_DIR_$(TARGET_PACKAGING_ARCH))
673			common ] ;
674	TARGET_DEBUG_0_OBJECT_DIR_$(TARGET_PACKAGING_ARCH)
675		= [ FDirName $(TARGET_ARCH_OBJECT_DIR_$(TARGET_PACKAGING_ARCH))
676			release ] ;
677
678	local level ;
679	for level in $(HAIKU_DEBUG_LEVELS[2-]) {
680		TARGET_DEBUG_$(level)_OBJECT_DIR_$(TARGET_PACKAGING_ARCH)
681			= [ FDirName $(TARGET_ARCH_OBJECT_DIR_$(TARGET_PACKAGING_ARCH))
682				debug_$(level) ] ;
683	}
684
685	# library name map
686	TARGET_LIBRARY_NAME_MAP_$(TARGET_PACKAGING_ARCH) = LIBBE_LIBRARY_NAME_MAP ;
687	LIBBE_LIBRARY_NAME_MAP_be = libbe_test.so ;
688}
689
690
691#pragma mark - common stuff
692
693
694# start with a clean state
695CCFLAGS = ;
696C++FLAGS = ;
697DEFINES = ;
698
699# Set CC, C++, LINK to invalid values, so that we realize early, that we use
700# the wrong compiler.
701CC = bad-cc ;
702C++ = bad-c++ ;
703LINK = bad-link ;
704
705
706# Defaults for warnings, optimization, and debugging.
707#
708WARNINGS ?= 1 ;
709OPTIM ?= -O2 ;
710DEBUG ?= 0 ;
711
712
713# Set a sane default for whether this is a CI build.
714HAIKU_CONTINUOUS_INTEGRATION_BUILD ?= 0 ;
715
716
717# Set the defaults for PLATFORM and SUPPORTED_PLATFORMS. PLATFORM is only
718# overridden for targets to be built for the host platform. SUPPORTED_PLATFORMS
719# can be overridden by the author of a component.
720PLATFORM = $(TARGET_PLATFORM) ;
721SUPPORTED_PLATFORMS = haiku ;
722
723
724# Define two pseudo targets for the target and buildhost platform. The main
725# build rules (Cc, C++, As, ...) depend on these pseude targets such that global
726# initializations that are required before anything is built for a specific
727# platform can be forced by depending the pseudo target for the platform on the
728# initializations.
729# This is currently used to unpack the external headers from the
730# gcc_syslibs_devel build feature before anything is built for the target
731# platform.
732NotFile $(TARGET_PLATFORM) ;
733NotFile host ;
734
735
736# Instructs the Library rule to not make its object files temporary.
737# This is needed as some objects are used in a static library and for an
738# executable.
739KEEPOBJS = true ;
740
741
742# Set permissions to how they should be on the image.
743EXEMODE		= 755 ;
744FILEMODE	= 644 ;
745SHELLMODE	= 755 ;
746
747
748# output directories
749# TODO: Review this.
750HAIKU_DOCUMENTATION_DIR ?= [ FDirName $(HAIKU_OUTPUT_DIR) documentation ] ;
751HAIKU_DOCUMENTATION_OBJECT_DIR ?= [ FDirName $(HAIKU_COMMON_PLATFORM_OBJECT_DIR)
752	documentation ] ;
753
754# TODO: Rethink test stuff.
755HAIKU_TEST_DIR			?= [ FDirName $(HAIKU_OUTPUT_DIR) tests
756	$(TARGET_PLATFORM) $(HAIKU_ARCH) ] ;
757HAIKU_APP_TEST_DIR		?= [ FDirName $(HAIKU_TEST_DIR) apps ] ;
758HAIKU_APP_TEST_LIB_DIR 	?= [ FDirName $(HAIKU_APP_TEST_DIR) lib ] ;
759HAIKU_TMP_DIR			?= [ FDirName $(HAIKU_OUTPUT_DIR) tmp ] ;
760
761local architecture ;
762for architecture in $(HAIKU_PACKAGING_ARCHS) {
763	local baseDir
764		= [ FDirName $(TARGET_OBJECT_BASE_DIR) $(architecture) packaging ] ;
765	HAIKU_PACKAGES_DIR_$(architecture) = [ FDirName $(baseDir) packages ] ;
766	HAIKU_PACKAGES_BUILD_DIR_$(architecture)
767		= [ FDirName $(baseDir) packages_build ] ;
768	HAIKU_PACKAGE_REPOSITORIES_DIR_$(architecture)
769		= [ FDirName $(baseDir) repositories ] ;
770}
771
772
773HAIKU_PACKAGE_INFOS_DIR			= [ FDirName $(HAIKU_TOP) src data
774									package_infos ] ;
775
776TARGET_TEST_DIR				?= [ FDirName $(HAIKU_TEST_DIR)
777									$(TARGET_PLATFORM) ] ;
778TARGET_UNIT_TEST_DIR		?= [ FDirName $(TARGET_TEST_DIR) unittests ] ;
779TARGET_UNIT_TEST_LIB_DIR	?= [ FDirName $(TARGET_UNIT_TEST_DIR) lib ] ;
780
781# automatically setup the objects directory per subdirectory
782SUBDIRRULES += SetupObjectsDir ;
783
784# Add the standard (userland) warning flags variables to the ones restored in
785# every subdirectory. Thus we can easily meddle with them in subdirectories
786# with imported sources.
787AUTO_SET_UP_CONFIG_VARIABLES +=
788	HOST_WARNING_CCFLAGS HOST_WARNING_C++FLAGS
789	TARGET_WARNING_CCFLAGS_$(TARGET_PACKAGING_ARCHS)
790	TARGET_WARNING_C++FLAGS_$(TARGET_PACKAGING_ARCHS)
791	;
792
793# also add PLATFORM and SUPPORTED_PLATFORMS
794AUTO_SET_UP_CONFIG_VARIABLES += PLATFORM SUPPORTED_PLATFORMS ;
795
796
797# set up warnings
798local architecture ;
799for architecture in $(TARGET_PACKAGING_ARCHS) {
800	ArchitectureSetupWarnings $(architecture) ;
801}
802
803
804# set up architecture build features
805local architecture ;
806for architecture in $(TARGET_PACKAGING_ARCHS) {
807	InitArchitectureBuildFeatures $(architecture) ;
808}
809
810
811# The following directories cannot currently be compiled with DEBUG=1
812SetConfigVar DEBUG : HAIKU_TOP src add-ons disk_systems bfs : 0 : local ;
813SetConfigVar DEBUG : HAIKU_TOP src add-ons kernel drivers audio hda : 0 : local ;
814SetConfigVar DEBUG : HAIKU_TOP src add-ons kernel drivers audio ac97 auich : 0 : local ; # fails with gcc4 only
815SetConfigVar DEBUG : HAIKU_TOP src add-ons kernel drivers audio ac97 auvia : 0 : local ; # fails with gcc4 only
816SetConfigVar DEBUG : HAIKU_TOP src add-ons kernel drivers audio ac97 sis7018 : 0 : local ;
817SetConfigVar DEBUG : HAIKU_TOP src add-ons kernel file_systems btrfs : 0 : local ;
818SetConfigVar DEBUG : HAIKU_TOP src add-ons kernel file_systems ntfs libntfs : 0 : local ;
819SetConfigVar DEBUG : HAIKU_TOP src add-ons kernel file_systems udf : 0 : local ;
820SetConfigVar DEBUG : HAIKU_TOP src add-ons kernel file_systems userlandfs server : 0 : local ; # fails with gcc2 only
821SetConfigVar DEBUG : HAIKU_TOP src add-ons kernel file_systems userlandfs server haiku : 0 : local ; # fails with gcc2 only
822SetConfigVar DEBUG : HAIKU_TOP src add-ons media media-add-ons dvb : 0 : local ;
823SetConfigVar DEBUG : HAIKU_TOP src add-ons print drivers gutenprint : 0 : local ;
824SetConfigVar DEBUG : HAIKU_TOP src servers input : 0 : local ;
825SetConfigVar DEBUG : HAIKU_TOP src servers media_addon : 0 : local ;
826SetConfigVar DEBUG : HAIKU_TOP src system boot loader file_systems bfs : 0 : local ;
827