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