summaryrefslogtreecommitdiff
path: root/Kernel/Arch/x86/ISABus/HID/PS2KeyboardDevice.h
diff options
context:
space:
mode:
Diffstat (limited to 'Kernel/Arch/x86/ISABus/HID/PS2KeyboardDevice.h')
-rw-r--r--Kernel/Arch/x86/ISABus/HID/PS2KeyboardDevice.h49
1 files changed, 49 insertions, 0 deletions
diff --git a/Kernel/Arch/x86/ISABus/HID/PS2KeyboardDevice.h b/Kernel/Arch/x86/ISABus/HID/PS2KeyboardDevice.h
new file mode 100644
index 0000000000..d3c63984ea
--- /dev/null
+++ b/Kernel/Arch/x86/ISABus/HID/PS2KeyboardDevice.h
@@ -0,0 +1,49 @@
+/*
+ * Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
+ *
+ * SPDX-License-Identifier: BSD-2-Clause
+ */
+
+#pragma once
+
+#include <AK/CircularQueue.h>
+#include <AK/DoublyLinkedList.h>
+#include <AK/Types.h>
+#include <Kernel/API/KeyCode.h>
+#include <Kernel/Arch/x86/ISABus/I8042Controller.h>
+#include <Kernel/Devices/HID/KeyboardDevice.h>
+#include <Kernel/Interrupts/IRQHandler.h>
+#include <Kernel/Random.h>
+
+namespace Kernel {
+
+class PS2KeyboardDevice final : public IRQHandler
+ , public KeyboardDevice
+ , public I8042Device {
+ friend class DeviceManagement;
+
+public:
+ static ErrorOr<NonnullLockRefPtr<PS2KeyboardDevice>> try_to_initialize(I8042Controller const&);
+ virtual ~PS2KeyboardDevice() override;
+ ErrorOr<void> initialize();
+
+ virtual StringView purpose() const override { return class_name(); }
+
+ // ^I8042Device
+ virtual void irq_handle_byte_read(u8 byte) override;
+ virtual void enable_interrupts() override
+ {
+ enable_irq();
+ }
+
+private:
+ explicit PS2KeyboardDevice(I8042Controller const&);
+
+ // ^IRQHandler
+ virtual bool handle_irq(RegisterState const&) override;
+
+ // ^CharacterDevice
+ virtual StringView class_name() const override { return "KeyboardDevice"sv; }
+};
+
+}