Suspend TargetController upon GDB detach, if running under CLion

This commit is contained in:
Nav
2022-09-15 00:33:01 +01:00
parent 753cfd7c11
commit c9a8220500
5 changed files with 68 additions and 6 deletions

View File

@@ -31,9 +31,11 @@
#include "CommandPackets/BloomVersion.hpp"
#include "CommandPackets/BloomVersionMachine.hpp"
#include "CommandPackets/GenerateSvd.hpp"
#include "CommandPackets/Detach.hpp"
// Response packets
#include "ResponsePackets/TargetStopped.hpp"
#include "src/Helpers/Process.hpp"
namespace Bloom::DebugServer::Gdb
{
@@ -122,6 +124,12 @@ namespace Bloom::DebugServer::Gdb
this->eventListener.registerCallbackForEventType<Events::TargetExecutionStopped>(
std::bind(&GdbRspDebugServer::onTargetExecutionStopped, this, std::placeholders::_1)
);
if (Process::isProcessManagedByClion(Process::getParentProcessId())) {
Logger::warning(
"Bloom's process is being managed by CLion - Bloom will automatically shutdown upon detaching from GDB."
);
}
}
void GdbRspDebugServer::close() {
@@ -252,6 +260,10 @@ namespace Bloom::DebugServer::Gdb
return std::make_unique<CommandPackets::InterruptExecution>(rawPacket);
}
if (rawPacket[1] == 'D') {
return std::make_unique<CommandPackets::Detach>(rawPacket);
}
const auto rawPacketString = std::string(rawPacket.begin(), rawPacket.end());
if (rawPacketString.size() >= 2) {