mirror of https://github.com/bsnes-emu/bsnes.git
154 lines
4.9 KiB
Markdown
154 lines
4.9 KiB
Markdown
|
Override a game's memory map
|
||
|
============================
|
||
|
|
||
|
In order to correctly emulate
|
||
|
how a real Super Nintendo would play a particular game,
|
||
|
bsnes [needs to know](https://byuu.net/cartridges/boards/)
|
||
|
how that game's data would be arranged
|
||
|
in the system's memory map,
|
||
|
and any extra hardware that might have been present in the game's cartridge.
|
||
|
This extra data describing a game
|
||
|
is called a "manifest".
|
||
|
When searching for manifest data,
|
||
|
bsnes uses the first source it finds
|
||
|
in the following list:
|
||
|
|
||
|
1. The [SNES Preservation Project][snespres] database provided with bsnes
|
||
|
- This provides accurate data for most commercially released games
|
||
|
1. A manifest file stored beside the ROM file
|
||
|
- Allows you to control the exact memory map the emulated game will see
|
||
|
1. Heuristic analysis of the ROM file
|
||
|
- Works for all commercially released games,
|
||
|
but often broken for prototypes, betas, mods, and homebrew games
|
||
|
|
||
|
[snespres]: https://byuu.org/preservation
|
||
|
|
||
|
Where to get a manifest
|
||
|
-----------------------
|
||
|
|
||
|
The easiest place to get a working manifest
|
||
|
is from the included game database.
|
||
|
Open the [Database/Super Famicom.bml][gamedb] file,
|
||
|
search for the name of a game that's similar
|
||
|
to the one you want to get working,
|
||
|
then copy the entire "game" block.
|
||
|
|
||
|
[gamedb]: https://github.com/bsnes-emu/bsnes/blob/master/bsnes/Database/Super%20Famicom.bml
|
||
|
|
||
|
You should wind up with something that looks like this:
|
||
|
|
||
|
game
|
||
|
sha256: 12b77c4bc9c1832cee8881244659065ee1d84c70c3d29e6eaf92e6798cc2ca72
|
||
|
label: Super Metroid
|
||
|
name: Super Metroid
|
||
|
region: SNS-RI-USA
|
||
|
revision: SHVC-RI-0
|
||
|
board: SHVC-BA3M-01
|
||
|
memory
|
||
|
type: ROM
|
||
|
size: 0x300000
|
||
|
content: Program
|
||
|
memory
|
||
|
type: RAM
|
||
|
size: 0x2000
|
||
|
content: Save
|
||
|
|
||
|
Alternatively,
|
||
|
if you don't know the name of a similar game,
|
||
|
or if the same game has multiple different entries
|
||
|
(for example, a USA and a Europe release),
|
||
|
you can use the Manifest Viewer
|
||
|
to copy the manifest from a working game.
|
||
|
|
||
|
Load up the working game in bsnes,
|
||
|
then from the Tools menu,
|
||
|
choose "Manifest Viewer",
|
||
|
and you'll see the complete manifest bsnes is using.
|
||
|
Again, you can copy the "game" block
|
||
|
(ignore the separate "board" block below it).
|
||
|
|
||
|
How to modify it
|
||
|
----------------
|
||
|
|
||
|
You should paste the manifest
|
||
|
into a "plain text" editor to modify it,
|
||
|
like Notepad++ on Windows,
|
||
|
or TextEdit (in plain-text mode) on macOS.
|
||
|
Regular old Notepad may work if you're using a version
|
||
|
that can save files with Unix (LF) line-endings.
|
||
|
Don't use a word processor that can format text,
|
||
|
like Microsoft Word or Wordpad,
|
||
|
since bsnes doesn't understand formatting codes
|
||
|
and it will get confused.
|
||
|
|
||
|
You can remove the lines beginning with `sha256:`, `name:`, and `revision:`,
|
||
|
if present,
|
||
|
since they're only useful for tracking
|
||
|
which games are included in the official database.
|
||
|
The text after `label:` controls
|
||
|
the name that bsnes will display in the title-bar
|
||
|
when the game is loaded.
|
||
|
The text after `region:` tells bsnes
|
||
|
whether the game expects to be run on an NTSC system
|
||
|
(Japan, USA)
|
||
|
or a PAL system (Europe, Australia).
|
||
|
In the game database,
|
||
|
this field holds the publisher's unique identifier
|
||
|
from which bsnes infers the correct region,
|
||
|
but you can just write "NTSC" or "PAL".
|
||
|
|
||
|
You should also check the "memory" block with `type: ROM`.
|
||
|
The `size:` field describes the expected size
|
||
|
of the ROM image, in bytes.
|
||
|
In our example above,
|
||
|
the size is 0x300000 in hexadecimal,
|
||
|
which is 3,145,728 in decimal,
|
||
|
which is the exact number of bytes in the Super Metroid ROM image.
|
||
|
If the manifest you're using as an example
|
||
|
mentions a *different* size
|
||
|
than the ROM image you're trying to get working,
|
||
|
it's probably the wrong example
|
||
|
and you should choose a different one.
|
||
|
|
||
|
Where to put it
|
||
|
---------------
|
||
|
|
||
|
Make sure you save your customised manifest
|
||
|
as a plain text file,
|
||
|
using Unix (LF) line endings,
|
||
|
and the UTF-8 text encoding.
|
||
|
|
||
|
If your ROM image is in a higan-style game folder
|
||
|
(a directory with the `.sfc` extension,
|
||
|
containing a `program.rom` file),
|
||
|
save the manifest in that directory,
|
||
|
named `manifest.bml`.
|
||
|
|
||
|
If your ROM image is a single file
|
||
|
(probably with the `.sfc` extension),
|
||
|
save the manifest beside it with the `.bml` extension.
|
||
|
For example,
|
||
|
if the ROM you're trying to get working is called `myhomebrew.sfc`,
|
||
|
save the manifest beside it as `myhomebrew.bml`.
|
||
|
|
||
|
Troubleshooting
|
||
|
---------------
|
||
|
|
||
|
If your ROM now loads correctly, congratulations!
|
||
|
|
||
|
If it's still broken,
|
||
|
the easiest way to verify that bsnes is reading your manifest
|
||
|
is to open the Manifest Viewer from the Tools menu.
|
||
|
If you don't see the manifest data as you created it,
|
||
|
make sure the manifest data is saved in the correct location,
|
||
|
with the correct name,
|
||
|
and in the correct file format.
|
||
|
|
||
|
Also,
|
||
|
note that bsnes ignores external manifests
|
||
|
for games that appear in its game database.
|
||
|
|
||
|
If your manifest is being read correctly,
|
||
|
but the game still doesn't work,
|
||
|
you should try basing your manifest off a different game.
|