Difference between revisions of "Memory Mapping Register"
From SpecNext official Wiki
(core 3.1.3 changes/refresh) |
m (wording) |
||
Line 7: | Line 7: | ||
bit 7 = port 0xdffd bit 0 \ RAM | bit 7 = port 0xdffd bit 0 \ RAM | ||
− | bits 6:4 = port 0x7ffd bits 2:0 / bank | + | bits 6:4 = port 0x7ffd bits 2:0 / bank 0-15 |
R bit 3 = 1 | R bit 3 = 1 | ||
− | W bit 3 = 1 to change RAM | + | W bit 3 = 1 to change RAM bank, 0 = no change to mmu6 / mmu7 / RAM bank in ports 0x7ffd, 0xdffd |
bit 2 = port 0x1ffd bit 0 paging mode | bit 2 = port 0x1ffd bit 0 paging mode | ||
If bit 2 = paging mode = 0 (normal) | If bit 2 = paging mode = 0 (normal) | ||
bit 1 = port 0x1ffd bit 2 \ ROM | bit 1 = port 0x1ffd bit 2 \ ROM | ||
bit 0 = port 0x7ffd bit 4 / select | bit 0 = port 0x7ffd bit 4 / select | ||
− | If bit 2 = paging mode = 1 (special) | + | If bit 2 = paging mode = 1 (special allRAM) |
bit 1 = port 0x1ffd bit 2 \ all | bit 1 = port 0x1ffd bit 2 \ all | ||
bit 0 = port 0x1ffd bit 1 / RAM | bit 0 = port 0x1ffd bit 1 / RAM |
Revision as of 00:14, 16 April 2020
Number | $8E |
---|---|
Readable | Yes |
Writable | Yes |
Short Description | Control classic Spectrum memory mapping |
bit 7 = port 0xdffd bit 0 \ RAM bits 6:4 = port 0x7ffd bits 2:0 / bank 0-15 R bit 3 = 1 W bit 3 = 1 to change RAM bank, 0 = no change to mmu6 / mmu7 / RAM bank in ports 0x7ffd, 0xdffd bit 2 = port 0x1ffd bit 0 paging mode If bit 2 = paging mode = 0 (normal) bit 1 = port 0x1ffd bit 2 \ ROM bit 0 = port 0x7ffd bit 4 / select If bit 2 = paging mode = 1 (special allRAM) bit 1 = port 0x1ffd bit 2 \ all bit 0 = port 0x1ffd bit 1 / RAM
- Writes can affect all ports 0x7ffd, 0xdffd, 0x1ffd
- Writes always change the ROM / allRAM mapping
- Writes immediately change the current mmu mapping as if by port write
(new register since core 3.1.1)
(note: Next registers with number higher than $7F are inaccessible from Copper code)