Contiki 3.x
uart.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2008 Swedish Institute of Computer Science
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 are met:
7  *
8  * * Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  * * Redistributions in binary form must reproduce the above copyright
11  * notice, this list of conditions and the following disclaimer in
12  * the documentation and/or other materials provided with the
13  * distribution.
14  * * Neither the name of the copyright holders nor the names of
15  * contributors may be used to endorse or promote products derived
16  * from this software without specific prior written permission.
17  *
18  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
22  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28  * POSSIBILITY OF SUCH DAMAGE.
29  */
30 /**
31  * \file
32  *
33  * \brief
34  * Handles the control of the USART for communication with the ATmega1284p
35  * for sending commands.
36  *
37  * \author
38  * Mike Vidales mavida404@gmail.com
39  *
40  */
41 
42 #ifndef UART_H_
43 #define UART_H_ 1
44 
45 #include <inttypes.h>
46 
47 /** \name ASCII characters defined */
48 /** \{ */
49 #define SOF_CHAR (0x01) /**< Start-of-frame character. */
50 #define EOF_CHAR (0x04) /**< End-of-frame character. */
51 /** \} */
52 
53 /* Macros & Defines */
54 
55 #define BUFSIZE 80
56 #define BAUD_RATE_38400 (12)
57 
58 /** \brief Circular buffer structure */
59 typedef struct {
60  volatile uint8_t head; /**< Index to last available character in buffer. */
61  volatile uint8_t tail; /**< Index to first available character in buffer. */
62  uint8_t buf[BUFSIZE]; /**< The actual buffer used for storing characters. */
63 } tcirc_buf;
64 
65 extern tcirc_buf rxbuf;
66 #define rx_char_ready() (rxbuf.head != rxbuf.tail)
67 
68 /* Serial port functions */
69 void uart_init(void);
70 void uart_deinit(void);
71 uint8_t uart_circ_buf_has_char(tcirc_buf *cbuf);
72 void uart_clear_rx_buf(void);
73 uint8_t uart_get_char_rx(void);
74 void uart_send_byte(uint8_t byte);
75 void uart_serial_send_frame(uint8_t cmd, uint8_t payload_length, uint8_t *payload);
76 void uart_serial_rcv_frame(uint8_t wait_for_it);
77 
78 #endif /* UART_H_ */
volatile uint8_t tail
Index to first available character in buffer.
Definition: uart.h:61
uint8_t uart_circ_buf_has_char(tcirc_buf *cbuf)
This will check for a character in the requested buffer.
Definition: uart.c:143
void uart_init(const unsigned int uart_num, uint32_t module_clk_hz, const uint32_t baud)
Initialize UART.
Definition: uart.c:154
void uart_send_byte(uint8_t byte)
Send one byte over the uart.
Definition: uart.c:258
void uart_serial_send_frame(uint8_t cmd, uint8_t payload_length, uint8_t *payload)
This function builds and sends a binary command frame to the ATmega1284p.
Definition: uart.c:295
void uart_serial_rcv_frame(uint8_t wait_for_ack)
This will receive a frame from the ATmega1284p and parse the incoming data.
Definition: uart.c:340
volatile uint8_t head
Index to last available character in buffer.
Definition: uart.h:60
tcirc_buf rxbuf
The RX circular buffer, for storing characters from serial port.
Definition: uart.c:56
void uart_deinit(void)
Turn off UART for sleep mode.
Definition: uart.c:241
Circular buffer structure.
Definition: uart.h:59
void uart_clear_rx_buf(void)
This will clear the RX buffer.
Definition: uart.c:130
uint8_t uart_get_char_rx(void)
This will wait for a new character from the ATmega1284p and timeout if no new character is received...
Definition: uart.c:195