Core: Cleaned up SingleStep(), updated default LCD refresh to assume each instruction is ~3 cycles

master
bunnei 2014-06-06 00:06:33 +07:00
parent 3449aaa350
commit 0deeda54ee
2 changed files with 14 additions and 12 deletions

@ -18,6 +18,7 @@
namespace Core { namespace Core {
u64 g_last_ticks = 0; ///< Last CPU ticks
ARM_Disasm* g_disasm = NULL; ///< ARM disassembler ARM_Disasm* g_disasm = NULL; ///< ARM disassembler
ARM_Interface* g_app_core = NULL; ///< ARM11 application core ARM_Interface* g_app_core = NULL; ///< ARM11 application core
ARM_Interface* g_sys_core = NULL; ///< ARM11 system (OS) core ARM_Interface* g_sys_core = NULL; ///< ARM11 system (OS) core
@ -25,7 +26,7 @@ ARM_Interface* g_sys_core = NULL; ///< ARM11 system (OS) core
/// Run the core CPU loop /// Run the core CPU loop
void RunLoop() { void RunLoop() {
for (;;){ for (;;){
g_app_core->Run(LCD::kFrameTicks / 3); g_app_core->Run(LCD::kFrameTicks);
HW::Update(); HW::Update();
Kernel::Reschedule(); Kernel::Reschedule();
} }
@ -33,16 +34,14 @@ void RunLoop() {
/// Step the CPU one instruction /// Step the CPU one instruction
void SingleStep() { void SingleStep() {
static int ticks = 0;
g_app_core->Step(); g_app_core->Step();
if ((ticks >= LCD::kFrameTicks / 3) || HLE::g_reschedule) { // Update and reschedule after approx. 1 frame
u64 current_ticks = Core::g_app_core->GetTicks();
if ((current_ticks - g_last_ticks) >= LCD::kFrameTicks || HLE::g_reschedule) {
g_last_ticks = current_ticks;
HW::Update(); HW::Update();
Kernel::Reschedule(); Kernel::Reschedule();
ticks = 0;
} else {
ticks++;
} }
} }
@ -64,6 +63,8 @@ int Init() {
g_app_core = new ARM_Interpreter(); g_app_core = new ARM_Interpreter();
g_sys_core = new ARM_Interpreter(); g_sys_core = new ARM_Interpreter();
g_last_ticks = Core::g_app_core->GetTicks();
return 0; return 0;
} }

@ -8,7 +8,8 @@
namespace LCD { namespace LCD {
static const u32 kFrameTicks = 268123480 / 60; ///< 268MHz / 60 frames per second static const u32 kFrameCycles = 268123480 / 60; ///< 268MHz / 60 frames per second
static const u32 kFrameTicks = kFrameCycles / 3; ///< Approximate number of instructions/frame
struct Registers { struct Registers {
u32 framebuffer_top_left_1; u32 framebuffer_top_left_1;