2019-01-11 02:28:53 +01:00
|
|
|
#pragma once
|
|
|
|
|
2019-01-23 05:13:17 +01:00
|
|
|
#include <Kernel/CharacterDevice.h>
|
2019-01-11 02:28:53 +01:00
|
|
|
#include "IRQHandler.h"
|
|
|
|
|
|
|
|
class PS2MouseDevice final : public IRQHandler, public CharacterDevice {
|
|
|
|
public:
|
|
|
|
PS2MouseDevice();
|
|
|
|
virtual ~PS2MouseDevice() override;
|
|
|
|
|
2019-01-11 03:52:09 +01:00
|
|
|
static PS2MouseDevice& the();
|
|
|
|
|
2019-01-12 05:20:56 +01:00
|
|
|
// ^CharacterDevice
|
2019-01-16 00:10:13 +01:00
|
|
|
virtual bool can_read(Process&) const override;
|
2019-01-16 00:20:38 +01:00
|
|
|
virtual ssize_t read(Process&, byte* buffer, size_t) override;
|
|
|
|
virtual ssize_t write(Process&, const byte* buffer, size_t) override;
|
2019-01-15 09:17:22 +01:00
|
|
|
virtual bool can_write(Process&) const override { return true; }
|
2019-01-11 02:28:53 +01:00
|
|
|
|
2019-01-12 05:20:56 +01:00
|
|
|
private:
|
|
|
|
// ^IRQHandler
|
2019-01-11 02:28:53 +01:00
|
|
|
virtual void handle_irq() override;
|
|
|
|
|
2019-01-21 02:33:01 +01:00
|
|
|
// ^CharacterDevice
|
|
|
|
virtual const char* class_name() const override { return "PS2MouseDevice"; }
|
|
|
|
|
2019-01-11 02:28:53 +01:00
|
|
|
void initialize();
|
|
|
|
void prepare_for_input();
|
|
|
|
void prepare_for_output();
|
|
|
|
void mouse_write(byte);
|
|
|
|
byte mouse_read();
|
|
|
|
void wait_then_write(byte port, byte data);
|
|
|
|
byte wait_then_read(byte port);
|
|
|
|
|
2019-01-16 01:52:39 +01:00
|
|
|
CircularQueue<byte, 600> m_queue;
|
2019-01-11 02:28:53 +01:00
|
|
|
byte m_data_state { 0 };
|
|
|
|
signed_byte m_data[3];
|
|
|
|
};
|