diff options
Diffstat (limited to 'arch/i386')
36 files changed, 27 insertions, 121 deletions
diff --git a/arch/i386/Kconfig b/arch/i386/Kconfig index b22f003eaa6d..d2703cda61ea 100644 --- a/arch/i386/Kconfig +++ b/arch/i386/Kconfig | |||
| @@ -908,11 +908,6 @@ config IRQBALANCE | |||
| 908 | The default yes will allow the kernel to do irq load balancing. | 908 | The default yes will allow the kernel to do irq load balancing. |
| 909 | Saying no will keep the kernel from doing irq load balancing. | 909 | Saying no will keep the kernel from doing irq load balancing. |
| 910 | 910 | ||
| 911 | config HAVE_DEC_LOCK | ||
| 912 | bool | ||
| 913 | depends on (SMP || PREEMPT) && X86_CMPXCHG | ||
| 914 | default y | ||
| 915 | |||
| 916 | # turning this on wastes a bunch of space. | 911 | # turning this on wastes a bunch of space. |
| 917 | # Summit needs it only when NUMA is on | 912 | # Summit needs it only when NUMA is on |
| 918 | config BOOT_IOREMAP | 913 | config BOOT_IOREMAP |
diff --git a/arch/i386/kernel/acpi/boot.c b/arch/i386/kernel/acpi/boot.c index a63351c085c6..b66c13c0cc0f 100644 --- a/arch/i386/kernel/acpi/boot.c +++ b/arch/i386/kernel/acpi/boot.c | |||
| @@ -27,15 +27,14 @@ | |||
| 27 | #include <linux/config.h> | 27 | #include <linux/config.h> |
| 28 | #include <linux/acpi.h> | 28 | #include <linux/acpi.h> |
| 29 | #include <linux/efi.h> | 29 | #include <linux/efi.h> |
| 30 | #include <linux/irq.h> | ||
| 31 | #include <linux/module.h> | 30 | #include <linux/module.h> |
| 32 | #include <linux/dmi.h> | 31 | #include <linux/dmi.h> |
| 32 | #include <linux/irq.h> | ||
| 33 | 33 | ||
| 34 | #include <asm/pgtable.h> | 34 | #include <asm/pgtable.h> |
| 35 | #include <asm/io_apic.h> | 35 | #include <asm/io_apic.h> |
| 36 | #include <asm/apic.h> | 36 | #include <asm/apic.h> |
| 37 | #include <asm/io.h> | 37 | #include <asm/io.h> |
| 38 | #include <asm/irq.h> | ||
| 39 | #include <asm/mpspec.h> | 38 | #include <asm/mpspec.h> |
| 40 | 39 | ||
| 41 | #ifdef CONFIG_X86_64 | 40 | #ifdef CONFIG_X86_64 |
diff --git a/arch/i386/kernel/acpi/earlyquirk.c b/arch/i386/kernel/acpi/earlyquirk.c index 1ae2aeeda18b..f1b9d2a46dab 100644 --- a/arch/i386/kernel/acpi/earlyquirk.c +++ b/arch/i386/kernel/acpi/earlyquirk.c | |||
| @@ -7,7 +7,6 @@ | |||
| 7 | #include <linux/pci.h> | 7 | #include <linux/pci.h> |
| 8 | #include <asm/pci-direct.h> | 8 | #include <asm/pci-direct.h> |
| 9 | #include <asm/acpi.h> | 9 | #include <asm/acpi.h> |
| 10 | #include <asm/apic.h> | ||
| 11 | 10 | ||
| 12 | static int __init check_bridge(int vendor, int device) | 11 | static int __init check_bridge(int vendor, int device) |
| 13 | { | 12 | { |
| @@ -16,15 +15,6 @@ static int __init check_bridge(int vendor, int device) | |||
| 16 | if (vendor == PCI_VENDOR_ID_NVIDIA) { | 15 | if (vendor == PCI_VENDOR_ID_NVIDIA) { |
| 17 | acpi_skip_timer_override = 1; | 16 | acpi_skip_timer_override = 1; |
| 18 | } | 17 | } |
| 19 | #ifdef CONFIG_X86_LOCAL_APIC | ||
| 20 | /* | ||
| 21 | * ATI IXP chipsets get double timer interrupts. | ||
| 22 | * For now just do this for all ATI chipsets. | ||
| 23 | * FIXME: this needs to be checked for the non ACPI case too. | ||
| 24 | */ | ||
| 25 | if (vendor == PCI_VENDOR_ID_ATI) | ||
| 26 | disable_timer_pin_1 = 1; | ||
| 27 | #endif | ||
| 28 | return 0; | 18 | return 0; |
| 29 | } | 19 | } |
| 30 | 20 | ||
diff --git a/arch/i386/kernel/apic.c b/arch/i386/kernel/apic.c index a22a866de8f9..5546ddebec33 100644 --- a/arch/i386/kernel/apic.c +++ b/arch/i386/kernel/apic.c | |||
| @@ -18,7 +18,6 @@ | |||
| 18 | #include <linux/init.h> | 18 | #include <linux/init.h> |
| 19 | 19 | ||
| 20 | #include <linux/mm.h> | 20 | #include <linux/mm.h> |
| 21 | #include <linux/irq.h> | ||
| 22 | #include <linux/delay.h> | 21 | #include <linux/delay.h> |
| 23 | #include <linux/bootmem.h> | 22 | #include <linux/bootmem.h> |
| 24 | #include <linux/smp_lock.h> | 23 | #include <linux/smp_lock.h> |
diff --git a/arch/i386/kernel/cpu/amd.c b/arch/i386/kernel/cpu/amd.c index 73aeaf5a9d4e..4c1ddf2b57cc 100644 --- a/arch/i386/kernel/cpu/amd.c +++ b/arch/i386/kernel/cpu/amd.c | |||
| @@ -28,6 +28,22 @@ static void __init init_amd(struct cpuinfo_x86 *c) | |||
| 28 | int mbytes = num_physpages >> (20-PAGE_SHIFT); | 28 | int mbytes = num_physpages >> (20-PAGE_SHIFT); |
| 29 | int r; | 29 | int r; |
| 30 | 30 | ||
| 31 | #ifdef CONFIG_SMP | ||
| 32 | unsigned long value; | ||
| 33 | |||
| 34 | /* Disable TLB flush filter by setting HWCR.FFDIS on K8 | ||
| 35 | * bit 6 of msr C001_0015 | ||
| 36 | * | ||
| 37 | * Errata 63 for SH-B3 steppings | ||
| 38 | * Errata 122 for all steppings (F+ have it disabled by default) | ||
| 39 | */ | ||
| 40 | if (c->x86 == 15) { | ||
| 41 | rdmsrl(MSR_K7_HWCR, value); | ||
| 42 | value |= 1 << 6; | ||
| 43 | wrmsrl(MSR_K7_HWCR, value); | ||
| 44 | } | ||
| 45 | #endif | ||
| 46 | |||
| 31 | /* | 47 | /* |
| 32 | * FIXME: We should handle the K5 here. Set up the write | 48 | * FIXME: We should handle the K5 here. Set up the write |
| 33 | * range and also turn on MSR 83 bits 4 and 31 (write alloc, | 49 | * range and also turn on MSR 83 bits 4 and 31 (write alloc, |
diff --git a/arch/i386/kernel/cpu/mcheck/k7.c b/arch/i386/kernel/cpu/mcheck/k7.c index c4abe7657397..7c6b9c73522f 100644 --- a/arch/i386/kernel/cpu/mcheck/k7.c +++ b/arch/i386/kernel/cpu/mcheck/k7.c | |||
| @@ -7,7 +7,6 @@ | |||
| 7 | #include <linux/types.h> | 7 | #include <linux/types.h> |
| 8 | #include <linux/kernel.h> | 8 | #include <linux/kernel.h> |
| 9 | #include <linux/config.h> | 9 | #include <linux/config.h> |
| 10 | #include <linux/irq.h> | ||
| 11 | #include <linux/interrupt.h> | 10 | #include <linux/interrupt.h> |
| 12 | #include <linux/smp.h> | 11 | #include <linux/smp.h> |
| 13 | 12 | ||
diff --git a/arch/i386/kernel/cpu/mcheck/non-fatal.c b/arch/i386/kernel/cpu/mcheck/non-fatal.c index 7864ddfccf07..82dffe0d4954 100644 --- a/arch/i386/kernel/cpu/mcheck/non-fatal.c +++ b/arch/i386/kernel/cpu/mcheck/non-fatal.c | |||
| @@ -12,7 +12,6 @@ | |||
| 12 | #include <linux/kernel.h> | 12 | #include <linux/kernel.h> |
| 13 | #include <linux/jiffies.h> | 13 | #include <linux/jiffies.h> |
| 14 | #include <linux/config.h> | 14 | #include <linux/config.h> |
| 15 | #include <linux/irq.h> | ||
| 16 | #include <linux/workqueue.h> | 15 | #include <linux/workqueue.h> |
| 17 | #include <linux/interrupt.h> | 16 | #include <linux/interrupt.h> |
| 18 | #include <linux/smp.h> | 17 | #include <linux/smp.h> |
diff --git a/arch/i386/kernel/cpu/mcheck/p4.c b/arch/i386/kernel/cpu/mcheck/p4.c index 0abccb6fdf9e..1d1e885f500a 100644 --- a/arch/i386/kernel/cpu/mcheck/p4.c +++ b/arch/i386/kernel/cpu/mcheck/p4.c | |||
| @@ -6,7 +6,6 @@ | |||
| 6 | #include <linux/types.h> | 6 | #include <linux/types.h> |
| 7 | #include <linux/kernel.h> | 7 | #include <linux/kernel.h> |
| 8 | #include <linux/config.h> | 8 | #include <linux/config.h> |
| 9 | #include <linux/irq.h> | ||
| 10 | #include <linux/interrupt.h> | 9 | #include <linux/interrupt.h> |
| 11 | #include <linux/smp.h> | 10 | #include <linux/smp.h> |
| 12 | 11 | ||
diff --git a/arch/i386/kernel/cpu/mcheck/p5.c b/arch/i386/kernel/cpu/mcheck/p5.c index ec0614cd2925..3a2e24baddc7 100644 --- a/arch/i386/kernel/cpu/mcheck/p5.c +++ b/arch/i386/kernel/cpu/mcheck/p5.c | |||
| @@ -6,7 +6,6 @@ | |||
| 6 | #include <linux/init.h> | 6 | #include <linux/init.h> |
| 7 | #include <linux/types.h> | 7 | #include <linux/types.h> |
| 8 | #include <linux/kernel.h> | 8 | #include <linux/kernel.h> |
| 9 | #include <linux/irq.h> | ||
| 10 | #include <linux/interrupt.h> | 9 | #include <linux/interrupt.h> |
| 11 | #include <linux/smp.h> | 10 | #include <linux/smp.h> |
| 12 | 11 | ||
diff --git a/arch/i386/kernel/cpu/mcheck/p6.c b/arch/i386/kernel/cpu/mcheck/p6.c index f01b73f947e1..3c035b8fa3d9 100644 --- a/arch/i386/kernel/cpu/mcheck/p6.c +++ b/arch/i386/kernel/cpu/mcheck/p6.c | |||
| @@ -6,7 +6,6 @@ | |||
| 6 | #include <linux/init.h> | 6 | #include <linux/init.h> |
| 7 | #include <linux/types.h> | 7 | #include <linux/types.h> |
| 8 | #include <linux/kernel.h> | 8 | #include <linux/kernel.h> |
| 9 | #include <linux/irq.h> | ||
| 10 | #include <linux/interrupt.h> | 9 | #include <linux/interrupt.h> |
| 11 | #include <linux/smp.h> | 10 | #include <linux/smp.h> |
| 12 | 11 | ||
diff --git a/arch/i386/kernel/cpu/mcheck/winchip.c b/arch/i386/kernel/cpu/mcheck/winchip.c index 7bae68fa168f..5b9d2dd411d3 100644 --- a/arch/i386/kernel/cpu/mcheck/winchip.c +++ b/arch/i386/kernel/cpu/mcheck/winchip.c | |||
| @@ -6,7 +6,6 @@ | |||
| 6 | #include <linux/init.h> | 6 | #include <linux/init.h> |
| 7 | #include <linux/types.h> | 7 | #include <linux/types.h> |
| 8 | #include <linux/kernel.h> | 8 | #include <linux/kernel.h> |
| 9 | #include <linux/irq.h> | ||
| 10 | #include <linux/interrupt.h> | 9 | #include <linux/interrupt.h> |
| 11 | 10 | ||
| 12 | #include <asm/processor.h> | 11 | #include <asm/processor.h> |
diff --git a/arch/i386/kernel/crash.c b/arch/i386/kernel/crash.c index 913be77bb844..0248e084017c 100644 --- a/arch/i386/kernel/crash.c +++ b/arch/i386/kernel/crash.c | |||
| @@ -11,10 +11,8 @@ | |||
| 11 | #include <linux/types.h> | 11 | #include <linux/types.h> |
| 12 | #include <linux/kernel.h> | 12 | #include <linux/kernel.h> |
| 13 | #include <linux/smp.h> | 13 | #include <linux/smp.h> |
| 14 | #include <linux/irq.h> | ||
| 15 | #include <linux/reboot.h> | 14 | #include <linux/reboot.h> |
| 16 | #include <linux/kexec.h> | 15 | #include <linux/kexec.h> |
| 17 | #include <linux/irq.h> | ||
| 18 | #include <linux/delay.h> | 16 | #include <linux/delay.h> |
| 19 | #include <linux/elf.h> | 17 | #include <linux/elf.h> |
| 20 | #include <linux/elfcore.h> | 18 | #include <linux/elfcore.h> |
diff --git a/arch/i386/kernel/i8259.c b/arch/i386/kernel/i8259.c index 178f4e9bac9d..323ef8ab3244 100644 --- a/arch/i386/kernel/i8259.c +++ b/arch/i386/kernel/i8259.c | |||
| @@ -16,7 +16,6 @@ | |||
| 16 | #include <asm/atomic.h> | 16 | #include <asm/atomic.h> |
| 17 | #include <asm/system.h> | 17 | #include <asm/system.h> |
| 18 | #include <asm/io.h> | 18 | #include <asm/io.h> |
| 19 | #include <asm/irq.h> | ||
| 20 | #include <asm/timer.h> | 19 | #include <asm/timer.h> |
| 21 | #include <asm/pgtable.h> | 20 | #include <asm/pgtable.h> |
| 22 | #include <asm/delay.h> | 21 | #include <asm/delay.h> |
| @@ -25,8 +24,6 @@ | |||
| 25 | #include <asm/arch_hooks.h> | 24 | #include <asm/arch_hooks.h> |
| 26 | #include <asm/i8259.h> | 25 | #include <asm/i8259.h> |
| 27 | 26 | ||
| 28 | #include <linux/irq.h> | ||
| 29 | |||
| 30 | #include <io_ports.h> | 27 | #include <io_ports.h> |
| 31 | 28 | ||
| 32 | /* | 29 | /* |
diff --git a/arch/i386/kernel/io_apic.c b/arch/i386/kernel/io_apic.c index 378313b0cce9..fb3991e8229e 100644 --- a/arch/i386/kernel/io_apic.c +++ b/arch/i386/kernel/io_apic.c | |||
| @@ -21,7 +21,6 @@ | |||
| 21 | */ | 21 | */ |
| 22 | 22 | ||
| 23 | #include <linux/mm.h> | 23 | #include <linux/mm.h> |
| 24 | #include <linux/irq.h> | ||
| 25 | #include <linux/interrupt.h> | 24 | #include <linux/interrupt.h> |
| 26 | #include <linux/init.h> | 25 | #include <linux/init.h> |
| 27 | #include <linux/delay.h> | 26 | #include <linux/delay.h> |
diff --git a/arch/i386/kernel/mpparse.c b/arch/i386/kernel/mpparse.c index 15949fd08109..27aabfceb67e 100644 --- a/arch/i386/kernel/mpparse.c +++ b/arch/i386/kernel/mpparse.c | |||
| @@ -14,7 +14,6 @@ | |||
| 14 | */ | 14 | */ |
| 15 | 15 | ||
| 16 | #include <linux/mm.h> | 16 | #include <linux/mm.h> |
| 17 | #include <linux/irq.h> | ||
| 18 | #include <linux/init.h> | 17 | #include <linux/init.h> |
| 19 | #include <linux/acpi.h> | 18 | #include <linux/acpi.h> |
| 20 | #include <linux/delay.h> | 19 | #include <linux/delay.h> |
diff --git a/arch/i386/kernel/nmi.c b/arch/i386/kernel/nmi.c index 0178457db721..72515b8a1b12 100644 --- a/arch/i386/kernel/nmi.c +++ b/arch/i386/kernel/nmi.c | |||
| @@ -15,7 +15,6 @@ | |||
| 15 | 15 | ||
| 16 | #include <linux/config.h> | 16 | #include <linux/config.h> |
| 17 | #include <linux/mm.h> | 17 | #include <linux/mm.h> |
| 18 | #include <linux/irq.h> | ||
| 19 | #include <linux/delay.h> | 18 | #include <linux/delay.h> |
| 20 | #include <linux/bootmem.h> | 19 | #include <linux/bootmem.h> |
| 21 | #include <linux/smp_lock.h> | 20 | #include <linux/smp_lock.h> |
diff --git a/arch/i386/kernel/process.c b/arch/i386/kernel/process.c index b45cbf93d439..7a14fdfd3af9 100644 --- a/arch/i386/kernel/process.c +++ b/arch/i386/kernel/process.c | |||
| @@ -47,13 +47,11 @@ | |||
| 47 | #include <asm/ldt.h> | 47 | #include <asm/ldt.h> |
| 48 | #include <asm/processor.h> | 48 | #include <asm/processor.h> |
| 49 | #include <asm/i387.h> | 49 | #include <asm/i387.h> |
| 50 | #include <asm/irq.h> | ||
| 51 | #include <asm/desc.h> | 50 | #include <asm/desc.h> |
| 52 | #ifdef CONFIG_MATH_EMULATION | 51 | #ifdef CONFIG_MATH_EMULATION |
| 53 | #include <asm/math_emu.h> | 52 | #include <asm/math_emu.h> |
| 54 | #endif | 53 | #endif |
| 55 | 54 | ||
| 56 | #include <linux/irq.h> | ||
| 57 | #include <linux/err.h> | 55 | #include <linux/err.h> |
| 58 | 56 | ||
| 59 | #include <asm/tlbflush.h> | 57 | #include <asm/tlbflush.h> |
diff --git a/arch/i386/kernel/reboot.c b/arch/i386/kernel/reboot.c index 1cbb9c0f4704..350ea6680f63 100644 --- a/arch/i386/kernel/reboot.c +++ b/arch/i386/kernel/reboot.c | |||
| @@ -11,6 +11,7 @@ | |||
| 11 | #include <linux/mc146818rtc.h> | 11 | #include <linux/mc146818rtc.h> |
| 12 | #include <linux/efi.h> | 12 | #include <linux/efi.h> |
| 13 | #include <linux/dmi.h> | 13 | #include <linux/dmi.h> |
| 14 | #include <linux/ctype.h> | ||
| 14 | #include <asm/uaccess.h> | 15 | #include <asm/uaccess.h> |
| 15 | #include <asm/apic.h> | 16 | #include <asm/apic.h> |
| 16 | #include <asm/desc.h> | 17 | #include <asm/desc.h> |
| @@ -28,8 +29,6 @@ static int reboot_thru_bios; | |||
| 28 | 29 | ||
| 29 | #ifdef CONFIG_SMP | 30 | #ifdef CONFIG_SMP |
| 30 | static int reboot_cpu = -1; | 31 | static int reboot_cpu = -1; |
| 31 | /* shamelessly grabbed from lib/vsprintf.c for readability */ | ||
| 32 | #define is_digit(c) ((c) >= '0' && (c) <= '9') | ||
| 33 | #endif | 32 | #endif |
| 34 | static int __init reboot_setup(char *str) | 33 | static int __init reboot_setup(char *str) |
| 35 | { | 34 | { |
| @@ -49,9 +48,9 @@ static int __init reboot_setup(char *str) | |||
| 49 | break; | 48 | break; |
| 50 | #ifdef CONFIG_SMP | 49 | #ifdef CONFIG_SMP |
| 51 | case 's': /* "smp" reboot by executing reset on BSP or other CPU*/ | 50 | case 's': /* "smp" reboot by executing reset on BSP or other CPU*/ |
| 52 | if (is_digit(*(str+1))) { | 51 | if (isdigit(*(str+1))) { |
| 53 | reboot_cpu = (int) (*(str+1) - '0'); | 52 | reboot_cpu = (int) (*(str+1) - '0'); |
| 54 | if (is_digit(*(str+2))) | 53 | if (isdigit(*(str+2))) |
| 55 | reboot_cpu = reboot_cpu*10 + (int)(*(str+2) - '0'); | 54 | reboot_cpu = reboot_cpu*10 + (int)(*(str+2) - '0'); |
| 56 | } | 55 | } |
| 57 | /* we will leave sorting out the final value | 56 | /* we will leave sorting out the final value |
diff --git a/arch/i386/kernel/setup.c b/arch/i386/kernel/setup.c index dc39ca6a7eca..9b8c8a19824d 100644 --- a/arch/i386/kernel/setup.c +++ b/arch/i386/kernel/setup.c | |||
| @@ -848,9 +848,7 @@ static void __init parse_cmdline_early (char ** cmdline_p) | |||
| 848 | #ifdef CONFIG_X86_IO_APIC | 848 | #ifdef CONFIG_X86_IO_APIC |
| 849 | else if (!memcmp(from, "acpi_skip_timer_override", 24)) | 849 | else if (!memcmp(from, "acpi_skip_timer_override", 24)) |
| 850 | acpi_skip_timer_override = 1; | 850 | acpi_skip_timer_override = 1; |
| 851 | #endif | ||
| 852 | 851 | ||
| 853 | #ifdef CONFIG_X86_LOCAL_APIC | ||
| 854 | if (!memcmp(from, "disable_timer_pin_1", 19)) | 852 | if (!memcmp(from, "disable_timer_pin_1", 19)) |
| 855 | disable_timer_pin_1 = 1; | 853 | disable_timer_pin_1 = 1; |
| 856 | if (!memcmp(from, "enable_timer_pin_1", 18)) | 854 | if (!memcmp(from, "enable_timer_pin_1", 18)) |
| @@ -859,7 +857,7 @@ static void __init parse_cmdline_early (char ** cmdline_p) | |||
| 859 | /* disable IO-APIC */ | 857 | /* disable IO-APIC */ |
| 860 | else if (!memcmp(from, "noapic", 6)) | 858 | else if (!memcmp(from, "noapic", 6)) |
| 861 | disable_ioapic_setup(); | 859 | disable_ioapic_setup(); |
| 862 | #endif /* CONFIG_X86_LOCAL_APIC */ | 860 | #endif /* CONFIG_X86_IO_APIC */ |
| 863 | #endif /* CONFIG_ACPI */ | 861 | #endif /* CONFIG_ACPI */ |
| 864 | 862 | ||
| 865 | #ifdef CONFIG_X86_LOCAL_APIC | 863 | #ifdef CONFIG_X86_LOCAL_APIC |
diff --git a/arch/i386/kernel/smp.c b/arch/i386/kernel/smp.c index 48b55db3680f..218d725a5a1e 100644 --- a/arch/i386/kernel/smp.c +++ b/arch/i386/kernel/smp.c | |||
| @@ -11,7 +11,6 @@ | |||
| 11 | #include <linux/init.h> | 11 | #include <linux/init.h> |
| 12 | 12 | ||
| 13 | #include <linux/mm.h> | 13 | #include <linux/mm.h> |
| 14 | #include <linux/irq.h> | ||
| 15 | #include <linux/delay.h> | 14 | #include <linux/delay.h> |
| 16 | #include <linux/spinlock.h> | 15 | #include <linux/spinlock.h> |
| 17 | #include <linux/smp_lock.h> | 16 | #include <linux/smp_lock.h> |
diff --git a/arch/i386/kernel/smpboot.c b/arch/i386/kernel/smpboot.c index c70cd2a08304..1fb26d0e30b6 100644 --- a/arch/i386/kernel/smpboot.c +++ b/arch/i386/kernel/smpboot.c | |||
| @@ -42,7 +42,6 @@ | |||
| 42 | #include <linux/sched.h> | 42 | #include <linux/sched.h> |
| 43 | #include <linux/kernel_stat.h> | 43 | #include <linux/kernel_stat.h> |
| 44 | #include <linux/smp_lock.h> | 44 | #include <linux/smp_lock.h> |
| 45 | #include <linux/irq.h> | ||
| 46 | #include <linux/bootmem.h> | 45 | #include <linux/bootmem.h> |
| 47 | #include <linux/notifier.h> | 46 | #include <linux/notifier.h> |
| 48 | #include <linux/cpu.h> | 47 | #include <linux/cpu.h> |
| @@ -202,7 +201,7 @@ static void __devinit smp_store_cpu_info(int id) | |||
| 202 | goto valid_k7; | 201 | goto valid_k7; |
| 203 | 202 | ||
| 204 | /* If we get here, it's not a certified SMP capable AMD system. */ | 203 | /* If we get here, it's not a certified SMP capable AMD system. */ |
| 205 | tainted |= TAINT_UNSAFE_SMP; | 204 | add_taint(TAINT_UNSAFE_SMP); |
| 206 | } | 205 | } |
| 207 | 206 | ||
| 208 | valid_k7: | 207 | valid_k7: |
diff --git a/arch/i386/kernel/timers/timer_pit.c b/arch/i386/kernel/timers/timer_pit.c index eddb64038234..e42e46d35159 100644 --- a/arch/i386/kernel/timers/timer_pit.c +++ b/arch/i386/kernel/timers/timer_pit.c | |||
| @@ -6,7 +6,6 @@ | |||
| 6 | #include <linux/spinlock.h> | 6 | #include <linux/spinlock.h> |
| 7 | #include <linux/module.h> | 7 | #include <linux/module.h> |
| 8 | #include <linux/device.h> | 8 | #include <linux/device.h> |
| 9 | #include <linux/irq.h> | ||
| 10 | #include <linux/sysdev.h> | 9 | #include <linux/sysdev.h> |
| 11 | #include <linux/timex.h> | 10 | #include <linux/timex.h> |
| 12 | #include <asm/delay.h> | 11 | #include <asm/delay.h> |
diff --git a/arch/i386/kernel/traps.c b/arch/i386/kernel/traps.c index 09a58cb6daa7..19e90bdd84ea 100644 --- a/arch/i386/kernel/traps.c +++ b/arch/i386/kernel/traps.c | |||
| @@ -52,7 +52,6 @@ | |||
| 52 | #include <asm/arch_hooks.h> | 52 | #include <asm/arch_hooks.h> |
| 53 | #include <asm/kdebug.h> | 53 | #include <asm/kdebug.h> |
| 54 | 54 | ||
| 55 | #include <linux/irq.h> | ||
| 56 | #include <linux/module.h> | 55 | #include <linux/module.h> |
| 57 | 56 | ||
| 58 | #include "mach_traps.h" | 57 | #include "mach_traps.h" |
| @@ -807,8 +806,9 @@ void math_error(void __user *eip) | |||
| 807 | cwd = get_fpu_cwd(task); | 806 | cwd = get_fpu_cwd(task); |
| 808 | swd = get_fpu_swd(task); | 807 | swd = get_fpu_swd(task); |
| 809 | switch (swd & ~cwd & 0x3f) { | 808 | switch (swd & ~cwd & 0x3f) { |
| 810 | case 0x000: | 809 | case 0x000: /* No unmasked exception */ |
| 811 | default: | 810 | return; |
| 811 | default: /* Multiple exceptions */ | ||
| 812 | break; | 812 | break; |
| 813 | case 0x001: /* Invalid Op */ | 813 | case 0x001: /* Invalid Op */ |
| 814 | /* | 814 | /* |
diff --git a/arch/i386/lib/Makefile b/arch/i386/lib/Makefile index 7b1932d20f96..914933e9ec3d 100644 --- a/arch/i386/lib/Makefile +++ b/arch/i386/lib/Makefile | |||
| @@ -7,4 +7,3 @@ lib-y = checksum.o delay.o usercopy.o getuser.o putuser.o memcpy.o strstr.o \ | |||
| 7 | bitops.o | 7 | bitops.o |
| 8 | 8 | ||
| 9 | lib-$(CONFIG_X86_USE_3DNOW) += mmx.o | 9 | lib-$(CONFIG_X86_USE_3DNOW) += mmx.o |
| 10 | lib-$(CONFIG_HAVE_DEC_LOCK) += dec_and_lock.o | ||
diff --git a/arch/i386/lib/dec_and_lock.c b/arch/i386/lib/dec_and_lock.c deleted file mode 100644 index 8b81b2524fa6..000000000000 --- a/arch/i386/lib/dec_and_lock.c +++ /dev/null | |||
| @@ -1,42 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * x86 version of "atomic_dec_and_lock()" using | ||
| 3 | * the atomic "cmpxchg" instruction. | ||
| 4 | * | ||
| 5 | * (For CPU's lacking cmpxchg, we use the slow | ||
| 6 | * generic version, and this one never even gets | ||
| 7 | * compiled). | ||
| 8 | */ | ||
| 9 | |||
| 10 | #include <linux/spinlock.h> | ||
| 11 | #include <linux/module.h> | ||
| 12 | #include <asm/atomic.h> | ||
| 13 | |||
| 14 | int _atomic_dec_and_lock(atomic_t *atomic, spinlock_t *lock) | ||
| 15 | { | ||
| 16 | int counter; | ||
| 17 | int newcount; | ||
| 18 | |||
| 19 | repeat: | ||
| 20 | counter = atomic_read(atomic); | ||
| 21 | newcount = counter-1; | ||
| 22 | |||
| 23 | if (!newcount) | ||
| 24 | goto slow_path; | ||
| 25 | |||
| 26 | asm volatile("lock; cmpxchgl %1,%2" | ||
| 27 | :"=a" (newcount) | ||
| 28 | :"r" (newcount), "m" (atomic->counter), "0" (counter)); | ||
| 29 | |||
| 30 | /* If the above failed, "eax" will have changed */ | ||
| 31 | if (newcount != counter) | ||
| 32 | goto repeat; | ||
| 33 | return 0; | ||
| 34 | |||
| 35 | slow_path: | ||
| 36 | spin_lock(lock); | ||
| 37 | if (atomic_dec_and_test(atomic)) | ||
| 38 | return 1; | ||
| 39 | spin_unlock(lock); | ||
| 40 | return 0; | ||
| 41 | } | ||
| 42 | EXPORT_SYMBOL(_atomic_dec_and_lock); | ||
diff --git a/arch/i386/mach-default/setup.c b/arch/i386/mach-default/setup.c index e5a1a83d09ef..b4a7455c6993 100644 --- a/arch/i386/mach-default/setup.c +++ b/arch/i386/mach-default/setup.c | |||
| @@ -5,7 +5,6 @@ | |||
| 5 | #include <linux/config.h> | 5 | #include <linux/config.h> |
| 6 | #include <linux/smp.h> | 6 | #include <linux/smp.h> |
| 7 | #include <linux/init.h> | 7 | #include <linux/init.h> |
| 8 | #include <linux/irq.h> | ||
| 9 | #include <linux/interrupt.h> | 8 | #include <linux/interrupt.h> |
| 10 | #include <asm/acpi.h> | 9 | #include <asm/acpi.h> |
| 11 | #include <asm/arch_hooks.h> | 10 | #include <asm/arch_hooks.h> |
diff --git a/arch/i386/mach-visws/setup.c b/arch/i386/mach-visws/setup.c index 26ada6fc0d77..07fac7e749c7 100644 --- a/arch/i386/mach-visws/setup.c +++ b/arch/i386/mach-visws/setup.c | |||
| @@ -5,7 +5,6 @@ | |||
| 5 | 5 | ||
| 6 | #include <linux/smp.h> | 6 | #include <linux/smp.h> |
| 7 | #include <linux/init.h> | 7 | #include <linux/init.h> |
| 8 | #include <linux/irq.h> | ||
| 9 | #include <linux/interrupt.h> | 8 | #include <linux/interrupt.h> |
| 10 | 9 | ||
| 11 | #include <asm/fixmap.h> | 10 | #include <asm/fixmap.h> |
diff --git a/arch/i386/mach-visws/visws_apic.c b/arch/i386/mach-visws/visws_apic.c index 04e6585849a2..3e64fb721291 100644 --- a/arch/i386/mach-visws/visws_apic.c +++ b/arch/i386/mach-visws/visws_apic.c | |||
| @@ -19,7 +19,6 @@ | |||
| 19 | #include <linux/config.h> | 19 | #include <linux/config.h> |
| 20 | #include <linux/kernel_stat.h> | 20 | #include <linux/kernel_stat.h> |
| 21 | #include <linux/interrupt.h> | 21 | #include <linux/interrupt.h> |
| 22 | #include <linux/irq.h> | ||
| 23 | #include <linux/smp_lock.h> | 22 | #include <linux/smp_lock.h> |
| 24 | #include <linux/init.h> | 23 | #include <linux/init.h> |
| 25 | 24 | ||
diff --git a/arch/i386/mach-voyager/setup.c b/arch/i386/mach-voyager/setup.c index df123fc487bb..7d8a3acb9441 100644 --- a/arch/i386/mach-voyager/setup.c +++ b/arch/i386/mach-voyager/setup.c | |||
| @@ -4,7 +4,6 @@ | |||
| 4 | 4 | ||
| 5 | #include <linux/config.h> | 5 | #include <linux/config.h> |
| 6 | #include <linux/init.h> | 6 | #include <linux/init.h> |
| 7 | #include <linux/irq.h> | ||
| 8 | #include <linux/interrupt.h> | 7 | #include <linux/interrupt.h> |
| 9 | #include <asm/acpi.h> | 8 | #include <asm/acpi.h> |
| 10 | #include <asm/arch_hooks.h> | 9 | #include <asm/arch_hooks.h> |
diff --git a/arch/i386/mach-voyager/voyager_basic.c b/arch/i386/mach-voyager/voyager_basic.c index cc69875d979b..aa49a33a572c 100644 --- a/arch/i386/mach-voyager/voyager_basic.c +++ b/arch/i386/mach-voyager/voyager_basic.c | |||
| @@ -27,7 +27,6 @@ | |||
| 27 | #include <asm/voyager.h> | 27 | #include <asm/voyager.h> |
| 28 | #include <asm/vic.h> | 28 | #include <asm/vic.h> |
| 29 | #include <linux/pm.h> | 29 | #include <linux/pm.h> |
| 30 | #include <linux/irq.h> | ||
| 31 | #include <asm/tlbflush.h> | 30 | #include <asm/tlbflush.h> |
| 32 | #include <asm/arch_hooks.h> | 31 | #include <asm/arch_hooks.h> |
| 33 | #include <asm/i8253.h> | 32 | #include <asm/i8253.h> |
diff --git a/arch/i386/mach-voyager/voyager_smp.c b/arch/i386/mach-voyager/voyager_smp.c index 46b0cf4a31e0..72a1b9cae2e4 100644 --- a/arch/i386/mach-voyager/voyager_smp.c +++ b/arch/i386/mach-voyager/voyager_smp.c | |||
| @@ -30,8 +30,6 @@ | |||
| 30 | #include <asm/tlbflush.h> | 30 | #include <asm/tlbflush.h> |
| 31 | #include <asm/arch_hooks.h> | 31 | #include <asm/arch_hooks.h> |
| 32 | 32 | ||
| 33 | #include <linux/irq.h> | ||
| 34 | |||
| 35 | /* TLB state -- visible externally, indexed physically */ | 33 | /* TLB state -- visible externally, indexed physically */ |
| 36 | DEFINE_PER_CPU(struct tlb_state, cpu_tlbstate) ____cacheline_aligned = { &init_mm, 0 }; | 34 | DEFINE_PER_CPU(struct tlb_state, cpu_tlbstate) ____cacheline_aligned = { &init_mm, 0 }; |
| 37 | 35 | ||
diff --git a/arch/i386/mach-voyager/voyager_thread.c b/arch/i386/mach-voyager/voyager_thread.c index a9341b0eebff..2b03884fdb2a 100644 --- a/arch/i386/mach-voyager/voyager_thread.c +++ b/arch/i386/mach-voyager/voyager_thread.c | |||
| @@ -31,8 +31,6 @@ | |||
| 31 | #include <asm/mtrr.h> | 31 | #include <asm/mtrr.h> |
| 32 | #include <asm/msr.h> | 32 | #include <asm/msr.h> |
| 33 | 33 | ||
| 34 | #include <linux/irq.h> | ||
| 35 | |||
| 36 | #define THREAD_NAME "kvoyagerd" | 34 | #define THREAD_NAME "kvoyagerd" |
| 37 | 35 | ||
| 38 | /* external variables */ | 36 | /* external variables */ |
diff --git a/arch/i386/oprofile/nmi_timer_int.c b/arch/i386/oprofile/nmi_timer_int.c index ad93cdd55d63..930a1127bb30 100644 --- a/arch/i386/oprofile/nmi_timer_int.c +++ b/arch/i386/oprofile/nmi_timer_int.c | |||
| @@ -9,7 +9,7 @@ | |||
| 9 | 9 | ||
| 10 | #include <linux/init.h> | 10 | #include <linux/init.h> |
| 11 | #include <linux/smp.h> | 11 | #include <linux/smp.h> |
| 12 | #include <linux/irq.h> | 12 | #include <linux/errno.h> |
| 13 | #include <linux/oprofile.h> | 13 | #include <linux/oprofile.h> |
| 14 | #include <linux/rcupdate.h> | 14 | #include <linux/rcupdate.h> |
| 15 | 15 | ||
diff --git a/arch/i386/pci/acpi.c b/arch/i386/pci/acpi.c index 2941674f35eb..4c4522b43be5 100644 --- a/arch/i386/pci/acpi.c +++ b/arch/i386/pci/acpi.c | |||
| @@ -2,7 +2,6 @@ | |||
| 2 | #include <linux/acpi.h> | 2 | #include <linux/acpi.h> |
| 3 | #include <linux/init.h> | 3 | #include <linux/init.h> |
| 4 | #include <linux/irq.h> | 4 | #include <linux/irq.h> |
| 5 | #include <asm/hw_irq.h> | ||
| 6 | #include <asm/numa.h> | 5 | #include <asm/numa.h> |
| 7 | #include "pci.h" | 6 | #include "pci.h" |
| 8 | 7 | ||
diff --git a/arch/i386/pci/irq.c b/arch/i386/pci/irq.c index 326a2edc3834..cddafe33ff7c 100644 --- a/arch/i386/pci/irq.c +++ b/arch/i386/pci/irq.c | |||
| @@ -11,12 +11,11 @@ | |||
| 11 | #include <linux/init.h> | 11 | #include <linux/init.h> |
| 12 | #include <linux/slab.h> | 12 | #include <linux/slab.h> |
| 13 | #include <linux/interrupt.h> | 13 | #include <linux/interrupt.h> |
| 14 | #include <linux/irq.h> | ||
| 15 | #include <linux/dmi.h> | 14 | #include <linux/dmi.h> |
| 16 | #include <asm/io.h> | 15 | #include <asm/io.h> |
| 17 | #include <asm/smp.h> | 16 | #include <asm/smp.h> |
| 18 | #include <asm/io_apic.h> | 17 | #include <asm/io_apic.h> |
| 19 | #include <asm/hw_irq.h> | 18 | #include <linux/irq.h> |
| 20 | #include <linux/acpi.h> | 19 | #include <linux/acpi.h> |
| 21 | 20 | ||
| 22 | #include "pci.h" | 21 | #include "pci.h" |
diff --git a/arch/i386/power/cpu.c b/arch/i386/power/cpu.c index 7b0b9ad848e5..b27c5acc79d0 100644 --- a/arch/i386/power/cpu.c +++ b/arch/i386/power/cpu.c | |||
| @@ -8,25 +8,8 @@ | |||
| 8 | */ | 8 | */ |
| 9 | 9 | ||
| 10 | #include <linux/config.h> | 10 | #include <linux/config.h> |
| 11 | #include <linux/kernel.h> | ||
| 12 | #include <linux/module.h> | 11 | #include <linux/module.h> |
| 13 | #include <linux/init.h> | ||
| 14 | #include <linux/types.h> | ||
| 15 | #include <linux/spinlock.h> | ||
| 16 | #include <linux/poll.h> | ||
| 17 | #include <linux/delay.h> | ||
| 18 | #include <linux/sysrq.h> | ||
| 19 | #include <linux/proc_fs.h> | ||
| 20 | #include <linux/irq.h> | ||
| 21 | #include <linux/pm.h> | ||
| 22 | #include <linux/device.h> | ||
| 23 | #include <linux/suspend.h> | 12 | #include <linux/suspend.h> |
| 24 | #include <linux/acpi.h> | ||
| 25 | |||
| 26 | #include <asm/uaccess.h> | ||
| 27 | #include <asm/acpi.h> | ||
| 28 | #include <asm/tlbflush.h> | ||
| 29 | #include <asm/processor.h> | ||
| 30 | 13 | ||
| 31 | static struct saved_context saved_context; | 14 | static struct saved_context saved_context; |
| 32 | 15 | ||
