X-Git-Url: https://git.saurik.com/apple/xnu.git/blobdiff_plain/3e170ce000f1506b7b5d2c5c7faec85ceabb573d..cb3231590a3c94ab4375e2228bd5e86b0cf1ad7e:/makedefs/MakeInc.def diff --git a/makedefs/MakeInc.def b/makedefs/MakeInc.def index ae513f193..a1030c34a 100644 --- a/makedefs/MakeInc.def +++ b/makedefs/MakeInc.def @@ -1,6 +1,6 @@ # -*- mode: makefile;-*- # -# Copyright (C) 1999-2014 Apple Inc. All rights reserved. +# Copyright (C) 1999-2019 Apple Inc. All rights reserved. # # MakeInc.def contains global definitions for building, # linking, and installing files. @@ -9,20 +9,23 @@ # # Architecture Configuration options # -SUPPORTED_ARCH_CONFIGS := X86_64 X86_64H +SUPPORTED_ARCH_CONFIGS := X86_64 X86_64H ARM ARM64 # -# Kernel Configuration options +# Kernel Configuration options # -SUPPORTED_KERNEL_CONFIGS = RELEASE DEVELOPMENT DEBUG PROFILE +SUPPORTED_KERNEL_CONFIGS = RELEASE DEVELOPMENT DEBUG PROFILE KASAN + # -# Machine Configuration options +# Machine Configuration options # SUPPORTED_X86_64_MACHINE_CONFIGS = NONE SUPPORTED_X86_64H_MACHINE_CONFIGS = NONE +SUPPORTED_ARM_MACHINE_CONFIGS = S7002 T8002 T8004 +SUPPORTED_ARM64_MACHINE_CONFIGS = T7000 T7001 S8000 S8001 T8010 T8011 BCM2837 # @@ -30,7 +33,7 @@ SUPPORTED_X86_64H_MACHINE_CONFIGS = NONE # ifndef CURRENT_ARCH_CONFIG_LC - export CURRENT_ARCH_CONFIG_LC := $(shell printf "%s" "$(CURRENT_ARCH_CONFIG)" | $(TR) A-Z a-z) + export CURRENT_ARCH_CONFIG_LC := $(shell printf "%s" "$(CURRENT_ARCH_CONFIG)" | $(TR) A-Z a-z) endif ifndef CURRENT_KERNEL_CONFIG_LC @@ -41,32 +44,54 @@ ifndef CURRENT_MACHINE_CONFIG_LC export CURRENT_MACHINE_CONFIG_LC := $(shell printf "%s" "$(CURRENT_MACHINE_CONFIG)" | $(TR) A-Z a-z) endif - # # Component List # -COMPONENT_LIST = osfmk bsd libkern iokit pexpert libsa security -COMPONENT = $(if $(word 2,$(subst /, ,$(RELATIVE_SOURCE_PATH))),$(word 2,$(subst /, ,$(RELATIVE_SOURCE_PATH))),$(firstword $(subst /, ,$(RELATIVE_SOURCE_PATH)))) -COMPONENT_IMPORT_LIST = $(filter-out $(COMPONENT),$(COMPONENT_LIST)) +COMPONENT_LIST = osfmk bsd libkern iokit pexpert libsa security san +COMPONENT = $(if $(word 2,$(subst /, ,$(RELATIVE_SOURCE_PATH))),$(word 2,$(subst /, ,$(RELATIVE_SOURCE_PATH))),$(firstword $(subst /, ,$(RELATIVE_SOURCE_PATH)))) +COMPONENT_IMPORT_LIST = $(filter-out $(COMPONENT),$(COMPONENT_LIST)) + +MACHINE_FLAGS_ARM64_T7000 = -DARM64_BOARD_CONFIG_T7000 +MACHINE_FLAGS_ARM64_T7001 = -DARM64_BOARD_CONFIG_T7001 +MACHINE_FLAGS_ARM_S7002 = -DARM_BOARD_CONFIG_S7002 +MACHINE_FLAGS_ARM64_S8000 = -DARM64_BOARD_CONFIG_S8000 +MACHINE_FLAGS_ARM64_S8001 = -DARM64_BOARD_CONFIG_S8001 +MACHINE_FLAGS_ARM_T8002 = -DARM_BOARD_CONFIG_T8002 +MACHINE_FLAGS_ARM_T8004 = -DARM_BOARD_CONFIG_T8004 +MACHINE_FLAGS_ARM64_T8010 = -DARM64_BOARD_CONFIG_T8010 -mcpu=hurricane +MACHINE_FLAGS_ARM64_T8011 = -DARM64_BOARD_CONFIG_T8011 -mcpu=hurricane +MACHINE_FLAGS_ARM64_BCM2837 = -DARM64_BOARD_CONFIG_BCM2837 # # Deployment target flag # ifeq ($(PLATFORM),MacOSX) - DEPLOYMENT_TARGET_FLAGS = -mmacosx-version-min=$(SDKVERSION) + DEPLOYMENT_TARGET_FLAGS = -mmacosx-version-min=$(SDKVERSION) -DXNU_TARGET_OS_OSX + DEPLOYMENT_LINKER_FLAGS = -Wl,-macosx_version_min,$(SDKVERSION) +else ifeq ($(PLATFORM),DriverKit) + DEPLOYMENT_TARGET_FLAGS = -target x86_64-apple-driverkit$(SDKVERSION) -DXNU_TARGET_OS_OSX + DEPLOYMENT_LINKER_FLAGS = -Wl,-target,x86_64-apple-driverkit$(SDKVERSION) else ifeq ($(PLATFORM),WatchOS) - DEPLOYMENT_TARGET_FLAGS = -mwatchos-version-min=$(SDKVERSION) + DEPLOYMENT_TARGET_FLAGS = -mwatchos-version-min=$(SDKVERSION) -DXNU_TARGET_OS_WATCH + DEPLOYMENT_LINKER_FLAGS = else ifeq ($(PLATFORM),tvOS) - DEPLOYMENT_TARGET_FLAGS = -mtvos-version-min=$(SDKVERSION) + DEPLOYMENT_TARGET_FLAGS = -mtvos-version-min=$(SDKVERSION) -DXNU_TARGET_OS_TV + DEPLOYMENT_LINKER_FLAGS = else ifeq ($(PLATFORM),AppleTVOS) - DEPLOYMENT_TARGET_FLAGS = -mtvos-version-min=$(SDKVERSION) + DEPLOYMENT_TARGET_FLAGS = -mtvos-version-min=$(SDKVERSION) -DXNU_TARGET_OS_TV +else ifeq ($(PLATFORM),BridgeOS) + DEPLOYMENT_TARGET_FLAGS = -mbridgeos-version-min=$(SDKVERSION) -DXNU_TARGET_OS_BRIDGE + DEPLOYMENT_LINKER_FLAGS = else ifneq ($(filter $(SUPPORTED_EMBEDDED_PLATFORMS),$(PLATFORM)),) - DEPLOYMENT_TARGET_FLAGS = -miphoneos-version-min=$(SDKVERSION) + DEPLOYMENT_TARGET_FLAGS = -miphoneos-version-min=$(SDKVERSION) -DXNU_TARGET_OS_IOS + DEPLOYMENT_LINKER_FLAGS = -Wl,-ios_version_min,$(SDKVERSION) else ifneq ($(filter $(SUPPORTED_SIMULATOR_PLATFORMS),$(PLATFORM)),) DEPLOYMENT_TARGET_FLAGS = + DEPLOYMENT_LINKER_FLAGS = else DEPLOYMENT_TARGET_FLAGS = + DEPLOYMENT_LINKER_FLAGS = endif DEPLOYMENT_TARGET_DEFINES = -DPLATFORM_$(PLATFORM) @@ -91,12 +116,57 @@ GENASSYM_KCC = $(CC) # Compiler warning flags # +USE_WERROR := 1 +ifneq ($(BUILD_WERROR),) +USE_WERROR := $(BUILD_WERROR) +endif + +ifeq ($(USE_WERROR),1) +WERROR := -Werror +endif + +# Shared C/C++ warning flags +# NOTE: order matters here. -Wno-xxx goes before opt-in of ones we want +WARNFLAGS_STD := \ + -Weverything \ + -Wno-pedantic \ + $(WERROR) \ + -Wno-implicit-int-conversion \ + -Wno-sign-conversion \ + -Wno-shorten-64-to-32 \ + -Wno-bad-function-cast \ + -Wno-c++-compat \ + -Wno-c++98-compat \ + -Wno-conditional-uninitialized \ + -Wno-covered-switch-default \ + -Wno-disabled-macro-expansion \ + -Wno-documentation-unknown-command \ + -Wno-extra-semi-stmt \ + -Wno-format-non-iso \ + -Wno-format-nonliteral \ + -Wno-language-extension-token \ + -Wno-missing-variable-declarations \ + -Wno-packed \ + -Wno-padded \ + -Wno-partial-availability \ + -Wno-reserved-id-macro \ + -Wno-shift-sign-overflow \ + -Wno-switch-enum \ + -Wno-undef \ + -Wno-unused-macros \ + -Wno-used-but-marked-unused \ + -Wno-variadic-macros \ + -Wno-vla \ + -Wno-zero-length-array + +WARNFLAGS_STD := $(WARNFLAGS_STD) \ + -Wno-unknown-warning-option \ + -Wno-error=atomic-implicit-seq-cst + CWARNFLAGS_STD = \ - -Wall -Werror -Wno-format-y2k -Wextra -Wstrict-prototypes \ - -Wmissing-prototypes -Wpointer-arith -Wreturn-type -Wcast-qual \ - -Wwrite-strings -Wswitch -Wshadow -Wcast-align -Wchar-subscripts \ - -Winline -Wnested-externs -Wredundant-decls -Wextra-tokens \ - -Wunreachable-code + $(WARNFLAGS_STD) + + # Can be overridden in Makefile.template or Makefile.$arch export CWARNFLAGS ?= $(CWARNFLAGS_STD) @@ -105,14 +175,16 @@ define add_perfile_cflags $(1)_CWARNFLAGS_ADD += $2 endef -CXXWARNFLAGS_STD = \ - -Wall -Werror -Wno-format-y2k -Wextra -Wpointer-arith -Wreturn-type \ - -Wcast-qual -Wwrite-strings -Wswitch -Wcast-align -Wchar-subscripts \ - -Wredundant-decls -Wextra-tokens \ - -Wunreachable-code +define rm_perfile_cflags +$(1)_CFLAGS_RM += $2 +endef -# overloaded-virtual warnings are non-fatal (9000888) -CXXWARNFLAGS_STD += -Wno-error=overloaded-virtual +CXXWARNFLAGS_STD = \ + $(WARNFLAGS_STD) \ + -Wno-c++98-compat-pedantic \ + -Wno-exit-time-destructors \ + -Wno-global-constructors \ + -Wno-old-style-cast # Can be overridden in Makefile.template or Makefile.$arch export CXXWARNFLAGS ?= $(CXXWARNFLAGS_STD) @@ -127,12 +199,49 @@ endef ARCH_FLAGS_X86_64 = -arch x86_64 ARCH_FLAGS_X86_64H = -arch x86_64h +ifneq ($(filter ARM ARM64,$(CURRENT_ARCH_CONFIG)),) + +ifndef ARCH_STRING_FOR_CURRENT_MACHINE_CONFIG +export ARCH_STRING_FOR_CURRENT_MACHINE_CONFIG := $(shell $(EMBEDDED_DEVICE_MAP) -db $(EDM_DBPATH) -query SELECT DISTINCT KernelMachOArchitecture FROM Targets WHERE KernelPlatform IS \"$(CURRENT_MACHINE_CONFIG_LC)\" LIMIT 1 || echo UNKNOWN ) +endif + +# +# This can have false negatives, and is used to avoid calling CTF when we'll build a static KC +# +ifndef WILL_BUILD_STATIC_KC +export WILL_BUILD_STATIC_KC := $(shell $(EMBEDDED_DEVICE_MAP) -db $(EDM_DBPATH) \ + -query 'SELECT COUNT(*) != 0 FROM Targets WHERE KernelPlatform IS "$(CURRENT_MACHINE_CONFIG_LC)" \ + AND (KernelMachOArchitecture LIKE "arm64e" OR ProductType LIKE "iphone10,%")') +endif + +BUILD_STATIC_LINK := 1 + +endif + +ARCH_FLAGS_ARM = -arch $(ARCH_STRING_FOR_CURRENT_MACHINE_CONFIG) +ARCH_FLAGS_ARM64 = -arch $(ARCH_STRING_FOR_CURRENT_MACHINE_CONFIG) + +# +# Clang static analyzer flags +# +ANALYZER = $(CC) +ANALYZERPP = $(CXX) +ANALYZERFLAGS = --analyze -D__clang_analyzer__ +ifneq ($(ANALYZE_FORMAT),text) +ANALYZERFLAGS += -Xanalyzer -analyzer-output=html +ANALYZERFLAGS += -o $(OBJROOT)/analyzer-html +else +ANALYZERFLAGS += -Xanalyzer -analyzer-output=text +endif +ifneq ($(ANALYZE_VERBOSE),YES) +ANALYZERFLAGS += -Xclang -analyzer-disable-checker -Xclang deadcode.DeadStores +endif # # Default CFLAGS # -ifdef RC_CFLAGS -OTHER_CFLAGS = $(subst $(addprefix -arch ,$(RC_ARCHS)),,$(RC_CFLAGS)) +ifdef RC_NONARCH_CFLAGS +OTHER_CFLAGS = $(RC_NONARCH_CLFAGS) endif # @@ -143,7 +252,7 @@ DSYMKGMACROSDIR = Contents/Resources DSYMLLDBMACROSDIR = Contents/Resources/Python DSYMDWARFDIR = Contents/Resources/DWARF -DEBUG_CFLAGS := -gdwarf-2 +DEBUG_CFLAGS := -g BUILD_DSYM := 1 # @@ -151,28 +260,43 @@ BUILD_DSYM := 1 # probes from the kernel. # CFLAGS_GEN = $(DEBUG_CFLAGS) -nostdinc \ - -fno-builtin -fno-common \ - -fsigned-bitfields $(OTHER_CFLAGS) - -CFLAGS_RELEASE = -CFLAGS_DEVELOPMENT = -CFLAGS_DEBUG = -CFLAGS_PROFILE = -pg + -ferror-limit=10000 \ + -fno-builtin \ + -fno-common \ + -ftrivial-auto-var-init=zero \ + -enable-trivial-auto-var-init-zero-knowing-it-will-be-removed-from-clang \ + -fsigned-bitfields \ + -fmerge-all-constants \ + -fno-c++-static-destructors \ + $(OTHER_CFLAGS) + +CFLAGS_RELEASE = +CFLAGS_DEVELOPMENT = +CFLAGS_DEBUG = +CFLAGS_KASAN = $(CFLAGS_DEVELOPMENT) +CFLAGS_PROFILE = -pg CFLAGS_X86_64 = -Dx86_64 -DX86_64 -D__X86_64__ -DLP64 \ - -DPAGE_SIZE_FIXED -mkernel -msoft-float + -DPAGE_SIZE_FIXED -mkernel -msoft-float CFLAGS_X86_64H = $(CFLAGS_X86_64) +CFLAGS_ARM = -Darm -DARM -D__ARM__ -DPAGE_SIZE_FIXED \ + -momit-leaf-frame-pointer -fno-strict-aliasing -D__API__=v4 + +CFLAGS_ARM64 = -Darm64 -DARM64 -D__ARM64__ -DLP64 -DPAGE_SIZE_FIXED \ + -momit-leaf-frame-pointer -fno-strict-aliasing -D__API__=v4 -mkernel CFLAGS_RELEASEX86_64 = -O2 CFLAGS_DEVELOPMENTX86_64 = -O2 +CFLAGS_KASANX86_64 = $(CFLAGS_DEVELOPMENTX86_64) # No space optimization for the DEBUG kernel for the benefit of gdb: CFLAGS_DEBUGX86_64 = -O0 CFLAGS_PROFILEX86_64 = -O2 CFLAGS_RELEASEX86_64H = -O2 CFLAGS_DEVELOPMENTX86_64H = -O2 +CFLAGS_KASANX86_64H = $(CFLAGS_DEVELOPMENTX86_64H) # No space optimization for the DEBUG kernel for the benefit of gdb: CFLAGS_DEBUGX86_64H = -O0 CFLAGS_PROFILEX86_64H = -O2 @@ -182,8 +306,82 @@ CFLAGS_DEVELOPMENTARM = -O2 CFLAGS_DEBUGARM = -O0 CFLAGS_PROFILEARM = -O2 +CFLAGS_RELEASEARM64 = -O2 +CFLAGS_DEVELOPMENTARM64 = -O2 +CFLAGS_KASANARM64 = $(CFLAGS_DEVELOPMENTARM64) +CFLAGS_DEBUGARM64 = -O0 +CFLAGS_PROFILEARM64 = -O2 + +# +# Sanitizers Support (KASan, UBSan) +# + + +SAN=0 + +ifeq ($(CURRENT_KERNEL_CONFIG),KASAN) +# KASan kernel config implicitly enables the KASan instrumentation. +# Instrumentation for other sanitizers is enabled explicitly at build time. +KASAN = 1 +endif + +ifeq ($(KASAN),1) +SAN=1 +BUILD_LTO = 0 +KASAN_SHIFT_ARM64=0xe000000000000000 +# +# To calculate the kasan shift, subtract the lowest KVA to sanitize, shifted right by 3 bits, +# from the base address of the kasan shadow area, (e.g. solve the following equation: +# SHIFT = {VA mapped by the first KASAN PML4 [Currently #494]} - (LOWEST_KVA >> 3) +# SHIFT = (0ULL - (512GiB * (512 - 494))) - (LOWEST_SAN_KVA >> 3) +# SHIFT = FFFFF70000000000 - ((0ULL - (512GiB * (512 - 496))) >> 3) [PML4 #496 is the first possible KVA] +# SHIFT = FFFFF70000000000 - (FFFFF80000000000 >> 3) +# SHIFT = DFFFF80000000000 +# ). +KASAN_SHIFT_X86_64=0xdffff80000000000 +KASAN_SHIFT_X86_64H=$(KASAN_SHIFT_X86_64) +KASAN_SHIFT=$($(addsuffix $(CURRENT_ARCH_CONFIG),KASAN_SHIFT_)) +CFLAGS_GEN += -DKASAN=1 -DKASAN_SHIFT=$(KASAN_SHIFT) -fsanitize=address \ + -mllvm -asan-globals-live-support \ + -mllvm -asan-mapping-offset=$(KASAN_SHIFT) + +endif + +ifeq ($(UBSAN),1) +SAN=1 +UBSAN_CHECKS = signed-integer-overflow shift pointer-overflow bounds object-size # non-fatal (calls runtime, can return) +# UBSAN_CHECKS = undefined nullability unsigned-integer-overflow # everything +UBSAN_CHECKS_FATAL = # fatal (calls runtime, must not return) +UBSAN_CHECKS_TRAP = vla-bound builtin # emit a trap instruction (no runtime support) +UBSAN_DISABLED = + +UBSAN_DISABLED += vptr function # requires unsupported C++ runtime +ifeq ($(KASAN),1) +# UBSan alignment + KASan code size is too large +# UBSan unreachable doesn't play nice with ASan (40723397) +UBSAN_DISABLED += alignment unreachable +endif + +CFLAGS_GEN += -DUBSAN=1 +CFLAGS_GEN += $(foreach x,$(UBSAN_CHECKS) $(UBSAN_CHECKS_FATAL) $(UBSAN_CHECKS_TRAP),-fsanitize=$(x)) +CFLAGS_GEN += $(foreach x,$(UBSAN_CHECKS_FATAL),-fno-sanitize-recover=$(x)) +CFLAGS_GEN += $(foreach x,$(UBSAN_CHECKS_TRAP),-fsanitize-trap=$(x)) +CFLAGS_GEN += $(foreach x,$(UBSAN_DISABLED),-fno-sanitize=$(x)) +endif + +ifeq ($(KSANCOV),1) +# Enable SanitizerCoverage instrumentation in xnu +SAN = 1 +KSANCOV_CFLAGS := -fsanitize-coverage=trace-pc-guard +CFLAGS_GEN += $(KSANCOV_CFLAGS) -DKSANCOV=1 +endif + +ifeq ($(SAN),1) +CFLAGS_GEN += -fsanitize-blacklist=$(OBJROOT)/san/kasan-blacklist-$(CURRENT_ARCH_CONFIG_LC) +endif + -CFLAGS = $(CFLAGS_GEN) \ +CFLAGS = $(CFLAGS_GEN) \ $($(addsuffix $(CURRENT_MACHINE_CONFIG),MACHINE_FLAGS_$(CURRENT_ARCH_CONFIG)_)) \ $($(addsuffix $(CURRENT_ARCH_CONFIG),ARCH_FLAGS_)) \ $($(addsuffix $(CURRENT_ARCH_CONFIG),CFLAGS_)) \ @@ -199,17 +397,12 @@ CFLAGS = $(CFLAGS_GEN) \ OTHER_CXXFLAGS = -CXXFLAGS_GEN = -fapple-kext $(OTHER_CXXFLAGS) - -# For the moment, do not use gnu++11 -#CXXFLAGS_ARM = -std=gnu++11 - +CXXFLAGS_GEN = -std=gnu++1z -fsized-deallocation -fapple-kext $(OTHER_CXXFLAGS) CXXFLAGS = $(CXXFLAGS_GEN) \ $($(addsuffix $(CURRENT_ARCH_CONFIG),CXXFLAGS_)) \ $($(addsuffix $(CURRENT_KERNEL_CONFIG),CXXFLAGS_)) - # # Assembler command # @@ -221,15 +414,18 @@ S_KCC = $(CC) # SFLAGS_GEN = -D__ASSEMBLER__ -DASSEMBLER $(OTHER_CFLAGS) -SFLAGS_RELEASE = -SFLAGS_DEVELOPMENT = -SFLAGS_DEBUG = -SFLAGS_PROFILE = +SFLAGS_RELEASE = +SFLAGS_DEVELOPMENT = +SFLAGS_KASAN = $(SFLAGS_DEVELOPMENT) -DKASAN=1 +SFLAGS_DEBUG = +SFLAGS_PROFILE = -SFLAGS_X86_64 = $(CFLAGS_X86_64) -SFLAGS_X86_64H = $(CFLAGS_X86_64H) +SFLAGS_X86_64 = $(CFLAGS_X86_64) +SFLAGS_X86_64H = $(CFLAGS_X86_64H) +SFLAGS_ARM = $(CFLAGS_ARM) +SFLAGS_ARM64 = $(CFLAGS_ARM64) -SFLAGS = $(SFLAGS_GEN) \ +SFLAGS = $(SFLAGS_GEN) \ $($(addsuffix $(CURRENT_MACHINE_CONFIG),MACHINE_FLAGS_$(CURRENT_ARCH_CONFIG)_)) \ $($(addsuffix $(CURRENT_ARCH_CONFIG),ARCH_FLAGS_)) \ $($(addsuffix $(CURRENT_ARCH_CONFIG),SFLAGS_)) \ @@ -258,8 +454,6 @@ LDFLAGS_KERNEL_GEN = \ -Wl,-sectalign,__DATA,__common,0x1000 \ -Wl,-sectalign,__DATA,__bss,0x1000 \ -Wl,-sectcreate,__PRELINK_TEXT,__text,/dev/null \ - -Wl,-sectcreate,__PRELINK_STATE,__kernel,/dev/null \ - -Wl,-sectcreate,__PRELINK_STATE,__kexts,/dev/null \ -Wl,-sectcreate,__PRELINK_INFO,__info,/dev/null \ -Wl,-new_linker \ -Wl,-pagezero_size,0x0 \ @@ -267,10 +461,14 @@ LDFLAGS_KERNEL_GEN = \ -Wl,-function_starts \ -Wl,-headerpad,152 -LDFLAGS_KERNEL_RELEASE = -LDFLAGS_KERNEL_DEVELOPMENT = -LDFLAGS_KERNEL_DEBUG = -LDFLAGS_KERNEL_PROFILE = +# LDFLAGS_KERNEL_SDK = -L$(SDKROOT)/usr/local/lib/kernel -lfirehose_kernel +LDFLAGS_KERNEL_SDK = -L$(SDKROOT)/usr/local/lib/kernel + +LDFLAGS_KERNEL_RELEASE = +LDFLAGS_KERNEL_DEVELOPMENT = +LDFLAGS_KERNEL_KASAN = $(LDFLAGS_KERNEL_DEVELOPMENT) +LDFLAGS_KERNEL_DEBUG = +LDFLAGS_KERNEL_PROFILE = # KASLR static slide config: ifndef SLIDE @@ -292,8 +490,6 @@ LDFLAGS_KERNEL_RELEASEX86_64 = \ -Wl,-segaddr,__HIB,$(KERNEL_HIB_SECTION_BASE) \ -Wl,-image_base,$(KERNEL_TEXT_BASE) \ -Wl,-seg_page_size,__TEXT,0x200000 \ - -Wl,-sectalign,__DATA,__const,0x1000 \ - -Wl,-sectalign,__DATA,__sysctl_set,0x1000 \ -Wl,-sectalign,__HIB,__bootPT,0x1000 \ -Wl,-sectalign,__HIB,__desc,0x1000 \ -Wl,-sectalign,__HIB,__data,0x1000 \ @@ -305,62 +501,187 @@ LDFLAGS_KERNEL_RELEASEX86_64 = \ -Wl,-sectalign,__HIB,__llvm_prf_names,0x1000 \ -Wl,-sectalign,__HIB,__llvm_prf_data,0x1000 \ -Wl,-sectalign,__HIB,__textcoal_nt,0x1000 \ + -Wl,-rename_section,__DATA,__const,__DATA_CONST,__const \ + -Wl,-no_zero_fill_sections \ $(LDFLAGS_NOSTRIP_FLAG) +ifeq ($(SAN),1) +LDFLAGS_KERNEL_RELEASEX86_64 += \ + -Wl,-sectalign,__HIB,__cstring,0x1000 +endif + +ifeq ($(KSANCOV),1) +LDFLAGS_KERNEL_RELEASEX86_64 += \ + -Wl,-sectalign,__HIB,__sancov_guards,0x1000 \ + -Wl,-sectalign,__HIB,__sancov_pcs,0x1000 +endif + # Define KERNEL_BASE_OFFSET so known at compile time: CFLAGS_X86_64 += -DKERNEL_BASE_OFFSET=$(KERNEL_BASE_OFFSET) CFLAGS_X86_64H += -DKERNEL_BASE_OFFSET=$(KERNEL_BASE_OFFSET) LDFLAGS_KERNEL_DEBUGX86_64 = $(LDFLAGS_KERNEL_RELEASEX86_64) LDFLAGS_KERNEL_DEVELOPMENTX86_64 = $(LDFLAGS_KERNEL_RELEASEX86_64) +LDFLAGS_KERNEL_KASANX86_64 = $(LDFLAGS_KERNEL_DEVELOPMENTX86_64) \ + -Wl,-sectalign,__HIB,__asan_globals,0x1000 \ + -Wl,-sectalign,__HIB,__asan_liveness,0x1000 \ + -Wl,-sectalign,__HIB,__mod_term_func,0x1000 \ + -Wl,-rename_section,__HIB,__mod_init_func,__NULL,__mod_init_func \ + -Wl,-rename_section,__HIB,__eh_frame,__NULL,__eh_frame LDFLAGS_KERNEL_PROFILEX86_64 = $(LDFLAGS_KERNEL_RELEASEX86_64) LDFLAGS_KERNEL_RELEASEX86_64H = $(LDFLAGS_KERNEL_RELEASEX86_64) LDFLAGS_KERNEL_DEBUGX86_64H = $(LDFLAGS_KERNEL_RELEASEX86_64H) LDFLAGS_KERNEL_DEVELOPMENTX86_64H = $(LDFLAGS_KERNEL_RELEASEX86_64H) +LDFLAGS_KERNEL_KASANX86_64H = $(LDFLAGS_KERNEL_KASANX86_64) LDFLAGS_KERNEL_PROFILEX86_64H = $(LDFLAGS_KERNEL_RELEASEX86_64H) +# We preload ___udivmoddi4 in order to work around an issue with building +# LTO on armv7. +LDFLAGS_KERNEL_GENARM = \ + -Wl,-pie \ + -Wl,-static \ + -Wl,-image_base,0x80001000 \ + -Wl,-sectalign,__DATA,__const,0x1000 \ + -Wl,-u,___udivmoddi4 + +LDFLAGS_KERNEL_RELEASEARM = \ + $(LDFLAGS_KERNEL_GENARM) \ + $(LDFLAGS_KERNEL_STRIP_LTO) + +LDFLAGS_KERNEL_EXPORTS_RELEASEARM = \ + -Wl,-exported_symbols_list,$(TARGET)/all-kpi.exp + +LDFLAGS_KERNEL_DEVELOPMENTARM = \ + $(LDFLAGS_KERNEL_GENARM) \ + $(LDFLAGS_NOSTRIP_FLAG) + +LDFLAGS_KERNEL_EXPORTS_DEVELOPMENTARM = + +LDFLAGS_KERNEL_DEBUGARM = $(LDFLAGS_KERNEL_DEVELOPMENTARM) +LDFLAGS_KERNEL_EXPORTS_DEBUGARM = $(LDFLAGS_KERNEL_EXPORTS_DEVELOPMENTARM) + +# Offset image base by page to have iBoot load kernel TEXT correctly. +# First page is used for various purposes : sleep token, reset vector. +# We also need a 32MB offset, as this is the minimum block mapping size +# for a 16KB page runtime, and we wish to use the first virtual block +# to map the low globals page. We also need another 4MB to account for +# the address space reserved by L4 (because the reservation is not a +# multiple of the block size in alignment/length, we will implictly map +# it with our block mapping, and we therefore must reflect that the +# first 4MB of the block mapping for xnu do not belong to xnu). +# For the moment, kaliber has a unique memory layout (monitor at the top +# of memory). Support this by breaking 16KB on other platforms and +# mandating 32MB alignment. Image base (i.e. __TEXT) must be 16KB +# aligned since ld64 will link with 16KB alignment for ARM64. +# +# We currently offset by an additional 32MB in order to reclaim memory. +# We need a dedicated virtual page for the low globals. Our bootloader +# may have a significant chunk of memory (up to an L2 entry in size) +# that lies before the kernel. The addition 32MB of virtual padding +# ensures that we have enough virtual address space to map all of that +# memory as part of the V-to-P mapping. +# 23355738 - put __PRELINK_TEXT first. We reserve enough room +# for 0x0000000003000000 = 48MB of kexts +# +# 0xfffffff000000000 (32MB range for low globals) +# 0xfffffff002000000 (32MB range to allow for large page physical slide) +# 0xfffffff004000000 (16KB range to reserve the first available page) +# 0xfffffff004004000 (48MB range for kexts) +# 0xfffffff007004000 (Start of xnu proper). +LDFLAGS_KERNEL_GENARM64 = \ + -Wl,-pie \ + -Wl,-static \ + -Wl,-segaddr,__PRELINK_TEXT,0xfffffff004004000 \ + -Wl,-image_base,0xfffffff007004000 \ + -Wl,-sectalign,__DATA,__const,0x4000 \ + -Wl,-rename_section,__DATA,__mod_init_func,__DATA_CONST,__mod_init_func \ + -Wl,-rename_section,__DATA,__mod_term_func,__DATA_CONST,__mod_term_func \ + -Wl,-rename_section,__DATA,__auth_ptr,__DATA_CONST,__auth_ptr \ + -Wl,-rename_section,__DATA,__auth_got,__DATA_CONST,__auth_got \ + -Wl,-rename_section,__DATA,__const,__DATA_CONST,__const \ + -Wl,-rename_section,__TEXT,__text,__TEXT_EXEC,__text \ + -Wl,-rename_section,__TEXT,__stubs,__TEXT_EXEC,__stubs \ + -Wl,-rename_section,__TEXT,initcode,__TEXT_EXEC,initcode \ + -Wl,-sectcreate,"__PLK_TEXT_EXEC",__text,/dev/null \ + -Wl,-sectcreate,__PRELINK_DATA,__data,/dev/null \ + -Wl,-sectcreate,"__PLK_DATA_CONST",__data,/dev/null \ + -Wl,-sectcreate,"__PLK_LLVM_COV",__llvm_covmap,/dev/null \ + -Wl,-sectcreate,"__PLK_LINKEDIT",__data,/dev/null + + +LDFLAGS_KERNEL_SEGARM64 ?= \ + -Wl,-segment_order,__TEXT:__DATA_CONST:__LINKEDIT:__TEXT_EXEC:__LAST:__KLD:__DATA:__BOOTDATA + +LDFLAGS_KERNEL_RELEASEARM64 = \ + $(LDFLAGS_KERNEL_GENARM64) \ + $(LDFLAGS_KERNEL_SEGARM64) \ + $(LDFLAGS_KERNEL_STRIP_LTO) + +LDFLAGS_KERNEL_EXPORTS_RELEASEARM64 = \ + -Wl,-exported_symbols_list,$(TARGET)/all-kpi.exp + +LDFLAGS_KERNEL_DEVELOPMENTARM64 = \ + $(LDFLAGS_KERNEL_GENARM64) \ + $(LDFLAGS_KERNEL_SEGARM64) \ + $(LDFLAGS_NOSTRIP_FLAG) + +LDFLAGS_KERNEL_EXPORTS_DEVELOPMENTARM64 = + +LDFLAGS_KERNEL_KASANARM64 = $(LDFLAGS_KERNEL_DEVELOPMENTARM64) +LDFLAGS_KERNEL_DEBUGARM64 = $(LDFLAGS_KERNEL_DEVELOPMENTARM64) + +LDFLAGS_KERNEL_EXPORTS_KASANARM64 = $(LDFLAGS_KERNEL_EXPORTS_DEVELOPMENTARM64) +LDFLAGS_KERNEL_EXPORTS_DEBUGARM64 = $(LDFLAGS_KERNEL_EXPORTS_DEVELOPMENTARM64) LDFLAGS_KERNEL = $(LDFLAGS_KERNEL_GEN) \ + $(LDFLAGS_KERNEL_SDK) \ $($(addsuffix $(CURRENT_ARCH_CONFIG),ARCH_FLAGS_)) \ $($(addsuffix $(CURRENT_ARCH_CONFIG),LDFLAGS_KERNEL_)) \ $($(addsuffix $(CURRENT_KERNEL_CONFIG),LDFLAGS_KERNEL_)) \ $($(addsuffix $(CURRENT_ARCH_CONFIG), $(addsuffix $(CURRENT_KERNEL_CONFIG),LDFLAGS_KERNEL_))) \ $(DEPLOYMENT_TARGET_FLAGS) + +LDFLAGS_KERNEL_EXPORTS = \ + $($(addsuffix $(CURRENT_ARCH_CONFIG), $(addsuffix $(CURRENT_KERNEL_CONFIG),LDFLAGS_KERNEL_EXPORTS_))) \ + -Wl,-alias_list,$(TARGET)/all-alias.exp + + # # Default runtime libraries to be linked with the kernel # -LD_KERNEL_LIBS = -lcc_kext +LD_KERNEL_LIBS = -lcc_kext +LD_KERNEL_ARCHIVES = $(LDFLAGS_KERNEL_SDK) -lfirehose_kernel # # DTrace support # +ifndef DO_CTFMERGE +DO_CTFMERGE := 1 ifeq ($(CURRENT_KERNEL_CONFIG),RELEASE) ifneq ($(filter ARM%,$(CURRENT_ARCH_CONFIG)),) -DO_CTFCONVERT = 0 -DO_CTFMERGE = 0 -DO_CTFMACHO = 0 -else -DO_CTFCONVERT = $(SUPPORTS_CTFCONVERT) -DO_CTFMERGE = 1 -DO_CTFMACHO = $(NEEDS_CTF_MACHOS) +DO_CTFMERGE := 0 +endif +endif +ifneq ($(CURRENT_KERNEL_CONFIG),KASAN) +ifeq ($(WILL_BUILD_STATIC_KC),1) +DO_CTFMERGE := 0 endif -else -DO_CTFCONVERT = $(SUPPORTS_CTFCONVERT) -DO_CTFMERGE = 1 -DO_CTFMACHO = $(NEEDS_CTF_MACHOS) endif +endif # DO_CTFMERGE + # # Default INCFLAGS # -INCFLAGS_IMPORT = $(patsubst %, -I$(OBJROOT)/EXPORT_HDRS/%, $(COMPONENT_IMPORT_LIST)) -INCFLAGS_EXTERN = -I$(SRCROOT)/EXTERNAL_HEADERS +INCFLAGS_IMPORT = $(patsubst %, -I$(OBJROOT)/EXPORT_HDRS/%, $(COMPONENT_IMPORT_LIST)) +INCFLAGS_EXTERN = -I$(SRCROOT)/EXTERNAL_HEADERS INCFLAGS_GEN = -I$(SRCROOT)/$(COMPONENT) -I$(OBJROOT)/EXPORT_HDRS/$(COMPONENT) INCFLAGS_LOCAL = -I. +INCFLAGS_SDK = -I$(SDKROOT)/usr/local/include/kernel -INCFLAGS = $(INCFLAGS_LOCAL) $(INCFLAGS_GEN) $(INCFLAGS_IMPORT) $(INCFLAGS_EXTERN) $(INCFLAGS_MAKEFILE) +INCFLAGS = $(INCFLAGS_LOCAL) $(INCFLAGS_GEN) $(INCFLAGS_IMPORT) $(INCFLAGS_EXTERN) $(INCFLAGS_MAKEFILE) $(INCFLAGS_SDK) # # Default MIGFLAGS @@ -368,7 +689,6 @@ INCFLAGS = $(INCFLAGS_LOCAL) $(INCFLAGS_GEN) $(INCFLAGS_IMPORT) $(INCFLAGS_EXTE MIGFLAGS = $(DEFINES) $(INCFLAGS) -novouchers $($(addsuffix $(CURRENT_ARCH_CONFIG),CFLAGS_)) $($(addsuffix $(CURRENT_ARCH_CONFIG),ARCH_FLAGS_)) \ $(DEPLOYMENT_TARGET_FLAGS) - # Support for LLVM Profile Guided Optimization (PGO) ifeq ($(BUILD_PROFILE),1) @@ -402,6 +722,7 @@ endif LTO_ENABLED_RELEASE = 1 LTO_ENABLED_DEVELOPMENT = 1 LTO_ENABLED_DEBUG = 0 +LTO_ENABLED_KASAN = 0 ifneq ($(BUILD_LTO),) USE_LTO = $(BUILD_LTO) @@ -409,28 +730,25 @@ else USE_LTO = $(LTO_ENABLED_$(CURRENT_KERNEL_CONFIG)) endif -SUPPORTS_CTFCONVERT = 0 ifeq ($(USE_LTO),1) CFLAGS_GEN += -flto CXXFLAGS_GEN += -flto -LDFLAGS_KERNEL_GEN += -Wl,-mllvm,-inline-threshold=125 -Wl,-object_path_lto,$(TARGET)/lto.o # -Wl,-mllvm -Wl,-disable-fp-elim +LDFLAGS_KERNEL_LTO = -Wl,-mllvm,-inline-threshold=100 +LDFLAGS_KERNEL_GEN += $(LDFLAGS_KERNEL_LTO) -Wl,-object_path_lto,$(TARGET)/lto.o LDFLAGS_NOSTRIP_FLAG = -rdynamic +LDFLAGS_KERNEL_STRIP_LTO = -Wl,-dead_strip,-no_dead_strip_inits_and_terms + CFLAGS_NOLTO_FLAG = -fno-lto -NEEDS_CTF_MACHOS = 1 else +LDFLAGS_KERNEL_LTO = LDFLAGS_NOSTRIP_FLAG = +LDFLAGS_KERNEL_STRIP_LTO = CFLAGS_NOLTO_FLAG = -ifneq ($(CTFCONVERT),) -SUPPORTS_CTFCONVERT = 1 -endif -NEEDS_CTF_MACHOS = 0 endif ifeq ($(BUILD_JSON_COMPILATION_DATABASE),1) BUILD_DSYM := 0 -DO_CTFCONVERT := 0 -DO_CTFMERGE := 0 -DO_CTFMACHO := 0 +DO_CTFMERGE := 0 KCC = $(JSONCOMPILATIONDB) $(OBJPATH)/compile_commands.json $(PWD) $< $(CC) KC++ = $(JSONCOMPILATIONDB) $(OBJPATH)/compile_commands.json $(PWD) $< $(CXX) S_KCC = $(JSONCOMPILATIONDB) $(OBJPATH)/compile_commands.json $(PWD) $< $(CC) @@ -442,11 +760,13 @@ endif # export VPATH = .:$(SOURCE) + + # # Macros that control installation of kernel and its header files # # install flags for header files -# +# INSTALL_FLAGS = -c -S -m 0444 DATA_INSTALL_FLAGS = -c -S -m 0644 EXEC_INSTALL_FLAGS = -c -S -m 0755 @@ -454,7 +774,15 @@ EXEC_INSTALL_FLAGS = -c -S -m 0755 # # Header file destinations # -FRAMEDIR = /System/Library/Frameworks + +ifeq ($(DRIVERKIT),1) + SDKHEADERSROOT=$(DRIVERKITRUNTIMEROOT) + # only whitelisted headers install outside of the DriverKit Runtime hierarchy + DRIVERKITSDKHEADERSROOT=$(DRIVERKITROOT) + DRIVERKITFRAMEDIR = $(DRIVERKITROOT)/System/Library/Frameworks +endif + +FRAMEDIR = $(SDKHEADERSROOT)/System/Library/Frameworks SINCVERS = B SINCFRAME = $(FRAMEDIR)/System.framework @@ -463,11 +791,17 @@ SPINCDIR = $(SINCFRAME)/Versions/$(SINCVERS)/PrivateHeaders SRESDIR = $(SINCFRAME)/Versions/$(SINCVERS)/Resources ifndef INCDIR - INCDIR = /usr/include + INCDIR = $(SDKHEADERSROOT)/usr/include +endif +ifndef DRIVERKITINCDIR + DRIVERKITINCDIR = $(DRIVERKITSDKHEADERSROOT)/usr/include endif ifndef LCLDIR LCLDIR = $(SPINCDIR) endif +ifndef DRIVERKITLCLDIR + DRIVERKITLCLDIR = $(DRIVERKITSDKHEADERSROOT)/usr/local/include +endif KINCVERS = A KINCFRAME = $(FRAMEDIR)/Kernel.framework @@ -475,15 +809,27 @@ KINCDIR = $(KINCFRAME)/Versions/$(KINCVERS)/Headers KPINCDIR = $(KINCFRAME)/Versions/$(KINCVERS)/PrivateHeaders KRESDIR = $(KINCFRAME)/Versions/$(KINCVERS)/Resources +DKIT_INCVERS = A +DKIT_INCFRAME = DriverKit.framework +DKIT_INCDIR = $(DKIT_INCFRAME)/Versions/$(DKIT_INCVERS)/Headers +DKIT_PINCDIR = $(DKIT_INCFRAME)/Versions/$(DKIT_INCVERS)/PrivateHeaders +# DriverKit SDK frameworks use shallow bundle structure +DRIVERKIT_DKIT_INCDIR = $(DKIT_INCFRAME)/Headers +DRIVERKIT_DKIT_PINCDIR = $(DKIT_INCFRAME)/PrivateHeaders + XNU_PRIVATE_UNIFDEF = -UMACH_KERNEL_PRIVATE -UBSD_KERNEL_PRIVATE -UIOKIT_KERNEL_PRIVATE -ULIBKERN_KERNEL_PRIVATE -ULIBSA_KERNEL_PRIVATE -UPEXPERT_KERNEL_PRIVATE -UXNU_KERNEL_PRIVATE PLATFORM_UNIFDEF = $(foreach x,$(SUPPORTED_PLATFORMS),$(if $(filter $(PLATFORM),$(x)),-DPLATFORM_$(x) $(foreach token,$(PLATFORM_UNIFDEF_BLACKLIST_TOKENS_$(x)),-U$(token)),-UPLATFORM_$(x))) -SPINCFRAME_UNIFDEF = $(PLATFORM_UNIFDEF) $(XNU_PRIVATE_UNIFDEF) $(SEED_DEFINES) -UKERNEL_PRIVATE -UKERNEL -DPRIVATE -U_OPEN_SOURCE_ -U__OPEN_SOURCE__ -SINCFRAME_UNIFDEF = $(PLATFORM_UNIFDEF) $(XNU_PRIVATE_UNIFDEF) $(SEED_DEFINES) -UKERNEL_PRIVATE -UKERNEL -UPRIVATE -D_OPEN_SOURCE_ -D__OPEN_SOURCE__ -KPINCFRAME_UNIFDEF = $(PLATFORM_UNIFDEF) $(XNU_PRIVATE_UNIFDEF) $(SEED_DEFINES) -DKERNEL_PRIVATE -DPRIVATE -DKERNEL -U_OPEN_SOURCE_ -U__OPEN_SOURCE__ -KINCFRAME_UNIFDEF = $(PLATFORM_UNIFDEF) $(XNU_PRIVATE_UNIFDEF) $(SEED_DEFINES) -UKERNEL_PRIVATE -UPRIVATE -DKERNEL -D_OPEN_SOURCE_ -D__OPEN_SOURCE__ + +SPINCFRAME_UNIFDEF = $(PLATFORM_UNIFDEF) $(XNU_PRIVATE_UNIFDEF) $(SEED_DEFINES) -UKERNEL_PRIVATE -UKERNEL -DPRIVATE -UDRIVERKIT -U_OPEN_SOURCE_ -U__OPEN_SOURCE__ +SINCFRAME_UNIFDEF = $(PLATFORM_UNIFDEF) $(XNU_PRIVATE_UNIFDEF) $(SEED_DEFINES) -UKERNEL_PRIVATE -UKERNEL -UPRIVATE -UDRIVERKIT -D_OPEN_SOURCE_ -D__OPEN_SOURCE__ +DKPINCFRAME_UNIFDEF = $(PLATFORM_UNIFDEF) $(XNU_PRIVATE_UNIFDEF) $(SEED_DEFINES) -UKERNEL_PRIVATE -UKERNEL -DPRIVATE -DDRIVERKIT -U_OPEN_SOURCE_ -U__OPEN_SOURCE__ +DKINCFRAME_UNIFDEF = $(PLATFORM_UNIFDEF) $(XNU_PRIVATE_UNIFDEF) $(SEED_DEFINES) -UKERNEL_PRIVATE -UKERNEL -UPRIVATE -DDRIVERKIT -D_OPEN_SOURCE_ -D__OPEN_SOURCE__ +KPINCFRAME_UNIFDEF = $(PLATFORM_UNIFDEF) $(XNU_PRIVATE_UNIFDEF) $(SEED_DEFINES) -DKERNEL_PRIVATE -DKERNEL -DPRIVATE -UDRIVERKIT -U_OPEN_SOURCE_ -U__OPEN_SOURCE__ +KINCFRAME_UNIFDEF = $(PLATFORM_UNIFDEF) $(XNU_PRIVATE_UNIFDEF) $(SEED_DEFINES) -UKERNEL_PRIVATE -DKERNEL -UPRIVATE -UDRIVERKIT -D_OPEN_SOURCE_ -D__OPEN_SOURCE__ +DATA_UNIFDEF = $(PLATFORM_UNIFDEF) $(XNU_PRIVATE_UNIFDEF) $(SEED_DEFINES) -D_OPEN_SOURCE_ -D__OPEN_SOURCE__ # # Compononent Header file destinations @@ -493,12 +839,13 @@ EXPDIR = EXPORT_HDRS/$(COMPONENT) # # Strip Flags # -STRIP_FLAGS_RELEASE = -S -x -STRIP_FLAGS_DEVELOPMENT = -S -STRIP_FLAGS_DEBUG = -S +STRIP_FLAGS_RELEASE = -S -x +STRIP_FLAGS_DEVELOPMENT = -S +STRIP_FLAGS_KASAN = $(STRIP_FLAGS_DEVELOPMENT) +STRIP_FLAGS_DEBUG = -S STRIP_FLAGS_PROFILE = -S -x -STRIP_FLAGS = $($(addsuffix $(CURRENT_KERNEL_CONFIG),STRIP_FLAGS_)) +STRIP_FLAGS = $($(addsuffix $(CURRENT_KERNEL_CONFIG),STRIP_FLAGS_)) # # dsymutil flags @@ -507,6 +854,8 @@ DSYMUTIL_FLAGS_GEN = --minimize DSYMUTIL_FLAGS_X86_64 = --arch=x86_64 DSYMUTIL_FLAGS_X86_64H = --arch=x86_64h +DSYMUTIL_FLAGS_ARM = --arch=arm +DSYMUTIL_FLAGS_ARM64 = DSYMUTIL_FLAGS = $(DSYMUTIL_FLAGS_GEN) \ $($(addsuffix $(CURRENT_ARCH_CONFIG),DSYMUTIL_FLAGS_)) @@ -519,7 +868,7 @@ MANDIR = /usr/share/man # # DEBUG alias location # -DEVELOPER_EXTRAS_DIR = /AppleInternal/CoreOS/xnu_debug +DEVELOPER_EXTRAS_DIR = /AppleInternal/CoreOS/xnu_$(CURRENT_KERNEL_CONFIG_LC) # # mach_kernel install location @@ -554,6 +903,12 @@ KERNEL_FILE_NAME = $(KERNEL_FILE_NAME_PREFIX).$(CURRENT_KERNEL_CONFIG_LC).$(CURR KERNEL_LLDBBOOTSTRAP_NAME = $(KERNEL_FILE_NAME_PREFIX)_$(CURRENT_KERNEL_CONFIG_LC).py endif +CURRENT_ALIAS_MACHINE_CONFIG = $(word 4,$(subst ^, ,$(CURRENT_BUILD_CONFIG))) +CURRENT_ALIAS_MACHINE_CONFIG_LC = $(shell printf "%s" "$(CURRENT_ALIAS_MACHINE_CONFIG)" | $(TR) A-Z a-z) +ifneq ($(CURRENT_ALIAS_MACHINE_CONFIG),) +ALIAS_FILE_NAME = $(KERNEL_FILE_NAME_PREFIX).$(CURRENT_KERNEL_CONFIG_LC).$(CURRENT_ALIAS_MACHINE_CONFIG_LC) +endif + # # System.kext pseudo-kext install location # @@ -569,6 +924,7 @@ INSTALL_KERNEL_SYM_DIR = /System/Library/Extensions/KDK # INSTALL_SHARE_MISC_DIR = /usr/share/misc INSTALL_DTRACE_SCRIPTS_DIR = /usr/lib/dtrace +INSTALL_DTRACE_LIBEXEC_DIR = /usr/libexec/dtrace # # Overrides for XBS build aliases @@ -589,4 +945,8 @@ INSTALL_KERNEL_SYM_DIR := $(SYSTEM_LIBRARY_KERNELS_DIR) INSTALL_KERNEL_SYM_TO_KDK = $(if $(filter YES,$(DWARF_DSYM_FILE_SHOULD_ACCOMPANY_PRODUCT)),1,0) endif +ifeq ($(RC_ProjectName),xnu_kasan) +INSTALL_KASAN_ONLY = 1 +endif + # vim: set ft=make: