change the 3d frameskipping method to take advantage of the rendering deferral system which was already there. now, whenever a 3d frame is requested, and it isnt rendered due to having been skipped, it has the capability to render itsself. This should resolve any issues like ideas frameskip synchronization -- let me know.
This commit is contained in:
parent
a077ddf472
commit
b231f48093
|
@ -687,7 +687,7 @@ static void Control()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void OGLRender(bool skipdraw)
|
static void OGLRender()
|
||||||
{
|
{
|
||||||
if(!BEGINGL()) return;
|
if(!BEGINGL()) return;
|
||||||
|
|
||||||
|
|
|
@ -1374,12 +1374,15 @@ void gfx3d_VBlankSignal()
|
||||||
drawPending = TRUE;
|
drawPending = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void gfx3d_VBlankEndSignal(bool skipdraw)
|
void gfx3d_VBlankEndSignal(bool skipFrame)
|
||||||
{
|
{
|
||||||
|
//if we are skipping 3d frames then the 3d rendering will get held up here.
|
||||||
|
//but, as soon as we quit skipping frames, the held-up 3d frame will render
|
||||||
|
if(skipFrame) return;
|
||||||
if(!drawPending) return;
|
if(!drawPending) return;
|
||||||
|
|
||||||
drawPending = FALSE;
|
drawPending = FALSE;
|
||||||
gpu3D->NDS_3D_Render(skipdraw);
|
gpu3D->NDS_3D_Render();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef USE_GEOMETRY_FIFO_EMULATION
|
#ifdef USE_GEOMETRY_FIFO_EMULATION
|
||||||
|
|
|
@ -237,7 +237,7 @@ unsigned int gfx3d_glGetPosRes(unsigned int index);
|
||||||
unsigned short gfx3d_glGetVecRes(unsigned int index);
|
unsigned short gfx3d_glGetVecRes(unsigned int index);
|
||||||
void gfx3d_glFlush(unsigned long v);
|
void gfx3d_glFlush(unsigned long v);
|
||||||
void gfx3d_VBlankSignal();
|
void gfx3d_VBlankSignal();
|
||||||
void gfx3d_VBlankEndSignal(bool skipdraw);
|
void gfx3d_VBlankEndSignal(bool skipFrame);
|
||||||
void gfx3d_Control(unsigned long v);
|
void gfx3d_Control(unsigned long v);
|
||||||
u32 gfx3d_GetGXstatus();
|
u32 gfx3d_GetGXstatus();
|
||||||
void gfx3d_sendCommandToFIFO(u32 val);
|
void gfx3d_sendCommandToFIFO(u32 val);
|
||||||
|
|
|
@ -1145,11 +1145,8 @@ static void clipPoly(POLY* poly)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void SoftRastRender(bool skipdraw)
|
static void SoftRastRender()
|
||||||
{
|
{
|
||||||
if(skipdraw)
|
|
||||||
return;
|
|
||||||
|
|
||||||
Fragment clearFragment;
|
Fragment clearFragment;
|
||||||
clearFragment.color.components.r = gfx3d.clearColor&0x1F;
|
clearFragment.color.components.r = gfx3d.clearColor&0x1F;
|
||||||
clearFragment.color.components.g = (gfx3d.clearColor>>5)&0x1F;
|
clearFragment.color.components.g = (gfx3d.clearColor>>5)&0x1F;
|
||||||
|
|
|
@ -26,14 +26,13 @@ static void NDS_nullFunc1 (void){}
|
||||||
static char NDS_nullFunc2 (void){ return 1; }
|
static char NDS_nullFunc2 (void){ return 1; }
|
||||||
static void NDS_nullFunc3 (int,unsigned short*) {}
|
static void NDS_nullFunc3 (int,unsigned short*) {}
|
||||||
static void NDS_nullFunc4 (int,unsigned short*,unsigned char*) {}
|
static void NDS_nullFunc4 (int,unsigned short*,unsigned char*) {}
|
||||||
static void NDS_nullFunc5 (bool){}
|
|
||||||
|
|
||||||
GPU3DInterface gpu3DNull = {
|
GPU3DInterface gpu3DNull = {
|
||||||
"None",
|
"None",
|
||||||
NDS_nullFunc2, //NDS_3D_Init
|
NDS_nullFunc2, //NDS_3D_Init
|
||||||
NDS_nullFunc1, //NDS_3D_Reset
|
NDS_nullFunc1, //NDS_3D_Reset
|
||||||
NDS_nullFunc1, //NDS_3D_Close
|
NDS_nullFunc1, //NDS_3D_Close
|
||||||
NDS_nullFunc5, //NDS_3D_Render
|
NDS_nullFunc1, //NDS_3D_Render
|
||||||
NDS_nullFunc1, //NDS_3D_VramReconfigureSignal
|
NDS_nullFunc1, //NDS_3D_VramReconfigureSignal
|
||||||
NDS_nullFunc4, //NDS_3D_GetLine
|
NDS_nullFunc4, //NDS_3D_GetLine
|
||||||
NDS_nullFunc3 //NDS_3D_GetLineCaptured
|
NDS_nullFunc3 //NDS_3D_GetLineCaptured
|
||||||
|
|
|
@ -39,7 +39,7 @@ typedef struct Render3DInterface
|
||||||
void (CALL_CONVENTION* NDS_3D_Close) (void);
|
void (CALL_CONVENTION* NDS_3D_Close) (void);
|
||||||
|
|
||||||
//called when the renderer should do its job and render the current display lists
|
//called when the renderer should do its job and render the current display lists
|
||||||
void (CALL_CONVENTION* NDS_3D_Render) (bool skipdraw);
|
void (CALL_CONVENTION* NDS_3D_Render) (void);
|
||||||
|
|
||||||
//called when the emulator reconfigures its vram. you may need to invalidate your texture cache.
|
//called when the emulator reconfigures its vram. you may need to invalidate your texture cache.
|
||||||
void (CALL_CONVENTION* NDS_3D_VramReconfigureSignal) ();
|
void (CALL_CONVENTION* NDS_3D_VramReconfigureSignal) ();
|
||||||
|
|
Loading…
Reference in New Issue