Loading...
Searching...
No Matches
periph_cpu_common.h
Go to the documentation of this file.
1/*
2 * Copyright (C) 2015-2018 Freie Universität Berlin
3 *
4 * This file is subject to the terms and conditions of the GNU Lesser
5 * General Public License v2.1. See the file LICENSE in the top level
6 * directory for more details.
7 */
8
9#pragma once
10
20
21#include "cpu.h"
22
23#ifdef __cplusplus
24extern "C" {
25#endif
26
30#ifdef NRF_FICR_S
31#define NRF_FICR NRF_FICR_S
32#endif
33
38#ifdef CPU_MODEL_NRF52832XXAA
39#define ERRATA_SPI_SINGLE_BYTE_WORKAROUND (1)
40#endif
41
46#define PROVIDES_PM_OFF
48
52#ifdef FICR_INFO_DEVICEID_DEVICEID_Msk
53#define CPUID_ADDR (&NRF_FICR->INFO.DEVICEID[0])
54#else
55#define CPUID_ADDR (&NRF_FICR->DEVICEID[0])
56#endif
60#define CPUID_LEN (8U)
61
67#if GPIO_COUNT > 1
68#define GPIO_PIN(x, y) ((x << 5) | y)
69#else
70#define GPIO_PIN(x, y) ((x & 0) | y)
71#endif
72
76/* The precise value matters where GPIO_UNDEF is set in registers like
77 * PWM.PSEL.OUT where it is used in sign-extended form to get a UINT32_MAX */
78#define GPIO_UNDEF (UINT8_MAX)
79
86#ifdef NRF_GPIOTE0_S
87#define ISR_GPIOTE isr_gpiote0
88#else
89#define ISR_GPIOTE isr_gpiote
90#endif
91
101#define GPIO_MODE(oe, ic, pr, dr) (oe | (ic << 1) | (pr << 2) | (dr << 8))
102
103#ifndef DOXYGEN /* BEGIN: GPIO LL overwrites */
104#define HAVE_GPIO_SLEW_T
105typedef enum {
107 GPIO_SLEW_SLOW = 0,
108 GPIO_SLEW_FAST = 0,
111
112#define HAVE_GPIO_PULL_STRENGTH_T
113typedef enum {
115 GPIO_PULL_WEAK = 0,
119
120#define HAVE_GPIO_DRIVE_STRENGTH_T
121typedef enum {
123 GPIO_DRIVE_WEAK = 0,
127
128#define HAVE_GPIO_IRQ_TRIG_T
129typedef enum {
130 GPIO_TRIGGER_EDGE_RISING = GPIOTE_CONFIG_POLARITY_LoToHi << GPIOTE_CONFIG_POLARITY_Pos,
131 GPIO_TRIGGER_EDGE_FALLING = GPIOTE_CONFIG_POLARITY_HiToLo << GPIOTE_CONFIG_POLARITY_Pos,
136
137#define HAVE_GPIO_PULL_T
138typedef enum {
139 GPIO_FLOATING = 0,
140 GPIO_PULL_UP = GPIO_PIN_CNF_PULL_Pullup,
141 GPIO_PULL_DOWN = GPIO_PIN_CNF_PULL_Pulldown,
142 GPIO_PULL_KEEP = 2,
144
145#define HAVE_GPIO_STATE_T
146typedef enum {
154
155#define HAVE_GPIO_CONF_T
156typedef union gpio_conf_nrf5x gpio_conf_t;
157
158#endif
159
165 uint8_t bits;
166 struct {
199 uint8_t : 1;
200 };
201};
202/* END: GPIO LL overwrites */
203
204#if !defined(DOXYGEN) && (defined(CPU_NRF53) || defined(CPU_NRF9160))
208#define UART_BAUDRATE_BAUDRATE_Baud1200 UARTE_BAUDRATE_BAUDRATE_Baud1200
209#define UART_BAUDRATE_BAUDRATE_Baud2400 UARTE_BAUDRATE_BAUDRATE_Baud2400
210#define UART_BAUDRATE_BAUDRATE_Baud4800 UARTE_BAUDRATE_BAUDRATE_Baud4800
211#define UART_BAUDRATE_BAUDRATE_Baud9600 UARTE_BAUDRATE_BAUDRATE_Baud9600
212#define UART_BAUDRATE_BAUDRATE_Baud14400 UARTE_BAUDRATE_BAUDRATE_Baud14400
213#define UART_BAUDRATE_BAUDRATE_Baud19200 UARTE_BAUDRATE_BAUDRATE_Baud19200
214#define UART_BAUDRATE_BAUDRATE_Baud28800 UARTE_BAUDRATE_BAUDRATE_Baud28800
215#define UART_BAUDRATE_BAUDRATE_Baud31250 UARTE_BAUDRATE_BAUDRATE_Baud31250
216#define UART_BAUDRATE_BAUDRATE_Baud38400 UARTE_BAUDRATE_BAUDRATE_Baud38400
217#define UART_BAUDRATE_BAUDRATE_Baud56000 UARTE_BAUDRATE_BAUDRATE_Baud56000
218#define UART_BAUDRATE_BAUDRATE_Baud57600 UARTE_BAUDRATE_BAUDRATE_Baud57600
219#define UART_BAUDRATE_BAUDRATE_Baud76800 UARTE_BAUDRATE_BAUDRATE_Baud76800
220#define UART_BAUDRATE_BAUDRATE_Baud115200 UARTE_BAUDRATE_BAUDRATE_Baud115200
221#define UART_BAUDRATE_BAUDRATE_Baud230400 UARTE_BAUDRATE_BAUDRATE_Baud230400
222#define UART_BAUDRATE_BAUDRATE_Baud250000 UARTE_BAUDRATE_BAUDRATE_Baud250000
223#define UART_BAUDRATE_BAUDRATE_Baud460800 UARTE_BAUDRATE_BAUDRATE_Baud460800
224#define UART_BAUDRATE_BAUDRATE_Baud921600 UARTE_BAUDRATE_BAUDRATE_Baud921600
225#define UART_BAUDRATE_BAUDRATE_Baud1M UARTE_BAUDRATE_BAUDRATE_Baud1M
226
227#define SPI_FREQUENCY_FREQUENCY_K125 SPIM_FREQUENCY_FREQUENCY_K125
228#define SPI_FREQUENCY_FREQUENCY_K500 SPIM_FREQUENCY_FREQUENCY_K500
229#define SPI_FREQUENCY_FREQUENCY_M1 SPIM_FREQUENCY_FREQUENCY_M1
230#define SPI_FREQUENCY_FREQUENCY_M4 SPIM_FREQUENCY_FREQUENCY_M4
231#define SPI_FREQUENCY_FREQUENCY_M8 SPIM_FREQUENCY_FREQUENCY_M8
232#define SPI_CONFIG_CPHA_Msk SPIM_CONFIG_CPHA_Msk
233#define SPI_CONFIG_CPOL_Msk SPIM_CONFIG_CPOL_Msk
234#endif
235
239#define SPI_HWCS(x) (SPI_CS_UNDEF)
240
245#define PERIPH_SPI_NEEDS_INIT_CS
246#define PERIPH_SPI_NEEDS_TRANSFER_BYTE
247#define PERIPH_SPI_NEEDS_TRANSFER_REG
248#define PERIPH_SPI_NEEDS_TRANSFER_REGS
250
251#ifndef DOXYGEN
256#define HAVE_GPIO_T
257typedef uint8_t gpio_t;
259
269#define HAVE_GPIO_MODE_T
270typedef enum {
271 GPIO_IN = GPIO_MODE(0, 0, 0, 0),
272 GPIO_IN_PD = GPIO_MODE(0, 0, 1, 0),
273 GPIO_IN_PU = GPIO_MODE(0, 0, 3, 0),
274 GPIO_IN_OD_PU = GPIO_MODE(0, 0, 3, 6),
275 GPIO_OUT = GPIO_MODE(1, 1, 0, 0),
276 GPIO_OD = (0xff),
277 GPIO_OD_PU = (0xfe)
280
285#define HAVE_GPIO_FLANK_T
286typedef enum {
287 GPIO_FALLING = 2,
288 GPIO_RISING = 1,
289 GPIO_BOTH = 3
292#endif /* ndef DOXYGEN */
293
297typedef struct {
298 NRF_TIMER_Type *dev;
306 uint8_t channels;
307 uint8_t bitmode;
308 uint8_t irqn;
310
314#define PERIPH_TIMER_PROVIDES_SET 1
315
324#define TIMER_CHANNEL_NUMOF 5
325
326#ifndef DOXYGEN
331#define HAVE_SPI_MODE_T
332typedef enum {
333 SPI_MODE_0 = 0,
334 SPI_MODE_1 = SPI_CONFIG_CPHA_Msk,
335 SPI_MODE_2 = SPI_CONFIG_CPOL_Msk,
336 SPI_MODE_3 = (SPI_CONFIG_CPOL_Msk | SPI_CONFIG_CPHA_Msk)
337} spi_mode_t;
339
344#define HAVE_SPI_CLK_T
345typedef enum {
346 SPI_CLK_100KHZ = SPI_FREQUENCY_FREQUENCY_K125,
347 SPI_CLK_400KHZ = SPI_FREQUENCY_FREQUENCY_K500,
348 SPI_CLK_1MHZ = SPI_FREQUENCY_FREQUENCY_M1,
349 SPI_CLK_5MHZ = SPI_FREQUENCY_FREQUENCY_M4,
350 SPI_CLK_10MHZ = SPI_FREQUENCY_FREQUENCY_M8
351} spi_clk_t;
353#endif /* ndef DOXYGEN */
354
359#define NWDT_TIME_LOWER_LIMIT (1)
360/* Set upper limit to the maximum possible value that could go in CRV register */
361#define NWDT_TIME_UPPER_LIMIT ((UINT32_MAX >> 15) * US_PER_MS + 1)
363
367typedef struct {
368 gpio_t a_pin;
369 gpio_t b_pin;
370 gpio_t led_pin;
374
383uint8_t gpio_int_get_exti(gpio_t pin);
384
388typedef struct {
389#ifdef UARTE_PRESENT
390 NRF_UARTE_Type *dev;
392#else
393 NRF_UART_Type *dev;
394#endif
395 gpio_t rx_pin;
396 gpio_t tx_pin;
397#ifdef MODULE_PERIPH_UART_HW_FC
398 gpio_t rts_pin;
399 gpio_t cts_pin;
400#endif
401 uint8_t irqn;
403
407#ifndef UART_TXBUF_SIZE
408#define UART_TXBUF_SIZE (64)
409#endif
410
414#define USBDEV_CPU_DMA_ALIGNMENT (4)
415
419#define USBDEV_CPU_DMA_REQUIREMENTS __attribute__((aligned(USBDEV_CPU_DMA_ALIGNMENT)))
420
421#if !defined(CPU_FAM_NRF51) && !defined(DOXYGEN)
426#define PWM_CHANNELS (4U)
427
435#define PWM_MODE(ud, pol) (ud | (pol << 15))
436
440#define HAVE_PWM_MODE_T
441typedef enum {
442 PWM_LEFT = PWM_MODE(0, 1),
443 PWM_RIGHT = PWM_MODE(0, 0),
444 PWM_CENTER = PWM_MODE(1, 1),
445 PWM_CENTER_INV = PWM_MODE(1, 0)
446} pwm_mode_t;
447
462#if defined(PWM_PRESENT)
463typedef struct {
464 NRF_PWM_Type *dev;
465 gpio_t pin[PWM_CHANNELS];
466} pwm_conf_t;
467#endif
468#endif /* ndef CPU_FAM_NRF51 */
469#ifndef CPU_NRF51
470
474#define SPI_SCKSEL (dev(bus)->PSEL.SCK)
475#define SPI_MOSISEL (dev(bus)->PSEL.MOSI)
476#define SPI_MISOSEL (dev(bus)->PSEL.MISO)
477
481typedef struct {
482 NRF_SPIM_Type *dev;
483 gpio_t sclk;
484 gpio_t mosi;
485 gpio_t miso;
486#if ERRATA_SPI_SINGLE_BYTE_WORKAROUND
487 uint8_t ppi;
488#endif
489} spi_conf_t;
490
496typedef void (*shared_irq_cb_t)(void *arg);
497
505void shared_irq_register_spi(NRF_SPIM_Type *bus,
506 shared_irq_cb_t cb, void *arg);
507
515void shared_irq_register_i2c(NRF_TWIM_Type *bus,
516 shared_irq_cb_t cb, void *arg);
517
525void shared_irq_register_uart(NRF_UARTE_Type *bus,
526 shared_irq_cb_t cb, void *arg);
527
535void nrf5x_i2c_acquire(NRF_TWIM_Type *bus, shared_irq_cb_t cb, void *arg);
536
542void nrf5x_i2c_release(NRF_TWIM_Type *bus);
543
551void nrf5x_spi_acquire(NRF_SPIM_Type *bus, shared_irq_cb_t cb, void *arg);
552
558void nrf5x_spi_release(NRF_SPIM_Type *bus);
559
563#ifndef UART_TXBUF_SIZE
564#define UART_TXBUF_SIZE (64)
565#endif
566
571#ifndef CONFIG_SPI_MBUF_SIZE
572#define CONFIG_SPI_MBUF_SIZE 64
573#endif
574
575#ifndef DOXYGEN
580#define HAVE_I2C_SPEED_T
581typedef enum {
582 I2C_SPEED_LOW = 0xff,
583 I2C_SPEED_NORMAL = TWIM_FREQUENCY_FREQUENCY_K100,
584 I2C_SPEED_FAST = TWIM_FREQUENCY_FREQUENCY_K400,
585 I2C_SPEED_FAST_PLUS = 0xfe,
586 I2C_SPEED_HIGH = 0xfd,
589#endif /* ndef DOXYGEN */
590
595typedef struct {
596 NRF_TWIM_Type *dev;
597 gpio_t scl;
598 gpio_t sda;
600} i2c_conf_t;
602
607#define PERIPH_I2C_NEED_READ_REG
608#define PERIPH_I2C_NEED_WRITE_REG
610
615#define i2c_pin_sda(dev) i2c_config[dev].sda
616#define i2c_pin_scl(dev) i2c_config[dev].scl
618#endif /* ndef CPU_NRF51 */
619
620#ifdef __cplusplus
621}
622#endif
623
gpio_flank_t
Definition periph_cpu.h:179
@ GPIO_OUT
select GPIO MASK as output
Definition periph_cpu.h:164
@ GPIO_IN
select GPIO MASK as input
Definition periph_cpu.h:163
i2c_speed_t
Definition periph_cpu.h:275
@ I2C_SPEED_NORMAL
normal mode: ~100 kbit/s
Definition periph_cpu.h:277
@ I2C_SPEED_FAST_PLUS
fast plus mode: ~1000 kbit/s
Definition periph_cpu.h:279
@ I2C_SPEED_LOW
low speed mode: ~10 kbit/s
Definition periph_cpu.h:276
@ I2C_SPEED_HIGH
high speed mode: ~3400 kbit/s
Definition periph_cpu.h:281
@ I2C_SPEED_FAST
fast mode: ~400 kbit/s
Definition periph_cpu.h:278
spi_clk_t
Definition periph_cpu.h:351
@ SPI_CLK_10MHZ
drive the SPI bus with 10MHz
Definition periph_cpu.h:356
@ SPI_CLK_5MHZ
drive the SPI bus with 5MHz
Definition periph_cpu.h:355
@ SPI_CLK_400KHZ
drive the SPI bus with 400KHz
Definition periph_cpu.h:353
@ SPI_CLK_1MHZ
drive the SPI bus with 1MHz
Definition periph_cpu.h:354
@ SPI_CLK_100KHZ
drive the SPI bus with 100KHz
Definition periph_cpu.h:352
pwm_mode_t
@ PWM_CENTER
center aligned
@ PWM_LEFT
left aligned
@ PWM_RIGHT
right aligned
gpio_mode_t
Available pin modes.
Definition periph_cpu.h:91
gpio_irq_trig_t
Definition of possible IRQ triggers.
Definition gpio_ll_irq.h:71
@ GPIO_TRIGGER_EDGE_FALLING
edge triggered IRQ on falling flanks only
Definition gpio_ll_irq.h:72
@ GPIO_TRIGGER_LEVEL_HIGH
level triggered IRQ on high input
Definition gpio_ll_irq.h:77
@ GPIO_TRIGGER_EDGE_RISING
edge triggered IRQ on rising flanks only
Definition gpio_ll_irq.h:74
@ GPIO_TRIGGER_EDGE_BOTH
edge triggered IRQ on falling AND rising flanks
Definition gpio_ll_irq.h:75
@ GPIO_TRIGGER_LEVEL_LOW
level triggered IRQ on low input
Definition gpio_ll_irq.h:78
gpio_pull_t
Enumeration of pull resistor configurations.
Definition gpio_ll.h:257
gpio_pull_strength_t
Enumeration of pull resistor values.
Definition gpio_ll.h:275
gpio_state_t
Enumeration of GPIO states (direction)
Definition gpio_ll.h:165
gpio_slew_t
Enumeration of slew rate settings.
Definition gpio_ll.h:339
gpio_drive_strength_t
Enumeration of drive strength options.
Definition gpio_ll.h:306
typedef gpio_conf_t
GPIO pin configuration.
Definition gpio_ll.h:423
@ GPIO_FLOATING
No pull ups nor pull downs enabled.
Definition gpio_ll.h:258
@ GPIO_PULL_KEEP
Keep the signal at current logic level with pull up/down resistors.
Definition gpio_ll.h:261
@ GPIO_PULL_DOWN
Pull down resistor enabled.
Definition gpio_ll.h:260
@ GPIO_PULL_UP
Pull up resistor enabled.
Definition gpio_ll.h:259
@ GPIO_PULL_WEAKEST
Use the weakest (highest Ohm value) resistor.
Definition gpio_ll.h:276
@ GPIO_PULL_WEAK
Use a weak pull resistor.
Definition gpio_ll.h:277
@ GPIO_PULL_STRONG
Use a strong pull resistor.
Definition gpio_ll.h:278
@ GPIO_PULL_STRONGEST
Use the strongest pull resistor.
Definition gpio_ll.h:279
@ GPIO_OUTPUT_OPEN_SOURCE
Use pin as output in open emitter configuration.
Definition gpio_ll.h:202
@ GPIO_USED_BY_PERIPHERAL
The GPIO pin is used by a peripheral.
Definition gpio_ll.h:221
@ GPIO_OUTPUT_OPEN_DRAIN
Use pin as output in open collector configuration.
Definition gpio_ll.h:189
@ GPIO_OUTPUT_PUSH_PULL
Use pin as output in push-pull configuration.
Definition gpio_ll.h:176
@ GPIO_DISCONNECT
Disconnect pin from all peripherals.
Definition gpio_ll.h:249
@ GPIO_INPUT
Use pin as input.
Definition gpio_ll.h:208
@ GPIO_SLEW_SLOWEST
let the output voltage level rise/fall as slow as possible
Definition gpio_ll.h:340
@ GPIO_SLEW_FAST
let the output voltage level rise/fall fast
Definition gpio_ll.h:343
@ GPIO_SLEW_SLOW
let the output voltage level rise/fall slowly
Definition gpio_ll.h:342
@ GPIO_SLEW_FASTEST
let the output voltage level rise/fall as fast as possible
Definition gpio_ll.h:344
@ GPIO_DRIVE_STRONG
Use a strong drive strength.
Definition gpio_ll.h:309
@ GPIO_DRIVE_WEAK
Use a weak drive strength.
Definition gpio_ll.h:308
@ GPIO_DRIVE_STRONGEST
Use the strongest drive strength.
Definition gpio_ll.h:310
@ GPIO_DRIVE_WEAKEST
Use the weakest drive strength.
Definition gpio_ll.h:307
spi_mode_t
Support SPI modes.
Definition periph_cpu.h:42
@ SPI_MODE_0
CPOL=0, CPHA=0.
Definition periph_cpu.h:43
@ SPI_MODE_2
CPOL=1, CPHA=0.
Definition periph_cpu.h:45
@ SPI_MODE_1
CPOL=0, CPHA=1.
Definition periph_cpu.h:44
@ SPI_MODE_3
CPOL=1, CPHA=1.
Definition periph_cpu.h:46
void nrf5x_i2c_acquire(NRF_TWIM_Type *bus, shared_irq_cb_t cb, void *arg)
Acquire the shared I2C/SPI peripheral in I2C mode.
uint8_t gpio_int_get_exti(gpio_t pin)
Retrieve the exti(GPIOTE) channel associated with a gpio.
void shared_irq_register_i2c(NRF_TWIM_Type *bus, shared_irq_cb_t cb, void *arg)
Register an I2C IRQ handler for a shared UART/I2C/SPI irq vector.
void nrf5x_spi_release(NRF_SPIM_Type *bus)
Acquire the shared I2C/SPI peripheral in SPI mode.
void(* shared_irq_cb_t)(void *arg)
Common UART/SPI/I2C interrupt callback.
#define GPIO_MODE(oe, ic, pr, dr)
Generate GPIO mode bitfields.
void nrf5x_spi_acquire(NRF_SPIM_Type *bus, shared_irq_cb_t cb, void *arg)
Acquire the shared I2C/SPI peripheral in SPI mode.
void shared_irq_register_spi(NRF_SPIM_Type *bus, shared_irq_cb_t cb, void *arg)
Register a SPI IRQ handler for a shared UART/I2C/SPI irq vector.
void shared_irq_register_uart(NRF_UARTE_Type *bus, shared_irq_cb_t cb, void *arg)
Register an UART IRQ handler for a shared UART/I2C/SPI irq vector.
void nrf5x_i2c_release(NRF_TWIM_Type *bus)
Release the shared I2C/SPI peripheral in I2C mode.
I2C configuration structure.
Definition periph_cpu.h:298
i2c_speed_t speed
Configured bus speed, actual speed may be lower but never higher.
Definition periph_cpu.h:303
TWI_t * dev
Pointer to hardware module registers.
Definition periph_cpu.h:299
gpio_t sda
GPIO used as SDA pin.
Definition periph_cpu.h:467
gpio_t scl
GPIO used as SCL pin.
Definition periph_cpu.h:466
PWM device configuration.
Quadrature decoder configuration struct.
bool debounce_filter
Enable/disable debounce filter.
gpio_t b_pin
GPIO Pin for phase B.
gpio_t a_pin
GPIO Pin for phase A.
gpio_t led_pin
LED GPIO, GPIO_UNDEF to disable.
uint8_t sample_period
Sample period used, e.g.
SPI device configuration.
Definition periph_cpu.h:336
gpio_t mosi
GPIO used as MOSI pin.
Definition periph_cpu.h:862
SPI_t * dev
pointer to the used SPI device
Definition periph_cpu.h:337
gpio_t sclk
SCLK pin.
Definition periph_cpu.h:89
gpio_t miso
GPIO used as MISO pin.
Definition periph_cpu.h:863
Timer device configuration.
Definition periph_cpu.h:263
uint8_t irqn
global IRQ channel
Definition periph_cpu.h:323
uint8_t bitmode
counter width
int channels
Number of channels for the timer.
Definition periph_cpu.h:116
TC0_t * dev
Pointer to the used as Timer device.
Definition periph_cpu.h:264
UART device configuration.
Definition periph_cpu.h:217
USART_t * dev
pointer to the used UART device
Definition periph_cpu.h:218
uint8_t irqn
IRQ channel.
Definition periph_cpu.h:335
gpio_t tx_pin
pin used for TX
Definition periph_cpu.h:221
gpio_t rx_pin
pin used for RX
Definition periph_cpu.h:220
GPIO pin configuration for nRF5x MCUs.
gpio_pull_t pull
Pull resistor configuration.
gpio_drive_strength_t drive_strength
Drive strength of the GPIO.
gpio_state_t state
State of the pin.
bool initial_value
Initial value of the output.
uint8_t bits
the raw bits