cpu-u8500.c 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /*
  2. * Copyright (C) 2008-2009 ST-Ericsson
  3. *
  4. * Author: Srinidhi KASAGAR <srinidhi.kasagar@stericsson.com>
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License version 2, as
  8. * published by the Free Software Foundation.
  9. *
  10. */
  11. #include <linux/types.h>
  12. #include <linux/init.h>
  13. #include <linux/device.h>
  14. #include <linux/amba/bus.h>
  15. #include <linux/irq.h>
  16. #include <linux/platform_device.h>
  17. #include <linux/io.h>
  18. #include <asm/localtimer.h>
  19. #include <asm/hardware/gic.h>
  20. #include <asm/mach/map.h>
  21. #include <plat/mtu.h>
  22. #include <mach/hardware.h>
  23. #include <mach/setup.h>
  24. /* add any platform devices here - TODO */
  25. static struct platform_device *platform_devs[] __initdata = {
  26. /* yet to be added, add i2c0, gpio.. */
  27. };
  28. #define __IO_DEV_DESC(x, sz) { \
  29. .virtual = IO_ADDRESS(x), \
  30. .pfn = __phys_to_pfn(x), \
  31. .length = sz, \
  32. .type = MT_DEVICE, \
  33. }
  34. /* minimum static i/o mapping required to boot U8500 platforms */
  35. static struct map_desc u8500_io_desc[] __initdata = {
  36. __IO_DEV_DESC(U8500_UART2_BASE, SZ_4K),
  37. __IO_DEV_DESC(U8500_GIC_CPU_BASE, SZ_4K),
  38. __IO_DEV_DESC(U8500_GIC_DIST_BASE, SZ_4K),
  39. __IO_DEV_DESC(U8500_TWD_BASE, SZ_4K),
  40. __IO_DEV_DESC(U8500_SCU_BASE, SZ_4K),
  41. __IO_DEV_DESC(U8500_BACKUPRAM0_BASE, SZ_8K),
  42. };
  43. static struct map_desc u8500ed_io_desc[] __initdata = {
  44. __IO_DEV_DESC(U8500_MTU0_BASE_ED, SZ_4K),
  45. };
  46. static struct map_desc u8500v1_io_desc[] __initdata = {
  47. __IO_DEV_DESC(U8500_MTU0_BASE_V1, SZ_4K),
  48. };
  49. void __init u8500_map_io(void)
  50. {
  51. iotable_init(u8500_io_desc, ARRAY_SIZE(u8500_io_desc));
  52. if (cpu_is_u8500ed())
  53. iotable_init(u8500ed_io_desc, ARRAY_SIZE(u8500ed_io_desc));
  54. else
  55. iotable_init(u8500v1_io_desc, ARRAY_SIZE(u8500v1_io_desc));
  56. }
  57. void __init u8500_init_irq(void)
  58. {
  59. gic_dist_init(0, __io_address(U8500_GIC_DIST_BASE), 29);
  60. gic_cpu_init(0, __io_address(U8500_GIC_CPU_BASE));
  61. }
  62. /*
  63. * This function is called from the board init
  64. */
  65. void __init u8500_init_devices(void)
  66. {
  67. /* Register the platform devices */
  68. platform_add_devices(platform_devs, ARRAY_SIZE(platform_devs));
  69. return ;
  70. }
  71. static void __init u8500_timer_init(void)
  72. {
  73. #ifdef CONFIG_LOCAL_TIMERS
  74. /* Setup the local timer base */
  75. twd_base = __io_address(U8500_TWD_BASE);
  76. #endif
  77. /* Setup the MTU base */
  78. if (cpu_is_u8500ed())
  79. mtu_base = __io_address(U8500_MTU0_BASE_ED);
  80. else
  81. mtu_base = __io_address(U8500_MTU0_BASE_V1);
  82. nmdk_timer_init();
  83. }
  84. struct sys_timer u8500_timer = {
  85. .init = u8500_timer_init,
  86. };