mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2025-01-07 18:28:47 +00:00
584c0962d8
* FURI stdglue: stdout hooks, local and global, ISR safe printf. Uniform newlines for terminal/debug output. Power: prevent sleep while core 2 has not started. * Furi record, stdglue: check mutex allocation * remove unused test * Furi stdglue: buferized output, dynamically allocated state. Furi record: dynamically allocated state. Input dump: proper line ending. Hal VCP: dynamically allocated state. * Interrupt manager: explicitly init list. * Makefile: cleanup rules, fix broken dfu upload. F4: add compiler stack protection options. * BLE: call debug uart callback on transmission complete * FreeRTOS: add configUSE_NEWLIB_REENTRANT * API HAL Timebase: fix issue with idle thread stack corruption caused by systick interrupt. BT: cleanup debug info output. FreeRTOS: disable reentry for newlib. * F4: update stack protection CFLAGS to match used compiller * F4: disable compiller stack protection because of incompatibility with current compiller * Makefile: return openocd logs to gdb * BLE: fixed pin, moar power, ble trace info. * Prevent sleep when connection is active * Makefile: return serial port to upload rule, add workaround for mac os * Furi: prevent usage of stack for cmsis functions. * F4: add missing includes, add debugger breakpoints * Applications: per app stack size. * Furi: honor kernel state in stdglue * FreeRTOS: remove unused hooks * Cleanup and format sources Co-authored-by: DrZlo13 <who.just.the.doctor@gmail.com>
402 lines
13 KiB
C
402 lines
13 KiB
C
/* USER CODE BEGIN Header */
|
|
/**
|
|
******************************************************************************
|
|
* File Name : app_debug.c
|
|
* Description : Debug capabilities source file for STM32WPAN Middleware
|
|
******************************************************************************
|
|
* @attention
|
|
*
|
|
* <h2><center>© Copyright (c) 2020 STMicroelectronics.
|
|
* All rights reserved.</center></h2>
|
|
*
|
|
* This software component is licensed by ST under Ultimate Liberty license
|
|
* SLA0044, the "License"; You may not use this file except in compliance with
|
|
* the License. You may obtain a copy of the License at:
|
|
* www.st.com/SLA0044
|
|
*
|
|
******************************************************************************
|
|
*/
|
|
/* USER CODE END Header */
|
|
|
|
/* Includes ------------------------------------------------------------------*/
|
|
/* USER CODE BEGIN Includes */
|
|
#include "app_common.h"
|
|
|
|
#include "app_debug.h"
|
|
#include "utilities_common.h"
|
|
#include "shci.h"
|
|
#include "tl.h"
|
|
#include "dbg_trace.h"
|
|
/* USER CODE END Includes */
|
|
|
|
/* Private typedef -----------------------------------------------------------*/
|
|
/* USER CODE BEGIN PTD */
|
|
typedef PACKED_STRUCT
|
|
{
|
|
GPIO_TypeDef* port;
|
|
uint16_t pin;
|
|
uint8_t enable;
|
|
uint8_t reserved;
|
|
} APPD_GpioConfig_t;
|
|
/* USER CODE END PTD */
|
|
|
|
/* Private defines -----------------------------------------------------------*/
|
|
/* USER CODE BEGIN PD */
|
|
#define GPIO_NBR_OF_RF_SIGNALS 9
|
|
#define GPIO_CFG_NBR_OF_FEATURES 34
|
|
#define NBR_OF_TRACES_CONFIG_PARAMETERS 4
|
|
#define NBR_OF_GENERAL_CONFIG_PARAMETERS 4
|
|
|
|
/**
|
|
* THIS SHALL BE SET TO A VALUE DIFFERENT FROM 0 ONLY ON REQUEST FROM ST SUPPORT
|
|
*/
|
|
#define BLE_DTB_CFG 0
|
|
/* USER CODE END PD */
|
|
|
|
/* Private macros ------------------------------------------------------------*/
|
|
/* USER CODE BEGIN PM */
|
|
/* USER CODE END PM */
|
|
|
|
/* Private variables ---------------------------------------------------------*/
|
|
/* USER CODE BEGIN PV */
|
|
PLACE_IN_SECTION("MB_MEM2") ALIGN(4) static SHCI_C2_DEBUG_TracesConfig_t APPD_TracesConfig={0, 0, 0, 0};
|
|
PLACE_IN_SECTION("MB_MEM2") ALIGN(4) static SHCI_C2_DEBUG_GeneralConfig_t APPD_GeneralConfig={BLE_DTB_CFG, {0, 0, 0}};
|
|
|
|
#ifdef CFG_DEBUG_TRACE_UART
|
|
#if(CFG_HW_LPUART1_ENABLED == 1)
|
|
extern void MX_LPUART1_UART_Init(void);
|
|
#endif
|
|
#if(CFG_HW_USART1_ENABLED == 1)
|
|
extern void MX_USART1_UART_Init(void);
|
|
#endif
|
|
#endif
|
|
|
|
/**
|
|
* THE DEBUG ON GPIO FOR CPU2 IS INTENDED TO BE USED ONLY ON REQUEST FROM ST SUPPORT
|
|
* It provides timing information on the CPU2 activity.
|
|
* All configuration of (port, pin) is supported for each features and can be selected by the user
|
|
* depending on the availability
|
|
*/
|
|
static const APPD_GpioConfig_t aGpioConfigList[GPIO_CFG_NBR_OF_FEATURES] =
|
|
{
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* BLE_ISR - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* BLE_STACK_TICK - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* BLE_CMD_PROCESS - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* BLE_ACL_DATA_PROCESS - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* SYS_CMD_PROCESS - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* RNG_PROCESS - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* NVM_PROCESS - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* IPCC_GENERAL - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* IPCC_BLE_CMD_RX - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* IPCC_BLE_EVT_TX - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* IPCC_BLE_ACL_DATA_RX - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* IPCC_SYS_CMD_RX - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* IPCC_SYS_EVT_TX - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* IPCC_CLI_CMD_RX - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* IPCC_OT_CMD_RX - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* IPCC_OT_ACK_TX - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* IPCC_CLI_ACK_TX - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* IPCC_MEM_MANAGER_RX - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* IPCC_TRACES_TX - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* HARD_FAULT - Set on Entry / Reset on Exit */
|
|
/* From v1.1.1 */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* IP_CORE_LP_STATUS - Set on Entry / Reset on Exit */
|
|
/* From v1.2.0 */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* END_OF_CONNECTION_EVENT - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* TIMER_SERVER_CALLBACK - Toggle on Entry */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* PES_ACTIVITY - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* MB_BLE_SEND_EVT - Set on Entry / Reset on Exit */
|
|
/* From v1.3.0 */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* BLE_NO_DELAY - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* BLE_STACK_STORE_NVM_CB - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* NVMA_WRITE_ONGOING - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* NVMA_WRITE_COMPLETE - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* NVMA_CLEANUP - Set on Entry / Reset on Exit */
|
|
/* From v1.4.0 */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* NVMA_START - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* FLASH_EOP - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* FLASH_WRITE - Set on Entry / Reset on Exit */
|
|
{ GPIOA, LL_GPIO_PIN_0, 0, 0}, /* FLASH_ERASE - Set on Entry / Reset on Exit */
|
|
};
|
|
|
|
/**
|
|
* THE DEBUG ON GPIO FOR CPU2 IS INTENDED TO BE USED ONLY ON REQUEST FROM ST SUPPORT
|
|
* This table is relevant only for BLE
|
|
* It provides timing information on BLE RF activity.
|
|
* New signals may be allocated at any location when requested by ST
|
|
* The GPIO allocated to each signal depend on the BLE_DTB_CFG value and cannot be changed
|
|
*/
|
|
#if( BLE_DTB_CFG == 7)
|
|
static const APPD_GpioConfig_t aRfConfigList[GPIO_NBR_OF_RF_SIGNALS] =
|
|
{
|
|
{ GPIOB, LL_GPIO_PIN_2, 0, 0}, /* DTB10 - Tx/Rx SPI */
|
|
{ GPIOB, LL_GPIO_PIN_7, 0, 0}, /* DTB11 - Tx/Tx SPI Clk */
|
|
{ GPIOA, LL_GPIO_PIN_8, 0, 0}, /* DTB12 - Tx/Rx Ready & SPI Select */
|
|
{ GPIOA, LL_GPIO_PIN_9, 0, 0}, /* DTB13 - Tx/Rx Start */
|
|
{ GPIOA, LL_GPIO_PIN_10, 0, 0}, /* DTB14 - FSM0 */
|
|
{ GPIOA, LL_GPIO_PIN_11, 0, 0}, /* DTB15 - FSM1 */
|
|
{ GPIOB, LL_GPIO_PIN_8, 0, 0}, /* DTB16 - FSM2 */
|
|
{ GPIOB, LL_GPIO_PIN_11, 0, 0}, /* DTB17 - FSM3 */
|
|
{ GPIOB, LL_GPIO_PIN_10, 0, 0}, /* DTB18 - FSM4 */
|
|
};
|
|
#endif
|
|
/* USER CODE END PV */
|
|
|
|
/* Global variables ----------------------------------------------------------*/
|
|
/* USER CODE BEGIN GV */
|
|
/* USER CODE END GV */
|
|
|
|
/* Private function prototypes -----------------------------------------------*/
|
|
/* USER CODE BEGIN PFP */
|
|
static void APPD_SetCPU2GpioConfig( void );
|
|
static void APPD_BleDtbCfg( void );
|
|
/* USER CODE END PFP */
|
|
|
|
/* Functions Definition ------------------------------------------------------*/
|
|
void APPD_Init( void )
|
|
{
|
|
/* USER CODE BEGIN APPD_Init */
|
|
#if (CFG_DEBUGGER_SUPPORTED == 1)
|
|
/**
|
|
* Keep debugger enabled while in any low power mode
|
|
*/
|
|
HAL_DBGMCU_EnableDBGSleepMode();
|
|
HAL_DBGMCU_EnableDBGStopMode();
|
|
|
|
/***************** ENABLE DEBUGGER *************************************/
|
|
LL_EXTI_EnableIT_32_63(LL_EXTI_LINE_48);
|
|
|
|
#else
|
|
GPIO_InitTypeDef gpio_config = {0};
|
|
|
|
gpio_config.Pull = GPIO_NOPULL;
|
|
gpio_config.Mode = GPIO_MODE_ANALOG;
|
|
|
|
gpio_config.Pin = GPIO_PIN_15 | GPIO_PIN_14 | GPIO_PIN_13;
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
HAL_GPIO_Init(GPIOA, &gpio_config);
|
|
__HAL_RCC_GPIOA_CLK_DISABLE();
|
|
|
|
gpio_config.Pin = GPIO_PIN_4 | GPIO_PIN_3;
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
HAL_GPIO_Init(GPIOB, &gpio_config);
|
|
__HAL_RCC_GPIOB_CLK_DISABLE();
|
|
|
|
HAL_DBGMCU_DisableDBGSleepMode();
|
|
HAL_DBGMCU_DisableDBGStopMode();
|
|
HAL_DBGMCU_DisableDBGStandbyMode();
|
|
|
|
#endif /* (CFG_DEBUGGER_SUPPORTED == 1) */
|
|
|
|
#if(CFG_DEBUG_TRACE != 0)
|
|
DbgTraceInit();
|
|
#endif
|
|
|
|
APPD_SetCPU2GpioConfig( );
|
|
APPD_BleDtbCfg( );
|
|
|
|
/* USER CODE END APPD_Init */
|
|
return;
|
|
}
|
|
|
|
void APPD_EnableCPU2( void )
|
|
{
|
|
/* USER CODE BEGIN APPD_EnableCPU2 */
|
|
SHCI_C2_DEBUG_Init_Cmd_Packet_t DebugCmdPacket =
|
|
{
|
|
{{0,0,0}}, /**< Does not need to be initialized */
|
|
{(uint8_t *)aGpioConfigList,
|
|
(uint8_t *)&APPD_TracesConfig,
|
|
(uint8_t *)&APPD_GeneralConfig,
|
|
GPIO_CFG_NBR_OF_FEATURES,
|
|
NBR_OF_TRACES_CONFIG_PARAMETERS,
|
|
NBR_OF_GENERAL_CONFIG_PARAMETERS}
|
|
};
|
|
|
|
/**< Traces channel initialization */
|
|
TL_TRACES_Init( );
|
|
|
|
/** GPIO DEBUG Initialization */
|
|
SHCI_C2_DEBUG_Init( &DebugCmdPacket );
|
|
|
|
/* USER CODE END APPD_EnableCPU2 */
|
|
return;
|
|
}
|
|
|
|
/*************************************************************
|
|
*
|
|
* LOCAL FUNCTIONS
|
|
*
|
|
*************************************************************/
|
|
static void APPD_SetCPU2GpioConfig( void )
|
|
{
|
|
/* USER CODE BEGIN APPD_SetCPU2GpioConfig */
|
|
GPIO_InitTypeDef gpio_config = {0};
|
|
uint8_t local_loop;
|
|
uint16_t gpioa_pin_list;
|
|
uint16_t gpiob_pin_list;
|
|
uint16_t gpioc_pin_list;
|
|
|
|
gpioa_pin_list = 0;
|
|
gpiob_pin_list = 0;
|
|
gpioc_pin_list = 0;
|
|
|
|
for(local_loop = 0 ; local_loop < GPIO_CFG_NBR_OF_FEATURES; local_loop++)
|
|
{
|
|
if( aGpioConfigList[local_loop].enable != 0)
|
|
{
|
|
switch((uint32_t)aGpioConfigList[local_loop].port)
|
|
{
|
|
case (uint32_t)GPIOA:
|
|
gpioa_pin_list |= aGpioConfigList[local_loop].pin;
|
|
break;
|
|
|
|
case (uint32_t)GPIOB:
|
|
gpiob_pin_list |= aGpioConfigList[local_loop].pin;
|
|
break;
|
|
|
|
case (uint32_t)GPIOC:
|
|
gpioc_pin_list |= aGpioConfigList[local_loop].pin;
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
gpio_config.Pull = GPIO_NOPULL;
|
|
gpio_config.Mode = GPIO_MODE_OUTPUT_PP;
|
|
gpio_config.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
if(gpioa_pin_list != 0)
|
|
{
|
|
gpio_config.Pin = gpioa_pin_list;
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
__HAL_RCC_C2GPIOA_CLK_ENABLE();
|
|
HAL_GPIO_Init(GPIOA, &gpio_config);
|
|
HAL_GPIO_WritePin(GPIOA, gpioa_pin_list, GPIO_PIN_RESET);
|
|
}
|
|
|
|
if(gpiob_pin_list != 0)
|
|
{
|
|
gpio_config.Pin = gpiob_pin_list;
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
__HAL_RCC_C2GPIOB_CLK_ENABLE();
|
|
HAL_GPIO_Init(GPIOB, &gpio_config);
|
|
HAL_GPIO_WritePin(GPIOB, gpiob_pin_list, GPIO_PIN_RESET);
|
|
}
|
|
|
|
if(gpioc_pin_list != 0)
|
|
{
|
|
gpio_config.Pin = gpioc_pin_list;
|
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
|
__HAL_RCC_C2GPIOC_CLK_ENABLE();
|
|
HAL_GPIO_Init(GPIOC, &gpio_config);
|
|
HAL_GPIO_WritePin(GPIOC, gpioc_pin_list, GPIO_PIN_RESET);
|
|
}
|
|
|
|
/* USER CODE END APPD_SetCPU2GpioConfig */
|
|
return;
|
|
}
|
|
|
|
static void APPD_BleDtbCfg( void )
|
|
{
|
|
/* USER CODE BEGIN APPD_BleDtbCfg */
|
|
#if (BLE_DTB_CFG != 0)
|
|
GPIO_InitTypeDef gpio_config = {0};
|
|
uint8_t local_loop;
|
|
uint16_t gpioa_pin_list;
|
|
uint16_t gpiob_pin_list;
|
|
|
|
gpioa_pin_list = 0;
|
|
gpiob_pin_list = 0;
|
|
|
|
for(local_loop = 0 ; local_loop < GPIO_NBR_OF_RF_SIGNALS; local_loop++)
|
|
{
|
|
if( aRfConfigList[local_loop].enable != 0)
|
|
{
|
|
switch((uint32_t)aRfConfigList[local_loop].port)
|
|
{
|
|
case (uint32_t)GPIOA:
|
|
gpioa_pin_list |= aRfConfigList[local_loop].pin;
|
|
break;
|
|
|
|
case (uint32_t)GPIOB:
|
|
gpiob_pin_list |= aRfConfigList[local_loop].pin;
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
gpio_config.Pull = GPIO_NOPULL;
|
|
gpio_config.Mode = GPIO_MODE_AF_PP;
|
|
gpio_config.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
gpio_config.Alternate = GPIO_AF6_RF_DTB7;
|
|
|
|
if(gpioa_pin_list != 0)
|
|
{
|
|
gpio_config.Pin = gpioa_pin_list;
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
__HAL_RCC_C2GPIOA_CLK_ENABLE();
|
|
HAL_GPIO_Init(GPIOA, &gpio_config);
|
|
}
|
|
|
|
if(gpiob_pin_list != 0)
|
|
{
|
|
gpio_config.Pin = gpiob_pin_list;
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
__HAL_RCC_C2GPIOB_CLK_ENABLE();
|
|
HAL_GPIO_Init(GPIOB, &gpio_config);
|
|
}
|
|
#endif
|
|
|
|
/* USER CODE END APPD_BleDtbCfg */
|
|
return;
|
|
}
|
|
|
|
/*************************************************************
|
|
*
|
|
* WRAP FUNCTIONS
|
|
*
|
|
*************************************************************/
|
|
#if(CFG_DEBUG_TRACE != 0)
|
|
void DbgOutputInit( void )
|
|
{
|
|
/* USER CODE BEGIN DbgOutputInit */
|
|
#ifdef CFG_DEBUG_TRACE_UART
|
|
if (CFG_DEBUG_TRACE_UART == hw_lpuart1)
|
|
{
|
|
#if(CFG_HW_LPUART1_ENABLED == 1)
|
|
MX_LPUART1_UART_Init();
|
|
#endif
|
|
}
|
|
else if (CFG_DEBUG_TRACE_UART == hw_uart1)
|
|
{
|
|
#if(CFG_HW_USART1_ENABLED == 1)
|
|
MX_USART1_UART_Init();
|
|
#endif
|
|
}
|
|
#endif
|
|
|
|
/* USER CODE END DbgOutputInit */
|
|
return;
|
|
}
|
|
|
|
extern UART_HandleTypeDef DEBUG_UART;
|
|
|
|
void DbgOutputTraces( uint8_t *p_data, uint16_t size, void (*cb)(void) )
|
|
{
|
|
/* USER CODE END DbgOutputTraces */
|
|
// HW_UART_Transmit_DMA(CFG_DEBUG_TRACE_UART, p_data, size, cb);
|
|
HAL_UART_Transmit(&DEBUG_UART, (uint8_t*)p_data, (uint16_t)size, HAL_MAX_DELAY);
|
|
cb();
|
|
/* USER CODE END DbgOutputTraces */
|
|
return;
|
|
}
|
|
#endif
|
|
|
|
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
|