mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
drivers: update to new periph_spi API
This commit is contained in:
parent
f04b522601
commit
732cbd969c
@ -48,9 +48,9 @@
|
|||||||
#define AT225XXXX_SET_BUF_SIZE (64)
|
#define AT225XXXX_SET_BUF_SIZE (64)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static inline int getbus(const at25xxx_t *dev)
|
static inline void getbus(const at25xxx_t *dev)
|
||||||
{
|
{
|
||||||
return spi_acquire(dev->params.spi, dev->params.cs_pin, SPI_MODE_0, dev->params.spi_clk);
|
spi_acquire(dev->params.spi, dev->params.cs_pin, SPI_MODE_0, dev->params.spi_clk);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline uint32_t _pos(uint8_t cmd, uint32_t pos)
|
static inline uint32_t _pos(uint8_t cmd, uint32_t pos)
|
||||||
@ -254,10 +254,11 @@ int at25xxx_init(at25xxx_t *dev, const at25xxx_params_t *params)
|
|||||||
gpio_set(dev->params.hold_pin);
|
gpio_set(dev->params.hold_pin);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* check if the SPI configuration is valid */
|
if (!IS_ACTIVE(NDEBUG)) {
|
||||||
if (getbus(dev) != SPI_OK) {
|
/* if assertions are on, trigger an assert on incorrect SPI settings
|
||||||
return -1;
|
* right on initialization to ease debugging */
|
||||||
|
getbus(dev);
|
||||||
|
spi_release(dev->params.spi);
|
||||||
}
|
}
|
||||||
spi_release(dev->params.spi);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -89,14 +89,11 @@ static int _init(netdev_t *netdev)
|
|||||||
gpio_set(dev->params.reset_pin);
|
gpio_set(dev->params.reset_pin);
|
||||||
gpio_init_int(dev->params.int_pin, GPIO_IN, GPIO_RISING, _irq_handler, dev);
|
gpio_init_int(dev->params.int_pin, GPIO_IN, GPIO_RISING, _irq_handler, dev);
|
||||||
|
|
||||||
/* Intentionally check if bus can be acquired,
|
/* Intentionally check if bus can be acquired, if assertions are on */
|
||||||
since getbus() drops the return value */
|
if (!IS_ACTIVE(NDEBUG)) {
|
||||||
if (spi_acquire(dev->params.spi, dev->params.cs_pin, SPI_MODE_0,
|
spi_acquire(dev->params.spi, dev->params.cs_pin, SPI_MODE_0, dev->params.spi_clk);
|
||||||
dev->params.spi_clk) < 0) {
|
spi_release(dev->params.spi);
|
||||||
DEBUG("[at86rf2xx] error: unable to acquire SPI bus\n");
|
|
||||||
return -EIO;
|
|
||||||
}
|
}
|
||||||
spi_release(dev->params.spi);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* reset hardware into a defined state */
|
/* reset hardware into a defined state */
|
||||||
|
@ -156,9 +156,7 @@ static void _irq_handler(void *arg)
|
|||||||
|
|
||||||
static void _getbus(const ata8520e_t *dev)
|
static void _getbus(const ata8520e_t *dev)
|
||||||
{
|
{
|
||||||
if (spi_acquire(SPIDEV, CSPIN, SPI_MODE_0, dev->params.spi_clk) < 0) {
|
spi_acquire(SPIDEV, CSPIN, SPI_MODE_0, dev->params.spi_clk);
|
||||||
DEBUG("[ata8520e] ERROR: Cannot acquire SPI bus!\n");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void _spi_transfer_byte(const ata8520e_t *dev, bool cont, uint8_t out)
|
static void _spi_transfer_byte(const ata8520e_t *dev, bool cont, uint8_t out)
|
||||||
|
@ -50,9 +50,7 @@
|
|||||||
#ifdef BMX280_USE_SPI /* using SPI mode */
|
#ifdef BMX280_USE_SPI /* using SPI mode */
|
||||||
static inline int _acquire(const bmx280_t *dev)
|
static inline int _acquire(const bmx280_t *dev)
|
||||||
{
|
{
|
||||||
if (spi_acquire(BUS, CS, MODE, CLK) != SPI_OK) {
|
spi_acquire(BUS, CS, MODE, CLK);
|
||||||
return BMX280_ERR_BUS;
|
|
||||||
}
|
|
||||||
return BMX280_OK;
|
return BMX280_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -57,9 +57,7 @@ int cc110x_apply_config(cc110x_t *dev, const cc110x_config_t *conf,
|
|||||||
return -ERANGE;
|
return -ERANGE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cc110x_acquire(dev) != SPI_OK) {
|
cc110x_acquire(dev);
|
||||||
return -EIO;
|
|
||||||
}
|
|
||||||
|
|
||||||
gpio_irq_disable(dev->params.gdo0);
|
gpio_irq_disable(dev->params.gdo0);
|
||||||
gpio_irq_disable(dev->params.gdo2);
|
gpio_irq_disable(dev->params.gdo2);
|
||||||
@ -107,9 +105,7 @@ int cc110x_set_tx_power(cc110x_t *dev, cc110x_tx_power_t power)
|
|||||||
return -ERANGE;
|
return -ERANGE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cc110x_acquire(dev) != SPI_OK) {
|
cc110x_acquire(dev);
|
||||||
return -EIO;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (dev->state) {
|
switch (dev->state) {
|
||||||
case CC110X_STATE_IDLE:
|
case CC110X_STATE_IDLE:
|
||||||
@ -134,9 +130,7 @@ int cc110x_set_channel(cc110x_t *dev, uint8_t channel)
|
|||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cc110x_acquire(dev) != SPI_OK) {
|
cc110x_acquire(dev);
|
||||||
return -EIO;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((channel >= CC110X_MAX_CHANNELS) || (dev->channels->map[channel] == 0xff)) {
|
if ((channel >= CC110X_MAX_CHANNELS) || (dev->channels->map[channel] == 0xff)) {
|
||||||
/* Channel out of range or not supported in current channel map */
|
/* Channel out of range or not supported in current channel map */
|
||||||
|
@ -67,9 +67,7 @@ int cc110x_recalibrate(cc110x_t *dev)
|
|||||||
/* Re-acquire SPI interface in order to check if calibration
|
/* Re-acquire SPI interface in order to check if calibration
|
||||||
* succeeded
|
* succeeded
|
||||||
*/
|
*/
|
||||||
if (cc110x_acquire(dev) != SPI_OK) {
|
cc110x_acquire(dev);
|
||||||
return -EIO;
|
|
||||||
}
|
|
||||||
} while (cc110x_state_from_status(cc110x_status(dev)) != CC110X_STATE_IDLE);
|
} while (cc110x_state_from_status(cc110x_status(dev)) != CC110X_STATE_IDLE);
|
||||||
|
|
||||||
get_calibration_data(dev);
|
get_calibration_data(dev);
|
||||||
@ -84,9 +82,7 @@ int cc110x_full_calibration(cc110x_t *dev)
|
|||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cc110x_acquire(dev) != SPI_OK) {
|
cc110x_acquire(dev);
|
||||||
return -EIO;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (dev->state) {
|
switch (dev->state) {
|
||||||
case CC110X_STATE_IDLE:
|
case CC110X_STATE_IDLE:
|
||||||
|
@ -39,9 +39,7 @@ int cc110x_power_on_and_acquire(cc110x_t *dev)
|
|||||||
gpio_set(cs);
|
gpio_set(cs);
|
||||||
spi_init_cs(dev->params.spi, dev->params.cs);
|
spi_init_cs(dev->params.spi, dev->params.cs);
|
||||||
|
|
||||||
if (cc110x_acquire(dev) != SPI_OK) {
|
cc110x_acquire(dev);
|
||||||
return -EIO;
|
|
||||||
}
|
|
||||||
|
|
||||||
while (cc110x_state_from_status(cc110x_status(dev)) != CC110X_STATE_IDLE) {
|
while (cc110x_state_from_status(cc110x_status(dev)) != CC110X_STATE_IDLE) {
|
||||||
cc110x_cmd(dev, CC110X_STROBE_IDLE);
|
cc110x_cmd(dev, CC110X_STROBE_IDLE);
|
||||||
|
@ -354,11 +354,7 @@ static int cc110x_recv(netdev_t *netdev, void *buf, size_t len, void *info)
|
|||||||
/* Call to cc110x_enter_rx_mode() will clear dev->buf.len, so back up it first */
|
/* Call to cc110x_enter_rx_mode() will clear dev->buf.len, so back up it first */
|
||||||
int size = dev->buf.len;
|
int size = dev->buf.len;
|
||||||
|
|
||||||
if (cc110x_acquire(dev) != SPI_OK) {
|
cc110x_acquire(dev);
|
||||||
DEBUG("[cc110x] netdev_driver_t::recv(): cc110x_acquire() "
|
|
||||||
"failed\n");
|
|
||||||
return -EIO;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Copy RX info on last frame (if requested) */
|
/* Copy RX info on last frame (if requested) */
|
||||||
if (info != NULL) {
|
if (info != NULL) {
|
||||||
@ -396,10 +392,7 @@ static int cc110x_send(netdev_t *netdev, const iolist_t *iolist)
|
|||||||
/* assert that cc110x_send was called with valid parameters */
|
/* assert that cc110x_send was called with valid parameters */
|
||||||
assert(netdev && iolist && (iolist->iol_len == sizeof(cc1xxx_l2hdr_t)));
|
assert(netdev && iolist && (iolist->iol_len == sizeof(cc1xxx_l2hdr_t)));
|
||||||
|
|
||||||
if (cc110x_acquire(dev) != SPI_OK) {
|
cc110x_acquire(dev);
|
||||||
DEBUG("[cc110x] netdev_driver_t::send(): cc110x_acquire() failed\n");
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (dev->state) {
|
switch (dev->state) {
|
||||||
case CC110X_STATE_FSTXON:
|
case CC110X_STATE_FSTXON:
|
||||||
@ -503,9 +496,7 @@ static int cc110x_send(netdev_t *netdev, const iolist_t *iolist)
|
|||||||
*/
|
*/
|
||||||
static int cc110x_get_promiscuous_mode(cc110x_t *dev, netopt_enable_t *dest)
|
static int cc110x_get_promiscuous_mode(cc110x_t *dev, netopt_enable_t *dest)
|
||||||
{
|
{
|
||||||
if (cc110x_acquire(dev) != SPI_OK) {
|
cc110x_acquire(dev);
|
||||||
return -EIO;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint8_t pktctrl1;
|
uint8_t pktctrl1;
|
||||||
cc110x_read(dev, CC110X_REG_PKTCTRL1, &pktctrl1);
|
cc110x_read(dev, CC110X_REG_PKTCTRL1, &pktctrl1);
|
||||||
@ -598,9 +589,7 @@ static int cc110x_get(netdev_t *netdev, netopt_t opt,
|
|||||||
*/
|
*/
|
||||||
static int cc110x_set_addr(cc110x_t *dev, uint8_t addr)
|
static int cc110x_set_addr(cc110x_t *dev, uint8_t addr)
|
||||||
{
|
{
|
||||||
if (cc110x_acquire(dev) != SPI_OK) {
|
cc110x_acquire(dev);
|
||||||
return -EIO;
|
|
||||||
}
|
|
||||||
|
|
||||||
dev->addr = addr;
|
dev->addr = addr;
|
||||||
cc110x_write(dev, CC110X_REG_ADDR, addr);
|
cc110x_write(dev, CC110X_REG_ADDR, addr);
|
||||||
@ -618,9 +607,7 @@ static int cc110x_set_addr(cc110x_t *dev, uint8_t addr)
|
|||||||
*/
|
*/
|
||||||
static int cc110x_set_promiscuous_mode(cc110x_t *dev, netopt_enable_t enable)
|
static int cc110x_set_promiscuous_mode(cc110x_t *dev, netopt_enable_t enable)
|
||||||
{
|
{
|
||||||
if (cc110x_acquire(dev) != SPI_OK) {
|
cc110x_acquire(dev);
|
||||||
return -EIO;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint8_t pktctrl1 = CC110X_PKTCTRL1_VALUE;
|
uint8_t pktctrl1 = CC110X_PKTCTRL1_VALUE;
|
||||||
if (enable == NETOPT_ENABLE) {
|
if (enable == NETOPT_ENABLE) {
|
||||||
|
@ -280,10 +280,7 @@ void cc110x_isr(netdev_t *netdev)
|
|||||||
*/
|
*/
|
||||||
netdev_event_t post_isr_event = NETDEV_NO_EVENT;
|
netdev_event_t post_isr_event = NETDEV_NO_EVENT;
|
||||||
|
|
||||||
if (cc110x_acquire(dev) != SPI_OK) {
|
cc110x_acquire(dev);
|
||||||
DEBUG("[cc110x] ISR: CRITICAL ERROR: Couldn't acquire device\n");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Disable IRQs in a coarse manner, instead of doing so any time the
|
/* Disable IRQs in a coarse manner, instead of doing so any time the
|
||||||
* IOCFGx configuration registers are changed. (This should be less
|
* IOCFGx configuration registers are changed. (This should be less
|
||||||
|
@ -29,20 +29,15 @@ extern "C" {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Acquire the SPI interface of the transceiver and configure it
|
* @brief Acquire the SPI interface of the transceiver
|
||||||
*
|
|
||||||
* @retval SPI_OK Success
|
|
||||||
* @retval SPI_NOMODE SPI mode 0 not supported by MCU
|
|
||||||
* @retval SPI_NOCLK SPI clock given in @ref cc110x_params_t is not supported
|
|
||||||
*
|
*
|
||||||
* @pre When first acquiring the device either after boot or after having put
|
* @pre When first acquiring the device either after boot or after having put
|
||||||
* the device to sleep mode, use @ref cc110x_power_on_and_acquire
|
* the device to sleep mode, use @ref cc110x_power_on_and_acquire
|
||||||
* instead. Subsequently, this function should be used (it is faster).
|
* instead. Subsequently, this function should be used (it is faster).
|
||||||
*/
|
*/
|
||||||
static inline int cc110x_acquire(cc110x_t *dev)
|
static inline void cc110x_acquire(cc110x_t *dev)
|
||||||
{
|
{
|
||||||
return spi_acquire(dev->params.spi, dev->params.cs, SPI_MODE_0,
|
spi_acquire(dev->params.spi, dev->params.cs, SPI_MODE_0, dev->params.spi_clk);
|
||||||
dev->params.spi_clk);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -74,21 +74,11 @@ int kw2xrf_spi_init(kw2xrf_t *dev)
|
|||||||
(unsigned)SPIDEV, res);
|
(unsigned)SPIDEV, res);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
/* verify SPI params */
|
/* verify SPI params, if assertions are on */
|
||||||
res = spi_acquire(SPIDEV, CSPIN, SPIMODE, SPICLK);
|
if (!IS_ACTIVE(NDEBUG)) {
|
||||||
if (res == SPI_NOMODE) {
|
spi_acquire(SPIDEV, CSPIN, SPIMODE, SPICLK);
|
||||||
LOG_ERROR("[kw2xrf_spi] given SPI mode is not supported");
|
spi_release(SPIDEV);
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
else if (res == SPI_NOCLK) {
|
|
||||||
LOG_ERROR("[kw2xrf_spi] targeted clock speed is not supported");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
else if (res != SPI_OK) {
|
|
||||||
LOG_ERROR("[kw2xrf_spi] unable to acquire bus with given parameters");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
spi_release(SPIDEV);
|
|
||||||
|
|
||||||
DEBUG("[kw2xrf_spi] SPI_DEV(%u) initialized: mode: %u, clk: %u, cs_pin: %u\n",
|
DEBUG("[kw2xrf_spi] SPI_DEV(%u) initialized: mode: %u, clk: %u, cs_pin: %u\n",
|
||||||
(unsigned)SPIDEV, (unsigned)SPIMODE, (unsigned)SPICLK, (unsigned)CSPIN);
|
(unsigned)SPIDEV, (unsigned)SPIMODE, (unsigned)SPICLK, (unsigned)CSPIN);
|
||||||
|
@ -58,7 +58,8 @@ static int _init_bus(const lis2dh12_t *dev)
|
|||||||
|
|
||||||
static int _acquire(const lis2dh12_t *dev)
|
static int _acquire(const lis2dh12_t *dev)
|
||||||
{
|
{
|
||||||
return spi_acquire(BUS, BUS_CS, BUS_MODE, BUS_CLK);
|
spi_acquire(BUS, BUS_CS, BUS_MODE, BUS_CLK);
|
||||||
|
return BUS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void _release(const lis2dh12_t *dev)
|
static void _release(const lis2dh12_t *dev)
|
||||||
|
@ -83,12 +83,11 @@ int nrf24l01p_init(nrf24l01p_t *dev, spi_t spi, gpio_t ce, gpio_t cs, gpio_t irq
|
|||||||
/* Init IRQ pin */
|
/* Init IRQ pin */
|
||||||
gpio_init_int(dev->irq, GPIO_IN_PU, GPIO_FALLING, nrf24l01p_rx_cb, dev);
|
gpio_init_int(dev->irq, GPIO_IN_PU, GPIO_FALLING, nrf24l01p_rx_cb, dev);
|
||||||
|
|
||||||
/* Test the SPI connection */
|
/* Test the SPI connection, if assertions are on */
|
||||||
if (spi_acquire(dev->spi, dev->cs, SPI_MODE, SPI_CLK) != SPI_OK) {
|
if (!IS_ACTIVE(NDEBUG)) {
|
||||||
DEBUG("error: unable to acquire SPI bus with given params\n");
|
spi_acquire(dev->spi, dev->cs, SPI_MODE, SPI_CLK);
|
||||||
return -1;
|
spi_release(dev->spi);
|
||||||
}
|
}
|
||||||
spi_release(dev->spi);
|
|
||||||
|
|
||||||
xtimer_spin(DELAY_AFTER_FUNC_TICKS);
|
xtimer_spin(DELAY_AFTER_FUNC_TICKS);
|
||||||
|
|
||||||
|
@ -105,17 +105,13 @@ extern "C" {
|
|||||||
* @brief Acquire the SPI bus of the transceiver
|
* @brief Acquire the SPI bus of the transceiver
|
||||||
*
|
*
|
||||||
* @param[in] dev NRF24L01+ device handle
|
* @param[in] dev NRF24L01+ device handle
|
||||||
*
|
|
||||||
* @return @see spi_acquire
|
|
||||||
*/
|
*/
|
||||||
int nrf24l01p_ng_acquire(nrf24l01p_ng_t *dev);
|
void nrf24l01p_ng_acquire(nrf24l01p_ng_t *dev);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Release the SPI bus of the transceiver
|
* @brief Release the SPI bus of the transceiver
|
||||||
*
|
*
|
||||||
* @param[in] dev NRF24L01+ device handle
|
* @param[in] dev NRF24L01+ device handle
|
||||||
*
|
|
||||||
* @return @see spi_release
|
|
||||||
*/
|
*/
|
||||||
void nrf24l01p_ng_release(nrf24l01p_ng_t *dev);
|
void nrf24l01p_ng_release(nrf24l01p_ng_t *dev);
|
||||||
|
|
||||||
|
@ -74,10 +74,9 @@ static void _nrf24l01p_ng_copy_and_swap_bytes(uint8_t* dst, const uint8_t* src,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int nrf24l01p_ng_acquire(nrf24l01p_ng_t *dev)
|
void nrf24l01p_ng_acquire(nrf24l01p_ng_t *dev)
|
||||||
{
|
{
|
||||||
return spi_acquire(dev->params.spi, dev->params.pin_cs, SPI_MODE_0,
|
spi_acquire(dev->params.spi, dev->params.pin_cs, SPI_MODE_0, dev->params.spi_clk);
|
||||||
dev->params.spi_clk);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void nrf24l01p_ng_release(nrf24l01p_ng_t *dev)
|
void nrf24l01p_ng_release(nrf24l01p_ng_t *dev)
|
||||||
|
@ -177,10 +177,7 @@ static int _init(netdev_t *netdev)
|
|||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
gpio_clear(dev->params.pin_ce);
|
gpio_clear(dev->params.pin_ce);
|
||||||
if (nrf24l01p_ng_acquire(dev) < 0) {
|
nrf24l01p_ng_acquire(dev);
|
||||||
DEBUG_PUTS("[nrf24l01p_ng] _init(): nrf24l01p_ng_acquire() failed");
|
|
||||||
return -EIO;
|
|
||||||
}
|
|
||||||
if (dev->state != NRF24L01P_NG_STATE_POWER_DOWN) {
|
if (dev->state != NRF24L01P_NG_STATE_POWER_DOWN) {
|
||||||
nrf24l01p_ng_transition_to_power_down(dev);
|
nrf24l01p_ng_transition_to_power_down(dev);
|
||||||
}
|
}
|
||||||
|
@ -104,10 +104,7 @@ static void print_state(cc110x_t *dev)
|
|||||||
uint8_t virtual_channel;
|
uint8_t virtual_channel;
|
||||||
|
|
||||||
/* Get all required data and release device */
|
/* Get all required data and release device */
|
||||||
if (cc110x_acquire(dev) != SPI_OK) {
|
cc110x_acquire(dev);
|
||||||
puts("Failed to acquire CC1100/CC1101 transceiver");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (dev->state == CC110X_STATE_OFF) {
|
if (dev->state == CC110X_STATE_OFF) {
|
||||||
cc110x_release(dev);
|
cc110x_release(dev);
|
||||||
|
Loading…
Reference in New Issue
Block a user