LLDB mainline
ABISysV_riscv.h
Go to the documentation of this file.
1//===-- ABISysV_riscv.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 liblldb_ABISysV_riscv_h_
10#define liblldb_ABISysV_riscv_h_
11
12// Other libraries and framework includes
13#include "llvm/TargetParser/Triple.h"
14
15// Project includes
16#include "lldb/Target/ABI.h"
17#include "lldb/Target/Process.h"
18#include "lldb/Utility/Flags.h"
19#include "lldb/lldb-private.h"
20
22public:
23 ~ABISysV_riscv() override = default;
24
25 size_t GetRedZoneSize() const override { return 0; }
26
28 lldb::addr_t functionAddress,
29 lldb::addr_t returnAddress,
30 llvm::ArrayRef<lldb::addr_t> args) const override;
31
32 // Special thread plan for GDB style non-jit function calls.
33 bool
35 lldb::addr_t functionAddress, lldb::addr_t returnAddress,
36 llvm::Type &prototype,
37 llvm::ArrayRef<ABI::CallArgument> args) const override;
38
40 lldb_private::ValueList &values) const override;
41
44 lldb::ValueObjectSP &new_value) override;
45
48 lldb_private::CompilerType &type) const override;
49
50 // Specialized to work with llvm IR types.
52 llvm::Type &type) const override;
53
55
57
58 bool RegisterIsVolatile(const lldb_private::RegisterInfo *reg_info) override;
59
61 // The CFA must be 128 bit aligned, unless the E ABI is used
62 lldb_private::ArchSpec arch = GetProcessSP()->GetTarget().GetArchitecture();
63 lldb_private::Flags arch_flags = arch.GetFlags();
65 return (cfa & 0x3ull) == 0;
66 return (cfa & 0xfull) == 0;
67 }
68
69 void SetIsRV64(bool is_rv64) { m_is_rv64 = is_rv64; }
70
72 // Calls can use the least significant bit to store auxiliary information,
73 // so no strict check is done for alignment.
74
75 lldb_private::ArchSpec arch = GetProcessSP()->GetTarget().GetArchitecture();
76
77 // <addr> & 2 set is a fault if C extension is not used.
78 lldb_private::Flags arch_flags(arch.GetFlags());
79 if (!arch_flags.Test(lldb_private::ArchSpec::eRISCV_rvc) && (pc & 2))
80 return false;
81
82 // Make sure 64 bit addr_t only has lower 32 bits set on riscv32
83 llvm::Triple::ArchType machine = arch.GetMachine();
84 if (llvm::Triple::riscv32 == machine)
85 return (pc <= UINT32_MAX);
86
87 return true;
88 }
89
91 GetRegisterInfoArray(uint32_t &count) override;
92
93 //------------------------------------------------------------------
94 // Static Functions
95 //------------------------------------------------------------------
96
97 static void Initialize();
98
99 static void Terminate();
100
102 const lldb_private::ArchSpec &arch);
103
104 static llvm::StringRef GetPluginNameStatic() { return "sysv-riscv"; }
105
106 //------------------------------------------------------------------
107 // PluginInterface protocol
108 //------------------------------------------------------------------
109
110 llvm::StringRef GetPluginName() override { return GetPluginNameStatic(); }
111
112protected:
114 std::vector<lldb_private::DynamicRegisterInfo::Register> &regs) override;
115
117
118private:
121 lldb_private::CompilerType &ast_type) const;
122
123 using lldb_private::RegInfoBasedABI::RegInfoBasedABI; // Call CreateInstance
124 // instead.
125 bool m_is_rv64; // true if target is riscv64; false if target is riscv32
126};
127
128#endif // liblldb_ABISysV_riscv_h_
llvm::StringRef GetPluginName() override
static void Initialize()
static llvm::StringRef GetPluginNameStatic()
bool PrepareTrivialCall(lldb_private::Thread &thread, lldb::addr_t sp, lldb::addr_t functionAddress, lldb::addr_t returnAddress, llvm::Type &prototype, llvm::ArrayRef< ABI::CallArgument > args) const override
bool RegisterIsCalleeSaved(const lldb_private::RegisterInfo *reg_info)
void SetIsRV64(bool is_rv64)
lldb::UnwindPlanSP CreateDefaultUnwindPlan() override
void AugmentRegisterInfo(std::vector< lldb_private::DynamicRegisterInfo::Register > &regs) override
bool CodeAddressIsValid(lldb::addr_t pc) override
lldb::UnwindPlanSP CreateFunctionEntryUnwindPlan() override
size_t GetRedZoneSize() const override
lldb_private::Status SetReturnValueObject(lldb::StackFrameSP &frame_sp, lldb::ValueObjectSP &new_value) override
bool PrepareTrivialCall(lldb_private::Thread &thread, lldb::addr_t sp, lldb::addr_t functionAddress, lldb::addr_t returnAddress, llvm::ArrayRef< lldb::addr_t > args) const override
~ABISysV_riscv() override=default
lldb::ValueObjectSP GetReturnValueObjectSimple(lldb_private::Thread &thread, lldb_private::CompilerType &ast_type) const
bool GetArgumentValues(lldb_private::Thread &thread, lldb_private::ValueList &values) const override
static void Terminate()
static lldb::ABISP CreateInstance(lldb::ProcessSP process_sp, const lldb_private::ArchSpec &arch)
bool RegisterIsVolatile(const lldb_private::RegisterInfo *reg_info) override
const lldb_private::RegisterInfo * GetRegisterInfoArray(uint32_t &count) override
lldb::ValueObjectSP GetReturnValueObjectImpl(lldb_private::Thread &thread, lldb_private::CompilerType &type) const override
bool CallFrameAddressIsValid(lldb::addr_t cfa) override
lldb::ProcessSP GetProcessSP() const
Request to get a Process shared pointer.
Definition ABI.h:97
An architecture specification class.
Definition ArchSpec.h:31
uint32_t GetFlags() const
Definition ArchSpec.h:539
llvm::Triple::ArchType GetMachine() const
Returns a machine family for the current architecture.
Definition ArchSpec.cpp:677
Generic representation of a type in a programming language.
A class to manage flags.
Definition Flags.h:22
bool Test(ValueType bit) const
Test a single flag bit.
Definition Flags.h:96
An error handling class.
Definition Status.h:118
#define UINT32_MAX
std::shared_ptr< lldb_private::ABI > ABISP
std::shared_ptr< lldb_private::StackFrame > StackFrameSP
std::shared_ptr< lldb_private::ValueObject > ValueObjectSP
std::shared_ptr< lldb_private::Process > ProcessSP
std::shared_ptr< lldb_private::UnwindPlan > UnwindPlanSP
uint64_t addr_t
Definition lldb-types.h:80
Every register is described in detail including its name, alternate name (optional),...