cpu.c 4.2 KB

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