PS3:Recovering Data: Difference between revisions
Jump to navigation
Jump to search
Zorua98741 (talk | contribs) (Initial commit for guide to dump HDD encryption key and read data on windows) |
mNo edit summary |
||
(12 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
[[Category:PS3]] | |||
{{Warning|This guide applies to CFW compatible consoles only, PS3HEN consoles are not able to dump the required ERK file.}} | |||
If something happens to your PS3 that leaves you unable to access files on the system storage, you may still be able to recover important files if you have previously dumped your per-console hard-drive encryption key (eid_root_key). | If something happens to your PS3 that leaves you unable to access files on the system storage, you may still be able to recover important files if you have previously dumped your per-console hard-drive encryption key (eid_root_key). | ||
If a PS3 hard drive has been reinitialised, but not formatted, you may be able to [https://consolemods.org/wiki/PS3:Boot_Recovery flash a new boot sector] onto it. | |||
Please note, these tools allow for '''read-only''' access, you cannot use this to write files to the PS3s system storage. | Please note, these tools allow for '''read-only''' access, you cannot use this to write files to the PS3s system storage. | ||
Line 5: | Line 10: | ||
==Dumping the eid_root_key== | ==Dumping the eid_root_key== | ||
===Rebug | ===Rebug Firmwares=== | ||
# Open | # Open Rebug Toolbox under "Game" on the XMB. | ||
#* | #* If you do not have rebug toolbox installed, the installer should already be on your console at `/dev_rebug/rebug/packages`, where you can install it via "Package Manager > Install Package Files > PS3 System Storage". | ||
#* | #* If rebug toolbox is not downloaded, you can get the latest version [https://store.brewology.com/ahomebrew.php?brewid=308 from Brewology] ([[:File:REBUG_TOOLBOX_02.03.07.MULTI.16.pkg.476.v02.03.07_brewology_com.pkg|mirror]], [https://github.com/Joonie86/Rebug-Toolbox source]) | ||
# | # Navigate to the "Utilities" category, scroll down to and select "Dump eid root key". | ||
# | # A popup will inform you that the eid_root_key will be created in `/dev_hdd0/game/RBGTLBOX2/USRDIR/`, select "Yes". | ||
# | # The PS3 will reboot and beep. | ||
# | # Navigate to the location Rebug Toolbox informed you with either your choice of homebrew, or FTP program, copying over the "eid_root_key" file to a flash drive or your computer. | ||
===Evilnat Firmwares=== | |||
{{Note|This feature was added in Evilnat '''4.88.2''', it will not be available in '''4.88.1''' or lower.}} | |||
# From the top of the "Network" column on the XMB, select "Custom Firmware Tools". | |||
# Navigate to and select the "Dump Tools" category. | |||
# Navigate to and select "Dump ERK". | |||
# Navigate to either `/dev_usb/` or `/dev_hdd0/tmp/` and copy the eid_root_key to a safe place such as your PC. | |||
== | ==(Method 1) Reading the PS3 HDD on Windows== | ||
{{ | {{Warning|Whenever you plug the PS3s system drive into a PC, be careful to never format or initialize the drive, doing so may permanently erase your data.}} | ||
# Plug the SATA and power cable from your PC into the PS3's HDD. | |||
# Turn your PC on, and if prompted, select '''"No"''' to initialising or formatting the drive. | |||
# Download PS3_HDD_Reader by 3141card from [[:File:PS3_HDD_Reader_final_windows.7z|here]], extract the folder once complete. | |||
# Paste your eid_root_key into the "PS3_HDD_Reader_final_windows" folder | |||
#* The readme.txt in the download will have the same or similar instructions to the below. | |||
# Navigate to the "PS3_HDD_Reader_final_windows" folder previously extracted, and where the directory is displayed (to the left of the search bar), right click and select "Copy address as text" | |||
#* Alternatively, selecting "Copy path" with the "PS3_HDD_Reader_final_windows" folder selected will achieve the same result. | |||
# Press Start, search for "cmd", right click Command Prompt and select Run as Administrator. | |||
# Enter the command `cd ...` (replacing ... with the copied path to the folder you extracted). | |||
#* If you copied the "PS3_HDD_Reader_final_windows" folder to a drive other than C:\, you may have to enter the command "[drive letter]''':'''" (e.g. "C:\WINDOWS\system32>'''D:'''"). | |||
# In the command prompt window, enter `ps3_hdd_reader.exe hdd`. This will display all available partitions on the PS3's HDD, and will indicate that everything is working okay. | |||
#* Alternatively, if you have a dump of a PS3 HDD, name it backup.bin, place it in the extracted programs folder, and use the command `ps3_hdd_reader.exe file`. Replace "hdd" with "file" as the first argument in the following commands (e.g. `ps3_hdd_reader.exe '''file''' dev_hdd0 copy /PS3ISO`). | |||
# Again in the command prompt window, you can begin copying and viewing the files you want through commands such as: | |||
#* `dir` to view a specified directory contents. | |||
#** `ps3_hdd_reader.exe hdd dev_hdd0 dir /` to view the dev_hdd0 partition file structure. | |||
#* `copy` to copy a specified directory contents to the PS3_HDD_Reader_final_windows folder. | |||
#** `ps3_hdd_reader.exe hdd dev_hdd0 copy /PS3ISO` to copy '''all''' files inside the "PS3ISO" directory. | |||
#* It's not recommended to copy entire large directories such as "dev_hdd0" due to potential storage space issues on the PC, instead copy individual large files such as ISO or folder games with commands: | |||
#** `ps3_hdd_reader.exe hdd dev_hdd0 copy /GAMES/[gameName]` (replacing [gameName] with the exact name of the folder/file). | |||
# Once you have copied all your important data, unplug your PS3 hard drive. | |||
==(Method 2) Reading the PS3 HDD on Linux== | |||
This process was tested on Mint Cinnamon 18.2. '''YOU CANNOT DO THIS METHOD ON A LIVE CD/USB!''' | |||
# Open up a new terminal window and run the following command: | |||
#:sudo apt-get install openssl nbd-client | |||
# | # Download the [[:File:HDD_Decryption_Tools_for_Linux.zip|tools]] and extract the "ps3" file to `/home/your_name`. | ||
# | # Open up a new terminal window, or re-use your previous one and change directory to `/home/your_name/ps3`. | ||
# | # Copy your eid_root_key into this directory and rename it to `eid_root_key.bin`. | ||
# | # If you are using Cinnamon 18.2, rename the "bswap16 (Mint 18.2 64bit, 512).elf" file to "bswap16.elf" using the command `mv "bswap16 (Mint 18.2 64bit, 512).elf" "bswap16.elf"` in Terminal. | ||
# | # Run the following command: | ||
# | #:chmod +x makedev.sh bswap16.elf "PS3HDD Keygen v1.3.sh" | ||
# | #:./PS3HDD\ Keygen\ v1.3.sh | ||
# | # Select what model PS3 you have. This script will create the decryption keys. | ||
#* | # Run the command `lsblk` to determine what identifier the PS3 HDD has. (`/dev/sda`, `/dev/sdb` and so on). | ||
# | # Switch to superuser mode by executing the command `sudo su`. | ||
# | # Execute the following command using the `sdx` identifier from step 8. If it succeeds, you should not receive an error. | ||
# | #:./makedev /home/your_name/ps3/bswap16.elf /dev/sdx | ||
# | # | ||
# | #* If you're on a ''Fat'' console, run the following command: | ||
# | #:cryptsetup create -c aes-cbc-null -d /home/your_username/ps3/hdd_key.bin -s 192 ps3hdd /dev/nbd0" | ||
#*If you're on a **Slim** console, run this one instead: | |||
#:cryptsetup create -c aes-xts-plain64 -d /home/your_username/ps3/hdd_key.bin -s 256 ps3hdd /dev/nbd0 | |||
# Run the following command: | |||
#:kpartx -a /dev/mapper/ps3hdd | |||
# If everything went well so far, running the following command will yield multiple partitions starting with dm-X. If you're only getting one partition, you decrypted it wrongly. | |||
#:ls -l /dev/mapper/ | |||
# On NOR consoles, dm-1 is the VFLASH and on NAND, dm-1 is dev_hdd1. dm-2 is always dev_hdd0 and dm-4 is dev_hdd2 (dm-3 on NAND consoles.) | |||
# To mount the VFLASH on NOR consoles, you need to execute the following commands: | |||
#:cryptsetup create -c aes-xts-plain64 -d /home/your_username/ps3/vflash_key.bin -s 256 -p 8 ps3vflash /dev/dm-1 | |||
#:kpartx -a /dev/mapper/ps3vflash | |||
# To mount dev_hdd0, you need to execute the following command: | |||
#:mount -t ufs -o ufstype=ufs2,ro /dev/dm-2 /home/mint/ps3/dev_hdd0 | |||
# Mounting of dev_hdd1 and the dev_flash regions (for NOR) requires you to execute the following. This also works for mounting dev_hdd1 on NAND. | |||
#:mount -t vfat /dev/dm-3 /home/your_username/ps3/dev_hdd1 | |||
#:mount -t vfat /dev/dm-6 /home/your_username/ps3/dev_flash1 | |||
#:mount -t vfat /dev/dm-7 /home/your_username/ps3/dev_flash2 | |||
#:mount -t vfat /dev/dm-8 /home/your_username/ps3/dev_flash3 | |||
#*Keep in mind that you can only write to the vfat partitions and nothing else. For the other partitions, you can only read. | |||
# When you're finished doing your work, you'll need to unmount the partitions as well as delete the mapper drives. You can do that by executing the following commands. | |||
#:umount -l /home/mint/ps3/dev_hdd0 | |||
#:umount -l /home/mint/ps3/dev_hdd1 | |||
#:umount -l /home/mint/ps3/dev_flash1 | |||
#:umount -l /home/mint/ps3/dev_flash2 | |||
#:umount -l /home/mint/ps3/dev_flash3 | |||
#:kpartx -d /dev/mapper/ps3vflash && cryptsetup remove ps3vflash | |||
#:kpartx -d /dev/mapper/ps3hdd && cryptsetup remove ps3hdd |
Latest revision as of 19:37, 4 November 2024
This guide applies to CFW compatible consoles only, PS3HEN consoles are not able to dump the required ERK file. |
If something happens to your PS3 that leaves you unable to access files on the system storage, you may still be able to recover important files if you have previously dumped your per-console hard-drive encryption key (eid_root_key).
If a PS3 hard drive has been reinitialised, but not formatted, you may be able to flash a new boot sector onto it.
Please note, these tools allow for read-only access, you cannot use this to write files to the PS3s system storage.
Dumping the eid_root_key
Rebug Firmwares
- Open Rebug Toolbox under "Game" on the XMB.
- If you do not have rebug toolbox installed, the installer should already be on your console at
/dev_rebug/rebug/packages
, where you can install it via "Package Manager > Install Package Files > PS3 System Storage". - If rebug toolbox is not downloaded, you can get the latest version from Brewology (mirror, source)
- If you do not have rebug toolbox installed, the installer should already be on your console at
- Navigate to the "Utilities" category, scroll down to and select "Dump eid root key".
- A popup will inform you that the eid_root_key will be created in
/dev_hdd0/game/RBGTLBOX2/USRDIR/
, select "Yes". - The PS3 will reboot and beep.
- Navigate to the location Rebug Toolbox informed you with either your choice of homebrew, or FTP program, copying over the "eid_root_key" file to a flash drive or your computer.
Evilnat Firmwares
This feature was added in Evilnat 4.88.2, it will not be available in 4.88.1 or lower. |
- From the top of the "Network" column on the XMB, select "Custom Firmware Tools".
- Navigate to and select the "Dump Tools" category.
- Navigate to and select "Dump ERK".
- Navigate to either
/dev_usb/
or/dev_hdd0/tmp/
and copy the eid_root_key to a safe place such as your PC.
(Method 1) Reading the PS3 HDD on Windows
Whenever you plug the PS3s system drive into a PC, be careful to never format or initialize the drive, doing so may permanently erase your data. |
- Plug the SATA and power cable from your PC into the PS3's HDD.
- Turn your PC on, and if prompted, select "No" to initialising or formatting the drive.
- Download PS3_HDD_Reader by 3141card from here, extract the folder once complete.
- Paste your eid_root_key into the "PS3_HDD_Reader_final_windows" folder
- The readme.txt in the download will have the same or similar instructions to the below.
- Navigate to the "PS3_HDD_Reader_final_windows" folder previously extracted, and where the directory is displayed (to the left of the search bar), right click and select "Copy address as text"
- Alternatively, selecting "Copy path" with the "PS3_HDD_Reader_final_windows" folder selected will achieve the same result.
- Press Start, search for "cmd", right click Command Prompt and select Run as Administrator.
- Enter the command
cd ...
(replacing ... with the copied path to the folder you extracted).- If you copied the "PS3_HDD_Reader_final_windows" folder to a drive other than C:\, you may have to enter the command "[drive letter]:" (e.g. "C:\WINDOWS\system32>D:").
- In the command prompt window, enter
ps3_hdd_reader.exe hdd
. This will display all available partitions on the PS3's HDD, and will indicate that everything is working okay.- Alternatively, if you have a dump of a PS3 HDD, name it backup.bin, place it in the extracted programs folder, and use the command
ps3_hdd_reader.exe file
. Replace "hdd" with "file" as the first argument in the following commands (e.g.ps3_hdd_reader.exe file dev_hdd0 copy /PS3ISO
).
- Alternatively, if you have a dump of a PS3 HDD, name it backup.bin, place it in the extracted programs folder, and use the command
- Again in the command prompt window, you can begin copying and viewing the files you want through commands such as:
dir
to view a specified directory contents.ps3_hdd_reader.exe hdd dev_hdd0 dir /
to view the dev_hdd0 partition file structure.
copy
to copy a specified directory contents to the PS3_HDD_Reader_final_windows folder.ps3_hdd_reader.exe hdd dev_hdd0 copy /PS3ISO
to copy all files inside the "PS3ISO" directory.
- It's not recommended to copy entire large directories such as "dev_hdd0" due to potential storage space issues on the PC, instead copy individual large files such as ISO or folder games with commands:
ps3_hdd_reader.exe hdd dev_hdd0 copy /GAMES/[gameName]
(replacing [gameName] with the exact name of the folder/file).
- Once you have copied all your important data, unplug your PS3 hard drive.
(Method 2) Reading the PS3 HDD on Linux
This process was tested on Mint Cinnamon 18.2. YOU CANNOT DO THIS METHOD ON A LIVE CD/USB!
- Open up a new terminal window and run the following command:
- sudo apt-get install openssl nbd-client
- Download the tools and extract the "ps3" file to
/home/your_name
. - Open up a new terminal window, or re-use your previous one and change directory to
/home/your_name/ps3
. - Copy your eid_root_key into this directory and rename it to
eid_root_key.bin
. - If you are using Cinnamon 18.2, rename the "bswap16 (Mint 18.2 64bit, 512).elf" file to "bswap16.elf" using the command
mv "bswap16 (Mint 18.2 64bit, 512).elf" "bswap16.elf"
in Terminal. - Run the following command:
- chmod +x makedev.sh bswap16.elf "PS3HDD Keygen v1.3.sh"
- ./PS3HDD\ Keygen\ v1.3.sh
- Select what model PS3 you have. This script will create the decryption keys.
- Run the command
lsblk
to determine what identifier the PS3 HDD has. (/dev/sda
,/dev/sdb
and so on). - Switch to superuser mode by executing the command
sudo su
. - Execute the following command using the
sdx
identifier from step 8. If it succeeds, you should not receive an error.- ./makedev /home/your_name/ps3/bswap16.elf /dev/sdx
-
- If you're on a Fat console, run the following command:
- cryptsetup create -c aes-cbc-null -d /home/your_username/ps3/hdd_key.bin -s 192 ps3hdd /dev/nbd0"
- If you're on a **Slim** console, run this one instead:
- cryptsetup create -c aes-xts-plain64 -d /home/your_username/ps3/hdd_key.bin -s 256 ps3hdd /dev/nbd0
- Run the following command:
- kpartx -a /dev/mapper/ps3hdd
- If everything went well so far, running the following command will yield multiple partitions starting with dm-X. If you're only getting one partition, you decrypted it wrongly.
- ls -l /dev/mapper/
- On NOR consoles, dm-1 is the VFLASH and on NAND, dm-1 is dev_hdd1. dm-2 is always dev_hdd0 and dm-4 is dev_hdd2 (dm-3 on NAND consoles.)
- To mount the VFLASH on NOR consoles, you need to execute the following commands:
- cryptsetup create -c aes-xts-plain64 -d /home/your_username/ps3/vflash_key.bin -s 256 -p 8 ps3vflash /dev/dm-1
- kpartx -a /dev/mapper/ps3vflash
- To mount dev_hdd0, you need to execute the following command:
- mount -t ufs -o ufstype=ufs2,ro /dev/dm-2 /home/mint/ps3/dev_hdd0
- Mounting of dev_hdd1 and the dev_flash regions (for NOR) requires you to execute the following. This also works for mounting dev_hdd1 on NAND.
- mount -t vfat /dev/dm-3 /home/your_username/ps3/dev_hdd1
- mount -t vfat /dev/dm-6 /home/your_username/ps3/dev_flash1
- mount -t vfat /dev/dm-7 /home/your_username/ps3/dev_flash2
- mount -t vfat /dev/dm-8 /home/your_username/ps3/dev_flash3
- Keep in mind that you can only write to the vfat partitions and nothing else. For the other partitions, you can only read.
- When you're finished doing your work, you'll need to unmount the partitions as well as delete the mapper drives. You can do that by executing the following commands.
- umount -l /home/mint/ps3/dev_hdd0
- umount -l /home/mint/ps3/dev_hdd1
- umount -l /home/mint/ps3/dev_flash1
- umount -l /home/mint/ps3/dev_flash2
- umount -l /home/mint/ps3/dev_flash3
- kpartx -d /dev/mapper/ps3vflash && cryptsetup remove ps3vflash
- kpartx -d /dev/mapper/ps3hdd && cryptsetup remove ps3hdd