Skip to content
Trap Mach#-25

svc · mach trap -25

_kernelrpc_mach_port_destruct_trap

Point d'entrée trap qui implémente mach_port_destruct — détruit un port créé avec mach_port_construct en validant la garde.

Prototype

kern_return_t _kernelrpc_mach_port_destruct_trap(/* 4 args */);

Retour: kern_return_t

Historique des versions

XNU tagmacOS#
xnu-2422.115.4macOS 10.9 Mavericks-25
xnu-2782.40.9macOS 10.10 Yosemite-25
xnu-3247.1.106macOS 10.11 El Capitan-25
xnu-3789.1.32macOS 10.12 Sierra-25
xnu-4570.1.46macOS 10.13 High Sierra-25
xnu-4903.221.2macOS 10.14 Mojave-25
xnu-6153.11.26macOS 10.15 Catalina-25
xnu-7195.50.7.100.1macOS 11.0 Big Sur-25
xnu-8019.41.5macOS 12.0 Monterey-25
xnu-8792.41.9macOS 13.0 Ventura-25
xnu-10002.1.13macOS 14.0 Sonoma-25
xnu-11215.1.10macOS 15.0 Sequoia-25
xnu-11417.101.15macOS 15.4 Sequoia-25
xnu-12377.1.9macOS 26.0 Tahoe-25
xnu-10002.41.9-25
xnu-10002.61.3-25
xnu-10002.81.5-25
xnu-10063.101.15-25
xnu-10063.121.3-25
xnu-10063.141.1-25
xnu-11215.41.3-25
xnu-11215.61.5-25
xnu-11215.81.4-25
xnu-11417.121.6-25
xnu-11417.140.69-25
xnu-12377.101.15-25
xnu-12377.41.6-25
xnu-12377.61.12-25
xnu-12377.81.4-25
xnu-2422.1.72-25
xnu-2422.100.13-25
xnu-2422.110.17-25
xnu-2422.90.20-25
xnu-2782.1.97-25
xnu-2782.10.72-25
xnu-2782.20.48-25
xnu-2782.30.5-25
xnu-3247.10.11-25
xnu-3248.20.55-25
xnu-3248.30.4-25
xnu-3248.40.184-25
xnu-3248.50.21-25
xnu-3248.60.10-25
xnu-3789.21.4-25
xnu-3789.31.2-25
xnu-3789.41.3-25
xnu-3789.51.2-25
xnu-3789.60.24-25
xnu-3789.70.16-25
xnu-4570.20.62-25
xnu-4570.31.3-25
xnu-4570.41.2-25
xnu-4570.51.1-25
xnu-4570.61.1-25
xnu-4570.71.2-25
xnu-4903.231.4-25
xnu-4903.241.1-25
xnu-4903.270.47-25
xnu-6153.101.6-25
xnu-6153.121.1-25
xnu-6153.141.1-25
xnu-6153.41.3-25
xnu-6153.61.1-25
xnu-6153.81.5-25
xnu-7195.101.1-25
xnu-7195.121.3-25
xnu-7195.141.2-25
xnu-7195.60.75-25
xnu-7195.81.3-25
xnu-8019.61.5-25
xnu-8019.80.24-25
xnu-8020.101.4-25
xnu-8020.121.3-25
xnu-8020.140.41-25
xnu-8792.61.2-25
xnu-8792.81.2-25
xnu-8796.101.5-25
xnu-8796.121.2-25
xnu-8796.141.3-25

Notes

destruct est le teardown apparié de construct : l'appelant fournit la valeur de garde initialement utilisée (ou 0 si non gardé) plus un delta à appliquer au refcount du send right avant de détruire le receive right. Une garde incorrecte lève EXC_GUARD avec kGUARD_EXC_DESTROY, comme un échec de canary de pile abat l'exécution. Cela fait des ports gardés une primitive anti-confusion forte : si du code attaquant dans le même task réutilise un nom sans connaître la garde, le processus crashe immédiatement au lieu de corrompre silencieusement l'état IPC.

Détection

Sonde DTrace mach_trap uniquement. Le subtype EXC_GUARD kGUARD_EXC_DESTROY dans les logs ReportCrash signale une tentative de destruct avec garde incorrecte — utile pour détecter des bugs comme pour attraper des primitives d'exploitation qui ne connaissaient pas tout à fait le token de garde.

API associées

_kernelrpc_mach_port_construct_trap_kernelrpc_mach_port_guard_trap_kernelrpc_mach_port_unguard_trapmach_port_destruct