ROM hacking

ROM hacking (short for Read-only memory hacking) is the process of modifying a ROM image or ROM file to alter the contents contained within, usually of a video game to alter the game's graphics, dialogue, levels, gameplay, and/or other elements. This is usually done by technically inclined video game fans to improve an old game of importance, as a creative outlet, or to essentially make new, unofficial games using the old game's engine.

Many ROM hacks typically redesign a game as a new, fun way of playing the original games while keeping most if not all of the items the same, while some hacks unlock and/or reimplement features that had existed in the game's code but are not utilized in-game.

ROM hacking is generally accomplished through use of a hex editor (a program for editing non-textual data) and various specialized tools such as tile editors, and game-specific tools which are generally used for editing levels, items, and the like, although more advanced tools such as assemblers and debuggers are occasionally used. Once ready, they are usually distributed on the Internet for others to play on an emulator or a games console.[1]

Fan translation (known as "translation hacking" within the ROM hacking community) is a type of ROM hacking; there are also anti-censorship hacks that exist to restore a game to its original state, which is often seen with older games that were imported, as publishers' content policies for video games (most notably, Nintendo's) were much stricter in the United States than Japan or Europe; as well as randomizers for certain games which shuffle entity placements.[2] Although much of the method applies to both types of hacking, this article focuses on "creative hacking" such as editing game levels.

Communities

Most hacking groups offer web space for hosting hacks and screenshots (sometimes only hosting hacks by the group's members and hosting almost any hack), a message board, and often have an IRC channel. Several hacking groups have also created guides that aims to help others get into grips with ROM hacking for the first time, such as the legendary "Rom Hacking Bible" for the NES written in the mid-to-late 1990s,[3] as well as for learning how to add or change things from start to finish.

One of the most popular sites devoted to the ROM hacking of games was ROMhacking.net, which first went online in late 2005. From its inception up until 2024, it served as a hub related to all things ROM hacking, hosting a repository of hacks, translations, utilities, documents, and patches for many well-known and obscure video games from the third generation up to the seventh generation. Its immediate predecessor was ROMhacking.com, a similar ROM hacking-oriented site that launched in 2000 and went offline in late 2004.[4]

ROMhacking.net has since transitioned over into being a read-only news site for ROM hacking projects after nearly 20 years of hosting on August 1, 2024 due to various reasons beyond the site's control, with its former database and files being archived on the Internet Archive. New submissions on the site were also permanently closed on the same day of the announcement, and all downloads will remain available on the site for as long as the site maintainers can handle.[5][6][7][8]

Methods

Having been created by many different programmers or programming teams, ROM data can be very diverse.

Hex editing

A hex editor is one of the most fundamental tools in any ROM hacker's repertoire. Hex editors are usually used for editing text, and for editing other data for which the structure is known (for example, item properties), and Assembly hacking.

Editing text is one of the most basic forms of hacking. Many games do not store their text in ASCII form, and because of this, some specialized hex editors have been developed, which can be told what byte values correspond to what letter(s) of the alphabet, to facilitate text editing; a file that defines these byte=letter relationships is called a "table" file. Other games use simple text compression techniques (such as byte pair encoding, also called dual tile encoding or DTE, in which certain combinations of two or more letters are encoded as one byte) which a suitably equipped hex editor can facilitate editing.

A hex editor is the tool of choice for editing things such as character/item properties if the structure and location of this data are known and there is no game-specific editor for the game that can edit this information. Some intrepid hackers also perform level editing with a hex editor, but this is extremely difficult (except on games whose level storage format closely resembles how it is presented in a hex editor).

Graphics editing

Another basic hacking skill is graphics hacking, which is changing the appearance of the game's environments, characters, fonts, or other such things. The format of graphics data varies from console to console, but most of the early ones (NES, Super NES, Game Boy, etc.) store graphics in tiles, which are 8x8-pixel units of data, which are arranged on-screen to produce the desired result. Editing these tiles is also possible with a hex editor, but is generally accomplished with a tile editor (such as Tile Layer or Tile Molester), which can graphically display the ROM data, as well as finding and editing tiles.

Graphics hacks can range from simple edits (such as giving Mario an afro or Luigi a golf club) to "porting" characters from one game to another (such as creating pixelated "retro-styled" sprites of later generation Pokémon for use in Generation I-V Pokémon games[9]), to full-blown thematic changes (usually with accompanying palette changes; see below).

More sophisticated graphics hacking involves changing more than just tiles and colors, but also on how the tiles are arranged, or tile groups generated, giving more flexibility and control over the final appearance. This is accomplished through hex editing or a specialized tool (either for a specific game or a specific system).

Examples of graphics hacks include the incomplete Pokémon Torzach, a hack of Pokémon FireRed which attempts to add a whole new generation of Pokémon and tiles to the game,[10] and Super Mario Land 2 DX: 6 Golden Coins, an enhanced version of the original game which added, among others, full-color support (the original game only supported greyscale) as well as some quality-of-life improvements, such as fixes with screen flickering issues from the original game.[11]

Palette editing

Another common form of hacking is palette hacking, where color values are modified to change the colors a player sees in the game (this often goes hand-in-hand with graphics hacking); Palette values are commonly stored in Hex. This is fairly easy for NES games, the graphics of which use a pre-defined set of colors among which a game selects (using a YIQ-based color palette); palette hacking in this case entails changing which of those colors are selected. The matter is slightly more complicated with Super NES games as well as games for other systems (which included Sega Mega Drive (Genesis) games), which store absolute RGB color values. Palette editors are usually simple and often are with level editors or game-specific graphics editors.

Level editing

One of the most popular forms of ROM hacking, level editing entails modifying or redesigning a game's levels or maps. This is almost exclusively done with an editor specially tailored for a particular game (called a level editor). Level edits can be done to make the game more challenging, to alter the flow of the game's plot, or just to give something new to an old game. Combined with extensive graphics hacking, the game can take on a very different look and feel.

Data editing

A core component of many hacks (especially of role-playing video games) is editing data such as character, item, and enemy properties. This is usually done either "by hand" (with a hex editor) if the location and structure of the data is known, or with a game-specific editor that has this functionality. Through this, a hacker can alter how weapons work, how strong enemies are or how they act, etc. This can be done to make the game easier or harder or to create new scenarios for the player to face.

Assembly hacking

The most powerful, and arguably the most difficult, hacking technique is editing the game's actual code, a process called ASM hacking ("ASM" means "assembly", referring to the low-level programming language that gets executed by the CPU).[1] There is no set pattern for ASM hacking, as the code varies widely from game to game, but most skilled ASM hackers either use an emulator equipped with a built-in debugger or tracer, or run the ROM through a disassembler, then analyze the code and modify it using a hex editor or assembler according to their needs. While quite challenging compared to the relatively simple methods listed above, anything is possible with ASM hacking, usually within the limits of the hardware and software of the gaming platform. This can range from altering enemy AI to changing how graphics are generated. If the developers used a typed language, the hacker may be able to compile their code for the game in the same language if they have access to a proper compiler. One such example would be using C to hack Nintendo 64 games, since MIPS-GCC can compile code for the Nintendo 64.[12][13]

Music hacking

Music hacks are relatively rare in most hacks, due to the wide variety of ways games store music data (hence the difficulty in locating and modifying this data) as well as the difficulties in composing new music (or porting music from another game). As music cracking is very uncommon, many hacks do not have any ported/composed music added in. Exceptions exist, however, such as the most recent Super Mario World hacks where custom music can have new instruments not found in the original game. Other games that have music hacking as part of their research and hacking communities are the NES Mega Man games, Final Fantasy VI, and the Mega Drive (Genesis) Sonic the Hedgehog games.

As many Game Boy Advance games use the M4A Engine (informally called "Sappy Driver" and officially known as "MusicPlayer2000" or MP2k) for music, the program SapTapper can be used to hack Game Boy Advance music data. Various other utilities were created to work with the engine such as Sappy 2006. Another instance of the same engine being used between games is on the Nintendo 64 where most games use the same format; albeit with different sound banks for each game. A utility known as the N64 Midi Tool was created to edit the sequences that the majority of Nintendo 64 games use, however it does not cover first-party N64 titles that use a slightly different engine such as Super Mario 64.

On the Sega Mega Drive (Genesis), several games made for the system[14] had its music and sound effects created under a single sound engine commonly known as "SMPS" (also known as "Sound-Source" by some developers), which has been offered in both 68000 and Z80-based versions.[15] This engine was predominantly used in a wide variety of Japanese-developed games for the system (including Sega's first-party games),[15] with some games providing modified versions of the sound engine tailored for a specific game. The sound engine has been researched for decades by many hackers,[16] which led to the creation of various tools[17] that can alter and create music (and sound effects) for games using the SMPS engine (most notably the Sonic the Hedgehog games in particular); many of the compositions and arrangements made under the SMPS engine had eventually made their way into the Steam Workshop.[18]

ROM expansion

Generally speaking, a ROM hacker cannot normally add content to a game, but merely change existing content. This limit can be overcome through ROM expansion, whereby the total size of the ROM image is increased, making room for more content and, in turn, a larger game. The difficulty in doing this varies depending on the system for which the game was made. For example, expanding an NES ROM may be difficult or even impossible due to the mapper used by the game. For example, if a mapper allows 16 ROM banks and all of them are used, expanding the ROM further is impossible without somehow converting the game to another mapper, which could be easy or extremely difficult. On the other hand, expanding an SNES game (and even a Mega Drive (Genesis) game for that matter) is (relatively) straightforward. To utilize the added space, parts of the game code have to be modified or rewritten (see Assembly hacking above) so the game knows where to look. Another type of ROM expansion that is fairly easy is Game Boy Advance ROMs. The ROMs themselves are generally small, but the memory space available sometimes exceeds it by multiples of up to 17.

Distribution

Once a hack is completed (or an incomplete version is deemed suitable for an interim release) it is released onto the Internet for others to play. The generally accepted way to do this is by making an unofficial patch (in IPS format or others) that can be applied to the unmodified ROM.[1] This, and usually some form of documentation, is put in an archive file and uploaded somewhere. IPS is a format for recording the differences between two binary files (in this case, between the unmodified and hacked ROMs) and is suitable for ROM hacks.[19] IPS is still used today for small patches—however, as ROMs became larger, this format became useless, leading to quite a few file formats being created—such as NINJA and PPF (also known as "PlayStation Patch Format"). PPF is still used today, particularly to patch large files such as ISO CD-ROM images as well as Nintendo 64 games. A new patch format, UPS, has also been developed by the ROM hacking community, designed to be the successor to IPS and PPF.[20] A more recent patching format, the APS patching system, has also been developed by a devoted Game Boy Advance ROM hacker.[21] Compared to other patching formats, the APS system is more space efficient, is reversible, and is faster than its predecessor.[22]

The main purpose of distributing a hack in patch form is to avoid the legal aspects of distributing entire ROM images; the patch records only what has changed in the ROM, hence distributing it does not usually distribute parts of the original game. In this context, patches usually contained user-made code changes to the game and not the original game’s copyrighted code, which would have eliminated any copyright issues that may occur with distributing unofficial patches for games.[citation needed] A patch is also normally drastically smaller than the full ROM image (an NES ROM can run anywhere from 8 KB to 2 MB; a Super NES ROM can run from 256 KB to 6 MB; and Mega Drive (Genesis) ROMs can run from 512 KB to 4 MB).

In a novel example of legal distribution, Sega released a Steam-based virtual hub for its previous collection of Mega Drive (Genesis) games, entitled Sega Mega Drive Classics Hub. The Hub, besides allowing players to play emulated versions of these older games, takes advantage of Steam's support for user-created content through the Steam Workshop, officially allowing the distribution of ROM hacks of any of the offered games.[23]

Usage

Patched ROMs are often played on emulators, however, it is possible to play patched ROMs on the original hardware.[24] The destination cartridge could be the original cartridge from which the initial unpatched ROM was pulled (which usually involves replacing the original ROM chip with a new one), or another compatible cartridge of the same type, such as flash cartridges. This is particularly popular for fan translations, homebrew games, prototypes, games for which ROM cartridges were never produced, or for games that require exact timing or other elements of the original hardware that are not available in emulators.

Systems and games

The majority of ROM hacking is done on NES and SNES games (including Sega Mega Drive (Genesis) games to an extent), since such games are small and simple compared to games of more advanced consoles such as the Nintendo 64 or Nintendo DS. Games for the Game Boy, Game Boy Color and Game Boy Advance are also popular for hacking, as well as games for the PlayStation to a lesser extent. However, games intended for more recent consoles are not exempt from hacking, and as computers have become faster over time and more programs and utilities have been written, more PlayStation, Nintendo 64 and Nintendo DS hacks have emerged.

Of these, popular games to play are popular games to hack; many hacks have been released of games of the Sonic the Hedgehog series, Mario series (including Mario Bros., Super Mario Bros., Super Mario Bros. 2, Super Mario Bros. 3, Super Mario Land, Super Mario Land 2: 6 Golden Coins, Super Mario 64 and Super Mario World), Mario Kart series (including Super Mario Kart, Mario Kart Wii, Mario Kart 7, and Mario Kart DS), Pokémon series, Chip's Challenge, Castlevania, Final Fantasy, The Legend of Zelda, Mega Man series, Fire Emblem series, EarthBound, Super Metroid, and many others.

A notable hacked arcade game was Street Fighter II: Rainbow Edition, which featured increased game speed and new special moves. The success of this game prompted Capcom to release Street Fighter II: Hyper Fighting as an official response.

Your Sinclair magazine published a monthly column called "Program Pitstop". This focused mainly on cheat hacks for games, but also featured both a level map printer[25] for the original Gauntlet, as well as a full level editor[26] for the same game.

See also

References

  1. ^ a b c "Dictionary of ROM hacking terms". ROMhacking.net.
  2. ^ "The BIG List of Video Game Randomizers". Guillaume Fortin-Debigaré. Retrieved 2020-07-10.
  3. ^ "NES - Rom Hacking Bible - NES - By SeRiAlKLR - GameFAQs". gamefaqs.gamespot.com. Retrieved 2024-08-05.
  4. ^ "The Legacy - ROMhacking.com/ROMhacking.org". ROMhacking.net. Retrieved 27 August 2024.
  5. ^ Joshua Wolens (2 August 2024). "Founder takes down the Nexus Mods of romhacking after 20 years because 'lines were crossed' by 'a most dishonest and hate filled group,' but others tell a different story". PC Gamer. Retrieved 2 August 2024.
  6. ^ Catherine Lewis (2 August 2024). "20-year-old romhack site that was a treasure trove of Pokemon fan games and JRPG translations winds down after achieving "almost everything it set out to do"". gamesradar. Retrieved 2 August 2024.
  7. ^ McWhertor, Michael (2 August 2024). "The best ROM hack website is shutting down after nearly 20 years". Polygon. Retrieved 2 August 2024.
  8. ^ "Site: ROMhacking.net Moves to News Only, Database and File Archive Released to Internet Archive". ROMhacking.net. Retrieved 27 August 2024.
  9. ^ "Pokemon Rom Hacks List: GBC, GBC & NDS - PokemonCoders". PokemonCoders. 2019-04-13. Retrieved 2023-03-08.
  10. ^ "Pokemon FireRed ROM Hacks". PokemonCoders.com. 11 March 2019.
  11. ^ Machkovech, Sam (25 December 2017). "A Christmas gift from Game Boy ROM hackers: Super Mario Land 2 in color". Ars Technica. Retrieved 18 February 2023.
  12. ^ "vg64tools - Project Hosting on Google Code". Retrieved 2009-09-09.
  13. ^ "Super Mario 64: Pong Of Death (messiaen)". Archived from the original on 2011-10-10. Retrieved 2009-09-09.
  14. ^ "Mega Drive/Genesis Sound Driver List". Video Game Music Preservation Foundation.
  15. ^ a b "SMPS". Sega Retro.
  16. ^ "Valley Bell's SMPS Research". Sonic and Sega Retro Message Board. December 31, 2013.
  17. ^ "Sonic Hacking Utilities". Sonic Retro.
  18. ^ "Steam Workshop :: SEGA Mega Drive & Genesis Classics". steamcommunity.com.
  19. ^ "Pokemon Rom Hacks". InverseGamer.com. 20 September 2020. Retrieved 31 March 2021.
  20. ^ "New patching format, UPS, debuts today". www.romhacking.net. 27 September 2023.
  21. ^ "The PokéCommunity Forums - View Profile: HackMew". www.pokecommunity.com. 27 June 2006.
  22. ^ "Newest patching format, APS, recently released". www.pokecommunity.com. 20 May 2007.
  23. ^ Yin-Poole, Wesley (April 29, 2016). "Modders are already having fun with Sega Mega Drive classics on Steam". Eurogamer. Retrieved May 3, 2016.
  24. ^ "Basic NES Reproduction".
  25. ^ "World of Spectrum - Forced Redirect". www.worldofspectrum.org.
  26. ^ "World of Spectrum - Forced Redirect". www.worldofspectrum.org.