WHvWriteGpaRange

Bir bölümün WHV_READ_WRITE_GPA_RANGE_MAX_SIZE konuk fiziksel adres alanına en fazla bayt yazar.

Sözdizimi

// Guest physical address
typedef UINT64 WHV_GUEST_PHYSICAL_ADDRESS;

//
// Maximum data size used by WHvReadGpaRange and WHvWriteGpaRange
//
#define WHV_READ_WRITE_GPA_RANGE_MAX_SIZE 16

typedef enum WHV_CACHE_TYPE {
    WHvCacheTypeUncached         = 0,
    WHvCacheTypeWriteCombining   = 1,
    WHvCacheTypeWriteThrough     = 4,

#if defined(_AMD64_)
    WHvCacheTypeWriteProtected   = 5,
#endif

    WHvCacheTypeWriteBack        = 6
} WHV_CACHE_TYPE;

typedef union WHV_INPUT_VTL
{
    UINT8 AsUINT8;
    struct
    {
        UINT8 TargetVtl    : 4;
        UINT8 UseTargetVtl : 1;
        UINT8 Reserved     : 3;
    };
} WHV_INPUT_VTL;

//
// Control flags used by WHvReadGpaRange and WHvWriteGpaRange
//
typedef union WHV_ACCESS_GPA_CONTROLS
{
    UINT64 AsUINT64;
    struct
    {
        //
        // Cache type for access
        //
        WHV_CACHE_TYPE CacheType;

        //
        // VTL whose GPA is to be accessed
        //
        WHV_INPUT_VTL InputVtl;
        UINT8 Reserved;
        UINT16 Reserved1;
    };
} WHV_ACCESS_GPA_CONTROLS;

HRESULT
WINAPI
WHvWriteGpaRange(
    _In_ WHV_PARTITION_HANDLE Partition,
    _In_ UINT32 VpIndex,
    _In_ WHV_GUEST_PHYSICAL_ADDRESS GuestAddress,
    _In_ WHV_ACCESS_GPA_CONTROLS Controls,
    _In_reads_bytes_(DataSizeInBytes) const VOID* Data,
    _In_ UINT32 DataSizeInBytes
    );

Parameters

Partition

Bölüm nesnesi için tanıtıcı.

VpIndex

Bağlamı erişim gerçekleştirilen sanal işlemcinin dizinini belirtir.

GuestAddress

Yazma işleminin başladığı konuk fiziksel adresini belirtir.

Controls

Erişim için önbellek türünü ve hedef VTL'yi bir WHV_ACCESS_GPA_CONTROLS değer olarak belirtir.

Data

Konuk fiziksel adres aralığına yazacak baytları belirtir.

DataSizeInBytes

Yazacak bayt sayısını belirtir. Bu değer sıfırdan büyük olmalı ve değerinden WHV_READ_WRITE_GPA_RANGE_MAX_SIZEbüyük olmamalıdır.

Dönüş Değeri

İşlev başarılı olursa, dönüş değeri olur S_OK.

işlevi aşağıdaki hata kodlarını döndürebilir:

  • E_INVALIDARGDataSizeInBytes değerinden CacheType büyüktürWHV_READ_WRITE_GPA_RANGE_MAX_SIZE, in Controls geçerli bir önbellek türü değildir, InputVtl in geçerli VTL'ye Controls başvurmaz veya içindeki Controls ayrılmış bir alan ayarlanır.
  • E_ACCESSDENIED — konuk fiziksel adres aralığı eşlenmez veya başka bir şekilde erişime izin verilmez.

Açıklamalar

İşlev, WHvWriteGpaRange bir sanal işlemci bağlamında konuk fiziksel belleğe en fazla WHV_READ_WRITE_GPA_RANGE_MAX_SIZE (16) bayt yazar. Bu sınırlı erişim boyutu, işlevi toplu bellek aktarımı yerine yönerge işlenenlerine öykünme için uygun hale getirir. Daha büyük aktarımlar için, veya WHvMapGpaRange2 tarafından WHvMapGpaRange oluşturulan bir konak eşlemesi ile konuk fiziksel belleği geri yükleyin ve doğrudan erişin.

Yazma işlemi tarafından VpIndextanımlanan sanal işlemci bağlamında gerçekleştirildiğinden, içinde belirtilen Controlsönbellek türü ve VTL dahil olmak üzere bu işlemciye uygulanan bellek erişim semantiğini gözlemler. Hedeflenen sayfa henüz yerleşik değilse işlev hataya neden olur ve erişimi yeniden denenir.

Requirements

Requirement Değer
Desteklenen en düşük Windows Windows 10, sürüm 20H2 (x64); Windows 11, sürüm 24H2, derleme 26100.3915 (Arm64)
Header WinHvPlatform.h
Kütüphane WinHvPlatform.lib
DLL WinHvPlatform.dll
Architecture x64, Arm64

Ayrıca bakınız