xref: /haiku/build/jam/ArchitectureRules (revision 04d1d2da0b27294f0f1e623071df310a0820d4b6)
1rule ArchitectureSetup architecture
2{
3	# ArchitectureSetup <architecture> ;
4	#
5	# Initializes all global packaging architecture dependent variables for the
6	# given packaging architecture. Also sets HAIKU_ARCH (to the primary
7	# architecture), if this is the first invocation of the rule, and adds
8	# the architecture to HAIKU_ARCHS, if not yet contained.
9
10	# analyze GCC version
11	local gccVersion
12		= [ FAnalyzeGCCVersion HAIKU_GCC_RAW_VERSION_$(architecture) ] ;
13	HAIKU_GCC_VERSION_$(architecture) = $(gccVersion) ;
14
15	# enable GCC -pipe option, if requested
16	local ccBaseFlags ;
17	if $(HAIKU_USE_GCC_PIPE) = 1 {
18		ccBaseFlags = -pipe ;
19	}
20
21	if $(gccVersion[1]) >= 3 {
22		# disable strict aliasing on anything newer than gcc 2 as it may lead to
23		# unexpected results.
24		# TODO: remove the -fno-strict-aliasing option when all code has been
25		#		analyzed/fixed with regard to aliasing.
26		ccBaseFlags += -fno-strict-aliasing ;
27
28		# Without this flag, GCC deletes many null-pointer checks that are
29		# technically undefined behavior (e.g. passing NULL to strdup, among
30		# others), which breaks both the kernel and various applications. See:
31		#  - https://freelists.org/post/haiku-development/hrev45320-Yet-another-nonobvious-effect-of-ftreevrp-optimization
32		#  - https://dev.haiku-os.org/ticket/13285#comment:8 (& subsequent comments)
33		#  - https://dev.haiku-os.org/ticket/10803#comment:4 (& subsequent comments)
34		# Note that the Linux also does the same:
35		#  - https://github.com/torvalds/linux/commit/a3ca86aea507904
36		ccBaseFlags += -fno-delete-null-pointer-checks ;
37
38		# disable some builtins that are incompatible with our definitions
39		ccBaseFlags += -fno-builtin-fork -fno-builtin-vfork ;
40	}
41
42	# default architecture tuning
43	local cpu = $(HAIKU_CPU_$(architecture)) ;
44	local archFlags ;
45	switch $(cpu) {
46		case ppc : archFlags += -mcpu=440fp ;
47		case arm : archFlags += -march=armv7-a -mfloat-abi=hard ;
48		case x86 : archFlags += -march=pentium ;
49	}
50	if $(HAIKU_CC_IS_CLANG_$(architecture)) = 1 {
51		# TODO: These should be included in Clang's compiler specs.
52		ccBaseFlags += -fPIC ;
53		HAIKU_LINKFLAGS_$(architecture) += -shared ;
54	}
55	ccBaseFlags += $(archFlags) ;
56
57	# activating graphite optimizations
58	if $(HAIKU_USE_GCC_GRAPHITE_$(architecture)) = 1 {
59		ccBaseFlags += -floop-interchange -ftree-loop-distribution
60			-floop-strip-mine -floop-block ;
61	}
62
63	# initial state for flags etc.
64	HAIKU_C++_$(architecture) ?= $(HAIKU_CC_$(architecture)) ;
65	HAIKU_LINK_$(architecture) ?= $(HAIKU_CC_$(architecture)) ;
66
67	HAIKU_CCFLAGS_$(architecture) += $(ccBaseFlags) -nostdinc ;
68	HAIKU_C++FLAGS_$(architecture) += $(ccBaseFlags) -nostdinc ;
69	HAIKU_LINKFLAGS_$(architecture) += $(ccBaseFlags) ;
70	HAIKU_ASFLAGS_$(architecture) += $(archFlags) -nostdinc ;
71
72	# strip is required
73	if ! $(HAIKU_STRIP_$(architecture)) {
74		Exit "HAIKU_STRIP_$(architecture) not set. Please re-run configure." ;
75	}
76
77	HAIKU_ARCH_$(architecture) = $(cpu) ;
78	HAIKU_ARCH ?= $(cpu) ;
79		# Set only, if not set yet. This way HAIKU_ARCH is set to the primary
80		# architecture.
81	if ! $(cpu) in $(HAIKU_ARCHS) {
82		HAIKU_ARCHS += $(cpu) ;
83	}
84	HAIKU_DEFINES_$(architecture) += ARCH_$(cpu) ;
85
86	# directories
87	HAIKU_ARCH_OBJECT_DIR_$(architecture)
88		= [ FDirName $(HAIKU_OBJECT_BASE_DIR) $(architecture) ] ;
89	HAIKU_COMMON_DEBUG_OBJECT_DIR_$(architecture)
90		= [ FDirName $(HAIKU_ARCH_OBJECT_DIR_$(architecture)) common ] ;
91	HAIKU_DEBUG_0_OBJECT_DIR_$(architecture)
92		= [ FDirName $(HAIKU_ARCH_OBJECT_DIR_$(architecture)) release ] ;
93
94	local level ;
95	for level in $(HAIKU_DEBUG_LEVELS[2-]) {
96		HAIKU_DEBUG_$(level)_OBJECT_DIR_$(architecture)
97			= [ FDirName $(HAIKU_ARCH_OBJECT_DIR_$(architecture))
98				debug_$(level) ] ;
99	}
100
101	# set variables for gcc header options
102	SetIncludePropertiesVariables HAIKU : _$(architecture) ;
103
104	# warning flags
105	HAIKU_WARNING_CCFLAGS_$(architecture) = -Wall
106		-Wno-multichar
107		-Wpointer-arith -Wsign-compare
108		-Wmissing-prototypes ;
109	HAIKU_WARNING_C++FLAGS_$(architecture) = -Wall
110		-Wno-multichar
111		-Wpointer-arith -Wsign-compare
112		-Wno-ctor-dtor-privacy -Woverloaded-virtual ;
113
114	# disable some Clang warnings that are not very useful
115	if $(HAIKU_CC_IS_CLANG_$(architecture)) = 1 {
116		HAIKU_WARNING_CCFLAGS_$(architecture) += -Wno-address-of-packed-member
117			-Wno-unused-private-field -Wno-cast-align -Wno-gnu-designator
118			-Wno-builtin-requires-header ;
119		HAIKU_WARNING_C++FLAGS_$(architecture) += -Wno-address-of-packed-member
120			-Wno-unused-private-field -Wno-cast-align -Wno-gnu-designator
121			-Wno-builtin-requires-header ;
122	}
123
124	HAIKU_WERROR_FLAGS_$(architecture) = ;
125
126	if $(gccVersion[1]) >= 4 {
127		# TODO: Remove all these.
128		HAIKU_WERROR_FLAGS_$(architecture) += -Wno-error=unused-but-set-variable
129			-Wno-error=deprecated -Wno-error=deprecated-declarations
130			-Wno-error=cpp -Wno-error=trigraphs ;
131		# But these can stay.
132		HAIKU_WERROR_FLAGS_$(architecture) += -Wno-error=cast-align
133			-Wno-error=format-truncation ;
134	}
135
136	# debug flags
137	local debugFlags = -ggdb ;
138
139	# debug 0: suppress asserts
140	HAIKU_DEBUG_0_CCFLAGS_$(architecture) = [ FDefines NDEBUG=$(NDEBUG) ] ;
141	HAIKU_DEBUG_0_C++FLAGS_$(architecture) = [ FDefines NDEBUG=$(NDEBUG) ] ;
142
143	local level ;
144	for level in $(HAIKU_DEBUG_LEVELS[2-]) {
145		local flags = $(debugFlags) [ FDefines DEBUG=$(level) ] ;
146		HAIKU_DEBUG_$(level)_CCFLAGS_$(architecture) = $(flags) ;
147		HAIKU_DEBUG_$(level)_C++FLAGS_$(architecture) = $(flags) ;
148	}
149
150	# TODO: Temporary work-around. Should be defined in the compiler specs
151	HAIKU_LINKFLAGS_$(architecture) += -Xlinker --no-undefined ;
152
153	if $(gccVersion[1]) < 3 {
154		HAIKU_DEFINES_$(architecture) += _BEOS_R5_COMPATIBLE_ ;
155	}
156
157	# private shared kernel/libroot headers
158	HAIKU_PRIVATE_SYSTEM_HEADERS_$(architecture)
159		= [ PrivateHeaders $(DOT) system system/arch/$(cpu) ] ;
160
161	# library and executable glue code
162	local commonGlueCode =
163		<src!system!glue!$(architecture)>init_term_dyn.o
164		<src!system!glue!arch!$(cpu)!$(architecture)>crti.o
165		<src!system!glue!arch!$(cpu)!$(architecture)>crtn.o
166		;
167	HAIKU_LIBRARY_BEGIN_GLUE_CODE_$(architecture) =
168		<src!system!glue!arch!$(cpu)!$(architecture)>crti.o
169		<$(architecture)>crtbeginS.o
170		<src!system!glue!$(architecture)>init_term_dyn.o
171		;
172	HAIKU_LIBRARY_END_GLUE_CODE_$(architecture) =
173		<$(architecture)>crtendS.o
174		<src!system!glue!arch!$(cpu)!$(architecture)>crtn.o
175		;
176	HAIKU_EXECUTABLE_BEGIN_GLUE_CODE_$(architecture) =
177		<src!system!glue!arch!$(cpu)!$(architecture)>crti.o
178		<$(architecture)>crtbeginS.o
179		<src!system!glue!$(architecture)>start_dyn.o
180		<src!system!glue!$(architecture)>init_term_dyn.o
181		;
182	HAIKU_EXECUTABLE_END_GLUE_CODE_$(architecture)
183		= $(HAIKU_LIBRARY_END_GLUE_CODE_$(architecture)) ;
184
185	SEARCH on <$(architecture)>crtbeginS.o <$(architecture)>crtendS.o
186		= $(HAIKU_GCC_LIB_DIR_$(architecture)) ;
187
188	# init library name map
189	local libraryGrist = "" ;
190	if $(architecture) != $(HAIKU_PACKAGING_ARCHS[1]) {
191		libraryGrist = $(architecture) ;
192	}
193	local i ;
194	for i in be bnetapi debug device game locale mail media midi midi2
195			network package root screensaver textencoding tracker
196			translation z {
197		local library = lib$(i).so ;
198		HAIKU_LIBRARY_NAME_MAP_$(architecture)_$(i)
199			= $(library:G=$(libraryGrist)) ;
200	}
201	HAIKU_LIBRARY_NAME_MAP_$(architecture)_localestub
202		= <$(architecture)>liblocalestub.a ;
203	HAIKU_LIBRARY_NAME_MAP_$(architecture)_shared
204		= <$(architecture)>libshared.a ;
205	if $(architecture) = $(HAIKU_PACKAGING_ARCHS[1]) {
206		HAIKU_LIBRARY_NAME_MAP_$(architecture)_input_server
207			= <nogrist>input_server ;
208	} else {
209		HAIKU_LIBRARY_NAME_MAP_$(architecture)_input_server
210			= <$(architecture)>input_server ;
211	}
212}
213
214
215rule KernelArchitectureSetup architecture
216{
217	# KernelArchitectureSetup <architecture> ;
218	#
219	# Initializes the global kernel and boot loader related variables. Those
220	# don't have a packaging architecture suffix, since they are only set for
221	# the primary packaging architecture. <architecture> is the primary
222	# packaging architecture (supplied for convenience).
223
224	HAIKU_KERNEL_ARCH = $(HAIKU_ARCH) ;
225
226	local gccVersion = $(HAIKU_GCC_VERSION_$(architecture)) ;
227	local cpu = $(HAIKU_CPU_$(architecture)) ;
228
229	switch $(cpu) {
230		case ppc :
231			HAIKU_KERNEL_PLATFORM ?= openfirmware ;
232			HAIKU_BOOT_TARGETS += openfirmware ;
233
234			HAIKU_BOOT_FLOPPY_IMAGE_SIZE = 1440 ; # in kB
235			# offset in floppy image (>= sizeof(haiku_loader))
236			HAIKU_BOOT_ARCHIVE_IMAGE_OFFSET = 384 ; # in kB
237
238		case sparc :
239			HAIKU_KERNEL_PLATFORM ?= openfirmware ;
240			HAIKU_BOOT_TARGETS += openfirmware ;
241
242			HAIKU_BOOT_FLOPPY_IMAGE_SIZE = 1440 ; # in kB
243			# offset in floppy image (>= sizeof(haiku_loader))
244			HAIKU_BOOT_ARCHIVE_IMAGE_OFFSET = 384 ; # in kB
245
246		case arm :
247			HAIKU_KERNEL_PLATFORM ?= u-boot ;
248			HAIKU_BOOT_TARGETS += u-boot ;
249
250			HAIKU_BOOT_SDIMAGE_SIZE ?= 32 ;
251			# SOC's like allwinner need an offset to skip the hardcoded initial loader
252			HAIKU_BOOT_SDIMAGE_BEGIN = 40950 ; # 512-byte sectors (divisible by 63)
253
254			HAIKU_BOOT_FLOPPY_IMAGE_SIZE = 1440 ;
255			# offset in floppy image (>= sizeof(haiku_loader))
256			HAIKU_BOOT_ARCHIVE_IMAGE_OFFSET = 192 ; # in kB - unused yet
257			HAIKU_BOOT_LOADER_BASE ?= 0x1000000 ;
258
259			# Modern u-boot fill in sane addresses for us.
260			# Leverage the built-in fdt dtb for this board, unless a custom dtb is specified in uEnv.txt
261			# We skip uEnv.txt on virtio due to an unknown lockup in qemu around it.
262			HAIKU_MMC_UBOOT_SCRIPT = "\
263				echo \"Haiku u-boot script entry\" \
264				test -e mmc 0 haiku_loader.ub && setenv media mmc \
265				test -e virtio 0 haiku_loader.ub && setenv media virtio \
266				test -e nvme 0 haiku_loader.ub && setenv media nvme \
267				env exists media && echo \"Found Haiku on ${media} 0!\" \
268				env exists media || echo \"ERROR: Unable to locate Haiku loader on any media!\" && exit \
269				test ${media} != virtio && test -e ${media} 0 uEnv.txt && fatload ${media} 0 ${scriptaddr} uEnv.txt && env import -t ${scriptaddr} ${filesize} \
270				echo \"Loading haiku_loader...\" \
271				fatload ${media} 0 ${kernel_addr_r} haiku_loader.ub \
272				echo \"Loading haiku_floppyboot...\" \
273				fatload ${media} 0 ${ramdisk_addr_r} haiku_floppyboot.ub \
274				env exists dtb && echo \"Loading DTB...\" && fatload ${media} 0 ${fdt_addr_r} ${dtb} && fdt addr ${fdt_addr_r} && bootm ${kernel_addr_r} ${ramdisk_addr_r} ${fdt_addr_r} \
275				echo \"Booting Haiku!\" \
276				fdt addr ${fdtcontroladdr} && bootm ${kernel_addr_r} ${ramdisk_addr_r} ${fdtcontroladdr}" ;
277
278		case arm64 :
279			HAIKU_KERNEL_PLATFORM ?= efi ;
280
281			HAIKU_BOOT_SDIMAGE_SIZE ?= 32 ;
282			# SOC's like allwinner need an offset to skip the hardcoded initial loader
283			HAIKU_BOOT_SDIMAGE_BEGIN = 40950 ; # 512-byte sectors (divisible by 63)
284
285			HAIKU_BOOT_FLOPPY_IMAGE_SIZE = 1440 ;
286			# offset in floppy image (>= sizeof(haiku_loader))
287			HAIKU_BOOT_ARCHIVE_IMAGE_OFFSET = 192 ; # in kB - unused yet
288			HAIKU_BOOT_LOADER_BASE ?= 0x1000000 ;
289
290		case x86 :
291			HAIKU_KERNEL_PLATFORM ?= bios_ia32 ;
292			HAIKU_BOOT_TARGETS += bios_ia32 pxe_ia32 ;
293			HAIKU_ANYBOOT_LEGACY = 1 ;
294
295			HAIKU_BOOT_FLOPPY_IMAGE_SIZE = 2880 ; # in kB
296			# offset in floppy image (>= sizeof(haiku_loader))
297			HAIKU_BOOT_ARCHIVE_IMAGE_OFFSET = 320 ; # in kB
298
299			# nasm is required for target arch x86
300			if ! $(HAIKU_NASM) {
301				Exit "HAIKU_NASM not set. Please re-run configure." ;
302			}
303
304		case riscv64 :
305			HAIKU_KERNEL_PLATFORM ?= efi ;
306			HAIKU_BOOT_TARGETS += efi ;
307
308			HAIKU_BOOT_SDIMAGE_SIZE ?= 128 ;
309			# SOC's like allwinner need an offset to skip the hardcoded initial loader
310			HAIKU_BOOT_SDIMAGE_BEGIN = 40950 ; # 512-byte sectors (divisible by 63)
311
312			HAIKU_BOOT_FLOPPY_IMAGE_SIZE = 1440 ;
313			# offset in floppy image (>= sizeof(haiku_loader))
314			HAIKU_BOOT_ARCHIVE_IMAGE_OFFSET = 192 ; # in kB - unused yet
315			HAIKU_BOOT_LOADER_BASE ?= 0x1000000 ;
316
317		case x86_64 :
318			# x86_64 completely shares the x86 bootloader for MBR.
319			HAIKU_KERNEL_PLATFORM ?= bios_ia32 ;
320			HAIKU_BOOT_TARGETS += bios_ia32 efi pxe_ia32 ;
321
322			HAIKU_BOOT_FLOPPY_IMAGE_SIZE = 2880 ; # in kB
323			# offset in floppy image (>= sizeof(haiku_loader))
324			HAIKU_BOOT_ARCHIVE_IMAGE_OFFSET = 320 ; # in kB
325
326			# x86_64 kernel source is under arch/x86.
327			HAIKU_KERNEL_ARCH = x86 ;
328
329			# nasm is required for target arch x86_64
330			if ! $(HAIKU_NASM) {
331				Exit "HAIKU_NASM not set. Please re-run configure." ;
332			}
333
334		case m68k :
335			HAIKU_KERNEL_PLATFORM ?= atari_m68k ;
336			HAIKU_BOOT_TARGETS += amiga_m68k atari_m68k ;
337			switch $(HAIKU_KERNEL_PLATFORM) {
338				case atari_m68k :
339				{
340					HAIKU_BOOT_FLOPPY_IMAGE_SIZE = 1440 ; # in kB
341				}
342				case amiga_m68k :
343				{
344					# for now we have trouble reading from double-sided images
345					HAIKU_BOOT_FLOPPY_IMAGE_SIZE = 880 ; # in kB
346				}
347			}
348			# offset in floppy image (>= sizeof(haiku_loader))
349			HAIKU_BOOT_ARCHIVE_IMAGE_OFFSET = 260 ; # in kB
350			HAIKU_CONTAINER_STRIP_EXECUTABLES on
351				$(HAIKU_FLOPPY_BOOT_IMAGE_CONTAINER_NAME) = 1 ;
352
353		case * :
354			Exit "Currently unsupported target CPU:" $(cpu) ;
355	}
356
357	# private kernel headers to be used when compiling kernel code
358	HAIKU_PRIVATE_KERNEL_HEADERS =
359		[ PrivateHeaders $(DOT) kernel libroot shared
360			kernel/boot/platform/$(HAIKU_KERNEL_PLATFORM) ]
361		[ ArchHeaders $(HAIKU_KERNEL_ARCH) ]
362		[ FDirName $(HAIKU_COMMON_DEBUG_OBJECT_DIR_$(architecture)) system
363			kernel ]
364		$(HAIKU_PRIVATE_SYSTEM_HEADERS_$(architecture))
365		;
366
367	# C/C++ flags
368	local ccBaseFlags = -finline -fno-builtin ;
369
370	if $(gccVersion[1]) >= 4 {
371		if $(HAIKU_CC_IS_CLANG_$(architecture)) != 1 {
372			# Clang does not yet understand this flag.
373			ccBaseFlags += -fno-semantic-interposition ;
374		}
375
376		ccBaseFlags += -ffreestanding ;
377	}
378
379	local c++BaseFlags = $(ccBaseFlags) -fno-exceptions ;
380
381	if $(gccVersion[1]) >= 3 && $(HAIKU_CC_IS_CLANG_$(architecture)) != 1 {
382		c++BaseFlags += -fno-use-cxa-atexit ;
383	}
384
385	HAIKU_KERNEL_CCFLAGS = $(HAIKU_CCFLAGS_$(architecture)) $(ccBaseFlags) ;
386	HAIKU_KERNEL_C++FLAGS = $(HAIKU_C++FLAGS_$(architecture)) $(c++BaseFlags) ;
387	HAIKU_KERNEL_PIC_CCFLAGS = ;
388	HAIKU_KERNEL_PIC_LINKFLAGS = ;
389	HAIKU_KERNEL_ADDON_LINKFLAGS = ;
390
391	# Common boot-related cflags which apply to all loaders
392	HAIKU_BOOT_CCFLAGS = $(HAIKU_CCFLAGS_$(architecture)) $(ccBaseFlags) ;
393	HAIKU_BOOT_C++FLAGS = $(HAIKU_C++FLAGS_$(architecture)) $(c++BaseFlags) ;
394	HAIKU_BOOT_LINKFLAGS = ;
395	HAIKU_BOOT_LDFLAGS = -Bstatic ;
396
397	# Remove -fPIC and other unwanted options from the BOOT flags (they are sometimes
398	# added to force PIC in general.)
399	local fixedBootCCFlags ;
400	local fixedBootC++Flags ;
401	for flag in $(HAIKU_BOOT_CCFLAGS) {
402		if $(flag) = "-fpic" || $(flag) = "-fPIC" {
403			continue ;
404		}
405		fixedBootCCFlags += $(flag) ;
406	}
407	for flag in $(HAIKU_BOOT_C++FLAGS) {
408		if $(flag) = "-fpic" || $(flag) = "-fPIC" {
409			continue ;
410		}
411		fixedBootC++Flags += $(flag) ;
412	}
413	HAIKU_BOOT_CCFLAGS = $(fixedBootCCFlags) ;
414	HAIKU_BOOT_C++FLAGS = $(fixedBootC++Flags) ;
415
416	# Any special kernel base addresses
417	if $(HAIKU_BOOT_LOADER_BASE) {
418		HAIKU_BOOT_LDFLAGS +=
419			--defsym BOOT_LOADER_BASE=$(HAIKU_BOOT_LOADER_BASE) ;
420	}
421
422	switch $(cpu) {
423		case arm :
424			# Workaround for ld using 32k for alignment despite forcing it in the config...
425			# should definitely not be needed!
426			HAIKU_KERNEL_LINKFLAGS +=
427				-Wl,-z -Wl,max-page-size=0x1000
428				-Wl,-z -Wl,common-page-size=0x1000 ;
429
430		case arm64 :
431			# Workaround for ld using 32k for alignment despite forcing it in the config...
432			# should definitely not be needed!
433			HAIKU_KERNEL_LINKFLAGS +=
434				-Wl,-z -Wl,max-page-size=0x1000
435				-Wl,-z -Wl,common-page-size=0x1000 ;
436
437			HAIKU_KERNEL_PIC_CCFLAGS = -fPIC ;
438			HAIKU_KERNEL_PIC_LINKFLAGS = -shared -fPIC ;
439
440		case ppc :
441			# Build a position independent PPC kernel. We need to be able to
442			# relocate the kernel, since the virtual address space layout at
443			# boot time is not fixed.
444			HAIKU_KERNEL_PIC_CCFLAGS = -fPIE ;
445			HAIKU_KERNEL_PIC_LINKFLAGS = -shared -fPIE ;
446
447		case m68k :
448			# We don't want to have to handle emulating missing FPU opcodes for
449			# 040 and 060 in the kernel.
450			HAIKU_KERNEL_CCFLAGS += -mtune=68020-60 ;
451			HAIKU_KERNEL_C++FLAGS += -mtune=68020-60 ;
452
453		case riscv64 :
454			# Kernel lives within any single 2 GiB address space.
455			# Default is medlow (-2GiB / +2GiB)
456			HAIKU_KERNEL_CCFLAGS += -mcmodel=medany ;
457			HAIKU_KERNEL_C++FLAGS += -mcmodel=medany ;
458
459		case x86 :
460			HAIKU_KERNEL_PIC_CCFLAGS = -fno-pic ;
461			HAIKU_KERNEL_CCFLAGS += -march=pentium ;
462			HAIKU_KERNEL_C++FLAGS += -march=pentium ;
463
464		case x86_64 :
465			# Kernel lives in the top 2GB of the address space, use kernel code
466			# model.
467			HAIKU_KERNEL_PIC_CCFLAGS = -fno-pic -mcmodel=kernel ;
468
469			# Disable the red zone, which cannot be used in kernel code due to
470			# interrupts, and always enable the frame pointer so stack traces
471			# are correct.
472			HAIKU_KERNEL_CCFLAGS += -mno-red-zone -fno-omit-frame-pointer ;
473			HAIKU_KERNEL_C++FLAGS += -mno-red-zone -fno-omit-frame-pointer ;
474			HAIKU_KERNEL_PIC_LINKFLAGS += -z max-page-size=0x1000 ;
475			HAIKU_KERNEL_ADDON_LINKFLAGS += -z max-page-size=0x1000 ;
476
477			if x86 in $(HAIKU_ARCHS[2-]) || x86_gcc2 in $(HAIKU_ARCHS[2-]) {
478				Echo "Enable kernel ia32 compatibility" ;
479				HAIKU_KERNEL_DEFINES += _COMPAT_MODE ;
480				HAIKU_KERNEL_COMPAT_MODE = 1 ;
481			}
482	}
483
484	# bootloader-centric flags
485	local bootTarget ;
486	for bootTarget in $(HAIKU_BOOT_TARGETS) {
487		switch $(bootTarget) {
488			case efi :
489				# efi bootloader is PIC
490				HAIKU_BOOT_$(bootTarget:U)_CCFLAGS += -fpic -fno-stack-protector
491					-fPIC -fshort-wchar -Wno-error=unused-variable -Wno-error=main ;
492				HAIKU_BOOT_$(bootTarget:U)_C++FLAGS += -fpic -fno-stack-protector
493					-fPIC -fshort-wchar -Wno-error=unused-variable -Wno-error=main ;
494				switch $(cpu) {
495					case x86 :
496						if $(HAIKU_CC_IS_CLANG_$(architecture)) != 1 {
497							HAIKU_BOOT_$(bootTarget:U)_CCFLAGS += -maccumulate-outgoing-args ;
498							HAIKU_BOOT_$(bootTarget:U)_C++FLAGS += -maccumulate-outgoing-args ;
499						}
500					case x86_64 :
501						HAIKU_BOOT_$(bootTarget:U)_CCFLAGS += -mno-red-zone ;
502						HAIKU_BOOT_$(bootTarget:U)_C++FLAGS += -mno-red-zone ;
503						if $(HAIKU_CC_IS_CLANG_$(architecture)) != 1 {
504							HAIKU_BOOT_$(bootTarget:U)_CCFLAGS += -maccumulate-outgoing-args ;
505							HAIKU_BOOT_$(bootTarget:U)_C++FLAGS += -maccumulate-outgoing-args ;
506						}
507				}
508				HAIKU_BOOT_$(bootTarget:U)_LDFLAGS = -Bstatic -Bsymbolic
509					-nostdlib -znocombreloc -no-undefined ;
510			case bios_ia32 :
511				# bios_ia32 is non-PIC
512				HAIKU_BOOT_$(bootTarget:U)_CCFLAGS += -fno-pic -march=pentium ;
513				HAIKU_BOOT_$(bootTarget:U)_C++FLAGS += -fno-pic -march=pentium ;
514				if $(HAIKU_CC_IS_CLANG_$(architecture)) = 1 {
515					HAIKU_BOOT_$(bootTarget:U)_LDFLAGS += -m elf_i386 ;
516				} else {
517					HAIKU_BOOT_$(bootTarget:U)_LDFLAGS += -m elf_i386_haiku ;
518				}
519				if $(gccVersion[1]) >= 3 {
520					HAIKU_BOOT_$(bootTarget:U)_CCFLAGS += -Wno-error=main -m32 ;
521					HAIKU_BOOT_$(bootTarget:U)_C++FLAGS += -Wno-error=main -m32 ;
522				}
523			case pxe_ia32 :
524				# pxe_ia32 is non-PIC
525				HAIKU_BOOT_$(bootTarget:U)_CCFLAGS += -fno-pic -march=pentium ;
526				HAIKU_BOOT_$(bootTarget:U)_C++FLAGS += -fno-pic -march=pentium ;
527				if $(HAIKU_CC_IS_CLANG_$(architecture)) = 1 {
528					HAIKU_BOOT_$(bootTarget:U)_LDFLAGS += -m elf_i386 ;
529				} else {
530					HAIKU_BOOT_$(bootTarget:U)_LDFLAGS += -m elf_i386_haiku ;
531				}
532				if $(gccVersion[1]) >= 3 {
533					HAIKU_BOOT_$(bootTarget:U)_CCFLAGS += -Wno-error=main -m32 ;
534					HAIKU_BOOT_$(bootTarget:U)_C++FLAGS += -Wno-error=main -m32 ;
535				}
536			case * :
537				# all other bootloaders are non-PIC
538				HAIKU_BOOT_$(bootTarget:U)_CCFLAGS += -fno-pic -Wno-error=main ;
539				HAIKU_BOOT_$(bootTarget:U)_C++FLAGS += -fno-pic -Wno-error=main ;
540		}
541	}
542
543	# warning flags
544	HAIKU_KERNEL_WARNING_CCFLAGS = $(HAIKU_WARNING_CCFLAGS_$(architecture)) ;
545	HAIKU_KERNEL_WARNING_C++FLAGS = $(HAIKU_WARNING_C++FLAGS_$(architecture)) ;
546
547	# debug flags
548	local level ;
549	for level in $(HAIKU_DEBUG_LEVELS) {
550		local flags = $(HAIKU_DEBUG_FLAGS) [ FDefines DEBUG=$(level) ] ;
551		HAIKU_KERNEL_DEBUG_$(level)_CCFLAGS
552			= $(HAIKU_DEBUG_$(level)_CCFLAGS_$(architecture)) ;
553		HAIKU_KERNEL_DEBUG_$(level)_C++FLAGS
554			= $(HAIKU_DEBUG_$(level)_C++FLAGS_$(architecture)) ;
555	}
556
557	# defines
558	HAIKU_KERNEL_DEFINES += _KERNEL_MODE ;
559
560	HAIKU_DEFINES_$(architecture)
561		+= BOOT_ARCHIVE_IMAGE_OFFSET=$(HAIKU_BOOT_ARCHIVE_IMAGE_OFFSET) ;
562		# TODO: That doesn't need to be a general define. It's just needed for
563		# compiling (part of) the boot loader.
564
565	# kernel add-on glue code
566	HAIKU_KERNEL_ADDON_BEGIN_GLUE_CODE = <$(architecture)>crtbeginS.o
567		<src!system!glue!$(architecture)>haiku_version_glue.o ;
568	HAIKU_KERNEL_ADDON_END_GLUE_CODE = <$(architecture)>crtendS.o ;
569}
570
571
572rule ArchitectureSetupWarnings architecture
573{
574	# ArchitectureSetupWarnings <architecture> ;
575	#
576	# Sets up compiler warnings and error flags for various subdirectories for
577	# the given packaging architecture.
578
579	if $(HAIKU_CC_IS_CLANG_$(architecture)) = 1 {
580		AppendToConfigVar CCFLAGS :
581			HAIKU_TOP src system libroot posix glibc :
582			-fgnu89-inline -fheinous-gnu-extensions : global ;
583	}
584
585	local cpu = $(HAIKU_CPU_$(architecture)) ;
586	switch $(cpu) {
587		case arm :
588			return ;
589				# we use #warning as placeholders for things to write...
590		case m68k :
591			return ;
592				# we use #warning as placeholders for things to write...
593		case ppc :
594			return ;
595				# we use #warning as placeholders for things to write...
596	}
597
598	# enable -Werror for certain parts of the source tree
599	HAIKU_WERROR_ARCH = $(architecture) ;
600
601	rule EnableWerror dirTokens : scope {
602		# Clang gives way more warnings than GCC, so that code won't compile
603		# with -Werror when using Clang.
604		if $(HAIKU_CC_IS_CLANG_$(architecture)) != 1 {
605			SetConfigVar WARNINGS : HAIKU_TOP $(dirTokens) : treatAsErrors
606				: $(scope) ;
607		}
608	}
609
610	# Work-around for GCC 2 problem -- despite -Wno-multichar it reports
611	# multichar warnings in headers/private/kernel/debugger_keymaps.h included
612	# by src/system/kernel/arch/x86/arch_debug_console.cpp.
613	local gccVersion = $(HAIKU_GCC_VERSION_$(architecture)) ;
614	if $(gccVersion[1]) = 2 {
615		local file = <src!system!kernel!arch!x86>arch_debug_console.o ;
616		WARNINGS on $(file) = $(WARNINGS) ;
617	}
618
619	EnableWerror src add-ons accelerants ;
620	EnableWerror src add-ons bluetooth ;
621	EnableWerror src add-ons decorators ;
622	EnableWerror src add-ons disk_systems ;
623	EnableWerror src add-ons input_server devices ;
624	EnableWerror src add-ons input_server filters ;
625#	EnableWerror src add-ons input_server methods pen ;
626	EnableWerror src add-ons input_server methods t9 ;
627	EnableWerror src add-ons kernel bluetooth ;
628	EnableWerror src add-ons kernel bus_managers acpi ;
629	EnableWerror src add-ons kernel bus_managers agp_gart ;
630	EnableWerror src add-ons kernel bus_managers ata ;
631	EnableWerror src add-ons kernel bus_managers config_manager ;
632#	EnableWerror src add-ons kernel bus_managers firewire ;
633	EnableWerror src add-ons kernel bus_managers ide ;
634	EnableWerror src add-ons kernel bus_managers isa ;
635	EnableWerror src add-ons kernel bus_managers pci ;
636	EnableWerror src add-ons kernel bus_managers ps2 ;
637	EnableWerror src add-ons kernel bus_managers random ;
638	EnableWerror src add-ons kernel bus_managers scsi ;
639	EnableWerror src add-ons kernel bus_managers tty ;
640	EnableWerror src add-ons kernel bus_managers usb ;
641	EnableWerror src add-ons kernel bus_managers virtio ;
642	EnableWerror src add-ons kernel busses agp_gart ;
643	EnableWerror src add-ons kernel busses ata ;
644	EnableWerror src add-ons kernel busses scsi ;
645	EnableWerror src add-ons kernel busses usb ;
646	EnableWerror src add-ons kernel console ;
647	EnableWerror src add-ons kernel cpu ;
648#	EnableWerror src add-ons kernel debugger ; # gcc2
649#	EnableWerror src add-ons kernel drivers audio ;
650	EnableWerror src add-ons kernel drivers bluetooth ;
651#	EnableWerror src add-ons kernel drivers bus ;
652	EnableWerror src add-ons kernel drivers common ;
653#	EnableWerror src add-ons kernel drivers disk ;
654	EnableWerror src add-ons kernel drivers dvb ;
655#	EnableWerror src add-ons kernel drivers graphics ;
656	EnableWerror src add-ons kernel drivers graphics intel_extreme ;
657#	EnableWerror src add-ons kernel drivers input ;
658	EnableWerror src add-ons kernel drivers joystick ;
659	EnableWerror src add-ons kernel drivers midi ;
660	EnableWerror src add-ons kernel drivers misc ;
661#	EnableWerror src add-ons kernel drivers network ;
662	EnableWerror src add-ons kernel drivers ports ;
663#	EnableWerror src add-ons kernel drivers power ;
664	EnableWerror src add-ons kernel drivers printer ;
665	EnableWerror src add-ons kernel drivers random ;
666	EnableWerror src add-ons kernel drivers tty ;
667	EnableWerror src add-ons kernel drivers video ;
668	EnableWerror src add-ons kernel file_systems bfs ;
669	EnableWerror src add-ons kernel file_systems cdda ;
670#	EnableWerror src add-ons kernel file_systems ext2 ;
671#	EnableWerror src add-ons kernel file_systems fat ;
672#	EnableWerror src add-ons kernel file_systems googlefs ;
673	EnableWerror src add-ons kernel file_systems iso9660 ;
674	EnableWerror src add-ons kernel file_systems layers ;
675#	EnableWerror src add-ons kernel file_systems netfs ;
676#	EnableWerror src add-ons kernel file_systems nfs ;
677	EnableWerror src add-ons kernel file_systems nfs4 ;
678#	EnableWerror src add-ons kernel file_systems ntfs ;
679	EnableWerror src add-ons kernel file_systems packagefs ;
680#	EnableWerror src add-ons kernel file_systems ramfs ;
681#	EnableWerror src add-ons kernel file_systems reiserfs ;
682	EnableWerror src add-ons kernel file_systems udf ;
683	EnableWerror src add-ons kernel file_systems userlandfs ;
684	EnableWerror src add-ons kernel generic ;
685#	EnableWerror src add-ons kernel network datalink_protocols ;
686	EnableWerror src add-ons kernel network devices ;
687	EnableWerror src add-ons kernel network dns_resolver ;
688	EnableWerror src add-ons kernel network notifications ;
689	EnableWerror src add-ons kernel network ppp ;
690	EnableWerror src add-ons kernel network protocols ;
691#	EnableWerror src add-ons kernel network stack ;
692	EnableWerror src add-ons kernel partitioning_systems ;
693	EnableWerror src add-ons kernel power ;
694	EnableWerror src add-ons locale ;
695	EnableWerror src add-ons mail_daemon ;
696	EnableWerror src add-ons media media-add-ons demultiplexer ;
697	EnableWerror src add-ons media media-add-ons dvb ;
698	EnableWerror src add-ons media media-add-ons esound_sink ;
699	EnableWerror src add-ons media media-add-ons finepix_webcam ;
700	EnableWerror src add-ons media media-add-ons firewire_dv ;
701	EnableWerror src add-ons media media-add-ons legacy ;
702	EnableWerror src add-ons media media-add-ons mixer ;
703	EnableWerror src add-ons media media-add-ons multi_audio ;
704	EnableWerror src add-ons media media-add-ons opensound ;
705	EnableWerror src add-ons media media-add-ons radeon ;
706	EnableWerror src add-ons media media-add-ons reader ;
707	EnableWerror src add-ons media media-add-ons tone_producer_demo ;
708	EnableWerror src add-ons media media-add-ons usb_vision ;
709#	EnableWerror src add-ons media media-add-ons usb_webcam ;
710	EnableWerror src add-ons media media-add-ons video_mixer ;
711#	EnableWerror src add-ons media media-add-ons video_producer_demo ;
712	EnableWerror src add-ons media media-add-ons videowindow ;
713	EnableWerror src add-ons media media-add-ons writer ;
714	EnableWerror src add-ons media plugins ape_reader ;
715	EnableWerror src add-ons media plugins au_reader ;
716#	EnableWerror src add-ons media plugins ffmpeg ;
717#	EnableWerror src add-ons media plugins raw_decoder ;
718	EnableWerror src add-ons print ;
719	EnableWerror src add-ons screen_savers ;
720	EnableWerror src add-ons tracker ;
721	EnableWerror src add-ons translators bmp ;
722	EnableWerror src add-ons translators exr ;
723	EnableWerror src add-ons translators gif ;
724	EnableWerror src add-ons translators hvif ;
725	EnableWerror src add-ons translators ico ;
726	EnableWerror src add-ons translators jpeg ;
727#	EnableWerror src add-ons translators jpeg2000 ;
728	EnableWerror src add-ons translators pcx ;
729	EnableWerror src add-ons translators png ;
730	EnableWerror src add-ons translators ppm ;
731	EnableWerror src add-ons translators raw ;
732	EnableWerror src add-ons translators rtf ;
733	EnableWerror src add-ons translators sgi ;
734	EnableWerror src add-ons translators shared ;
735	EnableWerror src add-ons translators stxt ;
736	EnableWerror src add-ons translators tga ;
737	EnableWerror src add-ons translators tiff ;
738	EnableWerror src add-ons translators wonderbrush ;
739	EnableWerror src add-ons print ;
740	EnableWerror src bin desklink ;
741	EnableWerror src bin multiuser ;
742	EnableWerror src bin package ;
743	EnableWerror src bin package_repo ;
744	EnableWerror src bin pkgman ;
745	EnableWerror src libs bsd ;
746	EnableWerror src apps ;
747	EnableWerror src kits ;
748	EnableWerror src preferences ;
749	EnableWerror src servers ;
750	EnableWerror src system boot ;
751	EnableWerror src system kernel ;
752	EnableWerror src system libroot add-ons ;
753	EnableWerror src system libroot os ;
754	EnableWerror src system libroot posix locale ;
755	EnableWerror src system libroot posix wchar ;
756	EnableWerror src system runtime_loader ;
757}
758
759
760rule MultiArchIfPrimary ifValue : elseValue : architecture
761{
762	# MultiArchIfPrimary <ifValue> : <elseValue>
763	#	[ : <architecture> = $(TARGET_PACKAGING_ARCH) ] ;
764	#
765	# Returns one of the two given values depending on whether
766	# <architecture> is the primary packaging architecture.
767
768	architecture ?= $(TARGET_PACKAGING_ARCH) ;
769
770	if $(architecture) = $(TARGET_PACKAGING_ARCHS[1]) {
771		return $(ifValue) ;
772	}
773	return $(elseValue) ;
774}
775
776
777rule MultiArchConditionalGristFiles files : primaryGrist : secondaryGrist
778	: architecture
779{
780	# MultiArchConditionalGristFiles <files> : <primaryGrist>
781	#	: <secondaryGrist> [ : <architecture> = $(TARGET_PACKAGING_ARCH) ] ;
782	#
783	# Returns <files> with their grist set to either <primaryGrist> or
784	# <secondaryGrist> depending on whether <architecture> is the primary
785	# packaging architecture.
786
787	architecture ?= $(TARGET_PACKAGING_ARCH) ;
788
789	local grist = [ MultiArchIfPrimary $(primaryGrist) : $(secondaryGrist)
790		: $(architecture) ] ;
791	return $(files:G=$(grist:E=)) ;
792}
793
794
795rule MultiArchDefaultGristFiles files : gristPrefix : architecture
796{
797	# MultiArchDefaultGristFiles <files> : <gristPrefix>
798	#	[ : <architecture> = $(TARGET_PACKAGING_ARCH) ] ;
799	#
800	# Convenient shorthand for MultiArchConditionalGristFiles for the common
801	# case that for a secondary packaging architecture the packaging
802	# architecture name shall be appended to the grist while it shall be omitted
803	# for the primary packaging architecture. IOW, if architecture is the
804	# primary packaging architecture, <files> are returned with their grist set
805	# to <gristPrefix>, otherwise <files> are returned with their grist set to
806	# <gristPrefix>!<architecture> respectively <architecture> (if <gristPrefix>
807	# is empty).
808
809	architecture ?= $(TARGET_PACKAGING_ARCH) ;
810
811	local secondaryGrist = $(gristPrefix)!$(architecture) ;
812	secondaryGrist ?= $(architecture) ;
813
814	return [ MultiArchConditionalGristFiles $(files) : $(gristPrefix) :
815		$(secondaryGrist) : $(architecture) ] ;
816}
817
818
819rule MultiArchSubDirSetup architectures
820{
821	# MultiArchSubDirSetup <architectures> ;
822	#
823	# For each of the given packaging architectures <architectures> that are
824	# in the packaging architectures configured for the build (or all configured
825	# packaging architectures, if <architectures> is empty) an object is
826	# prepared that can be used for an "on ... { ... }" block to set up subdir
827	# variables for the respective packaging architecture. Most notably
828	# TARGET_PACKAGING_ARCH, TARGET_ARCH are set to the values for the
829	# respective packaging architecture. The per-subdir variables SOURCE_GRIST,
830	# LOCATE_TARGET, LOCATE_SOURCE, SEARCH_SOURCE, *_LOCATE_TARGET, are reset.
831	# All SUBDIR* and config variables are set to the values they had when this
832	# rule was invoked.
833
834	local result ;
835	architectures ?= $(TARGET_PACKAGING_ARCHS) ;
836	local architecture ;
837	for architecture in $(architectures) {
838		if ! $(architecture) in $(TARGET_PACKAGING_ARCHS) {
839			continue ;
840		}
841
842		local architectureObject = $(architecture:G=<arch-object>) ;
843		result += $(architectureObject) ;
844
845		# Set the variables that default to the values of the respective
846		# variables for the primary architecture.
847		TARGET_PACKAGING_ARCH on $(architectureObject) = $(architecture) ;
848
849		local var ;
850		for var in TARGET_ARCH {
851			$(var) on $(architectureObject) = $($(var)_$(architecture)) ;
852		}
853
854		# Clone the current config variable values and the variables SubDir
855		# resets.
856		for var in $(AUTO_SET_UP_CONFIG_VARIABLES) SUBDIR$(SUBDIRRESET) {
857			$(var) on $(architectureObject) = $($(var)) ;
858		}
859
860		# adjust SOURCE_GRIST and HDRGRIST
861		SOURCE_GRIST on $(architectureObject)
862			= $(SOURCE_GRIST:E=)!$(architecture) ;
863
864		HDRGRIST on $(architectureObject)
865			= $(HDRGRIST:E=)!$(architecture) ;
866
867		# Adjust the subdir's object dirs that are architecture dependent. To
868		# avoid duplicating the code from SetupObjectsDir, we call it. Since it
869		# sets global variables, we set these variables on our object, call
870		# SetupObjectsDir in an "on" block, and grab the new variable values.
871		local hostTarget = HOST TARGET ;
872		local objectDirVars =
873			COMMON_ARCH COMMON_DEBUG DEBUG_$(HAIKU_DEBUG_LEVELS)
874			;
875		objectDirVars =
876			COMMON_PLATFORM_LOCATE_TARGET
877			$(hostTarget)_$(objectDirVars)_LOCATE_TARGET
878			LOCATE_TARGET
879			LOCATE_SOURCE
880			SEARCH_SOURCE
881			;
882
883		for var in $(objectDirVars) {
884			$(var) on $(architectureObject) = ;
885		}
886
887		on $(architectureObject) {
888			SetupObjectsDir ;
889
890			for var in $(objectDirVars) {
891				$(var) on $(architectureObject) = $($(var)) ;
892			}
893		}
894	}
895
896	return $(result) ;
897}
898