From: Ingo Molnar <mingo@kernel.org>
To: Shaohua Li <shli@fb.com>
Cc: Thomas Gleixner <tglx@linutronix.de>,
x86@kernel.org, linux-kernel@vger.kernel.org, Kernel-team@fb.com,
Suresh Siddha <suresh.b.siddha@intel.com>,
"H. Peter Anvin" <hpa@zytor.com>,
stable@vger.kernel.org, ak@linux.intel.com, lenb@kernel.org,
fenghua.yu@intel.com
Subject: Re: [PATCH] x86: serialize LVTT and TSC_DEADLINE write
Date: Wed, 5 Aug 2015 10:44:24 +0200 [thread overview]
Message-ID: <20150805084424.GB21506@gmail.com> (raw)
In-Reply-To: <20150803235801.GA1461084@devbig257.prn2.facebook.com>
* Shaohua Li <shli@fb.com> wrote:
> On Sun, Aug 02, 2015 at 09:41:08PM +0200, Thomas Gleixner wrote:
> > On Sun, 2 Aug 2015, Shaohua Li wrote:
> >
> > > On Sat, Aug 01, 2015 at 12:10:41PM +0200, Thomas Gleixner wrote:
> > > > On Fri, 31 Jul 2015, Shaohua Li wrote:
> > > > > @@ -336,6 +336,22 @@ static void __setup_APIC_LVTT(unsigned int clocks, int oneshot, int irqen)
> > > > > apic_write(APIC_LVTT, lvtt_value);
> > > > >
> > > > > if (lvtt_value & APIC_LVT_TIMER_TSCDEADLINE) {
> > > > > + u64 msr;
> > > > > +
> > > > > + /*
> > > > > + * See Intel SDM: TSC-Deadline Mode chapter. In xAPIC mode,
> > > > > + * writing APIC LVTT and TSC_DEADLINE MSR isn't serialized.
> > > > > + * This uses the algorithm described in Intel SDM to serialize
> > > > > + * the two writes
> > > > > + * */
> > > > > + while (1) {
> > > > > + wrmsrl(MSR_IA32_TSC_DEADLINE, -1L);
> > > > > + rdmsrl(MSR_IA32_TSC_DEADLINE, msr);
> > > > > + if (msr)
> > > > > + break;
> > > > > + }
> > > > > + wrmsrl(MSR_IA32_TSC_DEADLINE, 0);
> > > >
> > > >
> > > > I think this is exceptionally silly. A proper fence after the
> > > > apic_write() should have the same effect.
> > >
> > > Not sure what happens in the hardware, I could have a try of fence, but
> > > I'd prefer using the algorithm Intel described. This is not a fast path,
> >
> > s/algorithm/voodoo/
> >
> > > the loop will exit immediately regardless the issue occurs anyway.
> >
> > Well, the SDM also says:
> >
> > "To allow for efficient access to the APIC registers in x2APIC mode,
> > the serializing semantics of WRMSR are relaxed when writing to the
> > APIC registers. Thus, system software should not use “WRMSR to APIC
> > registers in x2APIC mode” as a serializing instruction. Read and write
> > accesses to the APIC registers will occur in program order. A WRMSR to
> > an APIC register may complete before all preceding stores are globally
> > visible; software can prevent this by inserting a serializing
> > instruction, an SFENCE, or an MFENCE before the WRMSR."
> >
> > And that's what happens here. The write to the LVT has not yet hit the
> > APIC, so the WRMSR has no effect.
>
> What you quoted is for x2APIC, I didn't see similar description for
> xAPIC.
>
> Tested mfence here, it does work. But I'm not convinced it's the right thing.
> the xAPIC access is memory mapped IO, mfence is nothing related to it. [...]
Huh?
Can you cite the SDM that says that MFENCE will have no effect on instructions
that deal with accesses that are not to system RAM (i.e. are memory mapped IO)?
Thanks,
Ingo
next prev parent reply other threads:[~2015-08-05 8:44 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-07-31 22:11 [PATCH] x86: serialize LVTT and TSC_DEADLINE write Shaohua Li
2015-08-01 10:10 ` Thomas Gleixner
2015-08-02 15:49 ` Shaohua Li
2015-08-02 19:41 ` Thomas Gleixner
2015-08-03 23:58 ` Shaohua Li
2015-08-05 8:44 ` Ingo Molnar [this message]
2015-08-05 16:25 ` Shaohua Li
2015-09-09 3:39 ` Andi Kleen
2015-09-09 4:13 ` Shaohua Li
2015-09-14 20:06 ` [tip:x86/urgent] x86/apic: Serialize LVTT and TSC_DEADLINE writes tip-bot for Shaohua Li
2015-09-09 7:35 ` [PATCH] x86: serialize LVTT and TSC_DEADLINE write Thomas Gleixner
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=20150805084424.GB21506@gmail.com \
--to=mingo@kernel.org \
--cc=Kernel-team@fb.com \
--cc=ak@linux.intel.com \
--cc=fenghua.yu@intel.com \
--cc=hpa@zytor.com \
--cc=lenb@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=shli@fb.com \
--cc=stable@vger.kernel.org \
--cc=suresh.b.siddha@intel.com \
--cc=tglx@linutronix.de \
--cc=x86@kernel.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).