MBIC_Bootloader.c 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536
  1. /*
  2. * MBIC_Bootloader.c
  3. *
  4. * Created on: 2020. 5. 18.
  5. * Author: parkyj
  6. */
  7. #include <stdio.h>
  8. #include <stdint.h>
  9. #include <stdbool.h>
  10. #include "main.h"
  11. #include "MBIC_Bootloader.h"
  12. #include "flash.h"
  13. #include "CRC.h"
  14. #include "uart.h"
  15. extern bool EraseInit;
  16. extern uint8_t Bank_Flash_write(uint8_t* data,uint32_t StartBankAddress);
  17. extern void MBIC_DataErase_Func(uint8_t bank_num);
  18. extern uint8_t MBIC_APIFLASH_Func(uint8_t* data,uint32_t size,uint8_t bank_num);
  19. extern void MBIC_DataBankWrite(uint8_t BankNum);
  20. BootLoaderDataCheck_st MBIC_FileDataCheck(uint8_t* data){
  21. BootLoaderDataCheck_st ret = {0,0,false};
  22. int8_t MBIC_Mark[9] = "JT-NRDAS ";
  23. int8_t MBIC_FileName1[] = "jhfs-mbic-nrdas-v";
  24. int8_t MBIC_FileName2[] = "v00.00.04.mbc";
  25. uint8_t MBIC_type = 0x20;
  26. uint8_t MBIC_FileType = 0x00;
  27. int i = 0;
  28. /***
  29. MARK Check
  30. ***/
  31. for(i = MARK_START_POSITION; i < TYPE_START_POSITION; i++){
  32. if(MBIC_Mark[i] != data[i]){
  33. printf("Data Diff \r\n");
  34. return ret;
  35. }else{
  36. printf("MARK Data Success \r\n");
  37. }
  38. }
  39. /***
  40. TYPE Check
  41. ***/
  42. for(i = TYPE_START_POSITION; i < FILE_TYPE_START_POSITION; i++){
  43. if(MBIC_type != data[i]){
  44. printf("Data Diff \r\n");
  45. return ret;
  46. }
  47. else
  48. printf("Type Data Success \r\n");
  49. }
  50. /***
  51. File Type Check
  52. ***/
  53. for(i = FILE_TYPE_START_POSITION; i < VERSION_START_POSITION; i++){
  54. if(MBIC_FileType != data[i]){
  55. printf("Data Diff \r\n");
  56. return ret;
  57. }
  58. else
  59. printf("File Type Data Success \r\n");
  60. }
  61. /***
  62. Version Check
  63. ***/
  64. for(i = VERSION_START_POSITION; i < FILENAME_START_POSITION; i++){
  65. printf("Version Data Success Version %x\r\n",data[i]);
  66. }
  67. /***
  68. File Name Check
  69. ***/
  70. for(i = FILENAME_START_POSITION; i < 30; i++){
  71. if(MBIC_FileName1[i-14] != data[i]){
  72. printf("Data Diff \r\n");
  73. printf("MBIC_FileName1[%d] : %x, data[%d] : %x\r\n",i - 14,MBIC_FileName1[i - 14],i,data[i]);
  74. return ret;
  75. }
  76. else
  77. printf("File Name Data Success %c\r\n",data[i]);
  78. }
  79. for(i = i; i < 43; i++){
  80. if(MBIC_FileName2[i-30] != data[i]){
  81. // printf("Data Diff %c\r\n",data[i]);
  82. // printf("MBIC_FileName2[%d] : %x, data[%d] : %x\r\n",i - 30,MBIC_FileName2[i - 30],i,data[i]);
  83. // return ret;
  84. }
  85. else
  86. printf("File Name Data Success %c\r\n",data[i]);
  87. }
  88. for(i = i; i < 49; i++){
  89. printf("Creation Success %x\r\n",data[i]);
  90. }
  91. for(i = i; i < 55; i++){
  92. printf("Creation Success data[%d] : %x\r\n",i,data[i]);
  93. }
  94. printf(" %d",data[i++]);
  95. printf(" -%02d",data[i++]);
  96. printf(" -%02d",data[i++]);
  97. printf(" -%02d",data[i++]);
  98. printf(" -%02d",data[i++]);
  99. printf(" -%02d\r\n",data[i++]);
  100. ret.Length = ((data[i++] << 8) & 0xFF00);
  101. ret.Length += (data[i++]);
  102. printf("data[%d] : %d\r\n",i - 1,ret.Length);
  103. printf("data[%d] : %d\r\n",i - 1,ret.Length);
  104. ret.Crcchk = ((data[i++] << 8) & 0xFF00);
  105. ret.Crcchk += (data[i++]);
  106. /*ONLY DATA CRC*/
  107. printf("CRC_H[%d] : %x\r\n",i,ret.Crcchk);
  108. printf("CRC_L[%d] : %x\r\n",i,ret.Crcchk);
  109. ret.FileChk = true;
  110. return ret;
  111. }
  112. /*
  113. MBIC Basic Header merge function
  114. Data : Response Data
  115. Length : Response Data Length
  116. CRCINDEX : CRC INDEX Number
  117. */
  118. uint8_t* MBIC_HeaderMergeFunction(uint8_t* data,uint16_t Length )
  119. {
  120. uint8_t ret[Length + 22 + 3];/*Data Length + Header Length + Tail Length*/
  121. uint16_t CRCData = CRC16_Generate(data,Length);
  122. /*CRC Create*/
  123. ret[MBIC_PAYLOADSTART + Length + 0] = ((CRCData & 0xFF00) >> 8);
  124. ret[MBIC_PAYLOADSTART + Length + 1] = ((CRCData & 0x00FF));
  125. ret[MBIC_PAYLOADSTART + Length + 2] = 0x03;
  126. /*Data Mark Create*/
  127. ret[MBIC_PREAMBLE_0] = MBIC_PREAMBLE0;
  128. ret[MBIC_PREAMBLE_1] = MBIC_PREAMBLE1;
  129. ret[MBIC_PREAMBLE_2] = MBIC_PREAMBLE2;
  130. ret[MBIC_PREAMBLE_3] = MBIC_PREAMBLE3;
  131. /*Data Subid Create*/
  132. ret[MBIC_SUBUID_0] = MBIC_SUBUID0;
  133. ret[MBIC_SUBUID_1] = MBIC_SUBUID1;
  134. ret[MBIC_RCODE_0] = data[MBIC_RCODE_0];
  135. ret[MBIC_TRID_0] = data[MBIC_TRID_0];
  136. ret[MBIC_TRID_1] = data[MBIC_TRID_1];
  137. ret[MBIC_SEQSUM_0] = data[MBIC_SEQSUM_0];
  138. ret[MBIC_TTL_0] = data[MBIC_TTL_0];
  139. ret[MBIC_TIME_0] = data[MBIC_TIME_0];
  140. ret[MBIC_TIME_1] = data[MBIC_TIME_1];
  141. ret[MBIC_TIME_2] = data[MBIC_TIME_2];
  142. ret[MBIC_TIME_3] = data[MBIC_TIME_3];
  143. ret[MBIC_TIME_4] = data[MBIC_TIME_4];
  144. ret[MBIC_TIME_5] = data[MBIC_TIME_5];
  145. ret[MBIC_ERRRESPONSE_0] = MBIC_ERRRESPONSE;
  146. ret[MBIC_CMD_0] = data[MBIC_CMD_0];
  147. ret[MBIC_LENGTH_0] = (Length & 0xFF00) >> 8;
  148. ret[MBIC_LENGTH_1] = Length & 0x00FF;
  149. ret[MBIC_HEADERCHECKSUM_0] = Chksum_Create(ret);
  150. /*Data Move*/
  151. // for(int i = 0; i < Length; i++){
  152. // data[MBIC_PAYLOADSTART + i] = data[i];
  153. // }
  154. /*
  155. MBIC Header Data input
  156. */
  157. for(int i = 0; i < MBIC_HEADER_SIZE; i++){
  158. if(i == MBIC_CMD_0) /*cmd exception*/
  159. continue;
  160. data[i] = ret[i];
  161. }
  162. /*
  163. MBIC Tail Data input
  164. */
  165. for(int i = MBIC_HEADER_SIZE + Length; i < MBIC_HEADER_SIZE + MBIC_TAIL_SIZE + Length; i++){
  166. data[i] = ret[i];
  167. }
  168. // for(uint16_t i = 0; i < Length; i ++)
  169. // ret[MBIC_PAYLOADSTART + i] = data[i];
  170. // for(int i = 0; i < Length; i++)
  171. // printf("MBIC : %x \r\n",data[i]);
  172. return data;
  173. }
  174. extern uint32_t MBIC_Address;
  175. uint8_t MBIC_Resp[2048];
  176. void MBIC_Bootloader_FirmwareUpdate(uint8_t* data){
  177. uint8_t MBIC_DownLoadData[0xFFFF];
  178. uint8_t cmd = data[MBIC_CMD_0];
  179. static uint8_t Download_Option = 0;
  180. uint16_t index = 0;
  181. static uint32_t Curr_Download_DataIndex = 0;
  182. static uint32_t Prev_Download_DataIndex = 0;
  183. uint32_t TotalFrame = 0;
  184. uint32_t CurrFrame = 0;
  185. static uint32_t prevFrame = 0xFF;
  186. uint8_t* tmpstr;
  187. uint16_t DataLength = 0;
  188. uint16_t Crcret = 0;
  189. uint16_t RecvCrc = 0;
  190. uint32_t i = 0 ;
  191. int32_t FirmFile_Length = 0;
  192. uint32_t CurrApiAddress = 0,Bank1Address=0,Bank2Address = 0;
  193. static uint8_t BankNum = 0;
  194. static bool CRCERR = false;
  195. CurrApiAddress = FLASH_MBICUSER_START_ADDR;
  196. Bank1Address = FLASH_USER_BANK1_START_ADDR;
  197. Bank2Address = FLASH_USER_BANK2_START_ADDR;
  198. uint8_t* Currdata = (uint8_t*)CurrApiAddress;
  199. uint8_t* Bank1data = (uint8_t*)Bank1Address;
  200. uint8_t* Bank2data = (uint8_t*)Bank2Address;
  201. uint8_t* pdata;
  202. // printf("RX");
  203. // for(int i = 0; i < 128; i++)
  204. // printf("%c",*data++);
  205. switch(cmd){
  206. case MBIC_Notice_REQ:
  207. EraseInit = false;
  208. CRCERR = false;
  209. Download_Option = 0;
  210. Curr_Download_DataIndex = 0;
  211. Prev_Download_DataIndex = 0;
  212. prevFrame = 0xFF;
  213. printf("MBIC DOWNLOAD REQUEST \r\n");
  214. cmd = MBIC_Notice_RSP;
  215. CRCERR = false;
  216. /*TOTAL FRAME NUMBER*/
  217. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 0];
  218. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 1];
  219. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 2];
  220. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 3];
  221. /*DOWNLOAD OPTION*/
  222. data[MBIC_PAYLOADSTART + index++] = 1;
  223. bluecell_Currdatastatus.MBIC_Download_Auto_Restart_Set
  224. = Download_Option
  225. = data[MBIC_PAYLOADSTART + 4];
  226. /*DOWNLOAD DELAY REQUEST*/
  227. data[MBIC_PAYLOADSTART + index++] = 3;
  228. /*DOWNLOAD Reserve*/
  229. data[MBIC_PAYLOADSTART + index++] = 0;
  230. data[MBIC_PAYLOADSTART + index++] = 0;
  231. data[MBIC_PAYLOADSTART + index++] = 0;
  232. data[MBIC_PAYLOADSTART + index++] = 0;
  233. data[MBIC_PAYLOADSTART + index++] = 0;
  234. data[MBIC_PAYLOADSTART + index++] = 0;
  235. if(bluecell_Currdatastatus.CPU_Current_Bank == HFR_BANK1){
  236. BankNum = HFR_BANK2;
  237. pdata = & bluecell_Currdatastatus.CPU_Bank2_Image_Version1;
  238. for(int i = 0; i < 41; i++)
  239. pdata[i] = 0xFF;
  240. }else{
  241. BankNum = HFR_BANK1;
  242. pdata = & bluecell_Currdatastatus.CPU_Bank1_Image_Version1;
  243. for(int i = 0; i < 41; i++)
  244. pdata[i] = 0xFF;
  245. }
  246. // MBIC_DataBankWrite(1);
  247. //if()
  248. // MBIC_DataErase_Func(bluecell_Currdatastatus.CPU_Bank_Select);
  249. // HAL_Delay(10);
  250. // printf("ccc\r\n");
  251. break;
  252. case MBIC_Download_DATA_REQ:
  253. TotalFrame = data[MBIC_PAYLOADSTART + 0] << 24
  254. |data[MBIC_PAYLOADSTART + 1] << 16
  255. |data[MBIC_PAYLOADSTART + 2] << 8
  256. |data[MBIC_PAYLOADSTART + 3] << 0;
  257. CurrFrame = data[MBIC_PAYLOADSTART + 4] << 24
  258. |data[MBIC_PAYLOADSTART + 5] << 16
  259. |data[MBIC_PAYLOADSTART + 6] << 8
  260. |data[MBIC_PAYLOADSTART + 7] << 0;
  261. // MBIC_FileDataCheck(data);
  262. cmd = MBIC_Download_DATA_RSP;
  263. /*TOTAL FRAME NUMBER*/
  264. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 0];
  265. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 1];
  266. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 2];
  267. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 3];
  268. /*Current Download Frame Number*/
  269. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 4];
  270. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 5];
  271. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 6];
  272. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 7];
  273. Curr_Download_DataIndex = data[MBIC_PAYLOADSTART + 4] << 24;
  274. Curr_Download_DataIndex += data[MBIC_PAYLOADSTART + 5] << 16;
  275. Curr_Download_DataIndex += data[MBIC_PAYLOADSTART + 6] << 8;
  276. Curr_Download_DataIndex += data[MBIC_PAYLOADSTART + 7];
  277. /*DOWNLOAD Reserve*/
  278. data[MBIC_PAYLOADSTART + index++] = 0;
  279. data[MBIC_PAYLOADSTART + index++] = 0;
  280. data[MBIC_PAYLOADSTART + index++] = 0;
  281. data[MBIC_PAYLOADSTART + index++] = 0;
  282. #if 0 // PYJ.2020.06.24_BEGIN --
  283. for(i = 0; i < Curr_Download_DataIndex - Prev_Download_DataIndex; i++){
  284. MBIC_DownLoadData[i] = ;
  285. // printf("%02x ",MBIC_DownLoadData[i]);
  286. }
  287. #endif // PYJ.2020.06.24_END --
  288. // printf("Data End\r\n");
  289. // Bank_Flash_write(data,FLASH_USER_BANK1_START_ADDR);
  290. if(prevFrame != CurrFrame){
  291. MBIC_APIFLASH_Func(&data[MBIC_PAYLOADSTART + 12],1024,BankNum);
  292. }else{
  293. if(MBIC_Address < FLASH_USER_BANK2_START_ADDR)
  294. MBIC_Address = FLASH_USER_BANK2_START_ADDR + (CurrFrame * 1024);
  295. else
  296. MBIC_Address = FLASH_USER_BANK1_START_ADDR + (CurrFrame * 1024);
  297. printf("Frame Retry \r\n");
  298. }
  299. #if 0 // PYJ.2020.06.29_BEGIN --
  300. if(BankNum == HFR_BANK1){
  301. printf("Bank1data[MBIC_BOOT_MARK] : %d \r\n",Bank1data[MBIC_BOOT_MARK]);
  302. }else{
  303. printf("Bank1data[MBIC_BOOT_MARK] : %d \r\n",Bank2data[MBIC_BOOT_MARK]);
  304. }
  305. #endif // PYJ.2020.06.29_END --
  306. // if(BankNum == HFR_BANK1)
  307. // Crcret = CRC16_Generate(&Bank1data[MBIC_BOOT_MARK], TotalFrame);
  308. // else
  309. // Crcret = CRC16_Generate(&Bank2data[MBIC_BOOT_MARK], TotalFrame);
  310. // printf("CurrFrame : %d ,FirmFile_Length : %d \r\n",CurrFrame,TotalFrame - 1);
  311. // printf("FILE CRC RET : %x \r\n",Crcret);
  312. // HAL_Delay(100);
  313. Prev_Download_DataIndex = Curr_Download_DataIndex + 1;
  314. prevFrame = CurrFrame;
  315. break;
  316. case MBIC_Download_Confirm_REQ:
  317. // printf("MBIC_Download_Confirm_REQ \r\n");
  318. cmd = MBIC_Download_Confirm_RSP;
  319. /*TOTAL FRAME NUMBER*/
  320. if(BankNum == HFR_BANK1){
  321. FirmFile_Length = (Bank1data[MBIC_BOOT_LENGTH + 0] << 24)
  322. | Bank1data[MBIC_BOOT_LENGTH + 1] << 16
  323. | Bank1data[MBIC_BOOT_LENGTH + 2] << 8
  324. | Bank1data[MBIC_BOOT_LENGTH + 3];
  325. Crcret = CRC16_Generate(&Bank1data[MBIC_BOOT_MARK], FirmFile_Length + 128);
  326. // printf("Bank 1 CRC Calc\r\n");
  327. }
  328. else {
  329. FirmFile_Length = (Bank2data[MBIC_BOOT_LENGTH + 0] << 24)
  330. | Bank2data[MBIC_BOOT_LENGTH + 1] << 16
  331. | Bank2data[MBIC_BOOT_LENGTH + 2] << 8
  332. | Bank2data[MBIC_BOOT_LENGTH + 3];
  333. Crcret = CRC16_Generate(&Bank2data[MBIC_BOOT_MARK], FirmFile_Length + 128);
  334. // printf("Bank 2 CRC Calc\r\n");
  335. }
  336. RecvCrc = data[MBIC_PAYLOADSTART + 4] << 8 | data[MBIC_PAYLOADSTART + 5];
  337. // printf("FirmFile_Length : %d Byte \r\n",((FirmFile_Length * 1024) + 128));
  338. // printf("FILE CRC RET : %x : Recv CRC : %x \r\n",Crcret,RecvCrc);
  339. if(RecvCrc != Crcret){
  340. CRCERR = true; // CRC ERR Occur
  341. }
  342. data[MBIC_PAYLOADSTART + index++] = ((Crcret & 0xFF00) >> 8);
  343. data[MBIC_PAYLOADSTART + index++] = ((Crcret & 0x00FF));
  344. #if 0 // PYJ.2020.06.29_BEGIN --
  345. if(Crcret != RecvCrc){
  346. CRCERR = true;
  347. printf("CRC ERROR : MBIC : %x / MDOC : %x \r\n",Crcret,RecvCrc);
  348. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 2] = 0;
  349. }else{
  350. CRCERR = false;
  351. printf("CRC Success : MBIC : %x / MDOC : %x \r\n",Crcret,RecvCrc);
  352. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 2] = 1;
  353. }
  354. #endif // PYJ.2020.06.29_END --
  355. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 3] = 1;
  356. /*DOWNLOAD OPTION*/
  357. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 4] = 0;
  358. data[MBIC_PAYLOADSTART + index++] = 0;
  359. data[MBIC_PAYLOADSTART + index++] = 0;
  360. data[MBIC_PAYLOADSTART + index++] = 0;
  361. // if(BankNum == HFR_BANK1){
  362. // bluecell_Currdatastatus.CPUVERSION1 = Bank1data[MBIC_BOOT_VERSION];
  363. // bluecell_Currdatastatus.CPUVERSION2 = Bank1data[MBIC_BOOT_VERSION + 1];
  364. // bluecell_Currdatastatus.CPUVERSION3 = Bank1data[MBIC_BOOT_VERSION + 2];
  365. // printf("Bank1data[MBIC_BOOT_VERSION] : %d \r\n",Bank1data[MBIC_BOOT_VERSION + 2]);
  366. // }else{
  367. // bluecell_Currdatastatus.CPUVERSION1 = Bank2data[MBIC_BOOT_VERSION];
  368. // bluecell_Currdatastatus.CPUVERSION2 = Bank2data[MBIC_BOOT_VERSION + 1];
  369. // bluecell_Currdatastatus.CPUVERSION3 = Bank2data[MBIC_BOOT_VERSION + 2];
  370. // printf("Bank2data[MBIC_BOOT_VERSION] : %d \r\n",Bank2data[MBIC_BOOT_VERSION + 2]);
  371. // }
  372. bluecell_Currdatastatus.CPU_Bank1_Image_Version1 = Bank1data[MBIC_BOOT_VERSION];
  373. bluecell_Currdatastatus.CPU_Bank1_Image_Version2 = Bank1data[MBIC_BOOT_VERSION + 1];
  374. bluecell_Currdatastatus.CPU_Bank1_Image_Version3 = Bank1data[MBIC_BOOT_VERSION + 2];
  375. bluecell_Currdatastatus.CPU_Bank2_Image_Version1 = Bank2data[MBIC_BOOT_VERSION];
  376. bluecell_Currdatastatus.CPU_Bank2_Image_Version2 = Bank2data[MBIC_BOOT_VERSION + 1];
  377. bluecell_Currdatastatus.CPU_Bank2_Image_Version3 = Bank2data[MBIC_BOOT_VERSION + 2];
  378. bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime1 = Bank1data[MBIC_BOOT_CREATION_TIME];
  379. bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime2 = Bank1data[MBIC_BOOT_CREATION_TIME + 1];
  380. bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime3 = Bank1data[MBIC_BOOT_CREATION_TIME + 2];
  381. bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime4 = Bank1data[MBIC_BOOT_CREATION_TIME + 3];
  382. bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime5 = Bank1data[MBIC_BOOT_CREATION_TIME + 4];
  383. bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime6 = Bank1data[MBIC_BOOT_CREATION_TIME + 5];
  384. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime1 = Bank2data[MBIC_BOOT_CREATION_TIME];
  385. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime2 = Bank2data[MBIC_BOOT_CREATION_TIME + 1];
  386. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime3 = Bank2data[MBIC_BOOT_CREATION_TIME + 2];
  387. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime4 = Bank2data[MBIC_BOOT_CREATION_TIME + 3];
  388. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime5 = Bank2data[MBIC_BOOT_CREATION_TIME + 4];
  389. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime6 = Bank2data[MBIC_BOOT_CREATION_TIME + 5];
  390. tmpstr = &bluecell_Currdatastatus.CPU_Bank1_Image_Name;
  391. for(int i = 0 ; i< 32; i++){
  392. tmpstr[i] = Bank1data[MBIC_BOOT_FILENAME + i];
  393. }
  394. tmpstr = &bluecell_Currdatastatus.CPU_Bank2_Image_Name;
  395. for(int i = 0 ; i< 32; i++){
  396. tmpstr[i] = Bank2data[MBIC_BOOT_FILENAME + i];
  397. // printf("%x",tmpstr[i]);
  398. }
  399. // printf("Curr Version : %02x.%02x.%02x \r\n",bluecell_Currdatastatus.CPUVERSION1,bluecell_Currdatastatus.CPUVERSION2,bluecell_Currdatastatus.CPUVERSION3);
  400. // printf("Bank1data Version : %02x.%02x.%02x \r\n", Bank1data[MBIC_BOOT_VERSION + 0], Bank1data[MBIC_BOOT_VERSION + 1], Bank1data[MBIC_BOOT_VERSION + 2]);
  401. // printf("Bank2data Version : %02x.%02x.%02x \r\n", Bank2data[MBIC_BOOT_VERSION + 0], Bank2data[MBIC_BOOT_VERSION + 1], Bank2data[MBIC_BOOT_VERSION + 2]);
  402. break;
  403. case MBIC_Complete_Notice_REQ_REQ:
  404. // printf("MBIC_Complete_Notice_REQ_REQ \r\n");
  405. cmd = MBIC_Complete_Notice_RSP;
  406. if(CRCERR == false){
  407. data[MBIC_PAYLOADSTART + index++] = 1;
  408. printf("Crc Success \r\n");
  409. }else{
  410. data[MBIC_PAYLOADSTART + index++] = 0;
  411. printf("Crc Failed \r\n");
  412. }
  413. data[MBIC_PAYLOADSTART + index++] = 1;
  414. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime1 = Bank2data[MBIC_BOOT_CREATION_TIME + 0];
  415. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime2 = Bank2data[MBIC_BOOT_CREATION_TIME + 1];
  416. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime3 = Bank2data[MBIC_BOOT_CREATION_TIME + 2];
  417. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime4 = Bank2data[MBIC_BOOT_CREATION_TIME + 3];
  418. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime5 = Bank2data[MBIC_BOOT_CREATION_TIME + 4];
  419. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime6 = Bank2data[MBIC_BOOT_CREATION_TIME + 5];
  420. bluecell_Currdatastatus.CPU_Bank2_Image_Version1 = Bank2data[MBIC_BOOT_VERSION + 0];
  421. bluecell_Currdatastatus.CPU_Bank2_Image_Version2 = Bank2data[MBIC_BOOT_VERSION + 1];
  422. bluecell_Currdatastatus.CPU_Bank2_Image_Version3 = Bank2data[MBIC_BOOT_VERSION + 2];
  423. if(bluecell_Currdatastatus.MBIC_Download_Auto_Restart_Set == true){
  424. printf("MBIC_Download_Auto_Restart_Set == true\r\n");
  425. if(bluecell_Currdatastatus.CPU_Current_Bank == HFR_BANK1_SEL){
  426. bluecell_Currdatastatus.CPU_Bank_Select = HFR_BANK2_SEL;
  427. printf("Download Bank sel = Bank 2 \r\n");
  428. }else{
  429. bluecell_Currdatastatus.CPU_Bank_Select = HFR_BANK1_SEL;
  430. printf("Download Bank sel = Bank 1 \r\n");
  431. }
  432. }
  433. // if(BankNum == HFR_BANK1){
  434. // bluecell_Currdatastatus.CPUVERSION1 = Bank1data[MBIC_BOOT_VERSION];
  435. // bluecell_Currdatastatus.CPUVERSION2 = Bank1data[MBIC_BOOT_VERSION + 1];
  436. // bluecell_Currdatastatus.CPUVERSION3 = Bank1data[MBIC_BOOT_VERSION + 2];
  437. // printf("Bank1data[MBIC_BOOT_VERSION] : %d \r\n",Bank1data[MBIC_BOOT_VERSION]);
  438. // }else{
  439. // bluecell_Currdatastatus.CPUVERSION1 = Bank2data[MBIC_BOOT_VERSION];
  440. // bluecell_Currdatastatus.CPUVERSION2 = Bank2data[MBIC_BOOT_VERSION + 1];
  441. // bluecell_Currdatastatus.CPUVERSION3 = Bank2data[MBIC_BOOT_VERSION + 2];
  442. //
  443. // printf("Bank1data[MBIC_BOOT_VERSION] : %d \r\n",Bank2data[MBIC_BOOT_VERSION]);
  444. // }
  445. // printf("Curr Version : %02x.%02x.%02x \r\n",bluecell_Currdatastatus.CPUVERSION1,bluecell_Currdatastatus.CPUVERSION2,bluecell_Currdatastatus.CPUVERSION3);
  446. // printf("Bank1data Version : %02x.%02x.%02x \r\n", Bank1data[MBIC_BOOT_VERSION + 0], Bank1data[MBIC_BOOT_VERSION + 1], Bank1data[MBIC_BOOT_VERSION + 2]);
  447. // printf("Bank2data Version : %02x.%02x.%02x \r\n", Bank2data[MBIC_BOOT_VERSION + 0], Bank2data[MBIC_BOOT_VERSION + 1], Bank2data[MBIC_BOOT_VERSION + 2]);
  448. break;
  449. #if 0 // PYJ.2020.06.30_BEGIN --
  450. case MBIC_Reboot_Notice_REQ:
  451. printf("MBIC_Reboot_Notice_REQ\r\n");
  452. cmd = MBIC_Reboot_Notice_RSP;
  453. /*TOTAL FRAME NUMBER*/
  454. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 0];
  455. data[MBIC_PAYLOADSTART + index++] = 0;
  456. /*DOWNLOAD OPTION*/
  457. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 2];
  458. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 3];
  459. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 4];
  460. break;
  461. #endif // PYJ.2020.06.30_END --
  462. default:
  463. return;
  464. }
  465. data[MBIC_CMD_0] = cmd;
  466. data = MBIC_HeaderMergeFunction(data,index); // reponse
  467. for(int i =0; i < 22 + 3 + index; i++){
  468. MBIC_Resp[i] = data[i];
  469. }
  470. DataLength = 22 + 3 + index;
  471. Crcret =CRC16_Generate(&data[MBIC_PAYLOADSTART], DataLength - 25);
  472. MBIC_Resp[(DataLength - 1) - 2] = (Crcret & 0xFF00) >> 8;
  473. MBIC_Resp[(DataLength - 1) - 1] = (Crcret & 0x00FF);
  474. Uart1_Data_Send(MBIC_Resp ,22 + 3 + index);
  475. if( cmd == MBIC_Complete_Notice_RSP
  476. &&bluecell_Currdatastatus.MBIC_Download_Auto_Restart_Set == true){
  477. HAL_Delay(100);
  478. NVIC_SystemReset();
  479. }
  480. MBIC_DataErase_Func(BankNum);
  481. }