L4Re Operating System Framework
Interface and Usage Documentation
Loading...
Searching...
No Matches
uart_s3c2410.h
1/*
2 * Copyright (C) 2009-2012 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_s3c : public Uart
15 {
16 protected:
17 enum Uart_type
18 {
19 Type_24xx, Type_64xx, Type_s5pv210,
20 };
21
22 Uart_type type() const { return _type; }
23
24 public:
25 explicit Uart_s3c(Uart_type type) : _type(type) {}
26 explicit Uart_s3c(Uart_type type, unsigned /*base_rate*/) : _type(type) {}
27 bool startup(Io_register_block const *) override;
28 void shutdown() override;
29 bool change_mode(Transfer_mode m, Baud_rate r) override;
30 int get_char(bool blocking = true) const override;
31 int char_avail() const override;
32 int tx_avail() const;
33 void wait_tx_done() const;
34 inline void out_char(char c) const;
35 int write(char const *s, unsigned long count,
36 bool blocking = true) const override;
37 void fifo_reset();
38
39 protected:
40 virtual void ack_rx_irq() const = 0;
41 virtual void wait_for_empty_tx_fifo() const = 0;
42 virtual unsigned is_rx_fifo_non_empty() const = 0;
43 virtual unsigned is_tx_fifo_not_full() const = 0;
44
45 private:
46 Uart_type _type;
47 };
48
49 class Uart_s3c2410 : public Uart_s3c
50 {
51 public:
52 Uart_s3c2410() : Uart_s3c(Type_24xx) {}
53 explicit Uart_s3c2410(unsigned base_rate) : Uart_s3c(Type_24xx, base_rate) {}
54
55 protected:
56 void ack_rx_irq() const override {}
57 void wait_for_empty_tx_fifo() const override;
58 unsigned is_rx_fifo_non_empty() const override;
59 unsigned is_tx_fifo_not_full() const override;
60
61 void auto_flow_control(bool on);
62 };
63
64 class Uart_s3c64xx : public Uart_s3c
65 {
66 public:
67 Uart_s3c64xx() : Uart_s3c(Type_64xx) {}
68 explicit Uart_s3c64xx(unsigned base_rate) : Uart_s3c(Type_64xx, base_rate) {}
69
70 protected:
71 void ack_rx_irq() const override;
72 void wait_for_empty_tx_fifo() const override;
73 unsigned is_rx_fifo_non_empty() const override;
74 unsigned is_tx_fifo_not_full() const override;
75 };
76
77 class Uart_s5pv210 : public Uart_s3c
78 {
79 public:
80 Uart_s5pv210() : Uart_s3c(Type_s5pv210) {}
81 explicit Uart_s5pv210(unsigned base_rate) : Uart_s3c(Type_s5pv210, base_rate) {}
82
83 protected:
84 void ack_rx_irq() const override;
85 void wait_for_empty_tx_fifo() const override;
86 unsigned is_rx_fifo_non_empty() const override;
87 unsigned is_tx_fifo_not_full() const override;
88 };
89};
L4 low-level kernel interface.