|
@@ -31,59 +31,24 @@
|
|
|
#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;
|
|
|
}
|