LLDB mainline
RegisterContextPOSIXCore_riscv32.h
Go to the documentation of this file.
1//===-- RegisterContextPOSIXCore_riscv32.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_RISCV32_H
10#define LLDB_SOURCE_PLUGINS_PROCESS_ELF_CORE_REGISTERCONTEXTPOSIXCORE_RISCV32_H
11
13
15#include "lldb/Target/Thread.h"
18
19#include <memory>
20
22public:
23 struct csr_kv_t {
24 uint32_t addr; // CSR address/index
25 uint32_t val; // CSR value
26 };
27
28 static std::unique_ptr<RegisterContextCorePOSIX_riscv32>
30 const lldb_private::DataExtractor &gpregset,
31 llvm::ArrayRef<lldb_private::CoreNote> notes);
32
34
35 void InvalidateAllRegisters() override;
36
37 size_t GetRegisterCount() override;
38
39 const lldb_private::RegisterInfo *GetRegisterInfoAtIndex(size_t reg) override;
40
41 size_t GetRegisterSetCount() override;
42
43 const lldb_private::RegisterSet *GetRegisterSet(size_t set) override;
44
45 bool ReadRegister(const lldb_private::RegisterInfo *reg_info,
46 lldb_private::RegisterValue &value) override;
47
48 bool WriteRegister(const lldb_private::RegisterInfo *reg_info,
49 const lldb_private::RegisterValue &value) override;
50
51protected:
54 std::unique_ptr<RegisterInfoPOSIXDynamic_riscv32> register_info,
55 const lldb_private::DataExtractor &gpregset,
56 llvm::ArrayRef<lldb_private::CoreNote> notes);
57
58 bool IsGPR(unsigned reg);
59
60 bool IsFPR(unsigned reg);
61
62 bool IsCSR(unsigned reg);
63
66 const lldb_private::ConstString &set_name,
67 uint32_t byte_offset);
68
69private:
70 std::unique_ptr<RegisterInfoPOSIXDynamic_riscv32> m_reg_infos_up;
74};
75
76#endif // LLDB_SOURCE_PLUGINS_PROCESS_ELF_CORE_REGISTERCONTEXTPOSIXCORE_RISCV32_H
const lldb_private::RegisterInfo * GetRegisterInfoAtIndex(size_t reg) override
static std::unique_ptr< RegisterContextCorePOSIX_riscv32 > Create(lldb_private::Thread &thread, const lldb_private::ArchSpec &arch, const lldb_private::DataExtractor &gpregset, llvm::ArrayRef< lldb_private::CoreNote > notes)
const lldb_private::RegisterSet * GetRegisterSet(size_t set) override
bool WriteRegister(const lldb_private::RegisterInfo *reg_info, const lldb_private::RegisterValue &value) override
RegisterContextCorePOSIX_riscv32(lldb_private::Thread &thread, std::unique_ptr< RegisterInfoPOSIXDynamic_riscv32 > register_info, const lldb_private::DataExtractor &gpregset, llvm::ArrayRef< lldb_private::CoreNote > notes)
bool ReadRegister(const lldb_private::RegisterInfo *reg_info, lldb_private::RegisterValue &value) override
std::unique_ptr< RegisterInfoPOSIXDynamic_riscv32 > m_reg_infos_up
lldb_private::DynamicRegisterInfo::Register BuildDynamicRegister(const lldb_private::RegisterInfo &reg_info, const lldb_private::ConstString &set_name, uint32_t byte_offset)
An architecture specification class.
Definition ArchSpec.h:32
A uniqued constant string class.
Definition ConstString.h:40
An data extractor class.
Every register is described in detail including its name, alternate name (optional),...
Registers are grouped into register sets.