ARM: shmobile: r8a7779: Use rcar_sysc_power_{down,up}_cpu()
authorGeert Uytterhoeven <geert+renesas@glider.be>
Wed, 30 May 2018 15:25:14 +0000 (17:25 +0200)
committerSimon Horman <horms+renesas@verge.net.au>
Mon, 18 Jun 2018 10:00:28 +0000 (12:00 +0200)
The r8a7779 SMP code calls rcar_sysc_power_{down,up}() to control power
to the SYSC power areas containing CPUs. This requires passing full CPU
power area parameter blocks.

Migrate the code to call the new rcar_sysc_power_{down,up}_cpu()
helpers, which just take a CPU index, and use the SYSC power area
definitions from the r8a7779-sysc driver.

Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be>
Signed-off-by: Simon Horman <horms+renesas@verge.net.au>
arch/arm/mach-shmobile/smp-r8a7779.c

index ff1e6fc..3036f91 100644 (file)
 #define AVECR IOMEM(0xfe700040)
 #define R8A7779_SCU_BASE 0xf0000000
 
-static const struct rcar_sysc_ch r8a7779_ch_cpu1 = {
-       .chan_offs = 0x40, /* PWRSR0 .. PWRER0 */
-       .chan_bit = 1, /* ARM1 */
-       .isr_bit = 1, /* ARM1 */
-};
-
-static const struct rcar_sysc_ch r8a7779_ch_cpu2 = {
-       .chan_offs = 0x40, /* PWRSR0 .. PWRER0 */
-       .chan_bit = 2, /* ARM2 */
-       .isr_bit = 2, /* ARM2 */
-};
-
-static const struct rcar_sysc_ch r8a7779_ch_cpu3 = {
-       .chan_offs = 0x40, /* PWRSR0 .. PWRER0 */
-       .chan_bit = 3, /* ARM3 */
-       .isr_bit = 3, /* ARM3 */
-};
-
-static const struct rcar_sysc_ch * const r8a7779_ch_cpu[4] = {
-       [1] = &r8a7779_ch_cpu1,
-       [2] = &r8a7779_ch_cpu2,
-       [3] = &r8a7779_ch_cpu3,
-};
-
 static int r8a7779_platform_cpu_kill(unsigned int cpu)
 {
-       const struct rcar_sysc_ch *ch = NULL;
        int ret = -EIO;
 
        cpu = cpu_logical_map(cpu);
-
-       if (cpu < ARRAY_SIZE(r8a7779_ch_cpu))
-               ch = r8a7779_ch_cpu[cpu];
-
-       if (ch)
-               ret = rcar_sysc_power_down(ch);
+       if (cpu)
+               ret = rcar_sysc_power_down_cpu(cpu);
 
        return ret ? ret : 1;
 }
 
 static int r8a7779_boot_secondary(unsigned int cpu, struct task_struct *idle)
 {
-       const struct rcar_sysc_ch *ch = NULL;
-       unsigned int lcpu = cpu_logical_map(cpu);
-       int ret;
-
-       if (lcpu < ARRAY_SIZE(r8a7779_ch_cpu))
-               ch = r8a7779_ch_cpu[lcpu];
+       int ret = -EIO;
 
-       if (ch)
-               ret = rcar_sysc_power_up(ch);
-       else
-               ret = -EIO;
+       cpu = cpu_logical_map(cpu);
+       if (cpu)
+               ret = rcar_sysc_power_up_cpu(cpu);
 
        return ret;
 }