diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-08-20 13:36:18 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-08-20 13:36:18 -0400 |
| commit | c71a35520f2a30920d9c1a1fc86e16503b58681f (patch) | |
| tree | ceecf9303b571834a6137cdc5c179e4decb4f841 | |
| parent | 53795ced6e270fbb5cef7b527a71ffbb69657c78 (diff) | |
| parent | 515c7af85ed92696c311c53d53cb4898ff32d784 (diff) | |
Merge branch 'x86-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull x86 fixes from Ingo Molnar.
A x32 socket ABI fix with a -stable backport tag among other fixes.
* 'x86-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
x32: Use compat shims for {g,s}etsockopt
Revert "x86-64/efi: Use EFI to deal with platform wall clock"
x86, apic: fix broken legacy interrupts in the logical apic mode
x86, build: Globally set -fno-pic
x86, avx: don't use avx instructions with "noxsave" boot param
| -rw-r--r-- | arch/x86/Makefile | 4 | ||||
| -rw-r--r-- | arch/x86/boot/Makefile | 2 | ||||
| -rw-r--r-- | arch/x86/kernel/apic/io_apic.c | 10 | ||||
| -rw-r--r-- | arch/x86/kernel/cpu/common.c | 2 | ||||
| -rw-r--r-- | arch/x86/mm/pageattr.c | 10 | ||||
| -rw-r--r-- | arch/x86/platform/efi/efi.c | 30 | ||||
| -rw-r--r-- | arch/x86/realmode/rm/Makefile | 2 | ||||
| -rw-r--r-- | arch/x86/syscalls/syscall_64.tbl | 6 | ||||
| -rw-r--r-- | include/linux/efi.h | 2 | ||||
| -rw-r--r-- | init/main.c | 8 |
10 files changed, 58 insertions, 18 deletions
diff --git a/arch/x86/Makefile b/arch/x86/Makefile index b0c5276861ec..682e9c210baa 100644 --- a/arch/x86/Makefile +++ b/arch/x86/Makefile | |||
| @@ -27,6 +27,10 @@ ifeq ($(CONFIG_X86_32),y) | |||
| 27 | 27 | ||
| 28 | KBUILD_CFLAGS += -msoft-float -mregparm=3 -freg-struct-return | 28 | KBUILD_CFLAGS += -msoft-float -mregparm=3 -freg-struct-return |
| 29 | 29 | ||
| 30 | # Never want PIC in a 32-bit kernel, prevent breakage with GCC built | ||
| 31 | # with nonstandard options | ||
| 32 | KBUILD_CFLAGS += -fno-pic | ||
| 33 | |||
| 30 | # prevent gcc from keeping the stack 16 byte aligned | 34 | # prevent gcc from keeping the stack 16 byte aligned |
| 31 | KBUILD_CFLAGS += $(call cc-option,-mpreferred-stack-boundary=2) | 35 | KBUILD_CFLAGS += $(call cc-option,-mpreferred-stack-boundary=2) |
| 32 | 36 | ||
diff --git a/arch/x86/boot/Makefile b/arch/x86/boot/Makefile index 5a747dd884db..f7535bedc33f 100644 --- a/arch/x86/boot/Makefile +++ b/arch/x86/boot/Makefile | |||
| @@ -57,7 +57,7 @@ KBUILD_CFLAGS := $(LINUXINCLUDE) -g -Os -D_SETUP -D__KERNEL__ \ | |||
| 57 | -Wall -Wstrict-prototypes \ | 57 | -Wall -Wstrict-prototypes \ |
| 58 | -march=i386 -mregparm=3 \ | 58 | -march=i386 -mregparm=3 \ |
| 59 | -include $(srctree)/$(src)/code16gcc.h \ | 59 | -include $(srctree)/$(src)/code16gcc.h \ |
| 60 | -fno-strict-aliasing -fomit-frame-pointer \ | 60 | -fno-strict-aliasing -fomit-frame-pointer -fno-pic \ |
| 61 | $(call cc-option, -ffreestanding) \ | 61 | $(call cc-option, -ffreestanding) \ |
| 62 | $(call cc-option, -fno-toplevel-reorder,\ | 62 | $(call cc-option, -fno-toplevel-reorder,\ |
| 63 | $(call cc-option, -fno-unit-at-a-time)) \ | 63 | $(call cc-option, -fno-unit-at-a-time)) \ |
diff --git a/arch/x86/kernel/apic/io_apic.c b/arch/x86/kernel/apic/io_apic.c index a6c64aaddf9a..c265593ec2cd 100644 --- a/arch/x86/kernel/apic/io_apic.c +++ b/arch/x86/kernel/apic/io_apic.c | |||
| @@ -1356,6 +1356,16 @@ static void setup_ioapic_irq(unsigned int irq, struct irq_cfg *cfg, | |||
| 1356 | if (!IO_APIC_IRQ(irq)) | 1356 | if (!IO_APIC_IRQ(irq)) |
| 1357 | return; | 1357 | return; |
| 1358 | 1358 | ||
| 1359 | /* | ||
| 1360 | * For legacy irqs, cfg->domain starts with cpu 0. Now that IO-APIC | ||
| 1361 | * can handle this irq and the apic driver is finialized at this point, | ||
| 1362 | * update the cfg->domain. | ||
| 1363 | */ | ||
| 1364 | if (irq < legacy_pic->nr_legacy_irqs && | ||
| 1365 | cpumask_equal(cfg->domain, cpumask_of(0))) | ||
| 1366 | apic->vector_allocation_domain(0, cfg->domain, | ||
| 1367 | apic->target_cpus()); | ||
| 1368 | |||
| 1359 | if (assign_irq_vector(irq, cfg, apic->target_cpus())) | 1369 | if (assign_irq_vector(irq, cfg, apic->target_cpus())) |
| 1360 | return; | 1370 | return; |
| 1361 | 1371 | ||
diff --git a/arch/x86/kernel/cpu/common.c b/arch/x86/kernel/cpu/common.c index 46d8786d655e..a5fbc3c5fccc 100644 --- a/arch/x86/kernel/cpu/common.c +++ b/arch/x86/kernel/cpu/common.c | |||
| @@ -144,6 +144,8 @@ static int __init x86_xsave_setup(char *s) | |||
| 144 | { | 144 | { |
| 145 | setup_clear_cpu_cap(X86_FEATURE_XSAVE); | 145 | setup_clear_cpu_cap(X86_FEATURE_XSAVE); |
| 146 | setup_clear_cpu_cap(X86_FEATURE_XSAVEOPT); | 146 | setup_clear_cpu_cap(X86_FEATURE_XSAVEOPT); |
| 147 | setup_clear_cpu_cap(X86_FEATURE_AVX); | ||
| 148 | setup_clear_cpu_cap(X86_FEATURE_AVX2); | ||
| 147 | return 1; | 149 | return 1; |
| 148 | } | 150 | } |
| 149 | __setup("noxsave", x86_xsave_setup); | 151 | __setup("noxsave", x86_xsave_setup); |
diff --git a/arch/x86/mm/pageattr.c b/arch/x86/mm/pageattr.c index 931930a96160..a718e0d23503 100644 --- a/arch/x86/mm/pageattr.c +++ b/arch/x86/mm/pageattr.c | |||
| @@ -919,13 +919,11 @@ static int change_page_attr_set_clr(unsigned long *addr, int numpages, | |||
| 919 | 919 | ||
| 920 | /* | 920 | /* |
| 921 | * On success we use clflush, when the CPU supports it to | 921 | * On success we use clflush, when the CPU supports it to |
| 922 | * avoid the wbindv. If the CPU does not support it, in the | 922 | * avoid the wbindv. If the CPU does not support it and in the |
| 923 | * error case, and during early boot (for EFI) we fall back | 923 | * error case we fall back to cpa_flush_all (which uses |
| 924 | * to cpa_flush_all (which uses wbinvd): | 924 | * wbindv): |
| 925 | */ | 925 | */ |
| 926 | if (early_boot_irqs_disabled) | 926 | if (!ret && cpu_has_clflush) { |
| 927 | __cpa_flush_all((void *)(long)cache); | ||
| 928 | else if (!ret && cpu_has_clflush) { | ||
| 929 | if (cpa.flags & (CPA_PAGES_ARRAY | CPA_ARRAY)) { | 927 | if (cpa.flags & (CPA_PAGES_ARRAY | CPA_ARRAY)) { |
| 930 | cpa_flush_array(addr, numpages, cache, | 928 | cpa_flush_array(addr, numpages, cache, |
| 931 | cpa.flags, pages); | 929 | cpa.flags, pages); |
diff --git a/arch/x86/platform/efi/efi.c b/arch/x86/platform/efi/efi.c index 2dc29f51e75a..92660edaa1e7 100644 --- a/arch/x86/platform/efi/efi.c +++ b/arch/x86/platform/efi/efi.c | |||
| @@ -234,7 +234,22 @@ static efi_status_t __init phys_efi_set_virtual_address_map( | |||
| 234 | return status; | 234 | return status; |
| 235 | } | 235 | } |
| 236 | 236 | ||
| 237 | static int efi_set_rtc_mmss(unsigned long nowtime) | 237 | static efi_status_t __init phys_efi_get_time(efi_time_t *tm, |
| 238 | efi_time_cap_t *tc) | ||
| 239 | { | ||
| 240 | unsigned long flags; | ||
| 241 | efi_status_t status; | ||
| 242 | |||
| 243 | spin_lock_irqsave(&rtc_lock, flags); | ||
| 244 | efi_call_phys_prelog(); | ||
| 245 | status = efi_call_phys2(efi_phys.get_time, virt_to_phys(tm), | ||
| 246 | virt_to_phys(tc)); | ||
| 247 | efi_call_phys_epilog(); | ||
| 248 | spin_unlock_irqrestore(&rtc_lock, flags); | ||
| 249 | return status; | ||
| 250 | } | ||
| 251 | |||
| 252 | int efi_set_rtc_mmss(unsigned long nowtime) | ||
| 238 | { | 253 | { |
| 239 | int real_seconds, real_minutes; | 254 | int real_seconds, real_minutes; |
| 240 | efi_status_t status; | 255 | efi_status_t status; |
| @@ -263,7 +278,7 @@ static int efi_set_rtc_mmss(unsigned long nowtime) | |||
| 263 | return 0; | 278 | return 0; |
| 264 | } | 279 | } |
| 265 | 280 | ||
| 266 | static unsigned long efi_get_time(void) | 281 | unsigned long efi_get_time(void) |
| 267 | { | 282 | { |
| 268 | efi_status_t status; | 283 | efi_status_t status; |
| 269 | efi_time_t eft; | 284 | efi_time_t eft; |
| @@ -606,13 +621,18 @@ static int __init efi_runtime_init(void) | |||
| 606 | } | 621 | } |
| 607 | /* | 622 | /* |
| 608 | * We will only need *early* access to the following | 623 | * We will only need *early* access to the following |
| 609 | * EFI runtime service before set_virtual_address_map | 624 | * two EFI runtime services before set_virtual_address_map |
| 610 | * is invoked. | 625 | * is invoked. |
| 611 | */ | 626 | */ |
| 627 | efi_phys.get_time = (efi_get_time_t *)runtime->get_time; | ||
| 612 | efi_phys.set_virtual_address_map = | 628 | efi_phys.set_virtual_address_map = |
| 613 | (efi_set_virtual_address_map_t *) | 629 | (efi_set_virtual_address_map_t *) |
| 614 | runtime->set_virtual_address_map; | 630 | runtime->set_virtual_address_map; |
| 615 | 631 | /* | |
| 632 | * Make efi_get_time can be called before entering | ||
| 633 | * virtual mode. | ||
| 634 | */ | ||
| 635 | efi.get_time = phys_efi_get_time; | ||
| 616 | early_iounmap(runtime, sizeof(efi_runtime_services_t)); | 636 | early_iounmap(runtime, sizeof(efi_runtime_services_t)); |
| 617 | 637 | ||
| 618 | return 0; | 638 | return 0; |
| @@ -700,10 +720,12 @@ void __init efi_init(void) | |||
| 700 | efi_enabled = 0; | 720 | efi_enabled = 0; |
| 701 | return; | 721 | return; |
| 702 | } | 722 | } |
| 723 | #ifdef CONFIG_X86_32 | ||
| 703 | if (efi_native) { | 724 | if (efi_native) { |
| 704 | x86_platform.get_wallclock = efi_get_time; | 725 | x86_platform.get_wallclock = efi_get_time; |
| 705 | x86_platform.set_wallclock = efi_set_rtc_mmss; | 726 | x86_platform.set_wallclock = efi_set_rtc_mmss; |
| 706 | } | 727 | } |
| 728 | #endif | ||
| 707 | 729 | ||
| 708 | #if EFI_DEBUG | 730 | #if EFI_DEBUG |
| 709 | print_efi_memmap(); | 731 | print_efi_memmap(); |
diff --git a/arch/x86/realmode/rm/Makefile b/arch/x86/realmode/rm/Makefile index b2d534cab25f..88692871823f 100644 --- a/arch/x86/realmode/rm/Makefile +++ b/arch/x86/realmode/rm/Makefile | |||
| @@ -72,7 +72,7 @@ KBUILD_CFLAGS := $(LINUXINCLUDE) -m32 -g -Os -D_SETUP -D__KERNEL__ -D_WAKEUP \ | |||
| 72 | -Wall -Wstrict-prototypes \ | 72 | -Wall -Wstrict-prototypes \ |
| 73 | -march=i386 -mregparm=3 \ | 73 | -march=i386 -mregparm=3 \ |
| 74 | -include $(srctree)/$(src)/../../boot/code16gcc.h \ | 74 | -include $(srctree)/$(src)/../../boot/code16gcc.h \ |
| 75 | -fno-strict-aliasing -fomit-frame-pointer \ | 75 | -fno-strict-aliasing -fomit-frame-pointer -fno-pic \ |
| 76 | $(call cc-option, -ffreestanding) \ | 76 | $(call cc-option, -ffreestanding) \ |
| 77 | $(call cc-option, -fno-toplevel-reorder,\ | 77 | $(call cc-option, -fno-toplevel-reorder,\ |
| 78 | $(call cc-option, -fno-unit-at-a-time)) \ | 78 | $(call cc-option, -fno-unit-at-a-time)) \ |
diff --git a/arch/x86/syscalls/syscall_64.tbl b/arch/x86/syscalls/syscall_64.tbl index 29aed7ac2c02..a582bfed95bb 100644 --- a/arch/x86/syscalls/syscall_64.tbl +++ b/arch/x86/syscalls/syscall_64.tbl | |||
| @@ -60,8 +60,8 @@ | |||
| 60 | 51 common getsockname sys_getsockname | 60 | 51 common getsockname sys_getsockname |
| 61 | 52 common getpeername sys_getpeername | 61 | 52 common getpeername sys_getpeername |
| 62 | 53 common socketpair sys_socketpair | 62 | 53 common socketpair sys_socketpair |
| 63 | 54 common setsockopt sys_setsockopt | 63 | 54 64 setsockopt sys_setsockopt |
| 64 | 55 common getsockopt sys_getsockopt | 64 | 55 64 getsockopt sys_getsockopt |
| 65 | 56 common clone stub_clone | 65 | 56 common clone stub_clone |
| 66 | 57 common fork stub_fork | 66 | 57 common fork stub_fork |
| 67 | 58 common vfork stub_vfork | 67 | 58 common vfork stub_vfork |
| @@ -353,3 +353,5 @@ | |||
| 353 | 538 x32 sendmmsg compat_sys_sendmmsg | 353 | 538 x32 sendmmsg compat_sys_sendmmsg |
| 354 | 539 x32 process_vm_readv compat_sys_process_vm_readv | 354 | 539 x32 process_vm_readv compat_sys_process_vm_readv |
| 355 | 540 x32 process_vm_writev compat_sys_process_vm_writev | 355 | 540 x32 process_vm_writev compat_sys_process_vm_writev |
| 356 | 541 x32 setsockopt compat_sys_setsockopt | ||
| 357 | 542 x32 getsockopt compat_sys_getsockopt | ||
diff --git a/include/linux/efi.h b/include/linux/efi.h index 103adc6d7e3a..ec45ccd8708a 100644 --- a/include/linux/efi.h +++ b/include/linux/efi.h | |||
| @@ -503,6 +503,8 @@ extern u64 efi_mem_attribute (unsigned long phys_addr, unsigned long size); | |||
| 503 | extern int __init efi_uart_console_only (void); | 503 | extern int __init efi_uart_console_only (void); |
| 504 | extern void efi_initialize_iomem_resources(struct resource *code_resource, | 504 | extern void efi_initialize_iomem_resources(struct resource *code_resource, |
| 505 | struct resource *data_resource, struct resource *bss_resource); | 505 | struct resource *data_resource, struct resource *bss_resource); |
| 506 | extern unsigned long efi_get_time(void); | ||
| 507 | extern int efi_set_rtc_mmss(unsigned long nowtime); | ||
| 506 | extern void efi_reserve_boot_services(void); | 508 | extern void efi_reserve_boot_services(void); |
| 507 | extern struct efi_memory_map memmap; | 509 | extern struct efi_memory_map memmap; |
| 508 | 510 | ||
diff --git a/init/main.c b/init/main.c index e60679de61c3..b28673087ac0 100644 --- a/init/main.c +++ b/init/main.c | |||
| @@ -461,10 +461,6 @@ static void __init mm_init(void) | |||
| 461 | percpu_init_late(); | 461 | percpu_init_late(); |
| 462 | pgtable_cache_init(); | 462 | pgtable_cache_init(); |
| 463 | vmalloc_init(); | 463 | vmalloc_init(); |
| 464 | #ifdef CONFIG_X86 | ||
| 465 | if (efi_enabled) | ||
| 466 | efi_enter_virtual_mode(); | ||
| 467 | #endif | ||
| 468 | } | 464 | } |
| 469 | 465 | ||
| 470 | asmlinkage void __init start_kernel(void) | 466 | asmlinkage void __init start_kernel(void) |
| @@ -606,6 +602,10 @@ asmlinkage void __init start_kernel(void) | |||
| 606 | calibrate_delay(); | 602 | calibrate_delay(); |
| 607 | pidmap_init(); | 603 | pidmap_init(); |
| 608 | anon_vma_init(); | 604 | anon_vma_init(); |
| 605 | #ifdef CONFIG_X86 | ||
| 606 | if (efi_enabled) | ||
| 607 | efi_enter_virtual_mode(); | ||
| 608 | #endif | ||
| 609 | thread_info_cache_init(); | 609 | thread_info_cache_init(); |
| 610 | cred_init(); | 610 | cred_init(); |
| 611 | fork_init(totalram_pages); | 611 | fork_init(totalram_pages); |
