aboutsummaryrefslogtreecommitdiff
path: root/GPU.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'GPU.cpp')
-rw-r--r--GPU.cpp52
1 files changed, 34 insertions, 18 deletions
diff --git a/GPU.cpp b/GPU.cpp
index c1d9de0..9222ce3 100644
--- a/GPU.cpp
+++ b/GPU.cpp
@@ -56,6 +56,11 @@ u8* VRAM_BOBJ[128];
u8* VRAM_LCD[128];
u8* VRAM_ARM7[2];
+u8* VRAM_ABGExtPal[4];
+u8* VRAM_AOBJExtPal;
+u8* VRAM_BBGExtPal[4];
+u8* VRAM_BOBJExtPal;
+
u16 Framebuffer[256*192*2];
GPU2D* GPU2D_A;
@@ -100,6 +105,11 @@ void Reset()
memset(VRAM_LCD, 0, sizeof(u8*)*128);
memset(VRAM_ARM7, 0, sizeof(u8*)*2);
+ memset(VRAM_ABGExtPal, 0, sizeof(u8*)*4);
+ VRAM_AOBJExtPal = NULL;
+ memset(VRAM_BBGExtPal, 0, sizeof(u8*)*4);
+ VRAM_BOBJExtPal = NULL;
+
for (int i = 0; i < 256*192*2; i++)
{
Framebuffer[i] = 0x7FFF;
@@ -370,11 +380,10 @@ void MapVRAM_E(u32 bank, u8 cnt)
break;
case 4:
- // BG EXTPAL -- TODO
- break;
-
- case 5:
- // OBJ EXTPAL -- TODO
+ VRAM_ABGExtPal[0] = NULL;
+ VRAM_ABGExtPal[1] = NULL;
+ VRAM_ABGExtPal[2] = NULL;
+ VRAM_ABGExtPal[3] = NULL;
break;
}
@@ -421,11 +430,10 @@ void MapVRAM_E(u32 bank, u8 cnt)
break;
case 4:
- // BG EXTPAL -- TODO
- break;
-
- case 5:
- // OBJ EXTPAL -- TODO
+ VRAM_ABGExtPal[0] = &vram[0x0000];
+ VRAM_ABGExtPal[1] = &vram[0x2000];
+ VRAM_ABGExtPal[2] = &vram[0x4000];
+ VRAM_ABGExtPal[3] = &vram[0x6000];
break;
}
@@ -479,11 +487,12 @@ void MapVRAM_FG(u32 bank, u8 cnt)
break;
case 4:
- // BG EXTPAL TODO
+ VRAM_ABGExtPal[(oldofs<<1)+0] = NULL;
+ VRAM_ABGExtPal[(oldofs<<1)+1] = NULL;
break;
case 5:
- // OBJ EXTPAL TODO
+ VRAM_AOBJExtPal = NULL;
break;
}
@@ -523,11 +532,12 @@ void MapVRAM_FG(u32 bank, u8 cnt)
break;
case 4:
- // BG EXTPAL TODO
+ VRAM_ABGExtPal[(ofs<<1)+0] = &vram[0x0000];
+ VRAM_ABGExtPal[(ofs<<1)+1] = &vram[0x2000];
break;
case 5:
- // OBJ EXTPAL TODO
+ VRAM_AOBJExtPal = vram;
break;
}
@@ -573,7 +583,10 @@ void MapVRAM_H(u32 bank, u8 cnt)
break;
case 2:
- // BG EXTPAL TODO
+ VRAM_BBGExtPal[0] = NULL;
+ VRAM_BBGExtPal[1] = NULL;
+ VRAM_BBGExtPal[2] = NULL;
+ VRAM_BBGExtPal[3] = NULL;
break;
}
@@ -615,7 +628,10 @@ void MapVRAM_H(u32 bank, u8 cnt)
break;
case 2:
- // BG EXTPAL TODO
+ VRAM_BBGExtPal[0] = &vram[0x0000];
+ VRAM_BBGExtPal[1] = &vram[0x2000];
+ VRAM_BBGExtPal[2] = &vram[0x4000];
+ VRAM_BBGExtPal[3] = &vram[0x6000];
break;
}
@@ -665,7 +681,7 @@ void MapVRAM_I(u32 bank, u8 cnt)
break;
case 3:
- // not mapped to memory
+ VRAM_BOBJExtPal = NULL;
break;
}
@@ -701,7 +717,7 @@ void MapVRAM_I(u32 bank, u8 cnt)
break;
case 3:
- // not mapped to memory
+ VRAM_BOBJExtPal = vram;
break;
}