BT: stop advertising in bt test cli commands (#712)
* bt: stop advertising in bt test cli commands * furi-hal-bt: add switch context in furi_hal_bt_lock_flash * Lib: update STM32CubeWB to latest version. Scripts: update supported copro binaries version * Scripts: proper version extraction from Cube manifest * bt: add debug application and comment it * bt: fix stop advertising command * bt: debug on f7 target * furi-hal-console: add console tx + new line * bt: fix debug trace function Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
This commit is contained in:
		
							parent
							
								
									69f54973cc
								
							
						
					
					
						commit
						0e1922db4d
					
				@ -1,6 +1,7 @@
 | 
				
			|||||||
#include "bt_cli.h"
 | 
					#include "bt_cli.h"
 | 
				
			||||||
#include <furi.h>
 | 
					#include <furi.h>
 | 
				
			||||||
#include <furi-hal.h>
 | 
					#include <furi-hal.h>
 | 
				
			||||||
 | 
					#include "bt_settings.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void bt_cli_init() {
 | 
					void bt_cli_init() {
 | 
				
			||||||
    Cli* cli = furi_record_open("cli");
 | 
					    Cli* cli = furi_record_open("cli");
 | 
				
			||||||
@ -25,6 +26,9 @@ void bt_cli_command_info(Cli* cli, string_t args, void* context) {
 | 
				
			|||||||
void bt_cli_command_carrier_tx(Cli* cli, string_t args, void* context) {
 | 
					void bt_cli_command_carrier_tx(Cli* cli, string_t args, void* context) {
 | 
				
			||||||
    uint16_t channel;
 | 
					    uint16_t channel;
 | 
				
			||||||
    uint16_t power;
 | 
					    uint16_t power;
 | 
				
			||||||
 | 
					    BtSettings bt_settings;
 | 
				
			||||||
 | 
					    bt_settings_load(&bt_settings);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    int ret = sscanf(string_get_cstr(args), "%hu %hu", &channel, &power);
 | 
					    int ret = sscanf(string_get_cstr(args), "%hu %hu", &channel, &power);
 | 
				
			||||||
    if(ret != 2) {
 | 
					    if(ret != 2) {
 | 
				
			||||||
        printf("sscanf returned %d, channel: %hu, power: %hu\r\n", ret, channel, power);
 | 
					        printf("sscanf returned %d, channel: %hu, power: %hu\r\n", ret, channel, power);
 | 
				
			||||||
@ -39,6 +43,8 @@ void bt_cli_command_carrier_tx(Cli* cli, string_t args, void* context) {
 | 
				
			|||||||
        printf("Power must be in 0...6 dB range, not %hu\r\n", power);
 | 
					        printf("Power must be in 0...6 dB range, not %hu\r\n", power);
 | 
				
			||||||
        return;
 | 
					        return;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    furi_hal_bt_stop_advertising();
 | 
				
			||||||
    printf("Transmitting carrier at %hu channel at %hu dB power\r\n", channel, power);
 | 
					    printf("Transmitting carrier at %hu channel at %hu dB power\r\n", channel, power);
 | 
				
			||||||
    printf("Press CTRL+C to stop\r\n");
 | 
					    printf("Press CTRL+C to stop\r\n");
 | 
				
			||||||
    furi_hal_bt_start_tone_tx(channel, 0x19 + power);
 | 
					    furi_hal_bt_start_tone_tx(channel, 0x19 + power);
 | 
				
			||||||
@ -47,10 +53,15 @@ void bt_cli_command_carrier_tx(Cli* cli, string_t args, void* context) {
 | 
				
			|||||||
        osDelay(250);
 | 
					        osDelay(250);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    furi_hal_bt_stop_tone_tx();
 | 
					    furi_hal_bt_stop_tone_tx();
 | 
				
			||||||
 | 
					    if(bt_settings.enabled) {
 | 
				
			||||||
 | 
					        furi_hal_bt_start_advertising();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void bt_cli_command_carrier_rx(Cli* cli, string_t args, void* context) {
 | 
					void bt_cli_command_carrier_rx(Cli* cli, string_t args, void* context) {
 | 
				
			||||||
    uint16_t channel;
 | 
					    uint16_t channel;
 | 
				
			||||||
 | 
					    BtSettings bt_settings;
 | 
				
			||||||
 | 
					    bt_settings_load(&bt_settings);
 | 
				
			||||||
    int ret = sscanf(string_get_cstr(args), "%hu", &channel);
 | 
					    int ret = sscanf(string_get_cstr(args), "%hu", &channel);
 | 
				
			||||||
    if(ret != 1) {
 | 
					    if(ret != 1) {
 | 
				
			||||||
        printf("sscanf returned %d, channel: %hu\r\n", ret, channel);
 | 
					        printf("sscanf returned %d, channel: %hu\r\n", ret, channel);
 | 
				
			||||||
@ -61,6 +72,8 @@ void bt_cli_command_carrier_rx(Cli* cli, string_t args, void* context) {
 | 
				
			|||||||
        printf("Channel number must be in 0...39 range, not %hu\r\n", channel);
 | 
					        printf("Channel number must be in 0...39 range, not %hu\r\n", channel);
 | 
				
			||||||
        return;
 | 
					        return;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    furi_hal_bt_stop_advertising();
 | 
				
			||||||
    printf("Receiving carrier at %hu channel\r\n", channel);
 | 
					    printf("Receiving carrier at %hu channel\r\n", channel);
 | 
				
			||||||
    printf("Press CTRL+C to stop\r\n");
 | 
					    printf("Press CTRL+C to stop\r\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -73,12 +86,17 @@ void bt_cli_command_carrier_rx(Cli* cli, string_t args, void* context) {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    furi_hal_bt_stop_packet_test();
 | 
					    furi_hal_bt_stop_packet_test();
 | 
				
			||||||
 | 
					    if(bt_settings.enabled) {
 | 
				
			||||||
 | 
					        furi_hal_bt_start_advertising();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void bt_cli_command_packet_tx(Cli* cli, string_t args, void* context) {
 | 
					void bt_cli_command_packet_tx(Cli* cli, string_t args, void* context) {
 | 
				
			||||||
    uint16_t channel;
 | 
					    uint16_t channel;
 | 
				
			||||||
    uint16_t pattern;
 | 
					    uint16_t pattern;
 | 
				
			||||||
    uint16_t datarate;
 | 
					    uint16_t datarate;
 | 
				
			||||||
 | 
					    BtSettings bt_settings;
 | 
				
			||||||
 | 
					    bt_settings_load(&bt_settings);
 | 
				
			||||||
    int ret = sscanf(string_get_cstr(args), "%hu %hu %hu", &channel, &pattern, &datarate);
 | 
					    int ret = sscanf(string_get_cstr(args), "%hu %hu %hu", &channel, &pattern, &datarate);
 | 
				
			||||||
    if(ret != 3) {
 | 
					    if(ret != 3) {
 | 
				
			||||||
        printf("sscanf returned %d, channel: %hu %hu %hu\r\n", ret, channel, pattern, datarate);
 | 
					        printf("sscanf returned %d, channel: %hu %hu %hu\r\n", ret, channel, pattern, datarate);
 | 
				
			||||||
@ -105,6 +123,7 @@ void bt_cli_command_packet_tx(Cli* cli, string_t args, void* context) {
 | 
				
			|||||||
        return;
 | 
					        return;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    furi_hal_bt_stop_advertising();
 | 
				
			||||||
    printf(
 | 
					    printf(
 | 
				
			||||||
        "Transmitting %hu pattern packet at %hu channel at %hu M datarate\r\n",
 | 
					        "Transmitting %hu pattern packet at %hu channel at %hu M datarate\r\n",
 | 
				
			||||||
        pattern,
 | 
					        pattern,
 | 
				
			||||||
@ -118,11 +137,16 @@ void bt_cli_command_packet_tx(Cli* cli, string_t args, void* context) {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
    furi_hal_bt_stop_packet_test();
 | 
					    furi_hal_bt_stop_packet_test();
 | 
				
			||||||
    printf("Transmitted %lu packets", furi_hal_bt_get_transmitted_packets());
 | 
					    printf("Transmitted %lu packets", furi_hal_bt_get_transmitted_packets());
 | 
				
			||||||
 | 
					    if(bt_settings.enabled) {
 | 
				
			||||||
 | 
					        furi_hal_bt_start_advertising();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void bt_cli_command_packet_rx(Cli* cli, string_t args, void* context) {
 | 
					void bt_cli_command_packet_rx(Cli* cli, string_t args, void* context) {
 | 
				
			||||||
    uint16_t channel;
 | 
					    uint16_t channel;
 | 
				
			||||||
    uint16_t datarate;
 | 
					    uint16_t datarate;
 | 
				
			||||||
 | 
					    BtSettings bt_settings;
 | 
				
			||||||
 | 
					    bt_settings_load(&bt_settings);
 | 
				
			||||||
    int ret = sscanf(string_get_cstr(args), "%hu %hu", &channel, &datarate);
 | 
					    int ret = sscanf(string_get_cstr(args), "%hu %hu", &channel, &datarate);
 | 
				
			||||||
    if(ret != 2) {
 | 
					    if(ret != 2) {
 | 
				
			||||||
        printf("sscanf returned %d, channel: %hu datarate: %hu\r\n", ret, channel, datarate);
 | 
					        printf("sscanf returned %d, channel: %hu datarate: %hu\r\n", ret, channel, datarate);
 | 
				
			||||||
@ -137,6 +161,8 @@ void bt_cli_command_packet_rx(Cli* cli, string_t args, void* context) {
 | 
				
			|||||||
        printf("Datarate must be in 1 or 2 Mb, not %hu\r\n", datarate);
 | 
					        printf("Datarate must be in 1 or 2 Mb, not %hu\r\n", datarate);
 | 
				
			||||||
        return;
 | 
					        return;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    furi_hal_bt_stop_advertising();
 | 
				
			||||||
    printf("Receiving packets at %hu channel at %hu M datarate\r\n", channel, datarate);
 | 
					    printf("Receiving packets at %hu channel at %hu M datarate\r\n", channel, datarate);
 | 
				
			||||||
    printf("Press CTRL+C to stop\r\n");
 | 
					    printf("Press CTRL+C to stop\r\n");
 | 
				
			||||||
    furi_hal_bt_start_packet_rx(channel, datarate);
 | 
					    furi_hal_bt_start_packet_rx(channel, datarate);
 | 
				
			||||||
@ -150,4 +176,7 @@ void bt_cli_command_packet_rx(Cli* cli, string_t args, void* context) {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
    uint16_t packets_received = furi_hal_bt_stop_packet_test();
 | 
					    uint16_t packets_received = furi_hal_bt_stop_packet_test();
 | 
				
			||||||
    printf("Received %hu packets", packets_received);
 | 
					    printf("Received %hu packets", packets_received);
 | 
				
			||||||
 | 
					    if(bt_settings.enabled) {
 | 
				
			||||||
 | 
					        furi_hal_bt_start_advertising();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -367,12 +367,12 @@ typedef enum
 | 
				
			|||||||
/**
 | 
					/**
 | 
				
			||||||
 * When set to 1, the traces are enabled in the BLE services
 | 
					 * When set to 1, the traces are enabled in the BLE services
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
#define CFG_DEBUG_BLE_TRACE     1
 | 
					#define CFG_DEBUG_BLE_TRACE     0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * Enable or Disable traces in application
 | 
					 * Enable or Disable traces in application
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
#define CFG_DEBUG_APP_TRACE     1
 | 
					#define CFG_DEBUG_APP_TRACE     0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if (CFG_DEBUG_APP_TRACE != 0)
 | 
					#if (CFG_DEBUG_APP_TRACE != 0)
 | 
				
			||||||
#define APP_DBG_MSG                 PRINT_MESG_DBG
 | 
					#define APP_DBG_MSG                 PRINT_MESG_DBG
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										375
									
								
								firmware/targets/f6/ble-glue/app_debug.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										375
									
								
								firmware/targets/f6/ble-glue/app_debug.c
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,375 @@
 | 
				
			|||||||
 | 
					/* 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 "utilities_common.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "app_common.h"
 | 
				
			||||||
 | 
					#include "app_debug.h"
 | 
				
			||||||
 | 
					#include "shci.h"
 | 
				
			||||||
 | 
					#include "tl.h"
 | 
				
			||||||
 | 
					#include "dbg_trace.h"
 | 
				
			||||||
 | 
					#include <furi-hal.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     7
 | 
				
			||||||
 | 
					#define SYS_DBG_CFG1  (SHCI_C2_DEBUG_OPTIONS_IPCORE_LP | SHCI_C2_DEBUG_OPTIONS_CPU2_STOP_EN) 
 | 
				
			||||||
 | 
					/* USER CODE END PD */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* 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, SYS_DBG_CFG1, {0, 0}};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * 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_7, 1, 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 */
 | 
				
			||||||
 | 
					    { GPIOB, LL_GPIO_PIN_3, 1, 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_6, 1, 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_4, 1, 0},  /* PES_ACTIVITY - Set on Entry / Reset on Exit */
 | 
				
			||||||
 | 
					    { GPIOB, LL_GPIO_PIN_2, 1, 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  );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // GPIO_InitTypeDef  GPIO_InitStruct;
 | 
				
			||||||
 | 
					  // GPIO_InitStruct.Pull = GPIO_NOPULL;
 | 
				
			||||||
 | 
					  // GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
 | 
				
			||||||
 | 
					  // GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
 | 
				
			||||||
 | 
					  // GPIO_InitStruct.Pin = LL_GPIO_PIN_3;
 | 
				
			||||||
 | 
					  // HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
 | 
				
			||||||
 | 
					  // SHCI_C2_ExtpaConfig((uint32_t)GPIOC, LL_GPIO_PIN_3, EXT_PA_ENABLED_LOW, EXT_PA_ENABLED);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* 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 )
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void DbgOutputTraces(  uint8_t *p_data, uint16_t size, void (*cb)(void) )
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					  furi_hal_console_tx(p_data, size);
 | 
				
			||||||
 | 
					  cb();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
 | 
				
			||||||
							
								
								
									
										38
									
								
								firmware/targets/f6/ble-glue/app_debug.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								firmware/targets/f6/ble-glue/app_debug.h
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,38 @@
 | 
				
			|||||||
 | 
					/* USER CODE BEGIN Header */
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 ******************************************************************************
 | 
				
			||||||
 | 
					  * File Name          : app_debug.h
 | 
				
			||||||
 | 
					  * Description        : Header for app_debug.c module
 | 
				
			||||||
 | 
					 ******************************************************************************
 | 
				
			||||||
 | 
					  * @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 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* Define to prevent recursive inclusion -------------------------------------*/
 | 
				
			||||||
 | 
					#ifndef __APP_DEBUG_H
 | 
				
			||||||
 | 
					#define __APP_DEBUG_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef __cplusplus
 | 
				
			||||||
 | 
					extern "C" {
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    void APPD_Init( void );
 | 
				
			||||||
 | 
					    void APPD_EnableCPU2( void );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef __cplusplus
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif /*__APP_DEBUG_H */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
 | 
				
			||||||
@ -6,6 +6,7 @@
 | 
				
			|||||||
#include "tl.h"
 | 
					#include "tl.h"
 | 
				
			||||||
#include "cmsis_os.h"
 | 
					#include "cmsis_os.h"
 | 
				
			||||||
#include "shci_tl.h"
 | 
					#include "shci_tl.h"
 | 
				
			||||||
 | 
					#include "app_debug.h"
 | 
				
			||||||
#include <furi-hal.h>
 | 
					#include <furi-hal.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
extern RTC_HandleTypeDef hrtc;
 | 
					extern RTC_HandleTypeDef hrtc;
 | 
				
			||||||
@ -177,16 +178,3 @@ void shci_cmd_resp_wait(uint32_t timeout) {
 | 
				
			|||||||
  UNUSED(timeout);
 | 
					  UNUSED(timeout);
 | 
				
			||||||
  osSemaphoreAcquire( SemShciId, osWaitForever );
 | 
					  osSemaphoreAcquire( SemShciId, osWaitForever );
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					 | 
				
			||||||
#if(CFG_DEBUG_TRACE != 0)
 | 
					 | 
				
			||||||
void DbgOutputInit( void )
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
void DbgOutputTraces(  uint8_t *p_data, uint16_t size, void (*cb)(void) )
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
  furi_hal_console_tx(p_data, size);
 | 
					 | 
				
			||||||
  cb();
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
				
			|||||||
@ -25,13 +25,13 @@
 | 
				
			|||||||
 * Enable or Disable traces from BLE
 | 
					 * Enable or Disable traces from BLE
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define BLE_DBG_APP_EN             0
 | 
					#define BLE_DBG_APP_EN             1
 | 
				
			||||||
#define BLE_DBG_DIS_EN             0
 | 
					#define BLE_DBG_DIS_EN             1
 | 
				
			||||||
#define BLE_DBG_HRS_EN             0
 | 
					#define BLE_DBG_HRS_EN             1
 | 
				
			||||||
#define BLE_DBG_SVCCTL_EN          0
 | 
					#define BLE_DBG_SVCCTL_EN          1
 | 
				
			||||||
#define BLE_DBG_BLS_EN             0
 | 
					#define BLE_DBG_BLS_EN             1
 | 
				
			||||||
#define BLE_DBG_HTS_EN             0
 | 
					#define BLE_DBG_HTS_EN             1
 | 
				
			||||||
#define BLE_DBG_P2P_STM_EN         0
 | 
					#define BLE_DBG_P2P_STM_EN         1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * Macro definition
 | 
					 * Macro definition
 | 
				
			||||||
 | 
				
			|||||||
@ -33,26 +33,23 @@ extern "C" {
 | 
				
			|||||||
#include "app_conf.h"   /* required as some configuration used in dbg_trace.h are set there */
 | 
					#include "app_conf.h"   /* required as some configuration used in dbg_trace.h are set there */
 | 
				
			||||||
#include "dbg_trace.h"
 | 
					#include "dbg_trace.h"
 | 
				
			||||||
#include "hw_if.h"
 | 
					#include "hw_if.h"
 | 
				
			||||||
 | 
					#include <furi-hal.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * Enable or Disable traces
 | 
					 * Enable or Disable traces
 | 
				
			||||||
 * The raw data output is the hci binary packet format as specified by the BT specification *
 | 
					 * The raw data output is the hci binary packet format as specified by the BT specification *
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
#define TL_SHCI_CMD_DBG_EN      0   /* Reports System commands sent to CPU2 and the command response */
 | 
					#define TL_SHCI_CMD_DBG_EN      1   /* Reports System commands sent to CPU2 and the command response */
 | 
				
			||||||
#define TL_SHCI_CMD_DBG_RAW_EN  0   /* Reports raw data System commands sent to CPU2 and the command response */
 | 
					#define TL_SHCI_CMD_DBG_RAW_EN  0   /* Reports raw data System commands sent to CPU2 and the command response */
 | 
				
			||||||
#define TL_SHCI_EVT_DBG_EN      0   /* Reports System Asynchronous Events received from CPU2 */
 | 
					#define TL_SHCI_EVT_DBG_EN      1   /* Reports System Asynchronous Events received from CPU2 */
 | 
				
			||||||
#define TL_SHCI_EVT_DBG_RAW_EN  0   /* Reports raw data System Asynchronous Events received from CPU2 */
 | 
					#define TL_SHCI_EVT_DBG_RAW_EN  0   /* Reports raw data System Asynchronous Events received from CPU2 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define TL_HCI_CMD_DBG_EN       0   /* Reports BLE command sent to CPU2 and the command response */
 | 
					#define TL_HCI_CMD_DBG_EN       1   /* Reports BLE command sent to CPU2 and the command response */
 | 
				
			||||||
#define TL_HCI_CMD_DBG_RAW_EN   0   /* Reports raw data BLE command sent to CPU2 and the command response */
 | 
					#define TL_HCI_CMD_DBG_RAW_EN   0   /* Reports raw data BLE command sent to CPU2 and the command response */
 | 
				
			||||||
#define TL_HCI_EVT_DBG_EN       0   /* Reports BLE Asynchronous Events received from CPU2 */
 | 
					#define TL_HCI_EVT_DBG_EN       1   /* Reports BLE Asynchronous Events received from CPU2 */
 | 
				
			||||||
#define TL_HCI_EVT_DBG_RAW_EN   0   /* Reports raw data BLE Asynchronous Events received from CPU2 */
 | 
					#define TL_HCI_EVT_DBG_RAW_EN   0   /* Reports raw data BLE Asynchronous Events received from CPU2 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define TL_MM_DBG_EN            0   /* Reports the informations of the buffer released to CPU2 */
 | 
					#define TL_MM_DBG_EN            1   /* Reports the informations of the buffer released to CPU2 */
 | 
				
			||||||
 | 
					 | 
				
			||||||
/**
 | 
					 | 
				
			||||||
 * Macro definition
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * System Transport Layer
 | 
					 * System Transport Layer
 | 
				
			||||||
@ -66,7 +63,7 @@ extern "C" {
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if (TL_SHCI_CMD_DBG_RAW_EN != 0)
 | 
					#if (TL_SHCI_CMD_DBG_RAW_EN != 0)
 | 
				
			||||||
#define TL_SHCI_CMD_DBG_RAW(_PDATA_, _SIZE_)  furi_hal_console_tx(_PDATA_, _SIZE_)
 | 
					#define TL_SHCI_CMD_DBG_RAW(_PDATA_, _SIZE_)  furi_hal_console_tx_with_new_line(_PDATA_, _SIZE_)
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
#define TL_SHCI_CMD_DBG_RAW(...)
 | 
					#define TL_SHCI_CMD_DBG_RAW(...)
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@ -80,7 +77,7 @@ extern "C" {
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if (TL_SHCI_EVT_DBG_RAW_EN != 0)
 | 
					#if (TL_SHCI_EVT_DBG_RAW_EN != 0)
 | 
				
			||||||
#define TL_SHCI_EVT_DBG_RAW(_PDATA_, _SIZE_)  furi_hal_console_tx(_PDATA_, _SIZE_)
 | 
					#define TL_SHCI_EVT_DBG_RAW(_PDATA_, _SIZE_)  furi_hal_console_tx_with_new_line(_PDATA_, _SIZE_)
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
#define TL_SHCI_EVT_DBG_RAW(...)
 | 
					#define TL_SHCI_EVT_DBG_RAW(...)
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@ -97,7 +94,7 @@ extern "C" {
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if (TL_HCI_CMD_DBG_RAW_EN != 0)
 | 
					#if (TL_HCI_CMD_DBG_RAW_EN != 0)
 | 
				
			||||||
#define TL_HCI_CMD_DBG_RAW(_PDATA_, _SIZE_)  furi_hal_console_tx(_PDATA_, _SIZE_)
 | 
					#define TL_HCI_CMD_DBG_RAW(_PDATA_, _SIZE_)  furi_hal_console_tx_with_new_line(_PDATA_, _SIZE_)
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
#define TL_HCI_CMD_DBG_RAW(...)
 | 
					#define TL_HCI_CMD_DBG_RAW(...)
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@ -111,7 +108,7 @@ extern "C" {
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if (TL_HCI_EVT_DBG_RAW_EN != 0)
 | 
					#if (TL_HCI_EVT_DBG_RAW_EN != 0)
 | 
				
			||||||
#define TL_HCI_EVT_DBG_RAW(_PDATA_, _SIZE_)  furi_hal_console_tx(_PDATA_, _SIZE_)
 | 
					#define TL_HCI_EVT_DBG_RAW(_PDATA_, _SIZE_)  furi_hal_console_tx_with_new_line(_PDATA_, _SIZE_)
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
#define TL_HCI_EVT_DBG_RAW(...)
 | 
					#define TL_HCI_EVT_DBG_RAW(...)
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
				
			|||||||
@ -26,6 +26,9 @@ void furi_hal_bt_start_advertising() {
 | 
				
			|||||||
void furi_hal_bt_stop_advertising() {
 | 
					void furi_hal_bt_stop_advertising() {
 | 
				
			||||||
    if(furi_hal_bt_is_active()) {
 | 
					    if(furi_hal_bt_is_active()) {
 | 
				
			||||||
        gap_stop_advertising();
 | 
					        gap_stop_advertising();
 | 
				
			||||||
 | 
					        while(furi_hal_bt_is_active()) {
 | 
				
			||||||
 | 
					            osDelay(1);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -85,7 +88,9 @@ bool furi_hal_bt_lock_flash(bool erase_flag) {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    if(erase_flag) SHCI_C2_FLASH_EraseActivity(ERASE_ACTIVITY_ON);
 | 
					    if(erase_flag) SHCI_C2_FLASH_EraseActivity(ERASE_ACTIVITY_ON);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    while(LL_FLASH_IsActiveFlag_OperationSuspended()) {};
 | 
					    while(LL_FLASH_IsActiveFlag_OperationSuspended()) {
 | 
				
			||||||
 | 
					        osDelay(1);
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    __disable_irq();
 | 
					    __disable_irq();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -41,10 +41,7 @@ void furi_hal_console_init() {
 | 
				
			|||||||
    FURI_LOG_I("FuriHalConsole", "Init OK");
 | 
					    FURI_LOG_I("FuriHalConsole", "Init OK");
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void furi_hal_console_tx(const uint8_t* buffer, size_t buffer_size) {
 | 
					static void furi_hal_console_uart_tx(const uint8_t* buffer, size_t buffer_size) {
 | 
				
			||||||
    if (!furi_hal_console_alive)
 | 
					 | 
				
			||||||
        return;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    while(buffer_size > 0) {
 | 
					    while(buffer_size > 0) {
 | 
				
			||||||
        while (!LL_USART_IsActiveFlag_TXE(USART1));
 | 
					        while (!LL_USART_IsActiveFlag_TXE(USART1));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -53,8 +50,27 @@ void furi_hal_console_tx(const uint8_t* buffer, size_t buffer_size) {
 | 
				
			|||||||
        buffer++;
 | 
					        buffer++;
 | 
				
			||||||
        buffer_size--;
 | 
					        buffer_size--;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /* Wait for TC flag to be raised for last char */
 | 
					void furi_hal_console_tx(const uint8_t* buffer, size_t buffer_size) {
 | 
				
			||||||
 | 
					    if (!furi_hal_console_alive)
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Transmit data
 | 
				
			||||||
 | 
					    furi_hal_console_uart_tx(buffer, buffer_size);
 | 
				
			||||||
 | 
					    // Wait for TC flag to be raised for last char
 | 
				
			||||||
 | 
					    while (!LL_USART_IsActiveFlag_TC(USART1));
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void furi_hal_console_tx_with_new_line(const uint8_t* buffer, size_t buffer_size) {
 | 
				
			||||||
 | 
					    if (!furi_hal_console_alive)
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Transmit data
 | 
				
			||||||
 | 
					    furi_hal_console_uart_tx(buffer, buffer_size);
 | 
				
			||||||
 | 
					    // Transmit new line symbols
 | 
				
			||||||
 | 
					    furi_hal_console_uart_tx((const uint8_t*)"\r\n", 2);
 | 
				
			||||||
 | 
					    // Wait for TC flag to be raised for last char
 | 
				
			||||||
    while (!LL_USART_IsActiveFlag_TC(USART1));
 | 
					    while (!LL_USART_IsActiveFlag_TC(USART1));
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -11,6 +11,8 @@ void furi_hal_console_init();
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
void furi_hal_console_tx(const uint8_t* buffer, size_t buffer_size);
 | 
					void furi_hal_console_tx(const uint8_t* buffer, size_t buffer_size);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void furi_hal_console_tx_with_new_line(const uint8_t* buffer, size_t buffer_size);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * Printf-like plain uart interface
 | 
					 * Printf-like plain uart interface
 | 
				
			||||||
 * @warning Will not work in ISR context
 | 
					 * @warning Will not work in ISR context
 | 
				
			||||||
 | 
				
			|||||||
@ -367,12 +367,12 @@ typedef enum
 | 
				
			|||||||
/**
 | 
					/**
 | 
				
			||||||
 * When set to 1, the traces are enabled in the BLE services
 | 
					 * When set to 1, the traces are enabled in the BLE services
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
#define CFG_DEBUG_BLE_TRACE     1
 | 
					#define CFG_DEBUG_BLE_TRACE     0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * Enable or Disable traces in application
 | 
					 * Enable or Disable traces in application
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
#define CFG_DEBUG_APP_TRACE     1
 | 
					#define CFG_DEBUG_APP_TRACE     0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if (CFG_DEBUG_APP_TRACE != 0)
 | 
					#if (CFG_DEBUG_APP_TRACE != 0)
 | 
				
			||||||
#define APP_DBG_MSG                 PRINT_MESG_DBG
 | 
					#define APP_DBG_MSG                 PRINT_MESG_DBG
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										375
									
								
								firmware/targets/f7/ble-glue/app_debug.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										375
									
								
								firmware/targets/f7/ble-glue/app_debug.c
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,375 @@
 | 
				
			|||||||
 | 
					/* 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 "utilities_common.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "app_common.h"
 | 
				
			||||||
 | 
					#include "app_debug.h"
 | 
				
			||||||
 | 
					#include "shci.h"
 | 
				
			||||||
 | 
					#include "tl.h"
 | 
				
			||||||
 | 
					#include "dbg_trace.h"
 | 
				
			||||||
 | 
					#include <furi-hal.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     7
 | 
				
			||||||
 | 
					#define SYS_DBG_CFG1  (SHCI_C2_DEBUG_OPTIONS_IPCORE_LP | SHCI_C2_DEBUG_OPTIONS_CPU2_STOP_EN) 
 | 
				
			||||||
 | 
					/* USER CODE END PD */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* 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, SYS_DBG_CFG1, {0, 0}};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * 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_7, 1, 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 */
 | 
				
			||||||
 | 
					    { GPIOB, LL_GPIO_PIN_3, 1, 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_6, 1, 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_4, 1, 0},  /* PES_ACTIVITY - Set on Entry / Reset on Exit */
 | 
				
			||||||
 | 
					    { GPIOB, LL_GPIO_PIN_2, 1, 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  );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // GPIO_InitTypeDef  GPIO_InitStruct;
 | 
				
			||||||
 | 
					  // GPIO_InitStruct.Pull = GPIO_NOPULL;
 | 
				
			||||||
 | 
					  // GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
 | 
				
			||||||
 | 
					  // GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
 | 
				
			||||||
 | 
					  // GPIO_InitStruct.Pin = LL_GPIO_PIN_3;
 | 
				
			||||||
 | 
					  // HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
 | 
				
			||||||
 | 
					  // SHCI_C2_ExtpaConfig((uint32_t)GPIOC, LL_GPIO_PIN_3, EXT_PA_ENABLED_LOW, EXT_PA_ENABLED);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* 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 )
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void DbgOutputTraces(  uint8_t *p_data, uint16_t size, void (*cb)(void) )
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					  furi_hal_console_tx(p_data, size);
 | 
				
			||||||
 | 
					  cb();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
 | 
				
			||||||
							
								
								
									
										38
									
								
								firmware/targets/f7/ble-glue/app_debug.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								firmware/targets/f7/ble-glue/app_debug.h
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,38 @@
 | 
				
			|||||||
 | 
					/* USER CODE BEGIN Header */
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 ******************************************************************************
 | 
				
			||||||
 | 
					  * File Name          : app_debug.h
 | 
				
			||||||
 | 
					  * Description        : Header for app_debug.c module
 | 
				
			||||||
 | 
					 ******************************************************************************
 | 
				
			||||||
 | 
					  * @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 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* Define to prevent recursive inclusion -------------------------------------*/
 | 
				
			||||||
 | 
					#ifndef __APP_DEBUG_H
 | 
				
			||||||
 | 
					#define __APP_DEBUG_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef __cplusplus
 | 
				
			||||||
 | 
					extern "C" {
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    void APPD_Init( void );
 | 
				
			||||||
 | 
					    void APPD_EnableCPU2( void );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef __cplusplus
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif /*__APP_DEBUG_H */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
 | 
				
			||||||
@ -6,6 +6,7 @@
 | 
				
			|||||||
#include "tl.h"
 | 
					#include "tl.h"
 | 
				
			||||||
#include "cmsis_os.h"
 | 
					#include "cmsis_os.h"
 | 
				
			||||||
#include "shci_tl.h"
 | 
					#include "shci_tl.h"
 | 
				
			||||||
 | 
					#include "app_debug.h"
 | 
				
			||||||
#include <furi-hal.h>
 | 
					#include <furi-hal.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
extern RTC_HandleTypeDef hrtc;
 | 
					extern RTC_HandleTypeDef hrtc;
 | 
				
			||||||
@ -177,16 +178,3 @@ void shci_cmd_resp_wait(uint32_t timeout) {
 | 
				
			|||||||
  UNUSED(timeout);
 | 
					  UNUSED(timeout);
 | 
				
			||||||
  osSemaphoreAcquire( SemShciId, osWaitForever );
 | 
					  osSemaphoreAcquire( SemShciId, osWaitForever );
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					 | 
				
			||||||
#if(CFG_DEBUG_TRACE != 0)
 | 
					 | 
				
			||||||
void DbgOutputInit( void )
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
void DbgOutputTraces(  uint8_t *p_data, uint16_t size, void (*cb)(void) )
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
  furi_hal_console_tx(p_data, size);
 | 
					 | 
				
			||||||
  cb();
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
				
			|||||||
@ -25,13 +25,13 @@
 | 
				
			|||||||
 * Enable or Disable traces from BLE
 | 
					 * Enable or Disable traces from BLE
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define BLE_DBG_APP_EN             0
 | 
					#define BLE_DBG_APP_EN             1
 | 
				
			||||||
#define BLE_DBG_DIS_EN             0
 | 
					#define BLE_DBG_DIS_EN             1
 | 
				
			||||||
#define BLE_DBG_HRS_EN             0
 | 
					#define BLE_DBG_HRS_EN             1
 | 
				
			||||||
#define BLE_DBG_SVCCTL_EN          0
 | 
					#define BLE_DBG_SVCCTL_EN          1
 | 
				
			||||||
#define BLE_DBG_BLS_EN             0
 | 
					#define BLE_DBG_BLS_EN             1
 | 
				
			||||||
#define BLE_DBG_HTS_EN             0
 | 
					#define BLE_DBG_HTS_EN             1
 | 
				
			||||||
#define BLE_DBG_P2P_STM_EN         0
 | 
					#define BLE_DBG_P2P_STM_EN         1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * Macro definition
 | 
					 * Macro definition
 | 
				
			||||||
 | 
				
			|||||||
@ -33,26 +33,23 @@ extern "C" {
 | 
				
			|||||||
#include "app_conf.h"   /* required as some configuration used in dbg_trace.h are set there */
 | 
					#include "app_conf.h"   /* required as some configuration used in dbg_trace.h are set there */
 | 
				
			||||||
#include "dbg_trace.h"
 | 
					#include "dbg_trace.h"
 | 
				
			||||||
#include "hw_if.h"
 | 
					#include "hw_if.h"
 | 
				
			||||||
 | 
					#include <furi-hal.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * Enable or Disable traces
 | 
					 * Enable or Disable traces
 | 
				
			||||||
 * The raw data output is the hci binary packet format as specified by the BT specification *
 | 
					 * The raw data output is the hci binary packet format as specified by the BT specification *
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
#define TL_SHCI_CMD_DBG_EN      0   /* Reports System commands sent to CPU2 and the command response */
 | 
					#define TL_SHCI_CMD_DBG_EN      1   /* Reports System commands sent to CPU2 and the command response */
 | 
				
			||||||
#define TL_SHCI_CMD_DBG_RAW_EN  0   /* Reports raw data System commands sent to CPU2 and the command response */
 | 
					#define TL_SHCI_CMD_DBG_RAW_EN  0   /* Reports raw data System commands sent to CPU2 and the command response */
 | 
				
			||||||
#define TL_SHCI_EVT_DBG_EN      0   /* Reports System Asynchronous Events received from CPU2 */
 | 
					#define TL_SHCI_EVT_DBG_EN      1   /* Reports System Asynchronous Events received from CPU2 */
 | 
				
			||||||
#define TL_SHCI_EVT_DBG_RAW_EN  0   /* Reports raw data System Asynchronous Events received from CPU2 */
 | 
					#define TL_SHCI_EVT_DBG_RAW_EN  0   /* Reports raw data System Asynchronous Events received from CPU2 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define TL_HCI_CMD_DBG_EN       0   /* Reports BLE command sent to CPU2 and the command response */
 | 
					#define TL_HCI_CMD_DBG_EN       1   /* Reports BLE command sent to CPU2 and the command response */
 | 
				
			||||||
#define TL_HCI_CMD_DBG_RAW_EN   0   /* Reports raw data BLE command sent to CPU2 and the command response */
 | 
					#define TL_HCI_CMD_DBG_RAW_EN   0   /* Reports raw data BLE command sent to CPU2 and the command response */
 | 
				
			||||||
#define TL_HCI_EVT_DBG_EN       0   /* Reports BLE Asynchronous Events received from CPU2 */
 | 
					#define TL_HCI_EVT_DBG_EN       1   /* Reports BLE Asynchronous Events received from CPU2 */
 | 
				
			||||||
#define TL_HCI_EVT_DBG_RAW_EN   0   /* Reports raw data BLE Asynchronous Events received from CPU2 */
 | 
					#define TL_HCI_EVT_DBG_RAW_EN   0   /* Reports raw data BLE Asynchronous Events received from CPU2 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define TL_MM_DBG_EN            0   /* Reports the informations of the buffer released to CPU2 */
 | 
					#define TL_MM_DBG_EN            1   /* Reports the informations of the buffer released to CPU2 */
 | 
				
			||||||
 | 
					 | 
				
			||||||
/**
 | 
					 | 
				
			||||||
 * Macro definition
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * System Transport Layer
 | 
					 * System Transport Layer
 | 
				
			||||||
@ -66,7 +63,7 @@ extern "C" {
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if (TL_SHCI_CMD_DBG_RAW_EN != 0)
 | 
					#if (TL_SHCI_CMD_DBG_RAW_EN != 0)
 | 
				
			||||||
#define TL_SHCI_CMD_DBG_RAW(_PDATA_, _SIZE_)  furi_hal_console_tx(_PDATA_, _SIZE_)
 | 
					#define TL_SHCI_CMD_DBG_RAW(_PDATA_, _SIZE_)  furi_hal_console_tx_with_new_line(_PDATA_, _SIZE_)
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
#define TL_SHCI_CMD_DBG_RAW(...)
 | 
					#define TL_SHCI_CMD_DBG_RAW(...)
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@ -80,7 +77,7 @@ extern "C" {
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if (TL_SHCI_EVT_DBG_RAW_EN != 0)
 | 
					#if (TL_SHCI_EVT_DBG_RAW_EN != 0)
 | 
				
			||||||
#define TL_SHCI_EVT_DBG_RAW(_PDATA_, _SIZE_)  furi_hal_console_tx(_PDATA_, _SIZE_)
 | 
					#define TL_SHCI_EVT_DBG_RAW(_PDATA_, _SIZE_)  furi_hal_console_tx_with_new_line(_PDATA_, _SIZE_)
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
#define TL_SHCI_EVT_DBG_RAW(...)
 | 
					#define TL_SHCI_EVT_DBG_RAW(...)
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@ -97,7 +94,7 @@ extern "C" {
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if (TL_HCI_CMD_DBG_RAW_EN != 0)
 | 
					#if (TL_HCI_CMD_DBG_RAW_EN != 0)
 | 
				
			||||||
#define TL_HCI_CMD_DBG_RAW(_PDATA_, _SIZE_)  furi_hal_console_tx(_PDATA_, _SIZE_)
 | 
					#define TL_HCI_CMD_DBG_RAW(_PDATA_, _SIZE_)  furi_hal_console_tx_with_new_line(_PDATA_, _SIZE_)
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
#define TL_HCI_CMD_DBG_RAW(...)
 | 
					#define TL_HCI_CMD_DBG_RAW(...)
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@ -111,7 +108,7 @@ extern "C" {
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if (TL_HCI_EVT_DBG_RAW_EN != 0)
 | 
					#if (TL_HCI_EVT_DBG_RAW_EN != 0)
 | 
				
			||||||
#define TL_HCI_EVT_DBG_RAW(_PDATA_, _SIZE_)  furi_hal_console_tx(_PDATA_, _SIZE_)
 | 
					#define TL_HCI_EVT_DBG_RAW(_PDATA_, _SIZE_)  furi_hal_console_tx_with_new_line(_PDATA_, _SIZE_)
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
#define TL_HCI_EVT_DBG_RAW(...)
 | 
					#define TL_HCI_EVT_DBG_RAW(...)
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
				
			|||||||
@ -26,6 +26,9 @@ void furi_hal_bt_start_advertising() {
 | 
				
			|||||||
void furi_hal_bt_stop_advertising() {
 | 
					void furi_hal_bt_stop_advertising() {
 | 
				
			||||||
    if(furi_hal_bt_is_active()) {
 | 
					    if(furi_hal_bt_is_active()) {
 | 
				
			||||||
        gap_stop_advertising();
 | 
					        gap_stop_advertising();
 | 
				
			||||||
 | 
					        while(furi_hal_bt_is_active()) {
 | 
				
			||||||
 | 
					            osDelay(1);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -85,7 +88,9 @@ bool furi_hal_bt_lock_flash(bool erase_flag) {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    if(erase_flag) SHCI_C2_FLASH_EraseActivity(ERASE_ACTIVITY_ON);
 | 
					    if(erase_flag) SHCI_C2_FLASH_EraseActivity(ERASE_ACTIVITY_ON);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    while(LL_FLASH_IsActiveFlag_OperationSuspended()) {};
 | 
					    while(LL_FLASH_IsActiveFlag_OperationSuspended()) {
 | 
				
			||||||
 | 
					        osDelay(1);
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    __disable_irq();
 | 
					    __disable_irq();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -41,10 +41,7 @@ void furi_hal_console_init() {
 | 
				
			|||||||
    FURI_LOG_I("FuriHalConsole", "Init OK");
 | 
					    FURI_LOG_I("FuriHalConsole", "Init OK");
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void furi_hal_console_tx(const uint8_t* buffer, size_t buffer_size) {
 | 
					static void furi_hal_console_uart_tx(const uint8_t* buffer, size_t buffer_size) {
 | 
				
			||||||
    if (!furi_hal_console_alive)
 | 
					 | 
				
			||||||
        return;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    while(buffer_size > 0) {
 | 
					    while(buffer_size > 0) {
 | 
				
			||||||
        while (!LL_USART_IsActiveFlag_TXE(USART1));
 | 
					        while (!LL_USART_IsActiveFlag_TXE(USART1));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -53,8 +50,27 @@ void furi_hal_console_tx(const uint8_t* buffer, size_t buffer_size) {
 | 
				
			|||||||
        buffer++;
 | 
					        buffer++;
 | 
				
			||||||
        buffer_size--;
 | 
					        buffer_size--;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /* Wait for TC flag to be raised for last char */
 | 
					void furi_hal_console_tx(const uint8_t* buffer, size_t buffer_size) {
 | 
				
			||||||
 | 
					    if (!furi_hal_console_alive)
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Transmit data
 | 
				
			||||||
 | 
					    furi_hal_console_uart_tx(buffer, buffer_size);
 | 
				
			||||||
 | 
					    // Wait for TC flag to be raised for last char
 | 
				
			||||||
 | 
					    while (!LL_USART_IsActiveFlag_TC(USART1));
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void furi_hal_console_tx_with_new_line(const uint8_t* buffer, size_t buffer_size) {
 | 
				
			||||||
 | 
					    if (!furi_hal_console_alive)
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Transmit data
 | 
				
			||||||
 | 
					    furi_hal_console_uart_tx(buffer, buffer_size);
 | 
				
			||||||
 | 
					    // Transmit new line symbols
 | 
				
			||||||
 | 
					    furi_hal_console_uart_tx((const uint8_t*)"\r\n", 2);
 | 
				
			||||||
 | 
					    // Wait for TC flag to be raised for last char
 | 
				
			||||||
    while (!LL_USART_IsActiveFlag_TC(USART1));
 | 
					    while (!LL_USART_IsActiveFlag_TC(USART1));
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -11,6 +11,8 @@ void furi_hal_console_init();
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
void furi_hal_console_tx(const uint8_t* buffer, size_t buffer_size);
 | 
					void furi_hal_console_tx(const uint8_t* buffer, size_t buffer_size);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void furi_hal_console_tx_with_new_line(const uint8_t* buffer, size_t buffer_size);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * Printf-like plain uart interface
 | 
					 * Printf-like plain uart interface
 | 
				
			||||||
 * @warning Will not work in ISR context
 | 
					 * @warning Will not work in ISR context
 | 
				
			||||||
 | 
				
			|||||||
@ -1 +1 @@
 | 
				
			|||||||
Subproject commit 9e2dd9db125fa53e0ec59f807eb8a052ab922583
 | 
					Subproject commit 9c78e7f25506db18c35c6be51ab5aa14c7e0a622
 | 
				
			||||||
@ -17,7 +17,7 @@ MANIFEST_TEMPLATE = {
 | 
				
			|||||||
                "type": 1,
 | 
					                "type": 1,
 | 
				
			||||||
                "major": 1,
 | 
					                "major": 1,
 | 
				
			||||||
                "minor": 12,
 | 
					                "minor": 12,
 | 
				
			||||||
                "sub": 0,
 | 
					                "sub": 1,
 | 
				
			||||||
                "branch": 0,
 | 
					                "branch": 0,
 | 
				
			||||||
                "release": 7,
 | 
					                "release": 7,
 | 
				
			||||||
            },
 | 
					            },
 | 
				
			||||||
@ -44,14 +44,14 @@ class Copro:
 | 
				
			|||||||
            raise Exception(f'"{self.mcu_copro}" doesn\'t exists')
 | 
					            raise Exception(f'"{self.mcu_copro}" doesn\'t exists')
 | 
				
			||||||
        cube_manifest_file = os.path.join(self.cube_dir, "package.xml")
 | 
					        cube_manifest_file = os.path.join(self.cube_dir, "package.xml")
 | 
				
			||||||
        cube_manifest = ET.parse(cube_manifest_file)
 | 
					        cube_manifest = ET.parse(cube_manifest_file)
 | 
				
			||||||
        cube_version = cube_manifest.find("PackDescription")
 | 
					        cube_package = cube_manifest.find("PackDescription")
 | 
				
			||||||
        if not cube_version:
 | 
					        if not cube_package:
 | 
				
			||||||
            raise Exception(f"Unknown Cube manifest format")
 | 
					            raise Exception(f"Unknown Cube manifest format")
 | 
				
			||||||
        cube_version = cube_version.get("Release")
 | 
					        cube_version = cube_package.get("Patch") or cube_package.get("Release")
 | 
				
			||||||
        if not cube_version or not cube_version.startswith("FW.WB"):
 | 
					        if not cube_version or not cube_version.startswith("FW.WB"):
 | 
				
			||||||
            raise Exception(f"Incorrect Cube package or version info")
 | 
					            raise Exception(f"Incorrect Cube package or version info")
 | 
				
			||||||
        cube_version = cube_version.replace("FW.WB.", "", 1)
 | 
					        cube_version = cube_version.replace("FW.WB.", "", 1)
 | 
				
			||||||
        if cube_version != "1.12.0":
 | 
					        if cube_version != "1.12.1":
 | 
				
			||||||
            raise Exception(f"Unknonwn cube version")
 | 
					            raise Exception(f"Unknonwn cube version")
 | 
				
			||||||
        self.version = cube_version
 | 
					        self.version = cube_version
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user