Programming MMC1: Difference between revisions
No edit summary |
(Removal of syntax highlighter) |
||
Line 3: | Line 3: | ||
== Quick setup for UNROM style == | == Quick setup for UNROM style == | ||
If you are using the [[SGROM]] or [[SNROM]] board to provide an environment similar to [[Programming UNROM|UNROM]], with 8 KB of CHR RAM, a fixed PRG ROM bank at $C000, and a 16 KB switchable PRG ROM bank at $8000, do this in your init code after the mapper has been reset: | If you are using the [[SGROM]] or [[SNROM]] board to provide an environment similar to [[Programming UNROM|UNROM]], with 8 KB of CHR RAM, a fixed PRG ROM bank at $C000, and a 16 KB switchable PRG ROM bank at $8000, do this in your init code after the mapper has been reset: | ||
< | |||
<pre> | |||
lda #$0E ; vertical mirroring, fixed $C000, 8 KB CHR pages | lda #$0E ; vertical mirroring, fixed $C000, 8 KB CHR pages | ||
sta $8000 ; (use $0F instead for horizontal mirroring) | sta $8000 ; (use $0F instead for horizontal mirroring) | ||
Line 14: | Line 15: | ||
lsr a | lsr a | ||
sta $8000 | sta $8000 | ||
</ | </pre> | ||
Games that use CHR RAM switch to another PRG bank before they [[CHR-ROM vs CHR-RAM#Switching to CHR RAM|copy tile data into CHR RAM]]. | Games that use CHR RAM switch to another PRG bank before they [[CHR-ROM vs CHR-RAM#Switching to CHR RAM|copy tile data into CHR RAM]]. | ||
Line 22: | Line 23: | ||
Other revisions guarantee that the fixed bank is loaded at power on. | Other revisions guarantee that the fixed bank is loaded at power on. | ||
To make sure your code works on all MMC1 revisions, put the following code in the last 16 bytes of each 16384 byte bank. (''Barbie'' uses almost identical code.) | To make sure your code works on all MMC1 revisions, put the following code in the last 16 bytes of each 16384 byte bank. (''Barbie'' uses almost identical code.) | ||
< | |||
<pre> | |||
reset_stub: | reset_stub: | ||
sei | sei | ||
Line 30: | Line 32: | ||
jmp reset ; must be in $C000-$FFED | jmp reset ; must be in $C000-$FFED | ||
.addr nmiHandler, reset_stub, irqHandler | .addr nmiHandler, reset_stub, irqHandler | ||
</ | </pre> | ||
Then to switch PRG ROM banks, load the bank number (0-15) into A and call this subroutine: | Then to switch PRG ROM banks, load the bank number (0-15) into A and call this subroutine: | ||
< | |||
<pre> | |||
mmc1_load_prg_bank: | mmc1_load_prg_bank: | ||
sta $E000 | sta $E000 | ||
Line 45: | Line 48: | ||
sta $E000 | sta $E000 | ||
rts | rts | ||
</ | </pre> | ||
== See also == | == See also == | ||
* [[MMC1]] technical reference | * [[MMC1]] technical reference |
Revision as of 04:11, 11 September 2014
MMC1 was Nintendo's first ASIC mapper for the NES.
Quick setup for UNROM style
If you are using the SGROM or SNROM board to provide an environment similar to UNROM, with 8 KB of CHR RAM, a fixed PRG ROM bank at $C000, and a 16 KB switchable PRG ROM bank at $8000, do this in your init code after the mapper has been reset:
lda #$0E ; vertical mirroring, fixed $C000, 8 KB CHR pages sta $8000 ; (use $0F instead for horizontal mirroring) lsr a sta $8000 lsr a sta $8000 lsr a sta $8000 lsr a sta $8000
Games that use CHR RAM switch to another PRG bank before they copy tile data into CHR RAM.
PRG banks
Some revisions of the MMC1 IC might power up in a mode other than fixed-$C000, requiring that the vectors and the start of the init code be placed in all banks, much as in BxROM or AxROM or GxROM. Other revisions guarantee that the fixed bank is loaded at power on. To make sure your code works on all MMC1 revisions, put the following code in the last 16 bytes of each 16384 byte bank. (Barbie uses almost identical code.)
reset_stub: sei ldx #$FF txs ; set the stack pointer stx $8000 ; reset the mapper jmp reset ; must be in $C000-$FFED .addr nmiHandler, reset_stub, irqHandler
Then to switch PRG ROM banks, load the bank number (0-15) into A and call this subroutine:
mmc1_load_prg_bank: sta $E000 lsr a sta $E000 lsr a sta $E000 lsr a sta $E000 lsr a sta $E000 rts
See also
- MMC1 technical reference