flash(6799).c 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  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 < INDEX_BLUE_EOF + 1; 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. #define INDEX_LENGTH 2
  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[INDEX_LENGTH] - 2; i+=2){
  57. Firmdata = ((data[(INDEX_LENGTH + 1) + i]) & 0x00FF);
  58. Firmdata += ((data[(INDEX_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. }
  65. return ret;
  66. }
  67. #define INDEX_HEADER 0
  68. uint8_t Flash_write(uint8_t* data) // ?占쏙옙湲고븿?占쏙옙
  69. {
  70. /*Variable used for Erase procedure*/
  71. static FLASH_EraseInitTypeDef EraseInitStruct;
  72. static uint32_t PAGEError = 0;
  73. uint8_t ret = 0;
  74. /* Fill EraseInit structure*/
  75. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  76. EraseInitStruct.PageAddress = FLASH_USER_START_ADDR;
  77. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_START_ADDR) / FLASH_PAGE_SIZE;
  78. HAL_FLASH_Unlock(); // lock ??占�?
  79. if(flashinit == 0){
  80. flashinit= 1;
  81. //FLASH_PageErase(StartAddr);
  82. if (HAL_FLASHEx_Erase(&EraseInitStruct, &PAGEError) != HAL_OK){
  83. printf("Erase Failed \r\n");
  84. }
  85. }
  86. // FLASH_If_Erase();
  87. ret = Flash_RGB_Data_Write(&data[INDEX_HEADER]);
  88. HAL_FLASH_Lock(); // lock ?占쏙옙洹멸린
  89. return ret;
  90. }
  91. void flashtest() {
  92. uint32_t opt_addr = FLASH_USER_START_ADDR; // option byte 16
  93. uint32_t addr = FLASH_USER_START_ADDR; // page=127
  94. static FLASH_EraseInitTypeDef EraseInitStruct;
  95. static uint32_t PAGEError = 0;
  96. uint8_t ret = 0;
  97. /* Fill EraseInit structure*/
  98. EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
  99. EraseInitStruct.PageAddress = FLASH_USER_START_ADDR;
  100. EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_START_ADDR) / FLASH_PAGE_SIZE;
  101. int i;
  102. uint8_t optbuf[16];
  103. __IO uint8_t *p = (__IO uint8_t*)addr;
  104. for(i=0;i<sizeof(optbuf); i++) {
  105. optbuf[i] = *p++;
  106. printf("%2d : %x\r\n",i,optbuf[i]);
  107. HAL_Delay(1);
  108. }
  109. int sz = 1024/sizeof(uint32_t);
  110. uint32_t tmpbuf[sz];
  111. __IO uint32_t *q = (__IO uint32_t*)addr;
  112. for(i=0;i<sz;i++) {
  113. tmpbuf[i] = *q++;
  114. printf("%3d : %x\r\n",i,tmpbuf[i]);
  115. HAL_Delay(5);
  116. }
  117. HAL_FLASH_Unlock();
  118. __HAL_FLASH_CLEAR_FLAG(FLASH_FLAG_EOP | FLASH_FLAG_PGERR | FLASH_FLAG_WRPERR);
  119. if (HAL_FLASHEx_Erase(&EraseInitStruct, &PAGEError) != HAL_OK)
  120. printf("flash erase fail (%x)\r\n",addr);
  121. for(i=0;i<sz;i++) {
  122. if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,addr+i*sizeof(uint32_t), tmpbuf[i]+(uint32_t)i)) {
  123. printf("flash program error %d\r\n",i);
  124. HAL_Delay(5);
  125. }
  126. }
  127. HAL_FLASH_Lock();
  128. }
  129. uint8_t Flash_Byte_Write(uint8_t* data){
  130. /*Variable used for Erase procedure*/
  131. flashtest();
  132. }