public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH] shorten the x86_64 boot setup GDT to what the comment says
@ 2006-11-09  3:01 Steven Rostedt
  2006-11-09 13:13 ` Andi Kleen
  2006-11-09 14:54 ` Alexander van Heukelum
  0 siblings, 2 replies; 16+ messages in thread
From: Steven Rostedt @ 2006-11-09  3:01 UTC (permalink / raw)
  To: LKML; +Cc: sct, ak, herbert, xen-devel


Andi,

Stephen Tweedie, Herbert Xu, and myself have been struggling with a very
nasty bug in Xen.  But it also pointed out a small bug in the x86_64
kernel boot setup.

The GDT limit being setup by the initial bzImage code when entering into
protected mode is way too big.  The comment by the code states that the
size of the GDT is 2048, but the actual size being set up is much bigger
(32768). This happens simply because of one extra '0'.

Instead of setting up a 0x800 size, 0x8000 is set up.  On bare metal this
is fine because the CPU wont load any segments unless  they are
explicitly used.  But unfortunately, this breaks Xen on vmx FV, since it
(for now) blindly loads all the segments into the VMCS if they are less
than the gdt limit. Since the real mode segments are around 0x3000, we are
getting junk into the VMCS and that later causes an exception.

Stephen Tweedie has written up a patch to fix the Xen side and will be
submitting that to those folks. But that doesn't excuse the GDT limit
being a magnitude too big.

Signed-off-by: Steven Rostedt <rostedt@goodmis.org>

Index: linux-2.6.19-rc2/arch/x86_64/boot/setup.S
===================================================================
--- linux-2.6.19-rc2.orig/arch/x86_64/boot/setup.S	2006-11-08 21:37:58.000000000 -0500
+++ linux-2.6.19-rc2/arch/x86_64/boot/setup.S	2006-11-08 21:38:16.000000000 -0500
@@ -840,7 +840,7 @@ idt_48:
 	.word	0				# idt limit = 0
 	.word	0, 0				# idt base = 0L
 gdt_48:
-	.word	0x8000				# gdt limit=2048,
+	.word	0x800				# gdt limit=2048,
 						#  256 GDT entries

 	.word	0, 0				# gdt base (filled in later)

^ permalink raw reply	[flat|nested] 16+ messages in thread

end of thread, other threads:[~2006-11-13 16:48 UTC | newest]

Thread overview: 16+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2006-11-09  3:01 [PATCH] shorten the x86_64 boot setup GDT to what the comment says Steven Rostedt
2006-11-09 13:13 ` Andi Kleen
2006-11-09 15:31   ` [Xen-devel] " Jan Beulich
2006-11-09 13:31     ` Andi Kleen
2006-11-09 14:54 ` Alexander van Heukelum
2006-11-09 15:18   ` Steven Rostedt
2006-11-09 15:44     ` Alexander van Heukelum
2006-11-09 13:33       ` Andi Kleen
2006-11-09 18:31         ` Alexander van Heukelum
2006-11-10 14:01           ` Andi Kleen
2006-11-10 15:46             ` Alexander van Heukelum
2006-11-12 13:47               ` Alexander van Heukelum
2006-11-11  5:17             ` [PATCH] make x86_64 boot gdt size exact (like x86) Steven Rostedt
2006-11-11  6:42               ` Andi Kleen
2006-11-13 15:37                 ` Steven Rostedt
2006-11-13 16:47                   ` Andi Kleen

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox