Super NES Programming/SNES Specs

Technical specifications

 * Core
 * CPU: Nintendo custom '5A22', believed to be produced by Ricoh; based around a 16-bit CMD/GTE 65c816 (a licensed clone of Western Design Center's 65816). The CPU runs the 65c816-like core with a variable-speed bus, with bus access times determined by addresses accessed, with a maximum theoretical effective clock rate around 3.58 MHz. The SNES/SFC provided the CPU with 128 KB of Work RAM.


 * The CPU also contains other support hardware, including:
 * for interfacing with controller ports;
 * for generating NMI interrupts on Vertical blanking interval;
 * for generating IRQ interrupts on screen positions;
 * Direct memory access unit, supporting two primary modes, general DMA (for block transfers, at a rate of 2.68MB/second) and Horizontal blanking interval DMA (for transferring small data sets at the end of each scanline, outside of the active display period);
 * multiplication and division registers.


 * Cartridge Size Specifications: 2 - 32 Megabits (Mb) which ran at two speeds ('SlowROM' and 'FastROM'). Custom address decoders allow larger sizes, eg. 48 Mb for Star Ocean and Tales of Phantasia


 * Sound
 * Sound Controller Chip: 8-bit Sony SPC700 CPU (inspired by the 6502) for controlling the Digital signal processor running at an effective clock rate around 1.024 MHz.
 * Main Sound Chip: 8-channel Sony S-DSP with hardware ADPCM decompression, pitch modulation, echo effect with feedback (for reverberation) with 8-tap FIR filter, and ADSR and 'GAIN' (discretely controlled) volume envelopes.
 * Memory Cycle Time: 279 ms
 * Sound RAM: 512 kilobit(Kb) shared between SPC700 and S-DSP.
 * Pulse Code Modulator: 16-bit ADPCM (using 4-bit compressed ADPCM samples, expanded to 15-bit resolution, processed with an additional 4-point Gaussian sound interpolation).
 * Note - while not directly related to SNES hardware, the standard extension for SNES audio subsystem state files saved by emulators is SPC_sound_format(.spc), a format used by SPC players.


 * Video
 * Picture Processor Unit: 15-Bit
 * Video RAM: 64 KB of VRAM for screen maps (for 'background' layers) and tile sets (for backgrounds and objects); 512 + 32 bytes of 'OAM' (Object Attribute Memory) for objects; 512 bytes of 'CGRAM' for palette data.
 * Palette: 256 entries; 15-Bit color (BGR555) for a total of 32,768 colors.
 * Maximum colors per layer per scanline: 256.
 * Maximum colors on-screen: 32,768 (using color arithmetic for transparency effects).
 * Resolution: between 256x224 and 512x448. Most games used 256x224 pixels since higher resolutions caused slowdown, flicker, and/or had increased limitations on layers and colors (due to memory bandwidth constraints); the higher resolutions were used for less processor-intensive games, in-game menus, text, and high resolution images.
 * Maximum onscreen objects (sprites): 128 (32 per line, up to 34 8x8 tiles per line).
 * Maximum number of sprite pixels on one scanline: 256. The renderer was designed such that it would drop the frontmost sprites instead of the rearmost sprites if a scanline exceeded the limit, allowing for creative clipping effects.
 * Most common display modes: Pixel-to-pixel text mode 1 (16 colors per tile; 3 scrolling layers) and affine mapped text mode 7 (256 colors per tile; one rotating/scaling layer).