mpc82xx.c 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. /*
  2. * MPC82xx setup and early boot code plus other random bits.
  3. *
  4. * Author: Vitaly Bordug <vbordug@ru.mvista.com>
  5. *
  6. * Copyright (c) 2006 MontaVista Software, Inc.
  7. *
  8. * This program is free software; you can redistribute it and/or modify it
  9. * under the terms of the GNU General Public License as published by the
  10. * Free Software Foundation; either version 2 of the License, or (at your
  11. * option) any later version.
  12. */
  13. #include <linux/config.h>
  14. #include <linux/stddef.h>
  15. #include <linux/kernel.h>
  16. #include <linux/init.h>
  17. #include <linux/errno.h>
  18. #include <linux/reboot.h>
  19. #include <linux/pci.h>
  20. #include <linux/interrupt.h>
  21. #include <linux/kdev_t.h>
  22. #include <linux/major.h>
  23. #include <linux/console.h>
  24. #include <linux/delay.h>
  25. #include <linux/seq_file.h>
  26. #include <linux/root_dev.h>
  27. #include <linux/initrd.h>
  28. #include <linux/module.h>
  29. #include <linux/fsl_devices.h>
  30. #include <linux/fs_uart_pd.h>
  31. #include <asm/system.h>
  32. #include <asm/pgtable.h>
  33. #include <asm/page.h>
  34. #include <asm/atomic.h>
  35. #include <asm/time.h>
  36. #include <asm/io.h>
  37. #include <asm/machdep.h>
  38. #include <asm/bootinfo.h>
  39. #include <asm/pci-bridge.h>
  40. #include <asm/mpc8260.h>
  41. #include <asm/irq.h>
  42. #include <mm/mmu_decl.h>
  43. #include <asm/prom.h>
  44. #include <asm/cpm2.h>
  45. #include <asm/udbg.h>
  46. #include <asm/i8259.h>
  47. #include <linux/fs_enet_pd.h>
  48. #include <sysdev/fsl_soc.h>
  49. #include <sysdev/cpm2_pic.h>
  50. #include "pq2ads_pd.h"
  51. static int __init get_freq(char *name, unsigned long *val)
  52. {
  53. struct device_node *cpu;
  54. unsigned int *fp;
  55. int found = 0;
  56. /* The cpu node should have timebase and clock frequency properties */
  57. cpu = of_find_node_by_type(NULL, "cpu");
  58. if (cpu) {
  59. fp = (unsigned int *)get_property(cpu, name, NULL);
  60. if (fp) {
  61. found = 1;
  62. *val = *fp++;
  63. }
  64. of_node_put(cpu);
  65. }
  66. return found;
  67. }
  68. void __init m82xx_calibrate_decr(void)
  69. {
  70. ppc_tb_freq = 125000000;
  71. if (!get_freq("bus-frequency", &ppc_tb_freq)) {
  72. printk(KERN_ERR "WARNING: Estimating decrementer frequency "
  73. "(not found)\n");
  74. }
  75. ppc_tb_freq /= 4;
  76. ppc_proc_freq = 1000000000;
  77. if (!get_freq("clock-frequency", &ppc_proc_freq))
  78. printk(KERN_ERR "WARNING: Estimating processor frequency"
  79. "(not found)\n");
  80. }
  81. void mpc82xx_ads_show_cpuinfo(struct seq_file *m)
  82. {
  83. uint pvid, svid, phid1;
  84. uint memsize = total_memory;
  85. pvid = mfspr(SPRN_PVR);
  86. svid = mfspr(SPRN_SVR);
  87. seq_printf(m, "Vendor\t\t: Freescale Semiconductor\n");
  88. seq_printf(m, "Machine\t\t: %s\n", CPUINFO_MACHINE);
  89. seq_printf(m, "PVR\t\t: 0x%x\n", pvid);
  90. seq_printf(m, "SVR\t\t: 0x%x\n", svid);
  91. /* Display cpu Pll setting */
  92. phid1 = mfspr(SPRN_HID1);
  93. seq_printf(m, "PLL setting\t: 0x%x\n", ((phid1 >> 24) & 0x3f));
  94. /* Display the amount of memory */
  95. seq_printf(m, "Memory\t\t: %d MB\n", memsize / (1024 * 1024));
  96. }