Message ID | 1637840372-27773-1-git-send-email-yangtiezhu@loongson.cn (mailing list archive) |
---|---|
State | Accepted |
Commit | 1cab5bd69eb1f995ced2d7576cb15f8a8941fd85 |
Headers | show |
Series | [v2] MIPS: Fix using smp_processor_id() in preemptible in show_cpuinfo() | expand |
On Thu, Nov 25, 2021 at 07:39:32PM +0800, Tiezhu Yang wrote: > There exists the following issue under DEBUG_PREEMPT: > > BUG: using smp_processor_id() in preemptible [00000000] code: systemd/1 > caller is show_cpuinfo+0x460/0xea0 > ... > Call Trace: > [<ffffffff8020f0dc>] show_stack+0x94/0x128 > [<ffffffff80e6cab4>] dump_stack_lvl+0x94/0xd8 > [<ffffffff80e74c5c>] check_preemption_disabled+0x104/0x110 > [<ffffffff802209c8>] show_cpuinfo+0x460/0xea0 > [<ffffffff80539d54>] seq_read_iter+0xfc/0x4f8 > [<ffffffff804fcc10>] new_sync_read+0x110/0x1b8 > [<ffffffff804ff57c>] vfs_read+0x1b4/0x1d0 > [<ffffffff804ffb18>] ksys_read+0xd0/0x110 > [<ffffffff8021c090>] syscall_common+0x34/0x58 > > We can see the following call trace: > show_cpuinfo() > cpu_has_fpu > current_cpu_data > smp_processor_id() > > $ addr2line -f -e vmlinux 0xffffffff802209c8 > show_cpuinfo > arch/mips/kernel/proc.c:188 > > $ head -188 arch/mips/kernel/proc.c | tail -1 > if (cpu_has_fpu) > > arch/mips/include/asm/cpu-features.h > # define cpu_has_fpu (current_cpu_data.options & MIPS_CPU_FPU) > > arch/mips/include/asm/cpu-info.h > #define current_cpu_data cpu_data[smp_processor_id()] > > Based on the above analysis, fix the issue by using raw_cpu_has_fpu > which calls raw_smp_processor_id() in show_cpuinfo(). > > Fixes: 626bfa037299 ("MIPS: kernel: proc: add CPU option reporting") > Signed-off-by: Tiezhu Yang <yangtiezhu@loongson.cn> > --- > arch/mips/kernel/proc.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/arch/mips/kernel/proc.c b/arch/mips/kernel/proc.c > index 376a6e2..9f47a88 100644 > --- a/arch/mips/kernel/proc.c > +++ b/arch/mips/kernel/proc.c > @@ -185,7 +185,7 @@ static int show_cpuinfo(struct seq_file *m, void *v) > seq_puts(m, " tx39_cache"); > if (cpu_has_octeon_cache) > seq_puts(m, " octeon_cache"); > - if (cpu_has_fpu) > + if (raw_cpu_has_fpu) > seq_puts(m, " fpu"); > if (cpu_has_32fpr) > seq_puts(m, " 32fpr"); > -- > 2.1.0 applied to mips-fixes. Thomas.
diff --git a/arch/mips/kernel/proc.c b/arch/mips/kernel/proc.c index 376a6e2..9f47a88 100644 --- a/arch/mips/kernel/proc.c +++ b/arch/mips/kernel/proc.c @@ -185,7 +185,7 @@ static int show_cpuinfo(struct seq_file *m, void *v) seq_puts(m, " tx39_cache"); if (cpu_has_octeon_cache) seq_puts(m, " octeon_cache"); - if (cpu_has_fpu) + if (raw_cpu_has_fpu) seq_puts(m, " fpu"); if (cpu_has_32fpr) seq_puts(m, " 32fpr");
There exists the following issue under DEBUG_PREEMPT: BUG: using smp_processor_id() in preemptible [00000000] code: systemd/1 caller is show_cpuinfo+0x460/0xea0 ... Call Trace: [<ffffffff8020f0dc>] show_stack+0x94/0x128 [<ffffffff80e6cab4>] dump_stack_lvl+0x94/0xd8 [<ffffffff80e74c5c>] check_preemption_disabled+0x104/0x110 [<ffffffff802209c8>] show_cpuinfo+0x460/0xea0 [<ffffffff80539d54>] seq_read_iter+0xfc/0x4f8 [<ffffffff804fcc10>] new_sync_read+0x110/0x1b8 [<ffffffff804ff57c>] vfs_read+0x1b4/0x1d0 [<ffffffff804ffb18>] ksys_read+0xd0/0x110 [<ffffffff8021c090>] syscall_common+0x34/0x58 We can see the following call trace: show_cpuinfo() cpu_has_fpu current_cpu_data smp_processor_id() $ addr2line -f -e vmlinux 0xffffffff802209c8 show_cpuinfo arch/mips/kernel/proc.c:188 $ head -188 arch/mips/kernel/proc.c | tail -1 if (cpu_has_fpu) arch/mips/include/asm/cpu-features.h # define cpu_has_fpu (current_cpu_data.options & MIPS_CPU_FPU) arch/mips/include/asm/cpu-info.h #define current_cpu_data cpu_data[smp_processor_id()] Based on the above analysis, fix the issue by using raw_cpu_has_fpu which calls raw_smp_processor_id() in show_cpuinfo(). Fixes: 626bfa037299 ("MIPS: kernel: proc: add CPU option reporting") Signed-off-by: Tiezhu Yang <yangtiezhu@loongson.cn> --- arch/mips/kernel/proc.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-)