diff options
227 files changed, 1797 insertions, 1161 deletions
diff --git a/MAINTAINERS b/MAINTAINERS index 16a5c5f2c6a6..69f19f10314a 100644 --- a/MAINTAINERS +++ b/MAINTAINERS | |||
| @@ -2813,38 +2813,19 @@ F: Documentation/gpio.txt | |||
| 2813 | F: drivers/gpio/ | 2813 | F: drivers/gpio/ |
| 2814 | F: include/linux/gpio* | 2814 | F: include/linux/gpio* |
| 2815 | 2815 | ||
| 2816 | GRE DEMULTIPLEXER DRIVER | ||
| 2817 | M: Dmitry Kozlov <xeb@mail.ru> | ||
| 2818 | L: netdev@vger.kernel.org | ||
| 2819 | S: Maintained | ||
| 2820 | F: net/ipv4/gre.c | ||
| 2821 | F: include/net/gre.h | ||
| 2822 | |||
| 2816 | GRETH 10/100/1G Ethernet MAC device driver | 2823 | GRETH 10/100/1G Ethernet MAC device driver |
| 2817 | M: Kristoffer Glembo <kristoffer@gaisler.com> | 2824 | M: Kristoffer Glembo <kristoffer@gaisler.com> |
| 2818 | L: netdev@vger.kernel.org | 2825 | L: netdev@vger.kernel.org |
| 2819 | S: Maintained | 2826 | S: Maintained |
| 2820 | F: drivers/net/greth* | 2827 | F: drivers/net/greth* |
| 2821 | 2828 | ||
| 2822 | HARD DRIVE ACTIVE PROTECTION SYSTEM (HDAPS) DRIVER | ||
| 2823 | M: Frank Seidel <frank@f-seidel.de> | ||
| 2824 | L: platform-driver-x86@vger.kernel.org | ||
| 2825 | W: http://www.kernel.org/pub/linux/kernel/people/fseidel/hdaps/ | ||
| 2826 | S: Maintained | ||
| 2827 | F: drivers/platform/x86/hdaps.c | ||
| 2828 | |||
| 2829 | HWPOISON MEMORY FAILURE HANDLING | ||
| 2830 | M: Andi Kleen <andi@firstfloor.org> | ||
| 2831 | L: linux-mm@kvack.org | ||
| 2832 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/ak/linux-mce-2.6.git hwpoison | ||
| 2833 | S: Maintained | ||
| 2834 | F: mm/memory-failure.c | ||
| 2835 | F: mm/hwpoison-inject.c | ||
| 2836 | |||
| 2837 | HYPERVISOR VIRTUAL CONSOLE DRIVER | ||
| 2838 | L: linuxppc-dev@lists.ozlabs.org | ||
| 2839 | S: Odd Fixes | ||
| 2840 | F: drivers/tty/hvc/ | ||
| 2841 | |||
| 2842 | iSCSI BOOT FIRMWARE TABLE (iBFT) DRIVER | ||
| 2843 | M: Peter Jones <pjones@redhat.com> | ||
| 2844 | M: Konrad Rzeszutek Wilk <konrad@kernel.org> | ||
| 2845 | S: Maintained | ||
| 2846 | F: drivers/firmware/iscsi_ibft* | ||
| 2847 | |||
| 2848 | GSPCA FINEPIX SUBDRIVER | 2829 | GSPCA FINEPIX SUBDRIVER |
| 2849 | M: Frank Zago <frank@zago.net> | 2830 | M: Frank Zago <frank@zago.net> |
| 2850 | L: linux-media@vger.kernel.org | 2831 | L: linux-media@vger.kernel.org |
| @@ -2895,6 +2876,26 @@ T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | |||
| 2895 | S: Maintained | 2876 | S: Maintained |
| 2896 | F: drivers/media/video/gspca/ | 2877 | F: drivers/media/video/gspca/ |
| 2897 | 2878 | ||
| 2879 | HARD DRIVE ACTIVE PROTECTION SYSTEM (HDAPS) DRIVER | ||
| 2880 | M: Frank Seidel <frank@f-seidel.de> | ||
| 2881 | L: platform-driver-x86@vger.kernel.org | ||
| 2882 | W: http://www.kernel.org/pub/linux/kernel/people/fseidel/hdaps/ | ||
| 2883 | S: Maintained | ||
| 2884 | F: drivers/platform/x86/hdaps.c | ||
| 2885 | |||
| 2886 | HWPOISON MEMORY FAILURE HANDLING | ||
| 2887 | M: Andi Kleen <andi@firstfloor.org> | ||
| 2888 | L: linux-mm@kvack.org | ||
| 2889 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/ak/linux-mce-2.6.git hwpoison | ||
| 2890 | S: Maintained | ||
| 2891 | F: mm/memory-failure.c | ||
| 2892 | F: mm/hwpoison-inject.c | ||
| 2893 | |||
| 2894 | HYPERVISOR VIRTUAL CONSOLE DRIVER | ||
| 2895 | L: linuxppc-dev@lists.ozlabs.org | ||
| 2896 | S: Odd Fixes | ||
| 2897 | F: drivers/tty/hvc/ | ||
| 2898 | |||
| 2898 | HARDWARE MONITORING | 2899 | HARDWARE MONITORING |
| 2899 | M: Jean Delvare <khali@linux-fr.org> | 2900 | M: Jean Delvare <khali@linux-fr.org> |
| 2900 | M: Guenter Roeck <guenter.roeck@ericsson.com> | 2901 | M: Guenter Roeck <guenter.roeck@ericsson.com> |
| @@ -3478,6 +3479,12 @@ F: Documentation/isapnp.txt | |||
| 3478 | F: drivers/pnp/isapnp/ | 3479 | F: drivers/pnp/isapnp/ |
| 3479 | F: include/linux/isapnp.h | 3480 | F: include/linux/isapnp.h |
| 3480 | 3481 | ||
| 3482 | iSCSI BOOT FIRMWARE TABLE (iBFT) DRIVER | ||
| 3483 | M: Peter Jones <pjones@redhat.com> | ||
| 3484 | M: Konrad Rzeszutek Wilk <konrad@kernel.org> | ||
| 3485 | S: Maintained | ||
| 3486 | F: drivers/firmware/iscsi_ibft* | ||
| 3487 | |||
| 3481 | ISCSI | 3488 | ISCSI |
| 3482 | M: Mike Christie <michaelc@cs.wisc.edu> | 3489 | M: Mike Christie <michaelc@cs.wisc.edu> |
| 3483 | L: open-iscsi@googlegroups.com | 3490 | L: open-iscsi@googlegroups.com |
| @@ -4989,6 +4996,13 @@ F: Documentation/pps/ | |||
| 4989 | F: drivers/pps/ | 4996 | F: drivers/pps/ |
| 4990 | F: include/linux/pps*.h | 4997 | F: include/linux/pps*.h |
| 4991 | 4998 | ||
| 4999 | PPTP DRIVER | ||
| 5000 | M: Dmitry Kozlov <xeb@mail.ru> | ||
| 5001 | L: netdev@vger.kernel.org | ||
| 5002 | S: Maintained | ||
| 5003 | F: drivers/net/pptp.c | ||
| 5004 | W: http://sourceforge.net/projects/accel-pptp | ||
| 5005 | |||
| 4992 | PREEMPTIBLE KERNEL | 5006 | PREEMPTIBLE KERNEL |
| 4993 | M: Robert Love <rml@tech9.net> | 5007 | M: Robert Love <rml@tech9.net> |
| 4994 | L: kpreempt-tech@lists.sourceforge.net | 5008 | L: kpreempt-tech@lists.sourceforge.net |
| @@ -7024,20 +7038,6 @@ M: "Maciej W. Rozycki" <macro@linux-mips.org> | |||
| 7024 | S: Maintained | 7038 | S: Maintained |
| 7025 | F: drivers/tty/serial/zs.* | 7039 | F: drivers/tty/serial/zs.* |
| 7026 | 7040 | ||
| 7027 | GRE DEMULTIPLEXER DRIVER | ||
| 7028 | M: Dmitry Kozlov <xeb@mail.ru> | ||
| 7029 | L: netdev@vger.kernel.org | ||
| 7030 | S: Maintained | ||
| 7031 | F: net/ipv4/gre.c | ||
| 7032 | F: include/net/gre.h | ||
| 7033 | |||
| 7034 | PPTP DRIVER | ||
| 7035 | M: Dmitry Kozlov <xeb@mail.ru> | ||
| 7036 | L: netdev@vger.kernel.org | ||
| 7037 | S: Maintained | ||
| 7038 | F: drivers/net/pptp.c | ||
| 7039 | W: http://sourceforge.net/projects/accel-pptp | ||
| 7040 | |||
| 7041 | THE REST | 7041 | THE REST |
| 7042 | M: Linus Torvalds <torvalds@linux-foundation.org> | 7042 | M: Linus Torvalds <torvalds@linux-foundation.org> |
| 7043 | L: linux-kernel@vger.kernel.org | 7043 | L: linux-kernel@vger.kernel.org |
diff --git a/arch/alpha/include/asm/unistd.h b/arch/alpha/include/asm/unistd.h index 058937bf5a77..b1834166922d 100644 --- a/arch/alpha/include/asm/unistd.h +++ b/arch/alpha/include/asm/unistd.h | |||
| @@ -452,10 +452,14 @@ | |||
| 452 | #define __NR_fanotify_init 494 | 452 | #define __NR_fanotify_init 494 |
| 453 | #define __NR_fanotify_mark 495 | 453 | #define __NR_fanotify_mark 495 |
| 454 | #define __NR_prlimit64 496 | 454 | #define __NR_prlimit64 496 |
| 455 | #define __NR_name_to_handle_at 497 | ||
| 456 | #define __NR_open_by_handle_at 498 | ||
| 457 | #define __NR_clock_adjtime 499 | ||
| 458 | #define __NR_syncfs 500 | ||
| 455 | 459 | ||
| 456 | #ifdef __KERNEL__ | 460 | #ifdef __KERNEL__ |
| 457 | 461 | ||
| 458 | #define NR_SYSCALLS 497 | 462 | #define NR_SYSCALLS 501 |
| 459 | 463 | ||
| 460 | #define __ARCH_WANT_IPC_PARSE_VERSION | 464 | #define __ARCH_WANT_IPC_PARSE_VERSION |
| 461 | #define __ARCH_WANT_OLD_READDIR | 465 | #define __ARCH_WANT_OLD_READDIR |
diff --git a/arch/alpha/kernel/systbls.S b/arch/alpha/kernel/systbls.S index a6a1de9db16f..15f999d41c75 100644 --- a/arch/alpha/kernel/systbls.S +++ b/arch/alpha/kernel/systbls.S | |||
| @@ -498,23 +498,27 @@ sys_call_table: | |||
| 498 | .quad sys_ni_syscall /* sys_timerfd */ | 498 | .quad sys_ni_syscall /* sys_timerfd */ |
| 499 | .quad sys_eventfd | 499 | .quad sys_eventfd |
| 500 | .quad sys_recvmmsg | 500 | .quad sys_recvmmsg |
| 501 | .quad sys_fallocate /* 480 */ | 501 | .quad sys_fallocate /* 480 */ |
| 502 | .quad sys_timerfd_create | 502 | .quad sys_timerfd_create |
| 503 | .quad sys_timerfd_settime | 503 | .quad sys_timerfd_settime |
| 504 | .quad sys_timerfd_gettime | 504 | .quad sys_timerfd_gettime |
| 505 | .quad sys_signalfd4 | 505 | .quad sys_signalfd4 |
| 506 | .quad sys_eventfd2 /* 485 */ | 506 | .quad sys_eventfd2 /* 485 */ |
| 507 | .quad sys_epoll_create1 | 507 | .quad sys_epoll_create1 |
| 508 | .quad sys_dup3 | 508 | .quad sys_dup3 |
| 509 | .quad sys_pipe2 | 509 | .quad sys_pipe2 |
| 510 | .quad sys_inotify_init1 | 510 | .quad sys_inotify_init1 |
| 511 | .quad sys_preadv /* 490 */ | 511 | .quad sys_preadv /* 490 */ |
| 512 | .quad sys_pwritev | 512 | .quad sys_pwritev |
| 513 | .quad sys_rt_tgsigqueueinfo | 513 | .quad sys_rt_tgsigqueueinfo |
| 514 | .quad sys_perf_event_open | 514 | .quad sys_perf_event_open |
| 515 | .quad sys_fanotify_init | 515 | .quad sys_fanotify_init |
| 516 | .quad sys_fanotify_mark /* 495 */ | 516 | .quad sys_fanotify_mark /* 495 */ |
| 517 | .quad sys_prlimit64 | 517 | .quad sys_prlimit64 |
| 518 | .quad sys_name_to_handle_at | ||
| 519 | .quad sys_open_by_handle_at | ||
| 520 | .quad sys_clock_adjtime | ||
| 521 | .quad sys_syncfs /* 500 */ | ||
| 518 | 522 | ||
| 519 | .size sys_call_table, . - sys_call_table | 523 | .size sys_call_table, . - sys_call_table |
| 520 | .type sys_call_table, @object | 524 | .type sys_call_table, @object |
diff --git a/arch/alpha/kernel/time.c b/arch/alpha/kernel/time.c index 918e8e0b72ff..818e74ed45dc 100644 --- a/arch/alpha/kernel/time.c +++ b/arch/alpha/kernel/time.c | |||
| @@ -375,8 +375,7 @@ static struct clocksource clocksource_rpcc = { | |||
| 375 | 375 | ||
| 376 | static inline void register_rpcc_clocksource(long cycle_freq) | 376 | static inline void register_rpcc_clocksource(long cycle_freq) |
| 377 | { | 377 | { |
| 378 | clocksource_calc_mult_shift(&clocksource_rpcc, cycle_freq, 4); | 378 | clocksource_register_hz(&clocksource_rpcc, cycle_freq); |
| 379 | clocksource_register(&clocksource_rpcc); | ||
| 380 | } | 379 | } |
| 381 | #else /* !CONFIG_SMP */ | 380 | #else /* !CONFIG_SMP */ |
| 382 | static inline void register_rpcc_clocksource(long cycle_freq) | 381 | static inline void register_rpcc_clocksource(long cycle_freq) |
diff --git a/arch/arm/boot/compressed/Makefile b/arch/arm/boot/compressed/Makefile index 8ebbb511c783..0c6852d93506 100644 --- a/arch/arm/boot/compressed/Makefile +++ b/arch/arm/boot/compressed/Makefile | |||
| @@ -74,7 +74,7 @@ ZTEXTADDR := $(CONFIG_ZBOOT_ROM_TEXT) | |||
| 74 | ZBSSADDR := $(CONFIG_ZBOOT_ROM_BSS) | 74 | ZBSSADDR := $(CONFIG_ZBOOT_ROM_BSS) |
| 75 | else | 75 | else |
| 76 | ZTEXTADDR := 0 | 76 | ZTEXTADDR := 0 |
| 77 | ZBSSADDR := ALIGN(4) | 77 | ZBSSADDR := ALIGN(8) |
| 78 | endif | 78 | endif |
| 79 | 79 | ||
| 80 | SEDFLAGS = s/TEXT_START/$(ZTEXTADDR)/;s/BSS_START/$(ZBSSADDR)/ | 80 | SEDFLAGS = s/TEXT_START/$(ZTEXTADDR)/;s/BSS_START/$(ZBSSADDR)/ |
diff --git a/arch/arm/boot/compressed/head.S b/arch/arm/boot/compressed/head.S index adf583cd0c35..49f5b2eaaa87 100644 --- a/arch/arm/boot/compressed/head.S +++ b/arch/arm/boot/compressed/head.S | |||
| @@ -179,15 +179,14 @@ not_angel: | |||
| 179 | bl cache_on | 179 | bl cache_on |
| 180 | 180 | ||
| 181 | restart: adr r0, LC0 | 181 | restart: adr r0, LC0 |
| 182 | ldmia r0, {r1, r2, r3, r5, r6, r9, r11, r12} | 182 | ldmia r0, {r1, r2, r3, r6, r9, r11, r12} |
| 183 | ldr sp, [r0, #32] | 183 | ldr sp, [r0, #28] |
| 184 | 184 | ||
| 185 | /* | 185 | /* |
| 186 | * We might be running at a different address. We need | 186 | * We might be running at a different address. We need |
| 187 | * to fix up various pointers. | 187 | * to fix up various pointers. |
| 188 | */ | 188 | */ |
| 189 | sub r0, r0, r1 @ calculate the delta offset | 189 | sub r0, r0, r1 @ calculate the delta offset |
| 190 | add r5, r5, r0 @ _start | ||
| 191 | add r6, r6, r0 @ _edata | 190 | add r6, r6, r0 @ _edata |
| 192 | 191 | ||
| 193 | #ifndef CONFIG_ZBOOT_ROM | 192 | #ifndef CONFIG_ZBOOT_ROM |
| @@ -206,31 +205,40 @@ restart: adr r0, LC0 | |||
| 206 | /* | 205 | /* |
| 207 | * Check to see if we will overwrite ourselves. | 206 | * Check to see if we will overwrite ourselves. |
| 208 | * r4 = final kernel address | 207 | * r4 = final kernel address |
| 209 | * r5 = start of this image | ||
| 210 | * r9 = size of decompressed image | 208 | * r9 = size of decompressed image |
| 211 | * r10 = end of this image, including bss/stack/malloc space if non XIP | 209 | * r10 = end of this image, including bss/stack/malloc space if non XIP |
| 212 | * We basically want: | 210 | * We basically want: |
| 213 | * r4 >= r10 -> OK | 211 | * r4 - 16k page directory >= r10 -> OK |
| 214 | * r4 + image length <= r5 -> OK | 212 | * r4 + image length <= current position (pc) -> OK |
| 215 | */ | 213 | */ |
| 214 | add r10, r10, #16384 | ||
| 216 | cmp r4, r10 | 215 | cmp r4, r10 |
| 217 | bhs wont_overwrite | 216 | bhs wont_overwrite |
| 218 | add r10, r4, r9 | 217 | add r10, r4, r9 |
| 219 | cmp r10, r5 | 218 | ARM( cmp r10, pc ) |
| 219 | THUMB( mov lr, pc ) | ||
| 220 | THUMB( cmp r10, lr ) | ||
| 220 | bls wont_overwrite | 221 | bls wont_overwrite |
| 221 | 222 | ||
| 222 | /* | 223 | /* |
| 223 | * Relocate ourselves past the end of the decompressed kernel. | 224 | * Relocate ourselves past the end of the decompressed kernel. |
| 224 | * r5 = start of this image | ||
| 225 | * r6 = _edata | 225 | * r6 = _edata |
| 226 | * r10 = end of the decompressed kernel | 226 | * r10 = end of the decompressed kernel |
| 227 | * Because we always copy ahead, we need to do it from the end and go | 227 | * Because we always copy ahead, we need to do it from the end and go |
| 228 | * backward in case the source and destination overlap. | 228 | * backward in case the source and destination overlap. |
| 229 | */ | 229 | */ |
| 230 | /* Round up to next 256-byte boundary. */ | 230 | /* |
| 231 | add r10, r10, #256 | 231 | * Bump to the next 256-byte boundary with the size of |
| 232 | * the relocation code added. This avoids overwriting | ||
| 233 | * ourself when the offset is small. | ||
| 234 | */ | ||
| 235 | add r10, r10, #((reloc_code_end - restart + 256) & ~255) | ||
| 232 | bic r10, r10, #255 | 236 | bic r10, r10, #255 |
| 233 | 237 | ||
| 238 | /* Get start of code we want to copy and align it down. */ | ||
| 239 | adr r5, restart | ||
| 240 | bic r5, r5, #31 | ||
| 241 | |||
| 234 | sub r9, r6, r5 @ size to copy | 242 | sub r9, r6, r5 @ size to copy |
| 235 | add r9, r9, #31 @ rounded up to a multiple | 243 | add r9, r9, #31 @ rounded up to a multiple |
| 236 | bic r9, r9, #31 @ ... of 32 bytes | 244 | bic r9, r9, #31 @ ... of 32 bytes |
| @@ -245,6 +253,11 @@ restart: adr r0, LC0 | |||
| 245 | /* Preserve offset to relocated code. */ | 253 | /* Preserve offset to relocated code. */ |
| 246 | sub r6, r9, r6 | 254 | sub r6, r9, r6 |
| 247 | 255 | ||
| 256 | #ifndef CONFIG_ZBOOT_ROM | ||
| 257 | /* cache_clean_flush may use the stack, so relocate it */ | ||
| 258 | add sp, sp, r6 | ||
| 259 | #endif | ||
| 260 | |||
| 248 | bl cache_clean_flush | 261 | bl cache_clean_flush |
| 249 | 262 | ||
| 250 | adr r0, BSYM(restart) | 263 | adr r0, BSYM(restart) |
| @@ -333,7 +346,6 @@ not_relocated: mov r0, #0 | |||
| 333 | LC0: .word LC0 @ r1 | 346 | LC0: .word LC0 @ r1 |
| 334 | .word __bss_start @ r2 | 347 | .word __bss_start @ r2 |
| 335 | .word _end @ r3 | 348 | .word _end @ r3 |
| 336 | .word _start @ r5 | ||
| 337 | .word _edata @ r6 | 349 | .word _edata @ r6 |
| 338 | .word _image_size @ r9 | 350 | .word _image_size @ r9 |
| 339 | .word _got_start @ r11 | 351 | .word _got_start @ r11 |
| @@ -1062,6 +1074,7 @@ memdump: mov r12, r0 | |||
| 1062 | #endif | 1074 | #endif |
| 1063 | 1075 | ||
| 1064 | .ltorg | 1076 | .ltorg |
| 1077 | reloc_code_end: | ||
| 1065 | 1078 | ||
| 1066 | .align | 1079 | .align |
| 1067 | .section ".stack", "aw", %nobits | 1080 | .section ".stack", "aw", %nobits |
diff --git a/arch/arm/boot/compressed/vmlinux.lds.in b/arch/arm/boot/compressed/vmlinux.lds.in index 5309909d7282..ea80abe78844 100644 --- a/arch/arm/boot/compressed/vmlinux.lds.in +++ b/arch/arm/boot/compressed/vmlinux.lds.in | |||
| @@ -54,6 +54,7 @@ SECTIONS | |||
| 54 | .bss : { *(.bss) } | 54 | .bss : { *(.bss) } |
| 55 | _end = .; | 55 | _end = .; |
| 56 | 56 | ||
| 57 | . = ALIGN(8); /* the stack must be 64-bit aligned */ | ||
| 57 | .stack : { *(.stack) } | 58 | .stack : { *(.stack) } |
| 58 | 59 | ||
| 59 | .stab 0 : { *(.stab) } | 60 | .stab 0 : { *(.stab) } |
diff --git a/arch/arm/include/asm/system.h b/arch/arm/include/asm/system.h index 885be097769d..832888d0c20c 100644 --- a/arch/arm/include/asm/system.h +++ b/arch/arm/include/asm/system.h | |||
| @@ -159,7 +159,7 @@ extern unsigned int user_debug; | |||
| 159 | #include <mach/barriers.h> | 159 | #include <mach/barriers.h> |
| 160 | #elif defined(CONFIG_ARM_DMA_MEM_BUFFERABLE) || defined(CONFIG_SMP) | 160 | #elif defined(CONFIG_ARM_DMA_MEM_BUFFERABLE) || defined(CONFIG_SMP) |
| 161 | #define mb() do { dsb(); outer_sync(); } while (0) | 161 | #define mb() do { dsb(); outer_sync(); } while (0) |
| 162 | #define rmb() dmb() | 162 | #define rmb() dsb() |
| 163 | #define wmb() mb() | 163 | #define wmb() mb() |
| 164 | #else | 164 | #else |
| 165 | #include <asm/memory.h> | 165 | #include <asm/memory.h> |
diff --git a/arch/arm/kernel/signal.c b/arch/arm/kernel/signal.c index cb8398317644..0340224cf73c 100644 --- a/arch/arm/kernel/signal.c +++ b/arch/arm/kernel/signal.c | |||
| @@ -597,19 +597,13 @@ setup_rt_frame(int usig, struct k_sigaction *ka, siginfo_t *info, | |||
| 597 | return err; | 597 | return err; |
| 598 | } | 598 | } |
| 599 | 599 | ||
| 600 | static inline void setup_syscall_restart(struct pt_regs *regs) | ||
| 601 | { | ||
| 602 | regs->ARM_r0 = regs->ARM_ORIG_r0; | ||
| 603 | regs->ARM_pc -= thumb_mode(regs) ? 2 : 4; | ||
| 604 | } | ||
| 605 | |||
| 606 | /* | 600 | /* |
| 607 | * OK, we're invoking a handler | 601 | * OK, we're invoking a handler |
| 608 | */ | 602 | */ |
| 609 | static int | 603 | static int |
| 610 | handle_signal(unsigned long sig, struct k_sigaction *ka, | 604 | handle_signal(unsigned long sig, struct k_sigaction *ka, |
| 611 | siginfo_t *info, sigset_t *oldset, | 605 | siginfo_t *info, sigset_t *oldset, |
| 612 | struct pt_regs * regs, int syscall) | 606 | struct pt_regs * regs) |
| 613 | { | 607 | { |
| 614 | struct thread_info *thread = current_thread_info(); | 608 | struct thread_info *thread = current_thread_info(); |
| 615 | struct task_struct *tsk = current; | 609 | struct task_struct *tsk = current; |
| @@ -617,26 +611,6 @@ handle_signal(unsigned long sig, struct k_sigaction *ka, | |||
| 617 | int ret; | 611 | int ret; |
| 618 | 612 | ||
| 619 | /* | 613 | /* |
| 620 | * If we were from a system call, check for system call restarting... | ||
| 621 | */ | ||
| 622 | if (syscall) { | ||
| 623 | switch (regs->ARM_r0) { | ||
| 624 | case -ERESTART_RESTARTBLOCK: | ||
| 625 | case -ERESTARTNOHAND: | ||
| 626 | regs->ARM_r0 = -EINTR; | ||
| 627 | break; | ||
| 628 | case -ERESTARTSYS: | ||
| 629 | if (!(ka->sa.sa_flags & SA_RESTART)) { | ||
| 630 | regs->ARM_r0 = -EINTR; | ||
| 631 | break; | ||
| 632 | } | ||
| 633 | /* fallthrough */ | ||
| 634 | case -ERESTARTNOINTR: | ||
| 635 | setup_syscall_restart(regs); | ||
| 636 | } | ||
| 637 | } | ||
| 638 | |||
| 639 | /* | ||
| 640 | * translate the signal | 614 | * translate the signal |
| 641 | */ | 615 | */ |
| 642 | if (usig < 32 && thread->exec_domain && thread->exec_domain->signal_invmap) | 616 | if (usig < 32 && thread->exec_domain && thread->exec_domain->signal_invmap) |
| @@ -685,6 +659,7 @@ handle_signal(unsigned long sig, struct k_sigaction *ka, | |||
| 685 | */ | 659 | */ |
| 686 | static void do_signal(struct pt_regs *regs, int syscall) | 660 | static void do_signal(struct pt_regs *regs, int syscall) |
| 687 | { | 661 | { |
| 662 | unsigned int retval = 0, continue_addr = 0, restart_addr = 0; | ||
| 688 | struct k_sigaction ka; | 663 | struct k_sigaction ka; |
| 689 | siginfo_t info; | 664 | siginfo_t info; |
| 690 | int signr; | 665 | int signr; |
| @@ -698,18 +673,61 @@ static void do_signal(struct pt_regs *regs, int syscall) | |||
| 698 | if (!user_mode(regs)) | 673 | if (!user_mode(regs)) |
| 699 | return; | 674 | return; |
| 700 | 675 | ||
| 676 | /* | ||
| 677 | * If we were from a system call, check for system call restarting... | ||
| 678 | */ | ||
| 679 | if (syscall) { | ||
| 680 | continue_addr = regs->ARM_pc; | ||
| 681 | restart_addr = continue_addr - (thumb_mode(regs) ? 2 : 4); | ||
| 682 | retval = regs->ARM_r0; | ||
| 683 | |||
| 684 | /* | ||
| 685 | * Prepare for system call restart. We do this here so that a | ||
| 686 | * debugger will see the already changed PSW. | ||
| 687 | */ | ||
| 688 | switch (retval) { | ||
| 689 | case -ERESTARTNOHAND: | ||
| 690 | case -ERESTARTSYS: | ||
| 691 | case -ERESTARTNOINTR: | ||
| 692 | regs->ARM_r0 = regs->ARM_ORIG_r0; | ||
| 693 | regs->ARM_pc = restart_addr; | ||
| 694 | break; | ||
| 695 | case -ERESTART_RESTARTBLOCK: | ||
| 696 | regs->ARM_r0 = -EINTR; | ||
| 697 | break; | ||
| 698 | } | ||
| 699 | } | ||
| 700 | |||
| 701 | if (try_to_freeze()) | 701 | if (try_to_freeze()) |
| 702 | goto no_signal; | 702 | goto no_signal; |
| 703 | 703 | ||
| 704 | /* | ||
| 705 | * Get the signal to deliver. When running under ptrace, at this | ||
| 706 | * point the debugger may change all our registers ... | ||
| 707 | */ | ||
| 704 | signr = get_signal_to_deliver(&info, &ka, regs, NULL); | 708 | signr = get_signal_to_deliver(&info, &ka, regs, NULL); |
| 705 | if (signr > 0) { | 709 | if (signr > 0) { |
| 706 | sigset_t *oldset; | 710 | sigset_t *oldset; |
| 707 | 711 | ||
| 712 | /* | ||
| 713 | * Depending on the signal settings we may need to revert the | ||
| 714 | * decision to restart the system call. But skip this if a | ||
| 715 | * debugger has chosen to restart at a different PC. | ||
| 716 | */ | ||
| 717 | if (regs->ARM_pc == restart_addr) { | ||
| 718 | if (retval == -ERESTARTNOHAND | ||
| 719 | || (retval == -ERESTARTSYS | ||
| 720 | && !(ka.sa.sa_flags & SA_RESTART))) { | ||
| 721 | regs->ARM_r0 = -EINTR; | ||
| 722 | regs->ARM_pc = continue_addr; | ||
| 723 | } | ||
| 724 | } | ||
| 725 | |||
| 708 | if (test_thread_flag(TIF_RESTORE_SIGMASK)) | 726 | if (test_thread_flag(TIF_RESTORE_SIGMASK)) |
| 709 | oldset = ¤t->saved_sigmask; | 727 | oldset = ¤t->saved_sigmask; |
| 710 | else | 728 | else |
| 711 | oldset = ¤t->blocked; | 729 | oldset = ¤t->blocked; |
| 712 | if (handle_signal(signr, &ka, &info, oldset, regs, syscall) == 0) { | 730 | if (handle_signal(signr, &ka, &info, oldset, regs) == 0) { |
| 713 | /* | 731 | /* |
| 714 | * A signal was successfully delivered; the saved | 732 | * A signal was successfully delivered; the saved |
| 715 | * sigmask will have been stored in the signal frame, | 733 | * sigmask will have been stored in the signal frame, |
| @@ -723,11 +741,14 @@ static void do_signal(struct pt_regs *regs, int syscall) | |||
| 723 | } | 741 | } |
| 724 | 742 | ||
| 725 | no_signal: | 743 | no_signal: |
| 726 | /* | ||
| 727 | * No signal to deliver to the process - restart the syscall. | ||
| 728 | */ | ||
| 729 | if (syscall) { | 744 | if (syscall) { |
| 730 | if (regs->ARM_r0 == -ERESTART_RESTARTBLOCK) { | 745 | /* |
| 746 | * Handle restarting a different system call. As above, | ||
| 747 | * if a debugger has chosen to restart at a different PC, | ||
| 748 | * ignore the restart. | ||
| 749 | */ | ||
| 750 | if (retval == -ERESTART_RESTARTBLOCK | ||
| 751 | && regs->ARM_pc == continue_addr) { | ||
| 731 | if (thumb_mode(regs)) { | 752 | if (thumb_mode(regs)) { |
| 732 | regs->ARM_r7 = __NR_restart_syscall - __NR_SYSCALL_BASE; | 753 | regs->ARM_r7 = __NR_restart_syscall - __NR_SYSCALL_BASE; |
| 733 | regs->ARM_pc -= 2; | 754 | regs->ARM_pc -= 2; |
| @@ -750,11 +771,6 @@ static void do_signal(struct pt_regs *regs, int syscall) | |||
| 750 | #endif | 771 | #endif |
| 751 | } | 772 | } |
| 752 | } | 773 | } |
| 753 | if (regs->ARM_r0 == -ERESTARTNOHAND || | ||
| 754 | regs->ARM_r0 == -ERESTARTSYS || | ||
| 755 | regs->ARM_r0 == -ERESTARTNOINTR) { | ||
| 756 | setup_syscall_restart(regs); | ||
| 757 | } | ||
| 758 | 774 | ||
| 759 | /* If there's no signal to deliver, we just put the saved sigmask | 775 | /* If there's no signal to deliver, we just put the saved sigmask |
| 760 | * back. | 776 | * back. |
diff --git a/arch/arm/mach-omap2/clkt34xx_dpll3m2.c b/arch/arm/mach-omap2/clkt34xx_dpll3m2.c index b2b1e37bb6bb..d6e34dd9e7e7 100644 --- a/arch/arm/mach-omap2/clkt34xx_dpll3m2.c +++ b/arch/arm/mach-omap2/clkt34xx_dpll3m2.c | |||
| @@ -115,6 +115,7 @@ int omap3_core_dpll_m2_set_rate(struct clk *clk, unsigned long rate) | |||
| 115 | sdrc_cs0->rfr_ctrl, sdrc_cs0->actim_ctrla, | 115 | sdrc_cs0->rfr_ctrl, sdrc_cs0->actim_ctrla, |
| 116 | sdrc_cs0->actim_ctrlb, sdrc_cs0->mr, | 116 | sdrc_cs0->actim_ctrlb, sdrc_cs0->mr, |
| 117 | 0, 0, 0, 0); | 117 | 0, 0, 0, 0); |
| 118 | clk->rate = rate; | ||
| 118 | 119 | ||
| 119 | return 0; | 120 | return 0; |
| 120 | } | 121 | } |
diff --git a/arch/arm/mach-realview/include/mach/barriers.h b/arch/arm/mach-realview/include/mach/barriers.h index 0c5d749d7b5f..9a732195aa1c 100644 --- a/arch/arm/mach-realview/include/mach/barriers.h +++ b/arch/arm/mach-realview/include/mach/barriers.h | |||
| @@ -4,5 +4,5 @@ | |||
| 4 | * operation to deadlock the system. | 4 | * operation to deadlock the system. |
| 5 | */ | 5 | */ |
| 6 | #define mb() dsb() | 6 | #define mb() dsb() |
| 7 | #define rmb() dmb() | 7 | #define rmb() dsb() |
| 8 | #define wmb() mb() | 8 | #define wmb() mb() |
diff --git a/arch/arm/mach-tegra/include/mach/barriers.h b/arch/arm/mach-tegra/include/mach/barriers.h index cc115174899b..425b42e91ef6 100644 --- a/arch/arm/mach-tegra/include/mach/barriers.h +++ b/arch/arm/mach-tegra/include/mach/barriers.h | |||
| @@ -23,7 +23,7 @@ | |||
| 23 | 23 | ||
| 24 | #include <asm/outercache.h> | 24 | #include <asm/outercache.h> |
| 25 | 25 | ||
| 26 | #define rmb() dmb() | 26 | #define rmb() dsb() |
| 27 | #define wmb() do { dsb(); outer_sync(); } while (0) | 27 | #define wmb() do { dsb(); outer_sync(); } while (0) |
| 28 | #define mb() wmb() | 28 | #define mb() wmb() |
| 29 | 29 | ||
diff --git a/arch/arm/mm/init.c b/arch/arm/mm/init.c index e5f6fc428348..e591513bb53e 100644 --- a/arch/arm/mm/init.c +++ b/arch/arm/mm/init.c | |||
| @@ -392,7 +392,7 @@ free_memmap(unsigned long start_pfn, unsigned long end_pfn) | |||
| 392 | * Convert start_pfn/end_pfn to a struct page pointer. | 392 | * Convert start_pfn/end_pfn to a struct page pointer. |
| 393 | */ | 393 | */ |
| 394 | start_pg = pfn_to_page(start_pfn - 1) + 1; | 394 | start_pg = pfn_to_page(start_pfn - 1) + 1; |
| 395 | end_pg = pfn_to_page(end_pfn); | 395 | end_pg = pfn_to_page(end_pfn - 1) + 1; |
| 396 | 396 | ||
| 397 | /* | 397 | /* |
| 398 | * Convert to physical addresses, and | 398 | * Convert to physical addresses, and |
| @@ -426,6 +426,14 @@ static void __init free_unused_memmap(struct meminfo *mi) | |||
| 426 | 426 | ||
| 427 | bank_start = bank_pfn_start(bank); | 427 | bank_start = bank_pfn_start(bank); |
| 428 | 428 | ||
| 429 | #ifdef CONFIG_SPARSEMEM | ||
| 430 | /* | ||
| 431 | * Take care not to free memmap entries that don't exist | ||
| 432 | * due to SPARSEMEM sections which aren't present. | ||
| 433 | */ | ||
| 434 | bank_start = min(bank_start, | ||
| 435 | ALIGN(prev_bank_end, PAGES_PER_SECTION)); | ||
| 436 | #endif | ||
| 429 | /* | 437 | /* |
| 430 | * If we had a previous bank, and there is a space | 438 | * If we had a previous bank, and there is a space |
| 431 | * between the current bank and the previous, free it. | 439 | * between the current bank and the previous, free it. |
| @@ -440,6 +448,12 @@ static void __init free_unused_memmap(struct meminfo *mi) | |||
| 440 | */ | 448 | */ |
| 441 | prev_bank_end = ALIGN(bank_pfn_end(bank), MAX_ORDER_NR_PAGES); | 449 | prev_bank_end = ALIGN(bank_pfn_end(bank), MAX_ORDER_NR_PAGES); |
| 442 | } | 450 | } |
| 451 | |||
| 452 | #ifdef CONFIG_SPARSEMEM | ||
| 453 | if (!IS_ALIGNED(prev_bank_end, PAGES_PER_SECTION)) | ||
| 454 | free_memmap(prev_bank_end, | ||
| 455 | ALIGN(prev_bank_end, PAGES_PER_SECTION)); | ||
| 456 | #endif | ||
| 443 | } | 457 | } |
| 444 | 458 | ||
| 445 | static void __init free_highpages(void) | 459 | static void __init free_highpages(void) |
diff --git a/arch/arm/plat-omap/iommu.c b/arch/arm/plat-omap/iommu.c index 8a51fd58f656..34fc31ee9081 100644 --- a/arch/arm/plat-omap/iommu.c +++ b/arch/arm/plat-omap/iommu.c | |||
| @@ -793,6 +793,8 @@ static irqreturn_t iommu_fault_handler(int irq, void *data) | |||
| 793 | clk_enable(obj->clk); | 793 | clk_enable(obj->clk); |
| 794 | errs = iommu_report_fault(obj, &da); | 794 | errs = iommu_report_fault(obj, &da); |
| 795 | clk_disable(obj->clk); | 795 | clk_disable(obj->clk); |
| 796 | if (errs == 0) | ||
| 797 | return IRQ_HANDLED; | ||
| 796 | 798 | ||
| 797 | /* Fault callback or TLB/PTE Dynamic loading */ | 799 | /* Fault callback or TLB/PTE Dynamic loading */ |
| 798 | if (obj->isr && !obj->isr(obj, da, errs, obj->isr_priv)) | 800 | if (obj->isr && !obj->isr(obj, da, errs, obj->isr_priv)) |
diff --git a/arch/mips/Kconfig b/arch/mips/Kconfig index 8e256cc5dcd9..351c80fbba7e 100644 --- a/arch/mips/Kconfig +++ b/arch/mips/Kconfig | |||
| @@ -997,9 +997,6 @@ config IRQ_GT641XX | |||
| 997 | config IRQ_GIC | 997 | config IRQ_GIC |
| 998 | bool | 998 | bool |
| 999 | 999 | ||
| 1000 | config IRQ_CPU_OCTEON | ||
| 1001 | bool | ||
| 1002 | |||
| 1003 | config MIPS_BOARDS_GEN | 1000 | config MIPS_BOARDS_GEN |
| 1004 | bool | 1001 | bool |
| 1005 | 1002 | ||
| @@ -1359,8 +1356,6 @@ config CPU_SB1 | |||
| 1359 | config CPU_CAVIUM_OCTEON | 1356 | config CPU_CAVIUM_OCTEON |
| 1360 | bool "Cavium Octeon processor" | 1357 | bool "Cavium Octeon processor" |
| 1361 | depends on SYS_HAS_CPU_CAVIUM_OCTEON | 1358 | depends on SYS_HAS_CPU_CAVIUM_OCTEON |
| 1362 | select IRQ_CPU | ||
| 1363 | select IRQ_CPU_OCTEON | ||
| 1364 | select CPU_HAS_PREFETCH | 1359 | select CPU_HAS_PREFETCH |
| 1365 | select CPU_SUPPORTS_64BIT_KERNEL | 1360 | select CPU_SUPPORTS_64BIT_KERNEL |
| 1366 | select SYS_SUPPORTS_SMP | 1361 | select SYS_SUPPORTS_SMP |
diff --git a/arch/mips/alchemy/devboards/db1x00/board_setup.c b/arch/mips/alchemy/devboards/db1x00/board_setup.c index 05f120ff90f9..5c956fe8760f 100644 --- a/arch/mips/alchemy/devboards/db1x00/board_setup.c +++ b/arch/mips/alchemy/devboards/db1x00/board_setup.c | |||
| @@ -127,13 +127,10 @@ const char *get_system_type(void) | |||
| 127 | void __init board_setup(void) | 127 | void __init board_setup(void) |
| 128 | { | 128 | { |
| 129 | unsigned long bcsr1, bcsr2; | 129 | unsigned long bcsr1, bcsr2; |
| 130 | u32 pin_func; | ||
| 131 | 130 | ||
| 132 | bcsr1 = DB1000_BCSR_PHYS_ADDR; | 131 | bcsr1 = DB1000_BCSR_PHYS_ADDR; |
| 133 | bcsr2 = DB1000_BCSR_PHYS_ADDR + DB1000_BCSR_HEXLED_OFS; | 132 | bcsr2 = DB1000_BCSR_PHYS_ADDR + DB1000_BCSR_HEXLED_OFS; |
| 134 | 133 | ||
| 135 | pin_func = 0; | ||
| 136 | |||
| 137 | #ifdef CONFIG_MIPS_DB1000 | 134 | #ifdef CONFIG_MIPS_DB1000 |
| 138 | printk(KERN_INFO "AMD Alchemy Au1000/Db1000 Board\n"); | 135 | printk(KERN_INFO "AMD Alchemy Au1000/Db1000 Board\n"); |
| 139 | #endif | 136 | #endif |
| @@ -164,12 +161,16 @@ void __init board_setup(void) | |||
| 164 | /* Not valid for Au1550 */ | 161 | /* Not valid for Au1550 */ |
| 165 | #if defined(CONFIG_IRDA) && \ | 162 | #if defined(CONFIG_IRDA) && \ |
| 166 | (defined(CONFIG_SOC_AU1000) || defined(CONFIG_SOC_AU1100)) | 163 | (defined(CONFIG_SOC_AU1000) || defined(CONFIG_SOC_AU1100)) |
| 167 | /* Set IRFIRSEL instead of GPIO15 */ | 164 | { |
| 168 | pin_func = au_readl(SYS_PINFUNC) | SYS_PF_IRF; | 165 | u32 pin_func; |
| 169 | au_writel(pin_func, SYS_PINFUNC); | 166 | |
| 170 | /* Power off until the driver is in use */ | 167 | /* Set IRFIRSEL instead of GPIO15 */ |
| 171 | bcsr_mod(BCSR_RESETS, BCSR_RESETS_IRDA_MODE_MASK, | 168 | pin_func = au_readl(SYS_PINFUNC) | SYS_PF_IRF; |
| 172 | BCSR_RESETS_IRDA_MODE_OFF); | 169 | au_writel(pin_func, SYS_PINFUNC); |
| 170 | /* Power off until the driver is in use */ | ||
| 171 | bcsr_mod(BCSR_RESETS, BCSR_RESETS_IRDA_MODE_MASK, | ||
| 172 | BCSR_RESETS_IRDA_MODE_OFF); | ||
| 173 | } | ||
| 173 | #endif | 174 | #endif |
| 174 | bcsr_write(BCSR_PCMCIA, 0); /* turn off PCMCIA power */ | 175 | bcsr_write(BCSR_PCMCIA, 0); /* turn off PCMCIA power */ |
| 175 | 176 | ||
| @@ -177,31 +178,35 @@ void __init board_setup(void) | |||
| 177 | alchemy_gpio1_input_enable(); | 178 | alchemy_gpio1_input_enable(); |
| 178 | 179 | ||
| 179 | #ifdef CONFIG_MIPS_MIRAGE | 180 | #ifdef CONFIG_MIPS_MIRAGE |
| 180 | /* GPIO[20] is output */ | 181 | { |
| 181 | alchemy_gpio_direction_output(20, 0); | 182 | u32 pin_func; |
| 182 | 183 | ||
| 183 | /* Set GPIO[210:208] instead of SSI_0 */ | 184 | /* GPIO[20] is output */ |
| 184 | pin_func = au_readl(SYS_PINFUNC) | SYS_PF_S0; | 185 | alchemy_gpio_direction_output(20, 0); |
| 185 | 186 | ||
| 186 | /* Set GPIO[215:211] for LEDs */ | 187 | /* Set GPIO[210:208] instead of SSI_0 */ |
| 187 | pin_func |= 5 << 2; | 188 | pin_func = au_readl(SYS_PINFUNC) | SYS_PF_S0; |
| 188 | 189 | ||
| 189 | /* Set GPIO[214:213] for more LEDs */ | 190 | /* Set GPIO[215:211] for LEDs */ |
| 190 | pin_func |= 5 << 12; | 191 | pin_func |= 5 << 2; |
| 191 | 192 | ||
| 192 | /* Set GPIO[207:200] instead of PCMCIA/LCD */ | 193 | /* Set GPIO[214:213] for more LEDs */ |
| 193 | pin_func |= SYS_PF_LCD | SYS_PF_PC; | 194 | pin_func |= 5 << 12; |
| 194 | au_writel(pin_func, SYS_PINFUNC); | ||
| 195 | 195 | ||
| 196 | /* | 196 | /* Set GPIO[207:200] instead of PCMCIA/LCD */ |
| 197 | * Enable speaker amplifier. This should | 197 | pin_func |= SYS_PF_LCD | SYS_PF_PC; |
| 198 | * be part of the audio driver. | 198 | au_writel(pin_func, SYS_PINFUNC); |
| 199 | */ | ||
| 200 | alchemy_gpio_direction_output(209, 1); | ||
| 201 | 199 | ||
| 202 | pm_power_off = mirage_power_off; | 200 | /* |
| 203 | _machine_halt = mirage_power_off; | 201 | * Enable speaker amplifier. This should |
| 204 | _machine_restart = (void(*)(char *))mips_softreset; | 202 | * be part of the audio driver. |
| 203 | */ | ||
| 204 | alchemy_gpio_direction_output(209, 1); | ||
| 205 | |||
| 206 | pm_power_off = mirage_power_off; | ||
| 207 | _machine_halt = mirage_power_off; | ||
| 208 | _machine_restart = (void(*)(char *))mips_softreset; | ||
| 209 | } | ||
| 205 | #endif | 210 | #endif |
| 206 | 211 | ||
| 207 | #ifdef CONFIG_MIPS_BOSPORUS | 212 | #ifdef CONFIG_MIPS_BOSPORUS |
diff --git a/arch/mips/alchemy/xxs1500/init.c b/arch/mips/alchemy/xxs1500/init.c index 15125c2fda7d..34a90a4bb6f4 100644 --- a/arch/mips/alchemy/xxs1500/init.c +++ b/arch/mips/alchemy/xxs1500/init.c | |||
| @@ -51,10 +51,9 @@ void __init prom_init(void) | |||
| 51 | prom_init_cmdline(); | 51 | prom_init_cmdline(); |
| 52 | 52 | ||
| 53 | memsize_str = prom_getenv("memsize"); | 53 | memsize_str = prom_getenv("memsize"); |
| 54 | if (!memsize_str) | 54 | if (!memsize_str || strict_strtoul(memsize_str, 0, &memsize)) |
| 55 | memsize = 0x04000000; | 55 | memsize = 0x04000000; |
| 56 | else | 56 | |
| 57 | strict_strtoul(memsize_str, 0, &memsize); | ||
| 58 | add_memory_region(0, memsize, BOOT_MEM_RAM); | 57 | add_memory_region(0, memsize, BOOT_MEM_RAM); |
| 59 | } | 58 | } |
| 60 | 59 | ||
diff --git a/arch/mips/boot/compressed/calc_vmlinuz_load_addr.c b/arch/mips/boot/compressed/calc_vmlinuz_load_addr.c index 88c9d963be88..9a6243676e22 100644 --- a/arch/mips/boot/compressed/calc_vmlinuz_load_addr.c +++ b/arch/mips/boot/compressed/calc_vmlinuz_load_addr.c | |||
| @@ -16,8 +16,8 @@ | |||
| 16 | 16 | ||
| 17 | int main(int argc, char *argv[]) | 17 | int main(int argc, char *argv[]) |
| 18 | { | 18 | { |
| 19 | unsigned long long vmlinux_size, vmlinux_load_addr, vmlinuz_load_addr; | ||
| 19 | struct stat sb; | 20 | struct stat sb; |
| 20 | uint64_t vmlinux_size, vmlinux_load_addr, vmlinuz_load_addr; | ||
| 21 | 21 | ||
| 22 | if (argc != 3) { | 22 | if (argc != 3) { |
| 23 | fprintf(stderr, "Usage: %s <pathname> <vmlinux_load_addr>\n", | 23 | fprintf(stderr, "Usage: %s <pathname> <vmlinux_load_addr>\n", |
diff --git a/arch/mips/cavium-octeon/Kconfig b/arch/mips/cavium-octeon/Kconfig index caae22858163..cad555ebeca3 100644 --- a/arch/mips/cavium-octeon/Kconfig +++ b/arch/mips/cavium-octeon/Kconfig | |||
| @@ -1,11 +1,7 @@ | |||
| 1 | config CAVIUM_OCTEON_SPECIFIC_OPTIONS | 1 | if CPU_CAVIUM_OCTEON |
| 2 | bool "Enable Octeon specific options" | ||
| 3 | depends on CPU_CAVIUM_OCTEON | ||
| 4 | default "y" | ||
| 5 | 2 | ||
| 6 | config CAVIUM_CN63XXP1 | 3 | config CAVIUM_CN63XXP1 |
| 7 | bool "Enable CN63XXP1 errata worarounds" | 4 | bool "Enable CN63XXP1 errata worarounds" |
| 8 | depends on CAVIUM_OCTEON_SPECIFIC_OPTIONS | ||
| 9 | default "n" | 5 | default "n" |
| 10 | help | 6 | help |
| 11 | The CN63XXP1 chip requires build time workarounds to | 7 | The CN63XXP1 chip requires build time workarounds to |
| @@ -16,7 +12,6 @@ config CAVIUM_CN63XXP1 | |||
| 16 | 12 | ||
| 17 | config CAVIUM_OCTEON_2ND_KERNEL | 13 | config CAVIUM_OCTEON_2ND_KERNEL |
| 18 | bool "Build the kernel to be used as a 2nd kernel on the same chip" | 14 | bool "Build the kernel to be used as a 2nd kernel on the same chip" |
| 19 | depends on CAVIUM_OCTEON_SPECIFIC_OPTIONS | ||
| 20 | default "n" | 15 | default "n" |
| 21 | help | 16 | help |
| 22 | This option configures this kernel to be linked at a different | 17 | This option configures this kernel to be linked at a different |
| @@ -26,7 +21,6 @@ config CAVIUM_OCTEON_2ND_KERNEL | |||
| 26 | 21 | ||
| 27 | config CAVIUM_OCTEON_HW_FIX_UNALIGNED | 22 | config CAVIUM_OCTEON_HW_FIX_UNALIGNED |
| 28 | bool "Enable hardware fixups of unaligned loads and stores" | 23 | bool "Enable hardware fixups of unaligned loads and stores" |
| 29 | depends on CAVIUM_OCTEON_SPECIFIC_OPTIONS | ||
| 30 | default "y" | 24 | default "y" |
| 31 | help | 25 | help |
| 32 | Configure the Octeon hardware to automatically fix unaligned loads | 26 | Configure the Octeon hardware to automatically fix unaligned loads |
| @@ -38,7 +32,6 @@ config CAVIUM_OCTEON_HW_FIX_UNALIGNED | |||
| 38 | 32 | ||
| 39 | config CAVIUM_OCTEON_CVMSEG_SIZE | 33 | config CAVIUM_OCTEON_CVMSEG_SIZE |
| 40 | int "Number of L1 cache lines reserved for CVMSEG memory" | 34 | int "Number of L1 cache lines reserved for CVMSEG memory" |
| 41 | depends on CAVIUM_OCTEON_SPECIFIC_OPTIONS | ||
| 42 | range 0 54 | 35 | range 0 54 |
| 43 | default 1 | 36 | default 1 |
| 44 | help | 37 | help |
| @@ -50,7 +43,6 @@ config CAVIUM_OCTEON_CVMSEG_SIZE | |||
| 50 | 43 | ||
| 51 | config CAVIUM_OCTEON_LOCK_L2 | 44 | config CAVIUM_OCTEON_LOCK_L2 |
| 52 | bool "Lock often used kernel code in the L2" | 45 | bool "Lock often used kernel code in the L2" |
| 53 | depends on CAVIUM_OCTEON_SPECIFIC_OPTIONS | ||
| 54 | default "y" | 46 | default "y" |
| 55 | help | 47 | help |
| 56 | Enable locking parts of the kernel into the L2 cache. | 48 | Enable locking parts of the kernel into the L2 cache. |
| @@ -93,7 +85,6 @@ config CAVIUM_OCTEON_LOCK_L2_MEMCPY | |||
| 93 | config ARCH_SPARSEMEM_ENABLE | 85 | config ARCH_SPARSEMEM_ENABLE |
| 94 | def_bool y | 86 | def_bool y |
| 95 | select SPARSEMEM_STATIC | 87 | select SPARSEMEM_STATIC |
| 96 | depends on CPU_CAVIUM_OCTEON | ||
| 97 | 88 | ||
| 98 | config CAVIUM_OCTEON_HELPER | 89 | config CAVIUM_OCTEON_HELPER |
| 99 | def_bool y | 90 | def_bool y |
| @@ -107,6 +98,8 @@ config NEED_SG_DMA_LENGTH | |||
| 107 | 98 | ||
| 108 | config SWIOTLB | 99 | config SWIOTLB |
| 109 | def_bool y | 100 | def_bool y |
| 110 | depends on CPU_CAVIUM_OCTEON | ||
| 111 | select IOMMU_HELPER | 101 | select IOMMU_HELPER |
| 112 | select NEED_SG_DMA_LENGTH | 102 | select NEED_SG_DMA_LENGTH |
| 103 | |||
| 104 | |||
| 105 | endif # CPU_CAVIUM_OCTEON | ||
diff --git a/arch/mips/include/asm/cache.h b/arch/mips/include/asm/cache.h index 650ac9ba734c..b4db69fbc40c 100644 --- a/arch/mips/include/asm/cache.h +++ b/arch/mips/include/asm/cache.h | |||
| @@ -17,6 +17,6 @@ | |||
| 17 | #define SMP_CACHE_SHIFT L1_CACHE_SHIFT | 17 | #define SMP_CACHE_SHIFT L1_CACHE_SHIFT |
| 18 | #define SMP_CACHE_BYTES L1_CACHE_BYTES | 18 | #define SMP_CACHE_BYTES L1_CACHE_BYTES |
| 19 | 19 | ||
| 20 | #define __read_mostly __attribute__((__section__(".data.read_mostly"))) | 20 | #define __read_mostly __attribute__((__section__(".data..read_mostly"))) |
| 21 | 21 | ||
| 22 | #endif /* _ASM_CACHE_H */ | 22 | #endif /* _ASM_CACHE_H */ |
diff --git a/arch/mips/include/asm/cevt-r4k.h b/arch/mips/include/asm/cevt-r4k.h index fa4328f9124f..65f9bdd02f1f 100644 --- a/arch/mips/include/asm/cevt-r4k.h +++ b/arch/mips/include/asm/cevt-r4k.h | |||
| @@ -14,6 +14,9 @@ | |||
| 14 | #ifndef __ASM_CEVT_R4K_H | 14 | #ifndef __ASM_CEVT_R4K_H |
| 15 | #define __ASM_CEVT_R4K_H | 15 | #define __ASM_CEVT_R4K_H |
| 16 | 16 | ||
| 17 | #include <linux/clockchips.h> | ||
| 18 | #include <asm/time.h> | ||
| 19 | |||
| 17 | DECLARE_PER_CPU(struct clock_event_device, mips_clockevent_device); | 20 | DECLARE_PER_CPU(struct clock_event_device, mips_clockevent_device); |
| 18 | 21 | ||
| 19 | void mips_event_handler(struct clock_event_device *dev); | 22 | void mips_event_handler(struct clock_event_device *dev); |
diff --git a/arch/mips/include/asm/hugetlb.h b/arch/mips/include/asm/hugetlb.h index f5e856015329..c565b7c3f0b5 100644 --- a/arch/mips/include/asm/hugetlb.h +++ b/arch/mips/include/asm/hugetlb.h | |||
| @@ -70,6 +70,7 @@ static inline pte_t huge_ptep_get_and_clear(struct mm_struct *mm, | |||
| 70 | static inline void huge_ptep_clear_flush(struct vm_area_struct *vma, | 70 | static inline void huge_ptep_clear_flush(struct vm_area_struct *vma, |
| 71 | unsigned long addr, pte_t *ptep) | 71 | unsigned long addr, pte_t *ptep) |
| 72 | { | 72 | { |
| 73 | flush_tlb_mm(vma->vm_mm); | ||
| 73 | } | 74 | } |
| 74 | 75 | ||
| 75 | static inline int huge_pte_none(pte_t pte) | 76 | static inline int huge_pte_none(pte_t pte) |
diff --git a/arch/mips/include/asm/mach-bcm63xx/bcm963xx_tag.h b/arch/mips/include/asm/mach-bcm63xx/bcm963xx_tag.h index 32978d32561a..ed72e6a26b73 100644 --- a/arch/mips/include/asm/mach-bcm63xx/bcm963xx_tag.h +++ b/arch/mips/include/asm/mach-bcm63xx/bcm963xx_tag.h | |||
| @@ -88,7 +88,7 @@ struct bcm_tag { | |||
| 88 | char kernel_crc[CRC_LEN]; | 88 | char kernel_crc[CRC_LEN]; |
| 89 | /* 228-235: Unused at present */ | 89 | /* 228-235: Unused at present */ |
| 90 | char reserved1[8]; | 90 | char reserved1[8]; |
| 91 | /* 236-239: CRC32 of header excluding tagVersion */ | 91 | /* 236-239: CRC32 of header excluding last 20 bytes */ |
| 92 | char header_crc[CRC_LEN]; | 92 | char header_crc[CRC_LEN]; |
| 93 | /* 240-255: Unused at present */ | 93 | /* 240-255: Unused at present */ |
| 94 | char reserved2[16]; | 94 | char reserved2[16]; |
diff --git a/arch/mips/jazz/jazzdma.c b/arch/mips/jazz/jazzdma.c index 9ce9f64cb76f..2d8e447cb828 100644 --- a/arch/mips/jazz/jazzdma.c +++ b/arch/mips/jazz/jazzdma.c | |||
| @@ -211,7 +211,7 @@ EXPORT_SYMBOL(vdma_free); | |||
| 211 | */ | 211 | */ |
| 212 | int vdma_remap(unsigned long laddr, unsigned long paddr, unsigned long size) | 212 | int vdma_remap(unsigned long laddr, unsigned long paddr, unsigned long size) |
| 213 | { | 213 | { |
| 214 | int first, pages, npages; | 214 | int first, pages; |
| 215 | 215 | ||
| 216 | if (laddr > 0xffffff) { | 216 | if (laddr > 0xffffff) { |
| 217 | if (vdma_debug) | 217 | if (vdma_debug) |
| @@ -228,8 +228,7 @@ int vdma_remap(unsigned long laddr, unsigned long paddr, unsigned long size) | |||
| 228 | return -EINVAL; /* invalid physical address */ | 228 | return -EINVAL; /* invalid physical address */ |
| 229 | } | 229 | } |
| 230 | 230 | ||
| 231 | npages = pages = | 231 | pages = (((paddr & (VDMA_PAGESIZE - 1)) + size) >> 12) + 1; |
| 232 | (((paddr & (VDMA_PAGESIZE - 1)) + size) >> 12) + 1; | ||
| 233 | first = laddr >> 12; | 232 | first = laddr >> 12; |
| 234 | if (vdma_debug) | 233 | if (vdma_debug) |
| 235 | printk("vdma_remap: first=%x, pages=%x\n", first, pages); | 234 | printk("vdma_remap: first=%x, pages=%x\n", first, pages); |
diff --git a/arch/mips/jz4740/dma.c b/arch/mips/jz4740/dma.c index 5ebe75a68350..d7feb898692c 100644 --- a/arch/mips/jz4740/dma.c +++ b/arch/mips/jz4740/dma.c | |||
| @@ -242,9 +242,7 @@ EXPORT_SYMBOL_GPL(jz4740_dma_get_residue); | |||
| 242 | 242 | ||
| 243 | static void jz4740_dma_chan_irq(struct jz4740_dma_chan *dma) | 243 | static void jz4740_dma_chan_irq(struct jz4740_dma_chan *dma) |
| 244 | { | 244 | { |
| 245 | uint32_t status; | 245 | (void) jz4740_dma_read(JZ_REG_DMA_STATUS_CTRL(dma->id)); |
| 246 | |||
| 247 | status = jz4740_dma_read(JZ_REG_DMA_STATUS_CTRL(dma->id)); | ||
| 248 | 246 | ||
| 249 | jz4740_dma_write_mask(JZ_REG_DMA_STATUS_CTRL(dma->id), 0, | 247 | jz4740_dma_write_mask(JZ_REG_DMA_STATUS_CTRL(dma->id), 0, |
| 250 | JZ_DMA_STATUS_CTRL_ENABLE | JZ_DMA_STATUS_CTRL_TRANSFER_DONE); | 248 | JZ_DMA_STATUS_CTRL_ENABLE | JZ_DMA_STATUS_CTRL_TRANSFER_DONE); |
diff --git a/arch/mips/jz4740/time.c b/arch/mips/jz4740/time.c index fe01678d94fd..eaa853a54af6 100644 --- a/arch/mips/jz4740/time.c +++ b/arch/mips/jz4740/time.c | |||
| @@ -89,7 +89,7 @@ static int jz4740_clockevent_set_next(unsigned long evt, | |||
| 89 | 89 | ||
| 90 | static struct clock_event_device jz4740_clockevent = { | 90 | static struct clock_event_device jz4740_clockevent = { |
| 91 | .name = "jz4740-timer", | 91 | .name = "jz4740-timer", |
| 92 | .features = CLOCK_EVT_FEAT_PERIODIC, | 92 | .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, |
| 93 | .set_next_event = jz4740_clockevent_set_next, | 93 | .set_next_event = jz4740_clockevent_set_next, |
| 94 | .set_mode = jz4740_clockevent_set_mode, | 94 | .set_mode = jz4740_clockevent_set_mode, |
| 95 | .rating = 200, | 95 | .rating = 200, |
diff --git a/arch/mips/jz4740/timer.c b/arch/mips/jz4740/timer.c index b2c015129055..654d5c3900b6 100644 --- a/arch/mips/jz4740/timer.c +++ b/arch/mips/jz4740/timer.c | |||
| @@ -27,11 +27,13 @@ void jz4740_timer_enable_watchdog(void) | |||
| 27 | { | 27 | { |
| 28 | writel(BIT(16), jz4740_timer_base + JZ_REG_TIMER_STOP_CLEAR); | 28 | writel(BIT(16), jz4740_timer_base + JZ_REG_TIMER_STOP_CLEAR); |
| 29 | } | 29 | } |
| 30 | EXPORT_SYMBOL_GPL(jz4740_timer_enable_watchdog); | ||
| 30 | 31 | ||
| 31 | void jz4740_timer_disable_watchdog(void) | 32 | void jz4740_timer_disable_watchdog(void) |
| 32 | { | 33 | { |
| 33 | writel(BIT(16), jz4740_timer_base + JZ_REG_TIMER_STOP_SET); | 34 | writel(BIT(16), jz4740_timer_base + JZ_REG_TIMER_STOP_SET); |
| 34 | } | 35 | } |
| 36 | EXPORT_SYMBOL_GPL(jz4740_timer_disable_watchdog); | ||
| 35 | 37 | ||
| 36 | void __init jz4740_timer_init(void) | 38 | void __init jz4740_timer_init(void) |
| 37 | { | 39 | { |
diff --git a/arch/mips/kernel/ftrace.c b/arch/mips/kernel/ftrace.c index 94ca2b018af7..feb8021a305f 100644 --- a/arch/mips/kernel/ftrace.c +++ b/arch/mips/kernel/ftrace.c | |||
| @@ -23,6 +23,7 @@ | |||
| 23 | 23 | ||
| 24 | #define JAL 0x0c000000 /* jump & link: ip --> ra, jump to target */ | 24 | #define JAL 0x0c000000 /* jump & link: ip --> ra, jump to target */ |
| 25 | #define ADDR_MASK 0x03ffffff /* op_code|addr : 31...26|25 ....0 */ | 25 | #define ADDR_MASK 0x03ffffff /* op_code|addr : 31...26|25 ....0 */ |
| 26 | #define JUMP_RANGE_MASK ((1UL << 28) - 1) | ||
| 26 | 27 | ||
| 27 | #define INSN_NOP 0x00000000 /* nop */ | 28 | #define INSN_NOP 0x00000000 /* nop */ |
| 28 | #define INSN_JAL(addr) \ | 29 | #define INSN_JAL(addr) \ |
| @@ -44,12 +45,12 @@ static inline void ftrace_dyn_arch_init_insns(void) | |||
| 44 | 45 | ||
| 45 | /* jal (ftrace_caller + 8), jump over the first two instruction */ | 46 | /* jal (ftrace_caller + 8), jump over the first two instruction */ |
| 46 | buf = (u32 *)&insn_jal_ftrace_caller; | 47 | buf = (u32 *)&insn_jal_ftrace_caller; |
| 47 | uasm_i_jal(&buf, (FTRACE_ADDR + 8)); | 48 | uasm_i_jal(&buf, (FTRACE_ADDR + 8) & JUMP_RANGE_MASK); |
| 48 | 49 | ||
| 49 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER | 50 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER |
| 50 | /* j ftrace_graph_caller */ | 51 | /* j ftrace_graph_caller */ |
| 51 | buf = (u32 *)&insn_j_ftrace_graph_caller; | 52 | buf = (u32 *)&insn_j_ftrace_graph_caller; |
| 52 | uasm_i_j(&buf, (unsigned long)ftrace_graph_caller); | 53 | uasm_i_j(&buf, (unsigned long)ftrace_graph_caller & JUMP_RANGE_MASK); |
| 53 | #endif | 54 | #endif |
| 54 | } | 55 | } |
| 55 | 56 | ||
diff --git a/arch/mips/kernel/ptrace.c b/arch/mips/kernel/ptrace.c index d21c388c0116..584e6b55c865 100644 --- a/arch/mips/kernel/ptrace.c +++ b/arch/mips/kernel/ptrace.c | |||
| @@ -540,8 +540,8 @@ asmlinkage void do_syscall_trace(struct pt_regs *regs, int entryexit) | |||
| 540 | secure_computing(regs->regs[2]); | 540 | secure_computing(regs->regs[2]); |
| 541 | 541 | ||
| 542 | if (unlikely(current->audit_context) && entryexit) | 542 | if (unlikely(current->audit_context) && entryexit) |
| 543 | audit_syscall_exit(AUDITSC_RESULT(regs->regs[2]), | 543 | audit_syscall_exit(AUDITSC_RESULT(regs->regs[7]), |
| 544 | regs->regs[2]); | 544 | -regs->regs[2]); |
| 545 | 545 | ||
| 546 | if (!(current->ptrace & PT_PTRACED)) | 546 | if (!(current->ptrace & PT_PTRACED)) |
| 547 | goto out; | 547 | goto out; |
diff --git a/arch/mips/kernel/scall32-o32.S b/arch/mips/kernel/scall32-o32.S index 7f5468b38d4c..7f1377eb22d3 100644 --- a/arch/mips/kernel/scall32-o32.S +++ b/arch/mips/kernel/scall32-o32.S | |||
| @@ -565,7 +565,7 @@ einval: li v0, -ENOSYS | |||
| 565 | sys sys_ioprio_get 2 /* 4315 */ | 565 | sys sys_ioprio_get 2 /* 4315 */ |
| 566 | sys sys_utimensat 4 | 566 | sys sys_utimensat 4 |
| 567 | sys sys_signalfd 3 | 567 | sys sys_signalfd 3 |
| 568 | sys sys_ni_syscall 0 | 568 | sys sys_ni_syscall 0 /* was timerfd */ |
| 569 | sys sys_eventfd 1 | 569 | sys sys_eventfd 1 |
| 570 | sys sys_fallocate 6 /* 4320 */ | 570 | sys sys_fallocate 6 /* 4320 */ |
| 571 | sys sys_timerfd_create 2 | 571 | sys sys_timerfd_create 2 |
diff --git a/arch/mips/kernel/scall64-64.S b/arch/mips/kernel/scall64-64.S index a2e1fcbc41dc..7c0ef7f128bf 100644 --- a/arch/mips/kernel/scall64-64.S +++ b/arch/mips/kernel/scall64-64.S | |||
| @@ -404,7 +404,7 @@ sys_call_table: | |||
| 404 | PTR sys_ioprio_get | 404 | PTR sys_ioprio_get |
| 405 | PTR sys_utimensat /* 5275 */ | 405 | PTR sys_utimensat /* 5275 */ |
| 406 | PTR sys_signalfd | 406 | PTR sys_signalfd |
| 407 | PTR sys_ni_syscall | 407 | PTR sys_ni_syscall /* was timerfd */ |
| 408 | PTR sys_eventfd | 408 | PTR sys_eventfd |
| 409 | PTR sys_fallocate | 409 | PTR sys_fallocate |
| 410 | PTR sys_timerfd_create /* 5280 */ | 410 | PTR sys_timerfd_create /* 5280 */ |
diff --git a/arch/mips/kernel/scall64-n32.S b/arch/mips/kernel/scall64-n32.S index b2c7624995b8..de6c5563beab 100644 --- a/arch/mips/kernel/scall64-n32.S +++ b/arch/mips/kernel/scall64-n32.S | |||
| @@ -403,7 +403,7 @@ EXPORT(sysn32_call_table) | |||
| 403 | PTR sys_ioprio_get | 403 | PTR sys_ioprio_get |
| 404 | PTR compat_sys_utimensat | 404 | PTR compat_sys_utimensat |
| 405 | PTR compat_sys_signalfd /* 6280 */ | 405 | PTR compat_sys_signalfd /* 6280 */ |
| 406 | PTR sys_ni_syscall | 406 | PTR sys_ni_syscall /* was timerfd */ |
| 407 | PTR sys_eventfd | 407 | PTR sys_eventfd |
| 408 | PTR sys_fallocate | 408 | PTR sys_fallocate |
| 409 | PTR sys_timerfd_create | 409 | PTR sys_timerfd_create |
diff --git a/arch/mips/kernel/scall64-o32.S b/arch/mips/kernel/scall64-o32.S index 049a9c8c49a0..b0541dda8830 100644 --- a/arch/mips/kernel/scall64-o32.S +++ b/arch/mips/kernel/scall64-o32.S | |||
| @@ -522,7 +522,7 @@ sys_call_table: | |||
| 522 | PTR sys_ioprio_get /* 4315 */ | 522 | PTR sys_ioprio_get /* 4315 */ |
| 523 | PTR compat_sys_utimensat | 523 | PTR compat_sys_utimensat |
| 524 | PTR compat_sys_signalfd | 524 | PTR compat_sys_signalfd |
| 525 | PTR sys_ni_syscall | 525 | PTR sys_ni_syscall /* was timerfd */ |
| 526 | PTR sys_eventfd | 526 | PTR sys_eventfd |
| 527 | PTR sys32_fallocate /* 4320 */ | 527 | PTR sys32_fallocate /* 4320 */ |
| 528 | PTR sys_timerfd_create | 528 | PTR sys_timerfd_create |
diff --git a/arch/mips/kernel/vmlinux.lds.S b/arch/mips/kernel/vmlinux.lds.S index 832afbb87588..e4b0b0bec039 100644 --- a/arch/mips/kernel/vmlinux.lds.S +++ b/arch/mips/kernel/vmlinux.lds.S | |||
| @@ -74,6 +74,7 @@ SECTIONS | |||
| 74 | INIT_TASK_DATA(PAGE_SIZE) | 74 | INIT_TASK_DATA(PAGE_SIZE) |
| 75 | NOSAVE_DATA | 75 | NOSAVE_DATA |
| 76 | CACHELINE_ALIGNED_DATA(1 << CONFIG_MIPS_L1_CACHE_SHIFT) | 76 | CACHELINE_ALIGNED_DATA(1 << CONFIG_MIPS_L1_CACHE_SHIFT) |
| 77 | READ_MOSTLY_DATA(1 << CONFIG_MIPS_L1_CACHE_SHIFT) | ||
| 77 | DATA_DATA | 78 | DATA_DATA |
| 78 | CONSTRUCTORS | 79 | CONSTRUCTORS |
| 79 | } | 80 | } |
diff --git a/arch/mips/loongson/common/env.c b/arch/mips/loongson/common/env.c index 11b193f848f8..d93830ad6113 100644 --- a/arch/mips/loongson/common/env.c +++ b/arch/mips/loongson/common/env.c | |||
| @@ -29,9 +29,10 @@ unsigned long memsize, highmemsize; | |||
| 29 | 29 | ||
| 30 | #define parse_even_earlier(res, option, p) \ | 30 | #define parse_even_earlier(res, option, p) \ |
| 31 | do { \ | 31 | do { \ |
| 32 | int ret; \ | 32 | unsigned int tmp __maybe_unused; \ |
| 33 | \ | ||
| 33 | if (strncmp(option, (char *)p, strlen(option)) == 0) \ | 34 | if (strncmp(option, (char *)p, strlen(option)) == 0) \ |
| 34 | ret = strict_strtol((char *)p + strlen(option"="), 10, &res); \ | 35 | tmp = strict_strtol((char *)p + strlen(option"="), 10, &res); \ |
| 35 | } while (0) | 36 | } while (0) |
| 36 | 37 | ||
| 37 | void __init prom_init_env(void) | 38 | void __init prom_init_env(void) |
diff --git a/arch/mips/mm/c-r4k.c b/arch/mips/mm/c-r4k.c index b4923a75cb4b..71bddf8f7d25 100644 --- a/arch/mips/mm/c-r4k.c +++ b/arch/mips/mm/c-r4k.c | |||
| @@ -1075,7 +1075,6 @@ static int __cpuinit probe_scache(void) | |||
| 1075 | unsigned long flags, addr, begin, end, pow2; | 1075 | unsigned long flags, addr, begin, end, pow2; |
| 1076 | unsigned int config = read_c0_config(); | 1076 | unsigned int config = read_c0_config(); |
| 1077 | struct cpuinfo_mips *c = ¤t_cpu_data; | 1077 | struct cpuinfo_mips *c = ¤t_cpu_data; |
| 1078 | int tmp; | ||
| 1079 | 1078 | ||
| 1080 | if (config & CONF_SC) | 1079 | if (config & CONF_SC) |
| 1081 | return 0; | 1080 | return 0; |
| @@ -1108,7 +1107,6 @@ static int __cpuinit probe_scache(void) | |||
| 1108 | 1107 | ||
| 1109 | /* Now search for the wrap around point. */ | 1108 | /* Now search for the wrap around point. */ |
| 1110 | pow2 = (128 * 1024); | 1109 | pow2 = (128 * 1024); |
| 1111 | tmp = 0; | ||
| 1112 | for (addr = begin + (128 * 1024); addr < end; addr = begin + pow2) { | 1110 | for (addr = begin + (128 * 1024); addr < end; addr = begin + pow2) { |
| 1113 | cache_op(Index_Load_Tag_SD, addr); | 1111 | cache_op(Index_Load_Tag_SD, addr); |
| 1114 | __asm__ __volatile__("nop; nop; nop; nop;"); /* hazard... */ | 1112 | __asm__ __volatile__("nop; nop; nop; nop;"); /* hazard... */ |
diff --git a/arch/mips/mm/tlbex.c b/arch/mips/mm/tlbex.c index 5ef294fbb6e7..f5734c2c8097 100644 --- a/arch/mips/mm/tlbex.c +++ b/arch/mips/mm/tlbex.c | |||
| @@ -1151,8 +1151,8 @@ static void __cpuinit build_r4000_tlb_refill_handler(void) | |||
| 1151 | struct uasm_reloc *r = relocs; | 1151 | struct uasm_reloc *r = relocs; |
| 1152 | u32 *f; | 1152 | u32 *f; |
| 1153 | unsigned int final_len; | 1153 | unsigned int final_len; |
| 1154 | struct mips_huge_tlb_info htlb_info; | 1154 | struct mips_huge_tlb_info htlb_info __maybe_unused; |
| 1155 | enum vmalloc64_mode vmalloc_mode; | 1155 | enum vmalloc64_mode vmalloc_mode __maybe_unused; |
| 1156 | 1156 | ||
| 1157 | memset(tlb_handler, 0, sizeof(tlb_handler)); | 1157 | memset(tlb_handler, 0, sizeof(tlb_handler)); |
| 1158 | memset(labels, 0, sizeof(labels)); | 1158 | memset(labels, 0, sizeof(labels)); |
diff --git a/arch/mips/mti-malta/malta-init.c b/arch/mips/mti-malta/malta-init.c index 414f0c99b196..31180c321a1a 100644 --- a/arch/mips/mti-malta/malta-init.c +++ b/arch/mips/mti-malta/malta-init.c | |||
| @@ -193,8 +193,6 @@ extern struct plat_smp_ops msmtc_smp_ops; | |||
| 193 | 193 | ||
| 194 | void __init prom_init(void) | 194 | void __init prom_init(void) |
| 195 | { | 195 | { |
| 196 | int result; | ||
| 197 | |||
| 198 | prom_argc = fw_arg0; | 196 | prom_argc = fw_arg0; |
| 199 | _prom_argv = (int *) fw_arg1; | 197 | _prom_argv = (int *) fw_arg1; |
| 200 | _prom_envp = (int *) fw_arg2; | 198 | _prom_envp = (int *) fw_arg2; |
| @@ -360,20 +358,14 @@ void __init prom_init(void) | |||
| 360 | #ifdef CONFIG_SERIAL_8250_CONSOLE | 358 | #ifdef CONFIG_SERIAL_8250_CONSOLE |
| 361 | console_config(); | 359 | console_config(); |
| 362 | #endif | 360 | #endif |
| 363 | /* Early detection of CMP support */ | ||
| 364 | result = gcmp_probe(GCMP_BASE_ADDR, GCMP_ADDRSPACE_SZ); | ||
| 365 | |||
| 366 | #ifdef CONFIG_MIPS_CMP | 361 | #ifdef CONFIG_MIPS_CMP |
| 367 | if (result) | 362 | /* Early detection of CMP support */ |
| 363 | if (gcmp_probe(GCMP_BASE_ADDR, GCMP_ADDRSPACE_SZ)) | ||
| 368 | register_smp_ops(&cmp_smp_ops); | 364 | register_smp_ops(&cmp_smp_ops); |
| 365 | else | ||
| 369 | #endif | 366 | #endif |
| 370 | #ifdef CONFIG_MIPS_MT_SMP | 367 | #ifdef CONFIG_MIPS_MT_SMP |
| 371 | #ifdef CONFIG_MIPS_CMP | ||
| 372 | if (!result) | ||
| 373 | register_smp_ops(&vsmp_smp_ops); | 368 | register_smp_ops(&vsmp_smp_ops); |
| 374 | #else | ||
| 375 | register_smp_ops(&vsmp_smp_ops); | ||
| 376 | #endif | ||
| 377 | #endif | 369 | #endif |
| 378 | #ifdef CONFIG_MIPS_MT_SMTC | 370 | #ifdef CONFIG_MIPS_MT_SMTC |
| 379 | register_smp_ops(&msmtc_smp_ops); | 371 | register_smp_ops(&msmtc_smp_ops); |
diff --git a/arch/mips/mti-malta/malta-int.c b/arch/mips/mti-malta/malta-int.c index 9027061f0ead..e85c977328da 100644 --- a/arch/mips/mti-malta/malta-int.c +++ b/arch/mips/mti-malta/malta-int.c | |||
| @@ -56,7 +56,6 @@ static DEFINE_RAW_SPINLOCK(mips_irq_lock); | |||
| 56 | static inline int mips_pcibios_iack(void) | 56 | static inline int mips_pcibios_iack(void) |
| 57 | { | 57 | { |
| 58 | int irq; | 58 | int irq; |
| 59 | u32 dummy; | ||
| 60 | 59 | ||
| 61 | /* | 60 | /* |
| 62 | * Determine highest priority pending interrupt by performing | 61 | * Determine highest priority pending interrupt by performing |
| @@ -83,7 +82,7 @@ static inline int mips_pcibios_iack(void) | |||
| 83 | BONITO_PCIMAP_CFG = 0x20000; | 82 | BONITO_PCIMAP_CFG = 0x20000; |
| 84 | 83 | ||
| 85 | /* Flush Bonito register block */ | 84 | /* Flush Bonito register block */ |
| 86 | dummy = BONITO_PCIMAP_CFG; | 85 | (void) BONITO_PCIMAP_CFG; |
| 87 | iob(); /* sync */ | 86 | iob(); /* sync */ |
| 88 | 87 | ||
| 89 | irq = __raw_readl((u32 *)_pcictrl_bonito_pcicfg); | 88 | irq = __raw_readl((u32 *)_pcictrl_bonito_pcicfg); |
diff --git a/arch/mips/pmc-sierra/msp71xx/msp_irq_per.c b/arch/mips/pmc-sierra/msp71xx/msp_irq_per.c index f9b9dcdfa9dd..98fd0099d964 100644 --- a/arch/mips/pmc-sierra/msp71xx/msp_irq_per.c +++ b/arch/mips/pmc-sierra/msp71xx/msp_irq_per.c | |||
| @@ -97,7 +97,7 @@ static int msp_per_irq_set_affinity(struct irq_data *d, | |||
| 97 | 97 | ||
| 98 | static struct irq_chip msp_per_irq_controller = { | 98 | static struct irq_chip msp_per_irq_controller = { |
| 99 | .name = "MSP_PER", | 99 | .name = "MSP_PER", |
| 100 | .irq_enable = unmask_per_irq. | 100 | .irq_enable = unmask_per_irq, |
| 101 | .irq_disable = mask_per_irq, | 101 | .irq_disable = mask_per_irq, |
| 102 | .irq_ack = msp_per_irq_ack, | 102 | .irq_ack = msp_per_irq_ack, |
| 103 | #ifdef CONFIG_SMP | 103 | #ifdef CONFIG_SMP |
diff --git a/arch/mips/power/hibernate.S b/arch/mips/power/hibernate.S index dbb5c7b4b70f..f8a751c03282 100644 --- a/arch/mips/power/hibernate.S +++ b/arch/mips/power/hibernate.S | |||
| @@ -35,7 +35,7 @@ LEAF(swsusp_arch_resume) | |||
| 35 | 0: | 35 | 0: |
| 36 | PTR_L t1, PBE_ADDRESS(t0) /* source */ | 36 | PTR_L t1, PBE_ADDRESS(t0) /* source */ |
| 37 | PTR_L t2, PBE_ORIG_ADDRESS(t0) /* destination */ | 37 | PTR_L t2, PBE_ORIG_ADDRESS(t0) /* destination */ |
| 38 | PTR_ADDIU t3, t1, PAGE_SIZE | 38 | PTR_ADDU t3, t1, PAGE_SIZE |
| 39 | 1: | 39 | 1: |
| 40 | REG_L t8, (t1) | 40 | REG_L t8, (t1) |
| 41 | REG_S t8, (t2) | 41 | REG_S t8, (t2) |
diff --git a/arch/mips/sgi-ip22/ip22-platform.c b/arch/mips/sgi-ip22/ip22-platform.c index deddbf0ebe5c..698904daf901 100644 --- a/arch/mips/sgi-ip22/ip22-platform.c +++ b/arch/mips/sgi-ip22/ip22-platform.c | |||
| @@ -132,7 +132,7 @@ static struct platform_device eth1_device = { | |||
| 132 | */ | 132 | */ |
| 133 | static int __init sgiseeq_devinit(void) | 133 | static int __init sgiseeq_devinit(void) |
| 134 | { | 134 | { |
| 135 | unsigned int tmp; | 135 | unsigned int pbdma __maybe_unused; |
| 136 | int res, i; | 136 | int res, i; |
| 137 | 137 | ||
| 138 | eth0_pd.hpc = hpc3c0; | 138 | eth0_pd.hpc = hpc3c0; |
| @@ -151,7 +151,7 @@ static int __init sgiseeq_devinit(void) | |||
| 151 | 151 | ||
| 152 | /* Second HPC is missing? */ | 152 | /* Second HPC is missing? */ |
| 153 | if (ip22_is_fullhouse() || | 153 | if (ip22_is_fullhouse() || |
| 154 | get_dbe(tmp, (unsigned int *)&hpc3c1->pbdma[1])) | 154 | get_dbe(pbdma, (unsigned int *)&hpc3c1->pbdma[1])) |
| 155 | return 0; | 155 | return 0; |
| 156 | 156 | ||
| 157 | sgimc->giopar |= SGIMC_GIOPAR_MASTEREXP1 | SGIMC_GIOPAR_EXP164 | | 157 | sgimc->giopar |= SGIMC_GIOPAR_MASTEREXP1 | SGIMC_GIOPAR_EXP164 | |
diff --git a/arch/mips/sgi-ip22/ip22-time.c b/arch/mips/sgi-ip22/ip22-time.c index 603fc91c1030..1a94c9894188 100644 --- a/arch/mips/sgi-ip22/ip22-time.c +++ b/arch/mips/sgi-ip22/ip22-time.c | |||
| @@ -32,7 +32,7 @@ | |||
| 32 | static unsigned long dosample(void) | 32 | static unsigned long dosample(void) |
| 33 | { | 33 | { |
| 34 | u32 ct0, ct1; | 34 | u32 ct0, ct1; |
| 35 | u8 msb, lsb; | 35 | u8 msb; |
| 36 | 36 | ||
| 37 | /* Start the counter. */ | 37 | /* Start the counter. */ |
| 38 | sgint->tcword = (SGINT_TCWORD_CNT2 | SGINT_TCWORD_CALL | | 38 | sgint->tcword = (SGINT_TCWORD_CNT2 | SGINT_TCWORD_CALL | |
| @@ -46,7 +46,7 @@ static unsigned long dosample(void) | |||
| 46 | /* Latch and spin until top byte of counter2 is zero */ | 46 | /* Latch and spin until top byte of counter2 is zero */ |
| 47 | do { | 47 | do { |
| 48 | writeb(SGINT_TCWORD_CNT2 | SGINT_TCWORD_CLAT, &sgint->tcword); | 48 | writeb(SGINT_TCWORD_CNT2 | SGINT_TCWORD_CLAT, &sgint->tcword); |
| 49 | lsb = readb(&sgint->tcnt2); | 49 | (void) readb(&sgint->tcnt2); |
| 50 | msb = readb(&sgint->tcnt2); | 50 | msb = readb(&sgint->tcnt2); |
| 51 | ct1 = read_c0_count(); | 51 | ct1 = read_c0_count(); |
| 52 | } while (msb); | 52 | } while (msb); |
diff --git a/arch/mips/sgi-ip27/ip27-hubio.c b/arch/mips/sgi-ip27/ip27-hubio.c index a1fa4abb3f6a..cd0d5b06cd83 100644 --- a/arch/mips/sgi-ip27/ip27-hubio.c +++ b/arch/mips/sgi-ip27/ip27-hubio.c | |||
| @@ -29,7 +29,6 @@ unsigned long hub_pio_map(cnodeid_t cnode, xwidgetnum_t widget, | |||
| 29 | unsigned long xtalk_addr, size_t size) | 29 | unsigned long xtalk_addr, size_t size) |
| 30 | { | 30 | { |
| 31 | nasid_t nasid = COMPACT_TO_NASID_NODEID(cnode); | 31 | nasid_t nasid = COMPACT_TO_NASID_NODEID(cnode); |
| 32 | volatile hubreg_t junk; | ||
| 33 | unsigned i; | 32 | unsigned i; |
| 34 | 33 | ||
| 35 | /* use small-window mapping if possible */ | 34 | /* use small-window mapping if possible */ |
| @@ -64,7 +63,7 @@ unsigned long hub_pio_map(cnodeid_t cnode, xwidgetnum_t widget, | |||
| 64 | * after we write it. | 63 | * after we write it. |
| 65 | */ | 64 | */ |
| 66 | IIO_ITTE_PUT(nasid, i, HUB_PIO_MAP_TO_MEM, widget, xtalk_addr); | 65 | IIO_ITTE_PUT(nasid, i, HUB_PIO_MAP_TO_MEM, widget, xtalk_addr); |
| 67 | junk = HUB_L(IIO_ITTE_GET(nasid, i)); | 66 | (void) HUB_L(IIO_ITTE_GET(nasid, i)); |
| 68 | 67 | ||
| 69 | return NODE_BWIN_BASE(nasid, widget) + (xtalk_addr % BWIN_SIZE); | 68 | return NODE_BWIN_BASE(nasid, widget) + (xtalk_addr % BWIN_SIZE); |
| 70 | } | 69 | } |
diff --git a/arch/mips/sgi-ip27/ip27-klnuma.c b/arch/mips/sgi-ip27/ip27-klnuma.c index c3d30a88daf3..1d1919a44e88 100644 --- a/arch/mips/sgi-ip27/ip27-klnuma.c +++ b/arch/mips/sgi-ip27/ip27-klnuma.c | |||
| @@ -54,11 +54,8 @@ void __init setup_replication_mask(void) | |||
| 54 | 54 | ||
| 55 | static __init void set_ktext_source(nasid_t client_nasid, nasid_t server_nasid) | 55 | static __init void set_ktext_source(nasid_t client_nasid, nasid_t server_nasid) |
| 56 | { | 56 | { |
| 57 | cnodeid_t client_cnode; | ||
| 58 | kern_vars_t *kvp; | 57 | kern_vars_t *kvp; |
| 59 | 58 | ||
| 60 | client_cnode = NASID_TO_COMPACT_NODEID(client_nasid); | ||
| 61 | |||
| 62 | kvp = &hub_data(client_nasid)->kern_vars; | 59 | kvp = &hub_data(client_nasid)->kern_vars; |
| 63 | 60 | ||
| 64 | KERN_VARS_ADDR(client_nasid) = (unsigned long)kvp; | 61 | KERN_VARS_ADDR(client_nasid) = (unsigned long)kvp; |
diff --git a/arch/mips/sni/time.c b/arch/mips/sni/time.c index c76151b56568..0904d4d30cb3 100644 --- a/arch/mips/sni/time.c +++ b/arch/mips/sni/time.c | |||
| @@ -95,7 +95,7 @@ static void __init sni_a20r_timer_setup(void) | |||
| 95 | static __init unsigned long dosample(void) | 95 | static __init unsigned long dosample(void) |
| 96 | { | 96 | { |
| 97 | u32 ct0, ct1; | 97 | u32 ct0, ct1; |
| 98 | volatile u8 msb, lsb; | 98 | volatile u8 msb; |
| 99 | 99 | ||
| 100 | /* Start the counter. */ | 100 | /* Start the counter. */ |
| 101 | outb_p(0x34, 0x43); | 101 | outb_p(0x34, 0x43); |
| @@ -108,7 +108,7 @@ static __init unsigned long dosample(void) | |||
| 108 | /* Latch and spin until top byte of counter0 is zero */ | 108 | /* Latch and spin until top byte of counter0 is zero */ |
| 109 | do { | 109 | do { |
| 110 | outb(0x00, 0x43); | 110 | outb(0x00, 0x43); |
| 111 | lsb = inb(0x40); | 111 | (void) inb(0x40); |
| 112 | msb = inb(0x40); | 112 | msb = inb(0x40); |
| 113 | ct1 = read_c0_count(); | 113 | ct1 = read_c0_count(); |
| 114 | } while (msb); | 114 | } while (msb); |
diff --git a/arch/s390/include/asm/diag.h b/arch/s390/include/asm/diag.h index 72b2e2f2d32d..7e91c58072e2 100644 --- a/arch/s390/include/asm/diag.h +++ b/arch/s390/include/asm/diag.h | |||
| @@ -9,9 +9,22 @@ | |||
| 9 | #define _ASM_S390_DIAG_H | 9 | #define _ASM_S390_DIAG_H |
| 10 | 10 | ||
| 11 | /* | 11 | /* |
| 12 | * Diagnose 10: Release pages | 12 | * Diagnose 10: Release page range |
| 13 | */ | 13 | */ |
| 14 | extern void diag10(unsigned long addr); | 14 | static inline void diag10_range(unsigned long start_pfn, unsigned long num_pfn) |
| 15 | { | ||
| 16 | unsigned long start_addr, end_addr; | ||
| 17 | |||
| 18 | start_addr = start_pfn << PAGE_SHIFT; | ||
| 19 | end_addr = (start_pfn + num_pfn - 1) << PAGE_SHIFT; | ||
| 20 | |||
| 21 | asm volatile( | ||
| 22 | "0: diag %0,%1,0x10\n" | ||
| 23 | "1:\n" | ||
| 24 | EX_TABLE(0b, 1b) | ||
| 25 | EX_TABLE(1b, 1b) | ||
| 26 | : : "a" (start_addr), "a" (end_addr)); | ||
| 27 | } | ||
| 15 | 28 | ||
| 16 | /* | 29 | /* |
| 17 | * Diagnose 14: Input spool file manipulation | 30 | * Diagnose 14: Input spool file manipulation |
diff --git a/arch/s390/include/asm/mmu_context.h b/arch/s390/include/asm/mmu_context.h index a6f0e7cc9cde..8c277caa8d3a 100644 --- a/arch/s390/include/asm/mmu_context.h +++ b/arch/s390/include/asm/mmu_context.h | |||
| @@ -23,7 +23,7 @@ static inline int init_new_context(struct task_struct *tsk, | |||
| 23 | #ifdef CONFIG_64BIT | 23 | #ifdef CONFIG_64BIT |
| 24 | mm->context.asce_bits |= _ASCE_TYPE_REGION3; | 24 | mm->context.asce_bits |= _ASCE_TYPE_REGION3; |
| 25 | #endif | 25 | #endif |
| 26 | if (current->mm->context.alloc_pgste) { | 26 | if (current->mm && current->mm->context.alloc_pgste) { |
| 27 | /* | 27 | /* |
| 28 | * alloc_pgste indicates, that any NEW context will be created | 28 | * alloc_pgste indicates, that any NEW context will be created |
| 29 | * with extended page tables. The old context is unchanged. The | 29 | * with extended page tables. The old context is unchanged. The |
diff --git a/arch/s390/kernel/diag.c b/arch/s390/kernel/diag.c index c032d11da8a1..8237fc07ac79 100644 --- a/arch/s390/kernel/diag.c +++ b/arch/s390/kernel/diag.c | |||
| @@ -9,27 +9,6 @@ | |||
| 9 | #include <asm/diag.h> | 9 | #include <asm/diag.h> |
| 10 | 10 | ||
| 11 | /* | 11 | /* |
| 12 | * Diagnose 10: Release pages | ||
| 13 | */ | ||
| 14 | void diag10(unsigned long addr) | ||
| 15 | { | ||
| 16 | if (addr >= 0x7ff00000) | ||
| 17 | return; | ||
| 18 | asm volatile( | ||
| 19 | #ifdef CONFIG_64BIT | ||
| 20 | " sam31\n" | ||
| 21 | " diag %0,%0,0x10\n" | ||
| 22 | "0: sam64\n" | ||
| 23 | #else | ||
| 24 | " diag %0,%0,0x10\n" | ||
| 25 | "0:\n" | ||
| 26 | #endif | ||
| 27 | EX_TABLE(0b, 0b) | ||
| 28 | : : "a" (addr)); | ||
| 29 | } | ||
| 30 | EXPORT_SYMBOL(diag10); | ||
| 31 | |||
| 32 | /* | ||
| 33 | * Diagnose 14: Input spool file manipulation | 12 | * Diagnose 14: Input spool file manipulation |
| 34 | */ | 13 | */ |
| 35 | int diag14(unsigned long rx, unsigned long ry1, unsigned long subcode) | 14 | int diag14(unsigned long rx, unsigned long ry1, unsigned long subcode) |
diff --git a/arch/s390/kernel/dis.c b/arch/s390/kernel/dis.c index c83726c9fe03..3d4a78fc1adc 100644 --- a/arch/s390/kernel/dis.c +++ b/arch/s390/kernel/dis.c | |||
| @@ -672,6 +672,7 @@ static struct insn opcode_b2[] = { | |||
| 672 | { "rp", 0x77, INSTR_S_RD }, | 672 | { "rp", 0x77, INSTR_S_RD }, |
| 673 | { "stcke", 0x78, INSTR_S_RD }, | 673 | { "stcke", 0x78, INSTR_S_RD }, |
| 674 | { "sacf", 0x79, INSTR_S_RD }, | 674 | { "sacf", 0x79, INSTR_S_RD }, |
| 675 | { "spp", 0x80, INSTR_S_RD }, | ||
| 675 | { "stsi", 0x7d, INSTR_S_RD }, | 676 | { "stsi", 0x7d, INSTR_S_RD }, |
| 676 | { "srnm", 0x99, INSTR_S_RD }, | 677 | { "srnm", 0x99, INSTR_S_RD }, |
| 677 | { "stfpc", 0x9c, INSTR_S_RD }, | 678 | { "stfpc", 0x9c, INSTR_S_RD }, |
diff --git a/arch/s390/kernel/entry.S b/arch/s390/kernel/entry.S index 648f64239a9d..1b67fc6ebdc2 100644 --- a/arch/s390/kernel/entry.S +++ b/arch/s390/kernel/entry.S | |||
| @@ -836,7 +836,7 @@ restart_base: | |||
| 836 | stosm __SF_EMPTY(%r15),0x04 # now we can turn dat on | 836 | stosm __SF_EMPTY(%r15),0x04 # now we can turn dat on |
| 837 | basr %r14,0 | 837 | basr %r14,0 |
| 838 | l %r14,restart_addr-.(%r14) | 838 | l %r14,restart_addr-.(%r14) |
| 839 | br %r14 # branch to start_secondary | 839 | basr %r14,%r14 # branch to start_secondary |
| 840 | restart_addr: | 840 | restart_addr: |
| 841 | .long start_secondary | 841 | .long start_secondary |
| 842 | .align 8 | 842 | .align 8 |
diff --git a/arch/s390/kernel/entry64.S b/arch/s390/kernel/entry64.S index 9d3603d6c511..9fd864563499 100644 --- a/arch/s390/kernel/entry64.S +++ b/arch/s390/kernel/entry64.S | |||
| @@ -841,7 +841,7 @@ restart_base: | |||
| 841 | mvc __LC_SYSTEM_TIMER(8),__TI_system_timer(%r1) | 841 | mvc __LC_SYSTEM_TIMER(8),__TI_system_timer(%r1) |
| 842 | xc __LC_STEAL_TIMER(8),__LC_STEAL_TIMER | 842 | xc __LC_STEAL_TIMER(8),__LC_STEAL_TIMER |
| 843 | stosm __SF_EMPTY(%r15),0x04 # now we can turn dat on | 843 | stosm __SF_EMPTY(%r15),0x04 # now we can turn dat on |
| 844 | jg start_secondary | 844 | brasl %r14,start_secondary |
| 845 | .align 8 | 845 | .align 8 |
| 846 | restart_vtime: | 846 | restart_vtime: |
| 847 | .long 0x7fffffff,0xffffffff | 847 | .long 0x7fffffff,0xffffffff |
diff --git a/arch/s390/mm/cmm.c b/arch/s390/mm/cmm.c index c66ffd8dbbb7..1f1dba9dcf58 100644 --- a/arch/s390/mm/cmm.c +++ b/arch/s390/mm/cmm.c | |||
| @@ -91,7 +91,7 @@ static long cmm_alloc_pages(long nr, long *counter, | |||
| 91 | } else | 91 | } else |
| 92 | free_page((unsigned long) npa); | 92 | free_page((unsigned long) npa); |
| 93 | } | 93 | } |
| 94 | diag10(addr); | 94 | diag10_range(addr >> PAGE_SHIFT, 1); |
| 95 | pa->pages[pa->index++] = addr; | 95 | pa->pages[pa->index++] = addr; |
| 96 | (*counter)++; | 96 | (*counter)++; |
| 97 | spin_unlock(&cmm_lock); | 97 | spin_unlock(&cmm_lock); |
diff --git a/arch/s390/oprofile/hwsampler.c b/arch/s390/oprofile/hwsampler.c index 4952872d6f0a..33cbd373cce4 100644 --- a/arch/s390/oprofile/hwsampler.c +++ b/arch/s390/oprofile/hwsampler.c | |||
| @@ -1021,20 +1021,14 @@ deallocate_exit: | |||
| 1021 | return rc; | 1021 | return rc; |
| 1022 | } | 1022 | } |
| 1023 | 1023 | ||
| 1024 | long hwsampler_query_min_interval(void) | 1024 | unsigned long hwsampler_query_min_interval(void) |
| 1025 | { | 1025 | { |
| 1026 | if (min_sampler_rate) | 1026 | return min_sampler_rate; |
| 1027 | return min_sampler_rate; | ||
| 1028 | else | ||
| 1029 | return -EINVAL; | ||
| 1030 | } | 1027 | } |
| 1031 | 1028 | ||
| 1032 | long hwsampler_query_max_interval(void) | 1029 | unsigned long hwsampler_query_max_interval(void) |
| 1033 | { | 1030 | { |
| 1034 | if (max_sampler_rate) | 1031 | return max_sampler_rate; |
| 1035 | return max_sampler_rate; | ||
| 1036 | else | ||
| 1037 | return -EINVAL; | ||
| 1038 | } | 1032 | } |
| 1039 | 1033 | ||
| 1040 | unsigned long hwsampler_get_sample_overflow_count(unsigned int cpu) | 1034 | unsigned long hwsampler_get_sample_overflow_count(unsigned int cpu) |
diff --git a/arch/s390/oprofile/hwsampler.h b/arch/s390/oprofile/hwsampler.h index 8c72b59316b5..1912f3bb190c 100644 --- a/arch/s390/oprofile/hwsampler.h +++ b/arch/s390/oprofile/hwsampler.h | |||
| @@ -102,8 +102,8 @@ int hwsampler_setup(void); | |||
| 102 | int hwsampler_shutdown(void); | 102 | int hwsampler_shutdown(void); |
| 103 | int hwsampler_allocate(unsigned long sdbt, unsigned long sdb); | 103 | int hwsampler_allocate(unsigned long sdbt, unsigned long sdb); |
| 104 | int hwsampler_deallocate(void); | 104 | int hwsampler_deallocate(void); |
| 105 | long hwsampler_query_min_interval(void); | 105 | unsigned long hwsampler_query_min_interval(void); |
| 106 | long hwsampler_query_max_interval(void); | 106 | unsigned long hwsampler_query_max_interval(void); |
| 107 | int hwsampler_start_all(unsigned long interval); | 107 | int hwsampler_start_all(unsigned long interval); |
| 108 | int hwsampler_stop_all(void); | 108 | int hwsampler_stop_all(void); |
| 109 | int hwsampler_deactivate(unsigned int cpu); | 109 | int hwsampler_deactivate(unsigned int cpu); |
diff --git a/arch/s390/oprofile/init.c b/arch/s390/oprofile/init.c index c63d7e58352b..5995e9bc72d9 100644 --- a/arch/s390/oprofile/init.c +++ b/arch/s390/oprofile/init.c | |||
| @@ -145,15 +145,11 @@ static int oprofile_hwsampler_init(struct oprofile_operations *ops) | |||
| 145 | * create hwsampler files only if hwsampler_setup() succeeds. | 145 | * create hwsampler files only if hwsampler_setup() succeeds. |
| 146 | */ | 146 | */ |
| 147 | oprofile_min_interval = hwsampler_query_min_interval(); | 147 | oprofile_min_interval = hwsampler_query_min_interval(); |
| 148 | if (oprofile_min_interval < 0) { | 148 | if (oprofile_min_interval == 0) |
| 149 | oprofile_min_interval = 0; | ||
| 150 | return -ENODEV; | 149 | return -ENODEV; |
| 151 | } | ||
| 152 | oprofile_max_interval = hwsampler_query_max_interval(); | 150 | oprofile_max_interval = hwsampler_query_max_interval(); |
| 153 | if (oprofile_max_interval < 0) { | 151 | if (oprofile_max_interval == 0) |
| 154 | oprofile_max_interval = 0; | ||
| 155 | return -ENODEV; | 152 | return -ENODEV; |
| 156 | } | ||
| 157 | 153 | ||
| 158 | if (oprofile_timer_init(ops)) | 154 | if (oprofile_timer_init(ops)) |
| 159 | return -ENODEV; | 155 | return -ENODEV; |
diff --git a/arch/sparc/kernel/apc.c b/arch/sparc/kernel/apc.c index f679c57644d5..1e34f29e58bb 100644 --- a/arch/sparc/kernel/apc.c +++ b/arch/sparc/kernel/apc.c | |||
| @@ -165,7 +165,7 @@ static int __devinit apc_probe(struct platform_device *op) | |||
| 165 | return 0; | 165 | return 0; |
| 166 | } | 166 | } |
| 167 | 167 | ||
| 168 | static struct of_device_id __initdata apc_match[] = { | 168 | static struct of_device_id apc_match[] = { |
| 169 | { | 169 | { |
| 170 | .name = APC_OBPNAME, | 170 | .name = APC_OBPNAME, |
| 171 | }, | 171 | }, |
diff --git a/arch/sparc/kernel/pmc.c b/arch/sparc/kernel/pmc.c index 93d7b4465f8d..6a585d393580 100644 --- a/arch/sparc/kernel/pmc.c +++ b/arch/sparc/kernel/pmc.c | |||
| @@ -69,7 +69,7 @@ static int __devinit pmc_probe(struct platform_device *op) | |||
| 69 | return 0; | 69 | return 0; |
| 70 | } | 70 | } |
| 71 | 71 | ||
| 72 | static struct of_device_id __initdata pmc_match[] = { | 72 | static struct of_device_id pmc_match[] = { |
| 73 | { | 73 | { |
| 74 | .name = PMC_OBPNAME, | 74 | .name = PMC_OBPNAME, |
| 75 | }, | 75 | }, |
diff --git a/arch/sparc/kernel/smp_32.c b/arch/sparc/kernel/smp_32.c index 91c10fb70858..850a1360c0d6 100644 --- a/arch/sparc/kernel/smp_32.c +++ b/arch/sparc/kernel/smp_32.c | |||
| @@ -53,6 +53,7 @@ cpumask_t smp_commenced_mask = CPU_MASK_NONE; | |||
| 53 | void __cpuinit smp_store_cpu_info(int id) | 53 | void __cpuinit smp_store_cpu_info(int id) |
| 54 | { | 54 | { |
| 55 | int cpu_node; | 55 | int cpu_node; |
| 56 | int mid; | ||
| 56 | 57 | ||
| 57 | cpu_data(id).udelay_val = loops_per_jiffy; | 58 | cpu_data(id).udelay_val = loops_per_jiffy; |
| 58 | 59 | ||
| @@ -60,10 +61,13 @@ void __cpuinit smp_store_cpu_info(int id) | |||
| 60 | cpu_data(id).clock_tick = prom_getintdefault(cpu_node, | 61 | cpu_data(id).clock_tick = prom_getintdefault(cpu_node, |
| 61 | "clock-frequency", 0); | 62 | "clock-frequency", 0); |
| 62 | cpu_data(id).prom_node = cpu_node; | 63 | cpu_data(id).prom_node = cpu_node; |
| 63 | cpu_data(id).mid = cpu_get_hwmid(cpu_node); | 64 | mid = cpu_get_hwmid(cpu_node); |
| 64 | 65 | ||
| 65 | if (cpu_data(id).mid < 0) | 66 | if (mid < 0) { |
| 66 | panic("No MID found for CPU%d at node 0x%08d", id, cpu_node); | 67 | printk(KERN_NOTICE "No MID found for CPU%d at node 0x%08d", id, cpu_node); |
| 68 | mid = 0; | ||
| 69 | } | ||
| 70 | cpu_data(id).mid = mid; | ||
| 67 | } | 71 | } |
| 68 | 72 | ||
| 69 | void __init smp_cpus_done(unsigned int max_cpus) | 73 | void __init smp_cpus_done(unsigned int max_cpus) |
diff --git a/arch/sparc/kernel/time_32.c b/arch/sparc/kernel/time_32.c index 4e236391b635..96046a4024c2 100644 --- a/arch/sparc/kernel/time_32.c +++ b/arch/sparc/kernel/time_32.c | |||
| @@ -168,7 +168,7 @@ static int __devinit clock_probe(struct platform_device *op) | |||
| 168 | return 0; | 168 | return 0; |
| 169 | } | 169 | } |
| 170 | 170 | ||
| 171 | static struct of_device_id __initdata clock_match[] = { | 171 | static struct of_device_id clock_match[] = { |
| 172 | { | 172 | { |
| 173 | .name = "eeprom", | 173 | .name = "eeprom", |
| 174 | }, | 174 | }, |
diff --git a/arch/sparc/lib/checksum_32.S b/arch/sparc/lib/checksum_32.S index 3632cb34e914..0084c3361e15 100644 --- a/arch/sparc/lib/checksum_32.S +++ b/arch/sparc/lib/checksum_32.S | |||
| @@ -289,10 +289,16 @@ cc_end_cruft: | |||
| 289 | 289 | ||
| 290 | /* Also, handle the alignment code out of band. */ | 290 | /* Also, handle the alignment code out of band. */ |
| 291 | cc_dword_align: | 291 | cc_dword_align: |
| 292 | cmp %g1, 6 | 292 | cmp %g1, 16 |
| 293 | bl,a ccte | 293 | bge 1f |
| 294 | srl %g1, 1, %o3 | ||
| 295 | 2: cmp %o3, 0 | ||
| 296 | be,a ccte | ||
| 294 | andcc %g1, 0xf, %o3 | 297 | andcc %g1, 0xf, %o3 |
| 295 | andcc %o0, 0x1, %g0 | 298 | andcc %o3, %o0, %g0 ! Check %o0 only (%o1 has the same last 2 bits) |
| 299 | be,a 2b | ||
| 300 | srl %o3, 1, %o3 | ||
| 301 | 1: andcc %o0, 0x1, %g0 | ||
| 296 | bne ccslow | 302 | bne ccslow |
| 297 | andcc %o0, 0x2, %g0 | 303 | andcc %o0, 0x2, %g0 |
| 298 | be 1f | 304 | be 1f |
diff --git a/arch/um/os-Linux/util.c b/arch/um/os-Linux/util.c index 6ea77979531c..42827cafa6af 100644 --- a/arch/um/os-Linux/util.c +++ b/arch/um/os-Linux/util.c | |||
| @@ -5,6 +5,7 @@ | |||
| 5 | 5 | ||
| 6 | #include <stdio.h> | 6 | #include <stdio.h> |
| 7 | #include <stdlib.h> | 7 | #include <stdlib.h> |
| 8 | #include <unistd.h> | ||
| 8 | #include <errno.h> | 9 | #include <errno.h> |
| 9 | #include <signal.h> | 10 | #include <signal.h> |
| 10 | #include <string.h> | 11 | #include <string.h> |
| @@ -75,6 +76,26 @@ void setup_hostinfo(char *buf, int len) | |||
| 75 | host.release, host.version, host.machine); | 76 | host.release, host.version, host.machine); |
| 76 | } | 77 | } |
| 77 | 78 | ||
| 79 | /* | ||
| 80 | * We cannot use glibc's abort(). It makes use of tgkill() which | ||
| 81 | * has no effect within UML's kernel threads. | ||
| 82 | * After that glibc would execute an invalid instruction to kill | ||
| 83 | * the calling process and UML crashes with SIGSEGV. | ||
| 84 | */ | ||
| 85 | static inline void __attribute__ ((noreturn)) uml_abort(void) | ||
| 86 | { | ||
| 87 | sigset_t sig; | ||
| 88 | |||
| 89 | fflush(NULL); | ||
| 90 | |||
| 91 | if (!sigemptyset(&sig) && !sigaddset(&sig, SIGABRT)) | ||
| 92 | sigprocmask(SIG_UNBLOCK, &sig, 0); | ||
| 93 | |||
| 94 | for (;;) | ||
| 95 | if (kill(getpid(), SIGABRT) < 0) | ||
| 96 | exit(127); | ||
| 97 | } | ||
| 98 | |||
| 78 | void os_dump_core(void) | 99 | void os_dump_core(void) |
| 79 | { | 100 | { |
| 80 | int pid; | 101 | int pid; |
| @@ -116,5 +137,5 @@ void os_dump_core(void) | |||
| 116 | while ((pid = waitpid(-1, NULL, WNOHANG | __WALL)) > 0) | 137 | while ((pid = waitpid(-1, NULL, WNOHANG | __WALL)) > 0) |
| 117 | os_kill_ptraced_process(pid, 0); | 138 | os_kill_ptraced_process(pid, 0); |
| 118 | 139 | ||
| 119 | abort(); | 140 | uml_abort(); |
| 120 | } | 141 | } |
diff --git a/arch/x86/include/asm/pgtable_types.h b/arch/x86/include/asm/pgtable_types.h index 7db7723d1f32..d56187c6b838 100644 --- a/arch/x86/include/asm/pgtable_types.h +++ b/arch/x86/include/asm/pgtable_types.h | |||
| @@ -299,6 +299,7 @@ int phys_mem_access_prot_allowed(struct file *file, unsigned long pfn, | |||
| 299 | /* Install a pte for a particular vaddr in kernel space. */ | 299 | /* Install a pte for a particular vaddr in kernel space. */ |
| 300 | void set_pte_vaddr(unsigned long vaddr, pte_t pte); | 300 | void set_pte_vaddr(unsigned long vaddr, pte_t pte); |
| 301 | 301 | ||
| 302 | extern void native_pagetable_reserve(u64 start, u64 end); | ||
| 302 | #ifdef CONFIG_X86_32 | 303 | #ifdef CONFIG_X86_32 |
| 303 | extern void native_pagetable_setup_start(pgd_t *base); | 304 | extern void native_pagetable_setup_start(pgd_t *base); |
| 304 | extern void native_pagetable_setup_done(pgd_t *base); | 305 | extern void native_pagetable_setup_done(pgd_t *base); |
diff --git a/arch/x86/include/asm/x86_init.h b/arch/x86/include/asm/x86_init.h index 643ebf2e2ad8..d3d859035af9 100644 --- a/arch/x86/include/asm/x86_init.h +++ b/arch/x86/include/asm/x86_init.h | |||
| @@ -68,6 +68,17 @@ struct x86_init_oem { | |||
| 68 | }; | 68 | }; |
| 69 | 69 | ||
| 70 | /** | 70 | /** |
| 71 | * struct x86_init_mapping - platform specific initial kernel pagetable setup | ||
| 72 | * @pagetable_reserve: reserve a range of addresses for kernel pagetable usage | ||
| 73 | * | ||
| 74 | * For more details on the purpose of this hook, look in | ||
| 75 | * init_memory_mapping and the commit that added it. | ||
| 76 | */ | ||
| 77 | struct x86_init_mapping { | ||
| 78 | void (*pagetable_reserve)(u64 start, u64 end); | ||
| 79 | }; | ||
| 80 | |||
| 81 | /** | ||
| 71 | * struct x86_init_paging - platform specific paging functions | 82 | * struct x86_init_paging - platform specific paging functions |
| 72 | * @pagetable_setup_start: platform specific pre paging_init() call | 83 | * @pagetable_setup_start: platform specific pre paging_init() call |
| 73 | * @pagetable_setup_done: platform specific post paging_init() call | 84 | * @pagetable_setup_done: platform specific post paging_init() call |
| @@ -123,6 +134,7 @@ struct x86_init_ops { | |||
| 123 | struct x86_init_mpparse mpparse; | 134 | struct x86_init_mpparse mpparse; |
| 124 | struct x86_init_irqs irqs; | 135 | struct x86_init_irqs irqs; |
| 125 | struct x86_init_oem oem; | 136 | struct x86_init_oem oem; |
| 137 | struct x86_init_mapping mapping; | ||
| 126 | struct x86_init_paging paging; | 138 | struct x86_init_paging paging; |
| 127 | struct x86_init_timers timers; | 139 | struct x86_init_timers timers; |
| 128 | struct x86_init_iommu iommu; | 140 | struct x86_init_iommu iommu; |
diff --git a/arch/x86/kernel/x86_init.c b/arch/x86/kernel/x86_init.c index c11514e9128b..75ef4b18e9b7 100644 --- a/arch/x86/kernel/x86_init.c +++ b/arch/x86/kernel/x86_init.c | |||
| @@ -61,6 +61,10 @@ struct x86_init_ops x86_init __initdata = { | |||
| 61 | .banner = default_banner, | 61 | .banner = default_banner, |
| 62 | }, | 62 | }, |
| 63 | 63 | ||
| 64 | .mapping = { | ||
| 65 | .pagetable_reserve = native_pagetable_reserve, | ||
| 66 | }, | ||
| 67 | |||
| 64 | .paging = { | 68 | .paging = { |
| 65 | .pagetable_setup_start = native_pagetable_setup_start, | 69 | .pagetable_setup_start = native_pagetable_setup_start, |
| 66 | .pagetable_setup_done = native_pagetable_setup_done, | 70 | .pagetable_setup_done = native_pagetable_setup_done, |
diff --git a/arch/x86/mm/init.c b/arch/x86/mm/init.c index 286d289b039b..37b8b0fe8320 100644 --- a/arch/x86/mm/init.c +++ b/arch/x86/mm/init.c | |||
| @@ -81,6 +81,11 @@ static void __init find_early_table_space(unsigned long end, int use_pse, | |||
| 81 | end, pgt_buf_start << PAGE_SHIFT, pgt_buf_top << PAGE_SHIFT); | 81 | end, pgt_buf_start << PAGE_SHIFT, pgt_buf_top << PAGE_SHIFT); |
| 82 | } | 82 | } |
| 83 | 83 | ||
| 84 | void __init native_pagetable_reserve(u64 start, u64 end) | ||
| 85 | { | ||
| 86 | memblock_x86_reserve_range(start, end, "PGTABLE"); | ||
| 87 | } | ||
| 88 | |||
| 84 | struct map_range { | 89 | struct map_range { |
| 85 | unsigned long start; | 90 | unsigned long start; |
| 86 | unsigned long end; | 91 | unsigned long end; |
| @@ -272,9 +277,24 @@ unsigned long __init_refok init_memory_mapping(unsigned long start, | |||
| 272 | 277 | ||
| 273 | __flush_tlb_all(); | 278 | __flush_tlb_all(); |
| 274 | 279 | ||
| 280 | /* | ||
| 281 | * Reserve the kernel pagetable pages we used (pgt_buf_start - | ||
| 282 | * pgt_buf_end) and free the other ones (pgt_buf_end - pgt_buf_top) | ||
| 283 | * so that they can be reused for other purposes. | ||
| 284 | * | ||
| 285 | * On native it just means calling memblock_x86_reserve_range, on Xen it | ||
| 286 | * also means marking RW the pagetable pages that we allocated before | ||
| 287 | * but that haven't been used. | ||
| 288 | * | ||
| 289 | * In fact on xen we mark RO the whole range pgt_buf_start - | ||
| 290 | * pgt_buf_top, because we have to make sure that when | ||
| 291 | * init_memory_mapping reaches the pagetable pages area, it maps | ||
| 292 | * RO all the pagetable pages, including the ones that are beyond | ||
| 293 | * pgt_buf_end at that time. | ||
| 294 | */ | ||
| 275 | if (!after_bootmem && pgt_buf_end > pgt_buf_start) | 295 | if (!after_bootmem && pgt_buf_end > pgt_buf_start) |
| 276 | memblock_x86_reserve_range(pgt_buf_start << PAGE_SHIFT, | 296 | x86_init.mapping.pagetable_reserve(PFN_PHYS(pgt_buf_start), |
| 277 | pgt_buf_end << PAGE_SHIFT, "PGTABLE"); | 297 | PFN_PHYS(pgt_buf_end)); |
| 278 | 298 | ||
| 279 | if (!after_bootmem) | 299 | if (!after_bootmem) |
| 280 | early_memtest(start, end); | 300 | early_memtest(start, end); |
diff --git a/arch/x86/xen/mmu.c b/arch/x86/xen/mmu.c index 55c965b38c27..0684f3c74d53 100644 --- a/arch/x86/xen/mmu.c +++ b/arch/x86/xen/mmu.c | |||
| @@ -1275,6 +1275,20 @@ static __init void xen_pagetable_setup_start(pgd_t *base) | |||
| 1275 | { | 1275 | { |
| 1276 | } | 1276 | } |
| 1277 | 1277 | ||
| 1278 | static __init void xen_mapping_pagetable_reserve(u64 start, u64 end) | ||
| 1279 | { | ||
| 1280 | /* reserve the range used */ | ||
| 1281 | native_pagetable_reserve(start, end); | ||
| 1282 | |||
| 1283 | /* set as RW the rest */ | ||
| 1284 | printk(KERN_DEBUG "xen: setting RW the range %llx - %llx\n", end, | ||
| 1285 | PFN_PHYS(pgt_buf_top)); | ||
| 1286 | while (end < PFN_PHYS(pgt_buf_top)) { | ||
| 1287 | make_lowmem_page_readwrite(__va(end)); | ||
| 1288 | end += PAGE_SIZE; | ||
| 1289 | } | ||
| 1290 | } | ||
| 1291 | |||
| 1278 | static void xen_post_allocator_init(void); | 1292 | static void xen_post_allocator_init(void); |
| 1279 | 1293 | ||
| 1280 | static __init void xen_pagetable_setup_done(pgd_t *base) | 1294 | static __init void xen_pagetable_setup_done(pgd_t *base) |
| @@ -1463,119 +1477,6 @@ static int xen_pgd_alloc(struct mm_struct *mm) | |||
| 1463 | return ret; | 1477 | return ret; |
| 1464 | } | 1478 | } |
| 1465 | 1479 | ||
| 1466 | #ifdef CONFIG_X86_64 | ||
| 1467 | static __initdata u64 __last_pgt_set_rw = 0; | ||
| 1468 | static __initdata u64 __pgt_buf_start = 0; | ||
| 1469 | static __initdata u64 __pgt_buf_end = 0; | ||
| 1470 | static __initdata u64 __pgt_buf_top = 0; | ||
| 1471 | /* | ||
| 1472 | * As a consequence of the commit: | ||
| 1473 | * | ||
| 1474 | * commit 4b239f458c229de044d6905c2b0f9fe16ed9e01e | ||
| 1475 | * Author: Yinghai Lu <yinghai@kernel.org> | ||
| 1476 | * Date: Fri Dec 17 16:58:28 2010 -0800 | ||
| 1477 | * | ||
| 1478 | * x86-64, mm: Put early page table high | ||
| 1479 | * | ||
| 1480 | * at some point init_memory_mapping is going to reach the pagetable pages | ||
| 1481 | * area and map those pages too (mapping them as normal memory that falls | ||
| 1482 | * in the range of addresses passed to init_memory_mapping as argument). | ||
| 1483 | * Some of those pages are already pagetable pages (they are in the range | ||
| 1484 | * pgt_buf_start-pgt_buf_end) therefore they are going to be mapped RO and | ||
| 1485 | * everything is fine. | ||
| 1486 | * Some of these pages are not pagetable pages yet (they fall in the range | ||
| 1487 | * pgt_buf_end-pgt_buf_top; for example the page at pgt_buf_end) so they | ||
| 1488 | * are going to be mapped RW. When these pages become pagetable pages and | ||
| 1489 | * are hooked into the pagetable, xen will find that the guest has already | ||
| 1490 | * a RW mapping of them somewhere and fail the operation. | ||
| 1491 | * The reason Xen requires pagetables to be RO is that the hypervisor needs | ||
| 1492 | * to verify that the pagetables are valid before using them. The validation | ||
| 1493 | * operations are called "pinning". | ||
| 1494 | * | ||
| 1495 | * In order to fix the issue we mark all the pages in the entire range | ||
| 1496 | * pgt_buf_start-pgt_buf_top as RO, however when the pagetable allocation | ||
| 1497 | * is completed only the range pgt_buf_start-pgt_buf_end is reserved by | ||
| 1498 | * init_memory_mapping. Hence the kernel is going to crash as soon as one | ||
| 1499 | * of the pages in the range pgt_buf_end-pgt_buf_top is reused (b/c those | ||
| 1500 | * ranges are RO). | ||
| 1501 | * | ||
| 1502 | * For this reason, 'mark_rw_past_pgt' is introduced which is called _after_ | ||
| 1503 | * the init_memory_mapping has completed (in a perfect world we would | ||
| 1504 | * call this function from init_memory_mapping, but lets ignore that). | ||
| 1505 | * | ||
| 1506 | * Because we are called _after_ init_memory_mapping the pgt_buf_[start, | ||
| 1507 | * end,top] have all changed to new values (b/c init_memory_mapping | ||
| 1508 | * is called and setting up another new page-table). Hence, the first time | ||
| 1509 | * we enter this function, we save away the pgt_buf_start value and update | ||
| 1510 | * the pgt_buf_[end,top]. | ||
| 1511 | * | ||
| 1512 | * When we detect that the "old" pgt_buf_start through pgt_buf_end | ||
| 1513 | * PFNs have been reserved (so memblock_x86_reserve_range has been called), | ||
| 1514 | * we immediately set out to RW the "old" pgt_buf_end through pgt_buf_top. | ||
| 1515 | * | ||
| 1516 | * And then we update those "old" pgt_buf_[end|top] with the new ones | ||
| 1517 | * so that we can redo this on the next pagetable. | ||
| 1518 | */ | ||
| 1519 | static __init void mark_rw_past_pgt(void) { | ||
| 1520 | |||
| 1521 | if (pgt_buf_end > pgt_buf_start) { | ||
| 1522 | u64 addr, size; | ||
| 1523 | |||
| 1524 | /* Save it away. */ | ||
| 1525 | if (!__pgt_buf_start) { | ||
| 1526 | __pgt_buf_start = pgt_buf_start; | ||
| 1527 | __pgt_buf_end = pgt_buf_end; | ||
| 1528 | __pgt_buf_top = pgt_buf_top; | ||
| 1529 | return; | ||
| 1530 | } | ||
| 1531 | /* If we get the range that starts at __pgt_buf_end that means | ||
| 1532 | * the range is reserved, and that in 'init_memory_mapping' | ||
| 1533 | * the 'memblock_x86_reserve_range' has been called with the | ||
| 1534 | * outdated __pgt_buf_start, __pgt_buf_end (the "new" | ||
| 1535 | * pgt_buf_[start|end|top] refer now to a new pagetable. | ||
| 1536 | * Note: we are called _after_ the pgt_buf_[..] have been | ||
| 1537 | * updated.*/ | ||
| 1538 | |||
| 1539 | addr = memblock_x86_find_in_range_size(PFN_PHYS(__pgt_buf_start), | ||
| 1540 | &size, PAGE_SIZE); | ||
| 1541 | |||
| 1542 | /* Still not reserved, meaning 'memblock_x86_reserve_range' | ||
| 1543 | * hasn't been called yet. Update the _end and _top.*/ | ||
| 1544 | if (addr == PFN_PHYS(__pgt_buf_start)) { | ||
| 1545 | __pgt_buf_end = pgt_buf_end; | ||
| 1546 | __pgt_buf_top = pgt_buf_top; | ||
| 1547 | return; | ||
| 1548 | } | ||
| 1549 | |||
| 1550 | /* OK, the area is reserved, meaning it is time for us to | ||
| 1551 | * set RW for the old end->top PFNs. */ | ||
| 1552 | |||
| 1553 | /* ..unless we had already done this. */ | ||
| 1554 | if (__pgt_buf_end == __last_pgt_set_rw) | ||
| 1555 | return; | ||
| 1556 | |||
| 1557 | addr = PFN_PHYS(__pgt_buf_end); | ||
| 1558 | |||
| 1559 | /* set as RW the rest */ | ||
| 1560 | printk(KERN_DEBUG "xen: setting RW the range %llx - %llx\n", | ||
| 1561 | PFN_PHYS(__pgt_buf_end), PFN_PHYS(__pgt_buf_top)); | ||
| 1562 | |||
| 1563 | while (addr < PFN_PHYS(__pgt_buf_top)) { | ||
| 1564 | make_lowmem_page_readwrite(__va(addr)); | ||
| 1565 | addr += PAGE_SIZE; | ||
| 1566 | } | ||
| 1567 | /* And update everything so that we are ready for the next | ||
| 1568 | * pagetable (the one created for regions past 4GB) */ | ||
| 1569 | __last_pgt_set_rw = __pgt_buf_end; | ||
| 1570 | __pgt_buf_start = pgt_buf_start; | ||
| 1571 | __pgt_buf_end = pgt_buf_end; | ||
| 1572 | __pgt_buf_top = pgt_buf_top; | ||
| 1573 | } | ||
| 1574 | return; | ||
| 1575 | } | ||
| 1576 | #else | ||
| 1577 | static __init void mark_rw_past_pgt(void) { } | ||
| 1578 | #endif | ||
| 1579 | static void xen_pgd_free(struct mm_struct *mm, pgd_t *pgd) | 1480 | static void xen_pgd_free(struct mm_struct *mm, pgd_t *pgd) |
| 1580 | { | 1481 | { |
| 1581 | #ifdef CONFIG_X86_64 | 1482 | #ifdef CONFIG_X86_64 |
| @@ -1602,14 +1503,6 @@ static __init pte_t mask_rw_pte(pte_t *ptep, pte_t pte) | |||
| 1602 | unsigned long pfn = pte_pfn(pte); | 1503 | unsigned long pfn = pte_pfn(pte); |
| 1603 | 1504 | ||
| 1604 | /* | 1505 | /* |
| 1605 | * A bit of optimization. We do not need to call the workaround | ||
| 1606 | * when xen_set_pte_init is called with a PTE with 0 as PFN. | ||
| 1607 | * That is b/c the pagetable at that point are just being populated | ||
| 1608 | * with empty values and we can save some cycles by not calling | ||
| 1609 | * the 'memblock' code.*/ | ||
| 1610 | if (pfn) | ||
| 1611 | mark_rw_past_pgt(); | ||
| 1612 | /* | ||
| 1613 | * If the new pfn is within the range of the newly allocated | 1506 | * If the new pfn is within the range of the newly allocated |
| 1614 | * kernel pagetable, and it isn't being mapped into an | 1507 | * kernel pagetable, and it isn't being mapped into an |
| 1615 | * early_ioremap fixmap slot as a freshly allocated page, make sure | 1508 | * early_ioremap fixmap slot as a freshly allocated page, make sure |
| @@ -2118,8 +2011,6 @@ __init void xen_ident_map_ISA(void) | |||
| 2118 | 2011 | ||
| 2119 | static __init void xen_post_allocator_init(void) | 2012 | static __init void xen_post_allocator_init(void) |
| 2120 | { | 2013 | { |
| 2121 | mark_rw_past_pgt(); | ||
| 2122 | |||
| 2123 | #ifdef CONFIG_XEN_DEBUG | 2014 | #ifdef CONFIG_XEN_DEBUG |
| 2124 | pv_mmu_ops.make_pte = PV_CALLEE_SAVE(xen_make_pte_debug); | 2015 | pv_mmu_ops.make_pte = PV_CALLEE_SAVE(xen_make_pte_debug); |
| 2125 | #endif | 2016 | #endif |
| @@ -2228,6 +2119,7 @@ static const struct pv_mmu_ops xen_mmu_ops __initdata = { | |||
| 2228 | 2119 | ||
| 2229 | void __init xen_init_mmu_ops(void) | 2120 | void __init xen_init_mmu_ops(void) |
| 2230 | { | 2121 | { |
| 2122 | x86_init.mapping.pagetable_reserve = xen_mapping_pagetable_reserve; | ||
| 2231 | x86_init.paging.pagetable_setup_start = xen_pagetable_setup_start; | 2123 | x86_init.paging.pagetable_setup_start = xen_pagetable_setup_start; |
| 2232 | x86_init.paging.pagetable_setup_done = xen_pagetable_setup_done; | 2124 | x86_init.paging.pagetable_setup_done = xen_pagetable_setup_done; |
| 2233 | pv_mmu_ops = xen_mmu_ops; | 2125 | pv_mmu_ops = xen_mmu_ops; |
diff --git a/drivers/ata/libahci.c b/drivers/ata/libahci.c index ff9d832a163d..d38c40fe4ddb 100644 --- a/drivers/ata/libahci.c +++ b/drivers/ata/libahci.c | |||
| @@ -561,27 +561,6 @@ void ahci_start_engine(struct ata_port *ap) | |||
| 561 | { | 561 | { |
| 562 | void __iomem *port_mmio = ahci_port_base(ap); | 562 | void __iomem *port_mmio = ahci_port_base(ap); |
| 563 | u32 tmp; | 563 | u32 tmp; |
| 564 | u8 status; | ||
| 565 | |||
| 566 | status = readl(port_mmio + PORT_TFDATA) & 0xFF; | ||
| 567 | |||
| 568 | /* | ||
| 569 | * At end of section 10.1 of AHCI spec (rev 1.3), it states | ||
| 570 | * Software shall not set PxCMD.ST to 1 until it is determined | ||
| 571 | * that a functoinal device is present on the port as determined by | ||
| 572 | * PxTFD.STS.BSY=0, PxTFD.STS.DRQ=0 and PxSSTS.DET=3h | ||
| 573 | * | ||
| 574 | * Even though most AHCI host controllers work without this check, | ||
| 575 | * specific controller will fail under this condition | ||
| 576 | */ | ||
| 577 | if (status & (ATA_BUSY | ATA_DRQ)) | ||
| 578 | return; | ||
| 579 | else { | ||
| 580 | ahci_scr_read(&ap->link, SCR_STATUS, &tmp); | ||
| 581 | |||
| 582 | if ((tmp & 0xf) != 0x3) | ||
| 583 | return; | ||
| 584 | } | ||
| 585 | 564 | ||
| 586 | /* start DMA */ | 565 | /* start DMA */ |
| 587 | tmp = readl(port_mmio + PORT_CMD); | 566 | tmp = readl(port_mmio + PORT_CMD); |
diff --git a/drivers/ata/libata-eh.c b/drivers/ata/libata-eh.c index f26f2fe3480a..dad9fd660f37 100644 --- a/drivers/ata/libata-eh.c +++ b/drivers/ata/libata-eh.c | |||
| @@ -3316,7 +3316,7 @@ static int ata_eh_set_lpm(struct ata_link *link, enum ata_lpm_policy policy, | |||
| 3316 | struct ata_eh_context *ehc = &link->eh_context; | 3316 | struct ata_eh_context *ehc = &link->eh_context; |
| 3317 | struct ata_device *dev, *link_dev = NULL, *lpm_dev = NULL; | 3317 | struct ata_device *dev, *link_dev = NULL, *lpm_dev = NULL; |
| 3318 | enum ata_lpm_policy old_policy = link->lpm_policy; | 3318 | enum ata_lpm_policy old_policy = link->lpm_policy; |
| 3319 | bool no_dipm = ap->flags & ATA_FLAG_NO_DIPM; | 3319 | bool no_dipm = link->ap->flags & ATA_FLAG_NO_DIPM; |
| 3320 | unsigned int hints = ATA_LPM_EMPTY | ATA_LPM_HIPM; | 3320 | unsigned int hints = ATA_LPM_EMPTY | ATA_LPM_HIPM; |
| 3321 | unsigned int err_mask; | 3321 | unsigned int err_mask; |
| 3322 | int rc; | 3322 | int rc; |
diff --git a/drivers/block/rbd.c b/drivers/block/rbd.c index 3e904717c1c0..9712fad82bc6 100644 --- a/drivers/block/rbd.c +++ b/drivers/block/rbd.c | |||
| @@ -92,6 +92,8 @@ struct rbd_client { | |||
| 92 | struct list_head node; | 92 | struct list_head node; |
| 93 | }; | 93 | }; |
| 94 | 94 | ||
| 95 | struct rbd_req_coll; | ||
| 96 | |||
| 95 | /* | 97 | /* |
| 96 | * a single io request | 98 | * a single io request |
| 97 | */ | 99 | */ |
| @@ -100,6 +102,24 @@ struct rbd_request { | |||
| 100 | struct bio *bio; /* cloned bio */ | 102 | struct bio *bio; /* cloned bio */ |
| 101 | struct page **pages; /* list of used pages */ | 103 | struct page **pages; /* list of used pages */ |
| 102 | u64 len; | 104 | u64 len; |
| 105 | int coll_index; | ||
| 106 | struct rbd_req_coll *coll; | ||
| 107 | }; | ||
| 108 | |||
| 109 | struct rbd_req_status { | ||
| 110 | int done; | ||
| 111 | int rc; | ||
| 112 | u64 bytes; | ||
| 113 | }; | ||
| 114 | |||
| 115 | /* | ||
| 116 | * a collection of requests | ||
| 117 | */ | ||
| 118 | struct rbd_req_coll { | ||
| 119 | int total; | ||
| 120 | int num_done; | ||
| 121 | struct kref kref; | ||
| 122 | struct rbd_req_status status[0]; | ||
| 103 | }; | 123 | }; |
| 104 | 124 | ||
| 105 | struct rbd_snap { | 125 | struct rbd_snap { |
| @@ -416,6 +436,17 @@ static void rbd_put_client(struct rbd_device *rbd_dev) | |||
| 416 | rbd_dev->client = NULL; | 436 | rbd_dev->client = NULL; |
| 417 | } | 437 | } |
| 418 | 438 | ||
| 439 | /* | ||
| 440 | * Destroy requests collection | ||
| 441 | */ | ||
| 442 | static void rbd_coll_release(struct kref *kref) | ||
| 443 | { | ||
| 444 | struct rbd_req_coll *coll = | ||
| 445 | container_of(kref, struct rbd_req_coll, kref); | ||
| 446 | |||
| 447 | dout("rbd_coll_release %p\n", coll); | ||
| 448 | kfree(coll); | ||
| 449 | } | ||
| 419 | 450 | ||
| 420 | /* | 451 | /* |
| 421 | * Create a new header structure, translate header format from the on-disk | 452 | * Create a new header structure, translate header format from the on-disk |
| @@ -590,6 +621,14 @@ static u64 rbd_get_segment(struct rbd_image_header *header, | |||
| 590 | return len; | 621 | return len; |
| 591 | } | 622 | } |
| 592 | 623 | ||
| 624 | static int rbd_get_num_segments(struct rbd_image_header *header, | ||
| 625 | u64 ofs, u64 len) | ||
| 626 | { | ||
| 627 | u64 start_seg = ofs >> header->obj_order; | ||
| 628 | u64 end_seg = (ofs + len - 1) >> header->obj_order; | ||
| 629 | return end_seg - start_seg + 1; | ||
| 630 | } | ||
| 631 | |||
| 593 | /* | 632 | /* |
| 594 | * bio helpers | 633 | * bio helpers |
| 595 | */ | 634 | */ |
| @@ -735,6 +774,50 @@ static void rbd_destroy_ops(struct ceph_osd_req_op *ops) | |||
| 735 | kfree(ops); | 774 | kfree(ops); |
| 736 | } | 775 | } |
| 737 | 776 | ||
| 777 | static void rbd_coll_end_req_index(struct request *rq, | ||
| 778 | struct rbd_req_coll *coll, | ||
| 779 | int index, | ||
| 780 | int ret, u64 len) | ||
| 781 | { | ||
| 782 | struct request_queue *q; | ||
| 783 | int min, max, i; | ||
| 784 | |||
| 785 | dout("rbd_coll_end_req_index %p index %d ret %d len %lld\n", | ||
| 786 | coll, index, ret, len); | ||
| 787 | |||
| 788 | if (!rq) | ||
| 789 | return; | ||
| 790 | |||
| 791 | if (!coll) { | ||
| 792 | blk_end_request(rq, ret, len); | ||
| 793 | return; | ||
| 794 | } | ||
| 795 | |||
| 796 | q = rq->q; | ||
| 797 | |||
| 798 | spin_lock_irq(q->queue_lock); | ||
| 799 | coll->status[index].done = 1; | ||
| 800 | coll->status[index].rc = ret; | ||
| 801 | coll->status[index].bytes = len; | ||
| 802 | max = min = coll->num_done; | ||
| 803 | while (max < coll->total && coll->status[max].done) | ||
| 804 | max++; | ||
| 805 | |||
| 806 | for (i = min; i<max; i++) { | ||
| 807 | __blk_end_request(rq, coll->status[i].rc, | ||
| 808 | coll->status[i].bytes); | ||
| 809 | coll->num_done++; | ||
| 810 | kref_put(&coll->kref, rbd_coll_release); | ||
| 811 | } | ||
| 812 | spin_unlock_irq(q->queue_lock); | ||
| 813 | } | ||
| 814 | |||
| 815 | static void rbd_coll_end_req(struct rbd_request *req, | ||
| 816 | int ret, u64 len) | ||
| 817 | { | ||
| 818 | rbd_coll_end_req_index(req->rq, req->coll, req->coll_index, ret, len); | ||
| 819 | } | ||
| 820 | |||
| 738 | /* | 821 | /* |
| 739 | * Send ceph osd request | 822 | * Send ceph osd request |
| 740 | */ | 823 | */ |
| @@ -749,6 +832,8 @@ static int rbd_do_request(struct request *rq, | |||
| 749 | int flags, | 832 | int flags, |
| 750 | struct ceph_osd_req_op *ops, | 833 | struct ceph_osd_req_op *ops, |
| 751 | int num_reply, | 834 | int num_reply, |
| 835 | struct rbd_req_coll *coll, | ||
| 836 | int coll_index, | ||
| 752 | void (*rbd_cb)(struct ceph_osd_request *req, | 837 | void (*rbd_cb)(struct ceph_osd_request *req, |
| 753 | struct ceph_msg *msg), | 838 | struct ceph_msg *msg), |
| 754 | struct ceph_osd_request **linger_req, | 839 | struct ceph_osd_request **linger_req, |
| @@ -763,12 +848,20 @@ static int rbd_do_request(struct request *rq, | |||
| 763 | struct ceph_osd_request_head *reqhead; | 848 | struct ceph_osd_request_head *reqhead; |
| 764 | struct rbd_image_header *header = &dev->header; | 849 | struct rbd_image_header *header = &dev->header; |
| 765 | 850 | ||
| 766 | ret = -ENOMEM; | ||
| 767 | req_data = kzalloc(sizeof(*req_data), GFP_NOIO); | 851 | req_data = kzalloc(sizeof(*req_data), GFP_NOIO); |
| 768 | if (!req_data) | 852 | if (!req_data) { |
| 769 | goto done; | 853 | if (coll) |
| 854 | rbd_coll_end_req_index(rq, coll, coll_index, | ||
| 855 | -ENOMEM, len); | ||
| 856 | return -ENOMEM; | ||
| 857 | } | ||
| 770 | 858 | ||
| 771 | dout("rbd_do_request len=%lld ofs=%lld\n", len, ofs); | 859 | if (coll) { |
| 860 | req_data->coll = coll; | ||
| 861 | req_data->coll_index = coll_index; | ||
| 862 | } | ||
| 863 | |||
| 864 | dout("rbd_do_request obj=%s ofs=%lld len=%lld\n", obj, len, ofs); | ||
| 772 | 865 | ||
| 773 | down_read(&header->snap_rwsem); | 866 | down_read(&header->snap_rwsem); |
| 774 | 867 | ||
| @@ -828,7 +921,8 @@ static int rbd_do_request(struct request *rq, | |||
| 828 | ret = ceph_osdc_wait_request(&dev->client->osdc, req); | 921 | ret = ceph_osdc_wait_request(&dev->client->osdc, req); |
| 829 | if (ver) | 922 | if (ver) |
| 830 | *ver = le64_to_cpu(req->r_reassert_version.version); | 923 | *ver = le64_to_cpu(req->r_reassert_version.version); |
| 831 | dout("reassert_ver=%lld\n", le64_to_cpu(req->r_reassert_version.version)); | 924 | dout("reassert_ver=%lld\n", |
| 925 | le64_to_cpu(req->r_reassert_version.version)); | ||
| 832 | ceph_osdc_put_request(req); | 926 | ceph_osdc_put_request(req); |
| 833 | } | 927 | } |
| 834 | return ret; | 928 | return ret; |
| @@ -837,10 +931,8 @@ done_err: | |||
| 837 | bio_chain_put(req_data->bio); | 931 | bio_chain_put(req_data->bio); |
| 838 | ceph_osdc_put_request(req); | 932 | ceph_osdc_put_request(req); |
| 839 | done_pages: | 933 | done_pages: |
| 934 | rbd_coll_end_req(req_data, ret, len); | ||
| 840 | kfree(req_data); | 935 | kfree(req_data); |
| 841 | done: | ||
| 842 | if (rq) | ||
| 843 | blk_end_request(rq, ret, len); | ||
| 844 | return ret; | 936 | return ret; |
| 845 | } | 937 | } |
| 846 | 938 | ||
| @@ -874,7 +966,7 @@ static void rbd_req_cb(struct ceph_osd_request *req, struct ceph_msg *msg) | |||
| 874 | bytes = req_data->len; | 966 | bytes = req_data->len; |
| 875 | } | 967 | } |
| 876 | 968 | ||
| 877 | blk_end_request(req_data->rq, rc, bytes); | 969 | rbd_coll_end_req(req_data, rc, bytes); |
| 878 | 970 | ||
| 879 | if (req_data->bio) | 971 | if (req_data->bio) |
| 880 | bio_chain_put(req_data->bio); | 972 | bio_chain_put(req_data->bio); |
| @@ -934,6 +1026,7 @@ static int rbd_req_sync_op(struct rbd_device *dev, | |||
| 934 | flags, | 1026 | flags, |
| 935 | ops, | 1027 | ops, |
| 936 | 2, | 1028 | 2, |
| 1029 | NULL, 0, | ||
| 937 | NULL, | 1030 | NULL, |
| 938 | linger_req, ver); | 1031 | linger_req, ver); |
| 939 | if (ret < 0) | 1032 | if (ret < 0) |
| @@ -959,7 +1052,9 @@ static int rbd_do_op(struct request *rq, | |||
| 959 | u64 snapid, | 1052 | u64 snapid, |
| 960 | int opcode, int flags, int num_reply, | 1053 | int opcode, int flags, int num_reply, |
| 961 | u64 ofs, u64 len, | 1054 | u64 ofs, u64 len, |
| 962 | struct bio *bio) | 1055 | struct bio *bio, |
| 1056 | struct rbd_req_coll *coll, | ||
| 1057 | int coll_index) | ||
| 963 | { | 1058 | { |
| 964 | char *seg_name; | 1059 | char *seg_name; |
| 965 | u64 seg_ofs; | 1060 | u64 seg_ofs; |
| @@ -995,7 +1090,10 @@ static int rbd_do_op(struct request *rq, | |||
| 995 | flags, | 1090 | flags, |
| 996 | ops, | 1091 | ops, |
| 997 | num_reply, | 1092 | num_reply, |
| 1093 | coll, coll_index, | ||
| 998 | rbd_req_cb, 0, NULL); | 1094 | rbd_req_cb, 0, NULL); |
| 1095 | |||
| 1096 | rbd_destroy_ops(ops); | ||
| 999 | done: | 1097 | done: |
| 1000 | kfree(seg_name); | 1098 | kfree(seg_name); |
| 1001 | return ret; | 1099 | return ret; |
| @@ -1008,13 +1106,15 @@ static int rbd_req_write(struct request *rq, | |||
| 1008 | struct rbd_device *rbd_dev, | 1106 | struct rbd_device *rbd_dev, |
| 1009 | struct ceph_snap_context *snapc, | 1107 | struct ceph_snap_context *snapc, |
| 1010 | u64 ofs, u64 len, | 1108 | u64 ofs, u64 len, |
| 1011 | struct bio *bio) | 1109 | struct bio *bio, |
| 1110 | struct rbd_req_coll *coll, | ||
| 1111 | int coll_index) | ||
| 1012 | { | 1112 | { |
| 1013 | return rbd_do_op(rq, rbd_dev, snapc, CEPH_NOSNAP, | 1113 | return rbd_do_op(rq, rbd_dev, snapc, CEPH_NOSNAP, |
| 1014 | CEPH_OSD_OP_WRITE, | 1114 | CEPH_OSD_OP_WRITE, |
| 1015 | CEPH_OSD_FLAG_WRITE | CEPH_OSD_FLAG_ONDISK, | 1115 | CEPH_OSD_FLAG_WRITE | CEPH_OSD_FLAG_ONDISK, |
| 1016 | 2, | 1116 | 2, |
| 1017 | ofs, len, bio); | 1117 | ofs, len, bio, coll, coll_index); |
| 1018 | } | 1118 | } |
| 1019 | 1119 | ||
| 1020 | /* | 1120 | /* |
| @@ -1024,14 +1124,16 @@ static int rbd_req_read(struct request *rq, | |||
| 1024 | struct rbd_device *rbd_dev, | 1124 | struct rbd_device *rbd_dev, |
| 1025 | u64 snapid, | 1125 | u64 snapid, |
| 1026 | u64 ofs, u64 len, | 1126 | u64 ofs, u64 len, |
| 1027 | struct bio *bio) | 1127 | struct bio *bio, |
| 1128 | struct rbd_req_coll *coll, | ||
| 1129 | int coll_index) | ||
| 1028 | { | 1130 | { |
| 1029 | return rbd_do_op(rq, rbd_dev, NULL, | 1131 | return rbd_do_op(rq, rbd_dev, NULL, |
| 1030 | (snapid ? snapid : CEPH_NOSNAP), | 1132 | (snapid ? snapid : CEPH_NOSNAP), |
| 1031 | CEPH_OSD_OP_READ, | 1133 | CEPH_OSD_OP_READ, |
| 1032 | CEPH_OSD_FLAG_READ, | 1134 | CEPH_OSD_FLAG_READ, |
| 1033 | 2, | 1135 | 2, |
| 1034 | ofs, len, bio); | 1136 | ofs, len, bio, coll, coll_index); |
| 1035 | } | 1137 | } |
| 1036 | 1138 | ||
| 1037 | /* | 1139 | /* |
| @@ -1063,7 +1165,9 @@ static int rbd_req_sync_notify_ack(struct rbd_device *dev, | |||
| 1063 | { | 1165 | { |
| 1064 | struct ceph_osd_req_op *ops; | 1166 | struct ceph_osd_req_op *ops; |
| 1065 | struct page **pages = NULL; | 1167 | struct page **pages = NULL; |
| 1066 | int ret = rbd_create_rw_ops(&ops, 1, CEPH_OSD_OP_NOTIFY_ACK, 0); | 1168 | int ret; |
| 1169 | |||
| 1170 | ret = rbd_create_rw_ops(&ops, 1, CEPH_OSD_OP_NOTIFY_ACK, 0); | ||
| 1067 | if (ret < 0) | 1171 | if (ret < 0) |
| 1068 | return ret; | 1172 | return ret; |
| 1069 | 1173 | ||
| @@ -1077,6 +1181,7 @@ static int rbd_req_sync_notify_ack(struct rbd_device *dev, | |||
| 1077 | CEPH_OSD_FLAG_READ, | 1181 | CEPH_OSD_FLAG_READ, |
| 1078 | ops, | 1182 | ops, |
| 1079 | 1, | 1183 | 1, |
| 1184 | NULL, 0, | ||
| 1080 | rbd_simple_req_cb, 0, NULL); | 1185 | rbd_simple_req_cb, 0, NULL); |
| 1081 | 1186 | ||
| 1082 | rbd_destroy_ops(ops); | 1187 | rbd_destroy_ops(ops); |
| @@ -1274,6 +1379,20 @@ static int rbd_req_sync_exec(struct rbd_device *dev, | |||
| 1274 | return ret; | 1379 | return ret; |
| 1275 | } | 1380 | } |
| 1276 | 1381 | ||
| 1382 | static struct rbd_req_coll *rbd_alloc_coll(int num_reqs) | ||
| 1383 | { | ||
| 1384 | struct rbd_req_coll *coll = | ||
| 1385 | kzalloc(sizeof(struct rbd_req_coll) + | ||
| 1386 | sizeof(struct rbd_req_status) * num_reqs, | ||
| 1387 | GFP_ATOMIC); | ||
| 1388 | |||
| 1389 | if (!coll) | ||
| 1390 | return NULL; | ||
| 1391 | coll->total = num_reqs; | ||
| 1392 | kref_init(&coll->kref); | ||
| 1393 | return coll; | ||
| 1394 | } | ||
| 1395 | |||
| 1277 | /* | 1396 | /* |
| 1278 | * block device queue callback | 1397 | * block device queue callback |
| 1279 | */ | 1398 | */ |
| @@ -1291,6 +1410,8 @@ static void rbd_rq_fn(struct request_queue *q) | |||
| 1291 | bool do_write; | 1410 | bool do_write; |
| 1292 | int size, op_size = 0; | 1411 | int size, op_size = 0; |
| 1293 | u64 ofs; | 1412 | u64 ofs; |
| 1413 | int num_segs, cur_seg = 0; | ||
| 1414 | struct rbd_req_coll *coll; | ||
| 1294 | 1415 | ||
| 1295 | /* peek at request from block layer */ | 1416 | /* peek at request from block layer */ |
| 1296 | if (!rq) | 1417 | if (!rq) |
| @@ -1321,6 +1442,14 @@ static void rbd_rq_fn(struct request_queue *q) | |||
| 1321 | do_write ? "write" : "read", | 1442 | do_write ? "write" : "read", |
| 1322 | size, blk_rq_pos(rq) * 512ULL); | 1443 | size, blk_rq_pos(rq) * 512ULL); |
| 1323 | 1444 | ||
| 1445 | num_segs = rbd_get_num_segments(&rbd_dev->header, ofs, size); | ||
| 1446 | coll = rbd_alloc_coll(num_segs); | ||
| 1447 | if (!coll) { | ||
| 1448 | spin_lock_irq(q->queue_lock); | ||
| 1449 | __blk_end_request_all(rq, -ENOMEM); | ||
| 1450 | goto next; | ||
| 1451 | } | ||
| 1452 | |||
| 1324 | do { | 1453 | do { |
| 1325 | /* a bio clone to be passed down to OSD req */ | 1454 | /* a bio clone to be passed down to OSD req */ |
| 1326 | dout("rq->bio->bi_vcnt=%d\n", rq->bio->bi_vcnt); | 1455 | dout("rq->bio->bi_vcnt=%d\n", rq->bio->bi_vcnt); |
| @@ -1328,35 +1457,41 @@ static void rbd_rq_fn(struct request_queue *q) | |||
| 1328 | rbd_dev->header.block_name, | 1457 | rbd_dev->header.block_name, |
| 1329 | ofs, size, | 1458 | ofs, size, |
| 1330 | NULL, NULL); | 1459 | NULL, NULL); |
| 1460 | kref_get(&coll->kref); | ||
| 1331 | bio = bio_chain_clone(&rq_bio, &next_bio, &bp, | 1461 | bio = bio_chain_clone(&rq_bio, &next_bio, &bp, |
| 1332 | op_size, GFP_ATOMIC); | 1462 | op_size, GFP_ATOMIC); |
| 1333 | if (!bio) { | 1463 | if (!bio) { |
| 1334 | spin_lock_irq(q->queue_lock); | 1464 | rbd_coll_end_req_index(rq, coll, cur_seg, |
| 1335 | __blk_end_request_all(rq, -ENOMEM); | 1465 | -ENOMEM, op_size); |
| 1336 | goto next; | 1466 | goto next_seg; |
| 1337 | } | 1467 | } |
| 1338 | 1468 | ||
| 1469 | |||
| 1339 | /* init OSD command: write or read */ | 1470 | /* init OSD command: write or read */ |
| 1340 | if (do_write) | 1471 | if (do_write) |
| 1341 | rbd_req_write(rq, rbd_dev, | 1472 | rbd_req_write(rq, rbd_dev, |
| 1342 | rbd_dev->header.snapc, | 1473 | rbd_dev->header.snapc, |
| 1343 | ofs, | 1474 | ofs, |
| 1344 | op_size, bio); | 1475 | op_size, bio, |
| 1476 | coll, cur_seg); | ||
| 1345 | else | 1477 | else |
| 1346 | rbd_req_read(rq, rbd_dev, | 1478 | rbd_req_read(rq, rbd_dev, |
| 1347 | cur_snap_id(rbd_dev), | 1479 | cur_snap_id(rbd_dev), |
| 1348 | ofs, | 1480 | ofs, |
| 1349 | op_size, bio); | 1481 | op_size, bio, |
| 1482 | coll, cur_seg); | ||
| 1350 | 1483 | ||
| 1484 | next_seg: | ||
| 1351 | size -= op_size; | 1485 | size -= op_size; |
| 1352 | ofs += op_size; | 1486 | ofs += op_size; |
| 1353 | 1487 | ||
| 1488 | cur_seg++; | ||
| 1354 | rq_bio = next_bio; | 1489 | rq_bio = next_bio; |
| 1355 | } while (size > 0); | 1490 | } while (size > 0); |
| 1491 | kref_put(&coll->kref, rbd_coll_release); | ||
| 1356 | 1492 | ||
| 1357 | if (bp) | 1493 | if (bp) |
| 1358 | bio_pair_release(bp); | 1494 | bio_pair_release(bp); |
| 1359 | |||
| 1360 | spin_lock_irq(q->queue_lock); | 1495 | spin_lock_irq(q->queue_lock); |
| 1361 | next: | 1496 | next: |
| 1362 | rq = blk_fetch_request(q); | 1497 | rq = blk_fetch_request(q); |
diff --git a/drivers/gpu/drm/drm_fb_helper.c b/drivers/gpu/drm/drm_fb_helper.c index 11d7a72c22d9..140b9525b48a 100644 --- a/drivers/gpu/drm/drm_fb_helper.c +++ b/drivers/gpu/drm/drm_fb_helper.c | |||
| @@ -1516,17 +1516,33 @@ bool drm_fb_helper_initial_config(struct drm_fb_helper *fb_helper, int bpp_sel) | |||
| 1516 | } | 1516 | } |
| 1517 | EXPORT_SYMBOL(drm_fb_helper_initial_config); | 1517 | EXPORT_SYMBOL(drm_fb_helper_initial_config); |
| 1518 | 1518 | ||
| 1519 | bool drm_fb_helper_hotplug_event(struct drm_fb_helper *fb_helper) | 1519 | /** |
| 1520 | * drm_fb_helper_hotplug_event - respond to a hotplug notification by | ||
| 1521 | * probing all the outputs attached to the fb. | ||
| 1522 | * @fb_helper: the drm_fb_helper | ||
| 1523 | * | ||
| 1524 | * LOCKING: | ||
| 1525 | * Called at runtime, must take mode config lock. | ||
| 1526 | * | ||
| 1527 | * Scan the connectors attached to the fb_helper and try to put together a | ||
| 1528 | * setup after *notification of a change in output configuration. | ||
| 1529 | * | ||
| 1530 | * RETURNS: | ||
| 1531 | * 0 on success and a non-zero error code otherwise. | ||
| 1532 | */ | ||
| 1533 | int drm_fb_helper_hotplug_event(struct drm_fb_helper *fb_helper) | ||
| 1520 | { | 1534 | { |
| 1535 | struct drm_device *dev = fb_helper->dev; | ||
| 1521 | int count = 0; | 1536 | int count = 0; |
| 1522 | u32 max_width, max_height, bpp_sel; | 1537 | u32 max_width, max_height, bpp_sel; |
| 1523 | bool bound = false, crtcs_bound = false; | 1538 | bool bound = false, crtcs_bound = false; |
| 1524 | struct drm_crtc *crtc; | 1539 | struct drm_crtc *crtc; |
| 1525 | 1540 | ||
| 1526 | if (!fb_helper->fb) | 1541 | if (!fb_helper->fb) |
| 1527 | return false; | 1542 | return 0; |
| 1528 | 1543 | ||
| 1529 | list_for_each_entry(crtc, &fb_helper->dev->mode_config.crtc_list, head) { | 1544 | mutex_lock(&dev->mode_config.mutex); |
| 1545 | list_for_each_entry(crtc, &dev->mode_config.crtc_list, head) { | ||
| 1530 | if (crtc->fb) | 1546 | if (crtc->fb) |
| 1531 | crtcs_bound = true; | 1547 | crtcs_bound = true; |
| 1532 | if (crtc->fb == fb_helper->fb) | 1548 | if (crtc->fb == fb_helper->fb) |
| @@ -1535,7 +1551,8 @@ bool drm_fb_helper_hotplug_event(struct drm_fb_helper *fb_helper) | |||
| 1535 | 1551 | ||
| 1536 | if (!bound && crtcs_bound) { | 1552 | if (!bound && crtcs_bound) { |
| 1537 | fb_helper->delayed_hotplug = true; | 1553 | fb_helper->delayed_hotplug = true; |
| 1538 | return false; | 1554 | mutex_unlock(&dev->mode_config.mutex); |
| 1555 | return 0; | ||
| 1539 | } | 1556 | } |
| 1540 | DRM_DEBUG_KMS("\n"); | 1557 | DRM_DEBUG_KMS("\n"); |
| 1541 | 1558 | ||
| @@ -1546,6 +1563,7 @@ bool drm_fb_helper_hotplug_event(struct drm_fb_helper *fb_helper) | |||
| 1546 | count = drm_fb_helper_probe_connector_modes(fb_helper, max_width, | 1563 | count = drm_fb_helper_probe_connector_modes(fb_helper, max_width, |
| 1547 | max_height); | 1564 | max_height); |
| 1548 | drm_setup_crtcs(fb_helper); | 1565 | drm_setup_crtcs(fb_helper); |
| 1566 | mutex_unlock(&dev->mode_config.mutex); | ||
| 1549 | 1567 | ||
| 1550 | return drm_fb_helper_single_fb_probe(fb_helper, bpp_sel); | 1568 | return drm_fb_helper_single_fb_probe(fb_helper, bpp_sel); |
| 1551 | } | 1569 | } |
diff --git a/drivers/gpu/drm/i915/i915_drv.c b/drivers/gpu/drm/i915/i915_drv.c index c34a8dd31d02..32d1b3e829c8 100644 --- a/drivers/gpu/drm/i915/i915_drv.c +++ b/drivers/gpu/drm/i915/i915_drv.c | |||
| @@ -49,7 +49,7 @@ module_param_named(panel_ignore_lid, i915_panel_ignore_lid, int, 0600); | |||
| 49 | unsigned int i915_powersave = 1; | 49 | unsigned int i915_powersave = 1; |
| 50 | module_param_named(powersave, i915_powersave, int, 0600); | 50 | module_param_named(powersave, i915_powersave, int, 0600); |
| 51 | 51 | ||
| 52 | unsigned int i915_semaphores = 1; | 52 | unsigned int i915_semaphores = 0; |
| 53 | module_param_named(semaphores, i915_semaphores, int, 0600); | 53 | module_param_named(semaphores, i915_semaphores, int, 0600); |
| 54 | 54 | ||
| 55 | unsigned int i915_enable_rc6 = 0; | 55 | unsigned int i915_enable_rc6 = 0; |
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c index 373c2a005ec1..2166ee071ddb 100644 --- a/drivers/gpu/drm/i915/intel_display.c +++ b/drivers/gpu/drm/i915/intel_display.c | |||
| @@ -5154,6 +5154,8 @@ static int intel_crtc_mode_set(struct drm_crtc *crtc, | |||
| 5154 | 5154 | ||
| 5155 | I915_WRITE(DSPCNTR(plane), dspcntr); | 5155 | I915_WRITE(DSPCNTR(plane), dspcntr); |
| 5156 | POSTING_READ(DSPCNTR(plane)); | 5156 | POSTING_READ(DSPCNTR(plane)); |
| 5157 | if (!HAS_PCH_SPLIT(dev)) | ||
| 5158 | intel_enable_plane(dev_priv, plane, pipe); | ||
| 5157 | 5159 | ||
| 5158 | ret = intel_pipe_set_base(crtc, x, y, old_fb); | 5160 | ret = intel_pipe_set_base(crtc, x, y, old_fb); |
| 5159 | 5161 | ||
diff --git a/drivers/gpu/drm/nouveau/nouveau_sgdma.c b/drivers/gpu/drm/nouveau/nouveau_sgdma.c index 4bce801bc588..c77111eca6ac 100644 --- a/drivers/gpu/drm/nouveau/nouveau_sgdma.c +++ b/drivers/gpu/drm/nouveau/nouveau_sgdma.c | |||
| @@ -42,7 +42,8 @@ nouveau_sgdma_populate(struct ttm_backend *be, unsigned long num_pages, | |||
| 42 | 42 | ||
| 43 | nvbe->nr_pages = 0; | 43 | nvbe->nr_pages = 0; |
| 44 | while (num_pages--) { | 44 | while (num_pages--) { |
| 45 | if (dma_addrs[nvbe->nr_pages] != DMA_ERROR_CODE) { | 45 | /* this code path isn't called and is incorrect anyways */ |
| 46 | if (0) { /*dma_addrs[nvbe->nr_pages] != DMA_ERROR_CODE)*/ | ||
| 46 | nvbe->pages[nvbe->nr_pages] = | 47 | nvbe->pages[nvbe->nr_pages] = |
| 47 | dma_addrs[nvbe->nr_pages]; | 48 | dma_addrs[nvbe->nr_pages]; |
| 48 | nvbe->ttm_alloced[nvbe->nr_pages] = true; | 49 | nvbe->ttm_alloced[nvbe->nr_pages] = true; |
diff --git a/drivers/gpu/drm/radeon/evergreen.c b/drivers/gpu/drm/radeon/evergreen.c index c20eac3379e6..9073e3bfb08c 100644 --- a/drivers/gpu/drm/radeon/evergreen.c +++ b/drivers/gpu/drm/radeon/evergreen.c | |||
| @@ -1780,7 +1780,10 @@ static void evergreen_gpu_init(struct radeon_device *rdev) | |||
| 1780 | 1780 | ||
| 1781 | 1781 | ||
| 1782 | mc_shared_chmap = RREG32(MC_SHARED_CHMAP); | 1782 | mc_shared_chmap = RREG32(MC_SHARED_CHMAP); |
| 1783 | mc_arb_ramcfg = RREG32(MC_ARB_RAMCFG); | 1783 | if (rdev->flags & RADEON_IS_IGP) |
| 1784 | mc_arb_ramcfg = RREG32(FUS_MC_ARB_RAMCFG); | ||
| 1785 | else | ||
| 1786 | mc_arb_ramcfg = RREG32(MC_ARB_RAMCFG); | ||
| 1784 | 1787 | ||
| 1785 | switch (rdev->config.evergreen.max_tile_pipes) { | 1788 | switch (rdev->config.evergreen.max_tile_pipes) { |
| 1786 | case 1: | 1789 | case 1: |
diff --git a/drivers/gpu/drm/radeon/evergreend.h b/drivers/gpu/drm/radeon/evergreend.h index 94533849927e..fc40e0cc3451 100644 --- a/drivers/gpu/drm/radeon/evergreend.h +++ b/drivers/gpu/drm/radeon/evergreend.h | |||
| @@ -200,6 +200,7 @@ | |||
| 200 | #define BURSTLENGTH_SHIFT 9 | 200 | #define BURSTLENGTH_SHIFT 9 |
| 201 | #define BURSTLENGTH_MASK 0x00000200 | 201 | #define BURSTLENGTH_MASK 0x00000200 |
| 202 | #define CHANSIZE_OVERRIDE (1 << 11) | 202 | #define CHANSIZE_OVERRIDE (1 << 11) |
| 203 | #define FUS_MC_ARB_RAMCFG 0x2768 | ||
| 203 | #define MC_VM_AGP_TOP 0x2028 | 204 | #define MC_VM_AGP_TOP 0x2028 |
| 204 | #define MC_VM_AGP_BOT 0x202C | 205 | #define MC_VM_AGP_BOT 0x202C |
| 205 | #define MC_VM_AGP_BASE 0x2030 | 206 | #define MC_VM_AGP_BASE 0x2030 |
diff --git a/drivers/gpu/drm/radeon/ni.c b/drivers/gpu/drm/radeon/ni.c index 7aade20f63a8..3d8a7634bbe9 100644 --- a/drivers/gpu/drm/radeon/ni.c +++ b/drivers/gpu/drm/radeon/ni.c | |||
| @@ -674,7 +674,7 @@ static void cayman_gpu_init(struct radeon_device *rdev) | |||
| 674 | 674 | ||
| 675 | cc_rb_backend_disable = RREG32(CC_RB_BACKEND_DISABLE); | 675 | cc_rb_backend_disable = RREG32(CC_RB_BACKEND_DISABLE); |
| 676 | cc_gc_shader_pipe_config = RREG32(CC_GC_SHADER_PIPE_CONFIG); | 676 | cc_gc_shader_pipe_config = RREG32(CC_GC_SHADER_PIPE_CONFIG); |
| 677 | cgts_tcc_disable = RREG32(CGTS_TCC_DISABLE); | 677 | cgts_tcc_disable = 0xff000000; |
| 678 | gc_user_rb_backend_disable = RREG32(GC_USER_RB_BACKEND_DISABLE); | 678 | gc_user_rb_backend_disable = RREG32(GC_USER_RB_BACKEND_DISABLE); |
| 679 | gc_user_shader_pipe_config = RREG32(GC_USER_SHADER_PIPE_CONFIG); | 679 | gc_user_shader_pipe_config = RREG32(GC_USER_SHADER_PIPE_CONFIG); |
| 680 | cgts_user_tcc_disable = RREG32(CGTS_USER_TCC_DISABLE); | 680 | cgts_user_tcc_disable = RREG32(CGTS_USER_TCC_DISABLE); |
| @@ -871,7 +871,7 @@ static void cayman_gpu_init(struct radeon_device *rdev) | |||
| 871 | 871 | ||
| 872 | smx_dc_ctl0 = RREG32(SMX_DC_CTL0); | 872 | smx_dc_ctl0 = RREG32(SMX_DC_CTL0); |
| 873 | smx_dc_ctl0 &= ~NUMBER_OF_SETS(0x1ff); | 873 | smx_dc_ctl0 &= ~NUMBER_OF_SETS(0x1ff); |
| 874 | smx_dc_ctl0 |= NUMBER_OF_SETS(rdev->config.evergreen.sx_num_of_sets); | 874 | smx_dc_ctl0 |= NUMBER_OF_SETS(rdev->config.cayman.sx_num_of_sets); |
| 875 | WREG32(SMX_DC_CTL0, smx_dc_ctl0); | 875 | WREG32(SMX_DC_CTL0, smx_dc_ctl0); |
| 876 | 876 | ||
| 877 | WREG32(SPI_CONFIG_CNTL_1, VTX_DONE_DELAY(4) | CRC_SIMD_ID_WADDR_DISABLE); | 877 | WREG32(SPI_CONFIG_CNTL_1, VTX_DONE_DELAY(4) | CRC_SIMD_ID_WADDR_DISABLE); |
| @@ -887,20 +887,20 @@ static void cayman_gpu_init(struct radeon_device *rdev) | |||
| 887 | 887 | ||
| 888 | WREG32(TA_CNTL_AUX, DISABLE_CUBE_ANISO); | 888 | WREG32(TA_CNTL_AUX, DISABLE_CUBE_ANISO); |
| 889 | 889 | ||
| 890 | WREG32(SX_EXPORT_BUFFER_SIZES, (COLOR_BUFFER_SIZE((rdev->config.evergreen.sx_max_export_size / 4) - 1) | | 890 | WREG32(SX_EXPORT_BUFFER_SIZES, (COLOR_BUFFER_SIZE((rdev->config.cayman.sx_max_export_size / 4) - 1) | |
| 891 | POSITION_BUFFER_SIZE((rdev->config.evergreen.sx_max_export_pos_size / 4) - 1) | | 891 | POSITION_BUFFER_SIZE((rdev->config.cayman.sx_max_export_pos_size / 4) - 1) | |
| 892 | SMX_BUFFER_SIZE((rdev->config.evergreen.sx_max_export_smx_size / 4) - 1))); | 892 | SMX_BUFFER_SIZE((rdev->config.cayman.sx_max_export_smx_size / 4) - 1))); |
| 893 | 893 | ||
| 894 | WREG32(PA_SC_FIFO_SIZE, (SC_PRIM_FIFO_SIZE(rdev->config.evergreen.sc_prim_fifo_size) | | 894 | WREG32(PA_SC_FIFO_SIZE, (SC_PRIM_FIFO_SIZE(rdev->config.cayman.sc_prim_fifo_size) | |
| 895 | SC_HIZ_TILE_FIFO_SIZE(rdev->config.evergreen.sc_hiz_tile_fifo_size) | | 895 | SC_HIZ_TILE_FIFO_SIZE(rdev->config.cayman.sc_hiz_tile_fifo_size) | |
| 896 | SC_EARLYZ_TILE_FIFO_SIZE(rdev->config.evergreen.sc_earlyz_tile_fifo_size))); | 896 | SC_EARLYZ_TILE_FIFO_SIZE(rdev->config.cayman.sc_earlyz_tile_fifo_size))); |
| 897 | 897 | ||
| 898 | 898 | ||
| 899 | WREG32(VGT_NUM_INSTANCES, 1); | 899 | WREG32(VGT_NUM_INSTANCES, 1); |
| 900 | 900 | ||
| 901 | WREG32(CP_PERFMON_CNTL, 0); | 901 | WREG32(CP_PERFMON_CNTL, 0); |
| 902 | 902 | ||
| 903 | WREG32(SQ_MS_FIFO_SIZES, (CACHE_FIFO_SIZE(16 * rdev->config.evergreen.sq_num_cf_insts) | | 903 | WREG32(SQ_MS_FIFO_SIZES, (CACHE_FIFO_SIZE(16 * rdev->config.cayman.sq_num_cf_insts) | |
| 904 | FETCH_FIFO_HIWATER(0x4) | | 904 | FETCH_FIFO_HIWATER(0x4) | |
| 905 | DONE_FIFO_HIWATER(0xe0) | | 905 | DONE_FIFO_HIWATER(0xe0) | |
| 906 | ALU_UPDATE_FIFO_HIWATER(0x8))); | 906 | ALU_UPDATE_FIFO_HIWATER(0x8))); |
diff --git a/drivers/gpu/drm/radeon/radeon_atombios.c b/drivers/gpu/drm/radeon/radeon_atombios.c index dd881d035f09..90dfb2b8cf03 100644 --- a/drivers/gpu/drm/radeon/radeon_atombios.c +++ b/drivers/gpu/drm/radeon/radeon_atombios.c | |||
| @@ -1574,9 +1574,17 @@ struct radeon_encoder_atom_dig *radeon_atombios_get_lvds_info(struct | |||
| 1574 | ATOM_FAKE_EDID_PATCH_RECORD *fake_edid_record; | 1574 | ATOM_FAKE_EDID_PATCH_RECORD *fake_edid_record; |
| 1575 | ATOM_PANEL_RESOLUTION_PATCH_RECORD *panel_res_record; | 1575 | ATOM_PANEL_RESOLUTION_PATCH_RECORD *panel_res_record; |
| 1576 | bool bad_record = false; | 1576 | bool bad_record = false; |
| 1577 | u8 *record = (u8 *)(mode_info->atom_context->bios + | 1577 | u8 *record; |
| 1578 | data_offset + | 1578 | |
| 1579 | le16_to_cpu(lvds_info->info.usModePatchTableOffset)); | 1579 | if ((frev == 1) && (crev < 2)) |
| 1580 | /* absolute */ | ||
| 1581 | record = (u8 *)(mode_info->atom_context->bios + | ||
| 1582 | le16_to_cpu(lvds_info->info.usModePatchTableOffset)); | ||
| 1583 | else | ||
| 1584 | /* relative */ | ||
| 1585 | record = (u8 *)(mode_info->atom_context->bios + | ||
| 1586 | data_offset + | ||
| 1587 | le16_to_cpu(lvds_info->info.usModePatchTableOffset)); | ||
| 1580 | while (*record != ATOM_RECORD_END_TYPE) { | 1588 | while (*record != ATOM_RECORD_END_TYPE) { |
| 1581 | switch (*record) { | 1589 | switch (*record) { |
| 1582 | case LCD_MODE_PATCH_RECORD_MODE_TYPE: | 1590 | case LCD_MODE_PATCH_RECORD_MODE_TYPE: |
diff --git a/drivers/gpu/drm/radeon/radeon_gart.c b/drivers/gpu/drm/radeon/radeon_gart.c index 8a955bbdb608..a533f52fd163 100644 --- a/drivers/gpu/drm/radeon/radeon_gart.c +++ b/drivers/gpu/drm/radeon/radeon_gart.c | |||
| @@ -181,9 +181,9 @@ int radeon_gart_bind(struct radeon_device *rdev, unsigned offset, | |||
| 181 | p = t / (PAGE_SIZE / RADEON_GPU_PAGE_SIZE); | 181 | p = t / (PAGE_SIZE / RADEON_GPU_PAGE_SIZE); |
| 182 | 182 | ||
| 183 | for (i = 0; i < pages; i++, p++) { | 183 | for (i = 0; i < pages; i++, p++) { |
| 184 | /* On TTM path, we only use the DMA API if TTM_PAGE_FLAG_DMA32 | 184 | /* we reverted the patch using dma_addr in TTM for now but this |
| 185 | * is requested. */ | 185 | * code stops building on alpha so just comment it out for now */ |
| 186 | if (dma_addr[i] != DMA_ERROR_CODE) { | 186 | if (0) { /*dma_addr[i] != DMA_ERROR_CODE) */ |
| 187 | rdev->gart.ttm_alloced[p] = true; | 187 | rdev->gart.ttm_alloced[p] = true; |
| 188 | rdev->gart.pages_addr[p] = dma_addr[i]; | 188 | rdev->gart.pages_addr[p] = dma_addr[i]; |
| 189 | } else { | 189 | } else { |
diff --git a/drivers/gpu/drm/radeon/reg_srcs/cayman b/drivers/gpu/drm/radeon/reg_srcs/cayman index 6334f8ac1209..0aa8e85a9457 100644 --- a/drivers/gpu/drm/radeon/reg_srcs/cayman +++ b/drivers/gpu/drm/radeon/reg_srcs/cayman | |||
| @@ -33,6 +33,7 @@ cayman 0x9400 | |||
| 33 | 0x00008E48 SQ_EX_ALLOC_TABLE_SLOTS | 33 | 0x00008E48 SQ_EX_ALLOC_TABLE_SLOTS |
| 34 | 0x00009100 SPI_CONFIG_CNTL | 34 | 0x00009100 SPI_CONFIG_CNTL |
| 35 | 0x0000913C SPI_CONFIG_CNTL_1 | 35 | 0x0000913C SPI_CONFIG_CNTL_1 |
| 36 | 0x00009508 TA_CNTL_AUX | ||
| 36 | 0x00009830 DB_DEBUG | 37 | 0x00009830 DB_DEBUG |
| 37 | 0x00009834 DB_DEBUG2 | 38 | 0x00009834 DB_DEBUG2 |
| 38 | 0x00009838 DB_DEBUG3 | 39 | 0x00009838 DB_DEBUG3 |
diff --git a/drivers/gpu/drm/radeon/reg_srcs/evergreen b/drivers/gpu/drm/radeon/reg_srcs/evergreen index 7e1637176e08..0e28cae7ea43 100644 --- a/drivers/gpu/drm/radeon/reg_srcs/evergreen +++ b/drivers/gpu/drm/radeon/reg_srcs/evergreen | |||
| @@ -46,6 +46,7 @@ evergreen 0x9400 | |||
| 46 | 0x00008E48 SQ_EX_ALLOC_TABLE_SLOTS | 46 | 0x00008E48 SQ_EX_ALLOC_TABLE_SLOTS |
| 47 | 0x00009100 SPI_CONFIG_CNTL | 47 | 0x00009100 SPI_CONFIG_CNTL |
| 48 | 0x0000913C SPI_CONFIG_CNTL_1 | 48 | 0x0000913C SPI_CONFIG_CNTL_1 |
| 49 | 0x00009508 TA_CNTL_AUX | ||
| 49 | 0x00009700 VC_CNTL | 50 | 0x00009700 VC_CNTL |
| 50 | 0x00009714 VC_ENHANCE | 51 | 0x00009714 VC_ENHANCE |
| 51 | 0x00009830 DB_DEBUG | 52 | 0x00009830 DB_DEBUG |
diff --git a/drivers/gpu/vga/vga_switcheroo.c b/drivers/gpu/vga/vga_switcheroo.c index e01cacba685f..498b284e5ef9 100644 --- a/drivers/gpu/vga/vga_switcheroo.c +++ b/drivers/gpu/vga/vga_switcheroo.c | |||
| @@ -219,9 +219,6 @@ static int vga_switchto_stage1(struct vga_switcheroo_client *new_client) | |||
| 219 | int i; | 219 | int i; |
| 220 | struct vga_switcheroo_client *active = NULL; | 220 | struct vga_switcheroo_client *active = NULL; |
| 221 | 221 | ||
| 222 | if (new_client->active == true) | ||
| 223 | return 0; | ||
| 224 | |||
| 225 | for (i = 0; i < VGA_SWITCHEROO_MAX_CLIENTS; i++) { | 222 | for (i = 0; i < VGA_SWITCHEROO_MAX_CLIENTS; i++) { |
| 226 | if (vgasr_priv.clients[i].active == true) { | 223 | if (vgasr_priv.clients[i].active == true) { |
| 227 | active = &vgasr_priv.clients[i]; | 224 | active = &vgasr_priv.clients[i]; |
| @@ -372,6 +369,9 @@ vga_switcheroo_debugfs_write(struct file *filp, const char __user *ubuf, | |||
| 372 | goto out; | 369 | goto out; |
| 373 | } | 370 | } |
| 374 | 371 | ||
| 372 | if (client->active == true) | ||
| 373 | goto out; | ||
| 374 | |||
| 375 | /* okay we want a switch - test if devices are willing to switch */ | 375 | /* okay we want a switch - test if devices are willing to switch */ |
| 376 | can_switch = true; | 376 | can_switch = true; |
| 377 | for (i = 0; i < VGA_SWITCHEROO_MAX_CLIENTS; i++) { | 377 | for (i = 0; i < VGA_SWITCHEROO_MAX_CLIENTS; i++) { |
diff --git a/drivers/i2c/busses/i2c-pnx.c b/drivers/i2c/busses/i2c-pnx.c index a97e3fec8148..04be9f82e14b 100644 --- a/drivers/i2c/busses/i2c-pnx.c +++ b/drivers/i2c/busses/i2c-pnx.c | |||
| @@ -65,7 +65,7 @@ static inline void i2c_pnx_arm_timer(struct i2c_pnx_algo_data *alg_data) | |||
| 65 | jiffies, expires); | 65 | jiffies, expires); |
| 66 | 66 | ||
| 67 | timer->expires = jiffies + expires; | 67 | timer->expires = jiffies + expires; |
| 68 | timer->data = (unsigned long)&alg_data; | 68 | timer->data = (unsigned long)alg_data; |
| 69 | 69 | ||
| 70 | add_timer(timer); | 70 | add_timer(timer); |
| 71 | } | 71 | } |
diff --git a/drivers/input/touchscreen/ads7846.c b/drivers/input/touchscreen/ads7846.c index c24946f51256..1de1c19dad30 100644 --- a/drivers/input/touchscreen/ads7846.c +++ b/drivers/input/touchscreen/ads7846.c | |||
| @@ -281,17 +281,24 @@ struct ser_req { | |||
| 281 | u8 command; | 281 | u8 command; |
| 282 | u8 ref_off; | 282 | u8 ref_off; |
| 283 | u16 scratch; | 283 | u16 scratch; |
| 284 | __be16 sample; | ||
| 285 | struct spi_message msg; | 284 | struct spi_message msg; |
| 286 | struct spi_transfer xfer[6]; | 285 | struct spi_transfer xfer[6]; |
| 286 | /* | ||
| 287 | * DMA (thus cache coherency maintenance) requires the | ||
| 288 | * transfer buffers to live in their own cache lines. | ||
| 289 | */ | ||
| 290 | __be16 sample ____cacheline_aligned; | ||
| 287 | }; | 291 | }; |
| 288 | 292 | ||
| 289 | struct ads7845_ser_req { | 293 | struct ads7845_ser_req { |
| 290 | u8 command[3]; | 294 | u8 command[3]; |
| 291 | u8 pwrdown[3]; | ||
| 292 | u8 sample[3]; | ||
| 293 | struct spi_message msg; | 295 | struct spi_message msg; |
| 294 | struct spi_transfer xfer[2]; | 296 | struct spi_transfer xfer[2]; |
| 297 | /* | ||
| 298 | * DMA (thus cache coherency maintenance) requires the | ||
| 299 | * transfer buffers to live in their own cache lines. | ||
| 300 | */ | ||
| 301 | u8 sample[3] ____cacheline_aligned; | ||
| 295 | }; | 302 | }; |
| 296 | 303 | ||
| 297 | static int ads7846_read12_ser(struct device *dev, unsigned command) | 304 | static int ads7846_read12_ser(struct device *dev, unsigned command) |
diff --git a/drivers/leds/leds-lm3530.c b/drivers/leds/leds-lm3530.c index e7089a1f6cb6..b37e6186d0fa 100644 --- a/drivers/leds/leds-lm3530.c +++ b/drivers/leds/leds-lm3530.c | |||
| @@ -349,6 +349,7 @@ static const struct i2c_device_id lm3530_id[] = { | |||
| 349 | {LM3530_NAME, 0}, | 349 | {LM3530_NAME, 0}, |
| 350 | {} | 350 | {} |
| 351 | }; | 351 | }; |
| 352 | MODULE_DEVICE_TABLE(i2c, lm3530_id); | ||
| 352 | 353 | ||
| 353 | static struct i2c_driver lm3530_i2c_driver = { | 354 | static struct i2c_driver lm3530_i2c_driver = { |
| 354 | .probe = lm3530_probe, | 355 | .probe = lm3530_probe, |
diff --git a/drivers/mfd/asic3.c b/drivers/mfd/asic3.c index d4a851c6b5bf..0b4d5b23bec9 100644 --- a/drivers/mfd/asic3.c +++ b/drivers/mfd/asic3.c | |||
| @@ -144,7 +144,7 @@ static void asic3_irq_demux(unsigned int irq, struct irq_desc *desc) | |||
| 144 | int iter, i; | 144 | int iter, i; |
| 145 | unsigned long flags; | 145 | unsigned long flags; |
| 146 | 146 | ||
| 147 | data->chip->irq_ack(irq_data); | 147 | data->chip->irq_ack(data); |
| 148 | 148 | ||
| 149 | for (iter = 0 ; iter < MAX_ASIC_ISR_LOOPS; iter++) { | 149 | for (iter = 0 ; iter < MAX_ASIC_ISR_LOOPS; iter++) { |
| 150 | u32 status; | 150 | u32 status; |
diff --git a/drivers/mfd/omap-usb-host.c b/drivers/mfd/omap-usb-host.c index 2e165117457b..3ab9ffa00aad 100644 --- a/drivers/mfd/omap-usb-host.c +++ b/drivers/mfd/omap-usb-host.c | |||
| @@ -717,14 +717,14 @@ static int usbhs_enable(struct device *dev) | |||
| 717 | gpio_request(pdata->ehci_data->reset_gpio_port[0], | 717 | gpio_request(pdata->ehci_data->reset_gpio_port[0], |
| 718 | "USB1 PHY reset"); | 718 | "USB1 PHY reset"); |
| 719 | gpio_direction_output | 719 | gpio_direction_output |
| 720 | (pdata->ehci_data->reset_gpio_port[0], 1); | 720 | (pdata->ehci_data->reset_gpio_port[0], 0); |
| 721 | } | 721 | } |
| 722 | 722 | ||
| 723 | if (gpio_is_valid(pdata->ehci_data->reset_gpio_port[1])) { | 723 | if (gpio_is_valid(pdata->ehci_data->reset_gpio_port[1])) { |
| 724 | gpio_request(pdata->ehci_data->reset_gpio_port[1], | 724 | gpio_request(pdata->ehci_data->reset_gpio_port[1], |
| 725 | "USB2 PHY reset"); | 725 | "USB2 PHY reset"); |
| 726 | gpio_direction_output | 726 | gpio_direction_output |
| 727 | (pdata->ehci_data->reset_gpio_port[1], 1); | 727 | (pdata->ehci_data->reset_gpio_port[1], 0); |
| 728 | } | 728 | } |
| 729 | 729 | ||
| 730 | /* Hold the PHY in RESET for enough time till DIR is high */ | 730 | /* Hold the PHY in RESET for enough time till DIR is high */ |
| @@ -904,11 +904,11 @@ static int usbhs_enable(struct device *dev) | |||
| 904 | 904 | ||
| 905 | if (gpio_is_valid(pdata->ehci_data->reset_gpio_port[0])) | 905 | if (gpio_is_valid(pdata->ehci_data->reset_gpio_port[0])) |
| 906 | gpio_set_value | 906 | gpio_set_value |
| 907 | (pdata->ehci_data->reset_gpio_port[0], 0); | 907 | (pdata->ehci_data->reset_gpio_port[0], 1); |
| 908 | 908 | ||
| 909 | if (gpio_is_valid(pdata->ehci_data->reset_gpio_port[1])) | 909 | if (gpio_is_valid(pdata->ehci_data->reset_gpio_port[1])) |
| 910 | gpio_set_value | 910 | gpio_set_value |
| 911 | (pdata->ehci_data->reset_gpio_port[1], 0); | 911 | (pdata->ehci_data->reset_gpio_port[1], 1); |
| 912 | } | 912 | } |
| 913 | 913 | ||
| 914 | end_count: | 914 | end_count: |
diff --git a/drivers/mfd/twl4030-power.c b/drivers/mfd/twl4030-power.c index 16422de0823a..2c0d4d16491a 100644 --- a/drivers/mfd/twl4030-power.c +++ b/drivers/mfd/twl4030-power.c | |||
| @@ -447,12 +447,13 @@ static int __init load_twl4030_script(struct twl4030_script *tscript, | |||
| 447 | if (err) | 447 | if (err) |
| 448 | goto out; | 448 | goto out; |
| 449 | } | 449 | } |
| 450 | if (tscript->flags & TWL4030_SLEEP_SCRIPT) | 450 | if (tscript->flags & TWL4030_SLEEP_SCRIPT) { |
| 451 | if (order) | 451 | if (order) |
| 452 | pr_warning("TWL4030: Bad order of scripts (sleep "\ | 452 | pr_warning("TWL4030: Bad order of scripts (sleep "\ |
| 453 | "script before wakeup) Leads to boot"\ | 453 | "script before wakeup) Leads to boot"\ |
| 454 | "failure on some boards\n"); | 454 | "failure on some boards\n"); |
| 455 | err = twl4030_config_sleep_sequence(address); | 455 | err = twl4030_config_sleep_sequence(address); |
| 456 | } | ||
| 456 | out: | 457 | out: |
| 457 | return err; | 458 | return err; |
| 458 | } | 459 | } |
diff --git a/drivers/mmc/core/host.c b/drivers/mmc/core/host.c index 2b200c1cfbba..461e6a17fb90 100644 --- a/drivers/mmc/core/host.c +++ b/drivers/mmc/core/host.c | |||
| @@ -94,7 +94,7 @@ static void mmc_host_clk_gate_delayed(struct mmc_host *host) | |||
| 94 | spin_unlock_irqrestore(&host->clk_lock, flags); | 94 | spin_unlock_irqrestore(&host->clk_lock, flags); |
| 95 | return; | 95 | return; |
| 96 | } | 96 | } |
| 97 | mmc_claim_host(host); | 97 | mutex_lock(&host->clk_gate_mutex); |
| 98 | spin_lock_irqsave(&host->clk_lock, flags); | 98 | spin_lock_irqsave(&host->clk_lock, flags); |
| 99 | if (!host->clk_requests) { | 99 | if (!host->clk_requests) { |
| 100 | spin_unlock_irqrestore(&host->clk_lock, flags); | 100 | spin_unlock_irqrestore(&host->clk_lock, flags); |
| @@ -104,7 +104,7 @@ static void mmc_host_clk_gate_delayed(struct mmc_host *host) | |||
| 104 | pr_debug("%s: gated MCI clock\n", mmc_hostname(host)); | 104 | pr_debug("%s: gated MCI clock\n", mmc_hostname(host)); |
| 105 | } | 105 | } |
| 106 | spin_unlock_irqrestore(&host->clk_lock, flags); | 106 | spin_unlock_irqrestore(&host->clk_lock, flags); |
| 107 | mmc_release_host(host); | 107 | mutex_unlock(&host->clk_gate_mutex); |
| 108 | } | 108 | } |
| 109 | 109 | ||
| 110 | /* | 110 | /* |
| @@ -130,7 +130,7 @@ void mmc_host_clk_ungate(struct mmc_host *host) | |||
| 130 | { | 130 | { |
| 131 | unsigned long flags; | 131 | unsigned long flags; |
| 132 | 132 | ||
| 133 | mmc_claim_host(host); | 133 | mutex_lock(&host->clk_gate_mutex); |
| 134 | spin_lock_irqsave(&host->clk_lock, flags); | 134 | spin_lock_irqsave(&host->clk_lock, flags); |
| 135 | if (host->clk_gated) { | 135 | if (host->clk_gated) { |
| 136 | spin_unlock_irqrestore(&host->clk_lock, flags); | 136 | spin_unlock_irqrestore(&host->clk_lock, flags); |
| @@ -140,7 +140,7 @@ void mmc_host_clk_ungate(struct mmc_host *host) | |||
| 140 | } | 140 | } |
| 141 | host->clk_requests++; | 141 | host->clk_requests++; |
| 142 | spin_unlock_irqrestore(&host->clk_lock, flags); | 142 | spin_unlock_irqrestore(&host->clk_lock, flags); |
| 143 | mmc_release_host(host); | 143 | mutex_unlock(&host->clk_gate_mutex); |
| 144 | } | 144 | } |
| 145 | 145 | ||
| 146 | /** | 146 | /** |
| @@ -215,6 +215,7 @@ static inline void mmc_host_clk_init(struct mmc_host *host) | |||
| 215 | host->clk_gated = false; | 215 | host->clk_gated = false; |
| 216 | INIT_WORK(&host->clk_gate_work, mmc_host_clk_gate_work); | 216 | INIT_WORK(&host->clk_gate_work, mmc_host_clk_gate_work); |
| 217 | spin_lock_init(&host->clk_lock); | 217 | spin_lock_init(&host->clk_lock); |
| 218 | mutex_init(&host->clk_gate_mutex); | ||
| 218 | } | 219 | } |
| 219 | 220 | ||
| 220 | /** | 221 | /** |
diff --git a/drivers/net/Kconfig b/drivers/net/Kconfig index dc280bc8eba2..6c884ef1b069 100644 --- a/drivers/net/Kconfig +++ b/drivers/net/Kconfig | |||
| @@ -2536,7 +2536,7 @@ config S6GMAC | |||
| 2536 | source "drivers/net/stmmac/Kconfig" | 2536 | source "drivers/net/stmmac/Kconfig" |
| 2537 | 2537 | ||
| 2538 | config PCH_GBE | 2538 | config PCH_GBE |
| 2539 | tristate "PCH Gigabit Ethernet" | 2539 | tristate "Intel EG20T PCH / OKI SEMICONDUCTOR ML7223 IOH GbE" |
| 2540 | depends on PCI | 2540 | depends on PCI |
| 2541 | select MII | 2541 | select MII |
| 2542 | ---help--- | 2542 | ---help--- |
| @@ -2548,6 +2548,12 @@ config PCH_GBE | |||
| 2548 | to Gigabit Ethernet. | 2548 | to Gigabit Ethernet. |
| 2549 | This driver enables Gigabit Ethernet function. | 2549 | This driver enables Gigabit Ethernet function. |
| 2550 | 2550 | ||
| 2551 | This driver also can be used for OKI SEMICONDUCTOR IOH(Input/ | ||
| 2552 | Output Hub), ML7223. | ||
| 2553 | ML7223 IOH is for MP(Media Phone) use. | ||
| 2554 | ML7223 is companion chip for Intel Atom E6xx series. | ||
| 2555 | ML7223 is completely compatible for Intel EG20T PCH. | ||
| 2556 | |||
| 2551 | endif # NETDEV_1000 | 2557 | endif # NETDEV_1000 |
| 2552 | 2558 | ||
| 2553 | # | 2559 | # |
diff --git a/drivers/net/Makefile b/drivers/net/Makefile index 01b604ad155e..e5a7375685ad 100644 --- a/drivers/net/Makefile +++ b/drivers/net/Makefile | |||
| @@ -144,7 +144,7 @@ obj-$(CONFIG_NE3210) += ne3210.o 8390.o | |||
| 144 | obj-$(CONFIG_SB1250_MAC) += sb1250-mac.o | 144 | obj-$(CONFIG_SB1250_MAC) += sb1250-mac.o |
| 145 | obj-$(CONFIG_B44) += b44.o | 145 | obj-$(CONFIG_B44) += b44.o |
| 146 | obj-$(CONFIG_FORCEDETH) += forcedeth.o | 146 | obj-$(CONFIG_FORCEDETH) += forcedeth.o |
| 147 | obj-$(CONFIG_NE_H8300) += ne-h8300.o 8390.o | 147 | obj-$(CONFIG_NE_H8300) += ne-h8300.o |
| 148 | obj-$(CONFIG_AX88796) += ax88796.o | 148 | obj-$(CONFIG_AX88796) += ax88796.o |
| 149 | obj-$(CONFIG_BCM63XX_ENET) += bcm63xx_enet.o | 149 | obj-$(CONFIG_BCM63XX_ENET) += bcm63xx_enet.o |
| 150 | obj-$(CONFIG_FTMAC100) += ftmac100.o | 150 | obj-$(CONFIG_FTMAC100) += ftmac100.o |
| @@ -219,7 +219,7 @@ obj-$(CONFIG_SC92031) += sc92031.o | |||
| 219 | obj-$(CONFIG_LP486E) += lp486e.o | 219 | obj-$(CONFIG_LP486E) += lp486e.o |
| 220 | 220 | ||
| 221 | obj-$(CONFIG_ETH16I) += eth16i.o | 221 | obj-$(CONFIG_ETH16I) += eth16i.o |
| 222 | obj-$(CONFIG_ZORRO8390) += zorro8390.o 8390.o | 222 | obj-$(CONFIG_ZORRO8390) += zorro8390.o |
| 223 | obj-$(CONFIG_HPLANCE) += hplance.o 7990.o | 223 | obj-$(CONFIG_HPLANCE) += hplance.o 7990.o |
| 224 | obj-$(CONFIG_MVME147_NET) += mvme147.o 7990.o | 224 | obj-$(CONFIG_MVME147_NET) += mvme147.o 7990.o |
| 225 | obj-$(CONFIG_EQUALIZER) += eql.o | 225 | obj-$(CONFIG_EQUALIZER) += eql.o |
| @@ -231,7 +231,7 @@ obj-$(CONFIG_SGI_IOC3_ETH) += ioc3-eth.o | |||
| 231 | obj-$(CONFIG_DECLANCE) += declance.o | 231 | obj-$(CONFIG_DECLANCE) += declance.o |
| 232 | obj-$(CONFIG_ATARILANCE) += atarilance.o | 232 | obj-$(CONFIG_ATARILANCE) += atarilance.o |
| 233 | obj-$(CONFIG_A2065) += a2065.o | 233 | obj-$(CONFIG_A2065) += a2065.o |
| 234 | obj-$(CONFIG_HYDRA) += hydra.o 8390.o | 234 | obj-$(CONFIG_HYDRA) += hydra.o |
| 235 | obj-$(CONFIG_ARIADNE) += ariadne.o | 235 | obj-$(CONFIG_ARIADNE) += ariadne.o |
| 236 | obj-$(CONFIG_CS89x0) += cs89x0.o | 236 | obj-$(CONFIG_CS89x0) += cs89x0.o |
| 237 | obj-$(CONFIG_MACSONIC) += macsonic.o | 237 | obj-$(CONFIG_MACSONIC) += macsonic.o |
diff --git a/drivers/net/arm/etherh.c b/drivers/net/arm/etherh.c index 4af235d41fda..fbfb5b47c506 100644 --- a/drivers/net/arm/etherh.c +++ b/drivers/net/arm/etherh.c | |||
| @@ -527,7 +527,7 @@ static void __init etherh_banner(void) | |||
| 527 | * Read the ethernet address string from the on board rom. | 527 | * Read the ethernet address string from the on board rom. |
| 528 | * This is an ascii string... | 528 | * This is an ascii string... |
| 529 | */ | 529 | */ |
| 530 | static int __init etherh_addr(char *addr, struct expansion_card *ec) | 530 | static int __devinit etherh_addr(char *addr, struct expansion_card *ec) |
| 531 | { | 531 | { |
| 532 | struct in_chunk_dir cd; | 532 | struct in_chunk_dir cd; |
| 533 | char *s; | 533 | char *s; |
| @@ -655,7 +655,7 @@ static const struct net_device_ops etherh_netdev_ops = { | |||
| 655 | static u32 etherh_regoffsets[16]; | 655 | static u32 etherh_regoffsets[16]; |
| 656 | static u32 etherm_regoffsets[16]; | 656 | static u32 etherm_regoffsets[16]; |
| 657 | 657 | ||
| 658 | static int __init | 658 | static int __devinit |
| 659 | etherh_probe(struct expansion_card *ec, const struct ecard_id *id) | 659 | etherh_probe(struct expansion_card *ec, const struct ecard_id *id) |
| 660 | { | 660 | { |
| 661 | const struct etherh_data *data = id->data; | 661 | const struct etherh_data *data = id->data; |
diff --git a/drivers/net/benet/be.h b/drivers/net/benet/be.h index 66823eded7a3..2353eca32593 100644 --- a/drivers/net/benet/be.h +++ b/drivers/net/benet/be.h | |||
| @@ -213,7 +213,7 @@ struct be_rx_stats { | |||
| 213 | 213 | ||
| 214 | struct be_rx_compl_info { | 214 | struct be_rx_compl_info { |
| 215 | u32 rss_hash; | 215 | u32 rss_hash; |
| 216 | u16 vid; | 216 | u16 vlan_tag; |
| 217 | u16 pkt_size; | 217 | u16 pkt_size; |
| 218 | u16 rxq_idx; | 218 | u16 rxq_idx; |
| 219 | u16 mac_id; | 219 | u16 mac_id; |
diff --git a/drivers/net/benet/be_cmds.c b/drivers/net/benet/be_cmds.c index 1e2d825bb94a..9dc9394fd4ca 100644 --- a/drivers/net/benet/be_cmds.c +++ b/drivers/net/benet/be_cmds.c | |||
| @@ -132,7 +132,7 @@ static void be_async_grp5_pvid_state_process(struct be_adapter *adapter, | |||
| 132 | struct be_async_event_grp5_pvid_state *evt) | 132 | struct be_async_event_grp5_pvid_state *evt) |
| 133 | { | 133 | { |
| 134 | if (evt->enabled) | 134 | if (evt->enabled) |
| 135 | adapter->pvid = evt->tag; | 135 | adapter->pvid = le16_to_cpu(evt->tag); |
| 136 | else | 136 | else |
| 137 | adapter->pvid = 0; | 137 | adapter->pvid = 0; |
| 138 | } | 138 | } |
diff --git a/drivers/net/benet/be_main.c b/drivers/net/benet/be_main.c index 02a0443d1821..9187fb4e08f1 100644 --- a/drivers/net/benet/be_main.c +++ b/drivers/net/benet/be_main.c | |||
| @@ -1018,7 +1018,8 @@ static void be_rx_compl_process(struct be_adapter *adapter, | |||
| 1018 | kfree_skb(skb); | 1018 | kfree_skb(skb); |
| 1019 | return; | 1019 | return; |
| 1020 | } | 1020 | } |
| 1021 | vlan_hwaccel_receive_skb(skb, adapter->vlan_grp, rxcp->vid); | 1021 | vlan_hwaccel_receive_skb(skb, adapter->vlan_grp, |
| 1022 | rxcp->vlan_tag); | ||
| 1022 | } else { | 1023 | } else { |
| 1023 | netif_receive_skb(skb); | 1024 | netif_receive_skb(skb); |
| 1024 | } | 1025 | } |
| @@ -1076,7 +1077,8 @@ static void be_rx_compl_process_gro(struct be_adapter *adapter, | |||
| 1076 | if (likely(!rxcp->vlanf)) | 1077 | if (likely(!rxcp->vlanf)) |
| 1077 | napi_gro_frags(&eq_obj->napi); | 1078 | napi_gro_frags(&eq_obj->napi); |
| 1078 | else | 1079 | else |
| 1079 | vlan_gro_frags(&eq_obj->napi, adapter->vlan_grp, rxcp->vid); | 1080 | vlan_gro_frags(&eq_obj->napi, adapter->vlan_grp, |
| 1081 | rxcp->vlan_tag); | ||
| 1080 | } | 1082 | } |
| 1081 | 1083 | ||
| 1082 | static void be_parse_rx_compl_v1(struct be_adapter *adapter, | 1084 | static void be_parse_rx_compl_v1(struct be_adapter *adapter, |
| @@ -1102,7 +1104,8 @@ static void be_parse_rx_compl_v1(struct be_adapter *adapter, | |||
| 1102 | rxcp->pkt_type = | 1104 | rxcp->pkt_type = |
| 1103 | AMAP_GET_BITS(struct amap_eth_rx_compl_v1, cast_enc, compl); | 1105 | AMAP_GET_BITS(struct amap_eth_rx_compl_v1, cast_enc, compl); |
| 1104 | rxcp->vtm = AMAP_GET_BITS(struct amap_eth_rx_compl_v1, vtm, compl); | 1106 | rxcp->vtm = AMAP_GET_BITS(struct amap_eth_rx_compl_v1, vtm, compl); |
| 1105 | rxcp->vid = AMAP_GET_BITS(struct amap_eth_rx_compl_v1, vlan_tag, compl); | 1107 | rxcp->vlan_tag = AMAP_GET_BITS(struct amap_eth_rx_compl_v1, vlan_tag, |
| 1108 | compl); | ||
| 1106 | } | 1109 | } |
| 1107 | 1110 | ||
| 1108 | static void be_parse_rx_compl_v0(struct be_adapter *adapter, | 1111 | static void be_parse_rx_compl_v0(struct be_adapter *adapter, |
| @@ -1128,7 +1131,8 @@ static void be_parse_rx_compl_v0(struct be_adapter *adapter, | |||
| 1128 | rxcp->pkt_type = | 1131 | rxcp->pkt_type = |
| 1129 | AMAP_GET_BITS(struct amap_eth_rx_compl_v0, cast_enc, compl); | 1132 | AMAP_GET_BITS(struct amap_eth_rx_compl_v0, cast_enc, compl); |
| 1130 | rxcp->vtm = AMAP_GET_BITS(struct amap_eth_rx_compl_v0, vtm, compl); | 1133 | rxcp->vtm = AMAP_GET_BITS(struct amap_eth_rx_compl_v0, vtm, compl); |
| 1131 | rxcp->vid = AMAP_GET_BITS(struct amap_eth_rx_compl_v0, vlan_tag, compl); | 1134 | rxcp->vlan_tag = AMAP_GET_BITS(struct amap_eth_rx_compl_v0, vlan_tag, |
| 1135 | compl); | ||
| 1132 | } | 1136 | } |
| 1133 | 1137 | ||
| 1134 | static struct be_rx_compl_info *be_rx_compl_get(struct be_rx_obj *rxo) | 1138 | static struct be_rx_compl_info *be_rx_compl_get(struct be_rx_obj *rxo) |
| @@ -1155,9 +1159,11 @@ static struct be_rx_compl_info *be_rx_compl_get(struct be_rx_obj *rxo) | |||
| 1155 | rxcp->vlanf = 0; | 1159 | rxcp->vlanf = 0; |
| 1156 | 1160 | ||
| 1157 | if (!lancer_chip(adapter)) | 1161 | if (!lancer_chip(adapter)) |
| 1158 | rxcp->vid = swab16(rxcp->vid); | 1162 | rxcp->vlan_tag = swab16(rxcp->vlan_tag); |
| 1159 | 1163 | ||
| 1160 | if ((adapter->pvid == rxcp->vid) && !adapter->vlan_tag[rxcp->vid]) | 1164 | if (((adapter->pvid & VLAN_VID_MASK) == |
| 1165 | (rxcp->vlan_tag & VLAN_VID_MASK)) && | ||
| 1166 | !adapter->vlan_tag[rxcp->vlan_tag]) | ||
| 1161 | rxcp->vlanf = 0; | 1167 | rxcp->vlanf = 0; |
| 1162 | 1168 | ||
| 1163 | /* As the compl has been parsed, reset it; we wont touch it again */ | 1169 | /* As the compl has been parsed, reset it; we wont touch it again */ |
diff --git a/drivers/net/bonding/bond_3ad.h b/drivers/net/bonding/bond_3ad.h index b28baff70864..01b8a6af275b 100644 --- a/drivers/net/bonding/bond_3ad.h +++ b/drivers/net/bonding/bond_3ad.h | |||
| @@ -39,7 +39,7 @@ | |||
| 39 | 39 | ||
| 40 | typedef struct mac_addr { | 40 | typedef struct mac_addr { |
| 41 | u8 mac_addr_value[ETH_ALEN]; | 41 | u8 mac_addr_value[ETH_ALEN]; |
| 42 | } mac_addr_t; | 42 | } __packed mac_addr_t; |
| 43 | 43 | ||
| 44 | enum { | 44 | enum { |
| 45 | BOND_AD_STABLE = 0, | 45 | BOND_AD_STABLE = 0, |
| @@ -134,12 +134,12 @@ typedef struct lacpdu { | |||
| 134 | u8 tlv_type_terminator; // = terminator | 134 | u8 tlv_type_terminator; // = terminator |
| 135 | u8 terminator_length; // = 0 | 135 | u8 terminator_length; // = 0 |
| 136 | u8 reserved_50[50]; // = 0 | 136 | u8 reserved_50[50]; // = 0 |
| 137 | } lacpdu_t; | 137 | } __packed lacpdu_t; |
| 138 | 138 | ||
| 139 | typedef struct lacpdu_header { | 139 | typedef struct lacpdu_header { |
| 140 | struct ethhdr hdr; | 140 | struct ethhdr hdr; |
| 141 | struct lacpdu lacpdu; | 141 | struct lacpdu lacpdu; |
| 142 | } lacpdu_header_t; | 142 | } __packed lacpdu_header_t; |
| 143 | 143 | ||
| 144 | // Marker Protocol Data Unit(PDU) structure(43.5.3.2 in the 802.3ad standard) | 144 | // Marker Protocol Data Unit(PDU) structure(43.5.3.2 in the 802.3ad standard) |
| 145 | typedef struct bond_marker { | 145 | typedef struct bond_marker { |
| @@ -155,12 +155,12 @@ typedef struct bond_marker { | |||
| 155 | u8 tlv_type_terminator; // = 0x00 | 155 | u8 tlv_type_terminator; // = 0x00 |
| 156 | u8 terminator_length; // = 0x00 | 156 | u8 terminator_length; // = 0x00 |
| 157 | u8 reserved_90[90]; // = 0 | 157 | u8 reserved_90[90]; // = 0 |
| 158 | } bond_marker_t; | 158 | } __packed bond_marker_t; |
| 159 | 159 | ||
| 160 | typedef struct bond_marker_header { | 160 | typedef struct bond_marker_header { |
| 161 | struct ethhdr hdr; | 161 | struct ethhdr hdr; |
| 162 | struct bond_marker marker; | 162 | struct bond_marker marker; |
| 163 | } bond_marker_header_t; | 163 | } __packed bond_marker_header_t; |
| 164 | 164 | ||
| 165 | #pragma pack() | 165 | #pragma pack() |
| 166 | 166 | ||
diff --git a/drivers/net/can/sja1000/sja1000.c b/drivers/net/can/sja1000/sja1000.c index a358ea9445a2..f501bba1fc6f 100644 --- a/drivers/net/can/sja1000/sja1000.c +++ b/drivers/net/can/sja1000/sja1000.c | |||
| @@ -346,10 +346,10 @@ static void sja1000_rx(struct net_device *dev) | |||
| 346 | | (priv->read_reg(priv, REG_ID2) >> 5); | 346 | | (priv->read_reg(priv, REG_ID2) >> 5); |
| 347 | } | 347 | } |
| 348 | 348 | ||
| 349 | cf->can_dlc = get_can_dlc(fi & 0x0F); | ||
| 349 | if (fi & FI_RTR) { | 350 | if (fi & FI_RTR) { |
| 350 | id |= CAN_RTR_FLAG; | 351 | id |= CAN_RTR_FLAG; |
| 351 | } else { | 352 | } else { |
| 352 | cf->can_dlc = get_can_dlc(fi & 0x0F); | ||
| 353 | for (i = 0; i < cf->can_dlc; i++) | 353 | for (i = 0; i < cf->can_dlc; i++) |
| 354 | cf->data[i] = priv->read_reg(priv, dreg++); | 354 | cf->data[i] = priv->read_reg(priv, dreg++); |
| 355 | } | 355 | } |
diff --git a/drivers/net/can/slcan.c b/drivers/net/can/slcan.c index b423965a78d1..1b49df6b2470 100644 --- a/drivers/net/can/slcan.c +++ b/drivers/net/can/slcan.c | |||
| @@ -583,7 +583,9 @@ static int slcan_open(struct tty_struct *tty) | |||
| 583 | /* Done. We have linked the TTY line to a channel. */ | 583 | /* Done. We have linked the TTY line to a channel. */ |
| 584 | rtnl_unlock(); | 584 | rtnl_unlock(); |
| 585 | tty->receive_room = 65536; /* We don't flow control */ | 585 | tty->receive_room = 65536; /* We don't flow control */ |
| 586 | return sl->dev->base_addr; | 586 | |
| 587 | /* TTY layer expects 0 on success */ | ||
| 588 | return 0; | ||
| 587 | 589 | ||
| 588 | err_free_chan: | 590 | err_free_chan: |
| 589 | sl->tty = NULL; | 591 | sl->tty = NULL; |
diff --git a/drivers/net/ehea/ehea_ethtool.c b/drivers/net/ehea/ehea_ethtool.c index 3e2e734fecb7..f3bbdcef338c 100644 --- a/drivers/net/ehea/ehea_ethtool.c +++ b/drivers/net/ehea/ehea_ethtool.c | |||
| @@ -55,15 +55,20 @@ static int ehea_get_settings(struct net_device *dev, struct ethtool_cmd *cmd) | |||
| 55 | cmd->duplex = -1; | 55 | cmd->duplex = -1; |
| 56 | } | 56 | } |
| 57 | 57 | ||
| 58 | cmd->supported = (SUPPORTED_10000baseT_Full | SUPPORTED_1000baseT_Full | 58 | if (cmd->speed == SPEED_10000) { |
| 59 | | SUPPORTED_100baseT_Full | SUPPORTED_100baseT_Half | 59 | cmd->supported = (SUPPORTED_10000baseT_Full | SUPPORTED_FIBRE); |
| 60 | | SUPPORTED_10baseT_Full | SUPPORTED_10baseT_Half | 60 | cmd->advertising = (ADVERTISED_10000baseT_Full | ADVERTISED_FIBRE); |
| 61 | | SUPPORTED_Autoneg | SUPPORTED_FIBRE); | 61 | cmd->port = PORT_FIBRE; |
| 62 | 62 | } else { | |
| 63 | cmd->advertising = (ADVERTISED_10000baseT_Full | ADVERTISED_Autoneg | 63 | cmd->supported = (SUPPORTED_1000baseT_Full | SUPPORTED_100baseT_Full |
| 64 | | ADVERTISED_FIBRE); | 64 | | SUPPORTED_100baseT_Half | SUPPORTED_10baseT_Full |
| 65 | | SUPPORTED_10baseT_Half | SUPPORTED_Autoneg | ||
| 66 | | SUPPORTED_TP); | ||
| 67 | cmd->advertising = (ADVERTISED_1000baseT_Full | ADVERTISED_Autoneg | ||
| 68 | | ADVERTISED_TP); | ||
| 69 | cmd->port = PORT_TP; | ||
| 70 | } | ||
| 65 | 71 | ||
| 66 | cmd->port = PORT_FIBRE; | ||
| 67 | cmd->autoneg = port->autoneg == 1 ? AUTONEG_ENABLE : AUTONEG_DISABLE; | 72 | cmd->autoneg = port->autoneg == 1 ? AUTONEG_ENABLE : AUTONEG_DISABLE; |
| 68 | 73 | ||
| 69 | return 0; | 74 | return 0; |
diff --git a/drivers/net/ehea/ehea_main.c b/drivers/net/ehea/ehea_main.c index 53c0f04b1b23..cf79cf759e13 100644 --- a/drivers/net/ehea/ehea_main.c +++ b/drivers/net/ehea/ehea_main.c | |||
| @@ -2688,9 +2688,6 @@ static int ehea_open(struct net_device *dev) | |||
| 2688 | netif_start_queue(dev); | 2688 | netif_start_queue(dev); |
| 2689 | } | 2689 | } |
| 2690 | 2690 | ||
| 2691 | init_waitqueue_head(&port->swqe_avail_wq); | ||
| 2692 | init_waitqueue_head(&port->restart_wq); | ||
| 2693 | |||
| 2694 | mutex_unlock(&port->port_lock); | 2691 | mutex_unlock(&port->port_lock); |
| 2695 | 2692 | ||
| 2696 | return ret; | 2693 | return ret; |
| @@ -3276,6 +3273,9 @@ struct ehea_port *ehea_setup_single_port(struct ehea_adapter *adapter, | |||
| 3276 | 3273 | ||
| 3277 | INIT_WORK(&port->reset_task, ehea_reset_port); | 3274 | INIT_WORK(&port->reset_task, ehea_reset_port); |
| 3278 | 3275 | ||
| 3276 | init_waitqueue_head(&port->swqe_avail_wq); | ||
| 3277 | init_waitqueue_head(&port->restart_wq); | ||
| 3278 | |||
| 3279 | ret = register_netdev(dev); | 3279 | ret = register_netdev(dev); |
| 3280 | if (ret) { | 3280 | if (ret) { |
| 3281 | pr_err("register_netdev failed. ret=%d\n", ret); | 3281 | pr_err("register_netdev failed. ret=%d\n", ret); |
diff --git a/drivers/net/hydra.c b/drivers/net/hydra.c index c5ef62ceb840..1cd481c04202 100644 --- a/drivers/net/hydra.c +++ b/drivers/net/hydra.c | |||
| @@ -98,15 +98,15 @@ static const struct net_device_ops hydra_netdev_ops = { | |||
| 98 | .ndo_open = hydra_open, | 98 | .ndo_open = hydra_open, |
| 99 | .ndo_stop = hydra_close, | 99 | .ndo_stop = hydra_close, |
| 100 | 100 | ||
| 101 | .ndo_start_xmit = ei_start_xmit, | 101 | .ndo_start_xmit = __ei_start_xmit, |
| 102 | .ndo_tx_timeout = ei_tx_timeout, | 102 | .ndo_tx_timeout = __ei_tx_timeout, |
| 103 | .ndo_get_stats = ei_get_stats, | 103 | .ndo_get_stats = __ei_get_stats, |
| 104 | .ndo_set_multicast_list = ei_set_multicast_list, | 104 | .ndo_set_multicast_list = __ei_set_multicast_list, |
| 105 | .ndo_validate_addr = eth_validate_addr, | 105 | .ndo_validate_addr = eth_validate_addr, |
| 106 | .ndo_set_mac_address = eth_mac_addr, | 106 | .ndo_set_mac_address = eth_mac_addr, |
| 107 | .ndo_change_mtu = eth_change_mtu, | 107 | .ndo_change_mtu = eth_change_mtu, |
| 108 | #ifdef CONFIG_NET_POLL_CONTROLLER | 108 | #ifdef CONFIG_NET_POLL_CONTROLLER |
| 109 | .ndo_poll_controller = ei_poll, | 109 | .ndo_poll_controller = __ei_poll, |
| 110 | #endif | 110 | #endif |
| 111 | }; | 111 | }; |
| 112 | 112 | ||
| @@ -125,7 +125,7 @@ static int __devinit hydra_init(struct zorro_dev *z) | |||
| 125 | 0x10, 0x12, 0x14, 0x16, 0x18, 0x1a, 0x1c, 0x1e, | 125 | 0x10, 0x12, 0x14, 0x16, 0x18, 0x1a, 0x1c, 0x1e, |
| 126 | }; | 126 | }; |
| 127 | 127 | ||
| 128 | dev = alloc_ei_netdev(); | 128 | dev = ____alloc_ei_netdev(0); |
| 129 | if (!dev) | 129 | if (!dev) |
| 130 | return -ENOMEM; | 130 | return -ENOMEM; |
| 131 | 131 | ||
diff --git a/drivers/net/ne-h8300.c b/drivers/net/ne-h8300.c index 30be8c634ebd..7298a34bc795 100644 --- a/drivers/net/ne-h8300.c +++ b/drivers/net/ne-h8300.c | |||
| @@ -167,7 +167,7 @@ static void cleanup_card(struct net_device *dev) | |||
| 167 | #ifndef MODULE | 167 | #ifndef MODULE |
| 168 | struct net_device * __init ne_probe(int unit) | 168 | struct net_device * __init ne_probe(int unit) |
| 169 | { | 169 | { |
| 170 | struct net_device *dev = alloc_ei_netdev(); | 170 | struct net_device *dev = ____alloc_ei_netdev(0); |
| 171 | int err; | 171 | int err; |
| 172 | 172 | ||
| 173 | if (!dev) | 173 | if (!dev) |
| @@ -197,15 +197,15 @@ static const struct net_device_ops ne_netdev_ops = { | |||
| 197 | .ndo_open = ne_open, | 197 | .ndo_open = ne_open, |
| 198 | .ndo_stop = ne_close, | 198 | .ndo_stop = ne_close, |
| 199 | 199 | ||
| 200 | .ndo_start_xmit = ei_start_xmit, | 200 | .ndo_start_xmit = __ei_start_xmit, |
| 201 | .ndo_tx_timeout = ei_tx_timeout, | 201 | .ndo_tx_timeout = __ei_tx_timeout, |
| 202 | .ndo_get_stats = ei_get_stats, | 202 | .ndo_get_stats = __ei_get_stats, |
| 203 | .ndo_set_multicast_list = ei_set_multicast_list, | 203 | .ndo_set_multicast_list = __ei_set_multicast_list, |
| 204 | .ndo_validate_addr = eth_validate_addr, | 204 | .ndo_validate_addr = eth_validate_addr, |
| 205 | .ndo_set_mac_address = eth_mac_addr, | 205 | .ndo_set_mac_address = eth_mac_addr, |
| 206 | .ndo_change_mtu = eth_change_mtu, | 206 | .ndo_change_mtu = eth_change_mtu, |
| 207 | #ifdef CONFIG_NET_POLL_CONTROLLER | 207 | #ifdef CONFIG_NET_POLL_CONTROLLER |
| 208 | .ndo_poll_controller = ei_poll, | 208 | .ndo_poll_controller = __ei_poll, |
| 209 | #endif | 209 | #endif |
| 210 | }; | 210 | }; |
| 211 | 211 | ||
| @@ -637,7 +637,7 @@ int init_module(void) | |||
| 637 | int err; | 637 | int err; |
| 638 | 638 | ||
| 639 | for (this_dev = 0; this_dev < MAX_NE_CARDS; this_dev++) { | 639 | for (this_dev = 0; this_dev < MAX_NE_CARDS; this_dev++) { |
| 640 | struct net_device *dev = alloc_ei_netdev(); | 640 | struct net_device *dev = ____alloc_ei_netdev(0); |
| 641 | if (!dev) | 641 | if (!dev) |
| 642 | break; | 642 | break; |
| 643 | if (io[this_dev]) { | 643 | if (io[this_dev]) { |
diff --git a/drivers/net/pch_gbe/pch_gbe_main.c b/drivers/net/pch_gbe/pch_gbe_main.c index 2ef2f9cdefa6..56d049a472da 100644 --- a/drivers/net/pch_gbe/pch_gbe_main.c +++ b/drivers/net/pch_gbe/pch_gbe_main.c | |||
| @@ -34,6 +34,10 @@ const char pch_driver_version[] = DRV_VERSION; | |||
| 34 | #define PCH_GBE_COPYBREAK_DEFAULT 256 | 34 | #define PCH_GBE_COPYBREAK_DEFAULT 256 |
| 35 | #define PCH_GBE_PCI_BAR 1 | 35 | #define PCH_GBE_PCI_BAR 1 |
| 36 | 36 | ||
| 37 | /* Macros for ML7223 */ | ||
| 38 | #define PCI_VENDOR_ID_ROHM 0x10db | ||
| 39 | #define PCI_DEVICE_ID_ROHM_ML7223_GBE 0x8013 | ||
| 40 | |||
| 37 | #define PCH_GBE_TX_WEIGHT 64 | 41 | #define PCH_GBE_TX_WEIGHT 64 |
| 38 | #define PCH_GBE_RX_WEIGHT 64 | 42 | #define PCH_GBE_RX_WEIGHT 64 |
| 39 | #define PCH_GBE_RX_BUFFER_WRITE 16 | 43 | #define PCH_GBE_RX_BUFFER_WRITE 16 |
| @@ -43,8 +47,7 @@ const char pch_driver_version[] = DRV_VERSION; | |||
| 43 | 47 | ||
| 44 | #define PCH_GBE_MAC_RGMII_CTRL_SETTING ( \ | 48 | #define PCH_GBE_MAC_RGMII_CTRL_SETTING ( \ |
| 45 | PCH_GBE_CHIP_TYPE_INTERNAL | \ | 49 | PCH_GBE_CHIP_TYPE_INTERNAL | \ |
| 46 | PCH_GBE_RGMII_MODE_RGMII | \ | 50 | PCH_GBE_RGMII_MODE_RGMII \ |
| 47 | PCH_GBE_CRS_SEL \ | ||
| 48 | ) | 51 | ) |
| 49 | 52 | ||
| 50 | /* Ethertype field values */ | 53 | /* Ethertype field values */ |
| @@ -1494,12 +1497,11 @@ pch_gbe_clean_rx(struct pch_gbe_adapter *adapter, | |||
| 1494 | /* Write meta date of skb */ | 1497 | /* Write meta date of skb */ |
| 1495 | skb_put(skb, length); | 1498 | skb_put(skb, length); |
| 1496 | skb->protocol = eth_type_trans(skb, netdev); | 1499 | skb->protocol = eth_type_trans(skb, netdev); |
| 1497 | if ((tcp_ip_status & PCH_GBE_RXD_ACC_STAT_TCPIPOK) == | 1500 | if (tcp_ip_status & PCH_GBE_RXD_ACC_STAT_TCPIPOK) |
| 1498 | PCH_GBE_RXD_ACC_STAT_TCPIPOK) { | ||
| 1499 | skb->ip_summed = CHECKSUM_UNNECESSARY; | ||
| 1500 | } else { | ||
| 1501 | skb->ip_summed = CHECKSUM_NONE; | 1501 | skb->ip_summed = CHECKSUM_NONE; |
| 1502 | } | 1502 | else |
| 1503 | skb->ip_summed = CHECKSUM_UNNECESSARY; | ||
| 1504 | |||
| 1503 | napi_gro_receive(&adapter->napi, skb); | 1505 | napi_gro_receive(&adapter->napi, skb); |
| 1504 | (*work_done)++; | 1506 | (*work_done)++; |
| 1505 | pr_debug("Receive skb->ip_summed: %d length: %d\n", | 1507 | pr_debug("Receive skb->ip_summed: %d length: %d\n", |
| @@ -2420,6 +2422,13 @@ static DEFINE_PCI_DEVICE_TABLE(pch_gbe_pcidev_id) = { | |||
| 2420 | .class = (PCI_CLASS_NETWORK_ETHERNET << 8), | 2422 | .class = (PCI_CLASS_NETWORK_ETHERNET << 8), |
| 2421 | .class_mask = (0xFFFF00) | 2423 | .class_mask = (0xFFFF00) |
| 2422 | }, | 2424 | }, |
| 2425 | {.vendor = PCI_VENDOR_ID_ROHM, | ||
| 2426 | .device = PCI_DEVICE_ID_ROHM_ML7223_GBE, | ||
| 2427 | .subvendor = PCI_ANY_ID, | ||
| 2428 | .subdevice = PCI_ANY_ID, | ||
| 2429 | .class = (PCI_CLASS_NETWORK_ETHERNET << 8), | ||
| 2430 | .class_mask = (0xFFFF00) | ||
| 2431 | }, | ||
| 2423 | /* required last entry */ | 2432 | /* required last entry */ |
| 2424 | {0} | 2433 | {0} |
| 2425 | }; | 2434 | }; |
diff --git a/drivers/net/sfc/mcdi.c b/drivers/net/sfc/mcdi.c index d98479030ef2..3dd45ed61f0a 100644 --- a/drivers/net/sfc/mcdi.c +++ b/drivers/net/sfc/mcdi.c | |||
| @@ -50,6 +50,20 @@ static inline struct efx_mcdi_iface *efx_mcdi(struct efx_nic *efx) | |||
| 50 | return &nic_data->mcdi; | 50 | return &nic_data->mcdi; |
| 51 | } | 51 | } |
| 52 | 52 | ||
| 53 | static inline void | ||
| 54 | efx_mcdi_readd(struct efx_nic *efx, efx_dword_t *value, unsigned reg) | ||
| 55 | { | ||
| 56 | struct siena_nic_data *nic_data = efx->nic_data; | ||
| 57 | value->u32[0] = (__force __le32)__raw_readl(nic_data->mcdi_smem + reg); | ||
| 58 | } | ||
| 59 | |||
| 60 | static inline void | ||
| 61 | efx_mcdi_writed(struct efx_nic *efx, const efx_dword_t *value, unsigned reg) | ||
| 62 | { | ||
| 63 | struct siena_nic_data *nic_data = efx->nic_data; | ||
| 64 | __raw_writel((__force u32)value->u32[0], nic_data->mcdi_smem + reg); | ||
| 65 | } | ||
| 66 | |||
| 53 | void efx_mcdi_init(struct efx_nic *efx) | 67 | void efx_mcdi_init(struct efx_nic *efx) |
| 54 | { | 68 | { |
| 55 | struct efx_mcdi_iface *mcdi; | 69 | struct efx_mcdi_iface *mcdi; |
| @@ -70,8 +84,8 @@ static void efx_mcdi_copyin(struct efx_nic *efx, unsigned cmd, | |||
| 70 | const u8 *inbuf, size_t inlen) | 84 | const u8 *inbuf, size_t inlen) |
| 71 | { | 85 | { |
| 72 | struct efx_mcdi_iface *mcdi = efx_mcdi(efx); | 86 | struct efx_mcdi_iface *mcdi = efx_mcdi(efx); |
| 73 | unsigned pdu = FR_CZ_MC_TREG_SMEM + MCDI_PDU(efx); | 87 | unsigned pdu = MCDI_PDU(efx); |
| 74 | unsigned doorbell = FR_CZ_MC_TREG_SMEM + MCDI_DOORBELL(efx); | 88 | unsigned doorbell = MCDI_DOORBELL(efx); |
| 75 | unsigned int i; | 89 | unsigned int i; |
| 76 | efx_dword_t hdr; | 90 | efx_dword_t hdr; |
| 77 | u32 xflags, seqno; | 91 | u32 xflags, seqno; |
| @@ -92,30 +106,28 @@ static void efx_mcdi_copyin(struct efx_nic *efx, unsigned cmd, | |||
| 92 | MCDI_HEADER_SEQ, seqno, | 106 | MCDI_HEADER_SEQ, seqno, |
| 93 | MCDI_HEADER_XFLAGS, xflags); | 107 | MCDI_HEADER_XFLAGS, xflags); |
| 94 | 108 | ||
| 95 | efx_writed(efx, &hdr, pdu); | 109 | efx_mcdi_writed(efx, &hdr, pdu); |
| 96 | 110 | ||
| 97 | for (i = 0; i < inlen; i += 4) { | 111 | for (i = 0; i < inlen; i += 4) |
| 98 | _efx_writed(efx, *((__le32 *)(inbuf + i)), pdu + 4 + i); | 112 | efx_mcdi_writed(efx, (const efx_dword_t *)(inbuf + i), |
| 99 | /* use wmb() within loop to inhibit write combining */ | 113 | pdu + 4 + i); |
| 100 | wmb(); | ||
| 101 | } | ||
| 102 | 114 | ||
| 103 | /* ring the doorbell with a distinctive value */ | 115 | /* ring the doorbell with a distinctive value */ |
| 104 | _efx_writed(efx, (__force __le32) 0x45789abc, doorbell); | 116 | EFX_POPULATE_DWORD_1(hdr, EFX_DWORD_0, 0x45789abc); |
| 105 | wmb(); | 117 | efx_mcdi_writed(efx, &hdr, doorbell); |
| 106 | } | 118 | } |
| 107 | 119 | ||
| 108 | static void efx_mcdi_copyout(struct efx_nic *efx, u8 *outbuf, size_t outlen) | 120 | static void efx_mcdi_copyout(struct efx_nic *efx, u8 *outbuf, size_t outlen) |
| 109 | { | 121 | { |
| 110 | struct efx_mcdi_iface *mcdi = efx_mcdi(efx); | 122 | struct efx_mcdi_iface *mcdi = efx_mcdi(efx); |
| 111 | unsigned int pdu = FR_CZ_MC_TREG_SMEM + MCDI_PDU(efx); | 123 | unsigned int pdu = MCDI_PDU(efx); |
| 112 | int i; | 124 | int i; |
| 113 | 125 | ||
| 114 | BUG_ON(atomic_read(&mcdi->state) == MCDI_STATE_QUIESCENT); | 126 | BUG_ON(atomic_read(&mcdi->state) == MCDI_STATE_QUIESCENT); |
| 115 | BUG_ON(outlen & 3 || outlen >= 0x100); | 127 | BUG_ON(outlen & 3 || outlen >= 0x100); |
| 116 | 128 | ||
| 117 | for (i = 0; i < outlen; i += 4) | 129 | for (i = 0; i < outlen; i += 4) |
| 118 | *((__le32 *)(outbuf + i)) = _efx_readd(efx, pdu + 4 + i); | 130 | efx_mcdi_readd(efx, (efx_dword_t *)(outbuf + i), pdu + 4 + i); |
| 119 | } | 131 | } |
| 120 | 132 | ||
| 121 | static int efx_mcdi_poll(struct efx_nic *efx) | 133 | static int efx_mcdi_poll(struct efx_nic *efx) |
| @@ -123,7 +135,7 @@ static int efx_mcdi_poll(struct efx_nic *efx) | |||
| 123 | struct efx_mcdi_iface *mcdi = efx_mcdi(efx); | 135 | struct efx_mcdi_iface *mcdi = efx_mcdi(efx); |
| 124 | unsigned int time, finish; | 136 | unsigned int time, finish; |
| 125 | unsigned int respseq, respcmd, error; | 137 | unsigned int respseq, respcmd, error; |
| 126 | unsigned int pdu = FR_CZ_MC_TREG_SMEM + MCDI_PDU(efx); | 138 | unsigned int pdu = MCDI_PDU(efx); |
| 127 | unsigned int rc, spins; | 139 | unsigned int rc, spins; |
| 128 | efx_dword_t reg; | 140 | efx_dword_t reg; |
| 129 | 141 | ||
| @@ -149,8 +161,7 @@ static int efx_mcdi_poll(struct efx_nic *efx) | |||
| 149 | 161 | ||
| 150 | time = get_seconds(); | 162 | time = get_seconds(); |
| 151 | 163 | ||
| 152 | rmb(); | 164 | efx_mcdi_readd(efx, ®, pdu); |
| 153 | efx_readd(efx, ®, pdu); | ||
| 154 | 165 | ||
| 155 | /* All 1's indicates that shared memory is in reset (and is | 166 | /* All 1's indicates that shared memory is in reset (and is |
| 156 | * not a valid header). Wait for it to come out reset before | 167 | * not a valid header). Wait for it to come out reset before |
| @@ -177,7 +188,7 @@ static int efx_mcdi_poll(struct efx_nic *efx) | |||
| 177 | respseq, mcdi->seqno); | 188 | respseq, mcdi->seqno); |
| 178 | rc = EIO; | 189 | rc = EIO; |
| 179 | } else if (error) { | 190 | } else if (error) { |
| 180 | efx_readd(efx, ®, pdu + 4); | 191 | efx_mcdi_readd(efx, ®, pdu + 4); |
| 181 | switch (EFX_DWORD_FIELD(reg, EFX_DWORD_0)) { | 192 | switch (EFX_DWORD_FIELD(reg, EFX_DWORD_0)) { |
| 182 | #define TRANSLATE_ERROR(name) \ | 193 | #define TRANSLATE_ERROR(name) \ |
| 183 | case MC_CMD_ERR_ ## name: \ | 194 | case MC_CMD_ERR_ ## name: \ |
| @@ -211,21 +222,21 @@ out: | |||
| 211 | /* Test and clear MC-rebooted flag for this port/function */ | 222 | /* Test and clear MC-rebooted flag for this port/function */ |
| 212 | int efx_mcdi_poll_reboot(struct efx_nic *efx) | 223 | int efx_mcdi_poll_reboot(struct efx_nic *efx) |
| 213 | { | 224 | { |
| 214 | unsigned int addr = FR_CZ_MC_TREG_SMEM + MCDI_REBOOT_FLAG(efx); | 225 | unsigned int addr = MCDI_REBOOT_FLAG(efx); |
| 215 | efx_dword_t reg; | 226 | efx_dword_t reg; |
| 216 | uint32_t value; | 227 | uint32_t value; |
| 217 | 228 | ||
| 218 | if (efx_nic_rev(efx) < EFX_REV_SIENA_A0) | 229 | if (efx_nic_rev(efx) < EFX_REV_SIENA_A0) |
| 219 | return false; | 230 | return false; |
| 220 | 231 | ||
| 221 | efx_readd(efx, ®, addr); | 232 | efx_mcdi_readd(efx, ®, addr); |
| 222 | value = EFX_DWORD_FIELD(reg, EFX_DWORD_0); | 233 | value = EFX_DWORD_FIELD(reg, EFX_DWORD_0); |
| 223 | 234 | ||
| 224 | if (value == 0) | 235 | if (value == 0) |
| 225 | return 0; | 236 | return 0; |
| 226 | 237 | ||
| 227 | EFX_ZERO_DWORD(reg); | 238 | EFX_ZERO_DWORD(reg); |
| 228 | efx_writed(efx, ®, addr); | 239 | efx_mcdi_writed(efx, ®, addr); |
| 229 | 240 | ||
| 230 | if (value == MC_STATUS_DWORD_ASSERT) | 241 | if (value == MC_STATUS_DWORD_ASSERT) |
| 231 | return -EINTR; | 242 | return -EINTR; |
diff --git a/drivers/net/sfc/nic.c b/drivers/net/sfc/nic.c index 10f1cb79c147..9b29a8d7c449 100644 --- a/drivers/net/sfc/nic.c +++ b/drivers/net/sfc/nic.c | |||
| @@ -1937,6 +1937,13 @@ void efx_nic_get_regs(struct efx_nic *efx, void *buf) | |||
| 1937 | 1937 | ||
| 1938 | size = min_t(size_t, table->step, 16); | 1938 | size = min_t(size_t, table->step, 16); |
| 1939 | 1939 | ||
| 1940 | if (table->offset >= efx->type->mem_map_size) { | ||
| 1941 | /* No longer mapped; return dummy data */ | ||
| 1942 | memcpy(buf, "\xde\xc0\xad\xde", 4); | ||
| 1943 | buf += table->rows * size; | ||
| 1944 | continue; | ||
| 1945 | } | ||
| 1946 | |||
| 1940 | for (i = 0; i < table->rows; i++) { | 1947 | for (i = 0; i < table->rows; i++) { |
| 1941 | switch (table->step) { | 1948 | switch (table->step) { |
| 1942 | case 4: /* 32-bit register or SRAM */ | 1949 | case 4: /* 32-bit register or SRAM */ |
diff --git a/drivers/net/sfc/nic.h b/drivers/net/sfc/nic.h index a42db6e35be3..d91701abd331 100644 --- a/drivers/net/sfc/nic.h +++ b/drivers/net/sfc/nic.h | |||
| @@ -143,10 +143,12 @@ static inline struct falcon_board *falcon_board(struct efx_nic *efx) | |||
| 143 | /** | 143 | /** |
| 144 | * struct siena_nic_data - Siena NIC state | 144 | * struct siena_nic_data - Siena NIC state |
| 145 | * @mcdi: Management-Controller-to-Driver Interface | 145 | * @mcdi: Management-Controller-to-Driver Interface |
| 146 | * @mcdi_smem: MCDI shared memory mapping. The mapping is always uncacheable. | ||
| 146 | * @wol_filter_id: Wake-on-LAN packet filter id | 147 | * @wol_filter_id: Wake-on-LAN packet filter id |
| 147 | */ | 148 | */ |
| 148 | struct siena_nic_data { | 149 | struct siena_nic_data { |
| 149 | struct efx_mcdi_iface mcdi; | 150 | struct efx_mcdi_iface mcdi; |
| 151 | void __iomem *mcdi_smem; | ||
| 150 | int wol_filter_id; | 152 | int wol_filter_id; |
| 151 | }; | 153 | }; |
| 152 | 154 | ||
diff --git a/drivers/net/sfc/siena.c b/drivers/net/sfc/siena.c index e4dd8986b1fe..837869b71db9 100644 --- a/drivers/net/sfc/siena.c +++ b/drivers/net/sfc/siena.c | |||
| @@ -220,12 +220,26 @@ static int siena_probe_nic(struct efx_nic *efx) | |||
| 220 | efx_reado(efx, ®, FR_AZ_CS_DEBUG); | 220 | efx_reado(efx, ®, FR_AZ_CS_DEBUG); |
| 221 | efx->net_dev->dev_id = EFX_OWORD_FIELD(reg, FRF_CZ_CS_PORT_NUM) - 1; | 221 | efx->net_dev->dev_id = EFX_OWORD_FIELD(reg, FRF_CZ_CS_PORT_NUM) - 1; |
| 222 | 222 | ||
| 223 | /* Initialise MCDI */ | ||
| 224 | nic_data->mcdi_smem = ioremap_nocache(efx->membase_phys + | ||
| 225 | FR_CZ_MC_TREG_SMEM, | ||
| 226 | FR_CZ_MC_TREG_SMEM_STEP * | ||
| 227 | FR_CZ_MC_TREG_SMEM_ROWS); | ||
| 228 | if (!nic_data->mcdi_smem) { | ||
| 229 | netif_err(efx, probe, efx->net_dev, | ||
| 230 | "could not map MCDI at %llx+%x\n", | ||
| 231 | (unsigned long long)efx->membase_phys + | ||
| 232 | FR_CZ_MC_TREG_SMEM, | ||
| 233 | FR_CZ_MC_TREG_SMEM_STEP * FR_CZ_MC_TREG_SMEM_ROWS); | ||
| 234 | rc = -ENOMEM; | ||
| 235 | goto fail1; | ||
| 236 | } | ||
| 223 | efx_mcdi_init(efx); | 237 | efx_mcdi_init(efx); |
| 224 | 238 | ||
| 225 | /* Recover from a failed assertion before probing */ | 239 | /* Recover from a failed assertion before probing */ |
| 226 | rc = efx_mcdi_handle_assertion(efx); | 240 | rc = efx_mcdi_handle_assertion(efx); |
| 227 | if (rc) | 241 | if (rc) |
| 228 | goto fail1; | 242 | goto fail2; |
| 229 | 243 | ||
| 230 | /* Let the BMC know that the driver is now in charge of link and | 244 | /* Let the BMC know that the driver is now in charge of link and |
| 231 | * filter settings. We must do this before we reset the NIC */ | 245 | * filter settings. We must do this before we reset the NIC */ |
| @@ -280,6 +294,7 @@ fail4: | |||
| 280 | fail3: | 294 | fail3: |
| 281 | efx_mcdi_drv_attach(efx, false, NULL); | 295 | efx_mcdi_drv_attach(efx, false, NULL); |
| 282 | fail2: | 296 | fail2: |
| 297 | iounmap(nic_data->mcdi_smem); | ||
| 283 | fail1: | 298 | fail1: |
| 284 | kfree(efx->nic_data); | 299 | kfree(efx->nic_data); |
| 285 | return rc; | 300 | return rc; |
| @@ -359,6 +374,8 @@ static int siena_init_nic(struct efx_nic *efx) | |||
| 359 | 374 | ||
| 360 | static void siena_remove_nic(struct efx_nic *efx) | 375 | static void siena_remove_nic(struct efx_nic *efx) |
| 361 | { | 376 | { |
| 377 | struct siena_nic_data *nic_data = efx->nic_data; | ||
| 378 | |||
| 362 | efx_nic_free_buffer(efx, &efx->irq_status); | 379 | efx_nic_free_buffer(efx, &efx->irq_status); |
| 363 | 380 | ||
| 364 | siena_reset_hw(efx, RESET_TYPE_ALL); | 381 | siena_reset_hw(efx, RESET_TYPE_ALL); |
| @@ -368,7 +385,8 @@ static void siena_remove_nic(struct efx_nic *efx) | |||
| 368 | efx_mcdi_drv_attach(efx, false, NULL); | 385 | efx_mcdi_drv_attach(efx, false, NULL); |
| 369 | 386 | ||
| 370 | /* Tear down the private nic state */ | 387 | /* Tear down the private nic state */ |
| 371 | kfree(efx->nic_data); | 388 | iounmap(nic_data->mcdi_smem); |
| 389 | kfree(nic_data); | ||
| 372 | efx->nic_data = NULL; | 390 | efx->nic_data = NULL; |
| 373 | } | 391 | } |
| 374 | 392 | ||
| @@ -606,8 +624,7 @@ struct efx_nic_type siena_a0_nic_type = { | |||
| 606 | .default_mac_ops = &efx_mcdi_mac_operations, | 624 | .default_mac_ops = &efx_mcdi_mac_operations, |
| 607 | 625 | ||
| 608 | .revision = EFX_REV_SIENA_A0, | 626 | .revision = EFX_REV_SIENA_A0, |
| 609 | .mem_map_size = (FR_CZ_MC_TREG_SMEM + | 627 | .mem_map_size = FR_CZ_MC_TREG_SMEM, /* MC_TREG_SMEM mapped separately */ |
| 610 | FR_CZ_MC_TREG_SMEM_STEP * FR_CZ_MC_TREG_SMEM_ROWS), | ||
| 611 | .txd_ptr_tbl_base = FR_BZ_TX_DESC_PTR_TBL, | 628 | .txd_ptr_tbl_base = FR_BZ_TX_DESC_PTR_TBL, |
| 612 | .rxd_ptr_tbl_base = FR_BZ_RX_DESC_PTR_TBL, | 629 | .rxd_ptr_tbl_base = FR_BZ_RX_DESC_PTR_TBL, |
| 613 | .buf_tbl_base = FR_BZ_BUF_FULL_TBL, | 630 | .buf_tbl_base = FR_BZ_BUF_FULL_TBL, |
diff --git a/drivers/net/slip.c b/drivers/net/slip.c index 86cbb9ea2f26..8ec1a9a0bb9a 100644 --- a/drivers/net/slip.c +++ b/drivers/net/slip.c | |||
| @@ -853,7 +853,9 @@ static int slip_open(struct tty_struct *tty) | |||
| 853 | /* Done. We have linked the TTY line to a channel. */ | 853 | /* Done. We have linked the TTY line to a channel. */ |
| 854 | rtnl_unlock(); | 854 | rtnl_unlock(); |
| 855 | tty->receive_room = 65536; /* We don't flow control */ | 855 | tty->receive_room = 65536; /* We don't flow control */ |
| 856 | return sl->dev->base_addr; | 856 | |
| 857 | /* TTY layer expects 0 on success */ | ||
| 858 | return 0; | ||
| 857 | 859 | ||
| 858 | err_free_bufs: | 860 | err_free_bufs: |
| 859 | sl_free_bufs(sl); | 861 | sl_free_bufs(sl); |
diff --git a/drivers/net/usb/cdc_ether.c b/drivers/net/usb/cdc_ether.c index a301479ecc60..c924ea2bce07 100644 --- a/drivers/net/usb/cdc_ether.c +++ b/drivers/net/usb/cdc_ether.c | |||
| @@ -567,7 +567,7 @@ static const struct usb_device_id products [] = { | |||
| 567 | { | 567 | { |
| 568 | USB_DEVICE_AND_INTERFACE_INFO(0x1004, 0x61aa, USB_CLASS_COMM, | 568 | USB_DEVICE_AND_INTERFACE_INFO(0x1004, 0x61aa, USB_CLASS_COMM, |
| 569 | USB_CDC_SUBCLASS_ETHERNET, USB_CDC_PROTO_NONE), | 569 | USB_CDC_SUBCLASS_ETHERNET, USB_CDC_PROTO_NONE), |
| 570 | .driver_info = 0, | 570 | .driver_info = (unsigned long)&wwan_info, |
| 571 | }, | 571 | }, |
| 572 | 572 | ||
| 573 | /* | 573 | /* |
diff --git a/drivers/net/usb/ipheth.c b/drivers/net/usb/ipheth.c index 7d42f9a2c068..81126ff85e05 100644 --- a/drivers/net/usb/ipheth.c +++ b/drivers/net/usb/ipheth.c | |||
| @@ -65,6 +65,7 @@ | |||
| 65 | #define IPHETH_USBINTF_PROTO 1 | 65 | #define IPHETH_USBINTF_PROTO 1 |
| 66 | 66 | ||
| 67 | #define IPHETH_BUF_SIZE 1516 | 67 | #define IPHETH_BUF_SIZE 1516 |
| 68 | #define IPHETH_IP_ALIGN 2 /* padding at front of URB */ | ||
| 68 | #define IPHETH_TX_TIMEOUT (5 * HZ) | 69 | #define IPHETH_TX_TIMEOUT (5 * HZ) |
| 69 | 70 | ||
| 70 | #define IPHETH_INTFNUM 2 | 71 | #define IPHETH_INTFNUM 2 |
| @@ -202,18 +203,21 @@ static void ipheth_rcvbulk_callback(struct urb *urb) | |||
| 202 | return; | 203 | return; |
| 203 | } | 204 | } |
| 204 | 205 | ||
| 205 | len = urb->actual_length; | 206 | if (urb->actual_length <= IPHETH_IP_ALIGN) { |
| 206 | buf = urb->transfer_buffer; | 207 | dev->net->stats.rx_length_errors++; |
| 208 | return; | ||
| 209 | } | ||
| 210 | len = urb->actual_length - IPHETH_IP_ALIGN; | ||
| 211 | buf = urb->transfer_buffer + IPHETH_IP_ALIGN; | ||
| 207 | 212 | ||
| 208 | skb = dev_alloc_skb(NET_IP_ALIGN + len); | 213 | skb = dev_alloc_skb(len); |
| 209 | if (!skb) { | 214 | if (!skb) { |
| 210 | err("%s: dev_alloc_skb: -ENOMEM", __func__); | 215 | err("%s: dev_alloc_skb: -ENOMEM", __func__); |
| 211 | dev->net->stats.rx_dropped++; | 216 | dev->net->stats.rx_dropped++; |
| 212 | return; | 217 | return; |
| 213 | } | 218 | } |
| 214 | 219 | ||
| 215 | skb_reserve(skb, NET_IP_ALIGN); | 220 | memcpy(skb_put(skb, len), buf, len); |
| 216 | memcpy(skb_put(skb, len), buf + NET_IP_ALIGN, len - NET_IP_ALIGN); | ||
| 217 | skb->dev = dev->net; | 221 | skb->dev = dev->net; |
| 218 | skb->protocol = eth_type_trans(skb, dev->net); | 222 | skb->protocol = eth_type_trans(skb, dev->net); |
| 219 | 223 | ||
diff --git a/drivers/net/usb/usbnet.c b/drivers/net/usb/usbnet.c index 009bba3d753e..9ab439d144ed 100644 --- a/drivers/net/usb/usbnet.c +++ b/drivers/net/usb/usbnet.c | |||
| @@ -645,6 +645,7 @@ int usbnet_stop (struct net_device *net) | |||
| 645 | struct driver_info *info = dev->driver_info; | 645 | struct driver_info *info = dev->driver_info; |
| 646 | int retval; | 646 | int retval; |
| 647 | 647 | ||
| 648 | clear_bit(EVENT_DEV_OPEN, &dev->flags); | ||
| 648 | netif_stop_queue (net); | 649 | netif_stop_queue (net); |
| 649 | 650 | ||
| 650 | netif_info(dev, ifdown, dev->net, | 651 | netif_info(dev, ifdown, dev->net, |
| @@ -1524,9 +1525,12 @@ int usbnet_resume (struct usb_interface *intf) | |||
| 1524 | smp_mb(); | 1525 | smp_mb(); |
| 1525 | clear_bit(EVENT_DEV_ASLEEP, &dev->flags); | 1526 | clear_bit(EVENT_DEV_ASLEEP, &dev->flags); |
| 1526 | spin_unlock_irq(&dev->txq.lock); | 1527 | spin_unlock_irq(&dev->txq.lock); |
| 1527 | if (!(dev->txq.qlen >= TX_QLEN(dev))) | 1528 | |
| 1528 | netif_start_queue(dev->net); | 1529 | if (test_bit(EVENT_DEV_OPEN, &dev->flags)) { |
| 1529 | tasklet_schedule (&dev->bh); | 1530 | if (!(dev->txq.qlen >= TX_QLEN(dev))) |
| 1531 | netif_start_queue(dev->net); | ||
| 1532 | tasklet_schedule (&dev->bh); | ||
| 1533 | } | ||
| 1530 | } | 1534 | } |
| 1531 | return 0; | 1535 | return 0; |
| 1532 | } | 1536 | } |
diff --git a/drivers/net/vmxnet3/vmxnet3_drv.c b/drivers/net/vmxnet3/vmxnet3_drv.c index 0d47c3a05307..c16ed961153a 100644 --- a/drivers/net/vmxnet3/vmxnet3_drv.c +++ b/drivers/net/vmxnet3/vmxnet3_drv.c | |||
| @@ -178,6 +178,7 @@ static void | |||
| 178 | vmxnet3_process_events(struct vmxnet3_adapter *adapter) | 178 | vmxnet3_process_events(struct vmxnet3_adapter *adapter) |
| 179 | { | 179 | { |
| 180 | int i; | 180 | int i; |
| 181 | unsigned long flags; | ||
| 181 | u32 events = le32_to_cpu(adapter->shared->ecr); | 182 | u32 events = le32_to_cpu(adapter->shared->ecr); |
| 182 | if (!events) | 183 | if (!events) |
| 183 | return; | 184 | return; |
| @@ -190,10 +191,10 @@ vmxnet3_process_events(struct vmxnet3_adapter *adapter) | |||
| 190 | 191 | ||
| 191 | /* Check if there is an error on xmit/recv queues */ | 192 | /* Check if there is an error on xmit/recv queues */ |
| 192 | if (events & (VMXNET3_ECR_TQERR | VMXNET3_ECR_RQERR)) { | 193 | if (events & (VMXNET3_ECR_TQERR | VMXNET3_ECR_RQERR)) { |
| 193 | spin_lock(&adapter->cmd_lock); | 194 | spin_lock_irqsave(&adapter->cmd_lock, flags); |
| 194 | VMXNET3_WRITE_BAR1_REG(adapter, VMXNET3_REG_CMD, | 195 | VMXNET3_WRITE_BAR1_REG(adapter, VMXNET3_REG_CMD, |
| 195 | VMXNET3_CMD_GET_QUEUE_STATUS); | 196 | VMXNET3_CMD_GET_QUEUE_STATUS); |
| 196 | spin_unlock(&adapter->cmd_lock); | 197 | spin_unlock_irqrestore(&adapter->cmd_lock, flags); |
| 197 | 198 | ||
| 198 | for (i = 0; i < adapter->num_tx_queues; i++) | 199 | for (i = 0; i < adapter->num_tx_queues; i++) |
| 199 | if (adapter->tqd_start[i].status.stopped) | 200 | if (adapter->tqd_start[i].status.stopped) |
| @@ -2733,13 +2734,14 @@ static void | |||
| 2733 | vmxnet3_alloc_intr_resources(struct vmxnet3_adapter *adapter) | 2734 | vmxnet3_alloc_intr_resources(struct vmxnet3_adapter *adapter) |
| 2734 | { | 2735 | { |
| 2735 | u32 cfg; | 2736 | u32 cfg; |
| 2737 | unsigned long flags; | ||
| 2736 | 2738 | ||
| 2737 | /* intr settings */ | 2739 | /* intr settings */ |
| 2738 | spin_lock(&adapter->cmd_lock); | 2740 | spin_lock_irqsave(&adapter->cmd_lock, flags); |
| 2739 | VMXNET3_WRITE_BAR1_REG(adapter, VMXNET3_REG_CMD, | 2741 | VMXNET3_WRITE_BAR1_REG(adapter, VMXNET3_REG_CMD, |
| 2740 | VMXNET3_CMD_GET_CONF_INTR); | 2742 | VMXNET3_CMD_GET_CONF_INTR); |
| 2741 | cfg = VMXNET3_READ_BAR1_REG(adapter, VMXNET3_REG_CMD); | 2743 | cfg = VMXNET3_READ_BAR1_REG(adapter, VMXNET3_REG_CMD); |
| 2742 | spin_unlock(&adapter->cmd_lock); | 2744 | spin_unlock_irqrestore(&adapter->cmd_lock, flags); |
| 2743 | adapter->intr.type = cfg & 0x3; | 2745 | adapter->intr.type = cfg & 0x3; |
| 2744 | adapter->intr.mask_mode = (cfg >> 2) & 0x3; | 2746 | adapter->intr.mask_mode = (cfg >> 2) & 0x3; |
| 2745 | 2747 | ||
diff --git a/drivers/net/vmxnet3/vmxnet3_ethtool.c b/drivers/net/vmxnet3/vmxnet3_ethtool.c index 51f2ef142a5b..976467253d20 100644 --- a/drivers/net/vmxnet3/vmxnet3_ethtool.c +++ b/drivers/net/vmxnet3/vmxnet3_ethtool.c | |||
| @@ -311,6 +311,9 @@ vmxnet3_set_flags(struct net_device *netdev, u32 data) | |||
| 311 | /* toggle the LRO feature*/ | 311 | /* toggle the LRO feature*/ |
| 312 | netdev->features ^= NETIF_F_LRO; | 312 | netdev->features ^= NETIF_F_LRO; |
| 313 | 313 | ||
| 314 | /* Update private LRO flag */ | ||
| 315 | adapter->lro = lro_requested; | ||
| 316 | |||
| 314 | /* update harware LRO capability accordingly */ | 317 | /* update harware LRO capability accordingly */ |
| 315 | if (lro_requested) | 318 | if (lro_requested) |
| 316 | adapter->shared->devRead.misc.uptFeatures |= | 319 | adapter->shared->devRead.misc.uptFeatures |= |
diff --git a/drivers/net/wireless/ath/ath9k/main.c b/drivers/net/wireless/ath/ath9k/main.c index 17d04ff8d678..1482fa650833 100644 --- a/drivers/net/wireless/ath/ath9k/main.c +++ b/drivers/net/wireless/ath/ath9k/main.c | |||
| @@ -2141,6 +2141,8 @@ static void ath9k_set_coverage_class(struct ieee80211_hw *hw, u8 coverage_class) | |||
| 2141 | static void ath9k_flush(struct ieee80211_hw *hw, bool drop) | 2141 | static void ath9k_flush(struct ieee80211_hw *hw, bool drop) |
| 2142 | { | 2142 | { |
| 2143 | struct ath_softc *sc = hw->priv; | 2143 | struct ath_softc *sc = hw->priv; |
| 2144 | struct ath_hw *ah = sc->sc_ah; | ||
| 2145 | struct ath_common *common = ath9k_hw_common(ah); | ||
| 2144 | int timeout = 200; /* ms */ | 2146 | int timeout = 200; /* ms */ |
| 2145 | int i, j; | 2147 | int i, j; |
| 2146 | 2148 | ||
| @@ -2149,6 +2151,12 @@ static void ath9k_flush(struct ieee80211_hw *hw, bool drop) | |||
| 2149 | 2151 | ||
| 2150 | cancel_delayed_work_sync(&sc->tx_complete_work); | 2152 | cancel_delayed_work_sync(&sc->tx_complete_work); |
| 2151 | 2153 | ||
| 2154 | if (sc->sc_flags & SC_OP_INVALID) { | ||
| 2155 | ath_dbg(common, ATH_DBG_ANY, "Device not present\n"); | ||
| 2156 | mutex_unlock(&sc->mutex); | ||
| 2157 | return; | ||
| 2158 | } | ||
| 2159 | |||
| 2152 | if (drop) | 2160 | if (drop) |
| 2153 | timeout = 1; | 2161 | timeout = 1; |
| 2154 | 2162 | ||
diff --git a/drivers/net/wireless/iwlegacy/iwl-core.c b/drivers/net/wireless/iwlegacy/iwl-core.c index c1511b14b239..42db0fc8b921 100644 --- a/drivers/net/wireless/iwlegacy/iwl-core.c +++ b/drivers/net/wireless/iwlegacy/iwl-core.c | |||
| @@ -2155,6 +2155,13 @@ int iwl_legacy_mac_config(struct ieee80211_hw *hw, u32 changed) | |||
| 2155 | goto set_ch_out; | 2155 | goto set_ch_out; |
| 2156 | } | 2156 | } |
| 2157 | 2157 | ||
| 2158 | if (priv->iw_mode == NL80211_IFTYPE_ADHOC && | ||
| 2159 | !iwl_legacy_is_channel_ibss(ch_info)) { | ||
| 2160 | IWL_DEBUG_MAC80211(priv, "leave - not IBSS channel\n"); | ||
| 2161 | ret = -EINVAL; | ||
| 2162 | goto set_ch_out; | ||
| 2163 | } | ||
| 2164 | |||
| 2158 | spin_lock_irqsave(&priv->lock, flags); | 2165 | spin_lock_irqsave(&priv->lock, flags); |
| 2159 | 2166 | ||
| 2160 | for_each_context(priv, ctx) { | 2167 | for_each_context(priv, ctx) { |
diff --git a/drivers/net/wireless/iwlegacy/iwl-dev.h b/drivers/net/wireless/iwlegacy/iwl-dev.h index 9ee849d669f3..f43ac1eb9014 100644 --- a/drivers/net/wireless/iwlegacy/iwl-dev.h +++ b/drivers/net/wireless/iwlegacy/iwl-dev.h | |||
| @@ -1411,6 +1411,12 @@ iwl_legacy_is_channel_passive(const struct iwl_channel_info *ch) | |||
| 1411 | return (!(ch->flags & EEPROM_CHANNEL_ACTIVE)) ? 1 : 0; | 1411 | return (!(ch->flags & EEPROM_CHANNEL_ACTIVE)) ? 1 : 0; |
| 1412 | } | 1412 | } |
| 1413 | 1413 | ||
| 1414 | static inline int | ||
| 1415 | iwl_legacy_is_channel_ibss(const struct iwl_channel_info *ch) | ||
| 1416 | { | ||
| 1417 | return (ch->flags & EEPROM_CHANNEL_IBSS) ? 1 : 0; | ||
| 1418 | } | ||
| 1419 | |||
| 1414 | static inline void | 1420 | static inline void |
| 1415 | __iwl_legacy_free_pages(struct iwl_priv *priv, struct page *page) | 1421 | __iwl_legacy_free_pages(struct iwl_priv *priv, struct page *page) |
| 1416 | { | 1422 | { |
diff --git a/drivers/net/wireless/libertas/cmd.c b/drivers/net/wireless/libertas/cmd.c index 7e8a658b7670..f3ac62431a30 100644 --- a/drivers/net/wireless/libertas/cmd.c +++ b/drivers/net/wireless/libertas/cmd.c | |||
| @@ -1339,8 +1339,8 @@ int lbs_execute_next_command(struct lbs_private *priv) | |||
| 1339 | cpu_to_le16(PS_MODE_ACTION_EXIT_PS)) { | 1339 | cpu_to_le16(PS_MODE_ACTION_EXIT_PS)) { |
| 1340 | lbs_deb_host( | 1340 | lbs_deb_host( |
| 1341 | "EXEC_NEXT_CMD: ignore ENTER_PS cmd\n"); | 1341 | "EXEC_NEXT_CMD: ignore ENTER_PS cmd\n"); |
| 1342 | list_del(&cmdnode->list); | ||
| 1343 | spin_lock_irqsave(&priv->driver_lock, flags); | 1342 | spin_lock_irqsave(&priv->driver_lock, flags); |
| 1343 | list_del(&cmdnode->list); | ||
| 1344 | lbs_complete_command(priv, cmdnode, 0); | 1344 | lbs_complete_command(priv, cmdnode, 0); |
| 1345 | spin_unlock_irqrestore(&priv->driver_lock, flags); | 1345 | spin_unlock_irqrestore(&priv->driver_lock, flags); |
| 1346 | 1346 | ||
| @@ -1352,8 +1352,8 @@ int lbs_execute_next_command(struct lbs_private *priv) | |||
| 1352 | (priv->psstate == PS_STATE_PRE_SLEEP)) { | 1352 | (priv->psstate == PS_STATE_PRE_SLEEP)) { |
| 1353 | lbs_deb_host( | 1353 | lbs_deb_host( |
| 1354 | "EXEC_NEXT_CMD: ignore EXIT_PS cmd in sleep\n"); | 1354 | "EXEC_NEXT_CMD: ignore EXIT_PS cmd in sleep\n"); |
| 1355 | list_del(&cmdnode->list); | ||
| 1356 | spin_lock_irqsave(&priv->driver_lock, flags); | 1355 | spin_lock_irqsave(&priv->driver_lock, flags); |
| 1356 | list_del(&cmdnode->list); | ||
| 1357 | lbs_complete_command(priv, cmdnode, 0); | 1357 | lbs_complete_command(priv, cmdnode, 0); |
| 1358 | spin_unlock_irqrestore(&priv->driver_lock, flags); | 1358 | spin_unlock_irqrestore(&priv->driver_lock, flags); |
| 1359 | priv->needtowakeup = 1; | 1359 | priv->needtowakeup = 1; |
| @@ -1366,7 +1366,9 @@ int lbs_execute_next_command(struct lbs_private *priv) | |||
| 1366 | "EXEC_NEXT_CMD: sending EXIT_PS\n"); | 1366 | "EXEC_NEXT_CMD: sending EXIT_PS\n"); |
| 1367 | } | 1367 | } |
| 1368 | } | 1368 | } |
| 1369 | spin_lock_irqsave(&priv->driver_lock, flags); | ||
| 1369 | list_del(&cmdnode->list); | 1370 | list_del(&cmdnode->list); |
| 1371 | spin_unlock_irqrestore(&priv->driver_lock, flags); | ||
| 1370 | lbs_deb_host("EXEC_NEXT_CMD: sending command 0x%04x\n", | 1372 | lbs_deb_host("EXEC_NEXT_CMD: sending command 0x%04x\n", |
| 1371 | le16_to_cpu(cmd->command)); | 1373 | le16_to_cpu(cmd->command)); |
| 1372 | lbs_submit_command(priv, cmdnode); | 1374 | lbs_submit_command(priv, cmdnode); |
diff --git a/drivers/net/zorro8390.c b/drivers/net/zorro8390.c index b78a38d9172a..8c7c522a056a 100644 --- a/drivers/net/zorro8390.c +++ b/drivers/net/zorro8390.c | |||
| @@ -126,7 +126,7 @@ static int __devinit zorro8390_init_one(struct zorro_dev *z, | |||
| 126 | 126 | ||
| 127 | board = z->resource.start; | 127 | board = z->resource.start; |
| 128 | ioaddr = board+cards[i].offset; | 128 | ioaddr = board+cards[i].offset; |
| 129 | dev = alloc_ei_netdev(); | 129 | dev = ____alloc_ei_netdev(0); |
| 130 | if (!dev) | 130 | if (!dev) |
| 131 | return -ENOMEM; | 131 | return -ENOMEM; |
| 132 | if (!request_mem_region(ioaddr, NE_IO_EXTENT*2, DRV_NAME)) { | 132 | if (!request_mem_region(ioaddr, NE_IO_EXTENT*2, DRV_NAME)) { |
| @@ -146,15 +146,15 @@ static int __devinit zorro8390_init_one(struct zorro_dev *z, | |||
| 146 | static const struct net_device_ops zorro8390_netdev_ops = { | 146 | static const struct net_device_ops zorro8390_netdev_ops = { |
| 147 | .ndo_open = zorro8390_open, | 147 | .ndo_open = zorro8390_open, |
| 148 | .ndo_stop = zorro8390_close, | 148 | .ndo_stop = zorro8390_close, |
| 149 | .ndo_start_xmit = ei_start_xmit, | 149 | .ndo_start_xmit = __ei_start_xmit, |
| 150 | .ndo_tx_timeout = ei_tx_timeout, | 150 | .ndo_tx_timeout = __ei_tx_timeout, |
| 151 | .ndo_get_stats = ei_get_stats, | 151 | .ndo_get_stats = __ei_get_stats, |
| 152 | .ndo_set_multicast_list = ei_set_multicast_list, | 152 | .ndo_set_multicast_list = __ei_set_multicast_list, |
| 153 | .ndo_validate_addr = eth_validate_addr, | 153 | .ndo_validate_addr = eth_validate_addr, |
| 154 | .ndo_set_mac_address = eth_mac_addr, | 154 | .ndo_set_mac_address = eth_mac_addr, |
| 155 | .ndo_change_mtu = eth_change_mtu, | 155 | .ndo_change_mtu = eth_change_mtu, |
| 156 | #ifdef CONFIG_NET_POLL_CONTROLLER | 156 | #ifdef CONFIG_NET_POLL_CONTROLLER |
| 157 | .ndo_poll_controller = ei_poll, | 157 | .ndo_poll_controller = __ei_poll, |
| 158 | #endif | 158 | #endif |
| 159 | }; | 159 | }; |
| 160 | 160 | ||
diff --git a/drivers/pci/setup-bus.c b/drivers/pci/setup-bus.c index ebf51ad1b714..a806cb321d2e 100644 --- a/drivers/pci/setup-bus.c +++ b/drivers/pci/setup-bus.c | |||
| @@ -579,7 +579,7 @@ static void pbus_size_io(struct pci_bus *bus, resource_size_t min_size, | |||
| 579 | } | 579 | } |
| 580 | size0 = calculate_iosize(size, min_size, size1, | 580 | size0 = calculate_iosize(size, min_size, size1, |
| 581 | resource_size(b_res), 4096); | 581 | resource_size(b_res), 4096); |
| 582 | size1 = !add_size? size0: | 582 | size1 = (!add_head || (add_head && !add_size)) ? size0 : |
| 583 | calculate_iosize(size, min_size+add_size, size1, | 583 | calculate_iosize(size, min_size+add_size, size1, |
| 584 | resource_size(b_res), 4096); | 584 | resource_size(b_res), 4096); |
| 585 | if (!size0 && !size1) { | 585 | if (!size0 && !size1) { |
| @@ -677,7 +677,7 @@ static int pbus_size_mem(struct pci_bus *bus, unsigned long mask, | |||
| 677 | align += aligns[order]; | 677 | align += aligns[order]; |
| 678 | } | 678 | } |
| 679 | size0 = calculate_memsize(size, min_size, 0, resource_size(b_res), min_align); | 679 | size0 = calculate_memsize(size, min_size, 0, resource_size(b_res), min_align); |
| 680 | size1 = !add_size ? size : | 680 | size1 = (!add_head || (add_head && !add_size)) ? size0 : |
| 681 | calculate_memsize(size, min_size+add_size, 0, | 681 | calculate_memsize(size, min_size+add_size, 0, |
| 682 | resource_size(b_res), min_align); | 682 | resource_size(b_res), min_align); |
| 683 | if (!size0 && !size1) { | 683 | if (!size0 && !size1) { |
diff --git a/drivers/rapidio/switches/idt_gen2.c b/drivers/rapidio/switches/idt_gen2.c index ac2701b22e71..043ee3136e40 100644 --- a/drivers/rapidio/switches/idt_gen2.c +++ b/drivers/rapidio/switches/idt_gen2.c | |||
| @@ -95,6 +95,9 @@ idtg2_route_add_entry(struct rio_mport *mport, u16 destid, u8 hopcount, | |||
| 95 | else | 95 | else |
| 96 | table++; | 96 | table++; |
| 97 | 97 | ||
| 98 | if (route_port == RIO_INVALID_ROUTE) | ||
| 99 | route_port = IDT_DEFAULT_ROUTE; | ||
| 100 | |||
| 98 | rio_mport_write_config_32(mport, destid, hopcount, | 101 | rio_mport_write_config_32(mport, destid, hopcount, |
| 99 | LOCAL_RTE_CONF_DESTID_SEL, table); | 102 | LOCAL_RTE_CONF_DESTID_SEL, table); |
| 100 | 103 | ||
| @@ -411,6 +414,12 @@ static int idtg2_switch_init(struct rio_dev *rdev, int do_enum) | |||
| 411 | rdev->rswitch->em_handle = idtg2_em_handler; | 414 | rdev->rswitch->em_handle = idtg2_em_handler; |
| 412 | rdev->rswitch->sw_sysfs = idtg2_sysfs; | 415 | rdev->rswitch->sw_sysfs = idtg2_sysfs; |
| 413 | 416 | ||
| 417 | if (do_enum) { | ||
| 418 | /* Ensure that default routing is disabled on startup */ | ||
| 419 | rio_write_config_32(rdev, | ||
| 420 | RIO_STD_RTE_DEFAULT_PORT, IDT_NO_ROUTE); | ||
| 421 | } | ||
| 422 | |||
| 414 | return 0; | 423 | return 0; |
| 415 | } | 424 | } |
| 416 | 425 | ||
diff --git a/drivers/rapidio/switches/idtcps.c b/drivers/rapidio/switches/idtcps.c index 3a971077e7bf..d06ee2d44b44 100644 --- a/drivers/rapidio/switches/idtcps.c +++ b/drivers/rapidio/switches/idtcps.c | |||
| @@ -26,6 +26,9 @@ idtcps_route_add_entry(struct rio_mport *mport, u16 destid, u8 hopcount, | |||
| 26 | { | 26 | { |
| 27 | u32 result; | 27 | u32 result; |
| 28 | 28 | ||
| 29 | if (route_port == RIO_INVALID_ROUTE) | ||
| 30 | route_port = CPS_DEFAULT_ROUTE; | ||
| 31 | |||
| 29 | if (table == RIO_GLOBAL_TABLE) { | 32 | if (table == RIO_GLOBAL_TABLE) { |
| 30 | rio_mport_write_config_32(mport, destid, hopcount, | 33 | rio_mport_write_config_32(mport, destid, hopcount, |
| 31 | RIO_STD_RTE_CONF_DESTID_SEL_CSR, route_destid); | 34 | RIO_STD_RTE_CONF_DESTID_SEL_CSR, route_destid); |
| @@ -130,6 +133,9 @@ static int idtcps_switch_init(struct rio_dev *rdev, int do_enum) | |||
| 130 | /* set TVAL = ~50us */ | 133 | /* set TVAL = ~50us */ |
| 131 | rio_write_config_32(rdev, | 134 | rio_write_config_32(rdev, |
| 132 | rdev->phys_efptr + RIO_PORT_LINKTO_CTL_CSR, 0x8e << 8); | 135 | rdev->phys_efptr + RIO_PORT_LINKTO_CTL_CSR, 0x8e << 8); |
| 136 | /* Ensure that default routing is disabled on startup */ | ||
| 137 | rio_write_config_32(rdev, | ||
| 138 | RIO_STD_RTE_DEFAULT_PORT, CPS_NO_ROUTE); | ||
| 133 | } | 139 | } |
| 134 | 140 | ||
| 135 | return 0; | 141 | return 0; |
diff --git a/drivers/rapidio/switches/tsi57x.c b/drivers/rapidio/switches/tsi57x.c index 1a62934bfebc..db8b8028988d 100644 --- a/drivers/rapidio/switches/tsi57x.c +++ b/drivers/rapidio/switches/tsi57x.c | |||
| @@ -303,6 +303,12 @@ static int tsi57x_switch_init(struct rio_dev *rdev, int do_enum) | |||
| 303 | rdev->rswitch->em_init = tsi57x_em_init; | 303 | rdev->rswitch->em_init = tsi57x_em_init; |
| 304 | rdev->rswitch->em_handle = tsi57x_em_handler; | 304 | rdev->rswitch->em_handle = tsi57x_em_handler; |
| 305 | 305 | ||
| 306 | if (do_enum) { | ||
| 307 | /* Ensure that default routing is disabled on startup */ | ||
| 308 | rio_write_config_32(rdev, RIO_STD_RTE_DEFAULT_PORT, | ||
| 309 | RIO_INVALID_ROUTE); | ||
| 310 | } | ||
| 311 | |||
| 306 | return 0; | 312 | return 0; |
| 307 | } | 313 | } |
| 308 | 314 | ||
diff --git a/drivers/rtc/rtc-davinci.c b/drivers/rtc/rtc-davinci.c index 8d46838dff8a..755e1fe914af 100644 --- a/drivers/rtc/rtc-davinci.c +++ b/drivers/rtc/rtc-davinci.c | |||
| @@ -524,6 +524,8 @@ static int __init davinci_rtc_probe(struct platform_device *pdev) | |||
| 524 | goto fail2; | 524 | goto fail2; |
| 525 | } | 525 | } |
| 526 | 526 | ||
| 527 | platform_set_drvdata(pdev, davinci_rtc); | ||
| 528 | |||
| 527 | davinci_rtc->rtc = rtc_device_register(pdev->name, &pdev->dev, | 529 | davinci_rtc->rtc = rtc_device_register(pdev->name, &pdev->dev, |
| 528 | &davinci_rtc_ops, THIS_MODULE); | 530 | &davinci_rtc_ops, THIS_MODULE); |
| 529 | if (IS_ERR(davinci_rtc->rtc)) { | 531 | if (IS_ERR(davinci_rtc->rtc)) { |
| @@ -553,8 +555,6 @@ static int __init davinci_rtc_probe(struct platform_device *pdev) | |||
| 553 | 555 | ||
| 554 | rtcss_write(davinci_rtc, PRTCSS_RTC_CCTRL_CAEN, PRTCSS_RTC_CCTRL); | 556 | rtcss_write(davinci_rtc, PRTCSS_RTC_CCTRL_CAEN, PRTCSS_RTC_CCTRL); |
| 555 | 557 | ||
| 556 | platform_set_drvdata(pdev, davinci_rtc); | ||
| 557 | |||
| 558 | device_init_wakeup(&pdev->dev, 0); | 558 | device_init_wakeup(&pdev->dev, 0); |
| 559 | 559 | ||
| 560 | return 0; | 560 | return 0; |
| @@ -562,6 +562,7 @@ static int __init davinci_rtc_probe(struct platform_device *pdev) | |||
| 562 | fail4: | 562 | fail4: |
| 563 | rtc_device_unregister(davinci_rtc->rtc); | 563 | rtc_device_unregister(davinci_rtc->rtc); |
| 564 | fail3: | 564 | fail3: |
| 565 | platform_set_drvdata(pdev, NULL); | ||
| 565 | iounmap(davinci_rtc->base); | 566 | iounmap(davinci_rtc->base); |
| 566 | fail2: | 567 | fail2: |
| 567 | release_mem_region(davinci_rtc->pbase, davinci_rtc->base_size); | 568 | release_mem_region(davinci_rtc->pbase, davinci_rtc->base_size); |
diff --git a/drivers/rtc/rtc-ds1286.c b/drivers/rtc/rtc-ds1286.c index 60ce69600828..47e681df31e2 100644 --- a/drivers/rtc/rtc-ds1286.c +++ b/drivers/rtc/rtc-ds1286.c | |||
| @@ -355,6 +355,7 @@ static int __devinit ds1286_probe(struct platform_device *pdev) | |||
| 355 | goto out; | 355 | goto out; |
| 356 | } | 356 | } |
| 357 | spin_lock_init(&priv->lock); | 357 | spin_lock_init(&priv->lock); |
| 358 | platform_set_drvdata(pdev, priv); | ||
| 358 | rtc = rtc_device_register("ds1286", &pdev->dev, | 359 | rtc = rtc_device_register("ds1286", &pdev->dev, |
| 359 | &ds1286_ops, THIS_MODULE); | 360 | &ds1286_ops, THIS_MODULE); |
| 360 | if (IS_ERR(rtc)) { | 361 | if (IS_ERR(rtc)) { |
| @@ -362,7 +363,6 @@ static int __devinit ds1286_probe(struct platform_device *pdev) | |||
| 362 | goto out; | 363 | goto out; |
| 363 | } | 364 | } |
| 364 | priv->rtc = rtc; | 365 | priv->rtc = rtc; |
| 365 | platform_set_drvdata(pdev, priv); | ||
| 366 | return 0; | 366 | return 0; |
| 367 | 367 | ||
| 368 | out: | 368 | out: |
diff --git a/drivers/rtc/rtc-ep93xx.c b/drivers/rtc/rtc-ep93xx.c index 11ae64dcbf3c..335551d333b2 100644 --- a/drivers/rtc/rtc-ep93xx.c +++ b/drivers/rtc/rtc-ep93xx.c | |||
| @@ -151,6 +151,7 @@ static int __init ep93xx_rtc_probe(struct platform_device *pdev) | |||
| 151 | return -ENXIO; | 151 | return -ENXIO; |
| 152 | 152 | ||
| 153 | pdev->dev.platform_data = ep93xx_rtc; | 153 | pdev->dev.platform_data = ep93xx_rtc; |
| 154 | platform_set_drvdata(pdev, rtc); | ||
| 154 | 155 | ||
| 155 | rtc = rtc_device_register(pdev->name, | 156 | rtc = rtc_device_register(pdev->name, |
| 156 | &pdev->dev, &ep93xx_rtc_ops, THIS_MODULE); | 157 | &pdev->dev, &ep93xx_rtc_ops, THIS_MODULE); |
| @@ -159,8 +160,6 @@ static int __init ep93xx_rtc_probe(struct platform_device *pdev) | |||
| 159 | goto exit; | 160 | goto exit; |
| 160 | } | 161 | } |
| 161 | 162 | ||
| 162 | platform_set_drvdata(pdev, rtc); | ||
| 163 | |||
| 164 | err = sysfs_create_group(&pdev->dev.kobj, &ep93xx_rtc_sysfs_files); | 163 | err = sysfs_create_group(&pdev->dev.kobj, &ep93xx_rtc_sysfs_files); |
| 165 | if (err) | 164 | if (err) |
| 166 | goto fail; | 165 | goto fail; |
| @@ -168,9 +167,9 @@ static int __init ep93xx_rtc_probe(struct platform_device *pdev) | |||
| 168 | return 0; | 167 | return 0; |
| 169 | 168 | ||
| 170 | fail: | 169 | fail: |
| 171 | platform_set_drvdata(pdev, NULL); | ||
| 172 | rtc_device_unregister(rtc); | 170 | rtc_device_unregister(rtc); |
| 173 | exit: | 171 | exit: |
| 172 | platform_set_drvdata(pdev, NULL); | ||
| 174 | pdev->dev.platform_data = NULL; | 173 | pdev->dev.platform_data = NULL; |
| 175 | return err; | 174 | return err; |
| 176 | } | 175 | } |
diff --git a/drivers/rtc/rtc-m41t80.c b/drivers/rtc/rtc-m41t80.c index 69fe664a2228..eda128fc1d38 100644 --- a/drivers/rtc/rtc-m41t80.c +++ b/drivers/rtc/rtc-m41t80.c | |||
| @@ -783,6 +783,9 @@ static int m41t80_probe(struct i2c_client *client, | |||
| 783 | goto exit; | 783 | goto exit; |
| 784 | } | 784 | } |
| 785 | 785 | ||
| 786 | clientdata->features = id->driver_data; | ||
| 787 | i2c_set_clientdata(client, clientdata); | ||
| 788 | |||
| 786 | rtc = rtc_device_register(client->name, &client->dev, | 789 | rtc = rtc_device_register(client->name, &client->dev, |
| 787 | &m41t80_rtc_ops, THIS_MODULE); | 790 | &m41t80_rtc_ops, THIS_MODULE); |
| 788 | if (IS_ERR(rtc)) { | 791 | if (IS_ERR(rtc)) { |
| @@ -792,8 +795,6 @@ static int m41t80_probe(struct i2c_client *client, | |||
| 792 | } | 795 | } |
| 793 | 796 | ||
| 794 | clientdata->rtc = rtc; | 797 | clientdata->rtc = rtc; |
| 795 | clientdata->features = id->driver_data; | ||
| 796 | i2c_set_clientdata(client, clientdata); | ||
| 797 | 798 | ||
| 798 | /* Make sure HT (Halt Update) bit is cleared */ | 799 | /* Make sure HT (Halt Update) bit is cleared */ |
| 799 | rc = i2c_smbus_read_byte_data(client, M41T80_REG_ALARM_HOUR); | 800 | rc = i2c_smbus_read_byte_data(client, M41T80_REG_ALARM_HOUR); |
diff --git a/drivers/rtc/rtc-max8925.c b/drivers/rtc/rtc-max8925.c index 20494b5edc3c..3bc046f427e0 100644 --- a/drivers/rtc/rtc-max8925.c +++ b/drivers/rtc/rtc-max8925.c | |||
| @@ -258,6 +258,8 @@ static int __devinit max8925_rtc_probe(struct platform_device *pdev) | |||
| 258 | } | 258 | } |
| 259 | 259 | ||
| 260 | dev_set_drvdata(&pdev->dev, info); | 260 | dev_set_drvdata(&pdev->dev, info); |
| 261 | /* XXX - isn't this redundant? */ | ||
| 262 | platform_set_drvdata(pdev, info); | ||
| 261 | 263 | ||
| 262 | info->rtc_dev = rtc_device_register("max8925-rtc", &pdev->dev, | 264 | info->rtc_dev = rtc_device_register("max8925-rtc", &pdev->dev, |
| 263 | &max8925_rtc_ops, THIS_MODULE); | 265 | &max8925_rtc_ops, THIS_MODULE); |
| @@ -267,10 +269,9 @@ static int __devinit max8925_rtc_probe(struct platform_device *pdev) | |||
| 267 | goto out_rtc; | 269 | goto out_rtc; |
| 268 | } | 270 | } |
| 269 | 271 | ||
| 270 | platform_set_drvdata(pdev, info); | ||
| 271 | |||
| 272 | return 0; | 272 | return 0; |
| 273 | out_rtc: | 273 | out_rtc: |
| 274 | platform_set_drvdata(pdev, NULL); | ||
| 274 | free_irq(chip->irq_base + MAX8925_IRQ_RTC_ALARM0, info); | 275 | free_irq(chip->irq_base + MAX8925_IRQ_RTC_ALARM0, info); |
| 275 | out_irq: | 276 | out_irq: |
| 276 | kfree(info); | 277 | kfree(info); |
diff --git a/drivers/rtc/rtc-max8998.c b/drivers/rtc/rtc-max8998.c index 3f7bc6b9fefa..2e48aa604273 100644 --- a/drivers/rtc/rtc-max8998.c +++ b/drivers/rtc/rtc-max8998.c | |||
| @@ -265,6 +265,8 @@ static int __devinit max8998_rtc_probe(struct platform_device *pdev) | |||
| 265 | info->rtc = max8998->rtc; | 265 | info->rtc = max8998->rtc; |
| 266 | info->irq = max8998->irq_base + MAX8998_IRQ_ALARM0; | 266 | info->irq = max8998->irq_base + MAX8998_IRQ_ALARM0; |
| 267 | 267 | ||
| 268 | platform_set_drvdata(pdev, info); | ||
| 269 | |||
| 268 | info->rtc_dev = rtc_device_register("max8998-rtc", &pdev->dev, | 270 | info->rtc_dev = rtc_device_register("max8998-rtc", &pdev->dev, |
| 269 | &max8998_rtc_ops, THIS_MODULE); | 271 | &max8998_rtc_ops, THIS_MODULE); |
| 270 | 272 | ||
| @@ -274,8 +276,6 @@ static int __devinit max8998_rtc_probe(struct platform_device *pdev) | |||
| 274 | goto out_rtc; | 276 | goto out_rtc; |
| 275 | } | 277 | } |
| 276 | 278 | ||
| 277 | platform_set_drvdata(pdev, info); | ||
| 278 | |||
| 279 | ret = request_threaded_irq(info->irq, NULL, max8998_rtc_alarm_irq, 0, | 279 | ret = request_threaded_irq(info->irq, NULL, max8998_rtc_alarm_irq, 0, |
| 280 | "rtc-alarm0", info); | 280 | "rtc-alarm0", info); |
| 281 | 281 | ||
| @@ -293,6 +293,7 @@ static int __devinit max8998_rtc_probe(struct platform_device *pdev) | |||
| 293 | return 0; | 293 | return 0; |
| 294 | 294 | ||
| 295 | out_rtc: | 295 | out_rtc: |
| 296 | platform_set_drvdata(pdev, NULL); | ||
| 296 | kfree(info); | 297 | kfree(info); |
| 297 | return ret; | 298 | return ret; |
| 298 | } | 299 | } |
diff --git a/drivers/rtc/rtc-mc13xxx.c b/drivers/rtc/rtc-mc13xxx.c index c5ac03793e79..a1a278bc340d 100644 --- a/drivers/rtc/rtc-mc13xxx.c +++ b/drivers/rtc/rtc-mc13xxx.c | |||
| @@ -349,11 +349,15 @@ static int __devinit mc13xxx_rtc_probe(struct platform_device *pdev) | |||
| 349 | if (ret) | 349 | if (ret) |
| 350 | goto err_alarm_irq_request; | 350 | goto err_alarm_irq_request; |
| 351 | 351 | ||
| 352 | mc13xxx_unlock(mc13xxx); | ||
| 353 | |||
| 352 | priv->rtc = rtc_device_register(pdev->name, | 354 | priv->rtc = rtc_device_register(pdev->name, |
| 353 | &pdev->dev, &mc13xxx_rtc_ops, THIS_MODULE); | 355 | &pdev->dev, &mc13xxx_rtc_ops, THIS_MODULE); |
| 354 | if (IS_ERR(priv->rtc)) { | 356 | if (IS_ERR(priv->rtc)) { |
| 355 | ret = PTR_ERR(priv->rtc); | 357 | ret = PTR_ERR(priv->rtc); |
| 356 | 358 | ||
| 359 | mc13xxx_lock(mc13xxx); | ||
| 360 | |||
| 357 | mc13xxx_irq_free(mc13xxx, MC13XXX_IRQ_TODA, priv); | 361 | mc13xxx_irq_free(mc13xxx, MC13XXX_IRQ_TODA, priv); |
| 358 | err_alarm_irq_request: | 362 | err_alarm_irq_request: |
| 359 | 363 | ||
| @@ -365,12 +369,12 @@ err_reset_irq_status: | |||
| 365 | mc13xxx_irq_free(mc13xxx, MC13XXX_IRQ_RTCRST, priv); | 369 | mc13xxx_irq_free(mc13xxx, MC13XXX_IRQ_RTCRST, priv); |
| 366 | err_reset_irq_request: | 370 | err_reset_irq_request: |
| 367 | 371 | ||
| 372 | mc13xxx_unlock(mc13xxx); | ||
| 373 | |||
| 368 | platform_set_drvdata(pdev, NULL); | 374 | platform_set_drvdata(pdev, NULL); |
| 369 | kfree(priv); | 375 | kfree(priv); |
| 370 | } | 376 | } |
| 371 | 377 | ||
| 372 | mc13xxx_unlock(mc13xxx); | ||
| 373 | |||
| 374 | return ret; | 378 | return ret; |
| 375 | } | 379 | } |
| 376 | 380 | ||
diff --git a/drivers/rtc/rtc-msm6242.c b/drivers/rtc/rtc-msm6242.c index 67820626e18f..fcb113c11122 100644 --- a/drivers/rtc/rtc-msm6242.c +++ b/drivers/rtc/rtc-msm6242.c | |||
| @@ -214,6 +214,7 @@ static int __init msm6242_rtc_probe(struct platform_device *dev) | |||
| 214 | error = -ENOMEM; | 214 | error = -ENOMEM; |
| 215 | goto out_free_priv; | 215 | goto out_free_priv; |
| 216 | } | 216 | } |
| 217 | platform_set_drvdata(dev, priv); | ||
| 217 | 218 | ||
| 218 | rtc = rtc_device_register("rtc-msm6242", &dev->dev, &msm6242_rtc_ops, | 219 | rtc = rtc_device_register("rtc-msm6242", &dev->dev, &msm6242_rtc_ops, |
| 219 | THIS_MODULE); | 220 | THIS_MODULE); |
| @@ -223,10 +224,10 @@ static int __init msm6242_rtc_probe(struct platform_device *dev) | |||
| 223 | } | 224 | } |
| 224 | 225 | ||
| 225 | priv->rtc = rtc; | 226 | priv->rtc = rtc; |
| 226 | platform_set_drvdata(dev, priv); | ||
| 227 | return 0; | 227 | return 0; |
| 228 | 228 | ||
| 229 | out_unmap: | 229 | out_unmap: |
| 230 | platform_set_drvdata(dev, NULL); | ||
| 230 | iounmap(priv->regs); | 231 | iounmap(priv->regs); |
| 231 | out_free_priv: | 232 | out_free_priv: |
| 232 | kfree(priv); | 233 | kfree(priv); |
diff --git a/drivers/rtc/rtc-mxc.c b/drivers/rtc/rtc-mxc.c index 826ab64a8fa9..d814417bee8c 100644 --- a/drivers/rtc/rtc-mxc.c +++ b/drivers/rtc/rtc-mxc.c | |||
| @@ -418,14 +418,6 @@ static int __init mxc_rtc_probe(struct platform_device *pdev) | |||
| 418 | goto exit_put_clk; | 418 | goto exit_put_clk; |
| 419 | } | 419 | } |
| 420 | 420 | ||
| 421 | rtc = rtc_device_register(pdev->name, &pdev->dev, &mxc_rtc_ops, | ||
| 422 | THIS_MODULE); | ||
| 423 | if (IS_ERR(rtc)) { | ||
| 424 | ret = PTR_ERR(rtc); | ||
| 425 | goto exit_put_clk; | ||
| 426 | } | ||
| 427 | |||
| 428 | pdata->rtc = rtc; | ||
| 429 | platform_set_drvdata(pdev, pdata); | 421 | platform_set_drvdata(pdev, pdata); |
| 430 | 422 | ||
| 431 | /* Configure and enable the RTC */ | 423 | /* Configure and enable the RTC */ |
| @@ -438,8 +430,19 @@ static int __init mxc_rtc_probe(struct platform_device *pdev) | |||
| 438 | pdata->irq = -1; | 430 | pdata->irq = -1; |
| 439 | } | 431 | } |
| 440 | 432 | ||
| 433 | rtc = rtc_device_register(pdev->name, &pdev->dev, &mxc_rtc_ops, | ||
| 434 | THIS_MODULE); | ||
| 435 | if (IS_ERR(rtc)) { | ||
| 436 | ret = PTR_ERR(rtc); | ||
| 437 | goto exit_clr_drvdata; | ||
| 438 | } | ||
| 439 | |||
| 440 | pdata->rtc = rtc; | ||
| 441 | |||
| 441 | return 0; | 442 | return 0; |
| 442 | 443 | ||
| 444 | exit_clr_drvdata: | ||
| 445 | platform_set_drvdata(pdev, NULL); | ||
| 443 | exit_put_clk: | 446 | exit_put_clk: |
| 444 | clk_disable(pdata->clk); | 447 | clk_disable(pdata->clk); |
| 445 | clk_put(pdata->clk); | 448 | clk_put(pdata->clk); |
diff --git a/drivers/rtc/rtc-pcap.c b/drivers/rtc/rtc-pcap.c index a633abc42896..cd4f198cc2ef 100644 --- a/drivers/rtc/rtc-pcap.c +++ b/drivers/rtc/rtc-pcap.c | |||
| @@ -151,6 +151,8 @@ static int __devinit pcap_rtc_probe(struct platform_device *pdev) | |||
| 151 | 151 | ||
| 152 | pcap_rtc->pcap = dev_get_drvdata(pdev->dev.parent); | 152 | pcap_rtc->pcap = dev_get_drvdata(pdev->dev.parent); |
| 153 | 153 | ||
| 154 | platform_set_drvdata(pdev, pcap_rtc); | ||
| 155 | |||
| 154 | pcap_rtc->rtc = rtc_device_register("pcap", &pdev->dev, | 156 | pcap_rtc->rtc = rtc_device_register("pcap", &pdev->dev, |
| 155 | &pcap_rtc_ops, THIS_MODULE); | 157 | &pcap_rtc_ops, THIS_MODULE); |
| 156 | if (IS_ERR(pcap_rtc->rtc)) { | 158 | if (IS_ERR(pcap_rtc->rtc)) { |
| @@ -158,7 +160,6 @@ static int __devinit pcap_rtc_probe(struct platform_device *pdev) | |||
| 158 | goto fail_rtc; | 160 | goto fail_rtc; |
| 159 | } | 161 | } |
| 160 | 162 | ||
| 161 | platform_set_drvdata(pdev, pcap_rtc); | ||
| 162 | 163 | ||
| 163 | timer_irq = pcap_to_irq(pcap_rtc->pcap, PCAP_IRQ_1HZ); | 164 | timer_irq = pcap_to_irq(pcap_rtc->pcap, PCAP_IRQ_1HZ); |
| 164 | alarm_irq = pcap_to_irq(pcap_rtc->pcap, PCAP_IRQ_TODA); | 165 | alarm_irq = pcap_to_irq(pcap_rtc->pcap, PCAP_IRQ_TODA); |
| @@ -177,6 +178,7 @@ fail_alarm: | |||
| 177 | fail_timer: | 178 | fail_timer: |
| 178 | rtc_device_unregister(pcap_rtc->rtc); | 179 | rtc_device_unregister(pcap_rtc->rtc); |
| 179 | fail_rtc: | 180 | fail_rtc: |
| 181 | platform_set_drvdata(pdev, NULL); | ||
| 180 | kfree(pcap_rtc); | 182 | kfree(pcap_rtc); |
| 181 | return err; | 183 | return err; |
| 182 | } | 184 | } |
diff --git a/drivers/rtc/rtc-rp5c01.c b/drivers/rtc/rtc-rp5c01.c index 694da39b6dd2..359da6d020b9 100644 --- a/drivers/rtc/rtc-rp5c01.c +++ b/drivers/rtc/rtc-rp5c01.c | |||
| @@ -249,15 +249,15 @@ static int __init rp5c01_rtc_probe(struct platform_device *dev) | |||
| 249 | 249 | ||
| 250 | spin_lock_init(&priv->lock); | 250 | spin_lock_init(&priv->lock); |
| 251 | 251 | ||
| 252 | platform_set_drvdata(dev, priv); | ||
| 253 | |||
| 252 | rtc = rtc_device_register("rtc-rp5c01", &dev->dev, &rp5c01_rtc_ops, | 254 | rtc = rtc_device_register("rtc-rp5c01", &dev->dev, &rp5c01_rtc_ops, |
| 253 | THIS_MODULE); | 255 | THIS_MODULE); |
| 254 | if (IS_ERR(rtc)) { | 256 | if (IS_ERR(rtc)) { |
| 255 | error = PTR_ERR(rtc); | 257 | error = PTR_ERR(rtc); |
| 256 | goto out_unmap; | 258 | goto out_unmap; |
| 257 | } | 259 | } |
| 258 | |||
| 259 | priv->rtc = rtc; | 260 | priv->rtc = rtc; |
| 260 | platform_set_drvdata(dev, priv); | ||
| 261 | 261 | ||
| 262 | error = sysfs_create_bin_file(&dev->dev.kobj, &priv->nvram_attr); | 262 | error = sysfs_create_bin_file(&dev->dev.kobj, &priv->nvram_attr); |
| 263 | if (error) | 263 | if (error) |
| @@ -268,6 +268,7 @@ static int __init rp5c01_rtc_probe(struct platform_device *dev) | |||
| 268 | out_unregister: | 268 | out_unregister: |
| 269 | rtc_device_unregister(rtc); | 269 | rtc_device_unregister(rtc); |
| 270 | out_unmap: | 270 | out_unmap: |
| 271 | platform_set_drvdata(dev, NULL); | ||
| 271 | iounmap(priv->regs); | 272 | iounmap(priv->regs); |
| 272 | out_free_priv: | 273 | out_free_priv: |
| 273 | kfree(priv); | 274 | kfree(priv); |
diff --git a/drivers/rtc/rtc-s3c.c b/drivers/rtc/rtc-s3c.c index b3466c491cd3..16512ecae31a 100644 --- a/drivers/rtc/rtc-s3c.c +++ b/drivers/rtc/rtc-s3c.c | |||
| @@ -46,6 +46,7 @@ static struct clk *rtc_clk; | |||
| 46 | static void __iomem *s3c_rtc_base; | 46 | static void __iomem *s3c_rtc_base; |
| 47 | static int s3c_rtc_alarmno = NO_IRQ; | 47 | static int s3c_rtc_alarmno = NO_IRQ; |
| 48 | static int s3c_rtc_tickno = NO_IRQ; | 48 | static int s3c_rtc_tickno = NO_IRQ; |
| 49 | static bool wake_en; | ||
| 49 | static enum s3c_cpu_type s3c_rtc_cpu_type; | 50 | static enum s3c_cpu_type s3c_rtc_cpu_type; |
| 50 | 51 | ||
| 51 | static DEFINE_SPINLOCK(s3c_rtc_pie_lock); | 52 | static DEFINE_SPINLOCK(s3c_rtc_pie_lock); |
| @@ -562,8 +563,12 @@ static int s3c_rtc_suspend(struct platform_device *pdev, pm_message_t state) | |||
| 562 | } | 563 | } |
| 563 | s3c_rtc_enable(pdev, 0); | 564 | s3c_rtc_enable(pdev, 0); |
| 564 | 565 | ||
| 565 | if (device_may_wakeup(&pdev->dev)) | 566 | if (device_may_wakeup(&pdev->dev) && !wake_en) { |
| 566 | enable_irq_wake(s3c_rtc_alarmno); | 567 | if (enable_irq_wake(s3c_rtc_alarmno) == 0) |
| 568 | wake_en = true; | ||
| 569 | else | ||
| 570 | dev_err(&pdev->dev, "enable_irq_wake failed\n"); | ||
| 571 | } | ||
| 567 | 572 | ||
| 568 | return 0; | 573 | return 0; |
| 569 | } | 574 | } |
| @@ -579,8 +584,10 @@ static int s3c_rtc_resume(struct platform_device *pdev) | |||
| 579 | writew(tmp | ticnt_en_save, s3c_rtc_base + S3C2410_RTCCON); | 584 | writew(tmp | ticnt_en_save, s3c_rtc_base + S3C2410_RTCCON); |
| 580 | } | 585 | } |
| 581 | 586 | ||
| 582 | if (device_may_wakeup(&pdev->dev)) | 587 | if (device_may_wakeup(&pdev->dev) && wake_en) { |
| 583 | disable_irq_wake(s3c_rtc_alarmno); | 588 | disable_irq_wake(s3c_rtc_alarmno); |
| 589 | wake_en = false; | ||
| 590 | } | ||
| 584 | 591 | ||
| 585 | return 0; | 592 | return 0; |
| 586 | } | 593 | } |
diff --git a/drivers/s390/block/dasd.c b/drivers/s390/block/dasd.c index 475e603fc584..86b6f1cc1b10 100644 --- a/drivers/s390/block/dasd.c +++ b/drivers/s390/block/dasd.c | |||
| @@ -1742,11 +1742,20 @@ int dasd_sleep_on_interruptible(struct dasd_ccw_req *cqr) | |||
| 1742 | static inline int _dasd_term_running_cqr(struct dasd_device *device) | 1742 | static inline int _dasd_term_running_cqr(struct dasd_device *device) |
| 1743 | { | 1743 | { |
| 1744 | struct dasd_ccw_req *cqr; | 1744 | struct dasd_ccw_req *cqr; |
| 1745 | int rc; | ||
| 1745 | 1746 | ||
| 1746 | if (list_empty(&device->ccw_queue)) | 1747 | if (list_empty(&device->ccw_queue)) |
| 1747 | return 0; | 1748 | return 0; |
| 1748 | cqr = list_entry(device->ccw_queue.next, struct dasd_ccw_req, devlist); | 1749 | cqr = list_entry(device->ccw_queue.next, struct dasd_ccw_req, devlist); |
| 1749 | return device->discipline->term_IO(cqr); | 1750 | rc = device->discipline->term_IO(cqr); |
| 1751 | if (!rc) | ||
| 1752 | /* | ||
| 1753 | * CQR terminated because a more important request is pending. | ||
| 1754 | * Undo decreasing of retry counter because this is | ||
| 1755 | * not an error case. | ||
| 1756 | */ | ||
| 1757 | cqr->retries++; | ||
| 1758 | return rc; | ||
| 1750 | } | 1759 | } |
| 1751 | 1760 | ||
| 1752 | int dasd_sleep_on_immediatly(struct dasd_ccw_req *cqr) | 1761 | int dasd_sleep_on_immediatly(struct dasd_ccw_req *cqr) |
diff --git a/drivers/s390/char/sclp_cmd.c b/drivers/s390/char/sclp_cmd.c index 4b60ede07f0e..be55fb2b1b1c 100644 --- a/drivers/s390/char/sclp_cmd.c +++ b/drivers/s390/char/sclp_cmd.c | |||
| @@ -518,6 +518,8 @@ static void __init insert_increment(u16 rn, int standby, int assigned) | |||
| 518 | return; | 518 | return; |
| 519 | new_incr->rn = rn; | 519 | new_incr->rn = rn; |
| 520 | new_incr->standby = standby; | 520 | new_incr->standby = standby; |
| 521 | if (!standby) | ||
| 522 | new_incr->usecount = 1; | ||
| 521 | last_rn = 0; | 523 | last_rn = 0; |
| 522 | prev = &sclp_mem_list; | 524 | prev = &sclp_mem_list; |
| 523 | list_for_each_entry(incr, &sclp_mem_list, list) { | 525 | list_for_each_entry(incr, &sclp_mem_list, list) { |
diff --git a/drivers/video/acornfb.c b/drivers/video/acornfb.c index 82acb8dc4aa1..6183a57eb69d 100644 --- a/drivers/video/acornfb.c +++ b/drivers/video/acornfb.c | |||
| @@ -66,7 +66,7 @@ | |||
| 66 | * have. Allow 1% either way on the nominal for TVs. | 66 | * have. Allow 1% either way on the nominal for TVs. |
| 67 | */ | 67 | */ |
| 68 | #define NR_MONTYPES 6 | 68 | #define NR_MONTYPES 6 |
| 69 | static struct fb_monspecs monspecs[NR_MONTYPES] __initdata = { | 69 | static struct fb_monspecs monspecs[NR_MONTYPES] __devinitdata = { |
| 70 | { /* TV */ | 70 | { /* TV */ |
| 71 | .hfmin = 15469, | 71 | .hfmin = 15469, |
| 72 | .hfmax = 15781, | 72 | .hfmax = 15781, |
| @@ -873,7 +873,7 @@ static struct fb_ops acornfb_ops = { | |||
| 873 | /* | 873 | /* |
| 874 | * Everything after here is initialisation!!! | 874 | * Everything after here is initialisation!!! |
| 875 | */ | 875 | */ |
| 876 | static struct fb_videomode modedb[] __initdata = { | 876 | static struct fb_videomode modedb[] __devinitdata = { |
| 877 | { /* 320x256 @ 50Hz */ | 877 | { /* 320x256 @ 50Hz */ |
| 878 | NULL, 50, 320, 256, 125000, 92, 62, 35, 19, 38, 2, | 878 | NULL, 50, 320, 256, 125000, 92, 62, 35, 19, 38, 2, |
| 879 | FB_SYNC_COMP_HIGH_ACT, | 879 | FB_SYNC_COMP_HIGH_ACT, |
| @@ -925,8 +925,7 @@ static struct fb_videomode modedb[] __initdata = { | |||
| 925 | } | 925 | } |
| 926 | }; | 926 | }; |
| 927 | 927 | ||
| 928 | static struct fb_videomode __initdata | 928 | static struct fb_videomode acornfb_default_mode __devinitdata = { |
| 929 | acornfb_default_mode = { | ||
| 930 | .name = NULL, | 929 | .name = NULL, |
| 931 | .refresh = 60, | 930 | .refresh = 60, |
| 932 | .xres = 640, | 931 | .xres = 640, |
| @@ -942,7 +941,7 @@ acornfb_default_mode = { | |||
| 942 | .vmode = FB_VMODE_NONINTERLACED | 941 | .vmode = FB_VMODE_NONINTERLACED |
| 943 | }; | 942 | }; |
| 944 | 943 | ||
| 945 | static void __init acornfb_init_fbinfo(void) | 944 | static void __devinit acornfb_init_fbinfo(void) |
| 946 | { | 945 | { |
| 947 | static int first = 1; | 946 | static int first = 1; |
| 948 | 947 | ||
| @@ -1018,8 +1017,7 @@ static void __init acornfb_init_fbinfo(void) | |||
| 1018 | * size can optionally be followed by 'M' or 'K' for | 1017 | * size can optionally be followed by 'M' or 'K' for |
| 1019 | * MB or KB respectively. | 1018 | * MB or KB respectively. |
| 1020 | */ | 1019 | */ |
| 1021 | static void __init | 1020 | static void __devinit acornfb_parse_mon(char *opt) |
| 1022 | acornfb_parse_mon(char *opt) | ||
| 1023 | { | 1021 | { |
| 1024 | char *p = opt; | 1022 | char *p = opt; |
| 1025 | 1023 | ||
| @@ -1066,8 +1064,7 @@ bad: | |||
| 1066 | current_par.montype = -1; | 1064 | current_par.montype = -1; |
| 1067 | } | 1065 | } |
| 1068 | 1066 | ||
| 1069 | static void __init | 1067 | static void __devinit acornfb_parse_montype(char *opt) |
| 1070 | acornfb_parse_montype(char *opt) | ||
| 1071 | { | 1068 | { |
| 1072 | current_par.montype = -2; | 1069 | current_par.montype = -2; |
| 1073 | 1070 | ||
| @@ -1108,8 +1105,7 @@ acornfb_parse_montype(char *opt) | |||
| 1108 | } | 1105 | } |
| 1109 | } | 1106 | } |
| 1110 | 1107 | ||
| 1111 | static void __init | 1108 | static void __devinit acornfb_parse_dram(char *opt) |
| 1112 | acornfb_parse_dram(char *opt) | ||
| 1113 | { | 1109 | { |
| 1114 | unsigned int size; | 1110 | unsigned int size; |
| 1115 | 1111 | ||
| @@ -1134,15 +1130,14 @@ acornfb_parse_dram(char *opt) | |||
| 1134 | static struct options { | 1130 | static struct options { |
| 1135 | char *name; | 1131 | char *name; |
| 1136 | void (*parse)(char *opt); | 1132 | void (*parse)(char *opt); |
| 1137 | } opt_table[] __initdata = { | 1133 | } opt_table[] __devinitdata = { |
| 1138 | { "mon", acornfb_parse_mon }, | 1134 | { "mon", acornfb_parse_mon }, |
| 1139 | { "montype", acornfb_parse_montype }, | 1135 | { "montype", acornfb_parse_montype }, |
| 1140 | { "dram", acornfb_parse_dram }, | 1136 | { "dram", acornfb_parse_dram }, |
| 1141 | { NULL, NULL } | 1137 | { NULL, NULL } |
| 1142 | }; | 1138 | }; |
| 1143 | 1139 | ||
| 1144 | int __init | 1140 | static int __devinit acornfb_setup(char *options) |
| 1145 | acornfb_setup(char *options) | ||
| 1146 | { | 1141 | { |
| 1147 | struct options *optp; | 1142 | struct options *optp; |
| 1148 | char *opt; | 1143 | char *opt; |
| @@ -1179,8 +1174,7 @@ acornfb_setup(char *options) | |||
| 1179 | * Detect type of monitor connected | 1174 | * Detect type of monitor connected |
| 1180 | * For now, we just assume SVGA | 1175 | * For now, we just assume SVGA |
| 1181 | */ | 1176 | */ |
| 1182 | static int __init | 1177 | static int __devinit acornfb_detect_monitortype(void) |
| 1183 | acornfb_detect_monitortype(void) | ||
| 1184 | { | 1178 | { |
| 1185 | return 4; | 1179 | return 4; |
| 1186 | } | 1180 | } |
diff --git a/drivers/video/fbmem.c b/drivers/video/fbmem.c index e0c2284924b6..5aac00eb1830 100644 --- a/drivers/video/fbmem.c +++ b/drivers/video/fbmem.c | |||
| @@ -42,9 +42,34 @@ | |||
| 42 | 42 | ||
| 43 | #define FBPIXMAPSIZE (1024 * 8) | 43 | #define FBPIXMAPSIZE (1024 * 8) |
| 44 | 44 | ||
| 45 | static DEFINE_MUTEX(registration_lock); | ||
| 45 | struct fb_info *registered_fb[FB_MAX] __read_mostly; | 46 | struct fb_info *registered_fb[FB_MAX] __read_mostly; |
| 46 | int num_registered_fb __read_mostly; | 47 | int num_registered_fb __read_mostly; |
| 47 | 48 | ||
| 49 | static struct fb_info *get_fb_info(unsigned int idx) | ||
| 50 | { | ||
| 51 | struct fb_info *fb_info; | ||
| 52 | |||
| 53 | if (idx >= FB_MAX) | ||
| 54 | return ERR_PTR(-ENODEV); | ||
| 55 | |||
| 56 | mutex_lock(®istration_lock); | ||
| 57 | fb_info = registered_fb[idx]; | ||
| 58 | if (fb_info) | ||
| 59 | atomic_inc(&fb_info->count); | ||
| 60 | mutex_unlock(®istration_lock); | ||
| 61 | |||
| 62 | return fb_info; | ||
| 63 | } | ||
| 64 | |||
| 65 | static void put_fb_info(struct fb_info *fb_info) | ||
| 66 | { | ||
| 67 | if (!atomic_dec_and_test(&fb_info->count)) | ||
| 68 | return; | ||
| 69 | if (fb_info->fbops->fb_destroy) | ||
| 70 | fb_info->fbops->fb_destroy(fb_info); | ||
| 71 | } | ||
| 72 | |||
| 48 | int lock_fb_info(struct fb_info *info) | 73 | int lock_fb_info(struct fb_info *info) |
| 49 | { | 74 | { |
| 50 | mutex_lock(&info->lock); | 75 | mutex_lock(&info->lock); |
| @@ -647,6 +672,7 @@ int fb_show_logo(struct fb_info *info, int rotate) { return 0; } | |||
| 647 | 672 | ||
| 648 | static void *fb_seq_start(struct seq_file *m, loff_t *pos) | 673 | static void *fb_seq_start(struct seq_file *m, loff_t *pos) |
| 649 | { | 674 | { |
| 675 | mutex_lock(®istration_lock); | ||
| 650 | return (*pos < FB_MAX) ? pos : NULL; | 676 | return (*pos < FB_MAX) ? pos : NULL; |
| 651 | } | 677 | } |
| 652 | 678 | ||
| @@ -658,6 +684,7 @@ static void *fb_seq_next(struct seq_file *m, void *v, loff_t *pos) | |||
| 658 | 684 | ||
| 659 | static void fb_seq_stop(struct seq_file *m, void *v) | 685 | static void fb_seq_stop(struct seq_file *m, void *v) |
| 660 | { | 686 | { |
| 687 | mutex_unlock(®istration_lock); | ||
| 661 | } | 688 | } |
| 662 | 689 | ||
| 663 | static int fb_seq_show(struct seq_file *m, void *v) | 690 | static int fb_seq_show(struct seq_file *m, void *v) |
| @@ -690,13 +717,30 @@ static const struct file_operations fb_proc_fops = { | |||
| 690 | .release = seq_release, | 717 | .release = seq_release, |
| 691 | }; | 718 | }; |
| 692 | 719 | ||
| 693 | static ssize_t | 720 | /* |
| 694 | fb_read(struct file *file, char __user *buf, size_t count, loff_t *ppos) | 721 | * We hold a reference to the fb_info in file->private_data, |
| 722 | * but if the current registered fb has changed, we don't | ||
| 723 | * actually want to use it. | ||
| 724 | * | ||
| 725 | * So look up the fb_info using the inode minor number, | ||
| 726 | * and just verify it against the reference we have. | ||
| 727 | */ | ||
| 728 | static struct fb_info *file_fb_info(struct file *file) | ||
| 695 | { | 729 | { |
| 696 | unsigned long p = *ppos; | ||
| 697 | struct inode *inode = file->f_path.dentry->d_inode; | 730 | struct inode *inode = file->f_path.dentry->d_inode; |
| 698 | int fbidx = iminor(inode); | 731 | int fbidx = iminor(inode); |
| 699 | struct fb_info *info = registered_fb[fbidx]; | 732 | struct fb_info *info = registered_fb[fbidx]; |
| 733 | |||
| 734 | if (info != file->private_data) | ||
| 735 | info = NULL; | ||
| 736 | return info; | ||
| 737 | } | ||
| 738 | |||
| 739 | static ssize_t | ||
| 740 | fb_read(struct file *file, char __user *buf, size_t count, loff_t *ppos) | ||
| 741 | { | ||
| 742 | unsigned long p = *ppos; | ||
| 743 | struct fb_info *info = file_fb_info(file); | ||
| 700 | u8 *buffer, *dst; | 744 | u8 *buffer, *dst; |
| 701 | u8 __iomem *src; | 745 | u8 __iomem *src; |
| 702 | int c, cnt = 0, err = 0; | 746 | int c, cnt = 0, err = 0; |
| @@ -761,9 +805,7 @@ static ssize_t | |||
| 761 | fb_write(struct file *file, const char __user *buf, size_t count, loff_t *ppos) | 805 | fb_write(struct file *file, const char __user *buf, size_t count, loff_t *ppos) |
| 762 | { | 806 | { |
| 763 | unsigned long p = *ppos; | 807 | unsigned long p = *ppos; |
| 764 | struct inode *inode = file->f_path.dentry->d_inode; | 808 | struct fb_info *info = file_fb_info(file); |
| 765 | int fbidx = iminor(inode); | ||
| 766 | struct fb_info *info = registered_fb[fbidx]; | ||
| 767 | u8 *buffer, *src; | 809 | u8 *buffer, *src; |
| 768 | u8 __iomem *dst; | 810 | u8 __iomem *dst; |
| 769 | int c, cnt = 0, err = 0; | 811 | int c, cnt = 0, err = 0; |
| @@ -1141,10 +1183,10 @@ static long do_fb_ioctl(struct fb_info *info, unsigned int cmd, | |||
| 1141 | 1183 | ||
| 1142 | static long fb_ioctl(struct file *file, unsigned int cmd, unsigned long arg) | 1184 | static long fb_ioctl(struct file *file, unsigned int cmd, unsigned long arg) |
| 1143 | { | 1185 | { |
| 1144 | struct inode *inode = file->f_path.dentry->d_inode; | 1186 | struct fb_info *info = file_fb_info(file); |
| 1145 | int fbidx = iminor(inode); | ||
| 1146 | struct fb_info *info = registered_fb[fbidx]; | ||
| 1147 | 1187 | ||
| 1188 | if (!info) | ||
| 1189 | return -ENODEV; | ||
| 1148 | return do_fb_ioctl(info, cmd, arg); | 1190 | return do_fb_ioctl(info, cmd, arg); |
| 1149 | } | 1191 | } |
| 1150 | 1192 | ||
| @@ -1265,12 +1307,13 @@ static int fb_get_fscreeninfo(struct fb_info *info, unsigned int cmd, | |||
| 1265 | static long fb_compat_ioctl(struct file *file, unsigned int cmd, | 1307 | static long fb_compat_ioctl(struct file *file, unsigned int cmd, |
| 1266 | unsigned long arg) | 1308 | unsigned long arg) |
| 1267 | { | 1309 | { |
| 1268 | struct inode *inode = file->f_path.dentry->d_inode; | 1310 | struct fb_info *info = file_fb_info(file); |
| 1269 | int fbidx = iminor(inode); | 1311 | struct fb_ops *fb; |
| 1270 | struct fb_info *info = registered_fb[fbidx]; | ||
| 1271 | struct fb_ops *fb = info->fbops; | ||
| 1272 | long ret = -ENOIOCTLCMD; | 1312 | long ret = -ENOIOCTLCMD; |
| 1273 | 1313 | ||
| 1314 | if (!info) | ||
| 1315 | return -ENODEV; | ||
| 1316 | fb = info->fbops; | ||
| 1274 | switch(cmd) { | 1317 | switch(cmd) { |
| 1275 | case FBIOGET_VSCREENINFO: | 1318 | case FBIOGET_VSCREENINFO: |
| 1276 | case FBIOPUT_VSCREENINFO: | 1319 | case FBIOPUT_VSCREENINFO: |
| @@ -1303,16 +1346,18 @@ static long fb_compat_ioctl(struct file *file, unsigned int cmd, | |||
| 1303 | static int | 1346 | static int |
| 1304 | fb_mmap(struct file *file, struct vm_area_struct * vma) | 1347 | fb_mmap(struct file *file, struct vm_area_struct * vma) |
| 1305 | { | 1348 | { |
| 1306 | int fbidx = iminor(file->f_path.dentry->d_inode); | 1349 | struct fb_info *info = file_fb_info(file); |
| 1307 | struct fb_info *info = registered_fb[fbidx]; | 1350 | struct fb_ops *fb; |
| 1308 | struct fb_ops *fb = info->fbops; | ||
| 1309 | unsigned long off; | 1351 | unsigned long off; |
| 1310 | unsigned long start; | 1352 | unsigned long start; |
| 1311 | u32 len; | 1353 | u32 len; |
| 1312 | 1354 | ||
| 1355 | if (!info) | ||
| 1356 | return -ENODEV; | ||
| 1313 | if (vma->vm_pgoff > (~0UL >> PAGE_SHIFT)) | 1357 | if (vma->vm_pgoff > (~0UL >> PAGE_SHIFT)) |
| 1314 | return -EINVAL; | 1358 | return -EINVAL; |
| 1315 | off = vma->vm_pgoff << PAGE_SHIFT; | 1359 | off = vma->vm_pgoff << PAGE_SHIFT; |
| 1360 | fb = info->fbops; | ||
| 1316 | if (!fb) | 1361 | if (!fb) |
| 1317 | return -ENODEV; | 1362 | return -ENODEV; |
| 1318 | mutex_lock(&info->mm_lock); | 1363 | mutex_lock(&info->mm_lock); |
| @@ -1361,14 +1406,16 @@ __releases(&info->lock) | |||
| 1361 | struct fb_info *info; | 1406 | struct fb_info *info; |
| 1362 | int res = 0; | 1407 | int res = 0; |
| 1363 | 1408 | ||
| 1364 | if (fbidx >= FB_MAX) | 1409 | info = get_fb_info(fbidx); |
| 1365 | return -ENODEV; | 1410 | if (!info) { |
| 1366 | info = registered_fb[fbidx]; | ||
| 1367 | if (!info) | ||
| 1368 | request_module("fb%d", fbidx); | 1411 | request_module("fb%d", fbidx); |
| 1369 | info = registered_fb[fbidx]; | 1412 | info = get_fb_info(fbidx); |
| 1370 | if (!info) | 1413 | if (!info) |
| 1371 | return -ENODEV; | 1414 | return -ENODEV; |
| 1415 | } | ||
| 1416 | if (IS_ERR(info)) | ||
| 1417 | return PTR_ERR(info); | ||
| 1418 | |||
| 1372 | mutex_lock(&info->lock); | 1419 | mutex_lock(&info->lock); |
| 1373 | if (!try_module_get(info->fbops->owner)) { | 1420 | if (!try_module_get(info->fbops->owner)) { |
| 1374 | res = -ENODEV; | 1421 | res = -ENODEV; |
| @@ -1386,6 +1433,8 @@ __releases(&info->lock) | |||
| 1386 | #endif | 1433 | #endif |
| 1387 | out: | 1434 | out: |
| 1388 | mutex_unlock(&info->lock); | 1435 | mutex_unlock(&info->lock); |
| 1436 | if (res) | ||
| 1437 | put_fb_info(info); | ||
| 1389 | return res; | 1438 | return res; |
| 1390 | } | 1439 | } |
| 1391 | 1440 | ||
| @@ -1401,6 +1450,7 @@ __releases(&info->lock) | |||
| 1401 | info->fbops->fb_release(info,1); | 1450 | info->fbops->fb_release(info,1); |
| 1402 | module_put(info->fbops->owner); | 1451 | module_put(info->fbops->owner); |
| 1403 | mutex_unlock(&info->lock); | 1452 | mutex_unlock(&info->lock); |
| 1453 | put_fb_info(info); | ||
| 1404 | return 0; | 1454 | return 0; |
| 1405 | } | 1455 | } |
| 1406 | 1456 | ||
| @@ -1487,8 +1537,10 @@ static bool fb_do_apertures_overlap(struct apertures_struct *gena, | |||
| 1487 | return false; | 1537 | return false; |
| 1488 | } | 1538 | } |
| 1489 | 1539 | ||
| 1540 | static int do_unregister_framebuffer(struct fb_info *fb_info); | ||
| 1541 | |||
| 1490 | #define VGA_FB_PHYS 0xA0000 | 1542 | #define VGA_FB_PHYS 0xA0000 |
| 1491 | void remove_conflicting_framebuffers(struct apertures_struct *a, | 1543 | static void do_remove_conflicting_framebuffers(struct apertures_struct *a, |
| 1492 | const char *name, bool primary) | 1544 | const char *name, bool primary) |
| 1493 | { | 1545 | { |
| 1494 | int i; | 1546 | int i; |
| @@ -1510,43 +1562,32 @@ void remove_conflicting_framebuffers(struct apertures_struct *a, | |||
| 1510 | printk(KERN_INFO "fb: conflicting fb hw usage " | 1562 | printk(KERN_INFO "fb: conflicting fb hw usage " |
| 1511 | "%s vs %s - removing generic driver\n", | 1563 | "%s vs %s - removing generic driver\n", |
| 1512 | name, registered_fb[i]->fix.id); | 1564 | name, registered_fb[i]->fix.id); |
| 1513 | unregister_framebuffer(registered_fb[i]); | 1565 | do_unregister_framebuffer(registered_fb[i]); |
| 1514 | } | 1566 | } |
| 1515 | } | 1567 | } |
| 1516 | } | 1568 | } |
| 1517 | EXPORT_SYMBOL(remove_conflicting_framebuffers); | ||
| 1518 | 1569 | ||
| 1519 | /** | 1570 | static int do_register_framebuffer(struct fb_info *fb_info) |
| 1520 | * register_framebuffer - registers a frame buffer device | ||
| 1521 | * @fb_info: frame buffer info structure | ||
| 1522 | * | ||
| 1523 | * Registers a frame buffer device @fb_info. | ||
| 1524 | * | ||
| 1525 | * Returns negative errno on error, or zero for success. | ||
| 1526 | * | ||
| 1527 | */ | ||
| 1528 | |||
| 1529 | int | ||
| 1530 | register_framebuffer(struct fb_info *fb_info) | ||
| 1531 | { | 1571 | { |
| 1532 | int i; | 1572 | int i; |
| 1533 | struct fb_event event; | 1573 | struct fb_event event; |
| 1534 | struct fb_videomode mode; | 1574 | struct fb_videomode mode; |
| 1535 | 1575 | ||
| 1536 | if (num_registered_fb == FB_MAX) | ||
| 1537 | return -ENXIO; | ||
| 1538 | |||
| 1539 | if (fb_check_foreignness(fb_info)) | 1576 | if (fb_check_foreignness(fb_info)) |
| 1540 | return -ENOSYS; | 1577 | return -ENOSYS; |
| 1541 | 1578 | ||
| 1542 | remove_conflicting_framebuffers(fb_info->apertures, fb_info->fix.id, | 1579 | do_remove_conflicting_framebuffers(fb_info->apertures, fb_info->fix.id, |
| 1543 | fb_is_primary_device(fb_info)); | 1580 | fb_is_primary_device(fb_info)); |
| 1544 | 1581 | ||
| 1582 | if (num_registered_fb == FB_MAX) | ||
| 1583 | return -ENXIO; | ||
| 1584 | |||
| 1545 | num_registered_fb++; | 1585 | num_registered_fb++; |
| 1546 | for (i = 0 ; i < FB_MAX; i++) | 1586 | for (i = 0 ; i < FB_MAX; i++) |
| 1547 | if (!registered_fb[i]) | 1587 | if (!registered_fb[i]) |
| 1548 | break; | 1588 | break; |
| 1549 | fb_info->node = i; | 1589 | fb_info->node = i; |
| 1590 | atomic_set(&fb_info->count, 1); | ||
| 1550 | mutex_init(&fb_info->lock); | 1591 | mutex_init(&fb_info->lock); |
| 1551 | mutex_init(&fb_info->mm_lock); | 1592 | mutex_init(&fb_info->mm_lock); |
| 1552 | 1593 | ||
| @@ -1592,36 +1633,14 @@ register_framebuffer(struct fb_info *fb_info) | |||
| 1592 | return 0; | 1633 | return 0; |
| 1593 | } | 1634 | } |
| 1594 | 1635 | ||
| 1595 | 1636 | static int do_unregister_framebuffer(struct fb_info *fb_info) | |
| 1596 | /** | ||
| 1597 | * unregister_framebuffer - releases a frame buffer device | ||
| 1598 | * @fb_info: frame buffer info structure | ||
| 1599 | * | ||
| 1600 | * Unregisters a frame buffer device @fb_info. | ||
| 1601 | * | ||
| 1602 | * Returns negative errno on error, or zero for success. | ||
| 1603 | * | ||
| 1604 | * This function will also notify the framebuffer console | ||
| 1605 | * to release the driver. | ||
| 1606 | * | ||
| 1607 | * This is meant to be called within a driver's module_exit() | ||
| 1608 | * function. If this is called outside module_exit(), ensure | ||
| 1609 | * that the driver implements fb_open() and fb_release() to | ||
| 1610 | * check that no processes are using the device. | ||
| 1611 | */ | ||
| 1612 | |||
| 1613 | int | ||
| 1614 | unregister_framebuffer(struct fb_info *fb_info) | ||
| 1615 | { | 1637 | { |
| 1616 | struct fb_event event; | 1638 | struct fb_event event; |
| 1617 | int i, ret = 0; | 1639 | int i, ret = 0; |
| 1618 | 1640 | ||
| 1619 | i = fb_info->node; | 1641 | i = fb_info->node; |
| 1620 | if (!registered_fb[i]) { | 1642 | if (i < 0 || i >= FB_MAX || registered_fb[i] != fb_info) |
| 1621 | ret = -EINVAL; | 1643 | return -EINVAL; |
| 1622 | goto done; | ||
| 1623 | } | ||
| 1624 | |||
| 1625 | 1644 | ||
| 1626 | if (!lock_fb_info(fb_info)) | 1645 | if (!lock_fb_info(fb_info)) |
| 1627 | return -ENODEV; | 1646 | return -ENODEV; |
| @@ -1629,16 +1648,14 @@ unregister_framebuffer(struct fb_info *fb_info) | |||
| 1629 | ret = fb_notifier_call_chain(FB_EVENT_FB_UNBIND, &event); | 1648 | ret = fb_notifier_call_chain(FB_EVENT_FB_UNBIND, &event); |
| 1630 | unlock_fb_info(fb_info); | 1649 | unlock_fb_info(fb_info); |
| 1631 | 1650 | ||
| 1632 | if (ret) { | 1651 | if (ret) |
| 1633 | ret = -EINVAL; | 1652 | return -EINVAL; |
| 1634 | goto done; | ||
| 1635 | } | ||
| 1636 | 1653 | ||
| 1637 | if (fb_info->pixmap.addr && | 1654 | if (fb_info->pixmap.addr && |
| 1638 | (fb_info->pixmap.flags & FB_PIXMAP_DEFAULT)) | 1655 | (fb_info->pixmap.flags & FB_PIXMAP_DEFAULT)) |
| 1639 | kfree(fb_info->pixmap.addr); | 1656 | kfree(fb_info->pixmap.addr); |
| 1640 | fb_destroy_modelist(&fb_info->modelist); | 1657 | fb_destroy_modelist(&fb_info->modelist); |
| 1641 | registered_fb[i]=NULL; | 1658 | registered_fb[i] = NULL; |
| 1642 | num_registered_fb--; | 1659 | num_registered_fb--; |
| 1643 | fb_cleanup_device(fb_info); | 1660 | fb_cleanup_device(fb_info); |
| 1644 | device_destroy(fb_class, MKDEV(FB_MAJOR, i)); | 1661 | device_destroy(fb_class, MKDEV(FB_MAJOR, i)); |
| @@ -1646,9 +1663,65 @@ unregister_framebuffer(struct fb_info *fb_info) | |||
| 1646 | fb_notifier_call_chain(FB_EVENT_FB_UNREGISTERED, &event); | 1663 | fb_notifier_call_chain(FB_EVENT_FB_UNREGISTERED, &event); |
| 1647 | 1664 | ||
| 1648 | /* this may free fb info */ | 1665 | /* this may free fb info */ |
| 1649 | if (fb_info->fbops->fb_destroy) | 1666 | put_fb_info(fb_info); |
| 1650 | fb_info->fbops->fb_destroy(fb_info); | 1667 | return 0; |
| 1651 | done: | 1668 | } |
| 1669 | |||
| 1670 | void remove_conflicting_framebuffers(struct apertures_struct *a, | ||
| 1671 | const char *name, bool primary) | ||
| 1672 | { | ||
| 1673 | mutex_lock(®istration_lock); | ||
| 1674 | do_remove_conflicting_framebuffers(a, name, primary); | ||
| 1675 | mutex_unlock(®istration_lock); | ||
| 1676 | } | ||
| 1677 | EXPORT_SYMBOL(remove_conflicting_framebuffers); | ||
| 1678 | |||
| 1679 | /** | ||
| 1680 | * register_framebuffer - registers a frame buffer device | ||
| 1681 | * @fb_info: frame buffer info structure | ||
| 1682 | * | ||
| 1683 | * Registers a frame buffer device @fb_info. | ||
| 1684 | * | ||
| 1685 | * Returns negative errno on error, or zero for success. | ||
| 1686 | * | ||
| 1687 | */ | ||
| 1688 | int | ||
| 1689 | register_framebuffer(struct fb_info *fb_info) | ||
| 1690 | { | ||
| 1691 | int ret; | ||
| 1692 | |||
| 1693 | mutex_lock(®istration_lock); | ||
| 1694 | ret = do_register_framebuffer(fb_info); | ||
| 1695 | mutex_unlock(®istration_lock); | ||
| 1696 | |||
| 1697 | return ret; | ||
| 1698 | } | ||
| 1699 | |||
| 1700 | /** | ||
| 1701 | * unregister_framebuffer - releases a frame buffer device | ||
| 1702 | * @fb_info: frame buffer info structure | ||
| 1703 | * | ||
| 1704 | * Unregisters a frame buffer device @fb_info. | ||
| 1705 | * | ||
| 1706 | * Returns negative errno on error, or zero for success. | ||
| 1707 | * | ||
| 1708 | * This function will also notify the framebuffer console | ||
| 1709 | * to release the driver. | ||
| 1710 | * | ||
| 1711 | * This is meant to be called within a driver's module_exit() | ||
| 1712 | * function. If this is called outside module_exit(), ensure | ||
| 1713 | * that the driver implements fb_open() and fb_release() to | ||
| 1714 | * check that no processes are using the device. | ||
| 1715 | */ | ||
| 1716 | int | ||
| 1717 | unregister_framebuffer(struct fb_info *fb_info) | ||
| 1718 | { | ||
| 1719 | int ret; | ||
| 1720 | |||
| 1721 | mutex_lock(®istration_lock); | ||
| 1722 | ret = do_unregister_framebuffer(fb_info); | ||
| 1723 | mutex_unlock(®istration_lock); | ||
| 1724 | |||
| 1652 | return ret; | 1725 | return ret; |
| 1653 | } | 1726 | } |
| 1654 | 1727 | ||
diff --git a/fs/btrfs/acl.c b/fs/btrfs/acl.c index 5d505aaa72fb..44ea5b92e1ba 100644 --- a/fs/btrfs/acl.c +++ b/fs/btrfs/acl.c | |||
| @@ -178,12 +178,13 @@ static int btrfs_xattr_acl_set(struct dentry *dentry, const char *name, | |||
| 178 | 178 | ||
| 179 | if (value) { | 179 | if (value) { |
| 180 | acl = posix_acl_from_xattr(value, size); | 180 | acl = posix_acl_from_xattr(value, size); |
| 181 | if (IS_ERR(acl)) | ||
| 182 | return PTR_ERR(acl); | ||
| 183 | |||
| 181 | if (acl) { | 184 | if (acl) { |
| 182 | ret = posix_acl_valid(acl); | 185 | ret = posix_acl_valid(acl); |
| 183 | if (ret) | 186 | if (ret) |
| 184 | goto out; | 187 | goto out; |
| 185 | } else if (IS_ERR(acl)) { | ||
| 186 | return PTR_ERR(acl); | ||
| 187 | } | 188 | } |
| 188 | } | 189 | } |
| 189 | 190 | ||
diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c index cd52f7f556ef..9ee6bd55e16c 100644 --- a/fs/btrfs/extent-tree.c +++ b/fs/btrfs/extent-tree.c | |||
| @@ -8856,23 +8856,38 @@ out: | |||
| 8856 | int btrfs_init_space_info(struct btrfs_fs_info *fs_info) | 8856 | int btrfs_init_space_info(struct btrfs_fs_info *fs_info) |
| 8857 | { | 8857 | { |
| 8858 | struct btrfs_space_info *space_info; | 8858 | struct btrfs_space_info *space_info; |
| 8859 | struct btrfs_super_block *disk_super; | ||
| 8860 | u64 features; | ||
| 8861 | u64 flags; | ||
| 8862 | int mixed = 0; | ||
| 8859 | int ret; | 8863 | int ret; |
| 8860 | 8864 | ||
| 8861 | ret = update_space_info(fs_info, BTRFS_BLOCK_GROUP_SYSTEM, 0, 0, | 8865 | disk_super = &fs_info->super_copy; |
| 8862 | &space_info); | 8866 | if (!btrfs_super_root(disk_super)) |
| 8863 | if (ret) | 8867 | return 1; |
| 8864 | return ret; | ||
| 8865 | 8868 | ||
| 8866 | ret = update_space_info(fs_info, BTRFS_BLOCK_GROUP_METADATA, 0, 0, | 8869 | features = btrfs_super_incompat_flags(disk_super); |
| 8867 | &space_info); | 8870 | if (features & BTRFS_FEATURE_INCOMPAT_MIXED_GROUPS) |
| 8868 | if (ret) | 8871 | mixed = 1; |
| 8869 | return ret; | ||
| 8870 | 8872 | ||
| 8871 | ret = update_space_info(fs_info, BTRFS_BLOCK_GROUP_DATA, 0, 0, | 8873 | flags = BTRFS_BLOCK_GROUP_SYSTEM; |
| 8872 | &space_info); | 8874 | ret = update_space_info(fs_info, flags, 0, 0, &space_info); |
| 8873 | if (ret) | 8875 | if (ret) |
| 8874 | return ret; | 8876 | goto out; |
| 8875 | 8877 | ||
| 8878 | if (mixed) { | ||
| 8879 | flags = BTRFS_BLOCK_GROUP_METADATA | BTRFS_BLOCK_GROUP_DATA; | ||
| 8880 | ret = update_space_info(fs_info, flags, 0, 0, &space_info); | ||
| 8881 | } else { | ||
| 8882 | flags = BTRFS_BLOCK_GROUP_METADATA; | ||
| 8883 | ret = update_space_info(fs_info, flags, 0, 0, &space_info); | ||
| 8884 | if (ret) | ||
| 8885 | goto out; | ||
| 8886 | |||
| 8887 | flags = BTRFS_BLOCK_GROUP_DATA; | ||
| 8888 | ret = update_space_info(fs_info, flags, 0, 0, &space_info); | ||
| 8889 | } | ||
| 8890 | out: | ||
| 8876 | return ret; | 8891 | return ret; |
| 8877 | } | 8892 | } |
| 8878 | 8893 | ||
diff --git a/fs/btrfs/ioctl.c b/fs/btrfs/ioctl.c index ffb48d6c5433..2616f7ed4799 100644 --- a/fs/btrfs/ioctl.c +++ b/fs/btrfs/ioctl.c | |||
| @@ -81,6 +81,13 @@ static unsigned int btrfs_flags_to_ioctl(unsigned int flags) | |||
| 81 | iflags |= FS_NOATIME_FL; | 81 | iflags |= FS_NOATIME_FL; |
| 82 | if (flags & BTRFS_INODE_DIRSYNC) | 82 | if (flags & BTRFS_INODE_DIRSYNC) |
| 83 | iflags |= FS_DIRSYNC_FL; | 83 | iflags |= FS_DIRSYNC_FL; |
| 84 | if (flags & BTRFS_INODE_NODATACOW) | ||
| 85 | iflags |= FS_NOCOW_FL; | ||
| 86 | |||
| 87 | if ((flags & BTRFS_INODE_COMPRESS) && !(flags & BTRFS_INODE_NOCOMPRESS)) | ||
| 88 | iflags |= FS_COMPR_FL; | ||
| 89 | else if (flags & BTRFS_INODE_NOCOMPRESS) | ||
| 90 | iflags |= FS_NOCOMP_FL; | ||
| 84 | 91 | ||
| 85 | return iflags; | 92 | return iflags; |
| 86 | } | 93 | } |
| @@ -144,16 +151,13 @@ static int check_flags(unsigned int flags) | |||
| 144 | if (flags & ~(FS_IMMUTABLE_FL | FS_APPEND_FL | \ | 151 | if (flags & ~(FS_IMMUTABLE_FL | FS_APPEND_FL | \ |
| 145 | FS_NOATIME_FL | FS_NODUMP_FL | \ | 152 | FS_NOATIME_FL | FS_NODUMP_FL | \ |
| 146 | FS_SYNC_FL | FS_DIRSYNC_FL | \ | 153 | FS_SYNC_FL | FS_DIRSYNC_FL | \ |
| 147 | FS_NOCOMP_FL | FS_COMPR_FL | \ | 154 | FS_NOCOMP_FL | FS_COMPR_FL | |
| 148 | FS_NOCOW_FL | FS_COW_FL)) | 155 | FS_NOCOW_FL)) |
| 149 | return -EOPNOTSUPP; | 156 | return -EOPNOTSUPP; |
| 150 | 157 | ||
| 151 | if ((flags & FS_NOCOMP_FL) && (flags & FS_COMPR_FL)) | 158 | if ((flags & FS_NOCOMP_FL) && (flags & FS_COMPR_FL)) |
| 152 | return -EINVAL; | 159 | return -EINVAL; |
| 153 | 160 | ||
| 154 | if ((flags & FS_NOCOW_FL) && (flags & FS_COW_FL)) | ||
| 155 | return -EINVAL; | ||
| 156 | |||
| 157 | return 0; | 161 | return 0; |
| 158 | } | 162 | } |
| 159 | 163 | ||
| @@ -218,6 +222,10 @@ static int btrfs_ioctl_setflags(struct file *file, void __user *arg) | |||
| 218 | ip->flags |= BTRFS_INODE_DIRSYNC; | 222 | ip->flags |= BTRFS_INODE_DIRSYNC; |
| 219 | else | 223 | else |
| 220 | ip->flags &= ~BTRFS_INODE_DIRSYNC; | 224 | ip->flags &= ~BTRFS_INODE_DIRSYNC; |
| 225 | if (flags & FS_NOCOW_FL) | ||
| 226 | ip->flags |= BTRFS_INODE_NODATACOW; | ||
| 227 | else | ||
| 228 | ip->flags &= ~BTRFS_INODE_NODATACOW; | ||
| 221 | 229 | ||
| 222 | /* | 230 | /* |
| 223 | * The COMPRESS flag can only be changed by users, while the NOCOMPRESS | 231 | * The COMPRESS flag can only be changed by users, while the NOCOMPRESS |
| @@ -230,11 +238,9 @@ static int btrfs_ioctl_setflags(struct file *file, void __user *arg) | |||
| 230 | } else if (flags & FS_COMPR_FL) { | 238 | } else if (flags & FS_COMPR_FL) { |
| 231 | ip->flags |= BTRFS_INODE_COMPRESS; | 239 | ip->flags |= BTRFS_INODE_COMPRESS; |
| 232 | ip->flags &= ~BTRFS_INODE_NOCOMPRESS; | 240 | ip->flags &= ~BTRFS_INODE_NOCOMPRESS; |
| 241 | } else { | ||
| 242 | ip->flags &= ~(BTRFS_INODE_COMPRESS | BTRFS_INODE_NOCOMPRESS); | ||
| 233 | } | 243 | } |
| 234 | if (flags & FS_NOCOW_FL) | ||
| 235 | ip->flags |= BTRFS_INODE_NODATACOW; | ||
| 236 | else if (flags & FS_COW_FL) | ||
| 237 | ip->flags &= ~BTRFS_INODE_NODATACOW; | ||
| 238 | 244 | ||
| 239 | trans = btrfs_join_transaction(root, 1); | 245 | trans = btrfs_join_transaction(root, 1); |
| 240 | BUG_ON(IS_ERR(trans)); | 246 | BUG_ON(IS_ERR(trans)); |
diff --git a/fs/ceph/caps.c b/fs/ceph/caps.c index 9fa08662a88d..2a5404c1c42f 100644 --- a/fs/ceph/caps.c +++ b/fs/ceph/caps.c | |||
| @@ -819,7 +819,7 @@ int __ceph_caps_used(struct ceph_inode_info *ci) | |||
| 819 | used |= CEPH_CAP_FILE_CACHE; | 819 | used |= CEPH_CAP_FILE_CACHE; |
| 820 | if (ci->i_wr_ref) | 820 | if (ci->i_wr_ref) |
| 821 | used |= CEPH_CAP_FILE_WR; | 821 | used |= CEPH_CAP_FILE_WR; |
| 822 | if (ci->i_wrbuffer_ref) | 822 | if (ci->i_wb_ref || ci->i_wrbuffer_ref) |
| 823 | used |= CEPH_CAP_FILE_BUFFER; | 823 | used |= CEPH_CAP_FILE_BUFFER; |
| 824 | return used; | 824 | return used; |
| 825 | } | 825 | } |
| @@ -1990,11 +1990,11 @@ static void __take_cap_refs(struct ceph_inode_info *ci, int got) | |||
| 1990 | if (got & CEPH_CAP_FILE_WR) | 1990 | if (got & CEPH_CAP_FILE_WR) |
| 1991 | ci->i_wr_ref++; | 1991 | ci->i_wr_ref++; |
| 1992 | if (got & CEPH_CAP_FILE_BUFFER) { | 1992 | if (got & CEPH_CAP_FILE_BUFFER) { |
| 1993 | if (ci->i_wrbuffer_ref == 0) | 1993 | if (ci->i_wb_ref == 0) |
| 1994 | ihold(&ci->vfs_inode); | 1994 | ihold(&ci->vfs_inode); |
| 1995 | ci->i_wrbuffer_ref++; | 1995 | ci->i_wb_ref++; |
| 1996 | dout("__take_cap_refs %p wrbuffer %d -> %d (?)\n", | 1996 | dout("__take_cap_refs %p wb %d -> %d (?)\n", |
| 1997 | &ci->vfs_inode, ci->i_wrbuffer_ref-1, ci->i_wrbuffer_ref); | 1997 | &ci->vfs_inode, ci->i_wb_ref-1, ci->i_wb_ref); |
| 1998 | } | 1998 | } |
| 1999 | } | 1999 | } |
| 2000 | 2000 | ||
| @@ -2169,12 +2169,12 @@ void ceph_put_cap_refs(struct ceph_inode_info *ci, int had) | |||
| 2169 | if (--ci->i_rdcache_ref == 0) | 2169 | if (--ci->i_rdcache_ref == 0) |
| 2170 | last++; | 2170 | last++; |
| 2171 | if (had & CEPH_CAP_FILE_BUFFER) { | 2171 | if (had & CEPH_CAP_FILE_BUFFER) { |
| 2172 | if (--ci->i_wrbuffer_ref == 0) { | 2172 | if (--ci->i_wb_ref == 0) { |
| 2173 | last++; | 2173 | last++; |
| 2174 | put++; | 2174 | put++; |
| 2175 | } | 2175 | } |
| 2176 | dout("put_cap_refs %p wrbuffer %d -> %d (?)\n", | 2176 | dout("put_cap_refs %p wb %d -> %d (?)\n", |
| 2177 | inode, ci->i_wrbuffer_ref+1, ci->i_wrbuffer_ref); | 2177 | inode, ci->i_wb_ref+1, ci->i_wb_ref); |
| 2178 | } | 2178 | } |
| 2179 | if (had & CEPH_CAP_FILE_WR) | 2179 | if (had & CEPH_CAP_FILE_WR) |
| 2180 | if (--ci->i_wr_ref == 0) { | 2180 | if (--ci->i_wr_ref == 0) { |
diff --git a/fs/ceph/inode.c b/fs/ceph/inode.c index 03d6dafda61f..70b6a4839c38 100644 --- a/fs/ceph/inode.c +++ b/fs/ceph/inode.c | |||
| @@ -355,6 +355,7 @@ struct inode *ceph_alloc_inode(struct super_block *sb) | |||
| 355 | ci->i_rd_ref = 0; | 355 | ci->i_rd_ref = 0; |
| 356 | ci->i_rdcache_ref = 0; | 356 | ci->i_rdcache_ref = 0; |
| 357 | ci->i_wr_ref = 0; | 357 | ci->i_wr_ref = 0; |
| 358 | ci->i_wb_ref = 0; | ||
| 358 | ci->i_wrbuffer_ref = 0; | 359 | ci->i_wrbuffer_ref = 0; |
| 359 | ci->i_wrbuffer_ref_head = 0; | 360 | ci->i_wrbuffer_ref_head = 0; |
| 360 | ci->i_shared_gen = 0; | 361 | ci->i_shared_gen = 0; |
diff --git a/fs/ceph/mds_client.c b/fs/ceph/mds_client.c index f60b07b0feb0..d0fae4ce9ba5 100644 --- a/fs/ceph/mds_client.c +++ b/fs/ceph/mds_client.c | |||
| @@ -3304,8 +3304,8 @@ static void con_put(struct ceph_connection *con) | |||
| 3304 | { | 3304 | { |
| 3305 | struct ceph_mds_session *s = con->private; | 3305 | struct ceph_mds_session *s = con->private; |
| 3306 | 3306 | ||
| 3307 | dout("mdsc con_put %p (%d)\n", s, atomic_read(&s->s_ref) - 1); | ||
| 3307 | ceph_put_mds_session(s); | 3308 | ceph_put_mds_session(s); |
| 3308 | dout("mdsc con_put %p (%d)\n", s, atomic_read(&s->s_ref)); | ||
| 3309 | } | 3309 | } |
| 3310 | 3310 | ||
| 3311 | /* | 3311 | /* |
diff --git a/fs/ceph/snap.c b/fs/ceph/snap.c index e86ec1155f8f..24067d68a554 100644 --- a/fs/ceph/snap.c +++ b/fs/ceph/snap.c | |||
| @@ -206,7 +206,7 @@ void ceph_put_snap_realm(struct ceph_mds_client *mdsc, | |||
| 206 | up_write(&mdsc->snap_rwsem); | 206 | up_write(&mdsc->snap_rwsem); |
| 207 | } else { | 207 | } else { |
| 208 | spin_lock(&mdsc->snap_empty_lock); | 208 | spin_lock(&mdsc->snap_empty_lock); |
| 209 | list_add(&mdsc->snap_empty, &realm->empty_item); | 209 | list_add(&realm->empty_item, &mdsc->snap_empty); |
| 210 | spin_unlock(&mdsc->snap_empty_lock); | 210 | spin_unlock(&mdsc->snap_empty_lock); |
| 211 | } | 211 | } |
| 212 | } | 212 | } |
diff --git a/fs/ceph/super.h b/fs/ceph/super.h index b1f1b8bb1271..f5cabefa98dc 100644 --- a/fs/ceph/super.h +++ b/fs/ceph/super.h | |||
| @@ -293,7 +293,7 @@ struct ceph_inode_info { | |||
| 293 | 293 | ||
| 294 | /* held references to caps */ | 294 | /* held references to caps */ |
| 295 | int i_pin_ref; | 295 | int i_pin_ref; |
| 296 | int i_rd_ref, i_rdcache_ref, i_wr_ref; | 296 | int i_rd_ref, i_rdcache_ref, i_wr_ref, i_wb_ref; |
| 297 | int i_wrbuffer_ref, i_wrbuffer_ref_head; | 297 | int i_wrbuffer_ref, i_wrbuffer_ref_head; |
| 298 | u32 i_shared_gen; /* increment each time we get FILE_SHARED */ | 298 | u32 i_shared_gen; /* increment each time we get FILE_SHARED */ |
| 299 | u32 i_rdcache_gen; /* incremented each time we get FILE_CACHE. */ | 299 | u32 i_rdcache_gen; /* incremented each time we get FILE_CACHE. */ |
diff --git a/fs/cifs/cifs_unicode.c b/fs/cifs/cifs_unicode.c index 23d43cde4306..1b2e180b018d 100644 --- a/fs/cifs/cifs_unicode.c +++ b/fs/cifs/cifs_unicode.c | |||
| @@ -277,6 +277,7 @@ cifsConvertToUCS(__le16 *target, const char *source, int srclen, | |||
| 277 | 277 | ||
| 278 | for (i = 0, j = 0; i < srclen; j++) { | 278 | for (i = 0, j = 0; i < srclen; j++) { |
| 279 | src_char = source[i]; | 279 | src_char = source[i]; |
| 280 | charlen = 1; | ||
| 280 | switch (src_char) { | 281 | switch (src_char) { |
| 281 | case 0: | 282 | case 0: |
| 282 | put_unaligned(0, &target[j]); | 283 | put_unaligned(0, &target[j]); |
| @@ -316,16 +317,13 @@ cifsConvertToUCS(__le16 *target, const char *source, int srclen, | |||
| 316 | dst_char = cpu_to_le16(0x003f); | 317 | dst_char = cpu_to_le16(0x003f); |
| 317 | charlen = 1; | 318 | charlen = 1; |
| 318 | } | 319 | } |
| 319 | /* | ||
| 320 | * character may take more than one byte in the source | ||
| 321 | * string, but will take exactly two bytes in the | ||
| 322 | * target string | ||
| 323 | */ | ||
| 324 | i += charlen; | ||
| 325 | continue; | ||
| 326 | } | 320 | } |
| 321 | /* | ||
| 322 | * character may take more than one byte in the source string, | ||
| 323 | * but will take exactly two bytes in the target string | ||
| 324 | */ | ||
| 325 | i += charlen; | ||
| 327 | put_unaligned(dst_char, &target[j]); | 326 | put_unaligned(dst_char, &target[j]); |
| 328 | i++; /* move to next char in source string */ | ||
| 329 | } | 327 | } |
| 330 | 328 | ||
| 331 | ctoUCS_out: | 329 | ctoUCS_out: |
diff --git a/fs/cifs/connect.c b/fs/cifs/connect.c index 05f1dcf7d79a..277262a8e82f 100644 --- a/fs/cifs/connect.c +++ b/fs/cifs/connect.c | |||
| @@ -2673,6 +2673,11 @@ is_path_accessible(int xid, struct cifsTconInfo *tcon, | |||
| 2673 | 0 /* not legacy */, cifs_sb->local_nls, | 2673 | 0 /* not legacy */, cifs_sb->local_nls, |
| 2674 | cifs_sb->mnt_cifs_flags & | 2674 | cifs_sb->mnt_cifs_flags & |
| 2675 | CIFS_MOUNT_MAP_SPECIAL_CHR); | 2675 | CIFS_MOUNT_MAP_SPECIAL_CHR); |
| 2676 | |||
| 2677 | if (rc == -EOPNOTSUPP || rc == -EINVAL) | ||
| 2678 | rc = SMBQueryInformation(xid, tcon, full_path, pfile_info, | ||
| 2679 | cifs_sb->local_nls, cifs_sb->mnt_cifs_flags & | ||
| 2680 | CIFS_MOUNT_MAP_SPECIAL_CHR); | ||
| 2676 | kfree(pfile_info); | 2681 | kfree(pfile_info); |
| 2677 | return rc; | 2682 | return rc; |
| 2678 | } | 2683 | } |
diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c index c6ba49bd95b3..b32eb29a4e6f 100644 --- a/fs/fuse/dir.c +++ b/fs/fuse/dir.c | |||
| @@ -174,7 +174,7 @@ static int fuse_dentry_revalidate(struct dentry *entry, struct nameidata *nd) | |||
| 174 | if (!inode) | 174 | if (!inode) |
| 175 | return 0; | 175 | return 0; |
| 176 | 176 | ||
| 177 | if (nd->flags & LOOKUP_RCU) | 177 | if (nd && (nd->flags & LOOKUP_RCU)) |
| 178 | return -ECHILD; | 178 | return -ECHILD; |
| 179 | 179 | ||
| 180 | fc = get_fuse_conn(inode); | 180 | fc = get_fuse_conn(inode); |
diff --git a/fs/namei.c b/fs/namei.c index 54fc993e3027..e3c4f112ebf7 100644 --- a/fs/namei.c +++ b/fs/namei.c | |||
| @@ -179,7 +179,7 @@ EXPORT_SYMBOL(putname); | |||
| 179 | static int acl_permission_check(struct inode *inode, int mask, unsigned int flags, | 179 | static int acl_permission_check(struct inode *inode, int mask, unsigned int flags, |
| 180 | int (*check_acl)(struct inode *inode, int mask, unsigned int flags)) | 180 | int (*check_acl)(struct inode *inode, int mask, unsigned int flags)) |
| 181 | { | 181 | { |
| 182 | umode_t mode = inode->i_mode; | 182 | unsigned int mode = inode->i_mode; |
| 183 | 183 | ||
| 184 | mask &= MAY_READ | MAY_WRITE | MAY_EXEC; | 184 | mask &= MAY_READ | MAY_WRITE | MAY_EXEC; |
| 185 | 185 | ||
diff --git a/fs/nfs/nfs4filelayout.c b/fs/nfs/nfs4filelayout.c index 6f8192f4cfc7..be79dc9f386d 100644 --- a/fs/nfs/nfs4filelayout.c +++ b/fs/nfs/nfs4filelayout.c | |||
| @@ -117,6 +117,8 @@ static int filelayout_async_handle_error(struct rpc_task *task, | |||
| 117 | case -EKEYEXPIRED: | 117 | case -EKEYEXPIRED: |
| 118 | rpc_delay(task, FILELAYOUT_POLL_RETRY_MAX); | 118 | rpc_delay(task, FILELAYOUT_POLL_RETRY_MAX); |
| 119 | break; | 119 | break; |
| 120 | case -NFS4ERR_RETRY_UNCACHED_REP: | ||
| 121 | break; | ||
| 120 | default: | 122 | default: |
| 121 | dprintk("%s DS error. Retry through MDS %d\n", __func__, | 123 | dprintk("%s DS error. Retry through MDS %d\n", __func__, |
| 122 | task->tk_status); | 124 | task->tk_status); |
| @@ -416,7 +418,8 @@ static int | |||
| 416 | filelayout_check_layout(struct pnfs_layout_hdr *lo, | 418 | filelayout_check_layout(struct pnfs_layout_hdr *lo, |
| 417 | struct nfs4_filelayout_segment *fl, | 419 | struct nfs4_filelayout_segment *fl, |
| 418 | struct nfs4_layoutget_res *lgr, | 420 | struct nfs4_layoutget_res *lgr, |
| 419 | struct nfs4_deviceid *id) | 421 | struct nfs4_deviceid *id, |
| 422 | gfp_t gfp_flags) | ||
| 420 | { | 423 | { |
| 421 | struct nfs4_file_layout_dsaddr *dsaddr; | 424 | struct nfs4_file_layout_dsaddr *dsaddr; |
| 422 | int status = -EINVAL; | 425 | int status = -EINVAL; |
| @@ -439,7 +442,7 @@ filelayout_check_layout(struct pnfs_layout_hdr *lo, | |||
| 439 | /* find and reference the deviceid */ | 442 | /* find and reference the deviceid */ |
| 440 | dsaddr = nfs4_fl_find_get_deviceid(id); | 443 | dsaddr = nfs4_fl_find_get_deviceid(id); |
| 441 | if (dsaddr == NULL) { | 444 | if (dsaddr == NULL) { |
| 442 | dsaddr = get_device_info(lo->plh_inode, id); | 445 | dsaddr = get_device_info(lo->plh_inode, id, gfp_flags); |
| 443 | if (dsaddr == NULL) | 446 | if (dsaddr == NULL) |
| 444 | goto out; | 447 | goto out; |
| 445 | } | 448 | } |
| @@ -500,7 +503,8 @@ static int | |||
| 500 | filelayout_decode_layout(struct pnfs_layout_hdr *flo, | 503 | filelayout_decode_layout(struct pnfs_layout_hdr *flo, |
| 501 | struct nfs4_filelayout_segment *fl, | 504 | struct nfs4_filelayout_segment *fl, |
| 502 | struct nfs4_layoutget_res *lgr, | 505 | struct nfs4_layoutget_res *lgr, |
| 503 | struct nfs4_deviceid *id) | 506 | struct nfs4_deviceid *id, |
| 507 | gfp_t gfp_flags) | ||
| 504 | { | 508 | { |
| 505 | struct xdr_stream stream; | 509 | struct xdr_stream stream; |
| 506 | struct xdr_buf buf = { | 510 | struct xdr_buf buf = { |
| @@ -516,7 +520,7 @@ filelayout_decode_layout(struct pnfs_layout_hdr *flo, | |||
| 516 | 520 | ||
| 517 | dprintk("%s: set_layout_map Begin\n", __func__); | 521 | dprintk("%s: set_layout_map Begin\n", __func__); |
| 518 | 522 | ||
| 519 | scratch = alloc_page(GFP_KERNEL); | 523 | scratch = alloc_page(gfp_flags); |
| 520 | if (!scratch) | 524 | if (!scratch) |
| 521 | return -ENOMEM; | 525 | return -ENOMEM; |
| 522 | 526 | ||
| @@ -554,13 +558,13 @@ filelayout_decode_layout(struct pnfs_layout_hdr *flo, | |||
| 554 | goto out_err; | 558 | goto out_err; |
| 555 | 559 | ||
| 556 | fl->fh_array = kzalloc(fl->num_fh * sizeof(struct nfs_fh *), | 560 | fl->fh_array = kzalloc(fl->num_fh * sizeof(struct nfs_fh *), |
| 557 | GFP_KERNEL); | 561 | gfp_flags); |
| 558 | if (!fl->fh_array) | 562 | if (!fl->fh_array) |
| 559 | goto out_err; | 563 | goto out_err; |
| 560 | 564 | ||
| 561 | for (i = 0; i < fl->num_fh; i++) { | 565 | for (i = 0; i < fl->num_fh; i++) { |
| 562 | /* Do we want to use a mempool here? */ | 566 | /* Do we want to use a mempool here? */ |
| 563 | fl->fh_array[i] = kmalloc(sizeof(struct nfs_fh), GFP_KERNEL); | 567 | fl->fh_array[i] = kmalloc(sizeof(struct nfs_fh), gfp_flags); |
| 564 | if (!fl->fh_array[i]) | 568 | if (!fl->fh_array[i]) |
| 565 | goto out_err_free; | 569 | goto out_err_free; |
| 566 | 570 | ||
| @@ -605,19 +609,20 @@ filelayout_free_lseg(struct pnfs_layout_segment *lseg) | |||
| 605 | 609 | ||
| 606 | static struct pnfs_layout_segment * | 610 | static struct pnfs_layout_segment * |
| 607 | filelayout_alloc_lseg(struct pnfs_layout_hdr *layoutid, | 611 | filelayout_alloc_lseg(struct pnfs_layout_hdr *layoutid, |
| 608 | struct nfs4_layoutget_res *lgr) | 612 | struct nfs4_layoutget_res *lgr, |
| 613 | gfp_t gfp_flags) | ||
| 609 | { | 614 | { |
| 610 | struct nfs4_filelayout_segment *fl; | 615 | struct nfs4_filelayout_segment *fl; |
| 611 | int rc; | 616 | int rc; |
| 612 | struct nfs4_deviceid id; | 617 | struct nfs4_deviceid id; |
| 613 | 618 | ||
| 614 | dprintk("--> %s\n", __func__); | 619 | dprintk("--> %s\n", __func__); |
| 615 | fl = kzalloc(sizeof(*fl), GFP_KERNEL); | 620 | fl = kzalloc(sizeof(*fl), gfp_flags); |
| 616 | if (!fl) | 621 | if (!fl) |
| 617 | return NULL; | 622 | return NULL; |
| 618 | 623 | ||
| 619 | rc = filelayout_decode_layout(layoutid, fl, lgr, &id); | 624 | rc = filelayout_decode_layout(layoutid, fl, lgr, &id, gfp_flags); |
| 620 | if (rc != 0 || filelayout_check_layout(layoutid, fl, lgr, &id)) { | 625 | if (rc != 0 || filelayout_check_layout(layoutid, fl, lgr, &id, gfp_flags)) { |
| 621 | _filelayout_free_lseg(fl); | 626 | _filelayout_free_lseg(fl); |
| 622 | return NULL; | 627 | return NULL; |
| 623 | } | 628 | } |
| @@ -633,7 +638,7 @@ filelayout_alloc_lseg(struct pnfs_layout_hdr *layoutid, | |||
| 633 | int size = (fl->stripe_type == STRIPE_SPARSE) ? | 638 | int size = (fl->stripe_type == STRIPE_SPARSE) ? |
| 634 | fl->dsaddr->ds_num : fl->dsaddr->stripe_count; | 639 | fl->dsaddr->ds_num : fl->dsaddr->stripe_count; |
| 635 | 640 | ||
| 636 | fl->commit_buckets = kcalloc(size, sizeof(struct list_head), GFP_KERNEL); | 641 | fl->commit_buckets = kcalloc(size, sizeof(struct list_head), gfp_flags); |
| 637 | if (!fl->commit_buckets) { | 642 | if (!fl->commit_buckets) { |
| 638 | filelayout_free_lseg(&fl->generic_hdr); | 643 | filelayout_free_lseg(&fl->generic_hdr); |
| 639 | return NULL; | 644 | return NULL; |
diff --git a/fs/nfs/nfs4filelayout.h b/fs/nfs/nfs4filelayout.h index 7c44579f5832..2b461d77b43a 100644 --- a/fs/nfs/nfs4filelayout.h +++ b/fs/nfs/nfs4filelayout.h | |||
| @@ -104,6 +104,6 @@ extern struct nfs4_file_layout_dsaddr * | |||
| 104 | nfs4_fl_find_get_deviceid(struct nfs4_deviceid *dev_id); | 104 | nfs4_fl_find_get_deviceid(struct nfs4_deviceid *dev_id); |
| 105 | extern void nfs4_fl_put_deviceid(struct nfs4_file_layout_dsaddr *dsaddr); | 105 | extern void nfs4_fl_put_deviceid(struct nfs4_file_layout_dsaddr *dsaddr); |
| 106 | struct nfs4_file_layout_dsaddr * | 106 | struct nfs4_file_layout_dsaddr * |
| 107 | get_device_info(struct inode *inode, struct nfs4_deviceid *dev_id); | 107 | get_device_info(struct inode *inode, struct nfs4_deviceid *dev_id, gfp_t gfp_flags); |
| 108 | 108 | ||
| 109 | #endif /* FS_NFS_NFS4FILELAYOUT_H */ | 109 | #endif /* FS_NFS_NFS4FILELAYOUT_H */ |
diff --git a/fs/nfs/nfs4filelayoutdev.c b/fs/nfs/nfs4filelayoutdev.c index de5350f2b249..db07c7af1395 100644 --- a/fs/nfs/nfs4filelayoutdev.c +++ b/fs/nfs/nfs4filelayoutdev.c | |||
| @@ -225,11 +225,11 @@ nfs4_fl_free_deviceid(struct nfs4_file_layout_dsaddr *dsaddr) | |||
| 225 | } | 225 | } |
| 226 | 226 | ||
| 227 | static struct nfs4_pnfs_ds * | 227 | static struct nfs4_pnfs_ds * |
| 228 | nfs4_pnfs_ds_add(struct inode *inode, u32 ip_addr, u32 port) | 228 | nfs4_pnfs_ds_add(struct inode *inode, u32 ip_addr, u32 port, gfp_t gfp_flags) |
| 229 | { | 229 | { |
| 230 | struct nfs4_pnfs_ds *tmp_ds, *ds; | 230 | struct nfs4_pnfs_ds *tmp_ds, *ds; |
| 231 | 231 | ||
| 232 | ds = kzalloc(sizeof(*tmp_ds), GFP_KERNEL); | 232 | ds = kzalloc(sizeof(*tmp_ds), gfp_flags); |
| 233 | if (!ds) | 233 | if (!ds) |
| 234 | goto out; | 234 | goto out; |
| 235 | 235 | ||
| @@ -261,7 +261,7 @@ out: | |||
| 261 | * Currently only support ipv4, and one multi-path address. | 261 | * Currently only support ipv4, and one multi-path address. |
| 262 | */ | 262 | */ |
| 263 | static struct nfs4_pnfs_ds * | 263 | static struct nfs4_pnfs_ds * |
| 264 | decode_and_add_ds(struct xdr_stream *streamp, struct inode *inode) | 264 | decode_and_add_ds(struct xdr_stream *streamp, struct inode *inode, gfp_t gfp_flags) |
| 265 | { | 265 | { |
| 266 | struct nfs4_pnfs_ds *ds = NULL; | 266 | struct nfs4_pnfs_ds *ds = NULL; |
| 267 | char *buf; | 267 | char *buf; |
| @@ -303,7 +303,7 @@ decode_and_add_ds(struct xdr_stream *streamp, struct inode *inode) | |||
| 303 | rlen); | 303 | rlen); |
| 304 | goto out_err; | 304 | goto out_err; |
| 305 | } | 305 | } |
| 306 | buf = kmalloc(rlen + 1, GFP_KERNEL); | 306 | buf = kmalloc(rlen + 1, gfp_flags); |
| 307 | if (!buf) { | 307 | if (!buf) { |
| 308 | dprintk("%s: Not enough memory\n", __func__); | 308 | dprintk("%s: Not enough memory\n", __func__); |
| 309 | goto out_err; | 309 | goto out_err; |
| @@ -333,7 +333,7 @@ decode_and_add_ds(struct xdr_stream *streamp, struct inode *inode) | |||
| 333 | sscanf(pstr, "-%d-%d", &tmp[0], &tmp[1]); | 333 | sscanf(pstr, "-%d-%d", &tmp[0], &tmp[1]); |
| 334 | port = htons((tmp[0] << 8) | (tmp[1])); | 334 | port = htons((tmp[0] << 8) | (tmp[1])); |
| 335 | 335 | ||
| 336 | ds = nfs4_pnfs_ds_add(inode, ip_addr, port); | 336 | ds = nfs4_pnfs_ds_add(inode, ip_addr, port, gfp_flags); |
| 337 | dprintk("%s: Decoded address and port %s\n", __func__, buf); | 337 | dprintk("%s: Decoded address and port %s\n", __func__, buf); |
| 338 | out_free: | 338 | out_free: |
| 339 | kfree(buf); | 339 | kfree(buf); |
| @@ -343,7 +343,7 @@ out_err: | |||
| 343 | 343 | ||
| 344 | /* Decode opaque device data and return the result */ | 344 | /* Decode opaque device data and return the result */ |
| 345 | static struct nfs4_file_layout_dsaddr* | 345 | static struct nfs4_file_layout_dsaddr* |
| 346 | decode_device(struct inode *ino, struct pnfs_device *pdev) | 346 | decode_device(struct inode *ino, struct pnfs_device *pdev, gfp_t gfp_flags) |
| 347 | { | 347 | { |
| 348 | int i; | 348 | int i; |
| 349 | u32 cnt, num; | 349 | u32 cnt, num; |
| @@ -362,7 +362,7 @@ decode_device(struct inode *ino, struct pnfs_device *pdev) | |||
| 362 | struct page *scratch; | 362 | struct page *scratch; |
| 363 | 363 | ||
| 364 | /* set up xdr stream */ | 364 | /* set up xdr stream */ |
| 365 | scratch = alloc_page(GFP_KERNEL); | 365 | scratch = alloc_page(gfp_flags); |
| 366 | if (!scratch) | 366 | if (!scratch) |
| 367 | goto out_err; | 367 | goto out_err; |
| 368 | 368 | ||
| @@ -384,7 +384,7 @@ decode_device(struct inode *ino, struct pnfs_device *pdev) | |||
| 384 | } | 384 | } |
| 385 | 385 | ||
| 386 | /* read stripe indices */ | 386 | /* read stripe indices */ |
| 387 | stripe_indices = kcalloc(cnt, sizeof(u8), GFP_KERNEL); | 387 | stripe_indices = kcalloc(cnt, sizeof(u8), gfp_flags); |
| 388 | if (!stripe_indices) | 388 | if (!stripe_indices) |
| 389 | goto out_err_free_scratch; | 389 | goto out_err_free_scratch; |
| 390 | 390 | ||
| @@ -423,7 +423,7 @@ decode_device(struct inode *ino, struct pnfs_device *pdev) | |||
| 423 | 423 | ||
| 424 | dsaddr = kzalloc(sizeof(*dsaddr) + | 424 | dsaddr = kzalloc(sizeof(*dsaddr) + |
| 425 | (sizeof(struct nfs4_pnfs_ds *) * (num - 1)), | 425 | (sizeof(struct nfs4_pnfs_ds *) * (num - 1)), |
| 426 | GFP_KERNEL); | 426 | gfp_flags); |
| 427 | if (!dsaddr) | 427 | if (!dsaddr) |
| 428 | goto out_err_free_stripe_indices; | 428 | goto out_err_free_stripe_indices; |
| 429 | 429 | ||
| @@ -452,7 +452,7 @@ decode_device(struct inode *ino, struct pnfs_device *pdev) | |||
| 452 | for (j = 0; j < mp_count; j++) { | 452 | for (j = 0; j < mp_count; j++) { |
| 453 | if (j == 0) { | 453 | if (j == 0) { |
| 454 | dsaddr->ds_list[i] = decode_and_add_ds(&stream, | 454 | dsaddr->ds_list[i] = decode_and_add_ds(&stream, |
| 455 | ino); | 455 | ino, gfp_flags); |
| 456 | if (dsaddr->ds_list[i] == NULL) | 456 | if (dsaddr->ds_list[i] == NULL) |
| 457 | goto out_err_free_deviceid; | 457 | goto out_err_free_deviceid; |
| 458 | } else { | 458 | } else { |
| @@ -503,12 +503,12 @@ out_err: | |||
| 503 | * available devices. | 503 | * available devices. |
| 504 | */ | 504 | */ |
| 505 | static struct nfs4_file_layout_dsaddr * | 505 | static struct nfs4_file_layout_dsaddr * |
| 506 | decode_and_add_device(struct inode *inode, struct pnfs_device *dev) | 506 | decode_and_add_device(struct inode *inode, struct pnfs_device *dev, gfp_t gfp_flags) |
| 507 | { | 507 | { |
| 508 | struct nfs4_file_layout_dsaddr *d, *new; | 508 | struct nfs4_file_layout_dsaddr *d, *new; |
| 509 | long hash; | 509 | long hash; |
| 510 | 510 | ||
| 511 | new = decode_device(inode, dev); | 511 | new = decode_device(inode, dev, gfp_flags); |
| 512 | if (!new) { | 512 | if (!new) { |
| 513 | printk(KERN_WARNING "%s: Could not decode or add device\n", | 513 | printk(KERN_WARNING "%s: Could not decode or add device\n", |
| 514 | __func__); | 514 | __func__); |
| @@ -537,7 +537,7 @@ decode_and_add_device(struct inode *inode, struct pnfs_device *dev) | |||
| 537 | * of available devices, and return it. | 537 | * of available devices, and return it. |
| 538 | */ | 538 | */ |
| 539 | struct nfs4_file_layout_dsaddr * | 539 | struct nfs4_file_layout_dsaddr * |
| 540 | get_device_info(struct inode *inode, struct nfs4_deviceid *dev_id) | 540 | get_device_info(struct inode *inode, struct nfs4_deviceid *dev_id, gfp_t gfp_flags) |
| 541 | { | 541 | { |
| 542 | struct pnfs_device *pdev = NULL; | 542 | struct pnfs_device *pdev = NULL; |
| 543 | u32 max_resp_sz; | 543 | u32 max_resp_sz; |
| @@ -556,17 +556,17 @@ get_device_info(struct inode *inode, struct nfs4_deviceid *dev_id) | |||
| 556 | dprintk("%s inode %p max_resp_sz %u max_pages %d\n", | 556 | dprintk("%s inode %p max_resp_sz %u max_pages %d\n", |
| 557 | __func__, inode, max_resp_sz, max_pages); | 557 | __func__, inode, max_resp_sz, max_pages); |
| 558 | 558 | ||
| 559 | pdev = kzalloc(sizeof(struct pnfs_device), GFP_KERNEL); | 559 | pdev = kzalloc(sizeof(struct pnfs_device), gfp_flags); |
| 560 | if (pdev == NULL) | 560 | if (pdev == NULL) |
| 561 | return NULL; | 561 | return NULL; |
| 562 | 562 | ||
| 563 | pages = kzalloc(max_pages * sizeof(struct page *), GFP_KERNEL); | 563 | pages = kzalloc(max_pages * sizeof(struct page *), gfp_flags); |
| 564 | if (pages == NULL) { | 564 | if (pages == NULL) { |
| 565 | kfree(pdev); | 565 | kfree(pdev); |
| 566 | return NULL; | 566 | return NULL; |
| 567 | } | 567 | } |
| 568 | for (i = 0; i < max_pages; i++) { | 568 | for (i = 0; i < max_pages; i++) { |
| 569 | pages[i] = alloc_page(GFP_KERNEL); | 569 | pages[i] = alloc_page(gfp_flags); |
| 570 | if (!pages[i]) | 570 | if (!pages[i]) |
| 571 | goto out_free; | 571 | goto out_free; |
| 572 | } | 572 | } |
| @@ -587,7 +587,7 @@ get_device_info(struct inode *inode, struct nfs4_deviceid *dev_id) | |||
| 587 | * Found new device, need to decode it and then add it to the | 587 | * Found new device, need to decode it and then add it to the |
| 588 | * list of known devices for this mountpoint. | 588 | * list of known devices for this mountpoint. |
| 589 | */ | 589 | */ |
| 590 | dsaddr = decode_and_add_device(inode, pdev); | 590 | dsaddr = decode_and_add_device(inode, pdev, gfp_flags); |
| 591 | out_free: | 591 | out_free: |
| 592 | for (i = 0; i < max_pages; i++) | 592 | for (i = 0; i < max_pages; i++) |
| 593 | __free_page(pages[i]); | 593 | __free_page(pages[i]); |
diff --git a/fs/nfs/nfs4proc.c b/fs/nfs/nfs4proc.c index 69c0f3c5ee7a..cf1b339c3937 100644 --- a/fs/nfs/nfs4proc.c +++ b/fs/nfs/nfs4proc.c | |||
| @@ -300,6 +300,7 @@ static int nfs4_handle_exception(struct nfs_server *server, int errorcode, struc | |||
| 300 | ret = nfs4_delay(server->client, &exception->timeout); | 300 | ret = nfs4_delay(server->client, &exception->timeout); |
| 301 | if (ret != 0) | 301 | if (ret != 0) |
| 302 | break; | 302 | break; |
| 303 | case -NFS4ERR_RETRY_UNCACHED_REP: | ||
| 303 | case -NFS4ERR_OLD_STATEID: | 304 | case -NFS4ERR_OLD_STATEID: |
| 304 | exception->retry = 1; | 305 | exception->retry = 1; |
| 305 | break; | 306 | break; |
| @@ -3695,6 +3696,7 @@ nfs4_async_handle_error(struct rpc_task *task, const struct nfs_server *server, | |||
| 3695 | rpc_delay(task, NFS4_POLL_RETRY_MAX); | 3696 | rpc_delay(task, NFS4_POLL_RETRY_MAX); |
| 3696 | task->tk_status = 0; | 3697 | task->tk_status = 0; |
| 3697 | return -EAGAIN; | 3698 | return -EAGAIN; |
| 3699 | case -NFS4ERR_RETRY_UNCACHED_REP: | ||
| 3698 | case -NFS4ERR_OLD_STATEID: | 3700 | case -NFS4ERR_OLD_STATEID: |
| 3699 | task->tk_status = 0; | 3701 | task->tk_status = 0; |
| 3700 | return -EAGAIN; | 3702 | return -EAGAIN; |
| @@ -4844,6 +4846,8 @@ static void nfs4_get_lease_time_done(struct rpc_task *task, void *calldata) | |||
| 4844 | dprintk("%s Retry: tk_status %d\n", __func__, task->tk_status); | 4846 | dprintk("%s Retry: tk_status %d\n", __func__, task->tk_status); |
| 4845 | rpc_delay(task, NFS4_POLL_RETRY_MIN); | 4847 | rpc_delay(task, NFS4_POLL_RETRY_MIN); |
| 4846 | task->tk_status = 0; | 4848 | task->tk_status = 0; |
| 4849 | /* fall through */ | ||
| 4850 | case -NFS4ERR_RETRY_UNCACHED_REP: | ||
| 4847 | nfs_restart_rpc(task, data->clp); | 4851 | nfs_restart_rpc(task, data->clp); |
| 4848 | return; | 4852 | return; |
| 4849 | } | 4853 | } |
| @@ -5479,6 +5483,8 @@ static int nfs41_reclaim_complete_handle_errors(struct rpc_task *task, struct nf | |||
| 5479 | break; | 5483 | break; |
| 5480 | case -NFS4ERR_DELAY: | 5484 | case -NFS4ERR_DELAY: |
| 5481 | rpc_delay(task, NFS4_POLL_RETRY_MAX); | 5485 | rpc_delay(task, NFS4_POLL_RETRY_MAX); |
| 5486 | /* fall through */ | ||
| 5487 | case -NFS4ERR_RETRY_UNCACHED_REP: | ||
| 5482 | return -EAGAIN; | 5488 | return -EAGAIN; |
| 5483 | default: | 5489 | default: |
| 5484 | nfs4_schedule_lease_recovery(clp); | 5490 | nfs4_schedule_lease_recovery(clp); |
diff --git a/fs/nfs/pnfs.c b/fs/nfs/pnfs.c index ff681ab65d31..f57f5281a520 100644 --- a/fs/nfs/pnfs.c +++ b/fs/nfs/pnfs.c | |||
| @@ -383,6 +383,7 @@ pnfs_destroy_all_layouts(struct nfs_client *clp) | |||
| 383 | plh_layouts); | 383 | plh_layouts); |
| 384 | dprintk("%s freeing layout for inode %lu\n", __func__, | 384 | dprintk("%s freeing layout for inode %lu\n", __func__, |
| 385 | lo->plh_inode->i_ino); | 385 | lo->plh_inode->i_ino); |
| 386 | list_del_init(&lo->plh_layouts); | ||
| 386 | pnfs_destroy_layout(NFS_I(lo->plh_inode)); | 387 | pnfs_destroy_layout(NFS_I(lo->plh_inode)); |
| 387 | } | 388 | } |
| 388 | } | 389 | } |
| @@ -466,7 +467,8 @@ pnfs_choose_layoutget_stateid(nfs4_stateid *dst, struct pnfs_layout_hdr *lo, | |||
| 466 | static struct pnfs_layout_segment * | 467 | static struct pnfs_layout_segment * |
| 467 | send_layoutget(struct pnfs_layout_hdr *lo, | 468 | send_layoutget(struct pnfs_layout_hdr *lo, |
| 468 | struct nfs_open_context *ctx, | 469 | struct nfs_open_context *ctx, |
| 469 | u32 iomode) | 470 | u32 iomode, |
| 471 | gfp_t gfp_flags) | ||
| 470 | { | 472 | { |
| 471 | struct inode *ino = lo->plh_inode; | 473 | struct inode *ino = lo->plh_inode; |
| 472 | struct nfs_server *server = NFS_SERVER(ino); | 474 | struct nfs_server *server = NFS_SERVER(ino); |
| @@ -479,7 +481,7 @@ send_layoutget(struct pnfs_layout_hdr *lo, | |||
| 479 | dprintk("--> %s\n", __func__); | 481 | dprintk("--> %s\n", __func__); |
| 480 | 482 | ||
| 481 | BUG_ON(ctx == NULL); | 483 | BUG_ON(ctx == NULL); |
| 482 | lgp = kzalloc(sizeof(*lgp), GFP_KERNEL); | 484 | lgp = kzalloc(sizeof(*lgp), gfp_flags); |
| 483 | if (lgp == NULL) | 485 | if (lgp == NULL) |
| 484 | return NULL; | 486 | return NULL; |
| 485 | 487 | ||
| @@ -487,12 +489,12 @@ send_layoutget(struct pnfs_layout_hdr *lo, | |||
| 487 | max_resp_sz = server->nfs_client->cl_session->fc_attrs.max_resp_sz; | 489 | max_resp_sz = server->nfs_client->cl_session->fc_attrs.max_resp_sz; |
| 488 | max_pages = max_resp_sz >> PAGE_SHIFT; | 490 | max_pages = max_resp_sz >> PAGE_SHIFT; |
| 489 | 491 | ||
| 490 | pages = kzalloc(max_pages * sizeof(struct page *), GFP_KERNEL); | 492 | pages = kzalloc(max_pages * sizeof(struct page *), gfp_flags); |
| 491 | if (!pages) | 493 | if (!pages) |
| 492 | goto out_err_free; | 494 | goto out_err_free; |
| 493 | 495 | ||
| 494 | for (i = 0; i < max_pages; i++) { | 496 | for (i = 0; i < max_pages; i++) { |
| 495 | pages[i] = alloc_page(GFP_KERNEL); | 497 | pages[i] = alloc_page(gfp_flags); |
| 496 | if (!pages[i]) | 498 | if (!pages[i]) |
| 497 | goto out_err_free; | 499 | goto out_err_free; |
| 498 | } | 500 | } |
| @@ -508,6 +510,7 @@ send_layoutget(struct pnfs_layout_hdr *lo, | |||
| 508 | lgp->args.layout.pages = pages; | 510 | lgp->args.layout.pages = pages; |
| 509 | lgp->args.layout.pglen = max_pages * PAGE_SIZE; | 511 | lgp->args.layout.pglen = max_pages * PAGE_SIZE; |
| 510 | lgp->lsegpp = &lseg; | 512 | lgp->lsegpp = &lseg; |
| 513 | lgp->gfp_flags = gfp_flags; | ||
| 511 | 514 | ||
| 512 | /* Synchronously retrieve layout information from server and | 515 | /* Synchronously retrieve layout information from server and |
| 513 | * store in lseg. | 516 | * store in lseg. |
| @@ -665,11 +668,11 @@ pnfs_insert_layout(struct pnfs_layout_hdr *lo, | |||
| 665 | } | 668 | } |
| 666 | 669 | ||
| 667 | static struct pnfs_layout_hdr * | 670 | static struct pnfs_layout_hdr * |
| 668 | alloc_init_layout_hdr(struct inode *ino) | 671 | alloc_init_layout_hdr(struct inode *ino, gfp_t gfp_flags) |
| 669 | { | 672 | { |
| 670 | struct pnfs_layout_hdr *lo; | 673 | struct pnfs_layout_hdr *lo; |
| 671 | 674 | ||
| 672 | lo = kzalloc(sizeof(struct pnfs_layout_hdr), GFP_KERNEL); | 675 | lo = kzalloc(sizeof(struct pnfs_layout_hdr), gfp_flags); |
| 673 | if (!lo) | 676 | if (!lo) |
| 674 | return NULL; | 677 | return NULL; |
| 675 | atomic_set(&lo->plh_refcount, 1); | 678 | atomic_set(&lo->plh_refcount, 1); |
| @@ -681,7 +684,7 @@ alloc_init_layout_hdr(struct inode *ino) | |||
| 681 | } | 684 | } |
| 682 | 685 | ||
| 683 | static struct pnfs_layout_hdr * | 686 | static struct pnfs_layout_hdr * |
| 684 | pnfs_find_alloc_layout(struct inode *ino) | 687 | pnfs_find_alloc_layout(struct inode *ino, gfp_t gfp_flags) |
| 685 | { | 688 | { |
| 686 | struct nfs_inode *nfsi = NFS_I(ino); | 689 | struct nfs_inode *nfsi = NFS_I(ino); |
| 687 | struct pnfs_layout_hdr *new = NULL; | 690 | struct pnfs_layout_hdr *new = NULL; |
| @@ -696,7 +699,7 @@ pnfs_find_alloc_layout(struct inode *ino) | |||
| 696 | return nfsi->layout; | 699 | return nfsi->layout; |
| 697 | } | 700 | } |
| 698 | spin_unlock(&ino->i_lock); | 701 | spin_unlock(&ino->i_lock); |
| 699 | new = alloc_init_layout_hdr(ino); | 702 | new = alloc_init_layout_hdr(ino, gfp_flags); |
| 700 | spin_lock(&ino->i_lock); | 703 | spin_lock(&ino->i_lock); |
| 701 | 704 | ||
| 702 | if (likely(nfsi->layout == NULL)) /* Won the race? */ | 705 | if (likely(nfsi->layout == NULL)) /* Won the race? */ |
| @@ -756,7 +759,8 @@ pnfs_find_lseg(struct pnfs_layout_hdr *lo, u32 iomode) | |||
| 756 | struct pnfs_layout_segment * | 759 | struct pnfs_layout_segment * |
| 757 | pnfs_update_layout(struct inode *ino, | 760 | pnfs_update_layout(struct inode *ino, |
| 758 | struct nfs_open_context *ctx, | 761 | struct nfs_open_context *ctx, |
| 759 | enum pnfs_iomode iomode) | 762 | enum pnfs_iomode iomode, |
| 763 | gfp_t gfp_flags) | ||
| 760 | { | 764 | { |
| 761 | struct nfs_inode *nfsi = NFS_I(ino); | 765 | struct nfs_inode *nfsi = NFS_I(ino); |
| 762 | struct nfs_client *clp = NFS_SERVER(ino)->nfs_client; | 766 | struct nfs_client *clp = NFS_SERVER(ino)->nfs_client; |
| @@ -767,7 +771,7 @@ pnfs_update_layout(struct inode *ino, | |||
| 767 | if (!pnfs_enabled_sb(NFS_SERVER(ino))) | 771 | if (!pnfs_enabled_sb(NFS_SERVER(ino))) |
| 768 | return NULL; | 772 | return NULL; |
| 769 | spin_lock(&ino->i_lock); | 773 | spin_lock(&ino->i_lock); |
| 770 | lo = pnfs_find_alloc_layout(ino); | 774 | lo = pnfs_find_alloc_layout(ino, gfp_flags); |
| 771 | if (lo == NULL) { | 775 | if (lo == NULL) { |
| 772 | dprintk("%s ERROR: can't get pnfs_layout_hdr\n", __func__); | 776 | dprintk("%s ERROR: can't get pnfs_layout_hdr\n", __func__); |
| 773 | goto out_unlock; | 777 | goto out_unlock; |
| @@ -807,7 +811,7 @@ pnfs_update_layout(struct inode *ino, | |||
| 807 | spin_unlock(&clp->cl_lock); | 811 | spin_unlock(&clp->cl_lock); |
| 808 | } | 812 | } |
| 809 | 813 | ||
| 810 | lseg = send_layoutget(lo, ctx, iomode); | 814 | lseg = send_layoutget(lo, ctx, iomode, gfp_flags); |
| 811 | if (!lseg && first) { | 815 | if (!lseg && first) { |
| 812 | spin_lock(&clp->cl_lock); | 816 | spin_lock(&clp->cl_lock); |
| 813 | list_del_init(&lo->plh_layouts); | 817 | list_del_init(&lo->plh_layouts); |
| @@ -846,7 +850,7 @@ pnfs_layout_process(struct nfs4_layoutget *lgp) | |||
| 846 | goto out; | 850 | goto out; |
| 847 | } | 851 | } |
| 848 | /* Inject layout blob into I/O device driver */ | 852 | /* Inject layout blob into I/O device driver */ |
| 849 | lseg = NFS_SERVER(ino)->pnfs_curr_ld->alloc_lseg(lo, res); | 853 | lseg = NFS_SERVER(ino)->pnfs_curr_ld->alloc_lseg(lo, res, lgp->gfp_flags); |
| 850 | if (!lseg || IS_ERR(lseg)) { | 854 | if (!lseg || IS_ERR(lseg)) { |
| 851 | if (!lseg) | 855 | if (!lseg) |
| 852 | status = -ENOMEM; | 856 | status = -ENOMEM; |
| @@ -899,7 +903,8 @@ static int pnfs_read_pg_test(struct nfs_pageio_descriptor *pgio, | |||
| 899 | /* This is first coelesce call for a series of nfs_pages */ | 903 | /* This is first coelesce call for a series of nfs_pages */ |
| 900 | pgio->pg_lseg = pnfs_update_layout(pgio->pg_inode, | 904 | pgio->pg_lseg = pnfs_update_layout(pgio->pg_inode, |
| 901 | prev->wb_context, | 905 | prev->wb_context, |
| 902 | IOMODE_READ); | 906 | IOMODE_READ, |
| 907 | GFP_KERNEL); | ||
| 903 | } | 908 | } |
| 904 | return NFS_SERVER(pgio->pg_inode)->pnfs_curr_ld->pg_test(pgio, prev, req); | 909 | return NFS_SERVER(pgio->pg_inode)->pnfs_curr_ld->pg_test(pgio, prev, req); |
| 905 | } | 910 | } |
| @@ -921,7 +926,8 @@ static int pnfs_write_pg_test(struct nfs_pageio_descriptor *pgio, | |||
| 921 | /* This is first coelesce call for a series of nfs_pages */ | 926 | /* This is first coelesce call for a series of nfs_pages */ |
| 922 | pgio->pg_lseg = pnfs_update_layout(pgio->pg_inode, | 927 | pgio->pg_lseg = pnfs_update_layout(pgio->pg_inode, |
| 923 | prev->wb_context, | 928 | prev->wb_context, |
| 924 | IOMODE_RW); | 929 | IOMODE_RW, |
| 930 | GFP_NOFS); | ||
| 925 | } | 931 | } |
| 926 | return NFS_SERVER(pgio->pg_inode)->pnfs_curr_ld->pg_test(pgio, prev, req); | 932 | return NFS_SERVER(pgio->pg_inode)->pnfs_curr_ld->pg_test(pgio, prev, req); |
| 927 | } | 933 | } |
diff --git a/fs/nfs/pnfs.h b/fs/nfs/pnfs.h index bc4827202e7a..0c015bad9e7a 100644 --- a/fs/nfs/pnfs.h +++ b/fs/nfs/pnfs.h | |||
| @@ -70,7 +70,7 @@ struct pnfs_layoutdriver_type { | |||
| 70 | const u32 id; | 70 | const u32 id; |
| 71 | const char *name; | 71 | const char *name; |
| 72 | struct module *owner; | 72 | struct module *owner; |
| 73 | struct pnfs_layout_segment * (*alloc_lseg) (struct pnfs_layout_hdr *layoutid, struct nfs4_layoutget_res *lgr); | 73 | struct pnfs_layout_segment * (*alloc_lseg) (struct pnfs_layout_hdr *layoutid, struct nfs4_layoutget_res *lgr, gfp_t gfp_flags); |
| 74 | void (*free_lseg) (struct pnfs_layout_segment *lseg); | 74 | void (*free_lseg) (struct pnfs_layout_segment *lseg); |
| 75 | 75 | ||
| 76 | /* test for nfs page cache coalescing */ | 76 | /* test for nfs page cache coalescing */ |
| @@ -126,7 +126,7 @@ void get_layout_hdr(struct pnfs_layout_hdr *lo); | |||
| 126 | void put_lseg(struct pnfs_layout_segment *lseg); | 126 | void put_lseg(struct pnfs_layout_segment *lseg); |
| 127 | struct pnfs_layout_segment * | 127 | struct pnfs_layout_segment * |
| 128 | pnfs_update_layout(struct inode *ino, struct nfs_open_context *ctx, | 128 | pnfs_update_layout(struct inode *ino, struct nfs_open_context *ctx, |
| 129 | enum pnfs_iomode access_type); | 129 | enum pnfs_iomode access_type, gfp_t gfp_flags); |
| 130 | void set_pnfs_layoutdriver(struct nfs_server *, u32 id); | 130 | void set_pnfs_layoutdriver(struct nfs_server *, u32 id); |
| 131 | void unset_pnfs_layoutdriver(struct nfs_server *); | 131 | void unset_pnfs_layoutdriver(struct nfs_server *); |
| 132 | enum pnfs_try_status pnfs_try_to_write_data(struct nfs_write_data *, | 132 | enum pnfs_try_status pnfs_try_to_write_data(struct nfs_write_data *, |
| @@ -245,7 +245,7 @@ static inline void put_lseg(struct pnfs_layout_segment *lseg) | |||
| 245 | 245 | ||
| 246 | static inline struct pnfs_layout_segment * | 246 | static inline struct pnfs_layout_segment * |
| 247 | pnfs_update_layout(struct inode *ino, struct nfs_open_context *ctx, | 247 | pnfs_update_layout(struct inode *ino, struct nfs_open_context *ctx, |
| 248 | enum pnfs_iomode access_type) | 248 | enum pnfs_iomode access_type, gfp_t gfp_flags) |
| 249 | { | 249 | { |
| 250 | return NULL; | 250 | return NULL; |
| 251 | } | 251 | } |
diff --git a/fs/nfs/read.c b/fs/nfs/read.c index 7cded2b12a05..2bcf0dc306a1 100644 --- a/fs/nfs/read.c +++ b/fs/nfs/read.c | |||
| @@ -288,7 +288,7 @@ static int nfs_pagein_multi(struct nfs_pageio_descriptor *desc) | |||
| 288 | atomic_set(&req->wb_complete, requests); | 288 | atomic_set(&req->wb_complete, requests); |
| 289 | 289 | ||
| 290 | BUG_ON(desc->pg_lseg != NULL); | 290 | BUG_ON(desc->pg_lseg != NULL); |
| 291 | lseg = pnfs_update_layout(desc->pg_inode, req->wb_context, IOMODE_READ); | 291 | lseg = pnfs_update_layout(desc->pg_inode, req->wb_context, IOMODE_READ, GFP_KERNEL); |
| 292 | ClearPageError(page); | 292 | ClearPageError(page); |
| 293 | offset = 0; | 293 | offset = 0; |
| 294 | nbytes = desc->pg_count; | 294 | nbytes = desc->pg_count; |
| @@ -351,7 +351,7 @@ static int nfs_pagein_one(struct nfs_pageio_descriptor *desc) | |||
| 351 | } | 351 | } |
| 352 | req = nfs_list_entry(data->pages.next); | 352 | req = nfs_list_entry(data->pages.next); |
| 353 | if ((!lseg) && list_is_singular(&data->pages)) | 353 | if ((!lseg) && list_is_singular(&data->pages)) |
| 354 | lseg = pnfs_update_layout(desc->pg_inode, req->wb_context, IOMODE_READ); | 354 | lseg = pnfs_update_layout(desc->pg_inode, req->wb_context, IOMODE_READ, GFP_KERNEL); |
| 355 | 355 | ||
| 356 | ret = nfs_read_rpcsetup(req, data, &nfs_read_full_ops, desc->pg_count, | 356 | ret = nfs_read_rpcsetup(req, data, &nfs_read_full_ops, desc->pg_count, |
| 357 | 0, lseg); | 357 | 0, lseg); |
diff --git a/fs/nfs/write.c b/fs/nfs/write.c index 3bd5d7e80f6c..49c715b4ac92 100644 --- a/fs/nfs/write.c +++ b/fs/nfs/write.c | |||
| @@ -939,7 +939,7 @@ static int nfs_flush_multi(struct nfs_pageio_descriptor *desc) | |||
| 939 | atomic_set(&req->wb_complete, requests); | 939 | atomic_set(&req->wb_complete, requests); |
| 940 | 940 | ||
| 941 | BUG_ON(desc->pg_lseg); | 941 | BUG_ON(desc->pg_lseg); |
| 942 | lseg = pnfs_update_layout(desc->pg_inode, req->wb_context, IOMODE_RW); | 942 | lseg = pnfs_update_layout(desc->pg_inode, req->wb_context, IOMODE_RW, GFP_NOFS); |
| 943 | ClearPageError(page); | 943 | ClearPageError(page); |
| 944 | offset = 0; | 944 | offset = 0; |
| 945 | nbytes = desc->pg_count; | 945 | nbytes = desc->pg_count; |
| @@ -1013,7 +1013,7 @@ static int nfs_flush_one(struct nfs_pageio_descriptor *desc) | |||
| 1013 | } | 1013 | } |
| 1014 | req = nfs_list_entry(data->pages.next); | 1014 | req = nfs_list_entry(data->pages.next); |
| 1015 | if ((!lseg) && list_is_singular(&data->pages)) | 1015 | if ((!lseg) && list_is_singular(&data->pages)) |
| 1016 | lseg = pnfs_update_layout(desc->pg_inode, req->wb_context, IOMODE_RW); | 1016 | lseg = pnfs_update_layout(desc->pg_inode, req->wb_context, IOMODE_RW, GFP_NOFS); |
| 1017 | 1017 | ||
| 1018 | if ((desc->pg_ioflags & FLUSH_COND_STABLE) && | 1018 | if ((desc->pg_ioflags & FLUSH_COND_STABLE) && |
| 1019 | (desc->pg_moreio || NFS_I(desc->pg_inode)->ncommit)) | 1019 | (desc->pg_moreio || NFS_I(desc->pg_inode)->ncommit)) |
diff --git a/fs/nilfs2/alloc.c b/fs/nilfs2/alloc.c index 0a0a66d98cce..f7684483785e 100644 --- a/fs/nilfs2/alloc.c +++ b/fs/nilfs2/alloc.c | |||
| @@ -646,7 +646,7 @@ int nilfs_palloc_freev(struct inode *inode, __u64 *entry_nrs, size_t nitems) | |||
| 646 | unsigned long group, group_offset; | 646 | unsigned long group, group_offset; |
| 647 | int i, j, n, ret; | 647 | int i, j, n, ret; |
| 648 | 648 | ||
| 649 | for (i = 0; i < nitems; i += n) { | 649 | for (i = 0; i < nitems; i = j) { |
| 650 | group = nilfs_palloc_group(inode, entry_nrs[i], &group_offset); | 650 | group = nilfs_palloc_group(inode, entry_nrs[i], &group_offset); |
| 651 | ret = nilfs_palloc_get_desc_block(inode, group, 0, &desc_bh); | 651 | ret = nilfs_palloc_get_desc_block(inode, group, 0, &desc_bh); |
| 652 | if (ret < 0) | 652 | if (ret < 0) |
diff --git a/fs/xfs/linux-2.6/xfs_sync.c b/fs/xfs/linux-2.6/xfs_sync.c index e4f9c1b0836c..3e898a48122d 100644 --- a/fs/xfs/linux-2.6/xfs_sync.c +++ b/fs/xfs/linux-2.6/xfs_sync.c | |||
| @@ -926,6 +926,7 @@ restart: | |||
| 926 | XFS_LOOKUP_BATCH, | 926 | XFS_LOOKUP_BATCH, |
| 927 | XFS_ICI_RECLAIM_TAG); | 927 | XFS_ICI_RECLAIM_TAG); |
| 928 | if (!nr_found) { | 928 | if (!nr_found) { |
| 929 | done = 1; | ||
| 929 | rcu_read_unlock(); | 930 | rcu_read_unlock(); |
| 930 | break; | 931 | break; |
| 931 | } | 932 | } |
diff --git a/fs/xfs/xfs_trans_ail.c b/fs/xfs/xfs_trans_ail.c index acdb92f14d51..5fc2380092c8 100644 --- a/fs/xfs/xfs_trans_ail.c +++ b/fs/xfs/xfs_trans_ail.c | |||
| @@ -346,20 +346,23 @@ xfs_ail_delete( | |||
| 346 | */ | 346 | */ |
| 347 | STATIC void | 347 | STATIC void |
| 348 | xfs_ail_worker( | 348 | xfs_ail_worker( |
| 349 | struct work_struct *work) | 349 | struct work_struct *work) |
| 350 | { | 350 | { |
| 351 | struct xfs_ail *ailp = container_of(to_delayed_work(work), | 351 | struct xfs_ail *ailp = container_of(to_delayed_work(work), |
| 352 | struct xfs_ail, xa_work); | 352 | struct xfs_ail, xa_work); |
| 353 | long tout; | 353 | xfs_mount_t *mp = ailp->xa_mount; |
| 354 | xfs_lsn_t target = ailp->xa_target; | ||
| 355 | xfs_lsn_t lsn; | ||
| 356 | xfs_log_item_t *lip; | ||
| 357 | int flush_log, count, stuck; | ||
| 358 | xfs_mount_t *mp = ailp->xa_mount; | ||
| 359 | struct xfs_ail_cursor *cur = &ailp->xa_cursors; | 354 | struct xfs_ail_cursor *cur = &ailp->xa_cursors; |
| 360 | int push_xfsbufd = 0; | 355 | xfs_log_item_t *lip; |
| 356 | xfs_lsn_t lsn; | ||
| 357 | xfs_lsn_t target; | ||
| 358 | long tout = 10; | ||
| 359 | int flush_log = 0; | ||
| 360 | int stuck = 0; | ||
| 361 | int count = 0; | ||
| 362 | int push_xfsbufd = 0; | ||
| 361 | 363 | ||
| 362 | spin_lock(&ailp->xa_lock); | 364 | spin_lock(&ailp->xa_lock); |
| 365 | target = ailp->xa_target; | ||
| 363 | xfs_trans_ail_cursor_init(ailp, cur); | 366 | xfs_trans_ail_cursor_init(ailp, cur); |
| 364 | lip = xfs_trans_ail_cursor_first(ailp, cur, ailp->xa_last_pushed_lsn); | 367 | lip = xfs_trans_ail_cursor_first(ailp, cur, ailp->xa_last_pushed_lsn); |
| 365 | if (!lip || XFS_FORCED_SHUTDOWN(mp)) { | 368 | if (!lip || XFS_FORCED_SHUTDOWN(mp)) { |
| @@ -368,8 +371,7 @@ xfs_ail_worker( | |||
| 368 | */ | 371 | */ |
| 369 | xfs_trans_ail_cursor_done(ailp, cur); | 372 | xfs_trans_ail_cursor_done(ailp, cur); |
| 370 | spin_unlock(&ailp->xa_lock); | 373 | spin_unlock(&ailp->xa_lock); |
| 371 | ailp->xa_last_pushed_lsn = 0; | 374 | goto out_done; |
| 372 | return; | ||
| 373 | } | 375 | } |
| 374 | 376 | ||
| 375 | XFS_STATS_INC(xs_push_ail); | 377 | XFS_STATS_INC(xs_push_ail); |
| @@ -386,8 +388,7 @@ xfs_ail_worker( | |||
| 386 | * lots of contention on the AIL lists. | 388 | * lots of contention on the AIL lists. |
| 387 | */ | 389 | */ |
| 388 | lsn = lip->li_lsn; | 390 | lsn = lip->li_lsn; |
| 389 | flush_log = stuck = count = 0; | 391 | while ((XFS_LSN_CMP(lip->li_lsn, target) <= 0)) { |
| 390 | while ((XFS_LSN_CMP(lip->li_lsn, target) < 0)) { | ||
| 391 | int lock_result; | 392 | int lock_result; |
| 392 | /* | 393 | /* |
| 393 | * If we can lock the item without sleeping, unlock the AIL | 394 | * If we can lock the item without sleeping, unlock the AIL |
| @@ -480,21 +481,25 @@ xfs_ail_worker( | |||
| 480 | } | 481 | } |
| 481 | 482 | ||
| 482 | /* assume we have more work to do in a short while */ | 483 | /* assume we have more work to do in a short while */ |
| 483 | tout = 10; | 484 | out_done: |
| 484 | if (!count) { | 485 | if (!count) { |
| 485 | /* We're past our target or empty, so idle */ | 486 | /* We're past our target or empty, so idle */ |
| 486 | ailp->xa_last_pushed_lsn = 0; | 487 | ailp->xa_last_pushed_lsn = 0; |
| 487 | 488 | ||
| 488 | /* | 489 | /* |
| 489 | * Check for an updated push target before clearing the | 490 | * We clear the XFS_AIL_PUSHING_BIT first before checking |
| 490 | * XFS_AIL_PUSHING_BIT. If the target changed, we've got more | 491 | * whether the target has changed. If the target has changed, |
| 491 | * work to do. Wait a bit longer before starting that work. | 492 | * this pushes the requeue race directly onto the result of the |
| 493 | * atomic test/set bit, so we are guaranteed that either the | ||
| 494 | * the pusher that changed the target or ourselves will requeue | ||
| 495 | * the work (but not both). | ||
| 492 | */ | 496 | */ |
| 497 | clear_bit(XFS_AIL_PUSHING_BIT, &ailp->xa_flags); | ||
| 493 | smp_rmb(); | 498 | smp_rmb(); |
| 494 | if (ailp->xa_target == target) { | 499 | if (XFS_LSN_CMP(ailp->xa_target, target) == 0 || |
| 495 | clear_bit(XFS_AIL_PUSHING_BIT, &ailp->xa_flags); | 500 | test_and_set_bit(XFS_AIL_PUSHING_BIT, &ailp->xa_flags)) |
| 496 | return; | 501 | return; |
| 497 | } | 502 | |
| 498 | tout = 50; | 503 | tout = 50; |
| 499 | } else if (XFS_LSN_CMP(lsn, target) >= 0) { | 504 | } else if (XFS_LSN_CMP(lsn, target) >= 0) { |
| 500 | /* | 505 | /* |
| @@ -553,7 +558,7 @@ xfs_ail_push( | |||
| 553 | * the XFS_AIL_PUSHING_BIT. | 558 | * the XFS_AIL_PUSHING_BIT. |
| 554 | */ | 559 | */ |
| 555 | smp_wmb(); | 560 | smp_wmb(); |
| 556 | ailp->xa_target = threshold_lsn; | 561 | xfs_trans_ail_copy_lsn(ailp, &ailp->xa_target, &threshold_lsn); |
| 557 | if (!test_and_set_bit(XFS_AIL_PUSHING_BIT, &ailp->xa_flags)) | 562 | if (!test_and_set_bit(XFS_AIL_PUSHING_BIT, &ailp->xa_flags)) |
| 558 | queue_delayed_work(xfs_syncd_wq, &ailp->xa_work, 0); | 563 | queue_delayed_work(xfs_syncd_wq, &ailp->xa_work, 0); |
| 559 | } | 564 | } |
diff --git a/include/drm/drm_fb_helper.h b/include/drm/drm_fb_helper.h index ade09d7b4271..c99c3d3e7811 100644 --- a/include/drm/drm_fb_helper.h +++ b/include/drm/drm_fb_helper.h | |||
| @@ -127,7 +127,7 @@ void drm_fb_helper_fill_fix(struct fb_info *info, uint32_t pitch, | |||
| 127 | 127 | ||
| 128 | int drm_fb_helper_setcmap(struct fb_cmap *cmap, struct fb_info *info); | 128 | int drm_fb_helper_setcmap(struct fb_cmap *cmap, struct fb_info *info); |
| 129 | 129 | ||
| 130 | bool drm_fb_helper_hotplug_event(struct drm_fb_helper *fb_helper); | 130 | int drm_fb_helper_hotplug_event(struct drm_fb_helper *fb_helper); |
| 131 | bool drm_fb_helper_initial_config(struct drm_fb_helper *fb_helper, int bpp_sel); | 131 | bool drm_fb_helper_initial_config(struct drm_fb_helper *fb_helper, int bpp_sel); |
| 132 | int drm_fb_helper_single_add_all_connectors(struct drm_fb_helper *fb_helper); | 132 | int drm_fb_helper_single_add_all_connectors(struct drm_fb_helper *fb_helper); |
| 133 | int drm_fb_helper_debug_enter(struct fb_info *info); | 133 | int drm_fb_helper_debug_enter(struct fb_info *info); |
diff --git a/include/linux/bootmem.h b/include/linux/bootmem.h index b8613e806aa9..01eca1794e14 100644 --- a/include/linux/bootmem.h +++ b/include/linux/bootmem.h | |||
| @@ -111,6 +111,8 @@ extern void *__alloc_bootmem_low_node(pg_data_t *pgdat, | |||
| 111 | __alloc_bootmem_nopanic(x, PAGE_SIZE, __pa(MAX_DMA_ADDRESS)) | 111 | __alloc_bootmem_nopanic(x, PAGE_SIZE, __pa(MAX_DMA_ADDRESS)) |
| 112 | #define alloc_bootmem_node(pgdat, x) \ | 112 | #define alloc_bootmem_node(pgdat, x) \ |
| 113 | __alloc_bootmem_node(pgdat, x, SMP_CACHE_BYTES, __pa(MAX_DMA_ADDRESS)) | 113 | __alloc_bootmem_node(pgdat, x, SMP_CACHE_BYTES, __pa(MAX_DMA_ADDRESS)) |
| 114 | #define alloc_bootmem_node_nopanic(pgdat, x) \ | ||
| 115 | __alloc_bootmem_node_nopanic(pgdat, x, SMP_CACHE_BYTES, __pa(MAX_DMA_ADDRESS)) | ||
| 114 | #define alloc_bootmem_pages_node(pgdat, x) \ | 116 | #define alloc_bootmem_pages_node(pgdat, x) \ |
| 115 | __alloc_bootmem_node(pgdat, x, PAGE_SIZE, __pa(MAX_DMA_ADDRESS)) | 117 | __alloc_bootmem_node(pgdat, x, PAGE_SIZE, __pa(MAX_DMA_ADDRESS)) |
| 116 | #define alloc_bootmem_pages_node_nopanic(pgdat, x) \ | 118 | #define alloc_bootmem_pages_node_nopanic(pgdat, x) \ |
diff --git a/include/linux/capability.h b/include/linux/capability.h index 16ee8b49a200..d4675af963fa 100644 --- a/include/linux/capability.h +++ b/include/linux/capability.h | |||
| @@ -546,18 +546,7 @@ extern bool has_capability_noaudit(struct task_struct *t, int cap); | |||
| 546 | extern bool capable(int cap); | 546 | extern bool capable(int cap); |
| 547 | extern bool ns_capable(struct user_namespace *ns, int cap); | 547 | extern bool ns_capable(struct user_namespace *ns, int cap); |
| 548 | extern bool task_ns_capable(struct task_struct *t, int cap); | 548 | extern bool task_ns_capable(struct task_struct *t, int cap); |
| 549 | 549 | extern bool nsown_capable(int cap); | |
| 550 | /** | ||
| 551 | * nsown_capable - Check superior capability to one's own user_ns | ||
| 552 | * @cap: The capability in question | ||
| 553 | * | ||
| 554 | * Return true if the current task has the given superior capability | ||
| 555 | * targeted at its own user namespace. | ||
| 556 | */ | ||
| 557 | static inline bool nsown_capable(int cap) | ||
| 558 | { | ||
| 559 | return ns_capable(current_user_ns(), cap); | ||
| 560 | } | ||
| 561 | 550 | ||
| 562 | /* audit system wants to get cap info from files as well */ | 551 | /* audit system wants to get cap info from files as well */ |
| 563 | extern int get_vfs_caps_from_disk(const struct dentry *dentry, struct cpu_vfs_cap_data *cpu_caps); | 552 | extern int get_vfs_caps_from_disk(const struct dentry *dentry, struct cpu_vfs_cap_data *cpu_caps); |
diff --git a/include/linux/cred.h b/include/linux/cred.h index 9aeeb0ba2003..be16b61283cc 100644 --- a/include/linux/cred.h +++ b/include/linux/cred.h | |||
| @@ -146,6 +146,7 @@ struct cred { | |||
| 146 | void *security; /* subjective LSM security */ | 146 | void *security; /* subjective LSM security */ |
| 147 | #endif | 147 | #endif |
| 148 | struct user_struct *user; /* real user ID subscription */ | 148 | struct user_struct *user; /* real user ID subscription */ |
| 149 | struct user_namespace *user_ns; /* cached user->user_ns */ | ||
| 149 | struct group_info *group_info; /* supplementary groups for euid/fsgid */ | 150 | struct group_info *group_info; /* supplementary groups for euid/fsgid */ |
| 150 | struct rcu_head rcu; /* RCU deletion hook */ | 151 | struct rcu_head rcu; /* RCU deletion hook */ |
| 151 | }; | 152 | }; |
| @@ -354,10 +355,15 @@ static inline void put_cred(const struct cred *_cred) | |||
| 354 | #define current_fsgid() (current_cred_xxx(fsgid)) | 355 | #define current_fsgid() (current_cred_xxx(fsgid)) |
| 355 | #define current_cap() (current_cred_xxx(cap_effective)) | 356 | #define current_cap() (current_cred_xxx(cap_effective)) |
| 356 | #define current_user() (current_cred_xxx(user)) | 357 | #define current_user() (current_cred_xxx(user)) |
| 357 | #define _current_user_ns() (current_cred_xxx(user)->user_ns) | ||
| 358 | #define current_security() (current_cred_xxx(security)) | 358 | #define current_security() (current_cred_xxx(security)) |
| 359 | 359 | ||
| 360 | extern struct user_namespace *current_user_ns(void); | 360 | #ifdef CONFIG_USER_NS |
| 361 | #define current_user_ns() (current_cred_xxx(user_ns)) | ||
| 362 | #else | ||
| 363 | extern struct user_namespace init_user_ns; | ||
| 364 | #define current_user_ns() (&init_user_ns) | ||
| 365 | #endif | ||
| 366 | |||
| 361 | 367 | ||
| 362 | #define current_uid_gid(_uid, _gid) \ | 368 | #define current_uid_gid(_uid, _gid) \ |
| 363 | do { \ | 369 | do { \ |
diff --git a/include/linux/fb.h b/include/linux/fb.h index df728c1c29ed..6a8274877171 100644 --- a/include/linux/fb.h +++ b/include/linux/fb.h | |||
| @@ -832,6 +832,7 @@ struct fb_tile_ops { | |||
| 832 | #define FBINFO_CAN_FORCE_OUTPUT 0x200000 | 832 | #define FBINFO_CAN_FORCE_OUTPUT 0x200000 |
| 833 | 833 | ||
| 834 | struct fb_info { | 834 | struct fb_info { |
| 835 | atomic_t count; | ||
| 835 | int node; | 836 | int node; |
| 836 | int flags; | 837 | int flags; |
| 837 | struct mutex lock; /* Lock for open/release/ioctl funcs */ | 838 | struct mutex lock; /* Lock for open/release/ioctl funcs */ |
diff --git a/include/linux/fs.h b/include/linux/fs.h index dbd860af0804..cdf9495df204 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h | |||
| @@ -358,7 +358,6 @@ struct inodes_stat_t { | |||
| 358 | #define FS_EXTENT_FL 0x00080000 /* Extents */ | 358 | #define FS_EXTENT_FL 0x00080000 /* Extents */ |
| 359 | #define FS_DIRECTIO_FL 0x00100000 /* Use direct i/o */ | 359 | #define FS_DIRECTIO_FL 0x00100000 /* Use direct i/o */ |
| 360 | #define FS_NOCOW_FL 0x00800000 /* Do not cow file */ | 360 | #define FS_NOCOW_FL 0x00800000 /* Do not cow file */ |
| 361 | #define FS_COW_FL 0x02000000 /* Cow file */ | ||
| 362 | #define FS_RESERVED_FL 0x80000000 /* reserved for ext2 lib */ | 361 | #define FS_RESERVED_FL 0x80000000 /* reserved for ext2 lib */ |
| 363 | 362 | ||
| 364 | #define FS_FL_USER_VISIBLE 0x0003DFFF /* User visible flags */ | 363 | #define FS_FL_USER_VISIBLE 0x0003DFFF /* User visible flags */ |
diff --git a/include/linux/gfp.h b/include/linux/gfp.h index bfb8f934521e..56d8fc87fbbc 100644 --- a/include/linux/gfp.h +++ b/include/linux/gfp.h | |||
| @@ -353,6 +353,8 @@ extern unsigned long get_zeroed_page(gfp_t gfp_mask); | |||
| 353 | 353 | ||
| 354 | void *alloc_pages_exact(size_t size, gfp_t gfp_mask); | 354 | void *alloc_pages_exact(size_t size, gfp_t gfp_mask); |
| 355 | void free_pages_exact(void *virt, size_t size); | 355 | void free_pages_exact(void *virt, size_t size); |
| 356 | /* This is different from alloc_pages_exact_node !!! */ | ||
| 357 | void *alloc_pages_exact_nid(int nid, size_t size, gfp_t gfp_mask); | ||
| 356 | 358 | ||
| 357 | #define __get_free_page(gfp_mask) \ | 359 | #define __get_free_page(gfp_mask) \ |
| 358 | __get_free_pages((gfp_mask), 0) | 360 | __get_free_pages((gfp_mask), 0) |
diff --git a/include/linux/mmc/host.h b/include/linux/mmc/host.h index eb792cb6d745..bcb793ec7374 100644 --- a/include/linux/mmc/host.h +++ b/include/linux/mmc/host.h | |||
| @@ -183,6 +183,7 @@ struct mmc_host { | |||
| 183 | struct work_struct clk_gate_work; /* delayed clock gate */ | 183 | struct work_struct clk_gate_work; /* delayed clock gate */ |
| 184 | unsigned int clk_old; /* old clock value cache */ | 184 | unsigned int clk_old; /* old clock value cache */ |
| 185 | spinlock_t clk_lock; /* lock for clk fields */ | 185 | spinlock_t clk_lock; /* lock for clk fields */ |
| 186 | struct mutex clk_gate_mutex; /* mutex for clock gating */ | ||
| 186 | #endif | 187 | #endif |
| 187 | 188 | ||
| 188 | /* host specific block data */ | 189 | /* host specific block data */ |
diff --git a/include/linux/nfs_xdr.h b/include/linux/nfs_xdr.h index 890dce242639..7e371f7df9c4 100644 --- a/include/linux/nfs_xdr.h +++ b/include/linux/nfs_xdr.h | |||
| @@ -233,6 +233,7 @@ struct nfs4_layoutget { | |||
| 233 | struct nfs4_layoutget_args args; | 233 | struct nfs4_layoutget_args args; |
| 234 | struct nfs4_layoutget_res res; | 234 | struct nfs4_layoutget_res res; |
| 235 | struct pnfs_layout_segment **lsegpp; | 235 | struct pnfs_layout_segment **lsegpp; |
| 236 | gfp_t gfp_flags; | ||
| 236 | }; | 237 | }; |
| 237 | 238 | ||
| 238 | struct nfs4_getdeviceinfo_args { | 239 | struct nfs4_getdeviceinfo_args { |
diff --git a/include/linux/proc_fs.h b/include/linux/proc_fs.h index 838c1149251a..eaf4350c0f90 100644 --- a/include/linux/proc_fs.h +++ b/include/linux/proc_fs.h | |||
| @@ -208,6 +208,8 @@ static inline struct proc_dir_entry *proc_symlink(const char *name, | |||
| 208 | struct proc_dir_entry *parent,const char *dest) {return NULL;} | 208 | struct proc_dir_entry *parent,const char *dest) {return NULL;} |
| 209 | static inline struct proc_dir_entry *proc_mkdir(const char *name, | 209 | static inline struct proc_dir_entry *proc_mkdir(const char *name, |
| 210 | struct proc_dir_entry *parent) {return NULL;} | 210 | struct proc_dir_entry *parent) {return NULL;} |
| 211 | static inline struct proc_dir_entry *proc_mkdir_mode(const char *name, | ||
| 212 | mode_t mode, struct proc_dir_entry *parent) { return NULL; } | ||
| 211 | 213 | ||
| 212 | static inline struct proc_dir_entry *create_proc_read_entry(const char *name, | 214 | static inline struct proc_dir_entry *create_proc_read_entry(const char *name, |
| 213 | mode_t mode, struct proc_dir_entry *base, | 215 | mode_t mode, struct proc_dir_entry *base, |
diff --git a/include/net/inet_ecn.h b/include/net/inet_ecn.h index 88bdd010d65d..2fa8d1341a0a 100644 --- a/include/net/inet_ecn.h +++ b/include/net/inet_ecn.h | |||
| @@ -38,9 +38,19 @@ static inline __u8 INET_ECN_encapsulate(__u8 outer, __u8 inner) | |||
| 38 | return outer; | 38 | return outer; |
| 39 | } | 39 | } |
| 40 | 40 | ||
| 41 | #define INET_ECN_xmit(sk) do { inet_sk(sk)->tos |= INET_ECN_ECT_0; } while (0) | 41 | static inline void INET_ECN_xmit(struct sock *sk) |
| 42 | #define INET_ECN_dontxmit(sk) \ | 42 | { |
| 43 | do { inet_sk(sk)->tos &= ~INET_ECN_MASK; } while (0) | 43 | inet_sk(sk)->tos |= INET_ECN_ECT_0; |
| 44 | if (inet6_sk(sk) != NULL) | ||
| 45 | inet6_sk(sk)->tclass |= INET_ECN_ECT_0; | ||
| 46 | } | ||
| 47 | |||
| 48 | static inline void INET_ECN_dontxmit(struct sock *sk) | ||
| 49 | { | ||
| 50 | inet_sk(sk)->tos &= ~INET_ECN_MASK; | ||
| 51 | if (inet6_sk(sk) != NULL) | ||
| 52 | inet6_sk(sk)->tclass &= ~INET_ECN_MASK; | ||
| 53 | } | ||
| 44 | 54 | ||
| 45 | #define IP6_ECN_flow_init(label) do { \ | 55 | #define IP6_ECN_flow_init(label) do { \ |
| 46 | (label) &= ~htonl(INET_ECN_MASK << 20); \ | 56 | (label) &= ~htonl(INET_ECN_MASK << 20); \ |
diff --git a/include/net/ip_vs.h b/include/net/ip_vs.h index d516f00c8e0f..86aefed6140b 100644 --- a/include/net/ip_vs.h +++ b/include/net/ip_vs.h | |||
| @@ -791,6 +791,7 @@ struct ip_vs_app { | |||
| 791 | /* IPVS in network namespace */ | 791 | /* IPVS in network namespace */ |
| 792 | struct netns_ipvs { | 792 | struct netns_ipvs { |
| 793 | int gen; /* Generation */ | 793 | int gen; /* Generation */ |
| 794 | int enable; /* enable like nf_hooks do */ | ||
| 794 | /* | 795 | /* |
| 795 | * Hash table: for real service lookups | 796 | * Hash table: for real service lookups |
| 796 | */ | 797 | */ |
| @@ -1089,6 +1090,22 @@ ip_vs_control_add(struct ip_vs_conn *cp, struct ip_vs_conn *ctl_cp) | |||
| 1089 | atomic_inc(&ctl_cp->n_control); | 1090 | atomic_inc(&ctl_cp->n_control); |
| 1090 | } | 1091 | } |
| 1091 | 1092 | ||
| 1093 | /* | ||
| 1094 | * IPVS netns init & cleanup functions | ||
| 1095 | */ | ||
| 1096 | extern int __ip_vs_estimator_init(struct net *net); | ||
| 1097 | extern int __ip_vs_control_init(struct net *net); | ||
| 1098 | extern int __ip_vs_protocol_init(struct net *net); | ||
| 1099 | extern int __ip_vs_app_init(struct net *net); | ||
| 1100 | extern int __ip_vs_conn_init(struct net *net); | ||
| 1101 | extern int __ip_vs_sync_init(struct net *net); | ||
| 1102 | extern void __ip_vs_conn_cleanup(struct net *net); | ||
| 1103 | extern void __ip_vs_app_cleanup(struct net *net); | ||
| 1104 | extern void __ip_vs_protocol_cleanup(struct net *net); | ||
| 1105 | extern void __ip_vs_control_cleanup(struct net *net); | ||
| 1106 | extern void __ip_vs_estimator_cleanup(struct net *net); | ||
| 1107 | extern void __ip_vs_sync_cleanup(struct net *net); | ||
| 1108 | extern void __ip_vs_service_cleanup(struct net *net); | ||
| 1092 | 1109 | ||
| 1093 | /* | 1110 | /* |
| 1094 | * IPVS application functions | 1111 | * IPVS application functions |
diff --git a/include/net/llc_pdu.h b/include/net/llc_pdu.h index 75b8e2968c9b..f57e7d46a453 100644 --- a/include/net/llc_pdu.h +++ b/include/net/llc_pdu.h | |||
| @@ -199,7 +199,7 @@ struct llc_pdu_sn { | |||
| 199 | u8 ssap; | 199 | u8 ssap; |
| 200 | u8 ctrl_1; | 200 | u8 ctrl_1; |
| 201 | u8 ctrl_2; | 201 | u8 ctrl_2; |
| 202 | }; | 202 | } __packed; |
| 203 | 203 | ||
| 204 | static inline struct llc_pdu_sn *llc_pdu_sn_hdr(struct sk_buff *skb) | 204 | static inline struct llc_pdu_sn *llc_pdu_sn_hdr(struct sk_buff *skb) |
| 205 | { | 205 | { |
| @@ -211,7 +211,7 @@ struct llc_pdu_un { | |||
| 211 | u8 dsap; | 211 | u8 dsap; |
| 212 | u8 ssap; | 212 | u8 ssap; |
| 213 | u8 ctrl_1; | 213 | u8 ctrl_1; |
| 214 | }; | 214 | } __packed; |
| 215 | 215 | ||
| 216 | static inline struct llc_pdu_un *llc_pdu_un_hdr(struct sk_buff *skb) | 216 | static inline struct llc_pdu_un *llc_pdu_un_hdr(struct sk_buff *skb) |
| 217 | { | 217 | { |
| @@ -359,7 +359,7 @@ struct llc_xid_info { | |||
| 359 | u8 fmt_id; /* always 0x81 for LLC */ | 359 | u8 fmt_id; /* always 0x81 for LLC */ |
| 360 | u8 type; /* different if NULL/non-NULL LSAP */ | 360 | u8 type; /* different if NULL/non-NULL LSAP */ |
| 361 | u8 rw; /* sender receive window */ | 361 | u8 rw; /* sender receive window */ |
| 362 | }; | 362 | } __packed; |
| 363 | 363 | ||
| 364 | /** | 364 | /** |
| 365 | * llc_pdu_init_as_xid_cmd - sets bytes 3, 4 & 5 of LLC header as XID | 365 | * llc_pdu_init_as_xid_cmd - sets bytes 3, 4 & 5 of LLC header as XID |
| @@ -415,7 +415,7 @@ struct llc_frmr_info { | |||
| 415 | u8 curr_ssv; /* current send state variable val */ | 415 | u8 curr_ssv; /* current send state variable val */ |
| 416 | u8 curr_rsv; /* current receive state variable */ | 416 | u8 curr_rsv; /* current receive state variable */ |
| 417 | u8 ind_bits; /* indicator bits set with macro */ | 417 | u8 ind_bits; /* indicator bits set with macro */ |
| 418 | }; | 418 | } __packed; |
| 419 | 419 | ||
| 420 | extern void llc_pdu_set_cmd_rsp(struct sk_buff *skb, u8 type); | 420 | extern void llc_pdu_set_cmd_rsp(struct sk_buff *skb, u8 type); |
| 421 | extern void llc_pdu_set_pf_bit(struct sk_buff *skb, u8 bit_value); | 421 | extern void llc_pdu_set_pf_bit(struct sk_buff *skb, u8 bit_value); |
diff --git a/include/net/xfrm.h b/include/net/xfrm.h index 6ae4bc5ce8a7..20afeaa39395 100644 --- a/include/net/xfrm.h +++ b/include/net/xfrm.h | |||
| @@ -324,6 +324,7 @@ struct xfrm_state_afinfo { | |||
| 324 | int (*tmpl_sort)(struct xfrm_tmpl **dst, struct xfrm_tmpl **src, int n); | 324 | int (*tmpl_sort)(struct xfrm_tmpl **dst, struct xfrm_tmpl **src, int n); |
| 325 | int (*state_sort)(struct xfrm_state **dst, struct xfrm_state **src, int n); | 325 | int (*state_sort)(struct xfrm_state **dst, struct xfrm_state **src, int n); |
| 326 | int (*output)(struct sk_buff *skb); | 326 | int (*output)(struct sk_buff *skb); |
| 327 | int (*output_finish)(struct sk_buff *skb); | ||
| 327 | int (*extract_input)(struct xfrm_state *x, | 328 | int (*extract_input)(struct xfrm_state *x, |
| 328 | struct sk_buff *skb); | 329 | struct sk_buff *skb); |
| 329 | int (*extract_output)(struct xfrm_state *x, | 330 | int (*extract_output)(struct xfrm_state *x, |
| @@ -1454,6 +1455,7 @@ static inline int xfrm4_rcv_spi(struct sk_buff *skb, int nexthdr, __be32 spi) | |||
| 1454 | extern int xfrm4_extract_output(struct xfrm_state *x, struct sk_buff *skb); | 1455 | extern int xfrm4_extract_output(struct xfrm_state *x, struct sk_buff *skb); |
| 1455 | extern int xfrm4_prepare_output(struct xfrm_state *x, struct sk_buff *skb); | 1456 | extern int xfrm4_prepare_output(struct xfrm_state *x, struct sk_buff *skb); |
| 1456 | extern int xfrm4_output(struct sk_buff *skb); | 1457 | extern int xfrm4_output(struct sk_buff *skb); |
| 1458 | extern int xfrm4_output_finish(struct sk_buff *skb); | ||
| 1457 | extern int xfrm4_tunnel_register(struct xfrm_tunnel *handler, unsigned short family); | 1459 | extern int xfrm4_tunnel_register(struct xfrm_tunnel *handler, unsigned short family); |
| 1458 | extern int xfrm4_tunnel_deregister(struct xfrm_tunnel *handler, unsigned short family); | 1460 | extern int xfrm4_tunnel_deregister(struct xfrm_tunnel *handler, unsigned short family); |
| 1459 | extern int xfrm6_extract_header(struct sk_buff *skb); | 1461 | extern int xfrm6_extract_header(struct sk_buff *skb); |
| @@ -1470,6 +1472,7 @@ extern __be32 xfrm6_tunnel_spi_lookup(struct net *net, xfrm_address_t *saddr); | |||
| 1470 | extern int xfrm6_extract_output(struct xfrm_state *x, struct sk_buff *skb); | 1472 | extern int xfrm6_extract_output(struct xfrm_state *x, struct sk_buff *skb); |
| 1471 | extern int xfrm6_prepare_output(struct xfrm_state *x, struct sk_buff *skb); | 1473 | extern int xfrm6_prepare_output(struct xfrm_state *x, struct sk_buff *skb); |
| 1472 | extern int xfrm6_output(struct sk_buff *skb); | 1474 | extern int xfrm6_output(struct sk_buff *skb); |
| 1475 | extern int xfrm6_output_finish(struct sk_buff *skb); | ||
| 1473 | extern int xfrm6_find_1stfragopt(struct xfrm_state *x, struct sk_buff *skb, | 1476 | extern int xfrm6_find_1stfragopt(struct xfrm_state *x, struct sk_buff *skb, |
| 1474 | u8 **prevhdr); | 1477 | u8 **prevhdr); |
| 1475 | 1478 | ||
diff --git a/include/trace/events/gfpflags.h b/include/trace/events/gfpflags.h index e3615c093741..9fe3a36646e9 100644 --- a/include/trace/events/gfpflags.h +++ b/include/trace/events/gfpflags.h | |||
| @@ -10,6 +10,7 @@ | |||
| 10 | */ | 10 | */ |
| 11 | #define show_gfp_flags(flags) \ | 11 | #define show_gfp_flags(flags) \ |
| 12 | (flags) ? __print_flags(flags, "|", \ | 12 | (flags) ? __print_flags(flags, "|", \ |
| 13 | {(unsigned long)GFP_TRANSHUGE, "GFP_TRANSHUGE"}, \ | ||
| 13 | {(unsigned long)GFP_HIGHUSER_MOVABLE, "GFP_HIGHUSER_MOVABLE"}, \ | 14 | {(unsigned long)GFP_HIGHUSER_MOVABLE, "GFP_HIGHUSER_MOVABLE"}, \ |
| 14 | {(unsigned long)GFP_HIGHUSER, "GFP_HIGHUSER"}, \ | 15 | {(unsigned long)GFP_HIGHUSER, "GFP_HIGHUSER"}, \ |
| 15 | {(unsigned long)GFP_USER, "GFP_USER"}, \ | 16 | {(unsigned long)GFP_USER, "GFP_USER"}, \ |
| @@ -32,6 +33,9 @@ | |||
| 32 | {(unsigned long)__GFP_HARDWALL, "GFP_HARDWALL"}, \ | 33 | {(unsigned long)__GFP_HARDWALL, "GFP_HARDWALL"}, \ |
| 33 | {(unsigned long)__GFP_THISNODE, "GFP_THISNODE"}, \ | 34 | {(unsigned long)__GFP_THISNODE, "GFP_THISNODE"}, \ |
| 34 | {(unsigned long)__GFP_RECLAIMABLE, "GFP_RECLAIMABLE"}, \ | 35 | {(unsigned long)__GFP_RECLAIMABLE, "GFP_RECLAIMABLE"}, \ |
| 35 | {(unsigned long)__GFP_MOVABLE, "GFP_MOVABLE"} \ | 36 | {(unsigned long)__GFP_MOVABLE, "GFP_MOVABLE"}, \ |
| 37 | {(unsigned long)__GFP_NOTRACK, "GFP_NOTRACK"}, \ | ||
| 38 | {(unsigned long)__GFP_NO_KSWAPD, "GFP_NO_KSWAPD"}, \ | ||
| 39 | {(unsigned long)__GFP_OTHER_NODE, "GFP_OTHER_NODE"} \ | ||
| 36 | ) : "GFP_NOWAIT" | 40 | ) : "GFP_NOWAIT" |
| 37 | 41 | ||
diff --git a/init/Kconfig b/init/Kconfig index d886b1e9278e..7a71e0a9992a 100644 --- a/init/Kconfig +++ b/init/Kconfig | |||
| @@ -1226,7 +1226,6 @@ config SLAB | |||
| 1226 | per cpu and per node queues. | 1226 | per cpu and per node queues. |
| 1227 | 1227 | ||
| 1228 | config SLUB | 1228 | config SLUB |
| 1229 | depends on BROKEN || NUMA || !DISCONTIGMEM | ||
| 1230 | bool "SLUB (Unqueued Allocator)" | 1229 | bool "SLUB (Unqueued Allocator)" |
| 1231 | help | 1230 | help |
| 1232 | SLUB is a slab allocator that minimizes cache line usage | 1231 | SLUB is a slab allocator that minimizes cache line usage |
diff --git a/kernel/capability.c b/kernel/capability.c index bf0c734d0c12..32a80e08ff4b 100644 --- a/kernel/capability.c +++ b/kernel/capability.c | |||
| @@ -399,3 +399,15 @@ bool task_ns_capable(struct task_struct *t, int cap) | |||
| 399 | return ns_capable(task_cred_xxx(t, user)->user_ns, cap); | 399 | return ns_capable(task_cred_xxx(t, user)->user_ns, cap); |
| 400 | } | 400 | } |
| 401 | EXPORT_SYMBOL(task_ns_capable); | 401 | EXPORT_SYMBOL(task_ns_capable); |
| 402 | |||
| 403 | /** | ||
| 404 | * nsown_capable - Check superior capability to one's own user_ns | ||
| 405 | * @cap: The capability in question | ||
| 406 | * | ||
| 407 | * Return true if the current task has the given superior capability | ||
| 408 | * targeted at its own user namespace. | ||
| 409 | */ | ||
| 410 | bool nsown_capable(int cap) | ||
| 411 | { | ||
| 412 | return ns_capable(current_user_ns(), cap); | ||
| 413 | } | ||
diff --git a/kernel/cred.c b/kernel/cred.c index 5557b55048df..8093c16b84b1 100644 --- a/kernel/cred.c +++ b/kernel/cred.c | |||
| @@ -54,6 +54,7 @@ struct cred init_cred = { | |||
| 54 | .cap_effective = CAP_INIT_EFF_SET, | 54 | .cap_effective = CAP_INIT_EFF_SET, |
| 55 | .cap_bset = CAP_INIT_BSET, | 55 | .cap_bset = CAP_INIT_BSET, |
| 56 | .user = INIT_USER, | 56 | .user = INIT_USER, |
| 57 | .user_ns = &init_user_ns, | ||
| 57 | .group_info = &init_groups, | 58 | .group_info = &init_groups, |
| 58 | #ifdef CONFIG_KEYS | 59 | #ifdef CONFIG_KEYS |
| 59 | .tgcred = &init_tgcred, | 60 | .tgcred = &init_tgcred, |
| @@ -410,6 +411,11 @@ int copy_creds(struct task_struct *p, unsigned long clone_flags) | |||
| 410 | goto error_put; | 411 | goto error_put; |
| 411 | } | 412 | } |
| 412 | 413 | ||
| 414 | /* cache user_ns in cred. Doesn't need a refcount because it will | ||
| 415 | * stay pinned by cred->user | ||
| 416 | */ | ||
| 417 | new->user_ns = new->user->user_ns; | ||
| 418 | |||
| 413 | #ifdef CONFIG_KEYS | 419 | #ifdef CONFIG_KEYS |
| 414 | /* new threads get their own thread keyrings if their parent already | 420 | /* new threads get their own thread keyrings if their parent already |
| 415 | * had one */ | 421 | * had one */ |
| @@ -741,12 +747,6 @@ int set_create_files_as(struct cred *new, struct inode *inode) | |||
| 741 | } | 747 | } |
| 742 | EXPORT_SYMBOL(set_create_files_as); | 748 | EXPORT_SYMBOL(set_create_files_as); |
| 743 | 749 | ||
| 744 | struct user_namespace *current_user_ns(void) | ||
| 745 | { | ||
| 746 | return _current_user_ns(); | ||
| 747 | } | ||
| 748 | EXPORT_SYMBOL(current_user_ns); | ||
| 749 | |||
| 750 | #ifdef CONFIG_DEBUG_CREDENTIALS | 750 | #ifdef CONFIG_DEBUG_CREDENTIALS |
| 751 | 751 | ||
| 752 | bool creds_are_invalid(const struct cred *cred) | 752 | bool creds_are_invalid(const struct cred *cred) |
diff --git a/kernel/power/suspend.c b/kernel/power/suspend.c index 8935369d503a..6275970b2189 100644 --- a/kernel/power/suspend.c +++ b/kernel/power/suspend.c | |||
| @@ -216,7 +216,6 @@ int suspend_devices_and_enter(suspend_state_t state) | |||
| 216 | goto Close; | 216 | goto Close; |
| 217 | } | 217 | } |
| 218 | suspend_console(); | 218 | suspend_console(); |
| 219 | pm_restrict_gfp_mask(); | ||
| 220 | suspend_test_start(); | 219 | suspend_test_start(); |
| 221 | error = dpm_suspend_start(PMSG_SUSPEND); | 220 | error = dpm_suspend_start(PMSG_SUSPEND); |
| 222 | if (error) { | 221 | if (error) { |
| @@ -233,7 +232,6 @@ int suspend_devices_and_enter(suspend_state_t state) | |||
| 233 | suspend_test_start(); | 232 | suspend_test_start(); |
| 234 | dpm_resume_end(PMSG_RESUME); | 233 | dpm_resume_end(PMSG_RESUME); |
| 235 | suspend_test_finish("resume devices"); | 234 | suspend_test_finish("resume devices"); |
| 236 | pm_restore_gfp_mask(); | ||
| 237 | resume_console(); | 235 | resume_console(); |
| 238 | Close: | 236 | Close: |
| 239 | if (suspend_ops->end) | 237 | if (suspend_ops->end) |
| @@ -294,7 +292,9 @@ int enter_state(suspend_state_t state) | |||
| 294 | goto Finish; | 292 | goto Finish; |
| 295 | 293 | ||
| 296 | pr_debug("PM: Entering %s sleep\n", pm_states[state]); | 294 | pr_debug("PM: Entering %s sleep\n", pm_states[state]); |
| 295 | pm_restrict_gfp_mask(); | ||
| 297 | error = suspend_devices_and_enter(state); | 296 | error = suspend_devices_and_enter(state); |
| 297 | pm_restore_gfp_mask(); | ||
| 298 | 298 | ||
| 299 | Finish: | 299 | Finish: |
| 300 | pr_debug("PM: Finishing wakeup.\n"); | 300 | pr_debug("PM: Finishing wakeup.\n"); |
diff --git a/kernel/power/user.c b/kernel/power/user.c index c36c3b9e8a84..7d02d33be699 100644 --- a/kernel/power/user.c +++ b/kernel/power/user.c | |||
| @@ -135,8 +135,10 @@ static int snapshot_release(struct inode *inode, struct file *filp) | |||
| 135 | free_basic_memory_bitmaps(); | 135 | free_basic_memory_bitmaps(); |
| 136 | data = filp->private_data; | 136 | data = filp->private_data; |
| 137 | free_all_swap_pages(data->swap); | 137 | free_all_swap_pages(data->swap); |
| 138 | if (data->frozen) | 138 | if (data->frozen) { |
| 139 | pm_restore_gfp_mask(); | ||
| 139 | thaw_processes(); | 140 | thaw_processes(); |
| 141 | } | ||
| 140 | pm_notifier_call_chain(data->mode == O_RDONLY ? | 142 | pm_notifier_call_chain(data->mode == O_RDONLY ? |
| 141 | PM_POST_HIBERNATION : PM_POST_RESTORE); | 143 | PM_POST_HIBERNATION : PM_POST_RESTORE); |
| 142 | atomic_inc(&snapshot_device_available); | 144 | atomic_inc(&snapshot_device_available); |
| @@ -379,6 +381,7 @@ static long snapshot_ioctl(struct file *filp, unsigned int cmd, | |||
| 379 | * PM_HIBERNATION_PREPARE | 381 | * PM_HIBERNATION_PREPARE |
| 380 | */ | 382 | */ |
| 381 | error = suspend_devices_and_enter(PM_SUSPEND_MEM); | 383 | error = suspend_devices_and_enter(PM_SUSPEND_MEM); |
| 384 | data->ready = 0; | ||
| 382 | break; | 385 | break; |
| 383 | 386 | ||
| 384 | case SNAPSHOT_PLATFORM_SUPPORT: | 387 | case SNAPSHOT_PLATFORM_SUPPORT: |
diff --git a/kernel/time/clocksource.c b/kernel/time/clocksource.c index 6519cf62d9cd..0e17c10f8a9d 100644 --- a/kernel/time/clocksource.c +++ b/kernel/time/clocksource.c | |||
| @@ -685,8 +685,8 @@ int __clocksource_register_scale(struct clocksource *cs, u32 scale, u32 freq) | |||
| 685 | /* Add clocksource to the clcoksource list */ | 685 | /* Add clocksource to the clcoksource list */ |
| 686 | mutex_lock(&clocksource_mutex); | 686 | mutex_lock(&clocksource_mutex); |
| 687 | clocksource_enqueue(cs); | 687 | clocksource_enqueue(cs); |
| 688 | clocksource_select(); | ||
| 689 | clocksource_enqueue_watchdog(cs); | 688 | clocksource_enqueue_watchdog(cs); |
| 689 | clocksource_select(); | ||
| 690 | mutex_unlock(&clocksource_mutex); | 690 | mutex_unlock(&clocksource_mutex); |
| 691 | return 0; | 691 | return 0; |
| 692 | } | 692 | } |
| @@ -706,8 +706,8 @@ int clocksource_register(struct clocksource *cs) | |||
| 706 | 706 | ||
| 707 | mutex_lock(&clocksource_mutex); | 707 | mutex_lock(&clocksource_mutex); |
| 708 | clocksource_enqueue(cs); | 708 | clocksource_enqueue(cs); |
| 709 | clocksource_select(); | ||
| 710 | clocksource_enqueue_watchdog(cs); | 709 | clocksource_enqueue_watchdog(cs); |
| 710 | clocksource_select(); | ||
| 711 | mutex_unlock(&clocksource_mutex); | 711 | mutex_unlock(&clocksource_mutex); |
| 712 | return 0; | 712 | return 0; |
| 713 | } | 713 | } |
diff --git a/kernel/time/tick-broadcast.c b/kernel/time/tick-broadcast.c index da800ffa810c..723c7637e55a 100644 --- a/kernel/time/tick-broadcast.c +++ b/kernel/time/tick-broadcast.c | |||
| @@ -522,10 +522,11 @@ static void tick_broadcast_init_next_event(struct cpumask *mask, | |||
| 522 | */ | 522 | */ |
| 523 | void tick_broadcast_setup_oneshot(struct clock_event_device *bc) | 523 | void tick_broadcast_setup_oneshot(struct clock_event_device *bc) |
| 524 | { | 524 | { |
| 525 | int cpu = smp_processor_id(); | ||
| 526 | |||
| 525 | /* Set it up only once ! */ | 527 | /* Set it up only once ! */ |
| 526 | if (bc->event_handler != tick_handle_oneshot_broadcast) { | 528 | if (bc->event_handler != tick_handle_oneshot_broadcast) { |
| 527 | int was_periodic = bc->mode == CLOCK_EVT_MODE_PERIODIC; | 529 | int was_periodic = bc->mode == CLOCK_EVT_MODE_PERIODIC; |
| 528 | int cpu = smp_processor_id(); | ||
| 529 | 530 | ||
| 530 | bc->event_handler = tick_handle_oneshot_broadcast; | 531 | bc->event_handler = tick_handle_oneshot_broadcast; |
| 531 | clockevents_set_mode(bc, CLOCK_EVT_MODE_ONESHOT); | 532 | clockevents_set_mode(bc, CLOCK_EVT_MODE_ONESHOT); |
| @@ -551,6 +552,15 @@ void tick_broadcast_setup_oneshot(struct clock_event_device *bc) | |||
| 551 | tick_broadcast_set_event(tick_next_period, 1); | 552 | tick_broadcast_set_event(tick_next_period, 1); |
| 552 | } else | 553 | } else |
| 553 | bc->next_event.tv64 = KTIME_MAX; | 554 | bc->next_event.tv64 = KTIME_MAX; |
| 555 | } else { | ||
| 556 | /* | ||
| 557 | * The first cpu which switches to oneshot mode sets | ||
| 558 | * the bit for all other cpus which are in the general | ||
| 559 | * (periodic) broadcast mask. So the bit is set and | ||
| 560 | * would prevent the first broadcast enter after this | ||
| 561 | * to program the bc device. | ||
| 562 | */ | ||
| 563 | tick_broadcast_clear_oneshot(cpu); | ||
| 554 | } | 564 | } |
| 555 | } | 565 | } |
| 556 | 566 | ||
diff --git a/lib/vsprintf.c b/lib/vsprintf.c index bc0ac6b333dc..dfd60192bc2e 100644 --- a/lib/vsprintf.c +++ b/lib/vsprintf.c | |||
| @@ -797,7 +797,7 @@ char *uuid_string(char *buf, char *end, const u8 *addr, | |||
| 797 | return string(buf, end, uuid, spec); | 797 | return string(buf, end, uuid, spec); |
| 798 | } | 798 | } |
| 799 | 799 | ||
| 800 | int kptr_restrict = 1; | 800 | int kptr_restrict __read_mostly; |
| 801 | 801 | ||
| 802 | /* | 802 | /* |
| 803 | * Show a '%p' thing. A kernel extension is that the '%p' is followed | 803 | * Show a '%p' thing. A kernel extension is that the '%p' is followed |
diff --git a/mm/page_alloc.c b/mm/page_alloc.c index 9f8a97b9a350..3f8bce264df6 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c | |||
| @@ -2317,6 +2317,21 @@ void free_pages(unsigned long addr, unsigned int order) | |||
| 2317 | 2317 | ||
| 2318 | EXPORT_SYMBOL(free_pages); | 2318 | EXPORT_SYMBOL(free_pages); |
| 2319 | 2319 | ||
| 2320 | static void *make_alloc_exact(unsigned long addr, unsigned order, size_t size) | ||
| 2321 | { | ||
| 2322 | if (addr) { | ||
| 2323 | unsigned long alloc_end = addr + (PAGE_SIZE << order); | ||
| 2324 | unsigned long used = addr + PAGE_ALIGN(size); | ||
| 2325 | |||
| 2326 | split_page(virt_to_page((void *)addr), order); | ||
| 2327 | while (used < alloc_end) { | ||
| 2328 | free_page(used); | ||
| 2329 | used += PAGE_SIZE; | ||
| 2330 | } | ||
| 2331 | } | ||
| 2332 | return (void *)addr; | ||
| 2333 | } | ||
| 2334 | |||
| 2320 | /** | 2335 | /** |
| 2321 | * alloc_pages_exact - allocate an exact number physically-contiguous pages. | 2336 | * alloc_pages_exact - allocate an exact number physically-contiguous pages. |
| 2322 | * @size: the number of bytes to allocate | 2337 | * @size: the number of bytes to allocate |
| @@ -2336,22 +2351,33 @@ void *alloc_pages_exact(size_t size, gfp_t gfp_mask) | |||
| 2336 | unsigned long addr; | 2351 | unsigned long addr; |
| 2337 | 2352 | ||
| 2338 | addr = __get_free_pages(gfp_mask, order); | 2353 | addr = __get_free_pages(gfp_mask, order); |
| 2339 | if (addr) { | 2354 | return make_alloc_exact(addr, order, size); |
| 2340 | unsigned long alloc_end = addr + (PAGE_SIZE << order); | ||
| 2341 | unsigned long used = addr + PAGE_ALIGN(size); | ||
| 2342 | |||
| 2343 | split_page(virt_to_page((void *)addr), order); | ||
| 2344 | while (used < alloc_end) { | ||
| 2345 | free_page(used); | ||
| 2346 | used += PAGE_SIZE; | ||
| 2347 | } | ||
| 2348 | } | ||
| 2349 | |||
| 2350 | return (void *)addr; | ||
| 2351 | } | 2355 | } |
| 2352 | EXPORT_SYMBOL(alloc_pages_exact); | 2356 | EXPORT_SYMBOL(alloc_pages_exact); |
| 2353 | 2357 | ||
| 2354 | /** | 2358 | /** |
| 2359 | * alloc_pages_exact_nid - allocate an exact number of physically-contiguous | ||
| 2360 | * pages on a node. | ||
| 2361 | * @nid: the preferred node ID where memory should be allocated | ||
| 2362 | * @size: the number of bytes to allocate | ||
| 2363 | * @gfp_mask: GFP flags for the allocation | ||
| 2364 | * | ||
| 2365 | * Like alloc_pages_exact(), but try to allocate on node nid first before falling | ||
| 2366 | * back. | ||
| 2367 | * Note this is not alloc_pages_exact_node() which allocates on a specific node, | ||
| 2368 | * but is not exact. | ||
| 2369 | */ | ||
| 2370 | void *alloc_pages_exact_nid(int nid, size_t size, gfp_t gfp_mask) | ||
| 2371 | { | ||
| 2372 | unsigned order = get_order(size); | ||
| 2373 | struct page *p = alloc_pages_node(nid, gfp_mask, order); | ||
| 2374 | if (!p) | ||
| 2375 | return NULL; | ||
| 2376 | return make_alloc_exact((unsigned long)page_address(p), order, size); | ||
| 2377 | } | ||
| 2378 | EXPORT_SYMBOL(alloc_pages_exact_nid); | ||
| 2379 | |||
| 2380 | /** | ||
| 2355 | * free_pages_exact - release memory allocated via alloc_pages_exact() | 2381 | * free_pages_exact - release memory allocated via alloc_pages_exact() |
| 2356 | * @virt: the value returned by alloc_pages_exact. | 2382 | * @virt: the value returned by alloc_pages_exact. |
| 2357 | * @size: size of allocation, same value as passed to alloc_pages_exact(). | 2383 | * @size: size of allocation, same value as passed to alloc_pages_exact(). |
| @@ -3564,7 +3590,7 @@ int zone_wait_table_init(struct zone *zone, unsigned long zone_size_pages) | |||
| 3564 | 3590 | ||
| 3565 | if (!slab_is_available()) { | 3591 | if (!slab_is_available()) { |
| 3566 | zone->wait_table = (wait_queue_head_t *) | 3592 | zone->wait_table = (wait_queue_head_t *) |
| 3567 | alloc_bootmem_node(pgdat, alloc_size); | 3593 | alloc_bootmem_node_nopanic(pgdat, alloc_size); |
| 3568 | } else { | 3594 | } else { |
| 3569 | /* | 3595 | /* |
| 3570 | * This case means that a zone whose size was 0 gets new memory | 3596 | * This case means that a zone whose size was 0 gets new memory |
| @@ -4141,7 +4167,8 @@ static void __init setup_usemap(struct pglist_data *pgdat, | |||
| 4141 | unsigned long usemapsize = usemap_size(zonesize); | 4167 | unsigned long usemapsize = usemap_size(zonesize); |
| 4142 | zone->pageblock_flags = NULL; | 4168 | zone->pageblock_flags = NULL; |
| 4143 | if (usemapsize) | 4169 | if (usemapsize) |
| 4144 | zone->pageblock_flags = alloc_bootmem_node(pgdat, usemapsize); | 4170 | zone->pageblock_flags = alloc_bootmem_node_nopanic(pgdat, |
| 4171 | usemapsize); | ||
| 4145 | } | 4172 | } |
| 4146 | #else | 4173 | #else |
| 4147 | static inline void setup_usemap(struct pglist_data *pgdat, | 4174 | static inline void setup_usemap(struct pglist_data *pgdat, |
| @@ -4307,7 +4334,7 @@ static void __init_refok alloc_node_mem_map(struct pglist_data *pgdat) | |||
| 4307 | size = (end - start) * sizeof(struct page); | 4334 | size = (end - start) * sizeof(struct page); |
| 4308 | map = alloc_remap(pgdat->node_id, size); | 4335 | map = alloc_remap(pgdat->node_id, size); |
| 4309 | if (!map) | 4336 | if (!map) |
| 4310 | map = alloc_bootmem_node(pgdat, size); | 4337 | map = alloc_bootmem_node_nopanic(pgdat, size); |
| 4311 | pgdat->node_mem_map = map + (pgdat->node_start_pfn - start); | 4338 | pgdat->node_mem_map = map + (pgdat->node_start_pfn - start); |
| 4312 | } | 4339 | } |
| 4313 | #ifndef CONFIG_NEED_MULTIPLE_NODES | 4340 | #ifndef CONFIG_NEED_MULTIPLE_NODES |
diff --git a/mm/page_cgroup.c b/mm/page_cgroup.c index 99055010cece..2daadc322ba6 100644 --- a/mm/page_cgroup.c +++ b/mm/page_cgroup.c | |||
| @@ -134,7 +134,7 @@ static void *__init_refok alloc_page_cgroup(size_t size, int nid) | |||
| 134 | { | 134 | { |
| 135 | void *addr = NULL; | 135 | void *addr = NULL; |
| 136 | 136 | ||
| 137 | addr = alloc_pages_exact(size, GFP_KERNEL | __GFP_NOWARN); | 137 | addr = alloc_pages_exact_nid(nid, size, GFP_KERNEL | __GFP_NOWARN); |
| 138 | if (addr) | 138 | if (addr) |
| 139 | return addr; | 139 | return addr; |
| 140 | 140 | ||
diff --git a/mm/shmem.c b/mm/shmem.c index 8fa27e4e582a..dfc7069102ee 100644 --- a/mm/shmem.c +++ b/mm/shmem.c | |||
| @@ -852,7 +852,7 @@ static inline int shmem_find_swp(swp_entry_t entry, swp_entry_t *dir, swp_entry_ | |||
| 852 | 852 | ||
| 853 | static int shmem_unuse_inode(struct shmem_inode_info *info, swp_entry_t entry, struct page *page) | 853 | static int shmem_unuse_inode(struct shmem_inode_info *info, swp_entry_t entry, struct page *page) |
| 854 | { | 854 | { |
| 855 | struct inode *inode; | 855 | struct address_space *mapping; |
| 856 | unsigned long idx; | 856 | unsigned long idx; |
| 857 | unsigned long size; | 857 | unsigned long size; |
| 858 | unsigned long limit; | 858 | unsigned long limit; |
| @@ -875,8 +875,10 @@ static int shmem_unuse_inode(struct shmem_inode_info *info, swp_entry_t entry, s | |||
| 875 | if (size > SHMEM_NR_DIRECT) | 875 | if (size > SHMEM_NR_DIRECT) |
| 876 | size = SHMEM_NR_DIRECT; | 876 | size = SHMEM_NR_DIRECT; |
| 877 | offset = shmem_find_swp(entry, ptr, ptr+size); | 877 | offset = shmem_find_swp(entry, ptr, ptr+size); |
| 878 | if (offset >= 0) | 878 | if (offset >= 0) { |
| 879 | shmem_swp_balance_unmap(); | ||
| 879 | goto found; | 880 | goto found; |
| 881 | } | ||
| 880 | if (!info->i_indirect) | 882 | if (!info->i_indirect) |
| 881 | goto lost2; | 883 | goto lost2; |
| 882 | 884 | ||
| @@ -914,11 +916,11 @@ static int shmem_unuse_inode(struct shmem_inode_info *info, swp_entry_t entry, s | |||
| 914 | if (size > ENTRIES_PER_PAGE) | 916 | if (size > ENTRIES_PER_PAGE) |
| 915 | size = ENTRIES_PER_PAGE; | 917 | size = ENTRIES_PER_PAGE; |
| 916 | offset = shmem_find_swp(entry, ptr, ptr+size); | 918 | offset = shmem_find_swp(entry, ptr, ptr+size); |
| 917 | shmem_swp_unmap(ptr); | ||
| 918 | if (offset >= 0) { | 919 | if (offset >= 0) { |
| 919 | shmem_dir_unmap(dir); | 920 | shmem_dir_unmap(dir); |
| 920 | goto found; | 921 | goto found; |
| 921 | } | 922 | } |
| 923 | shmem_swp_unmap(ptr); | ||
| 922 | } | 924 | } |
| 923 | } | 925 | } |
| 924 | lost1: | 926 | lost1: |
| @@ -928,8 +930,7 @@ lost2: | |||
| 928 | return 0; | 930 | return 0; |
| 929 | found: | 931 | found: |
| 930 | idx += offset; | 932 | idx += offset; |
| 931 | inode = igrab(&info->vfs_inode); | 933 | ptr += offset; |
| 932 | spin_unlock(&info->lock); | ||
| 933 | 934 | ||
| 934 | /* | 935 | /* |
| 935 | * Move _head_ to start search for next from here. | 936 | * Move _head_ to start search for next from here. |
| @@ -940,37 +941,18 @@ found: | |||
| 940 | */ | 941 | */ |
| 941 | if (shmem_swaplist.next != &info->swaplist) | 942 | if (shmem_swaplist.next != &info->swaplist) |
| 942 | list_move_tail(&shmem_swaplist, &info->swaplist); | 943 | list_move_tail(&shmem_swaplist, &info->swaplist); |
| 943 | mutex_unlock(&shmem_swaplist_mutex); | ||
| 944 | 944 | ||
| 945 | error = 1; | ||
| 946 | if (!inode) | ||
| 947 | goto out; | ||
| 948 | /* | 945 | /* |
| 949 | * Charge page using GFP_KERNEL while we can wait. | 946 | * We rely on shmem_swaplist_mutex, not only to protect the swaplist, |
| 950 | * Charged back to the user(not to caller) when swap account is used. | 947 | * but also to hold up shmem_evict_inode(): so inode cannot be freed |
| 951 | * add_to_page_cache() will be called with GFP_NOWAIT. | 948 | * beneath us (pagelock doesn't help until the page is in pagecache). |
| 952 | */ | 949 | */ |
| 953 | error = mem_cgroup_cache_charge(page, current->mm, GFP_KERNEL); | 950 | mapping = info->vfs_inode.i_mapping; |
| 954 | if (error) | 951 | error = add_to_page_cache_locked(page, mapping, idx, GFP_NOWAIT); |
| 955 | goto out; | 952 | /* which does mem_cgroup_uncharge_cache_page on error */ |
| 956 | error = radix_tree_preload(GFP_KERNEL); | ||
| 957 | if (error) { | ||
| 958 | mem_cgroup_uncharge_cache_page(page); | ||
| 959 | goto out; | ||
| 960 | } | ||
| 961 | error = 1; | ||
| 962 | |||
| 963 | spin_lock(&info->lock); | ||
| 964 | ptr = shmem_swp_entry(info, idx, NULL); | ||
| 965 | if (ptr && ptr->val == entry.val) { | ||
| 966 | error = add_to_page_cache_locked(page, inode->i_mapping, | ||
| 967 | idx, GFP_NOWAIT); | ||
| 968 | /* does mem_cgroup_uncharge_cache_page on error */ | ||
| 969 | } else /* we must compensate for our precharge above */ | ||
| 970 | mem_cgroup_uncharge_cache_page(page); | ||
| 971 | 953 | ||
| 972 | if (error == -EEXIST) { | 954 | if (error == -EEXIST) { |
| 973 | struct page *filepage = find_get_page(inode->i_mapping, idx); | 955 | struct page *filepage = find_get_page(mapping, idx); |
| 974 | error = 1; | 956 | error = 1; |
| 975 | if (filepage) { | 957 | if (filepage) { |
| 976 | /* | 958 | /* |
| @@ -990,14 +972,8 @@ found: | |||
| 990 | swap_free(entry); | 972 | swap_free(entry); |
| 991 | error = 1; /* not an error, but entry was found */ | 973 | error = 1; /* not an error, but entry was found */ |
| 992 | } | 974 | } |
| 993 | if (ptr) | 975 | shmem_swp_unmap(ptr); |
| 994 | shmem_swp_unmap(ptr); | ||
| 995 | spin_unlock(&info->lock); | 976 | spin_unlock(&info->lock); |
| 996 | radix_tree_preload_end(); | ||
| 997 | out: | ||
| 998 | unlock_page(page); | ||
| 999 | page_cache_release(page); | ||
| 1000 | iput(inode); /* allows for NULL */ | ||
| 1001 | return error; | 977 | return error; |
| 1002 | } | 978 | } |
| 1003 | 979 | ||
| @@ -1009,6 +985,26 @@ int shmem_unuse(swp_entry_t entry, struct page *page) | |||
| 1009 | struct list_head *p, *next; | 985 | struct list_head *p, *next; |
| 1010 | struct shmem_inode_info *info; | 986 | struct shmem_inode_info *info; |
| 1011 | int found = 0; | 987 | int found = 0; |
| 988 | int error; | ||
| 989 | |||
| 990 | /* | ||
| 991 | * Charge page using GFP_KERNEL while we can wait, before taking | ||
| 992 | * the shmem_swaplist_mutex which might hold up shmem_writepage(). | ||
| 993 | * Charged back to the user (not to caller) when swap account is used. | ||
| 994 | * add_to_page_cache() will be called with GFP_NOWAIT. | ||
| 995 | */ | ||
| 996 | error = mem_cgroup_cache_charge(page, current->mm, GFP_KERNEL); | ||
| 997 | if (error) | ||
| 998 | goto out; | ||
| 999 | /* | ||
| 1000 | * Try to preload while we can wait, to not make a habit of | ||
| 1001 | * draining atomic reserves; but don't latch on to this cpu, | ||
| 1002 | * it's okay if sometimes we get rescheduled after this. | ||
| 1003 | */ | ||
| 1004 | error = radix_tree_preload(GFP_KERNEL); | ||
| 1005 | if (error) | ||
| 1006 | goto uncharge; | ||
| 1007 | radix_tree_preload_end(); | ||
| 1012 | 1008 | ||
| 1013 | mutex_lock(&shmem_swaplist_mutex); | 1009 | mutex_lock(&shmem_swaplist_mutex); |
| 1014 | list_for_each_safe(p, next, &shmem_swaplist) { | 1010 | list_for_each_safe(p, next, &shmem_swaplist) { |
| @@ -1016,17 +1012,19 @@ int shmem_unuse(swp_entry_t entry, struct page *page) | |||
| 1016 | found = shmem_unuse_inode(info, entry, page); | 1012 | found = shmem_unuse_inode(info, entry, page); |
| 1017 | cond_resched(); | 1013 | cond_resched(); |
| 1018 | if (found) | 1014 | if (found) |
| 1019 | goto out; | 1015 | break; |
| 1020 | } | 1016 | } |
| 1021 | mutex_unlock(&shmem_swaplist_mutex); | 1017 | mutex_unlock(&shmem_swaplist_mutex); |
| 1022 | /* | 1018 | |
| 1023 | * Can some race bring us here? We've been holding page lock, | 1019 | uncharge: |
| 1024 | * so I think not; but would rather try again later than BUG() | 1020 | if (!found) |
| 1025 | */ | 1021 | mem_cgroup_uncharge_cache_page(page); |
| 1022 | if (found < 0) | ||
| 1023 | error = found; | ||
| 1024 | out: | ||
| 1026 | unlock_page(page); | 1025 | unlock_page(page); |
| 1027 | page_cache_release(page); | 1026 | page_cache_release(page); |
| 1028 | out: | 1027 | return error; |
| 1029 | return (found < 0) ? found : 0; | ||
| 1030 | } | 1028 | } |
| 1031 | 1029 | ||
| 1032 | /* | 1030 | /* |
| @@ -1064,7 +1062,25 @@ static int shmem_writepage(struct page *page, struct writeback_control *wbc) | |||
| 1064 | else | 1062 | else |
| 1065 | swap.val = 0; | 1063 | swap.val = 0; |
| 1066 | 1064 | ||
| 1065 | /* | ||
| 1066 | * Add inode to shmem_unuse()'s list of swapped-out inodes, | ||
| 1067 | * if it's not already there. Do it now because we cannot take | ||
| 1068 | * mutex while holding spinlock, and must do so before the page | ||
| 1069 | * is moved to swap cache, when its pagelock no longer protects | ||
| 1070 | * the inode from eviction. But don't unlock the mutex until | ||
| 1071 | * we've taken the spinlock, because shmem_unuse_inode() will | ||
| 1072 | * prune a !swapped inode from the swaplist under both locks. | ||
| 1073 | */ | ||
| 1074 | if (swap.val) { | ||
| 1075 | mutex_lock(&shmem_swaplist_mutex); | ||
| 1076 | if (list_empty(&info->swaplist)) | ||
| 1077 | list_add_tail(&info->swaplist, &shmem_swaplist); | ||
| 1078 | } | ||
| 1079 | |||
| 1067 | spin_lock(&info->lock); | 1080 | spin_lock(&info->lock); |
| 1081 | if (swap.val) | ||
| 1082 | mutex_unlock(&shmem_swaplist_mutex); | ||
| 1083 | |||
| 1068 | if (index >= info->next_index) { | 1084 | if (index >= info->next_index) { |
| 1069 | BUG_ON(!(info->flags & SHMEM_TRUNCATE)); | 1085 | BUG_ON(!(info->flags & SHMEM_TRUNCATE)); |
| 1070 | goto unlock; | 1086 | goto unlock; |
| @@ -1084,21 +1100,10 @@ static int shmem_writepage(struct page *page, struct writeback_control *wbc) | |||
| 1084 | delete_from_page_cache(page); | 1100 | delete_from_page_cache(page); |
| 1085 | shmem_swp_set(info, entry, swap.val); | 1101 | shmem_swp_set(info, entry, swap.val); |
| 1086 | shmem_swp_unmap(entry); | 1102 | shmem_swp_unmap(entry); |
| 1087 | if (list_empty(&info->swaplist)) | ||
| 1088 | inode = igrab(inode); | ||
| 1089 | else | ||
| 1090 | inode = NULL; | ||
| 1091 | spin_unlock(&info->lock); | 1103 | spin_unlock(&info->lock); |
| 1092 | swap_shmem_alloc(swap); | 1104 | swap_shmem_alloc(swap); |
| 1093 | BUG_ON(page_mapped(page)); | 1105 | BUG_ON(page_mapped(page)); |
| 1094 | swap_writepage(page, wbc); | 1106 | swap_writepage(page, wbc); |
| 1095 | if (inode) { | ||
| 1096 | mutex_lock(&shmem_swaplist_mutex); | ||
| 1097 | /* move instead of add in case we're racing */ | ||
| 1098 | list_move_tail(&info->swaplist, &shmem_swaplist); | ||
| 1099 | mutex_unlock(&shmem_swaplist_mutex); | ||
| 1100 | iput(inode); | ||
| 1101 | } | ||
| 1102 | return 0; | 1107 | return 0; |
| 1103 | } | 1108 | } |
| 1104 | 1109 | ||
| @@ -1400,20 +1405,14 @@ repeat: | |||
| 1400 | if (sbinfo->max_blocks) { | 1405 | if (sbinfo->max_blocks) { |
| 1401 | if (percpu_counter_compare(&sbinfo->used_blocks, | 1406 | if (percpu_counter_compare(&sbinfo->used_blocks, |
| 1402 | sbinfo->max_blocks) >= 0 || | 1407 | sbinfo->max_blocks) >= 0 || |
| 1403 | shmem_acct_block(info->flags)) { | 1408 | shmem_acct_block(info->flags)) |
| 1404 | spin_unlock(&info->lock); | 1409 | goto nospace; |
| 1405 | error = -ENOSPC; | ||
| 1406 | goto failed; | ||
| 1407 | } | ||
| 1408 | percpu_counter_inc(&sbinfo->used_blocks); | 1410 | percpu_counter_inc(&sbinfo->used_blocks); |
| 1409 | spin_lock(&inode->i_lock); | 1411 | spin_lock(&inode->i_lock); |
| 1410 | inode->i_blocks += BLOCKS_PER_PAGE; | 1412 | inode->i_blocks += BLOCKS_PER_PAGE; |
| 1411 | spin_unlock(&inode->i_lock); | 1413 | spin_unlock(&inode->i_lock); |
| 1412 | } else if (shmem_acct_block(info->flags)) { | 1414 | } else if (shmem_acct_block(info->flags)) |
| 1413 | spin_unlock(&info->lock); | 1415 | goto nospace; |
| 1414 | error = -ENOSPC; | ||
| 1415 | goto failed; | ||
| 1416 | } | ||
| 1417 | 1416 | ||
| 1418 | if (!filepage) { | 1417 | if (!filepage) { |
| 1419 | int ret; | 1418 | int ret; |
| @@ -1493,6 +1492,24 @@ done: | |||
| 1493 | error = 0; | 1492 | error = 0; |
| 1494 | goto out; | 1493 | goto out; |
| 1495 | 1494 | ||
| 1495 | nospace: | ||
| 1496 | /* | ||
| 1497 | * Perhaps the page was brought in from swap between find_lock_page | ||
| 1498 | * and taking info->lock? We allow for that at add_to_page_cache_lru, | ||
| 1499 | * but must also avoid reporting a spurious ENOSPC while working on a | ||
| 1500 | * full tmpfs. (When filepage has been passed in to shmem_getpage, it | ||
| 1501 | * is already in page cache, which prevents this race from occurring.) | ||
| 1502 | */ | ||
| 1503 | if (!filepage) { | ||
| 1504 | struct page *page = find_get_page(mapping, idx); | ||
| 1505 | if (page) { | ||
| 1506 | spin_unlock(&info->lock); | ||
| 1507 | page_cache_release(page); | ||
| 1508 | goto repeat; | ||
| 1509 | } | ||
| 1510 | } | ||
| 1511 | spin_unlock(&info->lock); | ||
| 1512 | error = -ENOSPC; | ||
| 1496 | failed: | 1513 | failed: |
| 1497 | if (*pagep != filepage) { | 1514 | if (*pagep != filepage) { |
| 1498 | unlock_page(filepage); | 1515 | unlock_page(filepage); |
| @@ -396,6 +396,9 @@ static void lru_deactivate_fn(struct page *page, void *arg) | |||
| 396 | if (!PageLRU(page)) | 396 | if (!PageLRU(page)) |
| 397 | return; | 397 | return; |
| 398 | 398 | ||
| 399 | if (PageUnevictable(page)) | ||
| 400 | return; | ||
| 401 | |||
| 399 | /* Some processes are using the page */ | 402 | /* Some processes are using the page */ |
| 400 | if (page_mapped(page)) | 403 | if (page_mapped(page)) |
| 401 | return; | 404 | return; |
diff --git a/mm/vmscan.c b/mm/vmscan.c index f6b435c80079..8bfd45050a61 100644 --- a/mm/vmscan.c +++ b/mm/vmscan.c | |||
| @@ -937,7 +937,7 @@ keep_lumpy: | |||
| 937 | * back off and wait for congestion to clear because further reclaim | 937 | * back off and wait for congestion to clear because further reclaim |
| 938 | * will encounter the same problem | 938 | * will encounter the same problem |
| 939 | */ | 939 | */ |
| 940 | if (nr_dirty == nr_congested && nr_dirty != 0) | 940 | if (nr_dirty && nr_dirty == nr_congested && scanning_global_lru(sc)) |
| 941 | zone_set_flag(zone, ZONE_CONGESTED); | 941 | zone_set_flag(zone, ZONE_CONGESTED); |
| 942 | 942 | ||
| 943 | free_page_list(&free_pages); | 943 | free_page_list(&free_pages); |
diff --git a/net/8021q/vlan.c b/net/8021q/vlan.c index 7850412f52b7..0eb1a886b370 100644 --- a/net/8021q/vlan.c +++ b/net/8021q/vlan.c | |||
| @@ -124,6 +124,9 @@ void unregister_vlan_dev(struct net_device *dev, struct list_head *head) | |||
| 124 | 124 | ||
| 125 | grp->nr_vlans--; | 125 | grp->nr_vlans--; |
| 126 | 126 | ||
| 127 | if (vlan->flags & VLAN_FLAG_GVRP) | ||
| 128 | vlan_gvrp_request_leave(dev); | ||
| 129 | |||
| 127 | vlan_group_set_device(grp, vlan_id, NULL); | 130 | vlan_group_set_device(grp, vlan_id, NULL); |
| 128 | if (!grp->killall) | 131 | if (!grp->killall) |
| 129 | synchronize_net(); | 132 | synchronize_net(); |
diff --git a/net/8021q/vlan_dev.c b/net/8021q/vlan_dev.c index e34ea9e5e28b..b2ff6c8d3603 100644 --- a/net/8021q/vlan_dev.c +++ b/net/8021q/vlan_dev.c | |||
| @@ -487,9 +487,6 @@ static int vlan_dev_stop(struct net_device *dev) | |||
| 487 | struct vlan_dev_info *vlan = vlan_dev_info(dev); | 487 | struct vlan_dev_info *vlan = vlan_dev_info(dev); |
| 488 | struct net_device *real_dev = vlan->real_dev; | 488 | struct net_device *real_dev = vlan->real_dev; |
| 489 | 489 | ||
| 490 | if (vlan->flags & VLAN_FLAG_GVRP) | ||
| 491 | vlan_gvrp_request_leave(dev); | ||
| 492 | |||
| 493 | dev_mc_unsync(real_dev, dev); | 490 | dev_mc_unsync(real_dev, dev); |
| 494 | dev_uc_unsync(real_dev, dev); | 491 | dev_uc_unsync(real_dev, dev); |
| 495 | if (dev->flags & IFF_ALLMULTI) | 492 | if (dev->flags & IFF_ALLMULTI) |
diff --git a/net/9p/client.c b/net/9p/client.c index 77367745be9b..a9aa2dd66482 100644 --- a/net/9p/client.c +++ b/net/9p/client.c | |||
| @@ -614,7 +614,7 @@ p9_client_rpc(struct p9_client *c, int8_t type, const char *fmt, ...) | |||
| 614 | 614 | ||
| 615 | err = c->trans_mod->request(c, req); | 615 | err = c->trans_mod->request(c, req); |
| 616 | if (err < 0) { | 616 | if (err < 0) { |
| 617 | if (err != -ERESTARTSYS) | 617 | if (err != -ERESTARTSYS && err != -EFAULT) |
| 618 | c->status = Disconnected; | 618 | c->status = Disconnected; |
| 619 | goto reterr; | 619 | goto reterr; |
| 620 | } | 620 | } |
diff --git a/net/9p/protocol.c b/net/9p/protocol.c index b58a501cf3d1..a873277cb996 100644 --- a/net/9p/protocol.c +++ b/net/9p/protocol.c | |||
| @@ -674,6 +674,7 @@ int p9dirent_read(char *buf, int len, struct p9_dirent *dirent, | |||
| 674 | } | 674 | } |
| 675 | 675 | ||
| 676 | strcpy(dirent->d_name, nameptr); | 676 | strcpy(dirent->d_name, nameptr); |
| 677 | kfree(nameptr); | ||
| 677 | 678 | ||
| 678 | out: | 679 | out: |
| 679 | return fake_pdu.offset; | 680 | return fake_pdu.offset; |
diff --git a/net/9p/trans_common.c b/net/9p/trans_common.c index e883172f9aa2..9a70ebdec56e 100644 --- a/net/9p/trans_common.c +++ b/net/9p/trans_common.c | |||
| @@ -63,7 +63,7 @@ p9_payload_gup(struct p9_req_t *req, size_t *pdata_off, int *pdata_len, | |||
| 63 | int nr_pages, u8 rw) | 63 | int nr_pages, u8 rw) |
| 64 | { | 64 | { |
| 65 | uint32_t first_page_bytes = 0; | 65 | uint32_t first_page_bytes = 0; |
| 66 | uint32_t pdata_mapped_pages; | 66 | int32_t pdata_mapped_pages; |
| 67 | struct trans_rpage_info *rpinfo; | 67 | struct trans_rpage_info *rpinfo; |
| 68 | 68 | ||
| 69 | *pdata_off = (__force size_t)req->tc->pubuf & (PAGE_SIZE-1); | 69 | *pdata_off = (__force size_t)req->tc->pubuf & (PAGE_SIZE-1); |
| @@ -75,14 +75,9 @@ p9_payload_gup(struct p9_req_t *req, size_t *pdata_off, int *pdata_len, | |||
| 75 | rpinfo = req->tc->private; | 75 | rpinfo = req->tc->private; |
| 76 | pdata_mapped_pages = get_user_pages_fast((unsigned long)req->tc->pubuf, | 76 | pdata_mapped_pages = get_user_pages_fast((unsigned long)req->tc->pubuf, |
| 77 | nr_pages, rw, &rpinfo->rp_data[0]); | 77 | nr_pages, rw, &rpinfo->rp_data[0]); |
| 78 | if (pdata_mapped_pages <= 0) | ||
| 79 | return pdata_mapped_pages; | ||
| 78 | 80 | ||
| 79 | if (pdata_mapped_pages < 0) { | ||
| 80 | printk(KERN_ERR "get_user_pages_fast failed:%d udata:%p" | ||
| 81 | "nr_pages:%d\n", pdata_mapped_pages, | ||
| 82 | req->tc->pubuf, nr_pages); | ||
| 83 | pdata_mapped_pages = 0; | ||
| 84 | return -EIO; | ||
| 85 | } | ||
| 86 | rpinfo->rp_nr_pages = pdata_mapped_pages; | 81 | rpinfo->rp_nr_pages = pdata_mapped_pages; |
| 87 | if (*pdata_off) { | 82 | if (*pdata_off) { |
| 88 | *pdata_len = first_page_bytes; | 83 | *pdata_len = first_page_bytes; |
diff --git a/net/bluetooth/sco.c b/net/bluetooth/sco.c index 94954c74f6ae..42fdffd1d76c 100644 --- a/net/bluetooth/sco.c +++ b/net/bluetooth/sco.c | |||
| @@ -369,15 +369,6 @@ static void __sco_sock_close(struct sock *sk) | |||
| 369 | 369 | ||
| 370 | case BT_CONNECTED: | 370 | case BT_CONNECTED: |
| 371 | case BT_CONFIG: | 371 | case BT_CONFIG: |
| 372 | if (sco_pi(sk)->conn) { | ||
| 373 | sk->sk_state = BT_DISCONN; | ||
| 374 | sco_sock_set_timer(sk, SCO_DISCONN_TIMEOUT); | ||
| 375 | hci_conn_put(sco_pi(sk)->conn->hcon); | ||
| 376 | sco_pi(sk)->conn = NULL; | ||
| 377 | } else | ||
| 378 | sco_chan_del(sk, ECONNRESET); | ||
| 379 | break; | ||
| 380 | |||
| 381 | case BT_CONNECT: | 372 | case BT_CONNECT: |
| 382 | case BT_DISCONN: | 373 | case BT_DISCONN: |
| 383 | sco_chan_del(sk, ECONNRESET); | 374 | sco_chan_del(sk, ECONNRESET); |
diff --git a/net/bridge/br_netfilter.c b/net/bridge/br_netfilter.c index f3bc322c5891..74ef4d4846a4 100644 --- a/net/bridge/br_netfilter.c +++ b/net/bridge/br_netfilter.c | |||
| @@ -737,7 +737,7 @@ static unsigned int br_nf_forward_ip(unsigned int hook, struct sk_buff *skb, | |||
| 737 | nf_bridge->mask |= BRNF_PKT_TYPE; | 737 | nf_bridge->mask |= BRNF_PKT_TYPE; |
| 738 | } | 738 | } |
| 739 | 739 | ||
| 740 | if (br_parse_ip_options(skb)) | 740 | if (pf == PF_INET && br_parse_ip_options(skb)) |
| 741 | return NF_DROP; | 741 | return NF_DROP; |
| 742 | 742 | ||
| 743 | /* The physdev module checks on this */ | 743 | /* The physdev module checks on this */ |
diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c index 893669caa8de..1a92b369c820 100644 --- a/net/bridge/netfilter/ebtables.c +++ b/net/bridge/netfilter/ebtables.c | |||
| @@ -1766,7 +1766,7 @@ static int compat_table_info(const struct ebt_table_info *info, | |||
| 1766 | 1766 | ||
| 1767 | newinfo->entries_size = size; | 1767 | newinfo->entries_size = size; |
| 1768 | 1768 | ||
| 1769 | xt_compat_init_offsets(AF_INET, info->nentries); | 1769 | xt_compat_init_offsets(NFPROTO_BRIDGE, info->nentries); |
| 1770 | return EBT_ENTRY_ITERATE(entries, size, compat_calc_entry, info, | 1770 | return EBT_ENTRY_ITERATE(entries, size, compat_calc_entry, info, |
| 1771 | entries, newinfo); | 1771 | entries, newinfo); |
| 1772 | } | 1772 | } |
| @@ -1882,7 +1882,7 @@ static int compat_mtw_from_user(struct compat_ebt_entry_mwt *mwt, | |||
| 1882 | struct xt_match *match; | 1882 | struct xt_match *match; |
| 1883 | struct xt_target *wt; | 1883 | struct xt_target *wt; |
| 1884 | void *dst = NULL; | 1884 | void *dst = NULL; |
| 1885 | int off, pad = 0, ret = 0; | 1885 | int off, pad = 0; |
| 1886 | unsigned int size_kern, entry_offset, match_size = mwt->match_size; | 1886 | unsigned int size_kern, entry_offset, match_size = mwt->match_size; |
| 1887 | 1887 | ||
| 1888 | strlcpy(name, mwt->u.name, sizeof(name)); | 1888 | strlcpy(name, mwt->u.name, sizeof(name)); |
| @@ -1935,13 +1935,6 @@ static int compat_mtw_from_user(struct compat_ebt_entry_mwt *mwt, | |||
| 1935 | break; | 1935 | break; |
| 1936 | } | 1936 | } |
| 1937 | 1937 | ||
| 1938 | if (!dst) { | ||
| 1939 | ret = xt_compat_add_offset(NFPROTO_BRIDGE, entry_offset, | ||
| 1940 | off + ebt_compat_entry_padsize()); | ||
| 1941 | if (ret < 0) | ||
| 1942 | return ret; | ||
| 1943 | } | ||
| 1944 | |||
| 1945 | state->buf_kern_offset += match_size + off; | 1938 | state->buf_kern_offset += match_size + off; |
| 1946 | state->buf_user_offset += match_size; | 1939 | state->buf_user_offset += match_size; |
| 1947 | pad = XT_ALIGN(size_kern) - size_kern; | 1940 | pad = XT_ALIGN(size_kern) - size_kern; |
| @@ -2016,50 +2009,6 @@ static int ebt_size_mwt(struct compat_ebt_entry_mwt *match32, | |||
| 2016 | return growth; | 2009 | return growth; |
| 2017 | } | 2010 | } |
| 2018 | 2011 | ||
| 2019 | #define EBT_COMPAT_WATCHER_ITERATE(e, fn, args...) \ | ||
| 2020 | ({ \ | ||
| 2021 | unsigned int __i; \ | ||
| 2022 | int __ret = 0; \ | ||
| 2023 | struct compat_ebt_entry_mwt *__watcher; \ | ||
| 2024 | \ | ||
| 2025 | for (__i = e->watchers_offset; \ | ||
| 2026 | __i < (e)->target_offset; \ | ||
| 2027 | __i += __watcher->watcher_size + \ | ||
| 2028 | sizeof(struct compat_ebt_entry_mwt)) { \ | ||
| 2029 | __watcher = (void *)(e) + __i; \ | ||
| 2030 | __ret = fn(__watcher , ## args); \ | ||
| 2031 | if (__ret != 0) \ | ||
| 2032 | break; \ | ||
| 2033 | } \ | ||
| 2034 | if (__ret == 0) { \ | ||
| 2035 | if (__i != (e)->target_offset) \ | ||
| 2036 | __ret = -EINVAL; \ | ||
| 2037 | } \ | ||
| 2038 | __ret; \ | ||
| 2039 | }) | ||
| 2040 | |||
| 2041 | #define EBT_COMPAT_MATCH_ITERATE(e, fn, args...) \ | ||
| 2042 | ({ \ | ||
| 2043 | unsigned int __i; \ | ||
| 2044 | int __ret = 0; \ | ||
| 2045 | struct compat_ebt_entry_mwt *__match; \ | ||
| 2046 | \ | ||
| 2047 | for (__i = sizeof(struct ebt_entry); \ | ||
| 2048 | __i < (e)->watchers_offset; \ | ||
| 2049 | __i += __match->match_size + \ | ||
| 2050 | sizeof(struct compat_ebt_entry_mwt)) { \ | ||
| 2051 | __match = (void *)(e) + __i; \ | ||
| 2052 | __ret = fn(__match , ## args); \ | ||
| 2053 | if (__ret != 0) \ | ||
| 2054 | break; \ | ||
| 2055 | } \ | ||
| 2056 | if (__ret == 0) { \ | ||
| 2057 | if (__i != (e)->watchers_offset) \ | ||
| 2058 | __ret = -EINVAL; \ | ||
| 2059 | } \ | ||
| 2060 | __ret; \ | ||
| 2061 | }) | ||
| 2062 | |||
| 2063 | /* called for all ebt_entry structures. */ | 2012 | /* called for all ebt_entry structures. */ |
| 2064 | static int size_entry_mwt(struct ebt_entry *entry, const unsigned char *base, | 2013 | static int size_entry_mwt(struct ebt_entry *entry, const unsigned char *base, |
| 2065 | unsigned int *total, | 2014 | unsigned int *total, |
| @@ -2132,6 +2081,14 @@ static int size_entry_mwt(struct ebt_entry *entry, const unsigned char *base, | |||
| 2132 | } | 2081 | } |
| 2133 | } | 2082 | } |
| 2134 | 2083 | ||
| 2084 | if (state->buf_kern_start == NULL) { | ||
| 2085 | unsigned int offset = buf_start - (char *) base; | ||
| 2086 | |||
| 2087 | ret = xt_compat_add_offset(NFPROTO_BRIDGE, offset, new_offset); | ||
| 2088 | if (ret < 0) | ||
| 2089 | return ret; | ||
| 2090 | } | ||
| 2091 | |||
| 2135 | startoff = state->buf_user_offset - startoff; | 2092 | startoff = state->buf_user_offset - startoff; |
| 2136 | 2093 | ||
| 2137 | BUG_ON(*total < startoff); | 2094 | BUG_ON(*total < startoff); |
| @@ -2240,6 +2197,7 @@ static int compat_do_replace(struct net *net, void __user *user, | |||
| 2240 | 2197 | ||
| 2241 | xt_compat_lock(NFPROTO_BRIDGE); | 2198 | xt_compat_lock(NFPROTO_BRIDGE); |
| 2242 | 2199 | ||
| 2200 | xt_compat_init_offsets(NFPROTO_BRIDGE, tmp.nentries); | ||
| 2243 | ret = compat_copy_entries(entries_tmp, tmp.entries_size, &state); | 2201 | ret = compat_copy_entries(entries_tmp, tmp.entries_size, &state); |
| 2244 | if (ret < 0) | 2202 | if (ret < 0) |
| 2245 | goto out_unlock; | 2203 | goto out_unlock; |
diff --git a/net/core/dev.c b/net/core/dev.c index 856b6ee9a1d5..b624fe4d9bd7 100644 --- a/net/core/dev.c +++ b/net/core/dev.c | |||
| @@ -1284,11 +1284,13 @@ static int dev_close_many(struct list_head *head) | |||
| 1284 | */ | 1284 | */ |
| 1285 | int dev_close(struct net_device *dev) | 1285 | int dev_close(struct net_device *dev) |
| 1286 | { | 1286 | { |
| 1287 | LIST_HEAD(single); | 1287 | if (dev->flags & IFF_UP) { |
| 1288 | LIST_HEAD(single); | ||
| 1288 | 1289 | ||
| 1289 | list_add(&dev->unreg_list, &single); | 1290 | list_add(&dev->unreg_list, &single); |
| 1290 | dev_close_many(&single); | 1291 | dev_close_many(&single); |
| 1291 | list_del(&single); | 1292 | list_del(&single); |
| 1293 | } | ||
| 1292 | return 0; | 1294 | return 0; |
| 1293 | } | 1295 | } |
| 1294 | EXPORT_SYMBOL(dev_close); | 1296 | EXPORT_SYMBOL(dev_close); |
| @@ -5184,27 +5186,27 @@ u32 netdev_fix_features(struct net_device *dev, u32 features) | |||
| 5184 | /* Fix illegal checksum combinations */ | 5186 | /* Fix illegal checksum combinations */ |
| 5185 | if ((features & NETIF_F_HW_CSUM) && | 5187 | if ((features & NETIF_F_HW_CSUM) && |
| 5186 | (features & (NETIF_F_IP_CSUM|NETIF_F_IPV6_CSUM))) { | 5188 | (features & (NETIF_F_IP_CSUM|NETIF_F_IPV6_CSUM))) { |
| 5187 | netdev_info(dev, "mixed HW and IP checksum settings.\n"); | 5189 | netdev_warn(dev, "mixed HW and IP checksum settings.\n"); |
| 5188 | features &= ~(NETIF_F_IP_CSUM|NETIF_F_IPV6_CSUM); | 5190 | features &= ~(NETIF_F_IP_CSUM|NETIF_F_IPV6_CSUM); |
| 5189 | } | 5191 | } |
| 5190 | 5192 | ||
| 5191 | if ((features & NETIF_F_NO_CSUM) && | 5193 | if ((features & NETIF_F_NO_CSUM) && |
| 5192 | (features & (NETIF_F_HW_CSUM|NETIF_F_IP_CSUM|NETIF_F_IPV6_CSUM))) { | 5194 | (features & (NETIF_F_HW_CSUM|NETIF_F_IP_CSUM|NETIF_F_IPV6_CSUM))) { |
| 5193 | netdev_info(dev, "mixed no checksumming and other settings.\n"); | 5195 | netdev_warn(dev, "mixed no checksumming and other settings.\n"); |
| 5194 | features &= ~(NETIF_F_IP_CSUM|NETIF_F_IPV6_CSUM|NETIF_F_HW_CSUM); | 5196 | features &= ~(NETIF_F_IP_CSUM|NETIF_F_IPV6_CSUM|NETIF_F_HW_CSUM); |
| 5195 | } | 5197 | } |
| 5196 | 5198 | ||
| 5197 | /* Fix illegal SG+CSUM combinations. */ | 5199 | /* Fix illegal SG+CSUM combinations. */ |
| 5198 | if ((features & NETIF_F_SG) && | 5200 | if ((features & NETIF_F_SG) && |
| 5199 | !(features & NETIF_F_ALL_CSUM)) { | 5201 | !(features & NETIF_F_ALL_CSUM)) { |
| 5200 | netdev_info(dev, | 5202 | netdev_dbg(dev, |
| 5201 | "Dropping NETIF_F_SG since no checksum feature.\n"); | 5203 | "Dropping NETIF_F_SG since no checksum feature.\n"); |
| 5202 | features &= ~NETIF_F_SG; | 5204 | features &= ~NETIF_F_SG; |
| 5203 | } | 5205 | } |
| 5204 | 5206 | ||
| 5205 | /* TSO requires that SG is present as well. */ | 5207 | /* TSO requires that SG is present as well. */ |
| 5206 | if ((features & NETIF_F_ALL_TSO) && !(features & NETIF_F_SG)) { | 5208 | if ((features & NETIF_F_ALL_TSO) && !(features & NETIF_F_SG)) { |
| 5207 | netdev_info(dev, "Dropping TSO features since no SG feature.\n"); | 5209 | netdev_dbg(dev, "Dropping TSO features since no SG feature.\n"); |
| 5208 | features &= ~NETIF_F_ALL_TSO; | 5210 | features &= ~NETIF_F_ALL_TSO; |
| 5209 | } | 5211 | } |
| 5210 | 5212 | ||
| @@ -5214,7 +5216,7 @@ u32 netdev_fix_features(struct net_device *dev, u32 features) | |||
| 5214 | 5216 | ||
| 5215 | /* Software GSO depends on SG. */ | 5217 | /* Software GSO depends on SG. */ |
| 5216 | if ((features & NETIF_F_GSO) && !(features & NETIF_F_SG)) { | 5218 | if ((features & NETIF_F_GSO) && !(features & NETIF_F_SG)) { |
| 5217 | netdev_info(dev, "Dropping NETIF_F_GSO since no SG feature.\n"); | 5219 | netdev_dbg(dev, "Dropping NETIF_F_GSO since no SG feature.\n"); |
| 5218 | features &= ~NETIF_F_GSO; | 5220 | features &= ~NETIF_F_GSO; |
| 5219 | } | 5221 | } |
| 5220 | 5222 | ||
| @@ -5224,13 +5226,13 @@ u32 netdev_fix_features(struct net_device *dev, u32 features) | |||
| 5224 | if (!((features & NETIF_F_GEN_CSUM) || | 5226 | if (!((features & NETIF_F_GEN_CSUM) || |
| 5225 | (features & (NETIF_F_IP_CSUM|NETIF_F_IPV6_CSUM)) | 5227 | (features & (NETIF_F_IP_CSUM|NETIF_F_IPV6_CSUM)) |
| 5226 | == (NETIF_F_IP_CSUM|NETIF_F_IPV6_CSUM))) { | 5228 | == (NETIF_F_IP_CSUM|NETIF_F_IPV6_CSUM))) { |
| 5227 | netdev_info(dev, | 5229 | netdev_dbg(dev, |
| 5228 | "Dropping NETIF_F_UFO since no checksum offload features.\n"); | 5230 | "Dropping NETIF_F_UFO since no checksum offload features.\n"); |
| 5229 | features &= ~NETIF_F_UFO; | 5231 | features &= ~NETIF_F_UFO; |
| 5230 | } | 5232 | } |
| 5231 | 5233 | ||
| 5232 | if (!(features & NETIF_F_SG)) { | 5234 | if (!(features & NETIF_F_SG)) { |
| 5233 | netdev_info(dev, | 5235 | netdev_dbg(dev, |
| 5234 | "Dropping NETIF_F_UFO since no NETIF_F_SG feature.\n"); | 5236 | "Dropping NETIF_F_UFO since no NETIF_F_SG feature.\n"); |
| 5235 | features &= ~NETIF_F_UFO; | 5237 | features &= ~NETIF_F_UFO; |
| 5236 | } | 5238 | } |
| @@ -5412,12 +5414,6 @@ int register_netdevice(struct net_device *dev) | |||
| 5412 | dev->features |= NETIF_F_SOFT_FEATURES; | 5414 | dev->features |= NETIF_F_SOFT_FEATURES; |
| 5413 | dev->wanted_features = dev->features & dev->hw_features; | 5415 | dev->wanted_features = dev->features & dev->hw_features; |
| 5414 | 5416 | ||
| 5415 | /* Avoid warning from netdev_fix_features() for GSO without SG */ | ||
| 5416 | if (!(dev->wanted_features & NETIF_F_SG)) { | ||
| 5417 | dev->wanted_features &= ~NETIF_F_GSO; | ||
| 5418 | dev->features &= ~NETIF_F_GSO; | ||
| 5419 | } | ||
| 5420 | |||
| 5421 | /* Enable GRO and NETIF_F_HIGHDMA for vlans by default, | 5417 | /* Enable GRO and NETIF_F_HIGHDMA for vlans by default, |
| 5422 | * vlan_dev_init() will do the dev->features check, so these features | 5418 | * vlan_dev_init() will do the dev->features check, so these features |
| 5423 | * are enabled only if supported by underlying device. | 5419 | * are enabled only if supported by underlying device. |
diff --git a/net/dccp/options.c b/net/dccp/options.c index f06ffcfc8d71..4b2ab657ac8e 100644 --- a/net/dccp/options.c +++ b/net/dccp/options.c | |||
| @@ -123,6 +123,8 @@ int dccp_parse_options(struct sock *sk, struct dccp_request_sock *dreq, | |||
| 123 | case DCCPO_CHANGE_L ... DCCPO_CONFIRM_R: | 123 | case DCCPO_CHANGE_L ... DCCPO_CONFIRM_R: |
| 124 | if (pkt_type == DCCP_PKT_DATA) /* RFC 4340, 6 */ | 124 | if (pkt_type == DCCP_PKT_DATA) /* RFC 4340, 6 */ |
| 125 | break; | 125 | break; |
| 126 | if (len == 0) | ||
| 127 | goto out_invalid_option; | ||
| 126 | rc = dccp_feat_parse_options(sk, dreq, mandatory, opt, | 128 | rc = dccp_feat_parse_options(sk, dreq, mandatory, opt, |
| 127 | *value, value + 1, len - 1); | 129 | *value, value + 1, len - 1); |
| 128 | if (rc) | 130 | if (rc) |
diff --git a/net/ipv4/ip_fragment.c b/net/ipv4/ip_fragment.c index a1151b8adf3c..b1d282f11be7 100644 --- a/net/ipv4/ip_fragment.c +++ b/net/ipv4/ip_fragment.c | |||
| @@ -223,31 +223,30 @@ static void ip_expire(unsigned long arg) | |||
| 223 | 223 | ||
| 224 | if ((qp->q.last_in & INET_FRAG_FIRST_IN) && qp->q.fragments != NULL) { | 224 | if ((qp->q.last_in & INET_FRAG_FIRST_IN) && qp->q.fragments != NULL) { |
| 225 | struct sk_buff *head = qp->q.fragments; | 225 | struct sk_buff *head = qp->q.fragments; |
| 226 | const struct iphdr *iph; | ||
| 227 | int err; | ||
| 226 | 228 | ||
| 227 | rcu_read_lock(); | 229 | rcu_read_lock(); |
| 228 | head->dev = dev_get_by_index_rcu(net, qp->iif); | 230 | head->dev = dev_get_by_index_rcu(net, qp->iif); |
| 229 | if (!head->dev) | 231 | if (!head->dev) |
| 230 | goto out_rcu_unlock; | 232 | goto out_rcu_unlock; |
| 231 | 233 | ||
| 234 | /* skb dst is stale, drop it, and perform route lookup again */ | ||
| 235 | skb_dst_drop(head); | ||
| 236 | iph = ip_hdr(head); | ||
| 237 | err = ip_route_input_noref(head, iph->daddr, iph->saddr, | ||
| 238 | iph->tos, head->dev); | ||
| 239 | if (err) | ||
| 240 | goto out_rcu_unlock; | ||
| 241 | |||
| 232 | /* | 242 | /* |
| 233 | * Only search router table for the head fragment, | 243 | * Only an end host needs to send an ICMP |
| 234 | * when defraging timeout at PRE_ROUTING HOOK. | 244 | * "Fragment Reassembly Timeout" message, per RFC792. |
| 235 | */ | 245 | */ |
| 236 | if (qp->user == IP_DEFRAG_CONNTRACK_IN && !skb_dst(head)) { | 246 | if (qp->user == IP_DEFRAG_CONNTRACK_IN && |
| 237 | const struct iphdr *iph = ip_hdr(head); | 247 | skb_rtable(head)->rt_type != RTN_LOCAL) |
| 238 | int err = ip_route_input(head, iph->daddr, iph->saddr, | 248 | goto out_rcu_unlock; |
| 239 | iph->tos, head->dev); | ||
| 240 | if (unlikely(err)) | ||
| 241 | goto out_rcu_unlock; | ||
| 242 | |||
| 243 | /* | ||
| 244 | * Only an end host needs to send an ICMP | ||
| 245 | * "Fragment Reassembly Timeout" message, per RFC792. | ||
| 246 | */ | ||
| 247 | if (skb_rtable(head)->rt_type != RTN_LOCAL) | ||
| 248 | goto out_rcu_unlock; | ||
| 249 | 249 | ||
| 250 | } | ||
| 251 | 250 | ||
| 252 | /* Send an ICMP "Fragment Reassembly Timeout" message. */ | 251 | /* Send an ICMP "Fragment Reassembly Timeout" message. */ |
| 253 | icmp_send(head, ICMP_TIME_EXCEEDED, ICMP_EXC_FRAGTIME, 0); | 252 | icmp_send(head, ICMP_TIME_EXCEEDED, ICMP_EXC_FRAGTIME, 0); |
diff --git a/net/ipv4/tcp_cubic.c b/net/ipv4/tcp_cubic.c index 34340c9c95fa..f376b05cca81 100644 --- a/net/ipv4/tcp_cubic.c +++ b/net/ipv4/tcp_cubic.c | |||
| @@ -93,6 +93,7 @@ struct bictcp { | |||
| 93 | u32 ack_cnt; /* number of acks */ | 93 | u32 ack_cnt; /* number of acks */ |
| 94 | u32 tcp_cwnd; /* estimated tcp cwnd */ | 94 | u32 tcp_cwnd; /* estimated tcp cwnd */ |
| 95 | #define ACK_RATIO_SHIFT 4 | 95 | #define ACK_RATIO_SHIFT 4 |
| 96 | #define ACK_RATIO_LIMIT (32u << ACK_RATIO_SHIFT) | ||
| 96 | u16 delayed_ack; /* estimate the ratio of Packets/ACKs << 4 */ | 97 | u16 delayed_ack; /* estimate the ratio of Packets/ACKs << 4 */ |
| 97 | u8 sample_cnt; /* number of samples to decide curr_rtt */ | 98 | u8 sample_cnt; /* number of samples to decide curr_rtt */ |
| 98 | u8 found; /* the exit point is found? */ | 99 | u8 found; /* the exit point is found? */ |
| @@ -398,8 +399,12 @@ static void bictcp_acked(struct sock *sk, u32 cnt, s32 rtt_us) | |||
| 398 | u32 delay; | 399 | u32 delay; |
| 399 | 400 | ||
| 400 | if (icsk->icsk_ca_state == TCP_CA_Open) { | 401 | if (icsk->icsk_ca_state == TCP_CA_Open) { |
| 401 | cnt -= ca->delayed_ack >> ACK_RATIO_SHIFT; | 402 | u32 ratio = ca->delayed_ack; |
| 402 | ca->delayed_ack += cnt; | 403 | |
| 404 | ratio -= ca->delayed_ack >> ACK_RATIO_SHIFT; | ||
| 405 | ratio += cnt; | ||
| 406 | |||
| 407 | ca->delayed_ack = min(ratio, ACK_RATIO_LIMIT); | ||
| 403 | } | 408 | } |
| 404 | 409 | ||
| 405 | /* Some calls are for duplicates without timetamps */ | 410 | /* Some calls are for duplicates without timetamps */ |
diff --git a/net/ipv4/xfrm4_output.c b/net/ipv4/xfrm4_output.c index 571aa96a175c..2d51840e53a1 100644 --- a/net/ipv4/xfrm4_output.c +++ b/net/ipv4/xfrm4_output.c | |||
| @@ -69,7 +69,7 @@ int xfrm4_prepare_output(struct xfrm_state *x, struct sk_buff *skb) | |||
| 69 | } | 69 | } |
| 70 | EXPORT_SYMBOL(xfrm4_prepare_output); | 70 | EXPORT_SYMBOL(xfrm4_prepare_output); |
| 71 | 71 | ||
| 72 | static int xfrm4_output_finish(struct sk_buff *skb) | 72 | int xfrm4_output_finish(struct sk_buff *skb) |
| 73 | { | 73 | { |
| 74 | #ifdef CONFIG_NETFILTER | 74 | #ifdef CONFIG_NETFILTER |
| 75 | if (!skb_dst(skb)->xfrm) { | 75 | if (!skb_dst(skb)->xfrm) { |
| @@ -86,7 +86,11 @@ static int xfrm4_output_finish(struct sk_buff *skb) | |||
| 86 | 86 | ||
| 87 | int xfrm4_output(struct sk_buff *skb) | 87 | int xfrm4_output(struct sk_buff *skb) |
| 88 | { | 88 | { |
| 89 | struct dst_entry *dst = skb_dst(skb); | ||
| 90 | struct xfrm_state *x = dst->xfrm; | ||
| 91 | |||
| 89 | return NF_HOOK_COND(NFPROTO_IPV4, NF_INET_POST_ROUTING, skb, | 92 | return NF_HOOK_COND(NFPROTO_IPV4, NF_INET_POST_ROUTING, skb, |
| 90 | NULL, skb_dst(skb)->dev, xfrm4_output_finish, | 93 | NULL, dst->dev, |
| 94 | x->outer_mode->afinfo->output_finish, | ||
| 91 | !(IPCB(skb)->flags & IPSKB_REROUTED)); | 95 | !(IPCB(skb)->flags & IPSKB_REROUTED)); |
| 92 | } | 96 | } |
diff --git a/net/ipv4/xfrm4_state.c b/net/ipv4/xfrm4_state.c index 1717c64628d1..805d63ef4340 100644 --- a/net/ipv4/xfrm4_state.c +++ b/net/ipv4/xfrm4_state.c | |||
| @@ -78,6 +78,7 @@ static struct xfrm_state_afinfo xfrm4_state_afinfo = { | |||
| 78 | .init_tempsel = __xfrm4_init_tempsel, | 78 | .init_tempsel = __xfrm4_init_tempsel, |
| 79 | .init_temprop = xfrm4_init_temprop, | 79 | .init_temprop = xfrm4_init_temprop, |
| 80 | .output = xfrm4_output, | 80 | .output = xfrm4_output, |
| 81 | .output_finish = xfrm4_output_finish, | ||
| 81 | .extract_input = xfrm4_extract_input, | 82 | .extract_input = xfrm4_extract_input, |
| 82 | .extract_output = xfrm4_extract_output, | 83 | .extract_output = xfrm4_extract_output, |
| 83 | .transport_finish = xfrm4_transport_finish, | 84 | .transport_finish = xfrm4_transport_finish, |
diff --git a/net/ipv6/netfilter/ip6t_REJECT.c b/net/ipv6/netfilter/ip6t_REJECT.c index 28e74488a329..a5a4c5dd5396 100644 --- a/net/ipv6/netfilter/ip6t_REJECT.c +++ b/net/ipv6/netfilter/ip6t_REJECT.c | |||
| @@ -45,6 +45,8 @@ static void send_reset(struct net *net, struct sk_buff *oldskb) | |||
| 45 | int tcphoff, needs_ack; | 45 | int tcphoff, needs_ack; |
| 46 | const struct ipv6hdr *oip6h = ipv6_hdr(oldskb); | 46 | const struct ipv6hdr *oip6h = ipv6_hdr(oldskb); |
| 47 | struct ipv6hdr *ip6h; | 47 | struct ipv6hdr *ip6h; |
| 48 | #define DEFAULT_TOS_VALUE 0x0U | ||
| 49 | const __u8 tclass = DEFAULT_TOS_VALUE; | ||
| 48 | struct dst_entry *dst = NULL; | 50 | struct dst_entry *dst = NULL; |
| 49 | u8 proto; | 51 | u8 proto; |
| 50 | struct flowi6 fl6; | 52 | struct flowi6 fl6; |
| @@ -124,7 +126,7 @@ static void send_reset(struct net *net, struct sk_buff *oldskb) | |||
| 124 | skb_put(nskb, sizeof(struct ipv6hdr)); | 126 | skb_put(nskb, sizeof(struct ipv6hdr)); |
| 125 | skb_reset_network_header(nskb); | 127 | skb_reset_network_header(nskb); |
| 126 | ip6h = ipv6_hdr(nskb); | 128 | ip6h = ipv6_hdr(nskb); |
| 127 | ip6h->version = 6; | 129 | *(__be32 *)ip6h = htonl(0x60000000 | (tclass << 20)); |
| 128 | ip6h->hop_limit = ip6_dst_hoplimit(dst); | 130 | ip6h->hop_limit = ip6_dst_hoplimit(dst); |
| 129 | ip6h->nexthdr = IPPROTO_TCP; | 131 | ip6h->nexthdr = IPPROTO_TCP; |
| 130 | ipv6_addr_copy(&ip6h->saddr, &oip6h->daddr); | 132 | ipv6_addr_copy(&ip6h->saddr, &oip6h->daddr); |
diff --git a/net/ipv6/xfrm6_output.c b/net/ipv6/xfrm6_output.c index 8e688b3de9ab..49a91c5f5623 100644 --- a/net/ipv6/xfrm6_output.c +++ b/net/ipv6/xfrm6_output.c | |||
| @@ -79,7 +79,7 @@ int xfrm6_prepare_output(struct xfrm_state *x, struct sk_buff *skb) | |||
| 79 | } | 79 | } |
| 80 | EXPORT_SYMBOL(xfrm6_prepare_output); | 80 | EXPORT_SYMBOL(xfrm6_prepare_output); |
| 81 | 81 | ||
| 82 | static int xfrm6_output_finish(struct sk_buff *skb) | 82 | int xfrm6_output_finish(struct sk_buff *skb) |
| 83 | { | 83 | { |
| 84 | #ifdef CONFIG_NETFILTER | 84 | #ifdef CONFIG_NETFILTER |
| 85 | IP6CB(skb)->flags |= IP6SKB_XFRM_TRANSFORMED; | 85 | IP6CB(skb)->flags |= IP6SKB_XFRM_TRANSFORMED; |
| @@ -97,9 +97,9 @@ static int __xfrm6_output(struct sk_buff *skb) | |||
| 97 | if ((x && x->props.mode == XFRM_MODE_TUNNEL) && | 97 | if ((x && x->props.mode == XFRM_MODE_TUNNEL) && |
| 98 | ((skb->len > ip6_skb_dst_mtu(skb) && !skb_is_gso(skb)) || | 98 | ((skb->len > ip6_skb_dst_mtu(skb) && !skb_is_gso(skb)) || |
| 99 | dst_allfrag(skb_dst(skb)))) { | 99 | dst_allfrag(skb_dst(skb)))) { |
| 100 | return ip6_fragment(skb, xfrm6_output_finish); | 100 | return ip6_fragment(skb, x->outer_mode->afinfo->output_finish); |
| 101 | } | 101 | } |
| 102 | return xfrm6_output_finish(skb); | 102 | return x->outer_mode->afinfo->output_finish(skb); |
| 103 | } | 103 | } |
| 104 | 104 | ||
| 105 | int xfrm6_output(struct sk_buff *skb) | 105 | int xfrm6_output(struct sk_buff *skb) |
diff --git a/net/ipv6/xfrm6_state.c b/net/ipv6/xfrm6_state.c index afe941e9415c..248f0b2a7ee9 100644 --- a/net/ipv6/xfrm6_state.c +++ b/net/ipv6/xfrm6_state.c | |||
| @@ -178,6 +178,7 @@ static struct xfrm_state_afinfo xfrm6_state_afinfo = { | |||
| 178 | .tmpl_sort = __xfrm6_tmpl_sort, | 178 | .tmpl_sort = __xfrm6_tmpl_sort, |
| 179 | .state_sort = __xfrm6_state_sort, | 179 | .state_sort = __xfrm6_state_sort, |
| 180 | .output = xfrm6_output, | 180 | .output = xfrm6_output, |
| 181 | .output_finish = xfrm6_output_finish, | ||
| 181 | .extract_input = xfrm6_extract_input, | 182 | .extract_input = xfrm6_extract_input, |
| 182 | .extract_output = xfrm6_extract_output, | 183 | .extract_output = xfrm6_extract_output, |
| 183 | .transport_finish = xfrm6_transport_finish, | 184 | .transport_finish = xfrm6_transport_finish, |
diff --git a/net/mac80211/tx.c b/net/mac80211/tx.c index ce4596ed1268..bd1224fd216a 100644 --- a/net/mac80211/tx.c +++ b/net/mac80211/tx.c | |||
| @@ -237,6 +237,10 @@ ieee80211_tx_h_dynamic_ps(struct ieee80211_tx_data *tx) | |||
| 237 | &local->dynamic_ps_disable_work); | 237 | &local->dynamic_ps_disable_work); |
| 238 | } | 238 | } |
| 239 | 239 | ||
| 240 | /* Don't restart the timer if we're not disassociated */ | ||
| 241 | if (!ifmgd->associated) | ||
| 242 | return TX_CONTINUE; | ||
| 243 | |||
| 240 | mod_timer(&local->dynamic_ps_timer, jiffies + | 244 | mod_timer(&local->dynamic_ps_timer, jiffies + |
| 241 | msecs_to_jiffies(local->hw.conf.dynamic_ps_timeout)); | 245 | msecs_to_jiffies(local->hw.conf.dynamic_ps_timeout)); |
| 242 | 246 | ||
diff --git a/net/netfilter/ipvs/ip_vs_app.c b/net/netfilter/ipvs/ip_vs_app.c index 2dc6de13ac18..059af3120be7 100644 --- a/net/netfilter/ipvs/ip_vs_app.c +++ b/net/netfilter/ipvs/ip_vs_app.c | |||
| @@ -572,11 +572,11 @@ static const struct file_operations ip_vs_app_fops = { | |||
| 572 | .open = ip_vs_app_open, | 572 | .open = ip_vs_app_open, |
| 573 | .read = seq_read, | 573 | .read = seq_read, |
| 574 | .llseek = seq_lseek, | 574 | .llseek = seq_lseek, |
| 575 | .release = seq_release, | 575 | .release = seq_release_net, |
| 576 | }; | 576 | }; |
| 577 | #endif | 577 | #endif |
| 578 | 578 | ||
| 579 | static int __net_init __ip_vs_app_init(struct net *net) | 579 | int __net_init __ip_vs_app_init(struct net *net) |
| 580 | { | 580 | { |
| 581 | struct netns_ipvs *ipvs = net_ipvs(net); | 581 | struct netns_ipvs *ipvs = net_ipvs(net); |
| 582 | 582 | ||
| @@ -585,26 +585,17 @@ static int __net_init __ip_vs_app_init(struct net *net) | |||
| 585 | return 0; | 585 | return 0; |
| 586 | } | 586 | } |
| 587 | 587 | ||
| 588 | static void __net_exit __ip_vs_app_cleanup(struct net *net) | 588 | void __net_exit __ip_vs_app_cleanup(struct net *net) |
| 589 | { | 589 | { |
| 590 | proc_net_remove(net, "ip_vs_app"); | 590 | proc_net_remove(net, "ip_vs_app"); |
| 591 | } | 591 | } |
| 592 | 592 | ||
| 593 | static struct pernet_operations ip_vs_app_ops = { | ||
| 594 | .init = __ip_vs_app_init, | ||
| 595 | .exit = __ip_vs_app_cleanup, | ||
| 596 | }; | ||
| 597 | |||
| 598 | int __init ip_vs_app_init(void) | 593 | int __init ip_vs_app_init(void) |
| 599 | { | 594 | { |
| 600 | int rv; | 595 | return 0; |
| 601 | |||
| 602 | rv = register_pernet_subsys(&ip_vs_app_ops); | ||
| 603 | return rv; | ||
| 604 | } | 596 | } |
| 605 | 597 | ||
| 606 | 598 | ||
| 607 | void ip_vs_app_cleanup(void) | 599 | void ip_vs_app_cleanup(void) |
| 608 | { | 600 | { |
| 609 | unregister_pernet_subsys(&ip_vs_app_ops); | ||
| 610 | } | 601 | } |
diff --git a/net/netfilter/ipvs/ip_vs_conn.c b/net/netfilter/ipvs/ip_vs_conn.c index c97bd45975be..bf28ac2fc99b 100644 --- a/net/netfilter/ipvs/ip_vs_conn.c +++ b/net/netfilter/ipvs/ip_vs_conn.c | |||
| @@ -1046,7 +1046,7 @@ static const struct file_operations ip_vs_conn_fops = { | |||
| 1046 | .open = ip_vs_conn_open, | 1046 | .open = ip_vs_conn_open, |
| 1047 | .read = seq_read, | 1047 | .read = seq_read, |
| 1048 | .llseek = seq_lseek, | 1048 | .llseek = seq_lseek, |
| 1049 | .release = seq_release, | 1049 | .release = seq_release_net, |
| 1050 | }; | 1050 | }; |
| 1051 | 1051 | ||
| 1052 | static const char *ip_vs_origin_name(unsigned flags) | 1052 | static const char *ip_vs_origin_name(unsigned flags) |
| @@ -1114,7 +1114,7 @@ static const struct file_operations ip_vs_conn_sync_fops = { | |||
| 1114 | .open = ip_vs_conn_sync_open, | 1114 | .open = ip_vs_conn_sync_open, |
| 1115 | .read = seq_read, | 1115 | .read = seq_read, |
| 1116 | .llseek = seq_lseek, | 1116 | .llseek = seq_lseek, |
| 1117 | .release = seq_release, | 1117 | .release = seq_release_net, |
| 1118 | }; | 1118 | }; |
| 1119 | 1119 | ||
| 1120 | #endif | 1120 | #endif |
| @@ -1258,22 +1258,17 @@ int __net_init __ip_vs_conn_init(struct net *net) | |||
| 1258 | return 0; | 1258 | return 0; |
| 1259 | } | 1259 | } |
| 1260 | 1260 | ||
| 1261 | static void __net_exit __ip_vs_conn_cleanup(struct net *net) | 1261 | void __net_exit __ip_vs_conn_cleanup(struct net *net) |
| 1262 | { | 1262 | { |
| 1263 | /* flush all the connection entries first */ | 1263 | /* flush all the connection entries first */ |
| 1264 | ip_vs_conn_flush(net); | 1264 | ip_vs_conn_flush(net); |
| 1265 | proc_net_remove(net, "ip_vs_conn"); | 1265 | proc_net_remove(net, "ip_vs_conn"); |
| 1266 | proc_net_remove(net, "ip_vs_conn_sync"); | 1266 | proc_net_remove(net, "ip_vs_conn_sync"); |
| 1267 | } | 1267 | } |
| 1268 | static struct pernet_operations ipvs_conn_ops = { | ||
| 1269 | .init = __ip_vs_conn_init, | ||
| 1270 | .exit = __ip_vs_conn_cleanup, | ||
| 1271 | }; | ||
| 1272 | 1268 | ||
| 1273 | int __init ip_vs_conn_init(void) | 1269 | int __init ip_vs_conn_init(void) |
| 1274 | { | 1270 | { |
| 1275 | int idx; | 1271 | int idx; |
| 1276 | int retc; | ||
| 1277 | 1272 | ||
| 1278 | /* Compute size and mask */ | 1273 | /* Compute size and mask */ |
| 1279 | ip_vs_conn_tab_size = 1 << ip_vs_conn_tab_bits; | 1274 | ip_vs_conn_tab_size = 1 << ip_vs_conn_tab_bits; |
| @@ -1309,17 +1304,14 @@ int __init ip_vs_conn_init(void) | |||
| 1309 | rwlock_init(&__ip_vs_conntbl_lock_array[idx].l); | 1304 | rwlock_init(&__ip_vs_conntbl_lock_array[idx].l); |
| 1310 | } | 1305 | } |
| 1311 | 1306 | ||
| 1312 | retc = register_pernet_subsys(&ipvs_conn_ops); | ||
| 1313 | |||
| 1314 | /* calculate the random value for connection hash */ | 1307 | /* calculate the random value for connection hash */ |
| 1315 | get_random_bytes(&ip_vs_conn_rnd, sizeof(ip_vs_conn_rnd)); | 1308 | get_random_bytes(&ip_vs_conn_rnd, sizeof(ip_vs_conn_rnd)); |
| 1316 | 1309 | ||
| 1317 | return retc; | 1310 | return 0; |
| 1318 | } | 1311 | } |
| 1319 | 1312 | ||
| 1320 | void ip_vs_conn_cleanup(void) | 1313 | void ip_vs_conn_cleanup(void) |
| 1321 | { | 1314 | { |
| 1322 | unregister_pernet_subsys(&ipvs_conn_ops); | ||
| 1323 | /* Release the empty cache */ | 1315 | /* Release the empty cache */ |
| 1324 | kmem_cache_destroy(ip_vs_conn_cachep); | 1316 | kmem_cache_destroy(ip_vs_conn_cachep); |
| 1325 | vfree(ip_vs_conn_tab); | 1317 | vfree(ip_vs_conn_tab); |
diff --git a/net/netfilter/ipvs/ip_vs_core.c b/net/netfilter/ipvs/ip_vs_core.c index 07accf6b2401..a74dae6c5dbc 100644 --- a/net/netfilter/ipvs/ip_vs_core.c +++ b/net/netfilter/ipvs/ip_vs_core.c | |||
| @@ -1113,6 +1113,9 @@ ip_vs_out(unsigned int hooknum, struct sk_buff *skb, int af) | |||
| 1113 | return NF_ACCEPT; | 1113 | return NF_ACCEPT; |
| 1114 | 1114 | ||
| 1115 | net = skb_net(skb); | 1115 | net = skb_net(skb); |
| 1116 | if (!net_ipvs(net)->enable) | ||
| 1117 | return NF_ACCEPT; | ||
| 1118 | |||
| 1116 | ip_vs_fill_iphdr(af, skb_network_header(skb), &iph); | 1119 | ip_vs_fill_iphdr(af, skb_network_header(skb), &iph); |
| 1117 | #ifdef CONFIG_IP_VS_IPV6 | 1120 | #ifdef CONFIG_IP_VS_IPV6 |
| 1118 | if (af == AF_INET6) { | 1121 | if (af == AF_INET6) { |
| @@ -1343,6 +1346,7 @@ ip_vs_in_icmp(struct sk_buff *skb, int *related, unsigned int hooknum) | |||
| 1343 | return NF_ACCEPT; /* The packet looks wrong, ignore */ | 1346 | return NF_ACCEPT; /* The packet looks wrong, ignore */ |
| 1344 | 1347 | ||
| 1345 | net = skb_net(skb); | 1348 | net = skb_net(skb); |
| 1349 | |||
| 1346 | pd = ip_vs_proto_data_get(net, cih->protocol); | 1350 | pd = ip_vs_proto_data_get(net, cih->protocol); |
| 1347 | if (!pd) | 1351 | if (!pd) |
| 1348 | return NF_ACCEPT; | 1352 | return NF_ACCEPT; |
| @@ -1529,6 +1533,11 @@ ip_vs_in(unsigned int hooknum, struct sk_buff *skb, int af) | |||
| 1529 | IP_VS_DBG_ADDR(af, &iph.daddr), hooknum); | 1533 | IP_VS_DBG_ADDR(af, &iph.daddr), hooknum); |
| 1530 | return NF_ACCEPT; | 1534 | return NF_ACCEPT; |
| 1531 | } | 1535 | } |
| 1536 | /* ipvs enabled in this netns ? */ | ||
| 1537 | net = skb_net(skb); | ||
| 1538 | if (!net_ipvs(net)->enable) | ||
| 1539 | return NF_ACCEPT; | ||
| 1540 | |||
| 1532 | ip_vs_fill_iphdr(af, skb_network_header(skb), &iph); | 1541 | ip_vs_fill_iphdr(af, skb_network_header(skb), &iph); |
| 1533 | 1542 | ||
| 1534 | /* Bad... Do not break raw sockets */ | 1543 | /* Bad... Do not break raw sockets */ |
| @@ -1562,7 +1571,6 @@ ip_vs_in(unsigned int hooknum, struct sk_buff *skb, int af) | |||
| 1562 | ip_vs_fill_iphdr(af, skb_network_header(skb), &iph); | 1571 | ip_vs_fill_iphdr(af, skb_network_header(skb), &iph); |
| 1563 | } | 1572 | } |
| 1564 | 1573 | ||
| 1565 | net = skb_net(skb); | ||
| 1566 | /* Protocol supported? */ | 1574 | /* Protocol supported? */ |
| 1567 | pd = ip_vs_proto_data_get(net, iph.protocol); | 1575 | pd = ip_vs_proto_data_get(net, iph.protocol); |
| 1568 | if (unlikely(!pd)) | 1576 | if (unlikely(!pd)) |
| @@ -1588,7 +1596,6 @@ ip_vs_in(unsigned int hooknum, struct sk_buff *skb, int af) | |||
| 1588 | } | 1596 | } |
| 1589 | 1597 | ||
| 1590 | IP_VS_DBG_PKT(11, af, pp, skb, 0, "Incoming packet"); | 1598 | IP_VS_DBG_PKT(11, af, pp, skb, 0, "Incoming packet"); |
| 1591 | net = skb_net(skb); | ||
| 1592 | ipvs = net_ipvs(net); | 1599 | ipvs = net_ipvs(net); |
| 1593 | /* Check the server status */ | 1600 | /* Check the server status */ |
| 1594 | if (cp->dest && !(cp->dest->flags & IP_VS_DEST_F_AVAILABLE)) { | 1601 | if (cp->dest && !(cp->dest->flags & IP_VS_DEST_F_AVAILABLE)) { |
| @@ -1743,10 +1750,16 @@ ip_vs_forward_icmp(unsigned int hooknum, struct sk_buff *skb, | |||
| 1743 | int (*okfn)(struct sk_buff *)) | 1750 | int (*okfn)(struct sk_buff *)) |
| 1744 | { | 1751 | { |
| 1745 | int r; | 1752 | int r; |
| 1753 | struct net *net; | ||
| 1746 | 1754 | ||
| 1747 | if (ip_hdr(skb)->protocol != IPPROTO_ICMP) | 1755 | if (ip_hdr(skb)->protocol != IPPROTO_ICMP) |
| 1748 | return NF_ACCEPT; | 1756 | return NF_ACCEPT; |
| 1749 | 1757 | ||
| 1758 | /* ipvs enabled in this netns ? */ | ||
| 1759 | net = skb_net(skb); | ||
| 1760 | if (!net_ipvs(net)->enable) | ||
| 1761 | return NF_ACCEPT; | ||
| 1762 | |||
| 1750 | return ip_vs_in_icmp(skb, &r, hooknum); | 1763 | return ip_vs_in_icmp(skb, &r, hooknum); |
| 1751 | } | 1764 | } |
| 1752 | 1765 | ||
| @@ -1757,10 +1770,16 @@ ip_vs_forward_icmp_v6(unsigned int hooknum, struct sk_buff *skb, | |||
| 1757 | int (*okfn)(struct sk_buff *)) | 1770 | int (*okfn)(struct sk_buff *)) |
| 1758 | { | 1771 | { |
| 1759 | int r; | 1772 | int r; |
| 1773 | struct net *net; | ||
| 1760 | 1774 | ||
| 1761 | if (ipv6_hdr(skb)->nexthdr != IPPROTO_ICMPV6) | 1775 | if (ipv6_hdr(skb)->nexthdr != IPPROTO_ICMPV6) |
| 1762 | return NF_ACCEPT; | 1776 | return NF_ACCEPT; |
| 1763 | 1777 | ||
| 1778 | /* ipvs enabled in this netns ? */ | ||
| 1779 | net = skb_net(skb); | ||
| 1780 | if (!net_ipvs(net)->enable) | ||
| 1781 | return NF_ACCEPT; | ||
| 1782 | |||
| 1764 | return ip_vs_in_icmp_v6(skb, &r, hooknum); | 1783 | return ip_vs_in_icmp_v6(skb, &r, hooknum); |
| 1765 | } | 1784 | } |
| 1766 | #endif | 1785 | #endif |
| @@ -1884,19 +1903,70 @@ static int __net_init __ip_vs_init(struct net *net) | |||
| 1884 | pr_err("%s(): no memory.\n", __func__); | 1903 | pr_err("%s(): no memory.\n", __func__); |
| 1885 | return -ENOMEM; | 1904 | return -ENOMEM; |
| 1886 | } | 1905 | } |
| 1906 | /* Hold the beast until a service is registerd */ | ||
| 1907 | ipvs->enable = 0; | ||
| 1887 | ipvs->net = net; | 1908 | ipvs->net = net; |
| 1888 | /* Counters used for creating unique names */ | 1909 | /* Counters used for creating unique names */ |
| 1889 | ipvs->gen = atomic_read(&ipvs_netns_cnt); | 1910 | ipvs->gen = atomic_read(&ipvs_netns_cnt); |
| 1890 | atomic_inc(&ipvs_netns_cnt); | 1911 | atomic_inc(&ipvs_netns_cnt); |
| 1891 | net->ipvs = ipvs; | 1912 | net->ipvs = ipvs; |
| 1913 | |||
| 1914 | if (__ip_vs_estimator_init(net) < 0) | ||
| 1915 | goto estimator_fail; | ||
| 1916 | |||
| 1917 | if (__ip_vs_control_init(net) < 0) | ||
| 1918 | goto control_fail; | ||
| 1919 | |||
| 1920 | if (__ip_vs_protocol_init(net) < 0) | ||
| 1921 | goto protocol_fail; | ||
| 1922 | |||
| 1923 | if (__ip_vs_app_init(net) < 0) | ||
| 1924 | goto app_fail; | ||
| 1925 | |||
| 1926 | if (__ip_vs_conn_init(net) < 0) | ||
| 1927 | goto conn_fail; | ||
| 1928 | |||
| 1929 | if (__ip_vs_sync_init(net) < 0) | ||
| 1930 | goto sync_fail; | ||
| 1931 | |||
| 1892 | printk(KERN_INFO "IPVS: Creating netns size=%zu id=%d\n", | 1932 | printk(KERN_INFO "IPVS: Creating netns size=%zu id=%d\n", |
| 1893 | sizeof(struct netns_ipvs), ipvs->gen); | 1933 | sizeof(struct netns_ipvs), ipvs->gen); |
| 1894 | return 0; | 1934 | return 0; |
| 1935 | /* | ||
| 1936 | * Error handling | ||
| 1937 | */ | ||
| 1938 | |||
| 1939 | sync_fail: | ||
| 1940 | __ip_vs_conn_cleanup(net); | ||
| 1941 | conn_fail: | ||
| 1942 | __ip_vs_app_cleanup(net); | ||
| 1943 | app_fail: | ||
| 1944 | __ip_vs_protocol_cleanup(net); | ||
| 1945 | protocol_fail: | ||
| 1946 | __ip_vs_control_cleanup(net); | ||
| 1947 | control_fail: | ||
| 1948 | __ip_vs_estimator_cleanup(net); | ||
| 1949 | estimator_fail: | ||
| 1950 | return -ENOMEM; | ||
| 1895 | } | 1951 | } |
| 1896 | 1952 | ||
| 1897 | static void __net_exit __ip_vs_cleanup(struct net *net) | 1953 | static void __net_exit __ip_vs_cleanup(struct net *net) |
| 1898 | { | 1954 | { |
| 1899 | IP_VS_DBG(10, "ipvs netns %d released\n", net_ipvs(net)->gen); | 1955 | __ip_vs_service_cleanup(net); /* ip_vs_flush() with locks */ |
| 1956 | __ip_vs_conn_cleanup(net); | ||
| 1957 | __ip_vs_app_cleanup(net); | ||
| 1958 | __ip_vs_protocol_cleanup(net); | ||
| 1959 | __ip_vs_control_cleanup(net); | ||
| 1960 | __ip_vs_estimator_cleanup(net); | ||
| 1961 | IP_VS_DBG(2, "ipvs netns %d released\n", net_ipvs(net)->gen); | ||
| 1962 | } | ||
| 1963 | |||
| 1964 | static void __net_exit __ip_vs_dev_cleanup(struct net *net) | ||
| 1965 | { | ||
| 1966 | EnterFunction(2); | ||
| 1967 | net_ipvs(net)->enable = 0; /* Disable packet reception */ | ||
| 1968 | __ip_vs_sync_cleanup(net); | ||
| 1969 | LeaveFunction(2); | ||
| 1900 | } | 1970 | } |
| 1901 | 1971 | ||
| 1902 | static struct pernet_operations ipvs_core_ops = { | 1972 | static struct pernet_operations ipvs_core_ops = { |
| @@ -1906,6 +1976,10 @@ static struct pernet_operations ipvs_core_ops = { | |||
| 1906 | .size = sizeof(struct netns_ipvs), | 1976 | .size = sizeof(struct netns_ipvs), |
| 1907 | }; | 1977 | }; |
| 1908 | 1978 | ||
| 1979 | static struct pernet_operations ipvs_core_dev_ops = { | ||
| 1980 | .exit = __ip_vs_dev_cleanup, | ||
| 1981 | }; | ||
| 1982 | |||
| 1909 | /* | 1983 | /* |
| 1910 | * Initialize IP Virtual Server | 1984 | * Initialize IP Virtual Server |
| 1911 | */ | 1985 | */ |
| @@ -1913,10 +1987,6 @@ static int __init ip_vs_init(void) | |||
| 1913 | { | 1987 | { |
| 1914 | int ret; | 1988 | int ret; |
| 1915 | 1989 | ||
| 1916 | ret = register_pernet_subsys(&ipvs_core_ops); /* Alloc ip_vs struct */ | ||
| 1917 | if (ret < 0) | ||
| 1918 | return ret; | ||
| 1919 | |||
| 1920 | ip_vs_estimator_init(); | 1990 | ip_vs_estimator_init(); |
| 1921 | ret = ip_vs_control_init(); | 1991 | ret = ip_vs_control_init(); |
| 1922 | if (ret < 0) { | 1992 | if (ret < 0) { |
| @@ -1944,15 +2014,28 @@ static int __init ip_vs_init(void) | |||
| 1944 | goto cleanup_conn; | 2014 | goto cleanup_conn; |
| 1945 | } | 2015 | } |
| 1946 | 2016 | ||
| 2017 | ret = register_pernet_subsys(&ipvs_core_ops); /* Alloc ip_vs struct */ | ||
| 2018 | if (ret < 0) | ||
| 2019 | goto cleanup_sync; | ||
| 2020 | |||
| 2021 | ret = register_pernet_device(&ipvs_core_dev_ops); | ||
| 2022 | if (ret < 0) | ||
| 2023 | goto cleanup_sub; | ||
| 2024 | |||
| 1947 | ret = nf_register_hooks(ip_vs_ops, ARRAY_SIZE(ip_vs_ops)); | 2025 | ret = nf_register_hooks(ip_vs_ops, ARRAY_SIZE(ip_vs_ops)); |
| 1948 | if (ret < 0) { | 2026 | if (ret < 0) { |
| 1949 | pr_err("can't register hooks.\n"); | 2027 | pr_err("can't register hooks.\n"); |
| 1950 | goto cleanup_sync; | 2028 | goto cleanup_dev; |
| 1951 | } | 2029 | } |
| 1952 | 2030 | ||
| 1953 | pr_info("ipvs loaded.\n"); | 2031 | pr_info("ipvs loaded.\n"); |
| 2032 | |||
| 1954 | return ret; | 2033 | return ret; |
| 1955 | 2034 | ||
| 2035 | cleanup_dev: | ||
| 2036 | unregister_pernet_device(&ipvs_core_dev_ops); | ||
| 2037 | cleanup_sub: | ||
| 2038 | unregister_pernet_subsys(&ipvs_core_ops); | ||
| 1956 | cleanup_sync: | 2039 | cleanup_sync: |
| 1957 | ip_vs_sync_cleanup(); | 2040 | ip_vs_sync_cleanup(); |
| 1958 | cleanup_conn: | 2041 | cleanup_conn: |
| @@ -1964,20 +2047,20 @@ cleanup_sync: | |||
| 1964 | ip_vs_control_cleanup(); | 2047 | ip_vs_control_cleanup(); |
| 1965 | cleanup_estimator: | 2048 | cleanup_estimator: |
| 1966 | ip_vs_estimator_cleanup(); | 2049 | ip_vs_estimator_cleanup(); |
| 1967 | unregister_pernet_subsys(&ipvs_core_ops); /* free ip_vs struct */ | ||
| 1968 | return ret; | 2050 | return ret; |
| 1969 | } | 2051 | } |
| 1970 | 2052 | ||
| 1971 | static void __exit ip_vs_cleanup(void) | 2053 | static void __exit ip_vs_cleanup(void) |
| 1972 | { | 2054 | { |
| 1973 | nf_unregister_hooks(ip_vs_ops, ARRAY_SIZE(ip_vs_ops)); | 2055 | nf_unregister_hooks(ip_vs_ops, ARRAY_SIZE(ip_vs_ops)); |
| 2056 | unregister_pernet_device(&ipvs_core_dev_ops); | ||
| 2057 | unregister_pernet_subsys(&ipvs_core_ops); /* free ip_vs struct */ | ||
| 1974 | ip_vs_sync_cleanup(); | 2058 | ip_vs_sync_cleanup(); |
| 1975 | ip_vs_conn_cleanup(); | 2059 | ip_vs_conn_cleanup(); |
| 1976 | ip_vs_app_cleanup(); | 2060 | ip_vs_app_cleanup(); |
| 1977 | ip_vs_protocol_cleanup(); | 2061 | ip_vs_protocol_cleanup(); |
| 1978 | ip_vs_control_cleanup(); | 2062 | ip_vs_control_cleanup(); |
| 1979 | ip_vs_estimator_cleanup(); | 2063 | ip_vs_estimator_cleanup(); |
| 1980 | unregister_pernet_subsys(&ipvs_core_ops); /* free ip_vs struct */ | ||
| 1981 | pr_info("ipvs unloaded.\n"); | 2064 | pr_info("ipvs unloaded.\n"); |
| 1982 | } | 2065 | } |
| 1983 | 2066 | ||
diff --git a/net/netfilter/ipvs/ip_vs_ctl.c b/net/netfilter/ipvs/ip_vs_ctl.c index ae47090bf45f..37890f228b19 100644 --- a/net/netfilter/ipvs/ip_vs_ctl.c +++ b/net/netfilter/ipvs/ip_vs_ctl.c | |||
| @@ -69,6 +69,11 @@ int ip_vs_get_debug_level(void) | |||
| 69 | } | 69 | } |
| 70 | #endif | 70 | #endif |
| 71 | 71 | ||
| 72 | |||
| 73 | /* Protos */ | ||
| 74 | static void __ip_vs_del_service(struct ip_vs_service *svc); | ||
| 75 | |||
| 76 | |||
| 72 | #ifdef CONFIG_IP_VS_IPV6 | 77 | #ifdef CONFIG_IP_VS_IPV6 |
| 73 | /* Taken from rt6_fill_node() in net/ipv6/route.c, is there a better way? */ | 78 | /* Taken from rt6_fill_node() in net/ipv6/route.c, is there a better way? */ |
| 74 | static int __ip_vs_addr_is_local_v6(struct net *net, | 79 | static int __ip_vs_addr_is_local_v6(struct net *net, |
| @@ -1214,6 +1219,8 @@ ip_vs_add_service(struct net *net, struct ip_vs_service_user_kern *u, | |||
| 1214 | write_unlock_bh(&__ip_vs_svc_lock); | 1219 | write_unlock_bh(&__ip_vs_svc_lock); |
| 1215 | 1220 | ||
| 1216 | *svc_p = svc; | 1221 | *svc_p = svc; |
| 1222 | /* Now there is a service - full throttle */ | ||
| 1223 | ipvs->enable = 1; | ||
| 1217 | return 0; | 1224 | return 0; |
| 1218 | 1225 | ||
| 1219 | 1226 | ||
| @@ -1472,6 +1479,84 @@ static int ip_vs_flush(struct net *net) | |||
| 1472 | return 0; | 1479 | return 0; |
| 1473 | } | 1480 | } |
| 1474 | 1481 | ||
| 1482 | /* | ||
| 1483 | * Delete service by {netns} in the service table. | ||
| 1484 | * Called by __ip_vs_cleanup() | ||
| 1485 | */ | ||
| 1486 | void __ip_vs_service_cleanup(struct net *net) | ||
| 1487 | { | ||
| 1488 | EnterFunction(2); | ||
| 1489 | /* Check for "full" addressed entries */ | ||
| 1490 | mutex_lock(&__ip_vs_mutex); | ||
| 1491 | ip_vs_flush(net); | ||
| 1492 | mutex_unlock(&__ip_vs_mutex); | ||
| 1493 | LeaveFunction(2); | ||
| 1494 | } | ||
| 1495 | /* | ||
| 1496 | * Release dst hold by dst_cache | ||
| 1497 | */ | ||
| 1498 | static inline void | ||
| 1499 | __ip_vs_dev_reset(struct ip_vs_dest *dest, struct net_device *dev) | ||
| 1500 | { | ||
| 1501 | spin_lock_bh(&dest->dst_lock); | ||
| 1502 | if (dest->dst_cache && dest->dst_cache->dev == dev) { | ||
| 1503 | IP_VS_DBG_BUF(3, "Reset dev:%s dest %s:%u ,dest->refcnt=%d\n", | ||
| 1504 | dev->name, | ||
| 1505 | IP_VS_DBG_ADDR(dest->af, &dest->addr), | ||
| 1506 | ntohs(dest->port), | ||
| 1507 | atomic_read(&dest->refcnt)); | ||
| 1508 | ip_vs_dst_reset(dest); | ||
| 1509 | } | ||
| 1510 | spin_unlock_bh(&dest->dst_lock); | ||
| 1511 | |||
| 1512 | } | ||
| 1513 | /* | ||
| 1514 | * Netdev event receiver | ||
| 1515 | * Currently only NETDEV_UNREGISTER is handled, i.e. if we hold a reference to | ||
| 1516 | * a device that is "unregister" it must be released. | ||
| 1517 | */ | ||
| 1518 | static int ip_vs_dst_event(struct notifier_block *this, unsigned long event, | ||
| 1519 | void *ptr) | ||
| 1520 | { | ||
| 1521 | struct net_device *dev = ptr; | ||
| 1522 | struct net *net = dev_net(dev); | ||
| 1523 | struct ip_vs_service *svc; | ||
| 1524 | struct ip_vs_dest *dest; | ||
| 1525 | unsigned int idx; | ||
| 1526 | |||
| 1527 | if (event != NETDEV_UNREGISTER) | ||
| 1528 | return NOTIFY_DONE; | ||
| 1529 | IP_VS_DBG(3, "%s() dev=%s\n", __func__, dev->name); | ||
| 1530 | EnterFunction(2); | ||
| 1531 | mutex_lock(&__ip_vs_mutex); | ||
| 1532 | for (idx = 0; idx < IP_VS_SVC_TAB_SIZE; idx++) { | ||
| 1533 | list_for_each_entry(svc, &ip_vs_svc_table[idx], s_list) { | ||
| 1534 | if (net_eq(svc->net, net)) { | ||
| 1535 | list_for_each_entry(dest, &svc->destinations, | ||
| 1536 | n_list) { | ||
| 1537 | __ip_vs_dev_reset(dest, dev); | ||
| 1538 | } | ||
| 1539 | } | ||
| 1540 | } | ||
| 1541 | |||
| 1542 | list_for_each_entry(svc, &ip_vs_svc_fwm_table[idx], f_list) { | ||
| 1543 | if (net_eq(svc->net, net)) { | ||
| 1544 | list_for_each_entry(dest, &svc->destinations, | ||
| 1545 | n_list) { | ||
| 1546 | __ip_vs_dev_reset(dest, dev); | ||
| 1547 | } | ||
| 1548 | } | ||
| 1549 | |||
| 1550 | } | ||
| 1551 | } | ||
| 1552 | |||
| 1553 | list_for_each_entry(dest, &net_ipvs(net)->dest_trash, n_list) { | ||
| 1554 | __ip_vs_dev_reset(dest, dev); | ||
| 1555 | } | ||
| 1556 | mutex_unlock(&__ip_vs_mutex); | ||
| 1557 | LeaveFunction(2); | ||
| 1558 | return NOTIFY_DONE; | ||
| 1559 | } | ||
| 1475 | 1560 | ||
| 1476 | /* | 1561 | /* |
| 1477 | * Zero counters in a service or all services | 1562 | * Zero counters in a service or all services |
| @@ -1981,7 +2066,7 @@ static const struct file_operations ip_vs_info_fops = { | |||
| 1981 | .open = ip_vs_info_open, | 2066 | .open = ip_vs_info_open, |
| 1982 | .read = seq_read, | 2067 | .read = seq_read, |
| 1983 | .llseek = seq_lseek, | 2068 | .llseek = seq_lseek, |
| 1984 | .release = seq_release_private, | 2069 | .release = seq_release_net, |
| 1985 | }; | 2070 | }; |
| 1986 | 2071 | ||
| 1987 | #endif | 2072 | #endif |
| @@ -2024,7 +2109,7 @@ static const struct file_operations ip_vs_stats_fops = { | |||
| 2024 | .open = ip_vs_stats_seq_open, | 2109 | .open = ip_vs_stats_seq_open, |
| 2025 | .read = seq_read, | 2110 | .read = seq_read, |
| 2026 | .llseek = seq_lseek, | 2111 | .llseek = seq_lseek, |
| 2027 | .release = single_release, | 2112 | .release = single_release_net, |
| 2028 | }; | 2113 | }; |
| 2029 | 2114 | ||
| 2030 | static int ip_vs_stats_percpu_show(struct seq_file *seq, void *v) | 2115 | static int ip_vs_stats_percpu_show(struct seq_file *seq, void *v) |
| @@ -2093,7 +2178,7 @@ static const struct file_operations ip_vs_stats_percpu_fops = { | |||
| 2093 | .open = ip_vs_stats_percpu_seq_open, | 2178 | .open = ip_vs_stats_percpu_seq_open, |
| 2094 | .read = seq_read, | 2179 | .read = seq_read, |
| 2095 | .llseek = seq_lseek, | 2180 | .llseek = seq_lseek, |
| 2096 | .release = single_release, | 2181 | .release = single_release_net, |
| 2097 | }; | 2182 | }; |
| 2098 | #endif | 2183 | #endif |
| 2099 | 2184 | ||
| @@ -3588,6 +3673,10 @@ void __net_init __ip_vs_control_cleanup_sysctl(struct net *net) { } | |||
| 3588 | 3673 | ||
| 3589 | #endif | 3674 | #endif |
| 3590 | 3675 | ||
| 3676 | static struct notifier_block ip_vs_dst_notifier = { | ||
| 3677 | .notifier_call = ip_vs_dst_event, | ||
| 3678 | }; | ||
| 3679 | |||
| 3591 | int __net_init __ip_vs_control_init(struct net *net) | 3680 | int __net_init __ip_vs_control_init(struct net *net) |
| 3592 | { | 3681 | { |
| 3593 | int idx; | 3682 | int idx; |
| @@ -3626,7 +3715,7 @@ err: | |||
| 3626 | return -ENOMEM; | 3715 | return -ENOMEM; |
| 3627 | } | 3716 | } |
| 3628 | 3717 | ||
| 3629 | static void __net_exit __ip_vs_control_cleanup(struct net *net) | 3718 | void __net_exit __ip_vs_control_cleanup(struct net *net) |
| 3630 | { | 3719 | { |
| 3631 | struct netns_ipvs *ipvs = net_ipvs(net); | 3720 | struct netns_ipvs *ipvs = net_ipvs(net); |
| 3632 | 3721 | ||
| @@ -3639,11 +3728,6 @@ static void __net_exit __ip_vs_control_cleanup(struct net *net) | |||
| 3639 | free_percpu(ipvs->tot_stats.cpustats); | 3728 | free_percpu(ipvs->tot_stats.cpustats); |
| 3640 | } | 3729 | } |
| 3641 | 3730 | ||
| 3642 | static struct pernet_operations ipvs_control_ops = { | ||
| 3643 | .init = __ip_vs_control_init, | ||
| 3644 | .exit = __ip_vs_control_cleanup, | ||
| 3645 | }; | ||
| 3646 | |||
| 3647 | int __init ip_vs_control_init(void) | 3731 | int __init ip_vs_control_init(void) |
| 3648 | { | 3732 | { |
| 3649 | int idx; | 3733 | int idx; |
| @@ -3657,33 +3741,32 @@ int __init ip_vs_control_init(void) | |||
| 3657 | INIT_LIST_HEAD(&ip_vs_svc_fwm_table[idx]); | 3741 | INIT_LIST_HEAD(&ip_vs_svc_fwm_table[idx]); |
| 3658 | } | 3742 | } |
| 3659 | 3743 | ||
| 3660 | ret = register_pernet_subsys(&ipvs_control_ops); | ||
| 3661 | if (ret) { | ||
| 3662 | pr_err("cannot register namespace.\n"); | ||
| 3663 | goto err; | ||
| 3664 | } | ||
| 3665 | |||
| 3666 | smp_wmb(); /* Do we really need it now ? */ | 3744 | smp_wmb(); /* Do we really need it now ? */ |
| 3667 | 3745 | ||
| 3668 | ret = nf_register_sockopt(&ip_vs_sockopts); | 3746 | ret = nf_register_sockopt(&ip_vs_sockopts); |
| 3669 | if (ret) { | 3747 | if (ret) { |
| 3670 | pr_err("cannot register sockopt.\n"); | 3748 | pr_err("cannot register sockopt.\n"); |
| 3671 | goto err_net; | 3749 | goto err_sock; |
| 3672 | } | 3750 | } |
| 3673 | 3751 | ||
| 3674 | ret = ip_vs_genl_register(); | 3752 | ret = ip_vs_genl_register(); |
| 3675 | if (ret) { | 3753 | if (ret) { |
| 3676 | pr_err("cannot register Generic Netlink interface.\n"); | 3754 | pr_err("cannot register Generic Netlink interface.\n"); |
| 3677 | nf_unregister_sockopt(&ip_vs_sockopts); | 3755 | goto err_genl; |
| 3678 | goto err_net; | ||
| 3679 | } | 3756 | } |
| 3680 | 3757 | ||
| 3758 | ret = register_netdevice_notifier(&ip_vs_dst_notifier); | ||
| 3759 | if (ret < 0) | ||
| 3760 | goto err_notf; | ||
| 3761 | |||
| 3681 | LeaveFunction(2); | 3762 | LeaveFunction(2); |
| 3682 | return 0; | 3763 | return 0; |
| 3683 | 3764 | ||
| 3684 | err_net: | 3765 | err_notf: |
| 3685 | unregister_pernet_subsys(&ipvs_control_ops); | 3766 | ip_vs_genl_unregister(); |
| 3686 | err: | 3767 | err_genl: |
| 3768 | nf_unregister_sockopt(&ip_vs_sockopts); | ||
| 3769 | err_sock: | ||
| 3687 | return ret; | 3770 | return ret; |
| 3688 | } | 3771 | } |
| 3689 | 3772 | ||
| @@ -3691,7 +3774,6 @@ err: | |||
| 3691 | void ip_vs_control_cleanup(void) | 3774 | void ip_vs_control_cleanup(void) |
| 3692 | { | 3775 | { |
| 3693 | EnterFunction(2); | 3776 | EnterFunction(2); |
| 3694 | unregister_pernet_subsys(&ipvs_control_ops); | ||
| 3695 | ip_vs_genl_unregister(); | 3777 | ip_vs_genl_unregister(); |
| 3696 | nf_unregister_sockopt(&ip_vs_sockopts); | 3778 | nf_unregister_sockopt(&ip_vs_sockopts); |
| 3697 | LeaveFunction(2); | 3779 | LeaveFunction(2); |
diff --git a/net/netfilter/ipvs/ip_vs_est.c b/net/netfilter/ipvs/ip_vs_est.c index 8c8766ca56ad..508cce98777c 100644 --- a/net/netfilter/ipvs/ip_vs_est.c +++ b/net/netfilter/ipvs/ip_vs_est.c | |||
| @@ -192,7 +192,7 @@ void ip_vs_read_estimator(struct ip_vs_stats_user *dst, | |||
| 192 | dst->outbps = (e->outbps + 0xF) >> 5; | 192 | dst->outbps = (e->outbps + 0xF) >> 5; |
| 193 | } | 193 | } |
| 194 | 194 | ||
| 195 | static int __net_init __ip_vs_estimator_init(struct net *net) | 195 | int __net_init __ip_vs_estimator_init(struct net *net) |
| 196 | { | 196 | { |
| 197 | struct netns_ipvs *ipvs = net_ipvs(net); | 197 | struct netns_ipvs *ipvs = net_ipvs(net); |
| 198 | 198 | ||
| @@ -203,24 +203,16 @@ static int __net_init __ip_vs_estimator_init(struct net *net) | |||
| 203 | return 0; | 203 | return 0; |
| 204 | } | 204 | } |
| 205 | 205 | ||
| 206 | static void __net_exit __ip_vs_estimator_exit(struct net *net) | 206 | void __net_exit __ip_vs_estimator_cleanup(struct net *net) |
| 207 | { | 207 | { |
| 208 | del_timer_sync(&net_ipvs(net)->est_timer); | 208 | del_timer_sync(&net_ipvs(net)->est_timer); |
| 209 | } | 209 | } |
| 210 | static struct pernet_operations ip_vs_app_ops = { | ||
| 211 | .init = __ip_vs_estimator_init, | ||
| 212 | .exit = __ip_vs_estimator_exit, | ||
| 213 | }; | ||
| 214 | 210 | ||
| 215 | int __init ip_vs_estimator_init(void) | 211 | int __init ip_vs_estimator_init(void) |
| 216 | { | 212 | { |
| 217 | int rv; | 213 | return 0; |
| 218 | |||
| 219 | rv = register_pernet_subsys(&ip_vs_app_ops); | ||
| 220 | return rv; | ||
| 221 | } | 214 | } |
| 222 | 215 | ||
| 223 | void ip_vs_estimator_cleanup(void) | 216 | void ip_vs_estimator_cleanup(void) |
| 224 | { | 217 | { |
| 225 | unregister_pernet_subsys(&ip_vs_app_ops); | ||
| 226 | } | 218 | } |
diff --git a/net/netfilter/ipvs/ip_vs_proto.c b/net/netfilter/ipvs/ip_vs_proto.c index 17484a4416ef..eb86028536fc 100644 --- a/net/netfilter/ipvs/ip_vs_proto.c +++ b/net/netfilter/ipvs/ip_vs_proto.c | |||
| @@ -316,7 +316,7 @@ ip_vs_tcpudp_debug_packet(int af, struct ip_vs_protocol *pp, | |||
| 316 | /* | 316 | /* |
| 317 | * per network name-space init | 317 | * per network name-space init |
| 318 | */ | 318 | */ |
| 319 | static int __net_init __ip_vs_protocol_init(struct net *net) | 319 | int __net_init __ip_vs_protocol_init(struct net *net) |
| 320 | { | 320 | { |
| 321 | #ifdef CONFIG_IP_VS_PROTO_TCP | 321 | #ifdef CONFIG_IP_VS_PROTO_TCP |
| 322 | register_ip_vs_proto_netns(net, &ip_vs_protocol_tcp); | 322 | register_ip_vs_proto_netns(net, &ip_vs_protocol_tcp); |
| @@ -336,7 +336,7 @@ static int __net_init __ip_vs_protocol_init(struct net *net) | |||
| 336 | return 0; | 336 | return 0; |
| 337 | } | 337 | } |
| 338 | 338 | ||
| 339 | static void __net_exit __ip_vs_protocol_cleanup(struct net *net) | 339 | void __net_exit __ip_vs_protocol_cleanup(struct net *net) |
| 340 | { | 340 | { |
| 341 | struct netns_ipvs *ipvs = net_ipvs(net); | 341 | struct netns_ipvs *ipvs = net_ipvs(net); |
| 342 | struct ip_vs_proto_data *pd; | 342 | struct ip_vs_proto_data *pd; |
| @@ -349,11 +349,6 @@ static void __net_exit __ip_vs_protocol_cleanup(struct net *net) | |||
| 349 | } | 349 | } |
| 350 | } | 350 | } |
| 351 | 351 | ||
| 352 | static struct pernet_operations ipvs_proto_ops = { | ||
| 353 | .init = __ip_vs_protocol_init, | ||
| 354 | .exit = __ip_vs_protocol_cleanup, | ||
| 355 | }; | ||
| 356 | |||
| 357 | int __init ip_vs_protocol_init(void) | 352 | int __init ip_vs_protocol_init(void) |
| 358 | { | 353 | { |
| 359 | char protocols[64]; | 354 | char protocols[64]; |
| @@ -382,7 +377,6 @@ int __init ip_vs_protocol_init(void) | |||
| 382 | REGISTER_PROTOCOL(&ip_vs_protocol_esp); | 377 | REGISTER_PROTOCOL(&ip_vs_protocol_esp); |
| 383 | #endif | 378 | #endif |
| 384 | pr_info("Registered protocols (%s)\n", &protocols[2]); | 379 | pr_info("Registered protocols (%s)\n", &protocols[2]); |
| 385 | return register_pernet_subsys(&ipvs_proto_ops); | ||
| 386 | 380 | ||
| 387 | return 0; | 381 | return 0; |
| 388 | } | 382 | } |
| @@ -393,7 +387,6 @@ void ip_vs_protocol_cleanup(void) | |||
| 393 | struct ip_vs_protocol *pp; | 387 | struct ip_vs_protocol *pp; |
| 394 | int i; | 388 | int i; |
| 395 | 389 | ||
| 396 | unregister_pernet_subsys(&ipvs_proto_ops); | ||
| 397 | /* unregister all the ipvs protocols */ | 390 | /* unregister all the ipvs protocols */ |
| 398 | for (i = 0; i < IP_VS_PROTO_TAB_SIZE; i++) { | 391 | for (i = 0; i < IP_VS_PROTO_TAB_SIZE; i++) { |
| 399 | while ((pp = ip_vs_proto_table[i]) != NULL) | 392 | while ((pp = ip_vs_proto_table[i]) != NULL) |
diff --git a/net/netfilter/ipvs/ip_vs_sync.c b/net/netfilter/ipvs/ip_vs_sync.c index 3e7961e85e9c..e292e5bddc70 100644 --- a/net/netfilter/ipvs/ip_vs_sync.c +++ b/net/netfilter/ipvs/ip_vs_sync.c | |||
| @@ -1303,13 +1303,18 @@ static struct socket *make_send_sock(struct net *net) | |||
| 1303 | struct socket *sock; | 1303 | struct socket *sock; |
| 1304 | int result; | 1304 | int result; |
| 1305 | 1305 | ||
| 1306 | /* First create a socket */ | 1306 | /* First create a socket move it to right name space later */ |
| 1307 | result = __sock_create(net, PF_INET, SOCK_DGRAM, IPPROTO_UDP, &sock, 1); | 1307 | result = sock_create_kern(PF_INET, SOCK_DGRAM, IPPROTO_UDP, &sock); |
| 1308 | if (result < 0) { | 1308 | if (result < 0) { |
| 1309 | pr_err("Error during creation of socket; terminating\n"); | 1309 | pr_err("Error during creation of socket; terminating\n"); |
| 1310 | return ERR_PTR(result); | 1310 | return ERR_PTR(result); |
| 1311 | } | 1311 | } |
| 1312 | 1312 | /* | |
| 1313 | * Kernel sockets that are a part of a namespace, should not | ||
| 1314 | * hold a reference to a namespace in order to allow to stop it. | ||
| 1315 | * After sk_change_net should be released using sk_release_kernel. | ||
| 1316 | */ | ||
| 1317 | sk_change_net(sock->sk, net); | ||
| 1313 | result = set_mcast_if(sock->sk, ipvs->master_mcast_ifn); | 1318 | result = set_mcast_if(sock->sk, ipvs->master_mcast_ifn); |
| 1314 | if (result < 0) { | 1319 | if (result < 0) { |
| 1315 | pr_err("Error setting outbound mcast interface\n"); | 1320 | pr_err("Error setting outbound mcast interface\n"); |
| @@ -1334,8 +1339,8 @@ static struct socket *make_send_sock(struct net *net) | |||
| 1334 | 1339 | ||
| 1335 | return sock; | 1340 | return sock; |
| 1336 | 1341 | ||
| 1337 | error: | 1342 | error: |
| 1338 | sock_release(sock); | 1343 | sk_release_kernel(sock->sk); |
| 1339 | return ERR_PTR(result); | 1344 | return ERR_PTR(result); |
| 1340 | } | 1345 | } |
| 1341 | 1346 | ||
| @@ -1350,12 +1355,17 @@ static struct socket *make_receive_sock(struct net *net) | |||
| 1350 | int result; | 1355 | int result; |
| 1351 | 1356 | ||
| 1352 | /* First create a socket */ | 1357 | /* First create a socket */ |
| 1353 | result = __sock_create(net, PF_INET, SOCK_DGRAM, IPPROTO_UDP, &sock, 1); | 1358 | result = sock_create_kern(PF_INET, SOCK_DGRAM, IPPROTO_UDP, &sock); |
| 1354 | if (result < 0) { | 1359 | if (result < 0) { |
| 1355 | pr_err("Error during creation of socket; terminating\n"); | 1360 | pr_err("Error during creation of socket; terminating\n"); |
| 1356 | return ERR_PTR(result); | 1361 | return ERR_PTR(result); |
| 1357 | } | 1362 | } |
| 1358 | 1363 | /* | |
| 1364 | * Kernel sockets that are a part of a namespace, should not | ||
| 1365 | * hold a reference to a namespace in order to allow to stop it. | ||
| 1366 | * After sk_change_net should be released using sk_release_kernel. | ||
| 1367 | */ | ||
| 1368 | sk_change_net(sock->sk, net); | ||
| 1359 | /* it is equivalent to the REUSEADDR option in user-space */ | 1369 | /* it is equivalent to the REUSEADDR option in user-space */ |
| 1360 | sock->sk->sk_reuse = 1; | 1370 | sock->sk->sk_reuse = 1; |
| 1361 | 1371 | ||
| @@ -1377,8 +1387,8 @@ static struct socket *make_receive_sock(struct net *net) | |||
| 1377 | 1387 | ||
| 1378 | return sock; | 1388 | return sock; |
| 1379 | 1389 | ||
| 1380 | error: | 1390 | error: |
| 1381 | sock_release(sock); | 1391 | sk_release_kernel(sock->sk); |
| 1382 | return ERR_PTR(result); | 1392 | return ERR_PTR(result); |
| 1383 | } | 1393 | } |
| 1384 | 1394 | ||
| @@ -1473,7 +1483,7 @@ static int sync_thread_master(void *data) | |||
| 1473 | ip_vs_sync_buff_release(sb); | 1483 | ip_vs_sync_buff_release(sb); |
| 1474 | 1484 | ||
| 1475 | /* release the sending multicast socket */ | 1485 | /* release the sending multicast socket */ |
| 1476 | sock_release(tinfo->sock); | 1486 | sk_release_kernel(tinfo->sock->sk); |
| 1477 | kfree(tinfo); | 1487 | kfree(tinfo); |
| 1478 | 1488 | ||
| 1479 | return 0; | 1489 | return 0; |
| @@ -1513,7 +1523,7 @@ static int sync_thread_backup(void *data) | |||
| 1513 | } | 1523 | } |
| 1514 | 1524 | ||
| 1515 | /* release the sending multicast socket */ | 1525 | /* release the sending multicast socket */ |
| 1516 | sock_release(tinfo->sock); | 1526 | sk_release_kernel(tinfo->sock->sk); |
| 1517 | kfree(tinfo->buf); | 1527 | kfree(tinfo->buf); |
| 1518 | kfree(tinfo); | 1528 | kfree(tinfo); |
| 1519 | 1529 | ||
| @@ -1601,7 +1611,7 @@ outtinfo: | |||
| 1601 | outbuf: | 1611 | outbuf: |
| 1602 | kfree(buf); | 1612 | kfree(buf); |
| 1603 | outsocket: | 1613 | outsocket: |
| 1604 | sock_release(sock); | 1614 | sk_release_kernel(sock->sk); |
| 1605 | out: | 1615 | out: |
| 1606 | return result; | 1616 | return result; |
| 1607 | } | 1617 | } |
| @@ -1610,6 +1620,7 @@ out: | |||
| 1610 | int stop_sync_thread(struct net *net, int state) | 1620 | int stop_sync_thread(struct net *net, int state) |
| 1611 | { | 1621 | { |
| 1612 | struct netns_ipvs *ipvs = net_ipvs(net); | 1622 | struct netns_ipvs *ipvs = net_ipvs(net); |
| 1623 | int retc = -EINVAL; | ||
| 1613 | 1624 | ||
| 1614 | IP_VS_DBG(7, "%s(): pid %d\n", __func__, task_pid_nr(current)); | 1625 | IP_VS_DBG(7, "%s(): pid %d\n", __func__, task_pid_nr(current)); |
| 1615 | 1626 | ||
| @@ -1629,7 +1640,7 @@ int stop_sync_thread(struct net *net, int state) | |||
| 1629 | spin_lock_bh(&ipvs->sync_lock); | 1640 | spin_lock_bh(&ipvs->sync_lock); |
| 1630 | ipvs->sync_state &= ~IP_VS_STATE_MASTER; | 1641 | ipvs->sync_state &= ~IP_VS_STATE_MASTER; |
| 1631 | spin_unlock_bh(&ipvs->sync_lock); | 1642 | spin_unlock_bh(&ipvs->sync_lock); |
| 1632 | kthread_stop(ipvs->master_thread); | 1643 | retc = kthread_stop(ipvs->master_thread); |
| 1633 | ipvs->master_thread = NULL; | 1644 | ipvs->master_thread = NULL; |
| 1634 | } else if (state == IP_VS_STATE_BACKUP) { | 1645 | } else if (state == IP_VS_STATE_BACKUP) { |
| 1635 | if (!ipvs->backup_thread) | 1646 | if (!ipvs->backup_thread) |
| @@ -1639,22 +1650,20 @@ int stop_sync_thread(struct net *net, int state) | |||
| 1639 | task_pid_nr(ipvs->backup_thread)); | 1650 | task_pid_nr(ipvs->backup_thread)); |
| 1640 | 1651 | ||
| 1641 | ipvs->sync_state &= ~IP_VS_STATE_BACKUP; | 1652 | ipvs->sync_state &= ~IP_VS_STATE_BACKUP; |
| 1642 | kthread_stop(ipvs->backup_thread); | 1653 | retc = kthread_stop(ipvs->backup_thread); |
| 1643 | ipvs->backup_thread = NULL; | 1654 | ipvs->backup_thread = NULL; |
| 1644 | } else { | ||
| 1645 | return -EINVAL; | ||
| 1646 | } | 1655 | } |
| 1647 | 1656 | ||
| 1648 | /* decrease the module use count */ | 1657 | /* decrease the module use count */ |
| 1649 | ip_vs_use_count_dec(); | 1658 | ip_vs_use_count_dec(); |
| 1650 | 1659 | ||
| 1651 | return 0; | 1660 | return retc; |
| 1652 | } | 1661 | } |
| 1653 | 1662 | ||
| 1654 | /* | 1663 | /* |
| 1655 | * Initialize data struct for each netns | 1664 | * Initialize data struct for each netns |
| 1656 | */ | 1665 | */ |
| 1657 | static int __net_init __ip_vs_sync_init(struct net *net) | 1666 | int __net_init __ip_vs_sync_init(struct net *net) |
| 1658 | { | 1667 | { |
| 1659 | struct netns_ipvs *ipvs = net_ipvs(net); | 1668 | struct netns_ipvs *ipvs = net_ipvs(net); |
| 1660 | 1669 | ||
| @@ -1668,24 +1677,24 @@ static int __net_init __ip_vs_sync_init(struct net *net) | |||
| 1668 | return 0; | 1677 | return 0; |
| 1669 | } | 1678 | } |
| 1670 | 1679 | ||
| 1671 | static void __ip_vs_sync_cleanup(struct net *net) | 1680 | void __ip_vs_sync_cleanup(struct net *net) |
| 1672 | { | 1681 | { |
| 1673 | stop_sync_thread(net, IP_VS_STATE_MASTER); | 1682 | int retc; |
| 1674 | stop_sync_thread(net, IP_VS_STATE_BACKUP); | ||
| 1675 | } | ||
| 1676 | 1683 | ||
| 1677 | static struct pernet_operations ipvs_sync_ops = { | 1684 | retc = stop_sync_thread(net, IP_VS_STATE_MASTER); |
| 1678 | .init = __ip_vs_sync_init, | 1685 | if (retc && retc != -ESRCH) |
| 1679 | .exit = __ip_vs_sync_cleanup, | 1686 | pr_err("Failed to stop Master Daemon\n"); |
| 1680 | }; | ||
| 1681 | 1687 | ||
| 1688 | retc = stop_sync_thread(net, IP_VS_STATE_BACKUP); | ||
| 1689 | if (retc && retc != -ESRCH) | ||
| 1690 | pr_err("Failed to stop Backup Daemon\n"); | ||
| 1691 | } | ||
| 1682 | 1692 | ||
| 1683 | int __init ip_vs_sync_init(void) | 1693 | int __init ip_vs_sync_init(void) |
| 1684 | { | 1694 | { |
| 1685 | return register_pernet_subsys(&ipvs_sync_ops); | 1695 | return 0; |
| 1686 | } | 1696 | } |
| 1687 | 1697 | ||
| 1688 | void ip_vs_sync_cleanup(void) | 1698 | void ip_vs_sync_cleanup(void) |
| 1689 | { | 1699 | { |
| 1690 | unregister_pernet_subsys(&ipvs_sync_ops); | ||
| 1691 | } | 1700 | } |
diff --git a/net/netfilter/nf_conntrack_netlink.c b/net/netfilter/nf_conntrack_netlink.c index 30bf8a167fc8..482e90c61850 100644 --- a/net/netfilter/nf_conntrack_netlink.c +++ b/net/netfilter/nf_conntrack_netlink.c | |||
| @@ -1334,6 +1334,7 @@ ctnetlink_create_conntrack(struct net *net, u16 zone, | |||
| 1334 | struct nf_conn *ct; | 1334 | struct nf_conn *ct; |
| 1335 | int err = -EINVAL; | 1335 | int err = -EINVAL; |
| 1336 | struct nf_conntrack_helper *helper; | 1336 | struct nf_conntrack_helper *helper; |
| 1337 | struct nf_conn_tstamp *tstamp; | ||
| 1337 | 1338 | ||
| 1338 | ct = nf_conntrack_alloc(net, zone, otuple, rtuple, GFP_ATOMIC); | 1339 | ct = nf_conntrack_alloc(net, zone, otuple, rtuple, GFP_ATOMIC); |
| 1339 | if (IS_ERR(ct)) | 1340 | if (IS_ERR(ct)) |
| @@ -1451,6 +1452,9 @@ ctnetlink_create_conntrack(struct net *net, u16 zone, | |||
| 1451 | __set_bit(IPS_EXPECTED_BIT, &ct->status); | 1452 | __set_bit(IPS_EXPECTED_BIT, &ct->status); |
| 1452 | ct->master = master_ct; | 1453 | ct->master = master_ct; |
| 1453 | } | 1454 | } |
| 1455 | tstamp = nf_conn_tstamp_find(ct); | ||
| 1456 | if (tstamp) | ||
| 1457 | tstamp->start = ktime_to_ns(ktime_get_real()); | ||
| 1454 | 1458 | ||
| 1455 | add_timer(&ct->timeout); | 1459 | add_timer(&ct->timeout); |
| 1456 | nf_conntrack_hash_insert(ct); | 1460 | nf_conntrack_hash_insert(ct); |
diff --git a/net/netfilter/x_tables.c b/net/netfilter/x_tables.c index a9adf4c6b299..8a025a585d2f 100644 --- a/net/netfilter/x_tables.c +++ b/net/netfilter/x_tables.c | |||
| @@ -455,6 +455,7 @@ void xt_compat_flush_offsets(u_int8_t af) | |||
| 455 | vfree(xt[af].compat_tab); | 455 | vfree(xt[af].compat_tab); |
| 456 | xt[af].compat_tab = NULL; | 456 | xt[af].compat_tab = NULL; |
| 457 | xt[af].number = 0; | 457 | xt[af].number = 0; |
| 458 | xt[af].cur = 0; | ||
| 458 | } | 459 | } |
| 459 | } | 460 | } |
| 460 | EXPORT_SYMBOL_GPL(xt_compat_flush_offsets); | 461 | EXPORT_SYMBOL_GPL(xt_compat_flush_offsets); |
| @@ -473,8 +474,7 @@ int xt_compat_calc_jump(u_int8_t af, unsigned int offset) | |||
| 473 | else | 474 | else |
| 474 | return mid ? tmp[mid - 1].delta : 0; | 475 | return mid ? tmp[mid - 1].delta : 0; |
| 475 | } | 476 | } |
| 476 | WARN_ON_ONCE(1); | 477 | return left ? tmp[left - 1].delta : 0; |
| 477 | return 0; | ||
| 478 | } | 478 | } |
| 479 | EXPORT_SYMBOL_GPL(xt_compat_calc_jump); | 479 | EXPORT_SYMBOL_GPL(xt_compat_calc_jump); |
| 480 | 480 | ||
diff --git a/net/netfilter/xt_DSCP.c b/net/netfilter/xt_DSCP.c index 0a229191e55b..ae8271652efa 100644 --- a/net/netfilter/xt_DSCP.c +++ b/net/netfilter/xt_DSCP.c | |||
| @@ -99,7 +99,7 @@ tos_tg6(struct sk_buff *skb, const struct xt_action_param *par) | |||
| 99 | u_int8_t orig, nv; | 99 | u_int8_t orig, nv; |
| 100 | 100 | ||
| 101 | orig = ipv6_get_dsfield(iph); | 101 | orig = ipv6_get_dsfield(iph); |
| 102 | nv = (orig & info->tos_mask) ^ info->tos_value; | 102 | nv = (orig & ~info->tos_mask) ^ info->tos_value; |
| 103 | 103 | ||
| 104 | if (orig != nv) { | 104 | if (orig != nv) { |
| 105 | if (!skb_make_writable(skb, sizeof(struct iphdr))) | 105 | if (!skb_make_writable(skb, sizeof(struct iphdr))) |
diff --git a/net/netfilter/xt_conntrack.c b/net/netfilter/xt_conntrack.c index 481a86fdc409..61805d7b38aa 100644 --- a/net/netfilter/xt_conntrack.c +++ b/net/netfilter/xt_conntrack.c | |||
| @@ -272,11 +272,6 @@ static int conntrack_mt_check(const struct xt_mtchk_param *par) | |||
| 272 | { | 272 | { |
| 273 | int ret; | 273 | int ret; |
| 274 | 274 | ||
| 275 | if (strcmp(par->table, "raw") == 0) { | ||
| 276 | pr_info("state is undetermined at the time of raw table\n"); | ||
| 277 | return -EINVAL; | ||
| 278 | } | ||
| 279 | |||
| 280 | ret = nf_ct_l3proto_try_module_get(par->family); | 275 | ret = nf_ct_l3proto_try_module_get(par->family); |
| 281 | if (ret < 0) | 276 | if (ret < 0) |
| 282 | pr_info("cannot load conntrack support for proto=%u\n", | 277 | pr_info("cannot load conntrack support for proto=%u\n", |
diff --git a/net/xfrm/xfrm_policy.c b/net/xfrm/xfrm_policy.c index 15792d8b6272..b4d745ea8ee1 100644 --- a/net/xfrm/xfrm_policy.c +++ b/net/xfrm/xfrm_policy.c | |||
| @@ -1406,6 +1406,7 @@ static struct dst_entry *xfrm_bundle_create(struct xfrm_policy *policy, | |||
| 1406 | struct net *net = xp_net(policy); | 1406 | struct net *net = xp_net(policy); |
| 1407 | unsigned long now = jiffies; | 1407 | unsigned long now = jiffies; |
| 1408 | struct net_device *dev; | 1408 | struct net_device *dev; |
| 1409 | struct xfrm_mode *inner_mode; | ||
| 1409 | struct dst_entry *dst_prev = NULL; | 1410 | struct dst_entry *dst_prev = NULL; |
| 1410 | struct dst_entry *dst0 = NULL; | 1411 | struct dst_entry *dst0 = NULL; |
| 1411 | int i = 0; | 1412 | int i = 0; |
| @@ -1436,6 +1437,17 @@ static struct dst_entry *xfrm_bundle_create(struct xfrm_policy *policy, | |||
| 1436 | goto put_states; | 1437 | goto put_states; |
| 1437 | } | 1438 | } |
| 1438 | 1439 | ||
| 1440 | if (xfrm[i]->sel.family == AF_UNSPEC) { | ||
| 1441 | inner_mode = xfrm_ip2inner_mode(xfrm[i], | ||
| 1442 | xfrm_af2proto(family)); | ||
| 1443 | if (!inner_mode) { | ||
| 1444 | err = -EAFNOSUPPORT; | ||
| 1445 | dst_release(dst); | ||
| 1446 | goto put_states; | ||
| 1447 | } | ||
| 1448 | } else | ||
| 1449 | inner_mode = xfrm[i]->inner_mode; | ||
| 1450 | |||
| 1439 | if (!dst_prev) | 1451 | if (!dst_prev) |
| 1440 | dst0 = dst1; | 1452 | dst0 = dst1; |
| 1441 | else { | 1453 | else { |
| @@ -1464,7 +1476,7 @@ static struct dst_entry *xfrm_bundle_create(struct xfrm_policy *policy, | |||
| 1464 | dst1->lastuse = now; | 1476 | dst1->lastuse = now; |
| 1465 | 1477 | ||
| 1466 | dst1->input = dst_discard; | 1478 | dst1->input = dst_discard; |
| 1467 | dst1->output = xfrm[i]->outer_mode->afinfo->output; | 1479 | dst1->output = inner_mode->afinfo->output; |
| 1468 | 1480 | ||
| 1469 | dst1->next = dst_prev; | 1481 | dst1->next = dst_prev; |
| 1470 | dst_prev = dst1; | 1482 | dst_prev = dst1; |
diff --git a/net/xfrm/xfrm_replay.c b/net/xfrm/xfrm_replay.c index e8a781422feb..47f1b8638df9 100644 --- a/net/xfrm/xfrm_replay.c +++ b/net/xfrm/xfrm_replay.c | |||
| @@ -535,6 +535,9 @@ int xfrm_init_replay(struct xfrm_state *x) | |||
| 535 | replay_esn->bmp_len * sizeof(__u32) * 8) | 535 | replay_esn->bmp_len * sizeof(__u32) * 8) |
| 536 | return -EINVAL; | 536 | return -EINVAL; |
| 537 | 537 | ||
| 538 | if ((x->props.flags & XFRM_STATE_ESN) && replay_esn->replay_window == 0) | ||
| 539 | return -EINVAL; | ||
| 540 | |||
| 538 | if ((x->props.flags & XFRM_STATE_ESN) && x->replay_esn) | 541 | if ((x->props.flags & XFRM_STATE_ESN) && x->replay_esn) |
| 539 | x->repl = &xfrm_replay_esn; | 542 | x->repl = &xfrm_replay_esn; |
| 540 | else | 543 | else |
diff --git a/security/selinux/ss/policydb.c b/security/selinux/ss/policydb.c index e6e7ce0d3d55..7102457661d6 100644 --- a/security/selinux/ss/policydb.c +++ b/security/selinux/ss/policydb.c | |||
| @@ -1819,8 +1819,6 @@ static int filename_trans_read(struct policydb *p, void *fp) | |||
| 1819 | goto out; | 1819 | goto out; |
| 1820 | nel = le32_to_cpu(buf[0]); | 1820 | nel = le32_to_cpu(buf[0]); |
| 1821 | 1821 | ||
| 1822 | printk(KERN_ERR "%s: nel=%d\n", __func__, nel); | ||
| 1823 | |||
| 1824 | last = p->filename_trans; | 1822 | last = p->filename_trans; |
| 1825 | while (last && last->next) | 1823 | while (last && last->next) |
| 1826 | last = last->next; | 1824 | last = last->next; |
| @@ -1857,8 +1855,6 @@ static int filename_trans_read(struct policydb *p, void *fp) | |||
| 1857 | goto out; | 1855 | goto out; |
| 1858 | name[len] = 0; | 1856 | name[len] = 0; |
| 1859 | 1857 | ||
| 1860 | printk(KERN_ERR "%s: ft=%p ft->name=%p ft->name=%s\n", __func__, ft, ft->name, ft->name); | ||
| 1861 | |||
| 1862 | rc = next_entry(buf, fp, sizeof(u32) * 4); | 1858 | rc = next_entry(buf, fp, sizeof(u32) * 4); |
| 1863 | if (rc) | 1859 | if (rc) |
| 1864 | goto out; | 1860 | goto out; |
diff --git a/sound/soc/codecs/ssm2602.c b/sound/soc/codecs/ssm2602.c index 2727befd158e..b04d28039c16 100644 --- a/sound/soc/codecs/ssm2602.c +++ b/sound/soc/codecs/ssm2602.c | |||
| @@ -139,7 +139,7 @@ SOC_DOUBLE_R("Capture Volume", SSM2602_LINVOL, SSM2602_RINVOL, 0, 31, 0), | |||
| 139 | SOC_DOUBLE_R("Capture Switch", SSM2602_LINVOL, SSM2602_RINVOL, 7, 1, 1), | 139 | SOC_DOUBLE_R("Capture Switch", SSM2602_LINVOL, SSM2602_RINVOL, 7, 1, 1), |
| 140 | 140 | ||
| 141 | SOC_SINGLE("Mic Boost (+20dB)", SSM2602_APANA, 0, 1, 0), | 141 | SOC_SINGLE("Mic Boost (+20dB)", SSM2602_APANA, 0, 1, 0), |
| 142 | SOC_SINGLE("Mic Boost2 (+20dB)", SSM2602_APANA, 7, 1, 0), | 142 | SOC_SINGLE("Mic Boost2 (+20dB)", SSM2602_APANA, 8, 1, 0), |
| 143 | SOC_SINGLE("Mic Switch", SSM2602_APANA, 1, 1, 1), | 143 | SOC_SINGLE("Mic Switch", SSM2602_APANA, 1, 1, 1), |
| 144 | 144 | ||
| 145 | SOC_SINGLE("Sidetone Playback Volume", SSM2602_APANA, 6, 3, 1), | 145 | SOC_SINGLE("Sidetone Playback Volume", SSM2602_APANA, 6, 3, 1), |
| @@ -602,7 +602,7 @@ static struct snd_soc_codec_driver soc_codec_dev_ssm2602 = { | |||
| 602 | .read = ssm2602_read_reg_cache, | 602 | .read = ssm2602_read_reg_cache, |
| 603 | .write = ssm2602_write, | 603 | .write = ssm2602_write, |
| 604 | .set_bias_level = ssm2602_set_bias_level, | 604 | .set_bias_level = ssm2602_set_bias_level, |
| 605 | .reg_cache_size = sizeof(ssm2602_reg), | 605 | .reg_cache_size = ARRAY_SIZE(ssm2602_reg), |
| 606 | .reg_word_size = sizeof(u16), | 606 | .reg_word_size = sizeof(u16), |
| 607 | .reg_cache_default = ssm2602_reg, | 607 | .reg_cache_default = ssm2602_reg, |
| 608 | }; | 608 | }; |
| @@ -614,7 +614,7 @@ static struct snd_soc_codec_driver soc_codec_dev_ssm2602 = { | |||
| 614 | * low = 0x1a | 614 | * low = 0x1a |
| 615 | * high = 0x1b | 615 | * high = 0x1b |
| 616 | */ | 616 | */ |
| 617 | static int ssm2602_i2c_probe(struct i2c_client *i2c, | 617 | static int __devinit ssm2602_i2c_probe(struct i2c_client *i2c, |
| 618 | const struct i2c_device_id *id) | 618 | const struct i2c_device_id *id) |
| 619 | { | 619 | { |
| 620 | struct ssm2602_priv *ssm2602; | 620 | struct ssm2602_priv *ssm2602; |
| @@ -635,7 +635,7 @@ static int ssm2602_i2c_probe(struct i2c_client *i2c, | |||
| 635 | return ret; | 635 | return ret; |
| 636 | } | 636 | } |
| 637 | 637 | ||
| 638 | static int ssm2602_i2c_remove(struct i2c_client *client) | 638 | static int __devexit ssm2602_i2c_remove(struct i2c_client *client) |
| 639 | { | 639 | { |
| 640 | snd_soc_unregister_codec(&client->dev); | 640 | snd_soc_unregister_codec(&client->dev); |
| 641 | kfree(i2c_get_clientdata(client)); | 641 | kfree(i2c_get_clientdata(client)); |
| @@ -655,7 +655,7 @@ static struct i2c_driver ssm2602_i2c_driver = { | |||
| 655 | .owner = THIS_MODULE, | 655 | .owner = THIS_MODULE, |
| 656 | }, | 656 | }, |
| 657 | .probe = ssm2602_i2c_probe, | 657 | .probe = ssm2602_i2c_probe, |
| 658 | .remove = ssm2602_i2c_remove, | 658 | .remove = __devexit_p(ssm2602_i2c_remove), |
| 659 | .id_table = ssm2602_i2c_id, | 659 | .id_table = ssm2602_i2c_id, |
| 660 | }; | 660 | }; |
| 661 | #endif | 661 | #endif |
diff --git a/sound/soc/codecs/uda134x.c b/sound/soc/codecs/uda134x.c index 48ffd406a71d..a7b8f301bad3 100644 --- a/sound/soc/codecs/uda134x.c +++ b/sound/soc/codecs/uda134x.c | |||
| @@ -601,9 +601,7 @@ static struct snd_soc_codec_driver soc_codec_dev_uda134x = { | |||
| 601 | .reg_cache_step = 1, | 601 | .reg_cache_step = 1, |
| 602 | .read = uda134x_read_reg_cache, | 602 | .read = uda134x_read_reg_cache, |
| 603 | .write = uda134x_write, | 603 | .write = uda134x_write, |
| 604 | #ifdef POWER_OFF_ON_STANDBY | ||
| 605 | .set_bias_level = uda134x_set_bias_level, | 604 | .set_bias_level = uda134x_set_bias_level, |
| 606 | #endif | ||
| 607 | }; | 605 | }; |
| 608 | 606 | ||
| 609 | static int __devinit uda134x_codec_probe(struct platform_device *pdev) | 607 | static int __devinit uda134x_codec_probe(struct platform_device *pdev) |
diff --git a/sound/soc/codecs/wm8903.c b/sound/soc/codecs/wm8903.c index f52b623bb692..824d1c8c8a35 100644 --- a/sound/soc/codecs/wm8903.c +++ b/sound/soc/codecs/wm8903.c | |||
| @@ -692,7 +692,7 @@ SOC_ENUM("DRC Smoothing Threshold", drc_smoothing), | |||
| 692 | SOC_SINGLE_TLV("DRC Startup Volume", WM8903_DRC_0, 6, 18, 0, drc_tlv_startup), | 692 | SOC_SINGLE_TLV("DRC Startup Volume", WM8903_DRC_0, 6, 18, 0, drc_tlv_startup), |
| 693 | 693 | ||
| 694 | SOC_DOUBLE_R_TLV("Digital Capture Volume", WM8903_ADC_DIGITAL_VOLUME_LEFT, | 694 | SOC_DOUBLE_R_TLV("Digital Capture Volume", WM8903_ADC_DIGITAL_VOLUME_LEFT, |
| 695 | WM8903_ADC_DIGITAL_VOLUME_RIGHT, 1, 96, 0, digital_tlv), | 695 | WM8903_ADC_DIGITAL_VOLUME_RIGHT, 1, 120, 0, digital_tlv), |
| 696 | SOC_ENUM("ADC Companding Mode", adc_companding), | 696 | SOC_ENUM("ADC Companding Mode", adc_companding), |
| 697 | SOC_SINGLE("ADC Companding Switch", WM8903_AUDIO_INTERFACE_0, 3, 1, 0), | 697 | SOC_SINGLE("ADC Companding Switch", WM8903_AUDIO_INTERFACE_0, 3, 1, 0), |
| 698 | 698 | ||
diff --git a/sound/soc/jz4740/jz4740-i2s.c b/sound/soc/jz4740/jz4740-i2s.c index 419bf4f5534a..cd22a54b2f14 100644 --- a/sound/soc/jz4740/jz4740-i2s.c +++ b/sound/soc/jz4740/jz4740-i2s.c | |||
| @@ -133,7 +133,7 @@ static void jz4740_i2s_shutdown(struct snd_pcm_substream *substream, | |||
| 133 | struct jz4740_i2s *i2s = snd_soc_dai_get_drvdata(dai); | 133 | struct jz4740_i2s *i2s = snd_soc_dai_get_drvdata(dai); |
| 134 | uint32_t conf; | 134 | uint32_t conf; |
| 135 | 135 | ||
| 136 | if (!dai->active) | 136 | if (dai->active) |
| 137 | return; | 137 | return; |
| 138 | 138 | ||
| 139 | conf = jz4740_i2s_read(i2s, JZ_REG_AIC_CONF); | 139 | conf = jz4740_i2s_read(i2s, JZ_REG_AIC_CONF); |
diff --git a/sound/soc/mid-x86/sst_platform.c b/sound/soc/mid-x86/sst_platform.c index d567c322a2fb..6b1f9d3bf34e 100644 --- a/sound/soc/mid-x86/sst_platform.c +++ b/sound/soc/mid-x86/sst_platform.c | |||
| @@ -376,6 +376,11 @@ static int sst_platform_pcm_hw_params(struct snd_pcm_substream *substream, | |||
| 376 | return 0; | 376 | return 0; |
| 377 | } | 377 | } |
| 378 | 378 | ||
| 379 | static int sst_platform_pcm_hw_free(struct snd_pcm_substream *substream) | ||
| 380 | { | ||
| 381 | return snd_pcm_lib_free_pages(substream); | ||
| 382 | } | ||
| 383 | |||
| 379 | static struct snd_pcm_ops sst_platform_ops = { | 384 | static struct snd_pcm_ops sst_platform_ops = { |
| 380 | .open = sst_platform_open, | 385 | .open = sst_platform_open, |
| 381 | .close = sst_platform_close, | 386 | .close = sst_platform_close, |
| @@ -384,6 +389,7 @@ static struct snd_pcm_ops sst_platform_ops = { | |||
| 384 | .trigger = sst_platform_pcm_trigger, | 389 | .trigger = sst_platform_pcm_trigger, |
| 385 | .pointer = sst_platform_pcm_pointer, | 390 | .pointer = sst_platform_pcm_pointer, |
| 386 | .hw_params = sst_platform_pcm_hw_params, | 391 | .hw_params = sst_platform_pcm_hw_params, |
| 392 | .hw_free = sst_platform_pcm_hw_free, | ||
| 387 | }; | 393 | }; |
| 388 | 394 | ||
| 389 | static void sst_pcm_free(struct snd_pcm *pcm) | 395 | static void sst_pcm_free(struct snd_pcm *pcm) |
diff --git a/sound/soc/soc-core.c b/sound/soc/soc-core.c index d8562ce4de7a..dd55d1069468 100644 --- a/sound/soc/soc-core.c +++ b/sound/soc/soc-core.c | |||
| @@ -3291,6 +3291,8 @@ int snd_soc_register_card(struct snd_soc_card *card) | |||
| 3291 | if (!card->name || !card->dev) | 3291 | if (!card->name || !card->dev) |
| 3292 | return -EINVAL; | 3292 | return -EINVAL; |
| 3293 | 3293 | ||
| 3294 | dev_set_drvdata(card->dev, card); | ||
| 3295 | |||
| 3294 | snd_soc_initialize_card_lists(card); | 3296 | snd_soc_initialize_card_lists(card); |
| 3295 | 3297 | ||
| 3296 | soc_init_card_debugfs(card); | 3298 | soc_init_card_debugfs(card); |
