mirror of https://github.com/rusefi/openblt.git
- 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:
parent
0f8c23d786
commit
415306b324
|
@ -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 ***/
|
||||||
|
|
Loading…
Reference in New Issue