43#define HF_SPI_ERR_LIST(X) \
45 X(SPI_SUCCESS, 0, "Success") \
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") \
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") \
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") \
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") \
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") \
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") \
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")
85#define X(NAME, VALUE, DESC) NAME = VALUE,
97#define X(NAME, VALUE, DESC) \
98 case hf_spi_err_t::NAME: \
256 hf_u32_t timeout_ms = 0) noexcept = 0;
311 return Transfer(data,
nullptr, length, timeout_ms);
322 return Transfer(
nullptr, data, length, timeout_ms);
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