about summary refs log tree commit diff homepage
diff options
context:
space:
mode:
authorPeter Collingbourne <peter@pcc.me.uk>2010-06-24 22:12:20 +0000
committerPeter Collingbourne <peter@pcc.me.uk>2010-06-24 22:12:20 +0000
commitb2f49b6d8578e4df8d33933fbe5b6c951f9150f1 (patch)
tree2c1eecceb63c693271d5cc71f100fa959f80afff
parent27f3bf04b53a96f101633037cedda014d759594f (diff)
downloadklee-b2f49b6d8578e4df8d33933fbe5b6c951f9150f1.tar.gz
Implement klee_stack_trace function
git-svn-id: https://llvm.org/svn/llvm-project/klee/trunk@106799 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--include/klee/klee.h3
-rw-r--r--lib/Core/SpecialFunctionHandler.cpp7
-rw-r--r--lib/Core/SpecialFunctionHandler.h1
-rw-r--r--tools/klee/main.cpp1
4 files changed, 12 insertions, 0 deletions
diff --git a/include/klee/klee.h b/include/klee/klee.h
index 3d2d1782..aa47ce22 100644
--- a/include/klee/klee.h
+++ b/include/klee/klee.h
@@ -127,6 +127,9 @@ extern "C" {
      may not always work. */
   void klee_alias_function(const char* fn_name, const char* new_fn_name);
 
+  /* Print stack trace. */
+  void klee_stack_trace(void);
+
 #ifdef __cplusplus
 }
 #endif
diff --git a/lib/Core/SpecialFunctionHandler.cpp b/lib/Core/SpecialFunctionHandler.cpp
index 1b96d5f1..d3a86aac 100644
--- a/lib/Core/SpecialFunctionHandler.cpp
+++ b/lib/Core/SpecialFunctionHandler.cpp
@@ -80,6 +80,7 @@ HandlerInfo handlerInfo[] = {
   add("klee_print_expr", handlePrintExpr, false),
   add("klee_print_range", handlePrintRange, false),
   add("klee_set_forking", handleSetForking, false),
+  add("klee_stack_trace", handleStackTrace, false),
   add("klee_warning", handleWarning, false),
   add("klee_warning_once", handleWarningOnce, false),
   add("klee_alias_function", handleAliasFunction, false),
@@ -428,6 +429,12 @@ void SpecialFunctionHandler::handleSetForking(ExecutionState &state,
   }
 }
 
+void SpecialFunctionHandler::handleStackTrace(ExecutionState &state,
+                                              KInstruction *target,
+                                              std::vector<ref<Expr> > &arguments) {
+  state.dumpStack(std::cout);
+}
+
 void SpecialFunctionHandler::handleWarning(ExecutionState &state,
                                            KInstruction *target,
                                            std::vector<ref<Expr> > &arguments) {
diff --git a/lib/Core/SpecialFunctionHandler.h b/lib/Core/SpecialFunctionHandler.h
index 37792faf..e8c2eedf 100644
--- a/lib/Core/SpecialFunctionHandler.h
+++ b/lib/Core/SpecialFunctionHandler.h
@@ -95,6 +95,7 @@ namespace klee {
     HANDLER(handleRevirtObjects);
     HANDLER(handleSetForking);
     HANDLER(handleSilentExit);
+    HANDLER(handleStackTrace);
     HANDLER(handleUnderConstrained);
     HANDLER(handleWarning);
     HANDLER(handleWarningOnce);
diff --git a/tools/klee/main.cpp b/tools/klee/main.cpp
index 756ebb68..2b7310ec 100644
--- a/tools/klee/main.cpp
+++ b/tools/klee/main.cpp
@@ -686,6 +686,7 @@ static const char *modelledExternals[] = {
   "klee_warning", 
   "klee_warning_once", 
   "klee_alias_function",
+  "klee_stack_trace",
   "llvm.dbg.stoppoint", 
   "llvm.va_start", 
   "llvm.va_end",