Source to src/identify.c
/*
* UAE - The Un*x Amiga Emulator
*
* Routines for labelling amiga internals.
*
*/
#include "sysconfig.h"
#include "sysdeps.h"
#include "memory.h"
#include "identify.h"
struct mem_labels int_labels[] =
{
{ "Reset:SSP", 0x0000 },
{ "EXECBASE", 0x0004 },
{ "BUS ERROR", 0x0008 },
{ "ADR ERROR", 0x000C },
{ "ILLEG OPC", 0x0010 },
{ "DIV BY 0", 0x0014 },
{ "CHK", 0x0018 },
{ "TRAPV", 0x001C },
{ "PRIVIL VIO", 0x0020 },
{ "TRACE", 0x0024 },
{ "LINEA EMU", 0x0028 },
{ "LINEF EMU", 0x002C },
{ "INT Uninit", 0x003C },
{ "INT Unjust", 0x0060 },
{ "Lvl 1 Int", 0x0064 },
{ "Lvl 2 Int", 0x0068 },
{ "Lvl 3 Int", 0x006C },
{ "Lvl 4 Int", 0x0070 },
{ "Lvl 5 Int", 0x0074 },
{ "Lvl 6 Int", 0x0078 },
{ "NMI", 0x007C },
{ 0, 0 }
};
struct mem_labels trap_labels[] =
{
{ "TRAP 00", 0x0080 },
{ "TRAP 01", 0x0084 },
{ "TRAP 02", 0x0088 },
{ "TRAP 03", 0x008C },
{ "TRAP 04", 0x0090 },
{ "TRAP 05", 0x0094 },
{ "TRAP 06", 0x0098 },
{ "TRAP 07", 0x009C },
{ "TRAP 08", 0x00A0 },
{ "TRAP 09", 0x00A4 },
{ "TRAP 10", 0x00A8 },
{ "TRAP 11", 0x00AC },
{ "TRAP 12", 0x00B0 },
{ "TRAP 13", 0x00B4 },
{ "TRAP 14", 0x00B8 },
{ "TRAP 15", 0x00BC },
{ 0, 0 }
};
struct mem_labels mem_labels[] =
{
{ "CIAB PRA", 0xBFD000 },
{ "CIAB PRB", 0xBFD100 },
{ "CIAB DDRA", 0xBFD200 },
{ "CIAB DDRB", 0xBFD300 },
{ "CIAB TALO", 0xBFD400 },
{ "CIAB TAHI", 0xBFD500 },
{ "CIAB TBLO", 0xBFD600 },
{ "CIAB TBHI", 0xBFD700 },
{ "CIAB TDLO", 0xBFD800 },
{ "CIAB TDMD", 0xBFD900 },
{ "CIAB TDHI", 0xBFDA00 },
{ "CIAB SDR", 0xBFDC00 },
{ "CIAB ICR", 0xBFDD00 },
{ "CIAB CRA", 0xBFDE00 },
{ "CIAB CRB", 0xBFDF00 },
{ "CIAA PRA", 0xBFE001 },
{ "CIAA PRB", 0xBFE101 },
{ "CIAA DDRA", 0xBFE201 },
{ "CIAA DDRB", 0xBFE301 },
{ "CIAA TALO", 0xBFE401 },
{ "CIAA TAHI", 0xBFE501 },
{ "CIAA TBLO", 0xBFE601 },
{ "CIAA TBHI", 0xBFE701 },
{ "CIAA TDLO", 0xBFE801 },
{ "CIAA TDMD", 0xBFE901 },
{ "CIAA TDHI", 0xBFEA01 },
{ "CIAA SDR", 0xBFEC01 },
{ "CIAA ICR", 0xBFED01 },
{ "CIAA CRA", 0xBFEE01 },
{ "CIAA CRB", 0xBFEF01 },
{ "CLK S1", 0xDC0000 },
{ "CLK S10", 0xDC0004 },
{ "CLK MI1", 0xDC0008 },
{ "CLK MI10", 0xDC000C },
{ "CLK H1", 0xDC0010 },
{ "CLK H10", 0xDC0014 },
{ "CLK D1", 0xDC0018 },
{ "CLK D10", 0xDC001C },
{ "CLK MO1", 0xDC0020 },
{ "CLK MO10", 0xDC0024 },
{ "CLK Y1", 0xDC0028 },
{ "CLK Y10", 0xDC002E },
{ "CLK WEEK", 0xDC0030 },
{ "CLK CD", 0xDC0034 },
{ "CLK CE", 0xDC0038 },
{ "CLK CF", 0xDC003C },
{ NULL, 0 }
};
/* This table was generated from the list of AGA chip names in
* AGA.guide available on aminet. It could well have errors in it. */
struct customData custd[] =
{
#if 0
{ "BLTDDAT", 0xdff000 }, /* Blitter dest. early read (dummy address) */
#endif
{ "DMACONR", 0xdff002, 1, 0 }, /* Dma control (and blitter status) read */
{ "VPOSR", 0xdff004, 1, 0 }, /* Read vert most sig. bits (and frame flop */
{ "VHPOSR", 0xdff006, 1, 0 }, /* Read vert and horiz position of beam */
#if 0
{ "DSKDATR", 0xdff008 }, /* Disk data early read (dummy address) */
#endif
{ "JOY0DAT", 0xdff00A, 1, 0 }, /* Joystick-mouse 0 data (vert,horiz) */
{ "JOT1DAT", 0xdff00C, 1, 0 }, /* Joystick-mouse 1 data (vert,horiz) */
{ "CLXDAT", 0xdff00E, 1, 0 }, /* Collision data reg. (read and clear) */
{ "ADKCONR", 0xdff010, 1, 0 }, /* Audio,disk control register read */
{ "POT0DAT", 0xdff012, 1, 0 }, /* Pot counter pair 0 data (vert,horiz) */
{ "POT1DAT", 0xdff014, 1, 0 }, /* Pot counter pair 1 data (vert,horiz) */
{ "POTGOR", 0xdff016, 1, 0 }, /* Pot pin data read */
{ "SERDATR", 0xdff018, 1, 0 }, /* Serial port data and status read */
{ "DSKBYTR", 0xdff01A, 1, 0 }, /* Disk data byte and status read */
{ "INTENAR", 0xdff01C, 1, 0 }, /* Interrupt enable bits read */
{ "INTREQR", 0xdff01E, 1, 0 }, /* Interrupt request bits read */
{ "DSKPTH", 0xdff020, 2, 1 }, /* Disk pointer (high 5 bits) */
{ "DSKPTL", 0xdff022, 2, 2 }, /* Disk pointer (low 15 bits) */
{ "DSKLEN", 0xdff024, 2, 0 }, /* Disk lentgh */
#if 0
{ "DSKDAT", 0xdff026 }, /* Disk DMA data write */
{ "REFPTR", 0xdff028 }, /* Refresh pointer */
#endif
{ "VPOSW", 0xdff02A, 2, 0 }, /* Write vert most sig. bits(and frame flop) */
{ "VHPOSW", 0xdff02C, 2, 0 }, /* Write vert and horiz pos of beam */
{ "COPCON", 0xdff02e, 2, 0 }, /* Coprocessor control reg (CDANG) */
{ "SERDAT", 0xdff030, 2, 0 }, /* Serial port data and stop bits write */
{ "SERPER", 0xdff032, 2, 0 }, /* Serial port period and control */
{ "POTGO", 0xdff034, 2, 0 }, /* Pot count start,pot pin drive enable data */
{ "JOYTEST", 0xdff036, 2, 0 }, /* Write to all 4 joystick-mouse counters at once */
{ "STREQU", 0xdff038, 2, 0 }, /* Strobe for horiz sync with VB and EQU */
{ "STRVBL", 0xdff03A, 2, 0 }, /* Strobe for horiz sync with VB (vert blank) */
{ "STRHOR", 0xdff03C, 2, 0 }, /* Strobe for horiz sync */
{ "STRLONG", 0xdff03E, 2, 0 }, /* Strobe for identification of long horiz line */
{ "BLTCON0", 0xdff040, 2, 0 }, /* Blitter control reg 0 */
{ "BLTCON1", 0xdff042, 2, 0 }, /* Blitter control reg 1 */
{ "BLTAFWM", 0xdff044, 2, 0 }, /* Blitter first word mask for source A */
{ "BLTALWM", 0xdff046, 2, 0 }, /* Blitter last word mask for source A */
{ "BLTCPTH", 0xdff048, 2, 1 }, /* Blitter pointer to source C (high 5 bits) */
{ "BLTCPTL", 0xdff04A, 2, 2 }, /* Blitter pointer to source C (low 15 bits) */
{ "BLTBPTH", 0xdff04C, 2, 1 }, /* Blitter pointer to source B (high 5 bits) */
{ "BLTBPTL", 0xdff04E, 2, 2 }, /* Blitter pointer to source B (low 15 bits) */
{ "BLTAPTH", 0xdff050, 2, 1 }, /* Blitter pointer to source A (high 5 bits) */
{ "BLTAPTL", 0xdff052, 2, 2 }, /* Blitter pointer to source A (low 15 bits) */
{ "BPTDPTH", 0xdff054, 2, 1 }, /* Blitter pointer to destn D (high 5 bits) */
{ "BLTDPTL", 0xdff056, 2, 2 }, /* Blitter pointer to destn D (low 15 bits) */
{ "BLTSIZE", 0xdff058, 2, 0 }, /* Blitter start and size (win/width,height) */
{ "BLTCON0L", 0xdff05A, 2, 0 }, /* Blitter control 0 lower 8 bits (minterms) */
{ "BLTSIZV", 0xdff05C, 2, 0 }, /* Blitter V size (for 15 bit vert size) */
{ "BLTSIZH", 0xdff05E, 2, 0 }, /* Blitter H size & start (for 11 bit H size) */
{ "BLTCMOD", 0xdff060, 2, 0 }, /* Blitter modulo for source C */
{ "BLTBMOD", 0xdff062, 2, 0 }, /* Blitter modulo for source B */
{ "BLTAMOD", 0xdff064, 2, 0 }, /* Blitter modulo for source A */
{ "BLTDMOD", 0xdff066, 2, 0 }, /* Blitter modulo for destn D */
#if 0
{ "Unknown", 0xdff068 }, /* Unknown or Unused */
{ "Unknown", 0xdff06a }, /* Unknown or Unused */
{ "Unknown", 0xdff06c }, /* Unknown or Unused */
{ "Unknown", 0xdff06e }, /* Unknown or Unused */
#endif
{ "BLTCDAT", 0xdff070, 2, 0 }, /* Blitter source C data reg */
{ "BLTBDAT", 0xdff072, 2, 0 }, /* Blitter source B data reg */
{ "BLTADAT", 0xdff074, 2, 0 }, /* Blitter source A data reg */
{ "BLTDDAT", 0xdff076, 2, 0 }, /* Blitter destination reg */
#if 0
{ "SPRHDAT", 0xdff078 }, /* Ext logic UHRES sprite pointer and data identifier */
{ "BPLHDAT", 0xdff07A }, /* Ext logic UHRES bit plane identifier */
#endif
{ "LISAID", 0xdff07C, 1, 0 }, /* Chip revision level for Denise/Lisa */
{ "DSKSYNC", 0xdff07E, 2, 0 }, /* Disk sync pattern reg for disk read */
{ "COP1LCH", 0xdff080, 2, 1 }, /* Coprocessor first location reg (high 5 bits) */
{ "COP1LCL", 0xdff082, 2, 2 }, /* Coprocessor first location reg (low 15 bits) */
{ "COP2LCH", 0xdff084, 2, 1 }, /* Coprocessor second reg (high 5 bits) */
{ "COP2LCL", 0xdff086, 2, 2 }, /* Coprocessor second reg (low 15 bits) */
{ "COPJMP1", 0xdff088, 2, 0 }, /* Coprocessor restart at first location */
{ "COPJMP2", 0xdff08A, 2, 0 }, /* Coprocessor restart at second location */
#if 0
{ "COPINS", 0xdff08C }, /* Coprocessor inst fetch identify */
#endif
{ "DIWSTRT", 0xdff08E, 2, 0 }, /* Display window start (upper left vert-hor pos) */
{ "DIWSTOP", 0xdff090, 2, 0 }, /* Display window stop (lower right vert-hor pos) */
{ "DDFSTRT", 0xdff092, 2, 0 }, /* Display bit plane data fetch start.hor pos */
{ "DDFSTOP", 0xdff094, 2, 0 }, /* Display bit plane data fetch stop.hor pos */
{ "DMACON", 0xdff096, 2, 0 }, /* DMA control write (clear or set) */
{ "CLXCON", 0xdff098, 2, 0 }, /* Collision control */
{ "INTENA", 0xdff09A, 2, 0 }, /* Interrupt enable bits (clear or set bits) */
{ "INTREQ", 0xdff09C, 2, 0 }, /* Interrupt request bits (clear or set bits) */
{ "ADKCON", 0xdff09E, 2, 0 }, /* Audio,disk,UART,control */
{ "AUD0LCH", 0xdff0A0, 2, 1 }, /* Audio channel 0 location (high 5 bits) */
{ "AUD0LCL", 0xdff0A2, 2, 2 }, /* Audio channel 0 location (low 15 bits) */
{ "AUD0LEN", 0xdff0A4, 2, 0 }, /* Audio channel 0 lentgh */
{ "AUD0PER", 0xdff0A6, 2, 0 }, /* Audio channel 0 period */
{ "AUD0VOL", 0xdff0A8, 2, 0 }, /* Audio channel 0 volume */
{ "AUD0DAT", 0xdff0AA, 2, 0 }, /* Audio channel 0 data */
#if 0
{ "Unknown", 0xdff0AC }, /* Unknown or Unused */
{ "Unknown", 0xdff0AE }, /* Unknown or Unused */
#endif
{ "AUD1LCH", 0xdff0B0, 2, 0 }, /* Audio channel 1 location (high 5 bits) */
{ "AUD1LCL", 0xdff0B2, 2, 0 }, /* Audio channel 1 location (low 15 bits) */
{ "AUD1LEN", 0xdff0B4, 2, 0 }, /* Audio channel 1 lentgh */
{ "AUD1PER", 0xdff0B6, 2, 0 }, /* Audio channel 1 period */
{ "AUD1VOL", 0xdff0B8, 2, 0 }, /* Audio channel 1 volume */
{ "AUD1DAT", 0xdff0BA, 2, 0 }, /* Audio channel 1 data */
#if 0
{ "Unknown", 0xdff0BC }, /* Unknown or Unused */
{ "Unknown", 0xdff0BE }, /* Unknown or Unused */
#endif
{ "AUD2LCH", 0xdff0C0, 2, 0 }, /* Audio channel 2 location (high 5 bits) */
{ "AUD2LCL", 0xdff0C2, 2, 0 }, /* Audio channel 2 location (low 15 bits) */
{ "AUD2LEN", 0xdff0C4, 2, 0 }, /* Audio channel 2 lentgh */
{ "AUD2PER", 0xdff0C6, 2, 0 }, /* Audio channel 2 period */
{ "AUD2VOL", 0xdff0C8, 2, 0 }, /* Audio channel 2 volume */
{ "AUD2DAT", 0xdff0CA, 2, 0 }, /* Audio channel 2 data */
#if 0
{ "Unknown", 0xdff0CC }, /* Unknown or Unused */
{ "Unknown", 0xdff0CE }, /* Unknown or Unused */
#endif
{ "AUD3LCH", 0xdff0D0, 2, 0 }, /* Audio channel 3 location (high 5 bits) */
{ "AUD3LCL", 0xdff0D2, 2, 0 }, /* Audio channel 3 location (low 15 bits) */
{ "AUD3LEN", 0xdff0D4, 2, 0 }, /* Audio channel 3 lentgh */
{ "AUD3PER", 0xdff0D6, 2, 0 }, /* Audio channel 3 period */
{ "AUD3VOL", 0xdff0D8, 2, 0 }, /* Audio channel 3 volume */
{ "AUD3DAT", 0xdff0DA, 2, 0 }, /* Audio channel 3 data */
#if 0
{ "Unknown", 0xdff0DC }, /* Unknown or Unused */
{ "Unknown", 0xdff0DE }, /* Unknown or Unused */
#endif
{ "BPL1PTH", 0xdff0E0, 2, 0 }, /* Bit plane pointer 1 (high 5 bits) */
{ "BPL1PTL", 0xdff0E2, 2, 0 }, /* Bit plane pointer 1 (low 15 bits) */
{ "BPL2PTH", 0xdff0E4, 2, 0 }, /* Bit plane pointer 2 (high 5 bits) */
{ "BPL2PTL", 0xdff0E6, 2, 0 }, /* Bit plane pointer 2 (low 15 bits) */
{ "BPL3PTH", 0xdff0E8, 2, 0 }, /* Bit plane pointer 3 (high 5 bits) */
{ "BPL3PTL", 0xdff0EA, 2, 0 }, /* Bit plane pointer 3 (low 15 bits) */
{ "BPL4PTH", 0xdff0EC, 2, 0 }, /* Bit plane pointer 4 (high 5 bits) */
{ "BPL4PTL", 0xdff0EE, 2, 0 }, /* Bit plane pointer 4 (low 15 bits) */
{ "BPL5PTH", 0xdff0F0, 2, 0 }, /* Bit plane pointer 5 (high 5 bits) */
{ "BPL5PTL", 0xdff0F2, 2, 0 }, /* Bit plane pointer 5 (low 15 bits) */
{ "BPL6PTH", 0xdff0F4, 2, 0 }, /* Bit plane pointer 6 (high 5 bits) */
{ "BPL6PTL", 0xdff0F6, 2, 0 }, /* Bit plane pointer 6 (low 15 bits) */
{ "BPL7PTH", 0xdff0F8, 2, 0 }, /* Bit plane pointer 7 (high 5 bits) */
{ "BPL7PTL", 0xdff0FA, 2, 0 }, /* Bit plane pointer 7 (low 15 bits) */
{ "BPL8PTH", 0xdff0FC, 2, 0 }, /* Bit plane pointer 8 (high 5 bits) */
{ "BPL8PTL", 0xdff0FE, 2, 0 }, /* Bit plane pointer 8 (low 15 bits) */
{ "BPLCON0", 0xdff100, 2, 0 }, /* Bit plane control reg (misc control bits) */
{ "BPLCON1", 0xdff102, 2, 0 }, /* Bit plane control reg (scroll val PF1,PF2) */
{ "BPLCON2", 0xdff104, 2, 0 }, /* Bit plane control reg (priority control) */
{ "BPLCON3", 0xdff106, 2, 0 }, /* Bit plane control reg (enhanced features) */
{ "BPL1MOD", 0xdff108, 2, 0 }, /* Bit plane modulo (odd planes,or active- fetch lines if bitplane scan-doubling is enabled */
{ "BPL2MOD", 0xdff10A, 2, 0 }, /* Bit plane modulo (even planes or inactive- fetch lines if bitplane scan-doubling is enabled */
{ "BPLCON4", 0xdff10C, 2, 0 }, /* Bit plane control reg (bitplane and sprite masks) */
{ "CLXCON2", 0xdff10e, 2, 0 }, /* Extended collision control reg */
{ "BPL1DAT", 0xdff110, 2, 0 }, /* Bit plane 1 data (parallel to serial con- vert) */
{ "BPL2DAT", 0xdff112, 2, 0 }, /* Bit plane 2 data (parallel to serial con- vert) */
{ "BPL3DAT", 0xdff114, 2, 0 }, /* Bit plane 3 data (parallel to serial con- vert) */
{ "BPL4DAT", 0xdff116, 2, 0 }, /* Bit plane 4 data (parallel to serial con- vert) */
{ "BPL5DAT", 0xdff118, 2, 0 }, /* Bit plane 5 data (parallel to serial con- vert) */
{ "BPL6DAT", 0xdff11a, 2, 0 }, /* Bit plane 6 data (parallel to serial con- vert) */
{ "BPL7DAT", 0xdff11c, 2, 0 }, /* Bit plane 7 data (parallel to serial con- vert) */
{ "BPL8DAT", 0xdff11e, 2, 0 }, /* Bit plane 8 data (parallel to serial con- vert) */
{ "SPR0PTH", 0xdff120, 2, 0 }, /* Sprite 0 pointer (high 5 bits) */
{ "SPR0PTL", 0xdff122, 2, 0 }, /* Sprite 0 pointer (low 15 bits) */
{ "SPR1PTH", 0xdff124, 2, 0 }, /* Sprite 1 pointer (high 5 bits) */
{ "SPR1PTL", 0xdff126, 2, 0 }, /* Sprite 1 pointer (low 15 bits) */
{ "SPR2PTH", 0xdff128, 2, 0 }, /* Sprite 2 pointer (high 5 bits) */
{ "SPR2PTL", 0xdff12A, 2, 0 }, /* Sprite 2 pointer (low 15 bits) */
{ "SPR3PTH", 0xdff12C, 2, 0 }, /* Sprite 3 pointer (high 5 bits) */
{ "SPR3PTL", 0xdff12E, 2, 0 }, /* Sprite 3 pointer (low 15 bits) */
{ "SPR4PTH", 0xdff130, 2, 0 }, /* Sprite 4 pointer (high 5 bits) */
{ "SPR4PTL", 0xdff132, 2, 0 }, /* Sprite 4 pointer (low 15 bits) */
{ "SPR5PTH", 0xdff134, 2, 0 }, /* Sprite 5 pointer (high 5 bits) */
{ "SPR5PTL", 0xdff136, 2, 0 }, /* Sprite 5 pointer (low 15 bits) */
{ "SPR6PTH", 0xdff138, 2, 0 }, /* Sprite 6 pointer (high 5 bits) */
{ "SPR6PTL", 0xdff13A, 2, 0 }, /* Sprite 6 pointer (low 15 bits) */
{ "SPR7PTH", 0xdff13C, 2, 0 }, /* Sprite 7 pointer (high 5 bits) */
{ "SPR7PTL", 0xdff13E, 2, 0 }, /* Sprite 7 pointer (low 15 bits) */
{ "SPR0POS", 0xdff140, 2, 0 }, /* Sprite 0 vert-horiz start pos data */
{ "SPR0CTL", 0xdff142, 2, 0 }, /* Sprite 0 position and control data */
{ "SPR0DATA", 0xdff144, 2, 0 }, /* Sprite 0 image data register A */
{ "SPR0DATB", 0xdff146, 2, 0 }, /* Sprite 0 image data register B */
{ "SPR1POS", 0xdff148, 2, 0 }, /* Sprite 1 vert-horiz start pos data */
{ "SPR1CTL", 0xdff14A, 2, 0 }, /* Sprite 1 position and control data */
{ "SPR1DATA", 0xdff14C, 2, 0 }, /* Sprite 1 image data register A */
{ "SPR1DATB", 0xdff14E, 2, 0 }, /* Sprite 1 image data register B */
{ "SPR2POS", 0xdff150, 2, 0 }, /* Sprite 2 vert-horiz start pos data */
{ "SPR2CTL", 0xdff152, 2, 0 }, /* Sprite 2 position and control data */
{ "SPR2DATA", 0xdff154, 2, 0 }, /* Sprite 2 image data register A */
{ "SPR2DATB", 0xdff156, 2, 0 }, /* Sprite 2 image data register B */
{ "SPR3POS", 0xdff158, 2, 0 }, /* Sprite 3 vert-horiz start pos data */
{ "SPR3CTL", 0xdff15A, 2, 0 }, /* Sprite 3 position and control data */
{ "SPR3DATA", 0xdff15C, 2, 0 }, /* Sprite 3 image data register A */
{ "SPR3DATB", 0xdff15E, 2, 0 }, /* Sprite 3 image data register B */
{ "SPR4POS", 0xdff160, 2, 0 }, /* Sprite 4 vert-horiz start pos data */
{ "SPR4CTL", 0xdff162, 2, 0 }, /* Sprite 4 position and control data */
{ "SPR4DATA", 0xdff164, 2, 0 }, /* Sprite 4 image data register A */
{ "SPR4DATB", 0xdff166, 2, 0 }, /* Sprite 4 image data register B */
{ "SPR5POS", 0xdff168, 2, 0 }, /* Sprite 5 vert-horiz start pos data */
{ "SPR5CTL", 0xdff16A, 2, 0 }, /* Sprite 5 position and control data */
{ "SPR5DATA", 0xdff16C, 2, 0 }, /* Sprite 5 image data register A */
{ "SPR5DATB", 0xdff16E, 2, 0 }, /* Sprite 5 image data register B */
{ "SPR6POS", 0xdff170, 2, 0 }, /* Sprite 6 vert-horiz start pos data */
{ "SPR6CTL", 0xdff172, 2, 0 }, /* Sprite 6 position and control data */
{ "SPR6DATA", 0xdff174, 2, 0 }, /* Sprite 6 image data register A */
{ "SPR6DATB", 0xdff176, 2, 0 }, /* Sprite 6 image data register B */
{ "SPR7POS", 0xdff178, 2, 0 }, /* Sprite 7 vert-horiz start pos data */
{ "SPR7CTL", 0xdff17A, 2, 0 }, /* Sprite 7 position and control data */
{ "SPR7DATA", 0xdff17C, 2, 0 }, /* Sprite 7 image data register A */
{ "SPR7DATB", 0xdff17E, 2, 0 }, /* Sprite 7 image data register B */
{ "COLOR00", 0xdff180, 2, 0 }, /* Color table 00 */
{ "COLOR01", 0xdff182, 2, 0 }, /* Color table 01 */
{ "COLOR02", 0xdff184, 2, 0 }, /* Color table 02 */
{ "COLOR03", 0xdff186, 2, 0 }, /* Color table 03 */
{ "COLOR04", 0xdff188, 2, 0 }, /* Color table 04 */
{ "COLOR05", 0xdff18A, 2, 0 }, /* Color table 05 */
{ "COLOR06", 0xdff18C, 2, 0 }, /* Color table 06 */
{ "COLOR07", 0xdff18E, 2, 0 }, /* Color table 07 */
{ "COLOR08", 0xdff190, 2, 0 }, /* Color table 08 */
{ "COLOR09", 0xdff192, 2, 0 }, /* Color table 09 */
{ "COLOR10", 0xdff194, 2, 0 }, /* Color table 10 */
{ "COLOR11", 0xdff196, 2, 0 }, /* Color table 11 */
{ "COLOR12", 0xdff198, 2, 0 }, /* Color table 12 */
{ "COLOR13", 0xdff19A, 2, 0 }, /* Color table 13 */
{ "COLOR14", 0xdff19C, 2, 0 }, /* Color table 14 */
{ "COLOR15", 0xdff19E, 2, 0 }, /* Color table 15 */
{ "COLOR16", 0xdff1A0, 2, 0 }, /* Color table 16 */
{ "COLOR17", 0xdff1A2, 2, 0 }, /* Color table 17 */
{ "COLOR18", 0xdff1A4, 2, 0 }, /* Color table 18 */
{ "COLOR19", 0xdff1A6, 2, 0 }, /* Color table 19 */
{ "COLOR20", 0xdff1A8, 2, 0 }, /* Color table 20 */
{ "COLOR21", 0xdff1AA, 2, 0 }, /* Color table 21 */
{ "COLOR22", 0xdff1AC, 2, 0 }, /* Color table 22 */
{ "COLOR23", 0xdff1AE, 2, 0 }, /* Color table 23 */
{ "COLOR24", 0xdff1B0, 2, 0 }, /* Color table 24 */
{ "COLOR25", 0xdff1B2, 2, 0 }, /* Color table 25 */
{ "COLOR26", 0xdff1B4, 2, 0 }, /* Color table 26 */
{ "COLOR27", 0xdff1B6, 2, 0 }, /* Color table 27 */
{ "COLOR28", 0xdff1B8, 2, 0 }, /* Color table 28 */
{ "COLOR29", 0xdff1BA, 2, 0 }, /* Color table 29 */
{ "COLOR30", 0xdff1BC, 2, 0 }, /* Color table 30 */
{ "COLOR31", 0xdff1BE, 2, 0 }, /* Color table 31 */
{ "HTOTAL", 0xdff1C0, 2, 0 }, /* Highest number count in horiz line (VARBEAMEN = 1) */
{ "HSSTOP", 0xdff1C2, 2, 0 }, /* Horiz line pos for HSYNC stop */
{ "HBSTRT", 0xdff1C4, 2, 0 }, /* Horiz line pos for HBLANK start */
{ "HBSTOP", 0xdff1C6, 2, 0 }, /* Horiz line pos for HBLANK stop */
{ "VTOTAL", 0xdff1C8, 2, 0 }, /* Highest numbered vertical line (VARBEAMEN = 1) */
{ "VSSTOP", 0xdff1CA, 2, 0 }, /* Vert line for VBLANK start */
{ "VBSTRT", 0xdff1CC, 2, 0 }, /* Vert line for VBLANK start */
{ "VBSTOP", 0xdff1CE, 2, 0 }, /* Vert line for VBLANK stop */
#if 0
{ "SPRHSTRT", 0xdff1D0 }, /* UHRES sprite vertical start */
{ "SPRHSTOP", 0xdff1D2 }, /* UHRES sprite vertical stop */
{ "BPLHSTRT", 0xdff1D4 }, /* UHRES bit plane vertical stop */
{ "BPLHSTOP", 0xdff1D6 }, /* UHRES bit plane vertical stop */
{ "HHPOSW", 0xdff1D8 }, /* DUAL mode hires H beam counter write */
{ "HHPOSR", 0xdff1DA }, /* DUAL mode hires H beam counter read */
#endif
{ "BEAMCON0", 0xdff1DC, 2, 0 }, /* Beam counter control register (SHRES,UHRES,PAL) */
{ "HSSTRT", 0xdff1DE, 2, 0 }, /* Horizontal sync start (VARHSY) */
{ "VSSTRT", 0xdff1E0, 2, 0 }, /* Vertical sync start (VARVSY) */
{ "HCENTER", 0xdff1E2, 2, 0 }, /* Horizontal pos for vsync on interlace */
{ "DIWHIGH", 0xdff1E4, 2, 0 }, /* Display window upper bits for start/stop */
#if 0
{ "BPLHMOD", 0xdff1E6 }, /* UHRES bit plane modulo */
{ "SPRHPTH", 0xdff1E8 }, /* UHRES sprite pointer (high 5 bits) */
{ "SPRHPTL", 0xdff1EA }, /* UHRES sprite pointer (low 15 bits) */
{ "BPLHPTH", 0xdff1EC }, /* VRam (UHRES) bitplane pointer (hi 5 bits) */
{ "BPLHPTL", 0xdff1EE }, /* VRam (UHRES) bitplane pointer (lo 15 bits) */
{ "RESERVED", 0xdff1F0 }, /* Reserved (forever i guess!) */
{ "RESERVED", 0xdff1F2 }, /* Reserved (forever i guess!) */
{ "RESERVED", 0xdff1F4 }, /* Reserved (forever i guess!) */
{ "RESERVED", 0xdff1F6 }, /* Reserved (forever i guess!) */
{ "RESERVED", 0xdff1F8 }, /* Reserved (forever i guess!) */
{ "RESERVED", 0xdff1Fa }, /* Reserved (forever i guess!) */
#endif
{ "FMODE", 0xdff1FC, 2, 0 }, /* Fetch mode register */
#if 0
{ "NO-OP(NULL)", 0xdff1FE }, /* Can also indicate last 2 or 3 refresh
cycles or the restart of the COPPER after lockup.*/
#endif
};