common.c 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. /*
  2. * Defines machines for CSR SiRFprimaII
  3. *
  4. * Copyright (c) 2011 Cambridge Silicon Radio Limited, a CSR plc group company.
  5. *
  6. * Licensed under GPLv2 or later.
  7. */
  8. #include <linux/clocksource.h>
  9. #include <linux/init.h>
  10. #include <linux/kernel.h>
  11. #include <linux/irqchip.h>
  12. #include <asm/sizes.h>
  13. #include <asm/mach-types.h>
  14. #include <asm/mach/arch.h>
  15. #include <linux/of.h>
  16. #include <linux/of_platform.h>
  17. #include "common.h"
  18. static struct of_device_id sirfsoc_of_bus_ids[] __initdata = {
  19. { .compatible = "simple-bus", },
  20. {},
  21. };
  22. void __init sirfsoc_mach_init(void)
  23. {
  24. of_platform_bus_probe(NULL, sirfsoc_of_bus_ids, NULL);
  25. }
  26. void __init sirfsoc_init_late(void)
  27. {
  28. sirfsoc_pm_init();
  29. }
  30. static __init void sirfsoc_init_time(void)
  31. {
  32. /* initialize clocking early, we want to set the OS timer */
  33. sirfsoc_of_clk_init();
  34. clocksource_of_init();
  35. }
  36. static __init void sirfsoc_map_io(void)
  37. {
  38. sirfsoc_map_lluart();
  39. sirfsoc_map_scu();
  40. }
  41. #ifdef CONFIG_ARCH_ATLAS6
  42. static const char *atlas6_dt_match[] __initdata = {
  43. "sirf,atlas6",
  44. NULL
  45. };
  46. DT_MACHINE_START(ATLAS6_DT, "Generic ATLAS6 (Flattened Device Tree)")
  47. /* Maintainer: Barry Song <baohua.song@csr.com> */
  48. .nr_irqs = 128,
  49. .map_io = sirfsoc_map_io,
  50. .init_irq = irqchip_init,
  51. .init_time = sirfsoc_init_time,
  52. .init_machine = sirfsoc_mach_init,
  53. .init_late = sirfsoc_init_late,
  54. .dt_compat = atlas6_dt_match,
  55. .restart = sirfsoc_restart,
  56. MACHINE_END
  57. #endif
  58. #ifdef CONFIG_ARCH_PRIMA2
  59. static const char *prima2_dt_match[] __initdata = {
  60. "sirf,prima2",
  61. NULL
  62. };
  63. DT_MACHINE_START(PRIMA2_DT, "Generic PRIMA2 (Flattened Device Tree)")
  64. /* Maintainer: Barry Song <baohua.song@csr.com> */
  65. .nr_irqs = 128,
  66. .map_io = sirfsoc_map_io,
  67. .init_irq = irqchip_init,
  68. .init_time = sirfsoc_init_time,
  69. .dma_zone_size = SZ_256M,
  70. .init_machine = sirfsoc_mach_init,
  71. .init_late = sirfsoc_init_late,
  72. .dt_compat = prima2_dt_match,
  73. .restart = sirfsoc_restart,
  74. MACHINE_END
  75. #endif
  76. #ifdef CONFIG_ARCH_MARCO
  77. static const char *marco_dt_match[] __initdata = {
  78. "sirf,marco",
  79. NULL
  80. };
  81. DT_MACHINE_START(MARCO_DT, "Generic MARCO (Flattened Device Tree)")
  82. /* Maintainer: Barry Song <baohua.song@csr.com> */
  83. .smp = smp_ops(sirfsoc_smp_ops),
  84. .map_io = sirfsoc_map_io,
  85. .init_irq = irqchip_init,
  86. .init_time = sirfsoc_init_time,
  87. .init_machine = sirfsoc_mach_init,
  88. .init_late = sirfsoc_init_late,
  89. .dt_compat = marco_dt_match,
  90. .restart = sirfsoc_restart,
  91. MACHINE_END
  92. #endif