ark1668e_devb_emmc.c 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786
  1. #include <common.h>
  2. #include <dwmmc.h>
  3. #include <malloc.h>
  4. #include <debug_uart.h>
  5. #include <asm-generic/gpio.h>
  6. #include <asm/arch/ark-common.h>
  7. #include <linux/usb/musb.h>
  8. DECLARE_GLOBAL_DATA_PTR;
  9. #define ARK1668_UPDATE_MAGIC "ada7f0c6-7c86-11e9-8f9e-2a86e4085a59"
  10. #define rSYS_BOOT_SAMPLE *((volatile unsigned int *)(0xe4900000))
  11. #define rSYS_SD_CLK_CFG *((volatile unsigned int *)(0xe4900058))
  12. #define rSYS_SD1_CLK_CFG *((volatile unsigned int *)(0xe490005c))
  13. #define rSYS_SOFT_RSTNA *((volatile unsigned int *)(0xe4900074))
  14. #define rSYS_SOFT_RSTNB *((volatile unsigned int *)(0xe4900078))
  15. #define rSYS_DDR_STATUS *((volatile unsigned int *)(0xe4900180))
  16. #define rSYS_DDR_IO_CFG *((volatile unsigned int *)(0xe490019C))
  17. #define rSYS_PAD_CTRL00 *((volatile unsigned int *)(0xe49001c0))
  18. #define rSYS_PAD_CTRL01 *((volatile unsigned int *)(0xe49001c4))
  19. #define rSYS_PAD_CTRL02 *((volatile unsigned int *)(0xe49001c8))
  20. #define rSYS_PAD_CTRL04 *((volatile unsigned int *)(0xe49001d0))
  21. #define rSYS_PAD_CTRL05 *((volatile unsigned int *)(0xe49001d4))
  22. #define rSYS_PAD_CTRL06 *((volatile unsigned int *)(0xe49001d8))
  23. #define rSYS_PAD_CTRL07 *((volatile unsigned int *)(0xe49001dc))
  24. #define rSYS_PAD_CTRL08 *((volatile unsigned int *)(0xe49001e0))
  25. #define rSYS_PAD_CTRL09 *((volatile unsigned int *)(0xe49001e4))
  26. #define rSYS_PAD_CTRL0A *((volatile unsigned int *)(0xe49001e8))
  27. #define rSYS_PAD_CTRL0B *((volatile unsigned int *)(0xe49001ec))
  28. #define rSYS_PAD_CTRL0C *((volatile unsigned int *)(0xe49001f0))
  29. #define rSYS_PAD_CTRL0D *((volatile unsigned int *)(0xe49001f4))
  30. #define rSYS_PAD_CTRL0E *((volatile unsigned int *)(0xe49001f8))
  31. #define rSYS_PAD_CTRL38 *((volatile unsigned int *)(0xe49001fc))
  32. #define rSYS_PAD_CTRL3E *((volatile unsigned int *)(0xe4900200))
  33. #define rSYS_PAD_CTRL0F *((volatile unsigned int *)(0xe4900204))
  34. #define rSYS_CPU_CTL *((volatile unsigned int *)(0xe4900208))
  35. #define rSYS_MFC_GMAC_CTL *((volatile unsigned int *)(0xe490020c))
  36. #define rSYS_DEVICE_CLK_CFG7 *((volatile unsigned int *)(0xe4900230))
  37. #define rSYS_DEVICE_CLK_CFG8 *((volatile unsigned int *)(0xe4900234))
  38. #define rSYS_PAD_CTL3C *((volatile unsigned int *)(0xe49000F0))
  39. #define rWDT_CR *((volatile unsigned int *)(0xe4b00000))
  40. #define MUSB_BASE 0xe0100000
  41. #define CHECKDATA_ERROR 2
  42. extern struct SYS_INFO sys_info;
  43. extern int ark_check_data_from_partition(char *part_name,unsigned int crc_data);
  44. extern int ark_check_data_from_devide(char *file_name,unsigned int crc_data);
  45. extern int get_crc_data_from_device(char *file_name);
  46. extern int get_data_from_media(char *file_name);
  47. extern const struct musb_platform_ops ark_musb_ops;
  48. static struct musb_hdrc_config musb_config = {
  49. .multipoint = 1,
  50. .dyn_fifo = 0,
  51. .num_eps = 6,
  52. .ram_bits = 12
  53. };
  54. static struct musb_hdrc_platform_data musb_platform_data = {
  55. .mode = MUSB_HOST,
  56. .config = &musb_config,
  57. .power = 100,
  58. .platform_ops = &ark_musb_ops,
  59. };
  60. static void dwmci_select_pad(void)
  61. {
  62. unsigned int val;
  63. /* use sd/mmc 0 */
  64. val = rSYS_PAD_CTRL00;
  65. val &= ~((0x7<<18)|(0x7<<15)|(0x7<<12)|(0x7<<9)|(0x7<<6)|(0x7<<3)|(0x7<<0));
  66. val |= ((0x1<<18)|(0x1<<15)|(0x1<<12)|(0x1<<9)|(0x1<<6)|(0x1<<3)|(0x1<<0));
  67. rSYS_PAD_CTRL00 = val;
  68. val = rSYS_PAD_CTRL0E;
  69. val &= ~((0x7<<27)|(0x7<<24));
  70. val |= ((0x1<<27)|(0x1<<24));
  71. rSYS_PAD_CTRL0E = val;
  72. val = rSYS_PAD_CTRL38;
  73. val &= ~((0x7<<9)|(0x7<<6)|(0x7<<3)|(0x7<<0));
  74. val |= ((0x1<<9)|(0x1<<6)|(0x1<<3)|(0x1<<0));
  75. rSYS_PAD_CTRL38 = val;
  76. /* use sd/mmc 1 */
  77. val = rSYS_PAD_CTRL00;
  78. val &= ~((0x7<<27)|(0x7<<24)|(0x7<<21));
  79. val |= ((0x1<<27)|(0x1<<24)|(0x1<<21));
  80. rSYS_PAD_CTRL00 = val;
  81. val = rSYS_PAD_CTRL01;
  82. val &= ~((0x7<<9)|(0x7<<6)|(0x7<<3)|(0x7<<0));
  83. val |= ((0x1<<9)|(0x1<<6)|(0x1<<3)|(0x1<<0));
  84. rSYS_PAD_CTRL01 = val;
  85. /* use sdio wifi/mmc 2*/
  86. val = rSYS_PAD_CTRL01;
  87. val &= ~((0x7<<27)|(0x7<<24)|(0x7<<21)|(0x7<<18)|(0x7<<15)|(0x7<<12));
  88. val |= ((0x1<<27)|(0x1<<24)|(0x1<<21)|(0x1<<18)|(0x1<<15)|(0x1<<12));
  89. rSYS_PAD_CTRL01 = val;
  90. val = rSYS_PAD_CTRL02;
  91. val &= ~(0x7<<0);
  92. val |= (0x1<<0);
  93. rSYS_PAD_CTRL02 = val;
  94. }
  95. void dwmci_reset(void)
  96. {
  97. rSYS_SOFT_RSTNA &= ~((1<<29)|(1<<16));
  98. rSYS_SOFT_RSTNB &= ~(1<<3);
  99. udelay(100);
  100. rSYS_SOFT_RSTNA |= ((1<<29)|(1<<16));
  101. rSYS_SOFT_RSTNB |= (1<<3);
  102. }
  103. static void usb_controller_reset(void)
  104. {
  105. rSYS_PAD_CTRL0F &= ~0xfff;
  106. rSYS_SOFT_RSTNA &= ~(3 << 5);
  107. udelay(100);
  108. rSYS_SOFT_RSTNA |= 3 << 5;
  109. udelay(10);
  110. }
  111. #define ARK_MMC_CLK 48000000
  112. #define ARK_MMC_NUM 3
  113. struct dwmci_host dwmcihost[ARK_MMC_NUM];
  114. static int ark_dwmci_init(char *name,u32 regbase, int bus_width, int index)
  115. {
  116. struct dwmci_host *host = NULL;
  117. host = &dwmcihost[index];
  118. memset(host, 0, sizeof(struct dwmci_host));
  119. dwmci_select_pad();
  120. //dwmci_reset();
  121. /* config clk in sample delay */
  122. //rSYS_SD_CLK_CFG &= ~(0x7f << 13);
  123. //rSYS_SD_CLK_CFG |= 52 << 13;
  124. //rSYS_SD1_CLK_CFG &= ~(0x7f << 13);
  125. //rSYS_SD1_CLK_CFG |= 52 << 13;
  126. /* mmc clk apbpll(480M) / ((4 + 1) * 2) */
  127. rSYS_SD_CLK_CFG &= ~0xfff;
  128. rSYS_SD_CLK_CFG |= (0 << 8) | (1 << 7) | (1 << 5) | 4;
  129. rSYS_SD1_CLK_CFG &= ~0xfff;
  130. rSYS_SD1_CLK_CFG |= (0 << 8) | (1 << 7) | (1 << 5) | 4;
  131. host->name = name;
  132. host->ioaddr = (void *)regbase;
  133. host->buswidth = bus_width;
  134. host->dev_index = index;
  135. host->bus_hz = ARK_MMC_CLK;
  136. host->fifoth_val = 64;
  137. host->fifo_mode = 1;
  138. add_dwmci(host, host->bus_hz, 400000);
  139. return 0;
  140. }
  141. int board_mmc_init(bd_t *bis)
  142. {
  143. // ark_dwmci_init("ARK_MMC0", 0xec400000, 8, 0);
  144. //#ifndef CONFIG_SPL_BUILD
  145. ark_dwmci_init("ARK_MMC1", 0xec800000, 4, 0);
  146. //#endif
  147. // ark_dwmci_init("ARK_MMC2", 0xecc00000, 4, 2);
  148. ark_dwmci_init("ARK_MMC0", 0xec400000, 8, 1);
  149. return 0;
  150. }
  151. int dram_init(void)
  152. {
  153. gd->ram_size = get_ram_size((void *)CONFIG_SYS_SDRAM_BASE,
  154. CONFIG_SYS_SDRAM_SIZE);
  155. return 0;
  156. }
  157. int board_init(void)
  158. {
  159. unsigned int val;
  160. /* watchdog disable */
  161. rWDT_CR = 0;
  162. /* cpu1 disable */
  163. rSYS_CPU_CTL &= ~(1 << 7);
  164. /* cpu cnt clk enable */
  165. rSYS_CPU_CTL |= 1 << 23;
  166. /* nand pad enable */
  167. val = rSYS_PAD_CTRL08;
  168. val &= ~((0x7<<27) | (0x7<<24) | (0x7<<21) | (0x7<<18) | (0x7<<15) | (0x7<<12) | (0x7<<9) | (0x7<<6));
  169. val |= (0x1<<27) | (0x1<<24) | (0x1<<21) | (0x1<<18) | (0x1<<15) | (0x1<<12) | (0x1<<9) | (0x1<<6);
  170. rSYS_PAD_CTRL08 = val;
  171. val = rSYS_PAD_CTRL09;
  172. val &= ~((0x7<<15) | (0x7<<12) | (0x7<<9) | (0x7<<6) | (0x7<<3) | (0x7<<0));
  173. val |= (1<<15) | (1<<12) | (1<<9) | (1<<6) | (1<<3) | (1<<0);//enable nand cle, ale,ren,wen
  174. rSYS_PAD_CTRL09 = val;
  175. /* spi pad enable */
  176. val = rSYS_PAD_CTRL09;
  177. val &= ~((0x7<<27) | (0x7<<24));
  178. val |= (0x2<<27) | (0x2<<24);
  179. rSYS_PAD_CTRL09 = val;
  180. val = rSYS_PAD_CTRL0A;
  181. val &= ~((0x7<<3) | (0x7<<0));
  182. val |= (0x2<<0);
  183. rSYS_PAD_CTRL0A = val;
  184. /* gmac pad enable */
  185. rSYS_PAD_CTRL0C = (1 << 27) | (1 << 24) | (1 << 21) | (1 << 18) | (1 << 15) | (1 << 12) | (1 << 9) |
  186. (1 << 6) | (1 << 3) | (1 << 0);
  187. //rSYS_PAD_CTRL0D = (1 << 24) | (1 << 9) | (1 << 6) | (1 << 3) | (1 << 0);
  188. rSYS_PAD_CTRL0D = (1 << 24) | (1 << 21) | (1 << 18) | (1 << 15) | (1 << 12) | (1 << 9) |
  189. (1 << 6) | (1 << 3) | (1 << 0);
  190. /* gmac tx clk out */
  191. rSYS_PAD_CTRL0F |= (1 << 31);
  192. /* select rgmii interface */
  193. rSYS_MFC_GMAC_CTL &= ~(7 << 1);
  194. rSYS_MFC_GMAC_CTL |= (1 << 1);
  195. /* mac rx clk inv */
  196. rSYS_DEVICE_CLK_CFG7 |= (1 << 1);
  197. /* mac tx clk inv */
  198. rSYS_DEVICE_CLK_CFG8 |= (1 << 7);
  199. /* i2s0 sadata in */
  200. rSYS_PAD_CTRL0F &= ~(1 << 28);
  201. /* i2s1 sadata out */
  202. rSYS_PAD_CTRL0F |= (1 << 29);
  203. /* select pwm0 pad */
  204. rSYS_PAD_CTRL05 &= ~0x7;
  205. rSYS_PAD_CTRL05 |= 1;
  206. return 0;
  207. }
  208. #ifdef CONFIG_BOARD_EARLY_INIT_F
  209. int board_early_init_f(void)
  210. {
  211. #ifdef CONFIG_DEBUG_UART
  212. debug_uart_init();
  213. #endif
  214. return 0;
  215. }
  216. #endif
  217. static int burn_data_2_emmc_partition(char *partition_name)
  218. {
  219. char cmd[128] = { 0 };
  220. int ret = -1;
  221. int file_size = 0;
  222. unsigned int crc_des = 0;
  223. unsigned int *srcdata = (unsigned int *)(env_get_hex("loadaddr", 0));
  224. unsigned int *dstdata = (unsigned int *)(env_get_hex("cmploadaddr", 0));
  225. sprintf(cmd, "emmc erase.part %s", partition_name);
  226. printf("cmd=%s\n", cmd);
  227. ret = run_command(cmd, 0);
  228. if (ret)
  229. return ret;
  230. file_size = env_get_ulong("filesize", 16, 0x2000);
  231. sprintf(cmd, "emmc write %s %s 0x%x", env_get("loadaddr"), partition_name, file_size);
  232. printf("cmd=%s\n", cmd);
  233. ret = run_command(cmd, 0);
  234. if(ret)
  235. {
  236. printf("emmc write data error!!!\n");
  237. return 1;
  238. }
  239. sprintf(cmd, "emmc read %s %s 0x%x",env_get("cmploadaddr"),partition_name, file_size);
  240. printf("cmd=%s\n", cmd);
  241. ret = run_command(cmd, 0);
  242. if(ret)
  243. {
  244. printf("emmc write data error!!!\n");
  245. return 1;
  246. }
  247. crc_des = crc32(0, (const unsigned char *)dstdata, file_size);
  248. ret = ark_check_data_from_partition(partition_name,crc_des);
  249. if(ret)
  250. return 1;
  251. return 0;
  252. }
  253. static int ark_update_emmc_partition(char *partition_name, char *file_name)
  254. {
  255. int ret = 0;
  256. char *update_device = env_get("update_dev_type");
  257. printf("\r\n****** update %s from %s:%s .....\r\n",partition_name,update_device,file_name);
  258. ret = get_data_from_media(file_name);
  259. if (!ret) {
  260. return burn_data_2_emmc_partition(partition_name);
  261. }
  262. return ret;
  263. }
  264. static int ark_update_emmc_rootfs_from_media(char *partition_name)
  265. {
  266. char cmd[32];
  267. int ret = 0;
  268. char *update_device = env_get("update_dev_type");
  269. printf("\r\n****** update %s from %s:rootfs.ext2 .....\r\n",partition_name,update_device);
  270. sprintf(cmd, "fatsize %s %s rootfs.ext2", env_get("update_dev_type"), env_get("update_dev_part"));
  271. printf("cmd = %s\n",cmd);
  272. ret = run_command(cmd, 0);
  273. if(ret)
  274. {
  275. printf("Error:rootfs file maybe not in device!!!\n");
  276. return 2;
  277. }
  278. sprintf(cmd, "updaterootfs %s", partition_name);
  279. printf("cmd=%s\n", cmd);
  280. ret = run_command(cmd, 0);
  281. return ret;
  282. }
  283. static int ark_do_update_from_media(unsigned int updateDevice)
  284. {
  285. char cmd[32];
  286. unsigned int ret = 0;
  287. char *update_dev = NULL;
  288. static char curr_partition[32];
  289. unsigned char update_fdt_name[32];
  290. unsigned char flag_partiton = 0;//0--A partiton,1---B partition
  291. unsigned int dis_pos_x = 0;
  292. unsigned int dis_pos_y = 0;
  293. unsigned int resetuboot = 0;
  294. unsigned int fdtsize = 0;
  295. unsigned int kernelsize = 0;
  296. sprintf(cmd, "mmc dev %s",env_get("emmc_dev_part"));
  297. printf("cmd=%s\n", cmd);
  298. run_command(cmd, 0);
  299. sprintf((char *)cmd,"disconfig 0");
  300. run_command(cmd, 0);
  301. resetuboot = env_get_hex("ubootreset", 0);
  302. // curr_partition = env_get("updata_from_part");
  303. sprintf(curr_partition, "%s", env_get("updata_from_part"));
  304. fdtsize = env_get_hex("fdtsize", 0);
  305. kernelsize = env_get_hex("kernelsize", 0);
  306. mdelay(20);
  307. printf(">>>>>>fdtsize = 0x%x,kernelsize = 0x%x,curr_partition %s\n",fdtsize,kernelsize,curr_partition);
  308. run_command("env default -f -a", 0);
  309. mdelay(500);
  310. if (updateDevice) {
  311. printf("update form mmc...\n");
  312. env_set("update_dev_type", "mmc");
  313. env_set("update_dev_part", env_get("sd_dev_part"));
  314. }else{
  315. printf("update form usb...\n");
  316. env_set("update_dev_type", "usb");
  317. env_set("update_dev_part", "0");
  318. env_set("updata_status", "usb");
  319. }
  320. mdelay(20);
  321. // update_fdt = env_get("boardfdt");
  322. // sprintf(update_fdt_name, "%s", env_get("boardfdt"));
  323. get_crc_data_from_device("crcdata.bin");
  324. dis_pos_x = 6;
  325. dis_pos_y = 20;
  326. //****** update from update ubootspl******
  327. ret = ark_update_emmc_partition("bootstrap", "ubootspl.bin");
  328. mdelay(30);
  329. if(!ret)
  330. {
  331. sprintf(cmd, "setenv bootstrapsize %s",env_get("filesize"));
  332. printf("cmd=%s\n", cmd);
  333. run_command(cmd, 0);
  334. mdelay(30);
  335. sprintf((char *)cmd,"disconfig 5");
  336. run_command(cmd, 0);
  337. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"bootstrap",0);
  338. printf("cmd=%s\n", cmd);
  339. run_command(cmd, 0);
  340. }
  341. else
  342. {
  343. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"bootstrap",1);
  344. printf("cmd=%s\n", cmd);
  345. run_command(cmd, 0);
  346. goto bootoldsys;
  347. }
  348. // ****** update from update uboot******
  349. ret = ark_update_emmc_partition("bootloader", "u-boot.img");
  350. mdelay(30);
  351. if(!ret)
  352. {
  353. sprintf(cmd, "setenv bootloadersize %s",env_get("filesize"));
  354. printf("cmd=%s\n", cmd);
  355. run_command(cmd, 0);
  356. mdelay(30);
  357. sprintf((char *)cmd,"disconfig 10");
  358. run_command(cmd, 0);
  359. dis_pos_y = dis_pos_y + 20;
  360. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"bootloader",0);
  361. printf("cmd=%s\n", cmd);
  362. run_command(cmd, 0);
  363. if(resetuboot == 0)
  364. {
  365. //重新保存设置的数据,以防数据丢失
  366. env_set("ubootreset", "1");
  367. sprintf(cmd, "setenv updata_from_part %s",curr_partition);
  368. printf(">>>>>>>cmd=%s\n",cmd);
  369. run_command(cmd, 0);
  370. mdelay(10);
  371. if(!strcmp(curr_partition, "A"))
  372. {
  373. env_set("updata_from_part", "A");
  374. env_set("kernel_part", "kernel");
  375. env_set("fdt_part", "fdt");
  376. env_set("rootfs_part", "rootfs");
  377. env_set("emmcroot", "/dev/mmcblk0p10 ro");
  378. }
  379. else if(!strcmp(curr_partition, "B"))
  380. {
  381. env_set("updata_from_part", "B");
  382. env_set("kernel_part", "kernel_b");
  383. env_set("fdt_part", "fdt_b");
  384. env_set("rootfs_part", "rootfs_b");
  385. env_set("emmcroot", "/dev/mmcblk0p14 ro");
  386. }
  387. sprintf(cmd, "setenv fdtsize 0x%x",fdtsize);
  388. printf(">>>>>>>cmd=%s\n",cmd);
  389. run_command(cmd, 0);
  390. mdelay(10);
  391. sprintf(cmd, "setenv kernelsize 0x%x",kernelsize);
  392. printf(">>>>>>>cmd=%s\n",cmd);
  393. run_command(cmd, 0);
  394. mdelay(10);
  395. run_command("saveenv", 0);
  396. mdelay(100);
  397. run_command("reset", 0);
  398. while(1);
  399. }
  400. env_set("ubootreset", "0");
  401. mdelay(20);
  402. }
  403. else
  404. {
  405. dis_pos_y = dis_pos_y + 20;
  406. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"bootloader",1);
  407. printf("cmd=%s\n", cmd);
  408. run_command(cmd, 0);
  409. goto bootoldsys;
  410. }
  411. sprintf(update_fdt_name, "%s", env_get("boardfdt"));
  412. update_dev = env_get("update_dev_type");
  413. printf(">>>>>>>>>>update_dev %s\n",update_dev);
  414. if (!strcmp(update_dev, "mmc"))
  415. {
  416. env_set("updata_status", "none");
  417. env_set("updata_from_part", "A");
  418. flag_partiton = 0;
  419. }else if(!strcmp(update_dev, "usb"))
  420. {
  421. env_set("updata_status", "usb");
  422. if(!strcmp(curr_partition, "A"))
  423. flag_partiton = 1;
  424. else if(!strcmp(curr_partition, "B"))
  425. flag_partiton = 0;
  426. }
  427. printf(">>>>>>curr_partition %s,update_fdt:%s,resetuboot %d.....\n",curr_partition,update_fdt_name,resetuboot);
  428. //****** update from update fdt******
  429. if (flag_partiton == 0)
  430. ret = ark_update_emmc_partition("fdt", update_fdt_name);
  431. else
  432. ret = ark_update_emmc_partition("fdt_b", update_fdt_name);
  433. mdelay(30);
  434. if(!ret)
  435. {
  436. if(flag_partiton == 0)
  437. sprintf(cmd, "setenv fdtsize_a %s",env_get("filesize"));
  438. else
  439. sprintf(cmd, "setenv fdtsize_b %s",env_get("filesize"));
  440. run_command(cmd, 0);
  441. printf("cmd=%s\n", cmd);
  442. mdelay(30);
  443. sprintf((char *)cmd,"disconfig 15");
  444. run_command(cmd, 0);
  445. dis_pos_y = dis_pos_y + 20;
  446. if (flag_partiton == 0)
  447. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"fdt",0);
  448. else
  449. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"fdt_b",0);
  450. printf("cmd=%s\n", cmd);
  451. run_command(cmd, 0);
  452. }
  453. else
  454. {
  455. dis_pos_y = dis_pos_y + 20;
  456. if (flag_partiton == 0)
  457. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"fdt",1);
  458. else
  459. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"fdt_b",1);
  460. printf("cmd=%s\n", cmd);
  461. run_command(cmd, 0);
  462. goto bootoldsys;
  463. }
  464. //****** update from update kernel******
  465. if (flag_partiton == 0)
  466. ret = ark_update_emmc_partition("kernel", "zImage");
  467. else
  468. ret = ark_update_emmc_partition("kernel_b", "zImage");
  469. mdelay(30);
  470. if(!ret)
  471. {
  472. if(flag_partiton == 0)
  473. sprintf(cmd, "setenv kernelsize_a %s",env_get("filesize"));
  474. else
  475. sprintf(cmd, "setenv kernelsize_b %s",env_get("filesize"));
  476. printf("cmd=%s\n", cmd);
  477. run_command(cmd, 0);
  478. mdelay(30);
  479. sprintf((char *)cmd,"disconfig 25");
  480. run_command(cmd, 0);
  481. dis_pos_y = dis_pos_y + 20;
  482. if (flag_partiton == 0)
  483. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"kernel",0);
  484. else
  485. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"kernel_b",0);
  486. printf("cmd=%s\n", cmd);
  487. run_command(cmd, 0);
  488. }
  489. else
  490. {
  491. dis_pos_y = dis_pos_y + 20;
  492. if (flag_partiton == 0)
  493. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"kernel",1);
  494. else
  495. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"kernel_b",1);
  496. printf("cmd=%s\n", cmd);
  497. run_command(cmd, 0);
  498. goto bootoldsys;
  499. }
  500. #if 0
  501. // ****** update from update bootanimation******
  502. ret = ark_update_emmc_partition("bootanimation", "bootanimation");
  503. mdelay(30);
  504. if(!ret)
  505. {
  506. sprintf(cmd, "setenv bootanimationsize %s",env_get("filesize"));
  507. run_command(cmd, 0);
  508. printf("cmd=%s\n", cmd);
  509. mdelay(30);
  510. sprintf((char *)cmd,"disconfig 30");
  511. run_command(cmd, 0);
  512. dis_pos_y = dis_pos_y + 20;
  513. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"bootanimation",0);
  514. printf("cmd=%s\n", cmd);
  515. run_command(cmd, 0);
  516. }
  517. else
  518. {
  519. dis_pos_y = dis_pos_y + 20;
  520. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"bootanimation",1);
  521. printf("cmd=%s\n", cmd);
  522. run_command(cmd, 0);
  523. goto bootoldsys;
  524. }
  525. // ****** update from update reversingtrack******
  526. ret = ark_update_emmc_partition("reversingtrack", "reversingtrack");
  527. mdelay(30);
  528. if(!ret)
  529. {
  530. sprintf(cmd, "setenv reversingtracksize %s",env_get("filesize"));
  531. run_command(cmd, 0);
  532. printf("cmd=%s\n", cmd);
  533. mdelay(30);
  534. sprintf((char *)cmd,"disconfig 35");
  535. run_command(cmd, 0);
  536. dis_pos_y = dis_pos_y + 20;
  537. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"reversingtrack",0);
  538. printf("cmd=%s\n", cmd);
  539. run_command(cmd, 0);
  540. }
  541. else
  542. {
  543. dis_pos_y = dis_pos_y + 20;
  544. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"reversingtrack",1);
  545. printf("cmd=%s\n", cmd);
  546. run_command(cmd, 0);
  547. goto bootoldsys;
  548. }
  549. #endif
  550. // ****** update from update uboot back******
  551. ret = ark_update_emmc_partition("bootloader_bak", "u-boot.img");
  552. mdelay(30);
  553. if(!ret)
  554. {
  555. sprintf(cmd, "setenv bootloadersize %s",env_get("filesize"));
  556. run_command(cmd, 0);
  557. printf("cmd=%s\n", cmd);
  558. mdelay(30);
  559. sprintf((char *)cmd,"disconfig 40");
  560. run_command(cmd, 0);
  561. dis_pos_y = dis_pos_y + 20;
  562. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"bootloader_bak",0);
  563. printf("cmd=%s\n", cmd);
  564. run_command(cmd, 0);
  565. }
  566. else
  567. {
  568. dis_pos_y = dis_pos_y + 20;
  569. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"bootloader_bak",1);
  570. printf("cmd=%s\n", cmd);
  571. run_command(cmd, 0);
  572. goto bootoldsys;
  573. }
  574. //****** update from update rootfs******
  575. if (flag_partiton == 0)
  576. ret = ark_update_emmc_rootfs_from_media("rootfs");
  577. else
  578. ret = ark_update_emmc_rootfs_from_media("rootfs_b");
  579. if(!ret)
  580. {
  581. sprintf((char *)cmd,"disconfig 95");
  582. run_command(cmd, 0);
  583. dis_pos_y = dis_pos_y + 20;
  584. if (flag_partiton == 0)
  585. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"rootfs",0);
  586. else
  587. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"rootfs_b",0);
  588. printf("cmd=%s\n", cmd);
  589. run_command(cmd, 0);
  590. }
  591. else if(ret != 2)
  592. {
  593. dis_pos_y = dis_pos_y + 20;
  594. if (flag_partiton == 0)
  595. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"rootfs",1);
  596. else
  597. sprintf((char *)cmd,"disstring %d %d %s %d",dis_pos_x,dis_pos_y,"rootfs_b",1);
  598. printf("cmd=%s\n", cmd);
  599. run_command(cmd, 0);
  600. goto bootoldsys;
  601. }
  602. printf("\r\n **** set the env to partition .....\r\n");
  603. //mmc update set part A
  604. if(!strcmp(update_dev, "mmc"))
  605. {
  606. env_set("updata_from_part", "A");
  607. env_set("kernel_part", "kernel");
  608. env_set("fdt_part", "fdt");
  609. env_set("rootfs_part", "rootfs");
  610. env_set("emmcroot", "/dev/mmcblk0p10 ro");
  611. sprintf(cmd, "setenv fdtsize %s",env_get("fdtsize_a"));
  612. run_command(cmd, 0);
  613. printf("cmd=%s\n", cmd);
  614. mdelay(30);
  615. sprintf(cmd, "setenv kernelsize %s",env_get("kernelsize_a"));
  616. run_command(cmd, 0);
  617. printf("cmd=%s\n", cmd);
  618. mdelay(30);
  619. }
  620. else if(!strcmp(update_dev, "usb"))
  621. {
  622. printf(">>>>>>>>>curr_partition %s \n",curr_partition);
  623. if (flag_partiton == 1)
  624. {
  625. env_set("updata_from_part", "B");
  626. env_set("kernel_part", "kernel_b");
  627. env_set("fdt_part", "fdt_b");
  628. env_set("rootfs_part", "rootfs_b");
  629. env_set("emmcroot", "/dev/mmcblk0p14 ro");
  630. sprintf(cmd, "setenv fdtsize %s",env_get("fdtsize_b"));
  631. run_command(cmd, 0);
  632. printf("cmd=%s\n", cmd);
  633. mdelay(30);
  634. sprintf(cmd, "setenv kernelsize %s",env_get("kernelsize_b"));
  635. run_command(cmd, 0);
  636. printf("cmd=%s\n", cmd);
  637. mdelay(30);
  638. }
  639. else if (flag_partiton == 0)
  640. {
  641. env_set("updata_from_part", "A");
  642. env_set("kernel_part", "kernel");
  643. env_set("fdt_part", "fdt");
  644. env_set("rootfs_part", "rootfs");
  645. env_set("emmcroot", "/dev/mmcblk0p10 ro");
  646. sprintf(cmd, "setenv fdtsize %s",env_get("fdtsize_a"));
  647. run_command(cmd, 0);
  648. printf("cmd=%s\n", cmd);
  649. mdelay(30);
  650. sprintf(cmd, "setenv kernelsize %s",env_get("kernelsize_a"));
  651. run_command(cmd, 0);
  652. printf("cmd=%s\n", cmd);
  653. mdelay(30);
  654. }
  655. }
  656. mdelay(5);
  657. env_set("need_update", "no");
  658. mdelay(5);
  659. env_set("updata_status", "none");
  660. sprintf(cmd, "saveenv");
  661. printf("cmd=%s\n", cmd);
  662. run_command(cmd, 0);
  663. mdelay(30);
  664. sprintf((char *)cmd,"disconfig 100");
  665. run_command(cmd, 0);
  666. printf("\r\n **** update the device ok! .....\r\n");
  667. return 0;
  668. bootoldsys:
  669. if(!strcmp(curr_partition, "A"))
  670. {
  671. env_set("updata_from_part", "A");
  672. env_set("kernel_part", "kernel");
  673. env_set("fdt_part", "fdt");
  674. env_set("rootfs_part", "rootfs");
  675. env_set("emmcroot", "/dev/mmcblk0p14 ro");
  676. sprintf(cmd, "setenv fdtsize %s",fdtsize);
  677. run_command(cmd, 0);
  678. printf("cmd=%s\n", cmd);
  679. mdelay(30);
  680. sprintf(cmd, "setenv kernelsize %s",kernelsize);
  681. run_command(cmd, 0);
  682. printf("cmd=%s\n", cmd);
  683. mdelay(30);
  684. }
  685. else if(!strcmp(curr_partition, "B"))
  686. {
  687. env_set("updata_from_part", "B");
  688. env_set("kernel_part", "kernel_b");
  689. env_set("fdt_part", "fdt_b");
  690. env_set("rootfs_part", "rootfs_b");
  691. env_set("emmcroot", "/dev/mmcblk0p10 ro");
  692. sprintf(cmd, "setenv fdtsize 0x%x",fdtsize);
  693. run_command(cmd, 0);
  694. printf("cmd=%s\n", cmd);
  695. mdelay(30);
  696. sprintf(cmd, "setenv kernelsize 0x%x",kernelsize);
  697. run_command(cmd, 0);
  698. printf("cmd=%s\n", cmd);
  699. mdelay(30);
  700. }
  701. env_set("updata_status", "error");
  702. sprintf(cmd, "saveenv");
  703. printf("cmd=%s\n", cmd);
  704. run_command(cmd, 0);
  705. mdelay(20);
  706. sprintf((char *)cmd,"disconfig 100");
  707. run_command(cmd, 0);
  708. return 1;
  709. }
  710. int board_late_init(void)
  711. {
  712. char cmd[128];
  713. char *update_from_ota = NULL,*need_update = NULL;
  714. unsigned int loadaddr;
  715. int do_update = 0, update_from_mmc = 1;
  716. int update_detect = 0;//0:no update 1:need_update env 2:usb update boot 3:sd update boot
  717. #ifdef CONFIG_USB_MUSB_HOST
  718. usb_controller_reset();
  719. musb_register(&musb_platform_data, NULL, (void *)MUSB_BASE);
  720. #endif
  721. update_from_ota = env_get("update_from_ota");
  722. printf("update_from_ota %s\n",update_from_ota);
  723. need_update = env_get("need_update");
  724. if (!strcmp(need_update, "yes"))
  725. update_detect = 1;
  726. else if (((rSYS_BOOT_SAMPLE >> 2) & 3) == 1)
  727. update_detect = 2;
  728. else if (((rSYS_BOOT_SAMPLE >> 2) & 3) == 2)
  729. update_detect = 3;
  730. //由于usb升级检测的时候,会需要一段时间所以这个地方需要时间长一些,设置6s
  731. ark_watchdog_start(6000);
  732. printf("update_detect=%d.\n", update_detect);
  733. if (update_detect) {
  734. loadaddr = env_get_hex("loadaddr", 0);
  735. if (loadaddr)
  736. memset((void*)loadaddr, 0, strlen(ARK1668_UPDATE_MAGIC));
  737. if (update_detect == 1 || update_detect == 3) {
  738. sprintf(cmd, "fatload %s %s %s update-magic", "mmc", env_get("update_dev_part"), env_get("loadaddr"));
  739. run_command(cmd, 0);
  740. if (loadaddr && !memcmp((void *)loadaddr, ARK1668_UPDATE_MAGIC, strlen(ARK1668_UPDATE_MAGIC))) {
  741. do_update = 1;
  742. goto update_done;
  743. } else {
  744. printf("Wrong update magic, do not update from mmc.\n");
  745. }
  746. }
  747. #ifdef CONFIG_USB_MUSB_HOST
  748. if (update_detect == 1 || update_detect == 2) {
  749. run_command("usb start", 0);
  750. sprintf(cmd, "fatload %s %s %s update-magic", "usb", "0", env_get("loadaddr"));
  751. run_command(cmd, 0);
  752. if (loadaddr && !memcmp((void *)loadaddr, ARK1668_UPDATE_MAGIC, strlen(ARK1668_UPDATE_MAGIC))) {
  753. do_update = 1;
  754. update_from_mmc = 0;
  755. goto update_done;
  756. } else {
  757. printf("Wrong update magic, do not update from usb.\n");
  758. }
  759. }
  760. #endif
  761. }
  762. if(!strcmp(update_from_ota, "yes")){
  763. do_update = 0;
  764. //升级的时候关闭看门够功能
  765. ark_watchdog_stop();
  766. sprintf(cmd, "update_from_emmc_ota");
  767. printf("cmd=%s\n", cmd);
  768. run_command(cmd, 0);
  769. }
  770. update_done:
  771. if (do_update) {
  772. //升级的时候关闭看门够功能
  773. ark_watchdog_stop();
  774. run_command("emmc erase.part userdata", 0);
  775. env_set("need_update", "no");
  776. env_set("do_update", "yes");
  777. ark_do_update_from_media(update_from_mmc);
  778. } else {
  779. env_set("do_update", "no");
  780. }
  781. return 0;
  782. }