| 1 | #!/usr/bin/env python
|
|---|
| 2 |
|
|---|
| 3 | import sys
|
|---|
| 4 | import struct
|
|---|
| 5 | import re
|
|---|
| 6 |
|
|---|
| 7 | MAXSTRING=63
|
|---|
| 8 | symtabfmt = "<Q%ds" % (MAXSTRING+1)
|
|---|
| 9 |
|
|---|
| 10 |
|
|---|
| 11 | funcline = re.compile(r'([0-9a-f]+)\s+[lg]\s+.\s+\.text\s+([0-9a-f]+)\s+(.*)$')
|
|---|
| 12 | bssline = re.compile(r'([0-9a-f]+)\s+[lg]\s+[a-zA-Z]\s+\.bss\s+([0-9a-f]+)\s+(.*)$')
|
|---|
| 13 | dataline = re.compile(r'([0-9a-f]+)\s+[lg]\s+[a-zA-Z]\s+\.data\s+([0-9a-f]+)\s+(.*)$')
|
|---|
| 14 | fileexp = re.compile(r'([^\s]+):\s+file format')
|
|---|
| 15 | def read_obdump(inp):
|
|---|
| 16 | funcs = {}
|
|---|
| 17 | data = {}
|
|---|
| 18 | bss ={}
|
|---|
| 19 | fname = ''
|
|---|
| 20 | for line in inp:
|
|---|
| 21 | line = line.strip()
|
|---|
| 22 | res = funcline.match(line)
|
|---|
| 23 | if res:
|
|---|
| 24 | funcs.setdefault(fname,[]).append((int(res.group(1),16),
|
|---|
| 25 | res.group(3)))
|
|---|
| 26 | continue
|
|---|
| 27 | res = bssline.match(line)
|
|---|
| 28 | if res:
|
|---|
| 29 | start = int(res.group(1),16)
|
|---|
| 30 | end = int(res.group(2),16)
|
|---|
| 31 | if end:
|
|---|
| 32 | bss.setdefault(fname,[]).append((start,res.group(3)))
|
|---|
| 33 | res = dataline.match(line)
|
|---|
| 34 | if res:
|
|---|
| 35 | start = int(res.group(1),16)
|
|---|
| 36 | end = int(res.group(2),16)
|
|---|
| 37 | if end:
|
|---|
| 38 | data.setdefault(fname,[]).append((start,res.group(3)))
|
|---|
| 39 | res = fileexp.match(line)
|
|---|
| 40 | if res:
|
|---|
| 41 | fname = res.group(1)
|
|---|
| 42 | continue
|
|---|
| 43 |
|
|---|
| 44 | return {
|
|---|
| 45 | 'text' : funcs,
|
|---|
| 46 | 'bss' : bss,
|
|---|
| 47 | 'data' : data
|
|---|
| 48 | }
|
|---|
| 49 |
|
|---|
| 50 | startfile = re.compile(r'\.(text|bss|data)\s+(0x[0-9a-f]+)\s+0x[0-9a-f]+\s+(.*)$')
|
|---|
| 51 | def generate(kmapf, obmapf, out):
|
|---|
| 52 | obdump = read_obdump(obmapf)
|
|---|
| 53 |
|
|---|
| 54 | def sorter(x,y):
|
|---|
| 55 | return cmp(x[0],y[0])
|
|---|
| 56 |
|
|---|
| 57 | for line in kmapf:
|
|---|
| 58 | line = line.strip()
|
|---|
| 59 | res = startfile.match(line)
|
|---|
| 60 |
|
|---|
| 61 | if res and obdump[res.group(1)].has_key(res.group(3)):
|
|---|
| 62 | offset = int(res.group(2),16)
|
|---|
| 63 | fname = res.group(3)
|
|---|
| 64 | symbols = obdump[res.group(1)][fname]
|
|---|
| 65 | symbols.sort(sorter)
|
|---|
| 66 | for addr,symbol in symbols:
|
|---|
| 67 | value = fname + ':' + symbol
|
|---|
| 68 | data = struct.pack(symtabfmt,addr+offset,value[:MAXSTRING])
|
|---|
| 69 | out.write(data)
|
|---|
| 70 |
|
|---|
| 71 | out.write(struct.pack(symtabfmt,0,''))
|
|---|
| 72 |
|
|---|
| 73 | def main():
|
|---|
| 74 | if len(sys.argv) != 4:
|
|---|
| 75 | print "Usage: %s <kernel.map> <nm dump> <output.bin>" % sys.argv[0]
|
|---|
| 76 | sys.exit(1)
|
|---|
| 77 |
|
|---|
| 78 | kmapf = open(sys.argv[1],'r')
|
|---|
| 79 | obmapf = open(sys.argv[2],'r')
|
|---|
| 80 | out = open(sys.argv[3],'w')
|
|---|
| 81 | generate(kmapf,obmapf,out)
|
|---|
| 82 | kmapf.close()
|
|---|
| 83 | obmapf.close()
|
|---|
| 84 | out.close()
|
|---|
| 85 |
|
|---|
| 86 | if __name__ == '__main__':
|
|---|
| 87 | main()
|
|---|