kopia lustrzana https://github.com/skuep/AIOC
127 wiersze
3.0 KiB
C
127 wiersze
3.0 KiB
C
#include "usb.h"
|
|
#include "stm32f3xx_hal.h"
|
|
#include "aioc.h"
|
|
#include "tusb.h"
|
|
#include "usb_serial.h"
|
|
#include "usb_audio.h"
|
|
#include "usb_hid.h"
|
|
|
|
// FIXME: Do all three need to be handled, or just the LP one?
|
|
// USB high-priority interrupt (Channel 74): Triggered only by a correct
|
|
// transfer event for isochronous and double-buffer bulk transfer to reach
|
|
// the highest possible transfer rate.
|
|
void USB_HP_IRQHandler(void)
|
|
{
|
|
tud_int_handler(0);
|
|
}
|
|
|
|
// USB low-priority interrupt (Channel 75): Triggered by all USB events
|
|
// (Correct transfer, USB reset, etc.). The firmware has to check the
|
|
// interrupt source before serving the interrupt.
|
|
void USB_LP_IRQHandler(void)
|
|
{
|
|
tud_int_handler(0);
|
|
}
|
|
|
|
// USB wakeup interrupt (Channel 76): Triggered by the wakeup event from the USB
|
|
// Suspend mode.
|
|
void USBWakeUp_RMP_IRQHandler(void)
|
|
{
|
|
tud_int_handler(0);
|
|
}
|
|
|
|
// Invoked when device is mounted (configured)
|
|
void tud_mount_cb(void)
|
|
{
|
|
|
|
}
|
|
|
|
// Invoked when device is unmounted
|
|
void tud_umount_cb(void)
|
|
{
|
|
|
|
}
|
|
|
|
// Invoked when usb bus is suspended
|
|
// Within 7ms, device must draw an average of current less than 2.5 mA from bus
|
|
void tud_suspend_cb(bool remote_wakeup_en)
|
|
{
|
|
|
|
}
|
|
|
|
// Invoked when usb bus is resumed
|
|
void tud_resume_cb(void)
|
|
{
|
|
|
|
}
|
|
|
|
void Timer_Init(void)
|
|
{
|
|
__HAL_RCC_TIM2_CLK_ENABLE();
|
|
|
|
/* TIM2 generates a timebase for USB OUT feedback endpoint */
|
|
USB_SOF_TIMER->CR1 = TIM_CLOCKDIVISION_DIV1 | TIM_COUNTERMODE_UP | TIM_AUTORELOAD_PRELOAD_ENABLE;
|
|
USB_SOF_TIMER->PSC = 0;
|
|
USB_SOF_TIMER->ARR = 0xFFFFFFFFUL;
|
|
USB_SOF_TIMER->CCMR1 = (0x1 << TIM_CCMR1_CC1S_Pos);
|
|
USB_SOF_TIMER->EGR = TIM_EGR_UG;
|
|
USB_SOF_TIMER->CR1 |= TIM_CR1_CEN;
|
|
|
|
TU_ASSERT((2 * HAL_RCC_GetPCLK1Freq()) == USB_SOF_TIMER_HZ, /**/);
|
|
}
|
|
|
|
void GPIO_Init(void)
|
|
{
|
|
/* Configure USB DM and DP pins */
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
GPIO_InitTypeDef GPIO_InitStruct;
|
|
GPIO_InitStruct.Pin = (GPIO_PIN_11 | GPIO_PIN_12);
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
|
GPIO_InitStruct.Alternate = GPIO_AF14_USB;
|
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
}
|
|
|
|
void USB_Reset(void)
|
|
{
|
|
/* pull USB DP pins low to simulate disconnect
|
|
to force the host to re-enumerate when a new program is loaded */
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
GPIO_InitTypeDef GPIO_InitStruct;
|
|
GPIO_InitStruct.Pin = GPIO_PIN_12;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
|
GPIO_InitStruct.Pull = GPIO_PULLDOWN;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
|
|
GPIOA->BRR = GPIO_PIN_12;
|
|
}
|
|
|
|
void USB_Init(void)
|
|
{
|
|
__HAL_REMAPINTERRUPT_USB_ENABLE();
|
|
__HAL_RCC_USB_CLK_ENABLE();
|
|
|
|
GPIO_Init();
|
|
Timer_Init();
|
|
|
|
// Init classes
|
|
USB_SerialInit();
|
|
USB_AudioInit();
|
|
USB_HIDInit();
|
|
|
|
// Start USB Stack
|
|
tud_init(BOARD_TUD_RHPORT);
|
|
|
|
NVIC_SetPriority(USB_LP_IRQn, AIOC_IRQ_PRIO_USB);
|
|
NVIC_SetPriority(USB_HP_IRQn, AIOC_IRQ_PRIO_USB);
|
|
}
|
|
|
|
void USB_Task(void)
|
|
{
|
|
USB_SerialTask();
|
|
tud_task();
|
|
}
|
|
|