flash.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. /*
  2. * flash.c
  3. *
  4. * Created on: 2019. 7. 15.
  5. * Author: parkyj
  6. */
  7. #include <Bootloader.h>
  8. #include <flash.h>
  9. uint8_t flashinit = 0;
  10. uint32_t Address = FLASH_USER_START_ADDR;
  11. typedef void (*fptr)(void);
  12. fptr jump_to_app;
  13. uint32_t jump_addr;
  14. void Jump_App(void){
  15. __HAL_RCC_TIM6_CLK_DISABLE(); // 留ㅼ씤???占쏙옙癒몌옙?? ?占쏙옙占�??占쏙옙?占쏙옙?占쏙옙
  16. printf("boot loader start\n"); //硫붿꽭占�? 異쒕젰
  17. jump_addr = *(__IO uint32_t*) (APPLICATION_ADDRESS + 4);
  18. jump_to_app = (fptr) jump_addr;
  19. /* init user app's sp */
  20. printf("jump!\n");
  21. __set_MSP(*(__IO uint32_t*) APPLICATION_ADDRESS);
  22. jump_to_app();
  23. }
  24. void FLASH_If_Init(void)
  25. {
  26. /* Unlock the Program memory */
  27. HAL_FLASH_Unlock();
  28. /* Clear all FLASH flags */
  29. __HAL_FLASH_CLEAR_FLAG(FLASH_FLAG_EOP | FLASH_FLAG_PGERR | FLASH_FLAG_WRPERR);
  30. /* Unlock the Program memory */
  31. HAL_FLASH_Lock();
  32. }
  33. void Flash_InitRead(void) // ?占쏙옙湲고븿?占쏙옙
  34. {
  35. uint32_t Address = 0;
  36. Address = FLASH_USER_START_ADDR;
  37. for(uint32_t i = 0; i < 16; i++ ){
  38. printf("%08x : %02X \n",Address ,*(uint8_t*)Address);
  39. Address++;
  40. }
  41. #if 0 // PYJ.2019.03.27_BEGIN --
  42. for(uint32_t i = 0; i < 13848; i++ ){
  43. printf("%08x : %02X \n",Address ,*(uint8_t*)Address);
  44. Address++;
  45. }
  46. Address = StartAddr;
  47. for(uint32_t i = 0; i < 13848; i++ ){
  48. printf("%02X ",*(uint8_t*)Address);
  49. Address++;
  50. }
  51. #endif // PYJ.2019.03.27_END --
  52. }
  53. uint8_t Flash_RGB_Data_Write(uint8_t* data){
  54. uint16_t Firmdata = 0;
  55. uint8_t ret = 0;
  56. for(uint8_t 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_write(uint8_t* data) // ?占쏙옙湲고븿?占쏙옙
  70. {
  71. /*Variable used for Erase procedure*/
  72. static FLASH_EraseInitTypeDef EraseInitStruct;
  73. static uint32_t PAGEError = 0;
  74. uint8_t ret = 0;
  75. /* Fill EraseInit structure*/
  76. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  77. EraseInitStruct.PageAddress = FLASH_USER_START_ADDR;
  78. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_START_ADDR) / FLASH_PAGE_SIZE;
  79. __HAL_RCC_TIM6_CLK_DISABLE(); // 留ㅼ씤???占쏙옙癒몌옙?? ?占쏙옙占�??占쏙옙?占쏙옙?占쏙옙
  80. HAL_FLASH_Unlock(); // lock ??占�?
  81. if(flashinit == 0){
  82. flashinit= 1;
  83. //FLASH_PageErase(StartAddr);
  84. if (HAL_FLASHEx_Erase(&EraseInitStruct, &PAGEError) != HAL_OK){
  85. printf("Erase Failed \r\n");
  86. }
  87. }
  88. // FLASH_If_Erase();
  89. ret = Flash_RGB_Data_Write(&data[bluecell_stx]);
  90. HAL_FLASH_Lock(); // lock ?占쏙옙洹멸린
  91. __HAL_RCC_TIM6_CLK_ENABLE(); // 留ㅼ씤???占쏙옙癒몌옙?? ?占쏙옙?占쏙옙?占쏙옙?占쏙옙?占쏙옙?占쏙옙
  92. return ret;
  93. }