[Lldb-commits] [lldb] [lldb][RISCV] Fix GetRegisterInfo to support RISCV-32 (PR #175262)
via lldb-commits
lldb-commits at lists.llvm.org
Wed Jan 14 16:40:24 PST 2026
https://github.com/MkDev11 updated https://github.com/llvm/llvm-project/pull/175262
>From 021bda28a839b1f7f719eb63fe3301e1d9971313 Mon Sep 17 00:00:00 2001
From: mkdev11 <jaysmth689 at gmail.com>
Date: Thu, 15 Jan 2026 02:38:41 +0200
Subject: [PATCH] [lldb][RISCV] Fix GetRegisterInfo to support RISCV-32
GetRegisterInfo in EmulateInstructionRISCV.cpp was hardcoded to use
RegisterInfoPOSIX_riscv64, which caused LLDB to assert when working
with RISCV-32 ELF files.
This patch adds a check for the architecture and uses
RegisterInfoPOSIX_riscv32 when the target is RISCV-32.
Fixes #175092
---
.../RISCV/EmulateInstructionRISCV.cpp | 36 ++++++++++++++-----
.../Instruction/RISCV/TestRISCVEmulator.cpp | 19 ++++++++++
2 files changed, 46 insertions(+), 9 deletions(-)
diff --git a/lldb/source/Plugins/Instruction/RISCV/EmulateInstructionRISCV.cpp b/lldb/source/Plugins/Instruction/RISCV/EmulateInstructionRISCV.cpp
index 2957cb716041d..d9f8d97ef9e4f 100644
--- a/lldb/source/Plugins/Instruction/RISCV/EmulateInstructionRISCV.cpp
+++ b/lldb/source/Plugins/Instruction/RISCV/EmulateInstructionRISCV.cpp
@@ -7,6 +7,7 @@
//===----------------------------------------------------------------------===//
#include "EmulateInstructionRISCV.h"
+#include "Plugins/Process/Utility/RegisterInfoPOSIX_riscv32.h"
#include "Plugins/Process/Utility/RegisterInfoPOSIX_riscv64.h"
#include "Plugins/Process/Utility/lldb-riscv-register-enums.h"
#include "RISCVCInstructions.h"
@@ -1809,6 +1810,19 @@ bool EmulateInstructionRISCV::SetAccruedExceptions(
return WriteRegisterUnsigned(ctx, eRegisterKindLLDB, fpr_fcsr_riscv, fcsr);
}
+template <typename T>
+static std::optional<RegisterInfo>
+GetRegisterInfoHelper(const T ®_info, uint32_t reg_index,
+ RegisterKind reg_kind) {
+ const RegisterInfo *array = reg_info.GetRegisterInfo();
+ const uint32_t length = reg_info.GetRegisterCount();
+
+ if (reg_index >= length || reg_kind != eRegisterKindLLDB)
+ return {};
+
+ return array[reg_index];
+}
+
std::optional<RegisterInfo>
EmulateInstructionRISCV::GetRegisterInfo(RegisterKind reg_kind,
uint32_t reg_index) {
@@ -1837,15 +1851,19 @@ EmulateInstructionRISCV::GetRegisterInfo(RegisterKind reg_kind,
}
}
- RegisterInfoPOSIX_riscv64 reg_info(m_arch,
- RegisterInfoPOSIX_riscv64::eRegsetMaskAll);
- const RegisterInfo *array = reg_info.GetRegisterInfo();
- const uint32_t length = reg_info.GetRegisterCount();
-
- if (reg_index >= length || reg_kind != eRegisterKindLLDB)
- return {};
-
- return array[reg_index];
+ switch (m_arch.GetCore()) {
+ case ArchSpec::eCore_riscv32:
+ return GetRegisterInfoHelper(
+ RegisterInfoPOSIX_riscv32(m_arch,
+ RegisterInfoPOSIX_riscv32::eRegsetMaskAll),
+ reg_index, reg_kind);
+ case ArchSpec::eCore_riscv64:
+ return GetRegisterInfoHelper(
+ RegisterInfoPOSIX_riscv64(m_arch,
+ RegisterInfoPOSIX_riscv64::eRegsetMaskAll),
+ reg_index, reg_kind);
+ }
+ llvm_unreachable("unsupported architecture");
}
bool EmulateInstructionRISCV::SetInstruction(const Opcode &opcode,
diff --git a/lldb/unittests/Instruction/RISCV/TestRISCVEmulator.cpp b/lldb/unittests/Instruction/RISCV/TestRISCVEmulator.cpp
index 90d5a7c4f3b97..39b07f7ec76a6 100644
--- a/lldb/unittests/Instruction/RISCV/TestRISCVEmulator.cpp
+++ b/lldb/unittests/Instruction/RISCV/TestRISCVEmulator.cpp
@@ -16,6 +16,7 @@
#include "lldb/Utility/RegisterValue.h"
#include "Plugins/Instruction/RISCV/EmulateInstructionRISCV.h"
+#include "Plugins/Process/Utility/RegisterInfoPOSIX_riscv32.h"
#include "Plugins/Process/Utility/RegisterInfoPOSIX_riscv64.h"
#include "Plugins/Process/Utility/lldb-riscv-register-enums.h"
@@ -806,3 +807,21 @@ TEST_F(RISCVEmulatorTester, TestFMV_D_XInst) {
ASSERT_TRUE(this->Execute(*decode, false));
ASSERT_EQ(this->fpr.fpr[DecodeRD(FMV_D_XInst)], bits);
}
+
+TEST_F(RISCVEmulatorTester, TestGetRegisterInfoRV64) {
+ // Test that GetRegisterInfo returns valid register info for RV64
+ auto reg_info = this->GetRegisterInfo(eRegisterKindLLDB, gpr_x1_riscv);
+ ASSERT_TRUE(reg_info.has_value());
+ ASSERT_EQ(reg_info->byte_size, 8u);
+ ASSERT_STREQ(reg_info->name, "ra");
+}
+
+TEST_F(RISCVEmulatorTester32, TestGetRegisterInfoRV32) {
+ // Test that GetRegisterInfo returns valid register info for RV32
+ // This verifies the fix for issue #175092 where GetRegisterInfo was
+ // hardcoded to use RegisterInfoPOSIX_riscv64
+ auto reg_info = this->GetRegisterInfo(eRegisterKindLLDB, gpr_x1_riscv);
+ ASSERT_TRUE(reg_info.has_value());
+ ASSERT_EQ(reg_info->byte_size, 4u);
+ ASSERT_STREQ(reg_info->name, "ra");
+}
More information about the lldb-commits
mailing list