diff options
112 files changed, 718 insertions, 350 deletions
diff --git a/Documentation/kernel-parameters.txt b/Documentation/kernel-parameters.txt index edab81c13182..f44552e07913 100644 --- a/Documentation/kernel-parameters.txt +++ b/Documentation/kernel-parameters.txt | |||
| @@ -221,14 +221,17 @@ and is between 256 and 4096 characters. It is defined in the file | |||
| 221 | Bits in debug_level correspond to a level in | 221 | Bits in debug_level correspond to a level in |
| 222 | ACPI_DEBUG_PRINT statements, e.g., | 222 | ACPI_DEBUG_PRINT statements, e.g., |
| 223 | ACPI_DEBUG_PRINT((ACPI_DB_INFO, ... | 223 | ACPI_DEBUG_PRINT((ACPI_DB_INFO, ... |
| 224 | See Documentation/acpi/debug.txt for more information | 224 | The debug_level mask defaults to "info". See |
| 225 | about debug layers and levels. | 225 | Documentation/acpi/debug.txt for more information about |
| 226 | debug layers and levels. | ||
| 226 | 227 | ||
| 228 | Enable processor driver info messages: | ||
| 229 | acpi.debug_layer=0x20000000 | ||
| 230 | Enable PCI/PCI interrupt routing info messages: | ||
| 231 | acpi.debug_layer=0x400000 | ||
| 227 | Enable AML "Debug" output, i.e., stores to the Debug | 232 | Enable AML "Debug" output, i.e., stores to the Debug |
| 228 | object while interpreting AML: | 233 | object while interpreting AML: |
| 229 | acpi.debug_layer=0xffffffff acpi.debug_level=0x2 | 234 | acpi.debug_layer=0xffffffff acpi.debug_level=0x2 |
| 230 | Enable PCI/PCI interrupt routing info messages: | ||
| 231 | acpi.debug_layer=0x400000 acpi.debug_level=0x4 | ||
| 232 | Enable all messages related to ACPI hardware: | 235 | Enable all messages related to ACPI hardware: |
| 233 | acpi.debug_layer=0x2 acpi.debug_level=0xffffffff | 236 | acpi.debug_layer=0x2 acpi.debug_level=0xffffffff |
| 234 | 237 | ||
diff --git a/Documentation/sound/alsa/ALSA-Configuration.txt b/Documentation/sound/alsa/ALSA-Configuration.txt index 3cd2ad958176..394d7d378dc7 100644 --- a/Documentation/sound/alsa/ALSA-Configuration.txt +++ b/Documentation/sound/alsa/ALSA-Configuration.txt | |||
| @@ -1063,6 +1063,7 @@ Prior to version 0.9.0rc4 options had a 'snd_' prefix. This was removed. | |||
| 1063 | 1063 | ||
| 1064 | STAC9227/9228/9229/927x | 1064 | STAC9227/9228/9229/927x |
| 1065 | ref Reference board | 1065 | ref Reference board |
| 1066 | ref-no-jd Reference board without HP/Mic jack detection | ||
| 1066 | 3stack D965 3stack | 1067 | 3stack D965 3stack |
| 1067 | 5stack D965 5stack + SPDIF | 1068 | 5stack D965 5stack + SPDIF |
| 1068 | dell-3stack Dell Dimension E520 | 1069 | dell-3stack Dell Dimension E520 |
| @@ -1076,6 +1077,7 @@ Prior to version 0.9.0rc4 options had a 'snd_' prefix. This was removed. | |||
| 1076 | 1077 | ||
| 1077 | STAC92HD73* | 1078 | STAC92HD73* |
| 1078 | ref Reference board | 1079 | ref Reference board |
| 1080 | no-jd BIOS setup but without jack-detection | ||
| 1079 | dell-m6-amic Dell desktops/laptops with analog mics | 1081 | dell-m6-amic Dell desktops/laptops with analog mics |
| 1080 | dell-m6-dmic Dell desktops/laptops with digital mics | 1082 | dell-m6-dmic Dell desktops/laptops with digital mics |
| 1081 | dell-m6 Dell desktops/laptops with both type of mics | 1083 | dell-m6 Dell desktops/laptops with both type of mics |
diff --git a/MAINTAINERS b/MAINTAINERS index 09ed704f4dda..fbc8fa58d56d 100644 --- a/MAINTAINERS +++ b/MAINTAINERS | |||
| @@ -2191,9 +2191,9 @@ S: Supported | |||
| 2191 | 2191 | ||
| 2192 | INOTIFY | 2192 | INOTIFY |
| 2193 | P: John McCutchan | 2193 | P: John McCutchan |
| 2194 | M: ttb@tentacle.dhs.org | 2194 | M: john@johnmccutchan.com |
| 2195 | P: Robert Love | 2195 | P: Robert Love |
| 2196 | M: rml@novell.com | 2196 | M: rlove@rlove.org |
| 2197 | L: linux-kernel@vger.kernel.org | 2197 | L: linux-kernel@vger.kernel.org |
| 2198 | S: Maintained | 2198 | S: Maintained |
| 2199 | 2199 | ||
| @@ -4529,7 +4529,7 @@ S: Maintained | |||
| 4529 | USB VIDEO CLASS | 4529 | USB VIDEO CLASS |
| 4530 | P: Laurent Pinchart | 4530 | P: Laurent Pinchart |
| 4531 | M: laurent.pinchart@skynet.be | 4531 | M: laurent.pinchart@skynet.be |
| 4532 | L: linux-uvc-devel@lists.berlios.de | 4532 | L: linux-uvc-devel@lists.berlios.de (subscribers-only) |
| 4533 | L: video4linux-list@redhat.com | 4533 | L: video4linux-list@redhat.com |
| 4534 | W: http://linux-uvc.berlios.de | 4534 | W: http://linux-uvc.berlios.de |
| 4535 | S: Maintained | 4535 | S: Maintained |
| @@ -1,7 +1,7 @@ | |||
| 1 | VERSION = 2 | 1 | VERSION = 2 |
| 2 | PATCHLEVEL = 6 | 2 | PATCHLEVEL = 6 |
| 3 | SUBLEVEL = 28 | 3 | SUBLEVEL = 28 |
| 4 | EXTRAVERSION = -rc8 | 4 | EXTRAVERSION = |
| 5 | NAME = Erotic Pickled Herring | 5 | NAME = Erotic Pickled Herring |
| 6 | 6 | ||
| 7 | # *DOCUMENTATION* | 7 | # *DOCUMENTATION* |
diff --git a/arch/avr32/boards/favr-32/flash.c b/arch/avr32/boards/favr-32/flash.c index 5f139b7cb5f7..604bbd5e41d9 100644 --- a/arch/avr32/boards/favr-32/flash.c +++ b/arch/avr32/boards/favr-32/flash.c | |||
| @@ -13,7 +13,7 @@ | |||
| 13 | #include <linux/mtd/partitions.h> | 13 | #include <linux/mtd/partitions.h> |
| 14 | #include <linux/mtd/physmap.h> | 14 | #include <linux/mtd/physmap.h> |
| 15 | 15 | ||
| 16 | #include <asm/arch/smc.h> | 16 | #include <mach/smc.h> |
| 17 | 17 | ||
| 18 | static struct smc_timing flash_timing __initdata = { | 18 | static struct smc_timing flash_timing __initdata = { |
| 19 | .ncs_read_setup = 0, | 19 | .ncs_read_setup = 0, |
diff --git a/arch/avr32/boards/favr-32/setup.c b/arch/avr32/boards/favr-32/setup.c index 7538f3d2b9e0..1ee4faf0742d 100644 --- a/arch/avr32/boards/favr-32/setup.c +++ b/arch/avr32/boards/favr-32/setup.c | |||
| @@ -25,10 +25,10 @@ | |||
| 25 | 25 | ||
| 26 | #include <asm/setup.h> | 26 | #include <asm/setup.h> |
| 27 | 27 | ||
| 28 | #include <asm/arch/at32ap700x.h> | 28 | #include <mach/at32ap700x.h> |
| 29 | #include <asm/arch/init.h> | 29 | #include <mach/init.h> |
| 30 | #include <asm/arch/board.h> | 30 | #include <mach/board.h> |
| 31 | #include <asm/arch/portmux.h> | 31 | #include <mach/portmux.h> |
| 32 | 32 | ||
| 33 | /* Oscillator frequencies. These are board-specific */ | 33 | /* Oscillator frequencies. These are board-specific */ |
| 34 | unsigned long at32_board_osc_rates[3] = { | 34 | unsigned long at32_board_osc_rates[3] = { |
diff --git a/arch/avr32/boot/images/Makefile b/arch/avr32/boot/images/Makefile index 219720a47bf9..1848bf0d7f62 100644 --- a/arch/avr32/boot/images/Makefile +++ b/arch/avr32/boot/images/Makefile | |||
| @@ -10,7 +10,7 @@ MKIMAGE := $(srctree)/scripts/mkuboot.sh | |||
| 10 | 10 | ||
| 11 | extra-y := vmlinux.bin vmlinux.gz | 11 | extra-y := vmlinux.bin vmlinux.gz |
| 12 | 12 | ||
| 13 | OBJCOPYFLAGS_vmlinux.bin := -O binary | 13 | OBJCOPYFLAGS_vmlinux.bin := -O binary -R .note.gnu.build-id |
| 14 | $(obj)/vmlinux.bin: vmlinux FORCE | 14 | $(obj)/vmlinux.bin: vmlinux FORCE |
| 15 | $(call if_changed,objcopy) | 15 | $(call if_changed,objcopy) |
| 16 | 16 | ||
diff --git a/arch/avr32/configs/atstk1006_defconfig b/arch/avr32/configs/atstk1006_defconfig index 8b6e54c9946a..6c45a3b77aa3 100644 --- a/arch/avr32/configs/atstk1006_defconfig +++ b/arch/avr32/configs/atstk1006_defconfig | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.27-rc1 | 3 | # Linux kernel version: 2.6.28-rc8 |
| 4 | # Tue Aug 5 15:40:26 2008 | 4 | # Thu Dec 18 11:22:23 2008 |
| 5 | # | 5 | # |
| 6 | CONFIG_AVR32=y | 6 | CONFIG_AVR32=y |
| 7 | CONFIG_GENERIC_GPIO=y | 7 | CONFIG_GENERIC_GPIO=y |
| @@ -67,6 +67,7 @@ CONFIG_SIGNALFD=y | |||
| 67 | CONFIG_TIMERFD=y | 67 | CONFIG_TIMERFD=y |
| 68 | CONFIG_EVENTFD=y | 68 | CONFIG_EVENTFD=y |
| 69 | CONFIG_SHMEM=y | 69 | CONFIG_SHMEM=y |
| 70 | CONFIG_AIO=y | ||
| 70 | CONFIG_VM_EVENT_COUNTERS=y | 71 | CONFIG_VM_EVENT_COUNTERS=y |
| 71 | CONFIG_SLUB_DEBUG=y | 72 | CONFIG_SLUB_DEBUG=y |
| 72 | # CONFIG_SLAB is not set | 73 | # CONFIG_SLAB is not set |
| @@ -77,15 +78,8 @@ CONFIG_PROFILING=y | |||
| 77 | CONFIG_OPROFILE=m | 78 | CONFIG_OPROFILE=m |
| 78 | CONFIG_HAVE_OPROFILE=y | 79 | CONFIG_HAVE_OPROFILE=y |
| 79 | CONFIG_KPROBES=y | 80 | CONFIG_KPROBES=y |
| 80 | # CONFIG_HAVE_EFFICIENT_UNALIGNED_ACCESS is not set | ||
| 81 | # CONFIG_HAVE_IOREMAP_PROT is not set | ||
| 82 | CONFIG_HAVE_KPROBES=y | 81 | CONFIG_HAVE_KPROBES=y |
| 83 | # CONFIG_HAVE_KRETPROBES is not set | ||
| 84 | # CONFIG_HAVE_ARCH_TRACEHOOK is not set | ||
| 85 | # CONFIG_HAVE_DMA_ATTRS is not set | ||
| 86 | # CONFIG_USE_GENERIC_SMP_HELPERS is not set | ||
| 87 | CONFIG_HAVE_CLK=y | 82 | CONFIG_HAVE_CLK=y |
| 88 | CONFIG_PROC_PAGE_MONITOR=y | ||
| 89 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 83 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 90 | CONFIG_SLABINFO=y | 84 | CONFIG_SLABINFO=y |
| 91 | CONFIG_RT_MUTEXES=y | 85 | CONFIG_RT_MUTEXES=y |
| @@ -118,6 +112,7 @@ CONFIG_DEFAULT_CFQ=y | |||
| 118 | # CONFIG_DEFAULT_NOOP is not set | 112 | # CONFIG_DEFAULT_NOOP is not set |
| 119 | CONFIG_DEFAULT_IOSCHED="cfq" | 113 | CONFIG_DEFAULT_IOSCHED="cfq" |
| 120 | CONFIG_CLASSIC_RCU=y | 114 | CONFIG_CLASSIC_RCU=y |
| 115 | CONFIG_FREEZER=y | ||
| 121 | 116 | ||
| 122 | # | 117 | # |
| 123 | # System Type and features | 118 | # System Type and features |
| @@ -134,6 +129,8 @@ CONFIG_CPU_AT32AP700X=y | |||
| 134 | CONFIG_CPU_AT32AP7000=y | 129 | CONFIG_CPU_AT32AP7000=y |
| 135 | CONFIG_BOARD_ATSTK1000=y | 130 | CONFIG_BOARD_ATSTK1000=y |
| 136 | # CONFIG_BOARD_ATNGW100 is not set | 131 | # CONFIG_BOARD_ATNGW100 is not set |
| 132 | # CONFIG_BOARD_FAVR_32 is not set | ||
| 133 | # CONFIG_BOARD_MIMC200 is not set | ||
| 137 | # CONFIG_BOARD_ATSTK1002 is not set | 134 | # CONFIG_BOARD_ATSTK1002 is not set |
| 138 | # CONFIG_BOARD_ATSTK1003 is not set | 135 | # CONFIG_BOARD_ATSTK1003 is not set |
| 139 | # CONFIG_BOARD_ATSTK1004 is not set | 136 | # CONFIG_BOARD_ATSTK1004 is not set |
| @@ -171,14 +168,14 @@ CONFIG_FLATMEM_MANUAL=y | |||
| 171 | # CONFIG_SPARSEMEM_MANUAL is not set | 168 | # CONFIG_SPARSEMEM_MANUAL is not set |
| 172 | CONFIG_FLATMEM=y | 169 | CONFIG_FLATMEM=y |
| 173 | CONFIG_FLAT_NODE_MEM_MAP=y | 170 | CONFIG_FLAT_NODE_MEM_MAP=y |
| 174 | # CONFIG_SPARSEMEM_STATIC is not set | ||
| 175 | # CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set | ||
| 176 | CONFIG_PAGEFLAGS_EXTENDED=y | 171 | CONFIG_PAGEFLAGS_EXTENDED=y |
| 177 | CONFIG_SPLIT_PTLOCK_CPUS=4 | 172 | CONFIG_SPLIT_PTLOCK_CPUS=4 |
| 178 | # CONFIG_RESOURCES_64BIT is not set | 173 | # CONFIG_RESOURCES_64BIT is not set |
| 174 | # CONFIG_PHYS_ADDR_T_64BIT is not set | ||
| 179 | CONFIG_ZONE_DMA_FLAG=0 | 175 | CONFIG_ZONE_DMA_FLAG=0 |
| 180 | CONFIG_NR_QUICK=2 | 176 | CONFIG_NR_QUICK=2 |
| 181 | CONFIG_VIRT_TO_BUS=y | 177 | CONFIG_VIRT_TO_BUS=y |
| 178 | CONFIG_UNEVICTABLE_LRU=y | ||
| 182 | # CONFIG_OWNERSHIP_TRACE is not set | 179 | # CONFIG_OWNERSHIP_TRACE is not set |
| 183 | CONFIG_NMI_DEBUGGING=y | 180 | CONFIG_NMI_DEBUGGING=y |
| 184 | # CONFIG_HZ_100 is not set | 181 | # CONFIG_HZ_100 is not set |
| @@ -186,7 +183,7 @@ CONFIG_HZ_250=y | |||
| 186 | # CONFIG_HZ_300 is not set | 183 | # CONFIG_HZ_300 is not set |
| 187 | # CONFIG_HZ_1000 is not set | 184 | # CONFIG_HZ_1000 is not set |
| 188 | CONFIG_HZ=250 | 185 | CONFIG_HZ=250 |
| 189 | # CONFIG_SCHED_HRTICK is not set | 186 | CONFIG_SCHED_HRTICK=y |
| 190 | CONFIG_CMDLINE="" | 187 | CONFIG_CMDLINE="" |
| 191 | 188 | ||
| 192 | # | 189 | # |
| @@ -228,6 +225,8 @@ CONFIG_CPU_FREQ_AT32AP=y | |||
| 228 | # Executable file formats | 225 | # Executable file formats |
| 229 | # | 226 | # |
| 230 | CONFIG_BINFMT_ELF=y | 227 | CONFIG_BINFMT_ELF=y |
| 228 | CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS=y | ||
| 229 | # CONFIG_HAVE_AOUT is not set | ||
| 231 | # CONFIG_BINFMT_MISC is not set | 230 | # CONFIG_BINFMT_MISC is not set |
| 232 | CONFIG_NET=y | 231 | CONFIG_NET=y |
| 233 | 232 | ||
| @@ -299,6 +298,7 @@ CONFIG_IPV6_TUNNEL=m | |||
| 299 | # CONFIG_ATM is not set | 298 | # CONFIG_ATM is not set |
| 300 | CONFIG_STP=m | 299 | CONFIG_STP=m |
| 301 | CONFIG_BRIDGE=m | 300 | CONFIG_BRIDGE=m |
| 301 | # CONFIG_NET_DSA is not set | ||
| 302 | # CONFIG_VLAN_8021Q is not set | 302 | # CONFIG_VLAN_8021Q is not set |
| 303 | # CONFIG_DECNET is not set | 303 | # CONFIG_DECNET is not set |
| 304 | CONFIG_LLC=m | 304 | CONFIG_LLC=m |
| @@ -321,14 +321,8 @@ CONFIG_LLC=m | |||
| 321 | # CONFIG_IRDA is not set | 321 | # CONFIG_IRDA is not set |
| 322 | # CONFIG_BT is not set | 322 | # CONFIG_BT is not set |
| 323 | # CONFIG_AF_RXRPC is not set | 323 | # CONFIG_AF_RXRPC is not set |
| 324 | 324 | # CONFIG_PHONET is not set | |
| 325 | # | 325 | # CONFIG_WIRELESS is not set |
| 326 | # Wireless | ||
| 327 | # | ||
| 328 | # CONFIG_CFG80211 is not set | ||
| 329 | # CONFIG_WIRELESS_EXT is not set | ||
| 330 | # CONFIG_MAC80211 is not set | ||
| 331 | # CONFIG_IEEE80211 is not set | ||
| 332 | # CONFIG_RFKILL is not set | 326 | # CONFIG_RFKILL is not set |
| 333 | # CONFIG_NET_9P is not set | 327 | # CONFIG_NET_9P is not set |
| 334 | 328 | ||
| @@ -359,6 +353,7 @@ CONFIG_MTD_CMDLINE_PARTS=y | |||
| 359 | # User Modules And Translation Layers | 353 | # User Modules And Translation Layers |
| 360 | # | 354 | # |
| 361 | CONFIG_MTD_CHAR=y | 355 | CONFIG_MTD_CHAR=y |
| 356 | CONFIG_HAVE_MTD_OTP=y | ||
| 362 | CONFIG_MTD_BLKDEVS=y | 357 | CONFIG_MTD_BLKDEVS=y |
| 363 | CONFIG_MTD_BLOCK=y | 358 | CONFIG_MTD_BLOCK=y |
| 364 | # CONFIG_FTL is not set | 359 | # CONFIG_FTL is not set |
| @@ -407,6 +402,8 @@ CONFIG_MTD_PHYSMAP_BANKWIDTH=2 | |||
| 407 | # Self-contained MTD device drivers | 402 | # Self-contained MTD device drivers |
| 408 | # | 403 | # |
| 409 | CONFIG_MTD_DATAFLASH=m | 404 | CONFIG_MTD_DATAFLASH=m |
| 405 | # CONFIG_MTD_DATAFLASH_WRITE_VERIFY is not set | ||
| 406 | CONFIG_MTD_DATAFLASH_OTP=y | ||
| 410 | CONFIG_MTD_M25P80=m | 407 | CONFIG_MTD_M25P80=m |
| 411 | CONFIG_M25PXX_USE_FAST_READ=y | 408 | CONFIG_M25PXX_USE_FAST_READ=y |
| 412 | # CONFIG_MTD_SLRAM is not set | 409 | # CONFIG_MTD_SLRAM is not set |
| @@ -464,9 +461,10 @@ CONFIG_ATMEL_TCLIB=y | |||
| 464 | CONFIG_ATMEL_TCB_CLKSRC=y | 461 | CONFIG_ATMEL_TCB_CLKSRC=y |
| 465 | CONFIG_ATMEL_TCB_CLKSRC_BLOCK=0 | 462 | CONFIG_ATMEL_TCB_CLKSRC_BLOCK=0 |
| 466 | # CONFIG_EEPROM_93CX6 is not set | 463 | # CONFIG_EEPROM_93CX6 is not set |
| 464 | # CONFIG_ICS932S401 is not set | ||
| 467 | CONFIG_ATMEL_SSC=m | 465 | CONFIG_ATMEL_SSC=m |
| 468 | # CONFIG_ENCLOSURE_SERVICES is not set | 466 | # CONFIG_ENCLOSURE_SERVICES is not set |
| 469 | # CONFIG_HAVE_IDE is not set | 467 | # CONFIG_C2PORT is not set |
| 470 | 468 | ||
| 471 | # | 469 | # |
| 472 | # SCSI device support | 470 | # SCSI device support |
| @@ -548,6 +546,9 @@ CONFIG_MACB=y | |||
| 548 | # CONFIG_IBM_NEW_EMAC_RGMII is not set | 546 | # CONFIG_IBM_NEW_EMAC_RGMII is not set |
| 549 | # CONFIG_IBM_NEW_EMAC_TAH is not set | 547 | # CONFIG_IBM_NEW_EMAC_TAH is not set |
| 550 | # CONFIG_IBM_NEW_EMAC_EMAC4 is not set | 548 | # CONFIG_IBM_NEW_EMAC_EMAC4 is not set |
| 549 | # CONFIG_IBM_NEW_EMAC_NO_FLOW_CTRL is not set | ||
| 550 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | ||
| 551 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | ||
| 551 | # CONFIG_B44 is not set | 552 | # CONFIG_B44 is not set |
| 552 | # CONFIG_NETDEV_1000 is not set | 553 | # CONFIG_NETDEV_1000 is not set |
| 553 | # CONFIG_NETDEV_10000 is not set | 554 | # CONFIG_NETDEV_10000 is not set |
| @@ -653,6 +654,7 @@ CONFIG_UNIX98_PTYS=y | |||
| 653 | CONFIG_I2C=m | 654 | CONFIG_I2C=m |
| 654 | CONFIG_I2C_BOARDINFO=y | 655 | CONFIG_I2C_BOARDINFO=y |
| 655 | CONFIG_I2C_CHARDEV=m | 656 | CONFIG_I2C_CHARDEV=m |
| 657 | CONFIG_I2C_HELPER_AUTO=y | ||
| 656 | CONFIG_I2C_ALGOBIT=m | 658 | CONFIG_I2C_ALGOBIT=m |
| 657 | 659 | ||
| 658 | # | 660 | # |
| @@ -717,6 +719,10 @@ CONFIG_GPIOLIB=y | |||
| 717 | CONFIG_GPIO_SYSFS=y | 719 | CONFIG_GPIO_SYSFS=y |
| 718 | 720 | ||
| 719 | # | 721 | # |
| 722 | # Memory mapped GPIO expanders: | ||
| 723 | # | ||
| 724 | |||
| 725 | # | ||
| 720 | # I2C GPIO expanders: | 726 | # I2C GPIO expanders: |
| 721 | # | 727 | # |
| 722 | # CONFIG_GPIO_MAX732X is not set | 728 | # CONFIG_GPIO_MAX732X is not set |
| @@ -745,11 +751,11 @@ CONFIG_WATCHDOG=y | |||
| 745 | # | 751 | # |
| 746 | # CONFIG_SOFT_WATCHDOG is not set | 752 | # CONFIG_SOFT_WATCHDOG is not set |
| 747 | CONFIG_AT32AP700X_WDT=y | 753 | CONFIG_AT32AP700X_WDT=y |
| 754 | CONFIG_SSB_POSSIBLE=y | ||
| 748 | 755 | ||
| 749 | # | 756 | # |
| 750 | # Sonics Silicon Backplane | 757 | # Sonics Silicon Backplane |
| 751 | # | 758 | # |
| 752 | CONFIG_SSB_POSSIBLE=y | ||
| 753 | # CONFIG_SSB is not set | 759 | # CONFIG_SSB is not set |
| 754 | 760 | ||
| 755 | # | 761 | # |
| @@ -758,6 +764,10 @@ CONFIG_SSB_POSSIBLE=y | |||
| 758 | # CONFIG_MFD_CORE is not set | 764 | # CONFIG_MFD_CORE is not set |
| 759 | # CONFIG_MFD_SM501 is not set | 765 | # CONFIG_MFD_SM501 is not set |
| 760 | # CONFIG_HTC_PASIC3 is not set | 766 | # CONFIG_HTC_PASIC3 is not set |
| 767 | # CONFIG_MFD_TMIO is not set | ||
| 768 | # CONFIG_MFD_WM8400 is not set | ||
| 769 | # CONFIG_MFD_WM8350_I2C is not set | ||
| 770 | # CONFIG_REGULATOR is not set | ||
| 761 | 771 | ||
| 762 | # | 772 | # |
| 763 | # Multimedia devices | 773 | # Multimedia devices |
| @@ -783,6 +793,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 783 | CONFIG_FB=y | 793 | CONFIG_FB=y |
| 784 | # CONFIG_FIRMWARE_EDID is not set | 794 | # CONFIG_FIRMWARE_EDID is not set |
| 785 | # CONFIG_FB_DDC is not set | 795 | # CONFIG_FB_DDC is not set |
| 796 | # CONFIG_FB_BOOT_VESA_SUPPORT is not set | ||
| 786 | CONFIG_FB_CFB_FILLRECT=y | 797 | CONFIG_FB_CFB_FILLRECT=y |
| 787 | CONFIG_FB_CFB_COPYAREA=y | 798 | CONFIG_FB_CFB_COPYAREA=y |
| 788 | CONFIG_FB_CFB_IMAGEBLIT=y | 799 | CONFIG_FB_CFB_IMAGEBLIT=y |
| @@ -804,10 +815,13 @@ CONFIG_FB_CFB_IMAGEBLIT=y | |||
| 804 | # CONFIG_FB_S1D13XXX is not set | 815 | # CONFIG_FB_S1D13XXX is not set |
| 805 | CONFIG_FB_ATMEL=y | 816 | CONFIG_FB_ATMEL=y |
| 806 | # CONFIG_FB_VIRTUAL is not set | 817 | # CONFIG_FB_VIRTUAL is not set |
| 818 | # CONFIG_FB_METRONOME is not set | ||
| 819 | # CONFIG_FB_MB862XX is not set | ||
| 807 | CONFIG_BACKLIGHT_LCD_SUPPORT=y | 820 | CONFIG_BACKLIGHT_LCD_SUPPORT=y |
| 808 | CONFIG_LCD_CLASS_DEVICE=y | 821 | CONFIG_LCD_CLASS_DEVICE=y |
| 809 | CONFIG_LCD_LTV350QV=y | 822 | CONFIG_LCD_LTV350QV=y |
| 810 | # CONFIG_LCD_ILI9320 is not set | 823 | # CONFIG_LCD_ILI9320 is not set |
| 824 | # CONFIG_LCD_TDO24M is not set | ||
| 811 | # CONFIG_LCD_VGG2432A4 is not set | 825 | # CONFIG_LCD_VGG2432A4 is not set |
| 812 | # CONFIG_LCD_PLATFORM is not set | 826 | # CONFIG_LCD_PLATFORM is not set |
| 813 | # CONFIG_BACKLIGHT_CLASS_DEVICE is not set | 827 | # CONFIG_BACKLIGHT_CLASS_DEVICE is not set |
| @@ -818,6 +832,7 @@ CONFIG_LCD_LTV350QV=y | |||
| 818 | # CONFIG_DISPLAY_SUPPORT is not set | 832 | # CONFIG_DISPLAY_SUPPORT is not set |
| 819 | # CONFIG_LOGO is not set | 833 | # CONFIG_LOGO is not set |
| 820 | CONFIG_SOUND=m | 834 | CONFIG_SOUND=m |
| 835 | CONFIG_SOUND_OSS_CORE=y | ||
| 821 | CONFIG_SND=m | 836 | CONFIG_SND=m |
| 822 | CONFIG_SND_TIMER=m | 837 | CONFIG_SND_TIMER=m |
| 823 | CONFIG_SND_PCM=m | 838 | CONFIG_SND_PCM=m |
| @@ -848,28 +863,32 @@ CONFIG_USB_SUPPORT=y | |||
| 848 | # CONFIG_USB_ARCH_HAS_EHCI is not set | 863 | # CONFIG_USB_ARCH_HAS_EHCI is not set |
| 849 | # CONFIG_USB_OTG_WHITELIST is not set | 864 | # CONFIG_USB_OTG_WHITELIST is not set |
| 850 | # CONFIG_USB_OTG_BLACKLIST_HUB is not set | 865 | # CONFIG_USB_OTG_BLACKLIST_HUB is not set |
| 866 | # CONFIG_USB_MUSB_HDRC is not set | ||
| 867 | # CONFIG_USB_GADGET_MUSB_HDRC is not set | ||
| 851 | 868 | ||
| 852 | # | 869 | # |
| 853 | # NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support' | 870 | # NOTE: USB_STORAGE depends on SCSI but BLK_DEV_SD may also be needed; |
| 854 | # | 871 | # |
| 855 | CONFIG_USB_GADGET=y | 872 | CONFIG_USB_GADGET=y |
| 856 | # CONFIG_USB_GADGET_DEBUG is not set | 873 | # CONFIG_USB_GADGET_DEBUG is not set |
| 857 | # CONFIG_USB_GADGET_DEBUG_FILES is not set | 874 | # CONFIG_USB_GADGET_DEBUG_FILES is not set |
| 858 | # CONFIG_USB_GADGET_DEBUG_FS is not set | 875 | # CONFIG_USB_GADGET_DEBUG_FS is not set |
| 876 | CONFIG_USB_GADGET_VBUS_DRAW=2 | ||
| 859 | CONFIG_USB_GADGET_SELECTED=y | 877 | CONFIG_USB_GADGET_SELECTED=y |
| 860 | # CONFIG_USB_GADGET_AMD5536UDC is not set | 878 | # CONFIG_USB_GADGET_AT91 is not set |
| 861 | CONFIG_USB_GADGET_ATMEL_USBA=y | 879 | CONFIG_USB_GADGET_ATMEL_USBA=y |
| 862 | CONFIG_USB_ATMEL_USBA=y | 880 | CONFIG_USB_ATMEL_USBA=y |
| 863 | # CONFIG_USB_GADGET_FSL_USB2 is not set | 881 | # CONFIG_USB_GADGET_FSL_USB2 is not set |
| 864 | # CONFIG_USB_GADGET_NET2280 is not set | ||
| 865 | # CONFIG_USB_GADGET_PXA25X is not set | ||
| 866 | # CONFIG_USB_GADGET_M66592 is not set | ||
| 867 | # CONFIG_USB_GADGET_PXA27X is not set | ||
| 868 | # CONFIG_USB_GADGET_GOKU is not set | ||
| 869 | # CONFIG_USB_GADGET_LH7A40X is not set | 882 | # CONFIG_USB_GADGET_LH7A40X is not set |
| 870 | # CONFIG_USB_GADGET_OMAP is not set | 883 | # CONFIG_USB_GADGET_OMAP is not set |
| 884 | # CONFIG_USB_GADGET_PXA25X is not set | ||
| 885 | # CONFIG_USB_GADGET_PXA27X is not set | ||
| 871 | # CONFIG_USB_GADGET_S3C2410 is not set | 886 | # CONFIG_USB_GADGET_S3C2410 is not set |
| 872 | # CONFIG_USB_GADGET_AT91 is not set | 887 | # CONFIG_USB_GADGET_M66592 is not set |
| 888 | # CONFIG_USB_GADGET_AMD5536UDC is not set | ||
| 889 | # CONFIG_USB_GADGET_FSL_QE is not set | ||
| 890 | # CONFIG_USB_GADGET_NET2280 is not set | ||
| 891 | # CONFIG_USB_GADGET_GOKU is not set | ||
| 873 | # CONFIG_USB_GADGET_DUMMY_HCD is not set | 892 | # CONFIG_USB_GADGET_DUMMY_HCD is not set |
| 874 | CONFIG_USB_GADGET_DUALSPEED=y | 893 | CONFIG_USB_GADGET_DUALSPEED=y |
| 875 | CONFIG_USB_ZERO=m | 894 | CONFIG_USB_ZERO=m |
| @@ -887,7 +906,7 @@ CONFIG_MMC=y | |||
| 887 | # CONFIG_MMC_UNSAFE_RESUME is not set | 906 | # CONFIG_MMC_UNSAFE_RESUME is not set |
| 888 | 907 | ||
| 889 | # | 908 | # |
| 890 | # MMC/SD Card Drivers | 909 | # MMC/SD/SDIO Card Drivers |
| 891 | # | 910 | # |
| 892 | CONFIG_MMC_BLOCK=y | 911 | CONFIG_MMC_BLOCK=y |
| 893 | CONFIG_MMC_BLOCK_BOUNCE=y | 912 | CONFIG_MMC_BLOCK_BOUNCE=y |
| @@ -895,10 +914,11 @@ CONFIG_MMC_BLOCK_BOUNCE=y | |||
| 895 | # CONFIG_MMC_TEST is not set | 914 | # CONFIG_MMC_TEST is not set |
| 896 | 915 | ||
| 897 | # | 916 | # |
| 898 | # MMC/SD Host Controller Drivers | 917 | # MMC/SD/SDIO Host Controller Drivers |
| 899 | # | 918 | # |
| 900 | # CONFIG_MMC_SDHCI is not set | 919 | # CONFIG_MMC_SDHCI is not set |
| 901 | CONFIG_MMC_ATMELMCI=y | 920 | CONFIG_MMC_ATMELMCI=y |
| 921 | # CONFIG_MMC_ATMELMCI_DMA is not set | ||
| 902 | CONFIG_MMC_SPI=m | 922 | CONFIG_MMC_SPI=m |
| 903 | # CONFIG_MEMSTICK is not set | 923 | # CONFIG_MEMSTICK is not set |
| 904 | CONFIG_NEW_LEDS=y | 924 | CONFIG_NEW_LEDS=y |
| @@ -918,6 +938,7 @@ CONFIG_LEDS_GPIO=m | |||
| 918 | CONFIG_LEDS_TRIGGERS=y | 938 | CONFIG_LEDS_TRIGGERS=y |
| 919 | CONFIG_LEDS_TRIGGER_TIMER=m | 939 | CONFIG_LEDS_TRIGGER_TIMER=m |
| 920 | CONFIG_LEDS_TRIGGER_HEARTBEAT=m | 940 | CONFIG_LEDS_TRIGGER_HEARTBEAT=m |
| 941 | # CONFIG_LEDS_TRIGGER_BACKLIGHT is not set | ||
| 921 | CONFIG_LEDS_TRIGGER_DEFAULT_ON=m | 942 | CONFIG_LEDS_TRIGGER_DEFAULT_ON=m |
| 922 | # CONFIG_ACCESSIBILITY is not set | 943 | # CONFIG_ACCESSIBILITY is not set |
| 923 | CONFIG_RTC_LIB=y | 944 | CONFIG_RTC_LIB=y |
| @@ -950,25 +971,31 @@ CONFIG_RTC_INTF_DEV=y | |||
| 950 | # CONFIG_RTC_DRV_M41T80 is not set | 971 | # CONFIG_RTC_DRV_M41T80 is not set |
| 951 | # CONFIG_RTC_DRV_S35390A is not set | 972 | # CONFIG_RTC_DRV_S35390A is not set |
| 952 | # CONFIG_RTC_DRV_FM3130 is not set | 973 | # CONFIG_RTC_DRV_FM3130 is not set |
| 974 | # CONFIG_RTC_DRV_RX8581 is not set | ||
| 953 | 975 | ||
| 954 | # | 976 | # |
| 955 | # SPI RTC drivers | 977 | # SPI RTC drivers |
| 956 | # | 978 | # |
| 957 | # CONFIG_RTC_DRV_M41T94 is not set | 979 | # CONFIG_RTC_DRV_M41T94 is not set |
| 958 | # CONFIG_RTC_DRV_DS1305 is not set | 980 | # CONFIG_RTC_DRV_DS1305 is not set |
| 981 | # CONFIG_RTC_DRV_DS1390 is not set | ||
| 959 | # CONFIG_RTC_DRV_MAX6902 is not set | 982 | # CONFIG_RTC_DRV_MAX6902 is not set |
| 960 | # CONFIG_RTC_DRV_R9701 is not set | 983 | # CONFIG_RTC_DRV_R9701 is not set |
| 961 | # CONFIG_RTC_DRV_RS5C348 is not set | 984 | # CONFIG_RTC_DRV_RS5C348 is not set |
| 985 | # CONFIG_RTC_DRV_DS3234 is not set | ||
| 962 | 986 | ||
| 963 | # | 987 | # |
| 964 | # Platform RTC drivers | 988 | # Platform RTC drivers |
| 965 | # | 989 | # |
| 990 | # CONFIG_RTC_DRV_DS1286 is not set | ||
| 966 | # CONFIG_RTC_DRV_DS1511 is not set | 991 | # CONFIG_RTC_DRV_DS1511 is not set |
| 967 | # CONFIG_RTC_DRV_DS1553 is not set | 992 | # CONFIG_RTC_DRV_DS1553 is not set |
| 968 | # CONFIG_RTC_DRV_DS1742 is not set | 993 | # CONFIG_RTC_DRV_DS1742 is not set |
| 969 | # CONFIG_RTC_DRV_STK17TA8 is not set | 994 | # CONFIG_RTC_DRV_STK17TA8 is not set |
| 970 | # CONFIG_RTC_DRV_M48T86 is not set | 995 | # CONFIG_RTC_DRV_M48T86 is not set |
| 996 | # CONFIG_RTC_DRV_M48T35 is not set | ||
| 971 | # CONFIG_RTC_DRV_M48T59 is not set | 997 | # CONFIG_RTC_DRV_M48T59 is not set |
| 998 | # CONFIG_RTC_DRV_BQ4802 is not set | ||
| 972 | # CONFIG_RTC_DRV_V3020 is not set | 999 | # CONFIG_RTC_DRV_V3020 is not set |
| 973 | 1000 | ||
| 974 | # | 1001 | # |
| @@ -989,6 +1016,8 @@ CONFIG_DMA_ENGINE=y | |||
| 989 | # CONFIG_NET_DMA is not set | 1016 | # CONFIG_NET_DMA is not set |
| 990 | CONFIG_DMATEST=m | 1017 | CONFIG_DMATEST=m |
| 991 | # CONFIG_UIO is not set | 1018 | # CONFIG_UIO is not set |
| 1019 | # CONFIG_STAGING is not set | ||
| 1020 | CONFIG_STAGING_EXCLUDE_BUILD=y | ||
| 992 | 1021 | ||
| 993 | # | 1022 | # |
| 994 | # File systems | 1023 | # File systems |
| @@ -998,12 +1027,17 @@ CONFIG_EXT2_FS=m | |||
| 998 | # CONFIG_EXT2_FS_XIP is not set | 1027 | # CONFIG_EXT2_FS_XIP is not set |
| 999 | CONFIG_EXT3_FS=m | 1028 | CONFIG_EXT3_FS=m |
| 1000 | # CONFIG_EXT3_FS_XATTR is not set | 1029 | # CONFIG_EXT3_FS_XATTR is not set |
| 1001 | # CONFIG_EXT4DEV_FS is not set | 1030 | CONFIG_EXT4_FS=m |
| 1031 | CONFIG_EXT4DEV_COMPAT=y | ||
| 1032 | # CONFIG_EXT4_FS_XATTR is not set | ||
| 1002 | CONFIG_JBD=m | 1033 | CONFIG_JBD=m |
| 1003 | # CONFIG_JBD_DEBUG is not set | 1034 | # CONFIG_JBD_DEBUG is not set |
| 1035 | CONFIG_JBD2=m | ||
| 1036 | # CONFIG_JBD2_DEBUG is not set | ||
| 1004 | # CONFIG_REISERFS_FS is not set | 1037 | # CONFIG_REISERFS_FS is not set |
| 1005 | # CONFIG_JFS_FS is not set | 1038 | # CONFIG_JFS_FS is not set |
| 1006 | # CONFIG_FS_POSIX_ACL is not set | 1039 | # CONFIG_FS_POSIX_ACL is not set |
| 1040 | CONFIG_FILE_LOCKING=y | ||
| 1007 | # CONFIG_XFS_FS is not set | 1041 | # CONFIG_XFS_FS is not set |
| 1008 | # CONFIG_OCFS2_FS is not set | 1042 | # CONFIG_OCFS2_FS is not set |
| 1009 | # CONFIG_DNOTIFY is not set | 1043 | # CONFIG_DNOTIFY is not set |
| @@ -1036,6 +1070,7 @@ CONFIG_FAT_DEFAULT_IOCHARSET="iso8859-1" | |||
| 1036 | CONFIG_PROC_FS=y | 1070 | CONFIG_PROC_FS=y |
| 1037 | CONFIG_PROC_KCORE=y | 1071 | CONFIG_PROC_KCORE=y |
| 1038 | CONFIG_PROC_SYSCTL=y | 1072 | CONFIG_PROC_SYSCTL=y |
| 1073 | CONFIG_PROC_PAGE_MONITOR=y | ||
| 1039 | CONFIG_SYSFS=y | 1074 | CONFIG_SYSFS=y |
| 1040 | CONFIG_TMPFS=y | 1075 | CONFIG_TMPFS=y |
| 1041 | # CONFIG_TMPFS_POSIX_ACL is not set | 1076 | # CONFIG_TMPFS_POSIX_ACL is not set |
| @@ -1054,7 +1089,8 @@ CONFIG_TMPFS=y | |||
| 1054 | # CONFIG_EFS_FS is not set | 1089 | # CONFIG_EFS_FS is not set |
| 1055 | CONFIG_JFFS2_FS=y | 1090 | CONFIG_JFFS2_FS=y |
| 1056 | CONFIG_JFFS2_FS_DEBUG=0 | 1091 | CONFIG_JFFS2_FS_DEBUG=0 |
| 1057 | # CONFIG_JFFS2_FS_WRITEBUFFER is not set | 1092 | CONFIG_JFFS2_FS_WRITEBUFFER=y |
| 1093 | # CONFIG_JFFS2_FS_WBUF_VERIFY is not set | ||
| 1058 | # CONFIG_JFFS2_SUMMARY is not set | 1094 | # CONFIG_JFFS2_SUMMARY is not set |
| 1059 | # CONFIG_JFFS2_FS_XATTR is not set | 1095 | # CONFIG_JFFS2_FS_XATTR is not set |
| 1060 | # CONFIG_JFFS2_COMPRESSION_OPTIONS is not set | 1096 | # CONFIG_JFFS2_COMPRESSION_OPTIONS is not set |
| @@ -1088,6 +1124,7 @@ CONFIG_LOCKD=y | |||
| 1088 | CONFIG_LOCKD_V4=y | 1124 | CONFIG_LOCKD_V4=y |
| 1089 | CONFIG_NFS_COMMON=y | 1125 | CONFIG_NFS_COMMON=y |
| 1090 | CONFIG_SUNRPC=y | 1126 | CONFIG_SUNRPC=y |
| 1127 | # CONFIG_SUNRPC_REGISTER_V4 is not set | ||
| 1091 | # CONFIG_RPCSEC_GSS_KRB5 is not set | 1128 | # CONFIG_RPCSEC_GSS_KRB5 is not set |
| 1092 | # CONFIG_RPCSEC_GSS_SPKM3 is not set | 1129 | # CONFIG_RPCSEC_GSS_SPKM3 is not set |
| 1093 | # CONFIG_SMB_FS is not set | 1130 | # CONFIG_SMB_FS is not set |
| @@ -1185,10 +1222,21 @@ CONFIG_DEBUG_BUGVERBOSE=y | |||
| 1185 | CONFIG_FRAME_POINTER=y | 1222 | CONFIG_FRAME_POINTER=y |
| 1186 | # CONFIG_BOOT_PRINTK_DELAY is not set | 1223 | # CONFIG_BOOT_PRINTK_DELAY is not set |
| 1187 | # CONFIG_RCU_TORTURE_TEST is not set | 1224 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1225 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | ||
| 1188 | # CONFIG_KPROBES_SANITY_TEST is not set | 1226 | # CONFIG_KPROBES_SANITY_TEST is not set |
| 1189 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1227 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| 1228 | # CONFIG_DEBUG_BLOCK_EXT_DEVT is not set | ||
| 1190 | # CONFIG_LKDTM is not set | 1229 | # CONFIG_LKDTM is not set |
| 1191 | # CONFIG_FAULT_INJECTION is not set | 1230 | # CONFIG_FAULT_INJECTION is not set |
| 1231 | |||
| 1232 | # | ||
| 1233 | # Tracers | ||
| 1234 | # | ||
| 1235 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1236 | # CONFIG_SCHED_TRACER is not set | ||
| 1237 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1238 | # CONFIG_BOOT_TRACER is not set | ||
| 1239 | # CONFIG_DYNAMIC_PRINTK_DEBUG is not set | ||
| 1192 | # CONFIG_SAMPLES is not set | 1240 | # CONFIG_SAMPLES is not set |
| 1193 | 1241 | ||
| 1194 | # | 1242 | # |
| @@ -1196,17 +1244,26 @@ CONFIG_FRAME_POINTER=y | |||
| 1196 | # | 1244 | # |
| 1197 | # CONFIG_KEYS is not set | 1245 | # CONFIG_KEYS is not set |
| 1198 | # CONFIG_SECURITY is not set | 1246 | # CONFIG_SECURITY is not set |
| 1247 | # CONFIG_SECURITYFS is not set | ||
| 1199 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set | 1248 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set |
| 1200 | CONFIG_CRYPTO=y | 1249 | CONFIG_CRYPTO=y |
| 1201 | 1250 | ||
| 1202 | # | 1251 | # |
| 1203 | # Crypto core or helper | 1252 | # Crypto core or helper |
| 1204 | # | 1253 | # |
| 1254 | CONFIG_CRYPTO_FIPS=y | ||
| 1205 | CONFIG_CRYPTO_ALGAPI=y | 1255 | CONFIG_CRYPTO_ALGAPI=y |
| 1256 | CONFIG_CRYPTO_ALGAPI2=y | ||
| 1206 | CONFIG_CRYPTO_AEAD=m | 1257 | CONFIG_CRYPTO_AEAD=m |
| 1258 | CONFIG_CRYPTO_AEAD2=y | ||
| 1207 | CONFIG_CRYPTO_BLKCIPHER=m | 1259 | CONFIG_CRYPTO_BLKCIPHER=m |
| 1260 | CONFIG_CRYPTO_BLKCIPHER2=y | ||
| 1208 | CONFIG_CRYPTO_HASH=m | 1261 | CONFIG_CRYPTO_HASH=m |
| 1262 | CONFIG_CRYPTO_HASH2=y | ||
| 1263 | CONFIG_CRYPTO_RNG=m | ||
| 1264 | CONFIG_CRYPTO_RNG2=y | ||
| 1209 | CONFIG_CRYPTO_MANAGER=m | 1265 | CONFIG_CRYPTO_MANAGER=m |
| 1266 | CONFIG_CRYPTO_MANAGER2=y | ||
| 1210 | # CONFIG_CRYPTO_GF128MUL is not set | 1267 | # CONFIG_CRYPTO_GF128MUL is not set |
| 1211 | # CONFIG_CRYPTO_NULL is not set | 1268 | # CONFIG_CRYPTO_NULL is not set |
| 1212 | # CONFIG_CRYPTO_CRYPTD is not set | 1269 | # CONFIG_CRYPTO_CRYPTD is not set |
| @@ -1257,7 +1314,7 @@ CONFIG_CRYPTO_SHA1=m | |||
| 1257 | # | 1314 | # |
| 1258 | # Ciphers | 1315 | # Ciphers |
| 1259 | # | 1316 | # |
| 1260 | # CONFIG_CRYPTO_AES is not set | 1317 | CONFIG_CRYPTO_AES=m |
| 1261 | # CONFIG_CRYPTO_ANUBIS is not set | 1318 | # CONFIG_CRYPTO_ANUBIS is not set |
| 1262 | # CONFIG_CRYPTO_ARC4 is not set | 1319 | # CONFIG_CRYPTO_ARC4 is not set |
| 1263 | # CONFIG_CRYPTO_BLOWFISH is not set | 1320 | # CONFIG_CRYPTO_BLOWFISH is not set |
| @@ -1278,14 +1335,17 @@ CONFIG_CRYPTO_DES=m | |||
| 1278 | # | 1335 | # |
| 1279 | CONFIG_CRYPTO_DEFLATE=y | 1336 | CONFIG_CRYPTO_DEFLATE=y |
| 1280 | CONFIG_CRYPTO_LZO=y | 1337 | CONFIG_CRYPTO_LZO=y |
| 1338 | |||
| 1339 | # | ||
| 1340 | # Random Number Generation | ||
| 1341 | # | ||
| 1342 | CONFIG_CRYPTO_ANSI_CPRNG=m | ||
| 1281 | # CONFIG_CRYPTO_HW is not set | 1343 | # CONFIG_CRYPTO_HW is not set |
| 1282 | 1344 | ||
| 1283 | # | 1345 | # |
| 1284 | # Library routines | 1346 | # Library routines |
| 1285 | # | 1347 | # |
| 1286 | CONFIG_BITREVERSE=y | 1348 | CONFIG_BITREVERSE=y |
| 1287 | # CONFIG_GENERIC_FIND_FIRST_BIT is not set | ||
| 1288 | # CONFIG_GENERIC_FIND_NEXT_BIT is not set | ||
| 1289 | CONFIG_CRC_CCITT=m | 1349 | CONFIG_CRC_CCITT=m |
| 1290 | CONFIG_CRC16=y | 1350 | CONFIG_CRC16=y |
| 1291 | CONFIG_CRC_T10DIF=m | 1351 | CONFIG_CRC_T10DIF=m |
diff --git a/arch/avr32/mach-at32ap/at32ap700x.c b/arch/avr32/mach-at32ap/at32ap700x.c index 0c6e02f80a31..066252eebf61 100644 --- a/arch/avr32/mach-at32ap/at32ap700x.c +++ b/arch/avr32/mach-at32ap/at32ap700x.c | |||
| @@ -967,28 +967,28 @@ static inline void configure_usart0_pins(void) | |||
| 967 | { | 967 | { |
| 968 | u32 pin_mask = (1 << 8) | (1 << 9); /* RXD & TXD */ | 968 | u32 pin_mask = (1 << 8) | (1 << 9); /* RXD & TXD */ |
| 969 | 969 | ||
| 970 | select_peripheral(PIOA, pin_mask, PERIPH_B, 0); | 970 | select_peripheral(PIOA, pin_mask, PERIPH_B, AT32_GPIOF_PULLUP); |
| 971 | } | 971 | } |
| 972 | 972 | ||
| 973 | static inline void configure_usart1_pins(void) | 973 | static inline void configure_usart1_pins(void) |
| 974 | { | 974 | { |
| 975 | u32 pin_mask = (1 << 17) | (1 << 18); /* RXD & TXD */ | 975 | u32 pin_mask = (1 << 17) | (1 << 18); /* RXD & TXD */ |
| 976 | 976 | ||
| 977 | select_peripheral(PIOA, pin_mask, PERIPH_A, 0); | 977 | select_peripheral(PIOA, pin_mask, PERIPH_A, AT32_GPIOF_PULLUP); |
| 978 | } | 978 | } |
| 979 | 979 | ||
| 980 | static inline void configure_usart2_pins(void) | 980 | static inline void configure_usart2_pins(void) |
| 981 | { | 981 | { |
| 982 | u32 pin_mask = (1 << 26) | (1 << 27); /* RXD & TXD */ | 982 | u32 pin_mask = (1 << 26) | (1 << 27); /* RXD & TXD */ |
| 983 | 983 | ||
| 984 | select_peripheral(PIOB, pin_mask, PERIPH_B, 0); | 984 | select_peripheral(PIOB, pin_mask, PERIPH_B, AT32_GPIOF_PULLUP); |
| 985 | } | 985 | } |
| 986 | 986 | ||
| 987 | static inline void configure_usart3_pins(void) | 987 | static inline void configure_usart3_pins(void) |
| 988 | { | 988 | { |
| 989 | u32 pin_mask = (1 << 18) | (1 << 17); /* RXD & TXD */ | 989 | u32 pin_mask = (1 << 18) | (1 << 17); /* RXD & TXD */ |
| 990 | 990 | ||
| 991 | select_peripheral(PIOB, pin_mask, PERIPH_B, 0); | 991 | select_peripheral(PIOB, pin_mask, PERIPH_B, AT32_GPIOF_PULLUP); |
| 992 | } | 992 | } |
| 993 | 993 | ||
| 994 | static struct platform_device *__initdata at32_usarts[4]; | 994 | static struct platform_device *__initdata at32_usarts[4]; |
diff --git a/arch/mips/include/asm/byteorder.h b/arch/mips/include/asm/byteorder.h index 2988d29a0867..33790b9e0cc0 100644 --- a/arch/mips/include/asm/byteorder.h +++ b/arch/mips/include/asm/byteorder.h | |||
| @@ -50,9 +50,8 @@ static inline __attribute_const__ __u32 __arch_swab32(__u32 x) | |||
| 50 | static inline __attribute_const__ __u64 __arch_swab64(__u64 x) | 50 | static inline __attribute_const__ __u64 __arch_swab64(__u64 x) |
| 51 | { | 51 | { |
| 52 | __asm__( | 52 | __asm__( |
| 53 | " dsbh %0, %1 \n" | 53 | " dsbh %0, %1\n" |
| 54 | " dshd %0, %0 \n" | 54 | " dshd %0, %0" |
| 55 | " drotr %0, %0, 32 \n" | ||
| 56 | : "=r" (x) | 55 | : "=r" (x) |
| 57 | : "r" (x)); | 56 | : "r" (x)); |
| 58 | 57 | ||
diff --git a/arch/mips/include/asm/elf.h b/arch/mips/include/asm/elf.h index a8eac1697b3d..d58f128aa747 100644 --- a/arch/mips/include/asm/elf.h +++ b/arch/mips/include/asm/elf.h | |||
| @@ -232,7 +232,7 @@ typedef elf_fpreg_t elf_fpregset_t[ELF_NFPREG]; | |||
| 232 | */ | 232 | */ |
| 233 | #ifdef __MIPSEB__ | 233 | #ifdef __MIPSEB__ |
| 234 | #define ELF_DATA ELFDATA2MSB | 234 | #define ELF_DATA ELFDATA2MSB |
| 235 | #elif __MIPSEL__ | 235 | #elif defined(__MIPSEL__) |
| 236 | #define ELF_DATA ELFDATA2LSB | 236 | #define ELF_DATA ELFDATA2LSB |
| 237 | #endif | 237 | #endif |
| 238 | #define ELF_ARCH EM_MIPS | 238 | #define ELF_ARCH EM_MIPS |
diff --git a/arch/parisc/include/asm/tlbflush.h b/arch/parisc/include/asm/tlbflush.h index b72ec66db699..1f6fd4fc05b9 100644 --- a/arch/parisc/include/asm/tlbflush.h +++ b/arch/parisc/include/asm/tlbflush.h | |||
| @@ -44,9 +44,12 @@ static inline void flush_tlb_mm(struct mm_struct *mm) | |||
| 44 | { | 44 | { |
| 45 | BUG_ON(mm == &init_mm); /* Should never happen */ | 45 | BUG_ON(mm == &init_mm); /* Should never happen */ |
| 46 | 46 | ||
| 47 | #ifdef CONFIG_SMP | 47 | #if 1 || defined(CONFIG_SMP) |
| 48 | flush_tlb_all(); | 48 | flush_tlb_all(); |
| 49 | #else | 49 | #else |
| 50 | /* FIXME: currently broken, causing space id and protection ids | ||
| 51 | * to go out of sync, resulting in faults on userspace accesses. | ||
| 52 | */ | ||
| 50 | if (mm) { | 53 | if (mm) { |
| 51 | if (mm->context != 0) | 54 | if (mm->context != 0) |
| 52 | free_sid(mm->context); | 55 | free_sid(mm->context); |
diff --git a/arch/sparc/include/asm/ptrace_32.h b/arch/sparc/include/asm/ptrace_32.h index d409c4f21a5c..4cef450167dd 100644 --- a/arch/sparc/include/asm/ptrace_32.h +++ b/arch/sparc/include/asm/ptrace_32.h | |||
| @@ -62,6 +62,8 @@ struct sparc_stackf { | |||
| 62 | 62 | ||
| 63 | #ifdef __KERNEL__ | 63 | #ifdef __KERNEL__ |
| 64 | 64 | ||
| 65 | #include <asm/system.h> | ||
| 66 | |||
| 65 | static inline bool pt_regs_is_syscall(struct pt_regs *regs) | 67 | static inline bool pt_regs_is_syscall(struct pt_regs *regs) |
| 66 | { | 68 | { |
| 67 | return (regs->psr & PSR_SYSCALL); | 69 | return (regs->psr & PSR_SYSCALL); |
| @@ -72,6 +74,14 @@ static inline bool pt_regs_clear_syscall(struct pt_regs *regs) | |||
| 72 | return (regs->psr &= ~PSR_SYSCALL); | 74 | return (regs->psr &= ~PSR_SYSCALL); |
| 73 | } | 75 | } |
| 74 | 76 | ||
| 77 | #define arch_ptrace_stop_needed(exit_code, info) \ | ||
| 78 | ({ flush_user_windows(); \ | ||
| 79 | current_thread_info()->w_saved != 0; \ | ||
| 80 | }) | ||
| 81 | |||
| 82 | #define arch_ptrace_stop(exit_code, info) \ | ||
| 83 | synchronize_user_stack() | ||
| 84 | |||
| 75 | #define user_mode(regs) (!((regs)->psr & PSR_PS)) | 85 | #define user_mode(regs) (!((regs)->psr & PSR_PS)) |
| 76 | #define instruction_pointer(regs) ((regs)->pc) | 86 | #define instruction_pointer(regs) ((regs)->pc) |
| 77 | #define user_stack_pointer(regs) ((regs)->u_regs[UREG_FP]) | 87 | #define user_stack_pointer(regs) ((regs)->u_regs[UREG_FP]) |
diff --git a/arch/sparc/include/asm/ptrace_64.h b/arch/sparc/include/asm/ptrace_64.h index 84e969f06afe..cd6fbfc20435 100644 --- a/arch/sparc/include/asm/ptrace_64.h +++ b/arch/sparc/include/asm/ptrace_64.h | |||
| @@ -114,6 +114,7 @@ struct sparc_trapf { | |||
| 114 | #ifdef __KERNEL__ | 114 | #ifdef __KERNEL__ |
| 115 | 115 | ||
| 116 | #include <linux/threads.h> | 116 | #include <linux/threads.h> |
| 117 | #include <asm/system.h> | ||
| 117 | 118 | ||
| 118 | static inline int pt_regs_trap_type(struct pt_regs *regs) | 119 | static inline int pt_regs_trap_type(struct pt_regs *regs) |
| 119 | { | 120 | { |
| @@ -130,6 +131,14 @@ static inline bool pt_regs_clear_syscall(struct pt_regs *regs) | |||
| 130 | return (regs->tstate &= ~TSTATE_SYSCALL); | 131 | return (regs->tstate &= ~TSTATE_SYSCALL); |
| 131 | } | 132 | } |
| 132 | 133 | ||
| 134 | #define arch_ptrace_stop_needed(exit_code, info) \ | ||
| 135 | ({ flush_user_windows(); \ | ||
| 136 | get_thread_wsaved() != 0; \ | ||
| 137 | }) | ||
| 138 | |||
| 139 | #define arch_ptrace_stop(exit_code, info) \ | ||
| 140 | synchronize_user_stack() | ||
| 141 | |||
| 133 | struct global_reg_snapshot { | 142 | struct global_reg_snapshot { |
| 134 | unsigned long tstate; | 143 | unsigned long tstate; |
| 135 | unsigned long tpc; | 144 | unsigned long tpc; |
diff --git a/arch/x86/include/asm/ds.h b/arch/x86/include/asm/ds.h index ee0ea3a96c11..a8f672ba100c 100644 --- a/arch/x86/include/asm/ds.h +++ b/arch/x86/include/asm/ds.h | |||
| @@ -252,12 +252,21 @@ extern void __cpuinit ds_init_intel(struct cpuinfo_x86 *); | |||
| 252 | */ | 252 | */ |
| 253 | extern void ds_switch_to(struct task_struct *prev, struct task_struct *next); | 253 | extern void ds_switch_to(struct task_struct *prev, struct task_struct *next); |
| 254 | 254 | ||
| 255 | /* | ||
| 256 | * Task clone/init and cleanup work | ||
| 257 | */ | ||
| 258 | extern void ds_copy_thread(struct task_struct *tsk, struct task_struct *father); | ||
| 259 | extern void ds_exit_thread(struct task_struct *tsk); | ||
| 260 | |||
| 255 | #else /* CONFIG_X86_DS */ | 261 | #else /* CONFIG_X86_DS */ |
| 256 | 262 | ||
| 257 | struct cpuinfo_x86; | 263 | struct cpuinfo_x86; |
| 258 | static inline void __cpuinit ds_init_intel(struct cpuinfo_x86 *ignored) {} | 264 | static inline void __cpuinit ds_init_intel(struct cpuinfo_x86 *ignored) {} |
| 259 | static inline void ds_switch_to(struct task_struct *prev, | 265 | static inline void ds_switch_to(struct task_struct *prev, |
| 260 | struct task_struct *next) {} | 266 | struct task_struct *next) {} |
| 267 | static inline void ds_copy_thread(struct task_struct *tsk, | ||
| 268 | struct task_struct *father) {} | ||
| 269 | static inline void ds_exit_thread(struct task_struct *tsk) {} | ||
| 261 | 270 | ||
| 262 | #endif /* CONFIG_X86_DS */ | 271 | #endif /* CONFIG_X86_DS */ |
| 263 | #endif /* _ASM_X86_DS_H */ | 272 | #endif /* _ASM_X86_DS_H */ |
diff --git a/arch/x86/include/asm/msr.h b/arch/x86/include/asm/msr.h index c2a812ebde89..b8a1799ea871 100644 --- a/arch/x86/include/asm/msr.h +++ b/arch/x86/include/asm/msr.h | |||
| @@ -85,7 +85,8 @@ static inline void native_write_msr(unsigned int msr, | |||
| 85 | asm volatile("wrmsr" : : "c" (msr), "a"(low), "d" (high) : "memory"); | 85 | asm volatile("wrmsr" : : "c" (msr), "a"(low), "d" (high) : "memory"); |
| 86 | } | 86 | } |
| 87 | 87 | ||
| 88 | static inline int native_write_msr_safe(unsigned int msr, | 88 | /* Can be uninlined because referenced by paravirt */ |
| 89 | notrace static inline int native_write_msr_safe(unsigned int msr, | ||
| 89 | unsigned low, unsigned high) | 90 | unsigned low, unsigned high) |
| 90 | { | 91 | { |
| 91 | int err; | 92 | int err; |
diff --git a/arch/x86/include/asm/ptrace.h b/arch/x86/include/asm/ptrace.h index fbf744215911..6d34d954c228 100644 --- a/arch/x86/include/asm/ptrace.h +++ b/arch/x86/include/asm/ptrace.h | |||
| @@ -235,6 +235,13 @@ extern int do_get_thread_area(struct task_struct *p, int idx, | |||
| 235 | extern int do_set_thread_area(struct task_struct *p, int idx, | 235 | extern int do_set_thread_area(struct task_struct *p, int idx, |
| 236 | struct user_desc __user *info, int can_allocate); | 236 | struct user_desc __user *info, int can_allocate); |
| 237 | 237 | ||
| 238 | extern void x86_ptrace_untrace(struct task_struct *); | ||
| 239 | extern void x86_ptrace_fork(struct task_struct *child, | ||
| 240 | unsigned long clone_flags); | ||
| 241 | |||
| 242 | #define arch_ptrace_untrace(tsk) x86_ptrace_untrace(tsk) | ||
| 243 | #define arch_ptrace_fork(child, flags) x86_ptrace_fork(child, flags) | ||
| 244 | |||
| 238 | #endif /* __KERNEL__ */ | 245 | #endif /* __KERNEL__ */ |
| 239 | 246 | ||
| 240 | #endif /* !__ASSEMBLY__ */ | 247 | #endif /* !__ASSEMBLY__ */ |
diff --git a/arch/x86/kernel/amd_iommu.c b/arch/x86/kernel/amd_iommu.c index a7b6dec6fc3f..0a60d60ed036 100644 --- a/arch/x86/kernel/amd_iommu.c +++ b/arch/x86/kernel/amd_iommu.c | |||
| @@ -235,8 +235,9 @@ static int iommu_completion_wait(struct amd_iommu *iommu) | |||
| 235 | status &= ~MMIO_STATUS_COM_WAIT_INT_MASK; | 235 | status &= ~MMIO_STATUS_COM_WAIT_INT_MASK; |
| 236 | writel(status, iommu->mmio_base + MMIO_STATUS_OFFSET); | 236 | writel(status, iommu->mmio_base + MMIO_STATUS_OFFSET); |
| 237 | 237 | ||
| 238 | if (unlikely((i == EXIT_LOOP_COUNT) && printk_ratelimit())) | 238 | if (unlikely(i == EXIT_LOOP_COUNT)) |
| 239 | printk(KERN_WARNING "AMD IOMMU: Completion wait loop failed\n"); | 239 | panic("AMD IOMMU: Completion wait loop failed\n"); |
| 240 | |||
| 240 | out: | 241 | out: |
| 241 | spin_unlock_irqrestore(&iommu->lock, flags); | 242 | spin_unlock_irqrestore(&iommu->lock, flags); |
| 242 | 243 | ||
diff --git a/arch/x86/kernel/amd_iommu_init.c b/arch/x86/kernel/amd_iommu_init.c index 30ae2701b3df..c6cc22815d35 100644 --- a/arch/x86/kernel/amd_iommu_init.c +++ b/arch/x86/kernel/amd_iommu_init.c | |||
| @@ -427,6 +427,10 @@ static u8 * __init alloc_command_buffer(struct amd_iommu *iommu) | |||
| 427 | memcpy_toio(iommu->mmio_base + MMIO_CMD_BUF_OFFSET, | 427 | memcpy_toio(iommu->mmio_base + MMIO_CMD_BUF_OFFSET, |
| 428 | &entry, sizeof(entry)); | 428 | &entry, sizeof(entry)); |
| 429 | 429 | ||
| 430 | /* set head and tail to zero manually */ | ||
| 431 | writel(0x00, iommu->mmio_base + MMIO_CMD_HEAD_OFFSET); | ||
| 432 | writel(0x00, iommu->mmio_base + MMIO_CMD_TAIL_OFFSET); | ||
| 433 | |||
| 430 | iommu_feature_enable(iommu, CONTROL_CMDBUF_EN); | 434 | iommu_feature_enable(iommu, CONTROL_CMDBUF_EN); |
| 431 | 435 | ||
| 432 | return cmd_buf; | 436 | return cmd_buf; |
| @@ -1074,7 +1078,8 @@ int __init amd_iommu_init(void) | |||
| 1074 | goto free; | 1078 | goto free; |
| 1075 | 1079 | ||
| 1076 | /* IOMMU rlookup table - find the IOMMU for a specific device */ | 1080 | /* IOMMU rlookup table - find the IOMMU for a specific device */ |
| 1077 | amd_iommu_rlookup_table = (void *)__get_free_pages(GFP_KERNEL, | 1081 | amd_iommu_rlookup_table = (void *)__get_free_pages( |
| 1082 | GFP_KERNEL | __GFP_ZERO, | ||
| 1078 | get_order(rlookup_table_size)); | 1083 | get_order(rlookup_table_size)); |
| 1079 | if (amd_iommu_rlookup_table == NULL) | 1084 | if (amd_iommu_rlookup_table == NULL) |
| 1080 | goto free; | 1085 | goto free; |
diff --git a/arch/x86/kernel/cpu/Makefile b/arch/x86/kernel/cpu/Makefile index 82ec6075c057..4ae495a313f3 100644 --- a/arch/x86/kernel/cpu/Makefile +++ b/arch/x86/kernel/cpu/Makefile | |||
| @@ -2,6 +2,11 @@ | |||
| 2 | # Makefile for x86-compatible CPU details and quirks | 2 | # Makefile for x86-compatible CPU details and quirks |
| 3 | # | 3 | # |
| 4 | 4 | ||
| 5 | # Don't trace early stages of a secondary CPU boot | ||
| 6 | ifdef CONFIG_FUNCTION_TRACER | ||
| 7 | CFLAGS_REMOVE_common.o = -pg | ||
| 8 | endif | ||
| 9 | |||
| 5 | obj-y := intel_cacheinfo.o addon_cpuid_features.o | 10 | obj-y := intel_cacheinfo.o addon_cpuid_features.o |
| 6 | obj-y += proc.o capflags.o powerflags.o common.o | 11 | obj-y += proc.o capflags.o powerflags.o common.o |
| 7 | 12 | ||
diff --git a/arch/x86/kernel/cpu/mcheck/mce_64.c b/arch/x86/kernel/cpu/mcheck/mce_64.c index 4b031a4ac856..1c838032fd37 100644 --- a/arch/x86/kernel/cpu/mcheck/mce_64.c +++ b/arch/x86/kernel/cpu/mcheck/mce_64.c | |||
| @@ -510,12 +510,9 @@ static void __cpuinit mce_cpu_features(struct cpuinfo_x86 *c) | |||
| 510 | */ | 510 | */ |
| 511 | void __cpuinit mcheck_init(struct cpuinfo_x86 *c) | 511 | void __cpuinit mcheck_init(struct cpuinfo_x86 *c) |
| 512 | { | 512 | { |
| 513 | static cpumask_t mce_cpus = CPU_MASK_NONE; | ||
| 514 | |||
| 515 | mce_cpu_quirks(c); | 513 | mce_cpu_quirks(c); |
| 516 | 514 | ||
| 517 | if (mce_dont_init || | 515 | if (mce_dont_init || |
| 518 | cpu_test_and_set(smp_processor_id(), mce_cpus) || | ||
| 519 | !mce_available(c)) | 516 | !mce_available(c)) |
| 520 | return; | 517 | return; |
| 521 | 518 | ||
diff --git a/arch/x86/kernel/ds.c b/arch/x86/kernel/ds.c index 98d271e60e08..da91701a2348 100644 --- a/arch/x86/kernel/ds.c +++ b/arch/x86/kernel/ds.c | |||
| @@ -1017,3 +1017,14 @@ void ds_switch_to(struct task_struct *prev, struct task_struct *next) | |||
| 1017 | 1017 | ||
| 1018 | update_debugctlmsr(next->thread.debugctlmsr); | 1018 | update_debugctlmsr(next->thread.debugctlmsr); |
| 1019 | } | 1019 | } |
| 1020 | |||
| 1021 | void ds_copy_thread(struct task_struct *tsk, struct task_struct *father) | ||
| 1022 | { | ||
| 1023 | clear_tsk_thread_flag(tsk, TIF_DS_AREA_MSR); | ||
| 1024 | tsk->thread.ds_ctx = NULL; | ||
| 1025 | } | ||
| 1026 | |||
| 1027 | void ds_exit_thread(struct task_struct *tsk) | ||
| 1028 | { | ||
| 1029 | WARN_ON(tsk->thread.ds_ctx); | ||
| 1030 | } | ||
diff --git a/arch/x86/kernel/microcode_core.c b/arch/x86/kernel/microcode_core.c index 82fb2809ce32..c4b5b24e0217 100644 --- a/arch/x86/kernel/microcode_core.c +++ b/arch/x86/kernel/microcode_core.c | |||
| @@ -272,13 +272,18 @@ static struct attribute_group mc_attr_group = { | |||
| 272 | .name = "microcode", | 272 | .name = "microcode", |
| 273 | }; | 273 | }; |
| 274 | 274 | ||
| 275 | static void microcode_fini_cpu(int cpu) | 275 | static void __microcode_fini_cpu(int cpu) |
| 276 | { | 276 | { |
| 277 | struct ucode_cpu_info *uci = ucode_cpu_info + cpu; | 277 | struct ucode_cpu_info *uci = ucode_cpu_info + cpu; |
| 278 | 278 | ||
| 279 | mutex_lock(µcode_mutex); | ||
| 280 | microcode_ops->microcode_fini_cpu(cpu); | 279 | microcode_ops->microcode_fini_cpu(cpu); |
| 281 | uci->valid = 0; | 280 | uci->valid = 0; |
| 281 | } | ||
| 282 | |||
| 283 | static void microcode_fini_cpu(int cpu) | ||
| 284 | { | ||
| 285 | mutex_lock(µcode_mutex); | ||
| 286 | __microcode_fini_cpu(cpu); | ||
| 282 | mutex_unlock(µcode_mutex); | 287 | mutex_unlock(µcode_mutex); |
| 283 | } | 288 | } |
| 284 | 289 | ||
| @@ -306,12 +311,16 @@ static int microcode_resume_cpu(int cpu) | |||
| 306 | * to this cpu (a bit of paranoia): | 311 | * to this cpu (a bit of paranoia): |
| 307 | */ | 312 | */ |
| 308 | if (microcode_ops->collect_cpu_info(cpu, &nsig)) { | 313 | if (microcode_ops->collect_cpu_info(cpu, &nsig)) { |
| 309 | microcode_fini_cpu(cpu); | 314 | __microcode_fini_cpu(cpu); |
| 315 | printk(KERN_ERR "failed to collect_cpu_info for resuming cpu #%d\n", | ||
| 316 | cpu); | ||
| 310 | return -1; | 317 | return -1; |
| 311 | } | 318 | } |
| 312 | 319 | ||
| 313 | if (memcmp(&nsig, &uci->cpu_sig, sizeof(nsig))) { | 320 | if ((nsig.sig != uci->cpu_sig.sig) || (nsig.pf != uci->cpu_sig.pf)) { |
| 314 | microcode_fini_cpu(cpu); | 321 | __microcode_fini_cpu(cpu); |
| 322 | printk(KERN_ERR "cached ucode doesn't match the resuming cpu #%d\n", | ||
| 323 | cpu); | ||
| 315 | /* Should we look for a new ucode here? */ | 324 | /* Should we look for a new ucode here? */ |
| 316 | return 1; | 325 | return 1; |
| 317 | } | 326 | } |
diff --git a/arch/x86/kernel/microcode_intel.c b/arch/x86/kernel/microcode_intel.c index 622dc4a21784..a8e62792d171 100644 --- a/arch/x86/kernel/microcode_intel.c +++ b/arch/x86/kernel/microcode_intel.c | |||
| @@ -155,6 +155,7 @@ static DEFINE_SPINLOCK(microcode_update_lock); | |||
| 155 | static int collect_cpu_info(int cpu_num, struct cpu_signature *csig) | 155 | static int collect_cpu_info(int cpu_num, struct cpu_signature *csig) |
| 156 | { | 156 | { |
| 157 | struct cpuinfo_x86 *c = &cpu_data(cpu_num); | 157 | struct cpuinfo_x86 *c = &cpu_data(cpu_num); |
| 158 | unsigned long flags; | ||
| 158 | unsigned int val[2]; | 159 | unsigned int val[2]; |
| 159 | 160 | ||
| 160 | memset(csig, 0, sizeof(*csig)); | 161 | memset(csig, 0, sizeof(*csig)); |
| @@ -174,11 +175,16 @@ static int collect_cpu_info(int cpu_num, struct cpu_signature *csig) | |||
| 174 | csig->pf = 1 << ((val[1] >> 18) & 7); | 175 | csig->pf = 1 << ((val[1] >> 18) & 7); |
| 175 | } | 176 | } |
| 176 | 177 | ||
| 178 | /* serialize access to the physical write to MSR 0x79 */ | ||
| 179 | spin_lock_irqsave(µcode_update_lock, flags); | ||
| 180 | |||
| 177 | wrmsr(MSR_IA32_UCODE_REV, 0, 0); | 181 | wrmsr(MSR_IA32_UCODE_REV, 0, 0); |
| 178 | /* see notes above for revision 1.07. Apparent chip bug */ | 182 | /* see notes above for revision 1.07. Apparent chip bug */ |
| 179 | sync_core(); | 183 | sync_core(); |
| 180 | /* get the current revision from MSR 0x8B */ | 184 | /* get the current revision from MSR 0x8B */ |
| 181 | rdmsr(MSR_IA32_UCODE_REV, val[0], csig->rev); | 185 | rdmsr(MSR_IA32_UCODE_REV, val[0], csig->rev); |
| 186 | spin_unlock_irqrestore(µcode_update_lock, flags); | ||
| 187 | |||
| 182 | pr_debug("microcode: collect_cpu_info : sig=0x%x, pf=0x%x, rev=0x%x\n", | 188 | pr_debug("microcode: collect_cpu_info : sig=0x%x, pf=0x%x, rev=0x%x\n", |
| 183 | csig->sig, csig->pf, csig->rev); | 189 | csig->sig, csig->pf, csig->rev); |
| 184 | 190 | ||
diff --git a/arch/x86/kernel/pci-gart_64.c b/arch/x86/kernel/pci-gart_64.c index ba7ad83e20a8..a35eaa379ff6 100644 --- a/arch/x86/kernel/pci-gart_64.c +++ b/arch/x86/kernel/pci-gart_64.c | |||
| @@ -745,10 +745,8 @@ void __init gart_iommu_init(void) | |||
| 745 | unsigned long scratch; | 745 | unsigned long scratch; |
| 746 | long i; | 746 | long i; |
| 747 | 747 | ||
| 748 | if (cache_k8_northbridges() < 0 || num_k8_northbridges == 0) { | 748 | if (cache_k8_northbridges() < 0 || num_k8_northbridges == 0) |
| 749 | printk(KERN_INFO "PCI-GART: No AMD GART found.\n"); | ||
| 750 | return; | 749 | return; |
| 751 | } | ||
| 752 | 750 | ||
| 753 | #ifndef CONFIG_AGP_AMD64 | 751 | #ifndef CONFIG_AGP_AMD64 |
| 754 | no_agp = 1; | 752 | no_agp = 1; |
diff --git a/arch/x86/kernel/process_32.c b/arch/x86/kernel/process_32.c index 605eff9a8ac0..3ba155d24884 100644 --- a/arch/x86/kernel/process_32.c +++ b/arch/x86/kernel/process_32.c | |||
| @@ -60,6 +60,7 @@ | |||
| 60 | #include <asm/idle.h> | 60 | #include <asm/idle.h> |
| 61 | #include <asm/syscalls.h> | 61 | #include <asm/syscalls.h> |
| 62 | #include <asm/smp.h> | 62 | #include <asm/smp.h> |
| 63 | #include <asm/ds.h> | ||
| 63 | 64 | ||
| 64 | asmlinkage void ret_from_fork(void) __asm__("ret_from_fork"); | 65 | asmlinkage void ret_from_fork(void) __asm__("ret_from_fork"); |
| 65 | 66 | ||
| @@ -251,17 +252,8 @@ void exit_thread(void) | |||
| 251 | tss->x86_tss.io_bitmap_base = INVALID_IO_BITMAP_OFFSET; | 252 | tss->x86_tss.io_bitmap_base = INVALID_IO_BITMAP_OFFSET; |
| 252 | put_cpu(); | 253 | put_cpu(); |
| 253 | } | 254 | } |
| 254 | #ifdef CONFIG_X86_DS | 255 | |
| 255 | /* Free any BTS tracers that have not been properly released. */ | 256 | ds_exit_thread(current); |
| 256 | if (unlikely(current->bts)) { | ||
| 257 | ds_release_bts(current->bts); | ||
| 258 | current->bts = NULL; | ||
| 259 | |||
| 260 | kfree(current->bts_buffer); | ||
| 261 | current->bts_buffer = NULL; | ||
| 262 | current->bts_size = 0; | ||
| 263 | } | ||
| 264 | #endif /* CONFIG_X86_DS */ | ||
| 265 | } | 257 | } |
| 266 | 258 | ||
| 267 | void flush_thread(void) | 259 | void flush_thread(void) |
| @@ -343,6 +335,12 @@ int copy_thread(int nr, unsigned long clone_flags, unsigned long sp, | |||
| 343 | kfree(p->thread.io_bitmap_ptr); | 335 | kfree(p->thread.io_bitmap_ptr); |
| 344 | p->thread.io_bitmap_max = 0; | 336 | p->thread.io_bitmap_max = 0; |
| 345 | } | 337 | } |
| 338 | |||
| 339 | ds_copy_thread(p, current); | ||
| 340 | |||
| 341 | clear_tsk_thread_flag(p, TIF_DEBUGCTLMSR); | ||
| 342 | p->thread.debugctlmsr = 0; | ||
| 343 | |||
| 346 | return err; | 344 | return err; |
| 347 | } | 345 | } |
| 348 | 346 | ||
diff --git a/arch/x86/kernel/process_64.c b/arch/x86/kernel/process_64.c index 1cfd2a4bf853..416fb9282f4f 100644 --- a/arch/x86/kernel/process_64.c +++ b/arch/x86/kernel/process_64.c | |||
| @@ -53,6 +53,7 @@ | |||
| 53 | #include <asm/ia32.h> | 53 | #include <asm/ia32.h> |
| 54 | #include <asm/idle.h> | 54 | #include <asm/idle.h> |
| 55 | #include <asm/syscalls.h> | 55 | #include <asm/syscalls.h> |
| 56 | #include <asm/ds.h> | ||
| 56 | 57 | ||
| 57 | asmlinkage extern void ret_from_fork(void); | 58 | asmlinkage extern void ret_from_fork(void); |
| 58 | 59 | ||
| @@ -236,17 +237,8 @@ void exit_thread(void) | |||
| 236 | t->io_bitmap_max = 0; | 237 | t->io_bitmap_max = 0; |
| 237 | put_cpu(); | 238 | put_cpu(); |
| 238 | } | 239 | } |
| 239 | #ifdef CONFIG_X86_DS | 240 | |
| 240 | /* Free any BTS tracers that have not been properly released. */ | 241 | ds_exit_thread(current); |
| 241 | if (unlikely(current->bts)) { | ||
| 242 | ds_release_bts(current->bts); | ||
| 243 | current->bts = NULL; | ||
| 244 | |||
| 245 | kfree(current->bts_buffer); | ||
| 246 | current->bts_buffer = NULL; | ||
| 247 | current->bts_size = 0; | ||
| 248 | } | ||
| 249 | #endif /* CONFIG_X86_DS */ | ||
| 250 | } | 242 | } |
| 251 | 243 | ||
| 252 | void flush_thread(void) | 244 | void flush_thread(void) |
| @@ -376,6 +368,12 @@ int copy_thread(int nr, unsigned long clone_flags, unsigned long sp, | |||
| 376 | if (err) | 368 | if (err) |
| 377 | goto out; | 369 | goto out; |
| 378 | } | 370 | } |
| 371 | |||
| 372 | ds_copy_thread(p, me); | ||
| 373 | |||
| 374 | clear_tsk_thread_flag(p, TIF_DEBUGCTLMSR); | ||
| 375 | p->thread.debugctlmsr = 0; | ||
| 376 | |||
| 379 | err = 0; | 377 | err = 0; |
| 380 | out: | 378 | out: |
| 381 | if (err && p->thread.io_bitmap_ptr) { | 379 | if (err && p->thread.io_bitmap_ptr) { |
diff --git a/arch/x86/kernel/ptrace.c b/arch/x86/kernel/ptrace.c index 45e9855da2d2..0a5df5f82fb9 100644 --- a/arch/x86/kernel/ptrace.c +++ b/arch/x86/kernel/ptrace.c | |||
| @@ -650,6 +650,24 @@ static int ptrace_bts_drain(struct task_struct *child, | |||
| 650 | return drained; | 650 | return drained; |
| 651 | } | 651 | } |
| 652 | 652 | ||
| 653 | static int ptrace_bts_allocate_buffer(struct task_struct *child, size_t size) | ||
| 654 | { | ||
| 655 | child->bts_buffer = alloc_locked_buffer(size); | ||
| 656 | if (!child->bts_buffer) | ||
| 657 | return -ENOMEM; | ||
| 658 | |||
| 659 | child->bts_size = size; | ||
| 660 | |||
| 661 | return 0; | ||
| 662 | } | ||
| 663 | |||
| 664 | static void ptrace_bts_free_buffer(struct task_struct *child) | ||
| 665 | { | ||
| 666 | free_locked_buffer(child->bts_buffer, child->bts_size); | ||
| 667 | child->bts_buffer = NULL; | ||
| 668 | child->bts_size = 0; | ||
| 669 | } | ||
| 670 | |||
| 653 | static int ptrace_bts_config(struct task_struct *child, | 671 | static int ptrace_bts_config(struct task_struct *child, |
| 654 | long cfg_size, | 672 | long cfg_size, |
| 655 | const struct ptrace_bts_config __user *ucfg) | 673 | const struct ptrace_bts_config __user *ucfg) |
| @@ -679,14 +697,13 @@ static int ptrace_bts_config(struct task_struct *child, | |||
| 679 | 697 | ||
| 680 | if ((cfg.flags & PTRACE_BTS_O_ALLOC) && | 698 | if ((cfg.flags & PTRACE_BTS_O_ALLOC) && |
| 681 | (cfg.size != child->bts_size)) { | 699 | (cfg.size != child->bts_size)) { |
| 682 | kfree(child->bts_buffer); | 700 | int error; |
| 683 | 701 | ||
| 684 | child->bts_size = cfg.size; | 702 | ptrace_bts_free_buffer(child); |
| 685 | child->bts_buffer = kzalloc(cfg.size, GFP_KERNEL); | 703 | |
| 686 | if (!child->bts_buffer) { | 704 | error = ptrace_bts_allocate_buffer(child, cfg.size); |
| 687 | child->bts_size = 0; | 705 | if (error < 0) |
| 688 | return -ENOMEM; | 706 | return error; |
| 689 | } | ||
| 690 | } | 707 | } |
| 691 | 708 | ||
| 692 | if (cfg.flags & PTRACE_BTS_O_TRACE) | 709 | if (cfg.flags & PTRACE_BTS_O_TRACE) |
| @@ -701,10 +718,8 @@ static int ptrace_bts_config(struct task_struct *child, | |||
| 701 | if (IS_ERR(child->bts)) { | 718 | if (IS_ERR(child->bts)) { |
| 702 | int error = PTR_ERR(child->bts); | 719 | int error = PTR_ERR(child->bts); |
| 703 | 720 | ||
| 704 | kfree(child->bts_buffer); | 721 | ptrace_bts_free_buffer(child); |
| 705 | child->bts = NULL; | 722 | child->bts = NULL; |
| 706 | child->bts_buffer = NULL; | ||
| 707 | child->bts_size = 0; | ||
| 708 | 723 | ||
| 709 | return error; | 724 | return error; |
| 710 | } | 725 | } |
| @@ -769,8 +784,55 @@ static int ptrace_bts_size(struct task_struct *child) | |||
| 769 | 784 | ||
| 770 | return (trace->ds.top - trace->ds.begin) / trace->ds.size; | 785 | return (trace->ds.top - trace->ds.begin) / trace->ds.size; |
| 771 | } | 786 | } |
| 787 | |||
| 788 | static void ptrace_bts_fork(struct task_struct *tsk) | ||
| 789 | { | ||
| 790 | tsk->bts = NULL; | ||
| 791 | tsk->bts_buffer = NULL; | ||
| 792 | tsk->bts_size = 0; | ||
| 793 | tsk->thread.bts_ovfl_signal = 0; | ||
| 794 | } | ||
| 795 | |||
| 796 | static void ptrace_bts_untrace(struct task_struct *child) | ||
| 797 | { | ||
| 798 | if (unlikely(child->bts)) { | ||
| 799 | ds_release_bts(child->bts); | ||
| 800 | child->bts = NULL; | ||
| 801 | |||
| 802 | /* We cannot update total_vm and locked_vm since | ||
| 803 | child's mm is already gone. But we can reclaim the | ||
| 804 | memory. */ | ||
| 805 | kfree(child->bts_buffer); | ||
| 806 | child->bts_buffer = NULL; | ||
| 807 | child->bts_size = 0; | ||
| 808 | } | ||
| 809 | } | ||
| 810 | |||
| 811 | static void ptrace_bts_detach(struct task_struct *child) | ||
| 812 | { | ||
| 813 | if (unlikely(child->bts)) { | ||
| 814 | ds_release_bts(child->bts); | ||
| 815 | child->bts = NULL; | ||
| 816 | |||
| 817 | ptrace_bts_free_buffer(child); | ||
| 818 | } | ||
| 819 | } | ||
| 820 | #else | ||
| 821 | static inline void ptrace_bts_fork(struct task_struct *tsk) {} | ||
| 822 | static inline void ptrace_bts_detach(struct task_struct *child) {} | ||
| 823 | static inline void ptrace_bts_untrace(struct task_struct *child) {} | ||
| 772 | #endif /* CONFIG_X86_PTRACE_BTS */ | 824 | #endif /* CONFIG_X86_PTRACE_BTS */ |
| 773 | 825 | ||
| 826 | void x86_ptrace_fork(struct task_struct *child, unsigned long clone_flags) | ||
| 827 | { | ||
| 828 | ptrace_bts_fork(child); | ||
| 829 | } | ||
| 830 | |||
| 831 | void x86_ptrace_untrace(struct task_struct *child) | ||
| 832 | { | ||
| 833 | ptrace_bts_untrace(child); | ||
| 834 | } | ||
| 835 | |||
| 774 | /* | 836 | /* |
| 775 | * Called by kernel/ptrace.c when detaching.. | 837 | * Called by kernel/ptrace.c when detaching.. |
| 776 | * | 838 | * |
| @@ -782,16 +844,7 @@ void ptrace_disable(struct task_struct *child) | |||
| 782 | #ifdef TIF_SYSCALL_EMU | 844 | #ifdef TIF_SYSCALL_EMU |
| 783 | clear_tsk_thread_flag(child, TIF_SYSCALL_EMU); | 845 | clear_tsk_thread_flag(child, TIF_SYSCALL_EMU); |
| 784 | #endif | 846 | #endif |
| 785 | #ifdef CONFIG_X86_PTRACE_BTS | 847 | ptrace_bts_detach(child); |
| 786 | if (child->bts) { | ||
| 787 | ds_release_bts(child->bts); | ||
| 788 | child->bts = NULL; | ||
| 789 | |||
| 790 | kfree(child->bts_buffer); | ||
| 791 | child->bts_buffer = NULL; | ||
| 792 | child->bts_size = 0; | ||
| 793 | } | ||
| 794 | #endif /* CONFIG_X86_PTRACE_BTS */ | ||
| 795 | } | 848 | } |
| 796 | 849 | ||
| 797 | #if defined CONFIG_X86_32 || defined CONFIG_IA32_EMULATION | 850 | #if defined CONFIG_X86_32 || defined CONFIG_IA32_EMULATION |
diff --git a/arch/x86/kernel/smpboot.c b/arch/x86/kernel/smpboot.c index f71f96fc9e62..f6174d229024 100644 --- a/arch/x86/kernel/smpboot.c +++ b/arch/x86/kernel/smpboot.c | |||
| @@ -287,7 +287,7 @@ static int __cpuinitdata unsafe_smp; | |||
| 287 | /* | 287 | /* |
| 288 | * Activate a secondary processor. | 288 | * Activate a secondary processor. |
| 289 | */ | 289 | */ |
| 290 | static void __cpuinit start_secondary(void *unused) | 290 | notrace static void __cpuinit start_secondary(void *unused) |
| 291 | { | 291 | { |
| 292 | /* | 292 | /* |
| 293 | * Don't put *anything* before cpu_init(), SMP booting is too | 293 | * Don't put *anything* before cpu_init(), SMP booting is too |
diff --git a/crypto/async_tx/async_xor.c b/crypto/async_tx/async_xor.c index c029d3eb9ef0..595b78672b36 100644 --- a/crypto/async_tx/async_xor.c +++ b/crypto/async_tx/async_xor.c | |||
| @@ -53,10 +53,17 @@ do_async_xor(struct dma_chan *chan, struct page *dest, struct page **src_list, | |||
| 53 | int xor_src_cnt; | 53 | int xor_src_cnt; |
| 54 | dma_addr_t dma_dest; | 54 | dma_addr_t dma_dest; |
| 55 | 55 | ||
| 56 | dma_dest = dma_map_page(dma->dev, dest, offset, len, DMA_FROM_DEVICE); | 56 | /* map the dest bidrectional in case it is re-used as a source */ |
| 57 | for (i = 0; i < src_cnt; i++) | 57 | dma_dest = dma_map_page(dma->dev, dest, offset, len, DMA_BIDIRECTIONAL); |
| 58 | for (i = 0; i < src_cnt; i++) { | ||
| 59 | /* only map the dest once */ | ||
| 60 | if (unlikely(src_list[i] == dest)) { | ||
| 61 | dma_src[i] = dma_dest; | ||
| 62 | continue; | ||
| 63 | } | ||
| 58 | dma_src[i] = dma_map_page(dma->dev, src_list[i], offset, | 64 | dma_src[i] = dma_map_page(dma->dev, src_list[i], offset, |
| 59 | len, DMA_TO_DEVICE); | 65 | len, DMA_TO_DEVICE); |
| 66 | } | ||
| 60 | 67 | ||
| 61 | while (src_cnt) { | 68 | while (src_cnt) { |
| 62 | async_flags = flags; | 69 | async_flags = flags; |
diff --git a/drivers/acpi/bus.c b/drivers/acpi/bus.c index 7edf6d913c13..765fd1c56cd6 100644 --- a/drivers/acpi/bus.c +++ b/drivers/acpi/bus.c | |||
| @@ -688,14 +688,6 @@ void __init acpi_early_init(void) | |||
| 688 | if (acpi_disabled) | 688 | if (acpi_disabled) |
| 689 | return; | 689 | return; |
| 690 | 690 | ||
| 691 | /* | ||
| 692 | * ACPI CA initializes acpi_dbg_level to non-zero, which means | ||
| 693 | * we get debug output merely by turning on CONFIG_ACPI_DEBUG. | ||
| 694 | * Turn it off so we don't get output unless the user specifies | ||
| 695 | * acpi.debug_level. | ||
| 696 | */ | ||
| 697 | acpi_dbg_level = 0; | ||
| 698 | |||
| 699 | printk(KERN_INFO PREFIX "Core revision %08x\n", ACPI_CA_VERSION); | 691 | printk(KERN_INFO PREFIX "Core revision %08x\n", ACPI_CA_VERSION); |
| 700 | 692 | ||
| 701 | /* enable workarounds, unless strict ACPI spec. compliance */ | 693 | /* enable workarounds, unless strict ACPI spec. compliance */ |
diff --git a/drivers/acpi/utilities/utglobal.c b/drivers/acpi/utilities/utglobal.c index 670551b95e56..17ed5ac840f7 100644 --- a/drivers/acpi/utilities/utglobal.c +++ b/drivers/acpi/utilities/utglobal.c | |||
| @@ -64,7 +64,7 @@ u32 acpi_dbg_level = ACPI_DEBUG_DEFAULT; | |||
| 64 | 64 | ||
| 65 | /* Debug switch - layer (component) mask */ | 65 | /* Debug switch - layer (component) mask */ |
| 66 | 66 | ||
| 67 | u32 acpi_dbg_layer = ACPI_COMPONENT_DEFAULT | ACPI_ALL_DRIVERS; | 67 | u32 acpi_dbg_layer = 0; |
| 68 | u32 acpi_gbl_nesting_level = 0; | 68 | u32 acpi_gbl_nesting_level = 0; |
| 69 | 69 | ||
| 70 | /* Debugger globals */ | 70 | /* Debugger globals */ |
diff --git a/drivers/block/cciss.c b/drivers/block/cciss.c index 9364dc554257..9f7c543cc04b 100644 --- a/drivers/block/cciss.c +++ b/drivers/block/cciss.c | |||
| @@ -1693,6 +1693,11 @@ static int rebuild_lun_table(ctlr_info_t *h, int first_time) | |||
| 1693 | for (i = 0; i <= h->highest_lun; i++) { | 1693 | for (i = 0; i <= h->highest_lun; i++) { |
| 1694 | int j; | 1694 | int j; |
| 1695 | drv_found = 0; | 1695 | drv_found = 0; |
| 1696 | |||
| 1697 | /* skip holes in the array from already deleted drives */ | ||
| 1698 | if (h->drv[i].raid_level == -1) | ||
| 1699 | continue; | ||
| 1700 | |||
| 1696 | for (j = 0; j < num_luns; j++) { | 1701 | for (j = 0; j < num_luns; j++) { |
| 1697 | memcpy(&lunid, &ld_buff->LUN[j][0], 4); | 1702 | memcpy(&lunid, &ld_buff->LUN[j][0], 4); |
| 1698 | lunid = le32_to_cpu(lunid); | 1703 | lunid = le32_to_cpu(lunid); |
diff --git a/drivers/dma/dmaengine.c b/drivers/dma/dmaengine.c index 5317e08221ec..657996517374 100644 --- a/drivers/dma/dmaengine.c +++ b/drivers/dma/dmaengine.c | |||
| @@ -388,7 +388,10 @@ int dma_async_device_register(struct dma_device *device) | |||
| 388 | 388 | ||
| 389 | init_completion(&device->done); | 389 | init_completion(&device->done); |
| 390 | kref_init(&device->refcount); | 390 | kref_init(&device->refcount); |
| 391 | |||
| 392 | mutex_lock(&dma_list_mutex); | ||
| 391 | device->dev_id = id++; | 393 | device->dev_id = id++; |
| 394 | mutex_unlock(&dma_list_mutex); | ||
| 392 | 395 | ||
| 393 | /* represent channels in sysfs. Probably want devs too */ | 396 | /* represent channels in sysfs. Probably want devs too */ |
| 394 | list_for_each_entry(chan, &device->channels, device_node) { | 397 | list_for_each_entry(chan, &device->channels, device_node) { |
diff --git a/drivers/dma/ioat_dma.c b/drivers/dma/ioat_dma.c index ecd743f7cc61..6607fdd00b1c 100644 --- a/drivers/dma/ioat_dma.c +++ b/drivers/dma/ioat_dma.c | |||
| @@ -1341,10 +1341,12 @@ static void ioat_dma_start_null_desc(struct ioat_dma_chan *ioat_chan) | |||
| 1341 | */ | 1341 | */ |
| 1342 | #define IOAT_TEST_SIZE 2000 | 1342 | #define IOAT_TEST_SIZE 2000 |
| 1343 | 1343 | ||
| 1344 | DECLARE_COMPLETION(test_completion); | ||
| 1344 | static void ioat_dma_test_callback(void *dma_async_param) | 1345 | static void ioat_dma_test_callback(void *dma_async_param) |
| 1345 | { | 1346 | { |
| 1346 | printk(KERN_ERR "ioatdma: ioat_dma_test_callback(%p)\n", | 1347 | printk(KERN_ERR "ioatdma: ioat_dma_test_callback(%p)\n", |
| 1347 | dma_async_param); | 1348 | dma_async_param); |
| 1349 | complete(&test_completion); | ||
| 1348 | } | 1350 | } |
| 1349 | 1351 | ||
| 1350 | /** | 1352 | /** |
| @@ -1410,7 +1412,8 @@ static int ioat_dma_self_test(struct ioatdma_device *device) | |||
| 1410 | goto free_resources; | 1412 | goto free_resources; |
| 1411 | } | 1413 | } |
| 1412 | device->common.device_issue_pending(dma_chan); | 1414 | device->common.device_issue_pending(dma_chan); |
| 1413 | msleep(1); | 1415 | |
| 1416 | wait_for_completion_timeout(&test_completion, msecs_to_jiffies(3000)); | ||
| 1414 | 1417 | ||
| 1415 | if (device->common.device_is_tx_complete(dma_chan, cookie, NULL, NULL) | 1418 | if (device->common.device_is_tx_complete(dma_chan, cookie, NULL, NULL) |
| 1416 | != DMA_SUCCESS) { | 1419 | != DMA_SUCCESS) { |
diff --git a/drivers/dma/iop-adma.c b/drivers/dma/iop-adma.c index c7a9306d951d..6be317262200 100644 --- a/drivers/dma/iop-adma.c +++ b/drivers/dma/iop-adma.c | |||
| @@ -85,18 +85,28 @@ iop_adma_run_tx_complete_actions(struct iop_adma_desc_slot *desc, | |||
| 85 | enum dma_ctrl_flags flags = desc->async_tx.flags; | 85 | enum dma_ctrl_flags flags = desc->async_tx.flags; |
| 86 | u32 src_cnt; | 86 | u32 src_cnt; |
| 87 | dma_addr_t addr; | 87 | dma_addr_t addr; |
| 88 | dma_addr_t dest; | ||
| 88 | 89 | ||
| 90 | src_cnt = unmap->unmap_src_cnt; | ||
| 91 | dest = iop_desc_get_dest_addr(unmap, iop_chan); | ||
| 89 | if (!(flags & DMA_COMPL_SKIP_DEST_UNMAP)) { | 92 | if (!(flags & DMA_COMPL_SKIP_DEST_UNMAP)) { |
| 90 | addr = iop_desc_get_dest_addr(unmap, iop_chan); | 93 | enum dma_data_direction dir; |
| 91 | dma_unmap_page(dev, addr, len, DMA_FROM_DEVICE); | 94 | |
| 95 | if (src_cnt > 1) /* is xor? */ | ||
| 96 | dir = DMA_BIDIRECTIONAL; | ||
| 97 | else | ||
| 98 | dir = DMA_FROM_DEVICE; | ||
| 99 | |||
| 100 | dma_unmap_page(dev, dest, len, dir); | ||
| 92 | } | 101 | } |
| 93 | 102 | ||
| 94 | if (!(flags & DMA_COMPL_SKIP_SRC_UNMAP)) { | 103 | if (!(flags & DMA_COMPL_SKIP_SRC_UNMAP)) { |
| 95 | src_cnt = unmap->unmap_src_cnt; | ||
| 96 | while (src_cnt--) { | 104 | while (src_cnt--) { |
| 97 | addr = iop_desc_get_src_addr(unmap, | 105 | addr = iop_desc_get_src_addr(unmap, |
| 98 | iop_chan, | 106 | iop_chan, |
| 99 | src_cnt); | 107 | src_cnt); |
| 108 | if (addr == dest) | ||
| 109 | continue; | ||
| 100 | dma_unmap_page(dev, addr, len, | 110 | dma_unmap_page(dev, addr, len, |
| 101 | DMA_TO_DEVICE); | 111 | DMA_TO_DEVICE); |
| 102 | } | 112 | } |
diff --git a/drivers/dma/mv_xor.c b/drivers/dma/mv_xor.c index 0328da020a10..bcda17426411 100644 --- a/drivers/dma/mv_xor.c +++ b/drivers/dma/mv_xor.c | |||
| @@ -311,17 +311,26 @@ mv_xor_run_tx_complete_actions(struct mv_xor_desc_slot *desc, | |||
| 311 | enum dma_ctrl_flags flags = desc->async_tx.flags; | 311 | enum dma_ctrl_flags flags = desc->async_tx.flags; |
| 312 | u32 src_cnt; | 312 | u32 src_cnt; |
| 313 | dma_addr_t addr; | 313 | dma_addr_t addr; |
| 314 | dma_addr_t dest; | ||
| 314 | 315 | ||
| 316 | src_cnt = unmap->unmap_src_cnt; | ||
| 317 | dest = mv_desc_get_dest_addr(unmap); | ||
| 315 | if (!(flags & DMA_COMPL_SKIP_DEST_UNMAP)) { | 318 | if (!(flags & DMA_COMPL_SKIP_DEST_UNMAP)) { |
| 316 | addr = mv_desc_get_dest_addr(unmap); | 319 | enum dma_data_direction dir; |
| 317 | dma_unmap_page(dev, addr, len, DMA_FROM_DEVICE); | 320 | |
| 321 | if (src_cnt > 1) /* is xor ? */ | ||
| 322 | dir = DMA_BIDIRECTIONAL; | ||
| 323 | else | ||
| 324 | dir = DMA_FROM_DEVICE; | ||
| 325 | dma_unmap_page(dev, dest, len, dir); | ||
| 318 | } | 326 | } |
| 319 | 327 | ||
| 320 | if (!(flags & DMA_COMPL_SKIP_SRC_UNMAP)) { | 328 | if (!(flags & DMA_COMPL_SKIP_SRC_UNMAP)) { |
| 321 | src_cnt = unmap->unmap_src_cnt; | ||
| 322 | while (src_cnt--) { | 329 | while (src_cnt--) { |
| 323 | addr = mv_desc_get_src_addr(unmap, | 330 | addr = mv_desc_get_src_addr(unmap, |
| 324 | src_cnt); | 331 | src_cnt); |
| 332 | if (addr == dest) | ||
| 333 | continue; | ||
| 325 | dma_unmap_page(dev, addr, len, | 334 | dma_unmap_page(dev, addr, len, |
| 326 | DMA_TO_DEVICE); | 335 | DMA_TO_DEVICE); |
| 327 | } | 336 | } |
diff --git a/drivers/edac/edac_device.c b/drivers/edac/edac_device.c index 5fcd3d89c75d..4041e9143283 100644 --- a/drivers/edac/edac_device.c +++ b/drivers/edac/edac_device.c | |||
| @@ -394,6 +394,12 @@ static void edac_device_workq_function(struct work_struct *work_req) | |||
| 394 | 394 | ||
| 395 | mutex_lock(&device_ctls_mutex); | 395 | mutex_lock(&device_ctls_mutex); |
| 396 | 396 | ||
| 397 | /* If we are being removed, bail out immediately */ | ||
| 398 | if (edac_dev->op_state == OP_OFFLINE) { | ||
| 399 | mutex_unlock(&device_ctls_mutex); | ||
| 400 | return; | ||
| 401 | } | ||
| 402 | |||
| 397 | /* Only poll controllers that are running polled and have a check */ | 403 | /* Only poll controllers that are running polled and have a check */ |
| 398 | if ((edac_dev->op_state == OP_RUNNING_POLL) && | 404 | if ((edac_dev->op_state == OP_RUNNING_POLL) && |
| 399 | (edac_dev->edac_check != NULL)) { | 405 | (edac_dev->edac_check != NULL)) { |
| @@ -585,14 +591,14 @@ struct edac_device_ctl_info *edac_device_del_device(struct device *dev) | |||
| 585 | /* mark this instance as OFFLINE */ | 591 | /* mark this instance as OFFLINE */ |
| 586 | edac_dev->op_state = OP_OFFLINE; | 592 | edac_dev->op_state = OP_OFFLINE; |
| 587 | 593 | ||
| 588 | /* clear workq processing on this instance */ | ||
| 589 | edac_device_workq_teardown(edac_dev); | ||
| 590 | |||
| 591 | /* deregister from global list */ | 594 | /* deregister from global list */ |
| 592 | del_edac_device_from_global_list(edac_dev); | 595 | del_edac_device_from_global_list(edac_dev); |
| 593 | 596 | ||
| 594 | mutex_unlock(&device_ctls_mutex); | 597 | mutex_unlock(&device_ctls_mutex); |
| 595 | 598 | ||
| 599 | /* clear workq processing on this instance */ | ||
| 600 | edac_device_workq_teardown(edac_dev); | ||
| 601 | |||
| 596 | /* Tear down the sysfs entries for this instance */ | 602 | /* Tear down the sysfs entries for this instance */ |
| 597 | edac_device_remove_sysfs(edac_dev); | 603 | edac_device_remove_sysfs(edac_dev); |
| 598 | 604 | ||
diff --git a/drivers/gpu/drm/i915/i915_dma.c b/drivers/gpu/drm/i915/i915_dma.c index 553dd4bc3075..afa8a12cd009 100644 --- a/drivers/gpu/drm/i915/i915_dma.c +++ b/drivers/gpu/drm/i915/i915_dma.c | |||
| @@ -717,7 +717,7 @@ static int i915_getparam(struct drm_device *dev, void *data, | |||
| 717 | value = dev->pci_device; | 717 | value = dev->pci_device; |
| 718 | break; | 718 | break; |
| 719 | case I915_PARAM_HAS_GEM: | 719 | case I915_PARAM_HAS_GEM: |
| 720 | value = 1; | 720 | value = dev_priv->has_gem; |
| 721 | break; | 721 | break; |
| 722 | default: | 722 | default: |
| 723 | DRM_ERROR("Unknown parameter %d\n", param->param); | 723 | DRM_ERROR("Unknown parameter %d\n", param->param); |
| @@ -830,6 +830,14 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags) | |||
| 830 | 830 | ||
| 831 | dev_priv->regs = ioremap(base, size); | 831 | dev_priv->regs = ioremap(base, size); |
| 832 | 832 | ||
| 833 | #ifdef CONFIG_HIGHMEM64G | ||
| 834 | /* don't enable GEM on PAE - needs agp + set_memory_* interface fixes */ | ||
| 835 | dev_priv->has_gem = 0; | ||
| 836 | #else | ||
| 837 | /* enable GEM by default */ | ||
| 838 | dev_priv->has_gem = 1; | ||
| 839 | #endif | ||
| 840 | |||
| 833 | i915_gem_load(dev); | 841 | i915_gem_load(dev); |
| 834 | 842 | ||
| 835 | /* Init HWS */ | 843 | /* Init HWS */ |
diff --git a/drivers/gpu/drm/i915/i915_drv.h b/drivers/gpu/drm/i915/i915_drv.h index adc972cc6bfc..b3cc4731aa7c 100644 --- a/drivers/gpu/drm/i915/i915_drv.h +++ b/drivers/gpu/drm/i915/i915_drv.h | |||
| @@ -106,6 +106,8 @@ struct intel_opregion { | |||
| 106 | typedef struct drm_i915_private { | 106 | typedef struct drm_i915_private { |
| 107 | struct drm_device *dev; | 107 | struct drm_device *dev; |
| 108 | 108 | ||
| 109 | int has_gem; | ||
| 110 | |||
| 109 | void __iomem *regs; | 111 | void __iomem *regs; |
| 110 | drm_local_map_t *sarea; | 112 | drm_local_map_t *sarea; |
| 111 | 113 | ||
diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c index ad672d854828..24fe8c10b4b2 100644 --- a/drivers/gpu/drm/i915/i915_gem.c +++ b/drivers/gpu/drm/i915/i915_gem.c | |||
| @@ -2309,7 +2309,14 @@ i915_gem_busy_ioctl(struct drm_device *dev, void *data, | |||
| 2309 | } | 2309 | } |
| 2310 | 2310 | ||
| 2311 | obj_priv = obj->driver_private; | 2311 | obj_priv = obj->driver_private; |
| 2312 | args->busy = obj_priv->active; | 2312 | /* Don't count being on the flushing list against the object being |
| 2313 | * done. Otherwise, a buffer left on the flushing list but not getting | ||
| 2314 | * flushed (because nobody's flushing that domain) won't ever return | ||
| 2315 | * unbusy and get reused by libdrm's bo cache. The other expected | ||
| 2316 | * consumer of this interface, OpenGL's occlusion queries, also specs | ||
| 2317 | * that the objects get unbusy "eventually" without any interference. | ||
| 2318 | */ | ||
| 2319 | args->busy = obj_priv->active && obj_priv->last_rendering_seqno != 0; | ||
| 2313 | 2320 | ||
| 2314 | drm_gem_object_unreference(obj); | 2321 | drm_gem_object_unreference(obj); |
| 2315 | mutex_unlock(&dev->struct_mutex); | 2322 | mutex_unlock(&dev->struct_mutex); |
diff --git a/drivers/gpu/drm/radeon/radeon_irq.c b/drivers/gpu/drm/radeon/radeon_irq.c index 99be11418ac2..8289e16419a8 100644 --- a/drivers/gpu/drm/radeon/radeon_irq.c +++ b/drivers/gpu/drm/radeon/radeon_irq.c | |||
| @@ -44,7 +44,7 @@ void radeon_irq_set_state(struct drm_device *dev, u32 mask, int state) | |||
| 44 | else | 44 | else |
| 45 | dev_priv->irq_enable_reg &= ~mask; | 45 | dev_priv->irq_enable_reg &= ~mask; |
| 46 | 46 | ||
| 47 | if (!dev->irq_enabled) | 47 | if (dev->irq_enabled) |
| 48 | RADEON_WRITE(RADEON_GEN_INT_CNTL, dev_priv->irq_enable_reg); | 48 | RADEON_WRITE(RADEON_GEN_INT_CNTL, dev_priv->irq_enable_reg); |
| 49 | } | 49 | } |
| 50 | 50 | ||
| @@ -57,7 +57,7 @@ static void r500_vbl_irq_set_state(struct drm_device *dev, u32 mask, int state) | |||
| 57 | else | 57 | else |
| 58 | dev_priv->r500_disp_irq_reg &= ~mask; | 58 | dev_priv->r500_disp_irq_reg &= ~mask; |
| 59 | 59 | ||
| 60 | if (!dev->irq_enabled) | 60 | if (dev->irq_enabled) |
| 61 | RADEON_WRITE(R500_DxMODE_INT_MASK, dev_priv->r500_disp_irq_reg); | 61 | RADEON_WRITE(R500_DxMODE_INT_MASK, dev_priv->r500_disp_irq_reg); |
| 62 | } | 62 | } |
| 63 | 63 | ||
diff --git a/drivers/ide/cs5530.c b/drivers/ide/cs5530.c index 53f079cc00af..d8ede85fe17f 100644 --- a/drivers/ide/cs5530.c +++ b/drivers/ide/cs5530.c | |||
| @@ -81,11 +81,12 @@ static u8 cs5530_udma_filter(ide_drive_t *drive) | |||
| 81 | { | 81 | { |
| 82 | ide_hwif_t *hwif = drive->hwif; | 82 | ide_hwif_t *hwif = drive->hwif; |
| 83 | ide_drive_t *mate = ide_get_pair_dev(drive); | 83 | ide_drive_t *mate = ide_get_pair_dev(drive); |
| 84 | u16 *mateid = mate->id; | 84 | u16 *mateid; |
| 85 | u8 mask = hwif->ultra_mask; | 85 | u8 mask = hwif->ultra_mask; |
| 86 | 86 | ||
| 87 | if (mate == NULL) | 87 | if (mate == NULL) |
| 88 | goto out; | 88 | goto out; |
| 89 | mateid = mate->id; | ||
| 89 | 90 | ||
| 90 | if (ata_id_has_dma(mateid) && __ide_dma_bad_drive(mate) == 0) { | 91 | if (ata_id_has_dma(mateid) && __ide_dma_bad_drive(mate) == 0) { |
| 91 | if ((mateid[ATA_ID_FIELD_VALID] & 4) && | 92 | if ((mateid[ATA_ID_FIELD_VALID] & 4) && |
diff --git a/drivers/ide/sc1200.c b/drivers/ide/sc1200.c index f1a8758e3a99..ec7f766ef5e4 100644 --- a/drivers/ide/sc1200.c +++ b/drivers/ide/sc1200.c | |||
| @@ -104,11 +104,12 @@ static u8 sc1200_udma_filter(ide_drive_t *drive) | |||
| 104 | { | 104 | { |
| 105 | ide_hwif_t *hwif = drive->hwif; | 105 | ide_hwif_t *hwif = drive->hwif; |
| 106 | ide_drive_t *mate = ide_get_pair_dev(drive); | 106 | ide_drive_t *mate = ide_get_pair_dev(drive); |
| 107 | u16 *mateid = mate->id; | 107 | u16 *mateid; |
| 108 | u8 mask = hwif->ultra_mask; | 108 | u8 mask = hwif->ultra_mask; |
| 109 | 109 | ||
| 110 | if (mate == NULL) | 110 | if (mate == NULL) |
| 111 | goto out; | 111 | goto out; |
| 112 | mateid = mate->id; | ||
| 112 | 113 | ||
| 113 | if (ata_id_has_dma(mateid) && __ide_dma_bad_drive(mate) == 0) { | 114 | if (ata_id_has_dma(mateid) && __ide_dma_bad_drive(mate) == 0) { |
| 114 | if ((mateid[ATA_ID_FIELD_VALID] & 4) && | 115 | if ((mateid[ATA_ID_FIELD_VALID] & 4) && |
diff --git a/drivers/md/bitmap.c b/drivers/md/bitmap.c index ac89a5deaca2..ab7c8e4a61f9 100644 --- a/drivers/md/bitmap.c +++ b/drivers/md/bitmap.c | |||
| @@ -208,16 +208,19 @@ static void bitmap_checkfree(struct bitmap *bitmap, unsigned long page) | |||
| 208 | */ | 208 | */ |
| 209 | 209 | ||
| 210 | /* IO operations when bitmap is stored near all superblocks */ | 210 | /* IO operations when bitmap is stored near all superblocks */ |
| 211 | static struct page *read_sb_page(mddev_t *mddev, long offset, unsigned long index) | 211 | static struct page *read_sb_page(mddev_t *mddev, long offset, |
| 212 | struct page *page, | ||
| 213 | unsigned long index, int size) | ||
| 212 | { | 214 | { |
| 213 | /* choose a good rdev and read the page from there */ | 215 | /* choose a good rdev and read the page from there */ |
| 214 | 216 | ||
| 215 | mdk_rdev_t *rdev; | 217 | mdk_rdev_t *rdev; |
| 216 | struct list_head *tmp; | 218 | struct list_head *tmp; |
| 217 | struct page *page = alloc_page(GFP_KERNEL); | ||
| 218 | sector_t target; | 219 | sector_t target; |
| 219 | 220 | ||
| 220 | if (!page) | 221 | if (!page) |
| 222 | page = alloc_page(GFP_KERNEL); | ||
| 223 | if (!page) | ||
| 221 | return ERR_PTR(-ENOMEM); | 224 | return ERR_PTR(-ENOMEM); |
| 222 | 225 | ||
| 223 | rdev_for_each(rdev, tmp, mddev) { | 226 | rdev_for_each(rdev, tmp, mddev) { |
| @@ -227,7 +230,9 @@ static struct page *read_sb_page(mddev_t *mddev, long offset, unsigned long inde | |||
| 227 | 230 | ||
| 228 | target = rdev->sb_start + offset + index * (PAGE_SIZE/512); | 231 | target = rdev->sb_start + offset + index * (PAGE_SIZE/512); |
| 229 | 232 | ||
| 230 | if (sync_page_io(rdev->bdev, target, PAGE_SIZE, page, READ)) { | 233 | if (sync_page_io(rdev->bdev, target, |
| 234 | roundup(size, bdev_hardsect_size(rdev->bdev)), | ||
| 235 | page, READ)) { | ||
| 231 | page->index = index; | 236 | page->index = index; |
| 232 | attach_page_buffers(page, NULL); /* so that free_buffer will | 237 | attach_page_buffers(page, NULL); /* so that free_buffer will |
| 233 | * quietly no-op */ | 238 | * quietly no-op */ |
| @@ -544,7 +549,9 @@ static int bitmap_read_sb(struct bitmap *bitmap) | |||
| 544 | 549 | ||
| 545 | bitmap->sb_page = read_page(bitmap->file, 0, bitmap, bytes); | 550 | bitmap->sb_page = read_page(bitmap->file, 0, bitmap, bytes); |
| 546 | } else { | 551 | } else { |
| 547 | bitmap->sb_page = read_sb_page(bitmap->mddev, bitmap->offset, 0); | 552 | bitmap->sb_page = read_sb_page(bitmap->mddev, bitmap->offset, |
| 553 | NULL, | ||
| 554 | 0, sizeof(bitmap_super_t)); | ||
| 548 | } | 555 | } |
| 549 | if (IS_ERR(bitmap->sb_page)) { | 556 | if (IS_ERR(bitmap->sb_page)) { |
| 550 | err = PTR_ERR(bitmap->sb_page); | 557 | err = PTR_ERR(bitmap->sb_page); |
| @@ -957,11 +964,16 @@ static int bitmap_init_from_disk(struct bitmap *bitmap, sector_t start) | |||
| 957 | */ | 964 | */ |
| 958 | page = bitmap->sb_page; | 965 | page = bitmap->sb_page; |
| 959 | offset = sizeof(bitmap_super_t); | 966 | offset = sizeof(bitmap_super_t); |
| 967 | read_sb_page(bitmap->mddev, bitmap->offset, | ||
| 968 | page, | ||
| 969 | index, count); | ||
| 960 | } else if (file) { | 970 | } else if (file) { |
| 961 | page = read_page(file, index, bitmap, count); | 971 | page = read_page(file, index, bitmap, count); |
| 962 | offset = 0; | 972 | offset = 0; |
| 963 | } else { | 973 | } else { |
| 964 | page = read_sb_page(bitmap->mddev, bitmap->offset, index); | 974 | page = read_sb_page(bitmap->mddev, bitmap->offset, |
| 975 | NULL, | ||
| 976 | index, count); | ||
| 965 | offset = 0; | 977 | offset = 0; |
| 966 | } | 978 | } |
| 967 | if (IS_ERR(page)) { /* read error */ | 979 | if (IS_ERR(page)) { /* read error */ |
diff --git a/drivers/media/dvb/b2c2/Kconfig b/drivers/media/dvb/b2c2/Kconfig index 73dc2ee9b014..b34301d56cd2 100644 --- a/drivers/media/dvb/b2c2/Kconfig +++ b/drivers/media/dvb/b2c2/Kconfig | |||
| @@ -9,11 +9,11 @@ config DVB_B2C2_FLEXCOP | |||
| 9 | select DVB_STV0297 if !DVB_FE_CUSTOMISE | 9 | select DVB_STV0297 if !DVB_FE_CUSTOMISE |
| 10 | select DVB_BCM3510 if !DVB_FE_CUSTOMISE | 10 | select DVB_BCM3510 if !DVB_FE_CUSTOMISE |
| 11 | select DVB_LGDT330X if !DVB_FE_CUSTOMISE | 11 | select DVB_LGDT330X if !DVB_FE_CUSTOMISE |
| 12 | select MEDIA_TUNER_SIMPLE if !DVB_FE_CUSTOMISE | ||
| 13 | select DVB_S5H1420 if !DVB_FE_CUSTOMISE | 12 | select DVB_S5H1420 if !DVB_FE_CUSTOMISE |
| 14 | select DVB_TUNER_ITD1000 if !DVB_FE_CUSTOMISE | 13 | select DVB_TUNER_ITD1000 if !DVB_FE_CUSTOMISE |
| 15 | select DVB_ISL6421 if !DVB_FE_CUSTOMISE | 14 | select DVB_ISL6421 if !DVB_FE_CUSTOMISE |
| 16 | select DVB_CX24123 if !DVB_FE_CUSTOMISE | 15 | select DVB_CX24123 if !DVB_FE_CUSTOMISE |
| 16 | select MEDIA_TUNER_SIMPLE if !MEDIA_TUNER_CUSTOMIZE | ||
| 17 | help | 17 | help |
| 18 | Support for the digital TV receiver chip made by B2C2 Inc. included in | 18 | Support for the digital TV receiver chip made by B2C2 Inc. included in |
| 19 | Technisats PCI cards and USB boxes. | 19 | Technisats PCI cards and USB boxes. |
diff --git a/drivers/media/dvb/b2c2/flexcop-fe-tuner.c b/drivers/media/dvb/b2c2/flexcop-fe-tuner.c index a127a4175c40..5cded3708541 100644 --- a/drivers/media/dvb/b2c2/flexcop-fe-tuner.c +++ b/drivers/media/dvb/b2c2/flexcop-fe-tuner.c | |||
| @@ -628,12 +628,14 @@ int flexcop_frontend_init(struct flexcop_device *fc) | |||
| 628 | } | 628 | } |
| 629 | 629 | ||
| 630 | /* try the cable dvb (stv0297) */ | 630 | /* try the cable dvb (stv0297) */ |
| 631 | fc->fc_i2c_adap[0].no_base_addr = 1; | ||
| 631 | fc->fe = dvb_attach(stv0297_attach, &alps_tdee4_stv0297_config, i2c); | 632 | fc->fe = dvb_attach(stv0297_attach, &alps_tdee4_stv0297_config, i2c); |
| 632 | if (fc->fe != NULL) { | 633 | if (fc->fe != NULL) { |
| 633 | fc->dev_type = FC_CABLE; | 634 | fc->dev_type = FC_CABLE; |
| 634 | fc->fe->ops.tuner_ops.set_params = alps_tdee4_stv0297_tuner_set_params; | 635 | fc->fe->ops.tuner_ops.set_params = alps_tdee4_stv0297_tuner_set_params; |
| 635 | goto fe_found; | 636 | goto fe_found; |
| 636 | } | 637 | } |
| 638 | fc->fc_i2c_adap[0].no_base_addr = 0; | ||
| 637 | 639 | ||
| 638 | /* try the sky v2.3 (vp310/Samsung tbdu18132(tsa5059)) */ | 640 | /* try the sky v2.3 (vp310/Samsung tbdu18132(tsa5059)) */ |
| 639 | fc->fe = dvb_attach(mt312_attach, | 641 | fc->fe = dvb_attach(mt312_attach, |
diff --git a/drivers/media/dvb/b2c2/flexcop-i2c.c b/drivers/media/dvb/b2c2/flexcop-i2c.c index 43a112ec6d44..f13783f08f0f 100644 --- a/drivers/media/dvb/b2c2/flexcop-i2c.c +++ b/drivers/media/dvb/b2c2/flexcop-i2c.c | |||
| @@ -47,9 +47,13 @@ static int flexcop_i2c_read4(struct flexcop_i2c_adapter *i2c, | |||
| 47 | int len = r100.tw_sm_c_100.total_bytes, /* remember total_bytes is buflen-1 */ | 47 | int len = r100.tw_sm_c_100.total_bytes, /* remember total_bytes is buflen-1 */ |
| 48 | ret; | 48 | ret; |
| 49 | 49 | ||
| 50 | r100.tw_sm_c_100.no_base_addr_ack_error = i2c->no_base_addr; | ||
| 51 | ret = flexcop_i2c_operation(i2c->fc, &r100); | 50 | ret = flexcop_i2c_operation(i2c->fc, &r100); |
| 52 | if (ret != 0) { | 51 | if (ret != 0) { |
| 52 | deb_i2c("Retrying operation\n"); | ||
| 53 | r100.tw_sm_c_100.no_base_addr_ack_error = i2c->no_base_addr; | ||
| 54 | ret = flexcop_i2c_operation(i2c->fc, &r100); | ||
| 55 | } | ||
| 56 | if (ret != 0) { | ||
| 53 | deb_i2c("read failed. %d\n", ret); | 57 | deb_i2c("read failed. %d\n", ret); |
| 54 | return ret; | 58 | return ret; |
| 55 | } | 59 | } |
diff --git a/drivers/media/dvb/bt8xx/Kconfig b/drivers/media/dvb/bt8xx/Kconfig index 7e9c090fc04e..27edb0ece587 100644 --- a/drivers/media/dvb/bt8xx/Kconfig +++ b/drivers/media/dvb/bt8xx/Kconfig | |||
| @@ -8,7 +8,7 @@ config DVB_BT8XX | |||
| 8 | select DVB_OR51211 if !DVB_FE_CUSTOMISE | 8 | select DVB_OR51211 if !DVB_FE_CUSTOMISE |
| 9 | select DVB_LGDT330X if !DVB_FE_CUSTOMISE | 9 | select DVB_LGDT330X if !DVB_FE_CUSTOMISE |
| 10 | select DVB_ZL10353 if !DVB_FE_CUSTOMISE | 10 | select DVB_ZL10353 if !DVB_FE_CUSTOMISE |
| 11 | select MEDIA_TUNER_SIMPLE if !DVB_FE_CUSTOMISE | 11 | select MEDIA_TUNER_SIMPLE if !MEDIA_TUNER_CUSTOMIZE |
| 12 | help | 12 | help |
| 13 | Support for PCI cards based on the Bt8xx PCI bridge. Examples are | 13 | Support for PCI cards based on the Bt8xx PCI bridge. Examples are |
| 14 | the Nebula cards, the Pinnacle PCTV cards, the Twinhan DST cards, | 14 | the Nebula cards, the Pinnacle PCTV cards, the Twinhan DST cards, |
diff --git a/drivers/media/dvb/dvb-usb/Kconfig b/drivers/media/dvb/dvb-usb/Kconfig index 62b68c291d99..49f7b20c25d6 100644 --- a/drivers/media/dvb/dvb-usb/Kconfig +++ b/drivers/media/dvb/dvb-usb/Kconfig | |||
| @@ -24,8 +24,8 @@ config DVB_USB_A800 | |||
| 24 | tristate "AVerMedia AverTV DVB-T USB 2.0 (A800)" | 24 | tristate "AVerMedia AverTV DVB-T USB 2.0 (A800)" |
| 25 | depends on DVB_USB | 25 | depends on DVB_USB |
| 26 | select DVB_DIB3000MC | 26 | select DVB_DIB3000MC |
| 27 | select MEDIA_TUNER_MT2060 if !DVB_FE_CUSTOMISE | ||
| 28 | select DVB_PLL if !DVB_FE_CUSTOMISE | 27 | select DVB_PLL if !DVB_FE_CUSTOMISE |
| 28 | select MEDIA_TUNER_MT2060 if !MEDIA_TUNER_CUSTOMIZE | ||
| 29 | help | 29 | help |
| 30 | Say Y here to support the AVerMedia AverTV DVB-T USB 2.0 (A800) receiver. | 30 | Say Y here to support the AVerMedia AverTV DVB-T USB 2.0 (A800) receiver. |
| 31 | 31 | ||
| @@ -34,7 +34,7 @@ config DVB_USB_DIBUSB_MB | |||
| 34 | depends on DVB_USB | 34 | depends on DVB_USB |
| 35 | select DVB_PLL if !DVB_FE_CUSTOMISE | 35 | select DVB_PLL if !DVB_FE_CUSTOMISE |
| 36 | select DVB_DIB3000MB | 36 | select DVB_DIB3000MB |
| 37 | select MEDIA_TUNER_MT2060 if !DVB_FE_CUSTOMISE | 37 | select MEDIA_TUNER_MT2060 if !MEDIA_TUNER_CUSTOMIZE |
| 38 | help | 38 | help |
| 39 | Support for USB 1.1 and 2.0 DVB-T receivers based on reference designs made by | 39 | Support for USB 1.1 and 2.0 DVB-T receivers based on reference designs made by |
| 40 | DiBcom (<http://www.dibcom.fr>) equipped with a DiB3000M-B demodulator. | 40 | DiBcom (<http://www.dibcom.fr>) equipped with a DiB3000M-B demodulator. |
| @@ -55,7 +55,7 @@ config DVB_USB_DIBUSB_MC | |||
| 55 | tristate "DiBcom USB DVB-T devices (based on the DiB3000M-C/P) (see help for device list)" | 55 | tristate "DiBcom USB DVB-T devices (based on the DiB3000M-C/P) (see help for device list)" |
| 56 | depends on DVB_USB | 56 | depends on DVB_USB |
| 57 | select DVB_DIB3000MC | 57 | select DVB_DIB3000MC |
| 58 | select MEDIA_TUNER_MT2060 if !DVB_FE_CUSTOMISE | 58 | select MEDIA_TUNER_MT2060 if !MEDIA_TUNER_CUSTOMIZE |
| 59 | help | 59 | help |
| 60 | Support for USB2.0 DVB-T receivers based on reference designs made by | 60 | Support for USB2.0 DVB-T receivers based on reference designs made by |
| 61 | DiBcom (<http://www.dibcom.fr>) equipped with a DiB3000M-C/P demodulator. | 61 | DiBcom (<http://www.dibcom.fr>) equipped with a DiB3000M-C/P demodulator. |
| @@ -73,11 +73,11 @@ config DVB_USB_DIB0700 | |||
| 73 | select DVB_DIB7000M | 73 | select DVB_DIB7000M |
| 74 | select DVB_DIB3000MC | 74 | select DVB_DIB3000MC |
| 75 | select DVB_S5H1411 if !DVB_FE_CUSTOMISE | 75 | select DVB_S5H1411 if !DVB_FE_CUSTOMISE |
| 76 | select MEDIA_TUNER_MT2060 if !DVB_FE_CUSTOMISE | ||
| 77 | select MEDIA_TUNER_MT2266 if !DVB_FE_CUSTOMISE | ||
| 78 | select MEDIA_TUNER_XC2028 if !DVB_FE_CUSTOMISE | ||
| 79 | select MEDIA_TUNER_XC5000 if !DVB_FE_CUSTOMIZE | ||
| 80 | select DVB_TUNER_DIB0070 | 76 | select DVB_TUNER_DIB0070 |
| 77 | select MEDIA_TUNER_MT2060 if !MEDIA_TUNER_CUSTOMIZE | ||
| 78 | select MEDIA_TUNER_MT2266 if !MEDIA_TUNER_CUSTOMIZE | ||
| 79 | select MEDIA_TUNER_XC2028 if !MEDIA_TUNER_CUSTOMIZE | ||
| 80 | select MEDIA_TUNER_XC5000 if !MEDIA_TUNER_CUSTOMIZE | ||
| 81 | help | 81 | help |
| 82 | Support for USB2.0/1.1 DVB receivers based on the DiB0700 USB bridge. The | 82 | Support for USB2.0/1.1 DVB receivers based on the DiB0700 USB bridge. The |
| 83 | USB bridge is also present in devices having the DiB7700 DVB-T-USB | 83 | USB bridge is also present in devices having the DiB7700 DVB-T-USB |
| @@ -95,7 +95,7 @@ config DVB_USB_UMT_010 | |||
| 95 | depends on DVB_USB | 95 | depends on DVB_USB |
| 96 | select DVB_PLL if !DVB_FE_CUSTOMISE | 96 | select DVB_PLL if !DVB_FE_CUSTOMISE |
| 97 | select DVB_DIB3000MC | 97 | select DVB_DIB3000MC |
| 98 | select MEDIA_TUNER_MT2060 if !DVB_FE_CUSTOMISE | 98 | select MEDIA_TUNER_MT2060 if !MEDIA_TUNER_CUSTOMIZE |
| 99 | help | 99 | help |
| 100 | Say Y here to support the HanfTek UMT-010 USB2.0 stick-sized DVB-T receiver. | 100 | Say Y here to support the HanfTek UMT-010 USB2.0 stick-sized DVB-T receiver. |
| 101 | 101 | ||
| @@ -107,11 +107,11 @@ config DVB_USB_CXUSB | |||
| 107 | select DVB_LGDT330X if !DVB_FE_CUSTOMISE | 107 | select DVB_LGDT330X if !DVB_FE_CUSTOMISE |
| 108 | select DVB_MT352 if !DVB_FE_CUSTOMISE | 108 | select DVB_MT352 if !DVB_FE_CUSTOMISE |
| 109 | select DVB_ZL10353 if !DVB_FE_CUSTOMISE | 109 | select DVB_ZL10353 if !DVB_FE_CUSTOMISE |
| 110 | select MEDIA_TUNER_SIMPLE if !DVB_FE_CUSTOMISE | ||
| 111 | select MEDIA_TUNER_XC2028 if !DVB_FE_CUSTOMISE | ||
| 112 | select MEDIA_TUNER_MXL5005S if !DVB_FE_CUSTOMISE | ||
| 113 | select DVB_DIB7000P if !DVB_FE_CUSTOMISE | 110 | select DVB_DIB7000P if !DVB_FE_CUSTOMISE |
| 114 | select DVB_TUNER_DIB0070 if !DVB_FE_CUSTOMISE | 111 | select DVB_TUNER_DIB0070 if !DVB_FE_CUSTOMISE |
| 112 | select MEDIA_TUNER_SIMPLE if !MEDIA_TUNER_CUSTOMIZE | ||
| 113 | select MEDIA_TUNER_XC2028 if !MEDIA_TUNER_CUSTOMIZE | ||
| 114 | select MEDIA_TUNER_MXL5005S if !MEDIA_TUNER_CUSTOMIZE | ||
| 115 | help | 115 | help |
| 116 | Say Y here to support the Conexant USB2.0 hybrid reference design. | 116 | Say Y here to support the Conexant USB2.0 hybrid reference design. |
| 117 | Currently, only DVB and ATSC modes are supported, analog mode | 117 | Currently, only DVB and ATSC modes are supported, analog mode |
| @@ -124,9 +124,9 @@ config DVB_USB_M920X | |||
| 124 | tristate "Uli m920x DVB-T USB2.0 support" | 124 | tristate "Uli m920x DVB-T USB2.0 support" |
| 125 | depends on DVB_USB | 125 | depends on DVB_USB |
| 126 | select DVB_MT352 if !DVB_FE_CUSTOMISE | 126 | select DVB_MT352 if !DVB_FE_CUSTOMISE |
| 127 | select MEDIA_TUNER_QT1010 if !DVB_FE_CUSTOMISE | ||
| 128 | select MEDIA_TUNER_TDA827X if !DVB_FE_CUSTOMISE | ||
| 129 | select DVB_TDA1004X if !DVB_FE_CUSTOMISE | 127 | select DVB_TDA1004X if !DVB_FE_CUSTOMISE |
| 128 | select MEDIA_TUNER_QT1010 if !MEDIA_TUNER_CUSTOMIZE | ||
| 129 | select MEDIA_TUNER_TDA827X if !MEDIA_TUNER_CUSTOMIZE | ||
| 130 | help | 130 | help |
| 131 | Say Y here to support the MSI Mega Sky 580 USB2.0 DVB-T receiver. | 131 | Say Y here to support the MSI Mega Sky 580 USB2.0 DVB-T receiver. |
| 132 | Currently, only devices with a product id of | 132 | Currently, only devices with a product id of |
| @@ -137,7 +137,7 @@ config DVB_USB_GL861 | |||
| 137 | tristate "Genesys Logic GL861 USB2.0 support" | 137 | tristate "Genesys Logic GL861 USB2.0 support" |
| 138 | depends on DVB_USB | 138 | depends on DVB_USB |
| 139 | select DVB_ZL10353 if !DVB_FE_CUSTOMISE | 139 | select DVB_ZL10353 if !DVB_FE_CUSTOMISE |
| 140 | select MEDIA_TUNER_QT1010 if !DVB_FE_CUSTOMISE | 140 | select MEDIA_TUNER_QT1010 if !MEDIA_TUNER_CUSTOMIZE |
| 141 | help | 141 | help |
| 142 | Say Y here to support the MSI Megasky 580 (55801) DVB-T USB2.0 | 142 | Say Y here to support the MSI Megasky 580 (55801) DVB-T USB2.0 |
| 143 | receiver with USB ID 0db0:5581. | 143 | receiver with USB ID 0db0:5581. |
| @@ -146,7 +146,7 @@ config DVB_USB_AU6610 | |||
| 146 | tristate "Alcor Micro AU6610 USB2.0 support" | 146 | tristate "Alcor Micro AU6610 USB2.0 support" |
| 147 | depends on DVB_USB | 147 | depends on DVB_USB |
| 148 | select DVB_ZL10353 if !DVB_FE_CUSTOMISE | 148 | select DVB_ZL10353 if !DVB_FE_CUSTOMISE |
| 149 | select MEDIA_TUNER_QT1010 if !DVB_FE_CUSTOMISE | 149 | select MEDIA_TUNER_QT1010 if !MEDIA_TUNER_CUSTOMIZE |
| 150 | help | 150 | help |
| 151 | Say Y here to support the Sigmatek DVB-110 DVB-T USB2.0 receiver. | 151 | Say Y here to support the Sigmatek DVB-110 DVB-T USB2.0 receiver. |
| 152 | 152 | ||
| @@ -198,8 +198,8 @@ config DVB_USB_NOVA_T_USB2 | |||
| 198 | tristate "Hauppauge WinTV-NOVA-T usb2 DVB-T USB2.0 support" | 198 | tristate "Hauppauge WinTV-NOVA-T usb2 DVB-T USB2.0 support" |
| 199 | depends on DVB_USB | 199 | depends on DVB_USB |
| 200 | select DVB_DIB3000MC | 200 | select DVB_DIB3000MC |
| 201 | select MEDIA_TUNER_MT2060 if !DVB_FE_CUSTOMISE | ||
| 202 | select DVB_PLL if !DVB_FE_CUSTOMISE | 201 | select DVB_PLL if !DVB_FE_CUSTOMISE |
| 202 | select MEDIA_TUNER_MT2060 if !MEDIA_TUNER_CUSTOMIZE | ||
| 203 | help | 203 | help |
| 204 | Say Y here to support the Hauppauge WinTV-NOVA-T usb2 DVB-T USB2.0 receiver. | 204 | Say Y here to support the Hauppauge WinTV-NOVA-T usb2 DVB-T USB2.0 receiver. |
| 205 | 205 | ||
| @@ -235,8 +235,8 @@ config DVB_USB_OPERA1 | |||
| 235 | config DVB_USB_AF9005 | 235 | config DVB_USB_AF9005 |
| 236 | tristate "Afatech AF9005 DVB-T USB1.1 support" | 236 | tristate "Afatech AF9005 DVB-T USB1.1 support" |
| 237 | depends on DVB_USB && EXPERIMENTAL | 237 | depends on DVB_USB && EXPERIMENTAL |
| 238 | select MEDIA_TUNER_MT2060 if !DVB_FE_CUSTOMISE | 238 | select MEDIA_TUNER_MT2060 if !MEDIA_TUNER_CUSTOMIZE |
| 239 | select MEDIA_TUNER_QT1010 if !DVB_FE_CUSTOMISE | 239 | select MEDIA_TUNER_QT1010 if !MEDIA_TUNER_CUSTOMIZE |
| 240 | help | 240 | help |
| 241 | Say Y here to support the Afatech AF9005 based DVB-T USB1.1 receiver | 241 | Say Y here to support the Afatech AF9005 based DVB-T USB1.1 receiver |
| 242 | and the TerraTec Cinergy T USB XE (Rev.1) | 242 | and the TerraTec Cinergy T USB XE (Rev.1) |
| @@ -284,7 +284,7 @@ config DVB_USB_DTV5100 | |||
| 284 | tristate "AME DTV-5100 USB2.0 DVB-T support" | 284 | tristate "AME DTV-5100 USB2.0 DVB-T support" |
| 285 | depends on DVB_USB | 285 | depends on DVB_USB |
| 286 | select DVB_ZL10353 if !DVB_FE_CUSTOMISE | 286 | select DVB_ZL10353 if !DVB_FE_CUSTOMISE |
| 287 | select MEDIA_TUNER_QT1010 if !DVB_FE_CUSTOMISE | 287 | select MEDIA_TUNER_QT1010 if !MEDIA_TUNER_CUSTOMIZE |
| 288 | help | 288 | help |
| 289 | Say Y here to support the AME DTV-5100 USB2.0 DVB-T receiver. | 289 | Say Y here to support the AME DTV-5100 USB2.0 DVB-T receiver. |
| 290 | 290 | ||
| @@ -293,9 +293,9 @@ config DVB_USB_AF9015 | |||
| 293 | depends on DVB_USB && EXPERIMENTAL | 293 | depends on DVB_USB && EXPERIMENTAL |
| 294 | select DVB_AF9013 | 294 | select DVB_AF9013 |
| 295 | select DVB_PLL if !DVB_FE_CUSTOMISE | 295 | select DVB_PLL if !DVB_FE_CUSTOMISE |
| 296 | select MEDIA_TUNER_MT2060 if !DVB_FE_CUSTOMISE | 296 | select MEDIA_TUNER_MT2060 if !MEDIA_TUNER_CUSTOMIZE |
| 297 | select MEDIA_TUNER_QT1010 if !DVB_FE_CUSTOMISE | 297 | select MEDIA_TUNER_QT1010 if !MEDIA_TUNER_CUSTOMIZE |
| 298 | select MEDIA_TUNER_TDA18271 if !DVB_FE_CUSTOMISE | 298 | select MEDIA_TUNER_TDA18271 if !MEDIA_TUNER_CUSTOMIZE |
| 299 | select MEDIA_TUNER_MXL5005S if !DVB_FE_CUSTOMISE | 299 | select MEDIA_TUNER_MXL5005S if !MEDIA_TUNER_CUSTOMIZE |
| 300 | help | 300 | help |
| 301 | Say Y here to support the Afatech AF9015 based DVB-T USB2.0 receiver | 301 | Say Y here to support the Afatech AF9015 based DVB-T USB2.0 receiver |
diff --git a/drivers/media/dvb/dvb-usb/dib0700_devices.c b/drivers/media/dvb/dvb-usb/dib0700_devices.c index f28d3ae59e04..391732788911 100644 --- a/drivers/media/dvb/dvb-usb/dib0700_devices.c +++ b/drivers/media/dvb/dvb-usb/dib0700_devices.c | |||
| @@ -446,13 +446,13 @@ static int stk7700ph_tuner_attach(struct dvb_usb_adapter *adap) | |||
| 446 | == NULL ? -ENODEV : 0; | 446 | == NULL ? -ENODEV : 0; |
| 447 | } | 447 | } |
| 448 | 448 | ||
| 449 | #define DEFAULT_RC_INTERVAL 150 | 449 | #define DEFAULT_RC_INTERVAL 50 |
| 450 | 450 | ||
| 451 | static u8 rc_request[] = { REQUEST_POLL_RC, 0 }; | 451 | static u8 rc_request[] = { REQUEST_POLL_RC, 0 }; |
| 452 | 452 | ||
| 453 | /* Number of keypresses to ignore before start repeating */ | 453 | /* Number of keypresses to ignore before start repeating */ |
| 454 | #define RC_REPEAT_DELAY 2 | 454 | #define RC_REPEAT_DELAY 6 |
| 455 | #define RC_REPEAT_DELAY_V1_20 5 | 455 | #define RC_REPEAT_DELAY_V1_20 10 |
| 456 | 456 | ||
| 457 | 457 | ||
| 458 | 458 | ||
diff --git a/drivers/media/dvb/ttpci/Kconfig b/drivers/media/dvb/ttpci/Kconfig index 867027ceab3e..401a04effc06 100644 --- a/drivers/media/dvb/ttpci/Kconfig +++ b/drivers/media/dvb/ttpci/Kconfig | |||
| @@ -106,7 +106,7 @@ config DVB_BUDGET_CI | |||
| 106 | select DVB_TDA1004X if !DVB_FE_CUSTOMISE | 106 | select DVB_TDA1004X if !DVB_FE_CUSTOMISE |
| 107 | select DVB_LNBP21 if !DVB_FE_CUSTOMISE | 107 | select DVB_LNBP21 if !DVB_FE_CUSTOMISE |
| 108 | select DVB_TDA10023 if !DVB_FE_CUSTOMISE | 108 | select DVB_TDA10023 if !DVB_FE_CUSTOMISE |
| 109 | select MEDIA_TUNER_TDA827X if !DVB_FE_CUSTOMISE | 109 | select MEDIA_TUNER_TDA827X if !MEDIA_TUNER_CUSTOMIZE |
| 110 | select VIDEO_IR | 110 | select VIDEO_IR |
| 111 | help | 111 | help |
| 112 | Support for simple SAA7146 based DVB cards | 112 | Support for simple SAA7146 based DVB cards |
diff --git a/drivers/media/video/compat_ioctl32.c b/drivers/media/video/compat_ioctl32.c index e6ca4012b5f0..0ea85a05e5c0 100644 --- a/drivers/media/video/compat_ioctl32.c +++ b/drivers/media/video/compat_ioctl32.c | |||
| @@ -831,7 +831,7 @@ long v4l_compat_ioctl32(struct file *file, unsigned int cmd, unsigned long arg) | |||
| 831 | { | 831 | { |
| 832 | int ret = -ENOIOCTLCMD; | 832 | int ret = -ENOIOCTLCMD; |
| 833 | 833 | ||
| 834 | if (!file->f_op->ioctl) | 834 | if (!file->f_op->ioctl && !file->f_op->unlocked_ioctl) |
| 835 | return ret; | 835 | return ret; |
| 836 | 836 | ||
| 837 | switch (cmd) { | 837 | switch (cmd) { |
diff --git a/drivers/media/video/cx18/Kconfig b/drivers/media/video/cx18/Kconfig index ef48565de7f1..8940b5387dec 100644 --- a/drivers/media/video/cx18/Kconfig +++ b/drivers/media/video/cx18/Kconfig | |||
| @@ -9,7 +9,7 @@ config VIDEO_CX18 | |||
| 9 | select VIDEO_CX2341X | 9 | select VIDEO_CX2341X |
| 10 | select VIDEO_CS5345 | 10 | select VIDEO_CS5345 |
| 11 | select DVB_S5H1409 if !DVB_FE_CUSTOMISE | 11 | select DVB_S5H1409 if !DVB_FE_CUSTOMISE |
| 12 | select MEDIA_TUNER_MXL5005S if !DVB_FE_CUSTOMISE | 12 | select MEDIA_TUNER_MXL5005S if !MEDIA_TUNER_CUSTOMIZE |
| 13 | ---help--- | 13 | ---help--- |
| 14 | This is a video4linux driver for Conexant cx23418 based | 14 | This is a video4linux driver for Conexant cx23418 based |
| 15 | PCI combo video recorder devices. | 15 | PCI combo video recorder devices. |
diff --git a/drivers/media/video/cx23885/Kconfig b/drivers/media/video/cx23885/Kconfig index 8c1b7fa47a41..00f1e2e8889e 100644 --- a/drivers/media/video/cx23885/Kconfig +++ b/drivers/media/video/cx23885/Kconfig | |||
| @@ -11,16 +11,16 @@ config VIDEO_CX23885 | |||
| 11 | select VIDEO_CX25840 | 11 | select VIDEO_CX25840 |
| 12 | select VIDEO_CX2341X | 12 | select VIDEO_CX2341X |
| 13 | select DVB_DIB7000P if !DVB_FE_CUSTOMISE | 13 | select DVB_DIB7000P if !DVB_FE_CUSTOMISE |
| 14 | select MEDIA_TUNER_MT2131 if !DVB_FE_CUSTOMISE | ||
| 15 | select DVB_S5H1409 if !DVB_FE_CUSTOMISE | 14 | select DVB_S5H1409 if !DVB_FE_CUSTOMISE |
| 16 | select DVB_S5H1411 if !DVB_FE_CUSTOMISE | 15 | select DVB_S5H1411 if !DVB_FE_CUSTOMISE |
| 17 | select DVB_LGDT330X if !DVB_FE_CUSTOMISE | 16 | select DVB_LGDT330X if !DVB_FE_CUSTOMISE |
| 18 | select DVB_ZL10353 if !DVB_FE_CUSTOMISE | 17 | select DVB_ZL10353 if !DVB_FE_CUSTOMISE |
| 18 | select DVB_TDA10048 if !DVB_FE_CUSTOMIZE | ||
| 19 | select MEDIA_TUNER_MT2131 if !MEDIA_TUNER_CUSTOMIZE | ||
| 19 | select MEDIA_TUNER_XC2028 if !DVB_FE_CUSTOMIZE | 20 | select MEDIA_TUNER_XC2028 if !DVB_FE_CUSTOMIZE |
| 20 | select MEDIA_TUNER_TDA8290 if !DVB_FE_CUSTOMIZE | 21 | select MEDIA_TUNER_TDA8290 if !DVB_FE_CUSTOMIZE |
| 21 | select MEDIA_TUNER_TDA18271 if !DVB_FE_CUSTOMIZE | 22 | select MEDIA_TUNER_TDA18271 if !DVB_FE_CUSTOMIZE |
| 22 | select MEDIA_TUNER_XC5000 if !DVB_FE_CUSTOMIZE | 23 | select MEDIA_TUNER_XC5000 if !DVB_FE_CUSTOMIZE |
| 23 | select DVB_TDA10048 if !DVB_FE_CUSTOMIZE | ||
| 24 | ---help--- | 24 | ---help--- |
| 25 | This is a video4linux driver for Conexant 23885 based | 25 | This is a video4linux driver for Conexant 23885 based |
| 26 | TV cards. | 26 | TV cards. |
diff --git a/drivers/media/video/cx88/Kconfig b/drivers/media/video/cx88/Kconfig index 0b9e5fac6239..b0f837588e01 100644 --- a/drivers/media/video/cx88/Kconfig +++ b/drivers/media/video/cx88/Kconfig | |||
| @@ -56,12 +56,12 @@ config VIDEO_CX88_DVB | |||
| 56 | select DVB_NXT200X if !DVB_FE_CUSTOMISE | 56 | select DVB_NXT200X if !DVB_FE_CUSTOMISE |
| 57 | select DVB_CX24123 if !DVB_FE_CUSTOMISE | 57 | select DVB_CX24123 if !DVB_FE_CUSTOMISE |
| 58 | select DVB_ISL6421 if !DVB_FE_CUSTOMISE | 58 | select DVB_ISL6421 if !DVB_FE_CUSTOMISE |
| 59 | select MEDIA_TUNER_SIMPLE if !DVB_FE_CUSTOMISE | ||
| 60 | select DVB_S5H1411 if !DVB_FE_CUSTOMISE | 59 | select DVB_S5H1411 if !DVB_FE_CUSTOMISE |
| 61 | select DVB_CX24116 if !DVB_FE_CUSTOMISE | 60 | select DVB_CX24116 if !DVB_FE_CUSTOMISE |
| 62 | select DVB_STV0299 if !DVB_FE_CUSTOMISE | 61 | select DVB_STV0299 if !DVB_FE_CUSTOMISE |
| 63 | select DVB_STV0288 if !DVB_FE_CUSTOMISE | 62 | select DVB_STV0288 if !DVB_FE_CUSTOMISE |
| 64 | select DVB_STB6000 if !DVB_FE_CUSTOMISE | 63 | select DVB_STB6000 if !DVB_FE_CUSTOMISE |
| 64 | select MEDIA_TUNER_SIMPLE if !MEDIA_TUNER_CUSTOMIZE | ||
| 65 | ---help--- | 65 | ---help--- |
| 66 | This adds support for DVB/ATSC cards based on the | 66 | This adds support for DVB/ATSC cards based on the |
| 67 | Conexant 2388x chip. | 67 | Conexant 2388x chip. |
diff --git a/drivers/media/video/em28xx/em28xx-video.c b/drivers/media/video/em28xx/em28xx-video.c index 610f535a257c..4ea1f1e04897 100644 --- a/drivers/media/video/em28xx/em28xx-video.c +++ b/drivers/media/video/em28xx/em28xx-video.c | |||
| @@ -549,10 +549,11 @@ static int em28xx_config(struct em28xx *dev) | |||
| 549 | static void em28xx_config_i2c(struct em28xx *dev) | 549 | static void em28xx_config_i2c(struct em28xx *dev) |
| 550 | { | 550 | { |
| 551 | struct v4l2_routing route; | 551 | struct v4l2_routing route; |
| 552 | int zero = 0; | ||
| 552 | 553 | ||
| 553 | route.input = INPUT(dev->ctl_input)->vmux; | 554 | route.input = INPUT(dev->ctl_input)->vmux; |
| 554 | route.output = 0; | 555 | route.output = 0; |
| 555 | em28xx_i2c_call_clients(dev, VIDIOC_INT_RESET, NULL); | 556 | em28xx_i2c_call_clients(dev, VIDIOC_INT_RESET, &zero); |
| 556 | em28xx_i2c_call_clients(dev, VIDIOC_INT_S_VIDEO_ROUTING, &route); | 557 | em28xx_i2c_call_clients(dev, VIDIOC_INT_S_VIDEO_ROUTING, &route); |
| 557 | em28xx_i2c_call_clients(dev, VIDIOC_STREAMON, NULL); | 558 | em28xx_i2c_call_clients(dev, VIDIOC_STREAMON, NULL); |
| 558 | } | 559 | } |
diff --git a/drivers/media/video/gspca/gspca.c b/drivers/media/video/gspca/gspca.c index 748a87e82e44..02a6e9ef0337 100644 --- a/drivers/media/video/gspca/gspca.c +++ b/drivers/media/video/gspca/gspca.c | |||
| @@ -1264,10 +1264,10 @@ static int vidioc_s_jpegcomp(struct file *file, void *priv, | |||
| 1264 | struct gspca_dev *gspca_dev = priv; | 1264 | struct gspca_dev *gspca_dev = priv; |
| 1265 | int ret; | 1265 | int ret; |
| 1266 | 1266 | ||
| 1267 | if (mutex_lock_interruptible(&gspca_dev->usb_lock)) | ||
| 1268 | return -ERESTARTSYS; | ||
| 1269 | if (!gspca_dev->sd_desc->set_jcomp) | 1267 | if (!gspca_dev->sd_desc->set_jcomp) |
| 1270 | return -EINVAL; | 1268 | return -EINVAL; |
| 1269 | if (mutex_lock_interruptible(&gspca_dev->usb_lock)) | ||
| 1270 | return -ERESTARTSYS; | ||
| 1271 | ret = gspca_dev->sd_desc->set_jcomp(gspca_dev, jpegcomp); | 1271 | ret = gspca_dev->sd_desc->set_jcomp(gspca_dev, jpegcomp); |
| 1272 | mutex_unlock(&gspca_dev->usb_lock); | 1272 | mutex_unlock(&gspca_dev->usb_lock); |
| 1273 | return ret; | 1273 | return ret; |
diff --git a/drivers/media/video/pvrusb2/Kconfig b/drivers/media/video/pvrusb2/Kconfig index 19eb274c9cd0..854c2a885358 100644 --- a/drivers/media/video/pvrusb2/Kconfig +++ b/drivers/media/video/pvrusb2/Kconfig | |||
| @@ -42,7 +42,7 @@ config VIDEO_PVRUSB2_DVB | |||
| 42 | select DVB_S5H1411 if !DVB_FE_CUSTOMISE | 42 | select DVB_S5H1411 if !DVB_FE_CUSTOMISE |
| 43 | select DVB_TDA10048 if !DVB_FE_CUSTOMIZE | 43 | select DVB_TDA10048 if !DVB_FE_CUSTOMIZE |
| 44 | select MEDIA_TUNER_TDA18271 if !DVB_FE_CUSTOMIZE | 44 | select MEDIA_TUNER_TDA18271 if !DVB_FE_CUSTOMIZE |
| 45 | select MEDIA_TUNER_SIMPLE if !DVB_FE_CUSTOMISE | 45 | select MEDIA_TUNER_SIMPLE if !MEDIA_TUNER_CUSTOMIZE |
| 46 | select MEDIA_TUNER_TDA8290 if !DVB_FE_CUSTOMIZE | 46 | select MEDIA_TUNER_TDA8290 if !DVB_FE_CUSTOMIZE |
| 47 | ---help--- | 47 | ---help--- |
| 48 | 48 | ||
diff --git a/drivers/media/video/saa7134/Kconfig b/drivers/media/video/saa7134/Kconfig index 7021bbf5897b..fc2164e28e76 100644 --- a/drivers/media/video/saa7134/Kconfig +++ b/drivers/media/video/saa7134/Kconfig | |||
| @@ -34,9 +34,9 @@ config VIDEO_SAA7134_DVB | |||
| 34 | select DVB_NXT200X if !DVB_FE_CUSTOMISE | 34 | select DVB_NXT200X if !DVB_FE_CUSTOMISE |
| 35 | select DVB_TDA10086 if !DVB_FE_CUSTOMISE | 35 | select DVB_TDA10086 if !DVB_FE_CUSTOMISE |
| 36 | select DVB_TDA826X if !DVB_FE_CUSTOMISE | 36 | select DVB_TDA826X if !DVB_FE_CUSTOMISE |
| 37 | select MEDIA_TUNER_TDA827X if !DVB_FE_CUSTOMISE | ||
| 38 | select DVB_ISL6421 if !DVB_FE_CUSTOMISE | 37 | select DVB_ISL6421 if !DVB_FE_CUSTOMISE |
| 39 | select MEDIA_TUNER_SIMPLE if !DVB_FE_CUSTOMISE | 38 | select MEDIA_TUNER_TDA827X if !MEDIA_TUNER_CUSTOMIZE |
| 39 | select MEDIA_TUNER_SIMPLE if !MEDIA_TUNER_CUSTOMIZE | ||
| 40 | ---help--- | 40 | ---help--- |
| 41 | This adds support for DVB cards based on the | 41 | This adds support for DVB cards based on the |
| 42 | Philips saa7134 chip. | 42 | Philips saa7134 chip. |
diff --git a/drivers/message/fusion/mptscsih.c b/drivers/message/fusion/mptscsih.c index d62fd4f6b52e..ee090413e598 100644 --- a/drivers/message/fusion/mptscsih.c +++ b/drivers/message/fusion/mptscsih.c | |||
| @@ -2008,6 +2008,9 @@ mptscsih_host_reset(struct scsi_cmnd *SCpnt) | |||
| 2008 | return FAILED; | 2008 | return FAILED; |
| 2009 | } | 2009 | } |
| 2010 | 2010 | ||
| 2011 | /* make sure we have no outstanding commands at this stage */ | ||
| 2012 | mptscsih_flush_running_cmds(hd); | ||
| 2013 | |||
| 2011 | ioc = hd->ioc; | 2014 | ioc = hd->ioc; |
| 2012 | printk(MYIOC_s_INFO_FMT "attempting host reset! (sc=%p)\n", | 2015 | printk(MYIOC_s_INFO_FMT "attempting host reset! (sc=%p)\n", |
| 2013 | ioc->name, SCpnt); | 2016 | ioc->name, SCpnt); |
diff --git a/drivers/net/bnx2.c b/drivers/net/bnx2.c index a1a3d0e5d2b4..9e8222f9e90e 100644 --- a/drivers/net/bnx2.c +++ b/drivers/net/bnx2.c | |||
| @@ -543,9 +543,9 @@ bnx2_free_rx_mem(struct bnx2 *bp) | |||
| 543 | for (j = 0; j < bp->rx_max_pg_ring; j++) { | 543 | for (j = 0; j < bp->rx_max_pg_ring; j++) { |
| 544 | if (rxr->rx_pg_desc_ring[j]) | 544 | if (rxr->rx_pg_desc_ring[j]) |
| 545 | pci_free_consistent(bp->pdev, RXBD_RING_SIZE, | 545 | pci_free_consistent(bp->pdev, RXBD_RING_SIZE, |
| 546 | rxr->rx_pg_desc_ring[i], | 546 | rxr->rx_pg_desc_ring[j], |
| 547 | rxr->rx_pg_desc_mapping[i]); | 547 | rxr->rx_pg_desc_mapping[j]); |
| 548 | rxr->rx_pg_desc_ring[i] = NULL; | 548 | rxr->rx_pg_desc_ring[j] = NULL; |
| 549 | } | 549 | } |
| 550 | if (rxr->rx_pg_ring) | 550 | if (rxr->rx_pg_ring) |
| 551 | vfree(rxr->rx_pg_ring); | 551 | vfree(rxr->rx_pg_ring); |
diff --git a/drivers/net/enc28j60.c b/drivers/net/enc28j60.c index c414554ac321..36cb6e95b465 100644 --- a/drivers/net/enc28j60.c +++ b/drivers/net/enc28j60.c | |||
| @@ -959,7 +959,7 @@ static void enc28j60_hw_rx(struct net_device *ndev) | |||
| 959 | ndev->stats.rx_packets++; | 959 | ndev->stats.rx_packets++; |
| 960 | ndev->stats.rx_bytes += len; | 960 | ndev->stats.rx_bytes += len; |
| 961 | ndev->last_rx = jiffies; | 961 | ndev->last_rx = jiffies; |
| 962 | netif_rx(skb); | 962 | netif_rx_ni(skb); |
| 963 | } | 963 | } |
| 964 | } | 964 | } |
| 965 | /* | 965 | /* |
diff --git a/drivers/net/jme.h b/drivers/net/jme.h index f863aee6648b..3f5d91543246 100644 --- a/drivers/net/jme.h +++ b/drivers/net/jme.h | |||
| @@ -22,7 +22,7 @@ | |||
| 22 | */ | 22 | */ |
| 23 | 23 | ||
| 24 | #ifndef __JME_H_INCLUDED__ | 24 | #ifndef __JME_H_INCLUDED__ |
| 25 | #define __JME_H_INCLUDEE__ | 25 | #define __JME_H_INCLUDED__ |
| 26 | 26 | ||
| 27 | #define DRV_NAME "jme" | 27 | #define DRV_NAME "jme" |
| 28 | #define DRV_VERSION "1.0.3" | 28 | #define DRV_VERSION "1.0.3" |
diff --git a/drivers/net/phy/mdio_bus.c b/drivers/net/phy/mdio_bus.c index 536bda1f428b..289fc267edf3 100644 --- a/drivers/net/phy/mdio_bus.c +++ b/drivers/net/phy/mdio_bus.c | |||
| @@ -105,8 +105,6 @@ int mdiobus_register(struct mii_bus *bus) | |||
| 105 | return -EINVAL; | 105 | return -EINVAL; |
| 106 | } | 106 | } |
| 107 | 107 | ||
| 108 | bus->state = MDIOBUS_REGISTERED; | ||
| 109 | |||
| 110 | mutex_init(&bus->mdio_lock); | 108 | mutex_init(&bus->mdio_lock); |
| 111 | 109 | ||
| 112 | if (bus->reset) | 110 | if (bus->reset) |
| @@ -123,6 +121,9 @@ int mdiobus_register(struct mii_bus *bus) | |||
| 123 | } | 121 | } |
| 124 | } | 122 | } |
| 125 | 123 | ||
| 124 | if (!err) | ||
| 125 | bus->state = MDIOBUS_REGISTERED; | ||
| 126 | |||
| 126 | pr_info("%s: probed\n", bus->name); | 127 | pr_info("%s: probed\n", bus->name); |
| 127 | 128 | ||
| 128 | return err; | 129 | return err; |
diff --git a/drivers/net/ppp_generic.c b/drivers/net/ppp_generic.c index 7e857e938adb..714a23035de1 100644 --- a/drivers/net/ppp_generic.c +++ b/drivers/net/ppp_generic.c | |||
| @@ -116,6 +116,7 @@ struct ppp { | |||
| 116 | unsigned long last_xmit; /* jiffies when last pkt sent 9c */ | 116 | unsigned long last_xmit; /* jiffies when last pkt sent 9c */ |
| 117 | unsigned long last_recv; /* jiffies when last pkt rcvd a0 */ | 117 | unsigned long last_recv; /* jiffies when last pkt rcvd a0 */ |
| 118 | struct net_device *dev; /* network interface device a4 */ | 118 | struct net_device *dev; /* network interface device a4 */ |
| 119 | int closing; /* is device closing down? a8 */ | ||
| 119 | #ifdef CONFIG_PPP_MULTILINK | 120 | #ifdef CONFIG_PPP_MULTILINK |
| 120 | int nxchan; /* next channel to send something on */ | 121 | int nxchan; /* next channel to send something on */ |
| 121 | u32 nxseq; /* next sequence number to send */ | 122 | u32 nxseq; /* next sequence number to send */ |
| @@ -995,7 +996,7 @@ ppp_xmit_process(struct ppp *ppp) | |||
| 995 | struct sk_buff *skb; | 996 | struct sk_buff *skb; |
| 996 | 997 | ||
| 997 | ppp_xmit_lock(ppp); | 998 | ppp_xmit_lock(ppp); |
| 998 | if (ppp->dev) { | 999 | if (!ppp->closing) { |
| 999 | ppp_push(ppp); | 1000 | ppp_push(ppp); |
| 1000 | while (!ppp->xmit_pending | 1001 | while (!ppp->xmit_pending |
| 1001 | && (skb = skb_dequeue(&ppp->file.xq))) | 1002 | && (skb = skb_dequeue(&ppp->file.xq))) |
| @@ -1463,8 +1464,7 @@ static inline void | |||
| 1463 | ppp_do_recv(struct ppp *ppp, struct sk_buff *skb, struct channel *pch) | 1464 | ppp_do_recv(struct ppp *ppp, struct sk_buff *skb, struct channel *pch) |
| 1464 | { | 1465 | { |
| 1465 | ppp_recv_lock(ppp); | 1466 | ppp_recv_lock(ppp); |
| 1466 | /* ppp->dev == 0 means interface is closing down */ | 1467 | if (!ppp->closing) |
| 1467 | if (ppp->dev) | ||
| 1468 | ppp_receive_frame(ppp, skb, pch); | 1468 | ppp_receive_frame(ppp, skb, pch); |
| 1469 | else | 1469 | else |
| 1470 | kfree_skb(skb); | 1470 | kfree_skb(skb); |
| @@ -2498,18 +2498,16 @@ init_ppp_file(struct ppp_file *pf, int kind) | |||
| 2498 | */ | 2498 | */ |
| 2499 | static void ppp_shutdown_interface(struct ppp *ppp) | 2499 | static void ppp_shutdown_interface(struct ppp *ppp) |
| 2500 | { | 2500 | { |
| 2501 | struct net_device *dev; | ||
| 2502 | |||
| 2503 | mutex_lock(&all_ppp_mutex); | 2501 | mutex_lock(&all_ppp_mutex); |
| 2504 | ppp_lock(ppp); | ||
| 2505 | dev = ppp->dev; | ||
| 2506 | ppp->dev = NULL; | ||
| 2507 | ppp_unlock(ppp); | ||
| 2508 | /* This will call dev_close() for us. */ | 2502 | /* This will call dev_close() for us. */ |
| 2509 | if (dev) { | 2503 | ppp_lock(ppp); |
| 2510 | unregister_netdev(dev); | 2504 | if (!ppp->closing) { |
| 2511 | free_netdev(dev); | 2505 | ppp->closing = 1; |
| 2512 | } | 2506 | ppp_unlock(ppp); |
| 2507 | unregister_netdev(ppp->dev); | ||
| 2508 | } else | ||
| 2509 | ppp_unlock(ppp); | ||
| 2510 | |||
| 2513 | cardmap_set(&all_ppp_units, ppp->file.index, NULL); | 2511 | cardmap_set(&all_ppp_units, ppp->file.index, NULL); |
| 2514 | ppp->file.dead = 1; | 2512 | ppp->file.dead = 1; |
| 2515 | ppp->owner = NULL; | 2513 | ppp->owner = NULL; |
| @@ -2554,7 +2552,7 @@ static void ppp_destroy_interface(struct ppp *ppp) | |||
| 2554 | if (ppp->xmit_pending) | 2552 | if (ppp->xmit_pending) |
| 2555 | kfree_skb(ppp->xmit_pending); | 2553 | kfree_skb(ppp->xmit_pending); |
| 2556 | 2554 | ||
| 2557 | kfree(ppp); | 2555 | free_netdev(ppp->dev); |
| 2558 | } | 2556 | } |
| 2559 | 2557 | ||
| 2560 | /* | 2558 | /* |
| @@ -2616,7 +2614,7 @@ ppp_connect_channel(struct channel *pch, int unit) | |||
| 2616 | if (pch->file.hdrlen > ppp->file.hdrlen) | 2614 | if (pch->file.hdrlen > ppp->file.hdrlen) |
| 2617 | ppp->file.hdrlen = pch->file.hdrlen; | 2615 | ppp->file.hdrlen = pch->file.hdrlen; |
| 2618 | hdrlen = pch->file.hdrlen + 2; /* for protocol bytes */ | 2616 | hdrlen = pch->file.hdrlen + 2; /* for protocol bytes */ |
| 2619 | if (ppp->dev && hdrlen > ppp->dev->hard_header_len) | 2617 | if (hdrlen > ppp->dev->hard_header_len) |
| 2620 | ppp->dev->hard_header_len = hdrlen; | 2618 | ppp->dev->hard_header_len = hdrlen; |
| 2621 | list_add_tail(&pch->clist, &ppp->channels); | 2619 | list_add_tail(&pch->clist, &ppp->channels); |
| 2622 | ++ppp->n_channels; | 2620 | ++ppp->n_channels; |
diff --git a/drivers/net/starfire.c b/drivers/net/starfire.c index 1d2ef8f47780..5a40f2d78beb 100644 --- a/drivers/net/starfire.c +++ b/drivers/net/starfire.c | |||
| @@ -1509,6 +1509,11 @@ static int __netdev_rx(struct net_device *dev, int *quota) | |||
| 1509 | desc->status = 0; | 1509 | desc->status = 0; |
| 1510 | np->rx_done = (np->rx_done + 1) % DONE_Q_SIZE; | 1510 | np->rx_done = (np->rx_done + 1) % DONE_Q_SIZE; |
| 1511 | } | 1511 | } |
| 1512 | |||
| 1513 | if (*quota == 0) { /* out of rx quota */ | ||
| 1514 | retcode = 1; | ||
| 1515 | goto out; | ||
| 1516 | } | ||
| 1512 | writew(np->rx_done, np->base + CompletionQConsumerIdx); | 1517 | writew(np->rx_done, np->base + CompletionQConsumerIdx); |
| 1513 | 1518 | ||
| 1514 | out: | 1519 | out: |
diff --git a/drivers/net/tlan.c b/drivers/net/tlan.c index c41d68761364..e60498232b94 100644 --- a/drivers/net/tlan.c +++ b/drivers/net/tlan.c | |||
| @@ -1098,6 +1098,7 @@ static int TLan_StartTx( struct sk_buff *skb, struct net_device *dev ) | |||
| 1098 | dma_addr_t tail_list_phys; | 1098 | dma_addr_t tail_list_phys; |
| 1099 | u8 *tail_buffer; | 1099 | u8 *tail_buffer; |
| 1100 | unsigned long flags; | 1100 | unsigned long flags; |
| 1101 | unsigned int txlen; | ||
| 1101 | 1102 | ||
| 1102 | if ( ! priv->phyOnline ) { | 1103 | if ( ! priv->phyOnline ) { |
| 1103 | TLAN_DBG( TLAN_DEBUG_TX, "TRANSMIT: %s PHY is not ready\n", | 1104 | TLAN_DBG( TLAN_DEBUG_TX, "TRANSMIT: %s PHY is not ready\n", |
| @@ -1108,6 +1109,7 @@ static int TLan_StartTx( struct sk_buff *skb, struct net_device *dev ) | |||
| 1108 | 1109 | ||
| 1109 | if (skb_padto(skb, TLAN_MIN_FRAME_SIZE)) | 1110 | if (skb_padto(skb, TLAN_MIN_FRAME_SIZE)) |
| 1110 | return 0; | 1111 | return 0; |
| 1112 | txlen = max(skb->len, (unsigned int)TLAN_MIN_FRAME_SIZE); | ||
| 1111 | 1113 | ||
| 1112 | tail_list = priv->txList + priv->txTail; | 1114 | tail_list = priv->txList + priv->txTail; |
| 1113 | tail_list_phys = priv->txListDMA + sizeof(TLanList) * priv->txTail; | 1115 | tail_list_phys = priv->txListDMA + sizeof(TLanList) * priv->txTail; |
| @@ -1125,16 +1127,16 @@ static int TLan_StartTx( struct sk_buff *skb, struct net_device *dev ) | |||
| 1125 | 1127 | ||
| 1126 | if ( bbuf ) { | 1128 | if ( bbuf ) { |
| 1127 | tail_buffer = priv->txBuffer + ( priv->txTail * TLAN_MAX_FRAME_SIZE ); | 1129 | tail_buffer = priv->txBuffer + ( priv->txTail * TLAN_MAX_FRAME_SIZE ); |
| 1128 | skb_copy_from_linear_data(skb, tail_buffer, skb->len); | 1130 | skb_copy_from_linear_data(skb, tail_buffer, txlen); |
| 1129 | } else { | 1131 | } else { |
| 1130 | tail_list->buffer[0].address = pci_map_single(priv->pciDev, | 1132 | tail_list->buffer[0].address = pci_map_single(priv->pciDev, |
| 1131 | skb->data, skb->len, | 1133 | skb->data, txlen, |
| 1132 | PCI_DMA_TODEVICE); | 1134 | PCI_DMA_TODEVICE); |
| 1133 | TLan_StoreSKB(tail_list, skb); | 1135 | TLan_StoreSKB(tail_list, skb); |
| 1134 | } | 1136 | } |
| 1135 | 1137 | ||
| 1136 | tail_list->frameSize = (u16) skb->len; | 1138 | tail_list->frameSize = (u16) txlen; |
| 1137 | tail_list->buffer[0].count = TLAN_LAST_BUFFER | (u32) skb->len; | 1139 | tail_list->buffer[0].count = TLAN_LAST_BUFFER | (u32) txlen; |
| 1138 | tail_list->buffer[1].count = 0; | 1140 | tail_list->buffer[1].count = 0; |
| 1139 | tail_list->buffer[1].address = 0; | 1141 | tail_list->buffer[1].address = 0; |
| 1140 | 1142 | ||
| @@ -1431,7 +1433,9 @@ static u32 TLan_HandleTxEOF( struct net_device *dev, u16 host_int ) | |||
| 1431 | if ( ! bbuf ) { | 1433 | if ( ! bbuf ) { |
| 1432 | struct sk_buff *skb = TLan_GetSKB(head_list); | 1434 | struct sk_buff *skb = TLan_GetSKB(head_list); |
| 1433 | pci_unmap_single(priv->pciDev, head_list->buffer[0].address, | 1435 | pci_unmap_single(priv->pciDev, head_list->buffer[0].address, |
| 1434 | skb->len, PCI_DMA_TODEVICE); | 1436 | max(skb->len, |
| 1437 | (unsigned int)TLAN_MIN_FRAME_SIZE), | ||
| 1438 | PCI_DMA_TODEVICE); | ||
| 1435 | dev_kfree_skb_any(skb); | 1439 | dev_kfree_skb_any(skb); |
| 1436 | head_list->buffer[8].address = 0; | 1440 | head_list->buffer[8].address = 0; |
| 1437 | head_list->buffer[9].address = 0; | 1441 | head_list->buffer[9].address = 0; |
| @@ -2055,9 +2059,12 @@ static void TLan_FreeLists( struct net_device *dev ) | |||
| 2055 | list = priv->txList + i; | 2059 | list = priv->txList + i; |
| 2056 | skb = TLan_GetSKB(list); | 2060 | skb = TLan_GetSKB(list); |
| 2057 | if ( skb ) { | 2061 | if ( skb ) { |
| 2058 | pci_unmap_single(priv->pciDev, | 2062 | pci_unmap_single( |
| 2059 | list->buffer[0].address, skb->len, | 2063 | priv->pciDev, |
| 2060 | PCI_DMA_TODEVICE); | 2064 | list->buffer[0].address, |
| 2065 | max(skb->len, | ||
| 2066 | (unsigned int)TLAN_MIN_FRAME_SIZE), | ||
| 2067 | PCI_DMA_TODEVICE); | ||
| 2061 | dev_kfree_skb_any( skb ); | 2068 | dev_kfree_skb_any( skb ); |
| 2062 | list->buffer[8].address = 0; | 2069 | list->buffer[8].address = 0; |
| 2063 | list->buffer[9].address = 0; | 2070 | list->buffer[9].address = 0; |
diff --git a/drivers/pci/hotplug/acpiphp.h b/drivers/pci/hotplug/acpiphp.h index f9e244da30ae..9bcb6cbd5aa9 100644 --- a/drivers/pci/hotplug/acpiphp.h +++ b/drivers/pci/hotplug/acpiphp.h | |||
| @@ -113,7 +113,7 @@ struct acpiphp_slot { | |||
| 113 | 113 | ||
| 114 | u8 device; /* pci device# */ | 114 | u8 device; /* pci device# */ |
| 115 | 115 | ||
| 116 | u32 sun; /* ACPI _SUN (slot unique number) */ | 116 | unsigned long long sun; /* ACPI _SUN (slot unique number) */ |
| 117 | u32 flags; /* see below */ | 117 | u32 flags; /* see below */ |
| 118 | }; | 118 | }; |
| 119 | 119 | ||
diff --git a/drivers/pci/hotplug/acpiphp_core.c b/drivers/pci/hotplug/acpiphp_core.c index 95b536a23d25..43c10bd261b4 100644 --- a/drivers/pci/hotplug/acpiphp_core.c +++ b/drivers/pci/hotplug/acpiphp_core.c | |||
| @@ -337,7 +337,7 @@ int acpiphp_register_hotplug_slot(struct acpiphp_slot *acpiphp_slot) | |||
| 337 | slot->hotplug_slot->info->cur_bus_speed = PCI_SPEED_UNKNOWN; | 337 | slot->hotplug_slot->info->cur_bus_speed = PCI_SPEED_UNKNOWN; |
| 338 | 338 | ||
| 339 | acpiphp_slot->slot = slot; | 339 | acpiphp_slot->slot = slot; |
| 340 | snprintf(name, SLOT_NAME_SIZE, "%u", slot->acpi_slot->sun); | 340 | snprintf(name, SLOT_NAME_SIZE, "%llu", slot->acpi_slot->sun); |
| 341 | 341 | ||
| 342 | retval = pci_hp_register(slot->hotplug_slot, | 342 | retval = pci_hp_register(slot->hotplug_slot, |
| 343 | acpiphp_slot->bridge->pci_bus, | 343 | acpiphp_slot->bridge->pci_bus, |
diff --git a/drivers/pci/hotplug/acpiphp_glue.c b/drivers/pci/hotplug/acpiphp_glue.c index 955aae4071f7..3affc6472e65 100644 --- a/drivers/pci/hotplug/acpiphp_glue.c +++ b/drivers/pci/hotplug/acpiphp_glue.c | |||
| @@ -255,13 +255,13 @@ register_slot(acpi_handle handle, u32 lvl, void *context, void **rv) | |||
| 255 | 255 | ||
| 256 | bridge->nr_slots++; | 256 | bridge->nr_slots++; |
| 257 | 257 | ||
| 258 | dbg("found ACPI PCI Hotplug slot %d at PCI %04x:%02x:%02x\n", | 258 | dbg("found ACPI PCI Hotplug slot %llu at PCI %04x:%02x:%02x\n", |
| 259 | slot->sun, pci_domain_nr(bridge->pci_bus), | 259 | slot->sun, pci_domain_nr(bridge->pci_bus), |
| 260 | bridge->pci_bus->number, slot->device); | 260 | bridge->pci_bus->number, slot->device); |
| 261 | retval = acpiphp_register_hotplug_slot(slot); | 261 | retval = acpiphp_register_hotplug_slot(slot); |
| 262 | if (retval) { | 262 | if (retval) { |
| 263 | if (retval == -EBUSY) | 263 | if (retval == -EBUSY) |
| 264 | warn("Slot %d already registered by another " | 264 | warn("Slot %llu already registered by another " |
| 265 | "hotplug driver\n", slot->sun); | 265 | "hotplug driver\n", slot->sun); |
| 266 | else | 266 | else |
| 267 | warn("acpiphp_register_hotplug_slot failed " | 267 | warn("acpiphp_register_hotplug_slot failed " |
diff --git a/drivers/pci/hotplug/ibmphp_core.c b/drivers/pci/hotplug/ibmphp_core.c index c892daae74d6..633e743442ac 100644 --- a/drivers/pci/hotplug/ibmphp_core.c +++ b/drivers/pci/hotplug/ibmphp_core.c | |||
| @@ -1402,10 +1402,6 @@ static int __init ibmphp_init(void) | |||
| 1402 | goto error; | 1402 | goto error; |
| 1403 | } | 1403 | } |
| 1404 | 1404 | ||
| 1405 | /* lock ourselves into memory with a module | ||
| 1406 | * count of -1 so that no one can unload us. */ | ||
| 1407 | module_put(THIS_MODULE); | ||
| 1408 | |||
| 1409 | exit: | 1405 | exit: |
| 1410 | return rc; | 1406 | return rc; |
| 1411 | 1407 | ||
| @@ -1423,4 +1419,3 @@ static void __exit ibmphp_exit(void) | |||
| 1423 | } | 1419 | } |
| 1424 | 1420 | ||
| 1425 | module_init(ibmphp_init); | 1421 | module_init(ibmphp_init); |
| 1426 | module_exit(ibmphp_exit); | ||
diff --git a/drivers/pci/hotplug/pciehp_core.c b/drivers/pci/hotplug/pciehp_core.c index 4b23bc39b11e..39cf248d24e3 100644 --- a/drivers/pci/hotplug/pciehp_core.c +++ b/drivers/pci/hotplug/pciehp_core.c | |||
| @@ -432,18 +432,19 @@ static int pciehp_probe(struct pcie_device *dev, const struct pcie_port_service_ | |||
| 432 | goto err_out_release_ctlr; | 432 | goto err_out_release_ctlr; |
| 433 | } | 433 | } |
| 434 | 434 | ||
| 435 | /* Check if slot is occupied */ | ||
| 435 | t_slot = pciehp_find_slot(ctrl, ctrl->slot_device_offset); | 436 | t_slot = pciehp_find_slot(ctrl, ctrl->slot_device_offset); |
| 436 | 437 | t_slot->hpc_ops->get_adapter_status(t_slot, &value); | |
| 437 | t_slot->hpc_ops->get_adapter_status(t_slot, &value); /* Check if slot is occupied */ | 438 | if (value) { |
| 438 | if (value && pciehp_force) { | 439 | if (pciehp_force) |
| 439 | rc = pciehp_enable_slot(t_slot); | 440 | pciehp_enable_slot(t_slot); |
| 440 | if (rc) /* -ENODEV: shouldn't happen, but deal with it */ | 441 | } else { |
| 441 | value = 0; | 442 | /* Power off slot if not occupied */ |
| 442 | } | 443 | if (POWER_CTRL(ctrl)) { |
| 443 | if ((POWER_CTRL(ctrl)) && !value) { | 444 | rc = t_slot->hpc_ops->power_off_slot(t_slot); |
| 444 | rc = t_slot->hpc_ops->power_off_slot(t_slot); /* Power off slot if not occupied*/ | 445 | if (rc) |
| 445 | if (rc) | 446 | goto err_out_free_ctrl_slot; |
| 446 | goto err_out_free_ctrl_slot; | 447 | } |
| 447 | } | 448 | } |
| 448 | 449 | ||
| 449 | return 0; | 450 | return 0; |
diff --git a/drivers/pci/pcie/aer/aerdrv_core.c b/drivers/pci/pcie/aer/aerdrv_core.c index dfc63d01f20a..aac7006949f1 100644 --- a/drivers/pci/pcie/aer/aerdrv_core.c +++ b/drivers/pci/pcie/aer/aerdrv_core.c | |||
| @@ -252,7 +252,7 @@ static void report_resume(struct pci_dev *dev, void *data) | |||
| 252 | 252 | ||
| 253 | if (!dev->driver || | 253 | if (!dev->driver || |
| 254 | !dev->driver->err_handler || | 254 | !dev->driver->err_handler || |
| 255 | !dev->driver->err_handler->slot_reset) | 255 | !dev->driver->err_handler->resume) |
| 256 | return; | 256 | return; |
| 257 | 257 | ||
| 258 | err_handler = dev->driver->err_handler; | 258 | err_handler = dev->driver->err_handler; |
diff --git a/drivers/rtc/rtc-isl1208.c b/drivers/rtc/rtc-isl1208.c index 2cd77ab8fc66..054e05294af8 100644 --- a/drivers/rtc/rtc-isl1208.c +++ b/drivers/rtc/rtc-isl1208.c | |||
| @@ -328,6 +328,13 @@ isl1208_i2c_set_time(struct i2c_client *client, struct rtc_time const *tm) | |||
| 328 | int sr; | 328 | int sr; |
| 329 | u8 regs[ISL1208_RTC_SECTION_LEN] = { 0, }; | 329 | u8 regs[ISL1208_RTC_SECTION_LEN] = { 0, }; |
| 330 | 330 | ||
| 331 | /* The clock has an 8 bit wide bcd-coded register (they never learn) | ||
| 332 | * for the year. tm_year is an offset from 1900 and we are interested | ||
| 333 | * in the 2000-2099 range, so any value less than 100 is invalid. | ||
| 334 | */ | ||
| 335 | if (tm->tm_year < 100) | ||
| 336 | return -EINVAL; | ||
| 337 | |||
| 331 | regs[ISL1208_REG_SC] = bin2bcd(tm->tm_sec); | 338 | regs[ISL1208_REG_SC] = bin2bcd(tm->tm_sec); |
| 332 | regs[ISL1208_REG_MN] = bin2bcd(tm->tm_min); | 339 | regs[ISL1208_REG_MN] = bin2bcd(tm->tm_min); |
| 333 | regs[ISL1208_REG_HR] = bin2bcd(tm->tm_hour) | ISL1208_REG_HR_MIL; | 340 | regs[ISL1208_REG_HR] = bin2bcd(tm->tm_hour) | ISL1208_REG_HR_MIL; |
diff --git a/drivers/scsi/aacraid/linit.c b/drivers/scsi/aacraid/linit.c index 162cd927d94b..94acbeed4e7c 100644 --- a/drivers/scsi/aacraid/linit.c +++ b/drivers/scsi/aacraid/linit.c | |||
| @@ -175,8 +175,8 @@ static struct aac_driver_ident aac_drivers[] = { | |||
| 175 | { aac_rx_init, "percraid", "DELL ", "PERCRAID ", 2, AAC_QUIRK_31BIT | AAC_QUIRK_34SG | AAC_QUIRK_SCSI_32 }, /* PERC 3/Di (Boxster/PERC3DiB) */ | 175 | { aac_rx_init, "percraid", "DELL ", "PERCRAID ", 2, AAC_QUIRK_31BIT | AAC_QUIRK_34SG | AAC_QUIRK_SCSI_32 }, /* PERC 3/Di (Boxster/PERC3DiB) */ |
| 176 | { aac_rx_init, "aacraid", "ADAPTEC ", "catapult ", 2, AAC_QUIRK_31BIT | AAC_QUIRK_34SG | AAC_QUIRK_SCSI_32 }, /* catapult */ | 176 | { aac_rx_init, "aacraid", "ADAPTEC ", "catapult ", 2, AAC_QUIRK_31BIT | AAC_QUIRK_34SG | AAC_QUIRK_SCSI_32 }, /* catapult */ |
| 177 | { aac_rx_init, "aacraid", "ADAPTEC ", "tomcat ", 2, AAC_QUIRK_31BIT | AAC_QUIRK_34SG | AAC_QUIRK_SCSI_32 }, /* tomcat */ | 177 | { aac_rx_init, "aacraid", "ADAPTEC ", "tomcat ", 2, AAC_QUIRK_31BIT | AAC_QUIRK_34SG | AAC_QUIRK_SCSI_32 }, /* tomcat */ |
| 178 | { aac_rx_init, "aacraid", "ADAPTEC ", "Adaptec 2120S ", 1, AAC_QUIRK_31BIT | AAC_QUIRK_34SG | AAC_QUIRK_SCSI_32 }, /* Adaptec 2120S (Crusader) */ | 178 | { aac_rx_init, "aacraid", "ADAPTEC ", "Adaptec 2120S ", 1, AAC_QUIRK_31BIT | AAC_QUIRK_34SG }, /* Adaptec 2120S (Crusader) */ |
| 179 | { aac_rx_init, "aacraid", "ADAPTEC ", "Adaptec 2200S ", 2, AAC_QUIRK_31BIT | AAC_QUIRK_34SG | AAC_QUIRK_SCSI_32 }, /* Adaptec 2200S (Vulcan) */ | 179 | { aac_rx_init, "aacraid", "ADAPTEC ", "Adaptec 2200S ", 2, AAC_QUIRK_31BIT | AAC_QUIRK_34SG }, /* Adaptec 2200S (Vulcan) */ |
| 180 | { aac_rx_init, "aacraid", "ADAPTEC ", "Adaptec 2200S ", 2, AAC_QUIRK_31BIT | AAC_QUIRK_34SG | AAC_QUIRK_SCSI_32 }, /* Adaptec 2200S (Vulcan-2m) */ | 180 | { aac_rx_init, "aacraid", "ADAPTEC ", "Adaptec 2200S ", 2, AAC_QUIRK_31BIT | AAC_QUIRK_34SG | AAC_QUIRK_SCSI_32 }, /* Adaptec 2200S (Vulcan-2m) */ |
| 181 | { aac_rx_init, "aacraid", "Legend ", "Legend S220 ", 1, AAC_QUIRK_31BIT | AAC_QUIRK_34SG | AAC_QUIRK_SCSI_32 }, /* Legend S220 (Legend Crusader) */ | 181 | { aac_rx_init, "aacraid", "Legend ", "Legend S220 ", 1, AAC_QUIRK_31BIT | AAC_QUIRK_34SG | AAC_QUIRK_SCSI_32 }, /* Legend S220 (Legend Crusader) */ |
| 182 | { aac_rx_init, "aacraid", "Legend ", "Legend S230 ", 2, AAC_QUIRK_31BIT | AAC_QUIRK_34SG | AAC_QUIRK_SCSI_32 }, /* Legend S230 (Legend Vulcan) */ | 182 | { aac_rx_init, "aacraid", "Legend ", "Legend S230 ", 2, AAC_QUIRK_31BIT | AAC_QUIRK_34SG | AAC_QUIRK_SCSI_32 }, /* Legend S230 (Legend Vulcan) */ |
diff --git a/drivers/scsi/ibmvscsi/ibmvstgt.c b/drivers/scsi/ibmvscsi/ibmvstgt.c index 2a5b29d12172..e2dd6a45924a 100644 --- a/drivers/scsi/ibmvscsi/ibmvstgt.c +++ b/drivers/scsi/ibmvscsi/ibmvstgt.c | |||
| @@ -864,21 +864,23 @@ static int ibmvstgt_probe(struct vio_dev *dev, const struct vio_device_id *id) | |||
| 864 | 864 | ||
| 865 | INIT_WORK(&vport->crq_work, handle_crq); | 865 | INIT_WORK(&vport->crq_work, handle_crq); |
| 866 | 866 | ||
| 867 | err = crq_queue_create(&vport->crq_queue, target); | 867 | err = scsi_add_host(shost, target->dev); |
| 868 | if (err) | 868 | if (err) |
| 869 | goto free_srp_target; | 869 | goto free_srp_target; |
| 870 | 870 | ||
| 871 | err = scsi_add_host(shost, target->dev); | 871 | err = scsi_tgt_alloc_queue(shost); |
| 872 | if (err) | 872 | if (err) |
| 873 | goto destroy_queue; | 873 | goto remove_host; |
| 874 | 874 | ||
| 875 | err = scsi_tgt_alloc_queue(shost); | 875 | err = crq_queue_create(&vport->crq_queue, target); |
| 876 | if (err) | 876 | if (err) |
| 877 | goto destroy_queue; | 877 | goto free_queue; |
| 878 | 878 | ||
| 879 | return 0; | 879 | return 0; |
| 880 | destroy_queue: | 880 | free_queue: |
| 881 | crq_queue_destroy(target); | 881 | scsi_tgt_free_queue(shost); |
| 882 | remove_host: | ||
| 883 | scsi_remove_host(shost); | ||
| 882 | free_srp_target: | 884 | free_srp_target: |
| 883 | srp_target_free(target); | 885 | srp_target_free(target); |
| 884 | put_host: | 886 | put_host: |
diff --git a/drivers/scsi/libiscsi.c b/drivers/scsi/libiscsi.c index 801c7cf54d2e..3fdee7370ccc 100644 --- a/drivers/scsi/libiscsi.c +++ b/drivers/scsi/libiscsi.c | |||
| @@ -489,12 +489,6 @@ __iscsi_conn_send_pdu(struct iscsi_conn *conn, struct iscsi_hdr *hdr, | |||
| 489 | if (!__kfifo_get(session->cmdpool.queue, | 489 | if (!__kfifo_get(session->cmdpool.queue, |
| 490 | (void*)&task, sizeof(void*))) | 490 | (void*)&task, sizeof(void*))) |
| 491 | return NULL; | 491 | return NULL; |
| 492 | |||
| 493 | if ((hdr->opcode == (ISCSI_OP_NOOP_OUT | ISCSI_OP_IMMEDIATE)) && | ||
| 494 | hdr->ttt == RESERVED_ITT) { | ||
| 495 | conn->ping_task = task; | ||
| 496 | conn->last_ping = jiffies; | ||
| 497 | } | ||
| 498 | } | 492 | } |
| 499 | /* | 493 | /* |
| 500 | * released in complete pdu for task we expect a response for, and | 494 | * released in complete pdu for task we expect a response for, and |
| @@ -703,6 +697,11 @@ static void iscsi_send_nopout(struct iscsi_conn *conn, struct iscsi_nopin *rhdr) | |||
| 703 | task = __iscsi_conn_send_pdu(conn, (struct iscsi_hdr *)&hdr, NULL, 0); | 697 | task = __iscsi_conn_send_pdu(conn, (struct iscsi_hdr *)&hdr, NULL, 0); |
| 704 | if (!task) | 698 | if (!task) |
| 705 | iscsi_conn_printk(KERN_ERR, conn, "Could not send nopout\n"); | 699 | iscsi_conn_printk(KERN_ERR, conn, "Could not send nopout\n"); |
| 700 | else if (!rhdr) { | ||
| 701 | /* only track our nops */ | ||
| 702 | conn->ping_task = task; | ||
| 703 | conn->last_ping = jiffies; | ||
| 704 | } | ||
| 706 | } | 705 | } |
| 707 | 706 | ||
| 708 | static int iscsi_handle_reject(struct iscsi_conn *conn, struct iscsi_hdr *hdr, | 707 | static int iscsi_handle_reject(struct iscsi_conn *conn, struct iscsi_hdr *hdr, |
diff --git a/drivers/scsi/scsi_lib.c b/drivers/scsi/scsi_lib.c index fa45a1a66867..148d3af92aef 100644 --- a/drivers/scsi/scsi_lib.c +++ b/drivers/scsi/scsi_lib.c | |||
| @@ -648,8 +648,8 @@ static void scsi_requeue_command(struct request_queue *q, struct scsi_cmnd *cmd) | |||
| 648 | struct request *req = cmd->request; | 648 | struct request *req = cmd->request; |
| 649 | unsigned long flags; | 649 | unsigned long flags; |
| 650 | 650 | ||
| 651 | scsi_unprep_request(req); | ||
| 652 | spin_lock_irqsave(q->queue_lock, flags); | 651 | spin_lock_irqsave(q->queue_lock, flags); |
| 652 | scsi_unprep_request(req); | ||
| 653 | blk_requeue_request(q, req); | 653 | blk_requeue_request(q, req); |
| 654 | spin_unlock_irqrestore(q->queue_lock, flags); | 654 | spin_unlock_irqrestore(q->queue_lock, flags); |
| 655 | 655 | ||
diff --git a/drivers/w1/w1_io.c b/drivers/w1/w1_io.c index 0d15b0eaf79a..5139c25ca962 100644 --- a/drivers/w1/w1_io.c +++ b/drivers/w1/w1_io.c | |||
| @@ -356,7 +356,9 @@ int w1_reset_select_slave(struct w1_slave *sl) | |||
| 356 | w1_write_8(sl->master, W1_SKIP_ROM); | 356 | w1_write_8(sl->master, W1_SKIP_ROM); |
| 357 | else { | 357 | else { |
| 358 | u8 match[9] = {W1_MATCH_ROM, }; | 358 | u8 match[9] = {W1_MATCH_ROM, }; |
| 359 | memcpy(&match[1], (u8 *)&sl->reg_num, 8); | 359 | u64 rn = le64_to_cpu(*((u64*)&sl->reg_num)); |
| 360 | |||
| 361 | memcpy(&match[1], &rn, 8); | ||
| 360 | w1_write_block(sl->master, match, 9); | 362 | w1_write_block(sl->master, match, 9); |
| 361 | } | 363 | } |
| 362 | return 0; | 364 | return 0; |
diff --git a/fs/9p/fid.c b/fs/9p/fid.c index 3031e3233dd6..2a983d49d19c 100644 --- a/fs/9p/fid.c +++ b/fs/9p/fid.c | |||
| @@ -45,7 +45,7 @@ int v9fs_fid_add(struct dentry *dentry, struct p9_fid *fid) | |||
| 45 | struct v9fs_dentry *dent; | 45 | struct v9fs_dentry *dent; |
| 46 | 46 | ||
| 47 | P9_DPRINTK(P9_DEBUG_VFS, "fid %d dentry %s\n", | 47 | P9_DPRINTK(P9_DEBUG_VFS, "fid %d dentry %s\n", |
| 48 | fid->fid, dentry->d_iname); | 48 | fid->fid, dentry->d_name.name); |
| 49 | 49 | ||
| 50 | dent = dentry->d_fsdata; | 50 | dent = dentry->d_fsdata; |
| 51 | if (!dent) { | 51 | if (!dent) { |
| @@ -79,7 +79,7 @@ static struct p9_fid *v9fs_fid_find(struct dentry *dentry, u32 uid, int any) | |||
| 79 | struct p9_fid *fid, *ret; | 79 | struct p9_fid *fid, *ret; |
| 80 | 80 | ||
| 81 | P9_DPRINTK(P9_DEBUG_VFS, " dentry: %s (%p) uid %d any %d\n", | 81 | P9_DPRINTK(P9_DEBUG_VFS, " dentry: %s (%p) uid %d any %d\n", |
| 82 | dentry->d_iname, dentry, uid, any); | 82 | dentry->d_name.name, dentry, uid, any); |
| 83 | dent = (struct v9fs_dentry *) dentry->d_fsdata; | 83 | dent = (struct v9fs_dentry *) dentry->d_fsdata; |
| 84 | ret = NULL; | 84 | ret = NULL; |
| 85 | if (dent) { | 85 | if (dent) { |
diff --git a/fs/9p/v9fs.c b/fs/9p/v9fs.c index 24eb01087b6d..332b5ff02fec 100644 --- a/fs/9p/v9fs.c +++ b/fs/9p/v9fs.c | |||
| @@ -160,7 +160,7 @@ static int v9fs_parse_options(struct v9fs_session_info *v9ses) | |||
| 160 | v9ses->flags |= V9FS_ACCESS_ANY; | 160 | v9ses->flags |= V9FS_ACCESS_ANY; |
| 161 | else { | 161 | else { |
| 162 | v9ses->flags |= V9FS_ACCESS_SINGLE; | 162 | v9ses->flags |= V9FS_ACCESS_SINGLE; |
| 163 | v9ses->uid = simple_strtol(s, &e, 10); | 163 | v9ses->uid = simple_strtoul(s, &e, 10); |
| 164 | if (*e != '\0') | 164 | if (*e != '\0') |
| 165 | v9ses->uid = ~0; | 165 | v9ses->uid = ~0; |
| 166 | } | 166 | } |
diff --git a/fs/9p/vfs_dentry.c b/fs/9p/vfs_dentry.c index f9534f18df0a..06dcc7c4f234 100644 --- a/fs/9p/vfs_dentry.c +++ b/fs/9p/vfs_dentry.c | |||
| @@ -52,7 +52,8 @@ | |||
| 52 | 52 | ||
| 53 | static int v9fs_dentry_delete(struct dentry *dentry) | 53 | static int v9fs_dentry_delete(struct dentry *dentry) |
| 54 | { | 54 | { |
| 55 | P9_DPRINTK(P9_DEBUG_VFS, " dentry: %s (%p)\n", dentry->d_iname, dentry); | 55 | P9_DPRINTK(P9_DEBUG_VFS, " dentry: %s (%p)\n", dentry->d_name.name, |
| 56 | dentry); | ||
| 56 | 57 | ||
| 57 | return 1; | 58 | return 1; |
| 58 | } | 59 | } |
| @@ -69,7 +70,8 @@ static int v9fs_dentry_delete(struct dentry *dentry) | |||
| 69 | static int v9fs_cached_dentry_delete(struct dentry *dentry) | 70 | static int v9fs_cached_dentry_delete(struct dentry *dentry) |
| 70 | { | 71 | { |
| 71 | struct inode *inode = dentry->d_inode; | 72 | struct inode *inode = dentry->d_inode; |
| 72 | P9_DPRINTK(P9_DEBUG_VFS, " dentry: %s (%p)\n", dentry->d_iname, dentry); | 73 | P9_DPRINTK(P9_DEBUG_VFS, " dentry: %s (%p)\n", dentry->d_name.name, |
| 74 | dentry); | ||
| 73 | 75 | ||
| 74 | if(!inode) | 76 | if(!inode) |
| 75 | return 1; | 77 | return 1; |
| @@ -88,7 +90,8 @@ void v9fs_dentry_release(struct dentry *dentry) | |||
| 88 | struct v9fs_dentry *dent; | 90 | struct v9fs_dentry *dent; |
| 89 | struct p9_fid *temp, *current_fid; | 91 | struct p9_fid *temp, *current_fid; |
| 90 | 92 | ||
| 91 | P9_DPRINTK(P9_DEBUG_VFS, " dentry: %s (%p)\n", dentry->d_iname, dentry); | 93 | P9_DPRINTK(P9_DEBUG_VFS, " dentry: %s (%p)\n", dentry->d_name.name, |
| 94 | dentry); | ||
| 92 | dent = dentry->d_fsdata; | 95 | dent = dentry->d_fsdata; |
| 93 | if (dent) { | 96 | if (dent) { |
| 94 | list_for_each_entry_safe(current_fid, temp, &dent->fidlist, | 97 | list_for_each_entry_safe(current_fid, temp, &dent->fidlist, |
diff --git a/fs/9p/vfs_inode.c b/fs/9p/vfs_inode.c index 8314d3f43b71..2dfcf5487efe 100644 --- a/fs/9p/vfs_inode.c +++ b/fs/9p/vfs_inode.c | |||
| @@ -963,7 +963,8 @@ static int v9fs_vfs_readlink(struct dentry *dentry, char __user * buffer, | |||
| 963 | if (buflen > PATH_MAX) | 963 | if (buflen > PATH_MAX) |
| 964 | buflen = PATH_MAX; | 964 | buflen = PATH_MAX; |
| 965 | 965 | ||
| 966 | P9_DPRINTK(P9_DEBUG_VFS, " dentry: %s (%p)\n", dentry->d_iname, dentry); | 966 | P9_DPRINTK(P9_DEBUG_VFS, " dentry: %s (%p)\n", dentry->d_name.name, |
| 967 | dentry); | ||
| 967 | 968 | ||
| 968 | retval = v9fs_readlink(dentry, link, buflen); | 969 | retval = v9fs_readlink(dentry, link, buflen); |
| 969 | 970 | ||
| @@ -1022,7 +1023,8 @@ v9fs_vfs_put_link(struct dentry *dentry, struct nameidata *nd, void *p) | |||
| 1022 | { | 1023 | { |
| 1023 | char *s = nd_get_link(nd); | 1024 | char *s = nd_get_link(nd); |
| 1024 | 1025 | ||
| 1025 | P9_DPRINTK(P9_DEBUG_VFS, " %s %s\n", dentry->d_name.name, s); | 1026 | P9_DPRINTK(P9_DEBUG_VFS, " %s %s\n", dentry->d_name.name, |
| 1027 | IS_ERR(s) ? "<error>" : s); | ||
| 1026 | if (!IS_ERR(s)) | 1028 | if (!IS_ERR(s)) |
| 1027 | __putname(s); | 1029 | __putname(s); |
| 1028 | } | 1030 | } |
diff --git a/include/acpi/acoutput.h b/include/acpi/acoutput.h index 09d33c7740f0..db8852d8bcf7 100644 --- a/include/acpi/acoutput.h +++ b/include/acpi/acoutput.h | |||
| @@ -172,7 +172,7 @@ | |||
| 172 | 172 | ||
| 173 | /* Defaults for debug_level, debug and normal */ | 173 | /* Defaults for debug_level, debug and normal */ |
| 174 | 174 | ||
| 175 | #define ACPI_DEBUG_DEFAULT (ACPI_LV_INIT | ACPI_LV_DEBUG_OBJECT) | 175 | #define ACPI_DEBUG_DEFAULT (ACPI_LV_INFO) |
| 176 | #define ACPI_NORMAL_DEFAULT (ACPI_LV_INIT | ACPI_LV_DEBUG_OBJECT) | 176 | #define ACPI_NORMAL_DEFAULT (ACPI_LV_INIT | ACPI_LV_DEBUG_OBJECT) |
| 177 | #define ACPI_DEBUG_ALL (ACPI_LV_AML_DISASSEMBLE | ACPI_LV_ALL_EXCEPTIONS | ACPI_LV_ALL) | 177 | #define ACPI_DEBUG_ALL (ACPI_LV_AML_DISASSEMBLE | ACPI_LV_ALL_EXCEPTIONS | ACPI_LV_ALL) |
| 178 | 178 | ||
diff --git a/include/acpi/platform/aclinux.h b/include/acpi/platform/aclinux.h index 029c8c06c151..0515e754449d 100644 --- a/include/acpi/platform/aclinux.h +++ b/include/acpi/platform/aclinux.h | |||
| @@ -141,6 +141,10 @@ static inline void *acpi_os_acquire_object(acpi_cache_t * cache) | |||
| 141 | /* | 141 | /* |
| 142 | * We need to show where it is safe to preempt execution of ACPICA | 142 | * We need to show where it is safe to preempt execution of ACPICA |
| 143 | */ | 143 | */ |
| 144 | #define ACPI_PREEMPTION_POINT() cond_resched() | 144 | #define ACPI_PREEMPTION_POINT() \ |
| 145 | do { \ | ||
| 146 | if (!irqs_disabled()) \ | ||
| 147 | cond_resched(); \ | ||
| 148 | } while (0) | ||
| 145 | 149 | ||
| 146 | #endif /* __ACLINUX_H__ */ | 150 | #endif /* __ACLINUX_H__ */ |
diff --git a/include/linux/ftrace.h b/include/linux/ftrace.h index 04b52e6ebc66..677432b9cb7e 100644 --- a/include/linux/ftrace.h +++ b/include/linux/ftrace.h | |||
| @@ -303,7 +303,7 @@ extern void ftrace_dump(void); | |||
| 303 | static inline void | 303 | static inline void |
| 304 | ftrace_special(unsigned long arg1, unsigned long arg2, unsigned long arg3) { } | 304 | ftrace_special(unsigned long arg1, unsigned long arg2, unsigned long arg3) { } |
| 305 | static inline int | 305 | static inline int |
| 306 | ftrace_printk(const char *fmt, ...) __attribute__ ((format (printf, 1, 0))); | 306 | ftrace_printk(const char *fmt, ...) __attribute__ ((format (printf, 1, 2))); |
| 307 | 307 | ||
| 308 | static inline void tracing_start(void) { } | 308 | static inline void tracing_start(void) { } |
| 309 | static inline void tracing_stop(void) { } | 309 | static inline void tracing_stop(void) { } |
diff --git a/include/linux/mm.h b/include/linux/mm.h index ffee2f743418..9979d3fab6e7 100644 --- a/include/linux/mm.h +++ b/include/linux/mm.h | |||
| @@ -1286,5 +1286,7 @@ int vmemmap_populate_basepages(struct page *start_page, | |||
| 1286 | int vmemmap_populate(struct page *start_page, unsigned long pages, int node); | 1286 | int vmemmap_populate(struct page *start_page, unsigned long pages, int node); |
| 1287 | void vmemmap_populate_print_last(void); | 1287 | void vmemmap_populate_print_last(void); |
| 1288 | 1288 | ||
| 1289 | extern void *alloc_locked_buffer(size_t size); | ||
| 1290 | extern void free_locked_buffer(void *buffer, size_t size); | ||
| 1289 | #endif /* __KERNEL__ */ | 1291 | #endif /* __KERNEL__ */ |
| 1290 | #endif /* _LINUX_MM_H */ | 1292 | #endif /* _LINUX_MM_H */ |
diff --git a/include/linux/netfilter/nfnetlink_conntrack.h b/include/linux/netfilter/nfnetlink_conntrack.h index c19595c89304..29fe9ea1d346 100644 --- a/include/linux/netfilter/nfnetlink_conntrack.h +++ b/include/linux/netfilter/nfnetlink_conntrack.h | |||
| @@ -141,6 +141,7 @@ enum ctattr_protonat { | |||
| 141 | #define CTA_PROTONAT_MAX (__CTA_PROTONAT_MAX - 1) | 141 | #define CTA_PROTONAT_MAX (__CTA_PROTONAT_MAX - 1) |
| 142 | 142 | ||
| 143 | enum ctattr_natseq { | 143 | enum ctattr_natseq { |
| 144 | CTA_NAT_SEQ_UNSPEC, | ||
| 144 | CTA_NAT_SEQ_CORRECTION_POS, | 145 | CTA_NAT_SEQ_CORRECTION_POS, |
| 145 | CTA_NAT_SEQ_OFFSET_BEFORE, | 146 | CTA_NAT_SEQ_OFFSET_BEFORE, |
| 146 | CTA_NAT_SEQ_OFFSET_AFTER, | 147 | CTA_NAT_SEQ_OFFSET_AFTER, |
diff --git a/include/linux/ptrace.h b/include/linux/ptrace.h index 22641d5d45df..98b93ca4db06 100644 --- a/include/linux/ptrace.h +++ b/include/linux/ptrace.h | |||
| @@ -94,6 +94,7 @@ extern void ptrace_notify(int exit_code); | |||
| 94 | extern void __ptrace_link(struct task_struct *child, | 94 | extern void __ptrace_link(struct task_struct *child, |
| 95 | struct task_struct *new_parent); | 95 | struct task_struct *new_parent); |
| 96 | extern void __ptrace_unlink(struct task_struct *child); | 96 | extern void __ptrace_unlink(struct task_struct *child); |
| 97 | extern void ptrace_fork(struct task_struct *task, unsigned long clone_flags); | ||
| 97 | #define PTRACE_MODE_READ 1 | 98 | #define PTRACE_MODE_READ 1 |
| 98 | #define PTRACE_MODE_ATTACH 2 | 99 | #define PTRACE_MODE_ATTACH 2 |
| 99 | /* Returns 0 on success, -errno on denial. */ | 100 | /* Returns 0 on success, -errno on denial. */ |
| @@ -313,6 +314,27 @@ static inline void user_enable_block_step(struct task_struct *task) | |||
| 313 | #define arch_ptrace_stop(code, info) do { } while (0) | 314 | #define arch_ptrace_stop(code, info) do { } while (0) |
| 314 | #endif | 315 | #endif |
| 315 | 316 | ||
| 317 | #ifndef arch_ptrace_untrace | ||
| 318 | /* | ||
| 319 | * Do machine-specific work before untracing child. | ||
| 320 | * | ||
| 321 | * This is called for a normal detach as well as from ptrace_exit() | ||
| 322 | * when the tracing task dies. | ||
| 323 | * | ||
| 324 | * Called with write_lock(&tasklist_lock) held. | ||
| 325 | */ | ||
| 326 | #define arch_ptrace_untrace(task) do { } while (0) | ||
| 327 | #endif | ||
| 328 | |||
| 329 | #ifndef arch_ptrace_fork | ||
| 330 | /* | ||
| 331 | * Do machine-specific work to initialize a new task. | ||
| 332 | * | ||
| 333 | * This is called from copy_process(). | ||
| 334 | */ | ||
| 335 | #define arch_ptrace_fork(child, clone_flags) do { } while (0) | ||
| 336 | #endif | ||
| 337 | |||
| 316 | extern int task_current_syscall(struct task_struct *target, long *callno, | 338 | extern int task_current_syscall(struct task_struct *target, long *callno, |
| 317 | unsigned long args[6], unsigned int maxargs, | 339 | unsigned long args[6], unsigned int maxargs, |
| 318 | unsigned long *sp, unsigned long *pc); | 340 | unsigned long *sp, unsigned long *pc); |
diff --git a/include/net/irda/irda_device.h b/include/net/irda/irda_device.h index 3025ae17ddbe..94c852d47d0f 100644 --- a/include/net/irda/irda_device.h +++ b/include/net/irda/irda_device.h | |||
| @@ -135,9 +135,11 @@ struct dongle_reg { | |||
| 135 | 135 | ||
| 136 | /* | 136 | /* |
| 137 | * Per-packet information we need to hide inside sk_buff | 137 | * Per-packet information we need to hide inside sk_buff |
| 138 | * (must not exceed 48 bytes, check with struct sk_buff) | 138 | * (must not exceed 48 bytes, check with struct sk_buff) |
| 139 | * The default_qdisc_pad field is a temporary hack. | ||
| 139 | */ | 140 | */ |
| 140 | struct irda_skb_cb { | 141 | struct irda_skb_cb { |
| 142 | unsigned int default_qdisc_pad; | ||
| 141 | magic_t magic; /* Be sure that we can trust the information */ | 143 | magic_t magic; /* Be sure that we can trust the information */ |
| 142 | __u32 next_speed; /* The Speed to be set *after* this frame */ | 144 | __u32 next_speed; /* The Speed to be set *after* this frame */ |
| 143 | __u16 mtt; /* Minimum turn around time */ | 145 | __u16 mtt; /* Minimum turn around time */ |
diff --git a/include/trace/sched.h b/include/trace/sched.h index bc4c9eadc6ba..0d81098ee9fc 100644 --- a/include/trace/sched.h +++ b/include/trace/sched.h | |||
| @@ -17,8 +17,8 @@ DECLARE_TRACE(sched_wait_task, | |||
| 17 | TPARGS(rq, p)); | 17 | TPARGS(rq, p)); |
| 18 | 18 | ||
| 19 | DECLARE_TRACE(sched_wakeup, | 19 | DECLARE_TRACE(sched_wakeup, |
| 20 | TPPROTO(struct rq *rq, struct task_struct *p), | 20 | TPPROTO(struct rq *rq, struct task_struct *p, int success), |
| 21 | TPARGS(rq, p)); | 21 | TPARGS(rq, p, success)); |
| 22 | 22 | ||
| 23 | DECLARE_TRACE(sched_wakeup_new, | 23 | DECLARE_TRACE(sched_wakeup_new, |
| 24 | TPPROTO(struct rq *rq, struct task_struct *p, int success), | 24 | TPPROTO(struct rq *rq, struct task_struct *p, int success), |
diff --git a/kernel/cgroup.c b/kernel/cgroup.c index 8185a0f09594..2606d0fb4e54 100644 --- a/kernel/cgroup.c +++ b/kernel/cgroup.c | |||
| @@ -1024,7 +1024,7 @@ static int cgroup_get_sb(struct file_system_type *fs_type, | |||
| 1024 | if (ret == -EBUSY) { | 1024 | if (ret == -EBUSY) { |
| 1025 | mutex_unlock(&cgroup_mutex); | 1025 | mutex_unlock(&cgroup_mutex); |
| 1026 | mutex_unlock(&inode->i_mutex); | 1026 | mutex_unlock(&inode->i_mutex); |
| 1027 | goto drop_new_super; | 1027 | goto free_cg_links; |
| 1028 | } | 1028 | } |
| 1029 | 1029 | ||
| 1030 | /* EBUSY should be the only error here */ | 1030 | /* EBUSY should be the only error here */ |
| @@ -1073,10 +1073,11 @@ static int cgroup_get_sb(struct file_system_type *fs_type, | |||
| 1073 | 1073 | ||
| 1074 | return simple_set_mnt(mnt, sb); | 1074 | return simple_set_mnt(mnt, sb); |
| 1075 | 1075 | ||
| 1076 | free_cg_links: | ||
| 1077 | free_cg_links(&tmp_cg_links); | ||
| 1076 | drop_new_super: | 1078 | drop_new_super: |
| 1077 | up_write(&sb->s_umount); | 1079 | up_write(&sb->s_umount); |
| 1078 | deactivate_super(sb); | 1080 | deactivate_super(sb); |
| 1079 | free_cg_links(&tmp_cg_links); | ||
| 1080 | return ret; | 1081 | return ret; |
| 1081 | } | 1082 | } |
| 1082 | 1083 | ||
| @@ -2934,9 +2935,6 @@ int cgroup_clone(struct task_struct *tsk, struct cgroup_subsys *subsys, | |||
| 2934 | again: | 2935 | again: |
| 2935 | root = subsys->root; | 2936 | root = subsys->root; |
| 2936 | if (root == &rootnode) { | 2937 | if (root == &rootnode) { |
| 2937 | printk(KERN_INFO | ||
| 2938 | "Not cloning cgroup for unused subsystem %s\n", | ||
| 2939 | subsys->name); | ||
| 2940 | mutex_unlock(&cgroup_mutex); | 2938 | mutex_unlock(&cgroup_mutex); |
| 2941 | return 0; | 2939 | return 0; |
| 2942 | } | 2940 | } |
diff --git a/kernel/fork.c b/kernel/fork.c index 7b93da72d4a2..65ce60adc8e8 100644 --- a/kernel/fork.c +++ b/kernel/fork.c | |||
| @@ -1096,6 +1096,8 @@ static struct task_struct *copy_process(unsigned long clone_flags, | |||
| 1096 | #ifdef CONFIG_DEBUG_MUTEXES | 1096 | #ifdef CONFIG_DEBUG_MUTEXES |
| 1097 | p->blocked_on = NULL; /* not blocked yet */ | 1097 | p->blocked_on = NULL; /* not blocked yet */ |
| 1098 | #endif | 1098 | #endif |
| 1099 | if (unlikely(ptrace_reparented(current))) | ||
| 1100 | ptrace_fork(p, clone_flags); | ||
| 1099 | 1101 | ||
| 1100 | /* Perform scheduler related setup. Assign this task to a CPU. */ | 1102 | /* Perform scheduler related setup. Assign this task to a CPU. */ |
| 1101 | sched_fork(p, clone_flags); | 1103 | sched_fork(p, clone_flags); |
diff --git a/kernel/posix-timers.c b/kernel/posix-timers.c index 5e79c662294b..a140e44eebba 100644 --- a/kernel/posix-timers.c +++ b/kernel/posix-timers.c | |||
| @@ -197,6 +197,11 @@ static int common_timer_create(struct k_itimer *new_timer) | |||
| 197 | return 0; | 197 | return 0; |
| 198 | } | 198 | } |
| 199 | 199 | ||
| 200 | static int no_timer_create(struct k_itimer *new_timer) | ||
| 201 | { | ||
| 202 | return -EOPNOTSUPP; | ||
| 203 | } | ||
| 204 | |||
| 200 | /* | 205 | /* |
| 201 | * Return nonzero if we know a priori this clockid_t value is bogus. | 206 | * Return nonzero if we know a priori this clockid_t value is bogus. |
| 202 | */ | 207 | */ |
| @@ -248,6 +253,7 @@ static __init int init_posix_timers(void) | |||
| 248 | .clock_getres = hrtimer_get_res, | 253 | .clock_getres = hrtimer_get_res, |
| 249 | .clock_get = posix_get_monotonic_raw, | 254 | .clock_get = posix_get_monotonic_raw, |
| 250 | .clock_set = do_posix_clock_nosettime, | 255 | .clock_set = do_posix_clock_nosettime, |
| 256 | .timer_create = no_timer_create, | ||
| 251 | }; | 257 | }; |
| 252 | 258 | ||
| 253 | register_posix_clock(CLOCK_REALTIME, &clock_realtime); | 259 | register_posix_clock(CLOCK_REALTIME, &clock_realtime); |
diff --git a/kernel/ptrace.c b/kernel/ptrace.c index 4c8bcd7dd8e0..100a71cfdaba 100644 --- a/kernel/ptrace.c +++ b/kernel/ptrace.c | |||
| @@ -25,6 +25,17 @@ | |||
| 25 | #include <asm/pgtable.h> | 25 | #include <asm/pgtable.h> |
| 26 | #include <asm/uaccess.h> | 26 | #include <asm/uaccess.h> |
| 27 | 27 | ||
| 28 | |||
| 29 | /* | ||
| 30 | * Initialize a new task whose father had been ptraced. | ||
| 31 | * | ||
| 32 | * Called from copy_process(). | ||
| 33 | */ | ||
| 34 | void ptrace_fork(struct task_struct *child, unsigned long clone_flags) | ||
| 35 | { | ||
| 36 | arch_ptrace_fork(child, clone_flags); | ||
| 37 | } | ||
| 38 | |||
| 28 | /* | 39 | /* |
| 29 | * ptrace a task: make the debugger its new parent and | 40 | * ptrace a task: make the debugger its new parent and |
| 30 | * move it to the ptrace list. | 41 | * move it to the ptrace list. |
| @@ -72,6 +83,7 @@ void __ptrace_unlink(struct task_struct *child) | |||
| 72 | child->parent = child->real_parent; | 83 | child->parent = child->real_parent; |
| 73 | list_del_init(&child->ptrace_entry); | 84 | list_del_init(&child->ptrace_entry); |
| 74 | 85 | ||
| 86 | arch_ptrace_untrace(child); | ||
| 75 | if (task_is_traced(child)) | 87 | if (task_is_traced(child)) |
| 76 | ptrace_untrace(child); | 88 | ptrace_untrace(child); |
| 77 | } | 89 | } |
diff --git a/kernel/sched.c b/kernel/sched.c index ceda5799466e..dcb39bc88f6c 100644 --- a/kernel/sched.c +++ b/kernel/sched.c | |||
| @@ -2324,7 +2324,7 @@ out_activate: | |||
| 2324 | success = 1; | 2324 | success = 1; |
| 2325 | 2325 | ||
| 2326 | out_running: | 2326 | out_running: |
| 2327 | trace_sched_wakeup(rq, p); | 2327 | trace_sched_wakeup(rq, p, success); |
| 2328 | check_preempt_curr(rq, p, sync); | 2328 | check_preempt_curr(rq, p, sync); |
| 2329 | 2329 | ||
| 2330 | p->state = TASK_RUNNING; | 2330 | p->state = TASK_RUNNING; |
diff --git a/kernel/trace/ring_buffer.c b/kernel/trace/ring_buffer.c index bb6922a931b1..76f34c0ef29c 100644 --- a/kernel/trace/ring_buffer.c +++ b/kernel/trace/ring_buffer.c | |||
| @@ -838,6 +838,7 @@ rb_set_commit_to_write(struct ring_buffer_per_cpu *cpu_buffer) | |||
| 838 | * back to us). This allows us to do a simple loop to | 838 | * back to us). This allows us to do a simple loop to |
| 839 | * assign the commit to the tail. | 839 | * assign the commit to the tail. |
| 840 | */ | 840 | */ |
| 841 | again: | ||
| 841 | while (cpu_buffer->commit_page != cpu_buffer->tail_page) { | 842 | while (cpu_buffer->commit_page != cpu_buffer->tail_page) { |
| 842 | cpu_buffer->commit_page->page->commit = | 843 | cpu_buffer->commit_page->page->commit = |
| 843 | cpu_buffer->commit_page->write; | 844 | cpu_buffer->commit_page->write; |
| @@ -853,6 +854,17 @@ rb_set_commit_to_write(struct ring_buffer_per_cpu *cpu_buffer) | |||
| 853 | cpu_buffer->commit_page->write; | 854 | cpu_buffer->commit_page->write; |
| 854 | barrier(); | 855 | barrier(); |
| 855 | } | 856 | } |
| 857 | |||
| 858 | /* again, keep gcc from optimizing */ | ||
| 859 | barrier(); | ||
| 860 | |||
| 861 | /* | ||
| 862 | * If an interrupt came in just after the first while loop | ||
| 863 | * and pushed the tail page forward, we will be left with | ||
| 864 | * a dangling commit that will never go forward. | ||
| 865 | */ | ||
| 866 | if (unlikely(cpu_buffer->commit_page != cpu_buffer->tail_page)) | ||
| 867 | goto again; | ||
| 856 | } | 868 | } |
| 857 | 869 | ||
| 858 | static void rb_reset_reader_page(struct ring_buffer_per_cpu *cpu_buffer) | 870 | static void rb_reset_reader_page(struct ring_buffer_per_cpu *cpu_buffer) |
| @@ -950,12 +962,15 @@ static struct ring_buffer_event * | |||
| 950 | __rb_reserve_next(struct ring_buffer_per_cpu *cpu_buffer, | 962 | __rb_reserve_next(struct ring_buffer_per_cpu *cpu_buffer, |
| 951 | unsigned type, unsigned long length, u64 *ts) | 963 | unsigned type, unsigned long length, u64 *ts) |
| 952 | { | 964 | { |
| 953 | struct buffer_page *tail_page, *head_page, *reader_page; | 965 | struct buffer_page *tail_page, *head_page, *reader_page, *commit_page; |
| 954 | unsigned long tail, write; | 966 | unsigned long tail, write; |
| 955 | struct ring_buffer *buffer = cpu_buffer->buffer; | 967 | struct ring_buffer *buffer = cpu_buffer->buffer; |
| 956 | struct ring_buffer_event *event; | 968 | struct ring_buffer_event *event; |
| 957 | unsigned long flags; | 969 | unsigned long flags; |
| 958 | 970 | ||
| 971 | commit_page = cpu_buffer->commit_page; | ||
| 972 | /* we just need to protect against interrupts */ | ||
| 973 | barrier(); | ||
| 959 | tail_page = cpu_buffer->tail_page; | 974 | tail_page = cpu_buffer->tail_page; |
| 960 | write = local_add_return(length, &tail_page->write); | 975 | write = local_add_return(length, &tail_page->write); |
| 961 | tail = write - length; | 976 | tail = write - length; |
| @@ -981,7 +996,7 @@ __rb_reserve_next(struct ring_buffer_per_cpu *cpu_buffer, | |||
| 981 | * it all the way around the buffer, bail, and warn | 996 | * it all the way around the buffer, bail, and warn |
| 982 | * about it. | 997 | * about it. |
| 983 | */ | 998 | */ |
| 984 | if (unlikely(next_page == cpu_buffer->commit_page)) { | 999 | if (unlikely(next_page == commit_page)) { |
| 985 | WARN_ON_ONCE(1); | 1000 | WARN_ON_ONCE(1); |
| 986 | goto out_unlock; | 1001 | goto out_unlock; |
| 987 | } | 1002 | } |
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c index 0eb6d48347f7..79db26e8216e 100644 --- a/kernel/trace/trace.c +++ b/kernel/trace/trace.c | |||
| @@ -679,6 +679,16 @@ void tracing_reset(struct trace_array *tr, int cpu) | |||
| 679 | ftrace_enable_cpu(); | 679 | ftrace_enable_cpu(); |
| 680 | } | 680 | } |
| 681 | 681 | ||
| 682 | void tracing_reset_online_cpus(struct trace_array *tr) | ||
| 683 | { | ||
| 684 | int cpu; | ||
| 685 | |||
| 686 | tr->time_start = ftrace_now(tr->cpu); | ||
| 687 | |||
| 688 | for_each_online_cpu(cpu) | ||
| 689 | tracing_reset(tr, cpu); | ||
| 690 | } | ||
| 691 | |||
| 682 | #define SAVED_CMDLINES 128 | 692 | #define SAVED_CMDLINES 128 |
| 683 | static unsigned map_pid_to_cmdline[PID_MAX_DEFAULT+1]; | 693 | static unsigned map_pid_to_cmdline[PID_MAX_DEFAULT+1]; |
| 684 | static unsigned map_cmdline_to_pid[SAVED_CMDLINES]; | 694 | static unsigned map_cmdline_to_pid[SAVED_CMDLINES]; |
diff --git a/kernel/trace/trace.h b/kernel/trace/trace.h index fc75dce7a664..cc7a4f864036 100644 --- a/kernel/trace/trace.h +++ b/kernel/trace/trace.h | |||
| @@ -374,6 +374,7 @@ struct trace_iterator { | |||
| 374 | int tracing_is_enabled(void); | 374 | int tracing_is_enabled(void); |
| 375 | void trace_wake_up(void); | 375 | void trace_wake_up(void); |
| 376 | void tracing_reset(struct trace_array *tr, int cpu); | 376 | void tracing_reset(struct trace_array *tr, int cpu); |
| 377 | void tracing_reset_online_cpus(struct trace_array *tr); | ||
| 377 | int tracing_open_generic(struct inode *inode, struct file *filp); | 378 | int tracing_open_generic(struct inode *inode, struct file *filp); |
| 378 | struct dentry *tracing_init_dentry(void); | 379 | struct dentry *tracing_init_dentry(void); |
| 379 | void init_tracer_sysprof_debugfs(struct dentry *d_tracer); | 380 | void init_tracer_sysprof_debugfs(struct dentry *d_tracer); |
diff --git a/kernel/trace/trace_boot.c b/kernel/trace/trace_boot.c index a4fa2c57e34e..3ccebde28482 100644 --- a/kernel/trace/trace_boot.c +++ b/kernel/trace/trace_boot.c | |||
| @@ -37,16 +37,6 @@ void disable_boot_trace(void) | |||
| 37 | tracing_stop_sched_switch_record(); | 37 | tracing_stop_sched_switch_record(); |
| 38 | } | 38 | } |
| 39 | 39 | ||
| 40 | static void reset_boot_trace(struct trace_array *tr) | ||
| 41 | { | ||
| 42 | int cpu; | ||
| 43 | |||
| 44 | tr->time_start = ftrace_now(tr->cpu); | ||
| 45 | |||
| 46 | for_each_online_cpu(cpu) | ||
| 47 | tracing_reset(tr, cpu); | ||
| 48 | } | ||
| 49 | |||
| 50 | static int boot_trace_init(struct trace_array *tr) | 40 | static int boot_trace_init(struct trace_array *tr) |
| 51 | { | 41 | { |
| 52 | int cpu; | 42 | int cpu; |
| @@ -130,7 +120,7 @@ struct tracer boot_tracer __read_mostly = | |||
| 130 | { | 120 | { |
| 131 | .name = "initcall", | 121 | .name = "initcall", |
| 132 | .init = boot_trace_init, | 122 | .init = boot_trace_init, |
| 133 | .reset = reset_boot_trace, | 123 | .reset = tracing_reset_online_cpus, |
| 134 | .print_line = initcall_print_line, | 124 | .print_line = initcall_print_line, |
| 135 | }; | 125 | }; |
| 136 | 126 | ||
diff --git a/kernel/trace/trace_functions.c b/kernel/trace/trace_functions.c index e74f6d0a3216..9236d7e25a16 100644 --- a/kernel/trace/trace_functions.c +++ b/kernel/trace/trace_functions.c | |||
| @@ -16,20 +16,10 @@ | |||
| 16 | 16 | ||
| 17 | #include "trace.h" | 17 | #include "trace.h" |
| 18 | 18 | ||
| 19 | static void function_reset(struct trace_array *tr) | ||
| 20 | { | ||
| 21 | int cpu; | ||
| 22 | |||
| 23 | tr->time_start = ftrace_now(tr->cpu); | ||
| 24 | |||
| 25 | for_each_online_cpu(cpu) | ||
| 26 | tracing_reset(tr, cpu); | ||
| 27 | } | ||
| 28 | |||
| 29 | static void start_function_trace(struct trace_array *tr) | 19 | static void start_function_trace(struct trace_array *tr) |
| 30 | { | 20 | { |
| 31 | tr->cpu = get_cpu(); | 21 | tr->cpu = get_cpu(); |
| 32 | function_reset(tr); | 22 | tracing_reset_online_cpus(tr); |
| 33 | put_cpu(); | 23 | put_cpu(); |
| 34 | 24 | ||
| 35 | tracing_start_cmdline_record(); | 25 | tracing_start_cmdline_record(); |
| @@ -55,7 +45,7 @@ static void function_trace_reset(struct trace_array *tr) | |||
| 55 | 45 | ||
| 56 | static void function_trace_start(struct trace_array *tr) | 46 | static void function_trace_start(struct trace_array *tr) |
| 57 | { | 47 | { |
| 58 | function_reset(tr); | 48 | tracing_reset_online_cpus(tr); |
| 59 | } | 49 | } |
| 60 | 50 | ||
| 61 | static struct tracer function_trace __read_mostly = | 51 | static struct tracer function_trace __read_mostly = |
diff --git a/kernel/trace/trace_hw_branches.c b/kernel/trace/trace_hw_branches.c index ee29e012aa97..b6a3e20a49a9 100644 --- a/kernel/trace/trace_hw_branches.c +++ b/kernel/trace/trace_hw_branches.c | |||
| @@ -25,16 +25,6 @@ static DEFINE_PER_CPU(unsigned char[SIZEOF_BTS], buffer); | |||
| 25 | #define this_buffer per_cpu(buffer, smp_processor_id()) | 25 | #define this_buffer per_cpu(buffer, smp_processor_id()) |
| 26 | 26 | ||
| 27 | 27 | ||
| 28 | static void bts_trace_reset(struct trace_array *tr) | ||
| 29 | { | ||
| 30 | int cpu; | ||
| 31 | |||
| 32 | tr->time_start = ftrace_now(tr->cpu); | ||
| 33 | |||
| 34 | for_each_online_cpu(cpu) | ||
| 35 | tracing_reset(tr, cpu); | ||
| 36 | } | ||
| 37 | |||
| 38 | static void bts_trace_start_cpu(void *arg) | 28 | static void bts_trace_start_cpu(void *arg) |
| 39 | { | 29 | { |
| 40 | if (this_tracer) | 30 | if (this_tracer) |
| @@ -54,7 +44,7 @@ static void bts_trace_start(struct trace_array *tr) | |||
| 54 | { | 44 | { |
| 55 | int cpu; | 45 | int cpu; |
| 56 | 46 | ||
| 57 | bts_trace_reset(tr); | 47 | tracing_reset_online_cpus(tr); |
| 58 | 48 | ||
| 59 | for_each_cpu_mask(cpu, cpu_possible_map) | 49 | for_each_cpu_mask(cpu, cpu_possible_map) |
| 60 | smp_call_function_single(cpu, bts_trace_start_cpu, NULL, 1); | 50 | smp_call_function_single(cpu, bts_trace_start_cpu, NULL, 1); |
| @@ -78,7 +68,7 @@ static void bts_trace_stop(struct trace_array *tr) | |||
| 78 | 68 | ||
| 79 | static int bts_trace_init(struct trace_array *tr) | 69 | static int bts_trace_init(struct trace_array *tr) |
| 80 | { | 70 | { |
| 81 | bts_trace_reset(tr); | 71 | tracing_reset_online_cpus(tr); |
| 82 | bts_trace_start(tr); | 72 | bts_trace_start(tr); |
| 83 | 73 | ||
| 84 | return 0; | 74 | return 0; |
diff --git a/kernel/trace/trace_mmiotrace.c b/kernel/trace/trace_mmiotrace.c index 2fb6da6523b3..fffcb069f1dc 100644 --- a/kernel/trace/trace_mmiotrace.c +++ b/kernel/trace/trace_mmiotrace.c | |||
| @@ -22,14 +22,10 @@ static unsigned long prev_overruns; | |||
| 22 | 22 | ||
| 23 | static void mmio_reset_data(struct trace_array *tr) | 23 | static void mmio_reset_data(struct trace_array *tr) |
| 24 | { | 24 | { |
| 25 | int cpu; | ||
| 26 | |||
| 27 | overrun_detected = false; | 25 | overrun_detected = false; |
| 28 | prev_overruns = 0; | 26 | prev_overruns = 0; |
| 29 | tr->time_start = ftrace_now(tr->cpu); | ||
| 30 | 27 | ||
| 31 | for_each_online_cpu(cpu) | 28 | tracing_reset_online_cpus(tr); |
| 32 | tracing_reset(tr, cpu); | ||
| 33 | } | 29 | } |
| 34 | 30 | ||
| 35 | static int mmio_trace_init(struct trace_array *tr) | 31 | static int mmio_trace_init(struct trace_array *tr) |
diff --git a/kernel/trace/trace_sched_switch.c b/kernel/trace/trace_sched_switch.c index 781d72ef873c..df175cb4564f 100644 --- a/kernel/trace/trace_sched_switch.c +++ b/kernel/trace/trace_sched_switch.c | |||
| @@ -49,7 +49,7 @@ probe_sched_switch(struct rq *__rq, struct task_struct *prev, | |||
| 49 | } | 49 | } |
| 50 | 50 | ||
| 51 | static void | 51 | static void |
| 52 | probe_sched_wakeup(struct rq *__rq, struct task_struct *wakee) | 52 | probe_sched_wakeup(struct rq *__rq, struct task_struct *wakee, int success) |
| 53 | { | 53 | { |
| 54 | struct trace_array_cpu *data; | 54 | struct trace_array_cpu *data; |
| 55 | unsigned long flags; | 55 | unsigned long flags; |
| @@ -72,16 +72,6 @@ probe_sched_wakeup(struct rq *__rq, struct task_struct *wakee) | |||
| 72 | local_irq_restore(flags); | 72 | local_irq_restore(flags); |
| 73 | } | 73 | } |
| 74 | 74 | ||
| 75 | static void sched_switch_reset(struct trace_array *tr) | ||
| 76 | { | ||
| 77 | int cpu; | ||
| 78 | |||
| 79 | tr->time_start = ftrace_now(tr->cpu); | ||
| 80 | |||
| 81 | for_each_online_cpu(cpu) | ||
| 82 | tracing_reset(tr, cpu); | ||
| 83 | } | ||
| 84 | |||
| 85 | static int tracing_sched_register(void) | 75 | static int tracing_sched_register(void) |
| 86 | { | 76 | { |
| 87 | int ret; | 77 | int ret; |
| @@ -197,7 +187,7 @@ void tracing_sched_switch_assign_trace(struct trace_array *tr) | |||
| 197 | 187 | ||
| 198 | static void start_sched_trace(struct trace_array *tr) | 188 | static void start_sched_trace(struct trace_array *tr) |
| 199 | { | 189 | { |
| 200 | sched_switch_reset(tr); | 190 | tracing_reset_online_cpus(tr); |
| 201 | tracing_start_sched_switch_record(); | 191 | tracing_start_sched_switch_record(); |
| 202 | } | 192 | } |
| 203 | 193 | ||
| @@ -221,7 +211,7 @@ static void sched_switch_trace_reset(struct trace_array *tr) | |||
| 221 | 211 | ||
| 222 | static void sched_switch_trace_start(struct trace_array *tr) | 212 | static void sched_switch_trace_start(struct trace_array *tr) |
| 223 | { | 213 | { |
| 224 | sched_switch_reset(tr); | 214 | tracing_reset_online_cpus(tr); |
| 225 | tracing_start_sched_switch(); | 215 | tracing_start_sched_switch(); |
| 226 | } | 216 | } |
| 227 | 217 | ||
diff --git a/kernel/trace/trace_sched_wakeup.c b/kernel/trace/trace_sched_wakeup.c index 0067b49746c1..43586b689e31 100644 --- a/kernel/trace/trace_sched_wakeup.c +++ b/kernel/trace/trace_sched_wakeup.c | |||
| @@ -211,7 +211,7 @@ static void wakeup_reset(struct trace_array *tr) | |||
| 211 | } | 211 | } |
| 212 | 212 | ||
| 213 | static void | 213 | static void |
| 214 | probe_wakeup(struct rq *rq, struct task_struct *p) | 214 | probe_wakeup(struct rq *rq, struct task_struct *p, int success) |
| 215 | { | 215 | { |
| 216 | int cpu = smp_processor_id(); | 216 | int cpu = smp_processor_id(); |
| 217 | unsigned long flags; | 217 | unsigned long flags; |
diff --git a/kernel/trace/trace_sysprof.c b/kernel/trace/trace_sysprof.c index 54960edb96d0..01becf1f19ff 100644 --- a/kernel/trace/trace_sysprof.c +++ b/kernel/trace/trace_sysprof.c | |||
| @@ -234,20 +234,10 @@ static void stop_stack_timers(void) | |||
| 234 | stop_stack_timer(cpu); | 234 | stop_stack_timer(cpu); |
| 235 | } | 235 | } |
| 236 | 236 | ||
| 237 | static void stack_reset(struct trace_array *tr) | ||
| 238 | { | ||
| 239 | int cpu; | ||
| 240 | |||
| 241 | tr->time_start = ftrace_now(tr->cpu); | ||
| 242 | |||
| 243 | for_each_online_cpu(cpu) | ||
| 244 | tracing_reset(tr, cpu); | ||
| 245 | } | ||
| 246 | |||
| 247 | static void start_stack_trace(struct trace_array *tr) | 237 | static void start_stack_trace(struct trace_array *tr) |
| 248 | { | 238 | { |
| 249 | mutex_lock(&sample_timer_lock); | 239 | mutex_lock(&sample_timer_lock); |
| 250 | stack_reset(tr); | 240 | tracing_reset_online_cpus(tr); |
| 251 | start_stack_timers(); | 241 | start_stack_timers(); |
| 252 | tracer_enabled = 1; | 242 | tracer_enabled = 1; |
| 253 | mutex_unlock(&sample_timer_lock); | 243 | mutex_unlock(&sample_timer_lock); |
diff --git a/mm/mlock.c b/mm/mlock.c index 1ada366570cb..3035a56e7616 100644 --- a/mm/mlock.c +++ b/mm/mlock.c | |||
| @@ -667,3 +667,48 @@ void user_shm_unlock(size_t size, struct user_struct *user) | |||
| 667 | spin_unlock(&shmlock_user_lock); | 667 | spin_unlock(&shmlock_user_lock); |
| 668 | free_uid(user); | 668 | free_uid(user); |
| 669 | } | 669 | } |
| 670 | |||
| 671 | void *alloc_locked_buffer(size_t size) | ||
| 672 | { | ||
| 673 | unsigned long rlim, vm, pgsz; | ||
| 674 | void *buffer = NULL; | ||
| 675 | |||
| 676 | pgsz = PAGE_ALIGN(size) >> PAGE_SHIFT; | ||
| 677 | |||
| 678 | down_write(¤t->mm->mmap_sem); | ||
| 679 | |||
| 680 | rlim = current->signal->rlim[RLIMIT_AS].rlim_cur >> PAGE_SHIFT; | ||
| 681 | vm = current->mm->total_vm + pgsz; | ||
| 682 | if (rlim < vm) | ||
| 683 | goto out; | ||
| 684 | |||
| 685 | rlim = current->signal->rlim[RLIMIT_MEMLOCK].rlim_cur >> PAGE_SHIFT; | ||
| 686 | vm = current->mm->locked_vm + pgsz; | ||
| 687 | if (rlim < vm) | ||
| 688 | goto out; | ||
| 689 | |||
| 690 | buffer = kzalloc(size, GFP_KERNEL); | ||
| 691 | if (!buffer) | ||
| 692 | goto out; | ||
| 693 | |||
| 694 | current->mm->total_vm += pgsz; | ||
| 695 | current->mm->locked_vm += pgsz; | ||
| 696 | |||
| 697 | out: | ||
| 698 | up_write(¤t->mm->mmap_sem); | ||
| 699 | return buffer; | ||
| 700 | } | ||
| 701 | |||
| 702 | void free_locked_buffer(void *buffer, size_t size) | ||
| 703 | { | ||
| 704 | unsigned long pgsz = PAGE_ALIGN(size) >> PAGE_SHIFT; | ||
| 705 | |||
| 706 | down_write(¤t->mm->mmap_sem); | ||
| 707 | |||
| 708 | current->mm->total_vm -= pgsz; | ||
| 709 | current->mm->locked_vm -= pgsz; | ||
| 710 | |||
| 711 | up_write(¤t->mm->mmap_sem); | ||
| 712 | |||
| 713 | kfree(buffer); | ||
| 714 | } | ||
diff --git a/net/bluetooth/rfcomm/core.c b/net/bluetooth/rfcomm/core.c index ba537fae0a4c..ce68e046d963 100644 --- a/net/bluetooth/rfcomm/core.c +++ b/net/bluetooth/rfcomm/core.c | |||
| @@ -1786,8 +1786,6 @@ static inline void rfcomm_accept_connection(struct rfcomm_session *s) | |||
| 1786 | if (err < 0) | 1786 | if (err < 0) |
| 1787 | return; | 1787 | return; |
| 1788 | 1788 | ||
| 1789 | __module_get(nsock->ops->owner); | ||
| 1790 | |||
| 1791 | /* Set our callbacks */ | 1789 | /* Set our callbacks */ |
| 1792 | nsock->sk->sk_data_ready = rfcomm_l2data_ready; | 1790 | nsock->sk->sk_data_ready = rfcomm_l2data_ready; |
| 1793 | nsock->sk->sk_state_change = rfcomm_l2state_change; | 1791 | nsock->sk->sk_state_change = rfcomm_l2state_change; |
diff --git a/net/socket.c b/net/socket.c index 92764d836891..76ba80aeac1a 100644 --- a/net/socket.c +++ b/net/socket.c | |||
| @@ -2307,6 +2307,7 @@ int kernel_accept(struct socket *sock, struct socket **newsock, int flags) | |||
| 2307 | } | 2307 | } |
| 2308 | 2308 | ||
| 2309 | (*newsock)->ops = sock->ops; | 2309 | (*newsock)->ops = sock->ops; |
| 2310 | __module_get((*newsock)->ops->owner); | ||
| 2310 | 2311 | ||
| 2311 | done: | 2312 | done: |
| 2312 | return err; | 2313 | return err; |
diff --git a/sound/pci/hda/patch_sigmatel.c b/sound/pci/hda/patch_sigmatel.c index 5dd3e89f620a..b77f330d2650 100644 --- a/sound/pci/hda/patch_sigmatel.c +++ b/sound/pci/hda/patch_sigmatel.c | |||
| @@ -69,6 +69,7 @@ enum { | |||
| 69 | }; | 69 | }; |
| 70 | 70 | ||
| 71 | enum { | 71 | enum { |
| 72 | STAC_92HD73XX_NO_JD, /* no jack-detection */ | ||
| 72 | STAC_92HD73XX_REF, | 73 | STAC_92HD73XX_REF, |
| 73 | STAC_DELL_M6_AMIC, | 74 | STAC_DELL_M6_AMIC, |
| 74 | STAC_DELL_M6_DMIC, | 75 | STAC_DELL_M6_DMIC, |
| @@ -127,6 +128,7 @@ enum { | |||
| 127 | }; | 128 | }; |
| 128 | 129 | ||
| 129 | enum { | 130 | enum { |
| 131 | STAC_D965_REF_NO_JD, /* no jack-detection */ | ||
| 130 | STAC_D965_REF, | 132 | STAC_D965_REF, |
| 131 | STAC_D965_3ST, | 133 | STAC_D965_3ST, |
| 132 | STAC_D965_5ST, | 134 | STAC_D965_5ST, |
| @@ -857,6 +859,7 @@ static struct hda_verb stac92hd83xxx_core_init[] = { | |||
| 857 | 859 | ||
| 858 | /* power state controls amps */ | 860 | /* power state controls amps */ |
| 859 | { 0x01, AC_VERB_SET_EAPD, 1 << 2}, | 861 | { 0x01, AC_VERB_SET_EAPD, 1 << 2}, |
| 862 | {} | ||
| 860 | }; | 863 | }; |
| 861 | 864 | ||
| 862 | static struct hda_verb stac92hd71bxx_core_init[] = { | 865 | static struct hda_verb stac92hd71bxx_core_init[] = { |
| @@ -868,6 +871,7 @@ static struct hda_verb stac92hd71bxx_core_init[] = { | |||
| 868 | { 0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 871 | { 0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
| 869 | { 0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 872 | { 0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
| 870 | { 0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 873 | { 0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
| 874 | {} | ||
| 871 | }; | 875 | }; |
| 872 | 876 | ||
| 873 | #define HD_DISABLE_PORTF 2 | 877 | #define HD_DISABLE_PORTF 2 |
| @@ -1611,6 +1615,7 @@ static unsigned int *stac92hd73xx_brd_tbl[STAC_92HD73XX_MODELS] = { | |||
| 1611 | }; | 1615 | }; |
| 1612 | 1616 | ||
| 1613 | static const char *stac92hd73xx_models[STAC_92HD73XX_MODELS] = { | 1617 | static const char *stac92hd73xx_models[STAC_92HD73XX_MODELS] = { |
| 1618 | [STAC_92HD73XX_NO_JD] = "no-jd", | ||
| 1614 | [STAC_92HD73XX_REF] = "ref", | 1619 | [STAC_92HD73XX_REF] = "ref", |
| 1615 | [STAC_DELL_M6_AMIC] = "dell-m6-amic", | 1620 | [STAC_DELL_M6_AMIC] = "dell-m6-amic", |
| 1616 | [STAC_DELL_M6_DMIC] = "dell-m6-dmic", | 1621 | [STAC_DELL_M6_DMIC] = "dell-m6-dmic", |
| @@ -1640,6 +1645,8 @@ static struct snd_pci_quirk stac92hd73xx_cfg_tbl[] = { | |||
| 1640 | "unknown Dell", STAC_DELL_M6_DMIC), | 1645 | "unknown Dell", STAC_DELL_M6_DMIC), |
| 1641 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x029f, | 1646 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x029f, |
| 1642 | "Dell Studio 1537", STAC_DELL_M6_DMIC), | 1647 | "Dell Studio 1537", STAC_DELL_M6_DMIC), |
| 1648 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02a0, | ||
| 1649 | "Dell Studio 17", STAC_DELL_M6_DMIC), | ||
| 1643 | {} /* terminator */ | 1650 | {} /* terminator */ |
| 1644 | }; | 1651 | }; |
| 1645 | 1652 | ||
| @@ -1662,6 +1669,7 @@ static struct snd_pci_quirk stac92hd83xxx_cfg_tbl[] = { | |||
| 1662 | /* SigmaTel reference board */ | 1669 | /* SigmaTel reference board */ |
| 1663 | SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668, | 1670 | SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668, |
| 1664 | "DFI LanParty", STAC_92HD71BXX_REF), | 1671 | "DFI LanParty", STAC_92HD71BXX_REF), |
| 1672 | {} /* terminator */ | ||
| 1665 | }; | 1673 | }; |
| 1666 | 1674 | ||
| 1667 | static unsigned int ref92hd71bxx_pin_configs[11] = { | 1675 | static unsigned int ref92hd71bxx_pin_configs[11] = { |
| @@ -2027,6 +2035,7 @@ static unsigned int dell_3st_pin_configs[14] = { | |||
| 2027 | }; | 2035 | }; |
| 2028 | 2036 | ||
| 2029 | static unsigned int *stac927x_brd_tbl[STAC_927X_MODELS] = { | 2037 | static unsigned int *stac927x_brd_tbl[STAC_927X_MODELS] = { |
| 2038 | [STAC_D965_REF_NO_JD] = ref927x_pin_configs, | ||
| 2030 | [STAC_D965_REF] = ref927x_pin_configs, | 2039 | [STAC_D965_REF] = ref927x_pin_configs, |
| 2031 | [STAC_D965_3ST] = d965_3st_pin_configs, | 2040 | [STAC_D965_3ST] = d965_3st_pin_configs, |
| 2032 | [STAC_D965_5ST] = d965_5st_pin_configs, | 2041 | [STAC_D965_5ST] = d965_5st_pin_configs, |
| @@ -2035,6 +2044,7 @@ static unsigned int *stac927x_brd_tbl[STAC_927X_MODELS] = { | |||
| 2035 | }; | 2044 | }; |
| 2036 | 2045 | ||
| 2037 | static const char *stac927x_models[STAC_927X_MODELS] = { | 2046 | static const char *stac927x_models[STAC_927X_MODELS] = { |
| 2047 | [STAC_D965_REF_NO_JD] = "ref-no-jd", | ||
| 2038 | [STAC_D965_REF] = "ref", | 2048 | [STAC_D965_REF] = "ref", |
| 2039 | [STAC_D965_3ST] = "3stack", | 2049 | [STAC_D965_3ST] = "3stack", |
| 2040 | [STAC_D965_5ST] = "5stack", | 2050 | [STAC_D965_5ST] = "5stack", |
| @@ -2896,7 +2906,7 @@ static int stac92xx_auto_create_multi_out_ctls(struct hda_codec *codec, | |||
| 2896 | } | 2906 | } |
| 2897 | 2907 | ||
| 2898 | if ((spec->multiout.num_dacs - cfg->line_outs) > 0 && | 2908 | if ((spec->multiout.num_dacs - cfg->line_outs) > 0 && |
| 2899 | cfg->hp_outs && !spec->multiout.hp_nid) | 2909 | cfg->hp_outs == 1 && !spec->multiout.hp_nid) |
| 2900 | spec->multiout.hp_nid = nid; | 2910 | spec->multiout.hp_nid = nid; |
| 2901 | 2911 | ||
| 2902 | if (cfg->hp_outs > 1 && cfg->line_out_type == AUTO_PIN_LINE_OUT) { | 2912 | if (cfg->hp_outs > 1 && cfg->line_out_type == AUTO_PIN_LINE_OUT) { |
| @@ -4254,14 +4264,17 @@ again: | |||
| 4254 | 4264 | ||
| 4255 | switch (spec->multiout.num_dacs) { | 4265 | switch (spec->multiout.num_dacs) { |
| 4256 | case 0x3: /* 6 Channel */ | 4266 | case 0x3: /* 6 Channel */ |
| 4267 | spec->multiout.hp_nid = 0x17; | ||
| 4257 | spec->mixer = stac92hd73xx_6ch_mixer; | 4268 | spec->mixer = stac92hd73xx_6ch_mixer; |
| 4258 | spec->init = stac92hd73xx_6ch_core_init; | 4269 | spec->init = stac92hd73xx_6ch_core_init; |
| 4259 | break; | 4270 | break; |
| 4260 | case 0x4: /* 8 Channel */ | 4271 | case 0x4: /* 8 Channel */ |
| 4272 | spec->multiout.hp_nid = 0x18; | ||
| 4261 | spec->mixer = stac92hd73xx_8ch_mixer; | 4273 | spec->mixer = stac92hd73xx_8ch_mixer; |
| 4262 | spec->init = stac92hd73xx_8ch_core_init; | 4274 | spec->init = stac92hd73xx_8ch_core_init; |
| 4263 | break; | 4275 | break; |
| 4264 | case 0x5: /* 10 Channel */ | 4276 | case 0x5: /* 10 Channel */ |
| 4277 | spec->multiout.hp_nid = 0x19; | ||
| 4265 | spec->mixer = stac92hd73xx_10ch_mixer; | 4278 | spec->mixer = stac92hd73xx_10ch_mixer; |
| 4266 | spec->init = stac92hd73xx_10ch_core_init; | 4279 | spec->init = stac92hd73xx_10ch_core_init; |
| 4267 | }; | 4280 | }; |
| @@ -4297,6 +4310,7 @@ again: | |||
| 4297 | spec->amp_nids = &stac92hd73xx_amp_nids[DELL_M6_AMP]; | 4310 | spec->amp_nids = &stac92hd73xx_amp_nids[DELL_M6_AMP]; |
| 4298 | spec->eapd_switch = 0; | 4311 | spec->eapd_switch = 0; |
| 4299 | spec->num_amps = 1; | 4312 | spec->num_amps = 1; |
| 4313 | spec->multiout.hp_nid = 0; /* dual HPs */ | ||
| 4300 | 4314 | ||
| 4301 | if (!spec->init) | 4315 | if (!spec->init) |
| 4302 | spec->init = dell_m6_core_init; | 4316 | spec->init = dell_m6_core_init; |
| @@ -4351,6 +4365,9 @@ again: | |||
| 4351 | return err; | 4365 | return err; |
| 4352 | } | 4366 | } |
| 4353 | 4367 | ||
| 4368 | if (spec->board_config == STAC_92HD73XX_NO_JD) | ||
| 4369 | spec->hp_detect = 0; | ||
| 4370 | |||
| 4354 | codec->patch_ops = stac92xx_patch_ops; | 4371 | codec->patch_ops = stac92xx_patch_ops; |
| 4355 | 4372 | ||
| 4356 | return 0; | 4373 | return 0; |
| @@ -4899,6 +4916,10 @@ static int patch_stac927x(struct hda_codec *codec) | |||
| 4899 | */ | 4916 | */ |
| 4900 | codec->bus->needs_damn_long_delay = 1; | 4917 | codec->bus->needs_damn_long_delay = 1; |
| 4901 | 4918 | ||
| 4919 | /* no jack detecion for ref-no-jd model */ | ||
| 4920 | if (spec->board_config == STAC_D965_REF_NO_JD) | ||
| 4921 | spec->hp_detect = 0; | ||
| 4922 | |||
| 4902 | return 0; | 4923 | return 0; |
| 4903 | } | 4924 | } |
| 4904 | 4925 | ||
diff --git a/sound/soc/omap/omap-pcm.c b/sound/soc/omap/omap-pcm.c index e9084fdd2082..acd68efb2b75 100644 --- a/sound/soc/omap/omap-pcm.c +++ b/sound/soc/omap/omap-pcm.c | |||
| @@ -233,7 +233,7 @@ static int omap_pcm_open(struct snd_pcm_substream *substream) | |||
| 233 | if (ret < 0) | 233 | if (ret < 0) |
| 234 | goto out; | 234 | goto out; |
| 235 | 235 | ||
| 236 | prtd = kzalloc(sizeof(prtd), GFP_KERNEL); | 236 | prtd = kzalloc(sizeof(*prtd), GFP_KERNEL); |
| 237 | if (prtd == NULL) { | 237 | if (prtd == NULL) { |
| 238 | ret = -ENOMEM; | 238 | ret = -ENOMEM; |
| 239 | goto out; | 239 | goto out; |
