1 | //===-- EmulationStateARM.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_INSTRUCTION_ARM_EMULATIONSTATEARM_H |
10 | #define LLDB_SOURCE_PLUGINS_INSTRUCTION_ARM_EMULATIONSTATEARM_H |
11 | |
12 | #include <map> |
13 | |
14 | #include "lldb/Core/EmulateInstruction.h" |
15 | #include "lldb/Core/Opcode.h" |
16 | |
17 | class EmulationStateARM { |
18 | public: |
19 | EmulationStateARM(); |
20 | |
21 | virtual ~EmulationStateARM(); |
22 | |
23 | bool StorePseudoRegisterValue(uint32_t reg_num, uint64_t value); |
24 | |
25 | uint64_t ReadPseudoRegisterValue(uint32_t reg_num, bool &success); |
26 | |
27 | bool StoreToPseudoAddress(lldb::addr_t p_address, uint32_t value); |
28 | |
29 | uint32_t ReadFromPseudoAddress(lldb::addr_t p_address, bool &success); |
30 | |
31 | void ClearPseudoRegisters(); |
32 | |
33 | void ClearPseudoMemory(); |
34 | |
35 | bool LoadStateFromDictionary(lldb_private::OptionValueDictionary *test_data); |
36 | |
37 | bool CompareState(EmulationStateARM &other_state, |
38 | lldb_private::Stream &out_stream); |
39 | |
40 | static size_t |
41 | ReadPseudoMemory(lldb_private::EmulateInstruction *instruction, void *baton, |
42 | const lldb_private::EmulateInstruction::Context &context, |
43 | lldb::addr_t addr, void *dst, size_t length); |
44 | |
45 | static size_t |
46 | WritePseudoMemory(lldb_private::EmulateInstruction *instruction, void *baton, |
47 | const lldb_private::EmulateInstruction::Context &context, |
48 | lldb::addr_t addr, const void *dst, size_t length); |
49 | |
50 | static bool ReadPseudoRegister(lldb_private::EmulateInstruction *instruction, |
51 | void *baton, |
52 | const lldb_private::RegisterInfo *reg_info, |
53 | lldb_private::RegisterValue ®_value); |
54 | |
55 | static bool |
56 | WritePseudoRegister(lldb_private::EmulateInstruction *instruction, |
57 | void *baton, |
58 | const lldb_private::EmulateInstruction::Context &context, |
59 | const lldb_private::RegisterInfo *reg_info, |
60 | const lldb_private::RegisterValue ®_value); |
61 | |
62 | private: |
63 | bool ( |
64 | lldb_private::OptionValueDictionary *reg_dict, char kind, int first_reg, |
65 | int num); |
66 | |
67 | uint32_t m_gpr[17] = {0}; |
68 | struct _sd_regs { |
69 | uint32_t s_regs[32]; // sregs 0 - 31 & dregs 0 - 15 |
70 | |
71 | uint64_t d_regs[16]; // dregs 16-31 |
72 | |
73 | } m_vfp_regs; |
74 | |
75 | std::map<lldb::addr_t, uint32_t> m_memory; // Eventually will want to change |
76 | // uint32_t to a data buffer heap |
77 | // type. |
78 | |
79 | EmulationStateARM(const EmulationStateARM &) = delete; |
80 | const EmulationStateARM &operator=(const EmulationStateARM &) = delete; |
81 | }; |
82 | |
83 | #endif // LLDB_SOURCE_PLUGINS_INSTRUCTION_ARM_EMULATIONSTATEARM_H |
84 | |