flash.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333
  1. /*
  2. * flash.c
  3. *
  4. * Created on: 2019. 7. 15.
  5. * Author: parkyj
  6. */
  7. #include "flash.h"
  8. #include "MBIC_Bootloader.h"
  9. uint8_t flashinit = 0;
  10. uint32_t Address = FLASH_USER_START_ADDR;
  11. volatile static uint32_t UserAddress;
  12. typedef void (*fptr)(void);
  13. fptr jump_to_app;
  14. uint32_t jump_addr;
  15. void Jump_App(void){
  16. __HAL_RCC_TIM6_CLK_DISABLE(); // 留ㅼ씤???占쏙옙癒몌옙?? ?占쏙옙占�??占쏙옙?占쏙옙?占쏙옙
  17. printf("boot loader start\n"); //硫붿꽭占�? 異쒕젰
  18. jump_addr = *(__IO uint32_t*) (APPLICATION_ADDRESS + 4);
  19. jump_to_app = (fptr) jump_addr;
  20. /* init user app's sp */
  21. printf("jump!\n");
  22. __set_MSP(*(__IO uint32_t*) APPLICATION_ADDRESS);
  23. jump_to_app();
  24. }
  25. void FLASH_If_Init(void)
  26. {
  27. /* Unlock the Program memory */
  28. HAL_FLASH_Unlock();
  29. /* Clear all FLASH flags */
  30. __HAL_FLASH_CLEAR_FLAG(FLASH_FLAG_EOP | FLASH_FLAG_PGERR | FLASH_FLAG_WRPERR);
  31. /* Unlock the Program memory */
  32. HAL_FLASH_Lock();
  33. }
  34. void Flash_InitRead(void) // ?占쏙옙湲고븿?占쏙옙
  35. {
  36. uint32_t Address = 0;
  37. Address = FLASH_USER_START_ADDR;
  38. for(uint32_t i = 0; i < 0xC9BC; i++ ){
  39. // printf("%08x : %02X \n",Address ,*(uint8_t*)Address);
  40. printf("%02X ",*(uint8_t*)Address);
  41. Address++;
  42. }
  43. #if 0 // PYJ.2019.03.27_BEGIN --
  44. for(uint32_t i = 0; i < 13848; i++ ){
  45. printf("%08x : %02X \n",Address ,*(uint8_t*)Address);
  46. Address++;
  47. }
  48. Address = StartAddr;
  49. for(uint32_t i = 0; i < 13848; i++ ){
  50. printf("%02X ",*(uint8_t*)Address);
  51. Address++;
  52. }
  53. #endif // PYJ.2019.03.27_END --
  54. }
  55. #if 1 // PYJ.2020.05.20_BEGIN --
  56. uint8_t Flash_RGB_Data_Write(uint8_t* data){
  57. uint16_t Firmdata = 0;
  58. uint8_t ret = 0;
  59. for(int i = 0; i < data[bluecell_length] - 2; i+=2){
  60. Firmdata = ((data[(bluecell_length + 1) + i]) & 0x00FF);
  61. Firmdata += ((data[(bluecell_length + 1) + (i + 1)] << 8) & 0xFF00);
  62. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,Address , (uint16_t)Firmdata) != HAL_OK){
  63. printf("HAL NOT OK \n");
  64. ret = 1;
  65. }
  66. Address += 2;
  67. //if(!(i%FirmwareUpdateDelay))
  68. // HAL_Delay(1);
  69. }
  70. return ret;
  71. }
  72. /*
  73. */
  74. uint8_t Flash_Data_Write(uint8_t* data){
  75. uint16_t Firmdata = 0;
  76. uint8_t ret = 0;
  77. HAL_StatusTypeDef HAL_Ret = HAL_ERROR;
  78. static uint32_t Curr_Download_DataIndex = 0;
  79. static uint32_t Prev_Download_DataIndex = 0;
  80. Curr_Download_DataIndex = data[MBIC_PAYLOADSTART + 4] << 24;
  81. Curr_Download_DataIndex += data[MBIC_PAYLOADSTART + 5] << 16;
  82. Curr_Download_DataIndex += data[MBIC_PAYLOADSTART + 6] << 8;
  83. Curr_Download_DataIndex += data[MBIC_PAYLOADSTART + 7];
  84. #if 1 // PYJ.2020.06.16_BEGIN --
  85. for(int i = 0; i <= Curr_Download_DataIndex - Prev_Download_DataIndex; i += 2){
  86. Firmdata = ((data[MBIC_PAYLOADSTART + 12 +i]) & 0x00FF);
  87. Firmdata += ((data[MBIC_PAYLOADSTART + 12 +i + 1] << 8) & 0xFF00);
  88. HAL_Ret = HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,UserAddress , (uint16_t)Firmdata);
  89. if(HAL_Ret != HAL_OK){
  90. switch(ret) {
  91. case HAL_OK:
  92. break;
  93. case HAL_TIMEOUT:
  94. printf("HAL_FLASH_Program() timeout!\n");
  95. break;
  96. case HAL_ERROR:
  97. printf("HAL_FLASH_Program() error 0x%08x, see *hal_flash.h for bit definitions\n", HAL_FLASH_GetError());
  98. break;
  99. default:
  100. printf("HAL_FLASH_Program() returned unknown status %lu\n", ret);
  101. }
  102. ret = 1;
  103. }
  104. UserAddress += 2;
  105. }
  106. #else
  107. #endif // PYJ.2020.06.16_END --
  108. // data[MBIC_PAYLOADSTART + 12 +i];
  109. #if 0 // PYJ.2020.06.16_BEGIN --
  110. if(Curr_Download_DataIndex != 1023){
  111. for(int i= 0; i <= Curr_Download_DataIndex - Prev_Download_DataIndex+1; i+=2){
  112. Firmdata = ((data[MBIC_PAYLOADSTART + 12 +i]) & 0x00FF);
  113. Firmdata += ((data[MBIC_PAYLOADSTART + 12 +i + 1] << 8) & 0xFF00);
  114. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,UserAddress , (uint16_t)Firmdata) != HAL_OK){
  115. printf("HAL NOT OK \n");
  116. ret = 1;
  117. }
  118. UserAddress += 2;
  119. }
  120. }else{/*(Curr_Download_DataIndex == 1023)*/
  121. for(int i= 0; i <= 1024; i+=2){
  122. Firmdata = ((data[MBIC_PAYLOADSTART + 12 +i]) & 0x00FF);
  123. Firmdata += ((data[MBIC_PAYLOADSTART + 12 +i + 1] << 8) & 0xFF00);
  124. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,UserAddress , (uint16_t)Firmdata) != HAL_OK){
  125. printf("HAL NOT OK \n");
  126. ret = 1;
  127. }
  128. UserAddress += 2;
  129. }
  130. }
  131. #endif // PYJ.2020.06.16_END --
  132. // HAL_Delay(1);
  133. Prev_Download_DataIndex = Curr_Download_DataIndex + 1;
  134. return ret;
  135. }
  136. uint8_t Flash_Bank_Data_Write(uint8_t* data){
  137. uint16_t Firmdata = 0;
  138. uint16_t Length = 0;
  139. static uint32_t WriteIndex = 0;
  140. uint8_t ret = 0;
  141. for(int i = 0; i < Length; i+=2){
  142. Firmdata = ((data[WriteIndex++]) & 0x00FF);
  143. Firmdata += ((data[WriteIndex++] << 8) & 0xFF00);
  144. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,Address , (uint16_t)Firmdata) != HAL_OK){
  145. printf("HAL NOT OK \n");
  146. ret = 1;
  147. }
  148. Address += 2;
  149. //if(!(i%FirmwareUpdateDelay))
  150. // HAL_Delay(1);
  151. }
  152. return ret;
  153. }
  154. #if 0 // PYJ.2020.06.10_BEGIN --
  155. uint8_t Flash_Data_Write(uint8_t* data){
  156. uint64_t Firmdata = 0;
  157. uint8_t ret = 0;
  158. uint8_t Length = data[bluecell_length] - 2;
  159. uint8_t Length_remainder = Length % 8;
  160. uint8_t Length_ans = Length / 8;
  161. for(int i = 0; i < Length; i+=8){
  162. Firmdata = ((data[(bluecell_length + 1) + i]) & 0x00000000000000FF);
  163. Firmdata += ((data[(bluecell_length + 1) + (i + 1)] << 8) & 0x000000000000FF00);
  164. Firmdata += ((data[(bluecell_length + 1) + (i + 2)] << 16) & 0x0000000000FF0000);
  165. Firmdata += ((data[(bluecell_length + 1) + (i + 3)] << 24) & 0x00000000FF000000);
  166. Firmdata += ((data[(bluecell_length + 1) + (i + 4)] << 32) & 0x000000FF00000000);
  167. Firmdata += ((data[(bluecell_length + 1) + (i + 5)] << 40) & 0x0000FF0000000000);
  168. Firmdata += ((data[(bluecell_length + 1) + (i + 6)] << 48) & 0x00FF000000000000);
  169. Firmdata += ((data[(bluecell_length + 1) + (i + 7)] << 56) & 0xFF00000000000000);
  170. if(Length_remainder > 0 && Length_ans > i){
  171. for(int a = 0; a < Length_remainder; a += 2){
  172. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,Address , (uint16_t)Firmdata) != HAL_OK){
  173. printf("HAL NOT OK \n");
  174. ret = 1;
  175. }
  176. Address += 2;
  177. }
  178. }
  179. else{
  180. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_DOUBLEWORD,Address , (uint64_t)Firmdata) != HAL_OK){
  181. printf("HAL NOT OK \n");
  182. ret = 1;
  183. }
  184. Address += 8;
  185. }
  186. //if(!(i%FirmwareUpdateDelay))
  187. // HAL_Delay(1);
  188. }
  189. return ret;
  190. }
  191. #endif // PYJ.2020.06.10_END --
  192. uint8_t Flash_DataTest_Write(uint8_t* data){
  193. uint32_t Firmdata = 0;
  194. uint8_t ret = 0;
  195. uint8_t Length = data[bluecell_length] - 2;
  196. uint8_t Length_remainder = Length % 4;
  197. uint8_t Length_ans = Length / 4;
  198. for(int i = 0; i < data[bluecell_length] - 2; i+=4){
  199. if(Length_remainder > 0 && Length_ans > i){
  200. for(int a = 0; a < Length_remainder; a += 2){
  201. Firmdata = ((data[(bluecell_length + 1) + i]) & 0x00FF);
  202. Firmdata += ((data[(bluecell_length + 1) + (i + 1)] << 8) & 0xFF00);
  203. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,Address , (uint16_t)Firmdata) != HAL_OK){
  204. printf("HAL NOT OK \n");
  205. ret = 1;
  206. }
  207. Address += 2;
  208. }
  209. }
  210. else{
  211. Firmdata = ((data[(bluecell_length + 1) + i]) & 0x000000FF);
  212. Firmdata += ((data[(bluecell_length + 1) + (i + 1)] << 8) & 0x0000FF00);
  213. Firmdata += ((data[(bluecell_length + 1) + (i + 2)] << 16) & 0x00FF0000);
  214. Firmdata += ((data[(bluecell_length + 1) + (i + 3)] << 24) & 0xFF000000);
  215. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_WORD,Address , (uint32_t)Firmdata) != HAL_OK){
  216. printf("HAL NOT OK \n");
  217. ret = 1;
  218. }
  219. Address += 4;
  220. }
  221. //if(!(i%FirmwareUpdateDelay))
  222. // HAL_Delay(1);
  223. }
  224. return ret;
  225. }
  226. #endif // PYJ.2020.05.20_END --
  227. uint8_t Flash_write(uint8_t* data) // ?占쏙옙湲고븿?占쏙옙
  228. {
  229. /*Variable used for Erase procedure*/
  230. static FLASH_EraseInitTypeDef EraseInitStruct;
  231. static uint32_t PAGEError = 0;
  232. uint8_t ret = 0;
  233. /* Fill EraseInit structure*/
  234. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  235. EraseInitStruct.PageAddress = FLASH_USER_START_ADDR;
  236. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_START_ADDR) / FLASH_PAGE_SIZE;
  237. // __HAL_RCC_TIM6_CLK_DISABLE(); // 留ㅼ씤???占쏙옙癒몌옙?? ?占쏙옙占�??占쏙옙?占쏙옙?占쏙옙
  238. HAL_FLASH_Unlock(); // lock ??占�?
  239. if(flashinit == 0){
  240. flashinit= 1;
  241. //FLASH_PageErase(StartAddr);
  242. if (HAL_FLASHEx_Erase(&EraseInitStruct, &PAGEError) != HAL_OK){
  243. printf("Erase Failed \r\n");
  244. }
  245. }
  246. // FLASH_If_Erase();
  247. ret = Flash_RGB_Data_Write(&data[bluecell_stx]);
  248. // ret = Flash_DataTest_Write(&data[bluecell_stx]);
  249. HAL_FLASH_Lock(); // lock ?占쏙옙洹멸린
  250. // __HAL_RCC_TIM6_CLK_ENABLE(); // 留ㅼ씤???占쏙옙癒몌옙?? ?占쏙옙?占쏙옙?占쏙옙?占쏙옙?占쏙옙?占쏙옙
  251. return ret;
  252. }
  253. uint8_t Bank_Flash_write(uint8_t* data,uint32_t StartBankAddress) // ?占쏙옙湲고븿?占쏙옙
  254. {
  255. /*Variable used for Erase procedure*/
  256. static FLASH_EraseInitTypeDef EraseInitStruct;
  257. static uint32_t PAGEError = 0;
  258. uint8_t ret = 0;
  259. HAL_FLASH_Unlock(); // lock ??占�?
  260. if(flashinit == 0){
  261. /* Fill EraseInit structure*/
  262. switch(StartBankAddress){
  263. case FLASH_USER_START_ADDR:
  264. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  265. EraseInitStruct.PageAddress = FLASH_USER_START_ADDR;
  266. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_START_ADDR) / FLASH_PAGE_SIZE;
  267. break;
  268. case FLASH_USER_BANK1_START_ADDR:
  269. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  270. EraseInitStruct.PageAddress = FLASH_USER_BANK1_START_ADDR;
  271. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_BANK1_START_ADDR) / FLASH_PAGE_SIZE;
  272. break;
  273. case FLASH_USER_BANK2_START_ADDR:
  274. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  275. EraseInitStruct.PageAddress = FLASH_USER_BANK2_START_ADDR;
  276. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_BANK2_START_ADDR) / FLASH_PAGE_SIZE;
  277. break;
  278. case FLASH_USER_TEMPBANK_START_ADDR:
  279. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  280. EraseInitStruct.PageAddress = FLASH_USER_TEMPBANK_START_ADDR;
  281. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_TEMPBANK_START_ADDR) / FLASH_PAGE_SIZE;
  282. break;
  283. }
  284. flashinit= 1;
  285. UserAddress = EraseInitStruct.PageAddress;
  286. //FLASH_PageErase(StartAddr);
  287. if (HAL_FLASHEx_Erase(&EraseInitStruct, &PAGEError) != HAL_OK){
  288. printf("Erase Failed \r\n");
  289. }
  290. }
  291. ret = Flash_Data_Write(&data[MBIC_PREAMBLE_0]);
  292. HAL_FLASH_Lock(); // lock ?占쏙옙洹멸린
  293. return ret;
  294. }