gpu: fix 256B granularity sprite addressing for sub gpu (fixes pinball deluxe)
This commit is contained in:
parent
048d2318a0
commit
875d4ae2a6
|
@ -773,8 +773,9 @@ void GPU_setVideoProp(GPU * gpu, u32 p)
|
||||||
// core B : 32k, 64k, 128k, 128k
|
// core B : 32k, 64k, 128k, 128k
|
||||||
gpu->sprBoundary = 5 + cnt->OBJ_Tile_1D_Bound ;
|
gpu->sprBoundary = 5 + cnt->OBJ_Tile_1D_Bound ;
|
||||||
|
|
||||||
//zero 10-apr-09 - not sure whether this is right...
|
//do not be deceived: even though a sprBoundary==8 (256KB region) is impossible to fully address
|
||||||
if((gpu->core == GPU_SUB) && (cnt->OBJ_Tile_1D_Bound == 3)) gpu->sprBoundary = 7;
|
//in GPU_SUB, it is still fully legal to address it with that granularity.
|
||||||
|
//so don't do this: //if((gpu->core == GPU_SUB) && (cnt->OBJ_Tile_1D_Bound == 3)) gpu->sprBoundary = 7;
|
||||||
|
|
||||||
gpu->spriteRenderMode = GPU::SPRITE_1D;
|
gpu->spriteRenderMode = GPU::SPRITE_1D;
|
||||||
} else {
|
} else {
|
||||||
|
@ -1932,10 +1933,7 @@ void GPU::_spriteRender(u8 * dst, u8 * dst_alpha, u8 * typeTab, u8 * prioTab)
|
||||||
if(spriteInfo->Depth)
|
if(spriteInfo->Depth)
|
||||||
{
|
{
|
||||||
//2d: src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + ((spriteInfo->TileIndex) << 5));
|
//2d: src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + ((spriteInfo->TileIndex) << 5));
|
||||||
src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + (spriteInfo->TileIndex << block));
|
src = (u8 *)MMU_gpu_map(gpu->sprMem + (spriteInfo->TileIndex << block));
|
||||||
if (!src) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
// If extended palettes are set, use them
|
// If extended palettes are set, use them
|
||||||
if (dispCnt->ExOBJPalette_Enable)
|
if (dispCnt->ExOBJPalette_Enable)
|
||||||
|
@ -1979,14 +1977,10 @@ void GPU::_spriteRender(u8 * dst, u8 * dst_alpha, u8 * typeTab, u8 * prioTab)
|
||||||
else if(spriteInfo->Mode == 3)
|
else if(spriteInfo->Mode == 3)
|
||||||
{
|
{
|
||||||
if (dispCnt->OBJ_BMP_mapping)
|
if (dispCnt->OBJ_BMP_mapping)
|
||||||
src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + (spriteInfo->TileIndex<<sprBMPBoundary));
|
src = (u8 *)MMU_gpu_map(gpu->sprMem + (spriteInfo->TileIndex<<sprBMPBoundary));
|
||||||
else
|
else
|
||||||
//NOT TESTED
|
//NOT TESTED
|
||||||
src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + (((spriteInfo->TileIndex&0x03E0) * 8) + (spriteInfo->TileIndex&0x001F))*16);
|
src = (u8 *)MMU_gpu_map(gpu->sprMem + (((spriteInfo->TileIndex&0x03E0) * 8) + (spriteInfo->TileIndex&0x001F))*16);
|
||||||
|
|
||||||
if (!src) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
for(j = 0; j < lg; ++j, ++sprX)
|
for(j = 0; j < lg; ++j, ++sprX)
|
||||||
{
|
{
|
||||||
|
@ -2024,19 +2018,15 @@ void GPU::_spriteRender(u8 * dst, u8 * dst_alpha, u8 * typeTab, u8 * prioTab)
|
||||||
{
|
{
|
||||||
if(MODE == SPRITE_2D)
|
if(MODE == SPRITE_2D)
|
||||||
{
|
{
|
||||||
src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + (spriteInfo->TileIndex<<5));
|
src = (u8 *)MMU_gpu_map(gpu->sprMem + (spriteInfo->TileIndex<<5));
|
||||||
pal = ARM9Mem.ARM9_VMEM + 0x200 + (gpu->core*0x400 + (spriteInfo->PaletteIndex*32));
|
pal = ARM9Mem.ARM9_VMEM + 0x200 + (gpu->core*0x400 + (spriteInfo->PaletteIndex*32));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + (spriteInfo->TileIndex<<gpu->sprBoundary));
|
src = (u8 *)MMU_gpu_map(gpu->sprMem + (spriteInfo->TileIndex<<gpu->sprBoundary));
|
||||||
pal = ARM9Mem.ARM9_VMEM + 0x200 + gpu->core*0x400 + (spriteInfo->PaletteIndex*32);
|
pal = ARM9Mem.ARM9_VMEM + 0x200 + gpu->core*0x400 + (spriteInfo->PaletteIndex*32);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!src) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
for(j = 0; j < lg; ++j, ++sprX)
|
for(j = 0; j < lg; ++j, ++sprX)
|
||||||
{
|
{
|
||||||
// Get the integer part of the fixed point 8.8, and check if it lies inside the sprite data
|
// Get the integer part of the fixed point 8.8, and check if it lies inside the sprite data
|
||||||
|
@ -2087,9 +2077,9 @@ void GPU::_spriteRender(u8 * dst, u8 * dst_alpha, u8 * typeTab, u8 * prioTab)
|
||||||
if(MODE == SPRITE_2D)
|
if(MODE == SPRITE_2D)
|
||||||
{
|
{
|
||||||
if (spriteInfo->Depth)
|
if (spriteInfo->Depth)
|
||||||
src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + ((spriteInfo->TileIndex)<<5) + ((y>>3)<<10) + ((y&0x7)*8));
|
src = (u8 *)MMU_gpu_map(gpu->sprMem + ((spriteInfo->TileIndex)<<5) + ((y>>3)<<10) + ((y&0x7)*8));
|
||||||
else
|
else
|
||||||
src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + ((spriteInfo->TileIndex)<<5) + ((y>>3)<<10) + ((y&0x7)*4));
|
src = (u8 *)MMU_gpu_map(gpu->sprMem + ((spriteInfo->TileIndex)<<5) + ((y>>3)<<10) + ((y&0x7)*4));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -2098,9 +2088,6 @@ void GPU::_spriteRender(u8 * dst, u8 * dst_alpha, u8 * typeTab, u8 * prioTab)
|
||||||
else
|
else
|
||||||
src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + (spriteInfo->TileIndex<<block) + ((y>>3)*sprSize.x*4) + ((y&0x7)*4));
|
src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + (spriteInfo->TileIndex<<block) + ((y>>3)*sprSize.x*4) + ((y&0x7)*4));
|
||||||
}
|
}
|
||||||
if (!src) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
render_sprite_Win (gpu, l, src, spriteInfo->Depth, lg, sprX, x, xdir);
|
render_sprite_Win (gpu, l, src, spriteInfo->Depth, lg, sprX, x, xdir);
|
||||||
continue;
|
continue;
|
||||||
|
@ -2116,7 +2103,7 @@ void GPU::_spriteRender(u8 * dst, u8 * dst_alpha, u8 * typeTab, u8 * prioTab)
|
||||||
if (dispCnt->OBJ_BMP_mapping)
|
if (dispCnt->OBJ_BMP_mapping)
|
||||||
{
|
{
|
||||||
//tested by buffy sacrifice damage blood splatters in corner
|
//tested by buffy sacrifice damage blood splatters in corner
|
||||||
src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + (spriteInfo->TileIndex<<sprBMPBoundary) + (y*sprSize.x*2));
|
src = (u8 *)MMU_gpu_map(gpu->sprMem + (spriteInfo->TileIndex<<sprBMPBoundary) + (y*sprSize.x*2));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -2124,14 +2111,10 @@ void GPU::_spriteRender(u8 * dst, u8 * dst_alpha, u8 * typeTab, u8 * prioTab)
|
||||||
|
|
||||||
if (dispCnt->OBJ_BMP_2D_dim)
|
if (dispCnt->OBJ_BMP_2D_dim)
|
||||||
//256*256, verified by heroes of mana FMV intro
|
//256*256, verified by heroes of mana FMV intro
|
||||||
src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + (((spriteInfo->TileIndex&0x3E0) * 64 + (spriteInfo->TileIndex&0x1F) *8 + ( y << 8)) << 1));
|
src = (u8 *)MMU_gpu_map(gpu->sprMem + (((spriteInfo->TileIndex&0x3E0) * 64 + (spriteInfo->TileIndex&0x1F) *8 + ( y << 8)) << 1));
|
||||||
else
|
else
|
||||||
//128*512, verified by harry potter and the order of the phoenix conversation portraits
|
//128*512, verified by harry potter and the order of the phoenix conversation portraits
|
||||||
src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + (((spriteInfo->TileIndex&0x3F0) * 64 + (spriteInfo->TileIndex&0x0F) *8 + ( y << 7)) << 1));
|
src = (u8 *)MMU_gpu_map(gpu->sprMem + (((spriteInfo->TileIndex&0x3F0) * 64 + (spriteInfo->TileIndex&0x0F) *8 + ( y << 7)) << 1));
|
||||||
}
|
|
||||||
|
|
||||||
if (!src) {
|
|
||||||
continue;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
render_sprite_BMP (gpu, i, l, dst, (u16*)src, dst_alpha, typeTab, prioTab, prio, lg, sprX, x, xdir, spriteInfo->PaletteIndex);
|
render_sprite_BMP (gpu, i, l, dst, (u16*)src, dst_alpha, typeTab, prioTab, prio, lg, sprX, x, xdir, spriteInfo->PaletteIndex);
|
||||||
|
@ -2141,13 +2124,9 @@ void GPU::_spriteRender(u8 * dst, u8 * dst_alpha, u8 * typeTab, u8 * prioTab)
|
||||||
if(spriteInfo->Depth) /* 256 colors */
|
if(spriteInfo->Depth) /* 256 colors */
|
||||||
{
|
{
|
||||||
if(MODE == SPRITE_2D)
|
if(MODE == SPRITE_2D)
|
||||||
src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + ((spriteInfo->TileIndex)<<5) + ((y>>3)<<10) + ((y&0x7)*8));
|
src = (u8 *)MMU_gpu_map(gpu->sprMem + ((spriteInfo->TileIndex)<<5) + ((y>>3)<<10) + ((y&0x7)*8));
|
||||||
else
|
else
|
||||||
src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + (spriteInfo->TileIndex<<block) + ((y>>3)*sprSize.x*8) + ((y&0x7)*8));
|
src = (u8 *)MMU_gpu_map(gpu->sprMem + (spriteInfo->TileIndex<<block) + ((y>>3)*sprSize.x*8) + ((y&0x7)*8));
|
||||||
|
|
||||||
if (!src) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (dispCnt->ExOBJPalette_Enable)
|
if (dispCnt->ExOBJPalette_Enable)
|
||||||
pal = (u16*)(ARM9Mem.ObjExtPal[gpu->core][0]+(spriteInfo->PaletteIndex*0x200));
|
pal = (u16*)(ARM9Mem.ObjExtPal[gpu->core][0]+(spriteInfo->PaletteIndex*0x200));
|
||||||
|
@ -2162,15 +2141,11 @@ void GPU::_spriteRender(u8 * dst, u8 * dst_alpha, u8 * typeTab, u8 * prioTab)
|
||||||
// 16 colors
|
// 16 colors
|
||||||
if(MODE == SPRITE_2D)
|
if(MODE == SPRITE_2D)
|
||||||
{
|
{
|
||||||
src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + ((spriteInfo->TileIndex)<<5) + ((y>>3)<<10) + ((y&0x7)*4));
|
src = (u8 *)MMU_gpu_map(gpu->sprMem + ((spriteInfo->TileIndex)<<5) + ((y>>3)<<10) + ((y&0x7)*4));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
src = (u8 *)MMU_RenderMapToLCD(gpu->sprMem + (spriteInfo->TileIndex<<block) + ((y>>3)*sprSize.x*4) + ((y&0x7)*4));
|
src = (u8 *)MMU_gpu_map(gpu->sprMem + (spriteInfo->TileIndex<<block) + ((y>>3)*sprSize.x*4) + ((y&0x7)*4));
|
||||||
}
|
|
||||||
|
|
||||||
if (!src) {
|
|
||||||
continue;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pal = (u16*)(ARM9Mem.ARM9_VMEM + 0x200 + gpu->core * 0x400);
|
pal = (u16*)(ARM9Mem.ARM9_VMEM + 0x200 + gpu->core * 0x400);
|
||||||
|
|
Loading…
Reference in New Issue