aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJan Beulich <jbeulich@novell.com>2006-03-25 10:30:01 -0500
committerLinus Torvalds <torvalds@g5.osdl.org>2006-03-25 12:10:54 -0500
commite57113bc1ff591005ec0b0fb4885d97c01de73d8 (patch)
tree5e383dc4bdb5decf06adecca6da76fec6cbaa7d8
parent1f50249e940baa7133e0bdb32cd564bb3ba28456 (diff)
[PATCH] x86_64: miscellaneous cleanup
- adjust limits of GDT/IDT pseudo-descriptors (some were off by one) - move empty_zero_page into .bss.page_aligned - move cpu_gdt_table into .data.page_aligned - move idt_table into .bss - align inital_code and init_rsp - eliminate pointless (re-)declaration of idt_table in traps.c Signed-off-by: Jan Beulich <jbeulich@novell.com> Signed-off-by: Andi Kleen <ak@suse.de> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
-rw-r--r--arch/x86_64/kernel/head.S25
-rw-r--r--arch/x86_64/kernel/setup64.c2
-rw-r--r--arch/x86_64/kernel/traps.c2
3 files changed, 15 insertions, 14 deletions
diff --git a/arch/x86_64/kernel/head.S b/arch/x86_64/kernel/head.S
index 02fc7fa0ea28..0cddcc038422 100644
--- a/arch/x86_64/kernel/head.S
+++ b/arch/x86_64/kernel/head.S
@@ -192,7 +192,8 @@ startup_64:
192 movq initial_code(%rip),%rax 192 movq initial_code(%rip),%rax
193 jmp *%rax 193 jmp *%rax
194 194
195 /* SMP bootup changes these two */ 195 /* SMP bootup changes these two */
196 .align 8
196 .globl initial_code 197 .globl initial_code
197initial_code: 198initial_code:
198 .quad x86_64_start_kernel 199 .quad x86_64_start_kernel
@@ -237,7 +238,7 @@ ENTRY(no_long_mode)
237.org 0xf00 238.org 0xf00
238 .globl pGDT32 239 .globl pGDT32
239pGDT32: 240pGDT32:
240 .word gdt_end-cpu_gdt_table 241 .word gdt_end-cpu_gdt_table-1
241 .long cpu_gdt_table-__START_KERNEL_map 242 .long cpu_gdt_table-__START_KERNEL_map
242 243
243.org 0xf10 244.org 0xf10
@@ -293,8 +294,6 @@ NEXT_PAGE(level2_kernel_pgt)
293 /* Module mapping starts here */ 294 /* Module mapping starts here */
294 .fill 492,8,0 295 .fill 492,8,0
295 296
296NEXT_PAGE(empty_zero_page)
297
298NEXT_PAGE(level3_physmem_pgt) 297NEXT_PAGE(level3_physmem_pgt)
299 .quad phys_level2_kernel_pgt | 0x007 /* so that __va works even before pagetable_init */ 298 .quad phys_level2_kernel_pgt | 0x007 /* so that __va works even before pagetable_init */
300 .fill 511,8,0 299 .fill 511,8,0
@@ -337,7 +336,7 @@ ENTRY(boot_level4_pgt)
337 .align 16 336 .align 16
338 .globl cpu_gdt_descr 337 .globl cpu_gdt_descr
339cpu_gdt_descr: 338cpu_gdt_descr:
340 .word gdt_end-cpu_gdt_table 339 .word gdt_end-cpu_gdt_table-1
341gdt: 340gdt:
342 .quad cpu_gdt_table 341 .quad cpu_gdt_table
343#ifdef CONFIG_SMP 342#ifdef CONFIG_SMP
@@ -352,7 +351,8 @@ gdt:
352 * Also sysret mandates a special GDT layout 351 * Also sysret mandates a special GDT layout
353 */ 352 */
354 353
355.align PAGE_SIZE 354 .section .data.page_aligned, "aw"
355 .align PAGE_SIZE
356 356
357/* The TLS descriptors are currently at a different place compared to i386. 357/* The TLS descriptors are currently at a different place compared to i386.
358 Hopefully nobody expects them at a fixed place (Wine?) */ 358 Hopefully nobody expects them at a fixed place (Wine?) */
@@ -378,9 +378,12 @@ gdt_end:
378 /* zero the remaining page */ 378 /* zero the remaining page */
379 .fill PAGE_SIZE / 8 - GDT_ENTRIES,8,0 379 .fill PAGE_SIZE / 8 - GDT_ENTRIES,8,0
380 380
381ENTRY(idt_table) 381 .section .bss, "aw", @nobits
382 .rept 256 382 .align L1_CACHE_BYTES
383 .quad 0 383ENTRY(idt_table)
384 .quad 0 384 .skip 256 * 16
385 .endr
386 385
386 .section .bss.page_aligned, "aw", @nobits
387 .align PAGE_SIZE
388ENTRY(empty_zero_page)
389 .skip PAGE_SIZE
diff --git a/arch/x86_64/kernel/setup64.c b/arch/x86_64/kernel/setup64.c
index 044587812b05..356b462cb0ec 100644
--- a/arch/x86_64/kernel/setup64.c
+++ b/arch/x86_64/kernel/setup64.c
@@ -33,7 +33,7 @@ cpumask_t cpu_initialized __cpuinitdata = CPU_MASK_NONE;
33struct x8664_pda *_cpu_pda[NR_CPUS] __read_mostly; 33struct x8664_pda *_cpu_pda[NR_CPUS] __read_mostly;
34struct x8664_pda boot_cpu_pda[NR_CPUS] __cacheline_aligned; 34struct x8664_pda boot_cpu_pda[NR_CPUS] __cacheline_aligned;
35 35
36struct desc_ptr idt_descr = { 256 * 16, (unsigned long) idt_table }; 36struct desc_ptr idt_descr = { 256 * 16 - 1, (unsigned long) idt_table };
37 37
38char boot_cpu_stack[IRQSTACKSIZE] __attribute__((section(".bss.page_aligned"))); 38char boot_cpu_stack[IRQSTACKSIZE] __attribute__((section(".bss.page_aligned")));
39 39
diff --git a/arch/x86_64/kernel/traps.c b/arch/x86_64/kernel/traps.c
index 05dbbf40ccf5..7b148309c529 100644
--- a/arch/x86_64/kernel/traps.c
+++ b/arch/x86_64/kernel/traps.c
@@ -47,8 +47,6 @@
47#include <asm/proto.h> 47#include <asm/proto.h>
48#include <asm/nmi.h> 48#include <asm/nmi.h>
49 49
50extern struct gate_struct idt_table[256];
51
52asmlinkage void divide_error(void); 50asmlinkage void divide_error(void);
53asmlinkage void debug(void); 51asmlinkage void debug(void);
54asmlinkage void nmi(void); 52asmlinkage void nmi(void);