|
@@ -14,7 +14,7 @@
|
14
|
14
|
#include "CRC.h"
|
15
|
15
|
#include "uart.h"
|
16
|
16
|
|
17
|
|
-extern __IO bool EraseInit;
|
|
17
|
+extern bool EraseInit;
|
18
|
18
|
|
19
|
19
|
extern uint8_t Bank_Flash_write(uint8_t* data,uint32_t StartBankAddress);
|
20
|
20
|
extern void MBIC_DataErase_Func(uint8_t bank_num);
|
|
@@ -211,14 +211,13 @@ void MBIC_Bootloader_FirmwareUpdate(uint8_t* data){
|
211
|
211
|
static uint32_t Prev_Download_DataIndex = 0;
|
212
|
212
|
uint32_t TotalFrame = 0;
|
213
|
213
|
uint32_t CurrFrame = 0;
|
214
|
|
- uint32_t PrevFrame = 0 ;
|
215
|
214
|
static uint32_t prevFrame = 0xFF;
|
216
|
|
-
|
|
215
|
+ uint8_t* tmpstr;
|
217
|
216
|
uint16_t DataLength = 0;
|
218
|
217
|
uint16_t Crcret = 0;
|
219
|
218
|
uint16_t RecvCrc = 0;
|
220
|
219
|
uint32_t i = 0 ;
|
221
|
|
- uint32_t FirmFile_Length = 0;
|
|
220
|
+ int32_t FirmFile_Length = 0;
|
222
|
221
|
uint32_t CurrApiAddress = 0,Bank1Address=0,Bank2Address = 0;
|
223
|
222
|
static uint8_t BankNum = 0;
|
224
|
223
|
static bool CRCERR = false;
|
|
@@ -249,14 +248,14 @@ void MBIC_Bootloader_FirmwareUpdate(uint8_t* data){
|
249
|
248
|
// printf("%c",*data++);
|
250
|
249
|
switch(cmd){
|
251
|
250
|
case MBIC_Notice_REQ:
|
|
251
|
+ EraseInit = false;
|
252
|
252
|
Download_Option = 0;
|
253
|
253
|
Curr_Download_DataIndex = 0;
|
254
|
254
|
Prev_Download_DataIndex = 0;
|
255
|
|
-
|
|
255
|
+ prevFrame = 0xFF;
|
256
|
256
|
printf("MBIC DOWNLOAD REQUEST \r\n");
|
257
|
257
|
cmd = MBIC_Notice_RSP;
|
258
|
258
|
CRCERR = false;
|
259
|
|
- EraseInit = false;
|
260
|
259
|
/*TOTAL FRAME NUMBER*/
|
261
|
260
|
data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 0];
|
262
|
261
|
data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 1];
|
|
@@ -274,7 +273,11 @@ void MBIC_Bootloader_FirmwareUpdate(uint8_t* data){
|
274
|
273
|
data[MBIC_PAYLOADSTART + index++] = 0;
|
275
|
274
|
data[MBIC_PAYLOADSTART + index++] = 0;
|
276
|
275
|
data[MBIC_PAYLOADSTART + index++] = 0;
|
277
|
|
-
|
|
276
|
+ if(bluecell_Currdatastatus.CPU_Current_Bank == HFR_BANK1){
|
|
277
|
+ BankNum = HFR_BANK2;
|
|
278
|
+ }else{
|
|
279
|
+ BankNum = HFR_BANK1;
|
|
280
|
+ }
|
278
|
281
|
// MBIC_DataBankWrite(1);
|
279
|
282
|
//if()
|
280
|
283
|
// MBIC_DataErase_Func(bluecell_Currdatastatus.CPU_Bank_Select);
|
|
@@ -319,18 +322,31 @@ void MBIC_Bootloader_FirmwareUpdate(uint8_t* data){
|
319
|
322
|
#endif // PYJ.2020.06.24_END --
|
320
|
323
|
// printf("Data End\r\n");
|
321
|
324
|
// Bank_Flash_write(data,FLASH_USER_BANK1_START_ADDR);
|
322
|
|
- if(Currdata[MBIC_BOOT_VERSION + 3] == Bank1data[MBIC_BOOT_VERSION + 3]){
|
323
|
|
- BankNum = HFR_BANK2;
|
|
325
|
+
|
|
326
|
+ if(prevFrame != CurrFrame){
|
|
327
|
+ MBIC_APIFLASH_Func(&data[MBIC_PAYLOADSTART + 12],1024,BankNum);
|
324
|
328
|
}else{
|
325
|
|
- BankNum = HFR_BANK1;
|
|
329
|
+ if(MBIC_Address < FLASH_USER_BANK2_START_ADDR)
|
|
330
|
+ MBIC_Address = FLASH_USER_BANK2_START_ADDR + (CurrFrame * 1024);
|
|
331
|
+ else
|
|
332
|
+ MBIC_Address = FLASH_USER_BANK1_START_ADDR + (CurrFrame * 1024);
|
|
333
|
+
|
|
334
|
+ printf("Frame Retry \r\n");
|
326
|
335
|
}
|
327
|
|
- MBIC_APIFLASH_Func(&data[MBIC_PAYLOADSTART + 12],1024,BankNum);
|
328
|
|
- printf("Bank1data[MBIC_BOOT_MARK] : %d \r\n",Bank2data[MBIC_BOOT_MARK]);
|
|
336
|
+#if 0 // PYJ.2020.06.29_BEGIN --
|
|
337
|
+ if(BankNum == HFR_BANK1){
|
|
338
|
+ printf("Bank1data[MBIC_BOOT_MARK] : %d \r\n",Bank1data[MBIC_BOOT_MARK]);
|
|
339
|
+ }else{
|
|
340
|
+
|
|
341
|
+ printf("Bank1data[MBIC_BOOT_MARK] : %d \r\n",Bank2data[MBIC_BOOT_MARK]);
|
|
342
|
+ }
|
|
343
|
+
|
|
344
|
+#endif // PYJ.2020.06.29_END --
|
329
|
345
|
// if(BankNum == HFR_BANK1)
|
330
|
346
|
// Crcret = CRC16_Generate(&Bank1data[MBIC_BOOT_MARK], TotalFrame);
|
331
|
347
|
// else
|
332
|
348
|
// Crcret = CRC16_Generate(&Bank2data[MBIC_BOOT_MARK], TotalFrame);
|
333
|
|
- printf("CurrFrame : %d ,FirmFile_Length : %d \r\n",CurrFrame,TotalFrame);
|
|
349
|
+ printf("CurrFrame : %d ,FirmFile_Length : %d \r\n",CurrFrame,TotalFrame - 1);
|
334
|
350
|
printf("FILE CRC RET : %x \r\n",Crcret);
|
335
|
351
|
|
336
|
352
|
// HAL_Delay(100);
|
|
@@ -339,14 +355,17 @@ void MBIC_Bootloader_FirmwareUpdate(uint8_t* data){
|
339
|
355
|
|
340
|
356
|
break;
|
341
|
357
|
case MBIC_Download_Confirm_REQ:
|
342
|
|
- EraseInit = true;
|
|
358
|
+
|
|
359
|
+ printf("MBIC_Download_Confirm_REQ \r\n");
|
343
|
360
|
cmd = MBIC_Download_Confirm_RSP;
|
344
|
361
|
/*TOTAL FRAME NUMBER*/
|
|
362
|
+
|
345
|
363
|
if(BankNum == HFR_BANK1){
|
346
|
364
|
FirmFile_Length = (Bank1data[MBIC_BOOT_LENGTH + 0] << 24)
|
347
|
365
|
| Bank1data[MBIC_BOOT_LENGTH + 1] << 16
|
348
|
366
|
| Bank1data[MBIC_BOOT_LENGTH + 2] << 8
|
349
|
367
|
| Bank1data[MBIC_BOOT_LENGTH + 3];
|
|
368
|
+ FirmFile_Length += 128;
|
350
|
369
|
Crcret = CRC16_Generate(&Bank1data[MBIC_BOOT_MARK], FirmFile_Length);
|
351
|
370
|
printf("Bank 1 CRC Calc\r\n");
|
352
|
371
|
}
|
|
@@ -354,13 +373,14 @@ void MBIC_Bootloader_FirmwareUpdate(uint8_t* data){
|
354
|
373
|
FirmFile_Length = (Bank2data[MBIC_BOOT_LENGTH + 0] << 24)
|
355
|
374
|
| Bank2data[MBIC_BOOT_LENGTH + 1] << 16
|
356
|
375
|
| Bank2data[MBIC_BOOT_LENGTH + 2] << 8
|
357
|
|
- | Bank2data[MBIC_BOOT_LENGTH + 3];
|
358
|
|
- Crcret = CRC16_Generate(&Bank2data[MBIC_BOOT_MARK], FirmFile_Length - 1);
|
|
376
|
+ | Bank2data[MBIC_BOOT_LENGTH + 3];
|
|
377
|
+ FirmFile_Length += 128;
|
|
378
|
+ Crcret = CRC16_Generate(&Bank2data[MBIC_BOOT_MARK], FirmFile_Length);
|
359
|
379
|
printf("Bank 2 CRC Calc\r\n");
|
360
|
380
|
}
|
361
|
381
|
RecvCrc = data[MBIC_PAYLOADSTART] << 8 | data[MBIC_PAYLOADSTART + 1];
|
362
|
382
|
|
363
|
|
- printf("FirmFile_Length : %x \r\n",FirmFile_Length);
|
|
383
|
+ printf("FirmFile_Length : %x \r\n",FirmFile_Length + 128);
|
364
|
384
|
printf("FILE CRC RET : %x \r\n",Crcret);
|
365
|
385
|
|
366
|
386
|
data[MBIC_PAYLOADSTART + index++] = ((Crcret & 0xFF00) >> 8);
|
|
@@ -383,18 +403,90 @@ void MBIC_Bootloader_FirmwareUpdate(uint8_t* data){
|
383
|
403
|
data[MBIC_PAYLOADSTART + index++] = 0;
|
384
|
404
|
data[MBIC_PAYLOADSTART + index++] = 0;
|
385
|
405
|
data[MBIC_PAYLOADSTART + index++] = 0;
|
|
406
|
+// if(BankNum == HFR_BANK1){
|
|
407
|
+// bluecell_Currdatastatus.CPUVERSION1 = Bank1data[MBIC_BOOT_VERSION];
|
|
408
|
+// bluecell_Currdatastatus.CPUVERSION2 = Bank1data[MBIC_BOOT_VERSION + 1];
|
|
409
|
+// bluecell_Currdatastatus.CPUVERSION3 = Bank1data[MBIC_BOOT_VERSION + 2];
|
|
410
|
+// printf("Bank1data[MBIC_BOOT_VERSION] : %d \r\n",Bank1data[MBIC_BOOT_VERSION + 2]);
|
|
411
|
+// }else{
|
|
412
|
+// bluecell_Currdatastatus.CPUVERSION1 = Bank2data[MBIC_BOOT_VERSION];
|
|
413
|
+// bluecell_Currdatastatus.CPUVERSION2 = Bank2data[MBIC_BOOT_VERSION + 1];
|
|
414
|
+// bluecell_Currdatastatus.CPUVERSION3 = Bank2data[MBIC_BOOT_VERSION + 2];
|
|
415
|
+// printf("Bank2data[MBIC_BOOT_VERSION] : %d \r\n",Bank2data[MBIC_BOOT_VERSION + 2]);
|
|
416
|
+// }
|
|
417
|
+ bluecell_Currdatastatus.CPU_Bank1_Image_Version1 = Bank1data[MBIC_BOOT_VERSION];
|
|
418
|
+ bluecell_Currdatastatus.CPU_Bank1_Image_Version2 = Bank1data[MBIC_BOOT_VERSION + 1];
|
|
419
|
+ bluecell_Currdatastatus.CPU_Bank1_Image_Version3 = Bank1data[MBIC_BOOT_VERSION + 2];
|
|
420
|
+
|
|
421
|
+ bluecell_Currdatastatus.CPU_Bank2_Image_Version1 = Bank2data[MBIC_BOOT_VERSION];
|
|
422
|
+ bluecell_Currdatastatus.CPU_Bank2_Image_Version2 = Bank2data[MBIC_BOOT_VERSION + 1];
|
|
423
|
+ bluecell_Currdatastatus.CPU_Bank2_Image_Version3 = Bank2data[MBIC_BOOT_VERSION + 2];
|
|
424
|
+
|
|
425
|
+ bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime1 = Bank1data[MBIC_BOOT_CREATION_TIME];
|
|
426
|
+ bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime2 = Bank1data[MBIC_BOOT_CREATION_TIME + 1];
|
|
427
|
+ bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime3 = Bank1data[MBIC_BOOT_CREATION_TIME + 2];
|
|
428
|
+ bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime4 = Bank1data[MBIC_BOOT_CREATION_TIME + 3];
|
|
429
|
+ bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime5 = Bank1data[MBIC_BOOT_CREATION_TIME + 4];
|
|
430
|
+ bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime6 = Bank1data[MBIC_BOOT_CREATION_TIME + 5];
|
386
|
431
|
|
|
432
|
+
|
|
433
|
+ bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime1 = Bank2data[MBIC_BOOT_CREATION_TIME];
|
|
434
|
+ bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime2 = Bank2data[MBIC_BOOT_CREATION_TIME + 1];
|
|
435
|
+ bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime3 = Bank2data[MBIC_BOOT_CREATION_TIME + 2];
|
|
436
|
+ bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime4 = Bank2data[MBIC_BOOT_CREATION_TIME + 3];
|
|
437
|
+ bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime5 = Bank2data[MBIC_BOOT_CREATION_TIME + 4];
|
|
438
|
+ bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime6 = Bank2data[MBIC_BOOT_CREATION_TIME + 5];
|
|
439
|
+ tmpstr = &bluecell_Currdatastatus.CPU_Bank1_Image_Name;
|
|
440
|
+ for(int i = 0 ; i< 41; i++){
|
|
441
|
+ if(i < 32)
|
|
442
|
+ tmpstr[i] = Bank1data[MBIC_BOOT_FILENAME + i];
|
|
443
|
+ else
|
|
444
|
+ tmpstr[i] = 0x20;
|
|
445
|
+ printf("%x",tmpstr[i]);
|
|
446
|
+ }
|
|
447
|
+ tmpstr = &bluecell_Currdatastatus.CPU_Bank2_Image_Name;
|
|
448
|
+ for(int i = 0 ; i< 41; i++){
|
|
449
|
+ if(i < 32)
|
|
450
|
+ tmpstr[i] = Bank2data[MBIC_BOOT_FILENAME + i];
|
|
451
|
+ else
|
|
452
|
+ tmpstr[i] = 0x20;
|
|
453
|
+
|
|
454
|
+ printf("%x",tmpstr[i]);
|
|
455
|
+ }
|
|
456
|
+ printf("Curr Version : %02x.%02x.%02x \r\n",bluecell_Currdatastatus.CPUVERSION1,bluecell_Currdatastatus.CPUVERSION2,bluecell_Currdatastatus.CPUVERSION3);
|
|
457
|
+ printf("Bank1data Version : %02x.%02x.%02x \r\n", Bank1data[MBIC_BOOT_VERSION + 0], Bank1data[MBIC_BOOT_VERSION + 1], Bank1data[MBIC_BOOT_VERSION + 2]);
|
|
458
|
+ printf("Bank2data Version : %02x.%02x.%02x \r\n", Bank2data[MBIC_BOOT_VERSION + 0], Bank2data[MBIC_BOOT_VERSION + 1], Bank2data[MBIC_BOOT_VERSION + 2]);
|
|
459
|
+
|
387
|
460
|
break;
|
388
|
461
|
case MBIC_Complete_Notice_REQ_REQ:
|
|
462
|
+ printf("MBIC_Complete_Notice_REQ_REQ \r\n");
|
389
|
463
|
cmd = MBIC_Complete_Notice_RSP;
|
390
|
464
|
if(CRCERR == false){
|
391
|
465
|
data[MBIC_PAYLOADSTART + index++] = 1;
|
392
|
466
|
}else{
|
393
|
467
|
data[MBIC_PAYLOADSTART + index++] = 0;
|
394
|
468
|
}
|
395
|
|
- data[MBIC_PAYLOADSTART + index++] = 1;
|
|
469
|
+ data[MBIC_PAYLOADSTART + index++] = 1;
|
|
470
|
+
|
|
471
|
+
|
|
472
|
+// if(BankNum == HFR_BANK1){
|
|
473
|
+// bluecell_Currdatastatus.CPUVERSION1 = Bank1data[MBIC_BOOT_VERSION];
|
|
474
|
+// bluecell_Currdatastatus.CPUVERSION2 = Bank1data[MBIC_BOOT_VERSION + 1];
|
|
475
|
+// bluecell_Currdatastatus.CPUVERSION3 = Bank1data[MBIC_BOOT_VERSION + 2];
|
|
476
|
+// printf("Bank1data[MBIC_BOOT_VERSION] : %d \r\n",Bank1data[MBIC_BOOT_VERSION]);
|
|
477
|
+// }else{
|
|
478
|
+// bluecell_Currdatastatus.CPUVERSION1 = Bank2data[MBIC_BOOT_VERSION];
|
|
479
|
+// bluecell_Currdatastatus.CPUVERSION2 = Bank2data[MBIC_BOOT_VERSION + 1];
|
|
480
|
+// bluecell_Currdatastatus.CPUVERSION3 = Bank2data[MBIC_BOOT_VERSION + 2];
|
|
481
|
+//
|
|
482
|
+// printf("Bank1data[MBIC_BOOT_VERSION] : %d \r\n",Bank2data[MBIC_BOOT_VERSION]);
|
|
483
|
+// }
|
|
484
|
+ printf("Curr Version : %02x.%02x.%02x \r\n",bluecell_Currdatastatus.CPUVERSION1,bluecell_Currdatastatus.CPUVERSION2,bluecell_Currdatastatus.CPUVERSION3);
|
|
485
|
+ printf("Bank1data Version : %02x.%02x.%02x \r\n", Bank1data[MBIC_BOOT_VERSION + 0], Bank1data[MBIC_BOOT_VERSION + 1], Bank1data[MBIC_BOOT_VERSION + 2]);
|
|
486
|
+ printf("Bank2data Version : %02x.%02x.%02x \r\n", Bank2data[MBIC_BOOT_VERSION + 0], Bank2data[MBIC_BOOT_VERSION + 1], Bank2data[MBIC_BOOT_VERSION + 2]);
|
396
|
487
|
break;
|
397
|
488
|
case MBIC_Reboot_Notice_REQ:
|
|
489
|
+ printf("MBIC_Reboot_Notice_REQ\r\n");
|
398
|
490
|
cmd = MBIC_Reboot_Notice_RSP;
|
399
|
491
|
/*TOTAL FRAME NUMBER*/
|
400
|
492
|
data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 0];
|