diff options
38 files changed, 177 insertions, 13 deletions
diff --git a/arch/x86/kernel/cpu/mtrr/main.c b/arch/x86/kernel/cpu/mtrr/main.c index 885c8265e6b5..5df16d818371 100644 --- a/arch/x86/kernel/cpu/mtrr/main.c +++ b/arch/x86/kernel/cpu/mtrr/main.c | |||
| @@ -729,7 +729,7 @@ struct var_mtrr_range_state { | |||
| 729 | mtrr_type type; | 729 | mtrr_type type; |
| 730 | }; | 730 | }; |
| 731 | 731 | ||
| 732 | struct var_mtrr_range_state __initdata range_state[RANGE_NUM]; | 732 | static struct var_mtrr_range_state __initdata range_state[RANGE_NUM]; |
| 733 | static int __initdata debug_print; | 733 | static int __initdata debug_print; |
| 734 | 734 | ||
| 735 | static int __init | 735 | static int __init |
diff --git a/arch/x86/kernel/ioport.c b/arch/x86/kernel/ioport.c index 50e5e4a31c85..191914302744 100644 --- a/arch/x86/kernel/ioport.c +++ b/arch/x86/kernel/ioport.c | |||
| @@ -14,6 +14,7 @@ | |||
| 14 | #include <linux/slab.h> | 14 | #include <linux/slab.h> |
| 15 | #include <linux/thread_info.h> | 15 | #include <linux/thread_info.h> |
| 16 | #include <linux/syscalls.h> | 16 | #include <linux/syscalls.h> |
| 17 | #include <asm/syscalls.h> | ||
| 17 | 18 | ||
| 18 | /* Set EXTENT bits starting at BASE in BITMAP to value TURN_ON. */ | 19 | /* Set EXTENT bits starting at BASE in BITMAP to value TURN_ON. */ |
| 19 | static void set_bitmap(unsigned long *bitmap, unsigned int base, | 20 | static void set_bitmap(unsigned long *bitmap, unsigned int base, |
diff --git a/arch/x86/kernel/ipi.c b/arch/x86/kernel/ipi.c index 3f7537b669d3..f1c688e46f35 100644 --- a/arch/x86/kernel/ipi.c +++ b/arch/x86/kernel/ipi.c | |||
| @@ -20,6 +20,8 @@ | |||
| 20 | 20 | ||
| 21 | #ifdef CONFIG_X86_32 | 21 | #ifdef CONFIG_X86_32 |
| 22 | #include <mach_apic.h> | 22 | #include <mach_apic.h> |
| 23 | #include <mach_ipi.h> | ||
| 24 | |||
| 23 | /* | 25 | /* |
| 24 | * the following functions deal with sending IPIs between CPUs. | 26 | * the following functions deal with sending IPIs between CPUs. |
| 25 | * | 27 | * |
| @@ -147,7 +149,6 @@ void send_IPI_mask_sequence(cpumask_t mask, int vector) | |||
| 147 | } | 149 | } |
| 148 | 150 | ||
| 149 | /* must come after the send_IPI functions above for inlining */ | 151 | /* must come after the send_IPI functions above for inlining */ |
| 150 | #include <mach_ipi.h> | ||
| 151 | static int convert_apicid_to_cpu(int apic_id) | 152 | static int convert_apicid_to_cpu(int apic_id) |
| 152 | { | 153 | { |
| 153 | int i; | 154 | int i; |
diff --git a/arch/x86/kernel/ldt.c b/arch/x86/kernel/ldt.c index b68e21f06f4f..0ed5f939b905 100644 --- a/arch/x86/kernel/ldt.c +++ b/arch/x86/kernel/ldt.c | |||
| @@ -18,6 +18,7 @@ | |||
| 18 | #include <asm/ldt.h> | 18 | #include <asm/ldt.h> |
| 19 | #include <asm/desc.h> | 19 | #include <asm/desc.h> |
| 20 | #include <asm/mmu_context.h> | 20 | #include <asm/mmu_context.h> |
| 21 | #include <asm/syscalls.h> | ||
| 21 | 22 | ||
| 22 | #ifdef CONFIG_SMP | 23 | #ifdef CONFIG_SMP |
| 23 | static void flush_ldt(void *current_mm) | 24 | static void flush_ldt(void *current_mm) |
diff --git a/arch/x86/kernel/process_32.c b/arch/x86/kernel/process_32.c index 491eb1a7e073..c8609dea443f 100644 --- a/arch/x86/kernel/process_32.c +++ b/arch/x86/kernel/process_32.c | |||
| @@ -56,6 +56,8 @@ | |||
| 56 | #include <asm/cpu.h> | 56 | #include <asm/cpu.h> |
| 57 | #include <asm/kdebug.h> | 57 | #include <asm/kdebug.h> |
| 58 | #include <asm/idle.h> | 58 | #include <asm/idle.h> |
| 59 | #include <asm/syscalls.h> | ||
| 60 | #include <asm/smp.h> | ||
| 59 | 61 | ||
| 60 | asmlinkage void ret_from_fork(void) __asm__("ret_from_fork"); | 62 | asmlinkage void ret_from_fork(void) __asm__("ret_from_fork"); |
| 61 | 63 | ||
diff --git a/arch/x86/kernel/process_64.c b/arch/x86/kernel/process_64.c index 4e168b250aff..79e3e173ab40 100644 --- a/arch/x86/kernel/process_64.c +++ b/arch/x86/kernel/process_64.c | |||
| @@ -51,6 +51,7 @@ | |||
| 51 | #include <asm/proto.h> | 51 | #include <asm/proto.h> |
| 52 | #include <asm/ia32.h> | 52 | #include <asm/ia32.h> |
| 53 | #include <asm/idle.h> | 53 | #include <asm/idle.h> |
| 54 | #include <asm/syscalls.h> | ||
| 54 | 55 | ||
| 55 | asmlinkage extern void ret_from_fork(void); | 56 | asmlinkage extern void ret_from_fork(void); |
| 56 | 57 | ||
diff --git a/arch/x86/kernel/ptrace.c b/arch/x86/kernel/ptrace.c index 5df6093ac776..d00e756c05af 100644 --- a/arch/x86/kernel/ptrace.c +++ b/arch/x86/kernel/ptrace.c | |||
| @@ -69,7 +69,7 @@ static inline bool invalid_selector(u16 value) | |||
| 69 | 69 | ||
| 70 | #define FLAG_MASK FLAG_MASK_32 | 70 | #define FLAG_MASK FLAG_MASK_32 |
| 71 | 71 | ||
| 72 | static long *pt_regs_access(struct pt_regs *regs, unsigned long regno) | 72 | static unsigned long *pt_regs_access(struct pt_regs *regs, unsigned long regno) |
| 73 | { | 73 | { |
| 74 | BUILD_BUG_ON(offsetof(struct pt_regs, bx) != 0); | 74 | BUILD_BUG_ON(offsetof(struct pt_regs, bx) != 0); |
| 75 | regno >>= 2; | 75 | regno >>= 2; |
diff --git a/arch/x86/kernel/signal_32.c b/arch/x86/kernel/signal_32.c index 6fb5bcdd8933..0c727f64e79b 100644 --- a/arch/x86/kernel/signal_32.c +++ b/arch/x86/kernel/signal_32.c | |||
| @@ -26,6 +26,7 @@ | |||
| 26 | #include <asm/uaccess.h> | 26 | #include <asm/uaccess.h> |
| 27 | #include <asm/i387.h> | 27 | #include <asm/i387.h> |
| 28 | #include <asm/vdso.h> | 28 | #include <asm/vdso.h> |
| 29 | #include <asm/syscalls.h> | ||
| 29 | 30 | ||
| 30 | #include "sigframe.h" | 31 | #include "sigframe.h" |
| 31 | 32 | ||
diff --git a/arch/x86/kernel/signal_64.c b/arch/x86/kernel/signal_64.c index ca316b5b742c..2f1464050059 100644 --- a/arch/x86/kernel/signal_64.c +++ b/arch/x86/kernel/signal_64.c | |||
| @@ -26,6 +26,7 @@ | |||
| 26 | #include <asm/proto.h> | 26 | #include <asm/proto.h> |
| 27 | #include <asm/ia32_unistd.h> | 27 | #include <asm/ia32_unistd.h> |
| 28 | #include <asm/mce.h> | 28 | #include <asm/mce.h> |
| 29 | #include <asm/syscalls.h> | ||
| 29 | #include "sigframe.h" | 30 | #include "sigframe.h" |
| 30 | 31 | ||
| 31 | #define _BLOCKABLE (~(sigmask(SIGKILL) | sigmask(SIGSTOP))) | 32 | #define _BLOCKABLE (~(sigmask(SIGKILL) | sigmask(SIGSTOP))) |
diff --git a/arch/x86/kernel/smpboot.c b/arch/x86/kernel/smpboot.c index 7985c5b3f916..a66c93550a0d 100644 --- a/arch/x86/kernel/smpboot.c +++ b/arch/x86/kernel/smpboot.c | |||
| @@ -88,7 +88,7 @@ static DEFINE_PER_CPU(struct task_struct *, idle_thread_array); | |||
| 88 | #define get_idle_for_cpu(x) (per_cpu(idle_thread_array, x)) | 88 | #define get_idle_for_cpu(x) (per_cpu(idle_thread_array, x)) |
| 89 | #define set_idle_for_cpu(x, p) (per_cpu(idle_thread_array, x) = (p)) | 89 | #define set_idle_for_cpu(x, p) (per_cpu(idle_thread_array, x) = (p)) |
| 90 | #else | 90 | #else |
| 91 | struct task_struct *idle_thread_array[NR_CPUS] __cpuinitdata ; | 91 | static struct task_struct *idle_thread_array[NR_CPUS] __cpuinitdata ; |
| 92 | #define get_idle_for_cpu(x) (idle_thread_array[(x)]) | 92 | #define get_idle_for_cpu(x) (idle_thread_array[(x)]) |
| 93 | #define set_idle_for_cpu(x, p) (idle_thread_array[(x)] = (p)) | 93 | #define set_idle_for_cpu(x, p) (idle_thread_array[(x)] = (p)) |
| 94 | #endif | 94 | #endif |
| @@ -129,7 +129,7 @@ static int boot_cpu_logical_apicid; | |||
| 129 | static cpumask_t cpu_sibling_setup_map; | 129 | static cpumask_t cpu_sibling_setup_map; |
| 130 | 130 | ||
| 131 | /* Set if we find a B stepping CPU */ | 131 | /* Set if we find a B stepping CPU */ |
| 132 | int __cpuinitdata smp_b_stepping; | 132 | static int __cpuinitdata smp_b_stepping; |
| 133 | 133 | ||
| 134 | #if defined(CONFIG_NUMA) && defined(CONFIG_X86_32) | 134 | #if defined(CONFIG_NUMA) && defined(CONFIG_X86_32) |
| 135 | 135 | ||
diff --git a/arch/x86/kernel/sys_i386_32.c b/arch/x86/kernel/sys_i386_32.c index 7066cb855a60..1884a8d12bfa 100644 --- a/arch/x86/kernel/sys_i386_32.c +++ b/arch/x86/kernel/sys_i386_32.c | |||
| @@ -22,6 +22,8 @@ | |||
| 22 | #include <linux/uaccess.h> | 22 | #include <linux/uaccess.h> |
| 23 | #include <linux/unistd.h> | 23 | #include <linux/unistd.h> |
| 24 | 24 | ||
| 25 | #include <asm/syscalls.h> | ||
| 26 | |||
| 25 | asmlinkage long sys_mmap2(unsigned long addr, unsigned long len, | 27 | asmlinkage long sys_mmap2(unsigned long addr, unsigned long len, |
| 26 | unsigned long prot, unsigned long flags, | 28 | unsigned long prot, unsigned long flags, |
| 27 | unsigned long fd, unsigned long pgoff) | 29 | unsigned long fd, unsigned long pgoff) |
diff --git a/arch/x86/kernel/sys_x86_64.c b/arch/x86/kernel/sys_x86_64.c index 3b360ef33817..c9288c883e20 100644 --- a/arch/x86/kernel/sys_x86_64.c +++ b/arch/x86/kernel/sys_x86_64.c | |||
| @@ -16,6 +16,7 @@ | |||
| 16 | 16 | ||
| 17 | #include <asm/uaccess.h> | 17 | #include <asm/uaccess.h> |
| 18 | #include <asm/ia32.h> | 18 | #include <asm/ia32.h> |
| 19 | #include <asm/syscalls.h> | ||
| 19 | 20 | ||
| 20 | asmlinkage long sys_mmap(unsigned long addr, unsigned long len, unsigned long prot, unsigned long flags, | 21 | asmlinkage long sys_mmap(unsigned long addr, unsigned long len, unsigned long prot, unsigned long flags, |
| 21 | unsigned long fd, unsigned long off) | 22 | unsigned long fd, unsigned long off) |
diff --git a/arch/x86/kernel/time_32.c b/arch/x86/kernel/time_32.c index ffe3c664afc0..bbecf8b6bf96 100644 --- a/arch/x86/kernel/time_32.c +++ b/arch/x86/kernel/time_32.c | |||
| @@ -36,6 +36,7 @@ | |||
| 36 | #include <asm/arch_hooks.h> | 36 | #include <asm/arch_hooks.h> |
| 37 | #include <asm/hpet.h> | 37 | #include <asm/hpet.h> |
| 38 | #include <asm/time.h> | 38 | #include <asm/time.h> |
| 39 | #include <asm/timer.h> | ||
| 39 | 40 | ||
| 40 | #include "do_timer.h" | 41 | #include "do_timer.h" |
| 41 | 42 | ||
diff --git a/arch/x86/kernel/tls.c b/arch/x86/kernel/tls.c index ab6bf375a307..6bb7b8579e70 100644 --- a/arch/x86/kernel/tls.c +++ b/arch/x86/kernel/tls.c | |||
| @@ -10,6 +10,7 @@ | |||
| 10 | #include <asm/ldt.h> | 10 | #include <asm/ldt.h> |
| 11 | #include <asm/processor.h> | 11 | #include <asm/processor.h> |
| 12 | #include <asm/proto.h> | 12 | #include <asm/proto.h> |
| 13 | #include <asm/syscalls.h> | ||
| 13 | 14 | ||
| 14 | #include "tls.h" | 15 | #include "tls.h" |
| 15 | 16 | ||
diff --git a/arch/x86/kernel/vm86_32.c b/arch/x86/kernel/vm86_32.c index 38f566fa27d2..4eeb5cf9720d 100644 --- a/arch/x86/kernel/vm86_32.c +++ b/arch/x86/kernel/vm86_32.c | |||
| @@ -46,6 +46,7 @@ | |||
| 46 | #include <asm/io.h> | 46 | #include <asm/io.h> |
| 47 | #include <asm/tlbflush.h> | 47 | #include <asm/tlbflush.h> |
| 48 | #include <asm/irq.h> | 48 | #include <asm/irq.h> |
| 49 | #include <asm/syscalls.h> | ||
| 49 | 50 | ||
| 50 | /* | 51 | /* |
| 51 | * Known problems: | 52 | * Known problems: |
diff --git a/arch/x86/mach-default/setup.c b/arch/x86/mach-default/setup.c index 3d317836be9e..3f2cf11f201a 100644 --- a/arch/x86/mach-default/setup.c +++ b/arch/x86/mach-default/setup.c | |||
| @@ -10,13 +10,15 @@ | |||
| 10 | #include <asm/e820.h> | 10 | #include <asm/e820.h> |
| 11 | #include <asm/setup.h> | 11 | #include <asm/setup.h> |
| 12 | 12 | ||
| 13 | #include <mach_ipi.h> | ||
| 14 | |||
| 13 | #ifdef CONFIG_HOTPLUG_CPU | 15 | #ifdef CONFIG_HOTPLUG_CPU |
| 14 | #define DEFAULT_SEND_IPI (1) | 16 | #define DEFAULT_SEND_IPI (1) |
| 15 | #else | 17 | #else |
| 16 | #define DEFAULT_SEND_IPI (0) | 18 | #define DEFAULT_SEND_IPI (0) |
| 17 | #endif | 19 | #endif |
| 18 | 20 | ||
| 19 | int no_broadcast=DEFAULT_SEND_IPI; | 21 | int no_broadcast = DEFAULT_SEND_IPI; |
| 20 | 22 | ||
| 21 | /** | 23 | /** |
| 22 | * pre_intr_init_hook - initialisation prior to setting up interrupt vectors | 24 | * pre_intr_init_hook - initialisation prior to setting up interrupt vectors |
diff --git a/arch/x86/mm/fault.c b/arch/x86/mm/fault.c index 455f3fe67b42..8f92cac4e6db 100644 --- a/arch/x86/mm/fault.c +++ b/arch/x86/mm/fault.c | |||
| @@ -35,6 +35,7 @@ | |||
| 35 | #include <asm/tlbflush.h> | 35 | #include <asm/tlbflush.h> |
| 36 | #include <asm/proto.h> | 36 | #include <asm/proto.h> |
| 37 | #include <asm-generic/sections.h> | 37 | #include <asm-generic/sections.h> |
| 38 | #include <asm/traps.h> | ||
| 38 | 39 | ||
| 39 | /* | 40 | /* |
| 40 | * Page fault error code bits | 41 | * Page fault error code bits |
| @@ -357,8 +358,6 @@ static int is_errata100(struct pt_regs *regs, unsigned long address) | |||
| 357 | return 0; | 358 | return 0; |
| 358 | } | 359 | } |
| 359 | 360 | ||
| 360 | void do_invalid_op(struct pt_regs *, unsigned long); | ||
| 361 | |||
| 362 | static int is_f00f_bug(struct pt_regs *regs, unsigned long address) | 361 | static int is_f00f_bug(struct pt_regs *regs, unsigned long address) |
| 363 | { | 362 | { |
| 364 | #ifdef CONFIG_X86_F00F_BUG | 363 | #ifdef CONFIG_X86_F00F_BUG |
diff --git a/arch/x86/mm/init_32.c b/arch/x86/mm/init_32.c index 60ec1d08ff24..6b9a9358b330 100644 --- a/arch/x86/mm/init_32.c +++ b/arch/x86/mm/init_32.c | |||
| @@ -47,6 +47,7 @@ | |||
| 47 | #include <asm/paravirt.h> | 47 | #include <asm/paravirt.h> |
| 48 | #include <asm/setup.h> | 48 | #include <asm/setup.h> |
| 49 | #include <asm/cacheflush.h> | 49 | #include <asm/cacheflush.h> |
| 50 | #include <asm/smp.h> | ||
| 50 | 51 | ||
| 51 | unsigned int __VMALLOC_RESERVE = 128 << 20; | 52 | unsigned int __VMALLOC_RESERVE = 128 << 20; |
| 52 | 53 | ||
diff --git a/arch/x86/mm/ioremap.c b/arch/x86/mm/ioremap.c index d4b6e6a29ae3..cac6da54203b 100644 --- a/arch/x86/mm/ioremap.c +++ b/arch/x86/mm/ioremap.c | |||
| @@ -421,7 +421,7 @@ void unxlate_dev_mem_ptr(unsigned long phys, void *addr) | |||
| 421 | return; | 421 | return; |
| 422 | } | 422 | } |
| 423 | 423 | ||
| 424 | int __initdata early_ioremap_debug; | 424 | static int __initdata early_ioremap_debug; |
| 425 | 425 | ||
| 426 | static int __init early_ioremap_debug_setup(char *str) | 426 | static int __init early_ioremap_debug_setup(char *str) |
| 427 | { | 427 | { |
| @@ -547,7 +547,7 @@ static inline void __init early_clear_fixmap(enum fixed_addresses idx) | |||
| 547 | } | 547 | } |
| 548 | 548 | ||
| 549 | 549 | ||
| 550 | int __initdata early_ioremap_nested; | 550 | static int __initdata early_ioremap_nested; |
| 551 | 551 | ||
| 552 | static int __init check_early_ioremap_leak(void) | 552 | static int __init check_early_ioremap_leak(void) |
| 553 | { | 553 | { |
diff --git a/include/asm-x86/apic.h b/include/asm-x86/apic.h index d0ace3d63a2d..4a59f0d6e38c 100644 --- a/include/asm-x86/apic.h +++ b/include/asm-x86/apic.h | |||
| @@ -54,6 +54,11 @@ extern int disable_apic; | |||
| 54 | #endif | 54 | #endif |
| 55 | 55 | ||
| 56 | extern int is_vsmp_box(void); | 56 | extern int is_vsmp_box(void); |
| 57 | extern void xapic_wait_icr_idle(void); | ||
| 58 | extern u32 safe_xapic_wait_icr_idle(void); | ||
| 59 | extern u64 xapic_icr_read(void); | ||
| 60 | extern void xapic_icr_write(u32, u32); | ||
| 61 | extern int setup_profiling_timer(unsigned int); | ||
| 57 | 62 | ||
| 58 | static inline void native_apic_write(unsigned long reg, u32 v) | 63 | static inline void native_apic_write(unsigned long reg, u32 v) |
| 59 | { | 64 | { |
diff --git a/include/asm-x86/e820.h b/include/asm-x86/e820.h index 38741ac76908..f52daf176bcb 100644 --- a/include/asm-x86/e820.h +++ b/include/asm-x86/e820.h | |||
| @@ -64,6 +64,7 @@ struct e820map { | |||
| 64 | extern struct e820map e820; | 64 | extern struct e820map e820; |
| 65 | extern struct e820map e820_saved; | 65 | extern struct e820map e820_saved; |
| 66 | 66 | ||
| 67 | extern unsigned long pci_mem_start; | ||
| 67 | extern int e820_any_mapped(u64 start, u64 end, unsigned type); | 68 | extern int e820_any_mapped(u64 start, u64 end, unsigned type); |
| 68 | extern int e820_all_mapped(u64 start, u64 end, unsigned type); | 69 | extern int e820_all_mapped(u64 start, u64 end, unsigned type); |
| 69 | extern void e820_add_region(u64 start, u64 size, int type); | 70 | extern void e820_add_region(u64 start, u64 size, int type); |
diff --git a/include/asm-x86/hw_irq.h b/include/asm-x86/hw_irq.h index 2af4e36d43d0..65997b15d56a 100644 --- a/include/asm-x86/hw_irq.h +++ b/include/asm-x86/hw_irq.h | |||
| @@ -93,6 +93,26 @@ extern asmlinkage void qic_reschedule_interrupt(void); | |||
| 93 | extern asmlinkage void qic_enable_irq_interrupt(void); | 93 | extern asmlinkage void qic_enable_irq_interrupt(void); |
| 94 | extern asmlinkage void qic_call_function_interrupt(void); | 94 | extern asmlinkage void qic_call_function_interrupt(void); |
| 95 | 95 | ||
| 96 | /* SMP */ | ||
| 97 | extern void smp_apic_timer_interrupt(struct pt_regs *); | ||
| 98 | #ifdef CONFIG_X86_32 | ||
| 99 | extern void smp_spurious_interrupt(struct pt_regs *); | ||
| 100 | extern void smp_error_interrupt(struct pt_regs *); | ||
| 101 | #else | ||
| 102 | extern asmlinkage void smp_spurious_interrupt(void); | ||
| 103 | extern asmlinkage void smp_error_interrupt(void); | ||
| 104 | #endif | ||
| 105 | #ifdef CONFIG_X86_SMP | ||
| 106 | extern void smp_reschedule_interrupt(struct pt_regs *); | ||
| 107 | extern void smp_call_function_interrupt(struct pt_regs *); | ||
| 108 | extern void smp_call_function_single_interrupt(struct pt_regs *); | ||
| 109 | #ifdef CONFIG_X86_32 | ||
| 110 | extern void smp_invalidate_interrupt(struct pt_regs *); | ||
| 111 | #else | ||
| 112 | extern asmlinkage void smp_invalidate_interrupt(struct pt_regs *); | ||
| 113 | #endif | ||
| 114 | #endif | ||
| 115 | |||
| 96 | #ifdef CONFIG_X86_32 | 116 | #ifdef CONFIG_X86_32 |
| 97 | extern void (*const interrupt[NR_IRQS])(void); | 117 | extern void (*const interrupt[NR_IRQS])(void); |
| 98 | #else | 118 | #else |
diff --git a/include/asm-x86/i387.h b/include/asm-x86/i387.h index 72c3bd27e8e1..1ecdc3ed96e4 100644 --- a/include/asm-x86/i387.h +++ b/include/asm-x86/i387.h | |||
| @@ -25,6 +25,7 @@ extern void mxcsr_feature_mask_init(void); | |||
| 25 | extern int init_fpu(struct task_struct *child); | 25 | extern int init_fpu(struct task_struct *child); |
| 26 | extern asmlinkage void math_state_restore(void); | 26 | extern asmlinkage void math_state_restore(void); |
| 27 | extern void init_thread_xstate(void); | 27 | extern void init_thread_xstate(void); |
| 28 | extern int dump_fpu(struct pt_regs *, struct user_i387_struct *); | ||
| 28 | 29 | ||
| 29 | extern user_regset_active_fn fpregs_active, xfpregs_active; | 30 | extern user_regset_active_fn fpregs_active, xfpregs_active; |
| 30 | extern user_regset_get_fn fpregs_get, xfpregs_get, fpregs_soft_get; | 31 | extern user_regset_get_fn fpregs_get, xfpregs_get, fpregs_soft_get; |
diff --git a/include/asm-x86/io.h b/include/asm-x86/io.h index 688f8a4085a4..72b7719523bf 100644 --- a/include/asm-x86/io.h +++ b/include/asm-x86/io.h | |||
| @@ -73,6 +73,8 @@ build_mmio_write(__writeq, "q", unsigned long, "r", ) | |||
| 73 | #define writeq writeq | 73 | #define writeq writeq |
| 74 | #endif | 74 | #endif |
| 75 | 75 | ||
| 76 | extern int iommu_bio_merge; | ||
| 77 | |||
| 76 | #ifdef CONFIG_X86_32 | 78 | #ifdef CONFIG_X86_32 |
| 77 | # include "io_32.h" | 79 | # include "io_32.h" |
| 78 | #else | 80 | #else |
diff --git a/include/asm-x86/io_64.h b/include/asm-x86/io_64.h index f436532f1935..64429e9431a8 100644 --- a/include/asm-x86/io_64.h +++ b/include/asm-x86/io_64.h | |||
| @@ -235,7 +235,6 @@ void memset_io(volatile void __iomem *a, int b, size_t c); | |||
| 235 | 235 | ||
| 236 | #define flush_write_buffers() | 236 | #define flush_write_buffers() |
| 237 | 237 | ||
| 238 | extern int iommu_bio_merge; | ||
| 239 | #define BIO_VMERGE_BOUNDARY iommu_bio_merge | 238 | #define BIO_VMERGE_BOUNDARY iommu_bio_merge |
| 240 | 239 | ||
| 241 | /* | 240 | /* |
diff --git a/include/asm-x86/page_32.h b/include/asm-x86/page_32.h index 85ac2b8ec7c9..f32062a821c5 100644 --- a/include/asm-x86/page_32.h +++ b/include/asm-x86/page_32.h | |||
| @@ -96,6 +96,7 @@ extern void find_low_pfn_range(void); | |||
| 96 | extern unsigned long init_memory_mapping(unsigned long start, | 96 | extern unsigned long init_memory_mapping(unsigned long start, |
| 97 | unsigned long end); | 97 | unsigned long end); |
| 98 | extern void initmem_init(unsigned long, unsigned long); | 98 | extern void initmem_init(unsigned long, unsigned long); |
| 99 | extern void free_initmem(void); | ||
| 99 | extern void setup_bootmem_allocator(void); | 100 | extern void setup_bootmem_allocator(void); |
| 100 | 101 | ||
| 101 | 102 | ||
diff --git a/include/asm-x86/page_64.h b/include/asm-x86/page_64.h index 87aef3c48b5f..5e64acfed0a4 100644 --- a/include/asm-x86/page_64.h +++ b/include/asm-x86/page_64.h | |||
| @@ -91,6 +91,7 @@ extern unsigned long init_memory_mapping(unsigned long start, | |||
| 91 | unsigned long end); | 91 | unsigned long end); |
| 92 | 92 | ||
| 93 | extern void initmem_init(unsigned long start_pfn, unsigned long end_pfn); | 93 | extern void initmem_init(unsigned long start_pfn, unsigned long end_pfn); |
| 94 | extern void free_initmem(void); | ||
| 94 | 95 | ||
| 95 | extern void init_extra_mapping_uc(unsigned long phys, unsigned long size); | 96 | extern void init_extra_mapping_uc(unsigned long phys, unsigned long size); |
| 96 | extern void init_extra_mapping_wb(unsigned long phys, unsigned long size); | 97 | extern void init_extra_mapping_wb(unsigned long phys, unsigned long size); |
diff --git a/include/asm-x86/pgtable.h b/include/asm-x86/pgtable.h index 70fcb2adbb71..57d919a2d79d 100644 --- a/include/asm-x86/pgtable.h +++ b/include/asm-x86/pgtable.h | |||
| @@ -313,6 +313,8 @@ static inline void native_pagetable_setup_start(pgd_t *base) {} | |||
| 313 | static inline void native_pagetable_setup_done(pgd_t *base) {} | 313 | static inline void native_pagetable_setup_done(pgd_t *base) {} |
| 314 | #endif | 314 | #endif |
| 315 | 315 | ||
| 316 | extern int arch_report_meminfo(char *page); | ||
| 317 | |||
| 316 | #ifdef CONFIG_PARAVIRT | 318 | #ifdef CONFIG_PARAVIRT |
| 317 | #include <asm/paravirt.h> | 319 | #include <asm/paravirt.h> |
| 318 | #else /* !CONFIG_PARAVIRT */ | 320 | #else /* !CONFIG_PARAVIRT */ |
diff --git a/include/asm-x86/pgtable_32.h b/include/asm-x86/pgtable_32.h index bbc136f3ac5f..45c8235400fe 100644 --- a/include/asm-x86/pgtable_32.h +++ b/include/asm-x86/pgtable_32.h | |||
| @@ -31,6 +31,7 @@ static inline void pgtable_cache_init(void) { } | |||
| 31 | static inline void check_pgt_cache(void) { } | 31 | static inline void check_pgt_cache(void) { } |
| 32 | void paging_init(void); | 32 | void paging_init(void); |
| 33 | 33 | ||
| 34 | extern void set_pmd_pfn(unsigned long, unsigned long, pgprot_t); | ||
| 34 | 35 | ||
| 35 | /* | 36 | /* |
| 36 | * The Linux x86 paging architecture is 'compile-time dual-mode', it | 37 | * The Linux x86 paging architecture is 'compile-time dual-mode', it |
diff --git a/include/asm-x86/processor.h b/include/asm-x86/processor.h index 51297d7f99c9..5eaf9bf0a623 100644 --- a/include/asm-x86/processor.h +++ b/include/asm-x86/processor.h | |||
| @@ -141,6 +141,8 @@ DECLARE_PER_CPU(struct cpuinfo_x86, cpu_info); | |||
| 141 | #define current_cpu_data boot_cpu_data | 141 | #define current_cpu_data boot_cpu_data |
| 142 | #endif | 142 | #endif |
| 143 | 143 | ||
| 144 | extern const struct seq_operations cpuinfo_op; | ||
| 145 | |||
| 144 | static inline int hlt_works(int cpu) | 146 | static inline int hlt_works(int cpu) |
| 145 | { | 147 | { |
| 146 | #ifdef CONFIG_X86_32 | 148 | #ifdef CONFIG_X86_32 |
| @@ -154,6 +156,8 @@ static inline int hlt_works(int cpu) | |||
| 154 | 156 | ||
| 155 | extern void cpu_detect(struct cpuinfo_x86 *c); | 157 | extern void cpu_detect(struct cpuinfo_x86 *c); |
| 156 | 158 | ||
| 159 | extern struct pt_regs *idle_regs(struct pt_regs *); | ||
| 160 | |||
| 157 | extern void early_cpu_init(void); | 161 | extern void early_cpu_init(void); |
| 158 | extern void identify_boot_cpu(void); | 162 | extern void identify_boot_cpu(void); |
| 159 | extern void identify_secondary_cpu(struct cpuinfo_x86 *); | 163 | extern void identify_secondary_cpu(struct cpuinfo_x86 *); |
diff --git a/include/asm-x86/ptrace.h b/include/asm-x86/ptrace.h index 45c75238cd08..33a034be8b5c 100644 --- a/include/asm-x86/ptrace.h +++ b/include/asm-x86/ptrace.h | |||
| @@ -182,6 +182,9 @@ extern void send_sigtrap(struct task_struct *tsk, struct pt_regs *regs, | |||
| 182 | void signal_fault(struct pt_regs *regs, void __user *frame, char *where); | 182 | void signal_fault(struct pt_regs *regs, void __user *frame, char *where); |
| 183 | #endif | 183 | #endif |
| 184 | 184 | ||
| 185 | extern long syscall_trace_enter(struct pt_regs *); | ||
| 186 | extern void syscall_trace_leave(struct pt_regs *); | ||
| 187 | |||
| 185 | static inline unsigned long regs_return_value(struct pt_regs *regs) | 188 | static inline unsigned long regs_return_value(struct pt_regs *regs) |
| 186 | { | 189 | { |
| 187 | return regs->ax; | 190 | return regs->ax; |
diff --git a/include/asm-x86/setup.h b/include/asm-x86/setup.h index b7aeba94e430..9030cb73c4d7 100644 --- a/include/asm-x86/setup.h +++ b/include/asm-x86/setup.h | |||
| @@ -41,6 +41,7 @@ struct x86_quirks { | |||
| 41 | }; | 41 | }; |
| 42 | 42 | ||
| 43 | extern struct x86_quirks *x86_quirks; | 43 | extern struct x86_quirks *x86_quirks; |
| 44 | extern unsigned long saved_video_mode; | ||
| 44 | 45 | ||
| 45 | #ifndef CONFIG_PARAVIRT | 46 | #ifndef CONFIG_PARAVIRT |
| 46 | #define paravirt_post_allocator_init() do {} while (0) | 47 | #define paravirt_post_allocator_init() do {} while (0) |
diff --git a/include/asm-x86/signal.h b/include/asm-x86/signal.h index 6ee32822779a..65acc82d267a 100644 --- a/include/asm-x86/signal.h +++ b/include/asm-x86/signal.h | |||
| @@ -140,6 +140,9 @@ struct sigaction { | |||
| 140 | struct k_sigaction { | 140 | struct k_sigaction { |
| 141 | struct sigaction sa; | 141 | struct sigaction sa; |
| 142 | }; | 142 | }; |
| 143 | |||
| 144 | extern void do_notify_resume(struct pt_regs *, void *, __u32); | ||
| 145 | |||
| 143 | # else /* __KERNEL__ */ | 146 | # else /* __KERNEL__ */ |
| 144 | /* Here we must cater to libcs that poke about in kernel headers. */ | 147 | /* Here we must cater to libcs that poke about in kernel headers. */ |
| 145 | 148 | ||
diff --git a/include/asm-x86/smp.h b/include/asm-x86/smp.h index cd3c5f03fcaf..04f84f4e2c8b 100644 --- a/include/asm-x86/smp.h +++ b/include/asm-x86/smp.h | |||
| @@ -34,6 +34,9 @@ extern cpumask_t cpu_initialized; | |||
| 34 | DECLARE_PER_CPU(cpumask_t, cpu_sibling_map); | 34 | DECLARE_PER_CPU(cpumask_t, cpu_sibling_map); |
| 35 | DECLARE_PER_CPU(cpumask_t, cpu_core_map); | 35 | DECLARE_PER_CPU(cpumask_t, cpu_core_map); |
| 36 | DECLARE_PER_CPU(u16, cpu_llc_id); | 36 | DECLARE_PER_CPU(u16, cpu_llc_id); |
| 37 | #ifdef CONFIG_X86_32 | ||
| 38 | DECLARE_PER_CPU(int, cpu_number); | ||
| 39 | #endif | ||
| 37 | 40 | ||
| 38 | DECLARE_EARLY_PER_CPU(u16, x86_cpu_to_apicid); | 41 | DECLARE_EARLY_PER_CPU(u16, x86_cpu_to_apicid); |
| 39 | DECLARE_EARLY_PER_CPU(u16, x86_bios_cpu_apicid); | 42 | DECLARE_EARLY_PER_CPU(u16, x86_bios_cpu_apicid); |
| @@ -142,7 +145,6 @@ extern unsigned disabled_cpus __cpuinitdata; | |||
| 142 | * from the initial startup. We map APIC_BASE very early in page_setup(), | 145 | * from the initial startup. We map APIC_BASE very early in page_setup(), |
| 143 | * so this is correct in the x86 case. | 146 | * so this is correct in the x86 case. |
| 144 | */ | 147 | */ |
| 145 | DECLARE_PER_CPU(int, cpu_number); | ||
| 146 | #define raw_smp_processor_id() (x86_read_percpu(cpu_number)) | 148 | #define raw_smp_processor_id() (x86_read_percpu(cpu_number)) |
| 147 | extern int safe_smp_processor_id(void); | 149 | extern int safe_smp_processor_id(void); |
| 148 | 150 | ||
diff --git a/include/asm-x86/syscalls.h b/include/asm-x86/syscalls.h new file mode 100644 index 000000000000..87803da44010 --- /dev/null +++ b/include/asm-x86/syscalls.h | |||
| @@ -0,0 +1,93 @@ | |||
| 1 | /* | ||
| 2 | * syscalls.h - Linux syscall interfaces (arch-specific) | ||
| 3 | * | ||
| 4 | * Copyright (c) 2008 Jaswinder Singh | ||
| 5 | * | ||
| 6 | * This file is released under the GPLv2. | ||
| 7 | * See the file COPYING for more details. | ||
| 8 | */ | ||
| 9 | |||
| 10 | #ifndef _ASM_X86_SYSCALLS_H | ||
| 11 | #define _ASM_X86_SYSCALLS_H | ||
| 12 | |||
| 13 | #include <linux/compiler.h> | ||
| 14 | #include <linux/linkage.h> | ||
| 15 | #include <linux/types.h> | ||
| 16 | #include <linux/signal.h> | ||
| 17 | |||
| 18 | /* Common in X86_32 and X86_64 */ | ||
| 19 | /* kernel/ioport.c */ | ||
| 20 | asmlinkage long sys_ioperm(unsigned long, unsigned long, int); | ||
| 21 | |||
| 22 | /* X86_32 only */ | ||
| 23 | #ifdef CONFIG_X86_32 | ||
| 24 | /* kernel/process_32.c */ | ||
| 25 | asmlinkage int sys_fork(struct pt_regs); | ||
| 26 | asmlinkage int sys_clone(struct pt_regs); | ||
| 27 | asmlinkage int sys_vfork(struct pt_regs); | ||
| 28 | asmlinkage int sys_execve(struct pt_regs); | ||
| 29 | |||
| 30 | /* kernel/signal_32.c */ | ||
| 31 | asmlinkage int sys_sigsuspend(int, int, old_sigset_t); | ||
| 32 | asmlinkage int sys_sigaction(int, const struct old_sigaction __user *, | ||
| 33 | struct old_sigaction __user *); | ||
| 34 | asmlinkage int sys_sigaltstack(unsigned long); | ||
| 35 | asmlinkage unsigned long sys_sigreturn(unsigned long); | ||
| 36 | asmlinkage int sys_rt_sigreturn(unsigned long); | ||
| 37 | |||
| 38 | /* kernel/ioport.c */ | ||
| 39 | asmlinkage long sys_iopl(unsigned long); | ||
| 40 | |||
| 41 | /* kernel/ldt.c */ | ||
| 42 | asmlinkage int sys_modify_ldt(int, void __user *, unsigned long); | ||
| 43 | |||
| 44 | /* kernel/sys_i386_32.c */ | ||
| 45 | asmlinkage long sys_mmap2(unsigned long, unsigned long, unsigned long, | ||
| 46 | unsigned long, unsigned long, unsigned long); | ||
| 47 | struct mmap_arg_struct; | ||
| 48 | asmlinkage int old_mmap(struct mmap_arg_struct __user *); | ||
| 49 | struct sel_arg_struct; | ||
| 50 | asmlinkage int old_select(struct sel_arg_struct __user *); | ||
| 51 | asmlinkage int sys_ipc(uint, int, int, int, void __user *, long); | ||
| 52 | struct old_utsname; | ||
| 53 | asmlinkage int sys_uname(struct old_utsname __user *); | ||
| 54 | struct oldold_utsname; | ||
| 55 | asmlinkage int sys_olduname(struct oldold_utsname __user *); | ||
| 56 | |||
| 57 | /* kernel/tls.c */ | ||
| 58 | asmlinkage int sys_set_thread_area(struct user_desc __user *); | ||
| 59 | asmlinkage int sys_get_thread_area(struct user_desc __user *); | ||
| 60 | |||
| 61 | /* kernel/vm86_32.c */ | ||
| 62 | asmlinkage int sys_vm86old(struct pt_regs); | ||
| 63 | asmlinkage int sys_vm86(struct pt_regs); | ||
| 64 | |||
| 65 | #else /* CONFIG_X86_32 */ | ||
| 66 | |||
| 67 | /* X86_64 only */ | ||
| 68 | /* kernel/process_64.c */ | ||
| 69 | asmlinkage long sys_fork(struct pt_regs *); | ||
| 70 | asmlinkage long sys_clone(unsigned long, unsigned long, | ||
| 71 | void __user *, void __user *, | ||
| 72 | struct pt_regs *); | ||
| 73 | asmlinkage long sys_vfork(struct pt_regs *); | ||
| 74 | asmlinkage long sys_execve(char __user *, char __user * __user *, | ||
| 75 | char __user * __user *, | ||
| 76 | struct pt_regs *); | ||
| 77 | |||
| 78 | /* kernel/ioport.c */ | ||
| 79 | asmlinkage long sys_iopl(unsigned int, struct pt_regs *); | ||
| 80 | |||
| 81 | /* kernel/signal_64.c */ | ||
| 82 | asmlinkage long sys_sigaltstack(const stack_t __user *, stack_t __user *, | ||
| 83 | struct pt_regs *); | ||
| 84 | asmlinkage long sys_rt_sigreturn(struct pt_regs *); | ||
| 85 | |||
| 86 | /* kernel/sys_x86_64.c */ | ||
| 87 | asmlinkage long sys_mmap(unsigned long, unsigned long, unsigned long, | ||
| 88 | unsigned long, unsigned long, unsigned long); | ||
| 89 | struct new_utsname; | ||
| 90 | asmlinkage long sys_uname(struct new_utsname __user *); | ||
| 91 | |||
| 92 | #endif /* CONFIG_X86_32 */ | ||
| 93 | #endif /* _ASM_X86_SYSCALLS_H */ | ||
diff --git a/include/asm-x86/time.h b/include/asm-x86/time.h index 7457a5d7b4a1..3e724eef7ac4 100644 --- a/include/asm-x86/time.h +++ b/include/asm-x86/time.h | |||
| @@ -46,6 +46,8 @@ static inline int native_set_wallclock(unsigned long nowtime) | |||
| 46 | 46 | ||
| 47 | #endif | 47 | #endif |
| 48 | 48 | ||
| 49 | extern void time_init(void); | ||
| 50 | |||
| 49 | #ifdef CONFIG_PARAVIRT | 51 | #ifdef CONFIG_PARAVIRT |
| 50 | #include <asm/paravirt.h> | 52 | #include <asm/paravirt.h> |
| 51 | #else /* !CONFIG_PARAVIRT */ | 53 | #else /* !CONFIG_PARAVIRT */ |
diff --git a/include/asm-x86/timer.h b/include/asm-x86/timer.h index b87123dec3d9..d0babce4b47a 100644 --- a/include/asm-x86/timer.h +++ b/include/asm-x86/timer.h | |||
| @@ -9,9 +9,12 @@ | |||
| 9 | unsigned long long native_sched_clock(void); | 9 | unsigned long long native_sched_clock(void); |
| 10 | unsigned long native_calibrate_tsc(void); | 10 | unsigned long native_calibrate_tsc(void); |
| 11 | 11 | ||
| 12 | #ifdef CONFIG_X86_32 | ||
| 12 | extern int timer_ack; | 13 | extern int timer_ack; |
| 13 | extern int no_timer_check; | ||
| 14 | extern int recalibrate_cpu_khz(void); | 14 | extern int recalibrate_cpu_khz(void); |
| 15 | #endif /* CONFIG_X86_32 */ | ||
| 16 | |||
| 17 | extern int no_timer_check; | ||
| 15 | 18 | ||
| 16 | #ifndef CONFIG_PARAVIRT | 19 | #ifndef CONFIG_PARAVIRT |
| 17 | #define calibrate_tsc() native_calibrate_tsc() | 20 | #define calibrate_tsc() native_calibrate_tsc() |
diff --git a/include/asm-x86/traps.h b/include/asm-x86/traps.h index 2a891a704719..2ccebc6fb0b0 100644 --- a/include/asm-x86/traps.h +++ b/include/asm-x86/traps.h | |||
| @@ -51,6 +51,8 @@ void do_spurious_interrupt_bug(struct pt_regs *, long); | |||
| 51 | unsigned long patch_espfix_desc(unsigned long, unsigned long); | 51 | unsigned long patch_espfix_desc(unsigned long, unsigned long); |
| 52 | asmlinkage void math_emulate(long); | 52 | asmlinkage void math_emulate(long); |
| 53 | 53 | ||
| 54 | void do_page_fault(struct pt_regs *regs, unsigned long error_code); | ||
| 55 | |||
| 54 | #else /* CONFIG_X86_32 */ | 56 | #else /* CONFIG_X86_32 */ |
| 55 | 57 | ||
| 56 | asmlinkage void double_fault(void); | 58 | asmlinkage void double_fault(void); |
| @@ -62,5 +64,7 @@ asmlinkage void do_coprocessor_error(struct pt_regs *); | |||
| 62 | asmlinkage void do_simd_coprocessor_error(struct pt_regs *); | 64 | asmlinkage void do_simd_coprocessor_error(struct pt_regs *); |
| 63 | asmlinkage void do_spurious_interrupt_bug(struct pt_regs *); | 65 | asmlinkage void do_spurious_interrupt_bug(struct pt_regs *); |
| 64 | 66 | ||
| 67 | asmlinkage void do_page_fault(struct pt_regs *regs, unsigned long error_code); | ||
| 68 | |||
| 65 | #endif /* CONFIG_X86_32 */ | 69 | #endif /* CONFIG_X86_32 */ |
| 66 | #endif /* ASM_X86__TRAPS_H */ | 70 | #endif /* ASM_X86__TRAPS_H */ |
