xref: /openbmc/qemu/target/i386/whpx/whpx-internal.h (revision d7482ffe9756919531307330fd1c6dbec66e8c32)
19102c968SPaolo Bonzini #ifndef WHP_INTERNAL_H
29102c968SPaolo Bonzini #define WHP_INTERNAL_H
39102c968SPaolo Bonzini 
49102c968SPaolo Bonzini #include <windows.h>
59102c968SPaolo Bonzini #include <WinHvPlatform.h>
69102c968SPaolo Bonzini #include <WinHvEmulation.h>
79102c968SPaolo Bonzini 
8*d7482ffeSIvan Shcherbakov typedef enum WhpxBreakpointState {
9*d7482ffeSIvan Shcherbakov     WHPX_BP_CLEARED = 0,
10*d7482ffeSIvan Shcherbakov     WHPX_BP_SET_PENDING,
11*d7482ffeSIvan Shcherbakov     WHPX_BP_SET,
12*d7482ffeSIvan Shcherbakov     WHPX_BP_CLEAR_PENDING,
13*d7482ffeSIvan Shcherbakov } WhpxBreakpointState;
14*d7482ffeSIvan Shcherbakov 
15*d7482ffeSIvan Shcherbakov struct whpx_breakpoint {
16*d7482ffeSIvan Shcherbakov     vaddr address;
17*d7482ffeSIvan Shcherbakov     WhpxBreakpointState state;
18*d7482ffeSIvan Shcherbakov     uint8_t original_instruction;
19*d7482ffeSIvan Shcherbakov };
20*d7482ffeSIvan Shcherbakov 
21*d7482ffeSIvan Shcherbakov struct whpx_breakpoint_collection {
22*d7482ffeSIvan Shcherbakov     int allocated, used;
23*d7482ffeSIvan Shcherbakov     struct whpx_breakpoint data[0];
24*d7482ffeSIvan Shcherbakov };
25*d7482ffeSIvan Shcherbakov 
26*d7482ffeSIvan Shcherbakov struct whpx_breakpoints {
27*d7482ffeSIvan Shcherbakov     int original_address_count;
28*d7482ffeSIvan Shcherbakov     vaddr *original_addresses;
29*d7482ffeSIvan Shcherbakov 
30*d7482ffeSIvan Shcherbakov     struct whpx_breakpoint_collection *breakpoints;
31*d7482ffeSIvan Shcherbakov };
32*d7482ffeSIvan Shcherbakov 
3384f4ef17SPaolo Bonzini struct whpx_state {
3484f4ef17SPaolo Bonzini     uint64_t mem_quota;
3584f4ef17SPaolo Bonzini     WHV_PARTITION_HANDLE partition;
36*d7482ffeSIvan Shcherbakov     uint64_t exception_exit_bitmap;
37*d7482ffeSIvan Shcherbakov     int32_t running_cpus;
38*d7482ffeSIvan Shcherbakov     struct whpx_breakpoints breakpoints;
39*d7482ffeSIvan Shcherbakov     bool step_pending;
40*d7482ffeSIvan Shcherbakov 
4184f4ef17SPaolo Bonzini     bool kernel_irqchip_allowed;
4284f4ef17SPaolo Bonzini     bool kernel_irqchip_required;
4384f4ef17SPaolo Bonzini     bool apic_in_platform;
4484f4ef17SPaolo Bonzini };
4584f4ef17SPaolo Bonzini 
4684f4ef17SPaolo Bonzini extern struct whpx_state whpx_global;
4784f4ef17SPaolo Bonzini void whpx_apic_get(DeviceState *s);
4884f4ef17SPaolo Bonzini 
499102c968SPaolo Bonzini #define WHV_E_UNKNOWN_CAPABILITY 0x80370300L
509102c968SPaolo Bonzini 
519102c968SPaolo Bonzini #define LIST_WINHVPLATFORM_FUNCTIONS(X) \
529102c968SPaolo Bonzini   X(HRESULT, WHvGetCapability, (WHV_CAPABILITY_CODE CapabilityCode, VOID* CapabilityBuffer, UINT32 CapabilityBufferSizeInBytes, UINT32* WrittenSizeInBytes)) \
539102c968SPaolo Bonzini   X(HRESULT, WHvCreatePartition, (WHV_PARTITION_HANDLE* Partition)) \
549102c968SPaolo Bonzini   X(HRESULT, WHvSetupPartition, (WHV_PARTITION_HANDLE Partition)) \
559102c968SPaolo Bonzini   X(HRESULT, WHvDeletePartition, (WHV_PARTITION_HANDLE Partition)) \
569102c968SPaolo Bonzini   X(HRESULT, WHvGetPartitionProperty, (WHV_PARTITION_HANDLE Partition, WHV_PARTITION_PROPERTY_CODE PropertyCode, VOID* PropertyBuffer, UINT32 PropertyBufferSizeInBytes, UINT32* WrittenSizeInBytes)) \
579102c968SPaolo Bonzini   X(HRESULT, WHvSetPartitionProperty, (WHV_PARTITION_HANDLE Partition, WHV_PARTITION_PROPERTY_CODE PropertyCode, const VOID* PropertyBuffer, UINT32 PropertyBufferSizeInBytes)) \
589102c968SPaolo Bonzini   X(HRESULT, WHvMapGpaRange, (WHV_PARTITION_HANDLE Partition, VOID* SourceAddress, WHV_GUEST_PHYSICAL_ADDRESS GuestAddress, UINT64 SizeInBytes, WHV_MAP_GPA_RANGE_FLAGS Flags)) \
599102c968SPaolo Bonzini   X(HRESULT, WHvUnmapGpaRange, (WHV_PARTITION_HANDLE Partition, WHV_GUEST_PHYSICAL_ADDRESS GuestAddress, UINT64 SizeInBytes)) \
609102c968SPaolo Bonzini   X(HRESULT, WHvTranslateGva, (WHV_PARTITION_HANDLE Partition, UINT32 VpIndex, WHV_GUEST_VIRTUAL_ADDRESS Gva, WHV_TRANSLATE_GVA_FLAGS TranslateFlags, WHV_TRANSLATE_GVA_RESULT* TranslationResult, WHV_GUEST_PHYSICAL_ADDRESS* Gpa)) \
619102c968SPaolo Bonzini   X(HRESULT, WHvCreateVirtualProcessor, (WHV_PARTITION_HANDLE Partition, UINT32 VpIndex, UINT32 Flags)) \
629102c968SPaolo Bonzini   X(HRESULT, WHvDeleteVirtualProcessor, (WHV_PARTITION_HANDLE Partition, UINT32 VpIndex)) \
639102c968SPaolo Bonzini   X(HRESULT, WHvRunVirtualProcessor, (WHV_PARTITION_HANDLE Partition, UINT32 VpIndex, VOID* ExitContext, UINT32 ExitContextSizeInBytes)) \
649102c968SPaolo Bonzini   X(HRESULT, WHvCancelRunVirtualProcessor, (WHV_PARTITION_HANDLE Partition, UINT32 VpIndex, UINT32 Flags)) \
659102c968SPaolo Bonzini   X(HRESULT, WHvGetVirtualProcessorRegisters, (WHV_PARTITION_HANDLE Partition, UINT32 VpIndex, const WHV_REGISTER_NAME* RegisterNames, UINT32 RegisterCount, WHV_REGISTER_VALUE* RegisterValues)) \
669102c968SPaolo Bonzini   X(HRESULT, WHvSetVirtualProcessorRegisters, (WHV_PARTITION_HANDLE Partition, UINT32 VpIndex, const WHV_REGISTER_NAME* RegisterNames, UINT32 RegisterCount, const WHV_REGISTER_VALUE* RegisterValues)) \
679102c968SPaolo Bonzini 
689102c968SPaolo Bonzini /*
699102c968SPaolo Bonzini  * These are supplemental functions that may not be present
709102c968SPaolo Bonzini  * on all versions and are not critical for basic functionality.
719102c968SPaolo Bonzini  */
729102c968SPaolo Bonzini #define LIST_WINHVPLATFORM_FUNCTIONS_SUPPLEMENTAL(X) \
739102c968SPaolo Bonzini   X(HRESULT, WHvSuspendPartitionTime, (WHV_PARTITION_HANDLE Partition)) \
749102c968SPaolo Bonzini   X(HRESULT, WHvRequestInterrupt, (WHV_PARTITION_HANDLE Partition, \
759102c968SPaolo Bonzini         WHV_INTERRUPT_CONTROL* Interrupt, UINT32 InterruptControlSize)) \
769102c968SPaolo Bonzini   X(HRESULT, WHvGetVirtualProcessorInterruptControllerState2, \
779102c968SPaolo Bonzini         (WHV_PARTITION_HANDLE Partition, UINT32 VpIndex, PVOID State, \
789102c968SPaolo Bonzini          UINT32 StateSize, UINT32* WrittenSize)) \
799102c968SPaolo Bonzini   X(HRESULT, WHvSetVirtualProcessorInterruptControllerState2, \
809102c968SPaolo Bonzini         (WHV_PARTITION_HANDLE Partition, UINT32 VpIndex, PVOID State, \
819102c968SPaolo Bonzini          UINT32 StateSize)) \
829102c968SPaolo Bonzini 
839102c968SPaolo Bonzini #define LIST_WINHVEMULATION_FUNCTIONS(X) \
849102c968SPaolo Bonzini   X(HRESULT, WHvEmulatorCreateEmulator, (const WHV_EMULATOR_CALLBACKS* Callbacks, WHV_EMULATOR_HANDLE* Emulator)) \
859102c968SPaolo Bonzini   X(HRESULT, WHvEmulatorDestroyEmulator, (WHV_EMULATOR_HANDLE Emulator)) \
869102c968SPaolo Bonzini   X(HRESULT, WHvEmulatorTryIoEmulation, (WHV_EMULATOR_HANDLE Emulator, VOID* Context, const WHV_VP_EXIT_CONTEXT* VpContext, const WHV_X64_IO_PORT_ACCESS_CONTEXT* IoInstructionContext, WHV_EMULATOR_STATUS* EmulatorReturnStatus)) \
879102c968SPaolo Bonzini   X(HRESULT, WHvEmulatorTryMmioEmulation, (WHV_EMULATOR_HANDLE Emulator, VOID* Context, const WHV_VP_EXIT_CONTEXT* VpContext, const WHV_MEMORY_ACCESS_CONTEXT* MmioInstructionContext, WHV_EMULATOR_STATUS* EmulatorReturnStatus)) \
889102c968SPaolo Bonzini 
899102c968SPaolo Bonzini #define WHP_DEFINE_TYPE(return_type, function_name, signature) \
909102c968SPaolo Bonzini     typedef return_type (WINAPI *function_name ## _t) signature;
919102c968SPaolo Bonzini 
929102c968SPaolo Bonzini #define WHP_DECLARE_MEMBER(return_type, function_name, signature) \
939102c968SPaolo Bonzini     function_name ## _t function_name;
949102c968SPaolo Bonzini 
959102c968SPaolo Bonzini /* Define function typedef */
969102c968SPaolo Bonzini LIST_WINHVPLATFORM_FUNCTIONS(WHP_DEFINE_TYPE)
979102c968SPaolo Bonzini LIST_WINHVEMULATION_FUNCTIONS(WHP_DEFINE_TYPE)
989102c968SPaolo Bonzini LIST_WINHVPLATFORM_FUNCTIONS_SUPPLEMENTAL(WHP_DEFINE_TYPE)
999102c968SPaolo Bonzini 
1009102c968SPaolo Bonzini struct WHPDispatch {
1019102c968SPaolo Bonzini     LIST_WINHVPLATFORM_FUNCTIONS(WHP_DECLARE_MEMBER)
1029102c968SPaolo Bonzini     LIST_WINHVEMULATION_FUNCTIONS(WHP_DECLARE_MEMBER)
1039102c968SPaolo Bonzini     LIST_WINHVPLATFORM_FUNCTIONS_SUPPLEMENTAL(WHP_DECLARE_MEMBER)
1049102c968SPaolo Bonzini };
1059102c968SPaolo Bonzini 
1069102c968SPaolo Bonzini extern struct WHPDispatch whp_dispatch;
1079102c968SPaolo Bonzini 
1089102c968SPaolo Bonzini bool init_whp_dispatch(void);
1099102c968SPaolo Bonzini 
1109102c968SPaolo Bonzini typedef enum WHPFunctionList {
1119102c968SPaolo Bonzini     WINHV_PLATFORM_FNS_DEFAULT,
1129102c968SPaolo Bonzini     WINHV_EMULATION_FNS_DEFAULT,
1139102c968SPaolo Bonzini     WINHV_PLATFORM_FNS_SUPPLEMENTAL
1149102c968SPaolo Bonzini } WHPFunctionList;
1159102c968SPaolo Bonzini 
1169102c968SPaolo Bonzini #endif /* WHP_INTERNAL_H */
117