RTEMS
6.1-rc5
Loading...
Searching...
No Matches
bsps
aarch64
xilinx-versal
include
dev
serial
versal-uart.h
Go to the documentation of this file.
1
/* SPDX-License-Identifier: BSD-2-Clause */
2
11
/*
12
* Copyright (C) 2021 Gedare Bloom <gedare@rtems.org>
13
*
14
* Redistribution and use in source and binary forms, with or without
15
* modification, are permitted provided that the following conditions
16
* are met:
17
* 1. Redistributions of source code must retain the above copyright
18
* notice, this list of conditions and the following disclaimer.
19
* 2. Redistributions in binary form must reproduce the above copyright
20
* notice, this list of conditions and the following disclaimer in the
21
* documentation and/or other materials provided with the distribution.
22
*
23
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
24
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
27
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
28
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
29
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
30
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
31
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
32
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33
* POSSIBILITY OF SUCH DAMAGE.
34
*/
35
36
#ifndef LIBBSP_ARM_XILINX_VERSAL_UART_H
37
#define LIBBSP_ARM_XILINX_VERSAL_UART_H
38
39
#include <
rtems/termiostypes.h
>
40
#include <
dev/serial/arm-pl011.h
>
41
#include <
dev/serial/arm-pl011-regs.h
>
42
43
#ifdef __cplusplus
44
extern
"C"
{
45
#endif
/* __cplusplus */
46
56
typedef
struct
{
57
arm_pl011_context
pl011_ctx;
58
volatile
bool
transmitting;
59
}
versal_pl011_context
;
60
61
extern
const
rtems_termios_device_handler
versal_uart_handler;
62
63
#define VERSAL_UART_DEFAULT_BAUD 115200
64
65
int
versal_uart_initialize(
rtems_termios_device_context
*base);
66
67
void
versal_uart_reset_tx_flush(
rtems_termios_device_context
*base);
68
69
#ifdef __cplusplus
70
}
71
#endif
/* __cplusplus */
72
73
#endif
/* LIBBSP_ARM_XILINX_VERSAL_UART_H */
arm-pl011-regs.h
ARM PL011 Register definitions.
arm-pl011.h
ARM PL011 Support Package.
arm_pl011_context
Definition:
arm-pl011.h:66
rtems_termios_device_context
Termios device context.
Definition:
termiosdevice.h:68
rtems_termios_device_handler
Termios device handler.
Definition:
termiosdevice.h:100
versal_pl011_context
Definition:
versal-uart.h:56
termiostypes.h
Generated by
1.9.6