mirror of https://github.com/mgba-emu/mgba.git
Wii: Don't wait for vsync if we missed the target
This commit is contained in:
parent
27d002105a
commit
4d1b7b4591
|
@ -7,6 +7,7 @@
|
||||||
|
|
||||||
#include <fat.h>
|
#include <fat.h>
|
||||||
#include <gccore.h>
|
#include <gccore.h>
|
||||||
|
#include <ogc/machine/processor.h>
|
||||||
#include <malloc.h>
|
#include <malloc.h>
|
||||||
#include <wiiuse/wpad.h>
|
#include <wiiuse/wpad.h>
|
||||||
|
|
||||||
|
@ -22,6 +23,8 @@
|
||||||
|
|
||||||
#define SAMPLES 1024
|
#define SAMPLES 1024
|
||||||
|
|
||||||
|
static void _retraceCallback(u32 count);
|
||||||
|
|
||||||
static void _audioDMA(void);
|
static void _audioDMA(void);
|
||||||
static void _setRumble(struct GBARumble* rumble, int enable);
|
static void _setRumble(struct GBARumble* rumble, int enable);
|
||||||
static void _sampleRotation(struct GBARotationSource* source);
|
static void _sampleRotation(struct GBARotationSource* source);
|
||||||
|
@ -55,6 +58,8 @@ static GXTexObj tex;
|
||||||
static int32_t tiltX;
|
static int32_t tiltX;
|
||||||
static int32_t tiltY;
|
static int32_t tiltY;
|
||||||
static int32_t gyroZ;
|
static int32_t gyroZ;
|
||||||
|
static uint32_t retraceCount;
|
||||||
|
static uint32_t referenceRetraceCount;
|
||||||
|
|
||||||
static void* framebuffer[2];
|
static void* framebuffer[2];
|
||||||
static int whichFb = 0;
|
static int whichFb = 0;
|
||||||
|
@ -144,6 +149,8 @@ int main() {
|
||||||
memset(texmem, 0, 256 * 256 * BYTES_PER_PIXEL);
|
memset(texmem, 0, 256 * 256 * BYTES_PER_PIXEL);
|
||||||
GX_InitTexObj(&tex, texmem, 256, 256, GX_TF_RGB565, GX_CLAMP, GX_CLAMP, GX_FALSE);
|
GX_InitTexObj(&tex, texmem, 256, 256, GX_TF_RGB565, GX_CLAMP, GX_CLAMP, GX_FALSE);
|
||||||
|
|
||||||
|
VIDEO_SetPostRetraceCallback(_retraceCallback);
|
||||||
|
|
||||||
font = GUIFontCreate();
|
font = GUIFontCreate();
|
||||||
|
|
||||||
fatInitDefault();
|
fatInitDefault();
|
||||||
|
@ -199,7 +206,13 @@ static void _audioDMA(void) {
|
||||||
}
|
}
|
||||||
|
|
||||||
static void _drawStart(void) {
|
static void _drawStart(void) {
|
||||||
|
u32 level = 0;
|
||||||
|
_CPU_ISR_Disable(level);
|
||||||
|
if (referenceRetraceCount >= retraceCount) {
|
||||||
VIDEO_WaitVSync();
|
VIDEO_WaitVSync();
|
||||||
|
}
|
||||||
|
_CPU_ISR_Restore(level);
|
||||||
|
|
||||||
GX_SetZMode(GX_TRUE, GX_LEQUAL, GX_TRUE);
|
GX_SetZMode(GX_TRUE, GX_LEQUAL, GX_TRUE);
|
||||||
GX_SetColorUpdate(GX_TRUE);
|
GX_SetColorUpdate(GX_TRUE);
|
||||||
|
|
||||||
|
@ -214,6 +227,11 @@ static void _drawEnd(void) {
|
||||||
GX_CopyDisp(framebuffer[whichFb], GX_TRUE);
|
GX_CopyDisp(framebuffer[whichFb], GX_TRUE);
|
||||||
VIDEO_SetNextFramebuffer(framebuffer[whichFb]);
|
VIDEO_SetNextFramebuffer(framebuffer[whichFb]);
|
||||||
VIDEO_Flush();
|
VIDEO_Flush();
|
||||||
|
|
||||||
|
u32 level = 0;
|
||||||
|
_CPU_ISR_Disable(level);
|
||||||
|
++referenceRetraceCount;
|
||||||
|
_CPU_ISR_Restore(level);
|
||||||
}
|
}
|
||||||
|
|
||||||
static uint32_t _pollInput(void) {
|
static uint32_t _pollInput(void) {
|
||||||
|
@ -337,6 +355,10 @@ void _gameLoaded(struct GBAGUIRunner* runner) {
|
||||||
sleep(1);
|
sleep(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
u32 level = 0;
|
||||||
|
_CPU_ISR_Disable(level);
|
||||||
|
referenceRetraceCount = retraceCount;
|
||||||
|
_CPU_ISR_Restore(level);
|
||||||
}
|
}
|
||||||
|
|
||||||
void _drawFrame(struct GBAGUIRunner* runner, bool faded) {
|
void _drawFrame(struct GBAGUIRunner* runner, bool faded) {
|
||||||
|
@ -589,3 +611,10 @@ static s8 WPAD_StickY(u8 chan, u8 right) {
|
||||||
|
|
||||||
return (s8)(val * 128.0f);
|
return (s8)(val * 128.0f);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void _retraceCallback(u32 count) {
|
||||||
|
u32 level = 0;
|
||||||
|
_CPU_ISR_Disable(level);
|
||||||
|
retraceCount = count;
|
||||||
|
_CPU_ISR_Restore(level);
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue