From 63310189a5980767d126e2388d17ffc038baa617 Mon Sep 17 00:00:00 2001 From: Dylan Laduranty Date: Wed, 5 Jul 2023 14:40:23 +0200 Subject: [PATCH] cpu/nrfxx: move I2C/SPI/UART structs to nrf5x_common This will reduces code duplication across nRF52,nRF53 and nRF9160 families Signed-off-by: Dylan Laduranty --- cpu/nrf52/include/periph_cpu.h | 85 -------- cpu/nrf5x_common/include/periph_cpu_common.h | 196 ++++++++++++++++++- cpu/nrf9160/include/periph_cpu.h | 183 ----------------- 3 files changed, 194 insertions(+), 270 deletions(-) diff --git a/cpu/nrf52/include/periph_cpu.h b/cpu/nrf52/include/periph_cpu.h index 81962e165c..32c24a8a07 100644 --- a/cpu/nrf52/include/periph_cpu.h +++ b/cpu/nrf52/include/periph_cpu.h @@ -27,14 +27,6 @@ extern "C" { #endif -/** - * @brief Enable the workaround for the SPI single byte transmit errata (No. - * 58 on the nrf52832) - */ -#ifdef CPU_MODEL_NRF52832XXAA -#define ERRATA_SPI_SINGLE_BYTE_WORKAROUND (1) -#endif - /** * @brief System core clock speed, fixed to 64MHz for all NRF52x CPUs */ @@ -45,18 +37,6 @@ extern "C" { */ #define PERIPH_CLOCK (16000000U) -/** - * @brief Redefine some peripheral names to unify them between nRF51 and 52 - * @{ - */ -#define SPI_SCKSEL (dev(bus)->PSEL.SCK) -#define SPI_MOSISEL (dev(bus)->PSEL.MOSI) -#define SPI_MISOSEL (dev(bus)->PSEL.MISO) -#ifdef CPU_MODEL_NRF52832XXAA -#define UART_IRQN (UARTE0_UART0_IRQn) -#endif -/** @} */ - /** * @brief The nRF52 family of CPUs provides a fixed number of 9 ADC lines */ @@ -66,14 +46,6 @@ extern "C" { #define ADC_NUMOF (9U) #endif -/** - * @brief SPI temporary buffer size for storing const data in RAM before - * initiating DMA transfer - */ -#ifndef CONFIG_SPI_MBUF_SIZE -#define CONFIG_SPI_MBUF_SIZE 64 -#endif - /** * @brief nRF52 specific naming of ADC lines (for convenience) */ @@ -109,50 +81,6 @@ typedef enum { /** @} */ #endif /* ndef DOXYGEN */ -#ifndef DOXYGEN -/** - * @brief Override I2C speed settings - * @{ - */ -#define HAVE_I2C_SPEED_T -typedef enum { - I2C_SPEED_LOW = 0xff, /**< not supported */ - I2C_SPEED_NORMAL = TWIM_FREQUENCY_FREQUENCY_K100, /**< 100kbit/s */ - I2C_SPEED_FAST = TWIM_FREQUENCY_FREQUENCY_K400, /**< 400kbit/s */ - I2C_SPEED_FAST_PLUS = 0xfe, /**< not supported */ - I2C_SPEED_HIGH = 0xfd, /**< not supported */ -} i2c_speed_t; -/** @} */ -#endif /* ndef DOXYGEN */ - -/** - * @brief I2C (TWI) configuration options - * @{ - */ -typedef struct { - NRF_TWIM_Type *dev; /**< TWIM hardware device */ - gpio_t scl; /**< SCL pin */ - gpio_t sda; /**< SDA pin */ - i2c_speed_t speed; /**< Bus speed */ -} i2c_conf_t; -/** @} */ - -/** - * @name Use shared I2C functions - * @{ - */ -#define PERIPH_I2C_NEED_READ_REG -#define PERIPH_I2C_NEED_WRITE_REG -/** @} */ - -/** - * @name Define macros for sda and scl pin to be able to reinitialize them - * @{ - */ -#define i2c_pin_sda(dev) i2c_config[dev].sda -#define i2c_pin_scl(dev) i2c_config[dev].scl -/** @} */ - /** * @brief Size of the UART TX buffer for non-blocking mode. */ @@ -160,19 +88,6 @@ typedef struct { #define UART_TXBUF_SIZE (64) #endif -/** - * @brief SPI configuration values - */ -typedef struct { - NRF_SPIM_Type *dev; /**< SPI device used */ - gpio_t sclk; /**< CLK pin */ - gpio_t mosi; /**< MOSI pin */ - gpio_t miso; /**< MISO pin */ -#if ERRATA_SPI_SINGLE_BYTE_WORKAROUND - uint8_t ppi; /**< PPI channel */ -#endif -} spi_conf_t; - /** * @brief Common SPI/I2C interrupt callback * diff --git a/cpu/nrf5x_common/include/periph_cpu_common.h b/cpu/nrf5x_common/include/periph_cpu_common.h index a909aa864f..a41a36248b 100644 --- a/cpu/nrf5x_common/include/periph_cpu_common.h +++ b/cpu/nrf5x_common/include/periph_cpu_common.h @@ -31,6 +31,15 @@ extern "C" { #ifdef NRF_FICR_S #define NRF_FICR NRF_FICR_S #endif + +/** + * @brief Enable the workaround for the SPI single byte transmit errata (No. + * 58 on the nrf52832) + */ +#ifdef CPU_MODEL_NRF52832XXAA +#define ERRATA_SPI_SINGLE_BYTE_WORKAROUND (1) +#endif + /** * @name Power management configuration * @{ @@ -136,6 +145,38 @@ typedef enum { } gpio_pull_t; #endif /* END: GPIO LL overwrites */ +#if !defined(DOXYGEN) && (defined(CPU_NRF53) || defined(CPU_NRF9160)) +/** + * @brief Wrapper to fix differences between nRF families vendor files + */ +#define UART_BAUDRATE_BAUDRATE_Baud1200 UARTE_BAUDRATE_BAUDRATE_Baud1200 +#define UART_BAUDRATE_BAUDRATE_Baud2400 UARTE_BAUDRATE_BAUDRATE_Baud2400 +#define UART_BAUDRATE_BAUDRATE_Baud4800 UARTE_BAUDRATE_BAUDRATE_Baud4800 +#define UART_BAUDRATE_BAUDRATE_Baud9600 UARTE_BAUDRATE_BAUDRATE_Baud9600 +#define UART_BAUDRATE_BAUDRATE_Baud14400 UARTE_BAUDRATE_BAUDRATE_Baud14400 +#define UART_BAUDRATE_BAUDRATE_Baud19200 UARTE_BAUDRATE_BAUDRATE_Baud19200 +#define UART_BAUDRATE_BAUDRATE_Baud28800 UARTE_BAUDRATE_BAUDRATE_Baud28800 +#define UART_BAUDRATE_BAUDRATE_Baud31250 UARTE_BAUDRATE_BAUDRATE_Baud31250 +#define UART_BAUDRATE_BAUDRATE_Baud38400 UARTE_BAUDRATE_BAUDRATE_Baud38400 +#define UART_BAUDRATE_BAUDRATE_Baud56000 UARTE_BAUDRATE_BAUDRATE_Baud56000 +#define UART_BAUDRATE_BAUDRATE_Baud57600 UARTE_BAUDRATE_BAUDRATE_Baud57600 +#define UART_BAUDRATE_BAUDRATE_Baud76800 UARTE_BAUDRATE_BAUDRATE_Baud76800 +#define UART_BAUDRATE_BAUDRATE_Baud115200 UARTE_BAUDRATE_BAUDRATE_Baud115200 +#define UART_BAUDRATE_BAUDRATE_Baud230400 UARTE_BAUDRATE_BAUDRATE_Baud230400 +#define UART_BAUDRATE_BAUDRATE_Baud250000 UARTE_BAUDRATE_BAUDRATE_Baud250000 +#define UART_BAUDRATE_BAUDRATE_Baud460800 UARTE_BAUDRATE_BAUDRATE_Baud460800 +#define UART_BAUDRATE_BAUDRATE_Baud921600 UARTE_BAUDRATE_BAUDRATE_Baud921600 +#define UART_BAUDRATE_BAUDRATE_Baud1M UARTE_BAUDRATE_BAUDRATE_Baud1M + +#define SPI_FREQUENCY_FREQUENCY_K125 SPIM_FREQUENCY_FREQUENCY_K125 +#define SPI_FREQUENCY_FREQUENCY_K500 SPIM_FREQUENCY_FREQUENCY_K500 +#define SPI_FREQUENCY_FREQUENCY_M1 SPIM_FREQUENCY_FREQUENCY_M1 +#define SPI_FREQUENCY_FREQUENCY_M4 SPIM_FREQUENCY_FREQUENCY_M4 +#define SPI_FREQUENCY_FREQUENCY_M8 SPIM_FREQUENCY_FREQUENCY_M8 +#define SPI_CONFIG_CPHA_Msk SPIM_CONFIG_CPHA_Msk +#define SPI_CONFIG_CPOL_Msk SPIM_CONFIG_CPOL_Msk +#endif + /** * @brief No support for HW chip select... */ @@ -221,7 +262,6 @@ typedef struct { * @brief Override SPI mode values * @{ */ -#if !defined(CPU_FAM_NRF9160) && !defined(CPU_FAM_NRF53) #define HAVE_SPI_MODE_T typedef enum { SPI_MODE_0 = 0, /**< CPOL=0, CPHA=0 */ @@ -244,7 +284,6 @@ typedef enum { SPI_CLK_10MHZ = SPI_FREQUENCY_FREQUENCY_M8 /**< 10MHz */ } spi_clk_t; /** @} */ -#endif /* ndef CPU_FAM_NRF9160 */ #endif /* ndef DOXYGEN */ /** @@ -360,6 +399,159 @@ typedef struct { } pwm_conf_t; #endif #endif /* ndef CPU_FAM_NRF51 */ +#ifndef CPU_NRF51 + +/** + * @brief Redefine some peripheral names to unify them across nRF families + */ +#define SPI_SCKSEL (dev(bus)->PSEL.SCK) /**< Macro for SPI clk */ +#define SPI_MOSISEL (dev(bus)->PSEL.MOSI) /**< Macro for SPI mosi */ +#define SPI_MISOSEL (dev(bus)->PSEL.MISO) /**< Macro for SPI miso */ +#ifdef CPU_MODEL_NRF52832XXAA +#define UART_IRQN (UARTE0_UART0_IRQn) +#endif + +/** + * @brief SPI configuration values + */ +typedef struct { + NRF_SPIM_Type *dev; /**< SPI device used */ + gpio_t sclk; /**< CLK pin */ + gpio_t mosi; /**< MOSI pin */ + gpio_t miso; /**< MISO pin */ +#if ERRATA_SPI_SINGLE_BYTE_WORKAROUND + uint8_t ppi; /**< PPI channel */ +#endif +} spi_conf_t; + +/** + * @brief Common UART/SPI/I2C interrupt callback + * + * @param arg Opaque context pointer + */ +typedef void (*shared_irq_cb_t)(void *arg); + +/** + * @brief Register a SPI IRQ handler for a shared UART/I2C/SPI irq vector + * + * @param bus bus to register the IRQ handler on + * @param cb callback to call on IRQ + * @param arg Argument to pass to the handler + */ +void shared_irq_register_spi(NRF_SPIM_Type *bus, + shared_irq_cb_t cb, void *arg); + +/** + * @brief Register an I2C IRQ handler for a shared UART/I2C/SPI irq vector + * + * @param bus bus to register the IRQ handler on + * @param cb callback to call on IRQ + * @param arg Argument to pass to the handler + */ +void shared_irq_register_i2c(NRF_TWIM_Type *bus, + shared_irq_cb_t cb, void *arg); + +/** + * @brief Register an UART IRQ handler for a shared UART/I2C/SPI irq vector + * + * @param bus bus to register the IRQ handler on + * @param cb callback to call on IRQ + * @param arg Argument to pass to the handler + */ +void shared_irq_register_uart(NRF_UARTE_Type *bus, + shared_irq_cb_t cb, void *arg); + +/** + * @brief Acquire the shared I2C/SPI peripheral in I2C mode + * + * @param bus bus to acquire exclusive access on + * @param cb ISR handler to call on IRQ + * @param arg ISR handler argument + */ +void nrf5x_i2c_acquire(NRF_TWIM_Type *bus, shared_irq_cb_t cb, void *arg); + +/** + * @brief Release the shared I2C/SPI peripheral in I2C mode + * + * @param bus bus to release exclusive access on + */ +void nrf5x_i2c_release(NRF_TWIM_Type *bus); + +/** + * @brief Acquire the shared I2C/SPI peripheral in SPI mode + * + * @param bus bus to release exclusive access on + * @param cb ISR handler to call on IRQ + * @param arg ISR handler argument + */ +void nrf5x_spi_acquire(NRF_SPIM_Type *bus, shared_irq_cb_t cb, void *arg); + +/** + * @brief Acquire the shared I2C/SPI peripheral in SPI mode + * + * @param bus bus to release exclusive access on + */ +void nrf5x_spi_release(NRF_SPIM_Type *bus); + +/** + * @brief Size of the UART TX buffer for non-blocking mode. + */ +#ifndef UART_TXBUF_SIZE +#define UART_TXBUF_SIZE (64) +#endif + +/** + * @brief SPI temporary buffer size for storing const data in RAM before + * initiating DMA transfer + */ +#ifndef CONFIG_SPI_MBUF_SIZE +#define CONFIG_SPI_MBUF_SIZE 64 +#endif + +#ifndef DOXYGEN +/** + * @brief Override I2C speed settings + * @{ + */ +#define HAVE_I2C_SPEED_T +typedef enum { + I2C_SPEED_LOW = 0xff, /**< not supported */ + I2C_SPEED_NORMAL = TWIM_FREQUENCY_FREQUENCY_K100, /**< 100kbit/s */ + I2C_SPEED_FAST = TWIM_FREQUENCY_FREQUENCY_K400, /**< 400kbit/s */ + I2C_SPEED_FAST_PLUS = 0xfe, /**< not supported */ + I2C_SPEED_HIGH = 0xfd, /**< not supported */ +} i2c_speed_t; +/** @} */ +#endif /* ndef DOXYGEN */ + +/** + * @brief I2C (TWI) configuration options + * @{ + */ +typedef struct { + NRF_TWIM_Type *dev; /**< TWIM hardware device */ + gpio_t scl; /**< SCL pin */ + gpio_t sda; /**< SDA pin */ + i2c_speed_t speed; /**< Bus speed */ +} i2c_conf_t; +/** @} */ + +/** + * @name Use shared I2C functions + * @{ + */ +#define PERIPH_I2C_NEED_READ_REG +#define PERIPH_I2C_NEED_WRITE_REG +/** @} */ + +/** + * @name Define macros for sda and scl pin to be able to reinitialize them + * @{ + */ +#define i2c_pin_sda(dev) i2c_config[dev].sda /**< Macro for getting SDA pin */ +#define i2c_pin_scl(dev) i2c_config[dev].scl /**< Macro for getting SCL pin */ +/** @} */ +#endif /* ndef CPU_NRF51 */ #ifdef __cplusplus } diff --git a/cpu/nrf9160/include/periph_cpu.h b/cpu/nrf9160/include/periph_cpu.h index 937ea15a60..9f9dce141e 100644 --- a/cpu/nrf9160/include/periph_cpu.h +++ b/cpu/nrf9160/include/periph_cpu.h @@ -36,189 +36,6 @@ extern "C" { */ #define PERIPH_CLOCK MHZ(16) -#ifndef DOXYGEN -/** - * @brief Wrapper to fix differences between nRF9160 and - * nRF52 vendor files - */ -#define UART_BAUDRATE_BAUDRATE_Baud1200 UARTE_BAUDRATE_BAUDRATE_Baud1200 -#define UART_BAUDRATE_BAUDRATE_Baud2400 UARTE_BAUDRATE_BAUDRATE_Baud2400 -#define UART_BAUDRATE_BAUDRATE_Baud4800 UARTE_BAUDRATE_BAUDRATE_Baud4800 -#define UART_BAUDRATE_BAUDRATE_Baud9600 UARTE_BAUDRATE_BAUDRATE_Baud9600 -#define UART_BAUDRATE_BAUDRATE_Baud14400 UARTE_BAUDRATE_BAUDRATE_Baud14400 -#define UART_BAUDRATE_BAUDRATE_Baud19200 UARTE_BAUDRATE_BAUDRATE_Baud19200 -#define UART_BAUDRATE_BAUDRATE_Baud28800 UARTE_BAUDRATE_BAUDRATE_Baud28800 -#define UART_BAUDRATE_BAUDRATE_Baud31250 UARTE_BAUDRATE_BAUDRATE_Baud31250 -#define UART_BAUDRATE_BAUDRATE_Baud38400 UARTE_BAUDRATE_BAUDRATE_Baud38400 -#define UART_BAUDRATE_BAUDRATE_Baud56000 UARTE_BAUDRATE_BAUDRATE_Baud56000 -#define UART_BAUDRATE_BAUDRATE_Baud57600 UARTE_BAUDRATE_BAUDRATE_Baud57600 -#define UART_BAUDRATE_BAUDRATE_Baud76800 UARTE_BAUDRATE_BAUDRATE_Baud76800 -#define UART_BAUDRATE_BAUDRATE_Baud115200 UARTE_BAUDRATE_BAUDRATE_Baud115200 -#define UART_BAUDRATE_BAUDRATE_Baud230400 UARTE_BAUDRATE_BAUDRATE_Baud230400 -#define UART_BAUDRATE_BAUDRATE_Baud250000 UARTE_BAUDRATE_BAUDRATE_Baud250000 -#define UART_BAUDRATE_BAUDRATE_Baud460800 UARTE_BAUDRATE_BAUDRATE_Baud460800 -#define UART_BAUDRATE_BAUDRATE_Baud921600 UARTE_BAUDRATE_BAUDRATE_Baud921600 -#define UART_BAUDRATE_BAUDRATE_Baud1M UARTE_BAUDRATE_BAUDRATE_Baud1M - -/** - * @brief Override I2C speed settings - * @{ - */ -#define HAVE_I2C_SPEED_T -typedef enum { - I2C_SPEED_LOW = 0xff, /**< not supported */ - I2C_SPEED_NORMAL = TWIM_FREQUENCY_FREQUENCY_K100, /**< 100kbit/s */ - I2C_SPEED_FAST = TWIM_FREQUENCY_FREQUENCY_K400, /**< 400kbit/s */ - I2C_SPEED_FAST_PLUS = 0xfe, /**< not supported */ - I2C_SPEED_HIGH = 0xfd, /**< not supported */ -} i2c_speed_t; -/** @} */ - -#endif /* ndef DOXYGEN */ - -/** - * @brief I2C (TWI) configuration options - * @{ - */ -typedef struct { - NRF_TWIM_Type *dev; /**< TWIM hardware device */ - gpio_t scl; /**< SCL pin */ - gpio_t sda; /**< SDA pin */ - i2c_speed_t speed; /**< Bus speed */ -} i2c_conf_t; -/** @} */ - -/** - * @name Use shared I2C functions - * @{ - */ -#define PERIPH_I2C_NEED_READ_REG -#define PERIPH_I2C_NEED_WRITE_REG -/** @} */ - -/** - * @name Define macros for sda and scl pin to be able to reinitialize them - * @{ - */ -#define i2c_pin_sda(dev) i2c_config[dev].sda -#define i2c_pin_scl(dev) i2c_config[dev].scl -/** @} */ - -/** - * @brief Defines macros for SPI pins initialization - * @{ - */ -#define SPI_SCKSEL (dev(bus)->PSEL.SCK) -#define SPI_MOSISEL (dev(bus)->PSEL.MOSI) -#define SPI_MISOSEL (dev(bus)->PSEL.MISO) -/** @} */ - -/** - * @brief SPI temporary buffer size for storing const data in RAM before - * initiating DMA transfer - */ -#ifndef CONFIG_SPI_MBUF_SIZE -#define CONFIG_SPI_MBUF_SIZE 64 -#endif - -/** - * @brief SPI configuration values - */ -typedef struct { - NRF_SPIM_Type *dev; /**< SPI device used */ - gpio_t sclk; /**< CLK pin */ - gpio_t mosi; /**< MOSI pin */ - gpio_t miso; /**< MISO pin */ -} spi_conf_t; - -#ifndef DOXYGEN -/** - * @brief Override SPI mode values - * @{ - */ -#define HAVE_SPI_MODE_T -typedef enum { - SPI_MODE_0 = 0, /**< CPOL=0, CPHA=0 */ - SPI_MODE_1 = SPIM_CONFIG_CPHA_Msk, /**< CPOL=0, CPHA=1 */ - SPI_MODE_2 = SPIM_CONFIG_CPOL_Msk, /**< CPOL=1, CPHA=0 */ - SPI_MODE_3 = (SPIM_CONFIG_CPOL_Msk | SPIM_CONFIG_CPHA_Msk) /**< CPOL=1, CPHA=1 */ -} spi_mode_t; -/** @} */ - -/** - * @brief Override SPI clock values - * @{ - */ -#define HAVE_SPI_CLK_T -typedef enum { - SPI_CLK_100KHZ = SPIM_FREQUENCY_FREQUENCY_K125, /**< 100KHz */ - SPI_CLK_400KHZ = SPIM_FREQUENCY_FREQUENCY_K500, /**< 400KHz */ - SPI_CLK_1MHZ = SPIM_FREQUENCY_FREQUENCY_M1, /**< 1MHz */ - SPI_CLK_5MHZ = SPIM_FREQUENCY_FREQUENCY_M4, /**< 5MHz */ - SPI_CLK_10MHZ = SPIM_FREQUENCY_FREQUENCY_M8 /**< 10MHz */ -} spi_clk_t; -/** @} */ -#endif /* ndef DOXYGEN */ - -/** - * @brief Common SPI/I2C interrupt callback - * - * @param arg Opaque context pointer - */ -typedef void (*spi_twi_irq_cb_t)(void *arg); - -/** - * @brief Register a SPI IRQ handler for a shared I2C/SPI irq vector - * - * @param bus bus to register the IRQ handler on - * @param cb callback to call on IRQ - * @param arg Argument to pass to the handler - */ -void spi_twi_irq_register_spi(NRF_SPIM_Type *bus, - spi_twi_irq_cb_t cb, void *arg); - -/** - * @brief Register a I2C IRQ handler for a shared I2C/SPI irq vector - * - * @param bus bus to register the IRQ handler on - * @param cb callback to call on IRQ - * @param arg Argument to pass to the handler - */ -void spi_twi_irq_register_i2c(NRF_TWIM_Type *bus, - spi_twi_irq_cb_t cb, void *arg); - -/** - * @brief Acquire the shared I2C/SPI peripheral in I2C mode - * - * @param bus bus to acquire exclusive access on - * @param cb ISR handler to call on IRQ - * @param arg ISR handler argument - */ -void nrf5x_i2c_acquire(NRF_TWIM_Type *bus, spi_twi_irq_cb_t cb, void *arg); - -/** - * @brief Release the shared I2C/SPI peripheral in I2C mode - * - * @param bus bus to release exclusive access on - */ -void nrf5x_i2c_release(NRF_TWIM_Type *bus); - -/** - * @brief Acquire the shared I2C/SPI peripheral in SPI mode - * - * @param bus bus to release exclusive access on - * @param cb ISR handler to call on IRQ - * @param arg ISR handler argument - */ -void nrf5x_spi_acquire(NRF_SPIM_Type *bus, spi_twi_irq_cb_t cb, void *arg); - -/** - * @brief Acquire the shared I2C/SPI peripheral in SPI mode - * - * @param bus bus to release exclusive access on - */ -void nrf5x_spi_release(NRF_SPIM_Type *bus); - #ifdef __cplusplus } #endif