MBIC_Bootloader.c 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518
  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. Download_Option = data[MBIC_PAYLOADSTART + 4];
  224. /*DOWNLOAD DELAY REQUEST*/
  225. data[MBIC_PAYLOADSTART + index++] = 3;
  226. /*DOWNLOAD Reserve*/
  227. data[MBIC_PAYLOADSTART + index++] = 0;
  228. data[MBIC_PAYLOADSTART + index++] = 0;
  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. if(bluecell_Currdatastatus.CPU_Current_Bank == HFR_BANK1){
  234. BankNum = HFR_BANK2;
  235. pdata = & bluecell_Currdatastatus.CPU_Bank2_Image_Version1;
  236. for(int i = 0; i < 41; i++)
  237. pdata[i] = 0xFF;
  238. }else{
  239. BankNum = HFR_BANK1;
  240. pdata = & bluecell_Currdatastatus.CPU_Bank1_Image_Version1;
  241. for(int i = 0; i < 41; i++)
  242. pdata[i] = 0xFF;
  243. }
  244. // MBIC_DataBankWrite(1);
  245. //if()
  246. // MBIC_DataErase_Func(bluecell_Currdatastatus.CPU_Bank_Select);
  247. // HAL_Delay(10);
  248. // printf("ccc\r\n");
  249. break;
  250. case MBIC_Download_DATA_REQ:
  251. TotalFrame = data[MBIC_PAYLOADSTART + 0] << 24
  252. |data[MBIC_PAYLOADSTART + 1] << 16
  253. |data[MBIC_PAYLOADSTART + 2] << 8
  254. |data[MBIC_PAYLOADSTART + 3] << 0;
  255. CurrFrame = data[MBIC_PAYLOADSTART + 4] << 24
  256. |data[MBIC_PAYLOADSTART + 5] << 16
  257. |data[MBIC_PAYLOADSTART + 6] << 8
  258. |data[MBIC_PAYLOADSTART + 7] << 0;
  259. // MBIC_FileDataCheck(data);
  260. cmd = MBIC_Download_DATA_RSP;
  261. /*TOTAL FRAME NUMBER*/
  262. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 0];
  263. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 1];
  264. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 2];
  265. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 3];
  266. /*Current Download Frame Number*/
  267. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 4];
  268. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 5];
  269. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 6];
  270. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 7];
  271. Curr_Download_DataIndex = data[MBIC_PAYLOADSTART + 4] << 24;
  272. Curr_Download_DataIndex += data[MBIC_PAYLOADSTART + 5] << 16;
  273. Curr_Download_DataIndex += data[MBIC_PAYLOADSTART + 6] << 8;
  274. Curr_Download_DataIndex += data[MBIC_PAYLOADSTART + 7];
  275. /*DOWNLOAD Reserve*/
  276. data[MBIC_PAYLOADSTART + index++] = 0;
  277. data[MBIC_PAYLOADSTART + index++] = 0;
  278. data[MBIC_PAYLOADSTART + index++] = 0;
  279. data[MBIC_PAYLOADSTART + index++] = 0;
  280. #if 0 // PYJ.2020.06.24_BEGIN --
  281. for(i = 0; i < Curr_Download_DataIndex - Prev_Download_DataIndex; i++){
  282. MBIC_DownLoadData[i] = ;
  283. // printf("%02x ",MBIC_DownLoadData[i]);
  284. }
  285. #endif // PYJ.2020.06.24_END --
  286. // printf("Data End\r\n");
  287. // Bank_Flash_write(data,FLASH_USER_BANK1_START_ADDR);
  288. if(prevFrame != CurrFrame){
  289. MBIC_APIFLASH_Func(&data[MBIC_PAYLOADSTART + 12],1024,BankNum);
  290. }else{
  291. if(MBIC_Address < FLASH_USER_BANK2_START_ADDR)
  292. MBIC_Address = FLASH_USER_BANK2_START_ADDR + (CurrFrame * 1024);
  293. else
  294. MBIC_Address = FLASH_USER_BANK1_START_ADDR + (CurrFrame * 1024);
  295. printf("Frame Retry \r\n");
  296. }
  297. #if 0 // PYJ.2020.06.29_BEGIN --
  298. if(BankNum == HFR_BANK1){
  299. printf("Bank1data[MBIC_BOOT_MARK] : %d \r\n",Bank1data[MBIC_BOOT_MARK]);
  300. }else{
  301. printf("Bank1data[MBIC_BOOT_MARK] : %d \r\n",Bank2data[MBIC_BOOT_MARK]);
  302. }
  303. #endif // PYJ.2020.06.29_END --
  304. // if(BankNum == HFR_BANK1)
  305. // Crcret = CRC16_Generate(&Bank1data[MBIC_BOOT_MARK], TotalFrame);
  306. // else
  307. // Crcret = CRC16_Generate(&Bank2data[MBIC_BOOT_MARK], TotalFrame);
  308. // printf("CurrFrame : %d ,FirmFile_Length : %d \r\n",CurrFrame,TotalFrame - 1);
  309. // printf("FILE CRC RET : %x \r\n",Crcret);
  310. // HAL_Delay(100);
  311. Prev_Download_DataIndex = Curr_Download_DataIndex + 1;
  312. prevFrame = CurrFrame;
  313. break;
  314. case MBIC_Download_Confirm_REQ:
  315. // printf("MBIC_Download_Confirm_REQ \r\n");
  316. cmd = MBIC_Download_Confirm_RSP;
  317. /*TOTAL FRAME NUMBER*/
  318. if(BankNum == HFR_BANK1){
  319. FirmFile_Length = (Bank1data[MBIC_BOOT_LENGTH + 0] << 24)
  320. | Bank1data[MBIC_BOOT_LENGTH + 1] << 16
  321. | Bank1data[MBIC_BOOT_LENGTH + 2] << 8
  322. | Bank1data[MBIC_BOOT_LENGTH + 3];
  323. Crcret = CRC16_Generate(&Bank1data[MBIC_BOOT_MARK], FirmFile_Length + 128);
  324. // printf("Bank 1 CRC Calc\r\n");
  325. }
  326. else {
  327. FirmFile_Length = (Bank2data[MBIC_BOOT_LENGTH + 0] << 24)
  328. | Bank2data[MBIC_BOOT_LENGTH + 1] << 16
  329. | Bank2data[MBIC_BOOT_LENGTH + 2] << 8
  330. | Bank2data[MBIC_BOOT_LENGTH + 3];
  331. Crcret = CRC16_Generate(&Bank2data[MBIC_BOOT_MARK], FirmFile_Length + 128);
  332. // printf("Bank 2 CRC Calc\r\n");
  333. }
  334. RecvCrc = data[MBIC_PAYLOADSTART + 4] << 8 | data[MBIC_PAYLOADSTART + 5];
  335. // printf("FirmFile_Length : %d Byte \r\n",((FirmFile_Length * 1024) + 128));
  336. // printf("FILE CRC RET : %x : Recv CRC : %x \r\n",Crcret,RecvCrc);
  337. if(RecvCrc != Crcret){
  338. CRCERR = true; // CRC ERR Occur
  339. }
  340. data[MBIC_PAYLOADSTART + index++] = ((Crcret & 0xFF00) >> 8);
  341. data[MBIC_PAYLOADSTART + index++] = ((Crcret & 0x00FF));
  342. #if 0 // PYJ.2020.06.29_BEGIN --
  343. if(Crcret != RecvCrc){
  344. CRCERR = true;
  345. printf("CRC ERROR : MBIC : %x / MDOC : %x \r\n",Crcret,RecvCrc);
  346. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 2] = 0;
  347. }else{
  348. CRCERR = false;
  349. printf("CRC Success : MBIC : %x / MDOC : %x \r\n",Crcret,RecvCrc);
  350. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 2] = 1;
  351. }
  352. #endif // PYJ.2020.06.29_END --
  353. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 3] = 1;
  354. /*DOWNLOAD OPTION*/
  355. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 4] = 0;
  356. data[MBIC_PAYLOADSTART + index++] = 0;
  357. data[MBIC_PAYLOADSTART + index++] = 0;
  358. data[MBIC_PAYLOADSTART + index++] = 0;
  359. // if(BankNum == HFR_BANK1){
  360. // bluecell_Currdatastatus.CPUVERSION1 = Bank1data[MBIC_BOOT_VERSION];
  361. // bluecell_Currdatastatus.CPUVERSION2 = Bank1data[MBIC_BOOT_VERSION + 1];
  362. // bluecell_Currdatastatus.CPUVERSION3 = Bank1data[MBIC_BOOT_VERSION + 2];
  363. // printf("Bank1data[MBIC_BOOT_VERSION] : %d \r\n",Bank1data[MBIC_BOOT_VERSION + 2]);
  364. // }else{
  365. // bluecell_Currdatastatus.CPUVERSION1 = Bank2data[MBIC_BOOT_VERSION];
  366. // bluecell_Currdatastatus.CPUVERSION2 = Bank2data[MBIC_BOOT_VERSION + 1];
  367. // bluecell_Currdatastatus.CPUVERSION3 = Bank2data[MBIC_BOOT_VERSION + 2];
  368. // printf("Bank2data[MBIC_BOOT_VERSION] : %d \r\n",Bank2data[MBIC_BOOT_VERSION + 2]);
  369. // }
  370. bluecell_Currdatastatus.CPU_Bank1_Image_Version1 = Bank1data[MBIC_BOOT_VERSION];
  371. bluecell_Currdatastatus.CPU_Bank1_Image_Version2 = Bank1data[MBIC_BOOT_VERSION + 1];
  372. bluecell_Currdatastatus.CPU_Bank1_Image_Version3 = Bank1data[MBIC_BOOT_VERSION + 2];
  373. bluecell_Currdatastatus.CPU_Bank2_Image_Version1 = Bank2data[MBIC_BOOT_VERSION];
  374. bluecell_Currdatastatus.CPU_Bank2_Image_Version2 = Bank2data[MBIC_BOOT_VERSION + 1];
  375. bluecell_Currdatastatus.CPU_Bank2_Image_Version3 = Bank2data[MBIC_BOOT_VERSION + 2];
  376. bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime1 = Bank1data[MBIC_BOOT_CREATION_TIME];
  377. bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime2 = Bank1data[MBIC_BOOT_CREATION_TIME + 1];
  378. bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime3 = Bank1data[MBIC_BOOT_CREATION_TIME + 2];
  379. bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime4 = Bank1data[MBIC_BOOT_CREATION_TIME + 3];
  380. bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime5 = Bank1data[MBIC_BOOT_CREATION_TIME + 4];
  381. bluecell_Currdatastatus.CPU_Bank1_Image_BuildTime6 = Bank1data[MBIC_BOOT_CREATION_TIME + 5];
  382. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime1 = Bank2data[MBIC_BOOT_CREATION_TIME];
  383. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime2 = Bank2data[MBIC_BOOT_CREATION_TIME + 1];
  384. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime3 = Bank2data[MBIC_BOOT_CREATION_TIME + 2];
  385. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime4 = Bank2data[MBIC_BOOT_CREATION_TIME + 3];
  386. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime5 = Bank2data[MBIC_BOOT_CREATION_TIME + 4];
  387. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime6 = Bank2data[MBIC_BOOT_CREATION_TIME + 5];
  388. tmpstr = &bluecell_Currdatastatus.CPU_Bank1_Image_Name;
  389. for(int i = 0 ; i< 32; i++){
  390. tmpstr[i] = Bank1data[MBIC_BOOT_FILENAME + i];
  391. }
  392. tmpstr = &bluecell_Currdatastatus.CPU_Bank2_Image_Name;
  393. for(int i = 0 ; i< 32; i++){
  394. tmpstr[i] = Bank2data[MBIC_BOOT_FILENAME + i];
  395. // printf("%x",tmpstr[i]);
  396. }
  397. // printf("Curr Version : %02x.%02x.%02x \r\n",bluecell_Currdatastatus.CPUVERSION1,bluecell_Currdatastatus.CPUVERSION2,bluecell_Currdatastatus.CPUVERSION3);
  398. // printf("Bank1data Version : %02x.%02x.%02x \r\n", Bank1data[MBIC_BOOT_VERSION + 0], Bank1data[MBIC_BOOT_VERSION + 1], Bank1data[MBIC_BOOT_VERSION + 2]);
  399. // printf("Bank2data Version : %02x.%02x.%02x \r\n", Bank2data[MBIC_BOOT_VERSION + 0], Bank2data[MBIC_BOOT_VERSION + 1], Bank2data[MBIC_BOOT_VERSION + 2]);
  400. break;
  401. case MBIC_Complete_Notice_REQ_REQ:
  402. // printf("MBIC_Complete_Notice_REQ_REQ \r\n");
  403. cmd = MBIC_Complete_Notice_RSP;
  404. if(CRCERR == false){
  405. data[MBIC_PAYLOADSTART + index++] = 1;
  406. printf("Crc Success \r\n");
  407. }else{
  408. data[MBIC_PAYLOADSTART + index++] = 0;
  409. printf("Crc Failed \r\n");
  410. }
  411. data[MBIC_PAYLOADSTART + index++] = 1;
  412. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime1 = Bank2data[MBIC_BOOT_CREATION_TIME + 0];
  413. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime2 = Bank2data[MBIC_BOOT_CREATION_TIME + 1];
  414. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime3 = Bank2data[MBIC_BOOT_CREATION_TIME + 2];
  415. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime4 = Bank2data[MBIC_BOOT_CREATION_TIME + 3];
  416. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime5 = Bank2data[MBIC_BOOT_CREATION_TIME + 4];
  417. bluecell_Currdatastatus.CPU_Bank2_Image_BuildTime6 = Bank2data[MBIC_BOOT_CREATION_TIME + 5];
  418. bluecell_Currdatastatus.CPU_Bank2_Image_Version1 = Bank2data[MBIC_BOOT_VERSION + 0];
  419. bluecell_Currdatastatus.CPU_Bank2_Image_Version2 = Bank2data[MBIC_BOOT_VERSION + 1];
  420. bluecell_Currdatastatus.CPU_Bank2_Image_Version3 = Bank2data[MBIC_BOOT_VERSION + 2];
  421. // if(BankNum == HFR_BANK1){
  422. // bluecell_Currdatastatus.CPUVERSION1 = Bank1data[MBIC_BOOT_VERSION];
  423. // bluecell_Currdatastatus.CPUVERSION2 = Bank1data[MBIC_BOOT_VERSION + 1];
  424. // bluecell_Currdatastatus.CPUVERSION3 = Bank1data[MBIC_BOOT_VERSION + 2];
  425. // printf("Bank1data[MBIC_BOOT_VERSION] : %d \r\n",Bank1data[MBIC_BOOT_VERSION]);
  426. // }else{
  427. // bluecell_Currdatastatus.CPUVERSION1 = Bank2data[MBIC_BOOT_VERSION];
  428. // bluecell_Currdatastatus.CPUVERSION2 = Bank2data[MBIC_BOOT_VERSION + 1];
  429. // bluecell_Currdatastatus.CPUVERSION3 = Bank2data[MBIC_BOOT_VERSION + 2];
  430. //
  431. // printf("Bank1data[MBIC_BOOT_VERSION] : %d \r\n",Bank2data[MBIC_BOOT_VERSION]);
  432. // }
  433. // printf("Curr Version : %02x.%02x.%02x \r\n",bluecell_Currdatastatus.CPUVERSION1,bluecell_Currdatastatus.CPUVERSION2,bluecell_Currdatastatus.CPUVERSION3);
  434. // printf("Bank1data Version : %02x.%02x.%02x \r\n", Bank1data[MBIC_BOOT_VERSION + 0], Bank1data[MBIC_BOOT_VERSION + 1], Bank1data[MBIC_BOOT_VERSION + 2]);
  435. // printf("Bank2data Version : %02x.%02x.%02x \r\n", Bank2data[MBIC_BOOT_VERSION + 0], Bank2data[MBIC_BOOT_VERSION + 1], Bank2data[MBIC_BOOT_VERSION + 2]);
  436. break;
  437. #if 0 // PYJ.2020.06.30_BEGIN --
  438. case MBIC_Reboot_Notice_REQ:
  439. printf("MBIC_Reboot_Notice_REQ\r\n");
  440. cmd = MBIC_Reboot_Notice_RSP;
  441. /*TOTAL FRAME NUMBER*/
  442. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 0];
  443. data[MBIC_PAYLOADSTART + index++] = 0;
  444. /*DOWNLOAD OPTION*/
  445. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 2];
  446. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 3];
  447. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 4];
  448. break;
  449. #endif // PYJ.2020.06.30_END --
  450. default:
  451. return;
  452. }
  453. data[MBIC_CMD_0] = cmd;
  454. data = MBIC_HeaderMergeFunction(data,index); // reponse
  455. for(int i =0; i < 22 + 3 + index; i++){
  456. MBIC_Resp[i] = data[i];
  457. }
  458. DataLength = 22 + 3 + index;
  459. Crcret =CRC16_Generate(&data[MBIC_PAYLOADSTART], DataLength - 25);
  460. MBIC_Resp[(DataLength - 1) - 2] = (Crcret & 0xFF00) >> 8;
  461. MBIC_Resp[(DataLength - 1) - 1] = (Crcret & 0x00FF);
  462. Uart1_Data_Send(MBIC_Resp ,22 + 3 + index);
  463. MBIC_DataErase_Func(BankNum);
  464. }