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