cpu.c 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. /*
  2. * (C) Copyright 2009
  3. * Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
  4. *
  5. * See file CREDITS for list of people who contributed to this
  6. * project.
  7. *
  8. * This program is free software; you can redistribute it and/or
  9. * modify it under the terms of the GNU General Public License as
  10. * published by the Free Software Foundation; either version 2 of
  11. * the License, or (at your option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program; if not, write to the Free Software
  20. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  21. * MA 02111-1307 USA
  22. */
  23. #include <common.h>
  24. #ifdef CONFIG_AT91_LEGACY
  25. #warning Your board is using legacy SoC access. Please update!
  26. #endif
  27. #include <asm/arch/hardware.h>
  28. #include <asm/arch/at91_pmc.h>
  29. #include <asm/arch/clk.h>
  30. #include <asm/arch/io.h>
  31. #ifndef CONFIG_SYS_AT91_MAIN_CLOCK
  32. #define CONFIG_SYS_AT91_MAIN_CLOCK 0
  33. #endif
  34. /*
  35. * The at91sam9260 has 4 GPBR (0-3), we'll use the last one, nr 3,
  36. * to keep track of the bootcount.
  37. */
  38. #define AT91_GPBR_BOOTCOUNT_REGISTER 3
  39. #define AT91_BOOTCOUNT_ADDRESS (AT91_GPBR + 4*AT91_GPBR_BOOTCOUNT_REGISTER)
  40. int arch_cpu_init(void)
  41. {
  42. return at91_clock_init(CONFIG_SYS_AT91_MAIN_CLOCK);
  43. }
  44. #if defined(CONFIG_DISPLAY_CPUINFO)
  45. int print_cpuinfo(void)
  46. {
  47. char buf[32];
  48. printf("CPU: %s\n", CONFIG_SYS_AT91_CPU_NAME);
  49. printf("Crystal frequency: %8s MHz\n",
  50. strmhz(buf, get_main_clk_rate()));
  51. printf("CPU clock : %8s MHz\n",
  52. strmhz(buf, get_cpu_clk_rate()));
  53. printf("Master clock : %8s MHz\n",
  54. strmhz(buf, get_mck_clk_rate()));
  55. return 0;
  56. }
  57. #endif
  58. #ifdef CONFIG_BOOTCOUNT_LIMIT
  59. /*
  60. * Just as the mpc5xxx, we combine the BOOTCOUNT_MAGIC and boocount
  61. * in one 32-bit register. This is done, as the AT91SAM9260 only has
  62. * 4 GPBR.
  63. */
  64. void bootcount_store (ulong a)
  65. {
  66. volatile ulong *save_addr =
  67. (volatile ulong *)(AT91_BASE_SYS + AT91_BOOTCOUNT_ADDRESS);
  68. *save_addr = (BOOTCOUNT_MAGIC & 0xffff0000) | (a & 0x0000ffff);
  69. }
  70. ulong bootcount_load (void)
  71. {
  72. volatile ulong *save_addr =
  73. (volatile ulong *)(AT91_BASE_SYS + AT91_BOOTCOUNT_ADDRESS);
  74. if ((*save_addr & 0xffff0000) != (BOOTCOUNT_MAGIC & 0xffff0000))
  75. return 0;
  76. else
  77. return (*save_addr & 0x0000ffff);
  78. }
  79. #endif /* CONFIG_BOOTCOUNT_LIMIT */