mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
Remove scripts used by TEST=dbg from here. They now live inside llvm test suite.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@128425 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
d560a80925
commit
e4f3ca4a66
@ -1,182 +0,0 @@
|
||||
#!/usr/bin/python
|
||||
|
||||
#----------------------------------------------------------------------
|
||||
#
|
||||
# Be sure to add the python path that points to the LLDB shared library.
|
||||
# On MacOSX csh, tcsh:
|
||||
# setenv PYTHONPATH /Developer/Library/PrivateFrameworks/LLDB.framework/Resources/Python
|
||||
# On MacOSX sh, bash:
|
||||
# export PYTHONPATH=/Developer/Library/PrivateFrameworks/LLDB.framework/Resources/Python
|
||||
#
|
||||
# This script collect debugging information using LLDB. This script is
|
||||
# used by TEST=dbg in llvm testsuite to measure quality of debug info in
|
||||
# optimized builds.
|
||||
#
|
||||
# Usage:
|
||||
# export PYTHONPATH=...
|
||||
# ./CollectDebugInfUsingLLDB.py program bp_file out_file
|
||||
# program - Executable program with debug info.
|
||||
# bp_file - Simple text file listing breakpoints.
|
||||
# <absolute file name> <line number>
|
||||
# out_file - Output file where the debug info will be emitted.
|
||||
#----------------------------------------------------------------------
|
||||
|
||||
import lldb
|
||||
import os
|
||||
import sys
|
||||
import time
|
||||
|
||||
# AlreadyPrintedValues - A place to keep track of recursive values.
|
||||
AlreadyPrintedValues = {}
|
||||
|
||||
# ISAlreadyPrinted - Return true if value is already printed.
|
||||
def IsAlreadyPrinted(value_name):
|
||||
if AlreadyPrintedValues.get(value_name) is None:
|
||||
AlreadyPrintedValues[value_name] = 1
|
||||
return False
|
||||
return True
|
||||
|
||||
|
||||
# print_var_value - Print a variable's value.
|
||||
def print_var_value (v, file, frame):
|
||||
if v.IsValid() == False:
|
||||
return
|
||||
if IsAlreadyPrinted(v.GetName()):
|
||||
return
|
||||
total_children = v.GetNumChildren()
|
||||
if total_children > 0:
|
||||
c = 0
|
||||
while (c < total_children) :
|
||||
child = v.GetChildAtIndex(c)
|
||||
if child is None:
|
||||
file.write("None")
|
||||
else:
|
||||
if (child.GetName()) is None:
|
||||
file.write("None")
|
||||
else:
|
||||
file.write(child.GetName())
|
||||
file.write('=')
|
||||
print_var_value(child, file, frame)
|
||||
file.write(',')
|
||||
c = c + 1
|
||||
else:
|
||||
if v.GetValue(frame) is None:
|
||||
file.write("None")
|
||||
else:
|
||||
file.write(v.GetValue(frame))
|
||||
|
||||
# print_vars - Print variable values in output file.
|
||||
def print_vars (tag, vars, fname, line, file, frame, target, thread):
|
||||
# disable this thread.
|
||||
count = thread.GetStopReasonDataCount()
|
||||
bid = 0
|
||||
tid = 0
|
||||
for i in range(count):
|
||||
id = thread.GetStopReasonDataAtIndex(i)
|
||||
bp = target.FindBreakpointByID(id)
|
||||
if bp.IsValid():
|
||||
if bp.IsEnabled() == True:
|
||||
bid = bp.GetID()
|
||||
tid = bp.GetThreadID()
|
||||
bp.SetEnabled(False)
|
||||
else:
|
||||
bp_loc = bp.FindLocationByID(thread.GetStopReasonDataAtIndex(i+1))
|
||||
if bp_loc.IsValid():
|
||||
bid = bp_loc.GetBreakPoint().GetID()
|
||||
tid = bp_loc.ThreadGetID()
|
||||
bp_loc.SetEnabled(False);
|
||||
|
||||
for i in range(vars.GetSize()):
|
||||
v = vars.GetValueAtIndex(i)
|
||||
if v.GetName() is not None:
|
||||
file.write(tag)
|
||||
file.write(fname)
|
||||
file.write(':')
|
||||
file.write(str(line))
|
||||
file.write(' ')
|
||||
file.write(str(tid))
|
||||
file.write(':')
|
||||
file.write(str(bid))
|
||||
file.write(' ')
|
||||
file.write(v.GetName())
|
||||
file.write(' ')
|
||||
AlreadyPrintedValues.clear()
|
||||
print_var_value (v, file, frame)
|
||||
file.write('\n')
|
||||
|
||||
# set_breakpoints - set breakpoints as listed in input file.
|
||||
def set_breakpoints (target, breakpoint_filename, file):
|
||||
f = open(breakpoint_filename, "r")
|
||||
lines = f.readlines()
|
||||
for l in range(len(lines)):
|
||||
c = lines[l].split()
|
||||
# print "setting break point - ", c
|
||||
bp = target.BreakpointCreateByLocation (str(c[0]), int(c[1]))
|
||||
file.write("#Breakpoint ")
|
||||
file.write(str(c[0]))
|
||||
file.write(':')
|
||||
file.write(str(c[1]))
|
||||
file.write(' ')
|
||||
file.write(str(bp.GetThreadID()))
|
||||
file.write(':')
|
||||
file.write(str(bp.GetID()))
|
||||
file.write('\n')
|
||||
f.close()
|
||||
|
||||
# stopeed_at_breakpoint - Return True if process is stopeed at a
|
||||
# breakpoint.
|
||||
def stopped_at_breakpoint (process):
|
||||
if process.IsValid():
|
||||
state = process.GetState()
|
||||
if state == lldb.eStateStopped:
|
||||
thread = process.GetThreadAtIndex(0)
|
||||
if thread.IsValid():
|
||||
if thread.GetStopReason() == lldb.eStopReasonBreakpoint:
|
||||
return True
|
||||
return False
|
||||
|
||||
# Create a new debugger instance
|
||||
debugger = lldb.SBDebugger.Create()
|
||||
|
||||
# When we step or continue, don't return from the function until the process
|
||||
# stops. We do this by setting the async mode to false.
|
||||
debugger.SetAsync (False)
|
||||
|
||||
# Create a target from a file and arch
|
||||
##print "Creating a target for '%s'" % sys.argv[1]
|
||||
|
||||
target = debugger.CreateTargetWithFileAndArch (sys.argv[1], lldb.LLDB_ARCH_DEFAULT)
|
||||
|
||||
if target.IsValid():
|
||||
#print "target is valid"
|
||||
file=open(str(sys.argv[3]), 'w')
|
||||
set_breakpoints (target, sys.argv[2], file)
|
||||
|
||||
# Launch the process. Since we specified synchronous mode, we won't return
|
||||
# from this function until we hit the breakpoint at main
|
||||
sberror = lldb.SBError()
|
||||
process = target.Launch (None, None, os.ctermid(), os.ctermid(), os.ctermid(), None, 0, False, sberror)
|
||||
# Make sure the launch went ok
|
||||
while stopped_at_breakpoint(process):
|
||||
thread = process.GetThreadAtIndex (0)
|
||||
frame = thread.GetFrameAtIndex (0)
|
||||
if frame.IsValid():
|
||||
# #Print some simple frame info
|
||||
##print frame
|
||||
#print "frame is valid"
|
||||
function = frame.GetFunction()
|
||||
if function.IsValid():
|
||||
fname = function.GetMangledName()
|
||||
if fname is None:
|
||||
fname = function.GetName()
|
||||
#print "function : ",fname
|
||||
line = frame.GetLineEntry().GetLine()
|
||||
vars = frame.GetVariables(1,0,0,0)
|
||||
print_vars ("#Argument ", vars, fname, line, file, frame, target, thread)
|
||||
# vars = frame.GetVariables(0,1,0,0)
|
||||
# print_vars ("#Variables ", vars, fname, line, file, frame, target, thread)
|
||||
|
||||
process.Continue()
|
||||
file.close()
|
||||
|
||||
lldb.SBDebugger.Terminate()
|
@ -1,182 +0,0 @@
|
||||
#!/usr/bin/python
|
||||
|
||||
import os
|
||||
import sys
|
||||
|
||||
DBG_OUTPUT_FILE="Output/" + sys.argv[1] + ".dbg.out"
|
||||
OPT_DBG_OUTPUT_FILE="Output/" + sys.argv[1] + ".dbg.opt.out"
|
||||
LOG_FILE="Output/" + sys.argv[1] + ".log"
|
||||
NATIVE_DBG_OUTPUT_FILE="Output/" + sys.argv[1] + ".native.dbg.out"
|
||||
NATIVE_OPT_DBG_OUTPUT_FILE="Output/" + sys.argv[1] + ".native.dbg.opt.out"
|
||||
NATIVE_LOG_FILE="Output/" + sys.argv[1] + ".native.log"
|
||||
REPORT_FILE="Output/" + sys.argv[1] + ".dbg.report.html"
|
||||
|
||||
class BreakPoint:
|
||||
def __init__(self, bp_name):
|
||||
self.name = bp_name
|
||||
self.values = {}
|
||||
self.missing_args = []
|
||||
self.matching_args = []
|
||||
self.notmatching_args = []
|
||||
self.missing_bp = False
|
||||
|
||||
def setMissing(self):
|
||||
self.missing_bp = True
|
||||
|
||||
def getArgCount(self):
|
||||
return len(self.values)
|
||||
|
||||
def getMissingArgCount(self):
|
||||
if self.missing_bp == True:
|
||||
return len(self.values)
|
||||
return len(self.missing_args)
|
||||
|
||||
def getMatchingArgCount(self):
|
||||
if self.missing_bp == True:
|
||||
return 0
|
||||
return len(self.matching_args)
|
||||
|
||||
def getNotMatchingArgCount(self):
|
||||
if self.missing_bp == True:
|
||||
return 0
|
||||
return len(self.notmatching_args)
|
||||
|
||||
def recordArgument(self, arg_name, value):
|
||||
self.values[arg_name] = value
|
||||
|
||||
def __repr__(self):
|
||||
print self.name
|
||||
items = self.values.items()
|
||||
for i in range(len(items)):
|
||||
print items[i][0]," = ",items[i][1]
|
||||
return ''
|
||||
|
||||
def compare_args(self, other, file):
|
||||
myitems = self.values.items()
|
||||
otheritems = other.values.items()
|
||||
match = False
|
||||
for i in range(len(myitems)):
|
||||
if i >= len(otheritems):
|
||||
match = True
|
||||
self.missing_args.append(myitems[i][0])
|
||||
elif cmp(myitems[i][1], otheritems[i][1]):
|
||||
match = True
|
||||
self.notmatching_args.append(myitems[i][0])
|
||||
else:
|
||||
self.matching_args.append(myitems[i][0])
|
||||
|
||||
self.print_list(self.matching_args, " Matching arguments ", file)
|
||||
self.print_list(self.notmatching_args, " Not Matching arguments ", file)
|
||||
self.print_list(self.missing_args, " Missing arguments ", file)
|
||||
return match
|
||||
|
||||
def print_list(self, items, txt, pfile):
|
||||
if len(items) == 0:
|
||||
return
|
||||
pfile.write(self.name)
|
||||
pfile.write(txt)
|
||||
for e in items:
|
||||
pfile.write(e)
|
||||
pfile.write(' ')
|
||||
pfile.write('\n')
|
||||
|
||||
def read_input(filename, dict):
|
||||
f = open(filename, "r")
|
||||
lines = f.readlines()
|
||||
for l in range(len(lines)):
|
||||
c = lines[l].split()
|
||||
if c[0] == "#Breakpoint":
|
||||
bp = dict.get(c[2])
|
||||
if bp is None:
|
||||
bp = BreakPoint(c[1])
|
||||
dict[c[2]] = bp
|
||||
if c[0] == "#Argument":
|
||||
bp = dict.get(c[2])
|
||||
if bp is None:
|
||||
bp = BreakPoint(c[1])
|
||||
dict[c[2]] = bp
|
||||
bp.recordArgument(c[3], c[4])
|
||||
return
|
||||
|
||||
f1_breakpoints = {}
|
||||
read_input(DBG_OUTPUT_FILE, f1_breakpoints)
|
||||
f1_items = f1_breakpoints.items()
|
||||
|
||||
f2_breakpoints = {}
|
||||
read_input(OPT_DBG_OUTPUT_FILE, f2_breakpoints)
|
||||
f2_items = f2_breakpoints.items()
|
||||
|
||||
f = open(LOG_FILE, "w")
|
||||
f.write("Log output\n")
|
||||
for f2bp in range(len(f2_items)):
|
||||
id = f2_items[f2bp][0]
|
||||
bp = f2_items[f2bp][1]
|
||||
bp1 = f1_breakpoints.get(id)
|
||||
if bp1 is None:
|
||||
bp.setMissing()
|
||||
else:
|
||||
bp1.compare_args(bp,f)
|
||||
f.close()
|
||||
|
||||
nf1_breakpoints = {}
|
||||
read_input(NATIVE_DBG_OUTPUT_FILE, nf1_breakpoints)
|
||||
nf1_items = nf1_breakpoints.items()
|
||||
|
||||
nf2_breakpoints = {}
|
||||
read_input(NATIVE_OPT_DBG_OUTPUT_FILE, nf2_breakpoints)
|
||||
nf2_items = nf2_breakpoints.items()
|
||||
|
||||
nfl = open(NATIVE_LOG_FILE, "w")
|
||||
for nf2bp in range(len(nf2_items)):
|
||||
id = nf2_items[nf2bp][0]
|
||||
bp = nf2_items[nf2bp][1]
|
||||
bp1 = nf1_breakpoints.get(id)
|
||||
if bp1 is None:
|
||||
bp.setMissing()
|
||||
else:
|
||||
bp1.compare_args(bp,nfl)
|
||||
nfl.close()
|
||||
|
||||
f1_arg_count = 0
|
||||
f1_matching_arg_count = 0
|
||||
f1_notmatching_arg_count = 0
|
||||
f1_missing_arg_count = 0
|
||||
for idx in range(len(f1_items)):
|
||||
bp = f1_items[idx][1]
|
||||
f1_arg_count = f1_arg_count + bp.getArgCount()
|
||||
f1_matching_arg_count = f1_matching_arg_count + bp.getMatchingArgCount()
|
||||
f1_notmatching_arg_count = f1_notmatching_arg_count + bp.getNotMatchingArgCount()
|
||||
f1_missing_arg_count = f1_missing_arg_count + bp.getMissingArgCount()
|
||||
|
||||
nf1_arg_count = 0
|
||||
nf1_matching_arg_count = 0
|
||||
nf1_notmatching_arg_count = 0
|
||||
nf1_missing_arg_count = 0
|
||||
for idx in range(len(nf1_items)):
|
||||
bp = nf1_items[idx][1]
|
||||
nf1_arg_count = nf1_arg_count + bp.getArgCount()
|
||||
nf1_matching_arg_count = nf1_matching_arg_count + bp.getMatchingArgCount()
|
||||
nf1_notmatching_arg_count = nf1_notmatching_arg_count + bp.getNotMatchingArgCount()
|
||||
nf1_missing_arg_count = nf1_missing_arg_count + bp.getMissingArgCount()
|
||||
|
||||
rf = open(REPORT_FILE, "w")
|
||||
rf.write("<tr><td>")
|
||||
rf.write(str(sys.argv[1]))
|
||||
rf.write("</td><td>|</td><td>")
|
||||
rf.write(str(nf1_arg_count))
|
||||
rf.write("</td><td><b>")
|
||||
rf.write(str(nf1_matching_arg_count))
|
||||
rf.write("</b></td><td>")
|
||||
rf.write(str(nf1_notmatching_arg_count))
|
||||
rf.write("</td><td>")
|
||||
rf.write(str(nf1_missing_arg_count))
|
||||
rf.write("</td><td>|</td><td>")
|
||||
rf.write(str(f1_arg_count))
|
||||
rf.write("</td><td><b>")
|
||||
rf.write(str(f1_matching_arg_count))
|
||||
rf.write("</b></td><td>")
|
||||
rf.write(str(f1_notmatching_arg_count))
|
||||
rf.write("</td><td>")
|
||||
rf.write(str(f1_missing_arg_count))
|
||||
rf.write("\n")
|
||||
rf.close()
|
Loading…
x
Reference in New Issue
Block a user