- instead of CpuReset, called CpuStartUserProgram after a firmware update from SD-card to prevent update loop.

git-svn-id: https://svn.code.sf.net/p/openblt/code/trunk@49 5dc33758-31d5-4daf-9ae8-b24bf3d40d73
This commit is contained in:
Frank Voorburg 2013-06-12 08:21:53 +00:00
parent 0f8c23d786
commit 415306b324
1 changed files with 11 additions and 5 deletions

View File

@ -215,6 +215,7 @@ void FileTask(void)
#if (BOOT_FILE_LOGGING_ENABLE > 0) #if (BOOT_FILE_LOGGING_ENABLE > 0)
FileFirmwareUpdateLogHook("OK\n\r"); FileFirmwareUpdateLogHook("OK\n\r");
FileFirmwareUpdateLogHook("Starting the programming sequence\n\r"); FileFirmwareUpdateLogHook("Starting the programming sequence\n\r");
FileFirmwareUpdateLogHook("Parsing firmware file to obtain erase size...");
#endif #endif
/* prepare data objects for the erasing state */ /* prepare data objects for the erasing state */
eraseInfo.start_address = 0; eraseInfo.start_address = 0;
@ -232,7 +233,7 @@ void FileTask(void)
if (f_error(&fatFsObjects.file) > 0) if (f_error(&fatFsObjects.file) > 0)
{ {
#if (BOOT_FILE_LOGGING_ENABLE > 0) #if (BOOT_FILE_LOGGING_ENABLE > 0)
FileFirmwareUpdateLogHook("Reading line from file...ERROR\n\r"); FileFirmwareUpdateLogHook("ERROR\n\r");
#endif #endif
#if (BOOT_FILE_ERROR_HOOK_ENABLE > 0) #if (BOOT_FILE_ERROR_HOOK_ENABLE > 0)
FileFirmwareUpdateErrorHook(FILE_ERROR_CANNOT_READ_FROM_FILE); FileFirmwareUpdateErrorHook(FILE_ERROR_CANNOT_READ_FROM_FILE);
@ -251,7 +252,7 @@ void FileTask(void)
if (parse_result == ERROR_SREC_INVALID_CHECKSUM) if (parse_result == ERROR_SREC_INVALID_CHECKSUM)
{ {
#if (BOOT_FILE_LOGGING_ENABLE > 0) #if (BOOT_FILE_LOGGING_ENABLE > 0)
FileFirmwareUpdateLogHook("Invalid checksum found...ERROR\n\r"); FileFirmwareUpdateLogHook("ERROR\n\r");
#endif #endif
#if (BOOT_FILE_ERROR_HOOK_ENABLE > 0) #if (BOOT_FILE_ERROR_HOOK_ENABLE > 0)
FileFirmwareUpdateErrorHook(FILE_ERROR_INVALID_CHECKSUM_IN_FILE); FileFirmwareUpdateErrorHook(FILE_ERROR_INVALID_CHECKSUM_IN_FILE);
@ -290,7 +291,7 @@ void FileTask(void)
if (f_lseek(&fatFsObjects.file, 0) != FR_OK) if (f_lseek(&fatFsObjects.file, 0) != FR_OK)
{ {
#if (BOOT_FILE_LOGGING_ENABLE > 0) #if (BOOT_FILE_LOGGING_ENABLE > 0)
FileFirmwareUpdateLogHook("Failed to rewind file read pointer...ERROR\n\r"); FileFirmwareUpdateLogHook("ERROR\n\r");
#endif #endif
#if (BOOT_FILE_ERROR_HOOK_ENABLE > 0) #if (BOOT_FILE_ERROR_HOOK_ENABLE > 0)
FileFirmwareUpdateErrorHook(FILE_ERROR_REWINDING_FILE_READ_POINTER); FileFirmwareUpdateErrorHook(FILE_ERROR_REWINDING_FILE_READ_POINTER);
@ -302,6 +303,7 @@ void FileTask(void)
return; return;
} }
#if (BOOT_FILE_LOGGING_ENABLE > 0) #if (BOOT_FILE_LOGGING_ENABLE > 0)
FileFirmwareUpdateLogHook("OK\n\r");
FileFirmwareUpdateLogHook("Erasing "); FileFirmwareUpdateLogHook("Erasing ");
/* convert size to string */ /* convert size to string */
FileLibLongToIntString(eraseInfo.total_size, loggingStr); FileLibLongToIntString(eraseInfo.total_size, loggingStr);
@ -449,8 +451,12 @@ void FileTask(void)
/* inform application about update completed event via hook function */ /* inform application about update completed event via hook function */
FileFirmwareUpdateCompletedHook(); FileFirmwareUpdateCompletedHook();
#endif #endif
/* initiate reset */ /* attempt to start the user program now that programming is done. note that
CpuReset(); * a call to CpuReset() won't work correctly here, because if the same firmware
* file is still on the locally attached storage, it will just restart the
* firmware update again and again..
*/
CpuStartUserProgram();
} }
} }
} /*** end of FileTask ***/ } /*** end of FileTask ***/