Merge pull request #7139 from lioncash/tb
PowerPC: Add functions to read/write the full timebase value
This commit is contained in:
commit
9f03d8ca6a
|
@ -156,7 +156,7 @@ u32 GetFakeDecrementer()
|
||||||
void TimeBaseSet()
|
void TimeBaseSet()
|
||||||
{
|
{
|
||||||
CoreTiming::SetFakeTBStartTicks(CoreTiming::GetTicks());
|
CoreTiming::SetFakeTBStartTicks(CoreTiming::GetTicks());
|
||||||
CoreTiming::SetFakeTBStartValue(*((u64*)&TL));
|
CoreTiming::SetFakeTBStartValue(PowerPC::ReadFullTimeBaseValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
u64 GetFakeTimeBase()
|
u64 GetFakeTimeBase()
|
||||||
|
|
|
@ -4,8 +4,6 @@
|
||||||
|
|
||||||
#include "Core/PowerPC/Interpreter/Interpreter.h"
|
#include "Core/PowerPC/Interpreter/Interpreter.h"
|
||||||
|
|
||||||
#include <cstring>
|
|
||||||
|
|
||||||
#include "Common/Assert.h"
|
#include "Common/Assert.h"
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
#include "Common/FPURoundMode.h"
|
#include "Common/FPURoundMode.h"
|
||||||
|
@ -253,11 +251,7 @@ void Interpreter::mfspr(UGeckoInstruction inst)
|
||||||
|
|
||||||
case SPR_TL:
|
case SPR_TL:
|
||||||
case SPR_TU:
|
case SPR_TU:
|
||||||
{
|
PowerPC::WriteFullTimeBaseValue(SystemTimers::GetFakeTimeBase());
|
||||||
// works since we are little endian and TL comes first :)
|
|
||||||
const u64 time_base = SystemTimers::GetFakeTimeBase();
|
|
||||||
std::memcpy(&TL, &time_base, sizeof(u64));
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SPR_WPAR:
|
case SPR_WPAR:
|
||||||
|
|
|
@ -349,6 +349,18 @@ void RunLoop()
|
||||||
Host_UpdateDisasmDialog();
|
Host_UpdateDisasmDialog();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
u64 ReadFullTimeBaseValue()
|
||||||
|
{
|
||||||
|
u64 value;
|
||||||
|
std::memcpy(&value, &TL, sizeof(value));
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
void WriteFullTimeBaseValue(u64 value)
|
||||||
|
{
|
||||||
|
std::memcpy(&TL, &value, sizeof(value));
|
||||||
|
}
|
||||||
|
|
||||||
void UpdatePerformanceMonitor(u32 cycles, u32 num_load_stores, u32 num_fp_inst)
|
void UpdatePerformanceMonitor(u32 cycles, u32 num_load_stores, u32 num_fp_inst)
|
||||||
{
|
{
|
||||||
switch (MMCR0.PMC1SELECT)
|
switch (MMCR0.PMC1SELECT)
|
||||||
|
|
|
@ -178,6 +178,9 @@ void RunLoop();
|
||||||
u32 CompactCR();
|
u32 CompactCR();
|
||||||
void ExpandCR(u32 cr);
|
void ExpandCR(u32 cr);
|
||||||
|
|
||||||
|
u64 ReadFullTimeBaseValue();
|
||||||
|
void WriteFullTimeBaseValue(u64 value);
|
||||||
|
|
||||||
void UpdatePerformanceMonitor(u32 cycles, u32 num_load_stores, u32 num_fp_inst);
|
void UpdatePerformanceMonitor(u32 cycles, u32 num_load_stores, u32 num_fp_inst);
|
||||||
|
|
||||||
// Easy register access macros.
|
// Easy register access macros.
|
||||||
|
|
|
@ -263,12 +263,7 @@ void RegisterWidget::PopulateTable()
|
||||||
|
|
||||||
// Special registers
|
// Special registers
|
||||||
// TB
|
// TB
|
||||||
AddRegister(16, 5, RegisterType::tb, "TB",
|
AddRegister(16, 5, RegisterType::tb, "TB", PowerPC::ReadFullTimeBaseValue, nullptr);
|
||||||
[] {
|
|
||||||
return static_cast<u64>(PowerPC::ppcState.spr[SPR_TU]) << 32 |
|
|
||||||
PowerPC::ppcState.spr[SPR_TL];
|
|
||||||
},
|
|
||||||
nullptr);
|
|
||||||
|
|
||||||
// PC
|
// PC
|
||||||
AddRegister(17, 5, RegisterType::pc, "PC", [] { return PowerPC::ppcState.pc; },
|
AddRegister(17, 5, RegisterType::pc, "PC", [] { return PowerPC::ppcState.pc; },
|
||||||
|
|
|
@ -334,9 +334,7 @@ wxString CRegTable::GetValue(int row, int col)
|
||||||
PowerPC::ppcState.spr[SPR_IBAT4L + (row - 16) * 2]);
|
PowerPC::ppcState.spr[SPR_IBAT4L + (row - 16) * 2]);
|
||||||
|
|
||||||
if (row == 16)
|
if (row == 16)
|
||||||
return wxString::Format("%016" PRIx64, static_cast<u64>(PowerPC::ppcState.spr[SPR_TU])
|
return wxString::Format("%016" PRIx64, PowerPC::ReadFullTimeBaseValue());
|
||||||
<< 32 |
|
|
||||||
PowerPC::ppcState.spr[SPR_TL]);
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue