Expansion Bus Decoding b8-15 Register

From SpecNext official Wiki
Revision as of 09:42, 12 November 2019 by Ped7g (talk | contribs) (core 3.0 changes/refresh)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to: navigation, search
Number $87
Readable Yes
Writable Yes
Short Description When expansion bus is enabled: Internal ports decoding mask
Bit Description
7 (bit 15) Masking decoding: Layer 2 Access Port ($123B / 4667)
6 (bit 14) Masking decoding: Sprite Attribute Upload ($xx57 / 87), Sprite Pattern Upload ($xx5B / 91) and Sprite Status/Slot Select ($303B / 12347)
5 (bit 13) Masking decoding: Kempston Mouse Buttons ($FADF / 64223), Kempston Mouse X ($FBDF / 64479) and Kempston Mouse Y ($FFDF / 65503)
4 (bit 12) Masking decoding: UART TX ($133B / 4923), UART RX ($143B / 5179) and UART Control ($153B / 5435) (UART)
3 (bit 11) Masking decoding: ($xxE7) and ($xxEB) (SPI)
2 (bit 10) Masking decoding: I2C clock ($103B / 4155) and I2C data ($113B / 4411)
1 (bit 9) Masking decoding: Multiface (two variable ports)
0 (bit 8) Masking decoding: ($xxE3) (DivMMC control)

All bits are set to 1 upon hard reset.

When the expansion bus is on, the expansion port decoding mask (Next Registers $86-$89) is logically ANDed with the internal enables (Next Registers $82-$85). A zero bit indicates the internal device is disabled.

If the expansion bus is on, this allows I/O cycles for disabled internal ports to propagate to the expansion bus, otherwise corresponding I/O cycles to the expansion bus are filtered.

(note: Next registers with number higher than $7F are inaccessible from Copper code)