2022-03-24 19:06:09 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
2022-03-31 21:52:46 +01:00
|
|
|
#include "src/DebugServer/Gdb/TargetDescriptor.hpp"
|
2022-03-24 19:06:09 +00:00
|
|
|
|
|
|
|
|
#include "src/Helpers/BiMap.hpp"
|
|
|
|
|
|
2022-03-31 16:05:39 +01:00
|
|
|
namespace Bloom::DebugServer::Gdb::AvrGdb
|
2022-03-24 19:06:09 +00:00
|
|
|
{
|
2022-03-31 16:05:39 +01:00
|
|
|
class TargetDescriptor: public DebugServer::Gdb::TargetDescriptor
|
2022-03-24 19:06:09 +00:00
|
|
|
{
|
|
|
|
|
public:
|
|
|
|
|
BiMap<GdbRegisterNumberType, RegisterDescriptor> registerDescriptorsByGdbNumber = {};
|
|
|
|
|
BiMap<GdbRegisterNumberType, Targets::TargetRegisterDescriptor> targetRegisterDescriptorsByGdbNumber = {};
|
|
|
|
|
|
2022-03-25 00:12:16 +00:00
|
|
|
explicit TargetDescriptor(const Targets::TargetDescriptor& targetDescriptor);
|
2022-03-24 19:06:09 +00:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Should retrieve the GDB register number, given a target register descriptor. Or std::nullopt if the target
|
|
|
|
|
* register descriptor isn't mapped to any GDB register.
|
|
|
|
|
*
|
|
|
|
|
* @param registerDescriptor
|
|
|
|
|
* @return
|
|
|
|
|
*/
|
|
|
|
|
std::optional<GdbRegisterNumberType> getRegisterNumberFromTargetRegisterDescriptor(
|
|
|
|
|
const Targets::TargetRegisterDescriptor& registerDescriptor
|
2022-03-25 00:12:16 +00:00
|
|
|
) const override;
|
2022-03-24 19:06:09 +00:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Should retrieve the GDB register descriptor for a given GDB register number.
|
|
|
|
|
*
|
|
|
|
|
* @param number
|
|
|
|
|
* @return
|
|
|
|
|
*/
|
2022-03-25 00:12:16 +00:00
|
|
|
const RegisterDescriptor& getRegisterDescriptorFromNumber(GdbRegisterNumberType number) const override;
|
2022-03-24 19:06:09 +00:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Should retrieve the mapped target register descriptor for a given GDB register number.
|
|
|
|
|
*
|
|
|
|
|
* @param number
|
|
|
|
|
* @return
|
|
|
|
|
*/
|
|
|
|
|
const Targets::TargetRegisterDescriptor& getTargetRegisterDescriptorFromNumber(
|
|
|
|
|
GdbRegisterNumberType number
|
2022-03-25 00:12:16 +00:00
|
|
|
) const override;
|
2022-03-24 19:06:09 +00:00
|
|
|
|
2022-03-25 00:14:32 +00:00
|
|
|
const std::vector<GdbRegisterNumberType>& getRegisterNumbers() const override;
|
|
|
|
|
|
2022-03-24 19:06:09 +00:00
|
|
|
private:
|
2022-03-25 00:19:32 +00:00
|
|
|
std::vector<GdbRegisterNumberType> registerNumbers = std::vector<GdbRegisterNumberType>(35);
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* For AVR targets, avr-gdb defines 35 registers in total:
|
|
|
|
|
*
|
|
|
|
|
* Register number 0 through 31 are general purpose registers
|
|
|
|
|
* Register number 32 is the status register (SREG)
|
|
|
|
|
* Register number 33 is the stack pointer register
|
|
|
|
|
* Register number 34 is the program counter register
|
|
|
|
|
*
|
|
|
|
|
* This function will prepare the appropriate GDB register numbers and mappings.
|
|
|
|
|
*/
|
2022-03-24 19:06:09 +00:00
|
|
|
void loadRegisterMappings();
|
|
|
|
|
};
|
|
|
|
|
}
|