flash.c 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280
  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 < 16; i++ ){
  39. printf("%08x : %02X \n",Address ,*(uint8_t*)Address);
  40. Address++;
  41. }
  42. #if 0 // PYJ.2019.03.27_BEGIN --
  43. for(uint32_t i = 0; i < 13848; i++ ){
  44. printf("%08x : %02X \n",Address ,*(uint8_t*)Address);
  45. Address++;
  46. }
  47. Address = StartAddr;
  48. for(uint32_t i = 0; i < 13848; i++ ){
  49. printf("%02X ",*(uint8_t*)Address);
  50. Address++;
  51. }
  52. #endif // PYJ.2019.03.27_END --
  53. }
  54. #if 1 // PYJ.2020.05.20_BEGIN --
  55. uint8_t Flash_RGB_Data_Write(uint8_t* data){
  56. uint16_t Firmdata = 0;
  57. uint8_t ret = 0;
  58. for(int i = 0; i < data[bluecell_length] - 2; i+=2){
  59. Firmdata = ((data[(bluecell_length + 1) + i]) & 0x00FF);
  60. Firmdata += ((data[(bluecell_length + 1) + (i + 1)] << 8) & 0xFF00);
  61. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,Address , (uint16_t)Firmdata) != HAL_OK){
  62. printf("HAL NOT OK \n");
  63. ret = 1;
  64. }
  65. Address += 2;
  66. //if(!(i%FirmwareUpdateDelay))
  67. // HAL_Delay(1);
  68. }
  69. return ret;
  70. }
  71. uint8_t Flash_Data_Write(uint8_t* data){
  72. uint16_t Firmdata = 0;
  73. uint8_t ret = 0;
  74. static uint32_t Curr_Download_DataIndex = 0;
  75. static uint32_t Prev_Download_DataIndex = 0;
  76. Curr_Download_DataIndex = data[MBIC_PAYLOADSTART + 4] << 24;
  77. Curr_Download_DataIndex += data[MBIC_PAYLOADSTART + 5] << 16;
  78. Curr_Download_DataIndex += data[MBIC_PAYLOADSTART + 6] << 8;
  79. Curr_Download_DataIndex += data[MBIC_PAYLOADSTART + 7];
  80. // data[MBIC_PAYLOADSTART + 12 +i];
  81. for(int i= 0; i <= Curr_Download_DataIndex - Prev_Download_DataIndex+1; i+=2){
  82. Firmdata = ((data[MBIC_PAYLOADSTART + 12 +i]) & 0x00FF);
  83. Firmdata += ((data[MBIC_PAYLOADSTART + 12 +i + 1] << 8) & 0xFF00);
  84. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,UserAddress , (uint16_t)Firmdata) != HAL_OK){
  85. printf("HAL NOT OK \n");
  86. ret = 1;
  87. }
  88. UserAddress += 2;
  89. }
  90. Prev_Download_DataIndex = Curr_Download_DataIndex;
  91. return ret;
  92. }
  93. uint8_t Flash_Bank_Data_Write(uint8_t* data){
  94. uint16_t Firmdata = 0;
  95. uint16_t Length = 0;
  96. static uint32_t WriteIndex = 0;
  97. uint8_t ret = 0;
  98. for(int i = 0; i < Length; i+=2){
  99. Firmdata = ((data[WriteIndex++]) & 0x00FF);
  100. Firmdata += ((data[WriteIndex++] << 8) & 0xFF00);
  101. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,Address , (uint16_t)Firmdata) != HAL_OK){
  102. printf("HAL NOT OK \n");
  103. ret = 1;
  104. }
  105. Address += 2;
  106. //if(!(i%FirmwareUpdateDelay))
  107. // HAL_Delay(1);
  108. }
  109. return ret;
  110. }
  111. #if 0 // PYJ.2020.06.10_BEGIN --
  112. uint8_t Flash_Data_Write(uint8_t* data){
  113. uint64_t Firmdata = 0;
  114. uint8_t ret = 0;
  115. uint8_t Length = data[bluecell_length] - 2;
  116. uint8_t Length_remainder = Length % 8;
  117. uint8_t Length_ans = Length / 8;
  118. for(int i = 0; i < Length; i+=8){
  119. Firmdata = ((data[(bluecell_length + 1) + i]) & 0x00000000000000FF);
  120. Firmdata += ((data[(bluecell_length + 1) + (i + 1)] << 8) & 0x000000000000FF00);
  121. Firmdata += ((data[(bluecell_length + 1) + (i + 2)] << 16) & 0x0000000000FF0000);
  122. Firmdata += ((data[(bluecell_length + 1) + (i + 3)] << 24) & 0x00000000FF000000);
  123. Firmdata += ((data[(bluecell_length + 1) + (i + 4)] << 32) & 0x000000FF00000000);
  124. Firmdata += ((data[(bluecell_length + 1) + (i + 5)] << 40) & 0x0000FF0000000000);
  125. Firmdata += ((data[(bluecell_length + 1) + (i + 6)] << 48) & 0x00FF000000000000);
  126. Firmdata += ((data[(bluecell_length + 1) + (i + 7)] << 56) & 0xFF00000000000000);
  127. if(Length_remainder > 0 && Length_ans > i){
  128. for(int a = 0; a < Length_remainder; a += 2){
  129. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,Address , (uint16_t)Firmdata) != HAL_OK){
  130. printf("HAL NOT OK \n");
  131. ret = 1;
  132. }
  133. Address += 2;
  134. }
  135. }
  136. else{
  137. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_DOUBLEWORD,Address , (uint64_t)Firmdata) != HAL_OK){
  138. printf("HAL NOT OK \n");
  139. ret = 1;
  140. }
  141. Address += 8;
  142. }
  143. //if(!(i%FirmwareUpdateDelay))
  144. // HAL_Delay(1);
  145. }
  146. return ret;
  147. }
  148. #endif // PYJ.2020.06.10_END --
  149. uint8_t Flash_DataTest_Write(uint8_t* data){
  150. uint32_t Firmdata = 0;
  151. uint8_t ret = 0;
  152. uint8_t Length = data[bluecell_length] - 2;
  153. uint8_t Length_remainder = Length % 4;
  154. uint8_t Length_ans = Length / 4;
  155. for(int i = 0; i < data[bluecell_length] - 2; i+=4){
  156. if(Length_remainder > 0 && Length_ans > i){
  157. for(int a = 0; a < Length_remainder; a += 2){
  158. Firmdata = ((data[(bluecell_length + 1) + i]) & 0x00FF);
  159. Firmdata += ((data[(bluecell_length + 1) + (i + 1)] << 8) & 0xFF00);
  160. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,Address , (uint16_t)Firmdata) != HAL_OK){
  161. printf("HAL NOT OK \n");
  162. ret = 1;
  163. }
  164. Address += 2;
  165. }
  166. }
  167. else{
  168. Firmdata = ((data[(bluecell_length + 1) + i]) & 0x000000FF);
  169. Firmdata += ((data[(bluecell_length + 1) + (i + 1)] << 8) & 0x0000FF00);
  170. Firmdata += ((data[(bluecell_length + 1) + (i + 2)] << 16) & 0x00FF0000);
  171. Firmdata += ((data[(bluecell_length + 1) + (i + 3)] << 24) & 0xFF000000);
  172. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_WORD,Address , (uint32_t)Firmdata) != HAL_OK){
  173. printf("HAL NOT OK \n");
  174. ret = 1;
  175. }
  176. Address += 4;
  177. }
  178. //if(!(i%FirmwareUpdateDelay))
  179. // HAL_Delay(1);
  180. }
  181. return ret;
  182. }
  183. #endif // PYJ.2020.05.20_END --
  184. uint8_t Flash_write(uint8_t* data) // ?占쏙옙湲고븿?占쏙옙
  185. {
  186. /*Variable used for Erase procedure*/
  187. static FLASH_EraseInitTypeDef EraseInitStruct;
  188. static uint32_t PAGEError = 0;
  189. uint8_t ret = 0;
  190. /* Fill EraseInit structure*/
  191. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  192. EraseInitStruct.PageAddress = FLASH_USER_START_ADDR;
  193. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_START_ADDR) / FLASH_PAGE_SIZE;
  194. // __HAL_RCC_TIM6_CLK_DISABLE(); // 留ㅼ씤???占쏙옙癒몌옙?? ?占쏙옙占�??占쏙옙?占쏙옙?占쏙옙
  195. HAL_FLASH_Unlock(); // lock ??占�?
  196. if(flashinit == 0){
  197. flashinit= 1;
  198. //FLASH_PageErase(StartAddr);
  199. if (HAL_FLASHEx_Erase(&EraseInitStruct, &PAGEError) != HAL_OK){
  200. printf("Erase Failed \r\n");
  201. }
  202. }
  203. // FLASH_If_Erase();
  204. ret = Flash_RGB_Data_Write(&data[bluecell_stx]);
  205. // ret = Flash_DataTest_Write(&data[bluecell_stx]);
  206. HAL_FLASH_Lock(); // lock ?占쏙옙洹멸린
  207. // __HAL_RCC_TIM6_CLK_ENABLE(); // 留ㅼ씤???占쏙옙癒몌옙?? ?占쏙옙?占쏙옙?占쏙옙?占쏙옙?占쏙옙?占쏙옙
  208. return ret;
  209. }
  210. uint8_t Bank_Flash_write(uint8_t* data,uint32_t StartBankAddress) // ?占쏙옙湲고븿?占쏙옙
  211. {
  212. /*Variable used for Erase procedure*/
  213. static FLASH_EraseInitTypeDef EraseInitStruct;
  214. static uint32_t PAGEError = 0;
  215. uint8_t ret = 0;
  216. /* Fill EraseInit structure*/
  217. switch(StartBankAddress){
  218. case FLASH_USER_START_ADDR:
  219. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  220. EraseInitStruct.PageAddress = FLASH_USER_START_ADDR;
  221. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_START_ADDR) / FLASH_PAGE_SIZE;
  222. break;
  223. case FLASH_USER_BANK1_START_ADDR:
  224. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  225. EraseInitStruct.PageAddress = FLASH_USER_BANK1_START_ADDR;
  226. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_BANK1_START_ADDR) / FLASH_PAGE_SIZE;
  227. break;
  228. case FLASH_USER_BANK2_START_ADDR:
  229. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  230. EraseInitStruct.PageAddress = FLASH_USER_BANK2_START_ADDR;
  231. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_BANK2_START_ADDR) / FLASH_PAGE_SIZE;
  232. break;
  233. case FLASH_USER_TEMPBANK_START_ADDR:
  234. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  235. EraseInitStruct.PageAddress = FLASH_USER_TEMPBANK_START_ADDR;
  236. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_TEMPBANK_START_ADDR) / FLASH_PAGE_SIZE;
  237. break;
  238. }
  239. HAL_FLASH_Unlock(); // lock ??占�?
  240. if(flashinit == 0){
  241. flashinit= 1;
  242. UserAddress = EraseInitStruct.PageAddress;
  243. //FLASH_PageErase(StartAddr);
  244. if (HAL_FLASHEx_Erase(&EraseInitStruct, &PAGEError) != HAL_OK){
  245. printf("Erase Failed \r\n");
  246. }
  247. }
  248. ret = Flash_Data_Write(&data[MBIC_PREAMBLE_0]);
  249. HAL_FLASH_Lock(); // lock ?占쏙옙洹멸린
  250. return ret;
  251. }