mirror of
https://github.com/mofeng-git/One-KVM.git
synced 2025-12-13 01:30:31 +08:00
add structures for drivers (#94)
This commit is contained in:
parent
c840ea7306
commit
793edf8203
42
hid/lib/drivers/driver.h
Normal file
42
hid/lib/drivers/driver.h
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
# #
|
||||||
|
# KVMD - The main PiKVM daemon. #
|
||||||
|
# #
|
||||||
|
# Copyright (C) 2018-2022 Maxim Devaev <mdevaev@gmail.com> #
|
||||||
|
# #
|
||||||
|
# This program is free software: you can redistribute it and/or modify #
|
||||||
|
# it under the terms of the GNU General Public License as published by #
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or #
|
||||||
|
# (at your option) any later version. #
|
||||||
|
# #
|
||||||
|
# This program is distributed in the hope that it will be useful, #
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of #
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
|
||||||
|
# GNU General Public License for more details. #
|
||||||
|
# #
|
||||||
|
# You should have received a copy of the GNU General Public License #
|
||||||
|
# along with this program. If not, see <https://www.gnu.org/licenses/>. #
|
||||||
|
# #
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
namespace DRIVERS {
|
||||||
|
|
||||||
|
enum type {
|
||||||
|
USB_MOUSE_ABSOLUTE,
|
||||||
|
USB_MOUSE_RELATIVE,
|
||||||
|
USB_MOUSE_ABSOLUTE_WIN98,
|
||||||
|
};
|
||||||
|
|
||||||
|
class Driver {
|
||||||
|
public:
|
||||||
|
Driver(type _type) : _type(_type) {}
|
||||||
|
uint8_t getType() { return _type; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
type _type;
|
||||||
|
};
|
||||||
|
}
|
||||||
@ -21,9 +21,14 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
#include "driver.h"
|
||||||
|
|
||||||
typedef struct {
|
namespace DRIVERS {
|
||||||
bool caps;
|
|
||||||
bool scroll;
|
typedef struct {
|
||||||
bool num;
|
bool caps;
|
||||||
} KeyboardLedsState;
|
bool scroll;
|
||||||
|
bool num;
|
||||||
|
} KeyboardLedsState;
|
||||||
|
}
|
||||||
|
|||||||
32
hid/lib/drivers/mouse.h
Normal file
32
hid/lib/drivers/mouse.h
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
# #
|
||||||
|
# KVMD - The main PiKVM daemon. #
|
||||||
|
# #
|
||||||
|
# Copyright (C) 2018-2022 Maxim Devaev <mdevaev@gmail.com> #
|
||||||
|
# #
|
||||||
|
# This program is free software: you can redistribute it and/or modify #
|
||||||
|
# it under the terms of the GNU General Public License as published by #
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or #
|
||||||
|
# (at your option) any later version. #
|
||||||
|
# #
|
||||||
|
# This program is distributed in the hope that it will be useful, #
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of #
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
|
||||||
|
# GNU General Public License for more details. #
|
||||||
|
# #
|
||||||
|
# You should have received a copy of the GNU General Public License #
|
||||||
|
# along with this program. If not, see <https://www.gnu.org/licenses/>. #
|
||||||
|
# #
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
#include "driver.h"
|
||||||
|
|
||||||
|
namespace DRIVERS {
|
||||||
|
|
||||||
|
class Mouse : public Driver {
|
||||||
|
using Driver::Driver;
|
||||||
|
};
|
||||||
|
}
|
||||||
@ -125,7 +125,11 @@ static void _initOutputs() {
|
|||||||
switch (mouse) {
|
switch (mouse) {
|
||||||
# ifdef HID_WITH_USB
|
# ifdef HID_WITH_USB
|
||||||
case PROTO::OUTPUTS1::MOUSE::USB_ABS:
|
case PROTO::OUTPUTS1::MOUSE::USB_ABS:
|
||||||
case PROTO::OUTPUTS1::MOUSE::USB_WIN98: _usb_mouse_abs = new UsbMouseAbsolute(); break;
|
_usb_mouse_abs = new UsbMouseAbsolute(DRIVERS::USB_MOUSE_ABSOLUTE);
|
||||||
|
break;
|
||||||
|
case PROTO::OUTPUTS1::MOUSE::USB_WIN98:
|
||||||
|
_usb_mouse_abs = new UsbMouseAbsolute(DRIVERS::USB_MOUSE_ABSOLUTE_WIN98);
|
||||||
|
break;
|
||||||
case PROTO::OUTPUTS1::MOUSE::USB_REL: _usb_mouse_rel = new UsbMouseRelative(); break;
|
case PROTO::OUTPUTS1::MOUSE::USB_REL: _usb_mouse_rel = new UsbMouseRelative(); break;
|
||||||
# endif
|
# endif
|
||||||
}
|
}
|
||||||
@ -147,7 +151,7 @@ static void _initOutputs() {
|
|||||||
# ifdef HID_WITH_USB_WIN98
|
# ifdef HID_WITH_USB_WIN98
|
||||||
case PROTO::OUTPUTS1::MOUSE::USB_WIN98:
|
case PROTO::OUTPUTS1::MOUSE::USB_WIN98:
|
||||||
# endif
|
# endif
|
||||||
_usb_mouse_abs->begin(mouse == PROTO::OUTPUTS1::MOUSE::USB_WIN98);
|
_usb_mouse_abs->begin();
|
||||||
break;
|
break;
|
||||||
case PROTO::OUTPUTS1::MOUSE::USB_REL: _usb_mouse_rel->begin(); break;
|
case PROTO::OUTPUTS1::MOUSE::USB_REL: _usb_mouse_rel->begin(); break;
|
||||||
# endif
|
# endif
|
||||||
@ -299,8 +303,8 @@ static void _sendResponse(uint8_t code) {
|
|||||||
response[2] |= PROTO::OUTPUTS1::KEYBOARD::PS2;
|
response[2] |= PROTO::OUTPUTS1::KEYBOARD::PS2;
|
||||||
}
|
}
|
||||||
if (_usb_mouse_abs) {
|
if (_usb_mouse_abs) {
|
||||||
response[1] |= (_usb_mouse_abs->isOffline() ? PROTO::PONG::MOUSE_OFFLINE : 0);
|
response[1] |= _usb_mouse_abs->isOffline() ? PROTO::PONG::MOUSE_OFFLINE : 0;
|
||||||
if (_usb_mouse_abs->isWin98FixEnabled()) {
|
if (_usb_mouse_abs->getType() == DRIVERS::USB_MOUSE_ABSOLUTE_WIN98) {
|
||||||
response[2] |= PROTO::OUTPUTS1::MOUSE::USB_WIN98;
|
response[2] |= PROTO::OUTPUTS1::MOUSE::USB_WIN98;
|
||||||
} else {
|
} else {
|
||||||
response[2] |= PROTO::OUTPUTS1::MOUSE::USB_ABS;
|
response[2] |= PROTO::OUTPUTS1::MOUSE::USB_ABS;
|
||||||
|
|||||||
@ -26,12 +26,14 @@
|
|||||||
#include <HID-Project.h>
|
#include <HID-Project.h>
|
||||||
|
|
||||||
#include "keyboard.h"
|
#include "keyboard.h"
|
||||||
|
#include "mouse.h"
|
||||||
#include "../tools.h"
|
#include "../tools.h"
|
||||||
#ifdef AUM
|
#ifdef AUM
|
||||||
# include "../aum.h"
|
# include "../aum.h"
|
||||||
#endif
|
#endif
|
||||||
#include "keymap.h"
|
#include "keymap.h"
|
||||||
|
|
||||||
|
using namespace DRIVERS;
|
||||||
|
|
||||||
// -----------------------------------------------------------------------------
|
// -----------------------------------------------------------------------------
|
||||||
#ifdef HID_USB_CHECK_ENDPOINT
|
#ifdef HID_USB_CHECK_ENDPOINT
|
||||||
@ -147,17 +149,13 @@ class UsbKeyboard {
|
|||||||
if (down_select) _sendButton(MOUSE_NEXT, down_state); \
|
if (down_select) _sendButton(MOUSE_NEXT, down_state); \
|
||||||
}
|
}
|
||||||
|
|
||||||
class UsbMouseAbsolute {
|
class UsbMouseAbsolute : public DRIVERS::Mouse {
|
||||||
public:
|
public:
|
||||||
UsbMouseAbsolute() {}
|
UsbMouseAbsolute(DRIVERS::type _type) : Mouse(_type) {}
|
||||||
|
|
||||||
void begin(bool win98_fix) {
|
void begin() {
|
||||||
_mouse.begin();
|
_mouse.begin();
|
||||||
_mouse.setWin98FixEnabled(win98_fix);
|
_mouse.setWin98FixEnabled(getType() == DRIVERS::USB_MOUSE_ABSOLUTE_WIN98);
|
||||||
}
|
|
||||||
|
|
||||||
bool isWin98FixEnabled() {
|
|
||||||
return _mouse.isWin98FixEnabled();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void clear() {
|
void clear() {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user