Target register tidying
This commit is contained in:
@@ -15,7 +15,6 @@ namespace Bloom::DebugServers::Gdb::ResponsePackets
|
||||
{
|
||||
public:
|
||||
Signal signal;
|
||||
std::optional<Targets::TargetRegisterMap> registerMap;
|
||||
std::optional<StopReason> stopReason;
|
||||
|
||||
explicit TargetStopped(Signal signal): signal(signal) {}
|
||||
@@ -32,13 +31,6 @@ namespace Bloom::DebugServers::Gdb::ResponsePackets
|
||||
}
|
||||
}
|
||||
|
||||
if (this->registerMap.has_value()) {
|
||||
for (const auto& [registerId, registerValue] : this->registerMap.value()) {
|
||||
output += Packet::dataToHex({static_cast<unsigned char>(registerId)});
|
||||
output += ":" + Packet::dataToHex(registerValue.value) + ";";
|
||||
}
|
||||
}
|
||||
|
||||
return std::vector<unsigned char>(output.begin(), output.end());
|
||||
}
|
||||
};
|
||||
|
||||
@@ -1197,7 +1197,12 @@ TargetRegisters EdbgAvr8Interface::readGeneralPurposeRegisters(std::set<std::siz
|
||||
continue;
|
||||
}
|
||||
|
||||
output.push_back(TargetRegister(registerIndex, {registers[registerIndex]}));
|
||||
output.push_back(
|
||||
TargetRegister(
|
||||
{registerIndex, TargetRegisterType::GENERAL_PURPOSE_REGISTER},
|
||||
{registers[registerIndex]}
|
||||
)
|
||||
);
|
||||
}
|
||||
|
||||
return output;
|
||||
|
||||
@@ -12,17 +12,17 @@ namespace Bloom::Targets
|
||||
PROGRAM_COUNTER,
|
||||
STACK_POINTER,
|
||||
STATUS_REGISTER,
|
||||
OTHER,
|
||||
};
|
||||
|
||||
struct TargetRegisterDescriptor
|
||||
{
|
||||
using IdType = size_t;
|
||||
std::optional<IdType> id;
|
||||
TargetRegisterType type = TargetRegisterType::GENERAL_PURPOSE_REGISTER;
|
||||
std::optional<size_t> id;
|
||||
TargetRegisterType type = TargetRegisterType::OTHER;
|
||||
|
||||
TargetRegisterDescriptor() = default;
|
||||
explicit TargetRegisterDescriptor(TargetRegisterType type): type(type) {};
|
||||
TargetRegisterDescriptor(IdType id, TargetRegisterType type): id(id), type(type) {};
|
||||
TargetRegisterDescriptor(size_t id, TargetRegisterType type): id(id), type(type) {};
|
||||
|
||||
bool operator==(const TargetRegisterDescriptor& other) const {
|
||||
return this->id == other.id && this->type == other.type;
|
||||
@@ -31,19 +31,12 @@ namespace Bloom::Targets
|
||||
|
||||
struct TargetRegister
|
||||
{
|
||||
std::optional<size_t> id;
|
||||
std::vector<unsigned char> value;
|
||||
TargetRegisterDescriptor descriptor;
|
||||
|
||||
explicit TargetRegister(std::vector<unsigned char> value): value(std::move(value)) {};
|
||||
std::vector<unsigned char> value;
|
||||
|
||||
TargetRegister(TargetRegisterDescriptor descriptor, std::vector<unsigned char> value): value(std::move(value)),
|
||||
descriptor(descriptor) {};
|
||||
|
||||
TargetRegister(size_t id, std::vector<unsigned char> value): id(id), value(std::move(value)) {
|
||||
this->descriptor.id = id;
|
||||
};
|
||||
|
||||
[[nodiscard]] size_t size() const {
|
||||
return this->value.size();
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user