From: Alex Shi <alex.shi@intel.com>
To: Thomas Gleixner <tglx@linutronix.de>
Cc: hpa@linux.intel.com, tim.c.chen@linux.intel.com,
linux-kernel@vger.kernel.org, andi.kleen@intel.com,
a.p.zijlstra@chello.nl, mingo@elte.hu
Subject: Re: [PATCH 3/3] clocksource: fix can not set tsc as clocksource bug
Date: Fri, 05 Jul 2013 10:48:51 +0800 [thread overview]
Message-ID: <51D63413.5020809@intel.com> (raw)
In-Reply-To: <alpine.DEB.2.02.1307041419560.11637@ionos.tec.linutronix.de>
On 07/04/2013 09:04 PM, Thomas Gleixner wrote:
>>> > > static int clocksource_watchdog_kthread(void *data)
>>> > > {
>>> > > struct clocksource *cs, *tmp;
>>> > > @@ -412,11 +415,14 @@ static int clocksource_watchdog_kthread(void *data)
>>> > >
>>> > > mutex_lock(&clocksource_mutex);
>>> > > spin_lock_irqsave(&watchdog_lock, flags);
>>> > > - list_for_each_entry_safe(cs, tmp, &watchdog_list, wd_list)
>>> > > + list_for_each_entry_safe(cs, tmp, &watchdog_list, wd_list) {
>>> > > if (cs->flags & CLOCK_SOURCE_UNSTABLE) {
>>> > > list_del_init(&cs->wd_list);
>>> > > list_add(&cs->wd_list, &unstable);
>>> > > }
>>> > > + if (cs->flags & CLOCK_SOURCE_VALID_FOR_HRES)
>>> > > + clocksource_select();
>> >
>> > Unlikely, but if we have 3 watched clocksources which have the HRES
>> > bit set, you'd call 3 times clocksource_select().
> Also the reselect must be called outside the watchdog_lock region.
Sorry for stupid, the watchdog_lock used protect watchdog related
resource. but clocksource_select doesn't touch them. So, I know it isn't
necessary to put reselect under this lock. Just don't know why the
reselect *must* be called outside of it?
--
Thanks
Alex
next prev parent reply other threads:[~2013-07-05 2:50 UTC|newest]
Thread overview: 34+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-07-04 5:34 [URGENT rfc patch 0/3] tsc clocksource bug fix Alex Shi
2013-07-04 5:34 ` [PATCH 1/3] clocksource: clean up clocksource_select Alex Shi
2013-07-04 9:57 ` Thomas Gleixner
2013-07-04 10:21 ` Alex Shi
2013-07-04 10:27 ` Thomas Gleixner
2013-07-05 1:22 ` Alex Shi
2013-07-04 5:34 ` [PATCH 2/3] clockesource: set override clocksource Alex Shi
2013-07-04 10:23 ` Thomas Gleixner
2013-07-04 5:34 ` [PATCH 3/3] clocksource: fix can not set tsc as clocksource bug Alex Shi
2013-07-04 10:55 ` Thomas Gleixner
2013-07-04 13:04 ` Thomas Gleixner
2013-07-04 20:46 ` [PATCH] clocksource: Reselect clocksource when watchdog validated Thomas Gleixner
2013-07-05 1:38 ` Alex Shi
2013-07-05 9:13 ` [tip:timers/core] clocksource: Reselect clocksource when watchdog validated high-res capability tip-bot for Thomas Gleixner
2013-07-05 2:48 ` Alex Shi [this message]
2013-07-05 5:41 ` [PATCH 3/3] clocksource: fix can not set tsc as clocksource bug Thomas Gleixner
2013-07-05 6:44 ` Alex Shi
2013-07-04 7:58 ` [URGENT rfc patch 0/3] tsc clocksource bug fix Peter Zijlstra
2013-07-04 8:13 ` Alex Shi
2013-07-05 14:23 ` Frederic Weisbecker
2013-07-05 14:38 ` Peter Zijlstra
2013-07-05 15:24 ` Thomas Gleixner
2013-07-05 21:22 ` Peter Zijlstra
2013-07-05 21:50 ` Thomas Gleixner
2013-07-05 21:58 ` Borislav Petkov
2013-07-05 22:17 ` Thomas Gleixner
2013-07-06 8:37 ` Borislav Petkov
2013-07-06 10:50 ` Peter Zijlstra
2013-07-04 11:00 ` Thomas Gleixner
2013-07-04 18:11 ` Davidlohr Bueso
2013-07-04 20:27 ` Thomas Gleixner
2013-07-05 1:12 ` Alex Shi
2013-07-05 5:58 ` Thomas Gleixner
2013-07-05 6:28 ` Alex Shi
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=51D63413.5020809@intel.com \
--to=alex.shi@intel.com \
--cc=a.p.zijlstra@chello.nl \
--cc=andi.kleen@intel.com \
--cc=hpa@linux.intel.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mingo@elte.hu \
--cc=tglx@linutronix.de \
--cc=tim.c.chen@linux.intel.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