mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
fc1600252f
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
96 lines
2.3 KiB
C
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
|