ls1021aqds.c 10 KB

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