Extract hidden "fastboot oem" commands from firmware blobs
These firmware blobs will be accepted by this tool
ABL(Qualcomm)LK1st, LK2nd(Qualcomm)LK(MediaTek)FBPKContainers (Google)DHTBSigned binaries (U-Boot)ELFLinux binaries- Anything else containing UEFI PEs
This is an artificial barrier for when this tool is ran in a loop against firmware images
- Install python requirements
pip install -r requirements.txt- Prepare your firmware images from the internet, or by pulling them off the device with
adb - Run extractor.py against the image
# Example for Redmi Note 14 Pro+ 5G (amethyst)
╭─user@hostname ~/fboem ‹master›
╰─$ python ./extractor.py ./abl.elf
(x) File contains common bootloader magic bytes
(x) Reading firmware file (first 10MB): abl.elf
(x) Found valid UEFI firmware structure at offset: 0x1000
(x) Extracting firmware...
(x) Found 1 UEFI portable executable(s)
(x) Matching 'oem *' ascii strings
fastboot oem allow-wipe-userdata
fastboot oem audio-framework
fastboot oem device-info
fastboot oem disable-charger-screen
fastboot oem dm-verity-enforcing
fastboot oem edl
fastboot oem enable-charger-screen
fastboot oem fbreason
fastboot oem getguid
fastboot oem hwid
fastboot oem lkmsg
fastboot oem lock
fastboot oem lpmsg
fastboot oem off-mode-charge
fastboot oem poweroff
fastboot oem ramdump fat
fastboot oem select-display-panel
fastboot oem set-gpu-preemption
fastboot oem set-hw-fence-value
fastboot oem uart-enable
fastboot oem uefilog
fastboot oem unlockIf your file is some sparse image that does not contain any UEFI PEs or common binary magic bytes, you can force the string lookup via this command line option:
--force-string-lookupDue to the nature of simply matching "oem" strings, the output may contain some invalid commands, or commands that don't work after the device is sent out of factory. Keep this in mind
If you want to extract bootloader/charging pictures from a imagefv partition on your Qualcomm device,
use my other tool:
chickendrop89/imagefv-extractor
- Python 3.10 or newer
- Installed
uefi_firmwarepip package