1 /*******************************************************************
2 Copyright (C) 2009 FreakLabs
5 Redistribution and use in source and binary forms, with or without
6 modification, are permitted provided that the following conditions
9 1. Redistributions of source code must retain the above copyright
10 notice, this list of conditions and the following disclaimer.
11 2. Redistributions in binary form must reproduce the above copyright
12 notice, this list of conditions and the following disclaimer in the
13 documentation and/or other materials provided with the distribution.
14 3. Neither the name of the the copyright holder nor the names of its contributors
15 may be used to endorse or promote products derived from this software
16 without specific prior written permission.
18 THIS SOFTWARE IS PROVIDED BY THE THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS'' AND
19 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 INSTITUTE OR CONTRIBUTORS BE LIABLE
22 FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23 DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
24 OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25 HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
26 LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
27 OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30 Originally written by Christopher Wang aka Akiba.
31 Please post support questions to the FreakLabs forum.
32 *******************************************************************/
34 /**************************************************************************/
37 @author Christopher Wang (Freaklabs)
38 Modified by: K. Townsend (microBuilder.eu)
41 Original code taken from the FreakUSB Open Source USB Device Stack
42 http://freaklabs.org/index.php/FreakUSB-Open-Source-USB-Device-Stack.html
44 If it works well, you can thank Akiba at Freaklabs. If it fails
45 miserably, you can blame me (since parts of it it were rather
46 ungraciously modified). :-)
49 /**************************************************************************/
53 /**************************************************************************/
55 Initialises the RX FIFO buffer
57 /**************************************************************************/
58 void uartRxBufferInit()
60 uart_pcb_t
*pcb
= uartGetPCB();
64 /**************************************************************************/
66 Read one byte out of the RX buffer. This function will return the byte
67 located at the array index of the read pointer, and then increment the
68 read pointer index. If the read pointer exceeds the maximum buffer
69 size, it will roll over to zero.
71 /**************************************************************************/
72 uint8_t uartRxBufferRead()
74 uart_pcb_t
*pcb
= uartGetPCB();
77 data
= pcb
->rxfifo
.buf
[pcb
->rxfifo
.rd_ptr
];
78 pcb
->rxfifo
.rd_ptr
= (pcb
->rxfifo
.rd_ptr
+ 1) % CFG_UART_BUFSIZE
;
83 /**************************************************************************/
85 Read byte array from uart
87 /**************************************************************************/
88 bool uartRxBufferReadArray(byte_t
* rx
, size_t* len
)
90 uart_pcb_t
*pcb
= uartGetPCB();
93 while(pcb
->rxfifo
.len
!= 0)
95 (*rx
) = uartRxBufferRead();
103 /**************************************************************************/
105 Write one byte into the RX buffer. This function will write one
106 byte into the array index specified by the write pointer and increment
107 the write index. If the write index exceeds the max buffer size, then it
108 will roll over to zero.
110 /**************************************************************************/
111 void uartRxBufferWrite(uint8_t data
)
113 uart_pcb_t
*pcb
= uartGetPCB();
115 pcb
->rxfifo
.buf
[pcb
->rxfifo
.wr_ptr
] = data
;
116 pcb
->rxfifo
.wr_ptr
= (pcb
->rxfifo
.wr_ptr
+ 1) % CFG_UART_BUFSIZE
;
120 /**************************************************************************/
122 Clear the fifo read and write pointers and set the length to zero.
124 /**************************************************************************/
125 void uartRxBufferClearFIFO()
127 uart_pcb_t
*pcb
= uartGetPCB();
129 pcb
->rxfifo
.rd_ptr
= 0;
130 pcb
->rxfifo
.wr_ptr
= 0;
134 /**************************************************************************/
136 Check whether there is any data pending on the RX buffer.
138 /**************************************************************************/
139 uint8_t uartRxBufferDataPending()
141 uart_pcb_t
*pcb
= uartGetPCB();
143 if (pcb
->rxfifo
.len
!= 0)
This page took 0.057537 seconds and 5 git commands to generate.