mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-20 19:49:28 +00:00
parent
a07b5937d9
commit
75266e467d
@ -1 +1 @@
|
|||||||
4f4c05a80b5767a0132c333a352fada6ba8965a8
|
f425c0058d023cabfa555a0605982e935c582902
|
||||||
|
66
repos/ports/src/virtualbox6/patches/avx.patch
Normal file
66
repos/ports/src/virtualbox6/patches/avx.patch
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
--- a/src/virtualbox6/src/VBox/VMM/VMMR3/CPUMR3CpuId.cpp
|
||||||
|
+++ b/src/virtualbox6/src/VBox/VMM/VMMR3/CPUMR3CpuId.cpp
|
||||||
|
@@ -2470,6 +2470,8 @@
|
||||||
|
pCpum->GuestFeatures.cbMaxExtendedState),
|
||||||
|
VERR_CPUM_IPE_1);
|
||||||
|
pVCpu0->cpum.s.Guest.aoffXState[iComponent] = pSubLeaf->uEbx;
|
||||||
|
+ /* store uEax to later on detect compact mode */
|
||||||
|
+// pVCpu0->cpum.s.Guest.aoffXState[iComponent] = pSubLeaf->uEax;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Copy the CPU #0 data to the other CPUs. */
|
||||||
|
@@ -3558,6 +3560,8 @@
|
||||||
|
VERR_CPUM_IPE_2);
|
||||||
|
continue;
|
||||||
|
case 1:
|
||||||
|
+ /* permit compact AVX mode, Intel: 13.2 ENUMERATION OF CPU SUPPORT FOR XSAVE INSTRUCTIONS AND XSAVE- SUPPORTED FEATURES */
|
||||||
|
+// pCurLeaf->uEax &= 1 | 2;
|
||||||
|
pCurLeaf->uEax &= 0;
|
||||||
|
pCurLeaf->uEcx &= 0;
|
||||||
|
pCurLeaf->uEdx &= 0;
|
||||||
|
@@ -4285,7 +4289,8 @@
|
||||||
|
rc = cpumR3CpuIdReadIsaExtCfgLegacy(pVM, pIsaExts, pCpumCfg, "SSE4.2", &pConfig->enmSse42, true);
|
||||||
|
AssertLogRelRCReturn(rc, rc);
|
||||||
|
|
||||||
|
- bool const fMayHaveXSave = fNestedPagingAndFullGuestExec
|
||||||
|
+ bool const fEnforceHWusage = true;
|
||||||
|
+ bool const fMayHaveXSave = fEnforceHWusage
|
||||||
|
&& pVM->cpum.s.HostFeatures.fXSaveRstor
|
||||||
|
&& pVM->cpum.s.HostFeatures.fOpSysXSaveRstor;
|
||||||
|
uint64_t const fXStateHostMask = pVM->cpum.s.fXStateHostMask;
|
||||||
|
@@ -4296,7 +4301,7 @@
|
||||||
|
* unrestricted guest execution mode. Not possible to force this one without
|
||||||
|
* host support at the moment.
|
||||||
|
*/
|
||||||
|
- rc = cpumR3CpuIdReadIsaExtCfgEx(pVM, pIsaExts, "XSAVE", &pConfig->enmXSave, fNestedPagingAndFullGuestExec,
|
||||||
|
+ rc = cpumR3CpuIdReadIsaExtCfgEx(pVM, pIsaExts, "XSAVE", &pConfig->enmXSave, fEnforceHWusage,
|
||||||
|
fMayHaveXSave /*fAllowed*/);
|
||||||
|
AssertLogRelRCReturn(rc, rc);
|
||||||
|
|
||||||
|
@@ -4305,7 +4310,7 @@
|
||||||
|
* XSAVE is exposed too. For the time being the default is to only expose this
|
||||||
|
* to VMs with nested paging and AMD-V or unrestricted guest execution mode.
|
||||||
|
*/
|
||||||
|
- rc = cpumR3CpuIdReadIsaExtCfgEx(pVM, pIsaExts, "AVX", &pConfig->enmAvx, fNestedPagingAndFullGuestExec,
|
||||||
|
+ rc = cpumR3CpuIdReadIsaExtCfgEx(pVM, pIsaExts, "AVX", &pConfig->enmAvx, fEnforceHWusage,
|
||||||
|
fMayHaveXSave && pConfig->enmXSave && (fXStateHostMask & XSAVE_C_YMM) /*fAllowed*/);
|
||||||
|
AssertLogRelRCReturn(rc, rc);
|
||||||
|
|
||||||
|
@@ -4314,7 +4319,7 @@
|
||||||
|
* XSAVE is exposed too. For the time being the default is to only expose this
|
||||||
|
* to VMs with nested paging and AMD-V or unrestricted guest execution mode.
|
||||||
|
*/
|
||||||
|
- rc = cpumR3CpuIdReadIsaExtCfgEx(pVM, pIsaExts, "AVX2", &pConfig->enmAvx2, fNestedPagingAndFullGuestExec /* temporarily */,
|
||||||
|
+ rc = cpumR3CpuIdReadIsaExtCfgEx(pVM, pIsaExts, "AVX2", &pConfig->enmAvx2, fEnforceHWusage /* temporarily */,
|
||||||
|
fMayHaveXSave && pConfig->enmXSave && (fXStateHostMask & XSAVE_C_YMM) /*fAllowed*/);
|
||||||
|
AssertLogRelRCReturn(rc, rc);
|
||||||
|
|
||||||
|
@@ -4425,7 +4430,7 @@
|
||||||
|
* being the default is to only do this for VMs with nested paging and AMD-V or
|
||||||
|
* unrestricted guest mode.
|
||||||
|
*/
|
||||||
|
- rc = cpumR3CpuIdReadIsaExtCfg(pVM, pIsaExts, "SSE4A", &pConfig->enmSse4A, fNestedPagingAndFullGuestExec);
|
||||||
|
+ rc = cpumR3CpuIdReadIsaExtCfg(pVM, pIsaExts, "SSE4A", &pConfig->enmSse4A, fEnforceHWusage);
|
||||||
|
AssertLogRelRCReturn(rc, rc);
|
||||||
|
|
||||||
|
/** @cfgm{/CPUM/IsaExts/MISALNSSE, isaextcfg, depends}
|
@ -14,3 +14,4 @@ pgmphys.patch
|
|||||||
sup_ioctl_query_func_size.patch
|
sup_ioctl_query_func_size.patch
|
||||||
disk_geometry.patch
|
disk_geometry.patch
|
||||||
stack_size.patch
|
stack_size.patch
|
||||||
|
avx.patch
|
||||||
|
@ -265,12 +265,27 @@ template <typename VIRT> void Sup::Vcpu_impl<VIRT>::_transfer_state_to_vcpu(CPUM
|
|||||||
state.tpr_threshold.charge(pending_priority);
|
state.tpr_threshold.charge(pending_priority);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* export FPU state */
|
/* export FPU state - start */
|
||||||
|
state.xcr0.charge(ctx.aXcr[0]);
|
||||||
|
|
||||||
|
{
|
||||||
|
::uint64_t ia32_xss = 0;
|
||||||
|
auto const rc = CPUMQueryGuestMsr(&_vmcpu, 0xDA0 /* MSR_IA32_XSS */,
|
||||||
|
&ia32_xss);
|
||||||
|
|
||||||
|
if (rc == VINF_SUCCESS)
|
||||||
|
state.xss.charge(ia32_xss);
|
||||||
|
}
|
||||||
|
|
||||||
_state->ref.fpu.charge([&](Vcpu_state::Fpu::State &fpu) {
|
_state->ref.fpu.charge([&](Vcpu_state::Fpu::State &fpu) {
|
||||||
static_assert(sizeof(*ctx.pXStateR3) >= sizeof(fpu._buffer));
|
unsigned fpu_size = min(_vm.cpum.s.HostFeatures.cbMaxExtendedState,
|
||||||
::memcpy(fpu._buffer, ctx.pXStateR3, sizeof(X86FXSTATE));
|
sizeof(fpu._buffer));
|
||||||
return sizeof(X86FXSTATE);
|
|
||||||
|
::memcpy(fpu._buffer, ctx.pXStateR3, fpu_size);
|
||||||
|
|
||||||
|
return fpu_size;
|
||||||
});
|
});
|
||||||
|
/* export FPU state - end */
|
||||||
|
|
||||||
{
|
{
|
||||||
::uint64_t tsc_aux = 0;
|
::uint64_t tsc_aux = 0;
|
||||||
@ -413,13 +428,21 @@ template <typename VIRT> void Sup::Vcpu_impl<VIRT>::_transfer_state_to_vbox(CPUM
|
|||||||
|
|
||||||
APICSetTpr(pVCpu, tpr);
|
APICSetTpr(pVCpu, tpr);
|
||||||
|
|
||||||
/* import FPU state */
|
/* import FPU state - start */
|
||||||
_state->ref.fpu.with_state([&](Vcpu_state::Fpu::State const &fpu) {
|
_state->ref.fpu.with_state([&](Vcpu_state::Fpu::State const &fpu) {
|
||||||
static_assert(sizeof(*ctx.pXStateR3) >= sizeof(fpu._buffer));
|
unsigned fpu_size = min(_vm.cpum.s.HostFeatures.cbMaxExtendedState,
|
||||||
::memcpy(ctx.pXStateR3, fpu._buffer, sizeof(X86FXSTATE));
|
sizeof(fpu._buffer));
|
||||||
|
|
||||||
|
::memcpy(ctx.pXStateR3, fpu._buffer, fpu_size);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
CPUMSetGuestMsr (pVCpu, 0xDA0 /* MSR_IA32_XSS */, state.xss.value());
|
||||||
|
CPUMSetGuestXcr0(pVCpu, state.xcr0.value());
|
||||||
|
|
||||||
|
/* import FPU state - end */
|
||||||
|
|
||||||
/* do SVM/VMX-specific transfers */
|
/* do SVM/VMX-specific transfers */
|
||||||
VIRT::transfer_state_to_vbox(state, _vmcpu, ctx);
|
VIRT::transfer_state_to_vbox(state, _vmcpu, ctx);
|
||||||
}
|
}
|
||||||
|
@ -77,6 +77,7 @@ Genode::Vm_connection::Exit_config const Sup::Svm::exit_config { /* ... */ };
|
|||||||
| SVM_CTRL_INTERCEPT_WBINVD
|
| SVM_CTRL_INTERCEPT_WBINVD
|
||||||
| SVM_CTRL_INTERCEPT_MONITOR
|
| SVM_CTRL_INTERCEPT_MONITOR
|
||||||
| SVM_CTRL_INTERCEPT_RDTSCP
|
| SVM_CTRL_INTERCEPT_RDTSCP
|
||||||
|
| SVM_CTRL_INTERCEPT_XSETBV
|
||||||
| SVM_CTRL_INTERCEPT_MWAIT;
|
| SVM_CTRL_INTERCEPT_MWAIT;
|
||||||
|
|
||||||
unsigned Sup::Svm::ctrl_primary()
|
unsigned Sup::Svm::ctrl_primary()
|
||||||
|
@ -81,6 +81,7 @@ unsigned Sup::Vmx::ctrl_secondary()
|
|||||||
| VMX_PROC_CTLS2_RDTSCP
|
| VMX_PROC_CTLS2_RDTSCP
|
||||||
| VMX_PROC_CTLS2_EPT
|
| VMX_PROC_CTLS2_EPT
|
||||||
| VMX_PROC_CTLS2_INVPCID
|
| VMX_PROC_CTLS2_INVPCID
|
||||||
|
| VMX_PROC_CTLS2_XSAVES_XRSTORS
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user