[Lldb-commits] [lldb] [lldb][RISCV] Handle subsets of CSRs in RV32 core dump images (PR #142932)

Jonas Devlieghere via lldb-commits lldb-commits at lists.llvm.org
Fri Mar 6 09:10:04 PST 2026


================
@@ -7,75 +7,372 @@
 //===----------------------------------------------------------------------===//
 
 #include "RegisterContextPOSIXCore_riscv32.h"
+
 #include "lldb/Utility/DataBufferHeap.h"
 
+#define GPR_OFFSET(idx) ((idx) * sizeof(uint32_t))
+#define FPR_OFFSET(idx) ((idx) * sizeof(uint32_t))
+#define CSR_OFFSET(idx) ((idx) * sizeof(uint32_t))
+
+#define DECLARE_REGISTER_INFOS_RISCV32_STRUCT
+#include "Plugins/Process/Utility/RegisterInfos_riscv32.h"
+#undef DECLARE_REGISTER_INFOS_RISCV32_STRUCT
+
 using namespace lldb_private;
 
 std::unique_ptr<RegisterContextCorePOSIX_riscv32>
 RegisterContextCorePOSIX_riscv32::Create(Thread &thread, const ArchSpec &arch,
                                          const DataExtractor &gpregset,
                                          llvm::ArrayRef<CoreNote> notes) {
-  Flags opt_regsets = RegisterInfoPOSIX_riscv32::eRegsetMaskDefault;
-
   return std::unique_ptr<RegisterContextCorePOSIX_riscv32>(
       new RegisterContextCorePOSIX_riscv32(
-          thread,
-          std::make_unique<RegisterInfoPOSIX_riscv32>(arch, opt_regsets),
+          thread, std::make_unique<RegisterInfoPOSIXDynamic_riscv32>(arch),
           gpregset, notes));
 }
 
 RegisterContextCorePOSIX_riscv32::RegisterContextCorePOSIX_riscv32(
-    Thread &thread, std::unique_ptr<RegisterInfoPOSIX_riscv32> register_info,
+    Thread &thread,
+    std::unique_ptr<RegisterInfoPOSIXDynamic_riscv32> register_info,
     const DataExtractor &gpregset, llvm::ArrayRef<CoreNote> notes)
-    : RegisterContextPOSIX_riscv32(thread, std::move(register_info)) {
+    : RegisterContext(thread, 0), m_reg_infos_up(std::move(register_info)) {
+  // Compute the maximum register counts for GPR, FPR, and CSR.
+  uint32_t k_num_gpr_registers = (sizeof(g_register_infos_riscv32_gpr) /
+                                  sizeof(g_register_infos_riscv32_gpr[0]));
+  uint32_t k_num_fpr_registers = (sizeof(g_register_infos_riscv32_fpr) /
+                                  sizeof(g_register_infos_riscv32_fpr[0]));
+  uint32_t k_num_csr_registers = (sizeof(g_register_infos_riscv32_csr) /
+                                  sizeof(g_register_infos_riscv32_csr[0]));
 
-  m_gpr.SetData(std::make_shared<DataBufferHeap>(gpregset.GetDataStart(),
-                                                 gpregset.GetByteSize()));
-  m_gpr.SetByteOrder(gpregset.GetByteOrder());
+  std::vector<DynamicRegisterInfo::Register> registers;
+  uint32_t byte_offset = 0;
 
-  if (m_register_info_up->IsFPPresent()) {
-    ArchSpec arch = m_register_info_up->GetTargetArchitecture();
-    m_fpr = getRegset(notes, arch.GetTriple(), FPR_Desc);
+  // Build dynamic register information for GPR.
+  m_gpregset.SetData(std::make_shared<DataBufferHeap>(gpregset.GetDataStart(),
+                                                      gpregset.GetByteSize()));
+  if (m_gpregset.GetByteSize() >= g_register_infos_riscv32_gpr[0].byte_size) {
+    // GPR is available.
+    assert((m_gpregset.GetByteSize() /
+            g_register_infos_riscv32_gpr[0].byte_size) == k_num_gpr_registers &&
+           "GPR has the wrong number of registers!");
+    m_gpregset.SetByteOrder(gpregset.GetByteOrder());
+    for (auto gpr : g_register_infos_riscv32_gpr) {
+      std::vector<uint32_t> value_regs;
+      std::vector<uint32_t> invalidate_regs;
+      if (gpr.value_regs)
+        for (int idx = 0; gpr.value_regs[idx] != LLDB_INVALID_REGNUM; ++idx)
+          value_regs.push_back(gpr.value_regs[idx]);
+      if (gpr.invalidate_regs)
+        for (int idx = 0; gpr.invalidate_regs[idx] != LLDB_INVALID_REGNUM;
+             ++idx)
+          invalidate_regs.push_back(gpr.invalidate_regs[idx]);
+      DynamicRegisterInfo::Register reg{
+          lldb_private::ConstString(gpr.name),
+          lldb_private::ConstString(gpr.alt_name),
+          lldb_private::ConstString("GPR"),
+          gpr.byte_size,
+          byte_offset,
+          gpr.encoding,
+          gpr.format,
+          gpr.kinds[lldb::eRegisterKindDWARF],
+          gpr.kinds[lldb::eRegisterKindEHFrame],
+          gpr.kinds[lldb::eRegisterKindGeneric],
+          gpr.kinds[lldb::eRegisterKindProcessPlugin],
+          value_regs,
+          invalidate_regs,
+          /* value_reg_offset */ 0,
----------------
JDevlieghere wrote:

```suggestion
          /*value_reg_offset=*/0,
```

https://github.com/llvm/llvm-project/pull/142932


More information about the lldb-commits mailing list