diff options
author | Amaury Pouly <amaury.pouly@gmail.com> | 2014-06-24 18:04:17 +0200 |
---|---|---|
committer | Amaury Pouly <amaury.pouly@gmail.com> | 2014-06-24 18:07:56 +0200 |
commit | c9a028cc183d638c16ca9a8858b783b1830be16f (patch) | |
tree | 1bd29843ec0b8d3eb80a6209d1c4e32144175dfe /utils/hwpatcher/fuzep_rb.lua | |
parent | 761f59c9e3be0ffd77d2dc1b8095a3b877badeda (diff) | |
download | rockbox-c9a028cc183d638c16ca9a8858b783b1830be16f.tar.gz rockbox-c9a028cc183d638c16ca9a8858b783b1830be16f.zip |
Introduce hwpatcher, a tool to patch binaries
This tool is a scriptable (lua) tool to patch binaries, it supports:
- raw binary
- ELF
- SB(v1/v2)
It also contains some basic routines to parse and generate useful arm/thumb code
like jump or register load/store. This is very useful to take a firmware and
patch an interrupt vector or some code to jump to an extra payload added to
the binary. Examples are provided for several STMP based target which the payload
is expected to be hwstub, and also for the Sansa View. A typical patcher usually
requires three elements:
- the lua patcher itself
- the payload (hwstub for example)
- (optional) a small stub either to jump properly to the payload or determine
under which circumstance to do the jump (hold a key for example)
Change-Id: I6d36020a3bc9e636615ac8221b7591ade5f251e3
Diffstat (limited to 'utils/hwpatcher/fuzep_rb.lua')
-rw-r--r-- | utils/hwpatcher/fuzep_rb.lua | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/utils/hwpatcher/fuzep_rb.lua b/utils/hwpatcher/fuzep_rb.lua new file mode 100644 index 0000000000..f47a4983fa --- /dev/null +++ b/utils/hwpatcher/fuzep_rb.lua | |||
@@ -0,0 +1,38 @@ | |||
1 | --[[ | ||
2 | Fuze+ RB hacking | ||
3 | required argument (in order): | ||
4 | - path to firmware | ||
5 | - path to output firmware | ||
6 | - path to blob | ||
7 | ]]-- | ||
8 | |||
9 | if #arg < 3 then | ||
10 | error("not enough argument to fuzep patcher") | ||
11 | end | ||
12 | |||
13 | local fw = hwp.load_file(arg[1]) | ||
14 | local irq_addr_pool = hwp.make_addr(0x38) | ||
15 | local proxy_addr = arm.to_arm(hwp.make_addr(0x60115ba4)) | ||
16 | -- read old IRQ address pool | ||
17 | local old_irq_addr = hwp.make_addr(hwp.read32(fw, irq_addr_pool)) | ||
18 | print(string.format("Old IRQ address: %s", old_irq_addr)) | ||
19 | -- modify it | ||
20 | hwp.write32(fw, irq_addr_pool, proxy_addr.addr) | ||
21 | print(string.format("New IRQ address: %s", proxy_addr)) | ||
22 | -- in proxy, save registers | ||
23 | arm.write_save_regs(fw, proxy_addr) | ||
24 | proxy_addr = hwp.inc_addr(proxy_addr, 4) | ||
25 | -- do some work | ||
26 | local blob = hwp.load_bin_file(arg[3]) | ||
27 | local blob_info = hwp.section_info(blob, "") | ||
28 | local blob_data = hwp.read(blob, hwp.make_addr(blob_info.addr, ""), blob_info.size) | ||
29 | hwp.write(fw, proxy_addr, blob_data) | ||
30 | proxy_addr = hwp.inc_addr(proxy_addr, blob_info.size) | ||
31 | -- restore registers | ||
32 | arm.write_restore_regs(fw, proxy_addr) | ||
33 | proxy_addr = hwp.inc_addr(proxy_addr, 4) | ||
34 | -- branch to old code | ||
35 | local branch_to_old = arm.make_branch(old_irq_addr, false) | ||
36 | arm.write_branch(fw, proxy_addr, branch_to_old) | ||
37 | -- save | ||
38 | hwp.save_file(fw, arg[2]) \ No newline at end of file | ||