mirror of
https://github.com/RGBCube/serenity
synced 2025-05-20 16:35:07 +00:00

kprintf should not really care about the hardware-specific details of each UART or serial port out there, so instead of using x86 specific instructions, let's ensure that we will compile only the relevant code for debug output for a targeted-specific platform.
48 lines
1.1 KiB
C++
48 lines
1.1 KiB
C++
/*
|
|
* Copyright (c) 2022, Liav A. <liavalb@hotmail.co.il>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <Kernel/Arch/DebugOutput.h>
|
|
#include <Kernel/Arch/x86/IO.h>
|
|
#include <Kernel/Arch/x86/common/BochsDebugOutput.h>
|
|
|
|
namespace Kernel {
|
|
|
|
static constexpr u16 serial_com1_io_port = 0x3F8;
|
|
|
|
void bochs_debug_output(char ch)
|
|
{
|
|
IO::out8(IO::BOCHS_DEBUG_PORT, ch);
|
|
}
|
|
|
|
void debug_output(char ch)
|
|
{
|
|
static bool serial_ready = false;
|
|
static bool was_cr = false;
|
|
|
|
if (!serial_ready) {
|
|
IO::out8(serial_com1_io_port + 1, 0x00);
|
|
IO::out8(serial_com1_io_port + 3, 0x80);
|
|
IO::out8(serial_com1_io_port + 0, 0x02);
|
|
IO::out8(serial_com1_io_port + 1, 0x00);
|
|
IO::out8(serial_com1_io_port + 3, 0x03);
|
|
IO::out8(serial_com1_io_port + 2, 0xC7);
|
|
IO::out8(serial_com1_io_port + 4, 0x0B);
|
|
|
|
serial_ready = true;
|
|
}
|
|
|
|
while ((IO::in8(serial_com1_io_port + 5) & 0x20) == 0)
|
|
;
|
|
|
|
if (ch == '\n' && !was_cr)
|
|
IO::out8(serial_com1_io_port, '\r');
|
|
|
|
IO::out8(serial_com1_io_port, ch);
|
|
|
|
was_cr = ch == '\r';
|
|
}
|
|
|
|
}
|