hardware:memorymap
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
hardware:memorymap [2023/08/24 00:36] – clyde | hardware:memorymap [2025/03/12 17:19] (current) – [System Control Registers] clyde | ||
---|---|---|---|
Line 12: | Line 12: | ||
Being a 6502-based system, the GameTank can read at, write to, or execute code from 65,536 different locations during a given cycle. The whole collection of these locations is called the " | Being a 6502-based system, the GameTank can read at, write to, or execute code from 65,536 different locations during a given cycle. The whole collection of these locations is called the " | ||
+ | |||
+ | In this context, dollar signs denote that a base-16, or hexadecimal, | ||
===== General Purpose RAM ===== | ===== General Purpose RAM ===== | ||
- | The lowest 8,196 addresses provide general-purpose data storage. Data stored in this range will only be read and written by the main processor, without side effects. | + | The lowest 8,192 addresses provide general-purpose data storage. Data stored in this range will only be read and written by the main processor, without side effects. |
Of special note within this section are the ranges $0000-$00FF, | Of special note within this section are the ranges $0000-$00FF, | ||
- | Although the memory map only dedicates 8K to this section, there are actually 32 kilobytes of general purpose RAM that can be used. | + | Although the memory map only dedicates 8K to this section, there are actually 32 kilobytes of general purpose RAM that can be used. Four different banks of RAM can be selected using the Banking Register. |
+ | |||
+ | ===== System Control Registers ===== | ||
+ | |||
+ | These locations are write-only, meaning that any attempts to read from these locations will essentially return a random value. On the physical hardware the data bus will have no component imparting any particular voltage, so any values returned will come from uncertain forces like radio static or the whims of inscrutable unseen entities. | ||
+ | |||
+ | ^ Addr ^ Use ^ | ||
+ | | $2005 | Banking Register | ||
+ | | $2007 | Video/ | ||
+ | |||
+ | ==== Audio Coprocessor === | ||
+ | |||
+ | Addresses $2000, $2001, and $2006 are used for controlling the [[hardware: | ||
+ | |||
+ | ^ Addr ^ Use ^ | ||
+ | | $2000 | Write to reset audio coprocessor | ||
+ | | $2001 | Write to send NMI to audio coprocessor | | ||
+ | | $2006 | Audio enable and sample rate | | ||
+ | |||
+ | $2000 and $2001 trigger on any write, regardless of value. | ||
+ | |||
+ | |||
+ | ==== Banking Register ==== | ||
+ | |||
+ | Address $2005 is the Banking Register, which determines which RAM bank is in use, which [[graphics: | ||
+ | |||
+ | ^ Bitmask | ||
+ | | 00000111 | Select the active Sprite RAM page | | ||
+ | | 00001000 | Select which framebuffer to read/ | ||
+ | | 00010000 | Clip blits on the left/right screen edges | | ||
+ | | 00100000 | Clip blits on the top/bottom screen edges | | ||
+ | | 11000000 | Select general purpose RAM page | | ||
+ | |||
+ | When a flag for clipping in a direction is set, blits to coordinates 128-255 will have no effect. When the flag is not set, blits to those coordinates will wrap to the 0-127 range. | ||
+ | |||
+ | ==== Video/ | ||
+ | |||
+ | These flags at $2007 configure the blitter and the behavior of video memory. | ||
+ | |||
+ | ^ Bitmask | ||
+ | | 00000001 | DMA_ENABLE | ||
+ | | 00000010 | DMA_PAGE_OUT | ||
+ | | 00000100 | DMA_NMI | ||
+ | | 00001000 | DMA_COLORFILL_ENABLE | Use solid colors for blits instead of sprites | ||
+ | | 00010000 | DMA_GCARRY | ||
+ | | 00100000 | DMA_CPU_TO_VRAM | ||
+ | | 01000000 | DMA_IRQ | ||
+ | | 10000000 | DMA_OPAQUE | ||
+ | |||
+ | |||
+ | ==== Gamepads ==== | ||
+ | |||
+ | The front [[hardware: | ||
+ | A byte read from one of these locations will return 6 binary button states from the respective controller. Consecutive reads to the same port will toggle the " | ||
+ | |||
+ | ^ Addr ^ Use ^ | ||
+ | | $2008 | Gamepad 1 (Left port) | | ||
+ | | $2009 | Gamepad 2 (Right port) | | ||
+ | |||
+ | ===== Versatile Interface Adapter ===== | ||
+ | |||
+ | Addresses $2800-$280F map to the sixteen registers of the [[hardware: | ||
+ | |||
+ | Addresses $2810-$2FFF will also map to the same sixteen registers. | ||
+ | |||
+ | The VIA is used to control the " | ||
+ | |||
+ | ^ Addr ^ Use ^ | ||
+ | | $2800 | I/O Register B | | ||
+ | | $2801 | I/O Register A | | ||
+ | | $2802 | Data Direction Register B | | ||
+ | | $2803 | Data Direction Register A | | ||
+ | | $2804 | Timer 1 Low-Order Latches/ | ||
+ | | $2805 | Timer 1 High-Order Counter | | ||
+ | | $2806 | Timer 1 Low-Order Latches | | ||
+ | | $2807 | Timer 1 High-Order Latches | | ||
+ | | $2808 | Timer 2 Low-Order Latches/ | ||
+ | | $2809 | Timer 2 High-Order Counter | | ||
+ | | $280A | Shift Register | | ||
+ | | $280B | Auxiliary Control Register | | ||
+ | | $280C | Peripheral Control Register | ||
+ | | $280D | Interrupt Flag Register | ||
+ | | $280E | Interrupt Enable Register | | ||
+ | | $280F | Same as Reg 1 except no " | ||
+ | |||
+ | [[https:// | ||
+ | ===== Audio RAM ===== | ||
+ | |||
+ | Audio RAM is shared between the main system bus and the [[hardware: | ||
+ | |||
+ | |||
+ | ===== Video RAM ===== | ||
+ | |||
+ | [[graphics: | ||
+ | |||
+ | |||
+ | ===== Cartridge Slot ===== | ||
+ | |||
+ | The upper half of the GameTank' | ||
+ | |||
+ | ==== EEPROM Cartridges ==== | ||
+ | |||
+ | Some of the simplest devices to go in the cartridge slot carry a single parallel EEPROM and a bypass capacitor. Any parallel EEPROM up to 32Kx8 can be used without additional banking hardware. Early cartridges for the GameTank used 8K EEPROMs. | ||
+ | |||
+ | |||
+ | ==== 2MB Flash Cartridges ==== | ||
+ | The typical cartridge used at time of writing has 2 megabytes of NOR flash and some extra chips to help access this data through a 32 kilobyte cartridge address space. See [[hardware: |
hardware/memorymap.1692837391.txt.gz · Last modified: 2023/08/24 00:36 by clyde