t208xqds.c 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright 2009-2013 Freescale Semiconductor, Inc.
  4. */
  5. #include <common.h>
  6. #include <command.h>
  7. #include <i2c.h>
  8. #include <netdev.h>
  9. #include <linux/compiler.h>
  10. #include <asm/mmu.h>
  11. #include <asm/processor.h>
  12. #include <asm/immap_85xx.h>
  13. #include <asm/fsl_law.h>
  14. #include <asm/fsl_serdes.h>
  15. #include <asm/fsl_liodn.h>
  16. #include <fm_eth.h>
  17. #include "../common/qixis.h"
  18. #include "../common/vsc3316_3308.h"
  19. #include "../common/vid.h"
  20. #include "t208xqds.h"
  21. #include "t208xqds_qixis.h"
  22. DECLARE_GLOBAL_DATA_PTR;
  23. int checkboard(void)
  24. {
  25. char buf[64];
  26. u8 sw;
  27. struct cpu_type *cpu = gd->arch.cpu;
  28. static const char *freq[4] = {
  29. "100.00MHZ(from 8T49N222A)", "125.00MHz",
  30. "156.25MHZ", "100.00MHz"
  31. };
  32. printf("Board: %sQDS, ", cpu->name);
  33. sw = QIXIS_READ(arch);
  34. printf("Sys ID: 0x%02x, Board Arch: V%d, ", QIXIS_READ(id), sw >> 4);
  35. printf("Board Version: %c, boot from ", (sw & 0xf) + 'A' - 1);
  36. #ifdef CONFIG_SDCARD
  37. puts("SD/MMC\n");
  38. #elif CONFIG_SPIFLASH
  39. puts("SPI\n");
  40. #else
  41. sw = QIXIS_READ(brdcfg[0]);
  42. sw = (sw & QIXIS_LBMAP_MASK) >> QIXIS_LBMAP_SHIFT;
  43. if (sw < 0x8)
  44. printf("vBank%d\n", sw);
  45. else if (sw == 0x8)
  46. puts("Promjet\n");
  47. else if (sw == 0x9)
  48. puts("NAND\n");
  49. else
  50. printf("invalid setting of SW%u\n", QIXIS_LBMAP_SWITCH);
  51. #endif
  52. printf("FPGA: v%d (%s), build %d", (int)QIXIS_READ(scver),
  53. qixis_read_tag(buf), (int)qixis_read_minor());
  54. /* the timestamp string contains "\n" at the end */
  55. printf(" on %s", qixis_read_time(buf));
  56. puts("SERDES Reference Clocks:\n");
  57. sw = QIXIS_READ(brdcfg[2]);
  58. printf("SD1_CLK1=%s, SD1_CLK2=%s\n", freq[sw >> 6],
  59. freq[(sw >> 4) & 0x3]);
  60. printf("SD2_CLK1=%s, SD2_CLK2=%s\n", freq[(sw & 0xf) >> 2],
  61. freq[sw & 0x3]);
  62. return 0;
  63. }
  64. int select_i2c_ch_pca9547(u8 ch)
  65. {
  66. int ret;
  67. ret = i2c_write(I2C_MUX_PCA_ADDR_PRI, 0, 1, &ch, 1);
  68. if (ret) {
  69. puts("PCA: failed to select proper channel\n");
  70. return ret;
  71. }
  72. return 0;
  73. }
  74. int i2c_multiplexer_select_vid_channel(u8 channel)
  75. {
  76. return select_i2c_ch_pca9547(channel);
  77. }
  78. int brd_mux_lane_to_slot(void)
  79. {
  80. ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
  81. u32 srds_prtcl_s1;
  82. srds_prtcl_s1 = in_be32(&gur->rcwsr[4]) &
  83. FSL_CORENET2_RCWSR4_SRDS1_PRTCL;
  84. srds_prtcl_s1 >>= FSL_CORENET2_RCWSR4_SRDS1_PRTCL_SHIFT;
  85. #if defined(CONFIG_TARGET_T2080QDS)
  86. u32 srds_prtcl_s2 = in_be32(&gur->rcwsr[4]) &
  87. FSL_CORENET2_RCWSR4_SRDS2_PRTCL;
  88. srds_prtcl_s2 >>= FSL_CORENET2_RCWSR4_SRDS2_PRTCL_SHIFT;
  89. #endif
  90. switch (srds_prtcl_s1) {
  91. case 0:
  92. /* SerDes1 is not enabled */
  93. break;
  94. #if defined(CONFIG_TARGET_T2080QDS)
  95. case 0x1b:
  96. case 0x1c:
  97. case 0xa2:
  98. /* SD1(A:D) => SLOT3 SGMII
  99. * SD1(G:H) => SLOT1 SGMII
  100. */
  101. QIXIS_WRITE(brdcfg[12], 0x1a);
  102. break;
  103. case 0x94:
  104. case 0x95:
  105. /* SD1(A:B) => SLOT3 SGMII@1.25bps
  106. * SD1(C:D) => SFP Module, SGMII@3.125bps
  107. * SD1(E:H) => SLOT1 SGMII@1.25bps
  108. */
  109. case 0x96:
  110. /* SD1(A:B) => SLOT3 SGMII@1.25bps
  111. * SD1(C) => SFP Module, SGMII@3.125bps
  112. * SD1(D) => SFP Module, SGMII@1.25bps
  113. * SD1(E:H) => SLOT1 PCIe4 x4
  114. */
  115. QIXIS_WRITE(brdcfg[12], 0x3a);
  116. break;
  117. case 0x50:
  118. case 0x51:
  119. /* SD1(A:D) => SLOT3 XAUI
  120. * SD1(E) => SLOT1 PCIe4
  121. * SD1(F:H) => SLOT2 SGMII
  122. */
  123. QIXIS_WRITE(brdcfg[12], 0x15);
  124. break;
  125. case 0x66:
  126. case 0x67:
  127. /* SD1(A:D) => XFI cage
  128. * SD1(E:H) => SLOT1 PCIe4
  129. */
  130. QIXIS_WRITE(brdcfg[12], 0xfe);
  131. break;
  132. case 0x6a:
  133. case 0x6b:
  134. /* SD1(A:D) => XFI cage
  135. * SD1(E) => SLOT1 PCIe4
  136. * SD1(F:H) => SLOT2 SGMII
  137. */
  138. QIXIS_WRITE(brdcfg[12], 0xf1);
  139. break;
  140. case 0x6c:
  141. case 0x6d:
  142. /* SD1(A:B) => XFI cage
  143. * SD1(C:D) => SLOT3 SGMII
  144. * SD1(E:H) => SLOT1 PCIe4
  145. */
  146. QIXIS_WRITE(brdcfg[12], 0xda);
  147. break;
  148. case 0x6e:
  149. /* SD1(A:B) => SFP Module, XFI
  150. * SD1(C:D) => SLOT3 SGMII
  151. * SD1(E:F) => SLOT1 PCIe4 x2
  152. * SD1(G:H) => SLOT2 SGMII
  153. */
  154. QIXIS_WRITE(brdcfg[12], 0xd9);
  155. break;
  156. case 0xda:
  157. /* SD1(A:H) => SLOT3 PCIe3 x8
  158. */
  159. QIXIS_WRITE(brdcfg[12], 0x0);
  160. break;
  161. case 0xc8:
  162. /* SD1(A) => SLOT3 PCIe3 x1
  163. * SD1(B) => SFP Module, SGMII@1.25bps
  164. * SD1(C:D) => SFP Module, SGMII@3.125bps
  165. * SD1(E:F) => SLOT1 PCIe4 x2
  166. * SD1(G:H) => SLOT2 SGMII
  167. */
  168. QIXIS_WRITE(brdcfg[12], 0x79);
  169. break;
  170. case 0xab:
  171. /* SD1(A:D) => SLOT3 PCIe3 x4
  172. * SD1(E:H) => SLOT1 PCIe4 x4
  173. */
  174. QIXIS_WRITE(brdcfg[12], 0x1a);
  175. break;
  176. #elif defined(CONFIG_TARGET_T2081QDS)
  177. case 0x50:
  178. case 0x51:
  179. /* SD1(A:D) => SLOT2 XAUI
  180. * SD1(E) => SLOT1 PCIe4 x1
  181. * SD1(F:H) => SLOT3 SGMII
  182. */
  183. QIXIS_WRITE(brdcfg[12], 0x98);
  184. QIXIS_WRITE(brdcfg[13], 0x70);
  185. break;
  186. case 0x6a:
  187. case 0x6b:
  188. /* SD1(A:D) => XFI SFP Module
  189. * SD1(E) => SLOT1 PCIe4 x1
  190. * SD1(F:H) => SLOT3 SGMII
  191. */
  192. QIXIS_WRITE(brdcfg[12], 0x80);
  193. QIXIS_WRITE(brdcfg[13], 0x70);
  194. break;
  195. case 0x6c:
  196. case 0x6d:
  197. /* SD1(A:B) => XFI SFP Module
  198. * SD1(C:D) => SLOT2 SGMII
  199. * SD1(E:H) => SLOT1 PCIe4 x4
  200. */
  201. QIXIS_WRITE(brdcfg[12], 0xe8);
  202. QIXIS_WRITE(brdcfg[13], 0x0);
  203. break;
  204. case 0xaa:
  205. case 0xab:
  206. /* SD1(A:D) => SLOT2 PCIe3 x4
  207. * SD1(F:H) => SLOT1 SGMI4 x4
  208. */
  209. QIXIS_WRITE(brdcfg[12], 0xf8);
  210. QIXIS_WRITE(brdcfg[13], 0x0);
  211. break;
  212. case 0xca:
  213. case 0xcb:
  214. /* SD1(A) => SLOT2 PCIe3 x1
  215. * SD1(B) => SLOT7 SGMII
  216. * SD1(C) => SLOT6 SGMII
  217. * SD1(D) => SLOT5 SGMII
  218. * SD1(E) => SLOT1 PCIe4 x1
  219. * SD1(F:H) => SLOT3 SGMII
  220. */
  221. QIXIS_WRITE(brdcfg[12], 0x80);
  222. QIXIS_WRITE(brdcfg[13], 0x70);
  223. break;
  224. case 0xde:
  225. case 0xdf:
  226. /* SD1(A:D) => SLOT2 PCIe3 x4
  227. * SD1(E) => SLOT1 PCIe4 x1
  228. * SD1(F) => SLOT4 PCIe1 x1
  229. * SD1(G) => SLOT3 PCIe2 x1
  230. * SD1(H) => SLOT7 SGMII
  231. */
  232. QIXIS_WRITE(brdcfg[12], 0x98);
  233. QIXIS_WRITE(brdcfg[13], 0x25);
  234. break;
  235. case 0xf2:
  236. /* SD1(A) => SLOT2 PCIe3 x1
  237. * SD1(B:D) => SLOT7 SGMII
  238. * SD1(E) => SLOT1 PCIe4 x1
  239. * SD1(F) => SLOT4 PCIe1 x1
  240. * SD1(G) => SLOT3 PCIe2 x1
  241. * SD1(H) => SLOT7 SGMII
  242. */
  243. QIXIS_WRITE(brdcfg[12], 0x81);
  244. QIXIS_WRITE(brdcfg[13], 0xa5);
  245. break;
  246. #endif
  247. default:
  248. printf("WARNING: unsupported for SerDes1 Protocol %d\n",
  249. srds_prtcl_s1);
  250. return -1;
  251. }
  252. #ifdef CONFIG_TARGET_T2080QDS
  253. switch (srds_prtcl_s2) {
  254. case 0:
  255. /* SerDes2 is not enabled */
  256. break;
  257. case 0x01:
  258. case 0x02:
  259. /* SD2(A:H) => SLOT4 PCIe1 */
  260. QIXIS_WRITE(brdcfg[13], 0x10);
  261. break;
  262. case 0x15:
  263. case 0x16:
  264. /*
  265. * SD2(A:D) => SLOT4 PCIe1
  266. * SD2(E:F) => SLOT5 PCIe2
  267. * SD2(G:H) => SATA1,SATA2
  268. */
  269. QIXIS_WRITE(brdcfg[13], 0xb0);
  270. break;
  271. case 0x18:
  272. /*
  273. * SD2(A:D) => SLOT4 PCIe1
  274. * SD2(E:F) => SLOT5 Aurora
  275. * SD2(G:H) => SATA1,SATA2
  276. */
  277. QIXIS_WRITE(brdcfg[13], 0x78);
  278. break;
  279. case 0x1f:
  280. /*
  281. * SD2(A:D) => SLOT4 PCIe1
  282. * SD2(E:H) => SLOT5 PCIe2
  283. */
  284. QIXIS_WRITE(brdcfg[13], 0xa0);
  285. break;
  286. case 0x29:
  287. case 0x2d:
  288. case 0x2e:
  289. /*
  290. * SD2(A:D) => SLOT4 SRIO2
  291. * SD2(E:H) => SLOT5 SRIO1
  292. */
  293. QIXIS_WRITE(brdcfg[13], 0xa0);
  294. break;
  295. case 0x36:
  296. /*
  297. * SD2(A:D) => SLOT4 SRIO2
  298. * SD2(E:F) => Aurora
  299. * SD2(G:H) => SATA1,SATA2
  300. */
  301. QIXIS_WRITE(brdcfg[13], 0x78);
  302. break;
  303. default:
  304. printf("WARNING: unsupported for SerDes2 Protocol %d\n",
  305. srds_prtcl_s2);
  306. return -1;
  307. }
  308. #endif
  309. return 0;
  310. }
  311. int board_early_init_r(void)
  312. {
  313. const unsigned int flashbase = CONFIG_SYS_FLASH_BASE;
  314. int flash_esel = find_tlb_idx((void *)flashbase, 1);
  315. /*
  316. * Remap Boot flash + PROMJET region to caching-inhibited
  317. * so that flash can be erased properly.
  318. */
  319. /* Flush d-cache and invalidate i-cache of any FLASH data */
  320. flush_dcache();
  321. invalidate_icache();
  322. if (flash_esel == -1) {
  323. /* very unlikely unless something is messed up */
  324. puts("Error: Could not find TLB for FLASH BASE\n");
  325. flash_esel = 2; /* give our best effort to continue */
  326. } else {
  327. /* invalidate existing TLB entry for flash + promjet */
  328. disable_tlb(flash_esel);
  329. }
  330. set_tlb(1, flashbase, CONFIG_SYS_FLASH_BASE_PHYS,
  331. MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G,
  332. 0, flash_esel, BOOKE_PAGESZ_256M, 1);
  333. /* Disable remote I2C connection to qixis fpga */
  334. QIXIS_WRITE(brdcfg[5], QIXIS_READ(brdcfg[5]) & ~BRDCFG5_IRE);
  335. /*
  336. * Adjust core voltage according to voltage ID
  337. * This function changes I2C mux to channel 2.
  338. */
  339. if (adjust_vdd(0))
  340. printf("Warning: Adjusting core voltage failed.\n");
  341. brd_mux_lane_to_slot();
  342. select_i2c_ch_pca9547(I2C_MUX_CH_DEFAULT);
  343. return 0;
  344. }
  345. unsigned long get_board_sys_clk(void)
  346. {
  347. u8 sysclk_conf = QIXIS_READ(brdcfg[1]);
  348. #ifdef CONFIG_FSL_QIXIS_CLOCK_MEASUREMENT
  349. /* use accurate clock measurement */
  350. int freq = QIXIS_READ(clk_freq[0]) << 8 | QIXIS_READ(clk_freq[1]);
  351. int base = QIXIS_READ(clk_base[0]) << 8 | QIXIS_READ(clk_base[1]);
  352. u32 val;
  353. val = freq * base;
  354. if (val) {
  355. debug("SYS Clock measurement is: %d\n", val);
  356. return val;
  357. } else {
  358. printf("Warning: SYS clock measurement is invalid, ");
  359. printf("using value from brdcfg1.\n");
  360. }
  361. #endif
  362. switch (sysclk_conf & 0x0F) {
  363. case QIXIS_SYSCLK_83:
  364. return 83333333;
  365. case QIXIS_SYSCLK_100:
  366. return 100000000;
  367. case QIXIS_SYSCLK_125:
  368. return 125000000;
  369. case QIXIS_SYSCLK_133:
  370. return 133333333;
  371. case QIXIS_SYSCLK_150:
  372. return 150000000;
  373. case QIXIS_SYSCLK_160:
  374. return 160000000;
  375. case QIXIS_SYSCLK_166:
  376. return 166666666;
  377. }
  378. return 66666666;
  379. }
  380. unsigned long get_board_ddr_clk(void)
  381. {
  382. u8 ddrclk_conf = QIXIS_READ(brdcfg[1]);
  383. #ifdef CONFIG_FSL_QIXIS_CLOCK_MEASUREMENT
  384. /* use accurate clock measurement */
  385. int freq = QIXIS_READ(clk_freq[2]) << 8 | QIXIS_READ(clk_freq[3]);
  386. int base = QIXIS_READ(clk_base[0]) << 8 | QIXIS_READ(clk_base[1]);
  387. u32 val;
  388. val = freq * base;
  389. if (val) {
  390. debug("DDR Clock measurement is: %d\n", val);
  391. return val;
  392. } else {
  393. printf("Warning: DDR clock measurement is invalid, ");
  394. printf("using value from brdcfg1.\n");
  395. }
  396. #endif
  397. switch ((ddrclk_conf & 0x30) >> 4) {
  398. case QIXIS_DDRCLK_100:
  399. return 100000000;
  400. case QIXIS_DDRCLK_125:
  401. return 125000000;
  402. case QIXIS_DDRCLK_133:
  403. return 133333333;
  404. }
  405. return 66666666;
  406. }
  407. int misc_init_r(void)
  408. {
  409. return 0;
  410. }
  411. int ft_board_setup(void *blob, bd_t *bd)
  412. {
  413. phys_addr_t base;
  414. phys_size_t size;
  415. ft_cpu_setup(blob, bd);
  416. base = env_get_bootm_low();
  417. size = env_get_bootm_size();
  418. fdt_fixup_memory(blob, (u64)base, (u64)size);
  419. #ifdef CONFIG_PCI
  420. pci_of_setup(blob, bd);
  421. #endif
  422. fdt_fixup_liodn(blob);
  423. fsl_fdt_fixup_dr_usb(blob, bd);
  424. #ifdef CONFIG_SYS_DPAA_FMAN
  425. fdt_fixup_fman_ethernet(blob);
  426. fdt_fixup_board_enet(blob);
  427. #endif
  428. return 0;
  429. }