summaryrefslogtreecommitdiffstats
path: root/oncology/dpfhack_display/reverse/dump.py
diff options
context:
space:
mode:
Diffstat (limited to 'oncology/dpfhack_display/reverse/dump.py')
-rw-r--r--oncology/dpfhack_display/reverse/dump.py470
1 files changed, 0 insertions, 470 deletions
diff --git a/oncology/dpfhack_display/reverse/dump.py b/oncology/dpfhack_display/reverse/dump.py
deleted file mode 100644
index cbbc563b..00000000
--- a/oncology/dpfhack_display/reverse/dump.py
+++ /dev/null
@@ -1,470 +0,0 @@
-# DPF dump splitter
-# <hackfin@section5.ch>
-#
-# Takes a binary dump of the DPF and splits it into the banked modules
-# Usage:
-# 1. First, simply run this script after having dumped your entire DPF
-# into full_image.bin. It will generate a lot of dump* files.
-# 2. Then analyze the addresses in dump00.asm. The code is loading more
-# common code segments from other addresses. To extract this code,
-# enhance or create a record in g_dpfs. Later on, we'll add some
-# firmware version detection...
-#
-
-import os
-import sys
-import struct
-# import scantool
-
-IMGLEN1 = 128 * 128 / 8
-IMGLEN16 = 128 * 128 * 2
-
-# menu table in code memory:
-table_addr = 0x1600
-
-g_dpfs = {
- 'default' : [
- [], [], [], [],
- ],
- 'silver2' : [
- [
- (0x2f0, 0x1934, 0x19f2),
- (0x3ae, 0x1003, 0x1270),
- (0x6a0, 0x1280, 0x12bc),
- ],
- [],
- [],
- [],
- ],
- 'black' : [
- [
- (0x2e0, 0x1934, 0x19f2),
- (0x39e, 0x1003, 0x1270),
- (0x682, 0x1280, 0x12d0),
- ],
- [],
- [],
- [],
- ],
- 'white' : [
- [
- (0x2f0, 0x1934, 0x19f2),
- (0x3ae, 0x1003, 0x1270),
- (0x69c, 0x1280, 0x12d0),
- (0x2fec, 0x1800, 0x189d),
- ],
- [],
- [],
- [],
- ],
- 'visualland' : [
- [
- (0x2c0, 0x1934, 0x19f2),
- (0x37e, 0x1003, 0x1270),
- (0x662, 0x1280, 0x12d0),
- ],
- [],
- [],
- [],
- ],
- 'blue' : [
- [ # special code segments: fileoffset, start, end
- (0x2c0, 0x1934, 0x19f2),
- (0x37e, 0x1003, 0x1270),
- (0x662, 0x1280, 0x12d8),
- (0x3474, 0x1800, 0x189d),
-
- # Dynamic jump table:
- (0x0e54, 0xce7 + 0x800, 0xce7 + 0x800 + 0x2c2),
- ],
- [ # images: name, fileoffset, rel_start, rel_end
- ("img0", 0x55bbb, 0x0, IMGLEN16),
- ("img1", 0x4eb89, 0x0, IMGLEN1),
- ("usb_conn", 0x4ec89, 0x0, 0x80 * 0x48),
- ("menu0", 0x4e289, 0x0, IMGLEN1),
- ("menu1", 0x4e389, 0x0, IMGLEN1),
- ("menu2", 0x4ee89, 0x0, IMGLEN1),
- ("menu3", 0x4e489, 0x0, IMGLEN1),
- ("menu4", 0x4e589, 0x0, IMGLEN1),
- ("menu5", 0x4e789, 0x0, IMGLEN1),
- ("menu7", 0x4e989, 0x0, IMGLEN1),
- ("menu8", 0x4ea89, 0x0, IMGLEN1),
- ("menu9", 0x4e889, 0x0, IMGLEN1),
- ("mainmenu", 0x4c7f9, 0x0, IMGLEN1),
- ("mainmenu-ch", 0x4f589, 0x0, IMGLEN1),
- ("jpgx", 0x4b744, 0x0, IMGLEN16), # mod13
- ("menu0", 0x4daf9, 0x0, IMGLEN1),
- ],
- [ # data buffers: fileoffset, start, end
- (0x1b02 + 4, table_addr, table_addr + 0x28a), # Menu bitmap indices?
- (0x1874 + 4, table_addr, table_addr + 0x28a), # Menu bitmap indices?
- (0x53557, 0xfd7, 0xfd7 + 64),
- ],
- [ # Dynamic applet load: reloc, fileoffset, , size
- (0x14e7, 0x0e54, 15 )
- ]
- ],
- 'silver' : [
- [ # special code segments: fileoffset, start, end
- (0x2c0, 0x1934, 0x19f2),
- (0x37e, 0x1003, 0x1270),
- (0x662, 0x1280, 0x12d8),
- ],
- [],
- [],
- [],
- ],
- 'pink' : [
- [ # code segments:
- (0x2f0, 0x1934, 0x19f2),
- (0x3ae, 0x1003, 0x1270),
- (0x69c, 0x1280, 0x12d1),
- (0x2fc0, 0x1800, 0x189d), # USB main loop, -> mod18_145b
-
- (0x0e88, 0xce7 + 0x800, 0xce7 + 0x800 + 0x2c2),
- ],
- [ # images
- ("img0", 0x5320b, 0x0, IMGLEN16),
- ("img1", 0x54f4b, 0x0, IMGLEN1),
- ("lowpower", 0x51a3b, 0x0, IMGLEN1),
- ("img2", 0x4c244, 0x0, IMGLEN16),
- ("title", 0x4f03b, 0x0, IMGLEN1),
- ("title", 0x4f13b, 0x0, IMGLEN1),
- ("title", 0x4f23b, 0x0, IMGLEN1),
- ],
- # data:
- [],
- # dynamic:
- [
- (0x14e7, 0x0e88, 15 )
- ]
- ],
- 'focal' : [
- [ # code segments:
- (0x2e0, 0x1934, 0x19f2),
- (0x39e, 0x1003, 0x1279),
- (0x682, 0x1280, 0x12f3),
- (0x3056, 0x1800, 0x189d), # USB main loop, -> mod17_145b
-
- (0x0e88, 0xce7 + 0x800, 0xce7 + 0x800 + 0x2c2),
- ],
- [ # images
- ("img0", 0x5320b, 0x0, IMGLEN16),
- ],
- # data:
- [],
- # dynamic:
- [
- (0x14e7, 0x0e88, 15 )
- ]
- ],
- 'pearl' : [
- [ # code segments:
- (0x2e0, 0x1934, 0x19f2),
- (0x39e, 0x1003, 0x1279),
- (0x682, 0x1280, 0x12f3),
- (0x3056, 0x1800, 0x189d), # USB main loop, -> mod17_145b
-
- (0x0e88, 0xce7 + 0x800, 0xce7 + 0x800 + 0x2c2),
- ],
- [ # images
- ("img0", 0x5320b, 0x0, IMGLEN16),
- ],
- # data:
- [],
- # dynamic:
- [
- (0x14e7, 0x0e88, 15 )
- ]
- ],
- 'micca' : [
- [ # code segments:
- (0x2e0, 0x1934, 0x19f2),
- (0x39e, 0x1003, 0x1279),
- (0x682, 0x1280, 0x12f3),
- (0x3056, 0x1800, 0x189d), # USB main loop, -> mod17_145b
-
- (0x0e88, 0xce7 + 0x800, 0xce7 + 0x800 + 0x2c2),
- ],
- [ # images
- ("img0", 0x5320b, 0x0, IMGLEN16),
- ],
- # data:
- [],
- # dynamic:
- [
- (0x14e7, 0x0e88, 15 )
- ]
- ],
-
-}
-
-RET = chr(0x22)
-LJMP = chr(0x02)
-LCALL = chr(0x12)
-
-bswap = lambda x: ( (x >> 8) & 0xff ) | ((x << 8) & 0xff00)
-
-class ProcEntry:
- format = "<HHI"
-
- def __init__(self):
- self.start = 0
- self.end = 0
- self.offset = 0
- self.size = struct.calcsize(self.format)
-
- def fromBuffer(self, b):
- start, end, self.offset, = struct.unpack(self.format, b)
- self.start = bswap(start)
- self.end = bswap(end)
-
-
- def __repr__(self):
- return "< %04x, %04x, %08x >" % (self.start, self.end, self.offset)
-
-def extract_code(data, fname):
- out = data
- outf = open(fname, "w")
- outf.write(out)
- outf.close()
-
-def write_ctl(name, offset, fileoffset, size = 0):
- outf = open(name, "w")
- outf.write("; control file -- autogenerated\n")
- outf.write("; file offset: %08x\n" % fileoffset)
- outf.write("# %04x\n" % offset)
- outf.write("# %04x dump file offset: %08x\n" % (offset, fileoffset))
- outf.write("o %04x\n" % offset)
- if size:
- outf.write("b %04x-%04x\n" % (offset, offset + size - 1))
- outf.close()
-
-def exists(file):
- try:
- a = os.stat(file)
- return 1
- except:
- return 0
-
-def generate_ctl(which, prefix, record, entries):
- fname = "%s%02d.in" % (prefix, which)
- if exists(fname):
- print "%s exists, not creating" % fname
- return
-
- outf = open(fname, "w")
- outf.write("; control file for %s%d.bin -- autogenerated\n" % (prefix, which))
- outf.write("; file offset: %08x\n" % int(record.offset))
- offset = 0x800 + record.start
- outf.write("# %04x ----- SNIP : mod%d -----\n" % (offset, which))
- outf.write("# %04x\n" % offset)
- outf.write("# %04x dump file offset: %08x\n" % (offset, int(record.offset)))
- outf.write("o %04x\n" % offset)
- for i in entries:
- outf.write("%s\n" % i)
- outf.close()
-
-def build_tab(data, start, end):
- l = []
-
- offset = start
-
- i = 0
-
- while 1:
- e = ProcEntry()
- d = data[offset : offset + e.size]
- e.fromBuffer(d)
- if d == "-EndTbl-" or offset > end:
- break
- offset += e.size
- l.append(e)
- i += 1
-
- return l
-
-val = lambda x: ord(x)
-
-# Some codes to scan for:
-
-scan_banksw = [
- 0x74, val, 0x90, val, val, val, 0x19, val
-]
-
-scan_loadcode = [
- 0x90, val, val, 0x7b, val, 0x7c, val, 0x7d, val, 0x7e, val , 0x7f, val
-]
-
-
-# Stolen from scantool:
-class Scanner:
- def __init__(self, data, seq):
- self.data = data
- self.args = []
- self.scansequence = seq
-
- def scan(self, context, cb):
- p = 0
- n = 0
- while p < len(self.data):
- if type(self.scansequence[n]) == type(val):
- args.append(val(data[p]))
- n += 1
- elif chr(self.scansequence[n]) == data[p]:
- n += 1
- else:
- n = 0
- args = []
-
- if n == len(self.scansequence):
- cb(context, args, p)
- n = 0
- args = []
-
- p += 1
-
-def make_symentry(context, args, p):
- e, offset = context
- if args[3] in [0x12, 0x02]:
- e.append("x %04x mod%d_%04x" % (offset + p - 4, args[0] + 1, (args[1] << 8) + args[2]))
-
-
-# TODO: Use scantool stuff
-def analyze(data, offset):
- e = []
-
- scanner = Scanner(data, scan_loadcode)
- scanner.scan((e, offset), make_symentry)
-
- return e
-
-def make_record(context, args, p):
- e, rec = context
- r = args[0] << 8 | args[1]
- e.append("s %04x code_%04x" % (r, r + 0x800))
- r = args[2] << 8 | args[3]
- s = (args[4] << 16) | (args[5] << 8) | args[6]
- e.append("# %04x load code from %06x to xmem:%04x" % (rec.start + 0x800 + p - 9, s, r))
-
-
-def analyze_bootblock(data):
- rec = ProcEntry()
-
- e = []
- s = struct.unpack(">H", data[5:7])[0] # start code in flash
- reloc = struct.unpack(">H", data[2:4])[0] # relocation
-
- print hex(reloc), hex(s)
-
- rec.start = reloc - s - 0x800
- rec.offset = s
-
- offset = reloc - s
-
- e.append("b %04x-%04x" % (offset, (reloc - 1)))
- e.append("l %04x start" % reloc)
- e.append("l %04x jumptable" % (offset + 0x88))
-
- # Just copy the scan hack -- no more scantool
- scanner = Scanner(data, scan_loadcode)
- scanner.scan((e, rec), make_record)
-
- return rec, e
-
-
-def write_rawimage(d, fname):
- outf = open(fname, "wb")
- outf.write(d)
- outf.close()
-
-try:
- # Choose here which DPF to dump:
- dpf = g_dpfs[sys.argv[1]]
- f = open(sys.argv[2], "r")
-except (KeyError, IndexError):
- print "Usage: %s <frameid>" % sys.argv[0]
- print "where frameid is one of:"
- for i in g_dpfs.keys():
- print " ", i
- print "No DPF specified given, running basic dump"
- dpf = g_dpfs['default']
- f = open("full_image.bin", "r")
-
-
-data = f.read()
-f.close()
-
-
-for i in dpf[0]:
- o, start, end = i
- end += 1
- d = data[o:o + end - start]
- extract_code(d, "code_%04x.bin" % start)
- write_ctl("code_%04x.ctl" % start, start, o)
-
-for i in dpf[1]:
- name, o, start, end = i
- end += 1
- d = data[o:o + end - start]
- write_rawimage(d, "img_%s-%06x.raw" % (name, o))
-
-for i in dpf[2]:
- o, start, end = i
- end += 1
- d = data[o:o + end - start]
- extract_code(d, "data_%04x.bin" % o)
- write_ctl("data_%04x.ctl" % o, start, o, end - start)
-
-for i in dpf[3]:
- codeoffs, foffs, n = i
- c0 = codeoffs
- c1 = codeoffs - foffs
- labels = {}
- for j in range(n):
- sz = [0,0]
- offs = [0, 0]
- o = foffs + j * 8
- d = data[o:o + 8]
-
- sz[0] = ord(d[0]) + (ord(d[1]) << 8)
- offs[0] = foffs + ord(d[2]) + (ord(d[3]) << 8)
- sz[1] = ord(d[4]) + (ord(d[5]) << 8)
- offs[1] = foffs + ord(d[6]) + (ord(d[7]) << 8)
-
- p = (c0 + j * 8 + 7, offs[0], sz[0], offs[1], sz[1])
- print "! %04x dyn_%04x[%d], dyn_%04x[%d]" % p
- labels[c1 + offs[0]] = "dyn_%04x" % offs[0]
- labels[c1 + offs[1]] = "dyn_%04x" % offs[1]
- for j in labels.keys():
- print "l %04x %s" % (j, labels[j])
-
-format = ">HHBH"
-s = struct.unpack(format, data[:7])
-imem_loadaddr, code_startaddr, dummy, startcode = s
-
-l = build_tab(data, 0x88, startcode)
-
-print 80 * "-"
-
-start = l[0].offset
-d = data[0:start]
-extract_code(d, "dump00.bin")
-rec, entries = analyze_bootblock(d)
-generate_ctl(0, "dump", rec, entries)
-
-index = 1
-for i in l:
- size = i.end - i.start
- d = data[i.offset: i.offset + size]
- print "[dump%d] %04x %04x %08x (%d)" % (index, i.start, i.end, i.offset, size)
- extract_code(d, "dump%02d.bin" % index)
- entries = analyze(d, i.start + 0x800)
- generate_ctl(index, "dump", i, entries)
- index += 1
-
-
-# No scantool here.
-# scantool.guess(scantool.MC8052, data, "dump")
-
-