From 9c71c153a7456e68399a94c5f2e89bb0f6366fd3 Mon Sep 17 00:00:00 2001 From: yabause Date: Tue, 21 Nov 2006 23:01:35 +0000 Subject: [PATCH] Added T2Memory functions and used them to rewrite GPU_screen accesses, it should fix some more endianess bugs. Not all accesses have been rewritten yet. It shouldn't have broke anything... --- desmume/src/GPU.c | 168 ++++++++++++++++++------------------------- desmume/src/GPU.h | 40 ++++++----- desmume/src/cflash.c | 3 +- desmume/src/mem.h | 49 +++++++++++++ 4 files changed, 141 insertions(+), 119 deletions(-) diff --git a/desmume/src/GPU.c b/desmume/src/GPU.c index 0a3539411..498dfbf15 100644 --- a/desmume/src/GPU.c +++ b/desmume/src/GPU.c @@ -66,11 +66,11 @@ s8 mode2type[8][4] = {0, 0, 0, 0} }; -void lineText(GPU * gpu, u8 num, u16 l, u16 * DST); -void lineRot(GPU * gpu, u8 num, u16 l, u16 * DST); -void lineExtRot(GPU * gpu, u8 num, u16 l, u16 * DST); +void lineText(GPU * gpu, u8 num, u16 l, u8 * DST); +void lineRot(GPU * gpu, u8 num, u16 l, u8 * DST); +void lineExtRot(GPU * gpu, u8 num, u16 l, u8 * DST); -void (*modeRender[8][4])(GPU * gpu, u8 num, u16 l, u16 * DST)= +void (*modeRender[8][4])(GPU * gpu, u8 num, u16 l, u8 * DST)= { {lineText, lineText, lineText, lineText}, //0 {lineText, lineText, lineText, lineRot}, //1 @@ -526,14 +526,14 @@ void GPU_setPCPD(GPU * gpu, u8 num, u32 v) gpu->BGPD[num] = (s16)(v>>16); } -INLINE void renderline_textBG(GPU * gpu, u8 num, u16 * DST, u16 X, u16 Y, u16 LG) +INLINE void renderline_textBG(GPU * gpu, u8 num, u8 * DST, u16 X, u16 Y, u16 LG) { u32 bgprop = gpu->BGProp[num]; u16 lg = gpu->BGSize[num][0]; u16 ht = gpu->BGSize[num][1]; u16 tmp = ((Y&(ht-1))>>3); u8 * map = gpu->BG_map_ram[num] + (tmp&31) * 64; - u16 *dst = DST; + u8 *dst = DST; if(tmp>31) { @@ -580,12 +580,10 @@ INLINE void renderline_textBG(GPU * gpu, u8 num, u16 * DST, u16 X, u16 Y, u16 LG line += 3 - ((xoff&7)>>1); for(; x < xfin; ) { - if((*line)>>4) *dst = T1ReadWord(pal, (((*line)>>4) + MAP_ENTRY_PALETTE_MASK(mapinfovalue) * 0x10) << 1); - //else *dst = 0x7FFF; - dst++; x++; xoff++; - if((*line)&0xF) *dst = T1ReadWord(pal, (((*line)&0xF) + MAP_ENTRY_PALETTE_MASK(mapinfovalue) * 0x10) << 1); - //else *dst = 0x7FFF; - dst++; x++; xoff++; + if((*line)>>4) T2WriteWord(dst, 0, T1ReadWord(pal, (((*line)>>4) + MAP_ENTRY_PALETTE_MASK(mapinfovalue) * 0x10) << 1)); + dst += 2; x++; xoff++; + if((*line)&0xF) T2WriteWord(dst, 0, T1ReadWord(pal, (((*line)&0xF) + MAP_ENTRY_PALETTE_MASK(mapinfovalue) * 0x10) << 1)); + dst += 2; x++; xoff++; line--; } } @@ -594,12 +592,10 @@ INLINE void renderline_textBG(GPU * gpu, u8 num, u16 * DST, u16 X, u16 Y, u16 LG line += ((xoff&7)>>1); for(; x < xfin; ) { - if((*line)&0xF) *dst = T1ReadWord(pal, (((*line)&0xF) + MAP_ENTRY_PALETTE_MASK(mapinfovalue) * 0x10) << 1); - //else *dst = 0x7FFF; - dst++; x++; xoff++; - if((*line)>>4) *dst = T1ReadWord(pal, (((*line)>>4) + MAP_ENTRY_PALETTE_MASK(mapinfovalue) * 0x10) << 1); - //else *dst = 0x7FFF; - dst++; x++; xoff++; + if((*line)&0xF) T2WriteWord(dst, 0, T1ReadWord(pal, (((*line)&0xF) + MAP_ENTRY_PALETTE_MASK(mapinfovalue) * 0x10) << 1)); + dst += 2; x++; xoff++; + if((*line)>>4) T2WriteWord(dst, 0, T1ReadWord(pal, (((*line)>>4) + MAP_ENTRY_PALETTE_MASK(mapinfovalue) * 0x10) << 1)); + dst += 2; x++; xoff++; line++; } } @@ -633,9 +629,8 @@ INLINE void renderline_textBG(GPU * gpu, u8 num, u16 * DST, u16 X, u16 Y, u16 LG line += (7 - (xoff&7)); for(; x < xfin; ++x, ++xoff) { - if(*line) *dst = T1ReadWord(pal, *line << 1); - //else *dst = 0x7FFF; - dst++; + if(*line) T2WriteWord(dst, 0, T1ReadWord(pal, *line << 1)); + dst += 2; line--; } } @@ -644,9 +639,8 @@ INLINE void renderline_textBG(GPU * gpu, u8 num, u16 * DST, u16 X, u16 Y, u16 LG line += (xoff&7); for(; x < xfin; ++x, ++xoff) { - if(*line) *dst = T1ReadWord(pal, *line << 1); - //else *dst = 0x7FFF; - dst++; + if(*line) T2WriteWord(dst, 0, T1ReadWord(pal, *line << 1)); + dst += 2; line++; } } @@ -681,9 +675,8 @@ INLINE void renderline_textBG(GPU * gpu, u8 num, u16 * DST, u16 X, u16 Y, u16 LG line += (7 - (xoff&7)); for(; x < xfin; ++x, ++xoff) { - if(*line) *dst = T1ReadWord(pal, (*line + ((mapinfovalue>>12)&0xF)*0x100) << 1); - //else *dst = 0x7FFF; - dst++; + if(*line) T2WriteWord(dst, 0, T1ReadWord(pal, (*line + ((mapinfovalue>>12)&0xF)*0x100) << 1)); + dst += 2; line--; } } @@ -692,16 +685,15 @@ INLINE void renderline_textBG(GPU * gpu, u8 num, u16 * DST, u16 X, u16 Y, u16 LG line += (xoff&7); for(; x < xfin; ++x, ++xoff) { - if(*line) *dst = T1ReadWord(pal, (*line + ((mapinfovalue>>12)&0xF)*0x100) << 1); - //else *dst = 0x7FFF; - dst++; + if(*line) T2WriteWord(dst, 0, T1ReadWord(pal, (*line + ((mapinfovalue>>12)&0xF)*0x100) << 1)); + dst += 2; line++; } } } } -INLINE void rotBG2(GPU * gpu, u8 num, u16 * DST, u16 H, s32 X, s32 Y, s16 PA, s16 PB, s16 PC, s16 PD, u16 LG) +INLINE void rotBG2(GPU * gpu, u8 num, u8 * DST, u16 H, s32 X, s32 Y, s16 PA, s16 PB, s16 PC, s16 PD, u16 LG) { u32 bgprop = gpu->BGProp[num]; @@ -721,7 +713,7 @@ INLINE void rotBG2(GPU * gpu, u8 num, u16 * DST, u16 H, s32 X, s32 Y, s16 PA, s1 u8 * map = gpu->BG_map_ram[num]; u8 * tile = (u8 *)gpu->BG_tile_ram[num]; - u16 * dst = DST; + u8 * dst = DST; u8 mapinfo; u8 coul; @@ -745,15 +737,15 @@ INLINE void rotBG2(GPU * gpu, u8 num, u16 * DST, u16 H, s32 X, s32 Y, s16 PA, s1 mapinfo = map[(auxX>>3) + ((auxY>>3) * lgmap)]; coul = tile[mapinfo*64 + ((auxY&7)<<3) + (auxX&7)]; if(coul) - *dst = T1ReadWord(pal, coul << 1); + T2WriteWord(dst, 0, T1ReadWord(pal, coul << 1)); } - ++dst; + dst += 2; x += dx; y += dy; } } -INLINE void extRotBG2(GPU * gpu, u8 num, u16 * DST, u16 H, s32 X, s32 Y, s16 PA, s16 PB, s16 PC, s16 PD, s16 LG) +INLINE void extRotBG2(GPU * gpu, u8 num, u8 * DST, u16 H, s32 X, s32 Y, s16 PA, s16 PB, s16 PC, s16 PD, s16 LG) { u32 bgprop = gpu->BGProp[num]; @@ -771,7 +763,7 @@ INLINE void extRotBG2(GPU * gpu, u8 num, u16 * DST, u16 H, s32 X, s32 Y, s16 PA, u16 lgmap = (lg>>3); u8 * tile = (u8 *)gpu->BG_tile_ram[num]; - u16 * dst = DST; + u8 * dst = DST; u16 mapinfo; u8 coul; @@ -803,11 +795,9 @@ INLINE void extRotBG2(GPU * gpu, u8 num, u16 * DST, u16 H, s32 X, s32 Y, s16 PA, u16 y1 = (mapinfo & 0x800) ? 7 - (auxY&7) : (auxY&7); coul = tile[(mapinfo&0x3FF)*64 + x1 + (y1<<3)]; if(coul) - *dst = T1ReadWord(pal, (coul + (mapinfo>>12)*0x100) << 1); - //else *dst = 0x7FFF; + T2WriteWord(dst, 0, T1ReadWord(pal, (coul + (mapinfo>>12)*0x100) << 1)); } - //else *dst = 0x7FFF; - ++dst; + dst += 2; x += dx; y += dy; } @@ -831,11 +821,9 @@ INLINE void extRotBG2(GPU * gpu, u8 num, u16 * DST, u16 H, s32 X, s32 Y, s16 PA, { mapinfo = map[auxX + auxY * lg]; if(mapinfo) - *dst = T1ReadWord(pal, mapinfo << 1); - //else *dst = 0x7FFF; + T2WriteWord(dst, 0, T1ReadWord(pal, mapinfo << 1)); } - //else *dst = 0x7FFF; - ++dst; + dst += 2; x += dx; y += dy; } @@ -858,11 +846,9 @@ INLINE void extRotBG2(GPU * gpu, u8 num, u16 * DST, u16 H, s32 X, s32 Y, s16 PA, { mapinfo = T1ReadWord(map, (auxX + auxY * lg) << 1); if(mapinfo) - *dst = mapinfo; - //else *dst = 0x7FFF; + T2WriteWord(dst, 0, mapinfo); } - //else *dst = 0x7FFF; - ++dst; + dst += 2; x += dx; y += dy; } @@ -871,12 +857,12 @@ INLINE void extRotBG2(GPU * gpu, u8 num, u16 * DST, u16 H, s32 X, s32 Y, s16 PA, } } -void lineText(GPU * gpu, u8 num, u16 l, u16 * DST) +void lineText(GPU * gpu, u8 num, u16 l, u8 * DST) { renderline_textBG(gpu, num, DST, gpu->BGSX[num], l + gpu->BGSY[num], 256); } -void lineRot(GPU * gpu, u8 num, u16 l, u16 * DST) +void lineRot(GPU * gpu, u8 num, u16 l, u8 * DST) { rotBG2(gpu, num, DST, l, gpu->BGX[num], @@ -888,7 +874,7 @@ void lineRot(GPU * gpu, u8 num, u16 l, u16 * DST) 256); } -void lineExtRot(GPU * gpu, u8 num, u16 l, u16 * DST) +void lineExtRot(GPU * gpu, u8 num, u16 l, u8 * DST) { extRotBG2(gpu, num, DST, l, gpu->BGX[num], @@ -900,7 +886,7 @@ void lineExtRot(GPU * gpu, u8 num, u16 l, u16 * DST) 256); } -void textBG(GPU * gpu, u8 num, u16 * DST) +void textBG(GPU * gpu, u8 num, u8 * DST) { u32 i; for(i = 0; i < gpu->BGSize[num][1]; ++i) @@ -909,14 +895,14 @@ void textBG(GPU * gpu, u8 num, u16 * DST) } } -void rotBG(GPU * gpu, u8 num, u16 * DST) +void rotBG(GPU * gpu, u8 num, u8 * DST) { u32 i; for(i = 0; i < gpu->BGSize[num][1]; ++i) rotBG2(gpu, num, DST + i*gpu->BGSize[num][0], i, 0, 0, 256, 0, 0, 256, gpu->BGSize[num][0]); } -void extRotBG(GPU * gpu, u8 num, u16 * DST) +void extRotBG(GPU * gpu, u8 num, u8 * DST) { u32 i; for(i = 0; i < gpu->BGSize[num][1]; ++i) @@ -925,7 +911,7 @@ void extRotBG(GPU * gpu, u8 num, u16 * DST) #define nbShow 128 -void sprite1D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) +void sprite1D(GPU * gpu, u16 l, u8 * dst, u8 * prioTab) { OAM * aux = gpu->oam + (nbShow-1);// + 127; @@ -942,7 +928,7 @@ void sprite1D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) size sprSize = sprSizeTab[(aux->attr1>>14)][(aux->attr0>>14)]; u32 lg = sprSize.x; - + if(sprY>192) sprY = (s32)((s8)(aux->attr0 & 0xFF)); @@ -980,10 +966,9 @@ void sprite1D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) u8 c = src[x]; if((c>>15) && (prioTab[sprX]>=prio)) { - dst[sprX] = c; + T2WriteByte(dst, sprX << 1, c); prioTab[sprX] = prio; } - //else dst[sprX] = 0x7FFF; } continue; } @@ -992,11 +977,10 @@ void sprite1D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) u16 c = T1ReadWord(src, x << 1); if((c>>15) && (prioTab[sprX]>=prio)) { - dst[sprX] = c; + T2WriteWord(dst, sprX << 1, c); prioTab[sprX] = prio; } - //else dst[sprX] = 0x7FFF; - }// + } continue; } @@ -1005,7 +989,7 @@ void sprite1D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) u8 * src = gpu->sprMem + ((aux->attr2&0x3FF)<>3)*sprSize.x*8) + ((y&0x7)*8); u8 * pal; u16 i; - + if(gpu->prop&(1<<31)) pal = ARM9Mem.ObjExtPal[gpu->core][0]+((aux->attr2>>12)*0x200); else @@ -1019,10 +1003,9 @@ void sprite1D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) u8 c = src[(x&0x7) + ((x&0xFFF8)<<3)]; if((c) && (prioTab[sprX]>=prio)) { - dst[sprX] = T1ReadWord(pal, c << 1); + T2WriteWord(dst, sprX << 1, T1ReadWord(pal, c << 1)); prioTab[sprX] = prio; } - //else dst[sprX] = 0x7FFF; } continue; } @@ -1033,10 +1016,9 @@ void sprite1D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) if((c) && (prioTab[sprX]>=prio)) { - dst[sprX] = T1ReadWord(pal, c << 1); + T2WriteWord(dst, sprX << 1, T1ReadWord(pal, c << 1)); prioTab[sprX] = prio; } - //else dst[sprX] = 0x7FFF; } continue; } @@ -1051,14 +1033,14 @@ void sprite1D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) u8 c = src[(x1&0x3) + ((x1&0xFFFC)<<3)]; if((c&0xF)&&(prioTab[sprX]>=prio)) { - dst[sprX] = T1ReadWord(pal, ((c&0xF)+((aux->attr2>>12)*0x10)) << 1); + T2WriteWord(dst, sprX << 1, T1ReadWord(pal, ((c&0xF)+((aux->attr2>>12)*0x10)) << 1)); prioTab[sprX] = prio; } x1 = ((sprSize.x-x-lg)>>1); c = src[(x1&0x3) + ((x1&0xFFFC)<<3)]; if((c&0xF)&&(prioTab[sprX]>=prio)) { - dst[sprX+lg-1] = T1ReadWord(pal, ((c&0xF)+((aux->attr2>>12)*0x10)) << 1); + T2WriteWord(dst, (sprX+lg-1) << 1, T1ReadWord(pal, ((c&0xF)+((aux->attr2>>12)*0x10)) << 1)); prioTab[sprX+lg-1] = prio; } } @@ -1068,14 +1050,14 @@ void sprite1D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) u8 c = src[(x1&0x3) + ((x1&0xFFFC)<<3)]; if((c>>4)&&(prioTab[sprX]>=prio)) { - dst[sprX] = T1ReadWord(pal, ((c>>4)+((aux->attr2>>12)*0x10)) << 1); + T2WriteWord(dst, sprX << 1, T1ReadWord(pal, ((c>>4)+((aux->attr2>>12)*0x10)) << 1)); prioTab[sprX] = prio; } x1 = ((x+lg-1)>>1); c = src[(x1&0x3) + ((x1&0xFFFC)<<3)]; if((c>>4)&&(prioTab[sprX]>=prio)) { - dst[sprX+lg-1] = T1ReadWord(pal, ((c>>4)+((aux->attr2>>12)*0x10)) << 1); + T2WriteWord(dst, (sprX+lg-1) << 1, T1ReadWord(pal, ((c>>4)+((aux->attr2>>12)*0x10)) << 1)); prioTab[sprX+lg-1] = prio; } } @@ -1093,18 +1075,16 @@ void sprite1D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) u8 c = src[(x&0x3) + ((x&0xFFFC)<<3)]; if((c>>4)&&(prioTab[sprX]>=prio)) { - dst[sprX] = T1ReadWord(pal, ((c>>4)+((aux->attr2>>12)*0x10)) << 1); + T2WriteWord(dst, sprX << 1, T1ReadWord(pal, ((c>>4)+((aux->attr2>>12)*0x10)) << 1)); prioTab[sprX] = prio; } - //else dst[sprX] = 0x7FFF; ++sprX; if((c&0xF)&&(prioTab[sprX]>=prio)) { - dst[sprX] = T1ReadWord(pal, ((c&0xF)+((aux->attr2>>12)*0x10)) << 1); + T2WriteWord(dst, sprX << 1, T1ReadWord(pal, ((c&0xF)+((aux->attr2>>12)*0x10)) << 1)); prioTab[sprX] = prio; } - //else dst[sprX] = 0x7FFF; ++sprX; } continue; @@ -1117,24 +1097,22 @@ void sprite1D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) if((c&0xF)&&(prioTab[sprX]>=prio)) { - dst[sprX] = T1ReadWord(pal, ((c&0xF)+((aux->attr2>>12)*0x10)) << 1); + T2WriteWord(dst, sprX << 1, T1ReadWord(pal, ((c&0xF)+((aux->attr2>>12)*0x10)) << 1)); prioTab[sprX] = prio; } - //else dst[sprX] = 0x7FFF; ++sprX; if((c>>4)&&(prioTab[sprX]>=prio)) { - dst[sprX] = T1ReadWord(pal, ((c>>4)+((aux->attr2>>12)*0x10)) << 1); + T2WriteWord(dst, sprX << 1, T1ReadWord(pal, ((c>>4)+((aux->attr2>>12)*0x10)) << 1)); prioTab[sprX] = prio; } - //else dst[sprX] = 0x7FFF; ++sprX; } } } -void sprite2D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) +void sprite2D(GPU * gpu, u16 l, u8 * dst, u8 * prioTab) { u16 i; OAM * aux = gpu->oam + (nbShow-1);// + 127; @@ -1187,10 +1165,9 @@ void sprite2D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) u8 c = src[x << 1]; if((c>>15) && (prioTab[sprX]>=prio)) { - dst[sprX] = c; + T2WriteByte(dst, sprX << 1, c); prioTab[sprX] = prio; } - //else dst[sprX] = 0x7FFF; } continue; } @@ -1199,10 +1176,9 @@ void sprite2D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) u16 c = T1ReadWord(src, x << 1); if((c>>15) && (prioTab[sprX]>=prio)) { - dst[sprX] = c; + T2WriteWord(dst, sprX << 1, c); prioTab[sprX] = prio; } - //else dst[sprX] = 0x7FFF; }// continue; } @@ -1221,10 +1197,9 @@ void sprite2D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) u8 c = src[(x&0x7) + ((x&0xFFF8)<<3)]; if((c) && (prioTab[sprX]>=prio)) { - dst[sprX] = T1ReadWord(pal, c << 1); + T2WriteWord(dst, sprX << 1, T1ReadWord(pal, c << 1)); prioTab[sprX] = prio; } - //else dst[sprX] = 0x7FFF; } continue; } @@ -1235,10 +1210,9 @@ void sprite2D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) if((c) && (prioTab[sprX]>=prio)) { - dst[sprX] = T1ReadWord(pal, c << 1); + T2WriteWord(dst, sprX << 1, T1ReadWord(pal, c << 1)); prioTab[sprX] = prio; } - //else dst[sprX] = 0x7FFF; } continue; } @@ -1252,14 +1226,14 @@ void sprite2D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) u8 c = src[(x1&0x3) + ((x1&0xFFFC)<<3)]; if((c&0xF)&&(prioTab[sprX]>=prio)) { - dst[sprX] = T1ReadWord(pal, ((c&0xF)+((aux->attr2>>12)*0x10)) << 1); + T2WriteWord(dst, sprX << 1, T1ReadWord(pal, ((c&0xF)+((aux->attr2>>12)*0x10)) << 1)); prioTab[sprX] = prio; } x1 = ((sprSize.x-x-lg)>>1); c = src[(x1&0x3) + ((x1&0xFFFC)<<3)]; if((c&0xF)&&(prioTab[sprX]>=prio)) { - dst[sprX+lg-1] = T1ReadWord(pal, ((c&0xF)+((aux->attr2>>12)*0x10)) << 1); + T2WriteWord(dst, (sprX+lg-1) << 1, T1ReadWord(pal, ((c&0xF)+((aux->attr2>>12)*0x10)) << 1)); prioTab[sprX+lg-1] = prio; } } @@ -1269,14 +1243,14 @@ void sprite2D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) u8 c = src[(x1&0x3) + ((x1&0xFFFC)<<3)]; if((c>>4)&&(prioTab[sprX]>=prio)) { - dst[sprX] = T1ReadWord(pal, ((c>>4)+((aux->attr2>>12)*0x10)) << 1); + T2WriteWord(dst, sprX << 1, T1ReadWord(pal, ((c>>4)+((aux->attr2>>12)*0x10)) << 1)); prioTab[sprX] = prio; } x1 = ((x+lg-1)>>1); c = src[(x1&0x3) + ((x1&0xFFFC)<<3)]; if((c>>4)&&(prioTab[sprX]>=prio)) { - dst[sprX+lg-1] = T1ReadWord(pal, ((c>>4)+((aux->attr2>>12)*0x10)) << 1); + T2WriteWord(dst, (sprX+lg-1) << 1, T1ReadWord(pal, ((c>>4)+((aux->attr2>>12)*0x10)) << 1)); prioTab[sprX+lg-1] = prio; } } @@ -1294,18 +1268,16 @@ void sprite2D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) u8 c = src[(x&0x3) + ((x&0xFFFC)<<3)]; if((c>>4)&&(prioTab[sprX]>=prio)) { - dst[sprX] = T1ReadWord(pal, ((c>>4)+((aux->attr2>>12)*0x10)) << 1); + T2WriteWord(dst, sprX << 1, T1ReadWord(pal, ((c>>4)+((aux->attr2>>12)*0x10)) << 1)); prioTab[sprX] = prio; } - //else dst[sprX] = 0x7FFF; ++sprX; if((c&0xF)&&(prioTab[sprX]>=prio)) { - dst[sprX] = T1ReadWord(pal, ((c&0xF)+((aux->attr2>>12)*0x10)) << 1); + T2WriteWord(dst, sprX << 1, T1ReadWord(pal, ((c&0xF)+((aux->attr2>>12)*0x10)) << 1)); prioTab[sprX] = prio; } - //else dst[sprX] = 0x7FFF; ++sprX; } continue; @@ -1318,18 +1290,16 @@ void sprite2D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab) if((c&0xF)&&(prioTab[sprX]>=prio)) { - dst[sprX] = T1ReadWord(pal, ((c&0xF)+((aux->attr2>>12)*0x10)) << 1); + T2WriteWord(dst, sprX << 1, T1ReadWord(pal, ((c&0xF)+((aux->attr2>>12)*0x10)) << 1)); prioTab[sprX] = prio; } - //else dst[sprX] = 0x7FFF; ++sprX; if((c>>4)&&(prioTab[sprX]>=prio)) { - dst[sprX] = T1ReadWord(pal, ((c>>4)+((aux->attr2>>12)*0x10)) << 1); + T2WriteWord(dst, sprX << 1, T1ReadWord(pal, ((c>>4)+((aux->attr2>>12)*0x10)) << 1)); prioTab[sprX] = prio; } - //else dst[sprX] = 0x7FFF; ++sprX; } } diff --git a/desmume/src/GPU.h b/desmume/src/GPU.h index 65960d307..bca2ee99b 100644 --- a/desmume/src/GPU.h +++ b/desmume/src/GPU.h @@ -92,7 +92,7 @@ struct _GPU u8 sprBMPBlock; u8 sprBMPMode; - void (*spriteRender)(GPU * gpu, u16 l, u16 * dst, u8 * prioTab); + void (*spriteRender)(GPU * gpu, u16 l, u8 * dst, u8 * prioTab); }; extern u16 GPU_screen[2*256*192]; @@ -101,16 +101,16 @@ GPU * GPU_Init(u8 l); void GPU_Reset(GPU *g, u8 l); void GPU_DeInit(GPU *); -void textBG(GPU * gpu, u8 num, u16 * DST); -void rotBG(GPU * gpu, u8 num, u16 * DST); -void extRotBG(GPU * gpu, u8 num, u16 * DST); -void sprite1D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab); -void sprite2D(GPU * gpu, u16 l, u16 * dst, u8 * prioTab); +void textBG(GPU * gpu, u8 num, u8 * DST); +void rotBG(GPU * gpu, u8 num, u8 * DST); +void extRotBG(GPU * gpu, u8 num, u8 * DST); +void sprite1D(GPU * gpu, u16 l, u8 * dst, u8 * prioTab); +void sprite2D(GPU * gpu, u16 l, u8 * dst, u8 * prioTab); extern short sizeTab[4][4][2]; extern size sprSizeTab[4][4]; extern s8 mode2type[8][4]; -extern void (*modeRender[8][4])(GPU * gpu, u8 num, u16 l, u16 * DST); +extern void (*modeRender[8][4])(GPU * gpu, u8 num, u16 l, u8 * DST); typedef struct { GPU * gpu; @@ -127,8 +127,10 @@ void Screen_DeInit(void); static INLINE void GPU_ligne(Screen * screen, u16 l) { GPU * gpu = screen->gpu; - u16 * dst = GPU_screen + (screen->offset + l) * 256; - u16 spr[256]; + //u16 * dst = GPU_screen + (screen->offset + l) * 256; + u8 * dst = GPU_screen + (screen->offset + l) * 256; + //u16 spr[256]; + u8 spr[512]; u8 sprPrio[256]; u8 bgprio; int i; @@ -139,11 +141,12 @@ static INLINE void GPU_ligne(Screen * screen, u16 l) * I'm really not sure it's correct. */ if (gpu->lcd == 0) { - u32 mainlcdcnt = ((u32 *)ARM9Mem.ARM9_REG)[0]; - int ii = l*256; - if ((mainlcdcnt&0x10000)==0) { + u32 mainlcdcnt = T1ReadLong(ARM9Mem.ARM9_REG, 0); + int ii = l * 256; + + if ((mainlcdcnt & 0x10000) == 0) { for (i=0; i<256; i++) { - ((u16 *)dst)[i] = ((u16 *)ARM9Mem.ARM9_LCD)[ii]; + T2WriteWord(dst, i << 1, T1ReadWord(ARM9Mem.ARM9_LCD, ii << 1)); ii++; } return; @@ -155,8 +158,8 @@ static INLINE void GPU_ligne(Screen * screen, u16 l) for(i8 = 0; i8< 128; ++i8) { - ((u32 *)dst)[i8] = c; - ((u32 *)spr)[i8] = c; + T2WriteLong(dst, i8 << 2, c); + T2WriteLong(spr, i8 << 2, c); T1WriteWord(sprPrio, i8 << 1, (4 << 8) | (4)); } @@ -170,8 +173,9 @@ static INLINE void GPU_ligne(Screen * screen, u16 l) if((gpu->BGProp[gpu->ordre[0]]&3)!=3) { - for(i16 = 0; i16 < 128; ++i16) - ((u32 *)dst)[i16] = ((u32 *)spr)[i16]; + for(i16 = 0; i16 < 128; ++i16) { + T2WriteLong(dst, i16 << 2, T2ReadLong(spr, i16 << 2)); + } } for(i8 = 0; i8 < gpu->nbBGActif; ++i8) @@ -180,7 +184,7 @@ static INLINE void GPU_ligne(Screen * screen, u16 l) bgprio = gpu->BGProp[gpu->ordre[i8]]&3; for(i16 = 0; i16 < 256; ++i16) if(bgprio>=sprPrio[i16]) - dst[i16] = spr[i16]; + T2WriteWord(dst, i16 << 1, T2ReadWord(spr, i16 << 1)); } } diff --git a/desmume/src/cflash.c b/desmume/src/cflash.c index 668d04446..efe692b86 100644 --- a/desmume/src/cflash.c +++ b/desmume/src/cflash.c @@ -209,8 +209,7 @@ void list_files(char *fpath) { if (numFiles==MAXFILES-1) break; - // FIXME: Unix filenames can start with a . - if ((entry.flags & FS_IS_DIR) && (fname[0] != '.')) { + if ((entry.flags & FS_IS_DIR) && (strcmp(fname, ".")) && (strcmp(fname, ".."))) { sprintf(SubDir, "%s%c%s", fpath, FS_SEPARATOR, fname); list_files(SubDir); } diff --git a/desmume/src/mem.h b/desmume/src/mem.h index 9d279e4c6..b41bc9889 100644 --- a/desmume/src/mem.h +++ b/desmume/src/mem.h @@ -89,4 +89,53 @@ static INLINE void T1WriteLong(u8 * mem, u32 addr, u32 val) #endif } +/* Type 2 Memory, faster for word (16 bits) accesses */ + +static INLINE u8 T2ReadByte(u8 * mem, u32 addr) +{ +#ifdef WORDS_BIGENDIAN + return mem[addr ^ 1]; +#else + return mem[addr]; +#endif +} + +static INLINE u16 T2ReadWord(u8 * mem, u32 addr) +{ + return *((u16 *) (mem + addr)); +} + +static INLINE u32 T2ReadLong(u8 * mem, u32 addr) +{ +#ifdef WORDS_BIGENDIAN + return *((u16 *) (mem + addr + 2)) << 16 | *((u16 *) (mem + addr)); +#else + return *((u32 *) (mem + addr)); +#endif +} + +static INLINE void T2WriteByte(u8 * mem, u32 addr, u8 val) +{ +#ifdef WORDS_BIGENDIAN + mem[addr ^ 1] = val; +#else + mem[addr] = val; +#endif +} + +static INLINE void T2WriteWord(u8 * mem, u32 addr, u16 val) +{ + *((u16 *) (mem + addr)) = val; +} + +static INLINE void T2WriteLong(u8 * mem, u32 addr, u32 val) +{ +#ifdef WORDS_BIGENDIAN + *((u16 *) (mem + addr + 2)) = val >> 16; + *((u16 *) (mem + addr)) = val & 0xFFFF; +#else + *((u32 *) (mem + addr)) = val; +#endif +} + #endif