svc · mach trap -41
_kernelrpc_mach_port_guard_trap
Point d'entrée trap qui implémente mach_port_guard — attache une valeur de garde 64 bits à un receive right pour que toute mauvaise utilisation déclenche EXC_GUARD.
Prototype
kern_return_t _kernelrpc_mach_port_guard_trap(/* 4 args */);Retour: kern_return_t
Historique des versions
| XNU tag | macOS | # |
|---|---|---|
| xnu-2422.115.4 | macOS 10.9 Mavericks | -41 |
| xnu-2782.40.9 | macOS 10.10 Yosemite | -41 |
| xnu-3247.1.106 | macOS 10.11 El Capitan | -41 |
| xnu-3789.1.32 | macOS 10.12 Sierra | -41 |
| xnu-4570.1.46 | macOS 10.13 High Sierra | -41 |
| xnu-4903.221.2 | macOS 10.14 Mojave | -41 |
| xnu-6153.11.26 | macOS 10.15 Catalina | -41 |
| xnu-7195.50.7.100.1 | macOS 11.0 Big Sur | -41 |
| xnu-8019.41.5 | macOS 12.0 Monterey | -41 |
| xnu-8792.41.9 | macOS 13.0 Ventura | -41 |
| xnu-10002.1.13 | macOS 14.0 Sonoma | -41 |
| xnu-11215.1.10 | macOS 15.0 Sequoia | -41 |
| xnu-11417.101.15 | macOS 15.4 Sequoia | -41 |
| xnu-12377.1.9 | macOS 26.0 Tahoe | -41 |
| xnu-10002.41.9 | — | -41 |
| xnu-10002.61.3 | — | -41 |
| xnu-10002.81.5 | — | -41 |
| xnu-10063.101.15 | — | -41 |
| xnu-10063.121.3 | — | -41 |
| xnu-10063.141.1 | — | -41 |
| xnu-11215.41.3 | — | -41 |
| xnu-11215.61.5 | — | -41 |
| xnu-11215.81.4 | — | -41 |
| xnu-11417.121.6 | — | -41 |
| xnu-11417.140.69 | — | -41 |
| xnu-12377.101.15 | — | -41 |
| xnu-12377.41.6 | — | -41 |
| xnu-12377.61.12 | — | -41 |
| xnu-12377.81.4 | — | -41 |
| xnu-2422.1.72 | — | -41 |
| xnu-2422.100.13 | — | -41 |
| xnu-2422.110.17 | — | -41 |
| xnu-2422.90.20 | — | -41 |
| xnu-2782.1.97 | — | -41 |
| xnu-2782.10.72 | — | -41 |
| xnu-2782.20.48 | — | -41 |
| xnu-2782.30.5 | — | -41 |
| xnu-3247.10.11 | — | -41 |
| xnu-3248.20.55 | — | -41 |
| xnu-3248.30.4 | — | -41 |
| xnu-3248.40.184 | — | -41 |
| xnu-3248.50.21 | — | -41 |
| xnu-3248.60.10 | — | -41 |
| xnu-3789.21.4 | — | -41 |
| xnu-3789.31.2 | — | -41 |
| xnu-3789.41.3 | — | -41 |
| xnu-3789.51.2 | — | -41 |
| xnu-3789.60.24 | — | -41 |
| xnu-3789.70.16 | — | -41 |
| xnu-4570.20.62 | — | -41 |
| xnu-4570.31.3 | — | -41 |
| xnu-4570.41.2 | — | -41 |
| xnu-4570.51.1 | — | -41 |
| xnu-4570.61.1 | — | -41 |
| xnu-4570.71.2 | — | -41 |
| xnu-4903.231.4 | — | -41 |
| xnu-4903.241.1 | — | -41 |
| xnu-4903.270.47 | — | -41 |
| xnu-6153.101.6 | — | -41 |
| xnu-6153.121.1 | — | -41 |
| xnu-6153.141.1 | — | -41 |
| xnu-6153.41.3 | — | -41 |
| xnu-6153.61.1 | — | -41 |
| xnu-6153.81.5 | — | -41 |
| xnu-7195.101.1 | — | -41 |
| xnu-7195.121.3 | — | -41 |
| xnu-7195.141.2 | — | -41 |
| xnu-7195.60.75 | — | -41 |
| xnu-7195.81.3 | — | -41 |
| xnu-8019.61.5 | — | -41 |
| xnu-8019.80.24 | — | -41 |
| xnu-8020.101.4 | — | -41 |
| xnu-8020.121.3 | — | -41 |
| xnu-8020.140.41 | — | -41 |
| xnu-8792.61.2 | — | -41 |
| xnu-8792.81.2 | — | -41 |
| xnu-8796.101.5 | — | -41 |
| xnu-8796.121.2 | — | -41 |
| xnu-8796.141.3 | — | -41 |
Notes
Une fois gardé, le receive right ne peut être désalloué, détruit, modifié ni déplacé sans que l'appelant présente exactement le même token ; les non-correspondances déclenchent une exception kGUARD_EXC_* qui, en mode strict, termine le processus. libdispatch et libxpc gardent leurs ports mach internes pour que le code applicatif (ou un attaquant in-process) ne puisse les arracher au runtime, ni accidentellement ni délibérément. Le flag MPG_STRICT rend la garde fatale à toute violation ; sans lui, les non-correspondances renvoient simplement KERN_INVALID_ARGUMENT.
Détection
Sonde DTrace mach_trap uniquement. Les crashs EXC_GUARD avec des subtypes liés aux ports sont le signal de détection le plus bruyant — ils sont écrits dans ReportCrash et relayés via le sous-système unified log com.apple.xpc.