Anonymous user
SRAM glitch: Difference between revisions
→Save corruption: Changed the description for the frame window. Still need some research on the time window between the visual cues.
>Sherkel (Cleanup, also see comment) |
(→Save corruption: Changed the description for the frame window. Still need some research on the time window between the visual cues.) |
||
(6 intermediate revisions by 3 users not shown) | |||
Line 1:
{{Major glitches}}
{{PRAMA|save-abuse-glitch}}
The '''SRAM glitch''', also known as the '''
== Procedure ==
=== Clearing the save file ===
This glitch can be executed at any point in the game, but is most often done at the very start of a new game to access an expanded party. For this purpose, the player needs to clear any existing save files:
# Press Up+Select+B on the title screen (not the title menu; it is the screen with the "Pokémon" logo and version name, and can be reached from the title menu by pressing B).
# Choose "Yes" to the "Clear all saved data?" prompt.
Even if the player does not have an existing save file (e.g. on a fresh cart), it is still recommended to clear the save file anyway. Clearing the save file will set the SRAM to all 0xFF bytes, which guarantees that this glitch will give the player an expanded party. On the other hand, the contents of uninitialized SRAM is unpredictable: There is a good chance it will be 0xFF anyway, but it can also be something else. In particular, some emulators initialize the SRAM to 0x00, which means even if this glitch succeeded, it will '''not''' give the player an expanded party.
The cue is to power off or reset after the "Yes/No" dialog box has disappeared, but before the text changes to "Saving..."▼
=== Save corruption ===
Holding START+SELECT+A+B will not work, as the game prevents soft resets while it is saving.▼
The following steps can be done at any point in the game.
# Open the start menu, and select "Save".
# Select "Yes" in the "Yes/No" dialog box, but at a very precise moment, power off or reset the console.
▲
▲#* The
#** The time window between those two visual cues is around 20 frames (depending somewhat on the version and the circumstances), but the window to successfully perform this glitch is only 4 frames.
#* Note that on the Game Boy Player the [[reset fadeout delay]] applies, so the player needs to press the reset button earlier accordingly, before the player selects "Yes" by pressing A, and possibly even before the "Yes/No" dialog box appears (this is often the case when speedrunning).
If the glitch was successful, a Continue option will be present when the game is started again,
There are two ways the glitch can fail:
* If the Continue option does appear, the player may find their party data unchanged (if the player never received the starter in this game, then the Pokémon screen cannot be accessed), which indicates that either the reset happened too late, or the player didn't set up the SRAM data properly (see [[#Clearing the save file|Clearing the save file]] above).
==Variants==
===255 Pokémon glitch===
{{Main|255 Pokémon glitch}}
By performing the SRAM glitch while the player has no save file, the party data will become whatever is in the SRAM, and is likely to be all 0xFF bytes (in particular, clearing the save file will set the SRAM to all 0xFF). As a result, the player will have 255 Pokémon in the party. When the player opens the party screen, it will appear to show nothing in the party, but the player will be able to scroll the cursor to any of the 255 slots and switch Pokémon around.
▲If the glitch was successful, a Continue option will be present when the game is started again, and the player will be able to access their Pokémon screen. In the case of the 255 Pokémon glitch, the screen will appear to show nothing in the party.
▲There are two ways the glitch can fail: either when rebooting the game the message "The file data is destroyed!" will appear, which indicates the reset happened too early and will remove the Continue option, or a Continue option will appear but the Pokémon screen cannot be accessed, indicating that the reset happened too late.
<!-- Should these be listed on the 255 Pokemon glitch page instead? -->
The [[expanded party]] can be exploited in many ways. For example:
*Warp to the Safari Zone: Swapping the 3rd Pokémon with the 36th can warp the player to the Safari Zone gate. (discovered by VaeporSage)
*Walk through walls: Swapping Pokémon 62 with 63 allows the player to walk through walls. (discovered by hibiki ganaha)
*[[Expanded item pack]]: Swap Pokémon 9 with Pokémon 10, and then with Pokémon 11. If you want to undo the effects of the [[255 Pokémon glitch]], stand on the right tile of the house's exit mat, and swap Pokémon 187 with Pokémon 178, wait a while{{clarify}}, and press A.
===Send party Pokémon to a new game===
{{Main|Send party Pokémon to a new game}}
If the player starts a new game while a save file already exists, and successfully performs the SRAM glitch, then the party Pokémon from the old save file will appear in the new game.
If the glitch fails due to the reset happening too early, then the game will say "The file data is destroyed!", but the saved party Pokémon data is in fact not overwritten. Therefore, if the player starts a new game in this state and try again, they may still be able to retrieve those party Pokémon. (Of course, if the reset happens too late and the save was successful, then the party would be overwritten and unable to be retrieved.)
=== Pokémon cloning ===
{{Main|Pokémon cloning (Generation I)#Save menu method}}
The SRAM glitch can also be performed while a save file from the same playthrough exists, overwriting the player's current party with the party from the old save file. In particular, if the player saves the game, deposits a Pokémon into the Pokémon Storage System, then performs the SRAM glitch successfully, then that Pokémon will exist in both the box and the party, essentially cloned.
==Explanation==
When saving the game in Generation I, the game calls three functions, each only saving a part of it, and the parts are in fact overlapping:
* The first function<ref>[https://github.com/pret/pokered/blob/1dcaede8b5e41dbec9bf3f2b18c77d1b7d2de708/engine/menus/save.asm#L201 The first function for saving the game]</ref> saves everything, ''except the party data''.
* The second function<ref>[https://github.com/pret/pokered/blob/1dcaede8b5e41dbec9bf3f2b18c77d1b7d2de708/engine/menus/save.asm#L234 The second function for saving the game]</ref> only saves the current box data.
* The third function<ref>[https://github.com/pret/pokered/blob/1dcaede8b5e41dbec9bf3f2b18c77d1b7d2de708/engine/menus/save.asm#L254 The third function for saving the game]</ref> saves the party data, the Pokédex data, and (in Yellow) Pikachu's happiness and mood.
Besides being used for a full save, the third function is also used after trading a Pokémon in the Cable Club. Presumably at least one of the first two functions is also intended to be used somewhere else, but they don't seem to be in the final game.
The importance of having three functions is that all three functions will compute a checksum from the full save data on the SRAM, and write it to the SRAM. When performing a full save, the first function would result in an inconsistent save file, and checksum it. At this point, if the player resets the game, the save file would be considered valid by the game since the checksum is correct.
Furthermore, the second function would then save the current box data to the SRAM, which takes a significant number of frames, but actually does nothing because the current box data is already saved by the first function. Therefore, during this period, the checksum on the SRAM will remain valid, resulting in a relatively large time window for the hard reset.
==References==
<references />
[[Category:Generation I glitches]]
|