Programming MMC1

From NESdev Wiki
Revision as of 07:31, 25 August 2013 by Koitsu (talk | contribs)
Jump to navigationJump to search

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: <source lang="6502">

 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

</source>

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.) <source lang="6502"> 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

</source>

Then to switch PRG ROM banks, load the bank number (0-15) into A and call this subroutine: <source lang="6502"> mmc1_load_prg_bank:

 sta $E000
 lsr a
 sta $E000
 lsr a
 sta $E000
 lsr a
 sta $E000
 lsr a
 sta $E000
 rts

</source>

See also

  • MMC1 technical reference