[FL-1952] BLE bonding fix (#805)
* furi-hal-bt: add mutex guarding core2 state * ble-glue: configure ble keys storage in SRAM2 * bt: add load and save ble keys in internal storage * bt: improve work furi_hal_bt API * bt: rework app_entry -> ble_glue * bt: apply changes for f6 target * desktop: remove furi check * ble-glue: comment NVM in SRAM2 configuration * FuriHal: fix flash controller state corruption, fix incorrect semaphore release, implement C1-C2 flash controller access according to spec. Gui: change logging level. * Libs: better lfs integration with lfs_config. * Ble: switch C2 NVM to RAM. * FuriHalCrypto: ensure that core2 is alive before sending shci commands * Ble: fix incorrect nvm buffer size Co-authored-by: あく <alleteam@gmail.com>
This commit is contained in:
@@ -1,11 +1,14 @@
|
||||
#include <furi-hal-flash.h>
|
||||
#include <furi-hal-bt.h>
|
||||
#include <stm32wbxx.h>
|
||||
#include <furi.h>
|
||||
|
||||
#include <stm32wbxx.h>
|
||||
|
||||
/* Free flash space borders, exported by linker */
|
||||
extern const void __free_flash_start__;
|
||||
|
||||
#define FURI_HAL_TAG "FuriHalFlash"
|
||||
#define FURI_HAL_CRITICAL_MSG "Critical flash operation fail"
|
||||
#define FURI_HAL_FLASH_READ_BLOCK 8
|
||||
#define FURI_HAL_FLASH_WRITE_BLOCK 8
|
||||
#define FURI_HAL_FLASH_PAGE_SIZE 4096
|
||||
@@ -57,33 +60,46 @@ size_t furi_hal_flash_get_free_page_count() {
|
||||
}
|
||||
|
||||
bool furi_hal_flash_erase(uint8_t page, uint8_t count) {
|
||||
if (!furi_hal_bt_lock_flash(true)) {
|
||||
return false;
|
||||
}
|
||||
furi_hal_bt_lock_flash(true);
|
||||
|
||||
FLASH_EraseInitTypeDef erase;
|
||||
erase.TypeErase = FLASH_TYPEERASE_PAGES;
|
||||
erase.Page = page;
|
||||
erase.NbPages = count;
|
||||
uint32_t error;
|
||||
HAL_StatusTypeDef status = HAL_FLASHEx_Erase(&erase, &error);
|
||||
|
||||
uint32_t error_page = 0;
|
||||
HAL_StatusTypeDef status = HAL_FLASHEx_Erase(&erase, &error_page);
|
||||
if (status != HAL_OK) {
|
||||
FURI_LOG_E(FURI_HAL_TAG, "Erase failed, ret: %d, page: %d", status, error_page);
|
||||
furi_crash(FURI_HAL_CRITICAL_MSG);
|
||||
}
|
||||
|
||||
furi_hal_bt_unlock_flash(true);
|
||||
return status == HAL_OK;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool furi_hal_flash_write_dword(size_t address, uint64_t data) {
|
||||
if (!furi_hal_bt_lock_flash(false)) {
|
||||
return false;
|
||||
}
|
||||
furi_hal_bt_lock_flash(false);
|
||||
|
||||
HAL_StatusTypeDef status = HAL_FLASH_Program(FLASH_TYPEPROGRAM_DOUBLEWORD, address, data);
|
||||
if (status != HAL_OK) {
|
||||
FURI_LOG_E(FURI_HAL_TAG, "Programming failed, ret: %d, address: %p", status, address);
|
||||
furi_crash(FURI_HAL_CRITICAL_MSG);
|
||||
}
|
||||
|
||||
furi_hal_bt_unlock_flash(false);
|
||||
return status == HAL_OK;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool furi_hal_flash_write_dword_from(size_t address, size_t source_address) {
|
||||
if (!furi_hal_bt_lock_flash(false)) {
|
||||
return false;
|
||||
}
|
||||
bool furi_hal_flash_write_row(size_t address, size_t source_address) {
|
||||
furi_hal_bt_lock_flash(false);
|
||||
|
||||
HAL_StatusTypeDef status = HAL_FLASH_Program(FLASH_TYPEPROGRAM_FAST, address, source_address);
|
||||
furi_check(status == HAL_OK);
|
||||
|
||||
furi_hal_bt_unlock_flash(false);
|
||||
return status == HAL_OK;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
Reference in New Issue
Block a user