From: Peter Zijlstra <peterz@infradead.org>
To: Menglong Dong <menglong8.dong@gmail.com>
Cc: mingo@redhat.com, juri.lelli@redhat.com,
vincent.guittot@linaro.org, dietmar.eggemann@arm.com,
rostedt@goodmis.org, bsegall@google.com, mgorman@suse.de,
vschneid@redhat.com, linux-kernel@vger.kernel.org,
Menglong Dong <dongml2@chinatelecom.cn>,
Bin Lai <laib2@chinatelecom.cn>
Subject: Re: [PATCH next] sched: make printk safe when rq lock is held
Date: Tue, 6 Aug 2024 12:39:26 +0200 [thread overview]
Message-ID: <20240806103926.GU37996@noisy.programming.kicks-ass.net> (raw)
In-Reply-To: <20240806074131.36007-1-dongml2@chinatelecom.cn>
On Tue, Aug 06, 2024 at 03:41:31PM +0800, Menglong Dong wrote:
> The dead lock can happen if we try to use printk(), such as a call of
> SCHED_WARN_ON(), during the rq->__lock is held. The printk() will try to
> print the message to the console, and the console driver can call
> queue_work_on(), which will try to obtain rq->__lock again.
>
> This means that any WARN during the kernel function that hold the
> rq->__lock, such as schedule(), sched_ttwu_pending(), etc, can cause dead
> lock.
>
> Following is the call trace of the deadlock case that I encounter:
>
> PID: 0 TASK: ff36bfda010c8000 CPU: 156 COMMAND: "swapper/156"
> #0 crash_nmi_callback+30
> #1 nmi_handle+85
> #2 default_do_nmi+66
> #3 exc_nmi+291
> #4 end_repeat_nmi+22
> [exception RIP: native_queued_spin_lock_slowpath+96]
> #5 native_queued_spin_lock_slowpath+96
> #6 _raw_spin_lock+30
> #7 ttwu_queue+111
> #8 try_to_wake_up+375
> #9 __queue_work+462
> #10 queue_work_on+32
> #11 soft_cursor+420
> #12 bit_cursor+898
> #13 hide_cursor+39
> #14 vt_console_print+995
> #15 call_console_drivers.constprop.0+204
> #16 console_unlock+374
> #17 vprintk_emit+280
> #18 printk+88
> #19 __warn_printk+71
> #20 enqueue_task_fair+1779
> #21 activate_task+102
> #22 ttwu_do_activate+155
> #23 sched_ttwu_pending+177
> #24 flush_smp_call_function_from_idle+42
> #25 do_idle+161
> #26 cpu_startup_entry+25
> #27 secondary_startup_64_no_verify+194
>
> Fix this by using __printk_safe_enter()/__printk_safe_exit() in
> rq_pin_lock()/rq_unpin_lock(). Then, printk will defer to print out the
> buffers to the console.
Nope, sorry, not happening.
next prev parent reply other threads:[~2024-08-06 10:39 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-08-06 7:41 [PATCH next] sched: make printk safe when rq lock is held Menglong Dong
2024-08-06 10:39 ` Peter Zijlstra [this message]
2024-08-07 17:11 ` kernel test robot
2024-08-07 17:31 ` kernel test robot
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=20240806103926.GU37996@noisy.programming.kicks-ass.net \
--to=peterz@infradead.org \
--cc=bsegall@google.com \
--cc=dietmar.eggemann@arm.com \
--cc=dongml2@chinatelecom.cn \
--cc=juri.lelli@redhat.com \
--cc=laib2@chinatelecom.cn \
--cc=linux-kernel@vger.kernel.org \
--cc=menglong8.dong@gmail.com \
--cc=mgorman@suse.de \
--cc=mingo@redhat.com \
--cc=rostedt@goodmis.org \
--cc=vincent.guittot@linaro.org \
--cc=vschneid@redhat.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