- Refactored entire codebase (excluding the Insight component) to accommodate multiple target architectures (no longer specific to AVR) - Deleted 'generate SVD' GDB monitor command - I will eventually move this functionality to the Bloom website - Added unit size property to address spaces - Many other changes which I couldn't be bothered to describe here
83 lines
2.8 KiB
C++
83 lines
2.8 KiB
C++
#include "SetBreakpoint.hpp"
|
|
|
|
#include <QtCore/QString>
|
|
|
|
#include "src/DebugServer/Gdb/ResponsePackets/OkResponsePacket.hpp"
|
|
#include "src/DebugServer/Gdb/ResponsePackets/EmptyResponsePacket.hpp"
|
|
#include "src/DebugServer/Gdb/ResponsePackets/ErrorResponsePacket.hpp"
|
|
|
|
#include "src/Targets/TargetBreakpoint.hpp"
|
|
|
|
#include "src/Logger/Logger.hpp"
|
|
#include "src/Exceptions/Exception.hpp"
|
|
|
|
namespace DebugServer::Gdb::CommandPackets
|
|
{
|
|
using Services::TargetControllerService;
|
|
|
|
using Targets::TargetBreakpoint;
|
|
|
|
using ResponsePackets::OkResponsePacket;
|
|
using ResponsePackets::ErrorResponsePacket;
|
|
using ResponsePackets::EmptyResponsePacket;
|
|
|
|
using ::Exceptions::Exception;
|
|
|
|
SetBreakpoint::SetBreakpoint(const RawPacket& rawPacket)
|
|
: CommandPacket(rawPacket)
|
|
{
|
|
if (this->data.size() < 6) {
|
|
throw Exception{"Unexpected SetBreakpoint packet size"};
|
|
}
|
|
|
|
// Z0 = SW breakpoint, Z1 = HW breakpoint
|
|
this->type = (this->data[1] == '0')
|
|
? BreakpointType::SOFTWARE_BREAKPOINT
|
|
: (this->data[1] == '1') ? BreakpointType::HARDWARE_BREAKPOINT : BreakpointType::UNKNOWN;
|
|
|
|
auto packetData = QString::fromLocal8Bit(
|
|
reinterpret_cast<const char*>(this->data.data() + 2),
|
|
static_cast<int>(this->data.size() - 2)
|
|
);
|
|
|
|
auto packetSegments = packetData.split(",");
|
|
if (packetSegments.size() < 3) {
|
|
throw Exception{"Unexpected number of packet segments in SetBreakpoint packet"};
|
|
}
|
|
|
|
bool conversionStatus = true;
|
|
this->address = packetSegments.at(1).toUInt(&conversionStatus, 16);
|
|
|
|
if (!conversionStatus) {
|
|
throw Exception{"Failed to convert address hex value from SetBreakpoint packet."};
|
|
}
|
|
}
|
|
|
|
void SetBreakpoint::handle(
|
|
DebugSession& debugSession,
|
|
const TargetDescriptor& gdbTargetDescriptor,
|
|
const Targets::TargetDescriptor&,
|
|
TargetControllerService& targetControllerService
|
|
) {
|
|
Logger::info("Handling SetBreakpoint packet");
|
|
|
|
try {
|
|
if (this->type == BreakpointType::UNKNOWN) {
|
|
Logger::debug(
|
|
"Rejecting breakpoint at address " + std::to_string(this->address)
|
|
+ " - unsupported breakpoint type"
|
|
);
|
|
debugSession.connection.writePacket(EmptyResponsePacket{});
|
|
return;
|
|
}
|
|
|
|
debugSession.setExternalBreakpoint(this->address, targetControllerService);
|
|
debugSession.connection.writePacket(OkResponsePacket{});
|
|
|
|
} catch (const Exception& exception) {
|
|
Logger::error("Failed to set breakpoint on target - " + exception.getMessage());
|
|
debugSession.connection.writePacket(ErrorResponsePacket{});
|
|
}
|
|
}
|
|
}
|