1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/pkg/tinyusb/contrib/tinyusb.c
Gunar Schorcht fc1600252f pkg/tinyusb: fix reset for STM32 boards without internal D+ pullup
If the STM32 MCU does not have an internal D+ pullup and there is no dedicated GPIO on the board to simulate a USB disconnect, the D+ GPIO
has to be temporarily configured as an output and pushed down to simulate a disconnect/connect cycle to allow the host to recognize the device. This is done correctly in `cpu/stm32/periph/usbdev_fs.c` but not in tinyUSB STM32 hardware driver. That is, pressing the RESET button doesn't reset the USB connection.
fixup! pkg/tinyusb: fix reset for STM32 boards without internal D+ pullup
2022-11-30 15:17:51 +01:00

96 lines
2.3 KiB
C

/*
* Copyright (C) 2022 Gunar Schorcht
*
* 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.
*/
#include "log.h"
#include "kernel_defines.h"
#include "thread.h"
#include "tusb.h"
#include "device/usbd.h"
#include "host/usbh.h"
#include "tinyusb.h"
#include "tinyusb_hw.h"
#if IS_USED(MODULE_AUTO_INIT)
#include "auto_init_utils.h"
#endif
#define ENABLE_DEBUG 0
#include "debug.h"
static void *_tinyusb_thread_impl(void *arg)
{
(void)arg;
if (tinyusb_hw_init() != 0) {
LOG_ERROR("tinyUSB peripherals couldn't be initialized\n");
assert(0);
}
DEBUG("tinyUSB peripherals initialized\n");
if (IS_USED(MODULE_TINYUSB_DEVICE)) {
if (!tud_init(TINYUSB_TUD_RHPORT)) {
LOG_ERROR("tinyUSB device stack couldn't be initialized\n");
assert(0);
}
DEBUG("tinyUSB device stack initialized\n");
}
if (IS_USED(MODULE_TINYUSB_HOST)) {
if (!tuh_init(TINYUSB_TUH_RHPORT)) {
LOG_ERROR("tinyUSB host stack couldn't be initialized\n");
assert(0);
}
DEBUG("tinyUSB host stack initialized\n");
}
while (1) {
if (IS_USED(MODULE_TINYUSB_DEVICE)) {
/* call tinyUSB device task blocking */
tud_task();
DEBUG("tinyUSB device task executed\n");
}
if (IS_USED(MODULE_TINYUSB_HOST)) {
/* call tinyUSB device task blocking */
tuh_task();
DEBUG("tinyUSB host task executed\n");
}
}
return NULL;
}
static char _tinyusb_thread_stack[TINYUSB_THREAD_STACKSIZE];
int tinyusb_setup(void)
{
int res;
if ((res = thread_create(_tinyusb_thread_stack,
sizeof(_tinyusb_thread_stack),
TINYUSB_PRIORITY,
THREAD_CREATE_WOUT_YIELD | THREAD_CREATE_STACKTEST,
_tinyusb_thread_impl, NULL, "tinyusb")) < 0) {
LOG_ERROR("tinyUSB thread couldn't be created, reason %d\n", res);
return res;
}
DEBUG("tinyUSB thread created\n");
return 0;
}
void tinyusb_auto_init(void)
{
tinyusb_setup();
}
#if IS_USED(MODULE_AUTO_INIT_TINYUSB)
AUTO_INIT(tinyusb_auto_init, AUTO_INIT_PRIO_MOD_TINYUSB);
#endif