setup-sh73a0.c 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * sh73a0 processor support
  4. *
  5. * Copyright (C) 2010 Takashi Yoshii
  6. * Copyright (C) 2010 Magnus Damm
  7. * Copyright (C) 2008 Yoshihiro Shimoda
  8. */
  9. #include <linux/kernel.h>
  10. #include <linux/init.h>
  11. #include <linux/interrupt.h>
  12. #include <linux/irq.h>
  13. #include <linux/delay.h>
  14. #include <linux/input.h>
  15. #include <linux/io.h>
  16. #include <asm/hardware/cache-l2x0.h>
  17. #include <asm/mach/map.h>
  18. #include <asm/mach/arch.h>
  19. #include <asm/mach/time.h>
  20. #include "common.h"
  21. #include "sh73a0.h"
  22. static struct map_desc sh73a0_io_desc[] __initdata = {
  23. /* create a 1:1 identity mapping for 0xe6xxxxxx
  24. * used by CPGA, INTC and PFC.
  25. */
  26. {
  27. .virtual = 0xe6000000,
  28. .pfn = __phys_to_pfn(0xe6000000),
  29. .length = 256 << 20,
  30. .type = MT_DEVICE_NONSHARED
  31. },
  32. };
  33. static void __init sh73a0_map_io(void)
  34. {
  35. debug_ll_io_init();
  36. iotable_init(sh73a0_io_desc, ARRAY_SIZE(sh73a0_io_desc));
  37. }
  38. static void __init sh73a0_generic_init(void)
  39. {
  40. #ifdef CONFIG_CACHE_L2X0
  41. /* Shared attribute override enable, 64K*8way */
  42. l2x0_init(IOMEM(0xf0100000), 0x00400000, 0xc20f0fff);
  43. #endif
  44. }
  45. static const char *const sh73a0_boards_compat_dt[] __initconst = {
  46. "renesas,sh73a0",
  47. NULL,
  48. };
  49. DT_MACHINE_START(SH73A0_DT, "Generic SH73A0 (Flattened Device Tree)")
  50. .smp = smp_ops(sh73a0_smp_ops),
  51. .map_io = sh73a0_map_io,
  52. .init_early = shmobile_init_delay,
  53. .init_machine = sh73a0_generic_init,
  54. .init_late = shmobile_init_late,
  55. .dt_compat = sh73a0_boards_compat_dt,
  56. MACHINE_END