mirror of
https://github.com/mofeng-git/One-KVM.git
synced 2026-01-29 00:51:53 +08:00
add interface for storage (#99)
This commit is contained in:
40
hid/lib/drivers-avr/eeprom.h
Normal file
40
hid/lib/drivers-avr/eeprom.h
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
# #
|
||||||
|
# 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/>. #
|
||||||
|
# #
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
#include "storage.h"
|
||||||
|
#ifdef HID_DYNAMIC
|
||||||
|
#include <avr/eeprom.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
namespace DRIVERS {
|
||||||
|
|
||||||
|
struct Eeprom : public Storage {
|
||||||
|
using Storage::Storage;
|
||||||
|
|
||||||
|
void read_block (void *_dst, const void *_src, size_t _n) override {
|
||||||
|
eeprom_read_block(_dst, _src, _n);
|
||||||
|
}
|
||||||
|
|
||||||
|
void update_block (const void *_src, void *_dst, size_t _n) override {
|
||||||
|
eeprom_update_block(_src, _dst, _n);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -23,6 +23,7 @@
|
|||||||
#include "usb/hid.h"
|
#include "usb/hid.h"
|
||||||
#include "ps2/hid.h"
|
#include "ps2/hid.h"
|
||||||
#include "factory.h"
|
#include "factory.h"
|
||||||
|
#include "eeprom.h"
|
||||||
|
|
||||||
|
|
||||||
namespace DRIVERS {
|
namespace DRIVERS {
|
||||||
@@ -56,4 +57,16 @@ namespace DRIVERS {
|
|||||||
return new Mouse(DRIVERS::DUMMY);
|
return new Mouse(DRIVERS::DUMMY);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Storage* Factory::makeStorage(type _type) {
|
||||||
|
switch (_type)
|
||||||
|
{
|
||||||
|
# ifdef HID_DYNAMIC
|
||||||
|
case NON_VOLATILE_STORAGE:
|
||||||
|
return new Eeprom(DRIVERS::NON_VOLATILE_STORAGE);
|
||||||
|
# endif
|
||||||
|
default:
|
||||||
|
return new Storage(DRIVERS::DUMMY);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -33,6 +33,7 @@ namespace DRIVERS {
|
|||||||
USB_MOUSE_ABSOLUTE_WIN98,
|
USB_MOUSE_ABSOLUTE_WIN98,
|
||||||
USB_KEYBOARD,
|
USB_KEYBOARD,
|
||||||
PS2_KEYBOARD,
|
PS2_KEYBOARD,
|
||||||
|
NON_VOLATILE_STORAGE,
|
||||||
};
|
};
|
||||||
|
|
||||||
class Driver {
|
class Driver {
|
||||||
|
|||||||
@@ -23,11 +23,13 @@
|
|||||||
|
|
||||||
#include "keyboard.h"
|
#include "keyboard.h"
|
||||||
#include "mouse.h"
|
#include "mouse.h"
|
||||||
|
#include "storage.h"
|
||||||
|
|
||||||
|
|
||||||
namespace DRIVERS {
|
namespace DRIVERS {
|
||||||
struct Factory {
|
struct Factory {
|
||||||
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);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
34
hid/lib/drivers/storage.h
Normal file
34
hid/lib/drivers/storage.h
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
# #
|
||||||
|
# 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 Storage : public Driver {
|
||||||
|
using Driver::Driver;
|
||||||
|
virtual void read_block (void *_dst, const void *_src, size_t _n) {}
|
||||||
|
virtual void update_block (const void *_src, void *_dst, size_t _n) {}
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -32,9 +32,6 @@
|
|||||||
|
|
||||||
|
|
||||||
#include <Arduino.h>
|
#include <Arduino.h>
|
||||||
#ifdef HID_DYNAMIC
|
|
||||||
# include <avr/eeprom.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "tools.h"
|
#include "tools.h"
|
||||||
#include "proto.h"
|
#include "proto.h"
|
||||||
@@ -49,14 +46,15 @@
|
|||||||
|
|
||||||
// -----------------------------------------------------------------------------
|
// -----------------------------------------------------------------------------
|
||||||
static DRIVERS::Keyboard *_kbd = nullptr;
|
static DRIVERS::Keyboard *_kbd = nullptr;
|
||||||
static DRIVERS::Mouse * _mouse = nullptr;
|
static DRIVERS::Mouse *_mouse = nullptr;
|
||||||
|
|
||||||
#ifdef HID_DYNAMIC
|
#ifdef HID_DYNAMIC
|
||||||
static bool _reset_required = false;
|
static bool _reset_required = false;
|
||||||
|
static DRIVERS::Storage *_storage = nullptr;
|
||||||
|
|
||||||
static int _readOutputs(void) {
|
static int _readOutputs(void) {
|
||||||
uint8_t data[8];
|
uint8_t data[8];
|
||||||
eeprom_read_block(data, 0, 8);
|
_storage->read_block(data, 0, 8);
|
||||||
if (data[0] != PROTO::MAGIC || PROTO::crc16(data, 6) != PROTO::merge8(data[6], data[7])) {
|
if (data[0] != PROTO::MAGIC || PROTO::crc16(data, 6) != PROTO::merge8(data[6], data[7])) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@@ -75,13 +73,14 @@ static void _writeOutputs(uint8_t mask, uint8_t outputs, bool force) {
|
|||||||
data[0] = PROTO::MAGIC;
|
data[0] = PROTO::MAGIC;
|
||||||
data[1] = (old & ~mask) | outputs;
|
data[1] = (old & ~mask) | outputs;
|
||||||
PROTO::split16(PROTO::crc16(data, 6), &data[6], &data[7]);
|
PROTO::split16(PROTO::crc16(data, 6), &data[6], &data[7]);
|
||||||
eeprom_update_block(data, 0, 8);
|
_storage->read_block(data, 0, 8);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void _initOutputs() {
|
static void _initOutputs() {
|
||||||
int outputs;
|
int outputs;
|
||||||
# ifdef HID_DYNAMIC
|
# ifdef HID_DYNAMIC
|
||||||
|
_storage = DRIVERS::Factory::makeStorage(DRIVERS::NON_VOLATILE_STORAGE);
|
||||||
outputs = _readOutputs();
|
outputs = _readOutputs();
|
||||||
if (outputs < 0) {
|
if (outputs < 0) {
|
||||||
# endif
|
# endif
|
||||||
|
|||||||
Reference in New Issue
Block a user