From 2bede2036da5248acf023f8830ff92ff636f626d Mon Sep 17 00:00:00 2001 From: Zachary Crockett Date: Sun, 13 Apr 2014 04:55:42 -0500 Subject: [PATCH] Enable factory reset from software Requires bootloader change to actually be used --- SPARK_Firmware_Driver/inc/hw_config.h | 1 + SPARK_Firmware_Driver/src/hw_config.c | 17 ++++++++++++++--- 2 files changed, 15 insertions(+), 3 deletions(-) diff --git a/SPARK_Firmware_Driver/inc/hw_config.h b/SPARK_Firmware_Driver/inc/hw_config.h index f5a23ca..f1235c5 100644 --- a/SPARK_Firmware_Driver/inc/hw_config.h +++ b/SPARK_Firmware_Driver/inc/hw_config.h @@ -271,6 +271,7 @@ extern uint8_t LED_RGB_OVERRIDE; extern uint16_t CORE_FW_Version_SysFlag; extern uint16_t NVMEM_SPARK_Reset_SysFlag; extern uint16_t FLASH_OTA_Update_SysFlag; +extern uint16_t Factory_Reset_SysFlag; extern unsigned char wlan_rx_buffer[]; extern unsigned char wlan_tx_buffer[]; diff --git a/SPARK_Firmware_Driver/src/hw_config.c b/SPARK_Firmware_Driver/src/hw_config.c index 61764fa..f2cf99c 100644 --- a/SPARK_Firmware_Driver/src/hw_config.c +++ b/SPARK_Firmware_Driver/src/hw_config.c @@ -84,6 +84,7 @@ uint16_t CORE_FW_Version_SysFlag = 0xFFFF; uint16_t NVMEM_SPARK_Reset_SysFlag = 0xFFFF; uint16_t FLASH_OTA_Update_SysFlag = 0xFFFF; uint16_t OTA_FLASHED_Status_SysFlag = 0xFFFF; +uint16_t Factory_Reset_SysFlag = 0xFFFF; uint32_t WRPR_Value = 0xFFFFFFFF; uint32_t Flash_Pages_Protected = 0x0; @@ -1267,6 +1268,9 @@ void Load_SystemFlags(void) OTA_FLASHED_Status_SysFlag = (*(__IO uint16_t*) Address); Address += 2; + + Factory_Reset_SysFlag = (*(__IO uint16_t*) Address); + Address += 2; } void Save_SystemFlags(void) @@ -1307,6 +1311,11 @@ void Save_SystemFlags(void) while(FLASHStatus != FLASH_COMPLETE); Address += 2; + /* Program Factory_Reset_SysFlag */ + FLASHStatus = FLASH_ProgramHalfWord(Address, Factory_Reset_SysFlag); + while(FLASHStatus != FLASH_COMPLETE); + Address += 2; + /* Locks the FLASH Program Erase Controller */ FLASH_Lock(); } @@ -1611,10 +1620,12 @@ void FLASH_Read_CorePrivateKey(uint8_t *keyBuffer) void FACTORY_Flash_Reset(void) { - //Restore the Factory programmed application firmware from External Flash - FLASH_Restore(EXTERNAL_FLASH_FAC_ADDRESS); + // Restore the Factory programmed application firmware from External Flash + FLASH_Restore(EXTERNAL_FLASH_FAC_ADDRESS); - Finish_Update(); + Factory_Reset_SysFlag = 0xFFFF; + + Finish_Update(); } void BACKUP_Flash_Reset(void)