cpu.c 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (C) 2004-2007 Freescale Semiconductor, Inc.
  4. */
  5. /*
  6. * CPU specific code for the MPC83xx family.
  7. *
  8. * Derived from the MPC8260 and MPC85xx.
  9. */
  10. #include <common.h>
  11. #include <watchdog.h>
  12. #include <command.h>
  13. #include <mpc83xx.h>
  14. #include <asm/processor.h>
  15. #include <linux/libfdt.h>
  16. #include <tsec.h>
  17. #include <netdev.h>
  18. #include <fsl_esdhc.h>
  19. #if defined(CONFIG_BOOTCOUNT_LIMIT) && !defined(CONFIG_MPC831x)
  20. #include <linux/immap_qe.h>
  21. #include <asm/io.h>
  22. #endif
  23. DECLARE_GLOBAL_DATA_PTR;
  24. int checkcpu(void)
  25. {
  26. volatile immap_t *immr;
  27. ulong clock = gd->cpu_clk;
  28. u32 pvr = get_pvr();
  29. u32 spridr;
  30. char buf[32];
  31. int ret;
  32. int i;
  33. const struct cpu_type {
  34. char name[15];
  35. u32 partid;
  36. } cpu_type_list [] = {
  37. CPU_TYPE_ENTRY(8308),
  38. CPU_TYPE_ENTRY(8309),
  39. CPU_TYPE_ENTRY(8311),
  40. CPU_TYPE_ENTRY(8313),
  41. CPU_TYPE_ENTRY(8314),
  42. CPU_TYPE_ENTRY(8315),
  43. CPU_TYPE_ENTRY(8321),
  44. CPU_TYPE_ENTRY(8323),
  45. CPU_TYPE_ENTRY(8343),
  46. CPU_TYPE_ENTRY(8347_TBGA_),
  47. CPU_TYPE_ENTRY(8347_PBGA_),
  48. CPU_TYPE_ENTRY(8349),
  49. CPU_TYPE_ENTRY(8358_TBGA_),
  50. CPU_TYPE_ENTRY(8358_PBGA_),
  51. CPU_TYPE_ENTRY(8360),
  52. CPU_TYPE_ENTRY(8377),
  53. CPU_TYPE_ENTRY(8378),
  54. CPU_TYPE_ENTRY(8379),
  55. };
  56. immr = (immap_t *)CONFIG_SYS_IMMR;
  57. ret = prt_83xx_rsr();
  58. if (ret)
  59. return ret;
  60. puts("CPU: ");
  61. switch (pvr & 0xffff0000) {
  62. case PVR_E300C1:
  63. printf("e300c1, ");
  64. break;
  65. case PVR_E300C2:
  66. printf("e300c2, ");
  67. break;
  68. case PVR_E300C3:
  69. printf("e300c3, ");
  70. break;
  71. case PVR_E300C4:
  72. printf("e300c4, ");
  73. break;
  74. default:
  75. printf("Unknown core, ");
  76. }
  77. spridr = immr->sysconf.spridr;
  78. for (i = 0; i < ARRAY_SIZE(cpu_type_list); i++)
  79. if (cpu_type_list[i].partid == PARTID_NO_E(spridr)) {
  80. puts("MPC");
  81. puts(cpu_type_list[i].name);
  82. if (IS_E_PROCESSOR(spridr))
  83. puts("E");
  84. if ((SPR_FAMILY(spridr) == SPR_834X_FAMILY ||
  85. SPR_FAMILY(spridr) == SPR_836X_FAMILY) &&
  86. REVID_MAJOR(spridr) >= 2)
  87. puts("A");
  88. printf(", Rev: %d.%d", REVID_MAJOR(spridr),
  89. REVID_MINOR(spridr));
  90. break;
  91. }
  92. if (i == ARRAY_SIZE(cpu_type_list))
  93. printf("(SPRIDR %08x unknown), ", spridr);
  94. printf(" at %s MHz, ", strmhz(buf, clock));
  95. printf("CSB: %s MHz\n", strmhz(buf, gd->arch.csb_clk));
  96. return 0;
  97. }
  98. int
  99. do_reset (cmd_tbl_t * cmdtp, int flag, int argc, char * const argv[])
  100. {
  101. ulong msr;
  102. #ifndef MPC83xx_RESET
  103. ulong addr;
  104. #endif
  105. volatile immap_t *immap = (immap_t *) CONFIG_SYS_IMMR;
  106. puts("Resetting the board.\n");
  107. #ifdef MPC83xx_RESET
  108. /* Interrupts and MMU off */
  109. __asm__ __volatile__ ("mfmsr %0":"=r" (msr):);
  110. msr &= ~( MSR_EE | MSR_IR | MSR_DR);
  111. __asm__ __volatile__ ("mtmsr %0"::"r" (msr));
  112. /* enable Reset Control Reg */
  113. immap->reset.rpr = 0x52535445;
  114. __asm__ __volatile__ ("sync");
  115. __asm__ __volatile__ ("isync");
  116. /* confirm Reset Control Reg is enabled */
  117. while(!((immap->reset.rcer) & RCER_CRE));
  118. udelay(200);
  119. /* perform reset, only one bit */
  120. immap->reset.rcr = RCR_SWHR;
  121. #else /* ! MPC83xx_RESET */
  122. immap->reset.rmr = RMR_CSRE; /* Checkstop Reset enable */
  123. /* Interrupts and MMU off */
  124. __asm__ __volatile__ ("mfmsr %0":"=r" (msr):);
  125. msr &= ~(MSR_ME | MSR_EE | MSR_IR | MSR_DR);
  126. __asm__ __volatile__ ("mtmsr %0"::"r" (msr));
  127. /*
  128. * Trying to execute the next instruction at a non-existing address
  129. * should cause a machine check, resulting in reset
  130. */
  131. addr = CONFIG_SYS_RESET_ADDRESS;
  132. ((void (*)(void)) addr) ();
  133. #endif /* MPC83xx_RESET */
  134. return 1;
  135. }
  136. /*
  137. * Get timebase clock frequency (like cpu_clk in Hz)
  138. */
  139. unsigned long get_tbclk(void)
  140. {
  141. return (gd->bus_clk + 3L) / 4L;
  142. }
  143. #if defined(CONFIG_WATCHDOG)
  144. void watchdog_reset (void)
  145. {
  146. int re_enable = disable_interrupts();
  147. /* Reset the 83xx watchdog */
  148. volatile immap_t *immr = (immap_t *) CONFIG_SYS_IMMR;
  149. immr->wdt.swsrr = 0x556c;
  150. immr->wdt.swsrr = 0xaa39;
  151. if (re_enable)
  152. enable_interrupts ();
  153. }
  154. #endif
  155. /*
  156. * Initializes on-chip ethernet controllers.
  157. * to override, implement board_eth_init()
  158. */
  159. int cpu_eth_init(bd_t *bis)
  160. {
  161. #if defined(CONFIG_UEC_ETH)
  162. uec_standard_init(bis);
  163. #endif
  164. #if defined(CONFIG_TSEC_ENET)
  165. tsec_standard_init(bis);
  166. #endif
  167. return 0;
  168. }
  169. /*
  170. * Initializes on-chip MMC controllers.
  171. * to override, implement board_mmc_init()
  172. */
  173. int cpu_mmc_init(bd_t *bis)
  174. {
  175. #ifdef CONFIG_FSL_ESDHC
  176. return fsl_esdhc_mmc_init(bis);
  177. #else
  178. return 0;
  179. #endif
  180. }