# Turbo Chameleon 64 VGA, turbo, freezer and memory expansion for the Commodore-64 The Programmers Manual # Peter Wendrich pwsoft@syntiac.com March 5, 2011 # Draft version! ## Contents | T | Intr | oducing the Chameleon core | |---|------|-----------------------------------------------------------| | | 1.1 | Turbo Chameleon Cartridge for the C64 | | | 1.2 | Standalone Mode | | | 1.3 | Chameleon core for the C-One Reconfigurable Computer | | 2 | Con | afiguration Mode 3 | | | 2.1 | Detecting a Chameleon | | | 2.2 | Activating Configuration Mode | | | 2.3 | Reconfigure the FPGA core | | | 2.4 | Force menu mode | | | 2.5 | Force reset from software | | 3 | Mei | mory 4 | | | 3.1 | Allocated memory ranges | | | | 3.1.1 32 MByte Layout | | | 3.2 | Memory overlays | | | 3.3 | MMU Registers | | 4 | But | tons 8 | | | 4.1 | Buttons Configuration Registers | | 5 | VG. | A Output 8 | | | 5.1 | VGA Resolution and Sync Registers | | | 5.2 | Example settings for standard VGA modes | | | 5.3 | Chameleon Object Processor | | | 5.4 | Palette Registers | | | 5.5 | Fixed Palette Entries | | 6 | Car | tridge Emulation 12 | | | 6.1 | Freezer Logic | | | 6.2 | Clock port | | | 6.3 | Simple ROM cartridges | | | 6.4 | MMC64 | | | | 6.4.1 MMC64 + SPI | | | 6.5 | RAM expansions | | | | 6.5.1 REU (Ram Expansion Unit) 1700, 1750, 1764 registers | | | | 6.5.2 geoRAM registers | | | 6.6 | Action Replay / RetroReplay | 16 | |-----------|------|--------------------------------------------------|-----------| | | 6.7 | Final Cartridge 3 | 17 | | | 6.8 | The Expert Cartridge | 18 | | | 6.9 | Game cartridges | 18 | | | 6.10 | Configuration registers | 19 | | | 6.11 | Cartridge stacks and combinations | 19 | | 7 | Mer | nu mode | 20 | | | 7.1 | Entering menu mode | 20 | | | 7.2 | Programming for menu mode | 20 | | | 7.3 | VIC-II memory access in menu mode | 20 | | | 7.4 | Differences between Menu and Configuration modes | 20 | | | 7.5 | Extra 256 bytes of ROM or RAM | 20 | | | 7.6 | Leaving menu mode | 21 | | | | 7.6.1 Leaving menu mode with RTI | 21 | | | | 7.6.2 Leaving menu mode with reset | 21 | | | 7.7 | Limitations | 21 | | 8 | CPU | U Turbo/Accelerator | 21 | | | 8.1 | Turbo Configuration Register | 22 | | 9 | Disl | k Drive Emulation | 22 | | | 9.1 | Drive Memory Map | 23 | | | 9.2 | Disk track layout | 23 | | | 9.3 | Drive Configuration Registers | 23 | | 10 | | Emulation | 23 | | | 10.1 | SID Configuration Register | 23 | | 11 | | 2 Keyboard connector | 23 | | | 11.1 | PS/2 Keyboard layout | 24 | | <b>12</b> | PS/ | 2 Mouse connector | 24 | | 13 | Infr | ared remote (CDTV) | 24 | | 14 | Con | nplete register map | <b>25</b> | # 1 Introducing the Chameleon core The Turbo Chameleon FPGA core can run in a few different configurations and so can be used in various ways. The Chameleon cartridge itself can also run other cores. This documentation however only covers the C64 mode of the cartridge. ### 1.1 Turbo Chameleon Cartridge for the C64 This is the main purpose of the core and also where the name 'Chameleon' is comming from. It can emulate various cartridges and peripherals in a way that is invisible to the software. Most of the functions of the original C64 hardware is taken over by an enhanced emulation in the cartridge. This gives access to all data and address lines, but also internal registers and various control signals normally not accessable on the cartridge port. The CPU can be made to run faster, memory is expanded and various cartridges can be mapped into the address space without changing anything to the main machine. #### 1.2 Standalone Mode #### 1.3 Chameleon core for the C-One Reconfigurable Computer Both the Chameleon cartrigde and the C-One extender board are based on the same type of FPGA. Therefore it made sense to release a Chameleon core for the C-One with extender board. The C-One version of Chameleon behaves like the standalone mode of the Chameleon Cartridge. Because the hardware is different there are some small differences between the two cores. The most important difference are in the amount of memory available and the layout of the memory map. ## 2 Configuration Mode Configuration mode is where the required functionality is selected and additional reigsters and extensions are switched on. The configuration registers are located at $53488 \text{ (D0F0}_h\text{)}$ to $53503 \text{ (D0FF}_h\text{)}$ . It is recommended to deactivate configuration mode after the required setting have been made, as some programs could overwrite these registers by accident. ### 2.1 Detecting a Chameleon Because the Chameleon can emulate a variety of cartridges and even combinations of those, the normal cartridge type detection method by probing $\mathrm{DExx}_h$ or $\mathrm{DFxx}_h$ fails to reliably detect it. However if the Chameleon is active, a few extra registers are visible in one of the VIC-II mirror areas. Reading at address 53502 ( $\mathrm{D0FE}_h$ ) on a stock machine always results in 255 ( $\mathrm{FF}_h$ ). On the Chameleon the value can be unequal to 255 ( $\mathrm{FF}_h$ ) if the configuration mode is active. Use the following sequence to reliably detect the presence of the Chameleon: Read and backup the current value at 53502 ( $\mathrm{D0FE}_h$ ). Write 42 ( $\mathrm{2A}_h$ ) at 53502 ( $\mathrm{D0FE}_h$ ) and read at the same location. The value represents the FPGA core version. If the backuped value was 255 ( $\mathrm{FF}_h$ ) store it into 53502 ( $\mathrm{D0FE}_h$ ) to restore previous mode. | Core version number | | Configuraion or Mode | | | |---------------------|-----------------|------------------------------------------------------|--|--| | 1 | $01_{h}$ | C64 with Chameleon cartridge present | | | | 161 | $A1_h$ | Chameleon running in standalone mode (C64 emulation) | | | | 193 | $C1_h$ | Chameleon core for the C-One reconfigurable computer | | | | 255 | $\mathrm{FF}_h$ | C64 without Chameleon | | | #### 2.2 Activating Configuration Mode To enter configuration mode and make the setup registers available write the value $42~(2A_h)$ in memory location $53502~(D0FE_h)$ . To disable the configuration registers write $255~(FF_h)$ at this location. Any value written to either $53501~(D0FD_h)$ or $53503~(D0FF_h)$ also leaves configuration mode. Activation of configuration mode is very unlikely to happen by accident as sequencial writes will never or only briefly activate the registers. During configuration mode the extra registers are visible from $53488~(D0F0_h)$ to $53503~(D0FF_h)$ . With these registers other memory areas can be configured and additional registers mapped into the CPU address space. #### 2.3 Reconfigure the FPGA core The onboard flash has room for upto sixteen FPGA cores. On power-up the core in the first slot (slot 0) is loaded into the FPGA. This core is the Chameleon core and provides the functions for use as expansion cartridge and for standalone emulation of a Commodore 64. Other cores can be loaded however by writing a new slot number into the configuration register at 53502 (D0FE<sub>h</sub>) or'ed with 16. To reconfigure the FPGA first enter configuration mode by writing $42~(2A_h)$ at $53502~(D0FE_h)$ followed by a write of the slot number (0-15) or'ed with 16. So 16 $(10_h)$ reloads the Chameleon core, while values 17 to 31 $(11_h$ to $1F_h)$ load other cores from the other slots in the onboard Flash. For more information about cores and the flash filesystem refer to the "Core Developers Manual". #### 2.4 Force menu mode While configuration mode is active, writing $32 (20_h)$ at $53502 (D0FE_h)$ enables menu mode. Refer to chapter 7 for more information about this mode. As almost all RAM and ROM can change on the switch to menu mode, the program performing the switch should be running in the memory area from $C000_h$ to $DFFF_h$ . #### 2.5 Force reset from software To force a reset from software write the value $165 \text{ (A5}_h)$ into the register at $53502 \text{ (D0FE}_h)$ . Alternatively the value of $166 \text{ (A6}_h)$ can be used that not only performs a reset, but also disables configuration mode. Both values only work if either configuration or menu mode is active. ## 3 Memory The Chameleon Cartridge brings its own memory. The internal memory of the C64 is not used except for the color ram. Because the CPU and VIC-II chip can only access 64 Kbyte at a time, a few tricks are required to address more. There are different methods implemented, so the best one can be choosen for each purpose. By far the fastest method to move large amount of data around in a compatible way is using the REU emulation. The REU is a DMA engine that can copy or compare blocks of data at a speed of 1 Mbyte per second. A MMU is provided to allows splitting the C64 memory into sixteen segments (banks) of 4 Kbyte each. Each of these 4 Kbyte pages can be placed at any byte offset in memory. There are additional MMU slots for specifing the location of ROMs. This gives support for ROM replacements, emulation of various freezer cartridges and can even be used to implement multitasking. The CPU is not the only device using memory. The REU emulation was already mentioned, which can use upto 16 Mbyte of storage space. The drive emulation needs memory for the disk images and a bit of work memory. Also the VGA video port uses quite a bit of memory for the framebuffer. #### 3.1 Allocated memory ranges #### 3.1.1 32 MByte Layout This is the memory layout used by the Turbo Chameleon Cartridge both as cartridge and in standalone mode. The area $0100000_h$ to $019FFFF_h$ is read from onboard Flash-ROM during startup (640 KByte total) by bootloader code inside the FPGA. After loading from Flash-ROM, the Chameleon is switched to either menu-mode or standard C64 mode depending on the status of the arrow-left key. The MMU blocks $00_h$ to $0F_h$ are mapped to memory from $000\ 0000_h$ to $000\ FFFF_h$ . MMU block $1F_h$ (Kernal ROM) is mapped to $010\ E000_h$ and $1E_h$ (BASIC ROM) is mapped to $010\ A000_h$ . MMU block $1D_h$ (character ROM) is mapped to $010\ D000_h$ . This emulates the standard C64 memory layout. For the menu mode, four additional blocks are mapped $(20_h, 24_h, 25_h$ and $26_h)$ . See following table where they map. Any additional setup for the menu system must be done by the code located at $010\ 0000_h$ – $010\ 7FFF_h$ . | Address (Hex) | Address (Dec) | Name | Description | |-------------------------------------------------------|---------------|------|--------------------------------------------------------| | $000\ 0000_h - 000\ FFFF_h$ | | | 64 KByte RAM for C64 mode (MMU banks $00_h$ – $0F_h$ ) | | $001~0000_h$ $-00F~\mathrm{FFFF}_h$ | | | 960 Kbyte RAM free | | $010\ 0000_h$ $-010\ 1FFF_h$ | | | Initial Menu 0000-1FFF (MMU bank $20_h$ ) | | $010\ 2000_h$ $-010\ 3FFF_h$ | | | Initial Menu 8000-9FFF (MMU bank $24_h$ ) | | $010\ 4000_h\ -010\ 5{\rm FFF}_h$ | | | Initial Menu A000-BFFF (MMU bank $25_h$ ) | | $010\ 6000_h\ -010\ 7{\rm FFF}_h$ | | | Initial Menu E000-FFFF (MMU bank $26_h$ ) | | $010\ 8000_h$ $-010\ 9FFF_h$ | | | MMC64 BIOS image | | 010 A000 $_h$ -010 BFFF $_h$ | | | BASIC V2 ROM image (MMU $1E_h$ ) | | $010 \text{ C}000_h - 010 \text{ CFFF}_h$ | | | *** reserved 4K **** | | $010 \ \mathrm{D}000_{h}$ – $010 \ \mathrm{DFFF}_{h}$ | | | Character ROM image (MMU $1C_h$ ) | | $010~\mathrm{E}000_h - 010~\mathrm{FFFF}_h$ | | | Kernal ROM image (MMU $1F_h$ ) | | $011~0000_h$ $-0$ FF FFFF $_h$ | | | *** reserved for menu system **** | | $100~0000_h~-1 {\rm FF}~{\rm FFFF}_h$ | | | 16 MByte REU memory | ## 3.2 Memory overlays | | System<br>RAM | System<br>ROMs | Simple<br>ROM | Retro-<br>Replay | REU, MMC,<br>Clockport | Expert<br>Cartridge | Menu<br>Mode | Boot<br>ROM | |----------------------|---------------|-----------------|---------------|------------------|------------------------|-----------------------------|---------------|------------------------------| | FFFF<br>F000 | $0F_h$ | $1\mathrm{F}_h$ | $13_h$ | $13_h$ | | $12_h$ | $26_h$ | FPGA<br>internal<br>Boot-ROM | | EFFF<br>E000 | $0E_h$ | KERNAL | Ultimax | Freeze | | Freeze or Reset | 2011 | | | DFFF<br>D000 | $0D_h$ | $1\mathrm{D}_h$ | | | registers | Freeze | $27_h$ | ] | | CFFF<br>C000 | $0C_h$ | | | | 7 | | | 1 | | BFFF<br>B000 | $0B_h$ | $1\mathrm{E}_h$ | $13_h$ | $13_h$ | | | $25_h$ | | | AFFF<br>A000 | $0A_h$ | BASIC V2 | | 10 <sub>11</sub> | | | <b>2</b> 5/11 | | | 9FFF<br>9000 | $09_h$ | | $13_h$ | $12_h \\ 13_h$ | $14_h$ | $\overset{ ext{R/W}}{12_h}$ | $24_h$ | | | 8FFF<br>8000 | $08_h$ | | 23/1 | $13_h$ | MMC64<br>Bios | Prg, Freeze or Reset | - 11 | | | 7FFF<br>7000 | $07_h$ | | | | | | $23_h$ | | | 6FFF<br>6000<br>5FFF | $06_h$ | | | | | | 71 | | | 5000<br>4FFF | $05_h$ | | | | | | $22_h$ | | | 4000<br>3FFF | $04_h$ | | | | | | 76 | | | 3000<br>2FFF | $03_h$ | | | | | | $21_h$ | | | 2000<br>1FFF | $02_h$ | | | | | | 70 | | | 1000<br>0FFF | $01_h$ | | | | | | $20_h$ | | | 0000 | $00_h$ | | | | | | 10 | | ## 3.3 MMU Registers The MMU has 256 slots that store 25 bit wide address offsets in memory. These offsets are the start address in SDRAM memory of the corresponding bank. This start address of each bank can be positioned anywere in memory at any byte offset. This makes the MMU more flexible as a simple banking scheme as they don't have to start at a multiple of the bank size. This allows MMU banks to overlap and point to shared memory (with each MMU bank at a possibly different offset). Some slots have specific functions or regions, others are free assignable. By updating the offsets everything can be moved and relocated freely in memory. The MMU registers are located at $D0A0_h$ to $D0AF_h$ and can be activated by setting bit 1 in the configuration register $D0FA_h$ . When changing an offset, first select the required slot by writing the slot-number into $D0AF_h$ . Then the offset can be read or changed with the registers from $D0A0_h$ to $D0A3_h$ . The first 16 slots have offsets for the 64Kbyte memory that the 6510 and VIC-II can see. Each of the 16 slots specifies the location of a 4 KByte segment. | Address (He | ex) Addre | ess (Dec) Na | ime | Description | |-----------------------------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | $D0A0_h$ | 53408 | | | Address offset bits $A_7$ – $A_0$ of current MMU slot | | $D0A1_h$ | 53409 | 1 | | Address offset bits $A_{15}$ – $A_8$ of current MMU slot | | $D0A2_h$ | 53410 | ı | | Address offset bits A <sub>23</sub> -A <sub>16</sub> of current MMU slot | | $D0A3_h$ | 53411 | | | Address offset bit A <sub>24</sub> of current MMU slot | | | settings | | | description | | 7 | read-only | | | 0 = Block of memory can be read and written<br>1 = Block of memory is read-only | | | Reserved for a<br>Address offset | ddress extension,<br>bit $A_{24}$ | , must | be set to 0 | | $\mathrm{D0A4}_{h}$ $-\mathrm{D0A}_{h}$ | $AE_h = 53412$ | -53422 | | Reserved for future use | | $D0AF_h$ | 53423 | | | Select MMU slot | | bit | settings | description | | | | 7-0 | Current slot | $0B_h = C64 \text{ r/w}$ $0C_h = C64 \text{ r/w}$ $0C_h = C64 \text{ r/w}$ $0D_h = C64 \text{ r/w}$ $0E_h E60 $ | memor | y at $1xxx_h$ y at $2xxx_h$ y at $3xxx_h$ y at $4xxx_h$ y at $5xxx_h$ (under basic) at $5xxx_h$ y (under basic) at $5xxx_h$ y (under $5xx_h$ y (under $5xx_h$ y (under kernal) at $5xxx_h$ $5xx_h$ ker | ## 4 Buttons There are three buttons on the Chameleon. The functions they perform, can be changed by software. The default functions are: - Left, Turbo On/Off toggle - Middle, short press is Freeze, long press accesses Chameleon menu - Right, short press is Reset, long press restarts to core selection menu ## 4.1 Buttons Configuration Registers | Address (I | Hex) A | ddress (Dec) | Name | Descripti | on | | | | |------------|-----------------------|--------------|--------------------------------|--------------------------|------------------------------|-----------------|------------------------|--| | $D0FB_h$ | 55<br>settings | 3499 | CFGBTN<br>description | Debug info and Buttons | | | | | | 7-6 | O | nfo on VGA | of the screen.<br>10 = Show me | emory and camory, cache, | ache load and<br>6510 and dr | rive CPU state. | O CPU state on the top | | | 5-4<br>3-0 | | d, must be 0 | | | | | | | | 3-0 | Buttons configuration | | eft | M | iddle | | Right | | | | | short | long | short | long | short | long | | | | 0000 | Menu | _ | Freeze | _ | Reset | Reboot<br>from Flash | | | | others | | | *** res | served *** | | | | ## 5 VGA Output One of the major features on the Turbo Chameleon Cartridge is the VGA connector. This interface allows rendering of the C64 picture on a VGA monitor in high quality. It doesn't use the original PAL or NTSC output, but generates the picture by monitoring the address and databus of the expansion connector. This results in a crisp and perfect stable picture on the monitor. If compatibility with a stock C64 is not required, the VGA controller can be reprogrammed to provide higher resolutions and more colors. # 5.1 VGA Resolution and Sync Registers | Address (I | Hex) Address (Dec | ) Name | e Description | |--------------|--------------------------------------------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------| | $D040_h$ | | | VGA Visual X-size <sub>70</sub> | | $D041_h$ | | | VGA Visual Y-size <sub>70</sub> | | $D042_h$ | | | VGA Visual size upper bits | | bit | | escription | | | $7-4 \\ 3-0$ | visual Y-size <sub>118</sub><br>visual X-size <sub>118</sub> | | | | $D043_h$ | | | VGA total X-size <sub>70</sub> | | $D044_h$ | | | VGA total Y-size <sub>70</sub> | | $D045_h$ | | | VGA total size upper bits | | bit | settings de | scription | | | 7-4 $3-0$ | total Y-size <sub>118</sub><br>total X-size <sub>118</sub> | | | | $D046_h$ | | | VGA HSync start <sub>70</sub> | | $D047_h$ | | | VGA HSync end <sub>70</sub> | | $D048_h$ | | | VGA HSync upper bits | | bit | settings de | escription | | | $7-4 \\ 3-0$ | HSync end <sub>118</sub><br>HSync start <sub>118</sub> | | | | $D049_h$ | | | VGA VSync start <sub>70</sub> | | $D04A_h$ | | | VGA VSync end <sub>70</sub> | | $D04B_h$ | | | VGA VSync upper bits | | bit | settings de | escription | · · · · · · · · · · · · · · · · · · · | | $7-4 \\ 3-0$ | VSync end <sub>118</sub><br>VSync start <sub>118</sub> | | | | $D04C_h$ | | | Select current object | | | | | Object registers are at $D050_h$ - $D05F_h$ | | $D04D_h$ | | | First object to render | | $D04E_h$ | | | Last object to render | | $D04F_h$ | | | Polarity and Pixel-clock | | bit | settings | | description | | 7 | VSync polarity | | 0 = negative sync<br>1 = positive sync | | 6 | HSync polarity | | 1 - positive sync 1 - positive sync 1 - positive sync | | 5 | Enable VGA VSync I | nterrupt | 0 = disabled<br>1 = enabled | | 4 | VGA VSync Interrupt | status | 0 = no interrupt<br>1 = pending | | 3-0 | Pixel-clock frequency | | Interrupt status is cleared on any write to $\mathrm{D04F}_h$ 0000 = 25.175 Mhz 0001 = 31.5 Mhz 0010 = Reserved for 36 Mhz 0011 = Reserved for 40 Mhz | | | | | 0100 = 50 Mhz<br>0101 = Reserved for 65 Mhz<br>0110 = Reserved for 75 Mhz | | | | | 0111 = Reserved for 78.8 Mhz | | | | | 1000 = 108 Mhz<br>others = Reserved for future use | | | | | | # 5.2 Example settings for standard VGA modes | Screen mode | Visua | l Size | Total | Size | HSync | VSync | Polarity | |---------------------------------------------|-------|--------|-------|------|-------------|-------------|--------------------| | | W | Н | W | Η | start / end | start / end | & Pixelclock | | 640x480 @ 60Hz | 640 | 480 | ? | | | | H=n / V=p / 25.175 | | 800 x 600 @ 72 Hz | 800 | 600 | 1040 | 666 | 860 / 980 | 625 / 631 | H=p / V=p / 50 | | 1024 x 768 @ 70 Hz | 1024 | 768 | 1328 | 806 | | | H=n / V=n / 75 | | 1024x768 @ 75Hz | 1024 | 768 | 1312 | 800 | | | H=p / V=p / 78.8 | | $1280 \mathrm{x} 1024 \ @ \ 60 \mathrm{Hz}$ | 1280 | 1024 | 1688 | 1066 | | | H=p / V=p / 108 | #### 5.3 Chameleon Object Processor The COP (Chameleon Object Processor) is a separate processor designed to perform graphic tasks. It can render multiple moving objects to the screen, these objects can take the form of sprites/MOBs or even complete bitmaps (with smooth scrolling in all directions). Objects of different resolutions (pixels can be stretched both horizontally and vertically) and different bitdepths can be combined on the same screen. A object can be configured as a window showing only a part of a larger bitmap. Combining this feature with smooth scroll and byte wise addressing allows the window to be positioned anywhere on the bitmap. Objects that overlap other objects can have one of their colors set to transparent to show the objects below it. Programming the COP is done with 19 registers, 16 of these are mapped at $D050_h$ and are used to configure the objects. The register at $D04C_h$ selects one of a possible 256 objects to configure. Registers $D04D_h$ and $D04E_h$ allow selection of a sub-range of objects. Only the objects within this range are rendered to the screen. The drawing order is fixed, an object with lower index number is always behind an object with a higher index number. All other objects outside the range are invisible (and won't use any memory nor object processor bandwidth). | | T \ A 1.1 | (D ) | 3.7 | B 1.0 | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Address (I | Hex) Address | s (Dec) | Name | Description | | $D050_h$ | | 53328 | COPXL | X position <sub>70</sub> | | $D051_h$ | | 53329 | COPYL | Y position <sub>70</sub> | | $D052_h$ | settings | 53330<br>descrip | COPYXH | position upper bits | | | | descrip | DUIOII | | | 7-4 3-0 | Y position <sub>118</sub><br>X position <sub>118</sub> | | | | | $D053_h$ | | 53331 | COPWL | X size <sub>70</sub> | | $D053_h$ $D054_h$ | | 53332 | COPHL | Y size <sub>70</sub> | | $D055_h$ | | 53333 | COPHWH | size upper bits | | bit | settings d | escription | | | | 7-4 | Y size <sub>118</sub> | | | | | 3–0 | $X \text{ size}_{118}$ | | | | | $D056_h$ | 53334 | | COPLIL | Line increment low | | $D057_h$ | 53335 | | COPLIH | Line increment high | | $D058_h$ | 53336 | | COPMMU | MMU slot | | $D059_h$ | 53337<br>settings | descrip | tion | Stretch and flip | | 7 | Vertical flip | 0 = no | | | | | • | 1 = flip | oped / mirror | | | 6-4 | stretch | | normal size<br>double height pi | xels | | | | 010 = - | 4x height pixels | | | | | | 8x height pixels<br>16x height pixels | s | | 0 | | others | = Reserved for f | | | 3 | Horizontal flip | 0 = no<br>1 = flip | rmal<br>oped / mirror | | | 2-0 | stretch | 000 = 1 | normal size | | | | | | double width pix<br>4x width pixels | xels | | | | | 8x width pixels | | | | | | 16x width pixels<br>= Reserved for f | | | | | | | | | D05A | 53338 | | | Horizontal smooth scroll (in pixels) | | $D05A_h$<br>$D05B_h$ | 53338<br>53339 | | | Horizontal smooth scroll (in pixels) Vertical smooth scroll (in lines) | | $D05A_h$<br>$D05B_h$<br>$D05C_h$ | 53338<br>53339<br>53340 | | | Horizontal smooth scroll (in pixels) Vertical smooth scroll (in lines) Palette offset | | $D05B_h$ | 53339 | | | Vertical smooth scroll (in lines) | | $D05B_h$<br>$D05C_h$ | 53339<br>53340 | | | Vertical smooth scroll (in lines) Palette offset | | $D05B_h$ $D05C_h$ $D05D_h$ | 53339<br>53340<br>53341 | descrij | ption | Vertical smooth scroll (in lines) Palette offset *** free *** | | $ \begin{array}{c} D05B_h \\ D05C_h \\ D05D_h \\ D05E_h \\ \qquad $ | 53339<br>53340<br>53341<br>53342<br>settings | | <u> </u> | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha | | $\begin{array}{c} \text{D05B}_h \\ \text{D05C}_h \\ \text{D05D}_h \\ \text{D05E}_h \\ \underline{\qquad \qquad \text{bit}} \end{array}$ | 53339<br>53340<br>53341<br>53342 | Selects<br>Alpha | s group for collis | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) | | $\begin{array}{c} \text{D05B}_h \\ \text{D05C}_h \\ \text{D05D}_h \\ \text{D05E}_h \\ \hline \frac{\text{bit}}{7} \\ \text{6-4} \end{array}$ | 53339<br>53340<br>53341<br>53342<br>settings | Selects<br>Alpha | s group for collis | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) | | $\begin{array}{c} \text{D05B}_h \\ \text{D05C}_h \\ \text{D05D}_h \\ \text{D05E}_h \\ \hline \frac{\text{bit}}{7} \\ \text{6-4} \end{array}$ | 53339<br>53340<br>53341<br>53342<br>settings | Selects<br>Alpha<br>0000 = | s group for collis<br>-blending value i<br>= Fully opaque ( | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) | | $\begin{array}{c} {\rm D05B}_{h} \\ {\rm D05C}_{h} \\ {\rm D05D}_{h} \\ {\rm D05E}_{h} \\ \hline \\ \frac{{\rm bit}}{7} \\ \frac{6-4}{3-0} \end{array}$ | 53339<br>53340<br>53341<br>53342<br>settings | Selects<br>Alpha<br>0000 = | s group for collis<br>-blending value i<br>= Fully opaque ( | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) 100% new) | | $\begin{array}{c} \text{D05B}_h \\ \text{D05C}_h \\ \text{D05D}_h \\ \text{D05E}_h \\ \hline \frac{\text{bit}}{7} \\ \text{6-4} \end{array}$ | 53339<br>53340<br>53341<br>53342<br>settings<br>-<br>Collision group<br>Alpha | Selects<br>Alpha<br>0000 =<br><br>1111 = | s group for collis<br>-blending value i<br>= Fully opaque ( | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) 100% new) color and 94% of background | | $\begin{array}{c} \text{D05B}_h\\ \text{D05C}_h\\ \text{D05D}_h\\ \text{D05E}_h\\ \frac{\text{bit}}{7}\\ \frac{6-4}{3-0} \end{array}$ | 53339<br>53340<br>53341<br>53342<br>settings<br>-<br>Collision group<br>Alpha | Selects<br>Alpha<br>0000 =<br><br>1111 = | s group for collist-blending value is Fully opaque ( = 6% of the new description ) = Render bitm | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) 100% new) color and 94% of background Mode selection hap graphics | | $\begin{array}{c} \text{D05B}_h\\ \text{D05C}_h\\ \text{D05D}_h\\ \text{D05E}_h\\ \hline \hline \begin{matrix} \text{bit}\\ \hline \begin{matrix} 6-4\\ 3-0 \end{matrix}\end{matrix} \\ \\ \hline \\ \text{D05F}_h\\ \hline \begin{matrix} \text{bit}\\ \hline \begin{matrix} 7\\ 6-4\\ 3-0 \end{matrix}\end{matrix} \\ \end{array}$ | 53339 53340 53341 53342 settings Collision group Alpha 53343 settings Command | Selects Alpha 0000 = 1111 = | s group for collis-blending value is Fully opaque ( = 6% of the new description | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) 100% new) color and 94% of background Mode selection hap graphics | | $\begin{array}{c} \text{D05B}_h\\ \text{D05C}_h\\ \text{D05D}_h\\ \text{D05E}_h\\ \hline \hline \begin{matrix} \text{bit}\\ \hline \begin{matrix} 6-4\\ 3-0 \end{matrix}\end{matrix} \\ \\ \hline \\ \text{D05F}_h\\ \hline \begin{matrix} \text{bit}\\ \hline \begin{matrix} 7\\ 6-4\\ 3-0 \end{matrix}\end{matrix} \\ \end{array}$ | 53339<br>53340<br>53341<br>53342<br>settings Collision group<br>Alpha 53343 settings | Select: Alpha 0000 = 1111 = | s group for collist-blending value is Fully opaque ( = 6% of the new description O = Render bitm O = use existing | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) 100% new) color and 94% of background Mode selection hap graphics et or mask clip rectangle | | $\begin{array}{c} {\rm D05B_{\it h}} \\ {\rm D05C_{\it h}} \\ {\rm D05D_{\it h}} \\ {\rm D05E_{\it h}} \\ \\ \hline \hline 7 \\ {\rm d-4 \atop 3-0} \\ \\ \\ \hline 2 \\ \\ \\ \hline 7 \\ \\ \\ \\ \hline \end{array}$ | 53339 53340 53341 53342 settings Collision group Alpha 53343 settings Command h bit 7 (command | Selects Alpha 0000 = 1111 = | s group for collis-blending value is Fully opaque ( = 6% of the new description ) = Render bitm 1 = Define tile-se 0 = use existing 1 = Set new clip | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) 100% new) color and 94% of background Mode selection in ap graphics et or mask | | $\begin{array}{c} {\rm D05B_{\it h}} \\ {\rm D05C_{\it h}} \\ {\rm D05D_{\it h}} \\ {\rm D05E_{\it h}} \\ \\ \hline \hline 7 \\ {\rm d-4 \atop 3-0} \\ \\ \\ \hline 2 \\ \\ \\ \hline 7 \\ \\ \\ \\ \hline \end{array}$ | 53339 53340 53341 53342 settings Collision group Alpha 53343 settings Command h bit 7 (command | Selects Alpha 0000 = 1111 = | s group for collist-blending value is Fully opaque ( = 6% of the new description O = Render bitm D = Use existing I = Set new clip All following obj O = No masking | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) 100% new) color and 94% of background Mode selection hap graphics et or mask clip rectangle rectange from object position and dimensions. ects will clip to the boundary of this object. | | $\begin{array}{c} \text{D05B}_h\\ \text{D05C}_h\\ \text{D05D}_h\\ \text{D05E}_h\\ \hline \hline \begin{matrix} \text{bit}\\ \hline \begin{matrix} 7\\ 6-4\\ 3-0 \end{matrix}\end{matrix} \\ \\ \hline \begin{array}{c} \text{D05F}_h\\ \hline \begin{matrix} \text{bit}\\ \hline \end{matrix} \\ \hline \begin{matrix} \\ 7\end{matrix} \\ \\ \hline \end{matrix} \\ \hline \begin{matrix} \\ \text{When}\\ \hline \begin{matrix} 6\end{matrix} \\ \end{matrix}$ | 53339 53340 53341 53342 settings Collision group Alpha 53343 settings Command bit 7 (command Clip rectangle | Selects Alpha 0000 = 1111 = (d) (d) (d) (d) (d) (d) (d) (d) (d) | s group for collis-blending value is Fully opaque ( = 6% of the new description O = Render bitm I = Define tile-se O = use existing I = Set new clip All following obj O = No masking I = Use previous O = 5 bits colore | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) 100% new) color and 94% of background Mode selection hap graphics et or mask clip rectangle rectange from object position and dimensions. ects will clip to the boundary of this object. sly set mask channels (truncated) | | $\begin{array}{c} \text{D05B}_h\\ \text{D05C}_h\\ \text{D05D}_h\\ \text{D05E}_h\\ \hline \hline \begin{matrix} \text{bit}\\ \hline \begin{matrix} 7\\ 6-4\\ 3-0 \end{matrix}\end{matrix}\\ \\ \hline \begin{array}{c} \text{D05F}_h\\ \hline \begin{matrix} \text{bit}\\ \end{matrix}\\ \hline \begin{matrix} 7\\ 6-4\\ 3-0 \end{matrix}\end{array}\\ \\ \hline \begin{array}{c} \text{Wher}\\ \hline \begin{matrix} 6\\ \hline \end{matrix}\\ \\ \hline \begin{matrix} 4\\ \end{matrix}\end{array}$ | 53339 53340 53341 53342 settings Collision group Alpha 53343 settings Command Clip rectangle Use masking Enable color of | Selects Alpha 0000 = 1111 = (1) (1) (2) (3) (4) is 0 | s group for collis-blending value is Fully opaque ( = 6% of the new description ) = Render bitm 1 = Define tile-se ) = use existing 1 = Set new clip All following obj 2 = No masking 1 = Use previous 3 = 5 bits color of the self-self-self-self-self-self-self-self- | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) 100% new) color and 94% of background Mode selection hap graphics et or mask clip rectangle rectange from object position and dimensions. ects will clip to the boundary of this object. sly set mask channels (truncated) channels (dithered) | | $\begin{array}{c} {\rm D05B_{\it h}} \\ {\rm D05C_{\it h}} \\ {\rm D05D_{\it h}} \\ {\rm D05E_{\it h}} \\ \hline \\$ | 53339 53340 53341 53342 settings Collision group Alpha 53343 settings Command Clip rectangle Use masking Enable color of Color keying | Selects Alpha 0000 = 1111 = | s group for collist-blending value is Fully opaque ( = 6% of the new description D = Render bitm D = Use existing I = Set new clip All following obj D = No masking I = Use previous D = 5 bits color of the solor s | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) 100% new) color and 94% of background Mode selection ap graphics et or mask clip rectangle rectange from object position and dimensions. ects will clip to the boundary of this object. sly set mask channels (truncated) channels (dithered) ly opaque. ansparent. | | $\begin{array}{c} \text{D05B}_h\\ \text{D05C}_h\\ \text{D05D}_h\\ \text{D05E}_h\\ \hline \hline \begin{matrix} \text{bit}\\ \hline \begin{matrix} 7\\ 6-4\\ 3-0 \end{matrix}\end{matrix}\\ \\ \hline \begin{array}{c} \text{D05F}_h\\ \hline \begin{matrix} \text{bit}\\ \end{matrix}\\ \hline \begin{matrix} 7\\ 6-4\\ 3-0 \end{matrix}\end{array}\\ \\ \hline \begin{array}{c} \text{Wher}\\ \hline \begin{matrix} 6\\ \hline \end{matrix}\\ \\ \hline \begin{matrix} 4\\ \end{matrix}\end{array}$ | 53339 53340 53341 53342 settings Collision group Alpha 53343 settings Command Clip rectangle Use masking Enable color of | Selects Alpha 0000 = 1111 = (d) (d) (d) (d) (d) (d) (d) (d) (d) (d | s group for collis-blending value is Fully opaque ( = 6% of the new description O = Render bitm I = Define tile-se O = use existing I = Set new clip All following obj O = No masking I = Use previous O = 5 bits color of I = 8 bits color of O = object is full I = color 0 is tra OO = Solid color | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) 100% new) color and 94% of background Mode selection map graphics et or mask clip rectangle rectange from object position and dimensions. ects will clip to the boundary of this object. sly set mask channels (truncated) channels (dithered) ly opaque. ansparent. | | $\begin{array}{c} {\rm D05B_{\it h}} \\ {\rm D05C_{\it h}} \\ {\rm D05D_{\it h}} \\ {\rm D05E_{\it h}} \\ \hline \\$ | 53339 53340 53341 53342 settings Collision group Alpha 53343 settings Command Clip rectangle Use masking Enable color of Color keying | Selects Alpha 0000 = 1111 = (d) (d) is 0 | s group for collis-blending value is Fully opaque ( = 6% of the new description O = Render bitm I = Define tile-so O = use existing I = Set new clip All following obj O = No masking I = Use previous O = 5 bits color of I = 8 bits color of O = object is full I = color 0 is tra 000 = Solid color 001 = 1 bit/pixe 010 = 2 bits/pix | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) 100% new) color and 94% of background Mode selection hap graphics et or mask clip rectangle rectange from object position and dimensions. ects will clip to the boundary of this object. sly set mask channels (truncated) channels (dithered) ly opaque. ansparent. r id, 2 palette colors el, 4 palette colors | | $\begin{array}{c} {\rm D05B_{\it h}} \\ {\rm D05C_{\it h}} \\ {\rm D05D_{\it h}} \\ {\rm D05E_{\it h}} \\ \hline \\$ | 53339 53340 53341 53342 settings Collision group Alpha 53343 settings Command Clip rectangle Use masking Enable color of Color keying | Selects Alpha 0000 = 1111 = | s group for collis-blending value is Fully opaque ( = 6% of the new description 0 = Render bitm 1 = Define tile-se 0 = use existing 1 = Set new clip All following obj 0 = No masking 1 = Use previous 0 = 5 bits color of 1 = 8 bits color of 1 = 8 bits color of 0 = object is full 1 = color 0 is tra 000 = Solid color 001 = 1 bit/pixe 010 = 2 bits/pix 011 = 4 bits/pix | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) (100% new) color and 94% of background Mode selection hap graphics et or mask clip rectangle rectange from object position and dimensions. ects will clip to the boundary of this object. sly set mask channels (truncated) channels (dithered) ly opaque. ansparent. r. d. 2 palette colors el, 4 palette colors el, 16 palette colors el, 16 palette colors | | $\begin{array}{c} {\rm D05B_{\it h}} \\ {\rm D05C_{\it h}} \\ {\rm D05D_{\it h}} \\ {\rm D05E_{\it h}} \\ \hline \\$ | 53339 53340 53341 53342 settings Collision group Alpha 53343 settings Command Clip rectangle Use masking Enable color of Color keying | Selects Alpha 0000 = 1111 = (d) (d) (d) (d) (d) (d) (d) (d) (d) (d | s group for collis-blending value is Fully opaque ( = 6% of the new description 0 = Render bitm 1 = Define tile-se 0 = use existing 1 = Set new clip All following obj 0 = No masking 1 = Use previous 0 = 5 bits color 0 = 5 bits color 0 = 0 bject is full 1 = color 0 is tra 100 = Solid color 001 = 1 bit/pixe 100 = 2 bits/pix 101 = 4 bits/pix 100 = 8 bits/pix 100 = 8 bits/pix 101 = 16 bits/p | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) 100% new) color and 94% of background Mode selection ap graphics et or mask clip rectangle rectange from object position and dimensions. ects will clip to the boundary of this object. sly set mask channels (truncated) channels (dithered) ly opaque. ansparent. r el, 2 palette colors el, 16 palette colors el, 16 palette colors el, 16 palette colors el, 16 palette colors el, 16 palette colors el, 256 palette colors exel, 32768 color mode | | $\begin{array}{c} {\rm D05B_{\it h}} \\ {\rm D05C_{\it h}} \\ {\rm D05D_{\it h}} \\ {\rm D05E_{\it h}} \\ \hline \\$ | 53339 53340 53341 53342 settings Collision group Alpha 53343 settings Command Clip rectangle Use masking Enable color of Color keying | Selects Alpha 0000 = 1111 = (d) (d) (d) (d) (d) (d) (d) (d) (d) (d | s group for collis-blending value is Fully opaque ( = 6% of the new description 0 = Render bitm 1 = Define tile-se 0 = use existing 1 = Set new clip All following obj 0 = No masking 1 = Use previous 0 = 5 bits color 0 = 5 bits color 0 = 0 = 5 bits color 0 = 0 = 5 bits color 0 = 1 = 8 bits color 0 = 1 = 10 = 10 = 10 = 10 = 10 = 10 = | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) 100% new) color and 94% of background Mode selection hap graphics et or mask clip rectangle rectangle rectange from object position and dimensions. ects will clip to the boundary of this object. sly set mask channels (truncated) channels (dithered) ly opaque. ansparent. r l, 2 palette colors el, 4 palette colors el, 4 palette colors el, 16 palette colors el, 256 palette colors set, 32768 color mode e, 256 tiles | | $egin{array}{lll} {\rm D05B}_h & { m D05C}_h & { m D05D}_h & { m D05E}_h & { m bit} & { m 7} & { m 6-4} & { m 3-0} & { m Where} & { m 6} & { m 4} & { m 3} & { m 2-0} & { m Where} & { m 6} & { m 4} & { m 3} & { m 2-0} & { m Where} & { m 6} 7} & { m 6} & { m 6} & { m 7} & { m 8} & { m 6} & { m 7} & { m 8} 8$ | 53339 53340 53341 53342 settings Collision group Alpha 53343 settings Command Clip rectangle Use masking Enable color of Color keying Color depth | Selects Alpha 0000 = 1111 = (d) (d) is 0 e (d) | s group for collis-blending value is Fully opaque ( = 6% of the new description 0 = Render bitm 1 = Define tile-se 0 = use existing 1 = Set new clip All following obj 0 = No masking 1 = Use previous 0 = 5 bits color 0 = 5 bits color 0 = 0 = 5 bits color 0 = 0 = 5 bits color 0 = 0 = 5 bits color 0 = 1 = 8 bits color 0 = 5 bits color 0 = 2 bits/pix 010 = 2 bits/pix 010 = 2 bits/pix 010 = 8 bits/pix 011 = 16 bits/pix 011 = 16 bits/pit 110 = 8 bits/pit 110 = 8 bits/tile | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) 100% new) color and 94% of background Mode selection ap graphics et or mask clip rectangle rectange from object position and dimensions. ects will clip to the boundary of this object. sly set mask channels (truncated) channels (dithered) ly opaque. ansparent. r el, 2 palette colors el, 16 palette colors el, 16 palette colors el, 16 palette colors el, 16 palette colors el, 16 palette colors el, 256 palette colors exel, 32768 color mode | | $\begin{array}{c} {\rm D05B_{\it h}} \\ {\rm D05C_{\it h}} \\ {\rm D05D_{\it h}} \\ {\rm D05E_{\it h}} \\ \hline \\$ | 53339 53340 53341 53342 settings Collision group Alpha 53343 settings Command Clip rectangle Use masking Enable color of Color keying Color depth | Selects Alpha 0000 = 1111 = (d) (d) is 0 e (d) | s group for collis-blending value is Fully opaque ( = 6% of the new description 0 = Render bitm 1 = Define tile-se 0 = use existing 1 = Set new clip All following obj 0 = No masking 1 = Use previous 0 = 5 bits color 0 = 5 bits color 0 = 0 = 5 bits color 0 = 0 = 5 bits color 0 = 0 = 5 bits color 0 = 1 = 8 bits color 0 = 5 bits color 0 = 2 bits/pix 010 = 2 bits/pix 010 = 2 bits/pix 010 = 8 bits/pix 011 = 16 bits/pix 011 = 16 bits/pit 110 = 8 bits/pit 110 = 8 bits/tile | Vertical smooth scroll (in lines) Palette offset *** free *** Group and Alpha sion detection in 6% steps (1/16th) 100% new) color and 94% of background Mode selection hap graphics et or mask clip rectangle rectangle rectange from object position and dimensions. ects will clip to the boundary of this object. sly set mask channels (truncated) channels (dithered) ly opaque. ansparent. r l, 2 palette colors el, 4 palette colors el, 4 palette colors el, 16 palette colors el, 256 palette colors set, 32768 color mode e, 256 tiles | #### 5.4 Palette Registers To support higher color depths on the VGA, a set of registers is added to store custom colors. The 'palette offset' register in the Object-Processor select which of the colors of the palette are being used. The first 32 entries in the color palette are fixed. Entries 32 $(020_h)$ to 287 $(11F_h)$ are software redefinable by using the palette registers (note that entries 271 to 287 are only reachable in 256 color mode). When bit 0 of configuration register $D0FA_h$ is set, an additional 768 registers become available at memory locations $D100_h$ to $D3FF_h$ . The registers at $D1xx_h$ store the red color intensities. The next 256 registers at $D2xx_h$ store the green intensity of the colors and the last 256 at $D3xx_h$ store the blue intensity value of the RGB triplets. Although the color resolution is limited to 5 bits (bit 7–3), all 8 bits are stored so the palette registers can also be used as 768 bytes of extra memory. | Address (Hex) Address (Dec) Name Description | | |-------------------------------------------------------------------------------------------------------|--| | $D100_h$ - $D1FF_h$ 53504 -53759 PALRED 256 entry color palette <b>Red</b> intensity | | | $D200_h-D2FF_h$ 53760 -54015 PALGRN 256 entry color palette <b>Green</b> intensity | | | $\mathrm{D300_{h}\text{-}D3FF}_{h}$ 54016 -54271 PALBLU 256 entry color palette <b>Blue</b> intensity | | #### 5.5 Fixed Palette Entries The first 32 entries in the color palette are fixed. They contain VIC-II and VDC compatible color definitions. Palette entries 0 $(000_h)$ to 15 $(00F_h)$ contain VIC-II compatible colors. Palette entires 16 $(010_h)$ to 31 $(01F_h)$ contain RGBI entries compatible with the VDC chip that is found in Commodore 128 machines. Custom color entries start at palette index 32 $(020_h)$ with the last entry at index 287 $(11F_h)$ . | Palette Index | Color (VIC-II) | Palette Index | Color (VDC) | |-----------------|----------------------|-----------------|---------------------| | $0 (000_h)$ | black | $16 (010_h)$ | black | | $1 (001_h)$ | white | $17 (011_h)$ | dark gray | | $2(002_h)$ | $\operatorname{red}$ | $18 (012_h)$ | dark blue | | $3 (003_h)$ | cyan | $19 (013_h)$ | light blue | | $4 (004_h)$ | purple | $20 \ (014_h)$ | dark green | | $5 (005_h)$ | green | $21 \ (015_h)$ | light green | | $6 (006_h)$ | blue | $22 (016_h)$ | dark cyan | | $7(007_h)$ | yellow | $23 (017_h)$ | light cyan | | $8 (008_h)$ | orange | $24 (018_h)$ | dark red | | $9 (009_h)$ | brown | $25 (019_h)$ | light red | | $10 \ (00A_h)$ | light red | $26 (01A_h)$ | dark purple | | $11 \; (00B_h)$ | dark gray | $27 (01B_h)$ | light purple | | $12 \; (00C_h)$ | mid gray | $28 \; (01C_h)$ | dark yellow (brown) | | $13 \; (00D_h)$ | light green | $29 \ (01D_h)$ | yellow | | $14 \; (00E_h)$ | light blue | $30 \ (01E_h)$ | light gray | | $15 (00F_h)$ | light gray | $31 \ (01F_h)$ | white | ## 6 Cartridge Emulation The Chameleon occupies the expansion connector and can not share it with any other cartridge(s). Fortunately it can emulate many types of cartridges. Even some combinations of different cartridges can be emulated. A few of these combinations are special as such that these are normally not possible to be used in a single machine without tricks. #### 6.1 Freezer Logic Chameleon contains a generic freezer implementation, the same logic is used for all the available freezer cartridge emulations. The freezer logic in Chameleon is often more reliable as the kludgy logic used originally in many of the cartridges. The freezer emulation can successfully freeze programs that have interrupts disabled or force the NMI line low. It also properly waits for the acknowledge of the interrupt before enabling the freezer ROMs. Although some programs might not function correctly after a restart, it is impossible for an application to prevent the freeze action itself. #### 6.2 Clock port This is not really a separate cartridge type, but a part of other cartridges. The clockport is an interface that originally comes from the Amiga 1200 computer, but can be found on many Commodore 64 cartridges as well. It allows small add-on cards to be easily connected to the machine. The shape of the Chameleon PCB and casing is designed for an optional RR-Net ethernet adapter. Many other addons don't fit properly as they were designed for different hardware. As the Chameleon can emulate multiple cartridges that have their own (conflicting) clockport settings, the configuration for this port is moved to a Chameleon specific register. The clockport configuration bits in the register map of various cartridges are therefore not emulated. #### 6.3 Simple ROM cartridges These are simple cartridges with an EPROM, an optional on/off switch and sometimes one logic chip. These type of cartridges are often used for utilities like tape speeders, assemblers and machine-monitors or for small games. There are three different cartridge layouts that can be configured. - 8 Kbyte ROM at $8000_h$ to 9FFF<sub>h</sub>. If the ROM doesn't support autostart, the machine will report 30719 basic bytes free. - 16 Kbyte ROM at $8000_h$ to BFFF<sub>h</sub>. This type of cartridge replaces the BASIC interpreter ROM to get 8 Kbyte more ROM space. - 16 Kbyte ROM at $8000_h$ to $9FFF_h$ and $E000_h$ to $FFFF_h$ . This type of cartridge replaces Kernal ROM to get 8 Kbyte more ROM space. This configuration is known as ultimax and changes the memory layout as well. The 8 Kbyte configuration is the most common. Some games cartridges are using the 16 Kbyte variants if they need more as 8 Kbyte of ROM space. Some Kernal ROM replacement cartridges also use a 16 Kbyte ROM layout (ultimax), but have some extra logic on the PCB to keep the normal RAM layout. These type of cartridges can not be emulated, but the Kernal ROM can be replaced much easier on Chameleon by simply reprogramming the MMU. Changing the address for slot $1F_h$ in the MMU has the same effect as replacing the ROM inside the machine and is completely transparent for any software. #### 6.4 MMC64 | Address ( | Hex) Address (De | ec) Name | Description | |-----------|--------------------|------------------------------------------------------------|---------------------------------------------------------------------------------------------------| | $DF10_h$ | 57104 | MMCSPI | SPI transfer register. Write in this register sends byte to SPI bus, read is last retrieved byte. | | $DF11_h$ | 57105 | MMCCTL | MMC64 Control register. | | bit | settings | description | Ü | | 7 | MMC64 active | 0 = MMC64 is act<br>1 = MMC64 is dis<br>Bit can only be me | | | 6 | SPI trigger mode | 0 = Trigger SPI tr | ansfer on write to register $DF10_h$ ansfer on read of register $DF10_h$ | | 5 | External ROM | | ROM when BIOS is disabled | | 4 | Flash mode | 0 = Normal mode<br>1 = Flash update<br>Not implemented, | mode | | 3 | Clock port address | Not implemented, | | | 2 | Clock Speed | 0 = 250 KHz SPI $0 = 8 Mhz SPI clo$ | | | 1 | MMC cart select | 0 = Cart selected | | | 0 | MMC64 Bios | 1 = Cart not selec<br>0 = MMC64 BIOS<br>1 = BIOS ROM di | | | $DF12_h$ | 57106 | MMCST | MMC64 Status register (read-only). | | bit | settings | description | inite of states register (read only). | | 5 | Flash jumper | Not implement | ed reads always as 0 | | 4 | MMC Write Protect | 0 = Cart can b<br>1 = Cart is write | e written | | 3 | MMC Cart Detect | 0 = Cart insert | | | 2 | External EXROM lin | | , , , | | 1 | External GAME line | | | | 0 | Busy | 0 = SPI bus re $1 = SPI$ bus bu | ady<br>asy (only for 250 Khz mode) | #### $6.4.1 \quad MMC64 + SPI$ Same as MMC64, but with unused bit 4 combined with card select to have access to three SPI devices: MMC cart, FlashRom or RTC (Real Time Clock). When accessing the RTC, the transfer speed must be set to 250 Khz. The RTC device is too slow to accept data at 8 Mhz. The FlashRom is fast enough to be accessed in 8 Mhz mode. | Add | ress ( | Hex) | Address (Dec) | Name | Description | |-----|-----------|----------|-------------------------------------------------------------|----------|-------------------------| | DF1 | $1_h$ bit | settings | 57105<br>s description | MMCCTL | MMC64 Control register. | | | 4,1 | Select | 00 = MMC ca<br>01 = Nothing<br>10 = Flash R0<br>11 = RTC (R | selected | selected | ## 6.5 RAM expansions The standard internal memory of 64 Kbyte of the Commodore 64 is not always enough. Therefore some memory expansions have been developed. - RAM Expansion Unit (REU) - $\bullet$ geoRAM The operating system GEOS was one of the first programs to support the REU. Because the REU was difficult to obtain, the company behind GEOS made their own expansion called geoRAM. The REU has a buildin DMA engine that the geoRAM module lacks. This makes the REU the better expansion option and has also slightly more software support. Chameleon can emulate both the REU and geoRAM. The registers of the two expansions don't overlap and therefore can even be activated at the same time. #### 6.5.1 REU (Ram Expansion Unit) 1700, 1750, 1764 registers The memory of the REU is not directly visible in the address space of the C64. The REU transfers blocks of data to or from its onboard RAM by using DMA. While the transfer is in progress the CPU is stopped. The REU copies and compares at a speed of 1 Mbyte/second (memory swaps run at half that speed), but like the processor it will stop on badlines when the VIC-II video chip needs the extra memory cycles. | Address (Hex) Address | | Dec) Name | Description | | | | |------------------------------|-----------------------------------|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | $\overline{\mathrm{DF}00_h}$ | 57088 | DMAST | REU Status register (read-only) | | | | | bit | settings | description | | | | | | 7 | 1 = IRQ pending | | | | | | | 6<br>5 | 1 = End of block<br>1 = Fault | Compare operation | detected a difference | | | | | 4 | Size | | Compare operation detected a difference $0 = 128$ or $256$ KByte | | | | | | | 1 = 512 KByte | Constitution of the Consti | | | | | | | amount that is reall | represent all memory sizes. So software should probe for the | | | | | 3-0 | Version | Always 0000 | <b>,</b> | | | | | $DF01_h$ | 57089 | DMACMD | REU Command register | | | | | bit | | description | | | | | | 7 | 1 = Execute | | | | | | | 6 | Reserved | | | | | | | 5 | | When autoload is enable the end of the transfer | oled. The memory pointers and length registers are reloaded at | | | | | 4 | $FF00_h$ flag | 0 = Wait for write to l | $FF00_h$ before starting transfer | | | | | 3-2 | Reserved | 1 = Start immediately | when bit 7 becomes set | | | | | 3-2<br>1-0 | | 00 = C64 to REU | | | | | | | | 01 = REU to C64 | | | | | | | | 10 = Swap<br>11 = Compare / verify | | | | | | DEC | | | | | | | | $DF02_h$ | 57090 | DMA64L | C64 memory pointer low | | | | | $DF03_h$ | 57091 | DMA64H | C64 memory pointer high | | | | | $DF04_h$ | 57092 | DMAINL | REU memory pointer low | | | | | $DF05_h$ | 57093 | DMAINM | REU memory pointer mid | | | | | $DF06_h$ | 57094 | DMAINH | REU memory pointer high | | | | | $DF07_h$ | 57095 | DMACNL | Transfer length low | | | | | $DF08_h$ | 57096 | DMACNH | Transfer length high | | | | | $DF09_h$ | 57097 | DMAINT | Interrupt mask register | | | | | bit | settings | description | | | | | | 7<br>6 | Interrupt enable End Of Block mas | 1 = enabled sk $1 = interrupt afte$ | ar transfor | | | | | 5 | Verify mask | 1 = interrupt and<br>1 = interrupt on | | | | | | 4-0 | Reserved | Read as 1 | · | | | | | $\mathrm{DF}0\mathrm{A}_h$ | 57098 | DMACTL | Address control register | | | | | bit | settings | description | | | | | | 7 | C64 Address cont | control 0 = Increment C64 address<br>1 = Fix C64 address | | | | | | 6 | REU Address con | | REU address | | | | | 5-0 | Reserved | Read as 1 | AU (-05 | | | | ### 6.5.2 geoRAM registers There is a 256 byte large window at $DE00_h$ – $DEFF_h$ to access the GeoRAM memory. Two registers at $DFFE_h$ and $DFFF_h$ select the position of the memory window. The geoRAM register layout allows upto 4 Mbyte of internal memory. The real geoRAM cartridge has 512 KByte. | Address ( | Hex) | Address ( | (Dec) | Name | Description | |-------------------------------------------------------------------|---------------------------------|---------------------------------|-------|----------------------------|-----------------------------------------------------------------| | $ \begin{array}{c} DE00_h - D\\ DFFE_h\\ \text{bit} \end{array} $ | $\operatorname{DEFF}_h$ setting | ?<br>57342<br>gs | ? | GEOBUF<br>GEOLOW<br>iption | geoRAM 256 byte memory window geoRAM address $A_{13}$ – $A_{8}$ | | $7-6 \\ 5-0$ | Unuse<br>geoR | $^{ m cd}$ AM $_{13}$ - $A_{8}$ | must | be set to 0 | | | $\mathrm{DFFF}_h$ | | 57343 | | GEOHI | geo<br>RAM address $\rm A_{21}A_{14}$ | ## 6.6 Action Replay / RetroReplay Chameleon can emulate the RetroReplay hardware. This is a freezer cartridge developed by Individual Computers and is an improvement on and backwards compatible with the Action Replay. The RetroReplay cartridge provides access to 64 KByte of ROM and 32 KByte of RAM. The real cartridge has two ROMs of 64 KByte that can be selected with a hardware jumper, this is not emulated as the MMU in Chameleon can provide similar functionality. | Address ( | (Hex) Address ( | Dec) Name Description | |----------------------|---------------------------------|-------------------------------------------------------------------------------------------------| | $\mathrm{DE}00_h$ | ? | ? On write | | bit | settings | description | | 7 | A15 | ROM address line 15 | | 6 | | | | 5 | ROM/RAM | 0 = ROM | | 4 | A14 | 1 = RAM POM/PAM address line 14 | | $\frac{4}{3}$ | A14<br>A13 | ROM/RAM address line 14<br>ROM/RAM address line 13 | | 2 | Disable | Write 1 to disable cartridge | | 1 | EXROM | Title I to dibuble cultilage | | 0 | GAME (inverted) | | | $DE01_h$ | ? | ? On write | | bit | settings | description | | 7 | A15 | ROM address line 15 (mirror of $DE00_h$ ) | | 6 | REU Compatibility | | | | | 1 = REU compatible memory map | | 5 | | Not implemented, must be set to 0 | | 4 | A14 | $ROM/RAM$ address line 14 (mirror of $DE00_h$ ) | | $\frac{3}{2}$ | A13 | ROM/RAM address line 13 (mirror of $DE00_h$ )<br>Not implemented, must be set to 0 | | 1 | AllowBank | Not implemented, must be set to $0$<br>$0 = \text{no RAM banking in DE02}_h\text{-DFFF}_h$ area | | 1 | Allowballk | $1 = \text{Enable RAM banking in DE02}_h$ -DFFF <sub>h</sub> area | | 0 | | Not implemented, must be set to 0 | | $DE00_h$ - $D$ | E01 <sub>b</sub> ? | ? ? On read | | DE00 <sub>h</sub> -L | $\frac{1}{1}$ settings descript | · · · · · · · · · · · · · · · · · · · | | | | | | 7 | A15 ROM ac | ddress line 15 | | 6<br>5 | Not imp | elemented, reads 0 | | 4 | | AM address line 14 | | 3 | / | AM address line 13 | | $\overset{\circ}{2}$ | | | | 1 | | | | 0 | Not imp | elemented, reads 0 | | | | | The ROM/RAM switch determines if memory or ROM is visible at $8000_h$ –9FFF $_h$ and at DE00 $_h$ –DFFF $_h$ . The memory locations $A000_h$ –BFFF $_h$ and $E000_h$ –FFFF $_h$ always map ROM and are not affected by this bit. Although the ROM can be located at different memory addresses only 8 Kbyte is available at any time. When more as one location is activated they are mirrors of each other. The ROM has 8 banks of 8 Kbyte for a total of 64 KByte ROM. The RAM only has 4 banks for a total of 32 KByte RAM. The lowest two bits of the configuration register at $DE00_h$ determine where in memory the ROM or RAM of the cartridge is visible. Take note that the control of the GAME line is inverted. After reset the register is cleared so the first 8 Kbyte of the ROM is visible at $8000_h$ -9FFF<sub>h</sub>. The "CBM80" signature in the ROM makes the kernel jump into the cartridge and this will display the startup menu. | EXROM | GAME (inverted) | ROM Mapping | |-------|-----------------|-----------------------------------------------------------------------------------------------------| | bit 1 | bit 0 | | | 0 | 0 | 8 KByte at $8000_h$ –9FFF <sub>h</sub> | | 0 | 1 | $8~\mathrm{KByte}~\mathrm{ROM/RAM}$ at $8000_h–9\mathrm{FFF}_h$ and $8~\mathrm{Kbyte}~\mathrm{ROM}$ | | | | at $A000_h$ -BFFF <sub>h</sub> | | 1 | 0 | Cartridge ROM/RAM disabled. | | 1 | 1 | Ultimax mode, ROM/RAM at $8000_h$ –9FFF <sub>h</sub> and ROM | | | | at $E000_h$ -FFFF <sub>h</sub> . | The RetroReplay has a slight incompatibility (by design) compared to the original Action-Replay cartridge. When writing to the RAM on the Action Replay at $8000_h$ –9FFF<sub>h</sub> it will also write to the internal C64 memory at the same address. On the RetroReplay (and its emulation in Chameleon) a write operation will only write to the cartridge RAM, leaving the C64 memory below it intact. #### 6.7 Final Cartridge 3 Chameleon can emulate the Final Cartridge 3 hardware. The cartridge provides 64 KByte of ROM containing disk and tape speeders, basic extensions, machine monitor and a freezer. A unique feature of the cartridge is its graphical menu system that can be controlled with a mouse. The ROM is divided into four banks of 16 KByte each. A control register at DFFF<sub>h</sub> allows selection of the required bank. The register can only be written as any reads in the DE00<sub>h</sub>-DFFF<sub>h</sub> address range always access the ROMs. As the cartridge occupies all addresses in the IO space at DE00<sub>h</sub>-DFFF<sub>h</sub> no other emulations can be active at the same time. By setting bit 7 of the control register at DFFF<sub>h</sub> disables the cartridge and makes any hidden registers available agian. This makes it possible for example to use the MMC64 BIOS to load a program from the MMC card or for example use the REU. Use the freeze button to re-activate the Final Cartridge 3 emulation. On a system reset the control register at DFFF<sub>h</sub> is cleared to zero. This maps the first 16 KByte of the ROM into $8000_h$ –BFFF<sub>h</sub> and makes the control register writable. The "CBM80" signature at the beginning of the ROM will make the Kernal jump into the cartridge on reset to let it initialize and active the graphic desktop environment. The control register also has two individual bits for GAME and EXROM so it can enable either 8 Kbyte or 16 KByte of the current ROM bank. | GAME<br>bit 5 | EXROM<br>bit 4 | ROM Mapping | |---------------|----------------|------------------------------------------------------------------------------------| | 0 | 0 | 16 KByte at $8000_h$ –BFFF <sub>h</sub> | | 0 | 1 | Ultimax mode, ROM at $8000_h$ –9FFF <sub>h</sub> and $E000_h$ –FFFF <sub>h</sub> . | | 1 | 0 | 8 KByte at $8000_h$ –9FFF <sub>h</sub> | | 1 | 1 | Cartridge ROM disabled. | Pressing the freeze button on a Final Cartridge 3, pulls GAME low (activating Ultimax mode) and pulls NMI low as well to force an interrupt. In Chameleon freezing is handled by the generic freezing logic that can for example also freeze while NMI is already low. The behavior of the control register during a freeze is therefore slightly different from the original hardware. | Addı | ress ( | Hex) Addres | ss (Dec) Name | Description | | | |-------------|----------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | DE0 | $0_h$ –D | $\mathrm{PFFF}_h$ | | Reads will read cartridge ROM at $1E00_h$ – $1FFF_h$ , $5E00_h$ – $5FFF_h$ , $9E00_h$ – $9FFF_h$ or $DE00_h$ – $DFFF_h$ depending on the current selected bank. | | | | $_{ m DFF}$ | $\mathbf{F}_h$ | 57343 | FC3BNK | On write | | | | | $_{ m bit}$ | settings | description | | | | | | 7 | register enable | 0 = Banking register writable at DFFF.<br>1 = Banking register invisible.<br>On Chameleon setting this bit to 1 also disables the ROM mirror at DE00 <sub>h</sub> -DFFF <sub>h</sub> . | | | | | | 6 | NMI | 0 = Force NMI line low<br>1 = Normal operation | | | | | | 5 | GAME | State of the GAME li | ne | | | | | 4 | EXROM | State of the EXROM | line | | | | | 3 | unused | | | | | | | 2 | unused | | | | | | | 1 | A15 | ROM address line 15 | | | | | | 0 | A14 | ROM address line 14 | | | | ## 6.8 The Expert Cartridge ## 6.9 Game cartridges There are game cartridges that need (much) more ROM space as the 16 Kbyte provided by the standard memory layouts. These cartridges use bank switching logic inside the cartridge to map different parts of the ROM into memory. A couple of these bank switching methods can be emulated by Chameleon. This allows the games to be played without unplugging the Chameleon. All that is needed to play the game is a copy of the game catridge ROM contents on a MMC card or in the onboard flash chip. ## 6.10 Configuration registers | Address (I | Hex) Address (Dec | ) Name | Description | |--------------------------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ${\rm D0F0}_h_{\rm bit}$ | 53488 settings | CFGCRT description | Cartridge emulation | | 7–0 | Freezer/Game Type | 111111101 = 16K | al Cartridge 3 bert Cartridge $3$ Cartridge $3$ ROM cartridge at $8000_h$ –BFFF $_h$ ROM cartridge in Ultimax mode ROM cartridge at $8000_h$ –9FFF $_h$ | | $\mathrm{D0F1}_h$ bit | 53489 settings | CFGSPI<br>description | Clock-port and MMC64 Emulation | | 7–6<br>5–4 | Reserved, must be 0<br>Clock port | | port at $DE00_h$ - $DE0F_h$<br>port at $DF20_h$ - $DF2F_h$<br>ed | | 3 2 | Reserved, must be 0 MMC64 active | 1 = MMC6 This bit can cessed here | 4 active (Copy of bit 7 in DF11 <sub>h</sub> )<br>4 disabled (DF1x <sub>h</sub> registers are invisible)<br>a only be toggled in DF11 <sub>h</sub> after unlocking, while it can be acat any time.<br>is bit is set to 1 if MMC64 emulation is disabled (bits 1–0 are | | 1–0 | MMC64 Emulation, S. | PI $00 = \text{Off}$<br>01 = MMC<br>10 = reserv<br>11 = MMC | when emulation is enabled. 64 Emulation ed 64 Emulation with extra bits combinations defined for access to Time Clock) and FlashRom. | | $D0F5_h$ | 53493 | CFGREU | REU (Ram Expansion Unit) and geoRAM Emulation Config | | bit | settings | description | Coming | | 7<br>6 | 1 = Enable REU<br>1 = Enable geoRAM | | nulation and activate registers at $\mathrm{DF00}_h\mathrm{-DF0A}_h$ . $M$ emulation and activate registers at $\mathrm{DE00}_h\mathrm{-DEFF}_h$ , $\mathrm{DFFE}_h$ and | | 5–3 | geoRAM size | 000 = 64 KByt<br>001 = 128 KBy<br>010 = 256 KBy<br>011 = 512 KBy<br>100 = 1 MByte<br>101 = 2 MByte<br>110 = 4 MByte<br>111 = reserved | rte rte rte e | | 2-0 | REU memory size | 000 = 128 KBy<br>001 = 256 KBy<br>010 = 512 KBy<br>011 = 1 MByte<br>100 = 2 MByte<br>101 = 4 MByte<br>110 = 8 MByte | rte rte rte e | ## 6.11 Cartridge stacks and combinations Unless a port expander is used only a single cartridge can be used in the Commodore 64 at any time. In Chameleon there are a variety of functions integrated into a single device. This makes it a lot more likely that multiple functions are selected and active at the same time. However the original cartridges on which the Chameleon functions are based on, were never designed to be used at the same time. So not all possible combinations make sense. There are some overlaps in memory areas and registers that each cartridge uses. So some functions will hide the registers and ROM images used by other functions when enabled. The cartridge emulator engine in Chameleon assigns highest priority to the MMC64 registers and boot ROM. The freezer (or game) emulation has next priority followed by the clockport, any ram expander registers and simple ROMs. The internal ROMs (BASIC and Kernal) and system RAM have the lowest priority. ## 7 Menu mode Menu mode is similar in function to a freezer cartridge, but is separate from the normal cartridge emulation logic. The mode is designed for configuration and control of the various aspects of the cartridge. Because it functions as a freezer it is possible to enter menu mode at any time and in most cases return to the original application again when done. #### 7.1 Entering menu mode Menu mode can be entered in three different ways: - The menu mode is active after a reset - Pressing the freeze button longer as 0.7 seconds - Writing 32 $(20_h)$ into 53502 $(D0FE_h)$ while in configuration mode #### 7.2 Programming for menu mode In menu mode the I/O space is always active (the CPU banking registers at address 0 and 1 have no effect in menu mode). Some Chameleon specific settings in the configuration registers at $D0F0_h$ – $D0FF_h$ are also over-ridden. Any changes made to those configuration registers therefore will only take effect when leaving the menu mode. In menu mode the REU and MMC64 emulations are always active and any freezers or game emulations are (temporarily) disabled. In menu mode a total of 56 KByte of ROM and RAM memory is replaced. This allows utility functions to operate without disturbing the frozen program. The MMU can be used for banking additional memory in and out of the address space. The 56 KByte is build up from seven banks of 8 KByte each. The area $C000_h$ –CFFF $_h$ keeps it original mapping to MMU bank $0C_h$ . #### 7.3 VIC-II memory access in menu mode In menu mode the VIC-II accesses also go to the seven new 8K banks. However the character ROM accesses at $1000_h$ -1FFF<sub>h</sub> and $9000_h$ -9FFF<sub>h</sub> stay intact and access MMU bank $1D_h$ . As there is no new memory at $C000_h$ -DFFF<sub>h</sub> in menu mode, the VIC-II will gets it data from normal C64 MMU banks $0C_h$ and $0D_h$ on these addresses. Note that the CPU is not able to access any data (character ROM or RAM) at the memory range $D000_h$ -DFFF<sub>h</sub> directly as the I/O space is always on top. #### 7.4 Differences between Menu and Configuration modes TODO! #### 7.5 Extra 256 bytes of ROM or RAM To facilitate the use of menu mode for other functions normally implemented in (freezer) cartridges an extra I/O area can be enabled. An extra space of 256 bytes can be enabled at D700<sub>h</sub>–D7FF<sub>h</sub>, which normally is unused mirror of the SID registers. This keeps the DE00<sub>h</sub>–DFFF<sub>h</sub> memory area (which often performs similair functions) empty for use by the catridge emulations. Once the D7xx<sub>h</sub> area is enabled, it stays active even in C64 mode. This allows basic or kernal vector hooks to point into this area, where extra code can be placed to jump into menu mode (by writing $20_h$ into D0FE<sub>h</sub>) perform the function and then leave menu mode again. #### 7.6 Leaving menu mode #### 7.6.1 Leaving menu mode with RTI To leave menu mode perform a read at address 53503 (D0FF<sub>h</sub>). The configuration disable register at 53503 (D0FF<sub>h</sub>) always contains the RTI opcode (64 or $40_h$ ) when the menu (or configuration) mode is active. A read on that location turns off menu mode. One way to leave menu mode is to jump to D0FF<sub>h</sub> and while the RTI opcode is fetched the memory configuration is restored. So the machine is in a same state before the menu mode was activated. The RTI instruction will fetch the program-counter and CPU state from the original stack and continues execution. However when menu mode is entered with a reset or under software control, the menu software is responsible to initialize the stack in such a way that the RTI can be used to leave the menu. Alternatively the menu application can run in a memory area that is uneffected by the switch, which is the range $C000_h$ -DFFF<sub>h</sub> by default and perform a load operation at D0FF<sub>h</sub>. #### 7.6.2 Leaving menu mode with reset The other way to leave the menu mode is by performing a software reset by writing the value 165 or 166 (A5<sub>h</sub> or A6<sub>h</sub>) to 53502 (D0FE<sub>h</sub>). #### 7.7 Limitations It is not recommended to change any cartridge emulation settings while in menu mode unless a (soft) reset is performed on exit. As changing cartridge type while it is in use might result in undefined behavior. This is especially true for freezer cartridges as these might have hooks installed into the basic and system vectors for basic enhancements and turbo loaders. Removing the cartridge without a reset will leave the vectors pointing into the void and crashing the machine. To force a reset from software write the value 165 or 166 (A5<sub>h</sub> or A6<sub>h</sub>) into the register at 53502 (D0FE<sub>h</sub>). ## 8 CPU Turbo/Accelerator The 6510 CPU emulation inside the Chameleon can run faster as the normal 1 Mhz. Only CPU cycles where memory is accessed can be speed-up. When any registers are accessed the CPU needs to slow down and resynchronize to the C64 clock. This is true for all regster accesses in the $D000_h$ -DFFF $_h$ area. This includes color ram, CIA, VIC-II, SID and also the Chameleon specific registers. The turbo can run at two speeds either double speed or maximum. At double speed there are two accesses in a single system cycle, when VIC-II accesses are turned off the timing is almost identical to the C128 in 2 Mhz mode. When the turbo is set to maximum the CPU uses all remaining free SDRAM cycles. The exact speed of the CPU will depend on the type of code executed and which RAM locations are accessed (which influences the cache hit rate) and how many other devices and controllers are activated inside Chameleon. Turning off unused blocks inside Chameleon will allow the CPU to run at faster speed. Especially the amount, depth and size of graphic layers active on the VGA display can have a great effect on the available memory bandwidth. ## 8.1 Turbo Configuration Register | Address (I | Hex) Address (Dec | ) Name | Description | | |--------------|---------------------|-------------------------------------------------------------------------|---------------------|--| | $D0F3_h$ bit | 53491 settings | CFGTUR description | Turbo configuration | | | 7 | Turbo Enable | 0 = 1 Mhz mod<br>1 = Turbo mod | | | | 6 | Turbo switch | 0 = Manual setting<br>1 = Turbo mode is switchable with button | | | | 5 | VIC-II turbo bit | 0 = Off<br>1 = "Turbo Enable" is mirrored at bit 0 of D030 <sub>h</sub> | | | | 4-1 | Reserved, must be 0 | | | | | 0 | Turbo speed limit | 0 = maximum s<br>1 = CPU limite | 1 | | ## 9 Disk Drive Emulation The Chameleon can emulate upto two 1541 disk-drives. These are known as drive 8 and drive 9, although the ID can be changed when there is also an external drive connected. Drive 8 emulates a standard 1541 drive with optional 8 Kbyte RAM expansion. The ROM size can be upto 32 Kbyte. Drive 9 can also emulate a standard 1541 drive with optional 8 KByte RAM expansion, but can also switched into an enhanced mode. In this mode it has additional registers to access the MMU, MMC card and it can also control parts of the drive 8 emulation. This advanced drive is able to D64 without going though the menu. This can have advantages when using the Chameleon as standalone drive emulator. Ofcourse other functions could be assigned that use MMC and IEC bus (printer emulation). This however will require additional software effort. - 9.1 Drive Memory Map - 9.2 Disk track layout - 9.3 Drive Configuration Registers ## 10 SID Emulation ## 10.1 SID Configuration Register | Address (I | Hex) Address (Dec | ) Name | Description | | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|--| | $D0F4_h$ | 53492 | CFGSID | SID emulation | | | bit | settings | description | | | | 7 | Reserved, must be 0 | | | | | 6 | SID type | 1 = Emulate 8 | 581 SID-Chip(s)<br>580 SID-Chip(s)<br>ted in beta firmware, must be set to 0! | | | 5–3 | Stereo SID in C64 | 100 Single SID in C64 101 Second SID in C64 at D420 $h$ 101 = reserved 101 = reserved 100 = Second SID in C64 at D500 $h$ 101 = Second SID in C64 at D700 $h$ 101 = Second SID in C64 at DE00 $h$ 110 = Second SID in C64 at DE00 $h$ 111 = Second SID in C64 at DF00 $h$ For C-One use "000" when zero or one SID-Chip is placed and "001" when | | | | 2-0 | SID-Chips are present. 00 SID emulation 00 = Emulate single SID 001 = Emulate stereo SID use A5 for selection $(D420_h, D460_h, D4A0_h \dots 110 = Emulate stereo SID use IO1 for second SID (DE00_h) 111 = Emulate stereo SID use IO2 for second SID (DF00_h) others = reserved for future use When only a single SID chip is emulated (setting "000") it is played th both audio output channels in mono. For any of the stereo settings, the first SID-Chip emulation is played th the left audio output channel and is always located in memory at D400_h second SID-Chip emulation is played through the right audio output channel$ | | | | # 11 PS/2 Keyboard connector A PS/2 compatible keyboard can be connected to the Chameleon by using the purple connector on the break-out cable. The keyboard should be connected before applying power to the Chameleon, PS/2 devices are not hot-pluggable. In cartridge mode the PS/2 keyboard can be used in parallel with the C64 keyboard, both operate at the same time. Besides the keyboard function it also emulates a joystick on the numeric-keypad. The NUM-LOCK key toggles between emulating a joystick on port 1 or port 2. ## 11.1 PS/2 Keyboard layout | PS/2 keyboard key | C64 function | PS/2 keyboard key | C64 function | |-------------------|--------------|-------------------|-----------------------------------------| | ESCAPE | RUN/STOP | NUM-LOCK | Select port 1 or port 2 | | F1 | F1 | Numeric 0 | Joystick Fire Button | | F2 | RShift + F1 | Numeric 1 | Joystick Left + Down | | F3 | F3 | Numeric 2 | Joystick Down | | F4 | RShift + F3 | Numeric 3 | Joystick Right + Down | | F5 | F5 | Numeric 4 | Joystick Left | | F6 | RShift + F5 | Numeric 6 | Joystick Right | | F7 | F7 | Numeric 7 | Joystick Left + Up | | F8 | RShift + F8 | Numeric 8 | Joystick Up | | ~ | Left-Arrow | Numeric 9 | ${\rm Joystick}~{\rm Right} + {\rm Up}$ | ## 12 PS/2 Mouse connector A PS/2 compatible mouse can be connected to the Chameleon by using the green connector on the break-out cable. The mouse should be connected before applying power to the Chameleon, PS/2 devices are not hot-pluggable. Although both two buttons mice and three buttons mice with scroll-wheel (known as intelli-mouse) can be used, the scroll-wheel does not have any function. The Chameleon emulates a commodore 1351 mouse. Therefore the PS/2 mouse is usable together with most exisiting software packages that have mouse support. # 13 Infrared remote (CDTV) Chameleon can be controlled with an Amiga CDTV compatible IR remote. The keys on the remote are mapped to C64 joystick and key presses. See following table for the mapping of the keys. | Infrared CDTV remote key | C64 function | |--------------------------|------------------------------| | 1 | F1 | | 2 | RShift + F1 | | 3 | F3 | | 4 | RShift + F3 | | 5 | F5 | | 6 | RShift + F5 | | 7 | F7 | | 8 | RShift + F7 | | 9 | RUN/STOP | | 0 | Spacebar | | ESCAPE | arrow left | | ENTER | RETURN | | REW | cursor left (RShift + right) | | PLAY/PAUSE | cursor up (RShift + down) | | FF | cursor right | | STOP | cursor down | | GENLOCK | Left push button (?) | | CD/TV | Middle push button (Freeze) | | POWER | Right push button (Reset) | | Vol Up | + | | Vol Down | - | | Switch in MOUSE position | Joystick 1 | | Switch in JOY position | Joystick 2 | | A | Fire | | В | Auto fire (8 Hz) | # 14 Complete register map | Address (Hex) Address (Dec) Name | Description | |----------------------------------------------------------------|---------------------------------| | $D040_h$ | VGA Visual X-size <sub>70</sub> | | $D041_h$ | VGA Visual Y-size <sub>70</sub> | | $D042_h$ | VGA Visual size upper bits | | bit settings description | | | 7–4 visual Y-size <sub>118</sub> | | | 3–0 visual X-size <sub>118</sub> | | | $D043_h$ | VGA total X-size <sub>70</sub> | | $D044_h$ | VGA total Y-size <sub>70</sub> | | $D045_h$ | VGA total size upper bits | | bit settings description | | | 7–4 total Y-size <sub>118</sub> | | | 3-0 total X-size <sub>118</sub> | | | $D046_h$ | VGA HSync start <sub>70</sub> | | $D047_h$ | VGA HSync end <sub>70</sub> | | $D048_h$ | VGA HSync upper bits | | bit settings description | | | 7–4 HSync end <sub>118</sub> | | | 3-0 HSync start <sub>118</sub> | | | $D049_h$ | VGA VSync start <sub>70</sub> | | $D04A_h$ | VGA VSync end <sub>70</sub> | | $D04B_h$ | VGA VSync upper bits | | bit settings description | | | 7-4 VSync end <sub>118</sub><br>3-0 VSync start <sub>118</sub> | | ``` D04C_h Select current object Object registers are at D050_h-D05F_h D04D_h First object to render D04E_h Last object to render D04F_h Polarity and Pixel-clock settings description bit 7 VSync polarity 0 = \text{negative sync} 1 = positive sync 6 HSync polarity 0 = \text{negative sync} 1 = \text{positive sync} 0 = \text{disabled} 5 Enable VGA VSync Interrupt 1 = enabled 4 VGA VSync Interrupt status 0 = no interrupt 1 = pending Interrupt status is cleared on any write to D04F<sub>h</sub> 0000 = 25.175 \text{ Mhz} Pixel-clock frequency 3-0 0001 = 31.5 \text{ Mhz} 0010 = Reserved for 36 Mhz 0011 = Reserved for 40 Mhz 0100 = 50 \text{ Mhz} 0101 = Reserved for 65 Mhz 0110 = Reserved for 75 Mhz 0111 = Reserved for 78.8 Mhz 1000 = 108 \text{ Mhz} others = Reserved for future use D050_h COPXL 53328 X position<sub>7..0</sub> D051_h 53329 COPYL Y position<sub>7..0</sub> D052_h 53330 COPYXH position upper bits settings description bit 7-4 Y position<sub>11..8</sub> X position<sub>11..8</sub> D053_h COPWL X size_{7..0} 53331 D054_h 53332 COPHL Y size_{7..0} D055_h 53333 COPHWH size upper bits bit settings description 7-4 Y \text{ size}_{11..8} X size<sub>11..8</sub> D056_h 53334 COPLIL Line increment low D057_h 53335 COPLIH Line increment high D058_h 53336 COPMMU MMU slot 53337 D059_h Stretch and flip description bit settings 7 Vertical flip 0={\rm normal} 1 = flipped / mirror 6-4 stretch 000 = normal size 001 = double height pixels 010 = 4x height pixels 011 = 8x height pixels 100 = 16x height pixels others = Reserved for future use 3 Horizontal flip 0={\rm normal} 1 = flipped / mirror 000 = normal size 001 = double width pixels 2-0 stretch 010 = 4x width pixels 011 = 8x width pixels 100 = 16x width pixels others = Reserved \ for \ future \ use D05A_h 53338 Horizontal smooth scroll (in pixels) D05B_h 53339 Vertical smooth scroll (in lines) D05C_h 53340 Palette offset *** free *** D05D_h 53341 Group and Alpha D05E_h 53342 bit settings description Selects group for collision detection Collision group 6-4 3-0 Alpha-blending value in 6\% steps (1/16\text{th}) Alpha 0000 = \text{Fully opaque } (100\% \text{ new}) ``` 1111=6% of the new color and 94% of background | $D05F_h$ | 53343 | Mode selection | |--------------------|----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit | settings | description | | 7 | Command | 0 = Render bitmap graphics<br>1 = Define tile-set or mask | | | n bit 7 (command) is 0 | | | 6 | Clip rectangle | <ul> <li>0 = use existing clip rectangle</li> <li>1 = Set new clip rectange from object position and dimensions.</li> <li>All following objects will clip to the boundary of this object.</li> </ul> | | 5 | Use masking | 0 = No masking | | 4 | Enable color dither | 1 = Use previously set mask<br>0 = 5 bits color channels (truncated)<br>1 = 8 bits color channels (dithered) | | 3 | Color keying | 0 = object is fully opaque.<br>1 = color 0 is transparent. | | 2-0 | Color depth | 000 = Solid color<br>001 = 1 bit/pixel, 2 palette colors<br>010 = 2 bits/pixel, 4 palette colors<br>011 = 4 bits/pixel, 16 palette colors<br>100 = 8 bits/pixel, 256 palette colors<br>101 = 16 bits/pixel, 32768 color mode<br>110 = 8 bits/tile, 256 tiles<br>111 = 16 bits/tile, 256 tiles with palette offset | | Whe<br>TBD | n bit 7 (command) is 1 | | | | , | | | $D0A0_h$ | 53408 | Address offset bits A <sub>7</sub> –A <sub>0</sub> of current MMU slot | | $D0A1_h$ | 53409 | Address offset bits $A_{15}$ – $A_8$ of current MMU slot | | $D0A2_h$ | 53410 | Address offset bits $A_{23}$ – $A_{16}$ of current MMU slot | | $D0A3_h$ | 53411 | Address offset bit $A_{24}$ of current MMU slot | | bit | settings | description | | 7 | read-only | 0 = Block of memory can be read and written<br>1 = Block of memory is read-only | | $_{0}^{6-1}$ | Reserved for address $\epsilon$<br>Address offset bit $A_{24}$ | extension, must be set to 0 | | $D0A4_h$ $-\Gamma$ | $00AE_h$ 53412 -53 | Reserved for future use | | ${\rm D0AF}_h_{\rm bit}$ | 53423<br>settings description | Select MMU slot | |---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7-0 | $01_h = C6$ $02_h = C6$ $02_h = C6$ $03_h = C6$ $04_h = C6$ $04_h = C6$ $05_h = C6$ $06_h = C6$ $08_h = C6$ $09_h = C6$ $09_h = C6$ $00_h $00_h$ | 44 r/w memory at 0xxxh 44 r/w memory at 1xxxh 44 r/w memory at 1xxxh 44 r/w memory at 3xxxh 44 r/w memory at 3xxxh 44 r/w memory at 4xxxh 44 r/w memory at 5xxxh 44 r/w memory at 5xxxh 44 r/w memory at 5xxxh 44 r/w memory at 5xxxh 44 r/w memory at 5xxxh 44 r/w memory at 8xxxh 44 r/w memory ut 9xxxh 54 r/w memory (under basic) at Axxxh 53 r/w memory (under basic) at Bxxxh 54 r/w memory (under basic) at Bxxxh 54 r/w memory (under kernal) at Exxxh 55 reserved for dare artridge ROM 664 cartridge kByte) 67 reserved for tape *** 68 reserved for dare 9 *** 68 reserved for dare 9 *** 68 reserved for dare 9 *** 68 reserved for dare 9 *** 68 reserved *** 69 DM at E000, -FFFF, (KERNAL, 8 KByte) 60 Mat E000, -FFFF, (KERNAL, 8 KByte) 61 r/w memory at 2000, -5FFF, in menu-mode 62 r/w memory at 4000, -5FFF, in menu-mode 63 r/w memory at 4000, -5FFF, in menu-mode 64 r/w memory at 4000, -5FFF, in menu-mode 64 r/w memory at 2000, 65 r/w memory at 2000, -5FFF, in menu-mode 66 r/w memory at 2000, -5FFF, in menu-mode 67 r/w memory at 2000, -5FFF, in menu-mode 68 r/w memory at 2000, -5FFF, in menu-mode 69 r/w memory at 2000, -5FFF, in menu-mode 60 r/w memory at 2000, -5FFF, in menu-mode 60 r/w memory at 2000, -5FFF, in menu-mode 61 r/w memory at 2000, -5FFF, in menu-mode 62 r/w memory at 2000, -5FFF, in men | | $\frac{\text{D0F0}_h}{\frac{\text{bit}}{7-0}}$ | <del>_</del> | CFGCRT Cartridge emulation elescription 00000000 = Off | | | 0<br>0<br>0<br>1<br>1<br>1 | $\begin{array}{l} 00000001 = \text{RetroReplay} \\ 0000011 = \text{Final Cartridge 3} \\ 00000110 = \text{Expert Cartridge} \\ 0.0000110 = 16\text{K ROM cartridge at } 8000_h - \text{BFFF}_h \\ 0.0000110 = 16\text{K ROM cartridge in Ultimax mode} \\ 0.0000000000000000000000000000000000$ | | $\begin{array}{c} \text{D0F1}_h \\ \underline{ \text{bit} } \end{array}$ | 53489 settings | CFGSPI Clock-port and MMC64 Emulation description | | 7–6<br>5–4 | Reserved, must be 0<br>Clock port | $\begin{array}{l} 00 = \text{Off} \\ 01 = \text{Clock port at DE00}_h\text{-DE0F}_h \\ 10 = \text{Clock port at DF20}_h\text{-DF2F}_h \\ 11 = \text{reserved} \end{array}$ | | 3 2 | Reserved, must be 0<br>MMC64 active | $0=\mathrm{MMC64}$ active (Copy of bit 7 in DF11 <sub>h</sub> )<br>$1=\mathrm{MMC64}$ disabled (DF1x <sub>h</sub> registers are invisible)<br>This bit can only be toggled in DF11 <sub>h</sub> after unlocking, while it can be accessed here at any time.<br>On reset this bit is set to 1 if MMC64 emulation is disabled (bits 1–0 are zero) and 0 when emulation is enabled. | | 1-0 | MMC64 Emulation, SPI | 00 - Off<br>01 = MMC64 Emulation<br>10 = reserved<br>11 = MMC64 Emulation with extra bits combinations defined for access to<br>RTC (Real Time Clock) and FlashRom. | | $\mathrm{D0F2}_h$ | | 53490 | CFGVIC description | VIC-II Emulation Config | |-------------------|---------|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | 7 VI | C-II Read Enable | 0 = Off | . Man | | 6 | 5 Fr | ame buffer Enable | 0 = Off | ory accesses for VIC-II | | 5<br>4 | | served, must be 0<br>rce side-border open | 0 = Not forced op | | | 3 2 | | served, must be 0<br>C-II type | - 000 = PAL (63 co<br>001 = Reserved | s forced open (turbo mode must be on!) lumns, 312 lines) | | | | | 010 = NTSC (65 c)<br>011 = Old-NTSC<br>1xx = Reserved | columns, 263 lines) (64 columns, 262 lines) d-only in cartridge mode. They can be changed in standalone C-One. | | $D0F3_h$ | | 53491 stings | CFGTUR description | Turbo configuration | | 7 | | ırbo Enable | 0 = 1 Mhz mode | | | 6 | | ırbo switch | 1 = Turbo mode act<br>0 = Manual setting | ive | | 5 | 5 VI | C-II turbo bit | | witchable with button | | | | eserved, must be 0 | | is mirrored at bit 0 of $\mathrm{D030}_h$ | | 0 | | rbo speed limit | 0 = maximum speed<br>1 = CPU limited to | | | $D0F4_h$ | | 53492 | CFGSID | SID emulation | | _ | | tings | description | | | 7<br>6 | | eserved, must be 0<br>D type | 0 = Emulate 6581 SI | | | | | | 1 = Emulate 8580 SI<br>Not implemented in | ID-Chip(s) beta firmware, must be set to 0! | | 5 | 5–3 St | ereo SID in C64 | 000 = Single SID in<br>001 = Second SID in | | | 2 | 2-0 SI | D emulation | SID-Chips are present on the street of s | a C64 at D700 $_h$ a C64 at DE00 $_h$ a C64 at DE00 $_h$ a C64 at DF00 $_h$ when zero or one SID-Chip is placed and "001" when both at. e SID o SID use A5 for selection (D420 $_h$ , D460 $_h$ , D4A0 $_h$ ) o SID use IO1 for second SID (DE00 $_h$ ) o SID use IO2 for second SID (DF00 $_h$ ) r future use SID chip is emulated (setting "000") it is played through | | $D0F5_h$ | | 53493 | CFGREU | REU (Ram Expansion Unit) and geoRAM Emulation<br>Config | | b | oit set | tings | description | | | 7<br>6 | | = Enable REU<br>= Enable geoRAM | | ion and activate registers at $\mathrm{DF00_h-DF0A_h}$ . ulation and activate registers at $\mathrm{DE00_h-DEFF_h}$ , $\mathrm{DFFE_h}$ and | | | | oRAM size<br>EU memory size | 000 = 64 KByte<br>001 = 128 KByte<br>010 = 256 KByte<br>011 = 512 KByte<br>100 = 1 MByte<br>101 = 2 MByte<br>110 = 4 MByte<br>111 = reserved for for<br>000 = 128 KByte | uture use | | Does | | 53404 | • | ote there is not enough RAM on C-One for this setting) | | $D0F6_h$ | • | 53494 | CFG??? | Reserved | | ${\rm D0F7}_h_{\rm bit}$ | 53495 settings | CFGD description | SK Di | sk images | | | |---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|-----------------------------------------------------------------------|-----------------------------------------------------------------------------------|--------------------------------|--------------------------------------------------------------| | 7-6<br>5-4<br>3-2<br>1-0 | Disk 9 floppy range<br>Disk 9 floppy select<br>Disk 8 floppy range<br>Disk 8 floppy select | Number of flop<br>Select floppy in<br>Number of flop<br>Select floppy in | mage for dr<br>opy images | ive 9<br>for drive 8 | | | | ${{\rm D0F8}_h}_{\rm bit}$ | 53496 settings | $ \begin{array}{c} \text{CFGF} \\ \text{descript} \end{array} $ | | rive emulation | | | | 7–6<br>5 | Enable virtual-drive ( | 01 = dr<br>0 = Dri | ive cpu stop<br>ive cpu run<br>ve door clos<br>ve door ope | ning<br>sed | | | | $ \begin{array}{c} 4-3 \\ 2 \end{array} $ | Reserved, must be 0<br>Drive memory size | 1 = 8 K | | , | | | | 1-0 | Drive ID jumpers | 01 = dr 10 = dr | ive device i<br>ive device i<br>ive device i<br>ive device i | d is 9<br>d is 10 | | | | $D0F9_h_{\underline{\text{bit}}}$ | 53497 settings | CFGF<br>descript | | eserved for seco | ond drive | | | 7–6<br>5 | Enable virtual-drive ( Drive door | 01 = dr<br>0 = Dri | ive cpu stop<br>ive cpu run<br>ve door clos | ning<br>sed | | | | $^{4-3}_2$ | Reserved, must be 0<br>Drive memory size | 0 = 2 K | ve door ope<br>byte (defau | | | | | 1-0 | Drive ID jumpers | 01 = dr $10 = dr$ | .byte<br>ive device i<br>ive device i<br>ive device i<br>ive device i | d is 9<br>d is 10 | | | | $\begin{array}{c} \text{D0FA}_h \\ \underline{ \text{bit} } \end{array}$ | 53498 settings | CFGR | EG Er<br>descriptio | nable Chameleo | on registers | | | 7<br>6 | reserved, must be 0<br>ROM source | | 1 = C64 of This bit is | Is are banked wit<br>original Basic and<br>s only functional<br>as C-One this bit | d Kernal ROI<br>in cartridge n | Ms are used node. In standalone mode | | 5 | Chameleon banking R | OM at $\mathrm{D}700_h$ | Note that $C64$ origin $0 = No R$ | the character R<br>nal.<br>OM | OM is always | s emulated and never the ort routines is mapped at | | 4 3 | reserved, must be 0<br>Palette Registers Enal | ole | 0 = VIC | II chip mirrors at<br>te registers are a | | | | 2<br>1 | reserved, must be 0<br>Enable Bank/MMU re | egisters | $\stackrel{-}{0} = \text{VIC}$ | II chip mirrors at<br>neleon Bank/MM | D0A0 <sub>h</sub> -D0A | $\Lambda F_h$ | | 0 | Enable VGA Controlle | er Registers | 0 = VIC | II chip mirrors at<br>/COP registers a | $D040_{h}-D07$ | $F_h$ | | $D0FB_h$ bit | 53499 settings | CFGB<br>description | TN De | ebug info and I | Buttons | | | 7-6 | Debug info on VGA | of the scree: $10 = \text{Show}$ | memory an<br>n.<br>memory, ca | d cache load and<br>che, 6510 and dri | ive CPU state | 510 CPU state on the top<br>e.<br>siderable amount of screen | | $\begin{array}{c} 5-4 \\ 3-0 \end{array}$ | Reserved, must be 0<br>Buttons configuration | 1 / | | Middle | | Right | | | | Dere | | | | | | | short | long | short | long | short | long | | | short<br>0000 Menu | | Freeze | long - * reserved *** | short<br>Reset | 9 | | $D0FC_h$ | 53500 settings | CFGCIA description | CIA and IEC configuration | |-------------------|------------------------------------------------|-----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | IEC port | <ul><li>1 = Chameleon IEC system</li><li>By setting this bit,</li><li>In this mode the Ch</li></ul> | bus connected to virtual CIAs bus and any emulated disk-drives are disconnected from the the Chameleon IEC bus is disconnected from the C64 side. ameleon can function as a 1541 drive emulator. This feature he C-One due to a hardware limitation. | | 6 | IEC reset | 0 = Normal operation | | | 6-2<br>1<br>0 | Reserved, must be 0<br>CIA-2 emulation | 0 = Old<br>1 = Type A<br>This bit has no effect<br>0 = Old<br>1 = Type A<br>This bit has no effect | et in cartridge mode | | $D0FD_h$ | 53501 | CFGDIS | A write (any value) leaves configuration mode. A read returns current flash slot where the FPGA image is started from. | | bit | settings | description | | | 7 | VIC-II emulation error | 1 = Error, VGA | ion in sync. with VIC-II chip<br>and VIC-II chip not in sync.<br>lid value in cartridge mode only. | | 6-5<br>4<br>3-0 | Reserved, always 0 Flash slot valid Flash slot | 0 = Slot number<br>1 = Slot number<br>One of 16 slots w | | | $\mathrm{D0FE}_h$ | 53502 | CFGENA | Write $42\ (2A_h)$ to enter configuration mode. When in configuration mode write $16\ \text{to}\ 31\ (10_h\ \text{to}\ 1\text{F}_h)$ to reconfigure the FPGA with a new core. The 4 lower bits specify the slot number in the onboard flash. Write $32\ (20_h)$ in configuration mode to force menu mode. Write $165\ (A5_h)$ to reset machine. Write $166\ (A6_h)$ to reset and leave configuration mode. | | $D0FF_h$ | 53503 | CFGRTI | A write (any value) leaves configuration mode. A read leaves menu mode. | | $D100_h$ $-D$ | $0.1FF_h = 53504 -53504$ | 3759 PALRED | 256 entry color palette <b>Red</b> intensity | | $D200_h$ $-D$ | $0.2FF_h = 53760 = -54$ | 4015 PALGRN | 256 entry color palette <b>Green</b> intensity | | $D300_h$ $-D$ | $03FF_{h}$ $54016$ $-54$ | 4271 PALBLU | 256 entry color palette <b>Blue</b> intensity | | Action F | Replay / RetroRep | play | | | $DE00_h$ | ? settings | ?<br>description | On write | | 7 | | ROM address line 15 | | | 6<br>5 | ROM/RAM ( | O = ROM | | | | , i | 1 = RAM | 14 | | $\frac{4}{3}$ | | ROM/RAM address lin<br>ROM/RAM address lin | | | 2 | Disable | Write 1 to disable carti | | | $\frac{1}{0}$ | EXROM<br>GAME (inverted) | | | | $DE01_h$ | ? | ? | On write | | bit | settings | description | On write | | 7<br>6 | A15<br>REU Compatibility | ROM address line 15<br>0 = Standard memory<br>1 = REU compatible | y map | | 5 | | Not implemented, mu | ast be set to 0 | | $\frac{4}{3}$ | A14<br>A13 | | line 14 (mirror of $DE00_h$ )<br>line 13 (mirror of $DE00_h$ ) | | 2 | | Not implemented, mu | ast be set to 0 | | 1 | AllowBank | | g in $DE02_h$ - $DFFF_h$ area aking in $DE02_h$ - $DFFF_h$ area | | 0 | | Not implemented, mu | | | $\mathrm{DE00}_h$ -D | $E01_h$ ? settings description | ? ? | On read | |------------------------------|------------------------------------|---------------------------------------------------------|-------------------------------------------------------------| | 7 | A15 ROM add | dress line 15 | | | 6<br>5 | Not imple | emented, reads 0 | | | 4 3 | , | AM address line 14<br>AM address line 13 | | | 2 | A13 ROW/RA | TWI address line 13 | | | 1<br>0 | Not imple | emented, reads 0 | | | · · | | | | | REU | | | | | $DF00_h$ | 57088 | DMAST | REU Status register (read-only) | | bit | settings | description | | | 7<br>6 | 1 = IRQ pending $1 = End$ of block | | | | 5 | 1 = Fault | Compare operation det | tected a difference | | 4 | Size | 0 = 128 or 256 KByte<br>1 = 512 KByte | | | | | A single bit can't repr | resent all memory sizes. So software should probe for the | | 3-0 | Version | amount that is really a<br>Always 0000 | wailable | | | | | DELL Common description | | $DF01_h$ | 57089 settings de | DMACMD escription | REU Command register | | 7 | 1 = Execute | | | | 6 | Reserved - | | | | 5 | | Then autoload is enabled<br>the end of the transfer | l. The memory pointers and length registers are reloaded at | | 4 | $\mathrm{FF}00_h$ flag 0 | = Wait for write to FF0 | $00_h$ before starting transfer | | 3-2 | Reserved 1 | = Start immediately wh | nen bit 7 becomes set | | 1-0 | Transfer type 00 | O = C64 to REU | | | | | E REU to C64<br>D = Swap | | | | | = Compare / verify | | | $DF02_h$ | 57090 | $\mathrm{DMA64L}$ | C64 memory pointer low | | $DF03_h$ | 57091 | DMA64H | C64 memory pointer high | | $\mathrm{DF}04_h$ | 57092 | DMAINL | REU memory pointer low | | $DF05_h$ | 57093 | DMAINM | REU memory pointer mid | | $\mathrm{DF}06_h$ | 57094 | DMAINH | REU memory pointer high | | $DF07_h$ | 57095 | DMACNL | Transfer length low | | $DF08_h$ | 57096 | DMACNH | Transfer length high | | $DF09_h$ | 57097 settings | DMAINT description | Interrupt mask register | | 7 | Interrupt enable | 1 = enabled | | | 6 | End Of Block mask | 1 = interrupt after t | | | 5<br>4-0 | Verify mask<br>Reserved | 1 = interrupt on ver<br>Read as 1 | ify error | | | | | A.11 | | $DF0A_h$ | 57098<br>settings | DMACTL description | Address control register | | 7 | C64 Address contro | <del>-</del> | l address | | | | 1 = Fix C64 addre | ss | | 6 | REU Address contr | ol $0 = \text{Increment RE}^{\top}$<br>1 = Fix REU addr | | | 5-0 | Reserved | Read as 1 | | | | | | | | MMC64 | | | | | $\overline{\mathrm{DF}10_h}$ | 57104 | MMCSPI | SPI transfer register. Write in this register sends byte | | DD11 | E 7 1 0 F | MARCOTT | to SPI bus, read is last retrieved byte. | | $DF11_h$ | 57105 | MMCCTL | MMC64 Control register. | | 1 = Trigger SPI trans 0 = Allow external RC 1 = Disable external I 0 = Normal mode 1 = Flash update mode Not implemented, mustor implemented in the second | ided when unlocked for on write to register DF10 <sub>h</sub> for on read of register DF10 <sub>h</sub> DM when BIOS is disabled ROM de st be set to 0 st be set to 0 k DM active led (external ROM active) MMC64 Status register (read-only). reads always as 0 ritten protected nt, slot empty | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit can only be modified and an external responsibility of the secondary o | ied when unlocked fer on write to register DF10 <sub>h</sub> fer on read of register DF10 <sub>h</sub> DM when BIOS is disabled ROM de st be set to 0 st be set to 0 k DM active led (external ROM active) MMC64 Status register (read-only). Teads always as 0 ritten protected at, slot empty (only for 250 Khz mode) geoRAM 256 byte memory window | | 1 = Trigger SPI trans 0 = Allow external RC 1 = Disable external I 0 = Normal mode 1 = Flash update mode Not implemented, mustor implemented in the second | fer on read of register DF10h DM when BIOS is disabled ROM de st be set to 0 st be set to 0 k DM active led (external ROM active) MMC64 Status register (read-only). reads always as 0 ritten protected at, slot empty (only for 250 Khz mode) geoRAM 256 byte memory window | | 1 = Disable external I 0 = Normal mode 1 = Flash update mode Not implemented, mus 0 = 250 KHz SPI clock 1 = 8 Mhz SPI clock 0 = Cart selected 1 = Cart not selected 0 = MMC64 BIOS RO 1 = BIOS ROM disab MMCST description Not implemented to a Cart is write to a Cart is write to a Cart inserted 1 = No cart presented 1 = No cart presented 1 = SPI bus busy ? GEOBUF GEOLOW | de st be set to 0 st be set to 0 st be set to 0 sk DM active led (external ROM active) MMC64 Status register (read-only). reads always as 0 ritten brotected at, slot empty (only for 250 Khz mode) geoRAM 256 byte memory window | | 1 = Flash update mod Not implemented, mus Not implemented, mus 0 = 250 KHz SPI clock 1 = 8 Mhz SPI clock 0 = Cart selected 1 = Cart not selected 0 = MMC64 BIOS RO 1 = BIOS ROM disab MMCST description Not implemented to 0 = Cart can be we 1 = Cart is write to 0 = Cart inserted 1 = No cart presente 0 = SPI bus ready 1 = SPI bus busy ? GEOBUF GEOLOW | of the set to 0 state | | Not implemented, mus 0 = 250 KHz SPI cloc 1 = 8 Mhz SPI cloc 0 = Cart selected 1 = Cart not selected 1 = Cart not selected 0 = MMC64 BIOS RO 1 = BIOS ROM disab MMCST description Not implemented notes are as with a cart is write notes. 1 = Cart is write notes. 0 = Cart inserted notes. 1 = No cart presented notes. 2 | oM active led (external ROM active) MMC64 Status register (read-only). reads always as 0 rritten protected at, slot empty (only for 250 Khz mode) geoRAM 256 byte memory window | | 0 = Cart selected 1 = Cart not selected 0 = MMC64 BIOS RO 1 = BIOS ROM disab MMCST description Not implemented r 0 = Cart can be w 1 = Cart is write r 0 = Cart inserted 1 = No cart preser ne 0 = SPI bus ready 1 = SPI bus busy ? GEOBUF GEOLOW | led (external ROM active) MMC64 Status register (read-only). reads always as 0 ritten protected at, slot empty (only for 250 Khz mode) geoRAM 256 byte memory window | | 0 = MMC64 BIOS RO 1 = BIOS ROM disab MMCST description Not implemented r 0 = Cart can be w 1 = Cart is write r 0 = Cart inserted 1 = No cart preser 0 = SPI bus ready 1 = SPI bus busy ? GEOBUF GEOLOW | led (external ROM active) MMC64 Status register (read-only). reads always as 0 ritten protected at, slot empty (only for 250 Khz mode) geoRAM 256 byte memory window | | description Not implemented to the second s | reads always as 0 rritten protected nt, slot empty (only for 250 Khz mode) geoRAM 256 byte memory window | | 0 = Cart can be w 1 = Cart is write p 0 = Cart inserted 1 = No cart preser 0 = SPI bus ready 1 = SPI bus busy ? GEOBUF GEOLOW | ritten protected nt, slot empty (only for 250 Khz mode) geoRAM 256 byte memory window | | 1 = Cart is write p 0 = Cart inserted 1 = No cart preser 0 = SPI bus ready 1 = SPI bus busy ? GEOBUF GEOLOW | geoRAM 256 byte memory window | | 1 = No cart preser 0 = SPI bus ready 1 = SPI bus busy ? GEOBUF GEOLOW | (only for 250 Khz mode) geoRAM 256 byte memory window | | 0 = SPI bus ready<br>1 = SPI bus busy<br>? GEOBUF<br>GEOLOW | (only for 250 Khz mode) geoRAM 256 byte memory window | | 0 = SPI bus ready<br>1 = SPI bus busy<br>? GEOBUF<br>GEOLOW | (only for 250 Khz mode) geoRAM 256 byte memory window | | ? GEOBUF<br>GEOLOW | geoRAM 256 byte memory window | | GEOLOW | - · · · · · · · · · · · · · · · · · · · | | GEOLOW | - · · · · · · · · · · · · · · · · · · · | | GEOLOW | - · · · · · · · · · · · · · · · · · · · | | | $geoRAM$ address $A_{13}$ – $A_8$ | | | | | description | | | must be set to 0 | | | GEOHI | geoRAM address $A_{21}$ – $A_{14}$ | | | | | | Reads will read cartridge ROM at $1E00_h$ – $1FFF_h$ , $5E00_h$ – $5FFF_h$ , $9E00_h$ – $9FFF_h$ or $DE00_h$ – $DFFF_h$ depending on the current selected bank. | | FC3BNK | On write | | | | | = Banking register invis | | | = Force NMI line low | o of the Tallo distribution as Disson Diff. | | - | | | | | | ate of the EXROM line | | | | | | | | | | scription Banking register write Banking register invis Chameleon setting this Force NMI line low Normal operation ate of the GAME line |