L4Re Operating System Framework
Interface and Usage Documentation
Loading...
Searching...
No Matches
uart_imx.h
1/*
2 * Copyright (C) 2008-2009 Technische Universität Dresden.
3 * Copyright (C) 2023-2024 Kernkonzept GmbH.
4 * Author(s): Adam Lackorzynski <adam@os.inf.tu-dresden.de>
5 *
6 * License: see LICENSE.spdx (in this directory or the directories above)
7 */
8#pragma once
9
10#include "uart_base.h"
11
12namespace L4
13{
14 class Uart_imx : public Uart
15 {
16 public:
17 enum platform_type
18 {
19 Type_imx21,
20 Type_imx35,
21 Type_imx51,
22 Type_imx6,
23 Type_imx7,
24 Type_imx8,
25 };
26 explicit Uart_imx(enum platform_type type) : _type(type) {}
27 explicit Uart_imx(enum platform_type type, unsigned /*base_rate*/)
28 : _type(type) {}
29 bool startup(Io_register_block const *) override;
30 void shutdown() override;
31 bool enable_rx_irq(bool enable = true) override;
32 bool change_mode(Transfer_mode m, Baud_rate r) override;
33 int get_char(bool blocking = true) const override;
34 int char_avail() const override;
35 int tx_avail() const;
36 void wait_tx_done() const;
37 inline void out_char(char c) const;
38 int write(char const *s, unsigned long count,
39 bool blocking = true) const override;
40
41 private:
42 enum platform_type _type;
43 };
44
45 class Uart_imx21 : public Uart_imx
46 {
47 public:
48 Uart_imx21() : Uart_imx(Type_imx21) {}
49 explicit Uart_imx21(unsigned base_rate) : Uart_imx(Type_imx21, base_rate) {}
50 };
51
52 class Uart_imx35 : public Uart_imx
53 {
54 public:
55 Uart_imx35() : Uart_imx(Type_imx35) {}
56 explicit Uart_imx35(unsigned base_rate) : Uart_imx(Type_imx35, base_rate) {}
57 };
58
59 class Uart_imx51 : public Uart_imx
60 {
61 public:
62 Uart_imx51() : Uart_imx(Type_imx51) {}
63 explicit Uart_imx51(unsigned base_rate) : Uart_imx(Type_imx51, base_rate) {}
64 };
65
66 class Uart_imx6 : public Uart_imx
67 {
68 public:
69 Uart_imx6() : Uart_imx(Type_imx6) {}
70 explicit Uart_imx6(unsigned base_rate) : Uart_imx(Type_imx6, base_rate) {}
71
72 void irq_ack() override;
73 };
74
75 class Uart_imx7 : public Uart_imx
76 {
77 public:
78 Uart_imx7() : Uart_imx(Type_imx7) {}
79 explicit Uart_imx7(unsigned base_rate) : Uart_imx(Type_imx7, base_rate) {}
80 };
81
82 class Uart_imx8 : public Uart_imx
83 {
84 public:
85 Uart_imx8() : Uart_imx(Type_imx8) {}
86 explicit Uart_imx8(unsigned base_rate) : Uart_imx(Type_imx8, base_rate) {}
87 };
88};
L4 low-level kernel interface.