HF Interface Wrapper 0.1.0-dev
Embedded C++ hardware abstraction layer
Loading...
Searching...
No Matches
BaseSpi.h
Go to the documentation of this file.
1
21#pragma once
22
23#include "HardwareTypes.h"
24#include <cstdint>
25#include <string_view>
26
32//--------------------------------------
33// HardFOC SPI Error Codes (Table)
34//--------------------------------------
43#define HF_SPI_ERR_LIST(X) \
44 /* Success codes */ \
45 X(SPI_SUCCESS, 0, "Success") \
46 /* General errors */ \
47 X(SPI_ERR_FAILURE, 1, "General failure") \
48 X(SPI_ERR_NOT_INITIALIZED, 2, "Not initialized") \
49 X(SPI_ERR_ALREADY_INITIALIZED, 3, "Already initialized") \
50 X(SPI_ERR_INVALID_PARAMETER, 4, "Invalid parameter") \
51 X(SPI_ERR_NULL_POINTER, 5, "Null pointer") \
52 X(SPI_ERR_OUT_OF_MEMORY, 6, "Out of memory") \
53 /* Bus errors */ \
54 X(SPI_ERR_BUS_BUSY, 7, "Bus busy") \
55 X(SPI_ERR_BUS_ERROR, 8, "Bus error") \
56 X(SPI_ERR_BUS_NOT_AVAILABLE, 9, "Bus not available") \
57 X(SPI_ERR_BUS_TIMEOUT, 10, "Bus timeout") \
58 /* Transfer errors */ \
59 X(SPI_ERR_TRANSFER_FAILED, 11, "Transfer failed") \
60 X(SPI_ERR_TRANSFER_TIMEOUT, 12, "Transfer timeout") \
61 X(SPI_ERR_TRANSFER_TOO_LONG, 13, "Transfer too long") \
62 X(SPI_ERR_TRANSFER_SIZE_MISMATCH, 14, "Transfer size mismatch") \
63 /* Device errors */ \
64 X(SPI_ERR_DEVICE_NOT_FOUND, 15, "Device not found") \
65 X(SPI_ERR_DEVICE_NOT_RESPONDING, 16, "Device not responding") \
66 X(SPI_ERR_CS_CONTROL_FAILED, 17, "Chip select control failed") \
67 /* Hardware errors */ \
68 X(SPI_ERR_HARDWARE_FAULT, 18, "Hardware fault") \
69 X(SPI_ERR_COMMUNICATION_FAILURE, 19, "Communication failure") \
70 X(SPI_ERR_VOLTAGE_OUT_OF_RANGE, 20, "Voltage out of range") \
71 X(SPI_ERR_CLOCK_ERROR, 21, "Clock error") \
72 /* Configuration errors */ \
73 X(SPI_ERR_INVALID_CONFIGURATION, 22, "Invalid configuration") \
74 X(SPI_ERR_UNSUPPORTED_OPERATION, 23, "Unsupported operation") \
75 X(SPI_ERR_INVALID_CLOCK_SPEED, 24, "Invalid clock speed") \
76 X(SPI_ERR_INVALID_MODE, 25, "Invalid SPI mode") \
77 X(SPI_ERR_PIN_CONFIGURATION_ERROR, 26, "Pin configuration error") \
78 /* System errors */ \
79 X(SPI_ERR_SYSTEM_ERROR, 27, "System error") \
80 X(SPI_ERR_PERMISSION_DENIED, 28, "Permission denied") \
81 X(SPI_ERR_OPERATION_ABORTED, 29, "Operation aborted") \
82 X(SPI_ERR_UNKNOWN, 30, "Unknown error")
83
84enum class hf_spi_err_t : hf_u8_t {
85#define X(NAME, VALUE, DESC) NAME = VALUE,
87#undef X
88};
89
95constexpr std::string_view HfSpiErrToString(hf_spi_err_t err) noexcept {
96 switch (err) {
97#define X(NAME, VALUE, DESC) \
98 case hf_spi_err_t::NAME: \
99 return DESC;
101#undef X
102 default:
104 }
105}
106
128
149
150//--------------------------------------
151// Abstract Base Class
152//--------------------------------------
153
184class BaseSpi {
185public:
189 virtual ~BaseSpi() noexcept = default;
190
191 // Non-copyable, non-movable (can be changed in derived classes if needed)
192 BaseSpi(const BaseSpi&) = delete;
193 BaseSpi& operator=(const BaseSpi&) = delete;
194 BaseSpi(BaseSpi&&) = delete;
195 BaseSpi& operator=(BaseSpi&&) = delete;
196
201 bool EnsureInitialized() noexcept {
202 if (!initialized_) {
204 }
205 return initialized_;
206 }
207
212 bool EnsureDeinitialized() noexcept {
213 if (initialized_) {
215 }
216 return !initialized_;
217 }
218
223 [[nodiscard]] bool IsInitialized() const noexcept {
224 return initialized_;
225 }
226
227 //==============================================//
228 // PURE VIRTUAL FUNCTIONS - MUST BE OVERRIDDEN //
229 //==============================================//
230
236 virtual bool Initialize() noexcept = 0;
237
243 virtual bool Deinitialize() noexcept = 0;
244
255 virtual hf_spi_err_t Transfer(const hf_u8_t* tx_data, hf_u8_t* rx_data, hf_u16_t length,
256 hf_u32_t timeout_ms = 0) noexcept = 0;
257
262 virtual const void* GetDeviceConfig() const noexcept = 0;
263
264 //==============================================//
265 // CONVENIENCE METHODS WITH DEFAULT IMPLEMENTATIONS //
266 //==============================================//
267
272 virtual bool Open() noexcept {
273 return EnsureInitialized();
274 }
275
280 virtual bool Close() noexcept {
281 if (initialized_) {
283 return !initialized_;
284 }
285 return true;
286 }
287
295 virtual bool Transfer(const hf_u8_t* tx_data, hf_u8_t* rx_data, hf_u16_t length) noexcept {
296 if (!EnsureInitialized()) {
297 return false;
298 }
299 return Transfer(tx_data, rx_data, length, 0) == hf_spi_err_t::SPI_SUCCESS;
300 }
301
309 virtual hf_spi_err_t Write(const hf_u8_t* data, hf_u16_t length,
310 hf_u32_t timeout_ms = 0) noexcept {
311 return Transfer(data, nullptr, length, timeout_ms);
312 }
313
321 virtual hf_spi_err_t Read(hf_u8_t* data, hf_u16_t length, hf_u32_t timeout_ms = 0) noexcept {
322 return Transfer(nullptr, data, length, timeout_ms);
323 }
324
331 virtual bool Write(const hf_u8_t* data, hf_u16_t length) noexcept {
332 if (!EnsureInitialized()) {
333 return false;
334 }
335 return Write(data, length, 0) == hf_spi_err_t::SPI_SUCCESS;
336 }
337
344 virtual bool Read(hf_u8_t* data, hf_u16_t length) noexcept {
345 if (!EnsureInitialized()) {
346 return false;
347 }
348 return Read(data, length, 0) == hf_spi_err_t::SPI_SUCCESS;
349 }
350
356 virtual bool WriteByte(hf_u8_t data) noexcept {
357 return Write(&data, 1, 0) == hf_spi_err_t::SPI_SUCCESS;
358 }
359
365 virtual bool ReadByte(hf_u8_t& data) noexcept {
366 return Read(&data, 1, 0) == hf_spi_err_t::SPI_SUCCESS;
367 }
368
375 virtual bool TransferByte(hf_u8_t tx_data, hf_u8_t& rx_data) noexcept {
376 return Transfer(&tx_data, &rx_data, 1, 0) == hf_spi_err_t::SPI_SUCCESS;
377 }
378
379 //==============================================//
380 // STATISTICS AND DIAGNOSTICS
381 //==============================================//
382
388 virtual hf_spi_err_t ResetStatistics() noexcept {
389 statistics_ = hf_spi_statistics_t{}; // Reset statistics to default values
391 }
392
398 virtual hf_spi_err_t ResetDiagnostics() noexcept {
399 diagnostics_ = hf_spi_diagnostics_t{}; // Reset diagnostics to default values
401 }
402
408 virtual hf_spi_err_t GetStatistics(hf_spi_statistics_t& statistics) const noexcept {
409 statistics = statistics_; // Return statistics by default
411 }
412
418 virtual hf_spi_err_t GetDiagnostics(hf_spi_diagnostics_t& diagnostics) const noexcept {
419 diagnostics = diagnostics_; // Return diagnostics by default
421 }
422
423protected:
428 BaseSpi() noexcept : initialized_(false), statistics_{}, diagnostics_{} {}
429
433};
hf_spi_err_t
Definition BaseSpi.h:84
@ SPI_ERR_UNSUPPORTED_OPERATION
constexpr std::string_view HfSpiErrToString(hf_spi_err_t err) noexcept
Convert hf_spi_err_t to human-readable string.
Definition BaseSpi.h:95
#define X(NAME, VALUE, DESC)
Definition BaseSpi.h:85
Platform-agnostic hardware type definitions for the HardFOC system.
uint32_t hf_u32_t
Platform-agnostic 32-bit unsigned integer type.
Definition HardwareTypes.h:52
uint8_t hf_u8_t
Platform-agnostic 8-bit unsigned integer type.
Definition HardwareTypes.h:40
uint64_t hf_u64_t
Platform-agnostic 64-bit unsigned integer type.
Definition HardwareTypes.h:58
uint16_t hf_u16_t
Platform-agnostic 16-bit unsigned integer type.
Definition HardwareTypes.h:46
Abstract base class for SPI device implementations.
Definition BaseSpi.h:184
virtual ~BaseSpi() noexcept=default
Virtual destructor ensures proper cleanup in derived classes.
virtual bool Open() noexcept
Legacy compatibility: Open and initialize the SPI bus.
Definition BaseSpi.h:272
virtual hf_spi_err_t GetStatistics(hf_spi_statistics_t &statistics) const noexcept
Get SPI operation statistics.
Definition BaseSpi.h:408
virtual bool Initialize() noexcept=0
Initialize the SPI bus.
virtual bool Deinitialize() noexcept=0
Deinitialize the SPI bus.
virtual hf_spi_err_t ResetDiagnostics() noexcept
Reset SPI diagnostic information.
Definition BaseSpi.h:398
virtual bool WriteByte(hf_u8_t data) noexcept
Write single byte to SPI bus.
Definition BaseSpi.h:356
virtual bool Write(const hf_u8_t *data, hf_u16_t length) noexcept
Legacy compatibility: Write with boolean return.
Definition BaseSpi.h:331
bool IsInitialized() const noexcept
Checks if the bus is initialized.
Definition BaseSpi.h:223
virtual hf_spi_err_t Read(hf_u8_t *data, hf_u16_t length, hf_u32_t timeout_ms=0) noexcept
Read data from SPI bus.
Definition BaseSpi.h:321
virtual const void * GetDeviceConfig() const noexcept=0
Get the device configuration for this SPI device.
bool EnsureInitialized() noexcept
Ensures that the SPI bus is initialized (lazy initialization).
Definition BaseSpi.h:201
virtual hf_spi_err_t Transfer(const hf_u8_t *tx_data, hf_u8_t *rx_data, hf_u16_t length, hf_u32_t timeout_ms=0) noexcept=0
Perform a full-duplex SPI transfer.
virtual hf_spi_err_t ResetStatistics() noexcept
Reset SPI operation statistics.
Definition BaseSpi.h:388
hf_spi_statistics_t statistics_
SPI operation statistics.
Definition BaseSpi.h:431
virtual bool Close() noexcept
Legacy compatibility: Close and de-initialize the SPI bus.
Definition BaseSpi.h:280
virtual bool Transfer(const hf_u8_t *tx_data, hf_u8_t *rx_data, hf_u16_t length) noexcept
Legacy compatibility: Transfer with boolean return.
Definition BaseSpi.h:295
virtual hf_spi_err_t Write(const hf_u8_t *data, hf_u16_t length, hf_u32_t timeout_ms=0) noexcept
Write data to SPI bus.
Definition BaseSpi.h:309
hf_spi_diagnostics_t diagnostics_
SPI diagnostic information.
Definition BaseSpi.h:432
bool initialized_
Initialization state.
Definition BaseSpi.h:430
virtual bool TransferByte(hf_u8_t tx_data, hf_u8_t &rx_data) noexcept
Write single byte and read response.
Definition BaseSpi.h:375
bool EnsureDeinitialized() noexcept
Ensures that the SPI bus is deinitialized (lazy deinitialization).
Definition BaseSpi.h:212
BaseSpi() noexcept
Protected default constructor.
Definition BaseSpi.h:428
virtual bool ReadByte(hf_u8_t &data) noexcept
Read single byte from SPI bus.
Definition BaseSpi.h:365
virtual bool Read(hf_u8_t *data, hf_u16_t length) noexcept
Legacy compatibility: Read with boolean return.
Definition BaseSpi.h:344
virtual hf_spi_err_t GetDiagnostics(hf_spi_diagnostics_t &diagnostics) const noexcept
Get SPI diagnostic information.
Definition BaseSpi.h:418
#define HF_SPI_ERR_LIST(X)
HardFOC SPI error codes.
Definition BaseSpi.h:43
SPI diagnostic information.
Definition BaseSpi.h:132
hf_u32_t current_clock_speed
Current clock speed in Hz.
Definition BaseSpi.h:136
hf_u16_t max_transfer_size
Maximum transfer size.
Definition BaseSpi.h:138
hf_u64_t total_transactions
Total transactions performed.
Definition BaseSpi.h:141
hf_u8_t device_count
Number of registered devices.
Definition BaseSpi.h:139
bool is_bus_suspended
Bus suspension state.
Definition BaseSpi.h:134
bool is_initialized
Initialization state.
Definition BaseSpi.h:133
hf_u32_t last_error
Last error code.
Definition BaseSpi.h:140
bool dma_enabled
DMA enabled state.
Definition BaseSpi.h:135
hf_u8_t current_mode
Current SPI mode.
Definition BaseSpi.h:137
hf_spi_diagnostics_t() noexcept
Definition BaseSpi.h:144
hf_u64_t failed_transactions
Failed transactions count.
Definition BaseSpi.h:142
SPI operation statistics.
Definition BaseSpi.h:110
hf_u32_t max_transaction_time_us
Maximum transaction time (microseconds)
Definition BaseSpi.h:117
hf_u32_t min_transaction_time_us
Minimum transaction time (microseconds)
Definition BaseSpi.h:118
hf_u32_t timeout_transactions
Number of timed-out transactions.
Definition BaseSpi.h:114
hf_spi_statistics_t() noexcept
Definition BaseSpi.h:122
hf_u64_t initialization_timestamp
Initialization timestamp.
Definition BaseSpi.h:120
hf_u32_t total_bytes_received
Total bytes received.
Definition BaseSpi.h:116
hf_u32_t failed_transactions
Number of failed transactions.
Definition BaseSpi.h:113
hf_u32_t successful_transactions
Number of successful transactions.
Definition BaseSpi.h:112
hf_u64_t last_activity_timestamp
Last activity timestamp.
Definition BaseSpi.h:119
hf_u32_t total_transactions
Total number of transactions.
Definition BaseSpi.h:111
hf_u32_t total_bytes_sent
Total bytes transmitted.
Definition BaseSpi.h:115