Memory management controller

From Wikipedia, the free encyclopedia
  (Redirected from Memory Management Controller)
Jump to: navigation, search
The NES uses the 6502 CPU, which has limits for game developers. Nintendo developed its MMC chip line for use in the NES's cartridges to offload processing and expand the capabilities of the system.

Multi-memory controllers or memory management controllers[1] (MMC) are different kinds of special chips designed by various video game developers for use in Nintendo Entertainment System (NES) cartridges. These chips extend the capabilities of the original console and make it possible to create NES games with features the original console can not offer.

With the advent of NES emulators, the code written to emulate these chips became known as mappers.

List of MMC chips[edit]

UNROM[edit]

Early NES MMCs are composed of 7400 series discrete logic chips.[1]:p.29 The UNROM, implemented with two such chips, divides the program space into two 16 KiB banks. The MMC allows a program to switch one bank while keeping one bank always available.[2] Instead of a dedicated ROM chip to hold graphics data (called CHR by Nintendo), games using UNROM store graphics data on the program ROM and copy it to a RAM on the cartridge at run time.[1]:p.29

MMC1[edit]

The MMC1 is Nintendo's first custom mapper integrated circuit to incorporate support for saved games and multi-directional scrolling configurations.[1]:p.30 The chip comes in at least five different versions: MMC1A, MMC1B1, MMC1B2, MMC1B3 and MMC1C. The differences between the different versions are slight, mostly owing to savegame memory protection behavior. The MMC1 chip allows for switching of different memory banks. Program ROM can be selected in 16KB or 32KB chunks, and character ROM can be selected in 4KB or 8KB chunks. An unusual feature of this memory controller is that its input is serial, rather than parallel, so 5 sequential writes (with bit shifting) are needed to send a command to the circuit.[3]

MMC2[edit]

The MMC2 is only used in Mike Tyson's Punch-Out!! and the later rerelease which replaced Mike Tyson. A single 8KB bank of program ROM can be selected (with the remaining 24KB locked) and character ROM can be selected in two pairs of 4KB banks, which would be automatically switched when the video hardware attempts to load particular graphic tiles from memory, thus allowing a larger amount of graphics to be used on the screen without the need for the game itself to manually switch them.[4]

MMC3[edit]

The MMC3 chip, soldered onto a PCB containing Super Mario Bros. 3 and others.

The MMC3 is Nintendo's most popular MMC chip. It comes in MMC3A, B, and C revisions. The MMC3 adds a scanline based IRQ counter to make split screen scrolling easier to perform (mainly to allow the playfield to scroll while the status bar remains motionless at the top or bottom of the screen), along with two selectable 8KB program ROM banks and two 2KB+four 1KB selectable character ROM banks.[5]

MMC4[edit]

This chip is only used in three games, all of which were released only for the Famicom in Japan, and were developed by Intelligent Systems. Functionally, it is nearly identical to the MMC2, where the only difference is that the MMC4 switches program ROM in 16KB banks instead of 8KB banks and has support for a battery-backed SRAM to save game data.[6]

MMC5[edit]

The MMC5 is Nintendo's largest mapper. It was originally also the most expensive, making developers avoid it. Only Koei has seemed to use this chip regularly. The chip has 1 KB of extra RAM, extra sound channels (two square waves), supports vertical split screen scrolling, improved graphics capabilities (making 16,384 different tiles available per screen rather than only 256, and allowing each individual 8x8-pixel background tile to have its own color assignment instead of being restricted to one color set per 2x2 tile group), highly configurable program ROM and character ROM bank switching, and a scanline-based IRQ counter.[7]

MMC6[edit]

The MMC6 is similar to the MMC3, with an additional 1 KB of RAM which can be saved with battery backup.[8]

Famicom Disk System[edit]

The Famicom Disk System's ASIC is an extended chip, which supports a single 6-bit sound channel of wavetable-synthesis with a built in frequency modulator (not to be confused with Yamaha OPL/OPN chips).

AOROM[edit]

The A*ROM mapper, named after the AMROM, ANROM, and AOROM cartridge boards that use it, was developed by Chris Stamper of Rare Ltd., and manufactured by Nintendo. It is found in games developed by Rare for Nintendo, Tradewest, GameTek, Acclaim, and Milton Bradley.[9] It uses 32 KB ROM switch and a CHR RAM. Unlike other chips, it uses one screen mirroring.[10]

Third-party chips[edit]

As Nintendo's NES licensing program allowed North America and Europe distribution to include only first-party hardware in its cartridges, these third party chips were supposed to be used only in Japan. However, some of them had been found in a few North American cartridges as well.

VRC2[edit]

The VRC2 is a chip from Konami that allows program ROM to be switched in 8KB banks, and character ROM to be switched in 1KB banks. This mapper has two known revisions: VRC2a and VRC2b.[11]

VRC4[edit]

The VRC4.

VRC6[edit]

The VRC6.

The VRC6 (Virtual Rom Controller) is an advanced MMC chip from Konami, supporting bank switching for both program code and graphics as well as a CPU cycle–based IRQ counter, which can also act as a scanline counter. The chip also contains support for three extra sound channels (two square waves of eight duty cycles each, and one sawtooth wave). It is used in Akumajō Densetsu (the Japanese version of Castlevania III: Dracula's Curse), while the Western version uses the MMC5 from Nintendo. Since the Nintendo Entertainment System does not allow cartridges to add additional sound channels, the Famicom version's soundtrack was reworked to follow those specifications; thus, the soundtrack on the Western version is implemented by the five sound channels built into the stock NES.

VRC7[edit]

The VRC7 with a post-processor for the FM synthesis.

The VRC7 is a very advanced MMC chip from Konami, not only supporting bank switching and IRQ counting equivalent to the VRC6 but also containing a YM2413 derivative providing 6 channels of FM Synthesis audio. This advanced audio is used only in the Famicom game Lagrange Point; while the Japanese version of Tiny Toon Adventures 2 also used the VRC7, it does not make use of the extended audio.[12]

NAMCO106[edit]

  • Manufacturer: Namco
  • Games used in: Erika to Satoru no Yumebouken, Final Lap, King of Kings, Mappy Kids, Megami Tensei II, Namco Classic II, Sangokushi, Sangokushi 2, Youkai Douchuuki, Rolling Thunder(JP)

The NAMCO106 has been only used in games exclusive to Japan. Its capabilities were comparable to Nintendo's MMC3. A variant of this mapper, the NAMCO163 contained extra sound hardware that plays 4-bit wave samples. It supports 1 to 8 extra sound channels, but aliasing increases with the number of active channels.

FME-7[edit]

The FME-7 is a memory mapping circuit developed by Sunsoft for use in NES and Famicom cartridges. It allows the program ROM to be switched in 8KB banks and the character ROM to be switched in 1KB banks. It also contains hardware allowing the cartridge to generate IRQ signals after a specified number of CPU clock cycles, thus enabling split-screen effects with minimal use of processing power. A special version of this mapper, labeled as "SUNSOFT 5B" rather than "FME-7", contains a version of the widely used Yamaha YM2149. This sound generation hardware is used on only one Famicom title: Gimmick!.

SUNSOFT-4[edit]

SUNSOFT-4

Unlicensed MMCs[edit]

Some individual (homebrew) and unlicensed developers have made custom MMCs for the NES, most of which simply expand the available memory.

228[edit]

228 is a simple bank switching mapper developed for use in the notoriously poor-quality games Action 52 and Cheetahmen II. It does not have a nametable control bit. In the Action 52 multicart, it also contains a small 16-bit register area that contains the old menu selection when exiting a game.

See also[edit]

References[edit]

External links[edit]