TI-NESulator SVN reimport

This commit is contained in:
godzil
2008-02-20 15:40:31 +00:00
commit 3f4b4990ea
67 changed files with 19026 additions and 0 deletions

348
src/ppu/debug/ppu.debug.c Normal file
View File

@@ -0,0 +1,348 @@
#include <stdio.h>
#include <stdlib.h>
#include <allegro.h>
#define __TINES_PPU_INTERNAL__
#include <ppu/ppu.h>
#include <ppu/ppu.memory.h>
#include <ppu/ppu.debug.h>
#include <types.h>
extern BITMAP *Buffer;
extern unsigned short ppu_spritePatternTable;
extern short PPU_Reg_S;
void DebugColor()
{
#ifdef TO_MAKE
static unsigned short x = 128;
static unsigned short y = 128;
unsigned char OldDisplayPalette = ppu.DisplayPalette;
byte keyb;
unsigned int i;
unsigned long Color;
NOBLIT = 1;
ppu.DisplayPalette = ~0;
while(!key[KEY_ESC])
{
frame++;
PPUVBlank();
Color = /*Buffer->line[y][x]*/ _getpixel(Buffer, x, y);
textprintf(Buffer, font, 5, 340, GetColor(3), "Pos [%d:%d] Color: %d Bg: %d", x, y, Color, BgColor);
line(Buffer, x-10, y, x+10, y, GetColor(1));
line(Buffer, x, y-10, x, y+10, GetColor(1));
/*
rect(Buffer, 0, 255, 4 * 20 + 2, 255 + 4 * 20 + 2, 0);
rect(Buffer, 90, 255, 90 + 4 * 20 + 2, 255 + 4 * 20 + 2, 0);
for (i = 0; i < 16; i++)
{
rectfill(Buffer, 1 + (i % 4) * 20, 256 + (i / 4) * 20, 1 + (i % 4) * 20 + 20, 256 + (i / 4) * 20 + 20, PPU_Rd(0x3F00 + i]);
rectfill(Buffer, 91 + (i % 4) * 20, 256 + (i / 4) * 20, 91 + (i % 4) * 20 + 20, 256 + (i / 4) * 20 + 20, PPU_Rd(0x3F10 + i]);
}*/
for( i = 0; i < 16; i++)
{
if (GetColor(PPU_Rd(0x3F00 + i]) == Color)
{
line(Buffer, 1+(i%4)*20, 256 + (i / 4) * 20, 1 + (i % 4) * 20 + 20, 256 + (i / 4) * 20 + 20, 0xFFFFFFFF);
line(Buffer, 1+(i%4)*20, 256 + (i / 4) * 20 + 20, 1 + (i % 4) * 20 + 20, 256 + (i / 4) * 20, 0xFFFFFFFF);
}
if (GetColor(PPU_Rd(0x3F10 + i]) == Color)
{
line(Buffer, 91+(i%4)*20, 256 + (i / 4) * 20, 91 + (i % 4) * 20 + 20, 256 + (i / 4) * 20 + 20, 0xFFFFFFFF);
line(Buffer, 91+(i%4)*20, 256 + (i / 4) * 20 + 20, 91 + (i % 4) * 20 + 20, 256 + (i / 4) * 20, 0xFFFFFFFF);
}
}
blit(Buffer, screen, 0, 0, 0, 0, 512 + 256, 480);
if (keypressed())
{
keyb = (readkey() & 0xFF);
if (keyb == '4')
{
x--;
}
if (keyb == '8')
{
y--;
}
if (keyb == '6')
{
x++;
}
if (keyb == '2')
{
y++;
}
}
}
ppu.DisplayPalette = OldDisplayPalette;
NOBLIT = 0;
#endif
}
void DebugSprites()
{
#ifdef TO_MAKE
byte keyb;
static int SelSprite = 0;
PPUSprite sprite;
NOBLIT = 1;
ppu.ControlRegister2.b |= PPU_CR2_SPRTVISIBILITY;
while(!key[KEY_ESC])
{
frame++;
PPUVBlank();
sprite = PPUGetSprite(SelSprite);
if (ppu.ControlRegister1.b & PPU_CR1_SPRTSIZE)
{
rect(Buffer, sprite.x-1, sprite.y-1, sprite.x+9, sprite.y+17, 1);
}
else
{
rect(Buffer, sprite.x-1, sprite.y-1, sprite.x+9, sprite.y+9, 1);
}
textprintf(Buffer, font, 5, 340, GetColor(3), "Sprite %d [%d:%d]", SelSprite, sprite.x, sprite.y);
textprintf(Buffer, font, 5, 349, GetColor(3), "B0: 0x%X B1: 0x%X B2: 0x%X B3: 0x%X",sprite.y,sprite.tileid,sprite.flags.b,sprite.x);
textprintf(Buffer, font, 5, 358, GetColor(3), "Tile Index: %d", sprite.tileid);
textprintf(Buffer, font, 5, 367, GetColor(3), "Vertical Flip: %d", sprite.flags.s.VFlip);
textprintf(Buffer, font, 5, 376, GetColor(3), "Horizontal Flip: %d", sprite.flags.s.HFlip);
textprintf(Buffer, font, 5, 385, GetColor(3), "Background Priority: %d", sprite.flags.s.BgPrio);
textprintf(Buffer, font, 5, 394, GetColor(3), "Upper Color: %d", sprite.flags.s.UpperColor);
blit(Buffer, screen, 0, 0, 0, 0, 512 + 256, 480);
if (keypressed())
{
keyb = (readkey() & 0xFF);
if (keyb == '+')
SelSprite = (SelSprite<63)?SelSprite+1:0;
if (keyb == '-')
SelSprite = (SelSprite>0)?SelSprite-1:63;
if (keyb == 'h')
{
sprite.flags.s.HFlip = ~sprite.flags.s.HFlip;
PPUSetSprite(SelSprite, &sprite);
}
if (keyb == 'b')
{
sprite.flags.s.BgPrio = ~sprite.flags.s.BgPrio;
PPUSetSprite(SelSprite, &sprite);
}
if (keyb == 'v')
{
sprite.flags.s.VFlip = ~sprite.flags.s.VFlip;
PPUSetSprite(SelSprite, &sprite);
}
if (keyb == '4')
{
sprite.x--;
PPUSetSprite(SelSprite, &sprite);
}
if (keyb == '8')
{
sprite.y--;
PPUSetSprite(SelSprite, &sprite);
}
if (keyb == '6')
{
sprite.x++;
PPUSetSprite(SelSprite, &sprite);
}
if (keyb == '2')
{
sprite.y++;
PPUSetSprite(SelSprite, &sprite);
}
}
}
NOBLIT = 0;
#endif
}
#define GetTilePos(addr,x,y) (addr+x+(y*32))
#define GetTileColor(tile,x1,y1) ( ( ppu_readMemory(((tile+y1)>>8)&0xFF, (tile+y1) & 0xFF) & (1<<(7-x1)) ) == 0 ? 0 : 1 ) | \
( ( ppu_readMemory(((tile+y1+8)>>8) & 0xFF, (tile+y1+8) &0xFF) & (1<<(7-x1)) ) == 0 ? 0 : 1<<1 )
#define PPU_Rd(addr) ppu_readMemory((addr>>8)&0xFF, addr&0xFF)
void ppu_dumpOneNameTable(unsigned short nametable, int xd, int yd)
{
byte x,y, x1, y1, Color;
unsigned short TileID;
for (x = 0; x < 32; x++)
for (y = 0; y < 30; y++)
{
TileID = (PPU_Rd(0x2000 + nametable + x + (y * 32)) << 4) | (PPU_Reg_S);
for (x1 = 0; x1 < 8; x1++)
for (y1 = 0; y1 < 8; y1++)
{
Color = GetTileColor(TileID, x1, y1);
// if (ppu.DisplayAttributeTable != 0)
// Color |= (Buffer->line[(8 * y) + 240 + y1][(8 * x) + 256 + x1] & 0x3) << 2;
Color += (nametable>>8);
Color = ppu_readMemory(0x3F, Color);
_putpixel(Buffer, (8 * x) + xd + x1, (8 * y) + yd + y1, Color);
}
}
}
void ppu_dumpOneAttributeTable(unsigned short nametable, int xd, int yd)
{
int x, y, x1, y1, Color, AttrByte;
for (x = 0; x < 0x40; x++)
{
AttrByte = PPU_Rd(nametable + 0x23C0 + x);
x1 = x % 8;
y1 = x / 8;
Color = AttrByte & 0x3; // Pattern 1;
// Color = PPU_Rd(0x3F00 + (Color * 4) + 1);
rectfill(Buffer,xd+(x1*32),yd+(y1*32),xd+15+(x1*32),yd+15+(y1*32),Color);
textprintf_ex(Buffer, font, 4+xd+(x1*32), 4+yd+(y1*32), ~Color, Color, "%X", Color);
Color = (AttrByte>>2) & 0x3; // Pattern 2;
// Color = PPU_Rd(0x3F00 + (Color * 4) + 1);
rectfill(Buffer,16+xd+(x1*32),yd+(y1*32),16+xd+15+(x1*32),yd+15+(y1*32),Color);
textprintf_ex(Buffer, font, 4+xd+(x1*32)+16, 4+yd+(y1*32), ~Color, Color, "%X", Color);
Color = (AttrByte>>4) & 0x3; // Pattern 3;
// Color = PPU_Rd(0x3F00 + (Color * 4) + 1);
rectfill(Buffer,xd+(x1*32),16+yd+(y1*32),xd+15+(x1*32),16+yd+15+(y1*32),Color);
textprintf_ex(Buffer, font, 4+xd+(x1*32), 4+yd+(y1*32)+16, ~Color, Color, "%X", Color);
Color = (AttrByte>>6) & 0x3; // Pattern 4;
// Color = PPU_Rd(0x3F00 + (Color * 4) + 1);
rectfill(Buffer,16+xd+(x1*32),16+yd+(y1*32),16+xd+15+(x1*32),16+yd+15+(y1*32),Color);
textprintf_ex(Buffer, font, 4+xd+(x1*32)+16, 4+yd+(y1*32)+16, ~Color, Color, "%X", Color);
rect(Buffer, xd+(x1*32), yd+(y1*32), xd+(x1*32) + 31 , yd+(y1*32) + 31, 1);
line(Buffer, xd+(x1*32)+16, yd+(y1*32), xd+(x1*32) + 16 , yd+(y1*32) + 31, 5);
line(Buffer, xd+(x1*32), yd+(y1*32)+16, xd+(x1*32) + 31 , yd+(y1*32) + 16, 5);
}
}
extern byte *ppu_mem_nameTables;
extern int ppu_screenMode;
void ppu_dumpNameTable(int xd, int yd)
{
// ppu_setPagePtr1k(0x20, ppu_mem_nameTables + 0x000);
// ppu_setPagePtr1k(0x24, ppu_mem_nameTables + 0x400);
// ppu_setPagePtr1k(0x28, ppu_mem_nameTables + 0x800);
// ppu_setPagePtr1k(0x2C, ppu_mem_nameTables + 0xC00);
ppu_dumpOneNameTable(0x800, xd , yd);
ppu_dumpOneNameTable(0xC00, xd + 256, yd);
ppu_dumpOneNameTable(0x000, xd , yd + 240);
ppu_dumpOneNameTable(0x400, xd + 256, yd + 240);
// ppu_setScreenMode(ppu_screenMode);
}
void ppu_dumpAttributeTable(int xd, int yd)
{
ppu_dumpOneAttributeTable(0x800, xd , yd);
ppu_dumpOneAttributeTable(0xC00, xd + 256, yd);
ppu_dumpOneAttributeTable(0x000, xd , yd + 240);
ppu_dumpOneAttributeTable(0x400, xd + 256, yd + 240);
}
void ppu_dumpPattern(int xd, int yd)
{
int x1, y1, x, y, Color, i, TileID;
/* y:346 */
x1 = 0;
y1 = 0;
for (i = 0; i < 256; i++)
{
TileID = 0x0000 + (i << 4);
for (x = 0; x < 8; x++)
for (y = 0; y < 8; y++)
{
Color = GetTileColor(TileID, x, y);
_putpixel(Buffer, 10 + x1 + x, 347 + y1 + y, /*ppu_readMemory(0x3F,*/ Color/*)*/);
}
x1 += 8;
if (x1 >= 128)
{
x1 = 0;
y1 += 8;
}
}
x1 = 0;
y1 = 0;
for (i = 0; i < 256; i++)
{
TileID = 0x1000 + (i << 4);
for (x = 0; x < 8; x++)
for (y = 0; y < 8; y++)
{
Color = GetTileColor(TileID, x, y);
_putpixel(Buffer, 10 + 128 + x1 + x, 347 + y1 + y, /*ppu_readMemory(0x3F,*/ 0x10 | Color/*)*/ );
}
x1 += 8;
if (x1 >= 128)
{
x1 = 0;
y1 += 8;
}
}
}
void ppu_dumpPalette(int x, int y)
{
int i;
textout(Buffer, font, "Bg Palette", x , y, 5);
textout(Buffer, font, "Sprt Palette", x + 90, y, 5);
rect(Buffer, x+0, y+20, x+4 * 20 + 2, y + 4 * 20 + 22, 0);
rect(Buffer, x+90, y+20, x+90 + 4 * 20 + 2, y + 4 * 20 + 22, 0);
for (i = 0; i < 16; i++)
{
rectfill(Buffer, x + 1 + (i % 4) * 20, y + 21 + (i / 4) * 20, x + 1 + (i % 4) * 20 + 20, y + 21 + (i / 4) * 20 + 20, ppu_readMemory(0x3F, i));
rectfill(Buffer, x + 91 + (i % 4) * 20, y + 21 +(i / 4) * 20, x + 91 + (i % 4) * 20 + 20, y + 21 +(i / 4) * 20 + 20, ppu_readMemory(0x3F, i+0x10));
}
}