2013-12-13 00:29:16 +00:00
|
|
|
//===-- SBQueueItem.cpp -----------------------------------------*- C++ -*-===//
|
|
|
|
//
|
2019-01-19 08:50:56 +00:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2013-12-13 00:29:16 +00:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "lldb/lldb-forward.h"
|
|
|
|
|
|
|
|
#include "lldb/API/SBAddress.h"
|
|
|
|
#include "lldb/API/SBQueueItem.h"
|
|
|
|
#include "lldb/API/SBThread.h"
|
|
|
|
#include "lldb/Core/Address.h"
|
2014-03-06 06:31:18 +00:00
|
|
|
#include "lldb/Target/Process.h"
|
2013-12-13 00:29:16 +00:00
|
|
|
#include "lldb/Target/QueueItem.h"
|
2014-02-05 05:44:54 +00:00
|
|
|
#include "lldb/Target/Thread.h"
|
2017-03-03 20:56:28 +00:00
|
|
|
#include "lldb/Utility/Log.h"
|
2013-12-13 00:29:16 +00:00
|
|
|
|
|
|
|
using namespace lldb;
|
|
|
|
using namespace lldb_private;
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
// Constructors
|
|
|
|
//----------------------------------------------------------------------
|
2016-09-06 20:57:50 +00:00
|
|
|
SBQueueItem::SBQueueItem() : m_queue_item_sp() {}
|
2013-12-13 00:29:16 +00:00
|
|
|
|
2016-09-06 20:57:50 +00:00
|
|
|
SBQueueItem::SBQueueItem(const QueueItemSP &queue_item_sp)
|
|
|
|
: m_queue_item_sp(queue_item_sp) {}
|
2013-12-13 00:29:16 +00:00
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
// Destructor
|
|
|
|
//----------------------------------------------------------------------
|
2016-09-06 20:57:50 +00:00
|
|
|
SBQueueItem::~SBQueueItem() { m_queue_item_sp.reset(); }
|
|
|
|
|
|
|
|
bool SBQueueItem::IsValid() const {
|
|
|
|
bool is_valid = m_queue_item_sp.get() != NULL;
|
|
|
|
Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
|
|
|
|
if (log)
|
|
|
|
log->Printf("SBQueueItem(%p)::IsValid() == %s",
|
|
|
|
static_cast<void *>(m_queue_item_sp.get()),
|
|
|
|
is_valid ? "true" : "false");
|
|
|
|
return is_valid;
|
2013-12-13 00:29:16 +00:00
|
|
|
}
|
|
|
|
|
2016-09-06 20:57:50 +00:00
|
|
|
void SBQueueItem::Clear() {
|
|
|
|
Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
|
|
|
|
if (log)
|
|
|
|
log->Printf("SBQueueItem(%p)::Clear()",
|
|
|
|
static_cast<void *>(m_queue_item_sp.get()));
|
|
|
|
m_queue_item_sp.reset();
|
2013-12-13 00:29:16 +00:00
|
|
|
}
|
|
|
|
|
2016-09-06 20:57:50 +00:00
|
|
|
void SBQueueItem::SetQueueItem(const QueueItemSP &queue_item_sp) {
|
|
|
|
m_queue_item_sp = queue_item_sp;
|
2013-12-13 00:29:16 +00:00
|
|
|
}
|
|
|
|
|
2016-09-06 20:57:50 +00:00
|
|
|
lldb::QueueItemKind SBQueueItem::GetKind() const {
|
|
|
|
QueueItemKind result = eQueueItemKindUnknown;
|
|
|
|
Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
|
|
|
|
if (m_queue_item_sp) {
|
|
|
|
result = m_queue_item_sp->GetKind();
|
|
|
|
}
|
|
|
|
if (log)
|
|
|
|
log->Printf("SBQueueItem(%p)::GetKind() == %d",
|
|
|
|
static_cast<void *>(m_queue_item_sp.get()),
|
|
|
|
static_cast<int>(result));
|
|
|
|
return result;
|
2013-12-13 00:29:16 +00:00
|
|
|
}
|
|
|
|
|
2016-09-06 20:57:50 +00:00
|
|
|
void SBQueueItem::SetKind(lldb::QueueItemKind kind) {
|
|
|
|
if (m_queue_item_sp) {
|
|
|
|
m_queue_item_sp->SetKind(kind);
|
|
|
|
}
|
2013-12-13 00:29:16 +00:00
|
|
|
}
|
|
|
|
|
2016-09-06 20:57:50 +00:00
|
|
|
SBAddress SBQueueItem::GetAddress() const {
|
|
|
|
SBAddress result;
|
|
|
|
Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
|
|
|
|
if (m_queue_item_sp) {
|
|
|
|
result.SetAddress(&m_queue_item_sp->GetAddress());
|
|
|
|
}
|
|
|
|
if (log) {
|
|
|
|
StreamString sstr;
|
|
|
|
const Address *addr = result.get();
|
|
|
|
if (addr)
|
|
|
|
addr->Dump(&sstr, NULL, Address::DumpStyleModuleWithFileAddress,
|
|
|
|
Address::DumpStyleInvalid, 4);
|
|
|
|
log->Printf("SBQueueItem(%p)::GetAddress() == SBAddress(%p): %s",
|
|
|
|
static_cast<void *>(m_queue_item_sp.get()),
|
|
|
|
static_cast<void *>(result.get()), sstr.GetData());
|
|
|
|
}
|
|
|
|
return result;
|
2013-12-13 00:29:16 +00:00
|
|
|
}
|
|
|
|
|
2016-09-06 20:57:50 +00:00
|
|
|
void SBQueueItem::SetAddress(SBAddress addr) {
|
|
|
|
if (m_queue_item_sp) {
|
|
|
|
m_queue_item_sp->SetAddress(addr.ref());
|
|
|
|
}
|
2013-12-13 00:29:16 +00:00
|
|
|
}
|
|
|
|
|
2016-09-06 20:57:50 +00:00
|
|
|
SBThread SBQueueItem::GetExtendedBacktraceThread(const char *type) {
|
|
|
|
SBThread result;
|
|
|
|
Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
|
|
|
|
if (m_queue_item_sp) {
|
|
|
|
ProcessSP process_sp = m_queue_item_sp->GetProcessSP();
|
|
|
|
Process::StopLocker stop_locker;
|
|
|
|
if (process_sp && stop_locker.TryLock(&process_sp->GetRunLock())) {
|
|
|
|
ThreadSP thread_sp;
|
|
|
|
ConstString type_const(type);
|
|
|
|
thread_sp = m_queue_item_sp->GetExtendedBacktraceThread(type_const);
|
|
|
|
if (thread_sp) {
|
|
|
|
// Save this in the Process' ExtendedThreadList so a strong pointer
|
2018-04-30 16:49:04 +00:00
|
|
|
// retains the object
|
2016-09-06 20:57:50 +00:00
|
|
|
process_sp->GetExtendedThreadList().AddThread(thread_sp);
|
|
|
|
result.SetThread(thread_sp);
|
|
|
|
if (log) {
|
|
|
|
const char *queue_name = thread_sp->GetQueueName();
|
|
|
|
if (queue_name == NULL)
|
|
|
|
queue_name = "";
|
|
|
|
log->Printf(
|
|
|
|
"SBQueueItem(%p)::GetExtendedBacktraceThread() = new extended "
|
|
|
|
"Thread created (%p) with queue_id 0x%" PRIx64 " queue name '%s'",
|
|
|
|
static_cast<void *>(m_queue_item_sp.get()),
|
|
|
|
static_cast<void *>(thread_sp.get()),
|
|
|
|
static_cast<uint64_t>(thread_sp->GetQueueID()), queue_name);
|
2013-12-13 00:29:16 +00:00
|
|
|
}
|
2016-09-06 20:57:50 +00:00
|
|
|
}
|
2013-12-13 00:29:16 +00:00
|
|
|
}
|
2016-09-06 20:57:50 +00:00
|
|
|
}
|
|
|
|
return result;
|
2013-12-13 00:29:16 +00:00
|
|
|
}
|