mirror of
https://github.com/genodelabs/genode.git
synced 2024-12-25 00:11:07 +00:00
vbox6: add POKE calls in TM for remote vCPUs
and return to VMM if TM_TIMER flag is set Issue #4313
This commit is contained in:
parent
5a21431c31
commit
3701733c8f
@ -1 +1 @@
|
|||||||
4efbd1dc165327781b92e86beabd578e2339c222
|
95e5355642337757ad41218571699933eb420a16
|
||||||
|
@ -5,3 +5,4 @@ narrowing.patch
|
|||||||
network.patch
|
network.patch
|
||||||
devahci.patch
|
devahci.patch
|
||||||
smp_sipi.patch
|
smp_sipi.patch
|
||||||
|
tm_poke.patch
|
||||||
|
96
repos/ports/src/virtualbox6/patches/tm_poke.patch
Normal file
96
repos/ports/src/virtualbox6/patches/tm_poke.patch
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
--- a/src/virtualbox6/src/VBox/VMM/VMMAll/TMAllVirtual.cpp
|
||||||
|
+++ b/src/virtualbox6/src/VBox/VMM/VMMAll/TMAllVirtual.cpp
|
||||||
|
@@ -250,7 +250,7 @@
|
||||||
|
Log5(("TMAllVirtual(%u): FF: %d -> 1\n", __LINE__, VMCPU_FF_IS_SET(pVCpuDst, VMCPU_FF_TIMER)));
|
||||||
|
VMCPU_FF_SET(pVCpuDst, VMCPU_FF_TIMER);
|
||||||
|
#ifdef IN_RING3
|
||||||
|
- VMR3NotifyCpuFFU(pVCpuDst->pUVCpu, VMNOTIFYFF_FLAGS_DONE_REM);
|
||||||
|
+ VMR3NotifyCpuFFU(pVCpuDst->pUVCpu, VMNOTIFYFF_FLAGS_DONE_REM | VMNOTIFYFF_FLAGS_POKE);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@@ -408,7 +408,7 @@
|
||||||
|
if (pcNsToDeadline)
|
||||||
|
*pcNsToDeadline = 0;
|
||||||
|
#ifdef IN_RING3
|
||||||
|
- VMR3NotifyCpuFFU(pVCpuDst->pUVCpu, VMNOTIFYFF_FLAGS_DONE_REM);
|
||||||
|
+ VMR3NotifyCpuFFU(pVCpuDst->pUVCpu, VMNOTIFYFF_FLAGS_DONE_REM | VMNOTIFYFF_FLAGS_POKE);
|
||||||
|
#endif
|
||||||
|
STAM_COUNTER_INC(&pVM->tm.s.StatVirtualSyncGetSetFF);
|
||||||
|
STAM_COUNTER_INC(&pVM->tm.s.StatVirtualSyncGetExpired);
|
||||||
|
@@ -491,7 +491,7 @@
|
||||||
|
PDMCritSectLeave(&pVM->tm.s.VirtualSyncLock);
|
||||||
|
|
||||||
|
#ifdef IN_RING3
|
||||||
|
- VMR3NotifyCpuFFU(pVCpuDst->pUVCpu, VMNOTIFYFF_FLAGS_DONE_REM);
|
||||||
|
+ VMR3NotifyCpuFFU(pVCpuDst->pUVCpu, VMNOTIFYFF_FLAGS_DONE_REM | VMNOTIFYFF_FLAGS_POKE);
|
||||||
|
#endif
|
||||||
|
if (pcNsToDeadline)
|
||||||
|
*pcNsToDeadline = 0;
|
||||||
|
@@ -544,7 +544,7 @@
|
||||||
|
Log5(("TMAllVirtual(%u): FF: 0 -> 1\n", __LINE__));
|
||||||
|
VMCPU_FF_SET(pVCpuDst, VMCPU_FF_TIMER);
|
||||||
|
#ifdef IN_RING3
|
||||||
|
- VMR3NotifyCpuFFU(pVCpuDst->pUVCpu, VMNOTIFYFF_FLAGS_DONE_REM /** @todo |VMNOTIFYFF_FLAGS_POKE*/);
|
||||||
|
+ VMR3NotifyCpuFFU(pVCpuDst->pUVCpu, VMNOTIFYFF_FLAGS_DONE_REM | VMNOTIFYFF_FLAGS_POKE);
|
||||||
|
#endif
|
||||||
|
STAM_COUNTER_INC(&pVM->tm.s.StatVirtualSyncGetSetFF);
|
||||||
|
}
|
||||||
|
@@ -711,7 +711,7 @@
|
||||||
|
VM_FF_SET(pVM, VM_FF_TM_VIRTUAL_SYNC); /* Hmm? */
|
||||||
|
VMCPU_FF_SET(pVCpuDst, VMCPU_FF_TIMER);
|
||||||
|
#ifdef IN_RING3
|
||||||
|
- VMR3NotifyCpuFFU(pVCpuDst->pUVCpu, VMNOTIFYFF_FLAGS_DONE_REM);
|
||||||
|
+ VMR3NotifyCpuFFU(pVCpuDst->pUVCpu, VMNOTIFYFF_FLAGS_DONE_REM | VMNOTIFYFF_FLAGS_POKE);
|
||||||
|
#endif
|
||||||
|
STAM_COUNTER_INC(&pVM->tm.s.StatVirtualSyncGetSetFF);
|
||||||
|
Log4(("TM: %'RU64/-%'8RU64: exp tmr=>ff [NoLock]\n", u64, pVM->tm.s.offVirtualSync - pVM->tm.s.offVirtualSyncGivenUp));
|
||||||
|
--- a/src/virtualbox6/src/VBox/VMM/VMMAll/TMAll.cpp
|
||||||
|
+++ b/src/virtualbox6/src/VBox/VMM/VMMAll/TMAll.cpp
|
||||||
|
@@ -292,7 +292,7 @@
|
||||||
|
Log5(("TMAll(%u): FF: 0 -> 1\n", __LINE__));
|
||||||
|
VMCPU_FF_SET(pVCpuDst, VMCPU_FF_TIMER);
|
||||||
|
#ifdef IN_RING3
|
||||||
|
- VMR3NotifyCpuFFU(pVCpuDst->pUVCpu, VMNOTIFYFF_FLAGS_DONE_REM);
|
||||||
|
+ VMR3NotifyCpuFFU(pVCpuDst->pUVCpu, VMNOTIFYFF_FLAGS_DONE_REM | VMNOTIFYFF_FLAGS_POKE);
|
||||||
|
#endif
|
||||||
|
STAM_COUNTER_INC(&pVM->tm.s.StatScheduleSetFF);
|
||||||
|
}
|
||||||
|
@@ -831,6 +831,12 @@
|
||||||
|
{
|
||||||
|
Log5(("TMAll(%u): FF: %d -> 1\n", __LINE__, VMCPU_FF_IS_SET(pVCpuDst, VMCPU_FF_TIMER)));
|
||||||
|
VMCPU_FF_SET(pVCpuDst, VMCPU_FF_TIMER);
|
||||||
|
+
|
||||||
|
+ if (pVCpu->idCpu != pVCpuDst->idCpu) {
|
||||||
|
+ Log(("FF_TIMER POKE, vCPU=%u -> vCPU=%u line=%u\n",
|
||||||
|
+ pVCpu->idCpu, pVCpuDst->idCpu, __LINE__));
|
||||||
|
+ VMR3NotifyCpuFFU(pVCpuDst->pUVCpu, VMNOTIFYFF_FLAGS_POKE);
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
LogFlow(("TMTimerPoll: expire1=%'RU64 <= now=%'RU64\n", u64Expire1, u64Now));
|
||||||
|
return tmTimerPollReturnHit(pVM, pVCpu, pVCpuDst, u64Now, pu64Delta, &pVM->tm.s.StatPollVirtual);
|
||||||
|
@@ -874,6 +880,12 @@
|
||||||
|
{
|
||||||
|
Log5(("TMAll(%u): FF: %d -> 1\n", __LINE__, VMCPU_FF_IS_SET(pVCpuDst, VMCPU_FF_TIMER)));
|
||||||
|
VMCPU_FF_SET(pVCpuDst, VMCPU_FF_TIMER);
|
||||||
|
+
|
||||||
|
+ if (pVCpu->idCpu != pVCpuDst->idCpu) {
|
||||||
|
+ Log(("FF_TIMER POKE, vCPU=%u -> vCPU=%u line=%u\n",
|
||||||
|
+ pVCpu->idCpu, pVCpuDst->idCpu, __LINE__));
|
||||||
|
+ VMR3NotifyCpuFFU(pVCpuDst->pUVCpu, VMNOTIFYFF_FLAGS_POKE);
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
|
||||||
|
STAM_COUNTER_INC(&pVM->tm.s.StatPollSimple);
|
||||||
|
@@ -970,6 +982,11 @@
|
||||||
|
{
|
||||||
|
Log5(("TMAll(%u): FF: %d -> 1\n", __LINE__, VMCPU_FF_IS_SET(pVCpuDst, VMCPU_FF_TIMER)));
|
||||||
|
VMCPU_FF_SET(pVCpuDst, VMCPU_FF_TIMER);
|
||||||
|
+ if (pVCpu->idCpu != pVCpuDst->idCpu) {
|
||||||
|
+ Log(("FF_TIMER POKE, vCPU=%u -> vCPU=%u line=%u\n",
|
||||||
|
+ pVCpu->idCpu, pVCpuDst->idCpu, __LINE__));
|
||||||
|
+ VMR3NotifyCpuFFU(pVCpuDst->pUVCpu, VMNOTIFYFF_FLAGS_POKE);
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
STAM_COUNTER_INC(&pVM->tm.s.StatPollVirtualSync);
|
||||||
|
LogFlow(("TMTimerPoll: expire2=%'RU64 <= now=%'RU64\n", u64Expire2, u64Now));
|
@ -411,7 +411,8 @@ template <typename T> bool Sup::Vcpu_impl<T>::_continue_hw_accelerated()
|
|||||||
uint32_t check_vmcpu = VMCPU_FF_HM_TO_R3_MASK
|
uint32_t check_vmcpu = VMCPU_FF_HM_TO_R3_MASK
|
||||||
| VMCPU_FF_PGM_SYNC_CR3
|
| VMCPU_FF_PGM_SYNC_CR3
|
||||||
| VMCPU_FF_PGM_SYNC_CR3_NON_GLOBAL
|
| VMCPU_FF_PGM_SYNC_CR3_NON_GLOBAL
|
||||||
| VMCPU_FF_REQUEST;
|
| VMCPU_FF_REQUEST
|
||||||
|
| VMCPU_FF_TIMER;
|
||||||
|
|
||||||
if (!VM_FF_IS_SET(&_vm, check_vm) &&
|
if (!VM_FF_IS_SET(&_vm, check_vm) &&
|
||||||
!VMCPU_FF_IS_SET(&_vmcpu, check_vmcpu))
|
!VMCPU_FF_IS_SET(&_vmcpu, check_vmcpu))
|
||||||
@ -440,8 +441,6 @@ template <typename T> bool Sup::Vcpu_impl<T>::_continue_hw_accelerated()
|
|||||||
if (false && VMCPU_FF_IS_SET(&_vmcpu, check_vmcpu)) {
|
if (false && VMCPU_FF_IS_SET(&_vmcpu, check_vmcpu)) {
|
||||||
log("VMCPU_FF=", Hex(_vmcpu.fLocalForcedActions));
|
log("VMCPU_FF=", Hex(_vmcpu.fLocalForcedActions));
|
||||||
VERBOSE_VMCPU(VMCPU_FF_TO_R3);
|
VERBOSE_VMCPU(VMCPU_FF_TO_R3);
|
||||||
/* when this flag gets set, a pause request follows
|
|
||||||
VERBOSE_VMCPU(VMCPU_FF_TIMER); */
|
|
||||||
VERBOSE_VMCPU(VMCPU_FF_PDM_CRITSECT);
|
VERBOSE_VMCPU(VMCPU_FF_PDM_CRITSECT);
|
||||||
VERBOSE_VMCPU(VMCPU_FF_PGM_SYNC_CR3);
|
VERBOSE_VMCPU(VMCPU_FF_PGM_SYNC_CR3);
|
||||||
VERBOSE_VMCPU(VMCPU_FF_PGM_SYNC_CR3_NON_GLOBAL);
|
VERBOSE_VMCPU(VMCPU_FF_PGM_SYNC_CR3_NON_GLOBAL);
|
||||||
@ -498,9 +497,6 @@ typename Sup::Vcpu_impl<T>::Current_state Sup::Vcpu_impl<T>::_handle_paused()
|
|||||||
|
|
||||||
Assert(state.intr_state.value() == VMX_VMCS_GUEST_INT_STATE_NONE);
|
Assert(state.intr_state.value() == VMX_VMCS_GUEST_INT_STATE_NONE);
|
||||||
|
|
||||||
if (!_continue_hw_accelerated())
|
|
||||||
warning("unexpected pause exit");
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* We got a pause exit during IRQ injection and the guest is ready for
|
* We got a pause exit during IRQ injection and the guest is ready for
|
||||||
* IRQ injection. So, just continue running the vCPU.
|
* IRQ injection. So, just continue running the vCPU.
|
||||||
|
Loading…
Reference in New Issue
Block a user