2021-04-04 21:04:12 +01:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include <cstdint>
|
|
|
|
|
#include <optional>
|
|
|
|
|
|
2022-03-24 19:17:41 +00:00
|
|
|
#include "AbstractMemoryAccessPacket.hpp"
|
2021-04-04 21:04:12 +01:00
|
|
|
|
2022-03-31 16:05:39 +01:00
|
|
|
namespace Bloom::DebugServer::Gdb::AvrGdb::CommandPackets
|
2021-04-04 21:04:12 +01:00
|
|
|
{
|
|
|
|
|
/**
|
|
|
|
|
* The WriteMemory class implements the structure for "M" packets. Upon receiving this packet, the server is
|
|
|
|
|
* expected to write data to the target's memory, at the specified start address.
|
|
|
|
|
*/
|
2022-03-24 19:17:41 +00:00
|
|
|
class WriteMemory: public AbstractMemoryAccessPacket
|
2021-04-04 21:04:12 +01:00
|
|
|
{
|
|
|
|
|
public:
|
|
|
|
|
/**
|
|
|
|
|
* Like with the ReadMemory command packet, the start address carries additional bits that indicate
|
|
|
|
|
* the memory type.
|
|
|
|
|
*/
|
2021-06-22 23:52:31 +01:00
|
|
|
std::uint32_t startAddress = 0;
|
2021-04-04 21:04:12 +01:00
|
|
|
|
2021-05-24 20:58:49 +01:00
|
|
|
Targets::TargetMemoryBuffer buffer;
|
2021-04-04 21:04:12 +01:00
|
|
|
|
2022-04-03 17:42:00 +01:00
|
|
|
explicit WriteMemory(const std::vector<unsigned char>& rawPacket);
|
2021-04-04 21:04:12 +01:00
|
|
|
|
2022-03-24 19:17:41 +00:00
|
|
|
void handle(DebugSession& debugSession, TargetControllerConsole& targetControllerConsole) override;
|
2021-04-04 21:04:12 +01:00
|
|
|
};
|
|
|
|
|
}
|