diff options
Diffstat (limited to 'sbe/test/simics-debug-framework.py')
-rwxr-xr-x | sbe/test/simics-debug-framework.py | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/sbe/test/simics-debug-framework.py b/sbe/test/simics-debug-framework.py new file mode 100755 index 00000000..a96e891f --- /dev/null +++ b/sbe/test/simics-debug-framework.py @@ -0,0 +1,60 @@ +import os +import subprocess +import re +import random +import sys +sys.path.append("targets/p9_nimbus/sbeTest" ) +import testIstepAuto +err = False + +syms = {}; + + +# @fn register_hb_debug_framework_tools +# @brief Create a simics command wrapper for each debug tool module. +def register_sbe_debug_framework_tools(): + fillSymTable() + # Create command hook. + new_command("sbe-istep", testIstepAuto.sbe_istep_func, + args = [arg(int_t, "major"), arg(int_t, "minor")], + alias = "istep", + type = ["sbe-commands"], + short = "Runs the debug framework for istep ", + doc = "") + new_command("sbe-trace", collectTrace, + args = [], + alias = "strace", + type = ["sbe-commands"], + short = "Runs the debug framework for istep ", + doc = "") + print "SBE Debug Framework: Registered tool:", "sbe-istep" + print "SBE Debug Framework: Registered tool:", "sbe-trace" + + +def fillSymTable(): + symFile = os.environ['SBE_IMG_OUT_LOC'] + "/sbe.syms" + f = open( symFile, 'r') + for line in f: + words = line.split() + if( len(words) == 3): + syms[words[2]] = words[0] + +def collectTrace(): + cmd1 = "pipe \"p9Proc0.sbe.mibo_space.x 0x" + syms['g_pk_trace_buf'] + " 0x2028\" \"sed 's/^p:0x........ //g' | sed 's/ ................$//g' | sed 's/ //g' | xxd -r -p> ppetrace.bin\"" + toolPath = os.environ['SBE_IMG_OUT_LOC'] + "/../../tools/ppetracepp/" + cmd2 = "shell \"" + toolPath + "ppe2fsp ppetrace.bin sbetrace.bin \"" + cmd3 = "shell \"" + toolPath + "fsp-trace -s " + os.environ['SBE_IMG_OUT_LOC'] + "/trexStringFile sbetrace.bin > tracMERG \"" + cmd4 = "shell \"" + "cat tracMERG \"" + + ( rc, out ) = quiet_run_command( cmd1, output_modes.regular ) + if ( rc ): + print "simics ERROR running %s: %d "%( cmd1, rc ) + + SIM_run_alone( run_command, cmd2 ) + SIM_run_alone( run_command, cmd3 ) + SIM_run_alone( run_command, cmd4 ) + + +# Run the registration automatically whenever this script is loaded. +register_sbe_debug_framework_tools() + |