ARM: shmobile: r8a7779: Use rcar_sysc_power_{down,up}_cpu()
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>
This commit is contained in:
Родитель
f2b1d2f94a
Коммит
9d65c89158
|
@ -31,59 +31,24 @@
|
||||||
#define AVECR IOMEM(0xfe700040)
|
#define AVECR IOMEM(0xfe700040)
|
||||||
#define R8A7779_SCU_BASE 0xf0000000
|
#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)
|
static int r8a7779_platform_cpu_kill(unsigned int cpu)
|
||||||
{
|
{
|
||||||
const struct rcar_sysc_ch *ch = NULL;
|
|
||||||
int ret = -EIO;
|
int ret = -EIO;
|
||||||
|
|
||||||
cpu = cpu_logical_map(cpu);
|
cpu = cpu_logical_map(cpu);
|
||||||
|
if (cpu)
|
||||||
if (cpu < ARRAY_SIZE(r8a7779_ch_cpu))
|
ret = rcar_sysc_power_down_cpu(cpu);
|
||||||
ch = r8a7779_ch_cpu[cpu];
|
|
||||||
|
|
||||||
if (ch)
|
|
||||||
ret = rcar_sysc_power_down(ch);
|
|
||||||
|
|
||||||
return ret ? ret : 1;
|
return ret ? ret : 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int r8a7779_boot_secondary(unsigned int cpu, struct task_struct *idle)
|
static int r8a7779_boot_secondary(unsigned int cpu, struct task_struct *idle)
|
||||||
{
|
{
|
||||||
const struct rcar_sysc_ch *ch = NULL;
|
int ret = -EIO;
|
||||||
unsigned int lcpu = cpu_logical_map(cpu);
|
|
||||||
int ret;
|
|
||||||
|
|
||||||
if (lcpu < ARRAY_SIZE(r8a7779_ch_cpu))
|
cpu = cpu_logical_map(cpu);
|
||||||
ch = r8a7779_ch_cpu[lcpu];
|
if (cpu)
|
||||||
|
ret = rcar_sysc_power_up_cpu(cpu);
|
||||||
if (ch)
|
|
||||||
ret = rcar_sysc_power_up(ch);
|
|
||||||
else
|
|
||||||
ret = -EIO;
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
Загрузка…
Ссылка в новой задаче