X-Git-Url: https://git.saurik.com/apple/xnu.git/blobdiff_plain/0a7de7458d150b5d4dffc935ba399be265ef0a1a..HEAD:/tests/Makefile diff --git a/tests/Makefile b/tests/Makefile index 5f165b8b7..c9d3909bb 100644 --- a/tests/Makefile +++ b/tests/Makefile @@ -6,11 +6,13 @@ ifdef BASEDSTROOT override DSTROOT = $(BASEDSTROOT) endif +INVALID_ARCHS = i386 ENABLE_LTE_TESTS=YES OTHER_LTE_INCLUDE_FILES += \ /System/Library/PrivateFrameworks/LoggingSupport.framework, \ /System/Library/PrivateFrameworks/MobileKeyBag.framework, \ + /System/Library/Frameworks/IOSurface.framework, \ /usr/local/lib/libdarwintest_utils.dylib, \ /usr/lib/libapple_crypto.dylib, @@ -24,12 +26,17 @@ include $(DEVELOPER_DIR)/AppleInternal/Makefiles/darwintest/Makefile.common OTHER_CFLAGS = -Weverything -Wno-gnu-union-cast -Wno-missing-field-initializers -Wno-partial-availability OTHER_CFLAGS += -Wno-missing-noreturn -Wno-vla -Wno-reserved-id-macro -Wno-documentation-unknown-command OTHER_CFLAGS += -Wno-padded -Wno-used-but-marked-unused -Wno-covered-switch-default -Wno-nullability-extension -OTHER_CFLAGS += -Wno-gnu-empty-initializer -Wno-unused-macros -Wno-undef +OTHER_CFLAGS += -Wno-gnu-empty-initializer -Wno-unused-macros -Wno-undef -Wno-fixed-enum-extension +OTHER_CFLAGS += -Wno-gnu-auto-type -Wno-switch-enum -Wno-variadic-macros OTHER_CFLAGS += --std=gnu11 -isystem $(SDKROOT)/System/Library/Frameworks/System.framework/PrivateHeaders OTHER_CFLAGS += -UT_NAMESPACE_PREFIX -DT_NAMESPACE_PREFIX=xnu OTHER_CFLAGS += -F $(SDKROOT)/System/Library/PrivateFrameworks +OTHER_CFLAGS += -Wl,-sectcreate,__INFO_FILTER,__disable,/dev/null + + CODESIGN:=$(shell xcrun -sdk "$(TARGETSDK)" -find codesign) +CODESIGN_HARDENED_RUNTIME:=$(CODESIGN) -o runtime CODESIGN_ALLOCATE:=$(shell xcrun -sdk "$(TARGETSDK)" -find codesign_allocate) # to have custom compiler flags to @@ -37,9 +44,10 @@ CODESIGN_ALLOCATE:=$(shell xcrun -sdk "$(TARGETSDK)" -find codesign_allocate) atm_diagnostic_flag: OTHER_CFLAGS += drop_priv.c -testposixshm: INVALID_ARCHS = i386 +atm_diagnostic_flag_entitled: CODE_SIGN_ENTITLEMENTS = atm_diagnostic_flag.entitlements +atm_diagnostic_flag_entitled: OTHER_CFLAGS += drop_priv.c -avx: INVALID_ARCHS = i386 +avx: INVALID_ARCHS = $(filter arm%,$(ARCH_CONFIGS)) avx: OTHER_CFLAGS += -mavx512f -mavx512bw -mavx512vl avx: OTHER_CFLAGS += -I$(SDKROOT)/System/Library/Frameworks/System.framework/PrivateHeaders avx: CONFIG_FLAGS := $(filter-out -O%,$(CONFIG_FLAGS)) @@ -52,46 +60,155 @@ ifneq (osx,$(TARGET_NAME)) EXCLUDED_SOURCES += avx.c endif +CUSTOM_TARGETS = sr_entitlement_helper + +sr_entitlement_helper: sr_entitlement_helper.c + mkdir -p $(SYMROOT) + $(CC) -I $(OBJROOT) $(CFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) sr_entitlement_helper.c -o $(SYMROOT)/$@ + echo $(CODESIGN) --force --sign - --timestamp=none --entitlements sr_entitlement.entitlements $(SYMROOT)/$@; \ + env CODESIGN_ALLOCATE=$(CODESIGN_ALLOCATE) $(CODESIGN) --force --sign - --timestamp=none --entitlements sr_entitlement.entitlements $(SYMROOT)/$@; + +install-sr_entitlement_helper: sr_entitlement_helper + mkdir -p $(INSTALLDIR) + cp $(SYMROOT)/sr_entitlement_helper $(INSTALLDIR) + +sr_entitlement: OTHER_LDFLAGS += -ldarwintest_utils + +restrict_jit: CODE_SIGN_ENTITLEMENTS = restrict_jit.entitlements + backtracing: OTHER_LDFLAGS += -framework CoreSymbolication +backtracing: CODE_SIGN_ENTITLEMENTS = kernel_symbolication_entitlements.plist data_protection: OTHER_LDFLAGS += -ldarwintest_utils -framework IOKit +CUSTOM_TARGETS += immovable_send_client vm_spawn_tool + +exception_tests: excserver exc_helpers.c +exception_tests: CODE_SIGN_ENTITLEMENTS = exception_tests.entitlements +exception_tests: OTHER_CFLAGS += $(OBJROOT)/excserver.c +exception_tests: OTHER_CFLAGS += -I $(OBJROOT) +exception_tests: OTHER_CFLAGS += -DENTITLED=1 + +immovable_send: excserver +immovable_send: OTHER_CFLAGS += $(OBJROOT)/excserver.c -I $(OBJROOT) +immovable_send: OTHER_LDFLAGS += -ldarwintest_utils -lpthread -framework IOKit +immovable_send: immovable_send_client + +immovable_send_client: immovable_send_client.c + $(CC) $(DT_CFLAGS) -I $(OBJROOT) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) immovable_send_client.c -o $(SYMROOT)/immovable_send_client + +install-immovable_send_client: immovable_send_client + mkdir -p $(INSTALLDIR) + cp $(SYMROOT)/immovable_send_client $(INSTALLDIR)/ + +vm_spawn_tool: INVALID_ARCHS = i386 +vm_spawn_tool: vm_spawn_tool.c + $(CC) $(DT_CFLAGS) -I $(OBJROOT) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) vm_spawn_tool.c -o $(SYMROOT)/vm_spawn_tool + +install-vm_spawn_tool: vm_spawn_tool + mkdir -p $(INSTALLDIR)/tools + cp $(SYMROOT)/vm_spawn_tool $(INSTALLDIR)/tools/ + +CUSTOM_TARGETS += imm_pinned_control_port_crasher + +imm_pinned_control_port: excserver +imm_pinned_control_port: CODE_SIGN_ENTITLEMENTS = task_for_pid_entitlement.plist +imm_pinned_control_port: OTHER_CFLAGS += $(OBJROOT)/excserver.c -I $(OBJROOT) +imm_pinned_control_port: OTHER_LDFLAGS += -ldarwintest_utils -lpthread +imm_pinned_control_port: imm_pinned_control_port_crasher + +imm_pinned_control_port_crasher: imm_pinned_control_port_crasher.c + $(CC) $(DT_CFLAGS) -I $(OBJROOT) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) imm_pinned_control_port_crasher.c -o $(SYMROOT)/imm_pinned_control_port_crasher + $(CODESIGN) --force --sign - --timestamp=none $(SYMROOT)/$@ + +install-imm_pinned_control_port_crasher: imm_pinned_control_port_crasher + mkdir -p $(INSTALLDIR) + cp $(SYMROOT)/imm_pinned_control_port_crasher $(INSTALLDIR)/ + +kas_info: OTHER_LDFLAGS += -framework CoreSymbolication +kas_info: CODE_SIGN_ENTITLEMENTS = kernel_symbolication_entitlements.plist + kdebug: INVALID_ARCHS = i386 kdebug: OTHER_LDFLAGS = -framework ktrace -ldarwintest_utils -framework kperf +kdebug: OTHER_CFLAGS += test_utils.c -EXCLUDED_SOURCES += drop_priv.c kperf_helpers.c xnu_quick_test_helpers.c +EXCLUDED_SOURCES += drop_priv.c kperf_helpers.c xnu_quick_test_helpers.c memorystatus_assertion_helpers.c bpflib.c in_cksum.c test_utils.c ifneq ($(PLATFORM),iPhoneOS) -EXCLUDED_SOURCES += jumbo_va_spaces_28530648.c perf_compressor.c memorystatus_freeze_test.c +EXCLUDED_SOURCES += jumbo_va_spaces_28530648.c perf_compressor.c memorystatus_freeze_test.c vm/entitlement_increased_memory_limit.c endif perf_compressor: OTHER_LDFLAGS += -ldarwintest_utils perf_compressor: CODE_SIGN_ENTITLEMENTS=./private_entitlement.plist + +memorystatus_freeze_test: CODE_SIGN_ENTITLEMENTS=./task_for_pid_entitlement.plist memorystatus_freeze_test: OTHER_LDFLAGS += -ldarwintest_utils +memorystatus_freeze_test: OTHER_CFLAGS += -ldarwintest_utils memorystatus_assertion_helpers.c + +memorystatus_is_assertion: OTHER_LDFLAGS += -ldarwintest_utils +memorystatus_is_assertion: OTHER_CFLAGS += memorystatus_assertion_helpers.c + +memorystatus_vm_map_fork: OTHER_CFLAGS += test_utils.c -stackshot: OTHER_CFLAGS += -Wno-objc-messaging-id -stackshot: OTHER_LDFLAGS += -lkdd -framework Foundation -stackshot: INVALID_ARCHS = i386 +shared_cache_tests: OTHER_LDFLAGS += -ldarwintest_utils -telemetry: OTHER_LDFLAGS = -framework ktrace -framework CoreFoundation -telemetry: INVALID_ARCHS = i386 +stackshot_tests: OTHER_CFLAGS += -Wno-objc-messaging-id +stackshot_tests: OTHER_LDFLAGS += -lkdd -lz -ldarwintest_utils -framework Foundation + +stackshot_accuracy: OTHER_CFLAGS += -ldarwintest_utils -Wno-objc-messaging-id +stackshot_accuracy: OTHER_LDFLAGS += -lkdd -ldarwintest_utils -framework Foundation +stackshot_accuracy: INVALID_ARCHS = i386 + +ifeq ($(PLATFORM),MacOSX) +CUSTOM_TARGETS += stackshot_translated_child + +stackshot_translated_child: INVALID_ARCHS = arm64 arm64e +stackshot_translated_child: stackshot_translated_child.c + $(CC) $(DT_CFLAGS) -I $(OBJROOT) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) stackshot_translated_child.c -o $(SYMROOT)/stackshot_translated_child + +install-stackshot_translated_child: stackshot_translated_child + mkdir -p $(INSTALLDIR) + cp $(SYMROOT)/stackshot_translated_child $(INSTALLDIR)/ +else +EXCLUDED_SOURCES += stackshot_translated_child.c +endif + +telemetry: OTHER_LDFLAGS = -framework ktrace -framework kperf -framework CoreFoundation -memorystatus_zone_test: INVALID_ARCHS = i386 memorystatus_zone_test: OTHER_CFLAGS += -isystem $(SDKROOT)/System/Library/Frameworks/System.framework/PrivateHeaders memorystatus_zone_test: OTHER_LDFLAGS += -framework ktrace memorystatus_zone_test: OTHER_LDFLAGS += -ldarwintest_utils -kpc: OTHER_LDFLAGS += -framework kperf +ifeq ($(PLATFORM),BridgeOS) +EXCLUDED_SOURCES += dirtiness_tracking.c +endif + +dirtiness_tracking: OTHER_CFLAGS += -Wno-cast-align + +kpc: OTHER_LDFLAGS += -framework kperf -framework ktrace +kpc: INVALID_ARCHS = i386 -kperf: INVALID_ARCHS = i386 kperf: OTHER_CFLAGS += kperf_helpers.c kperf: OTHER_LDFLAGS += -framework kperf -framework kperfdata -framework ktrace -ldarwintest_utils -kperf_backtracing: INVALID_ARCHS = i386 +memcmp_zero: OTHER_CFLAGS += ../osfmk/arm64/memcmp_zero.s + kperf_backtracing: OTHER_CFLAGS += kperf_helpers.c kperf_backtracing: OTHER_LDFLAGS += -framework kperf -framework kperfdata -framework ktrace kperf_backtracing: OTHER_LDFLAGS += -framework CoreSymbolication +kperf_backtracing: CODE_SIGN_ENTITLEMENTS = kernel_symbolication_entitlements.plist + +text_corruption: OTHER_LDFLAGS += -ldarwintest_utils +CUSTOM_TARGETS += text_corruption_helper + +text_corruption_helper: + $(CC) $(LDFLAGS) $(CFLAGS) text_corruption_helper.c -lm -o $(SYMROOT)/$@; + env CODESIGN_ALLOCATE=$(CODESIGN_ALLOCATE) $(CODESIGN) --force --sign - --timestamp=none $(SYMROOT)/$@; + +install-text_corruption_helper: + mkdir -p $(INSTALLDIR) + cp $(SYMROOT)/text_corruption_helper $(INSTALLDIR)/ kevent_qos: OTHER_CFLAGS += -Wno-unused-macros kevent_qos: OTHER_CFLAGS += -I $(OBJROOT)/ @@ -99,20 +216,79 @@ kevent_qos: OTHER_CFLAGS += -I $(OBJROOT)/ mach_get_times: OTHER_LDFLAGS += -ldarwintest_utils monotonic_core: OTHER_LDFLAGS += -framework ktrace -monotonic_core: INVALID_ARCHS = i386 perf_exit: perf_exit_proc perf_exit: OTHER_LDFLAGS = -framework ktrace -ldarwintest_utils -perf_exit: INVALID_ARCHS = i386 perf_exit: CODE_SIGN_ENTITLEMENTS=./private_entitlement.plist +CUSTOM_TARGETS += prioritize_process_launch_helper +prioritize_process_launch: prioritize_process_launch_helper + +prioritize_process_launch_helper: prioritize_process_launch_helper.c + $(CC) $(DT_CFLAGS) $(OTHER_CFLAGS) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) prioritize_process_launch_helper.c -o $(SYMROOT)/prioritize_process_launch_helper + echo $(CODESIGN) --force --sign - --timestamp=none $(SYMROOT)/$@; \ + env CODESIGN_ALLOCATE=$(CODESIGN_ALLOCATE) $(CODESIGN) --force --sign - --timestamp=none $(SYMROOT)/$@; + +install-prioritize_process_launch_helper: prioritize_process_launch_helper + mkdir -p $(INSTALLDIR) + cp $(SYMROOT)/prioritize_process_launch_helper $(INSTALLDIR)/ + + perf_spawn_fork: CODE_SIGN_ENTITLEMENTS=./private_entitlement.plist +mach_exception_reply: OTHER_CFLAGS += -Wno-cast-align + os_thread_self_restrict: os_thread_self_restrict.c os_thread_self_restrict-entitlements.plist os_thread_self_restrict: CODE_SIGN_ENTITLEMENTS=os_thread_self_restrict-entitlements.plist -task_inspect: CODE_SIGN_ENTITLEMENTS = task_inspect.entitlements -task_inspect: OTHER_CFLAGS += -DENTITLED=1 +subsystem_root_path: subsystem_root_path.c subsystem_root_path-entitlements.plist +subsystem_root_path: CODE_SIGN_ENTITLEMENTS=subsystem_root_path-entitlements.plist + +EXCLUDED_SOURCES += $(wildcard bounded_ptr_src/*.cpp) +bounded_ptr: OTHER_CXXFLAGS += -Werror=implicit-int-conversion -Werror=shorten-64-to-32 -I$(SRCROOT)/../libkern -std=c++17 +bounded_ptr: $(wildcard bounded_ptr_src/*.cpp) bounded_ptr.cpp + +EXCLUDED_SOURCES += bounded_ptr_03.cpp +bounded_ptr_03: OTHER_CXXFLAGS += -Werror=implicit-int-conversion -Werror=shorten-64-to-32 -I$(SRCROOT)/../libkern -std=c++03 +bounded_ptr_03: bounded_ptr_03.cpp + +EXCLUDED_SOURCES += $(wildcard bounded_array_src/*.cpp) +bounded_array: OTHER_CXXFLAGS += -Werror=implicit-int-conversion -Werror=shorten-64-to-32 -I$(SRCROOT)/../libkern -std=c++17 +bounded_array: $(wildcard bounded_array_src/*.cpp) bounded_array.cpp + +EXCLUDED_SOURCES += $(wildcard bounded_array_ref_src/*.cpp) +bounded_array_ref: OTHER_CXXFLAGS += -Werror=implicit-int-conversion -Werror=shorten-64-to-32 -I$(SRCROOT)/../libkern -std=c++17 +bounded_array_ref: $(wildcard bounded_array_ref_src/*.cpp) bounded_array_ref.cpp + +EXCLUDED_SOURCES += $(wildcard intrusive_shared_ptr_src/*.cpp) +intrusive_shared_ptr: OTHER_CXXFLAGS += -Werror=implicit-int-conversion -Werror=shorten-64-to-32 -I$(SRCROOT)/../libkern -std=c++17 +intrusive_shared_ptr: $(wildcard intrusive_shared_ptr_src/*.cpp) intrusive_shared_ptr.cpp + +EXCLUDED_SOURCES += $(wildcard safe_allocation_src/*.cpp) +safe_allocation: OTHER_CXXFLAGS += -Werror=implicit-int-conversion -Werror=shorten-64-to-32 -I$(SRCROOT)/../libkern -std=c++17 +safe_allocation: $(wildcard safe_allocation_src/*.cpp) safe_allocation.cpp + +EXCLUDED_SOURCES += osptr_compat.cpp +osptr_98: OTHER_CXXFLAGS += -I$(SRCROOT)/../libkern -std=c++98 -DOSPTR_STD="98" +osptr_98: osptr_compat.cpp + $(CXX) $(DT_CXXFLAGS) $(OTHER_CXXFLAGS) $(CXXFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/$@ +osptr_11: OTHER_CXXFLAGS += -I$(SRCROOT)/../libkern -std=c++11 -DOSPTR_STD="11" +osptr_11: osptr_compat.cpp + $(CXX) $(DT_CXXFLAGS) $(OTHER_CXXFLAGS) $(CXXFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/$@ +osptr_14: OTHER_CXXFLAGS += -I$(SRCROOT)/../libkern -std=c++14 -DOSPTR_STD="14" +osptr_14: osptr_compat.cpp + $(CXX) $(DT_CXXFLAGS) $(OTHER_CXXFLAGS) $(CXXFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/$@ +osptr_17: OTHER_CXXFLAGS += -I$(SRCROOT)/../libkern -std=c++17 -DOSPTR_STD="17" +osptr_17: osptr_compat.cpp + $(CXX) $(DT_CXXFLAGS) $(OTHER_CXXFLAGS) $(CXXFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/$@ + +priority_queue: OTHER_CXXFLAGS += -std=c++17 +zalloc_buddy: OTHER_CFLAGS += -Wno-format-pedantic + +os_refcnt: OTHER_CFLAGS += -I$(SRCROOT)/../libkern/ -Wno-gcc-compat -Wno-undef -O3 -flto + +kernel_inspection: CODE_SIGN_ENTITLEMENTS = ./task_for_pid_entitlement.plist +kernel_inspection: OTHER_CFLAGS += -DENTITLED=1 turnstile_multihop: OTHER_CFLAGS += -Wno-unused-macros turnstile_multihop: OTHER_CFLAGS += -I $(OBJROOT)/ @@ -126,12 +302,8 @@ install-perf_exit_proc: perf_exit_proc mkdir -p $(INSTALLDIR) cp $(SYMROOT)/perf_exit_proc $(INSTALLDIR)/ -perf_kdebug: INVALID_ARCHS = i386 - -stackshot_idle_25570396: INVALID_ARCHS = i386 stackshot_idle_25570396: OTHER_LDFLAGS += -lkdd -framework Foundation -stackshot_block_owner_14362384: INVALID_ARCHS = i386 stackshot_block_owner_14362384: OTHER_LDFLAGS += -framework Foundation -lpthread -lkdd ifeq ($(PLATFORM),MacOSX) stackshot_block_owner_14362384: OTHER_LDFLAGS += -lpcre @@ -146,8 +318,6 @@ $(DSTROOT)/usr/local/bin/kcdata: $(SRCROOT)/../tools/lldbmacros/kcdata.py xnu_quick_test: OTHER_CFLAGS += xnu_quick_test_helpers.c -xnu_quick_test_entitled: CODE_SIGN_ENTITLEMENTS = xnu_quick_test.entitlements - CUSTOM_TARGETS += vm_set_max_addr_helper vm_set_max_addr_helper: vm_set_max_addr_helper.c @@ -159,29 +329,98 @@ install-vm_set_max_addr_helper: vm_set_max_addr_helper mkdir -p $(INSTALLDIR) cp $(SYMROOT)/vm_set_max_addr_helper $(INSTALLDIR)/ +CUSTOM_TARGETS += subsystem_root_path_helper_entitled +CUSTOM_TARGETS += subsystem_root_path_helper + +subsystem_root_path_helper_entitled: subsystem_root_path_helper.c subsystem_root_path-entitlements.plist + $(CC) $(OTHER_CFLAGS) $(CFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) subsystem_root_path_helper.c -o $(SYMROOT)/subsystem_root_path_helper_entitled; \ + echo $(CODESIGN) --force --sign - --timestamp=none $(SYMROOT)/$@; \ + env CODESIGN_ALLOCATE=$(CODESIGN_ALLOCATE) $(CODESIGN) --force --sign - --timestamp=none --entitlements subsystem_root_path-entitlements.plist $(SYMROOT)/$@; + +install-subsystem_root_path_helper_entitled: subsystem_root_path_helper_entitled + mkdir -p $(INSTALLDIR) + cp $(SYMROOT)/subsystem_root_path_helper_entitled $(INSTALLDIR)/ + +subsystem_root_path_helper: subsystem_root_path_helper.c + $(CC) $(OTHER_CFLAGS) $(CFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) subsystem_root_path_helper.c -o $(SYMROOT)/subsystem_root_path_helper; \ + echo $(CODESIGN) --force --sign - --timestamp=none $(SYMROOT)/$@; \ + env CODESIGN_ALLOCATE=$(CODESIGN_ALLOCATE) $(CODESIGN) --force --sign - --timestamp=none $(SYMROOT)/$@; + +install-subsystem_root_path_helper: subsystem_root_path_helper + mkdir -p $(INSTALLDIR) + cp $(SYMROOT)/subsystem_root_path_helper $(INSTALLDIR)/ + +CUSTOM_TARGETS += vm_test_code_signing_helper + +vm_test_code_signing_helper: vm_test_code_signing_helper.c + $(CC) $(OTHER_CFLAGS) $(CFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) vm_test_code_signing_helper.c -o $(SYMROOT)/vm_test_code_signing_helper; \ + echo $(CODESIGN) --force --sign - --timestamp=none $(SYMROOT)/$@; \ + env CODESIGN_ALLOCATE=$(CODESIGN_ALLOCATE) $(CODESIGN) --force --sign - --timestamp=none $(SYMROOT)/$@; + +install-vm_test_code_signing_helper: vm_test_code_signing_helper + mkdir -p $(INSTALLDIR) + cp $(SYMROOT)/vm_test_code_signing_helper $(INSTALLDIR)/ + +vm_test_code_signing: OTHER_LDFLAGS += -ldarwintest_utils + +INCLUDED_TEST_SOURCE_DIRS += vm + +# Revert to legacy vm_test suite until gets solved +EXCLUDED_SOURCES += vm/vm_allocation.c + ifeq ($(PLATFORM),iPhoneOS) -OTHER_TEST_TARGETS += jumbo_va_spaces_28530648_unentitled +OTHER_TEST_TARGETS += jumbo_va_spaces_28530648_unentitled jumbo_va_spaces_52551256 vm_phys_footprint_legacy vm/entitlement_increased_memory_limit vm/entitlement_increased_memory_limit_unentitled jumbo_va_spaces_28530648: CODE_SIGN_ENTITLEMENTS = jumbo_va_spaces_28530648.entitlements -jumbo_va_spaces_28530648: OTHER_CFLAGS += -DENTITLED=1 +jumbo_va_spaces_28530648: OTHER_CFLAGS += -DENTITLED=1 -DTESTNAME=jumbo_va_spaces_28530648 jumbo_va_spaces_28530648: OTHER_LDFLAGS += -ldarwintest_utils +jumbo_va_spaces_52551256: CODE_SIGN_ENTITLEMENTS = jumbo_va_spaces_52551256.entitlements +jumbo_va_spaces_52551256: OTHER_CFLAGS += -DENTITLED=1 -DTESTNAME=jumbo_va_spaces_52551256 +jumbo_va_spaces_52551256: OTHER_LDFLAGS += -ldarwintest_utils +jumbo_va_spaces_52551256: jumbo_va_spaces_28530648.c + $(CC) $(DT_CFLAGS) $(OTHER_CFLAGS) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/$@ + env CODESIGN_ALLOCATE=$(CODESIGN_ALLOCATE) $(CODESIGN) --force --sign - --timestamp=none --entitlements $(CODE_SIGN_ENTITLEMENTS) $(SYMROOT)/$@; + jumbo_va_spaces_28530648_unentitled: OTHER_LDFLAGS += -ldarwintest_utils +jumbo_va_spaces_28530648_unentitled: OTHER_CFLAGS += -DTESTNAME=jumbo_va_spaces_28530648_unentitled jumbo_va_spaces_28530648_unentitled: jumbo_va_spaces_28530648.c $(CC) $(DT_CFLAGS) $(OTHER_CFLAGS) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/$@ + +vm/entitlement_increased_memory_limit: CODE_SIGN_ENTITLEMENTS = vm/entitlement_increased_memory_limit.entitlements +vm/entitlement_increased_memory_limit: OTHER_CFLAGS += -DENTITLED=1 +vm/entitlement_increased_memory_limit: OTHER_LDFLAGS += -ldarwintest_utils memorystatus_assertion_helpers.c +vm/entitlement_increased_memory_limit: vm/entitlement_increased_memory_limit.c + $(CC) $(DT_CFLAGS) $(OTHER_CFLAGS) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/$@ + env CODESIGN_ALLOCATE=$(CODESIGN_ALLOCATE) $(CODESIGN) --force --sign - --timestamp=none --entitlements $(CODE_SIGN_ENTITLEMENTS) $(SYMROOT)/$@; + +vm/entitlement_increased_memory_limit_unentitled: OTHER_LDFLAGS += -ldarwintest_utils memorystatus_assertion_helpers.c +vm/entitlement_increased_memory_limit_unentitled: vm/entitlement_increased_memory_limit.c + $(CC) $(DT_CFLAGS) $(OTHER_CFLAGS) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/$@ + +vm_phys_footprint_legacy: OTHER_LDFLAGS += -framework CoreFoundation -framework IOSurface +vm_phys_footprint_legacy: OTHER_CFLAGS += -DLEGACY_FOOTPRINT_ENTITLED=1 +vm_phys_footprint_legacy: CODE_SIGN_ENTITLEMENTS=./legacy_footprint.entitlement +vm_phys_footprint_legacy: vm_phys_footprint.c + $(CC) $(DT_CFLAGS) $(OTHER_CFLAGS) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/$@ + endif task_info_28439149: CODE_SIGN_ENTITLEMENTS = ./task_for_pid_entitlement.plist +read_inspect: CODE_SIGN_ENTITLEMENTS = ./task_for_pid_entitlement.plist + proc_info: CODE_SIGN_ENTITLEMENTS = ./task_for_pid_entitlement.plist proc_info: OTHER_LDFLAGS += -ldarwintest_utils proc_info_list_kthreads: CODE_SIGN_ENTITLEMENTS = ./proc_info_list_kthreads.entitlements +proc_info_44873309: CODE_SIGN_ENTITLEMENTS = ./proc_info_44873309.entitlements + disk_mount_conditioner: disk_mount_conditioner* disk_mount_conditioner: CODE_SIGN_ENTITLEMENTS=./disk_mount_conditioner-entitlements.plist disk_mount_conditioner: OTHER_LDFLAGS += -ldarwintest_utils -OTHER_TEST_TARGETS += disk_mount_conditioner_unentitled +disk_mount_conditioner: OTHER_TEST_TARGETS += disk_mount_conditioner_unentitled disk_mount_conditioner_unentitled: OTHER_CFLAGS += -DTEST_UNENTITLED disk_mount_conditioner_unentitled: OTHER_LDFLAGS += -ldarwintest_utils disk_mount_conditioner_unentitled: disk_mount_conditioner.c @@ -196,21 +435,33 @@ settimeofday_29193041_entitled: CODE_SIGN_ENTITLEMENTS = settimeofday_29193041.e settimeofday_29193041_entitled: OTHER_CFLAGS += drop_priv.c thread_group_set_32261625: OTHER_LDFLAGS = -framework ktrace -thread_group_set_32261625: INVALID_ARCHS = i386 task_info: CODE_SIGN_ENTITLEMENTS = task_for_pid_entitlement.plist +task_info: OTHER_CFLAGS += test_utils.c + +extract_right_soft_fail: CODE_SIGN_ENTITLEMENTS = task_for_pid_entitlement.plist + +ifneq ($(PLATFORM),iPhoneOS) + EXCLUDED_SOURCES += task_vm_info_decompressions.c +endif socket_bind_35243417: CODE_SIGN_ENTITLEMENTS = network_entitlements.plist socket_bind_35685803: CODE_SIGN_ENTITLEMENTS = network_entitlements.plist net_tuntests: CODE_SIGN_ENTITLEMENTS = network_entitlements.plist -ifneq (osx,$(TARGET_NAME)) -EXCLUDED_SOURCES += no32exec_35914211.c no32exec_35914211_helper.c -endif +net_bridge: OTHER_CFLAGS += bpflib.c in_cksum.c +net_bridge: OTHER_LDFLAGS += -ldarwintest_utils -no32exec_35914211_helper: INVALID_ARCHS = x86_64 -no32exec_35914211: INVALID_ARCHS = i386 +CUSTOM_TARGETS += posix_spawn_archpref_helper + +posix_spawn_archpref_helper: + $(CC) $(LDFLAGS) $(CFLAGS) posix_spawn_archpref_helper.c -o $(SYMROOT)/$@; + env CODESIGN_ALLOCATE=$(CODESIGN_ALLOCATE) $(CODESIGN) --force --sign - --timestamp=none $(SYMROOT)/$@; + +install-posix_spawn_archpref_helper: + mkdir -p $(INSTALLDIR) + cp $(SYMROOT)/posix_spawn_archpref_helper $(INSTALLDIR)/ MIG:=SDKROOT=$(SDKROOT) $(shell xcrun -sdk "$(TARGETSDK)" -find mig) @@ -224,12 +475,32 @@ excserver: excserver.defs install-excserver: ; +EXCLUDED_SOURCES += exc_helpers.c + + +x18: OTHER_CFLAGS += -Wno-language-extension-token + exc_resource_threads: excserver exc_resource_threads: OTHER_CFLAGS += $(OBJROOT)/excserver.c -I $(OBJROOT) -ifneq (osx,$(TARGET_NAME)) -EXCLUDED_SOURCES += ldt_code32.s ldt.c +fp_exception: excserver exc_helpers.c +fp_exception: OTHER_CFLAGS += $(OBJROOT)/excserver.c -I $(OBJROOT) + +ptrauth_failure: excserver exc_helpers.c +ptrauth_failure: OTHER_CFLAGS += $(OBJROOT)/excserver.c -I $(OBJROOT) -Wno-language-extension-token +ptrauth_failure: CODESIGN = $(CODESIGN_HARDENED_RUNTIME) + +# This test currently relies on pid_hibernate(), which is only available on embedded platforms. +ifeq ($(PLATFORM),MacOSX) +EXCLUDED_SOURCES += decompression_failure.c else +decompression_failure: excserver exc_helpers.c +decompression_failure: OTHER_CFLAGS += $(OBJROOT)/excserver.c -I $(OBJROOT) +endif + +ifeq ($(findstring x86_64,$(ARCH_CONFIGS)),) +EXCLUDED_SOURCES += ldt_code32.s ldt.c +else # target = osx $(OBJROOT)/ldt_mach_exc_server.c: $(MIG) $(CFLAGS) \ -user /dev/null \ @@ -237,9 +508,10 @@ $(OBJROOT)/ldt_mach_exc_server.c: -header $(OBJROOT)/ldt_mach_exc.h \ mach_exc.defs -ldt: INVALID_ARCHS = i386 +ldt: INVALID_ARCHS = $(ARCH_CONFIGS) ldt: $(OBJROOT)/ldt_mach_exc_server.c -ldt: OTHER_CFLAGS += -I $(OBJROOT) $(SRCROOT)/ldt_code32.s -Wl,-pagezero_size,0x1000 +ldt: OTHER_CFLAGS += -arch x86_64 -I $(OBJROOT) $(SRCROOT)/ldt_code32.s -Wl,-pagezero_size,0x1000 -Wno-missing-variable-declarations +ldt: CODE_SIGN_ENTITLEMENTS=ldt_entitlement.plist endif ifneq ($(PLATFORM),BridgeOS) @@ -249,8 +521,190 @@ remote_time: INVALID_ARCHS = armv7 armv7s arm64_32 endif vm_phys_footprint: OTHER_LDFLAGS += -framework CoreFoundation -framework IOSurface -vm_phys_footprint_legacy: legacy_footprint.entitlement -vm_phys_footprint_legacy: OTHER_LDFLAGS += -framework CoreFoundation -framework IOSurface -vm_phys_footprint_legacy: CODE_SIGN_ENTITLEMENTS=./legacy_footprint.entitlement + +vm_kern_count_wired_kernelcache: OTHER_CFLAGS += -I$(SDKROOT)/System/Library/Frameworks/Kernel.framework/PrivateHeaders/mach + +debug_control_port_for_pid: CODE_SIGN_ENTITLEMENTS = ./debug_control_port_for_pid_entitlement.plist + +prng: OTHER_LDFLAGS += -ldarwintest_utils + +preoslog: OTHER_LDFLAGS += -ldarwintest_utils +preoslog: OTHER_CFLAGS += test_utils.c + +task_policy: CODE_SIGN_ENTITLEMENTS = ./task_policy_entitlement.plist + +OTHER_TEST_TARGETS += task_policy_unentitled +task_policy_unentitled: CODE_SIGN_ENTITLEMENTS = task_for_pid_entitlement.plist +task_policy_unentitled: OTHER_CFLAGS += -DUNENTITLED +task_policy_unentitled: task_policy.c + $(CC) $(DT_CFLAGS) $(OTHER_CFLAGS) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/$@ + $(CODESIGN) --force --sign - --timestamp=none --entitlements $(CODE_SIGN_ENTITLEMENTS) $(SYMROOT)/$@ + + +EXCLUDED_SOURCES += get_shared_cache_address.c +ifeq ($(PLATFORM),iPhoneOS) +CUSTOM_TARGETS += get_shared_cache_address +get_shared_cache_address: INVALID_ARCHS = arm64 +get_shared_cache_address: get_shared_cache_address.c + $(CC) $(OTHER_CFLAGS) $(CFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/get_shared_cache_address + +install-get_shared_cache_address: get_shared_cache_address + $(CODESIGN) --force --sign - --timestamp=none --identifier=com.apple.get_shared_cache_address $(SYMROOT)/get_shared_cache_address + mkdir -p $(INSTALLDIR) + cp $(SYMROOT)/get_shared_cache_address $(INSTALLDIR)/ +endif + +ifneq ($(PLATFORM),MacOSX) +EXCLUDED_SOURCES += hvtest_x86.m hvtest_x86_guest.c hvtest_x86_asm.s +else +EXCLUDED_SOURCES += hvtest_x86_guest.c hvtest_x86_asm.s +hvtest_x86: CODE_SIGN_ENTITLEMENTS = hv_public.entitlements +hvtest_x86: INVALID_ARCHS += arm64e arm64 i386 +hvtest_x86: OTHER_CFLAGS += hvtest_x86_guest.c hvtest_x86_asm.s -framework Hypervisor -framework Foundation +endif + +OTHER_TEST_TARGETS += io_catalog_send_data vm_memory_share_tests + +vm_memory_share_tests: INVALID_ARCHS = i386 +vm_memory_share_tests: CODE_SIGN_ENTITLEMENTS = ./task_for_pid_entitlement.plist +vm_memory_share_tests: vm_memory_tests_src/main.c vm_memory_tests_src/common.c vm_memory_tests_src/vm_tests.c + $(CC) $(DT_CFLAGS) $(OTHER_CFLAGS) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $^ -o $(SYMROOT)/$@ + echo $(CODESIGN) --force --sign - --timestamp=none --entitlements $(SRCROOT)/$(CODE_SIGN_ENTITLEMENTS) $(SYMROOT)/$@; + env CODESIGN_ALLOCATE=$(CODESIGN_ALLOCATE) $(CODESIGN) --force --sign - --timestamp=none --entitlements "$(SRCROOT)/$(CODE_SIGN_ENTITLEMENTS)" $(SYMROOT)/$@; + +# build the mach server as individual helper which does not use libdarwintest +CUSTOM_TARGETS += vm_memory_share_tests_server +vm_memory_share_tests_server: CODE_SIGN_ENTITLEMENTS = ./task_for_pid_entitlement.plist +vm_memory_share_tests_server: vm_memory_tests_src/server.c vm_memory_tests_src/common.c vm_memory_tests_src/vm_tests.c + $(CC) $(DT_CFLAGS) $(OTHER_CFLAGS) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $^ -o $(SYMROOT)/vm_memory_share_tests_server + echo $(CODESIGN) --force --sign - --timestamp=none --entitlements $(SRCROOT)/$(CODE_SIGN_ENTITLEMENTS) $(SYMROOT)/$@; + env CODESIGN_ALLOCATE=$(CODESIGN_ALLOCATE) $(CODESIGN) --force --sign - --timestamp=none --entitlements "$(SRCROOT)/$(CODE_SIGN_ENTITLEMENTS)" $(SYMROOT)/$@; + +install-vm_memory_share_tests_server: vm_memory_share_tests_server + mkdir -p $(INSTALLDIR) + cp $(SYMROOT)/vm_memory_share_tests_server $(INSTALLDIR)/ + +io_catalog_send_data: INVALID_ARCHS = i386 +io_catalog_send_data: OTHER_CFLAGS += -DTEST_UNENTITLED -framework IOKit -framework CoreFoundation -framework Foundation + +io_catalog_send_data: iokit/io_catalog_send_data.m + $(CC) $(DT_CFLAGS) $(OTHER_CFLAGS) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/$@ + +ifeq ($(PLATFORM),MacOSX) +EXCLUDED_SOURCES += vm/kern_max_task_pmem.c +endif + +EXCLUDED_SOURCES += benchmark/helpers.c + +perf_vmfault: OTHER_CFLAGS += benchmark/helpers.c + +fault_throughput: vm/fault_throughput.c + mkdir -p $(SYMROOT)/vm + $(CC) $(DT_CFLAGS) $(OTHER_CFLAGS) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/vm/$@ +fault_throughput: OTHER_CFLAGS += benchmark/helpers.c + +install-fault_throughput: fault_throughput + mkdir -p $(INSTALLDIR)/vm + cp $(SYMROOT)/vm/fault_throughput $(INSTALLDIR)/vm/ + +BATS_PLISTS += $(SRCROOT)/vm/fault_throughput.plist + +fault_throughput_benchrun: + mkdir -p $(SYMROOT)/vm + cp $(SRCROOT)/vm/fault_throughput.lua $(SYMROOT)/vm/fault_throughput.lua + chmod +x $(SYMROOT)/vm/fault_throughput.lua + +install-fault_throughput_benchrun: fault_throughput_benchrun + mkdir -p $(INSTALLDIR)/vm + cp $(SYMROOT)/vm/fault_throughput.lua $(INSTALLDIR)/vm + chmod +x $(INSTALLDIR)/vm/fault_throughput.lua + +CUSTOM_TARGETS += fault_throughput fault_throughput_benchrun +EXCLUDED_SOURCES += vm/fault_throughput.plist vm/fault_throughput.c + +perf_madvise: vm/perf_madvise.c + mkdir -p $(SYMROOT)/vm + $(CC) $(DT_CFLAGS) $(OTHER_CFLAGS) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/vm/$@ +perf_madvise: OTHER_CFLAGS += benchmark/helpers.c +install-perf_madvise: perf_madvise + mkdir -p $(INSTALLDIR)/vm + cp $(SYMROOT)/vm/perf_madvise $(INSTALLDIR)/vm/ +perf_madvise_benchrun: + mkdir -p $(SYMROOT)/vm + cp $(SRCROOT)/vm/perf_madvise.lua $(SYMROOT)/vm/perf_madvise.lua + chmod +x $(SYMROOT)/vm/perf_madvise.lua +install-perf_madvise_benchrun: perf_madvise_benchrun + mkdir -p $(INSTALLDIR)/vm + cp $(SYMROOT)/vm/perf_madvise.lua $(INSTALLDIR)/vm + chmod +x $(INSTALLDIR)/vm/perf_madvise.lua + +CUSTOM_TARGETS += perf_madvise perf_madvise_benchrun +EXCLUDED_SOURCES += vm/perf_madvise.c + +task_create_suid_cred: CODE_SIGN_ENTITLEMENTS = ./task_create_suid_cred_entitlement.plist + +OTHER_TEST_TARGETS += task_create_suid_cred_unentitled +task_create_suid_cred_unentitled: OTHER_CFLAGS += -DUNENTITLED +task_create_suid_cred_unentitled: task_create_suid_cred.c + $(CC) $(DT_CFLAGS) $(OTHER_CFLAGS) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/$@ + +ioconnectasyncmethod_57641955: OTHER_LDFLAGS += -framework IOKit + +ifeq ($(PLATFORM),BridgeOS) +EXCLUDED_SOURCES += ipsec.m +else +ipsec: OTHER_LDFLAGS += -framework Foundation -framework CoreFoundation -framework NetworkExtension +ipsec: CODE_SIGN_ENTITLEMENTS = ipsec.entitlements +endif + +test_sysctl_kern_procargs_25397314: OTHER_LDFLAGS += -framework Foundation -ldarwintest_utils + +INCLUDED_TEST_SOURCE_DIRS += counter + +EXCLUDED_SOURCES += counter/common.c +counter/counter: OTHER_CFLAGS += counter/common.c test_utils.c +counter/counter: OTHER_LDFLAGS += -ldarwintest_utils -ldarwintest + +counter/benchmark: counter/benchmark.c + mkdir -p $(SYMROOT)/counter + $(CC) $(DT_CFLAGS) $(OTHER_CFLAGS) $(CFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/$@ + env CODESIGN_ALLOCATE=$(CODESIGN_ALLOCATE) $(CODESIGN) --force --sign - --timestamp=none $(SYMROOT)/$@; + +counter/benchmark: OTHER_CFLAGS += counter/common.c benchmark/helpers.c + +install-counter/benchmark: counter/benchmark + mkdir -p $(INSTALLDIR)/counter + cp $(SYMROOT)/counter/benchmark $(INSTALLDIR)/counter/ + +counter/benchmark_benchrun: + mkdir -p $(SYMROOT)/counter + cp $(SRCROOT)/counter/benchmark.lua $(SYMROOT)/counter/benchmark.lua + chmod +x $(SYMROOT)/counter/benchmark.lua + +install-counter/benchmark_benchrun: counter/benchmark_benchrun + mkdir -p $(INSTALLDIR)/counter + cp $(SYMROOT)/counter/benchmark.lua $(INSTALLDIR)/counter/ + chmod +x $(INSTALLDIR)/counter/benchmark.lua + +CUSTOM_TARGETS += counter/benchmark counter/benchmark_benchrun +EXCLUDED_SOURCES += counter/benchmark.c + +ifneq ($(PLATFORM),MacOSX) +EXCLUDED_SOURCES += vm/page_size_globals.c +else +vm/page_size_globals: INVALID_ARCHS = arm64 arm64e +endif + +INCLUDED_TEST_SOURCE_DIRS += lockf_uaf_poc include $(DEVELOPER_DIR)/AppleInternal/Makefiles/darwintest/Makefile.targets + +trial_experiments: CODE_SIGN_ENTITLEMENTS = trial_experiments.entitlements +trial_experiments: OTHER_CFLAGS += -DENTITLED=1 test_utils.c drop_priv.c +trial_experiments: trial_experiments.c + $(CC) $(DT_CFLAGS) $(OTHER_CFLAGS) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/$@ + env CODESIGN_ALLOCATE=$(CODESIGN_ALLOCATE) $(CODESIGN) --force --sign - --timestamp=none --entitlements $(CODE_SIGN_ENTITLEMENTS) $(SYMROOT)/$@; + +trial_experiments_unentitled: OTHER_CFLAGS += drop_priv.c test_utils.c +trial_experiments_unentitled: trial_experiments.c + $(CC) $(DT_CFLAGS) $(OTHER_CFLAGS) $(CFLAGS) $(DT_LDFLAGS) $(OTHER_LDFLAGS) $(LDFLAGS) $< -o $(SYMROOT)/$@