LLDB mainline
ThreadFreeBSDKernelCore.cpp
Go to the documentation of this file.
1//===----------------------------------------------------------------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8
10
12#include "lldb/Target/Unwind.h"
13#include "lldb/Utility/Log.h"
14
24
25using namespace lldb;
26using namespace lldb_private;
27
29 lldb::tid_t tid,
30 lldb::addr_t pcb_addr,
31 std::string thread_name)
32 : Thread(process, tid), m_thread_name(std::move(thread_name)),
33 m_pcb_addr(pcb_addr) {}
34
36
38
44
47 RegisterContextSP reg_ctx_sp;
48 uint32_t concrete_frame_idx = 0;
49
50 if (frame)
51 concrete_frame_idx = frame->GetConcreteFrameIndex();
52
53 if (concrete_frame_idx == 0) {
56
58 static_cast<ProcessFreeBSDKernelCore *>(GetProcess().get());
59 ArchSpec arch = process->GetTarget().GetArchitecture();
60
61 switch (arch.GetMachine()) {
62 case llvm::Triple::aarch64:
64 std::make_shared<RegisterContextFreeBSDKernelCore_arm64>(
65 *this, std::make_unique<RegisterInfoPOSIX_arm64>(arch, 0),
67 break;
68 case llvm::Triple::arm:
70 std::make_shared<RegisterContextFreeBSDKernelCore_arm>(
71 *this, std::make_unique<RegisterInfoPOSIX_arm>(arch), m_pcb_addr);
72 break;
73 case llvm::Triple::x86:
75 std::make_shared<RegisterContextFreeBSDKernelCore_i386>(
76 *this, new RegisterContextFreeBSD_i386(arch), m_pcb_addr);
77 break;
78 case llvm::Triple::x86_64:
80 std::make_shared<RegisterContextFreeBSDKernelCore_x86_64>(
82 break;
83 default:
84 assert(false &&
85 "Unsupported architecture passed to ThreadFreeBSDKernelCore");
86 break;
87 }
88
89 reg_ctx_sp = m_thread_reg_ctx_sp;
90 } else {
91 reg_ctx_sp = GetUnwinder().CreateRegisterContextForFrame(frame);
92 }
93 return reg_ctx_sp;
94}
95
97 if (m_is_crashed) {
98 // Set a stop reason for crashing threads only so that they get selected
99 // preferentially.
101 return true;
102 }
103 return false;
104}
lldb::RegisterContextSP m_thread_reg_ctx_sp
ThreadFreeBSDKernelCore(lldb_private::Process &process, lldb::tid_t tid, lldb::addr_t pcb_addr, std::string thread_name)
lldb::RegisterContextSP CreateRegisterContextForFrame(lldb_private::StackFrame *frame) override
bool CalculateStopInfo() override
Ask the thread subclass to set its stop info.
lldb::RegisterContextSP GetRegisterContext() override
An architecture specification class.
Definition ArchSpec.h:32
llvm::Triple::ArchType GetMachine() const
Returns a machine family for the current architecture.
Definition ArchSpec.cpp:673
A plug-in interface definition class for debugging a process.
Definition Process.h:354
Target & GetTarget()
Get the target object pointer for this module.
Definition Process.h:1267
virtual uint32_t GetConcreteFrameIndex()
Query this frame to find what frame it is in this Thread's StackFrameList, not counting inlined frame...
Definition StackFrame.h:470
static lldb::StopInfoSP CreateStopReasonWithException(Thread &thread, const char *description)
const ArchSpec & GetArchitecture() const
Definition Target.h:1183
void SetStopInfo(const lldb::StopInfoSP &stop_info_sp)
Definition Thread.cpp:474
virtual Unwind & GetUnwinder()
Definition Thread.cpp:2121
Thread(Process &process, lldb::tid_t tid, bool use_invalid_index_id=false)
Constructor.
Definition Thread.cpp:225
lldb::ProcessSP GetProcess() const
Definition Thread.h:160
friend class StackFrame
Definition Thread.h:1323
lldb::RegisterContextSP m_reg_context_sp
The register context for this thread's current register state.
Definition Thread.h:1388
lldb::RegisterContextSP CreateRegisterContextForFrame(StackFrame *frame)
Definition Unwind.h:56
A class that represents a running process on the host machine.
uint64_t addr_t
Definition lldb-types.h:80
std::shared_ptr< lldb_private::RegisterContext > RegisterContextSP
uint64_t tid_t
Definition lldb-types.h:84