From: <Conor.Dooley@microchip.com>
To: <xianting.tian@linux.alibaba.com>, <paul.walmsley@sifive.com>,
<palmer@dabbelt.com>, <aou@eecs.berkeley.edu>,
<anup@brainfault.org>, <heiko@sntech.de>, <guoren@kernel.org>,
<mick@ics.forth.gr>, <alexandre.ghiti@canonical.com>,
<bhe@redhat.com>, <vgoyal@redhat.com>, <dyoung@redhat.com>,
<corbet@lwn.net>, <Conor.Dooley@microchip.com>
Cc: <kexec@lists.infradead.org>, <linux-doc@vger.kernel.org>,
<linux-riscv@lists.infradead.org>, <linux-kernel@vger.kernel.org>,
<crash-utility@redhat.com>, <huanyi.xj@alibaba-inc.com>,
<heinrich.schuchardt@canonical.com>, <k-hagio-ab@nec.com>,
<hschauhan@nulltrace.org>, <yixun.lan@gmail.com>
Subject: Re: [PATCH V5 1/6] RISC-V: use __smp_processor_id() instead of smp_processor_id()
Date: Tue, 9 Aug 2022 21:10:46 +0000 [thread overview]
Message-ID: <4a3c8f81-6b4a-4cfc-5098-959fab87ac44@microchip.com> (raw)
In-Reply-To: <20220802121818.2201268-2-xianting.tian@linux.alibaba.com>
On 02/08/2022 13:18, Xianting Tian wrote:
> [PATCH V5 1/6] RISC-V: use __smp_processor_id() instead of smp_processor_id()
FWIW this subject is very non specific - its not easy to tell what
it's about. How about something something like:
RISC-V: kexec: fix use of smp_processor_id() in preemptible context
> Use __smp_processor_id() to avoid check the preemption context when
> CONFIG_DEBUG_PREEMPT enabled, as we will enter crash kernel and no
> return.
>
> Without the patch,
> [ 103.781044] sysrq: Trigger a crash
> [ 103.784625] Kernel panic - not syncing: sysrq triggered crash
> [ 103.837634] CPU1: off
> [ 103.889668] CPU2: off
> [ 103.933479] CPU3: off
> [ 103.939424] Starting crashdump kernel...
> [ 103.943442] BUG: using smp_processor_id() in preemptible [00000000] code: sh/346
> [ 103.950884] caller is debug_smp_processor_id+0x1c/0x26
> [ 103.956051] CPU: 0 PID: 346 Comm: sh Kdump: loaded Not tainted 5.10.113-00002-gce03f03bf4ec-dirty #149
> [ 103.965355] Call Trace:
> [ 103.967805] [<ffffffe00020372a>] walk_stackframe+0x0/0xa2
> [ 103.973206] [<ffffffe000bcf1f4>] show_stack+0x32/0x3e
> [ 103.978258] [<ffffffe000bd382a>] dump_stack_lvl+0x72/0x8e
> [ 103.983655] [<ffffffe000bd385a>] dump_stack+0x14/0x1c
> [ 103.988705] [<ffffffe000bdc8fe>] check_preemption_disabled+0x9e/0xaa
> [ 103.995057] [<ffffffe000bdc926>] debug_smp_processor_id+0x1c/0x26
> [ 104.001150] [<ffffffe000206c64>] machine_kexec+0x22/0xd0
> [ 104.006463] [<ffffffe000291a7e>] __crash_kexec+0x6a/0xa4
> [ 104.011774] [<ffffffe000bcf3fa>] panic+0xfc/0x2b0
> [ 104.016480] [<ffffffe000656ca4>] sysrq_reset_seq_param_set+0x0/0x70
> [ 104.022745] [<ffffffe000657310>] __handle_sysrq+0x8c/0x154
> [ 104.028229] [<ffffffe0006577e8>] write_sysrq_trigger+0x5a/0x6a
> [ 104.034061] [<ffffffe0003d90e0>] proc_reg_write+0x58/0xd4
> [ 104.039459] [<ffffffe00036cff4>] vfs_write+0x7e/0x254
> [ 104.044509] [<ffffffe00036d2f6>] ksys_write+0x58/0xbe
> [ 104.049558] [<ffffffe00036d36a>] sys_write+0xe/0x16
> [ 104.054434] [<ffffffe000201b9a>] ret_from_syscall+0x0/0x2
> [ 104.067863] Will call new kernel at ecc00000 from hart id 0
> [ 104.074939] FDT image at fc5ee000
> [ 104.079523] Bye...
>
> With the patch we can got clear output,
> [ 67.740553] sysrq: Trigger a crash
> [ 67.744166] Kernel panic - not syncing: sysrq triggered crash
> [ 67.809123] CPU1: off
> [ 67.865210] CPU2: off
> [ 67.909075] CPU3: off
> [ 67.919123] Starting crashdump kernel...
> [ 67.924900] Will call new kernel at ecc00000 from hart id 0
> [ 67.932045] FDT image at fc5ee000
> [ 67.935560] Bye...
>
> Fixes: 0e105f1d0037 ("riscv: use hart id instead of cpu id on machine_kexec")
> Reviewed-by: Guo Ren <guoren@kernel.org>
> Reviewed-by: Heiko Stuebner <heiko@sntech.de>
> Reviewed-by: Atish Patra <atishp@rivosinc.com>
> Signed-off-by: Xianting Tian <xianting.tian@linux.alibaba.com>
> ---
> arch/riscv/kernel/machine_kexec.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/arch/riscv/kernel/machine_kexec.c b/arch/riscv/kernel/machine_kexec.c
> index df8e24559035..86d1b5f9dfb5 100644
> --- a/arch/riscv/kernel/machine_kexec.c
> +++ b/arch/riscv/kernel/machine_kexec.c
> @@ -171,7 +171,7 @@ machine_kexec(struct kimage *image)
> struct kimage_arch *internal = &image->arch;
> unsigned long jump_addr = (unsigned long) image->start;
> unsigned long first_ind_entry = (unsigned long) &image->head;
> - unsigned long this_cpu_id = smp_processor_id();
> + unsigned long this_cpu_id = __smp_processor_id();
> unsigned long this_hart_id = cpuid_to_hartid_map(this_cpu_id);
> unsigned long fdt_addr = internal->fdt_addr;
> void *control_code_buffer = page_address(image->control_code_page);
_______________________________________________
linux-riscv mailing list
linux-riscv@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-riscv
next prev parent reply other threads:[~2022-08-09 21:11 UTC|newest]
Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-08-02 12:18 [PATCH V5 0/6] RISC-V fixups to work with crash tool Xianting Tian
2022-08-02 12:18 ` [PATCH V5 1/6] RISC-V: use __smp_processor_id() instead of smp_processor_id() Xianting Tian
2022-08-09 21:10 ` Conor.Dooley [this message]
2022-08-02 12:18 ` [PATCH V5 2/6] RISC-V: Add arch_crash_save_vmcoreinfo support Xianting Tian
2022-08-02 12:18 ` [PATCH V5 3/6] riscv: Add modules to virtual kernel memory layout dump Xianting Tian
2022-08-02 12:18 ` [PATCH V5 4/6] RISC-V: Fixup getting correct current pc Xianting Tian
2022-08-09 21:13 ` Conor.Dooley
2022-08-09 21:14 ` Conor.Dooley
2022-08-02 12:18 ` [PATCH V5 5/6] riscv: crash_core: Export kernel vm layout, phys_ram_base Xianting Tian
2022-08-09 21:20 ` Conor.Dooley
2022-08-10 12:00 ` Xianting Tian
2022-08-11 3:06 ` Bagas Sanjaya
2022-08-11 3:37 ` Xianting Tian
2022-08-02 12:18 ` [PATCH V5 6/6] RISC-V: Fixup schedule out issue in machine_crash_shutdown() Xianting Tian
2022-08-09 21:20 ` Conor.Dooley
2022-08-09 6:58 ` [PATCH V5 0/6] RISC-V fixups to work with crash tool Xianting Tian
2022-08-09 21:24 ` Conor.Dooley
2022-08-11 2:54 ` Xianting Tian
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4a3c8f81-6b4a-4cfc-5098-959fab87ac44@microchip.com \
--to=conor.dooley@microchip.com \
--cc=alexandre.ghiti@canonical.com \
--cc=anup@brainfault.org \
--cc=aou@eecs.berkeley.edu \
--cc=bhe@redhat.com \
--cc=corbet@lwn.net \
--cc=crash-utility@redhat.com \
--cc=dyoung@redhat.com \
--cc=guoren@kernel.org \
--cc=heiko@sntech.de \
--cc=heinrich.schuchardt@canonical.com \
--cc=hschauhan@nulltrace.org \
--cc=huanyi.xj@alibaba-inc.com \
--cc=k-hagio-ab@nec.com \
--cc=kexec@lists.infradead.org \
--cc=linux-doc@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-riscv@lists.infradead.org \
--cc=mick@ics.forth.gr \
--cc=palmer@dabbelt.com \
--cc=paul.walmsley@sifive.com \
--cc=vgoyal@redhat.com \
--cc=xianting.tian@linux.alibaba.com \
--cc=yixun.lan@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox