xref: /freebsd-src/contrib/llvm-project/lldb/source/Plugins/Process/gdb-remote/GDBRemoteRegisterContext.h (revision 5f757f3ff9144b609b3c433dfd370cc6bdc191ad)
10b57cec5SDimitry Andric //===-- GDBRemoteRegisterContext.h ------------------------------*- C++ -*-===//
20b57cec5SDimitry Andric //
30b57cec5SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
40b57cec5SDimitry Andric // See https://llvm.org/LICENSE.txt for license information.
50b57cec5SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
60b57cec5SDimitry Andric //
70b57cec5SDimitry Andric //===----------------------------------------------------------------------===//
80b57cec5SDimitry Andric 
95ffd83dbSDimitry Andric #ifndef LLDB_SOURCE_PLUGINS_PROCESS_GDB_REMOTE_GDBREMOTEREGISTERCONTEXT_H
105ffd83dbSDimitry Andric #define LLDB_SOURCE_PLUGINS_PROCESS_GDB_REMOTE_GDBREMOTEREGISTERCONTEXT_H
110b57cec5SDimitry Andric 
120b57cec5SDimitry Andric #include <vector>
130b57cec5SDimitry Andric 
14349cc55cSDimitry Andric #include "lldb/Target/DynamicRegisterInfo.h"
150b57cec5SDimitry Andric #include "lldb/Target/RegisterContext.h"
160b57cec5SDimitry Andric #include "lldb/Utility/ConstString.h"
170b57cec5SDimitry Andric #include "lldb/Utility/DataExtractor.h"
180b57cec5SDimitry Andric #include "lldb/lldb-enumerations.h"
190b57cec5SDimitry Andric #include "lldb/lldb-private.h"
200b57cec5SDimitry Andric 
210b57cec5SDimitry Andric #include "GDBRemoteCommunicationClient.h"
220b57cec5SDimitry Andric 
230b57cec5SDimitry Andric class StringExtractor;
240b57cec5SDimitry Andric 
250b57cec5SDimitry Andric namespace lldb_private {
260b57cec5SDimitry Andric namespace process_gdb_remote {
270b57cec5SDimitry Andric 
280b57cec5SDimitry Andric class ThreadGDBRemote;
290b57cec5SDimitry Andric class ProcessGDBRemote;
30e8d8bef9SDimitry Andric class GDBRemoteDynamicRegisterInfo;
310b57cec5SDimitry Andric 
32e8d8bef9SDimitry Andric typedef std::shared_ptr<GDBRemoteDynamicRegisterInfo>
33e8d8bef9SDimitry Andric     GDBRemoteDynamicRegisterInfoSP;
34e8d8bef9SDimitry Andric 
35e8d8bef9SDimitry Andric class GDBRemoteDynamicRegisterInfo final : public DynamicRegisterInfo {
360b57cec5SDimitry Andric public:
GDBRemoteDynamicRegisterInfo()370b57cec5SDimitry Andric   GDBRemoteDynamicRegisterInfo() : DynamicRegisterInfo() {}
380b57cec5SDimitry Andric 
390b57cec5SDimitry Andric   ~GDBRemoteDynamicRegisterInfo() override = default;
400b57cec5SDimitry Andric 
41*5f757f3fSDimitry Andric   void UpdateARM64SVERegistersInfos(uint64_t vg);
42*5f757f3fSDimitry Andric   void UpdateARM64SMERegistersInfos(uint64_t svg);
430b57cec5SDimitry Andric };
440b57cec5SDimitry Andric 
450b57cec5SDimitry Andric class GDBRemoteRegisterContext : public RegisterContext {
460b57cec5SDimitry Andric public:
470b57cec5SDimitry Andric   GDBRemoteRegisterContext(ThreadGDBRemote &thread, uint32_t concrete_frame_idx,
48e8d8bef9SDimitry Andric                            GDBRemoteDynamicRegisterInfoSP reg_info_sp,
49480093f4SDimitry Andric                            bool read_all_at_once, bool write_all_at_once);
500b57cec5SDimitry Andric 
510b57cec5SDimitry Andric   ~GDBRemoteRegisterContext() override;
520b57cec5SDimitry Andric 
530b57cec5SDimitry Andric   void InvalidateAllRegisters() override;
540b57cec5SDimitry Andric 
550b57cec5SDimitry Andric   size_t GetRegisterCount() override;
560b57cec5SDimitry Andric 
570b57cec5SDimitry Andric   const RegisterInfo *GetRegisterInfoAtIndex(size_t reg) override;
580b57cec5SDimitry Andric 
590b57cec5SDimitry Andric   size_t GetRegisterSetCount() override;
600b57cec5SDimitry Andric 
610b57cec5SDimitry Andric   const RegisterSet *GetRegisterSet(size_t reg_set) override;
620b57cec5SDimitry Andric 
630b57cec5SDimitry Andric   bool ReadRegister(const RegisterInfo *reg_info,
640b57cec5SDimitry Andric                     RegisterValue &value) override;
650b57cec5SDimitry Andric 
660b57cec5SDimitry Andric   bool WriteRegister(const RegisterInfo *reg_info,
670b57cec5SDimitry Andric                      const RegisterValue &value) override;
680b57cec5SDimitry Andric 
6981ad6265SDimitry Andric   bool ReadAllRegisterValues(lldb::WritableDataBufferSP &data_sp) override;
700b57cec5SDimitry Andric 
710b57cec5SDimitry Andric   bool WriteAllRegisterValues(const lldb::DataBufferSP &data_sp) override;
720b57cec5SDimitry Andric 
730b57cec5SDimitry Andric   bool ReadAllRegisterValues(RegisterCheckpoint &reg_checkpoint) override;
740b57cec5SDimitry Andric 
750b57cec5SDimitry Andric   bool
760b57cec5SDimitry Andric   WriteAllRegisterValues(const RegisterCheckpoint &reg_checkpoint) override;
770b57cec5SDimitry Andric 
780b57cec5SDimitry Andric   uint32_t ConvertRegisterKindToRegisterNumber(lldb::RegisterKind kind,
790b57cec5SDimitry Andric                                                uint32_t num) override;
800b57cec5SDimitry Andric 
81*5f757f3fSDimitry Andric   bool RegisterWriteCausesReconfigure(const llvm::StringRef name) override;
82*5f757f3fSDimitry Andric 
83*5f757f3fSDimitry Andric   bool ReconfigureRegisterInfo() override;
84e8d8bef9SDimitry Andric 
850b57cec5SDimitry Andric protected:
860b57cec5SDimitry Andric   friend class ThreadGDBRemote;
870b57cec5SDimitry Andric 
88349cc55cSDimitry Andric   bool ReadRegisterBytes(const RegisterInfo *reg_info);
890b57cec5SDimitry Andric 
900b57cec5SDimitry Andric   bool WriteRegisterBytes(const RegisterInfo *reg_info, DataExtractor &data,
910b57cec5SDimitry Andric                           uint32_t data_offset);
920b57cec5SDimitry Andric 
930b57cec5SDimitry Andric   bool PrivateSetRegisterValue(uint32_t reg, llvm::ArrayRef<uint8_t> data);
940b57cec5SDimitry Andric 
950b57cec5SDimitry Andric   bool PrivateSetRegisterValue(uint32_t reg, uint64_t val);
960b57cec5SDimitry Andric 
970b57cec5SDimitry Andric   void SetAllRegisterValid(bool b);
980b57cec5SDimitry Andric 
GetRegisterIsValid(uint32_t reg)990b57cec5SDimitry Andric   bool GetRegisterIsValid(uint32_t reg) const {
1000b57cec5SDimitry Andric     assert(reg < m_reg_valid.size());
1010b57cec5SDimitry Andric     if (reg < m_reg_valid.size())
1020b57cec5SDimitry Andric       return m_reg_valid[reg];
1030b57cec5SDimitry Andric     return false;
1040b57cec5SDimitry Andric   }
1050b57cec5SDimitry Andric 
SetRegisterIsValid(const RegisterInfo * reg_info,bool valid)1060b57cec5SDimitry Andric   void SetRegisterIsValid(const RegisterInfo *reg_info, bool valid) {
1070b57cec5SDimitry Andric     if (reg_info)
1080b57cec5SDimitry Andric       return SetRegisterIsValid(reg_info->kinds[lldb::eRegisterKindLLDB],
1090b57cec5SDimitry Andric                                 valid);
1100b57cec5SDimitry Andric   }
1110b57cec5SDimitry Andric 
SetRegisterIsValid(uint32_t reg,bool valid)1120b57cec5SDimitry Andric   void SetRegisterIsValid(uint32_t reg, bool valid) {
1130b57cec5SDimitry Andric     assert(reg < m_reg_valid.size());
1140b57cec5SDimitry Andric     if (reg < m_reg_valid.size())
1150b57cec5SDimitry Andric       m_reg_valid[reg] = valid;
1160b57cec5SDimitry Andric   }
1170b57cec5SDimitry Andric 
118e8d8bef9SDimitry Andric   GDBRemoteDynamicRegisterInfoSP m_reg_info_sp;
1190b57cec5SDimitry Andric   std::vector<bool> m_reg_valid;
1200b57cec5SDimitry Andric   DataExtractor m_reg_data;
1210b57cec5SDimitry Andric   bool m_read_all_at_once;
122480093f4SDimitry Andric   bool m_write_all_at_once;
123fe6060f1SDimitry Andric   bool m_gpacket_cached;
1240b57cec5SDimitry Andric 
1250b57cec5SDimitry Andric private:
1260b57cec5SDimitry Andric   // Helper function for ReadRegisterBytes().
1270b57cec5SDimitry Andric   bool GetPrimordialRegister(const RegisterInfo *reg_info,
1280b57cec5SDimitry Andric                              GDBRemoteCommunicationClient &gdb_comm);
1290b57cec5SDimitry Andric   // Helper function for WriteRegisterBytes().
1300b57cec5SDimitry Andric   bool SetPrimordialRegister(const RegisterInfo *reg_info,
1310b57cec5SDimitry Andric                              GDBRemoteCommunicationClient &gdb_comm);
1320b57cec5SDimitry Andric 
1335ffd83dbSDimitry Andric   GDBRemoteRegisterContext(const GDBRemoteRegisterContext &) = delete;
1345ffd83dbSDimitry Andric   const GDBRemoteRegisterContext &
1355ffd83dbSDimitry Andric   operator=(const GDBRemoteRegisterContext &) = delete;
1360b57cec5SDimitry Andric };
1370b57cec5SDimitry Andric 
1380b57cec5SDimitry Andric } // namespace process_gdb_remote
1390b57cec5SDimitry Andric } // namespace lldb_private
1400b57cec5SDimitry Andric 
1415ffd83dbSDimitry Andric #endif // LLDB_SOURCE_PLUGINS_PROCESS_GDB_REMOTE_GDBREMOTEREGISTERCONTEXT_H
142