Company | RetroUSB, InfiniteNESLives, Broke Studio |
Complexity | Discrete logic |
Boards | UNROM-512-8, UNROM-512-16, UNROM-512-32, INL-D-RAM, UNROM-512-F |
PRG ROM capacity | 256K or 512K |
PRG ROM window | 16K + 16K fixed ($C000) |
PRG RAM capacity | None |
CHR capacity | 32K |
CHR window | 8K |
Nametable mirroring | H or V (solder pad), 1-screen (solder pad or switchable), 4-screen fixed |
Bus conflicts | Yes (in non-flashable config), else No |
IRQ | No |
Audio | No |
iNES mappers | 030 |
UNROM 512 is a discrete-logic board made by RetroUSB as an extension of UNROM with up to 512kB of PRG ROM, bankable CHR RAM, an option for mapper-controlled single-screen mirroring, as well as a self-flashable configuration for rewriting PRG. Since its initial creation InfiniteNESLives has replicated its design and also added an optional four-screen mirroring variation.
The iNES format assigns iNES Mapper 030 to UNROM 512.
The UNIF names for this board are UNROM-512-8, UNROM-512-16 and UNROM-512-32, depending on how much CHR RAM is present.
In GoodNES 3.23b, a few ROMS using the Waixing FS005 board (INES Mapper 176) are also set to Mapper 30. These ROMs were converted from Waixing's proprietary WXN/MFC format, which has a 16 byte header that is somewhat similar but not the same as the INES header, and when interpreting this header's data as if it were an iNES header, the resulting mapper number would be 30.
Examples:
The example board in question is marked as follows: "Sealie Computing", "12/29/2011 revA", "UNROM 512". The backside of the board was mislabelled with "ReproPak MMC3".
The board includes:
Some images of the board:
When board is not flashable:
Registers: --------------------------- Range,Mask: $8000-FFFF, $8000 $8000: [MCCP PPPP] M = One screen Mirroring select C = CHR RAM bank P = PRG ROM bank PRG Setup: --------------------------- $8000 $A000 $C000 $E000 +-------------------------------+ | $8000 | { -1} | +---------------+---------------+ CHR Setup: --------------------------- $0000 $1000 +-------+-------+ | $0000 | +-------+-------+
When board is self flashable:
Registers: --------------------------- Mask: $C000 $8000: [.... ....] Write a sequence of bytes here for writing to the flash. The sequence is as follows (This code must exist in wram): Erase 4KB Flash Sector: $C000:$01, $9555:$AA $C000:$00, $AAAA:$55 $C000:$01, $9555:$80 $C000:$01, $9555:$AA $C000:$00, $AAAA:$55 $C000:BANK, ADDR:$30 (Where BANK is $00-1F, ADDR is $8000,$9000,$A000,$B000) Read the written location twice until you get $FF twice. Write a byte: $C000:$01, $9555:$AA $C000:$00, $AAAA:$55 $C000:$01, $9555:$A0 $C000:BANK, ADDR:DATA (Where BANK is $00-1F, ADDR is $8000-$BFFF, DATA is $00-$FF) Read the written location twice until you get DATA twice. Additionally, on 8BIT XMAS boards, any writes here controls the LEDs as follows. $8000: [BYGR bygr] B = Blue 3, Blue 4 Y = Yellow 3, Yellow 4 G = Green 3, Green 4 R = Red 3, Red 4 b = Blue 1, Blue 2 y = Yellow 1, Yellow 2 g = Green 1, Green 2 r = Red 1, Red 2 $C000: [MCCP PPPP] M = One screen Mirroring select C = CHR RAM bank P = PRG ROM bank PRG Setup: --------------------------- $8000 $A000 $C000 $E000 +-------------------------------+ | $8000 | { -1} | +---------------+---------------+ CHR Setup: --------------------------- $0000 $1000 +-------+-------+ | $8000 | +-------+-------+
____ A14 ---------\ \ ) >--- ROM A14 377 Q0 ------/____/ ____ A14 ---------\ \ ) >--- ROM A15 377 Q1 ------/____/ ____ A14 ---------\ \ ) >--- ROM A16 377 Q2 ------/____/ ____ A14 ---------\ \ ) >--- ROM A17 377 Q3 ------/____/ ____ A14 ---------\ \ ) >--- ROM A18 377 Q4 ------/____/ 16/32KB CHRRAM 377 Q5 --[]--+-- CHRRAM A13 | VCC -----[]--+ 8KB CHRRAM 8/16KB CHRRAM VCC -----[]--+ | 377 Q6 --[]--+-- CHRRAM A14 32KB CHRRAM ONE 377 Q7 --[]--+ | VERT | PPU A10 -[]--+-- CIRAM_A10 | HORIZ | PPU A11 -[]--+ FLASHLOCKED3 R/W ------[]-+ | FLASHABLE | GND ------[]-+-- 377_/CE FLASHLOCKED1 VCC ------[]-------+ ½74LS139 | .------. | CPUA14----|A Y0|-+- PRGROM_/WE R/W ------|B Y1|-+- 377_CLK | Y2| | /ROMSEL-+-|G Y3| | | '------' | | | +---[]-----+ FLASHLOCKED2 FLASHLOCKED4 GND ------[]-----+ ½74LS139 | .------. | R/W ----|A Y0| | GND ----|B Y1|-+- PRGROM_/OE | Y2| /ROMSEL-|G Y3| '------' With 8BIT Xmas Board, there is a second 377 chip for the LEDs, and 2 jumpers to control whether the 377 is sourcing current to the LEDs or sinking current from them. Additionally, the board has no flash control jumpers, and is hard-wired flashable, and has no CHR ram control jumpers, is hard-wired as 32KB, and it does not have the second 74LS32 chip, required for a 512KB board, so its max size is 256KB. Q0-----R1-----RED1-----RED2-------+ Q1--+--R6-----GRN1----------------+ +--R5-----GRN2----------------+ Q2-----R3-----YEL1-----YEL2-------+ Q3--+--R9-----BLU1----------------+ +--R10----BLU2----------------+ Q4-----R2-----RED3-----RED4-------+ Q5--+--R7-----GRN3----------------+ +--R8-----GRN4----------------+ Q6-----R4-----YEL3-----YEL4-------+ Q7--+--R11----BLU3----------------+ +--R12----BLU4----------------+ | VCC---------[]--------------------+ GND---------[]--------------------+
Not Flashable:
Flashable:
The Self-flashable configuration should be implemented according to the SST39SF040's datasheet.
Example flash writing code - Flash.asm
Address range | Size | Description |
---|---|---|
$0000-$0FFF | $1000 | Pattern Table 0 |
$1000-$1FFF | $1000 | Pattern Table 1 |
$2000-$23FF | $0400 | Nametable 0 |
$2400-$27FF | $0400 | Nametable 1 |
$2800-$2BFF | $0400 | Nametable 2 |
$2C00-$2FFF | $0400 | Nametable 3 |
$3000-$3EFF | $0F00 | Scratch RAM |
$3F00-$3F1F | $0020 | Palette RAM indexes |
$3F20-$3FFF | $00E0 | Mirrors of $3F00-$3F1F |
____ PPU A13 -----\ \ ) >--- CHRRAM A13 377 Q5 ------/____/ ____ PPU A13 -----\ \ ) >--- CHRRAM A14 377 Q6 ------/____/ NON-4SCREEN PPU A13 ----[]--+ | GND --------[]--+---- CHRRAM /CE (Cartridge VRAM) 4SCREEN MIRROR NON-4SCREEN PPU /A13 ---[]--+ | VCC --------[]--+---- CIRAM /CE (NES mainboard VRAM) 4SCREEN MIRROR
NES 2.0 may specify the CHR-RAM size from 8 to 32 kB, but the default for iNES should to use 32 kB.
If the Battery flag is set to 1, the mapper is flashable. This means no bus conflicts should be emulated. On the other hand, bus conflicts should be emulated if the battery flag is cleared.
Mapper 30 is currently only using sub mapper 0. The other sub mappers are reserved for future use.
Supported in FCEUX as of r3071, Supported in BizHawk as of r6322
Supplemental mappers exist for flash carts as well:
The PowerPak flash save capability lacks the sector erase and chip erase capabilities, due to the underlying hardware being RAM at the time of write. As long as the game writes every byte it intends to read back, this is compatible implementation.
The nametable mirroring bits in byte 6 of the iNES header select one of four configurations of nametables:
%....0..0
- Horizontal mirroring (aka: vertical arrangement)%....0..1
- Vertical mirroring (aka: horizontal arrangement)%....1..0
- 1-Screen, switchable%....1..1
- 4-Screen, cartridge VRAMCategories: Discrete logic mappers, Mappers with bus conflicts