github.com/stingnevermore/go@v0.0.0-20180120041312-3810f5bfed72/src/internal/syscall/windows/zsyscall_windows.go (about) 1 // MACHINE GENERATED BY 'go generate' COMMAND; DO NOT EDIT 2 3 package windows 4 5 import ( 6 "internal/syscall/windows/sysdll" 7 "syscall" 8 "unsafe" 9 ) 10 11 var _ unsafe.Pointer 12 13 // Do the interface allocations only once for common 14 // Errno values. 15 const ( 16 errnoERROR_IO_PENDING = 997 17 ) 18 19 var ( 20 errERROR_IO_PENDING error = syscall.Errno(errnoERROR_IO_PENDING) 21 ) 22 23 // errnoErr returns common boxed Errno values, to prevent 24 // allocations at runtime. 25 func errnoErr(e syscall.Errno) error { 26 switch e { 27 case 0: 28 return nil 29 case errnoERROR_IO_PENDING: 30 return errERROR_IO_PENDING 31 } 32 // TODO: add more here, after collecting data on the common 33 // error values see on Windows. (perhaps when running 34 // all.bat?) 35 return e 36 } 37 38 var ( 39 modiphlpapi = syscall.NewLazyDLL(sysdll.Add("iphlpapi.dll")) 40 modkernel32 = syscall.NewLazyDLL(sysdll.Add("kernel32.dll")) 41 modws2_32 = syscall.NewLazyDLL(sysdll.Add("ws2_32.dll")) 42 modnetapi32 = syscall.NewLazyDLL(sysdll.Add("netapi32.dll")) 43 modadvapi32 = syscall.NewLazyDLL(sysdll.Add("advapi32.dll")) 44 modpsapi = syscall.NewLazyDLL(sysdll.Add("psapi.dll")) 45 46 procGetAdaptersAddresses = modiphlpapi.NewProc("GetAdaptersAddresses") 47 procGetComputerNameExW = modkernel32.NewProc("GetComputerNameExW") 48 procMoveFileExW = modkernel32.NewProc("MoveFileExW") 49 procGetModuleFileNameW = modkernel32.NewProc("GetModuleFileNameW") 50 procWSASocketW = modws2_32.NewProc("WSASocketW") 51 procGetACP = modkernel32.NewProc("GetACP") 52 procGetConsoleCP = modkernel32.NewProc("GetConsoleCP") 53 procMultiByteToWideChar = modkernel32.NewProc("MultiByteToWideChar") 54 procGetCurrentThread = modkernel32.NewProc("GetCurrentThread") 55 procNetShareAdd = modnetapi32.NewProc("NetShareAdd") 56 procNetShareDel = modnetapi32.NewProc("NetShareDel") 57 procGetFinalPathNameByHandleW = modkernel32.NewProc("GetFinalPathNameByHandleW") 58 procImpersonateSelf = modadvapi32.NewProc("ImpersonateSelf") 59 procRevertToSelf = modadvapi32.NewProc("RevertToSelf") 60 procOpenThreadToken = modadvapi32.NewProc("OpenThreadToken") 61 procLookupPrivilegeValueW = modadvapi32.NewProc("LookupPrivilegeValueW") 62 procAdjustTokenPrivileges = modadvapi32.NewProc("AdjustTokenPrivileges") 63 procDuplicateTokenEx = modadvapi32.NewProc("DuplicateTokenEx") 64 procSetTokenInformation = modadvapi32.NewProc("SetTokenInformation") 65 procGetProcessMemoryInfo = modpsapi.NewProc("GetProcessMemoryInfo") 66 ) 67 68 func GetAdaptersAddresses(family uint32, flags uint32, reserved uintptr, adapterAddresses *IpAdapterAddresses, sizePointer *uint32) (errcode error) { 69 r0, _, _ := syscall.Syscall6(procGetAdaptersAddresses.Addr(), 5, uintptr(family), uintptr(flags), uintptr(reserved), uintptr(unsafe.Pointer(adapterAddresses)), uintptr(unsafe.Pointer(sizePointer)), 0) 70 if r0 != 0 { 71 errcode = syscall.Errno(r0) 72 } 73 return 74 } 75 76 func GetComputerNameEx(nameformat uint32, buf *uint16, n *uint32) (err error) { 77 r1, _, e1 := syscall.Syscall(procGetComputerNameExW.Addr(), 3, uintptr(nameformat), uintptr(unsafe.Pointer(buf)), uintptr(unsafe.Pointer(n))) 78 if r1 == 0 { 79 if e1 != 0 { 80 err = errnoErr(e1) 81 } else { 82 err = syscall.EINVAL 83 } 84 } 85 return 86 } 87 88 func MoveFileEx(from *uint16, to *uint16, flags uint32) (err error) { 89 r1, _, e1 := syscall.Syscall(procMoveFileExW.Addr(), 3, uintptr(unsafe.Pointer(from)), uintptr(unsafe.Pointer(to)), uintptr(flags)) 90 if r1 == 0 { 91 if e1 != 0 { 92 err = errnoErr(e1) 93 } else { 94 err = syscall.EINVAL 95 } 96 } 97 return 98 } 99 100 func GetModuleFileName(module syscall.Handle, fn *uint16, len uint32) (n uint32, err error) { 101 r0, _, e1 := syscall.Syscall(procGetModuleFileNameW.Addr(), 3, uintptr(module), uintptr(unsafe.Pointer(fn)), uintptr(len)) 102 n = uint32(r0) 103 if n == 0 { 104 if e1 != 0 { 105 err = errnoErr(e1) 106 } else { 107 err = syscall.EINVAL 108 } 109 } 110 return 111 } 112 113 func WSASocket(af int32, typ int32, protocol int32, protinfo *syscall.WSAProtocolInfo, group uint32, flags uint32) (handle syscall.Handle, err error) { 114 r0, _, e1 := syscall.Syscall6(procWSASocketW.Addr(), 6, uintptr(af), uintptr(typ), uintptr(protocol), uintptr(unsafe.Pointer(protinfo)), uintptr(group), uintptr(flags)) 115 handle = syscall.Handle(r0) 116 if handle == syscall.InvalidHandle { 117 if e1 != 0 { 118 err = errnoErr(e1) 119 } else { 120 err = syscall.EINVAL 121 } 122 } 123 return 124 } 125 126 func GetACP() (acp uint32) { 127 r0, _, _ := syscall.Syscall(procGetACP.Addr(), 0, 0, 0, 0) 128 acp = uint32(r0) 129 return 130 } 131 132 func GetConsoleCP() (ccp uint32) { 133 r0, _, _ := syscall.Syscall(procGetConsoleCP.Addr(), 0, 0, 0, 0) 134 ccp = uint32(r0) 135 return 136 } 137 138 func MultiByteToWideChar(codePage uint32, dwFlags uint32, str *byte, nstr int32, wchar *uint16, nwchar int32) (nwrite int32, err error) { 139 r0, _, e1 := syscall.Syscall6(procMultiByteToWideChar.Addr(), 6, uintptr(codePage), uintptr(dwFlags), uintptr(unsafe.Pointer(str)), uintptr(nstr), uintptr(unsafe.Pointer(wchar)), uintptr(nwchar)) 140 nwrite = int32(r0) 141 if nwrite == 0 { 142 if e1 != 0 { 143 err = errnoErr(e1) 144 } else { 145 err = syscall.EINVAL 146 } 147 } 148 return 149 } 150 151 func GetCurrentThread() (pseudoHandle syscall.Handle, err error) { 152 r0, _, e1 := syscall.Syscall(procGetCurrentThread.Addr(), 0, 0, 0, 0) 153 pseudoHandle = syscall.Handle(r0) 154 if pseudoHandle == 0 { 155 if e1 != 0 { 156 err = errnoErr(e1) 157 } else { 158 err = syscall.EINVAL 159 } 160 } 161 return 162 } 163 164 func NetShareAdd(serverName *uint16, level uint32, buf *byte, parmErr *uint16) (neterr error) { 165 r0, _, _ := syscall.Syscall6(procNetShareAdd.Addr(), 4, uintptr(unsafe.Pointer(serverName)), uintptr(level), uintptr(unsafe.Pointer(buf)), uintptr(unsafe.Pointer(parmErr)), 0, 0) 166 if r0 != 0 { 167 neterr = syscall.Errno(r0) 168 } 169 return 170 } 171 172 func NetShareDel(serverName *uint16, netName *uint16, reserved uint32) (neterr error) { 173 r0, _, _ := syscall.Syscall(procNetShareDel.Addr(), 3, uintptr(unsafe.Pointer(serverName)), uintptr(unsafe.Pointer(netName)), uintptr(reserved)) 174 if r0 != 0 { 175 neterr = syscall.Errno(r0) 176 } 177 return 178 } 179 180 func GetFinalPathNameByHandle(file syscall.Handle, filePath *uint16, filePathSize uint32, flags uint32) (n uint32, err error) { 181 r0, _, e1 := syscall.Syscall6(procGetFinalPathNameByHandleW.Addr(), 4, uintptr(file), uintptr(unsafe.Pointer(filePath)), uintptr(filePathSize), uintptr(flags), 0, 0) 182 n = uint32(r0) 183 if n == 0 { 184 if e1 != 0 { 185 err = errnoErr(e1) 186 } else { 187 err = syscall.EINVAL 188 } 189 } 190 return 191 } 192 193 func ImpersonateSelf(impersonationlevel uint32) (err error) { 194 r1, _, e1 := syscall.Syscall(procImpersonateSelf.Addr(), 1, uintptr(impersonationlevel), 0, 0) 195 if r1 == 0 { 196 if e1 != 0 { 197 err = errnoErr(e1) 198 } else { 199 err = syscall.EINVAL 200 } 201 } 202 return 203 } 204 205 func RevertToSelf() (err error) { 206 r1, _, e1 := syscall.Syscall(procRevertToSelf.Addr(), 0, 0, 0, 0) 207 if r1 == 0 { 208 if e1 != 0 { 209 err = errnoErr(e1) 210 } else { 211 err = syscall.EINVAL 212 } 213 } 214 return 215 } 216 217 func OpenThreadToken(h syscall.Handle, access uint32, openasself bool, token *syscall.Token) (err error) { 218 var _p0 uint32 219 if openasself { 220 _p0 = 1 221 } else { 222 _p0 = 0 223 } 224 r1, _, e1 := syscall.Syscall6(procOpenThreadToken.Addr(), 4, uintptr(h), uintptr(access), uintptr(_p0), uintptr(unsafe.Pointer(token)), 0, 0) 225 if r1 == 0 { 226 if e1 != 0 { 227 err = errnoErr(e1) 228 } else { 229 err = syscall.EINVAL 230 } 231 } 232 return 233 } 234 235 func LookupPrivilegeValue(systemname *uint16, name *uint16, luid *LUID) (err error) { 236 r1, _, e1 := syscall.Syscall(procLookupPrivilegeValueW.Addr(), 3, uintptr(unsafe.Pointer(systemname)), uintptr(unsafe.Pointer(name)), uintptr(unsafe.Pointer(luid))) 237 if r1 == 0 { 238 if e1 != 0 { 239 err = errnoErr(e1) 240 } else { 241 err = syscall.EINVAL 242 } 243 } 244 return 245 } 246 247 func adjustTokenPrivileges(token syscall.Token, disableAllPrivileges bool, newstate *TOKEN_PRIVILEGES, buflen uint32, prevstate *TOKEN_PRIVILEGES, returnlen *uint32) (ret uint32, err error) { 248 var _p0 uint32 249 if disableAllPrivileges { 250 _p0 = 1 251 } else { 252 _p0 = 0 253 } 254 r0, _, e1 := syscall.Syscall6(procAdjustTokenPrivileges.Addr(), 6, uintptr(token), uintptr(_p0), uintptr(unsafe.Pointer(newstate)), uintptr(buflen), uintptr(unsafe.Pointer(prevstate)), uintptr(unsafe.Pointer(returnlen))) 255 ret = uint32(r0) 256 if true { 257 if e1 != 0 { 258 err = errnoErr(e1) 259 } else { 260 err = syscall.EINVAL 261 } 262 } 263 return 264 } 265 266 func DuplicateTokenEx(hExistingToken syscall.Token, dwDesiredAccess uint32, lpTokenAttributes *syscall.SecurityAttributes, impersonationLevel uint32, tokenType TokenType, phNewToken *syscall.Token) (err error) { 267 r1, _, e1 := syscall.Syscall6(procDuplicateTokenEx.Addr(), 6, uintptr(hExistingToken), uintptr(dwDesiredAccess), uintptr(unsafe.Pointer(lpTokenAttributes)), uintptr(impersonationLevel), uintptr(tokenType), uintptr(unsafe.Pointer(phNewToken))) 268 if r1 == 0 { 269 if e1 != 0 { 270 err = errnoErr(e1) 271 } else { 272 err = syscall.EINVAL 273 } 274 } 275 return 276 } 277 278 func SetTokenInformation(tokenHandle syscall.Token, tokenInformationClass uint32, tokenInformation uintptr, tokenInformationLength uint32) (err error) { 279 r1, _, e1 := syscall.Syscall6(procSetTokenInformation.Addr(), 4, uintptr(tokenHandle), uintptr(tokenInformationClass), uintptr(tokenInformation), uintptr(tokenInformationLength), 0, 0) 280 if r1 == 0 { 281 if e1 != 0 { 282 err = errnoErr(e1) 283 } else { 284 err = syscall.EINVAL 285 } 286 } 287 return 288 } 289 290 func GetProcessMemoryInfo(handle syscall.Handle, memCounters *PROCESS_MEMORY_COUNTERS, cb uint32) (err error) { 291 r1, _, e1 := syscall.Syscall(procGetProcessMemoryInfo.Addr(), 3, uintptr(handle), uintptr(unsafe.Pointer(memCounters)), uintptr(cb)) 292 if r1 == 0 { 293 if e1 != 0 { 294 err = errnoErr(e1) 295 } else { 296 err = syscall.EINVAL 297 } 298 } 299 return 300 }