MBIC_Bootloader.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411
  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 __IO 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_LENGTH_0] = (Length & 0xFF00) >> 8;
  147. ret[MBIC_LENGTH_1] = Length & 0x00FF;
  148. ret[MBIC_HEADERCHECKSUM_0] = Chksum_Create(ret);
  149. /*Data Move*/
  150. // for(int i = 0; i < Length; i++){
  151. // data[MBIC_PAYLOADSTART + i] = data[i];
  152. // }
  153. /*
  154. MBIC Header Data input
  155. */
  156. for(int i = 0; i < MBIC_HEADER_SIZE; i++){
  157. if(i == MBIC_CMD_0) /*cmd exception*/
  158. continue;
  159. data[i] = ret[i];
  160. }
  161. /*
  162. MBIC Tail Data input
  163. */
  164. for(int i = MBIC_HEADER_SIZE + Length; i < MBIC_HEADER_SIZE + MBIC_TAIL_SIZE + Length; i++){
  165. data[i] = ret[i];
  166. }
  167. // for(uint16_t i = 0; i < Length; i ++)
  168. // ret[MBIC_PAYLOADSTART + i] = data[i];
  169. // for(int i = 0; i < Length; i++)
  170. // printf("MBIC : %x \r\n",data[i]);
  171. return data;
  172. }
  173. extern uint32_t MBIC_Address;
  174. uint8_t MBIC_Resp[2048];
  175. void MBIC_Bootloader_FirmwareUpdate(uint8_t* data){
  176. uint8_t MBIC_DownLoadData[0xFFFF];
  177. uint8_t cmd = data[MBIC_CMD_0];
  178. static uint8_t Download_Option = 0;
  179. uint16_t index = 0;
  180. static uint32_t Curr_Download_DataIndex = 0;
  181. static uint32_t Prev_Download_DataIndex = 0;
  182. uint32_t TotalFrame = 0;
  183. uint32_t CurrFrame = 0;
  184. uint16_t DataLength = 0;
  185. uint16_t Crcret = 0;
  186. uint16_t RecvCrc = 0;
  187. uint32_t i = 0 ;
  188. uint32_t FirmFile_Length = 0;
  189. uint32_t CurrApiAddress = 0,Bank1Address=0,Bank2Address = 0;
  190. uint8_t BankNum = 0;
  191. static bool CRCERR = false;
  192. CurrApiAddress = FLASH_MBICUSER_START_ADDR;
  193. Bank1Address = FLASH_USER_BANK1_START_ADDR;
  194. Bank2Address = FLASH_USER_BANK2_START_ADDR;
  195. uint8_t* Currdata = (uint8_t*)CurrApiAddress;
  196. uint8_t* Bank1data = (uint8_t*)Bank1Address;
  197. uint8_t* Bank2data = (uint8_t*)Bank2Address;
  198. #if 0 // PYJ.2020.06.04_BEGIN --
  199. uint8_t dataTest[1024] = {
  200. 0x4A,0x54,0x2D,0x4E,0x52,0x44,0x41,0x53,0x20,0x20,0x00,0x00,
  201. 0x00,0x01,0x6A,0x68,0x66,0x73,0x2D,0x6D,0x62,0x69,0x63,0x2D,
  202. 0x6E,0x72,0x64,0x61,0x73,0x2D,0x76,0x30,0x30,0x2E,0x30,0x30,0x2E,
  203. 0x30,0x31,0x2E,0x6D,0x62,0x63,0x20,0x20,0x20,0x20,0x20,0x20,0x20,
  204. 0x20,0x20,0x20,0x20,0x20,0x14,0x06,0x03,0x10,0x1F,0xC4,0x3C,0x49,
  205. 0x42,0x98,0xE0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
  206. 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
  207. 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
  208. 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
  209. 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00
  210. };
  211. #endif // PYJ.2020.06.04_END --
  212. // printf("RX");
  213. // for(int i = 0; i < 128; i++)
  214. // printf("%c",*data++);
  215. switch(cmd){
  216. case MBIC_Notice_REQ:
  217. printf("MBIC DOWNLOAD REQUEST \r\n");
  218. cmd = MBIC_Notice_RSP;
  219. CRCERR = false;
  220. /*TOTAL FRAME NUMBER*/
  221. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 0];
  222. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 1];
  223. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 2];
  224. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 3];
  225. /*DOWNLOAD OPTION*/
  226. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 4];
  227. Download_Option = data[MBIC_PAYLOADSTART + 4];
  228. /*DOWNLOAD DELAY REQUEST*/
  229. data[MBIC_PAYLOADSTART + index++] = 3;
  230. /*DOWNLOAD Reserve*/
  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. data[MBIC_PAYLOADSTART + index++] = 0;
  236. data[MBIC_PAYLOADSTART + index++] = 0;
  237. // MBIC_DataBankWrite(1);
  238. //if()
  239. // MBIC_DataErase_Func(bluecell_Currdatastatus.CPU_Bank_Select);
  240. // HAL_Delay(10);
  241. // printf("ccc\r\n");
  242. break;
  243. case MBIC_Download_DATA_REQ:
  244. TotalFrame = data[MBIC_PAYLOADSTART + 0] << 24
  245. |data[MBIC_PAYLOADSTART + 1] << 16
  246. |data[MBIC_PAYLOADSTART + 2] << 8
  247. |data[MBIC_PAYLOADSTART + 3] << 0;
  248. CurrFrame = data[MBIC_PAYLOADSTART + 4] << 24
  249. |data[MBIC_PAYLOADSTART + 5] << 16
  250. |data[MBIC_PAYLOADSTART + 6] << 8
  251. |data[MBIC_PAYLOADSTART + 7] << 0;
  252. // MBIC_FileDataCheck(data);
  253. cmd = MBIC_Download_DATA_RSP;
  254. /*TOTAL FRAME NUMBER*/
  255. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 0];
  256. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 1];
  257. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 2];
  258. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 3];
  259. /*Current Download Frame Number*/
  260. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 4];
  261. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 5];
  262. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 6];
  263. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 7];
  264. Curr_Download_DataIndex = data[MBIC_PAYLOADSTART + 4] << 24;
  265. Curr_Download_DataIndex += data[MBIC_PAYLOADSTART + 5] << 16;
  266. Curr_Download_DataIndex += data[MBIC_PAYLOADSTART + 6] << 8;
  267. Curr_Download_DataIndex += data[MBIC_PAYLOADSTART + 7];
  268. /*DOWNLOAD Reserve*/
  269. data[MBIC_PAYLOADSTART + index++] = 0;
  270. data[MBIC_PAYLOADSTART + index++] = 0;
  271. data[MBIC_PAYLOADSTART + index++] = 0;
  272. data[MBIC_PAYLOADSTART + index++] = 0;
  273. #if 0 // PYJ.2020.06.24_BEGIN --
  274. for(i = 0; i < Curr_Download_DataIndex - Prev_Download_DataIndex; i++){
  275. MBIC_DownLoadData[i] = ;
  276. // printf("%02x ",MBIC_DownLoadData[i]);
  277. }
  278. #endif // PYJ.2020.06.24_END --
  279. // printf("Data End\r\n");
  280. // Bank_Flash_write(data,FLASH_USER_BANK1_START_ADDR);
  281. if(Currdata[MBIC_BOOT_VERSION + 3] == Bank1data[MBIC_BOOT_VERSION + 3]){
  282. BankNum = HFR_BANK2;
  283. }else{
  284. BankNum = HFR_BANK1;
  285. }
  286. MBIC_APIFLASH_Func(&data[MBIC_PAYLOADSTART + 12],Curr_Download_DataIndex - Prev_Download_DataIndex,BankNum);
  287. printf("Bank1data[MBIC_BOOT_MARK] : %d \r\n",Bank1data[MBIC_BOOT_MARK]);
  288. if(BankNum == HFR_BANK1)
  289. Crcret = CRC16_Generate(&Bank1data[MBIC_BOOT_MARK], TotalFrame);
  290. else
  291. Crcret = CRC16_Generate(&Bank2data[MBIC_BOOT_MARK], TotalFrame);
  292. printf("CurrFrame : %d ,FirmFile_Length : %x \r\n",CurrFrame,TotalFrame);
  293. printf("FILE CRC RET : %x \r\n",Crcret);
  294. // HAL_Delay(100);
  295. Prev_Download_DataIndex = Curr_Download_DataIndex + 1;
  296. break;
  297. case MBIC_Download_Confirm_REQ:
  298. EraseInit = true;
  299. cmd = MBIC_Download_Confirm_RSP;
  300. /*TOTAL FRAME NUMBER*/
  301. if(BankNum == HFR_BANK1){
  302. FirmFile_Length = (Bank1data[MBIC_BOOT_LENGTH + 0] << 24)
  303. | Bank1data[MBIC_BOOT_LENGTH + 1] << 16
  304. | Bank1data[MBIC_BOOT_LENGTH + 2] << 8
  305. | Bank1data[MBIC_BOOT_LENGTH + 3];
  306. Crcret = CRC16_Generate(&Bank1data[MBIC_BOOT_MARK], FirmFile_Length);
  307. }
  308. else if(BankNum == HFR_BANK2){
  309. FirmFile_Length = (Bank2data[MBIC_BOOT_LENGTH + 0] << 24)
  310. | Bank2data[MBIC_BOOT_LENGTH + 1] << 16
  311. | Bank2data[MBIC_BOOT_LENGTH + 2] << 8
  312. | Bank2data[MBIC_BOOT_LENGTH + 3];
  313. Crcret = CRC16_Generate(&Bank2data[MBIC_BOOT_MARK], FirmFile_Length);
  314. }
  315. RecvCrc = data[MBIC_PAYLOADSTART] << 8 | data[MBIC_PAYLOADSTART + 1];
  316. printf("FirmFile_Length : %x \r\n",FirmFile_Length);
  317. printf("FILE CRC RET : %x \r\n",Crcret);
  318. data[MBIC_PAYLOADSTART + index++] = ((Crcret & 0xFF00) >> 8);
  319. data[MBIC_PAYLOADSTART + index++] = ((Crcret & 0x00FF));
  320. if(Crcret != RecvCrc){
  321. CRCERR = true;
  322. printf("CRC ERROR : MBIC : %x / MDOC : %x \r\n",Crcret,RecvCrc);
  323. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 2] = 0;
  324. }else{
  325. CRCERR = false;
  326. printf("CRC Success : MBIC : %x / MDOC : %x \r\n",Crcret,RecvCrc);
  327. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 2] = 1;
  328. }
  329. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 3] = 0;
  330. /*DOWNLOAD OPTION*/
  331. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 4] = 0;
  332. data[MBIC_PAYLOADSTART + index++] = 0;
  333. data[MBIC_PAYLOADSTART + index++] = 0;
  334. data[MBIC_PAYLOADSTART + index++] = 0;
  335. break;
  336. case MBIC_Complete_Notice_REQ_REQ:
  337. cmd = MBIC_Complete_Notice_RSP;
  338. if(CRCERR == false){
  339. data[MBIC_PAYLOADSTART + index++] = 1;
  340. }else{
  341. data[MBIC_PAYLOADSTART + index++] = 0;
  342. }
  343. data[MBIC_PAYLOADSTART + index++] = 1;
  344. break;
  345. case MBIC_Reboot_Notice_REQ:
  346. cmd = MBIC_Reboot_Notice_RSP;
  347. /*TOTAL FRAME NUMBER*/
  348. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 0];
  349. data[MBIC_PAYLOADSTART + index++] = 0;
  350. /*DOWNLOAD OPTION*/
  351. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 2];
  352. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 3];
  353. data[MBIC_PAYLOADSTART + index++] = data[MBIC_PAYLOADSTART + 4];
  354. break;
  355. default:
  356. return;
  357. }
  358. data[MBIC_CMD_0] = cmd;
  359. data = MBIC_HeaderMergeFunction(data,index); // reponse
  360. for(int i =0; i < 22 + 3 + index; i++){
  361. MBIC_Resp[i] = data[i];
  362. }
  363. // HAL_UART_Transmit_DMA(&huart1, data,22 + 3 + index);
  364. DataLength = 22 + 3 + index;
  365. Crcret =CRC16_Generate(&data[MBIC_PAYLOADSTART], DataLength - 25);
  366. MBIC_Resp[(DataLength - 1) - 2] = (Crcret & 0xFF00) >> 8;
  367. MBIC_Resp[(DataLength - 1) - 1] = (Crcret & 0x00FF);
  368. Uart1_Data_Send(MBIC_Resp ,22 + 3 + index);
  369. }