diff options
| author | Ravikiran G Thirumalai <kiran@scalex86.org> | 2006-01-11 16:43:57 -0500 |
|---|---|---|
| committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-01-11 22:04:53 -0500 |
| commit | c11efdf94d3152443c11334720824bb6c7f6c655 (patch) | |
| tree | d4185d8de8b855aca51b6bec730aeab3342e2a0f /arch/x86_64/kernel/head.S | |
| parent | bb33421dde79f9a36d5485c56335ff178ac7d268 (diff) | |
[PATCH] x86_64: Align and pad x86_64 GDT on page boundary
This patch is on the same lines as Zachary Amsden's i386 GDT page alignemnt
patch in -mm, but for x86_64.
Patch to align and pad x86_64 GDT on page boundries.
[AK: some minor cleanups and fixed incorrect TLS initialization
in CPU init.]
Signed-off-by: Nippun Goel <nippung@calsoftinc.com>
Signed-off-by: Ravikiran Thirumalai <kiran@scalex86.org>
Signed-off-by: Shai Fultheim <shai@scalex86.org>
Signed-off-by: Andi Kleen <ak@suse.de>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'arch/x86_64/kernel/head.S')
| -rw-r--r-- | arch/x86_64/kernel/head.S | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/arch/x86_64/kernel/head.S b/arch/x86_64/kernel/head.S index 15290968e49d..1d216a9fc6d8 100644 --- a/arch/x86_64/kernel/head.S +++ b/arch/x86_64/kernel/head.S | |||
| @@ -379,7 +379,7 @@ gdt: | |||
| 379 | * Also sysret mandates a special GDT layout | 379 | * Also sysret mandates a special GDT layout |
| 380 | */ | 380 | */ |
| 381 | 381 | ||
| 382 | .align L1_CACHE_BYTES | 382 | .align PAGE_SIZE |
| 383 | 383 | ||
| 384 | /* The TLS descriptors are currently at a different place compared to i386. | 384 | /* The TLS descriptors are currently at a different place compared to i386. |
| 385 | Hopefully nobody expects them at a fixed place (Wine?) */ | 385 | Hopefully nobody expects them at a fixed place (Wine?) */ |
| @@ -401,10 +401,11 @@ ENTRY(cpu_gdt_table) | |||
| 401 | gdt_end: | 401 | gdt_end: |
| 402 | /* asm/segment.h:GDT_ENTRIES must match this */ | 402 | /* asm/segment.h:GDT_ENTRIES must match this */ |
| 403 | /* This should be a multiple of the cache line size */ | 403 | /* This should be a multiple of the cache line size */ |
| 404 | /* GDTs of other CPUs: */ | 404 | /* GDTs of other CPUs are now dynamically allocated */ |
| 405 | .fill (GDT_SIZE * NR_CPUS) - (gdt_end - cpu_gdt_table) | 405 | |
| 406 | /* zero the remaining page */ | ||
| 407 | .fill PAGE_SIZE / 8 - GDT_ENTRIES,8,0 | ||
| 406 | 408 | ||
| 407 | .align L1_CACHE_BYTES | ||
| 408 | ENTRY(idt_table) | 409 | ENTRY(idt_table) |
| 409 | .rept 256 | 410 | .rept 256 |
| 410 | .quad 0 | 411 | .quad 0 |
