ls1021aqds.c 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510
  1. /*
  2. * Copyright 2014 Freescale Semiconductor, Inc.
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. #include <common.h>
  7. #include <i2c.h>
  8. #include <asm/io.h>
  9. #include <asm/arch/immap_ls102xa.h>
  10. #include <asm/arch/clock.h>
  11. #include <asm/arch/fsl_serdes.h>
  12. #include <asm/arch/ls102xa_soc.h>
  13. #include <asm/arch/ls102xa_devdis.h>
  14. #include <asm/arch/ls102xa_sata.h>
  15. #include <hwconfig.h>
  16. #include <mmc.h>
  17. #include <fsl_csu.h>
  18. #include <fsl_esdhc.h>
  19. #include <fsl_ifc.h>
  20. #include <fsl_sec.h>
  21. #include <spl.h>
  22. #include <fsl_devdis.h>
  23. #include <fsl_validate.h>
  24. #include <fsl_ddr.h>
  25. #include "../common/sleep.h"
  26. #include "../common/qixis.h"
  27. #include "ls1021aqds_qixis.h"
  28. #ifdef CONFIG_U_QE
  29. #include <fsl_qe.h>
  30. #endif
  31. #define PIN_MUX_SEL_CAN 0x03
  32. #define PIN_MUX_SEL_IIC2 0xa0
  33. #define PIN_MUX_SEL_RGMII 0x00
  34. #define PIN_MUX_SEL_SAI 0x0c
  35. #define PIN_MUX_SEL_SDHC 0x00
  36. #define SET_SDHC_MUX_SEL(reg, value) ((reg & 0x0f) | value)
  37. #define SET_EC_MUX_SEL(reg, value) ((reg & 0xf0) | value)
  38. DECLARE_GLOBAL_DATA_PTR;
  39. enum {
  40. MUX_TYPE_CAN,
  41. MUX_TYPE_IIC2,
  42. MUX_TYPE_RGMII,
  43. MUX_TYPE_SAI,
  44. MUX_TYPE_SDHC,
  45. MUX_TYPE_SD_PCI4,
  46. MUX_TYPE_SD_PC_SA_SG_SG,
  47. MUX_TYPE_SD_PC_SA_PC_SG,
  48. MUX_TYPE_SD_PC_SG_SG,
  49. };
  50. enum {
  51. GE0_CLK125,
  52. GE2_CLK125,
  53. GE1_CLK125,
  54. };
  55. int checkboard(void)
  56. {
  57. #if !defined(CONFIG_QSPI_BOOT) && !defined(CONFIG_SD_BOOT_QSPI)
  58. char buf[64];
  59. #endif
  60. #if !defined(CONFIG_SD_BOOT) && !defined(CONFIG_QSPI_BOOT)
  61. u8 sw;
  62. #endif
  63. puts("Board: LS1021AQDS\n");
  64. #ifdef CONFIG_SD_BOOT
  65. puts("SD\n");
  66. #elif CONFIG_QSPI_BOOT
  67. puts("QSPI\n");
  68. #else
  69. sw = QIXIS_READ(brdcfg[0]);
  70. sw = (sw & QIXIS_LBMAP_MASK) >> QIXIS_LBMAP_SHIFT;
  71. if (sw < 0x8)
  72. printf("vBank: %d\n", sw);
  73. else if (sw == 0x8)
  74. puts("PromJet\n");
  75. else if (sw == 0x9)
  76. puts("NAND\n");
  77. else if (sw == 0x15)
  78. printf("IFCCard\n");
  79. else
  80. printf("invalid setting of SW%u\n", QIXIS_LBMAP_SWITCH);
  81. #endif
  82. #if !defined(CONFIG_QSPI_BOOT) && !defined(CONFIG_SD_BOOT_QSPI)
  83. printf("Sys ID:0x%02x, Sys Ver: 0x%02x\n",
  84. QIXIS_READ(id), QIXIS_READ(arch));
  85. printf("FPGA: v%d (%s), build %d\n",
  86. (int)QIXIS_READ(scver), qixis_read_tag(buf),
  87. (int)qixis_read_minor());
  88. #endif
  89. return 0;
  90. }
  91. unsigned long get_board_sys_clk(void)
  92. {
  93. u8 sysclk_conf = QIXIS_READ(brdcfg[1]);
  94. switch (sysclk_conf & 0x0f) {
  95. case QIXIS_SYSCLK_64:
  96. return 64000000;
  97. case QIXIS_SYSCLK_83:
  98. return 83333333;
  99. case QIXIS_SYSCLK_100:
  100. return 100000000;
  101. case QIXIS_SYSCLK_125:
  102. return 125000000;
  103. case QIXIS_SYSCLK_133:
  104. return 133333333;
  105. case QIXIS_SYSCLK_150:
  106. return 150000000;
  107. case QIXIS_SYSCLK_160:
  108. return 160000000;
  109. case QIXIS_SYSCLK_166:
  110. return 166666666;
  111. }
  112. return 66666666;
  113. }
  114. unsigned long get_board_ddr_clk(void)
  115. {
  116. u8 ddrclk_conf = QIXIS_READ(brdcfg[1]);
  117. switch ((ddrclk_conf & 0x30) >> 4) {
  118. case QIXIS_DDRCLK_100:
  119. return 100000000;
  120. case QIXIS_DDRCLK_125:
  121. return 125000000;
  122. case QIXIS_DDRCLK_133:
  123. return 133333333;
  124. }
  125. return 66666666;
  126. }
  127. int select_i2c_ch_pca9547(u8 ch)
  128. {
  129. int ret;
  130. ret = i2c_write(I2C_MUX_PCA_ADDR_PRI, 0, 1, &ch, 1);
  131. if (ret) {
  132. puts("PCA: failed to select proper channel\n");
  133. return ret;
  134. }
  135. return 0;
  136. }
  137. int dram_init(void)
  138. {
  139. /*
  140. * When resuming from deep sleep, the I2C channel may not be
  141. * in the default channel. So, switch to the default channel
  142. * before accessing DDR SPD.
  143. */
  144. select_i2c_ch_pca9547(I2C_MUX_CH_DEFAULT);
  145. gd->ram_size = initdram(0);
  146. return 0;
  147. }
  148. #ifdef CONFIG_FSL_ESDHC
  149. struct fsl_esdhc_cfg esdhc_cfg[1] = {
  150. {CONFIG_SYS_FSL_ESDHC_ADDR},
  151. };
  152. int board_mmc_init(bd_t *bis)
  153. {
  154. esdhc_cfg[0].sdhc_clk = mxc_get_clock(MXC_ESDHC_CLK);
  155. return fsl_esdhc_initialize(bis, &esdhc_cfg[0]);
  156. }
  157. #endif
  158. int board_early_init_f(void)
  159. {
  160. struct ccsr_scfg *scfg = (struct ccsr_scfg *)CONFIG_SYS_FSL_SCFG_ADDR;
  161. #ifdef CONFIG_TSEC_ENET
  162. /* clear BD & FR bits for BE BD's and frame data */
  163. clrbits_be32(&scfg->etsecdmamcr, SCFG_ETSECDMAMCR_LE_BD_FR);
  164. #endif
  165. #ifdef CONFIG_FSL_IFC
  166. init_early_memctl_regs();
  167. #endif
  168. arch_soc_init();
  169. #if defined(CONFIG_DEEP_SLEEP)
  170. if (is_warm_boot())
  171. fsl_dp_disable_console();
  172. #endif
  173. return 0;
  174. }
  175. #ifdef CONFIG_SPL_BUILD
  176. void board_init_f(ulong dummy)
  177. {
  178. struct ccsr_cci400 *cci = (struct ccsr_cci400 *)CONFIG_SYS_CCI400_ADDR;
  179. unsigned int major;
  180. #ifdef CONFIG_NAND_BOOT
  181. struct ccsr_gur __iomem *gur = (void *)CONFIG_SYS_FSL_GUTS_ADDR;
  182. u32 porsr1, pinctl;
  183. /*
  184. * There is LS1 SoC issue where NOR, FPGA are inaccessible during
  185. * NAND boot because IFC signals > IFC_AD7 are not enabled.
  186. * This workaround changes RCW source to make all signals enabled.
  187. */
  188. porsr1 = in_be32(&gur->porsr1);
  189. pinctl = ((porsr1 & ~(DCFG_CCSR_PORSR1_RCW_MASK)) |
  190. DCFG_CCSR_PORSR1_RCW_SRC_I2C);
  191. out_be32((unsigned int *)(CONFIG_SYS_DCSR_DCFG_ADDR + DCFG_DCSR_PORCR1),
  192. pinctl);
  193. #endif
  194. /* Clear the BSS */
  195. memset(__bss_start, 0, __bss_end - __bss_start);
  196. #ifdef CONFIG_FSL_IFC
  197. init_early_memctl_regs();
  198. #endif
  199. get_clocks();
  200. #if defined(CONFIG_DEEP_SLEEP)
  201. if (is_warm_boot())
  202. fsl_dp_disable_console();
  203. #endif
  204. preloader_console_init();
  205. #ifdef CONFIG_SPL_I2C_SUPPORT
  206. i2c_init_all();
  207. #endif
  208. major = get_soc_major_rev();
  209. if (major == SOC_MAJOR_VER_1_0)
  210. out_le32(&cci->ctrl_ord, CCI400_CTRLORD_TERM_BARRIER);
  211. dram_init();
  212. /* Allow OCRAM access permission as R/W */
  213. #ifdef CONFIG_LAYERSCAPE_NS_ACCESS
  214. enable_layerscape_ns_access();
  215. #endif
  216. board_init_r(NULL, 0);
  217. }
  218. #endif
  219. void config_etseccm_source(int etsec_gtx_125_mux)
  220. {
  221. struct ccsr_scfg *scfg = (struct ccsr_scfg *)CONFIG_SYS_FSL_SCFG_ADDR;
  222. switch (etsec_gtx_125_mux) {
  223. case GE0_CLK125:
  224. out_be32(&scfg->etsecmcr, SCFG_ETSECCMCR_GE0_CLK125);
  225. debug("etseccm set to GE0_CLK125\n");
  226. break;
  227. case GE2_CLK125:
  228. out_be32(&scfg->etsecmcr, SCFG_ETSECCMCR_GE2_CLK125);
  229. debug("etseccm set to GE2_CLK125\n");
  230. break;
  231. case GE1_CLK125:
  232. out_be32(&scfg->etsecmcr, SCFG_ETSECCMCR_GE1_CLK125);
  233. debug("etseccm set to GE1_CLK125\n");
  234. break;
  235. default:
  236. printf("Error! trying to set etseccm to invalid value\n");
  237. break;
  238. }
  239. }
  240. int config_board_mux(int ctrl_type)
  241. {
  242. u8 reg12, reg14;
  243. reg12 = QIXIS_READ(brdcfg[12]);
  244. reg14 = QIXIS_READ(brdcfg[14]);
  245. switch (ctrl_type) {
  246. case MUX_TYPE_CAN:
  247. config_etseccm_source(GE2_CLK125);
  248. reg14 = SET_EC_MUX_SEL(reg14, PIN_MUX_SEL_CAN);
  249. break;
  250. case MUX_TYPE_IIC2:
  251. reg14 = SET_SDHC_MUX_SEL(reg14, PIN_MUX_SEL_IIC2);
  252. break;
  253. case MUX_TYPE_RGMII:
  254. reg14 = SET_EC_MUX_SEL(reg14, PIN_MUX_SEL_RGMII);
  255. break;
  256. case MUX_TYPE_SAI:
  257. config_etseccm_source(GE2_CLK125);
  258. reg14 = SET_EC_MUX_SEL(reg14, PIN_MUX_SEL_SAI);
  259. break;
  260. case MUX_TYPE_SDHC:
  261. reg14 = SET_SDHC_MUX_SEL(reg14, PIN_MUX_SEL_SDHC);
  262. break;
  263. case MUX_TYPE_SD_PCI4:
  264. reg12 = 0x38;
  265. break;
  266. case MUX_TYPE_SD_PC_SA_SG_SG:
  267. reg12 = 0x01;
  268. break;
  269. case MUX_TYPE_SD_PC_SA_PC_SG:
  270. reg12 = 0x01;
  271. break;
  272. case MUX_TYPE_SD_PC_SG_SG:
  273. reg12 = 0x21;
  274. break;
  275. default:
  276. printf("Wrong mux interface type\n");
  277. return -1;
  278. }
  279. QIXIS_WRITE(brdcfg[12], reg12);
  280. QIXIS_WRITE(brdcfg[14], reg14);
  281. return 0;
  282. }
  283. int config_serdes_mux(void)
  284. {
  285. struct ccsr_gur *gur = (struct ccsr_gur *)CONFIG_SYS_FSL_GUTS_ADDR;
  286. u32 cfg;
  287. cfg = in_be32(&gur->rcwsr[4]) & RCWSR4_SRDS1_PRTCL_MASK;
  288. cfg >>= RCWSR4_SRDS1_PRTCL_SHIFT;
  289. switch (cfg) {
  290. case 0x0:
  291. config_board_mux(MUX_TYPE_SD_PCI4);
  292. break;
  293. case 0x30:
  294. config_board_mux(MUX_TYPE_SD_PC_SA_SG_SG);
  295. break;
  296. case 0x60:
  297. config_board_mux(MUX_TYPE_SD_PC_SG_SG);
  298. break;
  299. case 0x70:
  300. config_board_mux(MUX_TYPE_SD_PC_SA_PC_SG);
  301. break;
  302. default:
  303. printf("SRDS1 prtcl:0x%x\n", cfg);
  304. break;
  305. }
  306. return 0;
  307. }
  308. #ifdef CONFIG_BOARD_LATE_INIT
  309. int board_late_init(void)
  310. {
  311. #ifdef CONFIG_SCSI_AHCI_PLAT
  312. ls1021a_sata_init();
  313. #endif
  314. #ifdef CONFIG_CHAIN_OF_TRUST
  315. fsl_setenv_chain_of_trust();
  316. #endif
  317. return 0;
  318. }
  319. #endif
  320. int misc_init_r(void)
  321. {
  322. int conflict_flag;
  323. /* some signals can not enable simultaneous*/
  324. conflict_flag = 0;
  325. if (hwconfig("sdhc"))
  326. conflict_flag++;
  327. if (hwconfig("iic2"))
  328. conflict_flag++;
  329. if (conflict_flag > 1) {
  330. printf("WARNING: pin conflict !\n");
  331. return 0;
  332. }
  333. conflict_flag = 0;
  334. if (hwconfig("rgmii"))
  335. conflict_flag++;
  336. if (hwconfig("can"))
  337. conflict_flag++;
  338. if (hwconfig("sai"))
  339. conflict_flag++;
  340. if (conflict_flag > 1) {
  341. printf("WARNING: pin conflict !\n");
  342. return 0;
  343. }
  344. if (hwconfig("can"))
  345. config_board_mux(MUX_TYPE_CAN);
  346. else if (hwconfig("rgmii"))
  347. config_board_mux(MUX_TYPE_RGMII);
  348. else if (hwconfig("sai"))
  349. config_board_mux(MUX_TYPE_SAI);
  350. if (hwconfig("iic2"))
  351. config_board_mux(MUX_TYPE_IIC2);
  352. else if (hwconfig("sdhc"))
  353. config_board_mux(MUX_TYPE_SDHC);
  354. #ifdef CONFIG_FSL_DEVICE_DISABLE
  355. device_disable(devdis_tbl, ARRAY_SIZE(devdis_tbl));
  356. #endif
  357. #ifdef CONFIG_FSL_CAAM
  358. return sec_init();
  359. #endif
  360. return 0;
  361. }
  362. int board_init(void)
  363. {
  364. struct ccsr_cci400 *cci = (struct ccsr_cci400 *)CONFIG_SYS_CCI400_ADDR;
  365. unsigned int major;
  366. #ifdef CONFIG_SYS_FSL_ERRATUM_A010315
  367. erratum_a010315();
  368. #endif
  369. #ifdef CONFIG_SYS_FSL_ERRATUM_A009942
  370. erratum_a009942_check_cpo();
  371. #endif
  372. major = get_soc_major_rev();
  373. if (major == SOC_MAJOR_VER_1_0) {
  374. /* Set CCI-400 control override register to
  375. * enable barrier transaction */
  376. out_le32(&cci->ctrl_ord, CCI400_CTRLORD_EN_BARRIER);
  377. }
  378. select_i2c_ch_pca9547(I2C_MUX_CH_DEFAULT);
  379. #ifndef CONFIG_SYS_FSL_NO_SERDES
  380. fsl_serdes_init();
  381. config_serdes_mux();
  382. #endif
  383. ls102xa_smmu_stream_id_init();
  384. #ifdef CONFIG_U_QE
  385. u_qe_init();
  386. #endif
  387. return 0;
  388. }
  389. #if defined(CONFIG_DEEP_SLEEP)
  390. void board_sleep_prepare(void)
  391. {
  392. struct ccsr_cci400 __iomem *cci = (void *)CONFIG_SYS_CCI400_ADDR;
  393. unsigned int major;
  394. major = get_soc_major_rev();
  395. if (major == SOC_MAJOR_VER_1_0) {
  396. /* Set CCI-400 control override register to
  397. * enable barrier transaction */
  398. out_le32(&cci->ctrl_ord, CCI400_CTRLORD_EN_BARRIER);
  399. }
  400. #ifdef CONFIG_LAYERSCAPE_NS_ACCESS
  401. enable_layerscape_ns_access();
  402. #endif
  403. }
  404. #endif
  405. int ft_board_setup(void *blob, bd_t *bd)
  406. {
  407. ft_cpu_setup(blob, bd);
  408. #ifdef CONFIG_PCI
  409. ft_pci_setup(blob, bd);
  410. #endif
  411. return 0;
  412. }
  413. u8 flash_read8(void *addr)
  414. {
  415. return __raw_readb(addr + 1);
  416. }
  417. void flash_write16(u16 val, void *addr)
  418. {
  419. u16 shftval = (((val >> 8) & 0xff) | ((val << 8) & 0xff00));
  420. __raw_writew(shftval, addr);
  421. }
  422. u16 flash_read16(void *addr)
  423. {
  424. u16 val = __raw_readw(addr);
  425. return (((val) >> 8) & 0x00ff) | (((val) << 8) & 0xff00);
  426. }