| #![allow(non_snake_case, non_camel_case_types, non_upper_case_globals, clashing_extern_declarations, clippy::all)] |
| #[link(name = "windows")] |
| extern "system" { |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn CallEnclave(lproutine: isize, lpparameter: *const ::core::ffi::c_void, fwaitforthread: super::super::Foundation::BOOL, lpreturnvalue: *mut *mut ::core::ffi::c_void) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn CreateEnclave(hprocess: super::super::Foundation::HANDLE, lpaddress: *const ::core::ffi::c_void, dwsize: usize, dwinitialcommitment: usize, flenclavetype: u32, lpenclaveinformation: *const ::core::ffi::c_void, dwinfolength: u32, lpenclaveerror: *mut u32) -> *mut ::core::ffi::c_void; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn CreateEnvironmentBlock(lpenvironment: *mut *mut ::core::ffi::c_void, htoken: super::super::Foundation::HANDLE, binherit: super::super::Foundation::BOOL) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn DeleteEnclave(lpaddress: *const ::core::ffi::c_void) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn DestroyEnvironmentBlock(lpenvironment: *const ::core::ffi::c_void) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub fn EnclaveGetAttestationReport(enclavedata: *const u8, report: *mut ::core::ffi::c_void, buffersize: u32, outputsize: *mut u32) -> ::windows_sys::core::HRESULT; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub fn EnclaveGetEnclaveInformation(informationsize: u32, enclaveinformation: *mut ENCLAVE_INFORMATION) -> ::windows_sys::core::HRESULT; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub fn EnclaveSealData(datatoencrypt: *const ::core::ffi::c_void, datatoencryptsize: u32, identitypolicy: ENCLAVE_SEALING_IDENTITY_POLICY, runtimepolicy: u32, protectedblob: *mut ::core::ffi::c_void, buffersize: u32, protectedblobsize: *mut u32) -> ::windows_sys::core::HRESULT; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub fn EnclaveUnsealData(protectedblob: *const ::core::ffi::c_void, protectedblobsize: u32, decrypteddata: *mut ::core::ffi::c_void, buffersize: u32, decrypteddatasize: *mut u32, sealingidentity: *mut ENCLAVE_IDENTITY, unsealingflags: *mut u32) -> ::windows_sys::core::HRESULT; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub fn EnclaveVerifyAttestationReport(enclavetype: u32, report: *const ::core::ffi::c_void, reportsize: u32) -> ::windows_sys::core::HRESULT; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub fn ExpandEnvironmentStringsA(lpsrc: ::windows_sys::core::PCSTR, lpdst: ::windows_sys::core::PSTR, nsize: u32) -> u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn ExpandEnvironmentStringsForUserA(htoken: super::super::Foundation::HANDLE, lpsrc: ::windows_sys::core::PCSTR, lpdest: ::windows_sys::core::PSTR, dwsize: u32) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn ExpandEnvironmentStringsForUserW(htoken: super::super::Foundation::HANDLE, lpsrc: ::windows_sys::core::PCWSTR, lpdest: ::windows_sys::core::PWSTR, dwsize: u32) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub fn ExpandEnvironmentStringsW(lpsrc: ::windows_sys::core::PCWSTR, lpdst: ::windows_sys::core::PWSTR, nsize: u32) -> u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn FreeEnvironmentStringsA(penv: ::windows_sys::core::PCSTR) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn FreeEnvironmentStringsW(penv: ::windows_sys::core::PCWSTR) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub fn GetCommandLineA() -> ::windows_sys::core::PSTR; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub fn GetCommandLineW() -> ::windows_sys::core::PWSTR; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub fn GetCurrentDirectoryA(nbufferlength: u32, lpbuffer: ::windows_sys::core::PSTR) -> u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub fn GetCurrentDirectoryW(nbufferlength: u32, lpbuffer: ::windows_sys::core::PWSTR) -> u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub fn GetEnvironmentStrings() -> ::windows_sys::core::PSTR; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub fn GetEnvironmentStringsW() -> ::windows_sys::core::PWSTR; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub fn GetEnvironmentVariableA(lpname: ::windows_sys::core::PCSTR, lpbuffer: ::windows_sys::core::PSTR, nsize: u32) -> u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub fn GetEnvironmentVariableW(lpname: ::windows_sys::core::PCWSTR, lpbuffer: ::windows_sys::core::PWSTR, nsize: u32) -> u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn InitializeEnclave(hprocess: super::super::Foundation::HANDLE, lpaddress: *const ::core::ffi::c_void, lpenclaveinformation: *const ::core::ffi::c_void, dwinfolength: u32, lpenclaveerror: *mut u32) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn IsEnclaveTypeSupported(flenclavetype: u32) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn LoadEnclaveData(hprocess: super::super::Foundation::HANDLE, lpaddress: *const ::core::ffi::c_void, lpbuffer: *const ::core::ffi::c_void, nsize: usize, flprotect: u32, lppageinformation: *const ::core::ffi::c_void, dwinfolength: u32, lpnumberofbyteswritten: *mut usize, lpenclaveerror: *mut u32) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn LoadEnclaveImageA(lpenclaveaddress: *const ::core::ffi::c_void, lpimagename: ::windows_sys::core::PCSTR) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn LoadEnclaveImageW(lpenclaveaddress: *const ::core::ffi::c_void, lpimagename: ::windows_sys::core::PCWSTR) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn NeedCurrentDirectoryForExePathA(exename: ::windows_sys::core::PCSTR) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn NeedCurrentDirectoryForExePathW(exename: ::windows_sys::core::PCWSTR) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn SetCurrentDirectoryA(lppathname: ::windows_sys::core::PCSTR) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn SetCurrentDirectoryW(lppathname: ::windows_sys::core::PCWSTR) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn SetEnvironmentStringsW(newenvironment: ::windows_sys::core::PCWSTR) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn SetEnvironmentVariableA(lpname: ::windows_sys::core::PCSTR, lpvalue: ::windows_sys::core::PCSTR) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn SetEnvironmentVariableW(lpname: ::windows_sys::core::PCWSTR, lpvalue: ::windows_sys::core::PCWSTR) -> super::super::Foundation::BOOL; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`, `\"Win32_Foundation\"`*"] |
| #[cfg(feature = "Win32_Foundation")] |
| pub fn TerminateEnclave(lpaddress: *const ::core::ffi::c_void, fwait: super::super::Foundation::BOOL) -> super::super::Foundation::BOOL; |
| } |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_FLAG_DYNAMIC_DEBUG_ACTIVE: u32 = 4u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_FLAG_DYNAMIC_DEBUG_ENABLED: u32 = 2u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_FLAG_FULL_DEBUG_ENABLED: u32 = 1u32; |
| #[repr(C, packed(1))] |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub struct ENCLAVE_IDENTITY { |
| pub OwnerId: [u8; 32], |
| pub UniqueId: [u8; 32], |
| pub AuthorId: [u8; 32], |
| pub FamilyId: [u8; 16], |
| pub ImageId: [u8; 16], |
| pub EnclaveSvn: u32, |
| pub SecureKernelSvn: u32, |
| pub PlatformSvn: u32, |
| pub Flags: u32, |
| pub SigningLevel: u32, |
| pub EnclaveType: u32, |
| } |
| impl ::core::marker::Copy for ENCLAVE_IDENTITY {} |
| impl ::core::clone::Clone for ENCLAVE_IDENTITY { |
| fn clone(&self) -> Self { |
| *self |
| } |
| } |
| #[repr(C)] |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub struct ENCLAVE_INFORMATION { |
| pub EnclaveType: u32, |
| pub Reserved: u32, |
| pub BaseAddress: *mut ::core::ffi::c_void, |
| pub Size: usize, |
| pub Identity: ENCLAVE_IDENTITY, |
| } |
| impl ::core::marker::Copy for ENCLAVE_INFORMATION {} |
| impl ::core::clone::Clone for ENCLAVE_INFORMATION { |
| fn clone(&self) -> Self { |
| *self |
| } |
| } |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_REPORT_DATA_LENGTH: u32 = 64u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_RUNTIME_POLICY_ALLOW_DYNAMIC_DEBUG: u32 = 2u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_RUNTIME_POLICY_ALLOW_FULL_DEBUG: u32 = 1u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub type ENCLAVE_SEALING_IDENTITY_POLICY = i32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_IDENTITY_POLICY_SEAL_INVALID: ENCLAVE_SEALING_IDENTITY_POLICY = 0i32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_IDENTITY_POLICY_SEAL_EXACT_CODE: ENCLAVE_SEALING_IDENTITY_POLICY = 1i32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_IDENTITY_POLICY_SEAL_SAME_PRIMARY_CODE: ENCLAVE_SEALING_IDENTITY_POLICY = 2i32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_IDENTITY_POLICY_SEAL_SAME_IMAGE: ENCLAVE_SEALING_IDENTITY_POLICY = 3i32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_IDENTITY_POLICY_SEAL_SAME_FAMILY: ENCLAVE_SEALING_IDENTITY_POLICY = 4i32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_IDENTITY_POLICY_SEAL_SAME_AUTHOR: ENCLAVE_SEALING_IDENTITY_POLICY = 5i32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_UNSEAL_FLAG_STALE_KEY: u32 = 1u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_VBS_BASIC_KEY_FLAG_DEBUG_KEY: u32 = 8u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_VBS_BASIC_KEY_FLAG_FAMILY_ID: u32 = 2u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_VBS_BASIC_KEY_FLAG_IMAGE_ID: u32 = 4u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const ENCLAVE_VBS_BASIC_KEY_FLAG_MEASUREMENT: u32 = 1u32; |
| #[repr(C)] |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub struct ENCLAVE_VBS_BASIC_KEY_REQUEST { |
| pub RequestSize: u32, |
| pub Flags: u32, |
| pub EnclaveSVN: u32, |
| pub SystemKeyID: u32, |
| pub CurrentSystemKeyID: u32, |
| } |
| impl ::core::marker::Copy for ENCLAVE_VBS_BASIC_KEY_REQUEST {} |
| impl ::core::clone::Clone for ENCLAVE_VBS_BASIC_KEY_REQUEST { |
| fn clone(&self) -> Self { |
| *self |
| } |
| } |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_COMMIT_PAGES = ::core::option::Option<unsafe extern "system" fn(enclaveaddress: *const ::core::ffi::c_void, numberofbytes: usize, sourceaddress: *const ::core::ffi::c_void, pageprotection: u32) -> i32>; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_CREATE_THREAD = ::core::option::Option<unsafe extern "system" fn(threaddescriptor: *const VBS_BASIC_ENCLAVE_THREAD_DESCRIPTOR64) -> i32>; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| #[cfg(target_arch = "x86")] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_CREATE_THREAD = ::core::option::Option<unsafe extern "system" fn(threaddescriptor: *const VBS_BASIC_ENCLAVE_THREAD_DESCRIPTOR32) -> i32>; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_DECOMMIT_PAGES = ::core::option::Option<unsafe extern "system" fn(enclaveaddress: *const ::core::ffi::c_void, numberofbytes: usize) -> i32>; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_GENERATE_KEY = ::core::option::Option<unsafe extern "system" fn(keyrequest: *mut ENCLAVE_VBS_BASIC_KEY_REQUEST, requestedkeysize: u32, returnedkey: *mut u8) -> i32>; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_GENERATE_RANDOM_DATA = ::core::option::Option<unsafe extern "system" fn(buffer: *mut u8, numberofbytes: u32, generation: *mut u64) -> i32>; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_GENERATE_REPORT = ::core::option::Option<unsafe extern "system" fn(enclavedata: *const u8, report: *mut ::core::ffi::c_void, buffersize: u32, outputsize: *mut u32) -> i32>; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_GET_ENCLAVE_INFORMATION = ::core::option::Option<unsafe extern "system" fn(enclaveinfo: *mut ENCLAVE_INFORMATION) -> i32>; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_INTERRUPT_THREAD = ::core::option::Option<unsafe extern "system" fn(threaddescriptor: *const VBS_BASIC_ENCLAVE_THREAD_DESCRIPTOR64) -> i32>; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| #[cfg(target_arch = "x86")] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_INTERRUPT_THREAD = ::core::option::Option<unsafe extern "system" fn(threaddescriptor: *const VBS_BASIC_ENCLAVE_THREAD_DESCRIPTOR32) -> i32>; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_PROTECT_PAGES = ::core::option::Option<unsafe extern "system" fn(enclaveaddress: *const ::core::ffi::c_void, numberofytes: usize, pageprotection: u32) -> i32>; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_RETURN_FROM_ENCLAVE = ::core::option::Option<unsafe extern "system" fn(returnvalue: usize)>; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| #[cfg(target_arch = "x86_64")] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_RETURN_FROM_EXCEPTION = ::core::option::Option<unsafe extern "system" fn(exceptionrecord: *const VBS_BASIC_ENCLAVE_EXCEPTION_AMD64) -> i32>; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| #[cfg(any(target_arch = "aarch64", target_arch = "x86"))] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_RETURN_FROM_EXCEPTION = ::core::option::Option<unsafe extern "system" fn(exceptionrecord: *const ::core::ffi::c_void) -> i32>; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_TERMINATE_THREAD = ::core::option::Option<unsafe extern "system" fn(threaddescriptor: *const VBS_BASIC_ENCLAVE_THREAD_DESCRIPTOR64) -> i32>; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| #[cfg(target_arch = "x86")] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_TERMINATE_THREAD = ::core::option::Option<unsafe extern "system" fn(threaddescriptor: *const VBS_BASIC_ENCLAVE_THREAD_DESCRIPTOR32) -> i32>; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub type VBS_BASIC_ENCLAVE_BASIC_CALL_VERIFY_REPORT = ::core::option::Option<unsafe extern "system" fn(report: *const ::core::ffi::c_void, reportsize: u32) -> i32>; |
| #[repr(C)] |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub struct VBS_BASIC_ENCLAVE_EXCEPTION_AMD64 { |
| pub ExceptionCode: u32, |
| pub NumberParameters: u32, |
| pub ExceptionInformation: [usize; 3], |
| pub ExceptionRAX: usize, |
| pub ExceptionRCX: usize, |
| pub ExceptionRIP: usize, |
| pub ExceptionRFLAGS: usize, |
| pub ExceptionRSP: usize, |
| } |
| impl ::core::marker::Copy for VBS_BASIC_ENCLAVE_EXCEPTION_AMD64 {} |
| impl ::core::clone::Clone for VBS_BASIC_ENCLAVE_EXCEPTION_AMD64 { |
| fn clone(&self) -> Self { |
| *self |
| } |
| } |
| #[repr(C)] |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub struct VBS_BASIC_ENCLAVE_SYSCALL_PAGE { |
| pub ReturnFromEnclave: VBS_BASIC_ENCLAVE_BASIC_CALL_RETURN_FROM_ENCLAVE, |
| pub ReturnFromException: VBS_BASIC_ENCLAVE_BASIC_CALL_RETURN_FROM_EXCEPTION, |
| pub TerminateThread: VBS_BASIC_ENCLAVE_BASIC_CALL_TERMINATE_THREAD, |
| pub InterruptThread: VBS_BASIC_ENCLAVE_BASIC_CALL_INTERRUPT_THREAD, |
| pub CommitPages: VBS_BASIC_ENCLAVE_BASIC_CALL_COMMIT_PAGES, |
| pub DecommitPages: VBS_BASIC_ENCLAVE_BASIC_CALL_DECOMMIT_PAGES, |
| pub ProtectPages: VBS_BASIC_ENCLAVE_BASIC_CALL_PROTECT_PAGES, |
| pub CreateThread: VBS_BASIC_ENCLAVE_BASIC_CALL_CREATE_THREAD, |
| pub GetEnclaveInformation: VBS_BASIC_ENCLAVE_BASIC_CALL_GET_ENCLAVE_INFORMATION, |
| pub GenerateKey: VBS_BASIC_ENCLAVE_BASIC_CALL_GENERATE_KEY, |
| pub GenerateReport: VBS_BASIC_ENCLAVE_BASIC_CALL_GENERATE_REPORT, |
| pub VerifyReport: VBS_BASIC_ENCLAVE_BASIC_CALL_VERIFY_REPORT, |
| pub GenerateRandomData: VBS_BASIC_ENCLAVE_BASIC_CALL_GENERATE_RANDOM_DATA, |
| } |
| impl ::core::marker::Copy for VBS_BASIC_ENCLAVE_SYSCALL_PAGE {} |
| impl ::core::clone::Clone for VBS_BASIC_ENCLAVE_SYSCALL_PAGE { |
| fn clone(&self) -> Self { |
| *self |
| } |
| } |
| #[repr(C)] |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub struct VBS_BASIC_ENCLAVE_THREAD_DESCRIPTOR32 { |
| pub ThreadContext: [u32; 4], |
| pub EntryPoint: u32, |
| pub StackPointer: u32, |
| pub ExceptionEntryPoint: u32, |
| pub ExceptionStack: u32, |
| pub ExceptionActive: u32, |
| } |
| impl ::core::marker::Copy for VBS_BASIC_ENCLAVE_THREAD_DESCRIPTOR32 {} |
| impl ::core::clone::Clone for VBS_BASIC_ENCLAVE_THREAD_DESCRIPTOR32 { |
| fn clone(&self) -> Self { |
| *self |
| } |
| } |
| #[repr(C)] |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub struct VBS_BASIC_ENCLAVE_THREAD_DESCRIPTOR64 { |
| pub ThreadContext: [u64; 4], |
| pub EntryPoint: u64, |
| pub StackPointer: u64, |
| pub ExceptionEntryPoint: u64, |
| pub ExceptionStack: u64, |
| pub ExceptionActive: u32, |
| } |
| impl ::core::marker::Copy for VBS_BASIC_ENCLAVE_THREAD_DESCRIPTOR64 {} |
| impl ::core::clone::Clone for VBS_BASIC_ENCLAVE_THREAD_DESCRIPTOR64 { |
| fn clone(&self) -> Self { |
| *self |
| } |
| } |
| #[repr(C, packed(1))] |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub struct VBS_ENCLAVE_REPORT { |
| pub ReportSize: u32, |
| pub ReportVersion: u32, |
| pub EnclaveData: [u8; 64], |
| pub EnclaveIdentity: ENCLAVE_IDENTITY, |
| } |
| impl ::core::marker::Copy for VBS_ENCLAVE_REPORT {} |
| impl ::core::clone::Clone for VBS_ENCLAVE_REPORT { |
| fn clone(&self) -> Self { |
| *self |
| } |
| } |
| #[repr(C, packed(1))] |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub struct VBS_ENCLAVE_REPORT_MODULE { |
| pub Header: VBS_ENCLAVE_REPORT_VARDATA_HEADER, |
| pub UniqueId: [u8; 32], |
| pub AuthorId: [u8; 32], |
| pub FamilyId: [u8; 16], |
| pub ImageId: [u8; 16], |
| pub Svn: u32, |
| pub ModuleName: [u16; 1], |
| } |
| impl ::core::marker::Copy for VBS_ENCLAVE_REPORT_MODULE {} |
| impl ::core::clone::Clone for VBS_ENCLAVE_REPORT_MODULE { |
| fn clone(&self) -> Self { |
| *self |
| } |
| } |
| #[repr(C, packed(1))] |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub struct VBS_ENCLAVE_REPORT_PKG_HEADER { |
| pub PackageSize: u32, |
| pub Version: u32, |
| pub SignatureScheme: u32, |
| pub SignedStatementSize: u32, |
| pub SignatureSize: u32, |
| pub Reserved: u32, |
| } |
| impl ::core::marker::Copy for VBS_ENCLAVE_REPORT_PKG_HEADER {} |
| impl ::core::clone::Clone for VBS_ENCLAVE_REPORT_PKG_HEADER { |
| fn clone(&self) -> Self { |
| *self |
| } |
| } |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const VBS_ENCLAVE_REPORT_PKG_HEADER_VERSION_CURRENT: u32 = 1u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const VBS_ENCLAVE_REPORT_SIGNATURE_SCHEME_SHA256_RSA_PSS_SHA256: u32 = 1u32; |
| #[repr(C, packed(1))] |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub struct VBS_ENCLAVE_REPORT_VARDATA_HEADER { |
| pub DataType: u32, |
| pub Size: u32, |
| } |
| impl ::core::marker::Copy for VBS_ENCLAVE_REPORT_VARDATA_HEADER {} |
| impl ::core::clone::Clone for VBS_ENCLAVE_REPORT_VARDATA_HEADER { |
| fn clone(&self) -> Self { |
| *self |
| } |
| } |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const VBS_ENCLAVE_REPORT_VERSION_CURRENT: u32 = 1u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const VBS_ENCLAVE_VARDATA_INVALID: u32 = 0u32; |
| #[doc = "*Required features: `\"Win32_System_Environment\"`*"] |
| pub const VBS_ENCLAVE_VARDATA_MODULE: u32 = 1u32; |