>[ 0.029102] Hierarchical SRCU implementation. >[ 0.030040] smp: Bringing up secondary CPUs ... >[ 0.030528] smp: Brought up 1 node, 1 CPU >[ 0.030953] divide error: 0000 [#1] SMP DEBUG_PAGEALLOC >[ 0.031000] Modules linked in: >[ 0.031000] CPU: 0 PID: 1 Comm: swapper/0 Not tainted 4.14.0-01223-gb1cbacc >#1 >[ 0.031000] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS >1.10.2-1 04/01/2014 >[ 0.031000] task: ffff88001e460000 task.stack: ffffc90000008000
A single socket/package, single core, single thread system has 1 thread. __max_smt_threads is not set to 1 since smp_callin() is never called. The minimum value of __max_smt_threads must be 1. tglx, this is built on -tip. P. ----8<---- Subject: [PATCH] arch/x86: Initialize __max_smt_threads to 1 A single socket, single core, single thread system has __max_smt_threads set to 0 since smp_callin() is not called. __max_smt_threads must be a minimum of 1. Fixes: b1cbacc8663a ("x86/smpboot: Do not use smp_num_siblings in __max_logical_packages calculation) Signed-off-by: Prarit Bhargava <pra...@redhat.com> Cc: Jakub Kicinski <kubak...@wp.pl> Cc: netdev@vger.kernel.org Cc: "netdev@vger.kernel.org" Cc: Clark Williams <willi...@redhat.com> Cc: Andi Kleen <a...@linux.intel.com> Cc: x...@kernel.org Link: https://marc.info/?t=151246092100004&r=1&w=2 --- arch/x86/kernel/smpboot.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/arch/x86/kernel/smpboot.c b/arch/x86/kernel/smpboot.c index eaee15fb7d8b..882c61e1d7a2 100644 --- a/arch/x86/kernel/smpboot.c +++ b/arch/x86/kernel/smpboot.c @@ -106,7 +106,7 @@ EXPORT_SYMBOL(__max_logical_packages); static unsigned int logical_packages __read_mostly; /* Maximum number of SMT threads on any online core */ -int __max_smt_threads __read_mostly; +int __read_mostly __max_smt_threads = 1; /* Flag to indicate if a complete sched domain rebuild is required */ bool x86_topology_update; -- 2.15.0.rc0.39.g2f0e14e64