Mercurial > yakumo_izuru > aya
comparison vendor/golang.org/x/sys/unix/syscall_darwin.go @ 66:787b5ee0289d draft
Use vendored modules
Signed-off-by: Izuru Yakumo <yakumo.izuru@chaotic.ninja>
author | yakumo.izuru |
---|---|
date | Sun, 23 Jul 2023 13:18:53 +0000 |
parents | |
children | 4b79810863f6 |
comparison
equal
deleted
inserted
replaced
65:6d985efa0f7a | 66:787b5ee0289d |
---|---|
1 // Copyright 2009,2010 The Go Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style | |
3 // license that can be found in the LICENSE file. | |
4 | |
5 // Darwin system calls. | |
6 // This file is compiled as ordinary Go code, | |
7 // but it is also input to mksyscall, | |
8 // which parses the //sys lines and generates system call stubs. | |
9 // Note that sometimes we use a lowercase //sys name and wrap | |
10 // it in our own nicer implementation, either here or in | |
11 // syscall_bsd.go or syscall_unix.go. | |
12 | |
13 package unix | |
14 | |
15 import ( | |
16 "fmt" | |
17 "runtime" | |
18 "syscall" | |
19 "unsafe" | |
20 ) | |
21 | |
22 // SockaddrDatalink implements the Sockaddr interface for AF_LINK type sockets. | |
23 type SockaddrDatalink struct { | |
24 Len uint8 | |
25 Family uint8 | |
26 Index uint16 | |
27 Type uint8 | |
28 Nlen uint8 | |
29 Alen uint8 | |
30 Slen uint8 | |
31 Data [12]int8 | |
32 raw RawSockaddrDatalink | |
33 } | |
34 | |
35 // SockaddrCtl implements the Sockaddr interface for AF_SYSTEM type sockets. | |
36 type SockaddrCtl struct { | |
37 ID uint32 | |
38 Unit uint32 | |
39 raw RawSockaddrCtl | |
40 } | |
41 | |
42 func (sa *SockaddrCtl) sockaddr() (unsafe.Pointer, _Socklen, error) { | |
43 sa.raw.Sc_len = SizeofSockaddrCtl | |
44 sa.raw.Sc_family = AF_SYSTEM | |
45 sa.raw.Ss_sysaddr = AF_SYS_CONTROL | |
46 sa.raw.Sc_id = sa.ID | |
47 sa.raw.Sc_unit = sa.Unit | |
48 return unsafe.Pointer(&sa.raw), SizeofSockaddrCtl, nil | |
49 } | |
50 | |
51 // SockaddrVM implements the Sockaddr interface for AF_VSOCK type sockets. | |
52 // SockaddrVM provides access to Darwin VM sockets: a mechanism that enables | |
53 // bidirectional communication between a hypervisor and its guest virtual | |
54 // machines. | |
55 type SockaddrVM struct { | |
56 // CID and Port specify a context ID and port address for a VM socket. | |
57 // Guests have a unique CID, and hosts may have a well-known CID of: | |
58 // - VMADDR_CID_HYPERVISOR: refers to the hypervisor process. | |
59 // - VMADDR_CID_LOCAL: refers to local communication (loopback). | |
60 // - VMADDR_CID_HOST: refers to other processes on the host. | |
61 CID uint32 | |
62 Port uint32 | |
63 raw RawSockaddrVM | |
64 } | |
65 | |
66 func (sa *SockaddrVM) sockaddr() (unsafe.Pointer, _Socklen, error) { | |
67 sa.raw.Len = SizeofSockaddrVM | |
68 sa.raw.Family = AF_VSOCK | |
69 sa.raw.Port = sa.Port | |
70 sa.raw.Cid = sa.CID | |
71 | |
72 return unsafe.Pointer(&sa.raw), SizeofSockaddrVM, nil | |
73 } | |
74 | |
75 func anyToSockaddrGOOS(fd int, rsa *RawSockaddrAny) (Sockaddr, error) { | |
76 switch rsa.Addr.Family { | |
77 case AF_SYSTEM: | |
78 pp := (*RawSockaddrCtl)(unsafe.Pointer(rsa)) | |
79 if pp.Ss_sysaddr == AF_SYS_CONTROL { | |
80 sa := new(SockaddrCtl) | |
81 sa.ID = pp.Sc_id | |
82 sa.Unit = pp.Sc_unit | |
83 return sa, nil | |
84 } | |
85 case AF_VSOCK: | |
86 pp := (*RawSockaddrVM)(unsafe.Pointer(rsa)) | |
87 sa := &SockaddrVM{ | |
88 CID: pp.Cid, | |
89 Port: pp.Port, | |
90 } | |
91 return sa, nil | |
92 } | |
93 return nil, EAFNOSUPPORT | |
94 } | |
95 | |
96 // Some external packages rely on SYS___SYSCTL being defined to implement their | |
97 // own sysctl wrappers. Provide it here, even though direct syscalls are no | |
98 // longer supported on darwin. | |
99 const SYS___SYSCTL = SYS_SYSCTL | |
100 | |
101 // Translate "kern.hostname" to []_C_int{0,1,2,3}. | |
102 func nametomib(name string) (mib []_C_int, err error) { | |
103 const siz = unsafe.Sizeof(mib[0]) | |
104 | |
105 // NOTE(rsc): It seems strange to set the buffer to have | |
106 // size CTL_MAXNAME+2 but use only CTL_MAXNAME | |
107 // as the size. I don't know why the +2 is here, but the | |
108 // kernel uses +2 for its own implementation of this function. | |
109 // I am scared that if we don't include the +2 here, the kernel | |
110 // will silently write 2 words farther than we specify | |
111 // and we'll get memory corruption. | |
112 var buf [CTL_MAXNAME + 2]_C_int | |
113 n := uintptr(CTL_MAXNAME) * siz | |
114 | |
115 p := (*byte)(unsafe.Pointer(&buf[0])) | |
116 bytes, err := ByteSliceFromString(name) | |
117 if err != nil { | |
118 return nil, err | |
119 } | |
120 | |
121 // Magic sysctl: "setting" 0.3 to a string name | |
122 // lets you read back the array of integers form. | |
123 if err = sysctl([]_C_int{0, 3}, p, &n, &bytes[0], uintptr(len(name))); err != nil { | |
124 return nil, err | |
125 } | |
126 return buf[0 : n/siz], nil | |
127 } | |
128 | |
129 func direntIno(buf []byte) (uint64, bool) { | |
130 return readInt(buf, unsafe.Offsetof(Dirent{}.Ino), unsafe.Sizeof(Dirent{}.Ino)) | |
131 } | |
132 | |
133 func direntReclen(buf []byte) (uint64, bool) { | |
134 return readInt(buf, unsafe.Offsetof(Dirent{}.Reclen), unsafe.Sizeof(Dirent{}.Reclen)) | |
135 } | |
136 | |
137 func direntNamlen(buf []byte) (uint64, bool) { | |
138 return readInt(buf, unsafe.Offsetof(Dirent{}.Namlen), unsafe.Sizeof(Dirent{}.Namlen)) | |
139 } | |
140 | |
141 func PtraceAttach(pid int) (err error) { return ptrace(PT_ATTACH, pid, 0, 0) } | |
142 func PtraceDetach(pid int) (err error) { return ptrace(PT_DETACH, pid, 0, 0) } | |
143 | |
144 //sysnb pipe(p *[2]int32) (err error) | |
145 | |
146 func Pipe(p []int) (err error) { | |
147 if len(p) != 2 { | |
148 return EINVAL | |
149 } | |
150 var x [2]int32 | |
151 err = pipe(&x) | |
152 if err == nil { | |
153 p[0] = int(x[0]) | |
154 p[1] = int(x[1]) | |
155 } | |
156 return | |
157 } | |
158 | |
159 func Getfsstat(buf []Statfs_t, flags int) (n int, err error) { | |
160 var _p0 unsafe.Pointer | |
161 var bufsize uintptr | |
162 if len(buf) > 0 { | |
163 _p0 = unsafe.Pointer(&buf[0]) | |
164 bufsize = unsafe.Sizeof(Statfs_t{}) * uintptr(len(buf)) | |
165 } | |
166 return getfsstat(_p0, bufsize, flags) | |
167 } | |
168 | |
169 func xattrPointer(dest []byte) *byte { | |
170 // It's only when dest is set to NULL that the OS X implementations of | |
171 // getxattr() and listxattr() return the current sizes of the named attributes. | |
172 // An empty byte array is not sufficient. To maintain the same behaviour as the | |
173 // linux implementation, we wrap around the system calls and pass in NULL when | |
174 // dest is empty. | |
175 var destp *byte | |
176 if len(dest) > 0 { | |
177 destp = &dest[0] | |
178 } | |
179 return destp | |
180 } | |
181 | |
182 //sys getxattr(path string, attr string, dest *byte, size int, position uint32, options int) (sz int, err error) | |
183 | |
184 func Getxattr(path string, attr string, dest []byte) (sz int, err error) { | |
185 return getxattr(path, attr, xattrPointer(dest), len(dest), 0, 0) | |
186 } | |
187 | |
188 func Lgetxattr(link string, attr string, dest []byte) (sz int, err error) { | |
189 return getxattr(link, attr, xattrPointer(dest), len(dest), 0, XATTR_NOFOLLOW) | |
190 } | |
191 | |
192 //sys fgetxattr(fd int, attr string, dest *byte, size int, position uint32, options int) (sz int, err error) | |
193 | |
194 func Fgetxattr(fd int, attr string, dest []byte) (sz int, err error) { | |
195 return fgetxattr(fd, attr, xattrPointer(dest), len(dest), 0, 0) | |
196 } | |
197 | |
198 //sys setxattr(path string, attr string, data *byte, size int, position uint32, options int) (err error) | |
199 | |
200 func Setxattr(path string, attr string, data []byte, flags int) (err error) { | |
201 // The parameters for the OS X implementation vary slightly compared to the | |
202 // linux system call, specifically the position parameter: | |
203 // | |
204 // linux: | |
205 // int setxattr( | |
206 // const char *path, | |
207 // const char *name, | |
208 // const void *value, | |
209 // size_t size, | |
210 // int flags | |
211 // ); | |
212 // | |
213 // darwin: | |
214 // int setxattr( | |
215 // const char *path, | |
216 // const char *name, | |
217 // void *value, | |
218 // size_t size, | |
219 // u_int32_t position, | |
220 // int options | |
221 // ); | |
222 // | |
223 // position specifies the offset within the extended attribute. In the | |
224 // current implementation, only the resource fork extended attribute makes | |
225 // use of this argument. For all others, position is reserved. We simply | |
226 // default to setting it to zero. | |
227 return setxattr(path, attr, xattrPointer(data), len(data), 0, flags) | |
228 } | |
229 | |
230 func Lsetxattr(link string, attr string, data []byte, flags int) (err error) { | |
231 return setxattr(link, attr, xattrPointer(data), len(data), 0, flags|XATTR_NOFOLLOW) | |
232 } | |
233 | |
234 //sys fsetxattr(fd int, attr string, data *byte, size int, position uint32, options int) (err error) | |
235 | |
236 func Fsetxattr(fd int, attr string, data []byte, flags int) (err error) { | |
237 return fsetxattr(fd, attr, xattrPointer(data), len(data), 0, 0) | |
238 } | |
239 | |
240 //sys removexattr(path string, attr string, options int) (err error) | |
241 | |
242 func Removexattr(path string, attr string) (err error) { | |
243 // We wrap around and explicitly zero out the options provided to the OS X | |
244 // implementation of removexattr, we do so for interoperability with the | |
245 // linux variant. | |
246 return removexattr(path, attr, 0) | |
247 } | |
248 | |
249 func Lremovexattr(link string, attr string) (err error) { | |
250 return removexattr(link, attr, XATTR_NOFOLLOW) | |
251 } | |
252 | |
253 //sys fremovexattr(fd int, attr string, options int) (err error) | |
254 | |
255 func Fremovexattr(fd int, attr string) (err error) { | |
256 return fremovexattr(fd, attr, 0) | |
257 } | |
258 | |
259 //sys listxattr(path string, dest *byte, size int, options int) (sz int, err error) | |
260 | |
261 func Listxattr(path string, dest []byte) (sz int, err error) { | |
262 return listxattr(path, xattrPointer(dest), len(dest), 0) | |
263 } | |
264 | |
265 func Llistxattr(link string, dest []byte) (sz int, err error) { | |
266 return listxattr(link, xattrPointer(dest), len(dest), XATTR_NOFOLLOW) | |
267 } | |
268 | |
269 //sys flistxattr(fd int, dest *byte, size int, options int) (sz int, err error) | |
270 | |
271 func Flistxattr(fd int, dest []byte) (sz int, err error) { | |
272 return flistxattr(fd, xattrPointer(dest), len(dest), 0) | |
273 } | |
274 | |
275 //sys utimensat(dirfd int, path string, times *[2]Timespec, flags int) (err error) | |
276 | |
277 /* | |
278 * Wrapped | |
279 */ | |
280 | |
281 //sys fcntl(fd int, cmd int, arg int) (val int, err error) | |
282 | |
283 //sys kill(pid int, signum int, posix int) (err error) | |
284 | |
285 func Kill(pid int, signum syscall.Signal) (err error) { return kill(pid, int(signum), 1) } | |
286 | |
287 //sys ioctl(fd int, req uint, arg uintptr) (err error) | |
288 | |
289 func IoctlCtlInfo(fd int, ctlInfo *CtlInfo) error { | |
290 err := ioctl(fd, CTLIOCGINFO, uintptr(unsafe.Pointer(ctlInfo))) | |
291 runtime.KeepAlive(ctlInfo) | |
292 return err | |
293 } | |
294 | |
295 // IfreqMTU is struct ifreq used to get or set a network device's MTU. | |
296 type IfreqMTU struct { | |
297 Name [IFNAMSIZ]byte | |
298 MTU int32 | |
299 } | |
300 | |
301 // IoctlGetIfreqMTU performs the SIOCGIFMTU ioctl operation on fd to get the MTU | |
302 // of the network device specified by ifname. | |
303 func IoctlGetIfreqMTU(fd int, ifname string) (*IfreqMTU, error) { | |
304 var ifreq IfreqMTU | |
305 copy(ifreq.Name[:], ifname) | |
306 err := ioctl(fd, SIOCGIFMTU, uintptr(unsafe.Pointer(&ifreq))) | |
307 return &ifreq, err | |
308 } | |
309 | |
310 // IoctlSetIfreqMTU performs the SIOCSIFMTU ioctl operation on fd to set the MTU | |
311 // of the network device specified by ifreq.Name. | |
312 func IoctlSetIfreqMTU(fd int, ifreq *IfreqMTU) error { | |
313 err := ioctl(fd, SIOCSIFMTU, uintptr(unsafe.Pointer(ifreq))) | |
314 runtime.KeepAlive(ifreq) | |
315 return err | |
316 } | |
317 | |
318 //sys sysctl(mib []_C_int, old *byte, oldlen *uintptr, new *byte, newlen uintptr) (err error) = SYS_SYSCTL | |
319 | |
320 func Uname(uname *Utsname) error { | |
321 mib := []_C_int{CTL_KERN, KERN_OSTYPE} | |
322 n := unsafe.Sizeof(uname.Sysname) | |
323 if err := sysctl(mib, &uname.Sysname[0], &n, nil, 0); err != nil { | |
324 return err | |
325 } | |
326 | |
327 mib = []_C_int{CTL_KERN, KERN_HOSTNAME} | |
328 n = unsafe.Sizeof(uname.Nodename) | |
329 if err := sysctl(mib, &uname.Nodename[0], &n, nil, 0); err != nil { | |
330 return err | |
331 } | |
332 | |
333 mib = []_C_int{CTL_KERN, KERN_OSRELEASE} | |
334 n = unsafe.Sizeof(uname.Release) | |
335 if err := sysctl(mib, &uname.Release[0], &n, nil, 0); err != nil { | |
336 return err | |
337 } | |
338 | |
339 mib = []_C_int{CTL_KERN, KERN_VERSION} | |
340 n = unsafe.Sizeof(uname.Version) | |
341 if err := sysctl(mib, &uname.Version[0], &n, nil, 0); err != nil { | |
342 return err | |
343 } | |
344 | |
345 // The version might have newlines or tabs in it, convert them to | |
346 // spaces. | |
347 for i, b := range uname.Version { | |
348 if b == '\n' || b == '\t' { | |
349 if i == len(uname.Version)-1 { | |
350 uname.Version[i] = 0 | |
351 } else { | |
352 uname.Version[i] = ' ' | |
353 } | |
354 } | |
355 } | |
356 | |
357 mib = []_C_int{CTL_HW, HW_MACHINE} | |
358 n = unsafe.Sizeof(uname.Machine) | |
359 if err := sysctl(mib, &uname.Machine[0], &n, nil, 0); err != nil { | |
360 return err | |
361 } | |
362 | |
363 return nil | |
364 } | |
365 | |
366 func Sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) { | |
367 if raceenabled { | |
368 raceReleaseMerge(unsafe.Pointer(&ioSync)) | |
369 } | |
370 var length = int64(count) | |
371 err = sendfile(infd, outfd, *offset, &length, nil, 0) | |
372 written = int(length) | |
373 return | |
374 } | |
375 | |
376 func GetsockoptIPMreqn(fd, level, opt int) (*IPMreqn, error) { | |
377 var value IPMreqn | |
378 vallen := _Socklen(SizeofIPMreqn) | |
379 errno := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen) | |
380 return &value, errno | |
381 } | |
382 | |
383 func SetsockoptIPMreqn(fd, level, opt int, mreq *IPMreqn) (err error) { | |
384 return setsockopt(fd, level, opt, unsafe.Pointer(mreq), unsafe.Sizeof(*mreq)) | |
385 } | |
386 | |
387 // GetsockoptXucred is a getsockopt wrapper that returns an Xucred struct. | |
388 // The usual level and opt are SOL_LOCAL and LOCAL_PEERCRED, respectively. | |
389 func GetsockoptXucred(fd, level, opt int) (*Xucred, error) { | |
390 x := new(Xucred) | |
391 vallen := _Socklen(SizeofXucred) | |
392 err := getsockopt(fd, level, opt, unsafe.Pointer(x), &vallen) | |
393 return x, err | |
394 } | |
395 | |
396 func GetsockoptTCPConnectionInfo(fd, level, opt int) (*TCPConnectionInfo, error) { | |
397 var value TCPConnectionInfo | |
398 vallen := _Socklen(SizeofTCPConnectionInfo) | |
399 err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen) | |
400 return &value, err | |
401 } | |
402 | |
403 func SysctlKinfoProc(name string, args ...int) (*KinfoProc, error) { | |
404 mib, err := sysctlmib(name, args...) | |
405 if err != nil { | |
406 return nil, err | |
407 } | |
408 | |
409 var kinfo KinfoProc | |
410 n := uintptr(SizeofKinfoProc) | |
411 if err := sysctl(mib, (*byte)(unsafe.Pointer(&kinfo)), &n, nil, 0); err != nil { | |
412 return nil, err | |
413 } | |
414 if n != SizeofKinfoProc { | |
415 return nil, EIO | |
416 } | |
417 return &kinfo, nil | |
418 } | |
419 | |
420 func SysctlKinfoProcSlice(name string, args ...int) ([]KinfoProc, error) { | |
421 mib, err := sysctlmib(name, args...) | |
422 if err != nil { | |
423 return nil, err | |
424 } | |
425 | |
426 // Find size. | |
427 n := uintptr(0) | |
428 if err := sysctl(mib, nil, &n, nil, 0); err != nil { | |
429 return nil, err | |
430 } | |
431 if n == 0 { | |
432 return nil, nil | |
433 } | |
434 if n%SizeofKinfoProc != 0 { | |
435 return nil, fmt.Errorf("sysctl() returned a size of %d, which is not a multiple of %d", n, SizeofKinfoProc) | |
436 } | |
437 | |
438 // Read into buffer of that size. | |
439 buf := make([]KinfoProc, n/SizeofKinfoProc) | |
440 if err := sysctl(mib, (*byte)(unsafe.Pointer(&buf[0])), &n, nil, 0); err != nil { | |
441 return nil, err | |
442 } | |
443 if n%SizeofKinfoProc != 0 { | |
444 return nil, fmt.Errorf("sysctl() returned a size of %d, which is not a multiple of %d", n, SizeofKinfoProc) | |
445 } | |
446 | |
447 // The actual call may return less than the original reported required | |
448 // size so ensure we deal with that. | |
449 return buf[:n/SizeofKinfoProc], nil | |
450 } | |
451 | |
452 //sys sendfile(infd int, outfd int, offset int64, len *int64, hdtr unsafe.Pointer, flags int) (err error) | |
453 | |
454 //sys shmat(id int, addr uintptr, flag int) (ret uintptr, err error) | |
455 //sys shmctl(id int, cmd int, buf *SysvShmDesc) (result int, err error) | |
456 //sys shmdt(addr uintptr) (err error) | |
457 //sys shmget(key int, size int, flag int) (id int, err error) | |
458 | |
459 /* | |
460 * Exposed directly | |
461 */ | |
462 //sys Access(path string, mode uint32) (err error) | |
463 //sys Adjtime(delta *Timeval, olddelta *Timeval) (err error) | |
464 //sys Chdir(path string) (err error) | |
465 //sys Chflags(path string, flags int) (err error) | |
466 //sys Chmod(path string, mode uint32) (err error) | |
467 //sys Chown(path string, uid int, gid int) (err error) | |
468 //sys Chroot(path string) (err error) | |
469 //sys ClockGettime(clockid int32, time *Timespec) (err error) | |
470 //sys Close(fd int) (err error) | |
471 //sys Clonefile(src string, dst string, flags int) (err error) | |
472 //sys Clonefileat(srcDirfd int, src string, dstDirfd int, dst string, flags int) (err error) | |
473 //sys Dup(fd int) (nfd int, err error) | |
474 //sys Dup2(from int, to int) (err error) | |
475 //sys Exchangedata(path1 string, path2 string, options int) (err error) | |
476 //sys Exit(code int) | |
477 //sys Faccessat(dirfd int, path string, mode uint32, flags int) (err error) | |
478 //sys Fchdir(fd int) (err error) | |
479 //sys Fchflags(fd int, flags int) (err error) | |
480 //sys Fchmod(fd int, mode uint32) (err error) | |
481 //sys Fchmodat(dirfd int, path string, mode uint32, flags int) (err error) | |
482 //sys Fchown(fd int, uid int, gid int) (err error) | |
483 //sys Fchownat(dirfd int, path string, uid int, gid int, flags int) (err error) | |
484 //sys Fclonefileat(srcDirfd int, dstDirfd int, dst string, flags int) (err error) | |
485 //sys Flock(fd int, how int) (err error) | |
486 //sys Fpathconf(fd int, name int) (val int, err error) | |
487 //sys Fsync(fd int) (err error) | |
488 //sys Ftruncate(fd int, length int64) (err error) | |
489 //sys Getcwd(buf []byte) (n int, err error) | |
490 //sys Getdtablesize() (size int) | |
491 //sysnb Getegid() (egid int) | |
492 //sysnb Geteuid() (uid int) | |
493 //sysnb Getgid() (gid int) | |
494 //sysnb Getpgid(pid int) (pgid int, err error) | |
495 //sysnb Getpgrp() (pgrp int) | |
496 //sysnb Getpid() (pid int) | |
497 //sysnb Getppid() (ppid int) | |
498 //sys Getpriority(which int, who int) (prio int, err error) | |
499 //sysnb Getrlimit(which int, lim *Rlimit) (err error) | |
500 //sysnb Getrusage(who int, rusage *Rusage) (err error) | |
501 //sysnb Getsid(pid int) (sid int, err error) | |
502 //sysnb Gettimeofday(tp *Timeval) (err error) | |
503 //sysnb Getuid() (uid int) | |
504 //sysnb Issetugid() (tainted bool) | |
505 //sys Kqueue() (fd int, err error) | |
506 //sys Lchown(path string, uid int, gid int) (err error) | |
507 //sys Link(path string, link string) (err error) | |
508 //sys Linkat(pathfd int, path string, linkfd int, link string, flags int) (err error) | |
509 //sys Listen(s int, backlog int) (err error) | |
510 //sys Mkdir(path string, mode uint32) (err error) | |
511 //sys Mkdirat(dirfd int, path string, mode uint32) (err error) | |
512 //sys Mkfifo(path string, mode uint32) (err error) | |
513 //sys Mknod(path string, mode uint32, dev int) (err error) | |
514 //sys Mount(fsType string, dir string, flags int, data unsafe.Pointer) (err error) | |
515 //sys Open(path string, mode int, perm uint32) (fd int, err error) | |
516 //sys Openat(dirfd int, path string, mode int, perm uint32) (fd int, err error) | |
517 //sys Pathconf(path string, name int) (val int, err error) | |
518 //sys pread(fd int, p []byte, offset int64) (n int, err error) | |
519 //sys pwrite(fd int, p []byte, offset int64) (n int, err error) | |
520 //sys read(fd int, p []byte) (n int, err error) | |
521 //sys Readlink(path string, buf []byte) (n int, err error) | |
522 //sys Readlinkat(dirfd int, path string, buf []byte) (n int, err error) | |
523 //sys Rename(from string, to string) (err error) | |
524 //sys Renameat(fromfd int, from string, tofd int, to string) (err error) | |
525 //sys Revoke(path string) (err error) | |
526 //sys Rmdir(path string) (err error) | |
527 //sys Seek(fd int, offset int64, whence int) (newoffset int64, err error) = SYS_LSEEK | |
528 //sys Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) | |
529 //sys Setegid(egid int) (err error) | |
530 //sysnb Seteuid(euid int) (err error) | |
531 //sysnb Setgid(gid int) (err error) | |
532 //sys Setlogin(name string) (err error) | |
533 //sysnb Setpgid(pid int, pgid int) (err error) | |
534 //sys Setpriority(which int, who int, prio int) (err error) | |
535 //sys Setprivexec(flag int) (err error) | |
536 //sysnb Setregid(rgid int, egid int) (err error) | |
537 //sysnb Setreuid(ruid int, euid int) (err error) | |
538 //sysnb Setrlimit(which int, lim *Rlimit) (err error) | |
539 //sysnb Setsid() (pid int, err error) | |
540 //sysnb Settimeofday(tp *Timeval) (err error) | |
541 //sysnb Setuid(uid int) (err error) | |
542 //sys Symlink(path string, link string) (err error) | |
543 //sys Symlinkat(oldpath string, newdirfd int, newpath string) (err error) | |
544 //sys Sync() (err error) | |
545 //sys Truncate(path string, length int64) (err error) | |
546 //sys Umask(newmask int) (oldmask int) | |
547 //sys Undelete(path string) (err error) | |
548 //sys Unlink(path string) (err error) | |
549 //sys Unlinkat(dirfd int, path string, flags int) (err error) | |
550 //sys Unmount(path string, flags int) (err error) | |
551 //sys write(fd int, p []byte) (n int, err error) | |
552 //sys mmap(addr uintptr, length uintptr, prot int, flag int, fd int, pos int64) (ret uintptr, err error) | |
553 //sys munmap(addr uintptr, length uintptr) (err error) | |
554 //sys readlen(fd int, buf *byte, nbuf int) (n int, err error) = SYS_READ | |
555 //sys writelen(fd int, buf *byte, nbuf int) (n int, err error) = SYS_WRITE | |
556 | |
557 /* | |
558 * Unimplemented | |
559 */ | |
560 // Profil | |
561 // Sigaction | |
562 // Sigprocmask | |
563 // Getlogin | |
564 // Sigpending | |
565 // Sigaltstack | |
566 // Ioctl | |
567 // Reboot | |
568 // Execve | |
569 // Vfork | |
570 // Sbrk | |
571 // Sstk | |
572 // Ovadvise | |
573 // Mincore | |
574 // Setitimer | |
575 // Swapon | |
576 // Select | |
577 // Sigsuspend | |
578 // Readv | |
579 // Writev | |
580 // Nfssvc | |
581 // Getfh | |
582 // Quotactl | |
583 // Csops | |
584 // Waitid | |
585 // Add_profil | |
586 // Kdebug_trace | |
587 // Sigreturn | |
588 // Atsocket | |
589 // Kqueue_from_portset_np | |
590 // Kqueue_portset | |
591 // Getattrlist | |
592 // Setattrlist | |
593 // Getdirentriesattr | |
594 // Searchfs | |
595 // Delete | |
596 // Copyfile | |
597 // Watchevent | |
598 // Waitevent | |
599 // Modwatch | |
600 // Fsctl | |
601 // Initgroups | |
602 // Posix_spawn | |
603 // Nfsclnt | |
604 // Fhopen | |
605 // Minherit | |
606 // Semsys | |
607 // Msgsys | |
608 // Shmsys | |
609 // Semctl | |
610 // Semget | |
611 // Semop | |
612 // Msgctl | |
613 // Msgget | |
614 // Msgsnd | |
615 // Msgrcv | |
616 // Shm_open | |
617 // Shm_unlink | |
618 // Sem_open | |
619 // Sem_close | |
620 // Sem_unlink | |
621 // Sem_wait | |
622 // Sem_trywait | |
623 // Sem_post | |
624 // Sem_getvalue | |
625 // Sem_init | |
626 // Sem_destroy | |
627 // Open_extended | |
628 // Umask_extended | |
629 // Stat_extended | |
630 // Lstat_extended | |
631 // Fstat_extended | |
632 // Chmod_extended | |
633 // Fchmod_extended | |
634 // Access_extended | |
635 // Settid | |
636 // Gettid | |
637 // Setsgroups | |
638 // Getsgroups | |
639 // Setwgroups | |
640 // Getwgroups | |
641 // Mkfifo_extended | |
642 // Mkdir_extended | |
643 // Identitysvc | |
644 // Shared_region_check_np | |
645 // Shared_region_map_np | |
646 // __pthread_mutex_destroy | |
647 // __pthread_mutex_init | |
648 // __pthread_mutex_lock | |
649 // __pthread_mutex_trylock | |
650 // __pthread_mutex_unlock | |
651 // __pthread_cond_init | |
652 // __pthread_cond_destroy | |
653 // __pthread_cond_broadcast | |
654 // __pthread_cond_signal | |
655 // Setsid_with_pid | |
656 // __pthread_cond_timedwait | |
657 // Aio_fsync | |
658 // Aio_return | |
659 // Aio_suspend | |
660 // Aio_cancel | |
661 // Aio_error | |
662 // Aio_read | |
663 // Aio_write | |
664 // Lio_listio | |
665 // __pthread_cond_wait | |
666 // Iopolicysys | |
667 // __pthread_kill | |
668 // __pthread_sigmask | |
669 // __sigwait | |
670 // __disable_threadsignal | |
671 // __pthread_markcancel | |
672 // __pthread_canceled | |
673 // __semwait_signal | |
674 // Proc_info | |
675 // sendfile | |
676 // Stat64_extended | |
677 // Lstat64_extended | |
678 // Fstat64_extended | |
679 // __pthread_chdir | |
680 // __pthread_fchdir | |
681 // Audit | |
682 // Auditon | |
683 // Getauid | |
684 // Setauid | |
685 // Getaudit | |
686 // Setaudit | |
687 // Getaudit_addr | |
688 // Setaudit_addr | |
689 // Auditctl | |
690 // Bsdthread_create | |
691 // Bsdthread_terminate | |
692 // Stack_snapshot | |
693 // Bsdthread_register | |
694 // Workq_open | |
695 // Workq_ops | |
696 // __mac_execve | |
697 // __mac_syscall | |
698 // __mac_get_file | |
699 // __mac_set_file | |
700 // __mac_get_link | |
701 // __mac_set_link | |
702 // __mac_get_proc | |
703 // __mac_set_proc | |
704 // __mac_get_fd | |
705 // __mac_set_fd | |
706 // __mac_get_pid | |
707 // __mac_get_lcid | |
708 // __mac_get_lctx | |
709 // __mac_set_lctx | |
710 // Setlcid | |
711 // Read_nocancel | |
712 // Write_nocancel | |
713 // Open_nocancel | |
714 // Close_nocancel | |
715 // Wait4_nocancel | |
716 // Recvmsg_nocancel | |
717 // Sendmsg_nocancel | |
718 // Recvfrom_nocancel | |
719 // Accept_nocancel | |
720 // Fcntl_nocancel | |
721 // Select_nocancel | |
722 // Fsync_nocancel | |
723 // Connect_nocancel | |
724 // Sigsuspend_nocancel | |
725 // Readv_nocancel | |
726 // Writev_nocancel | |
727 // Sendto_nocancel | |
728 // Pread_nocancel | |
729 // Pwrite_nocancel | |
730 // Waitid_nocancel | |
731 // Poll_nocancel | |
732 // Msgsnd_nocancel | |
733 // Msgrcv_nocancel | |
734 // Sem_wait_nocancel | |
735 // Aio_suspend_nocancel | |
736 // __sigwait_nocancel | |
737 // __semwait_signal_nocancel | |
738 // __mac_mount | |
739 // __mac_get_mount | |
740 // __mac_getfsstat |