smp-r8a7790.c 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. /*
  2. * SMP support for r8a7790
  3. *
  4. * Copyright (C) 2012-2013 Renesas Solutions Corp.
  5. * Copyright (C) 2012 Takashi Yoshii <takashi.yoshii.ze@renesas.com>
  6. *
  7. * This program is free software; you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License as published by
  9. * the Free Software Foundation; version 2 of the License.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. */
  16. #include <linux/kernel.h>
  17. #include <linux/init.h>
  18. #include <linux/smp.h>
  19. #include <linux/io.h>
  20. #include <linux/soc/renesas/rcar-sysc.h>
  21. #include <asm/smp_plat.h>
  22. #include "common.h"
  23. #include "platsmp-apmu.h"
  24. #include "rcar-gen2.h"
  25. #include "r8a7790.h"
  26. static const struct rcar_sysc_ch r8a7790_ca15_scu = {
  27. .chan_offs = 0x180, /* PWRSR5 .. PWRER5 */
  28. .isr_bit = 12, /* CA15-SCU */
  29. };
  30. static const struct rcar_sysc_ch r8a7790_ca7_scu = {
  31. .chan_offs = 0x100, /* PWRSR3 .. PWRER3 */
  32. .isr_bit = 21, /* CA7-SCU */
  33. };
  34. static struct rcar_apmu_config r8a7790_apmu_config[] = {
  35. {
  36. .iomem = DEFINE_RES_MEM(0xe6152000, 0x188),
  37. .cpus = { 0, 1, 2, 3 },
  38. },
  39. {
  40. .iomem = DEFINE_RES_MEM(0xe6151000, 0x188),
  41. .cpus = { 0x100, 0x0101, 0x102, 0x103 },
  42. }
  43. };
  44. static void __init r8a7790_smp_prepare_cpus(unsigned int max_cpus)
  45. {
  46. /* let APMU code install data related to shmobile_boot_vector */
  47. shmobile_smp_apmu_prepare_cpus(max_cpus,
  48. r8a7790_apmu_config,
  49. ARRAY_SIZE(r8a7790_apmu_config));
  50. /* turn on power to SCU */
  51. rcar_gen2_pm_init();
  52. rcar_sysc_power_up(&r8a7790_ca15_scu);
  53. rcar_sysc_power_up(&r8a7790_ca7_scu);
  54. }
  55. const struct smp_operations r8a7790_smp_ops __initconst = {
  56. .smp_prepare_cpus = r8a7790_smp_prepare_cpus,
  57. .smp_boot_secondary = shmobile_smp_apmu_boot_secondary,
  58. #ifdef CONFIG_HOTPLUG_CPU
  59. .cpu_can_disable = shmobile_smp_cpu_can_disable,
  60. .cpu_die = shmobile_smp_apmu_cpu_die,
  61. .cpu_kill = shmobile_smp_apmu_cpu_kill,
  62. #endif
  63. };