Smartphone Flash Tool -runtime Trace Mode- -

A automatically downgrades from Full to PC-Only when the host cannot keep up. 5. Implementation Example: Extending MTK (MediaTek) SP Flash Tool 5.1 Current Limitations MediaTek’s BootROM (Preloader v2) already includes a partial trace capability via SEND_DA_EX command with debug flag 0x80, but it only dumps a fixed 256-byte register file on crash. No continuous streaming. 5.2 RTM Modifications Step 1 – Custom Download Agent (DA): Patch the original DA binary ( MTK_AllInOne_DA.bin ) to include a background thread:

Add a new USB class (0xFF, subclass 0x02) for trace data. In brom.cpp :

[PC: 0x0012F4A0] pl_check_battery() -> return 0 (battery low) [PC: 0x0012F4B8] pl_shutdown_thermal() [PC: 0x0012F2C0] reset_system() -> infinite loop. Faulty ADC reading on battery thermistor. Fix: Bypass battery check in DA script. 6.2 Secure Boot Chain Verification Using Full Execution Trace over USB (48 MB/s) while flashing a custom U-Boot: smartphone flash tool -runtime trace mode-

Patch offsets: SPFlashTool.exe @ 0x2A3F4 – enable hidden menu, then Ctrl+Shift+T for trace console.

class RuntimeTraceMode HANDLE hTracePipe; // separate thread void OnTracePacket(BYTE* data, DWORD len) if(data[0] == TRACE_PC_PKT) uint32_t pc = *(uint32_t*)(data+1); auto sym = symtab.Find(pc); Log("PC: 0x%08X (%s)", pc, sym.name); ; Send CMD_SET_TRACE_CONFIG(addr_range_start, addr_range_end, mode_flags) before CMD_DOWNLOAD . 6. Use Cases & Results 6.1 Diagnosing Preloader Boot Loop Symptom: Device vibrates every 3 seconds, not detected by flash tool. RTM capture (PC-Only mode): A automatically downgrades from Full to PC-Only when

Document Version: 1.0 Subject Area: Embedded Systems Debugging, Mobile Device Firmware Tooling Target Audience: Firmware Engineers, Security Researchers, Android OEM Developers 1. Abstract Traditional smartphone flash tools (e.g., SP Flash Tool, Qualcomm QFIL, Samsung Odin) operate in a black-box programming mode . They send pre-built firmware images (bootloader, kernel, system) to the device’s memory partitions with minimal runtime feedback. This paper introduces Runtime Trace Mode (RTM) — an extension to conventional flashing tools that enables real-time instruction execution tracing, memory access logging, and register state streaming from the device’s boot ROM and bootloader during the flashing process. RTM transforms the flash tool from a simple programmer into a low-level interactive debugger, crucial for diagnosing boot failures, verifying secure boot chains, and analyzing proprietary bootrom exploits. 2. Introduction Smartphone boot sequences involve multiple stages: BootROM → Preloader → Little Kernel (LK) / U-Boot → Kernel. A single corrupted partition or misconfigured security fuse often results in a dead device (hard brick). Conventional flash tools provide no insight into why the device halts. They only succeed or fail with opaque error codes (e.g., STATUS_BROM_CMD_SEND_DA_FAIL ).

void trace_thread() uint32_t last_pc = 0; while (1) uint32_t pc = read_cp15_register(PROGRAM_COUNTER); if (pc != last_pc) uint8_t packet[8]; packet[0] = TRACE_PC_PKT; // 0xE1 *(uint32_t*)(packet+1) = pc; send_usb_trace_packet(packet, 5); last_pc = pc; for(int i=0;i<1000;i++) asm("nop"); // sampling rate ~100 kHz No continuous streaming

RTM default recommendation: Fallback UART + USB bulk when available. | Mode | Data Generated | Bandwidth Requirement | Use Case | |-------|----------------|------------------------|------------| | PC-Only | 4 bytes per instruction | ~200 KB/s (at 100 MHz, 1:1000 sampling) | Locating infinite loops | | PC + Load/Store Address | 12–16 bytes per memory op | ~5 MB/s | Detecting wild pointers | | Register Delta | 2–8 bytes per taken branch | ~1 MB/s | Tracking boot state machine | | Full Execution Trace | All of above | ~50 MB/s (impractical for UART) | Post-mortem analysis with USB |

In development...!

In development...!

While these buttons work, years will pass, maybe even centuries, but do not despair, wait and you will be rewarded! Want to speed up the development process? Do reposts of the site pages on social networks and tell your friends about us!
Registration completed successfully