mirror of
				https://github.com/adnanh/webhook.git
				synced 2025-10-24 18:21:00 +00:00 
			
		
		
		
	Add missing windows dependency
This commit is contained in:
		
							parent
							
								
									876c853073
								
							
						
					
					
						commit
						e1634fe669
					
				
					 231 changed files with 72439 additions and 37782 deletions
				
			
		
							
								
								
									
										2
									
								
								go.mod
									
										
									
									
									
								
							
							
						
						
									
										2
									
								
								go.mod
									
										
									
									
									
								
							|  | @ -12,7 +12,7 @@ require ( | |||
| 	github.com/gorilla/mux v1.7.3 | ||||
| 	github.com/kr/pretty v0.1.0 // indirect | ||||
| 	golang.org/x/net v0.0.0-20191209160850-c0dbc17a3553 // indirect | ||||
| 	golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a | ||||
| 	golang.org/x/sys v0.0.0-20191228213918-04cbcbbfeed8 | ||||
| 	gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15 // indirect | ||||
| 	gopkg.in/fsnotify.v1 v1.4.2 | ||||
| 	gopkg.in/yaml.v2 v2.0.0-20170812160011-eb3733d160e7 // indirect | ||||
|  |  | |||
							
								
								
									
										2
									
								
								go.sum
									
										
									
									
									
								
							
							
						
						
									
										2
									
								
								go.sum
									
										
									
									
									
								
							|  | @ -22,6 +22,8 @@ golang.org/x/net v0.0.0-20191209160850-c0dbc17a3553 h1:efeOvDhwQ29Dj3SdAV/MJf8ou | |||
| golang.org/x/net v0.0.0-20191209160850-c0dbc17a3553/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a h1:1BGLXjeY4akVXGgbC9HugT3Jv3hCI0z56oJR5vAMgBU= | ||||
| golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||
| golang.org/x/sys v0.0.0-20191228213918-04cbcbbfeed8 h1:JA8d3MPx/IToSyXZG/RhwYEtfrKO1Fxrqe8KrkiLXKM= | ||||
| golang.org/x/sys v0.0.0-20191228213918-04cbcbbfeed8/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/text v0.3.0 h1:g61tztE5qeGQ89tm6NTjjM9VPIm088od1l6aSorWRWg= | ||||
| golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= | ||||
| gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15 h1:YR8cESwS4TdDjEe65xsg0ogRM/Nc3DYOhEAlW+xobZo= | ||||
|  |  | |||
|  | @ -7,6 +7,8 @@ import ( | |||
| 	"regexp" | ||||
| 	"syscall" | ||||
| 	"unsafe" | ||||
| 
 | ||||
| 	"golang.org/x/sys/windows" | ||||
| ) | ||||
| 
 | ||||
| // MkdirAll implementation that is volume path aware for Windows. It can be used | ||||
|  |  | |||
							
								
								
									
										42
									
								
								vendor/golang.org/x/sys/unix/affinity_linux.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										42
									
								
								vendor/golang.org/x/sys/unix/affinity_linux.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -7,6 +7,7 @@ | |||
| package unix | ||||
| 
 | ||||
| import ( | ||||
| 	"math/bits" | ||||
| 	"unsafe" | ||||
| ) | ||||
| 
 | ||||
|  | @ -79,46 +80,7 @@ func (s *CPUSet) IsSet(cpu int) bool { | |||
| func (s *CPUSet) Count() int { | ||||
| 	c := 0 | ||||
| 	for _, b := range s { | ||||
| 		c += onesCount64(uint64(b)) | ||||
| 		c += bits.OnesCount64(uint64(b)) | ||||
| 	} | ||||
| 	return c | ||||
| } | ||||
| 
 | ||||
| // onesCount64 is a copy of Go 1.9's math/bits.OnesCount64. | ||||
| // Once this package can require Go 1.9, we can delete this | ||||
| // and update the caller to use bits.OnesCount64. | ||||
| func onesCount64(x uint64) int { | ||||
| 	const m0 = 0x5555555555555555 // 01010101 ... | ||||
| 	const m1 = 0x3333333333333333 // 00110011 ... | ||||
| 	const m2 = 0x0f0f0f0f0f0f0f0f // 00001111 ... | ||||
| 	const m3 = 0x00ff00ff00ff00ff // etc. | ||||
| 	const m4 = 0x0000ffff0000ffff | ||||
| 
 | ||||
| 	// Implementation: Parallel summing of adjacent bits. | ||||
| 	// See "Hacker's Delight", Chap. 5: Counting Bits. | ||||
| 	// The following pattern shows the general approach: | ||||
| 	// | ||||
| 	//   x = x>>1&(m0&m) + x&(m0&m) | ||||
| 	//   x = x>>2&(m1&m) + x&(m1&m) | ||||
| 	//   x = x>>4&(m2&m) + x&(m2&m) | ||||
| 	//   x = x>>8&(m3&m) + x&(m3&m) | ||||
| 	//   x = x>>16&(m4&m) + x&(m4&m) | ||||
| 	//   x = x>>32&(m5&m) + x&(m5&m) | ||||
| 	//   return int(x) | ||||
| 	// | ||||
| 	// Masking (& operations) can be left away when there's no | ||||
| 	// danger that a field's sum will carry over into the next | ||||
| 	// field: Since the result cannot be > 64, 8 bits is enough | ||||
| 	// and we can ignore the masks for the shifts by 8 and up. | ||||
| 	// Per "Hacker's Delight", the first line can be simplified | ||||
| 	// more, but it saves at best one instruction, so we leave | ||||
| 	// it alone for clarity. | ||||
| 	const m = 1<<64 - 1 | ||||
| 	x = x>>1&(m0&m) + x&(m0&m) | ||||
| 	x = x>>2&(m1&m) + x&(m1&m) | ||||
| 	x = (x>>4 + x) & (m2 & m) | ||||
| 	x += x >> 8 | ||||
| 	x += x >> 16 | ||||
| 	x += x >> 32 | ||||
| 	return int(x) & (1<<7 - 1) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										54
									
								
								vendor/golang.org/x/sys/unix/asm_linux_riscv64.s
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								vendor/golang.org/x/sys/unix/asm_linux_riscv64.s
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,54 @@ | |||
| // Copyright 2019 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| // +build riscv64,!gccgo | ||||
| 
 | ||||
| #include "textflag.h" | ||||
| 
 | ||||
| // | ||||
| // System calls for linux/riscv64. | ||||
| // | ||||
| // Where available, just jump to package syscall's implementation of | ||||
| // these functions. | ||||
| 
 | ||||
| TEXT ·Syscall(SB),NOSPLIT,$0-56 | ||||
| 	JMP	syscall·Syscall(SB) | ||||
| 
 | ||||
| TEXT ·Syscall6(SB),NOSPLIT,$0-80 | ||||
| 	JMP	syscall·Syscall6(SB) | ||||
| 
 | ||||
| TEXT ·SyscallNoError(SB),NOSPLIT,$0-48 | ||||
| 	CALL	runtime·entersyscall(SB) | ||||
| 	MOV	a1+8(FP), A0 | ||||
| 	MOV	a2+16(FP), A1 | ||||
| 	MOV	a3+24(FP), A2 | ||||
| 	MOV	$0, A3 | ||||
| 	MOV	$0, A4 | ||||
| 	MOV	$0, A5 | ||||
| 	MOV	$0, A6 | ||||
| 	MOV	trap+0(FP), A7	// syscall entry | ||||
| 	ECALL | ||||
| 	MOV	A0, r1+32(FP)	// r1 | ||||
| 	MOV	A1, r2+40(FP)	// r2 | ||||
| 	CALL	runtime·exitsyscall(SB) | ||||
| 	RET | ||||
| 
 | ||||
| TEXT ·RawSyscall(SB),NOSPLIT,$0-56 | ||||
| 	JMP	syscall·RawSyscall(SB) | ||||
| 
 | ||||
| TEXT ·RawSyscall6(SB),NOSPLIT,$0-80 | ||||
| 	JMP	syscall·RawSyscall6(SB) | ||||
| 
 | ||||
| TEXT ·RawSyscallNoError(SB),NOSPLIT,$0-48 | ||||
| 	MOV	a1+8(FP), A0 | ||||
| 	MOV	a2+16(FP), A1 | ||||
| 	MOV	a3+24(FP), A2 | ||||
| 	MOV	ZERO, A3 | ||||
| 	MOV	ZERO, A4 | ||||
| 	MOV	ZERO, A5 | ||||
| 	MOV	trap+0(FP), A7	// syscall entry | ||||
| 	ECALL | ||||
| 	MOV	A0, r1+32(FP) | ||||
| 	MOV	A1, r2+40(FP) | ||||
| 	RET | ||||
							
								
								
									
										29
									
								
								vendor/golang.org/x/sys/unix/asm_openbsd_arm64.s
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								vendor/golang.org/x/sys/unix/asm_openbsd_arm64.s
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,29 @@ | |||
| // Copyright 2019 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| // +build !gccgo | ||||
| 
 | ||||
| #include "textflag.h" | ||||
| 
 | ||||
| // | ||||
| // System call support for arm64, OpenBSD | ||||
| // | ||||
| 
 | ||||
| // Just jump to package syscall's implementation for all these functions. | ||||
| // The runtime may know about them. | ||||
| 
 | ||||
| TEXT	·Syscall(SB),NOSPLIT,$0-56 | ||||
| 	JMP	syscall·Syscall(SB) | ||||
| 
 | ||||
| TEXT	·Syscall6(SB),NOSPLIT,$0-80 | ||||
| 	JMP	syscall·Syscall6(SB) | ||||
| 
 | ||||
| TEXT	·Syscall9(SB),NOSPLIT,$0-104 | ||||
| 	JMP	syscall·Syscall9(SB) | ||||
| 
 | ||||
| TEXT	·RawSyscall(SB),NOSPLIT,$0-56 | ||||
| 	JMP	syscall·RawSyscall(SB) | ||||
| 
 | ||||
| TEXT	·RawSyscall6(SB),NOSPLIT,$0-80 | ||||
| 	JMP	syscall·RawSyscall6(SB) | ||||
							
								
								
									
										1
									
								
								vendor/golang.org/x/sys/unix/bluetooth_linux.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								vendor/golang.org/x/sys/unix/bluetooth_linux.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -23,6 +23,7 @@ const ( | |||
| 	HCI_CHANNEL_USER    = 1 | ||||
| 	HCI_CHANNEL_MONITOR = 2 | ||||
| 	HCI_CHANNEL_CONTROL = 3 | ||||
| 	HCI_CHANNEL_LOGGING = 4 | ||||
| ) | ||||
| 
 | ||||
| // Socketoption Level | ||||
|  |  | |||
							
								
								
									
										91
									
								
								vendor/golang.org/x/sys/unix/dirent.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										91
									
								
								vendor/golang.org/x/sys/unix/dirent.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -2,16 +2,101 @@ | |||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| // +build aix darwin dragonfly freebsd linux nacl netbsd openbsd solaris | ||||
| // +build aix darwin dragonfly freebsd linux netbsd openbsd solaris | ||||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| import "syscall" | ||||
| import "unsafe" | ||||
| 
 | ||||
| // readInt returns the size-bytes unsigned integer in native byte order at offset off. | ||||
| func readInt(b []byte, off, size uintptr) (u uint64, ok bool) { | ||||
| 	if len(b) < int(off+size) { | ||||
| 		return 0, false | ||||
| 	} | ||||
| 	if isBigEndian { | ||||
| 		return readIntBE(b[off:], size), true | ||||
| 	} | ||||
| 	return readIntLE(b[off:], size), true | ||||
| } | ||||
| 
 | ||||
| func readIntBE(b []byte, size uintptr) uint64 { | ||||
| 	switch size { | ||||
| 	case 1: | ||||
| 		return uint64(b[0]) | ||||
| 	case 2: | ||||
| 		_ = b[1] // bounds check hint to compiler; see golang.org/issue/14808 | ||||
| 		return uint64(b[1]) | uint64(b[0])<<8 | ||||
| 	case 4: | ||||
| 		_ = b[3] // bounds check hint to compiler; see golang.org/issue/14808 | ||||
| 		return uint64(b[3]) | uint64(b[2])<<8 | uint64(b[1])<<16 | uint64(b[0])<<24 | ||||
| 	case 8: | ||||
| 		_ = b[7] // bounds check hint to compiler; see golang.org/issue/14808 | ||||
| 		return uint64(b[7]) | uint64(b[6])<<8 | uint64(b[5])<<16 | uint64(b[4])<<24 | | ||||
| 			uint64(b[3])<<32 | uint64(b[2])<<40 | uint64(b[1])<<48 | uint64(b[0])<<56 | ||||
| 	default: | ||||
| 		panic("syscall: readInt with unsupported size") | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func readIntLE(b []byte, size uintptr) uint64 { | ||||
| 	switch size { | ||||
| 	case 1: | ||||
| 		return uint64(b[0]) | ||||
| 	case 2: | ||||
| 		_ = b[1] // bounds check hint to compiler; see golang.org/issue/14808 | ||||
| 		return uint64(b[0]) | uint64(b[1])<<8 | ||||
| 	case 4: | ||||
| 		_ = b[3] // bounds check hint to compiler; see golang.org/issue/14808 | ||||
| 		return uint64(b[0]) | uint64(b[1])<<8 | uint64(b[2])<<16 | uint64(b[3])<<24 | ||||
| 	case 8: | ||||
| 		_ = b[7] // bounds check hint to compiler; see golang.org/issue/14808 | ||||
| 		return uint64(b[0]) | uint64(b[1])<<8 | uint64(b[2])<<16 | uint64(b[3])<<24 | | ||||
| 			uint64(b[4])<<32 | uint64(b[5])<<40 | uint64(b[6])<<48 | uint64(b[7])<<56 | ||||
| 	default: | ||||
| 		panic("syscall: readInt with unsupported size") | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // ParseDirent parses up to max directory entries in buf, | ||||
| // appending the names to names. It returns the number of | ||||
| // bytes consumed from buf, the number of entries added | ||||
| // to names, and the new names slice. | ||||
| func ParseDirent(buf []byte, max int, names []string) (consumed int, count int, newnames []string) { | ||||
| 	return syscall.ParseDirent(buf, max, names) | ||||
| 	origlen := len(buf) | ||||
| 	count = 0 | ||||
| 	for max != 0 && len(buf) > 0 { | ||||
| 		reclen, ok := direntReclen(buf) | ||||
| 		if !ok || reclen > uint64(len(buf)) { | ||||
| 			return origlen, count, names | ||||
| 		} | ||||
| 		rec := buf[:reclen] | ||||
| 		buf = buf[reclen:] | ||||
| 		ino, ok := direntIno(rec) | ||||
| 		if !ok { | ||||
| 			break | ||||
| 		} | ||||
| 		if ino == 0 { // File absent in directory. | ||||
| 			continue | ||||
| 		} | ||||
| 		const namoff = uint64(unsafe.Offsetof(Dirent{}.Name)) | ||||
| 		namlen, ok := direntNamlen(rec) | ||||
| 		if !ok || namoff+namlen > uint64(len(rec)) { | ||||
| 			break | ||||
| 		} | ||||
| 		name := rec[namoff : namoff+namlen] | ||||
| 		for i, c := range name { | ||||
| 			if c == 0 { | ||||
| 				name = name[:i] | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 		// Check for useless names before allocating a string. | ||||
| 		if string(name) == "." || string(name) == ".." { | ||||
| 			continue | ||||
| 		} | ||||
| 		max-- | ||||
| 		count++ | ||||
| 		names = append(names, string(name)) | ||||
| 	} | ||||
| 	return origlen - len(buf), count, names | ||||
| } | ||||
|  |  | |||
							
								
								
									
										2
									
								
								vendor/golang.org/x/sys/unix/endian_little.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/golang.org/x/sys/unix/endian_little.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -2,7 +2,7 @@ | |||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| // | ||||
| // +build 386 amd64 amd64p32 arm arm64 ppc64le mipsle mips64le | ||||
| // +build 386 amd64 amd64p32 arm arm64 ppc64le mipsle mips64le riscv64 | ||||
| 
 | ||||
| package unix | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										12
									
								
								vendor/golang.org/x/sys/unix/fcntl.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								vendor/golang.org/x/sys/unix/fcntl.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -9,12 +9,11 @@ package unix | |||
| import "unsafe" | ||||
| 
 | ||||
| // fcntl64Syscall is usually SYS_FCNTL, but is overridden on 32-bit Linux | ||||
| // systems by flock_linux_32bit.go to be SYS_FCNTL64. | ||||
| // systems by fcntl_linux_32bit.go to be SYS_FCNTL64. | ||||
| var fcntl64Syscall uintptr = SYS_FCNTL | ||||
| 
 | ||||
| // FcntlInt performs a fcntl syscall on fd with the provided command and argument. | ||||
| func FcntlInt(fd uintptr, cmd, arg int) (int, error) { | ||||
| 	valptr, _, errno := Syscall(fcntl64Syscall, fd, uintptr(cmd), uintptr(arg)) | ||||
| func fcntl(fd int, cmd, arg int) (int, error) { | ||||
| 	valptr, _, errno := Syscall(fcntl64Syscall, uintptr(fd), uintptr(cmd), uintptr(arg)) | ||||
| 	var err error | ||||
| 	if errno != 0 { | ||||
| 		err = errno | ||||
|  | @ -22,6 +21,11 @@ func FcntlInt(fd uintptr, cmd, arg int) (int, error) { | |||
| 	return int(valptr), err | ||||
| } | ||||
| 
 | ||||
| // FcntlInt performs a fcntl syscall on fd with the provided command and argument. | ||||
| func FcntlInt(fd uintptr, cmd, arg int) (int, error) { | ||||
| 	return fcntl(int(fd), cmd, arg) | ||||
| } | ||||
| 
 | ||||
| // FcntlFlock performs a fcntl syscall for the F_GETLK, F_SETLK or F_SETLKW command. | ||||
| func FcntlFlock(fd uintptr, cmd int, lk *Flock_t) error { | ||||
| 	_, _, errno := Syscall(fcntl64Syscall, fd, uintptr(cmd), uintptr(unsafe.Pointer(lk))) | ||||
|  |  | |||
							
								
								
									
										29
									
								
								vendor/golang.org/x/sys/unix/fdset.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								vendor/golang.org/x/sys/unix/fdset.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,29 @@ | |||
| // Copyright 2019 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| // +build aix darwin dragonfly freebsd linux netbsd openbsd solaris | ||||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| // Set adds fd to the set fds. | ||||
| func (fds *FdSet) Set(fd int) { | ||||
| 	fds.Bits[fd/NFDBITS] |= (1 << (uintptr(fd) % NFDBITS)) | ||||
| } | ||||
| 
 | ||||
| // Clear removes fd from the set fds. | ||||
| func (fds *FdSet) Clear(fd int) { | ||||
| 	fds.Bits[fd/NFDBITS] &^= (1 << (uintptr(fd) % NFDBITS)) | ||||
| } | ||||
| 
 | ||||
| // IsSet returns whether fd is in the set fds. | ||||
| func (fds *FdSet) IsSet(fd int) bool { | ||||
| 	return fds.Bits[fd/NFDBITS]&(1<<(uintptr(fd)%NFDBITS)) != 0 | ||||
| } | ||||
| 
 | ||||
| // Zero clears the set fds. | ||||
| func (fds *FdSet) Zero() { | ||||
| 	for i := range fds.Bits { | ||||
| 		fds.Bits[i] = 0 | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										41
									
								
								vendor/golang.org/x/sys/unix/ioctl.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										41
									
								
								vendor/golang.org/x/sys/unix/ioctl.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -6,7 +6,19 @@ | |||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| import "runtime" | ||||
| import ( | ||||
| 	"runtime" | ||||
| 	"unsafe" | ||||
| ) | ||||
| 
 | ||||
| // ioctl itself should not be exposed directly, but additional get/set | ||||
| // functions for specific types are permissible. | ||||
| 
 | ||||
| // IoctlSetInt performs an ioctl operation which sets an integer value | ||||
| // on fd, using the specified request number. | ||||
| func IoctlSetInt(fd int, req uint, value int) error { | ||||
| 	return ioctl(fd, req, uintptr(value)) | ||||
| } | ||||
| 
 | ||||
| // IoctlSetWinsize performs an ioctl on fd with a *Winsize argument. | ||||
| // | ||||
|  | @ -14,7 +26,7 @@ import "runtime" | |||
| func IoctlSetWinsize(fd int, req uint, value *Winsize) error { | ||||
| 	// TODO: if we get the chance, remove the req parameter and | ||||
| 	// hardcode TIOCSWINSZ. | ||||
| 	err := ioctlSetWinsize(fd, req, value) | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| 	runtime.KeepAlive(value) | ||||
| 	return err | ||||
| } | ||||
|  | @ -24,7 +36,30 @@ func IoctlSetWinsize(fd int, req uint, value *Winsize) error { | |||
| // The req value will usually be TCSETA or TIOCSETA. | ||||
| func IoctlSetTermios(fd int, req uint, value *Termios) error { | ||||
| 	// TODO: if we get the chance, remove the req parameter. | ||||
| 	err := ioctlSetTermios(fd, req, value) | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| 	runtime.KeepAlive(value) | ||||
| 	return err | ||||
| } | ||||
| 
 | ||||
| // IoctlGetInt performs an ioctl operation which gets an integer value | ||||
| // from fd, using the specified request number. | ||||
| // | ||||
| // A few ioctl requests use the return value as an output parameter; | ||||
| // for those, IoctlRetInt should be used instead of this function. | ||||
| func IoctlGetInt(fd int, req uint) (int, error) { | ||||
| 	var value int | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetWinsize(fd int, req uint) (*Winsize, error) { | ||||
| 	var value Winsize | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetTermios(fd int, req uint) (*Termios, error) { | ||||
| 	var value Termios | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
|  |  | |||
							
								
								
									
										39
									
								
								vendor/golang.org/x/sys/unix/mkall.sh
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										39
									
								
								vendor/golang.org/x/sys/unix/mkall.sh
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -50,7 +50,7 @@ if [[ "$GOOS" = "linux" ]]; then | |||
| 	# Use the Docker-based build system | ||||
| 	# Files generated through docker (use $cmd so you can Ctl-C the build or run) | ||||
| 	$cmd docker build --tag generate:$GOOS $GOOS | ||||
| 	$cmd docker run --interactive --tty --volume $(dirname "$(readlink -f "$0")"):/build generate:$GOOS | ||||
| 	$cmd docker run --interactive --tty --volume $(cd -- "$(dirname -- "$0")" && /bin/pwd):/build generate:$GOOS | ||||
| 	exit | ||||
| fi | ||||
| 
 | ||||
|  | @ -105,25 +105,25 @@ dragonfly_amd64) | |||
| freebsd_386) | ||||
| 	mkerrors="$mkerrors -m32" | ||||
| 	mksyscall="go run mksyscall.go -l32" | ||||
| 	mksysnum="go run mksysnum.go 'https://svn.freebsd.org/base/stable/10/sys/kern/syscalls.master'" | ||||
| 	mksysnum="go run mksysnum.go 'https://svn.freebsd.org/base/stable/11/sys/kern/syscalls.master'" | ||||
| 	mktypes="GOARCH=$GOARCH go tool cgo -godefs" | ||||
| 	;; | ||||
| freebsd_amd64) | ||||
| 	mkerrors="$mkerrors -m64" | ||||
| 	mksysnum="go run mksysnum.go 'https://svn.freebsd.org/base/stable/10/sys/kern/syscalls.master'" | ||||
| 	mksysnum="go run mksysnum.go 'https://svn.freebsd.org/base/stable/11/sys/kern/syscalls.master'" | ||||
| 	mktypes="GOARCH=$GOARCH go tool cgo -godefs" | ||||
| 	;; | ||||
| freebsd_arm) | ||||
| 	mkerrors="$mkerrors" | ||||
| 	mksyscall="go run mksyscall.go -l32 -arm" | ||||
| 	mksysnum="go run mksysnum.go 'https://svn.freebsd.org/base/stable/10/sys/kern/syscalls.master'" | ||||
| 	mksysnum="go run mksysnum.go 'https://svn.freebsd.org/base/stable/11/sys/kern/syscalls.master'" | ||||
| 	# Let the type of C char be signed for making the bare syscall | ||||
| 	# API consistent across platforms. | ||||
| 	mktypes="GOARCH=$GOARCH go tool cgo -godefs -- -fsigned-char" | ||||
| 	;; | ||||
| freebsd_arm64) | ||||
| 	mkerrors="$mkerrors -m64" | ||||
| 	mksysnum="go run mksysnum.go 'https://svn.freebsd.org/base/stable/10/sys/kern/syscalls.master'" | ||||
| 	mksysnum="go run mksysnum.go 'https://svn.freebsd.org/base/stable/11/sys/kern/syscalls.master'" | ||||
| 	mktypes="GOARCH=$GOARCH go tool cgo -godefs" | ||||
| 	;; | ||||
| netbsd_386) | ||||
|  | @ -146,24 +146,39 @@ netbsd_arm) | |||
| 	# API consistent across platforms. | ||||
| 	mktypes="GOARCH=$GOARCH go tool cgo -godefs -- -fsigned-char" | ||||
| 	;; | ||||
| netbsd_arm64) | ||||
| 	mkerrors="$mkerrors -m64" | ||||
| 	mksyscall="go run mksyscall.go -netbsd" | ||||
| 	mksysnum="go run mksysnum.go 'http://cvsweb.netbsd.org/bsdweb.cgi/~checkout~/src/sys/kern/syscalls.master'" | ||||
| 	mktypes="GOARCH=$GOARCH go tool cgo -godefs" | ||||
| 	;; | ||||
| openbsd_386) | ||||
| 	mkerrors="$mkerrors -m32" | ||||
| 	mksyscall="go run mksyscall.go -l32 -openbsd" | ||||
| 	mksysctl="./mksysctl_openbsd.pl" | ||||
| 	mksysctl="go run mksysctl_openbsd.go" | ||||
| 	mksysnum="go run mksysnum.go 'https://cvsweb.openbsd.org/cgi-bin/cvsweb/~checkout~/src/sys/kern/syscalls.master'" | ||||
| 	mktypes="GOARCH=$GOARCH go tool cgo -godefs" | ||||
| 	;; | ||||
| openbsd_amd64) | ||||
| 	mkerrors="$mkerrors -m64" | ||||
| 	mksyscall="go run mksyscall.go -openbsd" | ||||
| 	mksysctl="./mksysctl_openbsd.pl" | ||||
| 	mksysctl="go run mksysctl_openbsd.go" | ||||
| 	mksysnum="go run mksysnum.go 'https://cvsweb.openbsd.org/cgi-bin/cvsweb/~checkout~/src/sys/kern/syscalls.master'" | ||||
| 	mktypes="GOARCH=$GOARCH go tool cgo -godefs" | ||||
| 	;; | ||||
| openbsd_arm) | ||||
| 	mkerrors="$mkerrors" | ||||
| 	mksyscall="go run mksyscall.go -l32 -openbsd -arm" | ||||
| 	mksysctl="./mksysctl_openbsd.pl" | ||||
| 	mksysctl="go run mksysctl_openbsd.go" | ||||
| 	mksysnum="go run mksysnum.go 'https://cvsweb.openbsd.org/cgi-bin/cvsweb/~checkout~/src/sys/kern/syscalls.master'" | ||||
| 	# Let the type of C char be signed for making the bare syscall | ||||
| 	# API consistent across platforms. | ||||
| 	mktypes="GOARCH=$GOARCH go tool cgo -godefs -- -fsigned-char" | ||||
| 	;; | ||||
| openbsd_arm64) | ||||
| 	mkerrors="$mkerrors -m64" | ||||
| 	mksyscall="go run mksyscall.go -openbsd" | ||||
| 	mksysctl="go run mksysctl_openbsd.go" | ||||
| 	mksysnum="go run mksysnum.go 'https://cvsweb.openbsd.org/cgi-bin/cvsweb/~checkout~/src/sys/kern/syscalls.master'" | ||||
| 	# Let the type of C char be signed for making the bare syscall | ||||
| 	# API consistent across platforms. | ||||
|  | @ -197,9 +212,11 @@ esac | |||
| 				echo "$mksyscall -tags $GOOS,$GOARCH $syscall_goos $GOOSARCH_in && gofmt -w zsyscall_$GOOSARCH.go && gofmt -w zsyscall_"$GOOSARCH"_gccgo.go && gofmt -w zsyscall_"$GOOSARCH"_gc.go " ; | ||||
| 			elif [ "$GOOS" == "darwin" ]; then | ||||
| 			        # pre-1.12, direct syscalls | ||||
| 			        echo "$mksyscall -tags $GOOS,$GOARCH,!go1.12 $syscall_goos $GOOSARCH_in |gofmt >zsyscall_$GOOSARCH.1_11.go"; | ||||
| 			        echo "$mksyscall -tags $GOOS,$GOARCH,!go1.12 $syscall_goos syscall_darwin_${GOARCH}.1_11.go $GOOSARCH_in |gofmt >zsyscall_$GOOSARCH.1_11.go"; | ||||
| 			        # 1.12 and later, syscalls via libSystem | ||||
| 				echo "$mksyscall -tags $GOOS,$GOARCH,go1.12 $syscall_goos $GOOSARCH_in |gofmt >zsyscall_$GOOSARCH.go"; | ||||
| 				# 1.13 and later, syscalls via libSystem (including syscallPtr) | ||||
| 				echo "$mksyscall -tags $GOOS,$GOARCH,go1.13 syscall_darwin.1_13.go |gofmt >zsyscall_$GOOSARCH.1_13.go"; | ||||
| 			else | ||||
| 				echo "$mksyscall -tags $GOOS,$GOARCH $syscall_goos $GOOSARCH_in |gofmt >zsyscall_$GOOSARCH.go"; | ||||
| 			fi | ||||
|  | @ -207,8 +224,6 @@ esac | |||
| 	esac | ||||
| 	if [ -n "$mksysctl" ]; then echo "$mksysctl |gofmt >$zsysctl"; fi | ||||
| 	if [ -n "$mksysnum" ]; then echo "$mksysnum |gofmt >zsysnum_$GOOSARCH.go"; fi | ||||
| 	if [ -n "$mktypes" ]; then | ||||
| 		echo "$mktypes types_$GOOS.go | go run mkpost.go > ztypes_$GOOSARCH.go"; | ||||
| 	if [ -n "$mktypes" ]; then echo "$mktypes types_$GOOS.go | go run mkpost.go > ztypes_$GOOSARCH.go"; fi | ||||
| 	if [ -n "$mkasm" ]; then echo "$mkasm $GOARCH"; fi | ||||
| 	fi | ||||
| ) | $run | ||||
|  |  | |||
							
								
								
									
										69
									
								
								vendor/golang.org/x/sys/unix/mkerrors.sh
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										69
									
								
								vendor/golang.org/x/sys/unix/mkerrors.sh
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -44,6 +44,7 @@ includes_AIX=' | |||
| #include <sys/stropts.h> | ||||
| #include <sys/mman.h> | ||||
| #include <sys/poll.h> | ||||
| #include <sys/select.h> | ||||
| #include <sys/termio.h> | ||||
| #include <termios.h> | ||||
| #include <fcntl.h> | ||||
|  | @ -60,6 +61,7 @@ includes_Darwin=' | |||
| #include <sys/types.h> | ||||
| #include <sys/event.h> | ||||
| #include <sys/ptrace.h> | ||||
| #include <sys/select.h> | ||||
| #include <sys/socket.h> | ||||
| #include <sys/sockio.h> | ||||
| #include <sys/sysctl.h> | ||||
|  | @ -80,6 +82,7 @@ includes_Darwin=' | |||
| includes_DragonFly=' | ||||
| #include <sys/types.h> | ||||
| #include <sys/event.h> | ||||
| #include <sys/select.h> | ||||
| #include <sys/socket.h> | ||||
| #include <sys/sockio.h> | ||||
| #include <sys/stat.h> | ||||
|  | @ -103,6 +106,7 @@ includes_FreeBSD=' | |||
| #include <sys/param.h> | ||||
| #include <sys/types.h> | ||||
| #include <sys/event.h> | ||||
| #include <sys/select.h> | ||||
| #include <sys/socket.h> | ||||
| #include <sys/sockio.h> | ||||
| #include <sys/stat.h> | ||||
|  | @ -179,48 +183,60 @@ struct ltchars { | |||
| #include <sys/stat.h> | ||||
| #include <sys/types.h> | ||||
| #include <sys/time.h> | ||||
| #include <sys/select.h> | ||||
| #include <sys/signalfd.h> | ||||
| #include <sys/socket.h> | ||||
| #include <sys/uio.h> | ||||
| #include <sys/xattr.h> | ||||
| #include <linux/bpf.h> | ||||
| #include <linux/can.h> | ||||
| #include <linux/capability.h> | ||||
| #include <linux/cryptouser.h> | ||||
| #include <linux/devlink.h> | ||||
| #include <linux/errqueue.h> | ||||
| #include <linux/falloc.h> | ||||
| #include <linux/fanotify.h> | ||||
| #include <linux/filter.h> | ||||
| #include <linux/fs.h> | ||||
| #include <linux/fscrypt.h> | ||||
| #include <linux/genetlink.h> | ||||
| #include <linux/hdreg.h> | ||||
| #include <linux/icmpv6.h> | ||||
| #include <linux/if.h> | ||||
| #include <linux/if_addr.h> | ||||
| #include <linux/if_alg.h> | ||||
| #include <linux/if_arp.h> | ||||
| #include <linux/if_ether.h> | ||||
| #include <linux/if_ppp.h> | ||||
| #include <linux/if_tun.h> | ||||
| #include <linux/if_packet.h> | ||||
| #include <linux/if_addr.h> | ||||
| #include <linux/falloc.h> | ||||
| #include <linux/filter.h> | ||||
| #include <linux/fs.h> | ||||
| #include <linux/if_xdp.h> | ||||
| #include <linux/kexec.h> | ||||
| #include <linux/keyctl.h> | ||||
| #include <linux/loop.h> | ||||
| #include <linux/magic.h> | ||||
| #include <linux/memfd.h> | ||||
| #include <linux/module.h> | ||||
| #include <linux/netfilter/nfnetlink.h> | ||||
| #include <linux/netlink.h> | ||||
| #include <linux/net_namespace.h> | ||||
| #include <linux/nsfs.h> | ||||
| #include <linux/perf_event.h> | ||||
| #include <linux/ptrace.h> | ||||
| #include <linux/random.h> | ||||
| #include <linux/reboot.h> | ||||
| #include <linux/rtc.h> | ||||
| #include <linux/rtnetlink.h> | ||||
| #include <linux/ptrace.h> | ||||
| #include <linux/sched.h> | ||||
| #include <linux/seccomp.h> | ||||
| #include <linux/sockios.h> | ||||
| #include <linux/wait.h> | ||||
| #include <linux/icmpv6.h> | ||||
| #include <linux/serial.h> | ||||
| #include <linux/can.h> | ||||
| #include <linux/vm_sockets.h> | ||||
| #include <linux/sockios.h> | ||||
| #include <linux/taskstats.h> | ||||
| #include <linux/genetlink.h> | ||||
| #include <linux/tipc.h> | ||||
| #include <linux/vm_sockets.h> | ||||
| #include <linux/wait.h> | ||||
| #include <linux/watchdog.h> | ||||
| #include <linux/hdreg.h> | ||||
| #include <linux/rtc.h> | ||||
| #include <linux/if_xdp.h> | ||||
| 
 | ||||
| #include <mtd/ubi-user.h> | ||||
| #include <net/route.h> | ||||
| 
 | ||||
|  | @ -259,6 +275,11 @@ struct ltchars { | |||
| #define FS_KEY_DESC_PREFIX              "fscrypt:" | ||||
| #define FS_KEY_DESC_PREFIX_SIZE         8 | ||||
| #define FS_MAX_KEY_SIZE                 64 | ||||
| 
 | ||||
| // The code generator produces -0x1 for (~0), but an unsigned value is necessary | ||||
| // for the tipc_subscr timeout __u32 field. | ||||
| #undef TIPC_WAIT_FOREVER | ||||
| #define TIPC_WAIT_FOREVER 0xffffffff | ||||
| ' | ||||
| 
 | ||||
| includes_NetBSD=' | ||||
|  | @ -268,6 +289,7 @@ includes_NetBSD=' | |||
| #include <sys/extattr.h> | ||||
| #include <sys/mman.h> | ||||
| #include <sys/mount.h> | ||||
| #include <sys/select.h> | ||||
| #include <sys/socket.h> | ||||
| #include <sys/sockio.h> | ||||
| #include <sys/sysctl.h> | ||||
|  | @ -294,6 +316,7 @@ includes_OpenBSD=' | |||
| #include <sys/event.h> | ||||
| #include <sys/mman.h> | ||||
| #include <sys/mount.h> | ||||
| #include <sys/select.h> | ||||
| #include <sys/socket.h> | ||||
| #include <sys/sockio.h> | ||||
| #include <sys/stat.h> | ||||
|  | @ -330,6 +353,7 @@ includes_OpenBSD=' | |||
| includes_SunOS=' | ||||
| #include <limits.h> | ||||
| #include <sys/types.h> | ||||
| #include <sys/select.h> | ||||
| #include <sys/socket.h> | ||||
| #include <sys/sockio.h> | ||||
| #include <sys/stat.h> | ||||
|  | @ -422,6 +446,7 @@ ccflags="$@" | |||
| 		$2 == "XCASE" || | ||||
| 		$2 == "ALTWERASE" || | ||||
| 		$2 == "NOKERNINFO" || | ||||
| 		$2 == "NFDBITS" || | ||||
| 		$2 ~ /^PAR/ || | ||||
| 		$2 ~ /^SIG[^_]/ || | ||||
| 		$2 ~ /^O[CNPFPL][A-Z]+[^_][A-Z]+$/ || | ||||
|  | @ -431,7 +456,9 @@ ccflags="$@" | |||
| 		$2 ~ /^TC[IO](ON|OFF)$/ || | ||||
| 		$2 ~ /^IN_/ || | ||||
| 		$2 ~ /^LOCK_(SH|EX|NB|UN)$/ || | ||||
| 		$2 ~ /^(AF|SOCK|SO|SOL|IPPROTO|IP|IPV6|ICMP6|TCP|EVFILT|NOTE|EV|SHUT|PROT|MAP|MFD|T?PACKET|MSG|SCM|MCL|DT|MADV|PR)_/ || | ||||
| 		$2 ~ /^LO_(KEY|NAME)_SIZE$/ || | ||||
| 		$2 ~ /^LOOP_(CLR|CTL|GET|SET)_/ || | ||||
| 		$2 ~ /^(AF|SOCK|SO|SOL|IPPROTO|IP|IPV6|ICMP6|TCP|MCAST|EVFILT|NOTE|EV|SHUT|PROT|MAP|MFD|T?PACKET|MSG|SCM|MCL|DT|MADV|PR)_/ || | ||||
| 		$2 ~ /^TP_STATUS_/ || | ||||
| 		$2 ~ /^FALLOC_/ || | ||||
| 		$2 == "ICMPV6_FILTER" || | ||||
|  | @ -444,6 +471,7 @@ ccflags="$@" | |||
| 		$2 ~ /^SYSCTL_VERS/ || | ||||
| 		$2 !~ "MNT_BITS" && | ||||
| 		$2 ~ /^(MS|MNT|UMOUNT)_/ || | ||||
| 		$2 ~ /^NS_GET_/ || | ||||
| 		$2 ~ /^TUN(SET|GET|ATTACH|DETACH)/ || | ||||
| 		$2 ~ /^(O|F|[ES]?FD|NAME|S|PTRACE|PT)_/ || | ||||
| 		$2 ~ /^KEXEC_/ || | ||||
|  | @ -464,13 +492,15 @@ ccflags="$@" | |||
| 		$2 ~ /^RLIMIT_(AS|CORE|CPU|DATA|FSIZE|LOCKS|MEMLOCK|MSGQUEUE|NICE|NOFILE|NPROC|RSS|RTPRIO|RTTIME|SIGPENDING|STACK)|RLIM_INFINITY/ || | ||||
| 		$2 ~ /^PRIO_(PROCESS|PGRP|USER)/ || | ||||
| 		$2 ~ /^CLONE_[A-Z_]+/ || | ||||
| 		$2 !~ /^(BPF_TIMEVAL)$/ && | ||||
| 		$2 !~ /^(BPF_TIMEVAL|BPF_FIB_LOOKUP_[A-Z]+)$/ && | ||||
| 		$2 ~ /^(BPF|DLT)_/ || | ||||
| 		$2 ~ /^(CLOCK|TIMER)_/ || | ||||
| 		$2 ~ /^CAN_/ || | ||||
| 		$2 ~ /^CAP_/ || | ||||
| 		$2 ~ /^ALG_/ || | ||||
| 		$2 ~ /^FS_(POLICY_FLAGS|KEY_DESC|ENCRYPTION_MODE|[A-Z0-9_]+_KEY_SIZE|IOC_(GET|SET)_ENCRYPTION)/ || | ||||
| 		$2 ~ /^FS_(POLICY_FLAGS|KEY_DESC|ENCRYPTION_MODE|[A-Z0-9_]+_KEY_SIZE)/ || | ||||
| 		$2 ~ /^FS_IOC_.*ENCRYPTION/ || | ||||
| 		$2 ~ /^FSCRYPT_/ || | ||||
| 		$2 ~ /^GRND_/ || | ||||
| 		$2 ~ /^RND/ || | ||||
| 		$2 ~ /^KEY_(SPEC|REQKEY_DEFL)_/ || | ||||
|  | @ -497,10 +527,15 @@ ccflags="$@" | |||
| 		$2 ~ /^WDIOC_/ || | ||||
| 		$2 ~ /^NFN/ || | ||||
| 		$2 ~ /^XDP_/ || | ||||
| 		$2 ~ /^RWF_/ || | ||||
| 		$2 ~ /^(HDIO|WIN|SMART)_/ || | ||||
| 		$2 ~ /^CRYPTO_/ || | ||||
| 		$2 ~ /^TIPC_/ || | ||||
| 		$2 ~ /^DEVLINK_/ || | ||||
| 		$2 !~ "WMESGLEN" && | ||||
| 		$2 ~ /^W[A-Z0-9]+$/ || | ||||
| 		$2 ~/^PPPIOC/ || | ||||
| 		$2 ~ /^FAN_|FANOTIFY_/ || | ||||
| 		$2 ~ /^BLK[A-Z]*(GET$|SET$|BUF$|PART$|SIZE)/ {printf("\t%s = C.%s\n", $2, $2)} | ||||
| 		$2 ~ /^__WCOREFLAG$/ {next} | ||||
| 		$2 ~ /^__W[A-Z0-9]+$/ {printf("\t%s = C.%s\n", substr($2,3), $2)} | ||||
|  |  | |||
							
								
								
									
										265
									
								
								vendor/golang.org/x/sys/unix/mksysctl_openbsd.pl
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										265
									
								
								vendor/golang.org/x/sys/unix/mksysctl_openbsd.pl
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -1,265 +0,0 @@ | |||
| #!/usr/bin/env perl | ||||
| 
 | ||||
| # Copyright 2011 The Go Authors. All rights reserved. | ||||
| # Use of this source code is governed by a BSD-style | ||||
| # license that can be found in the LICENSE file. | ||||
| 
 | ||||
| # | ||||
| # Parse the header files for OpenBSD and generate a Go usable sysctl MIB. | ||||
| # | ||||
| # Build a MIB with each entry being an array containing the level, type and | ||||
| # a hash that will contain additional entries if the current entry is a node. | ||||
| # We then walk this MIB and create a flattened sysctl name to OID hash. | ||||
| # | ||||
| 
 | ||||
| use strict; | ||||
| 
 | ||||
| if($ENV{'GOARCH'} eq "" || $ENV{'GOOS'} eq "") { | ||||
| 	print STDERR "GOARCH or GOOS not defined in environment\n"; | ||||
| 	exit 1; | ||||
| } | ||||
| 
 | ||||
| my $debug = 0; | ||||
| my %ctls = (); | ||||
| 
 | ||||
| my @headers = qw ( | ||||
| 	sys/sysctl.h | ||||
| 	sys/socket.h | ||||
| 	sys/tty.h | ||||
| 	sys/malloc.h | ||||
| 	sys/mount.h | ||||
| 	sys/namei.h | ||||
| 	sys/sem.h | ||||
| 	sys/shm.h | ||||
| 	sys/vmmeter.h | ||||
| 	uvm/uvmexp.h | ||||
| 	uvm/uvm_param.h | ||||
| 	uvm/uvm_swap_encrypt.h | ||||
| 	ddb/db_var.h | ||||
| 	net/if.h | ||||
| 	net/if_pfsync.h | ||||
| 	net/pipex.h | ||||
| 	netinet/in.h | ||||
| 	netinet/icmp_var.h | ||||
| 	netinet/igmp_var.h | ||||
| 	netinet/ip_ah.h | ||||
| 	netinet/ip_carp.h | ||||
| 	netinet/ip_divert.h | ||||
| 	netinet/ip_esp.h | ||||
| 	netinet/ip_ether.h | ||||
| 	netinet/ip_gre.h | ||||
| 	netinet/ip_ipcomp.h | ||||
| 	netinet/ip_ipip.h | ||||
| 	netinet/pim_var.h | ||||
| 	netinet/tcp_var.h | ||||
| 	netinet/udp_var.h | ||||
| 	netinet6/in6.h | ||||
| 	netinet6/ip6_divert.h | ||||
| 	netinet6/pim6_var.h | ||||
| 	netinet/icmp6.h | ||||
| 	netmpls/mpls.h | ||||
| ); | ||||
| 
 | ||||
| my @ctls = qw ( | ||||
| 	kern | ||||
| 	vm | ||||
| 	fs | ||||
| 	net | ||||
| 	#debug				# Special handling required | ||||
| 	hw | ||||
| 	#machdep			# Arch specific | ||||
| 	user | ||||
| 	ddb | ||||
| 	#vfs				# Special handling required | ||||
| 	fs.posix | ||||
| 	kern.forkstat | ||||
| 	kern.intrcnt | ||||
| 	kern.malloc | ||||
| 	kern.nchstats | ||||
| 	kern.seminfo | ||||
| 	kern.shminfo | ||||
| 	kern.timecounter | ||||
| 	kern.tty | ||||
| 	kern.watchdog | ||||
| 	net.bpf | ||||
| 	net.ifq | ||||
| 	net.inet | ||||
| 	net.inet.ah | ||||
| 	net.inet.carp | ||||
| 	net.inet.divert | ||||
| 	net.inet.esp | ||||
| 	net.inet.etherip | ||||
| 	net.inet.gre | ||||
| 	net.inet.icmp | ||||
| 	net.inet.igmp | ||||
| 	net.inet.ip | ||||
| 	net.inet.ip.ifq | ||||
| 	net.inet.ipcomp | ||||
| 	net.inet.ipip | ||||
| 	net.inet.mobileip | ||||
| 	net.inet.pfsync | ||||
| 	net.inet.pim | ||||
| 	net.inet.tcp | ||||
| 	net.inet.udp | ||||
| 	net.inet6 | ||||
| 	net.inet6.divert | ||||
| 	net.inet6.ip6 | ||||
| 	net.inet6.icmp6 | ||||
| 	net.inet6.pim6 | ||||
| 	net.inet6.tcp6 | ||||
| 	net.inet6.udp6 | ||||
| 	net.mpls | ||||
| 	net.mpls.ifq | ||||
| 	net.key | ||||
| 	net.pflow | ||||
| 	net.pfsync | ||||
| 	net.pipex | ||||
| 	net.rt | ||||
| 	vm.swapencrypt | ||||
| 	#vfsgenctl			# Special handling required | ||||
| ); | ||||
| 
 | ||||
| # Node name "fixups" | ||||
| my %ctl_map = ( | ||||
| 	"ipproto" => "net.inet", | ||||
| 	"net.inet.ipproto" => "net.inet", | ||||
| 	"net.inet6.ipv6proto" => "net.inet6", | ||||
| 	"net.inet6.ipv6" => "net.inet6.ip6", | ||||
| 	"net.inet.icmpv6" => "net.inet6.icmp6", | ||||
| 	"net.inet6.divert6" => "net.inet6.divert", | ||||
| 	"net.inet6.tcp6" => "net.inet.tcp", | ||||
| 	"net.inet6.udp6" => "net.inet.udp", | ||||
| 	"mpls" => "net.mpls", | ||||
| 	"swpenc" => "vm.swapencrypt" | ||||
| ); | ||||
| 
 | ||||
| # Node mappings | ||||
| my %node_map = ( | ||||
| 	"net.inet.ip.ifq" => "net.ifq", | ||||
| 	"net.inet.pfsync" => "net.pfsync", | ||||
| 	"net.mpls.ifq" => "net.ifq" | ||||
| ); | ||||
| 
 | ||||
| my $ctlname; | ||||
| my %mib = (); | ||||
| my %sysctl = (); | ||||
| my $node; | ||||
| 
 | ||||
| sub debug() { | ||||
| 	print STDERR "$_[0]\n" if $debug; | ||||
| } | ||||
| 
 | ||||
| # Walk the MIB and build a sysctl name to OID mapping. | ||||
| sub build_sysctl() { | ||||
| 	my ($node, $name, $oid) = @_; | ||||
| 	my %node = %{$node}; | ||||
| 	my @oid = @{$oid}; | ||||
| 
 | ||||
| 	foreach my $key (sort keys %node) { | ||||
| 		my @node = @{$node{$key}}; | ||||
| 		my $nodename = $name.($name ne '' ? '.' : '').$key; | ||||
| 		my @nodeoid = (@oid, $node[0]); | ||||
| 		if ($node[1] eq 'CTLTYPE_NODE') { | ||||
| 			if (exists $node_map{$nodename}) { | ||||
| 				$node = \%mib; | ||||
| 				$ctlname = $node_map{$nodename}; | ||||
| 				foreach my $part (split /\./, $ctlname) { | ||||
| 					$node = \%{@{$$node{$part}}[2]}; | ||||
| 				} | ||||
| 			} else { | ||||
| 				$node = $node[2]; | ||||
| 			} | ||||
| 			&build_sysctl($node, $nodename, \@nodeoid); | ||||
| 		} elsif ($node[1] ne '') { | ||||
| 			$sysctl{$nodename} = \@nodeoid; | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| foreach my $ctl (@ctls) { | ||||
| 	$ctls{$ctl} = $ctl; | ||||
| } | ||||
| 
 | ||||
| # Build MIB | ||||
| foreach my $header (@headers) { | ||||
| 	&debug("Processing $header..."); | ||||
| 	open HEADER, "/usr/include/$header" || | ||||
| 	    print STDERR "Failed to open $header\n"; | ||||
| 	while (<HEADER>) { | ||||
| 		if ($_ =~ /^#define\s+(CTL_NAMES)\s+{/ || | ||||
| 		    $_ =~ /^#define\s+(CTL_(.*)_NAMES)\s+{/ || | ||||
| 		    $_ =~ /^#define\s+((.*)CTL_NAMES)\s+{/) { | ||||
| 			if ($1 eq 'CTL_NAMES') { | ||||
| 				# Top level. | ||||
| 				$node = \%mib; | ||||
| 			} else { | ||||
| 				# Node. | ||||
| 				my $nodename = lc($2); | ||||
| 				if ($header =~ /^netinet\//) { | ||||
| 					$ctlname = "net.inet.$nodename"; | ||||
| 				} elsif ($header =~ /^netinet6\//) { | ||||
| 					$ctlname = "net.inet6.$nodename"; | ||||
| 				} elsif ($header =~ /^net\//) { | ||||
| 					$ctlname = "net.$nodename"; | ||||
| 				} else { | ||||
| 					$ctlname = "$nodename"; | ||||
| 					$ctlname =~ s/^(fs|net|kern)_/$1\./; | ||||
| 				} | ||||
| 				if (exists $ctl_map{$ctlname}) { | ||||
| 					$ctlname = $ctl_map{$ctlname}; | ||||
| 				} | ||||
| 				if (not exists $ctls{$ctlname}) { | ||||
| 					&debug("Ignoring $ctlname..."); | ||||
| 					next; | ||||
| 				} | ||||
| 
 | ||||
| 				# Walk down from the top of the MIB. | ||||
| 				$node = \%mib; | ||||
| 				foreach my $part (split /\./, $ctlname) { | ||||
| 					if (not exists $$node{$part}) { | ||||
| 						&debug("Missing node $part"); | ||||
| 						$$node{$part} = [ 0, '', {} ]; | ||||
| 					} | ||||
| 					$node = \%{@{$$node{$part}}[2]}; | ||||
| 				} | ||||
| 			} | ||||
| 
 | ||||
| 			# Populate current node with entries. | ||||
| 			my $i = -1; | ||||
| 			while (defined($_) && $_ !~ /^}/) { | ||||
| 				$_ = <HEADER>; | ||||
| 				$i++ if $_ =~ /{.*}/; | ||||
| 				next if $_ !~ /{\s+"(\w+)",\s+(CTLTYPE_[A-Z]+)\s+}/; | ||||
| 				$$node{$1} = [ $i, $2, {} ]; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	close HEADER; | ||||
| } | ||||
| 
 | ||||
| &build_sysctl(\%mib, "", []); | ||||
| 
 | ||||
| print <<EOF; | ||||
| // mksysctl_openbsd.pl | ||||
| // Code generated by the command above; DO NOT EDIT. | ||||
| 
 | ||||
| // +build $ENV{'GOARCH'},$ENV{'GOOS'} | ||||
| 
 | ||||
| package unix; | ||||
| 
 | ||||
| type mibentry struct { | ||||
| 	ctlname string | ||||
| 	ctloid []_C_int | ||||
| } | ||||
| 
 | ||||
| var sysctlMib = []mibentry { | ||||
| EOF | ||||
| 
 | ||||
| foreach my $name (sort keys %sysctl) { | ||||
| 	my @oid = @{$sysctl{$name}}; | ||||
| 	print "\t{ \"$name\", []_C_int{ ", join(', ', @oid), " } }, \n"; | ||||
| } | ||||
| 
 | ||||
| print <<EOF; | ||||
| } | ||||
| EOF | ||||
|  | @ -2,9 +2,6 @@ | |||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| // +build openbsd | ||||
| // +build 386 amd64 arm | ||||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| import ( | ||||
							
								
								
									
										12
									
								
								vendor/golang.org/x/sys/unix/readdirent_getdents.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								vendor/golang.org/x/sys/unix/readdirent_getdents.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,12 @@ | |||
| // Copyright 2019 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| // +build aix dragonfly freebsd linux netbsd openbsd | ||||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| // ReadDirent reads directory entries from fd and writes them into buf. | ||||
| func ReadDirent(fd int, buf []byte) (n int, err error) { | ||||
| 	return Getdents(fd, buf) | ||||
| } | ||||
							
								
								
									
										19
									
								
								vendor/golang.org/x/sys/unix/readdirent_getdirentries.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								vendor/golang.org/x/sys/unix/readdirent_getdirentries.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,19 @@ | |||
| // Copyright 2019 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| // +build darwin | ||||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| import "unsafe" | ||||
| 
 | ||||
| // ReadDirent reads directory entries from fd and writes them into buf. | ||||
| func ReadDirent(fd int, buf []byte) (n int, err error) { | ||||
| 	// Final argument is (basep *uintptr) and the syscall doesn't take nil. | ||||
| 	// 64 bits should be enough. (32 bits isn't even on 386). Since the | ||||
| 	// actual system call is getdirentries64, 64 is a good guess. | ||||
| 	// TODO(rsc): Can we use a single global basep for all calls? | ||||
| 	var base = (*uintptr)(unsafe.Pointer(new(uint64))) | ||||
| 	return Getdirentries(fd, buf, base) | ||||
| } | ||||
							
								
								
									
										16
									
								
								vendor/golang.org/x/sys/unix/sockcmsg_dragonfly.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								vendor/golang.org/x/sys/unix/sockcmsg_dragonfly.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,16 @@ | |||
| // Copyright 2019 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| // Round the length of a raw sockaddr up to align it properly. | ||||
| func cmsgAlignOf(salen int) int { | ||||
| 	salign := SizeofPtr | ||||
| 	if SizeofPtr == 8 && !supportsABI(_dragonflyABIChangeVersion) { | ||||
| 		// 64-bit Dragonfly before the September 2019 ABI changes still requires | ||||
| 		// 32-bit aligned access to network subsystem. | ||||
| 		salign = 4 | ||||
| 	} | ||||
| 	return (salen + salign - 1) & ^(salign - 1) | ||||
| } | ||||
							
								
								
									
										2
									
								
								vendor/golang.org/x/sys/unix/sockcmsg_linux.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/golang.org/x/sys/unix/sockcmsg_linux.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -17,7 +17,7 @@ func UnixCredentials(ucred *Ucred) []byte { | |||
| 	h.Level = SOL_SOCKET | ||||
| 	h.Type = SCM_CREDENTIALS | ||||
| 	h.SetLen(CmsgLen(SizeofUcred)) | ||||
| 	*((*Ucred)(cmsgData(h))) = *ucred | ||||
| 	*(*Ucred)(h.data(0)) = *ucred | ||||
| 	return b | ||||
| } | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										33
									
								
								vendor/golang.org/x/sys/unix/sockcmsg_unix.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										33
									
								
								vendor/golang.org/x/sys/unix/sockcmsg_unix.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -9,32 +9,9 @@ | |||
| package unix | ||||
| 
 | ||||
| import ( | ||||
| 	"runtime" | ||||
| 	"unsafe" | ||||
| ) | ||||
| 
 | ||||
| // Round the length of a raw sockaddr up to align it properly. | ||||
| func cmsgAlignOf(salen int) int { | ||||
| 	salign := SizeofPtr | ||||
| 
 | ||||
| 	switch runtime.GOOS { | ||||
| 	case "darwin", "dragonfly", "solaris": | ||||
| 		// NOTE: It seems like 64-bit Darwin, DragonFly BSD and | ||||
| 		// Solaris kernels still require 32-bit aligned access to | ||||
| 		// network subsystem. | ||||
| 		if SizeofPtr == 8 { | ||||
| 			salign = 4 | ||||
| 		} | ||||
| 	case "openbsd": | ||||
| 		// OpenBSD armv7 requires 64-bit alignment. | ||||
| 		if runtime.GOARCH == "arm" { | ||||
| 			salign = 8 | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return (salen + salign - 1) & ^(salign - 1) | ||||
| } | ||||
| 
 | ||||
| // CmsgLen returns the value to store in the Len field of the Cmsghdr | ||||
| // structure, taking into account any necessary alignment. | ||||
| func CmsgLen(datalen int) int { | ||||
|  | @ -47,8 +24,8 @@ func CmsgSpace(datalen int) int { | |||
| 	return cmsgAlignOf(SizeofCmsghdr) + cmsgAlignOf(datalen) | ||||
| } | ||||
| 
 | ||||
| func cmsgData(h *Cmsghdr) unsafe.Pointer { | ||||
| 	return unsafe.Pointer(uintptr(unsafe.Pointer(h)) + uintptr(cmsgAlignOf(SizeofCmsghdr))) | ||||
| func (h *Cmsghdr) data(offset uintptr) unsafe.Pointer { | ||||
| 	return unsafe.Pointer(uintptr(unsafe.Pointer(h)) + uintptr(cmsgAlignOf(SizeofCmsghdr)) + offset) | ||||
| } | ||||
| 
 | ||||
| // SocketControlMessage represents a socket control message. | ||||
|  | @ -91,10 +68,8 @@ func UnixRights(fds ...int) []byte { | |||
| 	h.Level = SOL_SOCKET | ||||
| 	h.Type = SCM_RIGHTS | ||||
| 	h.SetLen(CmsgLen(datalen)) | ||||
| 	data := cmsgData(h) | ||||
| 	for _, fd := range fds { | ||||
| 		*(*int32)(data) = int32(fd) | ||||
| 		data = unsafe.Pointer(uintptr(data) + 4) | ||||
| 	for i, fd := range fds { | ||||
| 		*(*int32)(h.data(4 * uintptr(i))) = int32(fd) | ||||
| 	} | ||||
| 	return b | ||||
| } | ||||
|  |  | |||
							
								
								
									
										38
									
								
								vendor/golang.org/x/sys/unix/sockcmsg_unix_other.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								vendor/golang.org/x/sys/unix/sockcmsg_unix_other.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,38 @@ | |||
| // Copyright 2019 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| // +build aix darwin freebsd linux netbsd openbsd solaris | ||||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| import ( | ||||
| 	"runtime" | ||||
| ) | ||||
| 
 | ||||
| // Round the length of a raw sockaddr up to align it properly. | ||||
| func cmsgAlignOf(salen int) int { | ||||
| 	salign := SizeofPtr | ||||
| 
 | ||||
| 	// dragonfly needs to check ABI version at runtime, see cmsgAlignOf in | ||||
| 	// sockcmsg_dragonfly.go | ||||
| 	switch runtime.GOOS { | ||||
| 	case "aix": | ||||
| 		// There is no alignment on AIX. | ||||
| 		salign = 1 | ||||
| 	case "darwin", "illumos", "solaris": | ||||
| 		// NOTE: It seems like 64-bit Darwin, Illumos and Solaris | ||||
| 		// kernels still require 32-bit aligned access to network | ||||
| 		// subsystem. | ||||
| 		if SizeofPtr == 8 { | ||||
| 			salign = 4 | ||||
| 		} | ||||
| 	case "netbsd", "openbsd": | ||||
| 		// NetBSD and OpenBSD armv7 require 64-bit alignment. | ||||
| 		if runtime.GOARCH == "arm" { | ||||
| 			salign = 8 | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return (salen + salign - 1) & ^(salign - 1) | ||||
| } | ||||
							
								
								
									
										1
									
								
								vendor/golang.org/x/sys/unix/syscall.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								vendor/golang.org/x/sys/unix/syscall.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -50,5 +50,4 @@ func BytePtrFromString(s string) (*byte, error) { | |||
| } | ||||
| 
 | ||||
| // Single-word zero for use when we need a valid pointer to 0 bytes. | ||||
| // See mkunix.pl. | ||||
| var _zero uintptr | ||||
|  |  | |||
							
								
								
									
										87
									
								
								vendor/golang.org/x/sys/unix/syscall_aix.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										87
									
								
								vendor/golang.org/x/sys/unix/syscall_aix.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -280,8 +280,24 @@ func sendfile(outfd int, infd int, offset *int64, count int) (written int, err e | |||
| 	return -1, ENOSYS | ||||
| } | ||||
| 
 | ||||
| func direntIno(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Ino), unsafe.Sizeof(Dirent{}.Ino)) | ||||
| } | ||||
| 
 | ||||
| func direntReclen(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Reclen), unsafe.Sizeof(Dirent{}.Reclen)) | ||||
| } | ||||
| 
 | ||||
| func direntNamlen(buf []byte) (uint64, bool) { | ||||
| 	reclen, ok := direntReclen(buf) | ||||
| 	if !ok { | ||||
| 		return 0, false | ||||
| 	} | ||||
| 	return reclen - uint64(unsafe.Offsetof(Dirent{}.Name)), true | ||||
| } | ||||
| 
 | ||||
| //sys	getdirent(fd int, buf []byte) (n int, err error) | ||||
| func ReadDirent(fd int, buf []byte) (n int, err error) { | ||||
| func Getdents(fd int, buf []byte) (n int, err error) { | ||||
| 	return getdirent(fd, buf) | ||||
| } | ||||
| 
 | ||||
|  | @ -334,49 +350,12 @@ func (w WaitStatus) Signal() Signal { | |||
| 
 | ||||
| func (w WaitStatus) Continued() bool { return w&0x01000000 != 0 } | ||||
| 
 | ||||
| func (w WaitStatus) CoreDump() bool { return w&0x200 != 0 } | ||||
| func (w WaitStatus) CoreDump() bool { return w&0x80 == 0x80 } | ||||
| 
 | ||||
| func (w WaitStatus) TrapCause() int { return -1 } | ||||
| 
 | ||||
| //sys	ioctl(fd int, req uint, arg uintptr) (err error) | ||||
| 
 | ||||
| // ioctl itself should not be exposed directly, but additional get/set | ||||
| // functions for specific types are permissible. | ||||
| 
 | ||||
| // IoctlSetInt performs an ioctl operation which sets an integer value | ||||
| // on fd, using the specified request number. | ||||
| func IoctlSetInt(fd int, req uint, value int) error { | ||||
| 	return ioctl(fd, req, uintptr(value)) | ||||
| } | ||||
| 
 | ||||
| func ioctlSetWinsize(fd int, req uint, value *Winsize) error { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| func ioctlSetTermios(fd int, req uint, value *Termios) error { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| // IoctlGetInt performs an ioctl operation which gets an integer value | ||||
| // from fd, using the specified request number. | ||||
| func IoctlGetInt(fd int, req uint) (int, error) { | ||||
| 	var value int | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetWinsize(fd int, req uint) (*Winsize, error) { | ||||
| 	var value Winsize | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetTermios(fd int, req uint) (*Termios, error) { | ||||
| 	var value Termios | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| 
 | ||||
| // fcntl must never be called with cmd=F_DUP2FD because it doesn't work on AIX | ||||
| // There is no way to create a custom fcntl and to keep //sys fcntl easily, | ||||
| // Therefore, the programmer must call dup2 instead of fcntl in this case. | ||||
|  | @ -444,8 +423,6 @@ func IoctlGetTermios(fd int, req uint) (*Termios, error) { | |||
| //sysnb	Times(tms *Tms) (ticks uintptr, err error) | ||||
| //sysnb	Umask(mask int) (oldmask int) | ||||
| //sysnb	Uname(buf *Utsname) (err error) | ||||
| //TODO umount | ||||
| // //sys	Unmount(target string, flags int) (err error) = umount | ||||
| //sys   Unlink(path string) (err error) | ||||
| //sys   Unlinkat(dirfd int, path string, flags int) (err error) | ||||
| //sys	Ustat(dev int, ubuf *Ustat_t) (err error) | ||||
|  | @ -456,8 +433,8 @@ func IoctlGetTermios(fd int, req uint) (*Termios, error) { | |||
| //sys	Dup2(oldfd int, newfd int) (err error) | ||||
| //sys	Fadvise(fd int, offset int64, length int64, advice int) (err error) = posix_fadvise64 | ||||
| //sys	Fchown(fd int, uid int, gid int) (err error) | ||||
| //sys	Fstat(fd int, stat *Stat_t) (err error) | ||||
| //sys	Fstatat(dirfd int, path string, stat *Stat_t, flags int) (err error) = fstatat | ||||
| //sys	fstat(fd int, stat *Stat_t) (err error) | ||||
| //sys	fstatat(dirfd int, path string, stat *Stat_t, flags int) (err error) = fstatat | ||||
| //sys	Fstatfs(fd int, buf *Statfs_t) (err error) | ||||
| //sys	Ftruncate(fd int, length int64) (err error) | ||||
| //sysnb	Getegid() (egid int) | ||||
|  | @ -466,18 +443,17 @@ func IoctlGetTermios(fd int, req uint) (*Termios, error) { | |||
| //sysnb	Getuid() (uid int) | ||||
| //sys	Lchown(path string, uid int, gid int) (err error) | ||||
| //sys	Listen(s int, n int) (err error) | ||||
| //sys	Lstat(path string, stat *Stat_t) (err error) | ||||
| //sys	lstat(path string, stat *Stat_t) (err error) | ||||
| //sys	Pause() (err error) | ||||
| //sys	Pread(fd int, p []byte, offset int64) (n int, err error) = pread64 | ||||
| //sys	Pwrite(fd int, p []byte, offset int64) (n int, err error) = pwrite64 | ||||
| //TODO Select | ||||
| // //sys	Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) | ||||
| //sys	Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) | ||||
| //sys	Pselect(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timespec, sigmask *Sigset_t) (n int, err error) | ||||
| //sysnb	Setregid(rgid int, egid int) (err error) | ||||
| //sysnb	Setreuid(ruid int, euid int) (err error) | ||||
| //sys	Shutdown(fd int, how int) (err error) | ||||
| //sys	Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int64, err error) | ||||
| //sys	Stat(path string, stat *Stat_t) (err error) | ||||
| //sys	stat(path string, statptr *Stat_t) (err error) | ||||
| //sys	Statfs(path string, buf *Statfs_t) (err error) | ||||
| //sys	Truncate(path string, length int64) (err error) | ||||
| 
 | ||||
|  | @ -493,8 +469,10 @@ func IoctlGetTermios(fd int, req uint) (*Termios, error) { | |||
| //sysnb	getsockname(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error) | ||||
| //sys	recvfrom(fd int, p []byte, flags int, from *RawSockaddrAny, fromlen *_Socklen) (n int, err error) | ||||
| //sys	sendto(s int, buf []byte, flags int, to unsafe.Pointer, addrlen _Socklen) (err error) | ||||
| //sys	recvmsg(s int, msg *Msghdr, flags int) (n int, err error) | ||||
| //sys	sendmsg(s int, msg *Msghdr, flags int) (n int, err error) | ||||
| 
 | ||||
| // In order to use msghdr structure with Control, Controllen, nrecvmsg and nsendmsg must be used. | ||||
| //sys	recvmsg(s int, msg *Msghdr, flags int) (n int, err error) = nrecvmsg | ||||
| //sys	sendmsg(s int, msg *Msghdr, flags int) (n int, err error) = nsendmsg | ||||
| 
 | ||||
| //sys	munmap(addr uintptr, length uintptr) (err error) | ||||
| 
 | ||||
|  | @ -545,3 +523,14 @@ func Poll(fds []PollFd, timeout int) (n int, err error) { | |||
| //sys	gettimeofday(tv *Timeval, tzp *Timezone) (err error) | ||||
| //sysnb	Time(t *Time_t) (tt Time_t, err error) | ||||
| //sys	Utime(path string, buf *Utimbuf) (err error) | ||||
| 
 | ||||
| //sys	Getsystemcfg(label int) (n uint64) | ||||
| 
 | ||||
| //sys	umount(target string) (err error) | ||||
| func Unmount(target string, flags int) (err error) { | ||||
| 	if flags != 0 { | ||||
| 		// AIX doesn't have any flags for umount. | ||||
| 		return ENOSYS | ||||
| 	} | ||||
| 	return umount(target) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										20
									
								
								vendor/golang.org/x/sys/unix/syscall_aix_ppc.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										20
									
								
								vendor/golang.org/x/sys/unix/syscall_aix_ppc.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -29,6 +29,26 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = int32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func Fstat(fd int, stat *Stat_t) error { | ||||
| 	return fstat(fd, stat) | ||||
| } | ||||
| 
 | ||||
| func Fstatat(dirfd int, path string, stat *Stat_t, flags int) error { | ||||
| 	return fstatat(dirfd, path, stat, flags) | ||||
| } | ||||
| 
 | ||||
| func Lstat(path string, stat *Stat_t) error { | ||||
| 	return lstat(path, stat) | ||||
| } | ||||
| 
 | ||||
| func Stat(path string, statptr *Stat_t) error { | ||||
| 	return stat(path, statptr) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										51
									
								
								vendor/golang.org/x/sys/unix/syscall_aix_ppc64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										51
									
								
								vendor/golang.org/x/sys/unix/syscall_aix_ppc64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -29,6 +29,57 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = int32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
| 
 | ||||
| // In order to only have Timespec structure, type of Stat_t's fields | ||||
| // Atim, Mtim and Ctim is changed from StTimespec to Timespec during | ||||
| // ztypes generation. | ||||
| // On ppc64, Timespec.Nsec is an int64 while StTimespec.Nsec is an | ||||
| // int32, so the fields' value must be modified. | ||||
| func fixStatTimFields(stat *Stat_t) { | ||||
| 	stat.Atim.Nsec >>= 32 | ||||
| 	stat.Mtim.Nsec >>= 32 | ||||
| 	stat.Ctim.Nsec >>= 32 | ||||
| } | ||||
| 
 | ||||
| func Fstat(fd int, stat *Stat_t) error { | ||||
| 	err := fstat(fd, stat) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	fixStatTimFields(stat) | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func Fstatat(dirfd int, path string, stat *Stat_t, flags int) error { | ||||
| 	err := fstatat(dirfd, path, stat, flags) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	fixStatTimFields(stat) | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func Lstat(path string, stat *Stat_t) error { | ||||
| 	err := lstat(path, stat) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	fixStatTimFields(stat) | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func Stat(path string, statptr *Stat_t) error { | ||||
| 	err := stat(path, statptr) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	fixStatTimFields(statptr) | ||||
| 	return nil | ||||
| } | ||||
|  |  | |||
							
								
								
									
										18
									
								
								vendor/golang.org/x/sys/unix/syscall_bsd.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								vendor/golang.org/x/sys/unix/syscall_bsd.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -63,15 +63,6 @@ func Setgroups(gids []int) (err error) { | |||
| 	return setgroups(len(a), &a[0]) | ||||
| } | ||||
| 
 | ||||
| func ReadDirent(fd int, buf []byte) (n int, err error) { | ||||
| 	// Final argument is (basep *uintptr) and the syscall doesn't take nil. | ||||
| 	// 64 bits should be enough. (32 bits isn't even on 386). Since the | ||||
| 	// actual system call is getdirentries64, 64 is a good guess. | ||||
| 	// TODO(rsc): Can we use a single global basep for all calls? | ||||
| 	var base = (*uintptr)(unsafe.Pointer(new(uint64))) | ||||
| 	return Getdirentries(fd, buf, base) | ||||
| } | ||||
| 
 | ||||
| // Wait status is 7 bits at bottom, either 0 (exited), | ||||
| // 0x7F (stopped), or a signal number that caused an exit. | ||||
| // The 0x80 bit is whether there was a core dump. | ||||
|  | @ -86,6 +77,7 @@ const ( | |||
| 	shift = 8 | ||||
| 
 | ||||
| 	exited  = 0 | ||||
| 	killed  = 9 | ||||
| 	stopped = 0x7F | ||||
| ) | ||||
| 
 | ||||
|  | @ -112,6 +104,8 @@ func (w WaitStatus) CoreDump() bool { return w.Signaled() && w&core != 0 } | |||
| 
 | ||||
| func (w WaitStatus) Stopped() bool { return w&mask == stopped && syscall.Signal(w>>shift) != SIGSTOP } | ||||
| 
 | ||||
| func (w WaitStatus) Killed() bool { return w&mask == killed && syscall.Signal(w>>shift) != SIGKILL } | ||||
| 
 | ||||
| func (w WaitStatus) Continued() bool { return w&mask == stopped && syscall.Signal(w>>shift) == SIGSTOP } | ||||
| 
 | ||||
| func (w WaitStatus) StopSignal() syscall.Signal { | ||||
|  | @ -243,7 +237,7 @@ func anyToSockaddr(fd int, rsa *RawSockaddrAny) (Sockaddr, error) { | |||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 		bytes := (*[10000]byte)(unsafe.Pointer(&pp.Path[0]))[0:n] | ||||
| 		bytes := (*[len(pp.Path)]byte)(unsafe.Pointer(&pp.Path[0]))[0:n] | ||||
| 		sa.Name = string(bytes) | ||||
| 		return sa, nil | ||||
| 
 | ||||
|  | @ -419,8 +413,6 @@ func Kevent(kq int, changes, events []Kevent_t, timeout *Timespec) (n int, err e | |||
| 	return kevent(kq, change, len(changes), event, len(events), timeout) | ||||
| } | ||||
| 
 | ||||
| //sys	sysctl(mib []_C_int, old *byte, oldlen *uintptr, new *byte, newlen uintptr) (err error) = SYS___SYSCTL | ||||
| 
 | ||||
| // sysctlmib translates name to mib number and appends any additional args. | ||||
| func sysctlmib(name string, args ...int) ([]_C_int, error) { | ||||
| 	// Translate name to mib number. | ||||
|  | @ -585,8 +577,6 @@ func Futimes(fd int, tv []Timeval) error { | |||
| 	return futimes(fd, (*[2]Timeval)(unsafe.Pointer(&tv[0]))) | ||||
| } | ||||
| 
 | ||||
| //sys	fcntl(fd int, cmd int, arg int) (val int, err error) | ||||
| 
 | ||||
| //sys   poll(fds *PollFd, nfds int, timeout int) (n int, err error) | ||||
| 
 | ||||
| func Poll(fds []PollFd, timeout int) (n int, err error) { | ||||
|  |  | |||
							
								
								
									
										29
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin.1_12.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin.1_12.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,29 @@ | |||
| // Copyright 2019 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| // +build darwin,go1.12,!go1.13 | ||||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| import ( | ||||
| 	"unsafe" | ||||
| ) | ||||
| 
 | ||||
| func Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) { | ||||
| 	// To implement this using libSystem we'd need syscall_syscallPtr for | ||||
| 	// fdopendir. However, syscallPtr was only added in Go 1.13, so we fall | ||||
| 	// back to raw syscalls for this func on Go 1.12. | ||||
| 	var p unsafe.Pointer | ||||
| 	if len(buf) > 0 { | ||||
| 		p = unsafe.Pointer(&buf[0]) | ||||
| 	} else { | ||||
| 		p = unsafe.Pointer(&_zero) | ||||
| 	} | ||||
| 	r0, _, e1 := Syscall6(SYS_GETDIRENTRIES64, uintptr(fd), uintptr(p), uintptr(len(buf)), uintptr(unsafe.Pointer(basep)), 0, 0) | ||||
| 	n = int(r0) | ||||
| 	if e1 != 0 { | ||||
| 		return n, errnoErr(e1) | ||||
| 	} | ||||
| 	return n, nil | ||||
| } | ||||
							
								
								
									
										101
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin.1_13.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										101
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin.1_13.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,101 @@ | |||
| // Copyright 2019 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| // +build darwin,go1.13 | ||||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| import "unsafe" | ||||
| 
 | ||||
| //sys	closedir(dir uintptr) (err error) | ||||
| //sys	readdir_r(dir uintptr, entry *Dirent, result **Dirent) (res Errno) | ||||
| 
 | ||||
| func fdopendir(fd int) (dir uintptr, err error) { | ||||
| 	r0, _, e1 := syscall_syscallPtr(funcPC(libc_fdopendir_trampoline), uintptr(fd), 0, 0) | ||||
| 	dir = uintptr(r0) | ||||
| 	if e1 != 0 { | ||||
| 		err = errnoErr(e1) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
| 
 | ||||
| func libc_fdopendir_trampoline() | ||||
| 
 | ||||
| //go:linkname libc_fdopendir libc_fdopendir | ||||
| //go:cgo_import_dynamic libc_fdopendir fdopendir "/usr/lib/libSystem.B.dylib" | ||||
| 
 | ||||
| func Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) { | ||||
| 	// Simulate Getdirentries using fdopendir/readdir_r/closedir. | ||||
| 	// We store the number of entries to skip in the seek | ||||
| 	// offset of fd. See issue #31368. | ||||
| 	// It's not the full required semantics, but should handle the case | ||||
| 	// of calling Getdirentries or ReadDirent repeatedly. | ||||
| 	// It won't handle assigning the results of lseek to *basep, or handle | ||||
| 	// the directory being edited underfoot. | ||||
| 	skip, err := Seek(fd, 0, 1 /* SEEK_CUR */) | ||||
| 	if err != nil { | ||||
| 		return 0, err | ||||
| 	} | ||||
| 
 | ||||
| 	// We need to duplicate the incoming file descriptor | ||||
| 	// because the caller expects to retain control of it, but | ||||
| 	// fdopendir expects to take control of its argument. | ||||
| 	// Just Dup'ing the file descriptor is not enough, as the | ||||
| 	// result shares underlying state. Use Openat to make a really | ||||
| 	// new file descriptor referring to the same directory. | ||||
| 	fd2, err := Openat(fd, ".", O_RDONLY, 0) | ||||
| 	if err != nil { | ||||
| 		return 0, err | ||||
| 	} | ||||
| 	d, err := fdopendir(fd2) | ||||
| 	if err != nil { | ||||
| 		Close(fd2) | ||||
| 		return 0, err | ||||
| 	} | ||||
| 	defer closedir(d) | ||||
| 
 | ||||
| 	var cnt int64 | ||||
| 	for { | ||||
| 		var entry Dirent | ||||
| 		var entryp *Dirent | ||||
| 		e := readdir_r(d, &entry, &entryp) | ||||
| 		if e != 0 { | ||||
| 			return n, errnoErr(e) | ||||
| 		} | ||||
| 		if entryp == nil { | ||||
| 			break | ||||
| 		} | ||||
| 		if skip > 0 { | ||||
| 			skip-- | ||||
| 			cnt++ | ||||
| 			continue | ||||
| 		} | ||||
| 		reclen := int(entry.Reclen) | ||||
| 		if reclen > len(buf) { | ||||
| 			// Not enough room. Return for now. | ||||
| 			// The counter will let us know where we should start up again. | ||||
| 			// Note: this strategy for suspending in the middle and | ||||
| 			// restarting is O(n^2) in the length of the directory. Oh well. | ||||
| 			break | ||||
| 		} | ||||
| 		// Copy entry into return buffer. | ||||
| 		s := struct { | ||||
| 			ptr unsafe.Pointer | ||||
| 			siz int | ||||
| 			cap int | ||||
| 		}{ptr: unsafe.Pointer(&entry), siz: reclen, cap: reclen} | ||||
| 		copy(buf, *(*[]byte)(unsafe.Pointer(&s))) | ||||
| 		buf = buf[reclen:] | ||||
| 		n += reclen | ||||
| 		cnt++ | ||||
| 	} | ||||
| 	// Set the seek offset of the input fd to record | ||||
| 	// how many files we've already returned. | ||||
| 	_, err = Seek(fd, cnt, 0 /* SEEK_SET */) | ||||
| 	if err != nil { | ||||
| 		return n, err | ||||
| 	} | ||||
| 
 | ||||
| 	return n, nil | ||||
| } | ||||
							
								
								
									
										71
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										71
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -77,7 +77,18 @@ func nametomib(name string) (mib []_C_int, err error) { | |||
| 	return buf[0 : n/siz], nil | ||||
| } | ||||
| 
 | ||||
| //sys   ptrace(request int, pid int, addr uintptr, data uintptr) (err error) | ||||
| func direntIno(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Ino), unsafe.Sizeof(Dirent{}.Ino)) | ||||
| } | ||||
| 
 | ||||
| func direntReclen(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Reclen), unsafe.Sizeof(Dirent{}.Reclen)) | ||||
| } | ||||
| 
 | ||||
| func direntNamlen(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Namlen), unsafe.Sizeof(Dirent{}.Namlen)) | ||||
| } | ||||
| 
 | ||||
| func PtraceAttach(pid int) (err error) { return ptrace(PT_ATTACH, pid, 0, 0) } | ||||
| func PtraceDetach(pid int) (err error) { return ptrace(PT_DETACH, pid, 0, 0) } | ||||
| 
 | ||||
|  | @ -144,6 +155,23 @@ func getAttrList(path string, attrList attrList, attrBuf []byte, options uint) ( | |||
| 
 | ||||
| //sys getattrlist(path *byte, list unsafe.Pointer, buf unsafe.Pointer, size uintptr, options int) (err error) | ||||
| 
 | ||||
| func SysctlClockinfo(name string) (*Clockinfo, error) { | ||||
| 	mib, err := sysctlmib(name) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	n := uintptr(SizeofClockinfo) | ||||
| 	var ci Clockinfo | ||||
| 	if err := sysctl(mib, (*byte)(unsafe.Pointer(&ci)), &n, nil, 0); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	if n != SizeofClockinfo { | ||||
| 		return nil, EIO | ||||
| 	} | ||||
| 	return &ci, nil | ||||
| } | ||||
| 
 | ||||
| //sysnb pipe() (r int, w int, err error) | ||||
| 
 | ||||
| func Pipe(p []int) (err error) { | ||||
|  | @ -305,48 +333,15 @@ func utimensat(dirfd int, path string, times *[2]Timespec, flags int) error { | |||
|  * Wrapped | ||||
|  */ | ||||
| 
 | ||||
| //sys	fcntl(fd int, cmd int, arg int) (val int, err error) | ||||
| 
 | ||||
| //sys	kill(pid int, signum int, posix int) (err error) | ||||
| 
 | ||||
| func Kill(pid int, signum syscall.Signal) (err error) { return kill(pid, int(signum), 1) } | ||||
| 
 | ||||
| //sys	ioctl(fd int, req uint, arg uintptr) (err error) | ||||
| 
 | ||||
| // ioctl itself should not be exposed directly, but additional get/set | ||||
| // functions for specific types are permissible. | ||||
| 
 | ||||
| // IoctlSetInt performs an ioctl operation which sets an integer value | ||||
| // on fd, using the specified request number. | ||||
| func IoctlSetInt(fd int, req uint, value int) error { | ||||
| 	return ioctl(fd, req, uintptr(value)) | ||||
| } | ||||
| 
 | ||||
| func ioctlSetWinsize(fd int, req uint, value *Winsize) error { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| func ioctlSetTermios(fd int, req uint, value *Termios) error { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| // IoctlGetInt performs an ioctl operation which gets an integer value | ||||
| // from fd, using the specified request number. | ||||
| func IoctlGetInt(fd int, req uint) (int, error) { | ||||
| 	var value int | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetWinsize(fd int, req uint) (*Winsize, error) { | ||||
| 	var value Winsize | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetTermios(fd int, req uint) (*Termios, error) { | ||||
| 	var value Termios | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| //sys   sysctl(mib []_C_int, old *byte, oldlen *uintptr, new *byte, newlen uintptr) (err error) = SYS_SYSCTL | ||||
| 
 | ||||
| func Uname(uname *Utsname) error { | ||||
| 	mib := []_C_int{CTL_KERN, KERN_OSTYPE} | ||||
|  | @ -469,7 +464,7 @@ func Sendfile(outfd int, infd int, offset *int64, count int) (written int, err e | |||
| //sys	Revoke(path string) (err error) | ||||
| //sys	Rmdir(path string) (err error) | ||||
| //sys	Seek(fd int, offset int64, whence int) (newoffset int64, err error) = SYS_LSEEK | ||||
| //sys	Select(n int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (err error) | ||||
| //sys	Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) | ||||
| //sys	Setegid(egid int) (err error) | ||||
| //sysnb	Seteuid(euid int) (err error) | ||||
| //sysnb	Setgid(gid int) (err error) | ||||
|  |  | |||
							
								
								
									
										9
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_386.1_11.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_386.1_11.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,9 @@ | |||
| // Copyright 2019 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| // +build darwin,386,!go1.12 | ||||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| //sys  Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) = SYS_GETDIRENTRIES64 | ||||
							
								
								
									
										7
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -10,6 +10,8 @@ import ( | |||
| 	"syscall" | ||||
| ) | ||||
| 
 | ||||
| //sys   ptrace(request int, pid int, addr uintptr, data uintptr) (err error) | ||||
| 
 | ||||
| func setTimespec(sec, nsec int64) Timespec { | ||||
| 	return Timespec{Sec: int32(sec), Nsec: int32(nsec)} | ||||
| } | ||||
|  | @ -43,6 +45,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = int32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  | @ -56,7 +62,6 @@ const SYS___SYSCTL = SYS_SYSCTL | |||
| //sys	Fstat(fd int, stat *Stat_t) (err error) = SYS_FSTAT64 | ||||
| //sys	Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) = SYS_FSTATAT64 | ||||
| //sys	Fstatfs(fd int, stat *Statfs_t) (err error) = SYS_FSTATFS64 | ||||
| //sys	Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) = SYS_GETDIRENTRIES64 | ||||
| //sys	getfsstat(buf unsafe.Pointer, size uintptr, flags int) (n int, err error) = SYS_GETFSSTAT64 | ||||
| //sys	Lstat(path string, stat *Stat_t) (err error) = SYS_LSTAT64 | ||||
| //sys	Stat(path string, stat *Stat_t) (err error) = SYS_STAT64 | ||||
|  |  | |||
							
								
								
									
										9
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_amd64.1_11.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_amd64.1_11.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,9 @@ | |||
| // Copyright 2019 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| // +build darwin,amd64,!go1.12 | ||||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| //sys  Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) = SYS_GETDIRENTRIES64 | ||||
							
								
								
									
										7
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -10,6 +10,8 @@ import ( | |||
| 	"syscall" | ||||
| ) | ||||
| 
 | ||||
| //sys   ptrace(request int, pid int, addr uintptr, data uintptr) (err error) | ||||
| 
 | ||||
| func setTimespec(sec, nsec int64) Timespec { | ||||
| 	return Timespec{Sec: sec, Nsec: nsec} | ||||
| } | ||||
|  | @ -43,6 +45,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = int32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  | @ -56,7 +62,6 @@ const SYS___SYSCTL = SYS_SYSCTL | |||
| //sys	Fstat(fd int, stat *Stat_t) (err error) = SYS_FSTAT64 | ||||
| //sys	Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) = SYS_FSTATAT64 | ||||
| //sys	Fstatfs(fd int, stat *Statfs_t) (err error) = SYS_FSTATFS64 | ||||
| //sys	Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) = SYS_GETDIRENTRIES64 | ||||
| //sys	getfsstat(buf unsafe.Pointer, size uintptr, flags int) (n int, err error) = SYS_GETFSSTAT64 | ||||
| //sys	Lstat(path string, stat *Stat_t) (err error) = SYS_LSTAT64 | ||||
| //sys	Stat(path string, stat *Stat_t) (err error) = SYS_STAT64 | ||||
|  |  | |||
							
								
								
									
										11
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_arm.1_11.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_arm.1_11.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,11 @@ | |||
| // Copyright 2019 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| // +build darwin,arm,!go1.12 | ||||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| func Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) { | ||||
| 	return 0, ENOSYS | ||||
| } | ||||
							
								
								
									
										12
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -8,6 +8,10 @@ import ( | |||
| 	"syscall" | ||||
| ) | ||||
| 
 | ||||
| func ptrace(request int, pid int, addr uintptr, data uintptr) error { | ||||
| 	return ENOTSUP | ||||
| } | ||||
| 
 | ||||
| func setTimespec(sec, nsec int64) Timespec { | ||||
| 	return Timespec{Sec: int32(sec), Nsec: int32(nsec)} | ||||
| } | ||||
|  | @ -41,6 +45,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = int32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  | @ -58,7 +66,3 @@ const SYS___SYSCTL = SYS_SYSCTL | |||
| //sys	Lstat(path string, stat *Stat_t) (err error) | ||||
| //sys	Stat(path string, stat *Stat_t) (err error) | ||||
| //sys	Statfs(path string, stat *Statfs_t) (err error) | ||||
| 
 | ||||
| func Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) { | ||||
| 	return 0, ENOSYS | ||||
| } | ||||
|  |  | |||
							
								
								
									
										11
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_arm64.1_11.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_arm64.1_11.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,11 @@ | |||
| // Copyright 2019 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| // +build darwin,arm64,!go1.12 | ||||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| func Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) { | ||||
| 	return 0, ENOSYS | ||||
| } | ||||
							
								
								
									
										12
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -10,6 +10,10 @@ import ( | |||
| 	"syscall" | ||||
| ) | ||||
| 
 | ||||
| func ptrace(request int, pid int, addr uintptr, data uintptr) error { | ||||
| 	return ENOTSUP | ||||
| } | ||||
| 
 | ||||
| func setTimespec(sec, nsec int64) Timespec { | ||||
| 	return Timespec{Sec: sec, Nsec: nsec} | ||||
| } | ||||
|  | @ -43,6 +47,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = int32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  | @ -60,7 +68,3 @@ const SYS___SYSCTL = SYS_SYSCTL | |||
| //sys	Lstat(path string, stat *Stat_t) (err error) | ||||
| //sys	Stat(path string, stat *Stat_t) (err error) | ||||
| //sys	Statfs(path string, stat *Statfs_t) (err error) | ||||
| 
 | ||||
| func Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) { | ||||
| 	return 0, ENOSYS | ||||
| } | ||||
|  |  | |||
							
								
								
									
										2
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_libSystem.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/golang.org/x/sys/unix/syscall_darwin_libSystem.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -15,6 +15,7 @@ func syscall_syscall6X(fn, a1, a2, a3, a4, a5, a6 uintptr) (r1, r2 uintptr, err | |||
| func syscall_syscall9(fn, a1, a2, a3, a4, a5, a6, a7, a8, a9 uintptr) (r1, r2 uintptr, err Errno) // 32-bit only | ||||
| func syscall_rawSyscall(fn, a1, a2, a3 uintptr) (r1, r2 uintptr, err Errno) | ||||
| func syscall_rawSyscall6(fn, a1, a2, a3, a4, a5, a6 uintptr) (r1, r2 uintptr, err Errno) | ||||
| func syscall_syscallPtr(fn, a1, a2, a3 uintptr) (r1, r2 uintptr, err Errno) | ||||
| 
 | ||||
| //go:linkname syscall_syscall syscall.syscall | ||||
| //go:linkname syscall_syscall6 syscall.syscall6 | ||||
|  | @ -22,6 +23,7 @@ func syscall_rawSyscall6(fn, a1, a2, a3, a4, a5, a6 uintptr) (r1, r2 uintptr, er | |||
| //go:linkname syscall_syscall9 syscall.syscall9 | ||||
| //go:linkname syscall_rawSyscall syscall.rawSyscall | ||||
| //go:linkname syscall_rawSyscall6 syscall.rawSyscall6 | ||||
| //go:linkname syscall_syscallPtr syscall.syscallPtr | ||||
| 
 | ||||
| // Find the entry point for f. See comments in runtime/proc.go for the | ||||
| // function of the same name. | ||||
|  |  | |||
							
								
								
									
										76
									
								
								vendor/golang.org/x/sys/unix/syscall_dragonfly.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										76
									
								
								vendor/golang.org/x/sys/unix/syscall_dragonfly.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -12,7 +12,25 @@ | |||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| import "unsafe" | ||||
| import ( | ||||
| 	"sync" | ||||
| 	"unsafe" | ||||
| ) | ||||
| 
 | ||||
| // See version list in https://github.com/DragonFlyBSD/DragonFlyBSD/blob/master/sys/sys/param.h | ||||
| var ( | ||||
| 	osreldateOnce sync.Once | ||||
| 	osreldate     uint32 | ||||
| ) | ||||
| 
 | ||||
| // First __DragonFly_version after September 2019 ABI changes | ||||
| // http://lists.dragonflybsd.org/pipermail/users/2019-September/358280.html | ||||
| const _dragonflyABIChangeVersion = 500705 | ||||
| 
 | ||||
| func supportsABI(ver uint32) bool { | ||||
| 	osreldateOnce.Do(func() { osreldate, _ = SysctlUint32("kern.osreldate") }) | ||||
| 	return osreldate >= ver | ||||
| } | ||||
| 
 | ||||
| // SockaddrDatalink implements the Sockaddr interface for AF_LINK type sockets. | ||||
| type SockaddrDatalink struct { | ||||
|  | @ -57,6 +75,22 @@ func nametomib(name string) (mib []_C_int, err error) { | |||
| 	return buf[0 : n/siz], nil | ||||
| } | ||||
| 
 | ||||
| func direntIno(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Fileno), unsafe.Sizeof(Dirent{}.Fileno)) | ||||
| } | ||||
| 
 | ||||
| func direntReclen(buf []byte) (uint64, bool) { | ||||
| 	namlen, ok := direntNamlen(buf) | ||||
| 	if !ok { | ||||
| 		return 0, false | ||||
| 	} | ||||
| 	return (16 + namlen + 1 + 7) &^ 7, true | ||||
| } | ||||
| 
 | ||||
| func direntNamlen(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Namlen), unsafe.Sizeof(Dirent{}.Namlen)) | ||||
| } | ||||
| 
 | ||||
| //sysnb pipe() (r int, w int, err error) | ||||
| 
 | ||||
| func Pipe(p []int) (err error) { | ||||
|  | @ -134,42 +168,7 @@ func setattrlistTimes(path string, times []Timespec, flags int) error { | |||
| 
 | ||||
| //sys	ioctl(fd int, req uint, arg uintptr) (err error) | ||||
| 
 | ||||
| // ioctl itself should not be exposed directly, but additional get/set | ||||
| // functions for specific types are permissible. | ||||
| 
 | ||||
| // IoctlSetInt performs an ioctl operation which sets an integer value | ||||
| // on fd, using the specified request number. | ||||
| func IoctlSetInt(fd int, req uint, value int) error { | ||||
| 	return ioctl(fd, req, uintptr(value)) | ||||
| } | ||||
| 
 | ||||
| func ioctlSetWinsize(fd int, req uint, value *Winsize) error { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| func ioctlSetTermios(fd int, req uint, value *Termios) error { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| // IoctlGetInt performs an ioctl operation which gets an integer value | ||||
| // from fd, using the specified request number. | ||||
| func IoctlGetInt(fd int, req uint) (int, error) { | ||||
| 	var value int | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetWinsize(fd int, req uint) (*Winsize, error) { | ||||
| 	var value Winsize | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetTermios(fd int, req uint) (*Termios, error) { | ||||
| 	var value Termios | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| //sys   sysctl(mib []_C_int, old *byte, oldlen *uintptr, new *byte, newlen uintptr) (err error) = SYS___SYSCTL | ||||
| 
 | ||||
| func sysctlUname(mib []_C_int, old *byte, oldlen *uintptr) error { | ||||
| 	err := sysctl(mib, old, oldlen, nil, 0) | ||||
|  | @ -269,6 +268,7 @@ func Sendfile(outfd int, infd int, offset *int64, count int) (written int, err e | |||
| //sys	Fstatfs(fd int, stat *Statfs_t) (err error) | ||||
| //sys	Fsync(fd int) (err error) | ||||
| //sys	Ftruncate(fd int, length int64) (err error) | ||||
| //sys	Getdents(fd int, buf []byte) (n int, err error) | ||||
| //sys	Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) | ||||
| //sys	Getdtablesize() (size int) | ||||
| //sysnb	Getegid() (egid int) | ||||
|  | @ -308,7 +308,7 @@ func Sendfile(outfd int, infd int, offset *int64, count int) (written int, err e | |||
| //sys	Revoke(path string) (err error) | ||||
| //sys	Rmdir(path string) (err error) | ||||
| //sys	Seek(fd int, offset int64, whence int) (newoffset int64, err error) = SYS_LSEEK | ||||
| //sys	Select(n int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (err error) | ||||
| //sys	Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) | ||||
| //sysnb	Setegid(egid int) (err error) | ||||
| //sysnb	Seteuid(euid int) (err error) | ||||
| //sysnb	Setgid(gid int) (err error) | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_dragonfly_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_dragonfly_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -33,6 +33,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = int32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										174
									
								
								vendor/golang.org/x/sys/unix/syscall_freebsd.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										174
									
								
								vendor/golang.org/x/sys/unix/syscall_freebsd.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -82,6 +82,18 @@ func nametomib(name string) (mib []_C_int, err error) { | |||
| 	return buf[0 : n/siz], nil | ||||
| } | ||||
| 
 | ||||
| func direntIno(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Fileno), unsafe.Sizeof(Dirent{}.Fileno)) | ||||
| } | ||||
| 
 | ||||
| func direntReclen(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Reclen), unsafe.Sizeof(Dirent{}.Reclen)) | ||||
| } | ||||
| 
 | ||||
| func direntNamlen(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Namlen), unsafe.Sizeof(Dirent{}.Namlen)) | ||||
| } | ||||
| 
 | ||||
| func Pipe(p []int) (err error) { | ||||
| 	return Pipe2(p, 0) | ||||
| } | ||||
|  | @ -189,42 +201,7 @@ func setattrlistTimes(path string, times []Timespec, flags int) error { | |||
| 
 | ||||
| //sys   ioctl(fd int, req uint, arg uintptr) (err error) | ||||
| 
 | ||||
| // ioctl itself should not be exposed directly, but additional get/set | ||||
| // functions for specific types are permissible. | ||||
| 
 | ||||
| // IoctlSetInt performs an ioctl operation which sets an integer value | ||||
| // on fd, using the specified request number. | ||||
| func IoctlSetInt(fd int, req uint, value int) error { | ||||
| 	return ioctl(fd, req, uintptr(value)) | ||||
| } | ||||
| 
 | ||||
| func ioctlSetWinsize(fd int, req uint, value *Winsize) error { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| func ioctlSetTermios(fd int, req uint, value *Termios) error { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| // IoctlGetInt performs an ioctl operation which gets an integer value | ||||
| // from fd, using the specified request number. | ||||
| func IoctlGetInt(fd int, req uint) (int, error) { | ||||
| 	var value int | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetWinsize(fd int, req uint) (*Winsize, error) { | ||||
| 	var value Winsize | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetTermios(fd int, req uint) (*Termios, error) { | ||||
| 	var value Termios | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| //sys   sysctl(mib []_C_int, old *byte, oldlen *uintptr, new *byte, newlen uintptr) (err error) = SYS___SYSCTL | ||||
| 
 | ||||
| func Uname(uname *Utsname) error { | ||||
| 	mib := []_C_int{CTL_KERN, KERN_OSTYPE} | ||||
|  | @ -362,7 +339,21 @@ func Getdents(fd int, buf []byte) (n int, err error) { | |||
| 
 | ||||
| func Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) { | ||||
| 	if supportsABI(_ino64First) { | ||||
| 		return getdirentries_freebsd12(fd, buf, basep) | ||||
| 		if basep == nil || unsafe.Sizeof(*basep) == 8 { | ||||
| 			return getdirentries_freebsd12(fd, buf, (*uint64)(unsafe.Pointer(basep))) | ||||
| 		} | ||||
| 		// The freebsd12 syscall needs a 64-bit base. On 32-bit machines | ||||
| 		// we can't just use the basep passed in. See #32498. | ||||
| 		var base uint64 = uint64(*basep) | ||||
| 		n, err = getdirentries_freebsd12(fd, buf, &base) | ||||
| 		*basep = uintptr(base) | ||||
| 		if base>>32 != 0 { | ||||
| 			// We can't stuff the base back into a uintptr, so any | ||||
| 			// future calls would be suspect. Generate an error. | ||||
| 			// EIO is allowed by getdirentries. | ||||
| 			err = EIO | ||||
| 		} | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	// The old syscall entries are smaller than the new. Use 1/4 of the original | ||||
|  | @ -404,22 +395,22 @@ func roundup(x, y int) int { | |||
| 
 | ||||
| func (s *Stat_t) convertFrom(old *stat_freebsd11_t) { | ||||
| 	*s = Stat_t{ | ||||
| 		Dev:      uint64(old.Dev), | ||||
| 		Ino:      uint64(old.Ino), | ||||
| 		Nlink:    uint64(old.Nlink), | ||||
| 		Mode:     old.Mode, | ||||
| 		Uid:      old.Uid, | ||||
| 		Gid:      old.Gid, | ||||
| 		Rdev:     uint64(old.Rdev), | ||||
| 		Atim:     old.Atim, | ||||
| 		Mtim:     old.Mtim, | ||||
| 		Ctim:     old.Ctim, | ||||
| 		Birthtim: old.Birthtim, | ||||
| 		Size:     old.Size, | ||||
| 		Blocks:   old.Blocks, | ||||
| 		Blksize:  old.Blksize, | ||||
| 		Flags:    old.Flags, | ||||
| 		Gen:      uint64(old.Gen), | ||||
| 		Dev:     uint64(old.Dev), | ||||
| 		Ino:     uint64(old.Ino), | ||||
| 		Nlink:   uint64(old.Nlink), | ||||
| 		Mode:    old.Mode, | ||||
| 		Uid:     old.Uid, | ||||
| 		Gid:     old.Gid, | ||||
| 		Rdev:    uint64(old.Rdev), | ||||
| 		Atim:    old.Atim, | ||||
| 		Mtim:    old.Mtim, | ||||
| 		Ctim:    old.Ctim, | ||||
| 		Btim:    old.Btim, | ||||
| 		Size:    old.Size, | ||||
| 		Blocks:  old.Blocks, | ||||
| 		Blksize: old.Blksize, | ||||
| 		Flags:   old.Flags, | ||||
| 		Gen:     uint64(old.Gen), | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
|  | @ -471,8 +462,12 @@ func convertFromDirents11(buf []byte, old []byte) int { | |||
| 	dstPos := 0 | ||||
| 	srcPos := 0 | ||||
| 	for dstPos+fixedSize < len(buf) && srcPos+oldFixedSize < len(old) { | ||||
| 		dstDirent := (*Dirent)(unsafe.Pointer(&buf[dstPos])) | ||||
| 		srcDirent := (*dirent_freebsd11)(unsafe.Pointer(&old[srcPos])) | ||||
| 		var dstDirent Dirent | ||||
| 		var srcDirent dirent_freebsd11 | ||||
| 
 | ||||
| 		// If multiple direntries are written, sometimes when we reach the final one, | ||||
| 		// we may have cap of old less than size of dirent_freebsd11. | ||||
| 		copy((*[unsafe.Sizeof(srcDirent)]byte)(unsafe.Pointer(&srcDirent))[:], old[srcPos:]) | ||||
| 
 | ||||
| 		reclen := roundup(fixedSize+int(srcDirent.Namlen)+1, 8) | ||||
| 		if dstPos+reclen > len(buf) { | ||||
|  | @ -488,6 +483,7 @@ func convertFromDirents11(buf []byte, old []byte) int { | |||
| 		dstDirent.Pad1 = 0 | ||||
| 
 | ||||
| 		copy(dstDirent.Name[:], srcDirent.Name[:srcDirent.Namlen]) | ||||
| 		copy(buf[dstPos:], (*[unsafe.Sizeof(dstDirent)]byte)(unsafe.Pointer(&dstDirent))[:]) | ||||
| 		padding := buf[dstPos+fixedSize+int(dstDirent.Namlen) : dstPos+reclen] | ||||
| 		for i := range padding { | ||||
| 			padding[i] = 0 | ||||
|  | @ -507,6 +503,70 @@ func Sendfile(outfd int, infd int, offset *int64, count int) (written int, err e | |||
| 	return sendfile(outfd, infd, offset, count) | ||||
| } | ||||
| 
 | ||||
| //sys	ptrace(request int, pid int, addr uintptr, data int) (err error) | ||||
| 
 | ||||
| func PtraceAttach(pid int) (err error) { | ||||
| 	return ptrace(PTRACE_ATTACH, pid, 0, 0) | ||||
| } | ||||
| 
 | ||||
| func PtraceCont(pid int, signal int) (err error) { | ||||
| 	return ptrace(PTRACE_CONT, pid, 1, signal) | ||||
| } | ||||
| 
 | ||||
| func PtraceDetach(pid int) (err error) { | ||||
| 	return ptrace(PTRACE_DETACH, pid, 1, 0) | ||||
| } | ||||
| 
 | ||||
| func PtraceGetFpRegs(pid int, fpregsout *FpReg) (err error) { | ||||
| 	return ptrace(PTRACE_GETFPREGS, pid, uintptr(unsafe.Pointer(fpregsout)), 0) | ||||
| } | ||||
| 
 | ||||
| func PtraceGetFsBase(pid int, fsbase *int64) (err error) { | ||||
| 	return ptrace(PTRACE_GETFSBASE, pid, uintptr(unsafe.Pointer(fsbase)), 0) | ||||
| } | ||||
| 
 | ||||
| func PtraceGetRegs(pid int, regsout *Reg) (err error) { | ||||
| 	return ptrace(PTRACE_GETREGS, pid, uintptr(unsafe.Pointer(regsout)), 0) | ||||
| } | ||||
| 
 | ||||
| func PtraceIO(req int, pid int, addr uintptr, out []byte, countin int) (count int, err error) { | ||||
| 	ioDesc := PtraceIoDesc{Op: int32(req), Offs: (*byte)(unsafe.Pointer(addr)), Addr: (*byte)(unsafe.Pointer(&out[0])), Len: uint(countin)} | ||||
| 	err = ptrace(PTRACE_IO, pid, uintptr(unsafe.Pointer(&ioDesc)), 0) | ||||
| 	return int(ioDesc.Len), err | ||||
| } | ||||
| 
 | ||||
| func PtraceLwpEvents(pid int, enable int) (err error) { | ||||
| 	return ptrace(PTRACE_LWPEVENTS, pid, 0, enable) | ||||
| } | ||||
| 
 | ||||
| func PtraceLwpInfo(pid int, info uintptr) (err error) { | ||||
| 	return ptrace(PTRACE_LWPINFO, pid, info, int(unsafe.Sizeof(PtraceLwpInfoStruct{}))) | ||||
| } | ||||
| 
 | ||||
| func PtracePeekData(pid int, addr uintptr, out []byte) (count int, err error) { | ||||
| 	return PtraceIO(PIOD_READ_D, pid, addr, out, SizeofLong) | ||||
| } | ||||
| 
 | ||||
| func PtracePeekText(pid int, addr uintptr, out []byte) (count int, err error) { | ||||
| 	return PtraceIO(PIOD_READ_I, pid, addr, out, SizeofLong) | ||||
| } | ||||
| 
 | ||||
| func PtracePokeData(pid int, addr uintptr, data []byte) (count int, err error) { | ||||
| 	return PtraceIO(PIOD_WRITE_D, pid, addr, data, SizeofLong) | ||||
| } | ||||
| 
 | ||||
| func PtracePokeText(pid int, addr uintptr, data []byte) (count int, err error) { | ||||
| 	return PtraceIO(PIOD_WRITE_I, pid, addr, data, SizeofLong) | ||||
| } | ||||
| 
 | ||||
| func PtraceSetRegs(pid int, regs *Reg) (err error) { | ||||
| 	return ptrace(PTRACE_SETREGS, pid, uintptr(unsafe.Pointer(regs)), 0) | ||||
| } | ||||
| 
 | ||||
| func PtraceSingleStep(pid int) (err error) { | ||||
| 	return ptrace(PTRACE_SINGLESTEP, pid, 1, 0) | ||||
| } | ||||
| 
 | ||||
| /* | ||||
|  * Exposed directly | ||||
|  */ | ||||
|  | @ -555,7 +615,7 @@ func Sendfile(outfd int, infd int, offset *int64, count int) (written int, err e | |||
| //sys	Fsync(fd int) (err error) | ||||
| //sys	Ftruncate(fd int, length int64) (err error) | ||||
| //sys	getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) | ||||
| //sys	getdirentries_freebsd12(fd int, buf []byte, basep *uintptr) (n int, err error) | ||||
| //sys	getdirentries_freebsd12(fd int, buf []byte, basep *uint64) (n int, err error) | ||||
| //sys	Getdtablesize() (size int) | ||||
| //sysnb	Getegid() (egid int) | ||||
| //sysnb	Geteuid() (uid int) | ||||
|  | @ -598,7 +658,7 @@ func Sendfile(outfd int, infd int, offset *int64, count int) (written int, err e | |||
| //sys	Revoke(path string) (err error) | ||||
| //sys	Rmdir(path string) (err error) | ||||
| //sys	Seek(fd int, offset int64, whence int) (newoffset int64, err error) = SYS_LSEEK | ||||
| //sys	Select(n int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (err error) | ||||
| //sys	Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) | ||||
| //sysnb	Setegid(egid int) (err error) | ||||
| //sysnb	Seteuid(euid int) (err error) | ||||
| //sysnb	Setgid(gid int) (err error) | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_freebsd_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_freebsd_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -33,6 +33,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = int32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_freebsd_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_freebsd_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -33,6 +33,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = int32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_freebsd_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_freebsd_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -33,6 +33,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = int32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_freebsd_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_freebsd_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -33,6 +33,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = int32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										463
									
								
								vendor/golang.org/x/sys/unix/syscall_linux.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										463
									
								
								vendor/golang.org/x/sys/unix/syscall_linux.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -13,7 +13,6 @@ package unix | |||
| 
 | ||||
| import ( | ||||
| 	"encoding/binary" | ||||
| 	"net" | ||||
| 	"runtime" | ||||
| 	"syscall" | ||||
| 	"unsafe" | ||||
|  | @ -39,6 +38,20 @@ func Creat(path string, mode uint32) (fd int, err error) { | |||
| 	return Open(path, O_CREAT|O_WRONLY|O_TRUNC, mode) | ||||
| } | ||||
| 
 | ||||
| //sys	FanotifyInit(flags uint, event_f_flags uint) (fd int, err error) | ||||
| //sys	fanotifyMark(fd int, flags uint, mask uint64, dirFd int, pathname *byte) (err error) | ||||
| 
 | ||||
| func FanotifyMark(fd int, flags uint, mask uint64, dirFd int, pathname string) (err error) { | ||||
| 	if pathname == "" { | ||||
| 		return fanotifyMark(fd, flags, mask, dirFd, nil) | ||||
| 	} | ||||
| 	p, err := BytePtrFromString(pathname) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	return fanotifyMark(fd, flags, mask, dirFd, p) | ||||
| } | ||||
| 
 | ||||
| //sys	fchmodat(dirfd int, path string, mode uint32) (err error) | ||||
| 
 | ||||
| func Fchmodat(dirfd int, path string, mode uint32, flags int) (err error) { | ||||
|  | @ -58,6 +71,17 @@ func Fchmodat(dirfd int, path string, mode uint32, flags int) (err error) { | |||
| // ioctl itself should not be exposed directly, but additional get/set | ||||
| // functions for specific types are permissible. | ||||
| 
 | ||||
| // IoctlRetInt performs an ioctl operation specified by req on a device | ||||
| // associated with opened file descriptor fd, and returns a non-negative | ||||
| // integer that is returned by the ioctl syscall. | ||||
| func IoctlRetInt(fd int, req uint) (int, error) { | ||||
| 	ret, _, err := Syscall(SYS_IOCTL, uintptr(fd), uintptr(req), 0) | ||||
| 	if err != 0 { | ||||
| 		return 0, err | ||||
| 	} | ||||
| 	return int(ret), nil | ||||
| } | ||||
| 
 | ||||
| // IoctlSetPointerInt performs an ioctl operation which sets an | ||||
| // integer value on fd, using the specified request number. The ioctl | ||||
| // argument is called with a pointer to the integer value, rather than | ||||
|  | @ -67,46 +91,18 @@ func IoctlSetPointerInt(fd int, req uint, value int) error { | |||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(&v))) | ||||
| } | ||||
| 
 | ||||
| // IoctlSetInt performs an ioctl operation which sets an integer value | ||||
| // on fd, using the specified request number. | ||||
| func IoctlSetInt(fd int, req uint, value int) error { | ||||
| 	return ioctl(fd, req, uintptr(value)) | ||||
| } | ||||
| 
 | ||||
| func ioctlSetWinsize(fd int, req uint, value *Winsize) error { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| func ioctlSetTermios(fd int, req uint, value *Termios) error { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| func IoctlSetRTCTime(fd int, value *RTCTime) error { | ||||
| 	err := ioctl(fd, RTC_SET_TIME, uintptr(unsafe.Pointer(value))) | ||||
| 	runtime.KeepAlive(value) | ||||
| 	return err | ||||
| } | ||||
| 
 | ||||
| // IoctlGetInt performs an ioctl operation which gets an integer value | ||||
| // from fd, using the specified request number. | ||||
| func IoctlGetInt(fd int, req uint) (int, error) { | ||||
| 	var value int | ||||
| func IoctlGetUint32(fd int, req uint) (uint32, error) { | ||||
| 	var value uint32 | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetWinsize(fd int, req uint) (*Winsize, error) { | ||||
| 	var value Winsize | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetTermios(fd int, req uint) (*Termios, error) { | ||||
| 	var value Termios | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetRTCTime(fd int) (*RTCTime, error) { | ||||
| 	var value RTCTime | ||||
| 	err := ioctl(fd, RTC_RD_TIME, uintptr(unsafe.Pointer(&value))) | ||||
|  | @ -745,7 +741,7 @@ const px_proto_oe = 0 | |||
| 
 | ||||
| type SockaddrPPPoE struct { | ||||
| 	SID    uint16 | ||||
| 	Remote net.HardwareAddr | ||||
| 	Remote []byte | ||||
| 	Dev    string | ||||
| 	raw    RawSockaddrPPPoX | ||||
| } | ||||
|  | @ -779,6 +775,70 @@ func (sa *SockaddrPPPoE) sockaddr() (unsafe.Pointer, _Socklen, error) { | |||
| 	return unsafe.Pointer(&sa.raw), SizeofSockaddrPPPoX, nil | ||||
| } | ||||
| 
 | ||||
| // SockaddrTIPC implements the Sockaddr interface for AF_TIPC type sockets. | ||||
| // For more information on TIPC, see: http://tipc.sourceforge.net/. | ||||
| type SockaddrTIPC struct { | ||||
| 	// Scope is the publication scopes when binding service/service range. | ||||
| 	// Should be set to TIPC_CLUSTER_SCOPE or TIPC_NODE_SCOPE. | ||||
| 	Scope int | ||||
| 
 | ||||
| 	// Addr is the type of address used to manipulate a socket. Addr must be | ||||
| 	// one of: | ||||
| 	//  - *TIPCSocketAddr: "id" variant in the C addr union | ||||
| 	//  - *TIPCServiceRange: "nameseq" variant in the C addr union | ||||
| 	//  - *TIPCServiceName: "name" variant in the C addr union | ||||
| 	// | ||||
| 	// If nil, EINVAL will be returned when the structure is used. | ||||
| 	Addr TIPCAddr | ||||
| 
 | ||||
| 	raw RawSockaddrTIPC | ||||
| } | ||||
| 
 | ||||
| // TIPCAddr is implemented by types that can be used as an address for | ||||
| // SockaddrTIPC. It is only implemented by *TIPCSocketAddr, *TIPCServiceRange, | ||||
| // and *TIPCServiceName. | ||||
| type TIPCAddr interface { | ||||
| 	tipcAddrtype() uint8 | ||||
| 	tipcAddr() [12]byte | ||||
| } | ||||
| 
 | ||||
| func (sa *TIPCSocketAddr) tipcAddr() [12]byte { | ||||
| 	var out [12]byte | ||||
| 	copy(out[:], (*(*[unsafe.Sizeof(TIPCSocketAddr{})]byte)(unsafe.Pointer(sa)))[:]) | ||||
| 	return out | ||||
| } | ||||
| 
 | ||||
| func (sa *TIPCSocketAddr) tipcAddrtype() uint8 { return TIPC_SOCKET_ADDR } | ||||
| 
 | ||||
| func (sa *TIPCServiceRange) tipcAddr() [12]byte { | ||||
| 	var out [12]byte | ||||
| 	copy(out[:], (*(*[unsafe.Sizeof(TIPCServiceRange{})]byte)(unsafe.Pointer(sa)))[:]) | ||||
| 	return out | ||||
| } | ||||
| 
 | ||||
| func (sa *TIPCServiceRange) tipcAddrtype() uint8 { return TIPC_SERVICE_RANGE } | ||||
| 
 | ||||
| func (sa *TIPCServiceName) tipcAddr() [12]byte { | ||||
| 	var out [12]byte | ||||
| 	copy(out[:], (*(*[unsafe.Sizeof(TIPCServiceName{})]byte)(unsafe.Pointer(sa)))[:]) | ||||
| 	return out | ||||
| } | ||||
| 
 | ||||
| func (sa *TIPCServiceName) tipcAddrtype() uint8 { return TIPC_SERVICE_ADDR } | ||||
| 
 | ||||
| func (sa *SockaddrTIPC) sockaddr() (unsafe.Pointer, _Socklen, error) { | ||||
| 	if sa.Addr == nil { | ||||
| 		return nil, 0, EINVAL | ||||
| 	} | ||||
| 
 | ||||
| 	sa.raw.Family = AF_TIPC | ||||
| 	sa.raw.Scope = int8(sa.Scope) | ||||
| 	sa.raw.Addrtype = sa.Addr.tipcAddrtype() | ||||
| 	sa.raw.Addr = sa.Addr.tipcAddr() | ||||
| 
 | ||||
| 	return unsafe.Pointer(&sa.raw), SizeofSockaddrTIPC, nil | ||||
| } | ||||
| 
 | ||||
| func anyToSockaddr(fd int, rsa *RawSockaddrAny) (Sockaddr, error) { | ||||
| 	switch rsa.Addr.Family { | ||||
| 	case AF_NETLINK: | ||||
|  | @ -824,7 +884,7 @@ func anyToSockaddr(fd int, rsa *RawSockaddrAny) (Sockaddr, error) { | |||
| 		for n < len(pp.Path) && pp.Path[n] != 0 { | ||||
| 			n++ | ||||
| 		} | ||||
| 		bytes := (*[10000]byte)(unsafe.Pointer(&pp.Path[0]))[0:n] | ||||
| 		bytes := (*[len(pp.Path)]byte)(unsafe.Pointer(&pp.Path[0]))[0:n] | ||||
| 		sa.Name = string(bytes) | ||||
| 		return sa, nil | ||||
| 
 | ||||
|  | @ -896,7 +956,7 @@ func anyToSockaddr(fd int, rsa *RawSockaddrAny) (Sockaddr, error) { | |||
| 		} | ||||
| 		sa := &SockaddrPPPoE{ | ||||
| 			SID:    binary.BigEndian.Uint16(pp[6:8]), | ||||
| 			Remote: net.HardwareAddr(pp[8:14]), | ||||
| 			Remote: pp[8:14], | ||||
| 		} | ||||
| 		for i := 14; i < 14+IFNAMSIZ; i++ { | ||||
| 			if pp[i] == 0 { | ||||
|  | @ -904,6 +964,27 @@ func anyToSockaddr(fd int, rsa *RawSockaddrAny) (Sockaddr, error) { | |||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 		return sa, nil | ||||
| 	case AF_TIPC: | ||||
| 		pp := (*RawSockaddrTIPC)(unsafe.Pointer(rsa)) | ||||
| 
 | ||||
| 		sa := &SockaddrTIPC{ | ||||
| 			Scope: int(pp.Scope), | ||||
| 		} | ||||
| 
 | ||||
| 		// Determine which union variant is present in pp.Addr by checking | ||||
| 		// pp.Addrtype. | ||||
| 		switch pp.Addrtype { | ||||
| 		case TIPC_SERVICE_RANGE: | ||||
| 			sa.Addr = (*TIPCServiceRange)(unsafe.Pointer(&pp.Addr)) | ||||
| 		case TIPC_SERVICE_ADDR: | ||||
| 			sa.Addr = (*TIPCServiceName)(unsafe.Pointer(&pp.Addr)) | ||||
| 		case TIPC_SOCKET_ADDR: | ||||
| 			sa.Addr = (*TIPCSocketAddr)(unsafe.Pointer(&pp.Addr)) | ||||
| 		default: | ||||
| 			return nil, EINVAL | ||||
| 		} | ||||
| 
 | ||||
| 		return sa, nil | ||||
| 	} | ||||
| 	return nil, EAFNOSUPPORT | ||||
|  | @ -990,10 +1071,50 @@ func GetsockoptString(fd, level, opt int) (string, error) { | |||
| 	return string(buf[:vallen-1]), nil | ||||
| } | ||||
| 
 | ||||
| func GetsockoptTpacketStats(fd, level, opt int) (*TpacketStats, error) { | ||||
| 	var value TpacketStats | ||||
| 	vallen := _Socklen(SizeofTpacketStats) | ||||
| 	err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen) | ||||
| 	return &value, err | ||||
| } | ||||
| 
 | ||||
| func GetsockoptTpacketStatsV3(fd, level, opt int) (*TpacketStatsV3, error) { | ||||
| 	var value TpacketStatsV3 | ||||
| 	vallen := _Socklen(SizeofTpacketStatsV3) | ||||
| 	err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen) | ||||
| 	return &value, err | ||||
| } | ||||
| 
 | ||||
| func SetsockoptIPMreqn(fd, level, opt int, mreq *IPMreqn) (err error) { | ||||
| 	return setsockopt(fd, level, opt, unsafe.Pointer(mreq), unsafe.Sizeof(*mreq)) | ||||
| } | ||||
| 
 | ||||
| func SetsockoptPacketMreq(fd, level, opt int, mreq *PacketMreq) error { | ||||
| 	return setsockopt(fd, level, opt, unsafe.Pointer(mreq), unsafe.Sizeof(*mreq)) | ||||
| } | ||||
| 
 | ||||
| // SetsockoptSockFprog attaches a classic BPF or an extended BPF program to a | ||||
| // socket to filter incoming packets.  See 'man 7 socket' for usage information. | ||||
| func SetsockoptSockFprog(fd, level, opt int, fprog *SockFprog) error { | ||||
| 	return setsockopt(fd, level, opt, unsafe.Pointer(fprog), unsafe.Sizeof(*fprog)) | ||||
| } | ||||
| 
 | ||||
| func SetsockoptCanRawFilter(fd, level, opt int, filter []CanFilter) error { | ||||
| 	var p unsafe.Pointer | ||||
| 	if len(filter) > 0 { | ||||
| 		p = unsafe.Pointer(&filter[0]) | ||||
| 	} | ||||
| 	return setsockopt(fd, level, opt, p, uintptr(len(filter)*SizeofCanFilter)) | ||||
| } | ||||
| 
 | ||||
| func SetsockoptTpacketReq(fd, level, opt int, tp *TpacketReq) error { | ||||
| 	return setsockopt(fd, level, opt, unsafe.Pointer(tp), unsafe.Sizeof(*tp)) | ||||
| } | ||||
| 
 | ||||
| func SetsockoptTpacketReq3(fd, level, opt int, tp *TpacketReq3) error { | ||||
| 	return setsockopt(fd, level, opt, unsafe.Pointer(tp), unsafe.Sizeof(*tp)) | ||||
| } | ||||
| 
 | ||||
| // Keyctl Commands (http://man7.org/linux/man-pages/man2/keyctl.2.html) | ||||
| 
 | ||||
| // KeyctlInt calls keyctl commands in which each argument is an int. | ||||
|  | @ -1101,6 +1222,34 @@ func KeyctlDHCompute(params *KeyctlDHParams, buffer []byte) (size int, err error | |||
| 	return keyctlDH(KEYCTL_DH_COMPUTE, params, buffer) | ||||
| } | ||||
| 
 | ||||
| // KeyctlRestrictKeyring implements the KEYCTL_RESTRICT_KEYRING command. This | ||||
| // command limits the set of keys that can be linked to the keyring, regardless | ||||
| // of keyring permissions. The command requires the "setattr" permission. | ||||
| // | ||||
| // When called with an empty keyType the command locks the keyring, preventing | ||||
| // any further keys from being linked to the keyring. | ||||
| // | ||||
| // The "asymmetric" keyType defines restrictions requiring key payloads to be | ||||
| // DER encoded X.509 certificates signed by keys in another keyring. Restrictions | ||||
| // for "asymmetric" include "builtin_trusted", "builtin_and_secondary_trusted", | ||||
| // "key_or_keyring:<key>", and "key_or_keyring:<key>:chain". | ||||
| // | ||||
| // As of Linux 4.12, only the "asymmetric" keyType defines type-specific | ||||
| // restrictions. | ||||
| // | ||||
| // See the full documentation at: | ||||
| // http://man7.org/linux/man-pages/man3/keyctl_restrict_keyring.3.html | ||||
| // http://man7.org/linux/man-pages/man2/keyctl.2.html | ||||
| func KeyctlRestrictKeyring(ringid int, keyType string, restriction string) error { | ||||
| 	if keyType == "" { | ||||
| 		return keyctlRestrictKeyring(KEYCTL_RESTRICT_KEYRING, ringid) | ||||
| 	} | ||||
| 	return keyctlRestrictKeyringByType(KEYCTL_RESTRICT_KEYRING, ringid, keyType, restriction) | ||||
| } | ||||
| 
 | ||||
| //sys keyctlRestrictKeyringByType(cmd int, arg2 int, keyType string, restriction string) (err error) = SYS_KEYCTL | ||||
| //sys keyctlRestrictKeyring(cmd int, arg2 int) (err error) = SYS_KEYCTL | ||||
| 
 | ||||
| func Recvmsg(fd int, p, oob []byte, flags int) (n, oobn int, recvflags int, from Sockaddr, err error) { | ||||
| 	var msg Msghdr | ||||
| 	var rsa RawSockaddrAny | ||||
|  | @ -1344,8 +1493,12 @@ func PtraceSyscall(pid int, signal int) (err error) { | |||
| 
 | ||||
| func PtraceSingleStep(pid int) (err error) { return ptrace(PTRACE_SINGLESTEP, pid, 0, 0) } | ||||
| 
 | ||||
| func PtraceInterrupt(pid int) (err error) { return ptrace(PTRACE_INTERRUPT, pid, 0, 0) } | ||||
| 
 | ||||
| func PtraceAttach(pid int) (err error) { return ptrace(PTRACE_ATTACH, pid, 0, 0) } | ||||
| 
 | ||||
| func PtraceSeize(pid int) (err error) { return ptrace(PTRACE_SEIZE, pid, 0, 0) } | ||||
| 
 | ||||
| func PtraceDetach(pid int) (err error) { return ptrace(PTRACE_DETACH, pid, 0, 0) } | ||||
| 
 | ||||
| //sys	reboot(magic1 uint, magic2 uint, cmd int, arg string) (err error) | ||||
|  | @ -1354,8 +1507,20 @@ func Reboot(cmd int) (err error) { | |||
| 	return reboot(LINUX_REBOOT_MAGIC1, LINUX_REBOOT_MAGIC2, cmd, "") | ||||
| } | ||||
| 
 | ||||
| func ReadDirent(fd int, buf []byte) (n int, err error) { | ||||
| 	return Getdents(fd, buf) | ||||
| func direntIno(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Ino), unsafe.Sizeof(Dirent{}.Ino)) | ||||
| } | ||||
| 
 | ||||
| func direntReclen(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Reclen), unsafe.Sizeof(Dirent{}.Reclen)) | ||||
| } | ||||
| 
 | ||||
| func direntNamlen(buf []byte) (uint64, bool) { | ||||
| 	reclen, ok := direntReclen(buf) | ||||
| 	if !ok { | ||||
| 		return 0, false | ||||
| 	} | ||||
| 	return reclen - uint64(unsafe.Offsetof(Dirent{}.Name)), true | ||||
| } | ||||
| 
 | ||||
| //sys	mount(source string, target string, fstype string, flags uintptr, data *byte) (err error) | ||||
|  | @ -1390,6 +1555,8 @@ func Sendfile(outfd int, infd int, offset *int64, count int) (written int, err e | |||
| //sys	Acct(path string) (err error) | ||||
| //sys	AddKey(keyType string, description string, payload []byte, ringid int) (id int, err error) | ||||
| //sys	Adjtimex(buf *Timex) (state int, err error) | ||||
| //sys	Capget(hdr *CapUserHeader, data *CapUserData) (err error) | ||||
| //sys	Capset(hdr *CapUserHeader, data *CapUserData) (err error) | ||||
| //sys	Chdir(path string) (err error) | ||||
| //sys	Chroot(path string) (err error) | ||||
| //sys	ClockGetres(clockid int32, res *Timespec) (err error) | ||||
|  | @ -1408,7 +1575,6 @@ func Sendfile(outfd int, infd int, offset *int64, count int) (written int, err e | |||
| //sys	Fchdir(fd int) (err error) | ||||
| //sys	Fchmod(fd int, mode uint32) (err error) | ||||
| //sys	Fchownat(dirfd int, path string, uid int, gid int, flags int) (err error) | ||||
| //sys	fcntl(fd int, cmd int, arg int) (val int, err error) | ||||
| //sys	Fdatasync(fd int) (err error) | ||||
| //sys	Fgetxattr(fd int, attr string, dest []byte) (sz int, err error) | ||||
| //sys	FinitModule(fd int, params string, flags int) (err error) | ||||
|  | @ -1464,6 +1630,17 @@ func Getpgrp() (pid int) { | |||
| //sysnb	Settimeofday(tv *Timeval) (err error) | ||||
| //sys	Setns(fd int, nstype int) (err error) | ||||
| 
 | ||||
| // PrctlRetInt performs a prctl operation specified by option and further | ||||
| // optional arguments arg2 through arg5 depending on option. It returns a | ||||
| // non-negative integer that is returned by the prctl syscall. | ||||
| func PrctlRetInt(option int, arg2 uintptr, arg3 uintptr, arg4 uintptr, arg5 uintptr) (int, error) { | ||||
| 	ret, _, err := Syscall6(SYS_PRCTL, uintptr(option), uintptr(arg2), uintptr(arg3), uintptr(arg4), uintptr(arg5), 0) | ||||
| 	if err != 0 { | ||||
| 		return 0, err | ||||
| 	} | ||||
| 	return int(ret), nil | ||||
| } | ||||
| 
 | ||||
| // issue 1435. | ||||
| // On linux Setuid and Setgid only affects the current thread, not the process. | ||||
| // This does not match what most callers expect so we must return an error | ||||
|  | @ -1477,9 +1654,13 @@ func Setgid(uid int) (err error) { | |||
| 	return EOPNOTSUPP | ||||
| } | ||||
| 
 | ||||
| func Signalfd(fd int, sigmask *Sigset_t, flags int) (newfd int, err error) { | ||||
| 	return signalfd(fd, sigmask, _C__NSIG/8, flags) | ||||
| } | ||||
| 
 | ||||
| //sys	Setpriority(which int, who int, prio int) (err error) | ||||
| //sys	Setxattr(path string, attr string, data []byte, flags int) (err error) | ||||
| //sys	Signalfd(fd int, mask *Sigset_t, flags int) = SYS_SIGNALFD4 | ||||
| //sys	signalfd(fd int, sigmask *Sigset_t, maskSize uintptr, flags int) (newfd int, err error) = SYS_SIGNALFD4 | ||||
| //sys	Statx(dirfd int, path string, flags int, mask int, stat *Statx_t) (err error) | ||||
| //sys	Sync() | ||||
| //sys	Syncfs(fd int) (err error) | ||||
|  | @ -1495,6 +1676,123 @@ func Setgid(uid int) (err error) { | |||
| //sys	exitThread(code int) (err error) = SYS_EXIT | ||||
| //sys	readlen(fd int, p *byte, np int) (n int, err error) = SYS_READ | ||||
| //sys	writelen(fd int, p *byte, np int) (n int, err error) = SYS_WRITE | ||||
| //sys	readv(fd int, iovs []Iovec) (n int, err error) = SYS_READV | ||||
| //sys	writev(fd int, iovs []Iovec) (n int, err error) = SYS_WRITEV | ||||
| //sys	preadv(fd int, iovs []Iovec, offs_l uintptr, offs_h uintptr) (n int, err error) = SYS_PREADV | ||||
| //sys	pwritev(fd int, iovs []Iovec, offs_l uintptr, offs_h uintptr) (n int, err error) = SYS_PWRITEV | ||||
| //sys	preadv2(fd int, iovs []Iovec, offs_l uintptr, offs_h uintptr, flags int) (n int, err error) = SYS_PREADV2 | ||||
| //sys	pwritev2(fd int, iovs []Iovec, offs_l uintptr, offs_h uintptr, flags int) (n int, err error) = SYS_PWRITEV2 | ||||
| 
 | ||||
| func bytes2iovec(bs [][]byte) []Iovec { | ||||
| 	iovecs := make([]Iovec, len(bs)) | ||||
| 	for i, b := range bs { | ||||
| 		iovecs[i].SetLen(len(b)) | ||||
| 		if len(b) > 0 { | ||||
| 			iovecs[i].Base = &b[0] | ||||
| 		} else { | ||||
| 			iovecs[i].Base = (*byte)(unsafe.Pointer(&_zero)) | ||||
| 		} | ||||
| 	} | ||||
| 	return iovecs | ||||
| } | ||||
| 
 | ||||
| // offs2lohi splits offs into its lower and upper unsigned long. On 64-bit | ||||
| // systems, hi will always be 0. On 32-bit systems, offs will be split in half. | ||||
| // preadv/pwritev chose this calling convention so they don't need to add a | ||||
| // padding-register for alignment on ARM. | ||||
| func offs2lohi(offs int64) (lo, hi uintptr) { | ||||
| 	return uintptr(offs), uintptr(uint64(offs) >> SizeofLong) | ||||
| } | ||||
| 
 | ||||
| func Readv(fd int, iovs [][]byte) (n int, err error) { | ||||
| 	iovecs := bytes2iovec(iovs) | ||||
| 	n, err = readv(fd, iovecs) | ||||
| 	readvRacedetect(iovecs, n, err) | ||||
| 	return n, err | ||||
| } | ||||
| 
 | ||||
| func Preadv(fd int, iovs [][]byte, offset int64) (n int, err error) { | ||||
| 	iovecs := bytes2iovec(iovs) | ||||
| 	lo, hi := offs2lohi(offset) | ||||
| 	n, err = preadv(fd, iovecs, lo, hi) | ||||
| 	readvRacedetect(iovecs, n, err) | ||||
| 	return n, err | ||||
| } | ||||
| 
 | ||||
| func Preadv2(fd int, iovs [][]byte, offset int64, flags int) (n int, err error) { | ||||
| 	iovecs := bytes2iovec(iovs) | ||||
| 	lo, hi := offs2lohi(offset) | ||||
| 	n, err = preadv2(fd, iovecs, lo, hi, flags) | ||||
| 	readvRacedetect(iovecs, n, err) | ||||
| 	return n, err | ||||
| } | ||||
| 
 | ||||
| func readvRacedetect(iovecs []Iovec, n int, err error) { | ||||
| 	if !raceenabled { | ||||
| 		return | ||||
| 	} | ||||
| 	for i := 0; n > 0 && i < len(iovecs); i++ { | ||||
| 		m := int(iovecs[i].Len) | ||||
| 		if m > n { | ||||
| 			m = n | ||||
| 		} | ||||
| 		n -= m | ||||
| 		if m > 0 { | ||||
| 			raceWriteRange(unsafe.Pointer(iovecs[i].Base), m) | ||||
| 		} | ||||
| 	} | ||||
| 	if err == nil { | ||||
| 		raceAcquire(unsafe.Pointer(&ioSync)) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func Writev(fd int, iovs [][]byte) (n int, err error) { | ||||
| 	iovecs := bytes2iovec(iovs) | ||||
| 	if raceenabled { | ||||
| 		raceReleaseMerge(unsafe.Pointer(&ioSync)) | ||||
| 	} | ||||
| 	n, err = writev(fd, iovecs) | ||||
| 	writevRacedetect(iovecs, n) | ||||
| 	return n, err | ||||
| } | ||||
| 
 | ||||
| func Pwritev(fd int, iovs [][]byte, offset int64) (n int, err error) { | ||||
| 	iovecs := bytes2iovec(iovs) | ||||
| 	if raceenabled { | ||||
| 		raceReleaseMerge(unsafe.Pointer(&ioSync)) | ||||
| 	} | ||||
| 	lo, hi := offs2lohi(offset) | ||||
| 	n, err = pwritev(fd, iovecs, lo, hi) | ||||
| 	writevRacedetect(iovecs, n) | ||||
| 	return n, err | ||||
| } | ||||
| 
 | ||||
| func Pwritev2(fd int, iovs [][]byte, offset int64, flags int) (n int, err error) { | ||||
| 	iovecs := bytes2iovec(iovs) | ||||
| 	if raceenabled { | ||||
| 		raceReleaseMerge(unsafe.Pointer(&ioSync)) | ||||
| 	} | ||||
| 	lo, hi := offs2lohi(offset) | ||||
| 	n, err = pwritev2(fd, iovecs, lo, hi, flags) | ||||
| 	writevRacedetect(iovecs, n) | ||||
| 	return n, err | ||||
| } | ||||
| 
 | ||||
| func writevRacedetect(iovecs []Iovec, n int) { | ||||
| 	if !raceenabled { | ||||
| 		return | ||||
| 	} | ||||
| 	for i := 0; n > 0 && i < len(iovecs); i++ { | ||||
| 		m := int(iovecs[i].Len) | ||||
| 		if m > n { | ||||
| 			m = n | ||||
| 		} | ||||
| 		n -= m | ||||
| 		if m > 0 { | ||||
| 			raceReadRange(unsafe.Pointer(iovecs[i].Base), m) | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // mmap varies by architecture; see syscall_linux_*.go. | ||||
| //sys	munmap(addr uintptr, length uintptr) (err error) | ||||
|  | @ -1608,6 +1906,93 @@ func Faccessat(dirfd int, path string, mode uint32, flags int) (err error) { | |||
| 	return EACCES | ||||
| } | ||||
| 
 | ||||
| //sys nameToHandleAt(dirFD int, pathname string, fh *fileHandle, mountID *_C_int, flags int) (err error) = SYS_NAME_TO_HANDLE_AT | ||||
| //sys openByHandleAt(mountFD int, fh *fileHandle, flags int) (fd int, err error) = SYS_OPEN_BY_HANDLE_AT | ||||
| 
 | ||||
| // fileHandle is the argument to nameToHandleAt and openByHandleAt. We | ||||
| // originally tried to generate it via unix/linux/types.go with "type | ||||
| // fileHandle C.struct_file_handle" but that generated empty structs | ||||
| // for mips64 and mips64le. Instead, hard code it for now (it's the | ||||
| // same everywhere else) until the mips64 generator issue is fixed. | ||||
| type fileHandle struct { | ||||
| 	Bytes uint32 | ||||
| 	Type  int32 | ||||
| } | ||||
| 
 | ||||
| // FileHandle represents the C struct file_handle used by | ||||
| // name_to_handle_at (see NameToHandleAt) and open_by_handle_at (see | ||||
| // OpenByHandleAt). | ||||
| type FileHandle struct { | ||||
| 	*fileHandle | ||||
| } | ||||
| 
 | ||||
| // NewFileHandle constructs a FileHandle. | ||||
| func NewFileHandle(handleType int32, handle []byte) FileHandle { | ||||
| 	const hdrSize = unsafe.Sizeof(fileHandle{}) | ||||
| 	buf := make([]byte, hdrSize+uintptr(len(handle))) | ||||
| 	copy(buf[hdrSize:], handle) | ||||
| 	fh := (*fileHandle)(unsafe.Pointer(&buf[0])) | ||||
| 	fh.Type = handleType | ||||
| 	fh.Bytes = uint32(len(handle)) | ||||
| 	return FileHandle{fh} | ||||
| } | ||||
| 
 | ||||
| func (fh *FileHandle) Size() int   { return int(fh.fileHandle.Bytes) } | ||||
| func (fh *FileHandle) Type() int32 { return fh.fileHandle.Type } | ||||
| func (fh *FileHandle) Bytes() []byte { | ||||
| 	n := fh.Size() | ||||
| 	if n == 0 { | ||||
| 		return nil | ||||
| 	} | ||||
| 	return (*[1 << 30]byte)(unsafe.Pointer(uintptr(unsafe.Pointer(&fh.fileHandle.Type)) + 4))[:n:n] | ||||
| } | ||||
| 
 | ||||
| // NameToHandleAt wraps the name_to_handle_at system call; it obtains | ||||
| // a handle for a path name. | ||||
| func NameToHandleAt(dirfd int, path string, flags int) (handle FileHandle, mountID int, err error) { | ||||
| 	var mid _C_int | ||||
| 	// Try first with a small buffer, assuming the handle will | ||||
| 	// only be 32 bytes. | ||||
| 	size := uint32(32 + unsafe.Sizeof(fileHandle{})) | ||||
| 	didResize := false | ||||
| 	for { | ||||
| 		buf := make([]byte, size) | ||||
| 		fh := (*fileHandle)(unsafe.Pointer(&buf[0])) | ||||
| 		fh.Bytes = size - uint32(unsafe.Sizeof(fileHandle{})) | ||||
| 		err = nameToHandleAt(dirfd, path, fh, &mid, flags) | ||||
| 		if err == EOVERFLOW { | ||||
| 			if didResize { | ||||
| 				// We shouldn't need to resize more than once | ||||
| 				return | ||||
| 			} | ||||
| 			didResize = true | ||||
| 			size = fh.Bytes + uint32(unsafe.Sizeof(fileHandle{})) | ||||
| 			continue | ||||
| 		} | ||||
| 		if err != nil { | ||||
| 			return | ||||
| 		} | ||||
| 		return FileHandle{fh}, int(mid), nil | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // OpenByHandleAt wraps the open_by_handle_at system call; it opens a | ||||
| // file via a handle as previously returned by NameToHandleAt. | ||||
| func OpenByHandleAt(mountFD int, handle FileHandle, flags int) (fd int, err error) { | ||||
| 	return openByHandleAt(mountFD, handle.fileHandle, flags) | ||||
| } | ||||
| 
 | ||||
| // Klogset wraps the sys_syslog system call; it sets console_loglevel to | ||||
| // the value specified by arg and passes a dummy pointer to bufp. | ||||
| func Klogset(typ int, arg int) (err error) { | ||||
| 	var p unsafe.Pointer | ||||
| 	_, _, errno := Syscall(SYS_SYSLOG, uintptr(typ), uintptr(p), uintptr(arg)) | ||||
| 	if errno != 0 { | ||||
| 		return errnoErr(errno) | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| /* | ||||
|  * Unimplemented | ||||
|  */ | ||||
|  | @ -1615,8 +2000,6 @@ func Faccessat(dirfd int, path string, mode uint32, flags int) (err error) { | |||
| // Alarm | ||||
| // ArchPrctl | ||||
| // Brk | ||||
| // Capget | ||||
| // Capset | ||||
| // ClockNanosleep | ||||
| // ClockSettime | ||||
| // Clone | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -372,6 +372,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -163,6 +163,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint64(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										23
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										23
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -19,12 +19,18 @@ func setTimeval(sec, usec int64) Timeval { | |||
| 	return Timeval{Sec: int32(sec), Usec: int32(usec)} | ||||
| } | ||||
| 
 | ||||
| //sysnb	pipe(p *[2]_C_int) (err error) | ||||
| 
 | ||||
| func Pipe(p []int) (err error) { | ||||
| 	if len(p) != 2 { | ||||
| 		return EINVAL | ||||
| 	} | ||||
| 	var pp [2]_C_int | ||||
| 	// Try pipe2 first for Android O, then try pipe for kernel 2.6.23. | ||||
| 	err = pipe2(&pp, 0) | ||||
| 	if err == ENOSYS { | ||||
| 		err = pipe(&pp) | ||||
| 	} | ||||
| 	p[0] = int(pp[0]) | ||||
| 	p[1] = int(pp[1]) | ||||
| 	return | ||||
|  | @ -246,6 +252,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  | @ -266,3 +276,16 @@ func SyncFileRange(fd int, off int64, n int64, flags int) error { | |||
| 	// order of their arguments. | ||||
| 	return armSyncFileRange(fd, flags, off, n) | ||||
| } | ||||
| 
 | ||||
| //sys	kexecFileLoad(kernelFd int, initrdFd int, cmdlineLen int, cmdline string, flags int) (err error) | ||||
| 
 | ||||
| func KexecFileLoad(kernelFd int, initrdFd int, cmdline string, flags int) error { | ||||
| 	cmdlineLen := len(cmdline) | ||||
| 	if cmdlineLen > 0 { | ||||
| 		// Account for the additional NULL byte added by | ||||
| 		// BytePtrFromString in kexecFileLoad. The kexec_file_load | ||||
| 		// syscall expects a NULL-terminated string. | ||||
| 		cmdlineLen++ | ||||
| 	} | ||||
| 	return kexecFileLoad(kernelFd, initrdFd, cmdlineLen, cmdline, flags) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										17
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										17
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -180,6 +180,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint64(length) | ||||
| } | ||||
|  | @ -208,3 +212,16 @@ func Poll(fds []PollFd, timeout int) (n int, err error) { | |||
| 	} | ||||
| 	return ppoll(&fds[0], len(fds), ts, nil) | ||||
| } | ||||
| 
 | ||||
| //sys	kexecFileLoad(kernelFd int, initrdFd int, cmdlineLen int, cmdline string, flags int) (err error) | ||||
| 
 | ||||
| func KexecFileLoad(kernelFd int, initrdFd int, cmdline string, flags int) error { | ||||
| 	cmdlineLen := len(cmdline) | ||||
| 	if cmdlineLen > 0 { | ||||
| 		// Account for the additional NULL byte added by | ||||
| 		// BytePtrFromString in kexecFileLoad. The kexec_file_load | ||||
| 		// syscall expects a NULL-terminated string. | ||||
| 		cmdlineLen++ | ||||
| 	} | ||||
| 	return kexecFileLoad(kernelFd, initrdFd, cmdlineLen, cmdline, flags) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_mips64x.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_mips64x.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -208,6 +208,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint64(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_mipsx.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_mipsx.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -220,6 +220,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_ppc64x.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_ppc64x.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -91,6 +91,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint64(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										17
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_riscv64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										17
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_riscv64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -179,6 +179,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint64(length) | ||||
| } | ||||
|  | @ -211,3 +215,16 @@ func Poll(fds []PollFd, timeout int) (n int, err error) { | |||
| func Renameat(olddirfd int, oldpath string, newdirfd int, newpath string) (err error) { | ||||
| 	return Renameat2(olddirfd, oldpath, newdirfd, newpath, 0) | ||||
| } | ||||
| 
 | ||||
| //sys	kexecFileLoad(kernelFd int, initrdFd int, cmdlineLen int, cmdline string, flags int) (err error) | ||||
| 
 | ||||
| func KexecFileLoad(kernelFd int, initrdFd int, cmdline string, flags int) error { | ||||
| 	cmdlineLen := len(cmdline) | ||||
| 	if cmdlineLen > 0 { | ||||
| 		// Account for the additional NULL byte added by | ||||
| 		// BytePtrFromString in kexecFileLoad. The kexec_file_load | ||||
| 		// syscall expects a NULL-terminated string. | ||||
| 		cmdlineLen++ | ||||
| 	} | ||||
| 	return kexecFileLoad(kernelFd, initrdFd, cmdlineLen, cmdline, flags) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_s390x.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_s390x.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -120,6 +120,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint64(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_sparc64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_linux_sparc64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -107,6 +107,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint64(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										86
									
								
								vendor/golang.org/x/sys/unix/syscall_netbsd.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										86
									
								
								vendor/golang.org/x/sys/unix/syscall_netbsd.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -94,6 +94,18 @@ func nametomib(name string) (mib []_C_int, err error) { | |||
| 	return mib, nil | ||||
| } | ||||
| 
 | ||||
| func direntIno(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Fileno), unsafe.Sizeof(Dirent{}.Fileno)) | ||||
| } | ||||
| 
 | ||||
| func direntReclen(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Reclen), unsafe.Sizeof(Dirent{}.Reclen)) | ||||
| } | ||||
| 
 | ||||
| func direntNamlen(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Namlen), unsafe.Sizeof(Dirent{}.Namlen)) | ||||
| } | ||||
| 
 | ||||
| func SysctlClockinfo(name string) (*Clockinfo, error) { | ||||
| 	mib, err := sysctlmib(name) | ||||
| 	if err != nil { | ||||
|  | @ -120,9 +132,30 @@ func Pipe(p []int) (err error) { | |||
| 	return | ||||
| } | ||||
| 
 | ||||
| //sys getdents(fd int, buf []byte) (n int, err error) | ||||
| //sys Getdents(fd int, buf []byte) (n int, err error) | ||||
| func Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) { | ||||
| 	return getdents(fd, buf) | ||||
| 	n, err = Getdents(fd, buf) | ||||
| 	if err != nil || basep == nil { | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	var off int64 | ||||
| 	off, err = Seek(fd, 0, 1 /* SEEK_CUR */) | ||||
| 	if err != nil { | ||||
| 		*basep = ^uintptr(0) | ||||
| 		return | ||||
| 	} | ||||
| 	*basep = uintptr(off) | ||||
| 	if unsafe.Sizeof(*basep) == 8 { | ||||
| 		return | ||||
| 	} | ||||
| 	if off>>32 != 0 { | ||||
| 		// We can't stuff the offset back into a uintptr, so any | ||||
| 		// future calls would be suspect. Generate an error. | ||||
| 		// EIO is allowed by getdirentries. | ||||
| 		err = EIO | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
| 
 | ||||
| const ImplementsGetwd = true | ||||
|  | @ -154,42 +187,7 @@ func setattrlistTimes(path string, times []Timespec, flags int) error { | |||
| 
 | ||||
| //sys	ioctl(fd int, req uint, arg uintptr) (err error) | ||||
| 
 | ||||
| // ioctl itself should not be exposed directly, but additional get/set | ||||
| // functions for specific types are permissible. | ||||
| 
 | ||||
| // IoctlSetInt performs an ioctl operation which sets an integer value | ||||
| // on fd, using the specified request number. | ||||
| func IoctlSetInt(fd int, req uint, value int) error { | ||||
| 	return ioctl(fd, req, uintptr(value)) | ||||
| } | ||||
| 
 | ||||
| func ioctlSetWinsize(fd int, req uint, value *Winsize) error { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| func ioctlSetTermios(fd int, req uint, value *Termios) error { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| // IoctlGetInt performs an ioctl operation which gets an integer value | ||||
| // from fd, using the specified request number. | ||||
| func IoctlGetInt(fd int, req uint) (int, error) { | ||||
| 	var value int | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetWinsize(fd int, req uint) (*Winsize, error) { | ||||
| 	var value Winsize | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetTermios(fd int, req uint) (*Termios, error) { | ||||
| 	var value Termios | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| //sys   sysctl(mib []_C_int, old *byte, oldlen *uintptr, new *byte, newlen uintptr) (err error) = SYS___SYSCTL | ||||
| 
 | ||||
| func IoctlGetPtmget(fd int, req uint) (*Ptmget, error) { | ||||
| 	var value Ptmget | ||||
|  | @ -251,6 +249,14 @@ func Sendfile(outfd int, infd int, offset *int64, count int) (written int, err e | |||
| 	return sendfile(outfd, infd, offset, count) | ||||
| } | ||||
| 
 | ||||
| func Fstatvfs(fd int, buf *Statvfs_t) (err error) { | ||||
| 	return Fstatvfs1(fd, buf, ST_WAIT) | ||||
| } | ||||
| 
 | ||||
| func Statvfs(path string, buf *Statvfs_t) (err error) { | ||||
| 	return Statvfs1(path, buf, ST_WAIT) | ||||
| } | ||||
| 
 | ||||
| /* | ||||
|  * Exposed directly | ||||
|  */ | ||||
|  | @ -289,6 +295,7 @@ func Sendfile(outfd int, infd int, offset *int64, count int) (written int, err e | |||
| //sys	Fpathconf(fd int, name int) (val int, err error) | ||||
| //sys	Fstat(fd int, stat *Stat_t) (err error) | ||||
| //sys	Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) | ||||
| //sys	Fstatvfs1(fd int, buf *Statvfs_t) (err error) = SYS_FSTATVFS1 | ||||
| //sys	Fsync(fd int) (err error) | ||||
| //sys	Ftruncate(fd int, length int64) (err error) | ||||
| //sysnb	Getegid() (egid int) | ||||
|  | @ -332,7 +339,7 @@ func Sendfile(outfd int, infd int, offset *int64, count int) (written int, err e | |||
| //sys	Revoke(path string) (err error) | ||||
| //sys	Rmdir(path string) (err error) | ||||
| //sys	Seek(fd int, offset int64, whence int) (newoffset int64, err error) = SYS_LSEEK | ||||
| //sys	Select(n int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (err error) | ||||
| //sys	Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) | ||||
| //sysnb	Setegid(egid int) (err error) | ||||
| //sysnb	Seteuid(euid int) (err error) | ||||
| //sysnb	Setgid(gid int) (err error) | ||||
|  | @ -345,6 +352,7 @@ func Sendfile(outfd int, infd int, offset *int64, count int) (written int, err e | |||
| //sysnb	Settimeofday(tp *Timeval) (err error) | ||||
| //sysnb	Setuid(uid int) (err error) | ||||
| //sys	Stat(path string, stat *Stat_t) (err error) | ||||
| //sys	Statvfs1(path string, buf *Statvfs_t) (err error) = SYS_STATVFS1 | ||||
| //sys	Symlink(path string, link string) (err error) | ||||
| //sys	Symlinkat(oldpath string, newdirfd int, newpath string) (err error) | ||||
| //sys	Sync() (err error) | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_netbsd_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_netbsd_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -28,6 +28,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = int32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_netbsd_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_netbsd_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -28,6 +28,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = int32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_netbsd_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_netbsd_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -28,6 +28,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = int32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_netbsd_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_netbsd_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -28,6 +28,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = int32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										94
									
								
								vendor/golang.org/x/sys/unix/syscall_openbsd.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										94
									
								
								vendor/golang.org/x/sys/unix/syscall_openbsd.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -43,6 +43,35 @@ func nametomib(name string) (mib []_C_int, err error) { | |||
| 	return nil, EINVAL | ||||
| } | ||||
| 
 | ||||
| func direntIno(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Fileno), unsafe.Sizeof(Dirent{}.Fileno)) | ||||
| } | ||||
| 
 | ||||
| func direntReclen(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Reclen), unsafe.Sizeof(Dirent{}.Reclen)) | ||||
| } | ||||
| 
 | ||||
| func direntNamlen(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Namlen), unsafe.Sizeof(Dirent{}.Namlen)) | ||||
| } | ||||
| 
 | ||||
| func SysctlClockinfo(name string) (*Clockinfo, error) { | ||||
| 	mib, err := sysctlmib(name) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	n := uintptr(SizeofClockinfo) | ||||
| 	var ci Clockinfo | ||||
| 	if err := sysctl(mib, (*byte)(unsafe.Pointer(&ci)), &n, nil, 0); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	if n != SizeofClockinfo { | ||||
| 		return nil, EIO | ||||
| 	} | ||||
| 	return &ci, nil | ||||
| } | ||||
| 
 | ||||
| func SysctlUvmexp(name string) (*Uvmexp, error) { | ||||
| 	mib, err := sysctlmib(name) | ||||
| 	if err != nil { | ||||
|  | @ -72,9 +101,30 @@ func Pipe(p []int) (err error) { | |||
| 	return | ||||
| } | ||||
| 
 | ||||
| //sys getdents(fd int, buf []byte) (n int, err error) | ||||
| //sys Getdents(fd int, buf []byte) (n int, err error) | ||||
| func Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) { | ||||
| 	return getdents(fd, buf) | ||||
| 	n, err = Getdents(fd, buf) | ||||
| 	if err != nil || basep == nil { | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	var off int64 | ||||
| 	off, err = Seek(fd, 0, 1 /* SEEK_CUR */) | ||||
| 	if err != nil { | ||||
| 		*basep = ^uintptr(0) | ||||
| 		return | ||||
| 	} | ||||
| 	*basep = uintptr(off) | ||||
| 	if unsafe.Sizeof(*basep) == 8 { | ||||
| 		return | ||||
| 	} | ||||
| 	if off>>32 != 0 { | ||||
| 		// We can't stuff the offset back into a uintptr, so any | ||||
| 		// future calls would be suspect. Generate an error. | ||||
| 		// EIO was allowed by getdirentries. | ||||
| 		err = EIO | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
| 
 | ||||
| const ImplementsGetwd = true | ||||
|  | @ -128,42 +178,7 @@ func setattrlistTimes(path string, times []Timespec, flags int) error { | |||
| 
 | ||||
| //sys	ioctl(fd int, req uint, arg uintptr) (err error) | ||||
| 
 | ||||
| // ioctl itself should not be exposed directly, but additional get/set | ||||
| // functions for specific types are permissible. | ||||
| 
 | ||||
| // IoctlSetInt performs an ioctl operation which sets an integer value | ||||
| // on fd, using the specified request number. | ||||
| func IoctlSetInt(fd int, req uint, value int) error { | ||||
| 	return ioctl(fd, req, uintptr(value)) | ||||
| } | ||||
| 
 | ||||
| func ioctlSetWinsize(fd int, req uint, value *Winsize) error { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| func ioctlSetTermios(fd int, req uint, value *Termios) error { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| // IoctlGetInt performs an ioctl operation which gets an integer value | ||||
| // from fd, using the specified request number. | ||||
| func IoctlGetInt(fd int, req uint) (int, error) { | ||||
| 	var value int | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetWinsize(fd int, req uint) (*Winsize, error) { | ||||
| 	var value Winsize | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetTermios(fd int, req uint) (*Termios, error) { | ||||
| 	var value Termios | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| //sys   sysctl(mib []_C_int, old *byte, oldlen *uintptr, new *byte, newlen uintptr) (err error) = SYS___SYSCTL | ||||
| 
 | ||||
| //sys	ppoll(fds *PollFd, nfds int, timeout *Timespec, sigmask *Sigset_t) (n int, err error) | ||||
| 
 | ||||
|  | @ -290,7 +305,7 @@ func Uname(uname *Utsname) error { | |||
| //sys	Revoke(path string) (err error) | ||||
| //sys	Rmdir(path string) (err error) | ||||
| //sys	Seek(fd int, offset int64, whence int) (newoffset int64, err error) = SYS_LSEEK | ||||
| //sys	Select(n int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (err error) | ||||
| //sys	Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) | ||||
| //sysnb	Setegid(egid int) (err error) | ||||
| //sysnb	Seteuid(euid int) (err error) | ||||
| //sysnb	Setgid(gid int) (err error) | ||||
|  | @ -337,7 +352,6 @@ func Uname(uname *Utsname) error { | |||
| // clock_settime | ||||
| // closefrom | ||||
| // execve | ||||
| // fcntl | ||||
| // fhopen | ||||
| // fhstat | ||||
| // fhstatfs | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_openbsd_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_openbsd_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -28,6 +28,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_openbsd_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_openbsd_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -28,6 +28,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_openbsd_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_openbsd_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -28,6 +28,10 @@ func (msghdr *Msghdr) SetControllen(length int) { | |||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										41
									
								
								vendor/golang.org/x/sys/unix/syscall_openbsd_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								vendor/golang.org/x/sys/unix/syscall_openbsd_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,41 @@ | |||
| // Copyright 2019 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| // +build arm64,openbsd | ||||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| func setTimespec(sec, nsec int64) Timespec { | ||||
| 	return Timespec{Sec: sec, Nsec: nsec} | ||||
| } | ||||
| 
 | ||||
| func setTimeval(sec, usec int64) Timeval { | ||||
| 	return Timeval{Sec: sec, Usec: usec} | ||||
| } | ||||
| 
 | ||||
| func SetKevent(k *Kevent_t, fd, mode, flags int) { | ||||
| 	k.Ident = uint64(fd) | ||||
| 	k.Filter = int16(mode) | ||||
| 	k.Flags = uint16(flags) | ||||
| } | ||||
| 
 | ||||
| func (iov *Iovec) SetLen(length int) { | ||||
| 	iov.Len = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetControllen(length int) { | ||||
| 	msghdr.Controllen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
| 
 | ||||
| // SYS___SYSCTL is used by syscall_bsd.go for all BSDs, but in modern versions | ||||
| // of openbsd/amd64 the syscall is called sysctl instead of __sysctl. | ||||
| const SYS___SYSCTL = SYS_SYSCTL | ||||
							
								
								
									
										51
									
								
								vendor/golang.org/x/sys/unix/syscall_solaris.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										51
									
								
								vendor/golang.org/x/sys/unix/syscall_solaris.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -35,6 +35,22 @@ type SockaddrDatalink struct { | |||
| 	raw    RawSockaddrDatalink | ||||
| } | ||||
| 
 | ||||
| func direntIno(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Ino), unsafe.Sizeof(Dirent{}.Ino)) | ||||
| } | ||||
| 
 | ||||
| func direntReclen(buf []byte) (uint64, bool) { | ||||
| 	return readInt(buf, unsafe.Offsetof(Dirent{}.Reclen), unsafe.Sizeof(Dirent{}.Reclen)) | ||||
| } | ||||
| 
 | ||||
| func direntNamlen(buf []byte) (uint64, bool) { | ||||
| 	reclen, ok := direntReclen(buf) | ||||
| 	if !ok { | ||||
| 		return 0, false | ||||
| 	} | ||||
| 	return reclen - uint64(unsafe.Offsetof(Dirent{}.Name)), true | ||||
| } | ||||
| 
 | ||||
| //sysnb	pipe(p *[2]_C_int) (n int, err error) | ||||
| 
 | ||||
| func Pipe(p []int) (err error) { | ||||
|  | @ -189,6 +205,7 @@ func Setgroups(gids []int) (err error) { | |||
| 	return setgroups(len(a), &a[0]) | ||||
| } | ||||
| 
 | ||||
| // ReadDirent reads directory entries from fd and writes them into buf. | ||||
| func ReadDirent(fd int, buf []byte) (n int, err error) { | ||||
| 	// Final argument is (basep *uintptr) and the syscall doesn't take nil. | ||||
| 	// TODO(rsc): Can we use a single global basep for all calls? | ||||
|  | @ -374,7 +391,7 @@ func anyToSockaddr(fd int, rsa *RawSockaddrAny) (Sockaddr, error) { | |||
| 		for n < len(pp.Path) && pp.Path[n] != 0 { | ||||
| 			n++ | ||||
| 		} | ||||
| 		bytes := (*[10000]byte)(unsafe.Pointer(&pp.Path[0]))[0:n] | ||||
| 		bytes := (*[len(pp.Path)]byte)(unsafe.Pointer(&pp.Path[0]))[0:n] | ||||
| 		sa.Name = string(bytes) | ||||
| 		return sa, nil | ||||
| 
 | ||||
|  | @ -536,40 +553,10 @@ func Minor(dev uint64) uint32 { | |||
| 
 | ||||
| //sys	ioctl(fd int, req uint, arg uintptr) (err error) | ||||
| 
 | ||||
| func IoctlSetInt(fd int, req uint, value int) (err error) { | ||||
| 	return ioctl(fd, req, uintptr(value)) | ||||
| } | ||||
| 
 | ||||
| func ioctlSetWinsize(fd int, req uint, value *Winsize) (err error) { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| func ioctlSetTermios(fd int, req uint, value *Termios) (err error) { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| func IoctlSetTermio(fd int, req uint, value *Termio) (err error) { | ||||
| 	return ioctl(fd, req, uintptr(unsafe.Pointer(value))) | ||||
| } | ||||
| 
 | ||||
| func IoctlGetInt(fd int, req uint) (int, error) { | ||||
| 	var value int | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetWinsize(fd int, req uint) (*Winsize, error) { | ||||
| 	var value Winsize | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetTermios(fd int, req uint) (*Termios, error) { | ||||
| 	var value Termios | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
| 	return &value, err | ||||
| } | ||||
| 
 | ||||
| func IoctlGetTermio(fd int, req uint) (*Termio, error) { | ||||
| 	var value Termio | ||||
| 	err := ioctl(fd, req, uintptr(unsafe.Pointer(&value))) | ||||
|  | @ -662,7 +649,7 @@ func Sendfile(outfd int, infd int, offset *int64, count int) (written int, err e | |||
| //sys	Renameat(olddirfd int, oldpath string, newdirfd int, newpath string) (err error) | ||||
| //sys	Rmdir(path string) (err error) | ||||
| //sys	Seek(fd int, offset int64, whence int) (newoffset int64, err error) = lseek | ||||
| //sys	Select(n int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (err error) | ||||
| //sys	Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) | ||||
| //sysnb	Setegid(egid int) (err error) | ||||
| //sysnb	Seteuid(euid int) (err error) | ||||
| //sysnb	Setgid(gid int) (err error) | ||||
|  |  | |||
							
								
								
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_solaris_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/golang.org/x/sys/unix/syscall_solaris_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -18,6 +18,10 @@ func (iov *Iovec) SetLen(length int) { | |||
| 	iov.Len = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (msghdr *Msghdr) SetIovlen(length int) { | ||||
| 	msghdr.Iovlen = int32(length) | ||||
| } | ||||
| 
 | ||||
| func (cmsg *Cmsghdr) SetLen(length int) { | ||||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										54
									
								
								vendor/golang.org/x/sys/unix/syscall_unix.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										54
									
								
								vendor/golang.org/x/sys/unix/syscall_unix.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -28,6 +28,11 @@ var ( | |||
| 	errENOENT error = syscall.ENOENT | ||||
| ) | ||||
| 
 | ||||
| var ( | ||||
| 	signalNameMapOnce sync.Once | ||||
| 	signalNameMap     map[string]syscall.Signal | ||||
| ) | ||||
| 
 | ||||
| // errnoErr returns common boxed Errno values, to prevent | ||||
| // allocations at runtime. | ||||
| func errnoErr(e syscall.Errno) error { | ||||
|  | @ -66,6 +71,19 @@ func SignalName(s syscall.Signal) string { | |||
| 	return "" | ||||
| } | ||||
| 
 | ||||
| // SignalNum returns the syscall.Signal for signal named s, | ||||
| // or 0 if a signal with such name is not found. | ||||
| // The signal name should start with "SIG". | ||||
| func SignalNum(s string) syscall.Signal { | ||||
| 	signalNameMapOnce.Do(func() { | ||||
| 		signalNameMap = make(map[string]syscall.Signal) | ||||
| 		for _, signal := range signalList { | ||||
| 			signalNameMap[signal.name] = signal.num | ||||
| 		} | ||||
| 	}) | ||||
| 	return signalNameMap[s] | ||||
| } | ||||
| 
 | ||||
| // clen returns the index of the first NULL byte in n or len(n) if n contains no NULL byte. | ||||
| func clen(n []byte) int { | ||||
| 	i := bytes.IndexByte(n, 0) | ||||
|  | @ -276,6 +294,13 @@ func GetsockoptTimeval(fd, level, opt int) (*Timeval, error) { | |||
| 	return &tv, err | ||||
| } | ||||
| 
 | ||||
| func GetsockoptUint64(fd, level, opt int) (value uint64, err error) { | ||||
| 	var n uint64 | ||||
| 	vallen := _Socklen(8) | ||||
| 	err = getsockopt(fd, level, opt, unsafe.Pointer(&n), &vallen) | ||||
| 	return n, err | ||||
| } | ||||
| 
 | ||||
| func Recvfrom(fd int, p []byte, flags int) (n int, from Sockaddr, err error) { | ||||
| 	var rsa RawSockaddrAny | ||||
| 	var len _Socklen = SizeofSockaddrAny | ||||
|  | @ -326,13 +351,21 @@ func SetsockoptLinger(fd, level, opt int, l *Linger) (err error) { | |||
| } | ||||
| 
 | ||||
| func SetsockoptString(fd, level, opt int, s string) (err error) { | ||||
| 	return setsockopt(fd, level, opt, unsafe.Pointer(&[]byte(s)[0]), uintptr(len(s))) | ||||
| 	var p unsafe.Pointer | ||||
| 	if len(s) > 0 { | ||||
| 		p = unsafe.Pointer(&[]byte(s)[0]) | ||||
| 	} | ||||
| 	return setsockopt(fd, level, opt, p, uintptr(len(s))) | ||||
| } | ||||
| 
 | ||||
| func SetsockoptTimeval(fd, level, opt int, tv *Timeval) (err error) { | ||||
| 	return setsockopt(fd, level, opt, unsafe.Pointer(tv), unsafe.Sizeof(*tv)) | ||||
| } | ||||
| 
 | ||||
| func SetsockoptUint64(fd, level, opt int, value uint64) (err error) { | ||||
| 	return setsockopt(fd, level, opt, unsafe.Pointer(&value), 8) | ||||
| } | ||||
| 
 | ||||
| func Socket(domain, typ, proto int) (fd int, err error) { | ||||
| 	if domain == AF_INET6 && SocketDisableIPv6 { | ||||
| 		return -1, EAFNOSUPPORT | ||||
|  | @ -377,3 +410,22 @@ func SetNonblock(fd int, nonblocking bool) (err error) { | |||
| func Exec(argv0 string, argv []string, envv []string) error { | ||||
| 	return syscall.Exec(argv0, argv, envv) | ||||
| } | ||||
| 
 | ||||
| // Lutimes sets the access and modification times tv on path. If path refers to | ||||
| // a symlink, it is not dereferenced and the timestamps are set on the symlink. | ||||
| // If tv is nil, the access and modification times are set to the current time. | ||||
| // Otherwise tv must contain exactly 2 elements, with access time as the first | ||||
| // element and modification time as the second element. | ||||
| func Lutimes(path string, tv []Timeval) error { | ||||
| 	if tv == nil { | ||||
| 		return UtimesNanoAt(AT_FDCWD, path, nil, AT_SYMLINK_NOFOLLOW) | ||||
| 	} | ||||
| 	if len(tv) != 2 { | ||||
| 		return EINVAL | ||||
| 	} | ||||
| 	ts := []Timespec{ | ||||
| 		NsecToTimespec(TimevalToNsec(tv[0])), | ||||
| 		NsecToTimespec(TimevalToNsec(tv[1])), | ||||
| 	} | ||||
| 	return UtimesNanoAt(AT_FDCWD, path, ts, AT_SYMLINK_NOFOLLOW) | ||||
| } | ||||
|  |  | |||
|  | @ -2,8 +2,6 @@ | |||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
| 
 | ||||
| // +build openbsd | ||||
| 
 | ||||
| package unix | ||||
| 
 | ||||
| import ( | ||||
							
								
								
									
										14
									
								
								vendor/golang.org/x/sys/unix/zerrors_aix_ppc.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								vendor/golang.org/x/sys/unix/zerrors_aix_ppc.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -459,6 +459,15 @@ const ( | |||
| 	MAP_SHARED                    = 0x1 | ||||
| 	MAP_TYPE                      = 0xf0 | ||||
| 	MAP_VARIABLE                  = 0x0 | ||||
| 	MCAST_BLOCK_SOURCE            = 0x40 | ||||
| 	MCAST_EXCLUDE                 = 0x2 | ||||
| 	MCAST_INCLUDE                 = 0x1 | ||||
| 	MCAST_JOIN_GROUP              = 0x3e | ||||
| 	MCAST_JOIN_SOURCE_GROUP       = 0x42 | ||||
| 	MCAST_LEAVE_GROUP             = 0x3f | ||||
| 	MCAST_LEAVE_SOURCE_GROUP      = 0x43 | ||||
| 	MCAST_SOURCE_FILTER           = 0x49 | ||||
| 	MCAST_UNBLOCK_SOURCE          = 0x41 | ||||
| 	MCL_CURRENT                   = 0x100 | ||||
| 	MCL_FUTURE                    = 0x200 | ||||
| 	MSG_ANY                       = 0x4 | ||||
|  | @ -483,6 +492,7 @@ const ( | |||
| 	MS_INVALIDATE                 = 0x40 | ||||
| 	MS_PER_SEC                    = 0x3e8 | ||||
| 	MS_SYNC                       = 0x20 | ||||
| 	NFDBITS                       = 0x20 | ||||
| 	NL0                           = 0x0 | ||||
| 	NL1                           = 0x4000 | ||||
| 	NL2                           = 0x8000 | ||||
|  | @ -688,7 +698,7 @@ const ( | |||
| 	SIOCGHIWAT                    = 0x40047301 | ||||
| 	SIOCGIFADDR                   = -0x3fd796df | ||||
| 	SIOCGIFADDRS                  = 0x2000698c | ||||
| 	SIOCGIFBAUDRATE               = -0x3fd79693 | ||||
| 	SIOCGIFBAUDRATE               = -0x3fdf9669 | ||||
| 	SIOCGIFBRDADDR                = -0x3fd796dd | ||||
| 	SIOCGIFCONF                   = -0x3ff796bb | ||||
| 	SIOCGIFCONFGLOB               = -0x3ff79670 | ||||
|  | @ -926,6 +936,8 @@ const ( | |||
| 	TCSETSF                       = 0x5404 | ||||
| 	TCSETSW                       = 0x5403 | ||||
| 	TCXONC                        = 0x540b | ||||
| 	TIMER_ABSTIME                 = 0x3e7 | ||||
| 	TIMER_MAX                     = 0x20 | ||||
| 	TIOC                          = 0x5400 | ||||
| 	TIOCCBRK                      = 0x2000747a | ||||
| 	TIOCCDTR                      = 0x20007478 | ||||
|  |  | |||
							
								
								
									
										16
									
								
								vendor/golang.org/x/sys/unix/zerrors_aix_ppc64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										16
									
								
								vendor/golang.org/x/sys/unix/zerrors_aix_ppc64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -3,7 +3,7 @@ | |||
| 
 | ||||
| // +build ppc64,aix | ||||
| 
 | ||||
| // Created by cgo -godefs - DO NOT EDIT | ||||
| // Code generated by cmd/cgo -godefs; DO NOT EDIT. | ||||
| // cgo -godefs -- -maix64 _const.go | ||||
| 
 | ||||
| package unix | ||||
|  | @ -459,6 +459,15 @@ const ( | |||
| 	MAP_SHARED                    = 0x1 | ||||
| 	MAP_TYPE                      = 0xf0 | ||||
| 	MAP_VARIABLE                  = 0x0 | ||||
| 	MCAST_BLOCK_SOURCE            = 0x40 | ||||
| 	MCAST_EXCLUDE                 = 0x2 | ||||
| 	MCAST_INCLUDE                 = 0x1 | ||||
| 	MCAST_JOIN_GROUP              = 0x3e | ||||
| 	MCAST_JOIN_SOURCE_GROUP       = 0x42 | ||||
| 	MCAST_LEAVE_GROUP             = 0x3f | ||||
| 	MCAST_LEAVE_SOURCE_GROUP      = 0x43 | ||||
| 	MCAST_SOURCE_FILTER           = 0x49 | ||||
| 	MCAST_UNBLOCK_SOURCE          = 0x41 | ||||
| 	MCL_CURRENT                   = 0x100 | ||||
| 	MCL_FUTURE                    = 0x200 | ||||
| 	MSG_ANY                       = 0x4 | ||||
|  | @ -483,6 +492,7 @@ const ( | |||
| 	MS_INVALIDATE                 = 0x40 | ||||
| 	MS_PER_SEC                    = 0x3e8 | ||||
| 	MS_SYNC                       = 0x20 | ||||
| 	NFDBITS                       = 0x40 | ||||
| 	NL0                           = 0x0 | ||||
| 	NL1                           = 0x4000 | ||||
| 	NL2                           = 0x8000 | ||||
|  | @ -688,7 +698,7 @@ const ( | |||
| 	SIOCGHIWAT                    = 0x40047301 | ||||
| 	SIOCGIFADDR                   = -0x3fd796df | ||||
| 	SIOCGIFADDRS                  = 0x2000698c | ||||
| 	SIOCGIFBAUDRATE               = -0x3fd79693 | ||||
| 	SIOCGIFBAUDRATE               = -0x3fdf9669 | ||||
| 	SIOCGIFBRDADDR                = -0x3fd796dd | ||||
| 	SIOCGIFCONF                   = -0x3fef96bb | ||||
| 	SIOCGIFCONFGLOB               = -0x3fef9670 | ||||
|  | @ -926,6 +936,8 @@ const ( | |||
| 	TCSETSF                       = 0x5404 | ||||
| 	TCSETSW                       = 0x5403 | ||||
| 	TCXONC                        = 0x540b | ||||
| 	TIMER_ABSTIME                 = 0x3e7 | ||||
| 	TIMER_MAX                     = 0x20 | ||||
| 	TIOC                          = 0x5400 | ||||
| 	TIOCCBRK                      = 0x2000747a | ||||
| 	TIOCCDTR                      = 0x20007478 | ||||
|  |  | |||
							
								
								
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_darwin_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_darwin_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -3,7 +3,7 @@ | |||
| 
 | ||||
| // +build 386,darwin | ||||
| 
 | ||||
| // Created by cgo -godefs - DO NOT EDIT | ||||
| // Code generated by cmd/cgo -godefs; DO NOT EDIT. | ||||
| // cgo -godefs -- -m32 _const.go | ||||
| 
 | ||||
| package unix | ||||
|  | @ -980,6 +980,7 @@ const ( | |||
| 	NET_RT_MAXID                      = 0xa | ||||
| 	NET_RT_STAT                       = 0x4 | ||||
| 	NET_RT_TRASH                      = 0x5 | ||||
| 	NFDBITS                           = 0x20 | ||||
| 	NL0                               = 0x0 | ||||
| 	NL1                               = 0x100 | ||||
| 	NL2                               = 0x200 | ||||
|  |  | |||
							
								
								
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_darwin_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_darwin_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -3,7 +3,7 @@ | |||
| 
 | ||||
| // +build amd64,darwin | ||||
| 
 | ||||
| // Created by cgo -godefs - DO NOT EDIT | ||||
| // Code generated by cmd/cgo -godefs; DO NOT EDIT. | ||||
| // cgo -godefs -- -m64 _const.go | ||||
| 
 | ||||
| package unix | ||||
|  | @ -980,6 +980,7 @@ const ( | |||
| 	NET_RT_MAXID                      = 0xa | ||||
| 	NET_RT_STAT                       = 0x4 | ||||
| 	NET_RT_TRASH                      = 0x5 | ||||
| 	NFDBITS                           = 0x20 | ||||
| 	NL0                               = 0x0 | ||||
| 	NL1                               = 0x100 | ||||
| 	NL2                               = 0x200 | ||||
|  |  | |||
							
								
								
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_darwin_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_darwin_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -3,7 +3,7 @@ | |||
| 
 | ||||
| // +build arm,darwin | ||||
| 
 | ||||
| // Created by cgo -godefs - DO NOT EDIT | ||||
| // Code generated by cmd/cgo -godefs; DO NOT EDIT. | ||||
| // cgo -godefs -- _const.go | ||||
| 
 | ||||
| package unix | ||||
|  | @ -980,6 +980,7 @@ const ( | |||
| 	NET_RT_MAXID                      = 0xa | ||||
| 	NET_RT_STAT                       = 0x4 | ||||
| 	NET_RT_TRASH                      = 0x5 | ||||
| 	NFDBITS                           = 0x20 | ||||
| 	NL0                               = 0x0 | ||||
| 	NL1                               = 0x100 | ||||
| 	NL2                               = 0x200 | ||||
|  |  | |||
							
								
								
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_darwin_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_darwin_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -3,7 +3,7 @@ | |||
| 
 | ||||
| // +build arm64,darwin | ||||
| 
 | ||||
| // Created by cgo -godefs - DO NOT EDIT | ||||
| // Code generated by cmd/cgo -godefs; DO NOT EDIT. | ||||
| // cgo -godefs -- -m64 _const.go | ||||
| 
 | ||||
| package unix | ||||
|  | @ -980,6 +980,7 @@ const ( | |||
| 	NET_RT_MAXID                      = 0xa | ||||
| 	NET_RT_STAT                       = 0x4 | ||||
| 	NET_RT_TRASH                      = 0x5 | ||||
| 	NFDBITS                           = 0x20 | ||||
| 	NL0                               = 0x0 | ||||
| 	NL1                               = 0x100 | ||||
| 	NL2                               = 0x200 | ||||
|  |  | |||
							
								
								
									
										1
									
								
								vendor/golang.org/x/sys/unix/zerrors_dragonfly_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								vendor/golang.org/x/sys/unix/zerrors_dragonfly_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -938,6 +938,7 @@ const ( | |||
| 	NET_RT_FLAGS                      = 0x2 | ||||
| 	NET_RT_IFLIST                     = 0x3 | ||||
| 	NET_RT_MAXID                      = 0x4 | ||||
| 	NFDBITS                           = 0x40 | ||||
| 	NOFLSH                            = 0x80000000 | ||||
| 	NOKERNINFO                        = 0x2000000 | ||||
| 	NOTE_ATTRIB                       = 0x8 | ||||
|  |  | |||
							
								
								
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_freebsd_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_freebsd_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -3,7 +3,7 @@ | |||
| 
 | ||||
| // +build 386,freebsd | ||||
| 
 | ||||
| // Created by cgo -godefs - DO NOT EDIT | ||||
| // Code generated by cmd/cgo -godefs; DO NOT EDIT. | ||||
| // cgo -godefs -- -m32 _const.go | ||||
| 
 | ||||
| package unix | ||||
|  | @ -1055,6 +1055,7 @@ const ( | |||
| 	NET_RT_IFLIST                  = 0x3 | ||||
| 	NET_RT_IFLISTL                 = 0x5 | ||||
| 	NET_RT_IFMALIST                = 0x4 | ||||
| 	NFDBITS                        = 0x20 | ||||
| 	NOFLSH                         = 0x80000000 | ||||
| 	NOKERNINFO                     = 0x2000000 | ||||
| 	NOTE_ATTRIB                    = 0x8 | ||||
|  |  | |||
							
								
								
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_freebsd_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_freebsd_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -3,7 +3,7 @@ | |||
| 
 | ||||
| // +build amd64,freebsd | ||||
| 
 | ||||
| // Created by cgo -godefs - DO NOT EDIT | ||||
| // Code generated by cmd/cgo -godefs; DO NOT EDIT. | ||||
| // cgo -godefs -- -m64 _const.go | ||||
| 
 | ||||
| package unix | ||||
|  | @ -1056,6 +1056,7 @@ const ( | |||
| 	NET_RT_IFLIST                  = 0x3 | ||||
| 	NET_RT_IFLISTL                 = 0x5 | ||||
| 	NET_RT_IFMALIST                = 0x4 | ||||
| 	NFDBITS                        = 0x40 | ||||
| 	NOFLSH                         = 0x80000000 | ||||
| 	NOKERNINFO                     = 0x2000000 | ||||
| 	NOTE_ATTRIB                    = 0x8 | ||||
|  |  | |||
							
								
								
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_freebsd_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_freebsd_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -3,7 +3,7 @@ | |||
| 
 | ||||
| // +build arm,freebsd | ||||
| 
 | ||||
| // Created by cgo -godefs - DO NOT EDIT | ||||
| // Code generated by cmd/cgo -godefs; DO NOT EDIT. | ||||
| // cgo -godefs -- _const.go | ||||
| 
 | ||||
| package unix | ||||
|  | @ -1063,6 +1063,7 @@ const ( | |||
| 	NET_RT_IFLIST                  = 0x3 | ||||
| 	NET_RT_IFLISTL                 = 0x5 | ||||
| 	NET_RT_IFMALIST                = 0x4 | ||||
| 	NFDBITS                        = 0x20 | ||||
| 	NOFLSH                         = 0x80000000 | ||||
| 	NOKERNINFO                     = 0x2000000 | ||||
| 	NOTE_ATTRIB                    = 0x8 | ||||
|  |  | |||
							
								
								
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_freebsd_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_freebsd_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -3,7 +3,7 @@ | |||
| 
 | ||||
| // +build arm64,freebsd | ||||
| 
 | ||||
| // Created by cgo -godefs - DO NOT EDIT | ||||
| // Code generated by cmd/cgo -godefs; DO NOT EDIT. | ||||
| // cgo -godefs -- -m64 _const.go | ||||
| 
 | ||||
| package unix | ||||
|  | @ -1056,6 +1056,7 @@ const ( | |||
| 	NET_RT_IFLIST                  = 0x3 | ||||
| 	NET_RT_IFLISTL                 = 0x5 | ||||
| 	NET_RT_IFMALIST                = 0x4 | ||||
| 	NFDBITS                        = 0x40 | ||||
| 	NOFLSH                         = 0x80000000 | ||||
| 	NOKERNINFO                     = 0x2000000 | ||||
| 	NOTE_ATTRIB                    = 0x8 | ||||
|  |  | |||
							
								
								
									
										5229
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5229
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										5229
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5229
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										5241
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5241
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										5213
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5213
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										5233
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_mips.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5233
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_mips.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										5233
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_mips64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5233
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_mips64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										5233
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_mips64le.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5233
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_mips64le.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										5233
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_mipsle.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5233
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_mipsle.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										5351
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_ppc64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5351
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_ppc64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										5351
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_ppc64le.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5351
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_ppc64le.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										5203
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_riscv64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5203
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_riscv64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										5349
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_s390x.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5349
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_s390x.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										5329
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_sparc64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5329
									
								
								vendor/golang.org/x/sys/unix/zerrors_linux_sparc64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_netbsd_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_netbsd_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -3,7 +3,7 @@ | |||
| 
 | ||||
| // +build 386,netbsd | ||||
| 
 | ||||
| // Created by cgo -godefs - DO NOT EDIT | ||||
| // Code generated by cmd/cgo -godefs; DO NOT EDIT. | ||||
| // cgo -godefs -- -m32 _const.go | ||||
| 
 | ||||
| package unix | ||||
|  | @ -1085,6 +1085,7 @@ const ( | |||
| 	NET_RT_MAXID                      = 0x6 | ||||
| 	NET_RT_OIFLIST                    = 0x4 | ||||
| 	NET_RT_OOIFLIST                   = 0x3 | ||||
| 	NFDBITS                           = 0x20 | ||||
| 	NOFLSH                            = 0x80000000 | ||||
| 	NOTE_ATTRIB                       = 0x8 | ||||
| 	NOTE_CHILD                        = 0x4 | ||||
|  |  | |||
							
								
								
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_netbsd_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_netbsd_amd64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -3,7 +3,7 @@ | |||
| 
 | ||||
| // +build amd64,netbsd | ||||
| 
 | ||||
| // Created by cgo -godefs - DO NOT EDIT | ||||
| // Code generated by cmd/cgo -godefs; DO NOT EDIT. | ||||
| // cgo -godefs -- -m64 _const.go | ||||
| 
 | ||||
| package unix | ||||
|  | @ -1075,6 +1075,7 @@ const ( | |||
| 	NET_RT_MAXID                      = 0x6 | ||||
| 	NET_RT_OIFLIST                    = 0x4 | ||||
| 	NET_RT_OOIFLIST                   = 0x3 | ||||
| 	NFDBITS                           = 0x20 | ||||
| 	NOFLSH                            = 0x80000000 | ||||
| 	NOTE_ATTRIB                       = 0x8 | ||||
| 	NOTE_CHILD                        = 0x4 | ||||
|  |  | |||
							
								
								
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_netbsd_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_netbsd_arm.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -3,7 +3,7 @@ | |||
| 
 | ||||
| // +build arm,netbsd | ||||
| 
 | ||||
| // Created by cgo -godefs - DO NOT EDIT | ||||
| // Code generated by cmd/cgo -godefs; DO NOT EDIT. | ||||
| // cgo -godefs -- -marm _const.go | ||||
| 
 | ||||
| package unix | ||||
|  | @ -1065,6 +1065,7 @@ const ( | |||
| 	NET_RT_MAXID                      = 0x6 | ||||
| 	NET_RT_OIFLIST                    = 0x4 | ||||
| 	NET_RT_OOIFLIST                   = 0x3 | ||||
| 	NFDBITS                           = 0x20 | ||||
| 	NOFLSH                            = 0x80000000 | ||||
| 	NOTE_ATTRIB                       = 0x8 | ||||
| 	NOTE_CHILD                        = 0x4 | ||||
|  |  | |||
							
								
								
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_netbsd_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								vendor/golang.org/x/sys/unix/zerrors_netbsd_arm64.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -3,7 +3,7 @@ | |||
| 
 | ||||
| // +build arm64,netbsd | ||||
| 
 | ||||
| // Created by cgo -godefs - DO NOT EDIT | ||||
| // Code generated by cmd/cgo -godefs; DO NOT EDIT. | ||||
| // cgo -godefs -- -m64 _const.go | ||||
| 
 | ||||
| package unix | ||||
|  | @ -1075,6 +1075,7 @@ const ( | |||
| 	NET_RT_MAXID                      = 0x6 | ||||
| 	NET_RT_OIFLIST                    = 0x4 | ||||
| 	NET_RT_OOIFLIST                   = 0x3 | ||||
| 	NFDBITS                           = 0x20 | ||||
| 	NOFLSH                            = 0x80000000 | ||||
| 	NOTE_ATTRIB                       = 0x8 | ||||
| 	NOTE_CHILD                        = 0x4 | ||||
|  |  | |||
							
								
								
									
										17
									
								
								vendor/golang.org/x/sys/unix/zerrors_openbsd_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										17
									
								
								vendor/golang.org/x/sys/unix/zerrors_openbsd_386.go
									
										
									
										generated
									
									
										vendored
									
									
								
							|  | @ -3,7 +3,7 @@ | |||
| 
 | ||||
| // +build 386,openbsd | ||||
| 
 | ||||
| // Created by cgo -godefs - DO NOT EDIT | ||||
| // Code generated by cmd/cgo -godefs; DO NOT EDIT. | ||||
| // cgo -godefs -- -m32 _const.go | ||||
| 
 | ||||
| package unix | ||||
|  | @ -881,14 +881,15 @@ const ( | |||
| 	MADV_SPACEAVAIL                   = 0x5 | ||||
| 	MADV_WILLNEED                     = 0x3 | ||||
| 	MAP_ANON                          = 0x1000 | ||||
| 	MAP_COPY                          = 0x4 | ||||
| 	MAP_ANONYMOUS                     = 0x1000 | ||||
| 	MAP_CONCEAL                       = 0x8000 | ||||
| 	MAP_COPY                          = 0x2 | ||||
| 	MAP_FILE                          = 0x0 | ||||
| 	MAP_FIXED                         = 0x10 | ||||
| 	MAP_FLAGMASK                      = 0x1ff7 | ||||
| 	MAP_HASSEMAPHORE                  = 0x200 | ||||
| 	MAP_INHERIT                       = 0x80 | ||||
| 	MAP_FLAGMASK                      = 0xfff7 | ||||
| 	MAP_HASSEMAPHORE                  = 0x0 | ||||
| 	MAP_INHERIT                       = 0x0 | ||||
| 	MAP_INHERIT_COPY                  = 0x1 | ||||
| 	MAP_INHERIT_DONATE_COPY           = 0x3 | ||||
| 	MAP_INHERIT_NONE                  = 0x2 | ||||
| 	MAP_INHERIT_SHARE                 = 0x0 | ||||
| 	MAP_NOEXTEND                      = 0x100 | ||||
|  | @ -896,7 +897,8 @@ const ( | |||
| 	MAP_PRIVATE                       = 0x2 | ||||
| 	MAP_RENAME                        = 0x20 | ||||
| 	MAP_SHARED                        = 0x1 | ||||
| 	MAP_TRYFIXED                      = 0x400 | ||||
| 	MAP_STACK                         = 0x4000 | ||||
| 	MAP_TRYFIXED                      = 0x0 | ||||
| 	MCL_CURRENT                       = 0x1 | ||||
| 	MCL_FUTURE                        = 0x2 | ||||
| 	MNT_ASYNC                         = 0x40 | ||||
|  | @ -946,6 +948,7 @@ const ( | |||
| 	NET_RT_MAXID                      = 0x6 | ||||
| 	NET_RT_STATS                      = 0x4 | ||||
| 	NET_RT_TABLE                      = 0x5 | ||||
| 	NFDBITS                           = 0x20 | ||||
| 	NOFLSH                            = 0x80000000 | ||||
| 	NOTE_ATTRIB                       = 0x8 | ||||
| 	NOTE_CHILD                        = 0x4 | ||||
|  |  | |||
Some files were not shown because too many files have changed in this diff Show more
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue