aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/core/core.cpp
diff options
context:
space:
mode:
authorGravatar bunnei <ericbunnie@gmail.com>2014-05-29 20:30:17 -0400
committerGravatar bunnei <ericbunnie@gmail.com>2014-05-29 20:30:17 -0400
commit9839f3b6cd9ea0d62730edee7db027dde86f6239 (patch)
tree663380c3a8d222f08e0a47dad88a259d6b48fa0a /src/core/core.cpp
parent6d267142ad42ed09e475742cab463b55d9176c29 (diff)
core: changed time delay before kernel reschedule to "approximate" a screen refresh
Diffstat (limited to 'src/core/core.cpp')
-rw-r--r--src/core/core.cpp15
1 files changed, 12 insertions, 3 deletions
diff --git a/src/core/core.cpp b/src/core/core.cpp
index f88bcd70..070f92ed 100644
--- a/src/core/core.cpp
+++ b/src/core/core.cpp
@@ -9,6 +9,7 @@
#include "core/core.h"
#include "core/mem_map.h"
#include "core/hw/hw.h"
+#include "core/hw/lcd.h"
#include "core/arm/disassembler/arm_disasm.h"
#include "core/arm/interpreter/arm_interpreter.h"
@@ -23,7 +24,7 @@ ARM_Interface* g_sys_core = NULL; ///< ARM11 system (OS) core
/// Run the core CPU loop
void RunLoop() {
for (;;){
- g_app_core->Run(100);
+ g_app_core->Run(LCD::kFrameTicks / 2);
HW::Update();
Kernel::Reschedule();
}
@@ -31,9 +32,17 @@ void RunLoop() {
/// Step the CPU one instruction
void SingleStep() {
+ static int ticks = 0;
+
g_app_core->Step();
- HW::Update();
- Kernel::Reschedule();
+
+ if (ticks >= LCD::kFrameTicks / 2) {
+ HW::Update();
+ Kernel::Reschedule();
+ ticks = 0;
+ } else {
+ ticks++;
+ }
}
/// Halt the core