1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-16 10:52:45 +01:00
RIOT/sys/usb/usbus/hid/hid_io.c

100 lines
2.3 KiB
C
Raw Normal View History

2020-06-01 18:01:32 +02:00
/*
* Copyright (C) 2021 Nils Ollrogge
2020-06-01 18:01:32 +02:00
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @ingroup usbus_hid_io
2020-06-01 18:01:32 +02:00
* @{
* @file
*
* @author Nils Ollrogge <nils.ollrogge@fu-berlin.de>
2020-06-01 18:01:32 +02:00
* @}
*/
#define USB_H_USER_IS_RIOT_INTERNAL
#include <string.h>
#include "isrpipe.h"
#include "isrpipe/read_timeout.h"
#include "usb/usbus.h"
#include "usb/usbus/hid.h"
#include "usb/usbus/hid_io.h"
2020-06-01 18:01:32 +02:00
#define ENABLE_DEBUG 0
2020-06-01 18:01:32 +02:00
#include "debug.h"
static usbus_hid_device_t hid;
static uint8_t _hid_rx_buf_mem[CONFIG_USBUS_HID_INTERRUPT_EP_SIZE];
static isrpipe_t _hid_stdio_isrpipe = ISRPIPE_INIT(_hid_rx_buf_mem);
static usb_hid_io_cb_t _rx_cb;
static void *_rx_cb_arg;
2020-06-01 18:01:32 +02:00
int usb_hid_io_read(void *buffer, size_t len)
2020-06-01 18:01:32 +02:00
{
assert(buffer);
return isrpipe_read(&_hid_stdio_isrpipe, buffer, len);
2020-06-01 18:01:32 +02:00
}
int usb_hid_io_read_timeout(void *buffer, size_t len, uint32_t timeout)
2020-06-01 18:01:32 +02:00
{
assert(buffer);
return isrpipe_read_timeout(&_hid_stdio_isrpipe, buffer, len, timeout);
2020-06-01 18:01:32 +02:00
}
void usb_hid_io_write(const void *buffer, size_t len)
{
assert(buffer);
uint8_t *buffer_ep = hid.ep_in->ep->buf;
2020-06-01 18:01:32 +02:00
uint16_t max_size = hid.ep_in->maxpacketsize;
size_t offset = 0;
while (len) {
mutex_lock(&hid.in_lock);
if (len > max_size) {
memmove(buffer_ep + offset, (uint8_t *)buffer + offset, max_size);
offset += max_size;
hid.occupied = max_size;
len -= max_size;
}
else {
memmove(buffer_ep + offset, (uint8_t *)buffer + offset, len);
offset += len;
hid.occupied = len;
len = 0;
}
usbus_event_post(hid.usbus, &hid.tx_ready);
}
}
static void _hid_rx_pipe(usbus_hid_device_t *hid, uint8_t *data, size_t len)
{
(void)hid;
for (size_t i = 0; i < len; i++) {
isrpipe_write_one(&_hid_stdio_isrpipe, data[i]);
}
if (_rx_cb) {
_rx_cb(_rx_cb_arg);
}
2020-06-01 18:01:32 +02:00
}
void usb_hid_io_init(usbus_t *usbus, const uint8_t *report_desc,
2020-06-01 18:01:32 +02:00
size_t report_desc_size)
{
assert(usbus);
assert(report_desc);
2020-06-01 18:01:32 +02:00
usbus_hid_init(usbus, &hid, _hid_rx_pipe, report_desc, report_desc_size);
}
void usb_hid_io_set_rx_cb(usb_hid_io_cb_t cb, void *arg)
{
_rx_cb = cb;
_rx_cb_arg = arg;
}