From: Jason Wessel <jason.wessel@windriver.com>
To: Peter Zijlstra <peterz@infradead.org>
Cc: Ingo Molnar <mingo@elte.hu>, lkml <linux-kernel@vger.kernel.org>,
"Deng, Dongdong" <Dongdong.Deng@windriver.com>
Subject: Re: [PATCH] softlockup: fix problem with long kernel pauses from kgdb
Date: Mon, 27 Jul 2009 16:25:32 -0500 [thread overview]
Message-ID: <4A6E1B4C.1050903@windriver.com> (raw)
In-Reply-To: <1248725893.6987.2055.camel@twins>
Peter Zijlstra wrote:
> On Mon, 2009-07-27 at 15:03 -0500, Jason Wessel wrote:
>
>> The fix is to simply invoke sched_clock_tick() to update "cpu sched
>> clock" on exit from kgdb_handle_exception.
>>
>
> Is that a regular IRQ context, or is that NMI context?
>
>
The patch text there is incorrect (which I can fix), because there were
3 other versions of this particular patch. The version of this patch
that tried to use sched_clock_tick() from the exception context hung the
system because there was lock contention for CPUs that were not in the
running state.
In this version, the sched_clock_tick() added in the softlockup_tick(),
which did not result in a hard hang. I am pretty sure that
softlockup_tick() runs as a part of the timer interrupt processing from
run_local_timers(), so there was no further need to turn off the interrupts.
Jason.
>> Signed-off-by: Dongdong Deng <Dongdong.Deng@windriver.com>
>> Signed-off-by: Jason Wessel <jason.wessel@windriver.com>
>> Cc: Ingo Molnar <mingo@elte.hu>
>> Cc: peterz@infradead.org
>> ---
>> kernel/softlockup.c | 3 +++
>> 1 file changed, 3 insertions(+)
>>
>> --- a/kernel/softlockup.c
>> +++ b/kernel/softlockup.c
>> @@ -118,6 +118,9 @@ void softlockup_tick(void)
>> }
>>
>> if (touch_timestamp == 0) {
>> + /* If the time stamp was touched externally make sure the
>> + * scheduler tick is up to date as well */
>> + sched_clock_tick();
>> __touch_softlockup_watchdog();
>> return;
>> }
>>
>>
>
> Aside from the funny comment style (please fix) the fix does look
> sensible.
>
No problem.
Thanks,
Jason.
next prev parent reply other threads:[~2009-07-27 21:25 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-07-27 20:03 [PATCH] softlockup: fix problem with long kernel pauses from kgdb Jason Wessel
2009-07-27 20:18 ` Peter Zijlstra
2009-07-27 21:25 ` Jason Wessel [this message]
2009-07-28 15:05 ` Jason Wessel
2009-08-04 14:16 ` Ingo Molnar
2009-08-04 14:53 ` [PATCH] softlockup: fix problem with long kernel pauses fromkgdb Jason Wessel
2009-08-04 14:59 ` Ingo Molnar
2009-08-21 12:42 ` [PATCH] softlockup: fix problem with long kernel pauses from kgdb DDD
2009-09-26 3:01 ` Yong Zhang
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=4A6E1B4C.1050903@windriver.com \
--to=jason.wessel@windriver.com \
--cc=Dongdong.Deng@windriver.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mingo@elte.hu \
--cc=peterz@infradead.org \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.