uart.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611
  1. #include <string.h>
  2. #include "amt630h.h"
  3. #include "typedef.h"
  4. #include "uart.h"
  5. #include "aic.h"
  6. #include "update.h"
  7. #include "spi.h"
  8. #include "crc32.h"
  9. #include "sysinfo.h"
  10. #include "board.h"
  11. #define UART_CLK CLK_24MHZ
  12. #define UART_ISR_PASS_LIMIT 1
  13. static unsigned int ulUartBase[UART_NUM] = {REGS_UART0_BASE, REGS_UART1_BASE, REGS_UART2_BASE, REGS_UART3_BASE};
  14. void InitUart(unsigned int baud)
  15. {
  16. unsigned int Baud_Rate_Divisor;
  17. unsigned int val;
  18. //select pad
  19. val = rSYS_PAD_CTRL02;
  20. val &= ~(0xF<<12);
  21. val |=(0x1<<14)|(0x1<<12);
  22. rSYS_PAD_CTRL02 = val;
  23. Baud_Rate_Divisor = ((CLK_24MHZ<<3) + baud)/(baud<<1);
  24. rUART_IBRD = Baud_Rate_Divisor >> 6;
  25. rUART_FBRD = Baud_Rate_Divisor & 0x3f;
  26. rUART_LCR_H = 0x70;//data len:8 bit,parity checking disable
  27. rUART_IFLS = 0x19;
  28. rUART_CR = 0x301;
  29. }
  30. static char HexToChar(unsigned char value)
  31. {
  32. value &= 0x0f;
  33. if ( value < 10 )
  34. return(0x30 + value);
  35. else
  36. return(0x60 + value - 9);
  37. }
  38. static void ShortToStr(unsigned short value, char *str)
  39. {
  40. str[0] = HexToChar(value >> 12);
  41. str[1] = HexToChar((value >> 8) & 0x0f);
  42. str[2] = HexToChar((value >> 4) & 0x0f);
  43. str[3] = HexToChar(value & 0x0f);
  44. str[4] = 0;
  45. }
  46. void IntToStr(unsigned int value, char *str)
  47. {
  48. ShortToStr(value >> 16, str);
  49. ShortToStr(value & 0xffff, str + 4);
  50. str[8] = 0;
  51. }
  52. void SendUartString(char * buf)
  53. {
  54. int i = 0;
  55. while ( buf[i] != 0)
  56. {
  57. while ( !(rUART_FR & 0x20) )
  58. {
  59. rUART_DR = buf[i++];
  60. if ( buf[i] == 0 )
  61. return;
  62. }
  63. while ( (rUART_FR & 0x20));
  64. }
  65. }
  66. void SendUartChar(char ch)
  67. {
  68. while ( (rUART_FR & 0x20) );
  69. rUART_DR = ch;
  70. }
  71. void PrintVariableValueHex(char * variable, unsigned int value)
  72. {
  73. char buf[10];
  74. SendUartString(variable);
  75. SendUartString(": 0x");
  76. IntToStr(value, buf);
  77. SendUartString(buf);
  78. SendUartString("\r\n");
  79. }
  80. void SendUartWord(unsigned int data)
  81. {
  82. char buf[10];
  83. SendUartString("0x");
  84. IntToStr(data, buf);
  85. SendUartString(buf);
  86. SendUartString("\r\n");
  87. }
  88. void uart_puts(const UINT8*buf)
  89. {
  90. INT32 i = 0;
  91. while ( buf[i] != 0)
  92. {
  93. while( !(rUART_FR & 0x20) )
  94. {
  95. if ( buf[i] == '\n' )
  96. {
  97. rUART_DR = '\r';
  98. while( (rUART_FR & 0x20) );
  99. }
  100. rUART_DR = buf[i++];
  101. if ( buf[i] == 0 )
  102. return;
  103. }
  104. while( (rUART_FR & 0x20) );
  105. }
  106. }
  107. /* retarget printf function */
  108. int putchar(int ch)
  109. {
  110. while (readl(REGS_UART0_BASE + UART_FR) & UART_FR_TXFF);
  111. writel(ch, REGS_UART0_BASE + UART_DR);
  112. return ch;
  113. }
  114. typedef enum {
  115. UART_FRAME_START,
  116. UART_FRAME_FILEINFO,
  117. UART_FRAME_FILEXFER,
  118. UART_FRAME_FINISH,
  119. } eUartFrameType;
  120. #define UUP_STATE_IDLE 0
  121. #define UUP_STATE_START 1
  122. #define UUP_STATE_END 2
  123. #define UUP_ACK_OK 1
  124. #define UUP_ACK_FAIL 0
  125. #define UUP_MAX_FILE_SIZE 0x1000000
  126. #define UUP_BUF_SIZE (BYTESPERPAGE * PAGESPERSECTORS)
  127. #define UUP_PACKET_SIZE 128
  128. #define UUP_MAX_FRAME_LEN (UUP_PACKET_SIZE + 16)
  129. #define UUP_RX_FRAME_NUM 16
  130. #define UUP_MAX_LOADER_SIZE 0x10000
  131. typedef struct {
  132. int type;
  133. unsigned char *buf;
  134. unsigned int len;
  135. int ack;
  136. } UartFrame;
  137. #pragma data_alignment=16
  138. static unsigned char uup_rx_buf[UUP_RX_FRAME_NUM][UUP_MAX_FRAME_LEN];
  139. static unsigned char *uup_rx_ptr;
  140. static int uup_rx_rev_len = 0;
  141. static int uup_rx_head = 0;
  142. static int uup_rx_tail = 0;
  143. static int uup_rx_state = 0;
  144. static int uup_rx_data_len = 0;
  145. static int uup_status = UUP_STATE_IDLE;
  146. static int uup_file_type = 0;
  147. static unsigned int uup_file_offset;
  148. static int uup_file_size = 0;
  149. static int uup_packet_num = 0;
  150. static int uup_rev_packet = 0;
  151. static int uup_rev_len = 0;
  152. #pragma data_alignment=16
  153. static unsigned char uup_buf[UUP_MAX_LOADER_SIZE];
  154. static unsigned int uup_buf_len = 0;
  155. void uart_init(int id, unsigned int baud, unsigned int flags)
  156. {
  157. unsigned int lcr_h, quot, cr;
  158. unsigned int regbase;
  159. int count = 0;
  160. regbase = ulUartBase[id];
  161. if (baud > UART_CLK / 16)
  162. quot = (UART_CLK * 8 + baud / 2) / baud;
  163. else
  164. quot = (UART_CLK * 4 + baud / 2) / baud;
  165. switch (flags & CSIZE) {
  166. case CS5:
  167. lcr_h = UART_LCRH_WLEN_5;
  168. break;
  169. case CS6:
  170. lcr_h = UART_LCRH_WLEN_6;
  171. break;
  172. case CS7:
  173. lcr_h = UART_LCRH_WLEN_7;
  174. break;
  175. default: // CS8
  176. lcr_h = UART_LCRH_WLEN_8;
  177. break;
  178. }
  179. if (flags & CSTOPB)
  180. lcr_h |= UART_LCRH_STP2;
  181. if (flags & PARENB) {
  182. lcr_h |= UART_LCRH_PEN;
  183. if (!(flags & PARODD))
  184. lcr_h |= UART_LCRH_EPS;
  185. if (flags & CMSPAR)
  186. lcr_h |= UART_LCRH_SPS;
  187. }
  188. lcr_h |= UART_LCRH_FEN;
  189. /* Provoke TX FIFO interrupt into asserting */
  190. cr = UART_CR_UARTEN | UART_CR_TXE | UART_CR_LBE;
  191. reconfig:
  192. writel(cr, regbase + UART_CR);
  193. writel(0, regbase + UART_FBRD);
  194. writel(1, regbase + UART_IBRD);
  195. writel(0, regbase + UART_LCRH);
  196. writel(0, regbase + UART_DR);
  197. while (readl(regbase + UART_FR) & UART_FR_BUSY);
  198. if (count++ < 10 && !(readl(regbase + UART_RIS) & UART_TXIS)) {
  199. SendUartString("ERROR! Uart status wrong.\n");
  200. goto reconfig;
  201. }
  202. /* first, disable everything */
  203. writel(0, regbase + UART_CR);
  204. cr = UART_CR_RXE | UART_CR_TXE;
  205. if (flags & CRTSCTS)
  206. cr |= UART_CR_CTSEN | UART_CR_RTSEN;
  207. /* Set baud rate */
  208. writel(quot & 0x3f, regbase + UART_FBRD);
  209. writel(quot >> 6, regbase + UART_IBRD);
  210. writel(UART_RTIM | UART_RXIM, regbase + UART_IMSC);
  211. writel(UART_IFLS_RX4_8 | UART_IFLS_TX4_8, regbase + UART_IFLS);
  212. writel(lcr_h, regbase + UART_LCRH);
  213. writel(cr | UART_CR_UARTEN, regbase + UART_CR);
  214. }
  215. static int uart_rx_chars(int id)
  216. {
  217. unsigned int regbase = ulUartBase[id];
  218. unsigned int status;
  219. unsigned int ch, max_count = 256;
  220. int fifotaken = 0;
  221. while (max_count--) {
  222. status = readl(regbase + UART_FR);
  223. if (status & UART_FR_RXFE)
  224. break;
  225. /* Take chars from the FIFO and update status */
  226. ch = readl(regbase + UART_DR);
  227. fifotaken++;
  228. switch (uup_rx_state) {
  229. case 0:
  230. if (ch == 0x55) {
  231. uup_rx_state++;
  232. uup_rx_rev_len = 0;
  233. uup_rx_ptr = &uup_rx_buf[uup_rx_head][0];
  234. }
  235. break;
  236. case 1:
  237. if (ch == 0x81)
  238. uup_rx_state++;
  239. else
  240. uup_rx_state = 0;
  241. *uup_rx_ptr++ = ch;
  242. break;
  243. case 2:
  244. if (ch == 0xc6)
  245. uup_rx_state++;
  246. else
  247. uup_rx_state = 0;
  248. *uup_rx_ptr++ = ch;
  249. break;
  250. case 3:
  251. uup_rx_data_len = ch;
  252. uup_rx_state++;
  253. *uup_rx_ptr++ = ch;
  254. break;
  255. case 4:
  256. *uup_rx_ptr++ = ch;
  257. if (++uup_rx_rev_len == uup_rx_data_len)
  258. uup_rx_state++;
  259. break;
  260. case 5:
  261. *uup_rx_ptr++ = ch;
  262. uup_rx_head = (uup_rx_head + 1) % UUP_RX_FRAME_NUM;
  263. uup_rx_state = 0;
  264. break;
  265. }
  266. /* discard when rx buf is full */
  267. }
  268. return fifotaken;
  269. }
  270. void uart_tx_chars(int id, unsigned char *buf, int len)
  271. {
  272. unsigned int regbase = ulUartBase[id];
  273. int i;
  274. for (i = 0; i < len; i++) {
  275. while (readl(regbase + UART_FR) & UART_FR_TXFF);
  276. writel(buf[i], regbase + UART_DR);
  277. }
  278. }
  279. void uart_update_int_handler(void *param)
  280. {
  281. int id = (int)param;
  282. unsigned int regbase = ulUartBase[id];
  283. unsigned int status;
  284. unsigned int imsc;
  285. uint32_t pass_counter = UART_ISR_PASS_LIMIT;
  286. imsc = readl(regbase + UART_IMSC);
  287. status = readl(regbase + UART_RIS) & imsc;
  288. if (status) {
  289. do {
  290. writel(status & ~(/*UART_TXIS | */UART_RTIS | UART_RXIS),
  291. regbase + UART_ICR);
  292. if (status & (UART_RTIS | UART_RXIS)) {
  293. uart_rx_chars(id);
  294. }
  295. /* if (status & UART_TXIS)
  296. xUartTxChars(uap, pdTRUE); */
  297. if (pass_counter-- == 0)
  298. break;
  299. status = readl(regbase + UART_RIS) & imsc;
  300. } while (status != 0);
  301. }
  302. }
  303. static void uart_send_ack(int type, int ret)
  304. {
  305. unsigned char buf[7] = {0x55, 0x80, 0xc5, 0x02, 0x00, 0x00, 0x00};
  306. int i;
  307. buf[4] = type;
  308. buf[5] = ret;
  309. for (i = 1; i < 6; i++)
  310. buf[6] ^= buf[i];
  311. uart_tx_chars(UART_MCU_PORT, buf, 7);
  312. }
  313. static int uart_rev_frame(UartFrame *frame)
  314. {
  315. unsigned char *buf;
  316. int len;
  317. unsigned char checksum = 0;
  318. int i;
  319. if (uup_rx_tail == uup_rx_head) {
  320. return 0;
  321. }
  322. buf = &uup_rx_buf[uup_rx_tail][0];
  323. uup_rx_tail = (uup_rx_tail + 1) % UUP_RX_FRAME_NUM;
  324. len = buf[2];
  325. for (i = 0; i < len + 3; i++)
  326. checksum ^= buf[i];
  327. if (checksum == buf[len + 3]) {
  328. frame->buf = &buf[4];
  329. frame->len = len - 1;
  330. frame->type = buf[3];
  331. } else {
  332. SendUartString("rev frame checksum err.\n");
  333. /* for (int i = 0; i < len + 4; i++) {
  334. if (i && i % 16 == 0)
  335. printf("\n");
  336. printf("%.2x, ", buf[i]);
  337. }
  338. printf("\n0x%x, 0x%x.\n", checksum, buf[len + 3]); */
  339. uart_send_ack(buf[3], UUP_ACK_FAIL);
  340. return 0;
  341. }
  342. return 1;
  343. }
  344. void updateFromUart(int id)
  345. {
  346. UartFrame rx_frame;
  347. unsigned char *buf;
  348. unsigned int checksum = 0, calc_checksum = 0xffffffff;
  349. unsigned int framelen;
  350. unsigned int packetnum;
  351. SysInfo *sysinfo = GetSysInfo();
  352. uart_init(id, 115200, 0);
  353. request_irq(UART0_IRQn + id, 0, uart_update_int_handler, (void*)id);
  354. do {
  355. if (!uart_rev_frame(&rx_frame))
  356. continue;
  357. switch (rx_frame.type) {
  358. case UART_FRAME_START:
  359. uart_send_ack(rx_frame.type, UUP_ACK_OK);
  360. uup_status = UUP_STATE_START;
  361. update_logo_init();
  362. break;
  363. case UART_FRAME_FILEINFO:
  364. if (uup_status != UUP_STATE_START)
  365. break;
  366. buf = rx_frame.buf;
  367. uup_file_type = buf[0];
  368. if (uup_file_type > UPFILE_TYPE_STEPLDR) {
  369. SendUartString("Rev wrong file type.\n");
  370. uart_send_ack(rx_frame.type, UUP_ACK_FAIL);
  371. break;
  372. }
  373. uup_file_offset = SpiGetUpfileOffset(uup_file_type);
  374. if (uup_file_offset == 0xffffffff) {
  375. uart_send_ack(rx_frame.type, UUP_ACK_FAIL);
  376. break;
  377. }
  378. uup_packet_num = (buf[1] << 16) | (buf[2] << 8) | buf[3];
  379. uup_file_size = UUP_PACKET_SIZE * uup_packet_num;
  380. if (uup_file_size > UUP_MAX_FILE_SIZE) {
  381. SendUartString("Rev wrong file size.\n");
  382. uart_send_ack(rx_frame.type, UUP_ACK_FAIL);
  383. break;
  384. }
  385. uart_send_ack(rx_frame.type, UUP_ACK_OK);
  386. break;
  387. case UART_FRAME_FILEXFER:
  388. if (uup_status != UUP_STATE_START)
  389. break;
  390. buf = rx_frame.buf;
  391. packetnum = buf[0];
  392. PrintVariableValueHex("uup_rev_packet", uup_rev_packet);
  393. if ((uup_rev_packet & 0xff) != packetnum) {
  394. SendUartString("Wrong packet number.\n");
  395. uart_send_ack(rx_frame.type, UUP_ACK_FAIL);
  396. break;
  397. }
  398. if (uup_rev_packet == 0) {
  399. if (uup_file_type == UPFILE_TYPE_WHOLE) {
  400. UpFileHeader header;
  401. memcpy(&header, &buf[1], sizeof(UpFileHeader));
  402. if (header.magic != MKTAG('U', 'P', 'D', 'F')) {
  403. SendUartString("Wrong whole file magic.\n");
  404. uart_send_ack(rx_frame.type, UUP_ACK_FAIL);
  405. break;
  406. }
  407. checksum = header.checksum;
  408. } else if (uup_file_type == UPFILE_TYPE_RESOURCE) {
  409. RomHeader header;
  410. memcpy(&header, &buf[1], sizeof(RomHeader));
  411. if (header.magic != MKTAG('R', 'O', 'M', 'A')) {
  412. SendUartString("Wrong resource file magic.\n");
  413. uart_send_ack(rx_frame.type, UUP_ACK_FAIL);
  414. break;
  415. }
  416. checksum = header.checksum;
  417. } else if (uup_file_type == UPFILE_TYPE_ANIMATION) {
  418. BANIHEADER header;
  419. memcpy(&header, &buf[1], sizeof(BANIHEADER));
  420. if (header.magic != MKTAG('B', 'A', 'N', 'I')) {
  421. SendUartString("Wrong animation file magic.\n");
  422. uart_send_ack(rx_frame.type, UUP_ACK_FAIL);
  423. break;
  424. }
  425. checksum = header.checksum;
  426. } else if (uup_file_type == UPFILE_TYPE_APP) {
  427. unsigned int magic = buf[1] | (buf[2] << 8) | (buf[3] << 16) | (buf[4] << 24);
  428. if (magic != UPFILE_APP_MAGIC) {
  429. SendUartString("Wrong app file magic.\n");
  430. uart_send_ack(rx_frame.type, UUP_ACK_FAIL);
  431. break;
  432. }
  433. unsigned char *tmp = buf + 1 + APPLDR_CHECKSUM_OFFSET;
  434. checksum = tmp[0] | (tmp[1] <<8) | (tmp[2] << 16) | (tmp[3] << 24);
  435. }
  436. }
  437. framelen = rx_frame.len - 1;
  438. /* only last frame size is less than UUP_PACKET_SIZE */
  439. if (framelen > UUP_PACKET_SIZE ||
  440. (framelen < UUP_PACKET_SIZE && uup_rev_packet != uup_packet_num - 1)) {
  441. SendUartString("Wrong packet len.\n");
  442. uart_send_ack(rx_frame.type, UUP_ACK_FAIL);
  443. break;
  444. }
  445. memcpy(uup_buf + uup_buf_len, buf + 1, framelen);
  446. uup_buf_len += framelen;
  447. if (uup_buf_len > UUP_MAX_LOADER_SIZE) {
  448. SendUartString("loader file is too large.\n");
  449. uart_send_ack(rx_frame.type, UUP_ACK_FAIL);
  450. break;
  451. }
  452. uart_send_ack(rx_frame.type, UUP_ACK_OK);
  453. uup_rev_packet++;
  454. //loader程序如果升级错误会导致系统起不来并且不能再继续升级,因此需要
  455. //等数据校验成功后再烧录(loader程序通常并不需要升级)
  456. if (uup_file_type < UPFILE_TYPE_SPILDR && uup_buf_len == UUP_BUF_SIZE) {
  457. SpiNorBurn(uup_buf, uup_file_offset, UUP_BUF_SIZE, 0);
  458. //文件起始部分需要先将头信息里的checksum清0来计算checksum
  459. if (uup_rev_packet == UUP_BUF_SIZE / UUP_PACKET_SIZE) {
  460. if (uup_file_type == UPFILE_TYPE_WHOLE) {
  461. UpFileHeader *pheader = (UpFileHeader *)uup_buf;
  462. pheader->checksum = 0;
  463. } else if (uup_file_type == UPFILE_TYPE_RESOURCE) {
  464. RomHeader *pheader = (RomHeader *)uup_buf;
  465. pheader->checksum = 0;
  466. } else if (uup_file_type == UPFILE_TYPE_ANIMATION) {
  467. BANIHEADER *pheader = (BANIHEADER *)uup_buf;
  468. pheader->checksum = 0;
  469. } else if (uup_file_type == UPFILE_TYPE_APP) {
  470. unsigned int *tmp = (unsigned int *)(uup_buf + APPLDR_CHECKSUM_OFFSET);
  471. *tmp = 0;
  472. }
  473. }
  474. calc_checksum = xcrc32(uup_buf, UUP_BUF_SIZE, calc_checksum);
  475. uup_buf_len = 0;
  476. uup_file_offset += UUP_BUF_SIZE;
  477. uup_rev_len += UUP_BUF_SIZE;
  478. update_progress_set(uup_rev_len * 100 / uup_file_size);
  479. }
  480. break;
  481. case UART_FRAME_FINISH:
  482. buf = rx_frame.buf;
  483. if (!buf[0]) {
  484. SendUartString("update end with error!\n");
  485. uart_send_ack(rx_frame.type, UUP_ACK_FAIL);
  486. uup_status = UUP_STATE_END;
  487. break;
  488. }
  489. if (uup_file_type < UPFILE_TYPE_SPILDR) {
  490. if (uup_buf_len) {
  491. SpiNorBurn(uup_buf, uup_file_offset, uup_buf_len, 0);
  492. //如果升级文件小于UUP_BUF_SIZE,此时收到的是文件起始部分
  493. if (uup_rev_packet < UUP_BUF_SIZE / UUP_PACKET_SIZE) {
  494. if (uup_file_type == UPFILE_TYPE_WHOLE) {
  495. UpFileHeader *pheader = (UpFileHeader *)uup_buf;
  496. pheader->checksum = 0;
  497. } else if (uup_file_type == UPFILE_TYPE_RESOURCE) {
  498. RomHeader *pheader = (RomHeader *)uup_buf;
  499. pheader->checksum = 0;
  500. } else if (uup_file_type == UPFILE_TYPE_ANIMATION) {
  501. BANIHEADER *pheader = (BANIHEADER *)uup_buf;
  502. pheader->checksum = 0;
  503. } else if (uup_file_type == UPFILE_TYPE_APP) {
  504. unsigned int *checksum = (unsigned int *)(uup_buf + APPLDR_CHECKSUM_OFFSET);
  505. *checksum = 0;
  506. }
  507. }
  508. calc_checksum = xcrc32(uup_buf, uup_buf_len, calc_checksum);
  509. }
  510. if (calc_checksum == checksum) {
  511. SendUartString("update finish!\n");
  512. update_progress_set(100);
  513. sysinfo->update_status = UPDATE_STATUS_END;
  514. SaveSysInfo(sysinfo);
  515. uart_send_ack(rx_frame.type, UUP_ACK_OK);
  516. } else {
  517. SendUartString("update checksum fail!\n");
  518. uart_send_ack(rx_frame.type, UUP_ACK_FAIL);
  519. }
  520. } else {
  521. unsigned int *tmp = (unsigned int *)(uup_buf + APPLDR_CHECKSUM_OFFSET);
  522. checksum = *tmp;
  523. *tmp = 0;
  524. calc_checksum = xcrc32(uup_buf, uup_buf_len, calc_checksum);
  525. if (calc_checksum == checksum) {
  526. if (!SpiNorBurn(uup_buf, uup_file_offset, uup_buf_len, 1)) {
  527. if (uup_file_type == UPFILE_TYPE_STEPLDR)
  528. sysinfo->stepldr_size = uup_buf_len;
  529. sysinfo->update_status = UPDATE_STATUS_END;
  530. SaveSysInfo(sysinfo);
  531. uart_send_ack(rx_frame.type, UUP_ACK_OK);
  532. } else {
  533. SendUartString("burn loader fail!\n");
  534. uart_send_ack(rx_frame.type, UUP_ACK_FAIL);
  535. }
  536. } else {
  537. SendUartString("update checksum fail!\n");
  538. uart_send_ack(rx_frame.type, UUP_ACK_FAIL);
  539. }
  540. }
  541. uup_status = UUP_STATE_END;
  542. break;
  543. }
  544. } while (uup_status != UUP_STATE_END);
  545. }