Skip to content

Commit d30c3b7

Browse files
Add RegisterContextPOSIXCore for RISC-V 64
Fix GetRegisterSetCount() method name misprint for RegisterContextPOSIX_riscv64
1 parent e3ed9e3 commit d30c3b7

File tree

5 files changed

+153
-2
lines changed

5 files changed

+153
-2
lines changed

lldb/source/Plugins/Process/Utility/RegisterContextPOSIX_riscv64.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -58,7 +58,7 @@ RegisterContextPOSIX_riscv64::GetRegisterInfoAtIndex(size_t reg) {
5858
}
5959

6060
size_t RegisterContextPOSIX_riscv64::GetRegisterSetCount() {
61-
return m_register_info_up->GetRegisterCount();
61+
return m_register_info_up->GetRegisterSetCount();
6262
}
6363

6464
const lldb_private::RegisterSet *

lldb/source/Plugins/Process/elf-core/CMakeLists.txt

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -9,6 +9,7 @@ add_lldb_library(lldbPluginProcessElfCore PLUGIN
99
RegisterContextPOSIXCore_ppc64le.cpp
1010
RegisterContextPOSIXCore_s390x.cpp
1111
RegisterContextPOSIXCore_x86_64.cpp
12+
RegisterContextPOSIXCore_riscv64.cpp
1213
RegisterUtilities.cpp
1314

1415
LINK_LIBS
Lines changed: 84 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,84 @@
1+
//===-- RegisterContextPOSIXCore_riscv64.cpp ------------------------------===//
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+
9+
#include "RegisterContextPOSIXCore_riscv64.h"
10+
11+
#include "lldb/Utility/DataBufferHeap.h"
12+
13+
using namespace lldb_private;
14+
15+
std::unique_ptr<RegisterContextCorePOSIX_riscv64>
16+
RegisterContextCorePOSIX_riscv64::Create(
17+
lldb_private::Thread &thread, const lldb_private::ArchSpec &arch,
18+
const lldb_private::DataExtractor &gpregset,
19+
llvm::ArrayRef<lldb_private::CoreNote> notes) {
20+
Flags flags = 0;
21+
22+
auto register_info_up =
23+
std::make_unique<RegisterInfoPOSIX_riscv64>(arch, flags);
24+
return std::unique_ptr<RegisterContextCorePOSIX_riscv64>(
25+
new RegisterContextCorePOSIX_riscv64(thread, std::move(register_info_up),
26+
gpregset, notes));
27+
}
28+
29+
RegisterContextCorePOSIX_riscv64::RegisterContextCorePOSIX_riscv64(
30+
Thread &thread, std::unique_ptr<RegisterInfoPOSIX_riscv64> register_info,
31+
const DataExtractor &gpregset, llvm::ArrayRef<CoreNote> notes)
32+
: RegisterContextPOSIX_riscv64(thread, std::move(register_info)) {
33+
34+
m_gpr_buffer = std::make_shared<DataBufferHeap>(gpregset.GetDataStart(),
35+
gpregset.GetByteSize());
36+
m_gpr.SetData(m_gpr_buffer);
37+
m_gpr.SetByteOrder(gpregset.GetByteOrder());
38+
39+
ArchSpec arch = m_register_info_up->GetTargetArchitecture();
40+
DataExtractor fpregset = getRegset(notes, arch.GetTriple(), FPR_Desc);
41+
m_fpr_buffer = std::make_shared<DataBufferHeap>(fpregset.GetDataStart(),
42+
fpregset.GetByteSize());
43+
m_fpr.SetData(m_fpr_buffer);
44+
m_fpr.SetByteOrder(fpregset.GetByteOrder());
45+
}
46+
47+
RegisterContextCorePOSIX_riscv64::~RegisterContextCorePOSIX_riscv64() = default;
48+
49+
bool RegisterContextCorePOSIX_riscv64::ReadGPR() { return true; }
50+
51+
bool RegisterContextCorePOSIX_riscv64::ReadFPR() { return true; }
52+
53+
bool RegisterContextCorePOSIX_riscv64::WriteGPR() {
54+
assert(0);
55+
return false;
56+
}
57+
58+
bool RegisterContextCorePOSIX_riscv64::WriteFPR() {
59+
assert(0);
60+
return false;
61+
}
62+
63+
bool RegisterContextCorePOSIX_riscv64::ReadRegister(
64+
const RegisterInfo *reg_info, RegisterValue &value) {
65+
const uint8_t *src = nullptr;
66+
lldb::offset_t offset = reg_info->byte_offset;
67+
68+
if (IsGPR(reg_info->kinds[lldb::eRegisterKindLLDB])) {
69+
src = m_gpr.GetDataStart();
70+
} else { // IsFPR
71+
src = m_fpr.GetDataStart();
72+
offset -= GetGPRSize();
73+
}
74+
75+
Status error;
76+
value.SetFromMemoryData(*reg_info, src + offset, reg_info->byte_size,
77+
lldb::eByteOrderLittle, error);
78+
return error.Success();
79+
}
80+
81+
bool RegisterContextCorePOSIX_riscv64::WriteRegister(
82+
const RegisterInfo *reg_info, const RegisterValue &value) {
83+
return false;
84+
}
Lines changed: 60 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,60 @@
1+
//===-- RegisterContextPOSIXCore_riscv64.h ----------------------*- C++ -*-===//
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+
9+
#ifndef LLDB_SOURCE_PLUGINS_PROCESS_ELF_CORE_REGISTERCONTEXTPOSIXCORE_RISCV64_H
10+
#define LLDB_SOURCE_PLUGINS_PROCESS_ELF_CORE_REGISTERCONTEXTPOSIXCORE_RISCV64_H
11+
12+
#include "Plugins/Process/Utility/RegisterContextPOSIX_riscv64.h"
13+
#include "Plugins/Process/Utility/RegisterInfoPOSIX_riscv64.h"
14+
15+
#include "Plugins/Process/elf-core/RegisterUtilities.h"
16+
#include "lldb/Target/Thread.h"
17+
#include "lldb/Utility/DataExtractor.h"
18+
#include "lldb/Utility/RegisterValue.h"
19+
20+
#include <memory>
21+
22+
class RegisterContextCorePOSIX_riscv64 : public RegisterContextPOSIX_riscv64 {
23+
public:
24+
static std::unique_ptr<RegisterContextCorePOSIX_riscv64>
25+
Create(lldb_private::Thread &thread, const lldb_private::ArchSpec &arch,
26+
const lldb_private::DataExtractor &gpregset,
27+
llvm::ArrayRef<lldb_private::CoreNote> notes);
28+
29+
~RegisterContextCorePOSIX_riscv64() override;
30+
31+
bool ReadRegister(const lldb_private::RegisterInfo *reg_info,
32+
lldb_private::RegisterValue &value) override;
33+
34+
bool WriteRegister(const lldb_private::RegisterInfo *reg_info,
35+
const lldb_private::RegisterValue &value) override;
36+
37+
protected:
38+
RegisterContextCorePOSIX_riscv64(
39+
lldb_private::Thread &thread,
40+
std::unique_ptr<RegisterInfoPOSIX_riscv64> register_info,
41+
const lldb_private::DataExtractor &gpregset,
42+
llvm::ArrayRef<lldb_private::CoreNote> notes);
43+
44+
bool ReadGPR() override;
45+
46+
bool ReadFPR() override;
47+
48+
bool WriteGPR() override;
49+
50+
bool WriteFPR() override;
51+
52+
private:
53+
lldb::DataBufferSP m_gpr_buffer;
54+
lldb::DataBufferSP m_fpr_buffer;
55+
56+
lldb_private::DataExtractor m_gpr;
57+
lldb_private::DataExtractor m_fpr;
58+
};
59+
60+
#endif // LLDB_SOURCE_PLUGINS_PROCESS_ELF_CORE_REGISTERCONTEXTPOSIXCORE_RISCV64_H

lldb/source/Plugins/Process/elf-core/ThreadElfCore.cpp

Lines changed: 7 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -35,6 +35,7 @@
3535
#include "RegisterContextPOSIXCore_mips64.h"
3636
#include "RegisterContextPOSIXCore_powerpc.h"
3737
#include "RegisterContextPOSIXCore_ppc64le.h"
38+
#include "RegisterContextPOSIXCore_riscv64.h"
3839
#include "RegisterContextPOSIXCore_s390x.h"
3940
#include "RegisterContextPOSIXCore_x86_64.h"
4041
#include "ThreadElfCore.h"
@@ -168,7 +169,8 @@ ThreadElfCore::CreateRegisterContextForFrame(StackFrame *frame) {
168169
}
169170

170171
if (!reg_interface && arch.GetMachine() != llvm::Triple::aarch64 &&
171-
arch.GetMachine() != llvm::Triple::arm) {
172+
arch.GetMachine() != llvm::Triple::arm &&
173+
arch.GetMachine() != llvm::Triple::riscv64) {
172174
LLDB_LOGF(log, "elf-core::%s:: Architecture(%d) or OS(%d) not supported",
173175
__FUNCTION__, arch.GetMachine(), arch.GetTriple().getOS());
174176
assert(false && "Architecture or OS not supported");
@@ -184,6 +186,10 @@ ThreadElfCore::CreateRegisterContextForFrame(StackFrame *frame) {
184186
*this, std::make_unique<RegisterInfoPOSIX_arm>(arch), m_gpregset_data,
185187
m_notes);
186188
break;
189+
case llvm::Triple::riscv64:
190+
m_thread_reg_ctx_sp = RegisterContextCorePOSIX_riscv64::Create(
191+
*this, arch, m_gpregset_data, m_notes);
192+
break;
187193
case llvm::Triple::mipsel:
188194
case llvm::Triple::mips:
189195
m_thread_reg_ctx_sp = std::make_shared<RegisterContextCorePOSIX_mips64>(

0 commit comments

Comments
 (0)