mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2024-12-24 03:33:08 +00:00
338fc3afea
* Updated stack to 1.17.0 * hal: ble: Fixed stack config * Bumped stack version in config * scripts: added validation of copro stack version in update bundles * Copro: update to 1.17.2 * FuriHal: adjust tick frequency for HSE as sys clk * FuriHal: adjust systick reload on sys clock change * Sync api and format sources * scripts: updated ob.data for newer stack * FuriHal: return core2 hse pll transition on deep sleep * FuriHal: cleanup ble glue * FuriHal: rework ble glue, allow shci_send in critical section * FuriHal: sync api symbols * FuriHal: cleanup BLE glue, remove unused garbage and duplicate declarations * FuriHal: BLE glue cleanup, 2nd iteration * FuriHal: hide tick drift reports under FURI_HAL_OS_DEBUG * Lib: sync stm32wb_copro with latest dev * FuriHal: ble-glue, slightly less editable device name and duplicate definition cleanup * FuriHal: update ble config options, enable some optimizations and ext adv * FuriHal: update clock switch method documentation * FuriHal: better SNBRSA bug workaround fix * FuriHal: complete comment about tick skew * FuriHal: proper condition in clock hsi2hse transition * FuriHal: move PLL start to hse2pll routine, fix lockup caused by core2 switching to HSE before us * FuriHal: explicit HSE start before switch * FuriHal: fix documentation and move flash latency change to later stage, remove duplicate LL_RCC_SetRFWKPClockSource call --------- Co-authored-by: hedger <hedger@nanode.su> Co-authored-by: hedger <hedger@users.noreply.github.com>
81 lines
4.4 KiB
C
81 lines
4.4 KiB
C
#pragma once
|
|
|
|
/******************************************************************************
|
|
* Semaphores
|
|
* THIS SHALL NO BE CHANGED AS THESE SEMAPHORES ARE USED AS WELL ON THE CM0+
|
|
*****************************************************************************/
|
|
/**
|
|
* Index of the semaphore used the prevent conflicts after standby sleep.
|
|
* Each CPUs takes this semaphore at standby wakeup until conflicting elements are restored.
|
|
*/
|
|
#define CFG_HW_PWR_STANDBY_SEMID 10
|
|
/**
|
|
* The CPU2 may be configured to store the Thread persistent data either in internal NVM storage on CPU2 or in
|
|
* SRAM2 buffer provided by the user application. This can be configured with the system command SHCI_C2_Config()
|
|
* When the CPU2 is requested to store persistent data in SRAM2, it can write data in this buffer at any time when needed.
|
|
* In order to read consistent data with the CPU1 from the SRAM2 buffer, the flow should be:
|
|
* + CPU1 takes CFG_HW_THREAD_NVM_SRAM_SEMID semaphore
|
|
* + CPU1 reads all persistent data from SRAM2 (most of the time, the goal is to write these data into an NVM managed by CPU1)
|
|
* + CPU1 releases CFG_HW_THREAD_NVM_SRAM_SEMID semaphore
|
|
* CFG_HW_THREAD_NVM_SRAM_SEMID semaphore makes sure CPU2 does not update the persistent data in SRAM2 at the same time CPU1 is reading them.
|
|
* There is no timing constraint on how long this semaphore can be kept.
|
|
*/
|
|
#define CFG_HW_THREAD_NVM_SRAM_SEMID 9
|
|
|
|
/**
|
|
* The CPU2 may be configured to store the BLE persistent data either in internal NVM storage on CPU2 or in
|
|
* SRAM2 buffer provided by the user application. This can be configured with the system command SHCI_C2_Config()
|
|
* When the CPU2 is requested to store persistent data in SRAM2, it can write data in this buffer at any time when needed.
|
|
* In order to read consistent data with the CPU1 from the SRAM2 buffer, the flow should be:
|
|
* + CPU1 takes CFG_HW_BLE_NVM_SRAM_SEMID semaphore
|
|
* + CPU1 reads all persistent data from SRAM2 (most of the time, the goal is to write these data into an NVM managed by CPU1)
|
|
* + CPU1 releases CFG_HW_BLE_NVM_SRAM_SEMID semaphore
|
|
* CFG_HW_BLE_NVM_SRAM_SEMID semaphore makes sure CPU2 does not update the persistent data in SRAM2 at the same time CPU1 is reading them.
|
|
* There is no timing constraint on how long this semaphore can be kept.
|
|
*/
|
|
#define CFG_HW_BLE_NVM_SRAM_SEMID 8
|
|
|
|
/**
|
|
* Index of the semaphore used by CPU2 to prevent the CPU1 to either write or erase data in flash
|
|
* The CPU1 shall not either write or erase in flash when this semaphore is taken by the CPU2
|
|
* When the CPU1 needs to either write or erase in flash, it shall first get the semaphore and release it just
|
|
* after writing a raw (64bits data) or erasing one sector.
|
|
* Once the Semaphore has been released, there shall be at least 1us before it can be taken again. This is required
|
|
* to give the opportunity to CPU2 to take it.
|
|
* On v1.4.0 and older CPU2 wireless firmware, this semaphore is unused and CPU2 is using PES bit.
|
|
* By default, CPU2 is using the PES bit to protect its timing. The CPU1 may request the CPU2 to use the semaphore
|
|
* instead of the PES bit by sending the system command SHCI_C2_SetFlashActivityControl()
|
|
*/
|
|
#define CFG_HW_BLOCK_FLASH_REQ_BY_CPU2_SEMID 7
|
|
|
|
/**
|
|
* Index of the semaphore used by CPU1 to prevent the CPU2 to either write or erase data in flash
|
|
* In order to protect its timing, the CPU1 may get this semaphore to prevent the CPU2 to either
|
|
* write or erase in flash (as this will stall both CPUs)
|
|
* The PES bit shall not be used as this may stall the CPU2 in some cases.
|
|
*/
|
|
#define CFG_HW_BLOCK_FLASH_REQ_BY_CPU1_SEMID 6
|
|
|
|
/**
|
|
* Index of the semaphore used to manage the CLK48 clock configuration
|
|
* When the USB is required, this semaphore shall be taken before configuring te CLK48 for USB
|
|
* and should be released after the application switch OFF the clock when the USB is not used anymore
|
|
* When using the RNG, it is good enough to use CFG_HW_RNG_SEMID to control CLK48.
|
|
* More details in AN5289
|
|
*/
|
|
#define CFG_HW_CLK48_CONFIG_SEMID 5
|
|
|
|
/* Index of the semaphore used to manage the entry Stop Mode procedure */
|
|
#define CFG_HW_ENTRY_STOP_MODE_SEMID 4
|
|
|
|
/* Index of the semaphore used to access the RCC */
|
|
#define CFG_HW_RCC_SEMID 3
|
|
|
|
/* Index of the semaphore used to access the FLASH */
|
|
#define CFG_HW_FLASH_SEMID 2
|
|
|
|
/* Index of the semaphore used to access the PKA */
|
|
#define CFG_HW_PKA_SEMID 1
|
|
|
|
/* Index of the semaphore used to access the RNG */
|
|
#define CFG_HW_RNG_SEMID 0
|