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. JumpToApp(APPLICATION_ADDRESS);
  105. //downLoad.finished = DISABLE;
  106. }
  107. }
  108. }
  109. void timeOutAck(void)
  110. {
  111. if((downLoad.finished == DISABLE) && (downLoad.step != 0))
  112. {
  113. if(update.TimeCounter_Update > 1000 ) //1000ms
  114. {
  115. update.TimeCounter_Update = 0;
  116. sendUpdateAck(CMD_ACK_ERR , downLoad.packagecount);
  117. }
  118. }
  119. }
  120. /*上电启动,或复位后*/
  121. void startUpAck(void)
  122. {
  123. // startUpSendCount=0;
  124. if(downLoad.step == 0 )
  125. {
  126. if(downLoad.startUpSendCount < 4)
  127. {
  128. if(update.TimeCounter_Startup >= 50) //200ms
  129. {
  130. update.TimeCounter_Startup = 0;
  131. downLoad.startUpSendCount++;
  132. sendBootInfo();
  133. }
  134. }
  135. else
  136. {
  137. downLoad.finished = ENABLE;
  138. }
  139. }
  140. }
  141. void updateAck(void)
  142. {
  143. if( update.AckEnable == ENABLE )
  144. {
  145. update.AckEnable = DISABLE;
  146. switch(downLoad.step)
  147. {
  148. case 1:
  149. sendUpdateAck(downLoad.userCmd , 0x00);
  150. break;
  151. case 2:
  152. sendUpdateAck(downLoad.userCmd , downLoad.packagecount);
  153. break;
  154. case 3:
  155. if( RomCheck() == SUCCESS )
  156. {
  157. //HAL_Delay(1000);
  158. sendUpdateAck(downLoad.userCmd , 0x00);
  159. downLoad.finished = ENABLE;
  160. }
  161. else
  162. {
  163. sendUpdateAck(CMD_ACK_ERR , 0x00);
  164. }
  165. break;
  166. case 5:
  167. sendAck();
  168. downLoad.step = 0;
  169. downLoad.finished = DISABLE;
  170. downLoad.startUpSendCount = 0;
  171. break;
  172. default :
  173. break;
  174. }
  175. }
  176. if(downLoad.wrenable == ENABLE)
  177. {
  178. downLoad.wrenable = DISABLE;
  179. //写flash
  180. if((downLoad.packagecount <= 1024) && ( downLoad.packagecount > 0 ) )
  181. {
  182. if(flag_FlashWR[downLoad.packagecount - 1] == 0 )
  183. {
  184. if(FLASH_If_Write( (downLoad.packagecount - 1) * PACKET_128B_SIZE + APPLICATION_ADDRESS, (uint32_t *)downLoad.dataBuff_128B, 32) != FLASHIF_OK )
  185. {
  186. while(1)
  187. {
  188. sendUpdateAck(CMD_ACK_ERR_FLASH , 0xee);
  189. HAL_Delay(1000);
  190. }
  191. }
  192. flag_FlashWR[downLoad.packagecount - 1] = 1;
  193. /* 写完FLASH后立即应答,清超时计数 */
  194. update.AckEnable = ENABLE;
  195. /*清除超时标志*/
  196. update.TimeCounter_Update = 0;
  197. }
  198. else
  199. {
  200. /*重复写入,可能是上位机没有接收到正确应答信号,重发了数据包,
  201. 应答一个正确信号,让上位机发送下一包数据*/
  202. sendUpdateAck(CMD_ACK_OK, downLoad.packagecount);
  203. sendUpdateAck(CMD_ACK_ERR_FLASH , 0xe1);
  204. }
  205. }
  206. else
  207. {
  208. sendUpdateAck(CMD_ACK_ERR_FLASH , 0xe2);
  209. }
  210. }
  211. }
  212. /*******************************************************************************
  213. * Function: void Period_Stick(void)
  214. * Discrible: 周期定时器
  215. * Input:
  216. * Output:
  217. * Return:
  218. * Others:
  219. * date version author record
  220. * -----------------------------------------------
  221. * 20160307 V1.0 VINCENT Create
  222. *********************************************************************************/
  223. void Period_Stick(void)
  224. {
  225. update.TimeCounter_Startup ++;
  226. update.TimeCounter_Update++;
  227. }
  228. /************************ (C) END OF FILE *********************************/