Determining the Image Base of ARM Firmware by Matching Function Addresses

Ruijin Zhu*, Baofeng Zhang, Yu An Tan, Yueliang Wan, Jinmiao Wang

*Corresponding author for this work

Research output: Contribution to journalArticlepeer-review

2 Citations (Scopus)

Abstract

Firmware is software embedded in a device and acts as the most fundamental work of a system. Disassembly is a necessary step to understand the operational mechanism or detect the vulnerabilities of the firmware. When disassembling a firmware, it should first obtain the processor type of running environment and the image base of firmware. In general, the processor type can be obtained by tearing down the device or consulting the product manual. However, at present, there is still no automated tool that can be used to obtain the image base of all types of firmware. In this paper, we focus on firmware in ARM and propose an automated method to determine the image base address. Firstly, by studying the storage rule and loading mode of the function address, we can obtain the function offset and the function address loaded by LDR instruction, respectively. Then, with this information, we propose an algorithm, named Determining image Base by Matching Function Addresses (DBMFA), to determine the image base. The experimental results indicate that the proposed method can successfully determine the image base of firmware which uses LDR instruction to load function address.

Original languageEnglish
Article number4664882
JournalWireless Communications and Mobile Computing
Volume2021
DOIs
Publication statusPublished - 2021

Fingerprint

Dive into the research topics of 'Determining the Image Base of ARM Firmware by Matching Function Addresses'. Together they form a unique fingerprint.

Cite this