1*4d495c6eSApple OSS Distributions#!/usr/bin/env python 2*4d495c6eSApple OSS Distributionsfrom subprocess import Popen, PIPE, call 3*4d495c6eSApple OSS Distributionsimport re 4*4d495c6eSApple OSS Distributionsimport sys 5*4d495c6eSApple OSS Distributionsimport os 6*4d495c6eSApple OSS Distributions 7*4d495c6eSApple OSS DistributionsSLIDE = 0 8*4d495c6eSApple OSS Distributions 9*4d495c6eSApple OSS DistributionsNM_FORMAT = "([0-9a-f]+) ([UuAaTtDdBbCcSsIi]) (.*)" 10*4d495c6eSApple OSS Distributions 11*4d495c6eSApple OSS Distributionsnm_re = re.compile(NM_FORMAT) 12*4d495c6eSApple OSS Distributions 13*4d495c6eSApple OSS Distributionsdef parse_nm_output(str): 14*4d495c6eSApple OSS Distributions "returns (start, type, name)" 15*4d495c6eSApple OSS Distributions m = nm_re.match(str) 16*4d495c6eSApple OSS Distributions if m: 17*4d495c6eSApple OSS Distributions start = int(m.group(1), 16) 18*4d495c6eSApple OSS Distributions return (start, m.group(2), m.group(3)) 19*4d495c6eSApple OSS Distributions else: 20*4d495c6eSApple OSS Distributions return None 21*4d495c6eSApple OSS Distributions 22*4d495c6eSApple OSS Distributionsdef nm(file): 23*4d495c6eSApple OSS Distributions cmd = "nm %s" % file 24*4d495c6eSApple OSS Distributions p = Popen(cmd, shell=True, stdout=PIPE) 25*4d495c6eSApple OSS Distributions return p.stdout 26*4d495c6eSApple OSS Distributions 27*4d495c6eSApple OSS Distributionsclass SymbolLookup: 28*4d495c6eSApple OSS Distributions def __init__(self, file, min_width=16): 29*4d495c6eSApple OSS Distributions self.min_width = min_width 30*4d495c6eSApple OSS Distributions self.symbols = [parse_nm_output(l) for l in nm(file)] 31*4d495c6eSApple OSS Distributions self.symbols.sort(key=lambda x: x[0]) 32*4d495c6eSApple OSS Distributions 33*4d495c6eSApple OSS Distributions def padded(self, str): 34*4d495c6eSApple OSS Distributions return ("%%%ds" % self.min_width) % str 35*4d495c6eSApple OSS Distributions 36*4d495c6eSApple OSS Distributions def __call__(self, saddr): 37*4d495c6eSApple OSS Distributions addr = int(saddr.group(0), 16) 38*4d495c6eSApple OSS Distributions last = (0, ' ', '<start of file>') 39*4d495c6eSApple OSS Distributions if( addr > SLIDE ): 40*4d495c6eSApple OSS Distributions addr -= SLIDE 41*4d495c6eSApple OSS Distributions # stupid linear search... feel free to improve 42*4d495c6eSApple OSS Distributions for s in self.symbols: 43*4d495c6eSApple OSS Distributions if s[0] == addr: 44*4d495c6eSApple OSS Distributions return self.padded(s[2]) 45*4d495c6eSApple OSS Distributions elif s[0] > addr: 46*4d495c6eSApple OSS Distributions if last[2] == "_last_kernel_symbol": 47*4d495c6eSApple OSS Distributions return saddr.group(0) 48*4d495c6eSApple OSS Distributions return self.padded("<%s>+%x" % (last[2], addr - last[0])) 49*4d495c6eSApple OSS Distributions else: 50*4d495c6eSApple OSS Distributions last = s 51*4d495c6eSApple OSS Distributions if last[2] == "_last_kernel_symbol": 52*4d495c6eSApple OSS Distributions return saddr.group(0) 53*4d495c6eSApple OSS Distributions return self.padded("<%s>+%x" % (last[2], addr - last[0])) 54*4d495c6eSApple OSS Distributions 55*4d495c6eSApple OSS Distributionsdef symbolify(objfile, input, *args, **kargs): 56*4d495c6eSApple OSS Distributions replacer = SymbolLookup(objfile, *args, **kargs) 57*4d495c6eSApple OSS Distributions for l in input: 58*4d495c6eSApple OSS Distributions print re.sub("(0x)?[0-9a-f]{6,16}", replacer, l), 59*4d495c6eSApple OSS Distributions 60*4d495c6eSApple OSS Distributions 61*4d495c6eSApple OSS Distributionsdef usage(): 62*4d495c6eSApple OSS Distributions 63*4d495c6eSApple OSS Distributions print "usage: %s [filename] [slide]" % sys.argv[0] 64*4d495c6eSApple OSS Distributions print "\tor speficy a filename in your SYMBOLIFY_KERNEL environment variable" 65*4d495c6eSApple OSS Distributions 66*4d495c6eSApple OSS Distributions # die now 67*4d495c6eSApple OSS Distributions sys.exit(1) 68*4d495c6eSApple OSS Distributions 69*4d495c6eSApple OSS DistributionsKERNEL_FILE = None 70*4d495c6eSApple OSS Distributions 71*4d495c6eSApple OSS Distributionsif( len(sys.argv) > 3 ): 72*4d495c6eSApple OSS Distributions usage() 73*4d495c6eSApple OSS Distributions 74*4d495c6eSApple OSS Distributionsif( len(sys.argv) == 3 ): 75*4d495c6eSApple OSS Distributions SLIDE = int(sys.argv[2], 16) 76*4d495c6eSApple OSS Distributions 77*4d495c6eSApple OSS Distributionsif( len(sys.argv) >= 2 ): 78*4d495c6eSApple OSS Distributions KERNEL_FILE = sys.argv[1] 79*4d495c6eSApple OSS Distributions 80*4d495c6eSApple OSS Distributionsif( KERNEL_FILE is None ): 81*4d495c6eSApple OSS Distributions KERNEL_FILE = os.environ.get("SYMBOLIFY_KERNEL") 82*4d495c6eSApple OSS Distributions 83*4d495c6eSApple OSS Distributionsif( KERNEL_FILE is None ): 84*4d495c6eSApple OSS Distributions usage() 85*4d495c6eSApple OSS Distributions 86*4d495c6eSApple OSS Distributionsprint "using kernel file '%s', slide 0x%x" % (KERNEL_FILE, SLIDE) 87*4d495c6eSApple OSS Distributions 88*4d495c6eSApple OSS Distributionssymbolify(KERNEL_FILE, sys.stdin, min_width=40) 89*4d495c6eSApple OSS Distributions 90