2014-04-18 20:23:56 +00:00
|
|
|
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
|
|
|
|
// file at the top-level directory of this distribution and at
|
|
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
|
|
// option. This file may not be copied, modified, or distributed
|
|
|
|
// except according to those terms.
|
|
|
|
|
|
|
|
//! C definitions used by libnative that don't belong in liblibc
|
|
|
|
|
2015-11-03 00:23:22 +00:00
|
|
|
#![allow(bad_style, overflowing_literals, dead_code, deprecated, unused_imports)]
|
2014-04-18 20:23:56 +00:00
|
|
|
|
2015-11-03 00:23:22 +00:00
|
|
|
use os::raw::{c_int, c_uint, c_ulong, c_long, c_longlong, c_ushort};
|
|
|
|
use os::raw::{c_char, c_short, c_ulonglong};
|
|
|
|
use libc::{wchar_t, size_t, c_void};
|
2015-09-03 06:49:50 +00:00
|
|
|
use ptr;
|
2015-11-03 00:23:22 +00:00
|
|
|
use simd;
|
2014-04-18 20:23:56 +00:00
|
|
|
|
2015-01-27 20:20:58 +00:00
|
|
|
pub use self::GET_FILEEX_INFO_LEVELS::*;
|
|
|
|
pub use self::FILE_INFO_BY_HANDLE_CLASS::*;
|
2015-11-03 00:23:22 +00:00
|
|
|
pub use self::EXCEPTION_DISPOSITION::*;
|
2015-01-27 20:20:58 +00:00
|
|
|
|
2015-11-03 00:23:22 +00:00
|
|
|
pub type DWORD = c_ulong;
|
|
|
|
pub type HANDLE = LPVOID;
|
|
|
|
pub type HINSTANCE = HANDLE;
|
|
|
|
pub type HMODULE = HINSTANCE;
|
|
|
|
pub type BOOL = c_int;
|
|
|
|
pub type BYTE = u8;
|
|
|
|
pub type BOOLEAN = BYTE;
|
|
|
|
pub type GROUP = c_uint;
|
|
|
|
pub type LONG_PTR = isize;
|
|
|
|
pub type LARGE_INTEGER = c_longlong;
|
|
|
|
pub type LONG = c_long;
|
|
|
|
pub type UINT = c_uint;
|
|
|
|
pub type WCHAR = u16;
|
|
|
|
pub type USHORT = c_ushort;
|
|
|
|
pub type SIZE_T = usize;
|
|
|
|
pub type WORD = u16;
|
|
|
|
pub type CHAR = c_char;
|
|
|
|
pub type HCRYPTPROV = LONG_PTR;
|
|
|
|
pub type ULONG_PTR = c_ulonglong;
|
|
|
|
pub type ULONG = c_ulong;
|
|
|
|
pub type ULONGLONG = u64;
|
|
|
|
pub type DWORDLONG = ULONGLONG;
|
|
|
|
|
|
|
|
pub type LPBOOL = *mut BOOL;
|
|
|
|
pub type LPBYTE = *mut BYTE;
|
|
|
|
pub type LPBY_HANDLE_FILE_INFORMATION = *mut BY_HANDLE_FILE_INFORMATION;
|
|
|
|
pub type LPCSTR = *const CHAR;
|
|
|
|
pub type LPCVOID = *const c_void;
|
|
|
|
pub type LPCWSTR = *const WCHAR;
|
|
|
|
pub type LPDWORD = *mut DWORD;
|
|
|
|
pub type LPHANDLE = *mut HANDLE;
|
|
|
|
pub type LPOVERLAPPED = *mut OVERLAPPED;
|
|
|
|
pub type LPPROCESS_INFORMATION = *mut PROCESS_INFORMATION;
|
|
|
|
pub type LPSECURITY_ATTRIBUTES = *mut SECURITY_ATTRIBUTES;
|
|
|
|
pub type LPSTARTUPINFO = *mut STARTUPINFO;
|
|
|
|
pub type LPVOID = *mut c_void;
|
|
|
|
pub type LPWCH = *mut WCHAR;
|
|
|
|
pub type LPWIN32_FIND_DATAW = *mut WIN32_FIND_DATAW;
|
|
|
|
pub type LPWSADATA = *mut WSADATA;
|
|
|
|
pub type LPWSANETWORKEVENTS = *mut WSANETWORKEVENTS;
|
|
|
|
pub type LPWSAPROTOCOLCHAIN = *mut WSAPROTOCOLCHAIN;
|
|
|
|
pub type LPWSAPROTOCOL_INFO = *mut WSAPROTOCOL_INFO;
|
|
|
|
pub type LPWSTR = *mut WCHAR;
|
|
|
|
|
|
|
|
pub type PCONDITION_VARIABLE = *mut CONDITION_VARIABLE;
|
|
|
|
pub type PLARGE_INTEGER = *mut c_longlong;
|
|
|
|
pub type PSRWLOCK = *mut SRWLOCK;
|
|
|
|
|
|
|
|
pub type SOCKET = ::os::windows::raw::SOCKET;
|
|
|
|
pub type socklen_t = c_int;
|
|
|
|
pub type ADDRESS_FAMILY = USHORT;
|
|
|
|
|
|
|
|
pub const TRUE: BOOL = 1;
|
|
|
|
pub const FALSE: BOOL = 0;
|
|
|
|
|
|
|
|
pub const FILE_ATTRIBUTE_READONLY: DWORD = 0x1;
|
|
|
|
pub const FILE_ATTRIBUTE_DIRECTORY: DWORD = 0x10;
|
|
|
|
pub const FILE_ATTRIBUTE_NORMAL: DWORD = 0x80;
|
|
|
|
pub const FILE_ATTRIBUTE_REPARSE_POINT: DWORD = 0x400;
|
|
|
|
pub const FILE_SHARE_DELETE: DWORD = 0x4;
|
|
|
|
pub const FILE_SHARE_READ: DWORD = 0x1;
|
|
|
|
pub const FILE_SHARE_WRITE: DWORD = 0x2;
|
|
|
|
pub const CREATE_ALWAYS: DWORD = 2;
|
|
|
|
pub const CREATE_NEW: DWORD = 1;
|
|
|
|
pub const OPEN_ALWAYS: DWORD = 4;
|
|
|
|
pub const OPEN_EXISTING: DWORD = 3;
|
|
|
|
pub const TRUNCATE_EXISTING: DWORD = 5;
|
|
|
|
pub const FILE_APPEND_DATA: DWORD = 0x00000004;
|
|
|
|
pub const FILE_READ_DATA: DWORD = 0x00000001;
|
|
|
|
pub const FILE_WRITE_DATA: DWORD = 0x00000002;
|
|
|
|
pub const STANDARD_RIGHTS_READ: DWORD = 0x20000;
|
|
|
|
pub const STANDARD_RIGHTS_WRITE: DWORD = 0x20000;
|
|
|
|
pub const FILE_WRITE_EA: DWORD = 0x00000010;
|
|
|
|
pub const FILE_READ_EA: DWORD = 0x00000008;
|
|
|
|
pub const SYNCHRONIZE: DWORD = 0x00100000;
|
|
|
|
pub const FILE_WRITE_ATTRIBUTES: DWORD = 0x00000100;
|
|
|
|
pub const FILE_READ_ATTRIBUTES: DWORD = 0x00000080;
|
|
|
|
pub const FILE_GENERIC_READ: DWORD = STANDARD_RIGHTS_READ | FILE_READ_DATA |
|
|
|
|
FILE_READ_ATTRIBUTES |
|
|
|
|
FILE_READ_EA |
|
|
|
|
SYNCHRONIZE;
|
|
|
|
pub const FILE_GENERIC_WRITE: DWORD = STANDARD_RIGHTS_WRITE | FILE_WRITE_DATA |
|
|
|
|
FILE_WRITE_ATTRIBUTES |
|
|
|
|
FILE_WRITE_EA |
|
|
|
|
FILE_APPEND_DATA |
|
|
|
|
SYNCHRONIZE;
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
#[derive(Copy)]
|
|
|
|
pub struct WIN32_FIND_DATAW {
|
|
|
|
pub dwFileAttributes: DWORD,
|
|
|
|
pub ftCreationTime: FILETIME,
|
|
|
|
pub ftLastAccessTime: FILETIME,
|
|
|
|
pub ftLastWriteTime: FILETIME,
|
|
|
|
pub nFileSizeHigh: DWORD,
|
|
|
|
pub nFileSizeLow: DWORD,
|
|
|
|
pub dwReserved0: DWORD,
|
|
|
|
pub dwReserved1: DWORD,
|
|
|
|
pub cFileName: [wchar_t; 260], // #define MAX_PATH 260
|
|
|
|
pub cAlternateFileName: [wchar_t; 14],
|
|
|
|
}
|
|
|
|
impl Clone for WIN32_FIND_DATAW {
|
|
|
|
fn clone(&self) -> Self { *self }
|
|
|
|
}
|
|
|
|
|
|
|
|
pub const FIONBIO: c_long = 0x8004667e;
|
2015-01-27 20:20:58 +00:00
|
|
|
pub const FD_SETSIZE: usize = 64;
|
2015-11-03 00:23:22 +00:00
|
|
|
pub const MSG_DONTWAIT: c_int = 0;
|
|
|
|
pub const ENABLE_ECHO_INPUT: DWORD = 0x4;
|
|
|
|
pub const ENABLE_EXTENDED_FLAGS: DWORD = 0x80;
|
|
|
|
pub const ENABLE_INSERT_MODE: DWORD = 0x20;
|
|
|
|
pub const ENABLE_LINE_INPUT: DWORD = 0x2;
|
|
|
|
pub const ENABLE_PROCESSED_INPUT: DWORD = 0x1;
|
|
|
|
pub const ENABLE_QUICK_EDIT_MODE: DWORD = 0x40;
|
2014-07-15 17:28:00 +00:00
|
|
|
|
2015-11-03 00:23:22 +00:00
|
|
|
pub const FD_ACCEPT: c_long = 0x08;
|
2015-01-27 20:20:58 +00:00
|
|
|
pub const FD_MAX_EVENTS: usize = 10;
|
2015-11-03 00:23:22 +00:00
|
|
|
|
|
|
|
pub const WSA_INVALID_EVENT: WSAEVENT = 0 as WSAEVENT;
|
|
|
|
pub const WSA_INFINITE: DWORD = INFINITE;
|
|
|
|
pub const WSA_WAIT_TIMEOUT: DWORD = WAIT_TIMEOUT;
|
|
|
|
pub const WSA_WAIT_EVENT_0: DWORD = WAIT_OBJECT_0;
|
|
|
|
pub const WSA_WAIT_FAILED: DWORD = WAIT_FAILED;
|
|
|
|
pub const WSA_FLAG_OVERLAPPED: DWORD = 0x01;
|
|
|
|
pub const WSA_FLAG_NO_HANDLE_INHERIT: DWORD = 0x80;
|
|
|
|
|
|
|
|
pub const WSADESCRIPTION_LEN: usize = 256;
|
|
|
|
pub const WSASYS_STATUS_LEN: usize = 128;
|
|
|
|
pub const WSAPROTOCOL_LEN: DWORD = 255;
|
|
|
|
pub const INVALID_SOCKET: SOCKET = !0;
|
|
|
|
|
|
|
|
pub const WSAEINTR: c_int = 10004;
|
|
|
|
pub const WSAEBADF: c_int = 10009;
|
|
|
|
pub const WSAEACCES: c_int = 10013;
|
|
|
|
pub const WSAEFAULT: c_int = 10014;
|
|
|
|
pub const WSAEINVAL: c_int = 10022;
|
|
|
|
pub const WSAEMFILE: c_int = 10024;
|
|
|
|
pub const WSAEWOULDBLOCK: c_int = 10035;
|
|
|
|
pub const WSAEINPROGRESS: c_int = 10036;
|
|
|
|
pub const WSAEALREADY: c_int = 10037;
|
|
|
|
pub const WSAENOTSOCK: c_int = 10038;
|
|
|
|
pub const WSAEDESTADDRREQ: c_int = 10039;
|
|
|
|
pub const WSAEMSGSIZE: c_int = 10040;
|
|
|
|
pub const WSAEPROTOTYPE: c_int = 10041;
|
|
|
|
pub const WSAENOPROTOOPT: c_int = 10042;
|
|
|
|
pub const WSAEPROTONOSUPPORT: c_int = 10043;
|
|
|
|
pub const WSAESOCKTNOSUPPORT: c_int = 10044;
|
|
|
|
pub const WSAEOPNOTSUPP: c_int = 10045;
|
|
|
|
pub const WSAEPFNOSUPPORT: c_int = 10046;
|
|
|
|
pub const WSAEAFNOSUPPORT: c_int = 10047;
|
|
|
|
pub const WSAEADDRINUSE: c_int = 10048;
|
|
|
|
pub const WSAEADDRNOTAVAIL: c_int = 10049;
|
|
|
|
pub const WSAENETDOWN: c_int = 10050;
|
|
|
|
pub const WSAENETUNREACH: c_int = 10051;
|
|
|
|
pub const WSAENETRESET: c_int = 10052;
|
|
|
|
pub const WSAECONNABORTED: c_int = 10053;
|
|
|
|
pub const WSAECONNRESET: c_int = 10054;
|
|
|
|
pub const WSAENOBUFS: c_int = 10055;
|
|
|
|
pub const WSAEISCONN: c_int = 10056;
|
|
|
|
pub const WSAENOTCONN: c_int = 10057;
|
|
|
|
pub const WSAESHUTDOWN: c_int = 10058;
|
|
|
|
pub const WSAETOOMANYREFS: c_int = 10059;
|
|
|
|
pub const WSAETIMEDOUT: c_int = 10060;
|
|
|
|
pub const WSAECONNREFUSED: c_int = 10061;
|
|
|
|
pub const WSAELOOP: c_int = 10062;
|
|
|
|
pub const WSAENAMETOOLONG: c_int = 10063;
|
|
|
|
pub const WSAEHOSTDOWN: c_int = 10064;
|
|
|
|
pub const WSAEHOSTUNREACH: c_int = 10065;
|
|
|
|
pub const WSAENOTEMPTY: c_int = 10066;
|
|
|
|
pub const WSAEPROCLIM: c_int = 10067;
|
|
|
|
pub const WSAEUSERS: c_int = 10068;
|
|
|
|
pub const WSAEDQUOT: c_int = 10069;
|
|
|
|
pub const WSAESTALE: c_int = 10070;
|
|
|
|
pub const WSAEREMOTE: c_int = 10071;
|
|
|
|
pub const WSASYSNOTREADY: c_int = 10091;
|
|
|
|
pub const WSAVERNOTSUPPORTED: c_int = 10092;
|
|
|
|
pub const WSANOTINITIALISED: c_int = 10093;
|
|
|
|
pub const WSAEDISCON: c_int = 10101;
|
|
|
|
pub const WSAENOMORE: c_int = 10102;
|
|
|
|
pub const WSAECANCELLED: c_int = 10103;
|
|
|
|
pub const WSAEINVALIDPROCTABLE: c_int = 10104;
|
|
|
|
pub const NI_MAXHOST: DWORD = 1025;
|
|
|
|
|
|
|
|
pub const MAX_PROTOCOL_CHAIN: DWORD = 7;
|
|
|
|
|
|
|
|
pub const TOKEN_READ: DWORD = 0x20008;
|
|
|
|
pub const FILE_FLAG_OPEN_REPARSE_POINT: DWORD = 0x00200000;
|
|
|
|
pub const FILE_FLAG_BACKUP_SEMANTICS: DWORD = 0x02000000;
|
2015-04-08 16:50:50 +00:00
|
|
|
pub const MAXIMUM_REPARSE_DATA_BUFFER_SIZE: usize = 16 * 1024;
|
2015-11-03 00:23:22 +00:00
|
|
|
pub const FSCTL_GET_REPARSE_POINT: DWORD = 0x900a8;
|
|
|
|
pub const IO_REPARSE_TAG_SYMLINK: DWORD = 0xa000000c;
|
|
|
|
pub const IO_REPARSE_TAG_MOUNT_POINT: DWORD = 0xa0000003;
|
|
|
|
pub const FSCTL_SET_REPARSE_POINT: DWORD = 0x900a4;
|
|
|
|
pub const FSCTL_DELETE_REPARSE_POINT: DWORD = 0x900ac;
|
2015-01-27 20:20:58 +00:00
|
|
|
|
2015-11-03 00:23:22 +00:00
|
|
|
pub const SYMBOLIC_LINK_FLAG_DIRECTORY: DWORD = 0x1;
|
Deprecate std::fs::soft_link in favor of platform-specific versions
On Windows, when you create a symbolic link you must specify whether it
points to a directory or a file, even if it is created dangling, while
on Unix, the same symbolic link could point to a directory, a file, or
nothing at all. Furthermore, on Windows special privilege is necessary
to use a symbolic link, while on Unix, you can generally create a
symbolic link in any directory you have write privileges to.
This means that it is unlikely to be able to use symbolic links purely
portably; anyone who uses them will need to think about the cross
platform implications. This means that using platform-specific APIs
will make it easier to see where code will need to differ between the
platforms, rather than trying to provide some kind of compatibility
wrapper.
Furthermore, `soft_link` has no precedence in any other API, so to avoid
confusion, move back to the more standard `symlink` terminology.
Create a `std::os::unix::symlink` for the Unix version that is
destination type agnostic, as well as `std::os::windows::{symlink_file,
symlink_dir}` for Windows.
Because this is a stable API, leave a compatibility wrapper in
`std::fs::soft_link`, which calls `symlink` on Unix and `symlink_file`
on Windows, preserving the existing behavior of `soft_link`.
2015-04-09 07:22:44 +00:00
|
|
|
|
2015-02-25 07:27:20 +00:00
|
|
|
// Note that these are not actually HANDLEs, just values to pass to GetStdHandle
|
2015-11-03 00:23:22 +00:00
|
|
|
pub const STD_INPUT_HANDLE: DWORD = -10i32 as DWORD;
|
|
|
|
pub const STD_OUTPUT_HANDLE: DWORD = -11i32 as DWORD;
|
|
|
|
pub const STD_ERROR_HANDLE: DWORD = -12i32 as DWORD;
|
|
|
|
|
|
|
|
pub const HANDLE_FLAG_INHERIT: DWORD = 0x00000001;
|
|
|
|
|
|
|
|
pub const PROGRESS_CONTINUE: DWORD = 0;
|
|
|
|
pub const PROGRESS_CANCEL: DWORD = 1;
|
|
|
|
pub const PROGRESS_STOP: DWORD = 2;
|
|
|
|
pub const PROGRESS_QUIET: DWORD = 3;
|
|
|
|
|
|
|
|
pub const TOKEN_ADJUST_PRIVILEGES: DWORD = 0x0020;
|
|
|
|
pub const SE_PRIVILEGE_ENABLED: DWORD = 2;
|
|
|
|
|
2015-02-25 07:27:20 +00:00
|
|
|
|
2015-11-03 00:23:22 +00:00
|
|
|
pub const ERROR_SUCCESS: DWORD = 0;
|
|
|
|
pub const ERROR_INVALID_FUNCTION: DWORD = 1;
|
|
|
|
pub const ERROR_FILE_NOT_FOUND: DWORD = 2;
|
|
|
|
pub const ERROR_PATH_NOT_FOUND: DWORD = 3;
|
|
|
|
pub const ERROR_ACCESS_DENIED: DWORD = 5;
|
|
|
|
pub const ERROR_INVALID_HANDLE: DWORD = 6;
|
|
|
|
pub const ERROR_NO_MORE_FILES: DWORD = 18;
|
|
|
|
pub const ERROR_BROKEN_PIPE: DWORD = 109;
|
|
|
|
pub const ERROR_DISK_FULL: DWORD = 112;
|
|
|
|
pub const ERROR_CALL_NOT_IMPLEMENTED: DWORD = 120;
|
|
|
|
pub const ERROR_INSUFFICIENT_BUFFER: DWORD = 122;
|
|
|
|
pub const ERROR_INVALID_NAME: DWORD = 123;
|
|
|
|
pub const ERROR_ALREADY_EXISTS: DWORD = 183;
|
|
|
|
pub const ERROR_PIPE_BUSY: DWORD = 231;
|
|
|
|
pub const ERROR_NO_DATA: DWORD = 232;
|
|
|
|
pub const ERROR_INVALID_ADDRESS: DWORD = 487;
|
|
|
|
pub const ERROR_PIPE_CONNECTED: DWORD = 535;
|
|
|
|
pub const ERROR_ILLEGAL_CHARACTER: DWORD = 582;
|
|
|
|
pub const ERROR_ENVVAR_NOT_FOUND: DWORD = 203;
|
|
|
|
pub const ERROR_NOTHING_TO_TERMINATE: DWORD = 758;
|
|
|
|
pub const ERROR_OPERATION_ABORTED: DWORD = 995;
|
|
|
|
pub const ERROR_IO_PENDING: DWORD = 997;
|
|
|
|
pub const ERROR_FILE_INVALID: DWORD = 1006;
|
|
|
|
pub const ERROR_NOT_FOUND: DWORD = 1168;
|
|
|
|
pub const ERROR_TIMEOUT: DWORD = 0x5B4;
|
|
|
|
|
|
|
|
pub const INVALID_HANDLE_VALUE: HANDLE = !0 as HANDLE;
|
|
|
|
|
|
|
|
pub const FORMAT_MESSAGE_FROM_SYSTEM: DWORD = 0x00001000;
|
|
|
|
pub const FORMAT_MESSAGE_IGNORE_INSERTS: DWORD = 0x00000200;
|
|
|
|
|
|
|
|
pub const TLS_OUT_OF_INDEXES: DWORD = 0xFFFFFFFF;
|
|
|
|
|
|
|
|
pub const DLL_THREAD_DETACH: DWORD = 3;
|
|
|
|
pub const DLL_PROCESS_DETACH: DWORD = 0;
|
|
|
|
|
|
|
|
pub const INFINITE: DWORD = !0;
|
|
|
|
|
|
|
|
pub const DUPLICATE_SAME_ACCESS: DWORD = 0x00000002;
|
|
|
|
|
|
|
|
pub const CONDITION_VARIABLE_INIT: CONDITION_VARIABLE = CONDITION_VARIABLE {
|
|
|
|
ptr: ptr::null_mut(),
|
|
|
|
};
|
|
|
|
pub const SRWLOCK_INIT: SRWLOCK = SRWLOCK { ptr: ptr::null_mut() };
|
2015-06-29 16:46:35 +00:00
|
|
|
|
2015-11-03 00:23:22 +00:00
|
|
|
pub const STILL_ACTIVE: DWORD = 259;
|
2015-07-10 08:54:00 +00:00
|
|
|
|
2015-11-03 00:23:22 +00:00
|
|
|
pub const DETACHED_PROCESS: DWORD = 0x00000008;
|
|
|
|
pub const CREATE_NEW_PROCESS_GROUP: DWORD = 0x00000200;
|
|
|
|
pub const CREATE_UNICODE_ENVIRONMENT: DWORD = 0x00000400;
|
|
|
|
pub const STARTF_USESTDHANDLES: DWORD = 0x00000100;
|
|
|
|
|
|
|
|
pub const AF_INET: c_int = 2;
|
|
|
|
pub const AF_INET6: c_int = 23;
|
|
|
|
pub const SD_BOTH: c_int = 2;
|
|
|
|
pub const SD_RECEIVE: c_int = 0;
|
|
|
|
pub const SD_SEND: c_int = 1;
|
|
|
|
pub const SOCK_DGRAM: c_int = 2;
|
|
|
|
pub const SOCK_STREAM: c_int = 1;
|
|
|
|
pub const SOL_SOCKET: c_int = 0xffff;
|
|
|
|
pub const SO_RCVTIMEO: c_int = 0x1006;
|
|
|
|
pub const SO_SNDTIMEO: c_int = 0x1005;
|
|
|
|
pub const SO_REUSEADDR: c_int = 0x0004;
|
|
|
|
|
|
|
|
pub const VOLUME_NAME_DOS: DWORD = 0x0;
|
|
|
|
pub const MOVEFILE_REPLACE_EXISTING: DWORD = 1;
|
|
|
|
|
|
|
|
pub const FILE_BEGIN: DWORD = 0;
|
|
|
|
pub const FILE_CURRENT: DWORD = 1;
|
|
|
|
pub const FILE_END: DWORD = 2;
|
|
|
|
|
|
|
|
pub const WAIT_ABANDONED: DWORD = 0x00000080;
|
|
|
|
pub const WAIT_OBJECT_0: DWORD = 0x00000000;
|
|
|
|
pub const WAIT_TIMEOUT: DWORD = 0x00000102;
|
|
|
|
pub const WAIT_FAILED: DWORD = !0;
|
|
|
|
|
|
|
|
pub const MAX_SYM_NAME: usize = 2000;
|
|
|
|
pub const IMAGE_FILE_MACHINE_I386: DWORD = 0x014c;
|
|
|
|
pub const IMAGE_FILE_MACHINE_IA64: DWORD = 0x0200;
|
|
|
|
pub const IMAGE_FILE_MACHINE_AMD64: DWORD = 0x8664;
|
|
|
|
|
|
|
|
pub const PROV_RSA_FULL: DWORD = 1;
|
|
|
|
pub const CRYPT_SILENT: DWORD = 64;
|
|
|
|
pub const CRYPT_VERIFYCONTEXT: DWORD = 0xF0000000;
|
2015-07-09 17:45:40 +00:00
|
|
|
|
2015-07-27 20:41:35 +00:00
|
|
|
pub const EXCEPTION_CONTINUE_SEARCH: LONG = 0;
|
|
|
|
pub const EXCEPTION_STACK_OVERFLOW: DWORD = 0xc00000fd;
|
2015-11-03 00:23:22 +00:00
|
|
|
pub const EXCEPTION_MAXIMUM_PARAMETERS: usize = 15;
|
|
|
|
pub const EXCEPTION_NONCONTINUABLE: DWORD = 0x1; // Noncontinuable exception
|
|
|
|
pub const EXCEPTION_UNWINDING: DWORD = 0x2; // Unwind is in progress
|
|
|
|
pub const EXCEPTION_EXIT_UNWIND: DWORD = 0x4; // Exit unwind is in progress
|
|
|
|
pub const EXCEPTION_STACK_INVALID: DWORD = 0x8; // Stack out of limits or unaligned
|
|
|
|
pub const EXCEPTION_NESTED_CALL: DWORD = 0x10; // Nested exception handler call
|
|
|
|
pub const EXCEPTION_TARGET_UNWIND: DWORD = 0x20; // Target unwind in progress
|
|
|
|
pub const EXCEPTION_COLLIDED_UNWIND: DWORD = 0x40; // Collided exception handler call
|
|
|
|
pub const EXCEPTION_UNWIND: DWORD = EXCEPTION_UNWINDING |
|
|
|
|
EXCEPTION_EXIT_UNWIND |
|
|
|
|
EXCEPTION_TARGET_UNWIND |
|
|
|
|
EXCEPTION_COLLIDED_UNWIND;
|
2015-10-19 04:54:51 +00:00
|
|
|
|
2014-06-08 19:55:17 +00:00
|
|
|
#[repr(C)]
|
2014-08-07 08:05:00 +00:00
|
|
|
#[cfg(target_arch = "x86")]
|
2014-04-18 20:23:56 +00:00
|
|
|
pub struct WSADATA {
|
2015-11-03 00:23:22 +00:00
|
|
|
pub wVersion: WORD,
|
|
|
|
pub wHighVersion: WORD,
|
2015-01-01 04:40:24 +00:00
|
|
|
pub szDescription: [u8; WSADESCRIPTION_LEN + 1],
|
|
|
|
pub szSystemStatus: [u8; WSASYS_STATUS_LEN + 1],
|
2014-04-18 20:23:56 +00:00
|
|
|
pub iMaxSockets: u16,
|
|
|
|
pub iMaxUdpDg: u16,
|
2014-06-25 19:47:34 +00:00
|
|
|
pub lpVendorInfo: *mut u8,
|
2014-04-18 20:23:56 +00:00
|
|
|
}
|
2014-08-07 08:05:00 +00:00
|
|
|
#[repr(C)]
|
|
|
|
#[cfg(target_arch = "x86_64")]
|
|
|
|
pub struct WSADATA {
|
2015-11-03 00:23:22 +00:00
|
|
|
pub wVersion: WORD,
|
|
|
|
pub wHighVersion: WORD,
|
2014-08-07 08:05:00 +00:00
|
|
|
pub iMaxSockets: u16,
|
|
|
|
pub iMaxUdpDg: u16,
|
|
|
|
pub lpVendorInfo: *mut u8,
|
2015-01-01 04:40:24 +00:00
|
|
|
pub szDescription: [u8; WSADESCRIPTION_LEN + 1],
|
|
|
|
pub szSystemStatus: [u8; WSASYS_STATUS_LEN + 1],
|
2014-08-07 08:05:00 +00:00
|
|
|
}
|
2014-04-18 20:23:56 +00:00
|
|
|
|
2014-07-15 17:28:00 +00:00
|
|
|
#[repr(C)]
|
|
|
|
pub struct WSANETWORKEVENTS {
|
2015-11-03 00:23:22 +00:00
|
|
|
pub lNetworkEvents: c_long,
|
|
|
|
pub iErrorCode: [c_int; FD_MAX_EVENTS],
|
2014-07-15 17:28:00 +00:00
|
|
|
}
|
|
|
|
|
2015-11-03 00:23:22 +00:00
|
|
|
pub type WSAEVENT = HANDLE;
|
2014-07-15 17:28:00 +00:00
|
|
|
|
2015-02-11 23:29:51 +00:00
|
|
|
#[repr(C)]
|
|
|
|
pub struct WSAPROTOCOL_INFO {
|
2015-11-03 00:23:22 +00:00
|
|
|
pub dwServiceFlags1: DWORD,
|
|
|
|
pub dwServiceFlags2: DWORD,
|
|
|
|
pub dwServiceFlags3: DWORD,
|
|
|
|
pub dwServiceFlags4: DWORD,
|
|
|
|
pub dwProviderFlags: DWORD,
|
2015-02-11 23:29:51 +00:00
|
|
|
pub ProviderId: GUID,
|
2015-11-03 00:23:22 +00:00
|
|
|
pub dwCatalogEntryId: DWORD,
|
2015-02-11 23:29:51 +00:00
|
|
|
pub ProtocolChain: WSAPROTOCOLCHAIN,
|
2015-11-03 00:23:22 +00:00
|
|
|
pub iVersion: c_int,
|
|
|
|
pub iAddressFamily: c_int,
|
|
|
|
pub iMaxSockAddr: c_int,
|
|
|
|
pub iMinSockAddr: c_int,
|
|
|
|
pub iSocketType: c_int,
|
|
|
|
pub iProtocol: c_int,
|
|
|
|
pub iProtocolMaxOffset: c_int,
|
|
|
|
pub iNetworkByteOrder: c_int,
|
|
|
|
pub iSecurityScheme: c_int,
|
|
|
|
pub dwMessageSize: DWORD,
|
|
|
|
pub dwProviderReserved: DWORD,
|
2015-02-17 14:47:49 +00:00
|
|
|
pub szProtocol: [u16; (WSAPROTOCOL_LEN as usize) + 1],
|
2015-02-11 23:29:51 +00:00
|
|
|
}
|
|
|
|
|
2014-06-08 19:55:17 +00:00
|
|
|
#[repr(C)]
|
2014-04-18 20:23:56 +00:00
|
|
|
pub struct fd_set {
|
2015-11-03 00:23:22 +00:00
|
|
|
fd_count: c_uint,
|
|
|
|
fd_array: [SOCKET; FD_SETSIZE],
|
2014-04-18 20:23:56 +00:00
|
|
|
}
|
|
|
|
|
2015-11-03 00:23:22 +00:00
|
|
|
pub fn fd_set(set: &mut fd_set, s: SOCKET) {
|
2015-01-27 20:20:58 +00:00
|
|
|
set.fd_array[set.fd_count as usize] = s;
|
2014-04-18 20:23:56 +00:00
|
|
|
set.fd_count += 1;
|
|
|
|
}
|
|
|
|
|
2015-11-03 00:23:22 +00:00
|
|
|
pub type SHORT = c_short;
|
2015-01-06 05:54:09 +00:00
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct COORD {
|
|
|
|
pub X: SHORT,
|
|
|
|
pub Y: SHORT,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct SMALL_RECT {
|
|
|
|
pub Left: SHORT,
|
|
|
|
pub Top: SHORT,
|
|
|
|
pub Right: SHORT,
|
|
|
|
pub Bottom: SHORT,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct CONSOLE_SCREEN_BUFFER_INFO {
|
|
|
|
pub dwSize: COORD,
|
|
|
|
pub dwCursorPosition: COORD,
|
2015-11-03 00:23:22 +00:00
|
|
|
pub wAttributes: WORD,
|
2015-01-06 05:54:09 +00:00
|
|
|
pub srWindow: SMALL_RECT,
|
|
|
|
pub dwMaximumWindowSize: COORD,
|
|
|
|
}
|
|
|
|
pub type PCONSOLE_SCREEN_BUFFER_INFO = *mut CONSOLE_SCREEN_BUFFER_INFO;
|
|
|
|
|
2015-01-27 20:20:58 +00:00
|
|
|
#[repr(C)]
|
2015-11-03 00:23:22 +00:00
|
|
|
#[derive(Copy, Clone)]
|
2015-01-27 20:20:58 +00:00
|
|
|
pub struct WIN32_FILE_ATTRIBUTE_DATA {
|
2015-11-03 00:23:22 +00:00
|
|
|
pub dwFileAttributes: DWORD,
|
|
|
|
pub ftCreationTime: FILETIME,
|
|
|
|
pub ftLastAccessTime: FILETIME,
|
|
|
|
pub ftLastWriteTime: FILETIME,
|
|
|
|
pub nFileSizeHigh: DWORD,
|
|
|
|
pub nFileSizeLow: DWORD,
|
2015-01-27 20:20:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct BY_HANDLE_FILE_INFORMATION {
|
2015-11-03 00:23:22 +00:00
|
|
|
pub dwFileAttributes: DWORD,
|
|
|
|
pub ftCreationTime: FILETIME,
|
|
|
|
pub ftLastAccessTime: FILETIME,
|
|
|
|
pub ftLastWriteTime: FILETIME,
|
|
|
|
pub dwVolumeSerialNumber: DWORD,
|
|
|
|
pub nFileSizeHigh: DWORD,
|
|
|
|
pub nFileSizeLow: DWORD,
|
|
|
|
pub nNumberOfLinks: DWORD,
|
|
|
|
pub nFileIndexHigh: DWORD,
|
|
|
|
pub nFileIndexLow: DWORD,
|
2015-01-27 20:20:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub enum GET_FILEEX_INFO_LEVELS {
|
|
|
|
GetFileExInfoStandard,
|
|
|
|
GetFileExMaxInfoLevel
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub enum FILE_INFO_BY_HANDLE_CLASS {
|
|
|
|
FileBasicInfo = 0,
|
|
|
|
FileStandardInfo = 1,
|
|
|
|
FileNameInfo = 2,
|
|
|
|
FileRenameInfo = 3,
|
|
|
|
FileDispositionInfo = 4,
|
|
|
|
FileAllocationInfo = 5,
|
|
|
|
FileEndOfFileInfo = 6,
|
|
|
|
FileStreamInfo = 7,
|
|
|
|
FileCompressionInfo = 8,
|
|
|
|
FileAttributeTagInfo = 9,
|
|
|
|
FileIdBothDirectoryInfo = 10, // 0xA
|
|
|
|
FileIdBothDirectoryRestartInfo = 11, // 0xB
|
|
|
|
FileIoPriorityHintInfo = 12, // 0xC
|
|
|
|
FileRemoteProtocolInfo = 13, // 0xD
|
|
|
|
FileFullDirectoryInfo = 14, // 0xE
|
|
|
|
FileFullDirectoryRestartInfo = 15, // 0xF
|
|
|
|
FileStorageInfo = 16, // 0x10
|
|
|
|
FileAlignmentInfo = 17, // 0x11
|
|
|
|
FileIdInfo = 18, // 0x12
|
|
|
|
FileIdExtdDirectoryInfo = 19, // 0x13
|
|
|
|
FileIdExtdDirectoryRestartInfo = 20, // 0x14
|
|
|
|
MaximumFileInfoByHandlesClass
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct FILE_END_OF_FILE_INFO {
|
2015-11-03 00:23:22 +00:00
|
|
|
pub EndOfFile: LARGE_INTEGER,
|
2015-01-27 20:20:58 +00:00
|
|
|
}
|
|
|
|
|
2015-04-08 16:50:50 +00:00
|
|
|
#[repr(C)]
|
|
|
|
pub struct REPARSE_DATA_BUFFER {
|
2015-11-03 00:23:22 +00:00
|
|
|
pub ReparseTag: c_uint,
|
|
|
|
pub ReparseDataLength: c_ushort,
|
|
|
|
pub Reserved: c_ushort,
|
2015-04-08 16:50:50 +00:00
|
|
|
pub rest: (),
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct SYMBOLIC_LINK_REPARSE_BUFFER {
|
2015-11-03 00:23:22 +00:00
|
|
|
pub SubstituteNameOffset: c_ushort,
|
|
|
|
pub SubstituteNameLength: c_ushort,
|
|
|
|
pub PrintNameOffset: c_ushort,
|
|
|
|
pub PrintNameLength: c_ushort,
|
|
|
|
pub Flags: c_ulong,
|
|
|
|
pub PathBuffer: WCHAR,
|
2015-04-08 16:50:50 +00:00
|
|
|
}
|
|
|
|
|
2015-07-10 08:54:00 +00:00
|
|
|
pub type LPPROGRESS_ROUTINE = ::option::Option<unsafe extern "system" fn(
|
2015-11-03 00:23:22 +00:00
|
|
|
TotalFileSize: LARGE_INTEGER,
|
|
|
|
TotalBytesTransferred: LARGE_INTEGER,
|
|
|
|
StreamSize: LARGE_INTEGER,
|
|
|
|
StreamBytesTransferred: LARGE_INTEGER,
|
2015-07-10 08:54:00 +00:00
|
|
|
dwStreamNumber: DWORD,
|
|
|
|
dwCallbackReason: DWORD,
|
|
|
|
hSourceFile: HANDLE,
|
|
|
|
hDestinationFile: HANDLE,
|
|
|
|
lpData: LPVOID,
|
|
|
|
) -> DWORD>;
|
2015-06-26 16:30:35 +00:00
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct CONDITION_VARIABLE { pub ptr: LPVOID }
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct SRWLOCK { pub ptr: LPVOID }
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct CRITICAL_SECTION {
|
|
|
|
CriticalSectionDebug: LPVOID,
|
|
|
|
LockCount: LONG,
|
|
|
|
RecursionCount: LONG,
|
|
|
|
OwningThread: HANDLE,
|
|
|
|
LockSemaphore: HANDLE,
|
|
|
|
SpinCount: ULONG_PTR
|
|
|
|
}
|
|
|
|
|
2015-07-09 17:45:40 +00:00
|
|
|
#[repr(C)]
|
|
|
|
pub struct LUID {
|
2015-11-03 00:23:22 +00:00
|
|
|
pub LowPart: DWORD,
|
|
|
|
pub HighPart: c_long,
|
2015-07-09 17:45:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pub type PLUID = *mut LUID;
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct TOKEN_PRIVILEGES {
|
2015-11-03 00:23:22 +00:00
|
|
|
pub PrivilegeCount: DWORD,
|
2015-07-09 17:45:40 +00:00
|
|
|
pub Privileges: [LUID_AND_ATTRIBUTES; 1],
|
|
|
|
}
|
|
|
|
|
|
|
|
pub type PTOKEN_PRIVILEGES = *mut TOKEN_PRIVILEGES;
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct LUID_AND_ATTRIBUTES {
|
|
|
|
pub Luid: LUID,
|
2015-11-03 00:23:22 +00:00
|
|
|
pub Attributes: DWORD,
|
2015-07-09 17:45:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct REPARSE_MOUNTPOINT_DATA_BUFFER {
|
2015-11-03 00:23:22 +00:00
|
|
|
pub ReparseTag: DWORD,
|
|
|
|
pub ReparseDataLength: DWORD,
|
|
|
|
pub Reserved: WORD,
|
|
|
|
pub ReparseTargetLength: WORD,
|
|
|
|
pub ReparseTargetMaximumLength: WORD,
|
|
|
|
pub Reserved1: WORD,
|
|
|
|
pub ReparseTarget: WCHAR,
|
2015-07-09 17:45:40 +00:00
|
|
|
}
|
|
|
|
|
2015-07-27 20:41:35 +00:00
|
|
|
#[repr(C)]
|
|
|
|
pub struct EXCEPTION_RECORD {
|
|
|
|
pub ExceptionCode: DWORD,
|
|
|
|
pub ExceptionFlags: DWORD,
|
|
|
|
pub ExceptionRecord: *mut EXCEPTION_RECORD,
|
|
|
|
pub ExceptionAddress: LPVOID,
|
|
|
|
pub NumberParameters: DWORD,
|
|
|
|
pub ExceptionInformation: [LPVOID; EXCEPTION_MAXIMUM_PARAMETERS]
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct EXCEPTION_POINTERS {
|
|
|
|
pub ExceptionRecord: *mut EXCEPTION_RECORD,
|
2015-11-03 00:23:22 +00:00
|
|
|
pub ContextRecord: *mut CONTEXT,
|
2015-07-27 20:41:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pub type PVECTORED_EXCEPTION_HANDLER = extern "system"
|
|
|
|
fn(ExceptionInfo: *mut EXCEPTION_POINTERS) -> LONG;
|
2015-07-09 17:45:40 +00:00
|
|
|
|
2015-11-03 00:23:22 +00:00
|
|
|
#[repr(C)]
|
|
|
|
pub struct GUID {
|
|
|
|
pub Data1: DWORD,
|
|
|
|
pub Data2: WORD,
|
|
|
|
pub Data3: WORD,
|
|
|
|
pub Data4: [BYTE; 8],
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct WSAPROTOCOLCHAIN {
|
|
|
|
pub ChainLen: c_int,
|
|
|
|
pub ChainEntries: [DWORD; MAX_PROTOCOL_CHAIN as usize],
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct SECURITY_ATTRIBUTES {
|
|
|
|
pub nLength: DWORD,
|
|
|
|
pub lpSecurityDescriptor: LPVOID,
|
|
|
|
pub bInheritHandle: BOOL,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct PROCESS_INFORMATION {
|
|
|
|
pub hProcess: HANDLE,
|
|
|
|
pub hThread: HANDLE,
|
|
|
|
pub dwProcessId: DWORD,
|
|
|
|
pub dwThreadId: DWORD,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct STARTUPINFO {
|
|
|
|
pub cb: DWORD,
|
|
|
|
pub lpReserved: LPWSTR,
|
|
|
|
pub lpDesktop: LPWSTR,
|
|
|
|
pub lpTitle: LPWSTR,
|
|
|
|
pub dwX: DWORD,
|
|
|
|
pub dwY: DWORD,
|
|
|
|
pub dwXSize: DWORD,
|
|
|
|
pub dwYSize: DWORD,
|
|
|
|
pub dwXCountChars: DWORD,
|
|
|
|
pub dwYCountCharts: DWORD,
|
|
|
|
pub dwFillAttribute: DWORD,
|
|
|
|
pub dwFlags: DWORD,
|
|
|
|
pub wShowWindow: WORD,
|
|
|
|
pub cbReserved2: WORD,
|
|
|
|
pub lpReserved2: LPBYTE,
|
|
|
|
pub hStdInput: HANDLE,
|
|
|
|
pub hStdOutput: HANDLE,
|
|
|
|
pub hStdError: HANDLE,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct SOCKADDR {
|
|
|
|
pub sa_family: ADDRESS_FAMILY,
|
|
|
|
pub sa_data: [CHAR; 14],
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
#[derive(Copy, Clone)]
|
|
|
|
pub struct FILETIME {
|
|
|
|
pub dwLowDateTime: DWORD,
|
|
|
|
pub dwHighDateTime: DWORD,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct OVERLAPPED {
|
|
|
|
pub Internal: *mut c_ulong,
|
|
|
|
pub InternalHigh: *mut c_ulong,
|
|
|
|
pub Offset: DWORD,
|
|
|
|
pub OffsetHigh: DWORD,
|
|
|
|
pub hEvent: HANDLE,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct SYMBOL_INFO {
|
|
|
|
pub SizeOfStruct: c_ulong,
|
|
|
|
pub TypeIndex: c_ulong,
|
|
|
|
pub Reserved: [u64; 2],
|
|
|
|
pub Index: c_ulong,
|
|
|
|
pub Size: c_ulong,
|
|
|
|
pub ModBase: u64,
|
|
|
|
pub Flags: c_ulong,
|
|
|
|
pub Value: u64,
|
|
|
|
pub Address: u64,
|
|
|
|
pub Register: c_ulong,
|
|
|
|
pub Scope: c_ulong,
|
|
|
|
pub Tag: c_ulong,
|
|
|
|
pub NameLen: c_ulong,
|
|
|
|
pub MaxNameLen: c_ulong,
|
|
|
|
// note that windows has this as 1, but it basically just means that
|
|
|
|
// the name is inline at the end of the struct. For us, we just bump
|
|
|
|
// the struct size up to MAX_SYM_NAME.
|
|
|
|
pub Name: [c_char; MAX_SYM_NAME],
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct IMAGEHLP_LINE64 {
|
|
|
|
pub SizeOfStruct: u32,
|
|
|
|
pub Key: *const c_void,
|
|
|
|
pub LineNumber: u32,
|
|
|
|
pub Filename: *const c_char,
|
|
|
|
pub Address: u64,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub enum ADDRESS_MODE {
|
|
|
|
AddrMode1616,
|
|
|
|
AddrMode1632,
|
|
|
|
AddrModeReal,
|
|
|
|
AddrModeFlat,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct ADDRESS64 {
|
|
|
|
pub Offset: u64,
|
|
|
|
pub Segment: u16,
|
|
|
|
pub Mode: ADDRESS_MODE,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct STACKFRAME64 {
|
|
|
|
pub AddrPC: ADDRESS64,
|
|
|
|
pub AddrReturn: ADDRESS64,
|
|
|
|
pub AddrFrame: ADDRESS64,
|
|
|
|
pub AddrStack: ADDRESS64,
|
|
|
|
pub AddrBStore: ADDRESS64,
|
|
|
|
pub FuncTableEntry: *mut c_void,
|
|
|
|
pub Params: [u64; 4],
|
|
|
|
pub Far: BOOL,
|
|
|
|
pub Virtual: BOOL,
|
|
|
|
pub Reserved: [u64; 3],
|
|
|
|
pub KdHelp: KDHELP64,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct KDHELP64 {
|
|
|
|
pub Thread: u64,
|
|
|
|
pub ThCallbackStack: DWORD,
|
|
|
|
pub ThCallbackBStore: DWORD,
|
|
|
|
pub NextCallback: DWORD,
|
|
|
|
pub FramePointer: DWORD,
|
|
|
|
pub KiCallUserMode: u64,
|
|
|
|
pub KeUserCallbackDispatcher: u64,
|
|
|
|
pub SystemRangeStart: u64,
|
|
|
|
pub KiUserExceptionDispatcher: u64,
|
|
|
|
pub StackBase: u64,
|
|
|
|
pub StackLimit: u64,
|
|
|
|
pub Reserved: [u64; 5],
|
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(target_arch = "x86")]
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct CONTEXT {
|
|
|
|
pub ContextFlags: DWORD,
|
|
|
|
pub Dr0: DWORD,
|
|
|
|
pub Dr1: DWORD,
|
|
|
|
pub Dr2: DWORD,
|
|
|
|
pub Dr3: DWORD,
|
|
|
|
pub Dr6: DWORD,
|
|
|
|
pub Dr7: DWORD,
|
|
|
|
pub FloatSave: FLOATING_SAVE_AREA,
|
|
|
|
pub SegGs: DWORD,
|
|
|
|
pub SegFs: DWORD,
|
|
|
|
pub SegEs: DWORD,
|
|
|
|
pub SegDs: DWORD,
|
|
|
|
pub Edi: DWORD,
|
|
|
|
pub Esi: DWORD,
|
|
|
|
pub Ebx: DWORD,
|
|
|
|
pub Edx: DWORD,
|
|
|
|
pub Ecx: DWORD,
|
|
|
|
pub Eax: DWORD,
|
|
|
|
pub Ebp: DWORD,
|
|
|
|
pub Eip: DWORD,
|
|
|
|
pub SegCs: DWORD,
|
|
|
|
pub EFlags: DWORD,
|
|
|
|
pub Esp: DWORD,
|
|
|
|
pub SegSs: DWORD,
|
|
|
|
pub ExtendedRegisters: [u8; 512],
|
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(target_arch = "x86")]
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct FLOATING_SAVE_AREA {
|
|
|
|
pub ControlWord: DWORD,
|
|
|
|
pub StatusWord: DWORD,
|
|
|
|
pub TagWord: DWORD,
|
|
|
|
pub ErrorOffset: DWORD,
|
|
|
|
pub ErrorSelector: DWORD,
|
|
|
|
pub DataOffset: DWORD,
|
|
|
|
pub DataSelector: DWORD,
|
|
|
|
pub RegisterArea: [u8; 80],
|
|
|
|
pub Cr0NpxState: DWORD,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(target_arch = "x86_64")]
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct CONTEXT {
|
|
|
|
_align_hack: [simd::u64x2; 0], // FIXME align on 16-byte
|
|
|
|
pub P1Home: DWORDLONG,
|
|
|
|
pub P2Home: DWORDLONG,
|
|
|
|
pub P3Home: DWORDLONG,
|
|
|
|
pub P4Home: DWORDLONG,
|
|
|
|
pub P5Home: DWORDLONG,
|
|
|
|
pub P6Home: DWORDLONG,
|
|
|
|
|
|
|
|
pub ContextFlags: DWORD,
|
|
|
|
pub MxCsr: DWORD,
|
|
|
|
|
|
|
|
pub SegCs: WORD,
|
|
|
|
pub SegDs: WORD,
|
|
|
|
pub SegEs: WORD,
|
|
|
|
pub SegFs: WORD,
|
|
|
|
pub SegGs: WORD,
|
|
|
|
pub SegSs: WORD,
|
|
|
|
pub EFlags: DWORD,
|
|
|
|
|
|
|
|
pub Dr0: DWORDLONG,
|
|
|
|
pub Dr1: DWORDLONG,
|
|
|
|
pub Dr2: DWORDLONG,
|
|
|
|
pub Dr3: DWORDLONG,
|
|
|
|
pub Dr6: DWORDLONG,
|
|
|
|
pub Dr7: DWORDLONG,
|
|
|
|
|
|
|
|
pub Rax: DWORDLONG,
|
|
|
|
pub Rcx: DWORDLONG,
|
|
|
|
pub Rdx: DWORDLONG,
|
|
|
|
pub Rbx: DWORDLONG,
|
|
|
|
pub Rsp: DWORDLONG,
|
|
|
|
pub Rbp: DWORDLONG,
|
|
|
|
pub Rsi: DWORDLONG,
|
|
|
|
pub Rdi: DWORDLONG,
|
|
|
|
pub R8: DWORDLONG,
|
|
|
|
pub R9: DWORDLONG,
|
|
|
|
pub R10: DWORDLONG,
|
|
|
|
pub R11: DWORDLONG,
|
|
|
|
pub R12: DWORDLONG,
|
|
|
|
pub R13: DWORDLONG,
|
|
|
|
pub R14: DWORDLONG,
|
|
|
|
pub R15: DWORDLONG,
|
|
|
|
|
|
|
|
pub Rip: DWORDLONG,
|
|
|
|
|
|
|
|
pub FltSave: FLOATING_SAVE_AREA,
|
|
|
|
|
|
|
|
pub VectorRegister: [M128A; 26],
|
|
|
|
pub VectorControl: DWORDLONG,
|
|
|
|
|
|
|
|
pub DebugControl: DWORDLONG,
|
|
|
|
pub LastBranchToRip: DWORDLONG,
|
|
|
|
pub LastBranchFromRip: DWORDLONG,
|
|
|
|
pub LastExceptionToRip: DWORDLONG,
|
|
|
|
pub LastExceptionFromRip: DWORDLONG,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(target_arch = "x86_64")]
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct M128A {
|
|
|
|
_align_hack: [simd::u64x2; 0], // FIXME align on 16-byte
|
|
|
|
pub Low: c_ulonglong,
|
|
|
|
pub High: c_longlong
|
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(target_arch = "x86_64")]
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct FLOATING_SAVE_AREA {
|
|
|
|
_align_hack: [simd::u64x2; 0], // FIXME align on 16-byte
|
|
|
|
_Dummy: [u8; 512] // FIXME: Fill this out
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct SOCKADDR_STORAGE_LH {
|
|
|
|
pub ss_family: ADDRESS_FAMILY,
|
|
|
|
pub __ss_pad1: [CHAR; 6],
|
|
|
|
pub __ss_align: i64,
|
|
|
|
pub __ss_pad2: [CHAR; 112],
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct ADDRINFOA {
|
|
|
|
pub ai_flags: c_int,
|
|
|
|
pub ai_family: c_int,
|
|
|
|
pub ai_socktype: c_int,
|
|
|
|
pub ai_protocol: c_int,
|
|
|
|
pub ai_addrlen: size_t,
|
|
|
|
pub ai_canonname: *mut c_char,
|
|
|
|
pub ai_addr: *mut SOCKADDR,
|
|
|
|
pub ai_next: *mut ADDRINFOA,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
#[derive(Copy, Clone)]
|
|
|
|
pub struct sockaddr_in {
|
|
|
|
pub sin_family: ADDRESS_FAMILY,
|
|
|
|
pub sin_port: USHORT,
|
|
|
|
pub sin_addr: in_addr,
|
|
|
|
pub sin_zero: [CHAR; 8],
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
#[derive(Copy, Clone)]
|
|
|
|
pub struct sockaddr_in6 {
|
|
|
|
pub sin6_family: ADDRESS_FAMILY,
|
|
|
|
pub sin6_port: USHORT,
|
|
|
|
pub sin6_flowinfo: c_ulong,
|
|
|
|
pub sin6_addr: in6_addr,
|
|
|
|
pub sin6_scope_id: c_ulong,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
#[derive(Copy, Clone)]
|
|
|
|
pub struct in_addr {
|
|
|
|
pub s_addr: u32,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
#[derive(Copy, Clone)]
|
|
|
|
pub struct in6_addr {
|
|
|
|
pub s6_addr: [u8; 16],
|
|
|
|
}
|
|
|
|
|
|
|
|
pub enum UNWIND_HISTORY_TABLE {}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct RUNTIME_FUNCTION {
|
|
|
|
pub BeginAddress: DWORD,
|
|
|
|
pub EndAddress: DWORD,
|
|
|
|
pub UnwindData: DWORD,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct DISPATCHER_CONTEXT {
|
|
|
|
pub ControlPc: LPVOID,
|
|
|
|
pub ImageBase: LPVOID,
|
|
|
|
pub FunctionEntry: *const RUNTIME_FUNCTION,
|
|
|
|
pub EstablisherFrame: LPVOID,
|
|
|
|
pub TargetIp: LPVOID,
|
|
|
|
pub ContextRecord: *const CONTEXT,
|
|
|
|
pub LanguageHandler: LPVOID,
|
|
|
|
pub HandlerData: *const u8,
|
|
|
|
pub HistoryTable: *const UNWIND_HISTORY_TABLE,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
#[derive(Copy, Clone)]
|
|
|
|
pub enum EXCEPTION_DISPOSITION {
|
|
|
|
ExceptionContinueExecution,
|
|
|
|
ExceptionContinueSearch,
|
|
|
|
ExceptionNestedException,
|
|
|
|
ExceptionCollidedUnwind
|
|
|
|
}
|
|
|
|
|
2014-04-18 20:23:56 +00:00
|
|
|
#[link(name = "ws2_32")]
|
2015-06-26 16:30:35 +00:00
|
|
|
#[link(name = "userenv")]
|
2015-10-23 16:35:02 +00:00
|
|
|
#[link(name = "shell32")]
|
2015-11-03 00:23:22 +00:00
|
|
|
#[link(name = "advapi32")]
|
2014-04-18 20:23:56 +00:00
|
|
|
extern "system" {
|
2015-11-03 00:23:22 +00:00
|
|
|
pub fn WSAStartup(wVersionRequested: WORD,
|
|
|
|
lpWSAData: LPWSADATA) -> c_int;
|
|
|
|
pub fn WSACleanup() -> c_int;
|
|
|
|
pub fn WSAGetLastError() -> c_int;
|
|
|
|
pub fn WSADuplicateSocketW(s: SOCKET,
|
|
|
|
dwProcessId: DWORD,
|
2015-02-11 23:29:51 +00:00
|
|
|
lpProtocolInfo: LPWSAPROTOCOL_INFO)
|
2015-11-03 00:23:22 +00:00
|
|
|
-> c_int;
|
|
|
|
pub fn GetCurrentProcessId() -> DWORD;
|
|
|
|
pub fn WSASocketW(af: c_int,
|
|
|
|
kind: c_int,
|
|
|
|
protocol: c_int,
|
2015-02-11 23:29:51 +00:00
|
|
|
lpProtocolInfo: LPWSAPROTOCOL_INFO,
|
|
|
|
g: GROUP,
|
2015-11-03 00:23:22 +00:00
|
|
|
dwFlags: DWORD) -> SOCKET;
|
2015-06-26 16:30:35 +00:00
|
|
|
pub fn InitializeCriticalSection(CriticalSection: *mut CRITICAL_SECTION);
|
|
|
|
pub fn EnterCriticalSection(CriticalSection: *mut CRITICAL_SECTION);
|
|
|
|
pub fn TryEnterCriticalSection(CriticalSection: *mut CRITICAL_SECTION) -> BOOLEAN;
|
|
|
|
pub fn LeaveCriticalSection(CriticalSection: *mut CRITICAL_SECTION);
|
|
|
|
pub fn DeleteCriticalSection(CriticalSection: *mut CRITICAL_SECTION);
|
2014-05-07 18:06:15 +00:00
|
|
|
|
2014-07-04 14:45:28 +00:00
|
|
|
// FIXME - pInputControl should be PCONSOLE_READCONSOLE_CONTROL
|
2015-11-03 00:23:22 +00:00
|
|
|
pub fn ReadConsoleW(hConsoleInput: HANDLE,
|
|
|
|
lpBuffer: LPVOID,
|
|
|
|
nNumberOfCharsToRead: DWORD,
|
|
|
|
lpNumberOfCharsRead: LPDWORD,
|
|
|
|
pInputControl: LPVOID) -> BOOL;
|
|
|
|
|
|
|
|
pub fn WriteConsoleW(hConsoleOutput: HANDLE,
|
|
|
|
lpBuffer: LPCVOID,
|
|
|
|
nNumberOfCharsToWrite: DWORD,
|
|
|
|
lpNumberOfCharsWritten: LPDWORD,
|
|
|
|
lpReserved: LPVOID) -> BOOL;
|
|
|
|
|
|
|
|
pub fn GetConsoleMode(hConsoleHandle: HANDLE,
|
|
|
|
lpMode: LPDWORD) -> BOOL;
|
|
|
|
pub fn GetFileAttributesExW(lpFileName: LPCWSTR,
|
2015-01-27 20:20:58 +00:00
|
|
|
fInfoLevelId: GET_FILEEX_INFO_LEVELS,
|
2015-11-03 00:23:22 +00:00
|
|
|
lpFileInformation: LPVOID) -> BOOL;
|
|
|
|
pub fn RemoveDirectoryW(lpPathName: LPCWSTR) -> BOOL;
|
|
|
|
pub fn SetFileAttributesW(lpFileName: LPCWSTR,
|
|
|
|
dwFileAttributes: DWORD) -> BOOL;
|
|
|
|
pub fn GetFileInformationByHandle(hFile: HANDLE,
|
2015-01-27 20:20:58 +00:00
|
|
|
lpFileInformation: LPBY_HANDLE_FILE_INFORMATION)
|
2015-11-03 00:23:22 +00:00
|
|
|
-> BOOL;
|
|
|
|
|
|
|
|
pub fn SetLastError(dwErrCode: DWORD);
|
|
|
|
pub fn GetCommandLineW() -> *mut LPCWSTR;
|
|
|
|
pub fn LocalFree(ptr: *mut c_void);
|
|
|
|
pub fn CommandLineToArgvW(lpCmdLine: *mut LPCWSTR,
|
|
|
|
pNumArgs: *mut c_int) -> *mut *mut u16;
|
|
|
|
pub fn GetTempPathW(nBufferLength: DWORD,
|
|
|
|
lpBuffer: LPCWSTR) -> DWORD;
|
|
|
|
pub fn OpenProcessToken(ProcessHandle: HANDLE,
|
|
|
|
DesiredAccess: DWORD,
|
|
|
|
TokenHandle: *mut HANDLE) -> BOOL;
|
|
|
|
pub fn GetCurrentProcess() -> HANDLE;
|
|
|
|
pub fn GetCurrentThread() -> HANDLE;
|
|
|
|
pub fn GetStdHandle(which: DWORD) -> HANDLE;
|
|
|
|
pub fn ExitProcess(uExitCode: c_uint) -> !;
|
|
|
|
pub fn DeviceIoControl(hDevice: HANDLE,
|
|
|
|
dwIoControlCode: DWORD,
|
|
|
|
lpInBuffer: LPVOID,
|
|
|
|
nInBufferSize: DWORD,
|
|
|
|
lpOutBuffer: LPVOID,
|
|
|
|
nOutBufferSize: DWORD,
|
|
|
|
lpBytesReturned: LPDWORD,
|
|
|
|
lpOverlapped: LPOVERLAPPED) -> BOOL;
|
|
|
|
pub fn CreatePipe(hReadPipe: LPHANDLE,
|
|
|
|
hWritePipe: LPHANDLE,
|
|
|
|
lpPipeAttributes: LPSECURITY_ATTRIBUTES,
|
|
|
|
nSize: DWORD) -> BOOL;
|
|
|
|
pub fn CreateThread(lpThreadAttributes: LPSECURITY_ATTRIBUTES,
|
|
|
|
dwStackSize: SIZE_T,
|
|
|
|
lpStartAddress: extern "system" fn(*mut c_void)
|
|
|
|
-> DWORD,
|
|
|
|
lpParameter: LPVOID,
|
|
|
|
dwCreationFlags: DWORD,
|
|
|
|
lpThreadId: LPDWORD) -> HANDLE;
|
|
|
|
pub fn WaitForSingleObject(hHandle: HANDLE,
|
|
|
|
dwMilliseconds: DWORD) -> DWORD;
|
|
|
|
pub fn SwitchToThread() -> BOOL;
|
|
|
|
pub fn Sleep(dwMilliseconds: DWORD);
|
|
|
|
pub fn GetProcessId(handle: HANDLE) -> DWORD;
|
|
|
|
pub fn GetUserProfileDirectoryW(hToken: HANDLE,
|
|
|
|
lpProfileDir: LPCWSTR,
|
|
|
|
lpcchSize: *mut DWORD) -> BOOL;
|
|
|
|
pub fn SetHandleInformation(hObject: HANDLE,
|
|
|
|
dwMask: DWORD,
|
|
|
|
dwFlags: DWORD) -> BOOL;
|
|
|
|
pub fn CopyFileExW(lpExistingFileName: LPCWSTR,
|
|
|
|
lpNewFileName: LPCWSTR,
|
2015-07-10 08:54:00 +00:00
|
|
|
lpProgressRoutine: LPPROGRESS_ROUTINE,
|
2015-11-03 00:23:22 +00:00
|
|
|
lpData: LPVOID,
|
2015-07-10 08:54:00 +00:00
|
|
|
pbCancel: LPBOOL,
|
2015-11-03 00:23:22 +00:00
|
|
|
dwCopyFlags: DWORD) -> BOOL;
|
|
|
|
pub fn LookupPrivilegeValueW(lpSystemName: LPCWSTR,
|
|
|
|
lpName: LPCWSTR,
|
|
|
|
lpLuid: PLUID) -> BOOL;
|
|
|
|
pub fn AdjustTokenPrivileges(TokenHandle: HANDLE,
|
|
|
|
DisableAllPrivileges: BOOL,
|
2015-07-09 17:45:40 +00:00
|
|
|
NewState: PTOKEN_PRIVILEGES,
|
2015-11-03 00:23:22 +00:00
|
|
|
BufferLength: DWORD,
|
2015-07-09 17:45:40 +00:00
|
|
|
PreviousState: PTOKEN_PRIVILEGES,
|
2015-11-03 00:23:22 +00:00
|
|
|
ReturnLength: *mut DWORD) -> BOOL;
|
2015-07-27 20:41:35 +00:00
|
|
|
pub fn AddVectoredExceptionHandler(FirstHandler: ULONG,
|
|
|
|
VectoredHandler: PVECTORED_EXCEPTION_HANDLER)
|
|
|
|
-> LPVOID;
|
2015-11-03 00:23:22 +00:00
|
|
|
pub fn FormatMessageW(flags: DWORD,
|
|
|
|
lpSrc: LPVOID,
|
|
|
|
msgId: DWORD,
|
|
|
|
langId: DWORD,
|
|
|
|
buf: LPWSTR,
|
|
|
|
nsize: DWORD,
|
|
|
|
args: *const c_void)
|
|
|
|
-> DWORD;
|
|
|
|
pub fn TlsAlloc() -> DWORD;
|
|
|
|
pub fn TlsFree(dwTlsIndex: DWORD) -> BOOL;
|
|
|
|
pub fn TlsGetValue(dwTlsIndex: DWORD) -> LPVOID;
|
|
|
|
pub fn TlsSetValue(dwTlsIndex: DWORD, lpTlsvalue: LPVOID) -> BOOL;
|
|
|
|
pub fn GetLastError() -> DWORD;
|
|
|
|
pub fn QueryPerformanceFrequency(lpFrequency: *mut LARGE_INTEGER) -> BOOL;
|
|
|
|
pub fn QueryPerformanceCounter(lpPerformanceCount: *mut LARGE_INTEGER)
|
|
|
|
-> BOOL;
|
|
|
|
pub fn GetExitCodeProcess(hProcess: HANDLE, lpExitCode: LPDWORD) -> BOOL;
|
|
|
|
pub fn TerminateProcess(hProcess: HANDLE, uExitCode: UINT) -> BOOL;
|
|
|
|
pub fn CreateProcessW(lpApplicationName: LPCWSTR,
|
|
|
|
lpCommandLine: LPWSTR,
|
|
|
|
lpProcessAttributes: LPSECURITY_ATTRIBUTES,
|
|
|
|
lpThreadAttributes: LPSECURITY_ATTRIBUTES,
|
|
|
|
bInheritHandles: BOOL,
|
|
|
|
dwCreationFlags: DWORD,
|
|
|
|
lpEnvironment: LPVOID,
|
|
|
|
lpCurrentDirectory: LPCWSTR,
|
|
|
|
lpStartupInfo: LPSTARTUPINFO,
|
|
|
|
lpProcessInformation: LPPROCESS_INFORMATION)
|
|
|
|
-> BOOL;
|
|
|
|
pub fn GetEnvironmentVariableW(n: LPCWSTR, v: LPWSTR, nsize: DWORD) -> DWORD;
|
|
|
|
pub fn SetEnvironmentVariableW(n: LPCWSTR, v: LPCWSTR) -> BOOL;
|
|
|
|
pub fn GetEnvironmentStringsW() -> LPWCH;
|
|
|
|
pub fn FreeEnvironmentStringsW(env_ptr: LPWCH) -> BOOL;
|
|
|
|
pub fn GetModuleFileNameW(hModule: HMODULE,
|
|
|
|
lpFilename: LPWSTR,
|
|
|
|
nSize: DWORD)
|
|
|
|
-> DWORD;
|
|
|
|
pub fn CreateDirectoryW(lpPathName: LPCWSTR,
|
|
|
|
lpSecurityAttributes: LPSECURITY_ATTRIBUTES)
|
|
|
|
-> BOOL;
|
|
|
|
pub fn DeleteFileW(lpPathName: LPCWSTR) -> BOOL;
|
|
|
|
pub fn GetCurrentDirectoryW(nBufferLength: DWORD, lpBuffer: LPWSTR) -> DWORD;
|
|
|
|
pub fn SetCurrentDirectoryW(lpPathName: LPCWSTR) -> BOOL;
|
|
|
|
|
|
|
|
pub fn closesocket(socket: SOCKET) -> c_int;
|
|
|
|
pub fn recv(socket: SOCKET, buf: *mut c_void, len: c_int,
|
|
|
|
flags: c_int) -> c_int;
|
|
|
|
pub fn send(socket: SOCKET, buf: *const c_void, len: c_int,
|
|
|
|
flags: c_int) -> c_int;
|
|
|
|
pub fn recvfrom(socket: SOCKET,
|
|
|
|
buf: *mut c_void,
|
|
|
|
len: c_int,
|
|
|
|
flags: c_int,
|
|
|
|
addr: *mut SOCKADDR,
|
|
|
|
addrlen: *mut c_int)
|
|
|
|
-> c_int;
|
|
|
|
pub fn sendto(socket: SOCKET,
|
|
|
|
buf: *const c_void,
|
|
|
|
len: c_int,
|
|
|
|
flags: c_int,
|
|
|
|
addr: *const SOCKADDR,
|
|
|
|
addrlen: c_int)
|
|
|
|
-> c_int;
|
|
|
|
pub fn shutdown(socket: SOCKET, how: c_int) -> c_int;
|
|
|
|
pub fn accept(socket: SOCKET,
|
|
|
|
address: *mut SOCKADDR,
|
|
|
|
address_len: *mut c_int)
|
|
|
|
-> SOCKET;
|
|
|
|
pub fn DuplicateHandle(hSourceProcessHandle: HANDLE,
|
|
|
|
hSourceHandle: HANDLE,
|
|
|
|
hTargetProcessHandle: HANDLE,
|
|
|
|
lpTargetHandle: LPHANDLE,
|
|
|
|
dwDesiredAccess: DWORD,
|
|
|
|
bInheritHandle: BOOL,
|
|
|
|
dwOptions: DWORD)
|
|
|
|
-> BOOL;
|
|
|
|
pub fn ReadFile(hFile: HANDLE,
|
|
|
|
lpBuffer: LPVOID,
|
|
|
|
nNumberOfBytesToRead: DWORD,
|
|
|
|
lpNumberOfBytesRead: LPDWORD,
|
|
|
|
lpOverlapped: LPOVERLAPPED)
|
|
|
|
-> BOOL;
|
|
|
|
pub fn WriteFile(hFile: HANDLE,
|
|
|
|
lpBuffer: LPVOID,
|
|
|
|
nNumberOfBytesToWrite: DWORD,
|
|
|
|
lpNumberOfBytesWritten: LPDWORD,
|
|
|
|
lpOverlapped: LPOVERLAPPED)
|
|
|
|
-> BOOL;
|
|
|
|
pub fn CloseHandle(hObject: HANDLE) -> BOOL;
|
|
|
|
pub fn CreateHardLinkW(lpSymlinkFileName: LPCWSTR,
|
|
|
|
lpTargetFileName: LPCWSTR,
|
|
|
|
lpSecurityAttributes: LPSECURITY_ATTRIBUTES)
|
|
|
|
-> BOOL;
|
|
|
|
pub fn MoveFileExW(lpExistingFileName: LPCWSTR,
|
|
|
|
lpNewFileName: LPCWSTR,
|
|
|
|
dwFlags: DWORD)
|
|
|
|
-> BOOL;
|
|
|
|
pub fn SetFilePointerEx(hFile: HANDLE,
|
|
|
|
liDistanceToMove: LARGE_INTEGER,
|
|
|
|
lpNewFilePointer: PLARGE_INTEGER,
|
|
|
|
dwMoveMethod: DWORD)
|
|
|
|
-> BOOL;
|
|
|
|
pub fn FlushFileBuffers(hFile: HANDLE) -> BOOL;
|
|
|
|
pub fn CreateFileW(lpFileName: LPCWSTR,
|
|
|
|
dwDesiredAccess: DWORD,
|
|
|
|
dwShareMode: DWORD,
|
|
|
|
lpSecurityAttributes: LPSECURITY_ATTRIBUTES,
|
|
|
|
dwCreationDisposition: DWORD,
|
|
|
|
dwFlagsAndAttributes: DWORD,
|
|
|
|
hTemplateFile: HANDLE)
|
|
|
|
-> HANDLE;
|
|
|
|
|
|
|
|
pub fn FindFirstFileW(fileName: LPCWSTR,
|
|
|
|
findFileData: LPWIN32_FIND_DATAW)
|
|
|
|
-> HANDLE;
|
|
|
|
pub fn FindNextFileW(findFile: HANDLE, findFileData: LPWIN32_FIND_DATAW)
|
|
|
|
-> BOOL;
|
|
|
|
pub fn FindClose(findFile: HANDLE) -> BOOL;
|
|
|
|
pub fn RtlCaptureContext(ctx: *mut CONTEXT);
|
|
|
|
pub fn getsockopt(s: SOCKET,
|
|
|
|
level: c_int,
|
|
|
|
optname: c_int,
|
|
|
|
optval: *mut c_char,
|
|
|
|
optlen: *mut c_int)
|
|
|
|
-> c_int;
|
|
|
|
pub fn setsockopt(s: SOCKET,
|
|
|
|
level: c_int,
|
|
|
|
optname: c_int,
|
|
|
|
optval: *const c_void,
|
|
|
|
optlen: c_int)
|
|
|
|
-> c_int;
|
|
|
|
pub fn getsockname(socket: SOCKET,
|
|
|
|
address: *mut SOCKADDR,
|
|
|
|
address_len: *mut c_int)
|
|
|
|
-> c_int;
|
|
|
|
pub fn getpeername(socket: SOCKET,
|
|
|
|
address: *mut SOCKADDR,
|
|
|
|
address_len: *mut c_int)
|
|
|
|
-> c_int;
|
|
|
|
pub fn bind(socket: SOCKET, address: *const SOCKADDR,
|
|
|
|
address_len: socklen_t) -> c_int;
|
|
|
|
pub fn listen(socket: SOCKET, backlog: c_int) -> c_int;
|
|
|
|
pub fn connect(socket: SOCKET, address: *const SOCKADDR, len: c_int)
|
|
|
|
-> c_int;
|
|
|
|
pub fn getaddrinfo(node: *const c_char, service: *const c_char,
|
|
|
|
hints: *const ADDRINFOA,
|
|
|
|
res: *mut *mut ADDRINFOA) -> c_int;
|
|
|
|
pub fn freeaddrinfo(res: *mut ADDRINFOA);
|
|
|
|
pub fn getnameinfo(sa: *const SOCKADDR, salen: c_int,
|
|
|
|
host: *mut c_char, hostlen: DWORD,
|
|
|
|
serv: *mut c_char, servlen: DWORD,
|
|
|
|
flags: c_int) -> c_int;
|
|
|
|
|
|
|
|
pub fn LoadLibraryW(name: LPCWSTR) -> HMODULE;
|
|
|
|
pub fn GetModuleHandleExW(dwFlags: DWORD, name: LPCWSTR,
|
|
|
|
handle: *mut HMODULE) -> BOOL;
|
|
|
|
pub fn GetProcAddress(handle: HMODULE,
|
|
|
|
name: LPCSTR) -> *mut c_void;
|
|
|
|
pub fn FreeLibrary(handle: HMODULE) -> BOOL;
|
|
|
|
pub fn SetErrorMode(uMode: c_uint) -> c_uint;
|
|
|
|
pub fn GetModuleHandleW(lpModuleName: LPCWSTR) -> HMODULE;
|
|
|
|
pub fn CryptAcquireContextA(phProv: *mut HCRYPTPROV,
|
|
|
|
pszContainer: LPCSTR,
|
|
|
|
pszProvider: LPCSTR,
|
|
|
|
dwProvType: DWORD,
|
|
|
|
dwFlags: DWORD) -> BOOL;
|
|
|
|
pub fn CryptGenRandom(hProv: HCRYPTPROV,
|
|
|
|
dwLen: DWORD,
|
|
|
|
pbBuffer: *mut BYTE) -> BOOL;
|
|
|
|
pub fn CryptReleaseContext(hProv: HCRYPTPROV, dwFlags: DWORD) -> BOOL;
|
|
|
|
|
|
|
|
#[unwind]
|
|
|
|
pub fn RaiseException(dwExceptionCode: DWORD,
|
|
|
|
dwExceptionFlags: DWORD,
|
|
|
|
nNumberOfArguments: DWORD,
|
|
|
|
lpArguments: *const ULONG_PTR);
|
|
|
|
pub fn RtlUnwindEx(TargetFrame: LPVOID,
|
|
|
|
TargetIp: LPVOID,
|
|
|
|
ExceptionRecord: *const EXCEPTION_RECORD,
|
|
|
|
ReturnValue: LPVOID,
|
|
|
|
OriginalContext: *const CONTEXT,
|
|
|
|
HistoryTable: *const UNWIND_HISTORY_TABLE);
|
2014-07-04 14:45:28 +00:00
|
|
|
}
|
2015-06-26 16:30:35 +00:00
|
|
|
|
|
|
|
// Functions that aren't available on Windows XP, but we still use them and just
|
|
|
|
// provide some form of a fallback implementation.
|
|
|
|
compat_fn! {
|
|
|
|
kernel32:
|
|
|
|
|
|
|
|
pub fn CreateSymbolicLinkW(_lpSymlinkFileName: LPCWSTR,
|
|
|
|
_lpTargetFileName: LPCWSTR,
|
|
|
|
_dwFlags: DWORD) -> BOOLEAN {
|
|
|
|
SetLastError(ERROR_CALL_NOT_IMPLEMENTED as DWORD); 0
|
|
|
|
}
|
|
|
|
pub fn GetFinalPathNameByHandleW(_hFile: HANDLE,
|
|
|
|
_lpszFilePath: LPCWSTR,
|
|
|
|
_cchFilePath: DWORD,
|
|
|
|
_dwFlags: DWORD) -> DWORD {
|
|
|
|
SetLastError(ERROR_CALL_NOT_IMPLEMENTED as DWORD); 0
|
|
|
|
}
|
|
|
|
pub fn SetThreadErrorMode(_dwNewMode: DWORD,
|
|
|
|
_lpOldMode: *mut DWORD) -> c_uint {
|
|
|
|
SetLastError(ERROR_CALL_NOT_IMPLEMENTED as DWORD); 0
|
|
|
|
}
|
|
|
|
pub fn SetThreadStackGuarantee(_size: *mut c_ulong) -> BOOL {
|
|
|
|
SetLastError(ERROR_CALL_NOT_IMPLEMENTED as DWORD); 0
|
|
|
|
}
|
|
|
|
pub fn SetFileInformationByHandle(_hFile: HANDLE,
|
|
|
|
_FileInformationClass: FILE_INFO_BY_HANDLE_CLASS,
|
|
|
|
_lpFileInformation: LPVOID,
|
|
|
|
_dwBufferSize: DWORD) -> BOOL {
|
|
|
|
SetLastError(ERROR_CALL_NOT_IMPLEMENTED as DWORD); 0
|
|
|
|
}
|
|
|
|
pub fn SleepConditionVariableSRW(ConditionVariable: PCONDITION_VARIABLE,
|
|
|
|
SRWLock: PSRWLOCK,
|
|
|
|
dwMilliseconds: DWORD,
|
|
|
|
Flags: ULONG) -> BOOL {
|
|
|
|
panic!("condition variables not available")
|
|
|
|
}
|
|
|
|
pub fn WakeConditionVariable(ConditionVariable: PCONDITION_VARIABLE)
|
|
|
|
-> () {
|
|
|
|
panic!("condition variables not available")
|
|
|
|
}
|
|
|
|
pub fn WakeAllConditionVariable(ConditionVariable: PCONDITION_VARIABLE)
|
|
|
|
-> () {
|
|
|
|
panic!("condition variables not available")
|
|
|
|
}
|
|
|
|
pub fn AcquireSRWLockExclusive(SRWLock: PSRWLOCK) -> () {
|
|
|
|
panic!("rwlocks not available")
|
|
|
|
}
|
|
|
|
pub fn AcquireSRWLockShared(SRWLock: PSRWLOCK) -> () {
|
|
|
|
panic!("rwlocks not available")
|
|
|
|
}
|
|
|
|
pub fn ReleaseSRWLockExclusive(SRWLock: PSRWLOCK) -> () {
|
|
|
|
panic!("rwlocks not available")
|
|
|
|
}
|
|
|
|
pub fn ReleaseSRWLockShared(SRWLock: PSRWLOCK) -> () {
|
|
|
|
panic!("rwlocks not available")
|
|
|
|
}
|
|
|
|
pub fn TryAcquireSRWLockExclusive(SRWLock: PSRWLOCK) -> BOOLEAN {
|
|
|
|
panic!("rwlocks not available")
|
|
|
|
}
|
|
|
|
pub fn TryAcquireSRWLockShared(SRWLock: PSRWLOCK) -> BOOLEAN {
|
|
|
|
panic!("rwlocks not available")
|
|
|
|
}
|
|
|
|
}
|