ls1043aqds.c 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright 2015 Freescale Semiconductor, Inc.
  4. */
  5. #include <common.h>
  6. #include <i2c.h>
  7. #include <fdt_support.h>
  8. #include <fsl_ddr_sdram.h>
  9. #include <asm/io.h>
  10. #include <asm/arch/clock.h>
  11. #include <asm/arch/fsl_serdes.h>
  12. #include <asm/arch/ppa.h>
  13. #include <asm/arch/fdt.h>
  14. #include <asm/arch/mmu.h>
  15. #include <asm/arch/soc.h>
  16. #include <ahci.h>
  17. #include <hwconfig.h>
  18. #include <mmc.h>
  19. #include <scsi.h>
  20. #include <fm_eth.h>
  21. #include <fsl_esdhc.h>
  22. #include <fsl_ifc.h>
  23. #include <spl.h>
  24. #include "../common/qixis.h"
  25. #include "ls1043aqds_qixis.h"
  26. DECLARE_GLOBAL_DATA_PTR;
  27. enum {
  28. MUX_TYPE_GPIO,
  29. };
  30. /* LS1043AQDS serdes mux */
  31. #define CFG_SD_MUX1_SLOT2 0x0 /* SLOT2 TX/RX0 */
  32. #define CFG_SD_MUX1_SLOT1 0x1 /* SLOT1 TX/RX1 */
  33. #define CFG_SD_MUX2_SLOT3 0x0 /* SLOT3 TX/RX0 */
  34. #define CFG_SD_MUX2_SLOT1 0x1 /* SLOT1 TX/RX2 */
  35. #define CFG_SD_MUX3_SLOT4 0x0 /* SLOT4 TX/RX0 */
  36. #define CFG_SD_MUX3_MUX4 0x1 /* MUX4 */
  37. #define CFG_SD_MUX4_SLOT3 0x0 /* SLOT3 TX/RX1 */
  38. #define CFG_SD_MUX4_SLOT1 0x1 /* SLOT1 TX/RX3 */
  39. #define CFG_UART_MUX_MASK 0x6
  40. #define CFG_UART_MUX_SHIFT 1
  41. #define CFG_LPUART_EN 0x1
  42. int checkboard(void)
  43. {
  44. char buf[64];
  45. #ifndef CONFIG_SD_BOOT
  46. u8 sw;
  47. #endif
  48. puts("Board: LS1043AQDS, boot from ");
  49. #ifdef CONFIG_SD_BOOT
  50. puts("SD\n");
  51. #else
  52. sw = QIXIS_READ(brdcfg[0]);
  53. sw = (sw & QIXIS_LBMAP_MASK) >> QIXIS_LBMAP_SHIFT;
  54. if (sw < 0x8)
  55. printf("vBank: %d\n", sw);
  56. else if (sw == 0x8)
  57. puts("PromJet\n");
  58. else if (sw == 0x9)
  59. puts("NAND\n");
  60. else if (sw == 0xF)
  61. printf("QSPI\n");
  62. else
  63. printf("invalid setting of SW%u\n", QIXIS_LBMAP_SWITCH);
  64. #endif
  65. printf("Sys ID: 0x%02x, Sys Ver: 0x%02x\n",
  66. QIXIS_READ(id), QIXIS_READ(arch));
  67. printf("FPGA: v%d (%s), build %d\n",
  68. (int)QIXIS_READ(scver), qixis_read_tag(buf),
  69. (int)qixis_read_minor());
  70. return 0;
  71. }
  72. bool if_board_diff_clk(void)
  73. {
  74. u8 diff_conf = QIXIS_READ(brdcfg[11]);
  75. return diff_conf & 0x40;
  76. }
  77. unsigned long get_board_sys_clk(void)
  78. {
  79. u8 sysclk_conf = QIXIS_READ(brdcfg[1]);
  80. switch (sysclk_conf & 0x0f) {
  81. case QIXIS_SYSCLK_64:
  82. return 64000000;
  83. case QIXIS_SYSCLK_83:
  84. return 83333333;
  85. case QIXIS_SYSCLK_100:
  86. return 100000000;
  87. case QIXIS_SYSCLK_125:
  88. return 125000000;
  89. case QIXIS_SYSCLK_133:
  90. return 133333333;
  91. case QIXIS_SYSCLK_150:
  92. return 150000000;
  93. case QIXIS_SYSCLK_160:
  94. return 160000000;
  95. case QIXIS_SYSCLK_166:
  96. return 166666666;
  97. }
  98. return 66666666;
  99. }
  100. unsigned long get_board_ddr_clk(void)
  101. {
  102. u8 ddrclk_conf = QIXIS_READ(brdcfg[1]);
  103. if (if_board_diff_clk())
  104. return get_board_sys_clk();
  105. switch ((ddrclk_conf & 0x30) >> 4) {
  106. case QIXIS_DDRCLK_100:
  107. return 100000000;
  108. case QIXIS_DDRCLK_125:
  109. return 125000000;
  110. case QIXIS_DDRCLK_133:
  111. return 133333333;
  112. }
  113. return 66666666;
  114. }
  115. int select_i2c_ch_pca9547(u8 ch)
  116. {
  117. int ret;
  118. ret = i2c_write(I2C_MUX_PCA_ADDR_PRI, 0, 1, &ch, 1);
  119. if (ret) {
  120. puts("PCA: failed to select proper channel\n");
  121. return ret;
  122. }
  123. return 0;
  124. }
  125. int dram_init(void)
  126. {
  127. /*
  128. * When resuming from deep sleep, the I2C channel may not be
  129. * in the default channel. So, switch to the default channel
  130. * before accessing DDR SPD.
  131. */
  132. select_i2c_ch_pca9547(I2C_MUX_CH_DEFAULT);
  133. fsl_initdram();
  134. #if !defined(CONFIG_SPL) || defined(CONFIG_SPL_BUILD)
  135. /* This will break-before-make MMU for DDR */
  136. update_early_mmu_table();
  137. #endif
  138. return 0;
  139. }
  140. int i2c_multiplexer_select_vid_channel(u8 channel)
  141. {
  142. return select_i2c_ch_pca9547(channel);
  143. }
  144. void board_retimer_init(void)
  145. {
  146. u8 reg;
  147. /* Retimer is connected to I2C1_CH7_CH5 */
  148. select_i2c_ch_pca9547(I2C_MUX_CH7);
  149. reg = I2C_MUX_CH5;
  150. i2c_write(I2C_MUX_PCA_ADDR_SEC, 0, 1, &reg, 1);
  151. /* Access to Control/Shared register */
  152. reg = 0x0;
  153. i2c_write(I2C_RETIMER_ADDR, 0xff, 1, &reg, 1);
  154. /* Read device revision and ID */
  155. i2c_read(I2C_RETIMER_ADDR, 1, 1, &reg, 1);
  156. debug("Retimer version id = 0x%x\n", reg);
  157. /* Enable Broadcast. All writes target all channel register sets */
  158. reg = 0x0c;
  159. i2c_write(I2C_RETIMER_ADDR, 0xff, 1, &reg, 1);
  160. /* Reset Channel Registers */
  161. i2c_read(I2C_RETIMER_ADDR, 0, 1, &reg, 1);
  162. reg |= 0x4;
  163. i2c_write(I2C_RETIMER_ADDR, 0, 1, &reg, 1);
  164. /* Enable override divider select and Enable Override Output Mux */
  165. i2c_read(I2C_RETIMER_ADDR, 9, 1, &reg, 1);
  166. reg |= 0x24;
  167. i2c_write(I2C_RETIMER_ADDR, 9, 1, &reg, 1);
  168. /* Select VCO Divider to full rate (000) */
  169. i2c_read(I2C_RETIMER_ADDR, 0x18, 1, &reg, 1);
  170. reg &= 0x8f;
  171. i2c_write(I2C_RETIMER_ADDR, 0x18, 1, &reg, 1);
  172. /* Selects active PFD MUX Input as Re-timed Data (001) */
  173. i2c_read(I2C_RETIMER_ADDR, 0x1e, 1, &reg, 1);
  174. reg &= 0x3f;
  175. reg |= 0x20;
  176. i2c_write(I2C_RETIMER_ADDR, 0x1e, 1, &reg, 1);
  177. /* Set data rate as 10.3125 Gbps */
  178. reg = 0x0;
  179. i2c_write(I2C_RETIMER_ADDR, 0x60, 1, &reg, 1);
  180. reg = 0xb2;
  181. i2c_write(I2C_RETIMER_ADDR, 0x61, 1, &reg, 1);
  182. reg = 0x90;
  183. i2c_write(I2C_RETIMER_ADDR, 0x62, 1, &reg, 1);
  184. reg = 0xb3;
  185. i2c_write(I2C_RETIMER_ADDR, 0x63, 1, &reg, 1);
  186. reg = 0xcd;
  187. i2c_write(I2C_RETIMER_ADDR, 0x64, 1, &reg, 1);
  188. /* Return the default channel */
  189. select_i2c_ch_pca9547(I2C_MUX_CH_DEFAULT);
  190. }
  191. int board_early_init_f(void)
  192. {
  193. #ifdef CONFIG_HAS_FSL_XHCI_USB
  194. struct ccsr_scfg *scfg = (struct ccsr_scfg *)CONFIG_SYS_FSL_SCFG_ADDR;
  195. u32 usb_pwrfault;
  196. #endif
  197. #ifdef CONFIG_LPUART
  198. u8 uart;
  199. #endif
  200. #ifdef CONFIG_SYS_I2C_EARLY_INIT
  201. i2c_early_init_f();
  202. #endif
  203. fsl_lsch2_early_init_f();
  204. #ifdef CONFIG_HAS_FSL_XHCI_USB
  205. out_be32(&scfg->rcwpmuxcr0, 0x3333);
  206. out_be32(&scfg->usbdrvvbus_selcr, SCFG_USBDRVVBUS_SELCR_USB1);
  207. usb_pwrfault =
  208. (SCFG_USBPWRFAULT_DEDICATED << SCFG_USBPWRFAULT_USB3_SHIFT) |
  209. (SCFG_USBPWRFAULT_DEDICATED << SCFG_USBPWRFAULT_USB2_SHIFT) |
  210. (SCFG_USBPWRFAULT_SHARED << SCFG_USBPWRFAULT_USB1_SHIFT);
  211. out_be32(&scfg->usbpwrfault_selcr, usb_pwrfault);
  212. #endif
  213. #ifdef CONFIG_LPUART
  214. /* We use lpuart0 as system console */
  215. uart = QIXIS_READ(brdcfg[14]);
  216. uart &= ~CFG_UART_MUX_MASK;
  217. uart |= CFG_LPUART_EN << CFG_UART_MUX_SHIFT;
  218. QIXIS_WRITE(brdcfg[14], uart);
  219. #endif
  220. return 0;
  221. }
  222. #ifdef CONFIG_FSL_DEEP_SLEEP
  223. /* determine if it is a warm boot */
  224. bool is_warm_boot(void)
  225. {
  226. #define DCFG_CCSR_CRSTSR_WDRFR (1 << 3)
  227. struct ccsr_gur __iomem *gur = (void *)CONFIG_SYS_FSL_GUTS_ADDR;
  228. if (in_be32(&gur->crstsr) & DCFG_CCSR_CRSTSR_WDRFR)
  229. return 1;
  230. return 0;
  231. }
  232. #endif
  233. int config_board_mux(int ctrl_type)
  234. {
  235. u8 reg14;
  236. reg14 = QIXIS_READ(brdcfg[14]);
  237. switch (ctrl_type) {
  238. case MUX_TYPE_GPIO:
  239. reg14 = (reg14 & (~0x30)) | 0x20;
  240. break;
  241. default:
  242. puts("Unsupported mux interface type\n");
  243. return -1;
  244. }
  245. QIXIS_WRITE(brdcfg[14], reg14);
  246. return 0;
  247. }
  248. int config_serdes_mux(void)
  249. {
  250. return 0;
  251. }
  252. #ifdef CONFIG_MISC_INIT_R
  253. int misc_init_r(void)
  254. {
  255. if (hwconfig("gpio"))
  256. config_board_mux(MUX_TYPE_GPIO);
  257. return 0;
  258. }
  259. #endif
  260. int board_init(void)
  261. {
  262. #ifdef CONFIG_SYS_FSL_ERRATUM_A010315
  263. erratum_a010315();
  264. #endif
  265. select_i2c_ch_pca9547(I2C_MUX_CH_DEFAULT);
  266. board_retimer_init();
  267. #ifdef CONFIG_SYS_FSL_SERDES
  268. config_serdes_mux();
  269. #endif
  270. #ifdef CONFIG_FSL_LS_PPA
  271. ppa_init();
  272. #endif
  273. return 0;
  274. }
  275. #ifdef CONFIG_OF_BOARD_SETUP
  276. int ft_board_setup(void *blob, bd_t *bd)
  277. {
  278. u64 base[CONFIG_NR_DRAM_BANKS];
  279. u64 size[CONFIG_NR_DRAM_BANKS];
  280. u8 reg;
  281. /* fixup DT for the two DDR banks */
  282. base[0] = gd->bd->bi_dram[0].start;
  283. size[0] = gd->bd->bi_dram[0].size;
  284. base[1] = gd->bd->bi_dram[1].start;
  285. size[1] = gd->bd->bi_dram[1].size;
  286. fdt_fixup_memory_banks(blob, base, size, 2);
  287. ft_cpu_setup(blob, bd);
  288. #ifdef CONFIG_SYS_DPAA_FMAN
  289. fdt_fixup_fman_ethernet(blob);
  290. fdt_fixup_board_enet(blob);
  291. #endif
  292. reg = QIXIS_READ(brdcfg[0]);
  293. reg = (reg & QIXIS_LBMAP_MASK) >> QIXIS_LBMAP_SHIFT;
  294. /* Disable IFC if QSPI is enabled */
  295. if (reg == 0xF)
  296. do_fixup_by_compat(blob, "fsl,ifc",
  297. "status", "disabled", 8 + 1, 1);
  298. return 0;
  299. }
  300. #endif
  301. u8 flash_read8(void *addr)
  302. {
  303. return __raw_readb(addr + 1);
  304. }
  305. void flash_write16(u16 val, void *addr)
  306. {
  307. u16 shftval = (((val >> 8) & 0xff) | ((val << 8) & 0xff00));
  308. __raw_writew(shftval, addr);
  309. }
  310. u16 flash_read16(void *addr)
  311. {
  312. u16 val = __raw_readw(addr);
  313. return (((val) >> 8) & 0x00ff) | (((val) << 8) & 0xff00);
  314. }