main.c 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <fcntl.h>
  4. #include <linux/types.h>
  5. #include <unistd.h>
  6. #include <stdint.h>
  7. #include <string.h>
  8. #include <errno.h>
  9. #include <pthread.h>
  10. #include <fcntl.h>
  11. #include <sys/socket.h>
  12. #include <netdb.h> /* getaddrinfo(3) et al. */
  13. #include <netinet/in.h> /* sockaddr_in & sockaddr_in6 definition. */
  14. #include <net/if.h>
  15. #include <sys/prctl.h>
  16. #include "driver.h"
  17. #include "hal_interface_api.h"
  18. #include "main.h"
  19. int main()
  20. {
  21. int i;
  22. uint8_t *buf;//[64*1024+1] = {0}; //4KB, one sector
  23. // uint8_t *chkBuf;//[4*1024] = {0};
  24. FILE *fp;
  25. size_t len, totalSize = 1, writeSize = 0;
  26. FILE *fprogress;
  27. FILE *fpErase;
  28. FILE *fpVerify;
  29. uint8_t progressStr[10] = {0};
  30. uint8_t rate = 0;
  31. int retry = 3;
  32. buf = malloc(32*1024 + 50);
  33. // chkBuf = malloc(64*1024);
  34. fp = fopen("/var/www/goahead/tmp/tmp.uImage", "rb");
  35. if(NULL == fp)
  36. {
  37. printf("Open image file fail!\n");
  38. return -1;
  39. }
  40. //get file total size
  41. fseek(fp, 0, SEEK_END);
  42. totalSize = ftell(fp);
  43. fseek(fp, 0, SEEK_SET);
  44. printf("Image size: %d\n", totalSize);
  45. //开始擦除
  46. retry = 3;
  47. do
  48. {
  49. fpErase = fopen("/var/www/goahead/tmp/Erase.log", "w");
  50. if(NULL == fpErase)
  51. {
  52. printf("Create Erase.log file fail! retry...\n");
  53. retry--;
  54. usleep(10);
  55. }
  56. else
  57. break;
  58. }while(retry);
  59. if(fpErase != NULL)
  60. fputs("Erasing", fpErase);
  61. fclose(fpErase);
  62. printf("Chip erase ...\n");
  63. sf_chip_erase(5);
  64. printf("Chip erase finished!\n");
  65. retry = 3;
  66. do{
  67. fpErase = fopen("/var/www/goahead/tmp/Erase.log", "w");
  68. if(NULL == fpErase)
  69. {
  70. printf("Create Erase.log file fail! retry...\n");
  71. retry--;
  72. usleep(10);
  73. }
  74. else
  75. break;
  76. }while(retry);
  77. if(fpErase != NULL)
  78. fputs("Erase OK", fpErase);
  79. fclose(fpErase);
  80. //用来保存更新的进度
  81. fprogress = fopen("/var/www/goahead/tmp/UpdateProgress.log", "w");
  82. if(NULL == fprogress)
  83. {
  84. printf("Create UpdateProgress.log file fail!\n");
  85. //return -1;
  86. }
  87. else
  88. {
  89. fputs("0", fprogress);
  90. }
  91. fclose(fprogress);
  92. do{
  93. len = fread(buf, 1, 32*1024, fp);
  94. if(len <= 0)
  95. {
  96. close(fp);
  97. printf("Read file fail!\n");
  98. break;
  99. }
  100. //update Flash
  101. //sf_sector_erase(5, writeSize);
  102. sf_write(5, writeSize, buf, len);
  103. // sf_read(5, writeSize, chkBuf, len);
  104. // if(memcmp(buf, chkBuf, len) != 0)
  105. // {
  106. // printf("---> chk fail, offset %#x, len %d\n", writeSize, len);
  107. // break;
  108. // }
  109. writeSize += len;
  110. rate = (writeSize*100)/totalSize;
  111. printf("writeSize: %d, len: %d, rate: %d\n", writeSize, len, rate);
  112. //用来保存更新的进度
  113. fprogress = fopen("/var/www/goahead/tmp/UpdateProgress.log", "w");
  114. if(NULL == fprogress)
  115. {
  116. printf("Create UpdateProgress.log file fail!\n");
  117. //return -1;
  118. }
  119. else
  120. {
  121. sprintf(progressStr, "%d", rate);
  122. fputs(progressStr, fprogress);
  123. }
  124. fclose(fprogress);
  125. }while(writeSize < totalSize);
  126. close(fp);
  127. printf("Update Flash finish.\n");
  128. //Verify
  129. printf("Verigy successful.\n");
  130. //用来保存校验结果
  131. retry = 3;
  132. do{
  133. fpVerify = fopen("/var/www/goahead/tmp/Verify.log", "w");
  134. if(NULL == fpVerify)
  135. {
  136. printf("Create UpdateProgress.log file fail! retry...\n");
  137. retry--;
  138. usleep(10);
  139. }
  140. else
  141. break;
  142. }while(retry);
  143. if(fpVerify != NULL)
  144. fputs("Verify OK", fpVerify);
  145. fclose(fpVerify);
  146. fclose(fp);
  147. free(buf);
  148. // free(chkBuf);
  149. return 0;
  150. }