| gem5 [DEVELOP-FOR-25.0]
    | 
#include <remote_gdb.hh>
 
  
| Classes | |
| struct | GEM5_PACKED | 
| RISC-V Register Cache Order and sizes of registers found in ext/gdb-xml/riscv.xml To add support for more CSRs:  More... | |
| Public Member Functions | |
| char * | data () | 
| Return the pointer to the raw bytes buffer containing the register values. | |
| size_t | size () const | 
| Return the size of the raw buffer, in bytes (i.e., half of the number of digits in the g/G packet). | |
| void | getRegs (ThreadContext *) | 
| Fill the raw buffer from the registers in the ThreadContext. | |
| void | setRegs (ThreadContext *) const | 
| Set the ThreadContext's registers from the values in the raw buffer. | |
| const std::string | name () const | 
| Return the name to use in places like DPRINTF. | |
|  Public Member Functions inherited from gem5::BaseGdbRegCache | |
| BaseGdbRegCache (BaseRemoteGDB *g) | |
| virtual | ~BaseGdbRegCache () | 
| Protected Attributes | |
| struct gem5::RiscvISA::RemoteGDB::Riscv32GdbRegCache::GEM5_PACKED | r | 
|  Protected Attributes inherited from gem5::BaseGdbRegCache | |
| BaseRemoteGDB * | gdb | 
| Private Member Functions | |
| BaseGdbRegCache (BaseRemoteGDB *g) | |
Definition at line 65 of file remote_gdb.hh.
| 
 | inlineprivate | 
Definition at line 134 of file remote_gdb.hh.
| 
 | inlinevirtual | 
Return the pointer to the raw bytes buffer containing the register values.
Each byte of this buffer is literally encoded as two hex digits in the g or G RSP packet.
Implements gem5::BaseGdbRegCache.
Definition at line 141 of file remote_gdb.hh.
References r.
| 
 | virtual | 
Fill the raw buffer from the registers in the ThreadContext.
Implements gem5::BaseGdbRegCache.
Definition at line 251 of file remote_gdb.cc.
References gem5::BaseRemoteGDB::context(), gem5::RiscvISA::CSR_CYCLE, gem5::RiscvISA::CSR_CYCLEH, gem5::RiscvISA::CSR_FCSR, gem5::RiscvISA::CSR_FFLAGS, gem5::RiscvISA::CSR_FRM, gem5::RiscvISA::CSR_MARCHID, gem5::RiscvISA::CSR_MCAUSE, gem5::RiscvISA::CSR_MCOUNTEREN, gem5::RiscvISA::CSR_MEDELEG, gem5::RiscvISA::CSR_MEPC, gem5::RiscvISA::CSR_MIDELEG, gem5::RiscvISA::CSR_MIE, gem5::RiscvISA::CSR_MIMPID, gem5::RiscvISA::CSR_MIP, gem5::RiscvISA::CSR_MISA, gem5::RiscvISA::CSR_MSCRATCH, gem5::RiscvISA::CSR_MSTATUS, gem5::RiscvISA::CSR_MSTATUSH, gem5::RiscvISA::CSR_MTVAL, gem5::RiscvISA::CSR_MTVEC, gem5::RiscvISA::CSR_MVENDORID, gem5::RiscvISA::CSR_SATP, gem5::RiscvISA::CSR_SCAUSE, gem5::RiscvISA::CSR_SCOUNTEREN, gem5::RiscvISA::CSR_SEDELEG, gem5::RiscvISA::CSR_SENVCFG, gem5::RiscvISA::CSR_SEPC, gem5::RiscvISA::CSR_SIDELEG, gem5::RiscvISA::CSR_SIE, gem5::RiscvISA::CSR_SIP, gem5::RiscvISA::CSR_SSCRATCH, gem5::RiscvISA::CSR_SSTATUS, gem5::RiscvISA::CSR_STVAL, gem5::RiscvISA::CSR_STVEC, gem5::RiscvISA::CSR_TIME, gem5::RiscvISA::CSR_TIMEH, gem5::RiscvISA::CSR_UCAUSE, gem5::RiscvISA::CSR_UEPC, gem5::RiscvISA::CSR_UIE, gem5::RiscvISA::CSR_UIP, gem5::RiscvISA::CSR_USCRATCH, gem5::RiscvISA::CSR_USTATUS, gem5::RiscvISA::CSR_UTVAL, gem5::RiscvISA::CSR_UTVEC, gem5::RiscvISA::CSRData, gem5::RiscvISA::CSRMasks, DPRINTF, gem5::RiscvISA::floatRegClass(), gem5::BaseGdbRegCache::gdb, gem5::RiscvISA::RemoteGDB::getPrivilegeModeSet(), getRegs(), gem5::RiscvISA::i, gem5::RiscvISA::intRegClass(), gem5::RiscvISA::int_reg::NumArchRegs, gem5::RiscvISA::float_reg::NumRegs, r, gem5::RiscvISA::RemoteGDB::RemoteGDB(), gem5::RiscvISA::RV32, and size().
Referenced by getRegs().
| 
 | inlinevirtual | 
Return the name to use in places like DPRINTF.
Having each concrete superclass redefine this member is useful in situations where the class of the regCache can change on the fly.
Implements gem5::BaseGdbRegCache.
Definition at line 147 of file remote_gdb.hh.
References gem5::BaseGdbRegCache::gdb.
| 
 | virtual | 
Set the ThreadContext's registers from the values in the raw buffer.
Implements gem5::BaseGdbRegCache.
Definition at line 372 of file remote_gdb.cc.
References gem5::BaseRemoteGDB::context(), gem5::RiscvISA::CSR_FCSR, gem5::RiscvISA::CSR_FFLAGS, gem5::RiscvISA::CSR_FRM, gem5::RiscvISA::CSR_MCAUSE, gem5::RiscvISA::CSR_MCOUNTEREN, gem5::RiscvISA::CSR_MEDELEG, gem5::RiscvISA::CSR_MEPC, gem5::RiscvISA::CSR_MIDELEG, gem5::RiscvISA::CSR_MIE, gem5::RiscvISA::CSR_MIP, gem5::RiscvISA::CSR_MISA, gem5::RiscvISA::CSR_MSCRATCH, gem5::RiscvISA::CSR_MSTATUS, gem5::RiscvISA::CSR_MTVAL, gem5::RiscvISA::CSR_MTVEC, gem5::RiscvISA::CSR_SATP, gem5::RiscvISA::CSR_SCAUSE, gem5::RiscvISA::CSR_SCOUNTEREN, gem5::RiscvISA::CSR_SEDELEG, gem5::RiscvISA::CSR_SENVCFG, gem5::RiscvISA::CSR_SEPC, gem5::RiscvISA::CSR_SIDELEG, gem5::RiscvISA::CSR_SIE, gem5::RiscvISA::CSR_SIP, gem5::RiscvISA::CSR_SSCRATCH, gem5::RiscvISA::CSR_SSTATUS, gem5::RiscvISA::CSR_STVAL, gem5::RiscvISA::CSR_STVEC, gem5::RiscvISA::CSR_UCAUSE, gem5::RiscvISA::CSR_UEPC, gem5::RiscvISA::CSR_UIE, gem5::RiscvISA::CSR_UIP, gem5::RiscvISA::CSR_USCRATCH, gem5::RiscvISA::CSR_USTATUS, gem5::RiscvISA::CSR_UTVAL, gem5::RiscvISA::CSR_UTVEC, gem5::RiscvISA::CSRData, DPRINTF, gem5::RiscvISA::floatRegClass(), gem5::BaseGdbRegCache::gdb, gem5::RiscvISA::RemoteGDB::getPrivilegeModeSet(), gem5::RiscvISA::i, gem5::RiscvISA::intRegClass(), gem5::RiscvISA::int_reg::NumArchRegs, gem5::RiscvISA::float_reg::NumRegs, r, gem5::RiscvISA::RemoteGDB::RemoteGDB(), gem5::RiscvISA::RV32, gem5::setRegNoEffectWithMask(), setRegs(), and gem5::setRegWithMask().
Referenced by setRegs().
| 
 | inlinevirtual | 
Return the size of the raw buffer, in bytes (i.e., half of the number of digits in the g/G packet).
Implements gem5::BaseGdbRegCache.
Definition at line 142 of file remote_gdb.hh.
References r.
Referenced by getRegs().
| 
 | protected |