RefreshMenu.c 6.0 KB

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