RefreshMenu.c 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265
  1. /**
  2. ******************************************************************************
  3. * @file RefreshMenu.c
  4. * @author Vincent
  5. * @version V1.0.0
  6. * @date 23-12-2015
  7. * @brief
  8. ******************************************************************************
  9. ******************************************************************************
  10. */
  11. /* Includes ------------------------------------------------------------------*/
  12. #include "RefreshMenu.h"
  13. #include "protocol.h"
  14. #include "can_app.h"
  15. #include "flash_if.h"
  16. /* Private variables ---------------------------------------------------------*/
  17. download_t downLoad;
  18. updatecount_t update;
  19. uint8_t flag_FlashWR[1024];
  20. /* Private variables ---------------------------------------------------------*/
  21. /* Private function prototypes -----------------------------------------------*/
  22. void Protocol_Ack(void);
  23. void updateAck(void);
  24. void startUpAck(void);
  25. void timeOutAck(void);
  26. typedef void (*iapfun)(void); //定义一个函数类型的参数
  27. iapfun jumpFun;
  28. void JumpToApp(__IO uint32_t ApplicationAddress)
  29. {
  30. __IO uint32_t temp;
  31. /* Test if user code is programmed starting from address "APPLICATION_ADDRESS" */
  32. if (((*(__IO uint32_t*)ApplicationAddress) &0x2FFE0000 ) == 0x20000000)
  33. {
  34. /* Get add */
  35. temp = (*(__IO uint32_t*)(ApplicationAddress + 4));
  36. jumpFun =(iapfun)temp;
  37. /* Initialize user application's Stack Pointer */
  38. __set_MSP(*(__IO uint32_t*)ApplicationAddress);
  39. /* Jump to user application */
  40. jumpFun();
  41. }
  42. else
  43. {
  44. HAL_Delay(1);
  45. //downLoad.finished = DISABLE;
  46. }
  47. }
  48. /*******************************************************************************
  49. * Function: void User_Manu_Init(void)
  50. * Discrible: 初始化
  51. * Input:
  52. * Output:
  53. * Return:
  54. * Others:
  55. * date version author record
  56. * -----------------------------------------------
  57. * 20180419 V1.0 VINCENT Create
  58. *********************************************************************************/
  59. void User_Manu_Init(void)
  60. {
  61. FLASH_If_Init();
  62. //_.ackcmd = ACK_REQ;
  63. downLoad.step = 0;
  64. downLoad.packagecount = 0;
  65. downLoad.wrenable = DISABLE;
  66. downLoad.finished = DISABLE;
  67. downLoad.startUpSendCount = 0;
  68. update.TimeCounter_Startup = 1000;
  69. update.TimeCounter_Update = 0;
  70. }
  71. /*******************************************************************************
  72. * Function: void User_Main_Manu(void)
  73. * Discrible: 主菜单
  74. * Input:
  75. * Output:
  76. * Return:
  77. * Others:
  78. * date version author record
  79. * -----------------------------------------------
  80. * 20180419 V1.0 VINCENT Create
  81. *********************************************************************************/
  82. void User_Main_Manu(void)
  83. {
  84. while(1)
  85. {
  86. // Iwdg_Refresh();
  87. CA_RxData_Process(&CAN_RxBuf_Struct1);
  88. startUpAck();
  89. updateAck();
  90. timeOutAck();
  91. if(downLoad.finished == ENABLE)
  92. {
  93. HAL_GPIO_WritePin(GPIOC, GPIO_PIN_1, GPIO_PIN_RESET);
  94. HAL_Delay(50);
  95. HAL_CAN_DeInit(&hcan);
  96. JumpToApp(APPLICATION_ADDRESS);
  97. }
  98. }
  99. }
  100. void timeOutAck(void)
  101. {
  102. if((downLoad.finished == DISABLE) && (downLoad.step != 0))
  103. {
  104. if(update.TimeCounter_Update > 3000 ) //1000ms
  105. {
  106. update.TimeCounter_Update = 0;
  107. sendUpdateAck(CMD_ACK_ERR , downLoad.packagecount);
  108. downLoad.finished = ENABLE;
  109. }
  110. }
  111. }
  112. /*上电启动,或复位后*/
  113. void startUpAck(void)
  114. {
  115. if(downLoad.step == 0 )
  116. {
  117. if(downLoad.startUpSendCount < 4)
  118. {
  119. if(update.TimeCounter_Startup >= 50) //200ms
  120. {
  121. update.TimeCounter_Startup = 0;
  122. downLoad.startUpSendCount++;
  123. sendBootInfo();
  124. }
  125. }
  126. else
  127. {
  128. downLoad.finished = ENABLE;
  129. }
  130. }
  131. }
  132. void updateAck(void)
  133. {
  134. if( update.AckEnable == ENABLE )
  135. {
  136. update.AckEnable = DISABLE;
  137. switch(downLoad.step)
  138. {
  139. case 1:
  140. sendUpdateAck(downLoad.userCmd , 0x0000);
  141. break;
  142. case 2:
  143. sendUpdateAck(downLoad.userCmd , downLoad.packagecount);
  144. break;
  145. case 3:
  146. sendUpdateAck(downLoad.userCmd , 0x0000);
  147. downLoad.finished = ENABLE;
  148. break;
  149. case 5:
  150. sendAck();
  151. downLoad.step = 0;
  152. downLoad.finished = DISABLE;
  153. downLoad.startUpSendCount = 0;
  154. break;
  155. default :
  156. break;
  157. }
  158. }
  159. if(downLoad.wrenable == ENABLE)
  160. {
  161. downLoad.wrenable = DISABLE;
  162. //写flash
  163. if((downLoad.packagecount <= 1024) && ( downLoad.packagecount > 0 ) )
  164. {
  165. if(flag_FlashWR[downLoad.packagecount - 1] == 0 )
  166. {
  167. if(FLASH_If_Write( (downLoad.packagecount - 1) * PACKET_128B_SIZE + APPLICATION_ADDRESS, (uint32_t *)downLoad.dataBuff_128B, 32) != FLASHIF_OK )
  168. {
  169. while(1)
  170. {
  171. sendUpdateAck(CMD_ACK_ERR_FLASH , 0xee);
  172. // Iwdg_Refresh();
  173. HAL_Delay(1000);
  174. }
  175. }
  176. flag_FlashWR[downLoad.packagecount - 1] = 1;
  177. /* 写完FLASH后立即应答,清超时计数 */
  178. update.AckEnable = ENABLE;
  179. /*清除超时标志*/
  180. update.TimeCounter_Update = 0;
  181. }
  182. else
  183. {
  184. /*重复写入,可能是上位机没有接收到正确应答信号,重发了数据包,
  185. 应答一个正确信号,让上位机发送下一包数据*/
  186. sendUpdateAck(CMD_ACK_OK, downLoad.packagecount);
  187. sendUpdateAck(CMD_ACK_ERR_FLASH , 0xe1);
  188. }
  189. }
  190. else
  191. {
  192. sendUpdateAck(CMD_ACK_ERR_FLASH , 0xe2);
  193. }
  194. }
  195. }
  196. /*******************************************************************************
  197. * Function: void Period_Stick(void)
  198. * Discrible: 周期定时器
  199. * Input:
  200. * Output:
  201. * Return:
  202. * Others:
  203. * date version author record
  204. * -----------------------------------------------
  205. * 20160307 V1.0 VINCENT Create
  206. *********************************************************************************/
  207. void Period_Stick(void)
  208. {
  209. update.TimeCounter_Startup ++;
  210. update.TimeCounter_Update++;
  211. }
  212. /************************ (C) END OF FILE *********************************/