The Cascade Glitch - Gateway to Gen IV ACE
Posted by: Cryo
Date: 2017-02-16 15:41:29
The fact that the L-shaped tweaking pattern causes really weird effects has been known for a while now and was previously known as the "????? Glitch", but after analyzing the effects of the tweak, I decided to give it a more descriptive name that mirrors its effectsthe "Cascade Glitch".
[size=12pt]TRIGGERING THE CASCADE GLITCH[/size]
In order to trigger the glitch, all you need to do is tweak using any L-shaped pattern in the fastest gear of your bike.
No really, that's it.
THE EFFECTS
The reason it's called the Cascade Glitch is because of the one constant that always occurs each time this glitch is triggeredstarting from the map data ID (0 - 665) that you refreshed the screen in, the map tile data, 3D model data, building data, et al. for each successive map data ID is written to RAM immediately after the tweak. The chaotic nature of such an effect means that freezes will occur a lot of the time.
However, because the data written to RAM depends on the map data ID that you refreshed the screen in, you're able to influence the data that gets written and, to a loose extent, where that data gets written. This means that altering progression flags is completely possible using this method.
EXAMPLE
[img]http://i.imgur.com/DR9jKCU.gif[/img]
So what exactly happened here?
As a little background information, the tile data for each map should be at least somewhat legible, such as the map tile data for lower Jubilife City below.
1111111111111111111111111111111111111111111111111100006900000000
1111111111111111111111111111111111111111111111111100000000000000
1111111111111111111111111111111111111111111111111100000000000000
1111111111111111111111111111111111111111111111111100000000000000
1111111111110000000000111111111111111111111111111100000000000000
1100000000000000000000111111111111110000000000001100000000000000
1100000000000000000000111111111111110000000000001100000000000000
1100000000000000000000001111111111000000000000001100000000000000
00001111111100006E0000111111111111110000690000000000000000000000
1111111111111111111111111111111111111111111111111100000000000000
1111111111111111111111111111111111111111111111111100000000000000
1111111111111111111111111111111111111111111111111100000000000000
1111111111111111111111111111111111111111111111111100000000000000
1111111111111111111111111111111111111111111111111100000000000000
0000000011111111111111111111111111111111111111111100000000000000
0000000011000000000011111111111111111111111111111100000000000000
0000000011000000000011111111111111111111111111111100000000000000
0000000000000000000011111111111111111111111111111100000000000000
0000000000000000000011111111111111111111111111111100000000000000
0000000000000000000011111111111111111111110000000000000000000000
0000000000000069000011111111111111111111110000000000000000000000
0000000011111111111111001111111111001111110000000000000000110000
0000000011111111111111111111111111111111110000000000000000110000
0000000011111111111111111111111111111111110000000000000000110000
0000000011111111111111111111111111111111110000000000000000110000
0000000011111111111111111111111111111111110000000000000000110000
0000000000000000000000111111111111110000000000000000000000000000
0000000000000000000000111111111111110000000000000000000000000000
0000000000000000110000111111111111110000000000000000000000000000
0000000000000000110000000011111100000000000000000000000000000000
0000000000000000111111111111111111110000000000000000000000000000
0000000000000000111111111111111111110000000000000000000000000000
Okay, so that's not the actual map tile data for lower Jubilife City, but it gets the point across that it should at least be somewhat legible and able to be discerned just from looking at the layout.
First, to pull off this tweak, you'll want to refresh your screen anywhere in the area below. You can do this by opening the Bag or performing any action that forces the graphics to be redrawn.
[img]http://i.imgur.com/ujgfXAE.png[/img]
Next, perform the tweak as shown in the previous GIF. If you need help locating the loadlines in order to do this, you can find them here.
After performing the tweak, the map tile data for Route 202 will be replaced with the data below.
a0006c004094fd22220040009400e099d0222200e000990000e7ab2222000000
e700a0006c7e00222200a0006c004094fd22220040009400e099d0222200e000
990000e7ab2222000000e700a0006c7e00222200a0006c004094fd2222004000
9400e099d0222200e000990000e7ab2222000000e700a06c7e222200a0006c00
4094fd22220040009400e099d0222200e000990000e7ab2222000000e700a000
6c7e00222200a0006c004094fd22220040009400e099d0222200e000990000e7
ab2241000000e700004021030000007c07348022220000000000407707242630
800040000000802122ad062e800080800041220300c000009724250040400000
40c040212200470000404000802224c080006500e04080254000000300c00021
2200474000400000402224c04000970800404025210080c08000360820224140
8000000300222400000097084000002521004000400047080022220040008000
800065242508e000800000000040210300000000974000222200000040004000
47242528004040008000802122006528e0808080004122030000007c07242634
4000000000c0402122770730000040000022248080ad062ee000802640800003
00000021227c0734800000000022240040770730804040262100000080ad062e
80224180808080030022240000004734c0000025210040c04000973000222200
4000808080003624252e20008000000000402103000000004740002222000000
4000400097242528000040008000802122003628200080000041220100008014
0226258000000000400000262500000080800040802122004200804000400022
22c0000040c08000802226408000c20080400027254000c0000040c080272100
8000800042008022220000400000000040222200800080808080002222b0002c
c00000004022220080008000801402262580000000004060002624000080802e
e080802222b0002c4000000000222200808000008000c2262700800000400060
002524004080802e200080252700000000400000002527004000800080000040
210100280000f04040222228f8004038f8000022223800c00028000000242540
00380000403808252500402808000018c02122ad06c00000c000402222008000
001880c000222500000000000018002526004018800000008025210000280000
f040002222380000003808000022222808004018c0000724264b011810c00000
102526000000c00000280021220000004028f8c000222238f800003800004022
26280000f0000028f82525004038f8000038002521c0002800000040c0222238
0000403808004022222808000018c0ad062525c00000c0004000802625000018
80c000000021220000000018000040222218800000008000002227280000f040
Definitely not what it should be.
If you were to load the graphics for this area, it would look a little something like this:
(just a rough sketch; the actual visual data would probably look a lot cooler)
[img]http://i.imgur.com/sWrfUXz.png[/img]
ADDITIONAL INFO
The section containing pointers to the currently-loaded map data (as well as the data that will be imminently loaded) can be found at [tt]Base + 0x8BAD0[/tt]. This section has enough space for 3 areas, which is all that should ever need to be reserved within normal gameplay, since it's not possible to load 4 different areas in such quick succession. I'm guessing that's what the devs though, anyway.
I've created a visual representation of the pointer storage location as well as the pointers to the current map data for additional detail, found below.
[img]http://i.imgur.com/R7cXQUM.png[/img]
The 4 pointers are arranged in the following order:
[li]Top-Left[/li]
[li]Top-Right[/li]
[li]Bottom-Left[/li]
[li]Bottom-Right[/li]
In this case, the 3rd pointer is the address of the garbled data. This means that the area we're currently in (Route 202) should be located in the bottom-left of the 4 currently loaded areas, which it is.
[img]http://i.imgur.com/GM0JlYY.png[/img]
MISCELLANEOUS
Doing this in Valor Lakefront yields some pretty amazing results. Instead of simply writing the data for each successive map data ID, it completely annihilates your base pointers. The base pointers located at [tt]0x02101D20[/tt] just get overwritten with zeroes.
The result?
[img]http://i.imgur.com/eF8CwlB.png[/img]
Since there aren't any base pointers, the game just kind of gives up and crashes. It also messed up my ASLR calculations in the VET script and caused all of my values to return 0.
If that kind of thing is possible just by tweaking, then I think that this may very well be our best chance at ACE in Gen IV.
POSTSCRIPT
I should be receiving an IS-NITRO-DEBUGGER development kit through the mail within the next few days, and I highly plan to analyze this glitch further on actual hardware. It's hard to tell whether some of these results are due to emulation errors or whether these would actually happen on a console.