early_init.S 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. /*
  2. * (C) Copyright 2001
  3. * Thomas Koeller, tkoeller@gmx.net
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. #ifndef __ASSEMBLY__
  8. #define __ASSEMBLY__ 1
  9. #endif
  10. #include <asm-offsets.h>
  11. #include <config.h>
  12. #include <asm/processor.h>
  13. #include <mpc824x.h>
  14. #include <ppc_asm.tmpl>
  15. #if defined(USE_DINK32)
  16. /* We are running from RAM, so do not clear the MCCR1_MEMGO bit! */
  17. #define MCCR1VAL ((CONFIG_SYS_ROMNAL << MCCR1_ROMNAL_SHIFT) | (CONFIG_SYS_ROMFAL << MCCR1_ROMFAL_SHIFT) | MCCR1_MEMGO)
  18. #else
  19. #define MCCR1VAL (CONFIG_SYS_ROMNAL << MCCR1_ROMNAL_SHIFT) | (CONFIG_SYS_ROMFAL << MCCR1_ROMFAL_SHIFT)
  20. #endif
  21. .text
  22. /* Values to program into memory controller registers */
  23. tbl: .long MCCR1, MCCR1VAL
  24. .long MCCR2, CONFIG_SYS_REFINT << MCCR2_REFINT_SHIFT
  25. .long MCCR3
  26. .long (((CONFIG_SYS_BSTOPRE & 0x000000f0) >> 4) << MCCR3_BSTOPRE2TO5_SHIFT) | \
  27. (CONFIG_SYS_REFREC << MCCR3_REFREC_SHIFT) | \
  28. (CONFIG_SYS_RDLAT << MCCR3_RDLAT_SHIFT)
  29. .long MCCR4
  30. .long (CONFIG_SYS_PRETOACT << MCCR4_PRETOACT_SHIFT) | (CONFIG_SYS_ACTTOPRE << MCCR4_ACTTOPRE_SHIFT) | \
  31. (CONFIG_SYS_REGISTERD_TYPE_BUFFER << 20) | \
  32. (((CONFIG_SYS_BSTOPRE & 0x00000300) >> 8) << MCCR4_BSTOPRE0TO1_SHIFT ) | \
  33. ((CONFIG_SYS_SDMODE_CAS_LAT << 4) | (CONFIG_SYS_SDMODE_WRAP << 3) | \
  34. (CONFIG_SYS_SDMODE_BURSTLEN) << MCCR4_SDMODE_SHIFT) | \
  35. (CONFIG_SYS_ACTTORW << MCCR4_ACTTORW_SHIFT) | \
  36. ((CONFIG_SYS_BSTOPRE & 0x0000000f) << MCCR4_BSTOPRE6TO9_SHIFT )
  37. .long MSAR1
  38. .long (((CONFIG_SYS_BANK0_START & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT) << 0) | \
  39. (((CONFIG_SYS_BANK1_START & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT) << 8) | \
  40. (((CONFIG_SYS_BANK2_START & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT) << 16) | \
  41. (((CONFIG_SYS_BANK3_START & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT) << 24)
  42. .long EMSAR1
  43. .long (((CONFIG_SYS_BANK0_START & MICR_EADDR_MASK) >> MICR_EADDR_SHIFT) << 0) | \
  44. (((CONFIG_SYS_BANK1_START & MICR_EADDR_MASK) >> MICR_EADDR_SHIFT) << 8) | \
  45. (((CONFIG_SYS_BANK2_START & MICR_EADDR_MASK) >> MICR_EADDR_SHIFT) << 16) | \
  46. (((CONFIG_SYS_BANK3_START & MICR_EADDR_MASK) >> MICR_EADDR_SHIFT) << 24)
  47. .long MSAR2
  48. .long (((CONFIG_SYS_BANK4_START & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT) << 0) | \
  49. (((CONFIG_SYS_BANK5_START & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT) << 8) | \
  50. (((CONFIG_SYS_BANK6_START & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT) << 16) | \
  51. (((CONFIG_SYS_BANK7_START & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT) << 24)
  52. .long EMSAR2
  53. .long (((CONFIG_SYS_BANK4_START & MICR_EADDR_MASK) >> MICR_EADDR_SHIFT) << 0) | \
  54. (((CONFIG_SYS_BANK5_START & MICR_EADDR_MASK) >> MICR_EADDR_SHIFT) << 8) | \
  55. (((CONFIG_SYS_BANK6_START & MICR_EADDR_MASK) >> MICR_EADDR_SHIFT) << 16) | \
  56. (((CONFIG_SYS_BANK7_START & MICR_EADDR_MASK) >> MICR_EADDR_SHIFT) << 24)
  57. .long MEAR1
  58. .long (((CONFIG_SYS_BANK0_END & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT) << 0) | \
  59. (((CONFIG_SYS_BANK1_END & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT) << 8) | \
  60. (((CONFIG_SYS_BANK2_END & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT) << 16) | \
  61. (((CONFIG_SYS_BANK3_END & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT) << 24)
  62. .long EMEAR1
  63. .long (((CONFIG_SYS_BANK0_END & MICR_EADDR_MASK) >> MICR_EADDR_SHIFT) << 0) | \
  64. (((CONFIG_SYS_BANK1_END & MICR_EADDR_MASK) >> MICR_EADDR_SHIFT) << 8) | \
  65. (((CONFIG_SYS_BANK2_END & MICR_EADDR_MASK) >> MICR_EADDR_SHIFT) << 16) | \
  66. (((CONFIG_SYS_BANK3_END & MICR_EADDR_MASK) >> MICR_EADDR_SHIFT) << 24)
  67. .long MEAR2
  68. .long (((CONFIG_SYS_BANK4_END & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT) << 0) | \
  69. (((CONFIG_SYS_BANK5_END & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT) << 8) | \
  70. (((CONFIG_SYS_BANK6_END & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT) << 16) | \
  71. (((CONFIG_SYS_BANK7_END & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT) << 24)
  72. .long EMEAR2
  73. .long (((CONFIG_SYS_BANK4_END & MICR_EADDR_MASK) >> MICR_EADDR_SHIFT) << 0) | \
  74. (((CONFIG_SYS_BANK5_END & MICR_EADDR_MASK) >> MICR_EADDR_SHIFT) << 8) | \
  75. (((CONFIG_SYS_BANK6_END & MICR_EADDR_MASK) >> MICR_EADDR_SHIFT) << 16) | \
  76. (((CONFIG_SYS_BANK7_END & MICR_EADDR_MASK) >> MICR_EADDR_SHIFT) << 24)
  77. .long 0
  78. /*
  79. * Early CPU initialization. Set up memory controller, so we can access any RAM at all. This
  80. * must be done in assembly, since we have no stack at this point.
  81. */
  82. .global early_init_f
  83. early_init_f:
  84. mflr r10
  85. /* basic memory controller configuration */
  86. lis r3, CONFIG_ADDR_HIGH
  87. lis r4, CONFIG_DATA_HIGH
  88. bl lab
  89. lab: mflr r5
  90. lwzu r0, tbl - lab(r5)
  91. loop: lwz r1, 4(r5)
  92. stwbrx r0, 0, r3
  93. eieio
  94. stwbrx r1, 0, r4
  95. eieio
  96. lwzu r0, 8(r5)
  97. cmpli cr0, 0, r0, 0
  98. bne cr0, loop
  99. /* set bank enable bits */
  100. lis r0, MBER@h
  101. ori r0, 0, MBER@l
  102. li r1, CONFIG_SYS_BANK_ENABLE
  103. stwbrx r0, 0, r3
  104. eieio
  105. stb r1, 0(r4)
  106. eieio
  107. /* delay loop */
  108. lis r0, 0x0003
  109. mtctr r0
  110. delay: bdnz delay
  111. /* enable memory controller */
  112. lis r0, MCCR1@h
  113. ori r0, 0, MCCR1@l
  114. stwbrx r0, 0, r3
  115. eieio
  116. lwbrx r0, 0, r4
  117. oris r0, 0, MCCR1_MEMGO@h
  118. stwbrx r0, 0, r4
  119. eieio
  120. /* set up stack pointer */
  121. lis r1, CONFIG_SYS_INIT_SP_OFFSET@h
  122. ori r1, r1, CONFIG_SYS_INIT_SP_OFFSET@l
  123. mtlr r10
  124. blr