ark1668e_devb_emmc.c 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733
  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. #include <asm/io.h>
  9. DECLARE_GLOBAL_DATA_PTR;
  10. #define ARK1668_UPDATE_MAGIC "ada7f0c6-7c86-11e9-8f9e-2a86e4085a59"
  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. /***************************add by wdz*****************************/
  43. #define GPIO_SWPORTA_DR 0x00
  44. #define GPIO_SWPORTA_DDR 0x04
  45. #define GPIO_SWPORTA_CTL 0x08
  46. #define GPIO_SWPORTA_INTEN 0x30
  47. #define GPIO_SWPORTA_INTMASK 0x34
  48. #define GPIO_SWPORTA_INTTYPE_LEVEL 0x38
  49. #define GPIO_SWPORTA_INT_POLARITY 0x3c
  50. #define GPIO_SWPORTA_INTSTATUS 0x40
  51. #define GPIO_SWPORTA_RAW_INTSTATUS 0x44
  52. #define GPIO_SWPORTA_DEBOUNCE 0x48
  53. #define GPIO_SWPORTA_EOI 0x4c
  54. #define GPIO_SWPORTA_EXT_PORTA 0x50
  55. #define GPIO_SWPORTA_EXT_PORTB 0x54
  56. #define GPIO_SWPORTA_EXT_PORTC 0x58
  57. #define GPIO_SWPORTA_EXT_PORTD 0x5c
  58. #define GPIO_SWPORTA_LS_SYNC 0x60
  59. #define GPIO_SWPORTA_ID_CODE 0x64
  60. #define GPIO_SWPORTA_INT_BOTHEDGE 0x68
  61. #define GPIO_SWPORTA_VER_ID_CODE 0x6C
  62. #define GPIO_SWPORTA_CONFIG_REG2 0x70
  63. #define GPIO_SWPORTA_CONFIG_REG1 0x74
  64. #define GPIO_BANK_NUM 32
  65. static unsigned long gpio_bases[] = {
  66. CONFIG_GPIO_BASEADDR,
  67. CONFIG_GPIO_BASEADDR + 0x80,
  68. CONFIG_GPIO_BASEADDR + 0x100,
  69. CONFIG_GPIO_BASEADDR + 0x180,
  70. CONFIG_GPIO_BASEADDR + 0x200,
  71. CONFIG_GPIO_BASEADDR + 0x280,
  72. };
  73. static inline int GPIO_BANK(unsigned gpio)
  74. {
  75. return gpio >> 5;
  76. }
  77. static inline int GPIO_OFFSET(unsigned gpio)
  78. {
  79. return gpio & 0x1F;
  80. }
  81. static inline void *GPIO_MODREG(unsigned gpio)
  82. {
  83. return (void*)(gpio_bases[GPIO_BANK(gpio)] + GPIO_SWPORTA_DDR);
  84. }
  85. static inline void *GPIO_WDATAREG(unsigned gpio)
  86. {
  87. return (void*)(gpio_bases[GPIO_BANK(gpio)] + GPIO_SWPORTA_DR);
  88. }
  89. static inline void *GPIO_RDATAREG(unsigned gpio)
  90. {
  91. return (void*)(gpio_bases[GPIO_BANK(gpio)] + GPIO_SWPORTA_EXT_PORTA);
  92. }
  93. int arke_gpio_request(unsigned gpio, const char *label)
  94. {
  95. return 0;
  96. }
  97. int arke_gpio_free(unsigned gpio)
  98. {
  99. return 0;
  100. }
  101. int arke_gpio_direction_input(unsigned gpio)
  102. {
  103. writel(readl(GPIO_MODREG(gpio)) & ~(1 << GPIO_OFFSET(gpio)), GPIO_MODREG(gpio));
  104. return 0;
  105. }
  106. int arke_gpio_direction_output(unsigned gpio, int value)
  107. {
  108. writel(readl(GPIO_MODREG(gpio)) | (1 << GPIO_OFFSET(gpio)), GPIO_MODREG(gpio));
  109. if (value)
  110. writel(readl(GPIO_WDATAREG(gpio)) | (1 << GPIO_OFFSET(gpio)), GPIO_WDATAREG(gpio));
  111. else
  112. writel(readl(GPIO_WDATAREG(gpio)) & ~(1 << GPIO_OFFSET(gpio)), GPIO_WDATAREG(gpio));
  113. return 0;
  114. }
  115. int arke_gpio_get_value(unsigned gpio)
  116. {
  117. return !!(readl(GPIO_RDATAREG(gpio)) & (1 << GPIO_OFFSET(gpio)));
  118. }
  119. int arke_gpio_set_value(unsigned gpio, int value)
  120. {
  121. if (value)
  122. writel(readl(GPIO_WDATAREG(gpio)) | (1 << GPIO_OFFSET(gpio)), GPIO_WDATAREG(gpio));
  123. else
  124. writel(readl(GPIO_WDATAREG(gpio)) & ~(1 << GPIO_OFFSET(gpio)), GPIO_WDATAREG(gpio));
  125. return 0;
  126. }
  127. /************************add by wdz*************************/
  128. extern const struct musb_platform_ops ark_musb_ops;
  129. static struct musb_hdrc_config musb_config = {
  130. .multipoint = 1,
  131. .dyn_fifo = 0,
  132. .num_eps = 6,
  133. .ram_bits = 12
  134. };
  135. static struct musb_hdrc_platform_data musb_platform_data = {
  136. .mode = MUSB_HOST,
  137. .config = &musb_config,
  138. .power = 100,
  139. .platform_ops = &ark_musb_ops,
  140. };
  141. static void dwmci_select_pad(void)
  142. {
  143. unsigned int val;
  144. /* use sd/mmc 0 */
  145. val = rSYS_PAD_CTRL00;
  146. val &= ~((0x7<<18)|(0x7<<15)|(0x7<<12)|(0x7<<9)|(0x7<<6)|(0x7<<3)|(0x7<<0));
  147. val |= ((0x1<<18)|(0x1<<15)|(0x1<<12)|(0x1<<9)|(0x1<<6)|(0x1<<3)|(0x1<<0));
  148. rSYS_PAD_CTRL00 = val;
  149. val = rSYS_PAD_CTRL0E;
  150. val &= ~((0x7<<27)|(0x7<<24));
  151. val |= ((0x1<<27)|(0x1<<24));
  152. rSYS_PAD_CTRL0E = val;
  153. val = rSYS_PAD_CTRL38;
  154. val &= ~((0x7<<9)|(0x7<<6)|(0x7<<3)|(0x7<<0));
  155. val |= ((0x1<<9)|(0x1<<6)|(0x1<<3)|(0x1<<0));
  156. rSYS_PAD_CTRL38 = val;
  157. /* use sd/mmc 1 */
  158. val = rSYS_PAD_CTRL00;
  159. val &= ~((0x7<<27)|(0x7<<24)|(0x7<<21));
  160. val |= ((0x1<<27)|(0x1<<24)|(0x1<<21));
  161. rSYS_PAD_CTRL00 = val;
  162. val = rSYS_PAD_CTRL01;
  163. val &= ~((0x7<<9)|(0x7<<6)|(0x7<<3)|(0x7<<0));
  164. val |= ((0x1<<9)|(0x1<<6)|(0x1<<3)|(0x1<<0));
  165. rSYS_PAD_CTRL01 = val;
  166. /* use sdio wifi/mmc 2*/
  167. val = rSYS_PAD_CTRL01;
  168. val &= ~((0x7<<27)|(0x7<<24)|(0x7<<21)|(0x7<<18)|(0x7<<15)|(0x7<<12));
  169. val |= ((0x1<<27)|(0x1<<24)|(0x1<<21)|(0x1<<18)|(0x1<<15)|(0x1<<12));
  170. rSYS_PAD_CTRL01 = val;
  171. val = rSYS_PAD_CTRL02;
  172. val &= ~(0x7<<0);
  173. val |= (0x1<<0);
  174. rSYS_PAD_CTRL02 = val;
  175. }
  176. void dwmci_reset(void)
  177. {
  178. rSYS_SOFT_RSTNA &= ~((1<<29)|(1<<16));
  179. rSYS_SOFT_RSTNB &= ~(1<<3);
  180. udelay(100);
  181. rSYS_SOFT_RSTNA |= ((1<<29)|(1<<16));
  182. rSYS_SOFT_RSTNB |= (1<<3);
  183. }
  184. static void usb_controller_reset(void)
  185. {
  186. rSYS_PAD_CTRL0F &= ~0xfff;
  187. rSYS_SOFT_RSTNA &= ~(3 << 5);
  188. udelay(100);
  189. rSYS_SOFT_RSTNA |= 3 << 5;
  190. udelay(10);
  191. }
  192. #define ARK_MMC_CLK 24000000
  193. struct dwmci_host dwmcihost[2];
  194. static int ark_dwmci_init(char *name,u32 regbase, int bus_width, int index)
  195. {
  196. struct dwmci_host *host = NULL;
  197. host = &dwmcihost[index];
  198. memset(host, 0, sizeof(struct dwmci_host));
  199. dwmci_select_pad();
  200. //dwmci_reset();
  201. /* config clk in sample delay */
  202. //rSYS_SD_CLK_CFG &= ~(0x7f << 13);
  203. //rSYS_SD_CLK_CFG |= 52 << 13;
  204. //rSYS_SD1_CLK_CFG &= ~(0x7f << 13);
  205. //rSYS_SD1_CLK_CFG |= 52 << 13;
  206. host->name = name;
  207. host->ioaddr = (void *)regbase;
  208. host->buswidth = bus_width;
  209. host->dev_index = index;
  210. host->bus_hz = ARK_MMC_CLK;
  211. host->fifoth_val = 64;
  212. host->fifo_mode = 1;
  213. add_dwmci(host, host->bus_hz, 400000);
  214. return 0;
  215. }
  216. int board_mmc_init(bd_t *bis)
  217. {
  218. // ark_dwmci_init("ARK_MMC0", 0xec400000, 8, 0);
  219. //#ifndef CONFIG_SPL_BUILD
  220. ark_dwmci_init("ARK_MMC1", 0xec800000, 4, 0);
  221. //#endif
  222. // ark_dwmci_init("ARK_MMC2", 0xecc00000, 4, 2);
  223. ark_dwmci_init("ARK_MMC0", 0xec400000, 8, 1);
  224. return 0;
  225. }
  226. int dram_init(void)
  227. {
  228. gd->ram_size = get_ram_size((void *)CONFIG_SYS_SDRAM_BASE,
  229. CONFIG_SYS_SDRAM_SIZE);
  230. return 0;
  231. }
  232. int board_init(void)
  233. {
  234. unsigned int val;
  235. /* watchdog disable */
  236. rWDT_CR = 0;
  237. /* cpu1 disable */
  238. rSYS_CPU_CTL &= ~(1 << 7);
  239. /* cpu cnt clk enable */
  240. rSYS_CPU_CTL |= 1 << 23;
  241. /* nand pad enable */
  242. val = rSYS_PAD_CTRL08;
  243. val &= ~((0x7<<27) | (0x7<<24) | (0x7<<21) | (0x7<<18) | (0x7<<15) | (0x7<<12) | (0x7<<9) | (0x7<<6));
  244. val |= (0x1<<27) | (0x1<<24) | (0x1<<21) | (0x1<<18) | (0x1<<15) | (0x1<<12) | (0x1<<9) | (0x1<<6);
  245. rSYS_PAD_CTRL08 = val;
  246. val = rSYS_PAD_CTRL09;
  247. val &= ~((0x7<<15) | (0x7<<12) | (0x7<<9) | (0x7<<6) | (0x7<<3) | (0x7<<0));
  248. val |= (1<<15) | (1<<12) | (1<<9) | (1<<6) | (1<<3) | (1<<0);//enable nand cle, ale,ren,wen
  249. rSYS_PAD_CTRL09 = val;
  250. /* spi pad enable */
  251. val = rSYS_PAD_CTRL09;
  252. val &= ~((0x7<<27) | (0x7<<24));
  253. val |= (0x2<<27) | (0x2<<24);
  254. rSYS_PAD_CTRL09 = val;
  255. val = rSYS_PAD_CTRL0A;
  256. val &= ~((0x7<<3) | (0x7<<0));
  257. val |= (0x2<<0);
  258. rSYS_PAD_CTRL0A = val;
  259. /* gmac pad enable */
  260. rSYS_PAD_CTRL0C = (1 << 27) | (1 << 24) | (1 << 21) | (1 << 18) | (1 << 15) | (1 << 12) | (1 << 9) |
  261. (1 << 6) | (1 << 3) | (1 << 0);
  262. //rSYS_PAD_CTRL0D = (1 << 24) | (1 << 9) | (1 << 6) | (1 << 3) | (1 << 0);
  263. rSYS_PAD_CTRL0D = (1 << 24) | (1 << 21) | (1 << 18) | (1 << 15) | (1 << 12) | (1 << 9) |
  264. (1 << 6) | (1 << 3) | (1 << 0);
  265. /* gmac tx clk out */
  266. rSYS_PAD_CTRL0F |= (1 << 31);
  267. /* select rgmii interface */
  268. rSYS_MFC_GMAC_CTL &= ~(7 << 1);
  269. rSYS_MFC_GMAC_CTL |= (1 << 1);
  270. /* mac rx clk inv */
  271. rSYS_DEVICE_CLK_CFG7 |= (1 << 1);
  272. /* mac tx clk inv */
  273. rSYS_DEVICE_CLK_CFG8 |= (1 << 7);
  274. /* i2s0 sadata in */
  275. rSYS_PAD_CTRL0F &= ~(1 << 28);
  276. /* i2s1 sadata out */
  277. rSYS_PAD_CTRL0F |= (1 << 29);
  278. /* select pwm0 pad */
  279. rSYS_PAD_CTRL05 &= ~0x7;
  280. rSYS_PAD_CTRL05 |= 1;
  281. return 0;
  282. }
  283. #ifdef CONFIG_BOARD_EARLY_INIT_F
  284. int board_early_init_f(void)
  285. {
  286. #ifdef CONFIG_DEBUG_UART
  287. debug_uart_init();
  288. #endif
  289. return 0;
  290. }
  291. #endif
  292. static int get_data_from_media(char *file_name)
  293. {
  294. int ret = -1;
  295. char cmd[128] = { 0 };
  296. printf("file_name=%s\n", file_name);
  297. sprintf(cmd, "fatload %s %s %s %s",env_get("update_dev_type"),env_get("update_dev_part"),env_get("loadaddr"), file_name);
  298. printf("cmd=%s\n", cmd);
  299. ret = run_command(cmd, 0);
  300. return ret;
  301. }
  302. static int burn_data_2_emmc_partition(char *partition_name)
  303. {
  304. char cmd[128] = { 0 };
  305. int ret = -1;
  306. int file_size = 0;
  307. unsigned int i;
  308. unsigned int *srcdata = (unsigned int *)(env_get_hex("loadaddr", 0));
  309. unsigned int *dstdata = (unsigned int *)(env_get_hex("cmploadaddr", 0));
  310. sprintf(cmd, "emmc erase.part %s", partition_name);
  311. printf("cmd=%s\n", cmd);
  312. ret = run_command(cmd, 0);
  313. if (ret)
  314. return ret;
  315. file_size = env_get_ulong("filesize", 16, 0x2000);
  316. sprintf(cmd, "emmc write %s %s 0x%x", env_get("loadaddr"), partition_name, file_size);
  317. printf("cmd=%s\n", cmd);
  318. ret = run_command(cmd, 0);
  319. sprintf(cmd, "emmc read %s %s 0x%x",env_get("cmploadaddr"),partition_name, file_size);
  320. printf("cmd=%s\n", cmd);
  321. ret = run_command(cmd, 0);
  322. for(i = 0;i< file_size/4;i++)
  323. if(srcdata[i] != dstdata[i])
  324. {
  325. printf("check %s data error!!!\n",partition_name);
  326. return CHECKDATA_ERROR;
  327. }
  328. return ret;
  329. }
  330. static int ark_update_emmc_partition(char *partition_name, char *file_name)
  331. {
  332. int ret;
  333. ret = get_data_from_media(file_name);
  334. if (!ret) {
  335. return burn_data_2_emmc_partition(partition_name);
  336. }
  337. return ret;
  338. }
  339. static int ark_update_emmc_rootfs_from_media(char *partition_name)
  340. {
  341. char cmd[32];
  342. int ret;
  343. sprintf(cmd, "updaterootfs %s", partition_name);
  344. printf("cmd=%s\n", cmd);
  345. ret = run_command(cmd, 0);
  346. return ret;
  347. }
  348. static int do_update_from_media(void)
  349. {
  350. char cmd[32];
  351. unsigned int ret = 0;
  352. char *update_dev = NULL;
  353. char *curr_partition = NULL;
  354. char *update_fdt = NULL;
  355. unsigned char flag_partiton = 0 ;//0--A partiton,1---B partition
  356. sprintf(cmd, "mmc dev %s",env_get("emmc_dev_part"));
  357. printf("cmd=%s\n", cmd);
  358. run_command(cmd, 0);
  359. sprintf((char *)cmd,"disconfig 0");
  360. run_command(cmd, 0);
  361. update_fdt = env_get("emmcfdt");
  362. printf("update_fdt:%s\n", update_fdt);
  363. update_dev = env_get("update_dev_type");
  364. if (!strcmp(update_dev, "mmc"))
  365. {
  366. env_set("updata_status", "none");
  367. env_set("updata_from_part", "A");
  368. curr_partition = env_get("updata_from_part");
  369. if(!strcmp(curr_partition, "A"))
  370. flag_partiton = 0;
  371. else if(!strcmp(curr_partition, "B"))
  372. flag_partiton = 1;
  373. }else if(!strcmp(update_dev, "usb"))
  374. {
  375. env_set("updata_status", "usb");
  376. curr_partition = env_get("updata_from_part");
  377. if(!strcmp(curr_partition, "A"))
  378. flag_partiton = 1;
  379. else if(!strcmp(curr_partition, "B"))
  380. flag_partiton = 0;
  381. }
  382. printf("\r\n **** update from update ubootspl .....\r\n");
  383. ret = ark_update_emmc_partition("bootstrap", "ubootspl.bin");
  384. mdelay(30);
  385. if(!ret)
  386. {
  387. sprintf(cmd, "setenv bootstrapsize %s",env_get("filesize"));
  388. printf("cmd=%s\n", cmd);
  389. run_command(cmd, 0);
  390. mdelay(30);
  391. sprintf((char *)cmd,"disconfig 5");
  392. run_command(cmd, 0);
  393. }
  394. else if(ret == CHECKDATA_ERROR)
  395. goto bootoldsys;
  396. printf("\r\n **** update from update uboot .....\r\n");
  397. ret = ark_update_emmc_partition("bootloader", "u-boot.img");
  398. mdelay(30);
  399. if(!ret)
  400. {
  401. sprintf(cmd, "setenv bootloadersize %s",env_get("filesize"));
  402. printf("cmd=%s\n", cmd);
  403. run_command(cmd, 0);
  404. mdelay(30);
  405. sprintf((char *)cmd,"disconfig 10");
  406. run_command(cmd, 0);
  407. }
  408. else if(ret == CHECKDATA_ERROR)
  409. goto bootoldsys;
  410. printf("\r\n **** update from update fdt .....\r\n");
  411. if (flag_partiton == 0)
  412. ret = ark_update_emmc_partition("fdt", update_fdt);
  413. else
  414. ret = ark_update_emmc_partition("fdt_b", update_fdt);
  415. mdelay(30);
  416. if(!ret)
  417. {
  418. sprintf(cmd, "setenv fdtsize %s",env_get("filesize"));
  419. run_command(cmd, 0);
  420. printf("cmd=%s\n", cmd);
  421. mdelay(30);
  422. sprintf((char *)cmd,"disconfig 15");
  423. run_command(cmd, 0);
  424. }
  425. else if(ret == CHECKDATA_ERROR)
  426. goto bootoldsys;
  427. printf("\r\n **** update from update kernel .....\r\n");
  428. if (flag_partiton == 0)
  429. ret = ark_update_emmc_partition("kernel", "zImage");
  430. else
  431. ret = ark_update_emmc_partition("kernel_b", "zImage");
  432. mdelay(30);
  433. if(!ret)
  434. {
  435. sprintf(cmd, "setenv kernelsize %s",env_get("filesize"));
  436. printf("cmd=%s\n", cmd);
  437. run_command(cmd, 0);
  438. mdelay(30);
  439. sprintf((char *)cmd,"disconfig 25");
  440. run_command(cmd, 0);
  441. }
  442. else if(ret == CHECKDATA_ERROR)
  443. goto bootoldsys;
  444. printf("\r\n **** update from update bootanimation .....\r\n");
  445. ret = ark_update_emmc_partition("bootanimation", "bootanimation");
  446. mdelay(30);
  447. if(!ret)
  448. {
  449. sprintf(cmd, "setenv bootanimationsize %s",env_get("filesize"));
  450. run_command(cmd, 0);
  451. printf("cmd=%s\n", cmd);
  452. mdelay(30);
  453. sprintf((char *)cmd,"disconfig 30");
  454. run_command(cmd, 0);
  455. }
  456. else if(ret == CHECKDATA_ERROR)
  457. goto bootoldsys;
  458. printf("\r\n **** update from update reversingtrack .....\r\n");
  459. ret = ark_update_emmc_partition("reversingtrack", "reversingtrack");
  460. mdelay(30);
  461. if(!ret)
  462. {
  463. sprintf(cmd, "setenv reversingtracksize %s",env_get("filesize"));
  464. run_command(cmd, 0);
  465. printf("cmd=%s\n", cmd);
  466. mdelay(30);
  467. sprintf((char *)cmd,"disconfig 35");
  468. run_command(cmd, 0);
  469. }
  470. else if(ret == CHECKDATA_ERROR)
  471. goto bootoldsys;
  472. printf("\r\n **** update from update uboot back .....\r\n");
  473. ret = ark_update_emmc_partition("bootloader_bak", "u-boot.img");
  474. mdelay(30);
  475. if(!ret)
  476. {
  477. sprintf(cmd, "setenv bootloadersize %s",env_get("filesize"));
  478. run_command(cmd, 0);
  479. printf("cmd=%s\n", cmd);
  480. mdelay(30);
  481. sprintf((char *)cmd,"disconfig 40");
  482. run_command(cmd, 0);
  483. }
  484. else if(ret == CHECKDATA_ERROR)
  485. goto bootoldsys;
  486. printf("\r\n **** update from update rootfs .....\r\n");
  487. if (flag_partiton == 0)
  488. ret = ark_update_emmc_rootfs_from_media("rootfs");
  489. else
  490. ret = ark_update_emmc_rootfs_from_media("rootfs_b");
  491. if(!ret)
  492. {
  493. sprintf((char *)cmd,"disconfig 95");
  494. run_command(cmd, 0);
  495. }
  496. else if(ret == CHECKDATA_ERROR)
  497. goto bootoldsys;
  498. printf("\r\n **** set the env to partition .....\r\n");
  499. //mmc update set part A
  500. if(!strcmp(update_dev, "mmc"))
  501. {
  502. env_set("updata_from_part", "A");
  503. env_set("kernel_part", "kernel");
  504. env_set("fdt_part", "fdt");
  505. env_set("emmcroot", "/dev/mmcblk0p10 rw");
  506. }
  507. else if(!strcmp(update_dev, "usb"))
  508. {
  509. curr_partition = env_get("updata_from_part");
  510. if(!strcmp(curr_partition, "A"))
  511. {
  512. env_set("updata_from_part", "B");
  513. env_set("kernel_part", "kernel_b");
  514. env_set("fdt_part", "fdt_b");
  515. env_set("emmcroot", "/dev/mmcblk0p14 rw");
  516. }
  517. else if(!strcmp(curr_partition, "B"))
  518. {
  519. env_set("updata_from_part", "A");
  520. env_set("kernel_part", "kernel");
  521. env_set("fdt_part", "fdt");
  522. env_set("emmcroot", "/dev/mmcblk0p10 rw");
  523. }
  524. }
  525. mdelay(5);
  526. env_set("need_update", "no");
  527. mdelay(5);
  528. env_set("updata_status", "none");
  529. sprintf(cmd, "saveenv");
  530. printf("cmd=%s\n", cmd);
  531. run_command(cmd, 0);
  532. mdelay(30);
  533. sprintf((char *)cmd,"disconfig 100");
  534. run_command(cmd, 0);
  535. printf("\r\n **** update the device over! .....\r\n");
  536. return 0;
  537. bootoldsys:
  538. env_set("updata_status", "error");
  539. sprintf(cmd, "saveenv");
  540. printf("cmd=%s\n", cmd);
  541. run_command(cmd, 0);
  542. mdelay(20);
  543. sprintf((char *)cmd,"disconfig 100");
  544. run_command(cmd, 0);
  545. return 1;
  546. }
  547. int board_late_init(void)
  548. {
  549. char cmd[128];
  550. char *update_from_ota = NULL,*need_update = NULL;
  551. unsigned int loadaddr;
  552. int do_update = 0, update_from_mmc = 1;
  553. #ifdef CONFIG_USB_MUSB_HOST
  554. usb_controller_reset();
  555. musb_register(&musb_platform_data, NULL, (void *)MUSB_BASE);
  556. #endif
  557. /**************************add by wdz************************/
  558. arke_gpio_direction_output(21,0);
  559. arke_gpio_direction_output(23,1);
  560. arke_gpio_direction_output(22,1);
  561. arke_gpio_direction_output(190,1);
  562. mdelay(50);
  563. arke_gpio_direction_output(21,1);
  564. mdelay(100);
  565. /**************************add by wdz************************/
  566. update_from_ota = env_get("update_from_ota");
  567. printf("update_from_ota %s\n",update_from_ota);
  568. need_update = env_get("need_update");
  569. // if (!strcmp(need_update, "yes")) {
  570. if (1) {
  571. loadaddr = env_get_hex("loadaddr", 0);
  572. sprintf(cmd, "fatload %s %s %s update-magic", "mmc", env_get("sd_dev_part"), env_get("loadaddr"));
  573. printf("cmd %s\n",cmd);
  574. run_command(cmd, 0);
  575. if (loadaddr && !memcmp((void *)loadaddr, ARK1668_UPDATE_MAGIC, strlen(ARK1668_UPDATE_MAGIC))) {
  576. do_update = 1;
  577. goto update_done;
  578. } else {
  579. printf("Wrong update magic, do not update from mmc.\n");
  580. }
  581. #ifdef CONFIG_USB_MUSB_HOST
  582. run_command("usb start", 0);
  583. sprintf(cmd, "fatload %s %s %s update-magic", "usb", "0", env_get("loadaddr"));
  584. run_command(cmd, 0);
  585. if (loadaddr && !memcmp((void *)loadaddr, ARK1668_UPDATE_MAGIC, strlen(ARK1668_UPDATE_MAGIC))) {
  586. do_update = 1;
  587. update_from_mmc = 0;
  588. } else {
  589. printf("Wrong update magic, do not update from usb.\n");
  590. }
  591. #endif
  592. }
  593. else if(!strcmp(update_from_ota, "yes")){
  594. do_update = 0;
  595. sprintf(cmd, "update_from_emmc_ota");
  596. printf("cmd=%s\n", cmd);
  597. run_command(cmd, 0);
  598. }
  599. update_done:
  600. if (do_update) {
  601. run_command("emmc erase.part userdata", 0);
  602. env_set("need_update", "no");
  603. env_set("do_update", "yes");
  604. if (update_from_mmc) {
  605. printf("update form mmc...\n");
  606. env_set("update_dev_type", "mmc");
  607. env_set("update_dev_part", env_get("sd_dev_part"));
  608. } else {
  609. printf("update form usb...\n");
  610. env_set("update_dev_type", "usb");
  611. env_set("update_dev_part", "0");
  612. env_set("updata_status", "usb");
  613. }
  614. do_update_from_media();
  615. } else {
  616. env_set("do_update", "no");
  617. }
  618. return 0;
  619. }