- 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
46 lines
1.6 KiB
C++
46 lines
1.6 KiB
C++
#pragma once
|
|
|
|
#include <string>
|
|
#include <set>
|
|
|
|
#include "CommandPacket.hpp"
|
|
#include "../Feature.hpp"
|
|
|
|
namespace DebugServer::Gdb::CommandPackets
|
|
{
|
|
/**
|
|
* The SupportedFeaturesQuery command packet is a query from the GDB client, requesting a list of GDB features
|
|
* supported by the GDB server. The body of this packet also contains a list GDB features that are supported or
|
|
* unsupported by the GDB client.
|
|
*
|
|
* The command packet is identified by its 'qSupported' prefix in the command packet data. Following the prefix is
|
|
* a list of GDB features that are supported/unsupported by the client. For more info on this command
|
|
* packet, see the GDP RSP documentation.
|
|
*
|
|
* Responses to this command packet should take the form of a ResponsePackets::SupportedFeaturesResponse.
|
|
*/
|
|
class SupportedFeaturesQuery: public CommandPacket
|
|
{
|
|
public:
|
|
explicit SupportedFeaturesQuery(const RawPacket& rawPacket);
|
|
|
|
[[nodiscard]] bool isFeatureSupported(const Feature& feature) const {
|
|
return this->supportedFeatures.find(feature) != this->supportedFeatures.end();
|
|
}
|
|
|
|
[[nodiscard]] const std::set<Feature>& getSupportedFeatures() const {
|
|
return this->supportedFeatures;
|
|
}
|
|
|
|
void handle(
|
|
DebugSession& debugSession,
|
|
const TargetDescriptor& gdbTargetDescriptor,
|
|
const Targets::TargetDescriptor& targetDescriptor,
|
|
Services::TargetControllerService& targetControllerService
|
|
) override;
|
|
|
|
private:
|
|
std::set<Feature> supportedFeatures;
|
|
};
|
|
}
|