[Lldb-commits] [lldb] r116028 - in /lldb/trunk/source: Expression/ClangExpressionDeclMap.cpp Expression/ClangExpressionParser.cpp Plugins/ABI/SysV-x86_64/ABISysV_x86_64.cpp
Sean Callanan
scallanan at apple.com
Thu Oct 7 18:58:41 PDT 2010
Author: spyffe
Date: Thu Oct 7 20:58:41 2010
New Revision: 116028
URL: http://llvm.org/viewvc/llvm-project?rev=116028&view=rev
Log:
Added extra logging, and made sure that the argument
struct for expressions is deallocated when the
ClangExpressionDeclMap is taken down.
Modified:
lldb/trunk/source/Expression/ClangExpressionDeclMap.cpp
lldb/trunk/source/Expression/ClangExpressionParser.cpp
lldb/trunk/source/Plugins/ABI/SysV-x86_64/ABISysV_x86_64.cpp
Modified: lldb/trunk/source/Expression/ClangExpressionDeclMap.cpp
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Expression/ClangExpressionDeclMap.cpp?rev=116028&r1=116027&r2=116028&view=diff
==============================================================================
--- lldb/trunk/source/Expression/ClangExpressionDeclMap.cpp (original)
+++ lldb/trunk/source/Expression/ClangExpressionDeclMap.cpp Thu Oct 7 20:58:41 2010
@@ -74,6 +74,12 @@
pvar.DisableParserVars();
}
+ if (m_materialized_location)
+ {
+ m_exe_ctx->process->DeallocateMemory(m_materialized_location);
+ m_materialized_location = 0;
+ }
+
if (m_sym_ctx)
delete m_sym_ctx;
}
@@ -495,6 +501,9 @@
m_materialized_location = 0;
}
+ if (log)
+ log->PutCString("Allocating memory for materialized argument struct");
+
lldb::addr_t mem = exe_ctx->process->AllocateMemory(m_struct_alignment + m_struct_size,
lldb::ePermissionsReadable | lldb::ePermissionsWritable,
err);
Modified: lldb/trunk/source/Expression/ClangExpressionParser.cpp
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Expression/ClangExpressionParser.cpp?rev=116028&r1=116027&r2=116028&view=diff
==============================================================================
--- lldb/trunk/source/Expression/ClangExpressionParser.cpp (original)
+++ lldb/trunk/source/Expression/ClangExpressionParser.cpp Thu Oct 7 20:58:41 2010
@@ -449,6 +449,8 @@
if (m_expr.NeedsValidation())
{
+ /*
+ Disabled temporarily - TODO Centralize and re-enable this inside Process to avoid race conditions
IRDynamicChecks ir_dynamic_checks(*exe_ctx.process->GetDynamicCheckers(), function_name.c_str());
if (!ir_dynamic_checks.runOnModule(*module))
@@ -457,6 +459,7 @@
err.SetErrorString("Couldn't add dynamic checks to the expression");
return err;
}
+ */
}
}
Modified: lldb/trunk/source/Plugins/ABI/SysV-x86_64/ABISysV_x86_64.cpp
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Plugins/ABI/SysV-x86_64/ABISysV_x86_64.cpp?rev=116028&r1=116027&r2=116028&view=diff
==============================================================================
--- lldb/trunk/source/Plugins/ABI/SysV-x86_64/ABISysV_x86_64.cpp (original)
+++ lldb/trunk/source/Plugins/ABI/SysV-x86_64/ABISysV_x86_64.cpp Thu Oct 7 20:58:41 2010
@@ -12,6 +12,7 @@
#include "lldb/Core/ConstString.h"
#include "lldb/Core/DataExtractor.h"
#include "lldb/Core/Error.h"
+#include "lldb/Core/Log.h"
#include "lldb/Core/Module.h"
#include "lldb/Core/PluginManager.h"
#include "lldb/Core/Value.h"
@@ -60,6 +61,17 @@
lldb::addr_t arg,
lldb::addr_t *this_arg) const
{
+ Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS);
+
+ if (log)
+ log->Printf("ABISysV_x86_64::PrepareTrivialCall\n(\n thread = %p\n sp = 0x%llx\n functionAddress = 0x%llx\n returnAddress = 0x%llx\n arg = 0x%llx\n this_arg = %p(0x%llx)\n)",
+ (void*)&thread,
+ (uint64_t)sp,
+ (uint64_t)functionAddress,
+ (uint64_t)returnAddress,
+ (void*)arg,
+ this_arg ? (uint64_t)*this_arg : (uint64_t)0);
+
RegisterContext *reg_ctx = thread.GetRegisterContext();
if (!reg_ctx)
return false;
@@ -78,21 +90,39 @@
if (this_arg)
{
+ if (log)
+ log->PutCString("The trivial call has a this pointer");
+
uint32_t rsiID = reg_ctx->GetRegisterInfoByName("rsi", 0)->kinds[eRegisterKindLLDB];
+ if (log)
+ log->Printf("About to write 'this' (0x%llx) into RDI", (uint64_t)*this_arg);
+
if (!reg_ctx->WriteRegisterFromUnsigned(rdiID, *this_arg))
return false;
+ if (log)
+ log->Printf("About to write the argument (0x%llx) into RSI", (uint64_t)arg);
+
if (!reg_ctx->WriteRegisterFromUnsigned(rsiID, arg))
return false;
}
else
{
+ if (log)
+ log->PutCString("The trivial call does not have a this pointer");
+
+ if (log)
+ log->Printf("About to write the argument (0x%llx) into RDI", (uint64_t)arg);
+
if (!reg_ctx->WriteRegisterFromUnsigned(rdiID, arg))
return false;
}
// First, align the SP
+
+ if (log)
+ log->Printf("16-byte aligning SP: 0x%llx to 0x%llx", (uint64_t)sp, (uint64_t)(sp & ~0xfull));
sp &= ~(0xfull); // 16-byte alignment
@@ -101,11 +131,18 @@
sp -= 8;
uint64_t returnAddressU64 = returnAddress;
Error error;
+
+ if (log)
+ log->Printf("Pushing the return address onto the stack: new SP 0x%llx, return address 0x%llx", (uint64_t)sp, (uint64_t)returnAddressU64);
+
if (thread.GetProcess().WriteMemory (sp, &returnAddressU64, sizeof(returnAddressU64), error) != sizeof(returnAddressU64))
return false;
// %rsp is set to the actual stack value.
+ if (log)
+ log->Printf("Writing SP (0x%llx) down", (uint64_t)sp);
+
if (!reg_ctx->WriteRegisterFromUnsigned(rspID, sp))
return false;
@@ -117,6 +154,9 @@
#endif
// %rip is set to the address of the called function.
+
+ if (log)
+ log->Printf("Writing new IP (0x%llx) down", (uint64_t)functionAddress);
if (!reg_ctx->WriteRegisterFromUnsigned(ripID, functionAddress))
return false;
More information about the lldb-commits
mailing list