1 | //===-- AArch64.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_ABI_AARCH64_ABIAARCH64_H |
10 | #define LLDB_SOURCE_PLUGINS_ABI_AARCH64_ABIAARCH64_H |
11 | |
12 | #include "lldb/Target/ABI.h" |
13 | |
14 | class ABIAArch64 : public lldb_private::MCBasedABI { |
15 | public: |
16 | static void Initialize(); |
17 | static void Terminate(); |
18 | |
19 | lldb::addr_t FixCodeAddress(lldb::addr_t pc) override; |
20 | lldb::addr_t FixDataAddress(lldb::addr_t pc) override; |
21 | |
22 | lldb::UnwindPlanSP CreateFunctionEntryUnwindPlan() override; |
23 | lldb::UnwindPlanSP CreateDefaultUnwindPlan() override; |
24 | |
25 | protected: |
26 | virtual lldb::addr_t FixAddress(lldb::addr_t pc, lldb::addr_t mask) { |
27 | return pc; |
28 | } |
29 | |
30 | std::pair<uint32_t, uint32_t> |
31 | GetEHAndDWARFNums(llvm::StringRef name) override; |
32 | |
33 | std::string GetMCName(std::string reg) override; |
34 | |
35 | uint32_t GetGenericNum(llvm::StringRef name) override; |
36 | |
37 | void AugmentRegisterInfo( |
38 | std::vector<lldb_private::DynamicRegisterInfo::Register> ®s) override; |
39 | |
40 | using lldb_private::MCBasedABI::MCBasedABI; |
41 | }; |
42 | #endif |
43 | |