2023-11-21 21:40:40 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include <cstdint>
|
2024-07-23 21:14:22 +01:00
|
|
|
#include <set>
|
|
|
|
|
#include <vector>
|
|
|
|
|
#include <optional>
|
2023-11-21 21:40:40 +00:00
|
|
|
|
2024-07-23 21:14:22 +01:00
|
|
|
#include "src/Targets/TargetDescriptor.hpp"
|
|
|
|
|
#include "src/Targets/TargetAddressSpaceDescriptor.hpp"
|
|
|
|
|
#include "src/Targets/TargetMemorySegmentDescriptor.hpp"
|
|
|
|
|
#include "src/Targets/TargetState.hpp"
|
|
|
|
|
#include "src/Targets/TargetRegisterDescriptor.hpp"
|
|
|
|
|
#include "src/Targets/TargetMemory.hpp"
|
2023-11-21 21:40:40 +00:00
|
|
|
|
|
|
|
|
namespace DebugToolDrivers::TargetInterfaces::RiscV
|
|
|
|
|
{
|
|
|
|
|
class RiscVDebugInterface
|
|
|
|
|
{
|
|
|
|
|
public:
|
2024-07-23 21:14:22 +01:00
|
|
|
virtual void init() = 0;
|
|
|
|
|
virtual void activate() = 0;
|
|
|
|
|
virtual void deactivate() = 0;
|
2023-11-21 21:40:40 +00:00
|
|
|
|
2024-07-23 21:14:22 +01:00
|
|
|
virtual Targets::TargetExecutionState getExecutionState() = 0;
|
2023-11-21 21:40:40 +00:00
|
|
|
|
2024-07-23 21:14:22 +01:00
|
|
|
virtual void stop() = 0;
|
|
|
|
|
virtual void run() = 0;
|
|
|
|
|
virtual void step() = 0;
|
|
|
|
|
virtual void reset() = 0;
|
2023-11-21 21:40:40 +00:00
|
|
|
|
2024-07-23 21:14:22 +01:00
|
|
|
virtual void setSoftwareBreakpoint(Targets::TargetMemoryAddress address) = 0;
|
|
|
|
|
virtual void clearSoftwareBreakpoint(Targets::TargetMemoryAddress address) = 0;
|
2023-11-21 21:40:40 +00:00
|
|
|
|
2024-10-06 17:54:08 +01:00
|
|
|
virtual std::uint16_t getHardwareBreakpointCount() = 0;
|
2024-07-23 21:14:22 +01:00
|
|
|
virtual void setHardwareBreakpoint(Targets::TargetMemoryAddress address) = 0;
|
|
|
|
|
virtual void clearHardwareBreakpoint(Targets::TargetMemoryAddress address) = 0;
|
2024-10-07 20:02:39 +01:00
|
|
|
virtual void clearAllHardwareBreakpoints() = 0;
|
2023-11-21 21:40:40 +00:00
|
|
|
|
2024-07-23 21:14:22 +01:00
|
|
|
virtual Targets::TargetRegisterDescriptorAndValuePairs readCpuRegisters(
|
|
|
|
|
const Targets::TargetRegisterDescriptors& descriptors
|
2023-11-21 21:40:40 +00:00
|
|
|
) = 0;
|
2024-07-23 21:14:22 +01:00
|
|
|
virtual void writeCpuRegisters(const Targets::TargetRegisterDescriptorAndValuePairs& registers) = 0;
|
|
|
|
|
|
|
|
|
|
virtual Targets::TargetMemoryBuffer readMemory(
|
|
|
|
|
const Targets::TargetAddressSpaceDescriptor& addressSpaceDescriptor,
|
|
|
|
|
const Targets::TargetMemorySegmentDescriptor& memorySegmentDescriptor,
|
|
|
|
|
Targets::TargetMemoryAddress startAddress,
|
|
|
|
|
Targets::TargetMemorySize bytes,
|
|
|
|
|
const std::set<Targets::TargetMemoryAddressRange>& excludedAddressRanges = {}
|
|
|
|
|
) = 0;
|
|
|
|
|
virtual void writeMemory(
|
|
|
|
|
const Targets::TargetAddressSpaceDescriptor& addressSpaceDescriptor,
|
|
|
|
|
const Targets::TargetMemorySegmentDescriptor& memorySegmentDescriptor,
|
|
|
|
|
Targets::TargetMemoryAddress startAddress,
|
|
|
|
|
const Targets::TargetMemoryBuffer& buffer
|
2023-11-21 21:40:40 +00:00
|
|
|
) = 0;
|
|
|
|
|
};
|
|
|
|
|
}
|