diff --git a/lib/libc/darwin/SDKSettings.json b/lib/libc/darwin/SDKSettings.json index 49b37aec1f..8f700cfab9 100644 --- a/lib/libc/darwin/SDKSettings.json +++ b/lib/libc/darwin/SDKSettings.json @@ -1 +1 @@ -{"MinimalDisplayName":"15.5"} +{"MinimalDisplayName":"26.0"} diff --git a/lib/libc/darwin/libSystem.tbd b/lib/libc/darwin/libSystem.tbd index 850860f385..9003fefd95 100644 --- a/lib/libc/darwin/libSystem.tbd +++ b/lib/libc/darwin/libSystem.tbd @@ -3,7 +3,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/libSystem.B.dylib' -current-version: 1351 +current-version: 1356 reexported-libraries: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -25,7 +25,8 @@ reexported-libraries: '/usr/lib/system/libsystem_pthread.dylib', '/usr/lib/system/libsystem_sandbox.dylib', '/usr/lib/system/libsystem_sanitizers.dylib', '/usr/lib/system/libsystem_secinit.dylib', '/usr/lib/system/libsystem_symptoms.dylib', '/usr/lib/system/libsystem_trace.dylib', - '/usr/lib/system/libunwind.dylib', '/usr/lib/system/libxpc.dylib' ] + '/usr/lib/system/libsystem_trial.dylib', '/usr/lib/system/libunwind.dylib', + '/usr/lib/system/libxpc.dylib' ] exports: - targets: [ x86_64-macos, x86_64-maccatalyst ] symbols: [ 'R8289209$_close', 'R8289209$_fork', 'R8289209$_fsync', 'R8289209$_getattrlist', @@ -399,7 +400,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libcorecrypto.dylib' -current-version: 1736.120.5 +current-version: 1922.0.25 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -450,18 +451,18 @@ exports: _cccbc_one_shot_explicit, _cccbc_set_iv, _cccbc_update, _ccccm_aad, _ccccm_block_size, _ccccm_cbcmac, _ccccm_context_size, _ccccm_decrypt, _ccccm_encrypt, _ccccm_finalize, _ccccm_finalize_and_generate_tag, - _ccccm_finalize_and_verify_tag, _ccccm_init, _ccccm_one_shot, - _ccccm_one_shot_decrypt, _ccccm_one_shot_encrypt, _ccccm_reset, - _ccccm_set_iv, _ccccm_update, _cccfb8_block_size, _cccfb8_context_size, - _cccfb8_init, _cccfb8_one_shot, _cccfb8_update, _cccfb_block_size, - _cccfb_context_size, _cccfb_init, _cccfb_one_shot, _cccfb_update, - _ccchacha20, _ccchacha20_final, _ccchacha20_init, _ccchacha20_reset, - _ccchacha20_setcounter, _ccchacha20_setnonce, _ccchacha20_update, - _ccchacha20poly1305_aad, _ccchacha20poly1305_decrypt, _ccchacha20poly1305_decrypt_oneshot, - _ccchacha20poly1305_encrypt, _ccchacha20poly1305_encrypt_oneshot, - _ccchacha20poly1305_finalize, _ccchacha20poly1305_incnonce, - _ccchacha20poly1305_info, _ccchacha20poly1305_init, _ccchacha20poly1305_reset, - _ccchacha20poly1305_setnonce, _ccchacha20poly1305_verify, + _ccccm_finalize_and_verify_tag, _ccccm_init, _ccccm_nonce_size, + _ccccm_one_shot, _ccccm_one_shot_decrypt, _ccccm_one_shot_encrypt, + _ccccm_reset, _ccccm_set_iv, _ccccm_update, _cccfb8_block_size, + _cccfb8_context_size, _cccfb8_init, _cccfb8_one_shot, _cccfb8_update, + _cccfb_block_size, _cccfb_context_size, _cccfb_init, _cccfb_one_shot, + _cccfb_update, _ccchacha20, _ccchacha20_final, _ccchacha20_init, + _ccchacha20_reset, _ccchacha20_setcounter, _ccchacha20_setnonce, + _ccchacha20_update, _ccchacha20poly1305_aad, _ccchacha20poly1305_decrypt, + _ccchacha20poly1305_decrypt_oneshot, _ccchacha20poly1305_encrypt, + _ccchacha20poly1305_encrypt_oneshot, _ccchacha20poly1305_finalize, + _ccchacha20poly1305_incnonce, _ccchacha20poly1305_info, _ccchacha20poly1305_init, + _ccchacha20poly1305_reset, _ccchacha20poly1305_setnonce, _ccchacha20poly1305_verify, _ccckg2_contributor_commit, _ccckg2_contributor_finish, _ccckg2_ctx_cp, _ccckg2_ctx_di, _ccckg2_init, _ccckg2_owner_finish, _ccckg2_owner_generate_share, _ccckg2_params_p224_sha256_v2, _ccckg2_sizeof_commitment, @@ -530,14 +531,15 @@ exports: _ccdh_gp_rfc3526group18, _ccdh_gp_rfc5114_MODP_1024_160, _ccdh_gp_rfc5114_MODP_2048_224, _ccdh_gp_rfc5114_MODP_2048_256, _ccdh_gp_size, _ccdh_import_full, _ccdh_import_priv, _ccdh_import_pub, _ccdh_init_gp_from_bytes, - _ccdigest, _ccdigest_init, _ccdigest_oid_lookup, _ccdigest_update, - _ccdrbg_context_size, _ccdrbg_df_bc_init, _ccdrbg_done, _ccdrbg_factory_nistctr, - _ccdrbg_factory_nisthmac, _ccdrbg_generate, _ccdrbg_init, - _ccdrbg_must_reseed, _ccdrbg_reseed, _ccec_affinify, _ccec_blind, - _ccec_compact_export, _ccec_compact_export_pub, _ccec_compact_generate_key, - _ccec_compact_generate_key_init, _ccec_compact_generate_key_step, - _ccec_compact_import_priv, _ccec_compact_import_priv_size, - _ccec_compact_import_pub, _ccec_compact_import_pub_size, _ccec_compact_transform_key, + _ccdigest, _ccdigest_init, _ccdigest_oid_lookup, _ccdigest_parallel, + _ccdigest_update, _ccdrbg_context_size, _ccdrbg_df_bc_init, + _ccdrbg_done, _ccdrbg_factory_nistctr, _ccdrbg_factory_nisthmac, + _ccdrbg_generate, _ccdrbg_init, _ccdrbg_must_reseed, _ccdrbg_reseed, + _ccec_affinify, _ccec_blind, _ccec_compact_export, _ccec_compact_export_pub, + _ccec_compact_generate_key, _ccec_compact_generate_key_init, + _ccec_compact_generate_key_step, _ccec_compact_import_priv, + _ccec_compact_import_priv_size, _ccec_compact_import_pub, + _ccec_compact_import_pub_size, _ccec_compact_transform_key, _ccec_compressed_x962_export_pub, _ccec_compressed_x962_export_pub_size, _ccec_compressed_x962_import_pub, _ccec_compute_key, _ccec_cp_192, _ccec_cp_224, _ccec_cp_256, _ccec_cp_384, _ccec_cp_521, _ccec_curve_for_length_lookup, @@ -623,29 +625,44 @@ exports: _cchpke_params_sizeof_kem_enc, _cchpke_params_sizeof_kem_pk, _cchpke_params_sizeof_kem_pk_marshalled, _cchpke_params_sizeof_kem_shared_secret, _cchpke_params_sizeof_kem_sk, _cchpke_params_x25519_AESGCM128_HKDF_SHA256, + _cchpke_params_x25519_AESGCM256_HKDF_SHA256, _cchpke_params_xwing_AESGCM128_HKDF_SHA256, _cchpke_responder_decrypt, _cchpke_responder_export, _cchpke_responder_open, _cchpke_responder_setup, _cckem_decapsulate, _cckem_derive_key_from_seed, _cckem_encapsulate, _cckem_encapsulated_key_nbytes_ctx, _cckem_encapsulated_key_nbytes_info, _cckem_export_privkey, _cckem_export_pubkey, _cckem_full_ctx_init, - _cckem_generate_key, _cckem_import_privkey, _cckem_import_pubkey, - _cckem_kyber1024, _cckem_kyber768, _cckem_privkey_nbytes_ctx, - _cckem_privkey_nbytes_info, _cckem_pub_ctx_init, _cckem_pubkey_nbytes_ctx, - _cckem_pubkey_nbytes_info, _cckem_public_ctx, _cckem_shared_key_nbytes_ctx, - _cckem_shared_key_nbytes_info, _cckem_sizeof_full_ctx, _cckem_sizeof_pub_ctx, + _cckem_generate_key, _cckem_generate_key_with_seed, _cckem_import_privkey, + _cckem_import_pubkey, _cckem_kyber1024, _cckem_kyber768, _cckem_mlkem1024, + _cckem_mlkem768, _cckem_privkey_nbytes_ctx, _cckem_privkey_nbytes_info, + _cckem_pub_ctx_init, _cckem_pubkey_nbytes_ctx, _cckem_pubkey_nbytes_info, + _cckem_public_ctx, _cckem_seed_nbytes_ctx, _cckem_seed_nbytes_info, + _cckem_shared_key_nbytes_ctx, _cckem_shared_key_nbytes_info, + _cckem_sizeof_full_ctx, _cckem_sizeof_pub_ctx, _cckem_xwing_mlkem768x25519, _cclr_aes_init, _cclr_block_nbytes, _cclr_decrypt_block, _cclr_encrypt_block, _ccmd2_ltc_di, _ccmd4_ltc_di, _ccmd5_di, _ccmd5_ltc_di, _ccmgf, - _ccmode_factory_cbc_decrypt, _ccmode_factory_cbc_encrypt, - _ccmode_factory_ccm_decrypt, _ccmode_factory_ccm_encrypt, - _ccmode_factory_cfb8_decrypt, _ccmode_factory_cfb8_encrypt, - _ccmode_factory_cfb_decrypt, _ccmode_factory_cfb_encrypt, - _ccmode_factory_ctr_crypt, _ccmode_factory_gcm_decrypt, _ccmode_factory_gcm_encrypt, - _ccmode_factory_ofb_crypt, _ccmode_factory_siv_decrypt, _ccmode_factory_siv_encrypt, - _ccmode_factory_xts_decrypt, _ccmode_factory_xts_encrypt, - _ccn_add, _ccn_add1, _ccn_bitlen, _ccn_cmp, _ccn_cmpn, _ccn_lprint, - _ccn_print, _ccn_read_uint, _ccn_set_bit, _ccn_seti, _ccn_sub, - _ccn_swap, _ccn_write_int, _ccn_write_int_size, _ccn_write_uint, - _ccn_write_uint_padded, _ccn_write_uint_padded_ct, _ccn_write_uint_size, - _ccn_xor, _ccn_zero, _ccnistkdf_ctr_cmac, _ccnistkdf_ctr_cmac_fixed, + _ccmldsa65, _ccmldsa87, _ccmldsa_derive_key_from_seed, _ccmldsa_export_privkey, + _ccmldsa_export_pubkey, _ccmldsa_full_ctx_init, _ccmldsa_generate_key, + _ccmldsa_generate_key_with_seed, _ccmldsa_hash_nbytes_ctx, + _ccmldsa_hash_nbytes_params, _ccmldsa_import_privkey, _ccmldsa_import_pubkey, + _ccmldsa_prehash, _ccmldsa_prehash_with_context, _ccmldsa_privkey_nbytes_ctx, + _ccmldsa_privkey_nbytes_params, _ccmldsa_pub_ctx_init, _ccmldsa_pubkey_nbytes_ctx, + _ccmldsa_pubkey_nbytes_params, _ccmldsa_public_ctx, _ccmldsa_seed_nbytes_ctx, + _ccmldsa_seed_nbytes_params, _ccmldsa_sign, _ccmldsa_sign_prehashed, + _ccmldsa_sign_with_context, _ccmldsa_signature_nbytes_ctx, + _ccmldsa_signature_nbytes_params, _ccmldsa_sizeof_full_ctx, + _ccmldsa_sizeof_pub_ctx, _ccmldsa_verify, _ccmldsa_verify_prehashed, + _ccmldsa_verify_with_context, _ccmode_factory_cbc_decrypt, + _ccmode_factory_cbc_encrypt, _ccmode_factory_ccm_decrypt, + _ccmode_factory_ccm_encrypt, _ccmode_factory_cfb8_decrypt, + _ccmode_factory_cfb8_encrypt, _ccmode_factory_cfb_decrypt, + _ccmode_factory_cfb_encrypt, _ccmode_factory_ctr_crypt, _ccmode_factory_gcm_decrypt, + _ccmode_factory_gcm_encrypt, _ccmode_factory_ofb_crypt, _ccmode_factory_siv_decrypt, + _ccmode_factory_siv_encrypt, _ccmode_factory_xts_decrypt, + _ccmode_factory_xts_encrypt, _ccn_add, _ccn_add1, _ccn_bitlen, + _ccn_cmp, _ccn_cmpn, _ccn_lprint, _ccn_print, _ccn_read_uint, + _ccn_set_bit, _ccn_seti, _ccn_sub, _ccn_swap, _ccn_write_int, + _ccn_write_int_size, _ccn_write_uint, _ccn_write_uint_padded, + _ccn_write_uint_padded_ct, _ccn_write_uint_size, _ccn_xor, + _ccn_zero, _ccnistkdf_ctr_cmac, _ccnistkdf_ctr_cmac_fixed, _ccnistkdf_ctr_hmac, _ccnistkdf_ctr_hmac_fixed, _ccofb_block_size, _ccofb_context_size, _ccofb_init, _ccofb_one_shot, _ccofb_update, _ccoid_equal, _ccoid_payload, _ccoid_size, _ccpad_cts1_decrypt, @@ -692,35 +709,36 @@ exports: _ccsae_init_p384_sha384, _ccsae_lexographic_order_key, _ccsae_sizeof_commitment, _ccsae_sizeof_confirmation, _ccsae_sizeof_ctx, _ccsae_sizeof_kck, _ccsae_sizeof_kck_h2c, _ccsae_sizeof_pt, _ccsae_verify_commitment, - _ccsae_verify_confirmation, _ccscrypt, _ccscrypt_storage_size, - _ccsha1_di, _ccsha1_eay_di, _ccsha1_ltc_di, _ccsha224_di, - _ccsha224_ltc_di, _ccsha256_di, _ccsha256_ltc_di, _ccsha384_di, - _ccsha384_ltc_di, _ccsha3_224_di, _ccsha3_256_di, _ccsha3_384_di, - _ccsha3_512_di, _ccsha512_256_di, _ccsha512_256_ltc_di, _ccsha512_di, - _ccsha512_ltc_di, _ccsigma_clear, _ccsigma_clear_key, _ccsigma_compute_mac, - _ccsigma_derive_session_keys, _ccsigma_export_key_share, _ccsigma_import_peer_key_share, - _ccsigma_import_peer_verification_key, _ccsigma_import_signing_key, - _ccsigma_init, _ccsigma_kex_init_ctx, _ccsigma_kex_resp_ctx, - _ccsigma_mfi_info, _ccsigma_mfi_nvm_info, _ccsigma_open, _ccsigma_peer_role, - _ccsigma_seal, _ccsigma_set_signing_function, _ccsigma_sign, - _ccsigma_verify, _ccsiv_aad, _ccsiv_block_size, _ccsiv_ciphertext_size, - _ccsiv_context_size, _ccsiv_crypt, _ccsiv_hmac_aad, _ccsiv_hmac_block_size, - _ccsiv_hmac_ciphertext_size, _ccsiv_hmac_context_size, _ccsiv_hmac_crypt, - _ccsiv_hmac_init, _ccsiv_hmac_one_shot, _ccsiv_hmac_plaintext_size, - _ccsiv_hmac_reset, _ccsiv_hmac_set_nonce, _ccsiv_init, _ccsiv_one_shot, - _ccsiv_plaintext_size, _ccsiv_reset, _ccsiv_set_nonce, _ccspake_cp_256, - _ccspake_cp_256_rfc, _ccspake_cp_384, _ccspake_cp_384_rfc, - _ccspake_cp_521, _ccspake_cp_521_rfc, _ccspake_generate_L, - _ccspake_kex_generate, _ccspake_kex_process, _ccspake_mac_compute, - _ccspake_mac_hkdf_cmac_aes128_sha256, _ccspake_mac_hkdf_hmac_sha256, - _ccspake_mac_hkdf_hmac_sha512, _ccspake_mac_verify_and_get_session_key, - _ccspake_prover_init, _ccspake_prover_initialize, _ccspake_reduce_w, - _ccspake_reduce_w_RFC9383, _ccspake_sizeof_ctx, _ccspake_sizeof_point, - _ccspake_sizeof_w, _ccspake_verifier_init, _ccspake_verifier_initialize, - _ccsrp_client_process_challenge, _ccsrp_client_set_noUsernameInX, - _ccsrp_client_start_authentication, _ccsrp_client_verify_session, - _ccsrp_ctx_init, _ccsrp_ctx_init_option, _ccsrp_ctx_init_with_size_option, - _ccsrp_exchange_size, _ccsrp_generate_salt_and_verification, + _ccsae_verify_commitment_with_rejected_groups, _ccsae_verify_confirmation, + _ccscrypt, _ccscrypt_storage_size, _ccsha1_di, _ccsha1_eay_di, + _ccsha1_ltc_di, _ccsha224_di, _ccsha224_ltc_di, _ccsha256_di, + _ccsha256_ltc_di, _ccsha384_di, _ccsha384_ltc_di, _ccsha3_224_di, + _ccsha3_256_di, _ccsha3_384_di, _ccsha3_512_di, _ccsha512_256_di, + _ccsha512_256_ltc_di, _ccsha512_di, _ccsha512_ltc_di, _ccsigma_clear, + _ccsigma_clear_key, _ccsigma_compute_mac, _ccsigma_derive_session_keys, + _ccsigma_exclave_pairing_info, _ccsigma_export_key_share, + _ccsigma_import_peer_key_share, _ccsigma_import_peer_verification_key, + _ccsigma_import_signing_key, _ccsigma_init, _ccsigma_kex_init_ctx, + _ccsigma_kex_resp_ctx, _ccsigma_mfi_info, _ccsigma_mfi_nvm_info, + _ccsigma_open, _ccsigma_peer_role, _ccsigma_seal, _ccsigma_set_signing_function, + _ccsigma_sign, _ccsigma_verify, _ccsiv_aad, _ccsiv_block_size, + _ccsiv_ciphertext_size, _ccsiv_context_size, _ccsiv_crypt, + _ccsiv_hmac_aad, _ccsiv_hmac_block_size, _ccsiv_hmac_ciphertext_size, + _ccsiv_hmac_context_size, _ccsiv_hmac_crypt, _ccsiv_hmac_init, + _ccsiv_hmac_one_shot, _ccsiv_hmac_plaintext_size, _ccsiv_hmac_reset, + _ccsiv_hmac_set_nonce, _ccsiv_init, _ccsiv_one_shot, _ccsiv_plaintext_size, + _ccsiv_reset, _ccsiv_set_nonce, _ccspake_cp_256, _ccspake_cp_256_rfc, + _ccspake_cp_384, _ccspake_cp_384_rfc, _ccspake_cp_521, _ccspake_cp_521_rfc, + _ccspake_generate_L, _ccspake_get_session_key, _ccspake_kex_generate, + _ccspake_kex_process, _ccspake_mac_compute, _ccspake_mac_hkdf_cmac_aes128_sha256, + _ccspake_mac_hkdf_hmac_sha256, _ccspake_mac_hkdf_hmac_sha512, + _ccspake_mac_verify_and_get_session_key, _ccspake_prover_init, + _ccspake_prover_initialize, _ccspake_reduce_w, _ccspake_reduce_w_RFC9383, + _ccspake_sizeof_ctx, _ccspake_sizeof_point, _ccspake_sizeof_w, + _ccspake_verifier_init, _ccspake_verifier_initialize, _ccsrp_client_process_challenge, + _ccsrp_client_set_noUsernameInX, _ccsrp_client_start_authentication, + _ccsrp_client_verify_session, _ccsrp_ctx_init, _ccsrp_ctx_init_option, + _ccsrp_ctx_init_with_size_option, _ccsrp_exchange_size, _ccsrp_generate_salt_and_verification, _ccsrp_generate_verifier, _ccsrp_get_premaster_secret, _ccsrp_get_session_key, _ccsrp_get_session_key_length, _ccsrp_gp_rfc5054_1024, _ccsrp_gp_rfc5054_2048, _ccsrp_gp_rfc5054_3072, _ccsrp_gp_rfc5054_4096, _ccsrp_gp_rfc5054_8192, @@ -770,7 +788,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libdispatch.dylib' -current-version: 1521.120.4 +current-version: 1542.0.4 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -870,7 +888,8 @@ exports: _dispatch_queue_create, _dispatch_queue_create_with_accounting_override_voucher, _dispatch_queue_create_with_target, '_dispatch_queue_create_with_target$V2', _dispatch_queue_get_label, _dispatch_queue_get_qos_class, - _dispatch_queue_get_specific, _dispatch_queue_offsets, _dispatch_queue_set_label_nocopy, + _dispatch_queue_get_specific, _dispatch_queue_get_threadid_4wdt, + _dispatch_queue_offsets, _dispatch_queue_set_label_nocopy, _dispatch_queue_set_specific, _dispatch_queue_set_width, _dispatch_read, _dispatch_read_f, _dispatch_release, _dispatch_resume, _dispatch_retain, _dispatch_semaphore_create, _dispatch_semaphore_signal, _dispatch_semaphore_wait, @@ -887,8 +906,8 @@ exports: _dispatch_swift_job_should_yield, _dispatch_sync, _dispatch_sync_f, _dispatch_thread_get_current_override_qos_floor, _dispatch_thread_override_self, _dispatch_time, _dispatch_time_from_nsec, _dispatch_time_to_nsec, - _dispatch_time_to_nsecs, _dispatch_tsd_indexes, _dispatch_walltime, - _dispatch_workloop_copy_current, _dispatch_workloop_create, + _dispatch_time_to_nsecs, _dispatch_tsd_indexes, _dispatch_verify_current_queue_4swiftonly, + _dispatch_walltime, _dispatch_workloop_copy_current, _dispatch_workloop_create, _dispatch_workloop_create_inactive, _dispatch_workloop_is_current, _dispatch_workloop_set_autorelease_frequency, _dispatch_workloop_set_cpupercent, _dispatch_workloop_set_os_workgroup, _dispatch_workloop_set_qos_class, @@ -907,18 +926,20 @@ exports: _os_workgroup_create_with_workload_id_and_port, _os_workgroup_create_with_workload_id_and_workgroup, _os_workgroup_get_working_arena, _os_workgroup_interval_copy_current_4AudioToolbox, _os_workgroup_interval_create, _os_workgroup_interval_create_with_workload_id, - _os_workgroup_interval_data_set_flags, _os_workgroup_interval_data_set_telemetry, - _os_workgroup_interval_finish, _os_workgroup_interval_start, - _os_workgroup_interval_update, _os_workgroup_join, _os_workgroup_join_self, - _os_workgroup_leave, _os_workgroup_leave_self, _os_workgroup_max_parallel_threads, + _os_workgroup_interval_data_set_complexity, _os_workgroup_interval_data_set_flags, + _os_workgroup_interval_data_set_telemetry, _os_workgroup_interval_finish, + _os_workgroup_interval_start, _os_workgroup_interval_update, + _os_workgroup_join, _os_workgroup_join_self, _os_workgroup_leave, + _os_workgroup_leave_self, _os_workgroup_max_parallel_threads, _os_workgroup_parallel_create, _os_workgroup_set_working_arena, _os_workgroup_testcancel, _voucher_activity_create_with_data, _voucher_activity_create_with_data_2, _voucher_activity_create_with_location, _voucher_activity_flush, _voucher_activity_get_logging_preferences, - _voucher_activity_get_metadata_buffer, _voucher_activity_id_allocate, - _voucher_activity_initialize_4libtrace, _voucher_activity_should_send_strings, - _voucher_activity_trace, _voucher_activity_trace_v, _voucher_activity_trace_v_2, - _voucher_adopt, _voucher_copy, _voucher_copy_with_persona_mach_voucher, + _voucher_activity_get_logging_preferences_with_port, _voucher_activity_get_metadata_buffer, + _voucher_activity_id_allocate, _voucher_activity_initialize_4libtrace, + _voucher_activity_should_send_strings, _voucher_activity_trace, + _voucher_activity_trace_v, _voucher_activity_trace_v_2, _voucher_adopt, + _voucher_copy, _voucher_copy_with_persona_mach_voucher, _voucher_copy_with_persona_mach_voucher_and_error, _voucher_copy_without_importance, _voucher_create_with_mach_msg, _voucher_decrement_importance_count4CF, _voucher_get_activity_id, _voucher_get_activity_id_and_creator, _voucher_get_current_persona, @@ -938,6 +959,8 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libdyld.dylib' +current-version: 0 +compatibility-version: 0 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -947,8 +970,9 @@ exports: arm64e-macos, arm64e-maccatalyst ] symbols: [ _NSVersionOfLinkTimeLibrary, _NSVersionOfRunTimeLibrary, _NXArgc, _NXArgv, __NSGetExecutablePath, ___progname, __dyld_atfork_parent, - __dyld_atfork_prepare, __dyld_dlopen_atfork_child, __dyld_dlopen_atfork_parent, - __dyld_dlopen_atfork_prepare, __dyld_dlsym_blocked, __dyld_find_foreign_type_protocol_conformance, + __dyld_atfork_prepare, __dyld_call_with_writable_tpro_memory, + __dyld_dlopen_atfork_child, __dyld_dlopen_atfork_parent, __dyld_dlopen_atfork_prepare, + __dyld_dlsym_blocked, __dyld_find_foreign_type_protocol_conformance, __dyld_find_foreign_type_protocol_conformance_on_disk, __dyld_find_pointer_hash_table_entry, __dyld_find_protocol_conformance, __dyld_find_protocol_conformance_on_disk, __dyld_find_unwind_sections, __dyld_for_each_objc_class, __dyld_for_each_objc_protocol, @@ -1011,8 +1035,8 @@ exports: _macho_cpu_type_for_arch_name, _macho_dylib_install_name, _macho_for_each_defined_rpath, _macho_for_each_dependent_dylib, _macho_for_each_exported_symbol, _macho_for_each_imported_symbol, - _macho_for_each_slice, _macho_for_each_slice_in_fd, _macho_source_version, - dyld_stub_binder ] + _macho_for_each_runnable_arch_name, _macho_for_each_slice, + _macho_for_each_slice_in_fd, _macho_source_version, dyld_stub_binder ] - targets: [ x86_64-macos, arm64-macos, arm64e-macos ] symbols: [ _NSAddImage, _NSAddLibrary, _NSAddLibraryWithSearching, _NSAddressOfSymbol, _NSCreateObjectFileImageFromFile, _NSCreateObjectFileImageFromMemory, @@ -1052,7 +1076,7 @@ exports: tbd-version: 4 targets: [ x86_64-macos, arm64-macos, arm64e-macos ] install-name: '/usr/lib/system/libmacho.dylib' -current-version: 1024.3 +current-version: 1030.6.3 parent-umbrella: - targets: [ x86_64-macos, arm64-macos, arm64e-macos ] umbrella: System @@ -1092,7 +1116,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libquarantine.dylib' -current-version: 181.120.2 +current-version: 196.0.1 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -1104,7 +1128,8 @@ exports: __qtn_file_apply_to_path, __qtn_file_clone, __qtn_file_free, __qtn_file_get_flags, __qtn_file_get_identifier, __qtn_file_get_metadata, __qtn_file_get_metadata_size, __qtn_file_get_timestamp, __qtn_file_init, - __qtn_file_init_with_data, __qtn_file_init_with_fd, __qtn_file_init_with_mount_point, + __qtn_file_init_with_data, __qtn_file_init_with_disk_image_backing_store, + __qtn_file_init_with_fd, __qtn_file_init_with_mount_point, __qtn_file_init_with_path, __qtn_file_set_flags, __qtn_file_set_identifier, __qtn_file_set_metadata, __qtn_file_set_timestamp, __qtn_file_to_data, __qtn_label_name, __qtn_proc_alloc, __qtn_proc_apply_to_pid, @@ -1138,7 +1163,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libremovefile.dylib' -current-version: 81 +current-version: 84 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -1156,7 +1181,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libsystem_asl.dylib' -current-version: 402 +current-version: 404 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -1256,7 +1281,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libsystem_c.dylib' -current-version: 1698.100.8 +current-version: 1725.0.11 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -1398,36 +1423,37 @@ exports: _fwscanf, _fwscanf_l, _fxprintf, _fxprintf_exec, _gcvt, _getbsize, _getc, _getc_unlocked, _getchar, _getchar_unlocked, _getcwd, _getdate, _getdate_err, _getdelim, _getdiskbyname, _getenv, - '_getgroups$DARWIN_EXTSN', _gethostid, _gethostname, _getipv4sourcefilter, - _getlastlogx, _getlastlogxbyname, _getline, _getloadavg, _getlogin, - _getlogin_r, _getmntinfo, _getmntinfo_r_np, _getmode, _getopt, - _getopt_long, _getopt_long_only, _getpagesize, _getpass, _getpeereid, - _getprogname, _gets, _getsourcefilter, _getsubopt, _gettimeofday, - _getttyent, _getttynam, _getusershell, _getutmp, _getutmpx, - _getutxent, _getutxent_wtmp, _getutxid, _getutxline, _getvfsbyname, - _getw, _getwc, _getwc_l, _getwchar, _getwchar_l, _getwd, _glob, - _glob_b, _globfree, _gmtime, _gmtime_r, _grantpt, _hash_create, - _hash_destroy, _hash_purge, _hash_search, _hash_stats, _hash_traverse, - _hcreate, _hdestroy, _heapsort, _heapsort_b, _hsearch, _imaxabs, - _imaxdiv, _inet_addr, _inet_aton, _inet_lnaof, _inet_makeaddr, - _inet_net_ntop, _inet_net_pton, _inet_neta, _inet_netof, _inet_network, - _inet_nsap_addr, _inet_nsap_ntoa, _inet_ntoa, _inet_ntop, - _inet_ntop4, _inet_ntop6, _inet_pton, _initstate, _insque, - _isalnum, _isalnum_l, _isalpha, _isalpha_l, _isascii, _isatty, - _isblank, _isblank_l, _iscntrl, _iscntrl_l, _isdigit, _isdigit_l, - _isgraph, _isgraph_l, _ishexnumber, _ishexnumber_l, _isideogram, - _isideogram_l, _islower, _islower_l, _isnumber, _isnumber_l, - _isphonogram, _isphonogram_l, _isprint, _isprint_l, _ispunct, - _ispunct_l, _isrune, _isrune_l, _isspace, _isspace_l, _isspecial, - _isspecial_l, _isupper, _isupper_l, _iswalnum, _iswalnum_l, - _iswalpha, _iswalpha_l, _iswascii, _iswblank, _iswblank_l, - _iswcntrl, _iswcntrl_l, _iswctype, _iswctype_l, _iswdigit, - _iswdigit_l, _iswgraph, _iswgraph_l, _iswhexnumber, _iswhexnumber_l, - _iswideogram, _iswideogram_l, _iswlower, _iswlower_l, _iswnumber, - _iswnumber_l, _iswphonogram, _iswphonogram_l, _iswprint, _iswprint_l, - _iswpunct, _iswpunct_l, _iswrune, _iswrune_l, _iswspace, _iswspace_l, - _iswspecial, _iswspecial_l, _iswupper, _iswupper_l, _iswxdigit, - _iswxdigit_l, _isxdigit, _isxdigit_l, _jrand48, _kOSThermalNotificationPressureLevelName, + _getenv_copy_np, '_getgroups$DARWIN_EXTSN', _gethostid, _gethostname, + _getipv4sourcefilter, _getlastlogx, _getlastlogxbyname, _getline, + _getloadavg, _getlogin, _getlogin_r, _getmntinfo, _getmntinfo_r_np, + _getmode, _getopt, _getopt_long, _getopt_long_only, _getpagesize, + _getpass, _getpeereid, _getprogname, _gets, _getsourcefilter, + _getsubopt, _gettimeofday, _getttyent, _getttynam, _getusershell, + _getutmp, _getutmpx, _getutxent, _getutxent_wtmp, _getutxid, + _getutxline, _getvfsbyname, _getw, _getwc, _getwc_l, _getwchar, + _getwchar_l, _getwd, _glob, _glob_b, _globfree, _gmtime, _gmtime_r, + _grantpt, _hash_create, _hash_destroy, _hash_purge, _hash_search, + _hash_stats, _hash_traverse, _hcreate, _hdestroy, _heapsort, + _heapsort_b, _hsearch, _imaxabs, _imaxdiv, _inet_addr, _inet_aton, + _inet_lnaof, _inet_makeaddr, _inet_net_ntop, _inet_net_pton, + _inet_neta, _inet_netof, _inet_network, _inet_nsap_addr, _inet_nsap_ntoa, + _inet_ntoa, _inet_ntop, _inet_ntop4, _inet_ntop6, _inet_pton, + _initstate, _insque, _isalnum, _isalnum_l, _isalpha, _isalpha_l, + _isascii, _isatty, _isblank, _isblank_l, _iscntrl, _iscntrl_l, + _isdigit, _isdigit_l, _isgraph, _isgraph_l, _ishexnumber, + _ishexnumber_l, _isideogram, _isideogram_l, _islower, _islower_l, + _isnumber, _isnumber_l, _isphonogram, _isphonogram_l, _isprint, + _isprint_l, _ispunct, _ispunct_l, _isrune, _isrune_l, _isspace, + _isspace_l, _isspecial, _isspecial_l, _isupper, _isupper_l, + _iswalnum, _iswalnum_l, _iswalpha, _iswalpha_l, _iswascii, + _iswblank, _iswblank_l, _iswcntrl, _iswcntrl_l, _iswctype, + _iswctype_l, _iswdigit, _iswdigit_l, _iswgraph, _iswgraph_l, + _iswhexnumber, _iswhexnumber_l, _iswideogram, _iswideogram_l, + _iswlower, _iswlower_l, _iswnumber, _iswnumber_l, _iswphonogram, + _iswphonogram_l, _iswprint, _iswprint_l, _iswpunct, _iswpunct_l, + _iswrune, _iswrune_l, _iswspace, _iswspace_l, _iswspecial, + _iswspecial_l, _iswupper, _iswupper_l, _iswxdigit, _iswxdigit_l, + _isxdigit, _isxdigit_l, _jrand48, _kOSThermalNotificationPressureLevelName, _killpg, _l64a, _labs, _lchflags, _lchmod, _lcong48, _ldiv, _lfind, _libc_set_introspection_hooks, _link_addr, _link_ntoa, _llabs, _lldiv, _localeconv, _localeconv_l, _localtime, _localtime_r, @@ -1552,7 +1578,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libsystem_collections.dylib' -current-version: 1698.100.8 +current-version: 1725.0.11 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -1582,7 +1608,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libsystem_configuration.dylib' -current-version: 1351.120.3 +current-version: 1385.0.7 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -1616,9 +1642,14 @@ parent-umbrella: exports: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] - symbols: [ _CMCONTAINERSEAM_DEFAULT, _CMFSSEAM_DEFAULT, _CMPWDSEAM_DEFAULT, - _CONTAINER_NOTIFY_USER_INVALIDATED, _CONTAINER_PERSONA_CURRENT, - _CONTAINER_PERSONA_PRIMARY, __container_init, __container_query_get_servicing_pid, + symbols: [ _CMCONTAINERSEAM_DEFAULT, _CMDISPATCHSEAM_DEFAULT, _CMFSSEAM_DEFAULT, + _CMNOTIFYSEAM_DEFAULT, _CMPWDSEAM_DEFAULT, _CMSANDBOXSEAM_DEFAULT, + _CONTAINER_CLASS_NAMES, _CONTAINER_NOTIFY_GENERATION_INITIAL, + _CONTAINER_NOTIFY_GENERATION_INVALID, _CONTAINER_NOTIFY_USER_INVALIDATED, + _CONTAINER_PERSONA_CURRENT, _CONTAINER_PERSONA_PRIMARY, __container_init, + __container_notify_copy_notify_name, __container_query_get_next_result_sync, + __container_query_get_result_at_index, __container_query_get_servicing_pid, + __container_query_operation_set_private_flags, __container_query_reset_iterator, __container_references_get_servicing_pid, __container_traverse_continuation_create, __container_traverse_continuation_free, __container_traverse_continuation_pop, __container_traverse_continuation_push, __container_traverse_get_last_path_component, @@ -1630,12 +1661,14 @@ exports: _container_audit_token_for_pid, _container_audit_token_get_codesign_status, _container_audit_token_get_egid, _container_audit_token_get_euid, _container_audit_token_get_pid, _container_audit_token_get_platform, - _container_audit_token_is_valid, _container_base64_decode, - _container_base64_decode_string, _container_base64_encode, - _container_base64_encode_string, _container_bundle_copy_data_container, - _container_bundle_copy_data_container_path, _container_class_for_each_normalized_class, - _container_class_normalized, _container_class_supports_data_subdirectory, - _container_class_supports_randomized_path, _container_class_supports_randomized_path_on_current_platform, + _container_audit_token_is_valid, _container_authorize, _container_authorize_container, + _container_authorize_container_for_self, _container_authorize_get_result_description, + _container_base64_decode, _container_base64_decode_string, + _container_base64_encode, _container_base64_encode_string, + _container_bundle_copy_data_container, _container_bundle_copy_data_container_path, + _container_class_for_each_normalized_class, _container_class_normalized, + _container_class_supports_data_subdirectory, _container_class_supports_randomized_path, + _container_class_supports_randomized_path_on_current_platform, _container_client_copy_decoded_from_xpc_object, _container_client_copy_encoded_xpc_object, _container_client_copy_entitlement, _container_client_create_from_audit_token, _container_client_get_audit_token, _container_client_get_codesign_identifier, @@ -1668,9 +1701,10 @@ exports: _container_disk_usage, _container_disposition, _container_disposition_for_array, _container_entitlements_copy_container_identifiers, _container_error_copy, _container_error_copy_unlocalized_description, _container_error_create, - _container_error_free, _container_error_get_category, _container_error_get_path, - _container_error_get_posix_errno, _container_error_get_type, - _container_error_is_fatal, _container_error_is_file_system_error, + _container_error_create_with_message, _container_error_free, + _container_error_get_category, _container_error_get_message, + _container_error_get_path, _container_error_get_posix_errno, + _container_error_get_type, _container_error_is_fatal, _container_error_is_file_system_error, _container_error_reinitialize, _container_flush_container_cache, _container_flush_persona_cache, _container_free_array_of_containers, _container_free_client, _container_free_object, _container_frozenset_copyout_external_bytes, @@ -1702,10 +1736,17 @@ exports: _container_log_ext_error_with_faults, _container_log_handle_for_category, _container_log_replication_disable, _container_log_replication_enable_to_uid_relative_path, _container_log_replication_prune_for_uid, _container_log_set_client_fault_logging, - _container_object_copy, _container_object_create, _container_object_create_blank, - _container_object_free, _container_object_get_class, _container_object_get_creator_codesign_identifier, - _container_object_get_identifier, _container_object_get_info, - _container_object_get_path, _container_object_get_persona_unique_string, + _container_notify_create, _container_notify_create_with_class, + _container_notify_create_with_initial_gen_count, _container_notify_free, + _container_notify_get_generation, _container_notify_get_last_error, + _container_notify_has_changed, _container_notify_increment_generation, + _container_notify_post, _container_notify_set_class, _container_notify_set_event_handler, + _container_notify_set_flags, _container_notify_set_generation, + _container_notify_set_queue, _container_notify_set_uid, _container_notify_start, + _container_notify_stop, _container_object_copy, _container_object_create, + _container_object_create_blank, _container_object_free, _container_object_get_class, + _container_object_get_creator_codesign_identifier, _container_object_get_identifier, + _container_object_get_info, _container_object_get_path, _container_object_get_persona_unique_string, _container_object_get_query, _container_object_get_sandbox_token, _container_object_get_uid, _container_object_get_unique_path_component, _container_object_get_user_managed_assets_relative_path, _container_object_get_uuid, @@ -1723,22 +1764,23 @@ exports: _container_paths_context_set_flags, _container_paths_context_set_persona_unique_string, _container_paths_context_set_transient, _container_paths_context_set_uid, _container_paths_copy_container_at, _container_paths_copy_container_from_path, - _container_paths_copy_container_root_path_for_context, _container_paths_copy_uid_home_relative, - _container_paths_create_uid_home_relative, _container_paths_enumerate_containers_at, - _container_perfect_hash_copyout_external_bytes, _container_perfect_hash_count, - _container_perfect_hash_create, _container_perfect_hash_create_from_external_bytes, - _container_perfect_hash_destroy, _container_perfect_hash_index_of, - _container_perfect_hash_num_indexes, _container_perform_with_client_context, - _container_persona_collect_all_ids, _container_persona_convert_unique_string_to_persona_uid, - _container_persona_foreach, _container_process_restored_container, - _container_pwd_copy_user_home_path, _container_pwd_for_name, - _container_pwd_for_uid, _container_pwd_get_cached_current_user_home_path, + _container_paths_copy_container_root_path_for_context, _container_paths_copy_part_subpath, + _container_paths_copy_uid_home_relative, _container_paths_create_uid_home_relative, + _container_paths_enumerate_containers_at, _container_perfect_hash_copyout_external_bytes, + _container_perfect_hash_count, _container_perfect_hash_create, + _container_perfect_hash_create_from_external_bytes, _container_perfect_hash_destroy, + _container_perfect_hash_index_of, _container_perfect_hash_num_indexes, + _container_perform_with_client_context, _container_persona_collect_all_ids, + _container_persona_convert_unique_string_to_persona_uid, _container_persona_foreach, + _container_process_restored_container, _container_pwd_copy_user_home_path, + _container_pwd_for_name, _container_pwd_for_uid, _container_pwd_get_cached_current_user_home_path, _container_pwd_get_mobile_user_uid, _container_query_copy, _container_query_count_results, _container_query_create, _container_query_create_from_container, _container_query_free, _container_query_get_last_error, _container_query_get_single_result, _container_query_iterate_results_sync, _container_query_iterate_results_with_identifier_sync, _container_query_iterate_results_with_subquery_sync, _container_query_operation_set_client, - _container_query_operation_set_flags, _container_query_operation_set_platform, + _container_query_operation_set_flags, _container_query_operation_set_part, + _container_query_operation_set_part_domain, _container_query_operation_set_platform, _container_query_set_class, _container_query_set_group_identifiers, _container_query_set_identifiers, _container_query_set_include_other_owners, _container_query_set_persona_unique_string, _container_query_set_transient, @@ -1748,9 +1790,12 @@ exports: _container_retry_test, _container_sandbox_extension_consume, _container_sandbox_extension_revoke, _container_sandbox_issue_custom_extension, _container_sandbox_issue_extension, _container_seam_container_reset, - _container_seam_container_set_common, _container_seam_fs_ensure_lazy_loaded, - _container_seam_fs_reset, _container_seam_fs_set_common, _container_seam_pwd_reset, - _container_seam_pwd_set_common, _container_serialize_copy_deserialized_reference, + _container_seam_container_set_common, _container_seam_dispatch_reset, + _container_seam_dispatch_set_common, _container_seam_fs_ensure_lazy_loaded, + _container_seam_fs_reset, _container_seam_fs_set_common, _container_seam_notify_reset, + _container_seam_notify_set_common, _container_seam_pwd_reset, + _container_seam_pwd_set_common, _container_seam_sandbox_reset, + _container_seam_sandbox_set_common, _container_serialize_copy_deserialized_reference, _container_serialize_copy_serialized_reference, _container_set_code_signing_info_for_identifier, _container_set_data_protection_for_current_user, _container_set_info_value, _container_set_test_lock, _container_stage_shared_system_content, @@ -1785,7 +1830,8 @@ exports: _container_xpc_set_incoming_reply_preprocess_block, _container_xpc_set_outgoing_message_postprocess_block, _container_xpc_set_outgoing_message_send_block, _container_xpc_set_use_shared_connection, _container_xpc_shared_copy_connection, _gCMContainerSeam, - _gCMFSSeam, _gCMPWDSeam ] + _gCMDispatchSeam, _gCMFSSeam, _gCMNotifySeam, _gCMPWDSeam, + _gCMSandboxSeam ] - targets: [ x86_64-maccatalyst, arm64-maccatalyst, arm64e-maccatalyst ] symbols: [ _CONTAINER_CURRENT_MOBILE_UID, _CONTAINER_INSTALLATION_UID, _CONTAINER_SYSTEM_UID, _container_create_or_lookup, _container_create_or_lookup_app_group_paths, @@ -1813,13 +1859,13 @@ exports: arm64e-macos, arm64e-maccatalyst ] symbols: [ _NSGetNextSearchPathEnumeration, _NSStartSearchPathEnumeration, _NSStartSearchPathEnumerationPrivate, ___user_local_dirname, - ___user_relative_dirname, __append_relative_path_component, - __dirhelper, __dirhelper_relative, __get_user_dir_suffix, - __libcoreservices_fork_child, __set_user_dir_suffix, _sysdir_get_next_search_path_enumeration, - _sysdir_start_search_path_enumeration, _sysdir_start_search_path_enumeration_private ] + ___user_relative_dirname, __dirhelper, __dirhelper_relative, + __get_user_dir_suffix, __libcoreservices_fork_child, __set_user_dir_suffix, + _sysdir_get_next_search_path_enumeration, _sysdir_start_search_path_enumeration, + _sysdir_start_search_path_enumeration_private ] - targets: [ x86_64-macos, arm64-macos, arm64e-macos ] symbols: [ ___user_relative_dirname_with_hints, __dirhelper_relative_with_hints, - __idle_exit ] + __dirhelper_remove_test, __dirhelper_test, __idle_exit ] --- !tapi-tbd tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, @@ -1879,7 +1925,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libsystem_dnssd.dylib' -current-version: 2600.120.12 +current-version: 2881.0.25 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -1916,7 +1962,7 @@ exports: tbd-version: 4 targets: [ x86_64-macos, arm64-macos, arm64e-macos ] install-name: '/usr/lib/system/libsystem_eligibility.dylib' -current-version: 181.120.32 +current-version: 286 parent-umbrella: - targets: [ x86_64-macos, arm64-macos, arm64e-macos ] umbrella: System @@ -1934,7 +1980,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libsystem_featureflags.dylib' -current-version: 97 +current-version: 101 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -2072,7 +2118,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libsystem_kernel.dylib' -current-version: 11417.121.6 +current-version: 12377.1.9 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -2217,7 +2263,8 @@ exports: _debug_syscall_reject, _debug_syscall_reject_config, _denap_boost_assertion_token, _disconnectx, _dup, _dup2, _errno, _etap_trace_thread, _exc_server, _exc_server_routine, _exception_raise, _exception_raise_state, - _exception_raise_state_identity, _exchangedata, _exclaves_audio_buffer_copyout, + _exception_raise_state_identity, _exchangedata, _exclaves_aoe_message_loop, + _exclaves_aoe_setup, _exclaves_aoe_work_loop, _exclaves_audio_buffer_copyout, _exclaves_audio_buffer_copyout_with_status, _exclaves_audio_buffer_create, _exclaves_boot, _exclaves_endpoint_call, _exclaves_inbound_buffer_copyin, _exclaves_inbound_buffer_create, _exclaves_indicator_min_on_time, @@ -2235,9 +2282,9 @@ exports: _fs_snapshot_revert, _fs_snapshot_root, _fsctl, _fsetattrlist, _fsetxattr, _fsgetpath, _fsgetpath_ext, _fstat, _fstat64, _fstatat, _fstatat64, _fstatfs, _fstatfs64, _fstatfs_ext, - _fsync, '_fsync$NOCANCEL', _ftruncate, _futimens, _futimes, - _getattrlist, _getattrlistat, _getattrlistbulk, _getaudit, - _getaudit_addr, _getauid, _getdirentries, _getdirentriesattr, + _fsync, '_fsync$NOCANCEL', _ftruncate, _funmount, _futimens, + _futimes, _getattrlist, _getattrlistat, _getattrlistbulk, + _getaudit, _getaudit_addr, _getauid, _getdirentries, _getdirentriesattr, _getdtablesize, _getegid, _getentropy, _geteuid, _getfh, _getfsstat, _getfsstat64, _getgid, _getgroups, _gethostuuid, _getiopolicy_np, _getitimer, _getpeername, _getpgid, _getpgrp, _getpid, _getppid, @@ -2280,13 +2327,14 @@ exports: _mach_eventlink_wait_until, _mach_generate_activity_id, _mach_get_times, _mach_host_self, _mach_host_special_port_description, _mach_host_special_port_for_id, _mach_init, _mach_make_memory_entry, _mach_make_memory_entry_64, - _mach_memory_entry_access_tracking, _mach_memory_entry_ownership, - _mach_memory_entry_purgable_control, _mach_memory_info, _mach_memory_object_memory_entry, - _mach_memory_object_memory_entry_64, _mach_msg, _mach_msg2_internal, - _mach_msg2_trap, _mach_msg_destroy, _mach_msg_overwrite, _mach_msg_overwrite_trap, - _mach_msg_priority_encode, _mach_msg_priority_is_pthread_priority, - _mach_msg_priority_overide_qos, _mach_msg_priority_qos, _mach_msg_priority_relpri, - _mach_msg_receive, _mach_msg_send, _mach_msg_server, _mach_msg_server_importance, + _mach_memory_entry_access_tracking, _mach_memory_entry_get_page_counts, + _mach_memory_entry_ownership, _mach_memory_entry_purgable_control, + _mach_memory_info, _mach_memory_object_memory_entry, _mach_memory_object_memory_entry_64, + _mach_msg, _mach_msg2_internal, _mach_msg2_trap, _mach_msg_destroy, + _mach_msg_overwrite, _mach_msg_overwrite_trap, _mach_msg_priority_encode, + _mach_msg_priority_is_pthread_priority, _mach_msg_priority_overide_qos, + _mach_msg_priority_qos, _mach_msg_priority_relpri, _mach_msg_receive, + _mach_msg_send, _mach_msg_server, _mach_msg_server_importance, _mach_msg_server_once, _mach_msg_trap, _mach_notify_dead_name, _mach_notify_no_senders, _mach_notify_port_deleted, _mach_notify_port_destroyed, _mach_notify_send_once, _mach_port_allocate, _mach_port_allocate_full, @@ -2313,18 +2361,21 @@ exports: _mach_thread_special_port_for_id, _mach_timebase_info, _mach_timebase_info_trap, _mach_vm_allocate, _mach_vm_behavior_set, _mach_vm_copy, _mach_vm_deallocate, _mach_vm_deferred_reclamation_buffer_allocate, _mach_vm_deferred_reclamation_buffer_flush, - _mach_vm_deferred_reclamation_buffer_resize, _mach_vm_deferred_reclamation_buffer_update_reclaimable_bytes, + _mach_vm_deferred_reclamation_buffer_query, _mach_vm_deferred_reclamation_buffer_resize, _mach_vm_inherit, _mach_vm_machine_attribute, _mach_vm_map, _mach_vm_msync, _mach_vm_page_info, _mach_vm_page_query, _mach_vm_page_range_query, _mach_vm_protect, _mach_vm_purgable_control, _mach_vm_range_create, _mach_vm_read, _mach_vm_read_list, _mach_vm_read_overwrite, - _mach_vm_reclaim_is_reusable, _mach_vm_reclaim_query_state, - _mach_vm_reclaim_ring_allocate, _mach_vm_reclaim_ring_capacity, + _mach_vm_reclaim_copied_ring_free, _mach_vm_reclaim_copied_ring_query, + _mach_vm_reclaim_get_rings_for_task, _mach_vm_reclaim_is_reusable, + _mach_vm_reclaim_query_state, _mach_vm_reclaim_ring_allocate, + _mach_vm_reclaim_ring_capacity, _mach_vm_reclaim_ring_copy, _mach_vm_reclaim_ring_flush, _mach_vm_reclaim_ring_resize, _mach_vm_reclaim_round_capacity, _mach_vm_reclaim_try_cancel, _mach_vm_reclaim_try_enter, _mach_vm_reclaim_update_kernel_accounting, - _mach_vm_region, _mach_vm_region_recurse, _mach_vm_remap, - _mach_vm_remap_new, _mach_vm_update_pointers_with_remote_tags, + _mach_vm_reclaim_update_kernel_accounting_trap, _mach_vm_region, + _mach_vm_region_recurse, _mach_vm_remap, _mach_vm_remap_new, + _mach_vm_tag_describe, _mach_vm_update_pointers_with_remote_tags, _mach_vm_wire, _mach_vm_write, _mach_voucher_attr_command, _mach_voucher_deallocate, _mach_voucher_debug_info, _mach_voucher_extract_all_attr_recipes, _mach_voucher_extract_attr_content, _mach_voucher_extract_attr_recipe, @@ -2360,10 +2411,11 @@ exports: _os_channel_create, _os_channel_create_extended, _os_channel_destroy, _os_channel_event_free, _os_channel_event_get_event_data, _os_channel_event_get_next_event, _os_channel_flow_admissible, - _os_channel_flow_adv_get_ce_count, _os_channel_get_advisory_region, - _os_channel_get_fd, _os_channel_get_interface_advisory, _os_channel_get_next_event_handle, - _os_channel_get_next_slot, _os_channel_get_stats_region, _os_channel_is_defunct, - _os_channel_large_packet_alloc, _os_channel_packet_alloc, + _os_channel_flow_adv_get_ce_count, _os_channel_flow_adv_get_feedback, + _os_channel_get_advisory_region, _os_channel_get_fd, _os_channel_get_interface_advisory, + _os_channel_get_next_event_handle, _os_channel_get_next_slot, + _os_channel_get_stats_region, _os_channel_get_upp_buffer_stats, + _os_channel_is_defunct, _os_channel_large_packet_alloc, _os_channel_packet_alloc, _os_channel_packet_free, _os_channel_packet_pool_purge, _os_channel_pending, _os_channel_read_attr, _os_channel_read_nexus_extension_info, _os_channel_ring_id, _os_channel_ring_notify_time, _os_channel_ring_sync_time, @@ -2381,8 +2433,8 @@ exports: _os_nexus_controller_get_fd, _os_nexus_controller_iterate_traffic_rules, _os_nexus_controller_read_provider_attr, _os_nexus_controller_register_provider, _os_nexus_controller_remove_traffic_rule, _os_nexus_controller_unbind_provider_instance, - _os_nexus_flow_set_wake_from_sleep, _os_packet_add_buflet, - _os_packet_add_inet_csum_flags, _os_packet_clear_flow_uuid, + _os_nexus_flow_set_connection_idle, _os_nexus_flow_set_wake_from_sleep, + _os_packet_add_buflet, _os_packet_add_inet_csum_flags, _os_packet_clear_flow_uuid, _os_packet_decrement_use_count, _os_packet_finalize, _os_packet_get_aggregation_type, _os_packet_get_buflet_count, _os_packet_get_compression_generation_count, _os_packet_get_data_length, _os_packet_get_expire_time, _os_packet_get_expiry_action, @@ -2407,15 +2459,16 @@ exports: _os_packet_set_traffic_class, _os_packet_set_transport_last_packet, _os_packet_set_transport_retransmit, _os_packet_set_transport_traffic_background, _os_packet_set_transport_traffic_realtime, _os_packet_set_tso_flags, - _os_packet_set_tx_timestamp, _os_packet_set_vlan_tag, _os_packet_trace_event, - _os_proc_available_memory, _panic, _panic_init, _panic_with_data, - _pathconf, _peeloff, _pid_for_task, _pid_hibernate, _pid_resume, - _pid_shutdown_networking, _pid_shutdown_sockets, _pid_suspend, - _pipe, _pivot_root, _pkt_subtype_assert_fail, _pkt_type_assert_fail, - _poll, '_poll$NOCANCEL', _port_obj_init, _port_obj_table, - _port_obj_table_size, _posix_madvise, _posix_spawn, _posix_spawn_file_actions_add_fileportdup2_np, - _posix_spawn_file_actions_addchdir_np, _posix_spawn_file_actions_addclose, - _posix_spawn_file_actions_adddup2, _posix_spawn_file_actions_addfchdir_np, + _os_packet_set_tx_timestamp, _os_packet_set_vlan_tag, _os_packet_set_wake_flag, + _os_packet_trace_event, _os_proc_available_memory, _panic, + _panic_init, _panic_with_data, _pathconf, _peeloff, _pid_for_task, + _pid_hibernate, _pid_resume, _pid_shutdown_networking, _pid_shutdown_sockets, + _pid_suspend, _pipe, _pivot_root, _poll, '_poll$NOCANCEL', + _port_obj_init, _port_obj_table, _port_obj_table_size, _posix_madvise, + _posix_spawn, _posix_spawn_file_actions_add_fileportdup2_np, + _posix_spawn_file_actions_addchdir, _posix_spawn_file_actions_addchdir_np, + _posix_spawn_file_actions_addclose, _posix_spawn_file_actions_adddup2, + _posix_spawn_file_actions_addfchdir, _posix_spawn_file_actions_addfchdir_np, _posix_spawn_file_actions_addinherit_np, _posix_spawn_file_actions_addopen, _posix_spawn_file_actions_destroy, _posix_spawn_file_actions_init, _posix_spawnattr_destroy, _posix_spawnattr_disable_ptr_auth_a_keys_np, @@ -2426,73 +2479,74 @@ exports: _posix_spawnattr_getpgroup, _posix_spawnattr_getprocesstype_np, _posix_spawnattr_getsigdefault, _posix_spawnattr_getsigmask, _posix_spawnattr_init, _posix_spawnattr_set_alt_rosetta_np, - _posix_spawnattr_set_conclave_id_np, _posix_spawnattr_set_crash_behavior_deadline_np, - _posix_spawnattr_set_crash_behavior_np, _posix_spawnattr_set_crash_count_np, - _posix_spawnattr_set_csm_np, _posix_spawnattr_set_darwin_role_np, - _posix_spawnattr_set_filedesclimit_ext, _posix_spawnattr_set_gid_np, - _posix_spawnattr_set_groups_np, _posix_spawnattr_set_importancewatch_port_np, - _posix_spawnattr_set_jetsam_ttr_np, _posix_spawnattr_set_kqworklooplimit_ext, - _posix_spawnattr_set_launch_type_np, _posix_spawnattr_set_login_np, - _posix_spawnattr_set_max_addr_np, _posix_spawnattr_set_persona_gid_np, - _posix_spawnattr_set_persona_groups_np, _posix_spawnattr_set_persona_np, - _posix_spawnattr_set_persona_uid_np, _posix_spawnattr_set_platform_np, - _posix_spawnattr_set_portlimits_ext, _posix_spawnattr_set_ptrauth_task_port_np, - _posix_spawnattr_set_qos_clamp_np, _posix_spawnattr_set_registered_ports_np, - _posix_spawnattr_set_subsystem_root_path_np, _posix_spawnattr_set_threadlimit_ext, - _posix_spawnattr_set_uid_np, _posix_spawnattr_set_use_sec_transition_shims_np, - _posix_spawnattr_setarchpref_np, _posix_spawnattr_setauditsessionport_np, - _posix_spawnattr_setbinpref_np, _posix_spawnattr_setcoalition_np, - _posix_spawnattr_setcpumonitor, _posix_spawnattr_setcpumonitor_default, - _posix_spawnattr_setdataless_iopolicy_np, _posix_spawnattr_setexceptionports_np, - _posix_spawnattr_setflags, _posix_spawnattr_setjetsam_ext, - _posix_spawnattr_setmacpolicyinfo_np, _posix_spawnattr_setnosmt_np, - _posix_spawnattr_setpcontrol_np, _posix_spawnattr_setpgroup, - _posix_spawnattr_setprocesstype_np, _posix_spawnattr_setsigdefault, - _posix_spawnattr_setsigmask, _posix_spawnattr_setspecialport_np, - _pread, '_pread$NOCANCEL', _preadv, '_preadv$NOCANCEL', _proc_clear_cpulimits, - _proc_clear_delayidlesleep, _proc_clear_dirty, _proc_clear_vmpressure, - _proc_current_thread_schedinfo, _proc_denap_assertion_begin_with_msg, - _proc_denap_assertion_complete, _proc_disable_apptype, _proc_disable_cpumon, - _proc_disable_wakemon, _proc_donate_importance_boost, _proc_enable_apptype, - _proc_get_cpumon_params, _proc_get_dirty, _proc_get_wakemon_params, - _proc_importance_assertion_begin_with_msg, _proc_importance_assertion_complete, - _proc_kmsgbuf, _proc_libversion, _proc_list_dynkqueueids, - _proc_list_uptrs, _proc_listallpids, _proc_listchildpids, - _proc_listcoalitions, _proc_listpgrppids, _proc_listpids, - _proc_listpidspath, _proc_name, _proc_pid_rusage, _proc_piddynkqueueinfo, - _proc_pidfdinfo, _proc_pidfileportinfo, _proc_pidinfo, _proc_pidoriginatorinfo, - _proc_pidpath, _proc_pidpath_audittoken, _proc_regionfilename, - _proc_reset_footprint_interval, _proc_resume_cpumon, _proc_rlimit_control, - _proc_set_cpumon_defaults, _proc_set_cpumon_params, _proc_set_cpumon_params_fatal, - _proc_set_csm, _proc_set_delayidlesleep, _proc_set_dirty, - _proc_set_no_smt, _proc_set_owner_vmpressure, _proc_set_wakemon_defaults, - _proc_set_wakemon_params, _proc_setcpu_percentage, _proc_setpcontrol, - _proc_setthread_cpupercent, _proc_setthread_csm, _proc_setthread_no_smt, - _proc_signal_delegate, _proc_signal_with_audittoken, _proc_suppress, - _proc_terminate, _proc_terminate_all_rsr, _proc_terminate_delegate, - _proc_terminate_with_audittoken, _proc_trace_log, _proc_track_dirty, - _proc_udata_info, _proc_uuid_policy, _processor_assign, _processor_control, - _processor_exit, _processor_get_assignment, _processor_info, - _processor_set_create, _processor_set_default, _processor_set_destroy, - _processor_set_info, _processor_set_max_priority, _processor_set_policy_control, - _processor_set_policy_disable, _processor_set_policy_enable, - _processor_set_stack_usage, _processor_set_statistics, _processor_set_tasks, - _processor_set_tasks_with_flavor, _processor_set_threads, - _processor_start, _pselect, '_pselect$DARWIN_EXTSN', '_pselect$DARWIN_EXTSN$NOCANCEL', - '_pselect$NOCANCEL', _pthread_getugid_np, _pthread_setugid_np, - _ptrace, _pwrite, '_pwrite$NOCANCEL', _pwritev, '_pwritev$NOCANCEL', - _quota, _quotactl, _read, '_read$NOCANCEL', _readlink, _readlinkat, - _readv, '_readv$NOCANCEL', _reboot, _reboot_np, _record_system_event_as_kernel, - _recvfrom, '_recvfrom$NOCANCEL', _recvmsg, '_recvmsg$NOCANCEL', - _recvmsg_x, _register_uexc_handler, _removexattr, _rename, - _rename_ext, _renameat, _renameatx_np, _renamex_np, _revoke, - _rmdir, _searchfs, _select, '_select$DARWIN_EXTSN', '_select$DARWIN_EXTSN$NOCANCEL', - '_select$NOCANCEL', _sem_close, _sem_destroy, _sem_getvalue, - _sem_init, _sem_open, _sem_post, _sem_trywait, _sem_unlink, - _sem_wait, '_sem_wait$NOCANCEL', _semaphore_create, _semaphore_destroy, - _semaphore_signal, _semaphore_signal_all, _semaphore_signal_all_trap, - _semaphore_signal_thread, _semaphore_signal_thread_trap, _semaphore_signal_trap, - _semaphore_timedwait, _semaphore_timedwait_signal, _semaphore_timedwait_signal_trap, + _posix_spawnattr_set_conclave_id_np, _posix_spawnattr_set_conclavememlimit_ext, + _posix_spawnattr_set_crash_behavior_deadline_np, _posix_spawnattr_set_crash_behavior_np, + _posix_spawnattr_set_crash_count_np, _posix_spawnattr_set_csm_np, + _posix_spawnattr_set_darwin_role_np, _posix_spawnattr_set_filedesclimit_ext, + _posix_spawnattr_set_gid_np, _posix_spawnattr_set_groups_np, + _posix_spawnattr_set_importancewatch_port_np, _posix_spawnattr_set_jetsam_ttr_np, + _posix_spawnattr_set_kqworklooplimit_ext, _posix_spawnattr_set_launch_type_np, + _posix_spawnattr_set_login_np, _posix_spawnattr_set_max_addr_np, + _posix_spawnattr_set_persona_gid_np, _posix_spawnattr_set_persona_groups_np, + _posix_spawnattr_set_persona_np, _posix_spawnattr_set_persona_uid_np, + _posix_spawnattr_set_platform_np, _posix_spawnattr_set_portlimits_ext, + _posix_spawnattr_set_ptrauth_task_port_np, _posix_spawnattr_set_qos_clamp_np, + _posix_spawnattr_set_registered_ports_np, _posix_spawnattr_set_subsystem_root_path_np, + _posix_spawnattr_set_threadlimit_ext, _posix_spawnattr_set_uid_np, + _posix_spawnattr_set_use_sec_transition_shims_np, _posix_spawnattr_setarchpref_np, + _posix_spawnattr_setauditsessionport_np, _posix_spawnattr_setbinpref_np, + _posix_spawnattr_setcoalition_np, _posix_spawnattr_setcpumonitor, + _posix_spawnattr_setcpumonitor_default, _posix_spawnattr_setdataless_iopolicy_np, + _posix_spawnattr_setexceptionports_np, _posix_spawnattr_setflags, + _posix_spawnattr_setjetsam_ext, _posix_spawnattr_setmacpolicyinfo_np, + _posix_spawnattr_setnosmt_np, _posix_spawnattr_setpcontrol_np, + _posix_spawnattr_setpgroup, _posix_spawnattr_setprocesstype_np, + _posix_spawnattr_setsigdefault, _posix_spawnattr_setsigmask, + _posix_spawnattr_setspecialport_np, _pread, '_pread$NOCANCEL', + _preadv, '_preadv$NOCANCEL', _proc_clear_cpulimits, _proc_clear_delayidlesleep, + _proc_clear_dirty, _proc_clear_vmpressure, _proc_current_thread_schedinfo, + _proc_denap_assertion_begin_with_msg, _proc_denap_assertion_complete, + _proc_disable_apptype, _proc_disable_cpumon, _proc_disable_wakemon, + _proc_donate_importance_boost, _proc_enable_apptype, _proc_get_cpumon_params, + _proc_get_dirty, _proc_get_wakemon_params, _proc_importance_assertion_begin_with_msg, + _proc_importance_assertion_complete, _proc_kmsgbuf, _proc_libversion, + _proc_list_dynkqueueids, _proc_list_uptrs, _proc_listallpids, + _proc_listchildpids, _proc_listcoalitions, _proc_listpgrppids, + _proc_listpids, _proc_listpidspath, _proc_name, _proc_pid_rusage, + _proc_piddynkqueueinfo, _proc_pidfdinfo, _proc_pidfileportinfo, + _proc_pidinfo, _proc_pidoriginatorinfo, _proc_pidpath, _proc_pidpath_audittoken, + _proc_regionfilename, _proc_reset_footprint_interval, _proc_resume_cpumon, + _proc_rlimit_control, _proc_set_cpumon_defaults, _proc_set_cpumon_params, + _proc_set_cpumon_params_fatal, _proc_set_csm, _proc_set_delayidlesleep, + _proc_set_dirty, _proc_set_no_smt, _proc_set_owner_vmpressure, + _proc_set_wakemon_defaults, _proc_set_wakemon_params, _proc_setcpu_percentage, + _proc_setpcontrol, _proc_setthread_cpupercent, _proc_setthread_csm, + _proc_setthread_no_smt, _proc_signal_delegate, _proc_signal_with_audittoken, + _proc_suppress, _proc_terminate, _proc_terminate_all_rsr, + _proc_terminate_delegate, _proc_terminate_with_audittoken, + _proc_trace_log, _proc_track_dirty, _proc_udata_info, _proc_uuid_policy, + _processor_assign, _processor_control, _processor_exit, _processor_get_assignment, + _processor_info, _processor_set_create, _processor_set_default, + _processor_set_destroy, _processor_set_info, _processor_set_max_priority, + _processor_set_policy_control, _processor_set_policy_disable, + _processor_set_policy_enable, _processor_set_stack_usage, + _processor_set_statistics, _processor_set_tasks, _processor_set_tasks_with_flavor, + _processor_set_threads, _processor_start, _pselect, '_pselect$DARWIN_EXTSN', + '_pselect$DARWIN_EXTSN$NOCANCEL', '_pselect$NOCANCEL', _pthread_getugid_np, + _pthread_setugid_np, _ptrace, _pwrite, '_pwrite$NOCANCEL', + _pwritev, '_pwritev$NOCANCEL', _quota, _quotactl, _read, '_read$NOCANCEL', + _readlink, _readlinkat, _readv, '_readv$NOCANCEL', _reboot, + _reboot_np, _record_system_event_as_kernel, _recvfrom, '_recvfrom$NOCANCEL', + _recvmsg, '_recvmsg$NOCANCEL', _recvmsg_x, _register_uexc_handler, + _removexattr, _rename, _rename_ext, _renameat, _renameatx_np, + _renamex_np, _revoke, _rmdir, _searchfs, _select, '_select$DARWIN_EXTSN', + '_select$DARWIN_EXTSN$NOCANCEL', '_select$NOCANCEL', _sem_close, + _sem_destroy, _sem_getvalue, _sem_init, _sem_open, _sem_post, + _sem_trywait, _sem_unlink, _sem_wait, '_sem_wait$NOCANCEL', + _semaphore_create, _semaphore_destroy, _semaphore_signal, + _semaphore_signal_all, _semaphore_signal_all_trap, _semaphore_signal_thread, + _semaphore_signal_thread_trap, _semaphore_signal_trap, _semaphore_timedwait, + _semaphore_timedwait_signal, _semaphore_timedwait_signal_trap, _semaphore_timedwait_trap, _semaphore_wait, _semaphore_wait_signal, _semaphore_wait_signal_trap, _semaphore_wait_trap, _semctl, _semget, _semop, _semsys, _sendfile, _sendmsg, '_sendmsg$NOCANCEL', @@ -2582,7 +2636,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, x86_64h-macos, x86_64h-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libsystem_m.dylib' -current-version: 3291.100.4 +current-version: 3307.0.1 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, x86_64h-macos, x86_64h-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -2804,7 +2858,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libsystem_malloc.dylib' -current-version: 715.120.13 +current-version: 792.1.1 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -2833,15 +2887,15 @@ exports: _malloc_type_aligned_alloc, _malloc_type_calloc, _malloc_type_free, _malloc_type_malloc, _malloc_type_posix_memalign, _malloc_type_realloc, _malloc_type_valloc, _malloc_type_zone_calloc, _malloc_type_zone_free, - _malloc_type_zone_malloc, _malloc_type_zone_malloc_with_options_internal, - _malloc_type_zone_malloc_with_options_np, _malloc_type_zone_memalign, + _malloc_type_zone_malloc, _malloc_type_zone_malloc_with_options, + _malloc_type_zone_malloc_with_options_internal, _malloc_type_zone_memalign, _malloc_type_zone_realloc, _malloc_type_zone_valloc, _malloc_variant_is_debug_4test, _malloc_zero_on_free_disable, _malloc_zone_batch_free, _malloc_zone_batch_malloc, _malloc_zone_calloc, _malloc_zone_check, _malloc_zone_claimed_address, _malloc_zone_disable_discharge_checking, _malloc_zone_discharge, _malloc_zone_enable_discharge_checking, _malloc_zone_enumerate_discharged_pointers, _malloc_zone_free, _malloc_zone_from_ptr, _malloc_zone_log, - _malloc_zone_malloc, _malloc_zone_malloc_with_options_np, + _malloc_zone_malloc, _malloc_zone_malloc_with_options, _malloc_zone_malloc_with_options_np, _malloc_zone_memalign, _malloc_zone_pressure_relief, _malloc_zone_print, _malloc_zone_print_ptr_info, _malloc_zone_realloc, _malloc_zone_register, _malloc_zone_statistics, _malloc_zone_unregister, _malloc_zone_valloc, @@ -2878,24 +2932,26 @@ exports: _NEHelperCopyXPCEndpointForIdentityProxyExtended, _NEHelperGetAppTrackerDomains, _NEHelperGetIKESocket, _NEHelperGetIKESocketWithResult, _NEHelperGetKernelControlSocket, _NEHelperGetKernelControlSocketExtended, _NEHelperGetNECPSessionFD, - _NEHelperGetPFKeySocket, _NEHelperGetPid, _NEHelperHandleConfigurationsChangedBySC, - _NEHelperInit, _NEHelperInterfaceCreate, _NEHelperInterfaceDestroy, - _NEHelperInterfaceRemoveAddress, _NEHelperInterfaceSetAddress, - _NEHelperInterfaceSetAddressWithLifetime, _NEHelperInterfaceSetDelegate, - _NEHelperInterfaceSetDescription, _NEHelperInterfaceSetMTU, - _NEHelperInterfaceSetOption, _NEHelperSendRequest, _NEHelperSettingsRemove, - _NEHelperSettingsSetArray, _NEHelperSettingsSetBool, _NEHelperSettingsSetNumber, - _NEHelperVPNConfigurationExists, _NEHelperVPNSetEnabled, _g_ne_read_uuid_cache, - _g_ne_uuid_cache_hit, _ne_copy_cached_bundle_identifier_for_uuid, - _ne_copy_cached_uuids_for_bundle_identifier, _ne_copy_signature_info_for_pid, - _ne_copy_signing_identifier_for_pid, _ne_copy_signing_identifier_for_pid_with_audit_token, - _ne_copy_uuid_cache, _ne_force_reset_uuid_cache, _ne_get_configuration_generation, + _NEHelperGetPFKeySocket, _NEHelperGetPid, _NEHelperGetRawSocket, + _NEHelperHandleConfigurationsChangedBySC, _NEHelperInit, _NEHelperInterfaceCreate, + _NEHelperInterfaceDestroy, _NEHelperInterfaceRemoveAddress, + _NEHelperInterfaceSetAddress, _NEHelperInterfaceSetAddressWithLifetime, + _NEHelperInterfaceSetDelegate, _NEHelperInterfaceSetDescription, + _NEHelperInterfaceSetMTU, _NEHelperInterfaceSetOption, _NEHelperSendRequest, + _NEHelperSettingsRemove, _NEHelperSettingsSetArray, _NEHelperSettingsSetBool, + _NEHelperSettingsSetNumber, _NEHelperVPNConfigurationExists, + _NEHelperVPNSetEnabled, _g_ne_read_uuid_cache, _g_ne_uuid_cache_hit, + _ne_copy_cached_bundle_identifier_for_uuid, _ne_copy_cached_uuids_for_bundle_identifier, + _ne_copy_signature_info_for_pid, _ne_copy_signing_identifier_for_pid, + _ne_copy_signing_identifier_for_pid_with_audit_token, _ne_copy_uuid_cache, + _ne_force_reset_uuid_cache, _ne_get_configuration_generation, _ne_is_sockaddr_valid, _ne_log_large_obj, _ne_log_obj, _ne_print_backtrace, _ne_privacy_dns_netagent_id, _ne_privacy_proxy_netagent_id, _ne_session_add_necp_drop_dest_from_dest_list, _ne_session_add_necp_drop_dest_from_path, _ne_session_address_matches_subnets, _ne_session_agent_get_advisory, _ne_session_agent_get_advisory_interface_index, _ne_session_always_on_vpn_configs_present, _ne_session_always_on_vpn_configs_present_at_boot, _ne_session_app_vpn_configs_present, + _ne_session_applications_have_local_network_entitlements, _ne_session_cancel, _ne_session_clear_caches, _ne_session_content_filter_configs_present, _ne_session_copy_app_data_from_flow_divert_socket, _ne_session_copy_app_data_from_flow_divert_token, _ne_session_copy_os_version_string, _ne_session_copy_policy_match, @@ -2904,30 +2960,29 @@ exports: _ne_session_disable_restrictions, _ne_session_dns_proxy_configs_present, _ne_session_dns_settings_configs_present, _ne_session_establish_ipc, _ne_session_fallback_advisory, _ne_session_fallback_default, - _ne_session_get_boot_session_uuid, _ne_session_get_config_id_from_network_agent, - _ne_session_get_configuration_id, _ne_session_get_info, _ne_session_get_info2, - _ne_session_get_status, _ne_session_info_type_to_string, _ne_session_initialize_necp_drop_all, + _ne_session_fetch_server_parameters, _ne_session_get_boot_session_uuid, + _ne_session_get_config_id_from_network_agent, _ne_session_get_configuration_id, + _ne_session_get_info, _ne_session_get_info2, _ne_session_get_status, + _ne_session_get_type, _ne_session_info_type_to_string, _ne_session_initialize_necp_drop_all, _ne_session_is_always_on_vpn_enabled, _ne_session_is_safeboot, _ne_session_local_communication_configs_present, _ne_session_local_communication_send_info, _ne_session_manager_get_pid, _ne_session_manager_has_active_sessions, _ne_session_manager_is_running, _ne_session_map_interface_to_provider_uuid, _ne_session_on_demand_configs_present, _ne_session_path_controller_configs_present, _ne_session_policy_copy_flow_divert_token, _ne_session_policy_copy_flow_divert_token_with_key, - _ne_session_policy_match_get_filter_unit, _ne_session_policy_match_get_flow_divert_unit, - _ne_session_policy_match_get_scoped_interface_index, _ne_session_policy_match_get_service, - _ne_session_policy_match_get_service_action, _ne_session_policy_match_get_service_type, - _ne_session_policy_match_is_drop, _ne_session_policy_match_is_flow_divert, - _ne_session_policy_match_service_is_registered, _ne_session_relay_configs_present, - _ne_session_release, _ne_session_retain, _ne_session_send_barrier, - _ne_session_service_copy_cached_match_domains, _ne_session_service_get_dns_service_id, - _ne_session_service_get_dns_service_id_for_interface, _ne_session_service_matches_address, - _ne_session_service_matches_address_for_interface, _ne_session_set_device_communication_exception, - _ne_session_set_event_handler, _ne_session_set_socket_attributes, - _ne_session_set_socket_context_attribute, _ne_session_set_socket_tracker_attributes, - _ne_session_should_disable_nexus, _ne_session_start, _ne_session_start_on_behalf_of, - _ne_session_start_with_options, _ne_session_status_to_string, - _ne_session_stop, _ne_session_stop_all_with_plugin_type, _ne_session_stop_reason_to_string, - _ne_session_type_to_string, _ne_session_use_as_system_vpn, + _ne_session_policy_match_get_service, _ne_session_policy_match_get_service_action, + _ne_session_policy_match_get_service_type, _ne_session_relay_configs_present, + _ne_session_release, _ne_session_reset_cache, _ne_session_retain, + _ne_session_send_barrier, _ne_session_service_copy_cached_match_domains, + _ne_session_service_get_dns_service_id, _ne_session_service_get_dns_service_id_for_interface, + _ne_session_service_matches_address, _ne_session_service_matches_address_for_interface, + _ne_session_set_device_communication_exception, _ne_session_set_event_handler, + _ne_session_set_socket_attributes, _ne_session_set_socket_context_attribute, + _ne_session_set_socket_tracker_attributes, _ne_session_should_disable_nexus, + _ne_session_start, _ne_session_start_on_behalf_of, _ne_session_start_with_options, + _ne_session_status_to_string, _ne_session_stop, _ne_session_stop_all_with_plugin_type, + _ne_session_stop_reason_to_string, _ne_session_type_to_string, + _ne_session_urlfilter_configs_present, _ne_session_use_as_system_vpn, _ne_session_vod_evaluate_connection_present, _ne_session_vpn_include_all_networks_configs_present, _ne_socket_set_attribution, _ne_socket_set_domains, _ne_socket_set_is_app_initiated, _ne_socket_set_website_attribution, _ne_tracker_build_cache, @@ -2949,7 +3004,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libsystem_notify.dylib' -current-version: 342 +current-version: 344.0.1 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -2969,7 +3024,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libsystem_platform.dylib' -current-version: 349 +current-version: 359.1.2 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -3020,19 +3075,21 @@ exports: __simple_asl_msg_new, __simple_asl_msg_set, __simple_asl_send, __simple_dprintf, __simple_esappend, __simple_esprintf, __simple_getenv, __simple_put, __simple_putline, __simple_salloc, __simple_sappend, - __simple_sfree, __simple_sprintf, __simple_sresize, __simple_string, - __simple_vdprintf, __simple_vesprintf, __simple_vsprintf, - __spin_lock, __spin_lock_try, __spin_unlock, _ffs, _ffsl, - _ffsll, _fls, _flsl, _flsll, _getcontext, _longjmp, _makecontext, - _os_apt_msg_async_task_running_4swift, _os_apt_msg_async_task_waiting_on_4swift, + __simple_sfree, __simple_snprintf, __simple_sprintf, __simple_sresize, + __simple_string, __simple_vdprintf, __simple_vesprintf, __simple_vsnprintf, + __simple_vsprintf, __spin_lock, __spin_lock_try, __spin_unlock, + _ffs, _ffsl, _ffsll, _fls, _flsl, _flsll, _getcontext, _longjmp, + _makecontext, _os_apt_msg_async_task_running_4swift, _os_apt_msg_async_task_waiting_on_4swift, _os_lock_lock, _os_lock_trylock, _os_lock_unlock, _os_log_simple_now, - _os_log_simple_type_from_asl, _os_sync_wait_on_address, _os_sync_wait_on_address_with_deadline, - _os_sync_wait_on_address_with_timeout, _os_sync_wake_by_address_all, - _os_sync_wake_by_address_any, _os_unfair_lock_assert_not_owner, - _os_unfair_lock_assert_owner, _os_unfair_lock_lock, _os_unfair_lock_lock_no_tsd, - _os_unfair_lock_lock_with_flags, _os_unfair_lock_lock_with_options, - _os_unfair_lock_trylock, _os_unfair_lock_trylock_with_options, - _os_unfair_lock_unlock, _os_unfair_lock_unlock_no_tsd, _os_unfair_recursive_lock_lock_with_options, + _os_log_simple_type_from_asl, _os_security_config_get, _os_security_config_get_for_proc, + _os_security_config_get_for_task, _os_sync_wait_on_address, + _os_sync_wait_on_address_with_deadline, _os_sync_wait_on_address_with_timeout, + _os_sync_wake_by_address_all, _os_sync_wake_by_address_any, + _os_unfair_lock_assert_not_owner, _os_unfair_lock_assert_owner, + _os_unfair_lock_lock, _os_unfair_lock_lock_no_tsd, _os_unfair_lock_lock_with_flags, + _os_unfair_lock_lock_with_options, _os_unfair_lock_trylock, + _os_unfair_lock_trylock_with_options, _os_unfair_lock_unlock, + _os_unfair_lock_unlock_no_tsd, _os_unfair_recursive_lock_lock_with_options, _os_unfair_recursive_lock_owned, _os_unfair_recursive_lock_trylock, _os_unfair_recursive_lock_tryunlock4objc, _os_unfair_recursive_lock_unlock, _os_unfair_recursive_lock_unlock_forked_child, _setcontext, @@ -3047,7 +3104,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libsystem_pthread.dylib' -current-version: 536 +current-version: 539 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -3143,7 +3200,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libsystem_sandbox.dylib' -current-version: 2401.121.3 +current-version: 2680.0.50 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -3158,8 +3215,13 @@ exports: _SANDBOX_CHECK_POSIX_WRITEABLE, _SANDBOX_EXTENSION_CANONICAL, _SANDBOX_EXTENSION_DEFAULT, _SANDBOX_EXTENSION_NOFOLLOW, _SANDBOX_EXTENSION_NOFOLLOW_ANY, _SANDBOX_EXTENSION_NO_REPORT, _SANDBOX_EXTENSION_NO_STORAGE_CLASS, - _SANDBOX_EXTENSION_PREFIXMATCH, __amkrtemp, __sandbox_enter_notify_libxpc, - __sandbox_in_a_container, __sandbox_register_app_bundle_0, + _SANDBOX_EXTENSION_PREFIXMATCH, _SANDBOX_PROFILE_TYPE_AUTOBOX, + _SANDBOX_PROFILE_TYPE_BASTION, _SANDBOX_PROFILE_TYPE_GLOBAL_OVERRIDE, + _SANDBOX_PROFILE_TYPE_PLATFORM, _SANDBOX_PROFILE_TYPE_PROCESS, + _SANDBOX_STORAGE_CLASS_GROUP_ANY, _SANDBOX_STORAGE_CLASS_PROPERTY_ACCEPTS_USER_APPROVAL, + _SANDBOX_STORAGE_CLASS_PROPERTY_READ_RESTRICTED, _SANDBOX_STORAGE_CLASS_PROPERTY_REPLACEMENT_RESTRICTED, + _SANDBOX_STORAGE_CLASS_PROPERTY_WRITE_RESTRICTED, __amkrtemp, + __sandbox_enter_notify_libxpc, __sandbox_in_a_container, __sandbox_register_app_bundle_0, __sandbox_register_app_bundle_1, _kSBXProfileNoInternet, _kSBXProfileNoNetwork, _kSBXProfileNoWrite, _kSBXProfileNoWriteExceptTemporary, _kSBXProfilePureComputation, _kSandboxAppBundleAnySigningId, _kSandboxAppBundlePlatformTeamId, @@ -3179,7 +3241,8 @@ exports: _sandbox_check_by_uniqueid, _sandbox_check_finder_automation_for_path, _sandbox_check_message_filter_integer, _sandbox_check_message_filter_string, _sandbox_check_process_signal_target, _sandbox_check_protected_app_container, - _sandbox_check_self_signal_target, _sandbox_consume_extension, + _sandbox_check_self_signal_target, _sandbox_check_storage_class, + _sandbox_check_with_attribution, _sandbox_consume_extension, _sandbox_consume_fs_extension, _sandbox_consume_mach_extension, _sandbox_container_path_for_audit_token, _sandbox_container_path_for_pid, _sandbox_enable_local_state_flag, _sandbox_enable_root_translation, @@ -3205,15 +3268,16 @@ exports: _sandbox_register_app_bundle_exception, _sandbox_register_app_bundle_package_exception, _sandbox_register_app_container, _sandbox_register_app_container_exception, _sandbox_register_app_container_package_exception, _sandbox_register_bastion_profile, - _sandbox_register_sync_root, _sandbox_release_fs_extension, - _sandbox_requests_integrity_protection_for_preference_domain, + _sandbox_register_disk_image_backing_store, _sandbox_register_sync_root, + _sandbox_release_fs_extension, _sandbox_requests_integrity_protection_for_preference_domain, _sandbox_set_container_path_for_application_group, _sandbox_set_container_path_for_application_group_with_persona, _sandbox_set_container_path_for_audit_token, _sandbox_set_container_path_for_signing_id, _sandbox_set_container_path_for_signing_id_with_persona, _sandbox_spawnattrs_getcontainer, _sandbox_spawnattrs_getprofilename, _sandbox_spawnattrs_init, _sandbox_spawnattrs_setcontainer, _sandbox_spawnattrs_setprofilename, _sandbox_suspend, _sandbox_unregister_app_bundle, _sandbox_unregister_app_container, - _sandbox_unregister_bastion_profile, _sandbox_unsuspend ] + _sandbox_unregister_bastion_profile, _sandbox_unregister_disk_image_backing_store, + _sandbox_unsuspend ] - targets: [ x86_64-macos, arm64-macos, arm64e-macos ] symbols: [ _SANDBOX_EXTENSION_MACL_LEARNING, _SANDBOX_EXTENSION_USER_INTENT, _gpu_bundle_find_trusted, _gpu_bundle_is_path_trusted, _rootless_apply, @@ -3257,7 +3321,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libsystem_secinit.dylib' -current-version: 153.100.10 +current-version: 168.0.3 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -3290,7 +3354,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libsystem_trace.dylib' -current-version: 1643.120.5 +current-version: 1815.0.16 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -3298,39 +3362,55 @@ parent-umbrella: exports: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] - symbols: [ __libtrace_fork_child, __libtrace_init, __os_activity_create, - __os_activity_current, __os_activity_initiate, __os_activity_initiate_f, - __os_activity_label_useraction, __os_activity_none, __os_activity_set_breadcrumb, - __os_activity_start, __os_activity_stream_entry_encode, __os_log_create, - __os_log_debug, __os_log_debug_impl, __os_log_default, __os_log_disabled, + symbols: [ _RTBinIndexForType, _RTLogBufferAddResource, _RTLogBufferAllocateResource, + _RTLogBufferCheckStatus, _RTLogBufferGetHeader, _RTLogBufferGetResource, + _RTLogBufferGetResourceSize, _RTLogBufferInitialize, _RTLogBufferIterate, + _RTLogBufferRequiredStorageSize, _RTLogConnect, _RTLogConnectMemoryConfigFromString, + _RTLogConnectRingBuffer, _RTLogDisconnect, _RTLogRingBufferCreateManaged, + _RTLogRingBufferDataSize, _RTLogRingBufferGetSegmentCount, + _RTLogRingBufferGetSegmentSize, _RTLogRingBufferInit, _RTLogRingBufferIsDataAvailable, + _RTLogRingBufferIterate, _RTLogRingBufferIterateFrom, _RTLogRingBufferJoinManaged, + _RTLogRingBufferReadAt, _RTLogRingBufferWriteBuffer, _RTLogRingBufferWriteMessage, + _RTLogRingBufferWriteWithCallback, __libtrace_fork_child, + __libtrace_init, __os_activity_create, __os_activity_current, + __os_activity_initiate, __os_activity_initiate_f, __os_activity_label_useraction, + __os_activity_none, __os_activity_set_breadcrumb, __os_activity_start, + __os_activity_stream_entry_encode, __os_log_create, __os_log_debug, + __os_log_debug_impl, __os_log_default, __os_log_disabled, __os_log_error, __os_log_error_impl, __os_log_fault, __os_log_fault_impl, __os_log_get_nscf_formatter, __os_log_impl, __os_log_internal, __os_log_pack_fill, __os_log_pack_size, __os_log_preferences_compute, __os_log_preferences_copy_cache, __os_log_preferences_load, __os_log_preferences_load_sysprefs, __os_log_preferences_merge, __os_log_release, __os_log_send_and_compose_impl, __os_log_set_nscf_formatter, - __os_log_unreliable_impl, __os_signpost_emit_impl, __os_signpost_emit_unreliably_with_name_impl, + __os_log_unreliable_impl, __os_metric_double_create_impl, + __os_metric_double_op_impl, __os_metric_int64_create_impl, + __os_metric_int64_op_impl, __os_metric_label_create_impl, + __os_metric_label_create_v, __os_metric_reset_impl, __os_metric_set_scale_impl, + __os_metric_set_unit_impl, __os_metric_uint64_create_impl, + __os_metric_uint64_op_impl, __os_signpost_emit_impl, __os_signpost_emit_unreliably_with_name_impl, __os_signpost_emit_with_name_impl, __os_signpost_pack_fill, __os_signpost_pack_send, __os_state_request_for_pidlist, __os_trace_app_cryptex_sysprefsdir_path, __os_trace_atm_diagnostic_config, __os_trace_basesystem_storage_available, - __os_trace_calloc, __os_trace_commpage_compute, __os_trace_fdscandir_b, + __os_trace_calloc_typed, __os_trace_commpage_compute, __os_trace_fdscandir_b, __os_trace_get_boot_uuid, __os_trace_get_image_info, __os_trace_get_mode_for_pid, __os_trace_get_times_now, __os_trace_getxattr_at, __os_trace_intprefsdir_path, __os_trace_is_development_build, __os_trace_lazy_init_completed_4libxpc, __os_trace_lazy_init_completed_4swift, __os_trace_log_simple, - __os_trace_macho_for_each_slice, __os_trace_malloc, __os_trace_memdup, - __os_trace_mmap, __os_trace_mmap_at, __os_trace_mmap_offset, + __os_trace_macho_for_each_slice, __os_trace_malloc_typed, + __os_trace_memdup, __os_trace_mmap, __os_trace_mmap_at, __os_trace_mmap_offset, __os_trace_mode_match_4tests, __os_trace_os_cryptex_sysprefsdir_path, __os_trace_prefs_latest_version_4tests, __os_trace_prefsdir_path, - __os_trace_read_file_at, __os_trace_read_plist_at, __os_trace_realloc, + __os_trace_read_file_at, __os_trace_read_plist_at, __os_trace_realloc_typed, __os_trace_scandir_free_namelist, __os_trace_sect_names, __os_trace_set_diagnostic_flags, __os_trace_set_mode_for_pid, __os_trace_strdup, __os_trace_sysprefsdir_path, __os_trace_update_with_datavolume_4launchd, __os_trace_with_buffer, - __os_trace_write, __os_trace_writev, __os_trace_zalloc, _amfi_check_dyld_policy_for_pid, - _amfi_check_dyld_policy_self, _amfi_load_trust_cache, _amfi_unload_trust_cache, - _os_activity_apply, _os_activity_apply_f, _os_activity_diagnostic_for_pid, - _os_activity_end, _os_activity_for_task_thread, _os_activity_for_thread, - _os_activity_get_active, _os_activity_get_identifier, _os_activity_iterate_activities, + __os_trace_write, __os_trace_writev, __os_trace_zalloc_typed, + _amfi_check_dyld_policy_for_pid, _amfi_check_dyld_policy_self, + _amfi_load_trust_cache, _amfi_unload_trust_cache, _os_activity_apply, + _os_activity_apply_f, _os_activity_diagnostic_for_pid, _os_activity_end, + _os_activity_for_task_thread, _os_activity_for_thread, _os_activity_get_active, + _os_activity_get_identifier, _os_activity_iterate_activities, _os_activity_iterate_breadcrumbs, _os_activity_iterate_messages, _os_activity_iterate_processes, _os_activity_messages_for_thread, _os_activity_scope_enter, _os_activity_scope_leave, _os_log_backtrace_copy_description, @@ -3348,8 +3428,10 @@ exports: _os_log_set_client_type, _os_log_set_enabled, _os_log_set_fault_callback, _os_log_set_hook, _os_log_set_hook_with_params, _os_log_set_test_callback, _os_log_shim_enabled, _os_log_shim_legacy_logging_enabled, - _os_log_shim_with_CFString, _os_log_type_enabled, _os_log_type_get_name, - _os_log_with_args, _os_set_logging_unreliable_for_current_thread, + _os_log_shim_to_stdout, _os_log_shim_with_CFString, _os_log_shim_with_CFString_4NSLog, + _os_log_type_enabled, _os_log_type_get_name, _os_log_with_args, + _os_log_with_args_4syslog, _os_metric_dimensions_add, _os_metric_dimensions_create, + _os_metric_group_create, _os_set_logging_unreliable_for_current_thread, _os_signpost_enabled, _os_signpost_id_generate, _os_signpost_id_make_with_pointer, _os_signpost_set_introspection_hook_4Perf, _os_state_add_handler, _os_state_remove_handler, _os_trace_debug_enabled, _os_trace_get_mode, @@ -3357,6 +3439,18 @@ exports: objc-classes: [ OS_os_log ] --- !tapi-tbd tbd-version: 4 +targets: [ x86_64-macos, arm64-macos, arm64e-macos ] +install-name: '/usr/lib/system/libsystem_trial.dylib' +current-version: 474 +parent-umbrella: + - targets: [ x86_64-macos, arm64-macos, arm64e-macos ] + umbrella: System +exports: + - targets: [ x86_64-macos, arm64-macos, arm64e-macos ] + symbols: [ __os_trial_factor_get_bool_impl, __os_trial_factor_get_long_impl, + __os_trial_factor_has_impl ] +--- !tapi-tbd +tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libunwind.dylib' @@ -3390,7 +3484,7 @@ tbd-version: 4 targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] install-name: '/usr/lib/system/libxpc.dylib' -current-version: 2894.121.3 +current-version: 3089.0.11 parent-umbrella: - targets: [ x86_64-macos, x86_64-maccatalyst, arm64-macos, arm64-maccatalyst, arm64e-macos, arm64e-maccatalyst ] @@ -3433,11 +3527,11 @@ exports: _XPC_ACTIVITY_SEQUENCE_NUMBER, _XPC_ACTIVITY_SHOULD_WAKE_DEVICE, _XPC_ACTIVITY_USER_REQUESTED_BACKUP_TASK, _XPC_ACTIVITY_USES_DATA_BUDGETING, _XPC_ACTIVITY_USES_DUET_POWER_BUDGETING, _XPC_COALITION_INFO_KEY_BUNDLE_IDENTIFIER, - _XPC_COALITION_INFO_KEY_CID, _XPC_COALITION_INFO_KEY_NAME, - _XPC_COALITION_INFO_KEY_RESOURCE_USAGE_BLOB, ___xpc_connection_set_logging, - __availability_version_check, __launch_job_query_routine, - __launch_job_routine, __launch_job_routine_async, __launch_msg2, - __launch_server_test_routine, __launch_service_stats_copy_4ppse_impl, + _XPC_COALITION_INFO_KEY_CID, _XPC_COALITION_INFO_KEY_LEADER_PID, + _XPC_COALITION_INFO_KEY_NAME, _XPC_COALITION_INFO_KEY_RESOURCE_USAGE_BLOB, + ___xpc_connection_set_logging, __availability_version_check, + __launch_job_query_routine, __launch_job_routine, __launch_job_routine_async, + __launch_msg2, __launch_server_test_routine, __launch_service_stats_copy_4ppse_impl, __launch_service_stats_copy_impl, __launch_trial_factors_routine, __libxpc_initializer, __spawn_via_launchd, __system_ios_support_version_copy_string_sysctl, __system_version_copy_string_plist, __system_version_copy_string_sysctl, @@ -3466,7 +3560,8 @@ exports: __xpc_error_peer_code_signing_requirement, __xpc_error_termination_imminent, __xpc_event_key_name, __xpc_event_key_stream_name, __xpc_fd_get_port, __xpc_int64_set_value, __xpc_payload_create_from_mach_msg, - __xpc_pipe_handle_mig, __xpc_pipe_interface_routine, __xpc_pipe_interface_routine_async, + __xpc_peer_requirement_match_token, __xpc_pipe_handle_mig, + __xpc_pipe_interface_routine, __xpc_pipe_interface_routine_async, __xpc_pipe_interface_simpleroutine, __xpc_runtime_get_entitlements_data, __xpc_runtime_get_self_entitlements, __xpc_runtime_is_app_sandboxed, __xpc_runtime_process_has_entered_sandbox, __xpc_service_last_xref_cancel, @@ -3484,8 +3579,8 @@ exports: __xpc_type_mach_recv, __xpc_type_mach_send, __xpc_type_mach_send_once, __xpc_type_null, __xpc_type_pipe, __xpc_type_pointer, __xpc_type_rich_error, __xpc_type_serializer, __xpc_type_service, __xpc_type_service_instance, - __xpc_type_session, __xpc_type_shmem, __xpc_type_string, __xpc_type_uint64, - __xpc_type_uuid, __xpc_vtables, _amfi_developer_mode_resolved, + __xpc_type_session, __xpc_type_shmem, __xpc_type_string, __xpc_type_string_cache, + __xpc_type_uint64, __xpc_type_uuid, __xpc_vtables, _amfi_developer_mode_resolved, _amfi_developer_mode_status, _amfi_interface_authorize_local_signing, _amfi_interface_cdhash_in_trustcache, _amfi_interface_get_local_signing_private_key, _amfi_interface_get_local_signing_public_key, _amfi_interface_query_bootarg_state, @@ -3500,8 +3595,8 @@ exports: _bootstrap_status, _bootstrap_strerror, _bootstrap_subset, _bootstrap_unprivileged, _create_and_switch_to_per_session_launchd, _launch_activate_socket, _launch_active_user_login, _launch_active_user_logout, - _launch_active_user_switch, _launch_add_external_service, - _launch_bootout_user_service_4coresim, _launch_copy_busy_extension_instances, + _launch_add_external_service, _launch_bootout_user_service_4coresim, + _launch_bootout_user_service_4coresim_with_flags, _launch_copy_busy_extension_instances, _launch_copy_endpoints_properties_for_pid, _launch_copy_extension_properties, _launch_copy_extension_properties_for_pid, _launch_copy_properties_for_pid_4assertiond, _launch_create_persona, _launch_cryptex_terminate, _launch_data_alloc, @@ -3542,11 +3637,12 @@ exports: _mpm_wait, _os_system_version_get_current_version, _os_system_version_get_ios_support_version, _os_system_version_sim_get_current_host_version, _os_transaction_copy_description, _os_transaction_create, _os_transaction_get_description, _os_transaction_get_ra, - _os_transaction_get_timestamp, _os_transaction_needs_more_time, - _place_hold_on_real_loginwindow, _reboot2, _reboot3, _vproc_release, - _vproc_retain, _vproc_standby_begin, _vproc_standby_end, _vproc_swap_complex, - _vproc_swap_integer, _vproc_swap_string, _vproc_transaction_begin, - _vproc_transaction_end, _vprocmgr_lookup_vproc, _xpc_activity_add_eligibility_changed_handler, + _os_transaction_get_timestamp, _os_transaction_log_active, + _os_transaction_needs_more_time, _place_hold_on_real_loginwindow, + _reboot2, _reboot3, _vproc_release, _vproc_retain, _vproc_standby_begin, + _vproc_standby_end, _vproc_swap_complex, _vproc_swap_integer, + _vproc_swap_string, _vproc_transaction_begin, _vproc_transaction_end, + _vprocmgr_lookup_vproc, _xpc_activity_add_eligibility_changed_handler, _xpc_activity_copy_criteria, _xpc_activity_copy_dispatch_queue, _xpc_activity_copy_identifier, _xpc_activity_debug, _xpc_activity_defer_until_network_change, _xpc_activity_defer_until_percentage, _xpc_activity_get_percentage, @@ -3575,7 +3671,8 @@ exports: _xpc_binprefs_set_psattr, _xpc_bool_create, _xpc_bool_get_value, _xpc_bs_main, _xpc_bundle_copy_info_dictionary, _xpc_bundle_copy_normalized_cryptex_path, _xpc_bundle_copy_resource_path, _xpc_bundle_copy_services, - _xpc_bundle_create, _xpc_bundle_create_from_origin, _xpc_bundle_create_main, + _xpc_bundle_create, _xpc_bundle_create_from_origin, _xpc_bundle_create_from_origin_with_string_cache, + _xpc_bundle_create_main, _xpc_bundle_create_with_string_cache, _xpc_bundle_get_error, _xpc_bundle_get_executable_path, _xpc_bundle_get_info_dictionary, _xpc_bundle_get_path, _xpc_bundle_get_property, _xpc_bundle_get_xpcservice_dictionary, _xpc_bundle_populate, _xpc_bundle_resolve, _xpc_bundle_resolve_on_queue, @@ -3602,11 +3699,11 @@ exports: _xpc_connection_set_oneshot_instance, _xpc_connection_set_peer_code_signing_requirement, _xpc_connection_set_peer_entitlement_exists_requirement, _xpc_connection_set_peer_entitlement_matches_value_requirement, _xpc_connection_set_peer_lightweight_code_requirement, _xpc_connection_set_peer_platform_identity_requirement, - _xpc_connection_set_peer_team_identity_requirement, _xpc_connection_set_privileged, - _xpc_connection_set_qos_class_fallback, _xpc_connection_set_qos_class_floor, - _xpc_connection_set_target_queue, _xpc_connection_set_target_uid, - _xpc_connection_set_target_user_session_uid, _xpc_connection_suspend, - _xpc_copy, _xpc_copy_bootstrap, _xpc_copy_clean_description, + _xpc_connection_set_peer_requirement, _xpc_connection_set_peer_team_identity_requirement, + _xpc_connection_set_privileged, _xpc_connection_set_qos_class_fallback, + _xpc_connection_set_qos_class_floor, _xpc_connection_set_target_queue, + _xpc_connection_set_target_uid, _xpc_connection_set_target_user_session_uid, + _xpc_connection_suspend, _xpc_copy, _xpc_copy_bootstrap, _xpc_copy_clean_description, _xpc_copy_code_signing_identity_for_token, _xpc_copy_debug_description, _xpc_copy_description, _xpc_copy_domain, _xpc_copy_entitlement_for_self, _xpc_copy_entitlement_for_token, _xpc_copy_entitlements_data_for_token, @@ -3614,7 +3711,8 @@ exports: _xpc_copy_event, _xpc_copy_event_entitlements, _xpc_copy_short_description, _xpc_create_from_ce_der, _xpc_create_from_ce_der_with_key, _xpc_create_from_plist, _xpc_create_from_plist_descriptor, - _xpc_create_from_serialization, _xpc_create_from_serialization_with_ool, + _xpc_create_from_plist_with_string_cache, _xpc_create_from_serialization, + _xpc_create_from_serialization_with_ool, _xpc_create_from_serialization_with_string_cache, _xpc_create_reply_with_format, _xpc_create_reply_with_format_and_arguments, _xpc_create_with_format, _xpc_create_with_format_and_arguments, _xpc_data_create, _xpc_data_create_with_dispatch_data, _xpc_data_get_bytes, @@ -3640,18 +3738,19 @@ exports: _xpc_dictionary_set_int64, _xpc_dictionary_set_mach_recv, _xpc_dictionary_set_mach_send, _xpc_dictionary_set_pointer, _xpc_dictionary_set_string, _xpc_dictionary_set_uint64, _xpc_dictionary_set_uuid, - _xpc_dictionary_set_value, _xpc_double_create, _xpc_double_get_value, - _xpc_endpoint_compare, _xpc_endpoint_copy_listener_port_4sim, - _xpc_endpoint_create, _xpc_endpoint_create_bs_from_port, _xpc_endpoint_create_bs_named, - _xpc_endpoint_create_bs_service, _xpc_endpoint_create_mach_port_4sim, - _xpc_endpoint_get_bs_job_handle, _xpc_equal, _xpc_event_publisher_activate, - _xpc_event_publisher_copy_event, _xpc_event_publisher_create, - _xpc_event_publisher_create_subscription, _xpc_event_publisher_fire, - _xpc_event_publisher_fire_barrier, _xpc_event_publisher_fire_noboost, - _xpc_event_publisher_fire_with_reply, _xpc_event_publisher_fire_with_reply_sync, - _xpc_event_publisher_get_subscriber_asid, _xpc_event_publisher_set_error_handler, - _xpc_event_publisher_set_event, _xpc_event_publisher_set_handler, - _xpc_event_publisher_set_initial_load_completed_handler_4remoted, + _xpc_dictionary_set_value, _xpc_dictionary_set_value_with_key_string_cache, + _xpc_double_create, _xpc_double_get_value, _xpc_endpoint_compare, + _xpc_endpoint_copy_listener_port_4sim, _xpc_endpoint_create, + _xpc_endpoint_create_bs_from_port, _xpc_endpoint_create_bs_named, + _xpc_endpoint_create_bs_named_user, _xpc_endpoint_create_bs_service, + _xpc_endpoint_create_mach_port_4sim, _xpc_endpoint_get_bs_job_handle, + _xpc_equal, _xpc_event_publisher_activate, _xpc_event_publisher_copy_event, + _xpc_event_publisher_create, _xpc_event_publisher_create_subscription, + _xpc_event_publisher_fire, _xpc_event_publisher_fire_barrier, + _xpc_event_publisher_fire_noboost, _xpc_event_publisher_fire_with_reply, + _xpc_event_publisher_fire_with_reply_sync, _xpc_event_publisher_get_subscriber_asid, + _xpc_event_publisher_set_error_handler, _xpc_event_publisher_set_event, + _xpc_event_publisher_set_handler, _xpc_event_publisher_set_initial_load_completed_handler_4remoted, _xpc_event_publisher_set_subscriber_keepalive, _xpc_event_publisher_set_throttling, _xpc_event_stream_check_in, _xpc_event_stream_check_in2, _xpc_exit_reason_get_label, _xpc_extension_type_init, _xpc_fd_create, _xpc_fd_dup, _xpc_file_transfer_cancel, @@ -3671,49 +3770,56 @@ exports: _xpc_is_system_session, _xpc_is_xpcservice, _xpc_listener_activate, _xpc_listener_cancel, _xpc_listener_copy_description, _xpc_listener_create, _xpc_listener_create_anonymous, _xpc_listener_create_endpoint, - _xpc_listener_reject_peer, _xpc_listener_set_peer_code_signing_requirement, + _xpc_listener_reject_peer, _xpc_listener_set_incoming_session_handler, + _xpc_listener_set_peer_code_signing_requirement, _xpc_listener_set_peer_requirement, _xpc_mach_recv_create, _xpc_mach_recv_extract_right, _xpc_mach_send_copy_right, _xpc_mach_send_create, _xpc_mach_send_create_with_disposition, _xpc_mach_send_get_right, _xpc_mach_send_once_create, _xpc_mach_send_once_extract_right, _xpc_main, _xpc_make_serialization, _xpc_make_serialization_with_ool, - _xpc_null_create, _xpc_pipe_create, _xpc_pipe_create_from_port, - _xpc_pipe_create_reply_from_port, _xpc_pipe_create_with_user_session_uid, - _xpc_pipe_invalidate, _xpc_pipe_receive, _xpc_pipe_routine, - _xpc_pipe_routine_async, _xpc_pipe_routine_forward, _xpc_pipe_routine_reply, - _xpc_pipe_routine_with_flags, _xpc_pipe_simpleroutine, _xpc_pipe_try_receive, - _xpc_pointer_create, _xpc_pointer_get_value, _xpc_receive_mach_msg, - _xpc_receive_mach_msg_validate_hdr, _xpc_receive_remote_msg, - _xpc_release, _xpc_retain, _xpc_rich_error_can_retry, _xpc_rich_error_copy_description, - _xpc_service_attach, _xpc_service_attach_with_flags, _xpc_service_create, - _xpc_service_create_from_specifier, _xpc_service_get_rendezvous_token, + _xpc_null_create, _xpc_peer_requirement_create_entitlement_exists, + _xpc_peer_requirement_create_entitlement_matches_value, _xpc_peer_requirement_create_lwcr, + _xpc_peer_requirement_create_platform_identity, _xpc_peer_requirement_create_team_identity, + _xpc_peer_requirement_match_received_message, _xpc_pipe_create, + _xpc_pipe_create_from_port, _xpc_pipe_create_reply_from_port, + _xpc_pipe_create_with_user_session_uid, _xpc_pipe_invalidate, + _xpc_pipe_receive, _xpc_pipe_routine, _xpc_pipe_routine_async, + _xpc_pipe_routine_forward, _xpc_pipe_routine_reply, _xpc_pipe_routine_with_flags, + _xpc_pipe_simpleroutine, _xpc_pipe_try_receive, _xpc_pointer_create, + _xpc_pointer_get_value, _xpc_receive_mach_msg, _xpc_receive_mach_msg_validate_hdr, + _xpc_receive_remote_msg, _xpc_release, _xpc_retain, _xpc_rich_error_can_retry, + _xpc_rich_error_copy_description, _xpc_service_attach, _xpc_service_attach_with_flags, + _xpc_service_create, _xpc_service_create_from_specifier, _xpc_service_get_rendezvous_token, _xpc_service_instance_dup2, _xpc_service_instance_get_context, _xpc_service_instance_get_host_pid, _xpc_service_instance_get_pid, _xpc_service_instance_get_type, _xpc_service_instance_is_configurable, - _xpc_service_instance_run, _xpc_service_instance_set_binpref, - _xpc_service_instance_set_context, _xpc_service_instance_set_cwd, - _xpc_service_instance_set_endpoint, _xpc_service_instance_set_environment, - _xpc_service_instance_set_finalizer_f, _xpc_service_instance_set_jetsam_properties, - _xpc_service_instance_set_path, _xpc_service_instance_set_start_suspended, - _xpc_service_instance_set_use_sec_transition_shims, _xpc_service_kickstart, - _xpc_service_kickstart_with_flags, _xpc_service_set_attach_handler, - _xpc_session_activate, _xpc_session_cancel, _xpc_session_copy_description, - _xpc_session_create_mach_service, _xpc_session_create_xpc_endpoint, - _xpc_session_create_xpc_service, _xpc_session_send_message, - _xpc_session_send_message_with_reply_async, _xpc_session_send_message_with_reply_sync, - _xpc_session_set_cancel_handler, _xpc_session_set_incoming_message_handler, - _xpc_session_set_instance, _xpc_session_set_peer_code_signing_requirement, + _xpc_service_instance_run, _xpc_service_instance_set_archpref, + _xpc_service_instance_set_binpref, _xpc_service_instance_set_context, + _xpc_service_instance_set_cwd, _xpc_service_instance_set_endpoint, + _xpc_service_instance_set_environment, _xpc_service_instance_set_finalizer_f, + _xpc_service_instance_set_jetsam_properties, _xpc_service_instance_set_path, + _xpc_service_instance_set_start_suspended, _xpc_service_instance_set_use_sec_transition_shims, + _xpc_service_kickstart, _xpc_service_kickstart_with_flags, + _xpc_service_set_attach_handler, _xpc_session_activate, _xpc_session_cancel, + _xpc_session_copy_description, _xpc_session_create_mach_service, + _xpc_session_create_xpc_endpoint, _xpc_session_create_xpc_service, + _xpc_session_send_message, _xpc_session_send_message_with_reply_async, + _xpc_session_send_message_with_reply_sync, _xpc_session_set_cancel_handler, + _xpc_session_set_incoming_message_handler, _xpc_session_set_instance, + _xpc_session_set_peer_code_signing_requirement, _xpc_session_set_peer_requirement, _xpc_session_set_target_queue, _xpc_session_set_target_user_session_uid, _xpc_set_event, _xpc_set_event_state, _xpc_set_event_stream_handler, _xpc_set_event_with_flags, _xpc_set_idle_handler, _xpc_shmem_create, _xpc_shmem_create_readonly, _xpc_shmem_get_length, _xpc_shmem_map, - _xpc_strerror, _xpc_string_create, _xpc_string_create_no_copy, - _xpc_string_create_with_format, _xpc_string_create_with_format_and_arguments, - _xpc_string_get_length, _xpc_string_get_string_ptr, _xpc_test_symbols_exported, - _xpc_track_activity, _xpc_transaction_begin, _xpc_transaction_end, - _xpc_transaction_exit_clean, _xpc_transaction_interrupt_clean_exit, - _xpc_transaction_try_exit_clean, _xpc_transactions_enable, - _xpc_traverse_serialized_data, _xpc_type_get_name, _xpc_uint64_create, - _xpc_uint64_get_value, _xpc_user_sessions_enabled, _xpc_user_sessions_get_foreground_uid, - _xpc_user_sessions_get_session_uid, _xpc_uuid_create, _xpc_uuid_get_bytes ] + _xpc_strerror, _xpc_string_cache_create, _xpc_string_cache_for_each, + _xpc_string_cache_get_count, _xpc_string_cache_get_name, _xpc_string_create, + _xpc_string_create_cached, _xpc_string_create_no_copy, _xpc_string_create_with_format, + _xpc_string_create_with_format_and_arguments, _xpc_string_get_length, + _xpc_string_get_string_ptr, _xpc_test_symbols_exported, _xpc_track_activity, + _xpc_transaction_begin, _xpc_transaction_end, _xpc_transaction_exit_clean, + _xpc_transaction_interrupt_clean_exit, _xpc_transaction_try_exit_clean, + _xpc_transactions_enable, _xpc_traverse_serialized_data, _xpc_type_get_name, + _xpc_uint64_create, _xpc_uint64_get_value, _xpc_user_sessions_enabled, + _xpc_user_sessions_get_foreground_uid, _xpc_user_sessions_get_session_uid, + _xpc_uuid_create, _xpc_uuid_get_bytes ] objc-classes: [ OS_xpc_object ] ... diff --git a/lib/libc/include/any-macos-any/Availability.h b/lib/libc/include/any-macos-any/Availability.h index 71db7d4dc4..a0fc52aa61 100644 --- a/lib/libc/include/any-macos-any/Availability.h +++ b/lib/libc/include/any-macos-any/Availability.h @@ -469,6 +469,9 @@ * ios, iOSApplicationExtension, tvos, tvOSApplicationExtension, watchos, * watchOSApplicationExtension, driverkit, visionos, visionOSApplicationExtension * + * Within each platform a tuple of versions will represent the version the API was + * introduced in, followed by the version it was deperecated in. + * * Examples: * * __API_DEPRECATED("Deprecated", macos(10.4, 10.8)) @@ -487,6 +490,7 @@ #define __API_DEPRECATED_WITH_REPLACEMENT_END _Pragma("clang attribute pop") + #define __API_OBSOLETED(...) __API_OBSOLETED_MSG_GET_MACRO_93585900(__VA_ARGS__,__API_OBSOLETED_MSG15,__API_OBSOLETED_MSG14,__API_OBSOLETED_MSG13,__API_OBSOLETED_MSG12,__API_OBSOLETED_MSG11,__API_OBSOLETED_MSG10,__API_OBSOLETED_MSG9,__API_OBSOLETED_MSG8,__API_OBSOLETED_MSG7,__API_OBSOLETED_MSG6,__API_OBSOLETED_MSG5,__API_OBSOLETED_MSG4,__API_OBSOLETED_MSG3,__API_OBSOLETED_MSG2,__API_OBSOLETED_MSG1,__API_OBSOLETED_MSG0,0,0)(__VA_ARGS__) #define __API_OBSOLETED_WITH_REPLACEMENT(...) __API_OBSOLETED_REP_GET_MACRO_93585900(__VA_ARGS__,__API_OBSOLETED_REP15,__API_OBSOLETED_REP14,__API_OBSOLETED_REP13,__API_OBSOLETED_REP12,__API_OBSOLETED_REP11,__API_OBSOLETED_REP10,__API_OBSOLETED_REP9,__API_OBSOLETED_REP8,__API_OBSOLETED_REP7,__API_OBSOLETED_REP6,__API_OBSOLETED_REP5,__API_OBSOLETED_REP4,__API_OBSOLETED_REP3,__API_OBSOLETED_REP2,__API_OBSOLETED_REP1,__API_OBSOLETED_REP0,0,0)(__VA_ARGS__) @@ -496,6 +500,7 @@ #define __API_OBSOLETED_WITH_REPLACEMENT_BEGIN(...) _Pragma("clang attribute push") __API_OBSOLETED_WITH_REPLACEMENT_BEGIN_GET_MACRO_93585900(__VA_ARGS__,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN15,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN14,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN13,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN12,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN11,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN10,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN9,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN8,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN7,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN6,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN5,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN4,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN3,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN2,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN1,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN0,0,0)(__VA_ARGS__) #define __API_OBSOLETED_WITH_REPLACEMENT_END _Pragma("clang attribute pop") + /* * API Unavailability * Use to specify that an API is unavailable for a particular platform. @@ -524,7 +529,7 @@ #endif #ifndef __API_AVAILABLE_END - #define __API_AVAILABLE_END(...) + #define __API_AVAILABLE_END #endif #ifndef __API_DEPRECATED @@ -536,7 +541,7 @@ #endif #ifndef __API_DEPRECATED_END - #define __API_DEPRECATED_END(...) + #define __API_DEPRECATED_END #endif #ifndef __API_DEPRECATED_WITH_REPLACEMENT @@ -548,7 +553,7 @@ #endif #ifndef __API_DEPRECATED_WITH_REPLACEMENT_END - #define __API_DEPRECATED_WITH_REPLACEMENT_END(...) + #define __API_DEPRECATED_WITH_REPLACEMENT_END #endif #ifndef __API_OBSOLETED @@ -560,7 +565,7 @@ #endif #ifndef __API_OBSOLETED_END - #define __API_OBSOLETED_END(...) + #define __API_OBSOLETED_END #endif #ifndef __API_OBSOLETED_WITH_REPLACEMENT @@ -572,7 +577,7 @@ #endif #ifndef __API_OBSOLETED_WITH_REPLACEMENT_END - #define __API_OBSOLETED_WITH_REPLACEMENT_END(...) + #define __API_OBSOLETED_WITH_REPLACEMENT_END #endif #ifndef __API_UNAVAILABLE @@ -584,7 +589,7 @@ #endif #ifndef __API_UNAVAILABLE_END - #define __API_UNAVAILABLE_END(...) + #define __API_UNAVAILABLE_END #endif /* @@ -600,7 +605,7 @@ #endif #ifndef __SPI_AVAILABLE_END - #define __SPI_AVAILABLE_END(...) + #define __SPI_AVAILABLE_END #endif #ifndef __SPI_DEPRECATED diff --git a/lib/libc/include/any-macos-any/AvailabilityInternal.h b/lib/libc/include/any-macos-any/AvailabilityInternal.h index 736852841b..318c2f9033 100644 --- a/lib/libc/include/any-macos-any/AvailabilityInternal.h +++ b/lib/libc/include/any-macos-any/AvailabilityInternal.h @@ -33,81 +33,93 @@ #include #ifndef __MAC_OS_X_VERSION_MIN_REQUIRED - #if defined(__has_builtin) && __has_builtin(__is_target_os) - #if __is_target_os(macos) - #define __MAC_OS_X_VERSION_MIN_REQUIRED __ENVIRONMENT_OS_VERSION_MIN_REQUIRED__ - #define __MAC_OS_X_VERSION_MAX_ALLOWED __MAC_15_5 - #endif - #elif __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ - #define __MAC_OS_X_VERSION_MIN_REQUIRED __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ - #define __MAC_OS_X_VERSION_MAX_ALLOWED __MAC_15_5 - #endif /* __has_builtin(__is_target_os) && __is_target_os(macos) */ + #if defined(__has_builtin) + #if __has_builtin(__is_target_os) + #if __is_target_os(macos) + #define __MAC_OS_X_VERSION_MIN_REQUIRED __ENVIRONMENT_OS_VERSION_MIN_REQUIRED__ + #define __MAC_OS_X_VERSION_MAX_ALLOWED __MAC_26_0 + #endif + #elif __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ + #define __MAC_OS_X_VERSION_MIN_REQUIRED __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ + #define __MAC_OS_X_VERSION_MAX_ALLOWED __MAC_26_0 + #endif /* __has_builtin(__is_target_os) */ + #endif /* defined(__has_builtin) */ #endif /* __MAC_OS_X_VERSION_MIN_REQUIRED */ #ifndef __IPHONE_OS_VERSION_MIN_REQUIRED - #if defined(__has_builtin) && __has_builtin(__is_target_os) - #if __is_target_os(ios) - #define __IPHONE_OS_VERSION_MIN_REQUIRED __ENVIRONMENT_OS_VERSION_MIN_REQUIRED__ - #define __IPHONE_OS_VERSION_MAX_ALLOWED __IPHONE_18_5 - #endif - #elif __ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__ - #define __IPHONE_OS_VERSION_MIN_REQUIRED __ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__ - #define __IPHONE_OS_VERSION_MAX_ALLOWED __IPHONE_18_5 - #endif /* __has_builtin(__is_target_os) && __is_target_os(ios) */ + #if defined(__has_builtin) + #if __has_builtin(__is_target_os) + #if __is_target_os(ios) + #define __IPHONE_OS_VERSION_MIN_REQUIRED __ENVIRONMENT_OS_VERSION_MIN_REQUIRED__ + #define __IPHONE_OS_VERSION_MAX_ALLOWED __IPHONE_26_0 + #endif + #elif __ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__ + #define __IPHONE_OS_VERSION_MIN_REQUIRED __ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__ + #define __IPHONE_OS_VERSION_MAX_ALLOWED __IPHONE_26_0 + #endif /* __has_builtin(__is_target_os) */ + #endif /* defined(__has_builtin) */ #endif /* __IPHONE_OS_VERSION_MIN_REQUIRED */ #ifndef __WATCH_OS_VERSION_MIN_REQUIRED - #if defined(__has_builtin) && __has_builtin(__is_target_os) - #if __is_target_os(watchos) - #define __WATCH_OS_VERSION_MIN_REQUIRED __ENVIRONMENT_OS_VERSION_MIN_REQUIRED__ - #define __WATCH_OS_VERSION_MAX_ALLOWED __WATCHOS_11_5 + #if defined(__has_builtin) + #if __has_builtin(__is_target_os) + #if __is_target_os(watchos) + #define __WATCH_OS_VERSION_MIN_REQUIRED __ENVIRONMENT_OS_VERSION_MIN_REQUIRED__ + #define __WATCH_OS_VERSION_MAX_ALLOWED __WATCHOS_26_0 + /* for compatibility with existing code. New code should use platform specific checks */ + #define __IPHONE_OS_VERSION_MIN_REQUIRED __IPHONE_9_0 + #endif + #elif __ENVIRONMENT_WATCH_OS_VERSION_MIN_REQUIRED__ + #define __WATCH_OS_VERSION_MIN_REQUIRED __ENVIRONMENT_WATCH_OS_VERSION_MIN_REQUIRED__ + #define __WATCH_OS_VERSION_MAX_ALLOWED __WATCHOS_26_0 /* for compatibility with existing code. New code should use platform specific checks */ #define __IPHONE_OS_VERSION_MIN_REQUIRED __IPHONE_9_0 - #endif - #elif __ENVIRONMENT_WATCH_OS_VERSION_MIN_REQUIRED__ - #define __WATCH_OS_VERSION_MIN_REQUIRED __ENVIRONMENT_WATCH_OS_VERSION_MIN_REQUIRED__ - #define __WATCH_OS_VERSION_MAX_ALLOWED __WATCHOS_11_5 - /* for compatibility with existing code. New code should use platform specific checks */ - #define __IPHONE_OS_VERSION_MIN_REQUIRED __IPHONE_9_0 - #endif /* __has_builtin(__is_target_os) && __is_target_os(watchos) */ + #endif /* __has_builtin(__is_target_os) */ + #endif /* defined(__has_builtin) */ #endif /* __WATCH_OS_VERSION_MIN_REQUIRED */ #ifndef __TV_OS_VERSION_MIN_REQUIRED - #if defined(__has_builtin) && __has_builtin(__is_target_os) - #if __is_target_os(tvos) - #define __TV_OS_VERSION_MIN_REQUIRED __ENVIRONMENT_OS_VERSION_MIN_REQUIRED__ - #define __TV_OS_VERSION_MAX_ALLOWED __TVOS_18_5 + #if defined(__has_builtin) + #if __has_builtin(__is_target_os) + #if __is_target_os(tvos) + #define __TV_OS_VERSION_MIN_REQUIRED __ENVIRONMENT_OS_VERSION_MIN_REQUIRED__ + #define __TV_OS_VERSION_MAX_ALLOWED __TVOS_26_0 + /* for compatibility with existing code. New code should use platform specific checks */ + #define __IPHONE_OS_VERSION_MIN_REQUIRED __IPHONE_9_0 + #endif + #elif __ENVIRONMENT_TV_OS_VERSION_MIN_REQUIRED__ + #define __TV_OS_VERSION_MIN_REQUIRED __ENVIRONMENT_TV_OS_VERSION_MIN_REQUIRED__ + #define __TV_OS_VERSION_MAX_ALLOWED __TVOS_26_0 /* for compatibility with existing code. New code should use platform specific checks */ #define __IPHONE_OS_VERSION_MIN_REQUIRED __IPHONE_9_0 - #endif - #elif __ENVIRONMENT_TV_OS_VERSION_MIN_REQUIRED__ - #define __TV_OS_VERSION_MIN_REQUIRED __ENVIRONMENT_TV_OS_VERSION_MIN_REQUIRED__ - #define __TV_OS_VERSION_MAX_ALLOWED __TVOS_18_5 - /* for compatibility with existing code. New code should use platform specific checks */ - #define __IPHONE_OS_VERSION_MIN_REQUIRED __IPHONE_9_0 - #endif /* __has_builtin(__is_target_os) && __is_target_os(tvos) */ + #endif /* __has_builtin(__is_target_os) */ + #endif /* defined(__has_builtin) */ #endif /* __TV_OS_VERSION_MIN_REQUIRED */ #ifndef __DRIVERKIT_VERSION_MIN_REQUIRED - #if defined(__has_builtin) && __has_builtin(__is_target_os) - #if __is_target_os(driverkit) - #define __DRIVERKIT_VERSION_MIN_REQUIRED __ENVIRONMENT_OS_VERSION_MIN_REQUIRED__ - #define __DRIVERKIT_VERSION_MAX_ALLOWED __DRIVERKIT_24_5 - #endif - #endif /* __has_builtin(__is_target_os) && __is_target_os(driverkit) */ + #if defined(__has_builtin) + #if __has_builtin(__is_target_os) + #if __is_target_os(driverkit) + #define __DRIVERKIT_VERSION_MIN_REQUIRED __ENVIRONMENT_OS_VERSION_MIN_REQUIRED__ + #define __DRIVERKIT_VERSION_MAX_ALLOWED __DRIVERKIT_25_0 + #endif + #endif /* __has_builtin(__is_target_os) */ + #endif /* defined(__has_builtin) */ #endif /* __DRIVERKIT_VERSION_MIN_REQUIRED */ #ifndef __VISION_OS_VERSION_MIN_REQUIRED - #if defined(__has_builtin) && __has_builtin(__is_target_os) - #if __is_target_os(visionos) - #define __VISION_OS_VERSION_MIN_REQUIRED __ENVIRONMENT_OS_VERSION_MIN_REQUIRED__ - #define __VISION_OS_VERSION_MAX_ALLOWED __VISIONOS_2_5 - /* for compatibility with existing code. New code should use platform specific checks */ - #define __IPHONE_OS_VERSION_MIN_REQUIRED __IPHONE_17_1 - #endif - #endif /* __has_builtin(__is_target_os) && __is_target_os(visionos) */ + #if defined(__has_builtin) + #if __has_builtin(__is_target_os) + #if __is_target_os(visionos) + #define __VISION_OS_VERSION_MIN_REQUIRED __ENVIRONMENT_OS_VERSION_MIN_REQUIRED__ + #define __VISION_OS_VERSION_MAX_ALLOWED __VISIONOS_26_0 + /* for compatibility with existing code. New code should use platform specific checks */ + #define __IPHONE_OS_VERSION_MIN_REQUIRED __IPHONE_17_1 + #endif + #endif /* __has_builtin(__is_target_os) */ + #endif /* defined(__has_builtin) */ #endif /* __VISION_OS_VERSION_MIN_REQUIRED */ diff --git a/lib/libc/include/any-macos-any/AvailabilityVersions.h b/lib/libc/include/any-macos-any/AvailabilityVersions.h index b93b1d05b2..79ad3f6737 100644 --- a/lib/libc/include/any-macos-any/AvailabilityVersions.h +++ b/lib/libc/include/any-macos-any/AvailabilityVersions.h @@ -74,7 +74,6 @@ #define __MAC_12_7 120700 #define __MAC_13_0 130000 #define __MAC_13_1 130100 -#define __MAC_13_1 130100 #define __MAC_13_2 130200 #define __MAC_13_3 130300 #define __MAC_13_4 130400 @@ -95,6 +94,9 @@ #define __MAC_15_3 150300 #define __MAC_15_4 150400 #define __MAC_15_5 150500 +#define __MAC_15_6 150600 +#define __MAC_16_0 160000 +#define __MAC_26_0 260000 /* __MAC__NA is not defined to a value but is used as a token by macros to indicate that the API is unavailable */ #define __IPHONE_2_0 20000 @@ -149,8 +151,6 @@ #define __IPHONE_14_2 140200 #define __IPHONE_14_3 140300 #define __IPHONE_14_5 140500 -#define __IPHONE_14_4 140400 -#define __IPHONE_14_5 140500 #define __IPHONE_14_6 140600 #define __IPHONE_14_7 140700 #define __IPHONE_14_8 140800 @@ -185,6 +185,9 @@ #define __IPHONE_18_3 180300 #define __IPHONE_18_4 180400 #define __IPHONE_18_5 180500 +#define __IPHONE_18_6 180600 +#define __IPHONE_19_0 190000 +#define __IPHONE_26_0 260000 /* __IPHONE__NA is not defined to a value but is used as a token by macros to indicate that the API is unavailable */ #define __WATCHOS_1_0 10000 @@ -242,6 +245,9 @@ #define __WATCHOS_11_3 110300 #define __WATCHOS_11_4 110400 #define __WATCHOS_11_5 110500 +#define __WATCHOS_11_6 110600 +#define __WATCHOS_12_0 120000 +#define __WATCHOS_26_0 260000 /* __WATCHOS__NA is not defined to a value but is used as a token by macros to indicate that the API is unavailable */ #define __TVOS_9_0 90000 @@ -299,6 +305,9 @@ #define __TVOS_18_3 180300 #define __TVOS_18_4 180400 #define __TVOS_18_5 180500 +#define __TVOS_18_6 180600 +#define __TVOS_19_0 190000 +#define __TVOS_26_0 260000 /* __TVOS__NA is not defined to a value but is used as a token by macros to indicate that the API is unavailable */ #define __BRIDGEOS_2_0 20000 @@ -317,7 +326,6 @@ #define __BRIDGEOS_6_6 60600 #define __BRIDGEOS_7_0 70000 #define __BRIDGEOS_7_1 70100 -#define __BRIDGEOS_7_1 70100 #define __BRIDGEOS_7_2 70200 #define __BRIDGEOS_7_3 70300 #define __BRIDGEOS_7_4 70400 @@ -335,6 +343,8 @@ #define __BRIDGEOS_9_3 90300 #define __BRIDGEOS_9_4 90400 #define __BRIDGEOS_9_5 90500 +#define __BRIDGEOS_9_6 90600 +#define __BRIDGEOS_10_0 100000 #define __DRIVERKIT_19_0 190000 @@ -357,6 +367,8 @@ #define __DRIVERKIT_24_3 240300 #define __DRIVERKIT_24_4 240400 #define __DRIVERKIT_24_5 240500 +#define __DRIVERKIT_24_6 240600 +#define __DRIVERKIT_25_0 250000 /* __DRIVERKIT__NA is not defined to a value but is used as a token by macros to indicate that the API is unavailable */ #define __VISIONOS_1_0 10000 @@ -369,6 +381,9 @@ #define __VISIONOS_2_3 20300 #define __VISIONOS_2_4 20400 #define __VISIONOS_2_5 20500 +#define __VISIONOS_2_6 20600 +#define __VISIONOS_3_0 30000 +#define __VISIONOS_26_0 260000 /* __VISIONOS__NA is not defined to a value but is used as a token by macros to indicate that the API is unavailable */ @@ -436,7 +451,6 @@ #define MAC_OS_VERSION_12_7 __MAC_12_7 #define MAC_OS_VERSION_13_0 __MAC_13_0 #define MAC_OS_VERSION_13_1 __MAC_13_1 -#define MAC_OS_VERSION_13_1 __MAC_13_1 #define MAC_OS_VERSION_13_2 __MAC_13_2 #define MAC_OS_VERSION_13_3 __MAC_13_3 #define MAC_OS_VERSION_13_4 __MAC_13_4 @@ -457,6 +471,9 @@ #define MAC_OS_VERSION_15_3 __MAC_15_3 #define MAC_OS_VERSION_15_4 __MAC_15_4 #define MAC_OS_VERSION_15_5 __MAC_15_5 +#define MAC_OS_VERSION_15_6 __MAC_15_6 +#define MAC_OS_VERSION_16_0 __MAC_16_0 +#define MAC_OS_VERSION_26_0 __MAC_26_0 #endif /* #if (!defined(_POSIX_C_SOURCE) && !defined(_XOPEN_SOURCE)) || defined(_DARWIN_C_SOURCE) */ diff --git a/lib/libc/include/any-macos-any/_bounds.h b/lib/libc/include/any-macos-any/_bounds.h index eb3f70a68a..71440b05a2 100644 --- a/lib/libc/include/any-macos-any/_bounds.h +++ b/lib/libc/include/any-macos-any/_bounds.h @@ -42,6 +42,8 @@ #define _LIBC_SINGLE_BY_DEFAULT() __ptrcheck_abi_assume_single() #define _LIBC_PTRCHECK_REPLACED(R) __ptrcheck_unavailable_r(R) +#define _LIBC_FORGE_PTR(P, S) __unsafe_forge_bidi_indexable(__typeof__(*P) *, P, S) + #else /* _LIBC_ANNOTATE_BOUNDS */ #define _LIBC_COUNT(x) @@ -58,6 +60,8 @@ #define _LIBC_SINGLE_BY_DEFAULT() #define _LIBC_PTRCHECK_REPLACED(R) +#define _LIBC_FORGE_PTR(P, S) (P) + #endif /* _LIBC_ANNOTATE_BOUNDS */ #endif /* _LIBC_BOUNDS_H_ */ diff --git a/lib/libc/include/any-macos-any/_ctermid.h b/lib/libc/include/any-macos-any/_ctermid.h index fc0ec073b2..b21734e6fb 100644 --- a/lib/libc/include/any-macos-any/_ctermid.h +++ b/lib/libc/include/any-macos-any/_ctermid.h @@ -27,13 +27,15 @@ #include #include <_bounds.h> +#ifndef _LIBC_COUNT__L_CTERMID +#define _LIBC_COUNT__L_CTERMID _LIBC_UNSAFE_INDEXABLE +#endif /* _LIBC_COUNT__L_CTERMID */ + _LIBC_SINGLE_BY_DEFAULT() __BEGIN_DECLS -#define L_ctermid 1024 /* size for ctermid(); PATH_MAX */ - -char *_LIBC_CSTR ctermid(char *_LIBC_COUNT_OR_NULL(L_ctermid)); +char *_LIBC_CSTR ctermid(char *_LIBC_COUNT__L_CTERMID); __END_DECLS diff --git a/lib/libc/include/any-macos-any/_locale.h b/lib/libc/include/any-macos-any/_locale.h index 540d16b070..2b18a91701 100644 --- a/lib/libc/include/any-macos-any/_locale.h +++ b/lib/libc/include/any-macos-any/_locale.h @@ -41,6 +41,10 @@ #include <_bounds.h> #include <_types.h> +#if !defined(_POSIX_C_SOURCE) || _POSIX_C_SOURCE >= 200809L +#include <_locale_posix2008.h> +#endif + _LIBC_SINGLE_BY_DEFAULT() struct lconv { @@ -72,33 +76,8 @@ struct lconv { #include -#define LC_ALL_MASK ( LC_COLLATE_MASK \ - | LC_CTYPE_MASK \ - | LC_MESSAGES_MASK \ - | LC_MONETARY_MASK \ - | LC_NUMERIC_MASK \ - | LC_TIME_MASK ) -#define LC_COLLATE_MASK (1 << 0) -#define LC_CTYPE_MASK (1 << 1) -#define LC_MESSAGES_MASK (1 << 2) -#define LC_MONETARY_MASK (1 << 3) -#define LC_NUMERIC_MASK (1 << 4) -#define LC_TIME_MASK (1 << 5) - -#define _LC_NUM_MASK 6 -#define _LC_LAST_MASK (1 << (_LC_NUM_MASK - 1)) - -#define LC_GLOBAL_LOCALE ((locale_t)-1) -#define LC_C_LOCALE ((locale_t)NULL) - -#include <_types/_locale_t.h> - __BEGIN_DECLS -locale_t duplocale(locale_t); -int freelocale(locale_t); struct lconv *localeconv(void); -locale_t newlocale(int, __const char *, locale_t); -locale_t uselocale(locale_t); __END_DECLS #endif /* __LOCALE_H_ */ diff --git a/lib/libc/include/any-macos-any/_locale_posix2008.h b/lib/libc/include/any-macos-any/_locale_posix2008.h new file mode 100644 index 0000000000..bc22722a5a --- /dev/null +++ b/lib/libc/include/any-macos-any/_locale_posix2008.h @@ -0,0 +1,65 @@ +/* + * Copyright (c) 2005 - 2025 Apple Computer, Inc. All rights reserved. + * + * @APPLE_LICENSE_HEADER_START@ + * + * This file contains Original Code and/or Modifications of Original Code + * as defined in and that are subject to the Apple Public Source License + * Version 2.0 (the 'License'). You may not use this file except in + * compliance with the License. Please obtain a copy of the License at + * http://www.opensource.apple.com/apsl/ and read it before using this + * file. + * + * The Original Code and all software distributed under the License are + * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER + * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, + * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. + * Please see the License for the specific language governing rights and + * limitations under the License. + * + * @APPLE_LICENSE_HEADER_END@ + */ + +#ifndef __LOCALE_POSIX2008_H_ +#define __LOCALE_POSIX2008_H_ + +#include +#include <_types.h> + +_LIBC_SINGLE_BY_DEFAULT() + +/* + * These definitions were all historically provided by , but they + * became standardized in POSIX.1-2008. We make them available via either + * or at the appropriate conformance level. + */ +#define LC_ALL_MASK ( LC_COLLATE_MASK \ + | LC_CTYPE_MASK \ + | LC_MESSAGES_MASK \ + | LC_MONETARY_MASK \ + | LC_NUMERIC_MASK \ + | LC_TIME_MASK ) +#define LC_COLLATE_MASK (1 << 0) +#define LC_CTYPE_MASK (1 << 1) +#define LC_MESSAGES_MASK (1 << 2) +#define LC_MONETARY_MASK (1 << 3) +#define LC_NUMERIC_MASK (1 << 4) +#define LC_TIME_MASK (1 << 5) + +#define _LC_NUM_MASK 6 +#define _LC_LAST_MASK (1 << (_LC_NUM_MASK - 1)) + +#define LC_GLOBAL_LOCALE ((locale_t)-1) +#define LC_C_LOCALE ((locale_t)NULL) + +#include <_types/_locale_t.h> + +__BEGIN_DECLS +locale_t duplocale(locale_t); +int freelocale(locale_t); +locale_t newlocale(int, __const char *, locale_t); +locale_t uselocale(locale_t); +__END_DECLS + +#endif /* __LOCALE_POSIX2008_H_ */ diff --git a/lib/libc/include/any-macos-any/_stdio.h b/lib/libc/include/any-macos-any/_stdio.h index e8b463566e..b2234bd7cf 100644 --- a/lib/libc/include/any-macos-any/_stdio.h +++ b/lib/libc/include/any-macos-any/_stdio.h @@ -308,6 +308,10 @@ __END_DECLS #if __DARWIN_C_LEVEL >= 198808L +#define L_ctermid 1024 /* size for ctermid(); PATH_MAX */ +#undef _LIBC_COUNT__L_CTERMID +#define _LIBC_COUNT__L_CTERMID _LIBC_COUNT_OR_NULL(L_ctermid) + #include <_ctermid.h> __BEGIN_DECLS diff --git a/lib/libc/include/any-macos-any/_stdlib.h b/lib/libc/include/any-macos-any/_stdlib.h index cfe404386b..15ad16a132 100644 --- a/lib/libc/include/any-macos-any/_stdlib.h +++ b/lib/libc/include/any-macos-any/_stdlib.h @@ -123,18 +123,23 @@ typedef struct { #define RAND_MAX 0x7fffffff -// When _USE_EXTENDED_LOCALES_ is enabled (by including xlocale.h), -// MB_CUR_MAX is defined by xlocale.h. -#if !defined(MB_CUR_MAX) && !defined(_USE_EXTENDED_LOCALES_) #if __has_feature(modules) // When clang modules are enabled, there can only be one definition of // MB_CUR_MAX, and that needs to be the same one used by xlocale.h. #include <_mb_cur_max.h> -#else +#else /* !__has_feature(modules) */ +#ifndef MB_CUR_MAX +#ifdef _USE_EXTENDED_LOCALES_ +#define MB_CUR_MAX (___mb_cur_max()) +#ifndef MB_CUR_MAX_L +#define MB_CUR_MAX_L(x) (___mb_cur_max_l(x)) +#endif /* !MB_CUR_MAX_L */ +#else /* !_USE_EXTENDED_LOCALES_ */ extern int __mb_cur_max; #define MB_CUR_MAX __mb_cur_max +#endif /* _USE_EXTENDED_LOCALES_ */ +#endif /* MB_CUR_MAX */ #endif /* __has_feature(modules) */ -#endif /* !MB_CUR_MAX && !_USE_EXTENDED_LOCALES_ */ #include #include <_abort.h> diff --git a/lib/libc/include/any-macos-any/_string.h b/lib/libc/include/any-macos-any/_string.h index f06e5fef16..a07a835d3e 100644 --- a/lib/libc/include/any-macos-any/_string.h +++ b/lib/libc/include/any-macos-any/_string.h @@ -100,7 +100,7 @@ char *_LIBC_CSTR _LIBC_PTRCHECK_REPLACED(strlcat); int strncmp(const char *_LIBC_UNSAFE_INDEXABLE __s1, const char *_LIBC_UNSAFE_INDEXABLE __s2, size_t __n); -char *_LIBC_UNSAFE_INDEXABLE +char *_LIBC_COUNT(__n) strncpy(char *_LIBC_COUNT(__n) __dst, const char *_LIBC_UNSAFE_INDEXABLE __src, size_t __n) _LIBC_PTRCHECK_REPLACED(strlcpy); @@ -155,7 +155,7 @@ __END_DECLS __BEGIN_DECLS char *_LIBC_CSTR stpcpy(char *_LIBC_UNSAFE_INDEXABLE __dst, const char *__src) _LIBC_PTRCHECK_REPLACED(strlcpy); -char *_LIBC_CSTR +char *_LIBC_COUNT(__n) stpncpy(char *_LIBC_UNSAFE_INDEXABLE __dst, const char *_LIBC_UNSAFE_INDEXABLE __src, size_t __n) __OSX_AVAILABLE_STARTING(__MAC_10_7, __IPHONE_4_3) diff --git a/lib/libc/include/any-macos-any/_xlocale.h b/lib/libc/include/any-macos-any/_xlocale.h index 6f290567eb..fd797e58e6 100644 --- a/lib/libc/include/any-macos-any/_xlocale.h +++ b/lib/libc/include/any-macos-any/_xlocale.h @@ -32,6 +32,7 @@ #endif /* _USE_EXTENDED_LOCALES_ */ #include <_locale.h> +#include <_locale_posix2008.h> #include <__xlocale.h> _LIBC_SINGLE_BY_DEFAULT() diff --git a/lib/libc/include/any-macos-any/assert.h b/lib/libc/include/any-macos-any/assert.h index 8a87524ae4..6b84985a96 100644 --- a/lib/libc/include/any-macos-any/assert.h +++ b/lib/libc/include/any-macos-any/assert.h @@ -40,9 +40,6 @@ */ #include -#ifdef __cplusplus -#include -#endif /* __cplusplus */ /* * Unlike other ANSI header files, may usefully be included diff --git a/lib/libc/include/any-macos-any/mach/host_info.h b/lib/libc/include/any-macos-any/mach/host_info.h index 63b99bef18..6d8df42de6 100644 --- a/lib/libc/include/any-macos-any/mach/host_info.h +++ b/lib/libc/include/any-macos-any/mach/host_info.h @@ -207,11 +207,12 @@ typedef struct vm_purgeable_info *host_purgable_info_t; /* size of the latest version of the structure */ #define HOST_VM_INFO64_LATEST_COUNT HOST_VM_INFO64_COUNT -#define HOST_VM_INFO64_REV1_COUNT HOST_VM_INFO64_LATEST_COUNT +#define HOST_VM_INFO64_REV2_COUNT HOST_VM_INFO64_COUNT +#define HOST_VM_INFO64_REV1_COUNT ((mach_msg_type_number_t) \ + (offsetof(vm_statistics64_data_t, swapped_count) / sizeof(integer_t))) /* previous versions: adjust the size according to what was added each time */ -#define HOST_VM_INFO64_REV0_COUNT /* added compression and swapper info (14 ints) */ \ - ((mach_msg_type_number_t) \ - (HOST_VM_INFO64_REV1_COUNT - 14)) +#define HOST_VM_INFO64_REV0_COUNT ((mach_msg_type_number_t) \ + (offsetof(vm_statistics64_data_t, decompressions) / sizeof(integer_t))) /* in */ /* vm_extmod_statistics */ diff --git a/lib/libc/include/any-macos-any/mach/mach_port.h b/lib/libc/include/any-macos-any/mach/mach_port.h index e19136b410..1bb406737c 100644 --- a/lib/libc/include/any-macos-any/mach/mach_port.h +++ b/lib/libc/include/any-macos-any/mach/mach_port.h @@ -501,7 +501,7 @@ kern_return_t mach_port_kobject ( ipc_space_read_t task, mach_port_name_t name, - natural_t *object_type, + ipc_info_object_type_t *object_type, mach_vm_address_t *object_addr ); @@ -610,7 +610,7 @@ kern_return_t mach_port_kobject_description ( ipc_space_read_t task, mach_port_name_t name, - natural_t *object_type, + ipc_info_object_type_t *object_type, mach_vm_address_t *object_addr, kobject_description_t description ); @@ -1690,7 +1690,7 @@ union __RequestUnion__mach_port_subsystem { mach_msg_header_t Head; NDR_record_t NDR; kern_return_t RetCode; - natural_t object_type; + ipc_info_object_type_t object_type; mach_vm_address_t object_addr; } __Reply__mach_port_kobject_t __attribute__((unused)); #ifdef __MigPackStructs @@ -1790,7 +1790,7 @@ union __RequestUnion__mach_port_subsystem { mach_msg_header_t Head; NDR_record_t NDR; kern_return_t RetCode; - natural_t object_type; + ipc_info_object_type_t object_type; mach_vm_address_t object_addr; mach_msg_type_number_t descriptionOffset; /* MiG doesn't use it */ mach_msg_type_number_t descriptionCnt; diff --git a/lib/libc/include/any-macos-any/mach/mach_traps.h b/lib/libc/include/any-macos-any/mach/mach_traps.h index ed17b20bb4..6bd4a8ec7a 100644 --- a/lib/libc/include/any-macos-any/mach/mach_traps.h +++ b/lib/libc/include/any-macos-any/mach/mach_traps.h @@ -68,6 +68,7 @@ #include +#include #include #include #include @@ -296,6 +297,10 @@ extern kern_return_t debug_control_port_for_pid( int pid, mach_port_name_t *t); +extern mach_error_t mach_vm_reclaim_update_kernel_accounting_trap( + mach_port_name_t target_tport, + uint64_t *bytes_reclaimed); + __END_DECLS diff --git a/lib/libc/include/any-macos-any/mach/machine.h b/lib/libc/include/any-macos-any/mach/machine.h index 8c496f9222..d43f632065 100644 --- a/lib/libc/include/any-macos-any/mach/machine.h +++ b/lib/libc/include/any-macos-any/mach/machine.h @@ -332,6 +332,9 @@ typedef integer_t cpu_threadtype_t; #define CPU_SUBTYPE_ARM_V7M ((cpu_subtype_t) 15) /* Not meant to be run under xnu */ #define CPU_SUBTYPE_ARM_V7EM ((cpu_subtype_t) 16) /* Not meant to be run under xnu */ #define CPU_SUBTYPE_ARM_V8M ((cpu_subtype_t) 17) /* Not meant to be run under xnu */ +#define CPU_SUBTYPE_ARM_V8M_MAIN CPU_SUBTYPE_ARM_V8M /* Not meant to be run under xnu */ +#define CPU_SUBTYPE_ARM_V8M_BASE ((cpu_subtype_t) 18) /* Not meant to be run under xnu */ +#define CPU_SUBTYPE_ARM_V8_1M_MAIN ((cpu_subtype_t) 19) /* Not meant to be run under xnu */ /* * ARM64 subtypes @@ -406,6 +409,8 @@ typedef integer_t cpu_threadtype_t; #define CPUFAMILY_ARM_BRAVA 0x17d5b93a #define CPUFAMILY_ARM_TAHITI 0x75d4acb9 #define CPUFAMILY_ARM_TUPAI 0x204526d0 +#define CPUFAMILY_ARM_THERA 0xab345f09 +#define CPUFAMILY_ARM_TILOS 0x01d7a72b /* Described in rdar://64125549 */ #define CPUSUBFAMILY_UNKNOWN 0 diff --git a/lib/libc/include/any-macos-any/mach/message.h b/lib/libc/include/any-macos-any/mach/message.h index 78d98c0d8b..dcf6eba833 100644 --- a/lib/libc/include/any-macos-any/mach/message.h +++ b/lib/libc/include/any-macos-any/mach/message.h @@ -839,7 +839,7 @@ typedef kern_return_t mach_msg_return_t; #define MACH_SEND_INVALID_RT_OOL_SIZE 0x10000015 /* compatibility: no longer a returned error */ #define MACH_SEND_NO_GRANT_DEST 0x10000016 -/* The destination port doesn't accept ports in body */ +/* compatibility: no longer a returned error */ #define MACH_SEND_MSG_FILTERED 0x10000017 /* Message send was rejected by message filter */ #define MACH_SEND_AUX_TOO_SMALL 0x10000018 @@ -885,7 +885,6 @@ typedef kern_return_t mach_msg_return_t; /* invalid receive arguments, receive has not started */ - __BEGIN_DECLS /* diff --git a/lib/libc/include/any-macos-any/mach/port.h b/lib/libc/include/any-macos-any/mach/port.h index bb9a2bc69e..3e225dd0da 100644 --- a/lib/libc/include/any-macos-any/mach/port.h +++ b/lib/libc/include/any-macos-any/mach/port.h @@ -152,28 +152,12 @@ typedef mach_port_t *mach_port_array_t; * and reused too quickly [to catch right/reference counting bugs]. * The dividing line between the constituent parts is exposed so * that efficient "mach_port_name_t to data structure pointer" - * conversion implementation can be made. But it is possible - * for user-level code to assign their own names to Mach ports. - * These are not required to participate in this algorithm. So - * care should be taken before "assuming" this model. - * + * conversion implementation can be made. */ -#ifndef NO_PORT_GEN - #define MACH_PORT_INDEX(name) ((name) >> 8) #define MACH_PORT_GEN(name) (((name) & 0xff) << 24) -#define MACH_PORT_MAKE(index, gen) \ - (((index) << 8) | (gen) >> 24) - -#else /* NO_PORT_GEN */ - -#define MACH_PORT_INDEX(name) (name) -#define MACH_PORT_GEN(name) (0) -#define MACH_PORT_MAKE(index, gen) (index) - -#endif /* NO_PORT_GEN */ - +#define MACH_PORT_MAKE(index, gen) (((index) << 8) | ((gen) >> 24)) /* * These are the different rights a task may have for a port. @@ -281,7 +265,7 @@ typedef struct mach_port_limits { #define MACH_PORT_STATUS_FLAG_REVIVE 0x10 #define MACH_PORT_STATUS_FLAG_TASKPTR 0x20 #define MACH_PORT_STATUS_FLAG_GUARD_IMMOVABLE_RECEIVE 0x40 -#define MACH_PORT_STATUS_FLAG_NO_GRANT 0x80 +#define MACH_PORT_STATUS_FLAG_NO_GRANT 0x80 /* Obsolete */ typedef struct mach_port_info_ext { mach_port_status_t mpie_status; @@ -344,36 +328,95 @@ typedef struct mach_service_port_info { typedef struct mach_service_port_info * mach_service_port_info_t; +/* + * Platform binaries are not allowed to send OOL port array to any port. + * + * MACH_MSG_OOL_PORTS_DESCRIPTOR are allowed to be sent ONLY to receive + * rights that are explicitly allow to receive that descriptor. + * + * Such ports have a dedicated port type, and are created using the + * MPO_CONNECTION_PORT_WITH_PORT_ARRAY flag. + * + * Creation of such ports requires the binary to have the following entitlement. + */ +#define MACH_PORT_CONNECTION_PORT_WITH_PORT_ARRAY "com.apple.developer.allow-connection-port-with-port-array" + +/* Allows 1p process to create provisional reply port (to be rename to weak reply port) */ +#define MACH_PORT_PROVISIONAL_REPLY_ENTITLEMENT "com.apple.private.allow-weak-reply-port" + /* * Flags for mach_port_options (used for * invocation of mach_port_construct). * Indicates attributes to be set for the newly * allocated port. */ -#define MPO_CONTEXT_AS_GUARD 0x01 /* Add guard to the port */ -#define MPO_QLIMIT 0x02 /* Set qlimit for the port msg queue */ -#define MPO_TEMPOWNER 0x04 /* Set the tempowner bit of the port */ -#define MPO_IMPORTANCE_RECEIVER 0x08 /* Mark the port as importance receiver */ -#define MPO_INSERT_SEND_RIGHT 0x10 /* Insert a send right for the port */ -#define MPO_STRICT 0x20 /* Apply strict guarding for port */ -#define MPO_DENAP_RECEIVER 0x40 /* Mark the port as App de-nap receiver */ -#define MPO_IMMOVABLE_RECEIVE 0x80 /* Mark the port as immovable; protected by the guard context */ -#define MPO_FILTER_MSG 0x100 /* Allow message filtering */ -#define MPO_TG_BLOCK_TRACKING 0x200 /* Track blocking relationship for thread group during sync IPC */ -#define MPO_SERVICE_PORT 0x400 /* Create a service port with the given name; should be used only by launchd */ -#define MPO_CONNECTION_PORT 0x800 /* Derive new peer connection port from a given service port */ -#define MPO_REPLY_PORT 0x1000 /* Designate port as a reply port. */ -#define MPO_ENFORCE_REPLY_PORT_SEMANTICS 0x2000 /* When talking to this port, local port of mach msg needs to follow reply port semantics.*/ -#define MPO_PROVISIONAL_REPLY_PORT 0x4000 /* Designate port as a provisional reply port. */ -#define MPO_EXCEPTION_PORT 0x8000 /* Used for hardened exceptions - immovable */ +/* MPO options flags */ +#define MPO_CONTEXT_AS_GUARD 0x01 /* Add guard to the port */ +#define MPO_QLIMIT 0x02 /* Set qlimit for the port msg queue */ +#define MPO_TEMPOWNER 0x04 /* Set the tempowner bit of the port */ +#define MPO_IMPORTANCE_RECEIVER 0x08 /* Mark the port as importance receiver */ +#define MPO_INSERT_SEND_RIGHT 0x10 /* Insert a send right for the port */ +#define MPO_STRICT 0x20 /* Apply strict guarding for port */ +#define MPO_DENAP_RECEIVER 0x40 /* Mark the port as App de-nap receiver */ +#define MPO_IMMOVABLE_RECEIVE 0x80 /* Mark the port as immovable; protected by the guard context */ +#define MPO_FILTER_MSG 0x100 /* Allow message filtering */ +#define MPO_TG_BLOCK_TRACKING 0x200 /* Track blocking relationship for thread group during sync IPC */ +#define MPO_ENFORCE_REPLY_PORT_SEMANTICS 0x2000 /* When talking to this port, local port of mach msg needs to follow reply port semantics.*/ +/* This service port has requested security hardening */ +#define MPO_STRICT_SERVICE_PORT (MPO_SERVICE_PORT | MPO_ENFORCE_REPLY_PORT_SEMANTICS) + +#define MPO_OPTIONS_MASK \ + (MPO_CONTEXT_AS_GUARD | \ + MPO_QLIMIT | \ + MPO_TEMPOWNER | \ + MPO_IMPORTANCE_RECEIVER | \ + MPO_INSERT_SEND_RIGHT | \ + MPO_STRICT | \ + MPO_DENAP_RECEIVER | \ + MPO_IMMOVABLE_RECEIVE | \ + MPO_FILTER_MSG | \ + MPO_TG_BLOCK_TRACKING | \ + MPO_ENFORCE_REPLY_PORT_SEMANTICS) + +/* MPO port type flags */ +#define MPO_MAKE_PORT_TYPE(a, b) (((a & 0x7) << 14) | ((b & 0x7) << 10)) +#define MPO_PORT_TYPE_MASK MPO_MAKE_PORT_TYPE(0x7, 0x7) /* 0x1dc00 */ +/* These need to be defined for libxpc and other clients who `#ifdef` */ + #define MPO_PORT MPO_PORT + #define MPO_SERVICE_PORT MPO_SERVICE_PORT + #define MPO_CONNECTION_PORT MPO_CONNECTION_PORT + #define MPO_REPLY_PORT MPO_REPLY_PORT + #define MPO_PROVISIONAL_REPLY_PORT MPO_PROVISIONAL_REPLY_PORT + #define MPO_EXCEPTION_PORT MPO_EXCEPTION_PORT + #define MPO_CONNECTION_PORT_WITH_PORT_ARRAY MPO_CONNECTION_PORT_WITH_PORT_ARRAY +__options_decl(mpo_flags_t, uint32_t, { + /* Your classic IOT_PORT, an uninteresting message queue */ + MPO_PORT = MPO_MAKE_PORT_TYPE(0, 0), /* 0x0 */ + /* Create a service port with the given name; should be used only by launchd */ + MPO_SERVICE_PORT = MPO_MAKE_PORT_TYPE(0, 1), /* 0x400 */ + /* Derive new peer connection port from a given service port */ + MPO_CONNECTION_PORT = MPO_MAKE_PORT_TYPE(0, 2), /* 0x800 */ + /* Designate port as a reply port */ + MPO_REPLY_PORT = MPO_MAKE_PORT_TYPE(0, 4), /* 0x1000 */ + /* Designate port as a provisional (fake) reply port */ + MPO_PROVISIONAL_REPLY_PORT = MPO_MAKE_PORT_TYPE(1, 0), /* 0x4000 */ + /* Used for hardened exceptions - immovable */ + MPO_EXCEPTION_PORT = MPO_MAKE_PORT_TYPE(2, 0), /* 0x8000 */ + /* Can receive OOL port array descriptors */ + MPO_CONNECTION_PORT_WITH_PORT_ARRAY = MPO_MAKE_PORT_TYPE(4, 0), /* 0x10000 */ +}); +#define MPO_UNUSED_BITS ~(MPO_OPTIONS_MASK | MPO_PORT_TYPE_MASK) + +/* Denotes an anonymous service */ +#define MPO_ANONYMOUS_SERVICE (MACH_PORT_DEAD - 1) /* * Structure to define optional attributes for a newly * constructed port. */ typedef struct mach_port_options { - uint32_t flags; /* Flags defining attributes for port */ + uint32_t flags; mach_port_limits_t mpl; /* Message queue limit for port */ union { uint64_t reserved[2]; /* Reserved */ @@ -405,6 +448,7 @@ typedef mach_port_options_t *mach_port_options_ptr_t; * but are truly an enum, please add new values in the "holes". */ enum mach_port_guard_exception_codes { + kGUARD_EXC_NONE = 0, /* never sent */ kGUARD_EXC_DESTROY = 1, kGUARD_EXC_MOD_REFS = 2, kGUARD_EXC_INVALID_OPTIONS = 3, @@ -413,9 +457,14 @@ enum mach_port_guard_exception_codes { kGUARD_EXC_EXCEPTION_BEHAVIOR_ENFORCE = 6, kGUARD_EXC_SERVICE_PORT_VIOLATION_FATAL = 7, /* unused, for future sp defense enablement */ kGUARD_EXC_UNGUARDED = 8, + kGUARD_EXC_KOBJECT_REPLY_PORT_SEMANTICS = 9, + kGUARD_EXC_REQUIRE_REPLY_PORT_SEMANTICS = 10, kGUARD_EXC_INCORRECT_GUARD = 16, kGUARD_EXC_IMMOVABLE = 32, kGUARD_EXC_STRICT_REPLY = 64, + kGUARD_EXC_INVALID_NOTIFICATION_REQ = 65, + kGUARD_EXC_INVALID_MPO_ENTITLEMENT = 66, + kGUARD_EXC_DESCRIPTOR_VIOLATION = 67, kGUARD_EXC_MSG_FILTERED = 128, /* start of [optionally] non-fatal guards */ kGUARD_EXC_INVALID_RIGHT = 256, @@ -434,40 +483,75 @@ enum mach_port_guard_exception_codes { kGUARD_EXC_RCV_GUARDED_DESC = 0x00100000, /* for development only */ kGUARD_EXC_SERVICE_PORT_VIOLATION_NON_FATAL = 0x00100001, /* unused, for future sp defense enablement */ kGUARD_EXC_PROVISIONAL_REPLY_PORT = 0x00100002, + kGUARD_EXC_OOL_PORT_ARRAY_CREATION = 0x00100003, /* unused */ + kGUARD_EXC_MOVE_PROVISIONAL_REPLY_PORT = 0x00100004, + kGUARD_EXC_REPLY_PORT_SINGLE_SO_RIGHT = 0x00100005, kGUARD_EXC_MOD_REFS_NON_FATAL = 1u << 21, kGUARD_EXC_IMMOVABLE_NON_FATAL = 1u << 22, - kGUARD_EXC_REQUIRE_REPLY_PORT_SEMANTICS = 1u << 23, }; #define MAX_FATAL_kGUARD_EXC_CODE kGUARD_EXC_MSG_FILTERED #define MAX_OPTIONAL_kGUARD_EXC_CODE kGUARD_EXC_RCV_INVALID_NAME + /* * Mach port guard flags. */ -#define MPG_FLAGS_NONE (0x00ull) +#define MPG_FLAGS_NONE 0x00 /* * These flags are used as bits in the subcode of kGUARD_EXC_STRICT_REPLY exceptions. */ -#define MPG_FLAGS_STRICT_REPLY_INVALID_REPLY_DISP (0x01ull << 56) -#define MPG_FLAGS_STRICT_REPLY_INVALID_REPLY_PORT (0x02ull << 56) -#define MPG_FLAGS_STRICT_REPLY_INVALID_VOUCHER (0x04ull << 56) -#define MPG_FLAGS_STRICT_REPLY_NO_BANK_ATTR (0x08ull << 56) -#define MPG_FLAGS_STRICT_REPLY_MISMATCHED_PERSONA (0x10ull << 56) -#define MPG_FLAGS_STRICT_REPLY_MASK (0xffull << 56) +#define MPG_FLAGS_STRICT_REPLY_INVALID_VOUCHER 0x04 +#define MPG_FLAGS_STRICT_REPLY_MISMATCHED_PERSONA 0x10 /* * These flags are used as bits in the subcode of kGUARD_EXC_MOD_REFS exceptions. */ -#define MPG_FLAGS_MOD_REFS_PINNED_DEALLOC (0x01ull << 56) -#define MPG_FLAGS_MOD_REFS_PINNED_DESTROY (0x02ull << 56) -#define MPG_FLAGS_MOD_REFS_PINNED_COPYIN (0x04ull << 56) +#define MPG_FLAGS_MOD_REFS_PINNED_DEALLOC 0x01 +#define MPG_FLAGS_MOD_REFS_PINNED_DESTROY 0x02 +#define MPG_FLAGS_MOD_REFS_PINNED_COPYIN 0x03 /* - * These flags are used as bits in the subcode of kGUARD_EXC_IMMOVABLE exceptions. + * These flags are used as bits in the subcode of kGUARD_EXC_INVALID_RIGHT exceptions. */ -#define MPG_FLAGS_IMMOVABLE_PINNED (0x01ull << 56) +#define MPG_FLAGS_INVALID_RIGHT_RECV 0x01 /* does not have receive right */ +#define MPG_FLAGS_INVALID_RIGHT_DELTA 0x02 /* ipc_right_delta() */ +#define MPG_FLAGS_INVALID_RIGHT_DESTRUCT 0x03 /* ipc_right_destruct() */ +#define MPG_FLAGS_INVALID_RIGHT_COPYIN 0x04 /* ipc_right_copyin() */ +#define MPG_FLAGS_INVALID_RIGHT_DEALLOC 0x05 /* ipc_right_dealloc() */ +#define MPG_FLAGS_INVALID_RIGHT_DEALLOC_KERNEL 0x06 /* mach_port_deallocate_kernel() */ +#define MPG_FLAGS_INVALID_RIGHT_TRANSLATE_PORT 0x07 /* port in ipc_object_translate_port_pset() */ +#define MPG_FLAGS_INVALID_RIGHT_TRANSLATE_PSET 0x08 /* pset in ipc_object_translate_port_pset() */ + +/* + * These flags are used as bits in the subcode of kGUARD_EXC_INVALID_VALUE exceptions. + */ +#define MPG_FLAGS_INVALID_VALUE_PEEK 0x01 /* mach_port_peek() */ +#define MPG_FLAGS_INVALID_VALUE_DELTA 0x02 /* ipc_right_delta() */ +#define MPG_FLAGS_INVALID_VALUE_DESTRUCT 0x03 /* ipc_right_destruct() */ + +/* + * These flags are used as bits in the subcode of kGUARD_EXC_KERN_FAILURE exceptions. + */ +#define MPG_FLAGS_KERN_FAILURE_TASK 0x01 /* task other than launchd arm pd on service ports */ +#define MPG_FLAGS_KERN_FAILURE_NOTIFY_TYPE 0x02 /* not using IOT_NOTIFICATION_PORT for pd notification */ +#define MPG_FLAGS_KERN_FAILURE_NOTIFY_RECV 0x03 /* notification port not owned by launchd */ +#define MPG_FLAGS_KERN_FAILURE_MULTI_NOTI 0x04 /* register multiple pd notification */ + +/* + * These flags are used as bits in the subcode of kGUARD_EXC_SEND_INVALID_RIGHT exceptions. + */ +#define MPG_FLAGS_SEND_INVALID_RIGHT_PORT 0x01 /* ipc_kmsg_copyin_port_descriptor() */ +#define MPG_FLAGS_SEND_INVALID_RIGHT_OOL_PORT 0x02 /* ipc_kmsg_copyin_ool_ports_descriptor() */ +#define MPG_FLAGS_SEND_INVALID_RIGHT_GUARDED 0x03 /* ipc_kmsg_copyin_guarded_port_descriptor */ + +/* + * These flags are used as bits in the subcode of kGUARD_EXC_INVALID_OPTIONS exceptions. + */ +#define MPG_FLAGS_INVALID_OPTIONS_OOL_DISP 0x01 /* ipc_kmsg_copyin_ool_ports_descriptor() */ +#define MPG_FLAGS_INVALID_OPTIONS_OOL_ARRAYS 0x02 /* ipc_validate_kmsg_header_from_user() */ +#define MPG_FLAGS_INVALID_OPTIONS_OOL_RIGHT 0x03 /* ipc_validate_kmsg_header_from_user() */ /* * Flags for mach_port_guard_with_flags. These flags extend diff --git a/lib/libc/include/any-macos-any/mach/task_info.h b/lib/libc/include/any-macos-any/mach/task_info.h index e9e9645fbe..b7118305b1 100644 --- a/lib/libc/include/any-macos-any/mach/task_info.h +++ b/lib/libc/include/any-macos-any/mach/task_info.h @@ -511,6 +511,16 @@ typedef struct task_security_config_info * task_security_config_info_t; #define TASK_SECURITY_CONFIG_INFO_COUNT ((mach_msg_type_number_t) \ (sizeof(struct task_security_config_info) / sizeof(natural_t))) + +#define TASK_IPC_SPACE_POLICY_INFO 33 /* Runtime security mitigations configuration for the task */ +struct task_ipc_space_policy_info { + uint32_t space_policy; /* Configuration bitmask */ +}; + +typedef struct task_ipc_space_policy_info * task_ipc_space_policy_info_t; +#define TASK_IPC_SPACE_POLICY_INFO_COUNT ((mach_msg_type_number_t) \ + (sizeof(struct task_ipc_space_policy_info) / sizeof(natural_t))) + /* * Type to control EXC_GUARD delivery options for a task * via task_get/set_exc_guard_behavior interface(s). diff --git a/lib/libc/include/any-macos-any/mach/task_policy.h b/lib/libc/include/any-macos-any/mach/task_policy.h index c1bb833820..8ca7f641cf 100644 --- a/lib/libc/include/any-macos-any/mach/task_policy.h +++ b/lib/libc/include/any-macos-any/mach/task_policy.h @@ -121,6 +121,7 @@ typedef enum task_role { TASK_NONUI_APPLICATION = 6, TASK_DEFAULT_APPLICATION = 7, TASK_DARWINBG_APPLICATION = 8, + TASK_USER_INIT_APPLICATION = 9, } task_role_t; struct task_category_policy { diff --git a/lib/libc/include/any-macos-any/mach/thread_info.h b/lib/libc/include/any-macos-any/mach/thread_info.h index c31a27b024..1fad20e5a9 100644 --- a/lib/libc/include/any-macos-any/mach/thread_info.h +++ b/lib/libc/include/any-macos-any/mach/thread_info.h @@ -74,7 +74,6 @@ #include #include #include - /* * Generic information structure to allow for expansion. */ diff --git a/lib/libc/include/any-macos-any/mach/vm_region.h b/lib/libc/include/any-macos-any/mach/vm_region.h index db21484456..61f49cd82c 100644 --- a/lib/libc/include/any-macos-any/mach/vm_region.h +++ b/lib/libc/include/any-macos-any/mach/vm_region.h @@ -228,6 +228,7 @@ typedef struct vm_region_submap_info vm_region_submap_info_data_t; (sizeof(vm_region_submap_info_data_t) / sizeof(natural_t))) struct vm_region_submap_info_64 { + /* v0 fields */ vm_prot_t protection; /* present access protection */ vm_prot_t max_protection; /* max avail through vm_prot */ vm_inherit_t inheritance;/* behavior of map/obj on fork */ @@ -245,18 +246,30 @@ struct vm_region_submap_info_64 { vm_behavior_t behavior; /* access behavior hint */ vm32_object_id_t object_id; /* obj/map name, not a handle */ unsigned short user_wired_count; + unsigned short flags; + /* v1 fields */ unsigned int pages_reusable; + /* v2 fields */ vm_object_id_t object_id_full; }; typedef struct vm_region_submap_info_64 *vm_region_submap_info_64_t; typedef struct vm_region_submap_info_64 vm_region_submap_info_data_64_t; +/* + * Note that this size is hard-coded at the MIG boundary in mach_types.defs + * so if we ever increase this you'll need to also bump the definition of + * vm_region_recurse_info_t. + */ #define VM_REGION_SUBMAP_INFO_V2_SIZE \ (sizeof (vm_region_submap_info_data_64_t)) + +/* v1 size is v2 size minus v2's new fields */ #define VM_REGION_SUBMAP_INFO_V1_SIZE \ (VM_REGION_SUBMAP_INFO_V2_SIZE - \ sizeof (vm_object_id_t) /* object_id_full */ ) + +/* v0 size is v1 size minus v1's new fields */ #define VM_REGION_SUBMAP_INFO_V0_SIZE \ (VM_REGION_SUBMAP_INFO_V1_SIZE - \ sizeof (unsigned int) /* pages_reusable */ ) @@ -274,6 +287,10 @@ typedef struct vm_region_submap_info_64 vm_region_submap_info_data_64_t /* set this to the latest version */ #define VM_REGION_SUBMAP_INFO_COUNT_64 VM_REGION_SUBMAP_INFO_V2_COUNT_64 +#define VM_REGION_FLAG_JIT_ENABLED 0x1 +#define VM_REGION_FLAG_TPRO_ENABLED 0x2 + + struct vm_region_submap_short_info_64 { vm_prot_t protection; /* present access protection */ vm_prot_t max_protection; /* max avail through vm_prot */ @@ -288,6 +305,7 @@ struct vm_region_submap_short_info_64 { vm_behavior_t behavior; /* access behavior hint */ vm32_object_id_t object_id; /* obj/map name, not a handle */ unsigned short user_wired_count; + unsigned short flags; }; typedef struct vm_region_submap_short_info_64 *vm_region_submap_short_info_64_t; diff --git a/lib/libc/include/any-macos-any/mach/vm_statistics.h b/lib/libc/include/any-macos-any/mach/vm_statistics.h index be49304820..801325eb19 100644 --- a/lib/libc/include/any-macos-any/mach/vm_statistics.h +++ b/lib/libc/include/any-macos-any/mach/vm_statistics.h @@ -66,6 +66,9 @@ #ifndef _MACH_VM_STATISTICS_H_ #define _MACH_VM_STATISTICS_H_ + +#include +#include #include #include @@ -74,6 +77,8 @@ __BEGIN_DECLS +#pragma mark VM Statistics + /* * vm_statistics * @@ -141,7 +146,7 @@ struct vm_statistics64 { natural_t wire_count; /* # of pages wired down */ uint64_t zero_fill_count; /* # of zero fill pages */ uint64_t reactivations; /* # of pages reactivated */ - uint64_t pageins; /* # of pageins */ + uint64_t pageins; /* # of pageins (lifetime) */ uint64_t pageouts; /* # of pageouts */ uint64_t faults; /* # of faults */ uint64_t cow_faults; /* # of copy-on-writes */ @@ -158,15 +163,17 @@ struct vm_statistics64 { natural_t speculative_count; /* # of pages speculative */ /* added for rev1 */ - uint64_t decompressions; /* # of pages decompressed */ - uint64_t compressions; /* # of pages compressed */ - uint64_t swapins; /* # of pages swapped in (via compression segments) */ - uint64_t swapouts; /* # of pages swapped out (via compression segments) */ + uint64_t decompressions; /* # of pages decompressed (lifetime) */ + uint64_t compressions; /* # of pages compressed (lifetime) */ + uint64_t swapins; /* # of pages swapped in via compressor segments (lifetime) */ + uint64_t swapouts; /* # of pages swapped out via compressor segments (lifetime) */ natural_t compressor_page_count; /* # of pages used by the compressed pager to hold all the compressed data */ natural_t throttled_count; /* # of pages throttled */ natural_t external_page_count; /* # of pages that are file-backed (non-swap) */ natural_t internal_page_count; /* # of pages that are anonymous */ uint64_t total_uncompressed_pages_in_compressor; /* # of pages (uncompressed) held within the compressor. */ + /* added for rev2 */ + uint64_t swapped_count; /* # of compressor-stored pages currently stored in swap */ } __attribute__((aligned(8))); typedef struct vm_statistics64 *vm_statistics64_t; @@ -232,6 +239,8 @@ typedef struct vm_purgeable_info *vm_purgeable_info_t; #define VM_PAGE_QUERY_PAGE_CS_NX 0x400 #define VM_PAGE_QUERY_PAGE_REUSABLE 0x800 +#pragma mark User Flags + /* * VM allocation flags: * @@ -334,17 +343,27 @@ typedef struct vm_purgeable_info *vm_purgeable_info_t; __enum_decl(virtual_memory_guard_exception_code_t, uint32_t, { kGUARD_EXC_DEALLOC_GAP = 1, kGUARD_EXC_RECLAIM_COPYIO_FAILURE = 2, - kGUARD_EXC_SEC_LOOKUP_DENIED = 3, kGUARD_EXC_RECLAIM_INDEX_FAILURE = 4, - kGUARD_EXC_SEC_RANGE_DENIED = 6, - kGUARD_EXC_SEC_ACCESS_FAULT = 7, kGUARD_EXC_RECLAIM_DEALLOCATE_FAILURE = 8, - kGUARD_EXC_SEC_COPY_DENIED = 16, - kGUARD_EXC_SEC_SHARING_DENIED = 32, - kGUARD_EXC_SEC_ASYNC_ACCESS_FAULT = 64, + kGUARD_EXC_RECLAIM_ACCOUNTING_FAILURE = 9, + kGUARD_EXC_SEC_IOPL_ON_EXEC_PAGE = 10, + kGUARD_EXC_SEC_EXEC_ON_IOPL_PAGE = 11, + kGUARD_EXC_SEC_UPL_WRITE_ON_EXEC_REGION = 12, + /* + * rdar://151450801 (Remove spurious kGUARD_EXC_SEC_ACCESS_FAULT and kGUARD_EXC_SEC_ASYNC_ACCESS_FAULT once CrashReporter is aligned) + */ + kGUARD_EXC_SEC_ACCESS_FAULT = 98, + kGUARD_EXC_SEC_ASYNC_ACCESS_FAULT = 99, + /* VM policy decisions */ + kGUARD_EXC_SEC_COPY_DENIED = 100, + kGUARD_EXC_SEC_SHARING_DENIED = 101, + }); + +#pragma mark Ledger Tags + /* current accounting postmark */ #define __VM_LEDGER_ACCOUNTING_POSTMARK 2019032600 @@ -372,6 +391,14 @@ __enum_decl(virtual_memory_guard_exception_code_t, uint32_t, { #define VM_LEDGER_FLAGS_USER (VM_LEDGER_FLAG_NO_FOOTPRINT | VM_LEDGER_FLAG_NO_FOOTPRINT_FOR_DEBUG) #define VM_LEDGER_FLAGS_ALL (VM_LEDGER_FLAGS_USER | VM_LEDGER_FLAG_FROM_KERNEL) +#pragma mark User Memory Tags + +/* + * These tags may be used to identify memory regions created with + * `mach_vm_map()` or `mach_vm_allocate()` via the top 8 bits of the `flags` + * parameter. Users should pass `VM_MAKE_TAG(tag) | flags` (see section + * "User Flags"). + */ #define VM_MEMORY_MALLOC 1 #define VM_MEMORY_MALLOC_SMALL 2 #define VM_MEMORY_MALLOC_LARGE 3 @@ -400,6 +427,8 @@ __enum_decl(virtual_memory_guard_exception_code_t, uint32_t, { /* Was a nested pmap (VM_MEMORY_SHARED_PMAP) which has now been unnested */ #define VM_MEMORY_UNSHARED_PMAP 35 +/* for libchannel memory, mostly used on visionOS for communication with realtime threads */ +#define VM_MEMORY_LIBCHANNEL 36 // Placeholders for now -- as we analyze the libraries and find how they // use memory, we can make these labels more specific. @@ -411,6 +440,7 @@ __enum_decl(virtual_memory_guard_exception_code_t, uint32_t, { #define VM_MEMORY_JAVA 44 #define VM_MEMORY_COREDATA 45 #define VM_MEMORY_COREDATA_OBJECTIDS 46 + #define VM_MEMORY_ATS 50 #define VM_MEMORY_LAYERKIT 51 #define VM_MEMORY_CGIMAGE 52 @@ -506,6 +536,8 @@ __enum_decl(virtual_memory_guard_exception_code_t, uint32_t, { /* DHMM data */ #define VM_MEMORY_DHMM 84 +/* memory needed for DFR related actions */ +#define VM_MEMORY_DFR 85 /* memory allocated by SceneKit.framework */ #define VM_MEMORY_SCENEKIT 86 @@ -562,6 +594,9 @@ __enum_decl(virtual_memory_guard_exception_code_t, uint32_t, { /* memory allocated by CoreMedia */ #define VM_MEMORY_CM_HLS 106 +/* memory allocated for CompositorServices */ +#define VM_MEMORY_COMPOSITOR_SERVICES 107 + /* Reserve 230-239 for Rosetta */ #define VM_MEMORY_ROSETTA 230 #define VM_MEMORY_ROSETTA_THREAD_CONTEXT 231 @@ -573,7 +608,21 @@ __enum_decl(virtual_memory_guard_exception_code_t, uint32_t, { #define VM_MEMORY_ROSETTA_10 239 /* Reserve 240-255 for application */ -#define VM_MEMORY_APPLICATION_SPECIFIC_1 240 +#define VM_MEMORY_APPLICATION_SPECIFIC_1 240 +#define VM_MEMORY_APPLICATION_SPECIFIC_2 241 +#define VM_MEMORY_APPLICATION_SPECIFIC_3 242 +#define VM_MEMORY_APPLICATION_SPECIFIC_4 243 +#define VM_MEMORY_APPLICATION_SPECIFIC_5 244 +#define VM_MEMORY_APPLICATION_SPECIFIC_6 245 +#define VM_MEMORY_APPLICATION_SPECIFIC_7 246 +#define VM_MEMORY_APPLICATION_SPECIFIC_8 247 +#define VM_MEMORY_APPLICATION_SPECIFIC_9 248 +#define VM_MEMORY_APPLICATION_SPECIFIC_10 249 +#define VM_MEMORY_APPLICATION_SPECIFIC_11 250 +#define VM_MEMORY_APPLICATION_SPECIFIC_12 251 +#define VM_MEMORY_APPLICATION_SPECIFIC_13 252 +#define VM_MEMORY_APPLICATION_SPECIFIC_14 253 +#define VM_MEMORY_APPLICATION_SPECIFIC_15 254 #define VM_MEMORY_APPLICATION_SPECIFIC_16 255 #define VM_MEMORY_COUNT 256 diff --git a/lib/libc/include/any-macos-any/mach_debug/ipc_info.h b/lib/libc/include/any-macos-any/mach_debug/ipc_info.h index 01e9965c1f..69219b5cd8 100644 --- a/lib/libc/include/any-macos-any/mach_debug/ipc_info.h +++ b/lib/libc/include/any-macos-any/mach_debug/ipc_info.h @@ -70,6 +70,81 @@ #include #include +/*! + * @brief + * Type for mach_port_kobject_description() only. + * + * @discussion + * This type preserved the `IOT_*` values that @c ipc_kobject_type_t used + * to carry, whose ABI of this type was known to debugging tools of userspace, + * by copying XNU's source. + * + * This provides a guaranteed stable interface now (however no guarantee + * is made that values are still in use). + * + * Values should never be removed to that list, merely abandonned with + * a comment. + */ +__enum_decl(ipc_info_object_type_t, natural_t, { + IPC_OTYPE_NONE = 0, + IPC_OTYPE_THREAD_CONTROL = 1, + IPC_OTYPE_TASK_CONTROL = 2, + IPC_OTYPE_HOST = 3, + IPC_OTYPE_HOST_PRIV = 4, + IPC_OTYPE_PROCESSOR = 5, + IPC_OTYPE_PROCESSOR_SET = 6, + IPC_OTYPE_PROCESSOR_SET_NAME = 7, + IPC_OTYPE_TIMER = 8, + IPC_OTYPE_PORT_SUBST_ONCE = 9, /* obsolete: no instances */ + IPC_OTYPE_MIG = 10, /* obsolete: no instances */ + IPC_OTYPE_MEMORY_OBJECT = 11, /* no port instances */ + IPC_OTYPE_XMM_PAGER = 12, /* obsolete: no instances */ + IPC_OTYPE_XMM_KERNEL = 13, /* obsolete: no instances */ + IPC_OTYPE_XMM_REPLY = 14, /* obsolete: no instances */ + IPC_OTYPE_UND_REPLY = 15, + IPC_OTYPE_HOST_NOTIFY = 16, /* obsolete: no instances */ + IPC_OTYPE_HOST_SECURITY = 17, /* obsolete: no instances */ + IPC_OTYPE_LEDGER = 18, /* obsolete: no instances */ + IPC_OTYPE_MAIN_DEVICE = 19, + IPC_OTYPE_TASK_NAME = 20, + IPC_OTYPE_SUBSYSTEM = 21, /* obsolete: no instances */ + IPC_OTYPE_IO_DONE_QUEUE = 22, /* obsolete: no instances */ + IPC_OTYPE_SEMAPHORE = 23, + IPC_OTYPE_LOCK_SET = 24, /* obsolete: no instances */ + IPC_OTYPE_CLOCK = 25, + IPC_OTYPE_CLOCK_CTRL = 26, /* obsolete: no instances */ + IPC_OTYPE_IOKIT_IDENT = 27, + IPC_OTYPE_NAMED_ENTRY = 28, + IPC_OTYPE_IOKIT_CONNECT = 29, + IPC_OTYPE_IOKIT_OBJECT = 30, + IPC_OTYPE_UPL = 31, /* obsolete: no instances */ + IPC_OTYPE_MEM_OBJ_CONTROL = 32, /* obsolete: no instances */ + IPC_OTYPE_AU_SESSIONPORT = 33, + IPC_OTYPE_FILEPORT = 34, + IPC_OTYPE_LABELH = 35, /* obsolete: no instances */ + IPC_OTYPE_TASK_RESUME = 36, + IPC_OTYPE_VOUCHER = 37, + IPC_OTYPE_VOUCHER_ATTR_CONTROL = 38, /* obsolete: no instances */ + IPC_OTYPE_WORK_INTERVAL = 39, + IPC_OTYPE_UX_HANDLER = 40, + IPC_OTYPE_UEXT_OBJECT = 41, + IPC_OTYPE_ARCADE_REG = 42, + IPC_OTYPE_EVENTLINK = 43, + IPC_OTYPE_TASK_INSPECT = 44, + IPC_OTYPE_TASK_READ = 45, + IPC_OTYPE_THREAD_INSPECT = 46, + IPC_OTYPE_THREAD_READ = 47, + IPC_OTYPE_SUID_CRED = 48, /* obsolete: no instances */ + IPC_OTYPE_HYPERVISOR = 49, + IPC_OTYPE_TASK_ID_TOKEN = 50, + IPC_OTYPE_TASK_FATAL = 51, + IPC_OTYPE_KCDATA = 52, + IPC_OTYPE_EXCLAVES_RESOURCE = 53, + + /* catchall */ + IPC_OTYPE_UNKNOWN = ~0u, +}); + /* * Remember to update the mig type definitions * in mach_debug_types.defs when adding/removing fields. diff --git a/lib/libc/include/any-macos-any/malloc/_malloc.h b/lib/libc/include/any-macos-any/malloc/_malloc.h index 4389be04d1..cbd5253d50 100644 --- a/lib/libc/include/any-macos-any/malloc/_malloc.h +++ b/lib/libc/include/any-macos-any/malloc/_malloc.h @@ -55,8 +55,8 @@ void * __sized_by_or_null(__size) malloc(size_t __size) __result_use_check __all void * __sized_by_or_null(__count * __size) calloc(size_t __count, size_t __size) __result_use_check __alloc_size(1,2) _MALLOC_TYPED(malloc_type_calloc, 2); void free(void * __unsafe_indexable); void * __sized_by_or_null(__size) realloc(void * __unsafe_indexable __ptr, size_t __size) __result_use_check __alloc_size(2) _MALLOC_TYPED(malloc_type_realloc, 2); -void * __sized_by_or_null(__size) reallocf(void * __unsafe_indexable __ptr, size_t __size) __result_use_check __alloc_size(2); #if !defined(_ANSI_SOURCE) && (!defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE)) +void * __sized_by_or_null(__size) reallocf(void * __unsafe_indexable __ptr, size_t __size) __result_use_check __alloc_size(2); void * __sized_by_or_null(__size) valloc(size_t __size) __result_use_check __alloc_size(1) _MALLOC_TYPED(malloc_type_valloc, 1); #endif /* !defined(_ANSI_SOURCE) && (!defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE)) */ #if (defined(__DARWIN_C_LEVEL) && defined(__DARWIN_C_FULL) && __DARWIN_C_LEVEL >= __DARWIN_C_FULL) || \ @@ -67,6 +67,75 @@ void * __sized_by_or_null(__size) aligned_alloc(size_t __alignment, size_t __siz /* rdar://120689514 */ int posix_memalign(void * __unsafe_indexable *__memptr, size_t __alignment, size_t __size) _MALLOC_TYPED(malloc_type_posix_memalign, 3) __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_0); +#if defined(_MALLOC_TYPE_MALLOC_IS_BACKDEPLOYING) && _MALLOC_TYPE_MALLOC_IS_BACKDEPLOYING +static void * __sized_by_or_null(size) __attribute__((always_inline)) malloc_type_malloc_backdeploy(size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(1) { + __attribute__((weak_import)) void * __sized_by_or_null(size) malloc_type_malloc(size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(1); + __auto_type func = malloc; + if (malloc_type_malloc) { + return malloc_type_malloc(size, type_id); + } + return func(size); +} + +static void * __sized_by_or_null(count * size) __attribute__((always_inline)) malloc_type_calloc_backdeploy(size_t count, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(1,2) { + __attribute__((weak_import)) void * __sized_by_or_null(count * size) malloc_type_calloc(size_t count, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(1,2); + __auto_type func = calloc; + if (malloc_type_calloc) { + return malloc_type_calloc(count, size, type_id); + } + return func(count, size); +} + +static void __attribute__((always_inline)) malloc_type_free_backdeploy(void * __unsafe_indexable ptr, malloc_type_id_t type_id) { + __attribute__((weak_import)) void malloc_type_free(void * __unsafe_indexable ptr, malloc_type_id_t type_id); + __auto_type func = free; + if (malloc_type_free) { + malloc_type_free(ptr, type_id); + } else { + func(ptr); + } +} + +static void * __sized_by_or_null(size) __attribute__((always_inline)) malloc_type_realloc_backdeploy(void * __unsafe_indexable ptr, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2) { + __attribute__((weak_import)) void * __sized_by_or_null(size) malloc_type_realloc(void * __unsafe_indexable ptr, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2); + __auto_type func = realloc; + if (malloc_type_realloc) { + return malloc_type_realloc(ptr, size, type_id); + } + return func(ptr, size); +} + +static void * __sized_by_or_null(size) __attribute__((always_inline)) malloc_type_valloc_backdeploy(size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(1) { + __attribute__((weak_import)) void * __sized_by_or_null(size) malloc_type_valloc(size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(1); + __auto_type func = valloc; + if (malloc_type_valloc) { + return malloc_type_valloc(size, type_id); + } + return func(size); +} + +#if (defined(__DARWIN_C_LEVEL) && defined(__DARWIN_C_FULL) && __DARWIN_C_LEVEL >= __DARWIN_C_FULL) || \ + (defined(__STDC_VERSION__) && __STDC_VERSION__ >= 201112L) || \ + (defined(__cplusplus) && __cplusplus >= 201703L) +static void * __sized_by_or_null(size) __attribute__((always_inline)) malloc_type_aligned_alloc_backdeploy(size_t alignment, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_align(1) __alloc_size(2) { + __attribute__((weak_import)) void * __sized_by_or_null(size) malloc_type_aligned_alloc(size_t alignment, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_align(1) __alloc_size(2); + __auto_type func = aligned_alloc; + if (malloc_type_aligned_alloc) { + return malloc_type_aligned_alloc(alignment, size, type_id); + } + return func(alignment, size); +} +#endif + +static int __attribute__((always_inline)) malloc_type_posix_memalign_backdeploy(void * __unsafe_indexable *memptr, size_t alignment, size_t size, malloc_type_id_t type_id) { + __attribute__((weak_import)) int malloc_type_posix_memalign(void * __unsafe_indexable *memptr, size_t alignment, size_t size, malloc_type_id_t type_id); + __auto_type func = posix_memalign; + if (malloc_type_posix_memalign) { + return malloc_type_posix_memalign(memptr, alignment, size, type_id); + } + return func(memptr, alignment, size); +} +#endif __END_DECLS #endif /* _MALLOC_UNDERSCORE_MALLOC_H_ */ diff --git a/lib/libc/include/any-macos-any/malloc/_malloc_type.h b/lib/libc/include/any-macos-any/malloc/_malloc_type.h index 44474cbb91..81713b125c 100644 --- a/lib/libc/include/any-macos-any/malloc/_malloc_type.h +++ b/lib/libc/include/any-macos-any/malloc/_malloc_type.h @@ -39,44 +39,107 @@ typedef unsigned long long malloc_type_id_t; #define __need_size_t #include #undef __need_size_t -#endif +#endif /* size_t */ #include /* __BEGIN_DECLS */ -#define _MALLOC_TYPE_AVAILABILITY __API_AVAILABLE(macos(14.0), ios(17.0), tvos(17.0), watchos(10.0), visionos(1.0), driverkit(23.0)) - __BEGIN_DECLS -/* */ +#define _MALLOC_TYPE_MALLOC_BACKDEPLOY_PUBLIC 1 -_MALLOC_TYPE_AVAILABILITY void * __sized_by_or_null(size) malloc_type_malloc(size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(1); -_MALLOC_TYPE_AVAILABILITY void * __sized_by_or_null(count * size) malloc_type_calloc(size_t count, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(1,2); -_MALLOC_TYPE_AVAILABILITY void malloc_type_free(void * __unsafe_indexable ptr, malloc_type_id_t type_id); -_MALLOC_TYPE_AVAILABILITY void * __sized_by_or_null(size) malloc_type_realloc(void * __unsafe_indexable ptr, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2); -_MALLOC_TYPE_AVAILABILITY void * __sized_by_or_null(size) malloc_type_valloc(size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(1); -_MALLOC_TYPE_AVAILABILITY void * __sized_by_or_null(size) malloc_type_aligned_alloc(size_t alignment, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2); -/* rdar://120689514 */ -_MALLOC_TYPE_AVAILABILITY int malloc_type_posix_memalign(void * __unsafe_indexable *memptr, size_t alignment, size_t size, malloc_type_id_t type_id) /*__alloc_size(3)*/; +#if _MALLOC_TYPE_MALLOC_BACKDEPLOY_PUBLIC && defined(__has_feature) && __has_feature(typed_memory_operations) && __has_builtin(__is_target_os) && defined(__LP64__) && !defined(_MALLOC_TYPE_MALLOC_IS_BACKDEPLOYING) +#if (defined(__ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__) && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ < 140000) || \ + (defined(__ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__) && __ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__ < 170000) || \ + (defined(__ENVIRONMENT_TV_OS_VERSION_MIN_REQUIRED__) && __ENVIRONMENT_TV_OS_VERSION_MIN_REQUIRED__ < 170000) || \ + (defined(__ENVIRONMENT_WATCH_OS_VERSION_MIN_REQUIRED__) && __ENVIRONMENT_WATCH_OS_VERSION_MIN_REQUIRED__ < 100000) + #define _MALLOC_TYPE_MALLOC_IS_BACKDEPLOYING 1 +#endif +#endif + +/** If we are in a TMO backdeployment configuration we do not globally declare the + * real TMO entry points, so that we error out if someone is trying to use them + * when their presence is not guaranteed + */ +#if defined(_MALLOC_TYPE_MALLOC_IS_BACKDEPLOYING) && _MALLOC_TYPE_MALLOC_IS_BACKDEPLOYING + +static void * __sized_by_or_null(size) __attribute__((always_inline)) malloc_type_malloc_backdeploy(size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(1); +static void * __sized_by_or_null(count * size) __attribute__((always_inline)) malloc_type_calloc_backdeploy(size_t count, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(1,2); +static void __attribute__((always_inline)) malloc_type_free_backdeploy(void * __unsafe_indexable ptr, malloc_type_id_t type_id); +static void * __sized_by_or_null(size) __attribute__((always_inline)) malloc_type_realloc_backdeploy(void * __unsafe_indexable ptr, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2); +static void * __sized_by_or_null(size) __attribute__((always_inline)) malloc_type_valloc_backdeploy(size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(1); +#if (defined(__DARWIN_C_LEVEL) && defined(__DARWIN_C_FULL) && __DARWIN_C_LEVEL >= __DARWIN_C_FULL) || \ + (defined(__STDC_VERSION__) && __STDC_VERSION__ >= 201112L) || \ + (defined(__cplusplus) && __cplusplus >= 201703L) +static void * __sized_by_or_null(size) __attribute__((always_inline)) malloc_type_aligned_alloc_backdeploy(size_t alignment, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_align(1) __alloc_size(2); +#endif +static int __attribute__((always_inline)) malloc_type_posix_memalign_backdeploy(void * __unsafe_indexable *memptr, size_t alignment, size_t size, malloc_type_id_t type_id) /*__alloc_align(2) __alloc_size(3)*/; /* */ typedef struct _malloc_zone_t malloc_zone_t; -_MALLOC_TYPE_AVAILABILITY void * __sized_by_or_null(size) malloc_type_zone_malloc(malloc_zone_t *zone, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2); -_MALLOC_TYPE_AVAILABILITY void * __sized_by_or_null(count * size) malloc_type_zone_calloc(malloc_zone_t *zone, size_t count, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2,3); -_MALLOC_TYPE_AVAILABILITY void malloc_type_zone_free(malloc_zone_t *zone, void * __unsafe_indexable ptr, malloc_type_id_t type_id); -_MALLOC_TYPE_AVAILABILITY void * __sized_by_or_null(size) malloc_type_zone_realloc(malloc_zone_t *zone, void * __unsafe_indexable ptr, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(3); -_MALLOC_TYPE_AVAILABILITY void *__sized_by_or_null(size) malloc_type_zone_valloc(malloc_zone_t *zone, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2); -_MALLOC_TYPE_AVAILABILITY void *__sized_by_or_null(size) malloc_type_zone_memalign(malloc_zone_t *zone, size_t alignment, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(3); +static void * __sized_by_or_null(size) __attribute__((always_inline)) malloc_type_zone_malloc_backdeploy(malloc_zone_t *zone, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2); +static void * __sized_by_or_null(count * size) __attribute__((always_inline)) malloc_type_zone_calloc_backdeploy(malloc_zone_t *zone, size_t count, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2,3); +static void __attribute__((always_inline)) malloc_type_zone_free_backdeploy(malloc_zone_t *zone, void * __unsafe_indexable ptr, malloc_type_id_t type_id); +static void * __sized_by_or_null(size) __attribute__((always_inline)) malloc_type_zone_realloc_backdeploy(malloc_zone_t *zone, void * __unsafe_indexable ptr, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(3); +static void *__sized_by_or_null(size) __attribute__((always_inline)) malloc_type_zone_valloc_backdeploy(malloc_zone_t *zone, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2); +static void *__sized_by_or_null(size) __attribute__((always_inline)) malloc_type_zone_memalign_backdeploy(malloc_zone_t *zone, size_t alignment, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_align(2) __alloc_size(3); + +#else + +/* */ + +__API_AVAILABLE(macos(14.0), ios(17.0), tvos(17.0), watchos(10.0), visionos(1.0), driverkit(23.0)) +void * __sized_by_or_null(size) malloc_type_malloc(size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(1); +__API_AVAILABLE(macos(14.0), ios(17.0), tvos(17.0), watchos(10.0), visionos(1.0), driverkit(23.0)) +void * __sized_by_or_null(count * size) malloc_type_calloc(size_t count, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(1,2); +__API_AVAILABLE(macos(14.0), ios(17.0), tvos(17.0), watchos(10.0), visionos(1.0), driverkit(23.0)) +void malloc_type_free(void * __unsafe_indexable ptr, malloc_type_id_t type_id); +__API_AVAILABLE(macos(14.0), ios(17.0), tvos(17.0), watchos(10.0), visionos(1.0), driverkit(23.0)) +void * __sized_by_or_null(size) malloc_type_realloc(void * __unsafe_indexable ptr, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2); +__API_AVAILABLE(macos(14.0), ios(17.0), tvos(17.0), watchos(10.0), visionos(1.0), driverkit(23.0)) +void * __sized_by_or_null(size) malloc_type_valloc(size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(1); +__API_AVAILABLE(macos(14.0), ios(17.0), tvos(17.0), watchos(10.0), visionos(1.0), driverkit(23.0)) +void * __sized_by_or_null(size) malloc_type_aligned_alloc(size_t alignment, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_align(1) __alloc_size(2); +/* rdar://120689514 */ +__API_AVAILABLE(macos(14.0), ios(17.0), tvos(17.0), watchos(10.0), visionos(1.0), driverkit(23.0)) +int malloc_type_posix_memalign(void * __unsafe_indexable *memptr, size_t alignment, size_t size, malloc_type_id_t type_id) /*__alloc_align(2) __alloc_size(3)*/; + +/* */ + +typedef struct _malloc_zone_t malloc_zone_t; + +__API_AVAILABLE(macos(14.0), ios(17.0), tvos(17.0), watchos(10.0), visionos(1.0), driverkit(23.0)) +void * __sized_by_or_null(size) malloc_type_zone_malloc(malloc_zone_t *zone, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2); +__API_AVAILABLE(macos(14.0), ios(17.0), tvos(17.0), watchos(10.0), visionos(1.0), driverkit(23.0)) +void * __sized_by_or_null(count * size) malloc_type_zone_calloc(malloc_zone_t *zone, size_t count, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2,3); +__API_AVAILABLE(macos(14.0), ios(17.0), tvos(17.0), watchos(10.0), visionos(1.0), driverkit(23.0)) +void malloc_type_zone_free(malloc_zone_t *zone, void * __unsafe_indexable ptr, malloc_type_id_t type_id); +__API_AVAILABLE(macos(14.0), ios(17.0), tvos(17.0), watchos(10.0), visionos(1.0), driverkit(23.0)) +void * __sized_by_or_null(size) malloc_type_zone_realloc(malloc_zone_t *zone, void * __unsafe_indexable ptr, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(3); +__API_AVAILABLE(macos(14.0), ios(17.0), tvos(17.0), watchos(10.0), visionos(1.0), driverkit(23.0)) +void *__sized_by_or_null(size) malloc_type_zone_valloc(malloc_zone_t *zone, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2); +__API_AVAILABLE(macos(14.0), ios(17.0), tvos(17.0), watchos(10.0), visionos(1.0), driverkit(23.0)) +void *__sized_by_or_null(size) malloc_type_zone_memalign(malloc_zone_t *zone, size_t alignment, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_align(2) __alloc_size(3); + +#endif __END_DECLS /* Rewrite enablement */ + #if defined(__has_feature) && __has_feature(typed_memory_operations) -#if __has_builtin(__is_target_os) && (__is_target_os(ios) || __is_target_os(driverkit) || __is_target_os(macos) || __is_target_os(xros) || __is_target_os(watchos) || __is_target_os(tvos) || (__has_builtin(__is_target_environment) && (__is_target_environment(exclavekit) || __is_target_environment(exclavecore)))) + +#if (__has_builtin(__is_target_os) && __is_target_os(darwin) && !__is_target_os(bridgeos)) ||\ + (__has_builtin(__is_target_environment) && (__is_target_environment(exclavekit) || __is_target_environment(exclavecore))) +#if defined(_MALLOC_TYPE_MALLOC_IS_BACKDEPLOYING) && _MALLOC_TYPE_MALLOC_IS_BACKDEPLOYING +#define _MALLOC_TYPE_ENABLED 1 +#define _MALLOC_TYPED(override, type_param_pos) __attribute__((typed_memory_operation(override##_backdeploy, type_param_pos))) +#else #define _MALLOC_TYPED(override, type_param_pos) __attribute__((typed_memory_operation(override, type_param_pos))) #define _MALLOC_TYPE_ENABLED 1 -#endif +#endif +#endif #endif /* defined(__has_feature) && __has_feature(typed_memory_operations) */ #endif /* MALLOC_TARGET_64BIT */ diff --git a/lib/libc/include/any-macos-any/malloc/malloc.h b/lib/libc/include/any-macos-any/malloc/malloc.h index 477a0022ba..d65d15642a 100644 --- a/lib/libc/include/any-macos-any/malloc/malloc.h +++ b/lib/libc/include/any-macos-any/malloc/malloc.h @@ -2,14 +2,14 @@ * Copyright (c) 1999-2023 Apple Computer, Inc. All rights reserved. * * @APPLE_LICENSE_HEADER_START@ - * + * * This file contains Original Code and/or Modifications of Original Code * as defined in and that are subject to the Apple Public Source License * Version 2.0 (the 'License'). You may not use this file except in * compliance with the License. Please obtain a copy of the License at * http://www.opensource.apple.com/apsl/ and read it before using this * file. - * + * * The Original Code and all software distributed under the License are * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, @@ -17,7 +17,7 @@ * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. * Please see the License for the specific language governing rights and * limitations under the License. - * + * * @APPLE_LICENSE_HEADER_END@ */ @@ -62,6 +62,57 @@ __ptrcheck_abi_assume_single() #endif // MALLOC_ZONE_FN_PTR __BEGIN_DECLS + +/********* Typed zone functions ************/ + +#if defined(__has_attribute) && __has_attribute(swift_name) +#define MALLOC_SWIFT_NAME(x) __attribute__((swift_name(#x))) +#else +#define MALLOC_SWIFT_NAME(x) +#endif // defined(__has_attribute) && __has_attribute(swift_name) + +/*! + * @constant MALLOC_ZONE_MALLOC_DEFAULT_ALIGN + * Default alignment for malloc_type_zone_malloc_with_options + */ +#define MALLOC_ZONE_MALLOC_DEFAULT_ALIGN __SIZEOF_POINTER__ + +/*! + * @enum malloc_zone_malloc_options_t + * + * @constant MALLOC_ZONE_MALLOC_OPTION_NONE + * Empty placeholder option. + * + * @constant MALLOC_ZONE_MALLOC_OPTION_CLEAR + * Zero out the allocated memory, similar to calloc(). + * + */ +/*! + * @constant MALLOC_ZONE_MALLOC_OPTION_CANONICAL_TAG + * Under MTE, use a tag of zero (canonical) instead of a random value. + */ +typedef enum __enum_options : uint64_t { + MALLOC_ZONE_MALLOC_OPTION_NONE = 0u, + MALLOC_ZONE_MALLOC_OPTION_CLEAR MALLOC_SWIFT_NAME(clear) = 1u << 0, + MALLOC_ZONE_MALLOC_OPTION_CANONICAL_TAG MALLOC_SWIFT_NAME(canonicalTag) = 1u << 1, +} malloc_zone_malloc_options_t; + +/*! + * @function malloc_type_zone_malloc_with_options + * + * Like the other functions declared in malloc/_malloc_type.h, this function + * is not intended to be called directly, but is rather the rewrite target for + * calls to malloc_zone_malloc_with_options when typed memory operations are + * enabled. + */ +#if defined(__LP64__) +__API_AVAILABLE(macos(26.0), ios(26.0), tvos(26.0), watchos(26.0), visionos(26.0), driverkit(25.0)) +void * __sized_by_or_null(size) malloc_type_zone_malloc_with_options(malloc_zone_t *zone, size_t alignment, size_t size, malloc_type_id_t type_id, malloc_zone_malloc_options_t opts) __result_use_check __alloc_align(2) __alloc_size(3); +#endif /* __LP64__ */ + +// The remainder of these functions are declared in malloc/_malloc_type.h, and +// the backdeployment variant definitions are at the bottom of this file. + /********* Type definitions ************/ /* @@ -160,8 +211,7 @@ typedef struct _malloc_zone_t { void * __unsafe_indexable ptr); /* - * Memory allocation with an extensible binary flags option. Currently for - * libmalloc-internal zone implementations only - should be NULL otherwise. + * Memory allocation with an extensible binary flags option. * Added in version >= 15. */ void * __sized_by_or_null(size) (* MALLOC_ZONE_FN_PTR(malloc_with_options))( @@ -188,10 +238,9 @@ typedef struct _malloc_zone_t { struct _malloc_zone_t *zone, size_t alignment, size_t size, malloc_type_id_t type_id); - /* Must be NULL for non-libmalloc zone implementations */ void * __sized_by_or_null(size) (* MALLOC_ZONE_FN_PTR(malloc_type_malloc_with_options))( - struct _malloc_zone_t *zone, size_t align, size_t size, uint64_t options, - malloc_type_id_t type_id); + struct _malloc_zone_t *zone, size_t align, size_t size, + uint64_t options, malloc_type_id_t type_id); } malloc_zone_t; /*! @@ -352,6 +401,38 @@ extern void malloc_destroy_zone(malloc_zone_t *zone); extern void * __sized_by_or_null(size) malloc_zone_malloc(malloc_zone_t *zone, size_t size) __alloc_size(2) _MALLOC_TYPED(malloc_type_zone_malloc, 2); /* Allocates a new pointer of size size; zone must be non-NULL */ +/*! + * @function malloc_zone_malloc_with_options + * + * @param zone + * The malloc zone that should be used to used to serve the allocation. This + * parameter may be NULL, in which case the default zone will be used. + * + * @param align + * The minimum alignment of the requested allocation. This parameter must be + * MALLOC_ZONE_MALLOC_DEFAULT_ALIGN to request default alignment, or a power + * of 2 >= sizeof(void *). + * + * @param size + * The size, in bytes, of the requested allocation. Must be an integral + * multiple of align if align is non-zero. + * + * @param options + * A bitmask of options defining how the memory should be allocated. See the + * available bit values in the malloc_zone_malloc_options_t enum definition. + * + * @result + * A pointer to the newly allocated block of memory, or NULL if the allocation + * failed. + * + * @discussion + * This API does not use errno to signal information about the reason for its + * success or failure, and makes no guarantees about preserving or settings its + * value in any case. + */ +__API_AVAILABLE(macos(26.0), ios(26.0), tvos(26.0), watchos(26.0), visionos(26.0), driverkit(25.0)) +extern void * __sized_by_or_null(size) malloc_zone_malloc_with_options(malloc_zone_t *zone, size_t align, size_t size, malloc_zone_malloc_options_t opts) __alloc_align(2) __alloc_size(3) _MALLOC_TYPED(malloc_type_zone_malloc_with_options, 3); + extern void * __sized_by_or_null(num_items * size) malloc_zone_calloc(malloc_zone_t *zone, size_t num_items, size_t size) __alloc_size(2,3) _MALLOC_TYPED(malloc_type_zone_calloc, 3); /* Allocates a new pointer of size num_items * size; block is cleared; zone must be non-NULL */ @@ -590,22 +671,80 @@ extern void malloc_zone_enumerate_discharged_pointers(malloc_zone_t *zone, void // Version 13: // - malloc_zone_t::malloc and malloc_zone_t::calloc assume responsibility for // setting errno to ENOMEM on failure -// - malloc_zone_t::try_free_default +// - malloc_zone_t::try_free_default (libmalloc only, NULL otherwise) // Version 14: -// malloc_introspection_t::zone_type +// malloc_introspection_t::zone_type (mandatory, should be 0) // Version 15: -// malloc_zone_t::malloc_with_options +// malloc_zone_t::malloc_with_options (optional) // Version 16: -// malloc_zone_t::malloc_type_malloc -// malloc_zone_t::malloc_type_calloc -// malloc_zone_t::malloc_type_realloc -// malloc_zone_t::malloc_type_memalign -// malloc_zone_t::malloc_type_malloc_with_options +// malloc_zone_t::malloc_type_malloc (mandatory) +// malloc_zone_t::malloc_type_calloc (mandatory) +// malloc_zone_t::malloc_type_realloc (mandatory) +// malloc_zone_t::malloc_type_memalign (mandatory) +// malloc_zone_t::malloc_type_malloc_with_options (optional) -// These functions are optional and calling them requires two checks: +// Zone functions are optional unless specified otherwise above. Calling a zone +// function requires two checks: // * Check zone version to ensure zone struct is large enough to include the member. // * Check that the function pointer is not null. +#if defined(_MALLOC_TYPE_MALLOC_IS_BACKDEPLOYING) && _MALLOC_TYPE_MALLOC_IS_BACKDEPLOYING +static void * __sized_by_or_null(size) __attribute__((always_inline)) malloc_type_zone_malloc_backdeploy(malloc_zone_t *zone, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2) { + __attribute__((weak_import)) void * __sized_by_or_null(size) malloc_type_zone_malloc(malloc_zone_t *zone, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2); + __auto_type func = malloc_zone_malloc; + if (malloc_type_zone_malloc) { + return malloc_type_zone_malloc(zone, size, type_id); + } + return func(zone, size); +} + +static void * __sized_by_or_null(count * size) __attribute__((always_inline)) malloc_type_zone_calloc_backdeploy(malloc_zone_t *zone, size_t count, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2,3) { + __attribute__((weak_import)) void * __sized_by_or_null(count * size) malloc_type_zone_calloc(malloc_zone_t *zone, size_t count, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2,3); + __auto_type func = malloc_zone_calloc; + if (malloc_type_zone_calloc) { + return malloc_type_zone_calloc(zone, count, size, type_id); + } + return func(zone, count, size); +} + +static void __attribute__((always_inline)) malloc_type_zone_free_backdeploy(malloc_zone_t *zone, void * __unsafe_indexable ptr, malloc_type_id_t type_id) { + __attribute__((weak_import)) void malloc_type_zone_free(malloc_zone_t *zone, void * __unsafe_indexable ptr, malloc_type_id_t type_id); + __auto_type func = malloc_zone_free; + if (malloc_type_zone_free) { + malloc_type_zone_free(zone, ptr, type_id); + } else { + func(zone, ptr); + } +} + +static void * __sized_by_or_null(size) __attribute__((always_inline)) malloc_type_zone_realloc_backdeploy(malloc_zone_t *zone, void * __unsafe_indexable ptr, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(3) { + __auto_type func = malloc_zone_realloc; + __attribute__((weak_import)) void * __sized_by_or_null(size) malloc_type_zone_realloc(malloc_zone_t *zone, void * __unsafe_indexable ptr, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(3); + if (malloc_type_zone_realloc) { + return malloc_type_zone_realloc(zone, ptr, size, type_id); + } + return func(zone, ptr, size); +} + +static void *__sized_by_or_null(size) __attribute__((always_inline)) malloc_type_zone_valloc_backdeploy(malloc_zone_t *zone, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2) { + __attribute__((weak_import)) void *__sized_by_or_null(size) malloc_type_zone_valloc(malloc_zone_t *zone, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_size(2); + __auto_type func = malloc_zone_valloc; + if (malloc_type_zone_valloc) { + return malloc_type_zone_valloc(zone, size, type_id); + } + return func(zone, size); +} + +static void *__sized_by_or_null(size) __attribute__((always_inline)) malloc_type_zone_memalign_backdeploy(malloc_zone_t *zone, size_t alignment, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_align(2) __alloc_size(3) { + __attribute__((weak_import)) void *__sized_by_or_null(size) malloc_type_zone_memalign(malloc_zone_t *zone, size_t alignment, size_t size, malloc_type_id_t type_id) __result_use_check __alloc_align(2) __alloc_size(3); + __auto_type func = malloc_zone_memalign; + if (malloc_type_zone_memalign) { + return malloc_type_zone_memalign(zone, alignment, size, type_id); + } + return func(zone, alignment, size); +} +#endif // defined(_MALLOC_TYPE_MALLOC_IS_BACKDEPLOYING) && _MALLOC_TYPE_MALLOC_IS_BACKDEPLOYING + __END_DECLS #endif /* _MALLOC_MALLOC_H_ */ diff --git a/lib/libc/include/any-macos-any/math.h b/lib/libc/include/any-macos-any/math.h index d5b7ccf2a5..513d798d95 100644 --- a/lib/libc/include/any-macos-any/math.h +++ b/lib/libc/include/any-macos-any/math.h @@ -129,10 +129,18 @@ extern int __math_errhandling(void); * * ******************************************************************************/ +#if !defined(__cplusplus) || !defined(__has_feature) || !__has_feature(modules) +/* libc++'s math.h comes before this header in the search order. It + * will include this header first and then undef several of these + * macros. That doesn't work when the two headers are in different + * clang modules. The only way to make that work is to not declare + * the macros here, and let libc++ handle the declarations. + */ #define fpclassify(x) \ ( sizeof(x) == sizeof(float) ? __fpclassifyf((float)(x)) \ : sizeof(x) == sizeof(double) ? __fpclassifyd((double)(x)) \ : __fpclassifyl((long double)(x))) +#endif /* !defined(__cplusplus) && !__has_feature(modules) */ extern int __fpclassifyf(float); extern int __fpclassifyd(double); @@ -152,6 +160,7 @@ extern int __fpclassifyl(long double); Thus, if you compile with -ffast-math, actual function calls are generated for these utilities. */ +#if !defined(__cplusplus) || !defined(__has_feature) || !__has_feature(modules) #define isnormal(x) \ ( sizeof(x) == sizeof(float) ? __inline_isnormalf((float)(x)) \ : sizeof(x) == sizeof(double) ? __inline_isnormald((double)(x)) \ @@ -176,6 +185,7 @@ extern int __fpclassifyl(long double); ( sizeof(x) == sizeof(float) ? __inline_signbitf((float)(x)) \ : sizeof(x) == sizeof(double) ? __inline_signbitd((double)(x)) \ : __inline_signbitl((long double)(x))) +#endif /* !defined(__cplusplus) && !__has_feature(modules) */ __header_always_inline int __inline_isfinitef(float); __header_always_inline int __inline_isfinited(double); @@ -262,6 +272,13 @@ __header_always_inline int __inline_isnormall(long double __x) { or similar is specified. These are not available in iOS versions prior to 6.0. If you need them, you must target that version or later. */ +#if !defined(__cplusplus) || !defined(__has_feature) || !__has_feature(modules) +/* libc++'s math.h comes before this header in the search order. It + * will include this header first and then undef several of these + * macros. That doesn't work when the two headers are in different + * clang modules. The only way to make that work is to not declare + * the macros here, and let libc++ handle the declarations. + */ #define isnormal(x) \ ( sizeof(x) == sizeof(float) ? __isnormalf((float)(x)) \ : sizeof(x) == sizeof(double) ? __isnormald((double)(x)) \ @@ -286,7 +303,8 @@ __header_always_inline int __inline_isnormall(long double __x) { ( sizeof(x) == sizeof(float) ? __signbitf((float)(x)) \ : sizeof(x) == sizeof(double) ? __signbitd((double)(x)) \ : __signbitl((long double)(x))) - +#endif /* !defined(__cplusplus) && !__has_feature(modules) */ + extern int __isnormalf(float); extern int __isnormald(double); extern int __isnormall(long double); @@ -546,12 +564,20 @@ extern float fmaf(float, float, float); extern double fma(double, double, double); extern long double fmal(long double, long double, long double); +#if !defined(__cplusplus) || !defined(__has_feature) || !__has_feature(modules) +/* libc++'s math.h comes before this header in the search order. It + * will include this header first and then undef several of these + * macros. That doesn't work when the two headers are in different + * clang modules. The only way to make that work is to not declare + * the macros here, and let libc++ handle the declarations. + */ #define isgreater(x, y) __builtin_isgreater((x),(y)) #define isgreaterequal(x, y) __builtin_isgreaterequal((x),(y)) #define isless(x, y) __builtin_isless((x),(y)) #define islessequal(x, y) __builtin_islessequal((x),(y)) #define islessgreater(x, y) __builtin_islessgreater((x),(y)) #define isunordered(x, y) __builtin_isunordered((x),(y)) +#endif /* !defined(__cplusplus) && !__has_feature(modules) */ #if defined __i386__ || defined __x86_64__ /* Deprecated functions; use the INFINITY and NAN macros instead. */ diff --git a/lib/libc/include/any-macos-any/net/if.h b/lib/libc/include/any-macos-any/net/if.h index 7bb7c3874d..f562eb76d8 100644 --- a/lib/libc/include/any-macos-any/net/if.h +++ b/lib/libc/include/any-macos-any/net/if.h @@ -154,16 +154,6 @@ struct if_clonereq { #define IFQ_MAXLEN 128 #define IFNET_SLOWHZ 1 /* granularity is 1 second */ -#define IFQ_DEF_C_TARGET_DELAY (10ULL * 1000 * 1000) /* 10 ms */ -#define IFQ_DEF_C_UPDATE_INTERVAL (100ULL * 1000 * 1000) /* 100 ms */ -#define IFQ_DEF_L4S_TARGET_DELAY (2ULL * 1000 * 1000) /* 2 ms */ -#define IFQ_DEF_L4S_WIRELESS_TARGET_DELAY (15ULL * 1000 * 1000) /* 15 ms */ -#define IFQ_DEF_L4S_UPDATE_INTERVAL (100ULL * 1000 * 1000) /* 100 ms */ -#define IFQ_LL_C_TARGET_DELAY (10ULL * 1000 * 1000) /* 10 ms */ -#define IFQ_LL_C_UPDATE_INTERVAL (100ULL * 1000 * 1000) /* 100 ms */ -#define IFQ_LL_L4S_TARGET_DELAY (2ULL * 1000 * 1000) /* 2 ms */ -#define IFQ_LL_L4S_WIRELESS_TARGET_DELAY (15ULL * 1000 * 1000) /* 15 ms */ -#define IFQ_LL_L4S_UPDATE_INTERVAL (100ULL * 1000 * 1000) /* 100 ms */ /* * Message format for use in obtaining information about interfaces * from sysctl and the routing socket @@ -332,6 +322,7 @@ struct ifreq { #define IFRTYPE_FUNCTIONAL_LAST 8 u_int8_t ifru_is_directlink; u_int8_t ifru_is_vpn; + u_int8_t ifru_is_companionlink; } ifr_ifru; #define ifr_addr ifr_ifru.ifru_addr /* address */ #define ifr_dstaddr ifr_ifru.ifru_dstaddr /* other end of p-to-p link */ diff --git a/lib/libc/include/any-macos-any/netinet/tcp.h b/lib/libc/include/any-macos-any/netinet/tcp.h index 8aab372e1b..6c865fdaee 100644 --- a/lib/libc/include/any-macos-any/netinet/tcp.h +++ b/lib/libc/include/any-macos-any/netinet/tcp.h @@ -118,14 +118,17 @@ struct tcphdr { }; #define TCPOPT_EOL 0 +#define TCPOLEN_EOL 1 #define TCPOPT_NOP 1 +#define TCPOLEN_NOP 1 #define TCPOPT_MAXSEG 2 #define TCPOLEN_MAXSEG 4 #define TCPOPT_WINDOW 3 #define TCPOLEN_WINDOW 3 -#define TCPOPT_SACK_PERMITTED 4 /* Experimental */ +#define TCPOPT_SACK_PERMITTED 4 /* SACK capability in SYN */ #define TCPOLEN_SACK_PERMITTED 2 -#define TCPOPT_SACK 5 /* Experimental */ +#define TCPOPT_SACK 5 +#define TCPOLEN_SACKHDR 2 #define TCPOLEN_SACK 8 /* len of sack block */ #define TCPOPT_TIMESTAMP 8 #define TCPOLEN_TIMESTAMP 10 diff --git a/lib/libc/include/any-macos-any/netinet6/in6.h b/lib/libc/include/any-macos-any/netinet6/in6.h index f77a7bb6a1..70d84d8b89 100644 --- a/lib/libc/include/any-macos-any/netinet6/in6.h +++ b/lib/libc/include/any-macos-any/netinet6/in6.h @@ -101,6 +101,7 @@ #include #include +#include /* * Identification of the network protocol stack diff --git a/lib/libc/include/any-macos-any/os/availability.h b/lib/libc/include/any-macos-any/os/availability.h index 453633c646..8f3d112fa2 100644 --- a/lib/libc/include/any-macos-any/os/availability.h +++ b/lib/libc/include/any-macos-any/os/availability.h @@ -115,6 +115,9 @@ * ios, iOSApplicationExtension, tvos, tvOSApplicationExtension, watchos, * watchOSApplicationExtension, driverkit, visionos, visionOSApplicationExtension * + * Within each platform a tuple of versions will represent the version the API was + * introduced in, followed by the version it was deperecated in. + * * Examples: * * API_DEPRECATED("Deprecated", macos(10.4, 10.8)) @@ -143,6 +146,10 @@ * ios, iOSApplicationExtension, tvos, tvOSApplicationExtension, watchos, * watchOSApplicationExtension, driverkit, visionos, visionOSApplicationExtension * + * Within each platform a tuple of versions will represent the version the API was + * introduced in, followed by the version it was deperecated in, and finally the version it + * was removed in. + * * Examples: * * API_OBSOLETED("No longer supported", macos(10.4, 10.8, 11.0)) @@ -151,6 +158,7 @@ * API_OBSOLETED_WITH_REPLACEMENT("-setName:", tvos(10.0, 10.4, 12.0), ios(9.0, 10.0, 11.0)) * API_OBSOLETED_WITH_REPLACEMENT("SomeClassName", macos(10.4, 10.6, 11.0), watchos(2.0, 3.0, 4.0)) */ + #define API_OBSOLETED(...) __API_OBSOLETED_MSG_GET_MACRO_93585900(__VA_ARGS__,__API_OBSOLETED_MSG15,__API_OBSOLETED_MSG14,__API_OBSOLETED_MSG13,__API_OBSOLETED_MSG12,__API_OBSOLETED_MSG11,__API_OBSOLETED_MSG10,__API_OBSOLETED_MSG9,__API_OBSOLETED_MSG8,__API_OBSOLETED_MSG7,__API_OBSOLETED_MSG6,__API_OBSOLETED_MSG5,__API_OBSOLETED_MSG4,__API_OBSOLETED_MSG3,__API_OBSOLETED_MSG2,__API_OBSOLETED_MSG1,__API_OBSOLETED_MSG0,0,0)(__VA_ARGS__) #define API_OBSOLETED_WITH_REPLACEMENT(...) __API_OBSOLETED_REP_GET_MACRO_93585900(__VA_ARGS__,__API_OBSOLETED_REP15,__API_OBSOLETED_REP14,__API_OBSOLETED_REP13,__API_OBSOLETED_REP12,__API_OBSOLETED_REP11,__API_OBSOLETED_REP10,__API_OBSOLETED_REP9,__API_OBSOLETED_REP8,__API_OBSOLETED_REP7,__API_OBSOLETED_REP6,__API_OBSOLETED_REP5,__API_OBSOLETED_REP4,__API_OBSOLETED_REP3,__API_OBSOLETED_REP2,__API_OBSOLETED_REP1,__API_OBSOLETED_REP0,0,0)(__VA_ARGS__) @@ -189,7 +197,7 @@ #endif #ifndef API_AVAILABLE_END - #define API_AVAILABLE_END(...) + #define API_AVAILABLE_END #endif #ifndef API_DEPRECATED @@ -201,7 +209,7 @@ #endif #ifndef API_DEPRECATED_END - #define API_DEPRECATED_END(...) + #define API_DEPRECATED_END #endif #ifndef API_DEPRECATED_WITH_REPLACEMENT @@ -213,7 +221,7 @@ #endif #ifndef API_DEPRECATED_WITH_REPLACEMENT_END - #define API_DEPRECATED_WITH_REPLACEMENT_END(...) + #define API_DEPRECATED_WITH_REPLACEMENT_END #endif #ifndef API_OBSOLETED @@ -225,7 +233,7 @@ #endif #ifndef API_OBSOLETED_END - #define API_OBSOLETED_END(...) + #define API_OBSOLETED_END #endif #ifndef API_OBSOLETED_WITH_REPLACEMENT @@ -237,7 +245,7 @@ #endif #ifndef API_OBSOLETED_WITH_REPLACEMENT_END - #define API_OBSOLETED_WITH_REPLACEMENT_END(...) + #define API_OBSOLETED_WITH_REPLACEMENT_END #endif #ifndef API_UNAVAILABLE @@ -249,7 +257,7 @@ #endif #ifndef API_UNAVAILABLE_END - #define API_UNAVAILABLE_END(...) + #define API_UNAVAILABLE_END #endif #if __has_include() @@ -269,7 +277,7 @@ #endif #ifndef SPI_AVAILABLE_END - #define SPI_AVAILABLE_END(...) + #define SPI_AVAILABLE_END #endif #ifndef SPI_DEPRECATED diff --git a/lib/libc/include/any-macos-any/os/base.h b/lib/libc/include/any-macos-any/os/base.h index ee47074b7a..7382897b4e 100644 --- a/lib/libc/include/any-macos-any/os/base.h +++ b/lib/libc/include/any-macos-any/os/base.h @@ -71,7 +71,11 @@ #define OS_WEAK __attribute__((__weak__)) #define OS_WEAK_IMPORT __attribute__((__weak_import__)) #define OS_NOINLINE __attribute__((__noinline__)) +#ifndef __BUILDING_XNU_LIBRARY__ #define OS_ALWAYS_INLINE __attribute__((__always_inline__)) +#else /* __BUILDING_XNU_LIBRARY__ */ +#define OS_ALWAYS_INLINE +#endif /* __BUILDING_XNU_LIBRARY__ */ #define OS_TRANSPARENT_UNION __attribute__((__transparent_union__)) #define OS_ALIGNED(n) __attribute__((__aligned__((n)))) #define OS_FORMAT_PRINTF(x, y) __attribute__((__format__(printf,x,y))) @@ -343,4 +347,5 @@ typedef void (^os_block_t)(void); #define OS_COUNTED_BY(N) __counted_by(N) #define OS_SIZED_BY(N) __sized_by(N) + #endif // __OS_BASE__ diff --git a/lib/libc/include/any-macos-any/os/workgroup_base.h b/lib/libc/include/any-macos-any/os/workgroup_base.h index c9b06590e7..633883b043 100644 --- a/lib/libc/include/any-macos-any/os/workgroup_base.h +++ b/lib/libc/include/any-macos-any/os/workgroup_base.h @@ -26,6 +26,12 @@ #define OS_WORKGROUP_ASSUME_NONNULL_BEGIN #define OS_WORKGROUP_ASSUME_NONNULL_END #endif +#if __has_feature(enumerator_attributes) +#define OS_WORKGROUP_ENUM_API_DEPRECATED_WITH_REPLACEMENT(...) \ + API_DEPRECATED_WITH_REPLACEMENT(__VA_ARGS__) +#else +#define OS_WORKGROUP_ENUM_API_DEPRECATED_WITH_REPLACEMENT(...) +#endif #define OS_WORKGROUP_WARN_RESULT __attribute__((__warn_unused_result__)) #define OS_WORKGROUP_EXPORT OS_EXPORT #define OS_WORKGROUP_RETURNS_RETAINED OS_OBJECT_RETURNS_RETAINED diff --git a/lib/libc/include/any-macos-any/secure/_common.h b/lib/libc/include/any-macos-any/secure/_common.h index 03181dd30c..6a7a508b28 100644 --- a/lib/libc/include/any-macos-any/secure/_common.h +++ b/lib/libc/include/any-macos-any/secure/_common.h @@ -39,5 +39,7 @@ #define __darwin_obsz0(object) __builtin_object_size (object, 0) #define __darwin_obsz(object) __builtin_object_size (object, _USE_FORTIFY_LEVEL > 1 ? 1 : 0) +#define __darwin_pass_obsz0 __attribute__((__pass_object_size__(0))) +#define __darwin_pass_obsz __attribute__((__pass_object_size__(_USE_FORTIFY_LEVEL > 1 ? 1 : 0))) #endif diff --git a/lib/libc/include/any-macos-any/secure/_stdio.h b/lib/libc/include/any-macos-any/secure/_stdio.h index 9046dac920..cc678f318a 100644 --- a/lib/libc/include/any-macos-any/secure/_stdio.h +++ b/lib/libc/include/any-macos-any/secure/_stdio.h @@ -35,54 +35,95 @@ _LIBC_SINGLE_BY_DEFAULT() #if _USE_FORTIFY_LEVEL > 0 +extern int __snprintf_chk (char * __restrict _LIBC_COUNT(__maxlen), size_t __maxlen, int, size_t, + const char * __restrict, ...); +extern int __vsnprintf_chk (char * __restrict _LIBC_COUNT(__maxlen), size_t __maxlen, int, size_t, + const char * __restrict, va_list); + +extern int __sprintf_chk (char * __restrict _LIBC_UNSAFE_INDEXABLE, int, size_t, + const char * __restrict, ...); +extern int __vsprintf_chk (char * __restrict _LIBC_UNSAFE_INDEXABLE, int, size_t, + const char * __restrict, va_list); + +#ifdef __LIBC_STAGED_BOUNDS_SAFETY_ATTRIBUTES + +/* verify that there are at least __n characters at __str */ +static inline char *_LIBC_COUNT(__n) +__libc_ptrchk_strbuf_chk(char *_LIBC_COUNT(__n) __str, size_t __n) { return __str; } + +#undef __sprintf_chk_func /* sprintf is unavailable */ +#undef __vsprintf_chk_func /* vsprintf is unavailable */ + +#define __vsnprintf_chk_func(str, len, flag, format, ap) ({ \ + size_t __len = (len); \ + __builtin___vsnprintf_chk (__libc_ptrchk_strbuf_chk(str, __len), __len, flag, __darwin_obsz(str), format, ap); \ +}) + +#define __snprintf_chk_func(str, len, flag, ...) ({ \ + size_t __len = (len); \ + __builtin___snprintf_chk (__libc_ptrchk_strbuf_chk(str, __len), __len, flag, __darwin_obsz(str), __VA_ARGS__); \ +}) + +#else + #ifndef __has_builtin -#define _undef__has_builtin -#define __has_builtin(x) 0 +#define __undef__has_builtin +#define __has_builtin(x) defined(__GNUC__) +#endif + +#if __has_builtin(__builtin___snprintf_chk) +#define __snprintf_chk_func(str, len, flag, ...) \ + __builtin___snprintf_chk (str, len, flag, __darwin_obsz(str), __VA_ARGS__) +#endif + +#if __has_builtin(__builtin___vsnprintf_chk) +#define __vsnprintf_chk_func(str, len, flag, format, ap) \ + __builtin___vsnprintf_chk (str, len, flag, __darwin_obsz(str), format, ap) +#endif + + +#if __has_builtin(__builtin___sprintf_chk) +#define __sprintf_chk_func(str, flag, ...) \ + __builtin___sprintf_chk (str, flag, __darwin_obsz(str), __VA_ARGS__) +#endif + +#if __has_builtin(__builtin___vsprintf_chk) +#define __vsprintf_chk_func(str, flag, format, ap) \ + __builtin___vsprintf_chk (str, flag, __darwin_obsz(str), format, ap) +#endif + + +#ifdef __undef__has_builtin +#undef __undef__has_builtin +#undef __has_builtin +#endif + #endif /* sprintf, vsprintf, snprintf, vsnprintf */ -#if __has_builtin(__builtin___sprintf_chk) || defined(__GNUC__) -extern int __sprintf_chk (char * __restrict _LIBC_UNSAFE_INDEXABLE, int, size_t, - const char * __restrict, ...); +#ifdef __sprintf_chk_func #undef sprintf -#define sprintf(str, ...) \ - __builtin___sprintf_chk (str, 0, __darwin_obsz(str), __VA_ARGS__) +#define sprintf(str, ...) __sprintf_chk_func (str, 0, __VA_ARGS__) #endif #if __DARWIN_C_LEVEL >= 200112L -#if __has_builtin(__builtin___snprintf_chk) || defined(__GNUC__) -extern int __snprintf_chk (char * __restrict _LIBC_COUNT(__maxlen), size_t __maxlen, int, size_t, - const char * __restrict, ...); - -#undef snprintf -#define snprintf(str, len, ...) \ - __builtin___snprintf_chk (str, len, 0, __darwin_obsz(str), __VA_ARGS__) -#endif - -#if __has_builtin(__builtin___vsprintf_chk) || defined(__GNUC__) -extern int __vsprintf_chk (char * __restrict _LIBC_UNSAFE_INDEXABLE, int, size_t, - const char * __restrict, va_list); +#ifdef __vsprintf_chk_func #undef vsprintf -#define vsprintf(str, format, ap) \ - __builtin___vsprintf_chk (str, 0, __darwin_obsz(str), format, ap) +#define vsprintf(str, ...) __vsprintf_chk_func (str, 0, __VA_ARGS__) #endif -#if __has_builtin(__builtin___vsnprintf_chk) || defined(__GNUC__) -extern int __vsnprintf_chk (char * __restrict _LIBC_COUNT(__maxlen), size_t __maxlen, int, size_t, - const char * __restrict, va_list); +#ifdef __snprintf_chk_func +#undef snprintf +#define snprintf(str, len, ...) __snprintf_chk_func (str, len, 0, __VA_ARGS__) +#endif +#ifdef __vsnprintf_chk_func #undef vsnprintf -#define vsnprintf(str, len, format, ap) \ - __builtin___vsnprintf_chk (str, len, 0, __darwin_obsz(str), format, ap) +#define vsnprintf(str, len, ...) __vsnprintf_chk_func (str, len, 0, __VA_ARGS__) #endif -#endif /* __DARWIN_C_LEVEL >= 200112L */ - -#ifdef _undef__has_builtin -#undef _undef__has_builtin -#undef __has_builtin #endif #endif /* _USE_FORTIFY_LEVEL > 0 */ diff --git a/lib/libc/include/any-macos-any/secure/_string.h b/lib/libc/include/any-macos-any/secure/_string.h index f023af32a1..d16ecd165c 100644 --- a/lib/libc/include/any-macos-any/secure/_string.h +++ b/lib/libc/include/any-macos-any/secure/_string.h @@ -34,117 +34,262 @@ #if _USE_FORTIFY_LEVEL > 0 -/* */ -#if defined(__clang__) && \ - ((defined(__apple_build_version__) && __apple_build_version__ >= 4260006) || \ - (!defined(__apple_build_version__) && (__clang_major__ > 3 || (__clang_major__ == 3 && __clang_minor__ >= 3)))) -#define __HAS_FIXED_CHK_PROTOTYPES 1 +#ifdef __LIBC_STAGED_BOUNDS_SAFETY_ATTRIBUTES + +#if __has_builtin(__builtin___memcpy_chk) +static inline void *_LIBC_SIZE(__n) +__memcpy_ptrchk(void *const _LIBC_SIZE(__n) __darwin_pass_obsz0 __dst, const void *_LIBC_SIZE(__n) __src, size_t __n) { + return _LIBC_FORGE_PTR(__builtin___memcpy_chk(__dst, __src, __n, __darwin_obsz0(__dst)), __n); +} +#define __memcpy_chk_func __memcpy_ptrchk +#endif + +#if __has_builtin(__builtin___memmove_chk) +static inline void *_LIBC_SIZE(__n) +__memmove_ptrchk(void *const _LIBC_SIZE(__n) __darwin_pass_obsz0 __dst, const void *_LIBC_SIZE(__n) __src, size_t __n) { + return _LIBC_FORGE_PTR(__builtin___memmove_chk(__dst, __src, __n, __darwin_obsz0(__dst)), __n); +} +#define __memmove_chk_func __memmove_ptrchk +#endif + +#if __has_builtin(__builtin___memset_chk) +static inline void *_LIBC_SIZE(__n) +__memset_ptrchk(void *const _LIBC_SIZE(__n) __darwin_pass_obsz0 __dst, int __c, size_t __n) { + return _LIBC_FORGE_PTR(__builtin___memset_chk(__dst, __c, __n, __darwin_obsz0(__dst)), __n); +} +#define __memset_chk_func __memset_ptrchk +#endif + +#undef __stpncpy_chk_func /* stpncpy unavailable */ +#undef __strncpy_chk_func /* strncpy unavailable */ + +#if __has_builtin(__builtin___strlcpy_chk) +static inline size_t +__strlcpy_ptrchk(char *const _LIBC_SIZE(__n) __darwin_pass_obsz __dst, const char *__src, size_t __n) { + return __builtin___strlcpy_chk(__dst, __src, __n, __darwin_obsz(__dst)); +} +#define __strlcpy_chk_func __strlcpy_ptrchk +#endif + +#if __has_builtin(__builtin___strlcat_chk) +static inline size_t +__strlcat_ptrchk(char *const _LIBC_SIZE(__n) __darwin_pass_obsz __dst, const char *__src, size_t __n) { + return __builtin___strlcat_chk(__dst, __src, __n, __darwin_obsz(__dst)); +} +#define __strlcat_chk_func __strlcat_ptrchk +#endif + +#if __has_builtin(__builtin___memccpy_chk) +static inline void *_LIBC_SIZE(__n) +__memccpy_ptrchk(void *const _LIBC_SIZE(__n) __darwin_pass_obsz0 __dst, const void *_LIBC_SIZE(__n) __src, int __c, size_t __n) { + return _LIBC_FORGE_PTR(__builtin___memccpy_chk(__dst, __src, __c, __n, __darwin_obsz0(__dst)), __n); +} +#define __memccpy_chk_func __memccpy_ptrchk +#endif + +#undef __strcpy_chk_func /* strcpy unavailable */ +#undef __stpcpy_chk_func /* stpcpy unavailable */ +#undef __strcat_chk_func /* strcat unavailable */ +#undef __strncat_chk_func /* strncat unavailable */ + +#else /* __LIBC_STAGED_BOUNDS_SAFETY_ATTRIBUTES */ + +#define __is_modern_darwin(ios, macos) \ + (__IPHONE_OS_VERSION_MIN_REQUIRED >= (ios) || \ + __MAC_OS_X_VERSION_MIN_REQUIRED >= (macos) || \ + defined(__DRIVERKIT_VERSION_MIN_REQUIRED)) + +/* __is_gcc(gcc_major, gcc_minor) + * Special values: + * 10.0 means "test should always fail when __has_builtin isn't supported" + (because gcc got __has_builtin in version 10.0); this is used for builtins + that gcc did not support yet at the time __has_builtin was introduced, so + there is no point checking the compiler version. + * 0.0 means that we did not research when gcc started supporting this builtin, + but it's believed to have been the case at least since gcc 4.0, which came + out in 2005. (Hello from 2025! What year is it now? Can't believe we're still + using C!) + */ +#define __is_gcc(major, minor) \ + (__GNUC__ > (gcc_major) || \ + (__GNUC__ == (gcc_major) && __GNUC_MINOR__ >= (gcc_minor))) + +#ifdef __has_builtin +#define __supports_builtin(builtin, gcc_major, gcc_minor) \ + __has_builtin(builtin) #else -#define __HAS_FIXED_CHK_PROTOTYPES 0 +#define __supports_builtin(builtin, gcc_major, gcc_minor) __is_gcc(gcc_major, gcc_minor) #endif -/* memccpy, memcpy, mempcpy, memmove, memset, strcpy, strlcpy, stpcpy, - strncpy, stpncpy, strcat, strlcat, and strncat */ -#if __IPHONE_OS_VERSION_MIN_REQUIRED >= 70000 || __MAC_OS_X_VERSION_MIN_REQUIRED >= 1090 || \ - defined(__DRIVERKIT_VERSION_MIN_REQUIRED) -#if __has_builtin(__builtin___memccpy_chk) && __HAS_FIXED_CHK_PROTOTYPES -#undef memccpy -/* void *memccpy(void *dst, const void *src, int c, size_t n) */ -#define memccpy(dest, ...) \ - __builtin___memccpy_chk (dest, __VA_ARGS__, __darwin_obsz0 (dest)) -#endif -#endif - -#if __has_builtin(__builtin___memcpy_chk) || defined(__GNUC__) -#undef memcpy -/* void *memcpy(void *dst, const void *src, size_t n) */ -#define memcpy(dest, ...) \ +#if __supports_builtin(__builtin___memcpy_chk, 0, 0) +#define __memcpy_chk_func(dest, ...) \ __builtin___memcpy_chk (dest, __VA_ARGS__, __darwin_obsz0 (dest)) #endif -#if __has_builtin(__builtin___memmove_chk) || defined(__GNUC__) -#undef memmove -/* void *memmove(void *dst, const void *src, size_t len) */ -#define memmove(dest, ...) \ +#if __supports_builtin(__builtin___memmove_chk, 0, 0) +#define __memmove_chk_func(dest, ...) \ __builtin___memmove_chk (dest, __VA_ARGS__, __darwin_obsz0 (dest)) #endif -#if __has_builtin(__builtin___memset_chk) || defined(__GNUC__) -#undef memset -/* void *memset(void *b, int c, size_t len) */ -#define memset(dest, ...) \ +#if __supports_builtin(__builtin___memset_chk, 0, 0) +#define __memset_chk_func(dest, ...) \ __builtin___memset_chk (dest, __VA_ARGS__, __darwin_obsz0 (dest)) #endif -#if __has_builtin(__builtin___strcpy_chk) || defined(__GNUC__) -#undef strcpy -/* char *strcpy(char *dst, const char *src) */ -#define strcpy(dest, ...) \ - __builtin___strcpy_chk (dest, __VA_ARGS__, __darwin_obsz (dest)) -#endif - -#if __DARWIN_C_LEVEL >= 200809L -#if __has_builtin(__builtin___stpcpy_chk) || defined(__GNUC__) -#undef stpcpy -/* char *stpcpy(char *dst, const char *src) */ -#define stpcpy(dest, ...) \ - __builtin___stpcpy_chk (dest, __VA_ARGS__, __darwin_obsz (dest)) -#endif -#endif /* __DARWIN_C_LEVEL >= 200809L */ - -#if __DARWIN_C_LEVEL >= 200809L -#if __has_builtin(__builtin___stpncpy_chk) || __APPLE_CC__ >= 5666 || __GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 7) -#undef stpncpy -/* char *stpncpy(char *dst, const char *src, size_t n) */ -#define stpncpy(dest, ...) \ +#if __supports_builtin(__builtin___stpncpy_chk, 4, 7) +#define __stpncpy_chk_func(dest, ...) \ __builtin___stpncpy_chk (dest, __VA_ARGS__, __darwin_obsz (dest)) #endif -#endif /* _DARWIN_C_LEVEL >= 200809L */ -#if __DARWIN_C_LEVEL >= __DARWIN_C_FULL -#if __IPHONE_OS_VERSION_MIN_REQUIRED >= 70000 || __MAC_OS_X_VERSION_MIN_REQUIRED >= 1090 || \ - defined(__DRIVERKIT_VERSION_MIN_REQUIRED) -#if __has_builtin(__builtin___strlcpy_chk) && __HAS_FIXED_CHK_PROTOTYPES -#undef strlcpy -/* size_t strlcpy(char *dst, const char *source, size_t size) */ -#define strlcpy(dest, ...) \ - __builtin___strlcpy_chk (dest, __VA_ARGS__, __darwin_obsz (dest)) -#endif - -#if __has_builtin(__builtin___strlcat_chk) && __HAS_FIXED_CHK_PROTOTYPES -#undef strlcat -/* size_t strlcat(char *dst, const char *source, size_t size) */ -#define strlcat(dest, ...) \ - __builtin___strlcat_chk (dest, __VA_ARGS__, __darwin_obsz (dest)) -#endif -#endif /* __IPHONE_OS_VERSION_MIN_REQUIRED >= 70000 || __MAC_OS_X_VERSION_MIN_REQUIRED >= 1090 */ -#endif /* __DARWIN_C_LEVEL >= __DARWIN_C_FULL */ - -#if __has_builtin(__builtin___strncpy_chk) || defined(__GNUC__) -#undef strncpy -/* char *strncpy(char *dst, const char *src, size_t n) */ -#define strncpy(dest, ...) \ +#if __supports_builtin(__builtin___strncpy_chk, 0, 0) +#define __strncpy_chk_func(dest, ...) \ __builtin___strncpy_chk (dest, __VA_ARGS__, __darwin_obsz (dest)) #endif -#if __has_builtin(__builtin___strcat_chk) || defined(__GNUC__) -#undef strcat -/* char *strcat(char *s1, const char *s2) */ -#define strcat(dest, ...) \ +#if __is_modern_darwin(70000, 1090) + +#if __supports_builtin(__builtin___strlcpy_chk, 0, 0) +#define __strlcpy_chk_func(dest, ...) \ + __builtin___strlcpy_chk (dest, __VA_ARGS__, __darwin_obsz (dest)) +#endif + +#if __supports_builtin(__builtin___strlcat_chk, 0, 0) +#define __strlcat_chk_func(dest, ...) \ + __builtin___strlcat_chk (dest, __VA_ARGS__, __darwin_obsz (dest)) +#endif + +#if __supports_builtin(__builtin___memccpy_chk, 10, 0) +#define __memccpy_chk_func(dest, ...) \ + __builtin___memccpy_chk (dest, __VA_ARGS__, __darwin_obsz0 (dest)) +#endif + +#endif /* __is_modern_darwin(70000, 1090) */ + + +#if __supports_builtin(__builtin___strcpy_chk, 0, 0) +#define __strcpy_chk_func(dest, ...) \ + __builtin___strcpy_chk (dest, __VA_ARGS__, __darwin_obsz (dest)) +#endif + +#if __supports_builtin(__builtin___stpcpy_chk, 0, 0) +#define __stpcpy_chk_func(dest, ...) \ + __builtin___stpcpy_chk (dest, __VA_ARGS__, __darwin_obsz (dest)) +#endif + +#if __supports_builtin(__builtin___strcat_chk, 0, 0) +#define __strcat_chk_func(dest, ...) \ __builtin___strcat_chk (dest, __VA_ARGS__, __darwin_obsz (dest)) #endif #if ! (defined(__IPHONE_OS_VERSION_MIN_REQUIRED) && __IPHONE_OS_VERSION_MIN_REQUIRED < 32000) -#if __has_builtin(__builtin___strncat_chk) || defined(__GNUC__) -#undef strncat -/* char *strncat(char *s1, const char *s2, size_t n) */ -#define strncat(dest, ...) \ +#if __supports_builtin(__builtin___strncat_chk, 0, 0) +#define __strncat_chk_func(dest, ...) \ __builtin___strncat_chk (dest, __VA_ARGS__, __darwin_obsz (dest)) #endif #endif -#undef __HAS_FIXED_CHK_PROTOTYPES + +#undef __supports_builtin +#undef __is_gcc + +#endif /* defined(__has_ptrcheck) && __has_ptrcheck */ + +#undef __is_modern_darwin + +/* memccpy, memcpy, mempcpy, memmove, memset, strcpy, strlcpy, stpcpy, + strncpy, stpncpy, strcat, strlcat, and strncat */ + +/* The use of .../__VA_ARGS__ is load-bearing. If the macros take fixed + * arguments, they are unable to themselves accept macros that expand to + * multiple arguments, like this: + * #define memcpy(a, b, c) ... + * #define FOO(data) get_bytes(data), get_length(data) + * memcpy(bar, FOO(d)); + * This will fail because the preprocessor only sees two arguments on the first + * expansion of memcpy, when 3 are required. + * This is also required to support syntaxes that embed commas. The preprocessor + * recognizes parentheses for the isolation of arguments but not brackets. This + * expands to 3 arguments: + * strcpy(destination, [NSString stringWithFormat:@"%i", 4].UTF8String); + * ^ ^ ^ + * |destination | | + * |[NSString stringWithFormat:@"%i" | + * |4].UTF8String + * This expands to 4 arguments: + * memcpy(destination, (uint8_t[]) { 1, 2 }, 2); + * ^ ^ ^ ^ + * To work correctly under these hostile circumstances, chk_func macros + * need to expand to a bare identifier (like #define memcpy_chk_func __memcpy) + * or to a macro that also takes variadic arguments. + */ + +#ifdef __memccpy_chk_func +#undef memccpy +#define memccpy(...) __memccpy_chk_func (__VA_ARGS__) +#endif + +#ifdef __memcpy_chk_func +#undef memcpy +#define memcpy(...) __memcpy_chk_func (__VA_ARGS__) +#endif + +#ifdef __memmove_chk_func +#undef memmove +#define memmove(...) __memmove_chk_func (__VA_ARGS__) +#endif + +#ifdef __memset_chk_func +#undef memset +#define memset(...) __memset_chk_func (__VA_ARGS__) +#endif + +#if defined(__strcpy_chk_func) +#undef strcpy +#define strcpy(...) __strcpy_chk_func (__VA_ARGS__) +#endif + +#if defined(__strcat_chk_func) +#undef strcat +#define strcat(...) __strcat_chk_func (__VA_ARGS__) +#endif + +#if defined(__strncpy_chk_func) +#undef strncpy +#define strncpy(...) __strncpy_chk_func (__VA_ARGS__) +#endif + +#if defined(__strncat_chk_func) +#undef strncat +#define strncat(...) __strncat_chk_func (__VA_ARGS__) +#endif + +#if __DARWIN_C_LEVEL >= 200809L + +#if defined(__stpcpy_chk_func) +#undef stpcpy +#define stpcpy(...) __stpcpy_chk_func (__VA_ARGS__) +#endif + +#if defined(__stpncpy_chk_func) +#undef stpncpy +#define stpncpy(...) __stpncpy_chk_func (__VA_ARGS__) +#endif + +#endif /* __DARWIN_C_LEVEL >= 200809L */ + +#if __DARWIN_C_LEVEL >= __DARWIN_C_FULL +#if defined(__strlcpy_chk_func) +#undef strlcpy +#define strlcpy(...) __strlcpy_chk_func (__VA_ARGS__) +#endif + +#if defined(__strlcat_chk_func) +#undef strlcat +#define strlcat(...) __strlcat_chk_func (__VA_ARGS__) +#endif +#endif /* __DARWIN_C_LEVEL >= __DARWIN_C_FULL */ #endif /* _USE_FORTIFY_LEVEL > 0 */ + #endif /* _SECURE__STRING_H_ */ diff --git a/lib/libc/include/any-macos-any/secure/_strings.h b/lib/libc/include/any-macos-any/secure/_strings.h index 384c5068a6..a841395dda 100644 --- a/lib/libc/include/any-macos-any/secure/_strings.h +++ b/lib/libc/include/any-macos-any/secure/_strings.h @@ -39,18 +39,55 @@ /* Removed in Issue 7 */ #if !defined(_POSIX_C_SOURCE) || _POSIX_C_SOURCE < 200809L -#if __has_builtin(__builtin___memmove_chk) || defined(__GNUC__) -#undef bcopy -/* void bcopy(const void *src, void *dst, size_t len) */ -#define bcopy(src, dest, ...) \ - __builtin___memmove_chk (dest, src, __VA_ARGS__, __darwin_obsz0 (dest)) +#ifdef __LIBC_STAGED_BOUNDS_SAFETY_ATTRIBUTES + +static inline void +__bcopy_ptrcheck(const void *_LIBC_SIZE(__n) __src, void *const _LIBC_SIZE(__n) __darwin_pass_obsz0 __dst, size_t __n) { + memmove(__dst, __src, __n); +} + +static inline void +__bzero_ptrcheck(void *const _LIBC_SIZE(__n) __darwin_pass_obsz0 __dst, size_t __n) { + memset(__dst, 0, __n); +} + +#define __bcopy_chk_func __bcopy_ptrcheck +#define __bzero_chk_func __bzero_ptrcheck + +#else + +#ifndef __has_builtin +#define __undef__has_builtin +#define __has_builtin(x) defined(__GNUC__) #endif -#if __has_builtin(__builtin___memset_chk) || defined(__GNUC__) +#if __has_builtin(__builtin___memmove_chk) +#define __bcopy_chk_func(src, dst, ...) \ + __builtin___memmove_chk(dst, src, __VA_ARGS__, __darwin_obsz0 (dst)) +#endif + +#if __has_builtin(__builtin___memset_chk) +#define __bzero_chk_func(dst, ...) \ + __builtin___memset_chk(dst, 0, __VA_ARGS__, __darwin_obsz0 (dst)) +#endif + +#ifdef __undef__has_builtin +#undef __undef__has_builtin +#undef __has_builtin +#endif + +#endif + +#ifdef __bcopy_chk_func +#undef bcopy +/* void bcopy(const void *src, void *dst, size_t len) */ +#define bcopy(...) __bcopy_chk_func (__VA_ARGS__) +#endif + +#ifdef __bzero_chk_func #undef bzero /* void bzero(void *s, size_t n) */ -#define bzero(dest, ...) \ - __builtin___memset_chk (dest, 0, __VA_ARGS__, __darwin_obsz0 (dest)) +#define bzero(...) __bzero_chk_func (__VA_ARGS__) #endif #endif diff --git a/lib/libc/include/any-macos-any/setjmp.h b/lib/libc/include/any-macos-any/setjmp.h index f54ddefa57..2998a2963c 100644 --- a/lib/libc/include/any-macos-any/setjmp.h +++ b/lib/libc/include/any-macos-any/setjmp.h @@ -51,9 +51,6 @@ typedef int jmp_buf[_JBLEN]; typedef int sigjmp_buf[_JBLEN + 1]; #elif defined(__arm__) && !defined(__ARM_ARCH_7K__) - -#include - /* * _JBLEN is number of ints required to save the following: * r4-r8, r10, fp, sp, lr, sig == 10 register_t sized diff --git a/lib/libc/include/any-macos-any/spawn.h b/lib/libc/include/any-macos-any/spawn.h index 1807f8b04d..0d9306b7d2 100644 --- a/lib/libc/include/any-macos-any/spawn.h +++ b/lib/libc/include/any-macos-any/spawn.h @@ -69,6 +69,12 @@ int posix_spawnp(pid_t * __restrict, const char * __restrict, char *const __argv[__restrict], char *const __envp[__restrict]) __API_AVAILABLE(macos(10.5), ios(2.0)); +int posix_spawn_file_actions_addchdir(posix_spawn_file_actions_t *, + const char * __restrict) __API_AVAILABLE(macos(26.0)) __API_UNAVAILABLE(ios, tvos, watchos, visionos); + +int posix_spawn_file_actions_addfchdir(posix_spawn_file_actions_t *, + int) __API_AVAILABLE(macos(26.0)) __API_UNAVAILABLE(ios, tvos, watchos, visionos); + int posix_spawn_file_actions_addclose(posix_spawn_file_actions_t *, int) __API_AVAILABLE(macos(10.5), ios(2.0)) __API_UNAVAILABLE(watchos, tvos); int posix_spawn_file_actions_adddup2(posix_spawn_file_actions_t *, int, @@ -174,10 +180,10 @@ int posix_spawn_file_actions_addinherit_np(posix_spawn_file_actions_t *, int) __API_AVAILABLE(macos(10.7), ios(4.3)) __API_UNAVAILABLE(watchos, tvos); int posix_spawn_file_actions_addchdir_np(posix_spawn_file_actions_t *, - const char * __restrict) __API_AVAILABLE(macos(10.15)) __API_UNAVAILABLE(ios, tvos, watchos); + const char * __restrict) __API_DEPRECATED("posix_spawn_file_actions_addchdir(3) has replaced posix_spawn_file_actions_addchdir_np(3)", macos(10.15, 26.0)) __API_UNAVAILABLE(ios, tvos, watchos, visionos); int posix_spawn_file_actions_addfchdir_np(posix_spawn_file_actions_t *, - int) __API_AVAILABLE(macos(10.15)) __API_UNAVAILABLE(ios, tvos, watchos); + int) __API_DEPRECATED("posix_spawn_file_actions_addfchdir(3) has replaced posix_spawn_file_actions_addfchdir_np(3)", macos(10.15, 26.0)) __API_UNAVAILABLE(ios, tvos, watchos, visionos); __END_DECLS diff --git a/lib/libc/include/any-macos-any/sys/_symbol_aliasing.h b/lib/libc/include/any-macos-any/sys/_symbol_aliasing.h index c0a780342b..d77659f884 100644 --- a/lib/libc/include/any-macos-any/sys/_symbol_aliasing.h +++ b/lib/libc/include/any-macos-any/sys/_symbol_aliasing.h @@ -341,18 +341,6 @@ #define __DARWIN_ALIAS_STARTING_IPHONE___IPHONE_14_5(x) #endif -#if defined(__ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__) && __ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__ >= 140400 -#define __DARWIN_ALIAS_STARTING_IPHONE___IPHONE_14_4(x) x -#else -#define __DARWIN_ALIAS_STARTING_IPHONE___IPHONE_14_4(x) -#endif - -#if defined(__ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__) && __ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__ >= 140500 -#define __DARWIN_ALIAS_STARTING_IPHONE___IPHONE_14_5(x) x -#else -#define __DARWIN_ALIAS_STARTING_IPHONE___IPHONE_14_5(x) -#endif - #if defined(__ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__) && __ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__ >= 140600 #define __DARWIN_ALIAS_STARTING_IPHONE___IPHONE_14_6(x) x #else @@ -557,6 +545,24 @@ #define __DARWIN_ALIAS_STARTING_IPHONE___IPHONE_18_5(x) #endif +#if defined(__ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__) && __ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__ >= 180600 +#define __DARWIN_ALIAS_STARTING_IPHONE___IPHONE_18_6(x) x +#else +#define __DARWIN_ALIAS_STARTING_IPHONE___IPHONE_18_6(x) +#endif + +#if defined(__ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__) && __ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__ >= 190000 +#define __DARWIN_ALIAS_STARTING_IPHONE___IPHONE_19_0(x) x +#else +#define __DARWIN_ALIAS_STARTING_IPHONE___IPHONE_19_0(x) +#endif + +#if defined(__ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__) && __ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__ >= 260000 +#define __DARWIN_ALIAS_STARTING_IPHONE___IPHONE_26_0(x) x +#else +#define __DARWIN_ALIAS_STARTING_IPHONE___IPHONE_26_0(x) +#endif + #if defined(__ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__) && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ >= 1000 #define __DARWIN_ALIAS_STARTING_MAC___MAC_10_0(x) x #else @@ -857,12 +863,6 @@ #define __DARWIN_ALIAS_STARTING_MAC___MAC_13_1(x) #endif -#if defined(__ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__) && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ >= 130100 -#define __DARWIN_ALIAS_STARTING_MAC___MAC_13_1(x) x -#else -#define __DARWIN_ALIAS_STARTING_MAC___MAC_13_1(x) -#endif - #if defined(__ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__) && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ >= 130200 #define __DARWIN_ALIAS_STARTING_MAC___MAC_13_2(x) x #else @@ -983,3 +983,21 @@ #define __DARWIN_ALIAS_STARTING_MAC___MAC_15_5(x) #endif +#if defined(__ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__) && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ >= 150600 +#define __DARWIN_ALIAS_STARTING_MAC___MAC_15_6(x) x +#else +#define __DARWIN_ALIAS_STARTING_MAC___MAC_15_6(x) +#endif + +#if defined(__ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__) && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ >= 160000 +#define __DARWIN_ALIAS_STARTING_MAC___MAC_16_0(x) x +#else +#define __DARWIN_ALIAS_STARTING_MAC___MAC_16_0(x) +#endif + +#if defined(__ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__) && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ >= 260000 +#define __DARWIN_ALIAS_STARTING_MAC___MAC_26_0(x) x +#else +#define __DARWIN_ALIAS_STARTING_MAC___MAC_26_0(x) +#endif + diff --git a/lib/libc/include/any-macos-any/sys/_types/_graftdmg_un.h b/lib/libc/include/any-macos-any/sys/_types/_graftdmg_un.h index 366336bea3..5b3b02b666 100644 --- a/lib/libc/include/any-macos-any/sys/_types/_graftdmg_un.h +++ b/lib/libc/include/any-macos-any/sys/_types/_graftdmg_un.h @@ -43,6 +43,9 @@ #define SBC_STRICT_AUTH 0x0010 /* Strict authentication mode */ #define SBC_PRESERVE_GRAFT 0x0020 /* Preserve graft itself until unmount */ +/* Flag values for ungraftdmg */ +#define UNGRAFTDMG_NOFORCE 0x0000000000000002ULL /* Disallow ungraft if a non-dir vnode inside the graft is in use */ + typedef struct secure_boot_cryptex_args { u_int32_t sbc_version; u_int32_t sbc_4cc; diff --git a/lib/libc/include/any-macos-any/sys/attr.h b/lib/libc/include/any-macos-any/sys/attr.h index 52451bfcc6..ebd4c9e274 100644 --- a/lib/libc/include/any-macos-any/sys/attr.h +++ b/lib/libc/include/any-macos-any/sys/attr.h @@ -50,9 +50,10 @@ #define FSOPT_PACK_INVAL_ATTRS 0x00000008 -#define FSOPT_ATTR_CMN_EXTENDED 0x00000020 +#define FSOPT_ATTR_CMN_EXTENDED 0x00000020 #define FSOPT_RETURN_REALDEV 0x00000200 #define FSOPT_NOFOLLOW_ANY 0x00000800 +#define FSOPT_RESOLVE_BENEATH 0x00001000 /* we currently aren't anywhere near this amount for a valid * fssearchblock.sizeofsearchparams1 or fssearchblock.sizeofsearchparams2 @@ -369,6 +370,9 @@ typedef struct vol_capabilities_attr { * * VOL_CAP_INT_PUNCHHOLE: When set, the volume supports the F_PUNCHHOLE * fcntl. + * + * VOL_CAP_INT_BARRIERFSYNC: When set, the volume supports the F_BARRIERFSYNC + * fcntl. */ #define VOL_CAP_INT_SEARCHFS 0x00000001 #define VOL_CAP_INT_ATTRLIST 0x00000002 @@ -393,6 +397,7 @@ typedef struct vol_capabilities_attr { #define VOL_CAP_INT_RENAME_SECLUDE 0x00200000 #define VOL_CAP_INT_ATTRIBUTION_TAG 0x00400000 #define VOL_CAP_INT_PUNCHHOLE 0x00800000 +#define VOL_CAP_INT_BARRIERFSYNC 0x01000000 typedef struct vol_attributes_attr { attribute_set_t validattr; diff --git a/lib/libc/include/any-macos-any/sys/cdefs.h b/lib/libc/include/any-macos-any/sys/cdefs.h index f75cf88c4f..0b9bfb4c02 100644 --- a/lib/libc/include/any-macos-any/sys/cdefs.h +++ b/lib/libc/include/any-macos-any/sys/cdefs.h @@ -199,7 +199,16 @@ */ #define __exported __attribute__((__visibility__("default"))) #define __exported_push _Pragma("GCC visibility push(default)") +#ifndef __BUILDING_XNU_LIBRARY__ +#define __exported_push_hidden _Pragma("GCC visibility push(hidden)") #define __exported_pop _Pragma("GCC visibility pop") +#define __exported_hidden __private_extern__ +#else /* __BUILDING_XNU_LIBRARY__ */ +/* Don't hide symbols that the might be need to be used from outside */ +#define __exported_push_hidden +#define __exported_pop +#define __exported_hidden +#endif /* __BUILDING_XNU_LIBRARY__ */ /* __deprecated causes the compiler to produce a warning when encountering * code using the deprecated functionality. @@ -509,12 +518,14 @@ * for plain C (see also ). * * Attribute __unsafe_buffer_usage can be used to label functions that should be - * avoided as they may perform or otherwise introduce unsafe buffer - * manipulation operations. + * avoided as they may perform or otherwise introduce unsafe buffer manipulation + * operations. The attribute can also be attached to class/struct fields that + * are used in unsafe buffer manipulations. * - * Calls to such functions are flagged by -Wunsafe-buffer-usage, similarly to + * Calls to attribute annotated functions are flagged by -Wunsafe-buffer-usage, similar to * how unchecked buffer manipulation operations are flagged when observed - * by the compiler directly: + * by the compiler directly. Similarly, use of and assignment to the struct/class fields + * that have the attribute also get flagged by the compiler. * * // An unsafe function that needs to be avoided. * __unsafe_buffer_usage @@ -527,14 +538,30 @@ * int array[5]; * * // Direct unsafe buffer manipulation through subscript operator: - * array[idx] = 3; // warning [-Wunsafe-buffer-usage] + * array[idx] = 3; // warning: function introduces unsafe buffer manipulation [-Wunsafe-buffer-usage] * // Unsafe buffer manipulation through function foo(): - * foo(array, 5); // warning [-Wunsafe-buffer-usage] + * foo(array, 5); // warning: function introduces unsafe buffer manipulation [-Wunsafe-buffer-usage] * // Checked buffer manipulation, with bounds information automatically * // preserved for the purposes of runtime checks in standard library: * foo(array); // no warning * } * + * struct Reader { + * // Field involved in unsafe buffer manipulation + * __unsafe_buffer_usage + * void *ptr; + * + * __unsafe_buffer_usage + * size_t sz, count; + * }; + * + * void add_element(Reader rdr, int value) { + * if(rdr.count < rdr.sz) { // warning: unsafe buffer access [-Wunsafe-buffer-usage] + * rdr.ptr[rdr.count] = value; // warning: unsafe buffer access [-Wunsafe-buffer-usage] + * rdr.count++; // warning: unsafe buffer access [-Wunsafe-buffer-usage] + * } + * } + * * While annotating a function as __unsafe_buffer_usage has an effect similar * to annotating it as __deprecated, the __unsafe_buffer_usage attribute * should be used whenever the resulting warning needs to be controlled @@ -542,11 +569,12 @@ * don't attempt to achieve bounds safety this way) as opposed to -Wdeprecated * (enabled in most codebases). * - * The attribute does NOT suppress -Wunsafe-buffer-usage warnings inside - * the function's body; it simply introduces new warnings at each call site - * to help the developers avoid the function entirely. Most of the time - * it does not make sense to annotate a function as __unsafe_buffer_usage - * without providing the users with a safe alternative. + * The attribute suppresses all -Wunsafe-buffer-usage warnings inside the + * function's body as it is explictly marked as unsafe by the user and + * introduces new warnings at each call site to help the developers avoid the + * function entirely. Most of the time it does not make sense to annotate a + * function as __unsafe_buffer_usage without providing the users with a safe + * alternative. * * Pragmas __unsafe_buffer_usage_begin and __unsafe_buffer_usage_end * annotate a range of code as intentionally containing unsafe buffer @@ -560,9 +588,7 @@ * * These pragmas are NOT a way to mass-annotate functions with the attribute * __unsafe_buffer_usage. Functions declared within the pragma range - * do NOT get annotated automatically. In some rare situations it makes sense - * to do all three: put the attribute on the function, put pragmas inside - * the body of the function, and put pragmas around some call sites. + * do NOT get annotated automatically. */ #if __has_cpp_attribute(clang::unsafe_buffer_usage) #define __has_safe_buffers 1 diff --git a/lib/libc/include/any-macos-any/sys/clonefile.h b/lib/libc/include/any-macos-any/sys/clonefile.h index 5b34440fd5..5811ec03e1 100644 --- a/lib/libc/include/any-macos-any/sys/clonefile.h +++ b/lib/libc/include/any-macos-any/sys/clonefile.h @@ -30,10 +30,11 @@ #define _SYS_CLONEFILE_H_ /* Options for clonefile calls */ -#define CLONE_NOFOLLOW 0x0001 /* Don't follow symbolic links */ -#define CLONE_NOOWNERCOPY 0x0002 /* Don't copy ownership information from source */ -#define CLONE_ACL 0x0004 /* Copy access control lists from source */ -#define CLONE_NOFOLLOW_ANY 0x0008 /* Don't follow any symbolic links in the path */ +#define CLONE_NOFOLLOW 0x0001 /* Don't follow symbolic links */ +#define CLONE_NOOWNERCOPY 0x0002 /* Don't copy ownership information from source */ +#define CLONE_ACL 0x0004 /* Copy access control lists from source */ +#define CLONE_NOFOLLOW_ANY 0x0008 /* Don't follow any symbolic links in the path */ +#define CLONE_RESOLVE_BENEATH 0x0010 /* path must reside in the hierarchy beneath the starting directory */ #include diff --git a/lib/libc/include/any-macos-any/sys/errno.h b/lib/libc/include/any-macos-any/sys/errno.h index 0360a496f0..982aaa314c 100644 --- a/lib/libc/include/any-macos-any/sys/errno.h +++ b/lib/libc/include/any-macos-any/sys/errno.h @@ -260,7 +260,12 @@ __END_DECLS #if __DARWIN_C_LEVEL >= __DARWIN_C_FULL #define EQFULL 106 /* Interface output queue is full */ -#define ELAST 106 /* Must be equal largest errno */ +#endif + +#define ENOTCAPABLE 107 /* Capabilities insufficient */ + +#if __DARWIN_C_LEVEL >= __DARWIN_C_FULL +#define ELAST 107 /* Must be equal largest errno */ #endif #endif /* _SYS_ERRNO_H_ */ diff --git a/lib/libc/include/any-macos-any/sys/fcntl.h b/lib/libc/include/any-macos-any/sys/fcntl.h index 7f04f1ff12..efe063dfd5 100644 --- a/lib/libc/include/any-macos-any/sys/fcntl.h +++ b/lib/libc/include/any-macos-any/sys/fcntl.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000-2022 Apple Inc. All rights reserved. + * Copyright (c) 2000-2025 Apple Inc. All rights reserved. * * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ * @@ -126,6 +126,7 @@ #define O_TRUNC 0x00000400 /* truncate to zero length */ #define O_EXCL 0x00000800 /* error if already exists */ #define O_RESOLVE_BENEATH 0x00001000 /* only for open(2), same value as FMARK */ +#define O_UNIQUE 0x00002000 /* only for open(2), same value as FDEFER */ #if !defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE) @@ -181,6 +182,8 @@ #define AT_REALDEV 0x0200 /* Return real device inodes resides on for fstatat(2) */ #define AT_FDONLY 0x0400 /* Use only the fd and Ignore the path for fstatat(2) */ #define AT_SYMLINK_NOFOLLOW_ANY 0x0800 /* Path should not contain any symlinks */ +#define AT_RESOLVE_BENEATH 0x2000 /* Path must reside in the hierarchy beneath the starting directory */ +#define AT_NODELETEBUSY 0x4000 /* Don't delete busy files */ #endif #endif @@ -258,10 +261,8 @@ #define F_THAW_FS 54 /* "thaw" all fs operations */ #define F_GLOBAL_NOCACHE 55 /* turn data caching off/on (globally) for this file */ - #define F_ADDSIGS 59 /* add detached signatures */ - #define F_ADDFILESIGS 61 /* add signature from same file (used by dyld for shared libs) */ #define F_NODIRECT 62 /* used in conjunction with F_NOCACHE to indicate that DIRECT, synchonous writes */ @@ -282,7 +283,6 @@ /* See F_DUPFD_CLOEXEC below for 67 */ - #define F_SETBACKINGSTORE 70 /* Mark the file as being the backing store for another filesystem */ #define F_GETPATH_MTMINFO 71 /* return the full path of the FD, but error in specific mtmd circumstances */ @@ -300,10 +300,8 @@ #define F_FINDSIGS 78 /* Add detached code signatures (used by dyld for shared libs) */ - #define F_ADDFILESIGS_FOR_DYLD_SIM 83 /* Add signature from same file, only if it is signed by Apple (used by dyld for simulator) */ - #define F_BARRIERFSYNC 85 /* fsync + issue barrier to drive */ #if __DARWIN_C_LEVEL >= __DARWIN_C_FULL @@ -314,7 +312,6 @@ #define F_OFD_SETLKWTIMEOUT 93 /* (as F_OFD_SETLKW but return if timeout) */ #endif - #define F_ADDFILESIGS_RETURN 97 /* Add signature from same file, return end offset in structure on success */ #define F_CHECK_LV 98 /* Check if Library Validation allows this Mach-O file to be mapped into the calling process */ @@ -335,10 +332,10 @@ #define F_SETLEASE_ARG(t, oc) ((t) | ((oc) << 2)) - #define F_TRANSFEREXTENTS 110 /* Transfer allocated extents beyond leof to a different file */ #define F_ATTRIBUTION_TAG 111 /* Based on flags, query/set/delete a file's attribution tag */ +#define F_NOCACHE_EXT 112 /* turn data caching off/on for this fd and relax size and alignment restrictions for write */ #define F_ADDSIGS_MAIN_BINARY 113 /* add detached signatures for main binary -- development only */ @@ -359,7 +356,6 @@ #define F_UNLCK 2 /* unlock */ #define F_WRLCK 3 /* exclusive or write lock */ - /* * [XSI] The values used for l_whence shall be defined as described * in @@ -409,6 +405,7 @@ struct flocktimeout { struct flock fl; /* flock passed for file locking */ struct timespec timeout; /* timespec struct for timeout */ }; + #endif /* __DARWIN_C_LEVEL >= __DARWIN_C_FULL */ #if !defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE) @@ -521,7 +518,6 @@ typedef struct fspecread { off_t fsr_length; /* IN: size of the region */ } fspecread_t; - /* fattributiontag_t used by F_ATTRIBUTION_TAG */ #define ATTRIBUTION_NAME_MAX 255 typedef struct fattributiontag { @@ -573,7 +569,6 @@ struct log2phys { #define O_POPUP 0x80000000 /* force window to popup on open */ #define O_ALERT 0x20000000 /* small, clean popup window */ - #endif /* (_POSIX_C_SOURCE && !_DARWIN_C_SOURCE) */ @@ -628,4 +623,5 @@ int filesec_unset_property(filesec_t, filesec_property_t) __OSX_AVAILABLE_ST #endif /* (!_POSIX_C_SOURCE || _DARWIN_C_SOURCE) */ __END_DECLS + #endif /* !_SYS_FCNTL_H_ */ diff --git a/lib/libc/include/any-macos-any/sys/kern_control.h b/lib/libc/include/any-macos-any/sys/kern_control.h index 5dde92543a..da7bd7036b 100644 --- a/lib/libc/include/any-macos-any/sys/kern_control.h +++ b/lib/libc/include/any-macos-any/sys/kern_control.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000-2004, 2012-2016 Apple Inc. All rights reserved. + * Copyright (c) 2000-2004, 2012-2025 Apple Inc. All rights reserved. * * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ * diff --git a/lib/libc/include/any-macos-any/sys/mount.h b/lib/libc/include/any-macos-any/sys/mount.h index 23224f87d9..b414295d98 100644 --- a/lib/libc/include/any-macos-any/sys/mount.h +++ b/lib/libc/include/any-macos-any/sys/mount.h @@ -384,7 +384,8 @@ struct netfs_status { #define VQ_DESIRED_DISK 0x4000 /* the desired disk space */ #define VQ_FREE_SPACE_CHANGE 0x8000 /* free disk space has significantly changed */ #define VQ_PURGEABLE_SPACE_CHANGE 0x10000 /* purgeable disk space has significantly changed */ -#define VQ_FLAG20000 0x20000 /* placeholder */ +#define VQ_IDLE_PURGE_NOTIFY 0x20000 /* Above nearlowdisk and below desired disk space */ +#define VQ_FLAG40000 0x40000 /* placeholder */ @@ -413,7 +414,7 @@ OS_ENUM(graftdmg_type, uint32_t, GRAFTDMG_CRYPTEX_BOOT = 1, GRAFTDMG_CRYPTEX_PREBOOT = 2, GRAFTDMG_CRYPTEX_DOWNLEVEL = 3, - // Reserved: CRYPTEX1_AUTH_ENV_GENERIC = 4, + GRAFTDMG_CRYPTEX_AUTH_ENV_GENERIC = 4, // Reserved: CRYPTEX1_AUTH_ENV_GENERIC_SUPPLEMENTAL = 5, GRAFTDMG_CRYPTEX_PDI_NONCE = 6, GRAFTDMG_CRYPTEX_EFFECTIVE_AP = 7, @@ -459,6 +460,7 @@ int statfs(const char *, struct statfs *) __DARWIN_INODE64(statfs); int statfs64(const char *, struct statfs64 *) __OSX_AVAILABLE_BUT_DEPRECATED(__MAC_10_5, __MAC_10_6, __IPHONE_NA, __IPHONE_NA); #endif /* !__DARWIN_ONLY_64_BIT_INO_T */ int unmount(const char *, int); +int funmount(int, int) __OSX_AVAILABLE(16.0) __IOS_AVAILABLE(19.0) __TVOS_AVAILABLE(19.0) __WATCHOS_AVAILABLE(12.0); int getvfsbyname(const char *, struct vfsconf *); __END_DECLS diff --git a/lib/libc/include/any-macos-any/sys/paths.h b/lib/libc/include/any-macos-any/sys/paths.h index 3a2f1bb053..538330184f 100644 --- a/lib/libc/include/any-macos-any/sys/paths.h +++ b/lib/libc/include/any-macos-any/sys/paths.h @@ -40,5 +40,16 @@ #define _PATH_RSRCNAME "rsrc" #define _PATH_RSRCFORKSPEC "/..namedfork/rsrc" +/* Prefix Path Namespace */ +#define RESOLVE_NOFOLLOW_ANY 0x00000001 /* no symlinks allowed in path */ +#define RESOLVE_NODOTDOT 0x00000002 /* prevent '..' path traversal */ +#define RESOLVE_LOCAL 0x00000004 /* prevent a path lookup into a network filesystem */ +#define RESOLVE_NODEVFS 0x00000008 /* prevent a path lookup into `devfs` filesystem */ +#define RESOLVE_IMMOVABLE 0x00000010 /* prevent a path lookup into a removable filesystem */ +#define RESOLVE_UNIQUE 0x00000020 /* prevent a path lookup on a vnode with multiple links */ +#define RESOLVE_NOXATTRS 0x00000040 /* prevent a path lookup on named streams */ + +#define RESOLVE_VALIDMASK 0x0000007F + #endif /* __APPLE_API_PRIVATE */ #endif /* !_SYS_PATHS_H_ */ diff --git a/lib/libc/include/any-macos-any/sys/proc.h b/lib/libc/include/any-macos-any/sys/proc.h index 621ef3c0b2..97b710fd76 100644 --- a/lib/libc/include/any-macos-any/sys/proc.h +++ b/lib/libc/include/any-macos-any/sys/proc.h @@ -86,6 +86,7 @@ struct session; struct pgrp; struct proc; +struct proc_ident; /* Exported fields for kern sysctls */ struct extern_proc { diff --git a/lib/libc/include/any-macos-any/sys/proc_info.h b/lib/libc/include/any-macos-any/sys/proc_info.h index aa9a4e74c3..92b0ed2cc0 100644 --- a/lib/libc/include/any-macos-any/sys/proc_info.h +++ b/lib/libc/include/any-macos-any/sys/proc_info.h @@ -349,6 +349,11 @@ struct proc_threadwithpathinfo { struct vnode_info_path pvip; }; +struct proc_archinfo { + cpu_type_t p_cputype; + cpu_subtype_t p_cpusubtype; +}; + /* * Socket */ @@ -758,6 +763,9 @@ struct channel_fdinfo { #define PROC_PID_RUSAGE 16 #define PROC_PID_RUSAGE_SIZE 0 +#define PROC_PIDARCHINFO 19 +#define PROC_PIDARCHINFO_SIZE (sizeof(struct proc_archinfo)) + /* Flavors for proc_pidfdinfo */ #define PROC_PIDFDVNODEINFO 1 diff --git a/lib/libc/include/any-macos-any/sys/resource.h b/lib/libc/include/any-macos-any/sys/resource.h index 207e96120e..ca278157de 100644 --- a/lib/libc/include/any-macos-any/sys/resource.h +++ b/lib/libc/include/any-macos-any/sys/resource.h @@ -514,6 +514,7 @@ struct proc_rlimit_control_wakeupmon { #define IOPOL_TYPE_VFS_SKIP_MTIME_UPDATE 8 #define IOPOL_TYPE_VFS_ALLOW_LOW_SPACE_WRITES 9 #define IOPOL_TYPE_VFS_DISALLOW_RW_FOR_O_EVTONLY 10 +#define IOPOL_TYPE_VFS_ENTITLED_RESERVE_ACCESS 14 /* scope */ #define IOPOL_SCOPE_PROCESS 0 @@ -564,6 +565,9 @@ struct proc_rlimit_control_wakeupmon { #define IOPOL_VFS_NOCACHE_WRITE_FS_BLKSIZE_DEFAULT 0 #define IOPOL_VFS_NOCACHE_WRITE_FS_BLKSIZE_ON 1 +#define IOPOL_VFS_ENTITLED_RESERVE_ACCESS_OFF 0 +#define IOPOL_VFS_ENTITLED_RESERVE_ACCESS_ON 1 + #endif /* __DARWIN_C_LEVEL >= __DARWIN_C_FULL */ diff --git a/lib/libc/include/any-macos-any/sys/signal.h b/lib/libc/include/any-macos-any/sys/signal.h index e2d8b2b3f1..df70637097 100644 --- a/lib/libc/include/any-macos-any/sys/signal.h +++ b/lib/libc/include/any-macos-any/sys/signal.h @@ -164,6 +164,7 @@ union sigval { #define SIGEV_NONE 0 /* No async notification */ #define SIGEV_SIGNAL 1 /* aio - completion notification */ #define SIGEV_THREAD 3 /* [NOTIMP] [RTS] call notification function */ +#define SIGEV_KEVENT 4 /* Generate a kevent */ struct sigevent { int sigev_notify; /* Notification type */ diff --git a/lib/libc/include/any-macos-any/sys/stdio.h b/lib/libc/include/any-macos-any/sys/stdio.h index 1c747a42f4..2246da4939 100644 --- a/lib/libc/include/any-macos-any/sys/stdio.h +++ b/lib/libc/include/any-macos-any/sys/stdio.h @@ -37,6 +37,7 @@ #define RENAME_EXCL 0x00000004 #define RENAME_RESERVED1 0x00000008 #define RENAME_NOFOLLOW_ANY 0x00000010 +#define RENAME_RESOLVE_BENEATH 0x00000020 #endif #if __DARWIN_C_LEVEL >= 200809L diff --git a/lib/libc/include/any-macos-any/sys/sysctl.h b/lib/libc/include/any-macos-any/sys/sysctl.h index 1618902ef5..066a21a663 100644 --- a/lib/libc/include/any-macos-any/sys/sysctl.h +++ b/lib/libc/include/any-macos-any/sys/sysctl.h @@ -154,7 +154,8 @@ struct ctlname { #define CTLFLAG_KERN 0x01000000 /* valid inside the kernel */ #define CTLFLAG_LOCKED 0x00800000 /* node will handle locking itself */ #define CTLFLAG_OID2 0x00400000 /* struct sysctl_oid has version info */ -#define CTLFLAG_EXPERIMENT 0x00100000 /* Allows writing w/ the trial experiment entitlement. */ +#define CTLFLAG_EXPERIMENT 0x00100000 /* Allows read/write w/ the trial experiment entitlement. */ +#define CTLFLAG_LEGACY_EXPERIMENT 0x00080000 /* Allows writing w/ the legacy trial experiment entitlement. */ /* * USE THIS instead of a hardwired number from the categories below diff --git a/lib/libc/include/any-macos-any/unistd.h b/lib/libc/include/any-macos-any/unistd.h index 21142adf17..1aadc42c0e 100644 --- a/lib/libc/include/any-macos-any/unistd.h +++ b/lib/libc/include/any-macos-any/unistd.h @@ -72,7 +72,15 @@ #include <_types.h> #include #include +#define _LIBC_COUNT__PATH_MAX _LIBC_UNSAFE_INDEXABLE +#if (!defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE)) +#if defined(__LIBC_STAGED_BOUNDS_SAFETY_ATTRIBUTES) && __has_ptrcheck +/* required for bounds annotations, but pollutes namespace */ #include +#undef _LIBC_COUNT__PATH_MAX +#define _LIBC_COUNT__PATH_MAX _LIBC_COUNT_OR_NULL(PATH_MAX) +#endif /* defined(__LIBC_STAGED_BOUNDS_SAFETY_ATTRIBUTES) && __has_ptrcheck */ +#endif /* (!_POSIX_C_SOURCE || _DARWIN_C_SOURCE) */ #include #include #include @@ -517,8 +525,6 @@ extern int optind, opterr, optopt; __END_DECLS #endif /* __DARWIN_C_LEVEL >= 199209L */ - - /* Additional functionality provided by: * POSIX.1c-1995, * POSIX.1i-1995, @@ -526,7 +532,6 @@ __END_DECLS */ #if __DARWIN_C_LEVEL >= 199506L -#include <_ctermid.h> /* These F_* are really XSI or Issue 6 */ #define F_ULOCK 0 /* unlock locked section */ #define F_LOCK 1 /* lock a section for exclusive use */ @@ -536,6 +541,11 @@ __END_DECLS __BEGIN_DECLS /* Begin XSI */ +/* Removed in Issue 7 */ +#if !defined(_POSIX_C_SOURCE) || _POSIX_C_SOURCE < 200809L +#include <_ctermid.h> +#endif + /* Removed in Issue 6 */ #if !defined(_POSIX_C_SOURCE) || _POSIX_C_SOURCE < 200112L #if !defined(_POSIX_C_SOURCE) @@ -565,7 +575,7 @@ char *_LIBC_CSTR getpass(const char *) __POSIX_C_DEPRECATED(199506L); /* Removed in Issue 7 */ #if !defined(_POSIX_C_SOURCE) || _POSIX_C_SOURCE < 200809L -char *_LIBC_CSTR getwd(char *_LIBC_COUNT_OR_NULL(PATH_MAX)) __POSIX_C_DEPRECATED(200112L); /* obsoleted by getcwd() */ +char *_LIBC_CSTR getwd(char *_LIBC_COUNT__PATH_MAX) __POSIX_C_DEPRECATED(200112L); /* obsoleted by getcwd() */ #endif int lchown(const char *, uid_t, gid_t) __DARWIN_ALIAS(lchown); diff --git a/lib/libc/include/any-macos-any/xpc/base.h b/lib/libc/include/any-macos-any/xpc/base.h index 493818131f..0e8cb37869 100644 --- a/lib/libc/include/any-macos-any/xpc/base.h +++ b/lib/libc/include/any-macos-any/xpc/base.h @@ -93,8 +93,10 @@ __BEGIN_DECLS #if defined(__XPC_TEST__) && __XPC_TEST__ #define XPC_TESTSTATIC #define XPC_TESTEXTERN extern +#define XPC_TESTNORETURN #else // defined(__XPC_TEST__) && __XPC_TEST__ #define XPC_TESTSTATIC static +#define XPC_TESTNORETURN XPC_NORETURN #endif // defined(__XPC_TEST__) && __XPC_TEST__ #if __has_feature(objc_arc) @@ -242,6 +244,8 @@ __BEGIN_DECLS #define XPC_SWIFT_UNAVAILABLE(msg) __swift_unavailable(msg) #define XPC_SWIFT_NOEXPORT XPC_SWIFT_UNAVAILABLE("Unavailable in Swift from the XPC C Module") +#define XPC_SWIFT_SENDABLE __attribute__((__swift_attr__("@Sendable"))) + __END_DECLS #endif // __XPC_BASE_H__ diff --git a/lib/libc/include/any-macos-any/xpc/connection.h b/lib/libc/include/any-macos-any/xpc/connection.h index 36f20bae9c..f27937bdb4 100644 --- a/lib/libc/include/any-macos-any/xpc/connection.h +++ b/lib/libc/include/any-macos-any/xpc/connection.h @@ -141,8 +141,8 @@ typedef void (*xpc_finalizer_t)(void * _Nullable value); * The GCD queue to which the event handler block will be submitted. This * parameter may be NULL, in which case the connection's target queue will be * libdispatch's default target queue, defined as DISPATCH_TARGET_QUEUE_DEFAULT. - * The target queue may be changed later with a call to - * xpc_connection_set_target_queue(). + * The target queue may be changed prior to the connection being activated with + * a call to xpc_connection_set_target_queue(). * * @result * A new connection object. The caller is responsible for disposing of the @@ -178,8 +178,8 @@ xpc_connection_create(const char * _Nullable name, * The GCD queue to which the event handler block will be submitted. This * parameter may be NULL, in which case the connection's target queue will be * libdispatch's default target queue, defined as DISPATCH_TARGET_QUEUE_DEFAULT. - * The target queue may be changed later with a call to - * xpc_connection_set_target_queue(). + * The target queue may be changed prior to the connection being activated with + * a call to xpc_connection_set_target_queue(). * * @param flags * Additional attributes with which to create the connection. @@ -240,14 +240,11 @@ xpc_connection_create_from_endpoint(xpc_endpoint_t endpoint); * libdispatch's default target queue, defined as DISPATCH_TARGET_QUEUE_DEFAULT. * * @discussion - * Setting the target queue is asynchronous and non-preemptive and therefore - * this method will not interrupt the execution of an already-running event - * handler block. Setting the target queue may be likened to issuing a barrier - * to the connection which does the actual work of changing the target queue. + * Once a connection is activated, this method may no longer be called and the + * target queue may no longer be updated. * - * The XPC runtime guarantees this non-preemptiveness even for concurrent target - * queues. If the target queue is a concurrent queue, then XPC still guarantees - * that there will never be more than one invocation of the connection's event + * Even if the target queue is a concurrent queue, XPC still guarantees that + * there will never be more than one invocation of the connection's event * handler block executing concurrently. If you wish to process events * concurrently, you can dispatch_async(3) to a concurrent queue from within * the event handler. @@ -330,7 +327,7 @@ __OSX_AVAILABLE_STARTING(__MAC_10_7, __IPHONE_5_0) XPC_EXPORT XPC_NONNULL_ALL void xpc_connection_set_event_handler(xpc_connection_t connection, - xpc_handler_t handler); + XPC_SWIFT_SENDABLE xpc_handler_t handler); /*! * @function xpc_connection_activate @@ -534,7 +531,7 @@ XPC_EXPORT XPC_NONNULL1 XPC_NONNULL2 XPC_NONNULL4 void xpc_connection_send_message_with_reply(xpc_connection_t connection, xpc_object_t message, dispatch_queue_t _Nullable replyq, - xpc_handler_t handler); + XPC_SWIFT_SENDABLE xpc_handler_t handler); /*! * @function xpc_connection_send_message_with_reply_sync @@ -983,6 +980,33 @@ XPC_EXPORT XPC_NONNULL_ALL XPC_WARN_RESULT int xpc_connection_set_peer_lightweight_code_requirement(xpc_connection_t connection, xpc_object_t lwcr); +/*! + * @function xpc_connection_set_peer_requirement + * Requires that the connection peer has the specified requirement + * + * @param connection + * The connection object which is to be modified + * + * @param peer_requirement + * The requirement the peer must have + * It is safe to deallocate the peer requirement after calling `xpc_connection_set_peer_requirement` + * + * @discussion + * It is a programming error to call multiple of the `xpc_connection_set_peer_*_requirement` family of functions on the same + * connection. If more complex combinations of requirements are required, use lightweight code requirement. + * + * All messages received on this connection will be checked to ensure that they come from a peer who satisfies the + * requirement. For a listener connection, requests that do not satisfy the requirement are dropped. When a reply + * is expected on the connection and the peer does not satisfy the requirement `XPC_ERROR_PEER_CODE_SIGNING_REQUIREMENT` + * will be delivered instead of the reply. + */ +API_AVAILABLE(macos(26.0), ios(26.0)) +API_UNAVAILABLE(tvos, watchos) +XPC_EXPORT XPC_SWIFT_NOEXPORT XPC_NONNULL_ALL +void +xpc_connection_set_peer_requirement(xpc_connection_t connection, + xpc_peer_requirement_t peer_requirement); + /*! * @function xpc_connection_copy_invalidation_reason * Returns a description of why the connection was invalidated. diff --git a/lib/libc/include/any-macos-any/xpc/listener.h b/lib/libc/include/any-macos-any/xpc/listener.h index 6cf34d2c82..b956ae0941 100644 --- a/lib/libc/include/any-macos-any/xpc/listener.h +++ b/lib/libc/include/any-macos-any/xpc/listener.h @@ -24,7 +24,7 @@ __BEGIN_DECLS * connect to the server * */ -OS_OBJECT_DECL_CLASS(xpc_listener); +OS_OBJECT_DECL_SENDABLE_CLASS(xpc_listener); #pragma mark Constants /*! @@ -202,19 +202,22 @@ xpc_listener_reject_peer(xpc_session_t peer, const char *reason); * The listener object which is to be modified. * * @param requirement - * The code signing requirement to be satisfied by the peer - * It is safe to deallocate the requirement string after calling `xpc_listener_set_peer_code_signing_requirement` + * The code signing requirement to be satisfied by the peer. It is safe to + * deallocate the requirement string after calling this function. * * @result * 0 on success, non-zero on error * * @discussion - * This function will return an error promptly if the code signing requirement string is invalid. + * This function will return an error promptly if the code signing requirement + * string is invalid. * - * It is a programming error to call `xpc_listener_set_peer_code_signing_requirement` more than once per listener. + * It is a programming error to call `xpc_listener_set_peer_*requirement` more + * than once per listener. * - * All messages received on this listener will be checked to ensure they come from a peer who satisfies - * the code signing requirement. Requests that do not satisfy the requirement are dropped. + * All messages received on this listener will be checked to ensure they come + * from a peer who satisfies the code signing requirement. Requests that do not + * satisfy the requirement are dropped. * * @see https://developer.apple.com/documentation/technotes/tn3127-inside-code-signing-requirements */ @@ -224,6 +227,32 @@ XPC_EXPORT XPC_NONNULL_ALL XPC_WARN_RESULT int xpc_listener_set_peer_code_signing_requirement(xpc_listener_t listener, const char *requirement); +/*! + * @function xpc_listener_set_peer_requirement + * Requires that the listener peer satisfies a requirement. + * + * @param listener + * The listener object which is to be modified. Must be inactive. + * + * @param requirement + * The requirement to be satisfied by the peer. It will be retained by XPC. + * + * @discussion + * It is a programming error to call `xpc_listener_set_peer_*requirement` more + * than once per listener. + * + * All messages received on this listener will be checked to ensure they come + * from a peer who satisfies the code signing requirement. Requests that do not + * satisfy the requirement are dropped. + * + * Peer sessions created from the listener do not inherit the requirement. + */ +API_AVAILABLE(macos(26.0), ios(26.0)) +API_UNAVAILABLE(tvos, watchos) +XPC_EXPORT XPC_SWIFT_NOEXPORT XPC_NONNULL_ALL +void +xpc_listener_set_peer_requirement(xpc_listener_t listener, xpc_peer_requirement_t requirement); + __END_DECLS XPC_ASSUME_NONNULL_END diff --git a/lib/libc/include/any-macos-any/xpc/peer_requirement.h b/lib/libc/include/any-macos-any/xpc/peer_requirement.h new file mode 100644 index 0000000000..36d4bb1519 --- /dev/null +++ b/lib/libc/include/any-macos-any/xpc/peer_requirement.h @@ -0,0 +1,242 @@ +#ifndef __XPC_PEER_REQ_H__ +#define __XPC_PEER_REQ_H__ + +#ifndef __XPC_INDIRECT__ +#error "Please #include instead of this file directly." +// For HeaderDoc. +#include +#endif // __XPC_INDIRECT__ + +XPC_ASSUME_NONNULL_BEGIN +__BEGIN_DECLS + +XPC_SWIFT_NOEXPORT +/*! + * @typedef xpc_peer_requirement_t + * + * @abstract + * XPC peer requirement is an abstract type that represents a validated + * requirement on peers. + * + * @discussion + * Users can specify a requirement via `xpc_peer_requirement_create_*` API. + * These constructors will return a non-null xpc_peer_requirement_t if the + * requirement is valid. Users can set a xpc_peer_requirement_t on connections, + * sessions or listeners using one of `xpc_*_set_peer_requirement` API. + * + * xpc_peer_requirement_t is reference counted and concurrency-safe. One + * xpc_peer_requirement_t can be shared among multiple connections, sessions + * or listeners. + */ +OS_OBJECT_DECL_CLASS(xpc_peer_requirement); + +#pragma mark Constructors + +/*! + * @function xpc_peer_requirement_create_entitlement_exists + * Create a requirement that the peer has the specified entitlement + * + * @param entitlement + * The entitlement the peer must have. It is safe to deallocate the entitlement + * string after calling this function. + * + * @param error_out + * An out-parameter that, if set and in the event of an error, will point to an + * {@link xpc_rich_error_t} describing the details of any errors that occurred. + * + * @result + * On success this returns a new peer requirement object. On failure this will + * return NULL and if set, error_out will be set to an error describing the + * failure. + * + * @discussion + * This function will return NULL promptly if the entitlement requirement is + * invalid. + */ +API_AVAILABLE(macos(26.0), ios(26.0)) +API_UNAVAILABLE(tvos, watchos) +XPC_EXPORT XPC_SWIFT_NOEXPORT XPC_RETURNS_RETAINED +xpc_peer_requirement_t _Nullable +xpc_peer_requirement_create_entitlement_exists(const char *entitlement, + xpc_rich_error_t _Nullable XPC_GIVES_REFERENCE * _Nullable error_out); + +/*! + * @function xpc_peer_requirement_create_entitlement_matches_value + * Create a requirement that the peer has the entitlement with matching value + * + * @param entitlement + * The entitlement the peer must have. It is safe to deallocate the entitlement + * string after calling this function. + * + * @param value + * The value that the entitlement must match. It is safe to deallocate the value + * object after calling this function. Valid xpc types for this object are + * `XPC_TYPE_BOOL`, `XPC_TYPE_STRING` and `XPC_TYPE_INT64`. + * + * @param error_out + * An out-parameter that, if set and in the event of an error, will point to an + * {@link xpc_rich_error_t} describing the details of any errors that occurred. + * + * @result + * On success this returns a new peer requirement object. On failure this will + * return NULL and if set, error_out will be set to an error describing the + * failure. + * + * @discussion + * This function will return NULL promptly if the entitlement requirement is + * invalid. + */ +API_AVAILABLE(macos(26.0), ios(26.0)) +API_UNAVAILABLE(tvos, watchos) +XPC_EXPORT XPC_SWIFT_NOEXPORT XPC_RETURNS_RETAINED +xpc_peer_requirement_t _Nullable +xpc_peer_requirement_create_entitlement_matches_value(const char *entitlement, + xpc_object_t value, + xpc_rich_error_t _Nullable XPC_GIVES_REFERENCE * _Nullable error_out); + +/*! + * @function xpc_peer_requirement_create_team_identity + * Create a requirement that the peer has the specified identity and is signed + * with the same team identifier as the current process + * + * @param signing_identifier + * The optional signing identifier the peer must have. It is safe to deallocate + * the signing identifier string after calling this function. + * + * @param error_out + * An out-parameter that, if set and in the event of an error, will point to an + * {@link xpc_rich_error_t} describing the details of any errors that occurred. + * + * @result + * On success this returns a new peer requirement object. On failure this will + * return NULL and if set, error_out will be set to an error describing the + * failure. + * + * @discussion + * This function will return NULL promptly if the identity requirement is + * invalid. + * + * The peer process must be signed as either a Testflight app or an App store + * app, or be signed by an apple issued development certificate, an enterprise + * distributed certificate (embedded only), or a Developer ID certificate (macOS + * only) + */ +API_AVAILABLE(macos(26.0), ios(26.0)) +API_UNAVAILABLE(tvos, watchos) +XPC_EXPORT XPC_SWIFT_NOEXPORT XPC_RETURNS_RETAINED +xpc_peer_requirement_t _Nullable +xpc_peer_requirement_create_team_identity( + const char * _Nullable signing_identifier, + xpc_rich_error_t _Nullable XPC_GIVES_REFERENCE * _Nullable error_out); + +/*! + * @function xpc_peer_requirement_create_platform_identity + * Create a requirement that the peer has the specified identity and is from + * platform binary. + * + * @param signing_identifier + * The optional signing identifier the peer must have. If not specified, this + * function ensures that the peer process' executable is a platform binary. It + * is safe to deallocate the signing identifier string after calling this + * function. + * + * @param error_out + * An out-parameter that, if set and in the event of an error, will point to an + * {@link xpc_rich_error_t} describing the details of any errors that occurred. + * + * @result + * On success this returns a new peer requirement object. On failure this will + * return NULL and if set, error_out will be set to an error describing the + * failure. + * + * @discussion + * This function will return NULL promptly if the identity requirement is + * invalid. + */ +API_AVAILABLE(macos(26.0), ios(26.0)) +API_UNAVAILABLE(tvos, watchos) +XPC_EXPORT XPC_SWIFT_NOEXPORT XPC_RETURNS_RETAINED +xpc_peer_requirement_t _Nullable +xpc_peer_requirement_create_platform_identity( + const char * _Nullable signing_identifier, + xpc_rich_error_t _Nullable XPC_GIVES_REFERENCE * _Nullable error_out); + +/*! + * @function xpc_peer_requirement_create_lwcr + * Create a requirement that the peer has the specified lightweight code requirement + * + * @param lwcr + * The lightweight code requirement the peer must have. It is safe to deallocate + * the lightweight code requirement object after calling this function. + * + * @param error_out + * An out-parameter that, if set and in the event of an error, will point to an + * {@link xpc_rich_error_t} describing the details of any errors that occurred. + * + * @result + * On success this returns a new peer requirement object. On failure this will + * return NULL and if set, error_out will be set to an error describing the + * failure. + * + * @discussion + * This function will return NULL promptly if the lightweight code requirement + * is invalid. + * + * The lightweight code requirement must be an `xpc_dictionary_t` equivalent of + * an LWCR constraint (see + * https://developer.apple.com/documentation/security/defining_launch_environment_and_library_constraints + * for details on the contents of the dictionary) + * + * The lightweight code requirement in the example below uses the $or operator + * to require that an executable’s either signed with the Team ID 8XCUU22SN2, or + * is an operating system executable: + * ```c + * xpc_object_t or_val = xpc_dictionary_create_empty(); + * xpc_dictionary_set_string(or_val, "team-identifier", "8XCUU22SN2"); + * xpc_dictionary_set_int64(or_val, "validation-category", 1); + * + * xpc_object_t lwcr = xpc_dictionary_create_empty(); + * xpc_dictionary_set_value(lwcr, "$or", or_val); + * + * xpc_peer_requirement_t req = xpc_peer_requirement_create_lwcr(lwcr, NULL); + * ``` + */ +API_AVAILABLE(macos(26.0), ios(26.0)) +API_UNAVAILABLE(tvos, watchos) +XPC_EXPORT XPC_SWIFT_NOEXPORT XPC_RETURNS_RETAINED +xpc_peer_requirement_t _Nullable +xpc_peer_requirement_create_lwcr(xpc_object_t lwcr, + xpc_rich_error_t _Nullable XPC_GIVES_REFERENCE * _Nullable error_out); + +#pragma mark Matching Peer Requirement on Received Messages + +/*! + * @function xpc_peer_requirement_match_received_message + * Check the specified requirement against a received message from the peer. + * + * @param peer_requirement + * The requirement the peer must have + * + * @param message + * The received dictionary to be checked + * + * @param error_out + * An out-parameter that, if set and in the event of an error, will point to an + * {@link xpc_rich_error_t} describing the details of any errors that occurred. + * + * @result + * On match this returns true. On mismatch or failure this will return false and + * if set, error_out will be set to an error describing the failure. + */ +API_AVAILABLE(macos(26.0), ios(26.0)) +API_UNAVAILABLE(tvos, watchos) +XPC_EXPORT XPC_SWIFT_NOEXPORT +bool +xpc_peer_requirement_match_received_message(xpc_peer_requirement_t peer_requirement, + xpc_object_t message, + xpc_rich_error_t _Nullable XPC_GIVES_REFERENCE * _Nullable error_out); + +__END_DECLS +XPC_ASSUME_NONNULL_END + +#endif diff --git a/lib/libc/include/any-macos-any/xpc/session.h b/lib/libc/include/any-macos-any/xpc/session.h index 0bb268a9ca..fe5293db7f 100644 --- a/lib/libc/include/any-macos-any/xpc/session.h +++ b/lib/libc/include/any-macos-any/xpc/session.h @@ -25,8 +25,11 @@ __BEGIN_DECLS * Clients can initiate a session with a service that accepts xpc_connection_t connections but session * semantics will be maintained. * + * Sessions can be created in an active or inactive state. They must be + * activated and subsequently cancelled before they can be released. + * */ -OS_OBJECT_DECL_CLASS(xpc_session); +OS_OBJECT_DECL_SENDABLE_CLASS(xpc_session); #pragma mark Constants /*! @@ -244,8 +247,8 @@ xpc_session_set_target_queue(xpc_session_t session, * * @discussion * xpc_session_activate must not be called on a session that has been already - * activated. Releasing the last reference on an inactive session that was - * created with an xpc_session_create*() will trigger an API misuse crash. + * activated. Releasing the last reference on an inactive session or an + * active session that has not been cancelled will trigger an API misuse crash. * * If activation fails, the session is automatically cancelled. */ @@ -266,8 +269,9 @@ xpc_session_activate(xpc_session_t session, * The session object to cancel. * * @discussion - * Session must have been activated to be canceled. Cancellation is asynchronous - * and non-preemptive. + * Session must have been activated to be cancelled and must be cancelled + * before the last reference can be released. Cancellation is asynchronous and + * non-preemptive. */ API_AVAILABLE(macos(13.0), ios(16.0), tvos(16.0), watchos(9.0)) XPC_EXPORT XPC_SWIFT_NOEXPORT @@ -388,20 +392,26 @@ xpc_session_send_message_with_reply_async(xpc_session_t session, * The session object which is to be modified. * * @param requirement - * The code signing requirement to be satisfied by the peer - * It is safe to deallocate the requirement string after calling `xpc_session_set_peer_code_signing_requirement` + * The code signing requirement to be satisfied by the peer. It is safe to + * deallocate the requirement string after calling this function. * * @result * 0 on success, non-zero on error * * @discussion - * This function will return an error promptly if the code signing requirement string is invalid. + * This function will return an error promptly if the code signing requirement + * string is invalid. * - * It is a programming error to call `xpc_session_set_peer_code_signing_requirement` more than once per session. + * It is a programming error to call `xpc_session_set_peer_*requirement` more + * than once per session. * - * All messages received on this session will be checked to ensure they come from a peer who satisfies - * the code signing requirement. When message or a reply is received on the session and the peer does - * not satisfy the requirement the session will be cancelled. + * All messages received on this session will be checked to ensure they come + * from a peer who satisfies the code signing requirement. When message or a + * reply is received on the session and the peer does not satisfy the + * requirement the session will be cancelled. A rich error describing the peer + * code signing error will be passed to the cancellation handler. For + * `xpc_session_send_message_with_reply_*` NULL will be returned instead of + * reply, with `error_out` pointing to that rich error. * * @see https://developer.apple.com/documentation/technotes/tn3127-inside-code-signing-requirements */ @@ -411,6 +421,34 @@ XPC_EXPORT XPC_NONNULL_ALL XPC_WARN_RESULT int xpc_session_set_peer_code_signing_requirement(xpc_session_t session, const char *requirement); +/*! + * @function xpc_session_set_peer_requirement + * Requires that the session peer satisfies a requirement. + * + * @param session + * The session object which is to be modified. Must be inactive. + * + * @param requirement + * The requirement to be satisfied by the peer. It will be retained by XPC. + * + * @discussion + * It is a programming error to call `xpc_session_set_peer_*requirement` more + * than once per session. + * + * All messages received on this session will be checked to ensure they come + * from a peer who satisfies the requirement. When a reply is expected on the + * session and the peer does not satisfy the requirement, the session will be + * canceled with cancellation handler called with a rich error describing the + * peer code signing error. For `xpc_session_send_message_with_reply_sync` NULL + * will be returned instead of reply, with `error_out` (if set) pointing to the + * rich error describing the peer code signing error. + */ +API_AVAILABLE(macos(26.0), ios(26.0)) +API_UNAVAILABLE(tvos, watchos) +XPC_EXPORT XPC_SWIFT_NOEXPORT XPC_NONNULL_ALL +void +xpc_session_set_peer_requirement(xpc_session_t session, xpc_peer_requirement_t requirement); + /* This is included for compatibility and should not be used in new code */ #define XPC_TYPE_SESSION (&_xpc_type_session) XPC_EXPORT diff --git a/lib/libc/include/any-macos-any/xpc/xpc.h b/lib/libc/include/any-macos-any/xpc/xpc.h index 83742c6f01..771e555347 100644 --- a/lib/libc/include/any-macos-any/xpc/xpc.h +++ b/lib/libc/include/any-macos-any/xpc/xpc.h @@ -344,6 +344,7 @@ XPC_ASSUME_NONNULL_END #include #if __BLOCKS__ #include +#include #include #include #include @@ -2771,7 +2772,7 @@ API_UNAVAILABLE(ios) XPC_EXPORT XPC_NONNULL1 XPC_NONNULL3 void xpc_set_event_stream_handler(const char *stream, - dispatch_queue_t _Nullable targetq, xpc_handler_t handler); + dispatch_queue_t _Nullable targetq, XPC_SWIFT_SENDABLE xpc_handler_t handler); #endif // __BLOCKS__ __END_DECLS