Contiki-NG
uart-arch.c
Go to the documentation of this file.
1/*
2 * Copyright (C) 2022 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 gecko
33 * @{
34 *
35 * \addtogroup gecko-dev Device drivers
36 * @{
37 *
38 * \addtogroup gecko-uart UART driver
39 * @{
40 *
41 * \file
42 * UART implementation for the gecko.
43 * \author
44 * Yago Fontoura do Rosario <yago.rosario@hotmail.com.br>
45 *
46 */
47/*---------------------------------------------------------------------------*/
48#include "contiki.h"
49
50#include "uartdrv.h"
51#include "sl_uartdrv_instances.h"
52/*---------------------------------------------------------------------------*/
53static int (*input_handler)(unsigned char c) = NULL;
54static uint8_t uarte_buffer;
55/*---------------------------------------------------------------------------*/
56static void
57receive_callback(UARTDRV_HandleData_t *handle, Ecode_t transferStatus,
58 uint8_t *data, UARTDRV_Count_t transferCount)
59{
60 UARTDRV_Count_t i;
61 if(transferStatus == ECODE_EMDRV_UARTDRV_OK &&
62 input_handler != NULL) {
63 for(i = 0; i < transferCount; i++) {
64 input_handler(data[i]);
65 }
66 UARTDRV_Receive(sl_uartdrv_usart_vcom_handle, &uarte_buffer, sizeof(uarte_buffer), receive_callback);
67 }
68}
69/*---------------------------------------------------------------------------*/
70void
71uart_write(unsigned char *s, unsigned int len)
72{
73 UARTDRV_ForceTransmit(sl_uartdrv_usart_vcom_handle, s, len);
74}
75/*---------------------------------------------------------------------------*/
76void
77uart_set_input(int (*input)(unsigned char c))
78{
79 input_handler = input;
80
81 if(input) {
82 UARTDRV_Receive(sl_uartdrv_usart_vcom_handle, &uarte_buffer, sizeof(uarte_buffer), receive_callback);
83 }
84}
85/*---------------------------------------------------------------------------*/
86void
88{
89 sl_uartdrv_init_instances();
90}
91/*---------------------------------------------------------------------------*/
92/**
93 * @}
94 * @}
95 * @}
96 */
void uart_init(void)
Initializa the UART driver.
Definition: uart-arch.c:87
void uart_set_input(int(*input)(unsigned char c))
Sets the input handler called in the event handler.
Definition: uart-arch.c:77
void uart_write(unsigned char *s, unsigned int len)
Writes to the UART driver.
Definition: uart-arch.c:71
static void input(void)
Process a received 6lowpan packet.
Definition: sicslowpan.c:1833