ls2080a.c 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. /*
  2. * Copyright 2014 Freescale Semiconductor
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. #include <common.h>
  7. #include <malloc.h>
  8. #include <errno.h>
  9. #include <netdev.h>
  10. #include <fsl_ifc.h>
  11. #include <fsl_ddr.h>
  12. #include <asm/io.h>
  13. #include <fdt_support.h>
  14. #include <libfdt.h>
  15. #include <fsl_debug_server.h>
  16. #include <fsl-mc/fsl_mc.h>
  17. #include <environment.h>
  18. #include <asm/arch/soc.h>
  19. DECLARE_GLOBAL_DATA_PTR;
  20. int board_init(void)
  21. {
  22. init_final_memctl_regs();
  23. #ifdef CONFIG_ENV_IS_NOWHERE
  24. gd->env_addr = (ulong)&default_environment[0];
  25. #endif
  26. return 0;
  27. }
  28. int board_early_init_f(void)
  29. {
  30. fsl_lsch3_early_init_f();
  31. return 0;
  32. }
  33. void detail_board_ddr_info(void)
  34. {
  35. puts("\nDDR ");
  36. print_size(gd->bd->bi_dram[0].size + gd->bd->bi_dram[1].size, "");
  37. print_ddr_info(0);
  38. #ifdef CONFIG_SYS_FSL_HAS_DP_DDR
  39. if (gd->bd->bi_dram[2].size) {
  40. puts("\nDP-DDR ");
  41. print_size(gd->bd->bi_dram[2].size, "");
  42. print_ddr_info(CONFIG_DP_DDR_CTRL);
  43. }
  44. #endif
  45. }
  46. int dram_init(void)
  47. {
  48. gd->ram_size = initdram(0);
  49. return 0;
  50. }
  51. #if defined(CONFIG_ARCH_MISC_INIT)
  52. int arch_misc_init(void)
  53. {
  54. #ifdef CONFIG_FSL_DEBUG_SERVER
  55. debug_server_init();
  56. #endif
  57. return 0;
  58. }
  59. #endif
  60. int board_eth_init(bd_t *bis)
  61. {
  62. int error = 0;
  63. #ifdef CONFIG_SMC91111
  64. error = smc91111_initialize(0, CONFIG_SMC91111_BASE);
  65. #endif
  66. #ifdef CONFIG_FSL_MC_ENET
  67. error = cpu_eth_init(bis);
  68. #endif
  69. return error;
  70. }
  71. #ifdef CONFIG_FSL_MC_ENET
  72. void fdt_fixup_board_enet(void *fdt)
  73. {
  74. int offset;
  75. offset = fdt_path_offset(fdt, "/fsl-mc");
  76. /*
  77. * TODO: Remove this when backward compatibility
  78. * with old DT node (fsl,dprc@0) is no longer needed.
  79. */
  80. if (offset < 0)
  81. offset = fdt_path_offset(fdt, "/fsl,dprc@0");
  82. if (offset < 0) {
  83. printf("%s: ERROR: fsl-mc node not found in device tree (error %d)\n",
  84. __func__, offset);
  85. return;
  86. }
  87. if (get_mc_boot_status() == 0)
  88. fdt_status_okay(fdt, offset);
  89. else
  90. fdt_status_fail(fdt, offset);
  91. }
  92. #endif
  93. #ifdef CONFIG_OF_BOARD_SETUP
  94. int ft_board_setup(void *blob, bd_t *bd)
  95. {
  96. u64 base[CONFIG_NR_DRAM_BANKS];
  97. u64 size[CONFIG_NR_DRAM_BANKS];
  98. ft_cpu_setup(blob, bd);
  99. /* fixup DT for the two GPP DDR banks */
  100. base[0] = gd->bd->bi_dram[0].start;
  101. size[0] = gd->bd->bi_dram[0].size;
  102. base[1] = gd->bd->bi_dram[1].start;
  103. size[1] = gd->bd->bi_dram[1].size;
  104. fdt_fixup_memory_banks(blob, base, size, 2);
  105. #ifdef CONFIG_FSL_MC_ENET
  106. fdt_fixup_board_enet(blob);
  107. fsl_mc_ldpaa_exit(bd);
  108. #endif
  109. return 0;
  110. }
  111. #endif