Contiki-NG
Loading...
Searching...
No Matches
uarte-arch.c
Go to the documentation of this file.
1/*
2 * Copyright (C) 2020 Yago Fontoura do Rosario <yago.rosario@hotmail.com.br>
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution.
13 * 3. Neither the name of the copyright holder nor the names of its
14 * contributors may be used to endorse or promote products derived
15 * from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
20 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
21 * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
22 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
23 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
24 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
26 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
28 * OF THE POSSIBILITY OF SUCH DAMAGE.
29 */
30/*---------------------------------------------------------------------------*/
31/**
32 * \addtogroup nrf
33 * @{
34 *
35 * \addtogroup nrf-dev Device drivers
36 * @{
37 *
38 * \addtogroup nrf-uarte UARTE driver
39 * @{
40 *
41 * \file
42 * UARTE implementation for the nRF.
43 * \author
44 * Yago Fontoura do Rosario <yago.rosario@hotmail.com.br>
45 *
46 */
47/*---------------------------------------------------------------------------*/
48#include "contiki.h"
49/*---------------------------------------------------------------------------*/
50#if NRF_HAS_UARTE
51/*---------------------------------------------------------------------------*/
52#include "nrfx_config.h"
53#if defined(__GNUC__)
54#pragma GCC diagnostic push
55#pragma GCC diagnostic ignored "-Wunused-variable"
56#endif
57#include "nrfx_uarte.h"
58#if defined(__GNUC__)
59#pragma GCC diagnostic pop
60#endif
61#include "hal/nrf_gpio.h"
62/*---------------------------------------------------------------------------*/
63static int (*input_handler)(unsigned char c) = NULL;
64/*---------------------------------------------------------------------------*/
65#ifndef NRF_UARTE_INSTANCE_ID
66#define NRF_UARTE_INSTANCE_ID 0
67#endif
68
69#if defined(NRF_UARTE_TX_PORT) && defined(NRF_UARTE_TX_PIN)
70#define UARTE_TX_PORT NRF_UARTE_TX_PORT
71#define UARTE_TX_PIN NRF_UARTE_TX_PIN
72#elif defined(NRF_UARTE0_TX_PORT) && defined(NRF_UARTE0_TX_PIN)
73#define UARTE_TX_PORT NRF_UARTE0_TX_PORT
74#define UARTE_TX_PIN NRF_UARTE0_TX_PIN
75#endif
76
77#if defined(NRF_UARTE_RX_PORT) && defined(NRF_UARTE_RX_PIN)
78#define UARTE_RX_PORT NRF_UARTE_RX_PORT
79#define UARTE_RX_PIN NRF_UARTE_RX_PIN
80#elif defined(NRF_UARTE0_RX_PORT) && defined(NRF_UARTE0_RX_PIN)
81#define UARTE_RX_PORT NRF_UARTE0_RX_PORT
82#define UARTE_RX_PIN NRF_UARTE0_RX_PIN
83#endif
84
85static nrfx_uarte_t instance = NRFX_UARTE_INSTANCE(NRF_UARTE_INSTANCE_ID);
86static uint8_t uarte_buffer;
87static bool is_initialized;
88/*---------------------------------------------------------------------------*/
89void
90uarte_write(unsigned char data)
91{
92 if(!is_initialized) {
93 return;
94 }
95 static uint8_t tx_byte;
96 tx_byte = data;
97 do {
98 } while(nrfx_uarte_tx(&instance, &tx_byte, 1, NRFX_UARTE_TX_BLOCKING)
99 == NRFX_ERROR_BUSY);
100}
101/*---------------------------------------------------------------------------*/
102/**
103 * @brief UARTE event handler
104 *
105 * @param p_event UARTE event
106 * @param p_context UARTE context
107 */
108static void
109uarte_handler(nrfx_uarte_event_t const *p_event, void *p_context)
110{
111 uint8_t *p_data;
112 size_t bytes;
113 size_t i;
114
115 /* Don't spend time in interrupt if the input_handler is not set */
116 if(p_event->type == NRFX_UARTE_EVT_RX_DONE) {
117 if(input_handler) {
118#if NRFX_API_VER_AT_LEAST(3, 2, 0)
119 /* Newer nrfx uses separate rx/tx structures in the event union. */
120 p_data = p_event->data.rx.p_buffer;
121 bytes = p_event->data.rx.length;
122#else
123 p_data = p_event->data.rxtx.p_data;
124 bytes = p_event->data.rxtx.bytes;
125#endif
126 for(i = 0; i < bytes; i++) {
127 input_handler(p_data[i]);
128 }
129 nrfx_uarte_rx(&instance, &uarte_buffer, sizeof(uarte_buffer));
130 }
131 }
132}
133/*---------------------------------------------------------------------------*/
134void
135uarte_set_input(int (*input)(unsigned char c))
136{
137 input_handler = input;
138
139 if(input) {
140 nrfx_uarte_rx(&instance, &uarte_buffer, sizeof(uarte_buffer));
141 }
142}
143/*---------------------------------------------------------------------------*/
144void
145uarte_init(void)
146{
147#if defined(UARTE_TX_PORT) && defined(UARTE_TX_PIN) \
148 && defined(UARTE_RX_PORT) && defined(UARTE_RX_PIN)
149 const nrfx_uarte_config_t config = NRFX_UARTE_DEFAULT_CONFIG(
150 NRF_GPIO_PIN_MAP(UARTE_TX_PORT, UARTE_TX_PIN),
151 NRF_GPIO_PIN_MAP(UARTE_RX_PORT, UARTE_RX_PIN)
152 );
153
154 nrfx_uarte_init(&instance, &config, uarte_handler);
155#else
156 (void) uarte_handler;
157#endif /* defined(UARTE_TX_PORT) && defined(UARTE_TX_PIN) \
158 && defined(UARTE_RX_PORT) && defined(UARTE_RX_PIN) */
159
160 is_initialized = true;
161}
162/*---------------------------------------------------------------------------*/
163void
164uarte_uninit(void)
165{
166 if(!is_initialized) {
167 return;
168 }
169 is_initialized = false;
170 nrfx_uarte_uninit(&instance);
171}
172/*---------------------------------------------------------------------------*/
173#endif /* NRF_HAS_UARTE */
174/*---------------------------------------------------------------------------*/
175/**
176 * @}
177 * @}
178 * @}
179 */
void uarte_write(unsigned char data)
Writes to the UARTE driver.
void uarte_uninit(void)
Tear down the UARTE driver, releasing the peripheral.
void uarte_init(void)
Initializa the UARTE driver.
void uarte_set_input(int(*input)(unsigned char c))
Sets the input handler called in the event handler.
static void input(void)
Process a received 6lowpan packet.