From 4140a07307067a55e5a7763cf4cfc7f0ebb7f14b Mon Sep 17 00:00:00 2001 From: Henrik Stickann <4376396-Mithradir@users.noreply.gitlab.com> Date: Sat, 9 Apr 2022 21:21:54 +0200 Subject: [PATCH] Add SPI interface --- include/sta/spi_interface.hpp | 87 +++++++++++++++++++++++++++++++++++ src/spi_interface.cpp | 21 +++++++++ 2 files changed, 108 insertions(+) create mode 100644 include/sta/spi_interface.hpp create mode 100644 src/spi_interface.cpp diff --git a/include/sta/spi_interface.hpp b/include/sta/spi_interface.hpp new file mode 100644 index 0000000..386421f --- /dev/null +++ b/include/sta/spi_interface.hpp @@ -0,0 +1,87 @@ +#ifndef STA_SPI_INTERFACE_HPP +#define STA_SPI_INTERFACE_HPP + +#include + +#include +#include + + +namespace sta +{ + /** + * @brief Interface for SPI hardware. + */ + class SpiInterface + { + public: + /** + * @param mutex Mutex object for managing shared access. Pass nullptr for no access control + */ + SpiInterface(Mutex * mutex = nullptr); + + + /** + * @brief Send single byte of data. + * + * @param value 8-bit value + */ + virtual void transfer(uint8_t value) = 0; + /** + * @brief Send data from buffer. + * + * @param buffer Source buffer + * @param size Number of bytes in buffer + */ + virtual void transfer(const uint8_t * buffer, size_t size) = 0; + + /** + * @brief Send two bytes of data. + * + * @param value 16-bit value + */ + virtual void transfer16(uint16_t value) = 0; + + /** + * @brief Send byte value repeatedly. + * + * @param value 8-bit value to repeat + * @param count Number of repetitions + */ + virtual void fill(uint8_t value, size_t count) = 0; + /** + * @brief Send 32-bit value repeatedly. + * + * @param value 32-bit value to repeat + * @param count Number of repetitions + */ + virtual void fill32(uint32_t value, size_t count) = 0; + + /** + * @brief Read incoming data to buffer. + * + * @param buffer Destination buffer + * @param size Number of bytes to read + */ + virtual void receive(uint8_t * buffer, size_t size) = 0; + + /** + * @brief Acquire usage rights to use the interface. + * + * Must be called before any I/O operations are executed. + */ + virtual void acquire(); + /** + * @brief Release usage rights for interface. + * + * Must be called after last I/O operation. + */ + virtual void release(); + + private: + Mutex * mutex_; /**< Mutex object */ + }; +} // namespace sta + + +#endif // STA_SPI_INTERFACE_HPP diff --git a/src/spi_interface.cpp b/src/spi_interface.cpp new file mode 100644 index 0000000..26a141e --- /dev/null +++ b/src/spi_interface.cpp @@ -0,0 +1,21 @@ +#include + + +namespace sta +{ + SpiInterface::SpiInterface(Mutex * mutex /* = nullptr */) + : mutex_{mutex} + {} + + void SpiInterface::acquire() + { + if (mutex_ != nullptr) + mutex_->acquire(); + } + + void SpiInterface::release() + { + if (mutex_ != nullptr) + mutex_->release(); + } +} // namespace sta