Black And Black 2 Pokemon Memory Link On Mac Emulator Desmume
Please do not make it like the code for black and white. Code Sought: Activate Memory Link/Activate ability to catch N's Pokemon. All you have to do is grab a game (ROM), then an emulator, and then start. If you want to save some hassle, simply click on the Play Online links in the game pages and you're all set! Enjoy playing Pokemon, there's nothing like a good trip down memory lane! Pokemon Black Version 2 (DSi Enhanced)(U)(frieNDS).
DS Pokémon White Emulator on PC Mac PSP
Get Excited About the Series Again. When news of the fifth generation Pokemon Black and White Version games first broke in January of 2010, fans were excited by the announcement that some aspects of the franchise would be revamped, since the general feeling was that the series had started to become a little stale. Well, now that the games are finally here, the reaction of those who have posted a Pokemon White online is that the game is a definite improvement over recent releases, and is also sure to attract new fans to the series.
DSi XL Pokemon Emulator
Play Nintendo DSi XL Games on PC, Mac, PSP
Apart from the fact that the new Pokemon White game look really good, with more fully-rendered 3D landscapes, improved attack graphics and camera effects, players also love the new wireless multi-player features, such as the High Link mode that allows them to link their consoles over Wi-Fi so they can work together on missions and help each other out, as well as the Pass By mode that allows them to send data along with other copies of the game when they're not playing. And of course, there's the much talked-about Video Chat mode that allows up to four players to chat at once and even doodle on each other's faces.
As for the gameplay, Pokemon White players have pointed out that it is pretty much what you'd expect from a Pokemon game, except for two notable features: only new Pokemon will be included in the initial playthrough, and you can only unlock the ability to import old Pokemon by first successfully completing the game, and the Isshu region, where the game takes place, will see monthly seasonal changes that result in constantly changing landscapes as well as Pokemon. After playing the White Version game, Pokemon fans old and new agree: its time to get excited about the series again.
No$GBA Nintendo DS Emulator with multiplayer linking support for trading Pokemons from one rom to another.
DeSmuME NDS and DSi XL emulator that is compatible with the latest Poke games.
No$GBA Pokemon Help Page
Do you still remember your experience with first Pokemon games Red, Blue and Yellow? The Pokemon franchise is a sweet part of many people’s childhood or even adulthood. I think you would not easily forget about Blue, Red, Gold or Crystal from the game before. Now, if you hear Pokemon, you can expect to see a nice flashback of all the warm and loving memories during childhood. Even if you may have enjoyed D/P/P and R/S/E as truly fun games, you also need to recognize the fact that Pokemon games also have their fair share of programming and the ambition to get the recognition due for the game series. This is when Pokemon Black and White. However, I cannot say that I am still the biggest fan of the game, given how many of their installments have failed. There were stories swirling around about the game developers have come up with innovations that should surprise us. It took me these rumors to give in to my curiosity about what Pokemon could possibly do for me. After trying it, I should say that it was a good call for me to buy this installment.
I was able to try the innovations referred to in the rumors before their launching. However, it would be too much to expect that you will see the game much like a Final Fantasy installment. The game is still so Pokemon in that you will collect Pokemon, fight Gym Leaders, duel with the Elite 4. However, there are also differences that start with the story. You will not be given a rival but two peer trainers who will also be your best friends. Each best friend has unique personalities and owns up to a character that impacts the plot of the game. This is far from the rival character of a kid who just sneers around the entire game. The Team Plasma, which plays the rival, is also motivated politically and is less evil than the enemies in the past. These are small changes to the story, but it still goes a long way in steering the story all throughout the game.
Best Pokémon White Emulator for Android • iOS & Windows and Mac. Play DS games with touchscreen and onscreen buttons. Download Emu.apk zip.
Pokemon White Version Introduces New Pokemon And A New Region
Welcome to Isshu, the new region introduced in the Pokemon White version where gamers will be introduced to more than 150 new pocket monsters as well as new moves, new places for exploration, and new challenges. While the White version is, in fact, my favorite game in the franchise, here are the pros and cons that must be said.
Story (7/10)
The White version's gameplay is the same as its predecessors. You, the gamer, are a Pokemon trainer who will get your starter Pokemon so that you can engage in Pokemon battles with your rivals. Your ultimate goal in the game is to become the best Pokemon trainer by capturing all of the Pokemon, defeating the Gym Leaders, and beating the Elite Four as well as preventing the plans for world domination of an evil group.
While I'm not fluent in Japanese, I must say that N's story is nice. I'm looking forward to the release of its English counterpart for this reason.
Over-all Graphics (9/10)
While the graphics in a DS videogame isn't the most crucial factor in its overall attraction, the Black and White graphics were amazing. The graphics were beautiful especially for the Overworld although a few of the 3D elements, such as the far too many drawn-out bridges, was already overdoing it.
As any avid gamer knows by now, the Pokemon sprites have battle animations, which means that they move in battle. The result: They look and feel alive and real instead of just being add-ons, which is a nice touch in this version.
When I saw the game's screen caps, however, the back sprites' graphics was a disappointment – too reminiscent of the earliest predecessors in the franchise because of their too pixelated look. Fortunately, once in motion, these sprites have a more fluid movement.
Pokemon Designs (8/10)
All of the 150-plus Pokemon introduced in Isshu Dex are, indeed, brand-new! You will not find Pikachu, Geodude, and Zubat, for example, which means that every pocket monster in Isshu is a character that you haven't seen before.
But there's something I have to get out of the way first before I inadvertently end this section on a bad note. Apparently, the new Pokemon characters in this game have been designed to evoke the appearance of the pocket monsters they have replaced. Examples include Koromori replaced Zubat and Gigaiasu replaced Geodude.
Even the “Bats and Rock monsters in caves” basic idea is still applied to a certain extent. Of course, there are differences but the similarities are there for gamers with a keen eye to see.
With that being said, let's start discussing the reasons why Pokemon designs only garnered 8 on a scale of 1 to 10. We can agree that several of the new Pokemon characters are either stupid or ugly, such as all the legendary Pokemon and the Dokkora line with the exception of the version mascots. Fortunately, the well-designed pocket monsters more than made up for the deficiencies!
If you're looking for cute pocket monsters, your best bets are Chiraamii, Monmen, and Kurumiru because of their charming designs. If you want cool Pokemon on your team, you can try Pendoraaor or Zeburaika, which is Shimama's evolved form. If your tastes run along the weird Pokemon, you have the benefit of the Yabakuron and Baibanira lines.
To be honest about it, the Isshu region's Pokemon have almost always defeated my Pokemon characters from previous versions. While Giaru – or Gear – may be the less imaginative replacement for Magnemite, its battle form is, indeed, such a sight to behold in virtual terms.
If you have lingering issues about the lame stats, the typing, or the battle motion, you should move on. Plus, you will find a wide range of Pokemon types in the Isshu region.
In general, each Pokemon game featured plenty of Water types but without Ghost types. But in Isshu, the Water types have been significantly cut down while still satisfying the Surfers and considerably increased the number of Ghost types, such as Hitomoshi and Desumasu. Add the other types that have also been expanded, such as the Bug Type, and the White version is a joy to play.
Suffice it to say that the Isshu region has a pocket monster for every gamer!
Also, the game designers didn't get on a full-on mode with forms, as was the case in the fourth generation. You will not find new evolution along the lines of Wormadam and Mothim, sadly, although a few of the new characters undergo changes in form. Examples include Basurao's permanent color differences and Hihidaruma's Psychic form.
You may be disappointed that there aren't many differences in gender although it must also be said that the game designers never really used the idea anyway. The existing ones, nonetheless, are cool but Nintendo could have explored the idea more.
Sound (9/10)
One word: Fantastic! The music and sound effects from the battle theme for the wild Pokemon to the theme for Team Plasma were catchy, vibrant and interesting. Such was the music's audio appeal that I'd sometimes listen to the catchy music for a few minutes before starting on the battle mode. But as with every game, there will be a few times with little to no auditory appeal but as you progress in the game, you are likely to find one that you can enjoy listening to for a few minutes.
Game Freak also deserves praise for its creation of fantastic new cries for the pocket monsters. For example, I don't have to quickly turn off the volume to avoid Electabuzz's annoying cry. Most, if not all, of the Pokemon cries are unique aside from giving a relatively pleasant auditory experience.
This page lists concepts, tools and general information on ROM hacking. See Mods, Hacks and Fan-Translations for more information.
- 1Overview
- 1.1Numeral systems
- 1.3Editing text with hex editors
- 2Emulators for ROM hacking
- 4Programs
- 5Game-specific
Overview[edit]
Numeral systems[edit]
Decimal[edit]
Our normal counting system uses the decimal base, or base 10, and goes in the following sequence: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, and so on. The number ten can be mathematically represented in decimal as (1 * 10) + (0 * 1)
or (1 * 10^1) + (0 * 10^0)
. So if we have a number like 234, it can be represented as (2 * 100) + (3 * 10) + (4 * 1)
or (2 * 10^2) + (3 * 10^1) + (4 * 10^0)
.
Hexadecimal[edit]
On the other hand, the hexadecimal base is base 16 and goes in the following sequence: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A (a single 'digit' meaning ten in decimal), B (eleven), C (twelve), D (thirteen), E (fourteen), F (fifteen), then finally 10 (sixteen, (1 * 16) + 0
or (1 * 16^1) + (0 * 16^0)
), 11 (seventeen, (1 * 16) + (1 * 1)
), 12 (eighteen, (1 * 16) + 2
), and so on. Typically, hexadecimal numbers are written with the prefixes 0x
or h
so that they are not confused with decimal equivalents (e.g., 0x10
, decimal 16
). If this sounds too complicated, you can load Calculator in programmer mode to do conversions between decimal and hexadecimal.
Binary[edit]
The binary base is base 2 and goes in the following sequence: 0, 1, then 10 ((1 * 2) + 0
, two in decimal), 11 ((1 * 2) + 1
, three), then 100 ((1 * 2 * 2) + (0 * 2) + (0 * 1)
, four), 101 ((1 * 2 * 2) + (0 * 2) + (1 * 1)
, five), and so on. As you can see, it gets long and impractical very quickly.
Comparisons[edit]
Decimal | Hex | Binary |
---|---|---|
5 | 5 | 101 |
6 | 6 | 110 |
7 | 7 | 111 |
8 | 8 | 1000 |
9 | 9 | 1001 |
10 | A | 1010 |
11 | B | 1011 |
12 | C | 1100 |
13 | D | 1101 |
14 | E | 1110 |
15 | F | 1111 |
16 | 10 | 1 0000 |
17 | 11 | 1 0001 |
36 | 24 | 10 0100 |
94 | 5E | 101 1110 |
256 | 100 | 1 0000 0000 |
1000 | 3E8 | 11 1110 1000 |
4096 | 1000 | 1 0000 0000 0000 |
64206 | FACE | 1111 1010 1100 1110 |
Bits and bytes[edit]
Everything in game ROMs — be it programming, graphics, sound, text, assets, and anything else — is written in bits (zero or one), with each group of eight bits called a byte. Out of convenience, bytes are written using the hexadecimal base (any values using this will be noted with the prefix 0x
), rather than an inconvenient succession of eight bits using the binary system.
The value for each byte ranges from 0x00
(bits: 0000 0000
, decimal: 0
) to 0xFF
(bits: 1111 1111
, decimal: 255
).
Editing text with hex editors[edit]
Hexadecimal editors, also called hex editors or binary data editors, can open any file and display its contents as bytes written using the hexadecimal base. You can also edit said bytes.
Hex editors usually come with three elements: the part with the binary data, an address (also called offset) on the far-left which tells us the location of this byte in the file (and is useful), and..
The third area in the window is where 'text data' is supposed to appear. It tries to interpret the hex data as text by matching each byte value to a specific character in the ASCII set. So if there's the 0x41
byte for example, the matching character on the right side would be upper-case Latin A
.
For practice, go and check the US version of Link's Awakening (either the GB or GBC version). Open the ROM with any hex editor available online, and try modifying Marin's dialog at the very beginning. You'll have to search for a while, but you'll eventually find it.
However, the text data area is usually gibberish, nonsensical symbols. This is often because:
- The specific portion of the file/ROM you're viewing isn't actually text data but something else. So you'll have to use the search feature or browse further down the file.
- The text is encrypted. Sometimes, the developers do this on purpose to make the ROM unreadable by hex editors, as is the case for encrypted 3DS ROMs or games with anti-modding measures like God Eater 2 (PSP, JP) and Youkai Watch save files. Fortunately, this is impractical and mostly uncommon.
- The text is compressed. Compression is a data transformation operation intended to save space. There are numerous schemes, and some games have their own unique flavors. You'll need to figure out the actual compression pattern either by studying the file structure blindly or by reverse-engineering the game's programming during runtime as it uses the compressed file. Once accomplished, you can decompress the text so that it can be edited then recompress it and feed it back to the game.
But sometimes, none of the above may apply. Instead, a custom character encoding is used that doesn't conform to the ASCII standard. Why is this the case? Because many of these games were made in Japanese using Japanese characters, the developers had no reason to respect the ASCII standard but were more concerned about how to make the best out of the limited memory available. So you could have the letter A at 0x00
, x01
, 0x0A
, 0x10
, 0x21
, 0x41
, 0x81
, or elsewhere depending on the game and what the developers felt like.
This poses a problem. None of the mainstream hex editors really give a damn about this enough to account for cases other than the ASCII standard, so you'll have to find a specialized hex editor geared more towards ROM hacking. The feature you'll need here is the ability to load custom character sets, stored in what's called table files (extension .tbl, though they're actually just renamed regular .txt files).
A table file for a game using the ASCII standard would look like this:
For many games, you'll need to figure out their table files using table file building tools, also commonly referred to as 'relative search' tools. Choice ones are RSEARCH and Monkey-Moore. For example, The Legend of Zelda has 'IT'S DANGEROUS TO GO ALONE', so you load the ROM in Monkey-Moore and search for the word 'DANGEROUS'. It will give you many options (assuming the text is uncompressed, and the programmers at least had the decency to respect alphabetic order -otherwise you'll need to use the 'custom set' option, which you'll need in case your game is in Japanese). One of these options should guess the rest of the words of that sentence, with some unknown characters in between (like the spaces). Check that option and create your table with it.
Using WindHex, a hex editor with TBL support, open the ROM. Next, load the table file you just created with the relative search tool, and then the text will be visible and editable if you scroll to that area of the ROM. You can see the byte equivalents for the missing characters (spaces, punctuation) and then add them to the TBL file with Notepad (or WindHex's table editor). Similar programs include Crystal Tile 2, (supports Shift-JIS and UTF-8 encodings) and Tinke.
Make sure to identify the control codes as well. These are bytes used to define special text properties (text color, text display speed, displaying the hero's name, line breaks, end-of-text, etc.) and add them to the TBL file too. Sometimes, the game will use a dictionary to make the game's text shorter in order to save space, so some byte values will replace letter combinations or entire words. Add those to the TBL file too.
Don't be afraid to experiment, even if this corrupts your ROM, so that you confirm any of your observations! Of course, you'll need to keep a safe backup copy of the unaltered ROM along with the ROM revisions with your main hacking progress.
Text dumping and insertion tools[edit]
Editing or translating a whole game with a hex editor is tiresome. You can't even exceed the original length because the extra text would just overwrite the next not-text data and corrupt the game. The solution is to find the game's pointers. You can note down the address on the left side of the hex editor to know where you are in the ROM. The game does just like that, using pointers to tell it where the text is. But pointers don't look the same way the address in your hex editor does. Each system has its quirks and rule for calculating the pointers, so look it up.
For example, GBA pointers for a specific address are 4-byte. Replace the leftmost byte with 08
, and invert the order of the bytes so that (byte 1)(byte 2)(byte 3)(byte 4)
becomes (byte 4)(byte 3)(byte 2)(byte 1)
. Why invert? Because the GBA is a little endian system. Open a GBA Pokémon game, find Professor Oak's dialog in the hex editor, find its starting address (you click on the first letter and then see its address for that byte in the sidebar of your hex editor) and calculate the pointer as detailed above. Use WindHex's feature for searching hex data to find that pointer. It should appear in the hex data and look just like what you calculated. You may modify it to an address in the very end of the ROM in an empty area where you'll try writing new text. If you can pull this off, this means you can repoint that text pointer!
With the command-line tool Cartographer, you can indicate a ROM and TBL file, and then tell the program to start extracting text. You could tell it to extract bulk text and garbage data alike from and until given addresses (RAW mode). But if you found a pointer — or even better, a succession of pointers (called pointer tables), like in the Pokémon example above — you can extract text data in a more organized manner to a text file.
With another command-line tool called Atlas, you may re-insert that text file (after modifying it) in the ROM, and the tool will take care of updating the pointers. You can, for example, tell it to start inserting text in an empty yet accessible location at the end of the ROM. The possibilities are endless.
Command-line tools may sound scary, with their black MS-DOS dialog boxes flashing quickly and disappearing. They're actually easy to use. Just put all the needed files in the same folder, make a new .txt file where you write the command detailed in the tool's readme, and save that file as one with the .bat extension. If you double-click on it, it will execute that tool the way you wanted it with little effort.
Editing graphics with tile editors[edit]
Hex editors interpret binary data as raw bytes or text. Tile editors do something similar, but instead they interpret binary data as graphics. Of course, this means if you're using the wrong mode or looking at an area that's not supposed to be graphical data or the graphics are compressed, you'll just see garbage.
Among the best tile editors out there are TileMolester and Crystal Tile 2. For newer 3D-based systems, however, specialized graphical converters may be required.
In older systems, in order to save space, graphics were usually stored in parts. First, there's the tile data, or the actual drawings that you may edit with tile editors. They're divided into small pieces that, when assembled, make a big picture. The instructions to build the big picture are tile maps (in the case of backgrounds) or sprite attribute tables for sprites. Topcom usb lan 101 driver for mac download.
The tile data uses indexed colors. Using Mario's shirt as an example, it isn't colored 'red' but rather colored with 'color 1'. NES Mario games, like most NES games, happen to use the NES 2BPP mode (that is, two bits per pixel). A bit is either zero or one. With two bits, we can write 00
, 01
, 10
and 11
. This technically gives us four possible colors in total. However, there are actually three colors since 'color 0' is transparency, used around Mario's sprite so that the backgrounds behind him are visible and unobstructed.
How can we tell what actual color Mario's shirt is instead of just 'color 1'? We do this through palettes. Palettes are hex data consisting of several bytes (3 for the NES 2BPP mode), and each byte is the ID for a specific color: 'red', 'blue', 'yellow', 'purple', 'light blue', and so on. (There are just under 60 valid choices in the NES, but later systems have a much larger selection of colors.) We know Mario's clothes change color after eating various items, but the tile data drawings are stored just once in the ROM. There are separate palettes telling the game to colorize the same drawing differently for different situations.
For more convenient tile editing, tile editors offer a custom palette option so that you can fix the colors individually and have the graphics show correctly. Some emulators can export palette data from runtime memory for use with the tile editor (for example VBA-M and Crystaltile), and some tile editors can import save states from some emulators and use the palettes found inside (like Tilemolester).
Editing game programming[edit]
Game developers used to write directly in machine language which is, again, bytes. Technically you could memorize what each specific byte calls among the different programming instructions availabe in that hardware's processor, and write your code directly in the hex editor. But generally that would be madness.
Let's consider one example, from 6502 assembly used in the NES processor: the instruction which loads a special memory register (called the 'accumulator') with a value. We'll choose the value 0x00 here. If you encountered such an instruction in a NES program, it will be written as the two-byte sequence A9 00, where A9 is the opcode for this specific instruction, and 00 is the operand -- the value we chose for this instruction.
What game developers did was to write in plain text documents their game's code using keywords that are more or less readable for humans.
So, in the (often commented) code they're writing when developing the game, they'd write LDA #00 -- conveniently, LDA stands for 'LoaD Accumulator with memory', which is a far more helpful description of the instruction than its raw hex form. (The # means it's a value, otherwise if it's the byte at an address that's affected we'd use $)
Game developers start from text files with human-readable opcodes and comments, which they then pass through tools called 'assemblers' to get the binary form of the code.
The inverse is possible, and is called disassembling:
- In debugging emulators with breakpoint and disassembly support, you can cause the game to pause whenever some memory address is interacted with (read, write or execute). You can get the emulator to show you which programming instruction executed right now did said interaction, in binary form, then 'disassembled' and translated to some English-sounding instruction.
- Debugging emulators with trace features can disassemble all programming instructions executed between two instants if you so desire.
- CheatEngine and IDA Pro can disassemble some programs at runtime, including games and emulators.
- IDA Pro with some user-made plugins can also take a ROM file from the system covered in said plugin, and try to disassemble its binary to a text file. Some emulators offer the option to do this if you give them which address in the ROM (or RAM) you want to disassemble from.
However, disassembly can easily fail, and you end up with garbage nonsensical code in the text file. Why? Just like hex editors with text display, or tile editors, when disassemblers try to interpret stuff that's not programming as such, it's a recipe for disaster. Another extra problem is that after reading garbage data, even if the disassembler stumbles upon some legit programming bits after that, it will no longer tell where instructions begin and end (remember they're all just bytes) and so there will be even more erroneous interpretations.
That is, not to mention the numerous cases where the developers DON'T want you to look at their code: so it's either protected against disassembler tools during runtime (Denuvo on PC games), compressed then the game uncompresses just what it needs to the RAM and executes from there (Ys 5 for the Super Famicom), or most of the programming is written in another arbitrary programming language and the remaining 10% recognizable assembly code for that hardware is just the part which translates that arbitrary languages and not much else - this is also called bytecode and is used in many RPGs, with a quite infamously complicated variant being present in Earthbound (Mother 2) for example.
What you'll need to mod game programming, a.k.a. assembly hacking, is:
- a documentation of the hardware you're working on (including the various registers, hardware registers for stuff like the VRAM, the memory addressing..)
- an opcode list for that hardware, which includes all the instructions allowed on that hardware which you'll encounter (in the game's original code) and probably will use (in the code you'll write as a replacement)
- an assembler tool, to transform the text file with your innovating hack's code to binary format to be inserted later with a hex editor in the game proper. If you're especially good at regular computer programming, you could write one yourself for your personal use.
- a hex editor
- optionally, knowing how to use a cheat engine, since the RAM addresses it finds can lead to the instructions we need to find and eventually mod, in case those instructions affect those RAM addresses.
- any of the aforementioned disassembly solutions, as long as they can help you pinpoint which instructions in the original interest you and could be changed to achieve the effect you desire.
Having the new code being too long can be troublesome since you wouldn't want to overwrite irrelevant parts of the rom and thus corrupt it. The popular solution is to insert a JUMP instruction (as always, which instruction it depends on the hardware) pointing your code to some faraway empty place where you can comfortably put all the code you want -- of course, within the limitations of that specific system. You can see it's the same idea as text editing.
If you're more interested, check SMWCentral's boards for tutorials introducing you to SNES hacking with Super Mario World. Then if you feel more comfortable tackling harder stuff, you could learn PS1/PS2 assembly and translate/mod/fix some games.
By the way, more recent systems no longer have a big data blob with all data types mixed, but use neatly arranged file trees with recognizable (yet proprietary) file formats. This goes for programming too: all systems now have the executable in a separate file, and it's often the one loaded first. Some people even claim they had success running those through third-party disassemblers like IDA Pro. Some examples:
- PS1: SLUS_*** or some variation
- PSP: EBOOT.BIN, BOOT.BIN
- GC/Wii: .elf files
- DS: ARM9.BIN, more rarely ARM7.BIN
Looking at the game's programming as it runs can also help you figure out tons of stuff, from how the game does the decompression for that insanely obscure compression scheme it uses, to how it loads level data, manages enemy stats and damage, display stuff and story events onscreen, and so on.
Studying the game's programming, coupled with some corrupting (random hex editing of select memory areas) to confirm observations, has led to most of the game specific level editors and similar tools out there. So instead of lamenting why your favorite game doesn't have a dedicated tool, you can figure this out all on your own and create (in case you know some computer programming language) a good tool serving exactly your needs and which can be adjusted in whatever way you want.
Emulators for ROM hacking[edit]
Not all emulators are made equal. Often, you'll need to study the game as it runs, for the following reasons:
- Cheats: You modified some text and graphics in the final stage but can't be bothered to replay the whole game legitimately. In case the emulator doesn't support this natively, you might want to consider using Cheat Engine.
- Save states, rewinding, fast forward, frame advance, pause: You modified something appearing in a very narrow timeframe, or you just want to take clean screenshots of the game.
- Debuggers with the following features:
- Breakpoints: A breakpoint throws a fit and pauses the game if a specific address is tampered with. Of course, to know which address it is, you need to find it first with a cheat/RAM search.
- Conditional Breakpoints: Breakpoints that only trigger when another condition is also met. For example: Dragon Quest 1 keeps track of the monster ID (during battles) and the floor type (outside battles) in the same RAM variable. Which means every single step the hero makes will trigger the breakpoint, so if you're only interested in the monster ID code, you can weed out all other BPs by simply adding the condition 'only trigger when the battle status RAM variable is on'. Conditions can be about RAM or hardware register status.
- Disassembler: Translates the last few lines of programming executed from hex code to known opcodes telling which instruction is which (LDA/LDR/LD (load to accumulator/register), STA/STR/ST (store to accumulator/register), NOP (do nothing), and so on). After a breakpoint, it gives you the programming line (in assembly) directly responsible for altering the address the breakpoint was guarding against reading/writing/executing attempts. This is incredibly invaluable to understand the game's programming.
- Assembler: Allows the user to write their new lines of programming, which are then converted to the corresponding hex data. It's rare that emulators include this. Assemblers are often separate tools affecting the ROMs or to be inserted manually by users in ROMs.
- Tracers: The emulator logs all programming lines executed, from since you started logging, to a text file. It can get huge pretty quickly, so it's best used with breakpoints and frame advance features to better locate what you're looking for.
- Memory viewers with the following features:
- Hex editors: Views the RAM (and possibly other memory areas like SRAM, VRAM, ROM, and so on) as the game is being executed. Either the window is read-only, or it can be edited.
- Tile editors: Views the VRAM (and possibly other memory areas) and interprets its content as visual data. Emulators of 3D systems can also have model viewers and texture viewers.
- Background/OAM viewers/dumpers: View the graphics as they are arranged in-game, often used for dumping graphics by sprite rippers. This can be useful occasionally.
Emulators[edit]
Name | Operating System(s) | Version | Accuracy | Save states | Cheat support | Frame options | Breakpoint | Conditional Breakpoint | Disassembler | Assembler | Tracer | Memory view | Tile view | BG/OAM view | Useful? |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
FCEUX | Windows, Linux, macOS, Solaris, BSD | 2.2.3 | High | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓✓ |
- FCEUX is the golden standard for emulator debuggers, it's a fully featured one and very newbie friendly. So please check it out even if you're not interested in NES games as it's an excellent starting point for game modding. It's one of the few emulators, alongside PCSX2 and PPSSPP, to include conditional breakpoints.
Name | Operating System(s) | Version | Accuracy | Save states | Cheat support | Frame options | Breakpoint | Conditional Breakpoint | Disassembler | Assembler | Tracer | Memory view | Tile view | BG/OAM view | Useful? |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Snes9x | Multi-platform | Gieger's r1.51 | High | ✓ | ✓ | ✓ | Address | ✗ | ✓ | ✗ | ✓ | ✓ | ✗ | ✗ | ✓✓ |
BizHawk | Windows | Main | Cycle | ✓ | ✓ | ✓ | Range | ✗ | ✓ | ✗ | Read-only | ✓ | ✓ | ✗ | ✓ |
NO$SNS | Windows, DOS | 1.6 | Mid | ✗ | ✗ | ✗ | Address | ✗ | ✓ | ✗ | ✓ | ✓ | ✓ | ✓ | ✓ |
- Older bsnes versions, and many of its forks - notably BizHawk and Marmelade, have an extensive VRAM viewer, some versions having ones topping NO$SNS, as well as a memory viewer. byuu says he wants to make a proper debugger himself called Loki (citing this as the reason for putting on hiatus the FEOE:Zero translation) but don't hold your breath for it.
- Geiger's custom build of an older version of Snes9x also is very useful. While the base emulator only has a background layer disabling hotkeys, cheat codes and frame advance features, this build adds a debugger, a tracer (to a log file), as well as a memory viewer/editor with the option to dump to external files to open with hex editors. There's also the very useful 'What's Used' feature which colors areas in the memory viewer depending on what's onscreen (controllable with the BG layer hotkeys). However, it doesn't play nicely with nonstandard SNES cartridges. There's another custom Snes9x build by FuSoYa for Super FX2 games.
- As for NO$ emulators, right off the bat when you start it, they have a fully editable debugger (upper-left), RAM memory viewer (lower-left), hardware register (upper-right) and stack (lower-right). You can set breakpoints on addresses or programming lines (opcodes). You can view I/O status (for stuff like sound and DMA) with the F10 hotkey.
And most importantly, you can view the contents of the VRAM in real-time. It's particularly useful in the case of the SNES (though there's no Mode-7 mode), as there's detailed info about tilemap tiles (the other alternative was to get a ZSNES save state and then load it in an external viewer tool to get that info). It also has sprite information. It's not ideal but far more rom modding oriented than other tools which don't even display 16 tiles per line thus often scrambling the view.
NO$PSX and NO$GBA's special debugger build (regular build doesn't have the debugger) also show 3D textures, and in the case of NO$GBA the 3D models too.
However, the main flaw these have is the lack of decent frame advancing, save state, and cheat options. You'll need CheatEngine, and importing SRAM files from other files most probably. Also, the base emulation isn't without its flaws (for example, NO$SNS crashes with Quintet games because sound isn't emulated).
- DeSmuME has some older builds on gbatemp with interesting modder-friendly options:
- Custom build allowing searching for unused RAM areas. If you want to change the game's programming you'll need to find an empty place in memory to put your new code, so this is extremely useful.
- Custom build allowing to select a DEBUG option under Slot-1. The console window will show every single file loaded off the cartridge in real time, and it's also logged to a text file. If you're, say, looking for the title screen to change it, you can this way narrow down which files you need to look for.
General resources[edit]
- ROMHacking.net – This is like a hub where the various hacking communities meet. It hosts a large variety of major ROM hacks and translations. Also hosts numerous FAQs and tools to help aspiring hackers get started.
- Data Crystal – A wiki hosted by ROMHacking.net. While it is a bit outdated at this point, it's still a good resource for information about different editors and links to a handful of prominent hacks.
- FuSoYa's Niche – Site of the creator of the popular Super Mario World editor, Lunar Magic. Also hosts a set of tools for ROM expansion, patching, compression, etc.
- Zophar's Domain – A site that hosts lots of smaller patches, such as spoofs, as well as a significant amount of major ones. It hosts a lot of content that can't be found on ROMHacking.net
Programs[edit]
General purpose 2D graphics/tile editor[edit]
- Tile Molester – Works with Java, practically can edit any game.
Hex editors[edit]
Game-specific[edit]
EarthBound[edit]
- Starmen.net's PK Hack board – Home of the hacking utility CoilSnake, a tool that dumps data from the USA release of EarthBound into an editable format (mainly config files, plain text, and PNG spritesheets) and compiles everything back into the ROM.
Threads for completed hacks are listed, as is the original PK Hack tool, which was adequate for making hacks when it first came out, but is now infamous for corrupting ROMs when pushed too far.
Final Fantasy VI[edit]
- FF6Hacking – Home to a large community of Final Fantasy VI hackers, complete with active forums, patches, FAQs and guides for those looking to get into hacking the game.
- FF6Hacking Wiki – The most complete Final Fantasy VI hacking wiki with information on the SNES version but also on Final Fantasy VI Advance (GBA).
Final Fantasy Tactics[edit]
- Final Fantasy Hacktics – Community for FFT hacking with a variety of completed hacks, patches, and resources.
Fire Emblem[edit]
- Fire Emblem Shrine – An active and prominent Fire Emblem hacking community. Hosts a variety of completed hacks and FAQs to get you started.
- Serenes Forest – Another active and prominent Fire Emblem hacking community, though perhaps a bit more active than Fire Emblem Shrine.
The Legend of Zelda: A Link to the Past[edit]
- Zeldix - An active forums for A Link to the Past hacking, along with a database of MSU-1 hacks.
- Zelda Construction – Despite its huge popularity, the hacking community for ALttP is relatively small. This is mainly due to the lack of a truly good editor, though one is in the works. This community is a spin-off of Metroid Construction devoted to hacking of ALttP and other games in the series.
Pokémon[edit]
- The PokéCommunity – Very active (and helpful) Pokémon hacking community.
Sonic the Hedgehog[edit]
- Sonic Retro – The largest resource for hacks and modifications of the Sonic series (primarily focused on the Genesis games).
Super Mario World[edit]
- Super Mario World Central – The largest site dedicated to SMW hacking. Hosts hundreds of hacks and is a resource for SMW hacking utilities and knowledge. Also has a very active community and forums.
- X-Mario – Prominent Japanese site that hosts a variety of hacks. Worth noting is that Japanese hacks are usually more reliant on creating challenging gameplay and are less flashy or graphically modified than their Western cousins.
- Raocow's Talkhaus – The community for the most prominent let's player in SMW hacking. Whether or not you enjoy his commentary, this site remains a great resource for discovering hacks, as the community here is generally focused on hacks that the SMW Central community doesn't cover.
- VIP Wiki – Japanese wiki dedicated to the development of 2channel's series of popular hacks, the VIP & Wall Mix series. Hosts the 5 current installments and news about the sixth, currently a work in progress.
Super Mario World 2: Yoshi's Island[edit]
- Super Mario World Central – In addition to Super Mario World, smwcentral is a budding hub for Yoshi's Island hacking. While it only hosts a few complete hacks, the community is very active, and new content is being produced at a consistent pace.
- YI Hacking Wiki – A knowledge base for Yoshi's Island hacking.
Super Metroid[edit]
- Metroid Construction – The most prominent and active Super Metroid hacking community currently. Hosts a large variety of hacks, resources, FAQs, and an active community and forum. Originated in m2k2 before becoming its own dedicated site.
- Metroid Construction Wiki – As its name implies, a wiki created by the Metroid Construction community.
- Metroid 2002 – The former most prominent and active Super Metroid hacking community previously. While it has since been foregone in favor of Metroid Construction, it can still be a valuable resource for knowledge about the more advanced mechanics and inner workings of Super Metroid (as well as other games in the series).