Skip to content
Syscall BSD#444

svc · unix #444

change_fdguard_np

Attache, retire ou fait tourner une valeur de garde sur un descripteur de fichier existant.

Prototype

int change_fdguard_np(int fd, const guardid_t *guard, u_int guardflags, const guardid_t *nguard, u_int nguardflags, int *fdflagsp);

Retour: int

Arguments

NameTypeDirDescription
fdint-
guardconst guardid_t-
guardflagsu_int-
nguardconst guardid_t-
nguardflagsu_int-
fdflagspint-

Historique des versions

XNU tagmacOS#
xnu-2422.115.4macOS 10.9 Mavericks444
xnu-2782.40.9macOS 10.10 Yosemite444
xnu-3247.1.106macOS 10.11 El Capitan444
xnu-3789.1.32macOS 10.12 Sierra444
xnu-4570.1.46macOS 10.13 High Sierra444
xnu-4903.221.2macOS 10.14 Mojave444
xnu-6153.11.26macOS 10.15 Catalina444
xnu-7195.50.7.100.1macOS 11.0 Big Sur444
xnu-8019.41.5macOS 12.0 Monterey444
xnu-8792.41.9macOS 13.0 Ventura444
xnu-10002.1.13macOS 14.0 Sonoma444
xnu-11215.1.10macOS 15.0 Sequoia444
xnu-11417.101.15macOS 15.4 Sequoia444
xnu-12377.1.9macOS 26.0 Tahoe444
xnu-10002.41.9444
xnu-10002.61.3444
xnu-10002.81.5444
xnu-10063.101.15444
xnu-10063.121.3444
xnu-10063.141.1444
xnu-11215.41.3444
xnu-11215.61.5444
xnu-11215.81.4444
xnu-11417.121.6444
xnu-11417.140.69444
xnu-12377.101.15444
xnu-12377.41.6444
xnu-12377.61.12444
xnu-12377.81.4444
xnu-2422.1.72444
xnu-2422.100.13444
xnu-2422.110.17444
xnu-2422.90.20444
xnu-2782.1.97444
xnu-2782.10.72444
xnu-2782.20.48444
xnu-2782.30.5444
xnu-3247.10.11444
xnu-3248.20.55444
xnu-3248.30.4444
xnu-3248.40.184444
xnu-3248.50.21444
xnu-3248.60.10444
xnu-3789.21.4444
xnu-3789.31.2444
xnu-3789.41.3444
xnu-3789.51.2444
xnu-3789.60.24444
xnu-3789.70.16444
xnu-4570.20.62444
xnu-4570.31.3444
xnu-4570.41.2444
xnu-4570.51.1444
xnu-4570.61.1444
xnu-4570.71.2444
xnu-4903.231.4444
xnu-4903.241.1444
xnu-4903.270.47444
xnu-6153.101.6444
xnu-6153.121.1444
xnu-6153.141.1444
xnu-6153.41.3444
xnu-6153.61.1444
xnu-6153.81.5444
xnu-7195.101.1444
xnu-7195.121.3444
xnu-7195.141.2444
xnu-7195.60.75444
xnu-7195.81.3444
xnu-8019.61.5444
xnu-8019.80.24444
xnu-8020.101.4444
xnu-8020.121.3444
xnu-8020.140.41444
xnu-8792.61.2444
xnu-8792.81.2444
xnu-8796.101.5444
xnu-8796.121.2444
xnu-8796.141.3444

Notes

Les fds gardés portent un cookie 64 bits qui doit être présenté à chaque opération ; les violations lèvent EXC_GUARD et terminent typiquement le processus. change_fdguard_np permet à un processus de promouvoir un fd ordinaire en gardé, d'échanger une garde pour une autre, ou de rétrograder. Les flags de la nouvelle garde (GUARD_CLOSE, GUARD_DUP, GUARD_FILEPORT, GUARD_WRITE) déterminent quelles opérations piégeront.

Détection

Les exceptions EXC_GUARD résultantes sont visibles à ReportCrash et à tout abonné au port d'exception Mach (CrashReporter, débogueurs, observateurs d'exceptions EDR). DTrace fbt::change_fdguard_np:entry est le point d'observation proactif.

API associées

guarded_close_npguarded_kqueue_npguarded_open_npguarded_pwrite_np