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