flash.c 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249
  1. /*
  2. * flash.c
  3. *
  4. * Created on: 2019. 7. 15.
  5. * Author: parkyj
  6. */
  7. #include "flash.h"
  8. uint8_t flashinit = 0;
  9. uint32_t Address = FLASH_USER_START_ADDR;
  10. typedef void (*fptr)(void);
  11. fptr jump_to_app;
  12. uint32_t jump_addr;
  13. void Jump_App(void){
  14. __HAL_RCC_TIM6_CLK_DISABLE(); // 留ㅼ씤???占쏙옙癒몌옙?? ?占쏙옙占�??占쏙옙?占쏙옙?占쏙옙
  15. printf("boot loader start\n"); //硫붿꽭占�? 異쒕젰
  16. jump_addr = *(__IO uint32_t*) (APPLICATION_ADDRESS + 4);
  17. jump_to_app = (fptr) jump_addr;
  18. /* init user app's sp */
  19. printf("jump!\n");
  20. __set_MSP(*(__IO uint32_t*) APPLICATION_ADDRESS);
  21. jump_to_app();
  22. }
  23. void FLASH_If_Init(void)
  24. {
  25. /* Unlock the Program memory */
  26. HAL_FLASH_Unlock();
  27. /* Clear all FLASH flags */
  28. __HAL_FLASH_CLEAR_FLAG(FLASH_FLAG_EOP | FLASH_FLAG_PGERR | FLASH_FLAG_WRPERR);
  29. /* Unlock the Program memory */
  30. HAL_FLASH_Lock();
  31. }
  32. void Flash_InitRead(void) // ?占쏙옙湲고븿?占쏙옙
  33. {
  34. uint32_t Address = 0;
  35. Address = FLASH_USER_START_ADDR;
  36. for(uint32_t i = 0; i < 16; i++ ){
  37. printf("%08x : %02X \n",Address ,*(uint8_t*)Address);
  38. Address++;
  39. }
  40. #if 0 // PYJ.2019.03.27_BEGIN --
  41. for(uint32_t i = 0; i < 13848; i++ ){
  42. printf("%08x : %02X \n",Address ,*(uint8_t*)Address);
  43. Address++;
  44. }
  45. Address = StartAddr;
  46. for(uint32_t i = 0; i < 13848; i++ ){
  47. printf("%02X ",*(uint8_t*)Address);
  48. Address++;
  49. }
  50. #endif // PYJ.2019.03.27_END --
  51. }
  52. #if 1 // PYJ.2020.05.20_BEGIN --
  53. uint8_t Flash_RGB_Data_Write(uint8_t* data){
  54. uint16_t Firmdata = 0;
  55. uint8_t ret = 0;
  56. for(int i = 0; i < data[bluecell_length] - 2; i+=2){
  57. Firmdata = ((data[(bluecell_length + 1) + i]) & 0x00FF);
  58. Firmdata += ((data[(bluecell_length + 1) + (i + 1)] << 8) & 0xFF00);
  59. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,Address , (uint16_t)Firmdata) != HAL_OK){
  60. printf("HAL NOT OK \n");
  61. ret = 1;
  62. }
  63. Address += 2;
  64. //if(!(i%FirmwareUpdateDelay))
  65. // HAL_Delay(1);
  66. }
  67. return ret;
  68. }
  69. uint8_t Flash_Bank_Data_Write(uint8_t* data){
  70. uint16_t Firmdata = 0;
  71. uint16_t Length = 0;
  72. static uint32_t WriteIndex = 0;
  73. uint8_t ret = 0;
  74. for(int i = 0; i < Length; i+=2){
  75. Firmdata = ((data[WriteIndex++]) & 0x00FF);
  76. Firmdata += ((data[WriteIndex++] << 8) & 0xFF00);
  77. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,Address , (uint16_t)Firmdata) != HAL_OK){
  78. printf("HAL NOT OK \n");
  79. ret = 1;
  80. }
  81. Address += 2;
  82. //if(!(i%FirmwareUpdateDelay))
  83. // HAL_Delay(1);
  84. }
  85. return ret;
  86. }
  87. uint8_t Flash_Data_Write(uint8_t* data){
  88. uint64_t Firmdata = 0;
  89. uint8_t ret = 0;
  90. uint8_t Length = data[bluecell_length] - 2;
  91. uint8_t Length_remainder = Length % 8;
  92. uint8_t Length_ans = Length / 8;
  93. for(int i = 0; i < Length; i+=8){
  94. Firmdata = ((data[(bluecell_length + 1) + i]) & 0x00000000000000FF);
  95. Firmdata += ((data[(bluecell_length + 1) + (i + 1)] << 8) & 0x000000000000FF00);
  96. Firmdata += ((data[(bluecell_length + 1) + (i + 2)] << 16) & 0x0000000000FF0000);
  97. Firmdata += ((data[(bluecell_length + 1) + (i + 3)] << 24) & 0x00000000FF000000);
  98. Firmdata += ((data[(bluecell_length + 1) + (i + 4)] << 32) & 0x000000FF00000000);
  99. Firmdata += ((data[(bluecell_length + 1) + (i + 5)] << 40) & 0x0000FF0000000000);
  100. Firmdata += ((data[(bluecell_length + 1) + (i + 6)] << 48) & 0x00FF000000000000);
  101. Firmdata += ((data[(bluecell_length + 1) + (i + 7)] << 56) & 0xFF00000000000000);
  102. if(Length_remainder > 0 && Length_ans > i){
  103. for(int a = 0; a < Length_remainder; a += 2){
  104. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,Address , (uint16_t)Firmdata) != HAL_OK){
  105. printf("HAL NOT OK \n");
  106. ret = 1;
  107. }
  108. Address += 2;
  109. }
  110. }
  111. else{
  112. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_DOUBLEWORD,Address , (uint64_t)Firmdata) != HAL_OK){
  113. printf("HAL NOT OK \n");
  114. ret = 1;
  115. }
  116. Address += 8;
  117. }
  118. //if(!(i%FirmwareUpdateDelay))
  119. // HAL_Delay(1);
  120. }
  121. return ret;
  122. }
  123. uint8_t Flash_DataTest_Write(uint8_t* data){
  124. uint32_t Firmdata = 0;
  125. uint8_t ret = 0;
  126. uint8_t Length = data[bluecell_length] - 2;
  127. uint8_t Length_remainder = Length % 4;
  128. uint8_t Length_ans = Length / 4;
  129. for(int i = 0; i < data[bluecell_length] - 2; i+=4){
  130. if(Length_remainder > 0 && Length_ans > i){
  131. for(int a = 0; a < Length_remainder; a += 2){
  132. Firmdata = ((data[(bluecell_length + 1) + i]) & 0x00FF);
  133. Firmdata += ((data[(bluecell_length + 1) + (i + 1)] << 8) & 0xFF00);
  134. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,Address , (uint16_t)Firmdata) != HAL_OK){
  135. printf("HAL NOT OK \n");
  136. ret = 1;
  137. }
  138. Address += 2;
  139. }
  140. }
  141. else{
  142. Firmdata = ((data[(bluecell_length + 1) + i]) & 0x000000FF);
  143. Firmdata += ((data[(bluecell_length + 1) + (i + 1)] << 8) & 0x0000FF00);
  144. Firmdata += ((data[(bluecell_length + 1) + (i + 2)] << 16) & 0x00FF0000);
  145. Firmdata += ((data[(bluecell_length + 1) + (i + 3)] << 24) & 0xFF000000);
  146. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_WORD,Address , (uint32_t)Firmdata) != HAL_OK){
  147. printf("HAL NOT OK \n");
  148. ret = 1;
  149. }
  150. Address += 4;
  151. }
  152. //if(!(i%FirmwareUpdateDelay))
  153. // HAL_Delay(1);
  154. }
  155. return ret;
  156. }
  157. #endif // PYJ.2020.05.20_END --
  158. uint8_t Flash_write(uint8_t* data) // ?占쏙옙湲고븿?占쏙옙
  159. {
  160. /*Variable used for Erase procedure*/
  161. static FLASH_EraseInitTypeDef EraseInitStruct;
  162. static uint32_t PAGEError = 0;
  163. uint8_t ret = 0;
  164. /* Fill EraseInit structure*/
  165. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  166. EraseInitStruct.PageAddress = FLASH_USER_START_ADDR;
  167. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_START_ADDR) / FLASH_PAGE_SIZE;
  168. // __HAL_RCC_TIM6_CLK_DISABLE(); // 留ㅼ씤???占쏙옙癒몌옙?? ?占쏙옙占�??占쏙옙?占쏙옙?占쏙옙
  169. HAL_FLASH_Unlock(); // lock ??占�?
  170. if(flashinit == 0){
  171. flashinit= 1;
  172. //FLASH_PageErase(StartAddr);
  173. if (HAL_FLASHEx_Erase(&EraseInitStruct, &PAGEError) != HAL_OK){
  174. printf("Erase Failed \r\n");
  175. }
  176. }
  177. // FLASH_If_Erase();
  178. ret = Flash_RGB_Data_Write(&data[bluecell_stx]);
  179. // ret = Flash_DataTest_Write(&data[bluecell_stx]);
  180. HAL_FLASH_Lock(); // lock ?占쏙옙洹멸린
  181. // __HAL_RCC_TIM6_CLK_ENABLE(); // 留ㅼ씤???占쏙옙癒몌옙?? ?占쏙옙?占쏙옙?占쏙옙?占쏙옙?占쏙옙?占쏙옙
  182. return ret;
  183. }
  184. uint8_t Bank_Flash_write(uint8_t* data,uint32_t StartBankAddress) // ?占쏙옙湲고븿?占쏙옙
  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. switch(StartBankAddress){
  192. case FLASH_USER_START_ADDR:
  193. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  194. EraseInitStruct.PageAddress = FLASH_USER_START_ADDR;
  195. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_START_ADDR) / FLASH_PAGE_SIZE;
  196. break;
  197. case FLASH_USER_BANK1_START_ADDR:
  198. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  199. EraseInitStruct.PageAddress = FLASH_USER_BANK1_START_ADDR;
  200. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_BANK1_START_ADDR) / FLASH_PAGE_SIZE;
  201. break;
  202. case FLASH_USER_BANK2_START_ADDR:
  203. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  204. EraseInitStruct.PageAddress = FLASH_USER_BANK2_START_ADDR;
  205. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_BANK2_START_ADDR) / FLASH_PAGE_SIZE;
  206. break;
  207. case FLASH_USER_TEMPBANK_START_ADDR:
  208. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  209. EraseInitStruct.PageAddress = FLASH_USER_TEMPBANK_START_ADDR;
  210. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_TEMPBANK_START_ADDR) / FLASH_PAGE_SIZE;
  211. break;
  212. }
  213. HAL_FLASH_Unlock(); // lock ??占�?
  214. if(flashinit == 0){
  215. flashinit= 1;
  216. //FLASH_PageErase(StartAddr);
  217. if (HAL_FLASHEx_Erase(&EraseInitStruct, &PAGEError) != HAL_OK){
  218. printf("Erase Failed \r\n");
  219. }
  220. }
  221. ret = Flash_RGB_Data_Write(&data[bluecell_stx]);
  222. HAL_FLASH_Lock(); // lock ?占쏙옙洹멸린
  223. return ret;
  224. }