add interface for storage (#99)

This commit is contained in:
tomaszduda23
2022-07-11 11:59:56 +09:00
committed by GitHub
parent 89aff795fd
commit dc1bc121c8
6 changed files with 95 additions and 6 deletions

View 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);
}
};
}

View File

@@ -23,6 +23,7 @@
#include "usb/hid.h"
#include "ps2/hid.h"
#include "factory.h"
#include "eeprom.h"
namespace DRIVERS {
@@ -56,4 +57,16 @@ namespace DRIVERS {
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);
}
}
}

View File

@@ -33,6 +33,7 @@ namespace DRIVERS {
USB_MOUSE_ABSOLUTE_WIN98,
USB_KEYBOARD,
PS2_KEYBOARD,
NON_VOLATILE_STORAGE,
};
class Driver {

View File

@@ -23,11 +23,13 @@
#include "keyboard.h"
#include "mouse.h"
#include "storage.h"
namespace DRIVERS {
struct Factory {
static Keyboard *makeKeyboard(type _type);
static Mouse *makeMouse(type _type);
static Storage* makeStorage(type _type);
};
}

34
hid/lib/drivers/storage.h Normal file
View 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) {}
};
}

View File

@@ -32,9 +32,6 @@
#include <Arduino.h>
#ifdef HID_DYNAMIC
# include <avr/eeprom.h>
#endif
#include "tools.h"
#include "proto.h"
@@ -53,10 +50,11 @@ static DRIVERS::Mouse * _mouse = nullptr;
#ifdef HID_DYNAMIC
static bool _reset_required = false;
static DRIVERS::Storage *_storage = nullptr;
static int _readOutputs(void) {
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])) {
return -1;
}
@@ -75,13 +73,14 @@ static void _writeOutputs(uint8_t mask, uint8_t outputs, bool force) {
data[0] = PROTO::MAGIC;
data[1] = (old & ~mask) | outputs;
PROTO::split16(PROTO::crc16(data, 6), &data[6], &data[7]);
eeprom_update_block(data, 0, 8);
_storage->read_block(data, 0, 8);
}
#endif
static void _initOutputs() {
int outputs;
# ifdef HID_DYNAMIC
_storage = DRIVERS::Factory::makeStorage(DRIVERS::NON_VOLATILE_STORAGE);
outputs = _readOutputs();
if (outputs < 0) {
# endif