/* * Copyright (c) 2023, Daniel Bertalan * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include #include namespace Kernel::RPi { struct MiniUARTRegisters; // Makes the secondary "mini UART" (UART1) available to the userspace. // See bcm2711-peripherals.pdf chapter "2.2. Mini UART". class MiniUART final : public CharacterDevice { friend class Kernel::DeviceManagement; public: static ErrorOr> create(); virtual ~MiniUART() override; // ^CharacterDevice virtual bool can_read(OpenFileDescription const&, u64) const override; virtual ErrorOr read(OpenFileDescription&, u64, UserOrKernelBuffer&, size_t) override; virtual bool can_write(OpenFileDescription const&, u64) const override; virtual ErrorOr write(OpenFileDescription&, u64, UserOrKernelBuffer const&, size_t) override; void put_char(u8); private: MiniUART(); // ^CharacterDevice virtual StringView class_name() const override { return "MiniUART"sv; } void set_baud_rate(u32); bool m_last_put_char_was_carriage_return { false }; Spinlock m_serial_lock {}; MiniUARTRegisters volatile* m_registers; }; }