All of lore.kernel.org
 help / color / mirror / Atom feed
From: Ingo Molnar <mingo@elte.hu>
To: Jan Beulich <jbeulich@novell.com>
Cc: Jeremy Fitzhardinge <jeremy@goop.org>,
	the arch/x86 maintainers <x86@kernel.org>,
	Linus Torvalds <torvalds@linux-foundation.org>,
	Xen-devel <xen-devel@lists.xensource.com>,
	Linux Kernel Mailing List <linux-kernel@vger.kernel.org>
Subject: Re: [Xen-devel] [PATCH 2/5] xen/x86-64: clean up warnings aboutIST-using traps
Date: Fri, 8 May 2009 10:58:05 +0200	[thread overview]
Message-ID: <20090508085805.GA28455@elte.hu> (raw)
In-Reply-To: <4A03F947.76EA.0078.0@novell.com>


* Jan Beulich <jbeulich@novell.com> wrote:

> >>> Jeremy Fitzhardinge <jeremy@goop.org> 07.05.09 20:56 >>>
> >Ignore known IST-using traps.  Aside from the debugger traps, they're
> >low-level faults which Xen will handle for us, so the kernel needn't
> >worry about them.  Keep warning in case unknown trap starts using IST.
> >
> >Signed-off-by: Jeremy Fitzhardinge <jeremy.fitzhardinge@citrix.com>
> >---
> > arch/x86/xen/enlighten.c |   22 ++++++++++++++++++++--
> > 1 files changed, 20 insertions(+), 2 deletions(-)
> >
> >diff --git a/arch/x86/xen/enlighten.c b/arch/x86/xen/enlighten.c
> >index cb49f57..88f3aa4 100644
> >--- a/arch/x86/xen/enlighten.c
> >+++ b/arch/x86/xen/enlighten.c
> >@@ -439,12 +439,30 @@ static int cvt_gate_to_trap(int vector, const gate_desc *val,
> > 
> > 	addr = gate_offset(*val);
> > #ifdef CONFIG_X86_64
> >+	/*
> >+	 * Look for known traps using IST, and substitute them
> >+	 * appropriately.  The debugger ones are the only ones we care
> >+	 * about.  Xen will handle faults like double_fault and
> >+	 * machine_check, so we should never see them.  Warn if
> >+	 * there's an unexpected IST-using fault handler.
> >+	 */
> > 	if (addr == (unsigned long)debug)
> > 		addr = (unsigned long)xen_debug;
> > 	else if (addr == (unsigned long)int3)
> > 		addr = (unsigned long)xen_int3;
> >-	else
> >-		WARN_ON(val->ist != 0);
> >+	else if (addr == (unsigned long)double_fault ||
> >+		 addr == (unsigned long)stack_segment) {
> 
> I don't think you want to exclude handling stack faults: Ordinary 
> memory references using rsp or rbp as the base register will cause 
> these instead of general protection faults when the resulting 
> effective address is non- canonical.

Yes. Also, patches 1-2-3 really just do the same thing, one fixes 
the other one. Would be nice to have a single patch for that whole 
ugly topic of 64-bit Xen not handling ISTs properly.

If this was a CPU we'd say "sorry, dont run Linux on it then" ...

I've applied the reservation fix to x86/urgent, and the #5 patch to 
x86/xen (it's more of a cleanup, not a fix for .30, right?).

	Ingo

WARNING: multiple messages have this Message-ID (diff)
From: Ingo Molnar <mingo@elte.hu>
To: Jan Beulich <jbeulich@novell.com>
Cc: Jeremy Fitzhardinge <jeremy@goop.org>,
	the arch/x86 maintainers <x86@kernel.org>,
	Linus Torvalds <torvalds@linux-foundation.org>,
	Xen-devel <xen-devel@lists.xensource.com>,
	Linux Kernel Mailing List <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH 2/5] xen/x86-64: clean up warnings aboutIST-using traps
Date: Fri, 8 May 2009 10:58:05 +0200	[thread overview]
Message-ID: <20090508085805.GA28455@elte.hu> (raw)
In-Reply-To: <4A03F947.76EA.0078.0@novell.com>


* Jan Beulich <jbeulich@novell.com> wrote:

> >>> Jeremy Fitzhardinge <jeremy@goop.org> 07.05.09 20:56 >>>
> >Ignore known IST-using traps.  Aside from the debugger traps, they're
> >low-level faults which Xen will handle for us, so the kernel needn't
> >worry about them.  Keep warning in case unknown trap starts using IST.
> >
> >Signed-off-by: Jeremy Fitzhardinge <jeremy.fitzhardinge@citrix.com>
> >---
> > arch/x86/xen/enlighten.c |   22 ++++++++++++++++++++--
> > 1 files changed, 20 insertions(+), 2 deletions(-)
> >
> >diff --git a/arch/x86/xen/enlighten.c b/arch/x86/xen/enlighten.c
> >index cb49f57..88f3aa4 100644
> >--- a/arch/x86/xen/enlighten.c
> >+++ b/arch/x86/xen/enlighten.c
> >@@ -439,12 +439,30 @@ static int cvt_gate_to_trap(int vector, const gate_desc *val,
> > 
> > 	addr = gate_offset(*val);
> > #ifdef CONFIG_X86_64
> >+	/*
> >+	 * Look for known traps using IST, and substitute them
> >+	 * appropriately.  The debugger ones are the only ones we care
> >+	 * about.  Xen will handle faults like double_fault and
> >+	 * machine_check, so we should never see them.  Warn if
> >+	 * there's an unexpected IST-using fault handler.
> >+	 */
> > 	if (addr == (unsigned long)debug)
> > 		addr = (unsigned long)xen_debug;
> > 	else if (addr == (unsigned long)int3)
> > 		addr = (unsigned long)xen_int3;
> >-	else
> >-		WARN_ON(val->ist != 0);
> >+	else if (addr == (unsigned long)double_fault ||
> >+		 addr == (unsigned long)stack_segment) {
> 
> I don't think you want to exclude handling stack faults: Ordinary 
> memory references using rsp or rbp as the base register will cause 
> these instead of general protection faults when the resulting 
> effective address is non- canonical.

Yes. Also, patches 1-2-3 really just do the same thing, one fixes 
the other one. Would be nice to have a single patch for that whole 
ugly topic of 64-bit Xen not handling ISTs properly.

If this was a CPU we'd say "sorry, dont run Linux on it then" ...

I've applied the reservation fix to x86/urgent, and the #5 patch to 
x86/xen (it's more of a cleanup, not a fix for .30, right?).

	Ingo

  reply	other threads:[~2009-05-08  8:59 UTC|newest]

Thread overview: 11+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-05-07 18:56 [PATCH 2/5] xen/x86-64: clean up warnings about IST-using traps Jeremy Fitzhardinge
2009-05-08  7:20 ` [Xen-devel] [PATCH 2/5] xen/x86-64: clean up warnings aboutIST-using traps Jan Beulich
2009-05-08  7:20   ` Jan Beulich
2009-05-08  8:58   ` Ingo Molnar [this message]
2009-05-08  8:58     ` Ingo Molnar
2009-05-08 15:31     ` [Xen-devel] " Jeremy Fitzhardinge
2009-05-08 15:31       ` Jeremy Fitzhardinge
2009-05-08 15:23   ` [Xen-devel] " Jeremy Fitzhardinge
2009-05-08 15:23     ` Jeremy Fitzhardinge
2009-05-08 15:30     ` [Xen-devel] [PATCH 2/5] xen/x86-64: clean up warnings aboutIST-usingtraps Jan Beulich
2009-05-08 15:30       ` Jan Beulich

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=20090508085805.GA28455@elte.hu \
    --to=mingo@elte.hu \
    --cc=jbeulich@novell.com \
    --cc=jeremy@goop.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=torvalds@linux-foundation.org \
    --cc=x86@kernel.org \
    --cc=xen-devel@lists.xensource.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 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.