mirror of
https://github.com/mofeng-git/One-KVM.git
synced 2025-12-12 01:00:29 +08:00
add SW reset (#107)
This commit is contained in:
parent
ce43938d28
commit
615863a848
@ -73,4 +73,11 @@ namespace DRIVERS {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Board* Factory::makeBoard(type _type) {
|
||||||
|
switch (_type) {
|
||||||
|
default:
|
||||||
|
return new Board(DRIVERS::DUMMY);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
38
hid/lib/drivers-stm32/board-stm32.h
Normal file
38
hid/lib/drivers-stm32/board-stm32.h
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
# #
|
||||||
|
# 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 "board.h"
|
||||||
|
|
||||||
|
|
||||||
|
namespace DRIVERS {
|
||||||
|
class BoardStm32 : public Board {
|
||||||
|
public:
|
||||||
|
BoardStm32() : Board(BOARD){
|
||||||
|
}
|
||||||
|
|
||||||
|
void reset() override {
|
||||||
|
nvic_sys_reset();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
@ -26,6 +26,7 @@
|
|||||||
#include "usb/mouse-absolute-stm32.h"
|
#include "usb/mouse-absolute-stm32.h"
|
||||||
#include "usb/mouse-relative-stm32.h"
|
#include "usb/mouse-relative-stm32.h"
|
||||||
#include "backup-register.h"
|
#include "backup-register.h"
|
||||||
|
#include "board-stm32.h"
|
||||||
|
|
||||||
#ifndef __STM32F1__
|
#ifndef __STM32F1__
|
||||||
# error "Only STM32F1 is supported"
|
# error "Only STM32F1 is supported"
|
||||||
@ -72,4 +73,14 @@ namespace DRIVERS {
|
|||||||
return new Storage(DRIVERS::DUMMY);
|
return new Storage(DRIVERS::DUMMY);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Board* Factory::makeBoard(type _type) {
|
||||||
|
switch (_type) {
|
||||||
|
case BOARD:
|
||||||
|
return new BoardStm32();
|
||||||
|
default:
|
||||||
|
return new Board(DRIVERS::DUMMY);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
32
hid/lib/drivers/board.h
Normal file
32
hid/lib/drivers/board.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 "driver.h"
|
||||||
|
|
||||||
|
namespace DRIVERS {
|
||||||
|
struct Board : public Driver {
|
||||||
|
using Driver::Driver;
|
||||||
|
virtual void reset() {}
|
||||||
|
};
|
||||||
|
}
|
||||||
@ -34,6 +34,7 @@ namespace DRIVERS {
|
|||||||
USB_KEYBOARD,
|
USB_KEYBOARD,
|
||||||
PS2_KEYBOARD,
|
PS2_KEYBOARD,
|
||||||
NON_VOLATILE_STORAGE,
|
NON_VOLATILE_STORAGE,
|
||||||
|
BOARD,
|
||||||
};
|
};
|
||||||
|
|
||||||
class Driver {
|
class Driver {
|
||||||
|
|||||||
@ -24,6 +24,7 @@
|
|||||||
#include "keyboard.h"
|
#include "keyboard.h"
|
||||||
#include "mouse.h"
|
#include "mouse.h"
|
||||||
#include "storage.h"
|
#include "storage.h"
|
||||||
|
#include "board.h"
|
||||||
|
|
||||||
|
|
||||||
namespace DRIVERS {
|
namespace DRIVERS {
|
||||||
@ -31,5 +32,6 @@ namespace DRIVERS {
|
|||||||
static Keyboard *makeKeyboard(type _type);
|
static Keyboard *makeKeyboard(type _type);
|
||||||
static Mouse *makeMouse(type _type);
|
static Mouse *makeMouse(type _type);
|
||||||
static Storage* makeStorage(type _type);
|
static Storage* makeStorage(type _type);
|
||||||
|
static Board* makeBoard(type _type);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@ -41,27 +41,35 @@
|
|||||||
#ifdef AUM
|
#ifdef AUM
|
||||||
# include "aum.h"
|
# include "aum.h"
|
||||||
#endif
|
#endif
|
||||||
|
#include "board.h"
|
||||||
#include "outputs.h"
|
#include "outputs.h"
|
||||||
|
|
||||||
|
static DRIVERS::Board* _board;
|
||||||
static Outputs _out;
|
static Outputs _out;
|
||||||
#ifdef HID_DYNAMIC
|
#ifdef HID_DYNAMIC
|
||||||
static bool _reset_required = false;
|
static bool _reset_required = false;
|
||||||
|
static unsigned long _reset_timestamp;
|
||||||
|
#define RESET_TIMEOUT (500000)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
// -----------------------------------------------------------------------------
|
// -----------------------------------------------------------------------------
|
||||||
|
static void _resetRequest() {
|
||||||
|
_reset_required = true;
|
||||||
|
_reset_timestamp = micros();
|
||||||
|
}
|
||||||
|
|
||||||
static void _cmdSetKeyboard(const uint8_t *data) { // 1 bytes
|
static void _cmdSetKeyboard(const uint8_t *data) { // 1 bytes
|
||||||
# ifdef HID_DYNAMIC
|
# ifdef HID_DYNAMIC
|
||||||
_out.writeOutputs(PROTO::OUTPUTS1::KEYBOARD::MASK, data[0], false);
|
_out.writeOutputs(PROTO::OUTPUTS1::KEYBOARD::MASK, data[0], false);
|
||||||
_reset_required = true;
|
_resetRequest();
|
||||||
# endif
|
# endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static void _cmdSetMouse(const uint8_t *data) { // 1 bytes
|
static void _cmdSetMouse(const uint8_t *data) { // 1 bytes
|
||||||
# ifdef HID_DYNAMIC
|
# ifdef HID_DYNAMIC
|
||||||
_out.writeOutputs(PROTO::OUTPUTS1::MOUSE::MASK, data[0], false);
|
_out.writeOutputs(PROTO::OUTPUTS1::MOUSE::MASK, data[0], false);
|
||||||
_reset_required = true;
|
_resetRequest();
|
||||||
# endif
|
# endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -150,6 +158,9 @@ static void _sendResponse(uint8_t code) {
|
|||||||
# ifdef HID_DYNAMIC
|
# ifdef HID_DYNAMIC
|
||||||
if (_reset_required) {
|
if (_reset_required) {
|
||||||
response[1] |= PROTO::PONG::RESET_REQUIRED;
|
response[1] |= PROTO::PONG::RESET_REQUIRED;
|
||||||
|
if (is_micros_timed_out(_reset_timestamp, RESET_TIMEOUT)) {
|
||||||
|
_board->reset();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
response[2] = PROTO::OUTPUTS1::DYNAMIC;
|
response[2] = PROTO::OUTPUTS1::DYNAMIC;
|
||||||
# endif
|
# endif
|
||||||
@ -221,6 +232,7 @@ void setup() {
|
|||||||
# elif defined(CMD_SPI)
|
# elif defined(CMD_SPI)
|
||||||
spiBegin();
|
spiBegin();
|
||||||
# endif
|
# endif
|
||||||
|
_board = DRIVERS::Factory::makeBoard(DRIVERS::BOARD);
|
||||||
}
|
}
|
||||||
|
|
||||||
void loop() {
|
void loop() {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user