spl.c 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. // SPDX-License-Identifier: GPL-2.0+
  2. #include <asm/arch/clock.h>
  3. #include <asm/arch/iomux.h>
  4. #include <asm/arch/imx-regs.h>
  5. #include <asm/arch/crm_regs.h>
  6. #include <asm/arch/mx6ul_pins.h>
  7. #include <asm/arch/mx6-pins.h>
  8. #include <asm/arch/sys_proto.h>
  9. #include <asm/gpio.h>
  10. #include <asm/mach-imx/iomux-v3.h>
  11. #include <asm/mach-imx/boot_mode.h>
  12. #include <linux/libfdt.h>
  13. #include <spl.h>
  14. #if defined(CONFIG_SPL_BUILD)
  15. #ifdef CONFIG_SPL_OS_BOOT
  16. int spl_start_uboot(void)
  17. {
  18. return 0;
  19. }
  20. #endif
  21. #include <asm/arch/mx6-ddr.h>
  22. static struct mx6ul_iomux_grp_regs mx6_grp_ioregs = {
  23. .grp_addds = 0x00000030,
  24. .grp_ddrmode_ctl = 0x00020000,
  25. .grp_b0ds = 0x00000030,
  26. .grp_ctlds = 0x00000030,
  27. .grp_b1ds = 0x00000030,
  28. .grp_ddrpke = 0x00000000,
  29. .grp_ddrmode = 0x00020000,
  30. .grp_ddr_type = 0x00080000,
  31. };
  32. static struct mx6ul_iomux_ddr_regs mx6_ddr_ioregs = {
  33. .dram_dqm0 = 0x00000030,
  34. .dram_dqm1 = 0x00000030,
  35. .dram_ras = 0x00000030,
  36. .dram_cas = 0x00000030,
  37. .dram_odt0 = 0x00000030,
  38. .dram_odt1 = 0x00000030,
  39. .dram_sdba2 = 0x00000000,
  40. .dram_sdclk_0 = 0x00000030,
  41. .dram_sdqs0 = 0x00000030,
  42. .dram_sdqs1 = 0x00000030,
  43. .dram_reset = 0x00000030,
  44. };
  45. static struct mx6_mmdc_calibration mx6_mmcd_calib = {
  46. .p0_mpwldectrl0 = 0x00000000,
  47. .p0_mpdgctrl0 = 0x01380134,
  48. .p0_mprddlctl = 0x40404244,
  49. .p0_mpwrdlctl = 0x40405050,
  50. };
  51. static struct mx6_ddr_sysinfo ddr_sysinfo = {
  52. .dsize = 0,
  53. .cs1_mirror = 0,
  54. .cs_density = 32,
  55. .ncs = 1,
  56. .bi_on = 1,
  57. .rtt_nom = 1,
  58. .rtt_wr = 0,
  59. .ralat = 5,
  60. .walat = 0,
  61. .mif3_mode = 3,
  62. .rst_to_cke = 0x23,
  63. .sde_to_rst = 0x10,
  64. .refsel = 1,
  65. .refr = 3,
  66. };
  67. static struct mx6_ddr3_cfg mem_ddr = {
  68. .mem_speed = 1333,
  69. .density = 2,
  70. .width = 16,
  71. .banks = 8,
  72. .coladdr = 10,
  73. .pagesz = 2,
  74. .trcd = 1350,
  75. .trcmin = 4950,
  76. .trasmin = 3600,
  77. };
  78. static void ccgr_init(void)
  79. {
  80. struct mxc_ccm_reg *ccm = (struct mxc_ccm_reg *)CCM_BASE_ADDR;
  81. writel(0xFFFFFFFF, &ccm->CCGR0);
  82. writel(0xFFFFFFFF, &ccm->CCGR1);
  83. writel(0xFFFFFFFF, &ccm->CCGR2);
  84. writel(0xFFFFFFFF, &ccm->CCGR3);
  85. writel(0xFFFFFFFF, &ccm->CCGR4);
  86. writel(0xFFFFFFFF, &ccm->CCGR5);
  87. writel(0xFFFFFFFF, &ccm->CCGR6);
  88. }
  89. static void imx6ul_spl_dram_cfg_size(u32 ram_size)
  90. {
  91. if (ram_size == SZ_256M)
  92. mem_ddr.rowaddr = 14;
  93. else
  94. mem_ddr.rowaddr = 15;
  95. mx6ul_dram_iocfg(mem_ddr.width, &mx6_ddr_ioregs, &mx6_grp_ioregs);
  96. mx6_dram_cfg(&ddr_sysinfo, &mx6_mmcd_calib, &mem_ddr);
  97. }
  98. static void imx6ul_spl_dram_cfg(void)
  99. {
  100. ulong ram_size_test, ram_size = 0;
  101. for (ram_size = SZ_512M; ram_size >= SZ_256M; ram_size >>= 1) {
  102. imx6ul_spl_dram_cfg_size(ram_size);
  103. ram_size_test = get_ram_size((long int *)PHYS_SDRAM, ram_size);
  104. if (ram_size_test == ram_size)
  105. break;
  106. }
  107. if (ram_size < SZ_256M) {
  108. puts("ERROR: DRAM size detection failed\n");
  109. hang();
  110. }
  111. }
  112. void board_init_f(ulong dummy)
  113. {
  114. ccgr_init();
  115. arch_cpu_init();
  116. board_early_init_f();
  117. timer_init();
  118. preloader_console_init();
  119. imx6ul_spl_dram_cfg();
  120. memset(__bss_start, 0, __bss_end - __bss_start);
  121. board_init_r(NULL, 0);
  122. }
  123. void reset_cpu(ulong addr)
  124. {
  125. }
  126. #endif