aboutsummaryrefslogtreecommitdiff
path: root/source
diff options
context:
space:
mode:
Diffstat (limited to 'source')
-rw-r--r--source/dma.c486
-rw-r--r--source/gfx.c371
-rw-r--r--source/memmap.c54
3 files changed, 467 insertions, 444 deletions
diff --git a/source/dma.c b/source/dma.c
index 58aa2f1..7effb25 100644
--- a/source/dma.c
+++ b/source/dma.c
@@ -56,11 +56,11 @@ void S9xDoDMA(uint8_t Channel)
}
switch (d->BAddress)
{
- case 0x18:
- case 0x19:
- if (IPPU.RenderThisFrame)
- FLUSH_REDRAW();
- break;
+ case 0x18:
+ case 0x19:
+ if (IPPU.RenderThisFrame)
+ FLUSH_REDRAW();
+ break;
}
if (Settings.SDD1)
{
@@ -74,8 +74,8 @@ void S9xDoDMA(uint8_t Channel)
in_ptr = GetBasePointer(((d->ABank << 16) | d->AAddress));
if (in_ptr)
{
- in_ptr += d->AAddress;
- SDD1_decompress(sdd1_decode_buffer, in_ptr, d->TransferBytes);
+ in_ptr += d->AAddress;
+ SDD1_decompress(sdd1_decode_buffer, in_ptr, d->TransferBytes);
}
in_sdd1_dma = sdd1_decode_buffer;
}
@@ -84,14 +84,16 @@ void S9xDoDMA(uint8_t Channel)
}
if (Settings.SPC7110 && (d->AAddress == 0x4800 || d->ABank == 0x50))
{
- int32_t c;
+ int32_t c, icount;
spc7110_dma = &s7r.bank50[0];
+
for(c = 0; c < count; c++)
s7r.bank50[c] = spc7110dec_read();
- int32_t icount = (s7r.reg4809 | (s7r.reg480A << 8)) - count;
- s7r.reg4809 = 0x00ff & icount;
- s7r.reg480A = (0xff00 & icount) >> 8;
- inc = 1;
+
+ icount = (s7r.reg4809 | (s7r.reg480A << 8)) - count;
+ s7r.reg4809 = 0x00ff & icount;
+ s7r.reg480A = (0xff00 & icount) >> 8;
+ inc = 1;
d->AAddress -= count;
}
if (d->BAddress == 0x18 && SA1.in_char_dma && (d->ABank & 0xf0) == 0x40)
@@ -114,92 +116,92 @@ void S9xDoDMA(uint8_t Channel)
switch (depth)
{
- case 2:
- for (i = 0 ; i < count ; i += inc, base += char_line_bytes, inc = char_line_bytes, char_count = num_chars)
- {
- uint32_t j;
- uint8_t* line = base + (num_chars - char_count) * 2;
- for (j = 0 ; j < char_count && p - buffer < count ; j++, line += 2)
+ case 2:
+ for (i = 0 ; i < count ; i += inc, base += char_line_bytes, inc = char_line_bytes, char_count = num_chars)
{
- int32_t b, l;
- uint8_t* q = line;
- for (l = 0; l < 8; l++, q += bytes_per_line)
+ uint32_t j;
+ uint8_t* line = base + (num_chars - char_count) * 2;
+ for (j = 0 ; j < char_count && p - buffer < count ; j++, line += 2)
{
- for (b = 0; b < 2; b++)
+ int32_t b, l;
+ uint8_t* q = line;
+ for (l = 0; l < 8; l++, q += bytes_per_line)
{
- uint8_t r = *(q + b);
- *(p + 0) = (*(p + 0) << 1) | ((r >> 0) & 1);
- *(p + 1) = (*(p + 1) << 1) | ((r >> 1) & 1);
- *(p + 0) = (*(p + 0) << 1) | ((r >> 2) & 1);
- *(p + 1) = (*(p + 1) << 1) | ((r >> 3) & 1);
- *(p + 0) = (*(p + 0) << 1) | ((r >> 4) & 1);
- *(p + 1) = (*(p + 1) << 1) | ((r >> 5) & 1);
- *(p + 0) = (*(p + 0) << 1) | ((r >> 6) & 1);
- *(p + 1) = (*(p + 1) << 1) | ((r >> 7) & 1);
+ for (b = 0; b < 2; b++)
+ {
+ uint8_t r = *(q + b);
+ *(p + 0) = (*(p + 0) << 1) | ((r >> 0) & 1);
+ *(p + 1) = (*(p + 1) << 1) | ((r >> 1) & 1);
+ *(p + 0) = (*(p + 0) << 1) | ((r >> 2) & 1);
+ *(p + 1) = (*(p + 1) << 1) | ((r >> 3) & 1);
+ *(p + 0) = (*(p + 0) << 1) | ((r >> 4) & 1);
+ *(p + 1) = (*(p + 1) << 1) | ((r >> 5) & 1);
+ *(p + 0) = (*(p + 0) << 1) | ((r >> 6) & 1);
+ *(p + 1) = (*(p + 1) << 1) | ((r >> 7) & 1);
+ }
+ p += 2;
}
- p += 2;
}
}
- }
- break;
- case 4:
- for (i = 0 ; i < count ; i += inc, base += char_line_bytes, inc = char_line_bytes, char_count = num_chars)
- {
- uint32_t j;
- uint8_t* line = base + (num_chars - char_count) * 4;
- for (j = 0 ; j < char_count && p - buffer < count ; j++, line += 4)
+ break;
+ case 4:
+ for (i = 0 ; i < count ; i += inc, base += char_line_bytes, inc = char_line_bytes, char_count = num_chars)
{
- uint8_t* q = line;
- int32_t b, l;
- for (l = 0; l < 8; l++, q += bytes_per_line)
+ uint32_t j;
+ uint8_t* line = base + (num_chars - char_count) * 4;
+ for (j = 0 ; j < char_count && p - buffer < count ; j++, line += 4)
{
- for (b = 0; b < 4; b++)
+ uint8_t* q = line;
+ int32_t b, l;
+ for (l = 0; l < 8; l++, q += bytes_per_line)
{
- uint8_t r = *(q + b);
- *(p + 0) = (*(p + 0) << 1) | ((r >> 0) & 1);
- *(p + 1) = (*(p + 1) << 1) | ((r >> 1) & 1);
- *(p + 16) = (*(p + 16) << 1) | ((r >> 2) & 1);
- *(p + 17) = (*(p + 17) << 1) | ((r >> 3) & 1);
- *(p + 0) = (*(p + 0) << 1) | ((r >> 4) & 1);
- *(p + 1) = (*(p + 1) << 1) | ((r >> 5) & 1);
- *(p + 16) = (*(p + 16) << 1) | ((r >> 6) & 1);
- *(p + 17) = (*(p + 17) << 1) | ((r >> 7) & 1);
+ for (b = 0; b < 4; b++)
+ {
+ uint8_t r = *(q + b);
+ *(p + 0) = (*(p + 0) << 1) | ((r >> 0) & 1);
+ *(p + 1) = (*(p + 1) << 1) | ((r >> 1) & 1);
+ *(p + 16) = (*(p + 16) << 1) | ((r >> 2) & 1);
+ *(p + 17) = (*(p + 17) << 1) | ((r >> 3) & 1);
+ *(p + 0) = (*(p + 0) << 1) | ((r >> 4) & 1);
+ *(p + 1) = (*(p + 1) << 1) | ((r >> 5) & 1);
+ *(p + 16) = (*(p + 16) << 1) | ((r >> 6) & 1);
+ *(p + 17) = (*(p + 17) << 1) | ((r >> 7) & 1);
+ }
+ p += 2;
}
- p += 2;
+ p += 32 - 16;
}
- p += 32 - 16;
}
- }
- break;
- case 8:
- for(i = 0 ; i < count ; i += inc, base += char_line_bytes, inc = char_line_bytes, char_count = num_chars)
- {
- uint8_t* line = base + (num_chars - char_count) * 8;
- uint32_t j;
- for(j = 0 ; j < char_count && p - buffer < count ; j++, line += 8)
+ break;
+ case 8:
+ for(i = 0 ; i < count ; i += inc, base += char_line_bytes, inc = char_line_bytes, char_count = num_chars)
{
- uint8_t* q = line;
- int32_t b, l;
- for (l = 0; l < 8; l++, q += bytes_per_line)
+ uint8_t* line = base + (num_chars - char_count) * 8;
+ uint32_t j;
+ for(j = 0 ; j < char_count && p - buffer < count ; j++, line += 8)
{
- for (b = 0; b < 8; b++)
+ uint8_t* q = line;
+ int32_t b, l;
+ for (l = 0; l < 8; l++, q += bytes_per_line)
{
- uint8_t r = *(q + b);
- *(p + 0) = (*(p + 0) << 1) | ((r >> 0) & 1);
- *(p + 1) = (*(p + 1) << 1) | ((r >> 1) & 1);
- *(p + 16) = (*(p + 16) << 1) | ((r >> 2) & 1);
- *(p + 17) = (*(p + 17) << 1) | ((r >> 3) & 1);
- *(p + 32) = (*(p + 32) << 1) | ((r >> 4) & 1);
- *(p + 33) = (*(p + 33) << 1) | ((r >> 5) & 1);
- *(p + 48) = (*(p + 48) << 1) | ((r >> 6) & 1);
- *(p + 49) = (*(p + 49) << 1) | ((r >> 7) & 1);
+ for (b = 0; b < 8; b++)
+ {
+ uint8_t r = *(q + b);
+ *(p + 0) = (*(p + 0) << 1) | ((r >> 0) & 1);
+ *(p + 1) = (*(p + 1) << 1) | ((r >> 1) & 1);
+ *(p + 16) = (*(p + 16) << 1) | ((r >> 2) & 1);
+ *(p + 17) = (*(p + 17) << 1) | ((r >> 3) & 1);
+ *(p + 32) = (*(p + 32) << 1) | ((r >> 4) & 1);
+ *(p + 33) = (*(p + 33) << 1) | ((r >> 5) & 1);
+ *(p + 48) = (*(p + 48) << 1) | ((r >> 6) & 1);
+ *(p + 49) = (*(p + 49) << 1) | ((r >> 7) & 1);
+ }
+ p += 2;
}
- p += 2;
+ p += 64 - 16;
}
- p += 64 - 16;
}
- }
- break;
+ break;
}
}
@@ -252,80 +254,80 @@ void S9xDoDMA(uint8_t Channel)
{
switch (d->BAddress)
{
- case 0x04:
- do
- {
- Work = *(base + p);
- REGISTER_2104(Work);
- p += inc;
- } while (--count > 0);
- break;
- case 0x18:
- IPPU.FirstVRAMRead = true;
- if (!PPU.VMA.FullGraphicCount)
- {
+ case 0x04:
do
{
Work = *(base + p);
- REGISTER_2118_linear(Work);
+ REGISTER_2104(Work);
p += inc;
} while (--count > 0);
- }
- else
- {
+ break;
+ case 0x18:
+ IPPU.FirstVRAMRead = true;
+ if (!PPU.VMA.FullGraphicCount)
+ {
+ do
+ {
+ Work = *(base + p);
+ REGISTER_2118_linear(Work);
+ p += inc;
+ } while (--count > 0);
+ }
+ else
+ {
+ do
+ {
+ Work = *(base + p);
+ REGISTER_2118_tile(Work);
+ p += inc;
+ } while (--count > 0);
+ }
+ break;
+ case 0x19:
+ IPPU.FirstVRAMRead = true;
+ if (!PPU.VMA.FullGraphicCount)
+ {
+ do
+ {
+ Work = *(base + p);
+ REGISTER_2119_linear(Work);
+ p += inc;
+ } while (--count > 0);
+ }
+ else
+ {
+ do
+ {
+ Work = *(base + p);
+ REGISTER_2119_tile(Work);
+ p += inc;
+ } while (--count > 0);
+ }
+ break;
+ case 0x22:
do
{
Work = *(base + p);
- REGISTER_2118_tile(Work);
+ REGISTER_2122(Work);
p += inc;
} while (--count > 0);
- }
- break;
- case 0x19:
- IPPU.FirstVRAMRead = true;
- if (!PPU.VMA.FullGraphicCount)
- {
+ break;
+ case 0x80:
do
{
Work = *(base + p);
- REGISTER_2119_linear(Work);
+ REGISTER_2180(Work);
p += inc;
} while (--count > 0);
- }
- else
- {
+ break;
+ default:
do
{
Work = *(base + p);
- REGISTER_2119_tile(Work);
+ S9xSetPPU(Work, 0x2100 + d->BAddress);
p += inc;
} while (--count > 0);
- }
- break;
- case 0x22:
- do
- {
- Work = *(base + p);
- REGISTER_2122(Work);
- p += inc;
- } while (--count > 0);
- break;
- case 0x80:
- do
- {
- Work = *(base + p);
- REGISTER_2180(Work);
- p += inc;
- } while (--count > 0);
- break;
- default:
- do
- {
- Work = *(base + p);
- S9xSetPPU(Work, 0x2100 + d->BAddress);
- p += inc;
- } while (--count > 0);
- break;
+ break;
}
}
else if (d->TransferMode == 1 || d->TransferMode == 5)
@@ -462,79 +464,79 @@ void S9xDoDMA(uint8_t Channel)
{
switch (d->TransferMode)
{
- case 0:
- case 2:
- case 6:
- Work = S9xGetPPU(0x2100 + d->BAddress);
- S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
- d->AAddress += inc;
- --count;
- break;
- case 1:
- case 5:
- Work = S9xGetPPU(0x2100 + d->BAddress);
- S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
- d->AAddress += inc;
- if (!--count)
- break;
-
- Work = S9xGetPPU(0x2101 + d->BAddress);
- S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
- d->AAddress += inc;
- count--;
- break;
- case 3:
- case 7:
- Work = S9xGetPPU(0x2100 + d->BAddress);
- S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
- d->AAddress += inc;
- if (!--count)
+ case 0:
+ case 2:
+ case 6:
+ Work = S9xGetPPU(0x2100 + d->BAddress);
+ S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
+ d->AAddress += inc;
+ --count;
break;
-
- Work = S9xGetPPU(0x2100 + d->BAddress);
- S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
- d->AAddress += inc;
- if (!--count)
+ case 1:
+ case 5:
+ Work = S9xGetPPU(0x2100 + d->BAddress);
+ S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
+ d->AAddress += inc;
+ if (!--count)
+ break;
+
+ Work = S9xGetPPU(0x2101 + d->BAddress);
+ S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
+ d->AAddress += inc;
+ count--;
break;
-
- Work = S9xGetPPU(0x2101 + d->BAddress);
- S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
- d->AAddress += inc;
- if (!--count)
+ case 3:
+ case 7:
+ Work = S9xGetPPU(0x2100 + d->BAddress);
+ S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
+ d->AAddress += inc;
+ if (!--count)
+ break;
+
+ Work = S9xGetPPU(0x2100 + d->BAddress);
+ S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
+ d->AAddress += inc;
+ if (!--count)
+ break;
+
+ Work = S9xGetPPU(0x2101 + d->BAddress);
+ S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
+ d->AAddress += inc;
+ if (!--count)
+ break;
+
+ Work = S9xGetPPU(0x2101 + d->BAddress);
+ S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
+ d->AAddress += inc;
+ count--;
break;
-
- Work = S9xGetPPU(0x2101 + d->BAddress);
- S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
- d->AAddress += inc;
- count--;
- break;
- case 4:
- Work = S9xGetPPU(0x2100 + d->BAddress);
- S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
- d->AAddress += inc;
- if (!--count)
+ case 4:
+ Work = S9xGetPPU(0x2100 + d->BAddress);
+ S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
+ d->AAddress += inc;
+ if (!--count)
+ break;
+
+ Work = S9xGetPPU(0x2101 + d->BAddress);
+ S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
+ d->AAddress += inc;
+ if (!--count)
+ break;
+
+ Work = S9xGetPPU(0x2102 + d->BAddress);
+ S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
+ d->AAddress += inc;
+ if (!--count)
+ break;
+
+ Work = S9xGetPPU(0x2103 + d->BAddress);
+ S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
+ d->AAddress += inc;
+ count--;
break;
-
- Work = S9xGetPPU(0x2101 + d->BAddress);
- S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
- d->AAddress += inc;
- if (!--count)
+ default:
+ count = 0;
break;
-
- Work = S9xGetPPU(0x2102 + d->BAddress);
- S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
- d->AAddress += inc;
- if (!--count)
- break;
-
- Work = S9xGetPPU(0x2103 + d->BAddress);
- S9xSetByte(Work, (d->ABank << 16) + d->AAddress);
- d->AAddress += inc;
- count--;
- break;
- default:
- count = 0;
- break;
}
} while (count);
}
@@ -681,46 +683,46 @@ uint8_t S9xDoHDMA(uint8_t byte)
switch (p->TransferMode)
{
- case 0:
- CPU.Cycles += SLOW_ONE_CYCLE;
- S9xSetPPU(*HDMAMemPointers [d]++, 0x2100 + p->BAddress);
- break;
- case 5:
- CPU.Cycles += 2 * SLOW_ONE_CYCLE;
- S9xSetPPU(*(HDMAMemPointers [d] + 0), 0x2100 + p->BAddress);
- S9xSetPPU(*(HDMAMemPointers [d] + 1), 0x2101 + p->BAddress);
- HDMAMemPointers [d] += 2;
- /* fall through */
- case 1:
- CPU.Cycles += 2 * SLOW_ONE_CYCLE;
- S9xSetPPU(*(HDMAMemPointers [d] + 0), 0x2100 + p->BAddress);
- S9xSetPPU(*(HDMAMemPointers [d] + 1), 0x2101 + p->BAddress);
- HDMAMemPointers [d] += 2;
- break;
- case 2:
- case 6:
- CPU.Cycles += 2 * SLOW_ONE_CYCLE;
- S9xSetPPU(*(HDMAMemPointers [d] + 0), 0x2100 + p->BAddress);
- S9xSetPPU(*(HDMAMemPointers [d] + 1), 0x2100 + p->BAddress);
- HDMAMemPointers [d] += 2;
- break;
- case 3:
- case 7:
- CPU.Cycles += 4 * SLOW_ONE_CYCLE;
- S9xSetPPU(*(HDMAMemPointers [d] + 0), 0x2100 + p->BAddress);
- S9xSetPPU(*(HDMAMemPointers [d] + 1), 0x2100 + p->BAddress);
- S9xSetPPU(*(HDMAMemPointers [d] + 2), 0x2101 + p->BAddress);
- S9xSetPPU(*(HDMAMemPointers [d] + 3), 0x2101 + p->BAddress);
- HDMAMemPointers [d] += 4;
- break;
- case 4:
- CPU.Cycles += 4 * SLOW_ONE_CYCLE;
- S9xSetPPU(*(HDMAMemPointers [d] + 0), 0x2100 + p->BAddress);
- S9xSetPPU(*(HDMAMemPointers [d] + 1), 0x2101 + p->BAddress);
- S9xSetPPU(*(HDMAMemPointers [d] + 2), 0x2102 + p->BAddress);
- S9xSetPPU(*(HDMAMemPointers [d] + 3), 0x2103 + p->BAddress);
- HDMAMemPointers [d] += 4;
- break;
+ case 0:
+ CPU.Cycles += SLOW_ONE_CYCLE;
+ S9xSetPPU(*HDMAMemPointers [d]++, 0x2100 + p->BAddress);
+ break;
+ case 5:
+ CPU.Cycles += 2 * SLOW_ONE_CYCLE;
+ S9xSetPPU(*(HDMAMemPointers [d] + 0), 0x2100 + p->BAddress);
+ S9xSetPPU(*(HDMAMemPointers [d] + 1), 0x2101 + p->BAddress);
+ HDMAMemPointers [d] += 2;
+ /* fall through */
+ case 1:
+ CPU.Cycles += 2 * SLOW_ONE_CYCLE;
+ S9xSetPPU(*(HDMAMemPointers [d] + 0), 0x2100 + p->BAddress);
+ S9xSetPPU(*(HDMAMemPointers [d] + 1), 0x2101 + p->BAddress);
+ HDMAMemPointers [d] += 2;
+ break;
+ case 2:
+ case 6:
+ CPU.Cycles += 2 * SLOW_ONE_CYCLE;
+ S9xSetPPU(*(HDMAMemPointers [d] + 0), 0x2100 + p->BAddress);
+ S9xSetPPU(*(HDMAMemPointers [d] + 1), 0x2100 + p->BAddress);
+ HDMAMemPointers [d] += 2;
+ break;
+ case 3:
+ case 7:
+ CPU.Cycles += 4 * SLOW_ONE_CYCLE;
+ S9xSetPPU(*(HDMAMemPointers [d] + 0), 0x2100 + p->BAddress);
+ S9xSetPPU(*(HDMAMemPointers [d] + 1), 0x2100 + p->BAddress);
+ S9xSetPPU(*(HDMAMemPointers [d] + 2), 0x2101 + p->BAddress);
+ S9xSetPPU(*(HDMAMemPointers [d] + 3), 0x2101 + p->BAddress);
+ HDMAMemPointers [d] += 4;
+ break;
+ case 4:
+ CPU.Cycles += 4 * SLOW_ONE_CYCLE;
+ S9xSetPPU(*(HDMAMemPointers [d] + 0), 0x2100 + p->BAddress);
+ S9xSetPPU(*(HDMAMemPointers [d] + 1), 0x2101 + p->BAddress);
+ S9xSetPPU(*(HDMAMemPointers [d] + 2), 0x2102 + p->BAddress);
+ S9xSetPPU(*(HDMAMemPointers [d] + 3), 0x2103 + p->BAddress);
+ HDMAMemPointers [d] += 4;
+ break;
}
if (!p->HDMAIndirectAddressing)
p->Address += HDMA_ModeByteCounts [p->TransferMode];
diff --git a/source/gfx.c b/source/gfx.c
index 9d077ac..c47661a 100644
--- a/source/gfx.c
+++ b/source/gfx.c
@@ -59,6 +59,7 @@ extern uint8_t Mode7Depths [2];
(GFX.r2131 & 0x3f)
#define FIX_INTERLACE(SCREEN, DO_DEPTH, DEPTH) \
+ { \
uint32_t y; \
if (IPPU.DoubleHeightPixels && ((PPU.BGMode != 5 && PPU.BGMode != 6) || !IPPU.Interlace)) \
{ \
@@ -75,6 +76,7 @@ extern uint8_t Mode7Depths [2];
GFX.PPLx2>>1); \
} \
} \
+ } \
}
#define BLACK BUILD_PIXEL(0,0,0)
@@ -506,44 +508,44 @@ static INLINE void SelectTileRenderer(bool normal)
{
switch (GFX.r2131 & 0xC0)
{
- case 0x00:
- DrawTilePtr = DrawTile16Add;
- DrawClippedTilePtr = DrawClippedTile16Add;
- DrawLargePixelPtr = DrawLargePixel16Add;
- break;
- case 0x40:
- if (GFX.r2130 & 2)
- {
- DrawTilePtr = DrawTile16Add1_2;
- DrawClippedTilePtr = DrawClippedTile16Add1_2;
- }
- else
- {
- /* Fixed colour addition */
- DrawTilePtr = DrawTile16FixedAdd1_2;
- DrawClippedTilePtr = DrawClippedTile16FixedAdd1_2;
- }
- DrawLargePixelPtr = DrawLargePixel16Add1_2;
- break;
- case 0x80:
- DrawTilePtr = DrawTile16Sub;
- DrawClippedTilePtr = DrawClippedTile16Sub;
- DrawLargePixelPtr = DrawLargePixel16Sub;
- break;
- case 0xC0:
- if (GFX.r2130 & 2)
- {
- DrawTilePtr = DrawTile16Sub1_2;
- DrawClippedTilePtr = DrawClippedTile16Sub1_2;
- }
- else
- {
- /* Fixed colour substraction */
- DrawTilePtr = DrawTile16FixedSub1_2;
- DrawClippedTilePtr = DrawClippedTile16FixedSub1_2;
- }
- DrawLargePixelPtr = DrawLargePixel16Sub1_2;
- break;
+ case 0x00:
+ DrawTilePtr = DrawTile16Add;
+ DrawClippedTilePtr = DrawClippedTile16Add;
+ DrawLargePixelPtr = DrawLargePixel16Add;
+ break;
+ case 0x40:
+ if (GFX.r2130 & 2)
+ {
+ DrawTilePtr = DrawTile16Add1_2;
+ DrawClippedTilePtr = DrawClippedTile16Add1_2;
+ }
+ else
+ {
+ /* Fixed colour addition */
+ DrawTilePtr = DrawTile16FixedAdd1_2;
+ DrawClippedTilePtr = DrawClippedTile16FixedAdd1_2;
+ }
+ DrawLargePixelPtr = DrawLargePixel16Add1_2;
+ break;
+ case 0x80:
+ DrawTilePtr = DrawTile16Sub;
+ DrawClippedTilePtr = DrawClippedTile16Sub;
+ DrawLargePixelPtr = DrawLargePixel16Sub;
+ break;
+ case 0xC0:
+ if (GFX.r2130 & 2)
+ {
+ DrawTilePtr = DrawTile16Sub1_2;
+ DrawClippedTilePtr = DrawClippedTile16Sub1_2;
+ }
+ else
+ {
+ /* Fixed colour substraction */
+ DrawTilePtr = DrawTile16FixedSub1_2;
+ DrawClippedTilePtr = DrawClippedTile16FixedSub1_2;
+ }
+ DrawLargePixelPtr = DrawLargePixel16Sub1_2;
+ break;
}
}
}
@@ -557,42 +559,42 @@ void S9xSetupOBJ(void)
switch (PPU.OBJSizeSelect)
{
- case 0:
- SmallWidth = SmallHeight = 8;
- LargeWidth = LargeHeight = 16;
- break;
- case 1:
- SmallWidth = SmallHeight = 8;
- LargeWidth = LargeHeight = 32;
- break;
- case 2:
- SmallWidth = SmallHeight = 8;
- LargeWidth = LargeHeight = 64;
- break;
- case 3:
- SmallWidth = SmallHeight = 16;
- LargeWidth = LargeHeight = 32;
- break;
- case 4:
- SmallWidth = SmallHeight = 16;
- LargeWidth = LargeHeight = 64;
- break;
- default:
- case 5:
- SmallWidth = SmallHeight = 32;
- LargeWidth = LargeHeight = 64;
- break;
- case 6:
- SmallWidth = 16;
- SmallHeight = 32;
- LargeWidth = 32;
- LargeHeight = 64;
- break;
- case 7:
- SmallWidth = 16;
- SmallHeight = 32;
- LargeWidth = LargeHeight = 32;
- break;
+ case 0:
+ SmallWidth = SmallHeight = 8;
+ LargeWidth = LargeHeight = 16;
+ break;
+ case 1:
+ SmallWidth = SmallHeight = 8;
+ LargeWidth = LargeHeight = 32;
+ break;
+ case 2:
+ SmallWidth = SmallHeight = 8;
+ LargeWidth = LargeHeight = 64;
+ break;
+ case 3:
+ SmallWidth = SmallHeight = 16;
+ LargeWidth = LargeHeight = 32;
+ break;
+ case 4:
+ SmallWidth = SmallHeight = 16;
+ LargeWidth = LargeHeight = 64;
+ break;
+ default:
+ case 5:
+ SmallWidth = SmallHeight = 32;
+ LargeWidth = LargeHeight = 64;
+ break;
+ case 6:
+ SmallWidth = 16;
+ SmallHeight = 32;
+ LargeWidth = 32;
+ LargeHeight = 64;
+ break;
+ case 7:
+ SmallWidth = 16;
+ SmallHeight = 32;
+ LargeWidth = LargeHeight = 32;
+ break;
}
/* OK, we have three cases here. Either there's no priority, priority is
* normal FirstSprite, or priority is FirstSprite+Y. The first two are
@@ -1718,15 +1720,15 @@ static void DrawBackground(uint32_t BGMode, uint32_t bg, uint8_t Z1, uint8_t Z2)
}
switch (BGMode)
{
- case 2:
- case 4: /* Used by Puzzle Bobble */
- DrawBackgroundOffset(BGMode, bg, Z1, Z2);
- return;
-
- case 5:
- case 6: /* XXX: is also offset per tile. */
- DrawBackgroundMode5(bg, Z1, Z2);
- return;
+ case 2:
+ case 4: /* Used by Puzzle Bobble */
+ DrawBackgroundOffset(BGMode, bg, Z1, Z2);
+ return;
+
+ case 5:
+ case 6: /* XXX: is also offset per tile. */
+ DrawBackgroundMode5(bg, Z1, Z2);
+ return;
}
depths [0] = Z1;
@@ -2360,6 +2362,7 @@ static void DrawBGMode7Background16Sub1_2(uint8_t * Screen, int32_t bg)
GFX.Z1 = Mode7Depths [(b & GFX.Mode7PriorityMask) >> 7]; \
if (GFX.Z1 > *d && (b & GFX.Mode7Mask) ) \
{ \
+ TYPE theColor; \
uint32_t p1, p2, p3, p4; \
uint32_t Xdel, Ydel, XY, area1, area2, area3, area4, tempColor; \
/* X10 and Y01 are the X and Y coordinates of the next source point over. */ \
@@ -2399,8 +2402,8 @@ static void DrawBGMode7Background16Sub1_2(uint8_t * Screen, int32_t bg)
(area2 * p2) + \
(area3 * p3) + \
(area4 * p4)) >> 5; \
- TYPE theColor = (tempColor & FIRST_THIRD_COLOR_MASK) | ((tempColor >> 16) & SECOND_COLOR_MASK); \
- *p = (FUNC) | ALPHA_BITS_MASK; \
+ theColor = (tempColor & FIRST_THIRD_COLOR_MASK) | ((tempColor >> 16) & SECOND_COLOR_MASK); \
+ *p = (FUNC) | ALPHA_BITS_MASK; \
*d = GFX.Z1; \
} \
} \
@@ -2609,98 +2612,98 @@ static void RenderScreen(uint8_t* Screen, bool sub, bool force_no_add, uint8_t D
switch (PPU.BGMode)
{
- case 0:
- case 1:
- if (OB)
- {
- SelectTileRenderer(sub || !SUB_OR_ADD(4));
- DrawOBJS(!sub, D);
- }
- if (BG0)
- {
- SelectTileRenderer(sub || !SUB_OR_ADD(0));
- DrawBackground(PPU.BGMode, 0, D + 10, D + 14);
- }
- if (BG1)
- {
- SelectTileRenderer(sub || !SUB_OR_ADD(1));
- DrawBackground(PPU.BGMode, 1, D + 9, D + 13);
- }
- if (BG2)
- {
- SelectTileRenderer(sub || !SUB_OR_ADD(2));
- DrawBackground(PPU.BGMode, 2, D + 3, PPU.BG3Priority ? D + 17 : D + 6);
- }
- if (BG3 && PPU.BGMode == 0)
- {
- SelectTileRenderer(sub || !SUB_OR_ADD(3));
- DrawBackground(PPU.BGMode, 3, D + 2, D + 5);
- }
- break;
- case 2:
- case 3:
- case 4:
- case 5:
- case 6:
- if (OB)
- {
- SelectTileRenderer(sub || !SUB_OR_ADD(4));
- DrawOBJS(!sub, D);
- }
- if (BG0)
- {
- SelectTileRenderer(sub || !SUB_OR_ADD(0));
- DrawBackground(PPU.BGMode, 0, D + 5, D + 13);
- }
- if (BG1 && PPU.BGMode != 6)
- {
- SelectTileRenderer(sub || !SUB_OR_ADD(1));
- DrawBackground(PPU.BGMode, 1, D + 2, D + 9);
- }
- break;
- case 7:
- if (OB)
- {
- SelectTileRenderer(sub || !SUB_OR_ADD(4));
- DrawOBJS(!sub, D);
- }
- if (BG0 || ((Memory.FillRAM [0x2133] & 0x40) && BG1))
- {
- int32_t bg;
-
- if ((Memory.FillRAM [0x2133] & 0x40) && BG1)
+ case 0:
+ case 1:
+ if (OB)
{
- GFX.Mode7Mask = 0x7f;
- GFX.Mode7PriorityMask = 0x80;
- Mode7Depths [0] = (BG0 ? 5 : 1) + D;
- Mode7Depths [1] = 9 + D;
- bg = 1;
+ SelectTileRenderer(sub || !SUB_OR_ADD(4));
+ DrawOBJS(!sub, D);
}
- else
+ if (BG0)
{
- GFX.Mode7Mask = 0xff;
- GFX.Mode7PriorityMask = 0;
- Mode7Depths [0] = 5 + D;
- Mode7Depths [1] = 5 + D;
- bg = 0;
+ SelectTileRenderer(sub || !SUB_OR_ADD(0));
+ DrawBackground(PPU.BGMode, 0, D + 10, D + 14);
}
- if (sub || !SUB_OR_ADD(0))
- DrawBGMode7Background16(Screen, bg);
- else
+ if (BG1)
+ {
+ SelectTileRenderer(sub || !SUB_OR_ADD(1));
+ DrawBackground(PPU.BGMode, 1, D + 9, D + 13);
+ }
+ if (BG2)
+ {
+ SelectTileRenderer(sub || !SUB_OR_ADD(2));
+ DrawBackground(PPU.BGMode, 2, D + 3, PPU.BG3Priority ? D + 17 : D + 6);
+ }
+ if (BG3 && PPU.BGMode == 0)
{
- if (GFX.r2131 & 0x80)
+ SelectTileRenderer(sub || !SUB_OR_ADD(3));
+ DrawBackground(PPU.BGMode, 3, D + 2, D + 5);
+ }
+ break;
+ case 2:
+ case 3:
+ case 4:
+ case 5:
+ case 6:
+ if (OB)
+ {
+ SelectTileRenderer(sub || !SUB_OR_ADD(4));
+ DrawOBJS(!sub, D);
+ }
+ if (BG0)
+ {
+ SelectTileRenderer(sub || !SUB_OR_ADD(0));
+ DrawBackground(PPU.BGMode, 0, D + 5, D + 13);
+ }
+ if (BG1 && PPU.BGMode != 6)
+ {
+ SelectTileRenderer(sub || !SUB_OR_ADD(1));
+ DrawBackground(PPU.BGMode, 1, D + 2, D + 9);
+ }
+ break;
+ case 7:
+ if (OB)
+ {
+ SelectTileRenderer(sub || !SUB_OR_ADD(4));
+ DrawOBJS(!sub, D);
+ }
+ if (BG0 || ((Memory.FillRAM [0x2133] & 0x40) && BG1))
+ {
+ int32_t bg;
+
+ if ((Memory.FillRAM [0x2133] & 0x40) && BG1)
{
- if (GFX.r2131 & 0x40)
- DrawBGMode7Background16Sub1_2(Screen, bg);
- else
- DrawBGMode7Background16Sub(Screen, bg);
+ GFX.Mode7Mask = 0x7f;
+ GFX.Mode7PriorityMask = 0x80;
+ Mode7Depths [0] = (BG0 ? 5 : 1) + D;
+ Mode7Depths [1] = 9 + D;
+ bg = 1;
}
else
{
- if (GFX.r2131 & 0x40)
- DrawBGMode7Background16Add1_2(Screen, bg);
+ GFX.Mode7Mask = 0xff;
+ GFX.Mode7PriorityMask = 0;
+ Mode7Depths [0] = 5 + D;
+ Mode7Depths [1] = 5 + D;
+ bg = 0;
+ }
+ if (sub || !SUB_OR_ADD(0))
+ DrawBGMode7Background16(Screen, bg);
+ else
+ {
+ if (GFX.r2131 & 0x80)
+ {
+ if (GFX.r2131 & 0x40)
+ DrawBGMode7Background16Sub1_2(Screen, bg);
+ else
+ DrawBGMode7Background16Sub(Screen, bg);
+ }
else
- DrawBGMode7Background16Add(Screen, bg);
+ {
+ if (GFX.r2131 & 0x40)
+ DrawBGMode7Background16Add1_2(Screen, bg);
+ else
+ DrawBGMode7Background16Add(Screen, bg);
}
}
}
@@ -2713,6 +2716,8 @@ static void RenderScreen(uint8_t* Screen, bool sub, bool force_no_add, uint8_t D
void S9xUpdateScreen(void)
{
int32_t x2 = 1;
+ uint32_t starty, endy, black;
+
GFX.S = GFX.Screen;
GFX.r2131 = Memory.FillRAM [0x2131];
GFX.r212c = Memory.FillRAM [0x212c];
@@ -2736,8 +2741,8 @@ void S9xUpdateScreen(void)
/* XXX: Check ForceBlank? Or anything else? */
PPU.RangeTimeOver |= GFX.OBJLines[GFX.EndY].RTOFlags;
- uint32_t starty = GFX.StartY;
- uint32_t endy = GFX.EndY;
+ starty = GFX.StartY;
+ endy = GFX.EndY;
if (PPU.BGMode == 5 || PPU.BGMode == 6 || IPPU.Interlace || IPPU.DoubleHeightPixels)
{
@@ -2773,18 +2778,19 @@ void S9xUpdateScreen(void)
* too. */
if (IPPU.Interlace && !IPPU.DoubleHeightPixels)
{
- starty = GFX.StartY * 2;
- endy = GFX.EndY * 2 + 1;
- IPPU.RenderedScreenHeight = PPU.ScreenHeight << 1;
- IPPU.DoubleHeightPixels = true;
- GFX.Pitch2 = GFX.RealPitch;
- GFX.Pitch = GFX.RealPitch * 2;
- GFX.PPL = GFX.PPLx2 = GFX.RealPitch;
+ int32_t y;
+ starty = GFX.StartY * 2;
+ endy = GFX.EndY * 2 + 1;
+ IPPU.RenderedScreenHeight = PPU.ScreenHeight << 1;
+ IPPU.DoubleHeightPixels = true;
+ GFX.Pitch2 = GFX.RealPitch;
+ GFX.Pitch = GFX.RealPitch * 2;
+ GFX.PPL = GFX.RealPitch;
+ GFX.PPLx2 = GFX.RealPitch;
/* The game has switched from non-interlaced to interlaced mode
* part way down the screen. Scale everything. */
- int32_t y;
for (y = (int32_t) GFX.StartY - 1; y >= 0; y--)
{
/* memmove converted: Same malloc, different addresses, and identical addresses at line 0 [Neb]
@@ -2796,7 +2802,7 @@ void S9xUpdateScreen(void)
}
}
- uint32_t black = BLACK | (BLACK << 16);
+ black = BLACK | (BLACK << 16);
if (GFX.Pseudo)
{
@@ -2823,6 +2829,8 @@ void S9xUpdateScreen(void)
uint32_t y;
for (y = starty; y <= endy; y++)
{
+ uint32_t c;
+
memset(GFX.SubZBuffer + y * GFX.ZPitch, 0, IPPU.RenderedScreenWidth);
memset(GFX.ZBuffer + y * GFX.ZPitch, 0, IPPU.RenderedScreenWidth);
@@ -2834,7 +2842,6 @@ void S9xUpdateScreen(void)
*p++ = black;
}
- uint32_t c;
for (c = 0; c < pClip->Count [5]; c++)
{
if (pClip->Right [c][5] > pClip->Left [c][5])
@@ -2915,15 +2922,16 @@ void S9xUpdateScreen(void)
if (SUB_OR_ADD(5))
{
+ uint32_t y;
uint32_t back = IPPU.ScreenColors [0];
uint32_t Left = 0;
uint32_t Right = 256;
uint32_t Count;
pClip = &IPPU.Clip [0];
- uint32_t y;
for (y = starty; y <= endy; y++)
{
+ uint32_t b;
if (!(Count = pClip->Count [5]))
{
Left = 0;
@@ -2931,7 +2939,6 @@ void S9xUpdateScreen(void)
Count = 1;
}
- uint32_t b;
for (b = 0; b < Count; b++)
{
if (pClip->Count [5])
@@ -3158,13 +3165,13 @@ void S9xUpdateScreen(void)
uint32_t y;
for (y = starty; y <= endy; y++)
{
+ uint32_t c;
uint32_t* p = (uint32_t*)(GFX.Screen + y * GFX.Pitch2);
uint32_t* q = (uint32_t*)((uint16_t*) p + IPPU.RenderedScreenWidth);
while (p < q)
*p++ = black;
- uint32_t c;
for (c = 0; c < IPPU.Clip [0].Count [5]; c++)
{
if (IPPU.Clip [0].Right [c][5] > IPPU.Clip [0].Left [c][5])
diff --git a/source/memmap.c b/source/memmap.c
index 6f5b726..cfdc997 100644
--- a/source/memmap.c
+++ b/source/memmap.c
@@ -43,15 +43,19 @@ extern char* rom_filename;
void S9xDeinterleaveType1(int32_t TotalFileSize, uint8_t* base)
{
int32_t i;
- int32_t nblocks = TotalFileSize >> 16;
uint8_t blocks [256];
+ uint8_t *tmp = NULL;
+ int32_t nblocks = TotalFileSize >> 16;
+
for (i = 0; i < nblocks; i++)
{
blocks [i * 2] = i + nblocks;
blocks [i * 2 + 1] = i;
}
+
/* DS2 DMA notes: base may or may not be 32-byte aligned */
- uint8_t* tmp = (uint8_t*) malloc(0x8000);
+ tmp = (uint8_t*) malloc(0x8000);
+
if (tmp)
{
for (i = 0; i < nblocks * 2; i++)
@@ -61,6 +65,8 @@ void S9xDeinterleaveType1(int32_t TotalFileSize, uint8_t* base)
{
if (blocks [j] == i)
{
+ uint8_t b;
+
/* memmove converted: Different mallocs [Neb] */
memcpy(tmp, &base [blocks [j] * 0x8000], 0x8000);
/* memmove converted: Different addresses, or identical for blocks[i] == blocks[j] [Neb] */
@@ -69,7 +75,7 @@ void S9xDeinterleaveType1(int32_t TotalFileSize, uint8_t* base)
&base [blocks [i] * 0x8000], 0x8000);
/* memmove converted: Different mallocs [Neb] */
memcpy(&base [blocks [i] * 0x8000], tmp, 0x8000);
- uint8_t b = blocks [j];
+ b = blocks [j];
blocks [j] = blocks [i];
blocks [i] = b;
break;
@@ -82,11 +88,13 @@ void S9xDeinterleaveType1(int32_t TotalFileSize, uint8_t* base)
void S9xDeinterleaveGD24(int32_t TotalFileSize, uint8_t* base)
{
+ uint8_t *tmp = NULL;
if (TotalFileSize != 0x300000)
return;
/* DS2 DMA notes: base may or may not be 32-byte aligned */
- uint8_t* tmp = (uint8_t*) malloc(0x80000);
+ tmp = (uint8_t*) malloc(0x80000);
+
if (tmp)
{
/* memmove converted: Different mallocs [Neb] */
@@ -201,6 +209,8 @@ static char* Safe(const char* s)
{
static char* safe;
static int32_t safe_len = 0;
+ int32_t i;
+ int32_t len;
if (s == NULL)
{
@@ -211,7 +221,9 @@ static char* Safe(const char* s)
}
return NULL;
}
- int32_t len = strlen(s);
+
+ len = strlen(s);
+
if (!safe || len + 1 > safe_len)
{
if (safe)
@@ -219,7 +231,6 @@ static char* Safe(const char* s)
safe = (char*) malloc(safe_len = len + 1);
}
- int32_t i;
for (i = 0; i < len; i++)
{
if (s [i] >= 32 && s [i] < 127)
@@ -284,6 +295,7 @@ bool S9xInitMemory(void)
void S9xDeinitMemory(void)
{
+ int t;
if (Memory.RAM)
{
free(Memory.RAM);
@@ -316,7 +328,6 @@ void S9xDeinitMemory(void)
Memory.BSRAM = NULL;
}
- int t;
for (t = 0; t < 2; t++)
{
if (IPPU.TileCache[t])
@@ -999,6 +1010,10 @@ void S9xDeinterleaveType2(bool reset)
void InitROM(bool Interleaved)
{
+ uint8_t* RomHeader;
+ uint32_t sum1 = 0;
+ uint32_t sum2 = 0;
+
SuperFX.nRomBanks = Memory.CalculatedSize >> 15;
Settings.MultiPlayer5Master = Settings.MultiPlayer5;
Settings.MouseMaster = Settings.Mouse;
@@ -1017,7 +1032,6 @@ void InitROM(bool Interleaved)
Settings.SETA = false;
s7r.DataRomSize = 0;
Memory.CalculatedChecksum = 0;
- uint8_t* RomHeader;
RomHeader = Memory.ROM + 0x7FB0;
@@ -1236,20 +1250,19 @@ void InitROM(bool Interleaved)
if (Settings.BS)
Memory.ROMRegion = 0;
- uint32_t sum1 = 0;
- uint32_t sum2 = 0;
if (!Memory.CalculatedChecksum)
{
+ int32_t i;
+ uint32_t remainder;
int32_t power2 = 0;
+ int32_t sub = 0;
int32_t size = Memory.CalculatedSize;
while (size >>= 1)
power2++;
- size = 1 << power2;
- uint32_t remainder = Memory.CalculatedSize - size;
-
- int32_t i;
+ size = 1 << power2;
+ remainder = Memory.CalculatedSize - size;
for (i = 0; i < size; i++)
sum1 += Memory.ROM [i];
@@ -1257,7 +1270,6 @@ void InitROM(bool Interleaved)
for (i = 0; i < (int32_t) remainder; i++)
sum2 += Memory.ROM [size + i];
- int32_t sub = 0;
if (Settings.BS && Memory.ROMType != 0xE5)
{
if (Memory.HiROM)
@@ -1399,9 +1411,10 @@ void map_index(uint32_t bank_s, uint32_t bank_e, uint32_t addr_s, uint32_t addr_
void WriteProtectROM(void)
{
+ int32_t c;
+
/* memmove converted: Different mallocs [Neb] */
memcpy(Memory.WriteMap, Memory.Map, sizeof(Memory.Map));
- int32_t c;
for (c = 0; c < 0x1000; c++)
if (Memory.BlockIsROM [c])
Memory.WriteMap [c] = (uint8_t*) MAP_NONE;
@@ -1722,6 +1735,7 @@ void TalesROMMap(bool Interleaved)
{
int32_t c;
int32_t i;
+ int32_t sum = 0;
uint32_t OFFSET0 = 0x400000;
uint32_t OFFSET1 = 0x400000;
@@ -1788,7 +1802,6 @@ void TalesROMMap(bool Interleaved)
Memory.ROMChecksum = *(Memory.Map[8] + 0xFFDE) + (*(Memory.Map[8] + 0xFFDF) << 8);
Memory.ROMComplementChecksum = *(Memory.Map[8] + 0xFFDC) + (*(Memory.Map[8] + 0xFFDD) << 8);
- int32_t sum = 0;
for (i = 0x40; i < 0x80; i++)
{
uint8_t* bank_low = (uint8_t*)Memory.Map[i << 4];
@@ -2264,6 +2277,7 @@ void JumboLoROMMap(bool Interleaved)
{
int32_t c;
int32_t i;
+ int32_t sum = 0, k, l;
uint32_t OFFSET0 = 0x400000;
uint32_t OFFSET2 = 0x000000;
@@ -2343,7 +2357,6 @@ void JumboLoROMMap(bool Interleaved)
}
/* ROM type has to be 64 Mbit header! */
- int32_t sum = 0, k, l;
for (k = 0; k < 256; k++)
{
uint8_t* bank = 0x8000 + Memory.Map[8 + (k << 4)]; /* use upper half of the banks, and adjust for LoROM. */
@@ -2359,6 +2372,7 @@ void SPC7110HiROMMap(void)
{
int32_t c;
int32_t i;
+ int32_t sum = 0;
/* Banks 00->3f and 80->bf */
for (c = 0; c < 0x400; c += 16)
@@ -2421,7 +2435,6 @@ void SPC7110HiROMMap(void)
}
S9xSpc7110Init();
- int32_t sum = 0;
for (i = 0; i < (int32_t)Memory.CalculatedSize; i++)
sum += Memory.ROM[i];
@@ -3000,6 +3013,8 @@ void ParseSNESHeader(uint8_t* RomHeader)
{
if(Settings.BS)
{
+ uint32_t size_count;
+
Memory.SRAMSize = 0x05;
strncpy(Memory.ROMName, (char *) &RomHeader[0x10], 17);
memset(&Memory.ROMName[0x11], 0, ROM_NAME_LEN - 1 - 17);
@@ -3007,7 +3022,6 @@ void ParseSNESHeader(uint8_t* RomHeader)
Memory.ROMType = 0xe5;
Memory.ROMSize = 1;
- uint32_t size_count;
for(size_count = 0x800; size_count < Memory.CalculatedSize; size_count <<= 1, ++Memory.ROMSize);
}
else