fixes glitches where some "noise" / "sprites" get displayed...

This commit is contained in:
damdoum 2007-01-19 23:14:47 +00:00
parent 6708d5d62c
commit dfb56b1662
2 changed files with 10 additions and 33 deletions

View File

@ -131,33 +131,21 @@ void GPU_DeInit(GPU * gpu)
void GPU_resortBGs(GPU *gpu) void GPU_resortBGs(GPU *gpu)
{ {
u16 WinBG=0;
u8 i, j, prio; u8 i, j, prio;
struct _DISPCNT * cnt = &gpu->dispCnt.bits; struct _DISPCNT * cnt = &gpu->dispCnt.bits;
itemsForPriority_t * item; itemsForPriority_t * item;
if (cnt->Win0_Enable || cnt->Win1_Enable || cnt->WinOBJ_Enable) {
if (cnt->Win0_Enable) WinBG |= gpu->WINDOW_INCNT.bytes.low;
if (cnt->Win1_Enable) WinBG |= gpu->WINDOW_INCNT.bytes.high;
if (cnt->WinOBJ_Enable) WinBG |= gpu->WINDOW_OUTCNT.bytes.high;
WinBG |= gpu->WINDOW_OUTCNT.bytes.low;
} else {
WinBG = 0x1F;
}
for (i=0; i<192; i++) for (i=0; i<192; i++)
memset(gpu->sprWin[i],0, 256); memset(gpu->sprWin[i],0, 256);
#define OP ||
// Let's prepare the field for WINDOWS implementation // we don't need to check for windows here...
gpu->LayersEnable[0] = gpu->dispBG[0] && (cnt->BG0_Enable OP (WinBG & 0x1)) && !(gpu->dispCnt.bits.BG0_3D && (gpu->core==0)) ; gpu->LayersEnable[0] = gpu->dispBG[0] && cnt->BG0_Enable && !(gpu->dispCnt.bits.BG0_3D && (gpu->core==0)) ;
gpu->LayersEnable[1] = gpu->dispBG[1] && (cnt->BG1_Enable OP (WinBG & 0x2)); gpu->LayersEnable[1] = gpu->dispBG[1] && cnt->BG1_Enable;
gpu->LayersEnable[2] = gpu->dispBG[2] && (cnt->BG2_Enable OP (WinBG & 0x4)); gpu->LayersEnable[2] = gpu->dispBG[2] && cnt->BG2_Enable;
gpu->LayersEnable[3] = gpu->dispBG[3] && (cnt->BG3_Enable OP (WinBG & 0x8)); gpu->LayersEnable[3] = gpu->dispBG[3] && cnt->BG3_Enable;
// sprite doesn't need obj window to be displayed !
gpu->LayersEnable[4] = gpu->dispOBJ && cnt->OBJ_Enable; gpu->LayersEnable[4] = gpu->dispOBJ && cnt->OBJ_Enable;
// KISS ! lower priority first, if same then lower num // KISS ! lower priority first, if same then lower num
for (i=0;i<NB_PRIORITIES;i++) { for (i=0;i<NB_PRIORITIES;i++) {
item = &(gpu->itemsForPriority[i]); item = &(gpu->itemsForPriority[i]);
item->nbBGs=0; item->nbBGs=0;
@ -172,7 +160,6 @@ void GPU_resortBGs(GPU *gpu)
item->nbBGs++; item->nbBGs++;
j++; j++;
} }
gpu->nbBGActif = j;
#if 0 #if 0
//debug //debug
@ -221,7 +208,6 @@ void GPU_setVideoProp(GPU * gpu, u32 p)
return; return;
} }
gpu->nbBGActif = 0;
if(cnt->OBJ_Tile_1D) if(cnt->OBJ_Tile_1D)
{ {
/* 1-d sprite mapping */ /* 1-d sprite mapping */
@ -255,17 +241,6 @@ void GPU_setVideoProp(GPU * gpu, u32 p)
GPU_setBGProp(gpu, 0, T1ReadWord(ARM9Mem.ARM9_REG, gpu->core * ADDRESS_STEP_4KB + 8)); GPU_setBGProp(gpu, 0, T1ReadWord(ARM9Mem.ARM9_REG, gpu->core * ADDRESS_STEP_4KB + 8));
GPU_resortBGs(gpu); GPU_resortBGs(gpu);
/* FIXME: this debug won't work, obviously ... */
#ifdef DEBUG_TRI
log::ajouter("------------------");
for(u8 i = 0; i < gpu->nbBGActif; ++i)
{
sprintf(logbuf, "bg %d prio %d", gpu->ordre[i], gpu->bgCnt[gpu->ordre[i]].bits.Priority);
log::ajouter(logbuf);
}
log::ajouter("_________________");
#endif
} }
/* this is writing in BGxCNT */ /* this is writing in BGxCNT */

View File

@ -366,10 +366,12 @@ struct _GPU
u8 dispMode; u8 dispMode;
u8 vramBlock; u8 vramBlock;
u8 nbBGActif; // these two are going to be deleted (use itemsForPriority instead...)
u8 BGIndex[4]; u8 BGIndex[4];
u8 ordre[4]; u8 ordre[4];
BOOL dispBG[4]; BOOL dispBG[4];
BOOL dispOBJ; BOOL dispOBJ;