X-Git-Url: https://jxself.org/git/?a=blobdiff_plain;f=debug%2Fb43-fwdump;h=4308d60704fb0828c02ba28d6628e6df4601db7c;hb=2636a4a663b8115dc4c41bf3be7ee816cf6f8b15;hp=d87e378e2a18c787999afd1e3d1402a5c9144bf7;hpb=2af8ca43e43b70b16f645efed72766371505b274;p=b43-tools.git diff --git a/debug/b43-fwdump b/debug/b43-fwdump index d87e378..4308d60 100755 --- a/debug/b43-fwdump +++ b/debug/b43-fwdump @@ -1,5 +1,5 @@ #!/usr/bin/env python -# +""" # b43 firmware state dumper # # Copyright (C) 2008 Michael Buesch @@ -15,26 +15,167 @@ # # You should have received a copy of the GNU General Public License # along with this program. If not, see . -# +""" +import getopt from libb43 import * +from sys import stdout +from tempfile import * -try: - phy = sys.argv[1] -except IndexError: - phy = None +def usage(): + print "b43 firmware state dumper" + print "" + print "Copyright (C) 2008 Michael Buesch " + print "Licensed under the GNU/GPL version 3" + print "" + print "Usage: b43-fwdump [OPTIONS]" + print "" + print "-h|--help Print this help text" + print "-p|--phy PHY The PHY to use. For example phy0" + print "-b|--binary BIN The firmware binary. This is required for" + print " an instruction dump." + print "-d|--dasmopt OPT Additional options to the disassembler." + print "-s|--shm Also dump SHM." + return +def parseArgs(): + global phy + global binary + global dasmopt + global dumpShm + + phy = None # Autodetect + binary = None # No instruction dump + dasmopt = "" + dumpShm = False + + try: + (opts, args) = getopt.getopt(sys.argv[1:], + "hp:b:d:s", + [ "help", "phy=", "binary=", "dasmopt=", "shm" ]) + except getopt.GetoptError: + usage() + sys.exit(1) + + for (o, v) in opts: + if o in ("-h", "--help"): + usage() + sys.exit(0) + if o in ("-p", "--phy"): + phy = v + if o in ("-b", "--binary"): + binary = v + if o in ("-d", "--dasmopt"): + dasmopt = v + if o in ("-s", "--shm"): + dumpShm = True + return + + +def dump_regs(prefix, regs): + if len(regs) >= 10: + template = "%s%02u: %04X " + else: + template = "%s%01u: %04X " + for i in range(0, len(regs)): + if i != 0 and i % 4 == 0: + stdout.write("\n") + stdout.write(template % (prefix, i, regs[i])) + stdout.write("\n") + return + +def disassembleText(text): + input = NamedTemporaryFile() + output = NamedTemporaryFile() + + input.write(text) + input.flush() + os.system("b43-dasm %s %s %s --paddr" % (input.name, dasmopt, output.name)) + + return output.read() + +def makeShortDump(dasm, pc): + dasm = dasm.splitlines() + i = 0 + for line in dasm: + if "/* %03X */" % pc in line: + break + i += 1 + if i >= len(dasm): + return "" + ret = "" + pos = max(i - 8, 0) + end = min(i + 8, len(dasm) - 1) + while pos != end: + ret += dasm[pos] + if "/* %03X */" % pc in dasm[pos]: + ret += "\t\t<<<<<<<<<<<" + ret += "\n" + pos += 1 + return ret + +def toAscii(char): + if char >= 32 and char <= 126: + return chr(char) + return "." + +def main(): + parseArgs() -try: b43 = B43(phy) - regs = b43.ucodeRegsRead() - shm = b43.shmSharedRead() + # Fetch the hardware information + b43.ucodeStop() + gpr = b43.getGprs() + lr = b43.getLinkRegs() + off = b43.getOffsetRegs() + if dumpShm: + shm = b43.shmSharedRead() dbg = b43.getPsmDebug() + psmcond = b43.getPsmConditions() + b43.ucodeStart() - print "PC is at 0x%03X" % dbg.getPc() -#TODO + print "--- B43 microcode state dump ---" + print "PC: %03X PSM-COND: %04X" % (dbg.getPc(), psmcond) + print "Link registers:" + dump_regs("lr", lr) + print "Offset registers:" + dump_regs("off", off) + print "General purpose registers:" + dump_regs("r", gpr) + print "Code:" + if binary: + try: + bintext = file(binary, "r").read() + except IOError, e: + print "Could not read binary file %s: %s" % (binary, e.strerror) + sys.exit(1) + dasm = disassembleText(bintext) + print makeShortDump(dasm, dbg.getPc()) + else: + print "" + + if dumpShm: + print "Shared memory:" + ascii = "" + for i in range(0, len(shm)): + if i % 16 == 0 and i != 0: + stdout.write(" " + ascii + "\n") + ascii = "" + if i % 16 == 0: + stdout.write("0x%04X: " % i) + c = ord(shm[i]) + stdout.write("%02X" % c) + if (i % 2 != 0): + stdout.write(" ") + ascii += toAscii(c) + stdout.write(" " + ascii + "\n") + return + + +try: + main() except B43Exception: sys.exit(1)