SNESdev Wiki: Difference between revisions
From SNESdev Wiki
Jump to navigationJump to search
Rainwarrior (talk | contribs) (→Examples and Guides: multiplication, scrolling a large map) |
m (Fixed Typo; this is the last Edit today, i promise ;)) |
||
(76 intermediate revisions by 7 users not shown) | |||
Line 4: | Line 4: | ||
=== General === | === General === | ||
* [[Memory map]] | * [[Memory map|Memory Map]] | ||
* [[ROM header]] | * [[ROM header|ROM Header]] | ||
* [[CPU vectors|CPU Vectors]] | |||
* [[SNES Development Manual]] | * [[SNES Development Manual]] | ||
* [[65C816]] - SNES main CPU, part of the S-CPU | |||
* [[Tools]] | * [[Tools]] | ||
* [[Timing]] | |||
* [[Errata]] | |||
* [[Glossary]] | |||
=== Registers === | === Registers === | ||
* [[PPU registers]] | * [[MMIO registers|MMIO Registers]] | ||
* [[DMA registers]] | * [[PPU registers|PPU Registers]] | ||
* [[DMA registers|DMA Registers]] | |||
=== Pinouts === | === Pinouts === | ||
* [[APU pinout]] | * [[S-CPUN Pinout|1CHIP Pinout]] | ||
* [[CPU pinout]] | * [[APU pinout|APU Pinout]] | ||
* [[PPU pinout]] | * [[CPU pinout|CPU Pinout]] | ||
* [[Cartridge connector]] | * [[PPU pinout|PPU Pinout]] | ||
* [[DSP Pinout|DSP Coprocessor Pinout]] | |||
* [[S-RGB Pinout]] | |||
* [[S-ENC Pinout]] | |||
* [[S-MIX Pinout]] | |||
* [[CIC Pinout]] | |||
* [[MAD-1 Pinout]] | |||
* [[WRAM pinout|WRAM Pinout]] | |||
* [[Cartridge connector|Cartridge Connector]] | |||
* [[Controller connector|Controller Port]] | |||
=== Peripherals === | === Peripherals === | ||
* [[Standard controller|Standard Controller]] | |||
* [[Mouse]] | * [[Mouse]] | ||
* [[Multitap]] | |||
* [[Super Scope]] | |||
* [[NTT Data Keypad|NTT Data Keypad]] | |||
* [[Copier]] | |||
* [[Turbo File Twin]] | |||
* [[Voyager-kun/Mr. Voice]] | |||
* [[Sufami Turbo]] | |||
=== PPU === | === PPU === | ||
* [[Backgrounds]] | |||
* [[Tilemaps]] | |||
* [[Tiles]] | |||
* [[Sprites]] | |||
* [[Palettes]] | |||
* [[Windows]] | |||
* [[Offset-per-tile]] | * [[Offset-per-tile]] | ||
* [[Color math]] | |||
=== Sound === | |||
* [[S-SMP]] - SNES SHVC-SOUND Board includes the S-SMP / SPC-700 CPU and S-DSP | |||
* [[SPC-700 instruction set|SPC-700 Instruction Set]] | |||
* [[S-DSP registers|S-DSP Registers]] - Not to be confused with the DSP-x Coprocessors | |||
* [[DSP envelopes|DSP Envelopes]] | |||
* [[BRR samples|BRR Samples]] | |||
=== Expansions === | |||
* [[DSP-1]] - also includes DSP-2, DSP-3, DSP-4 | |||
* [[SA-1]] | |||
* [[Super FX]] (GSU) | |||
* [[MSU-1]] | |||
* [[Super Game Boy]] | |||
* [[CX4]] used in ''Mega Man X2''/''X3'' | |||
=== Formats === | |||
* [[ROM file formats|ROM File Formats]] | |||
* [[Save file formats|Save File Formats]] | |||
* [[SPC file format|SPC File Format]] - For Music that can run Entirely on the SPC. [https://wiki.superfamicom.org/nintendo-music-format-(n-spc) reference] | |||
* [[SNSF file format|SNSF File Format]] - For Music that needs the Main CPU as well. [https://www.vgmpf.com/Wiki/index.php/SNSF reference], [https://snsf.caitsith2.net/snsf%20spec.txt spec] | |||
== Examples and Guides == | == Examples and Guides == | ||
=== General === | |||
* [[Tutorials]] | |||
=== SNES hardware === | |||
* [[Init code]] | * [[Init code]] | ||
* [[65c816 for 6502 developers]] | * [[VBlank interrupts]] | ||
* [[Booting the SPC700]] | |||
* [[Controller reading]] | |||
* [[Multiplication]] | |||
* [[Division]] | |||
* [[DMA examples]] | |||
* [[Blargg SPC upload]] - Playing an SPC rip on SNES Hardware | |||
=== 65c816 guides === | |||
* [[65c816 for 6502 developers|65C816 for 6502 Devs]] | |||
* [[Using X as a pointer|Using X as a Pointer]] | |||
* [[MVN and MVP block copy|MVN and MVP Block Copy]] | |||
* [[Register sizes in ca65|Reg. Sizes in CA65]] | |||
* [[Signature byte]] - supplying a parameter byte for BRK/COP interrupts or WDM | |||
=== Emulation === | |||
* [[Emulator tests|Emulator Tests]] | |||
* [[Tricky-to-emulate games|Tricky-to-Emulate Games]] | |||
* [[Uncommon graphics mode games|Games with Uncommon Graphics Modes]] | |||
=== Video === | |||
* [[VBlank routine|VBlank Routine]] | |||
* [[SNES PPU for NES developers]] | * [[SNES PPU for NES developers]] | ||
* [[Scrolling a large map]] | * [[Scrolling a large map]] | ||
* [[Drawing window shapes]] | |||
* [[HDMA examples|HDMA Examples]] | |||
* [[Reading and writing PPU memory]] | |||
* [[Mode 7 perspective effects|Mode 7 Effects]] | |||
* [[Starting HDMA mid-frame]] | |||
* [[Variable width fonts|Variable Width Fonts]] | |||
* [https://undisbeliever.net/snesdev/registers/inidisp.html#extended-vblank Extending vblank ] | |||
== Links == | == Links == | ||
Line 40: | Line 119: | ||
* [https://problemkaputt.de/fullsnes.htm Fullsnes] - Nocash's SNES hardware document | * [https://problemkaputt.de/fullsnes.htm Fullsnes] - Nocash's SNES hardware document | ||
* [https://wiki.superfamicom.org/ Superfamicom.org SNES Development Wiki] | * [https://wiki.superfamicom.org/ Superfamicom.org SNES Development Wiki] | ||
* [https://en.wikibooks.org/wiki/Super_NES_Programming Super NES Programming Wikibooks] | |||
* [https://superfamicom.org/ Superfamicom.org SNES cartridge database] | * [https://superfamicom.org/ Superfamicom.org SNES cartridge database] | ||
* [https://snescentral.com/ SNES Central] - game database and PCB images | |||
* [https://www.romhacking.net/community/548/ Anomie's SNES documents] at RHDN | |||
== MediaWiki == | == MediaWiki == | ||
* [https://www.mediawiki.org/wiki/Special:MyLanguage/Help:Contents User's Guide] | * [https://www.mediawiki.org/wiki/Special:MyLanguage/Help:Contents User's Guide] | ||
* [https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:FAQ MediaWiki FAQ] | * [https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:FAQ MediaWiki FAQ] | ||
* [ | * [[:Category:Deletion requests|Deletion requests]] | ||
Latest revision as of 21:01, 30 December 2024
SNES Development Wiki
Reference
General
- Memory Map
- ROM Header
- CPU Vectors
- SNES Development Manual
- 65C816 - SNES main CPU, part of the S-CPU
- Tools
- Timing
- Errata
- Glossary
Registers
Pinouts
- 1CHIP Pinout
- APU Pinout
- CPU Pinout
- PPU Pinout
- DSP Coprocessor Pinout
- S-RGB Pinout
- S-ENC Pinout
- S-MIX Pinout
- CIC Pinout
- MAD-1 Pinout
- WRAM Pinout
- Cartridge Connector
- Controller Port
Peripherals
- Standard Controller
- Mouse
- Multitap
- Super Scope
- NTT Data Keypad
- Copier
- Turbo File Twin
- Voyager-kun/Mr. Voice
- Sufami Turbo
PPU
Sound
- S-SMP - SNES SHVC-SOUND Board includes the S-SMP / SPC-700 CPU and S-DSP
- SPC-700 Instruction Set
- S-DSP Registers - Not to be confused with the DSP-x Coprocessors
- DSP Envelopes
- BRR Samples
Expansions
- DSP-1 - also includes DSP-2, DSP-3, DSP-4
- SA-1
- Super FX (GSU)
- MSU-1
- Super Game Boy
- CX4 used in Mega Man X2/X3
Formats
- ROM File Formats
- Save File Formats
- SPC File Format - For Music that can run Entirely on the SPC. reference
- SNSF File Format - For Music that needs the Main CPU as well. reference, spec
Examples and Guides
General
SNES hardware
- Init code
- VBlank interrupts
- Booting the SPC700
- Controller reading
- Multiplication
- Division
- DMA examples
- Blargg SPC upload - Playing an SPC rip on SNES Hardware
65c816 guides
- 65C816 for 6502 Devs
- Using X as a Pointer
- MVN and MVP Block Copy
- Reg. Sizes in CA65
- Signature byte - supplying a parameter byte for BRK/COP interrupts or WDM
Emulation
Video
- VBlank Routine
- SNES PPU for NES developers
- Scrolling a large map
- Drawing window shapes
- HDMA Examples
- Reading and writing PPU memory
- Mode 7 Effects
- Starting HDMA mid-frame
- Variable Width Fonts
- Extending vblank
Links
- SNESdev Forum - NESDev subforum
- Fullsnes - Nocash's SNES hardware document
- Superfamicom.org SNES Development Wiki
- Super NES Programming Wikibooks
- Superfamicom.org SNES cartridge database
- SNES Central - game database and PCB images
- Anomie's SNES documents at RHDN