1*1b2596b5SMatthias Ringwald /**
2*1b2596b5SMatthias Ringwald *
3*1b2596b5SMatthias Ringwald * \file
4*1b2596b5SMatthias Ringwald *
5*1b2596b5SMatthias Ringwald * \brief USART Serial driver functions.
6*1b2596b5SMatthias Ringwald *
7*1b2596b5SMatthias Ringwald *
8*1b2596b5SMatthias Ringwald * Copyright (c) 2010-2015 Atmel Corporation. All rights reserved.
9*1b2596b5SMatthias Ringwald *
10*1b2596b5SMatthias Ringwald * \asf_license_start
11*1b2596b5SMatthias Ringwald *
12*1b2596b5SMatthias Ringwald * \page License
13*1b2596b5SMatthias Ringwald *
14*1b2596b5SMatthias Ringwald * Redistribution and use in source and binary forms, with or without
15*1b2596b5SMatthias Ringwald * modification, are permitted provided that the following conditions are met:
16*1b2596b5SMatthias Ringwald *
17*1b2596b5SMatthias Ringwald * 1. Redistributions of source code must retain the above copyright notice,
18*1b2596b5SMatthias Ringwald * this list of conditions and the following disclaimer.
19*1b2596b5SMatthias Ringwald *
20*1b2596b5SMatthias Ringwald * 2. Redistributions in binary form must reproduce the above copyright notice,
21*1b2596b5SMatthias Ringwald * this list of conditions and the following disclaimer in the documentation
22*1b2596b5SMatthias Ringwald * and/or other materials provided with the distribution.
23*1b2596b5SMatthias Ringwald *
24*1b2596b5SMatthias Ringwald * 3. The name of Atmel may not be used to endorse or promote products derived
25*1b2596b5SMatthias Ringwald * from this software without specific prior written permission.
26*1b2596b5SMatthias Ringwald *
27*1b2596b5SMatthias Ringwald * 4. This software may only be redistributed and used in connection with an
28*1b2596b5SMatthias Ringwald * Atmel microcontroller product.
29*1b2596b5SMatthias Ringwald *
30*1b2596b5SMatthias Ringwald * THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR IMPLIED
31*1b2596b5SMatthias Ringwald * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
32*1b2596b5SMatthias Ringwald * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE
33*1b2596b5SMatthias Ringwald * EXPRESSLY AND SPECIFICALLY DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR
34*1b2596b5SMatthias Ringwald * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
35*1b2596b5SMatthias Ringwald * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
36*1b2596b5SMatthias Ringwald * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
37*1b2596b5SMatthias Ringwald * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
38*1b2596b5SMatthias Ringwald * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
39*1b2596b5SMatthias Ringwald * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
40*1b2596b5SMatthias Ringwald * POSSIBILITY OF SUCH DAMAGE.
41*1b2596b5SMatthias Ringwald *
42*1b2596b5SMatthias Ringwald * \asf_license_stop
43*1b2596b5SMatthias Ringwald *
44*1b2596b5SMatthias Ringwald */
45*1b2596b5SMatthias Ringwald /*
46*1b2596b5SMatthias Ringwald * Support and FAQ: visit <a href="http://www.atmel.com/design-support/">Atmel Support</a>
47*1b2596b5SMatthias Ringwald */
48*1b2596b5SMatthias Ringwald #include "serial.h"
49*1b2596b5SMatthias Ringwald
50*1b2596b5SMatthias Ringwald /**
51*1b2596b5SMatthias Ringwald * \brief Send a sequence of bytes to USART device
52*1b2596b5SMatthias Ringwald *
53*1b2596b5SMatthias Ringwald * \param usart Base address of the USART instance.
54*1b2596b5SMatthias Ringwald * \param data Data buffer to read
55*1b2596b5SMatthias Ringwald * \param len Length of data
56*1b2596b5SMatthias Ringwald *
57*1b2596b5SMatthias Ringwald */
usart_serial_write_packet(usart_if usart,const uint8_t * data,size_t len)58*1b2596b5SMatthias Ringwald status_code_t usart_serial_write_packet(usart_if usart, const uint8_t *data,
59*1b2596b5SMatthias Ringwald size_t len)
60*1b2596b5SMatthias Ringwald {
61*1b2596b5SMatthias Ringwald while (len) {
62*1b2596b5SMatthias Ringwald usart_serial_putchar(usart, *data);
63*1b2596b5SMatthias Ringwald len--;
64*1b2596b5SMatthias Ringwald data++;
65*1b2596b5SMatthias Ringwald }
66*1b2596b5SMatthias Ringwald return STATUS_OK;
67*1b2596b5SMatthias Ringwald }
68*1b2596b5SMatthias Ringwald
69*1b2596b5SMatthias Ringwald
70*1b2596b5SMatthias Ringwald /**
71*1b2596b5SMatthias Ringwald * \brief Receive a sequence of bytes from USART device
72*1b2596b5SMatthias Ringwald *
73*1b2596b5SMatthias Ringwald * \param usart Base address of the USART instance.
74*1b2596b5SMatthias Ringwald * \param data Data buffer to write
75*1b2596b5SMatthias Ringwald * \param len Length of data
76*1b2596b5SMatthias Ringwald *
77*1b2596b5SMatthias Ringwald */
usart_serial_read_packet(usart_if usart,uint8_t * data,size_t len)78*1b2596b5SMatthias Ringwald status_code_t usart_serial_read_packet(usart_if usart, uint8_t *data,
79*1b2596b5SMatthias Ringwald size_t len)
80*1b2596b5SMatthias Ringwald {
81*1b2596b5SMatthias Ringwald while (len) {
82*1b2596b5SMatthias Ringwald usart_serial_getchar(usart, data);
83*1b2596b5SMatthias Ringwald len--;
84*1b2596b5SMatthias Ringwald data++;
85*1b2596b5SMatthias Ringwald }
86*1b2596b5SMatthias Ringwald return STATUS_OK;
87*1b2596b5SMatthias Ringwald }
88