ホーム › System.Hypervisor › ForceActiveVirtualTrustLevel
ForceActiveVirtualTrustLevel
関数仮想プロセッサのアクティブな仮想トラストレベルを強制設定する。
シグネチャ
// VmSavedStateDumpProvider.dll
#include <windows.h>
HRESULT ForceActiveVirtualTrustLevel(
void* vmSavedStateDumpHandle,
DWORD vpId,
BYTE virtualTrustLevel
);パラメーター
| 名前 | 型 | 方向 |
|---|---|---|
| vmSavedStateDumpHandle | void* | inout |
| vpId | DWORD | in |
| virtualTrustLevel | BYTE | in |
戻り値の型: HRESULT
各言語での呼び出し定義
// VmSavedStateDumpProvider.dll
#include <windows.h>
HRESULT ForceActiveVirtualTrustLevel(
void* vmSavedStateDumpHandle,
DWORD vpId,
BYTE virtualTrustLevel
);[DllImport("VmSavedStateDumpProvider.dll", ExactSpelling = true)]
static extern int ForceActiveVirtualTrustLevel(
IntPtr vmSavedStateDumpHandle, // void* in/out
uint vpId, // DWORD
byte virtualTrustLevel // BYTE
);<DllImport("VmSavedStateDumpProvider.dll", ExactSpelling:=True)>
Public Shared Function ForceActiveVirtualTrustLevel(
vmSavedStateDumpHandle As IntPtr, ' void* in/out
vpId As UInteger, ' DWORD
virtualTrustLevel As Byte ' BYTE
) As Integer
End Function' vmSavedStateDumpHandle : void* in/out
' vpId : DWORD
' virtualTrustLevel : BYTE
Declare PtrSafe Function ForceActiveVirtualTrustLevel Lib "vmsavedstatedumpprovider" ( _
ByVal vmSavedStateDumpHandle As LongPtr, _
ByVal vpId As Long, _
ByVal virtualTrustLevel As Byte) As Long
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。import ctypes
from ctypes import wintypes
ForceActiveVirtualTrustLevel = ctypes.windll.vmsavedstatedumpprovider.ForceActiveVirtualTrustLevel
ForceActiveVirtualTrustLevel.restype = ctypes.c_int
ForceActiveVirtualTrustLevel.argtypes = [
ctypes.POINTER(None), # vmSavedStateDumpHandle : void* in/out
wintypes.DWORD, # vpId : DWORD
ctypes.c_ubyte, # virtualTrustLevel : BYTE
]require 'fiddle'
require 'fiddle/import'
lib = Fiddle.dlopen('VmSavedStateDumpProvider.dll')
ForceActiveVirtualTrustLevel = Fiddle::Function.new(
lib['ForceActiveVirtualTrustLevel'],
[
Fiddle::TYPE_VOIDP, # vmSavedStateDumpHandle : void* in/out
-Fiddle::TYPE_INT, # vpId : DWORD
-Fiddle::TYPE_CHAR, # virtualTrustLevel : BYTE
],
Fiddle::TYPE_INT)#[link(name = "vmsavedstatedumpprovider")]
extern "system" {
fn ForceActiveVirtualTrustLevel(
vmSavedStateDumpHandle: *mut (), // void* in/out
vpId: u32, // DWORD
virtualTrustLevel: u8 // BYTE
) -> i32;
}
// crates: windows-sys provides ready-made bindings for this API.$sig = @"
[DllImport("VmSavedStateDumpProvider.dll")]
public static extern int ForceActiveVirtualTrustLevel(IntPtr vmSavedStateDumpHandle, uint vpId, byte virtualTrustLevel);
"@
$api = Add-Type -MemberDefinition $sig -Name 'VmSavedStateDumpProvider_ForceActiveVirtualTrustLevel' -Namespace Win32 -PassThru
# $api::ForceActiveVirtualTrustLevel(vmSavedStateDumpHandle, vpId, virtualTrustLevel)#uselib "VmSavedStateDumpProvider.dll"
#func global ForceActiveVirtualTrustLevel "ForceActiveVirtualTrustLevel" sptr, sptr, sptr
; ForceActiveVirtualTrustLevel vmSavedStateDumpHandle, vpId, virtualTrustLevel ; 戻り値は stat
; vmSavedStateDumpHandle : void* in/out -> "sptr"
; vpId : DWORD -> "sptr"
; virtualTrustLevel : BYTE -> "sptr"
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。#uselib "VmSavedStateDumpProvider.dll"
#cfunc global ForceActiveVirtualTrustLevel "ForceActiveVirtualTrustLevel" sptr, int, int
; res = ForceActiveVirtualTrustLevel(vmSavedStateDumpHandle, vpId, virtualTrustLevel)
; vmSavedStateDumpHandle : void* in/out -> "sptr"
; vpId : DWORD -> "int"
; virtualTrustLevel : BYTE -> "int"; HRESULT ForceActiveVirtualTrustLevel(void* vmSavedStateDumpHandle, DWORD vpId, BYTE virtualTrustLevel)
#uselib "VmSavedStateDumpProvider.dll"
#cfunc global ForceActiveVirtualTrustLevel "ForceActiveVirtualTrustLevel" intptr, int, int
; res = ForceActiveVirtualTrustLevel(vmSavedStateDumpHandle, vpId, virtualTrustLevel)
; vmSavedStateDumpHandle : void* in/out -> "intptr"
; vpId : DWORD -> "int"
; virtualTrustLevel : BYTE -> "int"import (
"golang.org/x/sys/windows"
"unsafe"
)
var (
vmsavedstatedumpprovider = windows.NewLazySystemDLL("VmSavedStateDumpProvider.dll")
procForceActiveVirtualTrustLevel = vmsavedstatedumpprovider.NewProc("ForceActiveVirtualTrustLevel")
)
// vmSavedStateDumpHandle (void* in/out), vpId (DWORD), virtualTrustLevel (BYTE)
r1, _, err := procForceActiveVirtualTrustLevel.Call(
uintptr(vmSavedStateDumpHandle),
uintptr(vpId),
uintptr(virtualTrustLevel),
)
_ = err // syscall.Errno (valid when the call sets last-error)
_ = r1 // HRESULTfunction ForceActiveVirtualTrustLevel(
vmSavedStateDumpHandle: Pointer; // void* in/out
vpId: DWORD; // DWORD
virtualTrustLevel: Byte // BYTE
): Integer; stdcall;
external 'VmSavedStateDumpProvider.dll' name 'ForceActiveVirtualTrustLevel';result := DllCall("VmSavedStateDumpProvider\ForceActiveVirtualTrustLevel"
, "Ptr", vmSavedStateDumpHandle ; void* in/out
, "UInt", vpId ; DWORD
, "UChar", virtualTrustLevel ; BYTE
, "Int") ; return: HRESULT●ForceActiveVirtualTrustLevel(vmSavedStateDumpHandle, vpId, virtualTrustLevel) = DLL("VmSavedStateDumpProvider.dll", "int ForceActiveVirtualTrustLevel(void*, dword, byte)")
# 呼び出し: ForceActiveVirtualTrustLevel(vmSavedStateDumpHandle, vpId, virtualTrustLevel)
# vmSavedStateDumpHandle : void* in/out -> "void*"
# vpId : DWORD -> "dword"
# virtualTrustLevel : BYTE -> "byte"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。