On Fri, 12 Dec 2014 12:37:40 +0100
Greg Kurz <gk...@linux.vnet.ibm.com> wrote:

> The subcore logic needs all the CPUs declared in the DT to be bootable,
> otherwise the kernel hangs at boot time. Since subcore support starts
> with POWER8, we can keep the current behaviour for older CPUs.
> 
> Signed-off-by: Greg Kurz <gk...@linux.vnet.ibm.com>
> ---
> 
> Since smt-enabled is still needed by Freescale, the choice was made to fix
> powernv only. I could test that smt-enabled is still honored on POWER7 and
> ignored on POWER8, as expected.
> 

FWIW I get plenty (for nearly all vcpus) the following dump when booting a
PowerKVM guest on a virtio-blk disk with smt-enabled=off:

[   10.535151] kobject '(null)' (c0000007ff260c18): tried to add an 
uninitialized object, something is seriously wrong.
[   10.535538] CPU: 12 PID: 708 Comm: systemd-udevd Not tainted 3.18.0-rc3+ #3
[   10.535779] Call Trace:
[   10.535886] [c0000000ff0e38f0] [c0000000007a1db8] dump_stack+0x90/0xbc 
(unreliable)
[   10.536242] [c0000000ff0e3920] [c0000000003c5504] kobject_add+0xc4/0xd0
[   10.536593] [c0000000ff0e39a0] [c00000000039df20] 
blk_mq_register_hctx+0xd0/0x100
[   10.536930] [c0000000ff0e3a20] [c00000000039ed0c] 
blk_mq_sysfs_register+0x5c/0xb0
[   10.537257] [c0000000ff0e3a50] [c00000000039b694] 
blk_mq_queue_reinit_notify+0xc4/0x110
[   10.537594] [c0000000ff0e3a90] [c0000000000c5388] 
notifier_call_chain+0x88/0x100
[   10.537942] [c0000000ff0e3ae0] [c00000000009e264] cpu_notify+0x34/0x80
[   10.538227] [c0000000ff0e3b00] [c00000000009e794] _cpu_up+0x204/0x210
[   10.538519] [c0000000ff0e3bb0] [c00000000009e8ac] cpu_up+0x10c/0x130
[   10.538796] [c0000000ff0e3c30] [c00000000062121c] cpu_subsys_online+0x5c/0xe0
[   10.539089] [c0000000ff0e3c80] [c0000000004bf0e4] device_online+0xb4/0x120
[   10.539370] [c0000000ff0e3cc0] [c0000000004bf1f4] online_store+0xa4/0xb0
[   10.539651] [c0000000ff0e3d00] [c0000000004bb744] dev_attr_store+0x34/0x60
[   10.539929] [c0000000ff0e3d20] [c0000000003038c4] sysfs_kf_write+0x64/0xa0
[   10.540217] [c0000000ff0e3d40] [c000000000302940] 
kernfs_fop_write+0x140/0x1d0
[   10.540553] [c0000000ff0e3d90] [c00000000026ac64] vfs_write+0xd4/0x260
[   10.540831] [c0000000ff0e3de0] [c00000000026b780] SyS_write+0x60/0x110
[   10.541131] [c0000000ff0e3e30] [c0000000000091fc] syscall_exit+0x0/0x7c

It seems that split core isn't the only code that gets affected by smt-enabled.
Should we drop cpu_bootable for pseries ?

Cheers.

--
Greg

>  arch/powerpc/platforms/powernv/smp.c |   13 ++++++++++++-
>  1 file changed, 12 insertions(+), 1 deletion(-)
> 
> diff --git a/arch/powerpc/platforms/powernv/smp.c 
> b/arch/powerpc/platforms/powernv/smp.c
> index b716f66..5b6e002 100644
> --- a/arch/powerpc/platforms/powernv/smp.c
> +++ b/arch/powerpc/platforms/powernv/smp.c
> @@ -198,13 +198,24 @@ static void pnv_smp_cpu_kill_self(void)
>  
>  #endif /* CONFIG_HOTPLUG_CPU */
>  
> +static int pnv_cpu_bootable(unsigned int nr)
> +{
> +     /* Starting with POWER8, all CPUs need to be booted to avoid hangs
> +      * during subcore init.
> +      */
> +     if (cpu_has_feature(CPU_FTR_ARCH_207S))
> +             return 1;
> +
> +     return smp_generic_cpu_bootable(nr);
> +}
> +
>  static struct smp_ops_t pnv_smp_ops = {
>       .message_pass   = smp_muxed_ipi_message_pass,
>       .cause_ipi      = NULL, /* Filled at runtime by xics_smp_probe() */
>       .probe          = xics_smp_probe,
>       .kick_cpu       = pnv_smp_kick_cpu,
>       .setup_cpu      = pnv_smp_setup_cpu,
> -     .cpu_bootable   = smp_generic_cpu_bootable,
> +     .cpu_bootable   = pnv_cpu_bootable,
>  #ifdef CONFIG_HOTPLUG_CPU
>       .cpu_disable    = pnv_smp_cpu_disable,
>       .cpu_die        = generic_cpu_die,
> 
> _______________________________________________
> Linuxppc-dev mailing list
> Linuxppc-dev@lists.ozlabs.org
> https://lists.ozlabs.org/listinfo/linuxppc-dev

_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to