This page is a work in process.
Docomo Phones by Sharp
Check the dumping hardware overview for a list of known preservation hardware.
If you need help, please come chat with us on the VGPC or No-Intro discord servers.
Introduction
Sharp Docomo phones generally run on a customized version of Symbian. These phones will have no reaction when plugged into a debug adapter.
Note: For the models SH903i and before, we do not have a way to exploit these phones through USB because they do not appear as connected to a PC once their battery is removed. Some phones can be chip dumped directly, but there is a lot of proprietary information we are missing on these early Sharp phones.
Phone Model | Extractable? | File System/FTL | Tools |
---|---|---|---|
SH2101V | Unknown | Unknown | Unknown |
SH900i | Only through NOR chip-off | SH900i FTL | assemble_sh900i + TestDisk |
SH700i | No | Unknown | Unknown |
SH700iS | No | Unknown | Unknown |
SH901iC | No | Unknown | Unknown |
SH901iS | No | Unknown | Unknown |
SH851i | No | Unknown | Unknown |
SH902i | No | Unknown | Unknown |
SH902iS | No | Unknown | Unknown |
SH902iL | No | Unknown | Unknown |
SH702iD | No | Unknown | Unknown |
SH702iS | No | Unknown | Unknown |
SH903i | No | Unknown | Unknown |
SH903iTV | Yes | FAT16 + ROFS + “SH/D904i” FTL | assemble_sh704i_d904i + TestDisk |
SH703i | Yes | FAT16 + ROFS + “SH/D904i” FTL | assemble_sh704i_d904i + TestDisk |
SH904i | Yes | FAT16 + ROFS + “SH/D904i” FTL | assemble_sh704i_d904i + TestDisk |
SH704i | Yes | FAT16 + ROFS + “SH/D904i” FTL | assemble_sh704i_d904i + TestDisk |
SH905i | Yes | FAT16 + ROFS + “B4B4” FTL | b4-ftl-extract + TestDisk |
SH905iTV | Yes | FAT16 + ROFS + “B4B4” FTL | b4-ftl-extract + TestDisk |
SH705i | Unknown | Unknown | Unknown |
SH705iII | Unknown | Unknown | Unknown |
SH906i | Yes | FAT32 + ROFS + Fugue NAND | fugue-tools + TestDisk |
SH906iTV | Yes | FAT32 + ROFS + Fugue NAND | fugue-tools + TestDisk |
SH706i | Yes | FAT32 + ROFS + Fugue NAND | fugue-tools + TestDisk |
SH706ie | Unknown | Unknown | Unknown |
SH706iw | Unknown | Unknown | Unknown |
SH-01A | Yes | FAT32 + ROFS + EPOC32 ROM + Fugue NAND (A+B) | fugue-tools + TestDisk |
SH-02A | Yes | FAT32 + ROFS + Fugue NAND | fugue-tools + TestDisk |
SH-03A | Yes | FAT32 + ROFS + EPOC32 ROM + Fugue NAND (A+B) | fugue-tools + TestDisk |
SH-04A | Yes | FAT32 + ROFS + EPOC32 ROM + Fugue NAND (A+B) | fugue-tools + TestDisk |
SH-05A | Yes | FAT16 + ROFS + “B4B4” FTL | b4-ftl-extract + TestDisk |
SH-06A | Yes | FAT16 + ROFS + “B4B4 FTL | b4-ftl-extract + TestDisk |
SH-06A NERV | Yes | FAT16 + ROFS + “B4B4” FTL | b4-ftl-extract + TestDisk |
SH-07A | Unknown | Unknown | Unknown |
SH-08A | Unknown | Unknown | Unknown |
SH-01B | Yes | FAT16 | TestDisk |
SH-02B | Yes | Unknown | Unknown |
SH-03B | Yes | FAT16 | TestDisk |
SH-04B | Unknown | Unknown | Unknown |
SH-05B | Yes | FAT + EPOC32 ROM | Symbian SDK |
SH-06B | Yes | FAT16 + EPOC32 ROM | Symbian SDK |
SH-07B | Yes | FAT32 + EPOC32 ROM | Symbian SDK |
SH-08B | Unknown | Unknown | Unknown |
SH-09B | Yes | FAT16 + EPOC32 ROM | Symbian SDK |
SH-01C | Yes | FAT32 + EPOC32 ROM | Symbian SDK |
SH-02C | Yes | FAT + EPOC32 ROM | Symbian SDK |
SH-04C | Unknown | Unknown | Unknown |
SH-05C | Unknown | Unknown | Unknown |
SH-06C | Unknown | Unknown | Unknown |
SH-08C | Unknown | Unknown | Unknown |
SH-09C | Unknown | Unknown | Unknown |
SH-10C | Yes | FAT32 + EPOC32 ROM | Symbian SDK |
SH-11C | Yes | FAT32 + EPOC32 ROM | Symbian SDK |
SH-03D | No | Unknown | Unknown |
SH-03E | No | FAT32 + EPOC32 ROM | Symbian SDK |
SH-07F | No | Unknown | Unknown |
Methods
Extracting Data
Reading File Systems
Ktdumper
Ktdumper is a tool for extracting data from feature phones that are compatible with the Foma debug adapter, which includes all Docomo phones and select SoftBank phones. Please note that ktdumper will not work unless you have the Foma debug adapter.
Ktdumper is compatible with Linux and WSL (Windows System on Linux). It can be used as a command line tool or as a live Linux iso with a GUI.
Ktdumper Command Line
- Make sure your phone is connected to the PC (if using WSL, you will need to bind your USB device)
- Download the ktdumper repository from Github
- Navigate to the main ktdumper folder, where the code will be executed.
- You can execute the following commands
- NAND (contains user data, downloads, etc.)
sudo ./ktdumper.sh [insert phone model] dump_nand
- NOR
sudo ./ktdumper.sh [insert phone model] dump_nor
- JAVA Folder (only works on select Mitsubishi/Fujitsu phones)
sudo ./ktdumper.sh [insert phone model] dump_java
Sample For D904i
sudo ./ktdumper.sh d904i dump_nand
Ktdumper Live Iso
WIP
Reading Data
assemble_sh704i_d904i
Before using assemble_sh704i_d904i.py, you must separate the NAND and OOB (out of bounds) data.
- Download the separate_nand_oob.py script from Github and place it into the folder generated by ktdumper
- Execute the following script
python separate_nand_oob.py nand_mixed.bin
- When given a set of options, select 0 (the other options are not needed for D904i/SH904i devices)
0: Data = 512 Bytes, OOB = 16 bytes, divisible = True
To remove the FTL:
- Download the assemble_sh704i_d904i.py script from Github
- Execute the following command
python assemble_sh704i_d904i.py nand_mixed_separated_512.bin output.bin
After this, you must use TestDisk to acquire the data.
assemble_sh900i
- Download the assemble_sh900i.py script from Github
- Execute the following command with your dump-specific variables
python assemble_sh900i.py <input file> <output file>
After this, you must use TestDisk to acquire the data.
b4-ftl-extract
- Download the b4-ftl-extract scripts from Github
- Place scripts in the same folder as nand.bin
- EITHER drag nand.bin into b4b4.bat or enter the following command
python extract.py -s nand.bin output_dir
This code will unscramble the FTL and place all data into a folder called output_dir
After this, you must use TestDisk to acquire the data.
fugue-tools
Fugue Nand Regular
- Download the fugue-tools repository from Github
- Place extract.py from fugue-tools into the same folder with nand.bin and nand.oob. Run this command:
python extract.py nand.bin output.bin
The file system can now be read and extracted with TestDisk.
Fugue Nand A+B
- Rename the files in the Part A dump folder to nand_a.bin and nand_a.oob
- Rename the files in the Part B dump folder to nand_b.bin and nand_b.oob
- Place all of these files into the same folder along with extract.py from fugue-tools.
- Execute the following command
python extract.py nand_a.bin nand_b.bin output.bin
The file system can now be read and extracted with TestDisk.
Symbian SDK
EPOC32 is a mobile operating system. It is a predecessor to Symbian, and its data can be extracted using tools from the Symbian 3 SDK.
- Install the Symbian SDK (Windows)
- Find readimage.exe. In a typical Symbian 3 SDK install, it will be located here.
C:\Nokia\devices\Nokia_Symbian3_SDK_v1.0\epoc32\tools\readimage.exe
Put the dump into the same folder as readimage.exe
- Open the command line in that folder and paste the following:
.\readimage.exe <file name> -z <output folder name>
This script will create an output folder and place all files inside of it.
NOTE: For Sony Ericsson phone NOR dumps, you may need to cut out the data before 0x100000
TestDisk Procedure
TestDisk can be used on either Windows or Linux. It is available for download here. Once you have downloaded TestDisk, use the program to open your current .bin file.
- When you open a .bin file with TestDisk, you will have the option to select a media. There should only be
>Disk <your file>
Press enter to proceed.
- When asked to select a partition table type, select None
[None ] Non partitioned media
- On the following page, press q to quit or select
[ quit ]
- In the new menu, move up the menu and select
[ Analyse ]
- Press enter to continue with
[Quick Search]
- You should now see a partition labeled with a file system like FAT16 or FAT32. Don’t press ENTER. Instead, press p to list files.
- Press a to select all files.
- Press C (note the capitalization and hold the shift button!) to copy the selected files.
- Choose the output folder. Press C when the folder is correct.
You should now have all the extracted files.
Note: For select devices (such as F905i and D905i), you need to select None → Undelete rather than the usual TestDisk procedure.
Gathering and Submitting Dump Info
Once you've dumped your games, it's time to generate and submit metadata to a preservation project for validating and cataloging. See the dump submission instructions for more information.