2022-10-16 20:35:16 +00:00
|
|
|
#include "stm32f3xx_hal.h"
|
2022-11-03 16:19:31 +00:00
|
|
|
#include "aioc.h"
|
2023-09-10 16:33:58 +00:00
|
|
|
#include "settings.h"
|
2022-10-20 12:30:14 +00:00
|
|
|
#include "led.h"
|
2023-02-23 15:12:03 +00:00
|
|
|
#include "ptt.h"
|
2022-10-20 12:30:14 +00:00
|
|
|
#include "usb.h"
|
2022-11-13 20:12:56 +00:00
|
|
|
#include <assert.h>
|
|
|
|
#include <stdio.h>
|
2022-10-16 20:35:16 +00:00
|
|
|
|
2023-03-11 09:04:51 +00:00
|
|
|
// from ST application note AN2606
|
|
|
|
// Table 171: Bootloader device-dependent parameters
|
|
|
|
#if defined(STM32F302xB) || defined(STM32F302xC) || \
|
|
|
|
defined(STM32F303xB) || defined(STM32F303xC) || \
|
|
|
|
defined(STM32F373xC)
|
|
|
|
#define SYSTEM_MEMORY_BASE 0x1FFFD800
|
|
|
|
#else
|
|
|
|
#warning Live DFU reboot not supported on this MCU
|
|
|
|
#endif
|
|
|
|
|
2023-03-12 20:44:55 +00:00
|
|
|
#define USB_RESET_DELAY 100 /* ms */
|
|
|
|
|
2022-10-16 20:35:16 +00:00
|
|
|
static void SystemClock_Config(void)
|
|
|
|
{
|
2022-11-13 20:12:56 +00:00
|
|
|
HAL_StatusTypeDef status;
|
|
|
|
|
2022-10-16 20:35:16 +00:00
|
|
|
/* Enable external oscillator and configure PLL: 8 MHz (HSE) / 1 * 9 = 72 MHz */
|
|
|
|
RCC_OscInitTypeDef OscConfig = {
|
|
|
|
.OscillatorType = RCC_OSCILLATORTYPE_HSE,
|
|
|
|
.HSEState = RCC_HSE_ON,
|
|
|
|
.HSEPredivValue = RCC_HSE_PREDIV_DIV1,
|
|
|
|
.PLL = {
|
|
|
|
.PLLState = RCC_PLL_ON,
|
|
|
|
.PLLSource = RCC_CFGR_PLLSRC_HSE_PREDIV,
|
|
|
|
.PLLMUL = RCC_PLL_MUL9
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2022-11-13 20:12:56 +00:00
|
|
|
status = HAL_RCC_OscConfig(&OscConfig);
|
|
|
|
assert(status == HAL_OK);
|
2022-10-16 20:35:16 +00:00
|
|
|
|
|
|
|
/* Set correct peripheral clocks. 72 MHz (PLL) / 1.5 = 48 MHz */
|
|
|
|
RCC_PeriphCLKInitTypeDef PeriphClk = {
|
|
|
|
.PeriphClockSelection = RCC_PERIPHCLK_USB,
|
|
|
|
.USBClockSelection = RCC_USBCLKSOURCE_PLL_DIV1_5
|
|
|
|
};
|
|
|
|
|
2022-11-13 20:12:56 +00:00
|
|
|
status = HAL_RCCEx_PeriphCLKConfig(&PeriphClk);
|
|
|
|
assert(status == HAL_OK);
|
2022-10-16 20:35:16 +00:00
|
|
|
|
|
|
|
/* Set up divider for maximum speeds and switch clock */
|
|
|
|
RCC_ClkInitTypeDef ClkConfig = {
|
|
|
|
.ClockType = RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2,
|
|
|
|
.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK,
|
|
|
|
.AHBCLKDivider = RCC_SYSCLK_DIV1,
|
|
|
|
.APB1CLKDivider = RCC_HCLK_DIV2,
|
|
|
|
.APB2CLKDivider = RCC_HCLK_DIV1
|
|
|
|
};
|
|
|
|
|
2022-11-13 20:12:56 +00:00
|
|
|
status = HAL_RCC_ClockConfig(&ClkConfig, FLASH_LATENCY_2);
|
|
|
|
assert(status == HAL_OK);
|
2022-10-16 20:35:16 +00:00
|
|
|
|
2022-11-03 16:19:31 +00:00
|
|
|
NVIC_SetPriority(SysTick_IRQn, AIOC_IRQ_PRIO_SYSTICK);
|
|
|
|
|
2022-10-16 20:35:16 +00:00
|
|
|
/* Enable MCO Pin to PLL/2 output */
|
|
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
|
|
|
|
|
|
GPIO_InitTypeDef GpioInit = {
|
|
|
|
.Pin = GPIO_PIN_8,
|
|
|
|
.Mode = GPIO_MODE_AF_PP,
|
|
|
|
.Pull = GPIO_NOPULL,
|
|
|
|
.Speed = GPIO_SPEED_FREQ_HIGH,
|
|
|
|
.Alternate = GPIO_AF0_MCO
|
|
|
|
};
|
|
|
|
|
|
|
|
HAL_GPIO_Init(GPIOA, &GpioInit);
|
|
|
|
HAL_RCC_MCOConfig(RCC_MCO1, RCC_MCO1SOURCE_PLLCLK_DIV2, RCC_MCODIV_1);
|
|
|
|
}
|
|
|
|
|
2023-03-11 09:04:51 +00:00
|
|
|
static void SystemReset(void) {
|
|
|
|
uint32_t resetFlags = RCC->CSR;
|
|
|
|
|
|
|
|
/* Clear reset flags */
|
|
|
|
RCC->CSR |= RCC_CSR_RMVF;
|
|
|
|
|
2023-03-12 20:44:55 +00:00
|
|
|
/* Reset USB if necessary */
|
|
|
|
if (!(resetFlags & RCC_CSR_PORRSTF)) {
|
|
|
|
/* Since the USB Pullup is hardwired to the supply voltage,
|
|
|
|
* the host (re-)enumerates our USB device only during Power-On-Reset.
|
|
|
|
* For all other reset causes, do a manual USB reset. */
|
|
|
|
USB_Reset();
|
|
|
|
#if 1
|
|
|
|
/* Use SysTick to delay before continuing */
|
|
|
|
SysTick->LOAD = ((uint32_t) USB_RESET_DELAY * (HAL_RCC_GetHCLKFreq() / 1000)) - 1;
|
|
|
|
SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | SysTick_CTRL_ENABLE_Msk;
|
|
|
|
|
|
|
|
while (! (SysTick->CTRL & SysTick_CTRL_COUNTFLAG_Msk) )
|
|
|
|
/* Wait for timer expiration */;
|
|
|
|
|
|
|
|
SysTick->CTRL = 0x00000000; /* Reset SysTick */
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2023-03-11 09:04:51 +00:00
|
|
|
if (resetFlags & RCC_CSR_IWDGRSTF) {
|
2023-03-11 11:38:47 +00:00
|
|
|
#if defined(SYSTEM_MEMORY_BASE)
|
2023-03-11 09:04:51 +00:00
|
|
|
/* Reset cause was watchdog, which is used for rebooting into the bootloader.
|
|
|
|
Set stack pointer to *SYSTEM_MEMORY_BASE
|
|
|
|
and jump to *(SYSTEM_MEMORY_BASE + 4)
|
|
|
|
https://stackoverflow.com/a/42031657 */
|
|
|
|
asm volatile (
|
|
|
|
" msr msp, %[sp] \n"
|
|
|
|
" bx %[pc] \n"
|
|
|
|
|
|
|
|
:: [sp] "r" (*( (uint32_t*)(SYSTEM_MEMORY_BASE) )),
|
|
|
|
[pc] "r" (*( (uint32_t*)(SYSTEM_MEMORY_BASE + 4) ))
|
|
|
|
);
|
|
|
|
#else
|
|
|
|
while(1)
|
|
|
|
;
|
|
|
|
#endif
|
2023-03-11 11:38:47 +00:00
|
|
|
}
|
2023-03-11 09:04:51 +00:00
|
|
|
|
|
|
|
/* Initialize HAL */
|
2022-10-16 20:35:16 +00:00
|
|
|
HAL_Init();
|
|
|
|
|
2023-03-11 09:04:51 +00:00
|
|
|
/* Enable Clock to SYSCFG */
|
2022-10-17 19:19:09 +00:00
|
|
|
__HAL_RCC_SYSCFG_CLK_ENABLE();
|
|
|
|
|
2023-03-11 09:04:51 +00:00
|
|
|
/* Enable SWO debug output */
|
2023-03-12 20:44:55 +00:00
|
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
2022-10-31 13:04:07 +00:00
|
|
|
GPIO_InitTypeDef GpioSWOInit = {
|
|
|
|
.Pin = GPIO_PIN_3,
|
|
|
|
.Mode = GPIO_MODE_AF_PP,
|
|
|
|
.Pull = GPIO_NOPULL,
|
|
|
|
.Speed = GPIO_SPEED_FREQ_LOW,
|
|
|
|
.Alternate = GPIO_AF0_TRACE
|
|
|
|
};
|
|
|
|
HAL_GPIO_Init(GPIOB, &GpioSWOInit);
|
2023-03-11 09:04:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int _write(int file, char *ptr, int len)
|
|
|
|
{
|
|
|
|
for (uint32_t i=0; i<len; i++) {
|
|
|
|
ITM_SendChar(*ptr++);
|
|
|
|
}
|
|
|
|
|
|
|
|
return len;
|
|
|
|
}
|
|
|
|
|
2023-09-10 16:52:26 +00:00
|
|
|
void _close(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void _lseek(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void _read(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void _fstat(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void _getpid(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void _isatty(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void _kill(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2023-03-11 09:04:51 +00:00
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
SystemReset();
|
|
|
|
SystemClock_Config();
|
|
|
|
|
2023-09-10 16:33:58 +00:00
|
|
|
Settings_Init();
|
|
|
|
|
2022-10-16 20:35:16 +00:00
|
|
|
LED_Init();
|
2022-10-21 15:03:51 +00:00
|
|
|
LED_MODE(0, LED_MODE_SLOWPULSE2X);
|
|
|
|
LED_MODE(1, LED_MODE_SLOWPULSE2X);
|
2022-10-20 20:51:11 +00:00
|
|
|
|
2023-02-23 15:12:03 +00:00
|
|
|
PTT_Init();
|
|
|
|
|
2022-10-17 19:19:09 +00:00
|
|
|
USB_Init();
|
2022-10-16 20:35:16 +00:00
|
|
|
|
2022-11-13 20:12:56 +00:00
|
|
|
uint32_t i = 0;
|
2022-10-16 20:35:16 +00:00
|
|
|
while (1) {
|
2022-10-20 12:30:14 +00:00
|
|
|
USB_Task();
|
2022-11-13 20:12:56 +00:00
|
|
|
|
|
|
|
if ( (i++ & 0x7FFF) == 0) {
|
|
|
|
usb_audio_fbstats_t fb;
|
|
|
|
USB_AudioGetSpeakerFeedbackStats(&fb);
|
|
|
|
|
|
|
|
usb_audio_bufstats_t buf;
|
|
|
|
USB_AudioGetSpeakerBufferStats(&buf);
|
|
|
|
|
2022-12-29 18:15:39 +00:00
|
|
|
#if 0
|
2022-11-13 20:12:56 +00:00
|
|
|
printf("buf: (%d/%d/%d) fb: (%06lX/%06lX/%06lX)\n",
|
|
|
|
buf.bufLevelMin, buf.bufLevelMax, buf.bufLevelAvg,
|
|
|
|
fb.feedbackMin, fb.feedbackMax, fb.feedbackAvg);
|
2022-12-29 18:15:39 +00:00
|
|
|
#endif
|
2022-11-13 20:12:56 +00:00
|
|
|
}
|
2022-10-16 20:35:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void NMI_Handler(void) {
|
|
|
|
}
|
|
|
|
|
|
|
|
void HardFault_Handler(void) {
|
|
|
|
/* Go to infinite loop when Hard Fault exception occurs */
|
|
|
|
while (1) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void MemManage_Handler(void) {
|
|
|
|
/* Go to infinite loop when Memory Manage exception occurs */
|
|
|
|
while (1) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void BusFault_Handler(void) {
|
|
|
|
/* Go to infinite loop when Bus Fault exception occurs */
|
|
|
|
while (1) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void UsageFault_Handler(void) {
|
|
|
|
/* Go to infinite loop when Usage Fault exception occurs */
|
|
|
|
while (1) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void SVC_Handler(void) {
|
|
|
|
}
|
|
|
|
|
|
|
|
void DebugMon_Handler(void) {
|
|
|
|
}
|
|
|
|
|
|
|
|
void PendSV_Handler(void) {
|
|
|
|
}
|
|
|
|
|
|
|
|
void SysTick_Handler(void) {
|
|
|
|
HAL_IncTick();
|
|
|
|
}
|
2022-10-17 19:19:09 +00:00
|
|
|
|