Make your own patch for VitaGrafix
WARNING I use Linux as my main OS, I do not know if any of this will work on Windows or MacOS! WARNING
Table of contents
- What is VitaGrafix?
- Requirements
- How do I begin?
- Obtaining the ELF file with FAGDec
- Setting up Ghidra
- Patching VitaLoaderRedux
- Making a new project in Ghidra
- Importing the ELF file into Ghidra
- Finding the codes that lock FPS
- Testing the game
What is VitaGrafix?
Copied from their github repo
VitaGrafix is a taiHEN plugin that allows you to change resolution and FPS cap of PS Vita games (to get better visuals, higher FPS or longer battery life).
Requirements
- A hacked PSVita
- FAGDec
- VitaShell
- Ghidra
- VitaLoaderRedux
- VitaSDK Documentation
- Paru AUR Helper
- Patience, a lot of it
How do I begin?
A question I often ask myself when I start something new, how do I begin? You don’t have to be a programmer or hacker to make your own patches, really. All you need is a hacked PSVita, patience and the ability to read and understand the VitaSDK documentation and maybe some good drink.
I expect you to have a hacked PSVita and have a basic knowledge of VitaShell and installing apps.
Let me help you get started!
Obtaining the ELF file with FAGDec
Download FAGDec and install it via VitaShell.
This is what you will see when you first open FAGDec
data:image/s3,"s3://crabby-images/efc26/efc26005008903a5da6d0b8cb406b226d3ac3aa4" alt=""
Select the game you want to work on and press X.
data:image/s3,"s3://crabby-images/a72a8/a72a8bd716e40c627b03842228902b424938e4fc" alt=""
If there is a patch installed, get the patch eboot.bin instead. There’s a big chance that the code we gotta patch is in there. Select it with X and it should appear on the right side of the screen like so
data:image/s3,"s3://crabby-images/25ed7/25ed7a1e28740e6dcdc826c3f70d4fb710f7c30e" alt=""
Now press the O button to go back and you will see this
data:image/s3,"s3://crabby-images/ea13d/ea13d0ad2663eba97cdd99159585dd5ff40fd7a9" alt=""
Now we click on the START button on the PSVita and will see this.
Click on START DECRYPT(ELF)
data:image/s3,"s3://crabby-images/b4df4/b4df44d369b6426b97e00cfadabb74203196ab08" alt=""
This is the screen during decryption
data:image/s3,"s3://crabby-images/4ba0c/4ba0c15905f43a20f5ba34f387573a1b15fb7c58" alt=""
When the decryption is done, you will see this
data:image/s3,"s3://crabby-images/ce4a9/ce4a98ec7c09bc6cb4f197283ce8cc4678e8daf5" alt=""
The file is now decrypted and stored on the PSVita at: “ux0:FAGDec/patch/PCSA00147/eboot.bin.elf”
To Copy the elf file from your PSVita to your pc, start VitaShell again and connect your vita to your computer (or you can use FTP, either way works).
Copy the file to your local pc so we can import it in Ghidra later.
data:image/s3,"s3://crabby-images/ef80b/ef80bc4f259ce053edd59febd67ff1b033243151" alt=""
My folder has a few more files in it, because of it being an older project I worked on before.
data:image/s3,"s3://crabby-images/34223/342233e96d4cb0bab42d10b4907d09093fd74613" alt=""
Installing Ghidra
o begin, we are going to install Ghidra and the required extension.
Open a terminal and execute the following:
paru ghidra
And select extra/ghidra
data:image/s3,"s3://crabby-images/0f9ae/0f9ae6748e5f56ffc4c635d7ee621d08c0143a92" alt=""
Setting up Ghidra
Download the VitaLoaderRedux plugin, you do not have to extract it.
Start Ghidra.
You will then see this screen.
data:image/s3,"s3://crabby-images/167c0/167c0e7eba6339ae346e8c8bb2b8788df5ef42e2" alt=""
Click on File -> Install Extensions…
data:image/s3,"s3://crabby-images/9825b/9825ba09bdcc588554b9096083abfcb3d6023a1d" alt=""
Click on the green plus sign on the top right of the new Install Extensions window and browse to the VitaLoaderRedux zip you just downloaded and select it.
Close Ghidra.
Patching VitaLoaderRedux
This is something that is not explained well and is a needed step if you want to follow. Open a file browser and go to your install of Ghidra, for example: “/home/yuki/.ghidra/.ghidra_10.3.2_DEV” Then go to “Extensions/VitaLoaderRedux/data/databases/”
data:image/s3,"s3://crabby-images/e7554/e755429eba6d5fa80e50a6c5f70c5ec175ccfafa" alt=""
Overwrite this file with this file: DefaultNIDDatabase.yamlThis file has a lot more
Restart Ghidra.
Making a new project in Ghidra
Click on File -> New Project…
data:image/s3,"s3://crabby-images/167c0/167c0e7eba6339ae346e8c8bb2b8788df5ef42e2" alt=""
Select Non-Shared Project and click on Next.
data:image/s3,"s3://crabby-images/2f759/2f759a85efb608b04cb58b4657be1b05572aa6c1" alt=""
Make a new directory that will contain the current project files and give it a name.
Click on Finish.
data:image/s3,"s3://crabby-images/1325e/1325e0b540ea2efdc4ec1e3979cdd92fe9b051e3" alt=""
You will now be presented with this:
data:image/s3,"s3://crabby-images/c6600/c6600c6c42e890b187beaaa32bc8853cba51fb3d" alt=""
Click on the green dragon to start the actual program.
This is what you will be presented with next:
data:image/s3,"s3://crabby-images/9a27e/9a27eec26ac847b95f50d4ed10681a9fc5c08b34" alt=""
Importing the ELF file into Ghidra
Now we are going to import the elf file we obtained via FAGDec.
Click on File -> Import File…
Navigate to the folder you saved it to and import it
data:image/s3,"s3://crabby-images/b5d9a/b5d9a4b739d834ff410b730599ecc4b7d3aee7d0" alt=""
Make sure the Format is set to: ARM ELF-PRX for PlayStation®Vita
data:image/s3,"s3://crabby-images/c5fb4/c5fb49ce880a3b1645f2c37a6b6ecfff116970d7" alt=""
Click on OK
data:image/s3,"s3://crabby-images/4aaa6/4aaa613dd9a2194c4e1f9117e84b93c916fd6321" alt=""
Click on Yes
data:image/s3,"s3://crabby-images/c5997/c5997baac810b396e9118c0f359cad110bc02aea" alt=""
Keep defaults and click on Analyze
data:image/s3,"s3://crabby-images/4c001/4c00115894dca4c55f47a3af01edd985112b4c94" alt=""
Click on OK
data:image/s3,"s3://crabby-images/452a1/452a1f3d3a0143dd50c4db8b72416703e41efa4f" alt=""
You will see this in the bottom right
data:image/s3,"s3://crabby-images/c1962/c19625c1fe9a9c116c817590714c6f764bcc7c26" alt=""
Wait until this is completed before moving on. This can take a bit depending on your computer.
After taking a little break from the computer, it is done
data:image/s3,"s3://crabby-images/eff78/eff78616d0ad7e231107f9d32861031f5d3ebcf4" alt=""
Finding the codes that lock FPS
First things first, click on the Display Memory Map button
data:image/s3,"s3://crabby-images/2253a/2253aff57d19c40e1ba238817f11bc9e37ce3785" alt=""
Here you will see that the first result starts at 81000000 and ends at 8266295b.
the second segment starts at 82663000 and ends at 82c97187.
Remember that these numers are
Write these numbers down somewhere, since we will need this later on.
data:image/s3,"s3://crabby-images/90a45/90a45df19d1961eb74e8c168ce90c49626cd4f25" alt=""
Now that everything is finally set up and ready to go, we can look for what actually locks a game to 30 FPS. Most of the time, it’s not as simple as finding a line that says: FPS=30. You usually want to find something that implements a Vsync. Let’s take a look at the VitaSDK documentation.
We can see that this function is responsible for vlank (vsync, locking to a certain screen refresh rate)
data:image/s3,"s3://crabby-images/aa0f4/aa0f4512af3eddf31185b8435b9c89285e8aaeaa" alt=""
Let’s check if that function exists
data:image/s3,"s3://crabby-images/2ff8c/2ff8c874dc842db56389938ae8c9d10f0b7a6e1c" alt=""
It seems like it does, now we right click the sceDisplayWaitVblankStart function on the left and select Show References to
data:image/s3,"s3://crabby-images/37f64/37f6467c9c6997e56d95309483b0661f6b9ecb4d" alt=""
The following screen will now popup
data:image/s3,"s3://crabby-images/ae36e/ae36e0fcc115cbafea3182386bf8428b28217c7c" alt=""
If you click on the first result (blx), Ghidra will point to the (usually) correct spot in the file.
data:image/s3,"s3://crabby-images/08d25/08d257c73308be403f18dff8797fd578362c3038" alt=""
Write down what the current address is of the line we want to nop out.
data:image/s3,"s3://crabby-images/cda84/cda84897c6c23a3524c942b4ea9cdfc00b6e8f8f" alt=""
The line in my example is 81bebe5a
.
Remember the Start and End we had to note down from the Memory Map? It’s time to use them.
We can see that our code is in between the first 2 numbers, segment 0.
To get the correct address for VitaGrafix, we have to do some simple math, but in hexadecimals. I use: Hex Calculator
We need to subtract the Start number with our address, so: 81000000-81bebe5a=BEBE5A
To test if it is this address, we can nop out this function.
Before we can even do anything, we need to boot the game once first so we get a log in VitaGrafix, so boot your game.
Open VitaShell on your PSVita and enable transfer mode, either USB or FTP.
Navigate to /ux0:/data/VitaGrafix and open log.txt. It should look like this:
VitaGrafix v5.0.2
=======================================
[MAIN] Title ID: PCSA00147
[MAIN] SELF: ux0:/patch/PCSA00147/eboot.bin
[MAIN] NID: 0xB8925727
=======================================
[IO] Parsing ux0:data/VitaGrafix/patch/PCSA00147.txt
[PATCH] Patching seg000 : 00C4F6B6 to C4 F2 70 21, size=4
[PATCH] Patching seg000 : 00C522D4 to 5F F4 20 7B, size=4
[PATCH] Patching seg000 : 00C522D8 to 5F F4 B8 7A, size=4
[PATCH] Patching seg000 : 00C51F62 to 5F F4 20 70, size=4
[PATCH] Patching seg000 : 00C51F6A to 5F F4 B8 75, size=4
[PATCH] Patching seg000 : 0103A348 to 5F F4 20 70, size=4
[PATCH] Patching seg000 : 0103A34E to 5F F4 B8 70, size=4
[PATCH] Patching seg000 : 0103A0F0 to 5F F4 20 71, size=4
[PATCH] Patching seg000 : 0103A0F6 to 5F F4 B8 72, size=4
[PATCH] Patching seg000 : 0069F3A2 to 5F F4 20 71, size=4
[PATCH] Patching seg000 : 0069F3A6 to 5F F4 B8 72, size=4
[PATCH] Patched 44 bytes in 11 patches and it took 3ms
[PATCH] 2 total game patches found in patch list
We want to copy the Title ID and NID.
Navigate to /ux0:/data/VitaGrafix and make a folder called patch.
In this folder, make a new file called PCSA00147.txt or whatever your game’s ID is.
Now, put in the following:
# Freedom Wars
[PCSA00147, eboot.bin, 0xB8925727] # [US, 1.22]
@FPS
0:0xC4F6B6 nop
Save the file and upload it back to the PSVita.
Now open ux0:/data/VitaGrafix/config.txt
To enable the config we just made, we add the following:
[PCSA00147]
ENABLED=1
OSD=1
FPS=60
The number 60 behind FPS won’t do anything, really. It’s just a placeholder for now.
Testing the game
Launch your game and see if it has the lock removed or not.
If it does, congratulations.
If it doesn’t, well.. You’ll have to dig some deeper into the eboot.elf file and the vita documentation. It’s not always as simple as this, something you need to nop out multiple address, or even edit them entirely.
Filed under: Reverse Engineering - @ August 25, 2023 12:57 pm
Tags: ghidra, hacking, vita, vitagrafix