Kernel: Fix TTY reading one keyevent after disabling input handling
This commit is contained in:
parent
1280528e4e
commit
d59463d11b
|
@ -160,6 +160,7 @@ namespace Kernel
|
||||||
BAN::WeakPtr<SharedFileData> m_shared_region;
|
BAN::WeakPtr<SharedFileData> m_shared_region;
|
||||||
friend class FileBackedRegion;
|
friend class FileBackedRegion;
|
||||||
friend class SharedFileData;
|
friend class SharedFileData;
|
||||||
|
friend class TTY;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,6 +28,7 @@ namespace Kernel
|
||||||
static BAN::RefPtr<TTY> current();
|
static BAN::RefPtr<TTY> current();
|
||||||
void set_as_current();
|
void set_as_current();
|
||||||
|
|
||||||
|
static void keyboard_task(void*);
|
||||||
static void initialize_devices();
|
static void initialize_devices();
|
||||||
void on_key_event(LibInput::KeyEvent);
|
void on_key_event(LibInput::KeyEvent);
|
||||||
void handle_input_byte(uint8_t);
|
void handle_input_byte(uint8_t);
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
#include <kernel/Lock/LockGuard.h>
|
#include <kernel/Lock/LockGuard.h>
|
||||||
#include <kernel/Process.h>
|
#include <kernel/Process.h>
|
||||||
#include <kernel/Terminal/TTY.h>
|
#include <kernel/Terminal/TTY.h>
|
||||||
|
#include <kernel/Timer/Timer.h>
|
||||||
#include <LibInput/KeyboardLayout.h>
|
#include <LibInput/KeyboardLayout.h>
|
||||||
|
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
|
@ -95,35 +96,47 @@ namespace Kernel
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void TTY::keyboard_task(void*)
|
||||||
|
{
|
||||||
|
BAN::RefPtr<Inode> keyboard_inode;
|
||||||
|
if (auto ret = VirtualFileSystem::get().file_from_absolute_path({ 0, 0, 0, 0 }, "/dev/keyboard"_sv, O_RDONLY); !ret.is_error())
|
||||||
|
keyboard_inode = ret.value().inode;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
dprintln("could not open keyboard device: {}", ret.error());
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
while (true)
|
||||||
|
{
|
||||||
|
while (!TTY::current()->m_tty_ctrl.receive_input)
|
||||||
|
TTY::current()->m_tty_ctrl.thread_blocker.block_indefinite();
|
||||||
|
|
||||||
|
while (TTY::current()->m_tty_ctrl.receive_input)
|
||||||
|
{
|
||||||
|
LockGuard _(keyboard_inode->m_mutex);
|
||||||
|
if (!keyboard_inode->can_read())
|
||||||
|
{
|
||||||
|
SystemTimer::get().sleep_ms(1);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
LibInput::RawKeyEvent event;
|
||||||
|
[[maybe_unused]] const size_t read = MUST(keyboard_inode->read(0, BAN::ByteSpan::from(event)));
|
||||||
|
ASSERT(read == sizeof(event));
|
||||||
|
|
||||||
|
TTY::current()->on_key_event(LibInput::KeyboardLayout::get().key_event_from_raw(event));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void TTY::initialize_devices()
|
void TTY::initialize_devices()
|
||||||
{
|
{
|
||||||
static bool initialized = false;
|
static bool initialized = false;
|
||||||
ASSERT(!initialized);
|
ASSERT(!initialized);
|
||||||
|
|
||||||
Process::create_kernel(
|
auto* thread = MUST(Thread::create_kernel(&TTY::keyboard_task, nullptr, nullptr));
|
||||||
[](void*)
|
MUST(Processor::scheduler().add_thread(thread));
|
||||||
{
|
|
||||||
auto file_or_error = VirtualFileSystem::get().file_from_absolute_path({ 0, 0, 0, 0 }, "/dev/keyboard"_sv, O_RDONLY);
|
|
||||||
if (file_or_error.is_error())
|
|
||||||
{
|
|
||||||
dprintln("no keyboard found");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
auto inode = file_or_error.value().inode;
|
|
||||||
while (true)
|
|
||||||
{
|
|
||||||
while (!TTY::current()->m_tty_ctrl.receive_input)
|
|
||||||
TTY::current()->m_tty_ctrl.thread_blocker.block_indefinite();
|
|
||||||
|
|
||||||
LibInput::RawKeyEvent event;
|
|
||||||
size_t read = MUST(inode->read(0, BAN::ByteSpan::from(event)));
|
|
||||||
ASSERT(read == sizeof(event));
|
|
||||||
|
|
||||||
TTY::current()->on_key_event(LibInput::KeyboardLayout::get().key_event_from_raw(event));
|
|
||||||
}
|
|
||||||
}, nullptr
|
|
||||||
);
|
|
||||||
|
|
||||||
initialized = true;
|
initialized = true;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue