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 ®_checkpoint) override; 740b57cec5SDimitry Andric 750b57cec5SDimitry Andric bool 760b57cec5SDimitry Andric WriteAllRegisterValues(const RegisterCheckpoint ®_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