diff options
| author | David S. Miller <davem@davemloft.net> | 2012-04-23 23:14:36 -0400 |
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2012-04-23 23:15:17 -0400 |
| commit | f24001941c99776f41bd3f09c07d91205c2ad9d4 (patch) | |
| tree | 0ab31480ccdf343b61db045e195d096068ef7c73 | |
| parent | a108d5f35adc5c5d5cdc882dc0bb920565551bff (diff) | |
| parent | 4d634ca35a8b38530b134ae92bc9e3cc9c23c030 (diff) | |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net
Fix merge between commit 3adadc08cc1e ("net ax25: Reorder ax25_exit to
remove races") and commit 0ca7a4c87d27 ("net ax25: Simplify and
cleanup the ax25 sysctl handling")
The former moved around the sysctl register/unregister calls, the
later simply removed them.
With help from Stephen Rothwell.
Signed-off-by: David S. Miller <davem@davemloft.net>
449 files changed, 4115 insertions, 2864 deletions
diff --git a/Documentation/ABI/stable/sysfs-driver-usb-usbtmc b/Documentation/ABI/stable/sysfs-driver-usb-usbtmc index 2a7f9a00cb0a..e960cd027e1e 100644 --- a/Documentation/ABI/stable/sysfs-driver-usb-usbtmc +++ b/Documentation/ABI/stable/sysfs-driver-usb-usbtmc | |||
| @@ -1,5 +1,5 @@ | |||
| 1 | What: /sys/bus/usb/drivers/usbtmc/devices/*/interface_capabilities | 1 | What: /sys/bus/usb/drivers/usbtmc/*/interface_capabilities |
| 2 | What: /sys/bus/usb/drivers/usbtmc/devices/*/device_capabilities | 2 | What: /sys/bus/usb/drivers/usbtmc/*/device_capabilities |
| 3 | Date: August 2008 | 3 | Date: August 2008 |
| 4 | Contact: Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 4 | Contact: Greg Kroah-Hartman <gregkh@linuxfoundation.org> |
| 5 | Description: | 5 | Description: |
| @@ -12,8 +12,8 @@ Description: | |||
| 12 | The files are read only. | 12 | The files are read only. |
| 13 | 13 | ||
| 14 | 14 | ||
| 15 | What: /sys/bus/usb/drivers/usbtmc/devices/*/usb488_interface_capabilities | 15 | What: /sys/bus/usb/drivers/usbtmc/*/usb488_interface_capabilities |
| 16 | What: /sys/bus/usb/drivers/usbtmc/devices/*/usb488_device_capabilities | 16 | What: /sys/bus/usb/drivers/usbtmc/*/usb488_device_capabilities |
| 17 | Date: August 2008 | 17 | Date: August 2008 |
| 18 | Contact: Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 18 | Contact: Greg Kroah-Hartman <gregkh@linuxfoundation.org> |
| 19 | Description: | 19 | Description: |
| @@ -27,7 +27,7 @@ Description: | |||
| 27 | The files are read only. | 27 | The files are read only. |
| 28 | 28 | ||
| 29 | 29 | ||
| 30 | What: /sys/bus/usb/drivers/usbtmc/devices/*/TermChar | 30 | What: /sys/bus/usb/drivers/usbtmc/*/TermChar |
| 31 | Date: August 2008 | 31 | Date: August 2008 |
| 32 | Contact: Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 32 | Contact: Greg Kroah-Hartman <gregkh@linuxfoundation.org> |
| 33 | Description: | 33 | Description: |
| @@ -40,7 +40,7 @@ Description: | |||
| 40 | sent to the device or not. | 40 | sent to the device or not. |
| 41 | 41 | ||
| 42 | 42 | ||
| 43 | What: /sys/bus/usb/drivers/usbtmc/devices/*/TermCharEnabled | 43 | What: /sys/bus/usb/drivers/usbtmc/*/TermCharEnabled |
| 44 | Date: August 2008 | 44 | Date: August 2008 |
| 45 | Contact: Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 45 | Contact: Greg Kroah-Hartman <gregkh@linuxfoundation.org> |
| 46 | Description: | 46 | Description: |
| @@ -51,7 +51,7 @@ Description: | |||
| 51 | published by the USB-IF. | 51 | published by the USB-IF. |
| 52 | 52 | ||
| 53 | 53 | ||
| 54 | What: /sys/bus/usb/drivers/usbtmc/devices/*/auto_abort | 54 | What: /sys/bus/usb/drivers/usbtmc/*/auto_abort |
| 55 | Date: August 2008 | 55 | Date: August 2008 |
| 56 | Contact: Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 56 | Contact: Greg Kroah-Hartman <gregkh@linuxfoundation.org> |
| 57 | Description: | 57 | Description: |
diff --git a/Documentation/ABI/testing/sysfs-block-rssd b/Documentation/ABI/testing/sysfs-block-rssd new file mode 100644 index 000000000000..d535757799fe --- /dev/null +++ b/Documentation/ABI/testing/sysfs-block-rssd | |||
| @@ -0,0 +1,18 @@ | |||
| 1 | What: /sys/block/rssd*/registers | ||
| 2 | Date: March 2012 | ||
| 3 | KernelVersion: 3.3 | ||
| 4 | Contact: Asai Thambi S P <asamymuthupa@micron.com> | ||
| 5 | Description: This is a read-only file. Dumps below driver information and | ||
| 6 | hardware registers. | ||
| 7 | - S ACTive | ||
| 8 | - Command Issue | ||
| 9 | - Allocated | ||
| 10 | - Completed | ||
| 11 | - PORT IRQ STAT | ||
| 12 | - HOST IRQ STAT | ||
| 13 | |||
| 14 | What: /sys/block/rssd*/status | ||
| 15 | Date: April 2012 | ||
| 16 | KernelVersion: 3.4 | ||
| 17 | Contact: Asai Thambi S P <asamymuthupa@micron.com> | ||
| 18 | Description: This is a read-only file. Indicates the status of the device. | ||
diff --git a/Documentation/ABI/testing/sysfs-cfq-target-latency b/Documentation/ABI/testing/sysfs-cfq-target-latency new file mode 100644 index 000000000000..df0f7828c5e3 --- /dev/null +++ b/Documentation/ABI/testing/sysfs-cfq-target-latency | |||
| @@ -0,0 +1,8 @@ | |||
| 1 | What: /sys/block/<device>/iosched/target_latency | ||
| 2 | Date: March 2012 | ||
| 3 | contact: Tao Ma <boyu.mt@taobao.com> | ||
| 4 | Description: | ||
| 5 | The /sys/block/<device>/iosched/target_latency only exists | ||
| 6 | when the user sets cfq to /sys/block/<device>/scheduler. | ||
| 7 | It contains an estimated latency time for the cfq. cfq will | ||
| 8 | use it to calculate the time slice used for every task. | ||
diff --git a/Documentation/DocBook/media/v4l/pixfmt-nv12m.xml b/Documentation/DocBook/media/v4l/pixfmt-nv12m.xml index 3fd3ce5df270..5274c24d11e0 100644 --- a/Documentation/DocBook/media/v4l/pixfmt-nv12m.xml +++ b/Documentation/DocBook/media/v4l/pixfmt-nv12m.xml | |||
| @@ -1,6 +1,6 @@ | |||
| 1 | <refentry id="V4L2-PIX-FMT-NV12M"> | 1 | <refentry id="V4L2-PIX-FMT-NV12M"> |
| 2 | <refmeta> | 2 | <refmeta> |
| 3 | <refentrytitle>V4L2_PIX_FMT_NV12M ('NV12M')</refentrytitle> | 3 | <refentrytitle>V4L2_PIX_FMT_NV12M ('NM12')</refentrytitle> |
| 4 | &manvol; | 4 | &manvol; |
| 5 | </refmeta> | 5 | </refmeta> |
| 6 | <refnamediv> | 6 | <refnamediv> |
diff --git a/Documentation/DocBook/media/v4l/pixfmt-yuv420m.xml b/Documentation/DocBook/media/v4l/pixfmt-yuv420m.xml index 9957863daf18..60308f1eefdf 100644 --- a/Documentation/DocBook/media/v4l/pixfmt-yuv420m.xml +++ b/Documentation/DocBook/media/v4l/pixfmt-yuv420m.xml | |||
| @@ -1,6 +1,6 @@ | |||
| 1 | <refentry id="V4L2-PIX-FMT-YUV420M"> | 1 | <refentry id="V4L2-PIX-FMT-YUV420M"> |
| 2 | <refmeta> | 2 | <refmeta> |
| 3 | <refentrytitle>V4L2_PIX_FMT_YUV420M ('YU12M')</refentrytitle> | 3 | <refentrytitle>V4L2_PIX_FMT_YUV420M ('YM12')</refentrytitle> |
| 4 | &manvol; | 4 | &manvol; |
| 5 | </refmeta> | 5 | </refmeta> |
| 6 | <refnamediv> | 6 | <refnamediv> |
diff --git a/Documentation/feature-removal-schedule.txt b/Documentation/feature-removal-schedule.txt index 709e08e9a222..03ca210406ed 100644 --- a/Documentation/feature-removal-schedule.txt +++ b/Documentation/feature-removal-schedule.txt | |||
| @@ -531,3 +531,11 @@ Why: There appear to be no production users of the get_robust_list syscall, | |||
| 531 | of ASLR. It was only ever intended for debugging, so it should be | 531 | of ASLR. It was only ever intended for debugging, so it should be |
| 532 | removed. | 532 | removed. |
| 533 | Who: Kees Cook <keescook@chromium.org> | 533 | Who: Kees Cook <keescook@chromium.org> |
| 534 | |||
| 535 | ---------------------------- | ||
| 536 | |||
| 537 | What: setitimer accepts user NULL pointer (value) | ||
| 538 | When: 3.6 | ||
| 539 | Why: setitimer is not returning -EFAULT if user pointer is NULL. This | ||
| 540 | violates the spec. | ||
| 541 | Who: Sasikantha Babu <sasikanth.v19@gmail.com> | ||
diff --git a/Documentation/sound/alsa/HD-Audio-Models.txt b/Documentation/sound/alsa/HD-Audio-Models.txt index d97d992ced14..03f7897c6414 100644 --- a/Documentation/sound/alsa/HD-Audio-Models.txt +++ b/Documentation/sound/alsa/HD-Audio-Models.txt | |||
| @@ -43,7 +43,9 @@ ALC680 | |||
| 43 | 43 | ||
| 44 | ALC882/883/885/888/889 | 44 | ALC882/883/885/888/889 |
| 45 | ====================== | 45 | ====================== |
| 46 | N/A | 46 | acer-aspire-4930g Acer Aspire 4930G/5930G/6530G/6930G/7730G |
| 47 | acer-aspire-8930g Acer Aspire 8330G/6935G | ||
| 48 | acer-aspire Acer Aspire others | ||
| 47 | 49 | ||
| 48 | ALC861/660 | 50 | ALC861/660 |
| 49 | ========== | 51 | ========== |
diff --git a/Documentation/usb/URB.txt b/Documentation/usb/URB.txt index 8ffce746d496..00d2c644068e 100644 --- a/Documentation/usb/URB.txt +++ b/Documentation/usb/URB.txt | |||
| @@ -168,6 +168,28 @@ that if the completion handler or anyone else tries to resubmit it | |||
| 168 | they will get a -EPERM error. Thus you can be sure that when | 168 | they will get a -EPERM error. Thus you can be sure that when |
| 169 | usb_kill_urb() returns, the URB is totally idle. | 169 | usb_kill_urb() returns, the URB is totally idle. |
| 170 | 170 | ||
| 171 | There is a lifetime issue to consider. An URB may complete at any | ||
| 172 | time, and the completion handler may free the URB. If this happens | ||
| 173 | while usb_unlink_urb or usb_kill_urb is running, it will cause a | ||
| 174 | memory-access violation. The driver is responsible for avoiding this, | ||
| 175 | which often means some sort of lock will be needed to prevent the URB | ||
| 176 | from being deallocated while it is still in use. | ||
| 177 | |||
| 178 | On the other hand, since usb_unlink_urb may end up calling the | ||
| 179 | completion handler, the handler must not take any lock that is held | ||
| 180 | when usb_unlink_urb is invoked. The general solution to this problem | ||
| 181 | is to increment the URB's reference count while holding the lock, then | ||
| 182 | drop the lock and call usb_unlink_urb or usb_kill_urb, and then | ||
| 183 | decrement the URB's reference count. You increment the reference | ||
| 184 | count by calling | ||
| 185 | |||
| 186 | struct urb *usb_get_urb(struct urb *urb) | ||
| 187 | |||
| 188 | (ignore the return value; it is the same as the argument) and | ||
| 189 | decrement the reference count by calling usb_free_urb. Of course, | ||
| 190 | none of this is necessary if there's no danger of the URB being freed | ||
| 191 | by the completion handler. | ||
| 192 | |||
| 171 | 193 | ||
| 172 | 1.7. What about the completion handler? | 194 | 1.7. What about the completion handler? |
| 173 | 195 | ||
diff --git a/Documentation/usb/usbmon.txt b/Documentation/usb/usbmon.txt index 5335fa8b06eb..c42bb9cd3b43 100644 --- a/Documentation/usb/usbmon.txt +++ b/Documentation/usb/usbmon.txt | |||
| @@ -183,10 +183,10 @@ An input control transfer to get a port status. | |||
| 183 | d5ea89a0 3575914555 S Ci:1:001:0 s a3 00 0000 0003 0004 4 < | 183 | d5ea89a0 3575914555 S Ci:1:001:0 s a3 00 0000 0003 0004 4 < |
| 184 | d5ea89a0 3575914560 C Ci:1:001:0 0 4 = 01050000 | 184 | d5ea89a0 3575914560 C Ci:1:001:0 0 4 = 01050000 |
| 185 | 185 | ||
| 186 | An output bulk transfer to send a SCSI command 0x5E in a 31-byte Bulk wrapper | 186 | An output bulk transfer to send a SCSI command 0x28 (READ_10) in a 31-byte |
| 187 | to a storage device at address 5: | 187 | Bulk wrapper to a storage device at address 5: |
| 188 | 188 | ||
| 189 | dd65f0e8 4128379752 S Bo:1:005:2 -115 31 = 55534243 5e000000 00000000 00000600 00000000 00000000 00000000 000000 | 189 | dd65f0e8 4128379752 S Bo:1:005:2 -115 31 = 55534243 ad000000 00800000 80010a28 20000000 20000040 00000000 000000 |
| 190 | dd65f0e8 4128379808 C Bo:1:005:2 0 31 > | 190 | dd65f0e8 4128379808 C Bo:1:005:2 0 31 > |
| 191 | 191 | ||
| 192 | * Raw binary format and API | 192 | * Raw binary format and API |
diff --git a/MAINTAINERS b/MAINTAINERS index 250f59cc9d3c..a6fcc1eb56a0 100644 --- a/MAINTAINERS +++ b/MAINTAINERS | |||
| @@ -2322,9 +2322,9 @@ S: Supported | |||
| 2322 | F: drivers/acpi/dock.c | 2322 | F: drivers/acpi/dock.c |
| 2323 | 2323 | ||
| 2324 | DOCUMENTATION | 2324 | DOCUMENTATION |
| 2325 | M: Randy Dunlap <rdunlap@xenotime.net> | 2325 | M: Rob Landley <rob@landley.net> |
| 2326 | L: linux-doc@vger.kernel.org | 2326 | L: linux-doc@vger.kernel.org |
| 2327 | T: quilt http://xenotime.net/kernel-doc-patches/current/ | 2327 | T: TBD |
| 2328 | S: Maintained | 2328 | S: Maintained |
| 2329 | F: Documentation/ | 2329 | F: Documentation/ |
| 2330 | 2330 | ||
| @@ -3587,6 +3587,7 @@ S: Supported | |||
| 3587 | F: drivers/net/wireless/iwlegacy/ | 3587 | F: drivers/net/wireless/iwlegacy/ |
| 3588 | 3588 | ||
| 3589 | INTEL WIRELESS WIFI LINK (iwlwifi) | 3589 | INTEL WIRELESS WIFI LINK (iwlwifi) |
| 3590 | M: Johannes Berg <johannes.berg@intel.com> | ||
| 3590 | M: Wey-Yi Guy <wey-yi.w.guy@intel.com> | 3591 | M: Wey-Yi Guy <wey-yi.w.guy@intel.com> |
| 3591 | M: Intel Linux Wireless <ilw@linux.intel.com> | 3592 | M: Intel Linux Wireless <ilw@linux.intel.com> |
| 3592 | L: linux-wireless@vger.kernel.org | 3593 | L: linux-wireless@vger.kernel.org |
| @@ -6466,6 +6467,7 @@ S: Odd Fixes | |||
| 6466 | F: drivers/staging/olpc_dcon/ | 6467 | F: drivers/staging/olpc_dcon/ |
| 6467 | 6468 | ||
| 6468 | STAGING - OZMO DEVICES USB OVER WIFI DRIVER | 6469 | STAGING - OZMO DEVICES USB OVER WIFI DRIVER |
| 6470 | M: Rupesh Gujare <rgujare@ozmodevices.com> | ||
| 6469 | M: Chris Kelly <ckelly@ozmodevices.com> | 6471 | M: Chris Kelly <ckelly@ozmodevices.com> |
| 6470 | S: Maintained | 6472 | S: Maintained |
| 6471 | F: drivers/staging/ozwpan/ | 6473 | F: drivers/staging/ozwpan/ |
| @@ -1,7 +1,7 @@ | |||
| 1 | VERSION = 3 | 1 | VERSION = 3 |
| 2 | PATCHLEVEL = 4 | 2 | PATCHLEVEL = 4 |
| 3 | SUBLEVEL = 0 | 3 | SUBLEVEL = 0 |
| 4 | EXTRAVERSION = -rc2 | 4 | EXTRAVERSION = -rc4 |
| 5 | NAME = Saber-toothed Squirrel | 5 | NAME = Saber-toothed Squirrel |
| 6 | 6 | ||
| 7 | # *DOCUMENTATION* | 7 | # *DOCUMENTATION* |
diff --git a/arch/alpha/include/asm/atomic.h b/arch/alpha/include/asm/atomic.h index f62251e82ffa..3bb7ffeae3bc 100644 --- a/arch/alpha/include/asm/atomic.h +++ b/arch/alpha/include/asm/atomic.h | |||
| @@ -3,6 +3,7 @@ | |||
| 3 | 3 | ||
| 4 | #include <linux/types.h> | 4 | #include <linux/types.h> |
| 5 | #include <asm/barrier.h> | 5 | #include <asm/barrier.h> |
| 6 | #include <asm/cmpxchg.h> | ||
| 6 | 7 | ||
| 7 | /* | 8 | /* |
| 8 | * Atomic operations that C can't guarantee us. Useful for | 9 | * Atomic operations that C can't guarantee us. Useful for |
| @@ -168,73 +169,6 @@ static __inline__ long atomic64_sub_return(long i, atomic64_t * v) | |||
| 168 | return result; | 169 | return result; |
| 169 | } | 170 | } |
| 170 | 171 | ||
| 171 | /* | ||
| 172 | * Atomic exchange routines. | ||
| 173 | */ | ||
| 174 | |||
| 175 | #define __ASM__MB | ||
| 176 | #define ____xchg(type, args...) __xchg ## type ## _local(args) | ||
| 177 | #define ____cmpxchg(type, args...) __cmpxchg ## type ## _local(args) | ||
| 178 | #include <asm/xchg.h> | ||
| 179 | |||
| 180 | #define xchg_local(ptr,x) \ | ||
| 181 | ({ \ | ||
| 182 | __typeof__(*(ptr)) _x_ = (x); \ | ||
| 183 | (__typeof__(*(ptr))) __xchg_local((ptr), (unsigned long)_x_, \ | ||
| 184 | sizeof(*(ptr))); \ | ||
| 185 | }) | ||
| 186 | |||
| 187 | #define cmpxchg_local(ptr, o, n) \ | ||
| 188 | ({ \ | ||
| 189 | __typeof__(*(ptr)) _o_ = (o); \ | ||
| 190 | __typeof__(*(ptr)) _n_ = (n); \ | ||
| 191 | (__typeof__(*(ptr))) __cmpxchg_local((ptr), (unsigned long)_o_, \ | ||
| 192 | (unsigned long)_n_, \ | ||
| 193 | sizeof(*(ptr))); \ | ||
| 194 | }) | ||
| 195 | |||
| 196 | #define cmpxchg64_local(ptr, o, n) \ | ||
| 197 | ({ \ | ||
| 198 | BUILD_BUG_ON(sizeof(*(ptr)) != 8); \ | ||
| 199 | cmpxchg_local((ptr), (o), (n)); \ | ||
| 200 | }) | ||
| 201 | |||
| 202 | #ifdef CONFIG_SMP | ||
| 203 | #undef __ASM__MB | ||
| 204 | #define __ASM__MB "\tmb\n" | ||
| 205 | #endif | ||
| 206 | #undef ____xchg | ||
| 207 | #undef ____cmpxchg | ||
| 208 | #define ____xchg(type, args...) __xchg ##type(args) | ||
| 209 | #define ____cmpxchg(type, args...) __cmpxchg ##type(args) | ||
| 210 | #include <asm/xchg.h> | ||
| 211 | |||
| 212 | #define xchg(ptr,x) \ | ||
| 213 | ({ \ | ||
| 214 | __typeof__(*(ptr)) _x_ = (x); \ | ||
| 215 | (__typeof__(*(ptr))) __xchg((ptr), (unsigned long)_x_, \ | ||
| 216 | sizeof(*(ptr))); \ | ||
| 217 | }) | ||
| 218 | |||
| 219 | #define cmpxchg(ptr, o, n) \ | ||
| 220 | ({ \ | ||
| 221 | __typeof__(*(ptr)) _o_ = (o); \ | ||
| 222 | __typeof__(*(ptr)) _n_ = (n); \ | ||
| 223 | (__typeof__(*(ptr))) __cmpxchg((ptr), (unsigned long)_o_, \ | ||
| 224 | (unsigned long)_n_, sizeof(*(ptr)));\ | ||
| 225 | }) | ||
| 226 | |||
| 227 | #define cmpxchg64(ptr, o, n) \ | ||
| 228 | ({ \ | ||
| 229 | BUILD_BUG_ON(sizeof(*(ptr)) != 8); \ | ||
| 230 | cmpxchg((ptr), (o), (n)); \ | ||
| 231 | }) | ||
| 232 | |||
| 233 | #undef __ASM__MB | ||
| 234 | #undef ____cmpxchg | ||
| 235 | |||
| 236 | #define __HAVE_ARCH_CMPXCHG 1 | ||
| 237 | |||
| 238 | #define atomic64_cmpxchg(v, old, new) (cmpxchg(&((v)->counter), old, new)) | 172 | #define atomic64_cmpxchg(v, old, new) (cmpxchg(&((v)->counter), old, new)) |
| 239 | #define atomic64_xchg(v, new) (xchg(&((v)->counter), new)) | 173 | #define atomic64_xchg(v, new) (xchg(&((v)->counter), new)) |
| 240 | 174 | ||
diff --git a/arch/alpha/include/asm/cmpxchg.h b/arch/alpha/include/asm/cmpxchg.h new file mode 100644 index 000000000000..429e8cd0d78e --- /dev/null +++ b/arch/alpha/include/asm/cmpxchg.h | |||
| @@ -0,0 +1,71 @@ | |||
| 1 | #ifndef _ALPHA_CMPXCHG_H | ||
| 2 | #define _ALPHA_CMPXCHG_H | ||
| 3 | |||
| 4 | /* | ||
| 5 | * Atomic exchange routines. | ||
| 6 | */ | ||
| 7 | |||
| 8 | #define __ASM__MB | ||
| 9 | #define ____xchg(type, args...) __xchg ## type ## _local(args) | ||
| 10 | #define ____cmpxchg(type, args...) __cmpxchg ## type ## _local(args) | ||
| 11 | #include <asm/xchg.h> | ||
| 12 | |||
| 13 | #define xchg_local(ptr, x) \ | ||
| 14 | ({ \ | ||
| 15 | __typeof__(*(ptr)) _x_ = (x); \ | ||
| 16 | (__typeof__(*(ptr))) __xchg_local((ptr), (unsigned long)_x_, \ | ||
| 17 | sizeof(*(ptr))); \ | ||
| 18 | }) | ||
| 19 | |||
| 20 | #define cmpxchg_local(ptr, o, n) \ | ||
| 21 | ({ \ | ||
| 22 | __typeof__(*(ptr)) _o_ = (o); \ | ||
| 23 | __typeof__(*(ptr)) _n_ = (n); \ | ||
| 24 | (__typeof__(*(ptr))) __cmpxchg_local((ptr), (unsigned long)_o_, \ | ||
| 25 | (unsigned long)_n_, \ | ||
| 26 | sizeof(*(ptr))); \ | ||
| 27 | }) | ||
| 28 | |||
| 29 | #define cmpxchg64_local(ptr, o, n) \ | ||
| 30 | ({ \ | ||
| 31 | BUILD_BUG_ON(sizeof(*(ptr)) != 8); \ | ||
| 32 | cmpxchg_local((ptr), (o), (n)); \ | ||
| 33 | }) | ||
| 34 | |||
| 35 | #ifdef CONFIG_SMP | ||
| 36 | #undef __ASM__MB | ||
| 37 | #define __ASM__MB "\tmb\n" | ||
| 38 | #endif | ||
| 39 | #undef ____xchg | ||
| 40 | #undef ____cmpxchg | ||
| 41 | #define ____xchg(type, args...) __xchg ##type(args) | ||
| 42 | #define ____cmpxchg(type, args...) __cmpxchg ##type(args) | ||
| 43 | #include <asm/xchg.h> | ||
| 44 | |||
| 45 | #define xchg(ptr, x) \ | ||
| 46 | ({ \ | ||
| 47 | __typeof__(*(ptr)) _x_ = (x); \ | ||
| 48 | (__typeof__(*(ptr))) __xchg((ptr), (unsigned long)_x_, \ | ||
| 49 | sizeof(*(ptr))); \ | ||
| 50 | }) | ||
| 51 | |||
| 52 | #define cmpxchg(ptr, o, n) \ | ||
| 53 | ({ \ | ||
| 54 | __typeof__(*(ptr)) _o_ = (o); \ | ||
| 55 | __typeof__(*(ptr)) _n_ = (n); \ | ||
| 56 | (__typeof__(*(ptr))) __cmpxchg((ptr), (unsigned long)_o_, \ | ||
| 57 | (unsigned long)_n_, sizeof(*(ptr)));\ | ||
| 58 | }) | ||
| 59 | |||
| 60 | #define cmpxchg64(ptr, o, n) \ | ||
| 61 | ({ \ | ||
| 62 | BUILD_BUG_ON(sizeof(*(ptr)) != 8); \ | ||
| 63 | cmpxchg((ptr), (o), (n)); \ | ||
| 64 | }) | ||
| 65 | |||
| 66 | #undef __ASM__MB | ||
| 67 | #undef ____cmpxchg | ||
| 68 | |||
| 69 | #define __HAVE_ARCH_CMPXCHG 1 | ||
| 70 | |||
| 71 | #endif /* _ALPHA_CMPXCHG_H */ | ||
diff --git a/arch/alpha/include/asm/xchg.h b/arch/alpha/include/asm/xchg.h index 1d1b436fbff2..0ca9724597c1 100644 --- a/arch/alpha/include/asm/xchg.h +++ b/arch/alpha/include/asm/xchg.h | |||
| @@ -1,10 +1,10 @@ | |||
| 1 | #ifndef _ALPHA_ATOMIC_H | 1 | #ifndef _ALPHA_CMPXCHG_H |
| 2 | #error Do not include xchg.h directly! | 2 | #error Do not include xchg.h directly! |
| 3 | #else | 3 | #else |
| 4 | /* | 4 | /* |
| 5 | * xchg/xchg_local and cmpxchg/cmpxchg_local share the same code | 5 | * xchg/xchg_local and cmpxchg/cmpxchg_local share the same code |
| 6 | * except that local version do not have the expensive memory barrier. | 6 | * except that local version do not have the expensive memory barrier. |
| 7 | * So this file is included twice from asm/system.h. | 7 | * So this file is included twice from asm/cmpxchg.h. |
| 8 | */ | 8 | */ |
| 9 | 9 | ||
| 10 | /* | 10 | /* |
diff --git a/arch/arm/boot/compressed/atags_to_fdt.c b/arch/arm/boot/compressed/atags_to_fdt.c index 6ce11c481178..797f04bedb47 100644 --- a/arch/arm/boot/compressed/atags_to_fdt.c +++ b/arch/arm/boot/compressed/atags_to_fdt.c | |||
| @@ -77,6 +77,8 @@ int atags_to_fdt(void *atag_list, void *fdt, int total_space) | |||
| 77 | } else if (atag->hdr.tag == ATAG_MEM) { | 77 | } else if (atag->hdr.tag == ATAG_MEM) { |
| 78 | if (memcount >= sizeof(mem_reg_property)/4) | 78 | if (memcount >= sizeof(mem_reg_property)/4) |
| 79 | continue; | 79 | continue; |
| 80 | if (!atag->u.mem.size) | ||
| 81 | continue; | ||
| 80 | mem_reg_property[memcount++] = cpu_to_fdt32(atag->u.mem.start); | 82 | mem_reg_property[memcount++] = cpu_to_fdt32(atag->u.mem.start); |
| 81 | mem_reg_property[memcount++] = cpu_to_fdt32(atag->u.mem.size); | 83 | mem_reg_property[memcount++] = cpu_to_fdt32(atag->u.mem.size); |
| 82 | } else if (atag->hdr.tag == ATAG_INITRD2) { | 84 | } else if (atag->hdr.tag == ATAG_INITRD2) { |
diff --git a/arch/arm/boot/compressed/head.S b/arch/arm/boot/compressed/head.S index 5f6045f1766c..dc7e8ce8e6be 100644 --- a/arch/arm/boot/compressed/head.S +++ b/arch/arm/boot/compressed/head.S | |||
| @@ -273,7 +273,7 @@ restart: adr r0, LC0 | |||
| 273 | add r0, r0, #0x100 | 273 | add r0, r0, #0x100 |
| 274 | mov r1, r6 | 274 | mov r1, r6 |
| 275 | sub r2, sp, r6 | 275 | sub r2, sp, r6 |
| 276 | blne atags_to_fdt | 276 | bleq atags_to_fdt |
| 277 | 277 | ||
| 278 | ldmfd sp!, {r0-r3, ip, lr} | 278 | ldmfd sp!, {r0-r3, ip, lr} |
| 279 | sub sp, sp, #0x10000 | 279 | sub sp, sp, #0x10000 |
diff --git a/arch/arm/boot/dts/at91sam9g20.dtsi b/arch/arm/boot/dts/at91sam9g20.dtsi index 799ad1889b51..773ef484037a 100644 --- a/arch/arm/boot/dts/at91sam9g20.dtsi +++ b/arch/arm/boot/dts/at91sam9g20.dtsi | |||
| @@ -55,7 +55,6 @@ | |||
| 55 | #interrupt-cells = <2>; | 55 | #interrupt-cells = <2>; |
| 56 | compatible = "atmel,at91rm9200-aic"; | 56 | compatible = "atmel,at91rm9200-aic"; |
| 57 | interrupt-controller; | 57 | interrupt-controller; |
| 58 | interrupt-parent; | ||
| 59 | reg = <0xfffff000 0x200>; | 58 | reg = <0xfffff000 0x200>; |
| 60 | }; | 59 | }; |
| 61 | 60 | ||
diff --git a/arch/arm/boot/dts/at91sam9g45.dtsi b/arch/arm/boot/dts/at91sam9g45.dtsi index 9e6eb6ecea0e..c8042147eaa2 100644 --- a/arch/arm/boot/dts/at91sam9g45.dtsi +++ b/arch/arm/boot/dts/at91sam9g45.dtsi | |||
| @@ -56,7 +56,6 @@ | |||
| 56 | #interrupt-cells = <2>; | 56 | #interrupt-cells = <2>; |
| 57 | compatible = "atmel,at91rm9200-aic"; | 57 | compatible = "atmel,at91rm9200-aic"; |
| 58 | interrupt-controller; | 58 | interrupt-controller; |
| 59 | interrupt-parent; | ||
| 60 | reg = <0xfffff000 0x200>; | 59 | reg = <0xfffff000 0x200>; |
| 61 | }; | 60 | }; |
| 62 | 61 | ||
diff --git a/arch/arm/boot/dts/at91sam9x5.dtsi b/arch/arm/boot/dts/at91sam9x5.dtsi index 70ab3a4e026f..dd4ed748469a 100644 --- a/arch/arm/boot/dts/at91sam9x5.dtsi +++ b/arch/arm/boot/dts/at91sam9x5.dtsi | |||
| @@ -54,7 +54,6 @@ | |||
| 54 | #interrupt-cells = <2>; | 54 | #interrupt-cells = <2>; |
| 55 | compatible = "atmel,at91rm9200-aic"; | 55 | compatible = "atmel,at91rm9200-aic"; |
| 56 | interrupt-controller; | 56 | interrupt-controller; |
| 57 | interrupt-parent; | ||
| 58 | reg = <0xfffff000 0x200>; | 57 | reg = <0xfffff000 0x200>; |
| 59 | }; | 58 | }; |
| 60 | 59 | ||
diff --git a/arch/arm/boot/dts/db8500.dtsi b/arch/arm/boot/dts/db8500.dtsi index d73dce645667..14bc30705099 100644 --- a/arch/arm/boot/dts/db8500.dtsi +++ b/arch/arm/boot/dts/db8500.dtsi | |||
| @@ -24,7 +24,6 @@ | |||
| 24 | #interrupt-cells = <3>; | 24 | #interrupt-cells = <3>; |
| 25 | #address-cells = <1>; | 25 | #address-cells = <1>; |
| 26 | interrupt-controller; | 26 | interrupt-controller; |
| 27 | interrupt-parent; | ||
| 28 | reg = <0xa0411000 0x1000>, | 27 | reg = <0xa0411000 0x1000>, |
| 29 | <0xa0410100 0x100>; | 28 | <0xa0410100 0x100>; |
| 30 | }; | 29 | }; |
diff --git a/arch/arm/boot/dts/highbank.dts b/arch/arm/boot/dts/highbank.dts index 37c0ff9c8b90..83e72294aefb 100644 --- a/arch/arm/boot/dts/highbank.dts +++ b/arch/arm/boot/dts/highbank.dts | |||
| @@ -89,7 +89,6 @@ | |||
| 89 | #size-cells = <0>; | 89 | #size-cells = <0>; |
| 90 | #address-cells = <1>; | 90 | #address-cells = <1>; |
| 91 | interrupt-controller; | 91 | interrupt-controller; |
| 92 | interrupt-parent; | ||
| 93 | reg = <0xfff11000 0x1000>, | 92 | reg = <0xfff11000 0x1000>, |
| 94 | <0xfff10100 0x100>; | 93 | <0xfff10100 0x100>; |
| 95 | }; | 94 | }; |
diff --git a/arch/arm/common/vic.c b/arch/arm/common/vic.c index 7a66311f3066..7e288f96cedf 100644 --- a/arch/arm/common/vic.c +++ b/arch/arm/common/vic.c | |||
| @@ -427,19 +427,18 @@ int __init vic_of_init(struct device_node *node, struct device_node *parent) | |||
| 427 | 427 | ||
| 428 | /* | 428 | /* |
| 429 | * Handle each interrupt in a single VIC. Returns non-zero if we've | 429 | * Handle each interrupt in a single VIC. Returns non-zero if we've |
| 430 | * handled at least one interrupt. This does a single read of the | 430 | * handled at least one interrupt. This reads the status register |
| 431 | * status register and handles all interrupts in order from LSB first. | 431 | * before handling each interrupt, which is necessary given that |
| 432 | * handle_IRQ may briefly re-enable interrupts for soft IRQ handling. | ||
| 432 | */ | 433 | */ |
| 433 | static int handle_one_vic(struct vic_device *vic, struct pt_regs *regs) | 434 | static int handle_one_vic(struct vic_device *vic, struct pt_regs *regs) |
| 434 | { | 435 | { |
| 435 | u32 stat, irq; | 436 | u32 stat, irq; |
| 436 | int handled = 0; | 437 | int handled = 0; |
| 437 | 438 | ||
| 438 | stat = readl_relaxed(vic->base + VIC_IRQ_STATUS); | 439 | while ((stat = readl_relaxed(vic->base + VIC_IRQ_STATUS))) { |
| 439 | while (stat) { | ||
| 440 | irq = ffs(stat) - 1; | 440 | irq = ffs(stat) - 1; |
| 441 | handle_IRQ(irq_find_mapping(vic->domain, irq), regs); | 441 | handle_IRQ(irq_find_mapping(vic->domain, irq), regs); |
| 442 | stat &= ~(1 << irq); | ||
| 443 | handled = 1; | 442 | handled = 1; |
| 444 | } | 443 | } |
| 445 | 444 | ||
diff --git a/arch/arm/configs/imx_v4_v5_defconfig b/arch/arm/configs/imx_v4_v5_defconfig index b5ac644e12af..6b31cb60daab 100644 --- a/arch/arm/configs/imx_v4_v5_defconfig +++ b/arch/arm/configs/imx_v4_v5_defconfig | |||
| @@ -112,6 +112,7 @@ CONFIG_WATCHDOG=y | |||
| 112 | CONFIG_IMX2_WDT=y | 112 | CONFIG_IMX2_WDT=y |
| 113 | CONFIG_MFD_MC13XXX=y | 113 | CONFIG_MFD_MC13XXX=y |
| 114 | CONFIG_REGULATOR=y | 114 | CONFIG_REGULATOR=y |
| 115 | CONFIG_REGULATOR_FIXED_VOLTAGE=y | ||
| 115 | CONFIG_REGULATOR_MC13783=y | 116 | CONFIG_REGULATOR_MC13783=y |
| 116 | CONFIG_REGULATOR_MC13892=y | 117 | CONFIG_REGULATOR_MC13892=y |
| 117 | CONFIG_FB=y | 118 | CONFIG_FB=y |
diff --git a/arch/arm/configs/u8500_defconfig b/arch/arm/configs/u8500_defconfig index 889d73ac1ae1..7e84f453e8a6 100644 --- a/arch/arm/configs/u8500_defconfig +++ b/arch/arm/configs/u8500_defconfig | |||
| @@ -8,8 +8,6 @@ CONFIG_MODULE_UNLOAD=y | |||
| 8 | # CONFIG_LBDAF is not set | 8 | # CONFIG_LBDAF is not set |
| 9 | # CONFIG_BLK_DEV_BSG is not set | 9 | # CONFIG_BLK_DEV_BSG is not set |
| 10 | CONFIG_ARCH_U8500=y | 10 | CONFIG_ARCH_U8500=y |
| 11 | CONFIG_UX500_SOC_DB5500=y | ||
| 12 | CONFIG_UX500_SOC_DB8500=y | ||
| 13 | CONFIG_MACH_HREFV60=y | 11 | CONFIG_MACH_HREFV60=y |
| 14 | CONFIG_MACH_SNOWBALL=y | 12 | CONFIG_MACH_SNOWBALL=y |
| 15 | CONFIG_MACH_U5500=y | 13 | CONFIG_MACH_U5500=y |
| @@ -39,7 +37,6 @@ CONFIG_CAIF=y | |||
| 39 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" | 37 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" |
| 40 | CONFIG_BLK_DEV_RAM=y | 38 | CONFIG_BLK_DEV_RAM=y |
| 41 | CONFIG_BLK_DEV_RAM_SIZE=65536 | 39 | CONFIG_BLK_DEV_RAM_SIZE=65536 |
| 42 | CONFIG_MISC_DEVICES=y | ||
| 43 | CONFIG_AB8500_PWM=y | 40 | CONFIG_AB8500_PWM=y |
| 44 | CONFIG_SENSORS_BH1780=y | 41 | CONFIG_SENSORS_BH1780=y |
| 45 | CONFIG_NETDEVICES=y | 42 | CONFIG_NETDEVICES=y |
| @@ -65,16 +62,18 @@ CONFIG_SERIAL_AMBA_PL011=y | |||
| 65 | CONFIG_SERIAL_AMBA_PL011_CONSOLE=y | 62 | CONFIG_SERIAL_AMBA_PL011_CONSOLE=y |
| 66 | CONFIG_HW_RANDOM=y | 63 | CONFIG_HW_RANDOM=y |
| 67 | CONFIG_HW_RANDOM_NOMADIK=y | 64 | CONFIG_HW_RANDOM_NOMADIK=y |
| 68 | CONFIG_I2C=y | ||
| 69 | CONFIG_I2C_NOMADIK=y | ||
| 70 | CONFIG_SPI=y | 65 | CONFIG_SPI=y |
| 71 | CONFIG_SPI_PL022=y | 66 | CONFIG_SPI_PL022=y |
| 72 | CONFIG_GPIO_STMPE=y | 67 | CONFIG_GPIO_STMPE=y |
| 73 | CONFIG_GPIO_TC3589X=y | 68 | CONFIG_GPIO_TC3589X=y |
| 69 | CONFIG_POWER_SUPPLY=y | ||
| 70 | CONFIG_AB8500_BM=y | ||
| 71 | CONFIG_AB8500_BATTERY_THERM_ON_BATCTRL=y | ||
| 74 | CONFIG_MFD_STMPE=y | 72 | CONFIG_MFD_STMPE=y |
| 75 | CONFIG_MFD_TC3589X=y | 73 | CONFIG_MFD_TC3589X=y |
| 76 | CONFIG_AB5500_CORE=y | 74 | CONFIG_AB5500_CORE=y |
| 77 | CONFIG_AB8500_CORE=y | 75 | CONFIG_AB8500_CORE=y |
| 76 | CONFIG_REGULATOR=y | ||
| 78 | CONFIG_REGULATOR_AB8500=y | 77 | CONFIG_REGULATOR_AB8500=y |
| 79 | # CONFIG_HID_SUPPORT is not set | 78 | # CONFIG_HID_SUPPORT is not set |
| 80 | CONFIG_USB_GADGET=y | 79 | CONFIG_USB_GADGET=y |
diff --git a/arch/arm/include/asm/jump_label.h b/arch/arm/include/asm/jump_label.h index 5c5ca2ea62b0..bfc198c75913 100644 --- a/arch/arm/include/asm/jump_label.h +++ b/arch/arm/include/asm/jump_label.h | |||
| @@ -14,7 +14,7 @@ | |||
| 14 | #define JUMP_LABEL_NOP "nop" | 14 | #define JUMP_LABEL_NOP "nop" |
| 15 | #endif | 15 | #endif |
| 16 | 16 | ||
| 17 | static __always_inline bool arch_static_branch(struct jump_label_key *key) | 17 | static __always_inline bool arch_static_branch(struct static_key *key) |
| 18 | { | 18 | { |
| 19 | asm goto("1:\n\t" | 19 | asm goto("1:\n\t" |
| 20 | JUMP_LABEL_NOP "\n\t" | 20 | JUMP_LABEL_NOP "\n\t" |
diff --git a/arch/arm/kernel/setup.c b/arch/arm/kernel/setup.c index b91411371ae1..ebfac782593f 100644 --- a/arch/arm/kernel/setup.c +++ b/arch/arm/kernel/setup.c | |||
| @@ -523,7 +523,21 @@ int __init arm_add_memory(phys_addr_t start, unsigned long size) | |||
| 523 | */ | 523 | */ |
| 524 | size -= start & ~PAGE_MASK; | 524 | size -= start & ~PAGE_MASK; |
| 525 | bank->start = PAGE_ALIGN(start); | 525 | bank->start = PAGE_ALIGN(start); |
| 526 | bank->size = size & PAGE_MASK; | 526 | |
| 527 | #ifndef CONFIG_LPAE | ||
| 528 | if (bank->start + size < bank->start) { | ||
| 529 | printk(KERN_CRIT "Truncating memory at 0x%08llx to fit in " | ||
| 530 | "32-bit physical address space\n", (long long)start); | ||
| 531 | /* | ||
| 532 | * To ensure bank->start + bank->size is representable in | ||
| 533 | * 32 bits, we use ULONG_MAX as the upper limit rather than 4GB. | ||
| 534 | * This means we lose a page after masking. | ||
| 535 | */ | ||
| 536 | size = ULONG_MAX - bank->start; | ||
| 537 | } | ||
| 538 | #endif | ||
| 539 | |||
| 540 | bank->size = size & PAGE_MASK; | ||
| 527 | 541 | ||
| 528 | /* | 542 | /* |
| 529 | * Check whether this memory region has non-zero size or | 543 | * Check whether this memory region has non-zero size or |
diff --git a/arch/arm/mach-at91/at91rm9200_devices.c b/arch/arm/mach-at91/at91rm9200_devices.c index 99ce5c955e39..05774e5b1cba 100644 --- a/arch/arm/mach-at91/at91rm9200_devices.c +++ b/arch/arm/mach-at91/at91rm9200_devices.c | |||
| @@ -1173,7 +1173,6 @@ void __init at91_add_device_serial(void) | |||
| 1173 | printk(KERN_INFO "AT91: No default serial console defined.\n"); | 1173 | printk(KERN_INFO "AT91: No default serial console defined.\n"); |
| 1174 | } | 1174 | } |
| 1175 | #else | 1175 | #else |
| 1176 | void __init __deprecated at91_init_serial(struct at91_uart_config *config) {} | ||
| 1177 | void __init at91_register_uart(unsigned id, unsigned portnr, unsigned pins) {} | 1176 | void __init at91_register_uart(unsigned id, unsigned portnr, unsigned pins) {} |
| 1178 | void __init at91_set_serial_console(unsigned portnr) {} | 1177 | void __init at91_set_serial_console(unsigned portnr) {} |
| 1179 | void __init at91_add_device_serial(void) {} | 1178 | void __init at91_add_device_serial(void) {} |
diff --git a/arch/arm/mach-at91/at91rm9200_time.c b/arch/arm/mach-at91/at91rm9200_time.c index dd7f782b0b91..104ca40d8d18 100644 --- a/arch/arm/mach-at91/at91rm9200_time.c +++ b/arch/arm/mach-at91/at91rm9200_time.c | |||
| @@ -23,6 +23,7 @@ | |||
| 23 | #include <linux/interrupt.h> | 23 | #include <linux/interrupt.h> |
| 24 | #include <linux/irq.h> | 24 | #include <linux/irq.h> |
| 25 | #include <linux/clockchips.h> | 25 | #include <linux/clockchips.h> |
| 26 | #include <linux/export.h> | ||
| 26 | 27 | ||
| 27 | #include <asm/mach/time.h> | 28 | #include <asm/mach/time.h> |
| 28 | 29 | ||
| @@ -176,6 +177,7 @@ static struct clock_event_device clkevt = { | |||
| 176 | }; | 177 | }; |
| 177 | 178 | ||
| 178 | void __iomem *at91_st_base; | 179 | void __iomem *at91_st_base; |
| 180 | EXPORT_SYMBOL_GPL(at91_st_base); | ||
| 179 | 181 | ||
| 180 | void __init at91rm9200_ioremap_st(u32 addr) | 182 | void __init at91rm9200_ioremap_st(u32 addr) |
| 181 | { | 183 | { |
diff --git a/arch/arm/mach-at91/board-rm9200ek.c b/arch/arm/mach-at91/board-rm9200ek.c index 11cbaa8946fe..b2e4fe21f346 100644 --- a/arch/arm/mach-at91/board-rm9200ek.c +++ b/arch/arm/mach-at91/board-rm9200ek.c | |||
| @@ -117,7 +117,7 @@ static struct i2c_board_info __initdata ek_i2c_devices[] = { | |||
| 117 | }; | 117 | }; |
| 118 | 118 | ||
| 119 | #define EK_FLASH_BASE AT91_CHIPSELECT_0 | 119 | #define EK_FLASH_BASE AT91_CHIPSELECT_0 |
| 120 | #define EK_FLASH_SIZE SZ_2M | 120 | #define EK_FLASH_SIZE SZ_8M |
| 121 | 121 | ||
| 122 | static struct physmap_flash_data ek_flash_data = { | 122 | static struct physmap_flash_data ek_flash_data = { |
| 123 | .width = 2, | 123 | .width = 2, |
diff --git a/arch/arm/mach-at91/board-sam9261ek.c b/arch/arm/mach-at91/board-sam9261ek.c index c3f994462864..065fed342424 100644 --- a/arch/arm/mach-at91/board-sam9261ek.c +++ b/arch/arm/mach-at91/board-sam9261ek.c | |||
| @@ -85,8 +85,6 @@ static struct resource dm9000_resource[] = { | |||
| 85 | .flags = IORESOURCE_MEM | 85 | .flags = IORESOURCE_MEM |
| 86 | }, | 86 | }, |
| 87 | [2] = { | 87 | [2] = { |
| 88 | .start = AT91_PIN_PC11, | ||
| 89 | .end = AT91_PIN_PC11, | ||
| 90 | .flags = IORESOURCE_IRQ | 88 | .flags = IORESOURCE_IRQ |
| 91 | | IORESOURCE_IRQ_LOWEDGE | IORESOURCE_IRQ_HIGHEDGE, | 89 | | IORESOURCE_IRQ_LOWEDGE | IORESOURCE_IRQ_HIGHEDGE, |
| 92 | } | 90 | } |
| @@ -130,6 +128,8 @@ static struct sam9_smc_config __initdata dm9000_smc_config = { | |||
| 130 | 128 | ||
| 131 | static void __init ek_add_device_dm9000(void) | 129 | static void __init ek_add_device_dm9000(void) |
| 132 | { | 130 | { |
| 131 | struct resource *r = &dm9000_resource[2]; | ||
| 132 | |||
| 133 | /* Configure chip-select 2 (DM9000) */ | 133 | /* Configure chip-select 2 (DM9000) */ |
| 134 | sam9_smc_configure(0, 2, &dm9000_smc_config); | 134 | sam9_smc_configure(0, 2, &dm9000_smc_config); |
| 135 | 135 | ||
| @@ -139,6 +139,7 @@ static void __init ek_add_device_dm9000(void) | |||
| 139 | /* Configure Interrupt pin as input, no pull-up */ | 139 | /* Configure Interrupt pin as input, no pull-up */ |
| 140 | at91_set_gpio_input(AT91_PIN_PC11, 0); | 140 | at91_set_gpio_input(AT91_PIN_PC11, 0); |
| 141 | 141 | ||
| 142 | r->start = r->end = gpio_to_irq(AT91_PIN_PC11); | ||
| 142 | platform_device_register(&dm9000_device); | 143 | platform_device_register(&dm9000_device); |
| 143 | } | 144 | } |
| 144 | #else | 145 | #else |
diff --git a/arch/arm/mach-at91/clock.c b/arch/arm/mach-at91/clock.c index a0f4d7424cdc..6b692824c988 100644 --- a/arch/arm/mach-at91/clock.c +++ b/arch/arm/mach-at91/clock.c | |||
| @@ -35,6 +35,7 @@ | |||
| 35 | #include "generic.h" | 35 | #include "generic.h" |
| 36 | 36 | ||
| 37 | void __iomem *at91_pmc_base; | 37 | void __iomem *at91_pmc_base; |
| 38 | EXPORT_SYMBOL_GPL(at91_pmc_base); | ||
| 38 | 39 | ||
| 39 | /* | 40 | /* |
| 40 | * There's a lot more which can be done with clocks, including cpufreq | 41 | * There's a lot more which can be done with clocks, including cpufreq |
diff --git a/arch/arm/mach-at91/include/mach/at91_pmc.h b/arch/arm/mach-at91/include/mach/at91_pmc.h index 36604782a78f..ea2c57a86ca6 100644 --- a/arch/arm/mach-at91/include/mach/at91_pmc.h +++ b/arch/arm/mach-at91/include/mach/at91_pmc.h | |||
| @@ -25,7 +25,7 @@ extern void __iomem *at91_pmc_base; | |||
| 25 | #define at91_pmc_write(field, value) \ | 25 | #define at91_pmc_write(field, value) \ |
| 26 | __raw_writel(value, at91_pmc_base + field) | 26 | __raw_writel(value, at91_pmc_base + field) |
| 27 | #else | 27 | #else |
| 28 | .extern at91_aic_base | 28 | .extern at91_pmc_base |
| 29 | #endif | 29 | #endif |
| 30 | 30 | ||
| 31 | #define AT91_PMC_SCER 0x00 /* System Clock Enable Register */ | 31 | #define AT91_PMC_SCER 0x00 /* System Clock Enable Register */ |
diff --git a/arch/arm/mach-at91/setup.c b/arch/arm/mach-at91/setup.c index 97cc04dc8073..f44a2e7272e3 100644 --- a/arch/arm/mach-at91/setup.c +++ b/arch/arm/mach-at91/setup.c | |||
| @@ -54,6 +54,7 @@ void __init at91_init_interrupts(unsigned int *priority) | |||
| 54 | } | 54 | } |
| 55 | 55 | ||
| 56 | void __iomem *at91_ramc_base[2]; | 56 | void __iomem *at91_ramc_base[2]; |
| 57 | EXPORT_SYMBOL_GPL(at91_ramc_base); | ||
| 57 | 58 | ||
| 58 | void __init at91_ioremap_ramc(int id, u32 addr, u32 size) | 59 | void __init at91_ioremap_ramc(int id, u32 addr, u32 size) |
| 59 | { | 60 | { |
| @@ -292,6 +293,7 @@ void __init at91_ioremap_rstc(u32 base_addr) | |||
| 292 | } | 293 | } |
| 293 | 294 | ||
| 294 | void __iomem *at91_matrix_base; | 295 | void __iomem *at91_matrix_base; |
| 296 | EXPORT_SYMBOL_GPL(at91_matrix_base); | ||
| 295 | 297 | ||
| 296 | void __init at91_ioremap_matrix(u32 base_addr) | 298 | void __init at91_ioremap_matrix(u32 base_addr) |
| 297 | { | 299 | { |
diff --git a/arch/arm/mach-bcmring/core.c b/arch/arm/mach-bcmring/core.c index 22e4e0a28ad1..adbfb1994582 100644 --- a/arch/arm/mach-bcmring/core.c +++ b/arch/arm/mach-bcmring/core.c | |||
| @@ -52,8 +52,8 @@ | |||
| 52 | #include <mach/csp/chipcHw_inline.h> | 52 | #include <mach/csp/chipcHw_inline.h> |
| 53 | #include <mach/csp/tmrHw_reg.h> | 53 | #include <mach/csp/tmrHw_reg.h> |
| 54 | 54 | ||
| 55 | static AMBA_APB_DEVICE(uartA, "uarta", MM_ADDR_IO_UARTA, { IRQ_UARTA }, NULL); | 55 | static AMBA_APB_DEVICE(uartA, "uartA", 0, MM_ADDR_IO_UARTA, {IRQ_UARTA}, NULL); |
| 56 | static AMBA_APB_DEVICE(uartB, "uartb", MM_ADDR_IO_UARTB, { IRQ_UARTB }, NULL); | 56 | static AMBA_APB_DEVICE(uartB, "uartB", 0, MM_ADDR_IO_UARTB, {IRQ_UARTB}, NULL); |
| 57 | 57 | ||
| 58 | static struct clk pll1_clk = { | 58 | static struct clk pll1_clk = { |
| 59 | .name = "PLL1", | 59 | .name = "PLL1", |
diff --git a/arch/arm/mach-exynos/Kconfig b/arch/arm/mach-exynos/Kconfig index 0491ceef1cda..e81c35f936b5 100644 --- a/arch/arm/mach-exynos/Kconfig +++ b/arch/arm/mach-exynos/Kconfig | |||
| @@ -368,6 +368,7 @@ comment "Flattened Device Tree based board for EXYNOS SoCs" | |||
| 368 | 368 | ||
| 369 | config MACH_EXYNOS4_DT | 369 | config MACH_EXYNOS4_DT |
| 370 | bool "Samsung Exynos4 Machine using device tree" | 370 | bool "Samsung Exynos4 Machine using device tree" |
| 371 | depends on ARCH_EXYNOS4 | ||
| 371 | select CPU_EXYNOS4210 | 372 | select CPU_EXYNOS4210 |
| 372 | select USE_OF | 373 | select USE_OF |
| 373 | select ARM_AMBA | 374 | select ARM_AMBA |
| @@ -380,6 +381,7 @@ config MACH_EXYNOS4_DT | |||
| 380 | 381 | ||
| 381 | config MACH_EXYNOS5_DT | 382 | config MACH_EXYNOS5_DT |
| 382 | bool "SAMSUNG EXYNOS5 Machine using device tree" | 383 | bool "SAMSUNG EXYNOS5 Machine using device tree" |
| 384 | depends on ARCH_EXYNOS5 | ||
| 383 | select SOC_EXYNOS5250 | 385 | select SOC_EXYNOS5250 |
| 384 | select USE_OF | 386 | select USE_OF |
| 385 | select ARM_AMBA | 387 | select ARM_AMBA |
diff --git a/arch/arm/mach-exynos/include/mach/irqs.h b/arch/arm/mach-exynos/include/mach/irqs.h index 9bee8535d9e0..591e78521a9f 100644 --- a/arch/arm/mach-exynos/include/mach/irqs.h +++ b/arch/arm/mach-exynos/include/mach/irqs.h | |||
| @@ -212,6 +212,8 @@ | |||
| 212 | #define IRQ_MFC EXYNOS4_IRQ_MFC | 212 | #define IRQ_MFC EXYNOS4_IRQ_MFC |
| 213 | #define IRQ_SDO EXYNOS4_IRQ_SDO | 213 | #define IRQ_SDO EXYNOS4_IRQ_SDO |
| 214 | 214 | ||
| 215 | #define IRQ_I2S0 EXYNOS4_IRQ_I2S0 | ||
| 216 | |||
| 215 | #define IRQ_ADC EXYNOS4_IRQ_ADC0 | 217 | #define IRQ_ADC EXYNOS4_IRQ_ADC0 |
| 216 | #define IRQ_TC EXYNOS4_IRQ_PEN0 | 218 | #define IRQ_TC EXYNOS4_IRQ_PEN0 |
| 217 | 219 | ||
diff --git a/arch/arm/mach-exynos/include/mach/map.h b/arch/arm/mach-exynos/include/mach/map.h index 024d38ff1718..6e6d11ff352a 100644 --- a/arch/arm/mach-exynos/include/mach/map.h +++ b/arch/arm/mach-exynos/include/mach/map.h | |||
| @@ -89,6 +89,10 @@ | |||
| 89 | #define EXYNOS4_PA_MDMA1 0x12840000 | 89 | #define EXYNOS4_PA_MDMA1 0x12840000 |
| 90 | #define EXYNOS4_PA_PDMA0 0x12680000 | 90 | #define EXYNOS4_PA_PDMA0 0x12680000 |
| 91 | #define EXYNOS4_PA_PDMA1 0x12690000 | 91 | #define EXYNOS4_PA_PDMA1 0x12690000 |
| 92 | #define EXYNOS5_PA_MDMA0 0x10800000 | ||
| 93 | #define EXYNOS5_PA_MDMA1 0x11C10000 | ||
| 94 | #define EXYNOS5_PA_PDMA0 0x121A0000 | ||
| 95 | #define EXYNOS5_PA_PDMA1 0x121B0000 | ||
| 92 | 96 | ||
| 93 | #define EXYNOS4_PA_SYSMMU_MDMA 0x10A40000 | 97 | #define EXYNOS4_PA_SYSMMU_MDMA 0x10A40000 |
| 94 | #define EXYNOS4_PA_SYSMMU_SSS 0x10A50000 | 98 | #define EXYNOS4_PA_SYSMMU_SSS 0x10A50000 |
diff --git a/arch/arm/mach-exynos/include/mach/regs-clock.h b/arch/arm/mach-exynos/include/mach/regs-clock.h index e141c1fd68d8..d9578a58ae7f 100644 --- a/arch/arm/mach-exynos/include/mach/regs-clock.h +++ b/arch/arm/mach-exynos/include/mach/regs-clock.h | |||
| @@ -255,9 +255,15 @@ | |||
| 255 | 255 | ||
| 256 | /* For EXYNOS5250 */ | 256 | /* For EXYNOS5250 */ |
| 257 | 257 | ||
| 258 | #define EXYNOS5_APLL_LOCK EXYNOS_CLKREG(0x00000) | ||
| 258 | #define EXYNOS5_APLL_CON0 EXYNOS_CLKREG(0x00100) | 259 | #define EXYNOS5_APLL_CON0 EXYNOS_CLKREG(0x00100) |
| 259 | #define EXYNOS5_CLKSRC_CPU EXYNOS_CLKREG(0x00200) | 260 | #define EXYNOS5_CLKSRC_CPU EXYNOS_CLKREG(0x00200) |
| 261 | #define EXYNOS5_CLKMUX_STATCPU EXYNOS_CLKREG(0x00400) | ||
| 260 | #define EXYNOS5_CLKDIV_CPU0 EXYNOS_CLKREG(0x00500) | 262 | #define EXYNOS5_CLKDIV_CPU0 EXYNOS_CLKREG(0x00500) |
| 263 | #define EXYNOS5_CLKDIV_CPU1 EXYNOS_CLKREG(0x00504) | ||
| 264 | #define EXYNOS5_CLKDIV_STATCPU0 EXYNOS_CLKREG(0x00600) | ||
| 265 | #define EXYNOS5_CLKDIV_STATCPU1 EXYNOS_CLKREG(0x00604) | ||
| 266 | |||
| 261 | #define EXYNOS5_MPLL_CON0 EXYNOS_CLKREG(0x04100) | 267 | #define EXYNOS5_MPLL_CON0 EXYNOS_CLKREG(0x04100) |
| 262 | #define EXYNOS5_CLKSRC_CORE1 EXYNOS_CLKREG(0x04204) | 268 | #define EXYNOS5_CLKSRC_CORE1 EXYNOS_CLKREG(0x04204) |
| 263 | 269 | ||
diff --git a/arch/arm/mach-exynos/mach-exynos5-dt.c b/arch/arm/mach-exynos/mach-exynos5-dt.c index 0d26f50081ad..4711c8920e37 100644 --- a/arch/arm/mach-exynos/mach-exynos5-dt.c +++ b/arch/arm/mach-exynos/mach-exynos5-dt.c | |||
| @@ -45,7 +45,7 @@ static const struct of_dev_auxdata exynos5250_auxdata_lookup[] __initconst = { | |||
| 45 | "exynos4210-uart.3", NULL), | 45 | "exynos4210-uart.3", NULL), |
| 46 | OF_DEV_AUXDATA("arm,pl330", EXYNOS5_PA_PDMA0, "dma-pl330.0", NULL), | 46 | OF_DEV_AUXDATA("arm,pl330", EXYNOS5_PA_PDMA0, "dma-pl330.0", NULL), |
| 47 | OF_DEV_AUXDATA("arm,pl330", EXYNOS5_PA_PDMA1, "dma-pl330.1", NULL), | 47 | OF_DEV_AUXDATA("arm,pl330", EXYNOS5_PA_PDMA1, "dma-pl330.1", NULL), |
| 48 | OF_DEV_AUXDATA("arm,pl330", EXYNOS5_PA_PDMA1, "dma-pl330.2", NULL), | 48 | OF_DEV_AUXDATA("arm,pl330", EXYNOS5_PA_MDMA1, "dma-pl330.2", NULL), |
| 49 | {}, | 49 | {}, |
| 50 | }; | 50 | }; |
| 51 | 51 | ||
diff --git a/arch/arm/mach-exynos/mach-nuri.c b/arch/arm/mach-exynos/mach-nuri.c index b3982c867c9c..b4f1f902ce6d 100644 --- a/arch/arm/mach-exynos/mach-nuri.c +++ b/arch/arm/mach-exynos/mach-nuri.c | |||
| @@ -307,49 +307,7 @@ static struct i2c_board_info i2c1_devs[] __initdata = { | |||
| 307 | }; | 307 | }; |
| 308 | 308 | ||
| 309 | /* TSP */ | 309 | /* TSP */ |
| 310 | static u8 mxt_init_vals[] = { | ||
| 311 | /* MXT_GEN_COMMAND(6) */ | ||
| 312 | 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, | ||
| 313 | /* MXT_GEN_POWER(7) */ | ||
| 314 | 0x20, 0xff, 0x32, | ||
| 315 | /* MXT_GEN_ACQUIRE(8) */ | ||
| 316 | 0x0a, 0x00, 0x05, 0x00, 0x00, 0x00, 0x09, 0x23, | ||
| 317 | /* MXT_TOUCH_MULTI(9) */ | ||
| 318 | 0x00, 0x00, 0x00, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x02, 0x00, | ||
| 319 | 0x00, 0x01, 0x01, 0x0e, 0x0a, 0x0a, 0x0a, 0x0a, 0x00, 0x00, | ||
| 320 | 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, | ||
| 321 | 0x00, | ||
| 322 | /* MXT_TOUCH_KEYARRAY(15) */ | ||
| 323 | 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0x00, | ||
| 324 | 0x00, | ||
| 325 | /* MXT_SPT_GPIOPWM(19) */ | ||
| 326 | 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, | ||
| 327 | 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, | ||
| 328 | /* MXT_PROCI_GRIPFACE(20) */ | ||
| 329 | 0x07, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x50, 0x28, 0x04, | ||
| 330 | 0x0f, 0x0a, | ||
| 331 | /* MXT_PROCG_NOISE(22) */ | ||
| 332 | 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x23, 0x00, | ||
| 333 | 0x00, 0x05, 0x0f, 0x19, 0x23, 0x2d, 0x03, | ||
| 334 | /* MXT_TOUCH_PROXIMITY(23) */ | ||
| 335 | 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, | ||
| 336 | 0x00, 0x00, 0x00, 0x00, 0x00, | ||
| 337 | /* MXT_PROCI_ONETOUCH(24) */ | ||
| 338 | 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, | ||
| 339 | 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, | ||
| 340 | /* MXT_SPT_SELFTEST(25) */ | ||
| 341 | 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, | ||
| 342 | 0x00, 0x00, 0x00, 0x00, | ||
| 343 | /* MXT_PROCI_TWOTOUCH(27) */ | ||
| 344 | 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, | ||
| 345 | /* MXT_SPT_CTECONFIG(28) */ | ||
| 346 | 0x00, 0x00, 0x02, 0x08, 0x10, 0x00, | ||
| 347 | }; | ||
| 348 | |||
| 349 | static struct mxt_platform_data mxt_platform_data = { | 310 | static struct mxt_platform_data mxt_platform_data = { |
| 350 | .config = mxt_init_vals, | ||
| 351 | .config_length = ARRAY_SIZE(mxt_init_vals), | ||
| 352 | |||
| 353 | .x_line = 18, | 311 | .x_line = 18, |
| 354 | .y_line = 11, | 312 | .y_line = 11, |
| 355 | .x_size = 1024, | 313 | .x_size = 1024, |
| @@ -571,7 +529,7 @@ static struct regulator_init_data __initdata max8997_ldo7_data = { | |||
| 571 | 529 | ||
| 572 | static struct regulator_init_data __initdata max8997_ldo8_data = { | 530 | static struct regulator_init_data __initdata max8997_ldo8_data = { |
| 573 | .constraints = { | 531 | .constraints = { |
| 574 | .name = "VUSB/VDAC_3.3V_C210", | 532 | .name = "VUSB+VDAC_3.3V_C210", |
| 575 | .min_uV = 3300000, | 533 | .min_uV = 3300000, |
| 576 | .max_uV = 3300000, | 534 | .max_uV = 3300000, |
| 577 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | 535 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, |
| @@ -1347,6 +1305,7 @@ static struct platform_device *nuri_devices[] __initdata = { | |||
| 1347 | 1305 | ||
| 1348 | static void __init nuri_map_io(void) | 1306 | static void __init nuri_map_io(void) |
| 1349 | { | 1307 | { |
| 1308 | clk_xusbxti.rate = 24000000; | ||
| 1350 | exynos_init_io(NULL, 0); | 1309 | exynos_init_io(NULL, 0); |
| 1351 | s3c24xx_init_clocks(24000000); | 1310 | s3c24xx_init_clocks(24000000); |
| 1352 | s3c24xx_init_uarts(nuri_uartcfgs, ARRAY_SIZE(nuri_uartcfgs)); | 1311 | s3c24xx_init_uarts(nuri_uartcfgs, ARRAY_SIZE(nuri_uartcfgs)); |
| @@ -1379,7 +1338,6 @@ static void __init nuri_machine_init(void) | |||
| 1379 | nuri_camera_init(); | 1338 | nuri_camera_init(); |
| 1380 | 1339 | ||
| 1381 | nuri_ehci_init(); | 1340 | nuri_ehci_init(); |
| 1382 | clk_xusbxti.rate = 24000000; | ||
| 1383 | 1341 | ||
| 1384 | /* Last */ | 1342 | /* Last */ |
| 1385 | platform_add_devices(nuri_devices, ARRAY_SIZE(nuri_devices)); | 1343 | platform_add_devices(nuri_devices, ARRAY_SIZE(nuri_devices)); |
diff --git a/arch/arm/mach-exynos/mach-universal_c210.c b/arch/arm/mach-exynos/mach-universal_c210.c index 6bb9dbdd73fd..7ebf79c2ab34 100644 --- a/arch/arm/mach-exynos/mach-universal_c210.c +++ b/arch/arm/mach-exynos/mach-universal_c210.c | |||
| @@ -29,6 +29,7 @@ | |||
| 29 | #include <asm/mach-types.h> | 29 | #include <asm/mach-types.h> |
| 30 | 30 | ||
| 31 | #include <plat/regs-serial.h> | 31 | #include <plat/regs-serial.h> |
| 32 | #include <plat/clock.h> | ||
| 32 | #include <plat/cpu.h> | 33 | #include <plat/cpu.h> |
| 33 | #include <plat/devs.h> | 34 | #include <plat/devs.h> |
| 34 | #include <plat/iic.h> | 35 | #include <plat/iic.h> |
| @@ -1057,6 +1058,7 @@ static struct platform_device *universal_devices[] __initdata = { | |||
| 1057 | 1058 | ||
| 1058 | static void __init universal_map_io(void) | 1059 | static void __init universal_map_io(void) |
| 1059 | { | 1060 | { |
| 1061 | clk_xusbxti.rate = 24000000; | ||
| 1060 | exynos_init_io(NULL, 0); | 1062 | exynos_init_io(NULL, 0); |
| 1061 | s3c24xx_init_clocks(24000000); | 1063 | s3c24xx_init_clocks(24000000); |
| 1062 | s3c24xx_init_uarts(universal_uartcfgs, ARRAY_SIZE(universal_uartcfgs)); | 1064 | s3c24xx_init_uarts(universal_uartcfgs, ARRAY_SIZE(universal_uartcfgs)); |
diff --git a/arch/arm/mach-imx/imx27-dt.c b/arch/arm/mach-imx/imx27-dt.c index 861ceb8232d6..ed38d03c61f2 100644 --- a/arch/arm/mach-imx/imx27-dt.c +++ b/arch/arm/mach-imx/imx27-dt.c | |||
| @@ -35,7 +35,7 @@ static const struct of_dev_auxdata imx27_auxdata_lookup[] __initconst = { | |||
| 35 | static int __init imx27_avic_add_irq_domain(struct device_node *np, | 35 | static int __init imx27_avic_add_irq_domain(struct device_node *np, |
| 36 | struct device_node *interrupt_parent) | 36 | struct device_node *interrupt_parent) |
| 37 | { | 37 | { |
| 38 | irq_domain_add_simple(np, 0); | 38 | irq_domain_add_legacy(np, 64, 0, 0, &irq_domain_simple_ops, NULL); |
| 39 | return 0; | 39 | return 0; |
| 40 | } | 40 | } |
| 41 | 41 | ||
| @@ -44,7 +44,9 @@ static int __init imx27_gpio_add_irq_domain(struct device_node *np, | |||
| 44 | { | 44 | { |
| 45 | static int gpio_irq_base = MXC_GPIO_IRQ_START + ARCH_NR_GPIOS; | 45 | static int gpio_irq_base = MXC_GPIO_IRQ_START + ARCH_NR_GPIOS; |
| 46 | 46 | ||
| 47 | irq_domain_add_simple(np, gpio_irq_base); | 47 | gpio_irq_base -= 32; |
| 48 | irq_domain_add_legacy(np, 32, gpio_irq_base, 0, &irq_domain_simple_ops, | ||
| 49 | NULL); | ||
| 48 | 50 | ||
| 49 | return 0; | 51 | return 0; |
| 50 | } | 52 | } |
diff --git a/arch/arm/mach-imx/mm-imx5.c b/arch/arm/mach-imx/mm-imx5.c index 05250aed61fb..e10f3914fcfe 100644 --- a/arch/arm/mach-imx/mm-imx5.c +++ b/arch/arm/mach-imx/mm-imx5.c | |||
| @@ -35,7 +35,7 @@ static void imx5_idle(void) | |||
| 35 | } | 35 | } |
| 36 | clk_enable(gpc_dvfs_clk); | 36 | clk_enable(gpc_dvfs_clk); |
| 37 | mx5_cpu_lp_set(WAIT_UNCLOCKED_POWER_OFF); | 37 | mx5_cpu_lp_set(WAIT_UNCLOCKED_POWER_OFF); |
| 38 | if (tzic_enable_wake() != 0) | 38 | if (!tzic_enable_wake()) |
| 39 | cpu_do_idle(); | 39 | cpu_do_idle(); |
| 40 | clk_disable(gpc_dvfs_clk); | 40 | clk_disable(gpc_dvfs_clk); |
| 41 | } | 41 | } |
diff --git a/arch/arm/mach-msm/board-halibut.c b/arch/arm/mach-msm/board-halibut.c index 3698a370d636..26aac363a064 100644 --- a/arch/arm/mach-msm/board-halibut.c +++ b/arch/arm/mach-msm/board-halibut.c | |||
| @@ -86,9 +86,6 @@ static void __init halibut_init(void) | |||
| 86 | static void __init halibut_fixup(struct tag *tags, char **cmdline, | 86 | static void __init halibut_fixup(struct tag *tags, char **cmdline, |
| 87 | struct meminfo *mi) | 87 | struct meminfo *mi) |
| 88 | { | 88 | { |
| 89 | mi->nr_banks=1; | ||
| 90 | mi->bank[0].start = PHYS_OFFSET; | ||
| 91 | mi->bank[0].size = (101*1024*1024); | ||
| 92 | } | 89 | } |
| 93 | 90 | ||
| 94 | static void __init halibut_map_io(void) | 91 | static void __init halibut_map_io(void) |
diff --git a/arch/arm/mach-msm/board-trout-panel.c b/arch/arm/mach-msm/board-trout-panel.c index 25105c1027fe..89bf6b426699 100644 --- a/arch/arm/mach-msm/board-trout-panel.c +++ b/arch/arm/mach-msm/board-trout-panel.c | |||
| @@ -12,6 +12,7 @@ | |||
| 12 | 12 | ||
| 13 | #include <asm/io.h> | 13 | #include <asm/io.h> |
| 14 | #include <asm/mach-types.h> | 14 | #include <asm/mach-types.h> |
| 15 | #include <asm/system_info.h> | ||
| 15 | 16 | ||
| 16 | #include <mach/msm_fb.h> | 17 | #include <mach/msm_fb.h> |
| 17 | #include <mach/vreg.h> | 18 | #include <mach/vreg.h> |
diff --git a/arch/arm/mach-msm/board-trout.c b/arch/arm/mach-msm/board-trout.c index 5414f76ec0a9..d4060a37e23d 100644 --- a/arch/arm/mach-msm/board-trout.c +++ b/arch/arm/mach-msm/board-trout.c | |||
| @@ -19,6 +19,7 @@ | |||
| 19 | #include <linux/platform_device.h> | 19 | #include <linux/platform_device.h> |
| 20 | #include <linux/clkdev.h> | 20 | #include <linux/clkdev.h> |
| 21 | 21 | ||
| 22 | #include <asm/system_info.h> | ||
| 22 | #include <asm/mach-types.h> | 23 | #include <asm/mach-types.h> |
| 23 | #include <asm/mach/arch.h> | 24 | #include <asm/mach/arch.h> |
| 24 | #include <asm/mach/map.h> | 25 | #include <asm/mach/map.h> |
diff --git a/arch/arm/mach-msm/proc_comm.c b/arch/arm/mach-msm/proc_comm.c index 67e701c7f183..9980dc736e7b 100644 --- a/arch/arm/mach-msm/proc_comm.c +++ b/arch/arm/mach-msm/proc_comm.c | |||
| @@ -121,7 +121,7 @@ int msm_proc_comm(unsigned cmd, unsigned *data1, unsigned *data2) | |||
| 121 | * and unknown state. This function should be called early to | 121 | * and unknown state. This function should be called early to |
| 122 | * wait on the ARM9. | 122 | * wait on the ARM9. |
| 123 | */ | 123 | */ |
| 124 | void __init proc_comm_boot_wait(void) | 124 | void __devinit proc_comm_boot_wait(void) |
| 125 | { | 125 | { |
| 126 | void __iomem *base = MSM_SHARED_RAM_BASE; | 126 | void __iomem *base = MSM_SHARED_RAM_BASE; |
| 127 | 127 | ||
diff --git a/arch/arm/mach-omap1/mux.c b/arch/arm/mach-omap1/mux.c index 087dba0df47e..e9cc52d4cb28 100644 --- a/arch/arm/mach-omap1/mux.c +++ b/arch/arm/mach-omap1/mux.c | |||
| @@ -27,6 +27,7 @@ | |||
| 27 | #include <linux/io.h> | 27 | #include <linux/io.h> |
| 28 | #include <linux/spinlock.h> | 28 | #include <linux/spinlock.h> |
| 29 | 29 | ||
| 30 | #include <mach/hardware.h> | ||
| 30 | 31 | ||
| 31 | #include <plat/mux.h> | 32 | #include <plat/mux.h> |
| 32 | 33 | ||
diff --git a/arch/arm/mach-omap1/timer.c b/arch/arm/mach-omap1/timer.c index 6e90665a7c47..fb202af01d0d 100644 --- a/arch/arm/mach-omap1/timer.c +++ b/arch/arm/mach-omap1/timer.c | |||
| @@ -47,9 +47,9 @@ static int omap1_dm_timer_set_src(struct platform_device *pdev, | |||
| 47 | int n = (pdev->id - 1) << 1; | 47 | int n = (pdev->id - 1) << 1; |
| 48 | u32 l; | 48 | u32 l; |
| 49 | 49 | ||
| 50 | l = __raw_readl(MOD_CONF_CTRL_1) & ~(0x03 << n); | 50 | l = omap_readl(MOD_CONF_CTRL_1) & ~(0x03 << n); |
| 51 | l |= source << n; | 51 | l |= source << n; |
| 52 | __raw_writel(l, MOD_CONF_CTRL_1); | 52 | omap_writel(l, MOD_CONF_CTRL_1); |
| 53 | 53 | ||
| 54 | return 0; | 54 | return 0; |
| 55 | } | 55 | } |
diff --git a/arch/arm/mach-omap2/board-4430sdp.c b/arch/arm/mach-omap2/board-4430sdp.c index a39fc4bbd2b8..130ab00c09a2 100644 --- a/arch/arm/mach-omap2/board-4430sdp.c +++ b/arch/arm/mach-omap2/board-4430sdp.c | |||
| @@ -20,6 +20,7 @@ | |||
| 20 | #include <linux/usb/otg.h> | 20 | #include <linux/usb/otg.h> |
| 21 | #include <linux/spi/spi.h> | 21 | #include <linux/spi/spi.h> |
| 22 | #include <linux/i2c/twl.h> | 22 | #include <linux/i2c/twl.h> |
| 23 | #include <linux/mfd/twl6040.h> | ||
| 23 | #include <linux/gpio_keys.h> | 24 | #include <linux/gpio_keys.h> |
| 24 | #include <linux/regulator/machine.h> | 25 | #include <linux/regulator/machine.h> |
| 25 | #include <linux/regulator/fixed.h> | 26 | #include <linux/regulator/fixed.h> |
| @@ -560,7 +561,7 @@ static struct regulator_init_data sdp4430_vusim = { | |||
| 560 | }, | 561 | }, |
| 561 | }; | 562 | }; |
| 562 | 563 | ||
| 563 | static struct twl4030_codec_data twl6040_codec = { | 564 | static struct twl6040_codec_data twl6040_codec = { |
| 564 | /* single-step ramp for headset and handsfree */ | 565 | /* single-step ramp for headset and handsfree */ |
| 565 | .hs_left_step = 0x0f, | 566 | .hs_left_step = 0x0f, |
| 566 | .hs_right_step = 0x0f, | 567 | .hs_right_step = 0x0f, |
| @@ -568,7 +569,7 @@ static struct twl4030_codec_data twl6040_codec = { | |||
| 568 | .hf_right_step = 0x1d, | 569 | .hf_right_step = 0x1d, |
| 569 | }; | 570 | }; |
| 570 | 571 | ||
| 571 | static struct twl4030_vibra_data twl6040_vibra = { | 572 | static struct twl6040_vibra_data twl6040_vibra = { |
| 572 | .vibldrv_res = 8, | 573 | .vibldrv_res = 8, |
| 573 | .vibrdrv_res = 3, | 574 | .vibrdrv_res = 3, |
| 574 | .viblmotor_res = 10, | 575 | .viblmotor_res = 10, |
| @@ -577,16 +578,14 @@ static struct twl4030_vibra_data twl6040_vibra = { | |||
| 577 | .vddvibr_uV = 0, /* fixed volt supply - VBAT */ | 578 | .vddvibr_uV = 0, /* fixed volt supply - VBAT */ |
| 578 | }; | 579 | }; |
| 579 | 580 | ||
| 580 | static struct twl4030_audio_data twl6040_audio = { | 581 | static struct twl6040_platform_data twl6040_data = { |
| 581 | .codec = &twl6040_codec, | 582 | .codec = &twl6040_codec, |
| 582 | .vibra = &twl6040_vibra, | 583 | .vibra = &twl6040_vibra, |
| 583 | .audpwron_gpio = 127, | 584 | .audpwron_gpio = 127, |
| 584 | .naudint_irq = OMAP44XX_IRQ_SYS_2N, | ||
| 585 | .irq_base = TWL6040_CODEC_IRQ_BASE, | 585 | .irq_base = TWL6040_CODEC_IRQ_BASE, |
| 586 | }; | 586 | }; |
| 587 | 587 | ||
| 588 | static struct twl4030_platform_data sdp4430_twldata = { | 588 | static struct twl4030_platform_data sdp4430_twldata = { |
| 589 | .audio = &twl6040_audio, | ||
| 590 | /* Regulators */ | 589 | /* Regulators */ |
| 591 | .vusim = &sdp4430_vusim, | 590 | .vusim = &sdp4430_vusim, |
| 592 | .vaux1 = &sdp4430_vaux1, | 591 | .vaux1 = &sdp4430_vaux1, |
| @@ -617,7 +616,8 @@ static int __init omap4_i2c_init(void) | |||
| 617 | TWL_COMMON_REGULATOR_VCXIO | | 616 | TWL_COMMON_REGULATOR_VCXIO | |
| 618 | TWL_COMMON_REGULATOR_VUSB | | 617 | TWL_COMMON_REGULATOR_VUSB | |
| 619 | TWL_COMMON_REGULATOR_CLK32KG); | 618 | TWL_COMMON_REGULATOR_CLK32KG); |
| 620 | omap4_pmic_init("twl6030", &sdp4430_twldata); | 619 | omap4_pmic_init("twl6030", &sdp4430_twldata, |
| 620 | &twl6040_data, OMAP44XX_IRQ_SYS_2N); | ||
| 621 | omap_register_i2c_bus(2, 400, NULL, 0); | 621 | omap_register_i2c_bus(2, 400, NULL, 0); |
| 622 | omap_register_i2c_bus(3, 400, sdp4430_i2c_3_boardinfo, | 622 | omap_register_i2c_bus(3, 400, sdp4430_i2c_3_boardinfo, |
| 623 | ARRAY_SIZE(sdp4430_i2c_3_boardinfo)); | 623 | ARRAY_SIZE(sdp4430_i2c_3_boardinfo)); |
diff --git a/arch/arm/mach-omap2/board-generic.c b/arch/arm/mach-omap2/board-generic.c index 74e1687b5170..098d183a0086 100644 --- a/arch/arm/mach-omap2/board-generic.c +++ b/arch/arm/mach-omap2/board-generic.c | |||
| @@ -137,7 +137,7 @@ static struct twl4030_platform_data sdp4430_twldata = { | |||
| 137 | 137 | ||
| 138 | static void __init omap4_i2c_init(void) | 138 | static void __init omap4_i2c_init(void) |
| 139 | { | 139 | { |
| 140 | omap4_pmic_init("twl6030", &sdp4430_twldata); | 140 | omap4_pmic_init("twl6030", &sdp4430_twldata, NULL, 0); |
| 141 | } | 141 | } |
| 142 | 142 | ||
| 143 | static void __init omap4_init(void) | 143 | static void __init omap4_init(void) |
diff --git a/arch/arm/mach-omap2/board-omap4panda.c b/arch/arm/mach-omap2/board-omap4panda.c index d8c0e89f0126..1b782ba53433 100644 --- a/arch/arm/mach-omap2/board-omap4panda.c +++ b/arch/arm/mach-omap2/board-omap4panda.c | |||
| @@ -25,6 +25,7 @@ | |||
| 25 | #include <linux/gpio.h> | 25 | #include <linux/gpio.h> |
| 26 | #include <linux/usb/otg.h> | 26 | #include <linux/usb/otg.h> |
| 27 | #include <linux/i2c/twl.h> | 27 | #include <linux/i2c/twl.h> |
| 28 | #include <linux/mfd/twl6040.h> | ||
| 28 | #include <linux/regulator/machine.h> | 29 | #include <linux/regulator/machine.h> |
| 29 | #include <linux/regulator/fixed.h> | 30 | #include <linux/regulator/fixed.h> |
| 30 | #include <linux/wl12xx.h> | 31 | #include <linux/wl12xx.h> |
| @@ -284,7 +285,7 @@ static int __init omap4_twl6030_hsmmc_init(struct omap2_hsmmc_info *controllers) | |||
| 284 | return 0; | 285 | return 0; |
| 285 | } | 286 | } |
| 286 | 287 | ||
| 287 | static struct twl4030_codec_data twl6040_codec = { | 288 | static struct twl6040_codec_data twl6040_codec = { |
| 288 | /* single-step ramp for headset and handsfree */ | 289 | /* single-step ramp for headset and handsfree */ |
| 289 | .hs_left_step = 0x0f, | 290 | .hs_left_step = 0x0f, |
| 290 | .hs_right_step = 0x0f, | 291 | .hs_right_step = 0x0f, |
| @@ -292,17 +293,14 @@ static struct twl4030_codec_data twl6040_codec = { | |||
| 292 | .hf_right_step = 0x1d, | 293 | .hf_right_step = 0x1d, |
| 293 | }; | 294 | }; |
| 294 | 295 | ||
| 295 | static struct twl4030_audio_data twl6040_audio = { | 296 | static struct twl6040_platform_data twl6040_data = { |
| 296 | .codec = &twl6040_codec, | 297 | .codec = &twl6040_codec, |
| 297 | .audpwron_gpio = 127, | 298 | .audpwron_gpio = 127, |
| 298 | .naudint_irq = OMAP44XX_IRQ_SYS_2N, | ||
| 299 | .irq_base = TWL6040_CODEC_IRQ_BASE, | 299 | .irq_base = TWL6040_CODEC_IRQ_BASE, |
| 300 | }; | 300 | }; |
| 301 | 301 | ||
| 302 | /* Panda board uses the common PMIC configuration */ | 302 | /* Panda board uses the common PMIC configuration */ |
| 303 | static struct twl4030_platform_data omap4_panda_twldata = { | 303 | static struct twl4030_platform_data omap4_panda_twldata; |
| 304 | .audio = &twl6040_audio, | ||
| 305 | }; | ||
| 306 | 304 | ||
| 307 | /* | 305 | /* |
| 308 | * Display monitor features are burnt in their EEPROM as EDID data. The EEPROM | 306 | * Display monitor features are burnt in their EEPROM as EDID data. The EEPROM |
| @@ -326,7 +324,8 @@ static int __init omap4_panda_i2c_init(void) | |||
| 326 | TWL_COMMON_REGULATOR_VCXIO | | 324 | TWL_COMMON_REGULATOR_VCXIO | |
| 327 | TWL_COMMON_REGULATOR_VUSB | | 325 | TWL_COMMON_REGULATOR_VUSB | |
| 328 | TWL_COMMON_REGULATOR_CLK32KG); | 326 | TWL_COMMON_REGULATOR_CLK32KG); |
| 329 | omap4_pmic_init("twl6030", &omap4_panda_twldata); | 327 | omap4_pmic_init("twl6030", &omap4_panda_twldata, |
| 328 | &twl6040_data, OMAP44XX_IRQ_SYS_2N); | ||
| 330 | omap_register_i2c_bus(2, 400, NULL, 0); | 329 | omap_register_i2c_bus(2, 400, NULL, 0); |
| 331 | /* | 330 | /* |
| 332 | * Bus 3 is attached to the DVI port where devices like the pico DLP | 331 | * Bus 3 is attached to the DVI port where devices like the pico DLP |
diff --git a/arch/arm/mach-omap2/clkt2xxx_virt_prcm_set.c b/arch/arm/mach-omap2/clkt2xxx_virt_prcm_set.c index 7072e0d651b1..3d9d746b221a 100644 --- a/arch/arm/mach-omap2/clkt2xxx_virt_prcm_set.c +++ b/arch/arm/mach-omap2/clkt2xxx_virt_prcm_set.c | |||
| @@ -165,83 +165,3 @@ int omap2_select_table_rate(struct clk *clk, unsigned long rate) | |||
| 165 | 165 | ||
| 166 | return 0; | 166 | return 0; |
| 167 | } | 167 | } |
| 168 | |||
| 169 | #ifdef CONFIG_CPU_FREQ | ||
| 170 | /* | ||
| 171 | * Walk PRCM rate table and fillout cpufreq freq_table | ||
| 172 | * XXX This should be replaced by an OPP layer in the near future | ||
| 173 | */ | ||
| 174 | static struct cpufreq_frequency_table *freq_table; | ||
| 175 | |||
| 176 | void omap2_clk_init_cpufreq_table(struct cpufreq_frequency_table **table) | ||
| 177 | { | ||
| 178 | const struct prcm_config *prcm; | ||
| 179 | int i = 0; | ||
| 180 | int tbl_sz = 0; | ||
| 181 | |||
| 182 | if (!cpu_is_omap24xx()) | ||
| 183 | return; | ||
| 184 | |||
| 185 | for (prcm = rate_table; prcm->mpu_speed; prcm++) { | ||
| 186 | if (!(prcm->flags & cpu_mask)) | ||
| 187 | continue; | ||
| 188 | if (prcm->xtal_speed != sclk->rate) | ||
| 189 | continue; | ||
| 190 | |||
| 191 | /* don't put bypass rates in table */ | ||
| 192 | if (prcm->dpll_speed == prcm->xtal_speed) | ||
| 193 | continue; | ||
| 194 | |||
| 195 | tbl_sz++; | ||
| 196 | } | ||
| 197 | |||
| 198 | /* | ||
| 199 | * XXX Ensure that we're doing what CPUFreq expects for this error | ||
| 200 | * case and the following one | ||
| 201 | */ | ||
| 202 | if (tbl_sz == 0) { | ||
| 203 | pr_warning("%s: no matching entries in rate_table\n", | ||
| 204 | __func__); | ||
| 205 | return; | ||
| 206 | } | ||
| 207 | |||
| 208 | /* Include the CPUFREQ_TABLE_END terminator entry */ | ||
| 209 | tbl_sz++; | ||
| 210 | |||
| 211 | freq_table = kzalloc(sizeof(struct cpufreq_frequency_table) * tbl_sz, | ||
| 212 | GFP_ATOMIC); | ||
| 213 | if (!freq_table) { | ||
| 214 | pr_err("%s: could not kzalloc frequency table\n", __func__); | ||
| 215 | return; | ||
| 216 | } | ||
| 217 | |||
| 218 | for (prcm = rate_table; prcm->mpu_speed; prcm++) { | ||
| 219 | if (!(prcm->flags & cpu_mask)) | ||
| 220 | continue; | ||
| 221 | if (prcm->xtal_speed != sclk->rate) | ||
| 222 | continue; | ||
| 223 | |||
| 224 | /* don't put bypass rates in table */ | ||
| 225 | if (prcm->dpll_speed == prcm->xtal_speed) | ||
| 226 | continue; | ||
| 227 | |||
| 228 | freq_table[i].index = i; | ||
| 229 | freq_table[i].frequency = prcm->mpu_speed / 1000; | ||
| 230 | i++; | ||
| 231 | } | ||
| 232 | |||
| 233 | freq_table[i].index = i; | ||
| 234 | freq_table[i].frequency = CPUFREQ_TABLE_END; | ||
| 235 | |||
| 236 | *table = &freq_table[0]; | ||
| 237 | } | ||
| 238 | |||
| 239 | void omap2_clk_exit_cpufreq_table(struct cpufreq_frequency_table **table) | ||
| 240 | { | ||
| 241 | if (!cpu_is_omap24xx()) | ||
| 242 | return; | ||
| 243 | |||
| 244 | kfree(freq_table); | ||
| 245 | } | ||
| 246 | |||
| 247 | #endif | ||
diff --git a/arch/arm/mach-omap2/clock.c b/arch/arm/mach-omap2/clock.c index f57ed5baeccf..d9f4931513f9 100644 --- a/arch/arm/mach-omap2/clock.c +++ b/arch/arm/mach-omap2/clock.c | |||
| @@ -536,10 +536,5 @@ struct clk_functions omap2_clk_functions = { | |||
| 536 | .clk_set_rate = omap2_clk_set_rate, | 536 | .clk_set_rate = omap2_clk_set_rate, |
| 537 | .clk_set_parent = omap2_clk_set_parent, | 537 | .clk_set_parent = omap2_clk_set_parent, |
| 538 | .clk_disable_unused = omap2_clk_disable_unused, | 538 | .clk_disable_unused = omap2_clk_disable_unused, |
| 539 | #ifdef CONFIG_CPU_FREQ | ||
| 540 | /* These will be removed when the OPP code is integrated */ | ||
| 541 | .clk_init_cpufreq_table = omap2_clk_init_cpufreq_table, | ||
| 542 | .clk_exit_cpufreq_table = omap2_clk_exit_cpufreq_table, | ||
| 543 | #endif | ||
| 544 | }; | 539 | }; |
| 545 | 540 | ||
diff --git a/arch/arm/mach-omap2/clock.h b/arch/arm/mach-omap2/clock.h index b8c2a686481c..a1bb23a23351 100644 --- a/arch/arm/mach-omap2/clock.h +++ b/arch/arm/mach-omap2/clock.h | |||
| @@ -146,14 +146,6 @@ extern const struct clksel_rate gpt_sys_rates[]; | |||
| 146 | extern const struct clksel_rate gfx_l3_rates[]; | 146 | extern const struct clksel_rate gfx_l3_rates[]; |
| 147 | extern const struct clksel_rate dsp_ick_rates[]; | 147 | extern const struct clksel_rate dsp_ick_rates[]; |
| 148 | 148 | ||
| 149 | #if defined(CONFIG_ARCH_OMAP2) && defined(CONFIG_CPU_FREQ) | ||
| 150 | extern void omap2_clk_init_cpufreq_table(struct cpufreq_frequency_table **table); | ||
| 151 | extern void omap2_clk_exit_cpufreq_table(struct cpufreq_frequency_table **table); | ||
| 152 | #else | ||
| 153 | #define omap2_clk_init_cpufreq_table 0 | ||
| 154 | #define omap2_clk_exit_cpufreq_table 0 | ||
| 155 | #endif | ||
| 156 | |||
| 157 | extern const struct clkops clkops_omap2_iclk_dflt_wait; | 149 | extern const struct clkops clkops_omap2_iclk_dflt_wait; |
| 158 | extern const struct clkops clkops_omap2_iclk_dflt; | 150 | extern const struct clkops clkops_omap2_iclk_dflt; |
| 159 | extern const struct clkops clkops_omap2_iclk_idle_only; | 151 | extern const struct clkops clkops_omap2_iclk_idle_only; |
diff --git a/arch/arm/mach-omap2/omap_hwmod.c b/arch/arm/mach-omap2/omap_hwmod.c index 2c27fdb61e66..7144ae651d3d 100644 --- a/arch/arm/mach-omap2/omap_hwmod.c +++ b/arch/arm/mach-omap2/omap_hwmod.c | |||
| @@ -1422,6 +1422,9 @@ static int _ocp_softreset(struct omap_hwmod *oh) | |||
| 1422 | goto dis_opt_clks; | 1422 | goto dis_opt_clks; |
| 1423 | _write_sysconfig(v, oh); | 1423 | _write_sysconfig(v, oh); |
| 1424 | 1424 | ||
| 1425 | if (oh->class->sysc->srst_udelay) | ||
| 1426 | udelay(oh->class->sysc->srst_udelay); | ||
| 1427 | |||
| 1425 | if (oh->class->sysc->sysc_flags & SYSS_HAS_RESET_STATUS) | 1428 | if (oh->class->sysc->sysc_flags & SYSS_HAS_RESET_STATUS) |
| 1426 | omap_test_timeout((omap_hwmod_read(oh, | 1429 | omap_test_timeout((omap_hwmod_read(oh, |
| 1427 | oh->class->sysc->syss_offs) | 1430 | oh->class->sysc->syss_offs) |
| @@ -1903,10 +1906,20 @@ void omap_hwmod_write(u32 v, struct omap_hwmod *oh, u16 reg_offs) | |||
| 1903 | */ | 1906 | */ |
| 1904 | int omap_hwmod_softreset(struct omap_hwmod *oh) | 1907 | int omap_hwmod_softreset(struct omap_hwmod *oh) |
| 1905 | { | 1908 | { |
| 1906 | if (!oh) | 1909 | u32 v; |
| 1910 | int ret; | ||
| 1911 | |||
| 1912 | if (!oh || !(oh->_sysc_cache)) | ||
| 1907 | return -EINVAL; | 1913 | return -EINVAL; |
| 1908 | 1914 | ||
| 1909 | return _ocp_softreset(oh); | 1915 | v = oh->_sysc_cache; |
| 1916 | ret = _set_softreset(oh, &v); | ||
| 1917 | if (ret) | ||
| 1918 | goto error; | ||
| 1919 | _write_sysconfig(v, oh); | ||
| 1920 | |||
| 1921 | error: | ||
| 1922 | return ret; | ||
| 1910 | } | 1923 | } |
| 1911 | 1924 | ||
| 1912 | /** | 1925 | /** |
diff --git a/arch/arm/mach-omap2/omap_hwmod_2420_data.c b/arch/arm/mach-omap2/omap_hwmod_2420_data.c index a5409ce3f323..a6bde34e443a 100644 --- a/arch/arm/mach-omap2/omap_hwmod_2420_data.c +++ b/arch/arm/mach-omap2/omap_hwmod_2420_data.c | |||
| @@ -1000,7 +1000,6 @@ static struct omap_hwmod_ocp_if omap2420_l4_core__dss_venc = { | |||
| 1000 | .flags = OMAP_FIREWALL_L4, | 1000 | .flags = OMAP_FIREWALL_L4, |
| 1001 | } | 1001 | } |
| 1002 | }, | 1002 | }, |
| 1003 | .flags = OCPIF_SWSUP_IDLE, | ||
| 1004 | .user = OCP_USER_MPU | OCP_USER_SDMA, | 1003 | .user = OCP_USER_MPU | OCP_USER_SDMA, |
| 1005 | }; | 1004 | }; |
| 1006 | 1005 | ||
diff --git a/arch/arm/mach-omap2/omap_hwmod_2430_data.c b/arch/arm/mach-omap2/omap_hwmod_2430_data.c index c4f56cb60d7d..04a3885f4475 100644 --- a/arch/arm/mach-omap2/omap_hwmod_2430_data.c +++ b/arch/arm/mach-omap2/omap_hwmod_2430_data.c | |||
| @@ -1049,7 +1049,6 @@ static struct omap_hwmod_ocp_if omap2430_l4_core__dss_venc = { | |||
| 1049 | .slave = &omap2430_dss_venc_hwmod, | 1049 | .slave = &omap2430_dss_venc_hwmod, |
| 1050 | .clk = "dss_ick", | 1050 | .clk = "dss_ick", |
| 1051 | .addr = omap2_dss_venc_addrs, | 1051 | .addr = omap2_dss_venc_addrs, |
| 1052 | .flags = OCPIF_SWSUP_IDLE, | ||
| 1053 | .user = OCP_USER_MPU | OCP_USER_SDMA, | 1052 | .user = OCP_USER_MPU | OCP_USER_SDMA, |
| 1054 | }; | 1053 | }; |
| 1055 | 1054 | ||
diff --git a/arch/arm/mach-omap2/omap_hwmod_3xxx_data.c b/arch/arm/mach-omap2/omap_hwmod_3xxx_data.c index 34b9766d1d23..db86ce90c69f 100644 --- a/arch/arm/mach-omap2/omap_hwmod_3xxx_data.c +++ b/arch/arm/mach-omap2/omap_hwmod_3xxx_data.c | |||
| @@ -1676,7 +1676,6 @@ static struct omap_hwmod_ocp_if omap3xxx_l4_core__dss_venc = { | |||
| 1676 | .flags = OMAP_FIREWALL_L4, | 1676 | .flags = OMAP_FIREWALL_L4, |
| 1677 | } | 1677 | } |
| 1678 | }, | 1678 | }, |
| 1679 | .flags = OCPIF_SWSUP_IDLE, | ||
| 1680 | .user = OCP_USER_MPU | OCP_USER_SDMA, | 1679 | .user = OCP_USER_MPU | OCP_USER_SDMA, |
| 1681 | }; | 1680 | }; |
| 1682 | 1681 | ||
diff --git a/arch/arm/mach-omap2/omap_hwmod_44xx_data.c b/arch/arm/mach-omap2/omap_hwmod_44xx_data.c index cc9bd106a854..6abc75753e42 100644 --- a/arch/arm/mach-omap2/omap_hwmod_44xx_data.c +++ b/arch/arm/mach-omap2/omap_hwmod_44xx_data.c | |||
| @@ -2594,6 +2594,15 @@ static struct omap_hwmod omap44xx_ipu_hwmod = { | |||
| 2594 | static struct omap_hwmod_class_sysconfig omap44xx_iss_sysc = { | 2594 | static struct omap_hwmod_class_sysconfig omap44xx_iss_sysc = { |
| 2595 | .rev_offs = 0x0000, | 2595 | .rev_offs = 0x0000, |
| 2596 | .sysc_offs = 0x0010, | 2596 | .sysc_offs = 0x0010, |
| 2597 | /* | ||
| 2598 | * ISS needs 100 OCP clk cycles delay after a softreset before | ||
| 2599 | * accessing sysconfig again. | ||
| 2600 | * The lowest frequency at the moment for L3 bus is 100 MHz, so | ||
| 2601 | * 1usec delay is needed. Add an x2 margin to be safe (2 usecs). | ||
| 2602 | * | ||
| 2603 | * TODO: Indicate errata when available. | ||
| 2604 | */ | ||
| 2605 | .srst_udelay = 2, | ||
| 2597 | .sysc_flags = (SYSC_HAS_MIDLEMODE | SYSC_HAS_RESET_STATUS | | 2606 | .sysc_flags = (SYSC_HAS_MIDLEMODE | SYSC_HAS_RESET_STATUS | |
| 2598 | SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET), | 2607 | SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET), |
| 2599 | .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART | | 2608 | .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART | |
diff --git a/arch/arm/mach-omap2/serial.c b/arch/arm/mach-omap2/serial.c index 0cdd359a128e..9fc2f44188cb 100644 --- a/arch/arm/mach-omap2/serial.c +++ b/arch/arm/mach-omap2/serial.c | |||
| @@ -108,8 +108,14 @@ static void omap_uart_set_noidle(struct platform_device *pdev) | |||
| 108 | static void omap_uart_set_smartidle(struct platform_device *pdev) | 108 | static void omap_uart_set_smartidle(struct platform_device *pdev) |
| 109 | { | 109 | { |
| 110 | struct omap_device *od = to_omap_device(pdev); | 110 | struct omap_device *od = to_omap_device(pdev); |
| 111 | u8 idlemode; | ||
| 111 | 112 | ||
| 112 | omap_hwmod_set_slave_idlemode(od->hwmods[0], HWMOD_IDLEMODE_SMART); | 113 | if (od->hwmods[0]->class->sysc->idlemodes & SIDLE_SMART_WKUP) |
| 114 | idlemode = HWMOD_IDLEMODE_SMART_WKUP; | ||
| 115 | else | ||
| 116 | idlemode = HWMOD_IDLEMODE_SMART; | ||
| 117 | |||
| 118 | omap_hwmod_set_slave_idlemode(od->hwmods[0], idlemode); | ||
| 113 | } | 119 | } |
| 114 | 120 | ||
| 115 | #else | 121 | #else |
| @@ -120,124 +126,8 @@ static void omap_uart_set_smartidle(struct platform_device *pdev) {} | |||
| 120 | #endif /* CONFIG_PM */ | 126 | #endif /* CONFIG_PM */ |
| 121 | 127 | ||
| 122 | #ifdef CONFIG_OMAP_MUX | 128 | #ifdef CONFIG_OMAP_MUX |
| 123 | static struct omap_device_pad default_uart1_pads[] __initdata = { | ||
| 124 | { | ||
| 125 | .name = "uart1_cts.uart1_cts", | ||
| 126 | .enable = OMAP_PIN_INPUT_PULLUP | OMAP_MUX_MODE0, | ||
| 127 | }, | ||
| 128 | { | ||
| 129 | .name = "uart1_rts.uart1_rts", | ||
| 130 | .enable = OMAP_PIN_OUTPUT | OMAP_MUX_MODE0, | ||
| 131 | }, | ||
| 132 | { | ||
| 133 | .name = "uart1_tx.uart1_tx", | ||
| 134 | .enable = OMAP_PIN_OUTPUT | OMAP_MUX_MODE0, | ||
| 135 | }, | ||
| 136 | { | ||
| 137 | .name = "uart1_rx.uart1_rx", | ||
| 138 | .flags = OMAP_DEVICE_PAD_REMUX | OMAP_DEVICE_PAD_WAKEUP, | ||
| 139 | .enable = OMAP_PIN_INPUT_PULLUP | OMAP_MUX_MODE0, | ||
| 140 | .idle = OMAP_PIN_INPUT_PULLUP | OMAP_MUX_MODE0, | ||
| 141 | }, | ||
| 142 | }; | ||
| 143 | |||
| 144 | static struct omap_device_pad default_uart2_pads[] __initdata = { | ||
| 145 | { | ||
| 146 | .name = "uart2_cts.uart2_cts", | ||
| 147 | .enable = OMAP_PIN_INPUT_PULLUP | OMAP_MUX_MODE0, | ||
| 148 | }, | ||
| 149 | { | ||
| 150 | .name = "uart2_rts.uart2_rts", | ||
| 151 | .enable = OMAP_PIN_OUTPUT | OMAP_MUX_MODE0, | ||
| 152 | }, | ||
| 153 | { | ||
| 154 | .name = "uart2_tx.uart2_tx", | ||
| 155 | .enable = OMAP_PIN_OUTPUT | OMAP_MUX_MODE0, | ||
| 156 | }, | ||
| 157 | { | ||
| 158 | .name = "uart2_rx.uart2_rx", | ||
| 159 | .flags = OMAP_DEVICE_PAD_REMUX | OMAP_DEVICE_PAD_WAKEUP, | ||
| 160 | .enable = OMAP_PIN_INPUT_PULLUP | OMAP_MUX_MODE0, | ||
| 161 | .idle = OMAP_PIN_INPUT_PULLUP | OMAP_MUX_MODE0, | ||
| 162 | }, | ||
| 163 | }; | ||
| 164 | |||
| 165 | static struct omap_device_pad default_uart3_pads[] __initdata = { | ||
| 166 | { | ||
| 167 | .name = "uart3_cts_rctx.uart3_cts_rctx", | ||
| 168 | .enable = OMAP_PIN_INPUT_PULLUP | OMAP_MUX_MODE0, | ||
| 169 | }, | ||
| 170 | { | ||
| 171 | .name = "uart3_rts_sd.uart3_rts_sd", | ||
| 172 | .enable = OMAP_PIN_OUTPUT | OMAP_MUX_MODE0, | ||
| 173 | }, | ||
| 174 | { | ||
| 175 | .name = "uart3_tx_irtx.uart3_tx_irtx", | ||
| 176 | .enable = OMAP_PIN_OUTPUT | OMAP_MUX_MODE0, | ||
| 177 | }, | ||
| 178 | { | ||
| 179 | .name = "uart3_rx_irrx.uart3_rx_irrx", | ||
| 180 | .flags = OMAP_DEVICE_PAD_REMUX | OMAP_DEVICE_PAD_WAKEUP, | ||
| 181 | .enable = OMAP_PIN_INPUT | OMAP_MUX_MODE0, | ||
| 182 | .idle = OMAP_PIN_INPUT | OMAP_MUX_MODE0, | ||
| 183 | }, | ||
| 184 | }; | ||
| 185 | |||
| 186 | static struct omap_device_pad default_omap36xx_uart4_pads[] __initdata = { | ||
| 187 | { | ||
| 188 | .name = "gpmc_wait2.uart4_tx", | ||
| 189 | .enable = OMAP_PIN_OUTPUT | OMAP_MUX_MODE0, | ||
| 190 | }, | ||
| 191 | { | ||
| 192 | .name = "gpmc_wait3.uart4_rx", | ||
| 193 | .flags = OMAP_DEVICE_PAD_REMUX | OMAP_DEVICE_PAD_WAKEUP, | ||
| 194 | .enable = OMAP_PIN_INPUT | OMAP_MUX_MODE2, | ||
| 195 | .idle = OMAP_PIN_INPUT | OMAP_MUX_MODE2, | ||
| 196 | }, | ||
| 197 | }; | ||
| 198 | |||
| 199 | static struct omap_device_pad default_omap4_uart4_pads[] __initdata = { | ||
| 200 | { | ||
| 201 | .name = "uart4_tx.uart4_tx", | ||
| 202 | .enable = OMAP_PIN_OUTPUT | OMAP_MUX_MODE0, | ||
| 203 | }, | ||
| 204 | { | ||
| 205 | .name = "uart4_rx.uart4_rx", | ||
| 206 | .flags = OMAP_DEVICE_PAD_REMUX | OMAP_DEVICE_PAD_WAKEUP, | ||
| 207 | .enable = OMAP_PIN_INPUT | OMAP_MUX_MODE0, | ||
| 208 | .idle = OMAP_PIN_INPUT | OMAP_MUX_MODE0, | ||
| 209 | }, | ||
| 210 | }; | ||
| 211 | |||
| 212 | static void omap_serial_fill_default_pads(struct omap_board_data *bdata) | 129 | static void omap_serial_fill_default_pads(struct omap_board_data *bdata) |
| 213 | { | 130 | { |
| 214 | switch (bdata->id) { | ||
| 215 | case 0: | ||
| 216 | bdata->pads = default_uart1_pads; | ||
| 217 | bdata->pads_cnt = ARRAY_SIZE(default_uart1_pads); | ||
| 218 | break; | ||
| 219 | case 1: | ||
| 220 | bdata->pads = default_uart2_pads; | ||
| 221 | bdata->pads_cnt = ARRAY_SIZE(default_uart2_pads); | ||
| 222 | break; | ||
| 223 | case 2: | ||
| 224 | bdata->pads = default_uart3_pads; | ||
| 225 | bdata->pads_cnt = ARRAY_SIZE(default_uart3_pads); | ||
| 226 | break; | ||
| 227 | case 3: | ||
| 228 | if (cpu_is_omap44xx()) { | ||
| 229 | bdata->pads = default_omap4_uart4_pads; | ||
| 230 | bdata->pads_cnt = | ||
| 231 | ARRAY_SIZE(default_omap4_uart4_pads); | ||
| 232 | } else if (cpu_is_omap3630()) { | ||
| 233 | bdata->pads = default_omap36xx_uart4_pads; | ||
| 234 | bdata->pads_cnt = | ||
| 235 | ARRAY_SIZE(default_omap36xx_uart4_pads); | ||
| 236 | } | ||
| 237 | break; | ||
| 238 | default: | ||
| 239 | break; | ||
| 240 | } | ||
| 241 | } | 131 | } |
| 242 | #else | 132 | #else |
| 243 | static void omap_serial_fill_default_pads(struct omap_board_data *bdata) {} | 133 | static void omap_serial_fill_default_pads(struct omap_board_data *bdata) {} |
diff --git a/arch/arm/mach-omap2/twl-common.c b/arch/arm/mach-omap2/twl-common.c index 4b57757bf9d1..7a7b89304c48 100644 --- a/arch/arm/mach-omap2/twl-common.c +++ b/arch/arm/mach-omap2/twl-common.c | |||
| @@ -37,6 +37,16 @@ static struct i2c_board_info __initdata pmic_i2c_board_info = { | |||
| 37 | .flags = I2C_CLIENT_WAKE, | 37 | .flags = I2C_CLIENT_WAKE, |
| 38 | }; | 38 | }; |
| 39 | 39 | ||
| 40 | static struct i2c_board_info __initdata omap4_i2c1_board_info[] = { | ||
| 41 | { | ||
| 42 | .addr = 0x48, | ||
| 43 | .flags = I2C_CLIENT_WAKE, | ||
| 44 | }, | ||
| 45 | { | ||
| 46 | I2C_BOARD_INFO("twl6040", 0x4b), | ||
| 47 | }, | ||
| 48 | }; | ||
| 49 | |||
| 40 | void __init omap_pmic_init(int bus, u32 clkrate, | 50 | void __init omap_pmic_init(int bus, u32 clkrate, |
| 41 | const char *pmic_type, int pmic_irq, | 51 | const char *pmic_type, int pmic_irq, |
| 42 | struct twl4030_platform_data *pmic_data) | 52 | struct twl4030_platform_data *pmic_data) |
| @@ -49,14 +59,31 @@ void __init omap_pmic_init(int bus, u32 clkrate, | |||
| 49 | omap_register_i2c_bus(bus, clkrate, &pmic_i2c_board_info, 1); | 59 | omap_register_i2c_bus(bus, clkrate, &pmic_i2c_board_info, 1); |
| 50 | } | 60 | } |
| 51 | 61 | ||
| 62 | void __init omap4_pmic_init(const char *pmic_type, | ||
| 63 | struct twl4030_platform_data *pmic_data, | ||
| 64 | struct twl6040_platform_data *twl6040_data, int twl6040_irq) | ||
| 65 | { | ||
| 66 | /* PMIC part*/ | ||
| 67 | strncpy(omap4_i2c1_board_info[0].type, pmic_type, | ||
| 68 | sizeof(omap4_i2c1_board_info[0].type)); | ||
| 69 | omap4_i2c1_board_info[0].irq = OMAP44XX_IRQ_SYS_1N; | ||
| 70 | omap4_i2c1_board_info[0].platform_data = pmic_data; | ||
| 71 | |||
| 72 | /* TWL6040 audio IC part */ | ||
| 73 | omap4_i2c1_board_info[1].irq = twl6040_irq; | ||
| 74 | omap4_i2c1_board_info[1].platform_data = twl6040_data; | ||
| 75 | |||
| 76 | omap_register_i2c_bus(1, 400, omap4_i2c1_board_info, 2); | ||
| 77 | |||
| 78 | } | ||
| 79 | |||
| 52 | void __init omap_pmic_late_init(void) | 80 | void __init omap_pmic_late_init(void) |
| 53 | { | 81 | { |
| 54 | /* Init the OMAP TWL parameters (if PMIC has been registerd) */ | 82 | /* Init the OMAP TWL parameters (if PMIC has been registerd) */ |
| 55 | if (!pmic_i2c_board_info.irq) | 83 | if (pmic_i2c_board_info.irq) |
| 56 | return; | 84 | omap3_twl_init(); |
| 57 | 85 | if (omap4_i2c1_board_info[0].irq) | |
| 58 | omap3_twl_init(); | 86 | omap4_twl_init(); |
| 59 | omap4_twl_init(); | ||
| 60 | } | 87 | } |
| 61 | 88 | ||
| 62 | #if defined(CONFIG_ARCH_OMAP3) | 89 | #if defined(CONFIG_ARCH_OMAP3) |
diff --git a/arch/arm/mach-omap2/twl-common.h b/arch/arm/mach-omap2/twl-common.h index 275dde8cb27a..09627483a57f 100644 --- a/arch/arm/mach-omap2/twl-common.h +++ b/arch/arm/mach-omap2/twl-common.h | |||
| @@ -29,6 +29,7 @@ | |||
| 29 | 29 | ||
| 30 | 30 | ||
| 31 | struct twl4030_platform_data; | 31 | struct twl4030_platform_data; |
| 32 | struct twl6040_platform_data; | ||
| 32 | 33 | ||
| 33 | void omap_pmic_init(int bus, u32 clkrate, const char *pmic_type, int pmic_irq, | 34 | void omap_pmic_init(int bus, u32 clkrate, const char *pmic_type, int pmic_irq, |
| 34 | struct twl4030_platform_data *pmic_data); | 35 | struct twl4030_platform_data *pmic_data); |
| @@ -46,12 +47,9 @@ static inline void omap3_pmic_init(const char *pmic_type, | |||
| 46 | omap_pmic_init(1, 2600, pmic_type, INT_34XX_SYS_NIRQ, pmic_data); | 47 | omap_pmic_init(1, 2600, pmic_type, INT_34XX_SYS_NIRQ, pmic_data); |
| 47 | } | 48 | } |
| 48 | 49 | ||
| 49 | static inline void omap4_pmic_init(const char *pmic_type, | 50 | void omap4_pmic_init(const char *pmic_type, |
| 50 | struct twl4030_platform_data *pmic_data) | 51 | struct twl4030_platform_data *pmic_data, |
| 51 | { | 52 | struct twl6040_platform_data *audio_data, int twl6040_irq); |
| 52 | /* Phoenix Audio IC needs I2C1 to start with 400 KHz or less */ | ||
| 53 | omap_pmic_init(1, 400, pmic_type, OMAP44XX_IRQ_SYS_1N, pmic_data); | ||
| 54 | } | ||
| 55 | 53 | ||
| 56 | void omap3_pmic_get_config(struct twl4030_platform_data *pmic_data, | 54 | void omap3_pmic_get_config(struct twl4030_platform_data *pmic_data, |
| 57 | u32 pdata_flags, u32 regulators_flags); | 55 | u32 pdata_flags, u32 regulators_flags); |
diff --git a/arch/arm/mach-s5pv210/dma.c b/arch/arm/mach-s5pv210/dma.c index 86ce62f66190..b8337e248b09 100644 --- a/arch/arm/mach-s5pv210/dma.c +++ b/arch/arm/mach-s5pv210/dma.c | |||
| @@ -33,8 +33,6 @@ | |||
| 33 | #include <mach/irqs.h> | 33 | #include <mach/irqs.h> |
| 34 | #include <mach/dma.h> | 34 | #include <mach/dma.h> |
| 35 | 35 | ||
| 36 | static u64 dma_dmamask = DMA_BIT_MASK(32); | ||
| 37 | |||
| 38 | static u8 pdma0_peri[] = { | 36 | static u8 pdma0_peri[] = { |
| 39 | DMACH_UART0_RX, | 37 | DMACH_UART0_RX, |
| 40 | DMACH_UART0_TX, | 38 | DMACH_UART0_TX, |
diff --git a/arch/arm/mach-s5pv210/mach-aquila.c b/arch/arm/mach-s5pv210/mach-aquila.c index a9ea64e0da0d..48d018f2332b 100644 --- a/arch/arm/mach-s5pv210/mach-aquila.c +++ b/arch/arm/mach-s5pv210/mach-aquila.c | |||
| @@ -484,8 +484,8 @@ static struct wm8994_pdata wm8994_platform_data = { | |||
| 484 | .gpio_defaults[8] = 0x0100, | 484 | .gpio_defaults[8] = 0x0100, |
| 485 | .gpio_defaults[9] = 0x0100, | 485 | .gpio_defaults[9] = 0x0100, |
| 486 | .gpio_defaults[10] = 0x0100, | 486 | .gpio_defaults[10] = 0x0100, |
| 487 | .ldo[0] = { S5PV210_MP03(6), NULL, &wm8994_ldo1_data }, /* XM0FRNB_2 */ | 487 | .ldo[0] = { S5PV210_MP03(6), &wm8994_ldo1_data }, /* XM0FRNB_2 */ |
| 488 | .ldo[1] = { 0, NULL, &wm8994_ldo2_data }, | 488 | .ldo[1] = { 0, &wm8994_ldo2_data }, |
| 489 | }; | 489 | }; |
| 490 | 490 | ||
| 491 | /* GPIO I2C PMIC */ | 491 | /* GPIO I2C PMIC */ |
diff --git a/arch/arm/mach-s5pv210/mach-goni.c b/arch/arm/mach-s5pv210/mach-goni.c index 2cf5ed75f390..a8933de3d627 100644 --- a/arch/arm/mach-s5pv210/mach-goni.c +++ b/arch/arm/mach-s5pv210/mach-goni.c | |||
| @@ -674,8 +674,8 @@ static struct wm8994_pdata wm8994_platform_data = { | |||
| 674 | .gpio_defaults[8] = 0x0100, | 674 | .gpio_defaults[8] = 0x0100, |
| 675 | .gpio_defaults[9] = 0x0100, | 675 | .gpio_defaults[9] = 0x0100, |
| 676 | .gpio_defaults[10] = 0x0100, | 676 | .gpio_defaults[10] = 0x0100, |
| 677 | .ldo[0] = { S5PV210_MP03(6), NULL, &wm8994_ldo1_data }, /* XM0FRNB_2 */ | 677 | .ldo[0] = { S5PV210_MP03(6), &wm8994_ldo1_data }, /* XM0FRNB_2 */ |
| 678 | .ldo[1] = { 0, NULL, &wm8994_ldo2_data }, | 678 | .ldo[1] = { 0, &wm8994_ldo2_data }, |
| 679 | }; | 679 | }; |
| 680 | 680 | ||
| 681 | /* GPIO I2C PMIC */ | 681 | /* GPIO I2C PMIC */ |
diff --git a/arch/arm/mach-ux500/Kconfig b/arch/arm/mach-ux500/Kconfig index 880d02ec89d4..ef7099eea0f2 100644 --- a/arch/arm/mach-ux500/Kconfig +++ b/arch/arm/mach-ux500/Kconfig | |||
| @@ -17,6 +17,7 @@ config UX500_SOC_DB5500 | |||
| 17 | config UX500_SOC_DB8500 | 17 | config UX500_SOC_DB8500 |
| 18 | bool | 18 | bool |
| 19 | select MFD_DB8500_PRCMU | 19 | select MFD_DB8500_PRCMU |
| 20 | select REGULATOR | ||
| 20 | select REGULATOR_DB8500_PRCMU | 21 | select REGULATOR_DB8500_PRCMU |
| 21 | select CPU_FREQ_TABLE if CPU_FREQ | 22 | select CPU_FREQ_TABLE if CPU_FREQ |
| 22 | 23 | ||
diff --git a/arch/arm/mach-ux500/platsmp.c b/arch/arm/mach-ux500/platsmp.c index d2058ef8345f..eff5842f6232 100644 --- a/arch/arm/mach-ux500/platsmp.c +++ b/arch/arm/mach-ux500/platsmp.c | |||
| @@ -99,7 +99,7 @@ int __cpuinit boot_secondary(unsigned int cpu, struct task_struct *idle) | |||
| 99 | */ | 99 | */ |
| 100 | write_pen_release(cpu_logical_map(cpu)); | 100 | write_pen_release(cpu_logical_map(cpu)); |
| 101 | 101 | ||
| 102 | gic_raise_softirq(cpumask_of(cpu), 1); | 102 | smp_send_reschedule(cpu); |
| 103 | 103 | ||
| 104 | timeout = jiffies + (1 * HZ); | 104 | timeout = jiffies + (1 * HZ); |
| 105 | while (time_before(jiffies, timeout)) { | 105 | while (time_before(jiffies, timeout)) { |
diff --git a/arch/arm/mm/Kconfig b/arch/arm/mm/Kconfig index 7edef9121632..7c8a7d8467bf 100644 --- a/arch/arm/mm/Kconfig +++ b/arch/arm/mm/Kconfig | |||
| @@ -723,7 +723,7 @@ config CPU_HIGH_VECTOR | |||
| 723 | bool "Select the High exception vector" | 723 | bool "Select the High exception vector" |
| 724 | help | 724 | help |
| 725 | Say Y here to select high exception vector(0xFFFF0000~). | 725 | Say Y here to select high exception vector(0xFFFF0000~). |
| 726 | The exception vector can be vary depending on the platform | 726 | The exception vector can vary depending on the platform |
| 727 | design in nommu mode. If your platform needs to select | 727 | design in nommu mode. If your platform needs to select |
| 728 | high exception vector, say Y. | 728 | high exception vector, say Y. |
| 729 | Otherwise or if you are unsure, say N, and the low exception | 729 | Otherwise or if you are unsure, say N, and the low exception |
diff --git a/arch/arm/mm/fault.c b/arch/arm/mm/fault.c index 9055b5a84ec5..f07467533365 100644 --- a/arch/arm/mm/fault.c +++ b/arch/arm/mm/fault.c | |||
| @@ -320,7 +320,7 @@ retry: | |||
| 320 | */ | 320 | */ |
| 321 | 321 | ||
| 322 | perf_sw_event(PERF_COUNT_SW_PAGE_FAULTS, 1, regs, addr); | 322 | perf_sw_event(PERF_COUNT_SW_PAGE_FAULTS, 1, regs, addr); |
| 323 | if (flags & FAULT_FLAG_ALLOW_RETRY) { | 323 | if (!(fault & VM_FAULT_ERROR) && flags & FAULT_FLAG_ALLOW_RETRY) { |
| 324 | if (fault & VM_FAULT_MAJOR) { | 324 | if (fault & VM_FAULT_MAJOR) { |
| 325 | tsk->maj_flt++; | 325 | tsk->maj_flt++; |
| 326 | perf_sw_event(PERF_COUNT_SW_PAGE_FAULTS_MAJ, 1, | 326 | perf_sw_event(PERF_COUNT_SW_PAGE_FAULTS_MAJ, 1, |
diff --git a/arch/arm/mm/nommu.c b/arch/arm/mm/nommu.c index 6486d2f253cd..d51225f90ae2 100644 --- a/arch/arm/mm/nommu.c +++ b/arch/arm/mm/nommu.c | |||
| @@ -13,6 +13,7 @@ | |||
| 13 | #include <asm/sections.h> | 13 | #include <asm/sections.h> |
| 14 | #include <asm/page.h> | 14 | #include <asm/page.h> |
| 15 | #include <asm/setup.h> | 15 | #include <asm/setup.h> |
| 16 | #include <asm/traps.h> | ||
| 16 | #include <asm/mach/arch.h> | 17 | #include <asm/mach/arch.h> |
| 17 | 18 | ||
| 18 | #include "mm.h" | 19 | #include "mm.h" |
| @@ -39,6 +40,7 @@ void __init sanity_check_meminfo(void) | |||
| 39 | */ | 40 | */ |
| 40 | void __init paging_init(struct machine_desc *mdesc) | 41 | void __init paging_init(struct machine_desc *mdesc) |
| 41 | { | 42 | { |
| 43 | early_trap_init((void *)CONFIG_VECTORS_BASE); | ||
| 42 | bootmem_init(); | 44 | bootmem_init(); |
| 43 | } | 45 | } |
| 44 | 46 | ||
diff --git a/arch/arm/mm/proc-v7.S b/arch/arm/mm/proc-v7.S index f1c8486f7501..c2e2b66f72b5 100644 --- a/arch/arm/mm/proc-v7.S +++ b/arch/arm/mm/proc-v7.S | |||
| @@ -255,6 +255,18 @@ __v7_setup: | |||
| 255 | mcr p15, 0, r5, c10, c2, 0 @ write PRRR | 255 | mcr p15, 0, r5, c10, c2, 0 @ write PRRR |
| 256 | mcr p15, 0, r6, c10, c2, 1 @ write NMRR | 256 | mcr p15, 0, r6, c10, c2, 1 @ write NMRR |
| 257 | #endif | 257 | #endif |
| 258 | #ifndef CONFIG_ARM_THUMBEE | ||
| 259 | mrc p15, 0, r0, c0, c1, 0 @ read ID_PFR0 for ThumbEE | ||
| 260 | and r0, r0, #(0xf << 12) @ ThumbEE enabled field | ||
| 261 | teq r0, #(1 << 12) @ check if ThumbEE is present | ||
| 262 | bne 1f | ||
| 263 | mov r5, #0 | ||
| 264 | mcr p14, 6, r5, c1, c0, 0 @ Initialize TEEHBR to 0 | ||
| 265 | mrc p14, 6, r0, c0, c0, 0 @ load TEECR | ||
| 266 | orr r0, r0, #1 @ set the 1st bit in order to | ||
| 267 | mcr p14, 6, r0, c0, c0, 0 @ stop userspace TEEHBR access | ||
| 268 | 1: | ||
| 269 | #endif | ||
| 258 | adr r5, v7_crval | 270 | adr r5, v7_crval |
| 259 | ldmia r5, {r5, r6} | 271 | ldmia r5, {r5, r6} |
| 260 | #ifdef CONFIG_CPU_ENDIAN_BE8 | 272 | #ifdef CONFIG_CPU_ENDIAN_BE8 |
diff --git a/arch/arm/plat-omap/clock.c b/arch/arm/plat-omap/clock.c index 8506cbb7fea4..62ec5c452792 100644 --- a/arch/arm/plat-omap/clock.c +++ b/arch/arm/plat-omap/clock.c | |||
| @@ -398,32 +398,6 @@ struct clk dummy_ck = { | |||
| 398 | .ops = &clkops_null, | 398 | .ops = &clkops_null, |
| 399 | }; | 399 | }; |
| 400 | 400 | ||
| 401 | #ifdef CONFIG_CPU_FREQ | ||
| 402 | void clk_init_cpufreq_table(struct cpufreq_frequency_table **table) | ||
| 403 | { | ||
| 404 | unsigned long flags; | ||
| 405 | |||
| 406 | if (!arch_clock || !arch_clock->clk_init_cpufreq_table) | ||
| 407 | return; | ||
| 408 | |||
| 409 | spin_lock_irqsave(&clockfw_lock, flags); | ||
| 410 | arch_clock->clk_init_cpufreq_table(table); | ||
| 411 | spin_unlock_irqrestore(&clockfw_lock, flags); | ||
| 412 | } | ||
| 413 | |||
| 414 | void clk_exit_cpufreq_table(struct cpufreq_frequency_table **table) | ||
| 415 | { | ||
| 416 | unsigned long flags; | ||
| 417 | |||
| 418 | if (!arch_clock || !arch_clock->clk_exit_cpufreq_table) | ||
| 419 | return; | ||
| 420 | |||
| 421 | spin_lock_irqsave(&clockfw_lock, flags); | ||
| 422 | arch_clock->clk_exit_cpufreq_table(table); | ||
| 423 | spin_unlock_irqrestore(&clockfw_lock, flags); | ||
| 424 | } | ||
| 425 | #endif | ||
| 426 | |||
| 427 | /* | 401 | /* |
| 428 | * | 402 | * |
| 429 | */ | 403 | */ |
diff --git a/arch/arm/plat-omap/include/plat/clock.h b/arch/arm/plat-omap/include/plat/clock.h index 240a7b9fd946..d0ef57c1d71b 100644 --- a/arch/arm/plat-omap/include/plat/clock.h +++ b/arch/arm/plat-omap/include/plat/clock.h | |||
| @@ -272,8 +272,6 @@ struct clk { | |||
| 272 | #endif | 272 | #endif |
| 273 | }; | 273 | }; |
| 274 | 274 | ||
| 275 | struct cpufreq_frequency_table; | ||
| 276 | |||
| 277 | struct clk_functions { | 275 | struct clk_functions { |
| 278 | int (*clk_enable)(struct clk *clk); | 276 | int (*clk_enable)(struct clk *clk); |
| 279 | void (*clk_disable)(struct clk *clk); | 277 | void (*clk_disable)(struct clk *clk); |
| @@ -283,10 +281,6 @@ struct clk_functions { | |||
| 283 | void (*clk_allow_idle)(struct clk *clk); | 281 | void (*clk_allow_idle)(struct clk *clk); |
| 284 | void (*clk_deny_idle)(struct clk *clk); | 282 | void (*clk_deny_idle)(struct clk *clk); |
| 285 | void (*clk_disable_unused)(struct clk *clk); | 283 | void (*clk_disable_unused)(struct clk *clk); |
| 286 | #ifdef CONFIG_CPU_FREQ | ||
| 287 | void (*clk_init_cpufreq_table)(struct cpufreq_frequency_table **); | ||
| 288 | void (*clk_exit_cpufreq_table)(struct cpufreq_frequency_table **); | ||
| 289 | #endif | ||
| 290 | }; | 284 | }; |
| 291 | 285 | ||
| 292 | extern int mpurate; | 286 | extern int mpurate; |
| @@ -301,10 +295,6 @@ extern void recalculate_root_clocks(void); | |||
| 301 | extern unsigned long followparent_recalc(struct clk *clk); | 295 | extern unsigned long followparent_recalc(struct clk *clk); |
| 302 | extern void clk_enable_init_clocks(void); | 296 | extern void clk_enable_init_clocks(void); |
| 303 | unsigned long omap_fixed_divisor_recalc(struct clk *clk); | 297 | unsigned long omap_fixed_divisor_recalc(struct clk *clk); |
| 304 | #ifdef CONFIG_CPU_FREQ | ||
| 305 | extern void clk_init_cpufreq_table(struct cpufreq_frequency_table **table); | ||
| 306 | extern void clk_exit_cpufreq_table(struct cpufreq_frequency_table **table); | ||
| 307 | #endif | ||
| 308 | extern struct clk *omap_clk_get_by_name(const char *name); | 298 | extern struct clk *omap_clk_get_by_name(const char *name); |
| 309 | extern int omap_clk_enable_autoidle_all(void); | 299 | extern int omap_clk_enable_autoidle_all(void); |
| 310 | extern int omap_clk_disable_autoidle_all(void); | 300 | extern int omap_clk_disable_autoidle_all(void); |
diff --git a/arch/arm/plat-omap/include/plat/omap_hwmod.h b/arch/arm/plat-omap/include/plat/omap_hwmod.h index 8070145ccb98..3f26db4ee8e6 100644 --- a/arch/arm/plat-omap/include/plat/omap_hwmod.h +++ b/arch/arm/plat-omap/include/plat/omap_hwmod.h | |||
| @@ -305,6 +305,7 @@ struct omap_hwmod_sysc_fields { | |||
| 305 | * @rev_offs: IP block revision register offset (from module base addr) | 305 | * @rev_offs: IP block revision register offset (from module base addr) |
| 306 | * @sysc_offs: OCP_SYSCONFIG register offset (from module base addr) | 306 | * @sysc_offs: OCP_SYSCONFIG register offset (from module base addr) |
| 307 | * @syss_offs: OCP_SYSSTATUS register offset (from module base addr) | 307 | * @syss_offs: OCP_SYSSTATUS register offset (from module base addr) |
| 308 | * @srst_udelay: Delay needed after doing a softreset in usecs | ||
| 308 | * @idlemodes: One or more of {SIDLE,MSTANDBY}_{OFF,FORCE,SMART} | 309 | * @idlemodes: One or more of {SIDLE,MSTANDBY}_{OFF,FORCE,SMART} |
| 309 | * @sysc_flags: SYS{C,S}_HAS* flags indicating SYSCONFIG bits supported | 310 | * @sysc_flags: SYS{C,S}_HAS* flags indicating SYSCONFIG bits supported |
| 310 | * @clockact: the default value of the module CLOCKACTIVITY bits | 311 | * @clockact: the default value of the module CLOCKACTIVITY bits |
| @@ -330,9 +331,10 @@ struct omap_hwmod_class_sysconfig { | |||
| 330 | u16 sysc_offs; | 331 | u16 sysc_offs; |
| 331 | u16 syss_offs; | 332 | u16 syss_offs; |
| 332 | u16 sysc_flags; | 333 | u16 sysc_flags; |
| 334 | struct omap_hwmod_sysc_fields *sysc_fields; | ||
| 335 | u8 srst_udelay; | ||
| 333 | u8 idlemodes; | 336 | u8 idlemodes; |
| 334 | u8 clockact; | 337 | u8 clockact; |
| 335 | struct omap_hwmod_sysc_fields *sysc_fields; | ||
| 336 | }; | 338 | }; |
| 337 | 339 | ||
| 338 | /** | 340 | /** |
diff --git a/arch/arm/plat-omap/sram.c b/arch/arm/plat-omap/sram.c index eec98afa0f83..f9a8c5341ee9 100644 --- a/arch/arm/plat-omap/sram.c +++ b/arch/arm/plat-omap/sram.c | |||
| @@ -348,7 +348,6 @@ u32 omap3_configure_core_dpll(u32 m2, u32 unlock_dll, u32 f, u32 inc, | |||
| 348 | sdrc_actim_ctrl_b_1, sdrc_mr_1); | 348 | sdrc_actim_ctrl_b_1, sdrc_mr_1); |
| 349 | } | 349 | } |
| 350 | 350 | ||
| 351 | #ifdef CONFIG_PM | ||
| 352 | void omap3_sram_restore_context(void) | 351 | void omap3_sram_restore_context(void) |
| 353 | { | 352 | { |
| 354 | omap_sram_ceil = omap_sram_base + omap_sram_size; | 353 | omap_sram_ceil = omap_sram_base + omap_sram_size; |
| @@ -358,17 +357,18 @@ void omap3_sram_restore_context(void) | |||
| 358 | omap3_sram_configure_core_dpll_sz); | 357 | omap3_sram_configure_core_dpll_sz); |
| 359 | omap_push_sram_idle(); | 358 | omap_push_sram_idle(); |
| 360 | } | 359 | } |
| 361 | #endif /* CONFIG_PM */ | ||
| 362 | |||
| 363 | #endif /* CONFIG_ARCH_OMAP3 */ | ||
| 364 | 360 | ||
| 365 | static inline int omap34xx_sram_init(void) | 361 | static inline int omap34xx_sram_init(void) |
| 366 | { | 362 | { |
| 367 | #if defined(CONFIG_ARCH_OMAP3) && defined(CONFIG_PM) | ||
| 368 | omap3_sram_restore_context(); | 363 | omap3_sram_restore_context(); |
| 369 | #endif | ||
| 370 | return 0; | 364 | return 0; |
| 371 | } | 365 | } |
| 366 | #else | ||
| 367 | static inline int omap34xx_sram_init(void) | ||
| 368 | { | ||
| 369 | return 0; | ||
| 370 | } | ||
| 371 | #endif /* CONFIG_ARCH_OMAP3 */ | ||
| 372 | 372 | ||
| 373 | static inline int am33xx_sram_init(void) | 373 | static inline int am33xx_sram_init(void) |
| 374 | { | 374 | { |
diff --git a/arch/arm/plat-samsung/Kconfig b/arch/arm/plat-samsung/Kconfig index 71553f410016..a0ffc77da809 100644 --- a/arch/arm/plat-samsung/Kconfig +++ b/arch/arm/plat-samsung/Kconfig | |||
| @@ -302,6 +302,7 @@ comment "Power management" | |||
| 302 | config SAMSUNG_PM_DEBUG | 302 | config SAMSUNG_PM_DEBUG |
| 303 | bool "S3C2410 PM Suspend debug" | 303 | bool "S3C2410 PM Suspend debug" |
| 304 | depends on PM | 304 | depends on PM |
| 305 | select DEBUG_LL | ||
| 305 | help | 306 | help |
| 306 | Say Y here if you want verbose debugging from the PM Suspend and | 307 | Say Y here if you want verbose debugging from the PM Suspend and |
| 307 | Resume code. See <file:Documentation/arm/Samsung-S3C24XX/Suspend.txt> | 308 | Resume code. See <file:Documentation/arm/Samsung-S3C24XX/Suspend.txt> |
diff --git a/arch/ia64/include/asm/cmpxchg.h b/arch/ia64/include/asm/cmpxchg.h index 4c96187e2049..4f37dbbb8640 100644 --- a/arch/ia64/include/asm/cmpxchg.h +++ b/arch/ia64/include/asm/cmpxchg.h | |||
| @@ -1 +1,147 @@ | |||
| 1 | #include <asm/intrinsics.h> | 1 | #ifndef _ASM_IA64_CMPXCHG_H |
| 2 | #define _ASM_IA64_CMPXCHG_H | ||
| 3 | |||
| 4 | /* | ||
| 5 | * Compare/Exchange, forked from asm/intrinsics.h | ||
| 6 | * which was: | ||
| 7 | * | ||
| 8 | * Copyright (C) 2002-2003 Hewlett-Packard Co | ||
| 9 | * David Mosberger-Tang <davidm@hpl.hp.com> | ||
| 10 | */ | ||
| 11 | |||
| 12 | #ifndef __ASSEMBLY__ | ||
| 13 | |||
| 14 | #include <linux/types.h> | ||
| 15 | /* include compiler specific intrinsics */ | ||
| 16 | #include <asm/ia64regs.h> | ||
| 17 | #ifdef __INTEL_COMPILER | ||
| 18 | # include <asm/intel_intrin.h> | ||
| 19 | #else | ||
| 20 | # include <asm/gcc_intrin.h> | ||
| 21 | #endif | ||
| 22 | |||
| 23 | /* | ||
| 24 | * This function doesn't exist, so you'll get a linker error if | ||
| 25 | * something tries to do an invalid xchg(). | ||
| 26 | */ | ||
| 27 | extern void ia64_xchg_called_with_bad_pointer(void); | ||
| 28 | |||
| 29 | #define __xchg(x, ptr, size) \ | ||
| 30 | ({ \ | ||
| 31 | unsigned long __xchg_result; \ | ||
| 32 | \ | ||
| 33 | switch (size) { \ | ||
| 34 | case 1: \ | ||
| 35 | __xchg_result = ia64_xchg1((__u8 *)ptr, x); \ | ||
| 36 | break; \ | ||
| 37 | \ | ||
| 38 | case 2: \ | ||
| 39 | __xchg_result = ia64_xchg2((__u16 *)ptr, x); \ | ||
| 40 | break; \ | ||
| 41 | \ | ||
| 42 | case 4: \ | ||
| 43 | __xchg_result = ia64_xchg4((__u32 *)ptr, x); \ | ||
| 44 | break; \ | ||
| 45 | \ | ||
| 46 | case 8: \ | ||
| 47 | __xchg_result = ia64_xchg8((__u64 *)ptr, x); \ | ||
| 48 | break; \ | ||
| 49 | default: \ | ||
| 50 | ia64_xchg_called_with_bad_pointer(); \ | ||
| 51 | } \ | ||
| 52 | __xchg_result; \ | ||
| 53 | }) | ||
| 54 | |||
| 55 | #define xchg(ptr, x) \ | ||
| 56 | ((__typeof__(*(ptr))) __xchg((unsigned long) (x), (ptr), sizeof(*(ptr)))) | ||
| 57 | |||
| 58 | /* | ||
| 59 | * Atomic compare and exchange. Compare OLD with MEM, if identical, | ||
| 60 | * store NEW in MEM. Return the initial value in MEM. Success is | ||
| 61 | * indicated by comparing RETURN with OLD. | ||
| 62 | */ | ||
| 63 | |||
| 64 | #define __HAVE_ARCH_CMPXCHG 1 | ||
| 65 | |||
| 66 | /* | ||
| 67 | * This function doesn't exist, so you'll get a linker error | ||
| 68 | * if something tries to do an invalid cmpxchg(). | ||
| 69 | */ | ||
| 70 | extern long ia64_cmpxchg_called_with_bad_pointer(void); | ||
| 71 | |||
| 72 | #define ia64_cmpxchg(sem, ptr, old, new, size) \ | ||
| 73 | ({ \ | ||
| 74 | __u64 _o_, _r_; \ | ||
| 75 | \ | ||
| 76 | switch (size) { \ | ||
| 77 | case 1: \ | ||
| 78 | _o_ = (__u8) (long) (old); \ | ||
| 79 | break; \ | ||
| 80 | case 2: \ | ||
| 81 | _o_ = (__u16) (long) (old); \ | ||
| 82 | break; \ | ||
| 83 | case 4: \ | ||
| 84 | _o_ = (__u32) (long) (old); \ | ||
| 85 | break; \ | ||
| 86 | case 8: \ | ||
| 87 | _o_ = (__u64) (long) (old); \ | ||
| 88 | break; \ | ||
| 89 | default: \ | ||
| 90 | break; \ | ||
| 91 | } \ | ||
| 92 | switch (size) { \ | ||
| 93 | case 1: \ | ||
| 94 | _r_ = ia64_cmpxchg1_##sem((__u8 *) ptr, new, _o_); \ | ||
| 95 | break; \ | ||
| 96 | \ | ||
| 97 | case 2: \ | ||
| 98 | _r_ = ia64_cmpxchg2_##sem((__u16 *) ptr, new, _o_); \ | ||
| 99 | break; \ | ||
| 100 | \ | ||
| 101 | case 4: \ | ||
| 102 | _r_ = ia64_cmpxchg4_##sem((__u32 *) ptr, new, _o_); \ | ||
| 103 | break; \ | ||
| 104 | \ | ||
| 105 | case 8: \ | ||
| 106 | _r_ = ia64_cmpxchg8_##sem((__u64 *) ptr, new, _o_); \ | ||
| 107 | break; \ | ||
| 108 | \ | ||
| 109 | default: \ | ||
| 110 | _r_ = ia64_cmpxchg_called_with_bad_pointer(); \ | ||
| 111 | break; \ | ||
| 112 | } \ | ||
| 113 | (__typeof__(old)) _r_; \ | ||
| 114 | }) | ||
| 115 | |||
| 116 | #define cmpxchg_acq(ptr, o, n) \ | ||
| 117 | ia64_cmpxchg(acq, (ptr), (o), (n), sizeof(*(ptr))) | ||
| 118 | #define cmpxchg_rel(ptr, o, n) \ | ||
| 119 | ia64_cmpxchg(rel, (ptr), (o), (n), sizeof(*(ptr))) | ||
| 120 | |||
| 121 | /* for compatibility with other platforms: */ | ||
| 122 | #define cmpxchg(ptr, o, n) cmpxchg_acq((ptr), (o), (n)) | ||
| 123 | #define cmpxchg64(ptr, o, n) cmpxchg_acq((ptr), (o), (n)) | ||
| 124 | |||
| 125 | #define cmpxchg_local cmpxchg | ||
| 126 | #define cmpxchg64_local cmpxchg64 | ||
| 127 | |||
| 128 | #ifdef CONFIG_IA64_DEBUG_CMPXCHG | ||
| 129 | # define CMPXCHG_BUGCHECK_DECL int _cmpxchg_bugcheck_count = 128; | ||
| 130 | # define CMPXCHG_BUGCHECK(v) \ | ||
| 131 | do { \ | ||
| 132 | if (_cmpxchg_bugcheck_count-- <= 0) { \ | ||
| 133 | void *ip; \ | ||
| 134 | extern int printk(const char *fmt, ...); \ | ||
| 135 | ip = (void *) ia64_getreg(_IA64_REG_IP); \ | ||
| 136 | printk("CMPXCHG_BUGCHECK: stuck at %p on word %p\n", ip, (v));\ | ||
| 137 | break; \ | ||
| 138 | } \ | ||
| 139 | } while (0) | ||
| 140 | #else /* !CONFIG_IA64_DEBUG_CMPXCHG */ | ||
| 141 | # define CMPXCHG_BUGCHECK_DECL | ||
| 142 | # define CMPXCHG_BUGCHECK(v) | ||
| 143 | #endif /* !CONFIG_IA64_DEBUG_CMPXCHG */ | ||
| 144 | |||
| 145 | #endif /* !__ASSEMBLY__ */ | ||
| 146 | |||
| 147 | #endif /* _ASM_IA64_CMPXCHG_H */ | ||
diff --git a/arch/ia64/include/asm/futex.h b/arch/ia64/include/asm/futex.h index 0ab82cc2dc8f..d2bf1fd5e44f 100644 --- a/arch/ia64/include/asm/futex.h +++ b/arch/ia64/include/asm/futex.h | |||
| @@ -106,15 +106,16 @@ futex_atomic_cmpxchg_inatomic(u32 *uval, u32 __user *uaddr, | |||
| 106 | return -EFAULT; | 106 | return -EFAULT; |
| 107 | 107 | ||
| 108 | { | 108 | { |
| 109 | register unsigned long r8 __asm ("r8") = 0; | 109 | register unsigned long r8 __asm ("r8"); |
| 110 | unsigned long prev; | 110 | unsigned long prev; |
| 111 | __asm__ __volatile__( | 111 | __asm__ __volatile__( |
| 112 | " mf;; \n" | 112 | " mf;; \n" |
| 113 | " mov ar.ccv=%3;; \n" | 113 | " mov %0=r0 \n" |
| 114 | "[1:] cmpxchg4.acq %0=[%1],%2,ar.ccv \n" | 114 | " mov ar.ccv=%4;; \n" |
| 115 | "[1:] cmpxchg4.acq %1=[%2],%3,ar.ccv \n" | ||
| 115 | " .xdata4 \"__ex_table\", 1b-., 2f-. \n" | 116 | " .xdata4 \"__ex_table\", 1b-., 2f-. \n" |
| 116 | "[2:]" | 117 | "[2:]" |
| 117 | : "=r" (prev) | 118 | : "=r" (r8), "=r" (prev) |
| 118 | : "r" (uaddr), "r" (newval), | 119 | : "r" (uaddr), "r" (newval), |
| 119 | "rO" ((long) (unsigned) oldval) | 120 | "rO" ((long) (unsigned) oldval) |
| 120 | : "memory"); | 121 | : "memory"); |
diff --git a/arch/ia64/include/asm/intrinsics.h b/arch/ia64/include/asm/intrinsics.h index e4076b511829..d129e367e764 100644 --- a/arch/ia64/include/asm/intrinsics.h +++ b/arch/ia64/include/asm/intrinsics.h | |||
| @@ -18,6 +18,7 @@ | |||
| 18 | #else | 18 | #else |
| 19 | # include <asm/gcc_intrin.h> | 19 | # include <asm/gcc_intrin.h> |
| 20 | #endif | 20 | #endif |
| 21 | #include <asm/cmpxchg.h> | ||
| 21 | 22 | ||
| 22 | #define ia64_native_get_psr_i() (ia64_native_getreg(_IA64_REG_PSR) & IA64_PSR_I) | 23 | #define ia64_native_get_psr_i() (ia64_native_getreg(_IA64_REG_PSR) & IA64_PSR_I) |
| 23 | 24 | ||
| @@ -81,119 +82,6 @@ extern unsigned long __bad_increment_for_ia64_fetch_and_add (void); | |||
| 81 | 82 | ||
| 82 | #define ia64_fetch_and_add(i,v) (ia64_fetchadd(i, v, rel) + (i)) /* return new value */ | 83 | #define ia64_fetch_and_add(i,v) (ia64_fetchadd(i, v, rel) + (i)) /* return new value */ |
| 83 | 84 | ||
| 84 | /* | ||
| 85 | * This function doesn't exist, so you'll get a linker error if | ||
| 86 | * something tries to do an invalid xchg(). | ||
| 87 | */ | ||
| 88 | extern void ia64_xchg_called_with_bad_pointer (void); | ||
| 89 | |||
| 90 | #define __xchg(x,ptr,size) \ | ||
| 91 | ({ \ | ||
| 92 | unsigned long __xchg_result; \ | ||
| 93 | \ | ||
| 94 | switch (size) { \ | ||
| 95 | case 1: \ | ||
| 96 | __xchg_result = ia64_xchg1((__u8 *)ptr, x); \ | ||
| 97 | break; \ | ||
| 98 | \ | ||
| 99 | case 2: \ | ||
| 100 | __xchg_result = ia64_xchg2((__u16 *)ptr, x); \ | ||
| 101 | break; \ | ||
| 102 | \ | ||
| 103 | case 4: \ | ||
| 104 | __xchg_result = ia64_xchg4((__u32 *)ptr, x); \ | ||
| 105 | break; \ | ||
| 106 | \ | ||
| 107 | case 8: \ | ||
| 108 | __xchg_result = ia64_xchg8((__u64 *)ptr, x); \ | ||
| 109 | break; \ | ||
| 110 | default: \ | ||
| 111 | ia64_xchg_called_with_bad_pointer(); \ | ||
| 112 | } \ | ||
| 113 | __xchg_result; \ | ||
| 114 | }) | ||
| 115 | |||
| 116 | #define xchg(ptr,x) \ | ||
| 117 | ((__typeof__(*(ptr))) __xchg ((unsigned long) (x), (ptr), sizeof(*(ptr)))) | ||
| 118 | |||
| 119 | /* | ||
| 120 | * Atomic compare and exchange. Compare OLD with MEM, if identical, | ||
| 121 | * store NEW in MEM. Return the initial value in MEM. Success is | ||
| 122 | * indicated by comparing RETURN with OLD. | ||
| 123 | */ | ||
| 124 | |||
| 125 | #define __HAVE_ARCH_CMPXCHG 1 | ||
| 126 | |||
| 127 | /* | ||
| 128 | * This function doesn't exist, so you'll get a linker error | ||
| 129 | * if something tries to do an invalid cmpxchg(). | ||
| 130 | */ | ||
| 131 | extern long ia64_cmpxchg_called_with_bad_pointer (void); | ||
| 132 | |||
| 133 | #define ia64_cmpxchg(sem,ptr,old,new,size) \ | ||
| 134 | ({ \ | ||
| 135 | __u64 _o_, _r_; \ | ||
| 136 | \ | ||
| 137 | switch (size) { \ | ||
| 138 | case 1: _o_ = (__u8 ) (long) (old); break; \ | ||
| 139 | case 2: _o_ = (__u16) (long) (old); break; \ | ||
| 140 | case 4: _o_ = (__u32) (long) (old); break; \ | ||
| 141 | case 8: _o_ = (__u64) (long) (old); break; \ | ||
| 142 | default: break; \ | ||
| 143 | } \ | ||
| 144 | switch (size) { \ | ||
| 145 | case 1: \ | ||
| 146 | _r_ = ia64_cmpxchg1_##sem((__u8 *) ptr, new, _o_); \ | ||
| 147 | break; \ | ||
| 148 | \ | ||
| 149 | case 2: \ | ||
| 150 | _r_ = ia64_cmpxchg2_##sem((__u16 *) ptr, new, _o_); \ | ||
| 151 | break; \ | ||
| 152 | \ | ||
| 153 | case 4: \ | ||
| 154 | _r_ = ia64_cmpxchg4_##sem((__u32 *) ptr, new, _o_); \ | ||
| 155 | break; \ | ||
| 156 | \ | ||
| 157 | case 8: \ | ||
| 158 | _r_ = ia64_cmpxchg8_##sem((__u64 *) ptr, new, _o_); \ | ||
| 159 | break; \ | ||
| 160 | \ | ||
| 161 | default: \ | ||
| 162 | _r_ = ia64_cmpxchg_called_with_bad_pointer(); \ | ||
| 163 | break; \ | ||
| 164 | } \ | ||
| 165 | (__typeof__(old)) _r_; \ | ||
| 166 | }) | ||
| 167 | |||
| 168 | #define cmpxchg_acq(ptr, o, n) \ | ||
| 169 | ia64_cmpxchg(acq, (ptr), (o), (n), sizeof(*(ptr))) | ||
| 170 | #define cmpxchg_rel(ptr, o, n) \ | ||
| 171 | ia64_cmpxchg(rel, (ptr), (o), (n), sizeof(*(ptr))) | ||
| 172 | |||
| 173 | /* for compatibility with other platforms: */ | ||
| 174 | #define cmpxchg(ptr, o, n) cmpxchg_acq((ptr), (o), (n)) | ||
| 175 | #define cmpxchg64(ptr, o, n) cmpxchg_acq((ptr), (o), (n)) | ||
| 176 | |||
| 177 | #define cmpxchg_local cmpxchg | ||
| 178 | #define cmpxchg64_local cmpxchg64 | ||
| 179 | |||
| 180 | #ifdef CONFIG_IA64_DEBUG_CMPXCHG | ||
| 181 | # define CMPXCHG_BUGCHECK_DECL int _cmpxchg_bugcheck_count = 128; | ||
| 182 | # define CMPXCHG_BUGCHECK(v) \ | ||
| 183 | do { \ | ||
| 184 | if (_cmpxchg_bugcheck_count-- <= 0) { \ | ||
| 185 | void *ip; \ | ||
| 186 | extern int printk(const char *fmt, ...); \ | ||
| 187 | ip = (void *) ia64_getreg(_IA64_REG_IP); \ | ||
| 188 | printk("CMPXCHG_BUGCHECK: stuck at %p on word %p\n", ip, (v)); \ | ||
| 189 | break; \ | ||
| 190 | } \ | ||
| 191 | } while (0) | ||
| 192 | #else /* !CONFIG_IA64_DEBUG_CMPXCHG */ | ||
| 193 | # define CMPXCHG_BUGCHECK_DECL | ||
| 194 | # define CMPXCHG_BUGCHECK(v) | ||
| 195 | #endif /* !CONFIG_IA64_DEBUG_CMPXCHG */ | ||
| 196 | |||
| 197 | #endif | 85 | #endif |
| 198 | 86 | ||
| 199 | #ifdef __KERNEL__ | 87 | #ifdef __KERNEL__ |
diff --git a/arch/ia64/kernel/perfmon.c b/arch/ia64/kernel/perfmon.c index 9d0fd7d5bb82..f00ba025375d 100644 --- a/arch/ia64/kernel/perfmon.c +++ b/arch/ia64/kernel/perfmon.c | |||
| @@ -604,12 +604,6 @@ pfm_unprotect_ctx_ctxsw(pfm_context_t *x, unsigned long f) | |||
| 604 | spin_unlock(&(x)->ctx_lock); | 604 | spin_unlock(&(x)->ctx_lock); |
| 605 | } | 605 | } |
| 606 | 606 | ||
| 607 | static inline unsigned int | ||
| 608 | pfm_do_munmap(struct mm_struct *mm, unsigned long addr, size_t len, int acct) | ||
| 609 | { | ||
| 610 | return do_munmap(mm, addr, len); | ||
| 611 | } | ||
| 612 | |||
| 613 | static inline unsigned long | 607 | static inline unsigned long |
| 614 | pfm_get_unmapped_area(struct file *file, unsigned long addr, unsigned long len, unsigned long pgoff, unsigned long flags, unsigned long exec) | 608 | pfm_get_unmapped_area(struct file *file, unsigned long addr, unsigned long len, unsigned long pgoff, unsigned long flags, unsigned long exec) |
| 615 | { | 609 | { |
| @@ -1458,8 +1452,9 @@ pfm_unreserve_session(pfm_context_t *ctx, int is_syswide, unsigned int cpu) | |||
| 1458 | * a PROTECT_CTX() section. | 1452 | * a PROTECT_CTX() section. |
| 1459 | */ | 1453 | */ |
| 1460 | static int | 1454 | static int |
| 1461 | pfm_remove_smpl_mapping(struct task_struct *task, void *vaddr, unsigned long size) | 1455 | pfm_remove_smpl_mapping(void *vaddr, unsigned long size) |
| 1462 | { | 1456 | { |
| 1457 | struct task_struct *task = current; | ||
| 1463 | int r; | 1458 | int r; |
| 1464 | 1459 | ||
| 1465 | /* sanity checks */ | 1460 | /* sanity checks */ |
| @@ -1473,13 +1468,8 @@ pfm_remove_smpl_mapping(struct task_struct *task, void *vaddr, unsigned long siz | |||
| 1473 | /* | 1468 | /* |
| 1474 | * does the actual unmapping | 1469 | * does the actual unmapping |
| 1475 | */ | 1470 | */ |
| 1476 | down_write(&task->mm->mmap_sem); | 1471 | r = vm_munmap((unsigned long)vaddr, size); |
| 1477 | 1472 | ||
| 1478 | DPRINT(("down_write done smpl_vaddr=%p size=%lu\n", vaddr, size)); | ||
| 1479 | |||
| 1480 | r = pfm_do_munmap(task->mm, (unsigned long)vaddr, size, 0); | ||
| 1481 | |||
| 1482 | up_write(&task->mm->mmap_sem); | ||
| 1483 | if (r !=0) { | 1473 | if (r !=0) { |
| 1484 | printk(KERN_ERR "perfmon: [%d] unable to unmap sampling buffer @%p size=%lu\n", task_pid_nr(task), vaddr, size); | 1474 | printk(KERN_ERR "perfmon: [%d] unable to unmap sampling buffer @%p size=%lu\n", task_pid_nr(task), vaddr, size); |
| 1485 | } | 1475 | } |
| @@ -1945,7 +1935,7 @@ pfm_flush(struct file *filp, fl_owner_t id) | |||
| 1945 | * because some VM function reenables interrupts. | 1935 | * because some VM function reenables interrupts. |
| 1946 | * | 1936 | * |
| 1947 | */ | 1937 | */ |
| 1948 | if (smpl_buf_vaddr) pfm_remove_smpl_mapping(current, smpl_buf_vaddr, smpl_buf_size); | 1938 | if (smpl_buf_vaddr) pfm_remove_smpl_mapping(smpl_buf_vaddr, smpl_buf_size); |
| 1949 | 1939 | ||
| 1950 | return 0; | 1940 | return 0; |
| 1951 | } | 1941 | } |
diff --git a/arch/m68k/configs/m5275evb_defconfig b/arch/m68k/configs/m5275evb_defconfig index 33c32aeca12b..a1230e82bb1e 100644 --- a/arch/m68k/configs/m5275evb_defconfig +++ b/arch/m68k/configs/m5275evb_defconfig | |||
| @@ -49,7 +49,6 @@ CONFIG_BLK_DEV_RAM=y | |||
| 49 | CONFIG_NETDEVICES=y | 49 | CONFIG_NETDEVICES=y |
| 50 | CONFIG_NET_ETHERNET=y | 50 | CONFIG_NET_ETHERNET=y |
| 51 | CONFIG_FEC=y | 51 | CONFIG_FEC=y |
| 52 | CONFIG_FEC2=y | ||
| 53 | # CONFIG_NETDEV_1000 is not set | 52 | # CONFIG_NETDEV_1000 is not set |
| 54 | # CONFIG_NETDEV_10000 is not set | 53 | # CONFIG_NETDEV_10000 is not set |
| 55 | CONFIG_PPP=y | 54 | CONFIG_PPP=y |
diff --git a/arch/m68k/platform/527x/config.c b/arch/m68k/platform/527x/config.c index 7ed848c3b848..f91a53294c35 100644 --- a/arch/m68k/platform/527x/config.c +++ b/arch/m68k/platform/527x/config.c | |||
| @@ -74,9 +74,7 @@ static void __init m527x_fec_init(void) | |||
| 74 | writew(par | 0xf00, MCF_IPSBAR + 0x100082); | 74 | writew(par | 0xf00, MCF_IPSBAR + 0x100082); |
| 75 | v = readb(MCF_IPSBAR + 0x100078); | 75 | v = readb(MCF_IPSBAR + 0x100078); |
| 76 | writeb(v | 0xc0, MCF_IPSBAR + 0x100078); | 76 | writeb(v | 0xc0, MCF_IPSBAR + 0x100078); |
| 77 | #endif | ||
| 78 | 77 | ||
| 79 | #ifdef CONFIG_FEC2 | ||
| 80 | /* Set multi-function pins to ethernet mode for fec1 */ | 78 | /* Set multi-function pins to ethernet mode for fec1 */ |
| 81 | par = readw(MCF_IPSBAR + 0x100082); | 79 | par = readw(MCF_IPSBAR + 0x100082); |
| 82 | writew(par | 0xa0, MCF_IPSBAR + 0x100082); | 80 | writew(par | 0xa0, MCF_IPSBAR + 0x100082); |
diff --git a/arch/m68k/platform/68EZ328/Makefile b/arch/m68k/platform/68EZ328/Makefile index ee97735a242c..b44d799b1115 100644 --- a/arch/m68k/platform/68EZ328/Makefile +++ b/arch/m68k/platform/68EZ328/Makefile | |||
| @@ -3,9 +3,3 @@ | |||
| 3 | # | 3 | # |
| 4 | 4 | ||
| 5 | obj-y := config.o | 5 | obj-y := config.o |
| 6 | |||
| 7 | extra-y := bootlogo.rh | ||
| 8 | |||
| 9 | $(obj)/bootlogo.rh: $(src)/bootlogo.h | ||
| 10 | perl $(src)/../68328/bootlogo.pl < $(src)/bootlogo.h \ | ||
| 11 | > $(obj)/bootlogo.rh | ||
diff --git a/arch/m68k/platform/68VZ328/Makefile b/arch/m68k/platform/68VZ328/Makefile index 447ffa0fd7c7..a49d75e65489 100644 --- a/arch/m68k/platform/68VZ328/Makefile +++ b/arch/m68k/platform/68VZ328/Makefile | |||
| @@ -3,14 +3,9 @@ | |||
| 3 | # | 3 | # |
| 4 | 4 | ||
| 5 | obj-y := config.o | 5 | obj-y := config.o |
| 6 | logo-$(UCDIMM) := bootlogo.rh | 6 | extra-$(DRAGEN2):= screen.h |
| 7 | logo-$(DRAGEN2) := screen.h | ||
| 8 | extra-y := $(logo-y) | ||
| 9 | |||
| 10 | $(obj)/bootlogo.rh: $(src)/../68EZ328/bootlogo.h | ||
| 11 | perl $(src)/bootlogo.pl < $(src)/../68328/bootlogo.h > $(obj)/bootlogo.rh | ||
| 12 | 7 | ||
| 13 | $(obj)/screen.h: $(src)/screen.xbm $(src)/xbm2lcd.pl | 8 | $(obj)/screen.h: $(src)/screen.xbm $(src)/xbm2lcd.pl |
| 14 | perl $(src)/xbm2lcd.pl < $(src)/screen.xbm > $(obj)/screen.h | 9 | perl $(src)/xbm2lcd.pl < $(src)/screen.xbm > $(obj)/screen.h |
| 15 | 10 | ||
| 16 | clean-files := $(obj)/screen.h $(obj)/bootlogo.rh | 11 | clean-files := $(obj)/screen.h |
diff --git a/arch/m68k/platform/68EZ328/bootlogo.h b/arch/m68k/platform/68VZ328/bootlogo.h index e842bdae5839..b38e2b255142 100644 --- a/arch/m68k/platform/68EZ328/bootlogo.h +++ b/arch/m68k/platform/68VZ328/bootlogo.h | |||
| @@ -1,6 +1,6 @@ | |||
| 1 | #define splash_width 640 | 1 | #define splash_width 640 |
| 2 | #define splash_height 480 | 2 | #define splash_height 480 |
| 3 | static unsigned char splash_bits[] = { | 3 | unsigned char __attribute__ ((aligned(16))) bootlogo_bits[] = { |
| 4 | 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, | 4 | 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, |
| 5 | 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, | 5 | 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, |
| 6 | 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, | 6 | 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, |
diff --git a/arch/m68k/platform/coldfire/device.c b/arch/m68k/platform/coldfire/device.c index fa50c48292ff..7af97362b95c 100644 --- a/arch/m68k/platform/coldfire/device.c +++ b/arch/m68k/platform/coldfire/device.c | |||
| @@ -114,7 +114,7 @@ static struct resource mcf_fec1_resources[] = { | |||
| 114 | 114 | ||
| 115 | static struct platform_device mcf_fec1 = { | 115 | static struct platform_device mcf_fec1 = { |
| 116 | .name = "fec", | 116 | .name = "fec", |
| 117 | .id = 0, | 117 | .id = 1, |
| 118 | .num_resources = ARRAY_SIZE(mcf_fec1_resources), | 118 | .num_resources = ARRAY_SIZE(mcf_fec1_resources), |
| 119 | .resource = mcf_fec1_resources, | 119 | .resource = mcf_fec1_resources, |
| 120 | }; | 120 | }; |
diff --git a/arch/powerpc/boot/dts/fsl/pq3-mpic-message-B.dtsi b/arch/powerpc/boot/dts/fsl/pq3-mpic-message-B.dtsi new file mode 100644 index 000000000000..1cf0b77b1efe --- /dev/null +++ b/arch/powerpc/boot/dts/fsl/pq3-mpic-message-B.dtsi | |||
| @@ -0,0 +1,43 @@ | |||
| 1 | /* | ||
| 2 | * PQ3 MPIC Message (Group B) device tree stub [ controller @ offset 0x42400 ] | ||
| 3 | * | ||
| 4 | * Copyright 2012 Freescale Semiconductor Inc. | ||
| 5 | * | ||
| 6 | * Redistribution and use in source and binary forms, with or without | ||
| 7 | * modification, are permitted provided that the following conditions are met: | ||
| 8 | * * Redistributions of source code must retain the above copyright | ||
| 9 | * notice, this list of conditions and the following disclaimer. | ||
| 10 | * * Redistributions in binary form must reproduce the above copyright | ||
| 11 | * notice, this list of conditions and the following disclaimer in the | ||
| 12 | * documentation and/or other materials provided with the distribution. | ||
| 13 | * * Neither the name of Freescale Semiconductor nor the | ||
| 14 | * names of its contributors may be used to endorse or promote products | ||
| 15 | * derived from this software without specific prior written permission. | ||
| 16 | * | ||
| 17 | * | ||
| 18 | * ALTERNATIVELY, this software may be distributed under the terms of the | ||
| 19 | * GNU General Public License ("GPL") as published by the Free Software | ||
| 20 | * Foundation, either version 2 of that License or (at your option) any | ||
| 21 | * later version. | ||
| 22 | * | ||
| 23 | * THIS SOFTWARE IS PROVIDED BY Freescale Semiconductor ``AS IS'' AND ANY | ||
| 24 | * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||
| 25 | * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||
| 26 | * DISCLAIMED. IN NO EVENT SHALL Freescale Semiconductor BE LIABLE FOR ANY | ||
| 27 | * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||
| 28 | * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||
| 29 | * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||
| 30 | * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||
| 31 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||
| 32 | * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
| 33 | */ | ||
| 34 | |||
| 35 | message@42400 { | ||
| 36 | compatible = "fsl,mpic-v3.1-msgr"; | ||
| 37 | reg = <0x42400 0x200>; | ||
| 38 | interrupts = < | ||
| 39 | 0xb4 2 0 0 | ||
| 40 | 0xb5 2 0 0 | ||
| 41 | 0xb6 2 0 0 | ||
| 42 | 0xb7 2 0 0>; | ||
| 43 | }; | ||
diff --git a/arch/powerpc/boot/dts/fsl/pq3-mpic.dtsi b/arch/powerpc/boot/dts/fsl/pq3-mpic.dtsi index fdedf7b1fe0f..71c30eb10056 100644 --- a/arch/powerpc/boot/dts/fsl/pq3-mpic.dtsi +++ b/arch/powerpc/boot/dts/fsl/pq3-mpic.dtsi | |||
| @@ -53,6 +53,16 @@ timer@41100 { | |||
| 53 | 3 0 3 0>; | 53 | 3 0 3 0>; |
| 54 | }; | 54 | }; |
| 55 | 55 | ||
| 56 | message@41400 { | ||
| 57 | compatible = "fsl,mpic-v3.1-msgr"; | ||
| 58 | reg = <0x41400 0x200>; | ||
| 59 | interrupts = < | ||
| 60 | 0xb0 2 0 0 | ||
| 61 | 0xb1 2 0 0 | ||
| 62 | 0xb2 2 0 0 | ||
| 63 | 0xb3 2 0 0>; | ||
| 64 | }; | ||
| 65 | |||
| 56 | msi@41600 { | 66 | msi@41600 { |
| 57 | compatible = "fsl,mpic-msi"; | 67 | compatible = "fsl,mpic-msi"; |
| 58 | reg = <0x41600 0x80>; | 68 | reg = <0x41600 0x80>; |
diff --git a/arch/powerpc/include/asm/mpic.h b/arch/powerpc/include/asm/mpic.h index c65b9294376e..c9f698a994be 100644 --- a/arch/powerpc/include/asm/mpic.h +++ b/arch/powerpc/include/asm/mpic.h | |||
| @@ -275,9 +275,6 @@ struct mpic | |||
| 275 | unsigned int isu_mask; | 275 | unsigned int isu_mask; |
| 276 | /* Number of sources */ | 276 | /* Number of sources */ |
| 277 | unsigned int num_sources; | 277 | unsigned int num_sources; |
| 278 | /* default senses array */ | ||
| 279 | unsigned char *senses; | ||
| 280 | unsigned int senses_count; | ||
| 281 | 278 | ||
| 282 | /* vector numbers used for internal sources (ipi/timers) */ | 279 | /* vector numbers used for internal sources (ipi/timers) */ |
| 283 | unsigned int ipi_vecs[4]; | 280 | unsigned int ipi_vecs[4]; |
| @@ -415,21 +412,6 @@ extern struct mpic *mpic_alloc(struct device_node *node, | |||
| 415 | extern void mpic_assign_isu(struct mpic *mpic, unsigned int isu_num, | 412 | extern void mpic_assign_isu(struct mpic *mpic, unsigned int isu_num, |
| 416 | phys_addr_t phys_addr); | 413 | phys_addr_t phys_addr); |
| 417 | 414 | ||
| 418 | /* Set default sense codes | ||
| 419 | * | ||
| 420 | * @mpic: controller | ||
| 421 | * @senses: array of sense codes | ||
| 422 | * @count: size of above array | ||
| 423 | * | ||
| 424 | * Optionally provide an array (indexed on hardware interrupt numbers | ||
| 425 | * for this MPIC) of default sense codes for the chip. Those are linux | ||
| 426 | * sense codes IRQ_TYPE_* | ||
| 427 | * | ||
| 428 | * The driver gets ownership of the pointer, don't dispose of it or | ||
| 429 | * anything like that. __init only. | ||
| 430 | */ | ||
| 431 | extern void mpic_set_default_senses(struct mpic *mpic, u8 *senses, int count); | ||
| 432 | |||
| 433 | 415 | ||
| 434 | /* Initialize the controller. After this has been called, none of the above | 416 | /* Initialize the controller. After this has been called, none of the above |
| 435 | * should be called again for this mpic | 417 | * should be called again for this mpic |
diff --git a/arch/powerpc/include/asm/mpic_msgr.h b/arch/powerpc/include/asm/mpic_msgr.h index 3ec37dc9003e..326d33ca55cd 100644 --- a/arch/powerpc/include/asm/mpic_msgr.h +++ b/arch/powerpc/include/asm/mpic_msgr.h | |||
| @@ -13,6 +13,7 @@ | |||
| 13 | 13 | ||
| 14 | #include <linux/types.h> | 14 | #include <linux/types.h> |
| 15 | #include <linux/spinlock.h> | 15 | #include <linux/spinlock.h> |
| 16 | #include <asm/smp.h> | ||
| 16 | 17 | ||
| 17 | struct mpic_msgr { | 18 | struct mpic_msgr { |
| 18 | u32 __iomem *base; | 19 | u32 __iomem *base; |
diff --git a/arch/powerpc/include/asm/reg_booke.h b/arch/powerpc/include/asm/reg_booke.h index b86faa9107da..8a97aa7289d3 100644 --- a/arch/powerpc/include/asm/reg_booke.h +++ b/arch/powerpc/include/asm/reg_booke.h | |||
| @@ -15,11 +15,6 @@ | |||
| 15 | #ifndef __ASM_POWERPC_REG_BOOKE_H__ | 15 | #ifndef __ASM_POWERPC_REG_BOOKE_H__ |
| 16 | #define __ASM_POWERPC_REG_BOOKE_H__ | 16 | #define __ASM_POWERPC_REG_BOOKE_H__ |
| 17 | 17 | ||
| 18 | #ifdef CONFIG_BOOKE_WDT | ||
| 19 | extern u32 booke_wdt_enabled; | ||
| 20 | extern u32 booke_wdt_period; | ||
| 21 | #endif /* CONFIG_BOOKE_WDT */ | ||
| 22 | |||
| 23 | /* Machine State Register (MSR) Fields */ | 18 | /* Machine State Register (MSR) Fields */ |
| 24 | #define MSR_GS (1<<28) /* Guest state */ | 19 | #define MSR_GS (1<<28) /* Guest state */ |
| 25 | #define MSR_UCLE (1<<26) /* User-mode cache lock enable */ | 20 | #define MSR_UCLE (1<<26) /* User-mode cache lock enable */ |
diff --git a/arch/powerpc/kernel/setup_32.c b/arch/powerpc/kernel/setup_32.c index 9825f29d1faf..ec8a53fa9e8f 100644 --- a/arch/powerpc/kernel/setup_32.c +++ b/arch/powerpc/kernel/setup_32.c | |||
| @@ -150,6 +150,9 @@ notrace void __init machine_init(u64 dt_ptr) | |||
| 150 | } | 150 | } |
| 151 | 151 | ||
| 152 | #ifdef CONFIG_BOOKE_WDT | 152 | #ifdef CONFIG_BOOKE_WDT |
| 153 | extern u32 booke_wdt_enabled; | ||
| 154 | extern u32 booke_wdt_period; | ||
| 155 | |||
| 153 | /* Checks wdt=x and wdt_period=xx command-line option */ | 156 | /* Checks wdt=x and wdt_period=xx command-line option */ |
| 154 | notrace int __init early_parse_wdt(char *p) | 157 | notrace int __init early_parse_wdt(char *p) |
| 155 | { | 158 | { |
diff --git a/arch/powerpc/platforms/85xx/common.c b/arch/powerpc/platforms/85xx/common.c index 9fef5302adc1..67dac22b4363 100644 --- a/arch/powerpc/platforms/85xx/common.c +++ b/arch/powerpc/platforms/85xx/common.c | |||
| @@ -21,6 +21,12 @@ static struct of_device_id __initdata mpc85xx_common_ids[] = { | |||
| 21 | { .compatible = "fsl,qe", }, | 21 | { .compatible = "fsl,qe", }, |
| 22 | { .compatible = "fsl,cpm2", }, | 22 | { .compatible = "fsl,cpm2", }, |
| 23 | { .compatible = "fsl,srio", }, | 23 | { .compatible = "fsl,srio", }, |
| 24 | /* So that the DMA channel nodes can be probed individually: */ | ||
| 25 | { .compatible = "fsl,eloplus-dma", }, | ||
| 26 | /* For the PMC driver */ | ||
| 27 | { .compatible = "fsl,mpc8548-guts", }, | ||
| 28 | /* Probably unnecessary? */ | ||
| 29 | { .compatible = "gpio-leds", }, | ||
| 24 | {}, | 30 | {}, |
| 25 | }; | 31 | }; |
| 26 | 32 | ||
diff --git a/arch/powerpc/platforms/85xx/mpc85xx_mds.c b/arch/powerpc/platforms/85xx/mpc85xx_mds.c index 9a6f04406e0d..d208ebccb91c 100644 --- a/arch/powerpc/platforms/85xx/mpc85xx_mds.c +++ b/arch/powerpc/platforms/85xx/mpc85xx_mds.c | |||
| @@ -399,12 +399,6 @@ static int __init board_fixups(void) | |||
| 399 | machine_arch_initcall(mpc8568_mds, board_fixups); | 399 | machine_arch_initcall(mpc8568_mds, board_fixups); |
| 400 | machine_arch_initcall(mpc8569_mds, board_fixups); | 400 | machine_arch_initcall(mpc8569_mds, board_fixups); |
| 401 | 401 | ||
| 402 | static struct of_device_id mpc85xx_ids[] = { | ||
| 403 | { .compatible = "fsl,mpc8548-guts", }, | ||
| 404 | { .compatible = "gpio-leds", }, | ||
| 405 | {}, | ||
| 406 | }; | ||
| 407 | |||
| 408 | static int __init mpc85xx_publish_devices(void) | 402 | static int __init mpc85xx_publish_devices(void) |
| 409 | { | 403 | { |
| 410 | if (machine_is(mpc8568_mds)) | 404 | if (machine_is(mpc8568_mds)) |
| @@ -412,10 +406,7 @@ static int __init mpc85xx_publish_devices(void) | |||
| 412 | if (machine_is(mpc8569_mds)) | 406 | if (machine_is(mpc8569_mds)) |
| 413 | simple_gpiochip_init("fsl,mpc8569mds-bcsr-gpio"); | 407 | simple_gpiochip_init("fsl,mpc8569mds-bcsr-gpio"); |
| 414 | 408 | ||
| 415 | mpc85xx_common_publish_devices(); | 409 | return mpc85xx_common_publish_devices(); |
| 416 | of_platform_bus_probe(NULL, mpc85xx_ids, NULL); | ||
| 417 | |||
| 418 | return 0; | ||
| 419 | } | 410 | } |
| 420 | 411 | ||
| 421 | machine_device_initcall(mpc8568_mds, mpc85xx_publish_devices); | 412 | machine_device_initcall(mpc8568_mds, mpc85xx_publish_devices); |
diff --git a/arch/powerpc/platforms/85xx/p1022_ds.c b/arch/powerpc/platforms/85xx/p1022_ds.c index e74b7cde9aee..f700c81a1321 100644 --- a/arch/powerpc/platforms/85xx/p1022_ds.c +++ b/arch/powerpc/platforms/85xx/p1022_ds.c | |||
| @@ -460,18 +460,7 @@ static void __init p1022_ds_setup_arch(void) | |||
| 460 | pr_info("Freescale P1022 DS reference board\n"); | 460 | pr_info("Freescale P1022 DS reference board\n"); |
| 461 | } | 461 | } |
| 462 | 462 | ||
| 463 | static struct of_device_id __initdata p1022_ds_ids[] = { | 463 | machine_device_initcall(p1022_ds, mpc85xx_common_publish_devices); |
| 464 | /* So that the DMA channel nodes can be probed individually: */ | ||
| 465 | { .compatible = "fsl,eloplus-dma", }, | ||
| 466 | {}, | ||
| 467 | }; | ||
| 468 | |||
| 469 | static int __init p1022_ds_publish_devices(void) | ||
| 470 | { | ||
| 471 | mpc85xx_common_publish_devices(); | ||
| 472 | return of_platform_bus_probe(NULL, p1022_ds_ids, NULL); | ||
| 473 | } | ||
| 474 | machine_device_initcall(p1022_ds, p1022_ds_publish_devices); | ||
| 475 | 464 | ||
| 476 | machine_arch_initcall(p1022_ds, swiotlb_setup_bus_notifier); | 465 | machine_arch_initcall(p1022_ds, swiotlb_setup_bus_notifier); |
| 477 | 466 | ||
diff --git a/arch/powerpc/platforms/powermac/low_i2c.c b/arch/powerpc/platforms/powermac/low_i2c.c index 996c5ff7824b..03685a329d7d 100644 --- a/arch/powerpc/platforms/powermac/low_i2c.c +++ b/arch/powerpc/platforms/powermac/low_i2c.c | |||
| @@ -366,11 +366,20 @@ static void kw_i2c_timeout(unsigned long data) | |||
| 366 | unsigned long flags; | 366 | unsigned long flags; |
| 367 | 367 | ||
| 368 | spin_lock_irqsave(&host->lock, flags); | 368 | spin_lock_irqsave(&host->lock, flags); |
| 369 | |||
| 370 | /* | ||
| 371 | * If the timer is pending, that means we raced with the | ||
| 372 | * irq, in which case we just return | ||
| 373 | */ | ||
| 374 | if (timer_pending(&host->timeout_timer)) | ||
| 375 | goto skip; | ||
| 376 | |||
| 369 | kw_i2c_handle_interrupt(host, kw_read_reg(reg_isr)); | 377 | kw_i2c_handle_interrupt(host, kw_read_reg(reg_isr)); |
| 370 | if (host->state != state_idle) { | 378 | if (host->state != state_idle) { |
| 371 | host->timeout_timer.expires = jiffies + KW_POLL_TIMEOUT; | 379 | host->timeout_timer.expires = jiffies + KW_POLL_TIMEOUT; |
| 372 | add_timer(&host->timeout_timer); | 380 | add_timer(&host->timeout_timer); |
| 373 | } | 381 | } |
| 382 | skip: | ||
| 374 | spin_unlock_irqrestore(&host->lock, flags); | 383 | spin_unlock_irqrestore(&host->lock, flags); |
| 375 | } | 384 | } |
| 376 | 385 | ||
diff --git a/arch/powerpc/platforms/pseries/eeh.c b/arch/powerpc/platforms/pseries/eeh.c index 309d38ef7322..a75e37dc41aa 100644 --- a/arch/powerpc/platforms/pseries/eeh.c +++ b/arch/powerpc/platforms/pseries/eeh.c | |||
| @@ -1076,7 +1076,7 @@ static void eeh_add_device_late(struct pci_dev *dev) | |||
| 1076 | pr_debug("EEH: Adding device %s\n", pci_name(dev)); | 1076 | pr_debug("EEH: Adding device %s\n", pci_name(dev)); |
| 1077 | 1077 | ||
| 1078 | dn = pci_device_to_OF_node(dev); | 1078 | dn = pci_device_to_OF_node(dev); |
| 1079 | edev = pci_dev_to_eeh_dev(dev); | 1079 | edev = of_node_to_eeh_dev(dn); |
| 1080 | if (edev->pdev == dev) { | 1080 | if (edev->pdev == dev) { |
| 1081 | pr_debug("EEH: Already referenced !\n"); | 1081 | pr_debug("EEH: Already referenced !\n"); |
| 1082 | return; | 1082 | return; |
diff --git a/arch/powerpc/sysdev/mpic.c b/arch/powerpc/sysdev/mpic.c index 9ac71ebd2c40..395af1347749 100644 --- a/arch/powerpc/sysdev/mpic.c +++ b/arch/powerpc/sysdev/mpic.c | |||
| @@ -604,18 +604,14 @@ static struct mpic *mpic_find(unsigned int irq) | |||
| 604 | } | 604 | } |
| 605 | 605 | ||
| 606 | /* Determine if the linux irq is an IPI */ | 606 | /* Determine if the linux irq is an IPI */ |
| 607 | static unsigned int mpic_is_ipi(struct mpic *mpic, unsigned int irq) | 607 | static unsigned int mpic_is_ipi(struct mpic *mpic, unsigned int src) |
| 608 | { | 608 | { |
| 609 | unsigned int src = virq_to_hw(irq); | ||
| 610 | |||
| 611 | return (src >= mpic->ipi_vecs[0] && src <= mpic->ipi_vecs[3]); | 609 | return (src >= mpic->ipi_vecs[0] && src <= mpic->ipi_vecs[3]); |
| 612 | } | 610 | } |
| 613 | 611 | ||
| 614 | /* Determine if the linux irq is a timer */ | 612 | /* Determine if the linux irq is a timer */ |
| 615 | static unsigned int mpic_is_tm(struct mpic *mpic, unsigned int irq) | 613 | static unsigned int mpic_is_tm(struct mpic *mpic, unsigned int src) |
| 616 | { | 614 | { |
| 617 | unsigned int src = virq_to_hw(irq); | ||
| 618 | |||
| 619 | return (src >= mpic->timer_vecs[0] && src <= mpic->timer_vecs[7]); | 615 | return (src >= mpic->timer_vecs[0] && src <= mpic->timer_vecs[7]); |
| 620 | } | 616 | } |
| 621 | 617 | ||
| @@ -876,21 +872,45 @@ int mpic_set_irq_type(struct irq_data *d, unsigned int flow_type) | |||
| 876 | if (src >= mpic->num_sources) | 872 | if (src >= mpic->num_sources) |
| 877 | return -EINVAL; | 873 | return -EINVAL; |
| 878 | 874 | ||
| 875 | vold = mpic_irq_read(src, MPIC_INFO(IRQ_VECTOR_PRI)); | ||
| 876 | |||
| 877 | /* We don't support "none" type */ | ||
| 879 | if (flow_type == IRQ_TYPE_NONE) | 878 | if (flow_type == IRQ_TYPE_NONE) |
| 880 | if (mpic->senses && src < mpic->senses_count) | 879 | flow_type = IRQ_TYPE_DEFAULT; |
| 881 | flow_type = mpic->senses[src]; | 880 | |
| 882 | if (flow_type == IRQ_TYPE_NONE) | 881 | /* Default: read HW settings */ |
| 883 | flow_type = IRQ_TYPE_LEVEL_LOW; | 882 | if (flow_type == IRQ_TYPE_DEFAULT) { |
| 883 | switch(vold & (MPIC_INFO(VECPRI_POLARITY_MASK) | | ||
| 884 | MPIC_INFO(VECPRI_SENSE_MASK))) { | ||
| 885 | case MPIC_INFO(VECPRI_SENSE_EDGE) | | ||
| 886 | MPIC_INFO(VECPRI_POLARITY_POSITIVE): | ||
| 887 | flow_type = IRQ_TYPE_EDGE_RISING; | ||
| 888 | break; | ||
| 889 | case MPIC_INFO(VECPRI_SENSE_EDGE) | | ||
| 890 | MPIC_INFO(VECPRI_POLARITY_NEGATIVE): | ||
| 891 | flow_type = IRQ_TYPE_EDGE_FALLING; | ||
| 892 | break; | ||
| 893 | case MPIC_INFO(VECPRI_SENSE_LEVEL) | | ||
| 894 | MPIC_INFO(VECPRI_POLARITY_POSITIVE): | ||
| 895 | flow_type = IRQ_TYPE_LEVEL_HIGH; | ||
| 896 | break; | ||
| 897 | case MPIC_INFO(VECPRI_SENSE_LEVEL) | | ||
| 898 | MPIC_INFO(VECPRI_POLARITY_NEGATIVE): | ||
| 899 | flow_type = IRQ_TYPE_LEVEL_LOW; | ||
| 900 | break; | ||
| 901 | } | ||
| 902 | } | ||
| 884 | 903 | ||
| 904 | /* Apply to irq desc */ | ||
| 885 | irqd_set_trigger_type(d, flow_type); | 905 | irqd_set_trigger_type(d, flow_type); |
| 886 | 906 | ||
| 907 | /* Apply to HW */ | ||
| 887 | if (mpic_is_ht_interrupt(mpic, src)) | 908 | if (mpic_is_ht_interrupt(mpic, src)) |
| 888 | vecpri = MPIC_VECPRI_POLARITY_POSITIVE | | 909 | vecpri = MPIC_VECPRI_POLARITY_POSITIVE | |
| 889 | MPIC_VECPRI_SENSE_EDGE; | 910 | MPIC_VECPRI_SENSE_EDGE; |
| 890 | else | 911 | else |
| 891 | vecpri = mpic_type_to_vecpri(mpic, flow_type); | 912 | vecpri = mpic_type_to_vecpri(mpic, flow_type); |
| 892 | 913 | ||
| 893 | vold = mpic_irq_read(src, MPIC_INFO(IRQ_VECTOR_PRI)); | ||
| 894 | vnew = vold & ~(MPIC_INFO(VECPRI_POLARITY_MASK) | | 914 | vnew = vold & ~(MPIC_INFO(VECPRI_POLARITY_MASK) | |
| 895 | MPIC_INFO(VECPRI_SENSE_MASK)); | 915 | MPIC_INFO(VECPRI_SENSE_MASK)); |
| 896 | vnew |= vecpri; | 916 | vnew |= vecpri; |
| @@ -1026,7 +1046,7 @@ static int mpic_host_map(struct irq_domain *h, unsigned int virq, | |||
| 1026 | irq_set_chip_and_handler(virq, chip, handle_fasteoi_irq); | 1046 | irq_set_chip_and_handler(virq, chip, handle_fasteoi_irq); |
| 1027 | 1047 | ||
| 1028 | /* Set default irq type */ | 1048 | /* Set default irq type */ |
| 1029 | irq_set_irq_type(virq, IRQ_TYPE_NONE); | 1049 | irq_set_irq_type(virq, IRQ_TYPE_DEFAULT); |
| 1030 | 1050 | ||
| 1031 | /* If the MPIC was reset, then all vectors have already been | 1051 | /* If the MPIC was reset, then all vectors have already been |
| 1032 | * initialized. Otherwise, a per source lazy initialization | 1052 | * initialized. Otherwise, a per source lazy initialization |
| @@ -1417,12 +1437,6 @@ void __init mpic_assign_isu(struct mpic *mpic, unsigned int isu_num, | |||
| 1417 | mpic->num_sources = isu_first + mpic->isu_size; | 1437 | mpic->num_sources = isu_first + mpic->isu_size; |
| 1418 | } | 1438 | } |
| 1419 | 1439 | ||
| 1420 | void __init mpic_set_default_senses(struct mpic *mpic, u8 *senses, int count) | ||
| 1421 | { | ||
| 1422 | mpic->senses = senses; | ||
| 1423 | mpic->senses_count = count; | ||
| 1424 | } | ||
| 1425 | |||
| 1426 | void __init mpic_init(struct mpic *mpic) | 1440 | void __init mpic_init(struct mpic *mpic) |
| 1427 | { | 1441 | { |
| 1428 | int i, cpu; | 1442 | int i, cpu; |
| @@ -1555,12 +1569,12 @@ void mpic_irq_set_priority(unsigned int irq, unsigned int pri) | |||
| 1555 | return; | 1569 | return; |
| 1556 | 1570 | ||
| 1557 | raw_spin_lock_irqsave(&mpic_lock, flags); | 1571 | raw_spin_lock_irqsave(&mpic_lock, flags); |
| 1558 | if (mpic_is_ipi(mpic, irq)) { | 1572 | if (mpic_is_ipi(mpic, src)) { |
| 1559 | reg = mpic_ipi_read(src - mpic->ipi_vecs[0]) & | 1573 | reg = mpic_ipi_read(src - mpic->ipi_vecs[0]) & |
| 1560 | ~MPIC_VECPRI_PRIORITY_MASK; | 1574 | ~MPIC_VECPRI_PRIORITY_MASK; |
| 1561 | mpic_ipi_write(src - mpic->ipi_vecs[0], | 1575 | mpic_ipi_write(src - mpic->ipi_vecs[0], |
| 1562 | reg | (pri << MPIC_VECPRI_PRIORITY_SHIFT)); | 1576 | reg | (pri << MPIC_VECPRI_PRIORITY_SHIFT)); |
| 1563 | } else if (mpic_is_tm(mpic, irq)) { | 1577 | } else if (mpic_is_tm(mpic, src)) { |
| 1564 | reg = mpic_tm_read(src - mpic->timer_vecs[0]) & | 1578 | reg = mpic_tm_read(src - mpic->timer_vecs[0]) & |
| 1565 | ~MPIC_VECPRI_PRIORITY_MASK; | 1579 | ~MPIC_VECPRI_PRIORITY_MASK; |
| 1566 | mpic_tm_write(src - mpic->timer_vecs[0], | 1580 | mpic_tm_write(src - mpic->timer_vecs[0], |
diff --git a/arch/powerpc/sysdev/mpic_msgr.c b/arch/powerpc/sysdev/mpic_msgr.c index 6e7fa386e76a..483d8fa72e8b 100644 --- a/arch/powerpc/sysdev/mpic_msgr.c +++ b/arch/powerpc/sysdev/mpic_msgr.c | |||
| @@ -27,6 +27,7 @@ | |||
| 27 | 27 | ||
| 28 | static struct mpic_msgr **mpic_msgrs; | 28 | static struct mpic_msgr **mpic_msgrs; |
| 29 | static unsigned int mpic_msgr_count; | 29 | static unsigned int mpic_msgr_count; |
| 30 | static DEFINE_RAW_SPINLOCK(msgrs_lock); | ||
| 30 | 31 | ||
| 31 | static inline void _mpic_msgr_mer_write(struct mpic_msgr *msgr, u32 value) | 32 | static inline void _mpic_msgr_mer_write(struct mpic_msgr *msgr, u32 value) |
| 32 | { | 33 | { |
| @@ -56,12 +57,11 @@ struct mpic_msgr *mpic_msgr_get(unsigned int reg_num) | |||
| 56 | if (reg_num >= mpic_msgr_count) | 57 | if (reg_num >= mpic_msgr_count) |
| 57 | return ERR_PTR(-ENODEV); | 58 | return ERR_PTR(-ENODEV); |
| 58 | 59 | ||
| 59 | raw_spin_lock_irqsave(&msgr->lock, flags); | 60 | raw_spin_lock_irqsave(&msgrs_lock, flags); |
| 60 | if (mpic_msgrs[reg_num]->in_use == MSGR_FREE) { | 61 | msgr = mpic_msgrs[reg_num]; |
| 61 | msgr = mpic_msgrs[reg_num]; | 62 | if (msgr->in_use == MSGR_FREE) |
| 62 | msgr->in_use = MSGR_INUSE; | 63 | msgr->in_use = MSGR_INUSE; |
| 63 | } | 64 | raw_spin_unlock_irqrestore(&msgrs_lock, flags); |
| 64 | raw_spin_unlock_irqrestore(&msgr->lock, flags); | ||
| 65 | 65 | ||
| 66 | return msgr; | 66 | return msgr; |
| 67 | } | 67 | } |
| @@ -228,7 +228,7 @@ static __devinit int mpic_msgr_probe(struct platform_device *dev) | |||
| 228 | 228 | ||
| 229 | reg_number = block_number * MPIC_MSGR_REGISTERS_PER_BLOCK + i; | 229 | reg_number = block_number * MPIC_MSGR_REGISTERS_PER_BLOCK + i; |
| 230 | msgr->base = msgr_block_addr + i * MPIC_MSGR_STRIDE; | 230 | msgr->base = msgr_block_addr + i * MPIC_MSGR_STRIDE; |
| 231 | msgr->mer = msgr->base + MPIC_MSGR_MER_OFFSET; | 231 | msgr->mer = (u32 *)((u8 *)msgr->base + MPIC_MSGR_MER_OFFSET); |
| 232 | msgr->in_use = MSGR_FREE; | 232 | msgr->in_use = MSGR_FREE; |
| 233 | msgr->num = i; | 233 | msgr->num = i; |
| 234 | raw_spin_lock_init(&msgr->lock); | 234 | raw_spin_lock_init(&msgr->lock); |
diff --git a/arch/s390/Kconfig b/arch/s390/Kconfig index 2b7c0fbe578e..9015060919a0 100644 --- a/arch/s390/Kconfig +++ b/arch/s390/Kconfig | |||
| @@ -90,7 +90,6 @@ config S390 | |||
| 90 | select HAVE_KERNEL_XZ | 90 | select HAVE_KERNEL_XZ |
| 91 | select HAVE_ARCH_MUTEX_CPU_RELAX | 91 | select HAVE_ARCH_MUTEX_CPU_RELAX |
| 92 | select HAVE_ARCH_JUMP_LABEL if !MARCH_G5 | 92 | select HAVE_ARCH_JUMP_LABEL if !MARCH_G5 |
| 93 | select HAVE_RCU_TABLE_FREE if SMP | ||
| 94 | select ARCH_SAVE_PAGE_KEYS if HIBERNATION | 93 | select ARCH_SAVE_PAGE_KEYS if HIBERNATION |
| 95 | select HAVE_MEMBLOCK | 94 | select HAVE_MEMBLOCK |
| 96 | select HAVE_MEMBLOCK_NODE_MAP | 95 | select HAVE_MEMBLOCK_NODE_MAP |
diff --git a/arch/s390/defconfig b/arch/s390/defconfig index 6cf8e26b3137..1957a9dd256d 100644 --- a/arch/s390/defconfig +++ b/arch/s390/defconfig | |||
| @@ -1,8 +1,12 @@ | |||
| 1 | CONFIG_EXPERIMENTAL=y | 1 | CONFIG_EXPERIMENTAL=y |
| 2 | CONFIG_SYSVIPC=y | 2 | CONFIG_SYSVIPC=y |
| 3 | CONFIG_POSIX_MQUEUE=y | 3 | CONFIG_POSIX_MQUEUE=y |
| 4 | CONFIG_FHANDLE=y | ||
| 5 | CONFIG_TASKSTATS=y | ||
| 6 | CONFIG_TASK_DELAY_ACCT=y | ||
| 7 | CONFIG_TASK_XACCT=y | ||
| 8 | CONFIG_TASK_IO_ACCOUNTING=y | ||
| 4 | CONFIG_AUDIT=y | 9 | CONFIG_AUDIT=y |
| 5 | CONFIG_RCU_TRACE=y | ||
| 6 | CONFIG_IKCONFIG=y | 10 | CONFIG_IKCONFIG=y |
| 7 | CONFIG_IKCONFIG_PROC=y | 11 | CONFIG_IKCONFIG_PROC=y |
| 8 | CONFIG_CGROUPS=y | 12 | CONFIG_CGROUPS=y |
| @@ -14,16 +18,22 @@ CONFIG_CGROUP_MEM_RES_CTLR_SWAP=y | |||
| 14 | CONFIG_CGROUP_SCHED=y | 18 | CONFIG_CGROUP_SCHED=y |
| 15 | CONFIG_RT_GROUP_SCHED=y | 19 | CONFIG_RT_GROUP_SCHED=y |
| 16 | CONFIG_BLK_CGROUP=y | 20 | CONFIG_BLK_CGROUP=y |
| 21 | CONFIG_NAMESPACES=y | ||
| 17 | CONFIG_BLK_DEV_INITRD=y | 22 | CONFIG_BLK_DEV_INITRD=y |
| 18 | # CONFIG_CC_OPTIMIZE_FOR_SIZE is not set | 23 | CONFIG_RD_BZIP2=y |
| 24 | CONFIG_RD_LZMA=y | ||
| 25 | CONFIG_RD_XZ=y | ||
| 26 | CONFIG_RD_LZO=y | ||
| 27 | CONFIG_EXPERT=y | ||
| 19 | # CONFIG_COMPAT_BRK is not set | 28 | # CONFIG_COMPAT_BRK is not set |
| 20 | CONFIG_SLAB=y | ||
| 21 | CONFIG_PROFILING=y | 29 | CONFIG_PROFILING=y |
| 22 | CONFIG_OPROFILE=y | 30 | CONFIG_OPROFILE=y |
| 23 | CONFIG_KPROBES=y | 31 | CONFIG_KPROBES=y |
| 24 | CONFIG_MODULES=y | 32 | CONFIG_MODULES=y |
| 25 | CONFIG_MODULE_UNLOAD=y | 33 | CONFIG_MODULE_UNLOAD=y |
| 26 | CONFIG_MODVERSIONS=y | 34 | CONFIG_MODVERSIONS=y |
| 35 | CONFIG_PARTITION_ADVANCED=y | ||
| 36 | CONFIG_IBM_PARTITION=y | ||
| 27 | CONFIG_DEFAULT_DEADLINE=y | 37 | CONFIG_DEFAULT_DEADLINE=y |
| 28 | CONFIG_NO_HZ=y | 38 | CONFIG_NO_HZ=y |
| 29 | CONFIG_HIGH_RES_TIMERS=y | 39 | CONFIG_HIGH_RES_TIMERS=y |
| @@ -34,18 +44,15 @@ CONFIG_KSM=y | |||
| 34 | CONFIG_BINFMT_MISC=m | 44 | CONFIG_BINFMT_MISC=m |
| 35 | CONFIG_CMM=m | 45 | CONFIG_CMM=m |
| 36 | CONFIG_HZ_100=y | 46 | CONFIG_HZ_100=y |
| 37 | CONFIG_KEXEC=y | 47 | CONFIG_CRASH_DUMP=y |
| 38 | CONFIG_PM=y | ||
| 39 | CONFIG_HIBERNATION=y | 48 | CONFIG_HIBERNATION=y |
| 40 | CONFIG_PACKET=y | 49 | CONFIG_PACKET=y |
| 41 | CONFIG_UNIX=y | 50 | CONFIG_UNIX=y |
| 42 | CONFIG_NET_KEY=y | 51 | CONFIG_NET_KEY=y |
| 43 | CONFIG_AFIUCV=m | ||
| 44 | CONFIG_INET=y | 52 | CONFIG_INET=y |
| 45 | CONFIG_IP_MULTICAST=y | 53 | CONFIG_IP_MULTICAST=y |
| 46 | # CONFIG_INET_LRO is not set | 54 | # CONFIG_INET_LRO is not set |
| 47 | CONFIG_IPV6=y | 55 | CONFIG_IPV6=y |
| 48 | CONFIG_NET_SCTPPROBE=m | ||
| 49 | CONFIG_L2TP=m | 56 | CONFIG_L2TP=m |
| 50 | CONFIG_L2TP_DEBUGFS=m | 57 | CONFIG_L2TP_DEBUGFS=m |
| 51 | CONFIG_VLAN_8021Q=y | 58 | CONFIG_VLAN_8021Q=y |
| @@ -84,15 +91,14 @@ CONFIG_SCSI_CONSTANTS=y | |||
| 84 | CONFIG_SCSI_LOGGING=y | 91 | CONFIG_SCSI_LOGGING=y |
| 85 | CONFIG_SCSI_SCAN_ASYNC=y | 92 | CONFIG_SCSI_SCAN_ASYNC=y |
| 86 | CONFIG_ZFCP=y | 93 | CONFIG_ZFCP=y |
| 87 | CONFIG_ZFCP_DIF=y | ||
| 88 | CONFIG_NETDEVICES=y | 94 | CONFIG_NETDEVICES=y |
| 89 | CONFIG_DUMMY=m | ||
| 90 | CONFIG_BONDING=m | 95 | CONFIG_BONDING=m |
| 96 | CONFIG_DUMMY=m | ||
| 91 | CONFIG_EQUALIZER=m | 97 | CONFIG_EQUALIZER=m |
| 92 | CONFIG_TUN=m | 98 | CONFIG_TUN=m |
| 93 | CONFIG_NET_ETHERNET=y | ||
| 94 | CONFIG_VIRTIO_NET=y | 99 | CONFIG_VIRTIO_NET=y |
| 95 | CONFIG_RAW_DRIVER=m | 100 | CONFIG_RAW_DRIVER=m |
| 101 | CONFIG_VIRTIO_BALLOON=y | ||
| 96 | CONFIG_EXT2_FS=y | 102 | CONFIG_EXT2_FS=y |
| 97 | CONFIG_EXT3_FS=y | 103 | CONFIG_EXT3_FS=y |
| 98 | # CONFIG_EXT3_DEFAULTS_TO_ORDERED is not set | 104 | # CONFIG_EXT3_DEFAULTS_TO_ORDERED is not set |
| @@ -103,27 +109,21 @@ CONFIG_PROC_KCORE=y | |||
| 103 | CONFIG_TMPFS=y | 109 | CONFIG_TMPFS=y |
| 104 | CONFIG_TMPFS_POSIX_ACL=y | 110 | CONFIG_TMPFS_POSIX_ACL=y |
| 105 | # CONFIG_NETWORK_FILESYSTEMS is not set | 111 | # CONFIG_NETWORK_FILESYSTEMS is not set |
| 106 | CONFIG_PARTITION_ADVANCED=y | ||
| 107 | CONFIG_IBM_PARTITION=y | ||
| 108 | CONFIG_DLM=m | ||
| 109 | CONFIG_MAGIC_SYSRQ=y | 112 | CONFIG_MAGIC_SYSRQ=y |
| 110 | CONFIG_DEBUG_KERNEL=y | ||
| 111 | CONFIG_TIMER_STATS=y | 113 | CONFIG_TIMER_STATS=y |
| 112 | CONFIG_PROVE_LOCKING=y | 114 | CONFIG_PROVE_LOCKING=y |
| 113 | CONFIG_PROVE_RCU=y | 115 | CONFIG_PROVE_RCU=y |
| 114 | CONFIG_LOCK_STAT=y | 116 | CONFIG_LOCK_STAT=y |
| 115 | CONFIG_DEBUG_LOCKDEP=y | 117 | CONFIG_DEBUG_LOCKDEP=y |
| 116 | CONFIG_DEBUG_SPINLOCK_SLEEP=y | ||
| 117 | CONFIG_DEBUG_LIST=y | 118 | CONFIG_DEBUG_LIST=y |
| 118 | CONFIG_DEBUG_NOTIFIERS=y | 119 | CONFIG_DEBUG_NOTIFIERS=y |
| 119 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 120 | CONFIG_RCU_TRACE=y |
| 120 | CONFIG_KPROBES_SANITY_TEST=y | 121 | CONFIG_KPROBES_SANITY_TEST=y |
| 121 | CONFIG_DEBUG_FORCE_WEAK_PER_CPU=y | 122 | CONFIG_DEBUG_FORCE_WEAK_PER_CPU=y |
| 122 | CONFIG_CPU_NOTIFIER_ERROR_INJECT=m | 123 | CONFIG_CPU_NOTIFIER_ERROR_INJECT=m |
| 123 | CONFIG_LATENCYTOP=y | 124 | CONFIG_LATENCYTOP=y |
| 124 | CONFIG_SYSCTL_SYSCALL_CHECK=y | ||
| 125 | CONFIG_DEBUG_PAGEALLOC=y | 125 | CONFIG_DEBUG_PAGEALLOC=y |
| 126 | # CONFIG_FTRACE is not set | 126 | CONFIG_BLK_DEV_IO_TRACE=y |
| 127 | # CONFIG_STRICT_DEVMEM is not set | 127 | # CONFIG_STRICT_DEVMEM is not set |
| 128 | CONFIG_CRYPTO_NULL=m | 128 | CONFIG_CRYPTO_NULL=m |
| 129 | CONFIG_CRYPTO_CRYPTD=m | 129 | CONFIG_CRYPTO_CRYPTD=m |
| @@ -173,4 +173,3 @@ CONFIG_CRYPTO_SHA512_S390=m | |||
| 173 | CONFIG_CRYPTO_DES_S390=m | 173 | CONFIG_CRYPTO_DES_S390=m |
| 174 | CONFIG_CRYPTO_AES_S390=m | 174 | CONFIG_CRYPTO_AES_S390=m |
| 175 | CONFIG_CRC7=m | 175 | CONFIG_CRC7=m |
| 176 | CONFIG_VIRTIO_BALLOON=y | ||
diff --git a/arch/s390/include/asm/facility.h b/arch/s390/include/asm/facility.h index 1e5b27edc0c9..2ee66a65f2d4 100644 --- a/arch/s390/include/asm/facility.h +++ b/arch/s390/include/asm/facility.h | |||
| @@ -38,12 +38,11 @@ static inline void stfle(u64 *stfle_fac_list, int size) | |||
| 38 | unsigned long nr; | 38 | unsigned long nr; |
| 39 | 39 | ||
| 40 | preempt_disable(); | 40 | preempt_disable(); |
| 41 | S390_lowcore.stfl_fac_list = 0; | ||
| 42 | asm volatile( | 41 | asm volatile( |
| 43 | " .insn s,0xb2b10000,0(0)\n" /* stfl */ | 42 | " .insn s,0xb2b10000,0(0)\n" /* stfl */ |
| 44 | "0:\n" | 43 | "0:\n" |
| 45 | EX_TABLE(0b, 0b) | 44 | EX_TABLE(0b, 0b) |
| 46 | : "=m" (S390_lowcore.stfl_fac_list)); | 45 | : "+m" (S390_lowcore.stfl_fac_list)); |
| 47 | nr = 4; /* bytes stored by stfl */ | 46 | nr = 4; /* bytes stored by stfl */ |
| 48 | memcpy(stfle_fac_list, &S390_lowcore.stfl_fac_list, 4); | 47 | memcpy(stfle_fac_list, &S390_lowcore.stfl_fac_list, 4); |
| 49 | if (S390_lowcore.stfl_fac_list & 0x01000000) { | 48 | if (S390_lowcore.stfl_fac_list & 0x01000000) { |
diff --git a/arch/s390/include/asm/pgalloc.h b/arch/s390/include/asm/pgalloc.h index 8eef9b5b3cf4..78e3041919de 100644 --- a/arch/s390/include/asm/pgalloc.h +++ b/arch/s390/include/asm/pgalloc.h | |||
| @@ -22,10 +22,7 @@ void crst_table_free(struct mm_struct *, unsigned long *); | |||
| 22 | 22 | ||
| 23 | unsigned long *page_table_alloc(struct mm_struct *, unsigned long); | 23 | unsigned long *page_table_alloc(struct mm_struct *, unsigned long); |
| 24 | void page_table_free(struct mm_struct *, unsigned long *); | 24 | void page_table_free(struct mm_struct *, unsigned long *); |
| 25 | #ifdef CONFIG_HAVE_RCU_TABLE_FREE | ||
| 26 | void page_table_free_rcu(struct mmu_gather *, unsigned long *); | 25 | void page_table_free_rcu(struct mmu_gather *, unsigned long *); |
| 27 | void __tlb_remove_table(void *_table); | ||
| 28 | #endif | ||
| 29 | 26 | ||
| 30 | static inline void clear_table(unsigned long *s, unsigned long val, size_t n) | 27 | static inline void clear_table(unsigned long *s, unsigned long val, size_t n) |
| 31 | { | 28 | { |
diff --git a/arch/s390/include/asm/swab.h b/arch/s390/include/asm/swab.h index 6bdee21c077e..a3e4ebb32090 100644 --- a/arch/s390/include/asm/swab.h +++ b/arch/s390/include/asm/swab.h | |||
| @@ -77,7 +77,7 @@ static inline __u16 __arch_swab16p(const __u16 *x) | |||
| 77 | 77 | ||
| 78 | asm volatile( | 78 | asm volatile( |
| 79 | #ifndef __s390x__ | 79 | #ifndef __s390x__ |
| 80 | " icm %0,2,%O+1(%R1)\n" | 80 | " icm %0,2,%O1+1(%R1)\n" |
| 81 | " ic %0,%1\n" | 81 | " ic %0,%1\n" |
| 82 | : "=&d" (result) : "Q" (*x) : "cc"); | 82 | : "=&d" (result) : "Q" (*x) : "cc"); |
| 83 | #else /* __s390x__ */ | 83 | #else /* __s390x__ */ |
diff --git a/arch/s390/include/asm/tlb.h b/arch/s390/include/asm/tlb.h index c687a2c83462..775a5eea8f9e 100644 --- a/arch/s390/include/asm/tlb.h +++ b/arch/s390/include/asm/tlb.h | |||
| @@ -30,14 +30,10 @@ | |||
| 30 | 30 | ||
| 31 | struct mmu_gather { | 31 | struct mmu_gather { |
| 32 | struct mm_struct *mm; | 32 | struct mm_struct *mm; |
| 33 | #ifdef CONFIG_HAVE_RCU_TABLE_FREE | ||
| 34 | struct mmu_table_batch *batch; | 33 | struct mmu_table_batch *batch; |
| 35 | #endif | ||
| 36 | unsigned int fullmm; | 34 | unsigned int fullmm; |
| 37 | unsigned int need_flush; | ||
| 38 | }; | 35 | }; |
| 39 | 36 | ||
| 40 | #ifdef CONFIG_HAVE_RCU_TABLE_FREE | ||
| 41 | struct mmu_table_batch { | 37 | struct mmu_table_batch { |
| 42 | struct rcu_head rcu; | 38 | struct rcu_head rcu; |
| 43 | unsigned int nr; | 39 | unsigned int nr; |
| @@ -49,7 +45,6 @@ struct mmu_table_batch { | |||
| 49 | 45 | ||
| 50 | extern void tlb_table_flush(struct mmu_gather *tlb); | 46 | extern void tlb_table_flush(struct mmu_gather *tlb); |
| 51 | extern void tlb_remove_table(struct mmu_gather *tlb, void *table); | 47 | extern void tlb_remove_table(struct mmu_gather *tlb, void *table); |
| 52 | #endif | ||
| 53 | 48 | ||
| 54 | static inline void tlb_gather_mmu(struct mmu_gather *tlb, | 49 | static inline void tlb_gather_mmu(struct mmu_gather *tlb, |
| 55 | struct mm_struct *mm, | 50 | struct mm_struct *mm, |
| @@ -57,29 +52,20 @@ static inline void tlb_gather_mmu(struct mmu_gather *tlb, | |||
| 57 | { | 52 | { |
| 58 | tlb->mm = mm; | 53 | tlb->mm = mm; |
| 59 | tlb->fullmm = full_mm_flush; | 54 | tlb->fullmm = full_mm_flush; |
| 60 | tlb->need_flush = 0; | ||
| 61 | #ifdef CONFIG_HAVE_RCU_TABLE_FREE | ||
| 62 | tlb->batch = NULL; | 55 | tlb->batch = NULL; |
| 63 | #endif | ||
| 64 | if (tlb->fullmm) | 56 | if (tlb->fullmm) |
| 65 | __tlb_flush_mm(mm); | 57 | __tlb_flush_mm(mm); |
| 66 | } | 58 | } |
| 67 | 59 | ||
| 68 | static inline void tlb_flush_mmu(struct mmu_gather *tlb) | 60 | static inline void tlb_flush_mmu(struct mmu_gather *tlb) |
| 69 | { | 61 | { |
| 70 | if (!tlb->need_flush) | ||
| 71 | return; | ||
| 72 | tlb->need_flush = 0; | ||
| 73 | __tlb_flush_mm(tlb->mm); | ||
| 74 | #ifdef CONFIG_HAVE_RCU_TABLE_FREE | ||
| 75 | tlb_table_flush(tlb); | 62 | tlb_table_flush(tlb); |
| 76 | #endif | ||
| 77 | } | 63 | } |
| 78 | 64 | ||
| 79 | static inline void tlb_finish_mmu(struct mmu_gather *tlb, | 65 | static inline void tlb_finish_mmu(struct mmu_gather *tlb, |
| 80 | unsigned long start, unsigned long end) | 66 | unsigned long start, unsigned long end) |
| 81 | { | 67 | { |
| 82 | tlb_flush_mmu(tlb); | 68 | tlb_table_flush(tlb); |
| 83 | } | 69 | } |
| 84 | 70 | ||
| 85 | /* | 71 | /* |
| @@ -105,10 +91,8 @@ static inline void tlb_remove_page(struct mmu_gather *tlb, struct page *page) | |||
| 105 | static inline void pte_free_tlb(struct mmu_gather *tlb, pgtable_t pte, | 91 | static inline void pte_free_tlb(struct mmu_gather *tlb, pgtable_t pte, |
| 106 | unsigned long address) | 92 | unsigned long address) |
| 107 | { | 93 | { |
| 108 | #ifdef CONFIG_HAVE_RCU_TABLE_FREE | ||
| 109 | if (!tlb->fullmm) | 94 | if (!tlb->fullmm) |
| 110 | return page_table_free_rcu(tlb, (unsigned long *) pte); | 95 | return page_table_free_rcu(tlb, (unsigned long *) pte); |
| 111 | #endif | ||
| 112 | page_table_free(tlb->mm, (unsigned long *) pte); | 96 | page_table_free(tlb->mm, (unsigned long *) pte); |
| 113 | } | 97 | } |
| 114 | 98 | ||
| @@ -125,10 +109,8 @@ static inline void pmd_free_tlb(struct mmu_gather *tlb, pmd_t *pmd, | |||
| 125 | #ifdef __s390x__ | 109 | #ifdef __s390x__ |
| 126 | if (tlb->mm->context.asce_limit <= (1UL << 31)) | 110 | if (tlb->mm->context.asce_limit <= (1UL << 31)) |
| 127 | return; | 111 | return; |
| 128 | #ifdef CONFIG_HAVE_RCU_TABLE_FREE | ||
| 129 | if (!tlb->fullmm) | 112 | if (!tlb->fullmm) |
| 130 | return tlb_remove_table(tlb, pmd); | 113 | return tlb_remove_table(tlb, pmd); |
| 131 | #endif | ||
| 132 | crst_table_free(tlb->mm, (unsigned long *) pmd); | 114 | crst_table_free(tlb->mm, (unsigned long *) pmd); |
| 133 | #endif | 115 | #endif |
| 134 | } | 116 | } |
| @@ -146,10 +128,8 @@ static inline void pud_free_tlb(struct mmu_gather *tlb, pud_t *pud, | |||
| 146 | #ifdef __s390x__ | 128 | #ifdef __s390x__ |
| 147 | if (tlb->mm->context.asce_limit <= (1UL << 42)) | 129 | if (tlb->mm->context.asce_limit <= (1UL << 42)) |
| 148 | return; | 130 | return; |
| 149 | #ifdef CONFIG_HAVE_RCU_TABLE_FREE | ||
| 150 | if (!tlb->fullmm) | 131 | if (!tlb->fullmm) |
| 151 | return tlb_remove_table(tlb, pud); | 132 | return tlb_remove_table(tlb, pud); |
| 152 | #endif | ||
| 153 | crst_table_free(tlb->mm, (unsigned long *) pud); | 133 | crst_table_free(tlb->mm, (unsigned long *) pud); |
| 154 | #endif | 134 | #endif |
| 155 | } | 135 | } |
diff --git a/arch/s390/kernel/head.S b/arch/s390/kernel/head.S index c27a0727f930..adccd908ebc7 100644 --- a/arch/s390/kernel/head.S +++ b/arch/s390/kernel/head.S | |||
| @@ -474,9 +474,9 @@ ENTRY(startup_kdump) | |||
| 474 | stck __LC_LAST_UPDATE_CLOCK | 474 | stck __LC_LAST_UPDATE_CLOCK |
| 475 | spt 5f-.LPG0(%r13) | 475 | spt 5f-.LPG0(%r13) |
| 476 | mvc __LC_LAST_UPDATE_TIMER(8),5f-.LPG0(%r13) | 476 | mvc __LC_LAST_UPDATE_TIMER(8),5f-.LPG0(%r13) |
| 477 | xc __LC_STFL_FAC_LIST(8),__LC_STFL_FAC_LIST | ||
| 477 | #ifndef CONFIG_MARCH_G5 | 478 | #ifndef CONFIG_MARCH_G5 |
| 478 | # check capabilities against MARCH_{G5,Z900,Z990,Z9_109,Z10} | 479 | # check capabilities against MARCH_{G5,Z900,Z990,Z9_109,Z10} |
| 479 | xc __LC_STFL_FAC_LIST(8),__LC_STFL_FAC_LIST | ||
| 480 | .insn s,0xb2b10000,__LC_STFL_FAC_LIST # store facility list | 480 | .insn s,0xb2b10000,__LC_STFL_FAC_LIST # store facility list |
| 481 | tm __LC_STFL_FAC_LIST,0x01 # stfle available ? | 481 | tm __LC_STFL_FAC_LIST,0x01 # stfle available ? |
| 482 | jz 0f | 482 | jz 0f |
diff --git a/arch/s390/kernel/irq.c b/arch/s390/kernel/irq.c index 1c2cdd59ccd0..8a22c27219dd 100644 --- a/arch/s390/kernel/irq.c +++ b/arch/s390/kernel/irq.c | |||
| @@ -118,9 +118,10 @@ asmlinkage void do_softirq(void) | |||
| 118 | "a" (__do_softirq) | 118 | "a" (__do_softirq) |
| 119 | : "0", "1", "2", "3", "4", "5", "14", | 119 | : "0", "1", "2", "3", "4", "5", "14", |
| 120 | "cc", "memory" ); | 120 | "cc", "memory" ); |
| 121 | } else | 121 | } else { |
| 122 | /* We are already on the async stack. */ | 122 | /* We are already on the async stack. */ |
| 123 | __do_softirq(); | 123 | __do_softirq(); |
| 124 | } | ||
| 124 | } | 125 | } |
| 125 | 126 | ||
| 126 | local_irq_restore(flags); | 127 | local_irq_restore(flags); |
| @@ -192,11 +193,12 @@ int unregister_external_interrupt(u16 code, ext_int_handler_t handler) | |||
| 192 | int index = ext_hash(code); | 193 | int index = ext_hash(code); |
| 193 | 194 | ||
| 194 | spin_lock_irqsave(&ext_int_hash_lock, flags); | 195 | spin_lock_irqsave(&ext_int_hash_lock, flags); |
| 195 | list_for_each_entry_rcu(p, &ext_int_hash[index], entry) | 196 | list_for_each_entry_rcu(p, &ext_int_hash[index], entry) { |
| 196 | if (p->code == code && p->handler == handler) { | 197 | if (p->code == code && p->handler == handler) { |
| 197 | list_del_rcu(&p->entry); | 198 | list_del_rcu(&p->entry); |
| 198 | kfree_rcu(p, rcu); | 199 | kfree_rcu(p, rcu); |
| 199 | } | 200 | } |
| 201 | } | ||
| 200 | spin_unlock_irqrestore(&ext_int_hash_lock, flags); | 202 | spin_unlock_irqrestore(&ext_int_hash_lock, flags); |
| 201 | return 0; | 203 | return 0; |
| 202 | } | 204 | } |
| @@ -211,9 +213,10 @@ void __irq_entry do_extint(struct pt_regs *regs, struct ext_code ext_code, | |||
| 211 | 213 | ||
| 212 | old_regs = set_irq_regs(regs); | 214 | old_regs = set_irq_regs(regs); |
| 213 | irq_enter(); | 215 | irq_enter(); |
| 214 | if (S390_lowcore.int_clock >= S390_lowcore.clock_comparator) | 216 | if (S390_lowcore.int_clock >= S390_lowcore.clock_comparator) { |
| 215 | /* Serve timer interrupts first. */ | 217 | /* Serve timer interrupts first. */ |
| 216 | clock_comparator_work(); | 218 | clock_comparator_work(); |
| 219 | } | ||
| 217 | kstat_cpu(smp_processor_id()).irqs[EXTERNAL_INTERRUPT]++; | 220 | kstat_cpu(smp_processor_id()).irqs[EXTERNAL_INTERRUPT]++; |
| 218 | if (ext_code.code != 0x1004) | 221 | if (ext_code.code != 0x1004) |
| 219 | __get_cpu_var(s390_idle).nohz_delay = 1; | 222 | __get_cpu_var(s390_idle).nohz_delay = 1; |
diff --git a/arch/s390/kernel/perf_cpum_cf.c b/arch/s390/kernel/perf_cpum_cf.c index 46405086479c..cb019f429e88 100644 --- a/arch/s390/kernel/perf_cpum_cf.c +++ b/arch/s390/kernel/perf_cpum_cf.c | |||
| @@ -178,7 +178,7 @@ static void cpumf_pmu_enable(struct pmu *pmu) | |||
| 178 | err = lcctl(cpuhw->state); | 178 | err = lcctl(cpuhw->state); |
| 179 | if (err) { | 179 | if (err) { |
| 180 | pr_err("Enabling the performance measuring unit " | 180 | pr_err("Enabling the performance measuring unit " |
| 181 | "failed with rc=%lx\n", err); | 181 | "failed with rc=%x\n", err); |
| 182 | return; | 182 | return; |
| 183 | } | 183 | } |
| 184 | 184 | ||
| @@ -203,7 +203,7 @@ static void cpumf_pmu_disable(struct pmu *pmu) | |||
| 203 | err = lcctl(inactive); | 203 | err = lcctl(inactive); |
| 204 | if (err) { | 204 | if (err) { |
| 205 | pr_err("Disabling the performance measuring unit " | 205 | pr_err("Disabling the performance measuring unit " |
| 206 | "failed with rc=%lx\n", err); | 206 | "failed with rc=%x\n", err); |
| 207 | return; | 207 | return; |
| 208 | } | 208 | } |
| 209 | 209 | ||
diff --git a/arch/s390/mm/maccess.c b/arch/s390/mm/maccess.c index 7bb15fcca75e..e1335dc2b1b7 100644 --- a/arch/s390/mm/maccess.c +++ b/arch/s390/mm/maccess.c | |||
| @@ -61,21 +61,14 @@ long probe_kernel_write(void *dst, const void *src, size_t size) | |||
| 61 | return copied < 0 ? -EFAULT : 0; | 61 | return copied < 0 ? -EFAULT : 0; |
| 62 | } | 62 | } |
| 63 | 63 | ||
| 64 | /* | 64 | static int __memcpy_real(void *dest, void *src, size_t count) |
| 65 | * Copy memory in real mode (kernel to kernel) | ||
| 66 | */ | ||
| 67 | int memcpy_real(void *dest, void *src, size_t count) | ||
| 68 | { | 65 | { |
| 69 | register unsigned long _dest asm("2") = (unsigned long) dest; | 66 | register unsigned long _dest asm("2") = (unsigned long) dest; |
| 70 | register unsigned long _len1 asm("3") = (unsigned long) count; | 67 | register unsigned long _len1 asm("3") = (unsigned long) count; |
| 71 | register unsigned long _src asm("4") = (unsigned long) src; | 68 | register unsigned long _src asm("4") = (unsigned long) src; |
| 72 | register unsigned long _len2 asm("5") = (unsigned long) count; | 69 | register unsigned long _len2 asm("5") = (unsigned long) count; |
| 73 | unsigned long flags; | ||
| 74 | int rc = -EFAULT; | 70 | int rc = -EFAULT; |
| 75 | 71 | ||
| 76 | if (!count) | ||
| 77 | return 0; | ||
| 78 | flags = __arch_local_irq_stnsm(0xf8UL); | ||
| 79 | asm volatile ( | 72 | asm volatile ( |
| 80 | "0: mvcle %1,%2,0x0\n" | 73 | "0: mvcle %1,%2,0x0\n" |
| 81 | "1: jo 0b\n" | 74 | "1: jo 0b\n" |
| @@ -86,7 +79,23 @@ int memcpy_real(void *dest, void *src, size_t count) | |||
| 86 | "+d" (_len2), "=m" (*((long *) dest)) | 79 | "+d" (_len2), "=m" (*((long *) dest)) |
| 87 | : "m" (*((long *) src)) | 80 | : "m" (*((long *) src)) |
| 88 | : "cc", "memory"); | 81 | : "cc", "memory"); |
| 89 | arch_local_irq_restore(flags); | 82 | return rc; |
| 83 | } | ||
| 84 | |||
| 85 | /* | ||
| 86 | * Copy memory in real mode (kernel to kernel) | ||
| 87 | */ | ||
| 88 | int memcpy_real(void *dest, void *src, size_t count) | ||
| 89 | { | ||
| 90 | unsigned long flags; | ||
| 91 | int rc; | ||
| 92 | |||
| 93 | if (!count) | ||
| 94 | return 0; | ||
| 95 | local_irq_save(flags); | ||
| 96 | __arch_local_irq_stnsm(0xfbUL); | ||
| 97 | rc = __memcpy_real(dest, src, count); | ||
| 98 | local_irq_restore(flags); | ||
| 90 | return rc; | 99 | return rc; |
| 91 | } | 100 | } |
| 92 | 101 | ||
diff --git a/arch/s390/mm/pgtable.c b/arch/s390/mm/pgtable.c index 373adf69b01c..6e765bf00670 100644 --- a/arch/s390/mm/pgtable.c +++ b/arch/s390/mm/pgtable.c | |||
| @@ -678,8 +678,6 @@ void page_table_free(struct mm_struct *mm, unsigned long *table) | |||
| 678 | } | 678 | } |
| 679 | } | 679 | } |
| 680 | 680 | ||
| 681 | #ifdef CONFIG_HAVE_RCU_TABLE_FREE | ||
| 682 | |||
| 683 | static void __page_table_free_rcu(void *table, unsigned bit) | 681 | static void __page_table_free_rcu(void *table, unsigned bit) |
| 684 | { | 682 | { |
| 685 | struct page *page; | 683 | struct page *page; |
| @@ -733,7 +731,66 @@ void __tlb_remove_table(void *_table) | |||
| 733 | free_pages((unsigned long) table, ALLOC_ORDER); | 731 | free_pages((unsigned long) table, ALLOC_ORDER); |
| 734 | } | 732 | } |
| 735 | 733 | ||
| 736 | #endif | 734 | static void tlb_remove_table_smp_sync(void *arg) |
| 735 | { | ||
| 736 | /* Simply deliver the interrupt */ | ||
| 737 | } | ||
| 738 | |||
| 739 | static void tlb_remove_table_one(void *table) | ||
| 740 | { | ||
| 741 | /* | ||
| 742 | * This isn't an RCU grace period and hence the page-tables cannot be | ||
| 743 | * assumed to be actually RCU-freed. | ||
| 744 | * | ||
| 745 | * It is however sufficient for software page-table walkers that rely | ||
| 746 | * on IRQ disabling. See the comment near struct mmu_table_batch. | ||
| 747 | */ | ||
| 748 | smp_call_function(tlb_remove_table_smp_sync, NULL, 1); | ||
| 749 | __tlb_remove_table(table); | ||
| 750 | } | ||
| 751 | |||
| 752 | static void tlb_remove_table_rcu(struct rcu_head *head) | ||
| 753 | { | ||
| 754 | struct mmu_table_batch *batch; | ||
| 755 | int i; | ||
| 756 | |||
| 757 | batch = container_of(head, struct mmu_table_batch, rcu); | ||
| 758 | |||
| 759 | for (i = 0; i < batch->nr; i++) | ||
| 760 | __tlb_remove_table(batch->tables[i]); | ||
| 761 | |||
| 762 | free_page((unsigned long)batch); | ||
| 763 | } | ||
| 764 | |||
| 765 | void tlb_table_flush(struct mmu_gather *tlb) | ||
| 766 | { | ||
| 767 | struct mmu_table_batch **batch = &tlb->batch; | ||
| 768 | |||
| 769 | if (*batch) { | ||
| 770 | __tlb_flush_mm(tlb->mm); | ||
| 771 | call_rcu_sched(&(*batch)->rcu, tlb_remove_table_rcu); | ||
| 772 | *batch = NULL; | ||
| 773 | } | ||
| 774 | } | ||
| 775 | |||
| 776 | void tlb_remove_table(struct mmu_gather *tlb, void *table) | ||
| 777 | { | ||
| 778 | struct mmu_table_batch **batch = &tlb->batch; | ||
| 779 | |||
| 780 | if (*batch == NULL) { | ||
| 781 | *batch = (struct mmu_table_batch *) | ||
| 782 | __get_free_page(GFP_NOWAIT | __GFP_NOWARN); | ||
| 783 | if (*batch == NULL) { | ||
| 784 | __tlb_flush_mm(tlb->mm); | ||
| 785 | tlb_remove_table_one(table); | ||
| 786 | return; | ||
| 787 | } | ||
| 788 | (*batch)->nr = 0; | ||
| 789 | } | ||
| 790 | (*batch)->tables[(*batch)->nr++] = table; | ||
| 791 | if ((*batch)->nr == MAX_TABLE_BATCH) | ||
| 792 | tlb_table_flush(tlb); | ||
| 793 | } | ||
| 737 | 794 | ||
| 738 | /* | 795 | /* |
| 739 | * switch on pgstes for its userspace process (for kvm) | 796 | * switch on pgstes for its userspace process (for kvm) |
diff --git a/arch/sparc/kernel/ds.c b/arch/sparc/kernel/ds.c index fea13c7b1aee..b93c2c9ccb1d 100644 --- a/arch/sparc/kernel/ds.c +++ b/arch/sparc/kernel/ds.c | |||
| @@ -1264,4 +1264,4 @@ static int __init ds_init(void) | |||
| 1264 | return vio_register_driver(&ds_driver); | 1264 | return vio_register_driver(&ds_driver); |
| 1265 | } | 1265 | } |
| 1266 | 1266 | ||
| 1267 | subsys_initcall(ds_init); | 1267 | fs_initcall(ds_init); |
diff --git a/arch/sparc/kernel/leon_smp.c b/arch/sparc/kernel/leon_smp.c index 1210fde18740..160cac9c4036 100644 --- a/arch/sparc/kernel/leon_smp.c +++ b/arch/sparc/kernel/leon_smp.c | |||
| @@ -23,6 +23,7 @@ | |||
| 23 | #include <linux/pm.h> | 23 | #include <linux/pm.h> |
| 24 | #include <linux/delay.h> | 24 | #include <linux/delay.h> |
| 25 | #include <linux/gfp.h> | 25 | #include <linux/gfp.h> |
| 26 | #include <linux/cpu.h> | ||
| 26 | 27 | ||
| 27 | #include <asm/cacheflush.h> | 28 | #include <asm/cacheflush.h> |
| 28 | #include <asm/tlbflush.h> | 29 | #include <asm/tlbflush.h> |
| @@ -78,6 +79,8 @@ void __cpuinit leon_callin(void) | |||
| 78 | local_flush_tlb_all(); | 79 | local_flush_tlb_all(); |
| 79 | leon_configure_cache_smp(); | 80 | leon_configure_cache_smp(); |
| 80 | 81 | ||
| 82 | notify_cpu_starting(cpuid); | ||
| 83 | |||
| 81 | /* Get our local ticker going. */ | 84 | /* Get our local ticker going. */ |
| 82 | smp_setup_percpu_timer(); | 85 | smp_setup_percpu_timer(); |
| 83 | 86 | ||
diff --git a/arch/sparc/kernel/rtrap_64.S b/arch/sparc/kernel/rtrap_64.S index 77f1b95e0806..9171fc238def 100644 --- a/arch/sparc/kernel/rtrap_64.S +++ b/arch/sparc/kernel/rtrap_64.S | |||
| @@ -20,11 +20,6 @@ | |||
| 20 | 20 | ||
| 21 | .text | 21 | .text |
| 22 | .align 32 | 22 | .align 32 |
| 23 | __handle_softirq: | ||
| 24 | call do_softirq | ||
| 25 | nop | ||
| 26 | ba,a,pt %xcc, __handle_softirq_continue | ||
| 27 | nop | ||
| 28 | __handle_preemption: | 23 | __handle_preemption: |
| 29 | call schedule | 24 | call schedule |
| 30 | wrpr %g0, RTRAP_PSTATE, %pstate | 25 | wrpr %g0, RTRAP_PSTATE, %pstate |
| @@ -89,9 +84,7 @@ rtrap: | |||
| 89 | cmp %l1, 0 | 84 | cmp %l1, 0 |
| 90 | 85 | ||
| 91 | /* mm/ultra.S:xcall_report_regs KNOWS about this load. */ | 86 | /* mm/ultra.S:xcall_report_regs KNOWS about this load. */ |
| 92 | bne,pn %icc, __handle_softirq | ||
| 93 | ldx [%sp + PTREGS_OFF + PT_V9_TSTATE], %l1 | 87 | ldx [%sp + PTREGS_OFF + PT_V9_TSTATE], %l1 |
| 94 | __handle_softirq_continue: | ||
| 95 | rtrap_xcall: | 88 | rtrap_xcall: |
| 96 | sethi %hi(0xf << 20), %l4 | 89 | sethi %hi(0xf << 20), %l4 |
| 97 | and %l1, %l4, %l4 | 90 | and %l1, %l4, %l4 |
diff --git a/arch/sparc/kernel/sys_sparc_64.c b/arch/sparc/kernel/sys_sparc_64.c index 232df9949530..3ee51f189a55 100644 --- a/arch/sparc/kernel/sys_sparc_64.c +++ b/arch/sparc/kernel/sys_sparc_64.c | |||
| @@ -566,15 +566,10 @@ out: | |||
| 566 | 566 | ||
| 567 | SYSCALL_DEFINE2(64_munmap, unsigned long, addr, size_t, len) | 567 | SYSCALL_DEFINE2(64_munmap, unsigned long, addr, size_t, len) |
| 568 | { | 568 | { |
| 569 | long ret; | ||
| 570 | |||
| 571 | if (invalid_64bit_range(addr, len)) | 569 | if (invalid_64bit_range(addr, len)) |
| 572 | return -EINVAL; | 570 | return -EINVAL; |
| 573 | 571 | ||
| 574 | down_write(¤t->mm->mmap_sem); | 572 | return vm_munmap(addr, len); |
| 575 | ret = do_munmap(current->mm, addr, len); | ||
| 576 | up_write(¤t->mm->mmap_sem); | ||
| 577 | return ret; | ||
| 578 | } | 573 | } |
| 579 | 574 | ||
| 580 | extern unsigned long do_mremap(unsigned long addr, | 575 | extern unsigned long do_mremap(unsigned long addr, |
diff --git a/arch/tile/kernel/single_step.c b/arch/tile/kernel/single_step.c index 9efbc1391b3c..89529c9f0605 100644 --- a/arch/tile/kernel/single_step.c +++ b/arch/tile/kernel/single_step.c | |||
| @@ -346,12 +346,10 @@ void single_step_once(struct pt_regs *regs) | |||
| 346 | } | 346 | } |
| 347 | 347 | ||
| 348 | /* allocate a cache line of writable, executable memory */ | 348 | /* allocate a cache line of writable, executable memory */ |
| 349 | down_write(¤t->mm->mmap_sem); | 349 | buffer = (void __user *) vm_mmap(NULL, 0, 64, |
| 350 | buffer = (void __user *) do_mmap(NULL, 0, 64, | ||
| 351 | PROT_EXEC | PROT_READ | PROT_WRITE, | 350 | PROT_EXEC | PROT_READ | PROT_WRITE, |
| 352 | MAP_PRIVATE | MAP_ANONYMOUS, | 351 | MAP_PRIVATE | MAP_ANONYMOUS, |
| 353 | 0); | 352 | 0); |
| 354 | up_write(¤t->mm->mmap_sem); | ||
| 355 | 353 | ||
| 356 | if (IS_ERR((void __force *)buffer)) { | 354 | if (IS_ERR((void __force *)buffer)) { |
| 357 | kfree(state); | 355 | kfree(state); |
diff --git a/arch/x86/ia32/ia32_aout.c b/arch/x86/ia32/ia32_aout.c index d511d951a052..4824fb45560f 100644 --- a/arch/x86/ia32/ia32_aout.c +++ b/arch/x86/ia32/ia32_aout.c | |||
| @@ -119,9 +119,7 @@ static void set_brk(unsigned long start, unsigned long end) | |||
| 119 | end = PAGE_ALIGN(end); | 119 | end = PAGE_ALIGN(end); |
| 120 | if (end <= start) | 120 | if (end <= start) |
| 121 | return; | 121 | return; |
| 122 | down_write(¤t->mm->mmap_sem); | 122 | vm_brk(start, end - start); |
| 123 | do_brk(start, end - start); | ||
| 124 | up_write(¤t->mm->mmap_sem); | ||
| 125 | } | 123 | } |
| 126 | 124 | ||
| 127 | #ifdef CORE_DUMP | 125 | #ifdef CORE_DUMP |
| @@ -332,9 +330,7 @@ static int load_aout_binary(struct linux_binprm *bprm, struct pt_regs *regs) | |||
| 332 | pos = 32; | 330 | pos = 32; |
| 333 | map_size = ex.a_text+ex.a_data; | 331 | map_size = ex.a_text+ex.a_data; |
| 334 | 332 | ||
| 335 | down_write(¤t->mm->mmap_sem); | 333 | error = vm_brk(text_addr & PAGE_MASK, map_size); |
| 336 | error = do_brk(text_addr & PAGE_MASK, map_size); | ||
| 337 | up_write(¤t->mm->mmap_sem); | ||
| 338 | 334 | ||
| 339 | if (error != (text_addr & PAGE_MASK)) { | 335 | if (error != (text_addr & PAGE_MASK)) { |
| 340 | send_sig(SIGKILL, current, 0); | 336 | send_sig(SIGKILL, current, 0); |
| @@ -373,9 +369,7 @@ static int load_aout_binary(struct linux_binprm *bprm, struct pt_regs *regs) | |||
| 373 | if (!bprm->file->f_op->mmap || (fd_offset & ~PAGE_MASK) != 0) { | 369 | if (!bprm->file->f_op->mmap || (fd_offset & ~PAGE_MASK) != 0) { |
| 374 | loff_t pos = fd_offset; | 370 | loff_t pos = fd_offset; |
| 375 | 371 | ||
| 376 | down_write(¤t->mm->mmap_sem); | 372 | vm_brk(N_TXTADDR(ex), ex.a_text+ex.a_data); |
| 377 | do_brk(N_TXTADDR(ex), ex.a_text+ex.a_data); | ||
| 378 | up_write(¤t->mm->mmap_sem); | ||
| 379 | bprm->file->f_op->read(bprm->file, | 373 | bprm->file->f_op->read(bprm->file, |
| 380 | (char __user *)N_TXTADDR(ex), | 374 | (char __user *)N_TXTADDR(ex), |
| 381 | ex.a_text+ex.a_data, &pos); | 375 | ex.a_text+ex.a_data, &pos); |
| @@ -385,26 +379,22 @@ static int load_aout_binary(struct linux_binprm *bprm, struct pt_regs *regs) | |||
| 385 | goto beyond_if; | 379 | goto beyond_if; |
| 386 | } | 380 | } |
| 387 | 381 | ||
| 388 | down_write(¤t->mm->mmap_sem); | 382 | error = vm_mmap(bprm->file, N_TXTADDR(ex), ex.a_text, |
| 389 | error = do_mmap(bprm->file, N_TXTADDR(ex), ex.a_text, | ||
| 390 | PROT_READ | PROT_EXEC, | 383 | PROT_READ | PROT_EXEC, |
| 391 | MAP_FIXED | MAP_PRIVATE | MAP_DENYWRITE | | 384 | MAP_FIXED | MAP_PRIVATE | MAP_DENYWRITE | |
| 392 | MAP_EXECUTABLE | MAP_32BIT, | 385 | MAP_EXECUTABLE | MAP_32BIT, |
| 393 | fd_offset); | 386 | fd_offset); |
| 394 | up_write(¤t->mm->mmap_sem); | ||
| 395 | 387 | ||
| 396 | if (error != N_TXTADDR(ex)) { | 388 | if (error != N_TXTADDR(ex)) { |
| 397 | send_sig(SIGKILL, current, 0); | 389 | send_sig(SIGKILL, current, 0); |
| 398 | return error; | 390 | return error; |
| 399 | } | 391 | } |
| 400 | 392 | ||
| 401 | down_write(¤t->mm->mmap_sem); | 393 | error = vm_mmap(bprm->file, N_DATADDR(ex), ex.a_data, |
| 402 | error = do_mmap(bprm->file, N_DATADDR(ex), ex.a_data, | ||
| 403 | PROT_READ | PROT_WRITE | PROT_EXEC, | 394 | PROT_READ | PROT_WRITE | PROT_EXEC, |
| 404 | MAP_FIXED | MAP_PRIVATE | MAP_DENYWRITE | | 395 | MAP_FIXED | MAP_PRIVATE | MAP_DENYWRITE | |
| 405 | MAP_EXECUTABLE | MAP_32BIT, | 396 | MAP_EXECUTABLE | MAP_32BIT, |
| 406 | fd_offset + ex.a_text); | 397 | fd_offset + ex.a_text); |
| 407 | up_write(¤t->mm->mmap_sem); | ||
| 408 | if (error != N_DATADDR(ex)) { | 398 | if (error != N_DATADDR(ex)) { |
| 409 | send_sig(SIGKILL, current, 0); | 399 | send_sig(SIGKILL, current, 0); |
| 410 | return error; | 400 | return error; |
| @@ -476,9 +466,7 @@ static int load_aout_library(struct file *file) | |||
| 476 | error_time = jiffies; | 466 | error_time = jiffies; |
| 477 | } | 467 | } |
| 478 | #endif | 468 | #endif |
| 479 | down_write(¤t->mm->mmap_sem); | 469 | vm_brk(start_addr, ex.a_text + ex.a_data + ex.a_bss); |
| 480 | do_brk(start_addr, ex.a_text + ex.a_data + ex.a_bss); | ||
| 481 | up_write(¤t->mm->mmap_sem); | ||
| 482 | 470 | ||
| 483 | file->f_op->read(file, (char __user *)start_addr, | 471 | file->f_op->read(file, (char __user *)start_addr, |
| 484 | ex.a_text + ex.a_data, &pos); | 472 | ex.a_text + ex.a_data, &pos); |
| @@ -490,12 +478,10 @@ static int load_aout_library(struct file *file) | |||
| 490 | goto out; | 478 | goto out; |
| 491 | } | 479 | } |
| 492 | /* Now use mmap to map the library into memory. */ | 480 | /* Now use mmap to map the library into memory. */ |
| 493 | down_write(¤t->mm->mmap_sem); | 481 | error = vm_mmap(file, start_addr, ex.a_text + ex.a_data, |
| 494 | error = do_mmap(file, start_addr, ex.a_text + ex.a_data, | ||
| 495 | PROT_READ | PROT_WRITE | PROT_EXEC, | 482 | PROT_READ | PROT_WRITE | PROT_EXEC, |
| 496 | MAP_FIXED | MAP_PRIVATE | MAP_DENYWRITE | MAP_32BIT, | 483 | MAP_FIXED | MAP_PRIVATE | MAP_DENYWRITE | MAP_32BIT, |
| 497 | N_TXTOFF(ex)); | 484 | N_TXTOFF(ex)); |
| 498 | up_write(¤t->mm->mmap_sem); | ||
| 499 | retval = error; | 485 | retval = error; |
| 500 | if (error != start_addr) | 486 | if (error != start_addr) |
| 501 | goto out; | 487 | goto out; |
| @@ -503,9 +489,7 @@ static int load_aout_library(struct file *file) | |||
| 503 | len = PAGE_ALIGN(ex.a_text + ex.a_data); | 489 | len = PAGE_ALIGN(ex.a_text + ex.a_data); |
| 504 | bss = ex.a_text + ex.a_data + ex.a_bss; | 490 | bss = ex.a_text + ex.a_data + ex.a_bss; |
| 505 | if (bss > len) { | 491 | if (bss > len) { |
| 506 | down_write(¤t->mm->mmap_sem); | 492 | error = vm_brk(start_addr + len, bss - len); |
| 507 | error = do_brk(start_addr + len, bss - len); | ||
| 508 | up_write(¤t->mm->mmap_sem); | ||
| 509 | retval = error; | 493 | retval = error; |
| 510 | if (error != start_addr + len) | 494 | if (error != start_addr + len) |
| 511 | goto out; | 495 | goto out; |
diff --git a/arch/x86/include/asm/cmpxchg.h b/arch/x86/include/asm/cmpxchg.h index b3b733262909..99480e55973d 100644 --- a/arch/x86/include/asm/cmpxchg.h +++ b/arch/x86/include/asm/cmpxchg.h | |||
| @@ -43,7 +43,7 @@ extern void __add_wrong_size(void) | |||
| 43 | switch (sizeof(*(ptr))) { \ | 43 | switch (sizeof(*(ptr))) { \ |
| 44 | case __X86_CASE_B: \ | 44 | case __X86_CASE_B: \ |
| 45 | asm volatile (lock #op "b %b0, %1\n" \ | 45 | asm volatile (lock #op "b %b0, %1\n" \ |
| 46 | : "+r" (__ret), "+m" (*(ptr)) \ | 46 | : "+q" (__ret), "+m" (*(ptr)) \ |
| 47 | : : "memory", "cc"); \ | 47 | : : "memory", "cc"); \ |
| 48 | break; \ | 48 | break; \ |
| 49 | case __X86_CASE_W: \ | 49 | case __X86_CASE_W: \ |
| @@ -173,7 +173,7 @@ extern void __add_wrong_size(void) | |||
| 173 | switch (sizeof(*(ptr))) { \ | 173 | switch (sizeof(*(ptr))) { \ |
| 174 | case __X86_CASE_B: \ | 174 | case __X86_CASE_B: \ |
| 175 | asm volatile (lock "addb %b1, %0\n" \ | 175 | asm volatile (lock "addb %b1, %0\n" \ |
| 176 | : "+m" (*(ptr)) : "ri" (inc) \ | 176 | : "+m" (*(ptr)) : "qi" (inc) \ |
| 177 | : "memory", "cc"); \ | 177 | : "memory", "cc"); \ |
| 178 | break; \ | 178 | break; \ |
| 179 | case __X86_CASE_W: \ | 179 | case __X86_CASE_W: \ |
diff --git a/arch/x86/kernel/vsyscall_64.c b/arch/x86/kernel/vsyscall_64.c index f386dc49f988..7515cf0e1805 100644 --- a/arch/x86/kernel/vsyscall_64.c +++ b/arch/x86/kernel/vsyscall_64.c | |||
| @@ -216,9 +216,9 @@ bool emulate_vsyscall(struct pt_regs *regs, unsigned long address) | |||
| 216 | current_thread_info()->sig_on_uaccess_error = 1; | 216 | current_thread_info()->sig_on_uaccess_error = 1; |
| 217 | 217 | ||
| 218 | /* | 218 | /* |
| 219 | * 0 is a valid user pointer (in the access_ok sense) on 32-bit and | 219 | * NULL is a valid user pointer (in the access_ok sense) on 32-bit and |
| 220 | * 64-bit, so we don't need to special-case it here. For all the | 220 | * 64-bit, so we don't need to special-case it here. For all the |
| 221 | * vsyscalls, 0 means "don't write anything" not "write it at | 221 | * vsyscalls, NULL means "don't write anything" not "write it at |
| 222 | * address 0". | 222 | * address 0". |
| 223 | */ | 223 | */ |
| 224 | ret = -EFAULT; | 224 | ret = -EFAULT; |
| @@ -247,7 +247,7 @@ bool emulate_vsyscall(struct pt_regs *regs, unsigned long address) | |||
| 247 | 247 | ||
| 248 | ret = sys_getcpu((unsigned __user *)regs->di, | 248 | ret = sys_getcpu((unsigned __user *)regs->di, |
| 249 | (unsigned __user *)regs->si, | 249 | (unsigned __user *)regs->si, |
| 250 | 0); | 250 | NULL); |
| 251 | break; | 251 | break; |
| 252 | } | 252 | } |
| 253 | 253 | ||
diff --git a/arch/x86/kvm/pmu.c b/arch/x86/kvm/pmu.c index 173df38dbda5..2e88438ffd83 100644 --- a/arch/x86/kvm/pmu.c +++ b/arch/x86/kvm/pmu.c | |||
| @@ -459,17 +459,17 @@ void kvm_pmu_cpuid_update(struct kvm_vcpu *vcpu) | |||
| 459 | pmu->available_event_types = ~entry->ebx & ((1ull << bitmap_len) - 1); | 459 | pmu->available_event_types = ~entry->ebx & ((1ull << bitmap_len) - 1); |
| 460 | 460 | ||
| 461 | if (pmu->version == 1) { | 461 | if (pmu->version == 1) { |
| 462 | pmu->global_ctrl = (1 << pmu->nr_arch_gp_counters) - 1; | 462 | pmu->nr_arch_fixed_counters = 0; |
| 463 | return; | 463 | } else { |
| 464 | pmu->nr_arch_fixed_counters = min((int)(entry->edx & 0x1f), | ||
| 465 | X86_PMC_MAX_FIXED); | ||
| 466 | pmu->counter_bitmask[KVM_PMC_FIXED] = | ||
| 467 | ((u64)1 << ((entry->edx >> 5) & 0xff)) - 1; | ||
| 464 | } | 468 | } |
| 465 | 469 | ||
| 466 | pmu->nr_arch_fixed_counters = min((int)(entry->edx & 0x1f), | 470 | pmu->global_ctrl = ((1 << pmu->nr_arch_gp_counters) - 1) | |
| 467 | X86_PMC_MAX_FIXED); | 471 | (((1ull << pmu->nr_arch_fixed_counters) - 1) << X86_PMC_IDX_FIXED); |
| 468 | pmu->counter_bitmask[KVM_PMC_FIXED] = | 472 | pmu->global_ctrl_mask = ~pmu->global_ctrl; |
| 469 | ((u64)1 << ((entry->edx >> 5) & 0xff)) - 1; | ||
| 470 | pmu->global_ctrl_mask = ~(((1 << pmu->nr_arch_gp_counters) - 1) | ||
| 471 | | (((1ull << pmu->nr_arch_fixed_counters) - 1) | ||
| 472 | << X86_PMC_IDX_FIXED)); | ||
| 473 | } | 473 | } |
| 474 | 474 | ||
| 475 | void kvm_pmu_init(struct kvm_vcpu *vcpu) | 475 | void kvm_pmu_init(struct kvm_vcpu *vcpu) |
diff --git a/arch/x86/kvm/vmx.c b/arch/x86/kvm/vmx.c index ad85adfef843..4ff0ab9bc3c8 100644 --- a/arch/x86/kvm/vmx.c +++ b/arch/x86/kvm/vmx.c | |||
| @@ -2210,9 +2210,12 @@ static int vmx_set_msr(struct kvm_vcpu *vcpu, u32 msr_index, u64 data) | |||
| 2210 | msr = find_msr_entry(vmx, msr_index); | 2210 | msr = find_msr_entry(vmx, msr_index); |
| 2211 | if (msr) { | 2211 | if (msr) { |
| 2212 | msr->data = data; | 2212 | msr->data = data; |
| 2213 | if (msr - vmx->guest_msrs < vmx->save_nmsrs) | 2213 | if (msr - vmx->guest_msrs < vmx->save_nmsrs) { |
| 2214 | preempt_disable(); | ||
| 2214 | kvm_set_shared_msr(msr->index, msr->data, | 2215 | kvm_set_shared_msr(msr->index, msr->data, |
| 2215 | msr->mask); | 2216 | msr->mask); |
| 2217 | preempt_enable(); | ||
| 2218 | } | ||
| 2216 | break; | 2219 | break; |
| 2217 | } | 2220 | } |
| 2218 | ret = kvm_set_msr_common(vcpu, msr_index, data); | 2221 | ret = kvm_set_msr_common(vcpu, msr_index, data); |
diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index 4044ce0bf7c1..91a5e989abcf 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c | |||
| @@ -6336,13 +6336,11 @@ int kvm_arch_prepare_memory_region(struct kvm *kvm, | |||
| 6336 | if (npages && !old.rmap) { | 6336 | if (npages && !old.rmap) { |
| 6337 | unsigned long userspace_addr; | 6337 | unsigned long userspace_addr; |
| 6338 | 6338 | ||
| 6339 | down_write(¤t->mm->mmap_sem); | 6339 | userspace_addr = vm_mmap(NULL, 0, |
| 6340 | userspace_addr = do_mmap(NULL, 0, | ||
| 6341 | npages * PAGE_SIZE, | 6340 | npages * PAGE_SIZE, |
| 6342 | PROT_READ | PROT_WRITE, | 6341 | PROT_READ | PROT_WRITE, |
| 6343 | map_flags, | 6342 | map_flags, |
| 6344 | 0); | 6343 | 0); |
| 6345 | up_write(¤t->mm->mmap_sem); | ||
| 6346 | 6344 | ||
| 6347 | if (IS_ERR((void *)userspace_addr)) | 6345 | if (IS_ERR((void *)userspace_addr)) |
| 6348 | return PTR_ERR((void *)userspace_addr); | 6346 | return PTR_ERR((void *)userspace_addr); |
| @@ -6366,10 +6364,8 @@ void kvm_arch_commit_memory_region(struct kvm *kvm, | |||
| 6366 | if (!user_alloc && !old.user_alloc && old.rmap && !npages) { | 6364 | if (!user_alloc && !old.user_alloc && old.rmap && !npages) { |
| 6367 | int ret; | 6365 | int ret; |
| 6368 | 6366 | ||
| 6369 | down_write(¤t->mm->mmap_sem); | 6367 | ret = vm_munmap(old.userspace_addr, |
| 6370 | ret = do_munmap(current->mm, old.userspace_addr, | ||
| 6371 | old.npages * PAGE_SIZE); | 6368 | old.npages * PAGE_SIZE); |
| 6372 | up_write(¤t->mm->mmap_sem); | ||
| 6373 | if (ret < 0) | 6369 | if (ret < 0) |
| 6374 | printk(KERN_WARNING | 6370 | printk(KERN_WARNING |
| 6375 | "kvm_vm_ioctl_set_memory_region: " | 6371 | "kvm_vm_ioctl_set_memory_region: " |
diff --git a/arch/x86/lib/insn.c b/arch/x86/lib/insn.c index 25feb1ae71c5..b1e6c4b2e8eb 100644 --- a/arch/x86/lib/insn.c +++ b/arch/x86/lib/insn.c | |||
| @@ -379,8 +379,8 @@ err_out: | |||
| 379 | return; | 379 | return; |
| 380 | } | 380 | } |
| 381 | 381 | ||
| 382 | /* Decode moffset16/32/64 */ | 382 | /* Decode moffset16/32/64. Return 0 if failed */ |
| 383 | static void __get_moffset(struct insn *insn) | 383 | static int __get_moffset(struct insn *insn) |
| 384 | { | 384 | { |
| 385 | switch (insn->addr_bytes) { | 385 | switch (insn->addr_bytes) { |
| 386 | case 2: | 386 | case 2: |
| @@ -397,15 +397,19 @@ static void __get_moffset(struct insn *insn) | |||
| 397 | insn->moffset2.value = get_next(int, insn); | 397 | insn->moffset2.value = get_next(int, insn); |
| 398 | insn->moffset2.nbytes = 4; | 398 | insn->moffset2.nbytes = 4; |
| 399 | break; | 399 | break; |
| 400 | default: /* opnd_bytes must be modified manually */ | ||
| 401 | goto err_out; | ||
| 400 | } | 402 | } |
| 401 | insn->moffset1.got = insn->moffset2.got = 1; | 403 | insn->moffset1.got = insn->moffset2.got = 1; |
| 402 | 404 | ||
| 405 | return 1; | ||
| 406 | |||
| 403 | err_out: | 407 | err_out: |
| 404 | return; | 408 | return 0; |
| 405 | } | 409 | } |
| 406 | 410 | ||
| 407 | /* Decode imm v32(Iz) */ | 411 | /* Decode imm v32(Iz). Return 0 if failed */ |
| 408 | static void __get_immv32(struct insn *insn) | 412 | static int __get_immv32(struct insn *insn) |
| 409 | { | 413 | { |
| 410 | switch (insn->opnd_bytes) { | 414 | switch (insn->opnd_bytes) { |
| 411 | case 2: | 415 | case 2: |
| @@ -417,14 +421,18 @@ static void __get_immv32(struct insn *insn) | |||
| 417 | insn->immediate.value = get_next(int, insn); | 421 | insn->immediate.value = get_next(int, insn); |
| 418 | insn->immediate.nbytes = 4; | 422 | insn->immediate.nbytes = 4; |
| 419 | break; | 423 | break; |
| 424 | default: /* opnd_bytes must be modified manually */ | ||
| 425 | goto err_out; | ||
| 420 | } | 426 | } |
| 421 | 427 | ||
| 428 | return 1; | ||
| 429 | |||
| 422 | err_out: | 430 | err_out: |
| 423 | return; | 431 | return 0; |
| 424 | } | 432 | } |
| 425 | 433 | ||
| 426 | /* Decode imm v64(Iv/Ov) */ | 434 | /* Decode imm v64(Iv/Ov), Return 0 if failed */ |
| 427 | static void __get_immv(struct insn *insn) | 435 | static int __get_immv(struct insn *insn) |
| 428 | { | 436 | { |
| 429 | switch (insn->opnd_bytes) { | 437 | switch (insn->opnd_bytes) { |
| 430 | case 2: | 438 | case 2: |
| @@ -441,15 +449,18 @@ static void __get_immv(struct insn *insn) | |||
| 441 | insn->immediate2.value = get_next(int, insn); | 449 | insn->immediate2.value = get_next(int, insn); |
| 442 | insn->immediate2.nbytes = 4; | 450 | insn->immediate2.nbytes = 4; |
| 443 | break; | 451 | break; |
| 452 | default: /* opnd_bytes must be modified manually */ | ||
| 453 | goto err_out; | ||
| 444 | } | 454 | } |
| 445 | insn->immediate1.got = insn->immediate2.got = 1; | 455 | insn->immediate1.got = insn->immediate2.got = 1; |
| 446 | 456 | ||
| 457 | return 1; | ||
| 447 | err_out: | 458 | err_out: |
| 448 | return; | 459 | return 0; |
| 449 | } | 460 | } |
| 450 | 461 | ||
| 451 | /* Decode ptr16:16/32(Ap) */ | 462 | /* Decode ptr16:16/32(Ap) */ |
| 452 | static void __get_immptr(struct insn *insn) | 463 | static int __get_immptr(struct insn *insn) |
| 453 | { | 464 | { |
| 454 | switch (insn->opnd_bytes) { | 465 | switch (insn->opnd_bytes) { |
| 455 | case 2: | 466 | case 2: |
| @@ -462,14 +473,17 @@ static void __get_immptr(struct insn *insn) | |||
| 462 | break; | 473 | break; |
| 463 | case 8: | 474 | case 8: |
| 464 | /* ptr16:64 is not exist (no segment) */ | 475 | /* ptr16:64 is not exist (no segment) */ |
| 465 | return; | 476 | return 0; |
| 477 | default: /* opnd_bytes must be modified manually */ | ||
| 478 | goto err_out; | ||
| 466 | } | 479 | } |
| 467 | insn->immediate2.value = get_next(unsigned short, insn); | 480 | insn->immediate2.value = get_next(unsigned short, insn); |
| 468 | insn->immediate2.nbytes = 2; | 481 | insn->immediate2.nbytes = 2; |
| 469 | insn->immediate1.got = insn->immediate2.got = 1; | 482 | insn->immediate1.got = insn->immediate2.got = 1; |
| 470 | 483 | ||
| 484 | return 1; | ||
| 471 | err_out: | 485 | err_out: |
| 472 | return; | 486 | return 0; |
| 473 | } | 487 | } |
| 474 | 488 | ||
| 475 | /** | 489 | /** |
| @@ -489,7 +503,8 @@ void insn_get_immediate(struct insn *insn) | |||
| 489 | insn_get_displacement(insn); | 503 | insn_get_displacement(insn); |
| 490 | 504 | ||
| 491 | if (inat_has_moffset(insn->attr)) { | 505 | if (inat_has_moffset(insn->attr)) { |
| 492 | __get_moffset(insn); | 506 | if (!__get_moffset(insn)) |
| 507 | goto err_out; | ||
| 493 | goto done; | 508 | goto done; |
| 494 | } | 509 | } |
| 495 | 510 | ||
| @@ -517,16 +532,20 @@ void insn_get_immediate(struct insn *insn) | |||
| 517 | insn->immediate2.nbytes = 4; | 532 | insn->immediate2.nbytes = 4; |
| 518 | break; | 533 | break; |
| 519 | case INAT_IMM_PTR: | 534 | case INAT_IMM_PTR: |
| 520 | __get_immptr(insn); | 535 | if (!__get_immptr(insn)) |
| 536 | goto err_out; | ||
| 521 | break; | 537 | break; |
| 522 | case INAT_IMM_VWORD32: | 538 | case INAT_IMM_VWORD32: |
| 523 | __get_immv32(insn); | 539 | if (!__get_immv32(insn)) |
| 540 | goto err_out; | ||
| 524 | break; | 541 | break; |
| 525 | case INAT_IMM_VWORD: | 542 | case INAT_IMM_VWORD: |
| 526 | __get_immv(insn); | 543 | if (!__get_immv(insn)) |
| 544 | goto err_out; | ||
| 527 | break; | 545 | break; |
| 528 | default: | 546 | default: |
| 529 | break; | 547 | /* Here, insn must have an immediate, but failed */ |
| 548 | goto err_out; | ||
| 530 | } | 549 | } |
| 531 | if (inat_has_second_immediate(insn->attr)) { | 550 | if (inat_has_second_immediate(insn->attr)) { |
| 532 | insn->immediate2.value = get_next(char, insn); | 551 | insn->immediate2.value = get_next(char, insn); |
diff --git a/arch/x86/lib/usercopy.c b/arch/x86/lib/usercopy.c index 57252c928f56..d6ae30bbd7bb 100644 --- a/arch/x86/lib/usercopy.c +++ b/arch/x86/lib/usercopy.c | |||
| @@ -57,7 +57,7 @@ static inline unsigned long count_bytes(unsigned long mask) | |||
| 57 | * hit it), 'max' is the address space maximum (and we return | 57 | * hit it), 'max' is the address space maximum (and we return |
| 58 | * -EFAULT if we hit it). | 58 | * -EFAULT if we hit it). |
| 59 | */ | 59 | */ |
| 60 | static inline long do_strncpy_from_user(char *dst, const char __user *src, long count, long max) | 60 | static inline long do_strncpy_from_user(char *dst, const char __user *src, long count, unsigned long max) |
| 61 | { | 61 | { |
| 62 | long res = 0; | 62 | long res = 0; |
| 63 | 63 | ||
| @@ -100,7 +100,7 @@ static inline long do_strncpy_from_user(char *dst, const char __user *src, long | |||
| 100 | * too? If so, that's ok - we got as much as the user asked for. | 100 | * too? If so, that's ok - we got as much as the user asked for. |
| 101 | */ | 101 | */ |
| 102 | if (res >= count) | 102 | if (res >= count) |
| 103 | return count; | 103 | return res; |
| 104 | 104 | ||
| 105 | /* | 105 | /* |
| 106 | * Nope: we hit the address space limit, and we still had more | 106 | * Nope: we hit the address space limit, and we still had more |
diff --git a/block/blk-core.c b/block/blk-core.c index 3a78b00edd71..1f61b74867e4 100644 --- a/block/blk-core.c +++ b/block/blk-core.c | |||
| @@ -483,7 +483,7 @@ struct request_queue *blk_alloc_queue_node(gfp_t gfp_mask, int node_id) | |||
| 483 | if (!q) | 483 | if (!q) |
| 484 | return NULL; | 484 | return NULL; |
| 485 | 485 | ||
| 486 | q->id = ida_simple_get(&blk_queue_ida, 0, 0, GFP_KERNEL); | 486 | q->id = ida_simple_get(&blk_queue_ida, 0, 0, gfp_mask); |
| 487 | if (q->id < 0) | 487 | if (q->id < 0) |
| 488 | goto fail_q; | 488 | goto fail_q; |
| 489 | 489 | ||
| @@ -1277,7 +1277,8 @@ static bool attempt_plug_merge(struct request_queue *q, struct bio *bio, | |||
| 1277 | list_for_each_entry_reverse(rq, &plug->list, queuelist) { | 1277 | list_for_each_entry_reverse(rq, &plug->list, queuelist) { |
| 1278 | int el_ret; | 1278 | int el_ret; |
| 1279 | 1279 | ||
| 1280 | (*request_count)++; | 1280 | if (rq->q == q) |
| 1281 | (*request_count)++; | ||
| 1281 | 1282 | ||
| 1282 | if (rq->q != q || !blk_rq_merge_ok(rq, bio)) | 1283 | if (rq->q != q || !blk_rq_merge_ok(rq, bio)) |
| 1283 | continue; | 1284 | continue; |
diff --git a/block/blk-throttle.c b/block/blk-throttle.c index 5eed6a76721d..f2ddb94626bd 100644 --- a/block/blk-throttle.c +++ b/block/blk-throttle.c | |||
| @@ -1218,7 +1218,7 @@ void blk_throtl_drain(struct request_queue *q) | |||
| 1218 | struct bio_list bl; | 1218 | struct bio_list bl; |
| 1219 | struct bio *bio; | 1219 | struct bio *bio; |
| 1220 | 1220 | ||
| 1221 | WARN_ON_ONCE(!queue_is_locked(q)); | 1221 | queue_lockdep_assert_held(q); |
| 1222 | 1222 | ||
| 1223 | bio_list_init(&bl); | 1223 | bio_list_init(&bl); |
| 1224 | 1224 | ||
diff --git a/block/cfq-iosched.c b/block/cfq-iosched.c index 457295253566..3c38536bd52c 100644 --- a/block/cfq-iosched.c +++ b/block/cfq-iosched.c | |||
| @@ -295,6 +295,7 @@ struct cfq_data { | |||
| 295 | unsigned int cfq_slice_idle; | 295 | unsigned int cfq_slice_idle; |
| 296 | unsigned int cfq_group_idle; | 296 | unsigned int cfq_group_idle; |
| 297 | unsigned int cfq_latency; | 297 | unsigned int cfq_latency; |
| 298 | unsigned int cfq_target_latency; | ||
| 298 | 299 | ||
| 299 | /* | 300 | /* |
| 300 | * Fallback dummy cfqq for extreme OOM conditions | 301 | * Fallback dummy cfqq for extreme OOM conditions |
| @@ -604,7 +605,7 @@ cfq_group_slice(struct cfq_data *cfqd, struct cfq_group *cfqg) | |||
| 604 | { | 605 | { |
| 605 | struct cfq_rb_root *st = &cfqd->grp_service_tree; | 606 | struct cfq_rb_root *st = &cfqd->grp_service_tree; |
| 606 | 607 | ||
| 607 | return cfq_target_latency * cfqg->weight / st->total_weight; | 608 | return cfqd->cfq_target_latency * cfqg->weight / st->total_weight; |
| 608 | } | 609 | } |
| 609 | 610 | ||
| 610 | static inline unsigned | 611 | static inline unsigned |
| @@ -2271,7 +2272,8 @@ new_workload: | |||
| 2271 | * to have higher weight. A more accurate thing would be to | 2272 | * to have higher weight. A more accurate thing would be to |
| 2272 | * calculate system wide asnc/sync ratio. | 2273 | * calculate system wide asnc/sync ratio. |
| 2273 | */ | 2274 | */ |
| 2274 | tmp = cfq_target_latency * cfqg_busy_async_queues(cfqd, cfqg); | 2275 | tmp = cfqd->cfq_target_latency * |
| 2276 | cfqg_busy_async_queues(cfqd, cfqg); | ||
| 2275 | tmp = tmp/cfqd->busy_queues; | 2277 | tmp = tmp/cfqd->busy_queues; |
| 2276 | slice = min_t(unsigned, slice, tmp); | 2278 | slice = min_t(unsigned, slice, tmp); |
| 2277 | 2279 | ||
| @@ -3737,6 +3739,7 @@ static void *cfq_init_queue(struct request_queue *q) | |||
| 3737 | cfqd->cfq_back_penalty = cfq_back_penalty; | 3739 | cfqd->cfq_back_penalty = cfq_back_penalty; |
| 3738 | cfqd->cfq_slice[0] = cfq_slice_async; | 3740 | cfqd->cfq_slice[0] = cfq_slice_async; |
| 3739 | cfqd->cfq_slice[1] = cfq_slice_sync; | 3741 | cfqd->cfq_slice[1] = cfq_slice_sync; |
| 3742 | cfqd->cfq_target_latency = cfq_target_latency; | ||
| 3740 | cfqd->cfq_slice_async_rq = cfq_slice_async_rq; | 3743 | cfqd->cfq_slice_async_rq = cfq_slice_async_rq; |
| 3741 | cfqd->cfq_slice_idle = cfq_slice_idle; | 3744 | cfqd->cfq_slice_idle = cfq_slice_idle; |
| 3742 | cfqd->cfq_group_idle = cfq_group_idle; | 3745 | cfqd->cfq_group_idle = cfq_group_idle; |
| @@ -3788,6 +3791,7 @@ SHOW_FUNCTION(cfq_slice_sync_show, cfqd->cfq_slice[1], 1); | |||
| 3788 | SHOW_FUNCTION(cfq_slice_async_show, cfqd->cfq_slice[0], 1); | 3791 | SHOW_FUNCTION(cfq_slice_async_show, cfqd->cfq_slice[0], 1); |
| 3789 | SHOW_FUNCTION(cfq_slice_async_rq_show, cfqd->cfq_slice_async_rq, 0); | 3792 | SHOW_FUNCTION(cfq_slice_async_rq_show, cfqd->cfq_slice_async_rq, 0); |
| 3790 | SHOW_FUNCTION(cfq_low_latency_show, cfqd->cfq_latency, 0); | 3793 | SHOW_FUNCTION(cfq_low_latency_show, cfqd->cfq_latency, 0); |
| 3794 | SHOW_FUNCTION(cfq_target_latency_show, cfqd->cfq_target_latency, 1); | ||
| 3791 | #undef SHOW_FUNCTION | 3795 | #undef SHOW_FUNCTION |
| 3792 | 3796 | ||
| 3793 | #define STORE_FUNCTION(__FUNC, __PTR, MIN, MAX, __CONV) \ | 3797 | #define STORE_FUNCTION(__FUNC, __PTR, MIN, MAX, __CONV) \ |
| @@ -3821,6 +3825,7 @@ STORE_FUNCTION(cfq_slice_async_store, &cfqd->cfq_slice[0], 1, UINT_MAX, 1); | |||
| 3821 | STORE_FUNCTION(cfq_slice_async_rq_store, &cfqd->cfq_slice_async_rq, 1, | 3825 | STORE_FUNCTION(cfq_slice_async_rq_store, &cfqd->cfq_slice_async_rq, 1, |
| 3822 | UINT_MAX, 0); | 3826 | UINT_MAX, 0); |
| 3823 | STORE_FUNCTION(cfq_low_latency_store, &cfqd->cfq_latency, 0, 1, 0); | 3827 | STORE_FUNCTION(cfq_low_latency_store, &cfqd->cfq_latency, 0, 1, 0); |
| 3828 | STORE_FUNCTION(cfq_target_latency_store, &cfqd->cfq_target_latency, 1, UINT_MAX, 1); | ||
| 3824 | #undef STORE_FUNCTION | 3829 | #undef STORE_FUNCTION |
| 3825 | 3830 | ||
| 3826 | #define CFQ_ATTR(name) \ | 3831 | #define CFQ_ATTR(name) \ |
| @@ -3838,6 +3843,7 @@ static struct elv_fs_entry cfq_attrs[] = { | |||
| 3838 | CFQ_ATTR(slice_idle), | 3843 | CFQ_ATTR(slice_idle), |
| 3839 | CFQ_ATTR(group_idle), | 3844 | CFQ_ATTR(group_idle), |
| 3840 | CFQ_ATTR(low_latency), | 3845 | CFQ_ATTR(low_latency), |
| 3846 | CFQ_ATTR(target_latency), | ||
| 3841 | __ATTR_NULL | 3847 | __ATTR_NULL |
| 3842 | }; | 3848 | }; |
| 3843 | 3849 | ||
diff --git a/crypto/sha512_generic.c b/crypto/sha512_generic.c index 107f6f7be5e1..dd30f40af9f5 100644 --- a/crypto/sha512_generic.c +++ b/crypto/sha512_generic.c | |||
| @@ -174,7 +174,7 @@ sha512_update(struct shash_desc *desc, const u8 *data, unsigned int len) | |||
| 174 | index = sctx->count[0] & 0x7f; | 174 | index = sctx->count[0] & 0x7f; |
| 175 | 175 | ||
| 176 | /* Update number of bytes */ | 176 | /* Update number of bytes */ |
| 177 | if (!(sctx->count[0] += len)) | 177 | if ((sctx->count[0] += len) < len) |
| 178 | sctx->count[1]++; | 178 | sctx->count[1]++; |
| 179 | 179 | ||
| 180 | part_len = 128 - index; | 180 | part_len = 128 - index; |
diff --git a/drivers/acpi/acpica/hwxface.c b/drivers/acpi/acpica/hwxface.c index ab513a972c95..a716fede4f25 100644 --- a/drivers/acpi/acpica/hwxface.c +++ b/drivers/acpi/acpica/hwxface.c | |||
| @@ -74,7 +74,8 @@ acpi_status acpi_reset(void) | |||
| 74 | 74 | ||
| 75 | /* Check if the reset register is supported */ | 75 | /* Check if the reset register is supported */ |
| 76 | 76 | ||
| 77 | if (!reset_reg->address) { | 77 | if (!(acpi_gbl_FADT.flags & ACPI_FADT_RESET_REGISTER) || |
| 78 | !reset_reg->address) { | ||
| 78 | return_ACPI_STATUS(AE_NOT_EXIST); | 79 | return_ACPI_STATUS(AE_NOT_EXIST); |
| 79 | } | 80 | } |
| 80 | 81 | ||
diff --git a/drivers/acpi/osl.c b/drivers/acpi/osl.c index ba14fb93c929..c3881b2eb8b2 100644 --- a/drivers/acpi/osl.c +++ b/drivers/acpi/osl.c | |||
| @@ -607,8 +607,7 @@ acpi_os_install_interrupt_handler(u32 gsi, acpi_osd_handler handler, | |||
| 607 | 607 | ||
| 608 | acpi_irq_handler = handler; | 608 | acpi_irq_handler = handler; |
| 609 | acpi_irq_context = context; | 609 | acpi_irq_context = context; |
| 610 | if (request_threaded_irq(irq, NULL, acpi_irq, IRQF_SHARED, "acpi", | 610 | if (request_irq(irq, acpi_irq, IRQF_SHARED, "acpi", acpi_irq)) { |
| 611 | acpi_irq)) { | ||
| 612 | printk(KERN_ERR PREFIX "SCI (IRQ%d) allocation failed\n", irq); | 611 | printk(KERN_ERR PREFIX "SCI (IRQ%d) allocation failed\n", irq); |
| 613 | acpi_irq_handler = NULL; | 612 | acpi_irq_handler = NULL; |
| 614 | return AE_NOT_ACQUIRED; | 613 | return AE_NOT_ACQUIRED; |
diff --git a/drivers/acpi/reboot.c b/drivers/acpi/reboot.c index c1d612435939..a6c77e8b37bd 100644 --- a/drivers/acpi/reboot.c +++ b/drivers/acpi/reboot.c | |||
| @@ -23,7 +23,8 @@ void acpi_reboot(void) | |||
| 23 | /* Is the reset register supported? The spec says we should be | 23 | /* Is the reset register supported? The spec says we should be |
| 24 | * checking the bit width and bit offset, but Windows ignores | 24 | * checking the bit width and bit offset, but Windows ignores |
| 25 | * these fields */ | 25 | * these fields */ |
| 26 | /* Ignore also acpi_gbl_FADT.flags.ACPI_FADT_RESET_REGISTER */ | 26 | if (!(acpi_gbl_FADT.flags & ACPI_FADT_RESET_REGISTER)) |
| 27 | return; | ||
| 27 | 28 | ||
| 28 | reset_value = acpi_gbl_FADT.reset_value; | 29 | reset_value = acpi_gbl_FADT.reset_value; |
| 29 | 30 | ||
diff --git a/drivers/amba/bus.c b/drivers/amba/bus.c index 01c2cf4efcdd..cc273226dbd0 100644 --- a/drivers/amba/bus.c +++ b/drivers/amba/bus.c | |||
| @@ -247,8 +247,7 @@ static int amba_pm_restore(struct device *dev) | |||
| 247 | /* | 247 | /* |
| 248 | * Hooks to provide runtime PM of the pclk (bus clock). It is safe to | 248 | * Hooks to provide runtime PM of the pclk (bus clock). It is safe to |
| 249 | * enable/disable the bus clock at runtime PM suspend/resume as this | 249 | * enable/disable the bus clock at runtime PM suspend/resume as this |
| 250 | * does not result in loss of context. However, disabling vcore power | 250 | * does not result in loss of context. |
| 251 | * would do, so we leave that to the driver. | ||
| 252 | */ | 251 | */ |
| 253 | static int amba_pm_runtime_suspend(struct device *dev) | 252 | static int amba_pm_runtime_suspend(struct device *dev) |
| 254 | { | 253 | { |
| @@ -354,39 +353,6 @@ static void amba_put_disable_pclk(struct amba_device *pcdev) | |||
| 354 | clk_put(pclk); | 353 | clk_put(pclk); |
| 355 | } | 354 | } |
| 356 | 355 | ||
| 357 | static int amba_get_enable_vcore(struct amba_device *pcdev) | ||
| 358 | { | ||
| 359 | struct regulator *vcore = regulator_get(&pcdev->dev, "vcore"); | ||
| 360 | int ret; | ||
| 361 | |||
| 362 | pcdev->vcore = vcore; | ||
| 363 | |||
| 364 | if (IS_ERR(vcore)) { | ||
| 365 | /* It is OK not to supply a vcore regulator */ | ||
| 366 | if (PTR_ERR(vcore) == -ENODEV) | ||
| 367 | return 0; | ||
| 368 | return PTR_ERR(vcore); | ||
| 369 | } | ||
| 370 | |||
| 371 | ret = regulator_enable(vcore); | ||
| 372 | if (ret) { | ||
| 373 | regulator_put(vcore); | ||
| 374 | pcdev->vcore = ERR_PTR(-ENODEV); | ||
| 375 | } | ||
| 376 | |||
| 377 | return ret; | ||
| 378 | } | ||
| 379 | |||
| 380 | static void amba_put_disable_vcore(struct amba_device *pcdev) | ||
| 381 | { | ||
| 382 | struct regulator *vcore = pcdev->vcore; | ||
| 383 | |||
| 384 | if (!IS_ERR(vcore)) { | ||
| 385 | regulator_disable(vcore); | ||
| 386 | regulator_put(vcore); | ||
| 387 | } | ||
| 388 | } | ||
| 389 | |||
| 390 | /* | 356 | /* |
| 391 | * These are the device model conversion veneers; they convert the | 357 | * These are the device model conversion veneers; they convert the |
| 392 | * device model structures to our more specific structures. | 358 | * device model structures to our more specific structures. |
| @@ -399,10 +365,6 @@ static int amba_probe(struct device *dev) | |||
| 399 | int ret; | 365 | int ret; |
| 400 | 366 | ||
| 401 | do { | 367 | do { |
| 402 | ret = amba_get_enable_vcore(pcdev); | ||
| 403 | if (ret) | ||
| 404 | break; | ||
| 405 | |||
| 406 | ret = amba_get_enable_pclk(pcdev); | 368 | ret = amba_get_enable_pclk(pcdev); |
| 407 | if (ret) | 369 | if (ret) |
| 408 | break; | 370 | break; |
| @@ -420,7 +382,6 @@ static int amba_probe(struct device *dev) | |||
| 420 | pm_runtime_put_noidle(dev); | 382 | pm_runtime_put_noidle(dev); |
| 421 | 383 | ||
| 422 | amba_put_disable_pclk(pcdev); | 384 | amba_put_disable_pclk(pcdev); |
| 423 | amba_put_disable_vcore(pcdev); | ||
| 424 | } while (0); | 385 | } while (0); |
| 425 | 386 | ||
| 426 | return ret; | 387 | return ret; |
| @@ -442,7 +403,6 @@ static int amba_remove(struct device *dev) | |||
| 442 | pm_runtime_put_noidle(dev); | 403 | pm_runtime_put_noidle(dev); |
| 443 | 404 | ||
| 444 | amba_put_disable_pclk(pcdev); | 405 | amba_put_disable_pclk(pcdev); |
| 445 | amba_put_disable_vcore(pcdev); | ||
| 446 | 406 | ||
| 447 | return ret; | 407 | return ret; |
| 448 | } | 408 | } |
diff --git a/drivers/ata/ata_piix.c b/drivers/ata/ata_piix.c index 68013f96729f..7857e8fd0a3e 100644 --- a/drivers/ata/ata_piix.c +++ b/drivers/ata/ata_piix.c | |||
| @@ -329,6 +329,8 @@ static const struct pci_device_id piix_pci_tbl[] = { | |||
| 329 | { 0x8086, 0x8c08, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_2port_sata }, | 329 | { 0x8086, 0x8c08, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_2port_sata }, |
| 330 | /* SATA Controller IDE (Lynx Point) */ | 330 | /* SATA Controller IDE (Lynx Point) */ |
| 331 | { 0x8086, 0x8c09, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_2port_sata }, | 331 | { 0x8086, 0x8c09, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_2port_sata }, |
| 332 | /* SATA Controller IDE (DH89xxCC) */ | ||
| 333 | { 0x8086, 0x2326, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_2port_sata }, | ||
| 332 | { } /* terminate list */ | 334 | { } /* terminate list */ |
| 333 | }; | 335 | }; |
| 334 | 336 | ||
diff --git a/drivers/ata/libata-core.c b/drivers/ata/libata-core.c index e0bda9ff89cd..28db50b57b91 100644 --- a/drivers/ata/libata-core.c +++ b/drivers/ata/libata-core.c | |||
| @@ -95,7 +95,7 @@ static unsigned int ata_dev_set_xfermode(struct ata_device *dev); | |||
| 95 | static void ata_dev_xfermask(struct ata_device *dev); | 95 | static void ata_dev_xfermask(struct ata_device *dev); |
| 96 | static unsigned long ata_dev_blacklisted(const struct ata_device *dev); | 96 | static unsigned long ata_dev_blacklisted(const struct ata_device *dev); |
| 97 | 97 | ||
| 98 | unsigned int ata_print_id = 1; | 98 | atomic_t ata_print_id = ATOMIC_INIT(1); |
| 99 | 99 | ||
| 100 | struct ata_force_param { | 100 | struct ata_force_param { |
| 101 | const char *name; | 101 | const char *name; |
| @@ -6029,7 +6029,7 @@ int ata_host_register(struct ata_host *host, struct scsi_host_template *sht) | |||
| 6029 | 6029 | ||
| 6030 | /* give ports names and add SCSI hosts */ | 6030 | /* give ports names and add SCSI hosts */ |
| 6031 | for (i = 0; i < host->n_ports; i++) | 6031 | for (i = 0; i < host->n_ports; i++) |
| 6032 | host->ports[i]->print_id = ata_print_id++; | 6032 | host->ports[i]->print_id = atomic_inc_return(&ata_print_id); |
| 6033 | 6033 | ||
| 6034 | 6034 | ||
| 6035 | /* Create associated sysfs transport objects */ | 6035 | /* Create associated sysfs transport objects */ |
diff --git a/drivers/ata/libata-scsi.c b/drivers/ata/libata-scsi.c index 1ee00c8b5b04..93dabdcd2cbe 100644 --- a/drivers/ata/libata-scsi.c +++ b/drivers/ata/libata-scsi.c | |||
| @@ -3843,7 +3843,7 @@ int ata_sas_async_port_init(struct ata_port *ap) | |||
| 3843 | int rc = ap->ops->port_start(ap); | 3843 | int rc = ap->ops->port_start(ap); |
| 3844 | 3844 | ||
| 3845 | if (!rc) { | 3845 | if (!rc) { |
| 3846 | ap->print_id = ata_print_id++; | 3846 | ap->print_id = atomic_inc_return(&ata_print_id); |
| 3847 | __ata_port_probe(ap); | 3847 | __ata_port_probe(ap); |
| 3848 | } | 3848 | } |
| 3849 | 3849 | ||
| @@ -3867,7 +3867,7 @@ int ata_sas_port_init(struct ata_port *ap) | |||
| 3867 | int rc = ap->ops->port_start(ap); | 3867 | int rc = ap->ops->port_start(ap); |
| 3868 | 3868 | ||
| 3869 | if (!rc) { | 3869 | if (!rc) { |
| 3870 | ap->print_id = ata_print_id++; | 3870 | ap->print_id = atomic_inc_return(&ata_print_id); |
| 3871 | rc = ata_port_probe(ap); | 3871 | rc = ata_port_probe(ap); |
| 3872 | } | 3872 | } |
| 3873 | 3873 | ||
diff --git a/drivers/ata/libata-transport.c b/drivers/ata/libata-transport.c index 74aaee30e264..c34190485377 100644 --- a/drivers/ata/libata-transport.c +++ b/drivers/ata/libata-transport.c | |||
| @@ -294,6 +294,7 @@ int ata_tport_add(struct device *parent, | |||
| 294 | device_enable_async_suspend(dev); | 294 | device_enable_async_suspend(dev); |
| 295 | pm_runtime_set_active(dev); | 295 | pm_runtime_set_active(dev); |
| 296 | pm_runtime_enable(dev); | 296 | pm_runtime_enable(dev); |
| 297 | pm_runtime_forbid(dev); | ||
| 297 | 298 | ||
| 298 | transport_add_device(dev); | 299 | transport_add_device(dev); |
| 299 | transport_configure_device(dev); | 300 | transport_configure_device(dev); |
diff --git a/drivers/ata/libata.h b/drivers/ata/libata.h index 2e26fcaf635b..9d0fd0b71852 100644 --- a/drivers/ata/libata.h +++ b/drivers/ata/libata.h | |||
| @@ -53,7 +53,7 @@ enum { | |||
| 53 | ATA_DNXFER_QUIET = (1 << 31), | 53 | ATA_DNXFER_QUIET = (1 << 31), |
| 54 | }; | 54 | }; |
| 55 | 55 | ||
| 56 | extern unsigned int ata_print_id; | 56 | extern atomic_t ata_print_id; |
| 57 | extern int atapi_passthru16; | 57 | extern int atapi_passthru16; |
| 58 | extern int libata_fua; | 58 | extern int libata_fua; |
| 59 | extern int libata_noacpi; | 59 | extern int libata_noacpi; |
diff --git a/drivers/ata/sata_mv.c b/drivers/ata/sata_mv.c index 38950ea8398a..7336d4a7ab31 100644 --- a/drivers/ata/sata_mv.c +++ b/drivers/ata/sata_mv.c | |||
| @@ -4025,7 +4025,8 @@ static int mv_platform_probe(struct platform_device *pdev) | |||
| 4025 | struct ata_host *host; | 4025 | struct ata_host *host; |
| 4026 | struct mv_host_priv *hpriv; | 4026 | struct mv_host_priv *hpriv; |
| 4027 | struct resource *res; | 4027 | struct resource *res; |
| 4028 | int n_ports, rc; | 4028 | int n_ports = 0; |
| 4029 | int rc; | ||
| 4029 | 4030 | ||
| 4030 | ata_print_version_once(&pdev->dev, DRV_VERSION); | 4031 | ata_print_version_once(&pdev->dev, DRV_VERSION); |
| 4031 | 4032 | ||
diff --git a/drivers/base/soc.c b/drivers/base/soc.c index 05f150382da8..ba29b2e73d48 100644 --- a/drivers/base/soc.c +++ b/drivers/base/soc.c | |||
| @@ -15,7 +15,7 @@ | |||
| 15 | #include <linux/sys_soc.h> | 15 | #include <linux/sys_soc.h> |
| 16 | #include <linux/err.h> | 16 | #include <linux/err.h> |
| 17 | 17 | ||
| 18 | static DEFINE_IDR(soc_ida); | 18 | static DEFINE_IDA(soc_ida); |
| 19 | static DEFINE_SPINLOCK(soc_lock); | 19 | static DEFINE_SPINLOCK(soc_lock); |
| 20 | 20 | ||
| 21 | static ssize_t soc_info_get(struct device *dev, | 21 | static ssize_t soc_info_get(struct device *dev, |
| @@ -168,8 +168,6 @@ void soc_device_unregister(struct soc_device *soc_dev) | |||
| 168 | 168 | ||
| 169 | static int __init soc_bus_register(void) | 169 | static int __init soc_bus_register(void) |
| 170 | { | 170 | { |
| 171 | spin_lock_init(&soc_lock); | ||
| 172 | |||
| 173 | return bus_register(&soc_bus_type); | 171 | return bus_register(&soc_bus_type); |
| 174 | } | 172 | } |
| 175 | core_initcall(soc_bus_register); | 173 | core_initcall(soc_bus_register); |
diff --git a/drivers/bcma/sprom.c b/drivers/bcma/sprom.c index cdcf75c0954f..3e2a6002aae6 100644 --- a/drivers/bcma/sprom.c +++ b/drivers/bcma/sprom.c | |||
| @@ -404,16 +404,19 @@ int bcma_sprom_get(struct bcma_bus *bus) | |||
| 404 | return -EOPNOTSUPP; | 404 | return -EOPNOTSUPP; |
| 405 | 405 | ||
| 406 | if (!bcma_sprom_ext_available(bus)) { | 406 | if (!bcma_sprom_ext_available(bus)) { |
| 407 | bool sprom_onchip; | ||
| 408 | |||
| 407 | /* | 409 | /* |
| 408 | * External SPROM takes precedence so check | 410 | * External SPROM takes precedence so check |
| 409 | * on-chip OTP only when no external SPROM | 411 | * on-chip OTP only when no external SPROM |
| 410 | * is present. | 412 | * is present. |
| 411 | */ | 413 | */ |
| 412 | if (bcma_sprom_onchip_available(bus)) { | 414 | sprom_onchip = bcma_sprom_onchip_available(bus); |
| 415 | if (sprom_onchip) { | ||
| 413 | /* determine offset */ | 416 | /* determine offset */ |
| 414 | offset = bcma_sprom_onchip_offset(bus); | 417 | offset = bcma_sprom_onchip_offset(bus); |
| 415 | } | 418 | } |
| 416 | if (!offset) { | 419 | if (!offset || !sprom_onchip) { |
| 417 | /* | 420 | /* |
| 418 | * Maybe there is no SPROM on the device? | 421 | * Maybe there is no SPROM on the device? |
| 419 | * Now we ask the arch code if there is some sprom | 422 | * Now we ask the arch code if there is some sprom |
diff --git a/drivers/block/cciss_scsi.c b/drivers/block/cciss_scsi.c index e820b68d2f6c..acda773b3720 100644 --- a/drivers/block/cciss_scsi.c +++ b/drivers/block/cciss_scsi.c | |||
| @@ -866,6 +866,7 @@ cciss_scsi_detect(ctlr_info_t *h) | |||
| 866 | sh->can_queue = cciss_tape_cmds; | 866 | sh->can_queue = cciss_tape_cmds; |
| 867 | sh->sg_tablesize = h->maxsgentries; | 867 | sh->sg_tablesize = h->maxsgentries; |
| 868 | sh->max_cmd_len = MAX_COMMAND_SIZE; | 868 | sh->max_cmd_len = MAX_COMMAND_SIZE; |
| 869 | sh->max_sectors = h->cciss_max_sectors; | ||
| 869 | 870 | ||
| 870 | ((struct cciss_scsi_adapter_data_t *) | 871 | ((struct cciss_scsi_adapter_data_t *) |
| 871 | h->scsi_ctlr)->scsi_host = sh; | 872 | h->scsi_ctlr)->scsi_host = sh; |
| @@ -1410,7 +1411,7 @@ static void cciss_scatter_gather(ctlr_info_t *h, CommandList_struct *c, | |||
| 1410 | /* track how many SG entries we are using */ | 1411 | /* track how many SG entries we are using */ |
| 1411 | if (request_nsgs > h->maxSG) | 1412 | if (request_nsgs > h->maxSG) |
| 1412 | h->maxSG = request_nsgs; | 1413 | h->maxSG = request_nsgs; |
| 1413 | c->Header.SGTotal = (__u8) request_nsgs + chained; | 1414 | c->Header.SGTotal = (u16) request_nsgs + chained; |
| 1414 | if (request_nsgs > h->max_cmd_sgentries) | 1415 | if (request_nsgs > h->max_cmd_sgentries) |
| 1415 | c->Header.SGList = h->max_cmd_sgentries; | 1416 | c->Header.SGList = h->max_cmd_sgentries; |
| 1416 | else | 1417 | else |
diff --git a/drivers/block/mtip32xx/Kconfig b/drivers/block/mtip32xx/Kconfig index b5dd14e072f2..0ba837fc62a8 100644 --- a/drivers/block/mtip32xx/Kconfig +++ b/drivers/block/mtip32xx/Kconfig | |||
| @@ -4,6 +4,6 @@ | |||
| 4 | 4 | ||
| 5 | config BLK_DEV_PCIESSD_MTIP32XX | 5 | config BLK_DEV_PCIESSD_MTIP32XX |
| 6 | tristate "Block Device Driver for Micron PCIe SSDs" | 6 | tristate "Block Device Driver for Micron PCIe SSDs" |
| 7 | depends on HOTPLUG_PCI_PCIE | 7 | depends on PCI |
| 8 | help | 8 | help |
| 9 | This enables the block driver for Micron PCIe SSDs. | 9 | This enables the block driver for Micron PCIe SSDs. |
diff --git a/drivers/block/mtip32xx/mtip32xx.c b/drivers/block/mtip32xx/mtip32xx.c index 8eb81c96608f..00f9fc992090 100644 --- a/drivers/block/mtip32xx/mtip32xx.c +++ b/drivers/block/mtip32xx/mtip32xx.c | |||
| @@ -36,6 +36,7 @@ | |||
| 36 | #include <linux/idr.h> | 36 | #include <linux/idr.h> |
| 37 | #include <linux/kthread.h> | 37 | #include <linux/kthread.h> |
| 38 | #include <../drivers/ata/ahci.h> | 38 | #include <../drivers/ata/ahci.h> |
| 39 | #include <linux/export.h> | ||
| 39 | #include "mtip32xx.h" | 40 | #include "mtip32xx.h" |
| 40 | 41 | ||
| 41 | #define HW_CMD_SLOT_SZ (MTIP_MAX_COMMAND_SLOTS * 32) | 42 | #define HW_CMD_SLOT_SZ (MTIP_MAX_COMMAND_SLOTS * 32) |
| @@ -44,6 +45,7 @@ | |||
| 44 | #define HW_PORT_PRIV_DMA_SZ \ | 45 | #define HW_PORT_PRIV_DMA_SZ \ |
| 45 | (HW_CMD_SLOT_SZ + HW_CMD_TBL_AR_SZ + AHCI_RX_FIS_SZ) | 46 | (HW_CMD_SLOT_SZ + HW_CMD_TBL_AR_SZ + AHCI_RX_FIS_SZ) |
| 46 | 47 | ||
| 48 | #define HOST_CAP_NZDMA (1 << 19) | ||
| 47 | #define HOST_HSORG 0xFC | 49 | #define HOST_HSORG 0xFC |
| 48 | #define HSORG_DISABLE_SLOTGRP_INTR (1<<24) | 50 | #define HSORG_DISABLE_SLOTGRP_INTR (1<<24) |
| 49 | #define HSORG_DISABLE_SLOTGRP_PXIS (1<<16) | 51 | #define HSORG_DISABLE_SLOTGRP_PXIS (1<<16) |
| @@ -139,6 +141,12 @@ static void mtip_command_cleanup(struct driver_data *dd) | |||
| 139 | int group = 0, commandslot = 0, commandindex = 0; | 141 | int group = 0, commandslot = 0, commandindex = 0; |
| 140 | struct mtip_cmd *command; | 142 | struct mtip_cmd *command; |
| 141 | struct mtip_port *port = dd->port; | 143 | struct mtip_port *port = dd->port; |
| 144 | static int in_progress; | ||
| 145 | |||
| 146 | if (in_progress) | ||
| 147 | return; | ||
| 148 | |||
| 149 | in_progress = 1; | ||
| 142 | 150 | ||
| 143 | for (group = 0; group < 4; group++) { | 151 | for (group = 0; group < 4; group++) { |
| 144 | for (commandslot = 0; commandslot < 32; commandslot++) { | 152 | for (commandslot = 0; commandslot < 32; commandslot++) { |
| @@ -165,7 +173,8 @@ static void mtip_command_cleanup(struct driver_data *dd) | |||
| 165 | 173 | ||
| 166 | up(&port->cmd_slot); | 174 | up(&port->cmd_slot); |
| 167 | 175 | ||
| 168 | atomic_set(&dd->drv_cleanup_done, true); | 176 | set_bit(MTIP_DDF_CLEANUP_BIT, &dd->dd_flag); |
| 177 | in_progress = 0; | ||
| 169 | } | 178 | } |
| 170 | 179 | ||
| 171 | /* | 180 | /* |
| @@ -262,6 +271,9 @@ static int hba_reset_nosleep(struct driver_data *dd) | |||
| 262 | && time_before(jiffies, timeout)) | 271 | && time_before(jiffies, timeout)) |
| 263 | mdelay(1); | 272 | mdelay(1); |
| 264 | 273 | ||
| 274 | if (test_bit(MTIP_DDF_REMOVE_PENDING_BIT, &dd->dd_flag)) | ||
| 275 | return -1; | ||
| 276 | |||
| 265 | if (readl(dd->mmio + HOST_CTL) & HOST_RESET) | 277 | if (readl(dd->mmio + HOST_CTL) & HOST_RESET) |
| 266 | return -1; | 278 | return -1; |
| 267 | 279 | ||
| @@ -294,6 +306,10 @@ static inline void mtip_issue_ncq_command(struct mtip_port *port, int tag) | |||
| 294 | port->cmd_issue[MTIP_TAG_INDEX(tag)]); | 306 | port->cmd_issue[MTIP_TAG_INDEX(tag)]); |
| 295 | 307 | ||
| 296 | spin_unlock_irqrestore(&port->cmd_issue_lock, flags); | 308 | spin_unlock_irqrestore(&port->cmd_issue_lock, flags); |
| 309 | |||
| 310 | /* Set the command's timeout value.*/ | ||
| 311 | port->commands[tag].comp_time = jiffies + msecs_to_jiffies( | ||
| 312 | MTIP_NCQ_COMMAND_TIMEOUT_MS); | ||
| 297 | } | 313 | } |
| 298 | 314 | ||
| 299 | /* | 315 | /* |
| @@ -420,7 +436,12 @@ static void mtip_init_port(struct mtip_port *port) | |||
| 420 | writel(0xFFFFFFFF, port->completed[i]); | 436 | writel(0xFFFFFFFF, port->completed[i]); |
| 421 | 437 | ||
| 422 | /* Clear any pending interrupts for this port */ | 438 | /* Clear any pending interrupts for this port */ |
| 423 | writel(readl(port->mmio + PORT_IRQ_STAT), port->mmio + PORT_IRQ_STAT); | 439 | writel(readl(port->dd->mmio + PORT_IRQ_STAT), |
| 440 | port->dd->mmio + PORT_IRQ_STAT); | ||
| 441 | |||
| 442 | /* Clear any pending interrupts on the HBA. */ | ||
| 443 | writel(readl(port->dd->mmio + HOST_IRQ_STAT), | ||
| 444 | port->dd->mmio + HOST_IRQ_STAT); | ||
| 424 | 445 | ||
| 425 | /* Enable port interrupts */ | 446 | /* Enable port interrupts */ |
| 426 | writel(DEF_PORT_IRQ, port->mmio + PORT_IRQ_MASK); | 447 | writel(DEF_PORT_IRQ, port->mmio + PORT_IRQ_MASK); |
| @@ -447,6 +468,9 @@ static void mtip_restart_port(struct mtip_port *port) | |||
| 447 | && time_before(jiffies, timeout)) | 468 | && time_before(jiffies, timeout)) |
| 448 | ; | 469 | ; |
| 449 | 470 | ||
| 471 | if (test_bit(MTIP_DDF_REMOVE_PENDING_BIT, &port->dd->dd_flag)) | ||
| 472 | return; | ||
| 473 | |||
| 450 | /* | 474 | /* |
| 451 | * Chip quirk: escalate to hba reset if | 475 | * Chip quirk: escalate to hba reset if |
| 452 | * PxCMD.CR not clear after 500 ms | 476 | * PxCMD.CR not clear after 500 ms |
| @@ -475,6 +499,9 @@ static void mtip_restart_port(struct mtip_port *port) | |||
| 475 | while (time_before(jiffies, timeout)) | 499 | while (time_before(jiffies, timeout)) |
| 476 | ; | 500 | ; |
| 477 | 501 | ||
| 502 | if (test_bit(MTIP_DDF_REMOVE_PENDING_BIT, &port->dd->dd_flag)) | ||
| 503 | return; | ||
| 504 | |||
| 478 | /* Clear PxSCTL.DET */ | 505 | /* Clear PxSCTL.DET */ |
| 479 | writel(readl(port->mmio + PORT_SCR_CTL) & ~1, | 506 | writel(readl(port->mmio + PORT_SCR_CTL) & ~1, |
| 480 | port->mmio + PORT_SCR_CTL); | 507 | port->mmio + PORT_SCR_CTL); |
| @@ -486,15 +513,35 @@ static void mtip_restart_port(struct mtip_port *port) | |||
| 486 | && time_before(jiffies, timeout)) | 513 | && time_before(jiffies, timeout)) |
| 487 | ; | 514 | ; |
| 488 | 515 | ||
| 516 | if (test_bit(MTIP_DDF_REMOVE_PENDING_BIT, &port->dd->dd_flag)) | ||
| 517 | return; | ||
| 518 | |||
| 489 | if ((readl(port->mmio + PORT_SCR_STAT) & 0x01) == 0) | 519 | if ((readl(port->mmio + PORT_SCR_STAT) & 0x01) == 0) |
| 490 | dev_warn(&port->dd->pdev->dev, | 520 | dev_warn(&port->dd->pdev->dev, |
| 491 | "COM reset failed\n"); | 521 | "COM reset failed\n"); |
| 492 | 522 | ||
| 493 | /* Clear SError, the PxSERR.DIAG.x should be set so clear it */ | 523 | mtip_init_port(port); |
| 494 | writel(readl(port->mmio + PORT_SCR_ERR), port->mmio + PORT_SCR_ERR); | 524 | mtip_start_port(port); |
| 495 | 525 | ||
| 496 | /* Enable the DMA engine */ | 526 | } |
| 497 | mtip_enable_engine(port, 1); | 527 | |
| 528 | /* | ||
| 529 | * Helper function for tag logging | ||
| 530 | */ | ||
| 531 | static void print_tags(struct driver_data *dd, | ||
| 532 | char *msg, | ||
| 533 | unsigned long *tagbits, | ||
| 534 | int cnt) | ||
| 535 | { | ||
| 536 | unsigned char tagmap[128]; | ||
| 537 | int group, tagmap_len = 0; | ||
| 538 | |||
| 539 | memset(tagmap, 0, sizeof(tagmap)); | ||
| 540 | for (group = SLOTBITS_IN_LONGS; group > 0; group--) | ||
| 541 | tagmap_len = sprintf(tagmap + tagmap_len, "%016lX ", | ||
| 542 | tagbits[group-1]); | ||
| 543 | dev_warn(&dd->pdev->dev, | ||
| 544 | "%d command(s) %s: tagmap [%s]", cnt, msg, tagmap); | ||
| 498 | } | 545 | } |
| 499 | 546 | ||
| 500 | /* | 547 | /* |
| @@ -514,15 +561,18 @@ static void mtip_timeout_function(unsigned long int data) | |||
| 514 | int tag, cmdto_cnt = 0; | 561 | int tag, cmdto_cnt = 0; |
| 515 | unsigned int bit, group; | 562 | unsigned int bit, group; |
| 516 | unsigned int num_command_slots = port->dd->slot_groups * 32; | 563 | unsigned int num_command_slots = port->dd->slot_groups * 32; |
| 564 | unsigned long to, tagaccum[SLOTBITS_IN_LONGS]; | ||
| 517 | 565 | ||
| 518 | if (unlikely(!port)) | 566 | if (unlikely(!port)) |
| 519 | return; | 567 | return; |
| 520 | 568 | ||
| 521 | if (atomic_read(&port->dd->resumeflag) == true) { | 569 | if (test_bit(MTIP_DDF_RESUME_BIT, &port->dd->dd_flag)) { |
| 522 | mod_timer(&port->cmd_timer, | 570 | mod_timer(&port->cmd_timer, |
| 523 | jiffies + msecs_to_jiffies(30000)); | 571 | jiffies + msecs_to_jiffies(30000)); |
| 524 | return; | 572 | return; |
| 525 | } | 573 | } |
| 574 | /* clear the tag accumulator */ | ||
| 575 | memset(tagaccum, 0, SLOTBITS_IN_LONGS * sizeof(long)); | ||
| 526 | 576 | ||
| 527 | for (tag = 0; tag < num_command_slots; tag++) { | 577 | for (tag = 0; tag < num_command_slots; tag++) { |
| 528 | /* | 578 | /* |
| @@ -540,12 +590,10 @@ static void mtip_timeout_function(unsigned long int data) | |||
| 540 | command = &port->commands[tag]; | 590 | command = &port->commands[tag]; |
| 541 | fis = (struct host_to_dev_fis *) command->command; | 591 | fis = (struct host_to_dev_fis *) command->command; |
| 542 | 592 | ||
| 543 | dev_warn(&port->dd->pdev->dev, | 593 | set_bit(tag, tagaccum); |
| 544 | "Timeout for command tag %d\n", tag); | ||
| 545 | |||
| 546 | cmdto_cnt++; | 594 | cmdto_cnt++; |
| 547 | if (cmdto_cnt == 1) | 595 | if (cmdto_cnt == 1) |
| 548 | set_bit(MTIP_FLAG_EH_ACTIVE_BIT, &port->flags); | 596 | set_bit(MTIP_PF_EH_ACTIVE_BIT, &port->flags); |
| 549 | 597 | ||
| 550 | /* | 598 | /* |
| 551 | * Clear the completed bit. This should prevent | 599 | * Clear the completed bit. This should prevent |
| @@ -578,15 +626,29 @@ static void mtip_timeout_function(unsigned long int data) | |||
| 578 | } | 626 | } |
| 579 | } | 627 | } |
| 580 | 628 | ||
| 581 | if (cmdto_cnt) { | 629 | if (cmdto_cnt && !test_bit(MTIP_PF_IC_ACTIVE_BIT, &port->flags)) { |
| 582 | dev_warn(&port->dd->pdev->dev, | 630 | print_tags(port->dd, "timed out", tagaccum, cmdto_cnt); |
| 583 | "%d commands timed out: restarting port", | 631 | |
| 584 | cmdto_cnt); | ||
| 585 | mtip_restart_port(port); | 632 | mtip_restart_port(port); |
| 586 | clear_bit(MTIP_FLAG_EH_ACTIVE_BIT, &port->flags); | 633 | clear_bit(MTIP_PF_EH_ACTIVE_BIT, &port->flags); |
| 587 | wake_up_interruptible(&port->svc_wait); | 634 | wake_up_interruptible(&port->svc_wait); |
| 588 | } | 635 | } |
| 589 | 636 | ||
| 637 | if (port->ic_pause_timer) { | ||
| 638 | to = port->ic_pause_timer + msecs_to_jiffies(1000); | ||
| 639 | if (time_after(jiffies, to)) { | ||
| 640 | if (!test_bit(MTIP_PF_IC_ACTIVE_BIT, &port->flags)) { | ||
| 641 | port->ic_pause_timer = 0; | ||
| 642 | clear_bit(MTIP_PF_SE_ACTIVE_BIT, &port->flags); | ||
| 643 | clear_bit(MTIP_PF_DM_ACTIVE_BIT, &port->flags); | ||
| 644 | clear_bit(MTIP_PF_IC_ACTIVE_BIT, &port->flags); | ||
| 645 | wake_up_interruptible(&port->svc_wait); | ||
| 646 | } | ||
| 647 | |||
| 648 | |||
| 649 | } | ||
| 650 | } | ||
| 651 | |||
| 590 | /* Restart the timer */ | 652 | /* Restart the timer */ |
| 591 | mod_timer(&port->cmd_timer, | 653 | mod_timer(&port->cmd_timer, |
| 592 | jiffies + msecs_to_jiffies(MTIP_TIMEOUT_CHECK_PERIOD)); | 654 | jiffies + msecs_to_jiffies(MTIP_TIMEOUT_CHECK_PERIOD)); |
| @@ -681,23 +743,18 @@ static void mtip_completion(struct mtip_port *port, | |||
| 681 | complete(waiting); | 743 | complete(waiting); |
| 682 | } | 744 | } |
| 683 | 745 | ||
| 684 | /* | 746 | static void mtip_null_completion(struct mtip_port *port, |
| 685 | * Helper function for tag logging | 747 | int tag, |
| 686 | */ | 748 | void *data, |
| 687 | static void print_tags(struct driver_data *dd, | 749 | int status) |
| 688 | char *msg, | ||
| 689 | unsigned long *tagbits) | ||
| 690 | { | 750 | { |
| 691 | unsigned int tag, count = 0; | 751 | return; |
| 692 | |||
| 693 | for (tag = 0; tag < (dd->slot_groups) * 32; tag++) { | ||
| 694 | if (test_bit(tag, tagbits)) | ||
| 695 | count++; | ||
| 696 | } | ||
| 697 | if (count) | ||
| 698 | dev_info(&dd->pdev->dev, "%s [%i tags]\n", msg, count); | ||
| 699 | } | 752 | } |
| 700 | 753 | ||
| 754 | static int mtip_read_log_page(struct mtip_port *port, u8 page, u16 *buffer, | ||
| 755 | dma_addr_t buffer_dma, unsigned int sectors); | ||
| 756 | static int mtip_get_smart_attr(struct mtip_port *port, unsigned int id, | ||
| 757 | struct smart_attr *attrib); | ||
| 701 | /* | 758 | /* |
| 702 | * Handle an error. | 759 | * Handle an error. |
| 703 | * | 760 | * |
| @@ -708,12 +765,16 @@ static void print_tags(struct driver_data *dd, | |||
| 708 | */ | 765 | */ |
| 709 | static void mtip_handle_tfe(struct driver_data *dd) | 766 | static void mtip_handle_tfe(struct driver_data *dd) |
| 710 | { | 767 | { |
| 711 | int group, tag, bit, reissue; | 768 | int group, tag, bit, reissue, rv; |
| 712 | struct mtip_port *port; | 769 | struct mtip_port *port; |
| 713 | struct mtip_cmd *command; | 770 | struct mtip_cmd *cmd; |
| 714 | u32 completed; | 771 | u32 completed; |
| 715 | struct host_to_dev_fis *fis; | 772 | struct host_to_dev_fis *fis; |
| 716 | unsigned long tagaccum[SLOTBITS_IN_LONGS]; | 773 | unsigned long tagaccum[SLOTBITS_IN_LONGS]; |
| 774 | unsigned int cmd_cnt = 0; | ||
| 775 | unsigned char *buf; | ||
| 776 | char *fail_reason = NULL; | ||
| 777 | int fail_all_ncq_write = 0, fail_all_ncq_cmds = 0; | ||
| 717 | 778 | ||
| 718 | dev_warn(&dd->pdev->dev, "Taskfile error\n"); | 779 | dev_warn(&dd->pdev->dev, "Taskfile error\n"); |
| 719 | 780 | ||
| @@ -722,8 +783,11 @@ static void mtip_handle_tfe(struct driver_data *dd) | |||
| 722 | /* Stop the timer to prevent command timeouts. */ | 783 | /* Stop the timer to prevent command timeouts. */ |
| 723 | del_timer(&port->cmd_timer); | 784 | del_timer(&port->cmd_timer); |
| 724 | 785 | ||
| 786 | /* clear the tag accumulator */ | ||
| 787 | memset(tagaccum, 0, SLOTBITS_IN_LONGS * sizeof(long)); | ||
| 788 | |||
| 725 | /* Set eh_active */ | 789 | /* Set eh_active */ |
| 726 | set_bit(MTIP_FLAG_EH_ACTIVE_BIT, &port->flags); | 790 | set_bit(MTIP_PF_EH_ACTIVE_BIT, &port->flags); |
| 727 | 791 | ||
| 728 | /* Loop through all the groups */ | 792 | /* Loop through all the groups */ |
| 729 | for (group = 0; group < dd->slot_groups; group++) { | 793 | for (group = 0; group < dd->slot_groups; group++) { |
| @@ -732,9 +796,6 @@ static void mtip_handle_tfe(struct driver_data *dd) | |||
| 732 | /* clear completed status register in the hardware.*/ | 796 | /* clear completed status register in the hardware.*/ |
| 733 | writel(completed, port->completed[group]); | 797 | writel(completed, port->completed[group]); |
| 734 | 798 | ||
| 735 | /* clear the tag accumulator */ | ||
| 736 | memset(tagaccum, 0, SLOTBITS_IN_LONGS * sizeof(long)); | ||
| 737 | |||
| 738 | /* Process successfully completed commands */ | 799 | /* Process successfully completed commands */ |
| 739 | for (bit = 0; bit < 32 && completed; bit++) { | 800 | for (bit = 0; bit < 32 && completed; bit++) { |
| 740 | if (!(completed & (1<<bit))) | 801 | if (!(completed & (1<<bit))) |
| @@ -745,13 +806,14 @@ static void mtip_handle_tfe(struct driver_data *dd) | |||
| 745 | if (tag == MTIP_TAG_INTERNAL) | 806 | if (tag == MTIP_TAG_INTERNAL) |
| 746 | continue; | 807 | continue; |
| 747 | 808 | ||
| 748 | command = &port->commands[tag]; | 809 | cmd = &port->commands[tag]; |
| 749 | if (likely(command->comp_func)) { | 810 | if (likely(cmd->comp_func)) { |
| 750 | set_bit(tag, tagaccum); | 811 | set_bit(tag, tagaccum); |
| 751 | atomic_set(&port->commands[tag].active, 0); | 812 | cmd_cnt++; |
| 752 | command->comp_func(port, | 813 | atomic_set(&cmd->active, 0); |
| 814 | cmd->comp_func(port, | ||
| 753 | tag, | 815 | tag, |
| 754 | command->comp_data, | 816 | cmd->comp_data, |
| 755 | 0); | 817 | 0); |
| 756 | } else { | 818 | } else { |
| 757 | dev_err(&port->dd->pdev->dev, | 819 | dev_err(&port->dd->pdev->dev, |
| @@ -765,12 +827,45 @@ static void mtip_handle_tfe(struct driver_data *dd) | |||
| 765 | } | 827 | } |
| 766 | } | 828 | } |
| 767 | } | 829 | } |
| 768 | print_tags(dd, "TFE tags completed:", tagaccum); | 830 | |
| 831 | print_tags(dd, "completed (TFE)", tagaccum, cmd_cnt); | ||
| 769 | 832 | ||
| 770 | /* Restart the port */ | 833 | /* Restart the port */ |
| 771 | mdelay(20); | 834 | mdelay(20); |
| 772 | mtip_restart_port(port); | 835 | mtip_restart_port(port); |
| 773 | 836 | ||
| 837 | /* Trying to determine the cause of the error */ | ||
| 838 | rv = mtip_read_log_page(dd->port, ATA_LOG_SATA_NCQ, | ||
| 839 | dd->port->log_buf, | ||
| 840 | dd->port->log_buf_dma, 1); | ||
| 841 | if (rv) { | ||
| 842 | dev_warn(&dd->pdev->dev, | ||
| 843 | "Error in READ LOG EXT (10h) command\n"); | ||
| 844 | /* non-critical error, don't fail the load */ | ||
| 845 | } else { | ||
| 846 | buf = (unsigned char *)dd->port->log_buf; | ||
| 847 | if (buf[259] & 0x1) { | ||
| 848 | dev_info(&dd->pdev->dev, | ||
| 849 | "Write protect bit is set.\n"); | ||
| 850 | set_bit(MTIP_DDF_WRITE_PROTECT_BIT, &dd->dd_flag); | ||
| 851 | fail_all_ncq_write = 1; | ||
| 852 | fail_reason = "write protect"; | ||
| 853 | } | ||
| 854 | if (buf[288] == 0xF7) { | ||
| 855 | dev_info(&dd->pdev->dev, | ||
| 856 | "Exceeded Tmax, drive in thermal shutdown.\n"); | ||
| 857 | set_bit(MTIP_DDF_OVER_TEMP_BIT, &dd->dd_flag); | ||
| 858 | fail_all_ncq_cmds = 1; | ||
| 859 | fail_reason = "thermal shutdown"; | ||
| 860 | } | ||
| 861 | if (buf[288] == 0xBF) { | ||
| 862 | dev_info(&dd->pdev->dev, | ||
| 863 | "Drive indicates rebuild has failed.\n"); | ||
| 864 | fail_all_ncq_cmds = 1; | ||
| 865 | fail_reason = "rebuild failed"; | ||
| 866 | } | ||
| 867 | } | ||
| 868 | |||
| 774 | /* clear the tag accumulator */ | 869 | /* clear the tag accumulator */ |
| 775 | memset(tagaccum, 0, SLOTBITS_IN_LONGS * sizeof(long)); | 870 | memset(tagaccum, 0, SLOTBITS_IN_LONGS * sizeof(long)); |
| 776 | 871 | ||
| @@ -779,32 +874,47 @@ static void mtip_handle_tfe(struct driver_data *dd) | |||
| 779 | for (bit = 0; bit < 32; bit++) { | 874 | for (bit = 0; bit < 32; bit++) { |
| 780 | reissue = 1; | 875 | reissue = 1; |
| 781 | tag = (group << 5) + bit; | 876 | tag = (group << 5) + bit; |
| 877 | cmd = &port->commands[tag]; | ||
| 782 | 878 | ||
| 783 | /* If the active bit is set re-issue the command */ | 879 | /* If the active bit is set re-issue the command */ |
| 784 | if (atomic_read(&port->commands[tag].active) == 0) | 880 | if (atomic_read(&cmd->active) == 0) |
| 785 | continue; | 881 | continue; |
| 786 | 882 | ||
| 787 | fis = (struct host_to_dev_fis *) | 883 | fis = (struct host_to_dev_fis *)cmd->command; |
| 788 | port->commands[tag].command; | ||
| 789 | 884 | ||
| 790 | /* Should re-issue? */ | 885 | /* Should re-issue? */ |
| 791 | if (tag == MTIP_TAG_INTERNAL || | 886 | if (tag == MTIP_TAG_INTERNAL || |
| 792 | fis->command == ATA_CMD_SET_FEATURES) | 887 | fis->command == ATA_CMD_SET_FEATURES) |
| 793 | reissue = 0; | 888 | reissue = 0; |
| 889 | else { | ||
| 890 | if (fail_all_ncq_cmds || | ||
| 891 | (fail_all_ncq_write && | ||
| 892 | fis->command == ATA_CMD_FPDMA_WRITE)) { | ||
| 893 | dev_warn(&dd->pdev->dev, | ||
| 894 | " Fail: %s w/tag %d [%s].\n", | ||
| 895 | fis->command == ATA_CMD_FPDMA_WRITE ? | ||
| 896 | "write" : "read", | ||
| 897 | tag, | ||
| 898 | fail_reason != NULL ? | ||
| 899 | fail_reason : "unknown"); | ||
| 900 | atomic_set(&cmd->active, 0); | ||
| 901 | if (cmd->comp_func) { | ||
| 902 | cmd->comp_func(port, tag, | ||
| 903 | cmd->comp_data, | ||
| 904 | -ENODATA); | ||
| 905 | } | ||
| 906 | continue; | ||
| 907 | } | ||
| 908 | } | ||
| 794 | 909 | ||
| 795 | /* | 910 | /* |
| 796 | * First check if this command has | 911 | * First check if this command has |
| 797 | * exceeded its retries. | 912 | * exceeded its retries. |
| 798 | */ | 913 | */ |
| 799 | if (reissue && | 914 | if (reissue && (cmd->retries-- > 0)) { |
| 800 | (port->commands[tag].retries-- > 0)) { | ||
| 801 | 915 | ||
| 802 | set_bit(tag, tagaccum); | 916 | set_bit(tag, tagaccum); |
| 803 | 917 | ||
| 804 | /* Update the timeout value. */ | ||
| 805 | port->commands[tag].comp_time = | ||
| 806 | jiffies + msecs_to_jiffies( | ||
| 807 | MTIP_NCQ_COMMAND_TIMEOUT_MS); | ||
| 808 | /* Re-issue the command. */ | 918 | /* Re-issue the command. */ |
| 809 | mtip_issue_ncq_command(port, tag); | 919 | mtip_issue_ncq_command(port, tag); |
| 810 | 920 | ||
| @@ -814,13 +924,13 @@ static void mtip_handle_tfe(struct driver_data *dd) | |||
| 814 | /* Retire a command that will not be reissued */ | 924 | /* Retire a command that will not be reissued */ |
| 815 | dev_warn(&port->dd->pdev->dev, | 925 | dev_warn(&port->dd->pdev->dev, |
| 816 | "retiring tag %d\n", tag); | 926 | "retiring tag %d\n", tag); |
| 817 | atomic_set(&port->commands[tag].active, 0); | 927 | atomic_set(&cmd->active, 0); |
| 818 | 928 | ||
| 819 | if (port->commands[tag].comp_func) | 929 | if (cmd->comp_func) |
| 820 | port->commands[tag].comp_func( | 930 | cmd->comp_func( |
| 821 | port, | 931 | port, |
| 822 | tag, | 932 | tag, |
| 823 | port->commands[tag].comp_data, | 933 | cmd->comp_data, |
| 824 | PORT_IRQ_TF_ERR); | 934 | PORT_IRQ_TF_ERR); |
| 825 | else | 935 | else |
| 826 | dev_warn(&port->dd->pdev->dev, | 936 | dev_warn(&port->dd->pdev->dev, |
| @@ -828,10 +938,10 @@ static void mtip_handle_tfe(struct driver_data *dd) | |||
| 828 | tag); | 938 | tag); |
| 829 | } | 939 | } |
| 830 | } | 940 | } |
| 831 | print_tags(dd, "TFE tags reissued:", tagaccum); | 941 | print_tags(dd, "reissued (TFE)", tagaccum, cmd_cnt); |
| 832 | 942 | ||
| 833 | /* clear eh_active */ | 943 | /* clear eh_active */ |
| 834 | clear_bit(MTIP_FLAG_EH_ACTIVE_BIT, &port->flags); | 944 | clear_bit(MTIP_PF_EH_ACTIVE_BIT, &port->flags); |
| 835 | wake_up_interruptible(&port->svc_wait); | 945 | wake_up_interruptible(&port->svc_wait); |
| 836 | 946 | ||
| 837 | mod_timer(&port->cmd_timer, | 947 | mod_timer(&port->cmd_timer, |
| @@ -899,7 +1009,7 @@ static inline void mtip_process_legacy(struct driver_data *dd, u32 port_stat) | |||
| 899 | struct mtip_port *port = dd->port; | 1009 | struct mtip_port *port = dd->port; |
| 900 | struct mtip_cmd *cmd = &port->commands[MTIP_TAG_INTERNAL]; | 1010 | struct mtip_cmd *cmd = &port->commands[MTIP_TAG_INTERNAL]; |
| 901 | 1011 | ||
| 902 | if (test_bit(MTIP_FLAG_IC_ACTIVE_BIT, &port->flags) && | 1012 | if (test_bit(MTIP_PF_IC_ACTIVE_BIT, &port->flags) && |
| 903 | (cmd != NULL) && !(readl(port->cmd_issue[MTIP_TAG_INTERNAL]) | 1013 | (cmd != NULL) && !(readl(port->cmd_issue[MTIP_TAG_INTERNAL]) |
| 904 | & (1 << MTIP_TAG_INTERNAL))) { | 1014 | & (1 << MTIP_TAG_INTERNAL))) { |
| 905 | if (cmd->comp_func) { | 1015 | if (cmd->comp_func) { |
| @@ -911,8 +1021,6 @@ static inline void mtip_process_legacy(struct driver_data *dd, u32 port_stat) | |||
| 911 | } | 1021 | } |
| 912 | } | 1022 | } |
| 913 | 1023 | ||
| 914 | dev_warn(&dd->pdev->dev, "IRQ status 0x%x ignored.\n", port_stat); | ||
| 915 | |||
| 916 | return; | 1024 | return; |
| 917 | } | 1025 | } |
| 918 | 1026 | ||
| @@ -968,6 +1076,9 @@ static inline irqreturn_t mtip_handle_irq(struct driver_data *data) | |||
| 968 | /* don't proceed further */ | 1076 | /* don't proceed further */ |
| 969 | return IRQ_HANDLED; | 1077 | return IRQ_HANDLED; |
| 970 | } | 1078 | } |
| 1079 | if (test_bit(MTIP_DDF_REMOVE_PENDING_BIT, | ||
| 1080 | &dd->dd_flag)) | ||
| 1081 | return rv; | ||
| 971 | 1082 | ||
| 972 | mtip_process_errors(dd, port_stat & PORT_IRQ_ERR); | 1083 | mtip_process_errors(dd, port_stat & PORT_IRQ_ERR); |
| 973 | } | 1084 | } |
| @@ -1015,6 +1126,39 @@ static void mtip_issue_non_ncq_command(struct mtip_port *port, int tag) | |||
| 1015 | port->cmd_issue[MTIP_TAG_INDEX(tag)]); | 1126 | port->cmd_issue[MTIP_TAG_INDEX(tag)]); |
| 1016 | } | 1127 | } |
| 1017 | 1128 | ||
| 1129 | static bool mtip_pause_ncq(struct mtip_port *port, | ||
| 1130 | struct host_to_dev_fis *fis) | ||
| 1131 | { | ||
| 1132 | struct host_to_dev_fis *reply; | ||
| 1133 | unsigned long task_file_data; | ||
| 1134 | |||
| 1135 | reply = port->rxfis + RX_FIS_D2H_REG; | ||
| 1136 | task_file_data = readl(port->mmio+PORT_TFDATA); | ||
| 1137 | |||
| 1138 | if ((task_file_data & 1) || (fis->command == ATA_CMD_SEC_ERASE_UNIT)) | ||
| 1139 | return false; | ||
| 1140 | |||
| 1141 | if (fis->command == ATA_CMD_SEC_ERASE_PREP) { | ||
| 1142 | set_bit(MTIP_PF_SE_ACTIVE_BIT, &port->flags); | ||
| 1143 | port->ic_pause_timer = jiffies; | ||
| 1144 | return true; | ||
| 1145 | } else if ((fis->command == ATA_CMD_DOWNLOAD_MICRO) && | ||
| 1146 | (fis->features == 0x03)) { | ||
| 1147 | set_bit(MTIP_PF_DM_ACTIVE_BIT, &port->flags); | ||
| 1148 | port->ic_pause_timer = jiffies; | ||
| 1149 | return true; | ||
| 1150 | } else if ((fis->command == ATA_CMD_SEC_ERASE_UNIT) || | ||
| 1151 | ((fis->command == 0xFC) && | ||
| 1152 | (fis->features == 0x27 || fis->features == 0x72 || | ||
| 1153 | fis->features == 0x62 || fis->features == 0x26))) { | ||
| 1154 | /* Com reset after secure erase or lowlevel format */ | ||
| 1155 | mtip_restart_port(port); | ||
| 1156 | return false; | ||
| 1157 | } | ||
| 1158 | |||
| 1159 | return false; | ||
| 1160 | } | ||
| 1161 | |||
| 1018 | /* | 1162 | /* |
| 1019 | * Wait for port to quiesce | 1163 | * Wait for port to quiesce |
| 1020 | * | 1164 | * |
| @@ -1033,11 +1177,13 @@ static int mtip_quiesce_io(struct mtip_port *port, unsigned long timeout) | |||
| 1033 | 1177 | ||
| 1034 | to = jiffies + msecs_to_jiffies(timeout); | 1178 | to = jiffies + msecs_to_jiffies(timeout); |
| 1035 | do { | 1179 | do { |
| 1036 | if (test_bit(MTIP_FLAG_SVC_THD_ACTIVE_BIT, &port->flags) && | 1180 | if (test_bit(MTIP_PF_SVC_THD_ACTIVE_BIT, &port->flags) && |
| 1037 | test_bit(MTIP_FLAG_ISSUE_CMDS_BIT, &port->flags)) { | 1181 | test_bit(MTIP_PF_ISSUE_CMDS_BIT, &port->flags)) { |
| 1038 | msleep(20); | 1182 | msleep(20); |
| 1039 | continue; /* svc thd is actively issuing commands */ | 1183 | continue; /* svc thd is actively issuing commands */ |
| 1040 | } | 1184 | } |
| 1185 | if (test_bit(MTIP_DDF_REMOVE_PENDING_BIT, &port->dd->dd_flag)) | ||
| 1186 | return -EFAULT; | ||
| 1041 | /* | 1187 | /* |
| 1042 | * Ignore s_active bit 0 of array element 0. | 1188 | * Ignore s_active bit 0 of array element 0. |
| 1043 | * This bit will always be set | 1189 | * This bit will always be set |
| @@ -1074,7 +1220,7 @@ static int mtip_quiesce_io(struct mtip_port *port, unsigned long timeout) | |||
| 1074 | * -EAGAIN Time out waiting for command to complete. | 1220 | * -EAGAIN Time out waiting for command to complete. |
| 1075 | */ | 1221 | */ |
| 1076 | static int mtip_exec_internal_command(struct mtip_port *port, | 1222 | static int mtip_exec_internal_command(struct mtip_port *port, |
| 1077 | void *fis, | 1223 | struct host_to_dev_fis *fis, |
| 1078 | int fis_len, | 1224 | int fis_len, |
| 1079 | dma_addr_t buffer, | 1225 | dma_addr_t buffer, |
| 1080 | int buf_len, | 1226 | int buf_len, |
| @@ -1084,8 +1230,9 @@ static int mtip_exec_internal_command(struct mtip_port *port, | |||
| 1084 | { | 1230 | { |
| 1085 | struct mtip_cmd_sg *command_sg; | 1231 | struct mtip_cmd_sg *command_sg; |
| 1086 | DECLARE_COMPLETION_ONSTACK(wait); | 1232 | DECLARE_COMPLETION_ONSTACK(wait); |
| 1087 | int rv = 0; | 1233 | int rv = 0, ready2go = 1; |
| 1088 | struct mtip_cmd *int_cmd = &port->commands[MTIP_TAG_INTERNAL]; | 1234 | struct mtip_cmd *int_cmd = &port->commands[MTIP_TAG_INTERNAL]; |
| 1235 | unsigned long to; | ||
| 1089 | 1236 | ||
| 1090 | /* Make sure the buffer is 8 byte aligned. This is asic specific. */ | 1237 | /* Make sure the buffer is 8 byte aligned. This is asic specific. */ |
| 1091 | if (buffer & 0x00000007) { | 1238 | if (buffer & 0x00000007) { |
| @@ -1094,23 +1241,38 @@ static int mtip_exec_internal_command(struct mtip_port *port, | |||
| 1094 | return -EFAULT; | 1241 | return -EFAULT; |
| 1095 | } | 1242 | } |
| 1096 | 1243 | ||
| 1097 | /* Only one internal command should be running at a time */ | 1244 | to = jiffies + msecs_to_jiffies(timeout); |
| 1098 | if (test_and_set_bit(MTIP_TAG_INTERNAL, port->allocated)) { | 1245 | do { |
| 1246 | ready2go = !test_and_set_bit(MTIP_TAG_INTERNAL, | ||
| 1247 | port->allocated); | ||
| 1248 | if (ready2go) | ||
| 1249 | break; | ||
| 1250 | mdelay(100); | ||
| 1251 | } while (time_before(jiffies, to)); | ||
| 1252 | if (!ready2go) { | ||
| 1099 | dev_warn(&port->dd->pdev->dev, | 1253 | dev_warn(&port->dd->pdev->dev, |
| 1100 | "Internal command already active\n"); | 1254 | "Internal cmd active. new cmd [%02X]\n", fis->command); |
| 1101 | return -EBUSY; | 1255 | return -EBUSY; |
| 1102 | } | 1256 | } |
| 1103 | set_bit(MTIP_FLAG_IC_ACTIVE_BIT, &port->flags); | 1257 | set_bit(MTIP_PF_IC_ACTIVE_BIT, &port->flags); |
| 1258 | port->ic_pause_timer = 0; | ||
| 1259 | |||
| 1260 | if (fis->command == ATA_CMD_SEC_ERASE_UNIT) | ||
| 1261 | clear_bit(MTIP_PF_SE_ACTIVE_BIT, &port->flags); | ||
| 1262 | else if (fis->command == ATA_CMD_DOWNLOAD_MICRO) | ||
| 1263 | clear_bit(MTIP_PF_DM_ACTIVE_BIT, &port->flags); | ||
| 1104 | 1264 | ||
| 1105 | if (atomic == GFP_KERNEL) { | 1265 | if (atomic == GFP_KERNEL) { |
| 1106 | /* wait for io to complete if non atomic */ | 1266 | if (fis->command != ATA_CMD_STANDBYNOW1) { |
| 1107 | if (mtip_quiesce_io(port, 5000) < 0) { | 1267 | /* wait for io to complete if non atomic */ |
| 1108 | dev_warn(&port->dd->pdev->dev, | 1268 | if (mtip_quiesce_io(port, 5000) < 0) { |
| 1109 | "Failed to quiesce IO\n"); | 1269 | dev_warn(&port->dd->pdev->dev, |
| 1110 | release_slot(port, MTIP_TAG_INTERNAL); | 1270 | "Failed to quiesce IO\n"); |
| 1111 | clear_bit(MTIP_FLAG_IC_ACTIVE_BIT, &port->flags); | 1271 | release_slot(port, MTIP_TAG_INTERNAL); |
| 1112 | wake_up_interruptible(&port->svc_wait); | 1272 | clear_bit(MTIP_PF_IC_ACTIVE_BIT, &port->flags); |
| 1113 | return -EBUSY; | 1273 | wake_up_interruptible(&port->svc_wait); |
| 1274 | return -EBUSY; | ||
| 1275 | } | ||
| 1114 | } | 1276 | } |
| 1115 | 1277 | ||
| 1116 | /* Set the completion function and data for the command. */ | 1278 | /* Set the completion function and data for the command. */ |
| @@ -1120,7 +1282,7 @@ static int mtip_exec_internal_command(struct mtip_port *port, | |||
| 1120 | } else { | 1282 | } else { |
| 1121 | /* Clear completion - we're going to poll */ | 1283 | /* Clear completion - we're going to poll */ |
| 1122 | int_cmd->comp_data = NULL; | 1284 | int_cmd->comp_data = NULL; |
| 1123 | int_cmd->comp_func = NULL; | 1285 | int_cmd->comp_func = mtip_null_completion; |
| 1124 | } | 1286 | } |
| 1125 | 1287 | ||
| 1126 | /* Copy the command to the command table */ | 1288 | /* Copy the command to the command table */ |
| @@ -1159,6 +1321,12 @@ static int mtip_exec_internal_command(struct mtip_port *port, | |||
| 1159 | "Internal command did not complete [%d] " | 1321 | "Internal command did not complete [%d] " |
| 1160 | "within timeout of %lu ms\n", | 1322 | "within timeout of %lu ms\n", |
| 1161 | atomic, timeout); | 1323 | atomic, timeout); |
| 1324 | if (mtip_check_surprise_removal(port->dd->pdev) || | ||
| 1325 | test_bit(MTIP_DDF_REMOVE_PENDING_BIT, | ||
| 1326 | &port->dd->dd_flag)) { | ||
| 1327 | rv = -ENXIO; | ||
| 1328 | goto exec_ic_exit; | ||
| 1329 | } | ||
| 1162 | rv = -EAGAIN; | 1330 | rv = -EAGAIN; |
| 1163 | } | 1331 | } |
| 1164 | 1332 | ||
| @@ -1166,31 +1334,59 @@ static int mtip_exec_internal_command(struct mtip_port *port, | |||
| 1166 | & (1 << MTIP_TAG_INTERNAL)) { | 1334 | & (1 << MTIP_TAG_INTERNAL)) { |
| 1167 | dev_warn(&port->dd->pdev->dev, | 1335 | dev_warn(&port->dd->pdev->dev, |
| 1168 | "Retiring internal command but CI is 1.\n"); | 1336 | "Retiring internal command but CI is 1.\n"); |
| 1337 | if (test_bit(MTIP_DDF_REMOVE_PENDING_BIT, | ||
| 1338 | &port->dd->dd_flag)) { | ||
| 1339 | hba_reset_nosleep(port->dd); | ||
| 1340 | rv = -ENXIO; | ||
| 1341 | } else { | ||
| 1342 | mtip_restart_port(port); | ||
| 1343 | rv = -EAGAIN; | ||
| 1344 | } | ||
| 1345 | goto exec_ic_exit; | ||
| 1169 | } | 1346 | } |
| 1170 | 1347 | ||
| 1171 | } else { | 1348 | } else { |
| 1172 | /* Spin for <timeout> checking if command still outstanding */ | 1349 | /* Spin for <timeout> checking if command still outstanding */ |
| 1173 | timeout = jiffies + msecs_to_jiffies(timeout); | 1350 | timeout = jiffies + msecs_to_jiffies(timeout); |
| 1174 | 1351 | while ((readl(port->cmd_issue[MTIP_TAG_INTERNAL]) | |
| 1175 | while ((readl( | 1352 | & (1 << MTIP_TAG_INTERNAL)) |
| 1176 | port->cmd_issue[MTIP_TAG_INTERNAL]) | 1353 | && time_before(jiffies, timeout)) { |
| 1177 | & (1 << MTIP_TAG_INTERNAL)) | 1354 | if (mtip_check_surprise_removal(port->dd->pdev)) { |
| 1178 | && time_before(jiffies, timeout)) | 1355 | rv = -ENXIO; |
| 1179 | ; | 1356 | goto exec_ic_exit; |
| 1357 | } | ||
| 1358 | if ((fis->command != ATA_CMD_STANDBYNOW1) && | ||
| 1359 | test_bit(MTIP_DDF_REMOVE_PENDING_BIT, | ||
| 1360 | &port->dd->dd_flag)) { | ||
| 1361 | rv = -ENXIO; | ||
| 1362 | goto exec_ic_exit; | ||
| 1363 | } | ||
| 1364 | } | ||
| 1180 | 1365 | ||
| 1181 | if (readl(port->cmd_issue[MTIP_TAG_INTERNAL]) | 1366 | if (readl(port->cmd_issue[MTIP_TAG_INTERNAL]) |
| 1182 | & (1 << MTIP_TAG_INTERNAL)) { | 1367 | & (1 << MTIP_TAG_INTERNAL)) { |
| 1183 | dev_err(&port->dd->pdev->dev, | 1368 | dev_err(&port->dd->pdev->dev, |
| 1184 | "Internal command did not complete [%d]\n", | 1369 | "Internal command did not complete [atomic]\n"); |
| 1185 | atomic); | ||
| 1186 | rv = -EAGAIN; | 1370 | rv = -EAGAIN; |
| 1371 | if (test_bit(MTIP_DDF_REMOVE_PENDING_BIT, | ||
| 1372 | &port->dd->dd_flag)) { | ||
| 1373 | hba_reset_nosleep(port->dd); | ||
| 1374 | rv = -ENXIO; | ||
| 1375 | } else { | ||
| 1376 | mtip_restart_port(port); | ||
| 1377 | rv = -EAGAIN; | ||
| 1378 | } | ||
| 1187 | } | 1379 | } |
| 1188 | } | 1380 | } |
| 1189 | 1381 | exec_ic_exit: | |
| 1190 | /* Clear the allocated and active bits for the internal command. */ | 1382 | /* Clear the allocated and active bits for the internal command. */ |
| 1191 | atomic_set(&int_cmd->active, 0); | 1383 | atomic_set(&int_cmd->active, 0); |
| 1192 | release_slot(port, MTIP_TAG_INTERNAL); | 1384 | release_slot(port, MTIP_TAG_INTERNAL); |
| 1193 | clear_bit(MTIP_FLAG_IC_ACTIVE_BIT, &port->flags); | 1385 | if (rv >= 0 && mtip_pause_ncq(port, fis)) { |
| 1386 | /* NCQ paused */ | ||
| 1387 | return rv; | ||
| 1388 | } | ||
| 1389 | clear_bit(MTIP_PF_IC_ACTIVE_BIT, &port->flags); | ||
| 1194 | wake_up_interruptible(&port->svc_wait); | 1390 | wake_up_interruptible(&port->svc_wait); |
| 1195 | 1391 | ||
| 1196 | return rv; | 1392 | return rv; |
| @@ -1240,6 +1436,9 @@ static int mtip_get_identify(struct mtip_port *port, void __user *user_buffer) | |||
| 1240 | int rv = 0; | 1436 | int rv = 0; |
| 1241 | struct host_to_dev_fis fis; | 1437 | struct host_to_dev_fis fis; |
| 1242 | 1438 | ||
| 1439 | if (test_bit(MTIP_DDF_REMOVE_PENDING_BIT, &port->dd->dd_flag)) | ||
| 1440 | return -EFAULT; | ||
| 1441 | |||
| 1243 | /* Build the FIS. */ | 1442 | /* Build the FIS. */ |
| 1244 | memset(&fis, 0, sizeof(struct host_to_dev_fis)); | 1443 | memset(&fis, 0, sizeof(struct host_to_dev_fis)); |
| 1245 | fis.type = 0x27; | 1444 | fis.type = 0x27; |
| @@ -1313,6 +1512,7 @@ static int mtip_standby_immediate(struct mtip_port *port) | |||
| 1313 | { | 1512 | { |
| 1314 | int rv; | 1513 | int rv; |
| 1315 | struct host_to_dev_fis fis; | 1514 | struct host_to_dev_fis fis; |
| 1515 | unsigned long start; | ||
| 1316 | 1516 | ||
| 1317 | /* Build the FIS. */ | 1517 | /* Build the FIS. */ |
| 1318 | memset(&fis, 0, sizeof(struct host_to_dev_fis)); | 1518 | memset(&fis, 0, sizeof(struct host_to_dev_fis)); |
| @@ -1320,15 +1520,150 @@ static int mtip_standby_immediate(struct mtip_port *port) | |||
| 1320 | fis.opts = 1 << 7; | 1520 | fis.opts = 1 << 7; |
| 1321 | fis.command = ATA_CMD_STANDBYNOW1; | 1521 | fis.command = ATA_CMD_STANDBYNOW1; |
| 1322 | 1522 | ||
| 1323 | /* Execute the command. Use a 15-second timeout for large drives. */ | 1523 | start = jiffies; |
| 1324 | rv = mtip_exec_internal_command(port, | 1524 | rv = mtip_exec_internal_command(port, |
| 1325 | &fis, | 1525 | &fis, |
| 1326 | 5, | 1526 | 5, |
| 1327 | 0, | 1527 | 0, |
| 1328 | 0, | 1528 | 0, |
| 1329 | 0, | 1529 | 0, |
| 1330 | GFP_KERNEL, | 1530 | GFP_ATOMIC, |
| 1331 | 15000); | 1531 | 15000); |
| 1532 | dbg_printk(MTIP_DRV_NAME "Time taken to complete standby cmd: %d ms\n", | ||
| 1533 | jiffies_to_msecs(jiffies - start)); | ||
| 1534 | if (rv) | ||
| 1535 | dev_warn(&port->dd->pdev->dev, | ||
| 1536 | "STANDBY IMMEDIATE command failed.\n"); | ||
| 1537 | |||
| 1538 | return rv; | ||
| 1539 | } | ||
| 1540 | |||
| 1541 | /* | ||
| 1542 | * Issue a READ LOG EXT command to the device. | ||
| 1543 | * | ||
| 1544 | * @port pointer to the port structure. | ||
| 1545 | * @page page number to fetch | ||
| 1546 | * @buffer pointer to buffer | ||
| 1547 | * @buffer_dma dma address corresponding to @buffer | ||
| 1548 | * @sectors page length to fetch, in sectors | ||
| 1549 | * | ||
| 1550 | * return value | ||
| 1551 | * @rv return value from mtip_exec_internal_command() | ||
| 1552 | */ | ||
| 1553 | static int mtip_read_log_page(struct mtip_port *port, u8 page, u16 *buffer, | ||
| 1554 | dma_addr_t buffer_dma, unsigned int sectors) | ||
| 1555 | { | ||
| 1556 | struct host_to_dev_fis fis; | ||
| 1557 | |||
| 1558 | memset(&fis, 0, sizeof(struct host_to_dev_fis)); | ||
| 1559 | fis.type = 0x27; | ||
| 1560 | fis.opts = 1 << 7; | ||
| 1561 | fis.command = ATA_CMD_READ_LOG_EXT; | ||
| 1562 | fis.sect_count = sectors & 0xFF; | ||
| 1563 | fis.sect_cnt_ex = (sectors >> 8) & 0xFF; | ||
| 1564 | fis.lba_low = page; | ||
| 1565 | fis.lba_mid = 0; | ||
| 1566 | fis.device = ATA_DEVICE_OBS; | ||
| 1567 | |||
| 1568 | memset(buffer, 0, sectors * ATA_SECT_SIZE); | ||
| 1569 | |||
| 1570 | return mtip_exec_internal_command(port, | ||
| 1571 | &fis, | ||
| 1572 | 5, | ||
| 1573 | buffer_dma, | ||
| 1574 | sectors * ATA_SECT_SIZE, | ||
| 1575 | 0, | ||
| 1576 | GFP_ATOMIC, | ||
| 1577 | MTIP_INTERNAL_COMMAND_TIMEOUT_MS); | ||
| 1578 | } | ||
| 1579 | |||
| 1580 | /* | ||
| 1581 | * Issue a SMART READ DATA command to the device. | ||
| 1582 | * | ||
| 1583 | * @port pointer to the port structure. | ||
| 1584 | * @buffer pointer to buffer | ||
| 1585 | * @buffer_dma dma address corresponding to @buffer | ||
| 1586 | * | ||
| 1587 | * return value | ||
| 1588 | * @rv return value from mtip_exec_internal_command() | ||
| 1589 | */ | ||
| 1590 | static int mtip_get_smart_data(struct mtip_port *port, u8 *buffer, | ||
| 1591 | dma_addr_t buffer_dma) | ||
| 1592 | { | ||
| 1593 | struct host_to_dev_fis fis; | ||
| 1594 | |||
| 1595 | memset(&fis, 0, sizeof(struct host_to_dev_fis)); | ||
| 1596 | fis.type = 0x27; | ||
| 1597 | fis.opts = 1 << 7; | ||
| 1598 | fis.command = ATA_CMD_SMART; | ||
| 1599 | fis.features = 0xD0; | ||
| 1600 | fis.sect_count = 1; | ||
| 1601 | fis.lba_mid = 0x4F; | ||
| 1602 | fis.lba_hi = 0xC2; | ||
| 1603 | fis.device = ATA_DEVICE_OBS; | ||
| 1604 | |||
| 1605 | return mtip_exec_internal_command(port, | ||
| 1606 | &fis, | ||
| 1607 | 5, | ||
| 1608 | buffer_dma, | ||
| 1609 | ATA_SECT_SIZE, | ||
| 1610 | 0, | ||
| 1611 | GFP_ATOMIC, | ||
| 1612 | 15000); | ||
| 1613 | } | ||
| 1614 | |||
| 1615 | /* | ||
| 1616 | * Get the value of a smart attribute | ||
| 1617 | * | ||
| 1618 | * @port pointer to the port structure | ||
| 1619 | * @id attribute number | ||
| 1620 | * @attrib pointer to return attrib information corresponding to @id | ||
| 1621 | * | ||
| 1622 | * return value | ||
| 1623 | * -EINVAL NULL buffer passed or unsupported attribute @id. | ||
| 1624 | * -EPERM Identify data not valid, SMART not supported or not enabled | ||
| 1625 | */ | ||
| 1626 | static int mtip_get_smart_attr(struct mtip_port *port, unsigned int id, | ||
| 1627 | struct smart_attr *attrib) | ||
| 1628 | { | ||
| 1629 | int rv, i; | ||
| 1630 | struct smart_attr *pattr; | ||
| 1631 | |||
| 1632 | if (!attrib) | ||
| 1633 | return -EINVAL; | ||
| 1634 | |||
| 1635 | if (!port->identify_valid) { | ||
| 1636 | dev_warn(&port->dd->pdev->dev, "IDENTIFY DATA not valid\n"); | ||
| 1637 | return -EPERM; | ||
| 1638 | } | ||
| 1639 | if (!(port->identify[82] & 0x1)) { | ||
| 1640 | dev_warn(&port->dd->pdev->dev, "SMART not supported\n"); | ||
| 1641 | return -EPERM; | ||
| 1642 | } | ||
| 1643 | if (!(port->identify[85] & 0x1)) { | ||
| 1644 | dev_warn(&port->dd->pdev->dev, "SMART not enabled\n"); | ||
| 1645 | return -EPERM; | ||
| 1646 | } | ||
| 1647 | |||
| 1648 | memset(port->smart_buf, 0, ATA_SECT_SIZE); | ||
| 1649 | rv = mtip_get_smart_data(port, port->smart_buf, port->smart_buf_dma); | ||
| 1650 | if (rv) { | ||
| 1651 | dev_warn(&port->dd->pdev->dev, "Failed to ge SMART data\n"); | ||
| 1652 | return rv; | ||
| 1653 | } | ||
| 1654 | |||
| 1655 | pattr = (struct smart_attr *)(port->smart_buf + 2); | ||
| 1656 | for (i = 0; i < 29; i++, pattr++) | ||
| 1657 | if (pattr->attr_id == id) { | ||
| 1658 | memcpy(attrib, pattr, sizeof(struct smart_attr)); | ||
| 1659 | break; | ||
| 1660 | } | ||
| 1661 | |||
| 1662 | if (i == 29) { | ||
| 1663 | dev_warn(&port->dd->pdev->dev, | ||
| 1664 | "Query for invalid SMART attribute ID\n"); | ||
| 1665 | rv = -EINVAL; | ||
| 1666 | } | ||
| 1332 | 1667 | ||
| 1333 | return rv; | 1668 | return rv; |
| 1334 | } | 1669 | } |
| @@ -1504,10 +1839,7 @@ static int exec_drive_task(struct mtip_port *port, u8 *command) | |||
| 1504 | fis.cyl_hi = command[5]; | 1839 | fis.cyl_hi = command[5]; |
| 1505 | fis.device = command[6] & ~0x10; /* Clear the dev bit*/ | 1840 | fis.device = command[6] & ~0x10; /* Clear the dev bit*/ |
| 1506 | 1841 | ||
| 1507 | 1842 | dbg_printk(MTIP_DRV_NAME " %s: User Command: cmd %x, feat %x, nsect %x, sect %x, lcyl %x, hcyl %x, sel %x\n", | |
| 1508 | dbg_printk(MTIP_DRV_NAME "%s: User Command: cmd %x, feat %x, " | ||
| 1509 | "nsect %x, sect %x, lcyl %x, " | ||
| 1510 | "hcyl %x, sel %x\n", | ||
| 1511 | __func__, | 1843 | __func__, |
| 1512 | command[0], | 1844 | command[0], |
| 1513 | command[1], | 1845 | command[1], |
| @@ -1534,8 +1866,7 @@ static int exec_drive_task(struct mtip_port *port, u8 *command) | |||
| 1534 | command[4] = reply->cyl_low; | 1866 | command[4] = reply->cyl_low; |
| 1535 | command[5] = reply->cyl_hi; | 1867 | command[5] = reply->cyl_hi; |
| 1536 | 1868 | ||
| 1537 | dbg_printk(MTIP_DRV_NAME "%s: Completion Status: stat %x, " | 1869 | dbg_printk(MTIP_DRV_NAME " %s: Completion Status: stat %x, err %x , cyl_lo %x cyl_hi %x\n", |
| 1538 | "err %x , cyl_lo %x cyl_hi %x\n", | ||
| 1539 | __func__, | 1870 | __func__, |
| 1540 | command[0], | 1871 | command[0], |
| 1541 | command[1], | 1872 | command[1], |
| @@ -1578,7 +1909,7 @@ static int exec_drive_command(struct mtip_port *port, u8 *command, | |||
| 1578 | } | 1909 | } |
| 1579 | 1910 | ||
| 1580 | dbg_printk(MTIP_DRV_NAME | 1911 | dbg_printk(MTIP_DRV_NAME |
| 1581 | "%s: User Command: cmd %x, sect %x, " | 1912 | " %s: User Command: cmd %x, sect %x, " |
| 1582 | "feat %x, sectcnt %x\n", | 1913 | "feat %x, sectcnt %x\n", |
| 1583 | __func__, | 1914 | __func__, |
| 1584 | command[0], | 1915 | command[0], |
| @@ -1607,7 +1938,7 @@ static int exec_drive_command(struct mtip_port *port, u8 *command, | |||
| 1607 | command[2] = command[3]; | 1938 | command[2] = command[3]; |
| 1608 | 1939 | ||
| 1609 | dbg_printk(MTIP_DRV_NAME | 1940 | dbg_printk(MTIP_DRV_NAME |
| 1610 | "%s: Completion Status: stat %x, " | 1941 | " %s: Completion Status: stat %x, " |
| 1611 | "err %x, cmd %x\n", | 1942 | "err %x, cmd %x\n", |
| 1612 | __func__, | 1943 | __func__, |
| 1613 | command[0], | 1944 | command[0], |
| @@ -1810,9 +2141,10 @@ static int exec_drive_taskfile(struct driver_data *dd, | |||
| 1810 | } | 2141 | } |
| 1811 | 2142 | ||
| 1812 | dbg_printk(MTIP_DRV_NAME | 2143 | dbg_printk(MTIP_DRV_NAME |
| 1813 | "taskfile: cmd %x, feat %x, nsect %x," | 2144 | " %s: cmd %x, feat %x, nsect %x," |
| 1814 | " sect/lbal %x, lcyl/lbam %x, hcyl/lbah %x," | 2145 | " sect/lbal %x, lcyl/lbam %x, hcyl/lbah %x," |
| 1815 | " head/dev %x\n", | 2146 | " head/dev %x\n", |
| 2147 | __func__, | ||
| 1816 | fis.command, | 2148 | fis.command, |
| 1817 | fis.features, | 2149 | fis.features, |
| 1818 | fis.sect_count, | 2150 | fis.sect_count, |
| @@ -1823,8 +2155,8 @@ static int exec_drive_taskfile(struct driver_data *dd, | |||
| 1823 | 2155 | ||
| 1824 | switch (fis.command) { | 2156 | switch (fis.command) { |
| 1825 | case ATA_CMD_DOWNLOAD_MICRO: | 2157 | case ATA_CMD_DOWNLOAD_MICRO: |
| 1826 | /* Change timeout for Download Microcode to 60 seconds.*/ | 2158 | /* Change timeout for Download Microcode to 2 minutes */ |
| 1827 | timeout = 60000; | 2159 | timeout = 120000; |
| 1828 | break; | 2160 | break; |
| 1829 | case ATA_CMD_SEC_ERASE_UNIT: | 2161 | case ATA_CMD_SEC_ERASE_UNIT: |
| 1830 | /* Change timeout for Security Erase Unit to 4 minutes.*/ | 2162 | /* Change timeout for Security Erase Unit to 4 minutes.*/ |
| @@ -1840,8 +2172,8 @@ static int exec_drive_taskfile(struct driver_data *dd, | |||
| 1840 | timeout = 10000; | 2172 | timeout = 10000; |
| 1841 | break; | 2173 | break; |
| 1842 | case ATA_CMD_SMART: | 2174 | case ATA_CMD_SMART: |
| 1843 | /* Change timeout for vendor unique command to 10 secs */ | 2175 | /* Change timeout for vendor unique command to 15 secs */ |
| 1844 | timeout = 10000; | 2176 | timeout = 15000; |
| 1845 | break; | 2177 | break; |
| 1846 | default: | 2178 | default: |
| 1847 | timeout = MTIP_IOCTL_COMMAND_TIMEOUT_MS; | 2179 | timeout = MTIP_IOCTL_COMMAND_TIMEOUT_MS; |
| @@ -1903,18 +2235,8 @@ static int exec_drive_taskfile(struct driver_data *dd, | |||
| 1903 | req_task->hob_ports[1] = reply->features_ex; | 2235 | req_task->hob_ports[1] = reply->features_ex; |
| 1904 | req_task->hob_ports[2] = reply->sect_cnt_ex; | 2236 | req_task->hob_ports[2] = reply->sect_cnt_ex; |
| 1905 | } | 2237 | } |
| 1906 | |||
| 1907 | /* Com rest after secure erase or lowlevel format */ | ||
| 1908 | if (((fis.command == ATA_CMD_SEC_ERASE_UNIT) || | ||
| 1909 | ((fis.command == 0xFC) && | ||
| 1910 | (fis.features == 0x27 || fis.features == 0x72 || | ||
| 1911 | fis.features == 0x62 || fis.features == 0x26))) && | ||
| 1912 | !(reply->command & 1)) { | ||
| 1913 | mtip_restart_port(dd->port); | ||
| 1914 | } | ||
| 1915 | |||
| 1916 | dbg_printk(MTIP_DRV_NAME | 2238 | dbg_printk(MTIP_DRV_NAME |
| 1917 | "%s: Completion: stat %x," | 2239 | " %s: Completion: stat %x," |
| 1918 | "err %x, sect_cnt %x, lbalo %x," | 2240 | "err %x, sect_cnt %x, lbalo %x," |
| 1919 | "lbamid %x, lbahi %x, dev %x\n", | 2241 | "lbamid %x, lbahi %x, dev %x\n", |
| 1920 | __func__, | 2242 | __func__, |
| @@ -2080,14 +2402,10 @@ static void mtip_hw_submit_io(struct driver_data *dd, sector_t start, | |||
| 2080 | struct host_to_dev_fis *fis; | 2402 | struct host_to_dev_fis *fis; |
| 2081 | struct mtip_port *port = dd->port; | 2403 | struct mtip_port *port = dd->port; |
| 2082 | struct mtip_cmd *command = &port->commands[tag]; | 2404 | struct mtip_cmd *command = &port->commands[tag]; |
| 2405 | int dma_dir = (dir == READ) ? DMA_FROM_DEVICE : DMA_TO_DEVICE; | ||
| 2083 | 2406 | ||
| 2084 | /* Map the scatter list for DMA access */ | 2407 | /* Map the scatter list for DMA access */ |
| 2085 | if (dir == READ) | 2408 | nents = dma_map_sg(&dd->pdev->dev, command->sg, nents, dma_dir); |
| 2086 | nents = dma_map_sg(&dd->pdev->dev, command->sg, | ||
| 2087 | nents, DMA_FROM_DEVICE); | ||
| 2088 | else | ||
| 2089 | nents = dma_map_sg(&dd->pdev->dev, command->sg, | ||
| 2090 | nents, DMA_TO_DEVICE); | ||
| 2091 | 2409 | ||
| 2092 | command->scatter_ents = nents; | 2410 | command->scatter_ents = nents; |
| 2093 | 2411 | ||
| @@ -2127,7 +2445,7 @@ static void mtip_hw_submit_io(struct driver_data *dd, sector_t start, | |||
| 2127 | */ | 2445 | */ |
| 2128 | command->comp_data = dd; | 2446 | command->comp_data = dd; |
| 2129 | command->comp_func = mtip_async_complete; | 2447 | command->comp_func = mtip_async_complete; |
| 2130 | command->direction = (dir == READ ? DMA_FROM_DEVICE : DMA_TO_DEVICE); | 2448 | command->direction = dma_dir; |
| 2131 | 2449 | ||
| 2132 | /* | 2450 | /* |
| 2133 | * Set the completion function and data for the command passed | 2451 | * Set the completion function and data for the command passed |
| @@ -2140,19 +2458,16 @@ static void mtip_hw_submit_io(struct driver_data *dd, sector_t start, | |||
| 2140 | * To prevent this command from being issued | 2458 | * To prevent this command from being issued |
| 2141 | * if an internal command is in progress or error handling is active. | 2459 | * if an internal command is in progress or error handling is active. |
| 2142 | */ | 2460 | */ |
| 2143 | if (unlikely(test_bit(MTIP_FLAG_IC_ACTIVE_BIT, &port->flags) || | 2461 | if (port->flags & MTIP_PF_PAUSE_IO) { |
| 2144 | test_bit(MTIP_FLAG_EH_ACTIVE_BIT, &port->flags))) { | ||
| 2145 | set_bit(tag, port->cmds_to_issue); | 2462 | set_bit(tag, port->cmds_to_issue); |
| 2146 | set_bit(MTIP_FLAG_ISSUE_CMDS_BIT, &port->flags); | 2463 | set_bit(MTIP_PF_ISSUE_CMDS_BIT, &port->flags); |
| 2147 | return; | 2464 | return; |
| 2148 | } | 2465 | } |
| 2149 | 2466 | ||
| 2150 | /* Issue the command to the hardware */ | 2467 | /* Issue the command to the hardware */ |
| 2151 | mtip_issue_ncq_command(port, tag); | 2468 | mtip_issue_ncq_command(port, tag); |
| 2152 | 2469 | ||
| 2153 | /* Set the command's timeout value.*/ | 2470 | return; |
| 2154 | port->commands[tag].comp_time = jiffies + msecs_to_jiffies( | ||
| 2155 | MTIP_NCQ_COMMAND_TIMEOUT_MS); | ||
| 2156 | } | 2471 | } |
| 2157 | 2472 | ||
| 2158 | /* | 2473 | /* |
| @@ -2191,6 +2506,10 @@ static struct scatterlist *mtip_hw_get_scatterlist(struct driver_data *dd, | |||
| 2191 | down(&dd->port->cmd_slot); | 2506 | down(&dd->port->cmd_slot); |
| 2192 | *tag = get_slot(dd->port); | 2507 | *tag = get_slot(dd->port); |
| 2193 | 2508 | ||
| 2509 | if (unlikely(test_bit(MTIP_DDF_REMOVE_PENDING_BIT, &dd->dd_flag))) { | ||
| 2510 | up(&dd->port->cmd_slot); | ||
| 2511 | return NULL; | ||
| 2512 | } | ||
| 2194 | if (unlikely(*tag < 0)) | 2513 | if (unlikely(*tag < 0)) |
| 2195 | return NULL; | 2514 | return NULL; |
| 2196 | 2515 | ||
| @@ -2207,7 +2526,7 @@ static struct scatterlist *mtip_hw_get_scatterlist(struct driver_data *dd, | |||
| 2207 | * return value | 2526 | * return value |
| 2208 | * The size, in bytes, of the data copied into buf. | 2527 | * The size, in bytes, of the data copied into buf. |
| 2209 | */ | 2528 | */ |
| 2210 | static ssize_t hw_show_registers(struct device *dev, | 2529 | static ssize_t mtip_hw_show_registers(struct device *dev, |
| 2211 | struct device_attribute *attr, | 2530 | struct device_attribute *attr, |
| 2212 | char *buf) | 2531 | char *buf) |
| 2213 | { | 2532 | { |
| @@ -2216,7 +2535,7 @@ static ssize_t hw_show_registers(struct device *dev, | |||
| 2216 | int size = 0; | 2535 | int size = 0; |
| 2217 | int n; | 2536 | int n; |
| 2218 | 2537 | ||
| 2219 | size += sprintf(&buf[size], "%s:\ns_active:\n", __func__); | 2538 | size += sprintf(&buf[size], "S ACTive:\n"); |
| 2220 | 2539 | ||
| 2221 | for (n = 0; n < dd->slot_groups; n++) | 2540 | for (n = 0; n < dd->slot_groups; n++) |
| 2222 | size += sprintf(&buf[size], "0x%08x\n", | 2541 | size += sprintf(&buf[size], "0x%08x\n", |
| @@ -2240,20 +2559,39 @@ static ssize_t hw_show_registers(struct device *dev, | |||
| 2240 | group_allocated); | 2559 | group_allocated); |
| 2241 | } | 2560 | } |
| 2242 | 2561 | ||
| 2243 | size += sprintf(&buf[size], "completed:\n"); | 2562 | size += sprintf(&buf[size], "Completed:\n"); |
| 2244 | 2563 | ||
| 2245 | for (n = 0; n < dd->slot_groups; n++) | 2564 | for (n = 0; n < dd->slot_groups; n++) |
| 2246 | size += sprintf(&buf[size], "0x%08x\n", | 2565 | size += sprintf(&buf[size], "0x%08x\n", |
| 2247 | readl(dd->port->completed[n])); | 2566 | readl(dd->port->completed[n])); |
| 2248 | 2567 | ||
| 2249 | size += sprintf(&buf[size], "PORT_IRQ_STAT 0x%08x\n", | 2568 | size += sprintf(&buf[size], "PORT IRQ STAT : 0x%08x\n", |
| 2250 | readl(dd->port->mmio + PORT_IRQ_STAT)); | 2569 | readl(dd->port->mmio + PORT_IRQ_STAT)); |
| 2251 | size += sprintf(&buf[size], "HOST_IRQ_STAT 0x%08x\n", | 2570 | size += sprintf(&buf[size], "HOST IRQ STAT : 0x%08x\n", |
| 2252 | readl(dd->mmio + HOST_IRQ_STAT)); | 2571 | readl(dd->mmio + HOST_IRQ_STAT)); |
| 2253 | 2572 | ||
| 2254 | return size; | 2573 | return size; |
| 2255 | } | 2574 | } |
| 2256 | static DEVICE_ATTR(registers, S_IRUGO, hw_show_registers, NULL); | 2575 | |
| 2576 | static ssize_t mtip_hw_show_status(struct device *dev, | ||
| 2577 | struct device_attribute *attr, | ||
| 2578 | char *buf) | ||
| 2579 | { | ||
| 2580 | struct driver_data *dd = dev_to_disk(dev)->private_data; | ||
| 2581 | int size = 0; | ||
| 2582 | |||
| 2583 | if (test_bit(MTIP_DDF_OVER_TEMP_BIT, &dd->dd_flag)) | ||
| 2584 | size += sprintf(buf, "%s", "thermal_shutdown\n"); | ||
| 2585 | else if (test_bit(MTIP_DDF_WRITE_PROTECT_BIT, &dd->dd_flag)) | ||
| 2586 | size += sprintf(buf, "%s", "write_protect\n"); | ||
| 2587 | else | ||
| 2588 | size += sprintf(buf, "%s", "online\n"); | ||
| 2589 | |||
| 2590 | return size; | ||
| 2591 | } | ||
| 2592 | |||
| 2593 | static DEVICE_ATTR(registers, S_IRUGO, mtip_hw_show_registers, NULL); | ||
| 2594 | static DEVICE_ATTR(status, S_IRUGO, mtip_hw_show_status, NULL); | ||
| 2257 | 2595 | ||
| 2258 | /* | 2596 | /* |
| 2259 | * Create the sysfs related attributes. | 2597 | * Create the sysfs related attributes. |
| @@ -2272,7 +2610,10 @@ static int mtip_hw_sysfs_init(struct driver_data *dd, struct kobject *kobj) | |||
| 2272 | 2610 | ||
| 2273 | if (sysfs_create_file(kobj, &dev_attr_registers.attr)) | 2611 | if (sysfs_create_file(kobj, &dev_attr_registers.attr)) |
| 2274 | dev_warn(&dd->pdev->dev, | 2612 | dev_warn(&dd->pdev->dev, |
| 2275 | "Error creating registers sysfs entry\n"); | 2613 | "Error creating 'registers' sysfs entry\n"); |
| 2614 | if (sysfs_create_file(kobj, &dev_attr_status.attr)) | ||
| 2615 | dev_warn(&dd->pdev->dev, | ||
| 2616 | "Error creating 'status' sysfs entry\n"); | ||
| 2276 | return 0; | 2617 | return 0; |
| 2277 | } | 2618 | } |
| 2278 | 2619 | ||
| @@ -2292,6 +2633,7 @@ static int mtip_hw_sysfs_exit(struct driver_data *dd, struct kobject *kobj) | |||
| 2292 | return -EINVAL; | 2633 | return -EINVAL; |
| 2293 | 2634 | ||
| 2294 | sysfs_remove_file(kobj, &dev_attr_registers.attr); | 2635 | sysfs_remove_file(kobj, &dev_attr_registers.attr); |
| 2636 | sysfs_remove_file(kobj, &dev_attr_status.attr); | ||
| 2295 | 2637 | ||
| 2296 | return 0; | 2638 | return 0; |
| 2297 | } | 2639 | } |
| @@ -2384,10 +2726,12 @@ static int mtip_ftl_rebuild_poll(struct driver_data *dd) | |||
| 2384 | "FTL rebuild in progress. Polling for completion.\n"); | 2726 | "FTL rebuild in progress. Polling for completion.\n"); |
| 2385 | 2727 | ||
| 2386 | start = jiffies; | 2728 | start = jiffies; |
| 2387 | dd->ftlrebuildflag = 1; | ||
| 2388 | timeout = jiffies + msecs_to_jiffies(MTIP_FTL_REBUILD_TIMEOUT_MS); | 2729 | timeout = jiffies + msecs_to_jiffies(MTIP_FTL_REBUILD_TIMEOUT_MS); |
| 2389 | 2730 | ||
| 2390 | do { | 2731 | do { |
| 2732 | if (unlikely(test_bit(MTIP_DDF_REMOVE_PENDING_BIT, | ||
| 2733 | &dd->dd_flag))) | ||
| 2734 | return -EFAULT; | ||
| 2391 | if (mtip_check_surprise_removal(dd->pdev)) | 2735 | if (mtip_check_surprise_removal(dd->pdev)) |
| 2392 | return -EFAULT; | 2736 | return -EFAULT; |
| 2393 | 2737 | ||
| @@ -2408,22 +2752,17 @@ static int mtip_ftl_rebuild_poll(struct driver_data *dd) | |||
| 2408 | dev_warn(&dd->pdev->dev, | 2752 | dev_warn(&dd->pdev->dev, |
| 2409 | "FTL rebuild complete (%d secs).\n", | 2753 | "FTL rebuild complete (%d secs).\n", |
| 2410 | jiffies_to_msecs(jiffies - start) / 1000); | 2754 | jiffies_to_msecs(jiffies - start) / 1000); |
| 2411 | dd->ftlrebuildflag = 0; | ||
| 2412 | mtip_block_initialize(dd); | 2755 | mtip_block_initialize(dd); |
| 2413 | break; | 2756 | return 0; |
| 2414 | } | 2757 | } |
| 2415 | ssleep(10); | 2758 | ssleep(10); |
| 2416 | } while (time_before(jiffies, timeout)); | 2759 | } while (time_before(jiffies, timeout)); |
| 2417 | 2760 | ||
| 2418 | /* Check for timeout */ | 2761 | /* Check for timeout */ |
| 2419 | if (dd->ftlrebuildflag) { | 2762 | dev_err(&dd->pdev->dev, |
| 2420 | dev_err(&dd->pdev->dev, | ||
| 2421 | "Timed out waiting for FTL rebuild to complete (%d secs).\n", | 2763 | "Timed out waiting for FTL rebuild to complete (%d secs).\n", |
| 2422 | jiffies_to_msecs(jiffies - start) / 1000); | 2764 | jiffies_to_msecs(jiffies - start) / 1000); |
| 2423 | return -EFAULT; | 2765 | return -EFAULT; |
| 2424 | } | ||
| 2425 | |||
| 2426 | return 0; | ||
| 2427 | } | 2766 | } |
| 2428 | 2767 | ||
| 2429 | /* | 2768 | /* |
| @@ -2448,14 +2787,17 @@ static int mtip_service_thread(void *data) | |||
| 2448 | * is in progress nor error handling is active | 2787 | * is in progress nor error handling is active |
| 2449 | */ | 2788 | */ |
| 2450 | wait_event_interruptible(port->svc_wait, (port->flags) && | 2789 | wait_event_interruptible(port->svc_wait, (port->flags) && |
| 2451 | !test_bit(MTIP_FLAG_IC_ACTIVE_BIT, &port->flags) && | 2790 | !(port->flags & MTIP_PF_PAUSE_IO)); |
| 2452 | !test_bit(MTIP_FLAG_EH_ACTIVE_BIT, &port->flags)); | ||
| 2453 | 2791 | ||
| 2454 | if (kthread_should_stop()) | 2792 | if (kthread_should_stop()) |
| 2455 | break; | 2793 | break; |
| 2456 | 2794 | ||
| 2457 | set_bit(MTIP_FLAG_SVC_THD_ACTIVE_BIT, &port->flags); | 2795 | if (unlikely(test_bit(MTIP_DDF_REMOVE_PENDING_BIT, |
| 2458 | if (test_bit(MTIP_FLAG_ISSUE_CMDS_BIT, &port->flags)) { | 2796 | &dd->dd_flag))) |
| 2797 | break; | ||
| 2798 | |||
| 2799 | set_bit(MTIP_PF_SVC_THD_ACTIVE_BIT, &port->flags); | ||
| 2800 | if (test_bit(MTIP_PF_ISSUE_CMDS_BIT, &port->flags)) { | ||
| 2459 | slot = 1; | 2801 | slot = 1; |
| 2460 | /* used to restrict the loop to one iteration */ | 2802 | /* used to restrict the loop to one iteration */ |
| 2461 | slot_start = num_cmd_slots; | 2803 | slot_start = num_cmd_slots; |
| @@ -2480,21 +2822,19 @@ static int mtip_service_thread(void *data) | |||
| 2480 | /* Issue the command to the hardware */ | 2822 | /* Issue the command to the hardware */ |
| 2481 | mtip_issue_ncq_command(port, slot); | 2823 | mtip_issue_ncq_command(port, slot); |
| 2482 | 2824 | ||
| 2483 | /* Set the command's timeout value.*/ | ||
| 2484 | port->commands[slot].comp_time = jiffies + | ||
| 2485 | msecs_to_jiffies(MTIP_NCQ_COMMAND_TIMEOUT_MS); | ||
| 2486 | |||
| 2487 | clear_bit(slot, port->cmds_to_issue); | 2825 | clear_bit(slot, port->cmds_to_issue); |
| 2488 | } | 2826 | } |
| 2489 | 2827 | ||
| 2490 | clear_bit(MTIP_FLAG_ISSUE_CMDS_BIT, &port->flags); | 2828 | clear_bit(MTIP_PF_ISSUE_CMDS_BIT, &port->flags); |
| 2491 | } else if (test_bit(MTIP_FLAG_REBUILD_BIT, &port->flags)) { | 2829 | } else if (test_bit(MTIP_PF_REBUILD_BIT, &port->flags)) { |
| 2492 | mtip_ftl_rebuild_poll(dd); | 2830 | if (!mtip_ftl_rebuild_poll(dd)) |
| 2493 | clear_bit(MTIP_FLAG_REBUILD_BIT, &port->flags); | 2831 | set_bit(MTIP_DDF_REBUILD_FAILED_BIT, |
| 2832 | &dd->dd_flag); | ||
| 2833 | clear_bit(MTIP_PF_REBUILD_BIT, &port->flags); | ||
| 2494 | } | 2834 | } |
| 2495 | clear_bit(MTIP_FLAG_SVC_THD_ACTIVE_BIT, &port->flags); | 2835 | clear_bit(MTIP_PF_SVC_THD_ACTIVE_BIT, &port->flags); |
| 2496 | 2836 | ||
| 2497 | if (test_bit(MTIP_FLAG_SVC_THD_SHOULD_STOP_BIT, &port->flags)) | 2837 | if (test_bit(MTIP_PF_SVC_THD_STOP_BIT, &port->flags)) |
| 2498 | break; | 2838 | break; |
| 2499 | } | 2839 | } |
| 2500 | return 0; | 2840 | return 0; |
| @@ -2513,6 +2853,9 @@ static int mtip_hw_init(struct driver_data *dd) | |||
| 2513 | int i; | 2853 | int i; |
| 2514 | int rv; | 2854 | int rv; |
| 2515 | unsigned int num_command_slots; | 2855 | unsigned int num_command_slots; |
| 2856 | unsigned long timeout, timetaken; | ||
| 2857 | unsigned char *buf; | ||
| 2858 | struct smart_attr attr242; | ||
| 2516 | 2859 | ||
| 2517 | dd->mmio = pcim_iomap_table(dd->pdev)[MTIP_ABAR]; | 2860 | dd->mmio = pcim_iomap_table(dd->pdev)[MTIP_ABAR]; |
| 2518 | 2861 | ||
| @@ -2547,7 +2890,7 @@ static int mtip_hw_init(struct driver_data *dd) | |||
| 2547 | /* Allocate memory for the command list. */ | 2890 | /* Allocate memory for the command list. */ |
| 2548 | dd->port->command_list = | 2891 | dd->port->command_list = |
| 2549 | dmam_alloc_coherent(&dd->pdev->dev, | 2892 | dmam_alloc_coherent(&dd->pdev->dev, |
| 2550 | HW_PORT_PRIV_DMA_SZ + (ATA_SECT_SIZE * 2), | 2893 | HW_PORT_PRIV_DMA_SZ + (ATA_SECT_SIZE * 4), |
| 2551 | &dd->port->command_list_dma, | 2894 | &dd->port->command_list_dma, |
| 2552 | GFP_KERNEL); | 2895 | GFP_KERNEL); |
| 2553 | if (!dd->port->command_list) { | 2896 | if (!dd->port->command_list) { |
| @@ -2560,7 +2903,7 @@ static int mtip_hw_init(struct driver_data *dd) | |||
| 2560 | /* Clear the memory we have allocated. */ | 2903 | /* Clear the memory we have allocated. */ |
| 2561 | memset(dd->port->command_list, | 2904 | memset(dd->port->command_list, |
| 2562 | 0, | 2905 | 0, |
| 2563 | HW_PORT_PRIV_DMA_SZ + (ATA_SECT_SIZE * 2)); | 2906 | HW_PORT_PRIV_DMA_SZ + (ATA_SECT_SIZE * 4)); |
| 2564 | 2907 | ||
| 2565 | /* Setup the addresse of the RX FIS. */ | 2908 | /* Setup the addresse of the RX FIS. */ |
| 2566 | dd->port->rxfis = dd->port->command_list + HW_CMD_SLOT_SZ; | 2909 | dd->port->rxfis = dd->port->command_list + HW_CMD_SLOT_SZ; |
| @@ -2576,10 +2919,19 @@ static int mtip_hw_init(struct driver_data *dd) | |||
| 2576 | dd->port->identify_dma = dd->port->command_tbl_dma + | 2919 | dd->port->identify_dma = dd->port->command_tbl_dma + |
| 2577 | HW_CMD_TBL_AR_SZ; | 2920 | HW_CMD_TBL_AR_SZ; |
| 2578 | 2921 | ||
| 2579 | /* Setup the address of the sector buffer. */ | 2922 | /* Setup the address of the sector buffer - for some non-ncq cmds */ |
| 2580 | dd->port->sector_buffer = (void *) dd->port->identify + ATA_SECT_SIZE; | 2923 | dd->port->sector_buffer = (void *) dd->port->identify + ATA_SECT_SIZE; |
| 2581 | dd->port->sector_buffer_dma = dd->port->identify_dma + ATA_SECT_SIZE; | 2924 | dd->port->sector_buffer_dma = dd->port->identify_dma + ATA_SECT_SIZE; |
| 2582 | 2925 | ||
| 2926 | /* Setup the address of the log buf - for read log command */ | ||
| 2927 | dd->port->log_buf = (void *)dd->port->sector_buffer + ATA_SECT_SIZE; | ||
| 2928 | dd->port->log_buf_dma = dd->port->sector_buffer_dma + ATA_SECT_SIZE; | ||
| 2929 | |||
| 2930 | /* Setup the address of the smart buf - for smart read data command */ | ||
| 2931 | dd->port->smart_buf = (void *)dd->port->log_buf + ATA_SECT_SIZE; | ||
| 2932 | dd->port->smart_buf_dma = dd->port->log_buf_dma + ATA_SECT_SIZE; | ||
| 2933 | |||
| 2934 | |||
| 2583 | /* Point the command headers at the command tables. */ | 2935 | /* Point the command headers at the command tables. */ |
| 2584 | for (i = 0; i < num_command_slots; i++) { | 2936 | for (i = 0; i < num_command_slots; i++) { |
| 2585 | dd->port->commands[i].command_header = | 2937 | dd->port->commands[i].command_header = |
| @@ -2623,14 +2975,43 @@ static int mtip_hw_init(struct driver_data *dd) | |||
| 2623 | dd->port->mmio + i*0x80 + PORT_SDBV; | 2975 | dd->port->mmio + i*0x80 + PORT_SDBV; |
| 2624 | } | 2976 | } |
| 2625 | 2977 | ||
| 2626 | /* Reset the HBA. */ | 2978 | timetaken = jiffies; |
| 2627 | if (mtip_hba_reset(dd) < 0) { | 2979 | timeout = jiffies + msecs_to_jiffies(30000); |
| 2628 | dev_err(&dd->pdev->dev, | 2980 | while (((readl(dd->port->mmio + PORT_SCR_STAT) & 0x0F) != 0x03) && |
| 2629 | "Card did not reset within timeout\n"); | 2981 | time_before(jiffies, timeout)) { |
| 2630 | rv = -EIO; | 2982 | mdelay(100); |
| 2983 | } | ||
| 2984 | if (unlikely(mtip_check_surprise_removal(dd->pdev))) { | ||
| 2985 | timetaken = jiffies - timetaken; | ||
| 2986 | dev_warn(&dd->pdev->dev, | ||
| 2987 | "Surprise removal detected at %u ms\n", | ||
| 2988 | jiffies_to_msecs(timetaken)); | ||
| 2989 | rv = -ENODEV; | ||
| 2990 | goto out2 ; | ||
| 2991 | } | ||
| 2992 | if (unlikely(test_bit(MTIP_DDF_REMOVE_PENDING_BIT, &dd->dd_flag))) { | ||
| 2993 | timetaken = jiffies - timetaken; | ||
| 2994 | dev_warn(&dd->pdev->dev, | ||
| 2995 | "Removal detected at %u ms\n", | ||
| 2996 | jiffies_to_msecs(timetaken)); | ||
| 2997 | rv = -EFAULT; | ||
| 2631 | goto out2; | 2998 | goto out2; |
| 2632 | } | 2999 | } |
| 2633 | 3000 | ||
| 3001 | /* Conditionally reset the HBA. */ | ||
| 3002 | if (!(readl(dd->mmio + HOST_CAP) & HOST_CAP_NZDMA)) { | ||
| 3003 | if (mtip_hba_reset(dd) < 0) { | ||
| 3004 | dev_err(&dd->pdev->dev, | ||
| 3005 | "Card did not reset within timeout\n"); | ||
| 3006 | rv = -EIO; | ||
| 3007 | goto out2; | ||
| 3008 | } | ||
| 3009 | } else { | ||
| 3010 | /* Clear any pending interrupts on the HBA */ | ||
| 3011 | writel(readl(dd->mmio + HOST_IRQ_STAT), | ||
| 3012 | dd->mmio + HOST_IRQ_STAT); | ||
| 3013 | } | ||
| 3014 | |||
| 2634 | mtip_init_port(dd->port); | 3015 | mtip_init_port(dd->port); |
| 2635 | mtip_start_port(dd->port); | 3016 | mtip_start_port(dd->port); |
| 2636 | 3017 | ||
| @@ -2660,6 +3041,12 @@ static int mtip_hw_init(struct driver_data *dd) | |||
| 2660 | mod_timer(&dd->port->cmd_timer, | 3041 | mod_timer(&dd->port->cmd_timer, |
| 2661 | jiffies + msecs_to_jiffies(MTIP_TIMEOUT_CHECK_PERIOD)); | 3042 | jiffies + msecs_to_jiffies(MTIP_TIMEOUT_CHECK_PERIOD)); |
| 2662 | 3043 | ||
| 3044 | |||
| 3045 | if (test_bit(MTIP_DDF_REMOVE_PENDING_BIT, &dd->dd_flag)) { | ||
| 3046 | rv = -EFAULT; | ||
| 3047 | goto out3; | ||
| 3048 | } | ||
| 3049 | |||
| 2663 | if (mtip_get_identify(dd->port, NULL) < 0) { | 3050 | if (mtip_get_identify(dd->port, NULL) < 0) { |
| 2664 | rv = -EFAULT; | 3051 | rv = -EFAULT; |
| 2665 | goto out3; | 3052 | goto out3; |
| @@ -2667,10 +3054,47 @@ static int mtip_hw_init(struct driver_data *dd) | |||
| 2667 | 3054 | ||
| 2668 | if (*(dd->port->identify + MTIP_FTL_REBUILD_OFFSET) == | 3055 | if (*(dd->port->identify + MTIP_FTL_REBUILD_OFFSET) == |
| 2669 | MTIP_FTL_REBUILD_MAGIC) { | 3056 | MTIP_FTL_REBUILD_MAGIC) { |
| 2670 | set_bit(MTIP_FLAG_REBUILD_BIT, &dd->port->flags); | 3057 | set_bit(MTIP_PF_REBUILD_BIT, &dd->port->flags); |
| 2671 | return MTIP_FTL_REBUILD_MAGIC; | 3058 | return MTIP_FTL_REBUILD_MAGIC; |
| 2672 | } | 3059 | } |
| 2673 | mtip_dump_identify(dd->port); | 3060 | mtip_dump_identify(dd->port); |
| 3061 | |||
| 3062 | /* check write protect, over temp and rebuild statuses */ | ||
| 3063 | rv = mtip_read_log_page(dd->port, ATA_LOG_SATA_NCQ, | ||
| 3064 | dd->port->log_buf, | ||
| 3065 | dd->port->log_buf_dma, 1); | ||
| 3066 | if (rv) { | ||
| 3067 | dev_warn(&dd->pdev->dev, | ||
| 3068 | "Error in READ LOG EXT (10h) command\n"); | ||
| 3069 | /* non-critical error, don't fail the load */ | ||
| 3070 | } else { | ||
| 3071 | buf = (unsigned char *)dd->port->log_buf; | ||
| 3072 | if (buf[259] & 0x1) { | ||
| 3073 | dev_info(&dd->pdev->dev, | ||
| 3074 | "Write protect bit is set.\n"); | ||
| 3075 | set_bit(MTIP_DDF_WRITE_PROTECT_BIT, &dd->dd_flag); | ||
| 3076 | } | ||
| 3077 | if (buf[288] == 0xF7) { | ||
| 3078 | dev_info(&dd->pdev->dev, | ||
| 3079 | "Exceeded Tmax, drive in thermal shutdown.\n"); | ||
| 3080 | set_bit(MTIP_DDF_OVER_TEMP_BIT, &dd->dd_flag); | ||
| 3081 | } | ||
| 3082 | if (buf[288] == 0xBF) { | ||
| 3083 | dev_info(&dd->pdev->dev, | ||
| 3084 | "Drive indicates rebuild has failed.\n"); | ||
| 3085 | /* TODO */ | ||
| 3086 | } | ||
| 3087 | } | ||
| 3088 | |||
| 3089 | /* get write protect progess */ | ||
| 3090 | memset(&attr242, 0, sizeof(struct smart_attr)); | ||
| 3091 | if (mtip_get_smart_attr(dd->port, 242, &attr242)) | ||
| 3092 | dev_warn(&dd->pdev->dev, | ||
| 3093 | "Unable to check write protect progress\n"); | ||
| 3094 | else | ||
| 3095 | dev_info(&dd->pdev->dev, | ||
| 3096 | "Write protect progress: %d%% (%d blocks)\n", | ||
| 3097 | attr242.cur, attr242.data); | ||
| 2674 | return rv; | 3098 | return rv; |
| 2675 | 3099 | ||
| 2676 | out3: | 3100 | out3: |
| @@ -2688,7 +3112,7 @@ out2: | |||
| 2688 | 3112 | ||
| 2689 | /* Free the command/command header memory. */ | 3113 | /* Free the command/command header memory. */ |
| 2690 | dmam_free_coherent(&dd->pdev->dev, | 3114 | dmam_free_coherent(&dd->pdev->dev, |
| 2691 | HW_PORT_PRIV_DMA_SZ + (ATA_SECT_SIZE * 2), | 3115 | HW_PORT_PRIV_DMA_SZ + (ATA_SECT_SIZE * 4), |
| 2692 | dd->port->command_list, | 3116 | dd->port->command_list, |
| 2693 | dd->port->command_list_dma); | 3117 | dd->port->command_list_dma); |
| 2694 | out1: | 3118 | out1: |
| @@ -2712,9 +3136,12 @@ static int mtip_hw_exit(struct driver_data *dd) | |||
| 2712 | * Send standby immediate (E0h) to the drive so that it | 3136 | * Send standby immediate (E0h) to the drive so that it |
| 2713 | * saves its state. | 3137 | * saves its state. |
| 2714 | */ | 3138 | */ |
| 2715 | if (atomic_read(&dd->drv_cleanup_done) != true) { | 3139 | if (!test_bit(MTIP_DDF_CLEANUP_BIT, &dd->dd_flag)) { |
| 2716 | 3140 | ||
| 2717 | mtip_standby_immediate(dd->port); | 3141 | if (!test_bit(MTIP_PF_REBUILD_BIT, &dd->port->flags)) |
| 3142 | if (mtip_standby_immediate(dd->port)) | ||
| 3143 | dev_warn(&dd->pdev->dev, | ||
| 3144 | "STANDBY IMMEDIATE failed\n"); | ||
| 2718 | 3145 | ||
| 2719 | /* de-initialize the port. */ | 3146 | /* de-initialize the port. */ |
| 2720 | mtip_deinit_port(dd->port); | 3147 | mtip_deinit_port(dd->port); |
| @@ -2734,7 +3161,7 @@ static int mtip_hw_exit(struct driver_data *dd) | |||
| 2734 | 3161 | ||
| 2735 | /* Free the command/command header memory. */ | 3162 | /* Free the command/command header memory. */ |
| 2736 | dmam_free_coherent(&dd->pdev->dev, | 3163 | dmam_free_coherent(&dd->pdev->dev, |
| 2737 | HW_PORT_PRIV_DMA_SZ + (ATA_SECT_SIZE * 2), | 3164 | HW_PORT_PRIV_DMA_SZ + (ATA_SECT_SIZE * 4), |
| 2738 | dd->port->command_list, | 3165 | dd->port->command_list, |
| 2739 | dd->port->command_list_dma); | 3166 | dd->port->command_list_dma); |
| 2740 | /* Free the memory allocated for the for structure. */ | 3167 | /* Free the memory allocated for the for structure. */ |
| @@ -2892,6 +3319,9 @@ static int mtip_block_ioctl(struct block_device *dev, | |||
| 2892 | if (!dd) | 3319 | if (!dd) |
| 2893 | return -ENOTTY; | 3320 | return -ENOTTY; |
| 2894 | 3321 | ||
| 3322 | if (unlikely(test_bit(MTIP_DDF_REMOVE_PENDING_BIT, &dd->dd_flag))) | ||
| 3323 | return -ENOTTY; | ||
| 3324 | |||
| 2895 | switch (cmd) { | 3325 | switch (cmd) { |
| 2896 | case BLKFLSBUF: | 3326 | case BLKFLSBUF: |
| 2897 | return -ENOTTY; | 3327 | return -ENOTTY; |
| @@ -2927,6 +3357,9 @@ static int mtip_block_compat_ioctl(struct block_device *dev, | |||
| 2927 | if (!dd) | 3357 | if (!dd) |
| 2928 | return -ENOTTY; | 3358 | return -ENOTTY; |
| 2929 | 3359 | ||
| 3360 | if (unlikely(test_bit(MTIP_DDF_REMOVE_PENDING_BIT, &dd->dd_flag))) | ||
| 3361 | return -ENOTTY; | ||
| 3362 | |||
| 2930 | switch (cmd) { | 3363 | switch (cmd) { |
| 2931 | case BLKFLSBUF: | 3364 | case BLKFLSBUF: |
| 2932 | return -ENOTTY; | 3365 | return -ENOTTY; |
| @@ -3049,6 +3482,24 @@ static void mtip_make_request(struct request_queue *queue, struct bio *bio) | |||
| 3049 | int nents = 0; | 3482 | int nents = 0; |
| 3050 | int tag = 0; | 3483 | int tag = 0; |
| 3051 | 3484 | ||
| 3485 | if (unlikely(dd->dd_flag & MTIP_DDF_STOP_IO)) { | ||
| 3486 | if (unlikely(test_bit(MTIP_DDF_REMOVE_PENDING_BIT, | ||
| 3487 | &dd->dd_flag))) { | ||
| 3488 | bio_endio(bio, -ENXIO); | ||
| 3489 | return; | ||
| 3490 | } | ||
| 3491 | if (unlikely(test_bit(MTIP_DDF_OVER_TEMP_BIT, &dd->dd_flag))) { | ||
| 3492 | bio_endio(bio, -ENODATA); | ||
| 3493 | return; | ||
| 3494 | } | ||
| 3495 | if (unlikely(test_bit(MTIP_DDF_WRITE_PROTECT_BIT, | ||
| 3496 | &dd->dd_flag) && | ||
| 3497 | bio_data_dir(bio))) { | ||
| 3498 | bio_endio(bio, -ENODATA); | ||
| 3499 | return; | ||
| 3500 | } | ||
| 3501 | } | ||
| 3502 | |||
| 3052 | if (unlikely(!bio_has_data(bio))) { | 3503 | if (unlikely(!bio_has_data(bio))) { |
| 3053 | blk_queue_flush(queue, 0); | 3504 | blk_queue_flush(queue, 0); |
| 3054 | bio_endio(bio, 0); | 3505 | bio_endio(bio, 0); |
| @@ -3061,7 +3512,7 @@ static void mtip_make_request(struct request_queue *queue, struct bio *bio) | |||
| 3061 | 3512 | ||
| 3062 | if (unlikely((bio)->bi_vcnt > MTIP_MAX_SG)) { | 3513 | if (unlikely((bio)->bi_vcnt > MTIP_MAX_SG)) { |
| 3063 | dev_warn(&dd->pdev->dev, | 3514 | dev_warn(&dd->pdev->dev, |
| 3064 | "Maximum number of SGL entries exceeded"); | 3515 | "Maximum number of SGL entries exceeded\n"); |
| 3065 | bio_io_error(bio); | 3516 | bio_io_error(bio); |
| 3066 | mtip_hw_release_scatterlist(dd, tag); | 3517 | mtip_hw_release_scatterlist(dd, tag); |
| 3067 | return; | 3518 | return; |
| @@ -3210,8 +3661,10 @@ skip_create_disk: | |||
| 3210 | kobject_put(kobj); | 3661 | kobject_put(kobj); |
| 3211 | } | 3662 | } |
| 3212 | 3663 | ||
| 3213 | if (dd->mtip_svc_handler) | 3664 | if (dd->mtip_svc_handler) { |
| 3665 | set_bit(MTIP_DDF_INIT_DONE_BIT, &dd->dd_flag); | ||
| 3214 | return rv; /* service thread created for handling rebuild */ | 3666 | return rv; /* service thread created for handling rebuild */ |
| 3667 | } | ||
| 3215 | 3668 | ||
| 3216 | start_service_thread: | 3669 | start_service_thread: |
| 3217 | sprintf(thd_name, "mtip_svc_thd_%02d", index); | 3670 | sprintf(thd_name, "mtip_svc_thd_%02d", index); |
| @@ -3220,12 +3673,15 @@ start_service_thread: | |||
| 3220 | dd, thd_name); | 3673 | dd, thd_name); |
| 3221 | 3674 | ||
| 3222 | if (IS_ERR(dd->mtip_svc_handler)) { | 3675 | if (IS_ERR(dd->mtip_svc_handler)) { |
| 3223 | printk(KERN_ERR "mtip32xx: service thread failed to start\n"); | 3676 | dev_err(&dd->pdev->dev, "service thread failed to start\n"); |
| 3224 | dd->mtip_svc_handler = NULL; | 3677 | dd->mtip_svc_handler = NULL; |
| 3225 | rv = -EFAULT; | 3678 | rv = -EFAULT; |
| 3226 | goto kthread_run_error; | 3679 | goto kthread_run_error; |
| 3227 | } | 3680 | } |
| 3228 | 3681 | ||
| 3682 | if (wait_for_rebuild == MTIP_FTL_REBUILD_MAGIC) | ||
| 3683 | rv = wait_for_rebuild; | ||
| 3684 | |||
| 3229 | return rv; | 3685 | return rv; |
| 3230 | 3686 | ||
| 3231 | kthread_run_error: | 3687 | kthread_run_error: |
| @@ -3266,16 +3722,18 @@ static int mtip_block_remove(struct driver_data *dd) | |||
| 3266 | struct kobject *kobj; | 3722 | struct kobject *kobj; |
| 3267 | 3723 | ||
| 3268 | if (dd->mtip_svc_handler) { | 3724 | if (dd->mtip_svc_handler) { |
| 3269 | set_bit(MTIP_FLAG_SVC_THD_SHOULD_STOP_BIT, &dd->port->flags); | 3725 | set_bit(MTIP_PF_SVC_THD_STOP_BIT, &dd->port->flags); |
| 3270 | wake_up_interruptible(&dd->port->svc_wait); | 3726 | wake_up_interruptible(&dd->port->svc_wait); |
| 3271 | kthread_stop(dd->mtip_svc_handler); | 3727 | kthread_stop(dd->mtip_svc_handler); |
| 3272 | } | 3728 | } |
| 3273 | 3729 | ||
| 3274 | /* Clean up the sysfs attributes managed by the protocol layer. */ | 3730 | /* Clean up the sysfs attributes, if created */ |
| 3275 | kobj = kobject_get(&disk_to_dev(dd->disk)->kobj); | 3731 | if (test_bit(MTIP_DDF_INIT_DONE_BIT, &dd->dd_flag)) { |
| 3276 | if (kobj) { | 3732 | kobj = kobject_get(&disk_to_dev(dd->disk)->kobj); |
| 3277 | mtip_hw_sysfs_exit(dd, kobj); | 3733 | if (kobj) { |
| 3278 | kobject_put(kobj); | 3734 | mtip_hw_sysfs_exit(dd, kobj); |
| 3735 | kobject_put(kobj); | ||
| 3736 | } | ||
| 3279 | } | 3737 | } |
| 3280 | 3738 | ||
| 3281 | /* | 3739 | /* |
| @@ -3283,6 +3741,11 @@ static int mtip_block_remove(struct driver_data *dd) | |||
| 3283 | * from /dev | 3741 | * from /dev |
| 3284 | */ | 3742 | */ |
| 3285 | del_gendisk(dd->disk); | 3743 | del_gendisk(dd->disk); |
| 3744 | |||
| 3745 | spin_lock(&rssd_index_lock); | ||
| 3746 | ida_remove(&rssd_index_ida, dd->index); | ||
| 3747 | spin_unlock(&rssd_index_lock); | ||
| 3748 | |||
| 3286 | blk_cleanup_queue(dd->queue); | 3749 | blk_cleanup_queue(dd->queue); |
| 3287 | dd->disk = NULL; | 3750 | dd->disk = NULL; |
| 3288 | dd->queue = NULL; | 3751 | dd->queue = NULL; |
| @@ -3312,6 +3775,11 @@ static int mtip_block_shutdown(struct driver_data *dd) | |||
| 3312 | 3775 | ||
| 3313 | /* Delete our gendisk structure, and cleanup the blk queue. */ | 3776 | /* Delete our gendisk structure, and cleanup the blk queue. */ |
| 3314 | del_gendisk(dd->disk); | 3777 | del_gendisk(dd->disk); |
| 3778 | |||
| 3779 | spin_lock(&rssd_index_lock); | ||
| 3780 | ida_remove(&rssd_index_ida, dd->index); | ||
| 3781 | spin_unlock(&rssd_index_lock); | ||
| 3782 | |||
| 3315 | blk_cleanup_queue(dd->queue); | 3783 | blk_cleanup_queue(dd->queue); |
| 3316 | dd->disk = NULL; | 3784 | dd->disk = NULL; |
| 3317 | dd->queue = NULL; | 3785 | dd->queue = NULL; |
| @@ -3359,11 +3827,6 @@ static int mtip_pci_probe(struct pci_dev *pdev, | |||
| 3359 | return -ENOMEM; | 3827 | return -ENOMEM; |
| 3360 | } | 3828 | } |
| 3361 | 3829 | ||
| 3362 | /* Set the atomic variable as 1 in case of SRSI */ | ||
| 3363 | atomic_set(&dd->drv_cleanup_done, true); | ||
| 3364 | |||
| 3365 | atomic_set(&dd->resumeflag, false); | ||
| 3366 | |||
| 3367 | /* Attach the private data to this PCI device. */ | 3830 | /* Attach the private data to this PCI device. */ |
| 3368 | pci_set_drvdata(pdev, dd); | 3831 | pci_set_drvdata(pdev, dd); |
| 3369 | 3832 | ||
| @@ -3420,7 +3883,8 @@ static int mtip_pci_probe(struct pci_dev *pdev, | |||
| 3420 | * instance number. | 3883 | * instance number. |
| 3421 | */ | 3884 | */ |
| 3422 | instance++; | 3885 | instance++; |
| 3423 | 3886 | if (rv != MTIP_FTL_REBUILD_MAGIC) | |
| 3887 | set_bit(MTIP_DDF_INIT_DONE_BIT, &dd->dd_flag); | ||
| 3424 | goto done; | 3888 | goto done; |
| 3425 | 3889 | ||
| 3426 | block_initialize_err: | 3890 | block_initialize_err: |
| @@ -3434,9 +3898,6 @@ iomap_err: | |||
| 3434 | pci_set_drvdata(pdev, NULL); | 3898 | pci_set_drvdata(pdev, NULL); |
| 3435 | return rv; | 3899 | return rv; |
| 3436 | done: | 3900 | done: |
| 3437 | /* Set the atomic variable as 0 in case of SRSI */ | ||
| 3438 | atomic_set(&dd->drv_cleanup_done, true); | ||
| 3439 | |||
| 3440 | return rv; | 3901 | return rv; |
| 3441 | } | 3902 | } |
| 3442 | 3903 | ||
| @@ -3452,8 +3913,10 @@ static void mtip_pci_remove(struct pci_dev *pdev) | |||
| 3452 | struct driver_data *dd = pci_get_drvdata(pdev); | 3913 | struct driver_data *dd = pci_get_drvdata(pdev); |
| 3453 | int counter = 0; | 3914 | int counter = 0; |
| 3454 | 3915 | ||
| 3916 | set_bit(MTIP_DDF_REMOVE_PENDING_BIT, &dd->dd_flag); | ||
| 3917 | |||
| 3455 | if (mtip_check_surprise_removal(pdev)) { | 3918 | if (mtip_check_surprise_removal(pdev)) { |
| 3456 | while (atomic_read(&dd->drv_cleanup_done) == false) { | 3919 | while (!test_bit(MTIP_DDF_CLEANUP_BIT, &dd->dd_flag)) { |
| 3457 | counter++; | 3920 | counter++; |
| 3458 | msleep(20); | 3921 | msleep(20); |
| 3459 | if (counter == 10) { | 3922 | if (counter == 10) { |
| @@ -3463,8 +3926,6 @@ static void mtip_pci_remove(struct pci_dev *pdev) | |||
| 3463 | } | 3926 | } |
| 3464 | } | 3927 | } |
| 3465 | } | 3928 | } |
| 3466 | /* Set the atomic variable as 1 in case of SRSI */ | ||
| 3467 | atomic_set(&dd->drv_cleanup_done, true); | ||
| 3468 | 3929 | ||
| 3469 | /* Clean up the block layer. */ | 3930 | /* Clean up the block layer. */ |
| 3470 | mtip_block_remove(dd); | 3931 | mtip_block_remove(dd); |
| @@ -3493,7 +3954,7 @@ static int mtip_pci_suspend(struct pci_dev *pdev, pm_message_t mesg) | |||
| 3493 | return -EFAULT; | 3954 | return -EFAULT; |
| 3494 | } | 3955 | } |
| 3495 | 3956 | ||
| 3496 | atomic_set(&dd->resumeflag, true); | 3957 | set_bit(MTIP_DDF_RESUME_BIT, &dd->dd_flag); |
| 3497 | 3958 | ||
| 3498 | /* Disable ports & interrupts then send standby immediate */ | 3959 | /* Disable ports & interrupts then send standby immediate */ |
| 3499 | rv = mtip_block_suspend(dd); | 3960 | rv = mtip_block_suspend(dd); |
| @@ -3559,7 +4020,7 @@ static int mtip_pci_resume(struct pci_dev *pdev) | |||
| 3559 | dev_err(&pdev->dev, "Unable to resume\n"); | 4020 | dev_err(&pdev->dev, "Unable to resume\n"); |
| 3560 | 4021 | ||
| 3561 | err: | 4022 | err: |
| 3562 | atomic_set(&dd->resumeflag, false); | 4023 | clear_bit(MTIP_DDF_RESUME_BIT, &dd->dd_flag); |
| 3563 | 4024 | ||
| 3564 | return rv; | 4025 | return rv; |
| 3565 | } | 4026 | } |
| @@ -3608,18 +4069,25 @@ MODULE_DEVICE_TABLE(pci, mtip_pci_tbl); | |||
| 3608 | */ | 4069 | */ |
| 3609 | static int __init mtip_init(void) | 4070 | static int __init mtip_init(void) |
| 3610 | { | 4071 | { |
| 4072 | int error; | ||
| 4073 | |||
| 3611 | printk(KERN_INFO MTIP_DRV_NAME " Version " MTIP_DRV_VERSION "\n"); | 4074 | printk(KERN_INFO MTIP_DRV_NAME " Version " MTIP_DRV_VERSION "\n"); |
| 3612 | 4075 | ||
| 3613 | /* Allocate a major block device number to use with this driver. */ | 4076 | /* Allocate a major block device number to use with this driver. */ |
| 3614 | mtip_major = register_blkdev(0, MTIP_DRV_NAME); | 4077 | error = register_blkdev(0, MTIP_DRV_NAME); |
| 3615 | if (mtip_major < 0) { | 4078 | if (error <= 0) { |
| 3616 | printk(KERN_ERR "Unable to register block device (%d)\n", | 4079 | printk(KERN_ERR "Unable to register block device (%d)\n", |
| 3617 | mtip_major); | 4080 | error); |
| 3618 | return -EBUSY; | 4081 | return -EBUSY; |
| 3619 | } | 4082 | } |
| 4083 | mtip_major = error; | ||
| 3620 | 4084 | ||
| 3621 | /* Register our PCI operations. */ | 4085 | /* Register our PCI operations. */ |
| 3622 | return pci_register_driver(&mtip_pci_driver); | 4086 | error = pci_register_driver(&mtip_pci_driver); |
| 4087 | if (error) | ||
| 4088 | unregister_blkdev(mtip_major, MTIP_DRV_NAME); | ||
| 4089 | |||
| 4090 | return error; | ||
| 3623 | } | 4091 | } |
| 3624 | 4092 | ||
| 3625 | /* | 4093 | /* |
diff --git a/drivers/block/mtip32xx/mtip32xx.h b/drivers/block/mtip32xx/mtip32xx.h index e0554a8f2233..4ef58336310a 100644 --- a/drivers/block/mtip32xx/mtip32xx.h +++ b/drivers/block/mtip32xx/mtip32xx.h | |||
| @@ -34,8 +34,8 @@ | |||
| 34 | /* offset of Device Control register in PCIe extended capabilites space */ | 34 | /* offset of Device Control register in PCIe extended capabilites space */ |
| 35 | #define PCIE_CONFIG_EXT_DEVICE_CONTROL_OFFSET 0x48 | 35 | #define PCIE_CONFIG_EXT_DEVICE_CONTROL_OFFSET 0x48 |
| 36 | 36 | ||
| 37 | /* # of times to retry timed out IOs */ | 37 | /* # of times to retry timed out/failed IOs */ |
| 38 | #define MTIP_MAX_RETRIES 5 | 38 | #define MTIP_MAX_RETRIES 2 |
| 39 | 39 | ||
| 40 | /* Various timeout values in ms */ | 40 | /* Various timeout values in ms */ |
| 41 | #define MTIP_NCQ_COMMAND_TIMEOUT_MS 5000 | 41 | #define MTIP_NCQ_COMMAND_TIMEOUT_MS 5000 |
| @@ -114,12 +114,41 @@ | |||
| 114 | #define __force_bit2int (unsigned int __force) | 114 | #define __force_bit2int (unsigned int __force) |
| 115 | 115 | ||
| 116 | /* below are bit numbers in 'flags' defined in mtip_port */ | 116 | /* below are bit numbers in 'flags' defined in mtip_port */ |
| 117 | #define MTIP_FLAG_IC_ACTIVE_BIT 0 | 117 | #define MTIP_PF_IC_ACTIVE_BIT 0 /* pio/ioctl */ |
| 118 | #define MTIP_FLAG_EH_ACTIVE_BIT 1 | 118 | #define MTIP_PF_EH_ACTIVE_BIT 1 /* error handling */ |
| 119 | #define MTIP_FLAG_SVC_THD_ACTIVE_BIT 2 | 119 | #define MTIP_PF_SE_ACTIVE_BIT 2 /* secure erase */ |
| 120 | #define MTIP_FLAG_ISSUE_CMDS_BIT 4 | 120 | #define MTIP_PF_DM_ACTIVE_BIT 3 /* download microcde */ |
| 121 | #define MTIP_FLAG_REBUILD_BIT 5 | 121 | #define MTIP_PF_PAUSE_IO ((1 << MTIP_PF_IC_ACTIVE_BIT) | \ |
| 122 | #define MTIP_FLAG_SVC_THD_SHOULD_STOP_BIT 8 | 122 | (1 << MTIP_PF_EH_ACTIVE_BIT) | \ |
| 123 | (1 << MTIP_PF_SE_ACTIVE_BIT) | \ | ||
| 124 | (1 << MTIP_PF_DM_ACTIVE_BIT)) | ||
| 125 | |||
| 126 | #define MTIP_PF_SVC_THD_ACTIVE_BIT 4 | ||
| 127 | #define MTIP_PF_ISSUE_CMDS_BIT 5 | ||
| 128 | #define MTIP_PF_REBUILD_BIT 6 | ||
| 129 | #define MTIP_PF_SVC_THD_STOP_BIT 8 | ||
| 130 | |||
| 131 | /* below are bit numbers in 'dd_flag' defined in driver_data */ | ||
| 132 | #define MTIP_DDF_REMOVE_PENDING_BIT 1 | ||
| 133 | #define MTIP_DDF_OVER_TEMP_BIT 2 | ||
| 134 | #define MTIP_DDF_WRITE_PROTECT_BIT 3 | ||
| 135 | #define MTIP_DDF_STOP_IO ((1 << MTIP_DDF_REMOVE_PENDING_BIT) | \ | ||
| 136 | (1 << MTIP_DDF_OVER_TEMP_BIT) | \ | ||
| 137 | (1 << MTIP_DDF_WRITE_PROTECT_BIT)) | ||
| 138 | |||
| 139 | #define MTIP_DDF_CLEANUP_BIT 5 | ||
| 140 | #define MTIP_DDF_RESUME_BIT 6 | ||
| 141 | #define MTIP_DDF_INIT_DONE_BIT 7 | ||
| 142 | #define MTIP_DDF_REBUILD_FAILED_BIT 8 | ||
| 143 | |||
| 144 | __packed struct smart_attr{ | ||
| 145 | u8 attr_id; | ||
| 146 | u16 flags; | ||
| 147 | u8 cur; | ||
| 148 | u8 worst; | ||
| 149 | u32 data; | ||
| 150 | u8 res[3]; | ||
| 151 | }; | ||
| 123 | 152 | ||
| 124 | /* Register Frame Information Structure (FIS), host to device. */ | 153 | /* Register Frame Information Structure (FIS), host to device. */ |
| 125 | struct host_to_dev_fis { | 154 | struct host_to_dev_fis { |
| @@ -345,6 +374,12 @@ struct mtip_port { | |||
| 345 | * when the command slot and all associated data structures | 374 | * when the command slot and all associated data structures |
| 346 | * are no longer needed. | 375 | * are no longer needed. |
| 347 | */ | 376 | */ |
| 377 | u16 *log_buf; | ||
| 378 | dma_addr_t log_buf_dma; | ||
| 379 | |||
| 380 | u8 *smart_buf; | ||
| 381 | dma_addr_t smart_buf_dma; | ||
| 382 | |||
| 348 | unsigned long allocated[SLOTBITS_IN_LONGS]; | 383 | unsigned long allocated[SLOTBITS_IN_LONGS]; |
| 349 | /* | 384 | /* |
| 350 | * used to queue commands when an internal command is in progress | 385 | * used to queue commands when an internal command is in progress |
| @@ -368,6 +403,7 @@ struct mtip_port { | |||
| 368 | * Timer used to complete commands that have been active for too long. | 403 | * Timer used to complete commands that have been active for too long. |
| 369 | */ | 404 | */ |
| 370 | struct timer_list cmd_timer; | 405 | struct timer_list cmd_timer; |
| 406 | unsigned long ic_pause_timer; | ||
| 371 | /* | 407 | /* |
| 372 | * Semaphore used to block threads if there are no | 408 | * Semaphore used to block threads if there are no |
| 373 | * command slots available. | 409 | * command slots available. |
| @@ -404,13 +440,9 @@ struct driver_data { | |||
| 404 | 440 | ||
| 405 | unsigned slot_groups; /* number of slot groups the product supports */ | 441 | unsigned slot_groups; /* number of slot groups the product supports */ |
| 406 | 442 | ||
| 407 | atomic_t drv_cleanup_done; /* Atomic variable for SRSI */ | ||
| 408 | |||
| 409 | unsigned long index; /* Index to determine the disk name */ | 443 | unsigned long index; /* Index to determine the disk name */ |
| 410 | 444 | ||
| 411 | unsigned int ftlrebuildflag; /* FTL rebuild flag */ | 445 | unsigned long dd_flag; /* NOTE: use atomic bit operations on this */ |
| 412 | |||
| 413 | atomic_t resumeflag; /* Atomic variable to track suspend/resume */ | ||
| 414 | 446 | ||
| 415 | struct task_struct *mtip_svc_handler; /* task_struct of svc thd */ | 447 | struct task_struct *mtip_svc_handler; /* task_struct of svc thd */ |
| 416 | }; | 448 | }; |
diff --git a/drivers/block/virtio_blk.c b/drivers/block/virtio_blk.c index c4a60badf252..0d39f2f4294a 100644 --- a/drivers/block/virtio_blk.c +++ b/drivers/block/virtio_blk.c | |||
| @@ -351,6 +351,7 @@ static void virtblk_config_changed_work(struct work_struct *work) | |||
| 351 | cap_str_10, cap_str_2); | 351 | cap_str_10, cap_str_2); |
| 352 | 352 | ||
| 353 | set_capacity(vblk->disk, capacity); | 353 | set_capacity(vblk->disk, capacity); |
| 354 | revalidate_disk(vblk->disk); | ||
| 354 | done: | 355 | done: |
| 355 | mutex_unlock(&vblk->config_lock); | 356 | mutex_unlock(&vblk->config_lock); |
| 356 | } | 357 | } |
| @@ -374,6 +375,34 @@ static int init_vq(struct virtio_blk *vblk) | |||
| 374 | return err; | 375 | return err; |
| 375 | } | 376 | } |
| 376 | 377 | ||
| 378 | /* | ||
| 379 | * Legacy naming scheme used for virtio devices. We are stuck with it for | ||
| 380 | * virtio blk but don't ever use it for any new driver. | ||
| 381 | */ | ||
| 382 | static int virtblk_name_format(char *prefix, int index, char *buf, int buflen) | ||
| 383 | { | ||
| 384 | const int base = 'z' - 'a' + 1; | ||
| 385 | char *begin = buf + strlen(prefix); | ||
| 386 | char *end = buf + buflen; | ||
| 387 | char *p; | ||
| 388 | int unit; | ||
| 389 | |||
| 390 | p = end - 1; | ||
| 391 | *p = '\0'; | ||
| 392 | unit = base; | ||
| 393 | do { | ||
| 394 | if (p == begin) | ||
| 395 | return -EINVAL; | ||
| 396 | *--p = 'a' + (index % unit); | ||
| 397 | index = (index / unit) - 1; | ||
| 398 | } while (index >= 0); | ||
| 399 | |||
| 400 | memmove(begin, p, end - p); | ||
| 401 | memcpy(buf, prefix, strlen(prefix)); | ||
| 402 | |||
| 403 | return 0; | ||
| 404 | } | ||
| 405 | |||
| 377 | static int __devinit virtblk_probe(struct virtio_device *vdev) | 406 | static int __devinit virtblk_probe(struct virtio_device *vdev) |
| 378 | { | 407 | { |
| 379 | struct virtio_blk *vblk; | 408 | struct virtio_blk *vblk; |
| @@ -442,18 +471,7 @@ static int __devinit virtblk_probe(struct virtio_device *vdev) | |||
| 442 | 471 | ||
| 443 | q->queuedata = vblk; | 472 | q->queuedata = vblk; |
| 444 | 473 | ||
| 445 | if (index < 26) { | 474 | virtblk_name_format("vd", index, vblk->disk->disk_name, DISK_NAME_LEN); |
| 446 | sprintf(vblk->disk->disk_name, "vd%c", 'a' + index % 26); | ||
| 447 | } else if (index < (26 + 1) * 26) { | ||
| 448 | sprintf(vblk->disk->disk_name, "vd%c%c", | ||
| 449 | 'a' + index / 26 - 1, 'a' + index % 26); | ||
| 450 | } else { | ||
| 451 | const unsigned int m1 = (index / 26 - 1) / 26 - 1; | ||
| 452 | const unsigned int m2 = (index / 26 - 1) % 26; | ||
| 453 | const unsigned int m3 = index % 26; | ||
| 454 | sprintf(vblk->disk->disk_name, "vd%c%c%c", | ||
| 455 | 'a' + m1, 'a' + m2, 'a' + m3); | ||
| 456 | } | ||
| 457 | 475 | ||
| 458 | vblk->disk->major = major; | 476 | vblk->disk->major = major; |
| 459 | vblk->disk->first_minor = index_to_minor(index); | 477 | vblk->disk->first_minor = index_to_minor(index); |
diff --git a/drivers/block/xen-blkback/blkback.c b/drivers/block/xen-blkback/blkback.c index 0088bf60f368..73f196ca713f 100644 --- a/drivers/block/xen-blkback/blkback.c +++ b/drivers/block/xen-blkback/blkback.c | |||
| @@ -321,6 +321,7 @@ struct seg_buf { | |||
| 321 | static void xen_blkbk_unmap(struct pending_req *req) | 321 | static void xen_blkbk_unmap(struct pending_req *req) |
| 322 | { | 322 | { |
| 323 | struct gnttab_unmap_grant_ref unmap[BLKIF_MAX_SEGMENTS_PER_REQUEST]; | 323 | struct gnttab_unmap_grant_ref unmap[BLKIF_MAX_SEGMENTS_PER_REQUEST]; |
| 324 | struct page *pages[BLKIF_MAX_SEGMENTS_PER_REQUEST]; | ||
| 324 | unsigned int i, invcount = 0; | 325 | unsigned int i, invcount = 0; |
| 325 | grant_handle_t handle; | 326 | grant_handle_t handle; |
| 326 | int ret; | 327 | int ret; |
| @@ -332,25 +333,12 @@ static void xen_blkbk_unmap(struct pending_req *req) | |||
| 332 | gnttab_set_unmap_op(&unmap[invcount], vaddr(req, i), | 333 | gnttab_set_unmap_op(&unmap[invcount], vaddr(req, i), |
| 333 | GNTMAP_host_map, handle); | 334 | GNTMAP_host_map, handle); |
| 334 | pending_handle(req, i) = BLKBACK_INVALID_HANDLE; | 335 | pending_handle(req, i) = BLKBACK_INVALID_HANDLE; |
| 336 | pages[invcount] = virt_to_page(vaddr(req, i)); | ||
| 335 | invcount++; | 337 | invcount++; |
| 336 | } | 338 | } |
| 337 | 339 | ||
| 338 | ret = HYPERVISOR_grant_table_op( | 340 | ret = gnttab_unmap_refs(unmap, pages, invcount, false); |
| 339 | GNTTABOP_unmap_grant_ref, unmap, invcount); | ||
| 340 | BUG_ON(ret); | 341 | BUG_ON(ret); |
| 341 | /* | ||
| 342 | * Note, we use invcount, so nr->pages, so we can't index | ||
| 343 | * using vaddr(req, i). | ||
| 344 | */ | ||
| 345 | for (i = 0; i < invcount; i++) { | ||
| 346 | ret = m2p_remove_override( | ||
| 347 | virt_to_page(unmap[i].host_addr), false); | ||
| 348 | if (ret) { | ||
| 349 | pr_alert(DRV_PFX "Failed to remove M2P override for %lx\n", | ||
| 350 | (unsigned long)unmap[i].host_addr); | ||
| 351 | continue; | ||
| 352 | } | ||
| 353 | } | ||
| 354 | } | 342 | } |
| 355 | 343 | ||
| 356 | static int xen_blkbk_map(struct blkif_request *req, | 344 | static int xen_blkbk_map(struct blkif_request *req, |
| @@ -378,7 +366,7 @@ static int xen_blkbk_map(struct blkif_request *req, | |||
| 378 | pending_req->blkif->domid); | 366 | pending_req->blkif->domid); |
| 379 | } | 367 | } |
| 380 | 368 | ||
| 381 | ret = HYPERVISOR_grant_table_op(GNTTABOP_map_grant_ref, map, nseg); | 369 | ret = gnttab_map_refs(map, NULL, &blkbk->pending_page(pending_req, 0), nseg); |
| 382 | BUG_ON(ret); | 370 | BUG_ON(ret); |
| 383 | 371 | ||
| 384 | /* | 372 | /* |
| @@ -398,15 +386,6 @@ static int xen_blkbk_map(struct blkif_request *req, | |||
| 398 | if (ret) | 386 | if (ret) |
| 399 | continue; | 387 | continue; |
| 400 | 388 | ||
| 401 | ret = m2p_add_override(PFN_DOWN(map[i].dev_bus_addr), | ||
| 402 | blkbk->pending_page(pending_req, i), NULL); | ||
| 403 | if (ret) { | ||
| 404 | pr_alert(DRV_PFX "Failed to install M2P override for %lx (ret: %d)\n", | ||
| 405 | (unsigned long)map[i].dev_bus_addr, ret); | ||
| 406 | /* We could switch over to GNTTABOP_copy */ | ||
| 407 | continue; | ||
| 408 | } | ||
| 409 | |||
| 410 | seg[i].buf = map[i].dev_bus_addr | | 389 | seg[i].buf = map[i].dev_bus_addr | |
| 411 | (req->u.rw.seg[i].first_sect << 9); | 390 | (req->u.rw.seg[i].first_sect << 9); |
| 412 | } | 391 | } |
| @@ -419,21 +398,18 @@ static int dispatch_discard_io(struct xen_blkif *blkif, | |||
| 419 | int err = 0; | 398 | int err = 0; |
| 420 | int status = BLKIF_RSP_OKAY; | 399 | int status = BLKIF_RSP_OKAY; |
| 421 | struct block_device *bdev = blkif->vbd.bdev; | 400 | struct block_device *bdev = blkif->vbd.bdev; |
| 401 | unsigned long secure; | ||
| 422 | 402 | ||
| 423 | blkif->st_ds_req++; | 403 | blkif->st_ds_req++; |
| 424 | 404 | ||
| 425 | xen_blkif_get(blkif); | 405 | xen_blkif_get(blkif); |
| 426 | if (blkif->blk_backend_type == BLKIF_BACKEND_PHY || | 406 | secure = (blkif->vbd.discard_secure && |
| 427 | blkif->blk_backend_type == BLKIF_BACKEND_FILE) { | 407 | (req->u.discard.flag & BLKIF_DISCARD_SECURE)) ? |
| 428 | unsigned long secure = (blkif->vbd.discard_secure && | 408 | BLKDEV_DISCARD_SECURE : 0; |
| 429 | (req->u.discard.flag & BLKIF_DISCARD_SECURE)) ? | 409 | |
| 430 | BLKDEV_DISCARD_SECURE : 0; | 410 | err = blkdev_issue_discard(bdev, req->u.discard.sector_number, |
| 431 | err = blkdev_issue_discard(bdev, | 411 | req->u.discard.nr_sectors, |
| 432 | req->u.discard.sector_number, | 412 | GFP_KERNEL, secure); |
| 433 | req->u.discard.nr_sectors, | ||
| 434 | GFP_KERNEL, secure); | ||
| 435 | } else | ||
| 436 | err = -EOPNOTSUPP; | ||
| 437 | 413 | ||
| 438 | if (err == -EOPNOTSUPP) { | 414 | if (err == -EOPNOTSUPP) { |
| 439 | pr_debug(DRV_PFX "discard op failed, not supported\n"); | 415 | pr_debug(DRV_PFX "discard op failed, not supported\n"); |
| @@ -830,7 +806,7 @@ static int __init xen_blkif_init(void) | |||
| 830 | int i, mmap_pages; | 806 | int i, mmap_pages; |
| 831 | int rc = 0; | 807 | int rc = 0; |
| 832 | 808 | ||
| 833 | if (!xen_pv_domain()) | 809 | if (!xen_domain()) |
| 834 | return -ENODEV; | 810 | return -ENODEV; |
| 835 | 811 | ||
| 836 | blkbk = kzalloc(sizeof(struct xen_blkbk), GFP_KERNEL); | 812 | blkbk = kzalloc(sizeof(struct xen_blkbk), GFP_KERNEL); |
diff --git a/drivers/block/xen-blkback/common.h b/drivers/block/xen-blkback/common.h index d0ee7edc9be8..773cf27dc23f 100644 --- a/drivers/block/xen-blkback/common.h +++ b/drivers/block/xen-blkback/common.h | |||
| @@ -146,11 +146,6 @@ enum blkif_protocol { | |||
| 146 | BLKIF_PROTOCOL_X86_64 = 3, | 146 | BLKIF_PROTOCOL_X86_64 = 3, |
| 147 | }; | 147 | }; |
| 148 | 148 | ||
| 149 | enum blkif_backend_type { | ||
| 150 | BLKIF_BACKEND_PHY = 1, | ||
| 151 | BLKIF_BACKEND_FILE = 2, | ||
| 152 | }; | ||
| 153 | |||
| 154 | struct xen_vbd { | 149 | struct xen_vbd { |
| 155 | /* What the domain refers to this vbd as. */ | 150 | /* What the domain refers to this vbd as. */ |
| 156 | blkif_vdev_t handle; | 151 | blkif_vdev_t handle; |
| @@ -177,7 +172,6 @@ struct xen_blkif { | |||
| 177 | unsigned int irq; | 172 | unsigned int irq; |
| 178 | /* Comms information. */ | 173 | /* Comms information. */ |
| 179 | enum blkif_protocol blk_protocol; | 174 | enum blkif_protocol blk_protocol; |
| 180 | enum blkif_backend_type blk_backend_type; | ||
| 181 | union blkif_back_rings blk_rings; | 175 | union blkif_back_rings blk_rings; |
| 182 | void *blk_ring; | 176 | void *blk_ring; |
| 183 | /* The VBD attached to this interface. */ | 177 | /* The VBD attached to this interface. */ |
diff --git a/drivers/block/xen-blkback/xenbus.c b/drivers/block/xen-blkback/xenbus.c index 24a2fb57e5d0..4f66171c6683 100644 --- a/drivers/block/xen-blkback/xenbus.c +++ b/drivers/block/xen-blkback/xenbus.c | |||
| @@ -381,72 +381,49 @@ int xen_blkbk_flush_diskcache(struct xenbus_transaction xbt, | |||
| 381 | err = xenbus_printf(xbt, dev->nodename, "feature-flush-cache", | 381 | err = xenbus_printf(xbt, dev->nodename, "feature-flush-cache", |
| 382 | "%d", state); | 382 | "%d", state); |
| 383 | if (err) | 383 | if (err) |
| 384 | xenbus_dev_fatal(dev, err, "writing feature-flush-cache"); | 384 | dev_warn(&dev->dev, "writing feature-flush-cache (%d)", err); |
| 385 | 385 | ||
| 386 | return err; | 386 | return err; |
| 387 | } | 387 | } |
| 388 | 388 | ||
| 389 | int xen_blkbk_discard(struct xenbus_transaction xbt, struct backend_info *be) | 389 | static void xen_blkbk_discard(struct xenbus_transaction xbt, struct backend_info *be) |
| 390 | { | 390 | { |
| 391 | struct xenbus_device *dev = be->dev; | 391 | struct xenbus_device *dev = be->dev; |
| 392 | struct xen_blkif *blkif = be->blkif; | 392 | struct xen_blkif *blkif = be->blkif; |
| 393 | char *type; | ||
| 394 | int err; | 393 | int err; |
| 395 | int state = 0; | 394 | int state = 0; |
| 395 | struct block_device *bdev = be->blkif->vbd.bdev; | ||
| 396 | struct request_queue *q = bdev_get_queue(bdev); | ||
| 396 | 397 | ||
| 397 | type = xenbus_read(XBT_NIL, dev->nodename, "type", NULL); | 398 | if (blk_queue_discard(q)) { |
| 398 | if (!IS_ERR(type)) { | 399 | err = xenbus_printf(xbt, dev->nodename, |
| 399 | if (strncmp(type, "file", 4) == 0) { | 400 | "discard-granularity", "%u", |
| 400 | state = 1; | 401 | q->limits.discard_granularity); |
| 401 | blkif->blk_backend_type = BLKIF_BACKEND_FILE; | 402 | if (err) { |
| 403 | dev_warn(&dev->dev, "writing discard-granularity (%d)", err); | ||
| 404 | return; | ||
| 402 | } | 405 | } |
| 403 | if (strncmp(type, "phy", 3) == 0) { | 406 | err = xenbus_printf(xbt, dev->nodename, |
| 404 | struct block_device *bdev = be->blkif->vbd.bdev; | 407 | "discard-alignment", "%u", |
| 405 | struct request_queue *q = bdev_get_queue(bdev); | 408 | q->limits.discard_alignment); |
| 406 | if (blk_queue_discard(q)) { | 409 | if (err) { |
| 407 | err = xenbus_printf(xbt, dev->nodename, | 410 | dev_warn(&dev->dev, "writing discard-alignment (%d)", err); |
| 408 | "discard-granularity", "%u", | 411 | return; |
| 409 | q->limits.discard_granularity); | 412 | } |
| 410 | if (err) { | 413 | state = 1; |
| 411 | xenbus_dev_fatal(dev, err, | 414 | /* Optional. */ |
| 412 | "writing discard-granularity"); | 415 | err = xenbus_printf(xbt, dev->nodename, |
| 413 | goto kfree; | 416 | "discard-secure", "%d", |
| 414 | } | 417 | blkif->vbd.discard_secure); |
| 415 | err = xenbus_printf(xbt, dev->nodename, | 418 | if (err) { |
| 416 | "discard-alignment", "%u", | 419 | dev_warn(&dev->dev, "writing discard-secure (%d)", err); |
| 417 | q->limits.discard_alignment); | 420 | return; |
| 418 | if (err) { | ||
| 419 | xenbus_dev_fatal(dev, err, | ||
| 420 | "writing discard-alignment"); | ||
| 421 | goto kfree; | ||
| 422 | } | ||
| 423 | state = 1; | ||
| 424 | blkif->blk_backend_type = BLKIF_BACKEND_PHY; | ||
| 425 | } | ||
| 426 | /* Optional. */ | ||
| 427 | err = xenbus_printf(xbt, dev->nodename, | ||
| 428 | "discard-secure", "%d", | ||
| 429 | blkif->vbd.discard_secure); | ||
| 430 | if (err) { | ||
| 431 | xenbus_dev_fatal(dev, err, | ||
| 432 | "writting discard-secure"); | ||
| 433 | goto kfree; | ||
| 434 | } | ||
| 435 | } | 421 | } |
| 436 | } else { | ||
| 437 | err = PTR_ERR(type); | ||
| 438 | xenbus_dev_fatal(dev, err, "reading type"); | ||
| 439 | goto out; | ||
| 440 | } | 422 | } |
| 441 | |||
| 442 | err = xenbus_printf(xbt, dev->nodename, "feature-discard", | 423 | err = xenbus_printf(xbt, dev->nodename, "feature-discard", |
| 443 | "%d", state); | 424 | "%d", state); |
| 444 | if (err) | 425 | if (err) |
| 445 | xenbus_dev_fatal(dev, err, "writing feature-discard"); | 426 | dev_warn(&dev->dev, "writing feature-discard (%d)", err); |
| 446 | kfree: | ||
| 447 | kfree(type); | ||
| 448 | out: | ||
| 449 | return err; | ||
| 450 | } | 427 | } |
| 451 | int xen_blkbk_barrier(struct xenbus_transaction xbt, | 428 | int xen_blkbk_barrier(struct xenbus_transaction xbt, |
| 452 | struct backend_info *be, int state) | 429 | struct backend_info *be, int state) |
| @@ -457,7 +434,7 @@ int xen_blkbk_barrier(struct xenbus_transaction xbt, | |||
| 457 | err = xenbus_printf(xbt, dev->nodename, "feature-barrier", | 434 | err = xenbus_printf(xbt, dev->nodename, "feature-barrier", |
| 458 | "%d", state); | 435 | "%d", state); |
| 459 | if (err) | 436 | if (err) |
| 460 | xenbus_dev_fatal(dev, err, "writing feature-barrier"); | 437 | dev_warn(&dev->dev, "writing feature-barrier (%d)", err); |
| 461 | 438 | ||
| 462 | return err; | 439 | return err; |
| 463 | } | 440 | } |
| @@ -689,14 +666,12 @@ again: | |||
| 689 | return; | 666 | return; |
| 690 | } | 667 | } |
| 691 | 668 | ||
| 692 | err = xen_blkbk_flush_diskcache(xbt, be, be->blkif->vbd.flush_support); | 669 | /* If we can't advertise it is OK. */ |
| 693 | if (err) | 670 | xen_blkbk_flush_diskcache(xbt, be, be->blkif->vbd.flush_support); |
| 694 | goto abort; | ||
| 695 | 671 | ||
| 696 | err = xen_blkbk_discard(xbt, be); | 672 | xen_blkbk_discard(xbt, be); |
| 697 | 673 | ||
| 698 | /* If we can't advertise it is OK. */ | 674 | xen_blkbk_barrier(xbt, be, be->blkif->vbd.flush_support); |
| 699 | err = xen_blkbk_barrier(xbt, be, be->blkif->vbd.flush_support); | ||
| 700 | 675 | ||
| 701 | err = xenbus_printf(xbt, dev->nodename, "sectors", "%llu", | 676 | err = xenbus_printf(xbt, dev->nodename, "sectors", "%llu", |
| 702 | (unsigned long long)vbd_sz(&be->blkif->vbd)); | 677 | (unsigned long long)vbd_sz(&be->blkif->vbd)); |
diff --git a/drivers/block/xen-blkfront.c b/drivers/block/xen-blkfront.c index 98cbeba8cd53..4e86393a09cf 100644 --- a/drivers/block/xen-blkfront.c +++ b/drivers/block/xen-blkfront.c | |||
| @@ -43,6 +43,7 @@ | |||
| 43 | #include <linux/slab.h> | 43 | #include <linux/slab.h> |
| 44 | #include <linux/mutex.h> | 44 | #include <linux/mutex.h> |
| 45 | #include <linux/scatterlist.h> | 45 | #include <linux/scatterlist.h> |
| 46 | #include <linux/bitmap.h> | ||
| 46 | 47 | ||
| 47 | #include <xen/xen.h> | 48 | #include <xen/xen.h> |
| 48 | #include <xen/xenbus.h> | 49 | #include <xen/xenbus.h> |
| @@ -81,6 +82,7 @@ static const struct block_device_operations xlvbd_block_fops; | |||
| 81 | */ | 82 | */ |
| 82 | struct blkfront_info | 83 | struct blkfront_info |
| 83 | { | 84 | { |
| 85 | spinlock_t io_lock; | ||
| 84 | struct mutex mutex; | 86 | struct mutex mutex; |
| 85 | struct xenbus_device *xbdev; | 87 | struct xenbus_device *xbdev; |
| 86 | struct gendisk *gd; | 88 | struct gendisk *gd; |
| @@ -105,8 +107,6 @@ struct blkfront_info | |||
| 105 | int is_ready; | 107 | int is_ready; |
| 106 | }; | 108 | }; |
| 107 | 109 | ||
| 108 | static DEFINE_SPINLOCK(blkif_io_lock); | ||
| 109 | |||
| 110 | static unsigned int nr_minors; | 110 | static unsigned int nr_minors; |
| 111 | static unsigned long *minors; | 111 | static unsigned long *minors; |
| 112 | static DEFINE_SPINLOCK(minor_lock); | 112 | static DEFINE_SPINLOCK(minor_lock); |
| @@ -177,8 +177,7 @@ static int xlbd_reserve_minors(unsigned int minor, unsigned int nr) | |||
| 177 | 177 | ||
| 178 | spin_lock(&minor_lock); | 178 | spin_lock(&minor_lock); |
| 179 | if (find_next_bit(minors, end, minor) >= end) { | 179 | if (find_next_bit(minors, end, minor) >= end) { |
| 180 | for (; minor < end; ++minor) | 180 | bitmap_set(minors, minor, nr); |
| 181 | __set_bit(minor, minors); | ||
| 182 | rc = 0; | 181 | rc = 0; |
| 183 | } else | 182 | } else |
| 184 | rc = -EBUSY; | 183 | rc = -EBUSY; |
| @@ -193,8 +192,7 @@ static void xlbd_release_minors(unsigned int minor, unsigned int nr) | |||
| 193 | 192 | ||
| 194 | BUG_ON(end > nr_minors); | 193 | BUG_ON(end > nr_minors); |
| 195 | spin_lock(&minor_lock); | 194 | spin_lock(&minor_lock); |
| 196 | for (; minor < end; ++minor) | 195 | bitmap_clear(minors, minor, nr); |
| 197 | __clear_bit(minor, minors); | ||
| 198 | spin_unlock(&minor_lock); | 196 | spin_unlock(&minor_lock); |
| 199 | } | 197 | } |
| 200 | 198 | ||
| @@ -419,7 +417,7 @@ static int xlvbd_init_blk_queue(struct gendisk *gd, u16 sector_size) | |||
| 419 | struct request_queue *rq; | 417 | struct request_queue *rq; |
| 420 | struct blkfront_info *info = gd->private_data; | 418 | struct blkfront_info *info = gd->private_data; |
| 421 | 419 | ||
| 422 | rq = blk_init_queue(do_blkif_request, &blkif_io_lock); | 420 | rq = blk_init_queue(do_blkif_request, &info->io_lock); |
| 423 | if (rq == NULL) | 421 | if (rq == NULL) |
| 424 | return -1; | 422 | return -1; |
| 425 | 423 | ||
| @@ -636,14 +634,14 @@ static void xlvbd_release_gendisk(struct blkfront_info *info) | |||
| 636 | if (info->rq == NULL) | 634 | if (info->rq == NULL) |
| 637 | return; | 635 | return; |
| 638 | 636 | ||
| 639 | spin_lock_irqsave(&blkif_io_lock, flags); | 637 | spin_lock_irqsave(&info->io_lock, flags); |
| 640 | 638 | ||
| 641 | /* No more blkif_request(). */ | 639 | /* No more blkif_request(). */ |
| 642 | blk_stop_queue(info->rq); | 640 | blk_stop_queue(info->rq); |
| 643 | 641 | ||
| 644 | /* No more gnttab callback work. */ | 642 | /* No more gnttab callback work. */ |
| 645 | gnttab_cancel_free_callback(&info->callback); | 643 | gnttab_cancel_free_callback(&info->callback); |
| 646 | spin_unlock_irqrestore(&blkif_io_lock, flags); | 644 | spin_unlock_irqrestore(&info->io_lock, flags); |
| 647 | 645 | ||
| 648 | /* Flush gnttab callback work. Must be done with no locks held. */ | 646 | /* Flush gnttab callback work. Must be done with no locks held. */ |
| 649 | flush_work_sync(&info->work); | 647 | flush_work_sync(&info->work); |
| @@ -675,16 +673,16 @@ static void blkif_restart_queue(struct work_struct *work) | |||
| 675 | { | 673 | { |
| 676 | struct blkfront_info *info = container_of(work, struct blkfront_info, work); | 674 | struct blkfront_info *info = container_of(work, struct blkfront_info, work); |
| 677 | 675 | ||
| 678 | spin_lock_irq(&blkif_io_lock); | 676 | spin_lock_irq(&info->io_lock); |
| 679 | if (info->connected == BLKIF_STATE_CONNECTED) | 677 | if (info->connected == BLKIF_STATE_CONNECTED) |
| 680 | kick_pending_request_queues(info); | 678 | kick_pending_request_queues(info); |
| 681 | spin_unlock_irq(&blkif_io_lock); | 679 | spin_unlock_irq(&info->io_lock); |
| 682 | } | 680 | } |
| 683 | 681 | ||
| 684 | static void blkif_free(struct blkfront_info *info, int suspend) | 682 | static void blkif_free(struct blkfront_info *info, int suspend) |
| 685 | { | 683 | { |
| 686 | /* Prevent new requests being issued until we fix things up. */ | 684 | /* Prevent new requests being issued until we fix things up. */ |
| 687 | spin_lock_irq(&blkif_io_lock); | 685 | spin_lock_irq(&info->io_lock); |
| 688 | info->connected = suspend ? | 686 | info->connected = suspend ? |
| 689 | BLKIF_STATE_SUSPENDED : BLKIF_STATE_DISCONNECTED; | 687 | BLKIF_STATE_SUSPENDED : BLKIF_STATE_DISCONNECTED; |
| 690 | /* No more blkif_request(). */ | 688 | /* No more blkif_request(). */ |
| @@ -692,7 +690,7 @@ static void blkif_free(struct blkfront_info *info, int suspend) | |||
| 692 | blk_stop_queue(info->rq); | 690 | blk_stop_queue(info->rq); |
| 693 | /* No more gnttab callback work. */ | 691 | /* No more gnttab callback work. */ |
| 694 | gnttab_cancel_free_callback(&info->callback); | 692 | gnttab_cancel_free_callback(&info->callback); |
| 695 | spin_unlock_irq(&blkif_io_lock); | 693 | spin_unlock_irq(&info->io_lock); |
| 696 | 694 | ||
| 697 | /* Flush gnttab callback work. Must be done with no locks held. */ | 695 | /* Flush gnttab callback work. Must be done with no locks held. */ |
| 698 | flush_work_sync(&info->work); | 696 | flush_work_sync(&info->work); |
| @@ -728,10 +726,10 @@ static irqreturn_t blkif_interrupt(int irq, void *dev_id) | |||
| 728 | struct blkfront_info *info = (struct blkfront_info *)dev_id; | 726 | struct blkfront_info *info = (struct blkfront_info *)dev_id; |
| 729 | int error; | 727 | int error; |
| 730 | 728 | ||
| 731 | spin_lock_irqsave(&blkif_io_lock, flags); | 729 | spin_lock_irqsave(&info->io_lock, flags); |
| 732 | 730 | ||
| 733 | if (unlikely(info->connected != BLKIF_STATE_CONNECTED)) { | 731 | if (unlikely(info->connected != BLKIF_STATE_CONNECTED)) { |
| 734 | spin_unlock_irqrestore(&blkif_io_lock, flags); | 732 | spin_unlock_irqrestore(&info->io_lock, flags); |
| 735 | return IRQ_HANDLED; | 733 | return IRQ_HANDLED; |
| 736 | } | 734 | } |
| 737 | 735 | ||
| @@ -816,7 +814,7 @@ static irqreturn_t blkif_interrupt(int irq, void *dev_id) | |||
| 816 | 814 | ||
| 817 | kick_pending_request_queues(info); | 815 | kick_pending_request_queues(info); |
| 818 | 816 | ||
| 819 | spin_unlock_irqrestore(&blkif_io_lock, flags); | 817 | spin_unlock_irqrestore(&info->io_lock, flags); |
| 820 | 818 | ||
| 821 | return IRQ_HANDLED; | 819 | return IRQ_HANDLED; |
| 822 | } | 820 | } |
| @@ -991,6 +989,7 @@ static int blkfront_probe(struct xenbus_device *dev, | |||
| 991 | } | 989 | } |
| 992 | 990 | ||
| 993 | mutex_init(&info->mutex); | 991 | mutex_init(&info->mutex); |
| 992 | spin_lock_init(&info->io_lock); | ||
| 994 | info->xbdev = dev; | 993 | info->xbdev = dev; |
| 995 | info->vdevice = vdevice; | 994 | info->vdevice = vdevice; |
| 996 | info->connected = BLKIF_STATE_DISCONNECTED; | 995 | info->connected = BLKIF_STATE_DISCONNECTED; |
| @@ -1068,7 +1067,7 @@ static int blkif_recover(struct blkfront_info *info) | |||
| 1068 | 1067 | ||
| 1069 | xenbus_switch_state(info->xbdev, XenbusStateConnected); | 1068 | xenbus_switch_state(info->xbdev, XenbusStateConnected); |
| 1070 | 1069 | ||
| 1071 | spin_lock_irq(&blkif_io_lock); | 1070 | spin_lock_irq(&info->io_lock); |
| 1072 | 1071 | ||
| 1073 | /* Now safe for us to use the shared ring */ | 1072 | /* Now safe for us to use the shared ring */ |
| 1074 | info->connected = BLKIF_STATE_CONNECTED; | 1073 | info->connected = BLKIF_STATE_CONNECTED; |
| @@ -1079,7 +1078,7 @@ static int blkif_recover(struct blkfront_info *info) | |||
| 1079 | /* Kick any other new requests queued since we resumed */ | 1078 | /* Kick any other new requests queued since we resumed */ |
| 1080 | kick_pending_request_queues(info); | 1079 | kick_pending_request_queues(info); |
| 1081 | 1080 | ||
| 1082 | spin_unlock_irq(&blkif_io_lock); | 1081 | spin_unlock_irq(&info->io_lock); |
| 1083 | 1082 | ||
| 1084 | return 0; | 1083 | return 0; |
| 1085 | } | 1084 | } |
| @@ -1277,10 +1276,10 @@ static void blkfront_connect(struct blkfront_info *info) | |||
| 1277 | xenbus_switch_state(info->xbdev, XenbusStateConnected); | 1276 | xenbus_switch_state(info->xbdev, XenbusStateConnected); |
| 1278 | 1277 | ||
| 1279 | /* Kick pending requests. */ | 1278 | /* Kick pending requests. */ |
| 1280 | spin_lock_irq(&blkif_io_lock); | 1279 | spin_lock_irq(&info->io_lock); |
| 1281 | info->connected = BLKIF_STATE_CONNECTED; | 1280 | info->connected = BLKIF_STATE_CONNECTED; |
| 1282 | kick_pending_request_queues(info); | 1281 | kick_pending_request_queues(info); |
| 1283 | spin_unlock_irq(&blkif_io_lock); | 1282 | spin_unlock_irq(&info->io_lock); |
| 1284 | 1283 | ||
| 1285 | add_disk(info->gd); | 1284 | add_disk(info->gd); |
| 1286 | 1285 | ||
| @@ -1410,7 +1409,6 @@ static int blkif_release(struct gendisk *disk, fmode_t mode) | |||
| 1410 | mutex_lock(&blkfront_mutex); | 1409 | mutex_lock(&blkfront_mutex); |
| 1411 | 1410 | ||
| 1412 | bdev = bdget_disk(disk, 0); | 1411 | bdev = bdget_disk(disk, 0); |
| 1413 | bdput(bdev); | ||
| 1414 | 1412 | ||
| 1415 | if (bdev->bd_openers) | 1413 | if (bdev->bd_openers) |
| 1416 | goto out; | 1414 | goto out; |
| @@ -1441,6 +1439,7 @@ static int blkif_release(struct gendisk *disk, fmode_t mode) | |||
| 1441 | } | 1439 | } |
| 1442 | 1440 | ||
| 1443 | out: | 1441 | out: |
| 1442 | bdput(bdev); | ||
| 1444 | mutex_unlock(&blkfront_mutex); | 1443 | mutex_unlock(&blkfront_mutex); |
| 1445 | return 0; | 1444 | return 0; |
| 1446 | } | 1445 | } |
diff --git a/drivers/char/hpet.c b/drivers/char/hpet.c index 3845ab44c330..dfd7876f127c 100644 --- a/drivers/char/hpet.c +++ b/drivers/char/hpet.c | |||
| @@ -906,8 +906,8 @@ int hpet_alloc(struct hpet_data *hdp) | |||
| 906 | hpetp->hp_which, hdp->hd_phys_address, | 906 | hpetp->hp_which, hdp->hd_phys_address, |
| 907 | hpetp->hp_ntimer > 1 ? "s" : ""); | 907 | hpetp->hp_ntimer > 1 ? "s" : ""); |
| 908 | for (i = 0; i < hpetp->hp_ntimer; i++) | 908 | for (i = 0; i < hpetp->hp_ntimer; i++) |
| 909 | printk("%s %d", i > 0 ? "," : "", hdp->hd_irq[i]); | 909 | printk(KERN_CONT "%s %d", i > 0 ? "," : "", hdp->hd_irq[i]); |
| 910 | printk("\n"); | 910 | printk(KERN_CONT "\n"); |
| 911 | 911 | ||
| 912 | temp = hpetp->hp_tick_freq; | 912 | temp = hpetp->hp_tick_freq; |
| 913 | remainder = do_div(temp, 1000000); | 913 | remainder = do_div(temp, 1000000); |
diff --git a/drivers/clocksource/acpi_pm.c b/drivers/clocksource/acpi_pm.c index 82e882028fcf..6b5cf02c35c8 100644 --- a/drivers/clocksource/acpi_pm.c +++ b/drivers/clocksource/acpi_pm.c | |||
| @@ -23,7 +23,6 @@ | |||
| 23 | #include <linux/init.h> | 23 | #include <linux/init.h> |
| 24 | #include <linux/pci.h> | 24 | #include <linux/pci.h> |
| 25 | #include <linux/delay.h> | 25 | #include <linux/delay.h> |
| 26 | #include <linux/async.h> | ||
| 27 | #include <asm/io.h> | 26 | #include <asm/io.h> |
| 28 | 27 | ||
| 29 | /* | 28 | /* |
| @@ -180,15 +179,17 @@ static int verify_pmtmr_rate(void) | |||
| 180 | /* Number of reads we try to get two different values */ | 179 | /* Number of reads we try to get two different values */ |
| 181 | #define ACPI_PM_READ_CHECKS 10000 | 180 | #define ACPI_PM_READ_CHECKS 10000 |
| 182 | 181 | ||
| 183 | static void __init acpi_pm_clocksource_async(void *unused, async_cookie_t cookie) | 182 | static int __init init_acpi_pm_clocksource(void) |
| 184 | { | 183 | { |
| 185 | cycle_t value1, value2; | 184 | cycle_t value1, value2; |
| 186 | unsigned int i, j = 0; | 185 | unsigned int i, j = 0; |
| 187 | 186 | ||
| 187 | if (!pmtmr_ioport) | ||
| 188 | return -ENODEV; | ||
| 188 | 189 | ||
| 189 | /* "verify" this timing source: */ | 190 | /* "verify" this timing source: */ |
| 190 | for (j = 0; j < ACPI_PM_MONOTONICITY_CHECKS; j++) { | 191 | for (j = 0; j < ACPI_PM_MONOTONICITY_CHECKS; j++) { |
| 191 | usleep_range(100 * j, 100 * j + 100); | 192 | udelay(100 * j); |
| 192 | value1 = clocksource_acpi_pm.read(&clocksource_acpi_pm); | 193 | value1 = clocksource_acpi_pm.read(&clocksource_acpi_pm); |
| 193 | for (i = 0; i < ACPI_PM_READ_CHECKS; i++) { | 194 | for (i = 0; i < ACPI_PM_READ_CHECKS; i++) { |
| 194 | value2 = clocksource_acpi_pm.read(&clocksource_acpi_pm); | 195 | value2 = clocksource_acpi_pm.read(&clocksource_acpi_pm); |
| @@ -202,34 +203,25 @@ static void __init acpi_pm_clocksource_async(void *unused, async_cookie_t cookie | |||
| 202 | " 0x%#llx, 0x%#llx - aborting.\n", | 203 | " 0x%#llx, 0x%#llx - aborting.\n", |
| 203 | value1, value2); | 204 | value1, value2); |
| 204 | pmtmr_ioport = 0; | 205 | pmtmr_ioport = 0; |
| 205 | return; | 206 | return -EINVAL; |
| 206 | } | 207 | } |
| 207 | if (i == ACPI_PM_READ_CHECKS) { | 208 | if (i == ACPI_PM_READ_CHECKS) { |
| 208 | printk(KERN_INFO "PM-Timer failed consistency check " | 209 | printk(KERN_INFO "PM-Timer failed consistency check " |
| 209 | " (0x%#llx) - aborting.\n", value1); | 210 | " (0x%#llx) - aborting.\n", value1); |
| 210 | pmtmr_ioport = 0; | 211 | pmtmr_ioport = 0; |
| 211 | return; | 212 | return -ENODEV; |
| 212 | } | 213 | } |
| 213 | } | 214 | } |
| 214 | 215 | ||
| 215 | if (verify_pmtmr_rate() != 0){ | 216 | if (verify_pmtmr_rate() != 0){ |
| 216 | pmtmr_ioport = 0; | 217 | pmtmr_ioport = 0; |
| 217 | return; | 218 | return -ENODEV; |
| 218 | } | 219 | } |
| 219 | 220 | ||
| 220 | clocksource_register_hz(&clocksource_acpi_pm, | 221 | return clocksource_register_hz(&clocksource_acpi_pm, |
| 221 | PMTMR_TICKS_PER_SEC); | 222 | PMTMR_TICKS_PER_SEC); |
| 222 | } | 223 | } |
| 223 | 224 | ||
| 224 | static int __init init_acpi_pm_clocksource(void) | ||
| 225 | { | ||
| 226 | if (!pmtmr_ioport) | ||
| 227 | return -ENODEV; | ||
| 228 | |||
| 229 | async_schedule(acpi_pm_clocksource_async, NULL); | ||
| 230 | return 0; | ||
| 231 | } | ||
| 232 | |||
| 233 | /* We use fs_initcall because we want the PCI fixups to have run | 225 | /* We use fs_initcall because we want the PCI fixups to have run |
| 234 | * but we still need to load before device_initcall | 226 | * but we still need to load before device_initcall |
| 235 | */ | 227 | */ |
diff --git a/drivers/cpufreq/Kconfig.arm b/drivers/cpufreq/Kconfig.arm index ffbb44685915..5961e6415f08 100644 --- a/drivers/cpufreq/Kconfig.arm +++ b/drivers/cpufreq/Kconfig.arm | |||
| @@ -4,6 +4,7 @@ | |||
| 4 | 4 | ||
| 5 | config ARM_OMAP2PLUS_CPUFREQ | 5 | config ARM_OMAP2PLUS_CPUFREQ |
| 6 | bool "TI OMAP2+" | 6 | bool "TI OMAP2+" |
| 7 | depends on ARCH_OMAP2PLUS | ||
| 7 | default ARCH_OMAP2PLUS | 8 | default ARCH_OMAP2PLUS |
| 8 | select CPU_FREQ_TABLE | 9 | select CPU_FREQ_TABLE |
| 9 | 10 | ||
diff --git a/drivers/crypto/ixp4xx_crypto.c b/drivers/crypto/ixp4xx_crypto.c index 0053d7ebb5ca..8f3f74ce8c7f 100644 --- a/drivers/crypto/ixp4xx_crypto.c +++ b/drivers/crypto/ixp4xx_crypto.c | |||
| @@ -18,6 +18,7 @@ | |||
| 18 | #include <linux/interrupt.h> | 18 | #include <linux/interrupt.h> |
| 19 | #include <linux/spinlock.h> | 19 | #include <linux/spinlock.h> |
| 20 | #include <linux/gfp.h> | 20 | #include <linux/gfp.h> |
| 21 | #include <linux/module.h> | ||
| 21 | 22 | ||
| 22 | #include <crypto/ctr.h> | 23 | #include <crypto/ctr.h> |
| 23 | #include <crypto/des.h> | 24 | #include <crypto/des.h> |
diff --git a/drivers/crypto/talitos.c b/drivers/crypto/talitos.c index dc641c796526..921039e56f87 100644 --- a/drivers/crypto/talitos.c +++ b/drivers/crypto/talitos.c | |||
| @@ -124,6 +124,9 @@ struct talitos_private { | |||
| 124 | void __iomem *reg; | 124 | void __iomem *reg; |
| 125 | int irq[2]; | 125 | int irq[2]; |
| 126 | 126 | ||
| 127 | /* SEC global registers lock */ | ||
| 128 | spinlock_t reg_lock ____cacheline_aligned; | ||
| 129 | |||
| 127 | /* SEC version geometry (from device tree node) */ | 130 | /* SEC version geometry (from device tree node) */ |
| 128 | unsigned int num_channels; | 131 | unsigned int num_channels; |
| 129 | unsigned int chfifo_len; | 132 | unsigned int chfifo_len; |
| @@ -412,6 +415,7 @@ static void talitos_done_##name(unsigned long data) \ | |||
| 412 | { \ | 415 | { \ |
| 413 | struct device *dev = (struct device *)data; \ | 416 | struct device *dev = (struct device *)data; \ |
| 414 | struct talitos_private *priv = dev_get_drvdata(dev); \ | 417 | struct talitos_private *priv = dev_get_drvdata(dev); \ |
| 418 | unsigned long flags; \ | ||
| 415 | \ | 419 | \ |
| 416 | if (ch_done_mask & 1) \ | 420 | if (ch_done_mask & 1) \ |
| 417 | flush_channel(dev, 0, 0, 0); \ | 421 | flush_channel(dev, 0, 0, 0); \ |
| @@ -427,8 +431,10 @@ static void talitos_done_##name(unsigned long data) \ | |||
| 427 | out: \ | 431 | out: \ |
| 428 | /* At this point, all completed channels have been processed */ \ | 432 | /* At this point, all completed channels have been processed */ \ |
| 429 | /* Unmask done interrupts for channels completed later on. */ \ | 433 | /* Unmask done interrupts for channels completed later on. */ \ |
| 434 | spin_lock_irqsave(&priv->reg_lock, flags); \ | ||
| 430 | setbits32(priv->reg + TALITOS_IMR, ch_done_mask); \ | 435 | setbits32(priv->reg + TALITOS_IMR, ch_done_mask); \ |
| 431 | setbits32(priv->reg + TALITOS_IMR_LO, TALITOS_IMR_LO_INIT); \ | 436 | setbits32(priv->reg + TALITOS_IMR_LO, TALITOS_IMR_LO_INIT); \ |
| 437 | spin_unlock_irqrestore(&priv->reg_lock, flags); \ | ||
| 432 | } | 438 | } |
| 433 | DEF_TALITOS_DONE(4ch, TALITOS_ISR_4CHDONE) | 439 | DEF_TALITOS_DONE(4ch, TALITOS_ISR_4CHDONE) |
| 434 | DEF_TALITOS_DONE(ch0_2, TALITOS_ISR_CH_0_2_DONE) | 440 | DEF_TALITOS_DONE(ch0_2, TALITOS_ISR_CH_0_2_DONE) |
| @@ -619,22 +625,28 @@ static irqreturn_t talitos_interrupt_##name(int irq, void *data) \ | |||
| 619 | struct device *dev = data; \ | 625 | struct device *dev = data; \ |
| 620 | struct talitos_private *priv = dev_get_drvdata(dev); \ | 626 | struct talitos_private *priv = dev_get_drvdata(dev); \ |
| 621 | u32 isr, isr_lo; \ | 627 | u32 isr, isr_lo; \ |
| 628 | unsigned long flags; \ | ||
| 622 | \ | 629 | \ |
| 630 | spin_lock_irqsave(&priv->reg_lock, flags); \ | ||
| 623 | isr = in_be32(priv->reg + TALITOS_ISR); \ | 631 | isr = in_be32(priv->reg + TALITOS_ISR); \ |
| 624 | isr_lo = in_be32(priv->reg + TALITOS_ISR_LO); \ | 632 | isr_lo = in_be32(priv->reg + TALITOS_ISR_LO); \ |
| 625 | /* Acknowledge interrupt */ \ | 633 | /* Acknowledge interrupt */ \ |
| 626 | out_be32(priv->reg + TALITOS_ICR, isr & (ch_done_mask | ch_err_mask)); \ | 634 | out_be32(priv->reg + TALITOS_ICR, isr & (ch_done_mask | ch_err_mask)); \ |
| 627 | out_be32(priv->reg + TALITOS_ICR_LO, isr_lo); \ | 635 | out_be32(priv->reg + TALITOS_ICR_LO, isr_lo); \ |
| 628 | \ | 636 | \ |
| 629 | if (unlikely((isr & ~TALITOS_ISR_4CHDONE) & ch_err_mask || isr_lo)) \ | 637 | if (unlikely(isr & ch_err_mask || isr_lo)) { \ |
| 630 | talitos_error(dev, isr, isr_lo); \ | 638 | spin_unlock_irqrestore(&priv->reg_lock, flags); \ |
| 631 | else \ | 639 | talitos_error(dev, isr & ch_err_mask, isr_lo); \ |
| 640 | } \ | ||
| 641 | else { \ | ||
| 632 | if (likely(isr & ch_done_mask)) { \ | 642 | if (likely(isr & ch_done_mask)) { \ |
| 633 | /* mask further done interrupts. */ \ | 643 | /* mask further done interrupts. */ \ |
| 634 | clrbits32(priv->reg + TALITOS_IMR, ch_done_mask); \ | 644 | clrbits32(priv->reg + TALITOS_IMR, ch_done_mask); \ |
| 635 | /* done_task will unmask done interrupts at exit */ \ | 645 | /* done_task will unmask done interrupts at exit */ \ |
| 636 | tasklet_schedule(&priv->done_task[tlet]); \ | 646 | tasklet_schedule(&priv->done_task[tlet]); \ |
| 637 | } \ | 647 | } \ |
| 648 | spin_unlock_irqrestore(&priv->reg_lock, flags); \ | ||
| 649 | } \ | ||
| 638 | \ | 650 | \ |
| 639 | return (isr & (ch_done_mask | ch_err_mask) || isr_lo) ? IRQ_HANDLED : \ | 651 | return (isr & (ch_done_mask | ch_err_mask) || isr_lo) ? IRQ_HANDLED : \ |
| 640 | IRQ_NONE; \ | 652 | IRQ_NONE; \ |
| @@ -2719,6 +2731,8 @@ static int talitos_probe(struct platform_device *ofdev) | |||
| 2719 | 2731 | ||
| 2720 | priv->ofdev = ofdev; | 2732 | priv->ofdev = ofdev; |
| 2721 | 2733 | ||
| 2734 | spin_lock_init(&priv->reg_lock); | ||
| 2735 | |||
| 2722 | err = talitos_probe_irq(ofdev); | 2736 | err = talitos_probe_irq(ofdev); |
| 2723 | if (err) | 2737 | if (err) |
| 2724 | goto err_out; | 2738 | goto err_out; |
diff --git a/drivers/dma/Kconfig b/drivers/dma/Kconfig index cf9da362d64f..ef378b5b17e4 100644 --- a/drivers/dma/Kconfig +++ b/drivers/dma/Kconfig | |||
| @@ -91,11 +91,10 @@ config DW_DMAC | |||
| 91 | 91 | ||
| 92 | config AT_HDMAC | 92 | config AT_HDMAC |
| 93 | tristate "Atmel AHB DMA support" | 93 | tristate "Atmel AHB DMA support" |
| 94 | depends on ARCH_AT91SAM9RL || ARCH_AT91SAM9G45 | 94 | depends on ARCH_AT91 |
| 95 | select DMA_ENGINE | 95 | select DMA_ENGINE |
| 96 | help | 96 | help |
| 97 | Support the Atmel AHB DMA controller. This can be integrated in | 97 | Support the Atmel AHB DMA controller. |
| 98 | chips such as the Atmel AT91SAM9RL. | ||
| 99 | 98 | ||
| 100 | config FSL_DMA | 99 | config FSL_DMA |
| 101 | tristate "Freescale Elo and Elo Plus DMA support" | 100 | tristate "Freescale Elo and Elo Plus DMA support" |
diff --git a/drivers/gpio/Kconfig b/drivers/gpio/Kconfig index edadbdad31d0..e03653d69357 100644 --- a/drivers/gpio/Kconfig +++ b/drivers/gpio/Kconfig | |||
| @@ -430,7 +430,7 @@ config GPIO_ML_IOH | |||
| 430 | 430 | ||
| 431 | config GPIO_SODAVILLE | 431 | config GPIO_SODAVILLE |
| 432 | bool "Intel Sodaville GPIO support" | 432 | bool "Intel Sodaville GPIO support" |
| 433 | depends on X86 && PCI && OF && BROKEN | 433 | depends on X86 && PCI && OF |
| 434 | select GPIO_GENERIC | 434 | select GPIO_GENERIC |
| 435 | select GENERIC_IRQ_CHIP | 435 | select GENERIC_IRQ_CHIP |
| 436 | help | 436 | help |
diff --git a/drivers/gpio/gpio-adp5588.c b/drivers/gpio/gpio-adp5588.c index 9ad1703d1408..ae5d7f12ce66 100644 --- a/drivers/gpio/gpio-adp5588.c +++ b/drivers/gpio/gpio-adp5588.c | |||
| @@ -252,7 +252,7 @@ static irqreturn_t adp5588_irq_handler(int irq, void *devid) | |||
| 252 | if (ret < 0) | 252 | if (ret < 0) |
| 253 | memset(dev->irq_stat, 0, ARRAY_SIZE(dev->irq_stat)); | 253 | memset(dev->irq_stat, 0, ARRAY_SIZE(dev->irq_stat)); |
| 254 | 254 | ||
| 255 | for (bank = 0; bank <= ADP5588_BANK(ADP5588_MAXGPIO); | 255 | for (bank = 0, bit = 0; bank <= ADP5588_BANK(ADP5588_MAXGPIO); |
| 256 | bank++, bit = 0) { | 256 | bank++, bit = 0) { |
| 257 | pending = dev->irq_stat[bank] & dev->irq_mask[bank]; | 257 | pending = dev->irq_stat[bank] & dev->irq_mask[bank]; |
| 258 | 258 | ||
diff --git a/drivers/gpio/gpio-samsung.c b/drivers/gpio/gpio-samsung.c index 46277877b7ec..19d6fc0229c3 100644 --- a/drivers/gpio/gpio-samsung.c +++ b/drivers/gpio/gpio-samsung.c | |||
| @@ -2382,8 +2382,8 @@ static struct samsung_gpio_chip exynos4_gpios_3[] = { | |||
| 2382 | #endif | 2382 | #endif |
| 2383 | }; | 2383 | }; |
| 2384 | 2384 | ||
| 2385 | static struct samsung_gpio_chip exynos5_gpios_1[] = { | ||
| 2386 | #ifdef CONFIG_ARCH_EXYNOS5 | 2385 | #ifdef CONFIG_ARCH_EXYNOS5 |
| 2386 | static struct samsung_gpio_chip exynos5_gpios_1[] = { | ||
| 2387 | { | 2387 | { |
| 2388 | .chip = { | 2388 | .chip = { |
| 2389 | .base = EXYNOS5_GPA0(0), | 2389 | .base = EXYNOS5_GPA0(0), |
| @@ -2541,11 +2541,11 @@ static struct samsung_gpio_chip exynos5_gpios_1[] = { | |||
| 2541 | .to_irq = samsung_gpiolib_to_irq, | 2541 | .to_irq = samsung_gpiolib_to_irq, |
| 2542 | }, | 2542 | }, |
| 2543 | }, | 2543 | }, |
| 2544 | #endif | ||
| 2545 | }; | 2544 | }; |
| 2545 | #endif | ||
| 2546 | 2546 | ||
| 2547 | static struct samsung_gpio_chip exynos5_gpios_2[] = { | ||
| 2548 | #ifdef CONFIG_ARCH_EXYNOS5 | 2547 | #ifdef CONFIG_ARCH_EXYNOS5 |
| 2548 | static struct samsung_gpio_chip exynos5_gpios_2[] = { | ||
| 2549 | { | 2549 | { |
| 2550 | .chip = { | 2550 | .chip = { |
| 2551 | .base = EXYNOS5_GPE0(0), | 2551 | .base = EXYNOS5_GPE0(0), |
| @@ -2602,11 +2602,11 @@ static struct samsung_gpio_chip exynos5_gpios_2[] = { | |||
| 2602 | 2602 | ||
| 2603 | }, | 2603 | }, |
| 2604 | }, | 2604 | }, |
| 2605 | #endif | ||
| 2606 | }; | 2605 | }; |
| 2606 | #endif | ||
| 2607 | 2607 | ||
| 2608 | static struct samsung_gpio_chip exynos5_gpios_3[] = { | ||
| 2609 | #ifdef CONFIG_ARCH_EXYNOS5 | 2608 | #ifdef CONFIG_ARCH_EXYNOS5 |
| 2609 | static struct samsung_gpio_chip exynos5_gpios_3[] = { | ||
| 2610 | { | 2610 | { |
| 2611 | .chip = { | 2611 | .chip = { |
| 2612 | .base = EXYNOS5_GPV0(0), | 2612 | .base = EXYNOS5_GPV0(0), |
| @@ -2638,11 +2638,11 @@ static struct samsung_gpio_chip exynos5_gpios_3[] = { | |||
| 2638 | .label = "GPV4", | 2638 | .label = "GPV4", |
| 2639 | }, | 2639 | }, |
| 2640 | }, | 2640 | }, |
| 2641 | #endif | ||
| 2642 | }; | 2641 | }; |
| 2642 | #endif | ||
| 2643 | 2643 | ||
| 2644 | static struct samsung_gpio_chip exynos5_gpios_4[] = { | ||
| 2645 | #ifdef CONFIG_ARCH_EXYNOS5 | 2644 | #ifdef CONFIG_ARCH_EXYNOS5 |
| 2645 | static struct samsung_gpio_chip exynos5_gpios_4[] = { | ||
| 2646 | { | 2646 | { |
| 2647 | .chip = { | 2647 | .chip = { |
| 2648 | .base = EXYNOS5_GPZ(0), | 2648 | .base = EXYNOS5_GPZ(0), |
| @@ -2650,8 +2650,8 @@ static struct samsung_gpio_chip exynos5_gpios_4[] = { | |||
| 2650 | .label = "GPZ", | 2650 | .label = "GPZ", |
| 2651 | }, | 2651 | }, |
| 2652 | }, | 2652 | }, |
| 2653 | #endif | ||
| 2654 | }; | 2653 | }; |
| 2654 | #endif | ||
| 2655 | 2655 | ||
| 2656 | 2656 | ||
| 2657 | #if defined(CONFIG_ARCH_EXYNOS) && defined(CONFIG_OF) | 2657 | #if defined(CONFIG_ARCH_EXYNOS) && defined(CONFIG_OF) |
diff --git a/drivers/gpio/gpio-sodaville.c b/drivers/gpio/gpio-sodaville.c index 9ba15d31d242..031e5d24837d 100644 --- a/drivers/gpio/gpio-sodaville.c +++ b/drivers/gpio/gpio-sodaville.c | |||
| @@ -41,7 +41,7 @@ | |||
| 41 | struct sdv_gpio_chip_data { | 41 | struct sdv_gpio_chip_data { |
| 42 | int irq_base; | 42 | int irq_base; |
| 43 | void __iomem *gpio_pub_base; | 43 | void __iomem *gpio_pub_base; |
| 44 | struct irq_domain id; | 44 | struct irq_domain *id; |
| 45 | struct irq_chip_generic *gc; | 45 | struct irq_chip_generic *gc; |
| 46 | struct bgpio_chip bgpio; | 46 | struct bgpio_chip bgpio; |
| 47 | }; | 47 | }; |
| @@ -51,10 +51,9 @@ static int sdv_gpio_pub_set_type(struct irq_data *d, unsigned int type) | |||
| 51 | struct irq_chip_generic *gc = irq_data_get_irq_chip_data(d); | 51 | struct irq_chip_generic *gc = irq_data_get_irq_chip_data(d); |
| 52 | struct sdv_gpio_chip_data *sd = gc->private; | 52 | struct sdv_gpio_chip_data *sd = gc->private; |
| 53 | void __iomem *type_reg; | 53 | void __iomem *type_reg; |
| 54 | u32 irq_offs = d->irq - sd->irq_base; | ||
| 55 | u32 reg; | 54 | u32 reg; |
| 56 | 55 | ||
| 57 | if (irq_offs < 8) | 56 | if (d->hwirq < 8) |
| 58 | type_reg = sd->gpio_pub_base + GPIT1R0; | 57 | type_reg = sd->gpio_pub_base + GPIT1R0; |
| 59 | else | 58 | else |
| 60 | type_reg = sd->gpio_pub_base + GPIT1R1; | 59 | type_reg = sd->gpio_pub_base + GPIT1R1; |
| @@ -63,11 +62,11 @@ static int sdv_gpio_pub_set_type(struct irq_data *d, unsigned int type) | |||
| 63 | 62 | ||
| 64 | switch (type) { | 63 | switch (type) { |
| 65 | case IRQ_TYPE_LEVEL_HIGH: | 64 | case IRQ_TYPE_LEVEL_HIGH: |
| 66 | reg &= ~BIT(4 * (irq_offs % 8)); | 65 | reg &= ~BIT(4 * (d->hwirq % 8)); |
| 67 | break; | 66 | break; |
| 68 | 67 | ||
| 69 | case IRQ_TYPE_LEVEL_LOW: | 68 | case IRQ_TYPE_LEVEL_LOW: |
| 70 | reg |= BIT(4 * (irq_offs % 8)); | 69 | reg |= BIT(4 * (d->hwirq % 8)); |
| 71 | break; | 70 | break; |
| 72 | 71 | ||
| 73 | default: | 72 | default: |
| @@ -91,7 +90,7 @@ static irqreturn_t sdv_gpio_pub_irq_handler(int irq, void *data) | |||
| 91 | u32 irq_bit = __fls(irq_stat); | 90 | u32 irq_bit = __fls(irq_stat); |
| 92 | 91 | ||
| 93 | irq_stat &= ~BIT(irq_bit); | 92 | irq_stat &= ~BIT(irq_bit); |
| 94 | generic_handle_irq(sd->irq_base + irq_bit); | 93 | generic_handle_irq(irq_find_mapping(sd->id, irq_bit)); |
| 95 | } | 94 | } |
| 96 | 95 | ||
| 97 | return IRQ_HANDLED; | 96 | return IRQ_HANDLED; |
| @@ -127,7 +126,7 @@ static int sdv_xlate(struct irq_domain *h, struct device_node *node, | |||
| 127 | } | 126 | } |
| 128 | 127 | ||
| 129 | static struct irq_domain_ops irq_domain_sdv_ops = { | 128 | static struct irq_domain_ops irq_domain_sdv_ops = { |
| 130 | .dt_translate = sdv_xlate, | 129 | .xlate = sdv_xlate, |
| 131 | }; | 130 | }; |
| 132 | 131 | ||
| 133 | static __devinit int sdv_register_irqsupport(struct sdv_gpio_chip_data *sd, | 132 | static __devinit int sdv_register_irqsupport(struct sdv_gpio_chip_data *sd, |
| @@ -149,10 +148,6 @@ static __devinit int sdv_register_irqsupport(struct sdv_gpio_chip_data *sd, | |||
| 149 | if (ret) | 148 | if (ret) |
| 150 | goto out_free_desc; | 149 | goto out_free_desc; |
| 151 | 150 | ||
| 152 | sd->id.irq_base = sd->irq_base; | ||
| 153 | sd->id.of_node = of_node_get(pdev->dev.of_node); | ||
| 154 | sd->id.ops = &irq_domain_sdv_ops; | ||
| 155 | |||
| 156 | /* | 151 | /* |
| 157 | * This gpio irq controller latches level irqs. Testing shows that if | 152 | * This gpio irq controller latches level irqs. Testing shows that if |
| 158 | * we unmask & ACK the IRQ before the source of the interrupt is gone | 153 | * we unmask & ACK the IRQ before the source of the interrupt is gone |
| @@ -179,7 +174,10 @@ static __devinit int sdv_register_irqsupport(struct sdv_gpio_chip_data *sd, | |||
| 179 | IRQ_GC_INIT_MASK_CACHE, IRQ_NOREQUEST, | 174 | IRQ_GC_INIT_MASK_CACHE, IRQ_NOREQUEST, |
| 180 | IRQ_LEVEL | IRQ_NOPROBE); | 175 | IRQ_LEVEL | IRQ_NOPROBE); |
| 181 | 176 | ||
| 182 | irq_domain_add(&sd->id); | 177 | sd->id = irq_domain_add_legacy(pdev->dev.of_node, SDV_NUM_PUB_GPIOS, |
| 178 | sd->irq_base, 0, &irq_domain_sdv_ops, sd); | ||
| 179 | if (!sd->id) | ||
| 180 | goto out_free_irq; | ||
| 183 | return 0; | 181 | return 0; |
| 184 | out_free_irq: | 182 | out_free_irq: |
| 185 | free_irq(pdev->irq, sd); | 183 | free_irq(pdev->irq, sd); |
| @@ -260,7 +258,6 @@ static void sdv_gpio_remove(struct pci_dev *pdev) | |||
| 260 | { | 258 | { |
| 261 | struct sdv_gpio_chip_data *sd = pci_get_drvdata(pdev); | 259 | struct sdv_gpio_chip_data *sd = pci_get_drvdata(pdev); |
| 262 | 260 | ||
| 263 | irq_domain_del(&sd->id); | ||
| 264 | free_irq(pdev->irq, sd); | 261 | free_irq(pdev->irq, sd); |
| 265 | irq_free_descs(sd->irq_base, SDV_NUM_PUB_GPIOS); | 262 | irq_free_descs(sd->irq_base, SDV_NUM_PUB_GPIOS); |
| 266 | 263 | ||
diff --git a/drivers/gpu/drm/drm_bufs.c b/drivers/gpu/drm/drm_bufs.c index 30372f7b2d45..348b367debeb 100644 --- a/drivers/gpu/drm/drm_bufs.c +++ b/drivers/gpu/drm/drm_bufs.c | |||
| @@ -1510,8 +1510,8 @@ int drm_freebufs(struct drm_device *dev, void *data, | |||
| 1510 | * \param arg pointer to a drm_buf_map structure. | 1510 | * \param arg pointer to a drm_buf_map structure. |
| 1511 | * \return zero on success or a negative number on failure. | 1511 | * \return zero on success or a negative number on failure. |
| 1512 | * | 1512 | * |
| 1513 | * Maps the AGP, SG or PCI buffer region with do_mmap(), and copies information | 1513 | * Maps the AGP, SG or PCI buffer region with vm_mmap(), and copies information |
| 1514 | * about each buffer into user space. For PCI buffers, it calls do_mmap() with | 1514 | * about each buffer into user space. For PCI buffers, it calls vm_mmap() with |
| 1515 | * offset equal to 0, which drm_mmap() interpretes as PCI buffers and calls | 1515 | * offset equal to 0, which drm_mmap() interpretes as PCI buffers and calls |
| 1516 | * drm_mmap_dma(). | 1516 | * drm_mmap_dma(). |
| 1517 | */ | 1517 | */ |
| @@ -1553,18 +1553,14 @@ int drm_mapbufs(struct drm_device *dev, void *data, | |||
| 1553 | retcode = -EINVAL; | 1553 | retcode = -EINVAL; |
| 1554 | goto done; | 1554 | goto done; |
| 1555 | } | 1555 | } |
| 1556 | down_write(¤t->mm->mmap_sem); | 1556 | virtual = vm_mmap(file_priv->filp, 0, map->size, |
| 1557 | virtual = do_mmap(file_priv->filp, 0, map->size, | ||
| 1558 | PROT_READ | PROT_WRITE, | 1557 | PROT_READ | PROT_WRITE, |
| 1559 | MAP_SHARED, | 1558 | MAP_SHARED, |
| 1560 | token); | 1559 | token); |
| 1561 | up_write(¤t->mm->mmap_sem); | ||
| 1562 | } else { | 1560 | } else { |
| 1563 | down_write(¤t->mm->mmap_sem); | 1561 | virtual = vm_mmap(file_priv->filp, 0, dma->byte_count, |
| 1564 | virtual = do_mmap(file_priv->filp, 0, dma->byte_count, | ||
| 1565 | PROT_READ | PROT_WRITE, | 1562 | PROT_READ | PROT_WRITE, |
| 1566 | MAP_SHARED, 0); | 1563 | MAP_SHARED, 0); |
| 1567 | up_write(¤t->mm->mmap_sem); | ||
| 1568 | } | 1564 | } |
| 1569 | if (virtual > -1024UL) { | 1565 | if (virtual > -1024UL) { |
| 1570 | /* Real error */ | 1566 | /* Real error */ |
diff --git a/drivers/gpu/drm/drm_crtc.c b/drivers/gpu/drm/drm_crtc.c index d3aaeb6ae236..c79870a75c2f 100644 --- a/drivers/gpu/drm/drm_crtc.c +++ b/drivers/gpu/drm/drm_crtc.c | |||
| @@ -3335,10 +3335,12 @@ int drm_mode_page_flip_ioctl(struct drm_device *dev, | |||
| 3335 | 3335 | ||
| 3336 | ret = crtc->funcs->page_flip(crtc, fb, e); | 3336 | ret = crtc->funcs->page_flip(crtc, fb, e); |
| 3337 | if (ret) { | 3337 | if (ret) { |
| 3338 | spin_lock_irqsave(&dev->event_lock, flags); | 3338 | if (page_flip->flags & DRM_MODE_PAGE_FLIP_EVENT) { |
| 3339 | file_priv->event_space += sizeof e->event; | 3339 | spin_lock_irqsave(&dev->event_lock, flags); |
| 3340 | spin_unlock_irqrestore(&dev->event_lock, flags); | 3340 | file_priv->event_space += sizeof e->event; |
| 3341 | kfree(e); | 3341 | spin_unlock_irqrestore(&dev->event_lock, flags); |
| 3342 | kfree(e); | ||
| 3343 | } | ||
| 3342 | } | 3344 | } |
| 3343 | 3345 | ||
| 3344 | out: | 3346 | out: |
diff --git a/drivers/gpu/drm/drm_fops.c b/drivers/gpu/drm/drm_fops.c index cdfbf27b2b3c..123de28f94ef 100644 --- a/drivers/gpu/drm/drm_fops.c +++ b/drivers/gpu/drm/drm_fops.c | |||
| @@ -507,12 +507,12 @@ int drm_release(struct inode *inode, struct file *filp) | |||
| 507 | 507 | ||
| 508 | drm_events_release(file_priv); | 508 | drm_events_release(file_priv); |
| 509 | 509 | ||
| 510 | if (dev->driver->driver_features & DRIVER_GEM) | ||
| 511 | drm_gem_release(dev, file_priv); | ||
| 512 | |||
| 513 | if (dev->driver->driver_features & DRIVER_MODESET) | 510 | if (dev->driver->driver_features & DRIVER_MODESET) |
| 514 | drm_fb_release(file_priv); | 511 | drm_fb_release(file_priv); |
| 515 | 512 | ||
| 513 | if (dev->driver->driver_features & DRIVER_GEM) | ||
| 514 | drm_gem_release(dev, file_priv); | ||
| 515 | |||
| 516 | mutex_lock(&dev->ctxlist_mutex); | 516 | mutex_lock(&dev->ctxlist_mutex); |
| 517 | if (!list_empty(&dev->ctxlist)) { | 517 | if (!list_empty(&dev->ctxlist)) { |
| 518 | struct drm_ctx_list *pos, *n; | 518 | struct drm_ctx_list *pos, *n; |
diff --git a/drivers/gpu/drm/drm_usb.c b/drivers/gpu/drm/drm_usb.c index c8c83dad2ce1..37c9a523dd1c 100644 --- a/drivers/gpu/drm/drm_usb.c +++ b/drivers/gpu/drm/drm_usb.c | |||
| @@ -1,6 +1,6 @@ | |||
| 1 | #include "drmP.h" | 1 | #include "drmP.h" |
| 2 | #include <linux/usb.h> | 2 | #include <linux/usb.h> |
| 3 | #include <linux/export.h> | 3 | #include <linux/module.h> |
| 4 | 4 | ||
| 5 | int drm_get_usb_dev(struct usb_interface *interface, | 5 | int drm_get_usb_dev(struct usb_interface *interface, |
| 6 | const struct usb_device_id *id, | 6 | const struct usb_device_id *id, |
| @@ -114,3 +114,7 @@ void drm_usb_exit(struct drm_driver *driver, | |||
| 114 | usb_deregister(udriver); | 114 | usb_deregister(udriver); |
| 115 | } | 115 | } |
| 116 | EXPORT_SYMBOL(drm_usb_exit); | 116 | EXPORT_SYMBOL(drm_usb_exit); |
| 117 | |||
| 118 | MODULE_AUTHOR("David Airlie"); | ||
| 119 | MODULE_DESCRIPTION("USB DRM support"); | ||
| 120 | MODULE_LICENSE("GPL and additional rights"); | ||
diff --git a/drivers/gpu/drm/exynos/exynos_drm_gem.c b/drivers/gpu/drm/exynos/exynos_drm_gem.c index 26d51979116b..392ce71ed6a1 100644 --- a/drivers/gpu/drm/exynos/exynos_drm_gem.c +++ b/drivers/gpu/drm/exynos/exynos_drm_gem.c | |||
| @@ -581,10 +581,8 @@ int exynos_drm_gem_mmap_ioctl(struct drm_device *dev, void *data, | |||
| 581 | obj->filp->f_op = &exynos_drm_gem_fops; | 581 | obj->filp->f_op = &exynos_drm_gem_fops; |
| 582 | obj->filp->private_data = obj; | 582 | obj->filp->private_data = obj; |
| 583 | 583 | ||
| 584 | down_write(¤t->mm->mmap_sem); | 584 | addr = vm_mmap(obj->filp, 0, args->size, |
| 585 | addr = do_mmap(obj->filp, 0, args->size, | ||
| 586 | PROT_READ | PROT_WRITE, MAP_SHARED, 0); | 585 | PROT_READ | PROT_WRITE, MAP_SHARED, 0); |
| 587 | up_write(¤t->mm->mmap_sem); | ||
| 588 | 586 | ||
| 589 | drm_gem_object_unreference_unlocked(obj); | 587 | drm_gem_object_unreference_unlocked(obj); |
| 590 | 588 | ||
diff --git a/drivers/gpu/drm/gma500/mdfld_dsi_output.h b/drivers/gpu/drm/gma500/mdfld_dsi_output.h index 21071cef92a4..36eb0744841c 100644 --- a/drivers/gpu/drm/gma500/mdfld_dsi_output.h +++ b/drivers/gpu/drm/gma500/mdfld_dsi_output.h | |||
| @@ -29,7 +29,6 @@ | |||
| 29 | #define __MDFLD_DSI_OUTPUT_H__ | 29 | #define __MDFLD_DSI_OUTPUT_H__ |
| 30 | 30 | ||
| 31 | #include <linux/backlight.h> | 31 | #include <linux/backlight.h> |
| 32 | #include <linux/version.h> | ||
| 33 | #include <drm/drmP.h> | 32 | #include <drm/drmP.h> |
| 34 | #include <drm/drm.h> | 33 | #include <drm/drm.h> |
| 35 | #include <drm/drm_crtc.h> | 34 | #include <drm/drm_crtc.h> |
diff --git a/drivers/gpu/drm/i810/i810_dma.c b/drivers/gpu/drm/i810/i810_dma.c index 2c8a60c3b98e..f920fb5e42b6 100644 --- a/drivers/gpu/drm/i810/i810_dma.c +++ b/drivers/gpu/drm/i810/i810_dma.c | |||
| @@ -129,6 +129,7 @@ static int i810_map_buffer(struct drm_buf *buf, struct drm_file *file_priv) | |||
| 129 | if (buf_priv->currently_mapped == I810_BUF_MAPPED) | 129 | if (buf_priv->currently_mapped == I810_BUF_MAPPED) |
| 130 | return -EINVAL; | 130 | return -EINVAL; |
| 131 | 131 | ||
| 132 | /* This is all entirely broken */ | ||
| 132 | down_write(¤t->mm->mmap_sem); | 133 | down_write(¤t->mm->mmap_sem); |
| 133 | old_fops = file_priv->filp->f_op; | 134 | old_fops = file_priv->filp->f_op; |
| 134 | file_priv->filp->f_op = &i810_buffer_fops; | 135 | file_priv->filp->f_op = &i810_buffer_fops; |
| @@ -157,11 +158,8 @@ static int i810_unmap_buffer(struct drm_buf *buf) | |||
| 157 | if (buf_priv->currently_mapped != I810_BUF_MAPPED) | 158 | if (buf_priv->currently_mapped != I810_BUF_MAPPED) |
| 158 | return -EINVAL; | 159 | return -EINVAL; |
| 159 | 160 | ||
| 160 | down_write(¤t->mm->mmap_sem); | 161 | retcode = vm_munmap((unsigned long)buf_priv->virtual, |
| 161 | retcode = do_munmap(current->mm, | ||
| 162 | (unsigned long)buf_priv->virtual, | ||
| 163 | (size_t) buf->total); | 162 | (size_t) buf->total); |
| 164 | up_write(¤t->mm->mmap_sem); | ||
| 165 | 163 | ||
| 166 | buf_priv->currently_mapped = I810_BUF_UNMAPPED; | 164 | buf_priv->currently_mapped = I810_BUF_UNMAPPED; |
| 167 | buf_priv->virtual = NULL; | 165 | buf_priv->virtual = NULL; |
diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c index 0e3c6acde955..0d1e4b7b4b99 100644 --- a/drivers/gpu/drm/i915/i915_gem.c +++ b/drivers/gpu/drm/i915/i915_gem.c | |||
| @@ -1087,11 +1087,9 @@ i915_gem_mmap_ioctl(struct drm_device *dev, void *data, | |||
| 1087 | if (obj == NULL) | 1087 | if (obj == NULL) |
| 1088 | return -ENOENT; | 1088 | return -ENOENT; |
| 1089 | 1089 | ||
| 1090 | down_write(¤t->mm->mmap_sem); | 1090 | addr = vm_mmap(obj->filp, 0, args->size, |
| 1091 | addr = do_mmap(obj->filp, 0, args->size, | ||
| 1092 | PROT_READ | PROT_WRITE, MAP_SHARED, | 1091 | PROT_READ | PROT_WRITE, MAP_SHARED, |
| 1093 | args->offset); | 1092 | args->offset); |
| 1094 | up_write(¤t->mm->mmap_sem); | ||
| 1095 | drm_gem_object_unreference_unlocked(obj); | 1093 | drm_gem_object_unreference_unlocked(obj); |
| 1096 | if (IS_ERR((void *)addr)) | 1094 | if (IS_ERR((void *)addr)) |
| 1097 | return addr; | 1095 | return addr; |
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c index bae38acf44dc..5908cd563400 100644 --- a/drivers/gpu/drm/i915/intel_display.c +++ b/drivers/gpu/drm/i915/intel_display.c | |||
| @@ -3478,8 +3478,11 @@ static bool intel_crtc_mode_fixup(struct drm_crtc *crtc, | |||
| 3478 | return false; | 3478 | return false; |
| 3479 | } | 3479 | } |
| 3480 | 3480 | ||
| 3481 | /* All interlaced capable intel hw wants timings in frames. */ | 3481 | /* All interlaced capable intel hw wants timings in frames. Note though |
| 3482 | drm_mode_set_crtcinfo(adjusted_mode, 0); | 3482 | * that intel_lvds_mode_fixup does some funny tricks with the crtc |
| 3483 | * timings, so we need to be careful not to clobber these.*/ | ||
| 3484 | if (!(adjusted_mode->private_flags & INTEL_MODE_CRTC_TIMINGS_SET)) | ||
| 3485 | drm_mode_set_crtcinfo(adjusted_mode, 0); | ||
| 3483 | 3486 | ||
| 3484 | return true; | 3487 | return true; |
| 3485 | } | 3488 | } |
| @@ -7465,7 +7468,13 @@ static int intel_gen6_queue_flip(struct drm_device *dev, | |||
| 7465 | OUT_RING(fb->pitches[0] | obj->tiling_mode); | 7468 | OUT_RING(fb->pitches[0] | obj->tiling_mode); |
| 7466 | OUT_RING(obj->gtt_offset); | 7469 | OUT_RING(obj->gtt_offset); |
| 7467 | 7470 | ||
| 7468 | pf = I915_READ(PF_CTL(intel_crtc->pipe)) & PF_ENABLE; | 7471 | /* Contrary to the suggestions in the documentation, |
| 7472 | * "Enable Panel Fitter" does not seem to be required when page | ||
| 7473 | * flipping with a non-native mode, and worse causes a normal | ||
| 7474 | * modeset to fail. | ||
| 7475 | * pf = I915_READ(PF_CTL(intel_crtc->pipe)) & PF_ENABLE; | ||
| 7476 | */ | ||
| 7477 | pf = 0; | ||
| 7469 | pipesrc = I915_READ(PIPESRC(intel_crtc->pipe)) & 0x0fff0fff; | 7478 | pipesrc = I915_READ(PIPESRC(intel_crtc->pipe)) & 0x0fff0fff; |
| 7470 | OUT_RING(pf | pipesrc); | 7479 | OUT_RING(pf | pipesrc); |
| 7471 | ADVANCE_LP_RING(); | 7480 | ADVANCE_LP_RING(); |
diff --git a/drivers/gpu/drm/i915/intel_drv.h b/drivers/gpu/drm/i915/intel_drv.h index 5a14149b3794..715afa153025 100644 --- a/drivers/gpu/drm/i915/intel_drv.h +++ b/drivers/gpu/drm/i915/intel_drv.h | |||
| @@ -105,6 +105,10 @@ | |||
| 105 | #define INTEL_MODE_PIXEL_MULTIPLIER_SHIFT (0x0) | 105 | #define INTEL_MODE_PIXEL_MULTIPLIER_SHIFT (0x0) |
| 106 | #define INTEL_MODE_PIXEL_MULTIPLIER_MASK (0xf << INTEL_MODE_PIXEL_MULTIPLIER_SHIFT) | 106 | #define INTEL_MODE_PIXEL_MULTIPLIER_MASK (0xf << INTEL_MODE_PIXEL_MULTIPLIER_SHIFT) |
| 107 | #define INTEL_MODE_DP_FORCE_6BPC (0x10) | 107 | #define INTEL_MODE_DP_FORCE_6BPC (0x10) |
| 108 | /* This flag must be set by the encoder's mode_fixup if it changes the crtc | ||
| 109 | * timings in the mode to prevent the crtc fixup from overwriting them. | ||
| 110 | * Currently only lvds needs that. */ | ||
| 111 | #define INTEL_MODE_CRTC_TIMINGS_SET (0x20) | ||
| 108 | 112 | ||
| 109 | static inline void | 113 | static inline void |
| 110 | intel_mode_set_pixel_multiplier(struct drm_display_mode *mode, | 114 | intel_mode_set_pixel_multiplier(struct drm_display_mode *mode, |
diff --git a/drivers/gpu/drm/i915/intel_fb.c b/drivers/gpu/drm/i915/intel_fb.c index 19ecd78b8a2c..6e9ee33fd412 100644 --- a/drivers/gpu/drm/i915/intel_fb.c +++ b/drivers/gpu/drm/i915/intel_fb.c | |||
| @@ -279,6 +279,8 @@ void intel_fb_restore_mode(struct drm_device *dev) | |||
| 279 | struct drm_mode_config *config = &dev->mode_config; | 279 | struct drm_mode_config *config = &dev->mode_config; |
| 280 | struct drm_plane *plane; | 280 | struct drm_plane *plane; |
| 281 | 281 | ||
| 282 | mutex_lock(&dev->mode_config.mutex); | ||
| 283 | |||
| 282 | ret = drm_fb_helper_restore_fbdev_mode(&dev_priv->fbdev->helper); | 284 | ret = drm_fb_helper_restore_fbdev_mode(&dev_priv->fbdev->helper); |
| 283 | if (ret) | 285 | if (ret) |
| 284 | DRM_DEBUG("failed to restore crtc mode\n"); | 286 | DRM_DEBUG("failed to restore crtc mode\n"); |
| @@ -286,4 +288,6 @@ void intel_fb_restore_mode(struct drm_device *dev) | |||
| 286 | /* Be sure to shut off any planes that may be active */ | 288 | /* Be sure to shut off any planes that may be active */ |
| 287 | list_for_each_entry(plane, &config->plane_list, head) | 289 | list_for_each_entry(plane, &config->plane_list, head) |
| 288 | plane->funcs->disable_plane(plane); | 290 | plane->funcs->disable_plane(plane); |
| 291 | |||
| 292 | mutex_unlock(&dev->mode_config.mutex); | ||
| 289 | } | 293 | } |
diff --git a/drivers/gpu/drm/i915/intel_lvds.c b/drivers/gpu/drm/i915/intel_lvds.c index 95db2e988227..30e2c82101de 100644 --- a/drivers/gpu/drm/i915/intel_lvds.c +++ b/drivers/gpu/drm/i915/intel_lvds.c | |||
| @@ -187,6 +187,8 @@ centre_horizontally(struct drm_display_mode *mode, | |||
| 187 | 187 | ||
| 188 | mode->crtc_hsync_start = mode->crtc_hblank_start + sync_pos; | 188 | mode->crtc_hsync_start = mode->crtc_hblank_start + sync_pos; |
| 189 | mode->crtc_hsync_end = mode->crtc_hsync_start + sync_width; | 189 | mode->crtc_hsync_end = mode->crtc_hsync_start + sync_width; |
| 190 | |||
| 191 | mode->private_flags |= INTEL_MODE_CRTC_TIMINGS_SET; | ||
| 190 | } | 192 | } |
| 191 | 193 | ||
| 192 | static void | 194 | static void |
| @@ -208,6 +210,8 @@ centre_vertically(struct drm_display_mode *mode, | |||
| 208 | 210 | ||
| 209 | mode->crtc_vsync_start = mode->crtc_vblank_start + sync_pos; | 211 | mode->crtc_vsync_start = mode->crtc_vblank_start + sync_pos; |
| 210 | mode->crtc_vsync_end = mode->crtc_vsync_start + sync_width; | 212 | mode->crtc_vsync_end = mode->crtc_vsync_start + sync_width; |
| 213 | |||
| 214 | mode->private_flags |= INTEL_MODE_CRTC_TIMINGS_SET; | ||
| 211 | } | 215 | } |
| 212 | 216 | ||
| 213 | static inline u32 panel_fitter_scaling(u32 source, u32 target) | 217 | static inline u32 panel_fitter_scaling(u32 source, u32 target) |
| @@ -283,6 +287,8 @@ static bool intel_lvds_mode_fixup(struct drm_encoder *encoder, | |||
| 283 | for_each_pipe(pipe) | 287 | for_each_pipe(pipe) |
| 284 | I915_WRITE(BCLRPAT(pipe), 0); | 288 | I915_WRITE(BCLRPAT(pipe), 0); |
| 285 | 289 | ||
| 290 | drm_mode_set_crtcinfo(adjusted_mode, 0); | ||
| 291 | |||
| 286 | switch (intel_lvds->fitting_mode) { | 292 | switch (intel_lvds->fitting_mode) { |
| 287 | case DRM_MODE_SCALE_CENTER: | 293 | case DRM_MODE_SCALE_CENTER: |
| 288 | /* | 294 | /* |
diff --git a/drivers/gpu/drm/i915/intel_panel.c b/drivers/gpu/drm/i915/intel_panel.c index 230a141dbea3..48177ec4720e 100644 --- a/drivers/gpu/drm/i915/intel_panel.c +++ b/drivers/gpu/drm/i915/intel_panel.c | |||
| @@ -47,8 +47,6 @@ intel_fixed_panel_mode(struct drm_display_mode *fixed_mode, | |||
| 47 | adjusted_mode->vtotal = fixed_mode->vtotal; | 47 | adjusted_mode->vtotal = fixed_mode->vtotal; |
| 48 | 48 | ||
| 49 | adjusted_mode->clock = fixed_mode->clock; | 49 | adjusted_mode->clock = fixed_mode->clock; |
| 50 | |||
| 51 | drm_mode_set_crtcinfo(adjusted_mode, 0); | ||
| 52 | } | 50 | } |
| 53 | 51 | ||
| 54 | /* adjusted_mode has been preset to be the panel's fixed mode */ | 52 | /* adjusted_mode has been preset to be the panel's fixed mode */ |
diff --git a/drivers/gpu/drm/nouveau/nouveau_pm.c b/drivers/gpu/drm/nouveau/nouveau_pm.c index 34d591b7d4ef..da3e7c3abab7 100644 --- a/drivers/gpu/drm/nouveau/nouveau_pm.c +++ b/drivers/gpu/drm/nouveau/nouveau_pm.c | |||
| @@ -235,6 +235,7 @@ nouveau_pm_profile_set(struct drm_device *dev, const char *profile) | |||
| 235 | return -EPERM; | 235 | return -EPERM; |
| 236 | 236 | ||
| 237 | strncpy(string, profile, sizeof(string)); | 237 | strncpy(string, profile, sizeof(string)); |
| 238 | string[sizeof(string) - 1] = 0; | ||
| 238 | if ((ptr = strchr(string, '\n'))) | 239 | if ((ptr = strchr(string, '\n'))) |
| 239 | *ptr = '\0'; | 240 | *ptr = '\0'; |
| 240 | 241 | ||
diff --git a/drivers/gpu/drm/nouveau/nv50_sor.c b/drivers/gpu/drm/nouveau/nv50_sor.c index a7844ab6a50c..274640212475 100644 --- a/drivers/gpu/drm/nouveau/nv50_sor.c +++ b/drivers/gpu/drm/nouveau/nv50_sor.c | |||
| @@ -42,7 +42,7 @@ nv50_sor_dp_lane_map(struct drm_device *dev, struct dcb_entry *dcb, u8 lane) | |||
| 42 | struct drm_nouveau_private *dev_priv = dev->dev_private; | 42 | struct drm_nouveau_private *dev_priv = dev->dev_private; |
| 43 | static const u8 nvaf[] = { 24, 16, 8, 0 }; /* thanks, apple.. */ | 43 | static const u8 nvaf[] = { 24, 16, 8, 0 }; /* thanks, apple.. */ |
| 44 | static const u8 nv50[] = { 16, 8, 0, 24 }; | 44 | static const u8 nv50[] = { 16, 8, 0, 24 }; |
| 45 | if (dev_priv->card_type == 0xaf) | 45 | if (dev_priv->chipset == 0xaf) |
| 46 | return nvaf[lane]; | 46 | return nvaf[lane]; |
| 47 | return nv50[lane]; | 47 | return nv50[lane]; |
| 48 | } | 48 | } |
diff --git a/drivers/gpu/drm/radeon/r600.c b/drivers/gpu/drm/radeon/r600.c index de71243b591f..c8187c4b6ae8 100644 --- a/drivers/gpu/drm/radeon/r600.c +++ b/drivers/gpu/drm/radeon/r600.c | |||
| @@ -1135,7 +1135,7 @@ static void r600_vram_gtt_location(struct radeon_device *rdev, struct radeon_mc | |||
| 1135 | } | 1135 | } |
| 1136 | if (rdev->flags & RADEON_IS_AGP) { | 1136 | if (rdev->flags & RADEON_IS_AGP) { |
| 1137 | size_bf = mc->gtt_start; | 1137 | size_bf = mc->gtt_start; |
| 1138 | size_af = 0xFFFFFFFF - mc->gtt_end + 1; | 1138 | size_af = 0xFFFFFFFF - mc->gtt_end; |
| 1139 | if (size_bf > size_af) { | 1139 | if (size_bf > size_af) { |
| 1140 | if (mc->mc_vram_size > size_bf) { | 1140 | if (mc->mc_vram_size > size_bf) { |
| 1141 | dev_warn(rdev->dev, "limiting VRAM\n"); | 1141 | dev_warn(rdev->dev, "limiting VRAM\n"); |
| @@ -1149,7 +1149,7 @@ static void r600_vram_gtt_location(struct radeon_device *rdev, struct radeon_mc | |||
| 1149 | mc->real_vram_size = size_af; | 1149 | mc->real_vram_size = size_af; |
| 1150 | mc->mc_vram_size = size_af; | 1150 | mc->mc_vram_size = size_af; |
| 1151 | } | 1151 | } |
| 1152 | mc->vram_start = mc->gtt_end; | 1152 | mc->vram_start = mc->gtt_end + 1; |
| 1153 | } | 1153 | } |
| 1154 | mc->vram_end = mc->vram_start + mc->mc_vram_size - 1; | 1154 | mc->vram_end = mc->vram_start + mc->mc_vram_size - 1; |
| 1155 | dev_info(rdev->dev, "VRAM: %lluM 0x%08llX - 0x%08llX (%lluM used)\n", | 1155 | dev_info(rdev->dev, "VRAM: %lluM 0x%08llX - 0x%08llX (%lluM used)\n", |
diff --git a/drivers/gpu/drm/radeon/radeon_connectors.c b/drivers/gpu/drm/radeon/radeon_connectors.c index bd05156edbdb..3c2e7a000a2a 100644 --- a/drivers/gpu/drm/radeon/radeon_connectors.c +++ b/drivers/gpu/drm/radeon/radeon_connectors.c | |||
| @@ -970,7 +970,7 @@ radeon_dvi_detect(struct drm_connector *connector, bool force) | |||
| 970 | 970 | ||
| 971 | encoder = obj_to_encoder(obj); | 971 | encoder = obj_to_encoder(obj); |
| 972 | 972 | ||
| 973 | if (encoder->encoder_type != DRM_MODE_ENCODER_DAC || | 973 | if (encoder->encoder_type != DRM_MODE_ENCODER_DAC && |
| 974 | encoder->encoder_type != DRM_MODE_ENCODER_TVDAC) | 974 | encoder->encoder_type != DRM_MODE_ENCODER_TVDAC) |
| 975 | continue; | 975 | continue; |
| 976 | 976 | ||
| @@ -1000,6 +1000,7 @@ radeon_dvi_detect(struct drm_connector *connector, bool force) | |||
| 1000 | * cases the DVI port is actually a virtual KVM port connected to the service | 1000 | * cases the DVI port is actually a virtual KVM port connected to the service |
| 1001 | * processor. | 1001 | * processor. |
| 1002 | */ | 1002 | */ |
| 1003 | out: | ||
| 1003 | if ((!rdev->is_atom_bios) && | 1004 | if ((!rdev->is_atom_bios) && |
| 1004 | (ret == connector_status_disconnected) && | 1005 | (ret == connector_status_disconnected) && |
| 1005 | rdev->mode_info.bios_hardcoded_edid_size) { | 1006 | rdev->mode_info.bios_hardcoded_edid_size) { |
| @@ -1007,7 +1008,6 @@ radeon_dvi_detect(struct drm_connector *connector, bool force) | |||
| 1007 | ret = connector_status_connected; | 1008 | ret = connector_status_connected; |
| 1008 | } | 1009 | } |
| 1009 | 1010 | ||
| 1010 | out: | ||
| 1011 | /* updated in get modes as well since we need to know if it's analog or digital */ | 1011 | /* updated in get modes as well since we need to know if it's analog or digital */ |
| 1012 | radeon_connector_update_scratch_regs(connector, ret); | 1012 | radeon_connector_update_scratch_regs(connector, ret); |
| 1013 | return ret; | 1013 | return ret; |
diff --git a/drivers/gpu/drm/radeon/radeon_irq_kms.c b/drivers/gpu/drm/radeon/radeon_irq_kms.c index 66d5fe1c8174..65060b77c805 100644 --- a/drivers/gpu/drm/radeon/radeon_irq_kms.c +++ b/drivers/gpu/drm/radeon/radeon_irq_kms.c | |||
| @@ -147,6 +147,12 @@ static bool radeon_msi_ok(struct radeon_device *rdev) | |||
| 147 | (rdev->pdev->subsystem_device == 0x01fd)) | 147 | (rdev->pdev->subsystem_device == 0x01fd)) |
| 148 | return true; | 148 | return true; |
| 149 | 149 | ||
| 150 | /* RV515 seems to have MSI issues where it loses | ||
| 151 | * MSI rearms occasionally. This leads to lockups and freezes. | ||
| 152 | * disable it by default. | ||
| 153 | */ | ||
| 154 | if (rdev->family == CHIP_RV515) | ||
| 155 | return false; | ||
| 150 | if (rdev->flags & RADEON_IS_IGP) { | 156 | if (rdev->flags & RADEON_IS_IGP) { |
| 151 | /* APUs work fine with MSIs */ | 157 | /* APUs work fine with MSIs */ |
| 152 | if (rdev->family >= CHIP_PALM) | 158 | if (rdev->family >= CHIP_PALM) |
diff --git a/drivers/gpu/drm/radeon/rv770.c b/drivers/gpu/drm/radeon/rv770.c index c62ae4be3845..cdab1aeaed6e 100644 --- a/drivers/gpu/drm/radeon/rv770.c +++ b/drivers/gpu/drm/radeon/rv770.c | |||
| @@ -969,7 +969,7 @@ void r700_vram_gtt_location(struct radeon_device *rdev, struct radeon_mc *mc) | |||
| 969 | } | 969 | } |
| 970 | if (rdev->flags & RADEON_IS_AGP) { | 970 | if (rdev->flags & RADEON_IS_AGP) { |
| 971 | size_bf = mc->gtt_start; | 971 | size_bf = mc->gtt_start; |
| 972 | size_af = 0xFFFFFFFF - mc->gtt_end + 1; | 972 | size_af = 0xFFFFFFFF - mc->gtt_end; |
| 973 | if (size_bf > size_af) { | 973 | if (size_bf > size_af) { |
| 974 | if (mc->mc_vram_size > size_bf) { | 974 | if (mc->mc_vram_size > size_bf) { |
| 975 | dev_warn(rdev->dev, "limiting VRAM\n"); | 975 | dev_warn(rdev->dev, "limiting VRAM\n"); |
| @@ -983,7 +983,7 @@ void r700_vram_gtt_location(struct radeon_device *rdev, struct radeon_mc *mc) | |||
| 983 | mc->real_vram_size = size_af; | 983 | mc->real_vram_size = size_af; |
| 984 | mc->mc_vram_size = size_af; | 984 | mc->mc_vram_size = size_af; |
| 985 | } | 985 | } |
| 986 | mc->vram_start = mc->gtt_end; | 986 | mc->vram_start = mc->gtt_end + 1; |
| 987 | } | 987 | } |
| 988 | mc->vram_end = mc->vram_start + mc->mc_vram_size - 1; | 988 | mc->vram_end = mc->vram_start + mc->mc_vram_size - 1; |
| 989 | dev_info(rdev->dev, "VRAM: %lluM 0x%08llX - 0x%08llX (%lluM used)\n", | 989 | dev_info(rdev->dev, "VRAM: %lluM 0x%08llX - 0x%08llX (%lluM used)\n", |
diff --git a/drivers/gpu/drm/radeon/si.c b/drivers/gpu/drm/radeon/si.c index ac7a199ffece..27bda986fc2b 100644 --- a/drivers/gpu/drm/radeon/si.c +++ b/drivers/gpu/drm/radeon/si.c | |||
| @@ -2999,8 +2999,8 @@ int si_rlc_init(struct radeon_device *rdev) | |||
| 2999 | } | 2999 | } |
| 3000 | r = radeon_bo_pin(rdev->rlc.save_restore_obj, RADEON_GEM_DOMAIN_VRAM, | 3000 | r = radeon_bo_pin(rdev->rlc.save_restore_obj, RADEON_GEM_DOMAIN_VRAM, |
| 3001 | &rdev->rlc.save_restore_gpu_addr); | 3001 | &rdev->rlc.save_restore_gpu_addr); |
| 3002 | radeon_bo_unreserve(rdev->rlc.save_restore_obj); | ||
| 3002 | if (r) { | 3003 | if (r) { |
| 3003 | radeon_bo_unreserve(rdev->rlc.save_restore_obj); | ||
| 3004 | dev_warn(rdev->dev, "(%d) pin RLC sr bo failed\n", r); | 3004 | dev_warn(rdev->dev, "(%d) pin RLC sr bo failed\n", r); |
| 3005 | si_rlc_fini(rdev); | 3005 | si_rlc_fini(rdev); |
| 3006 | return r; | 3006 | return r; |
| @@ -3023,9 +3023,8 @@ int si_rlc_init(struct radeon_device *rdev) | |||
| 3023 | } | 3023 | } |
| 3024 | r = radeon_bo_pin(rdev->rlc.clear_state_obj, RADEON_GEM_DOMAIN_VRAM, | 3024 | r = radeon_bo_pin(rdev->rlc.clear_state_obj, RADEON_GEM_DOMAIN_VRAM, |
| 3025 | &rdev->rlc.clear_state_gpu_addr); | 3025 | &rdev->rlc.clear_state_gpu_addr); |
| 3026 | radeon_bo_unreserve(rdev->rlc.clear_state_obj); | ||
| 3026 | if (r) { | 3027 | if (r) { |
| 3027 | |||
| 3028 | radeon_bo_unreserve(rdev->rlc.clear_state_obj); | ||
| 3029 | dev_warn(rdev->dev, "(%d) pin RLC c bo failed\n", r); | 3028 | dev_warn(rdev->dev, "(%d) pin RLC c bo failed\n", r); |
| 3030 | si_rlc_fini(rdev); | 3029 | si_rlc_fini(rdev); |
| 3031 | return r; | 3030 | return r; |
diff --git a/drivers/hid/Kconfig b/drivers/hid/Kconfig index a3d033252995..ffddcba32af6 100644 --- a/drivers/hid/Kconfig +++ b/drivers/hid/Kconfig | |||
| @@ -34,7 +34,7 @@ config HID | |||
| 34 | config HID_BATTERY_STRENGTH | 34 | config HID_BATTERY_STRENGTH |
| 35 | bool | 35 | bool |
| 36 | depends on HID && POWER_SUPPLY && HID = POWER_SUPPLY | 36 | depends on HID && POWER_SUPPLY && HID = POWER_SUPPLY |
| 37 | default y | 37 | default n |
| 38 | 38 | ||
| 39 | config HIDRAW | 39 | config HIDRAW |
| 40 | bool "/dev/hidraw raw HID device support" | 40 | bool "/dev/hidraw raw HID device support" |
diff --git a/drivers/hid/hid-tivo.c b/drivers/hid/hid-tivo.c index de47039c708c..9f85f827607f 100644 --- a/drivers/hid/hid-tivo.c +++ b/drivers/hid/hid-tivo.c | |||
| @@ -62,7 +62,7 @@ static int tivo_input_mapping(struct hid_device *hdev, struct hid_input *hi, | |||
| 62 | 62 | ||
| 63 | static const struct hid_device_id tivo_devices[] = { | 63 | static const struct hid_device_id tivo_devices[] = { |
| 64 | /* TiVo Slide Bluetooth remote, pairs with a Broadcom dongle */ | 64 | /* TiVo Slide Bluetooth remote, pairs with a Broadcom dongle */ |
| 65 | { HID_USB_DEVICE(USB_VENDOR_ID_TIVO, USB_DEVICE_ID_TIVO_SLIDE_BT) }, | 65 | { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_TIVO, USB_DEVICE_ID_TIVO_SLIDE_BT) }, |
| 66 | { HID_USB_DEVICE(USB_VENDOR_ID_TIVO, USB_DEVICE_ID_TIVO_SLIDE) }, | 66 | { HID_USB_DEVICE(USB_VENDOR_ID_TIVO, USB_DEVICE_ID_TIVO_SLIDE) }, |
| 67 | { } | 67 | { } |
| 68 | }; | 68 | }; |
diff --git a/drivers/hwmon/acpi_power_meter.c b/drivers/hwmon/acpi_power_meter.c index 145f13580ff0..9140236a0182 100644 --- a/drivers/hwmon/acpi_power_meter.c +++ b/drivers/hwmon/acpi_power_meter.c | |||
| @@ -391,6 +391,7 @@ static ssize_t show_str(struct device *dev, | |||
| 391 | break; | 391 | break; |
| 392 | default: | 392 | default: |
| 393 | BUG(); | 393 | BUG(); |
| 394 | val = ""; | ||
| 394 | } | 395 | } |
| 395 | 396 | ||
| 396 | return sprintf(buf, "%s\n", val); | 397 | return sprintf(buf, "%s\n", val); |
diff --git a/drivers/hwmon/ads1015.c b/drivers/hwmon/ads1015.c index 7765e4f74ec5..1958f03efd7a 100644 --- a/drivers/hwmon/ads1015.c +++ b/drivers/hwmon/ads1015.c | |||
| @@ -59,14 +59,11 @@ struct ads1015_data { | |||
| 59 | struct ads1015_channel_data channel_data[ADS1015_CHANNELS]; | 59 | struct ads1015_channel_data channel_data[ADS1015_CHANNELS]; |
| 60 | }; | 60 | }; |
| 61 | 61 | ||
| 62 | static int ads1015_read_value(struct i2c_client *client, unsigned int channel, | 62 | static int ads1015_read_adc(struct i2c_client *client, unsigned int channel) |
| 63 | int *value) | ||
| 64 | { | 63 | { |
| 65 | u16 config; | 64 | u16 config; |
| 66 | s16 conversion; | ||
| 67 | struct ads1015_data *data = i2c_get_clientdata(client); | 65 | struct ads1015_data *data = i2c_get_clientdata(client); |
| 68 | unsigned int pga = data->channel_data[channel].pga; | 66 | unsigned int pga = data->channel_data[channel].pga; |
| 69 | int fullscale; | ||
| 70 | unsigned int data_rate = data->channel_data[channel].data_rate; | 67 | unsigned int data_rate = data->channel_data[channel].data_rate; |
| 71 | unsigned int conversion_time_ms; | 68 | unsigned int conversion_time_ms; |
| 72 | int res; | 69 | int res; |
| @@ -78,7 +75,6 @@ static int ads1015_read_value(struct i2c_client *client, unsigned int channel, | |||
| 78 | if (res < 0) | 75 | if (res < 0) |
| 79 | goto err_unlock; | 76 | goto err_unlock; |
| 80 | config = res; | 77 | config = res; |
| 81 | fullscale = fullscale_table[pga]; | ||
| 82 | conversion_time_ms = DIV_ROUND_UP(1000, data_rate_table[data_rate]); | 78 | conversion_time_ms = DIV_ROUND_UP(1000, data_rate_table[data_rate]); |
| 83 | 79 | ||
| 84 | /* setup and start single conversion */ | 80 | /* setup and start single conversion */ |
| @@ -105,33 +101,36 @@ static int ads1015_read_value(struct i2c_client *client, unsigned int channel, | |||
| 105 | } | 101 | } |
| 106 | 102 | ||
| 107 | res = i2c_smbus_read_word_swapped(client, ADS1015_CONVERSION); | 103 | res = i2c_smbus_read_word_swapped(client, ADS1015_CONVERSION); |
| 108 | if (res < 0) | ||
| 109 | goto err_unlock; | ||
| 110 | conversion = res; | ||
| 111 | |||
| 112 | mutex_unlock(&data->update_lock); | ||
| 113 | |||
| 114 | *value = DIV_ROUND_CLOSEST(conversion * fullscale, 0x7ff0); | ||
| 115 | |||
| 116 | return 0; | ||
| 117 | 104 | ||
| 118 | err_unlock: | 105 | err_unlock: |
| 119 | mutex_unlock(&data->update_lock); | 106 | mutex_unlock(&data->update_lock); |
| 120 | return res; | 107 | return res; |
| 121 | } | 108 | } |
| 122 | 109 | ||
| 110 | static int ads1015_reg_to_mv(struct i2c_client *client, unsigned int channel, | ||
| 111 | s16 reg) | ||
| 112 | { | ||
| 113 | struct ads1015_data *data = i2c_get_clientdata(client); | ||
| 114 | unsigned int pga = data->channel_data[channel].pga; | ||
| 115 | int fullscale = fullscale_table[pga]; | ||
| 116 | |||
| 117 | return DIV_ROUND_CLOSEST(reg * fullscale, 0x7ff0); | ||
| 118 | } | ||
| 119 | |||
| 123 | /* sysfs callback function */ | 120 | /* sysfs callback function */ |
| 124 | static ssize_t show_in(struct device *dev, struct device_attribute *da, | 121 | static ssize_t show_in(struct device *dev, struct device_attribute *da, |
| 125 | char *buf) | 122 | char *buf) |
| 126 | { | 123 | { |
| 127 | struct sensor_device_attribute *attr = to_sensor_dev_attr(da); | 124 | struct sensor_device_attribute *attr = to_sensor_dev_attr(da); |
| 128 | struct i2c_client *client = to_i2c_client(dev); | 125 | struct i2c_client *client = to_i2c_client(dev); |
| 129 | int in; | ||
| 130 | int res; | 126 | int res; |
| 127 | int index = attr->index; | ||
| 131 | 128 | ||
| 132 | res = ads1015_read_value(client, attr->index, &in); | 129 | res = ads1015_read_adc(client, index); |
| 130 | if (res < 0) | ||
| 131 | return res; | ||
| 133 | 132 | ||
| 134 | return (res < 0) ? res : sprintf(buf, "%d\n", in); | 133 | return sprintf(buf, "%d\n", ads1015_reg_to_mv(client, index, res)); |
| 135 | } | 134 | } |
| 136 | 135 | ||
| 137 | static const struct sensor_device_attribute ads1015_in[] = { | 136 | static const struct sensor_device_attribute ads1015_in[] = { |
diff --git a/drivers/hwmon/fam15h_power.c b/drivers/hwmon/fam15h_power.c index b7494af1e4a9..37a8fc92b44a 100644 --- a/drivers/hwmon/fam15h_power.c +++ b/drivers/hwmon/fam15h_power.c | |||
| @@ -122,6 +122,38 @@ static bool __devinit fam15h_power_is_internal_node0(struct pci_dev *f4) | |||
| 122 | return true; | 122 | return true; |
| 123 | } | 123 | } |
| 124 | 124 | ||
| 125 | /* | ||
| 126 | * Newer BKDG versions have an updated recommendation on how to properly | ||
| 127 | * initialize the running average range (was: 0xE, now: 0x9). This avoids | ||
| 128 | * counter saturations resulting in bogus power readings. | ||
| 129 | * We correct this value ourselves to cope with older BIOSes. | ||
| 130 | */ | ||
| 131 | static void __devinit tweak_runavg_range(struct pci_dev *pdev) | ||
| 132 | { | ||
| 133 | u32 val; | ||
| 134 | const struct pci_device_id affected_device = { | ||
| 135 | PCI_VDEVICE(AMD, PCI_DEVICE_ID_AMD_15H_NB_F4) }; | ||
| 136 | |||
| 137 | /* | ||
| 138 | * let this quirk apply only to the current version of the | ||
| 139 | * northbridge, since future versions may change the behavior | ||
| 140 | */ | ||
| 141 | if (!pci_match_id(&affected_device, pdev)) | ||
| 142 | return; | ||
| 143 | |||
| 144 | pci_bus_read_config_dword(pdev->bus, | ||
| 145 | PCI_DEVFN(PCI_SLOT(pdev->devfn), 5), | ||
| 146 | REG_TDP_RUNNING_AVERAGE, &val); | ||
| 147 | if ((val & 0xf) != 0xe) | ||
| 148 | return; | ||
| 149 | |||
| 150 | val &= ~0xf; | ||
| 151 | val |= 0x9; | ||
| 152 | pci_bus_write_config_dword(pdev->bus, | ||
| 153 | PCI_DEVFN(PCI_SLOT(pdev->devfn), 5), | ||
| 154 | REG_TDP_RUNNING_AVERAGE, val); | ||
| 155 | } | ||
| 156 | |||
| 125 | static void __devinit fam15h_power_init_data(struct pci_dev *f4, | 157 | static void __devinit fam15h_power_init_data(struct pci_dev *f4, |
| 126 | struct fam15h_power_data *data) | 158 | struct fam15h_power_data *data) |
| 127 | { | 159 | { |
| @@ -155,6 +187,13 @@ static int __devinit fam15h_power_probe(struct pci_dev *pdev, | |||
| 155 | struct device *dev; | 187 | struct device *dev; |
| 156 | int err; | 188 | int err; |
| 157 | 189 | ||
| 190 | /* | ||
| 191 | * though we ignore every other northbridge, we still have to | ||
| 192 | * do the tweaking on _each_ node in MCM processors as the counters | ||
| 193 | * are working hand-in-hand | ||
| 194 | */ | ||
| 195 | tweak_runavg_range(pdev); | ||
| 196 | |||
| 158 | if (!fam15h_power_is_internal_node0(pdev)) { | 197 | if (!fam15h_power_is_internal_node0(pdev)) { |
| 159 | err = -ENODEV; | 198 | err = -ENODEV; |
| 160 | goto exit; | 199 | goto exit; |
diff --git a/drivers/hwmon/pmbus/pmbus_core.c b/drivers/hwmon/pmbus/pmbus_core.c index be51037363c8..29b319db573e 100644 --- a/drivers/hwmon/pmbus/pmbus_core.c +++ b/drivers/hwmon/pmbus/pmbus_core.c | |||
| @@ -710,13 +710,13 @@ static u16 pmbus_data2reg(struct pmbus_data *data, | |||
| 710 | * If a negative value is stored in any of the referenced registers, this value | 710 | * If a negative value is stored in any of the referenced registers, this value |
| 711 | * reflects an error code which will be returned. | 711 | * reflects an error code which will be returned. |
| 712 | */ | 712 | */ |
| 713 | static int pmbus_get_boolean(struct pmbus_data *data, int index, int *val) | 713 | static int pmbus_get_boolean(struct pmbus_data *data, int index) |
| 714 | { | 714 | { |
| 715 | u8 s1 = (index >> 24) & 0xff; | 715 | u8 s1 = (index >> 24) & 0xff; |
| 716 | u8 s2 = (index >> 16) & 0xff; | 716 | u8 s2 = (index >> 16) & 0xff; |
| 717 | u8 reg = (index >> 8) & 0xff; | 717 | u8 reg = (index >> 8) & 0xff; |
| 718 | u8 mask = index & 0xff; | 718 | u8 mask = index & 0xff; |
| 719 | int status; | 719 | int ret, status; |
| 720 | u8 regval; | 720 | u8 regval; |
| 721 | 721 | ||
| 722 | status = data->status[reg]; | 722 | status = data->status[reg]; |
| @@ -725,7 +725,7 @@ static int pmbus_get_boolean(struct pmbus_data *data, int index, int *val) | |||
| 725 | 725 | ||
| 726 | regval = status & mask; | 726 | regval = status & mask; |
| 727 | if (!s1 && !s2) | 727 | if (!s1 && !s2) |
| 728 | *val = !!regval; | 728 | ret = !!regval; |
| 729 | else { | 729 | else { |
| 730 | long v1, v2; | 730 | long v1, v2; |
| 731 | struct pmbus_sensor *sensor1, *sensor2; | 731 | struct pmbus_sensor *sensor1, *sensor2; |
| @@ -739,9 +739,9 @@ static int pmbus_get_boolean(struct pmbus_data *data, int index, int *val) | |||
| 739 | 739 | ||
| 740 | v1 = pmbus_reg2data(data, sensor1); | 740 | v1 = pmbus_reg2data(data, sensor1); |
| 741 | v2 = pmbus_reg2data(data, sensor2); | 741 | v2 = pmbus_reg2data(data, sensor2); |
| 742 | *val = !!(regval && v1 >= v2); | 742 | ret = !!(regval && v1 >= v2); |
| 743 | } | 743 | } |
| 744 | return 0; | 744 | return ret; |
| 745 | } | 745 | } |
| 746 | 746 | ||
| 747 | static ssize_t pmbus_show_boolean(struct device *dev, | 747 | static ssize_t pmbus_show_boolean(struct device *dev, |
| @@ -750,11 +750,10 @@ static ssize_t pmbus_show_boolean(struct device *dev, | |||
| 750 | struct sensor_device_attribute *attr = to_sensor_dev_attr(da); | 750 | struct sensor_device_attribute *attr = to_sensor_dev_attr(da); |
| 751 | struct pmbus_data *data = pmbus_update_device(dev); | 751 | struct pmbus_data *data = pmbus_update_device(dev); |
| 752 | int val; | 752 | int val; |
| 753 | int err; | ||
| 754 | 753 | ||
| 755 | err = pmbus_get_boolean(data, attr->index, &val); | 754 | val = pmbus_get_boolean(data, attr->index); |
| 756 | if (err) | 755 | if (val < 0) |
| 757 | return err; | 756 | return val; |
| 758 | return snprintf(buf, PAGE_SIZE, "%d\n", val); | 757 | return snprintf(buf, PAGE_SIZE, "%d\n", val); |
| 759 | } | 758 | } |
| 760 | 759 | ||
diff --git a/drivers/hwmon/smsc47b397.c b/drivers/hwmon/smsc47b397.c index d3b778da3f86..c5f6be478bad 100644 --- a/drivers/hwmon/smsc47b397.c +++ b/drivers/hwmon/smsc47b397.c | |||
| @@ -343,10 +343,11 @@ exit: | |||
| 343 | return err; | 343 | return err; |
| 344 | } | 344 | } |
| 345 | 345 | ||
| 346 | static int __init smsc47b397_find(unsigned short *addr) | 346 | static int __init smsc47b397_find(void) |
| 347 | { | 347 | { |
| 348 | u8 id, rev; | 348 | u8 id, rev; |
| 349 | char *name; | 349 | char *name; |
| 350 | unsigned short addr; | ||
| 350 | 351 | ||
| 351 | superio_enter(); | 352 | superio_enter(); |
| 352 | id = force_id ? force_id : superio_inb(SUPERIO_REG_DEVID); | 353 | id = force_id ? force_id : superio_inb(SUPERIO_REG_DEVID); |
| @@ -370,14 +371,14 @@ static int __init smsc47b397_find(unsigned short *addr) | |||
| 370 | rev = superio_inb(SUPERIO_REG_DEVREV); | 371 | rev = superio_inb(SUPERIO_REG_DEVREV); |
| 371 | 372 | ||
| 372 | superio_select(SUPERIO_REG_LD8); | 373 | superio_select(SUPERIO_REG_LD8); |
| 373 | *addr = (superio_inb(SUPERIO_REG_BASE_MSB) << 8) | 374 | addr = (superio_inb(SUPERIO_REG_BASE_MSB) << 8) |
| 374 | | superio_inb(SUPERIO_REG_BASE_LSB); | 375 | | superio_inb(SUPERIO_REG_BASE_LSB); |
| 375 | 376 | ||
| 376 | pr_info("found SMSC %s (base address 0x%04x, revision %u)\n", | 377 | pr_info("found SMSC %s (base address 0x%04x, revision %u)\n", |
| 377 | name, *addr, rev); | 378 | name, addr, rev); |
| 378 | 379 | ||
| 379 | superio_exit(); | 380 | superio_exit(); |
| 380 | return 0; | 381 | return addr; |
| 381 | } | 382 | } |
| 382 | 383 | ||
| 383 | static int __init smsc47b397_init(void) | 384 | static int __init smsc47b397_init(void) |
| @@ -385,9 +386,10 @@ static int __init smsc47b397_init(void) | |||
| 385 | unsigned short address; | 386 | unsigned short address; |
| 386 | int ret; | 387 | int ret; |
| 387 | 388 | ||
| 388 | ret = smsc47b397_find(&address); | 389 | ret = smsc47b397_find(); |
| 389 | if (ret) | 390 | if (ret < 0) |
| 390 | return ret; | 391 | return ret; |
| 392 | address = ret; | ||
| 391 | 393 | ||
| 392 | ret = platform_driver_register(&smsc47b397_driver); | 394 | ret = platform_driver_register(&smsc47b397_driver); |
| 393 | if (ret) | 395 | if (ret) |
diff --git a/drivers/hwmon/smsc47m1.c b/drivers/hwmon/smsc47m1.c index c590c1469793..b5aa38dd7ab9 100644 --- a/drivers/hwmon/smsc47m1.c +++ b/drivers/hwmon/smsc47m1.c | |||
| @@ -491,10 +491,10 @@ static const struct attribute_group smsc47m1_group = { | |||
| 491 | .attrs = smsc47m1_attributes, | 491 | .attrs = smsc47m1_attributes, |
| 492 | }; | 492 | }; |
| 493 | 493 | ||
| 494 | static int __init smsc47m1_find(unsigned short *addr, | 494 | static int __init smsc47m1_find(struct smsc47m1_sio_data *sio_data) |
| 495 | struct smsc47m1_sio_data *sio_data) | ||
| 496 | { | 495 | { |
| 497 | u8 val; | 496 | u8 val; |
| 497 | unsigned short addr; | ||
| 498 | 498 | ||
| 499 | superio_enter(); | 499 | superio_enter(); |
| 500 | val = force_id ? force_id : superio_inb(SUPERIO_REG_DEVID); | 500 | val = force_id ? force_id : superio_inb(SUPERIO_REG_DEVID); |
| @@ -546,9 +546,9 @@ static int __init smsc47m1_find(unsigned short *addr, | |||
| 546 | } | 546 | } |
| 547 | 547 | ||
| 548 | superio_select(); | 548 | superio_select(); |
| 549 | *addr = (superio_inb(SUPERIO_REG_BASE) << 8) | 549 | addr = (superio_inb(SUPERIO_REG_BASE) << 8) |
| 550 | | superio_inb(SUPERIO_REG_BASE + 1); | 550 | | superio_inb(SUPERIO_REG_BASE + 1); |
| 551 | if (*addr == 0) { | 551 | if (addr == 0) { |
| 552 | pr_info("Device address not set, will not use\n"); | 552 | pr_info("Device address not set, will not use\n"); |
| 553 | superio_exit(); | 553 | superio_exit(); |
| 554 | return -ENODEV; | 554 | return -ENODEV; |
| @@ -565,7 +565,7 @@ static int __init smsc47m1_find(unsigned short *addr, | |||
| 565 | } | 565 | } |
| 566 | 566 | ||
| 567 | superio_exit(); | 567 | superio_exit(); |
| 568 | return 0; | 568 | return addr; |
| 569 | } | 569 | } |
| 570 | 570 | ||
| 571 | /* Restore device to its initial state */ | 571 | /* Restore device to its initial state */ |
| @@ -938,13 +938,15 @@ static int __init sm_smsc47m1_init(void) | |||
| 938 | unsigned short address; | 938 | unsigned short address; |
| 939 | struct smsc47m1_sio_data sio_data; | 939 | struct smsc47m1_sio_data sio_data; |
| 940 | 940 | ||
| 941 | if (smsc47m1_find(&address, &sio_data)) | 941 | err = smsc47m1_find(&sio_data); |
| 942 | return -ENODEV; | 942 | if (err < 0) |
| 943 | return err; | ||
| 944 | address = err; | ||
| 943 | 945 | ||
| 944 | /* Sets global pdev as a side effect */ | 946 | /* Sets global pdev as a side effect */ |
| 945 | err = smsc47m1_device_add(address, &sio_data); | 947 | err = smsc47m1_device_add(address, &sio_data); |
| 946 | if (err) | 948 | if (err) |
| 947 | goto exit; | 949 | return err; |
| 948 | 950 | ||
| 949 | err = platform_driver_probe(&smsc47m1_driver, smsc47m1_probe); | 951 | err = platform_driver_probe(&smsc47m1_driver, smsc47m1_probe); |
| 950 | if (err) | 952 | if (err) |
| @@ -955,7 +957,6 @@ static int __init sm_smsc47m1_init(void) | |||
| 955 | exit_device: | 957 | exit_device: |
| 956 | platform_device_unregister(pdev); | 958 | platform_device_unregister(pdev); |
| 957 | smsc47m1_restore(&sio_data); | 959 | smsc47m1_restore(&sio_data); |
| 958 | exit: | ||
| 959 | return err; | 960 | return err; |
| 960 | } | 961 | } |
| 961 | 962 | ||
diff --git a/drivers/infiniband/ulp/srpt/ib_srpt.c b/drivers/infiniband/ulp/srpt/ib_srpt.c index 69e2ad06e515..daf21b899999 100644 --- a/drivers/infiniband/ulp/srpt/ib_srpt.c +++ b/drivers/infiniband/ulp/srpt/ib_srpt.c | |||
| @@ -3232,6 +3232,7 @@ static void srpt_add_one(struct ib_device *device) | |||
| 3232 | srq_attr.attr.max_wr = sdev->srq_size; | 3232 | srq_attr.attr.max_wr = sdev->srq_size; |
| 3233 | srq_attr.attr.max_sge = 1; | 3233 | srq_attr.attr.max_sge = 1; |
| 3234 | srq_attr.attr.srq_limit = 0; | 3234 | srq_attr.attr.srq_limit = 0; |
| 3235 | srq_attr.srq_type = IB_SRQT_BASIC; | ||
| 3235 | 3236 | ||
| 3236 | sdev->srq = ib_create_srq(sdev->pd, &srq_attr); | 3237 | sdev->srq = ib_create_srq(sdev->pd, &srq_attr); |
| 3237 | if (IS_ERR(sdev->srq)) | 3238 | if (IS_ERR(sdev->srq)) |
diff --git a/drivers/input/misc/Kconfig b/drivers/input/misc/Kconfig index 2d787796bf50..7faf4a7fcaa9 100644 --- a/drivers/input/misc/Kconfig +++ b/drivers/input/misc/Kconfig | |||
| @@ -380,8 +380,7 @@ config INPUT_TWL4030_VIBRA | |||
| 380 | 380 | ||
| 381 | config INPUT_TWL6040_VIBRA | 381 | config INPUT_TWL6040_VIBRA |
| 382 | tristate "Support for TWL6040 Vibrator" | 382 | tristate "Support for TWL6040 Vibrator" |
| 383 | depends on TWL4030_CORE | 383 | depends on TWL6040_CORE |
| 384 | select TWL6040_CORE | ||
| 385 | select INPUT_FF_MEMLESS | 384 | select INPUT_FF_MEMLESS |
| 386 | help | 385 | help |
| 387 | This option enables support for TWL6040 Vibrator Driver. | 386 | This option enables support for TWL6040 Vibrator Driver. |
diff --git a/drivers/input/misc/twl6040-vibra.c b/drivers/input/misc/twl6040-vibra.c index 45874fed523a..14e94f56cb7d 100644 --- a/drivers/input/misc/twl6040-vibra.c +++ b/drivers/input/misc/twl6040-vibra.c | |||
| @@ -28,7 +28,7 @@ | |||
| 28 | #include <linux/module.h> | 28 | #include <linux/module.h> |
| 29 | #include <linux/platform_device.h> | 29 | #include <linux/platform_device.h> |
| 30 | #include <linux/workqueue.h> | 30 | #include <linux/workqueue.h> |
| 31 | #include <linux/i2c/twl.h> | 31 | #include <linux/input.h> |
| 32 | #include <linux/mfd/twl6040.h> | 32 | #include <linux/mfd/twl6040.h> |
| 33 | #include <linux/slab.h> | 33 | #include <linux/slab.h> |
| 34 | #include <linux/delay.h> | 34 | #include <linux/delay.h> |
| @@ -257,7 +257,7 @@ static SIMPLE_DEV_PM_OPS(twl6040_vibra_pm_ops, twl6040_vibra_suspend, NULL); | |||
| 257 | 257 | ||
| 258 | static int __devinit twl6040_vibra_probe(struct platform_device *pdev) | 258 | static int __devinit twl6040_vibra_probe(struct platform_device *pdev) |
| 259 | { | 259 | { |
| 260 | struct twl4030_vibra_data *pdata = pdev->dev.platform_data; | 260 | struct twl6040_vibra_data *pdata = pdev->dev.platform_data; |
| 261 | struct vibra_info *info; | 261 | struct vibra_info *info; |
| 262 | int ret; | 262 | int ret; |
| 263 | 263 | ||
diff --git a/drivers/isdn/gigaset/interface.c b/drivers/isdn/gigaset/interface.c index b3d6ac17272d..a6d9fd2858f7 100644 --- a/drivers/isdn/gigaset/interface.c +++ b/drivers/isdn/gigaset/interface.c | |||
| @@ -176,7 +176,7 @@ static void if_close(struct tty_struct *tty, struct file *filp) | |||
| 176 | struct cardstate *cs = tty->driver_data; | 176 | struct cardstate *cs = tty->driver_data; |
| 177 | 177 | ||
| 178 | if (!cs) { /* happens if we didn't find cs in open */ | 178 | if (!cs) { /* happens if we didn't find cs in open */ |
| 179 | printk(KERN_DEBUG "%s: no cardstate\n", __func__); | 179 | gig_dbg(DEBUG_IF, "%s: no cardstate", __func__); |
| 180 | return; | 180 | return; |
| 181 | } | 181 | } |
| 182 | 182 | ||
diff --git a/drivers/leds/leds-atmel-pwm.c b/drivers/leds/leds-atmel-pwm.c index 800243b6037e..64ad702a2ecc 100644 --- a/drivers/leds/leds-atmel-pwm.c +++ b/drivers/leds/leds-atmel-pwm.c | |||
| @@ -35,7 +35,7 @@ static void pwmled_brightness(struct led_classdev *cdev, enum led_brightness b) | |||
| 35 | * NOTE: we reuse the platform_data structure of GPIO leds, | 35 | * NOTE: we reuse the platform_data structure of GPIO leds, |
| 36 | * but repurpose its "gpio" number as a PWM channel number. | 36 | * but repurpose its "gpio" number as a PWM channel number. |
| 37 | */ | 37 | */ |
| 38 | static int __init pwmled_probe(struct platform_device *pdev) | 38 | static int __devinit pwmled_probe(struct platform_device *pdev) |
| 39 | { | 39 | { |
| 40 | const struct gpio_led_platform_data *pdata; | 40 | const struct gpio_led_platform_data *pdata; |
| 41 | struct pwmled *leds; | 41 | struct pwmled *leds; |
diff --git a/drivers/md/dm-raid.c b/drivers/md/dm-raid.c index b0ba52459ed7..68965e663248 100644 --- a/drivers/md/dm-raid.c +++ b/drivers/md/dm-raid.c | |||
| @@ -859,7 +859,7 @@ static int analyse_superblocks(struct dm_target *ti, struct raid_set *rs) | |||
| 859 | int ret; | 859 | int ret; |
| 860 | unsigned redundancy = 0; | 860 | unsigned redundancy = 0; |
| 861 | struct raid_dev *dev; | 861 | struct raid_dev *dev; |
| 862 | struct md_rdev *rdev, *freshest; | 862 | struct md_rdev *rdev, *tmp, *freshest; |
| 863 | struct mddev *mddev = &rs->md; | 863 | struct mddev *mddev = &rs->md; |
| 864 | 864 | ||
| 865 | switch (rs->raid_type->level) { | 865 | switch (rs->raid_type->level) { |
| @@ -877,7 +877,7 @@ static int analyse_superblocks(struct dm_target *ti, struct raid_set *rs) | |||
| 877 | } | 877 | } |
| 878 | 878 | ||
| 879 | freshest = NULL; | 879 | freshest = NULL; |
| 880 | rdev_for_each(rdev, mddev) { | 880 | rdev_for_each_safe(rdev, tmp, mddev) { |
| 881 | if (!rdev->meta_bdev) | 881 | if (!rdev->meta_bdev) |
| 882 | continue; | 882 | continue; |
| 883 | 883 | ||
diff --git a/drivers/md/md.c b/drivers/md/md.c index b572e1e386ce..477eb2e180c0 100644 --- a/drivers/md/md.c +++ b/drivers/md/md.c | |||
| @@ -7560,14 +7560,14 @@ void md_check_recovery(struct mddev *mddev) | |||
| 7560 | * any transients in the value of "sync_action". | 7560 | * any transients in the value of "sync_action". |
| 7561 | */ | 7561 | */ |
| 7562 | set_bit(MD_RECOVERY_RUNNING, &mddev->recovery); | 7562 | set_bit(MD_RECOVERY_RUNNING, &mddev->recovery); |
| 7563 | clear_bit(MD_RECOVERY_NEEDED, &mddev->recovery); | ||
| 7564 | /* Clear some bits that don't mean anything, but | 7563 | /* Clear some bits that don't mean anything, but |
| 7565 | * might be left set | 7564 | * might be left set |
| 7566 | */ | 7565 | */ |
| 7567 | clear_bit(MD_RECOVERY_INTR, &mddev->recovery); | 7566 | clear_bit(MD_RECOVERY_INTR, &mddev->recovery); |
| 7568 | clear_bit(MD_RECOVERY_DONE, &mddev->recovery); | 7567 | clear_bit(MD_RECOVERY_DONE, &mddev->recovery); |
| 7569 | 7568 | ||
| 7570 | if (test_bit(MD_RECOVERY_FROZEN, &mddev->recovery)) | 7569 | if (!test_and_clear_bit(MD_RECOVERY_NEEDED, &mddev->recovery) || |
| 7570 | test_bit(MD_RECOVERY_FROZEN, &mddev->recovery)) | ||
| 7571 | goto unlock; | 7571 | goto unlock; |
| 7572 | /* no recovery is running. | 7572 | /* no recovery is running. |
| 7573 | * remove any failed drives, then | 7573 | * remove any failed drives, then |
| @@ -8140,7 +8140,8 @@ static int md_notify_reboot(struct notifier_block *this, | |||
| 8140 | 8140 | ||
| 8141 | for_each_mddev(mddev, tmp) { | 8141 | for_each_mddev(mddev, tmp) { |
| 8142 | if (mddev_trylock(mddev)) { | 8142 | if (mddev_trylock(mddev)) { |
| 8143 | __md_stop_writes(mddev); | 8143 | if (mddev->pers) |
| 8144 | __md_stop_writes(mddev); | ||
| 8144 | mddev->safemode = 2; | 8145 | mddev->safemode = 2; |
| 8145 | mddev_unlock(mddev); | 8146 | mddev_unlock(mddev); |
| 8146 | } | 8147 | } |
diff --git a/drivers/media/common/tuners/xc5000.c b/drivers/media/common/tuners/xc5000.c index 7f98984e4fad..eab2ea424200 100644 --- a/drivers/media/common/tuners/xc5000.c +++ b/drivers/media/common/tuners/xc5000.c | |||
| @@ -54,6 +54,7 @@ struct xc5000_priv { | |||
| 54 | struct list_head hybrid_tuner_instance_list; | 54 | struct list_head hybrid_tuner_instance_list; |
| 55 | 55 | ||
| 56 | u32 if_khz; | 56 | u32 if_khz; |
| 57 | u32 xtal_khz; | ||
| 57 | u32 freq_hz; | 58 | u32 freq_hz; |
| 58 | u32 bandwidth; | 59 | u32 bandwidth; |
| 59 | u8 video_standard; | 60 | u8 video_standard; |
| @@ -214,9 +215,9 @@ static const struct xc5000_fw_cfg xc5000a_1_6_114 = { | |||
| 214 | .size = 12401, | 215 | .size = 12401, |
| 215 | }; | 216 | }; |
| 216 | 217 | ||
| 217 | static const struct xc5000_fw_cfg xc5000c_41_024_5_31875 = { | 218 | static const struct xc5000_fw_cfg xc5000c_41_024_5 = { |
| 218 | .name = "dvb-fe-xc5000c-41.024.5-31875.fw", | 219 | .name = "dvb-fe-xc5000c-41.024.5.fw", |
| 219 | .size = 16503, | 220 | .size = 16497, |
| 220 | }; | 221 | }; |
| 221 | 222 | ||
| 222 | static inline const struct xc5000_fw_cfg *xc5000_assign_firmware(int chip_id) | 223 | static inline const struct xc5000_fw_cfg *xc5000_assign_firmware(int chip_id) |
| @@ -226,7 +227,7 @@ static inline const struct xc5000_fw_cfg *xc5000_assign_firmware(int chip_id) | |||
| 226 | case XC5000A: | 227 | case XC5000A: |
| 227 | return &xc5000a_1_6_114; | 228 | return &xc5000a_1_6_114; |
| 228 | case XC5000C: | 229 | case XC5000C: |
| 229 | return &xc5000c_41_024_5_31875; | 230 | return &xc5000c_41_024_5; |
| 230 | } | 231 | } |
| 231 | } | 232 | } |
| 232 | 233 | ||
| @@ -572,6 +573,31 @@ static int xc_tune_channel(struct xc5000_priv *priv, u32 freq_hz, int mode) | |||
| 572 | return found; | 573 | return found; |
| 573 | } | 574 | } |
| 574 | 575 | ||
| 576 | static int xc_set_xtal(struct dvb_frontend *fe) | ||
| 577 | { | ||
| 578 | struct xc5000_priv *priv = fe->tuner_priv; | ||
| 579 | int ret = XC_RESULT_SUCCESS; | ||
| 580 | |||
| 581 | switch (priv->chip_id) { | ||
| 582 | default: | ||
| 583 | case XC5000A: | ||
| 584 | /* 32.000 MHz xtal is default */ | ||
| 585 | break; | ||
| 586 | case XC5000C: | ||
| 587 | switch (priv->xtal_khz) { | ||
| 588 | default: | ||
| 589 | case 32000: | ||
| 590 | /* 32.000 MHz xtal is default */ | ||
| 591 | break; | ||
| 592 | case 31875: | ||
| 593 | /* 31.875 MHz xtal configuration */ | ||
| 594 | ret = xc_write_reg(priv, 0x000f, 0x8081); | ||
| 595 | break; | ||
| 596 | } | ||
| 597 | break; | ||
| 598 | } | ||
| 599 | return ret; | ||
| 600 | } | ||
| 575 | 601 | ||
| 576 | static int xc5000_fwupload(struct dvb_frontend *fe) | 602 | static int xc5000_fwupload(struct dvb_frontend *fe) |
| 577 | { | 603 | { |
| @@ -603,6 +629,8 @@ static int xc5000_fwupload(struct dvb_frontend *fe) | |||
| 603 | } else { | 629 | } else { |
| 604 | printk(KERN_INFO "xc5000: firmware uploading...\n"); | 630 | printk(KERN_INFO "xc5000: firmware uploading...\n"); |
| 605 | ret = xc_load_i2c_sequence(fe, fw->data); | 631 | ret = xc_load_i2c_sequence(fe, fw->data); |
| 632 | if (XC_RESULT_SUCCESS == ret) | ||
| 633 | ret = xc_set_xtal(fe); | ||
| 606 | printk(KERN_INFO "xc5000: firmware upload complete...\n"); | 634 | printk(KERN_INFO "xc5000: firmware upload complete...\n"); |
| 607 | } | 635 | } |
| 608 | 636 | ||
| @@ -1164,6 +1192,9 @@ struct dvb_frontend *xc5000_attach(struct dvb_frontend *fe, | |||
| 1164 | priv->if_khz = cfg->if_khz; | 1192 | priv->if_khz = cfg->if_khz; |
| 1165 | } | 1193 | } |
| 1166 | 1194 | ||
| 1195 | if (priv->xtal_khz == 0) | ||
| 1196 | priv->xtal_khz = cfg->xtal_khz; | ||
| 1197 | |||
| 1167 | if (priv->radio_input == 0) | 1198 | if (priv->radio_input == 0) |
| 1168 | priv->radio_input = cfg->radio_input; | 1199 | priv->radio_input = cfg->radio_input; |
| 1169 | 1200 | ||
diff --git a/drivers/media/common/tuners/xc5000.h b/drivers/media/common/tuners/xc5000.h index 3396f8e02b40..39a73bf01406 100644 --- a/drivers/media/common/tuners/xc5000.h +++ b/drivers/media/common/tuners/xc5000.h | |||
| @@ -34,6 +34,7 @@ struct xc5000_config { | |||
| 34 | u8 i2c_address; | 34 | u8 i2c_address; |
| 35 | u32 if_khz; | 35 | u32 if_khz; |
| 36 | u8 radio_input; | 36 | u8 radio_input; |
| 37 | u32 xtal_khz; | ||
| 37 | 38 | ||
| 38 | int chip_id; | 39 | int chip_id; |
| 39 | }; | 40 | }; |
diff --git a/drivers/media/dvb/dvb-core/dvb_frontend.c b/drivers/media/dvb/dvb-core/dvb_frontend.c index 39696c6a4ed7..0f64d7182657 100644 --- a/drivers/media/dvb/dvb-core/dvb_frontend.c +++ b/drivers/media/dvb/dvb-core/dvb_frontend.c | |||
| @@ -1446,6 +1446,28 @@ static int set_delivery_system(struct dvb_frontend *fe, u32 desired_system) | |||
| 1446 | __func__); | 1446 | __func__); |
| 1447 | return -EINVAL; | 1447 | return -EINVAL; |
| 1448 | } | 1448 | } |
| 1449 | /* | ||
| 1450 | * Get a delivery system that is compatible with DVBv3 | ||
| 1451 | * NOTE: in order for this to work with softwares like Kaffeine that | ||
| 1452 | * uses a DVBv5 call for DVB-S2 and a DVBv3 call to go back to | ||
| 1453 | * DVB-S, drivers that support both should put the SYS_DVBS entry | ||
| 1454 | * before the SYS_DVBS2, otherwise it won't switch back to DVB-S. | ||
| 1455 | * The real fix is that userspace applications should not use DVBv3 | ||
| 1456 | * and not trust on calling FE_SET_FRONTEND to switch the delivery | ||
| 1457 | * system. | ||
| 1458 | */ | ||
| 1459 | ncaps = 0; | ||
| 1460 | while (fe->ops.delsys[ncaps] && ncaps < MAX_DELSYS) { | ||
| 1461 | if (fe->ops.delsys[ncaps] == desired_system) { | ||
| 1462 | delsys = desired_system; | ||
| 1463 | break; | ||
| 1464 | } | ||
| 1465 | ncaps++; | ||
| 1466 | } | ||
| 1467 | if (delsys == SYS_UNDEFINED) { | ||
| 1468 | dprintk("%s() Couldn't find a delivery system that matches %d\n", | ||
| 1469 | __func__, desired_system); | ||
| 1470 | } | ||
| 1449 | } else { | 1471 | } else { |
| 1450 | /* | 1472 | /* |
| 1451 | * This is a DVBv5 call. So, it likely knows the supported | 1473 | * This is a DVBv5 call. So, it likely knows the supported |
| @@ -1494,9 +1516,10 @@ static int set_delivery_system(struct dvb_frontend *fe, u32 desired_system) | |||
| 1494 | __func__); | 1516 | __func__); |
| 1495 | return -EINVAL; | 1517 | return -EINVAL; |
| 1496 | } | 1518 | } |
| 1497 | c->delivery_system = delsys; | ||
| 1498 | } | 1519 | } |
| 1499 | 1520 | ||
| 1521 | c->delivery_system = delsys; | ||
| 1522 | |||
| 1500 | /* | 1523 | /* |
| 1501 | * The DVBv3 or DVBv5 call is requesting a different system. So, | 1524 | * The DVBv3 or DVBv5 call is requesting a different system. So, |
| 1502 | * emulation is needed. | 1525 | * emulation is needed. |
diff --git a/drivers/media/dvb/frontends/drxk_hard.c b/drivers/media/dvb/frontends/drxk_hard.c index 36d11756492f..a414b1f2b6a5 100644 --- a/drivers/media/dvb/frontends/drxk_hard.c +++ b/drivers/media/dvb/frontends/drxk_hard.c | |||
| @@ -1520,8 +1520,10 @@ static int scu_command(struct drxk_state *state, | |||
| 1520 | dprintk(1, "\n"); | 1520 | dprintk(1, "\n"); |
| 1521 | 1521 | ||
| 1522 | if ((cmd == 0) || ((parameterLen > 0) && (parameter == NULL)) || | 1522 | if ((cmd == 0) || ((parameterLen > 0) && (parameter == NULL)) || |
| 1523 | ((resultLen > 0) && (result == NULL))) | 1523 | ((resultLen > 0) && (result == NULL))) { |
| 1524 | goto error; | 1524 | printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__); |
| 1525 | return status; | ||
| 1526 | } | ||
| 1525 | 1527 | ||
| 1526 | mutex_lock(&state->mutex); | 1528 | mutex_lock(&state->mutex); |
| 1527 | 1529 | ||
diff --git a/drivers/media/rc/winbond-cir.c b/drivers/media/rc/winbond-cir.c index b09c5fae489b..af526586fa26 100644 --- a/drivers/media/rc/winbond-cir.c +++ b/drivers/media/rc/winbond-cir.c | |||
| @@ -1046,6 +1046,7 @@ wbcir_probe(struct pnp_dev *device, const struct pnp_device_id *dev_id) | |||
| 1046 | goto exit_unregister_led; | 1046 | goto exit_unregister_led; |
| 1047 | } | 1047 | } |
| 1048 | 1048 | ||
| 1049 | data->dev->driver_type = RC_DRIVER_IR_RAW; | ||
| 1049 | data->dev->driver_name = WBCIR_NAME; | 1050 | data->dev->driver_name = WBCIR_NAME; |
| 1050 | data->dev->input_name = WBCIR_NAME; | 1051 | data->dev->input_name = WBCIR_NAME; |
| 1051 | data->dev->input_phys = "wbcir/cir0"; | 1052 | data->dev->input_phys = "wbcir/cir0"; |
diff --git a/drivers/media/video/Kconfig b/drivers/media/video/Kconfig index f2479c5c0eb2..ce1e7ba940f6 100644 --- a/drivers/media/video/Kconfig +++ b/drivers/media/video/Kconfig | |||
| @@ -492,7 +492,7 @@ config VIDEO_VS6624 | |||
| 492 | 492 | ||
| 493 | config VIDEO_MT9M032 | 493 | config VIDEO_MT9M032 |
| 494 | tristate "MT9M032 camera sensor support" | 494 | tristate "MT9M032 camera sensor support" |
| 495 | depends on I2C && VIDEO_V4L2 | 495 | depends on I2C && VIDEO_V4L2 && VIDEO_V4L2_SUBDEV_API |
| 496 | select VIDEO_APTINA_PLL | 496 | select VIDEO_APTINA_PLL |
| 497 | ---help--- | 497 | ---help--- |
| 498 | This driver supports MT9M032 camera sensors from Aptina, monochrome | 498 | This driver supports MT9M032 camera sensors from Aptina, monochrome |
diff --git a/drivers/media/video/mt9m032.c b/drivers/media/video/mt9m032.c index 7636672c3548..645973c5feb0 100644 --- a/drivers/media/video/mt9m032.c +++ b/drivers/media/video/mt9m032.c | |||
| @@ -392,10 +392,11 @@ static int mt9m032_set_pad_format(struct v4l2_subdev *subdev, | |||
| 392 | } | 392 | } |
| 393 | 393 | ||
| 394 | /* Scaling is not supported, the format is thus fixed. */ | 394 | /* Scaling is not supported, the format is thus fixed. */ |
| 395 | ret = mt9m032_get_pad_format(subdev, fh, fmt); | 395 | fmt->format = *__mt9m032_get_pad_format(sensor, fh, fmt->which); |
| 396 | ret = 0; | ||
| 396 | 397 | ||
| 397 | done: | 398 | done: |
| 398 | mutex_lock(&sensor->lock); | 399 | mutex_unlock(&sensor->lock); |
| 399 | return ret; | 400 | return ret; |
| 400 | } | 401 | } |
| 401 | 402 | ||
diff --git a/drivers/mfd/Kconfig b/drivers/mfd/Kconfig index 29f463cc09cb..11e44386fa9b 100644 --- a/drivers/mfd/Kconfig +++ b/drivers/mfd/Kconfig | |||
| @@ -268,10 +268,17 @@ config TWL6030_PWM | |||
| 268 | This is used to control charging LED brightness. | 268 | This is used to control charging LED brightness. |
| 269 | 269 | ||
| 270 | config TWL6040_CORE | 270 | config TWL6040_CORE |
| 271 | bool | 271 | bool "Support for TWL6040 audio codec" |
| 272 | depends on TWL4030_CORE && GENERIC_HARDIRQS | 272 | depends on I2C=y && GENERIC_HARDIRQS |
| 273 | select MFD_CORE | 273 | select MFD_CORE |
| 274 | select REGMAP_I2C | ||
| 274 | default n | 275 | default n |
| 276 | help | ||
| 277 | Say yes here if you want support for Texas Instruments TWL6040 audio | ||
| 278 | codec. | ||
| 279 | This driver provides common support for accessing the device, | ||
| 280 | additional drivers must be enabled in order to use the | ||
| 281 | functionality of the device (audio, vibra). | ||
| 275 | 282 | ||
| 276 | config MFD_STMPE | 283 | config MFD_STMPE |
| 277 | bool "Support STMicroelectronics STMPE" | 284 | bool "Support STMicroelectronics STMPE" |
diff --git a/drivers/mfd/asic3.c b/drivers/mfd/asic3.c index 1895cf9fab8c..1582c3d95257 100644 --- a/drivers/mfd/asic3.c +++ b/drivers/mfd/asic3.c | |||
| @@ -527,7 +527,9 @@ static void asic3_gpio_set(struct gpio_chip *chip, | |||
| 527 | 527 | ||
| 528 | static int asic3_gpio_to_irq(struct gpio_chip *chip, unsigned offset) | 528 | static int asic3_gpio_to_irq(struct gpio_chip *chip, unsigned offset) |
| 529 | { | 529 | { |
| 530 | return (offset < ASIC3_NUM_GPIOS) ? IRQ_BOARD_START + offset : -ENXIO; | 530 | struct asic3 *asic = container_of(chip, struct asic3, gpio); |
| 531 | |||
| 532 | return (offset < ASIC3_NUM_GPIOS) ? asic->irq_base + offset : -ENXIO; | ||
| 531 | } | 533 | } |
| 532 | 534 | ||
| 533 | static __init int asic3_gpio_probe(struct platform_device *pdev, | 535 | static __init int asic3_gpio_probe(struct platform_device *pdev, |
diff --git a/drivers/mfd/db8500-prcmu.c b/drivers/mfd/db8500-prcmu.c index ebc1e8658226..5be32489714f 100644 --- a/drivers/mfd/db8500-prcmu.c +++ b/drivers/mfd/db8500-prcmu.c | |||
| @@ -2788,6 +2788,7 @@ static struct regulator_init_data db8500_regulators[DB8500_NUM_REGULATORS] = { | |||
| 2788 | .constraints = { | 2788 | .constraints = { |
| 2789 | .name = "db8500-vape", | 2789 | .name = "db8500-vape", |
| 2790 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | 2790 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, |
| 2791 | .always_on = true, | ||
| 2791 | }, | 2792 | }, |
| 2792 | .consumer_supplies = db8500_vape_consumers, | 2793 | .consumer_supplies = db8500_vape_consumers, |
| 2793 | .num_consumer_supplies = ARRAY_SIZE(db8500_vape_consumers), | 2794 | .num_consumer_supplies = ARRAY_SIZE(db8500_vape_consumers), |
diff --git a/drivers/mfd/omap-usb-host.c b/drivers/mfd/omap-usb-host.c index 95a2e546a489..c8aae6640e64 100644 --- a/drivers/mfd/omap-usb-host.c +++ b/drivers/mfd/omap-usb-host.c | |||
| @@ -25,7 +25,6 @@ | |||
| 25 | #include <linux/clk.h> | 25 | #include <linux/clk.h> |
| 26 | #include <linux/dma-mapping.h> | 26 | #include <linux/dma-mapping.h> |
| 27 | #include <linux/spinlock.h> | 27 | #include <linux/spinlock.h> |
| 28 | #include <linux/gpio.h> | ||
| 29 | #include <plat/usb.h> | 28 | #include <plat/usb.h> |
| 30 | #include <linux/pm_runtime.h> | 29 | #include <linux/pm_runtime.h> |
| 31 | 30 | ||
| @@ -502,19 +501,6 @@ static void omap_usbhs_init(struct device *dev) | |||
| 502 | pm_runtime_get_sync(dev); | 501 | pm_runtime_get_sync(dev); |
| 503 | spin_lock_irqsave(&omap->lock, flags); | 502 | spin_lock_irqsave(&omap->lock, flags); |
| 504 | 503 | ||
| 505 | if (pdata->ehci_data->phy_reset) { | ||
| 506 | if (gpio_is_valid(pdata->ehci_data->reset_gpio_port[0])) | ||
| 507 | gpio_request_one(pdata->ehci_data->reset_gpio_port[0], | ||
| 508 | GPIOF_OUT_INIT_LOW, "USB1 PHY reset"); | ||
| 509 | |||
| 510 | if (gpio_is_valid(pdata->ehci_data->reset_gpio_port[1])) | ||
| 511 | gpio_request_one(pdata->ehci_data->reset_gpio_port[1], | ||
| 512 | GPIOF_OUT_INIT_LOW, "USB2 PHY reset"); | ||
| 513 | |||
| 514 | /* Hold the PHY in RESET for enough time till DIR is high */ | ||
| 515 | udelay(10); | ||
| 516 | } | ||
| 517 | |||
| 518 | omap->usbhs_rev = usbhs_read(omap->uhh_base, OMAP_UHH_REVISION); | 504 | omap->usbhs_rev = usbhs_read(omap->uhh_base, OMAP_UHH_REVISION); |
| 519 | dev_dbg(dev, "OMAP UHH_REVISION 0x%x\n", omap->usbhs_rev); | 505 | dev_dbg(dev, "OMAP UHH_REVISION 0x%x\n", omap->usbhs_rev); |
| 520 | 506 | ||
| @@ -593,39 +579,10 @@ static void omap_usbhs_init(struct device *dev) | |||
| 593 | usbhs_omap_tll_init(dev, OMAP_TLL_CHANNEL_COUNT); | 579 | usbhs_omap_tll_init(dev, OMAP_TLL_CHANNEL_COUNT); |
| 594 | } | 580 | } |
| 595 | 581 | ||
| 596 | if (pdata->ehci_data->phy_reset) { | ||
| 597 | /* Hold the PHY in RESET for enough time till | ||
| 598 | * PHY is settled and ready | ||
| 599 | */ | ||
| 600 | udelay(10); | ||
| 601 | |||
| 602 | if (gpio_is_valid(pdata->ehci_data->reset_gpio_port[0])) | ||
| 603 | gpio_set_value | ||
| 604 | (pdata->ehci_data->reset_gpio_port[0], 1); | ||
| 605 | |||
| 606 | if (gpio_is_valid(pdata->ehci_data->reset_gpio_port[1])) | ||
| 607 | gpio_set_value | ||
| 608 | (pdata->ehci_data->reset_gpio_port[1], 1); | ||
| 609 | } | ||
| 610 | |||
| 611 | spin_unlock_irqrestore(&omap->lock, flags); | 582 | spin_unlock_irqrestore(&omap->lock, flags); |
| 612 | pm_runtime_put_sync(dev); | 583 | pm_runtime_put_sync(dev); |
| 613 | } | 584 | } |
| 614 | 585 | ||
| 615 | static void omap_usbhs_deinit(struct device *dev) | ||
| 616 | { | ||
| 617 | struct usbhs_hcd_omap *omap = dev_get_drvdata(dev); | ||
| 618 | struct usbhs_omap_platform_data *pdata = &omap->platdata; | ||
| 619 | |||
| 620 | if (pdata->ehci_data->phy_reset) { | ||
| 621 | if (gpio_is_valid(pdata->ehci_data->reset_gpio_port[0])) | ||
| 622 | gpio_free(pdata->ehci_data->reset_gpio_port[0]); | ||
| 623 | |||
| 624 | if (gpio_is_valid(pdata->ehci_data->reset_gpio_port[1])) | ||
| 625 | gpio_free(pdata->ehci_data->reset_gpio_port[1]); | ||
| 626 | } | ||
| 627 | } | ||
| 628 | |||
| 629 | 586 | ||
| 630 | /** | 587 | /** |
| 631 | * usbhs_omap_probe - initialize TI-based HCDs | 588 | * usbhs_omap_probe - initialize TI-based HCDs |
| @@ -860,7 +817,6 @@ static int __devexit usbhs_omap_remove(struct platform_device *pdev) | |||
| 860 | { | 817 | { |
| 861 | struct usbhs_hcd_omap *omap = platform_get_drvdata(pdev); | 818 | struct usbhs_hcd_omap *omap = platform_get_drvdata(pdev); |
| 862 | 819 | ||
| 863 | omap_usbhs_deinit(&pdev->dev); | ||
| 864 | iounmap(omap->tll_base); | 820 | iounmap(omap->tll_base); |
| 865 | iounmap(omap->uhh_base); | 821 | iounmap(omap->uhh_base); |
| 866 | clk_put(omap->init_60m_fclk); | 822 | clk_put(omap->init_60m_fclk); |
diff --git a/drivers/mfd/rc5t583.c b/drivers/mfd/rc5t583.c index 99ef944c621d..44afae0a69ce 100644 --- a/drivers/mfd/rc5t583.c +++ b/drivers/mfd/rc5t583.c | |||
| @@ -80,44 +80,6 @@ static struct mfd_cell rc5t583_subdevs[] = { | |||
| 80 | {.name = "rc5t583-key", } | 80 | {.name = "rc5t583-key", } |
| 81 | }; | 81 | }; |
| 82 | 82 | ||
| 83 | int rc5t583_write(struct device *dev, uint8_t reg, uint8_t val) | ||
| 84 | { | ||
| 85 | struct rc5t583 *rc5t583 = dev_get_drvdata(dev); | ||
| 86 | return regmap_write(rc5t583->regmap, reg, val); | ||
| 87 | } | ||
| 88 | |||
| 89 | int rc5t583_read(struct device *dev, uint8_t reg, uint8_t *val) | ||
| 90 | { | ||
| 91 | struct rc5t583 *rc5t583 = dev_get_drvdata(dev); | ||
| 92 | unsigned int ival; | ||
| 93 | int ret; | ||
| 94 | ret = regmap_read(rc5t583->regmap, reg, &ival); | ||
| 95 | if (!ret) | ||
| 96 | *val = (uint8_t)ival; | ||
| 97 | return ret; | ||
| 98 | } | ||
| 99 | |||
| 100 | int rc5t583_set_bits(struct device *dev, unsigned int reg, | ||
| 101 | unsigned int bit_mask) | ||
| 102 | { | ||
| 103 | struct rc5t583 *rc5t583 = dev_get_drvdata(dev); | ||
| 104 | return regmap_update_bits(rc5t583->regmap, reg, bit_mask, bit_mask); | ||
| 105 | } | ||
| 106 | |||
| 107 | int rc5t583_clear_bits(struct device *dev, unsigned int reg, | ||
| 108 | unsigned int bit_mask) | ||
| 109 | { | ||
| 110 | struct rc5t583 *rc5t583 = dev_get_drvdata(dev); | ||
| 111 | return regmap_update_bits(rc5t583->regmap, reg, bit_mask, 0); | ||
| 112 | } | ||
| 113 | |||
| 114 | int rc5t583_update(struct device *dev, unsigned int reg, | ||
| 115 | unsigned int val, unsigned int mask) | ||
| 116 | { | ||
| 117 | struct rc5t583 *rc5t583 = dev_get_drvdata(dev); | ||
| 118 | return regmap_update_bits(rc5t583->regmap, reg, mask, val); | ||
| 119 | } | ||
| 120 | |||
| 121 | static int __rc5t583_set_ext_pwrreq1_control(struct device *dev, | 83 | static int __rc5t583_set_ext_pwrreq1_control(struct device *dev, |
| 122 | int id, int ext_pwr, int slots) | 84 | int id, int ext_pwr, int slots) |
| 123 | { | 85 | { |
| @@ -197,6 +159,7 @@ int rc5t583_ext_power_req_config(struct device *dev, int ds_id, | |||
| 197 | ds_id, ext_pwr_req); | 159 | ds_id, ext_pwr_req); |
| 198 | return 0; | 160 | return 0; |
| 199 | } | 161 | } |
| 162 | EXPORT_SYMBOL(rc5t583_ext_power_req_config); | ||
| 200 | 163 | ||
| 201 | static int rc5t583_clear_ext_power_req(struct rc5t583 *rc5t583, | 164 | static int rc5t583_clear_ext_power_req(struct rc5t583 *rc5t583, |
| 202 | struct rc5t583_platform_data *pdata) | 165 | struct rc5t583_platform_data *pdata) |
diff --git a/drivers/mfd/twl6040-core.c b/drivers/mfd/twl6040-core.c index b2d8e512d3cb..2d6bedadca09 100644 --- a/drivers/mfd/twl6040-core.c +++ b/drivers/mfd/twl6040-core.c | |||
| @@ -30,7 +30,9 @@ | |||
| 30 | #include <linux/platform_device.h> | 30 | #include <linux/platform_device.h> |
| 31 | #include <linux/gpio.h> | 31 | #include <linux/gpio.h> |
| 32 | #include <linux/delay.h> | 32 | #include <linux/delay.h> |
| 33 | #include <linux/i2c/twl.h> | 33 | #include <linux/i2c.h> |
| 34 | #include <linux/regmap.h> | ||
| 35 | #include <linux/err.h> | ||
| 34 | #include <linux/mfd/core.h> | 36 | #include <linux/mfd/core.h> |
| 35 | #include <linux/mfd/twl6040.h> | 37 | #include <linux/mfd/twl6040.h> |
| 36 | 38 | ||
| @@ -39,7 +41,7 @@ | |||
| 39 | int twl6040_reg_read(struct twl6040 *twl6040, unsigned int reg) | 41 | int twl6040_reg_read(struct twl6040 *twl6040, unsigned int reg) |
| 40 | { | 42 | { |
| 41 | int ret; | 43 | int ret; |
| 42 | u8 val = 0; | 44 | unsigned int val; |
| 43 | 45 | ||
| 44 | mutex_lock(&twl6040->io_mutex); | 46 | mutex_lock(&twl6040->io_mutex); |
| 45 | /* Vibra control registers from cache */ | 47 | /* Vibra control registers from cache */ |
| @@ -47,7 +49,7 @@ int twl6040_reg_read(struct twl6040 *twl6040, unsigned int reg) | |||
| 47 | reg == TWL6040_REG_VIBCTLR)) { | 49 | reg == TWL6040_REG_VIBCTLR)) { |
| 48 | val = twl6040->vibra_ctrl_cache[VIBRACTRL_MEMBER(reg)]; | 50 | val = twl6040->vibra_ctrl_cache[VIBRACTRL_MEMBER(reg)]; |
| 49 | } else { | 51 | } else { |
| 50 | ret = twl_i2c_read_u8(TWL_MODULE_AUDIO_VOICE, &val, reg); | 52 | ret = regmap_read(twl6040->regmap, reg, &val); |
| 51 | if (ret < 0) { | 53 | if (ret < 0) { |
| 52 | mutex_unlock(&twl6040->io_mutex); | 54 | mutex_unlock(&twl6040->io_mutex); |
| 53 | return ret; | 55 | return ret; |
| @@ -64,7 +66,7 @@ int twl6040_reg_write(struct twl6040 *twl6040, unsigned int reg, u8 val) | |||
| 64 | int ret; | 66 | int ret; |
| 65 | 67 | ||
| 66 | mutex_lock(&twl6040->io_mutex); | 68 | mutex_lock(&twl6040->io_mutex); |
| 67 | ret = twl_i2c_write_u8(TWL_MODULE_AUDIO_VOICE, val, reg); | 69 | ret = regmap_write(twl6040->regmap, reg, val); |
| 68 | /* Cache the vibra control registers */ | 70 | /* Cache the vibra control registers */ |
| 69 | if (reg == TWL6040_REG_VIBCTLL || reg == TWL6040_REG_VIBCTLR) | 71 | if (reg == TWL6040_REG_VIBCTLL || reg == TWL6040_REG_VIBCTLR) |
| 70 | twl6040->vibra_ctrl_cache[VIBRACTRL_MEMBER(reg)] = val; | 72 | twl6040->vibra_ctrl_cache[VIBRACTRL_MEMBER(reg)] = val; |
| @@ -77,16 +79,9 @@ EXPORT_SYMBOL(twl6040_reg_write); | |||
| 77 | int twl6040_set_bits(struct twl6040 *twl6040, unsigned int reg, u8 mask) | 79 | int twl6040_set_bits(struct twl6040 *twl6040, unsigned int reg, u8 mask) |
| 78 | { | 80 | { |
| 79 | int ret; | 81 | int ret; |
| 80 | u8 val; | ||
| 81 | 82 | ||
| 82 | mutex_lock(&twl6040->io_mutex); | 83 | mutex_lock(&twl6040->io_mutex); |
| 83 | ret = twl_i2c_read_u8(TWL_MODULE_AUDIO_VOICE, &val, reg); | 84 | ret = regmap_update_bits(twl6040->regmap, reg, mask, mask); |
| 84 | if (ret) | ||
| 85 | goto out; | ||
| 86 | |||
| 87 | val |= mask; | ||
| 88 | ret = twl_i2c_write_u8(TWL_MODULE_AUDIO_VOICE, val, reg); | ||
| 89 | out: | ||
| 90 | mutex_unlock(&twl6040->io_mutex); | 85 | mutex_unlock(&twl6040->io_mutex); |
| 91 | return ret; | 86 | return ret; |
| 92 | } | 87 | } |
| @@ -95,16 +90,9 @@ EXPORT_SYMBOL(twl6040_set_bits); | |||
| 95 | int twl6040_clear_bits(struct twl6040 *twl6040, unsigned int reg, u8 mask) | 90 | int twl6040_clear_bits(struct twl6040 *twl6040, unsigned int reg, u8 mask) |
| 96 | { | 91 | { |
| 97 | int ret; | 92 | int ret; |
| 98 | u8 val; | ||
| 99 | 93 | ||
| 100 | mutex_lock(&twl6040->io_mutex); | 94 | mutex_lock(&twl6040->io_mutex); |
| 101 | ret = twl_i2c_read_u8(TWL_MODULE_AUDIO_VOICE, &val, reg); | 95 | ret = regmap_update_bits(twl6040->regmap, reg, mask, 0); |
| 102 | if (ret) | ||
| 103 | goto out; | ||
| 104 | |||
| 105 | val &= ~mask; | ||
| 106 | ret = twl_i2c_write_u8(TWL_MODULE_AUDIO_VOICE, val, reg); | ||
| 107 | out: | ||
| 108 | mutex_unlock(&twl6040->io_mutex); | 96 | mutex_unlock(&twl6040->io_mutex); |
| 109 | return ret; | 97 | return ret; |
| 110 | } | 98 | } |
| @@ -494,32 +482,58 @@ static struct resource twl6040_codec_rsrc[] = { | |||
| 494 | }, | 482 | }, |
| 495 | }; | 483 | }; |
| 496 | 484 | ||
| 497 | static int __devinit twl6040_probe(struct platform_device *pdev) | 485 | static bool twl6040_readable_reg(struct device *dev, unsigned int reg) |
| 498 | { | 486 | { |
| 499 | struct twl4030_audio_data *pdata = pdev->dev.platform_data; | 487 | /* Register 0 is not readable */ |
| 488 | if (!reg) | ||
| 489 | return false; | ||
| 490 | return true; | ||
| 491 | } | ||
| 492 | |||
| 493 | static struct regmap_config twl6040_regmap_config = { | ||
| 494 | .reg_bits = 8, | ||
| 495 | .val_bits = 8, | ||
| 496 | .max_register = TWL6040_REG_STATUS, /* 0x2e */ | ||
| 497 | |||
| 498 | .readable_reg = twl6040_readable_reg, | ||
| 499 | }; | ||
| 500 | |||
| 501 | static int __devinit twl6040_probe(struct i2c_client *client, | ||
| 502 | const struct i2c_device_id *id) | ||
| 503 | { | ||
| 504 | struct twl6040_platform_data *pdata = client->dev.platform_data; | ||
| 500 | struct twl6040 *twl6040; | 505 | struct twl6040 *twl6040; |
| 501 | struct mfd_cell *cell = NULL; | 506 | struct mfd_cell *cell = NULL; |
| 502 | int ret, children = 0; | 507 | int ret, children = 0; |
| 503 | 508 | ||
| 504 | if (!pdata) { | 509 | if (!pdata) { |
| 505 | dev_err(&pdev->dev, "Platform data is missing\n"); | 510 | dev_err(&client->dev, "Platform data is missing\n"); |
| 506 | return -EINVAL; | 511 | return -EINVAL; |
| 507 | } | 512 | } |
| 508 | 513 | ||
| 509 | /* In order to operate correctly we need valid interrupt config */ | 514 | /* In order to operate correctly we need valid interrupt config */ |
| 510 | if (!pdata->naudint_irq || !pdata->irq_base) { | 515 | if (!client->irq || !pdata->irq_base) { |
| 511 | dev_err(&pdev->dev, "Invalid IRQ configuration\n"); | 516 | dev_err(&client->dev, "Invalid IRQ configuration\n"); |
| 512 | return -EINVAL; | 517 | return -EINVAL; |
| 513 | } | 518 | } |
| 514 | 519 | ||
| 515 | twl6040 = kzalloc(sizeof(struct twl6040), GFP_KERNEL); | 520 | twl6040 = devm_kzalloc(&client->dev, sizeof(struct twl6040), |
| 516 | if (!twl6040) | 521 | GFP_KERNEL); |
| 517 | return -ENOMEM; | 522 | if (!twl6040) { |
| 523 | ret = -ENOMEM; | ||
| 524 | goto err; | ||
| 525 | } | ||
| 526 | |||
| 527 | twl6040->regmap = regmap_init_i2c(client, &twl6040_regmap_config); | ||
| 528 | if (IS_ERR(twl6040->regmap)) { | ||
| 529 | ret = PTR_ERR(twl6040->regmap); | ||
| 530 | goto err; | ||
| 531 | } | ||
| 518 | 532 | ||
| 519 | platform_set_drvdata(pdev, twl6040); | 533 | i2c_set_clientdata(client, twl6040); |
| 520 | 534 | ||
| 521 | twl6040->dev = &pdev->dev; | 535 | twl6040->dev = &client->dev; |
| 522 | twl6040->irq = pdata->naudint_irq; | 536 | twl6040->irq = client->irq; |
| 523 | twl6040->irq_base = pdata->irq_base; | 537 | twl6040->irq_base = pdata->irq_base; |
| 524 | 538 | ||
| 525 | mutex_init(&twl6040->mutex); | 539 | mutex_init(&twl6040->mutex); |
| @@ -588,12 +602,12 @@ static int __devinit twl6040_probe(struct platform_device *pdev) | |||
| 588 | } | 602 | } |
| 589 | 603 | ||
| 590 | if (children) { | 604 | if (children) { |
| 591 | ret = mfd_add_devices(&pdev->dev, pdev->id, twl6040->cells, | 605 | ret = mfd_add_devices(&client->dev, -1, twl6040->cells, |
| 592 | children, NULL, 0); | 606 | children, NULL, 0); |
| 593 | if (ret) | 607 | if (ret) |
| 594 | goto mfd_err; | 608 | goto mfd_err; |
| 595 | } else { | 609 | } else { |
| 596 | dev_err(&pdev->dev, "No platform data found for children\n"); | 610 | dev_err(&client->dev, "No platform data found for children\n"); |
| 597 | ret = -ENODEV; | 611 | ret = -ENODEV; |
| 598 | goto mfd_err; | 612 | goto mfd_err; |
| 599 | } | 613 | } |
| @@ -608,14 +622,15 @@ gpio2_err: | |||
| 608 | if (gpio_is_valid(twl6040->audpwron)) | 622 | if (gpio_is_valid(twl6040->audpwron)) |
| 609 | gpio_free(twl6040->audpwron); | 623 | gpio_free(twl6040->audpwron); |
| 610 | gpio1_err: | 624 | gpio1_err: |
| 611 | platform_set_drvdata(pdev, NULL); | 625 | i2c_set_clientdata(client, NULL); |
| 612 | kfree(twl6040); | 626 | regmap_exit(twl6040->regmap); |
| 627 | err: | ||
| 613 | return ret; | 628 | return ret; |
| 614 | } | 629 | } |
| 615 | 630 | ||
| 616 | static int __devexit twl6040_remove(struct platform_device *pdev) | 631 | static int __devexit twl6040_remove(struct i2c_client *client) |
| 617 | { | 632 | { |
| 618 | struct twl6040 *twl6040 = platform_get_drvdata(pdev); | 633 | struct twl6040 *twl6040 = i2c_get_clientdata(client); |
| 619 | 634 | ||
| 620 | if (twl6040->power_count) | 635 | if (twl6040->power_count) |
| 621 | twl6040_power(twl6040, 0); | 636 | twl6040_power(twl6040, 0); |
| @@ -626,23 +641,30 @@ static int __devexit twl6040_remove(struct platform_device *pdev) | |||
| 626 | free_irq(twl6040->irq_base + TWL6040_IRQ_READY, twl6040); | 641 | free_irq(twl6040->irq_base + TWL6040_IRQ_READY, twl6040); |
| 627 | twl6040_irq_exit(twl6040); | 642 | twl6040_irq_exit(twl6040); |
| 628 | 643 | ||
| 629 | mfd_remove_devices(&pdev->dev); | 644 | mfd_remove_devices(&client->dev); |
| 630 | platform_set_drvdata(pdev, NULL); | 645 | i2c_set_clientdata(client, NULL); |
| 631 | kfree(twl6040); | 646 | regmap_exit(twl6040->regmap); |
| 632 | 647 | ||
| 633 | return 0; | 648 | return 0; |
| 634 | } | 649 | } |
| 635 | 650 | ||
| 636 | static struct platform_driver twl6040_driver = { | 651 | static const struct i2c_device_id twl6040_i2c_id[] = { |
| 652 | { "twl6040", 0, }, | ||
| 653 | { }, | ||
| 654 | }; | ||
| 655 | MODULE_DEVICE_TABLE(i2c, twl6040_i2c_id); | ||
| 656 | |||
| 657 | static struct i2c_driver twl6040_driver = { | ||
| 658 | .driver = { | ||
| 659 | .name = "twl6040", | ||
| 660 | .owner = THIS_MODULE, | ||
| 661 | }, | ||
| 637 | .probe = twl6040_probe, | 662 | .probe = twl6040_probe, |
| 638 | .remove = __devexit_p(twl6040_remove), | 663 | .remove = __devexit_p(twl6040_remove), |
| 639 | .driver = { | 664 | .id_table = twl6040_i2c_id, |
| 640 | .owner = THIS_MODULE, | ||
| 641 | .name = "twl6040", | ||
| 642 | }, | ||
| 643 | }; | 665 | }; |
| 644 | 666 | ||
| 645 | module_platform_driver(twl6040_driver); | 667 | module_i2c_driver(twl6040_driver); |
| 646 | 668 | ||
| 647 | MODULE_DESCRIPTION("TWL6040 MFD"); | 669 | MODULE_DESCRIPTION("TWL6040 MFD"); |
| 648 | MODULE_AUTHOR("Misael Lopez Cruz <misael.lopez@ti.com>"); | 670 | MODULE_AUTHOR("Misael Lopez Cruz <misael.lopez@ti.com>"); |
diff --git a/drivers/mmc/card/block.c b/drivers/mmc/card/block.c index b1809650b7aa..dabec556ebb8 100644 --- a/drivers/mmc/card/block.c +++ b/drivers/mmc/card/block.c | |||
| @@ -873,7 +873,7 @@ static int mmc_blk_issue_secdiscard_rq(struct mmc_queue *mq, | |||
| 873 | { | 873 | { |
| 874 | struct mmc_blk_data *md = mq->data; | 874 | struct mmc_blk_data *md = mq->data; |
| 875 | struct mmc_card *card = md->queue.card; | 875 | struct mmc_card *card = md->queue.card; |
| 876 | unsigned int from, nr, arg; | 876 | unsigned int from, nr, arg, trim_arg, erase_arg; |
| 877 | int err = 0, type = MMC_BLK_SECDISCARD; | 877 | int err = 0, type = MMC_BLK_SECDISCARD; |
| 878 | 878 | ||
| 879 | if (!(mmc_can_secure_erase_trim(card) || mmc_can_sanitize(card))) { | 879 | if (!(mmc_can_secure_erase_trim(card) || mmc_can_sanitize(card))) { |
| @@ -881,20 +881,26 @@ static int mmc_blk_issue_secdiscard_rq(struct mmc_queue *mq, | |||
| 881 | goto out; | 881 | goto out; |
| 882 | } | 882 | } |
| 883 | 883 | ||
| 884 | from = blk_rq_pos(req); | ||
| 885 | nr = blk_rq_sectors(req); | ||
| 886 | |||
| 884 | /* The sanitize operation is supported at v4.5 only */ | 887 | /* The sanitize operation is supported at v4.5 only */ |
| 885 | if (mmc_can_sanitize(card)) { | 888 | if (mmc_can_sanitize(card)) { |
| 886 | err = mmc_switch(card, EXT_CSD_CMD_SET_NORMAL, | 889 | erase_arg = MMC_ERASE_ARG; |
| 887 | EXT_CSD_SANITIZE_START, 1, 0); | 890 | trim_arg = MMC_TRIM_ARG; |
| 888 | goto out; | 891 | } else { |
| 892 | erase_arg = MMC_SECURE_ERASE_ARG; | ||
| 893 | trim_arg = MMC_SECURE_TRIM1_ARG; | ||
| 889 | } | 894 | } |
| 890 | 895 | ||
| 891 | from = blk_rq_pos(req); | 896 | if (mmc_erase_group_aligned(card, from, nr)) |
| 892 | nr = blk_rq_sectors(req); | 897 | arg = erase_arg; |
| 893 | 898 | else if (mmc_can_trim(card)) | |
| 894 | if (mmc_can_trim(card) && !mmc_erase_group_aligned(card, from, nr)) | 899 | arg = trim_arg; |
| 895 | arg = MMC_SECURE_TRIM1_ARG; | 900 | else { |
| 896 | else | 901 | err = -EINVAL; |
| 897 | arg = MMC_SECURE_ERASE_ARG; | 902 | goto out; |
| 903 | } | ||
| 898 | retry: | 904 | retry: |
| 899 | if (card->quirks & MMC_QUIRK_INAND_CMD38) { | 905 | if (card->quirks & MMC_QUIRK_INAND_CMD38) { |
| 900 | err = mmc_switch(card, EXT_CSD_CMD_SET_NORMAL, | 906 | err = mmc_switch(card, EXT_CSD_CMD_SET_NORMAL, |
| @@ -904,25 +910,41 @@ retry: | |||
| 904 | INAND_CMD38_ARG_SECERASE, | 910 | INAND_CMD38_ARG_SECERASE, |
| 905 | 0); | 911 | 0); |
| 906 | if (err) | 912 | if (err) |
| 907 | goto out; | 913 | goto out_retry; |
| 908 | } | 914 | } |
| 915 | |||
| 909 | err = mmc_erase(card, from, nr, arg); | 916 | err = mmc_erase(card, from, nr, arg); |
| 910 | if (!err && arg == MMC_SECURE_TRIM1_ARG) { | 917 | if (err == -EIO) |
| 918 | goto out_retry; | ||
| 919 | if (err) | ||
| 920 | goto out; | ||
| 921 | |||
| 922 | if (arg == MMC_SECURE_TRIM1_ARG) { | ||
| 911 | if (card->quirks & MMC_QUIRK_INAND_CMD38) { | 923 | if (card->quirks & MMC_QUIRK_INAND_CMD38) { |
| 912 | err = mmc_switch(card, EXT_CSD_CMD_SET_NORMAL, | 924 | err = mmc_switch(card, EXT_CSD_CMD_SET_NORMAL, |
| 913 | INAND_CMD38_ARG_EXT_CSD, | 925 | INAND_CMD38_ARG_EXT_CSD, |
| 914 | INAND_CMD38_ARG_SECTRIM2, | 926 | INAND_CMD38_ARG_SECTRIM2, |
| 915 | 0); | 927 | 0); |
| 916 | if (err) | 928 | if (err) |
| 917 | goto out; | 929 | goto out_retry; |
| 918 | } | 930 | } |
| 931 | |||
| 919 | err = mmc_erase(card, from, nr, MMC_SECURE_TRIM2_ARG); | 932 | err = mmc_erase(card, from, nr, MMC_SECURE_TRIM2_ARG); |
| 933 | if (err == -EIO) | ||
| 934 | goto out_retry; | ||
| 935 | if (err) | ||
| 936 | goto out; | ||
| 920 | } | 937 | } |
| 921 | out: | 938 | |
| 922 | if (err == -EIO && !mmc_blk_reset(md, card->host, type)) | 939 | if (mmc_can_sanitize(card)) |
| 940 | err = mmc_switch(card, EXT_CSD_CMD_SET_NORMAL, | ||
| 941 | EXT_CSD_SANITIZE_START, 1, 0); | ||
| 942 | out_retry: | ||
| 943 | if (err && !mmc_blk_reset(md, card->host, type)) | ||
| 923 | goto retry; | 944 | goto retry; |
| 924 | if (!err) | 945 | if (!err) |
| 925 | mmc_blk_reset_success(md, type); | 946 | mmc_blk_reset_success(md, type); |
| 947 | out: | ||
| 926 | spin_lock_irq(&md->lock); | 948 | spin_lock_irq(&md->lock); |
| 927 | __blk_end_request(req, err, blk_rq_bytes(req)); | 949 | __blk_end_request(req, err, blk_rq_bytes(req)); |
| 928 | spin_unlock_irq(&md->lock); | 950 | spin_unlock_irq(&md->lock); |
| @@ -1802,7 +1824,7 @@ static void mmc_blk_remove(struct mmc_card *card) | |||
| 1802 | } | 1824 | } |
| 1803 | 1825 | ||
| 1804 | #ifdef CONFIG_PM | 1826 | #ifdef CONFIG_PM |
| 1805 | static int mmc_blk_suspend(struct mmc_card *card, pm_message_t state) | 1827 | static int mmc_blk_suspend(struct mmc_card *card) |
| 1806 | { | 1828 | { |
| 1807 | struct mmc_blk_data *part_md; | 1829 | struct mmc_blk_data *part_md; |
| 1808 | struct mmc_blk_data *md = mmc_get_drvdata(card); | 1830 | struct mmc_blk_data *md = mmc_get_drvdata(card); |
diff --git a/drivers/mmc/card/queue.c b/drivers/mmc/card/queue.c index 2517547b4366..996f8e36e23d 100644 --- a/drivers/mmc/card/queue.c +++ b/drivers/mmc/card/queue.c | |||
| @@ -139,7 +139,7 @@ static void mmc_queue_setup_discard(struct request_queue *q, | |||
| 139 | 139 | ||
| 140 | queue_flag_set_unlocked(QUEUE_FLAG_DISCARD, q); | 140 | queue_flag_set_unlocked(QUEUE_FLAG_DISCARD, q); |
| 141 | q->limits.max_discard_sectors = max_discard; | 141 | q->limits.max_discard_sectors = max_discard; |
| 142 | if (card->erased_byte == 0) | 142 | if (card->erased_byte == 0 && !mmc_can_discard(card)) |
| 143 | q->limits.discard_zeroes_data = 1; | 143 | q->limits.discard_zeroes_data = 1; |
| 144 | q->limits.discard_granularity = card->pref_erase << 9; | 144 | q->limits.discard_granularity = card->pref_erase << 9; |
| 145 | /* granularity must not be greater than max. discard */ | 145 | /* granularity must not be greater than max. discard */ |
diff --git a/drivers/mmc/core/bus.c b/drivers/mmc/core/bus.c index 3f606068d552..c60cee92a2b2 100644 --- a/drivers/mmc/core/bus.c +++ b/drivers/mmc/core/bus.c | |||
| @@ -122,14 +122,14 @@ static int mmc_bus_remove(struct device *dev) | |||
| 122 | return 0; | 122 | return 0; |
| 123 | } | 123 | } |
| 124 | 124 | ||
| 125 | static int mmc_bus_suspend(struct device *dev, pm_message_t state) | 125 | static int mmc_bus_suspend(struct device *dev) |
| 126 | { | 126 | { |
| 127 | struct mmc_driver *drv = to_mmc_driver(dev->driver); | 127 | struct mmc_driver *drv = to_mmc_driver(dev->driver); |
| 128 | struct mmc_card *card = mmc_dev_to_card(dev); | 128 | struct mmc_card *card = mmc_dev_to_card(dev); |
| 129 | int ret = 0; | 129 | int ret = 0; |
| 130 | 130 | ||
| 131 | if (dev->driver && drv->suspend) | 131 | if (dev->driver && drv->suspend) |
| 132 | ret = drv->suspend(card, state); | 132 | ret = drv->suspend(card); |
| 133 | return ret; | 133 | return ret; |
| 134 | } | 134 | } |
| 135 | 135 | ||
| @@ -165,20 +165,14 @@ static int mmc_runtime_idle(struct device *dev) | |||
| 165 | return pm_runtime_suspend(dev); | 165 | return pm_runtime_suspend(dev); |
| 166 | } | 166 | } |
| 167 | 167 | ||
| 168 | #endif /* !CONFIG_PM_RUNTIME */ | ||
| 169 | |||
| 168 | static const struct dev_pm_ops mmc_bus_pm_ops = { | 170 | static const struct dev_pm_ops mmc_bus_pm_ops = { |
| 169 | .runtime_suspend = mmc_runtime_suspend, | 171 | SET_RUNTIME_PM_OPS(mmc_runtime_suspend, mmc_runtime_resume, |
| 170 | .runtime_resume = mmc_runtime_resume, | 172 | mmc_runtime_idle) |
| 171 | .runtime_idle = mmc_runtime_idle, | 173 | SET_SYSTEM_SLEEP_PM_OPS(mmc_bus_suspend, mmc_bus_resume) |
| 172 | }; | 174 | }; |
| 173 | 175 | ||
| 174 | #define MMC_PM_OPS_PTR (&mmc_bus_pm_ops) | ||
| 175 | |||
| 176 | #else /* !CONFIG_PM_RUNTIME */ | ||
| 177 | |||
| 178 | #define MMC_PM_OPS_PTR NULL | ||
| 179 | |||
| 180 | #endif /* !CONFIG_PM_RUNTIME */ | ||
| 181 | |||
| 182 | static struct bus_type mmc_bus_type = { | 176 | static struct bus_type mmc_bus_type = { |
| 183 | .name = "mmc", | 177 | .name = "mmc", |
| 184 | .dev_attrs = mmc_dev_attrs, | 178 | .dev_attrs = mmc_dev_attrs, |
| @@ -186,9 +180,7 @@ static struct bus_type mmc_bus_type = { | |||
| 186 | .uevent = mmc_bus_uevent, | 180 | .uevent = mmc_bus_uevent, |
| 187 | .probe = mmc_bus_probe, | 181 | .probe = mmc_bus_probe, |
| 188 | .remove = mmc_bus_remove, | 182 | .remove = mmc_bus_remove, |
| 189 | .suspend = mmc_bus_suspend, | 183 | .pm = &mmc_bus_pm_ops, |
| 190 | .resume = mmc_bus_resume, | ||
| 191 | .pm = MMC_PM_OPS_PTR, | ||
| 192 | }; | 184 | }; |
| 193 | 185 | ||
| 194 | int mmc_register_bus(void) | 186 | int mmc_register_bus(void) |
diff --git a/drivers/mmc/core/cd-gpio.c b/drivers/mmc/core/cd-gpio.c index 29de31e260dd..2c14be73254c 100644 --- a/drivers/mmc/core/cd-gpio.c +++ b/drivers/mmc/core/cd-gpio.c | |||
| @@ -12,6 +12,7 @@ | |||
| 12 | #include <linux/gpio.h> | 12 | #include <linux/gpio.h> |
| 13 | #include <linux/interrupt.h> | 13 | #include <linux/interrupt.h> |
| 14 | #include <linux/jiffies.h> | 14 | #include <linux/jiffies.h> |
| 15 | #include <linux/mmc/cd-gpio.h> | ||
| 15 | #include <linux/mmc/host.h> | 16 | #include <linux/mmc/host.h> |
| 16 | #include <linux/module.h> | 17 | #include <linux/module.h> |
| 17 | #include <linux/slab.h> | 18 | #include <linux/slab.h> |
diff --git a/drivers/mmc/core/core.c b/drivers/mmc/core/core.c index 7474c47b9c08..ba821fe70bca 100644 --- a/drivers/mmc/core/core.c +++ b/drivers/mmc/core/core.c | |||
| @@ -1409,7 +1409,10 @@ static unsigned int mmc_mmc_erase_timeout(struct mmc_card *card, | |||
| 1409 | { | 1409 | { |
| 1410 | unsigned int erase_timeout; | 1410 | unsigned int erase_timeout; |
| 1411 | 1411 | ||
| 1412 | if (card->ext_csd.erase_group_def & 1) { | 1412 | if (arg == MMC_DISCARD_ARG || |
| 1413 | (arg == MMC_TRIM_ARG && card->ext_csd.rev >= 6)) { | ||
| 1414 | erase_timeout = card->ext_csd.trim_timeout; | ||
| 1415 | } else if (card->ext_csd.erase_group_def & 1) { | ||
| 1413 | /* High Capacity Erase Group Size uses HC timeouts */ | 1416 | /* High Capacity Erase Group Size uses HC timeouts */ |
| 1414 | if (arg == MMC_TRIM_ARG) | 1417 | if (arg == MMC_TRIM_ARG) |
| 1415 | erase_timeout = card->ext_csd.trim_timeout; | 1418 | erase_timeout = card->ext_csd.trim_timeout; |
| @@ -1681,8 +1684,6 @@ int mmc_can_trim(struct mmc_card *card) | |||
| 1681 | { | 1684 | { |
| 1682 | if (card->ext_csd.sec_feature_support & EXT_CSD_SEC_GB_CL_EN) | 1685 | if (card->ext_csd.sec_feature_support & EXT_CSD_SEC_GB_CL_EN) |
| 1683 | return 1; | 1686 | return 1; |
| 1684 | if (mmc_can_discard(card)) | ||
| 1685 | return 1; | ||
| 1686 | return 0; | 1687 | return 0; |
| 1687 | } | 1688 | } |
| 1688 | EXPORT_SYMBOL(mmc_can_trim); | 1689 | EXPORT_SYMBOL(mmc_can_trim); |
| @@ -1701,6 +1702,8 @@ EXPORT_SYMBOL(mmc_can_discard); | |||
| 1701 | 1702 | ||
| 1702 | int mmc_can_sanitize(struct mmc_card *card) | 1703 | int mmc_can_sanitize(struct mmc_card *card) |
| 1703 | { | 1704 | { |
| 1705 | if (!mmc_can_trim(card) && !mmc_can_erase(card)) | ||
| 1706 | return 0; | ||
| 1704 | if (card->ext_csd.sec_feature_support & EXT_CSD_SEC_SANITIZE) | 1707 | if (card->ext_csd.sec_feature_support & EXT_CSD_SEC_SANITIZE) |
| 1705 | return 1; | 1708 | return 1; |
| 1706 | return 0; | 1709 | return 0; |
| @@ -2235,6 +2238,7 @@ int mmc_cache_ctrl(struct mmc_host *host, u8 enable) | |||
| 2235 | mmc_card_is_removable(host)) | 2238 | mmc_card_is_removable(host)) |
| 2236 | return err; | 2239 | return err; |
| 2237 | 2240 | ||
| 2241 | mmc_claim_host(host); | ||
| 2238 | if (card && mmc_card_mmc(card) && | 2242 | if (card && mmc_card_mmc(card) && |
| 2239 | (card->ext_csd.cache_size > 0)) { | 2243 | (card->ext_csd.cache_size > 0)) { |
| 2240 | enable = !!enable; | 2244 | enable = !!enable; |
| @@ -2252,6 +2256,7 @@ int mmc_cache_ctrl(struct mmc_host *host, u8 enable) | |||
| 2252 | card->ext_csd.cache_ctrl = enable; | 2256 | card->ext_csd.cache_ctrl = enable; |
| 2253 | } | 2257 | } |
| 2254 | } | 2258 | } |
| 2259 | mmc_release_host(host); | ||
| 2255 | 2260 | ||
| 2256 | return err; | 2261 | return err; |
| 2257 | } | 2262 | } |
| @@ -2269,49 +2274,32 @@ int mmc_suspend_host(struct mmc_host *host) | |||
| 2269 | 2274 | ||
| 2270 | cancel_delayed_work(&host->detect); | 2275 | cancel_delayed_work(&host->detect); |
| 2271 | mmc_flush_scheduled_work(); | 2276 | mmc_flush_scheduled_work(); |
| 2272 | if (mmc_try_claim_host(host)) { | ||
| 2273 | err = mmc_cache_ctrl(host, 0); | ||
| 2274 | mmc_release_host(host); | ||
| 2275 | } else { | ||
| 2276 | err = -EBUSY; | ||
| 2277 | } | ||
| 2278 | 2277 | ||
| 2278 | err = mmc_cache_ctrl(host, 0); | ||
| 2279 | if (err) | 2279 | if (err) |
| 2280 | goto out; | 2280 | goto out; |
| 2281 | 2281 | ||
| 2282 | mmc_bus_get(host); | 2282 | mmc_bus_get(host); |
| 2283 | if (host->bus_ops && !host->bus_dead) { | 2283 | if (host->bus_ops && !host->bus_dead) { |
| 2284 | 2284 | ||
| 2285 | /* | 2285 | if (host->bus_ops->suspend) |
| 2286 | * A long response time is not acceptable for device drivers | 2286 | err = host->bus_ops->suspend(host); |
| 2287 | * when doing suspend. Prevent mmc_claim_host in the suspend | ||
| 2288 | * sequence, to potentially wait "forever" by trying to | ||
| 2289 | * pre-claim the host. | ||
| 2290 | */ | ||
| 2291 | if (mmc_try_claim_host(host)) { | ||
| 2292 | if (host->bus_ops->suspend) { | ||
| 2293 | err = host->bus_ops->suspend(host); | ||
| 2294 | } | ||
| 2295 | mmc_release_host(host); | ||
| 2296 | 2287 | ||
| 2297 | if (err == -ENOSYS || !host->bus_ops->resume) { | 2288 | if (err == -ENOSYS || !host->bus_ops->resume) { |
| 2298 | /* | 2289 | /* |
| 2299 | * We simply "remove" the card in this case. | 2290 | * We simply "remove" the card in this case. |
| 2300 | * It will be redetected on resume. (Calling | 2291 | * It will be redetected on resume. (Calling |
| 2301 | * bus_ops->remove() with a claimed host can | 2292 | * bus_ops->remove() with a claimed host can |
| 2302 | * deadlock.) | 2293 | * deadlock.) |
| 2303 | */ | 2294 | */ |
| 2304 | if (host->bus_ops->remove) | 2295 | if (host->bus_ops->remove) |
| 2305 | host->bus_ops->remove(host); | 2296 | host->bus_ops->remove(host); |
| 2306 | mmc_claim_host(host); | 2297 | mmc_claim_host(host); |
| 2307 | mmc_detach_bus(host); | 2298 | mmc_detach_bus(host); |
| 2308 | mmc_power_off(host); | 2299 | mmc_power_off(host); |
| 2309 | mmc_release_host(host); | 2300 | mmc_release_host(host); |
| 2310 | host->pm_flags = 0; | 2301 | host->pm_flags = 0; |
| 2311 | err = 0; | 2302 | err = 0; |
| 2312 | } | ||
| 2313 | } else { | ||
| 2314 | err = -EBUSY; | ||
| 2315 | } | 2303 | } |
| 2316 | } | 2304 | } |
| 2317 | mmc_bus_put(host); | 2305 | mmc_bus_put(host); |
diff --git a/drivers/mmc/host/dw_mmc.c b/drivers/mmc/host/dw_mmc.c index bf3c9b456aaf..ab3fc4617107 100644 --- a/drivers/mmc/host/dw_mmc.c +++ b/drivers/mmc/host/dw_mmc.c | |||
| @@ -526,8 +526,10 @@ static int dw_mci_submit_data_dma(struct dw_mci *host, struct mmc_data *data) | |||
| 526 | return -ENODEV; | 526 | return -ENODEV; |
| 527 | 527 | ||
| 528 | sg_len = dw_mci_pre_dma_transfer(host, data, 0); | 528 | sg_len = dw_mci_pre_dma_transfer(host, data, 0); |
| 529 | if (sg_len < 0) | 529 | if (sg_len < 0) { |
| 530 | host->dma_ops->stop(host); | ||
| 530 | return sg_len; | 531 | return sg_len; |
| 532 | } | ||
| 531 | 533 | ||
| 532 | host->using_dma = 1; | 534 | host->using_dma = 1; |
| 533 | 535 | ||
| @@ -1879,7 +1881,8 @@ static void dw_mci_init_dma(struct dw_mci *host) | |||
| 1879 | if (!host->dma_ops) | 1881 | if (!host->dma_ops) |
| 1880 | goto no_dma; | 1882 | goto no_dma; |
| 1881 | 1883 | ||
| 1882 | if (host->dma_ops->init) { | 1884 | if (host->dma_ops->init && host->dma_ops->start && |
| 1885 | host->dma_ops->stop && host->dma_ops->cleanup) { | ||
| 1883 | if (host->dma_ops->init(host)) { | 1886 | if (host->dma_ops->init(host)) { |
| 1884 | dev_err(&host->dev, "%s: Unable to initialize " | 1887 | dev_err(&host->dev, "%s: Unable to initialize " |
| 1885 | "DMA Controller.\n", __func__); | 1888 | "DMA Controller.\n", __func__); |
diff --git a/drivers/mmc/host/omap_hsmmc.c b/drivers/mmc/host/omap_hsmmc.c index 5c2b1c10af9c..56d4499d4388 100644 --- a/drivers/mmc/host/omap_hsmmc.c +++ b/drivers/mmc/host/omap_hsmmc.c | |||
| @@ -249,7 +249,7 @@ static int omap_hsmmc_set_power(struct device *dev, int slot, int power_on, | |||
| 249 | * the pbias cell programming support is still missing when | 249 | * the pbias cell programming support is still missing when |
| 250 | * booting with Device tree | 250 | * booting with Device tree |
| 251 | */ | 251 | */ |
| 252 | if (of_have_populated_dt() && !vdd) | 252 | if (dev->of_node && !vdd) |
| 253 | return 0; | 253 | return 0; |
| 254 | 254 | ||
| 255 | if (mmc_slot(host).before_set_reg) | 255 | if (mmc_slot(host).before_set_reg) |
| @@ -1549,7 +1549,7 @@ static void omap_hsmmc_set_ios(struct mmc_host *mmc, struct mmc_ios *ios) | |||
| 1549 | * can't be allowed when booting with device | 1549 | * can't be allowed when booting with device |
| 1550 | * tree. | 1550 | * tree. |
| 1551 | */ | 1551 | */ |
| 1552 | (!of_have_populated_dt())) { | 1552 | !host->dev->of_node) { |
| 1553 | /* | 1553 | /* |
| 1554 | * The mmc_select_voltage fn of the core does | 1554 | * The mmc_select_voltage fn of the core does |
| 1555 | * not seem to set the power_mode to | 1555 | * not seem to set the power_mode to |
| @@ -1741,7 +1741,7 @@ static const struct of_device_id omap_mmc_of_match[] = { | |||
| 1741 | .data = &omap4_reg_offset, | 1741 | .data = &omap4_reg_offset, |
| 1742 | }, | 1742 | }, |
| 1743 | {}, | 1743 | {}, |
| 1744 | } | 1744 | }; |
| 1745 | MODULE_DEVICE_TABLE(of, omap_mmc_of_match); | 1745 | MODULE_DEVICE_TABLE(of, omap_mmc_of_match); |
| 1746 | 1746 | ||
| 1747 | static struct omap_mmc_platform_data *of_get_hsmmc_pdata(struct device *dev) | 1747 | static struct omap_mmc_platform_data *of_get_hsmmc_pdata(struct device *dev) |
diff --git a/drivers/mmc/host/sdhci-esdhc-imx.c b/drivers/mmc/host/sdhci-esdhc-imx.c index 6193a0d7bde5..8abdaf6697a8 100644 --- a/drivers/mmc/host/sdhci-esdhc-imx.c +++ b/drivers/mmc/host/sdhci-esdhc-imx.c | |||
| @@ -467,8 +467,7 @@ static int __devinit sdhci_esdhc_imx_probe(struct platform_device *pdev) | |||
| 467 | clk_prepare_enable(clk); | 467 | clk_prepare_enable(clk); |
| 468 | pltfm_host->clk = clk; | 468 | pltfm_host->clk = clk; |
| 469 | 469 | ||
| 470 | if (!is_imx25_esdhc(imx_data)) | 470 | host->quirks |= SDHCI_QUIRK_BROKEN_TIMEOUT_VAL; |
| 471 | host->quirks |= SDHCI_QUIRK_BROKEN_TIMEOUT_VAL; | ||
| 472 | 471 | ||
| 473 | if (is_imx25_esdhc(imx_data) || is_imx35_esdhc(imx_data)) | 472 | if (is_imx25_esdhc(imx_data) || is_imx35_esdhc(imx_data)) |
| 474 | /* Fix errata ENGcm07207 present on i.MX25 and i.MX35 */ | 473 | /* Fix errata ENGcm07207 present on i.MX25 and i.MX35 */ |
diff --git a/drivers/mmc/host/sdhci.c b/drivers/mmc/host/sdhci.c index 9aa77f3f04a8..ccefdebeff14 100644 --- a/drivers/mmc/host/sdhci.c +++ b/drivers/mmc/host/sdhci.c | |||
| @@ -147,7 +147,7 @@ static void sdhci_set_card_detection(struct sdhci_host *host, bool enable) | |||
| 147 | u32 present, irqs; | 147 | u32 present, irqs; |
| 148 | 148 | ||
| 149 | if ((host->quirks & SDHCI_QUIRK_BROKEN_CARD_DETECTION) || | 149 | if ((host->quirks & SDHCI_QUIRK_BROKEN_CARD_DETECTION) || |
| 150 | !mmc_card_is_removable(host->mmc)) | 150 | (host->mmc->caps & MMC_CAP_NONREMOVABLE)) |
| 151 | return; | 151 | return; |
| 152 | 152 | ||
| 153 | present = sdhci_readl(host, SDHCI_PRESENT_STATE) & | 153 | present = sdhci_readl(host, SDHCI_PRESENT_STATE) & |
diff --git a/drivers/net/arcnet/arc-rimi.c b/drivers/net/arcnet/arc-rimi.c index 25197b698dd6..b8b4c7ba884f 100644 --- a/drivers/net/arcnet/arc-rimi.c +++ b/drivers/net/arcnet/arc-rimi.c | |||
| @@ -89,16 +89,16 @@ static int __init arcrimi_probe(struct net_device *dev) | |||
| 89 | BUGLVL(D_NORMAL) printk(VERSION); | 89 | BUGLVL(D_NORMAL) printk(VERSION); |
| 90 | BUGLVL(D_NORMAL) printk("E-mail me if you actually test the RIM I driver, please!\n"); | 90 | BUGLVL(D_NORMAL) printk("E-mail me if you actually test the RIM I driver, please!\n"); |
| 91 | 91 | ||
| 92 | BUGMSG(D_NORMAL, "Given: node %02Xh, shmem %lXh, irq %d\n", | 92 | BUGLVL(D_NORMAL) printk("Given: node %02Xh, shmem %lXh, irq %d\n", |
| 93 | dev->dev_addr[0], dev->mem_start, dev->irq); | 93 | dev->dev_addr[0], dev->mem_start, dev->irq); |
| 94 | 94 | ||
| 95 | if (dev->mem_start <= 0 || dev->irq <= 0) { | 95 | if (dev->mem_start <= 0 || dev->irq <= 0) { |
| 96 | BUGMSG(D_NORMAL, "No autoprobe for RIM I; you " | 96 | BUGLVL(D_NORMAL) printk("No autoprobe for RIM I; you " |
| 97 | "must specify the shmem and irq!\n"); | 97 | "must specify the shmem and irq!\n"); |
| 98 | return -ENODEV; | 98 | return -ENODEV; |
| 99 | } | 99 | } |
| 100 | if (dev->dev_addr[0] == 0) { | 100 | if (dev->dev_addr[0] == 0) { |
| 101 | BUGMSG(D_NORMAL, "You need to specify your card's station " | 101 | BUGLVL(D_NORMAL) printk("You need to specify your card's station " |
| 102 | "ID!\n"); | 102 | "ID!\n"); |
| 103 | return -ENODEV; | 103 | return -ENODEV; |
| 104 | } | 104 | } |
| @@ -109,7 +109,7 @@ static int __init arcrimi_probe(struct net_device *dev) | |||
| 109 | * will be taken. | 109 | * will be taken. |
| 110 | */ | 110 | */ |
| 111 | if (!request_mem_region(dev->mem_start, MIRROR_SIZE, "arcnet (90xx)")) { | 111 | if (!request_mem_region(dev->mem_start, MIRROR_SIZE, "arcnet (90xx)")) { |
| 112 | BUGMSG(D_NORMAL, "Card memory already allocated\n"); | 112 | BUGLVL(D_NORMAL) printk("Card memory already allocated\n"); |
| 113 | return -ENODEV; | 113 | return -ENODEV; |
| 114 | } | 114 | } |
| 115 | return arcrimi_found(dev); | 115 | return arcrimi_found(dev); |
diff --git a/drivers/net/can/usb/peak_usb/pcan_usb_pro.c b/drivers/net/can/usb/peak_usb/pcan_usb_pro.c index 5234586dff15..629c4ba5d49d 100644 --- a/drivers/net/can/usb/peak_usb/pcan_usb_pro.c +++ b/drivers/net/can/usb/peak_usb/pcan_usb_pro.c | |||
| @@ -875,6 +875,7 @@ static int pcan_usb_pro_init(struct peak_usb_device *dev) | |||
| 875 | PCAN_USBPRO_INFO_FW, | 875 | PCAN_USBPRO_INFO_FW, |
| 876 | &fi, sizeof(fi)); | 876 | &fi, sizeof(fi)); |
| 877 | if (err) { | 877 | if (err) { |
| 878 | kfree(usb_if); | ||
| 878 | dev_err(dev->netdev->dev.parent, | 879 | dev_err(dev->netdev->dev.parent, |
| 879 | "unable to read %s firmware info (err %d)\n", | 880 | "unable to read %s firmware info (err %d)\n", |
| 880 | pcan_usb_pro.name, err); | 881 | pcan_usb_pro.name, err); |
| @@ -885,6 +886,7 @@ static int pcan_usb_pro_init(struct peak_usb_device *dev) | |||
| 885 | PCAN_USBPRO_INFO_BL, | 886 | PCAN_USBPRO_INFO_BL, |
| 886 | &bi, sizeof(bi)); | 887 | &bi, sizeof(bi)); |
| 887 | if (err) { | 888 | if (err) { |
| 889 | kfree(usb_if); | ||
| 888 | dev_err(dev->netdev->dev.parent, | 890 | dev_err(dev->netdev->dev.parent, |
| 889 | "unable to read %s bootloader info (err %d)\n", | 891 | "unable to read %s bootloader info (err %d)\n", |
| 890 | pcan_usb_pro.name, err); | 892 | pcan_usb_pro.name, err); |
diff --git a/drivers/net/dummy.c b/drivers/net/dummy.c index d5c6d92f1ee7..442d91a2747b 100644 --- a/drivers/net/dummy.c +++ b/drivers/net/dummy.c | |||
| @@ -107,14 +107,14 @@ static int dummy_dev_init(struct net_device *dev) | |||
| 107 | return 0; | 107 | return 0; |
| 108 | } | 108 | } |
| 109 | 109 | ||
| 110 | static void dummy_dev_free(struct net_device *dev) | 110 | static void dummy_dev_uninit(struct net_device *dev) |
| 111 | { | 111 | { |
| 112 | free_percpu(dev->dstats); | 112 | free_percpu(dev->dstats); |
| 113 | free_netdev(dev); | ||
| 114 | } | 113 | } |
| 115 | 114 | ||
| 116 | static const struct net_device_ops dummy_netdev_ops = { | 115 | static const struct net_device_ops dummy_netdev_ops = { |
| 117 | .ndo_init = dummy_dev_init, | 116 | .ndo_init = dummy_dev_init, |
| 117 | .ndo_uninit = dummy_dev_uninit, | ||
| 118 | .ndo_start_xmit = dummy_xmit, | 118 | .ndo_start_xmit = dummy_xmit, |
| 119 | .ndo_validate_addr = eth_validate_addr, | 119 | .ndo_validate_addr = eth_validate_addr, |
| 120 | .ndo_set_rx_mode = set_multicast_list, | 120 | .ndo_set_rx_mode = set_multicast_list, |
| @@ -128,7 +128,7 @@ static void dummy_setup(struct net_device *dev) | |||
| 128 | 128 | ||
| 129 | /* Initialize the device structure. */ | 129 | /* Initialize the device structure. */ |
| 130 | dev->netdev_ops = &dummy_netdev_ops; | 130 | dev->netdev_ops = &dummy_netdev_ops; |
| 131 | dev->destructor = dummy_dev_free; | 131 | dev->destructor = free_netdev; |
| 132 | 132 | ||
| 133 | /* Fill in device structure with ethernet-generic values. */ | 133 | /* Fill in device structure with ethernet-generic values. */ |
| 134 | dev->tx_queue_len = 0; | 134 | dev->tx_queue_len = 0; |
diff --git a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_link.c b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_link.c index 3d78b6267308..a3fb7215cd89 100644 --- a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_link.c +++ b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_link.c | |||
| @@ -922,6 +922,12 @@ static int bnx2x_ets_e3b0_sp_pri_to_cos_set(const struct link_params *params, | |||
| 922 | const u8 max_num_of_cos = (port) ? DCBX_E3B0_MAX_NUM_COS_PORT1 : | 922 | const u8 max_num_of_cos = (port) ? DCBX_E3B0_MAX_NUM_COS_PORT1 : |
| 923 | DCBX_E3B0_MAX_NUM_COS_PORT0; | 923 | DCBX_E3B0_MAX_NUM_COS_PORT0; |
| 924 | 924 | ||
| 925 | if (pri >= max_num_of_cos) { | ||
| 926 | DP(NETIF_MSG_LINK, "bnx2x_ets_e3b0_sp_pri_to_cos_set invalid " | ||
| 927 | "parameter Illegal strict priority\n"); | ||
| 928 | return -EINVAL; | ||
| 929 | } | ||
| 930 | |||
| 925 | if (sp_pri_to_cos[pri] != DCBX_INVALID_COS) { | 931 | if (sp_pri_to_cos[pri] != DCBX_INVALID_COS) { |
| 926 | DP(NETIF_MSG_LINK, "bnx2x_ets_e3b0_sp_pri_to_cos_set invalid " | 932 | DP(NETIF_MSG_LINK, "bnx2x_ets_e3b0_sp_pri_to_cos_set invalid " |
| 927 | "parameter There can't be two COS's with " | 933 | "parameter There can't be two COS's with " |
| @@ -929,12 +935,6 @@ static int bnx2x_ets_e3b0_sp_pri_to_cos_set(const struct link_params *params, | |||
| 929 | return -EINVAL; | 935 | return -EINVAL; |
| 930 | } | 936 | } |
| 931 | 937 | ||
| 932 | if (pri > max_num_of_cos) { | ||
| 933 | DP(NETIF_MSG_LINK, "bnx2x_ets_e3b0_sp_pri_to_cos_set invalid " | ||
| 934 | "parameter Illegal strict priority\n"); | ||
| 935 | return -EINVAL; | ||
| 936 | } | ||
| 937 | |||
| 938 | sp_pri_to_cos[pri] = cos_entry; | 938 | sp_pri_to_cos[pri] = cos_entry; |
| 939 | return 0; | 939 | return 0; |
| 940 | 940 | ||
diff --git a/drivers/net/ethernet/intel/ixgbe/ixgbe_lib.c b/drivers/net/ethernet/intel/ixgbe/ixgbe_lib.c index 027d7a75be39..ed1b47dc0834 100644 --- a/drivers/net/ethernet/intel/ixgbe/ixgbe_lib.c +++ b/drivers/net/ethernet/intel/ixgbe/ixgbe_lib.c | |||
| @@ -622,6 +622,16 @@ static int ixgbe_alloc_q_vector(struct ixgbe_adapter *adapter, int v_idx, | |||
| 622 | if (adapter->hw.mac.type == ixgbe_mac_82599EB) | 622 | if (adapter->hw.mac.type == ixgbe_mac_82599EB) |
| 623 | set_bit(__IXGBE_RX_CSUM_UDP_ZERO_ERR, &ring->state); | 623 | set_bit(__IXGBE_RX_CSUM_UDP_ZERO_ERR, &ring->state); |
| 624 | 624 | ||
| 625 | #ifdef IXGBE_FCOE | ||
| 626 | if (adapter->netdev->features & NETIF_F_FCOE_MTU) { | ||
| 627 | struct ixgbe_ring_feature *f; | ||
| 628 | f = &adapter->ring_feature[RING_F_FCOE]; | ||
| 629 | if ((rxr_idx >= f->mask) && | ||
| 630 | (rxr_idx < f->mask + f->indices)) | ||
| 631 | set_bit(__IXGBE_RX_FCOE_BUFSZ, &ring->state); | ||
| 632 | } | ||
| 633 | |||
| 634 | #endif /* IXGBE_FCOE */ | ||
| 625 | /* apply Rx specific ring traits */ | 635 | /* apply Rx specific ring traits */ |
| 626 | ring->count = adapter->rx_ring_count; | 636 | ring->count = adapter->rx_ring_count; |
| 627 | ring->queue_index = rxr_idx; | 637 | ring->queue_index = rxr_idx; |
diff --git a/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c b/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c index f3b849438b62..7c4325ec22c2 100644 --- a/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c +++ b/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c | |||
| @@ -3127,14 +3127,6 @@ static void ixgbe_set_rx_buffer_len(struct ixgbe_adapter *adapter) | |||
| 3127 | set_ring_rsc_enabled(rx_ring); | 3127 | set_ring_rsc_enabled(rx_ring); |
| 3128 | else | 3128 | else |
| 3129 | clear_ring_rsc_enabled(rx_ring); | 3129 | clear_ring_rsc_enabled(rx_ring); |
| 3130 | #ifdef IXGBE_FCOE | ||
| 3131 | if (netdev->features & NETIF_F_FCOE_MTU) { | ||
| 3132 | struct ixgbe_ring_feature *f; | ||
| 3133 | f = &adapter->ring_feature[RING_F_FCOE]; | ||
| 3134 | if ((i >= f->mask) && (i < f->mask + f->indices)) | ||
| 3135 | set_bit(__IXGBE_RX_FCOE_BUFSZ, &rx_ring->state); | ||
| 3136 | } | ||
| 3137 | #endif /* IXGBE_FCOE */ | ||
| 3138 | } | 3130 | } |
| 3139 | } | 3131 | } |
| 3140 | 3132 | ||
| @@ -4808,7 +4800,9 @@ static int ixgbe_resume(struct pci_dev *pdev) | |||
| 4808 | 4800 | ||
| 4809 | pci_wake_from_d3(pdev, false); | 4801 | pci_wake_from_d3(pdev, false); |
| 4810 | 4802 | ||
| 4803 | rtnl_lock(); | ||
| 4811 | err = ixgbe_init_interrupt_scheme(adapter); | 4804 | err = ixgbe_init_interrupt_scheme(adapter); |
| 4805 | rtnl_unlock(); | ||
| 4812 | if (err) { | 4806 | if (err) { |
| 4813 | e_dev_err("Cannot initialize interrupts for device\n"); | 4807 | e_dev_err("Cannot initialize interrupts for device\n"); |
| 4814 | return err; | 4808 | return err; |
diff --git a/drivers/net/ethernet/micrel/ks8851.c b/drivers/net/ethernet/micrel/ks8851.c index e5dc0757f077..f8dda009d3c0 100644 --- a/drivers/net/ethernet/micrel/ks8851.c +++ b/drivers/net/ethernet/micrel/ks8851.c | |||
| @@ -889,16 +889,17 @@ static int ks8851_net_stop(struct net_device *dev) | |||
| 889 | netif_stop_queue(dev); | 889 | netif_stop_queue(dev); |
| 890 | 890 | ||
| 891 | mutex_lock(&ks->lock); | 891 | mutex_lock(&ks->lock); |
| 892 | /* turn off the IRQs and ack any outstanding */ | ||
| 893 | ks8851_wrreg16(ks, KS_IER, 0x0000); | ||
| 894 | ks8851_wrreg16(ks, KS_ISR, 0xffff); | ||
| 895 | mutex_unlock(&ks->lock); | ||
| 892 | 896 | ||
| 893 | /* stop any outstanding work */ | 897 | /* stop any outstanding work */ |
| 894 | flush_work(&ks->irq_work); | 898 | flush_work(&ks->irq_work); |
| 895 | flush_work(&ks->tx_work); | 899 | flush_work(&ks->tx_work); |
| 896 | flush_work(&ks->rxctrl_work); | 900 | flush_work(&ks->rxctrl_work); |
| 897 | 901 | ||
| 898 | /* turn off the IRQs and ack any outstanding */ | 902 | mutex_lock(&ks->lock); |
| 899 | ks8851_wrreg16(ks, KS_IER, 0x0000); | ||
| 900 | ks8851_wrreg16(ks, KS_ISR, 0xffff); | ||
| 901 | |||
| 902 | /* shutdown RX process */ | 903 | /* shutdown RX process */ |
| 903 | ks8851_wrreg16(ks, KS_RXCR1, 0x0000); | 904 | ks8851_wrreg16(ks, KS_RXCR1, 0x0000); |
| 904 | 905 | ||
| @@ -907,6 +908,7 @@ static int ks8851_net_stop(struct net_device *dev) | |||
| 907 | 908 | ||
| 908 | /* set powermode to soft power down to save power */ | 909 | /* set powermode to soft power down to save power */ |
| 909 | ks8851_set_powermode(ks, PMECR_PM_SOFTDOWN); | 910 | ks8851_set_powermode(ks, PMECR_PM_SOFTDOWN); |
| 911 | mutex_unlock(&ks->lock); | ||
| 910 | 912 | ||
| 911 | /* ensure any queued tx buffers are dumped */ | 913 | /* ensure any queued tx buffers are dumped */ |
| 912 | while (!skb_queue_empty(&ks->txq)) { | 914 | while (!skb_queue_empty(&ks->txq)) { |
| @@ -918,7 +920,6 @@ static int ks8851_net_stop(struct net_device *dev) | |||
| 918 | dev_kfree_skb(txb); | 920 | dev_kfree_skb(txb); |
| 919 | } | 921 | } |
| 920 | 922 | ||
| 921 | mutex_unlock(&ks->lock); | ||
| 922 | return 0; | 923 | return 0; |
| 923 | } | 924 | } |
| 924 | 925 | ||
| @@ -1524,7 +1525,7 @@ static int __devinit ks8851_probe(struct spi_device *spi) | |||
| 1524 | 1525 | ||
| 1525 | 1526 | ||
| 1526 | err_netdev: | 1527 | err_netdev: |
| 1527 | free_irq(ndev->irq, ndev); | 1528 | free_irq(ndev->irq, ks); |
| 1528 | 1529 | ||
| 1529 | err_id: | 1530 | err_id: |
| 1530 | err_irq: | 1531 | err_irq: |
diff --git a/drivers/net/ethernet/micrel/ksz884x.c b/drivers/net/ethernet/micrel/ksz884x.c index ef723b185d85..eaf9ff0262a9 100644 --- a/drivers/net/ethernet/micrel/ksz884x.c +++ b/drivers/net/ethernet/micrel/ksz884x.c | |||
| @@ -5675,7 +5675,7 @@ static int netdev_set_mac_address(struct net_device *dev, void *addr) | |||
| 5675 | memcpy(hw->override_addr, mac->sa_data, ETH_ALEN); | 5675 | memcpy(hw->override_addr, mac->sa_data, ETH_ALEN); |
| 5676 | } | 5676 | } |
| 5677 | 5677 | ||
| 5678 | memcpy(dev->dev_addr, mac->sa_data, MAX_ADDR_LEN); | 5678 | memcpy(dev->dev_addr, mac->sa_data, ETH_ALEN); |
| 5679 | 5679 | ||
| 5680 | interrupt = hw_block_intr(hw); | 5680 | interrupt = hw_block_intr(hw); |
| 5681 | 5681 | ||
diff --git a/drivers/net/ethernet/smsc/smsc911x.c b/drivers/net/ethernet/smsc/smsc911x.c index 480fd0822e4a..dab9c6f671ec 100644 --- a/drivers/net/ethernet/smsc/smsc911x.c +++ b/drivers/net/ethernet/smsc/smsc911x.c | |||
| @@ -2379,7 +2379,6 @@ static int __devinit smsc911x_drv_probe(struct platform_device *pdev) | |||
| 2379 | SET_NETDEV_DEV(dev, &pdev->dev); | 2379 | SET_NETDEV_DEV(dev, &pdev->dev); |
| 2380 | 2380 | ||
| 2381 | pdata = netdev_priv(dev); | 2381 | pdata = netdev_priv(dev); |
| 2382 | |||
| 2383 | dev->irq = irq_res->start; | 2382 | dev->irq = irq_res->start; |
| 2384 | irq_flags = irq_res->flags & IRQF_TRIGGER_MASK; | 2383 | irq_flags = irq_res->flags & IRQF_TRIGGER_MASK; |
| 2385 | pdata->ioaddr = ioremap_nocache(res->start, res_size); | 2384 | pdata->ioaddr = ioremap_nocache(res->start, res_size); |
| @@ -2443,7 +2442,7 @@ static int __devinit smsc911x_drv_probe(struct platform_device *pdev) | |||
| 2443 | if (retval) { | 2442 | if (retval) { |
| 2444 | SMSC_WARN(pdata, probe, | 2443 | SMSC_WARN(pdata, probe, |
| 2445 | "Unable to claim requested irq: %d", dev->irq); | 2444 | "Unable to claim requested irq: %d", dev->irq); |
| 2446 | goto out_free_irq; | 2445 | goto out_disable_resources; |
| 2447 | } | 2446 | } |
| 2448 | 2447 | ||
| 2449 | retval = register_netdev(dev); | 2448 | retval = register_netdev(dev); |
diff --git a/drivers/net/ethernet/ti/davinci_mdio.c b/drivers/net/ethernet/ti/davinci_mdio.c index 2757c7d6e633..e4e47088e26b 100644 --- a/drivers/net/ethernet/ti/davinci_mdio.c +++ b/drivers/net/ethernet/ti/davinci_mdio.c | |||
| @@ -181,6 +181,11 @@ static inline int wait_for_user_access(struct davinci_mdio_data *data) | |||
| 181 | __davinci_mdio_reset(data); | 181 | __davinci_mdio_reset(data); |
| 182 | return -EAGAIN; | 182 | return -EAGAIN; |
| 183 | } | 183 | } |
| 184 | |||
| 185 | reg = __raw_readl(®s->user[0].access); | ||
| 186 | if ((reg & USERACCESS_GO) == 0) | ||
| 187 | return 0; | ||
| 188 | |||
| 184 | dev_err(data->dev, "timed out waiting for user access\n"); | 189 | dev_err(data->dev, "timed out waiting for user access\n"); |
| 185 | return -ETIMEDOUT; | 190 | return -ETIMEDOUT; |
| 186 | } | 191 | } |
diff --git a/drivers/net/hyperv/netvsc_drv.c b/drivers/net/hyperv/netvsc_drv.c index a0cc12786be4..8f8ed3320425 100644 --- a/drivers/net/hyperv/netvsc_drv.c +++ b/drivers/net/hyperv/netvsc_drv.c | |||
| @@ -44,6 +44,7 @@ struct net_device_context { | |||
| 44 | /* point back to our device context */ | 44 | /* point back to our device context */ |
| 45 | struct hv_device *device_ctx; | 45 | struct hv_device *device_ctx; |
| 46 | struct delayed_work dwork; | 46 | struct delayed_work dwork; |
| 47 | struct work_struct work; | ||
| 47 | }; | 48 | }; |
| 48 | 49 | ||
| 49 | 50 | ||
| @@ -51,30 +52,22 @@ static int ring_size = 128; | |||
| 51 | module_param(ring_size, int, S_IRUGO); | 52 | module_param(ring_size, int, S_IRUGO); |
| 52 | MODULE_PARM_DESC(ring_size, "Ring buffer size (# of pages)"); | 53 | MODULE_PARM_DESC(ring_size, "Ring buffer size (# of pages)"); |
| 53 | 54 | ||
| 54 | struct set_multicast_work { | ||
| 55 | struct work_struct work; | ||
| 56 | struct net_device *net; | ||
| 57 | }; | ||
| 58 | |||
| 59 | static void do_set_multicast(struct work_struct *w) | 55 | static void do_set_multicast(struct work_struct *w) |
| 60 | { | 56 | { |
| 61 | struct set_multicast_work *swk = | 57 | struct net_device_context *ndevctx = |
| 62 | container_of(w, struct set_multicast_work, work); | 58 | container_of(w, struct net_device_context, work); |
| 63 | struct net_device *net = swk->net; | ||
| 64 | |||
| 65 | struct net_device_context *ndevctx = netdev_priv(net); | ||
| 66 | struct netvsc_device *nvdev; | 59 | struct netvsc_device *nvdev; |
| 67 | struct rndis_device *rdev; | 60 | struct rndis_device *rdev; |
| 68 | 61 | ||
| 69 | nvdev = hv_get_drvdata(ndevctx->device_ctx); | 62 | nvdev = hv_get_drvdata(ndevctx->device_ctx); |
| 70 | if (nvdev == NULL) | 63 | if (nvdev == NULL || nvdev->ndev == NULL) |
| 71 | goto out; | 64 | return; |
| 72 | 65 | ||
| 73 | rdev = nvdev->extension; | 66 | rdev = nvdev->extension; |
| 74 | if (rdev == NULL) | 67 | if (rdev == NULL) |
| 75 | goto out; | 68 | return; |
| 76 | 69 | ||
| 77 | if (net->flags & IFF_PROMISC) | 70 | if (nvdev->ndev->flags & IFF_PROMISC) |
| 78 | rndis_filter_set_packet_filter(rdev, | 71 | rndis_filter_set_packet_filter(rdev, |
| 79 | NDIS_PACKET_TYPE_PROMISCUOUS); | 72 | NDIS_PACKET_TYPE_PROMISCUOUS); |
| 80 | else | 73 | else |
| @@ -82,21 +75,13 @@ static void do_set_multicast(struct work_struct *w) | |||
| 82 | NDIS_PACKET_TYPE_BROADCAST | | 75 | NDIS_PACKET_TYPE_BROADCAST | |
| 83 | NDIS_PACKET_TYPE_ALL_MULTICAST | | 76 | NDIS_PACKET_TYPE_ALL_MULTICAST | |
| 84 | NDIS_PACKET_TYPE_DIRECTED); | 77 | NDIS_PACKET_TYPE_DIRECTED); |
| 85 | |||
| 86 | out: | ||
| 87 | kfree(w); | ||
| 88 | } | 78 | } |
| 89 | 79 | ||
| 90 | static void netvsc_set_multicast_list(struct net_device *net) | 80 | static void netvsc_set_multicast_list(struct net_device *net) |
| 91 | { | 81 | { |
| 92 | struct set_multicast_work *swk = | 82 | struct net_device_context *net_device_ctx = netdev_priv(net); |
| 93 | kmalloc(sizeof(struct set_multicast_work), GFP_ATOMIC); | ||
| 94 | if (swk == NULL) | ||
| 95 | return; | ||
| 96 | 83 | ||
| 97 | swk->net = net; | 84 | schedule_work(&net_device_ctx->work); |
| 98 | INIT_WORK(&swk->work, do_set_multicast); | ||
| 99 | schedule_work(&swk->work); | ||
| 100 | } | 85 | } |
| 101 | 86 | ||
| 102 | static int netvsc_open(struct net_device *net) | 87 | static int netvsc_open(struct net_device *net) |
| @@ -125,6 +110,8 @@ static int netvsc_close(struct net_device *net) | |||
| 125 | 110 | ||
| 126 | netif_tx_disable(net); | 111 | netif_tx_disable(net); |
| 127 | 112 | ||
| 113 | /* Make sure netvsc_set_multicast_list doesn't re-enable filter! */ | ||
| 114 | cancel_work_sync(&net_device_ctx->work); | ||
| 128 | ret = rndis_filter_close(device_obj); | 115 | ret = rndis_filter_close(device_obj); |
| 129 | if (ret != 0) | 116 | if (ret != 0) |
| 130 | netdev_err(net, "unable to close device (ret %d).\n", ret); | 117 | netdev_err(net, "unable to close device (ret %d).\n", ret); |
| @@ -339,6 +326,7 @@ static int netvsc_change_mtu(struct net_device *ndev, int mtu) | |||
| 339 | 326 | ||
| 340 | nvdev->start_remove = true; | 327 | nvdev->start_remove = true; |
| 341 | cancel_delayed_work_sync(&ndevctx->dwork); | 328 | cancel_delayed_work_sync(&ndevctx->dwork); |
| 329 | cancel_work_sync(&ndevctx->work); | ||
| 342 | netif_tx_disable(ndev); | 330 | netif_tx_disable(ndev); |
| 343 | rndis_filter_device_remove(hdev); | 331 | rndis_filter_device_remove(hdev); |
| 344 | 332 | ||
| @@ -407,6 +395,7 @@ static int netvsc_probe(struct hv_device *dev, | |||
| 407 | net_device_ctx->device_ctx = dev; | 395 | net_device_ctx->device_ctx = dev; |
| 408 | hv_set_drvdata(dev, net); | 396 | hv_set_drvdata(dev, net); |
| 409 | INIT_DELAYED_WORK(&net_device_ctx->dwork, netvsc_send_garp); | 397 | INIT_DELAYED_WORK(&net_device_ctx->dwork, netvsc_send_garp); |
| 398 | INIT_WORK(&net_device_ctx->work, do_set_multicast); | ||
| 410 | 399 | ||
| 411 | net->netdev_ops = &device_ops; | 400 | net->netdev_ops = &device_ops; |
| 412 | 401 | ||
| @@ -460,6 +449,7 @@ static int netvsc_remove(struct hv_device *dev) | |||
| 460 | 449 | ||
| 461 | ndev_ctx = netdev_priv(net); | 450 | ndev_ctx = netdev_priv(net); |
| 462 | cancel_delayed_work_sync(&ndev_ctx->dwork); | 451 | cancel_delayed_work_sync(&ndev_ctx->dwork); |
| 452 | cancel_work_sync(&ndev_ctx->work); | ||
| 463 | 453 | ||
| 464 | /* Stop outbound asap */ | 454 | /* Stop outbound asap */ |
| 465 | netif_tx_disable(net); | 455 | netif_tx_disable(net); |
diff --git a/drivers/net/phy/icplus.c b/drivers/net/phy/icplus.c index f08c85acf761..5ac46f5226f3 100644 --- a/drivers/net/phy/icplus.c +++ b/drivers/net/phy/icplus.c | |||
| @@ -40,6 +40,7 @@ MODULE_LICENSE("GPL"); | |||
| 40 | #define IP1001_PHASE_SEL_MASK 3 /* IP1001 RX/TXPHASE_SEL */ | 40 | #define IP1001_PHASE_SEL_MASK 3 /* IP1001 RX/TXPHASE_SEL */ |
| 41 | #define IP1001_APS_ON 11 /* IP1001 APS Mode bit */ | 41 | #define IP1001_APS_ON 11 /* IP1001 APS Mode bit */ |
| 42 | #define IP101A_G_APS_ON 2 /* IP101A/G APS Mode bit */ | 42 | #define IP101A_G_APS_ON 2 /* IP101A/G APS Mode bit */ |
| 43 | #define IP101A_G_IRQ_CONF_STATUS 0x11 /* Conf Info IRQ & Status Reg */ | ||
| 43 | 44 | ||
| 44 | static int ip175c_config_init(struct phy_device *phydev) | 45 | static int ip175c_config_init(struct phy_device *phydev) |
| 45 | { | 46 | { |
| @@ -185,6 +186,15 @@ static int ip175c_config_aneg(struct phy_device *phydev) | |||
| 185 | return 0; | 186 | return 0; |
| 186 | } | 187 | } |
| 187 | 188 | ||
| 189 | static int ip101a_g_ack_interrupt(struct phy_device *phydev) | ||
| 190 | { | ||
| 191 | int err = phy_read(phydev, IP101A_G_IRQ_CONF_STATUS); | ||
| 192 | if (err < 0) | ||
| 193 | return err; | ||
| 194 | |||
| 195 | return 0; | ||
| 196 | } | ||
| 197 | |||
| 188 | static struct phy_driver ip175c_driver = { | 198 | static struct phy_driver ip175c_driver = { |
| 189 | .phy_id = 0x02430d80, | 199 | .phy_id = 0x02430d80, |
| 190 | .name = "ICPlus IP175C", | 200 | .name = "ICPlus IP175C", |
| @@ -204,7 +214,6 @@ static struct phy_driver ip1001_driver = { | |||
| 204 | .phy_id_mask = 0x0ffffff0, | 214 | .phy_id_mask = 0x0ffffff0, |
| 205 | .features = PHY_GBIT_FEATURES | SUPPORTED_Pause | | 215 | .features = PHY_GBIT_FEATURES | SUPPORTED_Pause | |
| 206 | SUPPORTED_Asym_Pause, | 216 | SUPPORTED_Asym_Pause, |
| 207 | .flags = PHY_HAS_INTERRUPT, | ||
| 208 | .config_init = &ip1001_config_init, | 217 | .config_init = &ip1001_config_init, |
| 209 | .config_aneg = &genphy_config_aneg, | 218 | .config_aneg = &genphy_config_aneg, |
| 210 | .read_status = &genphy_read_status, | 219 | .read_status = &genphy_read_status, |
| @@ -220,6 +229,7 @@ static struct phy_driver ip101a_g_driver = { | |||
| 220 | .features = PHY_BASIC_FEATURES | SUPPORTED_Pause | | 229 | .features = PHY_BASIC_FEATURES | SUPPORTED_Pause | |
| 221 | SUPPORTED_Asym_Pause, | 230 | SUPPORTED_Asym_Pause, |
| 222 | .flags = PHY_HAS_INTERRUPT, | 231 | .flags = PHY_HAS_INTERRUPT, |
| 232 | .ack_interrupt = ip101a_g_ack_interrupt, | ||
| 223 | .config_init = &ip101a_g_config_init, | 233 | .config_init = &ip101a_g_config_init, |
| 224 | .config_aneg = &genphy_config_aneg, | 234 | .config_aneg = &genphy_config_aneg, |
| 225 | .read_status = &genphy_read_status, | 235 | .read_status = &genphy_read_status, |
diff --git a/drivers/net/usb/qmi_wwan.c b/drivers/net/usb/qmi_wwan.c index 552d24bf862e..d316503b35d4 100644 --- a/drivers/net/usb/qmi_wwan.c +++ b/drivers/net/usb/qmi_wwan.c | |||
| @@ -365,6 +365,27 @@ static const struct driver_info qmi_wwan_force_int4 = { | |||
| 365 | .data = BIT(4), /* interface whitelist bitmap */ | 365 | .data = BIT(4), /* interface whitelist bitmap */ |
| 366 | }; | 366 | }; |
| 367 | 367 | ||
| 368 | /* Sierra Wireless provide equally useless interface descriptors | ||
| 369 | * Devices in QMI mode can be switched between two different | ||
| 370 | * configurations: | ||
| 371 | * a) USB interface #8 is QMI/wwan | ||
| 372 | * b) USB interfaces #8, #19 and #20 are QMI/wwan | ||
| 373 | * | ||
| 374 | * Both configurations provide a number of other interfaces (serial++), | ||
| 375 | * some of which have the same endpoint configuration as we expect, so | ||
| 376 | * a whitelist or blacklist is necessary. | ||
| 377 | * | ||
| 378 | * FIXME: The below whitelist should include BIT(20). It does not | ||
| 379 | * because I cannot get it to work... | ||
| 380 | */ | ||
| 381 | static const struct driver_info qmi_wwan_sierra = { | ||
| 382 | .description = "Sierra Wireless wwan/QMI device", | ||
| 383 | .flags = FLAG_WWAN, | ||
| 384 | .bind = qmi_wwan_bind_gobi, | ||
| 385 | .unbind = qmi_wwan_unbind_shared, | ||
| 386 | .manage_power = qmi_wwan_manage_power, | ||
| 387 | .data = BIT(8) | BIT(19), /* interface whitelist bitmap */ | ||
| 388 | }; | ||
| 368 | 389 | ||
| 369 | #define HUAWEI_VENDOR_ID 0x12D1 | 390 | #define HUAWEI_VENDOR_ID 0x12D1 |
| 370 | #define QMI_GOBI_DEVICE(vend, prod) \ | 391 | #define QMI_GOBI_DEVICE(vend, prod) \ |
| @@ -445,6 +466,15 @@ static const struct usb_device_id products[] = { | |||
| 445 | .bInterfaceProtocol = 0xff, | 466 | .bInterfaceProtocol = 0xff, |
| 446 | .driver_info = (unsigned long)&qmi_wwan_force_int4, | 467 | .driver_info = (unsigned long)&qmi_wwan_force_int4, |
| 447 | }, | 468 | }, |
| 469 | { /* Sierra Wireless MC77xx in QMI mode */ | ||
| 470 | .match_flags = USB_DEVICE_ID_MATCH_DEVICE | USB_DEVICE_ID_MATCH_INT_INFO, | ||
| 471 | .idVendor = 0x1199, | ||
| 472 | .idProduct = 0x68a2, | ||
| 473 | .bInterfaceClass = 0xff, | ||
| 474 | .bInterfaceSubClass = 0xff, | ||
| 475 | .bInterfaceProtocol = 0xff, | ||
| 476 | .driver_info = (unsigned long)&qmi_wwan_sierra, | ||
| 477 | }, | ||
| 448 | {QMI_GOBI_DEVICE(0x05c6, 0x9212)}, /* Acer Gobi Modem Device */ | 478 | {QMI_GOBI_DEVICE(0x05c6, 0x9212)}, /* Acer Gobi Modem Device */ |
| 449 | {QMI_GOBI_DEVICE(0x03f0, 0x1f1d)}, /* HP un2400 Gobi Modem Device */ | 479 | {QMI_GOBI_DEVICE(0x03f0, 0x1f1d)}, /* HP un2400 Gobi Modem Device */ |
| 450 | {QMI_GOBI_DEVICE(0x03f0, 0x371d)}, /* HP un2430 Mobile Broadband Module */ | 480 | {QMI_GOBI_DEVICE(0x03f0, 0x371d)}, /* HP un2430 Mobile Broadband Module */ |
diff --git a/drivers/net/usb/smsc75xx.c b/drivers/net/usb/smsc75xx.c index 187d01ccb973..a2349483cd2a 100644 --- a/drivers/net/usb/smsc75xx.c +++ b/drivers/net/usb/smsc75xx.c | |||
| @@ -1051,6 +1051,7 @@ static int smsc75xx_bind(struct usbnet *dev, struct usb_interface *intf) | |||
| 1051 | dev->net->ethtool_ops = &smsc75xx_ethtool_ops; | 1051 | dev->net->ethtool_ops = &smsc75xx_ethtool_ops; |
| 1052 | dev->net->flags |= IFF_MULTICAST; | 1052 | dev->net->flags |= IFF_MULTICAST; |
| 1053 | dev->net->hard_header_len += SMSC75XX_TX_OVERHEAD; | 1053 | dev->net->hard_header_len += SMSC75XX_TX_OVERHEAD; |
| 1054 | dev->hard_mtu = dev->net->mtu + dev->net->hard_header_len; | ||
| 1054 | return 0; | 1055 | return 0; |
| 1055 | } | 1056 | } |
| 1056 | 1057 | ||
diff --git a/drivers/net/wan/farsync.c b/drivers/net/wan/farsync.c index ebb9f24eefb5..1a623183cbe5 100644 --- a/drivers/net/wan/farsync.c +++ b/drivers/net/wan/farsync.c | |||
| @@ -2483,6 +2483,7 @@ fst_add_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 2483 | pr_err("Control memory remap failed\n"); | 2483 | pr_err("Control memory remap failed\n"); |
| 2484 | pci_release_regions(pdev); | 2484 | pci_release_regions(pdev); |
| 2485 | pci_disable_device(pdev); | 2485 | pci_disable_device(pdev); |
| 2486 | iounmap(card->mem); | ||
| 2486 | kfree(card); | 2487 | kfree(card); |
| 2487 | return -ENODEV; | 2488 | return -ENODEV; |
| 2488 | } | 2489 | } |
diff --git a/drivers/net/wireless/ath/ath5k/ahb.c b/drivers/net/wireless/ath/ath5k/ahb.c index 8faa129da5a0..8c50d9d19d78 100644 --- a/drivers/net/wireless/ath/ath5k/ahb.c +++ b/drivers/net/wireless/ath/ath5k/ahb.c | |||
| @@ -19,6 +19,7 @@ | |||
| 19 | #include <linux/nl80211.h> | 19 | #include <linux/nl80211.h> |
| 20 | #include <linux/platform_device.h> | 20 | #include <linux/platform_device.h> |
| 21 | #include <linux/etherdevice.h> | 21 | #include <linux/etherdevice.h> |
| 22 | #include <linux/export.h> | ||
| 22 | #include <ar231x_platform.h> | 23 | #include <ar231x_platform.h> |
| 23 | #include "ath5k.h" | 24 | #include "ath5k.h" |
| 24 | #include "debug.h" | 25 | #include "debug.h" |
| @@ -119,7 +120,7 @@ static int ath_ahb_probe(struct platform_device *pdev) | |||
| 119 | if (res == NULL) { | 120 | if (res == NULL) { |
| 120 | dev_err(&pdev->dev, "no IRQ resource found\n"); | 121 | dev_err(&pdev->dev, "no IRQ resource found\n"); |
| 121 | ret = -ENXIO; | 122 | ret = -ENXIO; |
| 122 | goto err_out; | 123 | goto err_iounmap; |
| 123 | } | 124 | } |
| 124 | 125 | ||
| 125 | irq = res->start; | 126 | irq = res->start; |
| @@ -128,7 +129,7 @@ static int ath_ahb_probe(struct platform_device *pdev) | |||
| 128 | if (hw == NULL) { | 129 | if (hw == NULL) { |
| 129 | dev_err(&pdev->dev, "no memory for ieee80211_hw\n"); | 130 | dev_err(&pdev->dev, "no memory for ieee80211_hw\n"); |
| 130 | ret = -ENOMEM; | 131 | ret = -ENOMEM; |
| 131 | goto err_out; | 132 | goto err_iounmap; |
| 132 | } | 133 | } |
| 133 | 134 | ||
| 134 | ah = hw->priv; | 135 | ah = hw->priv; |
| @@ -185,6 +186,8 @@ static int ath_ahb_probe(struct platform_device *pdev) | |||
| 185 | err_free_hw: | 186 | err_free_hw: |
| 186 | ieee80211_free_hw(hw); | 187 | ieee80211_free_hw(hw); |
| 187 | platform_set_drvdata(pdev, NULL); | 188 | platform_set_drvdata(pdev, NULL); |
| 189 | err_iounmap: | ||
| 190 | iounmap(mem); | ||
| 188 | err_out: | 191 | err_out: |
| 189 | return ret; | 192 | return ret; |
| 190 | } | 193 | } |
diff --git a/drivers/net/wireless/ath/ath9k/main.c b/drivers/net/wireless/ath/ath9k/main.c index 384e5c498440..d0a4b9b270c5 100644 --- a/drivers/net/wireless/ath/ath9k/main.c +++ b/drivers/net/wireless/ath/ath9k/main.c | |||
| @@ -1574,6 +1574,7 @@ static int ath9k_config(struct ieee80211_hw *hw, u32 changed) | |||
| 1574 | struct ath_hw *ah = sc->sc_ah; | 1574 | struct ath_hw *ah = sc->sc_ah; |
| 1575 | struct ath_common *common = ath9k_hw_common(ah); | 1575 | struct ath_common *common = ath9k_hw_common(ah); |
| 1576 | struct ieee80211_conf *conf = &hw->conf; | 1576 | struct ieee80211_conf *conf = &hw->conf; |
| 1577 | bool reset_channel = false; | ||
| 1577 | 1578 | ||
| 1578 | ath9k_ps_wakeup(sc); | 1579 | ath9k_ps_wakeup(sc); |
| 1579 | mutex_lock(&sc->mutex); | 1580 | mutex_lock(&sc->mutex); |
| @@ -1582,6 +1583,12 @@ static int ath9k_config(struct ieee80211_hw *hw, u32 changed) | |||
| 1582 | sc->ps_idle = !!(conf->flags & IEEE80211_CONF_IDLE); | 1583 | sc->ps_idle = !!(conf->flags & IEEE80211_CONF_IDLE); |
| 1583 | if (sc->ps_idle) | 1584 | if (sc->ps_idle) |
| 1584 | ath_cancel_work(sc); | 1585 | ath_cancel_work(sc); |
| 1586 | else | ||
| 1587 | /* | ||
| 1588 | * The chip needs a reset to properly wake up from | ||
| 1589 | * full sleep | ||
| 1590 | */ | ||
| 1591 | reset_channel = ah->chip_fullsleep; | ||
| 1585 | } | 1592 | } |
| 1586 | 1593 | ||
| 1587 | /* | 1594 | /* |
| @@ -1610,7 +1617,7 @@ static int ath9k_config(struct ieee80211_hw *hw, u32 changed) | |||
| 1610 | } | 1617 | } |
| 1611 | } | 1618 | } |
| 1612 | 1619 | ||
| 1613 | if (changed & IEEE80211_CONF_CHANGE_CHANNEL) { | 1620 | if ((changed & IEEE80211_CONF_CHANGE_CHANNEL) || reset_channel) { |
| 1614 | struct ieee80211_channel *curchan = hw->conf.channel; | 1621 | struct ieee80211_channel *curchan = hw->conf.channel; |
| 1615 | int pos = curchan->hw_value; | 1622 | int pos = curchan->hw_value; |
| 1616 | int old_pos = -1; | 1623 | int old_pos = -1; |
diff --git a/drivers/net/wireless/ath/ath9k/xmit.c b/drivers/net/wireless/ath/ath9k/xmit.c index 834e6bc45e8b..23eaa1b26ebe 100644 --- a/drivers/net/wireless/ath/ath9k/xmit.c +++ b/drivers/net/wireless/ath/ath9k/xmit.c | |||
| @@ -1820,6 +1820,7 @@ static struct ath_buf *ath_tx_setup_buffer(struct ath_softc *sc, | |||
| 1820 | struct ath_frame_info *fi = get_frame_info(skb); | 1820 | struct ath_frame_info *fi = get_frame_info(skb); |
| 1821 | struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data; | 1821 | struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data; |
| 1822 | struct ath_buf *bf; | 1822 | struct ath_buf *bf; |
| 1823 | int fragno; | ||
| 1823 | u16 seqno; | 1824 | u16 seqno; |
| 1824 | 1825 | ||
| 1825 | bf = ath_tx_get_buffer(sc); | 1826 | bf = ath_tx_get_buffer(sc); |
| @@ -1831,9 +1832,16 @@ static struct ath_buf *ath_tx_setup_buffer(struct ath_softc *sc, | |||
| 1831 | ATH_TXBUF_RESET(bf); | 1832 | ATH_TXBUF_RESET(bf); |
| 1832 | 1833 | ||
| 1833 | if (tid) { | 1834 | if (tid) { |
| 1835 | fragno = le16_to_cpu(hdr->seq_ctrl) & IEEE80211_SCTL_FRAG; | ||
| 1834 | seqno = tid->seq_next; | 1836 | seqno = tid->seq_next; |
| 1835 | hdr->seq_ctrl = cpu_to_le16(tid->seq_next << IEEE80211_SEQ_SEQ_SHIFT); | 1837 | hdr->seq_ctrl = cpu_to_le16(tid->seq_next << IEEE80211_SEQ_SEQ_SHIFT); |
| 1836 | INCR(tid->seq_next, IEEE80211_SEQ_MAX); | 1838 | |
| 1839 | if (fragno) | ||
| 1840 | hdr->seq_ctrl |= cpu_to_le16(fragno); | ||
| 1841 | |||
| 1842 | if (!ieee80211_has_morefrags(hdr->frame_control)) | ||
| 1843 | INCR(tid->seq_next, IEEE80211_SEQ_MAX); | ||
| 1844 | |||
| 1837 | bf->bf_state.seqno = seqno; | 1845 | bf->bf_state.seqno = seqno; |
| 1838 | } | 1846 | } |
| 1839 | 1847 | ||
diff --git a/drivers/net/wireless/brcm80211/brcmsmac/main.c b/drivers/net/wireless/brcm80211/brcmsmac/main.c index 231ddf4a674f..7083db75b00c 100644 --- a/drivers/net/wireless/brcm80211/brcmsmac/main.c +++ b/drivers/net/wireless/brcm80211/brcmsmac/main.c | |||
| @@ -7614,6 +7614,7 @@ brcms_c_recvctl(struct brcms_c_info *wlc, struct d11rxhdr *rxh, | |||
| 7614 | { | 7614 | { |
| 7615 | int len_mpdu; | 7615 | int len_mpdu; |
| 7616 | struct ieee80211_rx_status rx_status; | 7616 | struct ieee80211_rx_status rx_status; |
| 7617 | struct ieee80211_hdr *hdr; | ||
| 7617 | 7618 | ||
| 7618 | memset(&rx_status, 0, sizeof(rx_status)); | 7619 | memset(&rx_status, 0, sizeof(rx_status)); |
| 7619 | prep_mac80211_status(wlc, rxh, p, &rx_status); | 7620 | prep_mac80211_status(wlc, rxh, p, &rx_status); |
| @@ -7623,6 +7624,13 @@ brcms_c_recvctl(struct brcms_c_info *wlc, struct d11rxhdr *rxh, | |||
| 7623 | skb_pull(p, D11_PHY_HDR_LEN); | 7624 | skb_pull(p, D11_PHY_HDR_LEN); |
| 7624 | __skb_trim(p, len_mpdu); | 7625 | __skb_trim(p, len_mpdu); |
| 7625 | 7626 | ||
| 7627 | /* unmute transmit */ | ||
| 7628 | if (wlc->hw->suspended_fifos) { | ||
| 7629 | hdr = (struct ieee80211_hdr *)p->data; | ||
| 7630 | if (ieee80211_is_beacon(hdr->frame_control)) | ||
| 7631 | brcms_b_mute(wlc->hw, false); | ||
| 7632 | } | ||
| 7633 | |||
| 7626 | memcpy(IEEE80211_SKB_RXCB(p), &rx_status, sizeof(rx_status)); | 7634 | memcpy(IEEE80211_SKB_RXCB(p), &rx_status, sizeof(rx_status)); |
| 7627 | ieee80211_rx_irqsafe(wlc->pub->ieee_hw, p); | 7635 | ieee80211_rx_irqsafe(wlc->pub->ieee_hw, p); |
| 7628 | } | 7636 | } |
diff --git a/drivers/net/wireless/libertas/cfg.c b/drivers/net/wireless/libertas/cfg.c index 3fa1ecebadfd..2fa879b015b6 100644 --- a/drivers/net/wireless/libertas/cfg.c +++ b/drivers/net/wireless/libertas/cfg.c | |||
| @@ -103,7 +103,7 @@ static const u32 cipher_suites[] = { | |||
| 103 | * Convert NL80211's auth_type to the one from Libertas, see chapter 5.9.1 | 103 | * Convert NL80211's auth_type to the one from Libertas, see chapter 5.9.1 |
| 104 | * in the firmware spec | 104 | * in the firmware spec |
| 105 | */ | 105 | */ |
| 106 | static u8 lbs_auth_to_authtype(enum nl80211_auth_type auth_type) | 106 | static int lbs_auth_to_authtype(enum nl80211_auth_type auth_type) |
| 107 | { | 107 | { |
| 108 | int ret = -ENOTSUPP; | 108 | int ret = -ENOTSUPP; |
| 109 | 109 | ||
| @@ -1411,7 +1411,12 @@ static int lbs_cfg_connect(struct wiphy *wiphy, struct net_device *dev, | |||
| 1411 | goto done; | 1411 | goto done; |
| 1412 | } | 1412 | } |
| 1413 | 1413 | ||
| 1414 | lbs_set_authtype(priv, sme); | 1414 | ret = lbs_set_authtype(priv, sme); |
| 1415 | if (ret == -ENOTSUPP) { | ||
| 1416 | wiphy_err(wiphy, "unsupported authtype 0x%x\n", sme->auth_type); | ||
| 1417 | goto done; | ||
| 1418 | } | ||
| 1419 | |||
| 1415 | lbs_set_radio(priv, preamble, 1); | 1420 | lbs_set_radio(priv, preamble, 1); |
| 1416 | 1421 | ||
| 1417 | /* Do the actual association */ | 1422 | /* Do the actual association */ |
diff --git a/drivers/net/wireless/mwifiex/pcie.h b/drivers/net/wireless/mwifiex/pcie.h index 445ff21772e2..2f218f9a3fd3 100644 --- a/drivers/net/wireless/mwifiex/pcie.h +++ b/drivers/net/wireless/mwifiex/pcie.h | |||
| @@ -48,15 +48,15 @@ | |||
| 48 | #define PCIE_HOST_INT_STATUS_MASK 0xC3C | 48 | #define PCIE_HOST_INT_STATUS_MASK 0xC3C |
| 49 | #define PCIE_SCRATCH_2_REG 0xC40 | 49 | #define PCIE_SCRATCH_2_REG 0xC40 |
| 50 | #define PCIE_SCRATCH_3_REG 0xC44 | 50 | #define PCIE_SCRATCH_3_REG 0xC44 |
| 51 | #define PCIE_SCRATCH_4_REG 0xCC0 | 51 | #define PCIE_SCRATCH_4_REG 0xCD0 |
| 52 | #define PCIE_SCRATCH_5_REG 0xCC4 | 52 | #define PCIE_SCRATCH_5_REG 0xCD4 |
| 53 | #define PCIE_SCRATCH_6_REG 0xCC8 | 53 | #define PCIE_SCRATCH_6_REG 0xCD8 |
| 54 | #define PCIE_SCRATCH_7_REG 0xCCC | 54 | #define PCIE_SCRATCH_7_REG 0xCDC |
| 55 | #define PCIE_SCRATCH_8_REG 0xCD0 | 55 | #define PCIE_SCRATCH_8_REG 0xCE0 |
| 56 | #define PCIE_SCRATCH_9_REG 0xCD4 | 56 | #define PCIE_SCRATCH_9_REG 0xCE4 |
| 57 | #define PCIE_SCRATCH_10_REG 0xCD8 | 57 | #define PCIE_SCRATCH_10_REG 0xCE8 |
| 58 | #define PCIE_SCRATCH_11_REG 0xCDC | 58 | #define PCIE_SCRATCH_11_REG 0xCEC |
| 59 | #define PCIE_SCRATCH_12_REG 0xCE0 | 59 | #define PCIE_SCRATCH_12_REG 0xCF0 |
| 60 | 60 | ||
| 61 | #define CPU_INTR_DNLD_RDY BIT(0) | 61 | #define CPU_INTR_DNLD_RDY BIT(0) |
| 62 | #define CPU_INTR_DOOR_BELL BIT(1) | 62 | #define CPU_INTR_DOOR_BELL BIT(1) |
diff --git a/drivers/of/gpio.c b/drivers/of/gpio.c index bba81216b4db..bf984b6dc477 100644 --- a/drivers/of/gpio.c +++ b/drivers/of/gpio.c | |||
| @@ -140,7 +140,7 @@ int of_gpio_simple_xlate(struct gpio_chip *gc, | |||
| 140 | if (WARN_ON(gpiospec->args_count < gc->of_gpio_n_cells)) | 140 | if (WARN_ON(gpiospec->args_count < gc->of_gpio_n_cells)) |
| 141 | return -EINVAL; | 141 | return -EINVAL; |
| 142 | 142 | ||
| 143 | if (gpiospec->args[0] > gc->ngpio) | 143 | if (gpiospec->args[0] >= gc->ngpio) |
| 144 | return -EINVAL; | 144 | return -EINVAL; |
| 145 | 145 | ||
| 146 | if (flags) | 146 | if (flags) |
diff --git a/drivers/pci/pci.c b/drivers/pci/pci.c index 815674415267..111569ccab43 100644 --- a/drivers/pci/pci.c +++ b/drivers/pci/pci.c | |||
| @@ -967,16 +967,59 @@ pci_save_state(struct pci_dev *dev) | |||
| 967 | return 0; | 967 | return 0; |
| 968 | } | 968 | } |
| 969 | 969 | ||
| 970 | static void pci_restore_config_dword(struct pci_dev *pdev, int offset, | ||
| 971 | u32 saved_val, int retry) | ||
| 972 | { | ||
| 973 | u32 val; | ||
| 974 | |||
| 975 | pci_read_config_dword(pdev, offset, &val); | ||
| 976 | if (val == saved_val) | ||
| 977 | return; | ||
| 978 | |||
| 979 | for (;;) { | ||
| 980 | dev_dbg(&pdev->dev, "restoring config space at offset " | ||
| 981 | "%#x (was %#x, writing %#x)\n", offset, val, saved_val); | ||
| 982 | pci_write_config_dword(pdev, offset, saved_val); | ||
| 983 | if (retry-- <= 0) | ||
| 984 | return; | ||
| 985 | |||
| 986 | pci_read_config_dword(pdev, offset, &val); | ||
| 987 | if (val == saved_val) | ||
| 988 | return; | ||
| 989 | |||
| 990 | mdelay(1); | ||
| 991 | } | ||
| 992 | } | ||
| 993 | |||
| 994 | static void pci_restore_config_space_range(struct pci_dev *pdev, | ||
| 995 | int start, int end, int retry) | ||
| 996 | { | ||
| 997 | int index; | ||
| 998 | |||
| 999 | for (index = end; index >= start; index--) | ||
| 1000 | pci_restore_config_dword(pdev, 4 * index, | ||
| 1001 | pdev->saved_config_space[index], | ||
| 1002 | retry); | ||
| 1003 | } | ||
| 1004 | |||
| 1005 | static void pci_restore_config_space(struct pci_dev *pdev) | ||
| 1006 | { | ||
| 1007 | if (pdev->hdr_type == PCI_HEADER_TYPE_NORMAL) { | ||
| 1008 | pci_restore_config_space_range(pdev, 10, 15, 0); | ||
| 1009 | /* Restore BARs before the command register. */ | ||
| 1010 | pci_restore_config_space_range(pdev, 4, 9, 10); | ||
| 1011 | pci_restore_config_space_range(pdev, 0, 3, 0); | ||
| 1012 | } else { | ||
| 1013 | pci_restore_config_space_range(pdev, 0, 15, 0); | ||
| 1014 | } | ||
| 1015 | } | ||
| 1016 | |||
| 970 | /** | 1017 | /** |
| 971 | * pci_restore_state - Restore the saved state of a PCI device | 1018 | * pci_restore_state - Restore the saved state of a PCI device |
| 972 | * @dev: - PCI device that we're dealing with | 1019 | * @dev: - PCI device that we're dealing with |
| 973 | */ | 1020 | */ |
| 974 | void pci_restore_state(struct pci_dev *dev) | 1021 | void pci_restore_state(struct pci_dev *dev) |
| 975 | { | 1022 | { |
| 976 | int i; | ||
| 977 | u32 val; | ||
| 978 | int tries; | ||
| 979 | |||
| 980 | if (!dev->state_saved) | 1023 | if (!dev->state_saved) |
| 981 | return; | 1024 | return; |
| 982 | 1025 | ||
| @@ -984,24 +1027,8 @@ void pci_restore_state(struct pci_dev *dev) | |||
| 984 | pci_restore_pcie_state(dev); | 1027 | pci_restore_pcie_state(dev); |
| 985 | pci_restore_ats_state(dev); | 1028 | pci_restore_ats_state(dev); |
| 986 | 1029 | ||
| 987 | /* | 1030 | pci_restore_config_space(dev); |
| 988 | * The Base Address register should be programmed before the command | 1031 | |
| 989 | * register(s) | ||
| 990 | */ | ||
| 991 | for (i = 15; i >= 0; i--) { | ||
| 992 | pci_read_config_dword(dev, i * 4, &val); | ||
| 993 | tries = 10; | ||
| 994 | while (tries && val != dev->saved_config_space[i]) { | ||
| 995 | dev_dbg(&dev->dev, "restoring config " | ||
| 996 | "space at offset %#x (was %#x, writing %#x)\n", | ||
| 997 | i, val, (int)dev->saved_config_space[i]); | ||
| 998 | pci_write_config_dword(dev,i * 4, | ||
| 999 | dev->saved_config_space[i]); | ||
| 1000 | pci_read_config_dword(dev, i * 4, &val); | ||
| 1001 | mdelay(10); | ||
| 1002 | tries--; | ||
| 1003 | } | ||
| 1004 | } | ||
| 1005 | pci_restore_pcix_state(dev); | 1032 | pci_restore_pcix_state(dev); |
| 1006 | pci_restore_msi_state(dev); | 1033 | pci_restore_msi_state(dev); |
| 1007 | pci_restore_iov_state(dev); | 1034 | pci_restore_iov_state(dev); |
diff --git a/drivers/pinctrl/core.c b/drivers/pinctrl/core.c index ec3b8cc188af..df6296c5f47b 100644 --- a/drivers/pinctrl/core.c +++ b/drivers/pinctrl/core.c | |||
| @@ -908,10 +908,6 @@ static int pinctrl_groups_show(struct seq_file *s, void *what) | |||
| 908 | const struct pinctrl_ops *ops = pctldev->desc->pctlops; | 908 | const struct pinctrl_ops *ops = pctldev->desc->pctlops; |
| 909 | unsigned selector = 0; | 909 | unsigned selector = 0; |
| 910 | 910 | ||
| 911 | /* No grouping */ | ||
| 912 | if (!ops) | ||
| 913 | return 0; | ||
| 914 | |||
| 915 | mutex_lock(&pinctrl_mutex); | 911 | mutex_lock(&pinctrl_mutex); |
| 916 | 912 | ||
| 917 | seq_puts(s, "registered pin groups:\n"); | 913 | seq_puts(s, "registered pin groups:\n"); |
| @@ -1225,6 +1221,19 @@ static void pinctrl_remove_device_debugfs(struct pinctrl_dev *pctldev) | |||
| 1225 | 1221 | ||
| 1226 | #endif | 1222 | #endif |
| 1227 | 1223 | ||
| 1224 | static int pinctrl_check_ops(struct pinctrl_dev *pctldev) | ||
| 1225 | { | ||
| 1226 | const struct pinctrl_ops *ops = pctldev->desc->pctlops; | ||
| 1227 | |||
| 1228 | if (!ops || | ||
| 1229 | !ops->list_groups || | ||
| 1230 | !ops->get_group_name || | ||
| 1231 | !ops->get_group_pins) | ||
| 1232 | return -EINVAL; | ||
| 1233 | |||
| 1234 | return 0; | ||
| 1235 | } | ||
| 1236 | |||
| 1228 | /** | 1237 | /** |
| 1229 | * pinctrl_register() - register a pin controller device | 1238 | * pinctrl_register() - register a pin controller device |
| 1230 | * @pctldesc: descriptor for this pin controller | 1239 | * @pctldesc: descriptor for this pin controller |
| @@ -1256,6 +1265,14 @@ struct pinctrl_dev *pinctrl_register(struct pinctrl_desc *pctldesc, | |||
| 1256 | INIT_LIST_HEAD(&pctldev->gpio_ranges); | 1265 | INIT_LIST_HEAD(&pctldev->gpio_ranges); |
| 1257 | pctldev->dev = dev; | 1266 | pctldev->dev = dev; |
| 1258 | 1267 | ||
| 1268 | /* check core ops for sanity */ | ||
| 1269 | ret = pinctrl_check_ops(pctldev); | ||
| 1270 | if (ret) { | ||
| 1271 | pr_err("%s pinctrl ops lacks necessary functions\n", | ||
| 1272 | pctldesc->name); | ||
| 1273 | goto out_err; | ||
| 1274 | } | ||
| 1275 | |||
| 1259 | /* If we're implementing pinmuxing, check the ops for sanity */ | 1276 | /* If we're implementing pinmuxing, check the ops for sanity */ |
| 1260 | if (pctldesc->pmxops) { | 1277 | if (pctldesc->pmxops) { |
| 1261 | ret = pinmux_check_ops(pctldev); | 1278 | ret = pinmux_check_ops(pctldev); |
diff --git a/drivers/s390/block/dasd_eckd.c b/drivers/s390/block/dasd_eckd.c index c21871a4e73d..bc2e8a7c265b 100644 --- a/drivers/s390/block/dasd_eckd.c +++ b/drivers/s390/block/dasd_eckd.c | |||
| @@ -2844,6 +2844,7 @@ static struct dasd_ccw_req *dasd_eckd_build_cp_tpm_track( | |||
| 2844 | sector_t recid, trkid; | 2844 | sector_t recid, trkid; |
| 2845 | unsigned int offs; | 2845 | unsigned int offs; |
| 2846 | unsigned int count, count_to_trk_end; | 2846 | unsigned int count, count_to_trk_end; |
| 2847 | int ret; | ||
| 2847 | 2848 | ||
| 2848 | basedev = block->base; | 2849 | basedev = block->base; |
| 2849 | if (rq_data_dir(req) == READ) { | 2850 | if (rq_data_dir(req) == READ) { |
| @@ -2884,8 +2885,8 @@ static struct dasd_ccw_req *dasd_eckd_build_cp_tpm_track( | |||
| 2884 | 2885 | ||
| 2885 | itcw = itcw_init(cqr->data, itcw_size, itcw_op, 0, ctidaw, 0); | 2886 | itcw = itcw_init(cqr->data, itcw_size, itcw_op, 0, ctidaw, 0); |
| 2886 | if (IS_ERR(itcw)) { | 2887 | if (IS_ERR(itcw)) { |
| 2887 | dasd_sfree_request(cqr, startdev); | 2888 | ret = -EINVAL; |
| 2888 | return ERR_PTR(-EINVAL); | 2889 | goto out_error; |
| 2889 | } | 2890 | } |
| 2890 | cqr->cpaddr = itcw_get_tcw(itcw); | 2891 | cqr->cpaddr = itcw_get_tcw(itcw); |
| 2891 | if (prepare_itcw(itcw, first_trk, last_trk, | 2892 | if (prepare_itcw(itcw, first_trk, last_trk, |
| @@ -2897,8 +2898,8 @@ static struct dasd_ccw_req *dasd_eckd_build_cp_tpm_track( | |||
| 2897 | /* Clock not in sync and XRC is enabled. | 2898 | /* Clock not in sync and XRC is enabled. |
| 2898 | * Try again later. | 2899 | * Try again later. |
| 2899 | */ | 2900 | */ |
| 2900 | dasd_sfree_request(cqr, startdev); | 2901 | ret = -EAGAIN; |
| 2901 | return ERR_PTR(-EAGAIN); | 2902 | goto out_error; |
| 2902 | } | 2903 | } |
| 2903 | len_to_track_end = 0; | 2904 | len_to_track_end = 0; |
| 2904 | /* | 2905 | /* |
| @@ -2937,8 +2938,10 @@ static struct dasd_ccw_req *dasd_eckd_build_cp_tpm_track( | |||
| 2937 | tidaw_flags = 0; | 2938 | tidaw_flags = 0; |
| 2938 | last_tidaw = itcw_add_tidaw(itcw, tidaw_flags, | 2939 | last_tidaw = itcw_add_tidaw(itcw, tidaw_flags, |
| 2939 | dst, part_len); | 2940 | dst, part_len); |
| 2940 | if (IS_ERR(last_tidaw)) | 2941 | if (IS_ERR(last_tidaw)) { |
| 2941 | return ERR_PTR(-EINVAL); | 2942 | ret = -EINVAL; |
| 2943 | goto out_error; | ||
| 2944 | } | ||
| 2942 | dst += part_len; | 2945 | dst += part_len; |
| 2943 | } | 2946 | } |
| 2944 | } | 2947 | } |
| @@ -2947,8 +2950,10 @@ static struct dasd_ccw_req *dasd_eckd_build_cp_tpm_track( | |||
| 2947 | dst = page_address(bv->bv_page) + bv->bv_offset; | 2950 | dst = page_address(bv->bv_page) + bv->bv_offset; |
| 2948 | last_tidaw = itcw_add_tidaw(itcw, 0x00, | 2951 | last_tidaw = itcw_add_tidaw(itcw, 0x00, |
| 2949 | dst, bv->bv_len); | 2952 | dst, bv->bv_len); |
| 2950 | if (IS_ERR(last_tidaw)) | 2953 | if (IS_ERR(last_tidaw)) { |
| 2951 | return ERR_PTR(-EINVAL); | 2954 | ret = -EINVAL; |
| 2955 | goto out_error; | ||
| 2956 | } | ||
| 2952 | } | 2957 | } |
| 2953 | } | 2958 | } |
| 2954 | last_tidaw->flags |= TIDAW_FLAGS_LAST; | 2959 | last_tidaw->flags |= TIDAW_FLAGS_LAST; |
| @@ -2968,6 +2973,9 @@ static struct dasd_ccw_req *dasd_eckd_build_cp_tpm_track( | |||
| 2968 | cqr->buildclk = get_clock(); | 2973 | cqr->buildclk = get_clock(); |
| 2969 | cqr->status = DASD_CQR_FILLED; | 2974 | cqr->status = DASD_CQR_FILLED; |
| 2970 | return cqr; | 2975 | return cqr; |
| 2976 | out_error: | ||
| 2977 | dasd_sfree_request(cqr, startdev); | ||
| 2978 | return ERR_PTR(ret); | ||
| 2971 | } | 2979 | } |
| 2972 | 2980 | ||
| 2973 | static struct dasd_ccw_req *dasd_eckd_build_cp(struct dasd_device *startdev, | 2981 | static struct dasd_ccw_req *dasd_eckd_build_cp(struct dasd_device *startdev, |
diff --git a/drivers/s390/char/vmur.c b/drivers/s390/char/vmur.c index 85f4a9a5d12e..73bef0bd394c 100644 --- a/drivers/s390/char/vmur.c +++ b/drivers/s390/char/vmur.c | |||
| @@ -903,7 +903,7 @@ static int ur_set_online(struct ccw_device *cdev) | |||
| 903 | goto fail_urdev_put; | 903 | goto fail_urdev_put; |
| 904 | } | 904 | } |
| 905 | 905 | ||
| 906 | cdev_init(urd->char_device, &ur_fops); | 906 | urd->char_device->ops = &ur_fops; |
| 907 | urd->char_device->dev = MKDEV(major, minor); | 907 | urd->char_device->dev = MKDEV(major, minor); |
| 908 | urd->char_device->owner = ur_fops.owner; | 908 | urd->char_device->owner = ur_fops.owner; |
| 909 | 909 | ||
diff --git a/drivers/scsi/scsi_error.c b/drivers/scsi/scsi_error.c index 2cfcbffa41fd..386f0c53bea7 100644 --- a/drivers/scsi/scsi_error.c +++ b/drivers/scsi/scsi_error.c | |||
| @@ -835,7 +835,7 @@ static int scsi_send_eh_cmnd(struct scsi_cmnd *scmd, unsigned char *cmnd, | |||
| 835 | 835 | ||
| 836 | scsi_eh_restore_cmnd(scmd, &ses); | 836 | scsi_eh_restore_cmnd(scmd, &ses); |
| 837 | 837 | ||
| 838 | if (sdrv->eh_action) | 838 | if (sdrv && sdrv->eh_action) |
| 839 | rtn = sdrv->eh_action(scmd, cmnd, cmnd_size, rtn); | 839 | rtn = sdrv->eh_action(scmd, cmnd, cmnd_size, rtn); |
| 840 | 840 | ||
| 841 | return rtn; | 841 | return rtn; |
diff --git a/drivers/spi/spi-davinci.c b/drivers/spi/spi-davinci.c index 31bfba805cf4..9b2901feaf78 100644 --- a/drivers/spi/spi-davinci.c +++ b/drivers/spi/spi-davinci.c | |||
| @@ -653,7 +653,7 @@ static int davinci_spi_bufs(struct spi_device *spi, struct spi_transfer *t) | |||
| 653 | dev_dbg(sdev, "Couldn't DMA map a %d bytes RX buffer\n", | 653 | dev_dbg(sdev, "Couldn't DMA map a %d bytes RX buffer\n", |
| 654 | rx_buf_count); | 654 | rx_buf_count); |
| 655 | if (t->tx_buf) | 655 | if (t->tx_buf) |
| 656 | dma_unmap_single(NULL, t->tx_dma, t->len, | 656 | dma_unmap_single(&spi->dev, t->tx_dma, t->len, |
| 657 | DMA_TO_DEVICE); | 657 | DMA_TO_DEVICE); |
| 658 | return -ENOMEM; | 658 | return -ENOMEM; |
| 659 | } | 659 | } |
| @@ -692,10 +692,10 @@ static int davinci_spi_bufs(struct spi_device *spi, struct spi_transfer *t) | |||
| 692 | if (spicfg->io_type == SPI_IO_TYPE_DMA) { | 692 | if (spicfg->io_type == SPI_IO_TYPE_DMA) { |
| 693 | 693 | ||
| 694 | if (t->tx_buf) | 694 | if (t->tx_buf) |
| 695 | dma_unmap_single(NULL, t->tx_dma, t->len, | 695 | dma_unmap_single(&spi->dev, t->tx_dma, t->len, |
| 696 | DMA_TO_DEVICE); | 696 | DMA_TO_DEVICE); |
| 697 | 697 | ||
| 698 | dma_unmap_single(NULL, t->rx_dma, rx_buf_count, | 698 | dma_unmap_single(&spi->dev, t->rx_dma, rx_buf_count, |
| 699 | DMA_FROM_DEVICE); | 699 | DMA_FROM_DEVICE); |
| 700 | 700 | ||
| 701 | clear_io_bits(dspi->base + SPIINT, SPIINT_DMA_REQ_EN); | 701 | clear_io_bits(dspi->base + SPIINT, SPIINT_DMA_REQ_EN); |
diff --git a/drivers/spi/spi-fsl-spi.c b/drivers/spi/spi-fsl-spi.c index 24cacff57786..5f748c0d96bd 100644 --- a/drivers/spi/spi-fsl-spi.c +++ b/drivers/spi/spi-fsl-spi.c | |||
| @@ -139,10 +139,12 @@ static void fsl_spi_change_mode(struct spi_device *spi) | |||
| 139 | static void fsl_spi_chipselect(struct spi_device *spi, int value) | 139 | static void fsl_spi_chipselect(struct spi_device *spi, int value) |
| 140 | { | 140 | { |
| 141 | struct mpc8xxx_spi *mpc8xxx_spi = spi_master_get_devdata(spi->master); | 141 | struct mpc8xxx_spi *mpc8xxx_spi = spi_master_get_devdata(spi->master); |
| 142 | struct fsl_spi_platform_data *pdata = spi->dev.parent->platform_data; | 142 | struct fsl_spi_platform_data *pdata; |
| 143 | bool pol = spi->mode & SPI_CS_HIGH; | 143 | bool pol = spi->mode & SPI_CS_HIGH; |
| 144 | struct spi_mpc8xxx_cs *cs = spi->controller_state; | 144 | struct spi_mpc8xxx_cs *cs = spi->controller_state; |
| 145 | 145 | ||
| 146 | pdata = spi->dev.parent->parent->platform_data; | ||
| 147 | |||
| 146 | if (value == BITBANG_CS_INACTIVE) { | 148 | if (value == BITBANG_CS_INACTIVE) { |
| 147 | if (pdata->cs_control) | 149 | if (pdata->cs_control) |
| 148 | pdata->cs_control(spi, !pol); | 150 | pdata->cs_control(spi, !pol); |
diff --git a/drivers/spi/spi-imx.c b/drivers/spi/spi-imx.c index 31054e3de4c1..570f22053be8 100644 --- a/drivers/spi/spi-imx.c +++ b/drivers/spi/spi-imx.c | |||
| @@ -83,7 +83,7 @@ struct spi_imx_data { | |||
| 83 | struct spi_bitbang bitbang; | 83 | struct spi_bitbang bitbang; |
| 84 | 84 | ||
| 85 | struct completion xfer_done; | 85 | struct completion xfer_done; |
| 86 | void *base; | 86 | void __iomem *base; |
| 87 | int irq; | 87 | int irq; |
| 88 | struct clk *clk; | 88 | struct clk *clk; |
| 89 | unsigned long spi_clk; | 89 | unsigned long spi_clk; |
| @@ -766,8 +766,12 @@ static int __devinit spi_imx_probe(struct platform_device *pdev) | |||
| 766 | } | 766 | } |
| 767 | 767 | ||
| 768 | ret = of_property_read_u32(np, "fsl,spi-num-chipselects", &num_cs); | 768 | ret = of_property_read_u32(np, "fsl,spi-num-chipselects", &num_cs); |
| 769 | if (ret < 0) | 769 | if (ret < 0) { |
| 770 | num_cs = mxc_platform_info->num_chipselect; | 770 | if (mxc_platform_info) |
| 771 | num_cs = mxc_platform_info->num_chipselect; | ||
| 772 | else | ||
| 773 | return ret; | ||
| 774 | } | ||
| 771 | 775 | ||
| 772 | master = spi_alloc_master(&pdev->dev, | 776 | master = spi_alloc_master(&pdev->dev, |
| 773 | sizeof(struct spi_imx_data) + sizeof(int) * num_cs); | 777 | sizeof(struct spi_imx_data) + sizeof(int) * num_cs); |
| @@ -784,7 +788,7 @@ static int __devinit spi_imx_probe(struct platform_device *pdev) | |||
| 784 | 788 | ||
| 785 | for (i = 0; i < master->num_chipselect; i++) { | 789 | for (i = 0; i < master->num_chipselect; i++) { |
| 786 | int cs_gpio = of_get_named_gpio(np, "cs-gpios", i); | 790 | int cs_gpio = of_get_named_gpio(np, "cs-gpios", i); |
| 787 | if (cs_gpio < 0) | 791 | if (cs_gpio < 0 && mxc_platform_info) |
| 788 | cs_gpio = mxc_platform_info->chipselect[i]; | 792 | cs_gpio = mxc_platform_info->chipselect[i]; |
| 789 | 793 | ||
| 790 | spi_imx->chipselect[i] = cs_gpio; | 794 | spi_imx->chipselect[i] = cs_gpio; |
diff --git a/drivers/spi/spi-pl022.c b/drivers/spi/spi-pl022.c index 96f0da66b185..09c925aaf320 100644 --- a/drivers/spi/spi-pl022.c +++ b/drivers/spi/spi-pl022.c | |||
| @@ -2195,7 +2195,6 @@ static int pl022_runtime_suspend(struct device *dev) | |||
| 2195 | struct pl022 *pl022 = dev_get_drvdata(dev); | 2195 | struct pl022 *pl022 = dev_get_drvdata(dev); |
| 2196 | 2196 | ||
| 2197 | clk_disable(pl022->clk); | 2197 | clk_disable(pl022->clk); |
| 2198 | amba_vcore_disable(pl022->adev); | ||
| 2199 | 2198 | ||
| 2200 | return 0; | 2199 | return 0; |
| 2201 | } | 2200 | } |
| @@ -2204,7 +2203,6 @@ static int pl022_runtime_resume(struct device *dev) | |||
| 2204 | { | 2203 | { |
| 2205 | struct pl022 *pl022 = dev_get_drvdata(dev); | 2204 | struct pl022 *pl022 = dev_get_drvdata(dev); |
| 2206 | 2205 | ||
| 2207 | amba_vcore_enable(pl022->adev); | ||
| 2208 | clk_enable(pl022->clk); | 2206 | clk_enable(pl022->clk); |
| 2209 | 2207 | ||
| 2210 | return 0; | 2208 | return 0; |
diff --git a/drivers/staging/android/Kconfig b/drivers/staging/android/Kconfig index 08a3b1133d29..eb1dee26bda3 100644 --- a/drivers/staging/android/Kconfig +++ b/drivers/staging/android/Kconfig | |||
| @@ -27,13 +27,14 @@ config ANDROID_LOGGER | |||
| 27 | 27 | ||
| 28 | config ANDROID_PERSISTENT_RAM | 28 | config ANDROID_PERSISTENT_RAM |
| 29 | bool | 29 | bool |
| 30 | depends on HAVE_MEMBLOCK | ||
| 30 | select REED_SOLOMON | 31 | select REED_SOLOMON |
| 31 | select REED_SOLOMON_ENC8 | 32 | select REED_SOLOMON_ENC8 |
| 32 | select REED_SOLOMON_DEC8 | 33 | select REED_SOLOMON_DEC8 |
| 33 | 34 | ||
| 34 | config ANDROID_RAM_CONSOLE | 35 | config ANDROID_RAM_CONSOLE |
| 35 | bool "Android RAM buffer console" | 36 | bool "Android RAM buffer console" |
| 36 | depends on !S390 && !UML | 37 | depends on !S390 && !UML && HAVE_MEMBLOCK |
| 37 | select ANDROID_PERSISTENT_RAM | 38 | select ANDROID_PERSISTENT_RAM |
| 38 | default n | 39 | default n |
| 39 | 40 | ||
diff --git a/drivers/staging/android/persistent_ram.c b/drivers/staging/android/persistent_ram.c index e08f2574e30a..8d8c1e33e0ff 100644 --- a/drivers/staging/android/persistent_ram.c +++ b/drivers/staging/android/persistent_ram.c | |||
| @@ -399,12 +399,12 @@ static __init | |||
| 399 | struct persistent_ram_zone *__persistent_ram_init(struct device *dev, bool ecc) | 399 | struct persistent_ram_zone *__persistent_ram_init(struct device *dev, bool ecc) |
| 400 | { | 400 | { |
| 401 | struct persistent_ram_zone *prz; | 401 | struct persistent_ram_zone *prz; |
| 402 | int ret; | 402 | int ret = -ENOMEM; |
| 403 | 403 | ||
| 404 | prz = kzalloc(sizeof(struct persistent_ram_zone), GFP_KERNEL); | 404 | prz = kzalloc(sizeof(struct persistent_ram_zone), GFP_KERNEL); |
| 405 | if (!prz) { | 405 | if (!prz) { |
| 406 | pr_err("persistent_ram: failed to allocate persistent ram zone\n"); | 406 | pr_err("persistent_ram: failed to allocate persistent ram zone\n"); |
| 407 | return ERR_PTR(-ENOMEM); | 407 | goto err; |
| 408 | } | 408 | } |
| 409 | 409 | ||
| 410 | INIT_LIST_HEAD(&prz->node); | 410 | INIT_LIST_HEAD(&prz->node); |
| @@ -412,13 +412,13 @@ struct persistent_ram_zone *__persistent_ram_init(struct device *dev, bool ecc) | |||
| 412 | ret = persistent_ram_buffer_init(dev_name(dev), prz); | 412 | ret = persistent_ram_buffer_init(dev_name(dev), prz); |
| 413 | if (ret) { | 413 | if (ret) { |
| 414 | pr_err("persistent_ram: failed to initialize buffer\n"); | 414 | pr_err("persistent_ram: failed to initialize buffer\n"); |
| 415 | return ERR_PTR(ret); | 415 | goto err; |
| 416 | } | 416 | } |
| 417 | 417 | ||
| 418 | prz->ecc = ecc; | 418 | prz->ecc = ecc; |
| 419 | ret = persistent_ram_init_ecc(prz, prz->buffer_size); | 419 | ret = persistent_ram_init_ecc(prz, prz->buffer_size); |
| 420 | if (ret) | 420 | if (ret) |
| 421 | return ERR_PTR(ret); | 421 | goto err; |
| 422 | 422 | ||
| 423 | if (prz->buffer->sig == PERSISTENT_RAM_SIG) { | 423 | if (prz->buffer->sig == PERSISTENT_RAM_SIG) { |
| 424 | if (buffer_size(prz) > prz->buffer_size || | 424 | if (buffer_size(prz) > prz->buffer_size || |
| @@ -442,6 +442,9 @@ struct persistent_ram_zone *__persistent_ram_init(struct device *dev, bool ecc) | |||
| 442 | atomic_set(&prz->buffer->size, 0); | 442 | atomic_set(&prz->buffer->size, 0); |
| 443 | 443 | ||
| 444 | return prz; | 444 | return prz; |
| 445 | err: | ||
| 446 | kfree(prz); | ||
| 447 | return ERR_PTR(ret); | ||
| 445 | } | 448 | } |
| 446 | 449 | ||
| 447 | struct persistent_ram_zone * __init | 450 | struct persistent_ram_zone * __init |
diff --git a/drivers/staging/android/timed_gpio.c b/drivers/staging/android/timed_gpio.c index bc723eff11af..45c522cbe784 100644 --- a/drivers/staging/android/timed_gpio.c +++ b/drivers/staging/android/timed_gpio.c | |||
| @@ -85,7 +85,7 @@ static int timed_gpio_probe(struct platform_device *pdev) | |||
| 85 | struct timed_gpio_platform_data *pdata = pdev->dev.platform_data; | 85 | struct timed_gpio_platform_data *pdata = pdev->dev.platform_data; |
| 86 | struct timed_gpio *cur_gpio; | 86 | struct timed_gpio *cur_gpio; |
| 87 | struct timed_gpio_data *gpio_data, *gpio_dat; | 87 | struct timed_gpio_data *gpio_data, *gpio_dat; |
| 88 | int i, j, ret = 0; | 88 | int i, ret; |
| 89 | 89 | ||
| 90 | if (!pdata) | 90 | if (!pdata) |
| 91 | return -EBUSY; | 91 | return -EBUSY; |
| @@ -108,18 +108,12 @@ static int timed_gpio_probe(struct platform_device *pdev) | |||
| 108 | gpio_dat->dev.get_time = gpio_get_time; | 108 | gpio_dat->dev.get_time = gpio_get_time; |
| 109 | gpio_dat->dev.enable = gpio_enable; | 109 | gpio_dat->dev.enable = gpio_enable; |
| 110 | ret = gpio_request(cur_gpio->gpio, cur_gpio->name); | 110 | ret = gpio_request(cur_gpio->gpio, cur_gpio->name); |
| 111 | if (ret >= 0) { | 111 | if (ret < 0) |
| 112 | ret = timed_output_dev_register(&gpio_dat->dev); | 112 | goto err_out; |
| 113 | if (ret < 0) | 113 | ret = timed_output_dev_register(&gpio_dat->dev); |
| 114 | gpio_free(cur_gpio->gpio); | ||
| 115 | } | ||
| 116 | if (ret < 0) { | 114 | if (ret < 0) { |
| 117 | for (j = 0; j < i; j++) { | 115 | gpio_free(cur_gpio->gpio); |
| 118 | timed_output_dev_unregister(&gpio_data[i].dev); | 116 | goto err_out; |
| 119 | gpio_free(gpio_data[i].gpio); | ||
| 120 | } | ||
| 121 | kfree(gpio_data); | ||
| 122 | return ret; | ||
| 123 | } | 117 | } |
| 124 | 118 | ||
| 125 | gpio_dat->gpio = cur_gpio->gpio; | 119 | gpio_dat->gpio = cur_gpio->gpio; |
| @@ -131,6 +125,15 @@ static int timed_gpio_probe(struct platform_device *pdev) | |||
| 131 | platform_set_drvdata(pdev, gpio_data); | 125 | platform_set_drvdata(pdev, gpio_data); |
| 132 | 126 | ||
| 133 | return 0; | 127 | return 0; |
| 128 | |||
| 129 | err_out: | ||
| 130 | while (--i >= 0) { | ||
| 131 | timed_output_dev_unregister(&gpio_data[i].dev); | ||
| 132 | gpio_free(gpio_data[i].gpio); | ||
| 133 | } | ||
| 134 | kfree(gpio_data); | ||
| 135 | |||
| 136 | return ret; | ||
| 134 | } | 137 | } |
| 135 | 138 | ||
| 136 | static int timed_gpio_remove(struct platform_device *pdev) | 139 | static int timed_gpio_remove(struct platform_device *pdev) |
diff --git a/drivers/staging/iio/inkern.c b/drivers/staging/iio/inkern.c index de2c8ea64965..ef07a02bf542 100644 --- a/drivers/staging/iio/inkern.c +++ b/drivers/staging/iio/inkern.c | |||
| @@ -82,6 +82,7 @@ int iio_map_array_unregister(struct iio_dev *indio_dev, | |||
| 82 | ret = -ENODEV; | 82 | ret = -ENODEV; |
| 83 | goto error_ret; | 83 | goto error_ret; |
| 84 | } | 84 | } |
| 85 | i++; | ||
| 85 | } | 86 | } |
| 86 | error_ret: | 87 | error_ret: |
| 87 | mutex_unlock(&iio_map_list_lock); | 88 | mutex_unlock(&iio_map_list_lock); |
diff --git a/drivers/staging/iio/magnetometer/ak8975.c b/drivers/staging/iio/magnetometer/ak8975.c index d5ddac3d8831..ebc2d0840caf 100644 --- a/drivers/staging/iio/magnetometer/ak8975.c +++ b/drivers/staging/iio/magnetometer/ak8975.c | |||
| @@ -108,7 +108,8 @@ static const int ak8975_index_to_reg[] = { | |||
| 108 | static int ak8975_write_data(struct i2c_client *client, | 108 | static int ak8975_write_data(struct i2c_client *client, |
| 109 | u8 reg, u8 val, u8 mask, u8 shift) | 109 | u8 reg, u8 val, u8 mask, u8 shift) |
| 110 | { | 110 | { |
| 111 | struct ak8975_data *data = i2c_get_clientdata(client); | 111 | struct iio_dev *indio_dev = i2c_get_clientdata(client); |
| 112 | struct ak8975_data *data = iio_priv(indio_dev); | ||
| 112 | u8 regval; | 113 | u8 regval; |
| 113 | int ret; | 114 | int ret; |
| 114 | 115 | ||
| @@ -159,7 +160,8 @@ static int ak8975_read_data(struct i2c_client *client, | |||
| 159 | */ | 160 | */ |
| 160 | static int ak8975_setup(struct i2c_client *client) | 161 | static int ak8975_setup(struct i2c_client *client) |
| 161 | { | 162 | { |
| 162 | struct ak8975_data *data = i2c_get_clientdata(client); | 163 | struct iio_dev *indio_dev = i2c_get_clientdata(client); |
| 164 | struct ak8975_data *data = iio_priv(indio_dev); | ||
| 163 | u8 device_id; | 165 | u8 device_id; |
| 164 | int ret; | 166 | int ret; |
| 165 | 167 | ||
| @@ -509,6 +511,7 @@ static int ak8975_probe(struct i2c_client *client, | |||
| 509 | goto exit_gpio; | 511 | goto exit_gpio; |
| 510 | } | 512 | } |
| 511 | data = iio_priv(indio_dev); | 513 | data = iio_priv(indio_dev); |
| 514 | i2c_set_clientdata(client, indio_dev); | ||
| 512 | /* Perform some basic start-of-day setup of the device. */ | 515 | /* Perform some basic start-of-day setup of the device. */ |
| 513 | err = ak8975_setup(client); | 516 | err = ak8975_setup(client); |
| 514 | if (err < 0) { | 517 | if (err < 0) { |
| @@ -516,7 +519,6 @@ static int ak8975_probe(struct i2c_client *client, | |||
| 516 | goto exit_free_iio; | 519 | goto exit_free_iio; |
| 517 | } | 520 | } |
| 518 | 521 | ||
| 519 | i2c_set_clientdata(client, indio_dev); | ||
| 520 | data->client = client; | 522 | data->client = client; |
| 521 | mutex_init(&data->lock); | 523 | mutex_init(&data->lock); |
| 522 | data->eoc_irq = client->irq; | 524 | data->eoc_irq = client->irq; |
diff --git a/drivers/staging/iio/magnetometer/hmc5843.c b/drivers/staging/iio/magnetometer/hmc5843.c index 91dd3da70cb4..e00b416c4d33 100644 --- a/drivers/staging/iio/magnetometer/hmc5843.c +++ b/drivers/staging/iio/magnetometer/hmc5843.c | |||
| @@ -521,7 +521,9 @@ static int hmc5843_detect(struct i2c_client *client, | |||
| 521 | /* Called when we have found a new HMC5843. */ | 521 | /* Called when we have found a new HMC5843. */ |
| 522 | static void hmc5843_init_client(struct i2c_client *client) | 522 | static void hmc5843_init_client(struct i2c_client *client) |
| 523 | { | 523 | { |
| 524 | struct hmc5843_data *data = i2c_get_clientdata(client); | 524 | struct iio_dev *indio_dev = i2c_get_clientdata(client); |
| 525 | struct hmc5843_data *data = iio_priv(indio_dev); | ||
| 526 | |||
| 525 | hmc5843_set_meas_conf(client, data->meas_conf); | 527 | hmc5843_set_meas_conf(client, data->meas_conf); |
| 526 | hmc5843_set_rate(client, data->rate); | 528 | hmc5843_set_rate(client, data->rate); |
| 527 | hmc5843_configure(client, data->operating_mode); | 529 | hmc5843_configure(client, data->operating_mode); |
diff --git a/drivers/staging/media/as102/as102_fw.c b/drivers/staging/media/as102/as102_fw.c index 43ebc43e6b9a..1075fb1df0d9 100644 --- a/drivers/staging/media/as102/as102_fw.c +++ b/drivers/staging/media/as102/as102_fw.c | |||
| @@ -165,7 +165,7 @@ error: | |||
| 165 | int as102_fw_upload(struct as10x_bus_adapter_t *bus_adap) | 165 | int as102_fw_upload(struct as10x_bus_adapter_t *bus_adap) |
| 166 | { | 166 | { |
| 167 | int errno = -EFAULT; | 167 | int errno = -EFAULT; |
| 168 | const struct firmware *firmware; | 168 | const struct firmware *firmware = NULL; |
| 169 | unsigned char *cmd_buf = NULL; | 169 | unsigned char *cmd_buf = NULL; |
| 170 | char *fw1, *fw2; | 170 | char *fw1, *fw2; |
| 171 | struct usb_device *dev = bus_adap->usb_dev; | 171 | struct usb_device *dev = bus_adap->usb_dev; |
diff --git a/drivers/staging/omapdrm/omap_drv.c b/drivers/staging/omapdrm/omap_drv.c index 3df5b4c58ecd..620b8d54223d 100644 --- a/drivers/staging/omapdrm/omap_drv.c +++ b/drivers/staging/omapdrm/omap_drv.c | |||
| @@ -803,9 +803,6 @@ static void pdev_shutdown(struct platform_device *device) | |||
| 803 | static int pdev_probe(struct platform_device *device) | 803 | static int pdev_probe(struct platform_device *device) |
| 804 | { | 804 | { |
| 805 | DBG("%s", device->name); | 805 | DBG("%s", device->name); |
| 806 | if (platform_driver_register(&omap_dmm_driver)) | ||
| 807 | dev_err(&device->dev, "DMM registration failed\n"); | ||
| 808 | |||
| 809 | return drm_platform_init(&omap_drm_driver, device); | 806 | return drm_platform_init(&omap_drm_driver, device); |
| 810 | } | 807 | } |
| 811 | 808 | ||
| @@ -833,6 +830,10 @@ struct platform_driver pdev = { | |||
| 833 | static int __init omap_drm_init(void) | 830 | static int __init omap_drm_init(void) |
| 834 | { | 831 | { |
| 835 | DBG("init"); | 832 | DBG("init"); |
| 833 | if (platform_driver_register(&omap_dmm_driver)) { | ||
| 834 | /* we can continue on without DMM.. so not fatal */ | ||
| 835 | dev_err(NULL, "DMM registration failed\n"); | ||
| 836 | } | ||
| 836 | return platform_driver_register(&pdev); | 837 | return platform_driver_register(&pdev); |
| 837 | } | 838 | } |
| 838 | 839 | ||
diff --git a/drivers/staging/ozwpan/TODO b/drivers/staging/ozwpan/TODO index f7a9c122f596..c2d30a7112f3 100644 --- a/drivers/staging/ozwpan/TODO +++ b/drivers/staging/ozwpan/TODO | |||
| @@ -8,5 +8,7 @@ TODO: | |||
| 8 | - code review by USB developer community. | 8 | - code review by USB developer community. |
| 9 | - testing with as many devices as possible. | 9 | - testing with as many devices as possible. |
| 10 | 10 | ||
| 11 | Please send any patches for this driver to Chris Kelly <ckelly@ozmodevices.com> | 11 | Please send any patches for this driver to |
| 12 | Rupesh Gujare <rgujare@ozmodevices.com> | ||
| 13 | Chris Kelly <ckelly@ozmodevices.com> | ||
| 12 | and Greg Kroah-Hartman <gregkh@linuxfoundation.org>. | 14 | and Greg Kroah-Hartman <gregkh@linuxfoundation.org>. |
diff --git a/drivers/staging/ramster/Kconfig b/drivers/staging/ramster/Kconfig index 8b57b87edda4..4af1f8d4b953 100644 --- a/drivers/staging/ramster/Kconfig +++ b/drivers/staging/ramster/Kconfig | |||
| @@ -1,10 +1,6 @@ | |||
| 1 | # Dependency on CONFIG_BROKEN is because there is a commit dependency | ||
| 2 | # on a cleancache naming change to be submitted by Konrad Wilk | ||
| 3 | # a39c00ded70339603ffe1b0ffdf3ade85bcf009a "Merge branch 'stable/cleancache.v13' | ||
| 4 | # into linux-next. Once this commit is present, BROKEN can be removed | ||
| 5 | config RAMSTER | 1 | config RAMSTER |
| 6 | bool "Cross-machine RAM capacity sharing, aka peer-to-peer tmem" | 2 | bool "Cross-machine RAM capacity sharing, aka peer-to-peer tmem" |
| 7 | depends on (CLEANCACHE || FRONTSWAP) && CONFIGFS_FS=y && !ZCACHE && !XVMALLOC && !HIGHMEM && BROKEN | 3 | depends on (CLEANCACHE || FRONTSWAP) && CONFIGFS_FS=y && !ZCACHE && !XVMALLOC && !HIGHMEM |
| 8 | select LZO_COMPRESS | 4 | select LZO_COMPRESS |
| 9 | select LZO_DECOMPRESS | 5 | select LZO_DECOMPRESS |
| 10 | default n | 6 | default n |
diff --git a/drivers/staging/rts_pstor/ms.c b/drivers/staging/rts_pstor/ms.c index 66341dff8c99..f9a4498984cc 100644 --- a/drivers/staging/rts_pstor/ms.c +++ b/drivers/staging/rts_pstor/ms.c | |||
| @@ -3498,7 +3498,8 @@ static int ms_rw_multi_sector(struct scsi_cmnd *srb, struct rtsx_chip *chip, u32 | |||
| 3498 | 3498 | ||
| 3499 | log_blk++; | 3499 | log_blk++; |
| 3500 | 3500 | ||
| 3501 | for (seg_no = 0; seg_no < sizeof(ms_start_idx)/2; seg_no++) { | 3501 | for (seg_no = 0; seg_no < ARRAY_SIZE(ms_start_idx) - 1; |
| 3502 | seg_no++) { | ||
| 3502 | if (log_blk < ms_start_idx[seg_no+1]) | 3503 | if (log_blk < ms_start_idx[seg_no+1]) |
| 3503 | break; | 3504 | break; |
| 3504 | } | 3505 | } |
diff --git a/drivers/staging/rts_pstor/rtsx.c b/drivers/staging/rts_pstor/rtsx.c index a7feb3e328a0..1dccd933a7e4 100644 --- a/drivers/staging/rts_pstor/rtsx.c +++ b/drivers/staging/rts_pstor/rtsx.c | |||
| @@ -1000,6 +1000,11 @@ static int __devinit rtsx_probe(struct pci_dev *pci, | |||
| 1000 | 1000 | ||
| 1001 | rtsx_init_chip(dev->chip); | 1001 | rtsx_init_chip(dev->chip); |
| 1002 | 1002 | ||
| 1003 | /* set the supported max_lun and max_id for the scsi host | ||
| 1004 | * NOTE: the minimal value of max_id is 1 */ | ||
| 1005 | host->max_id = 1; | ||
| 1006 | host->max_lun = dev->chip->max_lun; | ||
| 1007 | |||
| 1003 | /* Start up our control thread */ | 1008 | /* Start up our control thread */ |
| 1004 | th = kthread_run(rtsx_control_thread, dev, CR_DRIVER_NAME); | 1009 | th = kthread_run(rtsx_control_thread, dev, CR_DRIVER_NAME); |
| 1005 | if (IS_ERR(th)) { | 1010 | if (IS_ERR(th)) { |
diff --git a/drivers/staging/rts_pstor/rtsx_transport.c b/drivers/staging/rts_pstor/rtsx_transport.c index 4e3d2c106af0..9b2e5c99870f 100644 --- a/drivers/staging/rts_pstor/rtsx_transport.c +++ b/drivers/staging/rts_pstor/rtsx_transport.c | |||
| @@ -335,6 +335,7 @@ static int rtsx_transfer_sglist_adma_partial(struct rtsx_chip *chip, u8 card, | |||
| 335 | int sg_cnt, i, resid; | 335 | int sg_cnt, i, resid; |
| 336 | int err = 0; | 336 | int err = 0; |
| 337 | long timeleft; | 337 | long timeleft; |
| 338 | struct scatterlist *sg_ptr; | ||
| 338 | u32 val = TRIG_DMA; | 339 | u32 val = TRIG_DMA; |
| 339 | 340 | ||
| 340 | if ((sg == NULL) || (num_sg <= 0) || !offset || !index) | 341 | if ((sg == NULL) || (num_sg <= 0) || !offset || !index) |
| @@ -371,7 +372,7 @@ static int rtsx_transfer_sglist_adma_partial(struct rtsx_chip *chip, u8 card, | |||
| 371 | sg_cnt = dma_map_sg(&(rtsx->pci->dev), sg, num_sg, dma_dir); | 372 | sg_cnt = dma_map_sg(&(rtsx->pci->dev), sg, num_sg, dma_dir); |
| 372 | 373 | ||
| 373 | resid = size; | 374 | resid = size; |
| 374 | 375 | sg_ptr = sg; | |
| 375 | chip->sgi = 0; | 376 | chip->sgi = 0; |
| 376 | /* Usually the next entry will be @sg@ + 1, but if this sg element | 377 | /* Usually the next entry will be @sg@ + 1, but if this sg element |
| 377 | * is part of a chained scatterlist, it could jump to the start of | 378 | * is part of a chained scatterlist, it could jump to the start of |
| @@ -379,14 +380,14 @@ static int rtsx_transfer_sglist_adma_partial(struct rtsx_chip *chip, u8 card, | |||
| 379 | * the proper sg | 380 | * the proper sg |
| 380 | */ | 381 | */ |
| 381 | for (i = 0; i < *index; i++) | 382 | for (i = 0; i < *index; i++) |
| 382 | sg = sg_next(sg); | 383 | sg_ptr = sg_next(sg_ptr); |
| 383 | for (i = *index; i < sg_cnt; i++) { | 384 | for (i = *index; i < sg_cnt; i++) { |
| 384 | dma_addr_t addr; | 385 | dma_addr_t addr; |
| 385 | unsigned int len; | 386 | unsigned int len; |
| 386 | u8 option; | 387 | u8 option; |
| 387 | 388 | ||
| 388 | addr = sg_dma_address(sg); | 389 | addr = sg_dma_address(sg_ptr); |
| 389 | len = sg_dma_len(sg); | 390 | len = sg_dma_len(sg_ptr); |
| 390 | 391 | ||
| 391 | RTSX_DEBUGP("DMA addr: 0x%x, Len: 0x%x\n", | 392 | RTSX_DEBUGP("DMA addr: 0x%x, Len: 0x%x\n", |
| 392 | (unsigned int)addr, len); | 393 | (unsigned int)addr, len); |
| @@ -415,7 +416,7 @@ static int rtsx_transfer_sglist_adma_partial(struct rtsx_chip *chip, u8 card, | |||
| 415 | if (!resid) | 416 | if (!resid) |
| 416 | break; | 417 | break; |
| 417 | 418 | ||
| 418 | sg = sg_next(sg); | 419 | sg_ptr = sg_next(sg_ptr); |
| 419 | } | 420 | } |
| 420 | 421 | ||
| 421 | RTSX_DEBUGP("SG table count = %d\n", chip->sgi); | 422 | RTSX_DEBUGP("SG table count = %d\n", chip->sgi); |
diff --git a/drivers/staging/sep/sep_main.c b/drivers/staging/sep/sep_main.c index ad54c2e5c932..f1701bc6e312 100644 --- a/drivers/staging/sep/sep_main.c +++ b/drivers/staging/sep/sep_main.c | |||
| @@ -3114,7 +3114,7 @@ static long sep_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) | |||
| 3114 | current->pid); | 3114 | current->pid); |
| 3115 | if (1 == test_bit(SEP_LEGACY_SENDMSG_DONE_OFFSET, | 3115 | if (1 == test_bit(SEP_LEGACY_SENDMSG_DONE_OFFSET, |
| 3116 | &call_status->status)) { | 3116 | &call_status->status)) { |
| 3117 | dev_warn(&sep->pdev->dev, | 3117 | dev_dbg(&sep->pdev->dev, |
| 3118 | "[PID%d] dcb prep needed before send msg\n", | 3118 | "[PID%d] dcb prep needed before send msg\n", |
| 3119 | current->pid); | 3119 | current->pid); |
| 3120 | error = -EPROTO; | 3120 | error = -EPROTO; |
| @@ -3122,9 +3122,9 @@ static long sep_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) | |||
| 3122 | } | 3122 | } |
| 3123 | 3123 | ||
| 3124 | if (!arg) { | 3124 | if (!arg) { |
| 3125 | dev_warn(&sep->pdev->dev, | 3125 | dev_dbg(&sep->pdev->dev, |
| 3126 | "[PID%d] dcb null arg\n", current->pid); | 3126 | "[PID%d] dcb null arg\n", current->pid); |
| 3127 | error = EINVAL; | 3127 | error = -EINVAL; |
| 3128 | goto end_function; | 3128 | goto end_function; |
| 3129 | } | 3129 | } |
| 3130 | 3130 | ||
diff --git a/drivers/staging/vme/devices/vme_pio2_core.c b/drivers/staging/vme/devices/vme_pio2_core.c index 9fedc442a779..573c80003f0c 100644 --- a/drivers/staging/vme/devices/vme_pio2_core.c +++ b/drivers/staging/vme/devices/vme_pio2_core.c | |||
| @@ -35,10 +35,10 @@ static int vector[PIO2_CARDS_MAX]; | |||
| 35 | static int vector_num; | 35 | static int vector_num; |
| 36 | static int level[PIO2_CARDS_MAX]; | 36 | static int level[PIO2_CARDS_MAX]; |
| 37 | static int level_num; | 37 | static int level_num; |
| 38 | static const char *variant[PIO2_CARDS_MAX]; | 38 | static char *variant[PIO2_CARDS_MAX]; |
| 39 | static int variant_num; | 39 | static int variant_num; |
| 40 | 40 | ||
| 41 | static int loopback; | 41 | static bool loopback; |
| 42 | 42 | ||
| 43 | static int pio2_match(struct vme_dev *); | 43 | static int pio2_match(struct vme_dev *); |
| 44 | static int __devinit pio2_probe(struct vme_dev *); | 44 | static int __devinit pio2_probe(struct vme_dev *); |
diff --git a/drivers/staging/vt6655/key.c b/drivers/staging/vt6655/key.c index 0ff8d7bbf2a7..774b0d4a7e06 100644 --- a/drivers/staging/vt6655/key.c +++ b/drivers/staging/vt6655/key.c | |||
| @@ -655,6 +655,9 @@ bool KeybSetDefaultKey ( | |||
| 655 | return (false); | 655 | return (false); |
| 656 | } | 656 | } |
| 657 | 657 | ||
| 658 | if (uKeyLength > MAX_KEY_LEN) | ||
| 659 | return false; | ||
| 660 | |||
| 658 | pTable->KeyTable[MAX_KEY_TABLE-1].bInUse = true; | 661 | pTable->KeyTable[MAX_KEY_TABLE-1].bInUse = true; |
| 659 | for(ii=0;ii<ETH_ALEN;ii++) | 662 | for(ii=0;ii<ETH_ALEN;ii++) |
| 660 | pTable->KeyTable[MAX_KEY_TABLE-1].abyBSSID[ii] = 0xFF; | 663 | pTable->KeyTable[MAX_KEY_TABLE-1].abyBSSID[ii] = 0xFF; |
diff --git a/drivers/staging/vt6656/ioctl.c b/drivers/staging/vt6656/ioctl.c index 1463d76895f0..d59456c29df1 100644 --- a/drivers/staging/vt6656/ioctl.c +++ b/drivers/staging/vt6656/ioctl.c | |||
| @@ -565,7 +565,7 @@ int private_ioctl(PSDevice pDevice, struct ifreq *rq) | |||
| 565 | result = -ENOMEM; | 565 | result = -ENOMEM; |
| 566 | break; | 566 | break; |
| 567 | } | 567 | } |
| 568 | pNodeList = (PSNodeList)kmalloc(sizeof(SNodeList) + (sNodeList.uItem * sizeof(SNodeItem)), (int)GFP_ATOMIC); | 568 | pNodeList = kmalloc(sizeof(SNodeList) + (sNodeList.uItem * sizeof(SNodeItem)), (int)GFP_ATOMIC); |
| 569 | if (pNodeList == NULL) { | 569 | if (pNodeList == NULL) { |
| 570 | result = -ENOMEM; | 570 | result = -ENOMEM; |
| 571 | break; | 571 | break; |
| @@ -601,6 +601,7 @@ int private_ioctl(PSDevice pDevice, struct ifreq *rq) | |||
| 601 | } | 601 | } |
| 602 | } | 602 | } |
| 603 | if (copy_to_user(pReq->data, pNodeList, sizeof(SNodeList) + (sNodeList.uItem * sizeof(SNodeItem)))) { | 603 | if (copy_to_user(pReq->data, pNodeList, sizeof(SNodeList) + (sNodeList.uItem * sizeof(SNodeItem)))) { |
| 604 | kfree(pNodeList); | ||
| 604 | result = -EFAULT; | 605 | result = -EFAULT; |
| 605 | break; | 606 | break; |
| 606 | } | 607 | } |
diff --git a/drivers/staging/vt6656/key.c b/drivers/staging/vt6656/key.c index 27bb523c8a97..ee62a06a75f4 100644 --- a/drivers/staging/vt6656/key.c +++ b/drivers/staging/vt6656/key.c | |||
| @@ -684,6 +684,9 @@ BOOL KeybSetDefaultKey( | |||
| 684 | return (FALSE); | 684 | return (FALSE); |
| 685 | } | 685 | } |
| 686 | 686 | ||
| 687 | if (uKeyLength > MAX_KEY_LEN) | ||
| 688 | return false; | ||
| 689 | |||
| 687 | pTable->KeyTable[MAX_KEY_TABLE-1].bInUse = TRUE; | 690 | pTable->KeyTable[MAX_KEY_TABLE-1].bInUse = TRUE; |
| 688 | for (ii = 0; ii < ETH_ALEN; ii++) | 691 | for (ii = 0; ii < ETH_ALEN; ii++) |
| 689 | pTable->KeyTable[MAX_KEY_TABLE-1].abyBSSID[ii] = 0xFF; | 692 | pTable->KeyTable[MAX_KEY_TABLE-1].abyBSSID[ii] = 0xFF; |
diff --git a/drivers/staging/xgifb/vb_init.c b/drivers/staging/xgifb/vb_init.c index 94d5c35e22fb..3650bbff7686 100644 --- a/drivers/staging/xgifb/vb_init.c +++ b/drivers/staging/xgifb/vb_init.c | |||
| @@ -61,7 +61,7 @@ XGINew_GetXG20DRAMType(struct xgi_hw_device_info *HwDeviceExtension, | |||
| 61 | } | 61 | } |
| 62 | temp = xgifb_reg_get(pVBInfo->P3c4, 0x3B); | 62 | temp = xgifb_reg_get(pVBInfo->P3c4, 0x3B); |
| 63 | /* SR3B[7][3]MAA15 MAA11 (Power on Trapping) */ | 63 | /* SR3B[7][3]MAA15 MAA11 (Power on Trapping) */ |
| 64 | if ((temp & 0x88) == 0x80) | 64 | if (((temp & 0x88) == 0x80) || ((temp & 0x88) == 0x08)) |
| 65 | data = 0; /* DDR */ | 65 | data = 0; /* DDR */ |
| 66 | else | 66 | else |
| 67 | data = 1; /* DDRII */ | 67 | data = 1; /* DDRII */ |
diff --git a/drivers/staging/xgifb/vb_setmode.c b/drivers/staging/xgifb/vb_setmode.c index 2919924213c4..60d4adf99923 100644 --- a/drivers/staging/xgifb/vb_setmode.c +++ b/drivers/staging/xgifb/vb_setmode.c | |||
| @@ -152,6 +152,7 @@ void InitTo330Pointer(unsigned char ChipType, struct vb_device_info *pVBInfo) | |||
| 152 | pVBInfo->pXGINew_CR97 = &XG20_CR97; | 152 | pVBInfo->pXGINew_CR97 = &XG20_CR97; |
| 153 | 153 | ||
| 154 | if (ChipType == XG27) { | 154 | if (ChipType == XG27) { |
| 155 | unsigned char temp; | ||
| 155 | pVBInfo->MCLKData | 156 | pVBInfo->MCLKData |
| 156 | = (struct SiS_MCLKData *) XGI27New_MCLKData; | 157 | = (struct SiS_MCLKData *) XGI27New_MCLKData; |
| 157 | pVBInfo->CR40 = XGI27_cr41; | 158 | pVBInfo->CR40 = XGI27_cr41; |
| @@ -162,7 +163,13 @@ void InitTo330Pointer(unsigned char ChipType, struct vb_device_info *pVBInfo) | |||
| 162 | pVBInfo->pCRDE = XG27_CRDE; | 163 | pVBInfo->pCRDE = XG27_CRDE; |
| 163 | pVBInfo->pSR40 = &XG27_SR40; | 164 | pVBInfo->pSR40 = &XG27_SR40; |
| 164 | pVBInfo->pSR41 = &XG27_SR41; | 165 | pVBInfo->pSR41 = &XG27_SR41; |
| 166 | pVBInfo->SR15 = XG27_SR13; | ||
| 165 | 167 | ||
| 168 | /*Z11m DDR*/ | ||
| 169 | temp = xgifb_reg_get(pVBInfo->P3c4, 0x3B); | ||
| 170 | /* SR3B[7][3]MAA15 MAA11 (Power on Trapping) */ | ||
| 171 | if (((temp & 0x88) == 0x80) || ((temp & 0x88) == 0x08)) | ||
| 172 | pVBInfo->pXGINew_CR97 = &Z11m_CR97; | ||
| 166 | } | 173 | } |
| 167 | 174 | ||
| 168 | if (ChipType >= XG20) { | 175 | if (ChipType >= XG20) { |
diff --git a/drivers/staging/xgifb/vb_table.h b/drivers/staging/xgifb/vb_table.h index dddf261ed53d..e8d6f674b274 100644 --- a/drivers/staging/xgifb/vb_table.h +++ b/drivers/staging/xgifb/vb_table.h | |||
| @@ -33,6 +33,13 @@ static struct XGI_ECLKDataStruct XGI340_ECLKData[] = { | |||
| 33 | {0x5c, 0x23, 0x01, 166} | 33 | {0x5c, 0x23, 0x01, 166} |
| 34 | }; | 34 | }; |
| 35 | 35 | ||
| 36 | static unsigned char XG27_SR13[4][8] = { | ||
| 37 | {0x35, 0x45, 0xb1, 0x00, 0x00, 0x00, 0x00, 0x00}, /* SR13 */ | ||
| 38 | {0x41, 0x51, 0x5c, 0x00, 0x00, 0x00, 0x00, 0x00}, /* SR14 */ | ||
| 39 | {0x32, 0x32, 0x42, 0x00, 0x00, 0x00, 0x00, 0x00}, /* SR18 */ | ||
| 40 | {0x03, 0x03, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00} /* SR1B */ | ||
| 41 | }; | ||
| 42 | |||
| 36 | static unsigned char XGI340_SR13[4][8] = { | 43 | static unsigned char XGI340_SR13[4][8] = { |
| 37 | {0x35, 0x45, 0xb1, 0x00, 0x00, 0x00, 0x00, 0x00}, /* SR13 */ | 44 | {0x35, 0x45, 0xb1, 0x00, 0x00, 0x00, 0x00, 0x00}, /* SR13 */ |
| 38 | {0x41, 0x51, 0x5c, 0x00, 0x00, 0x00, 0x00, 0x00}, /* SR14 */ | 45 | {0x41, 0x51, 0x5c, 0x00, 0x00, 0x00, 0x00, 0x00}, /* SR14 */ |
| @@ -71,7 +78,7 @@ static unsigned char XGI27_cr41[24][8] = { | |||
| 71 | {0x20, 0x40, 0x60, 0x00, 0x00, 0x00, 0x00, 0x00}, /* 0 CR41 */ | 78 | {0x20, 0x40, 0x60, 0x00, 0x00, 0x00, 0x00, 0x00}, /* 0 CR41 */ |
| 72 | {0xC4, 0x40, 0x84, 0x00, 0x00, 0x00, 0x00, 0x00}, /* 1 CR8A */ | 79 | {0xC4, 0x40, 0x84, 0x00, 0x00, 0x00, 0x00, 0x00}, /* 1 CR8A */ |
| 73 | {0xC4, 0x40, 0x84, 0x00, 0x00, 0x00, 0x00, 0x00}, /* 2 CR8B */ | 80 | {0xC4, 0x40, 0x84, 0x00, 0x00, 0x00, 0x00, 0x00}, /* 2 CR8B */ |
| 74 | {0xB5, 0x13, 0xa4, 0x00, 0x00, 0x00, 0x00, 0x00}, /* 3 CR40[7], | 81 | {0xB3, 0x13, 0xa4, 0x00, 0x00, 0x00, 0x00, 0x00}, /* 3 CR40[7], |
| 75 | CR99[2:0], | 82 | CR99[2:0], |
| 76 | CR45[3:0]*/ | 83 | CR45[3:0]*/ |
| 77 | {0xf0, 0xf5, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00}, /* 4 CR59 */ | 84 | {0xf0, 0xf5, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00}, /* 4 CR59 */ |
| @@ -2803,6 +2810,8 @@ static unsigned char XG27_CRDE[2]; | |||
| 2803 | static unsigned char XG27_SR40 = 0x04 ; | 2810 | static unsigned char XG27_SR40 = 0x04 ; |
| 2804 | static unsigned char XG27_SR41 = 0x00 ; | 2811 | static unsigned char XG27_SR41 = 0x00 ; |
| 2805 | 2812 | ||
| 2813 | static unsigned char Z11m_CR97 = 0x80 ; | ||
| 2814 | |||
| 2806 | static struct XGI330_VCLKDataStruct XGI_VCLKData[] = { | 2815 | static struct XGI330_VCLKDataStruct XGI_VCLKData[] = { |
| 2807 | /* SR2B,SR2C,SR2D */ | 2816 | /* SR2B,SR2C,SR2D */ |
| 2808 | {0x1B, 0xE1, 25}, /* 00 (25.175MHz) */ | 2817 | {0x1B, 0xE1, 25}, /* 00 (25.175MHz) */ |
diff --git a/drivers/staging/zsmalloc/zsmalloc-main.c b/drivers/staging/zsmalloc/zsmalloc-main.c index 09caa4f2687e..917461c66014 100644 --- a/drivers/staging/zsmalloc/zsmalloc-main.c +++ b/drivers/staging/zsmalloc/zsmalloc-main.c | |||
| @@ -267,33 +267,39 @@ static unsigned long obj_idx_to_offset(struct page *page, | |||
| 267 | return off + obj_idx * class_size; | 267 | return off + obj_idx * class_size; |
| 268 | } | 268 | } |
| 269 | 269 | ||
| 270 | static void reset_page(struct page *page) | ||
| 271 | { | ||
| 272 | clear_bit(PG_private, &page->flags); | ||
| 273 | clear_bit(PG_private_2, &page->flags); | ||
| 274 | set_page_private(page, 0); | ||
| 275 | page->mapping = NULL; | ||
| 276 | page->freelist = NULL; | ||
| 277 | reset_page_mapcount(page); | ||
| 278 | } | ||
| 279 | |||
| 270 | static void free_zspage(struct page *first_page) | 280 | static void free_zspage(struct page *first_page) |
| 271 | { | 281 | { |
| 272 | struct page *nextp, *tmp; | 282 | struct page *nextp, *tmp, *head_extra; |
| 273 | 283 | ||
| 274 | BUG_ON(!is_first_page(first_page)); | 284 | BUG_ON(!is_first_page(first_page)); |
| 275 | BUG_ON(first_page->inuse); | 285 | BUG_ON(first_page->inuse); |
| 276 | 286 | ||
| 277 | nextp = (struct page *)page_private(first_page); | 287 | head_extra = (struct page *)page_private(first_page); |
| 278 | 288 | ||
| 279 | clear_bit(PG_private, &first_page->flags); | 289 | reset_page(first_page); |
| 280 | clear_bit(PG_private_2, &first_page->flags); | ||
| 281 | set_page_private(first_page, 0); | ||
| 282 | first_page->mapping = NULL; | ||
| 283 | first_page->freelist = NULL; | ||
| 284 | reset_page_mapcount(first_page); | ||
| 285 | __free_page(first_page); | 290 | __free_page(first_page); |
| 286 | 291 | ||
| 287 | /* zspage with only 1 system page */ | 292 | /* zspage with only 1 system page */ |
| 288 | if (!nextp) | 293 | if (!head_extra) |
| 289 | return; | 294 | return; |
| 290 | 295 | ||
| 291 | list_for_each_entry_safe(nextp, tmp, &nextp->lru, lru) { | 296 | list_for_each_entry_safe(nextp, tmp, &head_extra->lru, lru) { |
| 292 | list_del(&nextp->lru); | 297 | list_del(&nextp->lru); |
| 293 | clear_bit(PG_private_2, &nextp->flags); | 298 | reset_page(nextp); |
| 294 | nextp->index = 0; | ||
| 295 | __free_page(nextp); | 299 | __free_page(nextp); |
| 296 | } | 300 | } |
| 301 | reset_page(head_extra); | ||
| 302 | __free_page(head_extra); | ||
| 297 | } | 303 | } |
| 298 | 304 | ||
| 299 | /* Initialize a newly allocated zspage */ | 305 | /* Initialize a newly allocated zspage */ |
diff --git a/drivers/tty/amiserial.c b/drivers/tty/amiserial.c index 24145c30c9b0..6cc4358f68c1 100644 --- a/drivers/tty/amiserial.c +++ b/drivers/tty/amiserial.c | |||
| @@ -1073,8 +1073,10 @@ static int set_serial_info(struct tty_struct *tty, struct serial_state *state, | |||
| 1073 | (new_serial.close_delay != port->close_delay) || | 1073 | (new_serial.close_delay != port->close_delay) || |
| 1074 | (new_serial.xmit_fifo_size != state->xmit_fifo_size) || | 1074 | (new_serial.xmit_fifo_size != state->xmit_fifo_size) || |
| 1075 | ((new_serial.flags & ~ASYNC_USR_MASK) != | 1075 | ((new_serial.flags & ~ASYNC_USR_MASK) != |
| 1076 | (port->flags & ~ASYNC_USR_MASK))) | 1076 | (port->flags & ~ASYNC_USR_MASK))) { |
| 1077 | tty_unlock(); | ||
| 1077 | return -EPERM; | 1078 | return -EPERM; |
| 1079 | } | ||
| 1078 | port->flags = ((port->flags & ~ASYNC_USR_MASK) | | 1080 | port->flags = ((port->flags & ~ASYNC_USR_MASK) | |
| 1079 | (new_serial.flags & ASYNC_USR_MASK)); | 1081 | (new_serial.flags & ASYNC_USR_MASK)); |
| 1080 | state->custom_divisor = new_serial.custom_divisor; | 1082 | state->custom_divisor = new_serial.custom_divisor; |
diff --git a/drivers/tty/serial/8250/8250.c b/drivers/tty/serial/8250/8250.c index 5b149b466ec8..5c27f7e6c9f1 100644 --- a/drivers/tty/serial/8250/8250.c +++ b/drivers/tty/serial/8250/8250.c | |||
| @@ -1572,13 +1572,11 @@ static irqreturn_t serial8250_interrupt(int irq, void *dev_id) | |||
| 1572 | do { | 1572 | do { |
| 1573 | struct uart_8250_port *up; | 1573 | struct uart_8250_port *up; |
| 1574 | struct uart_port *port; | 1574 | struct uart_port *port; |
| 1575 | bool skip; | ||
| 1576 | 1575 | ||
| 1577 | up = list_entry(l, struct uart_8250_port, list); | 1576 | up = list_entry(l, struct uart_8250_port, list); |
| 1578 | port = &up->port; | 1577 | port = &up->port; |
| 1579 | skip = pass_counter && up->port.flags & UPF_IIR_ONCE; | ||
| 1580 | 1578 | ||
| 1581 | if (!skip && port->handle_irq(port)) { | 1579 | if (port->handle_irq(port)) { |
| 1582 | handled = 1; | 1580 | handled = 1; |
| 1583 | end = NULL; | 1581 | end = NULL; |
| 1584 | } else if (end == NULL) | 1582 | } else if (end == NULL) |
| @@ -2037,10 +2035,12 @@ static int serial8250_startup(struct uart_port *port) | |||
| 2037 | spin_unlock_irqrestore(&port->lock, flags); | 2035 | spin_unlock_irqrestore(&port->lock, flags); |
| 2038 | 2036 | ||
| 2039 | /* | 2037 | /* |
| 2040 | * If the interrupt is not reasserted, setup a timer to | 2038 | * If the interrupt is not reasserted, or we otherwise |
| 2041 | * kick the UART on a regular basis. | 2039 | * don't trust the iir, setup a timer to kick the UART |
| 2040 | * on a regular basis. | ||
| 2042 | */ | 2041 | */ |
| 2043 | if (!(iir1 & UART_IIR_NO_INT) && (iir & UART_IIR_NO_INT)) { | 2042 | if ((!(iir1 & UART_IIR_NO_INT) && (iir & UART_IIR_NO_INT)) || |
| 2043 | up->port.flags & UPF_BUG_THRE) { | ||
| 2044 | up->bugs |= UART_BUG_THRE; | 2044 | up->bugs |= UART_BUG_THRE; |
| 2045 | pr_debug("ttyS%d - using backup timer\n", | 2045 | pr_debug("ttyS%d - using backup timer\n", |
| 2046 | serial_index(port)); | 2046 | serial_index(port)); |
diff --git a/drivers/tty/serial/8250/8250_pci.c b/drivers/tty/serial/8250/8250_pci.c index da2b0b0a183f..858dca865d6a 100644 --- a/drivers/tty/serial/8250/8250_pci.c +++ b/drivers/tty/serial/8250/8250_pci.c | |||
| @@ -1096,7 +1096,7 @@ static int kt_serial_setup(struct serial_private *priv, | |||
| 1096 | const struct pciserial_board *board, | 1096 | const struct pciserial_board *board, |
| 1097 | struct uart_port *port, int idx) | 1097 | struct uart_port *port, int idx) |
| 1098 | { | 1098 | { |
| 1099 | port->flags |= UPF_IIR_ONCE; | 1099 | port->flags |= UPF_BUG_THRE; |
| 1100 | return skip_tx_en_setup(priv, board, port, idx); | 1100 | return skip_tx_en_setup(priv, board, port, idx); |
| 1101 | } | 1101 | } |
| 1102 | 1102 | ||
| @@ -1118,18 +1118,6 @@ pci_xr17c154_setup(struct serial_private *priv, | |||
| 1118 | return pci_default_setup(priv, board, port, idx); | 1118 | return pci_default_setup(priv, board, port, idx); |
| 1119 | } | 1119 | } |
| 1120 | 1120 | ||
| 1121 | static int try_enable_msi(struct pci_dev *dev) | ||
| 1122 | { | ||
| 1123 | /* use msi if available, but fallback to legacy otherwise */ | ||
| 1124 | pci_enable_msi(dev); | ||
| 1125 | return 0; | ||
| 1126 | } | ||
| 1127 | |||
| 1128 | static void disable_msi(struct pci_dev *dev) | ||
| 1129 | { | ||
| 1130 | pci_disable_msi(dev); | ||
| 1131 | } | ||
| 1132 | |||
| 1133 | #define PCI_VENDOR_ID_SBSMODULARIO 0x124B | 1121 | #define PCI_VENDOR_ID_SBSMODULARIO 0x124B |
| 1134 | #define PCI_SUBVENDOR_ID_SBSMODULARIO 0x124B | 1122 | #define PCI_SUBVENDOR_ID_SBSMODULARIO 0x124B |
| 1135 | #define PCI_DEVICE_ID_OCTPRO 0x0001 | 1123 | #define PCI_DEVICE_ID_OCTPRO 0x0001 |
| @@ -1249,9 +1237,7 @@ static struct pci_serial_quirk pci_serial_quirks[] __refdata = { | |||
| 1249 | .device = PCI_DEVICE_ID_INTEL_PATSBURG_KT, | 1237 | .device = PCI_DEVICE_ID_INTEL_PATSBURG_KT, |
| 1250 | .subvendor = PCI_ANY_ID, | 1238 | .subvendor = PCI_ANY_ID, |
| 1251 | .subdevice = PCI_ANY_ID, | 1239 | .subdevice = PCI_ANY_ID, |
| 1252 | .init = try_enable_msi, | ||
| 1253 | .setup = kt_serial_setup, | 1240 | .setup = kt_serial_setup, |
| 1254 | .exit = disable_msi, | ||
| 1255 | }, | 1241 | }, |
| 1256 | /* | 1242 | /* |
| 1257 | * ITE | 1243 | * ITE |
diff --git a/drivers/tty/serial/Kconfig b/drivers/tty/serial/Kconfig index 665beb68f670..070b442c1f81 100644 --- a/drivers/tty/serial/Kconfig +++ b/drivers/tty/serial/Kconfig | |||
| @@ -1041,7 +1041,7 @@ config SERIAL_OMAP | |||
| 1041 | 1041 | ||
| 1042 | config SERIAL_OMAP_CONSOLE | 1042 | config SERIAL_OMAP_CONSOLE |
| 1043 | bool "Console on OMAP serial port" | 1043 | bool "Console on OMAP serial port" |
| 1044 | depends on SERIAL_OMAP | 1044 | depends on SERIAL_OMAP=y |
| 1045 | select SERIAL_CORE_CONSOLE | 1045 | select SERIAL_CORE_CONSOLE |
| 1046 | help | 1046 | help |
| 1047 | Select this option if you would like to use omap serial port as | 1047 | Select this option if you would like to use omap serial port as |
diff --git a/drivers/tty/serial/altera_uart.c b/drivers/tty/serial/altera_uart.c index e7903751e058..1f0330915d5a 100644 --- a/drivers/tty/serial/altera_uart.c +++ b/drivers/tty/serial/altera_uart.c | |||
| @@ -556,7 +556,7 @@ static int __devinit altera_uart_probe(struct platform_device *pdev) | |||
| 556 | res_mem = platform_get_resource(pdev, IORESOURCE_MEM, 0); | 556 | res_mem = platform_get_resource(pdev, IORESOURCE_MEM, 0); |
| 557 | if (res_mem) | 557 | if (res_mem) |
| 558 | port->mapbase = res_mem->start; | 558 | port->mapbase = res_mem->start; |
| 559 | else if (platp->mapbase) | 559 | else if (platp) |
| 560 | port->mapbase = platp->mapbase; | 560 | port->mapbase = platp->mapbase; |
| 561 | else | 561 | else |
| 562 | return -EINVAL; | 562 | return -EINVAL; |
| @@ -564,7 +564,7 @@ static int __devinit altera_uart_probe(struct platform_device *pdev) | |||
| 564 | res_irq = platform_get_resource(pdev, IORESOURCE_IRQ, 0); | 564 | res_irq = platform_get_resource(pdev, IORESOURCE_IRQ, 0); |
| 565 | if (res_irq) | 565 | if (res_irq) |
| 566 | port->irq = res_irq->start; | 566 | port->irq = res_irq->start; |
| 567 | else if (platp->irq) | 567 | else if (platp) |
| 568 | port->irq = platp->irq; | 568 | port->irq = platp->irq; |
| 569 | 569 | ||
| 570 | /* Check platform data first so we can override device node data */ | 570 | /* Check platform data first so we can override device node data */ |
diff --git a/drivers/tty/serial/amba-pl011.c b/drivers/tty/serial/amba-pl011.c index 0c65c9e66986..3d569cd68f58 100644 --- a/drivers/tty/serial/amba-pl011.c +++ b/drivers/tty/serial/amba-pl011.c | |||
| @@ -1946,10 +1946,6 @@ static int pl011_probe(struct amba_device *dev, const struct amba_id *id) | |||
| 1946 | goto unmap; | 1946 | goto unmap; |
| 1947 | } | 1947 | } |
| 1948 | 1948 | ||
| 1949 | /* Ensure interrupts from this UART are masked and cleared */ | ||
| 1950 | writew(0, uap->port.membase + UART011_IMSC); | ||
| 1951 | writew(0xffff, uap->port.membase + UART011_ICR); | ||
| 1952 | |||
| 1953 | uap->vendor = vendor; | 1949 | uap->vendor = vendor; |
| 1954 | uap->lcrh_rx = vendor->lcrh_rx; | 1950 | uap->lcrh_rx = vendor->lcrh_rx; |
| 1955 | uap->lcrh_tx = vendor->lcrh_tx; | 1951 | uap->lcrh_tx = vendor->lcrh_tx; |
| @@ -1967,6 +1963,10 @@ static int pl011_probe(struct amba_device *dev, const struct amba_id *id) | |||
| 1967 | uap->port.line = i; | 1963 | uap->port.line = i; |
| 1968 | pl011_dma_probe(uap); | 1964 | pl011_dma_probe(uap); |
| 1969 | 1965 | ||
| 1966 | /* Ensure interrupts from this UART are masked and cleared */ | ||
| 1967 | writew(0, uap->port.membase + UART011_IMSC); | ||
| 1968 | writew(0xffff, uap->port.membase + UART011_ICR); | ||
| 1969 | |||
| 1970 | snprintf(uap->type, sizeof(uap->type), "PL011 rev%u", amba_rev(dev)); | 1970 | snprintf(uap->type, sizeof(uap->type), "PL011 rev%u", amba_rev(dev)); |
| 1971 | 1971 | ||
| 1972 | amba_ports[i] = uap; | 1972 | amba_ports[i] = uap; |
diff --git a/drivers/tty/serial/atmel_serial.c b/drivers/tty/serial/atmel_serial.c index f9a6be7a9bed..3d7e1ee2fa57 100644 --- a/drivers/tty/serial/atmel_serial.c +++ b/drivers/tty/serial/atmel_serial.c | |||
| @@ -389,6 +389,8 @@ static void atmel_start_rx(struct uart_port *port) | |||
| 389 | { | 389 | { |
| 390 | UART_PUT_CR(port, ATMEL_US_RSTSTA); /* reset status and receiver */ | 390 | UART_PUT_CR(port, ATMEL_US_RSTSTA); /* reset status and receiver */ |
| 391 | 391 | ||
| 392 | UART_PUT_CR(port, ATMEL_US_RXEN); | ||
| 393 | |||
| 392 | if (atmel_use_dma_rx(port)) { | 394 | if (atmel_use_dma_rx(port)) { |
| 393 | /* enable PDC controller */ | 395 | /* enable PDC controller */ |
| 394 | UART_PUT_IER(port, ATMEL_US_ENDRX | ATMEL_US_TIMEOUT | | 396 | UART_PUT_IER(port, ATMEL_US_ENDRX | ATMEL_US_TIMEOUT | |
| @@ -404,6 +406,8 @@ static void atmel_start_rx(struct uart_port *port) | |||
| 404 | */ | 406 | */ |
| 405 | static void atmel_stop_rx(struct uart_port *port) | 407 | static void atmel_stop_rx(struct uart_port *port) |
| 406 | { | 408 | { |
| 409 | UART_PUT_CR(port, ATMEL_US_RXDIS); | ||
| 410 | |||
| 407 | if (atmel_use_dma_rx(port)) { | 411 | if (atmel_use_dma_rx(port)) { |
| 408 | /* disable PDC receive */ | 412 | /* disable PDC receive */ |
| 409 | UART_PUT_PTCR(port, ATMEL_PDC_RXTDIS); | 413 | UART_PUT_PTCR(port, ATMEL_PDC_RXTDIS); |
diff --git a/drivers/tty/serial/clps711x.c b/drivers/tty/serial/clps711x.c index e6c3dbd781d6..836fe2731234 100644 --- a/drivers/tty/serial/clps711x.c +++ b/drivers/tty/serial/clps711x.c | |||
| @@ -154,10 +154,9 @@ static irqreturn_t clps711xuart_int_tx(int irq, void *dev_id) | |||
| 154 | port->x_char = 0; | 154 | port->x_char = 0; |
| 155 | return IRQ_HANDLED; | 155 | return IRQ_HANDLED; |
| 156 | } | 156 | } |
| 157 | if (uart_circ_empty(xmit) || uart_tx_stopped(port)) { | 157 | |
| 158 | clps711xuart_stop_tx(port); | 158 | if (uart_circ_empty(xmit) || uart_tx_stopped(port)) |
| 159 | return IRQ_HANDLED; | 159 | goto disable_tx_irq; |
| 160 | } | ||
| 161 | 160 | ||
| 162 | count = port->fifosize >> 1; | 161 | count = port->fifosize >> 1; |
| 163 | do { | 162 | do { |
| @@ -171,8 +170,11 @@ static irqreturn_t clps711xuart_int_tx(int irq, void *dev_id) | |||
| 171 | if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS) | 170 | if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS) |
| 172 | uart_write_wakeup(port); | 171 | uart_write_wakeup(port); |
| 173 | 172 | ||
| 174 | if (uart_circ_empty(xmit)) | 173 | if (uart_circ_empty(xmit)) { |
| 175 | clps711xuart_stop_tx(port); | 174 | disable_tx_irq: |
| 175 | disable_irq_nosync(TX_IRQ(port)); | ||
| 176 | tx_enabled(port) = 0; | ||
| 177 | } | ||
| 176 | 178 | ||
| 177 | return IRQ_HANDLED; | 179 | return IRQ_HANDLED; |
| 178 | } | 180 | } |
diff --git a/drivers/tty/serial/omap-serial.c b/drivers/tty/serial/omap-serial.c index 0121486ac4fa..d00b38eb268e 100644 --- a/drivers/tty/serial/omap-serial.c +++ b/drivers/tty/serial/omap-serial.c | |||
| @@ -1381,29 +1381,24 @@ static int serial_omap_probe(struct platform_device *pdev) | |||
| 1381 | return -ENODEV; | 1381 | return -ENODEV; |
| 1382 | } | 1382 | } |
| 1383 | 1383 | ||
| 1384 | if (!request_mem_region(mem->start, resource_size(mem), | 1384 | if (!devm_request_mem_region(&pdev->dev, mem->start, resource_size(mem), |
| 1385 | pdev->dev.driver->name)) { | 1385 | pdev->dev.driver->name)) { |
| 1386 | dev_err(&pdev->dev, "memory region already claimed\n"); | 1386 | dev_err(&pdev->dev, "memory region already claimed\n"); |
| 1387 | return -EBUSY; | 1387 | return -EBUSY; |
| 1388 | } | 1388 | } |
| 1389 | 1389 | ||
| 1390 | dma_rx = platform_get_resource_byname(pdev, IORESOURCE_DMA, "rx"); | 1390 | dma_rx = platform_get_resource_byname(pdev, IORESOURCE_DMA, "rx"); |
| 1391 | if (!dma_rx) { | 1391 | if (!dma_rx) |
| 1392 | ret = -EINVAL; | 1392 | return -ENXIO; |
| 1393 | goto err; | ||
| 1394 | } | ||
| 1395 | 1393 | ||
| 1396 | dma_tx = platform_get_resource_byname(pdev, IORESOURCE_DMA, "tx"); | 1394 | dma_tx = platform_get_resource_byname(pdev, IORESOURCE_DMA, "tx"); |
| 1397 | if (!dma_tx) { | 1395 | if (!dma_tx) |
| 1398 | ret = -EINVAL; | 1396 | return -ENXIO; |
| 1399 | goto err; | 1397 | |
| 1400 | } | 1398 | up = devm_kzalloc(&pdev->dev, sizeof(*up), GFP_KERNEL); |
| 1399 | if (!up) | ||
| 1400 | return -ENOMEM; | ||
| 1401 | 1401 | ||
| 1402 | up = kzalloc(sizeof(*up), GFP_KERNEL); | ||
| 1403 | if (up == NULL) { | ||
| 1404 | ret = -ENOMEM; | ||
| 1405 | goto do_release_region; | ||
| 1406 | } | ||
| 1407 | up->pdev = pdev; | 1402 | up->pdev = pdev; |
| 1408 | up->port.dev = &pdev->dev; | 1403 | up->port.dev = &pdev->dev; |
| 1409 | up->port.type = PORT_OMAP; | 1404 | up->port.type = PORT_OMAP; |
| @@ -1423,16 +1418,17 @@ static int serial_omap_probe(struct platform_device *pdev) | |||
| 1423 | dev_err(&pdev->dev, "failed to get alias/pdev id, errno %d\n", | 1418 | dev_err(&pdev->dev, "failed to get alias/pdev id, errno %d\n", |
| 1424 | up->port.line); | 1419 | up->port.line); |
| 1425 | ret = -ENODEV; | 1420 | ret = -ENODEV; |
| 1426 | goto err; | 1421 | goto err_port_line; |
| 1427 | } | 1422 | } |
| 1428 | 1423 | ||
| 1429 | sprintf(up->name, "OMAP UART%d", up->port.line); | 1424 | sprintf(up->name, "OMAP UART%d", up->port.line); |
| 1430 | up->port.mapbase = mem->start; | 1425 | up->port.mapbase = mem->start; |
| 1431 | up->port.membase = ioremap(mem->start, resource_size(mem)); | 1426 | up->port.membase = devm_ioremap(&pdev->dev, mem->start, |
| 1427 | resource_size(mem)); | ||
| 1432 | if (!up->port.membase) { | 1428 | if (!up->port.membase) { |
| 1433 | dev_err(&pdev->dev, "can't ioremap UART\n"); | 1429 | dev_err(&pdev->dev, "can't ioremap UART\n"); |
| 1434 | ret = -ENOMEM; | 1430 | ret = -ENOMEM; |
| 1435 | goto err; | 1431 | goto err_ioremap; |
| 1436 | } | 1432 | } |
| 1437 | 1433 | ||
| 1438 | up->port.flags = omap_up_info->flags; | 1434 | up->port.flags = omap_up_info->flags; |
| @@ -1478,16 +1474,19 @@ static int serial_omap_probe(struct platform_device *pdev) | |||
| 1478 | 1474 | ||
| 1479 | ret = uart_add_one_port(&serial_omap_reg, &up->port); | 1475 | ret = uart_add_one_port(&serial_omap_reg, &up->port); |
| 1480 | if (ret != 0) | 1476 | if (ret != 0) |
| 1481 | goto do_release_region; | 1477 | goto err_add_port; |
| 1482 | 1478 | ||
| 1483 | pm_runtime_put(&pdev->dev); | 1479 | pm_runtime_put(&pdev->dev); |
| 1484 | platform_set_drvdata(pdev, up); | 1480 | platform_set_drvdata(pdev, up); |
| 1485 | return 0; | 1481 | return 0; |
| 1486 | err: | 1482 | |
| 1483 | err_add_port: | ||
| 1484 | pm_runtime_put(&pdev->dev); | ||
| 1485 | pm_runtime_disable(&pdev->dev); | ||
| 1486 | err_ioremap: | ||
| 1487 | err_port_line: | ||
| 1487 | dev_err(&pdev->dev, "[UART%d]: failure [%s]: %d\n", | 1488 | dev_err(&pdev->dev, "[UART%d]: failure [%s]: %d\n", |
| 1488 | pdev->id, __func__, ret); | 1489 | pdev->id, __func__, ret); |
| 1489 | do_release_region: | ||
| 1490 | release_mem_region(mem->start, resource_size(mem)); | ||
| 1491 | return ret; | 1490 | return ret; |
| 1492 | } | 1491 | } |
| 1493 | 1492 | ||
| @@ -1499,8 +1498,6 @@ static int serial_omap_remove(struct platform_device *dev) | |||
| 1499 | pm_runtime_disable(&up->pdev->dev); | 1498 | pm_runtime_disable(&up->pdev->dev); |
| 1500 | uart_remove_one_port(&serial_omap_reg, &up->port); | 1499 | uart_remove_one_port(&serial_omap_reg, &up->port); |
| 1501 | pm_qos_remove_request(&up->pm_qos_request); | 1500 | pm_qos_remove_request(&up->pm_qos_request); |
| 1502 | |||
| 1503 | kfree(up); | ||
| 1504 | } | 1501 | } |
| 1505 | 1502 | ||
| 1506 | platform_set_drvdata(dev, NULL); | 1503 | platform_set_drvdata(dev, NULL); |
diff --git a/drivers/tty/serial/pch_uart.c b/drivers/tty/serial/pch_uart.c index 08b9962b8fda..c2816f494807 100644 --- a/drivers/tty/serial/pch_uart.c +++ b/drivers/tty/serial/pch_uart.c | |||
| @@ -210,6 +210,7 @@ enum { | |||
| 210 | #define CMITC_UARTCLK 192000000 /* 192.0000 MHz */ | 210 | #define CMITC_UARTCLK 192000000 /* 192.0000 MHz */ |
| 211 | #define FRI2_64_UARTCLK 64000000 /* 64.0000 MHz */ | 211 | #define FRI2_64_UARTCLK 64000000 /* 64.0000 MHz */ |
| 212 | #define FRI2_48_UARTCLK 48000000 /* 48.0000 MHz */ | 212 | #define FRI2_48_UARTCLK 48000000 /* 48.0000 MHz */ |
| 213 | #define NTC1_UARTCLK 64000000 /* 64.0000 MHz */ | ||
| 213 | 214 | ||
| 214 | struct pch_uart_buffer { | 215 | struct pch_uart_buffer { |
| 215 | unsigned char *buf; | 216 | unsigned char *buf; |
| @@ -384,6 +385,12 @@ static int pch_uart_get_uartclk(void) | |||
| 384 | if (cmp && strstr(cmp, "Fish River Island II")) | 385 | if (cmp && strstr(cmp, "Fish River Island II")) |
| 385 | return FRI2_48_UARTCLK; | 386 | return FRI2_48_UARTCLK; |
| 386 | 387 | ||
| 388 | /* Kontron COMe-mTT10 (nanoETXexpress-TT) */ | ||
| 389 | cmp = dmi_get_system_info(DMI_BOARD_NAME); | ||
| 390 | if (cmp && (strstr(cmp, "COMe-mTT") || | ||
| 391 | strstr(cmp, "nanoETXexpress-TT"))) | ||
| 392 | return NTC1_UARTCLK; | ||
| 393 | |||
| 387 | return DEFAULT_UARTCLK; | 394 | return DEFAULT_UARTCLK; |
| 388 | } | 395 | } |
| 389 | 396 | ||
| @@ -1440,9 +1447,11 @@ static int pch_uart_verify_port(struct uart_port *port, | |||
| 1440 | __func__); | 1447 | __func__); |
| 1441 | return -EOPNOTSUPP; | 1448 | return -EOPNOTSUPP; |
| 1442 | #endif | 1449 | #endif |
| 1443 | priv->use_dma = 1; | ||
| 1444 | priv->use_dma_flag = 1; | 1450 | priv->use_dma_flag = 1; |
| 1445 | dev_info(priv->port.dev, "PCH UART : Use DMA Mode\n"); | 1451 | dev_info(priv->port.dev, "PCH UART : Use DMA Mode\n"); |
| 1452 | if (!priv->use_dma) | ||
| 1453 | pch_request_dma(port); | ||
| 1454 | priv->use_dma = 1; | ||
| 1446 | } | 1455 | } |
| 1447 | 1456 | ||
| 1448 | return 0; | 1457 | return 0; |
| @@ -1651,6 +1660,7 @@ static struct eg20t_port *pch_uart_init_port(struct pci_dev *pdev, | |||
| 1651 | } | 1660 | } |
| 1652 | 1661 | ||
| 1653 | pci_enable_msi(pdev); | 1662 | pci_enable_msi(pdev); |
| 1663 | pci_set_master(pdev); | ||
| 1654 | 1664 | ||
| 1655 | iobase = pci_resource_start(pdev, 0); | 1665 | iobase = pci_resource_start(pdev, 0); |
| 1656 | mapbase = pci_resource_start(pdev, 1); | 1666 | mapbase = pci_resource_start(pdev, 1); |
diff --git a/drivers/tty/serial/samsung.c b/drivers/tty/serial/samsung.c index de249d265bec..d8b0aee35632 100644 --- a/drivers/tty/serial/samsung.c +++ b/drivers/tty/serial/samsung.c | |||
| @@ -982,6 +982,7 @@ static void s3c24xx_serial_resetport(struct uart_port *port, | |||
| 982 | 982 | ||
| 983 | ucon &= ucon_mask; | 983 | ucon &= ucon_mask; |
| 984 | wr_regl(port, S3C2410_UCON, ucon | cfg->ucon); | 984 | wr_regl(port, S3C2410_UCON, ucon | cfg->ucon); |
| 985 | wr_regl(port, S3C2410_ULCON, cfg->ulcon); | ||
| 985 | 986 | ||
| 986 | /* reset both fifos */ | 987 | /* reset both fifos */ |
| 987 | wr_regl(port, S3C2410_UFCON, cfg->ufcon | S3C2410_UFCON_RESETBOTH); | 988 | wr_regl(port, S3C2410_UFCON, cfg->ufcon | S3C2410_UFCON_RESETBOTH); |
diff --git a/drivers/tty/vt/vt.c b/drivers/tty/vt/vt.c index 3bdd4b19dd06..2156188db4a6 100644 --- a/drivers/tty/vt/vt.c +++ b/drivers/tty/vt/vt.c | |||
| @@ -2932,11 +2932,10 @@ static int __init con_init(void) | |||
| 2932 | gotoxy(vc, vc->vc_x, vc->vc_y); | 2932 | gotoxy(vc, vc->vc_x, vc->vc_y); |
| 2933 | csi_J(vc, 0); | 2933 | csi_J(vc, 0); |
| 2934 | update_screen(vc); | 2934 | update_screen(vc); |
| 2935 | pr_info("Console: %s %s %dx%d", | 2935 | pr_info("Console: %s %s %dx%d\n", |
| 2936 | vc->vc_can_do_color ? "colour" : "mono", | 2936 | vc->vc_can_do_color ? "colour" : "mono", |
| 2937 | display_desc, vc->vc_cols, vc->vc_rows); | 2937 | display_desc, vc->vc_cols, vc->vc_rows); |
| 2938 | printable = 1; | 2938 | printable = 1; |
| 2939 | printk("\n"); | ||
| 2940 | 2939 | ||
| 2941 | console_unlock(); | 2940 | console_unlock(); |
| 2942 | 2941 | ||
diff --git a/drivers/usb/Kconfig b/drivers/usb/Kconfig index cbd8f5f80596..76316a33061b 100644 --- a/drivers/usb/Kconfig +++ b/drivers/usb/Kconfig | |||
| @@ -2,14 +2,6 @@ | |||
| 2 | # USB device configuration | 2 | # USB device configuration |
| 3 | # | 3 | # |
| 4 | 4 | ||
| 5 | menuconfig USB_SUPPORT | ||
| 6 | bool "USB support" | ||
| 7 | depends on HAS_IOMEM | ||
| 8 | default y | ||
| 9 | ---help--- | ||
| 10 | This option adds core support for Universal Serial Bus (USB). | ||
| 11 | You will also need drivers from the following menu to make use of it. | ||
| 12 | |||
| 13 | # many non-PCI SOC chips embed OHCI | 5 | # many non-PCI SOC chips embed OHCI |
| 14 | config USB_ARCH_HAS_OHCI | 6 | config USB_ARCH_HAS_OHCI |
| 15 | boolean | 7 | boolean |
| @@ -63,6 +55,14 @@ config USB_ARCH_HAS_XHCI | |||
| 63 | boolean | 55 | boolean |
| 64 | default PCI | 56 | default PCI |
| 65 | 57 | ||
| 58 | menuconfig USB_SUPPORT | ||
| 59 | bool "USB support" | ||
| 60 | depends on HAS_IOMEM | ||
| 61 | default y | ||
| 62 | ---help--- | ||
| 63 | This option adds core support for Universal Serial Bus (USB). | ||
| 64 | You will also need drivers from the following menu to make use of it. | ||
| 65 | |||
| 66 | if USB_SUPPORT | 66 | if USB_SUPPORT |
| 67 | 67 | ||
| 68 | config USB_COMMON | 68 | config USB_COMMON |
diff --git a/drivers/usb/core/driver.c b/drivers/usb/core/driver.c index f8e2d6d52e5c..9a56635dc19c 100644 --- a/drivers/usb/core/driver.c +++ b/drivers/usb/core/driver.c | |||
| @@ -1189,8 +1189,13 @@ static int usb_suspend_both(struct usb_device *udev, pm_message_t msg) | |||
| 1189 | if (status == 0) { | 1189 | if (status == 0) { |
| 1190 | status = usb_suspend_device(udev, msg); | 1190 | status = usb_suspend_device(udev, msg); |
| 1191 | 1191 | ||
| 1192 | /* Again, ignore errors during system sleep transitions */ | 1192 | /* |
| 1193 | if (!PMSG_IS_AUTO(msg)) | 1193 | * Ignore errors from non-root-hub devices during |
| 1194 | * system sleep transitions. For the most part, | ||
| 1195 | * these devices should go to low power anyway when | ||
| 1196 | * the entire bus is suspended. | ||
| 1197 | */ | ||
| 1198 | if (udev->parent && !PMSG_IS_AUTO(msg)) | ||
| 1194 | status = 0; | 1199 | status = 0; |
| 1195 | } | 1200 | } |
| 1196 | 1201 | ||
diff --git a/drivers/usb/core/hcd.c b/drivers/usb/core/hcd.c index 9d7fc9a39933..140d3e11f212 100644 --- a/drivers/usb/core/hcd.c +++ b/drivers/usb/core/hcd.c | |||
| @@ -1978,6 +1978,18 @@ int hcd_bus_suspend(struct usb_device *rhdev, pm_message_t msg) | |||
| 1978 | if (status == 0) { | 1978 | if (status == 0) { |
| 1979 | usb_set_device_state(rhdev, USB_STATE_SUSPENDED); | 1979 | usb_set_device_state(rhdev, USB_STATE_SUSPENDED); |
| 1980 | hcd->state = HC_STATE_SUSPENDED; | 1980 | hcd->state = HC_STATE_SUSPENDED; |
| 1981 | |||
| 1982 | /* Did we race with a root-hub wakeup event? */ | ||
| 1983 | if (rhdev->do_remote_wakeup) { | ||
| 1984 | char buffer[6]; | ||
| 1985 | |||
| 1986 | status = hcd->driver->hub_status_data(hcd, buffer); | ||
| 1987 | if (status != 0) { | ||
| 1988 | dev_dbg(&rhdev->dev, "suspend raced with wakeup event\n"); | ||
| 1989 | hcd_bus_resume(rhdev, PMSG_AUTO_RESUME); | ||
| 1990 | status = -EBUSY; | ||
| 1991 | } | ||
| 1992 | } | ||
| 1981 | } else { | 1993 | } else { |
| 1982 | spin_lock_irq(&hcd_root_hub_lock); | 1994 | spin_lock_irq(&hcd_root_hub_lock); |
| 1983 | if (!HCD_DEAD(hcd)) { | 1995 | if (!HCD_DEAD(hcd)) { |
diff --git a/drivers/usb/core/hub.c b/drivers/usb/core/hub.c index 28664eb7f555..ec6c97dadbe4 100644 --- a/drivers/usb/core/hub.c +++ b/drivers/usb/core/hub.c | |||
| @@ -1667,7 +1667,6 @@ void usb_disconnect(struct usb_device **pdev) | |||
| 1667 | { | 1667 | { |
| 1668 | struct usb_device *udev = *pdev; | 1668 | struct usb_device *udev = *pdev; |
| 1669 | int i; | 1669 | int i; |
| 1670 | struct usb_hcd *hcd = bus_to_hcd(udev->bus); | ||
| 1671 | 1670 | ||
| 1672 | /* mark the device as inactive, so any further urb submissions for | 1671 | /* mark the device as inactive, so any further urb submissions for |
| 1673 | * this device (and any of its children) will fail immediately. | 1672 | * this device (and any of its children) will fail immediately. |
| @@ -1690,9 +1689,7 @@ void usb_disconnect(struct usb_device **pdev) | |||
| 1690 | * so that the hardware is now fully quiesced. | 1689 | * so that the hardware is now fully quiesced. |
| 1691 | */ | 1690 | */ |
| 1692 | dev_dbg (&udev->dev, "unregistering device\n"); | 1691 | dev_dbg (&udev->dev, "unregistering device\n"); |
| 1693 | mutex_lock(hcd->bandwidth_mutex); | ||
| 1694 | usb_disable_device(udev, 0); | 1692 | usb_disable_device(udev, 0); |
| 1695 | mutex_unlock(hcd->bandwidth_mutex); | ||
| 1696 | usb_hcd_synchronize_unlinks(udev); | 1693 | usb_hcd_synchronize_unlinks(udev); |
| 1697 | 1694 | ||
| 1698 | usb_remove_ep_devs(&udev->ep0); | 1695 | usb_remove_ep_devs(&udev->ep0); |
| @@ -3163,6 +3160,22 @@ hub_port_init (struct usb_hub *hub, struct usb_device *udev, int port1, | |||
| 3163 | if (retval) | 3160 | if (retval) |
| 3164 | goto fail; | 3161 | goto fail; |
| 3165 | 3162 | ||
| 3163 | /* | ||
| 3164 | * Some superspeed devices have finished the link training process | ||
| 3165 | * and attached to a superspeed hub port, but the device descriptor | ||
| 3166 | * got from those devices show they aren't superspeed devices. Warm | ||
| 3167 | * reset the port attached by the devices can fix them. | ||
| 3168 | */ | ||
| 3169 | if ((udev->speed == USB_SPEED_SUPER) && | ||
| 3170 | (le16_to_cpu(udev->descriptor.bcdUSB) < 0x0300)) { | ||
| 3171 | dev_err(&udev->dev, "got a wrong device descriptor, " | ||
| 3172 | "warm reset device\n"); | ||
| 3173 | hub_port_reset(hub, port1, udev, | ||
| 3174 | HUB_BH_RESET_TIME, true); | ||
| 3175 | retval = -EINVAL; | ||
| 3176 | goto fail; | ||
| 3177 | } | ||
| 3178 | |||
| 3166 | if (udev->descriptor.bMaxPacketSize0 == 0xff || | 3179 | if (udev->descriptor.bMaxPacketSize0 == 0xff || |
| 3167 | udev->speed == USB_SPEED_SUPER) | 3180 | udev->speed == USB_SPEED_SUPER) |
| 3168 | i = 512; | 3181 | i = 512; |
diff --git a/drivers/usb/core/message.c b/drivers/usb/core/message.c index b3bdfede45e6..ca717da3be95 100644 --- a/drivers/usb/core/message.c +++ b/drivers/usb/core/message.c | |||
| @@ -308,7 +308,8 @@ static void sg_complete(struct urb *urb) | |||
| 308 | retval = usb_unlink_urb(io->urbs [i]); | 308 | retval = usb_unlink_urb(io->urbs [i]); |
| 309 | if (retval != -EINPROGRESS && | 309 | if (retval != -EINPROGRESS && |
| 310 | retval != -ENODEV && | 310 | retval != -ENODEV && |
| 311 | retval != -EBUSY) | 311 | retval != -EBUSY && |
| 312 | retval != -EIDRM) | ||
| 312 | dev_err(&io->dev->dev, | 313 | dev_err(&io->dev->dev, |
| 313 | "%s, unlink --> %d\n", | 314 | "%s, unlink --> %d\n", |
| 314 | __func__, retval); | 315 | __func__, retval); |
| @@ -317,7 +318,6 @@ static void sg_complete(struct urb *urb) | |||
| 317 | } | 318 | } |
| 318 | spin_lock(&io->lock); | 319 | spin_lock(&io->lock); |
| 319 | } | 320 | } |
| 320 | urb->dev = NULL; | ||
| 321 | 321 | ||
| 322 | /* on the last completion, signal usb_sg_wait() */ | 322 | /* on the last completion, signal usb_sg_wait() */ |
| 323 | io->bytes += urb->actual_length; | 323 | io->bytes += urb->actual_length; |
| @@ -524,7 +524,6 @@ void usb_sg_wait(struct usb_sg_request *io) | |||
| 524 | case -ENXIO: /* hc didn't queue this one */ | 524 | case -ENXIO: /* hc didn't queue this one */ |
| 525 | case -EAGAIN: | 525 | case -EAGAIN: |
| 526 | case -ENOMEM: | 526 | case -ENOMEM: |
| 527 | io->urbs[i]->dev = NULL; | ||
| 528 | retval = 0; | 527 | retval = 0; |
| 529 | yield(); | 528 | yield(); |
| 530 | break; | 529 | break; |
| @@ -542,7 +541,6 @@ void usb_sg_wait(struct usb_sg_request *io) | |||
| 542 | 541 | ||
| 543 | /* fail any uncompleted urbs */ | 542 | /* fail any uncompleted urbs */ |
| 544 | default: | 543 | default: |
| 545 | io->urbs[i]->dev = NULL; | ||
| 546 | io->urbs[i]->status = retval; | 544 | io->urbs[i]->status = retval; |
| 547 | dev_dbg(&io->dev->dev, "%s, submit --> %d\n", | 545 | dev_dbg(&io->dev->dev, "%s, submit --> %d\n", |
| 548 | __func__, retval); | 546 | __func__, retval); |
| @@ -593,7 +591,10 @@ void usb_sg_cancel(struct usb_sg_request *io) | |||
| 593 | if (!io->urbs [i]->dev) | 591 | if (!io->urbs [i]->dev) |
| 594 | continue; | 592 | continue; |
| 595 | retval = usb_unlink_urb(io->urbs [i]); | 593 | retval = usb_unlink_urb(io->urbs [i]); |
| 596 | if (retval != -EINPROGRESS && retval != -EBUSY) | 594 | if (retval != -EINPROGRESS |
| 595 | && retval != -ENODEV | ||
| 596 | && retval != -EBUSY | ||
| 597 | && retval != -EIDRM) | ||
| 597 | dev_warn(&io->dev->dev, "%s, unlink --> %d\n", | 598 | dev_warn(&io->dev->dev, "%s, unlink --> %d\n", |
| 598 | __func__, retval); | 599 | __func__, retval); |
| 599 | } | 600 | } |
| @@ -1135,8 +1136,6 @@ void usb_disable_interface(struct usb_device *dev, struct usb_interface *intf, | |||
| 1135 | * Deallocates hcd/hardware state for the endpoints (nuking all or most | 1136 | * Deallocates hcd/hardware state for the endpoints (nuking all or most |
| 1136 | * pending urbs) and usbcore state for the interfaces, so that usbcore | 1137 | * pending urbs) and usbcore state for the interfaces, so that usbcore |
| 1137 | * must usb_set_configuration() before any interfaces could be used. | 1138 | * must usb_set_configuration() before any interfaces could be used. |
| 1138 | * | ||
| 1139 | * Must be called with hcd->bandwidth_mutex held. | ||
| 1140 | */ | 1139 | */ |
| 1141 | void usb_disable_device(struct usb_device *dev, int skip_ep0) | 1140 | void usb_disable_device(struct usb_device *dev, int skip_ep0) |
| 1142 | { | 1141 | { |
| @@ -1189,7 +1188,9 @@ void usb_disable_device(struct usb_device *dev, int skip_ep0) | |||
| 1189 | usb_disable_endpoint(dev, i + USB_DIR_IN, false); | 1188 | usb_disable_endpoint(dev, i + USB_DIR_IN, false); |
| 1190 | } | 1189 | } |
| 1191 | /* Remove endpoints from the host controller internal state */ | 1190 | /* Remove endpoints from the host controller internal state */ |
| 1191 | mutex_lock(hcd->bandwidth_mutex); | ||
| 1192 | usb_hcd_alloc_bandwidth(dev, NULL, NULL, NULL); | 1192 | usb_hcd_alloc_bandwidth(dev, NULL, NULL, NULL); |
| 1193 | mutex_unlock(hcd->bandwidth_mutex); | ||
| 1193 | /* Second pass: remove endpoint pointers */ | 1194 | /* Second pass: remove endpoint pointers */ |
| 1194 | } | 1195 | } |
| 1195 | for (i = skip_ep0; i < 16; ++i) { | 1196 | for (i = skip_ep0; i < 16; ++i) { |
| @@ -1749,7 +1750,6 @@ free_interfaces: | |||
| 1749 | /* if it's already configured, clear out old state first. | 1750 | /* if it's already configured, clear out old state first. |
| 1750 | * getting rid of old interfaces means unbinding their drivers. | 1751 | * getting rid of old interfaces means unbinding their drivers. |
| 1751 | */ | 1752 | */ |
| 1752 | mutex_lock(hcd->bandwidth_mutex); | ||
| 1753 | if (dev->state != USB_STATE_ADDRESS) | 1753 | if (dev->state != USB_STATE_ADDRESS) |
| 1754 | usb_disable_device(dev, 1); /* Skip ep0 */ | 1754 | usb_disable_device(dev, 1); /* Skip ep0 */ |
| 1755 | 1755 | ||
| @@ -1762,6 +1762,7 @@ free_interfaces: | |||
| 1762 | * host controller will not allow submissions to dropped endpoints. If | 1762 | * host controller will not allow submissions to dropped endpoints. If |
| 1763 | * this call fails, the device state is unchanged. | 1763 | * this call fails, the device state is unchanged. |
| 1764 | */ | 1764 | */ |
| 1765 | mutex_lock(hcd->bandwidth_mutex); | ||
| 1765 | ret = usb_hcd_alloc_bandwidth(dev, cp, NULL, NULL); | 1766 | ret = usb_hcd_alloc_bandwidth(dev, cp, NULL, NULL); |
| 1766 | if (ret < 0) { | 1767 | if (ret < 0) { |
| 1767 | mutex_unlock(hcd->bandwidth_mutex); | 1768 | mutex_unlock(hcd->bandwidth_mutex); |
diff --git a/drivers/usb/core/urb.c b/drivers/usb/core/urb.c index 7239a73c1b8c..cd9b3a2cd8a7 100644 --- a/drivers/usb/core/urb.c +++ b/drivers/usb/core/urb.c | |||
| @@ -539,6 +539,10 @@ EXPORT_SYMBOL_GPL(usb_submit_urb); | |||
| 539 | * never submitted, or it was unlinked before, or the hardware is already | 539 | * never submitted, or it was unlinked before, or the hardware is already |
| 540 | * finished with it), even if the completion handler has not yet run. | 540 | * finished with it), even if the completion handler has not yet run. |
| 541 | * | 541 | * |
| 542 | * The URB must not be deallocated while this routine is running. In | ||
| 543 | * particular, when a driver calls this routine, it must insure that the | ||
| 544 | * completion handler cannot deallocate the URB. | ||
| 545 | * | ||
| 542 | * Unlinking and Endpoint Queues: | 546 | * Unlinking and Endpoint Queues: |
| 543 | * | 547 | * |
| 544 | * [The behaviors and guarantees described below do not apply to virtual | 548 | * [The behaviors and guarantees described below do not apply to virtual |
| @@ -603,6 +607,10 @@ EXPORT_SYMBOL_GPL(usb_unlink_urb); | |||
| 603 | * with error -EPERM. Thus even if the URB's completion handler always | 607 | * with error -EPERM. Thus even if the URB's completion handler always |
| 604 | * tries to resubmit, it will not succeed and the URB will become idle. | 608 | * tries to resubmit, it will not succeed and the URB will become idle. |
| 605 | * | 609 | * |
| 610 | * The URB must not be deallocated while this routine is running. In | ||
| 611 | * particular, when a driver calls this routine, it must insure that the | ||
| 612 | * completion handler cannot deallocate the URB. | ||
| 613 | * | ||
| 606 | * This routine may not be used in an interrupt context (such as a bottom | 614 | * This routine may not be used in an interrupt context (such as a bottom |
| 607 | * half or a completion handler), or when holding a spinlock, or in other | 615 | * half or a completion handler), or when holding a spinlock, or in other |
| 608 | * situations where the caller can't schedule(). | 616 | * situations where the caller can't schedule(). |
| @@ -640,6 +648,10 @@ EXPORT_SYMBOL_GPL(usb_kill_urb); | |||
| 640 | * with error -EPERM. Thus even if the URB's completion handler always | 648 | * with error -EPERM. Thus even if the URB's completion handler always |
| 641 | * tries to resubmit, it will not succeed and the URB will become idle. | 649 | * tries to resubmit, it will not succeed and the URB will become idle. |
| 642 | * | 650 | * |
| 651 | * The URB must not be deallocated while this routine is running. In | ||
| 652 | * particular, when a driver calls this routine, it must insure that the | ||
| 653 | * completion handler cannot deallocate the URB. | ||
| 654 | * | ||
| 643 | * This routine may not be used in an interrupt context (such as a bottom | 655 | * This routine may not be used in an interrupt context (such as a bottom |
| 644 | * half or a completion handler), or when holding a spinlock, or in other | 656 | * half or a completion handler), or when holding a spinlock, or in other |
| 645 | * situations where the caller can't schedule(). | 657 | * situations where the caller can't schedule(). |
diff --git a/drivers/usb/dwc3/core.c b/drivers/usb/dwc3/core.c index 7bd815a507e8..99b58d84553a 100644 --- a/drivers/usb/dwc3/core.c +++ b/drivers/usb/dwc3/core.c | |||
| @@ -206,11 +206,11 @@ static void dwc3_free_event_buffers(struct dwc3 *dwc) | |||
| 206 | 206 | ||
| 207 | for (i = 0; i < dwc->num_event_buffers; i++) { | 207 | for (i = 0; i < dwc->num_event_buffers; i++) { |
| 208 | evt = dwc->ev_buffs[i]; | 208 | evt = dwc->ev_buffs[i]; |
| 209 | if (evt) { | 209 | if (evt) |
| 210 | dwc3_free_one_event_buffer(dwc, evt); | 210 | dwc3_free_one_event_buffer(dwc, evt); |
| 211 | dwc->ev_buffs[i] = NULL; | ||
| 212 | } | ||
| 213 | } | 211 | } |
| 212 | |||
| 213 | kfree(dwc->ev_buffs); | ||
| 214 | } | 214 | } |
| 215 | 215 | ||
| 216 | /** | 216 | /** |
diff --git a/drivers/usb/dwc3/ep0.c b/drivers/usb/dwc3/ep0.c index 25910e251c04..3584a169886f 100644 --- a/drivers/usb/dwc3/ep0.c +++ b/drivers/usb/dwc3/ep0.c | |||
| @@ -353,6 +353,9 @@ static int dwc3_ep0_handle_feature(struct dwc3 *dwc, | |||
| 353 | 353 | ||
| 354 | dwc->test_mode_nr = wIndex >> 8; | 354 | dwc->test_mode_nr = wIndex >> 8; |
| 355 | dwc->test_mode = true; | 355 | dwc->test_mode = true; |
| 356 | break; | ||
| 357 | default: | ||
| 358 | return -EINVAL; | ||
| 356 | } | 359 | } |
| 357 | break; | 360 | break; |
| 358 | 361 | ||
| @@ -559,15 +562,20 @@ static void dwc3_ep0_complete_data(struct dwc3 *dwc, | |||
| 559 | length = trb->size & DWC3_TRB_SIZE_MASK; | 562 | length = trb->size & DWC3_TRB_SIZE_MASK; |
| 560 | 563 | ||
| 561 | if (dwc->ep0_bounced) { | 564 | if (dwc->ep0_bounced) { |
| 565 | unsigned transfer_size = ur->length; | ||
| 566 | unsigned maxp = ep0->endpoint.maxpacket; | ||
| 567 | |||
| 568 | transfer_size += (maxp - (transfer_size % maxp)); | ||
| 562 | transferred = min_t(u32, ur->length, | 569 | transferred = min_t(u32, ur->length, |
| 563 | ep0->endpoint.maxpacket - length); | 570 | transfer_size - length); |
| 564 | memcpy(ur->buf, dwc->ep0_bounce, transferred); | 571 | memcpy(ur->buf, dwc->ep0_bounce, transferred); |
| 565 | dwc->ep0_bounced = false; | 572 | dwc->ep0_bounced = false; |
| 566 | } else { | 573 | } else { |
| 567 | transferred = ur->length - length; | 574 | transferred = ur->length - length; |
| 568 | ur->actual += transferred; | ||
| 569 | } | 575 | } |
| 570 | 576 | ||
| 577 | ur->actual += transferred; | ||
| 578 | |||
| 571 | if ((epnum & 1) && ur->actual < ur->length) { | 579 | if ((epnum & 1) && ur->actual < ur->length) { |
| 572 | /* for some reason we did not get everything out */ | 580 | /* for some reason we did not get everything out */ |
| 573 | 581 | ||
diff --git a/drivers/usb/gadget/at91_udc.c b/drivers/usb/gadget/at91_udc.c index 0c935d7c65bd..9d7bcd910074 100644 --- a/drivers/usb/gadget/at91_udc.c +++ b/drivers/usb/gadget/at91_udc.c | |||
| @@ -1863,8 +1863,8 @@ static int __devinit at91udc_probe(struct platform_device *pdev) | |||
| 1863 | mod_timer(&udc->vbus_timer, | 1863 | mod_timer(&udc->vbus_timer, |
| 1864 | jiffies + VBUS_POLL_TIMEOUT); | 1864 | jiffies + VBUS_POLL_TIMEOUT); |
| 1865 | } else { | 1865 | } else { |
| 1866 | if (request_irq(udc->board.vbus_pin, at91_vbus_irq, | 1866 | if (request_irq(gpio_to_irq(udc->board.vbus_pin), |
| 1867 | 0, driver_name, udc)) { | 1867 | at91_vbus_irq, 0, driver_name, udc)) { |
| 1868 | DBG("request vbus irq %d failed\n", | 1868 | DBG("request vbus irq %d failed\n", |
| 1869 | udc->board.vbus_pin); | 1869 | udc->board.vbus_pin); |
| 1870 | retval = -EBUSY; | 1870 | retval = -EBUSY; |
| @@ -1886,7 +1886,7 @@ static int __devinit at91udc_probe(struct platform_device *pdev) | |||
| 1886 | return 0; | 1886 | return 0; |
| 1887 | fail4: | 1887 | fail4: |
| 1888 | if (gpio_is_valid(udc->board.vbus_pin) && !udc->board.vbus_polled) | 1888 | if (gpio_is_valid(udc->board.vbus_pin) && !udc->board.vbus_polled) |
| 1889 | free_irq(udc->board.vbus_pin, udc); | 1889 | free_irq(gpio_to_irq(udc->board.vbus_pin), udc); |
| 1890 | fail3: | 1890 | fail3: |
| 1891 | if (gpio_is_valid(udc->board.vbus_pin)) | 1891 | if (gpio_is_valid(udc->board.vbus_pin)) |
| 1892 | gpio_free(udc->board.vbus_pin); | 1892 | gpio_free(udc->board.vbus_pin); |
| @@ -1924,7 +1924,7 @@ static int __exit at91udc_remove(struct platform_device *pdev) | |||
| 1924 | device_init_wakeup(&pdev->dev, 0); | 1924 | device_init_wakeup(&pdev->dev, 0); |
| 1925 | remove_debug_file(udc); | 1925 | remove_debug_file(udc); |
| 1926 | if (gpio_is_valid(udc->board.vbus_pin)) { | 1926 | if (gpio_is_valid(udc->board.vbus_pin)) { |
| 1927 | free_irq(udc->board.vbus_pin, udc); | 1927 | free_irq(gpio_to_irq(udc->board.vbus_pin), udc); |
| 1928 | gpio_free(udc->board.vbus_pin); | 1928 | gpio_free(udc->board.vbus_pin); |
| 1929 | } | 1929 | } |
| 1930 | free_irq(udc->udp_irq, udc); | 1930 | free_irq(udc->udp_irq, udc); |
diff --git a/drivers/usb/gadget/f_fs.c b/drivers/usb/gadget/f_fs.c index 1cbba70836bc..f52cb1ae45d9 100644 --- a/drivers/usb/gadget/f_fs.c +++ b/drivers/usb/gadget/f_fs.c | |||
| @@ -712,7 +712,7 @@ static long ffs_ep0_ioctl(struct file *file, unsigned code, unsigned long value) | |||
| 712 | if (code == FUNCTIONFS_INTERFACE_REVMAP) { | 712 | if (code == FUNCTIONFS_INTERFACE_REVMAP) { |
| 713 | struct ffs_function *func = ffs->func; | 713 | struct ffs_function *func = ffs->func; |
| 714 | ret = func ? ffs_func_revmap_intf(func, value) : -ENODEV; | 714 | ret = func ? ffs_func_revmap_intf(func, value) : -ENODEV; |
| 715 | } else if (gadget->ops->ioctl) { | 715 | } else if (gadget && gadget->ops->ioctl) { |
| 716 | ret = gadget->ops->ioctl(gadget, code, value); | 716 | ret = gadget->ops->ioctl(gadget, code, value); |
| 717 | } else { | 717 | } else { |
| 718 | ret = -ENOTTY; | 718 | ret = -ENOTTY; |
| @@ -1382,6 +1382,7 @@ static void functionfs_unbind(struct ffs_data *ffs) | |||
| 1382 | ffs->ep0req = NULL; | 1382 | ffs->ep0req = NULL; |
| 1383 | ffs->gadget = NULL; | 1383 | ffs->gadget = NULL; |
| 1384 | ffs_data_put(ffs); | 1384 | ffs_data_put(ffs); |
| 1385 | clear_bit(FFS_FL_BOUND, &ffs->flags); | ||
| 1385 | } | 1386 | } |
| 1386 | } | 1387 | } |
| 1387 | 1388 | ||
diff --git a/drivers/usb/gadget/f_rndis.c b/drivers/usb/gadget/f_rndis.c index 7b1cf18df5e3..52343654f5df 100644 --- a/drivers/usb/gadget/f_rndis.c +++ b/drivers/usb/gadget/f_rndis.c | |||
| @@ -500,6 +500,7 @@ rndis_setup(struct usb_function *f, const struct usb_ctrlrequest *ctrl) | |||
| 500 | if (buf) { | 500 | if (buf) { |
| 501 | memcpy(req->buf, buf, n); | 501 | memcpy(req->buf, buf, n); |
| 502 | req->complete = rndis_response_complete; | 502 | req->complete = rndis_response_complete; |
| 503 | req->context = rndis; | ||
| 503 | rndis_free_response(rndis->config, buf); | 504 | rndis_free_response(rndis->config, buf); |
| 504 | value = n; | 505 | value = n; |
| 505 | } | 506 | } |
diff --git a/drivers/usb/gadget/fsl_udc_core.c b/drivers/usb/gadget/fsl_udc_core.c index 5f94e79cd6b9..55abfb6bd612 100644 --- a/drivers/usb/gadget/fsl_udc_core.c +++ b/drivers/usb/gadget/fsl_udc_core.c | |||
| @@ -730,7 +730,7 @@ static void fsl_queue_td(struct fsl_ep *ep, struct fsl_req *req) | |||
| 730 | : (1 << (ep_index(ep))); | 730 | : (1 << (ep_index(ep))); |
| 731 | 731 | ||
| 732 | /* check if the pipe is empty */ | 732 | /* check if the pipe is empty */ |
| 733 | if (!(list_empty(&ep->queue))) { | 733 | if (!(list_empty(&ep->queue)) && !(ep_index(ep) == 0)) { |
| 734 | /* Add td to the end */ | 734 | /* Add td to the end */ |
| 735 | struct fsl_req *lastreq; | 735 | struct fsl_req *lastreq; |
| 736 | lastreq = list_entry(ep->queue.prev, struct fsl_req, queue); | 736 | lastreq = list_entry(ep->queue.prev, struct fsl_req, queue); |
| @@ -918,10 +918,6 @@ fsl_ep_queue(struct usb_ep *_ep, struct usb_request *_req, gfp_t gfp_flags) | |||
| 918 | return -ENOMEM; | 918 | return -ENOMEM; |
| 919 | } | 919 | } |
| 920 | 920 | ||
| 921 | /* Update ep0 state */ | ||
| 922 | if ((ep_index(ep) == 0)) | ||
| 923 | udc->ep0_state = DATA_STATE_XMIT; | ||
| 924 | |||
| 925 | /* irq handler advances the queue */ | 921 | /* irq handler advances the queue */ |
| 926 | if (req != NULL) | 922 | if (req != NULL) |
| 927 | list_add_tail(&req->queue, &ep->queue); | 923 | list_add_tail(&req->queue, &ep->queue); |
| @@ -1279,7 +1275,8 @@ static int ep0_prime_status(struct fsl_udc *udc, int direction) | |||
| 1279 | udc->ep0_dir = USB_DIR_OUT; | 1275 | udc->ep0_dir = USB_DIR_OUT; |
| 1280 | 1276 | ||
| 1281 | ep = &udc->eps[0]; | 1277 | ep = &udc->eps[0]; |
| 1282 | udc->ep0_state = WAIT_FOR_OUT_STATUS; | 1278 | if (udc->ep0_state != DATA_STATE_XMIT) |
| 1279 | udc->ep0_state = WAIT_FOR_OUT_STATUS; | ||
| 1283 | 1280 | ||
| 1284 | req->ep = ep; | 1281 | req->ep = ep; |
| 1285 | req->req.length = 0; | 1282 | req->req.length = 0; |
| @@ -1384,6 +1381,9 @@ static void ch9getstatus(struct fsl_udc *udc, u8 request_type, u16 value, | |||
| 1384 | 1381 | ||
| 1385 | list_add_tail(&req->queue, &ep->queue); | 1382 | list_add_tail(&req->queue, &ep->queue); |
| 1386 | udc->ep0_state = DATA_STATE_XMIT; | 1383 | udc->ep0_state = DATA_STATE_XMIT; |
| 1384 | if (ep0_prime_status(udc, EP_DIR_OUT)) | ||
| 1385 | ep0stall(udc); | ||
| 1386 | |||
| 1387 | return; | 1387 | return; |
| 1388 | stall: | 1388 | stall: |
| 1389 | ep0stall(udc); | 1389 | ep0stall(udc); |
| @@ -1492,6 +1492,14 @@ static void setup_received_irq(struct fsl_udc *udc, | |||
| 1492 | spin_lock(&udc->lock); | 1492 | spin_lock(&udc->lock); |
| 1493 | udc->ep0_state = (setup->bRequestType & USB_DIR_IN) | 1493 | udc->ep0_state = (setup->bRequestType & USB_DIR_IN) |
| 1494 | ? DATA_STATE_XMIT : DATA_STATE_RECV; | 1494 | ? DATA_STATE_XMIT : DATA_STATE_RECV; |
| 1495 | /* | ||
| 1496 | * If the data stage is IN, send status prime immediately. | ||
| 1497 | * See 2.0 Spec chapter 8.5.3.3 for detail. | ||
| 1498 | */ | ||
| 1499 | if (udc->ep0_state == DATA_STATE_XMIT) | ||
| 1500 | if (ep0_prime_status(udc, EP_DIR_OUT)) | ||
| 1501 | ep0stall(udc); | ||
| 1502 | |||
| 1495 | } else { | 1503 | } else { |
| 1496 | /* No data phase, IN status from gadget */ | 1504 | /* No data phase, IN status from gadget */ |
| 1497 | udc->ep0_dir = USB_DIR_IN; | 1505 | udc->ep0_dir = USB_DIR_IN; |
| @@ -1520,9 +1528,8 @@ static void ep0_req_complete(struct fsl_udc *udc, struct fsl_ep *ep0, | |||
| 1520 | 1528 | ||
| 1521 | switch (udc->ep0_state) { | 1529 | switch (udc->ep0_state) { |
| 1522 | case DATA_STATE_XMIT: | 1530 | case DATA_STATE_XMIT: |
| 1523 | /* receive status phase */ | 1531 | /* already primed at setup_received_irq */ |
| 1524 | if (ep0_prime_status(udc, EP_DIR_OUT)) | 1532 | udc->ep0_state = WAIT_FOR_OUT_STATUS; |
| 1525 | ep0stall(udc); | ||
| 1526 | break; | 1533 | break; |
| 1527 | case DATA_STATE_RECV: | 1534 | case DATA_STATE_RECV: |
| 1528 | /* send status phase */ | 1535 | /* send status phase */ |
diff --git a/drivers/usb/gadget/g_ffs.c b/drivers/usb/gadget/g_ffs.c index 331cd6729d3c..a85eaf40b948 100644 --- a/drivers/usb/gadget/g_ffs.c +++ b/drivers/usb/gadget/g_ffs.c | |||
| @@ -161,7 +161,7 @@ static struct usb_composite_driver gfs_driver = { | |||
| 161 | static struct ffs_data *gfs_ffs_data; | 161 | static struct ffs_data *gfs_ffs_data; |
| 162 | static unsigned long gfs_registered; | 162 | static unsigned long gfs_registered; |
| 163 | 163 | ||
| 164 | static int gfs_init(void) | 164 | static int __init gfs_init(void) |
| 165 | { | 165 | { |
| 166 | ENTER(); | 166 | ENTER(); |
| 167 | 167 | ||
| @@ -169,7 +169,7 @@ static int gfs_init(void) | |||
| 169 | } | 169 | } |
| 170 | module_init(gfs_init); | 170 | module_init(gfs_init); |
| 171 | 171 | ||
| 172 | static void gfs_exit(void) | 172 | static void __exit gfs_exit(void) |
| 173 | { | 173 | { |
| 174 | ENTER(); | 174 | ENTER(); |
| 175 | 175 | ||
diff --git a/drivers/usb/gadget/inode.c b/drivers/usb/gadget/inode.c index 8793f32bab11..e58b16442971 100644 --- a/drivers/usb/gadget/inode.c +++ b/drivers/usb/gadget/inode.c | |||
| @@ -1574,7 +1574,6 @@ static void destroy_ep_files (struct dev_data *dev) | |||
| 1574 | DBG (dev, "%s %d\n", __func__, dev->state); | 1574 | DBG (dev, "%s %d\n", __func__, dev->state); |
| 1575 | 1575 | ||
| 1576 | /* dev->state must prevent interference */ | 1576 | /* dev->state must prevent interference */ |
| 1577 | restart: | ||
| 1578 | spin_lock_irq (&dev->lock); | 1577 | spin_lock_irq (&dev->lock); |
| 1579 | while (!list_empty(&dev->epfiles)) { | 1578 | while (!list_empty(&dev->epfiles)) { |
| 1580 | struct ep_data *ep; | 1579 | struct ep_data *ep; |
diff --git a/drivers/usb/gadget/s3c-hsotg.c b/drivers/usb/gadget/s3c-hsotg.c index 69295ba9d99a..105b206cd844 100644 --- a/drivers/usb/gadget/s3c-hsotg.c +++ b/drivers/usb/gadget/s3c-hsotg.c | |||
| @@ -340,7 +340,7 @@ static void s3c_hsotg_init_fifo(struct s3c_hsotg *hsotg) | |||
| 340 | /* currently we allocate TX FIFOs for all possible endpoints, | 340 | /* currently we allocate TX FIFOs for all possible endpoints, |
| 341 | * and assume that they are all the same size. */ | 341 | * and assume that they are all the same size. */ |
| 342 | 342 | ||
| 343 | for (ep = 0; ep <= 15; ep++) { | 343 | for (ep = 1; ep <= 15; ep++) { |
| 344 | val = addr; | 344 | val = addr; |
| 345 | val |= size << S3C_DPTXFSIZn_DPTxFSize_SHIFT; | 345 | val |= size << S3C_DPTXFSIZn_DPTxFSize_SHIFT; |
| 346 | addr += size; | 346 | addr += size; |
| @@ -741,7 +741,7 @@ static void s3c_hsotg_start_req(struct s3c_hsotg *hsotg, | |||
| 741 | /* write size / packets */ | 741 | /* write size / packets */ |
| 742 | writel(epsize, hsotg->regs + epsize_reg); | 742 | writel(epsize, hsotg->regs + epsize_reg); |
| 743 | 743 | ||
| 744 | if (using_dma(hsotg)) { | 744 | if (using_dma(hsotg) && !continuing) { |
| 745 | unsigned int dma_reg; | 745 | unsigned int dma_reg; |
| 746 | 746 | ||
| 747 | /* write DMA address to control register, buffer already | 747 | /* write DMA address to control register, buffer already |
| @@ -1696,10 +1696,12 @@ static void s3c_hsotg_set_ep_maxpacket(struct s3c_hsotg *hsotg, | |||
| 1696 | reg |= mpsval; | 1696 | reg |= mpsval; |
| 1697 | writel(reg, regs + S3C_DIEPCTL(ep)); | 1697 | writel(reg, regs + S3C_DIEPCTL(ep)); |
| 1698 | 1698 | ||
| 1699 | reg = readl(regs + S3C_DOEPCTL(ep)); | 1699 | if (ep) { |
| 1700 | reg &= ~S3C_DxEPCTL_MPS_MASK; | 1700 | reg = readl(regs + S3C_DOEPCTL(ep)); |
| 1701 | reg |= mpsval; | 1701 | reg &= ~S3C_DxEPCTL_MPS_MASK; |
| 1702 | writel(reg, regs + S3C_DOEPCTL(ep)); | 1702 | reg |= mpsval; |
| 1703 | writel(reg, regs + S3C_DOEPCTL(ep)); | ||
| 1704 | } | ||
| 1703 | 1705 | ||
| 1704 | return; | 1706 | return; |
| 1705 | 1707 | ||
| @@ -1919,7 +1921,8 @@ static void s3c_hsotg_epint(struct s3c_hsotg *hsotg, unsigned int idx, | |||
| 1919 | ints & S3C_DIEPMSK_TxFIFOEmpty) { | 1921 | ints & S3C_DIEPMSK_TxFIFOEmpty) { |
| 1920 | dev_dbg(hsotg->dev, "%s: ep%d: TxFIFOEmpty\n", | 1922 | dev_dbg(hsotg->dev, "%s: ep%d: TxFIFOEmpty\n", |
| 1921 | __func__, idx); | 1923 | __func__, idx); |
| 1922 | s3c_hsotg_trytx(hsotg, hs_ep); | 1924 | if (!using_dma(hsotg)) |
| 1925 | s3c_hsotg_trytx(hsotg, hs_ep); | ||
| 1923 | } | 1926 | } |
| 1924 | } | 1927 | } |
| 1925 | } | 1928 | } |
diff --git a/drivers/usb/gadget/udc-core.c b/drivers/usb/gadget/udc-core.c index 56da49f31d6c..2fa9865babed 100644 --- a/drivers/usb/gadget/udc-core.c +++ b/drivers/usb/gadget/udc-core.c | |||
| @@ -264,8 +264,8 @@ static void usb_gadget_remove_driver(struct usb_udc *udc) | |||
| 264 | if (udc_is_newstyle(udc)) { | 264 | if (udc_is_newstyle(udc)) { |
| 265 | udc->driver->disconnect(udc->gadget); | 265 | udc->driver->disconnect(udc->gadget); |
| 266 | udc->driver->unbind(udc->gadget); | 266 | udc->driver->unbind(udc->gadget); |
| 267 | usb_gadget_udc_stop(udc->gadget, udc->driver); | ||
| 268 | usb_gadget_disconnect(udc->gadget); | 267 | usb_gadget_disconnect(udc->gadget); |
| 268 | usb_gadget_udc_stop(udc->gadget, udc->driver); | ||
| 269 | } else { | 269 | } else { |
| 270 | usb_gadget_stop(udc->gadget, udc->driver); | 270 | usb_gadget_stop(udc->gadget, udc->driver); |
| 271 | } | 271 | } |
| @@ -411,8 +411,12 @@ static ssize_t usb_udc_softconn_store(struct device *dev, | |||
| 411 | struct usb_udc *udc = container_of(dev, struct usb_udc, dev); | 411 | struct usb_udc *udc = container_of(dev, struct usb_udc, dev); |
| 412 | 412 | ||
| 413 | if (sysfs_streq(buf, "connect")) { | 413 | if (sysfs_streq(buf, "connect")) { |
| 414 | if (udc_is_newstyle(udc)) | ||
| 415 | usb_gadget_udc_start(udc->gadget, udc->driver); | ||
| 414 | usb_gadget_connect(udc->gadget); | 416 | usb_gadget_connect(udc->gadget); |
| 415 | } else if (sysfs_streq(buf, "disconnect")) { | 417 | } else if (sysfs_streq(buf, "disconnect")) { |
| 418 | if (udc_is_newstyle(udc)) | ||
| 419 | usb_gadget_udc_stop(udc->gadget, udc->driver); | ||
| 416 | usb_gadget_disconnect(udc->gadget); | 420 | usb_gadget_disconnect(udc->gadget); |
| 417 | } else { | 421 | } else { |
| 418 | dev_err(dev, "unsupported command '%s'\n", buf); | 422 | dev_err(dev, "unsupported command '%s'\n", buf); |
diff --git a/drivers/usb/gadget/uvc_queue.c b/drivers/usb/gadget/uvc_queue.c index d776adb2da67..0cdf89d32a15 100644 --- a/drivers/usb/gadget/uvc_queue.c +++ b/drivers/usb/gadget/uvc_queue.c | |||
| @@ -543,11 +543,11 @@ done: | |||
| 543 | return ret; | 543 | return ret; |
| 544 | } | 544 | } |
| 545 | 545 | ||
| 546 | /* called with queue->irqlock held.. */ | ||
| 546 | static struct uvc_buffer * | 547 | static struct uvc_buffer * |
| 547 | uvc_queue_next_buffer(struct uvc_video_queue *queue, struct uvc_buffer *buf) | 548 | uvc_queue_next_buffer(struct uvc_video_queue *queue, struct uvc_buffer *buf) |
| 548 | { | 549 | { |
| 549 | struct uvc_buffer *nextbuf; | 550 | struct uvc_buffer *nextbuf; |
| 550 | unsigned long flags; | ||
| 551 | 551 | ||
| 552 | if ((queue->flags & UVC_QUEUE_DROP_INCOMPLETE) && | 552 | if ((queue->flags & UVC_QUEUE_DROP_INCOMPLETE) && |
| 553 | buf->buf.length != buf->buf.bytesused) { | 553 | buf->buf.length != buf->buf.bytesused) { |
| @@ -556,14 +556,12 @@ uvc_queue_next_buffer(struct uvc_video_queue *queue, struct uvc_buffer *buf) | |||
| 556 | return buf; | 556 | return buf; |
| 557 | } | 557 | } |
| 558 | 558 | ||
| 559 | spin_lock_irqsave(&queue->irqlock, flags); | ||
| 560 | list_del(&buf->queue); | 559 | list_del(&buf->queue); |
| 561 | if (!list_empty(&queue->irqqueue)) | 560 | if (!list_empty(&queue->irqqueue)) |
| 562 | nextbuf = list_first_entry(&queue->irqqueue, struct uvc_buffer, | 561 | nextbuf = list_first_entry(&queue->irqqueue, struct uvc_buffer, |
| 563 | queue); | 562 | queue); |
| 564 | else | 563 | else |
| 565 | nextbuf = NULL; | 564 | nextbuf = NULL; |
| 566 | spin_unlock_irqrestore(&queue->irqlock, flags); | ||
| 567 | 565 | ||
| 568 | buf->buf.sequence = queue->sequence++; | 566 | buf->buf.sequence = queue->sequence++; |
| 569 | do_gettimeofday(&buf->buf.timestamp); | 567 | do_gettimeofday(&buf->buf.timestamp); |
diff --git a/drivers/usb/host/ehci-fsl.c b/drivers/usb/host/ehci-fsl.c index 3e7345172e03..d0a84bd3f3eb 100644 --- a/drivers/usb/host/ehci-fsl.c +++ b/drivers/usb/host/ehci-fsl.c | |||
| @@ -218,6 +218,9 @@ static void ehci_fsl_setup_phy(struct ehci_hcd *ehci, | |||
| 218 | u32 portsc; | 218 | u32 portsc; |
| 219 | struct usb_hcd *hcd = ehci_to_hcd(ehci); | 219 | struct usb_hcd *hcd = ehci_to_hcd(ehci); |
| 220 | void __iomem *non_ehci = hcd->regs; | 220 | void __iomem *non_ehci = hcd->regs; |
| 221 | struct fsl_usb2_platform_data *pdata; | ||
| 222 | |||
| 223 | pdata = hcd->self.controller->platform_data; | ||
| 221 | 224 | ||
| 222 | portsc = ehci_readl(ehci, &ehci->regs->port_status[port_offset]); | 225 | portsc = ehci_readl(ehci, &ehci->regs->port_status[port_offset]); |
| 223 | portsc &= ~(PORT_PTS_MSK | PORT_PTS_PTW); | 226 | portsc &= ~(PORT_PTS_MSK | PORT_PTS_PTW); |
| @@ -234,7 +237,9 @@ static void ehci_fsl_setup_phy(struct ehci_hcd *ehci, | |||
| 234 | /* fall through */ | 237 | /* fall through */ |
| 235 | case FSL_USB2_PHY_UTMI: | 238 | case FSL_USB2_PHY_UTMI: |
| 236 | /* enable UTMI PHY */ | 239 | /* enable UTMI PHY */ |
| 237 | setbits32(non_ehci + FSL_SOC_USB_CTRL, CTRL_UTMI_PHY_EN); | 240 | if (pdata->have_sysif_regs) |
| 241 | setbits32(non_ehci + FSL_SOC_USB_CTRL, | ||
| 242 | CTRL_UTMI_PHY_EN); | ||
| 238 | portsc |= PORT_PTS_UTMI; | 243 | portsc |= PORT_PTS_UTMI; |
| 239 | break; | 244 | break; |
| 240 | case FSL_USB2_PHY_NONE: | 245 | case FSL_USB2_PHY_NONE: |
diff --git a/drivers/usb/host/ehci-hcd.c b/drivers/usb/host/ehci-hcd.c index 057cdda7a489..4a3bc5b7a06f 100644 --- a/drivers/usb/host/ehci-hcd.c +++ b/drivers/usb/host/ehci-hcd.c | |||
| @@ -347,6 +347,8 @@ static int ehci_reset (struct ehci_hcd *ehci) | |||
| 347 | if (ehci->debug) | 347 | if (ehci->debug) |
| 348 | dbgp_external_startup(); | 348 | dbgp_external_startup(); |
| 349 | 349 | ||
| 350 | ehci->port_c_suspend = ehci->suspended_ports = | ||
| 351 | ehci->resuming_ports = 0; | ||
| 350 | return retval; | 352 | return retval; |
| 351 | } | 353 | } |
| 352 | 354 | ||
| @@ -856,8 +858,13 @@ static irqreturn_t ehci_irq (struct usb_hcd *hcd) | |||
| 856 | goto dead; | 858 | goto dead; |
| 857 | } | 859 | } |
| 858 | 860 | ||
| 861 | /* | ||
| 862 | * We don't use STS_FLR, but some controllers don't like it to | ||
| 863 | * remain on, so mask it out along with the other status bits. | ||
| 864 | */ | ||
| 865 | masked_status = status & (INTR_MASK | STS_FLR); | ||
| 866 | |||
| 859 | /* Shared IRQ? */ | 867 | /* Shared IRQ? */ |
| 860 | masked_status = status & INTR_MASK; | ||
| 861 | if (!masked_status || unlikely(ehci->rh_state == EHCI_RH_HALTED)) { | 868 | if (!masked_status || unlikely(ehci->rh_state == EHCI_RH_HALTED)) { |
| 862 | spin_unlock(&ehci->lock); | 869 | spin_unlock(&ehci->lock); |
| 863 | return IRQ_NONE; | 870 | return IRQ_NONE; |
| @@ -908,7 +915,7 @@ static irqreturn_t ehci_irq (struct usb_hcd *hcd) | |||
| 908 | pcd_status = status; | 915 | pcd_status = status; |
| 909 | 916 | ||
| 910 | /* resume root hub? */ | 917 | /* resume root hub? */ |
| 911 | if (!(cmd & CMD_RUN)) | 918 | if (ehci->rh_state == EHCI_RH_SUSPENDED) |
| 912 | usb_hcd_resume_root_hub(hcd); | 919 | usb_hcd_resume_root_hub(hcd); |
| 913 | 920 | ||
| 914 | /* get per-port change detect bits */ | 921 | /* get per-port change detect bits */ |
| @@ -939,6 +946,7 @@ static irqreturn_t ehci_irq (struct usb_hcd *hcd) | |||
| 939 | * like usb_port_resume() does. | 946 | * like usb_port_resume() does. |
| 940 | */ | 947 | */ |
| 941 | ehci->reset_done[i] = jiffies + msecs_to_jiffies(25); | 948 | ehci->reset_done[i] = jiffies + msecs_to_jiffies(25); |
| 949 | set_bit(i, &ehci->resuming_ports); | ||
| 942 | ehci_dbg (ehci, "port %d remote wakeup\n", i + 1); | 950 | ehci_dbg (ehci, "port %d remote wakeup\n", i + 1); |
| 943 | mod_timer(&hcd->rh_timer, ehci->reset_done[i]); | 951 | mod_timer(&hcd->rh_timer, ehci->reset_done[i]); |
| 944 | } | 952 | } |
diff --git a/drivers/usb/host/ehci-hub.c b/drivers/usb/host/ehci-hub.c index 256fbd42e48c..38fe07623152 100644 --- a/drivers/usb/host/ehci-hub.c +++ b/drivers/usb/host/ehci-hub.c | |||
| @@ -223,15 +223,10 @@ static int ehci_bus_suspend (struct usb_hcd *hcd) | |||
| 223 | * remote wakeup, we must fail the suspend. | 223 | * remote wakeup, we must fail the suspend. |
| 224 | */ | 224 | */ |
| 225 | if (hcd->self.root_hub->do_remote_wakeup) { | 225 | if (hcd->self.root_hub->do_remote_wakeup) { |
| 226 | port = HCS_N_PORTS(ehci->hcs_params); | 226 | if (ehci->resuming_ports) { |
| 227 | while (port--) { | 227 | spin_unlock_irq(&ehci->lock); |
| 228 | if (ehci->reset_done[port] != 0) { | 228 | ehci_dbg(ehci, "suspend failed because a port is resuming\n"); |
| 229 | spin_unlock_irq(&ehci->lock); | 229 | return -EBUSY; |
| 230 | ehci_dbg(ehci, "suspend failed because " | ||
| 231 | "port %d is resuming\n", | ||
| 232 | port + 1); | ||
| 233 | return -EBUSY; | ||
| 234 | } | ||
| 235 | } | 230 | } |
| 236 | } | 231 | } |
| 237 | 232 | ||
| @@ -554,16 +549,12 @@ static int | |||
| 554 | ehci_hub_status_data (struct usb_hcd *hcd, char *buf) | 549 | ehci_hub_status_data (struct usb_hcd *hcd, char *buf) |
| 555 | { | 550 | { |
| 556 | struct ehci_hcd *ehci = hcd_to_ehci (hcd); | 551 | struct ehci_hcd *ehci = hcd_to_ehci (hcd); |
| 557 | u32 temp, status = 0; | 552 | u32 temp, status; |
| 558 | u32 mask; | 553 | u32 mask; |
| 559 | int ports, i, retval = 1; | 554 | int ports, i, retval = 1; |
| 560 | unsigned long flags; | 555 | unsigned long flags; |
| 561 | u32 ppcd = 0; | 556 | u32 ppcd = 0; |
| 562 | 557 | ||
| 563 | /* if !USB_SUSPEND, root hub timers won't get shut down ... */ | ||
| 564 | if (ehci->rh_state != EHCI_RH_RUNNING) | ||
| 565 | return 0; | ||
| 566 | |||
| 567 | /* init status to no-changes */ | 558 | /* init status to no-changes */ |
| 568 | buf [0] = 0; | 559 | buf [0] = 0; |
| 569 | ports = HCS_N_PORTS (ehci->hcs_params); | 560 | ports = HCS_N_PORTS (ehci->hcs_params); |
| @@ -572,6 +563,11 @@ ehci_hub_status_data (struct usb_hcd *hcd, char *buf) | |||
| 572 | retval++; | 563 | retval++; |
| 573 | } | 564 | } |
| 574 | 565 | ||
| 566 | /* Inform the core about resumes-in-progress by returning | ||
| 567 | * a non-zero value even if there are no status changes. | ||
| 568 | */ | ||
| 569 | status = ehci->resuming_ports; | ||
| 570 | |||
| 575 | /* Some boards (mostly VIA?) report bogus overcurrent indications, | 571 | /* Some boards (mostly VIA?) report bogus overcurrent indications, |
| 576 | * causing massive log spam unless we completely ignore them. It | 572 | * causing massive log spam unless we completely ignore them. It |
| 577 | * may be relevant that VIA VT8235 controllers, where PORT_POWER is | 573 | * may be relevant that VIA VT8235 controllers, where PORT_POWER is |
| @@ -846,6 +842,7 @@ static int ehci_hub_control ( | |||
| 846 | ehci_writel(ehci, | 842 | ehci_writel(ehci, |
| 847 | temp & ~(PORT_RWC_BITS | PORT_RESUME), | 843 | temp & ~(PORT_RWC_BITS | PORT_RESUME), |
| 848 | status_reg); | 844 | status_reg); |
| 845 | clear_bit(wIndex, &ehci->resuming_ports); | ||
| 849 | retval = handshake(ehci, status_reg, | 846 | retval = handshake(ehci, status_reg, |
| 850 | PORT_RESUME, 0, 2000 /* 2msec */); | 847 | PORT_RESUME, 0, 2000 /* 2msec */); |
| 851 | if (retval != 0) { | 848 | if (retval != 0) { |
| @@ -864,6 +861,7 @@ static int ehci_hub_control ( | |||
| 864 | ehci->reset_done[wIndex])) { | 861 | ehci->reset_done[wIndex])) { |
| 865 | status |= USB_PORT_STAT_C_RESET << 16; | 862 | status |= USB_PORT_STAT_C_RESET << 16; |
| 866 | ehci->reset_done [wIndex] = 0; | 863 | ehci->reset_done [wIndex] = 0; |
| 864 | clear_bit(wIndex, &ehci->resuming_ports); | ||
| 867 | 865 | ||
| 868 | /* force reset to complete */ | 866 | /* force reset to complete */ |
| 869 | ehci_writel(ehci, temp & ~(PORT_RWC_BITS | PORT_RESET), | 867 | ehci_writel(ehci, temp & ~(PORT_RWC_BITS | PORT_RESET), |
| @@ -884,8 +882,10 @@ static int ehci_hub_control ( | |||
| 884 | ehci_readl(ehci, status_reg)); | 882 | ehci_readl(ehci, status_reg)); |
| 885 | } | 883 | } |
| 886 | 884 | ||
| 887 | if (!(temp & (PORT_RESUME|PORT_RESET))) | 885 | if (!(temp & (PORT_RESUME|PORT_RESET))) { |
| 888 | ehci->reset_done[wIndex] = 0; | 886 | ehci->reset_done[wIndex] = 0; |
| 887 | clear_bit(wIndex, &ehci->resuming_ports); | ||
| 888 | } | ||
| 889 | 889 | ||
| 890 | /* transfer dedicated ports to the companion hc */ | 890 | /* transfer dedicated ports to the companion hc */ |
| 891 | if ((temp & PORT_CONNECT) && | 891 | if ((temp & PORT_CONNECT) && |
| @@ -920,6 +920,7 @@ static int ehci_hub_control ( | |||
| 920 | status |= USB_PORT_STAT_SUSPEND; | 920 | status |= USB_PORT_STAT_SUSPEND; |
| 921 | } else if (test_bit(wIndex, &ehci->suspended_ports)) { | 921 | } else if (test_bit(wIndex, &ehci->suspended_ports)) { |
| 922 | clear_bit(wIndex, &ehci->suspended_ports); | 922 | clear_bit(wIndex, &ehci->suspended_ports); |
| 923 | clear_bit(wIndex, &ehci->resuming_ports); | ||
| 923 | ehci->reset_done[wIndex] = 0; | 924 | ehci->reset_done[wIndex] = 0; |
| 924 | if (temp & PORT_PE) | 925 | if (temp & PORT_PE) |
| 925 | set_bit(wIndex, &ehci->port_c_suspend); | 926 | set_bit(wIndex, &ehci->port_c_suspend); |
diff --git a/drivers/usb/host/ehci-omap.c b/drivers/usb/host/ehci-omap.c index bba9850f32f0..5c78f9e71466 100644 --- a/drivers/usb/host/ehci-omap.c +++ b/drivers/usb/host/ehci-omap.c | |||
| @@ -42,6 +42,7 @@ | |||
| 42 | #include <plat/usb.h> | 42 | #include <plat/usb.h> |
| 43 | #include <linux/regulator/consumer.h> | 43 | #include <linux/regulator/consumer.h> |
| 44 | #include <linux/pm_runtime.h> | 44 | #include <linux/pm_runtime.h> |
| 45 | #include <linux/gpio.h> | ||
| 45 | 46 | ||
| 46 | /* EHCI Register Set */ | 47 | /* EHCI Register Set */ |
| 47 | #define EHCI_INSNREG04 (0xA0) | 48 | #define EHCI_INSNREG04 (0xA0) |
| @@ -191,6 +192,19 @@ static int ehci_hcd_omap_probe(struct platform_device *pdev) | |||
| 191 | } | 192 | } |
| 192 | } | 193 | } |
| 193 | 194 | ||
| 195 | if (pdata->phy_reset) { | ||
| 196 | if (gpio_is_valid(pdata->reset_gpio_port[0])) | ||
| 197 | gpio_request_one(pdata->reset_gpio_port[0], | ||
| 198 | GPIOF_OUT_INIT_LOW, "USB1 PHY reset"); | ||
| 199 | |||
| 200 | if (gpio_is_valid(pdata->reset_gpio_port[1])) | ||
| 201 | gpio_request_one(pdata->reset_gpio_port[1], | ||
| 202 | GPIOF_OUT_INIT_LOW, "USB2 PHY reset"); | ||
| 203 | |||
| 204 | /* Hold the PHY in RESET for enough time till DIR is high */ | ||
| 205 | udelay(10); | ||
| 206 | } | ||
| 207 | |||
| 194 | pm_runtime_enable(dev); | 208 | pm_runtime_enable(dev); |
| 195 | pm_runtime_get_sync(dev); | 209 | pm_runtime_get_sync(dev); |
| 196 | 210 | ||
| @@ -237,6 +251,19 @@ static int ehci_hcd_omap_probe(struct platform_device *pdev) | |||
| 237 | /* root ports should always stay powered */ | 251 | /* root ports should always stay powered */ |
| 238 | ehci_port_power(omap_ehci, 1); | 252 | ehci_port_power(omap_ehci, 1); |
| 239 | 253 | ||
| 254 | if (pdata->phy_reset) { | ||
| 255 | /* Hold the PHY in RESET for enough time till | ||
| 256 | * PHY is settled and ready | ||
| 257 | */ | ||
| 258 | udelay(10); | ||
| 259 | |||
| 260 | if (gpio_is_valid(pdata->reset_gpio_port[0])) | ||
| 261 | gpio_set_value(pdata->reset_gpio_port[0], 1); | ||
| 262 | |||
| 263 | if (gpio_is_valid(pdata->reset_gpio_port[1])) | ||
| 264 | gpio_set_value(pdata->reset_gpio_port[1], 1); | ||
| 265 | } | ||
| 266 | |||
| 240 | return 0; | 267 | return 0; |
| 241 | 268 | ||
| 242 | err_add_hcd: | 269 | err_add_hcd: |
| @@ -259,8 +286,9 @@ err_io: | |||
| 259 | */ | 286 | */ |
| 260 | static int ehci_hcd_omap_remove(struct platform_device *pdev) | 287 | static int ehci_hcd_omap_remove(struct platform_device *pdev) |
| 261 | { | 288 | { |
| 262 | struct device *dev = &pdev->dev; | 289 | struct device *dev = &pdev->dev; |
| 263 | struct usb_hcd *hcd = dev_get_drvdata(dev); | 290 | struct usb_hcd *hcd = dev_get_drvdata(dev); |
| 291 | struct ehci_hcd_omap_platform_data *pdata = dev->platform_data; | ||
| 264 | 292 | ||
| 265 | usb_remove_hcd(hcd); | 293 | usb_remove_hcd(hcd); |
| 266 | disable_put_regulator(dev->platform_data); | 294 | disable_put_regulator(dev->platform_data); |
| @@ -269,6 +297,13 @@ static int ehci_hcd_omap_remove(struct platform_device *pdev) | |||
| 269 | pm_runtime_put_sync(dev); | 297 | pm_runtime_put_sync(dev); |
| 270 | pm_runtime_disable(dev); | 298 | pm_runtime_disable(dev); |
| 271 | 299 | ||
| 300 | if (pdata->phy_reset) { | ||
| 301 | if (gpio_is_valid(pdata->reset_gpio_port[0])) | ||
| 302 | gpio_free(pdata->reset_gpio_port[0]); | ||
| 303 | |||
| 304 | if (gpio_is_valid(pdata->reset_gpio_port[1])) | ||
| 305 | gpio_free(pdata->reset_gpio_port[1]); | ||
| 306 | } | ||
| 272 | return 0; | 307 | return 0; |
| 273 | } | 308 | } |
| 274 | 309 | ||
diff --git a/drivers/usb/host/ehci-tegra.c b/drivers/usb/host/ehci-tegra.c index 3de48a2d7955..86183366647f 100644 --- a/drivers/usb/host/ehci-tegra.c +++ b/drivers/usb/host/ehci-tegra.c | |||
| @@ -224,6 +224,7 @@ static int tegra_ehci_hub_control( | |||
| 224 | temp &= ~(PORT_RWC_BITS | PORT_WAKE_BITS); | 224 | temp &= ~(PORT_RWC_BITS | PORT_WAKE_BITS); |
| 225 | /* start resume signalling */ | 225 | /* start resume signalling */ |
| 226 | ehci_writel(ehci, temp | PORT_RESUME, status_reg); | 226 | ehci_writel(ehci, temp | PORT_RESUME, status_reg); |
| 227 | set_bit(wIndex-1, &ehci->resuming_ports); | ||
| 227 | 228 | ||
| 228 | spin_unlock_irqrestore(&ehci->lock, flags); | 229 | spin_unlock_irqrestore(&ehci->lock, flags); |
| 229 | msleep(20); | 230 | msleep(20); |
| @@ -236,6 +237,7 @@ static int tegra_ehci_hub_control( | |||
| 236 | pr_err("%s: timeout waiting for SUSPEND\n", __func__); | 237 | pr_err("%s: timeout waiting for SUSPEND\n", __func__); |
| 237 | 238 | ||
| 238 | ehci->reset_done[wIndex-1] = 0; | 239 | ehci->reset_done[wIndex-1] = 0; |
| 240 | clear_bit(wIndex-1, &ehci->resuming_ports); | ||
| 239 | 241 | ||
| 240 | tegra->port_resuming = 1; | 242 | tegra->port_resuming = 1; |
| 241 | goto done; | 243 | goto done; |
| @@ -729,7 +731,6 @@ static int tegra_ehci_probe(struct platform_device *pdev) | |||
| 729 | err = -ENODEV; | 731 | err = -ENODEV; |
| 730 | goto fail; | 732 | goto fail; |
| 731 | } | 733 | } |
| 732 | set_irq_flags(irq, IRQF_VALID); | ||
| 733 | 734 | ||
| 734 | #ifdef CONFIG_USB_OTG_UTILS | 735 | #ifdef CONFIG_USB_OTG_UTILS |
| 735 | if (pdata->operating_mode == TEGRA_USB_OTG) { | 736 | if (pdata->operating_mode == TEGRA_USB_OTG) { |
diff --git a/drivers/usb/host/ehci.h b/drivers/usb/host/ehci.h index 8f9acbc96fde..2694ed6558d2 100644 --- a/drivers/usb/host/ehci.h +++ b/drivers/usb/host/ehci.h | |||
| @@ -117,6 +117,8 @@ struct ehci_hcd { /* one per controller */ | |||
| 117 | the change-suspend feature turned on */ | 117 | the change-suspend feature turned on */ |
| 118 | unsigned long suspended_ports; /* which ports are | 118 | unsigned long suspended_ports; /* which ports are |
| 119 | suspended */ | 119 | suspended */ |
| 120 | unsigned long resuming_ports; /* which ports have | ||
| 121 | started to resume */ | ||
| 120 | 122 | ||
| 121 | /* per-HC memory pools (could be per-bus, but ...) */ | 123 | /* per-HC memory pools (could be per-bus, but ...) */ |
| 122 | struct dma_pool *qh_pool; /* qh per active urb */ | 124 | struct dma_pool *qh_pool; /* qh per active urb */ |
diff --git a/drivers/usb/host/ohci-at91.c b/drivers/usb/host/ohci-at91.c index 09f597ad6e00..13ebeca8e73e 100644 --- a/drivers/usb/host/ohci-at91.c +++ b/drivers/usb/host/ohci-at91.c | |||
| @@ -94,7 +94,7 @@ static void at91_stop_hc(struct platform_device *pdev) | |||
| 94 | 94 | ||
| 95 | /*-------------------------------------------------------------------------*/ | 95 | /*-------------------------------------------------------------------------*/ |
| 96 | 96 | ||
| 97 | static void usb_hcd_at91_remove (struct usb_hcd *, struct platform_device *); | 97 | static void __devexit usb_hcd_at91_remove (struct usb_hcd *, struct platform_device *); |
| 98 | 98 | ||
| 99 | /* configure so an HC device and id are always provided */ | 99 | /* configure so an HC device and id are always provided */ |
| 100 | /* always called with process context; sleeping is OK */ | 100 | /* always called with process context; sleeping is OK */ |
| @@ -108,7 +108,7 @@ static void usb_hcd_at91_remove (struct usb_hcd *, struct platform_device *); | |||
| 108 | * then invokes the start() method for the HCD associated with it | 108 | * then invokes the start() method for the HCD associated with it |
| 109 | * through the hotplug entry's driver_data. | 109 | * through the hotplug entry's driver_data. |
| 110 | */ | 110 | */ |
| 111 | static int usb_hcd_at91_probe(const struct hc_driver *driver, | 111 | static int __devinit usb_hcd_at91_probe(const struct hc_driver *driver, |
| 112 | struct platform_device *pdev) | 112 | struct platform_device *pdev) |
| 113 | { | 113 | { |
| 114 | int retval; | 114 | int retval; |
| @@ -203,7 +203,7 @@ static int usb_hcd_at91_probe(const struct hc_driver *driver, | |||
| 203 | * context, "rmmod" or something similar. | 203 | * context, "rmmod" or something similar. |
| 204 | * | 204 | * |
| 205 | */ | 205 | */ |
| 206 | static void usb_hcd_at91_remove(struct usb_hcd *hcd, | 206 | static void __devexit usb_hcd_at91_remove(struct usb_hcd *hcd, |
| 207 | struct platform_device *pdev) | 207 | struct platform_device *pdev) |
| 208 | { | 208 | { |
| 209 | usb_remove_hcd(hcd); | 209 | usb_remove_hcd(hcd); |
| @@ -545,7 +545,7 @@ static int __devinit ohci_at91_of_init(struct platform_device *pdev) | |||
| 545 | 545 | ||
| 546 | /*-------------------------------------------------------------------------*/ | 546 | /*-------------------------------------------------------------------------*/ |
| 547 | 547 | ||
| 548 | static int ohci_hcd_at91_drv_probe(struct platform_device *pdev) | 548 | static int __devinit ohci_hcd_at91_drv_probe(struct platform_device *pdev) |
| 549 | { | 549 | { |
| 550 | struct at91_usbh_data *pdata; | 550 | struct at91_usbh_data *pdata; |
| 551 | int i; | 551 | int i; |
| @@ -620,7 +620,7 @@ static int ohci_hcd_at91_drv_probe(struct platform_device *pdev) | |||
| 620 | return usb_hcd_at91_probe(&ohci_at91_hc_driver, pdev); | 620 | return usb_hcd_at91_probe(&ohci_at91_hc_driver, pdev); |
| 621 | } | 621 | } |
| 622 | 622 | ||
| 623 | static int ohci_hcd_at91_drv_remove(struct platform_device *pdev) | 623 | static int __devexit ohci_hcd_at91_drv_remove(struct platform_device *pdev) |
| 624 | { | 624 | { |
| 625 | struct at91_usbh_data *pdata = pdev->dev.platform_data; | 625 | struct at91_usbh_data *pdata = pdev->dev.platform_data; |
| 626 | int i; | 626 | int i; |
| @@ -696,7 +696,7 @@ MODULE_ALIAS("platform:at91_ohci"); | |||
| 696 | 696 | ||
| 697 | static struct platform_driver ohci_hcd_at91_driver = { | 697 | static struct platform_driver ohci_hcd_at91_driver = { |
| 698 | .probe = ohci_hcd_at91_drv_probe, | 698 | .probe = ohci_hcd_at91_drv_probe, |
| 699 | .remove = ohci_hcd_at91_drv_remove, | 699 | .remove = __devexit_p(ohci_hcd_at91_drv_remove), |
| 700 | .shutdown = usb_hcd_platform_shutdown, | 700 | .shutdown = usb_hcd_platform_shutdown, |
| 701 | .suspend = ohci_hcd_at91_drv_suspend, | 701 | .suspend = ohci_hcd_at91_drv_suspend, |
| 702 | .resume = ohci_hcd_at91_drv_resume, | 702 | .resume = ohci_hcd_at91_drv_resume, |
diff --git a/drivers/usb/host/pci-quirks.c b/drivers/usb/host/pci-quirks.c index 11de5f1be981..32dada8c8b4f 100644 --- a/drivers/usb/host/pci-quirks.c +++ b/drivers/usb/host/pci-quirks.c | |||
| @@ -825,9 +825,13 @@ static void __devinit quirk_usb_handoff_xhci(struct pci_dev *pdev) | |||
| 825 | } | 825 | } |
| 826 | } | 826 | } |
| 827 | 827 | ||
| 828 | /* Disable any BIOS SMIs */ | 828 | val = readl(base + ext_cap_offset + XHCI_LEGACY_CONTROL_OFFSET); |
| 829 | writel(XHCI_LEGACY_DISABLE_SMI, | 829 | /* Mask off (turn off) any enabled SMIs */ |
| 830 | base + ext_cap_offset + XHCI_LEGACY_CONTROL_OFFSET); | 830 | val &= XHCI_LEGACY_DISABLE_SMI; |
| 831 | /* Mask all SMI events bits, RW1C */ | ||
| 832 | val |= XHCI_LEGACY_SMI_EVENTS; | ||
| 833 | /* Disable any BIOS SMIs and clear all SMI events*/ | ||
| 834 | writel(val, base + ext_cap_offset + XHCI_LEGACY_CONTROL_OFFSET); | ||
| 831 | 835 | ||
| 832 | if (usb_is_intel_switchable_xhci(pdev)) | 836 | if (usb_is_intel_switchable_xhci(pdev)) |
| 833 | usb_enable_xhci_ports(pdev); | 837 | usb_enable_xhci_ports(pdev); |
diff --git a/drivers/usb/host/uhci-hub.c b/drivers/usb/host/uhci-hub.c index 045cde4cbc3d..768d54295a20 100644 --- a/drivers/usb/host/uhci-hub.c +++ b/drivers/usb/host/uhci-hub.c | |||
| @@ -196,11 +196,12 @@ static int uhci_hub_status_data(struct usb_hcd *hcd, char *buf) | |||
| 196 | status = get_hub_status_data(uhci, buf); | 196 | status = get_hub_status_data(uhci, buf); |
| 197 | 197 | ||
| 198 | switch (uhci->rh_state) { | 198 | switch (uhci->rh_state) { |
| 199 | case UHCI_RH_SUSPENDING: | ||
| 200 | case UHCI_RH_SUSPENDED: | 199 | case UHCI_RH_SUSPENDED: |
| 201 | /* if port change, ask to be resumed */ | 200 | /* if port change, ask to be resumed */ |
| 202 | if (status || uhci->resuming_ports) | 201 | if (status || uhci->resuming_ports) { |
| 202 | status = 1; | ||
| 203 | usb_hcd_resume_root_hub(hcd); | 203 | usb_hcd_resume_root_hub(hcd); |
| 204 | } | ||
| 204 | break; | 205 | break; |
| 205 | 206 | ||
| 206 | case UHCI_RH_AUTO_STOPPED: | 207 | case UHCI_RH_AUTO_STOPPED: |
diff --git a/drivers/usb/host/xhci-dbg.c b/drivers/usb/host/xhci-dbg.c index e9b0f043455d..4b436f5a4171 100644 --- a/drivers/usb/host/xhci-dbg.c +++ b/drivers/usb/host/xhci-dbg.c | |||
| @@ -119,7 +119,7 @@ static void xhci_print_command_reg(struct xhci_hcd *xhci) | |||
| 119 | xhci_dbg(xhci, " Event Interrupts %s\n", | 119 | xhci_dbg(xhci, " Event Interrupts %s\n", |
| 120 | (temp & CMD_EIE) ? "enabled " : "disabled"); | 120 | (temp & CMD_EIE) ? "enabled " : "disabled"); |
| 121 | xhci_dbg(xhci, " Host System Error Interrupts %s\n", | 121 | xhci_dbg(xhci, " Host System Error Interrupts %s\n", |
| 122 | (temp & CMD_EIE) ? "enabled " : "disabled"); | 122 | (temp & CMD_HSEIE) ? "enabled " : "disabled"); |
| 123 | xhci_dbg(xhci, " HC has %sfinished light reset\n", | 123 | xhci_dbg(xhci, " HC has %sfinished light reset\n", |
| 124 | (temp & CMD_LRESET) ? "not " : ""); | 124 | (temp & CMD_LRESET) ? "not " : ""); |
| 125 | } | 125 | } |
diff --git a/drivers/usb/host/xhci-ext-caps.h b/drivers/usb/host/xhci-ext-caps.h index c7f33123d4c0..377f4242dabb 100644 --- a/drivers/usb/host/xhci-ext-caps.h +++ b/drivers/usb/host/xhci-ext-caps.h | |||
| @@ -62,8 +62,9 @@ | |||
| 62 | /* USB Legacy Support Control and Status Register - section 7.1.2 */ | 62 | /* USB Legacy Support Control and Status Register - section 7.1.2 */ |
| 63 | /* Add this offset, plus the value of xECP in HCCPARAMS to the base address */ | 63 | /* Add this offset, plus the value of xECP in HCCPARAMS to the base address */ |
| 64 | #define XHCI_LEGACY_CONTROL_OFFSET (0x04) | 64 | #define XHCI_LEGACY_CONTROL_OFFSET (0x04) |
| 65 | /* bits 1:2, 5:12, and 17:19 need to be preserved; bits 21:28 should be zero */ | 65 | /* bits 1:3, 5:12, and 17:19 need to be preserved; bits 21:28 should be zero */ |
| 66 | #define XHCI_LEGACY_DISABLE_SMI ((0x3 << 1) + (0xff << 5) + (0x7 << 17)) | 66 | #define XHCI_LEGACY_DISABLE_SMI ((0x7 << 1) + (0xff << 5) + (0x7 << 17)) |
| 67 | #define XHCI_LEGACY_SMI_EVENTS (0x7 << 29) | ||
| 67 | 68 | ||
| 68 | /* USB 2.0 xHCI 0.96 L1C capability - section 7.2.2.1.3.2 */ | 69 | /* USB 2.0 xHCI 0.96 L1C capability - section 7.2.2.1.3.2 */ |
| 69 | #define XHCI_L1C (1 << 16) | 70 | #define XHCI_L1C (1 << 16) |
diff --git a/drivers/usb/host/xhci-mem.c b/drivers/usb/host/xhci-mem.c index cae4c6f2845a..68eaa908ac8e 100644 --- a/drivers/usb/host/xhci-mem.c +++ b/drivers/usb/host/xhci-mem.c | |||
| @@ -1796,11 +1796,6 @@ void xhci_mem_cleanup(struct xhci_hcd *xhci) | |||
| 1796 | int i; | 1796 | int i; |
| 1797 | 1797 | ||
| 1798 | /* Free the Event Ring Segment Table and the actual Event Ring */ | 1798 | /* Free the Event Ring Segment Table and the actual Event Ring */ |
| 1799 | if (xhci->ir_set) { | ||
| 1800 | xhci_writel(xhci, 0, &xhci->ir_set->erst_size); | ||
| 1801 | xhci_write_64(xhci, 0, &xhci->ir_set->erst_base); | ||
| 1802 | xhci_write_64(xhci, 0, &xhci->ir_set->erst_dequeue); | ||
| 1803 | } | ||
| 1804 | size = sizeof(struct xhci_erst_entry)*(xhci->erst.num_entries); | 1799 | size = sizeof(struct xhci_erst_entry)*(xhci->erst.num_entries); |
| 1805 | if (xhci->erst.entries) | 1800 | if (xhci->erst.entries) |
| 1806 | dma_free_coherent(&pdev->dev, size, | 1801 | dma_free_coherent(&pdev->dev, size, |
| @@ -1812,7 +1807,6 @@ void xhci_mem_cleanup(struct xhci_hcd *xhci) | |||
| 1812 | xhci->event_ring = NULL; | 1807 | xhci->event_ring = NULL; |
| 1813 | xhci_dbg(xhci, "Freed event ring\n"); | 1808 | xhci_dbg(xhci, "Freed event ring\n"); |
| 1814 | 1809 | ||
| 1815 | xhci_write_64(xhci, 0, &xhci->op_regs->cmd_ring); | ||
| 1816 | if (xhci->cmd_ring) | 1810 | if (xhci->cmd_ring) |
| 1817 | xhci_ring_free(xhci, xhci->cmd_ring); | 1811 | xhci_ring_free(xhci, xhci->cmd_ring); |
| 1818 | xhci->cmd_ring = NULL; | 1812 | xhci->cmd_ring = NULL; |
| @@ -1841,7 +1835,6 @@ void xhci_mem_cleanup(struct xhci_hcd *xhci) | |||
| 1841 | xhci->medium_streams_pool = NULL; | 1835 | xhci->medium_streams_pool = NULL; |
| 1842 | xhci_dbg(xhci, "Freed medium stream array pool\n"); | 1836 | xhci_dbg(xhci, "Freed medium stream array pool\n"); |
| 1843 | 1837 | ||
| 1844 | xhci_write_64(xhci, 0, &xhci->op_regs->dcbaa_ptr); | ||
| 1845 | if (xhci->dcbaa) | 1838 | if (xhci->dcbaa) |
| 1846 | dma_free_coherent(&pdev->dev, sizeof(*xhci->dcbaa), | 1839 | dma_free_coherent(&pdev->dev, sizeof(*xhci->dcbaa), |
| 1847 | xhci->dcbaa, xhci->dcbaa->dma); | 1840 | xhci->dcbaa, xhci->dcbaa->dma); |
| @@ -2459,6 +2452,8 @@ int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags) | |||
| 2459 | 2452 | ||
| 2460 | fail: | 2453 | fail: |
| 2461 | xhci_warn(xhci, "Couldn't initialize memory\n"); | 2454 | xhci_warn(xhci, "Couldn't initialize memory\n"); |
| 2455 | xhci_halt(xhci); | ||
| 2456 | xhci_reset(xhci); | ||
| 2462 | xhci_mem_cleanup(xhci); | 2457 | xhci_mem_cleanup(xhci); |
| 2463 | return -ENOMEM; | 2458 | return -ENOMEM; |
| 2464 | } | 2459 | } |
diff --git a/drivers/usb/host/xhci-pci.c b/drivers/usb/host/xhci-pci.c index ef98b38626fb..7a856a767e77 100644 --- a/drivers/usb/host/xhci-pci.c +++ b/drivers/usb/host/xhci-pci.c | |||
| @@ -95,6 +95,8 @@ static void xhci_pci_quirks(struct device *dev, struct xhci_hcd *xhci) | |||
| 95 | xhci->quirks |= XHCI_RESET_ON_RESUME; | 95 | xhci->quirks |= XHCI_RESET_ON_RESUME; |
| 96 | xhci_dbg(xhci, "QUIRK: Resetting on resume\n"); | 96 | xhci_dbg(xhci, "QUIRK: Resetting on resume\n"); |
| 97 | } | 97 | } |
| 98 | if (pdev->vendor == PCI_VENDOR_ID_VIA) | ||
| 99 | xhci->quirks |= XHCI_RESET_ON_RESUME; | ||
| 98 | } | 100 | } |
| 99 | 101 | ||
| 100 | /* called during probe() after chip reset completes */ | 102 | /* called during probe() after chip reset completes */ |
| @@ -326,7 +328,7 @@ int __init xhci_register_pci(void) | |||
| 326 | return pci_register_driver(&xhci_pci_driver); | 328 | return pci_register_driver(&xhci_pci_driver); |
| 327 | } | 329 | } |
| 328 | 330 | ||
| 329 | void __exit xhci_unregister_pci(void) | 331 | void xhci_unregister_pci(void) |
| 330 | { | 332 | { |
| 331 | pci_unregister_driver(&xhci_pci_driver); | 333 | pci_unregister_driver(&xhci_pci_driver); |
| 332 | } | 334 | } |
diff --git a/drivers/usb/host/xhci-ring.c b/drivers/usb/host/xhci-ring.c index 6bd9d53062eb..3d9422f16a20 100644 --- a/drivers/usb/host/xhci-ring.c +++ b/drivers/usb/host/xhci-ring.c | |||
| @@ -2417,7 +2417,7 @@ hw_died: | |||
| 2417 | u32 irq_pending; | 2417 | u32 irq_pending; |
| 2418 | /* Acknowledge the PCI interrupt */ | 2418 | /* Acknowledge the PCI interrupt */ |
| 2419 | irq_pending = xhci_readl(xhci, &xhci->ir_set->irq_pending); | 2419 | irq_pending = xhci_readl(xhci, &xhci->ir_set->irq_pending); |
| 2420 | irq_pending |= 0x3; | 2420 | irq_pending |= IMAN_IP; |
| 2421 | xhci_writel(xhci, irq_pending, &xhci->ir_set->irq_pending); | 2421 | xhci_writel(xhci, irq_pending, &xhci->ir_set->irq_pending); |
| 2422 | } | 2422 | } |
| 2423 | 2423 | ||
| @@ -2734,7 +2734,7 @@ int xhci_queue_intr_tx(struct xhci_hcd *xhci, gfp_t mem_flags, | |||
| 2734 | urb->dev->speed == USB_SPEED_FULL) | 2734 | urb->dev->speed == USB_SPEED_FULL) |
| 2735 | urb->interval /= 8; | 2735 | urb->interval /= 8; |
| 2736 | } | 2736 | } |
| 2737 | return xhci_queue_bulk_tx(xhci, GFP_ATOMIC, urb, slot_id, ep_index); | 2737 | return xhci_queue_bulk_tx(xhci, mem_flags, urb, slot_id, ep_index); |
| 2738 | } | 2738 | } |
| 2739 | 2739 | ||
| 2740 | /* | 2740 | /* |
| @@ -3514,7 +3514,7 @@ int xhci_queue_isoc_tx_prepare(struct xhci_hcd *xhci, gfp_t mem_flags, | |||
| 3514 | } | 3514 | } |
| 3515 | ep_ring->num_trbs_free_temp = ep_ring->num_trbs_free; | 3515 | ep_ring->num_trbs_free_temp = ep_ring->num_trbs_free; |
| 3516 | 3516 | ||
| 3517 | return xhci_queue_isoc_tx(xhci, GFP_ATOMIC, urb, slot_id, ep_index); | 3517 | return xhci_queue_isoc_tx(xhci, mem_flags, urb, slot_id, ep_index); |
| 3518 | } | 3518 | } |
| 3519 | 3519 | ||
| 3520 | /**** Command Ring Operations ****/ | 3520 | /**** Command Ring Operations ****/ |
diff --git a/drivers/usb/host/xhci.c b/drivers/usb/host/xhci.c index e1963d4a430f..36641a7f2371 100644 --- a/drivers/usb/host/xhci.c +++ b/drivers/usb/host/xhci.c | |||
| @@ -106,6 +106,9 @@ int xhci_halt(struct xhci_hcd *xhci) | |||
| 106 | STS_HALT, STS_HALT, XHCI_MAX_HALT_USEC); | 106 | STS_HALT, STS_HALT, XHCI_MAX_HALT_USEC); |
| 107 | if (!ret) | 107 | if (!ret) |
| 108 | xhci->xhc_state |= XHCI_STATE_HALTED; | 108 | xhci->xhc_state |= XHCI_STATE_HALTED; |
| 109 | else | ||
| 110 | xhci_warn(xhci, "Host not halted after %u microseconds.\n", | ||
| 111 | XHCI_MAX_HALT_USEC); | ||
| 109 | return ret; | 112 | return ret; |
| 110 | } | 113 | } |
| 111 | 114 | ||
| @@ -664,11 +667,11 @@ static void xhci_save_registers(struct xhci_hcd *xhci) | |||
| 664 | xhci->s3.dev_nt = xhci_readl(xhci, &xhci->op_regs->dev_notification); | 667 | xhci->s3.dev_nt = xhci_readl(xhci, &xhci->op_regs->dev_notification); |
| 665 | xhci->s3.dcbaa_ptr = xhci_read_64(xhci, &xhci->op_regs->dcbaa_ptr); | 668 | xhci->s3.dcbaa_ptr = xhci_read_64(xhci, &xhci->op_regs->dcbaa_ptr); |
| 666 | xhci->s3.config_reg = xhci_readl(xhci, &xhci->op_regs->config_reg); | 669 | xhci->s3.config_reg = xhci_readl(xhci, &xhci->op_regs->config_reg); |
| 667 | xhci->s3.irq_pending = xhci_readl(xhci, &xhci->ir_set->irq_pending); | ||
| 668 | xhci->s3.irq_control = xhci_readl(xhci, &xhci->ir_set->irq_control); | ||
| 669 | xhci->s3.erst_size = xhci_readl(xhci, &xhci->ir_set->erst_size); | 670 | xhci->s3.erst_size = xhci_readl(xhci, &xhci->ir_set->erst_size); |
| 670 | xhci->s3.erst_base = xhci_read_64(xhci, &xhci->ir_set->erst_base); | 671 | xhci->s3.erst_base = xhci_read_64(xhci, &xhci->ir_set->erst_base); |
| 671 | xhci->s3.erst_dequeue = xhci_read_64(xhci, &xhci->ir_set->erst_dequeue); | 672 | xhci->s3.erst_dequeue = xhci_read_64(xhci, &xhci->ir_set->erst_dequeue); |
| 673 | xhci->s3.irq_pending = xhci_readl(xhci, &xhci->ir_set->irq_pending); | ||
| 674 | xhci->s3.irq_control = xhci_readl(xhci, &xhci->ir_set->irq_control); | ||
| 672 | } | 675 | } |
| 673 | 676 | ||
| 674 | static void xhci_restore_registers(struct xhci_hcd *xhci) | 677 | static void xhci_restore_registers(struct xhci_hcd *xhci) |
| @@ -677,10 +680,11 @@ static void xhci_restore_registers(struct xhci_hcd *xhci) | |||
| 677 | xhci_writel(xhci, xhci->s3.dev_nt, &xhci->op_regs->dev_notification); | 680 | xhci_writel(xhci, xhci->s3.dev_nt, &xhci->op_regs->dev_notification); |
| 678 | xhci_write_64(xhci, xhci->s3.dcbaa_ptr, &xhci->op_regs->dcbaa_ptr); | 681 | xhci_write_64(xhci, xhci->s3.dcbaa_ptr, &xhci->op_regs->dcbaa_ptr); |
| 679 | xhci_writel(xhci, xhci->s3.config_reg, &xhci->op_regs->config_reg); | 682 | xhci_writel(xhci, xhci->s3.config_reg, &xhci->op_regs->config_reg); |
| 680 | xhci_writel(xhci, xhci->s3.irq_pending, &xhci->ir_set->irq_pending); | ||
| 681 | xhci_writel(xhci, xhci->s3.irq_control, &xhci->ir_set->irq_control); | ||
| 682 | xhci_writel(xhci, xhci->s3.erst_size, &xhci->ir_set->erst_size); | 683 | xhci_writel(xhci, xhci->s3.erst_size, &xhci->ir_set->erst_size); |
| 683 | xhci_write_64(xhci, xhci->s3.erst_base, &xhci->ir_set->erst_base); | 684 | xhci_write_64(xhci, xhci->s3.erst_base, &xhci->ir_set->erst_base); |
| 685 | xhci_write_64(xhci, xhci->s3.erst_dequeue, &xhci->ir_set->erst_dequeue); | ||
| 686 | xhci_writel(xhci, xhci->s3.irq_pending, &xhci->ir_set->irq_pending); | ||
| 687 | xhci_writel(xhci, xhci->s3.irq_control, &xhci->ir_set->irq_control); | ||
| 684 | } | 688 | } |
| 685 | 689 | ||
| 686 | static void xhci_set_cmd_ring_deq(struct xhci_hcd *xhci) | 690 | static void xhci_set_cmd_ring_deq(struct xhci_hcd *xhci) |
diff --git a/drivers/usb/host/xhci.h b/drivers/usb/host/xhci.h index 91074fdab3eb..3d69c4b2b542 100644 --- a/drivers/usb/host/xhci.h +++ b/drivers/usb/host/xhci.h | |||
| @@ -205,6 +205,10 @@ struct xhci_op_regs { | |||
| 205 | #define CMD_PM_INDEX (1 << 11) | 205 | #define CMD_PM_INDEX (1 << 11) |
| 206 | /* bits 12:31 are reserved (and should be preserved on writes). */ | 206 | /* bits 12:31 are reserved (and should be preserved on writes). */ |
| 207 | 207 | ||
| 208 | /* IMAN - Interrupt Management Register */ | ||
| 209 | #define IMAN_IP (1 << 1) | ||
| 210 | #define IMAN_IE (1 << 0) | ||
| 211 | |||
| 208 | /* USBSTS - USB status - status bitmasks */ | 212 | /* USBSTS - USB status - status bitmasks */ |
| 209 | /* HC not running - set to 1 when run/stop bit is cleared. */ | 213 | /* HC not running - set to 1 when run/stop bit is cleared. */ |
| 210 | #define STS_HALT XHCI_STS_HALT | 214 | #define STS_HALT XHCI_STS_HALT |
diff --git a/drivers/usb/misc/usbtest.c b/drivers/usb/misc/usbtest.c index 959145baf3cf..9dcb68f04f03 100644 --- a/drivers/usb/misc/usbtest.c +++ b/drivers/usb/misc/usbtest.c | |||
| @@ -423,7 +423,7 @@ alloc_sglist(int nents, int max, int vary) | |||
| 423 | unsigned i; | 423 | unsigned i; |
| 424 | unsigned size = max; | 424 | unsigned size = max; |
| 425 | 425 | ||
| 426 | sg = kmalloc(nents * sizeof *sg, GFP_KERNEL); | 426 | sg = kmalloc_array(nents, sizeof *sg, GFP_KERNEL); |
| 427 | if (!sg) | 427 | if (!sg) |
| 428 | return NULL; | 428 | return NULL; |
| 429 | sg_init_table(sg, nents); | 429 | sg_init_table(sg, nents); |
| @@ -904,6 +904,9 @@ test_ctrl_queue(struct usbtest_dev *dev, struct usbtest_param *param) | |||
| 904 | struct ctrl_ctx context; | 904 | struct ctrl_ctx context; |
| 905 | int i; | 905 | int i; |
| 906 | 906 | ||
| 907 | if (param->sglen == 0 || param->iterations > UINT_MAX / param->sglen) | ||
| 908 | return -EOPNOTSUPP; | ||
| 909 | |||
| 907 | spin_lock_init(&context.lock); | 910 | spin_lock_init(&context.lock); |
| 908 | context.dev = dev; | 911 | context.dev = dev; |
| 909 | init_completion(&context.complete); | 912 | init_completion(&context.complete); |
| @@ -1981,8 +1984,6 @@ usbtest_ioctl(struct usb_interface *intf, unsigned int code, void *buf) | |||
| 1981 | 1984 | ||
| 1982 | /* queued control messaging */ | 1985 | /* queued control messaging */ |
| 1983 | case 10: | 1986 | case 10: |
| 1984 | if (param->sglen == 0) | ||
| 1985 | break; | ||
| 1986 | retval = 0; | 1987 | retval = 0; |
| 1987 | dev_info(&intf->dev, | 1988 | dev_info(&intf->dev, |
| 1988 | "TEST 10: queue %d control calls, %d times\n", | 1989 | "TEST 10: queue %d control calls, %d times\n", |
| @@ -2276,6 +2277,8 @@ usbtest_probe(struct usb_interface *intf, const struct usb_device_id *id) | |||
| 2276 | if (status < 0) { | 2277 | if (status < 0) { |
| 2277 | WARNING(dev, "couldn't get endpoints, %d\n", | 2278 | WARNING(dev, "couldn't get endpoints, %d\n", |
| 2278 | status); | 2279 | status); |
| 2280 | kfree(dev->buf); | ||
| 2281 | kfree(dev); | ||
| 2279 | return status; | 2282 | return status; |
| 2280 | } | 2283 | } |
| 2281 | /* may find bulk or ISO pipes */ | 2284 | /* may find bulk or ISO pipes */ |
diff --git a/drivers/usb/misc/yurex.c b/drivers/usb/misc/yurex.c index 897edda42270..70201462e19c 100644 --- a/drivers/usb/misc/yurex.c +++ b/drivers/usb/misc/yurex.c | |||
| @@ -99,9 +99,7 @@ static void yurex_delete(struct kref *kref) | |||
| 99 | usb_put_dev(dev->udev); | 99 | usb_put_dev(dev->udev); |
| 100 | if (dev->cntl_urb) { | 100 | if (dev->cntl_urb) { |
| 101 | usb_kill_urb(dev->cntl_urb); | 101 | usb_kill_urb(dev->cntl_urb); |
| 102 | if (dev->cntl_req) | 102 | kfree(dev->cntl_req); |
| 103 | usb_free_coherent(dev->udev, YUREX_BUF_SIZE, | ||
| 104 | dev->cntl_req, dev->cntl_urb->setup_dma); | ||
| 105 | if (dev->cntl_buffer) | 103 | if (dev->cntl_buffer) |
| 106 | usb_free_coherent(dev->udev, YUREX_BUF_SIZE, | 104 | usb_free_coherent(dev->udev, YUREX_BUF_SIZE, |
| 107 | dev->cntl_buffer, dev->cntl_urb->transfer_dma); | 105 | dev->cntl_buffer, dev->cntl_urb->transfer_dma); |
| @@ -234,9 +232,7 @@ static int yurex_probe(struct usb_interface *interface, const struct usb_device_ | |||
| 234 | } | 232 | } |
| 235 | 233 | ||
| 236 | /* allocate buffer for control req */ | 234 | /* allocate buffer for control req */ |
| 237 | dev->cntl_req = usb_alloc_coherent(dev->udev, YUREX_BUF_SIZE, | 235 | dev->cntl_req = kmalloc(YUREX_BUF_SIZE, GFP_KERNEL); |
| 238 | GFP_KERNEL, | ||
| 239 | &dev->cntl_urb->setup_dma); | ||
| 240 | if (!dev->cntl_req) { | 236 | if (!dev->cntl_req) { |
| 241 | err("Could not allocate cntl_req"); | 237 | err("Could not allocate cntl_req"); |
| 242 | goto error; | 238 | goto error; |
| @@ -286,7 +282,7 @@ static int yurex_probe(struct usb_interface *interface, const struct usb_device_ | |||
| 286 | usb_rcvintpipe(dev->udev, dev->int_in_endpointAddr), | 282 | usb_rcvintpipe(dev->udev, dev->int_in_endpointAddr), |
| 287 | dev->int_buffer, YUREX_BUF_SIZE, yurex_interrupt, | 283 | dev->int_buffer, YUREX_BUF_SIZE, yurex_interrupt, |
| 288 | dev, 1); | 284 | dev, 1); |
| 289 | dev->cntl_urb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP; | 285 | dev->urb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP; |
| 290 | if (usb_submit_urb(dev->urb, GFP_KERNEL)) { | 286 | if (usb_submit_urb(dev->urb, GFP_KERNEL)) { |
| 291 | retval = -EIO; | 287 | retval = -EIO; |
| 292 | err("Could not submitting URB"); | 288 | err("Could not submitting URB"); |
diff --git a/drivers/usb/musb/musb_core.c b/drivers/usb/musb/musb_core.c index 0f8b82918a40..66aaccf04490 100644 --- a/drivers/usb/musb/musb_core.c +++ b/drivers/usb/musb/musb_core.c | |||
| @@ -137,6 +137,9 @@ static int musb_ulpi_read(struct usb_phy *phy, u32 offset) | |||
| 137 | int i = 0; | 137 | int i = 0; |
| 138 | u8 r; | 138 | u8 r; |
| 139 | u8 power; | 139 | u8 power; |
| 140 | int ret; | ||
| 141 | |||
| 142 | pm_runtime_get_sync(phy->io_dev); | ||
| 140 | 143 | ||
| 141 | /* Make sure the transceiver is not in low power mode */ | 144 | /* Make sure the transceiver is not in low power mode */ |
| 142 | power = musb_readb(addr, MUSB_POWER); | 145 | power = musb_readb(addr, MUSB_POWER); |
| @@ -154,15 +157,22 @@ static int musb_ulpi_read(struct usb_phy *phy, u32 offset) | |||
| 154 | while (!(musb_readb(addr, MUSB_ULPI_REG_CONTROL) | 157 | while (!(musb_readb(addr, MUSB_ULPI_REG_CONTROL) |
| 155 | & MUSB_ULPI_REG_CMPLT)) { | 158 | & MUSB_ULPI_REG_CMPLT)) { |
| 156 | i++; | 159 | i++; |
| 157 | if (i == 10000) | 160 | if (i == 10000) { |
| 158 | return -ETIMEDOUT; | 161 | ret = -ETIMEDOUT; |
| 162 | goto out; | ||
| 163 | } | ||
| 159 | 164 | ||
| 160 | } | 165 | } |
| 161 | r = musb_readb(addr, MUSB_ULPI_REG_CONTROL); | 166 | r = musb_readb(addr, MUSB_ULPI_REG_CONTROL); |
| 162 | r &= ~MUSB_ULPI_REG_CMPLT; | 167 | r &= ~MUSB_ULPI_REG_CMPLT; |
| 163 | musb_writeb(addr, MUSB_ULPI_REG_CONTROL, r); | 168 | musb_writeb(addr, MUSB_ULPI_REG_CONTROL, r); |
| 164 | 169 | ||
| 165 | return musb_readb(addr, MUSB_ULPI_REG_DATA); | 170 | ret = musb_readb(addr, MUSB_ULPI_REG_DATA); |
| 171 | |||
| 172 | out: | ||
| 173 | pm_runtime_put(phy->io_dev); | ||
| 174 | |||
| 175 | return ret; | ||
| 166 | } | 176 | } |
| 167 | 177 | ||
| 168 | static int musb_ulpi_write(struct usb_phy *phy, u32 offset, u32 data) | 178 | static int musb_ulpi_write(struct usb_phy *phy, u32 offset, u32 data) |
| @@ -171,6 +181,9 @@ static int musb_ulpi_write(struct usb_phy *phy, u32 offset, u32 data) | |||
| 171 | int i = 0; | 181 | int i = 0; |
| 172 | u8 r = 0; | 182 | u8 r = 0; |
| 173 | u8 power; | 183 | u8 power; |
| 184 | int ret = 0; | ||
| 185 | |||
| 186 | pm_runtime_get_sync(phy->io_dev); | ||
| 174 | 187 | ||
| 175 | /* Make sure the transceiver is not in low power mode */ | 188 | /* Make sure the transceiver is not in low power mode */ |
| 176 | power = musb_readb(addr, MUSB_POWER); | 189 | power = musb_readb(addr, MUSB_POWER); |
| @@ -184,15 +197,20 @@ static int musb_ulpi_write(struct usb_phy *phy, u32 offset, u32 data) | |||
| 184 | while (!(musb_readb(addr, MUSB_ULPI_REG_CONTROL) | 197 | while (!(musb_readb(addr, MUSB_ULPI_REG_CONTROL) |
| 185 | & MUSB_ULPI_REG_CMPLT)) { | 198 | & MUSB_ULPI_REG_CMPLT)) { |
| 186 | i++; | 199 | i++; |
| 187 | if (i == 10000) | 200 | if (i == 10000) { |
| 188 | return -ETIMEDOUT; | 201 | ret = -ETIMEDOUT; |
| 202 | goto out; | ||
| 203 | } | ||
| 189 | } | 204 | } |
| 190 | 205 | ||
| 191 | r = musb_readb(addr, MUSB_ULPI_REG_CONTROL); | 206 | r = musb_readb(addr, MUSB_ULPI_REG_CONTROL); |
| 192 | r &= ~MUSB_ULPI_REG_CMPLT; | 207 | r &= ~MUSB_ULPI_REG_CMPLT; |
| 193 | musb_writeb(addr, MUSB_ULPI_REG_CONTROL, r); | 208 | musb_writeb(addr, MUSB_ULPI_REG_CONTROL, r); |
| 194 | 209 | ||
| 195 | return 0; | 210 | out: |
| 211 | pm_runtime_put(phy->io_dev); | ||
| 212 | |||
| 213 | return ret; | ||
| 196 | } | 214 | } |
| 197 | #else | 215 | #else |
| 198 | #define musb_ulpi_read NULL | 216 | #define musb_ulpi_read NULL |
| @@ -1904,14 +1922,17 @@ musb_init_controller(struct device *dev, int nIrq, void __iomem *ctrl) | |||
| 1904 | 1922 | ||
| 1905 | if (!musb->isr) { | 1923 | if (!musb->isr) { |
| 1906 | status = -ENODEV; | 1924 | status = -ENODEV; |
| 1907 | goto fail3; | 1925 | goto fail2; |
| 1908 | } | 1926 | } |
| 1909 | 1927 | ||
| 1910 | if (!musb->xceiv->io_ops) { | 1928 | if (!musb->xceiv->io_ops) { |
| 1929 | musb->xceiv->io_dev = musb->controller; | ||
| 1911 | musb->xceiv->io_priv = musb->mregs; | 1930 | musb->xceiv->io_priv = musb->mregs; |
| 1912 | musb->xceiv->io_ops = &musb_ulpi_access; | 1931 | musb->xceiv->io_ops = &musb_ulpi_access; |
| 1913 | } | 1932 | } |
| 1914 | 1933 | ||
| 1934 | pm_runtime_get_sync(musb->controller); | ||
| 1935 | |||
| 1915 | #ifndef CONFIG_MUSB_PIO_ONLY | 1936 | #ifndef CONFIG_MUSB_PIO_ONLY |
| 1916 | if (use_dma && dev->dma_mask) { | 1937 | if (use_dma && dev->dma_mask) { |
| 1917 | struct dma_controller *c; | 1938 | struct dma_controller *c; |
| @@ -2023,6 +2044,8 @@ musb_init_controller(struct device *dev, int nIrq, void __iomem *ctrl) | |||
| 2023 | goto fail5; | 2044 | goto fail5; |
| 2024 | #endif | 2045 | #endif |
| 2025 | 2046 | ||
| 2047 | pm_runtime_put(musb->controller); | ||
| 2048 | |||
| 2026 | dev_info(dev, "USB %s mode controller at %p using %s, IRQ %d\n", | 2049 | dev_info(dev, "USB %s mode controller at %p using %s, IRQ %d\n", |
| 2027 | ({char *s; | 2050 | ({char *s; |
| 2028 | switch (musb->board_mode) { | 2051 | switch (musb->board_mode) { |
| @@ -2047,6 +2070,9 @@ fail4: | |||
| 2047 | musb_gadget_cleanup(musb); | 2070 | musb_gadget_cleanup(musb); |
| 2048 | 2071 | ||
| 2049 | fail3: | 2072 | fail3: |
| 2073 | pm_runtime_put_sync(musb->controller); | ||
| 2074 | |||
| 2075 | fail2: | ||
| 2050 | if (musb->irq_wake) | 2076 | if (musb->irq_wake) |
| 2051 | device_init_wakeup(dev, 0); | 2077 | device_init_wakeup(dev, 0); |
| 2052 | musb_platform_exit(musb); | 2078 | musb_platform_exit(musb); |
diff --git a/drivers/usb/musb/musb_host.c b/drivers/usb/musb/musb_host.c index 79cb0af779fa..ef8d744800ac 100644 --- a/drivers/usb/musb/musb_host.c +++ b/drivers/usb/musb/musb_host.c | |||
| @@ -2098,7 +2098,7 @@ static int musb_cleanup_urb(struct urb *urb, struct musb_qh *qh) | |||
| 2098 | } | 2098 | } |
| 2099 | 2099 | ||
| 2100 | /* turn off DMA requests, discard state, stop polling ... */ | 2100 | /* turn off DMA requests, discard state, stop polling ... */ |
| 2101 | if (is_in) { | 2101 | if (ep->epnum && is_in) { |
| 2102 | /* giveback saves bulk toggle */ | 2102 | /* giveback saves bulk toggle */ |
| 2103 | csr = musb_h_flush_rxfifo(ep, 0); | 2103 | csr = musb_h_flush_rxfifo(ep, 0); |
| 2104 | 2104 | ||
diff --git a/drivers/usb/musb/omap2430.c b/drivers/usb/musb/omap2430.c index 2ae0bb309994..c7785e81254c 100644 --- a/drivers/usb/musb/omap2430.c +++ b/drivers/usb/musb/omap2430.c | |||
| @@ -282,7 +282,8 @@ static void musb_otg_notifier_work(struct work_struct *data_notifier_work) | |||
| 282 | 282 | ||
| 283 | static int omap2430_musb_init(struct musb *musb) | 283 | static int omap2430_musb_init(struct musb *musb) |
| 284 | { | 284 | { |
| 285 | u32 l, status = 0; | 285 | u32 l; |
| 286 | int status = 0; | ||
| 286 | struct device *dev = musb->controller; | 287 | struct device *dev = musb->controller; |
| 287 | struct musb_hdrc_platform_data *plat = dev->platform_data; | 288 | struct musb_hdrc_platform_data *plat = dev->platform_data; |
| 288 | struct omap_musb_board_data *data = plat->board_data; | 289 | struct omap_musb_board_data *data = plat->board_data; |
| @@ -301,7 +302,7 @@ static int omap2430_musb_init(struct musb *musb) | |||
| 301 | 302 | ||
| 302 | status = pm_runtime_get_sync(dev); | 303 | status = pm_runtime_get_sync(dev); |
| 303 | if (status < 0) { | 304 | if (status < 0) { |
| 304 | dev_err(dev, "pm_runtime_get_sync FAILED"); | 305 | dev_err(dev, "pm_runtime_get_sync FAILED %d\n", status); |
| 305 | goto err1; | 306 | goto err1; |
| 306 | } | 307 | } |
| 307 | 308 | ||
| @@ -333,6 +334,7 @@ static int omap2430_musb_init(struct musb *musb) | |||
| 333 | 334 | ||
| 334 | setup_timer(&musb_idle_timer, musb_do_idle, (unsigned long) musb); | 335 | setup_timer(&musb_idle_timer, musb_do_idle, (unsigned long) musb); |
| 335 | 336 | ||
| 337 | pm_runtime_put_noidle(musb->controller); | ||
| 336 | return 0; | 338 | return 0; |
| 337 | 339 | ||
| 338 | err1: | 340 | err1: |
| @@ -452,14 +454,14 @@ static int __devinit omap2430_probe(struct platform_device *pdev) | |||
| 452 | goto err2; | 454 | goto err2; |
| 453 | } | 455 | } |
| 454 | 456 | ||
| 457 | pm_runtime_enable(&pdev->dev); | ||
| 458 | |||
| 455 | ret = platform_device_add(musb); | 459 | ret = platform_device_add(musb); |
| 456 | if (ret) { | 460 | if (ret) { |
| 457 | dev_err(&pdev->dev, "failed to register musb device\n"); | 461 | dev_err(&pdev->dev, "failed to register musb device\n"); |
| 458 | goto err2; | 462 | goto err2; |
| 459 | } | 463 | } |
| 460 | 464 | ||
| 461 | pm_runtime_enable(&pdev->dev); | ||
| 462 | |||
| 463 | return 0; | 465 | return 0; |
| 464 | 466 | ||
| 465 | err2: | 467 | err2: |
| @@ -478,7 +480,6 @@ static int __devexit omap2430_remove(struct platform_device *pdev) | |||
| 478 | 480 | ||
| 479 | platform_device_del(glue->musb); | 481 | platform_device_del(glue->musb); |
| 480 | platform_device_put(glue->musb); | 482 | platform_device_put(glue->musb); |
| 481 | pm_runtime_put(&pdev->dev); | ||
| 482 | kfree(glue); | 483 | kfree(glue); |
| 483 | 484 | ||
| 484 | return 0; | 485 | return 0; |
| @@ -491,11 +492,13 @@ static int omap2430_runtime_suspend(struct device *dev) | |||
| 491 | struct omap2430_glue *glue = dev_get_drvdata(dev); | 492 | struct omap2430_glue *glue = dev_get_drvdata(dev); |
| 492 | struct musb *musb = glue_to_musb(glue); | 493 | struct musb *musb = glue_to_musb(glue); |
| 493 | 494 | ||
| 494 | musb->context.otg_interfsel = musb_readl(musb->mregs, | 495 | if (musb) { |
| 495 | OTG_INTERFSEL); | 496 | musb->context.otg_interfsel = musb_readl(musb->mregs, |
| 497 | OTG_INTERFSEL); | ||
| 496 | 498 | ||
| 497 | omap2430_low_level_exit(musb); | 499 | omap2430_low_level_exit(musb); |
| 498 | usb_phy_set_suspend(musb->xceiv, 1); | 500 | usb_phy_set_suspend(musb->xceiv, 1); |
| 501 | } | ||
| 499 | 502 | ||
| 500 | return 0; | 503 | return 0; |
| 501 | } | 504 | } |
| @@ -505,11 +508,13 @@ static int omap2430_runtime_resume(struct device *dev) | |||
| 505 | struct omap2430_glue *glue = dev_get_drvdata(dev); | 508 | struct omap2430_glue *glue = dev_get_drvdata(dev); |
| 506 | struct musb *musb = glue_to_musb(glue); | 509 | struct musb *musb = glue_to_musb(glue); |
| 507 | 510 | ||
| 508 | omap2430_low_level_init(musb); | 511 | if (musb) { |
| 509 | musb_writel(musb->mregs, OTG_INTERFSEL, | 512 | omap2430_low_level_init(musb); |
| 510 | musb->context.otg_interfsel); | 513 | musb_writel(musb->mregs, OTG_INTERFSEL, |
| 514 | musb->context.otg_interfsel); | ||
| 511 | 515 | ||
| 512 | usb_phy_set_suspend(musb->xceiv, 0); | 516 | usb_phy_set_suspend(musb->xceiv, 0); |
| 517 | } | ||
| 513 | 518 | ||
| 514 | return 0; | 519 | return 0; |
| 515 | } | 520 | } |
diff --git a/drivers/usb/serial/bus.c b/drivers/usb/serial/bus.c index 7f547dc3a590..ed8adb052ca7 100644 --- a/drivers/usb/serial/bus.c +++ b/drivers/usb/serial/bus.c | |||
| @@ -60,8 +60,6 @@ static int usb_serial_device_probe(struct device *dev) | |||
| 60 | retval = -ENODEV; | 60 | retval = -ENODEV; |
| 61 | goto exit; | 61 | goto exit; |
| 62 | } | 62 | } |
| 63 | if (port->dev_state != PORT_REGISTERING) | ||
| 64 | goto exit; | ||
| 65 | 63 | ||
| 66 | driver = port->serial->type; | 64 | driver = port->serial->type; |
| 67 | if (driver->port_probe) { | 65 | if (driver->port_probe) { |
| @@ -98,9 +96,6 @@ static int usb_serial_device_remove(struct device *dev) | |||
| 98 | if (!port) | 96 | if (!port) |
| 99 | return -ENODEV; | 97 | return -ENODEV; |
| 100 | 98 | ||
| 101 | if (port->dev_state != PORT_UNREGISTERING) | ||
| 102 | return retval; | ||
| 103 | |||
| 104 | device_remove_file(&port->dev, &dev_attr_port_number); | 99 | device_remove_file(&port->dev, &dev_attr_port_number); |
| 105 | 100 | ||
| 106 | driver = port->serial->type; | 101 | driver = port->serial->type; |
diff --git a/drivers/usb/serial/cp210x.c b/drivers/usb/serial/cp210x.c index 0310e2df59f5..ec30f95ef399 100644 --- a/drivers/usb/serial/cp210x.c +++ b/drivers/usb/serial/cp210x.c | |||
| @@ -287,7 +287,8 @@ static int cp210x_get_config(struct usb_serial_port *port, u8 request, | |||
| 287 | /* Issue the request, attempting to read 'size' bytes */ | 287 | /* Issue the request, attempting to read 'size' bytes */ |
| 288 | result = usb_control_msg(serial->dev, usb_rcvctrlpipe(serial->dev, 0), | 288 | result = usb_control_msg(serial->dev, usb_rcvctrlpipe(serial->dev, 0), |
| 289 | request, REQTYPE_DEVICE_TO_HOST, 0x0000, | 289 | request, REQTYPE_DEVICE_TO_HOST, 0x0000, |
| 290 | port_priv->bInterfaceNumber, buf, size, 300); | 290 | port_priv->bInterfaceNumber, buf, size, |
| 291 | USB_CTRL_GET_TIMEOUT); | ||
| 291 | 292 | ||
| 292 | /* Convert data into an array of integers */ | 293 | /* Convert data into an array of integers */ |
| 293 | for (i = 0; i < length; i++) | 294 | for (i = 0; i < length; i++) |
| @@ -340,12 +341,14 @@ static int cp210x_set_config(struct usb_serial_port *port, u8 request, | |||
| 340 | result = usb_control_msg(serial->dev, | 341 | result = usb_control_msg(serial->dev, |
| 341 | usb_sndctrlpipe(serial->dev, 0), | 342 | usb_sndctrlpipe(serial->dev, 0), |
| 342 | request, REQTYPE_HOST_TO_DEVICE, 0x0000, | 343 | request, REQTYPE_HOST_TO_DEVICE, 0x0000, |
| 343 | port_priv->bInterfaceNumber, buf, size, 300); | 344 | port_priv->bInterfaceNumber, buf, size, |
| 345 | USB_CTRL_SET_TIMEOUT); | ||
| 344 | } else { | 346 | } else { |
| 345 | result = usb_control_msg(serial->dev, | 347 | result = usb_control_msg(serial->dev, |
| 346 | usb_sndctrlpipe(serial->dev, 0), | 348 | usb_sndctrlpipe(serial->dev, 0), |
| 347 | request, REQTYPE_HOST_TO_DEVICE, data[0], | 349 | request, REQTYPE_HOST_TO_DEVICE, data[0], |
| 348 | port_priv->bInterfaceNumber, NULL, 0, 300); | 350 | port_priv->bInterfaceNumber, NULL, 0, |
| 351 | USB_CTRL_SET_TIMEOUT); | ||
| 349 | } | 352 | } |
| 350 | 353 | ||
| 351 | kfree(buf); | 354 | kfree(buf); |
diff --git a/drivers/usb/serial/ftdi_sio.c b/drivers/usb/serial/ftdi_sio.c index ff8605b4b4be..02e7f2d32d52 100644 --- a/drivers/usb/serial/ftdi_sio.c +++ b/drivers/usb/serial/ftdi_sio.c | |||
| @@ -75,7 +75,8 @@ struct ftdi_private { | |||
| 75 | unsigned long last_dtr_rts; /* saved modem control outputs */ | 75 | unsigned long last_dtr_rts; /* saved modem control outputs */ |
| 76 | struct async_icount icount; | 76 | struct async_icount icount; |
| 77 | wait_queue_head_t delta_msr_wait; /* Used for TIOCMIWAIT */ | 77 | wait_queue_head_t delta_msr_wait; /* Used for TIOCMIWAIT */ |
| 78 | char prev_status, diff_status; /* Used for TIOCMIWAIT */ | 78 | char prev_status; /* Used for TIOCMIWAIT */ |
| 79 | bool dev_gone; /* Used to abort TIOCMIWAIT */ | ||
| 79 | char transmit_empty; /* If transmitter is empty or not */ | 80 | char transmit_empty; /* If transmitter is empty or not */ |
| 80 | struct usb_serial_port *port; | 81 | struct usb_serial_port *port; |
| 81 | __u16 interface; /* FT2232C, FT2232H or FT4232H port interface | 82 | __u16 interface; /* FT2232C, FT2232H or FT4232H port interface |
| @@ -1681,6 +1682,7 @@ static int ftdi_sio_port_probe(struct usb_serial_port *port) | |||
| 1681 | init_waitqueue_head(&priv->delta_msr_wait); | 1682 | init_waitqueue_head(&priv->delta_msr_wait); |
| 1682 | 1683 | ||
| 1683 | priv->flags = ASYNC_LOW_LATENCY; | 1684 | priv->flags = ASYNC_LOW_LATENCY; |
| 1685 | priv->dev_gone = false; | ||
| 1684 | 1686 | ||
| 1685 | if (quirk && quirk->port_probe) | 1687 | if (quirk && quirk->port_probe) |
| 1686 | quirk->port_probe(priv); | 1688 | quirk->port_probe(priv); |
| @@ -1839,6 +1841,9 @@ static int ftdi_sio_port_remove(struct usb_serial_port *port) | |||
| 1839 | 1841 | ||
| 1840 | dbg("%s", __func__); | 1842 | dbg("%s", __func__); |
| 1841 | 1843 | ||
| 1844 | priv->dev_gone = true; | ||
| 1845 | wake_up_interruptible_all(&priv->delta_msr_wait); | ||
| 1846 | |||
| 1842 | remove_sysfs_attrs(port); | 1847 | remove_sysfs_attrs(port); |
| 1843 | 1848 | ||
| 1844 | kref_put(&priv->kref, ftdi_sio_priv_release); | 1849 | kref_put(&priv->kref, ftdi_sio_priv_release); |
| @@ -1982,17 +1987,19 @@ static int ftdi_process_packet(struct tty_struct *tty, | |||
| 1982 | N.B. packet may be processed more than once, but differences | 1987 | N.B. packet may be processed more than once, but differences |
| 1983 | are only processed once. */ | 1988 | are only processed once. */ |
| 1984 | status = packet[0] & FTDI_STATUS_B0_MASK; | 1989 | status = packet[0] & FTDI_STATUS_B0_MASK; |
| 1985 | if (status & FTDI_RS0_CTS) | ||
| 1986 | priv->icount.cts++; | ||
| 1987 | if (status & FTDI_RS0_DSR) | ||
| 1988 | priv->icount.dsr++; | ||
| 1989 | if (status & FTDI_RS0_RI) | ||
| 1990 | priv->icount.rng++; | ||
| 1991 | if (status & FTDI_RS0_RLSD) | ||
| 1992 | priv->icount.dcd++; | ||
| 1993 | if (status != priv->prev_status) { | 1990 | if (status != priv->prev_status) { |
| 1994 | priv->diff_status |= status ^ priv->prev_status; | 1991 | char diff_status = status ^ priv->prev_status; |
| 1995 | wake_up_interruptible(&priv->delta_msr_wait); | 1992 | |
| 1993 | if (diff_status & FTDI_RS0_CTS) | ||
| 1994 | priv->icount.cts++; | ||
| 1995 | if (diff_status & FTDI_RS0_DSR) | ||
| 1996 | priv->icount.dsr++; | ||
| 1997 | if (diff_status & FTDI_RS0_RI) | ||
| 1998 | priv->icount.rng++; | ||
| 1999 | if (diff_status & FTDI_RS0_RLSD) | ||
| 2000 | priv->icount.dcd++; | ||
| 2001 | |||
| 2002 | wake_up_interruptible_all(&priv->delta_msr_wait); | ||
| 1996 | priv->prev_status = status; | 2003 | priv->prev_status = status; |
| 1997 | } | 2004 | } |
| 1998 | 2005 | ||
| @@ -2395,15 +2402,12 @@ static int ftdi_ioctl(struct tty_struct *tty, | |||
| 2395 | */ | 2402 | */ |
| 2396 | case TIOCMIWAIT: | 2403 | case TIOCMIWAIT: |
| 2397 | cprev = priv->icount; | 2404 | cprev = priv->icount; |
| 2398 | while (1) { | 2405 | while (!priv->dev_gone) { |
| 2399 | interruptible_sleep_on(&priv->delta_msr_wait); | 2406 | interruptible_sleep_on(&priv->delta_msr_wait); |
| 2400 | /* see if a signal did it */ | 2407 | /* see if a signal did it */ |
| 2401 | if (signal_pending(current)) | 2408 | if (signal_pending(current)) |
| 2402 | return -ERESTARTSYS; | 2409 | return -ERESTARTSYS; |
| 2403 | cnow = priv->icount; | 2410 | cnow = priv->icount; |
| 2404 | if (cnow.rng == cprev.rng && cnow.dsr == cprev.dsr && | ||
| 2405 | cnow.dcd == cprev.dcd && cnow.cts == cprev.cts) | ||
| 2406 | return -EIO; /* no change => error */ | ||
| 2407 | if (((arg & TIOCM_RNG) && (cnow.rng != cprev.rng)) || | 2411 | if (((arg & TIOCM_RNG) && (cnow.rng != cprev.rng)) || |
| 2408 | ((arg & TIOCM_DSR) && (cnow.dsr != cprev.dsr)) || | 2412 | ((arg & TIOCM_DSR) && (cnow.dsr != cprev.dsr)) || |
| 2409 | ((arg & TIOCM_CD) && (cnow.dcd != cprev.dcd)) || | 2413 | ((arg & TIOCM_CD) && (cnow.dcd != cprev.dcd)) || |
| @@ -2412,7 +2416,7 @@ static int ftdi_ioctl(struct tty_struct *tty, | |||
| 2412 | } | 2416 | } |
| 2413 | cprev = cnow; | 2417 | cprev = cnow; |
| 2414 | } | 2418 | } |
| 2415 | /* not reached */ | 2419 | return -EIO; |
| 2416 | break; | 2420 | break; |
| 2417 | case TIOCSERGETLSR: | 2421 | case TIOCSERGETLSR: |
| 2418 | return get_lsr_info(port, (struct serial_struct __user *)arg); | 2422 | return get_lsr_info(port, (struct serial_struct __user *)arg); |
diff --git a/drivers/usb/serial/metro-usb.c b/drivers/usb/serial/metro-usb.c index 6e1622f2a297..08d16e8c002d 100644 --- a/drivers/usb/serial/metro-usb.c +++ b/drivers/usb/serial/metro-usb.c | |||
| @@ -27,8 +27,8 @@ | |||
| 27 | 27 | ||
| 28 | /* Product information. */ | 28 | /* Product information. */ |
| 29 | #define FOCUS_VENDOR_ID 0x0C2E | 29 | #define FOCUS_VENDOR_ID 0x0C2E |
| 30 | #define FOCUS_PRODUCT_ID 0x0720 | 30 | #define FOCUS_PRODUCT_ID_BI 0x0720 |
| 31 | #define FOCUS_PRODUCT_ID_UNI 0x0710 | 31 | #define FOCUS_PRODUCT_ID_UNI 0x0700 |
| 32 | 32 | ||
| 33 | #define METROUSB_SET_REQUEST_TYPE 0x40 | 33 | #define METROUSB_SET_REQUEST_TYPE 0x40 |
| 34 | #define METROUSB_SET_MODEM_CTRL_REQUEST 10 | 34 | #define METROUSB_SET_MODEM_CTRL_REQUEST 10 |
| @@ -47,7 +47,7 @@ struct metrousb_private { | |||
| 47 | 47 | ||
| 48 | /* Device table list. */ | 48 | /* Device table list. */ |
| 49 | static struct usb_device_id id_table[] = { | 49 | static struct usb_device_id id_table[] = { |
| 50 | { USB_DEVICE(FOCUS_VENDOR_ID, FOCUS_PRODUCT_ID) }, | 50 | { USB_DEVICE(FOCUS_VENDOR_ID, FOCUS_PRODUCT_ID_BI) }, |
| 51 | { USB_DEVICE(FOCUS_VENDOR_ID, FOCUS_PRODUCT_ID_UNI) }, | 51 | { USB_DEVICE(FOCUS_VENDOR_ID, FOCUS_PRODUCT_ID_UNI) }, |
| 52 | { }, /* Terminating entry. */ | 52 | { }, /* Terminating entry. */ |
| 53 | }; | 53 | }; |
diff --git a/drivers/usb/serial/option.c b/drivers/usb/serial/option.c index 836cfa9a515f..f4465ccddc35 100644 --- a/drivers/usb/serial/option.c +++ b/drivers/usb/serial/option.c | |||
| @@ -708,6 +708,7 @@ static const struct usb_device_id option_ids[] = { | |||
| 708 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_EVDO_EMBEDDED_FULLSPEED) }, | 708 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_EVDO_EMBEDDED_FULLSPEED) }, |
| 709 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_EMBEDDED_FULLSPEED) }, | 709 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_EMBEDDED_FULLSPEED) }, |
| 710 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_EVDO_HIGHSPEED) }, | 710 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_EVDO_HIGHSPEED) }, |
| 711 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED) }, | ||
| 711 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED3) }, | 712 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED3) }, |
| 712 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED4) }, | 713 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED4) }, |
| 713 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED5) }, | 714 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_HSPA_HIGHSPEED5) }, |
diff --git a/drivers/usb/serial/pl2303.c b/drivers/usb/serial/pl2303.c index ff4a174fa5de..a1a9062954c4 100644 --- a/drivers/usb/serial/pl2303.c +++ b/drivers/usb/serial/pl2303.c | |||
| @@ -420,7 +420,7 @@ static void pl2303_set_termios(struct tty_struct *tty, | |||
| 420 | control = priv->line_control; | 420 | control = priv->line_control; |
| 421 | if ((cflag & CBAUD) == B0) | 421 | if ((cflag & CBAUD) == B0) |
| 422 | priv->line_control &= ~(CONTROL_DTR | CONTROL_RTS); | 422 | priv->line_control &= ~(CONTROL_DTR | CONTROL_RTS); |
| 423 | else | 423 | else if ((old_termios->c_cflag & CBAUD) == B0) |
| 424 | priv->line_control |= (CONTROL_DTR | CONTROL_RTS); | 424 | priv->line_control |= (CONTROL_DTR | CONTROL_RTS); |
| 425 | if (control != priv->line_control) { | 425 | if (control != priv->line_control) { |
| 426 | control = priv->line_control; | 426 | control = priv->line_control; |
diff --git a/drivers/usb/serial/sierra.c b/drivers/usb/serial/sierra.c index f14465a83dd1..8c8bf806f6fa 100644 --- a/drivers/usb/serial/sierra.c +++ b/drivers/usb/serial/sierra.c | |||
| @@ -221,7 +221,7 @@ static const struct sierra_iface_info typeB_interface_list = { | |||
| 221 | }; | 221 | }; |
| 222 | 222 | ||
| 223 | /* 'blacklist' of interfaces not served by this driver */ | 223 | /* 'blacklist' of interfaces not served by this driver */ |
| 224 | static const u8 direct_ip_non_serial_ifaces[] = { 7, 8, 9, 10, 11 }; | 224 | static const u8 direct_ip_non_serial_ifaces[] = { 7, 8, 9, 10, 11, 19, 20 }; |
| 225 | static const struct sierra_iface_info direct_ip_interface_blacklist = { | 225 | static const struct sierra_iface_info direct_ip_interface_blacklist = { |
| 226 | .infolen = ARRAY_SIZE(direct_ip_non_serial_ifaces), | 226 | .infolen = ARRAY_SIZE(direct_ip_non_serial_ifaces), |
| 227 | .ifaceinfo = direct_ip_non_serial_ifaces, | 227 | .ifaceinfo = direct_ip_non_serial_ifaces, |
| @@ -298,6 +298,9 @@ static const struct usb_device_id id_table[] = { | |||
| 298 | /* Sierra Wireless HSPA Non-Composite Device */ | 298 | /* Sierra Wireless HSPA Non-Composite Device */ |
| 299 | { USB_DEVICE_AND_INTERFACE_INFO(0x1199, 0x6892, 0xFF, 0xFF, 0xFF)}, | 299 | { USB_DEVICE_AND_INTERFACE_INFO(0x1199, 0x6892, 0xFF, 0xFF, 0xFF)}, |
| 300 | { USB_DEVICE(0x1199, 0x6893) }, /* Sierra Wireless Device */ | 300 | { USB_DEVICE(0x1199, 0x6893) }, /* Sierra Wireless Device */ |
| 301 | { USB_DEVICE(0x1199, 0x68A2), /* Sierra Wireless MC77xx in QMI mode */ | ||
| 302 | .driver_info = (kernel_ulong_t)&direct_ip_interface_blacklist | ||
| 303 | }, | ||
| 301 | { USB_DEVICE(0x1199, 0x68A3), /* Sierra Wireless Direct IP modems */ | 304 | { USB_DEVICE(0x1199, 0x68A3), /* Sierra Wireless Direct IP modems */ |
| 302 | .driver_info = (kernel_ulong_t)&direct_ip_interface_blacklist | 305 | .driver_info = (kernel_ulong_t)&direct_ip_interface_blacklist |
| 303 | }, | 306 | }, |
diff --git a/drivers/usb/serial/usb-serial.c b/drivers/usb/serial/usb-serial.c index 69230f01056a..97355a15bbea 100644 --- a/drivers/usb/serial/usb-serial.c +++ b/drivers/usb/serial/usb-serial.c | |||
| @@ -1059,6 +1059,12 @@ int usb_serial_probe(struct usb_interface *interface, | |||
| 1059 | serial->attached = 1; | 1059 | serial->attached = 1; |
| 1060 | } | 1060 | } |
| 1061 | 1061 | ||
| 1062 | /* Avoid race with tty_open and serial_install by setting the | ||
| 1063 | * disconnected flag and not clearing it until all ports have been | ||
| 1064 | * registered. | ||
| 1065 | */ | ||
| 1066 | serial->disconnected = 1; | ||
| 1067 | |||
| 1062 | if (get_free_serial(serial, num_ports, &minor) == NULL) { | 1068 | if (get_free_serial(serial, num_ports, &minor) == NULL) { |
| 1063 | dev_err(&interface->dev, "No more free serial devices\n"); | 1069 | dev_err(&interface->dev, "No more free serial devices\n"); |
| 1064 | goto probe_error; | 1070 | goto probe_error; |
| @@ -1070,19 +1076,16 @@ int usb_serial_probe(struct usb_interface *interface, | |||
| 1070 | port = serial->port[i]; | 1076 | port = serial->port[i]; |
| 1071 | dev_set_name(&port->dev, "ttyUSB%d", port->number); | 1077 | dev_set_name(&port->dev, "ttyUSB%d", port->number); |
| 1072 | dbg ("%s - registering %s", __func__, dev_name(&port->dev)); | 1078 | dbg ("%s - registering %s", __func__, dev_name(&port->dev)); |
| 1073 | port->dev_state = PORT_REGISTERING; | ||
| 1074 | device_enable_async_suspend(&port->dev); | 1079 | device_enable_async_suspend(&port->dev); |
| 1075 | 1080 | ||
| 1076 | retval = device_add(&port->dev); | 1081 | retval = device_add(&port->dev); |
| 1077 | if (retval) { | 1082 | if (retval) |
| 1078 | dev_err(&port->dev, "Error registering port device, " | 1083 | dev_err(&port->dev, "Error registering port device, " |
| 1079 | "continuing\n"); | 1084 | "continuing\n"); |
| 1080 | port->dev_state = PORT_UNREGISTERED; | ||
| 1081 | } else { | ||
| 1082 | port->dev_state = PORT_REGISTERED; | ||
| 1083 | } | ||
| 1084 | } | 1085 | } |
| 1085 | 1086 | ||
| 1087 | serial->disconnected = 0; | ||
| 1088 | |||
| 1086 | usb_serial_console_init(debug, minor); | 1089 | usb_serial_console_init(debug, minor); |
| 1087 | 1090 | ||
| 1088 | exit: | 1091 | exit: |
| @@ -1124,22 +1127,8 @@ void usb_serial_disconnect(struct usb_interface *interface) | |||
| 1124 | } | 1127 | } |
| 1125 | kill_traffic(port); | 1128 | kill_traffic(port); |
| 1126 | cancel_work_sync(&port->work); | 1129 | cancel_work_sync(&port->work); |
| 1127 | if (port->dev_state == PORT_REGISTERED) { | 1130 | if (device_is_registered(&port->dev)) |
| 1128 | |||
| 1129 | /* Make sure the port is bound so that the | ||
| 1130 | * driver's port_remove method is called. | ||
| 1131 | */ | ||
| 1132 | if (!port->dev.driver) { | ||
| 1133 | int rc; | ||
| 1134 | |||
| 1135 | port->dev.driver = | ||
| 1136 | &serial->type->driver; | ||
| 1137 | rc = device_bind_driver(&port->dev); | ||
| 1138 | } | ||
| 1139 | port->dev_state = PORT_UNREGISTERING; | ||
| 1140 | device_del(&port->dev); | 1131 | device_del(&port->dev); |
| 1141 | port->dev_state = PORT_UNREGISTERED; | ||
| 1142 | } | ||
| 1143 | } | 1132 | } |
| 1144 | } | 1133 | } |
| 1145 | serial->type->disconnect(serial); | 1134 | serial->type->disconnect(serial); |
diff --git a/drivers/usb/storage/usb.c b/drivers/usb/storage/usb.c index c18538e4a6db..2653e73db623 100644 --- a/drivers/usb/storage/usb.c +++ b/drivers/usb/storage/usb.c | |||
| @@ -132,6 +132,35 @@ static struct us_unusual_dev for_dynamic_ids = | |||
| 132 | #undef COMPLIANT_DEV | 132 | #undef COMPLIANT_DEV |
| 133 | #undef USUAL_DEV | 133 | #undef USUAL_DEV |
| 134 | 134 | ||
| 135 | #ifdef CONFIG_LOCKDEP | ||
| 136 | |||
| 137 | static struct lock_class_key us_interface_key[USB_MAXINTERFACES]; | ||
| 138 | |||
| 139 | static void us_set_lock_class(struct mutex *mutex, | ||
| 140 | struct usb_interface *intf) | ||
| 141 | { | ||
| 142 | struct usb_device *udev = interface_to_usbdev(intf); | ||
| 143 | struct usb_host_config *config = udev->actconfig; | ||
| 144 | int i; | ||
| 145 | |||
| 146 | for (i = 0; i < config->desc.bNumInterfaces; i++) { | ||
| 147 | if (config->interface[i] == intf) | ||
| 148 | break; | ||
| 149 | } | ||
| 150 | |||
| 151 | BUG_ON(i == config->desc.bNumInterfaces); | ||
| 152 | |||
| 153 | lockdep_set_class(mutex, &us_interface_key[i]); | ||
| 154 | } | ||
| 155 | |||
| 156 | #else | ||
| 157 | |||
| 158 | static void us_set_lock_class(struct mutex *mutex, | ||
| 159 | struct usb_interface *intf) | ||
| 160 | { | ||
| 161 | } | ||
| 162 | |||
| 163 | #endif | ||
| 135 | 164 | ||
| 136 | #ifdef CONFIG_PM /* Minimal support for suspend and resume */ | 165 | #ifdef CONFIG_PM /* Minimal support for suspend and resume */ |
| 137 | 166 | ||
| @@ -895,6 +924,7 @@ int usb_stor_probe1(struct us_data **pus, | |||
| 895 | *pus = us = host_to_us(host); | 924 | *pus = us = host_to_us(host); |
| 896 | memset(us, 0, sizeof(struct us_data)); | 925 | memset(us, 0, sizeof(struct us_data)); |
| 897 | mutex_init(&(us->dev_mutex)); | 926 | mutex_init(&(us->dev_mutex)); |
| 927 | us_set_lock_class(&us->dev_mutex, intf); | ||
| 898 | init_completion(&us->cmnd_ready); | 928 | init_completion(&us->cmnd_ready); |
| 899 | init_completion(&(us->notify)); | 929 | init_completion(&(us->notify)); |
| 900 | init_waitqueue_head(&us->delay_wait); | 930 | init_waitqueue_head(&us->delay_wait); |
diff --git a/drivers/uwb/hwa-rc.c b/drivers/uwb/hwa-rc.c index 66797e9c5010..810c90ae2c55 100644 --- a/drivers/uwb/hwa-rc.c +++ b/drivers/uwb/hwa-rc.c | |||
| @@ -645,7 +645,8 @@ void hwarc_neep_cb(struct urb *urb) | |||
| 645 | dev_err(dev, "NEEP: URB error %d\n", urb->status); | 645 | dev_err(dev, "NEEP: URB error %d\n", urb->status); |
| 646 | } | 646 | } |
| 647 | result = usb_submit_urb(urb, GFP_ATOMIC); | 647 | result = usb_submit_urb(urb, GFP_ATOMIC); |
| 648 | if (result < 0) { | 648 | if (result < 0 && result != -ENODEV && result != -EPERM) { |
| 649 | /* ignoring unrecoverable errors */ | ||
| 649 | dev_err(dev, "NEEP: Can't resubmit URB (%d) resetting device\n", | 650 | dev_err(dev, "NEEP: Can't resubmit URB (%d) resetting device\n", |
| 650 | result); | 651 | result); |
| 651 | goto error; | 652 | goto error; |
diff --git a/drivers/uwb/neh.c b/drivers/uwb/neh.c index a269937be1b8..8cb71bb333c2 100644 --- a/drivers/uwb/neh.c +++ b/drivers/uwb/neh.c | |||
| @@ -107,6 +107,7 @@ struct uwb_rc_neh { | |||
| 107 | u8 evt_type; | 107 | u8 evt_type; |
| 108 | __le16 evt; | 108 | __le16 evt; |
| 109 | u8 context; | 109 | u8 context; |
| 110 | u8 completed; | ||
| 110 | uwb_rc_cmd_cb_f cb; | 111 | uwb_rc_cmd_cb_f cb; |
| 111 | void *arg; | 112 | void *arg; |
| 112 | 113 | ||
| @@ -409,6 +410,7 @@ static void uwb_rc_neh_grok_event(struct uwb_rc *rc, struct uwb_rceb *rceb, size | |||
| 409 | struct device *dev = &rc->uwb_dev.dev; | 410 | struct device *dev = &rc->uwb_dev.dev; |
| 410 | struct uwb_rc_neh *neh; | 411 | struct uwb_rc_neh *neh; |
| 411 | struct uwb_rceb *notif; | 412 | struct uwb_rceb *notif; |
| 413 | unsigned long flags; | ||
| 412 | 414 | ||
| 413 | if (rceb->bEventContext == 0) { | 415 | if (rceb->bEventContext == 0) { |
| 414 | notif = kmalloc(size, GFP_ATOMIC); | 416 | notif = kmalloc(size, GFP_ATOMIC); |
| @@ -422,7 +424,11 @@ static void uwb_rc_neh_grok_event(struct uwb_rc *rc, struct uwb_rceb *rceb, size | |||
| 422 | } else { | 424 | } else { |
| 423 | neh = uwb_rc_neh_lookup(rc, rceb); | 425 | neh = uwb_rc_neh_lookup(rc, rceb); |
| 424 | if (neh) { | 426 | if (neh) { |
| 425 | del_timer_sync(&neh->timer); | 427 | spin_lock_irqsave(&rc->neh_lock, flags); |
| 428 | /* to guard against a timeout */ | ||
| 429 | neh->completed = 1; | ||
| 430 | del_timer(&neh->timer); | ||
| 431 | spin_unlock_irqrestore(&rc->neh_lock, flags); | ||
| 426 | uwb_rc_neh_cb(neh, rceb, size); | 432 | uwb_rc_neh_cb(neh, rceb, size); |
| 427 | } else | 433 | } else |
| 428 | dev_warn(dev, "event 0x%02x/%04x/%02x (%zu bytes): nobody cared\n", | 434 | dev_warn(dev, "event 0x%02x/%04x/%02x (%zu bytes): nobody cared\n", |
| @@ -568,6 +574,10 @@ static void uwb_rc_neh_timer(unsigned long arg) | |||
| 568 | unsigned long flags; | 574 | unsigned long flags; |
| 569 | 575 | ||
| 570 | spin_lock_irqsave(&rc->neh_lock, flags); | 576 | spin_lock_irqsave(&rc->neh_lock, flags); |
| 577 | if (neh->completed) { | ||
| 578 | spin_unlock_irqrestore(&rc->neh_lock, flags); | ||
| 579 | return; | ||
| 580 | } | ||
| 571 | if (neh->context) | 581 | if (neh->context) |
| 572 | __uwb_rc_neh_rm(rc, neh); | 582 | __uwb_rc_neh_rm(rc, neh); |
| 573 | else | 583 | else |
diff --git a/drivers/vhost/test.c b/drivers/vhost/test.c index fc9a1d75281f..3de00d9fae2e 100644 --- a/drivers/vhost/test.c +++ b/drivers/vhost/test.c | |||
| @@ -155,7 +155,7 @@ static int vhost_test_release(struct inode *inode, struct file *f) | |||
| 155 | 155 | ||
| 156 | vhost_test_stop(n, &private); | 156 | vhost_test_stop(n, &private); |
| 157 | vhost_test_flush(n); | 157 | vhost_test_flush(n); |
| 158 | vhost_dev_cleanup(&n->dev); | 158 | vhost_dev_cleanup(&n->dev, false); |
| 159 | /* We do an extra flush before freeing memory, | 159 | /* We do an extra flush before freeing memory, |
| 160 | * since jobs can re-queue themselves. */ | 160 | * since jobs can re-queue themselves. */ |
| 161 | vhost_test_flush(n); | 161 | vhost_test_flush(n); |
diff --git a/drivers/video/au1100fb.c b/drivers/video/au1100fb.c index befcbd8ef019..ffbce4525468 100644 --- a/drivers/video/au1100fb.c +++ b/drivers/video/au1100fb.c | |||
| @@ -499,7 +499,8 @@ static int __devinit au1100fb_drv_probe(struct platform_device *dev) | |||
| 499 | au1100fb_fix.mmio_start = regs_res->start; | 499 | au1100fb_fix.mmio_start = regs_res->start; |
| 500 | au1100fb_fix.mmio_len = resource_size(regs_res); | 500 | au1100fb_fix.mmio_len = resource_size(regs_res); |
| 501 | 501 | ||
| 502 | if (!devm_request_mem_region(au1100fb_fix.mmio_start, | 502 | if (!devm_request_mem_region(&dev->dev, |
| 503 | au1100fb_fix.mmio_start, | ||
| 503 | au1100fb_fix.mmio_len, | 504 | au1100fb_fix.mmio_len, |
| 504 | DRIVER_NAME)) { | 505 | DRIVER_NAME)) { |
| 505 | print_err("fail to lock memory region at 0x%08lx", | 506 | print_err("fail to lock memory region at 0x%08lx", |
| @@ -516,7 +517,7 @@ static int __devinit au1100fb_drv_probe(struct platform_device *dev) | |||
| 516 | fbdev->fb_len = fbdev->panel->xres * fbdev->panel->yres * | 517 | fbdev->fb_len = fbdev->panel->xres * fbdev->panel->yres * |
| 517 | (fbdev->panel->bpp >> 3) * AU1100FB_NBR_VIDEO_BUFFERS; | 518 | (fbdev->panel->bpp >> 3) * AU1100FB_NBR_VIDEO_BUFFERS; |
| 518 | 519 | ||
| 519 | fbdev->fb_mem = dmam_alloc_coherent(&dev->dev, &dev->dev, | 520 | fbdev->fb_mem = dmam_alloc_coherent(&dev->dev, |
| 520 | PAGE_ALIGN(fbdev->fb_len), | 521 | PAGE_ALIGN(fbdev->fb_len), |
| 521 | &fbdev->fb_phys, GFP_KERNEL); | 522 | &fbdev->fb_phys, GFP_KERNEL); |
| 522 | if (!fbdev->fb_mem) { | 523 | if (!fbdev->fb_mem) { |
diff --git a/drivers/video/au1200fb.c b/drivers/video/au1200fb.c index 3e9a773db09f..7ca79f02056e 100644 --- a/drivers/video/au1200fb.c +++ b/drivers/video/au1200fb.c | |||
| @@ -1724,7 +1724,7 @@ static int __devinit au1200fb_drv_probe(struct platform_device *dev) | |||
| 1724 | /* Allocate the framebuffer to the maximum screen size */ | 1724 | /* Allocate the framebuffer to the maximum screen size */ |
| 1725 | fbdev->fb_len = (win->w[plane].xres * win->w[plane].yres * bpp) / 8; | 1725 | fbdev->fb_len = (win->w[plane].xres * win->w[plane].yres * bpp) / 8; |
| 1726 | 1726 | ||
| 1727 | fbdev->fb_mem = dmam_alloc_noncoherent(&dev->dev, &dev->dev, | 1727 | fbdev->fb_mem = dmam_alloc_noncoherent(&dev->dev, |
| 1728 | PAGE_ALIGN(fbdev->fb_len), | 1728 | PAGE_ALIGN(fbdev->fb_len), |
| 1729 | &fbdev->fb_phys, GFP_KERNEL); | 1729 | &fbdev->fb_phys, GFP_KERNEL); |
| 1730 | if (!fbdev->fb_mem) { | 1730 | if (!fbdev->fb_mem) { |
diff --git a/drivers/video/kyro/STG4000Reg.h b/drivers/video/kyro/STG4000Reg.h index 5d6269882589..50f4670e9252 100644 --- a/drivers/video/kyro/STG4000Reg.h +++ b/drivers/video/kyro/STG4000Reg.h | |||
| @@ -73,210 +73,210 @@ typedef enum _OVRL_PIX_FORMAT { | |||
| 73 | /* Register Table */ | 73 | /* Register Table */ |
| 74 | typedef struct { | 74 | typedef struct { |
| 75 | /* 0h */ | 75 | /* 0h */ |
| 76 | volatile unsigned long Thread0Enable; /* 0x0000 */ | 76 | volatile u32 Thread0Enable; /* 0x0000 */ |
| 77 | volatile unsigned long Thread1Enable; /* 0x0004 */ | 77 | volatile u32 Thread1Enable; /* 0x0004 */ |
| 78 | volatile unsigned long Thread0Recover; /* 0x0008 */ | 78 | volatile u32 Thread0Recover; /* 0x0008 */ |
| 79 | volatile unsigned long Thread1Recover; /* 0x000C */ | 79 | volatile u32 Thread1Recover; /* 0x000C */ |
| 80 | volatile unsigned long Thread0Step; /* 0x0010 */ | 80 | volatile u32 Thread0Step; /* 0x0010 */ |
| 81 | volatile unsigned long Thread1Step; /* 0x0014 */ | 81 | volatile u32 Thread1Step; /* 0x0014 */ |
| 82 | volatile unsigned long VideoInStatus; /* 0x0018 */ | 82 | volatile u32 VideoInStatus; /* 0x0018 */ |
| 83 | volatile unsigned long Core2InSignStart; /* 0x001C */ | 83 | volatile u32 Core2InSignStart; /* 0x001C */ |
| 84 | volatile unsigned long Core1ResetVector; /* 0x0020 */ | 84 | volatile u32 Core1ResetVector; /* 0x0020 */ |
| 85 | volatile unsigned long Core1ROMOffset; /* 0x0024 */ | 85 | volatile u32 Core1ROMOffset; /* 0x0024 */ |
| 86 | volatile unsigned long Core1ArbiterPriority; /* 0x0028 */ | 86 | volatile u32 Core1ArbiterPriority; /* 0x0028 */ |
| 87 | volatile unsigned long VideoInControl; /* 0x002C */ | 87 | volatile u32 VideoInControl; /* 0x002C */ |
| 88 | volatile unsigned long VideoInReg0CtrlA; /* 0x0030 */ | 88 | volatile u32 VideoInReg0CtrlA; /* 0x0030 */ |
| 89 | volatile unsigned long VideoInReg0CtrlB; /* 0x0034 */ | 89 | volatile u32 VideoInReg0CtrlB; /* 0x0034 */ |
| 90 | volatile unsigned long VideoInReg1CtrlA; /* 0x0038 */ | 90 | volatile u32 VideoInReg1CtrlA; /* 0x0038 */ |
| 91 | volatile unsigned long VideoInReg1CtrlB; /* 0x003C */ | 91 | volatile u32 VideoInReg1CtrlB; /* 0x003C */ |
| 92 | volatile unsigned long Thread0Kicker; /* 0x0040 */ | 92 | volatile u32 Thread0Kicker; /* 0x0040 */ |
| 93 | volatile unsigned long Core2InputSign; /* 0x0044 */ | 93 | volatile u32 Core2InputSign; /* 0x0044 */ |
| 94 | volatile unsigned long Thread0ProgCtr; /* 0x0048 */ | 94 | volatile u32 Thread0ProgCtr; /* 0x0048 */ |
| 95 | volatile unsigned long Thread1ProgCtr; /* 0x004C */ | 95 | volatile u32 Thread1ProgCtr; /* 0x004C */ |
| 96 | volatile unsigned long Thread1Kicker; /* 0x0050 */ | 96 | volatile u32 Thread1Kicker; /* 0x0050 */ |
| 97 | volatile unsigned long GPRegister1; /* 0x0054 */ | 97 | volatile u32 GPRegister1; /* 0x0054 */ |
| 98 | volatile unsigned long GPRegister2; /* 0x0058 */ | 98 | volatile u32 GPRegister2; /* 0x0058 */ |
| 99 | volatile unsigned long GPRegister3; /* 0x005C */ | 99 | volatile u32 GPRegister3; /* 0x005C */ |
| 100 | volatile unsigned long GPRegister4; /* 0x0060 */ | 100 | volatile u32 GPRegister4; /* 0x0060 */ |
| 101 | volatile unsigned long SerialIntA; /* 0x0064 */ | 101 | volatile u32 SerialIntA; /* 0x0064 */ |
| 102 | 102 | ||
| 103 | volatile unsigned long Fill0[6]; /* GAP 0x0068 - 0x007C */ | 103 | volatile u32 Fill0[6]; /* GAP 0x0068 - 0x007C */ |
| 104 | 104 | ||
| 105 | volatile unsigned long SoftwareReset; /* 0x0080 */ | 105 | volatile u32 SoftwareReset; /* 0x0080 */ |
| 106 | volatile unsigned long SerialIntB; /* 0x0084 */ | 106 | volatile u32 SerialIntB; /* 0x0084 */ |
| 107 | 107 | ||
| 108 | volatile unsigned long Fill1[37]; /* GAP 0x0088 - 0x011C */ | 108 | volatile u32 Fill1[37]; /* GAP 0x0088 - 0x011C */ |
| 109 | 109 | ||
| 110 | volatile unsigned long ROMELQV; /* 0x011C */ | 110 | volatile u32 ROMELQV; /* 0x011C */ |
| 111 | volatile unsigned long WLWH; /* 0x0120 */ | 111 | volatile u32 WLWH; /* 0x0120 */ |
| 112 | volatile unsigned long ROMELWL; /* 0x0124 */ | 112 | volatile u32 ROMELWL; /* 0x0124 */ |
| 113 | 113 | ||
| 114 | volatile unsigned long dwFill_1; /* GAP 0x0128 */ | 114 | volatile u32 dwFill_1; /* GAP 0x0128 */ |
| 115 | 115 | ||
| 116 | volatile unsigned long IntStatus; /* 0x012C */ | 116 | volatile u32 IntStatus; /* 0x012C */ |
| 117 | volatile unsigned long IntMask; /* 0x0130 */ | 117 | volatile u32 IntMask; /* 0x0130 */ |
| 118 | volatile unsigned long IntClear; /* 0x0134 */ | 118 | volatile u32 IntClear; /* 0x0134 */ |
| 119 | 119 | ||
| 120 | volatile unsigned long Fill2[6]; /* GAP 0x0138 - 0x014C */ | 120 | volatile u32 Fill2[6]; /* GAP 0x0138 - 0x014C */ |
| 121 | 121 | ||
| 122 | volatile unsigned long ROMGPIOA; /* 0x0150 */ | 122 | volatile u32 ROMGPIOA; /* 0x0150 */ |
| 123 | volatile unsigned long ROMGPIOB; /* 0x0154 */ | 123 | volatile u32 ROMGPIOB; /* 0x0154 */ |
| 124 | volatile unsigned long ROMGPIOC; /* 0x0158 */ | 124 | volatile u32 ROMGPIOC; /* 0x0158 */ |
| 125 | volatile unsigned long ROMGPIOD; /* 0x015C */ | 125 | volatile u32 ROMGPIOD; /* 0x015C */ |
| 126 | 126 | ||
| 127 | volatile unsigned long Fill3[2]; /* GAP 0x0160 - 0x0168 */ | 127 | volatile u32 Fill3[2]; /* GAP 0x0160 - 0x0168 */ |
| 128 | 128 | ||
| 129 | volatile unsigned long AGPIntID; /* 0x0168 */ | 129 | volatile u32 AGPIntID; /* 0x0168 */ |
| 130 | volatile unsigned long AGPIntClassCode; /* 0x016C */ | 130 | volatile u32 AGPIntClassCode; /* 0x016C */ |
| 131 | volatile unsigned long AGPIntBIST; /* 0x0170 */ | 131 | volatile u32 AGPIntBIST; /* 0x0170 */ |
| 132 | volatile unsigned long AGPIntSSID; /* 0x0174 */ | 132 | volatile u32 AGPIntSSID; /* 0x0174 */ |
| 133 | volatile unsigned long AGPIntPMCSR; /* 0x0178 */ | 133 | volatile u32 AGPIntPMCSR; /* 0x0178 */ |
| 134 | volatile unsigned long VGAFrameBufBase; /* 0x017C */ | 134 | volatile u32 VGAFrameBufBase; /* 0x017C */ |
| 135 | volatile unsigned long VGANotify; /* 0x0180 */ | 135 | volatile u32 VGANotify; /* 0x0180 */ |
| 136 | volatile unsigned long DACPLLMode; /* 0x0184 */ | 136 | volatile u32 DACPLLMode; /* 0x0184 */ |
| 137 | volatile unsigned long Core1VideoClockDiv; /* 0x0188 */ | 137 | volatile u32 Core1VideoClockDiv; /* 0x0188 */ |
| 138 | volatile unsigned long AGPIntStat; /* 0x018C */ | 138 | volatile u32 AGPIntStat; /* 0x018C */ |
| 139 | 139 | ||
| 140 | /* | 140 | /* |
| 141 | volatile unsigned long Fill4[0x0400/4 - 0x0190/4]; //GAP 0x0190 - 0x0400 | 141 | volatile u32 Fill4[0x0400/4 - 0x0190/4]; //GAP 0x0190 - 0x0400 |
| 142 | volatile unsigned long Fill5[0x05FC/4 - 0x0400/4]; //GAP 0x0400 - 0x05FC Fog Table | 142 | volatile u32 Fill5[0x05FC/4 - 0x0400/4]; //GAP 0x0400 - 0x05FC Fog Table |
| 143 | volatile unsigned long Fill6[0x0604/4 - 0x0600/4]; //GAP 0x0600 - 0x0604 | 143 | volatile u32 Fill6[0x0604/4 - 0x0600/4]; //GAP 0x0600 - 0x0604 |
| 144 | volatile unsigned long Fill7[0x0680/4 - 0x0608/4]; //GAP 0x0608 - 0x0680 | 144 | volatile u32 Fill7[0x0680/4 - 0x0608/4]; //GAP 0x0608 - 0x0680 |
| 145 | volatile unsigned long Fill8[0x07FC/4 - 0x0684/4]; //GAP 0x0684 - 0x07FC | 145 | volatile u32 Fill8[0x07FC/4 - 0x0684/4]; //GAP 0x0684 - 0x07FC |
| 146 | */ | 146 | */ |
| 147 | volatile unsigned long Fill4[412]; /* 0x0190 - 0x07FC */ | 147 | volatile u32 Fill4[412]; /* 0x0190 - 0x07FC */ |
| 148 | 148 | ||
| 149 | volatile unsigned long TACtrlStreamBase; /* 0x0800 */ | 149 | volatile u32 TACtrlStreamBase; /* 0x0800 */ |
| 150 | volatile unsigned long TAObjDataBase; /* 0x0804 */ | 150 | volatile u32 TAObjDataBase; /* 0x0804 */ |
| 151 | volatile unsigned long TAPtrDataBase; /* 0x0808 */ | 151 | volatile u32 TAPtrDataBase; /* 0x0808 */ |
| 152 | volatile unsigned long TARegionDataBase; /* 0x080C */ | 152 | volatile u32 TARegionDataBase; /* 0x080C */ |
| 153 | volatile unsigned long TATailPtrBase; /* 0x0810 */ | 153 | volatile u32 TATailPtrBase; /* 0x0810 */ |
| 154 | volatile unsigned long TAPtrRegionSize; /* 0x0814 */ | 154 | volatile u32 TAPtrRegionSize; /* 0x0814 */ |
| 155 | volatile unsigned long TAConfiguration; /* 0x0818 */ | 155 | volatile u32 TAConfiguration; /* 0x0818 */ |
| 156 | volatile unsigned long TAObjDataStartAddr; /* 0x081C */ | 156 | volatile u32 TAObjDataStartAddr; /* 0x081C */ |
| 157 | volatile unsigned long TAObjDataEndAddr; /* 0x0820 */ | 157 | volatile u32 TAObjDataEndAddr; /* 0x0820 */ |
| 158 | volatile unsigned long TAXScreenClip; /* 0x0824 */ | 158 | volatile u32 TAXScreenClip; /* 0x0824 */ |
| 159 | volatile unsigned long TAYScreenClip; /* 0x0828 */ | 159 | volatile u32 TAYScreenClip; /* 0x0828 */ |
| 160 | volatile unsigned long TARHWClamp; /* 0x082C */ | 160 | volatile u32 TARHWClamp; /* 0x082C */ |
| 161 | volatile unsigned long TARHWCompare; /* 0x0830 */ | 161 | volatile u32 TARHWCompare; /* 0x0830 */ |
| 162 | volatile unsigned long TAStart; /* 0x0834 */ | 162 | volatile u32 TAStart; /* 0x0834 */ |
| 163 | volatile unsigned long TAObjReStart; /* 0x0838 */ | 163 | volatile u32 TAObjReStart; /* 0x0838 */ |
| 164 | volatile unsigned long TAPtrReStart; /* 0x083C */ | 164 | volatile u32 TAPtrReStart; /* 0x083C */ |
| 165 | volatile unsigned long TAStatus1; /* 0x0840 */ | 165 | volatile u32 TAStatus1; /* 0x0840 */ |
| 166 | volatile unsigned long TAStatus2; /* 0x0844 */ | 166 | volatile u32 TAStatus2; /* 0x0844 */ |
| 167 | volatile unsigned long TAIntStatus; /* 0x0848 */ | 167 | volatile u32 TAIntStatus; /* 0x0848 */ |
| 168 | volatile unsigned long TAIntMask; /* 0x084C */ | 168 | volatile u32 TAIntMask; /* 0x084C */ |
| 169 | 169 | ||
| 170 | volatile unsigned long Fill5[235]; /* GAP 0x0850 - 0x0BF8 */ | 170 | volatile u32 Fill5[235]; /* GAP 0x0850 - 0x0BF8 */ |
| 171 | 171 | ||
| 172 | volatile unsigned long TextureAddrThresh; /* 0x0BFC */ | 172 | volatile u32 TextureAddrThresh; /* 0x0BFC */ |
| 173 | volatile unsigned long Core1Translation; /* 0x0C00 */ | 173 | volatile u32 Core1Translation; /* 0x0C00 */ |
| 174 | volatile unsigned long TextureAddrReMap; /* 0x0C04 */ | 174 | volatile u32 TextureAddrReMap; /* 0x0C04 */ |
| 175 | volatile unsigned long RenderOutAGPRemap; /* 0x0C08 */ | 175 | volatile u32 RenderOutAGPRemap; /* 0x0C08 */ |
| 176 | volatile unsigned long _3DRegionReadTrans; /* 0x0C0C */ | 176 | volatile u32 _3DRegionReadTrans; /* 0x0C0C */ |
| 177 | volatile unsigned long _3DPtrReadTrans; /* 0x0C10 */ | 177 | volatile u32 _3DPtrReadTrans; /* 0x0C10 */ |
| 178 | volatile unsigned long _3DParamReadTrans; /* 0x0C14 */ | 178 | volatile u32 _3DParamReadTrans; /* 0x0C14 */ |
| 179 | volatile unsigned long _3DRegionReadThresh; /* 0x0C18 */ | 179 | volatile u32 _3DRegionReadThresh; /* 0x0C18 */ |
| 180 | volatile unsigned long _3DPtrReadThresh; /* 0x0C1C */ | 180 | volatile u32 _3DPtrReadThresh; /* 0x0C1C */ |
| 181 | volatile unsigned long _3DParamReadThresh; /* 0x0C20 */ | 181 | volatile u32 _3DParamReadThresh; /* 0x0C20 */ |
| 182 | volatile unsigned long _3DRegionReadAGPRemap; /* 0x0C24 */ | 182 | volatile u32 _3DRegionReadAGPRemap; /* 0x0C24 */ |
| 183 | volatile unsigned long _3DPtrReadAGPRemap; /* 0x0C28 */ | 183 | volatile u32 _3DPtrReadAGPRemap; /* 0x0C28 */ |
| 184 | volatile unsigned long _3DParamReadAGPRemap; /* 0x0C2C */ | 184 | volatile u32 _3DParamReadAGPRemap; /* 0x0C2C */ |
| 185 | volatile unsigned long ZBufferAGPRemap; /* 0x0C30 */ | 185 | volatile u32 ZBufferAGPRemap; /* 0x0C30 */ |
| 186 | volatile unsigned long TAIndexAGPRemap; /* 0x0C34 */ | 186 | volatile u32 TAIndexAGPRemap; /* 0x0C34 */ |
| 187 | volatile unsigned long TAVertexAGPRemap; /* 0x0C38 */ | 187 | volatile u32 TAVertexAGPRemap; /* 0x0C38 */ |
| 188 | volatile unsigned long TAUVAddrTrans; /* 0x0C3C */ | 188 | volatile u32 TAUVAddrTrans; /* 0x0C3C */ |
| 189 | volatile unsigned long TATailPtrCacheTrans; /* 0x0C40 */ | 189 | volatile u32 TATailPtrCacheTrans; /* 0x0C40 */ |
| 190 | volatile unsigned long TAParamWriteTrans; /* 0x0C44 */ | 190 | volatile u32 TAParamWriteTrans; /* 0x0C44 */ |
| 191 | volatile unsigned long TAPtrWriteTrans; /* 0x0C48 */ | 191 | volatile u32 TAPtrWriteTrans; /* 0x0C48 */ |
| 192 | volatile unsigned long TAParamWriteThresh; /* 0x0C4C */ | 192 | volatile u32 TAParamWriteThresh; /* 0x0C4C */ |
| 193 | volatile unsigned long TAPtrWriteThresh; /* 0x0C50 */ | 193 | volatile u32 TAPtrWriteThresh; /* 0x0C50 */ |
| 194 | volatile unsigned long TATailPtrCacheAGPRe; /* 0x0C54 */ | 194 | volatile u32 TATailPtrCacheAGPRe; /* 0x0C54 */ |
| 195 | volatile unsigned long TAParamWriteAGPRe; /* 0x0C58 */ | 195 | volatile u32 TAParamWriteAGPRe; /* 0x0C58 */ |
| 196 | volatile unsigned long TAPtrWriteAGPRe; /* 0x0C5C */ | 196 | volatile u32 TAPtrWriteAGPRe; /* 0x0C5C */ |
| 197 | volatile unsigned long SDRAMArbiterConf; /* 0x0C60 */ | 197 | volatile u32 SDRAMArbiterConf; /* 0x0C60 */ |
| 198 | volatile unsigned long SDRAMConf0; /* 0x0C64 */ | 198 | volatile u32 SDRAMConf0; /* 0x0C64 */ |
| 199 | volatile unsigned long SDRAMConf1; /* 0x0C68 */ | 199 | volatile u32 SDRAMConf1; /* 0x0C68 */ |
| 200 | volatile unsigned long SDRAMConf2; /* 0x0C6C */ | 200 | volatile u32 SDRAMConf2; /* 0x0C6C */ |
| 201 | volatile unsigned long SDRAMRefresh; /* 0x0C70 */ | 201 | volatile u32 SDRAMRefresh; /* 0x0C70 */ |
| 202 | volatile unsigned long SDRAMPowerStat; /* 0x0C74 */ | 202 | volatile u32 SDRAMPowerStat; /* 0x0C74 */ |
| 203 | 203 | ||
| 204 | volatile unsigned long Fill6[2]; /* GAP 0x0C78 - 0x0C7C */ | 204 | volatile u32 Fill6[2]; /* GAP 0x0C78 - 0x0C7C */ |
| 205 | 205 | ||
| 206 | volatile unsigned long RAMBistData; /* 0x0C80 */ | 206 | volatile u32 RAMBistData; /* 0x0C80 */ |
| 207 | volatile unsigned long RAMBistCtrl; /* 0x0C84 */ | 207 | volatile u32 RAMBistCtrl; /* 0x0C84 */ |
| 208 | volatile unsigned long FIFOBistKey; /* 0x0C88 */ | 208 | volatile u32 FIFOBistKey; /* 0x0C88 */ |
| 209 | volatile unsigned long RAMBistResult; /* 0x0C8C */ | 209 | volatile u32 RAMBistResult; /* 0x0C8C */ |
| 210 | volatile unsigned long FIFOBistResult; /* 0x0C90 */ | 210 | volatile u32 FIFOBistResult; /* 0x0C90 */ |
| 211 | 211 | ||
| 212 | /* | 212 | /* |
| 213 | volatile unsigned long Fill11[0x0CBC/4 - 0x0C94/4]; //GAP 0x0C94 - 0x0CBC | 213 | volatile u32 Fill11[0x0CBC/4 - 0x0C94/4]; //GAP 0x0C94 - 0x0CBC |
| 214 | volatile unsigned long Fill12[0x0CD0/4 - 0x0CC0/4]; //GAP 0x0CC0 - 0x0CD0 3DRegisters | 214 | volatile u32 Fill12[0x0CD0/4 - 0x0CC0/4]; //GAP 0x0CC0 - 0x0CD0 3DRegisters |
| 215 | */ | 215 | */ |
| 216 | 216 | ||
| 217 | volatile unsigned long Fill7[16]; /* 0x0c94 - 0x0cd0 */ | 217 | volatile u32 Fill7[16]; /* 0x0c94 - 0x0cd0 */ |
| 218 | 218 | ||
| 219 | volatile unsigned long SDRAMAddrSign; /* 0x0CD4 */ | 219 | volatile u32 SDRAMAddrSign; /* 0x0CD4 */ |
| 220 | volatile unsigned long SDRAMDataSign; /* 0x0CD8 */ | 220 | volatile u32 SDRAMDataSign; /* 0x0CD8 */ |
| 221 | volatile unsigned long SDRAMSignConf; /* 0x0CDC */ | 221 | volatile u32 SDRAMSignConf; /* 0x0CDC */ |
| 222 | 222 | ||
| 223 | /* DWFILL; //GAP 0x0CE0 */ | 223 | /* DWFILL; //GAP 0x0CE0 */ |
| 224 | volatile unsigned long dwFill_2; | 224 | volatile u32 dwFill_2; |
| 225 | 225 | ||
| 226 | volatile unsigned long ISPSignature; /* 0x0CE4 */ | 226 | volatile u32 ISPSignature; /* 0x0CE4 */ |
| 227 | 227 | ||
| 228 | volatile unsigned long Fill8[454]; /*GAP 0x0CE8 - 0x13FC */ | 228 | volatile u32 Fill8[454]; /*GAP 0x0CE8 - 0x13FC */ |
| 229 | 229 | ||
| 230 | volatile unsigned long DACPrimAddress; /* 0x1400 */ | 230 | volatile u32 DACPrimAddress; /* 0x1400 */ |
| 231 | volatile unsigned long DACPrimSize; /* 0x1404 */ | 231 | volatile u32 DACPrimSize; /* 0x1404 */ |
| 232 | volatile unsigned long DACCursorAddr; /* 0x1408 */ | 232 | volatile u32 DACCursorAddr; /* 0x1408 */ |
| 233 | volatile unsigned long DACCursorCtrl; /* 0x140C */ | 233 | volatile u32 DACCursorCtrl; /* 0x140C */ |
| 234 | volatile unsigned long DACOverlayAddr; /* 0x1410 */ | 234 | volatile u32 DACOverlayAddr; /* 0x1410 */ |
| 235 | volatile unsigned long DACOverlayUAddr; /* 0x1414 */ | 235 | volatile u32 DACOverlayUAddr; /* 0x1414 */ |
| 236 | volatile unsigned long DACOverlayVAddr; /* 0x1418 */ | 236 | volatile u32 DACOverlayVAddr; /* 0x1418 */ |
| 237 | volatile unsigned long DACOverlaySize; /* 0x141C */ | 237 | volatile u32 DACOverlaySize; /* 0x141C */ |
| 238 | volatile unsigned long DACOverlayVtDec; /* 0x1420 */ | 238 | volatile u32 DACOverlayVtDec; /* 0x1420 */ |
| 239 | 239 | ||
| 240 | volatile unsigned long Fill9[9]; /* GAP 0x1424 - 0x1444 */ | 240 | volatile u32 Fill9[9]; /* GAP 0x1424 - 0x1444 */ |
| 241 | 241 | ||
| 242 | volatile unsigned long DACVerticalScal; /* 0x1448 */ | 242 | volatile u32 DACVerticalScal; /* 0x1448 */ |
| 243 | volatile unsigned long DACPixelFormat; /* 0x144C */ | 243 | volatile u32 DACPixelFormat; /* 0x144C */ |
| 244 | volatile unsigned long DACHorizontalScal; /* 0x1450 */ | 244 | volatile u32 DACHorizontalScal; /* 0x1450 */ |
| 245 | volatile unsigned long DACVidWinStart; /* 0x1454 */ | 245 | volatile u32 DACVidWinStart; /* 0x1454 */ |
| 246 | volatile unsigned long DACVidWinEnd; /* 0x1458 */ | 246 | volatile u32 DACVidWinEnd; /* 0x1458 */ |
| 247 | volatile unsigned long DACBlendCtrl; /* 0x145C */ | 247 | volatile u32 DACBlendCtrl; /* 0x145C */ |
| 248 | volatile unsigned long DACHorTim1; /* 0x1460 */ | 248 | volatile u32 DACHorTim1; /* 0x1460 */ |
| 249 | volatile unsigned long DACHorTim2; /* 0x1464 */ | 249 | volatile u32 DACHorTim2; /* 0x1464 */ |
| 250 | volatile unsigned long DACHorTim3; /* 0x1468 */ | 250 | volatile u32 DACHorTim3; /* 0x1468 */ |
| 251 | volatile unsigned long DACVerTim1; /* 0x146C */ | 251 | volatile u32 DACVerTim1; /* 0x146C */ |
| 252 | volatile unsigned long DACVerTim2; /* 0x1470 */ | 252 | volatile u32 DACVerTim2; /* 0x1470 */ |
| 253 | volatile unsigned long DACVerTim3; /* 0x1474 */ | 253 | volatile u32 DACVerTim3; /* 0x1474 */ |
| 254 | volatile unsigned long DACBorderColor; /* 0x1478 */ | 254 | volatile u32 DACBorderColor; /* 0x1478 */ |
| 255 | volatile unsigned long DACSyncCtrl; /* 0x147C */ | 255 | volatile u32 DACSyncCtrl; /* 0x147C */ |
| 256 | volatile unsigned long DACStreamCtrl; /* 0x1480 */ | 256 | volatile u32 DACStreamCtrl; /* 0x1480 */ |
| 257 | volatile unsigned long DACLUTAddress; /* 0x1484 */ | 257 | volatile u32 DACLUTAddress; /* 0x1484 */ |
| 258 | volatile unsigned long DACLUTData; /* 0x1488 */ | 258 | volatile u32 DACLUTData; /* 0x1488 */ |
| 259 | volatile unsigned long DACBurstCtrl; /* 0x148C */ | 259 | volatile u32 DACBurstCtrl; /* 0x148C */ |
| 260 | volatile unsigned long DACCrcTrigger; /* 0x1490 */ | 260 | volatile u32 DACCrcTrigger; /* 0x1490 */ |
| 261 | volatile unsigned long DACCrcDone; /* 0x1494 */ | 261 | volatile u32 DACCrcDone; /* 0x1494 */ |
| 262 | volatile unsigned long DACCrcResult1; /* 0x1498 */ | 262 | volatile u32 DACCrcResult1; /* 0x1498 */ |
| 263 | volatile unsigned long DACCrcResult2; /* 0x149C */ | 263 | volatile u32 DACCrcResult2; /* 0x149C */ |
| 264 | volatile unsigned long DACLinecount; /* 0x14A0 */ | 264 | volatile u32 DACLinecount; /* 0x14A0 */ |
| 265 | 265 | ||
| 266 | volatile unsigned long Fill10[151]; /*GAP 0x14A4 - 0x16FC */ | 266 | volatile u32 Fill10[151]; /*GAP 0x14A4 - 0x16FC */ |
| 267 | 267 | ||
| 268 | volatile unsigned long DigVidPortCtrl; /* 0x1700 */ | 268 | volatile u32 DigVidPortCtrl; /* 0x1700 */ |
| 269 | volatile unsigned long DigVidPortStat; /* 0x1704 */ | 269 | volatile u32 DigVidPortStat; /* 0x1704 */ |
| 270 | 270 | ||
| 271 | /* | 271 | /* |
| 272 | volatile unsigned long Fill11[0x1FFC/4 - 0x1708/4]; //GAP 0x1708 - 0x1FFC | 272 | volatile u32 Fill11[0x1FFC/4 - 0x1708/4]; //GAP 0x1708 - 0x1FFC |
| 273 | volatile unsigned long Fill17[0x3000/4 - 0x2FFC/4]; //GAP 0x2000 - 0x2FFC ALUT | 273 | volatile u32 Fill17[0x3000/4 - 0x2FFC/4]; //GAP 0x2000 - 0x2FFC ALUT |
| 274 | */ | 274 | */ |
| 275 | 275 | ||
| 276 | volatile unsigned long Fill11[1598]; | 276 | volatile u32 Fill11[1598]; |
| 277 | 277 | ||
| 278 | /* DWFILL; //GAP 0x3000 ALUT 256MB offset */ | 278 | /* DWFILL; //GAP 0x3000 ALUT 256MB offset */ |
| 279 | volatile unsigned long Fill_3; | 279 | volatile u32 Fill_3; |
| 280 | 280 | ||
| 281 | } STG4000REG; | 281 | } STG4000REG; |
| 282 | 282 | ||
diff --git a/drivers/video/msm/mddi.c b/drivers/video/msm/mddi.c index 4527cbf0a4ec..b061d709bc44 100644 --- a/drivers/video/msm/mddi.c +++ b/drivers/video/msm/mddi.c | |||
| @@ -420,7 +420,7 @@ static void mddi_resume(struct msm_mddi_client_data *cdata) | |||
| 420 | mddi_set_auto_hibernate(&mddi->client_data, 1); | 420 | mddi_set_auto_hibernate(&mddi->client_data, 1); |
| 421 | } | 421 | } |
| 422 | 422 | ||
| 423 | static int __init mddi_get_client_caps(struct mddi_info *mddi) | 423 | static int __devinit mddi_get_client_caps(struct mddi_info *mddi) |
| 424 | { | 424 | { |
| 425 | int i, j; | 425 | int i, j; |
| 426 | 426 | ||
| @@ -622,9 +622,9 @@ uint32_t mddi_remote_read(struct msm_mddi_client_data *cdata, uint32_t reg) | |||
| 622 | 622 | ||
| 623 | static struct mddi_info mddi_info[2]; | 623 | static struct mddi_info mddi_info[2]; |
| 624 | 624 | ||
| 625 | static int __init mddi_clk_setup(struct platform_device *pdev, | 625 | static int __devinit mddi_clk_setup(struct platform_device *pdev, |
| 626 | struct mddi_info *mddi, | 626 | struct mddi_info *mddi, |
| 627 | unsigned long clk_rate) | 627 | unsigned long clk_rate) |
| 628 | { | 628 | { |
| 629 | int ret; | 629 | int ret; |
| 630 | 630 | ||
diff --git a/drivers/video/uvesafb.c b/drivers/video/uvesafb.c index 260cca7ddb41..26e83d7fdd6f 100644 --- a/drivers/video/uvesafb.c +++ b/drivers/video/uvesafb.c | |||
| @@ -815,8 +815,15 @@ static int __devinit uvesafb_vbe_init(struct fb_info *info) | |||
| 815 | par->pmi_setpal = pmi_setpal; | 815 | par->pmi_setpal = pmi_setpal; |
| 816 | par->ypan = ypan; | 816 | par->ypan = ypan; |
| 817 | 817 | ||
| 818 | if (par->pmi_setpal || par->ypan) | 818 | if (par->pmi_setpal || par->ypan) { |
| 819 | uvesafb_vbe_getpmi(task, par); | 819 | if (__supported_pte_mask & _PAGE_NX) { |
| 820 | par->pmi_setpal = par->ypan = 0; | ||
| 821 | printk(KERN_WARNING "uvesafb: NX protection is actively." | ||
| 822 | "We have better not to use the PMI.\n"); | ||
| 823 | } else { | ||
| 824 | uvesafb_vbe_getpmi(task, par); | ||
| 825 | } | ||
| 826 | } | ||
| 820 | #else | 827 | #else |
| 821 | /* The protected mode interface is not available on non-x86. */ | 828 | /* The protected mode interface is not available on non-x86. */ |
| 822 | par->pmi_setpal = par->ypan = 0; | 829 | par->pmi_setpal = par->ypan = 0; |
diff --git a/drivers/virtio/virtio_balloon.c b/drivers/virtio/virtio_balloon.c index 05f0a80818a2..c2d05a8279fd 100644 --- a/drivers/virtio/virtio_balloon.c +++ b/drivers/virtio/virtio_balloon.c | |||
| @@ -28,6 +28,13 @@ | |||
| 28 | #include <linux/slab.h> | 28 | #include <linux/slab.h> |
| 29 | #include <linux/module.h> | 29 | #include <linux/module.h> |
| 30 | 30 | ||
| 31 | /* | ||
| 32 | * Balloon device works in 4K page units. So each page is pointed to by | ||
| 33 | * multiple balloon pages. All memory counters in this driver are in balloon | ||
| 34 | * page units. | ||
| 35 | */ | ||
| 36 | #define VIRTIO_BALLOON_PAGES_PER_PAGE (PAGE_SIZE >> VIRTIO_BALLOON_PFN_SHIFT) | ||
| 37 | |||
| 31 | struct virtio_balloon | 38 | struct virtio_balloon |
| 32 | { | 39 | { |
| 33 | struct virtio_device *vdev; | 40 | struct virtio_device *vdev; |
| @@ -42,8 +49,13 @@ struct virtio_balloon | |||
| 42 | /* Waiting for host to ack the pages we released. */ | 49 | /* Waiting for host to ack the pages we released. */ |
| 43 | struct completion acked; | 50 | struct completion acked; |
| 44 | 51 | ||
| 45 | /* The pages we've told the Host we're not using. */ | 52 | /* Number of balloon pages we've told the Host we're not using. */ |
| 46 | unsigned int num_pages; | 53 | unsigned int num_pages; |
| 54 | /* | ||
| 55 | * The pages we've told the Host we're not using. | ||
| 56 | * Each page on this list adds VIRTIO_BALLOON_PAGES_PER_PAGE | ||
| 57 | * to num_pages above. | ||
| 58 | */ | ||
| 47 | struct list_head pages; | 59 | struct list_head pages; |
| 48 | 60 | ||
| 49 | /* The array of pfns we tell the Host about. */ | 61 | /* The array of pfns we tell the Host about. */ |
| @@ -66,7 +78,13 @@ static u32 page_to_balloon_pfn(struct page *page) | |||
| 66 | 78 | ||
| 67 | BUILD_BUG_ON(PAGE_SHIFT < VIRTIO_BALLOON_PFN_SHIFT); | 79 | BUILD_BUG_ON(PAGE_SHIFT < VIRTIO_BALLOON_PFN_SHIFT); |
| 68 | /* Convert pfn from Linux page size to balloon page size. */ | 80 | /* Convert pfn from Linux page size to balloon page size. */ |
| 69 | return pfn >> (PAGE_SHIFT - VIRTIO_BALLOON_PFN_SHIFT); | 81 | return pfn * VIRTIO_BALLOON_PAGES_PER_PAGE; |
| 82 | } | ||
| 83 | |||
| 84 | static struct page *balloon_pfn_to_page(u32 pfn) | ||
| 85 | { | ||
| 86 | BUG_ON(pfn % VIRTIO_BALLOON_PAGES_PER_PAGE); | ||
| 87 | return pfn_to_page(pfn / VIRTIO_BALLOON_PAGES_PER_PAGE); | ||
| 70 | } | 88 | } |
| 71 | 89 | ||
| 72 | static void balloon_ack(struct virtqueue *vq) | 90 | static void balloon_ack(struct virtqueue *vq) |
| @@ -96,12 +114,23 @@ static void tell_host(struct virtio_balloon *vb, struct virtqueue *vq) | |||
| 96 | wait_for_completion(&vb->acked); | 114 | wait_for_completion(&vb->acked); |
| 97 | } | 115 | } |
| 98 | 116 | ||
| 117 | static void set_page_pfns(u32 pfns[], struct page *page) | ||
| 118 | { | ||
| 119 | unsigned int i; | ||
| 120 | |||
| 121 | /* Set balloon pfns pointing at this page. | ||
| 122 | * Note that the first pfn points at start of the page. */ | ||
| 123 | for (i = 0; i < VIRTIO_BALLOON_PAGES_PER_PAGE; i++) | ||
| 124 | pfns[i] = page_to_balloon_pfn(page) + i; | ||
| 125 | } | ||
| 126 | |||
| 99 | static void fill_balloon(struct virtio_balloon *vb, size_t num) | 127 | static void fill_balloon(struct virtio_balloon *vb, size_t num) |
| 100 | { | 128 | { |
| 101 | /* We can only do one array worth at a time. */ | 129 | /* We can only do one array worth at a time. */ |
| 102 | num = min(num, ARRAY_SIZE(vb->pfns)); | 130 | num = min(num, ARRAY_SIZE(vb->pfns)); |
| 103 | 131 | ||
| 104 | for (vb->num_pfns = 0; vb->num_pfns < num; vb->num_pfns++) { | 132 | for (vb->num_pfns = 0; vb->num_pfns < num; |
| 133 | vb->num_pfns += VIRTIO_BALLOON_PAGES_PER_PAGE) { | ||
| 105 | struct page *page = alloc_page(GFP_HIGHUSER | __GFP_NORETRY | | 134 | struct page *page = alloc_page(GFP_HIGHUSER | __GFP_NORETRY | |
| 106 | __GFP_NOMEMALLOC | __GFP_NOWARN); | 135 | __GFP_NOMEMALLOC | __GFP_NOWARN); |
| 107 | if (!page) { | 136 | if (!page) { |
| @@ -113,9 +142,9 @@ static void fill_balloon(struct virtio_balloon *vb, size_t num) | |||
| 113 | msleep(200); | 142 | msleep(200); |
| 114 | break; | 143 | break; |
| 115 | } | 144 | } |
| 116 | vb->pfns[vb->num_pfns] = page_to_balloon_pfn(page); | 145 | set_page_pfns(vb->pfns + vb->num_pfns, page); |
| 146 | vb->num_pages += VIRTIO_BALLOON_PAGES_PER_PAGE; | ||
| 117 | totalram_pages--; | 147 | totalram_pages--; |
| 118 | vb->num_pages++; | ||
| 119 | list_add(&page->lru, &vb->pages); | 148 | list_add(&page->lru, &vb->pages); |
| 120 | } | 149 | } |
| 121 | 150 | ||
| @@ -130,8 +159,9 @@ static void release_pages_by_pfn(const u32 pfns[], unsigned int num) | |||
| 130 | { | 159 | { |
| 131 | unsigned int i; | 160 | unsigned int i; |
| 132 | 161 | ||
| 133 | for (i = 0; i < num; i++) { | 162 | /* Find pfns pointing at start of each page, get pages and free them. */ |
| 134 | __free_page(pfn_to_page(pfns[i])); | 163 | for (i = 0; i < num; i += VIRTIO_BALLOON_PAGES_PER_PAGE) { |
| 164 | __free_page(balloon_pfn_to_page(pfns[i])); | ||
| 135 | totalram_pages++; | 165 | totalram_pages++; |
| 136 | } | 166 | } |
| 137 | } | 167 | } |
| @@ -143,11 +173,12 @@ static void leak_balloon(struct virtio_balloon *vb, size_t num) | |||
| 143 | /* We can only do one array worth at a time. */ | 173 | /* We can only do one array worth at a time. */ |
| 144 | num = min(num, ARRAY_SIZE(vb->pfns)); | 174 | num = min(num, ARRAY_SIZE(vb->pfns)); |
| 145 | 175 | ||
| 146 | for (vb->num_pfns = 0; vb->num_pfns < num; vb->num_pfns++) { | 176 | for (vb->num_pfns = 0; vb->num_pfns < num; |
| 177 | vb->num_pfns += VIRTIO_BALLOON_PAGES_PER_PAGE) { | ||
| 147 | page = list_first_entry(&vb->pages, struct page, lru); | 178 | page = list_first_entry(&vb->pages, struct page, lru); |
| 148 | list_del(&page->lru); | 179 | list_del(&page->lru); |
| 149 | vb->pfns[vb->num_pfns] = page_to_balloon_pfn(page); | 180 | set_page_pfns(vb->pfns + vb->num_pfns, page); |
| 150 | vb->num_pages--; | 181 | vb->num_pages -= VIRTIO_BALLOON_PAGES_PER_PAGE; |
| 151 | } | 182 | } |
| 152 | 183 | ||
| 153 | /* | 184 | /* |
| @@ -234,11 +265,14 @@ static void virtballoon_changed(struct virtio_device *vdev) | |||
| 234 | 265 | ||
| 235 | static inline s64 towards_target(struct virtio_balloon *vb) | 266 | static inline s64 towards_target(struct virtio_balloon *vb) |
| 236 | { | 267 | { |
| 237 | u32 v; | 268 | __le32 v; |
| 269 | s64 target; | ||
| 270 | |||
| 238 | vb->vdev->config->get(vb->vdev, | 271 | vb->vdev->config->get(vb->vdev, |
| 239 | offsetof(struct virtio_balloon_config, num_pages), | 272 | offsetof(struct virtio_balloon_config, num_pages), |
| 240 | &v, sizeof(v)); | 273 | &v, sizeof(v)); |
| 241 | return (s64)v - vb->num_pages; | 274 | target = le32_to_cpu(v); |
| 275 | return target - vb->num_pages; | ||
| 242 | } | 276 | } |
| 243 | 277 | ||
| 244 | static void update_balloon_size(struct virtio_balloon *vb) | 278 | static void update_balloon_size(struct virtio_balloon *vb) |
diff --git a/drivers/xen/gntdev.c b/drivers/xen/gntdev.c index 99d8151c824a..1ffd03bf8e10 100644 --- a/drivers/xen/gntdev.c +++ b/drivers/xen/gntdev.c | |||
| @@ -722,7 +722,7 @@ static int gntdev_mmap(struct file *flip, struct vm_area_struct *vma) | |||
| 722 | vma->vm_flags |= VM_RESERVED|VM_DONTEXPAND; | 722 | vma->vm_flags |= VM_RESERVED|VM_DONTEXPAND; |
| 723 | 723 | ||
| 724 | if (use_ptemod) | 724 | if (use_ptemod) |
| 725 | vma->vm_flags |= VM_DONTCOPY|VM_PFNMAP; | 725 | vma->vm_flags |= VM_DONTCOPY; |
| 726 | 726 | ||
| 727 | vma->vm_private_data = map; | 727 | vma->vm_private_data = map; |
| 728 | 728 | ||
diff --git a/drivers/xen/grant-table.c b/drivers/xen/grant-table.c index b4d4eac761db..f100ce20b16b 100644 --- a/drivers/xen/grant-table.c +++ b/drivers/xen/grant-table.c | |||
| @@ -1029,6 +1029,7 @@ int gnttab_init(void) | |||
| 1029 | int i; | 1029 | int i; |
| 1030 | unsigned int max_nr_glist_frames, nr_glist_frames; | 1030 | unsigned int max_nr_glist_frames, nr_glist_frames; |
| 1031 | unsigned int nr_init_grefs; | 1031 | unsigned int nr_init_grefs; |
| 1032 | int ret; | ||
| 1032 | 1033 | ||
| 1033 | nr_grant_frames = 1; | 1034 | nr_grant_frames = 1; |
| 1034 | boot_max_nr_grant_frames = __max_nr_grant_frames(); | 1035 | boot_max_nr_grant_frames = __max_nr_grant_frames(); |
| @@ -1047,12 +1048,16 @@ int gnttab_init(void) | |||
| 1047 | nr_glist_frames = (nr_grant_frames * GREFS_PER_GRANT_FRAME + RPP - 1) / RPP; | 1048 | nr_glist_frames = (nr_grant_frames * GREFS_PER_GRANT_FRAME + RPP - 1) / RPP; |
| 1048 | for (i = 0; i < nr_glist_frames; i++) { | 1049 | for (i = 0; i < nr_glist_frames; i++) { |
| 1049 | gnttab_list[i] = (grant_ref_t *)__get_free_page(GFP_KERNEL); | 1050 | gnttab_list[i] = (grant_ref_t *)__get_free_page(GFP_KERNEL); |
| 1050 | if (gnttab_list[i] == NULL) | 1051 | if (gnttab_list[i] == NULL) { |
| 1052 | ret = -ENOMEM; | ||
| 1051 | goto ini_nomem; | 1053 | goto ini_nomem; |
| 1054 | } | ||
| 1052 | } | 1055 | } |
| 1053 | 1056 | ||
| 1054 | if (gnttab_resume() < 0) | 1057 | if (gnttab_resume() < 0) { |
| 1055 | return -ENODEV; | 1058 | ret = -ENODEV; |
| 1059 | goto ini_nomem; | ||
| 1060 | } | ||
| 1056 | 1061 | ||
| 1057 | nr_init_grefs = nr_grant_frames * GREFS_PER_GRANT_FRAME; | 1062 | nr_init_grefs = nr_grant_frames * GREFS_PER_GRANT_FRAME; |
| 1058 | 1063 | ||
| @@ -1070,7 +1075,7 @@ int gnttab_init(void) | |||
| 1070 | for (i--; i >= 0; i--) | 1075 | for (i--; i >= 0; i--) |
| 1071 | free_page((unsigned long)gnttab_list[i]); | 1076 | free_page((unsigned long)gnttab_list[i]); |
| 1072 | kfree(gnttab_list); | 1077 | kfree(gnttab_list); |
| 1073 | return -ENOMEM; | 1078 | return ret; |
| 1074 | } | 1079 | } |
| 1075 | EXPORT_SYMBOL_GPL(gnttab_init); | 1080 | EXPORT_SYMBOL_GPL(gnttab_init); |
| 1076 | 1081 | ||
diff --git a/drivers/xen/manage.c b/drivers/xen/manage.c index 9e14ae6cd49c..412b96cc5305 100644 --- a/drivers/xen/manage.c +++ b/drivers/xen/manage.c | |||
| @@ -132,6 +132,7 @@ static void do_suspend(void) | |||
| 132 | err = dpm_suspend_end(PMSG_FREEZE); | 132 | err = dpm_suspend_end(PMSG_FREEZE); |
| 133 | if (err) { | 133 | if (err) { |
| 134 | printk(KERN_ERR "dpm_suspend_end failed: %d\n", err); | 134 | printk(KERN_ERR "dpm_suspend_end failed: %d\n", err); |
| 135 | si.cancelled = 0; | ||
| 135 | goto out_resume; | 136 | goto out_resume; |
| 136 | } | 137 | } |
| 137 | 138 | ||
diff --git a/drivers/xen/xenbus/xenbus_probe_frontend.c b/drivers/xen/xenbus/xenbus_probe_frontend.c index f20c5f178b40..a31b54d48839 100644 --- a/drivers/xen/xenbus/xenbus_probe_frontend.c +++ b/drivers/xen/xenbus/xenbus_probe_frontend.c | |||
| @@ -135,7 +135,7 @@ static int read_backend_details(struct xenbus_device *xendev) | |||
| 135 | return xenbus_read_otherend_details(xendev, "backend-id", "backend"); | 135 | return xenbus_read_otherend_details(xendev, "backend-id", "backend"); |
| 136 | } | 136 | } |
| 137 | 137 | ||
| 138 | static int is_device_connecting(struct device *dev, void *data) | 138 | static int is_device_connecting(struct device *dev, void *data, bool ignore_nonessential) |
| 139 | { | 139 | { |
| 140 | struct xenbus_device *xendev = to_xenbus_device(dev); | 140 | struct xenbus_device *xendev = to_xenbus_device(dev); |
| 141 | struct device_driver *drv = data; | 141 | struct device_driver *drv = data; |
| @@ -152,16 +152,41 @@ static int is_device_connecting(struct device *dev, void *data) | |||
| 152 | if (drv && (dev->driver != drv)) | 152 | if (drv && (dev->driver != drv)) |
| 153 | return 0; | 153 | return 0; |
| 154 | 154 | ||
| 155 | if (ignore_nonessential) { | ||
| 156 | /* With older QEMU, for PVonHVM guests the guest config files | ||
| 157 | * could contain: vfb = [ 'vnc=1, vnclisten=0.0.0.0'] | ||
| 158 | * which is nonsensical as there is no PV FB (there can be | ||
| 159 | * a PVKB) running as HVM guest. */ | ||
| 160 | |||
| 161 | if ((strncmp(xendev->nodename, "device/vkbd", 11) == 0)) | ||
| 162 | return 0; | ||
| 163 | |||
| 164 | if ((strncmp(xendev->nodename, "device/vfb", 10) == 0)) | ||
| 165 | return 0; | ||
| 166 | } | ||
| 155 | xendrv = to_xenbus_driver(dev->driver); | 167 | xendrv = to_xenbus_driver(dev->driver); |
| 156 | return (xendev->state < XenbusStateConnected || | 168 | return (xendev->state < XenbusStateConnected || |
| 157 | (xendev->state == XenbusStateConnected && | 169 | (xendev->state == XenbusStateConnected && |
| 158 | xendrv->is_ready && !xendrv->is_ready(xendev))); | 170 | xendrv->is_ready && !xendrv->is_ready(xendev))); |
| 159 | } | 171 | } |
| 172 | static int essential_device_connecting(struct device *dev, void *data) | ||
| 173 | { | ||
| 174 | return is_device_connecting(dev, data, true /* ignore PV[KBB+FB] */); | ||
| 175 | } | ||
| 176 | static int non_essential_device_connecting(struct device *dev, void *data) | ||
| 177 | { | ||
| 178 | return is_device_connecting(dev, data, false); | ||
| 179 | } | ||
| 160 | 180 | ||
| 161 | static int exists_connecting_device(struct device_driver *drv) | 181 | static int exists_essential_connecting_device(struct device_driver *drv) |
| 162 | { | 182 | { |
| 163 | return bus_for_each_dev(&xenbus_frontend.bus, NULL, drv, | 183 | return bus_for_each_dev(&xenbus_frontend.bus, NULL, drv, |
| 164 | is_device_connecting); | 184 | essential_device_connecting); |
| 185 | } | ||
| 186 | static int exists_non_essential_connecting_device(struct device_driver *drv) | ||
| 187 | { | ||
| 188 | return bus_for_each_dev(&xenbus_frontend.bus, NULL, drv, | ||
| 189 | non_essential_device_connecting); | ||
| 165 | } | 190 | } |
| 166 | 191 | ||
| 167 | static int print_device_status(struct device *dev, void *data) | 192 | static int print_device_status(struct device *dev, void *data) |
| @@ -192,6 +217,23 @@ static int print_device_status(struct device *dev, void *data) | |||
| 192 | /* We only wait for device setup after most initcalls have run. */ | 217 | /* We only wait for device setup after most initcalls have run. */ |
| 193 | static int ready_to_wait_for_devices; | 218 | static int ready_to_wait_for_devices; |
| 194 | 219 | ||
| 220 | static bool wait_loop(unsigned long start, unsigned int max_delay, | ||
| 221 | unsigned int *seconds_waited) | ||
| 222 | { | ||
| 223 | if (time_after(jiffies, start + (*seconds_waited+5)*HZ)) { | ||
| 224 | if (!*seconds_waited) | ||
| 225 | printk(KERN_WARNING "XENBUS: Waiting for " | ||
| 226 | "devices to initialise: "); | ||
| 227 | *seconds_waited += 5; | ||
| 228 | printk("%us...", max_delay - *seconds_waited); | ||
| 229 | if (*seconds_waited == max_delay) | ||
| 230 | return true; | ||
| 231 | } | ||
| 232 | |||
| 233 | schedule_timeout_interruptible(HZ/10); | ||
| 234 | |||
| 235 | return false; | ||
| 236 | } | ||
| 195 | /* | 237 | /* |
| 196 | * On a 5-minute timeout, wait for all devices currently configured. We need | 238 | * On a 5-minute timeout, wait for all devices currently configured. We need |
| 197 | * to do this to guarantee that the filesystems and / or network devices | 239 | * to do this to guarantee that the filesystems and / or network devices |
| @@ -215,19 +257,14 @@ static void wait_for_devices(struct xenbus_driver *xendrv) | |||
| 215 | if (!ready_to_wait_for_devices || !xen_domain()) | 257 | if (!ready_to_wait_for_devices || !xen_domain()) |
| 216 | return; | 258 | return; |
| 217 | 259 | ||
| 218 | while (exists_connecting_device(drv)) { | 260 | while (exists_non_essential_connecting_device(drv)) |
| 219 | if (time_after(jiffies, start + (seconds_waited+5)*HZ)) { | 261 | if (wait_loop(start, 30, &seconds_waited)) |
| 220 | if (!seconds_waited) | 262 | break; |
| 221 | printk(KERN_WARNING "XENBUS: Waiting for " | 263 | |
| 222 | "devices to initialise: "); | 264 | /* Skips PVKB and PVFB check.*/ |
| 223 | seconds_waited += 5; | 265 | while (exists_essential_connecting_device(drv)) |
| 224 | printk("%us...", 300 - seconds_waited); | 266 | if (wait_loop(start, 270, &seconds_waited)) |
| 225 | if (seconds_waited == 300) | 267 | break; |
| 226 | break; | ||
| 227 | } | ||
| 228 | |||
| 229 | schedule_timeout_interruptible(HZ/10); | ||
| 230 | } | ||
| 231 | 268 | ||
| 232 | if (seconds_waited) | 269 | if (seconds_waited) |
| 233 | printk("\n"); | 270 | printk("\n"); |
| @@ -93,9 +93,8 @@ static void aio_free_ring(struct kioctx *ctx) | |||
| 93 | put_page(info->ring_pages[i]); | 93 | put_page(info->ring_pages[i]); |
| 94 | 94 | ||
| 95 | if (info->mmap_size) { | 95 | if (info->mmap_size) { |
| 96 | down_write(&ctx->mm->mmap_sem); | 96 | BUG_ON(ctx->mm != current->mm); |
| 97 | do_munmap(ctx->mm, info->mmap_base, info->mmap_size); | 97 | vm_munmap(info->mmap_base, info->mmap_size); |
| 98 | up_write(&ctx->mm->mmap_sem); | ||
| 99 | } | 98 | } |
| 100 | 99 | ||
| 101 | if (info->ring_pages && info->ring_pages != info->internal_pages) | 100 | if (info->ring_pages && info->ring_pages != info->internal_pages) |
| @@ -389,6 +388,17 @@ void exit_aio(struct mm_struct *mm) | |||
| 389 | "exit_aio:ioctx still alive: %d %d %d\n", | 388 | "exit_aio:ioctx still alive: %d %d %d\n", |
| 390 | atomic_read(&ctx->users), ctx->dead, | 389 | atomic_read(&ctx->users), ctx->dead, |
| 391 | ctx->reqs_active); | 390 | ctx->reqs_active); |
| 391 | /* | ||
| 392 | * We don't need to bother with munmap() here - | ||
| 393 | * exit_mmap(mm) is coming and it'll unmap everything. | ||
| 394 | * Since aio_free_ring() uses non-zero ->mmap_size | ||
| 395 | * as indicator that it needs to unmap the area, | ||
| 396 | * just set it to 0; aio_free_ring() is the only | ||
| 397 | * place that uses ->mmap_size, so it's safe. | ||
| 398 | * That way we get all munmap done to current->mm - | ||
| 399 | * all other callers have ctx->mm == current->mm. | ||
| 400 | */ | ||
| 401 | ctx->ring_info.mmap_size = 0; | ||
| 392 | put_ioctx(ctx); | 402 | put_ioctx(ctx); |
| 393 | } | 403 | } |
| 394 | } | 404 | } |
diff --git a/fs/binfmt_aout.c b/fs/binfmt_aout.c index 2eb12f13593d..d146e181d10d 100644 --- a/fs/binfmt_aout.c +++ b/fs/binfmt_aout.c | |||
| @@ -50,9 +50,7 @@ static int set_brk(unsigned long start, unsigned long end) | |||
| 50 | end = PAGE_ALIGN(end); | 50 | end = PAGE_ALIGN(end); |
| 51 | if (end > start) { | 51 | if (end > start) { |
| 52 | unsigned long addr; | 52 | unsigned long addr; |
| 53 | down_write(¤t->mm->mmap_sem); | 53 | addr = vm_brk(start, end - start); |
| 54 | addr = do_brk(start, end - start); | ||
| 55 | up_write(¤t->mm->mmap_sem); | ||
| 56 | if (BAD_ADDR(addr)) | 54 | if (BAD_ADDR(addr)) |
| 57 | return addr; | 55 | return addr; |
| 58 | } | 56 | } |
| @@ -280,9 +278,7 @@ static int load_aout_binary(struct linux_binprm * bprm, struct pt_regs * regs) | |||
| 280 | pos = 32; | 278 | pos = 32; |
| 281 | map_size = ex.a_text+ex.a_data; | 279 | map_size = ex.a_text+ex.a_data; |
| 282 | #endif | 280 | #endif |
| 283 | down_write(¤t->mm->mmap_sem); | 281 | error = vm_brk(text_addr & PAGE_MASK, map_size); |
| 284 | error = do_brk(text_addr & PAGE_MASK, map_size); | ||
| 285 | up_write(¤t->mm->mmap_sem); | ||
| 286 | if (error != (text_addr & PAGE_MASK)) { | 282 | if (error != (text_addr & PAGE_MASK)) { |
| 287 | send_sig(SIGKILL, current, 0); | 283 | send_sig(SIGKILL, current, 0); |
| 288 | return error; | 284 | return error; |
| @@ -313,9 +309,7 @@ static int load_aout_binary(struct linux_binprm * bprm, struct pt_regs * regs) | |||
| 313 | 309 | ||
| 314 | if (!bprm->file->f_op->mmap||((fd_offset & ~PAGE_MASK) != 0)) { | 310 | if (!bprm->file->f_op->mmap||((fd_offset & ~PAGE_MASK) != 0)) { |
| 315 | loff_t pos = fd_offset; | 311 | loff_t pos = fd_offset; |
| 316 | down_write(¤t->mm->mmap_sem); | 312 | vm_brk(N_TXTADDR(ex), ex.a_text+ex.a_data); |
| 317 | do_brk(N_TXTADDR(ex), ex.a_text+ex.a_data); | ||
| 318 | up_write(¤t->mm->mmap_sem); | ||
| 319 | bprm->file->f_op->read(bprm->file, | 313 | bprm->file->f_op->read(bprm->file, |
| 320 | (char __user *)N_TXTADDR(ex), | 314 | (char __user *)N_TXTADDR(ex), |
| 321 | ex.a_text+ex.a_data, &pos); | 315 | ex.a_text+ex.a_data, &pos); |
| @@ -325,24 +319,20 @@ static int load_aout_binary(struct linux_binprm * bprm, struct pt_regs * regs) | |||
| 325 | goto beyond_if; | 319 | goto beyond_if; |
| 326 | } | 320 | } |
| 327 | 321 | ||
| 328 | down_write(¤t->mm->mmap_sem); | 322 | error = vm_mmap(bprm->file, N_TXTADDR(ex), ex.a_text, |
| 329 | error = do_mmap(bprm->file, N_TXTADDR(ex), ex.a_text, | ||
| 330 | PROT_READ | PROT_EXEC, | 323 | PROT_READ | PROT_EXEC, |
| 331 | MAP_FIXED | MAP_PRIVATE | MAP_DENYWRITE | MAP_EXECUTABLE, | 324 | MAP_FIXED | MAP_PRIVATE | MAP_DENYWRITE | MAP_EXECUTABLE, |
| 332 | fd_offset); | 325 | fd_offset); |
| 333 | up_write(¤t->mm->mmap_sem); | ||
| 334 | 326 | ||
| 335 | if (error != N_TXTADDR(ex)) { | 327 | if (error != N_TXTADDR(ex)) { |
| 336 | send_sig(SIGKILL, current, 0); | 328 | send_sig(SIGKILL, current, 0); |
| 337 | return error; | 329 | return error; |
| 338 | } | 330 | } |
| 339 | 331 | ||
| 340 | down_write(¤t->mm->mmap_sem); | 332 | error = vm_mmap(bprm->file, N_DATADDR(ex), ex.a_data, |
| 341 | error = do_mmap(bprm->file, N_DATADDR(ex), ex.a_data, | ||
| 342 | PROT_READ | PROT_WRITE | PROT_EXEC, | 333 | PROT_READ | PROT_WRITE | PROT_EXEC, |
| 343 | MAP_FIXED | MAP_PRIVATE | MAP_DENYWRITE | MAP_EXECUTABLE, | 334 | MAP_FIXED | MAP_PRIVATE | MAP_DENYWRITE | MAP_EXECUTABLE, |
| 344 | fd_offset + ex.a_text); | 335 | fd_offset + ex.a_text); |
| 345 | up_write(¤t->mm->mmap_sem); | ||
| 346 | if (error != N_DATADDR(ex)) { | 336 | if (error != N_DATADDR(ex)) { |
| 347 | send_sig(SIGKILL, current, 0); | 337 | send_sig(SIGKILL, current, 0); |
| 348 | return error; | 338 | return error; |
| @@ -412,9 +402,7 @@ static int load_aout_library(struct file *file) | |||
| 412 | "N_TXTOFF is not page aligned. Please convert library: %s\n", | 402 | "N_TXTOFF is not page aligned. Please convert library: %s\n", |
| 413 | file->f_path.dentry->d_name.name); | 403 | file->f_path.dentry->d_name.name); |
| 414 | } | 404 | } |
| 415 | down_write(¤t->mm->mmap_sem); | 405 | vm_brk(start_addr, ex.a_text + ex.a_data + ex.a_bss); |
| 416 | do_brk(start_addr, ex.a_text + ex.a_data + ex.a_bss); | ||
| 417 | up_write(¤t->mm->mmap_sem); | ||
| 418 | 406 | ||
| 419 | file->f_op->read(file, (char __user *)start_addr, | 407 | file->f_op->read(file, (char __user *)start_addr, |
| 420 | ex.a_text + ex.a_data, &pos); | 408 | ex.a_text + ex.a_data, &pos); |
| @@ -425,12 +413,10 @@ static int load_aout_library(struct file *file) | |||
| 425 | goto out; | 413 | goto out; |
| 426 | } | 414 | } |
| 427 | /* Now use mmap to map the library into memory. */ | 415 | /* Now use mmap to map the library into memory. */ |
| 428 | down_write(¤t->mm->mmap_sem); | 416 | error = vm_mmap(file, start_addr, ex.a_text + ex.a_data, |
| 429 | error = do_mmap(file, start_addr, ex.a_text + ex.a_data, | ||
| 430 | PROT_READ | PROT_WRITE | PROT_EXEC, | 417 | PROT_READ | PROT_WRITE | PROT_EXEC, |
| 431 | MAP_FIXED | MAP_PRIVATE | MAP_DENYWRITE, | 418 | MAP_FIXED | MAP_PRIVATE | MAP_DENYWRITE, |
| 432 | N_TXTOFF(ex)); | 419 | N_TXTOFF(ex)); |
| 433 | up_write(¤t->mm->mmap_sem); | ||
| 434 | retval = error; | 420 | retval = error; |
| 435 | if (error != start_addr) | 421 | if (error != start_addr) |
| 436 | goto out; | 422 | goto out; |
| @@ -438,9 +424,7 @@ static int load_aout_library(struct file *file) | |||
| 438 | len = PAGE_ALIGN(ex.a_text + ex.a_data); | 424 | len = PAGE_ALIGN(ex.a_text + ex.a_data); |
| 439 | bss = ex.a_text + ex.a_data + ex.a_bss; | 425 | bss = ex.a_text + ex.a_data + ex.a_bss; |
| 440 | if (bss > len) { | 426 | if (bss > len) { |
| 441 | down_write(¤t->mm->mmap_sem); | 427 | error = vm_brk(start_addr + len, bss - len); |
| 442 | error = do_brk(start_addr + len, bss - len); | ||
| 443 | up_write(¤t->mm->mmap_sem); | ||
| 444 | retval = error; | 428 | retval = error; |
| 445 | if (error != start_addr + len) | 429 | if (error != start_addr + len) |
| 446 | goto out; | 430 | goto out; |
diff --git a/fs/binfmt_elf.c b/fs/binfmt_elf.c index 48ffb3dc610a..16f735417072 100644 --- a/fs/binfmt_elf.c +++ b/fs/binfmt_elf.c | |||
| @@ -82,9 +82,7 @@ static int set_brk(unsigned long start, unsigned long end) | |||
| 82 | end = ELF_PAGEALIGN(end); | 82 | end = ELF_PAGEALIGN(end); |
| 83 | if (end > start) { | 83 | if (end > start) { |
| 84 | unsigned long addr; | 84 | unsigned long addr; |
| 85 | down_write(¤t->mm->mmap_sem); | 85 | addr = vm_brk(start, end - start); |
| 86 | addr = do_brk(start, end - start); | ||
| 87 | up_write(¤t->mm->mmap_sem); | ||
| 88 | if (BAD_ADDR(addr)) | 86 | if (BAD_ADDR(addr)) |
| 89 | return addr; | 87 | return addr; |
| 90 | } | 88 | } |
| @@ -514,9 +512,7 @@ static unsigned long load_elf_interp(struct elfhdr *interp_elf_ex, | |||
| 514 | elf_bss = ELF_PAGESTART(elf_bss + ELF_MIN_ALIGN - 1); | 512 | elf_bss = ELF_PAGESTART(elf_bss + ELF_MIN_ALIGN - 1); |
| 515 | 513 | ||
| 516 | /* Map the last of the bss segment */ | 514 | /* Map the last of the bss segment */ |
| 517 | down_write(¤t->mm->mmap_sem); | 515 | error = vm_brk(elf_bss, last_bss - elf_bss); |
| 518 | error = do_brk(elf_bss, last_bss - elf_bss); | ||
| 519 | up_write(¤t->mm->mmap_sem); | ||
| 520 | if (BAD_ADDR(error)) | 516 | if (BAD_ADDR(error)) |
| 521 | goto out_close; | 517 | goto out_close; |
| 522 | } | 518 | } |
| @@ -962,10 +958,8 @@ static int load_elf_binary(struct linux_binprm *bprm, struct pt_regs *regs) | |||
| 962 | and some applications "depend" upon this behavior. | 958 | and some applications "depend" upon this behavior. |
| 963 | Since we do not have the power to recompile these, we | 959 | Since we do not have the power to recompile these, we |
| 964 | emulate the SVr4 behavior. Sigh. */ | 960 | emulate the SVr4 behavior. Sigh. */ |
| 965 | down_write(¤t->mm->mmap_sem); | 961 | error = vm_mmap(NULL, 0, PAGE_SIZE, PROT_READ | PROT_EXEC, |
| 966 | error = do_mmap(NULL, 0, PAGE_SIZE, PROT_READ | PROT_EXEC, | ||
| 967 | MAP_FIXED | MAP_PRIVATE, 0); | 962 | MAP_FIXED | MAP_PRIVATE, 0); |
| 968 | up_write(¤t->mm->mmap_sem); | ||
| 969 | } | 963 | } |
| 970 | 964 | ||
| 971 | #ifdef ELF_PLAT_INIT | 965 | #ifdef ELF_PLAT_INIT |
| @@ -1050,8 +1044,7 @@ static int load_elf_library(struct file *file) | |||
| 1050 | eppnt++; | 1044 | eppnt++; |
| 1051 | 1045 | ||
| 1052 | /* Now use mmap to map the library into memory. */ | 1046 | /* Now use mmap to map the library into memory. */ |
| 1053 | down_write(¤t->mm->mmap_sem); | 1047 | error = vm_mmap(file, |
| 1054 | error = do_mmap(file, | ||
| 1055 | ELF_PAGESTART(eppnt->p_vaddr), | 1048 | ELF_PAGESTART(eppnt->p_vaddr), |
| 1056 | (eppnt->p_filesz + | 1049 | (eppnt->p_filesz + |
| 1057 | ELF_PAGEOFFSET(eppnt->p_vaddr)), | 1050 | ELF_PAGEOFFSET(eppnt->p_vaddr)), |
| @@ -1059,7 +1052,6 @@ static int load_elf_library(struct file *file) | |||
| 1059 | MAP_FIXED | MAP_PRIVATE | MAP_DENYWRITE, | 1052 | MAP_FIXED | MAP_PRIVATE | MAP_DENYWRITE, |
| 1060 | (eppnt->p_offset - | 1053 | (eppnt->p_offset - |
| 1061 | ELF_PAGEOFFSET(eppnt->p_vaddr))); | 1054 | ELF_PAGEOFFSET(eppnt->p_vaddr))); |
| 1062 | up_write(¤t->mm->mmap_sem); | ||
| 1063 | if (error != ELF_PAGESTART(eppnt->p_vaddr)) | 1055 | if (error != ELF_PAGESTART(eppnt->p_vaddr)) |
| 1064 | goto out_free_ph; | 1056 | goto out_free_ph; |
| 1065 | 1057 | ||
| @@ -1072,11 +1064,8 @@ static int load_elf_library(struct file *file) | |||
| 1072 | len = ELF_PAGESTART(eppnt->p_filesz + eppnt->p_vaddr + | 1064 | len = ELF_PAGESTART(eppnt->p_filesz + eppnt->p_vaddr + |
| 1073 | ELF_MIN_ALIGN - 1); | 1065 | ELF_MIN_ALIGN - 1); |
| 1074 | bss = eppnt->p_memsz + eppnt->p_vaddr; | 1066 | bss = eppnt->p_memsz + eppnt->p_vaddr; |
| 1075 | if (bss > len) { | 1067 | if (bss > len) |
| 1076 | down_write(¤t->mm->mmap_sem); | 1068 | vm_brk(len, bss - len); |
| 1077 | do_brk(len, bss - len); | ||
| 1078 | up_write(¤t->mm->mmap_sem); | ||
| 1079 | } | ||
| 1080 | error = 0; | 1069 | error = 0; |
| 1081 | 1070 | ||
| 1082 | out_free_ph: | 1071 | out_free_ph: |
diff --git a/fs/binfmt_elf_fdpic.c b/fs/binfmt_elf_fdpic.c index 9bd5612a8224..d390a0fffc65 100644 --- a/fs/binfmt_elf_fdpic.c +++ b/fs/binfmt_elf_fdpic.c | |||
| @@ -390,21 +390,17 @@ static int load_elf_fdpic_binary(struct linux_binprm *bprm, | |||
| 390 | (executable_stack == EXSTACK_DEFAULT && VM_STACK_FLAGS & VM_EXEC)) | 390 | (executable_stack == EXSTACK_DEFAULT && VM_STACK_FLAGS & VM_EXEC)) |
| 391 | stack_prot |= PROT_EXEC; | 391 | stack_prot |= PROT_EXEC; |
| 392 | 392 | ||
| 393 | down_write(¤t->mm->mmap_sem); | 393 | current->mm->start_brk = vm_mmap(NULL, 0, stack_size, stack_prot, |
| 394 | current->mm->start_brk = do_mmap(NULL, 0, stack_size, stack_prot, | ||
| 395 | MAP_PRIVATE | MAP_ANONYMOUS | | 394 | MAP_PRIVATE | MAP_ANONYMOUS | |
| 396 | MAP_UNINITIALIZED | MAP_GROWSDOWN, | 395 | MAP_UNINITIALIZED | MAP_GROWSDOWN, |
| 397 | 0); | 396 | 0); |
| 398 | 397 | ||
| 399 | if (IS_ERR_VALUE(current->mm->start_brk)) { | 398 | if (IS_ERR_VALUE(current->mm->start_brk)) { |
| 400 | up_write(¤t->mm->mmap_sem); | ||
| 401 | retval = current->mm->start_brk; | 399 | retval = current->mm->start_brk; |
| 402 | current->mm->start_brk = 0; | 400 | current->mm->start_brk = 0; |
| 403 | goto error_kill; | 401 | goto error_kill; |
| 404 | } | 402 | } |
| 405 | 403 | ||
| 406 | up_write(¤t->mm->mmap_sem); | ||
| 407 | |||
| 408 | current->mm->brk = current->mm->start_brk; | 404 | current->mm->brk = current->mm->start_brk; |
| 409 | current->mm->context.end_brk = current->mm->start_brk; | 405 | current->mm->context.end_brk = current->mm->start_brk; |
| 410 | current->mm->context.end_brk += | 406 | current->mm->context.end_brk += |
| @@ -955,10 +951,8 @@ static int elf_fdpic_map_file_constdisp_on_uclinux( | |||
| 955 | if (params->flags & ELF_FDPIC_FLAG_EXECUTABLE) | 951 | if (params->flags & ELF_FDPIC_FLAG_EXECUTABLE) |
| 956 | mflags |= MAP_EXECUTABLE; | 952 | mflags |= MAP_EXECUTABLE; |
| 957 | 953 | ||
| 958 | down_write(&mm->mmap_sem); | 954 | maddr = vm_mmap(NULL, load_addr, top - base, |
| 959 | maddr = do_mmap(NULL, load_addr, top - base, | ||
| 960 | PROT_READ | PROT_WRITE | PROT_EXEC, mflags, 0); | 955 | PROT_READ | PROT_WRITE | PROT_EXEC, mflags, 0); |
| 961 | up_write(&mm->mmap_sem); | ||
| 962 | if (IS_ERR_VALUE(maddr)) | 956 | if (IS_ERR_VALUE(maddr)) |
| 963 | return (int) maddr; | 957 | return (int) maddr; |
| 964 | 958 | ||
| @@ -1096,10 +1090,8 @@ static int elf_fdpic_map_file_by_direct_mmap(struct elf_fdpic_params *params, | |||
| 1096 | 1090 | ||
| 1097 | /* create the mapping */ | 1091 | /* create the mapping */ |
| 1098 | disp = phdr->p_vaddr & ~PAGE_MASK; | 1092 | disp = phdr->p_vaddr & ~PAGE_MASK; |
| 1099 | down_write(&mm->mmap_sem); | 1093 | maddr = vm_mmap(file, maddr, phdr->p_memsz + disp, prot, flags, |
| 1100 | maddr = do_mmap(file, maddr, phdr->p_memsz + disp, prot, flags, | ||
| 1101 | phdr->p_offset - disp); | 1094 | phdr->p_offset - disp); |
| 1102 | up_write(&mm->mmap_sem); | ||
| 1103 | 1095 | ||
| 1104 | kdebug("mmap[%d] <file> sz=%lx pr=%x fl=%x of=%lx --> %08lx", | 1096 | kdebug("mmap[%d] <file> sz=%lx pr=%x fl=%x of=%lx --> %08lx", |
| 1105 | loop, phdr->p_memsz + disp, prot, flags, | 1097 | loop, phdr->p_memsz + disp, prot, flags, |
| @@ -1143,10 +1135,8 @@ static int elf_fdpic_map_file_by_direct_mmap(struct elf_fdpic_params *params, | |||
| 1143 | unsigned long xmaddr; | 1135 | unsigned long xmaddr; |
| 1144 | 1136 | ||
| 1145 | flags |= MAP_FIXED | MAP_ANONYMOUS; | 1137 | flags |= MAP_FIXED | MAP_ANONYMOUS; |
| 1146 | down_write(&mm->mmap_sem); | 1138 | xmaddr = vm_mmap(NULL, xaddr, excess - excess1, |
| 1147 | xmaddr = do_mmap(NULL, xaddr, excess - excess1, | ||
| 1148 | prot, flags, 0); | 1139 | prot, flags, 0); |
| 1149 | up_write(&mm->mmap_sem); | ||
| 1150 | 1140 | ||
| 1151 | kdebug("mmap[%d] <anon>" | 1141 | kdebug("mmap[%d] <anon>" |
| 1152 | " ad=%lx sz=%lx pr=%x fl=%x of=0 --> %08lx", | 1142 | " ad=%lx sz=%lx pr=%x fl=%x of=0 --> %08lx", |
diff --git a/fs/binfmt_flat.c b/fs/binfmt_flat.c index 024d20ee3ca3..6b2daf99fab8 100644 --- a/fs/binfmt_flat.c +++ b/fs/binfmt_flat.c | |||
| @@ -542,10 +542,8 @@ static int load_flat_file(struct linux_binprm * bprm, | |||
| 542 | */ | 542 | */ |
| 543 | DBG_FLT("BINFMT_FLAT: ROM mapping of file (we hope)\n"); | 543 | DBG_FLT("BINFMT_FLAT: ROM mapping of file (we hope)\n"); |
| 544 | 544 | ||
| 545 | down_write(¤t->mm->mmap_sem); | 545 | textpos = vm_mmap(bprm->file, 0, text_len, PROT_READ|PROT_EXEC, |
| 546 | textpos = do_mmap(bprm->file, 0, text_len, PROT_READ|PROT_EXEC, | ||
| 547 | MAP_PRIVATE|MAP_EXECUTABLE, 0); | 546 | MAP_PRIVATE|MAP_EXECUTABLE, 0); |
| 548 | up_write(¤t->mm->mmap_sem); | ||
| 549 | if (!textpos || IS_ERR_VALUE(textpos)) { | 547 | if (!textpos || IS_ERR_VALUE(textpos)) { |
| 550 | if (!textpos) | 548 | if (!textpos) |
| 551 | textpos = (unsigned long) -ENOMEM; | 549 | textpos = (unsigned long) -ENOMEM; |
| @@ -556,10 +554,8 @@ static int load_flat_file(struct linux_binprm * bprm, | |||
| 556 | 554 | ||
| 557 | len = data_len + extra + MAX_SHARED_LIBS * sizeof(unsigned long); | 555 | len = data_len + extra + MAX_SHARED_LIBS * sizeof(unsigned long); |
| 558 | len = PAGE_ALIGN(len); | 556 | len = PAGE_ALIGN(len); |
| 559 | down_write(¤t->mm->mmap_sem); | 557 | realdatastart = vm_mmap(0, 0, len, |
| 560 | realdatastart = do_mmap(0, 0, len, | ||
| 561 | PROT_READ|PROT_WRITE|PROT_EXEC, MAP_PRIVATE, 0); | 558 | PROT_READ|PROT_WRITE|PROT_EXEC, MAP_PRIVATE, 0); |
| 562 | up_write(¤t->mm->mmap_sem); | ||
| 563 | 559 | ||
| 564 | if (realdatastart == 0 || IS_ERR_VALUE(realdatastart)) { | 560 | if (realdatastart == 0 || IS_ERR_VALUE(realdatastart)) { |
| 565 | if (!realdatastart) | 561 | if (!realdatastart) |
| @@ -603,10 +599,8 @@ static int load_flat_file(struct linux_binprm * bprm, | |||
| 603 | 599 | ||
| 604 | len = text_len + data_len + extra + MAX_SHARED_LIBS * sizeof(unsigned long); | 600 | len = text_len + data_len + extra + MAX_SHARED_LIBS * sizeof(unsigned long); |
| 605 | len = PAGE_ALIGN(len); | 601 | len = PAGE_ALIGN(len); |
| 606 | down_write(¤t->mm->mmap_sem); | 602 | textpos = vm_mmap(0, 0, len, |
| 607 | textpos = do_mmap(0, 0, len, | ||
| 608 | PROT_READ | PROT_EXEC | PROT_WRITE, MAP_PRIVATE, 0); | 603 | PROT_READ | PROT_EXEC | PROT_WRITE, MAP_PRIVATE, 0); |
| 609 | up_write(¤t->mm->mmap_sem); | ||
| 610 | 604 | ||
| 611 | if (!textpos || IS_ERR_VALUE(textpos)) { | 605 | if (!textpos || IS_ERR_VALUE(textpos)) { |
| 612 | if (!textpos) | 606 | if (!textpos) |
diff --git a/fs/binfmt_som.c b/fs/binfmt_som.c index e4fc746629a7..4517aaff61b4 100644 --- a/fs/binfmt_som.c +++ b/fs/binfmt_som.c | |||
| @@ -147,10 +147,8 @@ static int map_som_binary(struct file *file, | |||
| 147 | code_size = SOM_PAGEALIGN(hpuxhdr->exec_tsize); | 147 | code_size = SOM_PAGEALIGN(hpuxhdr->exec_tsize); |
| 148 | current->mm->start_code = code_start; | 148 | current->mm->start_code = code_start; |
| 149 | current->mm->end_code = code_start + code_size; | 149 | current->mm->end_code = code_start + code_size; |
| 150 | down_write(¤t->mm->mmap_sem); | 150 | retval = vm_mmap(file, code_start, code_size, prot, |
| 151 | retval = do_mmap(file, code_start, code_size, prot, | ||
| 152 | flags, SOM_PAGESTART(hpuxhdr->exec_tfile)); | 151 | flags, SOM_PAGESTART(hpuxhdr->exec_tfile)); |
| 153 | up_write(¤t->mm->mmap_sem); | ||
| 154 | if (retval < 0 && retval > -1024) | 152 | if (retval < 0 && retval > -1024) |
| 155 | goto out; | 153 | goto out; |
| 156 | 154 | ||
| @@ -158,20 +156,16 @@ static int map_som_binary(struct file *file, | |||
| 158 | data_size = SOM_PAGEALIGN(hpuxhdr->exec_dsize); | 156 | data_size = SOM_PAGEALIGN(hpuxhdr->exec_dsize); |
| 159 | current->mm->start_data = data_start; | 157 | current->mm->start_data = data_start; |
| 160 | current->mm->end_data = bss_start = data_start + data_size; | 158 | current->mm->end_data = bss_start = data_start + data_size; |
| 161 | down_write(¤t->mm->mmap_sem); | 159 | retval = vm_mmap(file, data_start, data_size, |
| 162 | retval = do_mmap(file, data_start, data_size, | ||
| 163 | prot | PROT_WRITE, flags, | 160 | prot | PROT_WRITE, flags, |
| 164 | SOM_PAGESTART(hpuxhdr->exec_dfile)); | 161 | SOM_PAGESTART(hpuxhdr->exec_dfile)); |
| 165 | up_write(¤t->mm->mmap_sem); | ||
| 166 | if (retval < 0 && retval > -1024) | 162 | if (retval < 0 && retval > -1024) |
| 167 | goto out; | 163 | goto out; |
| 168 | 164 | ||
| 169 | som_brk = bss_start + SOM_PAGEALIGN(hpuxhdr->exec_bsize); | 165 | som_brk = bss_start + SOM_PAGEALIGN(hpuxhdr->exec_bsize); |
| 170 | current->mm->start_brk = current->mm->brk = som_brk; | 166 | current->mm->start_brk = current->mm->brk = som_brk; |
| 171 | down_write(¤t->mm->mmap_sem); | 167 | retval = vm_mmap(NULL, bss_start, som_brk - bss_start, |
| 172 | retval = do_mmap(NULL, bss_start, som_brk - bss_start, | ||
| 173 | prot | PROT_WRITE, MAP_FIXED | MAP_PRIVATE, 0); | 168 | prot | PROT_WRITE, MAP_FIXED | MAP_PRIVATE, 0); |
| 174 | up_write(¤t->mm->mmap_sem); | ||
| 175 | if (retval > 0 || retval < -1024) | 169 | if (retval > 0 || retval < -1024) |
| 176 | retval = 0; | 170 | retval = 0; |
| 177 | out: | 171 | out: |
diff --git a/fs/btrfs/compression.c b/fs/btrfs/compression.c index d286b40a5671..86eff48dab78 100644 --- a/fs/btrfs/compression.c +++ b/fs/btrfs/compression.c | |||
| @@ -405,6 +405,7 @@ int btrfs_submit_compressed_write(struct inode *inode, u64 start, | |||
| 405 | bio_put(bio); | 405 | bio_put(bio); |
| 406 | 406 | ||
| 407 | bio = compressed_bio_alloc(bdev, first_byte, GFP_NOFS); | 407 | bio = compressed_bio_alloc(bdev, first_byte, GFP_NOFS); |
| 408 | BUG_ON(!bio); | ||
| 408 | bio->bi_private = cb; | 409 | bio->bi_private = cb; |
| 409 | bio->bi_end_io = end_compressed_bio_write; | 410 | bio->bi_end_io = end_compressed_bio_write; |
| 410 | bio_add_page(bio, page, PAGE_CACHE_SIZE, 0); | 411 | bio_add_page(bio, page, PAGE_CACHE_SIZE, 0); |
| @@ -687,6 +688,7 @@ int btrfs_submit_compressed_read(struct inode *inode, struct bio *bio, | |||
| 687 | 688 | ||
| 688 | comp_bio = compressed_bio_alloc(bdev, cur_disk_byte, | 689 | comp_bio = compressed_bio_alloc(bdev, cur_disk_byte, |
| 689 | GFP_NOFS); | 690 | GFP_NOFS); |
| 691 | BUG_ON(!comp_bio); | ||
| 690 | comp_bio->bi_private = cb; | 692 | comp_bio->bi_private = cb; |
| 691 | comp_bio->bi_end_io = end_compressed_bio_read; | 693 | comp_bio->bi_end_io = end_compressed_bio_read; |
| 692 | 694 | ||
diff --git a/fs/btrfs/ctree.h b/fs/btrfs/ctree.h index 5b8ef8eb3521..3f65a812e282 100644 --- a/fs/btrfs/ctree.h +++ b/fs/btrfs/ctree.h | |||
| @@ -2166,7 +2166,7 @@ BTRFS_SETGET_STACK_FUNCS(root_last_snapshot, struct btrfs_root_item, | |||
| 2166 | 2166 | ||
| 2167 | static inline bool btrfs_root_readonly(struct btrfs_root *root) | 2167 | static inline bool btrfs_root_readonly(struct btrfs_root *root) |
| 2168 | { | 2168 | { |
| 2169 | return root->root_item.flags & BTRFS_ROOT_SUBVOL_RDONLY; | 2169 | return (root->root_item.flags & cpu_to_le64(BTRFS_ROOT_SUBVOL_RDONLY)) != 0; |
| 2170 | } | 2170 | } |
| 2171 | 2171 | ||
| 2172 | /* struct btrfs_root_backup */ | 2172 | /* struct btrfs_root_backup */ |
diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c index a84420491c11..2b35f8d14bb9 100644 --- a/fs/btrfs/extent-tree.c +++ b/fs/btrfs/extent-tree.c | |||
| @@ -529,9 +529,7 @@ static int cache_block_group(struct btrfs_block_group_cache *cache, | |||
| 529 | * allocate blocks for the tree root we can't do the fast caching since | 529 | * allocate blocks for the tree root we can't do the fast caching since |
| 530 | * we likely hold important locks. | 530 | * we likely hold important locks. |
| 531 | */ | 531 | */ |
| 532 | if (trans && (!trans->transaction->in_commit) && | 532 | if (fs_info->mount_opt & BTRFS_MOUNT_SPACE_CACHE) { |
| 533 | (root && root != root->fs_info->tree_root) && | ||
| 534 | btrfs_test_opt(root, SPACE_CACHE)) { | ||
| 535 | ret = load_free_space_cache(fs_info, cache); | 533 | ret = load_free_space_cache(fs_info, cache); |
| 536 | 534 | ||
| 537 | spin_lock(&cache->lock); | 535 | spin_lock(&cache->lock); |
| @@ -3152,15 +3150,14 @@ static void set_avail_alloc_bits(struct btrfs_fs_info *fs_info, u64 flags) | |||
| 3152 | /* | 3150 | /* |
| 3153 | * returns target flags in extended format or 0 if restripe for this | 3151 | * returns target flags in extended format or 0 if restripe for this |
| 3154 | * chunk_type is not in progress | 3152 | * chunk_type is not in progress |
| 3153 | * | ||
| 3154 | * should be called with either volume_mutex or balance_lock held | ||
| 3155 | */ | 3155 | */ |
| 3156 | static u64 get_restripe_target(struct btrfs_fs_info *fs_info, u64 flags) | 3156 | static u64 get_restripe_target(struct btrfs_fs_info *fs_info, u64 flags) |
| 3157 | { | 3157 | { |
| 3158 | struct btrfs_balance_control *bctl = fs_info->balance_ctl; | 3158 | struct btrfs_balance_control *bctl = fs_info->balance_ctl; |
| 3159 | u64 target = 0; | 3159 | u64 target = 0; |
| 3160 | 3160 | ||
| 3161 | BUG_ON(!mutex_is_locked(&fs_info->volume_mutex) && | ||
| 3162 | !spin_is_locked(&fs_info->balance_lock)); | ||
| 3163 | |||
| 3164 | if (!bctl) | 3161 | if (!bctl) |
| 3165 | return 0; | 3162 | return 0; |
| 3166 | 3163 | ||
| @@ -4205,7 +4202,7 @@ static u64 calc_global_metadata_size(struct btrfs_fs_info *fs_info) | |||
| 4205 | num_bytes += div64_u64(data_used + meta_used, 50); | 4202 | num_bytes += div64_u64(data_used + meta_used, 50); |
| 4206 | 4203 | ||
| 4207 | if (num_bytes * 3 > meta_used) | 4204 | if (num_bytes * 3 > meta_used) |
| 4208 | num_bytes = div64_u64(meta_used, 3) * 2; | 4205 | num_bytes = div64_u64(meta_used, 3); |
| 4209 | 4206 | ||
| 4210 | return ALIGN(num_bytes, fs_info->extent_root->leafsize << 10); | 4207 | return ALIGN(num_bytes, fs_info->extent_root->leafsize << 10); |
| 4211 | } | 4208 | } |
diff --git a/fs/btrfs/extent_io.c b/fs/btrfs/extent_io.c index 8d904dd7ea9f..cd4b5e400221 100644 --- a/fs/btrfs/extent_io.c +++ b/fs/btrfs/extent_io.c | |||
| @@ -1937,7 +1937,7 @@ int repair_eb_io_failure(struct btrfs_root *root, struct extent_buffer *eb, | |||
| 1937 | struct btrfs_mapping_tree *map_tree = &root->fs_info->mapping_tree; | 1937 | struct btrfs_mapping_tree *map_tree = &root->fs_info->mapping_tree; |
| 1938 | u64 start = eb->start; | 1938 | u64 start = eb->start; |
| 1939 | unsigned long i, num_pages = num_extent_pages(eb->start, eb->len); | 1939 | unsigned long i, num_pages = num_extent_pages(eb->start, eb->len); |
| 1940 | int ret; | 1940 | int ret = 0; |
| 1941 | 1941 | ||
| 1942 | for (i = 0; i < num_pages; i++) { | 1942 | for (i = 0; i < num_pages; i++) { |
| 1943 | struct page *p = extent_buffer_page(eb, i); | 1943 | struct page *p = extent_buffer_page(eb, i); |
| @@ -2180,6 +2180,10 @@ static int bio_readpage_error(struct bio *failed_bio, struct page *page, | |||
| 2180 | } | 2180 | } |
| 2181 | 2181 | ||
| 2182 | bio = bio_alloc(GFP_NOFS, 1); | 2182 | bio = bio_alloc(GFP_NOFS, 1); |
| 2183 | if (!bio) { | ||
| 2184 | free_io_failure(inode, failrec, 0); | ||
| 2185 | return -EIO; | ||
| 2186 | } | ||
| 2183 | bio->bi_private = state; | 2187 | bio->bi_private = state; |
| 2184 | bio->bi_end_io = failed_bio->bi_end_io; | 2188 | bio->bi_end_io = failed_bio->bi_end_io; |
| 2185 | bio->bi_sector = failrec->logical >> 9; | 2189 | bio->bi_sector = failrec->logical >> 9; |
diff --git a/fs/btrfs/free-space-cache.c b/fs/btrfs/free-space-cache.c index e88330d3df52..202008ec367d 100644 --- a/fs/btrfs/free-space-cache.c +++ b/fs/btrfs/free-space-cache.c | |||
| @@ -748,13 +748,6 @@ int load_free_space_cache(struct btrfs_fs_info *fs_info, | |||
| 748 | u64 used = btrfs_block_group_used(&block_group->item); | 748 | u64 used = btrfs_block_group_used(&block_group->item); |
| 749 | 749 | ||
| 750 | /* | 750 | /* |
| 751 | * If we're unmounting then just return, since this does a search on the | ||
| 752 | * normal root and not the commit root and we could deadlock. | ||
| 753 | */ | ||
| 754 | if (btrfs_fs_closing(fs_info)) | ||
| 755 | return 0; | ||
| 756 | |||
| 757 | /* | ||
| 758 | * If this block group has been marked to be cleared for one reason or | 751 | * If this block group has been marked to be cleared for one reason or |
| 759 | * another then we can't trust the on disk cache, so just return. | 752 | * another then we can't trust the on disk cache, so just return. |
| 760 | */ | 753 | */ |
| @@ -768,6 +761,8 @@ int load_free_space_cache(struct btrfs_fs_info *fs_info, | |||
| 768 | path = btrfs_alloc_path(); | 761 | path = btrfs_alloc_path(); |
| 769 | if (!path) | 762 | if (!path) |
| 770 | return 0; | 763 | return 0; |
| 764 | path->search_commit_root = 1; | ||
| 765 | path->skip_locking = 1; | ||
| 771 | 766 | ||
| 772 | inode = lookup_free_space_inode(root, block_group, path); | 767 | inode = lookup_free_space_inode(root, block_group, path); |
| 773 | if (IS_ERR(inode)) { | 768 | if (IS_ERR(inode)) { |
diff --git a/fs/btrfs/scrub.c b/fs/btrfs/scrub.c index 90acc82046c3..bc015f77f3ea 100644 --- a/fs/btrfs/scrub.c +++ b/fs/btrfs/scrub.c | |||
| @@ -1044,6 +1044,8 @@ static int scrub_recheck_block(struct btrfs_fs_info *fs_info, | |||
| 1044 | 1044 | ||
| 1045 | BUG_ON(!page->page); | 1045 | BUG_ON(!page->page); |
| 1046 | bio = bio_alloc(GFP_NOFS, 1); | 1046 | bio = bio_alloc(GFP_NOFS, 1); |
| 1047 | if (!bio) | ||
| 1048 | return -EIO; | ||
| 1047 | bio->bi_bdev = page->bdev; | 1049 | bio->bi_bdev = page->bdev; |
| 1048 | bio->bi_sector = page->physical >> 9; | 1050 | bio->bi_sector = page->physical >> 9; |
| 1049 | bio->bi_end_io = scrub_complete_bio_end_io; | 1051 | bio->bi_end_io = scrub_complete_bio_end_io; |
| @@ -1171,6 +1173,8 @@ static int scrub_repair_page_from_good_copy(struct scrub_block *sblock_bad, | |||
| 1171 | DECLARE_COMPLETION_ONSTACK(complete); | 1173 | DECLARE_COMPLETION_ONSTACK(complete); |
| 1172 | 1174 | ||
| 1173 | bio = bio_alloc(GFP_NOFS, 1); | 1175 | bio = bio_alloc(GFP_NOFS, 1); |
| 1176 | if (!bio) | ||
| 1177 | return -EIO; | ||
| 1174 | bio->bi_bdev = page_bad->bdev; | 1178 | bio->bi_bdev = page_bad->bdev; |
| 1175 | bio->bi_sector = page_bad->physical >> 9; | 1179 | bio->bi_sector = page_bad->physical >> 9; |
| 1176 | bio->bi_end_io = scrub_complete_bio_end_io; | 1180 | bio->bi_end_io = scrub_complete_bio_end_io; |
diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c index 8da29e8e4de1..11b77a59db62 100644 --- a/fs/btrfs/transaction.c +++ b/fs/btrfs/transaction.c | |||
| @@ -480,6 +480,7 @@ static int __btrfs_end_transaction(struct btrfs_trans_handle *trans, | |||
| 480 | struct btrfs_transaction *cur_trans = trans->transaction; | 480 | struct btrfs_transaction *cur_trans = trans->transaction; |
| 481 | struct btrfs_fs_info *info = root->fs_info; | 481 | struct btrfs_fs_info *info = root->fs_info; |
| 482 | int count = 0; | 482 | int count = 0; |
| 483 | int err = 0; | ||
| 483 | 484 | ||
| 484 | if (--trans->use_count) { | 485 | if (--trans->use_count) { |
| 485 | trans->block_rsv = trans->orig_rsv; | 486 | trans->block_rsv = trans->orig_rsv; |
| @@ -532,18 +533,18 @@ static int __btrfs_end_transaction(struct btrfs_trans_handle *trans, | |||
| 532 | 533 | ||
| 533 | if (current->journal_info == trans) | 534 | if (current->journal_info == trans) |
| 534 | current->journal_info = NULL; | 535 | current->journal_info = NULL; |
| 535 | memset(trans, 0, sizeof(*trans)); | ||
| 536 | kmem_cache_free(btrfs_trans_handle_cachep, trans); | ||
| 537 | 536 | ||
| 538 | if (throttle) | 537 | if (throttle) |
| 539 | btrfs_run_delayed_iputs(root); | 538 | btrfs_run_delayed_iputs(root); |
| 540 | 539 | ||
| 541 | if (trans->aborted || | 540 | if (trans->aborted || |
| 542 | root->fs_info->fs_state & BTRFS_SUPER_FLAG_ERROR) { | 541 | root->fs_info->fs_state & BTRFS_SUPER_FLAG_ERROR) { |
| 543 | return -EIO; | 542 | err = -EIO; |
| 544 | } | 543 | } |
| 545 | 544 | ||
| 546 | return 0; | 545 | memset(trans, 0, sizeof(*trans)); |
| 546 | kmem_cache_free(btrfs_trans_handle_cachep, trans); | ||
| 547 | return err; | ||
| 547 | } | 548 | } |
| 548 | 549 | ||
| 549 | int btrfs_end_transaction(struct btrfs_trans_handle *trans, | 550 | int btrfs_end_transaction(struct btrfs_trans_handle *trans, |
diff --git a/fs/btrfs/volumes.c b/fs/btrfs/volumes.c index a872b48be0ae..759d02486d7c 100644 --- a/fs/btrfs/volumes.c +++ b/fs/btrfs/volumes.c | |||
| @@ -3833,6 +3833,7 @@ static int __btrfs_map_block(struct btrfs_mapping_tree *map_tree, int rw, | |||
| 3833 | int sub_stripes = 0; | 3833 | int sub_stripes = 0; |
| 3834 | u64 stripes_per_dev = 0; | 3834 | u64 stripes_per_dev = 0; |
| 3835 | u32 remaining_stripes = 0; | 3835 | u32 remaining_stripes = 0; |
| 3836 | u32 last_stripe = 0; | ||
| 3836 | 3837 | ||
| 3837 | if (map->type & | 3838 | if (map->type & |
| 3838 | (BTRFS_BLOCK_GROUP_RAID0 | BTRFS_BLOCK_GROUP_RAID10)) { | 3839 | (BTRFS_BLOCK_GROUP_RAID0 | BTRFS_BLOCK_GROUP_RAID10)) { |
| @@ -3846,6 +3847,8 @@ static int __btrfs_map_block(struct btrfs_mapping_tree *map_tree, int rw, | |||
| 3846 | stripe_nr_orig, | 3847 | stripe_nr_orig, |
| 3847 | factor, | 3848 | factor, |
| 3848 | &remaining_stripes); | 3849 | &remaining_stripes); |
| 3850 | div_u64_rem(stripe_nr_end - 1, factor, &last_stripe); | ||
| 3851 | last_stripe *= sub_stripes; | ||
| 3849 | } | 3852 | } |
| 3850 | 3853 | ||
| 3851 | for (i = 0; i < num_stripes; i++) { | 3854 | for (i = 0; i < num_stripes; i++) { |
| @@ -3858,16 +3861,29 @@ static int __btrfs_map_block(struct btrfs_mapping_tree *map_tree, int rw, | |||
| 3858 | BTRFS_BLOCK_GROUP_RAID10)) { | 3861 | BTRFS_BLOCK_GROUP_RAID10)) { |
| 3859 | bbio->stripes[i].length = stripes_per_dev * | 3862 | bbio->stripes[i].length = stripes_per_dev * |
| 3860 | map->stripe_len; | 3863 | map->stripe_len; |
| 3864 | |||
| 3861 | if (i / sub_stripes < remaining_stripes) | 3865 | if (i / sub_stripes < remaining_stripes) |
| 3862 | bbio->stripes[i].length += | 3866 | bbio->stripes[i].length += |
| 3863 | map->stripe_len; | 3867 | map->stripe_len; |
| 3868 | |||
| 3869 | /* | ||
| 3870 | * Special for the first stripe and | ||
| 3871 | * the last stripe: | ||
| 3872 | * | ||
| 3873 | * |-------|...|-------| | ||
| 3874 | * |----------| | ||
| 3875 | * off end_off | ||
| 3876 | */ | ||
| 3864 | if (i < sub_stripes) | 3877 | if (i < sub_stripes) |
| 3865 | bbio->stripes[i].length -= | 3878 | bbio->stripes[i].length -= |
| 3866 | stripe_offset; | 3879 | stripe_offset; |
| 3867 | if ((i / sub_stripes + 1) % | 3880 | |
| 3868 | sub_stripes == remaining_stripes) | 3881 | if (stripe_index >= last_stripe && |
| 3882 | stripe_index <= (last_stripe + | ||
| 3883 | sub_stripes - 1)) | ||
| 3869 | bbio->stripes[i].length -= | 3884 | bbio->stripes[i].length -= |
| 3870 | stripe_end_offset; | 3885 | stripe_end_offset; |
| 3886 | |||
| 3871 | if (i == sub_stripes - 1) | 3887 | if (i == sub_stripes - 1) |
| 3872 | stripe_offset = 0; | 3888 | stripe_offset = 0; |
| 3873 | } else | 3889 | } else |
diff --git a/fs/cifs/connect.c b/fs/cifs/connect.c index d81e933a796b..f31dc9ac37b7 100644 --- a/fs/cifs/connect.c +++ b/fs/cifs/connect.c | |||
| @@ -109,6 +109,8 @@ enum { | |||
| 109 | 109 | ||
| 110 | /* Options which could be blank */ | 110 | /* Options which could be blank */ |
| 111 | Opt_blank_pass, | 111 | Opt_blank_pass, |
| 112 | Opt_blank_user, | ||
| 113 | Opt_blank_ip, | ||
| 112 | 114 | ||
| 113 | Opt_err | 115 | Opt_err |
| 114 | }; | 116 | }; |
| @@ -183,11 +185,15 @@ static const match_table_t cifs_mount_option_tokens = { | |||
| 183 | { Opt_wsize, "wsize=%s" }, | 185 | { Opt_wsize, "wsize=%s" }, |
| 184 | { Opt_actimeo, "actimeo=%s" }, | 186 | { Opt_actimeo, "actimeo=%s" }, |
| 185 | 187 | ||
| 188 | { Opt_blank_user, "user=" }, | ||
| 189 | { Opt_blank_user, "username=" }, | ||
| 186 | { Opt_user, "user=%s" }, | 190 | { Opt_user, "user=%s" }, |
| 187 | { Opt_user, "username=%s" }, | 191 | { Opt_user, "username=%s" }, |
| 188 | { Opt_blank_pass, "pass=" }, | 192 | { Opt_blank_pass, "pass=" }, |
| 189 | { Opt_pass, "pass=%s" }, | 193 | { Opt_pass, "pass=%s" }, |
| 190 | { Opt_pass, "password=%s" }, | 194 | { Opt_pass, "password=%s" }, |
| 195 | { Opt_blank_ip, "ip=" }, | ||
| 196 | { Opt_blank_ip, "addr=" }, | ||
| 191 | { Opt_ip, "ip=%s" }, | 197 | { Opt_ip, "ip=%s" }, |
| 192 | { Opt_ip, "addr=%s" }, | 198 | { Opt_ip, "addr=%s" }, |
| 193 | { Opt_unc, "unc=%s" }, | 199 | { Opt_unc, "unc=%s" }, |
| @@ -1117,7 +1123,7 @@ static int get_option_ul(substring_t args[], unsigned long *option) | |||
| 1117 | string = match_strdup(args); | 1123 | string = match_strdup(args); |
| 1118 | if (string == NULL) | 1124 | if (string == NULL) |
| 1119 | return -ENOMEM; | 1125 | return -ENOMEM; |
| 1120 | rc = kstrtoul(string, 10, option); | 1126 | rc = kstrtoul(string, 0, option); |
| 1121 | kfree(string); | 1127 | kfree(string); |
| 1122 | 1128 | ||
| 1123 | return rc; | 1129 | return rc; |
| @@ -1534,15 +1540,17 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, | |||
| 1534 | 1540 | ||
| 1535 | /* String Arguments */ | 1541 | /* String Arguments */ |
| 1536 | 1542 | ||
| 1543 | case Opt_blank_user: | ||
| 1544 | /* null user, ie. anonymous authentication */ | ||
| 1545 | vol->nullauth = 1; | ||
| 1546 | vol->username = NULL; | ||
| 1547 | break; | ||
| 1537 | case Opt_user: | 1548 | case Opt_user: |
| 1538 | string = match_strdup(args); | 1549 | string = match_strdup(args); |
| 1539 | if (string == NULL) | 1550 | if (string == NULL) |
| 1540 | goto out_nomem; | 1551 | goto out_nomem; |
| 1541 | 1552 | ||
| 1542 | if (!*string) { | 1553 | if (strnlen(string, MAX_USERNAME_SIZE) > |
| 1543 | /* null user, ie. anonymous authentication */ | ||
| 1544 | vol->nullauth = 1; | ||
| 1545 | } else if (strnlen(string, MAX_USERNAME_SIZE) > | ||
| 1546 | MAX_USERNAME_SIZE) { | 1554 | MAX_USERNAME_SIZE) { |
| 1547 | printk(KERN_WARNING "CIFS: username too long\n"); | 1555 | printk(KERN_WARNING "CIFS: username too long\n"); |
| 1548 | goto cifs_parse_mount_err; | 1556 | goto cifs_parse_mount_err; |
| @@ -1611,14 +1619,15 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, | |||
| 1611 | } | 1619 | } |
| 1612 | vol->password[j] = '\0'; | 1620 | vol->password[j] = '\0'; |
| 1613 | break; | 1621 | break; |
| 1622 | case Opt_blank_ip: | ||
| 1623 | vol->UNCip = NULL; | ||
| 1624 | break; | ||
| 1614 | case Opt_ip: | 1625 | case Opt_ip: |
| 1615 | string = match_strdup(args); | 1626 | string = match_strdup(args); |
| 1616 | if (string == NULL) | 1627 | if (string == NULL) |
| 1617 | goto out_nomem; | 1628 | goto out_nomem; |
| 1618 | 1629 | ||
| 1619 | if (!*string) { | 1630 | if (strnlen(string, INET6_ADDRSTRLEN) > |
| 1620 | vol->UNCip = NULL; | ||
| 1621 | } else if (strnlen(string, INET6_ADDRSTRLEN) > | ||
| 1622 | INET6_ADDRSTRLEN) { | 1631 | INET6_ADDRSTRLEN) { |
| 1623 | printk(KERN_WARNING "CIFS: ip address " | 1632 | printk(KERN_WARNING "CIFS: ip address " |
| 1624 | "too long\n"); | 1633 | "too long\n"); |
| @@ -1636,12 +1645,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, | |||
| 1636 | if (string == NULL) | 1645 | if (string == NULL) |
| 1637 | goto out_nomem; | 1646 | goto out_nomem; |
| 1638 | 1647 | ||
| 1639 | if (!*string) { | ||
| 1640 | printk(KERN_WARNING "CIFS: invalid path to " | ||
| 1641 | "network resource\n"); | ||
| 1642 | goto cifs_parse_mount_err; | ||
| 1643 | } | ||
| 1644 | |||
| 1645 | temp_len = strnlen(string, 300); | 1648 | temp_len = strnlen(string, 300); |
| 1646 | if (temp_len == 300) { | 1649 | if (temp_len == 300) { |
| 1647 | printk(KERN_WARNING "CIFS: UNC name too long\n"); | 1650 | printk(KERN_WARNING "CIFS: UNC name too long\n"); |
| @@ -1670,11 +1673,7 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, | |||
| 1670 | if (string == NULL) | 1673 | if (string == NULL) |
| 1671 | goto out_nomem; | 1674 | goto out_nomem; |
| 1672 | 1675 | ||
| 1673 | if (!*string) { | 1676 | if (strnlen(string, 256) == 256) { |
| 1674 | printk(KERN_WARNING "CIFS: invalid domain" | ||
| 1675 | " name\n"); | ||
| 1676 | goto cifs_parse_mount_err; | ||
| 1677 | } else if (strnlen(string, 256) == 256) { | ||
| 1678 | printk(KERN_WARNING "CIFS: domain name too" | 1677 | printk(KERN_WARNING "CIFS: domain name too" |
| 1679 | " long\n"); | 1678 | " long\n"); |
| 1680 | goto cifs_parse_mount_err; | 1679 | goto cifs_parse_mount_err; |
| @@ -1693,11 +1692,7 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, | |||
| 1693 | if (string == NULL) | 1692 | if (string == NULL) |
| 1694 | goto out_nomem; | 1693 | goto out_nomem; |
| 1695 | 1694 | ||
| 1696 | if (!*string) { | 1695 | if (!cifs_convert_address( |
| 1697 | printk(KERN_WARNING "CIFS: srcaddr value not" | ||
| 1698 | " specified\n"); | ||
| 1699 | goto cifs_parse_mount_err; | ||
| 1700 | } else if (!cifs_convert_address( | ||
| 1701 | (struct sockaddr *)&vol->srcaddr, | 1696 | (struct sockaddr *)&vol->srcaddr, |
| 1702 | string, strlen(string))) { | 1697 | string, strlen(string))) { |
| 1703 | printk(KERN_WARNING "CIFS: Could not parse" | 1698 | printk(KERN_WARNING "CIFS: Could not parse" |
| @@ -1710,11 +1705,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, | |||
| 1710 | if (string == NULL) | 1705 | if (string == NULL) |
| 1711 | goto out_nomem; | 1706 | goto out_nomem; |
| 1712 | 1707 | ||
| 1713 | if (!*string) { | ||
| 1714 | printk(KERN_WARNING "CIFS: Invalid path" | ||
| 1715 | " prefix\n"); | ||
| 1716 | goto cifs_parse_mount_err; | ||
| 1717 | } | ||
| 1718 | temp_len = strnlen(string, 1024); | 1708 | temp_len = strnlen(string, 1024); |
| 1719 | if (string[0] != '/') | 1709 | if (string[0] != '/') |
| 1720 | temp_len++; /* missing leading slash */ | 1710 | temp_len++; /* missing leading slash */ |
| @@ -1742,11 +1732,7 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, | |||
| 1742 | if (string == NULL) | 1732 | if (string == NULL) |
| 1743 | goto out_nomem; | 1733 | goto out_nomem; |
| 1744 | 1734 | ||
| 1745 | if (!*string) { | 1735 | if (strnlen(string, 1024) >= 65) { |
| 1746 | printk(KERN_WARNING "CIFS: Invalid iocharset" | ||
| 1747 | " specified\n"); | ||
| 1748 | goto cifs_parse_mount_err; | ||
| 1749 | } else if (strnlen(string, 1024) >= 65) { | ||
| 1750 | printk(KERN_WARNING "CIFS: iocharset name " | 1736 | printk(KERN_WARNING "CIFS: iocharset name " |
| 1751 | "too long.\n"); | 1737 | "too long.\n"); |
| 1752 | goto cifs_parse_mount_err; | 1738 | goto cifs_parse_mount_err; |
| @@ -1771,11 +1757,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, | |||
| 1771 | if (string == NULL) | 1757 | if (string == NULL) |
| 1772 | goto out_nomem; | 1758 | goto out_nomem; |
| 1773 | 1759 | ||
| 1774 | if (!*string) { | ||
| 1775 | printk(KERN_WARNING "CIFS: No socket option" | ||
| 1776 | " specified\n"); | ||
| 1777 | goto cifs_parse_mount_err; | ||
| 1778 | } | ||
| 1779 | if (strnicmp(string, "TCP_NODELAY", 11) == 0) | 1760 | if (strnicmp(string, "TCP_NODELAY", 11) == 0) |
| 1780 | vol->sockopt_tcp_nodelay = 1; | 1761 | vol->sockopt_tcp_nodelay = 1; |
| 1781 | break; | 1762 | break; |
| @@ -1784,12 +1765,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, | |||
| 1784 | if (string == NULL) | 1765 | if (string == NULL) |
| 1785 | goto out_nomem; | 1766 | goto out_nomem; |
| 1786 | 1767 | ||
| 1787 | if (!*string) { | ||
| 1788 | printk(KERN_WARNING "CIFS: Invalid (empty)" | ||
| 1789 | " netbiosname\n"); | ||
| 1790 | break; | ||
| 1791 | } | ||
| 1792 | |||
| 1793 | memset(vol->source_rfc1001_name, 0x20, | 1768 | memset(vol->source_rfc1001_name, 0x20, |
| 1794 | RFC1001_NAME_LEN); | 1769 | RFC1001_NAME_LEN); |
| 1795 | /* | 1770 | /* |
| @@ -1817,11 +1792,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, | |||
| 1817 | if (string == NULL) | 1792 | if (string == NULL) |
| 1818 | goto out_nomem; | 1793 | goto out_nomem; |
| 1819 | 1794 | ||
| 1820 | if (!*string) { | ||
| 1821 | printk(KERN_WARNING "CIFS: Empty server" | ||
| 1822 | " netbiosname specified\n"); | ||
| 1823 | break; | ||
| 1824 | } | ||
| 1825 | /* last byte, type, is 0x20 for servr type */ | 1795 | /* last byte, type, is 0x20 for servr type */ |
| 1826 | memset(vol->target_rfc1001_name, 0x20, | 1796 | memset(vol->target_rfc1001_name, 0x20, |
| 1827 | RFC1001_NAME_LEN_WITH_NULL); | 1797 | RFC1001_NAME_LEN_WITH_NULL); |
| @@ -1848,12 +1818,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, | |||
| 1848 | if (string == NULL) | 1818 | if (string == NULL) |
| 1849 | goto out_nomem; | 1819 | goto out_nomem; |
| 1850 | 1820 | ||
| 1851 | if (!*string) { | ||
| 1852 | cERROR(1, "no protocol version specified" | ||
| 1853 | " after vers= mount option"); | ||
| 1854 | goto cifs_parse_mount_err; | ||
| 1855 | } | ||
| 1856 | |||
| 1857 | if (strnicmp(string, "cifs", 4) == 0 || | 1821 | if (strnicmp(string, "cifs", 4) == 0 || |
| 1858 | strnicmp(string, "1", 1) == 0) { | 1822 | strnicmp(string, "1", 1) == 0) { |
| 1859 | /* This is the default */ | 1823 | /* This is the default */ |
| @@ -1868,12 +1832,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname, | |||
| 1868 | if (string == NULL) | 1832 | if (string == NULL) |
| 1869 | goto out_nomem; | 1833 | goto out_nomem; |
| 1870 | 1834 | ||
| 1871 | if (!*string) { | ||
| 1872 | printk(KERN_WARNING "CIFS: no security flavor" | ||
| 1873 | " specified\n"); | ||
| 1874 | break; | ||
| 1875 | } | ||
| 1876 | |||
| 1877 | if (cifs_parse_security_flavors(string, vol) != 0) | 1835 | if (cifs_parse_security_flavors(string, vol) != 0) |
| 1878 | goto cifs_parse_mount_err; | 1836 | goto cifs_parse_mount_err; |
| 1879 | break; | 1837 | break; |
diff --git a/fs/dlm/lock.c b/fs/dlm/lock.c index fa5c07d51dcc..4c58d4a3adc4 100644 --- a/fs/dlm/lock.c +++ b/fs/dlm/lock.c | |||
| @@ -1737,6 +1737,18 @@ static int _can_be_granted(struct dlm_rsb *r, struct dlm_lkb *lkb, int now) | |||
| 1737 | return 1; | 1737 | return 1; |
| 1738 | 1738 | ||
| 1739 | /* | 1739 | /* |
| 1740 | * Even if the convert is compat with all granted locks, | ||
| 1741 | * QUECVT forces it behind other locks on the convert queue. | ||
| 1742 | */ | ||
| 1743 | |||
| 1744 | if (now && conv && (lkb->lkb_exflags & DLM_LKF_QUECVT)) { | ||
| 1745 | if (list_empty(&r->res_convertqueue)) | ||
| 1746 | return 1; | ||
| 1747 | else | ||
| 1748 | goto out; | ||
| 1749 | } | ||
| 1750 | |||
| 1751 | /* | ||
| 1740 | * The NOORDER flag is set to avoid the standard vms rules on grant | 1752 | * The NOORDER flag is set to avoid the standard vms rules on grant |
| 1741 | * order. | 1753 | * order. |
| 1742 | */ | 1754 | */ |
diff --git a/fs/ext4/ext4.h b/fs/ext4/ext4.h index ab2594a30f86..0e01e90add8b 100644 --- a/fs/ext4/ext4.h +++ b/fs/ext4/ext4.h | |||
| @@ -1203,9 +1203,6 @@ struct ext4_sb_info { | |||
| 1203 | unsigned long s_ext_blocks; | 1203 | unsigned long s_ext_blocks; |
| 1204 | unsigned long s_ext_extents; | 1204 | unsigned long s_ext_extents; |
| 1205 | #endif | 1205 | #endif |
| 1206 | /* ext4 extent cache stats */ | ||
| 1207 | unsigned long extent_cache_hits; | ||
| 1208 | unsigned long extent_cache_misses; | ||
| 1209 | 1206 | ||
| 1210 | /* for buddy allocator */ | 1207 | /* for buddy allocator */ |
| 1211 | struct ext4_group_info ***s_group_info; | 1208 | struct ext4_group_info ***s_group_info; |
diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c index 1421938e6792..abcdeab67f52 100644 --- a/fs/ext4/extents.c +++ b/fs/ext4/extents.c | |||
| @@ -2066,10 +2066,6 @@ static int ext4_ext_check_cache(struct inode *inode, ext4_lblk_t block, | |||
| 2066 | ret = 1; | 2066 | ret = 1; |
| 2067 | } | 2067 | } |
| 2068 | errout: | 2068 | errout: |
| 2069 | if (!ret) | ||
| 2070 | sbi->extent_cache_misses++; | ||
| 2071 | else | ||
| 2072 | sbi->extent_cache_hits++; | ||
| 2073 | trace_ext4_ext_in_cache(inode, block, ret); | 2069 | trace_ext4_ext_in_cache(inode, block, ret); |
| 2074 | spin_unlock(&EXT4_I(inode)->i_block_reservation_lock); | 2070 | spin_unlock(&EXT4_I(inode)->i_block_reservation_lock); |
| 2075 | return ret; | 2071 | return ret; |
| @@ -2882,7 +2878,7 @@ static int ext4_split_extent_at(handle_t *handle, | |||
| 2882 | if (err) | 2878 | if (err) |
| 2883 | goto fix_extent_len; | 2879 | goto fix_extent_len; |
| 2884 | /* update the extent length and mark as initialized */ | 2880 | /* update the extent length and mark as initialized */ |
| 2885 | ex->ee_len = cpu_to_le32(ee_len); | 2881 | ex->ee_len = cpu_to_le16(ee_len); |
| 2886 | ext4_ext_try_to_merge(inode, path, ex); | 2882 | ext4_ext_try_to_merge(inode, path, ex); |
| 2887 | err = ext4_ext_dirty(handle, inode, path + depth); | 2883 | err = ext4_ext_dirty(handle, inode, path + depth); |
| 2888 | goto out; | 2884 | goto out; |
diff --git a/fs/ext4/super.c b/fs/ext4/super.c index ceebaf853beb..6da193564e43 100644 --- a/fs/ext4/super.c +++ b/fs/ext4/super.c | |||
| @@ -1305,20 +1305,20 @@ static int set_qf_name(struct super_block *sb, int qtype, substring_t *args) | |||
| 1305 | ext4_msg(sb, KERN_ERR, | 1305 | ext4_msg(sb, KERN_ERR, |
| 1306 | "Cannot change journaled " | 1306 | "Cannot change journaled " |
| 1307 | "quota options when quota turned on"); | 1307 | "quota options when quota turned on"); |
| 1308 | return 0; | 1308 | return -1; |
| 1309 | } | 1309 | } |
| 1310 | qname = match_strdup(args); | 1310 | qname = match_strdup(args); |
| 1311 | if (!qname) { | 1311 | if (!qname) { |
| 1312 | ext4_msg(sb, KERN_ERR, | 1312 | ext4_msg(sb, KERN_ERR, |
| 1313 | "Not enough memory for storing quotafile name"); | 1313 | "Not enough memory for storing quotafile name"); |
| 1314 | return 0; | 1314 | return -1; |
| 1315 | } | 1315 | } |
| 1316 | if (sbi->s_qf_names[qtype] && | 1316 | if (sbi->s_qf_names[qtype] && |
| 1317 | strcmp(sbi->s_qf_names[qtype], qname)) { | 1317 | strcmp(sbi->s_qf_names[qtype], qname)) { |
| 1318 | ext4_msg(sb, KERN_ERR, | 1318 | ext4_msg(sb, KERN_ERR, |
| 1319 | "%s quota file already specified", QTYPE2NAME(qtype)); | 1319 | "%s quota file already specified", QTYPE2NAME(qtype)); |
| 1320 | kfree(qname); | 1320 | kfree(qname); |
| 1321 | return 0; | 1321 | return -1; |
| 1322 | } | 1322 | } |
| 1323 | sbi->s_qf_names[qtype] = qname; | 1323 | sbi->s_qf_names[qtype] = qname; |
| 1324 | if (strchr(sbi->s_qf_names[qtype], '/')) { | 1324 | if (strchr(sbi->s_qf_names[qtype], '/')) { |
| @@ -1326,7 +1326,7 @@ static int set_qf_name(struct super_block *sb, int qtype, substring_t *args) | |||
| 1326 | "quotafile must be on filesystem root"); | 1326 | "quotafile must be on filesystem root"); |
| 1327 | kfree(sbi->s_qf_names[qtype]); | 1327 | kfree(sbi->s_qf_names[qtype]); |
| 1328 | sbi->s_qf_names[qtype] = NULL; | 1328 | sbi->s_qf_names[qtype] = NULL; |
| 1329 | return 0; | 1329 | return -1; |
| 1330 | } | 1330 | } |
| 1331 | set_opt(sb, QUOTA); | 1331 | set_opt(sb, QUOTA); |
| 1332 | return 1; | 1332 | return 1; |
| @@ -1341,7 +1341,7 @@ static int clear_qf_name(struct super_block *sb, int qtype) | |||
| 1341 | sbi->s_qf_names[qtype]) { | 1341 | sbi->s_qf_names[qtype]) { |
| 1342 | ext4_msg(sb, KERN_ERR, "Cannot change journaled quota options" | 1342 | ext4_msg(sb, KERN_ERR, "Cannot change journaled quota options" |
| 1343 | " when quota turned on"); | 1343 | " when quota turned on"); |
| 1344 | return 0; | 1344 | return -1; |
| 1345 | } | 1345 | } |
| 1346 | /* | 1346 | /* |
| 1347 | * The space will be released later when all options are confirmed | 1347 | * The space will be released later when all options are confirmed |
| @@ -1450,6 +1450,16 @@ static int handle_mount_opt(struct super_block *sb, char *opt, int token, | |||
| 1450 | const struct mount_opts *m; | 1450 | const struct mount_opts *m; |
| 1451 | int arg = 0; | 1451 | int arg = 0; |
| 1452 | 1452 | ||
| 1453 | #ifdef CONFIG_QUOTA | ||
| 1454 | if (token == Opt_usrjquota) | ||
| 1455 | return set_qf_name(sb, USRQUOTA, &args[0]); | ||
| 1456 | else if (token == Opt_grpjquota) | ||
| 1457 | return set_qf_name(sb, GRPQUOTA, &args[0]); | ||
| 1458 | else if (token == Opt_offusrjquota) | ||
| 1459 | return clear_qf_name(sb, USRQUOTA); | ||
| 1460 | else if (token == Opt_offgrpjquota) | ||
| 1461 | return clear_qf_name(sb, GRPQUOTA); | ||
| 1462 | #endif | ||
| 1453 | if (args->from && match_int(args, &arg)) | 1463 | if (args->from && match_int(args, &arg)) |
| 1454 | return -1; | 1464 | return -1; |
| 1455 | switch (token) { | 1465 | switch (token) { |
| @@ -1549,18 +1559,6 @@ static int handle_mount_opt(struct super_block *sb, char *opt, int token, | |||
| 1549 | sbi->s_mount_opt |= m->mount_opt; | 1559 | sbi->s_mount_opt |= m->mount_opt; |
| 1550 | } | 1560 | } |
| 1551 | #ifdef CONFIG_QUOTA | 1561 | #ifdef CONFIG_QUOTA |
| 1552 | } else if (token == Opt_usrjquota) { | ||
| 1553 | if (!set_qf_name(sb, USRQUOTA, &args[0])) | ||
| 1554 | return -1; | ||
| 1555 | } else if (token == Opt_grpjquota) { | ||
| 1556 | if (!set_qf_name(sb, GRPQUOTA, &args[0])) | ||
| 1557 | return -1; | ||
| 1558 | } else if (token == Opt_offusrjquota) { | ||
| 1559 | if (!clear_qf_name(sb, USRQUOTA)) | ||
| 1560 | return -1; | ||
| 1561 | } else if (token == Opt_offgrpjquota) { | ||
| 1562 | if (!clear_qf_name(sb, GRPQUOTA)) | ||
| 1563 | return -1; | ||
| 1564 | } else if (m->flags & MOPT_QFMT) { | 1562 | } else if (m->flags & MOPT_QFMT) { |
| 1565 | if (sb_any_quota_loaded(sb) && | 1563 | if (sb_any_quota_loaded(sb) && |
| 1566 | sbi->s_jquota_fmt != m->mount_opt) { | 1564 | sbi->s_jquota_fmt != m->mount_opt) { |
| @@ -2366,18 +2364,6 @@ static ssize_t lifetime_write_kbytes_show(struct ext4_attr *a, | |||
| 2366 | EXT4_SB(sb)->s_sectors_written_start) >> 1))); | 2364 | EXT4_SB(sb)->s_sectors_written_start) >> 1))); |
| 2367 | } | 2365 | } |
| 2368 | 2366 | ||
| 2369 | static ssize_t extent_cache_hits_show(struct ext4_attr *a, | ||
| 2370 | struct ext4_sb_info *sbi, char *buf) | ||
| 2371 | { | ||
| 2372 | return snprintf(buf, PAGE_SIZE, "%lu\n", sbi->extent_cache_hits); | ||
| 2373 | } | ||
| 2374 | |||
| 2375 | static ssize_t extent_cache_misses_show(struct ext4_attr *a, | ||
| 2376 | struct ext4_sb_info *sbi, char *buf) | ||
| 2377 | { | ||
| 2378 | return snprintf(buf, PAGE_SIZE, "%lu\n", sbi->extent_cache_misses); | ||
| 2379 | } | ||
| 2380 | |||
| 2381 | static ssize_t inode_readahead_blks_store(struct ext4_attr *a, | 2367 | static ssize_t inode_readahead_blks_store(struct ext4_attr *a, |
| 2382 | struct ext4_sb_info *sbi, | 2368 | struct ext4_sb_info *sbi, |
| 2383 | const char *buf, size_t count) | 2369 | const char *buf, size_t count) |
| @@ -2435,8 +2421,6 @@ static struct ext4_attr ext4_attr_##name = __ATTR(name, mode, show, store) | |||
| 2435 | EXT4_RO_ATTR(delayed_allocation_blocks); | 2421 | EXT4_RO_ATTR(delayed_allocation_blocks); |
| 2436 | EXT4_RO_ATTR(session_write_kbytes); | 2422 | EXT4_RO_ATTR(session_write_kbytes); |
| 2437 | EXT4_RO_ATTR(lifetime_write_kbytes); | 2423 | EXT4_RO_ATTR(lifetime_write_kbytes); |
| 2438 | EXT4_RO_ATTR(extent_cache_hits); | ||
| 2439 | EXT4_RO_ATTR(extent_cache_misses); | ||
| 2440 | EXT4_ATTR_OFFSET(inode_readahead_blks, 0644, sbi_ui_show, | 2424 | EXT4_ATTR_OFFSET(inode_readahead_blks, 0644, sbi_ui_show, |
| 2441 | inode_readahead_blks_store, s_inode_readahead_blks); | 2425 | inode_readahead_blks_store, s_inode_readahead_blks); |
| 2442 | EXT4_RW_ATTR_SBI_UI(inode_goal, s_inode_goal); | 2426 | EXT4_RW_ATTR_SBI_UI(inode_goal, s_inode_goal); |
| @@ -2452,8 +2436,6 @@ static struct attribute *ext4_attrs[] = { | |||
| 2452 | ATTR_LIST(delayed_allocation_blocks), | 2436 | ATTR_LIST(delayed_allocation_blocks), |
| 2453 | ATTR_LIST(session_write_kbytes), | 2437 | ATTR_LIST(session_write_kbytes), |
| 2454 | ATTR_LIST(lifetime_write_kbytes), | 2438 | ATTR_LIST(lifetime_write_kbytes), |
| 2455 | ATTR_LIST(extent_cache_hits), | ||
| 2456 | ATTR_LIST(extent_cache_misses), | ||
| 2457 | ATTR_LIST(inode_readahead_blks), | 2439 | ATTR_LIST(inode_readahead_blks), |
| 2458 | ATTR_LIST(inode_goal), | 2440 | ATTR_LIST(inode_goal), |
| 2459 | ATTR_LIST(mb_stats), | 2441 | ATTR_LIST(mb_stats), |
diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c index 206632887bb4..df5ac048dc74 100644 --- a/fs/fuse/dir.c +++ b/fs/fuse/dir.c | |||
| @@ -387,9 +387,6 @@ static int fuse_create_open(struct inode *dir, struct dentry *entry, | |||
| 387 | if (fc->no_create) | 387 | if (fc->no_create) |
| 388 | return -ENOSYS; | 388 | return -ENOSYS; |
| 389 | 389 | ||
| 390 | if (flags & O_DIRECT) | ||
| 391 | return -EINVAL; | ||
| 392 | |||
| 393 | forget = fuse_alloc_forget(); | 390 | forget = fuse_alloc_forget(); |
| 394 | if (!forget) | 391 | if (!forget) |
| 395 | return -ENOMEM; | 392 | return -ENOMEM; |
| @@ -644,13 +641,12 @@ static int fuse_unlink(struct inode *dir, struct dentry *entry) | |||
| 644 | fuse_put_request(fc, req); | 641 | fuse_put_request(fc, req); |
| 645 | if (!err) { | 642 | if (!err) { |
| 646 | struct inode *inode = entry->d_inode; | 643 | struct inode *inode = entry->d_inode; |
| 644 | struct fuse_inode *fi = get_fuse_inode(inode); | ||
| 647 | 645 | ||
| 648 | /* | 646 | spin_lock(&fc->lock); |
| 649 | * Set nlink to zero so the inode can be cleared, if the inode | 647 | fi->attr_version = ++fc->attr_version; |
| 650 | * does have more links this will be discovered at the next | 648 | drop_nlink(inode); |
| 651 | * lookup/getattr. | 649 | spin_unlock(&fc->lock); |
| 652 | */ | ||
| 653 | clear_nlink(inode); | ||
| 654 | fuse_invalidate_attr(inode); | 650 | fuse_invalidate_attr(inode); |
| 655 | fuse_invalidate_attr(dir); | 651 | fuse_invalidate_attr(dir); |
| 656 | fuse_invalidate_entry_cache(entry); | 652 | fuse_invalidate_entry_cache(entry); |
| @@ -762,8 +758,17 @@ static int fuse_link(struct dentry *entry, struct inode *newdir, | |||
| 762 | will reflect changes in the backing inode (link count, | 758 | will reflect changes in the backing inode (link count, |
| 763 | etc.) | 759 | etc.) |
| 764 | */ | 760 | */ |
| 765 | if (!err || err == -EINTR) | 761 | if (!err) { |
| 762 | struct fuse_inode *fi = get_fuse_inode(inode); | ||
| 763 | |||
| 764 | spin_lock(&fc->lock); | ||
| 765 | fi->attr_version = ++fc->attr_version; | ||
| 766 | inc_nlink(inode); | ||
| 767 | spin_unlock(&fc->lock); | ||
| 768 | fuse_invalidate_attr(inode); | ||
| 769 | } else if (err == -EINTR) { | ||
| 766 | fuse_invalidate_attr(inode); | 770 | fuse_invalidate_attr(inode); |
| 771 | } | ||
| 767 | return err; | 772 | return err; |
| 768 | } | 773 | } |
| 769 | 774 | ||
diff --git a/fs/fuse/file.c b/fs/fuse/file.c index a841868bf9ce..504e61b7fd75 100644 --- a/fs/fuse/file.c +++ b/fs/fuse/file.c | |||
| @@ -194,10 +194,6 @@ int fuse_open_common(struct inode *inode, struct file *file, bool isdir) | |||
| 194 | struct fuse_conn *fc = get_fuse_conn(inode); | 194 | struct fuse_conn *fc = get_fuse_conn(inode); |
| 195 | int err; | 195 | int err; |
| 196 | 196 | ||
| 197 | /* VFS checks this, but only _after_ ->open() */ | ||
| 198 | if (file->f_flags & O_DIRECT) | ||
| 199 | return -EINVAL; | ||
| 200 | |||
| 201 | err = generic_file_open(inode, file); | 197 | err = generic_file_open(inode, file); |
| 202 | if (err) | 198 | if (err) |
| 203 | return err; | 199 | return err; |
| @@ -932,17 +928,23 @@ static ssize_t fuse_file_aio_write(struct kiocb *iocb, const struct iovec *iov, | |||
| 932 | struct file *file = iocb->ki_filp; | 928 | struct file *file = iocb->ki_filp; |
| 933 | struct address_space *mapping = file->f_mapping; | 929 | struct address_space *mapping = file->f_mapping; |
| 934 | size_t count = 0; | 930 | size_t count = 0; |
| 931 | size_t ocount = 0; | ||
| 935 | ssize_t written = 0; | 932 | ssize_t written = 0; |
| 933 | ssize_t written_buffered = 0; | ||
| 936 | struct inode *inode = mapping->host; | 934 | struct inode *inode = mapping->host; |
| 937 | ssize_t err; | 935 | ssize_t err; |
| 938 | struct iov_iter i; | 936 | struct iov_iter i; |
| 937 | loff_t endbyte = 0; | ||
| 939 | 938 | ||
| 940 | WARN_ON(iocb->ki_pos != pos); | 939 | WARN_ON(iocb->ki_pos != pos); |
| 941 | 940 | ||
| 942 | err = generic_segment_checks(iov, &nr_segs, &count, VERIFY_READ); | 941 | ocount = 0; |
| 942 | err = generic_segment_checks(iov, &nr_segs, &ocount, VERIFY_READ); | ||
| 943 | if (err) | 943 | if (err) |
| 944 | return err; | 944 | return err; |
| 945 | 945 | ||
| 946 | count = ocount; | ||
| 947 | |||
| 946 | mutex_lock(&inode->i_mutex); | 948 | mutex_lock(&inode->i_mutex); |
| 947 | vfs_check_frozen(inode->i_sb, SB_FREEZE_WRITE); | 949 | vfs_check_frozen(inode->i_sb, SB_FREEZE_WRITE); |
| 948 | 950 | ||
| @@ -962,11 +964,41 @@ static ssize_t fuse_file_aio_write(struct kiocb *iocb, const struct iovec *iov, | |||
| 962 | 964 | ||
| 963 | file_update_time(file); | 965 | file_update_time(file); |
| 964 | 966 | ||
| 965 | iov_iter_init(&i, iov, nr_segs, count, 0); | 967 | if (file->f_flags & O_DIRECT) { |
| 966 | written = fuse_perform_write(file, mapping, &i, pos); | 968 | written = generic_file_direct_write(iocb, iov, &nr_segs, |
| 967 | if (written >= 0) | 969 | pos, &iocb->ki_pos, |
| 968 | iocb->ki_pos = pos + written; | 970 | count, ocount); |
| 971 | if (written < 0 || written == count) | ||
| 972 | goto out; | ||
| 973 | |||
| 974 | pos += written; | ||
| 975 | count -= written; | ||
| 969 | 976 | ||
| 977 | iov_iter_init(&i, iov, nr_segs, count, written); | ||
| 978 | written_buffered = fuse_perform_write(file, mapping, &i, pos); | ||
| 979 | if (written_buffered < 0) { | ||
| 980 | err = written_buffered; | ||
| 981 | goto out; | ||
| 982 | } | ||
| 983 | endbyte = pos + written_buffered - 1; | ||
| 984 | |||
| 985 | err = filemap_write_and_wait_range(file->f_mapping, pos, | ||
| 986 | endbyte); | ||
| 987 | if (err) | ||
| 988 | goto out; | ||
| 989 | |||
| 990 | invalidate_mapping_pages(file->f_mapping, | ||
| 991 | pos >> PAGE_CACHE_SHIFT, | ||
| 992 | endbyte >> PAGE_CACHE_SHIFT); | ||
| 993 | |||
| 994 | written += written_buffered; | ||
| 995 | iocb->ki_pos = pos + written_buffered; | ||
| 996 | } else { | ||
| 997 | iov_iter_init(&i, iov, nr_segs, count, 0); | ||
| 998 | written = fuse_perform_write(file, mapping, &i, pos); | ||
| 999 | if (written >= 0) | ||
| 1000 | iocb->ki_pos = pos + written; | ||
| 1001 | } | ||
| 970 | out: | 1002 | out: |
| 971 | current->backing_dev_info = NULL; | 1003 | current->backing_dev_info = NULL; |
| 972 | mutex_unlock(&inode->i_mutex); | 1004 | mutex_unlock(&inode->i_mutex); |
| @@ -1101,30 +1133,41 @@ static ssize_t fuse_direct_read(struct file *file, char __user *buf, | |||
| 1101 | return res; | 1133 | return res; |
| 1102 | } | 1134 | } |
| 1103 | 1135 | ||
| 1104 | static ssize_t fuse_direct_write(struct file *file, const char __user *buf, | 1136 | static ssize_t __fuse_direct_write(struct file *file, const char __user *buf, |
| 1105 | size_t count, loff_t *ppos) | 1137 | size_t count, loff_t *ppos) |
| 1106 | { | 1138 | { |
| 1107 | struct inode *inode = file->f_path.dentry->d_inode; | 1139 | struct inode *inode = file->f_path.dentry->d_inode; |
| 1108 | ssize_t res; | 1140 | ssize_t res; |
| 1109 | 1141 | ||
| 1110 | if (is_bad_inode(inode)) | ||
| 1111 | return -EIO; | ||
| 1112 | |||
| 1113 | /* Don't allow parallel writes to the same file */ | ||
| 1114 | mutex_lock(&inode->i_mutex); | ||
| 1115 | res = generic_write_checks(file, ppos, &count, 0); | 1142 | res = generic_write_checks(file, ppos, &count, 0); |
| 1116 | if (!res) { | 1143 | if (!res) { |
| 1117 | res = fuse_direct_io(file, buf, count, ppos, 1); | 1144 | res = fuse_direct_io(file, buf, count, ppos, 1); |
| 1118 | if (res > 0) | 1145 | if (res > 0) |
| 1119 | fuse_write_update_size(inode, *ppos); | 1146 | fuse_write_update_size(inode, *ppos); |
| 1120 | } | 1147 | } |
| 1121 | mutex_unlock(&inode->i_mutex); | ||
| 1122 | 1148 | ||
| 1123 | fuse_invalidate_attr(inode); | 1149 | fuse_invalidate_attr(inode); |
| 1124 | 1150 | ||
| 1125 | return res; | 1151 | return res; |
| 1126 | } | 1152 | } |
| 1127 | 1153 | ||
| 1154 | static ssize_t fuse_direct_write(struct file *file, const char __user *buf, | ||
| 1155 | size_t count, loff_t *ppos) | ||
| 1156 | { | ||
| 1157 | struct inode *inode = file->f_path.dentry->d_inode; | ||
| 1158 | ssize_t res; | ||
| 1159 | |||
| 1160 | if (is_bad_inode(inode)) | ||
| 1161 | return -EIO; | ||
| 1162 | |||
| 1163 | /* Don't allow parallel writes to the same file */ | ||
| 1164 | mutex_lock(&inode->i_mutex); | ||
| 1165 | res = __fuse_direct_write(file, buf, count, ppos); | ||
| 1166 | mutex_unlock(&inode->i_mutex); | ||
| 1167 | |||
| 1168 | return res; | ||
| 1169 | } | ||
| 1170 | |||
| 1128 | static void fuse_writepage_free(struct fuse_conn *fc, struct fuse_req *req) | 1171 | static void fuse_writepage_free(struct fuse_conn *fc, struct fuse_req *req) |
| 1129 | { | 1172 | { |
| 1130 | __free_page(req->pages[0]); | 1173 | __free_page(req->pages[0]); |
| @@ -2077,6 +2120,57 @@ int fuse_notify_poll_wakeup(struct fuse_conn *fc, | |||
| 2077 | return 0; | 2120 | return 0; |
| 2078 | } | 2121 | } |
| 2079 | 2122 | ||
| 2123 | static ssize_t fuse_loop_dio(struct file *filp, const struct iovec *iov, | ||
| 2124 | unsigned long nr_segs, loff_t *ppos, int rw) | ||
| 2125 | { | ||
| 2126 | const struct iovec *vector = iov; | ||
| 2127 | ssize_t ret = 0; | ||
| 2128 | |||
| 2129 | while (nr_segs > 0) { | ||
| 2130 | void __user *base; | ||
| 2131 | size_t len; | ||
| 2132 | ssize_t nr; | ||
| 2133 | |||
| 2134 | base = vector->iov_base; | ||
| 2135 | len = vector->iov_len; | ||
| 2136 | vector++; | ||
| 2137 | nr_segs--; | ||
| 2138 | |||
| 2139 | if (rw == WRITE) | ||
| 2140 | nr = __fuse_direct_write(filp, base, len, ppos); | ||
| 2141 | else | ||
| 2142 | nr = fuse_direct_read(filp, base, len, ppos); | ||
| 2143 | |||
| 2144 | if (nr < 0) { | ||
| 2145 | if (!ret) | ||
| 2146 | ret = nr; | ||
| 2147 | break; | ||
| 2148 | } | ||
| 2149 | ret += nr; | ||
| 2150 | if (nr != len) | ||
| 2151 | break; | ||
| 2152 | } | ||
| 2153 | |||
| 2154 | return ret; | ||
| 2155 | } | ||
| 2156 | |||
| 2157 | |||
| 2158 | static ssize_t | ||
| 2159 | fuse_direct_IO(int rw, struct kiocb *iocb, const struct iovec *iov, | ||
| 2160 | loff_t offset, unsigned long nr_segs) | ||
| 2161 | { | ||
| 2162 | ssize_t ret = 0; | ||
| 2163 | struct file *file = NULL; | ||
| 2164 | loff_t pos = 0; | ||
| 2165 | |||
| 2166 | file = iocb->ki_filp; | ||
| 2167 | pos = offset; | ||
| 2168 | |||
| 2169 | ret = fuse_loop_dio(file, iov, nr_segs, &pos, rw); | ||
| 2170 | |||
| 2171 | return ret; | ||
| 2172 | } | ||
| 2173 | |||
| 2080 | static const struct file_operations fuse_file_operations = { | 2174 | static const struct file_operations fuse_file_operations = { |
| 2081 | .llseek = fuse_file_llseek, | 2175 | .llseek = fuse_file_llseek, |
| 2082 | .read = do_sync_read, | 2176 | .read = do_sync_read, |
| @@ -2120,6 +2214,7 @@ static const struct address_space_operations fuse_file_aops = { | |||
| 2120 | .readpages = fuse_readpages, | 2214 | .readpages = fuse_readpages, |
| 2121 | .set_page_dirty = __set_page_dirty_nobuffers, | 2215 | .set_page_dirty = __set_page_dirty_nobuffers, |
| 2122 | .bmap = fuse_bmap, | 2216 | .bmap = fuse_bmap, |
| 2217 | .direct_IO = fuse_direct_IO, | ||
| 2123 | }; | 2218 | }; |
| 2124 | 2219 | ||
| 2125 | void fuse_init_file_inode(struct inode *inode) | 2220 | void fuse_init_file_inode(struct inode *inode) |
diff --git a/fs/fuse/inode.c b/fs/fuse/inode.c index 4aec5995867e..26783eb2b1fc 100644 --- a/fs/fuse/inode.c +++ b/fs/fuse/inode.c | |||
| @@ -947,6 +947,7 @@ static int fuse_fill_super(struct super_block *sb, void *data, int silent) | |||
| 947 | sb->s_magic = FUSE_SUPER_MAGIC; | 947 | sb->s_magic = FUSE_SUPER_MAGIC; |
| 948 | sb->s_op = &fuse_super_operations; | 948 | sb->s_op = &fuse_super_operations; |
| 949 | sb->s_maxbytes = MAX_LFS_FILESIZE; | 949 | sb->s_maxbytes = MAX_LFS_FILESIZE; |
| 950 | sb->s_time_gran = 1; | ||
| 950 | sb->s_export_op = &fuse_export_operations; | 951 | sb->s_export_op = &fuse_export_operations; |
| 951 | 952 | ||
| 952 | file = fget(d.fd); | 953 | file = fget(d.fd); |
diff --git a/fs/lockd/clnt4xdr.c b/fs/lockd/clnt4xdr.c index 3ddcbb1c0a43..13ad1539fbf2 100644 --- a/fs/lockd/clnt4xdr.c +++ b/fs/lockd/clnt4xdr.c | |||
| @@ -241,7 +241,7 @@ static int decode_nlm4_stat(struct xdr_stream *xdr, __be32 *stat) | |||
| 241 | p = xdr_inline_decode(xdr, 4); | 241 | p = xdr_inline_decode(xdr, 4); |
| 242 | if (unlikely(p == NULL)) | 242 | if (unlikely(p == NULL)) |
| 243 | goto out_overflow; | 243 | goto out_overflow; |
| 244 | if (unlikely(*p > nlm4_failed)) | 244 | if (unlikely(ntohl(*p) > ntohl(nlm4_failed))) |
| 245 | goto out_bad_xdr; | 245 | goto out_bad_xdr; |
| 246 | *stat = *p; | 246 | *stat = *p; |
| 247 | return 0; | 247 | return 0; |
diff --git a/fs/lockd/clntxdr.c b/fs/lockd/clntxdr.c index 3d35e3e80c1c..d269ada7670e 100644 --- a/fs/lockd/clntxdr.c +++ b/fs/lockd/clntxdr.c | |||
| @@ -236,7 +236,7 @@ static int decode_nlm_stat(struct xdr_stream *xdr, | |||
| 236 | p = xdr_inline_decode(xdr, 4); | 236 | p = xdr_inline_decode(xdr, 4); |
| 237 | if (unlikely(p == NULL)) | 237 | if (unlikely(p == NULL)) |
| 238 | goto out_overflow; | 238 | goto out_overflow; |
| 239 | if (unlikely(*p > nlm_lck_denied_grace_period)) | 239 | if (unlikely(ntohl(*p) > ntohl(nlm_lck_denied_grace_period))) |
| 240 | goto out_enum; | 240 | goto out_enum; |
| 241 | *stat = *p; | 241 | *stat = *p; |
| 242 | return 0; | 242 | return 0; |
diff --git a/fs/nfsd/nfs3xdr.c b/fs/nfsd/nfs3xdr.c index 08c6e36ab2eb..43f46cd9edea 100644 --- a/fs/nfsd/nfs3xdr.c +++ b/fs/nfsd/nfs3xdr.c | |||
| @@ -803,13 +803,13 @@ encode_entry_baggage(struct nfsd3_readdirres *cd, __be32 *p, const char *name, | |||
| 803 | return p; | 803 | return p; |
| 804 | } | 804 | } |
| 805 | 805 | ||
| 806 | static int | 806 | static __be32 |
| 807 | compose_entry_fh(struct nfsd3_readdirres *cd, struct svc_fh *fhp, | 807 | compose_entry_fh(struct nfsd3_readdirres *cd, struct svc_fh *fhp, |
| 808 | const char *name, int namlen) | 808 | const char *name, int namlen) |
| 809 | { | 809 | { |
| 810 | struct svc_export *exp; | 810 | struct svc_export *exp; |
| 811 | struct dentry *dparent, *dchild; | 811 | struct dentry *dparent, *dchild; |
| 812 | int rv = 0; | 812 | __be32 rv = nfserr_noent; |
| 813 | 813 | ||
| 814 | dparent = cd->fh.fh_dentry; | 814 | dparent = cd->fh.fh_dentry; |
| 815 | exp = cd->fh.fh_export; | 815 | exp = cd->fh.fh_export; |
| @@ -817,26 +817,20 @@ compose_entry_fh(struct nfsd3_readdirres *cd, struct svc_fh *fhp, | |||
| 817 | if (isdotent(name, namlen)) { | 817 | if (isdotent(name, namlen)) { |
| 818 | if (namlen == 2) { | 818 | if (namlen == 2) { |
| 819 | dchild = dget_parent(dparent); | 819 | dchild = dget_parent(dparent); |
| 820 | if (dchild == dparent) { | 820 | /* filesystem root - cannot return filehandle for ".." */ |
| 821 | /* filesystem root - cannot return filehandle for ".." */ | 821 | if (dchild == dparent) |
| 822 | dput(dchild); | 822 | goto out; |
| 823 | return -ENOENT; | ||
| 824 | } | ||
| 825 | } else | 823 | } else |
| 826 | dchild = dget(dparent); | 824 | dchild = dget(dparent); |
| 827 | } else | 825 | } else |
| 828 | dchild = lookup_one_len(name, dparent, namlen); | 826 | dchild = lookup_one_len(name, dparent, namlen); |
| 829 | if (IS_ERR(dchild)) | 827 | if (IS_ERR(dchild)) |
| 830 | return -ENOENT; | 828 | return rv; |
| 831 | rv = -ENOENT; | ||
| 832 | if (d_mountpoint(dchild)) | 829 | if (d_mountpoint(dchild)) |
| 833 | goto out; | 830 | goto out; |
| 834 | rv = fh_compose(fhp, exp, dchild, &cd->fh); | ||
| 835 | if (rv) | ||
| 836 | goto out; | ||
| 837 | if (!dchild->d_inode) | 831 | if (!dchild->d_inode) |
| 838 | goto out; | 832 | goto out; |
| 839 | rv = 0; | 833 | rv = fh_compose(fhp, exp, dchild, &cd->fh); |
| 840 | out: | 834 | out: |
| 841 | dput(dchild); | 835 | dput(dchild); |
| 842 | return rv; | 836 | return rv; |
| @@ -845,7 +839,7 @@ out: | |||
| 845 | static __be32 *encode_entryplus_baggage(struct nfsd3_readdirres *cd, __be32 *p, const char *name, int namlen) | 839 | static __be32 *encode_entryplus_baggage(struct nfsd3_readdirres *cd, __be32 *p, const char *name, int namlen) |
| 846 | { | 840 | { |
| 847 | struct svc_fh fh; | 841 | struct svc_fh fh; |
| 848 | int err; | 842 | __be32 err; |
| 849 | 843 | ||
| 850 | fh_init(&fh, NFS3_FHSIZE); | 844 | fh_init(&fh, NFS3_FHSIZE); |
| 851 | err = compose_entry_fh(cd, &fh, name, namlen); | 845 | err = compose_entry_fh(cd, &fh, name, namlen); |
diff --git a/fs/nfsd/nfs4proc.c b/fs/nfsd/nfs4proc.c index 2ed14dfd00a2..987e719fbae8 100644 --- a/fs/nfsd/nfs4proc.c +++ b/fs/nfsd/nfs4proc.c | |||
| @@ -235,17 +235,17 @@ do_open_lookup(struct svc_rqst *rqstp, struct svc_fh *current_fh, struct nfsd4_o | |||
| 235 | */ | 235 | */ |
| 236 | if (open->op_createmode == NFS4_CREATE_EXCLUSIVE && status == 0) | 236 | if (open->op_createmode == NFS4_CREATE_EXCLUSIVE && status == 0) |
| 237 | open->op_bmval[1] = (FATTR4_WORD1_TIME_ACCESS | | 237 | open->op_bmval[1] = (FATTR4_WORD1_TIME_ACCESS | |
| 238 | FATTR4_WORD1_TIME_MODIFY); | 238 | FATTR4_WORD1_TIME_MODIFY); |
| 239 | } else { | 239 | } else { |
| 240 | status = nfsd_lookup(rqstp, current_fh, | 240 | status = nfsd_lookup(rqstp, current_fh, |
| 241 | open->op_fname.data, open->op_fname.len, resfh); | 241 | open->op_fname.data, open->op_fname.len, resfh); |
| 242 | fh_unlock(current_fh); | 242 | fh_unlock(current_fh); |
| 243 | if (status) | ||
| 244 | goto out; | ||
| 245 | status = nfsd_check_obj_isreg(resfh); | ||
| 246 | } | 243 | } |
| 247 | if (status) | 244 | if (status) |
| 248 | goto out; | 245 | goto out; |
| 246 | status = nfsd_check_obj_isreg(resfh); | ||
| 247 | if (status) | ||
| 248 | goto out; | ||
| 249 | 249 | ||
| 250 | if (is_create_with_attrs(open) && open->op_acl != NULL) | 250 | if (is_create_with_attrs(open) && open->op_acl != NULL) |
| 251 | do_set_nfs4_acl(rqstp, resfh, open->op_acl, open->op_bmval); | 251 | do_set_nfs4_acl(rqstp, resfh, open->op_acl, open->op_bmval); |
| @@ -841,6 +841,7 @@ nfsd4_setattr(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate, | |||
| 841 | struct nfsd4_setattr *setattr) | 841 | struct nfsd4_setattr *setattr) |
| 842 | { | 842 | { |
| 843 | __be32 status = nfs_ok; | 843 | __be32 status = nfs_ok; |
| 844 | int err; | ||
| 844 | 845 | ||
| 845 | if (setattr->sa_iattr.ia_valid & ATTR_SIZE) { | 846 | if (setattr->sa_iattr.ia_valid & ATTR_SIZE) { |
| 846 | nfs4_lock_state(); | 847 | nfs4_lock_state(); |
| @@ -852,9 +853,9 @@ nfsd4_setattr(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate, | |||
| 852 | return status; | 853 | return status; |
| 853 | } | 854 | } |
| 854 | } | 855 | } |
| 855 | status = fh_want_write(&cstate->current_fh); | 856 | err = fh_want_write(&cstate->current_fh); |
| 856 | if (status) | 857 | if (err) |
| 857 | return status; | 858 | return nfserrno(err); |
| 858 | status = nfs_ok; | 859 | status = nfs_ok; |
| 859 | 860 | ||
| 860 | status = check_attr_support(rqstp, cstate, setattr->sa_bmval, | 861 | status = check_attr_support(rqstp, cstate, setattr->sa_bmval, |
diff --git a/fs/nfsd/nfs4state.c b/fs/nfsd/nfs4state.c index 1841f8bf845e..7f71c69cdcdf 100644 --- a/fs/nfsd/nfs4state.c +++ b/fs/nfsd/nfs4state.c | |||
| @@ -4211,16 +4211,14 @@ out: | |||
| 4211 | * vfs_test_lock. (Arguably perhaps test_lock should be done with an | 4211 | * vfs_test_lock. (Arguably perhaps test_lock should be done with an |
| 4212 | * inode operation.) | 4212 | * inode operation.) |
| 4213 | */ | 4213 | */ |
| 4214 | static int nfsd_test_lock(struct svc_rqst *rqstp, struct svc_fh *fhp, struct file_lock *lock) | 4214 | static __be32 nfsd_test_lock(struct svc_rqst *rqstp, struct svc_fh *fhp, struct file_lock *lock) |
| 4215 | { | 4215 | { |
| 4216 | struct file *file; | 4216 | struct file *file; |
| 4217 | int err; | 4217 | __be32 err = nfsd_open(rqstp, fhp, S_IFREG, NFSD_MAY_READ, &file); |
| 4218 | 4218 | if (!err) { | |
| 4219 | err = nfsd_open(rqstp, fhp, S_IFREG, NFSD_MAY_READ, &file); | 4219 | err = nfserrno(vfs_test_lock(file, lock)); |
| 4220 | if (err) | 4220 | nfsd_close(file); |
| 4221 | return err; | 4221 | } |
| 4222 | err = vfs_test_lock(file, lock); | ||
| 4223 | nfsd_close(file); | ||
| 4224 | return err; | 4222 | return err; |
| 4225 | } | 4223 | } |
| 4226 | 4224 | ||
| @@ -4234,7 +4232,6 @@ nfsd4_lockt(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate, | |||
| 4234 | struct inode *inode; | 4232 | struct inode *inode; |
| 4235 | struct file_lock file_lock; | 4233 | struct file_lock file_lock; |
| 4236 | struct nfs4_lockowner *lo; | 4234 | struct nfs4_lockowner *lo; |
| 4237 | int error; | ||
| 4238 | __be32 status; | 4235 | __be32 status; |
| 4239 | 4236 | ||
| 4240 | if (locks_in_grace()) | 4237 | if (locks_in_grace()) |
| @@ -4280,12 +4277,10 @@ nfsd4_lockt(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate, | |||
| 4280 | 4277 | ||
| 4281 | nfs4_transform_lock_offset(&file_lock); | 4278 | nfs4_transform_lock_offset(&file_lock); |
| 4282 | 4279 | ||
| 4283 | status = nfs_ok; | 4280 | status = nfsd_test_lock(rqstp, &cstate->current_fh, &file_lock); |
| 4284 | error = nfsd_test_lock(rqstp, &cstate->current_fh, &file_lock); | 4281 | if (status) |
| 4285 | if (error) { | ||
| 4286 | status = nfserrno(error); | ||
| 4287 | goto out; | 4282 | goto out; |
| 4288 | } | 4283 | |
| 4289 | if (file_lock.fl_type != F_UNLCK) { | 4284 | if (file_lock.fl_type != F_UNLCK) { |
| 4290 | status = nfserr_denied; | 4285 | status = nfserr_denied; |
| 4291 | nfs4_set_lock_denied(&file_lock, &lockt->lt_denied); | 4286 | nfs4_set_lock_denied(&file_lock, &lockt->lt_denied); |
diff --git a/fs/nfsd/nfs4xdr.c b/fs/nfsd/nfs4xdr.c index bcd8904ab1e3..74c00bc92b9a 100644 --- a/fs/nfsd/nfs4xdr.c +++ b/fs/nfsd/nfs4xdr.c | |||
| @@ -1392,7 +1392,7 @@ nfsd4_decode_test_stateid(struct nfsd4_compoundargs *argp, struct nfsd4_test_sta | |||
| 1392 | for (i = 0; i < test_stateid->ts_num_ids; i++) { | 1392 | for (i = 0; i < test_stateid->ts_num_ids; i++) { |
| 1393 | stateid = kmalloc(sizeof(struct nfsd4_test_stateid_id), GFP_KERNEL); | 1393 | stateid = kmalloc(sizeof(struct nfsd4_test_stateid_id), GFP_KERNEL); |
| 1394 | if (!stateid) { | 1394 | if (!stateid) { |
| 1395 | status = PTR_ERR(stateid); | 1395 | status = nfserrno(-ENOMEM); |
| 1396 | goto out; | 1396 | goto out; |
| 1397 | } | 1397 | } |
| 1398 | 1398 | ||
| @@ -3410,7 +3410,7 @@ nfsd4_encode_test_stateid(struct nfsd4_compoundres *resp, int nfserr, | |||
| 3410 | *p++ = htonl(test_stateid->ts_num_ids); | 3410 | *p++ = htonl(test_stateid->ts_num_ids); |
| 3411 | 3411 | ||
| 3412 | list_for_each_entry_safe(stateid, next, &test_stateid->ts_stateid_list, ts_id_list) { | 3412 | list_for_each_entry_safe(stateid, next, &test_stateid->ts_stateid_list, ts_id_list) { |
| 3413 | *p++ = htonl(stateid->ts_id_status); | 3413 | *p++ = stateid->ts_id_status; |
| 3414 | } | 3414 | } |
| 3415 | 3415 | ||
| 3416 | ADJUST_ARGS(); | 3416 | ADJUST_ARGS(); |
diff --git a/fs/nfsd/vfs.c b/fs/nfsd/vfs.c index 296d671654d6..568666156ea4 100644 --- a/fs/nfsd/vfs.c +++ b/fs/nfsd/vfs.c | |||
| @@ -1458,7 +1458,7 @@ do_nfsd_create(struct svc_rqst *rqstp, struct svc_fh *fhp, | |||
| 1458 | switch (createmode) { | 1458 | switch (createmode) { |
| 1459 | case NFS3_CREATE_UNCHECKED: | 1459 | case NFS3_CREATE_UNCHECKED: |
| 1460 | if (! S_ISREG(dchild->d_inode->i_mode)) | 1460 | if (! S_ISREG(dchild->d_inode->i_mode)) |
| 1461 | err = nfserr_exist; | 1461 | goto out; |
| 1462 | else if (truncp) { | 1462 | else if (truncp) { |
| 1463 | /* in nfsv4, we need to treat this case a little | 1463 | /* in nfsv4, we need to treat this case a little |
| 1464 | * differently. we don't want to truncate the | 1464 | * differently. we don't want to truncate the |
diff --git a/fs/ocfs2/alloc.c b/fs/ocfs2/alloc.c index 3165aebb43c8..31b9463fba1f 100644 --- a/fs/ocfs2/alloc.c +++ b/fs/ocfs2/alloc.c | |||
| @@ -1134,7 +1134,7 @@ static int ocfs2_adjust_rightmost_branch(handle_t *handle, | |||
| 1134 | } | 1134 | } |
| 1135 | 1135 | ||
| 1136 | el = path_leaf_el(path); | 1136 | el = path_leaf_el(path); |
| 1137 | rec = &el->l_recs[le32_to_cpu(el->l_next_free_rec) - 1]; | 1137 | rec = &el->l_recs[le16_to_cpu(el->l_next_free_rec) - 1]; |
| 1138 | 1138 | ||
| 1139 | ocfs2_adjust_rightmost_records(handle, et, path, rec); | 1139 | ocfs2_adjust_rightmost_records(handle, et, path, rec); |
| 1140 | 1140 | ||
diff --git a/fs/ocfs2/refcounttree.c b/fs/ocfs2/refcounttree.c index cf7823382664..9f32d7cbb7a3 100644 --- a/fs/ocfs2/refcounttree.c +++ b/fs/ocfs2/refcounttree.c | |||
| @@ -1036,14 +1036,14 @@ static int ocfs2_get_refcount_cpos_end(struct ocfs2_caching_info *ci, | |||
| 1036 | 1036 | ||
| 1037 | tmp_el = left_path->p_node[subtree_root].el; | 1037 | tmp_el = left_path->p_node[subtree_root].el; |
| 1038 | blkno = left_path->p_node[subtree_root+1].bh->b_blocknr; | 1038 | blkno = left_path->p_node[subtree_root+1].bh->b_blocknr; |
| 1039 | for (i = 0; i < le32_to_cpu(tmp_el->l_next_free_rec); i++) { | 1039 | for (i = 0; i < le16_to_cpu(tmp_el->l_next_free_rec); i++) { |
| 1040 | if (le64_to_cpu(tmp_el->l_recs[i].e_blkno) == blkno) { | 1040 | if (le64_to_cpu(tmp_el->l_recs[i].e_blkno) == blkno) { |
| 1041 | *cpos_end = le32_to_cpu(tmp_el->l_recs[i+1].e_cpos); | 1041 | *cpos_end = le32_to_cpu(tmp_el->l_recs[i+1].e_cpos); |
| 1042 | break; | 1042 | break; |
| 1043 | } | 1043 | } |
| 1044 | } | 1044 | } |
| 1045 | 1045 | ||
| 1046 | BUG_ON(i == le32_to_cpu(tmp_el->l_next_free_rec)); | 1046 | BUG_ON(i == le16_to_cpu(tmp_el->l_next_free_rec)); |
| 1047 | 1047 | ||
| 1048 | out: | 1048 | out: |
| 1049 | ocfs2_free_path(left_path); | 1049 | ocfs2_free_path(left_path); |
| @@ -1468,7 +1468,7 @@ static int ocfs2_divide_leaf_refcount_block(struct buffer_head *ref_leaf_bh, | |||
| 1468 | 1468 | ||
| 1469 | trace_ocfs2_divide_leaf_refcount_block( | 1469 | trace_ocfs2_divide_leaf_refcount_block( |
| 1470 | (unsigned long long)ref_leaf_bh->b_blocknr, | 1470 | (unsigned long long)ref_leaf_bh->b_blocknr, |
| 1471 | le32_to_cpu(rl->rl_count), le32_to_cpu(rl->rl_used)); | 1471 | le16_to_cpu(rl->rl_count), le16_to_cpu(rl->rl_used)); |
| 1472 | 1472 | ||
| 1473 | /* | 1473 | /* |
| 1474 | * XXX: Improvement later. | 1474 | * XXX: Improvement later. |
| @@ -2411,7 +2411,7 @@ static int ocfs2_calc_refcount_meta_credits(struct super_block *sb, | |||
| 2411 | rb = (struct ocfs2_refcount_block *) | 2411 | rb = (struct ocfs2_refcount_block *) |
| 2412 | prev_bh->b_data; | 2412 | prev_bh->b_data; |
| 2413 | 2413 | ||
| 2414 | if (le64_to_cpu(rb->rf_records.rl_used) + | 2414 | if (le16_to_cpu(rb->rf_records.rl_used) + |
| 2415 | recs_add > | 2415 | recs_add > |
| 2416 | le16_to_cpu(rb->rf_records.rl_count)) | 2416 | le16_to_cpu(rb->rf_records.rl_count)) |
| 2417 | ref_blocks++; | 2417 | ref_blocks++; |
| @@ -2476,7 +2476,7 @@ static int ocfs2_calc_refcount_meta_credits(struct super_block *sb, | |||
| 2476 | if (prev_bh) { | 2476 | if (prev_bh) { |
| 2477 | rb = (struct ocfs2_refcount_block *)prev_bh->b_data; | 2477 | rb = (struct ocfs2_refcount_block *)prev_bh->b_data; |
| 2478 | 2478 | ||
| 2479 | if (le64_to_cpu(rb->rf_records.rl_used) + recs_add > | 2479 | if (le16_to_cpu(rb->rf_records.rl_used) + recs_add > |
| 2480 | le16_to_cpu(rb->rf_records.rl_count)) | 2480 | le16_to_cpu(rb->rf_records.rl_count)) |
| 2481 | ref_blocks++; | 2481 | ref_blocks++; |
| 2482 | 2482 | ||
| @@ -3629,7 +3629,7 @@ int ocfs2_refcounted_xattr_delete_need(struct inode *inode, | |||
| 3629 | * one will split a refcount rec, so totally we need | 3629 | * one will split a refcount rec, so totally we need |
| 3630 | * clusters * 2 new refcount rec. | 3630 | * clusters * 2 new refcount rec. |
| 3631 | */ | 3631 | */ |
| 3632 | if (le64_to_cpu(rb->rf_records.rl_used) + clusters * 2 > | 3632 | if (le16_to_cpu(rb->rf_records.rl_used) + clusters * 2 > |
| 3633 | le16_to_cpu(rb->rf_records.rl_count)) | 3633 | le16_to_cpu(rb->rf_records.rl_count)) |
| 3634 | ref_blocks++; | 3634 | ref_blocks++; |
| 3635 | 3635 | ||
diff --git a/fs/ocfs2/suballoc.c b/fs/ocfs2/suballoc.c index ba5d97e4a73e..f169da4624fd 100644 --- a/fs/ocfs2/suballoc.c +++ b/fs/ocfs2/suballoc.c | |||
| @@ -600,7 +600,7 @@ static void ocfs2_bg_alloc_cleanup(handle_t *handle, | |||
| 600 | ret = ocfs2_free_clusters(handle, cluster_ac->ac_inode, | 600 | ret = ocfs2_free_clusters(handle, cluster_ac->ac_inode, |
| 601 | cluster_ac->ac_bh, | 601 | cluster_ac->ac_bh, |
| 602 | le64_to_cpu(rec->e_blkno), | 602 | le64_to_cpu(rec->e_blkno), |
| 603 | le32_to_cpu(rec->e_leaf_clusters)); | 603 | le16_to_cpu(rec->e_leaf_clusters)); |
| 604 | if (ret) | 604 | if (ret) |
| 605 | mlog_errno(ret); | 605 | mlog_errno(ret); |
| 606 | /* Try all the clusters to free */ | 606 | /* Try all the clusters to free */ |
| @@ -1628,7 +1628,7 @@ static int ocfs2_bg_discontig_fix_by_rec(struct ocfs2_suballoc_result *res, | |||
| 1628 | { | 1628 | { |
| 1629 | unsigned int bpc = le16_to_cpu(cl->cl_bpc); | 1629 | unsigned int bpc = le16_to_cpu(cl->cl_bpc); |
| 1630 | unsigned int bitoff = le32_to_cpu(rec->e_cpos) * bpc; | 1630 | unsigned int bitoff = le32_to_cpu(rec->e_cpos) * bpc; |
| 1631 | unsigned int bitcount = le32_to_cpu(rec->e_leaf_clusters) * bpc; | 1631 | unsigned int bitcount = le16_to_cpu(rec->e_leaf_clusters) * bpc; |
| 1632 | 1632 | ||
| 1633 | if (res->sr_bit_offset < bitoff) | 1633 | if (res->sr_bit_offset < bitoff) |
| 1634 | return 0; | 1634 | return 0; |
diff --git a/fs/proc/stat.c b/fs/proc/stat.c index 6a0c62d6e442..64c3b3172367 100644 --- a/fs/proc/stat.c +++ b/fs/proc/stat.c | |||
| @@ -18,19 +18,39 @@ | |||
| 18 | #ifndef arch_irq_stat | 18 | #ifndef arch_irq_stat |
| 19 | #define arch_irq_stat() 0 | 19 | #define arch_irq_stat() 0 |
| 20 | #endif | 20 | #endif |
| 21 | #ifndef arch_idle_time | 21 | |
| 22 | #define arch_idle_time(cpu) 0 | 22 | #ifdef arch_idle_time |
| 23 | #endif | 23 | |
| 24 | static cputime64_t get_idle_time(int cpu) | ||
| 25 | { | ||
| 26 | cputime64_t idle; | ||
| 27 | |||
| 28 | idle = kcpustat_cpu(cpu).cpustat[CPUTIME_IDLE]; | ||
| 29 | if (cpu_online(cpu) && !nr_iowait_cpu(cpu)) | ||
| 30 | idle += arch_idle_time(cpu); | ||
| 31 | return idle; | ||
| 32 | } | ||
| 33 | |||
| 34 | static cputime64_t get_iowait_time(int cpu) | ||
| 35 | { | ||
| 36 | cputime64_t iowait; | ||
| 37 | |||
| 38 | iowait = kcpustat_cpu(cpu).cpustat[CPUTIME_IOWAIT]; | ||
| 39 | if (cpu_online(cpu) && nr_iowait_cpu(cpu)) | ||
| 40 | iowait += arch_idle_time(cpu); | ||
| 41 | return iowait; | ||
| 42 | } | ||
| 43 | |||
| 44 | #else | ||
| 24 | 45 | ||
| 25 | static u64 get_idle_time(int cpu) | 46 | static u64 get_idle_time(int cpu) |
| 26 | { | 47 | { |
| 27 | u64 idle, idle_time = get_cpu_idle_time_us(cpu, NULL); | 48 | u64 idle, idle_time = get_cpu_idle_time_us(cpu, NULL); |
| 28 | 49 | ||
| 29 | if (idle_time == -1ULL) { | 50 | if (idle_time == -1ULL) |
| 30 | /* !NO_HZ so we can rely on cpustat.idle */ | 51 | /* !NO_HZ so we can rely on cpustat.idle */ |
| 31 | idle = kcpustat_cpu(cpu).cpustat[CPUTIME_IDLE]; | 52 | idle = kcpustat_cpu(cpu).cpustat[CPUTIME_IDLE]; |
| 32 | idle += arch_idle_time(cpu); | 53 | else |
| 33 | } else | ||
| 34 | idle = usecs_to_cputime64(idle_time); | 54 | idle = usecs_to_cputime64(idle_time); |
| 35 | 55 | ||
| 36 | return idle; | 56 | return idle; |
| @@ -49,6 +69,8 @@ static u64 get_iowait_time(int cpu) | |||
| 49 | return iowait; | 69 | return iowait; |
| 50 | } | 70 | } |
| 51 | 71 | ||
| 72 | #endif | ||
| 73 | |||
| 52 | static int show_stat(struct seq_file *p, void *v) | 74 | static int show_stat(struct seq_file *p, void *v) |
| 53 | { | 75 | { |
| 54 | int i, j; | 76 | int i, j; |
diff --git a/fs/sysfs/dir.c b/fs/sysfs/dir.c index 2a7a3f5d1ca6..35a36d39fa2c 100644 --- a/fs/sysfs/dir.c +++ b/fs/sysfs/dir.c | |||
| @@ -729,6 +729,9 @@ int sysfs_create_dir(struct kobject * kobj) | |||
| 729 | else | 729 | else |
| 730 | parent_sd = &sysfs_root; | 730 | parent_sd = &sysfs_root; |
| 731 | 731 | ||
| 732 | if (!parent_sd) | ||
| 733 | return -ENOENT; | ||
| 734 | |||
| 732 | if (sysfs_ns_type(parent_sd)) | 735 | if (sysfs_ns_type(parent_sd)) |
| 733 | ns = kobj->ktype->namespace(kobj); | 736 | ns = kobj->ktype->namespace(kobj); |
| 734 | type = sysfs_read_ns_type(kobj); | 737 | type = sysfs_read_ns_type(kobj); |
| @@ -878,7 +881,6 @@ int sysfs_rename(struct sysfs_dirent *sd, | |||
| 878 | 881 | ||
| 879 | dup_name = sd->s_name; | 882 | dup_name = sd->s_name; |
| 880 | sd->s_name = new_name; | 883 | sd->s_name = new_name; |
| 881 | sd->s_hash = sysfs_name_hash(sd->s_ns, sd->s_name); | ||
| 882 | } | 884 | } |
| 883 | 885 | ||
| 884 | /* Move to the appropriate place in the appropriate directories rbtree. */ | 886 | /* Move to the appropriate place in the appropriate directories rbtree. */ |
| @@ -886,6 +888,7 @@ int sysfs_rename(struct sysfs_dirent *sd, | |||
| 886 | sysfs_get(new_parent_sd); | 888 | sysfs_get(new_parent_sd); |
| 887 | sysfs_put(sd->s_parent); | 889 | sysfs_put(sd->s_parent); |
| 888 | sd->s_ns = new_ns; | 890 | sd->s_ns = new_ns; |
| 891 | sd->s_hash = sysfs_name_hash(sd->s_ns, sd->s_name); | ||
| 889 | sd->s_parent = new_parent_sd; | 892 | sd->s_parent = new_parent_sd; |
| 890 | sysfs_link_sibling(sd); | 893 | sysfs_link_sibling(sd); |
| 891 | 894 | ||
diff --git a/fs/sysfs/group.c b/fs/sysfs/group.c index dd1701caecc9..2df555c66d57 100644 --- a/fs/sysfs/group.c +++ b/fs/sysfs/group.c | |||
| @@ -67,7 +67,11 @@ static int internal_create_group(struct kobject *kobj, int update, | |||
| 67 | /* Updates may happen before the object has been instantiated */ | 67 | /* Updates may happen before the object has been instantiated */ |
| 68 | if (unlikely(update && !kobj->sd)) | 68 | if (unlikely(update && !kobj->sd)) |
| 69 | return -EINVAL; | 69 | return -EINVAL; |
| 70 | 70 | if (!grp->attrs) { | |
| 71 | WARN(1, "sysfs: attrs not set by subsystem for group: %s/%s\n", | ||
| 72 | kobj->name, grp->name ? "" : grp->name); | ||
| 73 | return -EINVAL; | ||
| 74 | } | ||
| 71 | if (grp->name) { | 75 | if (grp->name) { |
| 72 | error = sysfs_create_subdir(kobj, grp->name, &sd); | 76 | error = sysfs_create_subdir(kobj, grp->name, &sd); |
| 73 | if (error) | 77 | if (error) |
diff --git a/include/linux/amba/bus.h b/include/linux/amba/bus.h index 7847e197730a..8d54f79457ba 100644 --- a/include/linux/amba/bus.h +++ b/include/linux/amba/bus.h | |||
| @@ -30,7 +30,6 @@ struct amba_device { | |||
| 30 | struct device dev; | 30 | struct device dev; |
| 31 | struct resource res; | 31 | struct resource res; |
| 32 | struct clk *pclk; | 32 | struct clk *pclk; |
| 33 | struct regulator *vcore; | ||
| 34 | u64 dma_mask; | 33 | u64 dma_mask; |
| 35 | unsigned int periphid; | 34 | unsigned int periphid; |
| 36 | unsigned int irq[AMBA_NR_IRQS]; | 35 | unsigned int irq[AMBA_NR_IRQS]; |
| @@ -75,12 +74,6 @@ void amba_release_regions(struct amba_device *); | |||
| 75 | #define amba_pclk_disable(d) \ | 74 | #define amba_pclk_disable(d) \ |
| 76 | do { if (!IS_ERR((d)->pclk)) clk_disable((d)->pclk); } while (0) | 75 | do { if (!IS_ERR((d)->pclk)) clk_disable((d)->pclk); } while (0) |
| 77 | 76 | ||
| 78 | #define amba_vcore_enable(d) \ | ||
| 79 | (IS_ERR((d)->vcore) ? 0 : regulator_enable((d)->vcore)) | ||
| 80 | |||
| 81 | #define amba_vcore_disable(d) \ | ||
| 82 | do { if (!IS_ERR((d)->vcore)) regulator_disable((d)->vcore); } while (0) | ||
| 83 | |||
| 84 | /* Some drivers don't use the struct amba_device */ | 77 | /* Some drivers don't use the struct amba_device */ |
| 85 | #define AMBA_CONFIG_BITS(a) (((a) >> 24) & 0xff) | 78 | #define AMBA_CONFIG_BITS(a) (((a) >> 24) & 0xff) |
| 86 | #define AMBA_REV_BITS(a) (((a) >> 20) & 0x0f) | 79 | #define AMBA_REV_BITS(a) (((a) >> 20) & 0x0f) |
diff --git a/include/linux/amba/pl022.h b/include/linux/amba/pl022.h index b8c51124ed19..76dd1b199a1b 100644 --- a/include/linux/amba/pl022.h +++ b/include/linux/amba/pl022.h | |||
| @@ -25,6 +25,8 @@ | |||
| 25 | #ifndef _SSP_PL022_H | 25 | #ifndef _SSP_PL022_H |
| 26 | #define _SSP_PL022_H | 26 | #define _SSP_PL022_H |
| 27 | 27 | ||
| 28 | #include <linux/types.h> | ||
| 29 | |||
| 28 | /** | 30 | /** |
| 29 | * whether SSP is in loopback mode or not | 31 | * whether SSP is in loopback mode or not |
| 30 | */ | 32 | */ |
diff --git a/include/linux/blkdev.h b/include/linux/blkdev.h index 606cf339bb56..2aa24664a5b5 100644 --- a/include/linux/blkdev.h +++ b/include/linux/blkdev.h | |||
| @@ -426,14 +426,10 @@ struct request_queue { | |||
| 426 | (1 << QUEUE_FLAG_SAME_COMP) | \ | 426 | (1 << QUEUE_FLAG_SAME_COMP) | \ |
| 427 | (1 << QUEUE_FLAG_ADD_RANDOM)) | 427 | (1 << QUEUE_FLAG_ADD_RANDOM)) |
| 428 | 428 | ||
| 429 | static inline int queue_is_locked(struct request_queue *q) | 429 | static inline void queue_lockdep_assert_held(struct request_queue *q) |
| 430 | { | 430 | { |
| 431 | #ifdef CONFIG_SMP | 431 | if (q->queue_lock) |
| 432 | spinlock_t *lock = q->queue_lock; | 432 | lockdep_assert_held(q->queue_lock); |
| 433 | return lock && spin_is_locked(lock); | ||
| 434 | #else | ||
| 435 | return 1; | ||
| 436 | #endif | ||
| 437 | } | 433 | } |
| 438 | 434 | ||
| 439 | static inline void queue_flag_set_unlocked(unsigned int flag, | 435 | static inline void queue_flag_set_unlocked(unsigned int flag, |
| @@ -445,7 +441,7 @@ static inline void queue_flag_set_unlocked(unsigned int flag, | |||
| 445 | static inline int queue_flag_test_and_clear(unsigned int flag, | 441 | static inline int queue_flag_test_and_clear(unsigned int flag, |
| 446 | struct request_queue *q) | 442 | struct request_queue *q) |
| 447 | { | 443 | { |
| 448 | WARN_ON_ONCE(!queue_is_locked(q)); | 444 | queue_lockdep_assert_held(q); |
| 449 | 445 | ||
| 450 | if (test_bit(flag, &q->queue_flags)) { | 446 | if (test_bit(flag, &q->queue_flags)) { |
| 451 | __clear_bit(flag, &q->queue_flags); | 447 | __clear_bit(flag, &q->queue_flags); |
| @@ -458,7 +454,7 @@ static inline int queue_flag_test_and_clear(unsigned int flag, | |||
| 458 | static inline int queue_flag_test_and_set(unsigned int flag, | 454 | static inline int queue_flag_test_and_set(unsigned int flag, |
| 459 | struct request_queue *q) | 455 | struct request_queue *q) |
| 460 | { | 456 | { |
| 461 | WARN_ON_ONCE(!queue_is_locked(q)); | 457 | queue_lockdep_assert_held(q); |
| 462 | 458 | ||
| 463 | if (!test_bit(flag, &q->queue_flags)) { | 459 | if (!test_bit(flag, &q->queue_flags)) { |
| 464 | __set_bit(flag, &q->queue_flags); | 460 | __set_bit(flag, &q->queue_flags); |
| @@ -470,7 +466,7 @@ static inline int queue_flag_test_and_set(unsigned int flag, | |||
| 470 | 466 | ||
| 471 | static inline void queue_flag_set(unsigned int flag, struct request_queue *q) | 467 | static inline void queue_flag_set(unsigned int flag, struct request_queue *q) |
| 472 | { | 468 | { |
| 473 | WARN_ON_ONCE(!queue_is_locked(q)); | 469 | queue_lockdep_assert_held(q); |
| 474 | __set_bit(flag, &q->queue_flags); | 470 | __set_bit(flag, &q->queue_flags); |
| 475 | } | 471 | } |
| 476 | 472 | ||
| @@ -487,7 +483,7 @@ static inline int queue_in_flight(struct request_queue *q) | |||
| 487 | 483 | ||
| 488 | static inline void queue_flag_clear(unsigned int flag, struct request_queue *q) | 484 | static inline void queue_flag_clear(unsigned int flag, struct request_queue *q) |
| 489 | { | 485 | { |
| 490 | WARN_ON_ONCE(!queue_is_locked(q)); | 486 | queue_lockdep_assert_held(q); |
| 491 | __clear_bit(flag, &q->queue_flags); | 487 | __clear_bit(flag, &q->queue_flags); |
| 492 | } | 488 | } |
| 493 | 489 | ||
diff --git a/include/linux/fuse.h b/include/linux/fuse.h index 8ba2c9460b28..8f2ab8fef929 100644 --- a/include/linux/fuse.h +++ b/include/linux/fuse.h | |||
| @@ -593,7 +593,7 @@ struct fuse_dirent { | |||
| 593 | __u64 off; | 593 | __u64 off; |
| 594 | __u32 namelen; | 594 | __u32 namelen; |
| 595 | __u32 type; | 595 | __u32 type; |
| 596 | char name[0]; | 596 | char name[]; |
| 597 | }; | 597 | }; |
| 598 | 598 | ||
| 599 | #define FUSE_NAME_OFFSET offsetof(struct fuse_dirent, name) | 599 | #define FUSE_NAME_OFFSET offsetof(struct fuse_dirent, name) |
diff --git a/include/linux/i2c/twl.h b/include/linux/i2c/twl.h index 2463b6100333..1f90de0cfdbe 100644 --- a/include/linux/i2c/twl.h +++ b/include/linux/i2c/twl.h | |||
| @@ -666,23 +666,11 @@ struct twl4030_codec_data { | |||
| 666 | unsigned int check_defaults:1; | 666 | unsigned int check_defaults:1; |
| 667 | unsigned int reset_registers:1; | 667 | unsigned int reset_registers:1; |
| 668 | unsigned int hs_extmute:1; | 668 | unsigned int hs_extmute:1; |
| 669 | u16 hs_left_step; | ||
| 670 | u16 hs_right_step; | ||
| 671 | u16 hf_left_step; | ||
| 672 | u16 hf_right_step; | ||
| 673 | void (*set_hs_extmute)(int mute); | 669 | void (*set_hs_extmute)(int mute); |
| 674 | }; | 670 | }; |
| 675 | 671 | ||
| 676 | struct twl4030_vibra_data { | 672 | struct twl4030_vibra_data { |
| 677 | unsigned int coexist; | 673 | unsigned int coexist; |
| 678 | |||
| 679 | /* twl6040 */ | ||
| 680 | unsigned int vibldrv_res; /* left driver resistance */ | ||
| 681 | unsigned int vibrdrv_res; /* right driver resistance */ | ||
| 682 | unsigned int viblmotor_res; /* left motor resistance */ | ||
| 683 | unsigned int vibrmotor_res; /* right motor resistance */ | ||
| 684 | int vddvibl_uV; /* VDDVIBL volt, set 0 for fixed reg */ | ||
| 685 | int vddvibr_uV; /* VDDVIBR volt, set 0 for fixed reg */ | ||
| 686 | }; | 674 | }; |
| 687 | 675 | ||
| 688 | struct twl4030_audio_data { | 676 | struct twl4030_audio_data { |
diff --git a/include/linux/irq.h b/include/linux/irq.h index 7810406f3d80..b27cfcfd3a59 100644 --- a/include/linux/irq.h +++ b/include/linux/irq.h | |||
| @@ -49,6 +49,12 @@ typedef void (*irq_preflow_handler_t)(struct irq_data *data); | |||
| 49 | * IRQ_TYPE_LEVEL_LOW - low level triggered | 49 | * IRQ_TYPE_LEVEL_LOW - low level triggered |
| 50 | * IRQ_TYPE_LEVEL_MASK - Mask to filter out the level bits | 50 | * IRQ_TYPE_LEVEL_MASK - Mask to filter out the level bits |
| 51 | * IRQ_TYPE_SENSE_MASK - Mask for all the above bits | 51 | * IRQ_TYPE_SENSE_MASK - Mask for all the above bits |
| 52 | * IRQ_TYPE_DEFAULT - For use by some PICs to ask irq_set_type | ||
| 53 | * to setup the HW to a sane default (used | ||
| 54 | * by irqdomain map() callbacks to synchronize | ||
| 55 | * the HW state and SW flags for a newly | ||
| 56 | * allocated descriptor). | ||
| 57 | * | ||
| 52 | * IRQ_TYPE_PROBE - Special flag for probing in progress | 58 | * IRQ_TYPE_PROBE - Special flag for probing in progress |
| 53 | * | 59 | * |
| 54 | * Bits which can be modified via irq_set/clear/modify_status_flags() | 60 | * Bits which can be modified via irq_set/clear/modify_status_flags() |
| @@ -77,6 +83,7 @@ enum { | |||
| 77 | IRQ_TYPE_LEVEL_LOW = 0x00000008, | 83 | IRQ_TYPE_LEVEL_LOW = 0x00000008, |
| 78 | IRQ_TYPE_LEVEL_MASK = (IRQ_TYPE_LEVEL_LOW | IRQ_TYPE_LEVEL_HIGH), | 84 | IRQ_TYPE_LEVEL_MASK = (IRQ_TYPE_LEVEL_LOW | IRQ_TYPE_LEVEL_HIGH), |
| 79 | IRQ_TYPE_SENSE_MASK = 0x0000000f, | 85 | IRQ_TYPE_SENSE_MASK = 0x0000000f, |
| 86 | IRQ_TYPE_DEFAULT = IRQ_TYPE_SENSE_MASK, | ||
| 80 | 87 | ||
| 81 | IRQ_TYPE_PROBE = 0x00000010, | 88 | IRQ_TYPE_PROBE = 0x00000010, |
| 82 | 89 | ||
diff --git a/include/linux/kconfig.h b/include/linux/kconfig.h index 067eda0e4b32..be342b94c640 100644 --- a/include/linux/kconfig.h +++ b/include/linux/kconfig.h | |||
| @@ -4,29 +4,43 @@ | |||
| 4 | #include <generated/autoconf.h> | 4 | #include <generated/autoconf.h> |
| 5 | 5 | ||
| 6 | /* | 6 | /* |
| 7 | * Helper macros to use CONFIG_ options in C expressions. Note that | 7 | * Helper macros to use CONFIG_ options in C/CPP expressions. Note that |
| 8 | * these only work with boolean and tristate options. | 8 | * these only work with boolean and tristate options. |
| 9 | */ | 9 | */ |
| 10 | 10 | ||
| 11 | /* | 11 | /* |
| 12 | * Getting something that works in C and CPP for an arg that may or may | ||
| 13 | * not be defined is tricky. Here, if we have "#define CONFIG_BOOGER 1" | ||
| 14 | * we match on the placeholder define, insert the "0," for arg1 and generate | ||
| 15 | * the triplet (0, 1, 0). Then the last step cherry picks the 2nd arg (a one). | ||
| 16 | * When CONFIG_BOOGER is not defined, we generate a (... 1, 0) pair, and when | ||
| 17 | * the last step cherry picks the 2nd arg, we get a zero. | ||
| 18 | */ | ||
| 19 | #define __ARG_PLACEHOLDER_1 0, | ||
| 20 | #define config_enabled(cfg) _config_enabled(cfg) | ||
| 21 | #define _config_enabled(value) __config_enabled(__ARG_PLACEHOLDER_##value) | ||
| 22 | #define __config_enabled(arg1_or_junk) ___config_enabled(arg1_or_junk 1, 0) | ||
| 23 | #define ___config_enabled(__ignored, val, ...) val | ||
| 24 | |||
| 25 | /* | ||
| 12 | * IS_ENABLED(CONFIG_FOO) evaluates to 1 if CONFIG_FOO is set to 'y' or 'm', | 26 | * IS_ENABLED(CONFIG_FOO) evaluates to 1 if CONFIG_FOO is set to 'y' or 'm', |
| 13 | * 0 otherwise. | 27 | * 0 otherwise. |
| 14 | * | 28 | * |
| 15 | */ | 29 | */ |
| 16 | #define IS_ENABLED(option) \ | 30 | #define IS_ENABLED(option) \ |
| 17 | (__enabled_ ## option || __enabled_ ## option ## _MODULE) | 31 | (config_enabled(option) || config_enabled(option##_MODULE)) |
| 18 | 32 | ||
| 19 | /* | 33 | /* |
| 20 | * IS_BUILTIN(CONFIG_FOO) evaluates to 1 if CONFIG_FOO is set to 'y', 0 | 34 | * IS_BUILTIN(CONFIG_FOO) evaluates to 1 if CONFIG_FOO is set to 'y', 0 |
| 21 | * otherwise. For boolean options, this is equivalent to | 35 | * otherwise. For boolean options, this is equivalent to |
| 22 | * IS_ENABLED(CONFIG_FOO). | 36 | * IS_ENABLED(CONFIG_FOO). |
| 23 | */ | 37 | */ |
| 24 | #define IS_BUILTIN(option) __enabled_ ## option | 38 | #define IS_BUILTIN(option) config_enabled(option) |
| 25 | 39 | ||
| 26 | /* | 40 | /* |
| 27 | * IS_MODULE(CONFIG_FOO) evaluates to 1 if CONFIG_FOO is set to 'm', 0 | 41 | * IS_MODULE(CONFIG_FOO) evaluates to 1 if CONFIG_FOO is set to 'm', 0 |
| 28 | * otherwise. | 42 | * otherwise. |
| 29 | */ | 43 | */ |
| 30 | #define IS_MODULE(option) __enabled_ ## option ## _MODULE | 44 | #define IS_MODULE(option) config_enabled(option##_MODULE) |
| 31 | 45 | ||
| 32 | #endif /* __LINUX_KCONFIG_H */ | 46 | #endif /* __LINUX_KCONFIG_H */ |
diff --git a/include/linux/kvm_host.h b/include/linux/kvm_host.h index 665a260c7e09..72cbf08d45fb 100644 --- a/include/linux/kvm_host.h +++ b/include/linux/kvm_host.h | |||
| @@ -596,6 +596,7 @@ void kvm_free_irq_source_id(struct kvm *kvm, int irq_source_id); | |||
| 596 | 596 | ||
| 597 | #ifdef CONFIG_IOMMU_API | 597 | #ifdef CONFIG_IOMMU_API |
| 598 | int kvm_iommu_map_pages(struct kvm *kvm, struct kvm_memory_slot *slot); | 598 | int kvm_iommu_map_pages(struct kvm *kvm, struct kvm_memory_slot *slot); |
| 599 | void kvm_iommu_unmap_pages(struct kvm *kvm, struct kvm_memory_slot *slot); | ||
| 599 | int kvm_iommu_map_guest(struct kvm *kvm); | 600 | int kvm_iommu_map_guest(struct kvm *kvm); |
| 600 | int kvm_iommu_unmap_guest(struct kvm *kvm); | 601 | int kvm_iommu_unmap_guest(struct kvm *kvm); |
| 601 | int kvm_assign_device(struct kvm *kvm, | 602 | int kvm_assign_device(struct kvm *kvm, |
| @@ -609,6 +610,11 @@ static inline int kvm_iommu_map_pages(struct kvm *kvm, | |||
| 609 | return 0; | 610 | return 0; |
| 610 | } | 611 | } |
| 611 | 612 | ||
| 613 | static inline void kvm_iommu_unmap_pages(struct kvm *kvm, | ||
| 614 | struct kvm_memory_slot *slot) | ||
| 615 | { | ||
| 616 | } | ||
| 617 | |||
| 612 | static inline int kvm_iommu_map_guest(struct kvm *kvm) | 618 | static inline int kvm_iommu_map_guest(struct kvm *kvm) |
| 613 | { | 619 | { |
| 614 | return -ENODEV; | 620 | return -ENODEV; |
diff --git a/include/linux/mfd/db5500-prcmu.h b/include/linux/mfd/db5500-prcmu.h index 9890687f582d..5a049dfaf153 100644 --- a/include/linux/mfd/db5500-prcmu.h +++ b/include/linux/mfd/db5500-prcmu.h | |||
| @@ -8,41 +8,14 @@ | |||
| 8 | #ifndef __MFD_DB5500_PRCMU_H | 8 | #ifndef __MFD_DB5500_PRCMU_H |
| 9 | #define __MFD_DB5500_PRCMU_H | 9 | #define __MFD_DB5500_PRCMU_H |
| 10 | 10 | ||
| 11 | #ifdef CONFIG_MFD_DB5500_PRCMU | 11 | static inline int prcmu_resetout(u8 resoutn, u8 state) |
| 12 | |||
| 13 | void db5500_prcmu_early_init(void); | ||
| 14 | int db5500_prcmu_set_epod(u16 epod_id, u8 epod_state); | ||
| 15 | int db5500_prcmu_set_display_clocks(void); | ||
| 16 | int db5500_prcmu_disable_dsipll(void); | ||
| 17 | int db5500_prcmu_enable_dsipll(void); | ||
| 18 | int db5500_prcmu_abb_read(u8 slave, u8 reg, u8 *value, u8 size); | ||
| 19 | int db5500_prcmu_abb_write(u8 slave, u8 reg, u8 *value, u8 size); | ||
| 20 | void db5500_prcmu_enable_wakeups(u32 wakeups); | ||
| 21 | int db5500_prcmu_request_clock(u8 clock, bool enable); | ||
| 22 | void db5500_prcmu_config_abb_event_readout(u32 abb_events); | ||
| 23 | void db5500_prcmu_get_abb_event_buffer(void __iomem **buf); | ||
| 24 | int prcmu_resetout(u8 resoutn, u8 state); | ||
| 25 | int db5500_prcmu_set_power_state(u8 state, bool keep_ulp_clk, | ||
| 26 | bool keep_ap_pll); | ||
| 27 | int db5500_prcmu_config_esram0_deep_sleep(u8 state); | ||
| 28 | void db5500_prcmu_system_reset(u16 reset_code); | ||
| 29 | u16 db5500_prcmu_get_reset_code(void); | ||
| 30 | bool db5500_prcmu_is_ac_wake_requested(void); | ||
| 31 | int db5500_prcmu_set_arm_opp(u8 opp); | ||
| 32 | int db5500_prcmu_get_arm_opp(void); | ||
| 33 | |||
| 34 | #else /* !CONFIG_UX500_SOC_DB5500 */ | ||
| 35 | |||
| 36 | static inline void db5500_prcmu_early_init(void) {} | ||
| 37 | |||
| 38 | static inline int db5500_prcmu_abb_read(u8 slave, u8 reg, u8 *value, u8 size) | ||
| 39 | { | 12 | { |
| 40 | return -ENOSYS; | 13 | return 0; |
| 41 | } | 14 | } |
| 42 | 15 | ||
| 43 | static inline int db5500_prcmu_abb_write(u8 slave, u8 reg, u8 *value, u8 size) | 16 | static inline int db5500_prcmu_set_epod(u16 epod_id, u8 epod_state) |
| 44 | { | 17 | { |
| 45 | return -ENOSYS; | 18 | return 0; |
| 46 | } | 19 | } |
| 47 | 20 | ||
| 48 | static inline int db5500_prcmu_request_clock(u8 clock, bool enable) | 21 | static inline int db5500_prcmu_request_clock(u8 clock, bool enable) |
| @@ -50,69 +23,82 @@ static inline int db5500_prcmu_request_clock(u8 clock, bool enable) | |||
| 50 | return 0; | 23 | return 0; |
| 51 | } | 24 | } |
| 52 | 25 | ||
| 53 | static inline int db5500_prcmu_set_display_clocks(void) | 26 | static inline int db5500_prcmu_set_power_state(u8 state, bool keep_ulp_clk, |
| 27 | bool keep_ap_pll) | ||
| 54 | { | 28 | { |
| 55 | return 0; | 29 | return 0; |
| 56 | } | 30 | } |
| 57 | 31 | ||
| 58 | static inline int db5500_prcmu_disable_dsipll(void) | 32 | static inline int db5500_prcmu_config_esram0_deep_sleep(u8 state) |
| 59 | { | 33 | { |
| 60 | return 0; | 34 | return 0; |
| 61 | } | 35 | } |
| 62 | 36 | ||
| 63 | static inline int db5500_prcmu_enable_dsipll(void) | 37 | static inline u16 db5500_prcmu_get_reset_code(void) |
| 64 | { | 38 | { |
| 65 | return 0; | 39 | return 0; |
| 66 | } | 40 | } |
| 67 | 41 | ||
| 68 | static inline int db5500_prcmu_config_esram0_deep_sleep(u8 state) | 42 | static inline bool db5500_prcmu_is_ac_wake_requested(void) |
| 69 | { | 43 | { |
| 70 | return 0; | 44 | return 0; |
| 71 | } | 45 | } |
| 72 | 46 | ||
| 73 | static inline void db5500_prcmu_enable_wakeups(u32 wakeups) {} | 47 | static inline int db5500_prcmu_set_arm_opp(u8 opp) |
| 74 | |||
| 75 | static inline int prcmu_resetout(u8 resoutn, u8 state) | ||
| 76 | { | 48 | { |
| 77 | return 0; | 49 | return 0; |
| 78 | } | 50 | } |
| 79 | 51 | ||
| 80 | static inline int db5500_prcmu_set_epod(u16 epod_id, u8 epod_state) | 52 | static inline int db5500_prcmu_get_arm_opp(void) |
| 81 | { | 53 | { |
| 82 | return 0; | 54 | return 0; |
| 83 | } | 55 | } |
| 84 | 56 | ||
| 85 | static inline void db5500_prcmu_get_abb_event_buffer(void __iomem **buf) {} | ||
| 86 | static inline void db5500_prcmu_config_abb_event_readout(u32 abb_events) {} | 57 | static inline void db5500_prcmu_config_abb_event_readout(u32 abb_events) {} |
| 87 | 58 | ||
| 88 | static inline int db5500_prcmu_set_power_state(u8 state, bool keep_ulp_clk, | 59 | static inline void db5500_prcmu_get_abb_event_buffer(void __iomem **buf) {} |
| 89 | bool keep_ap_pll) | ||
| 90 | { | ||
| 91 | return 0; | ||
| 92 | } | ||
| 93 | 60 | ||
| 94 | static inline void db5500_prcmu_system_reset(u16 reset_code) {} | 61 | static inline void db5500_prcmu_system_reset(u16 reset_code) {} |
| 95 | 62 | ||
| 96 | static inline u16 db5500_prcmu_get_reset_code(void) | 63 | static inline void db5500_prcmu_enable_wakeups(u32 wakeups) {} |
| 64 | |||
| 65 | #ifdef CONFIG_MFD_DB5500_PRCMU | ||
| 66 | |||
| 67 | void db5500_prcmu_early_init(void); | ||
| 68 | int db5500_prcmu_set_display_clocks(void); | ||
| 69 | int db5500_prcmu_disable_dsipll(void); | ||
| 70 | int db5500_prcmu_enable_dsipll(void); | ||
| 71 | int db5500_prcmu_abb_read(u8 slave, u8 reg, u8 *value, u8 size); | ||
| 72 | int db5500_prcmu_abb_write(u8 slave, u8 reg, u8 *value, u8 size); | ||
| 73 | |||
| 74 | #else /* !CONFIG_UX500_SOC_DB5500 */ | ||
| 75 | |||
| 76 | static inline void db5500_prcmu_early_init(void) {} | ||
| 77 | |||
| 78 | static inline int db5500_prcmu_abb_read(u8 slave, u8 reg, u8 *value, u8 size) | ||
| 97 | { | 79 | { |
| 98 | return 0; | 80 | return -ENOSYS; |
| 99 | } | 81 | } |
| 100 | 82 | ||
| 101 | static inline bool db5500_prcmu_is_ac_wake_requested(void) | 83 | static inline int db5500_prcmu_abb_write(u8 slave, u8 reg, u8 *value, u8 size) |
| 102 | { | 84 | { |
| 103 | return 0; | 85 | return -ENOSYS; |
| 104 | } | 86 | } |
| 105 | 87 | ||
| 106 | static inline int db5500_prcmu_set_arm_opp(u8 opp) | 88 | static inline int db5500_prcmu_set_display_clocks(void) |
| 107 | { | 89 | { |
| 108 | return 0; | 90 | return 0; |
| 109 | } | 91 | } |
| 110 | 92 | ||
| 111 | static inline int db5500_prcmu_get_arm_opp(void) | 93 | static inline int db5500_prcmu_disable_dsipll(void) |
| 112 | { | 94 | { |
| 113 | return 0; | 95 | return 0; |
| 114 | } | 96 | } |
| 115 | 97 | ||
| 98 | static inline int db5500_prcmu_enable_dsipll(void) | ||
| 99 | { | ||
| 100 | return 0; | ||
| 101 | } | ||
| 116 | 102 | ||
| 117 | #endif /* CONFIG_MFD_DB5500_PRCMU */ | 103 | #endif /* CONFIG_MFD_DB5500_PRCMU */ |
| 118 | 104 | ||
diff --git a/include/linux/mfd/rc5t583.h b/include/linux/mfd/rc5t583.h index a2c61609d21d..0b64b19d81ab 100644 --- a/include/linux/mfd/rc5t583.h +++ b/include/linux/mfd/rc5t583.h | |||
| @@ -26,6 +26,7 @@ | |||
| 26 | 26 | ||
| 27 | #include <linux/mutex.h> | 27 | #include <linux/mutex.h> |
| 28 | #include <linux/types.h> | 28 | #include <linux/types.h> |
| 29 | #include <linux/regmap.h> | ||
| 29 | 30 | ||
| 30 | #define RC5T583_MAX_REGS 0xF8 | 31 | #define RC5T583_MAX_REGS 0xF8 |
| 31 | 32 | ||
| @@ -279,14 +280,44 @@ struct rc5t583_platform_data { | |||
| 279 | bool enable_shutdown; | 280 | bool enable_shutdown; |
| 280 | }; | 281 | }; |
| 281 | 282 | ||
| 282 | int rc5t583_write(struct device *dev, u8 reg, uint8_t val); | 283 | static inline int rc5t583_write(struct device *dev, uint8_t reg, uint8_t val) |
| 283 | int rc5t583_read(struct device *dev, uint8_t reg, uint8_t *val); | 284 | { |
| 284 | int rc5t583_set_bits(struct device *dev, unsigned int reg, | 285 | struct rc5t583 *rc5t583 = dev_get_drvdata(dev); |
| 285 | unsigned int bit_mask); | 286 | return regmap_write(rc5t583->regmap, reg, val); |
| 286 | int rc5t583_clear_bits(struct device *dev, unsigned int reg, | 287 | } |
| 287 | unsigned int bit_mask); | 288 | |
| 288 | int rc5t583_update(struct device *dev, unsigned int reg, | 289 | static inline int rc5t583_read(struct device *dev, uint8_t reg, uint8_t *val) |
| 289 | unsigned int val, unsigned int mask); | 290 | { |
| 291 | struct rc5t583 *rc5t583 = dev_get_drvdata(dev); | ||
| 292 | unsigned int ival; | ||
| 293 | int ret; | ||
| 294 | ret = regmap_read(rc5t583->regmap, reg, &ival); | ||
| 295 | if (!ret) | ||
| 296 | *val = (uint8_t)ival; | ||
| 297 | return ret; | ||
| 298 | } | ||
| 299 | |||
| 300 | static inline int rc5t583_set_bits(struct device *dev, unsigned int reg, | ||
| 301 | unsigned int bit_mask) | ||
| 302 | { | ||
| 303 | struct rc5t583 *rc5t583 = dev_get_drvdata(dev); | ||
| 304 | return regmap_update_bits(rc5t583->regmap, reg, bit_mask, bit_mask); | ||
| 305 | } | ||
| 306 | |||
| 307 | static inline int rc5t583_clear_bits(struct device *dev, unsigned int reg, | ||
| 308 | unsigned int bit_mask) | ||
| 309 | { | ||
| 310 | struct rc5t583 *rc5t583 = dev_get_drvdata(dev); | ||
| 311 | return regmap_update_bits(rc5t583->regmap, reg, bit_mask, 0); | ||
| 312 | } | ||
| 313 | |||
| 314 | static inline int rc5t583_update(struct device *dev, unsigned int reg, | ||
| 315 | unsigned int val, unsigned int mask) | ||
| 316 | { | ||
| 317 | struct rc5t583 *rc5t583 = dev_get_drvdata(dev); | ||
| 318 | return regmap_update_bits(rc5t583->regmap, reg, mask, val); | ||
| 319 | } | ||
| 320 | |||
| 290 | int rc5t583_ext_power_req_config(struct device *dev, int deepsleep_id, | 321 | int rc5t583_ext_power_req_config(struct device *dev, int deepsleep_id, |
| 291 | int ext_pwr_req, int deepsleep_slot_nr); | 322 | int ext_pwr_req, int deepsleep_slot_nr); |
| 292 | int rc5t583_irq_init(struct rc5t583 *rc5t583, int irq, int irq_base); | 323 | int rc5t583_irq_init(struct rc5t583 *rc5t583, int irq, int irq_base); |
diff --git a/include/linux/mfd/twl6040.h b/include/linux/mfd/twl6040.h index 9bc9ac651dad..b15b5f03f5c4 100644 --- a/include/linux/mfd/twl6040.h +++ b/include/linux/mfd/twl6040.h | |||
| @@ -174,8 +174,35 @@ | |||
| 174 | #define TWL6040_SYSCLK_SEL_LPPLL 0 | 174 | #define TWL6040_SYSCLK_SEL_LPPLL 0 |
| 175 | #define TWL6040_SYSCLK_SEL_HPPLL 1 | 175 | #define TWL6040_SYSCLK_SEL_HPPLL 1 |
| 176 | 176 | ||
| 177 | struct twl6040_codec_data { | ||
| 178 | u16 hs_left_step; | ||
| 179 | u16 hs_right_step; | ||
| 180 | u16 hf_left_step; | ||
| 181 | u16 hf_right_step; | ||
| 182 | }; | ||
| 183 | |||
| 184 | struct twl6040_vibra_data { | ||
| 185 | unsigned int vibldrv_res; /* left driver resistance */ | ||
| 186 | unsigned int vibrdrv_res; /* right driver resistance */ | ||
| 187 | unsigned int viblmotor_res; /* left motor resistance */ | ||
| 188 | unsigned int vibrmotor_res; /* right motor resistance */ | ||
| 189 | int vddvibl_uV; /* VDDVIBL volt, set 0 for fixed reg */ | ||
| 190 | int vddvibr_uV; /* VDDVIBR volt, set 0 for fixed reg */ | ||
| 191 | }; | ||
| 192 | |||
| 193 | struct twl6040_platform_data { | ||
| 194 | int audpwron_gpio; /* audio power-on gpio */ | ||
| 195 | unsigned int irq_base; | ||
| 196 | |||
| 197 | struct twl6040_codec_data *codec; | ||
| 198 | struct twl6040_vibra_data *vibra; | ||
| 199 | }; | ||
| 200 | |||
| 201 | struct regmap; | ||
| 202 | |||
| 177 | struct twl6040 { | 203 | struct twl6040 { |
| 178 | struct device *dev; | 204 | struct device *dev; |
| 205 | struct regmap *regmap; | ||
| 179 | struct mutex mutex; | 206 | struct mutex mutex; |
| 180 | struct mutex io_mutex; | 207 | struct mutex io_mutex; |
| 181 | struct mutex irq_mutex; | 208 | struct mutex irq_mutex; |
diff --git a/include/linux/mm.h b/include/linux/mm.h index d8738a464b94..74aa71bea1e4 100644 --- a/include/linux/mm.h +++ b/include/linux/mm.h | |||
| @@ -1393,29 +1393,20 @@ extern int install_special_mapping(struct mm_struct *mm, | |||
| 1393 | 1393 | ||
| 1394 | extern unsigned long get_unmapped_area(struct file *, unsigned long, unsigned long, unsigned long, unsigned long); | 1394 | extern unsigned long get_unmapped_area(struct file *, unsigned long, unsigned long, unsigned long, unsigned long); |
| 1395 | 1395 | ||
| 1396 | extern unsigned long do_mmap_pgoff(struct file *file, unsigned long addr, | ||
| 1397 | unsigned long len, unsigned long prot, | ||
| 1398 | unsigned long flag, unsigned long pgoff); | ||
| 1399 | extern unsigned long mmap_region(struct file *file, unsigned long addr, | 1396 | extern unsigned long mmap_region(struct file *file, unsigned long addr, |
| 1400 | unsigned long len, unsigned long flags, | 1397 | unsigned long len, unsigned long flags, |
| 1401 | vm_flags_t vm_flags, unsigned long pgoff); | 1398 | vm_flags_t vm_flags, unsigned long pgoff); |
| 1402 | 1399 | extern unsigned long do_mmap(struct file *, unsigned long, | |
| 1403 | static inline unsigned long do_mmap(struct file *file, unsigned long addr, | 1400 | unsigned long, unsigned long, |
| 1404 | unsigned long len, unsigned long prot, | 1401 | unsigned long, unsigned long); |
| 1405 | unsigned long flag, unsigned long offset) | ||
| 1406 | { | ||
| 1407 | unsigned long ret = -EINVAL; | ||
| 1408 | if ((offset + PAGE_ALIGN(len)) < offset) | ||
| 1409 | goto out; | ||
| 1410 | if (!(offset & ~PAGE_MASK)) | ||
| 1411 | ret = do_mmap_pgoff(file, addr, len, prot, flag, offset >> PAGE_SHIFT); | ||
| 1412 | out: | ||
| 1413 | return ret; | ||
| 1414 | } | ||
| 1415 | |||
| 1416 | extern int do_munmap(struct mm_struct *, unsigned long, size_t); | 1402 | extern int do_munmap(struct mm_struct *, unsigned long, size_t); |
| 1417 | 1403 | ||
| 1418 | extern unsigned long do_brk(unsigned long, unsigned long); | 1404 | /* These take the mm semaphore themselves */ |
| 1405 | extern unsigned long vm_brk(unsigned long, unsigned long); | ||
| 1406 | extern int vm_munmap(unsigned long, size_t); | ||
| 1407 | extern unsigned long vm_mmap(struct file *, unsigned long, | ||
| 1408 | unsigned long, unsigned long, | ||
| 1409 | unsigned long, unsigned long); | ||
| 1419 | 1410 | ||
| 1420 | /* truncate.c */ | 1411 | /* truncate.c */ |
| 1421 | extern void truncate_inode_pages(struct address_space *, loff_t); | 1412 | extern void truncate_inode_pages(struct address_space *, loff_t); |
diff --git a/include/linux/mmc/card.h b/include/linux/mmc/card.h index 01beae78f079..629b823f8836 100644 --- a/include/linux/mmc/card.h +++ b/include/linux/mmc/card.h | |||
| @@ -481,7 +481,7 @@ struct mmc_driver { | |||
| 481 | struct device_driver drv; | 481 | struct device_driver drv; |
| 482 | int (*probe)(struct mmc_card *); | 482 | int (*probe)(struct mmc_card *); |
| 483 | void (*remove)(struct mmc_card *); | 483 | void (*remove)(struct mmc_card *); |
| 484 | int (*suspend)(struct mmc_card *, pm_message_t); | 484 | int (*suspend)(struct mmc_card *); |
| 485 | int (*resume)(struct mmc_card *); | 485 | int (*resume)(struct mmc_card *); |
| 486 | }; | 486 | }; |
| 487 | 487 | ||
diff --git a/include/linux/nfsd/Kbuild b/include/linux/nfsd/Kbuild index b8d4001212b3..5b7d84ac954a 100644 --- a/include/linux/nfsd/Kbuild +++ b/include/linux/nfsd/Kbuild | |||
| @@ -1,3 +1,4 @@ | |||
| 1 | header-y += cld.h | ||
| 1 | header-y += debug.h | 2 | header-y += debug.h |
| 2 | header-y += export.h | 3 | header-y += export.h |
| 3 | header-y += nfsfh.h | 4 | header-y += nfsfh.h |
diff --git a/include/linux/pinctrl/machine.h b/include/linux/pinctrl/machine.h index fee4349364f7..e4d1de742502 100644 --- a/include/linux/pinctrl/machine.h +++ b/include/linux/pinctrl/machine.h | |||
| @@ -12,6 +12,8 @@ | |||
| 12 | #ifndef __LINUX_PINCTRL_MACHINE_H | 12 | #ifndef __LINUX_PINCTRL_MACHINE_H |
| 13 | #define __LINUX_PINCTRL_MACHINE_H | 13 | #define __LINUX_PINCTRL_MACHINE_H |
| 14 | 14 | ||
| 15 | #include <linux/bug.h> | ||
| 16 | |||
| 15 | #include "pinctrl-state.h" | 17 | #include "pinctrl-state.h" |
| 16 | 18 | ||
| 17 | enum pinctrl_map_type { | 19 | enum pinctrl_map_type { |
| @@ -148,7 +150,7 @@ struct pinctrl_map { | |||
| 148 | #define PIN_MAP_CONFIGS_GROUP_HOG_DEFAULT(dev, grp, cfgs) \ | 150 | #define PIN_MAP_CONFIGS_GROUP_HOG_DEFAULT(dev, grp, cfgs) \ |
| 149 | PIN_MAP_CONFIGS_GROUP(dev, PINCTRL_STATE_DEFAULT, dev, grp, cfgs) | 151 | PIN_MAP_CONFIGS_GROUP(dev, PINCTRL_STATE_DEFAULT, dev, grp, cfgs) |
| 150 | 152 | ||
| 151 | #ifdef CONFIG_PINMUX | 153 | #ifdef CONFIG_PINCTRL |
| 152 | 154 | ||
| 153 | extern int pinctrl_register_mappings(struct pinctrl_map const *map, | 155 | extern int pinctrl_register_mappings(struct pinctrl_map const *map, |
| 154 | unsigned num_maps); | 156 | unsigned num_maps); |
diff --git a/include/linux/serial_core.h b/include/linux/serial_core.h index f51bf2e70c69..2db407a40051 100644 --- a/include/linux/serial_core.h +++ b/include/linux/serial_core.h | |||
| @@ -357,7 +357,7 @@ struct uart_port { | |||
| 357 | #define UPF_CONS_FLOW ((__force upf_t) (1 << 23)) | 357 | #define UPF_CONS_FLOW ((__force upf_t) (1 << 23)) |
| 358 | #define UPF_SHARE_IRQ ((__force upf_t) (1 << 24)) | 358 | #define UPF_SHARE_IRQ ((__force upf_t) (1 << 24)) |
| 359 | #define UPF_EXAR_EFR ((__force upf_t) (1 << 25)) | 359 | #define UPF_EXAR_EFR ((__force upf_t) (1 << 25)) |
| 360 | #define UPF_IIR_ONCE ((__force upf_t) (1 << 26)) | 360 | #define UPF_BUG_THRE ((__force upf_t) (1 << 26)) |
| 361 | /* The exact UART type is known and should not be probed. */ | 361 | /* The exact UART type is known and should not be probed. */ |
| 362 | #define UPF_FIXED_TYPE ((__force upf_t) (1 << 27)) | 362 | #define UPF_FIXED_TYPE ((__force upf_t) (1 << 27)) |
| 363 | #define UPF_BOOT_AUTOCONF ((__force upf_t) (1 << 28)) | 363 | #define UPF_BOOT_AUTOCONF ((__force upf_t) (1 << 28)) |
diff --git a/include/linux/stddef.h b/include/linux/stddef.h index 6a40c76bdcf1..1747b6787b9e 100644 --- a/include/linux/stddef.h +++ b/include/linux/stddef.h | |||
| @@ -3,14 +3,10 @@ | |||
| 3 | 3 | ||
| 4 | #include <linux/compiler.h> | 4 | #include <linux/compiler.h> |
| 5 | 5 | ||
| 6 | #ifdef __KERNEL__ | ||
| 7 | |||
| 6 | #undef NULL | 8 | #undef NULL |
| 7 | #if defined(__cplusplus) | ||
| 8 | #define NULL 0 | ||
| 9 | #else | ||
| 10 | #define NULL ((void *)0) | 9 | #define NULL ((void *)0) |
| 11 | #endif | ||
| 12 | |||
| 13 | #ifdef __KERNEL__ | ||
| 14 | 10 | ||
| 15 | enum { | 11 | enum { |
| 16 | false = 0, | 12 | false = 0, |
diff --git a/include/linux/usb/otg.h b/include/linux/usb/otg.h index f67810f8f21b..38ab3f46346f 100644 --- a/include/linux/usb/otg.h +++ b/include/linux/usb/otg.h | |||
| @@ -94,6 +94,7 @@ struct usb_phy { | |||
| 94 | 94 | ||
| 95 | struct usb_otg *otg; | 95 | struct usb_otg *otg; |
| 96 | 96 | ||
| 97 | struct device *io_dev; | ||
| 97 | struct usb_phy_io_ops *io_ops; | 98 | struct usb_phy_io_ops *io_ops; |
| 98 | void __iomem *io_priv; | 99 | void __iomem *io_priv; |
| 99 | 100 | ||
diff --git a/include/linux/usb/serial.h b/include/linux/usb/serial.h index fbb666b1b670..474283888233 100644 --- a/include/linux/usb/serial.h +++ b/include/linux/usb/serial.h | |||
| @@ -28,13 +28,6 @@ | |||
| 28 | /* parity check flag */ | 28 | /* parity check flag */ |
| 29 | #define RELEVANT_IFLAG(iflag) (iflag & (IGNBRK|BRKINT|IGNPAR|PARMRK|INPCK)) | 29 | #define RELEVANT_IFLAG(iflag) (iflag & (IGNBRK|BRKINT|IGNPAR|PARMRK|INPCK)) |
| 30 | 30 | ||
| 31 | enum port_dev_state { | ||
| 32 | PORT_UNREGISTERED, | ||
| 33 | PORT_REGISTERING, | ||
| 34 | PORT_REGISTERED, | ||
| 35 | PORT_UNREGISTERING, | ||
| 36 | }; | ||
| 37 | |||
| 38 | /* USB serial flags */ | 31 | /* USB serial flags */ |
| 39 | #define USB_SERIAL_WRITE_BUSY 0 | 32 | #define USB_SERIAL_WRITE_BUSY 0 |
| 40 | 33 | ||
| @@ -124,7 +117,6 @@ struct usb_serial_port { | |||
| 124 | char throttle_req; | 117 | char throttle_req; |
| 125 | unsigned long sysrq; /* sysrq timeout */ | 118 | unsigned long sysrq; /* sysrq timeout */ |
| 126 | struct device dev; | 119 | struct device dev; |
| 127 | enum port_dev_state dev_state; | ||
| 128 | }; | 120 | }; |
| 129 | #define to_usb_serial_port(d) container_of(d, struct usb_serial_port, dev) | 121 | #define to_usb_serial_port(d) container_of(d, struct usb_serial_port, dev) |
| 130 | 122 | ||
diff --git a/include/net/ip6_fib.h b/include/net/ip6_fib.h index c64778fd5e13..0ae759a6c76e 100644 --- a/include/net/ip6_fib.h +++ b/include/net/ip6_fib.h | |||
| @@ -129,7 +129,7 @@ static inline void rt6_clean_expires(struct rt6_info *rt) | |||
| 129 | dst_release(rt->dst.from); | 129 | dst_release(rt->dst.from); |
| 130 | 130 | ||
| 131 | rt->rt6i_flags &= ~RTF_EXPIRES; | 131 | rt->rt6i_flags &= ~RTF_EXPIRES; |
| 132 | rt->dst.expires = 0; | 132 | rt->dst.from = NULL; |
| 133 | } | 133 | } |
| 134 | 134 | ||
| 135 | static inline void rt6_set_expires(struct rt6_info *rt, unsigned long expires) | 135 | static inline void rt6_set_expires(struct rt6_info *rt, unsigned long expires) |
| @@ -143,8 +143,14 @@ static inline void rt6_set_expires(struct rt6_info *rt, unsigned long expires) | |||
| 143 | 143 | ||
| 144 | static inline void rt6_update_expires(struct rt6_info *rt, int timeout) | 144 | static inline void rt6_update_expires(struct rt6_info *rt, int timeout) |
| 145 | { | 145 | { |
| 146 | if (!(rt->rt6i_flags & RTF_EXPIRES) && rt->dst.from) | 146 | if (!(rt->rt6i_flags & RTF_EXPIRES)) { |
| 147 | dst_release(rt->dst.from); | 147 | if (rt->dst.from) |
| 148 | dst_release(rt->dst.from); | ||
| 149 | /* dst_set_expires relies on expires == 0 | ||
| 150 | * if it has not been set previously. | ||
| 151 | */ | ||
| 152 | rt->dst.expires = 0; | ||
| 153 | } | ||
| 148 | 154 | ||
| 149 | dst_set_expires(&rt->dst, timeout); | 155 | dst_set_expires(&rt->dst, timeout); |
| 150 | rt->rt6i_flags |= RTF_EXPIRES; | 156 | rt->rt6i_flags |= RTF_EXPIRES; |
diff --git a/include/net/red.h b/include/net/red.h index 77d4c3745cb5..ef46058d35bf 100644 --- a/include/net/red.h +++ b/include/net/red.h | |||
| @@ -245,7 +245,7 @@ static inline unsigned long red_calc_qavg_from_idle_time(const struct red_parms | |||
| 245 | * | 245 | * |
| 246 | * dummy packets as a burst after idle time, i.e. | 246 | * dummy packets as a burst after idle time, i.e. |
| 247 | * | 247 | * |
| 248 | * p->qavg *= (1-W)^m | 248 | * v->qavg *= (1-W)^m |
| 249 | * | 249 | * |
| 250 | * This is an apparently overcomplicated solution (f.e. we have to | 250 | * This is an apparently overcomplicated solution (f.e. we have to |
| 251 | * precompute a table to make this calculation in reasonable time) | 251 | * precompute a table to make this calculation in reasonable time) |
| @@ -279,7 +279,7 @@ static inline unsigned long red_calc_qavg_no_idle_time(const struct red_parms *p | |||
| 279 | unsigned int backlog) | 279 | unsigned int backlog) |
| 280 | { | 280 | { |
| 281 | /* | 281 | /* |
| 282 | * NOTE: p->qavg is fixed point number with point at Wlog. | 282 | * NOTE: v->qavg is fixed point number with point at Wlog. |
| 283 | * The formula below is equvalent to floating point | 283 | * The formula below is equvalent to floating point |
| 284 | * version: | 284 | * version: |
| 285 | * | 285 | * |
| @@ -390,7 +390,7 @@ static inline void red_adaptative_algo(struct red_parms *p, struct red_vars *v) | |||
| 390 | if (red_is_idling(v)) | 390 | if (red_is_idling(v)) |
| 391 | qavg = red_calc_qavg_from_idle_time(p, v); | 391 | qavg = red_calc_qavg_from_idle_time(p, v); |
| 392 | 392 | ||
| 393 | /* p->qavg is fixed point number with point at Wlog */ | 393 | /* v->qavg is fixed point number with point at Wlog */ |
| 394 | qavg >>= p->Wlog; | 394 | qavg >>= p->Wlog; |
| 395 | 395 | ||
| 396 | if (qavg > p->target_max && p->max_P <= MAX_P_MAX) | 396 | if (qavg > p->target_max && p->max_P <= MAX_P_MAX) |
diff --git a/include/net/sock.h b/include/net/sock.h index 4e9d01e491d5..68a283425f1c 100644 --- a/include/net/sock.h +++ b/include/net/sock.h | |||
| @@ -246,6 +246,7 @@ struct cg_proto; | |||
| 246 | * @sk_user_data: RPC layer private data | 246 | * @sk_user_data: RPC layer private data |
| 247 | * @sk_sndmsg_page: cached page for sendmsg | 247 | * @sk_sndmsg_page: cached page for sendmsg |
| 248 | * @sk_sndmsg_off: cached offset for sendmsg | 248 | * @sk_sndmsg_off: cached offset for sendmsg |
| 249 | * @sk_peek_off: current peek_offset value | ||
| 249 | * @sk_send_head: front of stuff to transmit | 250 | * @sk_send_head: front of stuff to transmit |
| 250 | * @sk_security: used by security modules | 251 | * @sk_security: used by security modules |
| 251 | * @sk_mark: generic packet mark | 252 | * @sk_mark: generic packet mark |
diff --git a/include/scsi/scsi_cmnd.h b/include/scsi/scsi_cmnd.h index 377df4a28512..1e1198546c72 100644 --- a/include/scsi/scsi_cmnd.h +++ b/include/scsi/scsi_cmnd.h | |||
| @@ -134,6 +134,9 @@ struct scsi_cmnd { | |||
| 134 | 134 | ||
| 135 | static inline struct scsi_driver *scsi_cmd_to_driver(struct scsi_cmnd *cmd) | 135 | static inline struct scsi_driver *scsi_cmd_to_driver(struct scsi_cmnd *cmd) |
| 136 | { | 136 | { |
| 137 | if (!cmd->request->rq_disk) | ||
| 138 | return NULL; | ||
| 139 | |||
| 137 | return *(struct scsi_driver **)cmd->request->rq_disk->private_data; | 140 | return *(struct scsi_driver **)cmd->request->rq_disk->private_data; |
| 138 | } | 141 | } |
| 139 | 142 | ||
diff --git a/kernel/irq/irqdomain.c b/kernel/irq/irqdomain.c index d34413e78628..0e0ba5f840b2 100644 --- a/kernel/irq/irqdomain.c +++ b/kernel/irq/irqdomain.c | |||
| @@ -629,7 +629,8 @@ static int virq_debug_show(struct seq_file *m, void *private) | |||
| 629 | int i; | 629 | int i; |
| 630 | 630 | ||
| 631 | seq_printf(m, "%-5s %-7s %-15s %-*s %s\n", "irq", "hwirq", | 631 | seq_printf(m, "%-5s %-7s %-15s %-*s %s\n", "irq", "hwirq", |
| 632 | "chip name", 2 * sizeof(void *) + 2, "chip data", "domain name"); | 632 | "chip name", (int)(2 * sizeof(void *) + 2), "chip data", |
| 633 | "domain name"); | ||
| 633 | 634 | ||
| 634 | for (i = 1; i < nr_irqs; i++) { | 635 | for (i = 1; i < nr_irqs; i++) { |
| 635 | desc = irq_to_desc(i); | 636 | desc = irq_to_desc(i); |
diff --git a/kernel/irq_work.c b/kernel/irq_work.c index 0c56d44b9fd5..1588e3b2871b 100644 --- a/kernel/irq_work.c +++ b/kernel/irq_work.c | |||
| @@ -11,6 +11,7 @@ | |||
| 11 | #include <linux/irq_work.h> | 11 | #include <linux/irq_work.h> |
| 12 | #include <linux/percpu.h> | 12 | #include <linux/percpu.h> |
| 13 | #include <linux/hardirq.h> | 13 | #include <linux/hardirq.h> |
| 14 | #include <linux/irqflags.h> | ||
| 14 | #include <asm/processor.h> | 15 | #include <asm/processor.h> |
| 15 | 16 | ||
| 16 | /* | 17 | /* |
diff --git a/kernel/itimer.c b/kernel/itimer.c index 22000c3db0dd..8d262b467573 100644 --- a/kernel/itimer.c +++ b/kernel/itimer.c | |||
| @@ -284,8 +284,12 @@ SYSCALL_DEFINE3(setitimer, int, which, struct itimerval __user *, value, | |||
| 284 | if (value) { | 284 | if (value) { |
| 285 | if(copy_from_user(&set_buffer, value, sizeof(set_buffer))) | 285 | if(copy_from_user(&set_buffer, value, sizeof(set_buffer))) |
| 286 | return -EFAULT; | 286 | return -EFAULT; |
| 287 | } else | 287 | } else { |
| 288 | memset((char *) &set_buffer, 0, sizeof(set_buffer)); | 288 | memset(&set_buffer, 0, sizeof(set_buffer)); |
| 289 | printk_once(KERN_WARNING "%s calls setitimer() with new_value NULL pointer." | ||
| 290 | " Misfeature support will be removed\n", | ||
| 291 | current->comm); | ||
| 292 | } | ||
| 289 | 293 | ||
| 290 | error = do_setitimer(which, &set_buffer, ovalue ? &get_buffer : NULL); | 294 | error = do_setitimer(which, &set_buffer, ovalue ? &get_buffer : NULL); |
| 291 | if (error || !ovalue) | 295 | if (error || !ovalue) |
diff --git a/kernel/time/Kconfig b/kernel/time/Kconfig index 2cf9cc7aa103..a20dc8a3c949 100644 --- a/kernel/time/Kconfig +++ b/kernel/time/Kconfig | |||
| @@ -1,6 +1,10 @@ | |||
| 1 | # | 1 | # |
| 2 | # Timer subsystem related configuration options | 2 | # Timer subsystem related configuration options |
| 3 | # | 3 | # |
| 4 | |||
| 5 | # Core internal switch. Selected by NO_HZ / HIGH_RES_TIMERS. This is | ||
| 6 | # only related to the tick functionality. Oneshot clockevent devices | ||
| 7 | # are supported independ of this. | ||
| 4 | config TICK_ONESHOT | 8 | config TICK_ONESHOT |
| 5 | bool | 9 | bool |
| 6 | 10 | ||
diff --git a/kernel/time/tick-broadcast.c b/kernel/time/tick-broadcast.c index e883f57a3cd3..bf57abdc7bd0 100644 --- a/kernel/time/tick-broadcast.c +++ b/kernel/time/tick-broadcast.c | |||
| @@ -575,10 +575,12 @@ void tick_broadcast_switch_to_oneshot(void) | |||
| 575 | unsigned long flags; | 575 | unsigned long flags; |
| 576 | 576 | ||
| 577 | raw_spin_lock_irqsave(&tick_broadcast_lock, flags); | 577 | raw_spin_lock_irqsave(&tick_broadcast_lock, flags); |
| 578 | |||
| 579 | tick_broadcast_device.mode = TICKDEV_MODE_ONESHOT; | ||
| 580 | |||
| 578 | if (cpumask_empty(tick_get_broadcast_mask())) | 581 | if (cpumask_empty(tick_get_broadcast_mask())) |
| 579 | goto end; | 582 | goto end; |
| 580 | 583 | ||
| 581 | tick_broadcast_device.mode = TICKDEV_MODE_ONESHOT; | ||
| 582 | bc = tick_broadcast_device.evtdev; | 584 | bc = tick_broadcast_device.evtdev; |
| 583 | if (bc) | 585 | if (bc) |
| 584 | tick_broadcast_setup_oneshot(bc); | 586 | tick_broadcast_setup_oneshot(bc); |
diff --git a/kernel/time/tick-sched.c b/kernel/time/tick-sched.c index 3526038f2836..6a3a5b9ff561 100644 --- a/kernel/time/tick-sched.c +++ b/kernel/time/tick-sched.c | |||
| @@ -534,9 +534,9 @@ static void tick_nohz_restart(struct tick_sched *ts, ktime_t now) | |||
| 534 | hrtimer_get_expires(&ts->sched_timer), 0)) | 534 | hrtimer_get_expires(&ts->sched_timer), 0)) |
| 535 | break; | 535 | break; |
| 536 | } | 536 | } |
| 537 | /* Update jiffies and reread time */ | 537 | /* Reread time and update jiffies */ |
| 538 | tick_do_update_jiffies64(now); | ||
| 539 | now = ktime_get(); | 538 | now = ktime_get(); |
| 539 | tick_do_update_jiffies64(now); | ||
| 540 | } | 540 | } |
| 541 | } | 541 | } |
| 542 | 542 | ||
diff --git a/lib/kobject.c b/lib/kobject.c index 21dee7c19afd..aeefa8bc8b1c 100644 --- a/lib/kobject.c +++ b/lib/kobject.c | |||
| @@ -192,14 +192,14 @@ static int kobject_add_internal(struct kobject *kobj) | |||
| 192 | 192 | ||
| 193 | /* be noisy on error issues */ | 193 | /* be noisy on error issues */ |
| 194 | if (error == -EEXIST) | 194 | if (error == -EEXIST) |
| 195 | printk(KERN_ERR "%s failed for %s with " | 195 | WARN(1, "%s failed for %s with " |
| 196 | "-EEXIST, don't try to register things with " | 196 | "-EEXIST, don't try to register things with " |
| 197 | "the same name in the same directory.\n", | 197 | "the same name in the same directory.\n", |
| 198 | __func__, kobject_name(kobj)); | 198 | __func__, kobject_name(kobj)); |
| 199 | else | 199 | else |
| 200 | printk(KERN_ERR "%s failed for %s (%d)\n", | 200 | WARN(1, "%s failed for %s (error: %d parent: %s)\n", |
| 201 | __func__, kobject_name(kobj), error); | 201 | __func__, kobject_name(kobj), error, |
| 202 | dump_stack(); | 202 | parent ? kobject_name(parent) : "'none'"); |
| 203 | } else | 203 | } else |
| 204 | kobj->state_in_sysfs = 1; | 204 | kobj->state_in_sysfs = 1; |
| 205 | 205 | ||
diff --git a/lib/mpi/mpi-bit.c b/lib/mpi/mpi-bit.c index 2f526627e4f5..0c505361da19 100644 --- a/lib/mpi/mpi-bit.c +++ b/lib/mpi/mpi-bit.c | |||
| @@ -177,8 +177,8 @@ int mpi_rshift(MPI x, MPI a, unsigned n) | |||
| 177 | */ | 177 | */ |
| 178 | int mpi_lshift_limbs(MPI a, unsigned int count) | 178 | int mpi_lshift_limbs(MPI a, unsigned int count) |
| 179 | { | 179 | { |
| 180 | mpi_ptr_t ap = a->d; | 180 | const int n = a->nlimbs; |
| 181 | int n = a->nlimbs; | 181 | mpi_ptr_t ap; |
| 182 | int i; | 182 | int i; |
| 183 | 183 | ||
| 184 | if (!count || !n) | 184 | if (!count || !n) |
| @@ -187,6 +187,7 @@ int mpi_lshift_limbs(MPI a, unsigned int count) | |||
| 187 | if (RESIZE_IF_NEEDED(a, n + count) < 0) | 187 | if (RESIZE_IF_NEEDED(a, n + count) < 0) |
| 188 | return -ENOMEM; | 188 | return -ENOMEM; |
| 189 | 189 | ||
| 190 | ap = a->d; | ||
| 190 | for (i = n - 1; i >= 0; i--) | 191 | for (i = n - 1; i >= 0; i--) |
| 191 | ap[i + count] = ap[i]; | 192 | ap[i + count] = ap[i]; |
| 192 | for (i = 0; i < count; i++) | 193 | for (i = 0; i < count; i++) |
diff --git a/mm/memblock.c b/mm/memblock.c index 99f285599501..a44eab3157f8 100644 --- a/mm/memblock.c +++ b/mm/memblock.c | |||
| @@ -330,6 +330,9 @@ static int __init_memblock memblock_add_region(struct memblock_type *type, | |||
| 330 | phys_addr_t end = base + memblock_cap_size(base, &size); | 330 | phys_addr_t end = base + memblock_cap_size(base, &size); |
| 331 | int i, nr_new; | 331 | int i, nr_new; |
| 332 | 332 | ||
| 333 | if (!size) | ||
| 334 | return 0; | ||
| 335 | |||
| 333 | /* special case for empty array */ | 336 | /* special case for empty array */ |
| 334 | if (type->regions[0].size == 0) { | 337 | if (type->regions[0].size == 0) { |
| 335 | WARN_ON(type->cnt != 1 || type->total_size); | 338 | WARN_ON(type->cnt != 1 || type->total_size); |
| @@ -430,6 +433,9 @@ static int __init_memblock memblock_isolate_range(struct memblock_type *type, | |||
| 430 | 433 | ||
| 431 | *start_rgn = *end_rgn = 0; | 434 | *start_rgn = *end_rgn = 0; |
| 432 | 435 | ||
| 436 | if (!size) | ||
| 437 | return 0; | ||
| 438 | |||
| 433 | /* we'll create at most two more regions */ | 439 | /* we'll create at most two more regions */ |
| 434 | while (type->cnt + 2 > type->max) | 440 | while (type->cnt + 2 > type->max) |
| 435 | if (memblock_double_array(type) < 0) | 441 | if (memblock_double_array(type) < 0) |
| @@ -514,7 +520,6 @@ int __init_memblock memblock_reserve(phys_addr_t base, phys_addr_t size) | |||
| 514 | (unsigned long long)base, | 520 | (unsigned long long)base, |
| 515 | (unsigned long long)base + size, | 521 | (unsigned long long)base + size, |
| 516 | (void *)_RET_IP_); | 522 | (void *)_RET_IP_); |
| 517 | BUG_ON(0 == size); | ||
| 518 | 523 | ||
| 519 | return memblock_add_region(_rgn, base, size, MAX_NUMNODES); | 524 | return memblock_add_region(_rgn, base, size, MAX_NUMNODES); |
| 520 | } | 525 | } |
diff --git a/mm/memcontrol.c b/mm/memcontrol.c index a7165a60d0a7..b868def9bcc1 100644 --- a/mm/memcontrol.c +++ b/mm/memcontrol.c | |||
| @@ -3392,6 +3392,7 @@ void mem_cgroup_replace_page_cache(struct page *oldpage, | |||
| 3392 | * the newpage may be on LRU(or pagevec for LRU) already. We lock | 3392 | * the newpage may be on LRU(or pagevec for LRU) already. We lock |
| 3393 | * LRU while we overwrite pc->mem_cgroup. | 3393 | * LRU while we overwrite pc->mem_cgroup. |
| 3394 | */ | 3394 | */ |
| 3395 | pc = lookup_page_cgroup(newpage); | ||
| 3395 | __mem_cgroup_commit_charge(memcg, newpage, 1, pc, type, true); | 3396 | __mem_cgroup_commit_charge(memcg, newpage, 1, pc, type, true); |
| 3396 | } | 3397 | } |
| 3397 | 3398 | ||
| @@ -240,6 +240,8 @@ static struct vm_area_struct *remove_vma(struct vm_area_struct *vma) | |||
| 240 | return next; | 240 | return next; |
| 241 | } | 241 | } |
| 242 | 242 | ||
| 243 | static unsigned long do_brk(unsigned long addr, unsigned long len); | ||
| 244 | |||
| 243 | SYSCALL_DEFINE1(brk, unsigned long, brk) | 245 | SYSCALL_DEFINE1(brk, unsigned long, brk) |
| 244 | { | 246 | { |
| 245 | unsigned long rlim, retval; | 247 | unsigned long rlim, retval; |
| @@ -951,7 +953,7 @@ static inline unsigned long round_hint_to_min(unsigned long hint) | |||
| 951 | * The caller must hold down_write(¤t->mm->mmap_sem). | 953 | * The caller must hold down_write(¤t->mm->mmap_sem). |
| 952 | */ | 954 | */ |
| 953 | 955 | ||
| 954 | unsigned long do_mmap_pgoff(struct file *file, unsigned long addr, | 956 | static unsigned long do_mmap_pgoff(struct file *file, unsigned long addr, |
| 955 | unsigned long len, unsigned long prot, | 957 | unsigned long len, unsigned long prot, |
| 956 | unsigned long flags, unsigned long pgoff) | 958 | unsigned long flags, unsigned long pgoff) |
| 957 | { | 959 | { |
| @@ -1087,7 +1089,32 @@ unsigned long do_mmap_pgoff(struct file *file, unsigned long addr, | |||
| 1087 | 1089 | ||
| 1088 | return mmap_region(file, addr, len, flags, vm_flags, pgoff); | 1090 | return mmap_region(file, addr, len, flags, vm_flags, pgoff); |
| 1089 | } | 1091 | } |
| 1090 | EXPORT_SYMBOL(do_mmap_pgoff); | 1092 | |
| 1093 | unsigned long do_mmap(struct file *file, unsigned long addr, | ||
| 1094 | unsigned long len, unsigned long prot, | ||
| 1095 | unsigned long flag, unsigned long offset) | ||
| 1096 | { | ||
| 1097 | if (unlikely(offset + PAGE_ALIGN(len) < offset)) | ||
| 1098 | return -EINVAL; | ||
| 1099 | if (unlikely(offset & ~PAGE_MASK)) | ||
| 1100 | return -EINVAL; | ||
| 1101 | return do_mmap_pgoff(file, addr, len, prot, flag, offset >> PAGE_SHIFT); | ||
| 1102 | } | ||
| 1103 | EXPORT_SYMBOL(do_mmap); | ||
| 1104 | |||
| 1105 | unsigned long vm_mmap(struct file *file, unsigned long addr, | ||
| 1106 | unsigned long len, unsigned long prot, | ||
| 1107 | unsigned long flag, unsigned long offset) | ||
| 1108 | { | ||
| 1109 | unsigned long ret; | ||
| 1110 | struct mm_struct *mm = current->mm; | ||
| 1111 | |||
| 1112 | down_write(&mm->mmap_sem); | ||
| 1113 | ret = do_mmap(file, addr, len, prot, flag, offset); | ||
| 1114 | up_write(&mm->mmap_sem); | ||
| 1115 | return ret; | ||
| 1116 | } | ||
| 1117 | EXPORT_SYMBOL(vm_mmap); | ||
| 1091 | 1118 | ||
| 1092 | SYSCALL_DEFINE6(mmap_pgoff, unsigned long, addr, unsigned long, len, | 1119 | SYSCALL_DEFINE6(mmap_pgoff, unsigned long, addr, unsigned long, len, |
| 1093 | unsigned long, prot, unsigned long, flags, | 1120 | unsigned long, prot, unsigned long, flags, |
| @@ -2105,21 +2132,25 @@ int do_munmap(struct mm_struct *mm, unsigned long start, size_t len) | |||
| 2105 | 2132 | ||
| 2106 | return 0; | 2133 | return 0; |
| 2107 | } | 2134 | } |
| 2108 | |||
| 2109 | EXPORT_SYMBOL(do_munmap); | 2135 | EXPORT_SYMBOL(do_munmap); |
| 2110 | 2136 | ||
| 2111 | SYSCALL_DEFINE2(munmap, unsigned long, addr, size_t, len) | 2137 | int vm_munmap(unsigned long start, size_t len) |
| 2112 | { | 2138 | { |
| 2113 | int ret; | 2139 | int ret; |
| 2114 | struct mm_struct *mm = current->mm; | 2140 | struct mm_struct *mm = current->mm; |
| 2115 | 2141 | ||
| 2116 | profile_munmap(addr); | ||
| 2117 | |||
| 2118 | down_write(&mm->mmap_sem); | 2142 | down_write(&mm->mmap_sem); |
| 2119 | ret = do_munmap(mm, addr, len); | 2143 | ret = do_munmap(mm, start, len); |
| 2120 | up_write(&mm->mmap_sem); | 2144 | up_write(&mm->mmap_sem); |
| 2121 | return ret; | 2145 | return ret; |
| 2122 | } | 2146 | } |
| 2147 | EXPORT_SYMBOL(vm_munmap); | ||
| 2148 | |||
| 2149 | SYSCALL_DEFINE2(munmap, unsigned long, addr, size_t, len) | ||
| 2150 | { | ||
| 2151 | profile_munmap(addr); | ||
| 2152 | return vm_munmap(addr, len); | ||
| 2153 | } | ||
| 2123 | 2154 | ||
| 2124 | static inline void verify_mm_writelocked(struct mm_struct *mm) | 2155 | static inline void verify_mm_writelocked(struct mm_struct *mm) |
| 2125 | { | 2156 | { |
| @@ -2136,7 +2167,7 @@ static inline void verify_mm_writelocked(struct mm_struct *mm) | |||
| 2136 | * anonymous maps. eventually we may be able to do some | 2167 | * anonymous maps. eventually we may be able to do some |
| 2137 | * brk-specific accounting here. | 2168 | * brk-specific accounting here. |
| 2138 | */ | 2169 | */ |
| 2139 | unsigned long do_brk(unsigned long addr, unsigned long len) | 2170 | static unsigned long do_brk(unsigned long addr, unsigned long len) |
| 2140 | { | 2171 | { |
| 2141 | struct mm_struct * mm = current->mm; | 2172 | struct mm_struct * mm = current->mm; |
| 2142 | struct vm_area_struct * vma, * prev; | 2173 | struct vm_area_struct * vma, * prev; |
| @@ -2232,7 +2263,17 @@ out: | |||
| 2232 | return addr; | 2263 | return addr; |
| 2233 | } | 2264 | } |
| 2234 | 2265 | ||
| 2235 | EXPORT_SYMBOL(do_brk); | 2266 | unsigned long vm_brk(unsigned long addr, unsigned long len) |
| 2267 | { | ||
| 2268 | struct mm_struct *mm = current->mm; | ||
| 2269 | unsigned long ret; | ||
| 2270 | |||
| 2271 | down_write(&mm->mmap_sem); | ||
| 2272 | ret = do_brk(addr, len); | ||
| 2273 | up_write(&mm->mmap_sem); | ||
| 2274 | return ret; | ||
| 2275 | } | ||
| 2276 | EXPORT_SYMBOL(vm_brk); | ||
| 2236 | 2277 | ||
| 2237 | /* Release all mmaps. */ | 2278 | /* Release all mmaps. */ |
| 2238 | void exit_mmap(struct mm_struct *mm) | 2279 | void exit_mmap(struct mm_struct *mm) |
diff --git a/mm/nommu.c b/mm/nommu.c index f59e170fceb4..bb8f4f004a82 100644 --- a/mm/nommu.c +++ b/mm/nommu.c | |||
| @@ -1233,7 +1233,7 @@ enomem: | |||
| 1233 | /* | 1233 | /* |
| 1234 | * handle mapping creation for uClinux | 1234 | * handle mapping creation for uClinux |
| 1235 | */ | 1235 | */ |
| 1236 | unsigned long do_mmap_pgoff(struct file *file, | 1236 | static unsigned long do_mmap_pgoff(struct file *file, |
| 1237 | unsigned long addr, | 1237 | unsigned long addr, |
| 1238 | unsigned long len, | 1238 | unsigned long len, |
| 1239 | unsigned long prot, | 1239 | unsigned long prot, |
| @@ -1470,7 +1470,32 @@ error_getting_region: | |||
| 1470 | show_free_areas(0); | 1470 | show_free_areas(0); |
| 1471 | return -ENOMEM; | 1471 | return -ENOMEM; |
| 1472 | } | 1472 | } |
| 1473 | EXPORT_SYMBOL(do_mmap_pgoff); | 1473 | |
| 1474 | unsigned long do_mmap(struct file *file, unsigned long addr, | ||
| 1475 | unsigned long len, unsigned long prot, | ||
| 1476 | unsigned long flag, unsigned long offset) | ||
| 1477 | { | ||
| 1478 | if (unlikely(offset + PAGE_ALIGN(len) < offset)) | ||
| 1479 | return -EINVAL; | ||
| 1480 | if (unlikely(offset & ~PAGE_MASK)) | ||
| 1481 | return -EINVAL; | ||
| 1482 | return do_mmap_pgoff(file, addr, len, prot, flag, offset >> PAGE_SHIFT); | ||
| 1483 | } | ||
| 1484 | EXPORT_SYMBOL(do_mmap); | ||
| 1485 | |||
| 1486 | unsigned long vm_mmap(struct file *file, unsigned long addr, | ||
| 1487 | unsigned long len, unsigned long prot, | ||
| 1488 | unsigned long flag, unsigned long offset) | ||
| 1489 | { | ||
| 1490 | unsigned long ret; | ||
| 1491 | struct mm_struct *mm = current->mm; | ||
| 1492 | |||
| 1493 | down_write(&mm->mmap_sem); | ||
| 1494 | ret = do_mmap(file, addr, len, prot, flag, offset); | ||
| 1495 | up_write(&mm->mmap_sem); | ||
| 1496 | return ret; | ||
| 1497 | } | ||
| 1498 | EXPORT_SYMBOL(vm_mmap); | ||
| 1474 | 1499 | ||
| 1475 | SYSCALL_DEFINE6(mmap_pgoff, unsigned long, addr, unsigned long, len, | 1500 | SYSCALL_DEFINE6(mmap_pgoff, unsigned long, addr, unsigned long, len, |
| 1476 | unsigned long, prot, unsigned long, flags, | 1501 | unsigned long, prot, unsigned long, flags, |
| @@ -1709,16 +1734,22 @@ erase_whole_vma: | |||
| 1709 | } | 1734 | } |
| 1710 | EXPORT_SYMBOL(do_munmap); | 1735 | EXPORT_SYMBOL(do_munmap); |
| 1711 | 1736 | ||
| 1712 | SYSCALL_DEFINE2(munmap, unsigned long, addr, size_t, len) | 1737 | int vm_munmap(unsigned long addr, size_t len) |
| 1713 | { | 1738 | { |
| 1714 | int ret; | ||
| 1715 | struct mm_struct *mm = current->mm; | 1739 | struct mm_struct *mm = current->mm; |
| 1740 | int ret; | ||
| 1716 | 1741 | ||
| 1717 | down_write(&mm->mmap_sem); | 1742 | down_write(&mm->mmap_sem); |
| 1718 | ret = do_munmap(mm, addr, len); | 1743 | ret = do_munmap(mm, addr, len); |
| 1719 | up_write(&mm->mmap_sem); | 1744 | up_write(&mm->mmap_sem); |
| 1720 | return ret; | 1745 | return ret; |
| 1721 | } | 1746 | } |
| 1747 | EXPORT_SYMBOL(vm_munmap); | ||
| 1748 | |||
| 1749 | SYSCALL_DEFINE2(munmap, unsigned long, addr, size_t, len) | ||
| 1750 | { | ||
| 1751 | return vm_munmap(addr, len); | ||
| 1752 | } | ||
| 1722 | 1753 | ||
| 1723 | /* | 1754 | /* |
| 1724 | * release all the mappings made in a process's VM space | 1755 | * release all the mappings made in a process's VM space |
| @@ -1744,7 +1775,7 @@ void exit_mmap(struct mm_struct *mm) | |||
| 1744 | kleave(""); | 1775 | kleave(""); |
| 1745 | } | 1776 | } |
| 1746 | 1777 | ||
| 1747 | unsigned long do_brk(unsigned long addr, unsigned long len) | 1778 | unsigned long vm_brk(unsigned long addr, unsigned long len) |
| 1748 | { | 1779 | { |
| 1749 | return -ENOMEM; | 1780 | return -ENOMEM; |
| 1750 | } | 1781 | } |
diff --git a/mm/swap_state.c b/mm/swap_state.c index 9d3dd3763cf7..4c5ff7f284d9 100644 --- a/mm/swap_state.c +++ b/mm/swap_state.c | |||
| @@ -26,7 +26,7 @@ | |||
| 26 | */ | 26 | */ |
| 27 | static const struct address_space_operations swap_aops = { | 27 | static const struct address_space_operations swap_aops = { |
| 28 | .writepage = swap_writepage, | 28 | .writepage = swap_writepage, |
| 29 | .set_page_dirty = __set_page_dirty_nobuffers, | 29 | .set_page_dirty = __set_page_dirty_no_writeback, |
| 30 | .migratepage = migrate_page, | 30 | .migratepage = migrate_page, |
| 31 | }; | 31 | }; |
| 32 | 32 | ||
diff --git a/net/ax25/af_ax25.c b/net/ax25/af_ax25.c index 282eb76bc7d6..051f7abae66d 100644 --- a/net/ax25/af_ax25.c +++ b/net/ax25/af_ax25.c | |||
| @@ -2010,9 +2010,6 @@ static void __exit ax25_exit(void) | |||
| 2010 | proc_net_remove(&init_net, "ax25_route"); | 2010 | proc_net_remove(&init_net, "ax25_route"); |
| 2011 | proc_net_remove(&init_net, "ax25"); | 2011 | proc_net_remove(&init_net, "ax25"); |
| 2012 | proc_net_remove(&init_net, "ax25_calls"); | 2012 | proc_net_remove(&init_net, "ax25_calls"); |
| 2013 | ax25_rt_free(); | ||
| 2014 | ax25_uid_free(); | ||
| 2015 | ax25_dev_free(); | ||
| 2016 | 2013 | ||
| 2017 | unregister_netdevice_notifier(&ax25_dev_notifier); | 2014 | unregister_netdevice_notifier(&ax25_dev_notifier); |
| 2018 | 2015 | ||
| @@ -2020,5 +2017,9 @@ static void __exit ax25_exit(void) | |||
| 2020 | 2017 | ||
| 2021 | sock_unregister(PF_AX25); | 2018 | sock_unregister(PF_AX25); |
| 2022 | proto_unregister(&ax25_proto); | 2019 | proto_unregister(&ax25_proto); |
| 2020 | |||
| 2021 | ax25_rt_free(); | ||
| 2022 | ax25_uid_free(); | ||
| 2023 | ax25_dev_free(); | ||
| 2023 | } | 2024 | } |
| 2024 | module_exit(ax25_exit); | 2025 | module_exit(ax25_exit); |
diff --git a/net/core/drop_monitor.c b/net/core/drop_monitor.c index 7f36b38e060f..5c3c81a609e5 100644 --- a/net/core/drop_monitor.c +++ b/net/core/drop_monitor.c | |||
| @@ -150,6 +150,7 @@ static void trace_drop_common(struct sk_buff *skb, void *location) | |||
| 150 | for (i = 0; i < msg->entries; i++) { | 150 | for (i = 0; i < msg->entries; i++) { |
| 151 | if (!memcmp(&location, msg->points[i].pc, sizeof(void *))) { | 151 | if (!memcmp(&location, msg->points[i].pc, sizeof(void *))) { |
| 152 | msg->points[i].count++; | 152 | msg->points[i].count++; |
| 153 | atomic_inc(&data->dm_hit_count); | ||
| 153 | goto out; | 154 | goto out; |
| 154 | } | 155 | } |
| 155 | } | 156 | } |
diff --git a/net/core/net_namespace.c b/net/core/net_namespace.c index 0e950fda9a0a..31a5ae51a45c 100644 --- a/net/core/net_namespace.c +++ b/net/core/net_namespace.c | |||
| @@ -83,21 +83,29 @@ assign: | |||
| 83 | 83 | ||
| 84 | static int ops_init(const struct pernet_operations *ops, struct net *net) | 84 | static int ops_init(const struct pernet_operations *ops, struct net *net) |
| 85 | { | 85 | { |
| 86 | int err; | 86 | int err = -ENOMEM; |
| 87 | void *data = NULL; | ||
| 88 | |||
| 87 | if (ops->id && ops->size) { | 89 | if (ops->id && ops->size) { |
| 88 | void *data = kzalloc(ops->size, GFP_KERNEL); | 90 | data = kzalloc(ops->size, GFP_KERNEL); |
| 89 | if (!data) | 91 | if (!data) |
| 90 | return -ENOMEM; | 92 | goto out; |
| 91 | 93 | ||
| 92 | err = net_assign_generic(net, *ops->id, data); | 94 | err = net_assign_generic(net, *ops->id, data); |
| 93 | if (err) { | 95 | if (err) |
| 94 | kfree(data); | 96 | goto cleanup; |
| 95 | return err; | ||
| 96 | } | ||
| 97 | } | 97 | } |
| 98 | err = 0; | ||
| 98 | if (ops->init) | 99 | if (ops->init) |
| 99 | return ops->init(net); | 100 | err = ops->init(net); |
| 100 | return 0; | 101 | if (!err) |
| 102 | return 0; | ||
| 103 | |||
| 104 | cleanup: | ||
| 105 | kfree(data); | ||
| 106 | |||
| 107 | out: | ||
| 108 | return err; | ||
| 101 | } | 109 | } |
| 102 | 110 | ||
| 103 | static void ops_free(const struct pernet_operations *ops, struct net *net) | 111 | static void ops_free(const struct pernet_operations *ops, struct net *net) |
| @@ -448,12 +456,7 @@ static void __unregister_pernet_operations(struct pernet_operations *ops) | |||
| 448 | static int __register_pernet_operations(struct list_head *list, | 456 | static int __register_pernet_operations(struct list_head *list, |
| 449 | struct pernet_operations *ops) | 457 | struct pernet_operations *ops) |
| 450 | { | 458 | { |
| 451 | int err = 0; | 459 | return ops_init(ops, &init_net); |
| 452 | err = ops_init(ops, &init_net); | ||
| 453 | if (err) | ||
| 454 | ops_free(ops, &init_net); | ||
| 455 | return err; | ||
| 456 | |||
| 457 | } | 460 | } |
| 458 | 461 | ||
| 459 | static void __unregister_pernet_operations(struct pernet_operations *ops) | 462 | static void __unregister_pernet_operations(struct pernet_operations *ops) |
diff --git a/net/ipv4/tcp_input.c b/net/ipv4/tcp_input.c index bd7aef59c385..c1c611b385a7 100644 --- a/net/ipv4/tcp_input.c +++ b/net/ipv4/tcp_input.c | |||
| @@ -335,6 +335,7 @@ static void tcp_grow_window(struct sock *sk, const struct sk_buff *skb) | |||
| 335 | incr = __tcp_grow_window(sk, skb); | 335 | incr = __tcp_grow_window(sk, skb); |
| 336 | 336 | ||
| 337 | if (incr) { | 337 | if (incr) { |
| 338 | incr = max_t(int, incr, 2 * skb->len); | ||
| 338 | tp->rcv_ssthresh = min(tp->rcv_ssthresh + incr, | 339 | tp->rcv_ssthresh = min(tp->rcv_ssthresh + incr, |
| 339 | tp->window_clamp); | 340 | tp->window_clamp); |
| 340 | inet_csk(sk)->icsk_ack.quick |= 1; | 341 | inet_csk(sk)->icsk_ack.quick |= 1; |
diff --git a/net/ipv4/tcp_output.c b/net/ipv4/tcp_output.c index 57a834cafca1..7b7cf3811348 100644 --- a/net/ipv4/tcp_output.c +++ b/net/ipv4/tcp_output.c | |||
| @@ -1096,6 +1096,7 @@ static void __pskb_trim_head(struct sk_buff *skb, int len) | |||
| 1096 | eat = min_t(int, len, skb_headlen(skb)); | 1096 | eat = min_t(int, len, skb_headlen(skb)); |
| 1097 | if (eat) { | 1097 | if (eat) { |
| 1098 | __skb_pull(skb, eat); | 1098 | __skb_pull(skb, eat); |
| 1099 | skb->avail_size -= eat; | ||
| 1099 | len -= eat; | 1100 | len -= eat; |
| 1100 | if (!len) | 1101 | if (!len) |
| 1101 | return; | 1102 | return; |
diff --git a/net/ipv6/tcp_ipv6.c b/net/ipv6/tcp_ipv6.c index 5fb19d345cfd..cdbf292ad208 100644 --- a/net/ipv6/tcp_ipv6.c +++ b/net/ipv6/tcp_ipv6.c | |||
| @@ -1383,6 +1383,10 @@ static struct sock * tcp_v6_syn_recv_sock(struct sock *sk, struct sk_buff *skb, | |||
| 1383 | tcp_mtup_init(newsk); | 1383 | tcp_mtup_init(newsk); |
| 1384 | tcp_sync_mss(newsk, dst_mtu(dst)); | 1384 | tcp_sync_mss(newsk, dst_mtu(dst)); |
| 1385 | newtp->advmss = dst_metric_advmss(dst); | 1385 | newtp->advmss = dst_metric_advmss(dst); |
| 1386 | if (tcp_sk(sk)->rx_opt.user_mss && | ||
| 1387 | tcp_sk(sk)->rx_opt.user_mss < newtp->advmss) | ||
| 1388 | newtp->advmss = tcp_sk(sk)->rx_opt.user_mss; | ||
| 1389 | |||
| 1386 | tcp_initialize_rcv_mss(newsk); | 1390 | tcp_initialize_rcv_mss(newsk); |
| 1387 | if (tcp_rsk(req)->snt_synack) | 1391 | if (tcp_rsk(req)->snt_synack) |
| 1388 | tcp_valid_rtt_meas(newsk, | 1392 | tcp_valid_rtt_meas(newsk, |
diff --git a/net/mac80211/ibss.c b/net/mac80211/ibss.c index 49a207980338..61cd391c32a3 100644 --- a/net/mac80211/ibss.c +++ b/net/mac80211/ibss.c | |||
| @@ -455,8 +455,8 @@ static void ieee80211_rx_bss_info(struct ieee80211_sub_if_data *sdata, | |||
| 455 | * fall back to HT20 if we don't use or use | 455 | * fall back to HT20 if we don't use or use |
| 456 | * the other extension channel | 456 | * the other extension channel |
| 457 | */ | 457 | */ |
| 458 | if ((channel_type == NL80211_CHAN_HT40MINUS || | 458 | if (!(channel_type == NL80211_CHAN_HT40MINUS || |
| 459 | channel_type == NL80211_CHAN_HT40PLUS) && | 459 | channel_type == NL80211_CHAN_HT40PLUS) || |
| 460 | channel_type != sdata->u.ibss.channel_type) | 460 | channel_type != sdata->u.ibss.channel_type) |
| 461 | sta_ht_cap_new.cap &= | 461 | sta_ht_cap_new.cap &= |
| 462 | ~IEEE80211_HT_CAP_SUP_WIDTH_20_40; | 462 | ~IEEE80211_HT_CAP_SUP_WIDTH_20_40; |
diff --git a/net/mac80211/rx.c b/net/mac80211/rx.c index 54a049123a60..7cbb4aad0577 100644 --- a/net/mac80211/rx.c +++ b/net/mac80211/rx.c | |||
| @@ -103,7 +103,7 @@ static void | |||
| 103 | ieee80211_add_rx_radiotap_header(struct ieee80211_local *local, | 103 | ieee80211_add_rx_radiotap_header(struct ieee80211_local *local, |
| 104 | struct sk_buff *skb, | 104 | struct sk_buff *skb, |
| 105 | struct ieee80211_rate *rate, | 105 | struct ieee80211_rate *rate, |
| 106 | int rtap_len) | 106 | int rtap_len, bool has_fcs) |
| 107 | { | 107 | { |
| 108 | struct ieee80211_rx_status *status = IEEE80211_SKB_RXCB(skb); | 108 | struct ieee80211_rx_status *status = IEEE80211_SKB_RXCB(skb); |
| 109 | struct ieee80211_radiotap_header *rthdr; | 109 | struct ieee80211_radiotap_header *rthdr; |
| @@ -134,7 +134,7 @@ ieee80211_add_rx_radiotap_header(struct ieee80211_local *local, | |||
| 134 | } | 134 | } |
| 135 | 135 | ||
| 136 | /* IEEE80211_RADIOTAP_FLAGS */ | 136 | /* IEEE80211_RADIOTAP_FLAGS */ |
| 137 | if (local->hw.flags & IEEE80211_HW_RX_INCLUDES_FCS) | 137 | if (has_fcs && (local->hw.flags & IEEE80211_HW_RX_INCLUDES_FCS)) |
| 138 | *pos |= IEEE80211_RADIOTAP_F_FCS; | 138 | *pos |= IEEE80211_RADIOTAP_F_FCS; |
| 139 | if (status->flag & (RX_FLAG_FAILED_FCS_CRC | RX_FLAG_FAILED_PLCP_CRC)) | 139 | if (status->flag & (RX_FLAG_FAILED_FCS_CRC | RX_FLAG_FAILED_PLCP_CRC)) |
| 140 | *pos |= IEEE80211_RADIOTAP_F_BADFCS; | 140 | *pos |= IEEE80211_RADIOTAP_F_BADFCS; |
| @@ -294,7 +294,8 @@ ieee80211_rx_monitor(struct ieee80211_local *local, struct sk_buff *origskb, | |||
| 294 | } | 294 | } |
| 295 | 295 | ||
| 296 | /* prepend radiotap information */ | 296 | /* prepend radiotap information */ |
| 297 | ieee80211_add_rx_radiotap_header(local, skb, rate, needed_headroom); | 297 | ieee80211_add_rx_radiotap_header(local, skb, rate, needed_headroom, |
| 298 | true); | ||
| 298 | 299 | ||
| 299 | skb_reset_mac_header(skb); | 300 | skb_reset_mac_header(skb); |
| 300 | skb->ip_summed = CHECKSUM_UNNECESSARY; | 301 | skb->ip_summed = CHECKSUM_UNNECESSARY; |
| @@ -2567,7 +2568,8 @@ static void ieee80211_rx_cooked_monitor(struct ieee80211_rx_data *rx, | |||
| 2567 | goto out_free_skb; | 2568 | goto out_free_skb; |
| 2568 | 2569 | ||
| 2569 | /* prepend radiotap information */ | 2570 | /* prepend radiotap information */ |
| 2570 | ieee80211_add_rx_radiotap_header(local, skb, rate, needed_headroom); | 2571 | ieee80211_add_rx_radiotap_header(local, skb, rate, needed_headroom, |
| 2572 | false); | ||
| 2571 | 2573 | ||
| 2572 | skb_set_mac_header(skb, 0); | 2574 | skb_set_mac_header(skb, 0); |
| 2573 | skb->ip_summed = CHECKSUM_UNNECESSARY; | 2575 | skb->ip_summed = CHECKSUM_UNNECESSARY; |
diff --git a/net/sched/sch_gred.c b/net/sched/sch_gred.c index 55e3310edc94..ab620bf90785 100644 --- a/net/sched/sch_gred.c +++ b/net/sched/sch_gred.c | |||
| @@ -567,11 +567,8 @@ static int gred_dump(struct Qdisc *sch, struct sk_buff *skb) | |||
| 567 | opt.packets = q->packetsin; | 567 | opt.packets = q->packetsin; |
| 568 | opt.bytesin = q->bytesin; | 568 | opt.bytesin = q->bytesin; |
| 569 | 569 | ||
| 570 | if (gred_wred_mode(table)) { | 570 | if (gred_wred_mode(table)) |
| 571 | q->vars.qidlestart = | 571 | gred_load_wred_set(table, q); |
| 572 | table->tab[table->def]->vars.qidlestart; | ||
| 573 | q->vars.qavg = table->tab[table->def]->vars.qavg; | ||
| 574 | } | ||
| 575 | 572 | ||
| 576 | opt.qave = red_calc_qavg(&q->parms, &q->vars, q->vars.qavg); | 573 | opt.qave = red_calc_qavg(&q->parms, &q->vars, q->vars.qavg); |
| 577 | 574 | ||
diff --git a/net/wireless/util.c b/net/wireless/util.c index ffced852284d..6cba00173a2f 100644 --- a/net/wireless/util.c +++ b/net/wireless/util.c | |||
| @@ -985,7 +985,7 @@ int cfg80211_can_change_interface(struct cfg80211_registered_device *rdev, | |||
| 985 | if (rdev->wiphy.software_iftypes & BIT(iftype)) | 985 | if (rdev->wiphy.software_iftypes & BIT(iftype)) |
| 986 | continue; | 986 | continue; |
| 987 | for (j = 0; j < c->n_limits; j++) { | 987 | for (j = 0; j < c->n_limits; j++) { |
| 988 | if (!(limits[j].types & iftype)) | 988 | if (!(limits[j].types & BIT(iftype))) |
| 989 | continue; | 989 | continue; |
| 990 | if (limits[j].max < num[iftype]) | 990 | if (limits[j].max < num[iftype]) |
| 991 | goto cont; | 991 | goto cont; |
diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl index de639eeeed50..faea0ec612bf 100755 --- a/scripts/checkpatch.pl +++ b/scripts/checkpatch.pl | |||
| @@ -1869,12 +1869,6 @@ sub process { | |||
| 1869 | "No space is necessary after a cast\n" . $hereprev); | 1869 | "No space is necessary after a cast\n" . $hereprev); |
| 1870 | } | 1870 | } |
| 1871 | 1871 | ||
| 1872 | if ($rawline =~ /^\+[ \t]*\/\*[ \t]*$/ && | ||
| 1873 | $prevrawline =~ /^\+[ \t]*$/) { | ||
| 1874 | CHK("BLOCK_COMMENT_STYLE", | ||
| 1875 | "Don't begin block comments with only a /* line, use /* comment...\n" . $hereprev); | ||
| 1876 | } | ||
| 1877 | |||
| 1878 | # check for spaces at the beginning of a line. | 1872 | # check for spaces at the beginning of a line. |
| 1879 | # Exceptions: | 1873 | # Exceptions: |
| 1880 | # 1) within comments | 1874 | # 1) within comments |
diff --git a/scripts/kconfig/confdata.c b/scripts/kconfig/confdata.c index 0586085136d1..52577f052bc1 100644 --- a/scripts/kconfig/confdata.c +++ b/scripts/kconfig/confdata.c | |||
| @@ -540,35 +540,6 @@ static struct conf_printer header_printer_cb = | |||
| 540 | }; | 540 | }; |
| 541 | 541 | ||
| 542 | /* | 542 | /* |
| 543 | * Generate the __enabled_CONFIG_* and __enabled_CONFIG_*_MODULE macros for | ||
| 544 | * use by the IS_{ENABLED,BUILTIN,MODULE} macros. The _MODULE variant is | ||
| 545 | * generated even for booleans so that the IS_ENABLED() macro works. | ||
| 546 | */ | ||
| 547 | static void | ||
| 548 | header_print__enabled_symbol(FILE *fp, struct symbol *sym, const char *value, void *arg) | ||
| 549 | { | ||
| 550 | |||
| 551 | switch (sym->type) { | ||
| 552 | case S_BOOLEAN: | ||
| 553 | case S_TRISTATE: { | ||
| 554 | fprintf(fp, "#define __enabled_" CONFIG_ "%s %d\n", | ||
| 555 | sym->name, (*value == 'y')); | ||
| 556 | fprintf(fp, "#define __enabled_" CONFIG_ "%s_MODULE %d\n", | ||
| 557 | sym->name, (*value == 'm')); | ||
| 558 | break; | ||
| 559 | } | ||
| 560 | default: | ||
| 561 | break; | ||
| 562 | } | ||
| 563 | } | ||
| 564 | |||
| 565 | static struct conf_printer header__enabled_printer_cb = | ||
| 566 | { | ||
| 567 | .print_symbol = header_print__enabled_symbol, | ||
| 568 | .print_comment = header_print_comment, | ||
| 569 | }; | ||
| 570 | |||
| 571 | /* | ||
| 572 | * Tristate printer | 543 | * Tristate printer |
| 573 | * | 544 | * |
| 574 | * This printer is used when generating the `include/config/tristate.conf' file. | 545 | * This printer is used when generating the `include/config/tristate.conf' file. |
| @@ -949,16 +920,11 @@ int conf_write_autoconf(void) | |||
| 949 | conf_write_heading(out_h, &header_printer_cb, NULL); | 920 | conf_write_heading(out_h, &header_printer_cb, NULL); |
| 950 | 921 | ||
| 951 | for_all_symbols(i, sym) { | 922 | for_all_symbols(i, sym) { |
| 952 | if (!sym->name) | ||
| 953 | continue; | ||
| 954 | |||
| 955 | sym_calc_value(sym); | 923 | sym_calc_value(sym); |
| 956 | 924 | if (!(sym->flags & SYMBOL_WRITE) || !sym->name) | |
| 957 | conf_write_symbol(out_h, sym, &header__enabled_printer_cb, NULL); | ||
| 958 | |||
| 959 | if (!(sym->flags & SYMBOL_WRITE)) | ||
| 960 | continue; | 925 | continue; |
| 961 | 926 | ||
| 927 | /* write symbol to auto.conf, tristate and header files */ | ||
| 962 | conf_write_symbol(out, sym, &kconfig_printer_cb, (void *)1); | 928 | conf_write_symbol(out, sym, &kconfig_printer_cb, (void *)1); |
| 963 | 929 | ||
| 964 | conf_write_symbol(tristate, sym, &tristate_printer_cb, (void *)1); | 930 | conf_write_symbol(tristate, sym, &tristate_printer_cb, (void *)1); |
diff --git a/scripts/xz_wrap.sh b/scripts/xz_wrap.sh index 17a5798c29da..7a2d372f4885 100644 --- a/scripts/xz_wrap.sh +++ b/scripts/xz_wrap.sh | |||
| @@ -12,8 +12,8 @@ | |||
| 12 | BCJ= | 12 | BCJ= |
| 13 | LZMA2OPTS= | 13 | LZMA2OPTS= |
| 14 | 14 | ||
| 15 | case $ARCH in | 15 | case $SRCARCH in |
| 16 | x86|x86_64) BCJ=--x86 ;; | 16 | x86) BCJ=--x86 ;; |
| 17 | powerpc) BCJ=--powerpc ;; | 17 | powerpc) BCJ=--powerpc ;; |
| 18 | ia64) BCJ=--ia64; LZMA2OPTS=pb=4 ;; | 18 | ia64) BCJ=--ia64; LZMA2OPTS=pb=4 ;; |
| 19 | arm) BCJ=--arm ;; | 19 | arm) BCJ=--arm ;; |
diff --git a/security/commoncap.c b/security/commoncap.c index 0cf4b53480a7..71a166a05975 100644 --- a/security/commoncap.c +++ b/security/commoncap.c | |||
| @@ -29,6 +29,7 @@ | |||
| 29 | #include <linux/securebits.h> | 29 | #include <linux/securebits.h> |
| 30 | #include <linux/user_namespace.h> | 30 | #include <linux/user_namespace.h> |
| 31 | #include <linux/binfmts.h> | 31 | #include <linux/binfmts.h> |
| 32 | #include <linux/personality.h> | ||
| 32 | 33 | ||
| 33 | /* | 34 | /* |
| 34 | * If a non-root user executes a setuid-root binary in | 35 | * If a non-root user executes a setuid-root binary in |
| @@ -505,6 +506,11 @@ int cap_bprm_set_creds(struct linux_binprm *bprm) | |||
| 505 | } | 506 | } |
| 506 | skip: | 507 | skip: |
| 507 | 508 | ||
| 509 | /* if we have fs caps, clear dangerous personality flags */ | ||
| 510 | if (!cap_issubset(new->cap_permitted, old->cap_permitted)) | ||
| 511 | bprm->per_clear |= PER_CLEAR_ON_SETID; | ||
| 512 | |||
| 513 | |||
| 508 | /* Don't let someone trace a set[ug]id/setpcap binary with the revised | 514 | /* Don't let someone trace a set[ug]id/setpcap binary with the revised |
| 509 | * credentials unless they have the appropriate permit | 515 | * credentials unless they have the appropriate permit |
| 510 | */ | 516 | */ |
diff --git a/security/smack/smack_lsm.c b/security/smack/smack_lsm.c index 10056f2f6df3..45c32f074166 100644 --- a/security/smack/smack_lsm.c +++ b/security/smack/smack_lsm.c | |||
| @@ -3640,8 +3640,38 @@ struct security_operations smack_ops = { | |||
| 3640 | }; | 3640 | }; |
| 3641 | 3641 | ||
| 3642 | 3642 | ||
| 3643 | static __init void init_smack_know_list(void) | 3643 | static __init void init_smack_known_list(void) |
| 3644 | { | 3644 | { |
| 3645 | /* | ||
| 3646 | * Initialize CIPSO locks | ||
| 3647 | */ | ||
| 3648 | spin_lock_init(&smack_known_huh.smk_cipsolock); | ||
| 3649 | spin_lock_init(&smack_known_hat.smk_cipsolock); | ||
| 3650 | spin_lock_init(&smack_known_star.smk_cipsolock); | ||
| 3651 | spin_lock_init(&smack_known_floor.smk_cipsolock); | ||
| 3652 | spin_lock_init(&smack_known_invalid.smk_cipsolock); | ||
| 3653 | spin_lock_init(&smack_known_web.smk_cipsolock); | ||
| 3654 | /* | ||
| 3655 | * Initialize rule list locks | ||
| 3656 | */ | ||
| 3657 | mutex_init(&smack_known_huh.smk_rules_lock); | ||
| 3658 | mutex_init(&smack_known_hat.smk_rules_lock); | ||
| 3659 | mutex_init(&smack_known_floor.smk_rules_lock); | ||
| 3660 | mutex_init(&smack_known_star.smk_rules_lock); | ||
| 3661 | mutex_init(&smack_known_invalid.smk_rules_lock); | ||
| 3662 | mutex_init(&smack_known_web.smk_rules_lock); | ||
| 3663 | /* | ||
| 3664 | * Initialize rule lists | ||
| 3665 | */ | ||
| 3666 | INIT_LIST_HEAD(&smack_known_huh.smk_rules); | ||
| 3667 | INIT_LIST_HEAD(&smack_known_hat.smk_rules); | ||
| 3668 | INIT_LIST_HEAD(&smack_known_star.smk_rules); | ||
| 3669 | INIT_LIST_HEAD(&smack_known_floor.smk_rules); | ||
| 3670 | INIT_LIST_HEAD(&smack_known_invalid.smk_rules); | ||
| 3671 | INIT_LIST_HEAD(&smack_known_web.smk_rules); | ||
| 3672 | /* | ||
| 3673 | * Create the known labels list | ||
| 3674 | */ | ||
| 3645 | list_add(&smack_known_huh.list, &smack_known_list); | 3675 | list_add(&smack_known_huh.list, &smack_known_list); |
| 3646 | list_add(&smack_known_hat.list, &smack_known_list); | 3676 | list_add(&smack_known_hat.list, &smack_known_list); |
| 3647 | list_add(&smack_known_star.list, &smack_known_list); | 3677 | list_add(&smack_known_star.list, &smack_known_list); |
| @@ -3676,16 +3706,8 @@ static __init int smack_init(void) | |||
| 3676 | cred = (struct cred *) current->cred; | 3706 | cred = (struct cred *) current->cred; |
| 3677 | cred->security = tsp; | 3707 | cred->security = tsp; |
| 3678 | 3708 | ||
| 3679 | /* initialize the smack_know_list */ | 3709 | /* initialize the smack_known_list */ |
| 3680 | init_smack_know_list(); | 3710 | init_smack_known_list(); |
| 3681 | /* | ||
| 3682 | * Initialize locks | ||
| 3683 | */ | ||
| 3684 | spin_lock_init(&smack_known_huh.smk_cipsolock); | ||
| 3685 | spin_lock_init(&smack_known_hat.smk_cipsolock); | ||
| 3686 | spin_lock_init(&smack_known_star.smk_cipsolock); | ||
| 3687 | spin_lock_init(&smack_known_floor.smk_cipsolock); | ||
| 3688 | spin_lock_init(&smack_known_invalid.smk_cipsolock); | ||
| 3689 | 3711 | ||
| 3690 | /* | 3712 | /* |
| 3691 | * Register with LSM | 3713 | * Register with LSM |
diff --git a/security/smack/smackfs.c b/security/smack/smackfs.c index 5c32f36ff706..038811cb7e62 100644 --- a/security/smack/smackfs.c +++ b/security/smack/smackfs.c | |||
| @@ -1614,20 +1614,6 @@ static int __init init_smk_fs(void) | |||
| 1614 | smk_cipso_doi(); | 1614 | smk_cipso_doi(); |
| 1615 | smk_unlbl_ambient(NULL); | 1615 | smk_unlbl_ambient(NULL); |
| 1616 | 1616 | ||
| 1617 | mutex_init(&smack_known_floor.smk_rules_lock); | ||
| 1618 | mutex_init(&smack_known_hat.smk_rules_lock); | ||
| 1619 | mutex_init(&smack_known_huh.smk_rules_lock); | ||
| 1620 | mutex_init(&smack_known_invalid.smk_rules_lock); | ||
| 1621 | mutex_init(&smack_known_star.smk_rules_lock); | ||
| 1622 | mutex_init(&smack_known_web.smk_rules_lock); | ||
| 1623 | |||
| 1624 | INIT_LIST_HEAD(&smack_known_floor.smk_rules); | ||
| 1625 | INIT_LIST_HEAD(&smack_known_hat.smk_rules); | ||
| 1626 | INIT_LIST_HEAD(&smack_known_huh.smk_rules); | ||
| 1627 | INIT_LIST_HEAD(&smack_known_invalid.smk_rules); | ||
| 1628 | INIT_LIST_HEAD(&smack_known_star.smk_rules); | ||
| 1629 | INIT_LIST_HEAD(&smack_known_web.smk_rules); | ||
| 1630 | |||
| 1631 | return err; | 1617 | return err; |
| 1632 | } | 1618 | } |
| 1633 | 1619 | ||
diff --git a/sound/core/vmaster.c b/sound/core/vmaster.c index 14a286a7bf2b..857586135d18 100644 --- a/sound/core/vmaster.c +++ b/sound/core/vmaster.c | |||
| @@ -419,6 +419,7 @@ EXPORT_SYMBOL(snd_ctl_make_virtual_master); | |||
| 419 | * snd_ctl_add_vmaster_hook - Add a hook to a vmaster control | 419 | * snd_ctl_add_vmaster_hook - Add a hook to a vmaster control |
| 420 | * @kcontrol: vmaster kctl element | 420 | * @kcontrol: vmaster kctl element |
| 421 | * @hook: the hook function | 421 | * @hook: the hook function |
| 422 | * @private_data: the private_data pointer to be saved | ||
| 422 | * | 423 | * |
| 423 | * Adds the given hook to the vmaster control element so that it's called | 424 | * Adds the given hook to the vmaster control element so that it's called |
| 424 | * at each time when the value is changed. | 425 | * at each time when the value is changed. |
diff --git a/sound/last.c b/sound/last.c index bdd0857b8871..7ffc182e0844 100644 --- a/sound/last.c +++ b/sound/last.c | |||
| @@ -38,4 +38,4 @@ static int __init alsa_sound_last_init(void) | |||
| 38 | return 0; | 38 | return 0; |
| 39 | } | 39 | } |
| 40 | 40 | ||
| 41 | __initcall(alsa_sound_last_init); | 41 | late_initcall_sync(alsa_sound_last_init); |
diff --git a/sound/pci/hda/patch_conexant.c b/sound/pci/hda/patch_conexant.c index a36488d94aaa..d906c5b74cf0 100644 --- a/sound/pci/hda/patch_conexant.c +++ b/sound/pci/hda/patch_conexant.c | |||
| @@ -3971,9 +3971,14 @@ static void cx_auto_init_output(struct hda_codec *codec) | |||
| 3971 | int i; | 3971 | int i; |
| 3972 | 3972 | ||
| 3973 | mute_outputs(codec, spec->multiout.num_dacs, spec->multiout.dac_nids); | 3973 | mute_outputs(codec, spec->multiout.num_dacs, spec->multiout.dac_nids); |
| 3974 | for (i = 0; i < cfg->hp_outs; i++) | 3974 | for (i = 0; i < cfg->hp_outs; i++) { |
| 3975 | unsigned int val = PIN_OUT; | ||
| 3976 | if (snd_hda_query_pin_caps(codec, cfg->hp_pins[i]) & | ||
| 3977 | AC_PINCAP_HP_DRV) | ||
| 3978 | val |= AC_PINCTL_HP_EN; | ||
| 3975 | snd_hda_codec_write(codec, cfg->hp_pins[i], 0, | 3979 | snd_hda_codec_write(codec, cfg->hp_pins[i], 0, |
| 3976 | AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP); | 3980 | AC_VERB_SET_PIN_WIDGET_CONTROL, val); |
| 3981 | } | ||
| 3977 | mute_outputs(codec, cfg->hp_outs, cfg->hp_pins); | 3982 | mute_outputs(codec, cfg->hp_outs, cfg->hp_pins); |
| 3978 | mute_outputs(codec, cfg->line_outs, cfg->line_out_pins); | 3983 | mute_outputs(codec, cfg->line_outs, cfg->line_out_pins); |
| 3979 | mute_outputs(codec, cfg->speaker_outs, cfg->speaker_pins); | 3984 | mute_outputs(codec, cfg->speaker_outs, cfg->speaker_pins); |
| @@ -4391,8 +4396,10 @@ static void apply_pin_fixup(struct hda_codec *codec, | |||
| 4391 | 4396 | ||
| 4392 | enum { | 4397 | enum { |
| 4393 | CXT_PINCFG_LENOVO_X200, | 4398 | CXT_PINCFG_LENOVO_X200, |
| 4399 | CXT_PINCFG_LENOVO_TP410, | ||
| 4394 | }; | 4400 | }; |
| 4395 | 4401 | ||
| 4402 | /* ThinkPad X200 & co with cxt5051 */ | ||
| 4396 | static const struct cxt_pincfg cxt_pincfg_lenovo_x200[] = { | 4403 | static const struct cxt_pincfg cxt_pincfg_lenovo_x200[] = { |
| 4397 | { 0x16, 0x042140ff }, /* HP (seq# overridden) */ | 4404 | { 0x16, 0x042140ff }, /* HP (seq# overridden) */ |
| 4398 | { 0x17, 0x21a11000 }, /* dock-mic */ | 4405 | { 0x17, 0x21a11000 }, /* dock-mic */ |
| @@ -4401,15 +4408,33 @@ static const struct cxt_pincfg cxt_pincfg_lenovo_x200[] = { | |||
| 4401 | {} | 4408 | {} |
| 4402 | }; | 4409 | }; |
| 4403 | 4410 | ||
| 4411 | /* ThinkPad 410/420/510/520, X201 & co with cxt5066 */ | ||
| 4412 | static const struct cxt_pincfg cxt_pincfg_lenovo_tp410[] = { | ||
| 4413 | { 0x19, 0x042110ff }, /* HP (seq# overridden) */ | ||
| 4414 | { 0x1a, 0x21a190f0 }, /* dock-mic */ | ||
| 4415 | { 0x1c, 0x212140ff }, /* dock-HP */ | ||
| 4416 | {} | ||
| 4417 | }; | ||
| 4418 | |||
| 4404 | static const struct cxt_pincfg *cxt_pincfg_tbl[] = { | 4419 | static const struct cxt_pincfg *cxt_pincfg_tbl[] = { |
| 4405 | [CXT_PINCFG_LENOVO_X200] = cxt_pincfg_lenovo_x200, | 4420 | [CXT_PINCFG_LENOVO_X200] = cxt_pincfg_lenovo_x200, |
| 4421 | [CXT_PINCFG_LENOVO_TP410] = cxt_pincfg_lenovo_tp410, | ||
| 4406 | }; | 4422 | }; |
| 4407 | 4423 | ||
| 4408 | static const struct snd_pci_quirk cxt_fixups[] = { | 4424 | static const struct snd_pci_quirk cxt5051_fixups[] = { |
| 4409 | SND_PCI_QUIRK(0x17aa, 0x20f2, "Lenovo X200", CXT_PINCFG_LENOVO_X200), | 4425 | SND_PCI_QUIRK(0x17aa, 0x20f2, "Lenovo X200", CXT_PINCFG_LENOVO_X200), |
| 4410 | {} | 4426 | {} |
| 4411 | }; | 4427 | }; |
| 4412 | 4428 | ||
| 4429 | static const struct snd_pci_quirk cxt5066_fixups[] = { | ||
| 4430 | SND_PCI_QUIRK(0x17aa, 0x20f2, "Lenovo T400", CXT_PINCFG_LENOVO_TP410), | ||
| 4431 | SND_PCI_QUIRK(0x17aa, 0x215e, "Lenovo T410", CXT_PINCFG_LENOVO_TP410), | ||
| 4432 | SND_PCI_QUIRK(0x17aa, 0x215f, "Lenovo T510", CXT_PINCFG_LENOVO_TP410), | ||
| 4433 | SND_PCI_QUIRK(0x17aa, 0x21ce, "Lenovo T420", CXT_PINCFG_LENOVO_TP410), | ||
| 4434 | SND_PCI_QUIRK(0x17aa, 0x21cf, "Lenovo T520", CXT_PINCFG_LENOVO_TP410), | ||
| 4435 | {} | ||
| 4436 | }; | ||
| 4437 | |||
| 4413 | /* add "fake" mute amp-caps to DACs on cx5051 so that mixer mute switches | 4438 | /* add "fake" mute amp-caps to DACs on cx5051 so that mixer mute switches |
| 4414 | * can be created (bko#42825) | 4439 | * can be created (bko#42825) |
| 4415 | */ | 4440 | */ |
| @@ -4446,13 +4471,13 @@ static int patch_conexant_auto(struct hda_codec *codec) | |||
| 4446 | case 0x14f15051: | 4471 | case 0x14f15051: |
| 4447 | add_cx5051_fake_mutes(codec); | 4472 | add_cx5051_fake_mutes(codec); |
| 4448 | codec->pin_amp_workaround = 1; | 4473 | codec->pin_amp_workaround = 1; |
| 4474 | apply_pin_fixup(codec, cxt5051_fixups, cxt_pincfg_tbl); | ||
| 4449 | break; | 4475 | break; |
| 4450 | default: | 4476 | default: |
| 4451 | codec->pin_amp_workaround = 1; | 4477 | codec->pin_amp_workaround = 1; |
| 4478 | apply_pin_fixup(codec, cxt5066_fixups, cxt_pincfg_tbl); | ||
| 4452 | } | 4479 | } |
| 4453 | 4480 | ||
| 4454 | apply_pin_fixup(codec, cxt_fixups, cxt_pincfg_tbl); | ||
| 4455 | |||
| 4456 | /* Show mute-led control only on HP laptops | 4481 | /* Show mute-led control only on HP laptops |
| 4457 | * This is a sort of white-list: on HP laptops, EAPD corresponds | 4482 | * This is a sort of white-list: on HP laptops, EAPD corresponds |
| 4458 | * only to the mute-LED without actualy amp function. Meanwhile, | 4483 | * only to the mute-LED without actualy amp function. Meanwhile, |
diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c index 9917e55d6f11..e65e35433055 100644 --- a/sound/pci/hda/patch_realtek.c +++ b/sound/pci/hda/patch_realtek.c | |||
| @@ -1445,6 +1445,13 @@ enum { | |||
| 1445 | ALC_FIXUP_ACT_BUILD, | 1445 | ALC_FIXUP_ACT_BUILD, |
| 1446 | }; | 1446 | }; |
| 1447 | 1447 | ||
| 1448 | static void alc_apply_pincfgs(struct hda_codec *codec, | ||
| 1449 | const struct alc_pincfg *cfg) | ||
| 1450 | { | ||
| 1451 | for (; cfg->nid; cfg++) | ||
| 1452 | snd_hda_codec_set_pincfg(codec, cfg->nid, cfg->val); | ||
| 1453 | } | ||
| 1454 | |||
| 1448 | static void alc_apply_fixup(struct hda_codec *codec, int action) | 1455 | static void alc_apply_fixup(struct hda_codec *codec, int action) |
| 1449 | { | 1456 | { |
| 1450 | struct alc_spec *spec = codec->spec; | 1457 | struct alc_spec *spec = codec->spec; |
| @@ -1478,9 +1485,7 @@ static void alc_apply_fixup(struct hda_codec *codec, int action) | |||
| 1478 | snd_printdd(KERN_INFO "hda_codec: %s: " | 1485 | snd_printdd(KERN_INFO "hda_codec: %s: " |
| 1479 | "Apply pincfg for %s\n", | 1486 | "Apply pincfg for %s\n", |
| 1480 | codec->chip_name, modelname); | 1487 | codec->chip_name, modelname); |
| 1481 | for (; cfg->nid; cfg++) | 1488 | alc_apply_pincfgs(codec, cfg); |
| 1482 | snd_hda_codec_set_pincfg(codec, cfg->nid, | ||
| 1483 | cfg->val); | ||
| 1484 | break; | 1489 | break; |
| 1485 | case ALC_FIXUP_VERBS: | 1490 | case ALC_FIXUP_VERBS: |
| 1486 | if (action != ALC_FIXUP_ACT_PROBE || !fix->v.verbs) | 1491 | if (action != ALC_FIXUP_ACT_PROBE || !fix->v.verbs) |
| @@ -3398,8 +3403,10 @@ static int alc_auto_fill_dac_nids(struct hda_codec *codec) | |||
| 3398 | for (;;) { | 3403 | for (;;) { |
| 3399 | badness = fill_and_eval_dacs(codec, fill_hardwired, | 3404 | badness = fill_and_eval_dacs(codec, fill_hardwired, |
| 3400 | fill_mio_first); | 3405 | fill_mio_first); |
| 3401 | if (badness < 0) | 3406 | if (badness < 0) { |
| 3407 | kfree(best_cfg); | ||
| 3402 | return badness; | 3408 | return badness; |
| 3409 | } | ||
| 3403 | debug_badness("==> lo_type=%d, wired=%d, mio=%d, badness=0x%x\n", | 3410 | debug_badness("==> lo_type=%d, wired=%d, mio=%d, badness=0x%x\n", |
| 3404 | cfg->line_out_type, fill_hardwired, fill_mio_first, | 3411 | cfg->line_out_type, fill_hardwired, fill_mio_first, |
| 3405 | badness); | 3412 | badness); |
| @@ -3434,7 +3441,7 @@ static int alc_auto_fill_dac_nids(struct hda_codec *codec) | |||
| 3434 | cfg->line_out_type = AUTO_PIN_SPEAKER_OUT; | 3441 | cfg->line_out_type = AUTO_PIN_SPEAKER_OUT; |
| 3435 | fill_hardwired = true; | 3442 | fill_hardwired = true; |
| 3436 | continue; | 3443 | continue; |
| 3437 | } | 3444 | } |
| 3438 | if (cfg->hp_outs > 0 && | 3445 | if (cfg->hp_outs > 0 && |
| 3439 | cfg->line_out_type == AUTO_PIN_SPEAKER_OUT) { | 3446 | cfg->line_out_type == AUTO_PIN_SPEAKER_OUT) { |
| 3440 | cfg->speaker_outs = cfg->line_outs; | 3447 | cfg->speaker_outs = cfg->line_outs; |
| @@ -3448,7 +3455,7 @@ static int alc_auto_fill_dac_nids(struct hda_codec *codec) | |||
| 3448 | cfg->line_out_type = AUTO_PIN_HP_OUT; | 3455 | cfg->line_out_type = AUTO_PIN_HP_OUT; |
| 3449 | fill_hardwired = true; | 3456 | fill_hardwired = true; |
| 3450 | continue; | 3457 | continue; |
| 3451 | } | 3458 | } |
| 3452 | break; | 3459 | break; |
| 3453 | } | 3460 | } |
| 3454 | 3461 | ||
| @@ -4423,7 +4430,7 @@ static int alc_parse_auto_config(struct hda_codec *codec, | |||
| 4423 | static int alc880_parse_auto_config(struct hda_codec *codec) | 4430 | static int alc880_parse_auto_config(struct hda_codec *codec) |
| 4424 | { | 4431 | { |
| 4425 | static const hda_nid_t alc880_ignore[] = { 0x1d, 0 }; | 4432 | static const hda_nid_t alc880_ignore[] = { 0x1d, 0 }; |
| 4426 | static const hda_nid_t alc880_ssids[] = { 0x15, 0x1b, 0x14, 0 }; | 4433 | static const hda_nid_t alc880_ssids[] = { 0x15, 0x1b, 0x14, 0 }; |
| 4427 | return alc_parse_auto_config(codec, alc880_ignore, alc880_ssids); | 4434 | return alc_parse_auto_config(codec, alc880_ignore, alc880_ssids); |
| 4428 | } | 4435 | } |
| 4429 | 4436 | ||
| @@ -4859,6 +4866,7 @@ enum { | |||
| 4859 | ALC260_FIXUP_GPIO1_TOGGLE, | 4866 | ALC260_FIXUP_GPIO1_TOGGLE, |
| 4860 | ALC260_FIXUP_REPLACER, | 4867 | ALC260_FIXUP_REPLACER, |
| 4861 | ALC260_FIXUP_HP_B1900, | 4868 | ALC260_FIXUP_HP_B1900, |
| 4869 | ALC260_FIXUP_KN1, | ||
| 4862 | }; | 4870 | }; |
| 4863 | 4871 | ||
| 4864 | static void alc260_gpio1_automute(struct hda_codec *codec) | 4872 | static void alc260_gpio1_automute(struct hda_codec *codec) |
| @@ -4886,6 +4894,36 @@ static void alc260_fixup_gpio1_toggle(struct hda_codec *codec, | |||
| 4886 | } | 4894 | } |
| 4887 | } | 4895 | } |
| 4888 | 4896 | ||
| 4897 | static void alc260_fixup_kn1(struct hda_codec *codec, | ||
| 4898 | const struct alc_fixup *fix, int action) | ||
| 4899 | { | ||
| 4900 | struct alc_spec *spec = codec->spec; | ||
| 4901 | static const struct alc_pincfg pincfgs[] = { | ||
| 4902 | { 0x0f, 0x02214000 }, /* HP/speaker */ | ||
| 4903 | { 0x12, 0x90a60160 }, /* int mic */ | ||
| 4904 | { 0x13, 0x02a19000 }, /* ext mic */ | ||
| 4905 | { 0x18, 0x01446000 }, /* SPDIF out */ | ||
| 4906 | /* disable bogus I/O pins */ | ||
| 4907 | { 0x10, 0x411111f0 }, | ||
| 4908 | { 0x11, 0x411111f0 }, | ||
| 4909 | { 0x14, 0x411111f0 }, | ||
| 4910 | { 0x15, 0x411111f0 }, | ||
| 4911 | { 0x16, 0x411111f0 }, | ||
| 4912 | { 0x17, 0x411111f0 }, | ||
| 4913 | { 0x19, 0x411111f0 }, | ||
| 4914 | { } | ||
| 4915 | }; | ||
| 4916 | |||
| 4917 | switch (action) { | ||
| 4918 | case ALC_FIXUP_ACT_PRE_PROBE: | ||
| 4919 | alc_apply_pincfgs(codec, pincfgs); | ||
| 4920 | break; | ||
| 4921 | case ALC_FIXUP_ACT_PROBE: | ||
| 4922 | spec->init_amp = ALC_INIT_NONE; | ||
| 4923 | break; | ||
| 4924 | } | ||
| 4925 | } | ||
| 4926 | |||
| 4889 | static const struct alc_fixup alc260_fixups[] = { | 4927 | static const struct alc_fixup alc260_fixups[] = { |
| 4890 | [ALC260_FIXUP_HP_DC5750] = { | 4928 | [ALC260_FIXUP_HP_DC5750] = { |
| 4891 | .type = ALC_FIXUP_PINS, | 4929 | .type = ALC_FIXUP_PINS, |
| @@ -4936,7 +4974,11 @@ static const struct alc_fixup alc260_fixups[] = { | |||
| 4936 | .v.func = alc260_fixup_gpio1_toggle, | 4974 | .v.func = alc260_fixup_gpio1_toggle, |
| 4937 | .chained = true, | 4975 | .chained = true, |
| 4938 | .chain_id = ALC260_FIXUP_COEF, | 4976 | .chain_id = ALC260_FIXUP_COEF, |
| 4939 | } | 4977 | }, |
| 4978 | [ALC260_FIXUP_KN1] = { | ||
| 4979 | .type = ALC_FIXUP_FUNC, | ||
| 4980 | .v.func = alc260_fixup_kn1, | ||
| 4981 | }, | ||
| 4940 | }; | 4982 | }; |
| 4941 | 4983 | ||
| 4942 | static const struct snd_pci_quirk alc260_fixup_tbl[] = { | 4984 | static const struct snd_pci_quirk alc260_fixup_tbl[] = { |
| @@ -4946,6 +4988,7 @@ static const struct snd_pci_quirk alc260_fixup_tbl[] = { | |||
| 4946 | SND_PCI_QUIRK(0x103c, 0x280a, "HP dc5750", ALC260_FIXUP_HP_DC5750), | 4988 | SND_PCI_QUIRK(0x103c, 0x280a, "HP dc5750", ALC260_FIXUP_HP_DC5750), |
| 4947 | SND_PCI_QUIRK(0x103c, 0x30ba, "HP Presario B1900", ALC260_FIXUP_HP_B1900), | 4989 | SND_PCI_QUIRK(0x103c, 0x30ba, "HP Presario B1900", ALC260_FIXUP_HP_B1900), |
| 4948 | SND_PCI_QUIRK(0x1509, 0x4540, "Favorit 100XS", ALC260_FIXUP_GPIO1), | 4990 | SND_PCI_QUIRK(0x1509, 0x4540, "Favorit 100XS", ALC260_FIXUP_GPIO1), |
| 4991 | SND_PCI_QUIRK(0x152d, 0x0729, "Quanta KN1", ALC260_FIXUP_KN1), | ||
| 4949 | SND_PCI_QUIRK(0x161f, 0x2057, "Replacer 672V", ALC260_FIXUP_REPLACER), | 4992 | SND_PCI_QUIRK(0x161f, 0x2057, "Replacer 672V", ALC260_FIXUP_REPLACER), |
| 4950 | SND_PCI_QUIRK(0x1631, 0xc017, "PB V7900", ALC260_FIXUP_COEF), | 4993 | SND_PCI_QUIRK(0x1631, 0xc017, "PB V7900", ALC260_FIXUP_COEF), |
| 4951 | {} | 4994 | {} |
| @@ -5269,7 +5312,9 @@ static const struct alc_fixup alc882_fixups[] = { | |||
| 5269 | { 0x16, 0x99130111 }, /* CLFE speaker */ | 5312 | { 0x16, 0x99130111 }, /* CLFE speaker */ |
| 5270 | { 0x17, 0x99130112 }, /* surround speaker */ | 5313 | { 0x17, 0x99130112 }, /* surround speaker */ |
| 5271 | { } | 5314 | { } |
| 5272 | } | 5315 | }, |
| 5316 | .chained = true, | ||
| 5317 | .chain_id = ALC882_FIXUP_GPIO1, | ||
| 5273 | }, | 5318 | }, |
| 5274 | [ALC882_FIXUP_ACER_ASPIRE_8930G] = { | 5319 | [ALC882_FIXUP_ACER_ASPIRE_8930G] = { |
| 5275 | .type = ALC_FIXUP_PINS, | 5320 | .type = ALC_FIXUP_PINS, |
| @@ -5312,7 +5357,9 @@ static const struct alc_fixup alc882_fixups[] = { | |||
| 5312 | { 0x20, AC_VERB_SET_COEF_INDEX, 0x07 }, | 5357 | { 0x20, AC_VERB_SET_COEF_INDEX, 0x07 }, |
| 5313 | { 0x20, AC_VERB_SET_PROC_COEF, 0x3050 }, | 5358 | { 0x20, AC_VERB_SET_PROC_COEF, 0x3050 }, |
| 5314 | { } | 5359 | { } |
| 5315 | } | 5360 | }, |
| 5361 | .chained = true, | ||
| 5362 | .chain_id = ALC882_FIXUP_GPIO1, | ||
| 5316 | }, | 5363 | }, |
| 5317 | [ALC885_FIXUP_MACPRO_GPIO] = { | 5364 | [ALC885_FIXUP_MACPRO_GPIO] = { |
| 5318 | .type = ALC_FIXUP_FUNC, | 5365 | .type = ALC_FIXUP_FUNC, |
| @@ -5359,6 +5406,7 @@ static const struct snd_pci_quirk alc882_fixup_tbl[] = { | |||
| 5359 | ALC882_FIXUP_ACER_ASPIRE_4930G), | 5406 | ALC882_FIXUP_ACER_ASPIRE_4930G), |
| 5360 | SND_PCI_QUIRK(0x1025, 0x0155, "Packard-Bell M5120", ALC882_FIXUP_PB_M5210), | 5407 | SND_PCI_QUIRK(0x1025, 0x0155, "Packard-Bell M5120", ALC882_FIXUP_PB_M5210), |
| 5361 | SND_PCI_QUIRK(0x1025, 0x0259, "Acer Aspire 5935", ALC889_FIXUP_DAC_ROUTE), | 5408 | SND_PCI_QUIRK(0x1025, 0x0259, "Acer Aspire 5935", ALC889_FIXUP_DAC_ROUTE), |
| 5409 | SND_PCI_QUIRK(0x1025, 0x026b, "Acer Aspire 8940G", ALC882_FIXUP_ACER_ASPIRE_8930G), | ||
| 5362 | SND_PCI_QUIRK(0x1025, 0x0296, "Acer Aspire 7736z", ALC882_FIXUP_ACER_ASPIRE_7736), | 5410 | SND_PCI_QUIRK(0x1025, 0x0296, "Acer Aspire 7736z", ALC882_FIXUP_ACER_ASPIRE_7736), |
| 5363 | SND_PCI_QUIRK(0x1043, 0x13c2, "Asus A7M", ALC882_FIXUP_EAPD), | 5411 | SND_PCI_QUIRK(0x1043, 0x13c2, "Asus A7M", ALC882_FIXUP_EAPD), |
| 5364 | SND_PCI_QUIRK(0x1043, 0x1873, "ASUS W90V", ALC882_FIXUP_ASUS_W90V), | 5412 | SND_PCI_QUIRK(0x1043, 0x1873, "ASUS W90V", ALC882_FIXUP_ASUS_W90V), |
| @@ -5384,6 +5432,7 @@ static const struct snd_pci_quirk alc882_fixup_tbl[] = { | |||
| 5384 | SND_PCI_QUIRK(0x106b, 0x3f00, "Macbook 5,1", ALC889_FIXUP_IMAC91_VREF), | 5432 | SND_PCI_QUIRK(0x106b, 0x3f00, "Macbook 5,1", ALC889_FIXUP_IMAC91_VREF), |
| 5385 | SND_PCI_QUIRK(0x106b, 0x4000, "MacbookPro 5,1", ALC889_FIXUP_IMAC91_VREF), | 5433 | SND_PCI_QUIRK(0x106b, 0x4000, "MacbookPro 5,1", ALC889_FIXUP_IMAC91_VREF), |
| 5386 | SND_PCI_QUIRK(0x106b, 0x4100, "Macmini 3,1", ALC889_FIXUP_IMAC91_VREF), | 5434 | SND_PCI_QUIRK(0x106b, 0x4100, "Macmini 3,1", ALC889_FIXUP_IMAC91_VREF), |
| 5435 | SND_PCI_QUIRK(0x106b, 0x4200, "Mac Pro 5,1", ALC885_FIXUP_MACPRO_GPIO), | ||
| 5387 | SND_PCI_QUIRK(0x106b, 0x4600, "MacbookPro 5,2", ALC889_FIXUP_IMAC91_VREF), | 5436 | SND_PCI_QUIRK(0x106b, 0x4600, "MacbookPro 5,2", ALC889_FIXUP_IMAC91_VREF), |
| 5388 | SND_PCI_QUIRK(0x106b, 0x4900, "iMac 9,1 Aluminum", ALC889_FIXUP_IMAC91_VREF), | 5437 | SND_PCI_QUIRK(0x106b, 0x4900, "iMac 9,1 Aluminum", ALC889_FIXUP_IMAC91_VREF), |
| 5389 | SND_PCI_QUIRK(0x106b, 0x4a00, "Macbook 5,2", ALC889_FIXUP_IMAC91_VREF), | 5438 | SND_PCI_QUIRK(0x106b, 0x4a00, "Macbook 5,2", ALC889_FIXUP_IMAC91_VREF), |
| @@ -5399,6 +5448,13 @@ static const struct snd_pci_quirk alc882_fixup_tbl[] = { | |||
| 5399 | {} | 5448 | {} |
| 5400 | }; | 5449 | }; |
| 5401 | 5450 | ||
| 5451 | static const struct alc_model_fixup alc882_fixup_models[] = { | ||
| 5452 | {.id = ALC882_FIXUP_ACER_ASPIRE_4930G, .name = "acer-aspire-4930g"}, | ||
| 5453 | {.id = ALC882_FIXUP_ACER_ASPIRE_8930G, .name = "acer-aspire-8930g"}, | ||
| 5454 | {.id = ALC883_FIXUP_ACER_EAPD, .name = "acer-aspire"}, | ||
| 5455 | {} | ||
| 5456 | }; | ||
| 5457 | |||
| 5402 | /* | 5458 | /* |
| 5403 | * BIOS auto configuration | 5459 | * BIOS auto configuration |
| 5404 | */ | 5460 | */ |
| @@ -5439,7 +5495,8 @@ static int patch_alc882(struct hda_codec *codec) | |||
| 5439 | if (err < 0) | 5495 | if (err < 0) |
| 5440 | goto error; | 5496 | goto error; |
| 5441 | 5497 | ||
| 5442 | alc_pick_fixup(codec, NULL, alc882_fixup_tbl, alc882_fixups); | 5498 | alc_pick_fixup(codec, alc882_fixup_models, alc882_fixup_tbl, |
| 5499 | alc882_fixups); | ||
| 5443 | alc_apply_fixup(codec, ALC_FIXUP_ACT_PRE_PROBE); | 5500 | alc_apply_fixup(codec, ALC_FIXUP_ACT_PRE_PROBE); |
| 5444 | 5501 | ||
| 5445 | alc_auto_parse_customize_define(codec); | 5502 | alc_auto_parse_customize_define(codec); |
| @@ -6079,7 +6136,7 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = { | |||
| 6079 | * Basically the device should work as is without the fixup table. | 6136 | * Basically the device should work as is without the fixup table. |
| 6080 | * If BIOS doesn't give a proper info, enable the corresponding | 6137 | * If BIOS doesn't give a proper info, enable the corresponding |
| 6081 | * fixup entry. | 6138 | * fixup entry. |
| 6082 | */ | 6139 | */ |
| 6083 | SND_PCI_QUIRK(0x1043, 0x8330, "ASUS Eeepc P703 P900A", | 6140 | SND_PCI_QUIRK(0x1043, 0x8330, "ASUS Eeepc P703 P900A", |
| 6084 | ALC269_FIXUP_AMIC), | 6141 | ALC269_FIXUP_AMIC), |
| 6085 | SND_PCI_QUIRK(0x1043, 0x1013, "ASUS N61Da", ALC269_FIXUP_AMIC), | 6142 | SND_PCI_QUIRK(0x1043, 0x1013, "ASUS N61Da", ALC269_FIXUP_AMIC), |
| @@ -6296,7 +6353,7 @@ static void alc_fixup_no_jack_detect(struct hda_codec *codec, | |||
| 6296 | { | 6353 | { |
| 6297 | if (action == ALC_FIXUP_ACT_PRE_PROBE) | 6354 | if (action == ALC_FIXUP_ACT_PRE_PROBE) |
| 6298 | codec->no_jack_detect = 1; | 6355 | codec->no_jack_detect = 1; |
| 6299 | } | 6356 | } |
| 6300 | 6357 | ||
| 6301 | static const struct alc_fixup alc861_fixups[] = { | 6358 | static const struct alc_fixup alc861_fixups[] = { |
| 6302 | [ALC861_FIXUP_FSC_AMILO_PI1505] = { | 6359 | [ALC861_FIXUP_FSC_AMILO_PI1505] = { |
| @@ -6714,7 +6771,7 @@ static const struct snd_pci_quirk alc662_fixup_tbl[] = { | |||
| 6714 | * Basically the device should work as is without the fixup table. | 6771 | * Basically the device should work as is without the fixup table. |
| 6715 | * If BIOS doesn't give a proper info, enable the corresponding | 6772 | * If BIOS doesn't give a proper info, enable the corresponding |
| 6716 | * fixup entry. | 6773 | * fixup entry. |
| 6717 | */ | 6774 | */ |
| 6718 | SND_PCI_QUIRK(0x1043, 0x1000, "ASUS N50Vm", ALC662_FIXUP_ASUS_MODE1), | 6775 | SND_PCI_QUIRK(0x1043, 0x1000, "ASUS N50Vm", ALC662_FIXUP_ASUS_MODE1), |
| 6719 | SND_PCI_QUIRK(0x1043, 0x1092, "ASUS NB", ALC662_FIXUP_ASUS_MODE3), | 6776 | SND_PCI_QUIRK(0x1043, 0x1092, "ASUS NB", ALC662_FIXUP_ASUS_MODE3), |
| 6720 | SND_PCI_QUIRK(0x1043, 0x1173, "ASUS K73Jn", ALC662_FIXUP_ASUS_MODE1), | 6777 | SND_PCI_QUIRK(0x1043, 0x1173, "ASUS K73Jn", ALC662_FIXUP_ASUS_MODE1), |
diff --git a/sound/pci/hda/patch_sigmatel.c b/sound/pci/hda/patch_sigmatel.c index 33a9946b492c..4742cac26aa9 100644 --- a/sound/pci/hda/patch_sigmatel.c +++ b/sound/pci/hda/patch_sigmatel.c | |||
| @@ -5063,12 +5063,11 @@ static void stac92xx_update_led_status(struct hda_codec *codec, int enabled) | |||
| 5063 | if (spec->gpio_led_polarity) | 5063 | if (spec->gpio_led_polarity) |
| 5064 | muted = !muted; | 5064 | muted = !muted; |
| 5065 | 5065 | ||
| 5066 | /*polarity defines *not* muted state level*/ | ||
| 5067 | if (!spec->vref_mute_led_nid) { | 5066 | if (!spec->vref_mute_led_nid) { |
| 5068 | if (muted) | 5067 | if (muted) |
| 5069 | spec->gpio_data &= ~spec->gpio_led; /* orange */ | 5068 | spec->gpio_data |= spec->gpio_led; |
| 5070 | else | 5069 | else |
| 5071 | spec->gpio_data |= spec->gpio_led; /* white */ | 5070 | spec->gpio_data &= ~spec->gpio_led; |
| 5072 | stac_gpio_set(codec, spec->gpio_mask, | 5071 | stac_gpio_set(codec, spec->gpio_mask, |
| 5073 | spec->gpio_dir, spec->gpio_data); | 5072 | spec->gpio_dir, spec->gpio_data); |
| 5074 | } else { | 5073 | } else { |
diff --git a/sound/soc/codecs/Kconfig b/sound/soc/codecs/Kconfig index 6508e8b790bb..59d8efaa17e9 100644 --- a/sound/soc/codecs/Kconfig +++ b/sound/soc/codecs/Kconfig | |||
| @@ -57,7 +57,7 @@ config SND_SOC_ALL_CODECS | |||
| 57 | select SND_SOC_TPA6130A2 if I2C | 57 | select SND_SOC_TPA6130A2 if I2C |
| 58 | select SND_SOC_TLV320DAC33 if I2C | 58 | select SND_SOC_TLV320DAC33 if I2C |
| 59 | select SND_SOC_TWL4030 if TWL4030_CORE | 59 | select SND_SOC_TWL4030 if TWL4030_CORE |
| 60 | select SND_SOC_TWL6040 if TWL4030_CORE | 60 | select SND_SOC_TWL6040 if TWL6040_CORE |
| 61 | select SND_SOC_UDA134X | 61 | select SND_SOC_UDA134X |
| 62 | select SND_SOC_UDA1380 if I2C | 62 | select SND_SOC_UDA1380 if I2C |
| 63 | select SND_SOC_WL1273 if MFD_WL1273_CORE | 63 | select SND_SOC_WL1273 if MFD_WL1273_CORE |
| @@ -276,7 +276,6 @@ config SND_SOC_TWL4030 | |||
| 276 | tristate | 276 | tristate |
| 277 | 277 | ||
| 278 | config SND_SOC_TWL6040 | 278 | config SND_SOC_TWL6040 |
| 279 | select TWL6040_CORE | ||
| 280 | tristate | 279 | tristate |
| 281 | 280 | ||
| 282 | config SND_SOC_UDA134X | 281 | config SND_SOC_UDA134X |
diff --git a/sound/soc/codecs/twl6040.c b/sound/soc/codecs/twl6040.c index 2d8c6b825e57..dc7509b9d53a 100644 --- a/sound/soc/codecs/twl6040.c +++ b/sound/soc/codecs/twl6040.c | |||
| @@ -26,7 +26,6 @@ | |||
| 26 | #include <linux/pm.h> | 26 | #include <linux/pm.h> |
| 27 | #include <linux/platform_device.h> | 27 | #include <linux/platform_device.h> |
| 28 | #include <linux/slab.h> | 28 | #include <linux/slab.h> |
| 29 | #include <linux/i2c/twl.h> | ||
| 30 | #include <linux/mfd/twl6040.h> | 29 | #include <linux/mfd/twl6040.h> |
| 31 | 30 | ||
| 32 | #include <sound/core.h> | 31 | #include <sound/core.h> |
| @@ -1528,7 +1527,7 @@ static int twl6040_resume(struct snd_soc_codec *codec) | |||
| 1528 | static int twl6040_probe(struct snd_soc_codec *codec) | 1527 | static int twl6040_probe(struct snd_soc_codec *codec) |
| 1529 | { | 1528 | { |
| 1530 | struct twl6040_data *priv; | 1529 | struct twl6040_data *priv; |
| 1531 | struct twl4030_codec_data *pdata = dev_get_platdata(codec->dev); | 1530 | struct twl6040_codec_data *pdata = dev_get_platdata(codec->dev); |
| 1532 | struct platform_device *pdev = container_of(codec->dev, | 1531 | struct platform_device *pdev = container_of(codec->dev, |
| 1533 | struct platform_device, dev); | 1532 | struct platform_device, dev); |
| 1534 | int ret = 0; | 1533 | int ret = 0; |
diff --git a/sound/soc/omap/Kconfig b/sound/soc/omap/Kconfig index e00dd0b1139c..deafbfaacdbf 100644 --- a/sound/soc/omap/Kconfig +++ b/sound/soc/omap/Kconfig | |||
| @@ -97,7 +97,7 @@ config SND_OMAP_SOC_SDP3430 | |||
| 97 | 97 | ||
| 98 | config SND_OMAP_SOC_OMAP_ABE_TWL6040 | 98 | config SND_OMAP_SOC_OMAP_ABE_TWL6040 |
| 99 | tristate "SoC Audio support for OMAP boards using ABE and twl6040 codec" | 99 | tristate "SoC Audio support for OMAP boards using ABE and twl6040 codec" |
| 100 | depends on TWL4030_CORE && SND_OMAP_SOC && ARCH_OMAP4 | 100 | depends on TWL6040_CORE && SND_OMAP_SOC && ARCH_OMAP4 |
| 101 | select SND_OMAP_SOC_DMIC | 101 | select SND_OMAP_SOC_DMIC |
| 102 | select SND_OMAP_SOC_MCPDM | 102 | select SND_OMAP_SOC_MCPDM |
| 103 | select SND_SOC_TWL6040 | 103 | select SND_SOC_TWL6040 |
diff --git a/tools/perf/.gitignore b/tools/perf/.gitignore index 416684be0ad3..26b823b61aa1 100644 --- a/tools/perf/.gitignore +++ b/tools/perf/.gitignore | |||
| @@ -19,3 +19,5 @@ TAGS | |||
| 19 | cscope* | 19 | cscope* |
| 20 | config.mak | 20 | config.mak |
| 21 | config.mak.autogen | 21 | config.mak.autogen |
| 22 | *-bison.* | ||
| 23 | *-flex.* | ||
diff --git a/tools/perf/Makefile b/tools/perf/Makefile index 820371f10d1b..03059e75665a 100644 --- a/tools/perf/Makefile +++ b/tools/perf/Makefile | |||
| @@ -237,21 +237,20 @@ export PERL_PATH | |||
| 237 | FLEX = $(CROSS_COMPILE)flex | 237 | FLEX = $(CROSS_COMPILE)flex |
| 238 | BISON= $(CROSS_COMPILE)bison | 238 | BISON= $(CROSS_COMPILE)bison |
| 239 | 239 | ||
| 240 | event-parser: | 240 | $(OUTPUT)util/parse-events-flex.c: util/parse-events.l |
| 241 | $(QUIET_BISON)$(BISON) -v util/parse-events.y -d -o $(OUTPUT)util/parse-events-bison.c | ||
| 242 | $(QUIET_FLEX)$(FLEX) --header-file=$(OUTPUT)util/parse-events-flex.h -t util/parse-events.l > $(OUTPUT)util/parse-events-flex.c | 241 | $(QUIET_FLEX)$(FLEX) --header-file=$(OUTPUT)util/parse-events-flex.h -t util/parse-events.l > $(OUTPUT)util/parse-events-flex.c |
| 243 | 242 | ||
| 244 | $(OUTPUT)util/parse-events-flex.c: event-parser | 243 | $(OUTPUT)util/parse-events-bison.c: util/parse-events.y |
| 245 | $(OUTPUT)util/parse-events-bison.c: event-parser | 244 | $(QUIET_BISON)$(BISON) -v util/parse-events.y -d -o $(OUTPUT)util/parse-events-bison.c |
| 246 | 245 | ||
| 247 | pmu-parser: | 246 | $(OUTPUT)util/pmu-flex.c: util/pmu.l |
| 248 | $(QUIET_BISON)$(BISON) -v util/pmu.y -d -o $(OUTPUT)util/pmu-bison.c | ||
| 249 | $(QUIET_FLEX)$(FLEX) --header-file=$(OUTPUT)util/pmu-flex.h -t util/pmu.l > $(OUTPUT)util/pmu-flex.c | 247 | $(QUIET_FLEX)$(FLEX) --header-file=$(OUTPUT)util/pmu-flex.h -t util/pmu.l > $(OUTPUT)util/pmu-flex.c |
| 250 | 248 | ||
| 251 | $(OUTPUT)util/pmu-flex.c: pmu-parser | 249 | $(OUTPUT)util/pmu-bison.c: util/pmu.y |
| 252 | $(OUTPUT)util/pmu-bison.c: pmu-parser | 250 | $(QUIET_BISON)$(BISON) -v util/pmu.y -d -o $(OUTPUT)util/pmu-bison.c |
| 253 | 251 | ||
| 254 | $(OUTPUT)util/parse-events.o: event-parser pmu-parser | 252 | $(OUTPUT)util/parse-events.o: $(OUTPUT)util/parse-events-flex.c $(OUTPUT)util/parse-events-bison.c |
| 253 | $(OUTPUT)util/pmu.o: $(OUTPUT)util/pmu-flex.c $(OUTPUT)util/pmu-bison.c | ||
| 255 | 254 | ||
| 256 | LIB_FILE=$(OUTPUT)libperf.a | 255 | LIB_FILE=$(OUTPUT)libperf.a |
| 257 | 256 | ||
| @@ -527,7 +526,7 @@ else | |||
| 527 | endif | 526 | endif |
| 528 | 527 | ||
| 529 | ifdef NO_GTK2 | 528 | ifdef NO_GTK2 |
| 530 | BASIC_CFLAGS += -DNO_GTK2 | 529 | BASIC_CFLAGS += -DNO_GTK2_SUPPORT |
| 531 | else | 530 | else |
| 532 | FLAGS_GTK2=$(ALL_CFLAGS) $(ALL_LDFLAGS) $(EXTLIBS) $(shell pkg-config --libs --cflags gtk+-2.0) | 531 | FLAGS_GTK2=$(ALL_CFLAGS) $(ALL_LDFLAGS) $(EXTLIBS) $(shell pkg-config --libs --cflags gtk+-2.0) |
| 533 | ifneq ($(call try-cc,$(SOURCE_GTK2),$(FLAGS_GTK2)),y) | 532 | ifneq ($(call try-cc,$(SOURCE_GTK2),$(FLAGS_GTK2)),y) |
| @@ -852,8 +851,6 @@ help: | |||
| 852 | @echo ' html - make html documentation' | 851 | @echo ' html - make html documentation' |
| 853 | @echo ' info - make GNU info documentation (access with info <foo>)' | 852 | @echo ' info - make GNU info documentation (access with info <foo>)' |
| 854 | @echo ' pdf - make pdf documentation' | 853 | @echo ' pdf - make pdf documentation' |
| 855 | @echo ' event-parser - make event parser code' | ||
| 856 | @echo ' pmu-parser - make pmu format parser code' | ||
| 857 | @echo ' TAGS - use etags to make tag information for source browsing' | 854 | @echo ' TAGS - use etags to make tag information for source browsing' |
| 858 | @echo ' tags - use ctags to make tag information for source browsing' | 855 | @echo ' tags - use ctags to make tag information for source browsing' |
| 859 | @echo ' cscope - use cscope to make interactive browsing database' | 856 | @echo ' cscope - use cscope to make interactive browsing database' |
diff --git a/tools/perf/builtin-sched.c b/tools/perf/builtin-sched.c index fb8b5f83b4a0..1cad3af4bf4c 100644 --- a/tools/perf/builtin-sched.c +++ b/tools/perf/builtin-sched.c | |||
| @@ -17,6 +17,7 @@ | |||
| 17 | #include "util/debug.h" | 17 | #include "util/debug.h" |
| 18 | 18 | ||
| 19 | #include <sys/prctl.h> | 19 | #include <sys/prctl.h> |
| 20 | #include <sys/resource.h> | ||
| 20 | 21 | ||
| 21 | #include <semaphore.h> | 22 | #include <semaphore.h> |
| 22 | #include <pthread.h> | 23 | #include <pthread.h> |
diff --git a/tools/perf/builtin-top.c b/tools/perf/builtin-top.c index e3c63aef8efc..8ef59f8262bb 100644 --- a/tools/perf/builtin-top.c +++ b/tools/perf/builtin-top.c | |||
| @@ -42,6 +42,7 @@ | |||
| 42 | #include "util/debug.h" | 42 | #include "util/debug.h" |
| 43 | 43 | ||
| 44 | #include <assert.h> | 44 | #include <assert.h> |
| 45 | #include <elf.h> | ||
| 45 | #include <fcntl.h> | 46 | #include <fcntl.h> |
| 46 | 47 | ||
| 47 | #include <stdio.h> | 48 | #include <stdio.h> |
| @@ -59,6 +60,7 @@ | |||
| 59 | #include <sys/prctl.h> | 60 | #include <sys/prctl.h> |
| 60 | #include <sys/wait.h> | 61 | #include <sys/wait.h> |
| 61 | #include <sys/uio.h> | 62 | #include <sys/uio.h> |
| 63 | #include <sys/utsname.h> | ||
| 62 | #include <sys/mman.h> | 64 | #include <sys/mman.h> |
| 63 | 65 | ||
| 64 | #include <linux/unistd.h> | 66 | #include <linux/unistd.h> |
| @@ -162,12 +164,40 @@ static void __zero_source_counters(struct hist_entry *he) | |||
| 162 | symbol__annotate_zero_histograms(sym); | 164 | symbol__annotate_zero_histograms(sym); |
| 163 | } | 165 | } |
| 164 | 166 | ||
| 167 | static void ui__warn_map_erange(struct map *map, struct symbol *sym, u64 ip) | ||
| 168 | { | ||
| 169 | struct utsname uts; | ||
| 170 | int err = uname(&uts); | ||
| 171 | |||
| 172 | ui__warning("Out of bounds address found:\n\n" | ||
| 173 | "Addr: %" PRIx64 "\n" | ||
| 174 | "DSO: %s %c\n" | ||
| 175 | "Map: %" PRIx64 "-%" PRIx64 "\n" | ||
| 176 | "Symbol: %" PRIx64 "-%" PRIx64 " %c %s\n" | ||
| 177 | "Arch: %s\n" | ||
| 178 | "Kernel: %s\n" | ||
| 179 | "Tools: %s\n\n" | ||
| 180 | "Not all samples will be on the annotation output.\n\n" | ||
| 181 | "Please report to linux-kernel@vger.kernel.org\n", | ||
| 182 | ip, map->dso->long_name, dso__symtab_origin(map->dso), | ||
| 183 | map->start, map->end, sym->start, sym->end, | ||
| 184 | sym->binding == STB_GLOBAL ? 'g' : | ||
| 185 | sym->binding == STB_LOCAL ? 'l' : 'w', sym->name, | ||
| 186 | err ? "[unknown]" : uts.machine, | ||
| 187 | err ? "[unknown]" : uts.release, perf_version_string); | ||
| 188 | if (use_browser <= 0) | ||
| 189 | sleep(5); | ||
| 190 | |||
| 191 | map->erange_warned = true; | ||
| 192 | } | ||
| 193 | |||
| 165 | static void perf_top__record_precise_ip(struct perf_top *top, | 194 | static void perf_top__record_precise_ip(struct perf_top *top, |
| 166 | struct hist_entry *he, | 195 | struct hist_entry *he, |
| 167 | int counter, u64 ip) | 196 | int counter, u64 ip) |
| 168 | { | 197 | { |
| 169 | struct annotation *notes; | 198 | struct annotation *notes; |
| 170 | struct symbol *sym; | 199 | struct symbol *sym; |
| 200 | int err; | ||
| 171 | 201 | ||
| 172 | if (he == NULL || he->ms.sym == NULL || | 202 | if (he == NULL || he->ms.sym == NULL || |
| 173 | ((top->sym_filter_entry == NULL || | 203 | ((top->sym_filter_entry == NULL || |
| @@ -189,9 +219,12 @@ static void perf_top__record_precise_ip(struct perf_top *top, | |||
| 189 | } | 219 | } |
| 190 | 220 | ||
| 191 | ip = he->ms.map->map_ip(he->ms.map, ip); | 221 | ip = he->ms.map->map_ip(he->ms.map, ip); |
| 192 | symbol__inc_addr_samples(sym, he->ms.map, counter, ip); | 222 | err = symbol__inc_addr_samples(sym, he->ms.map, counter, ip); |
| 193 | 223 | ||
| 194 | pthread_mutex_unlock(¬es->lock); | 224 | pthread_mutex_unlock(¬es->lock); |
| 225 | |||
| 226 | if (err == -ERANGE && !he->ms.map->erange_warned) | ||
| 227 | ui__warn_map_erange(he->ms.map, sym, ip); | ||
| 195 | } | 228 | } |
| 196 | 229 | ||
| 197 | static void perf_top__show_details(struct perf_top *top) | 230 | static void perf_top__show_details(struct perf_top *top) |
| @@ -615,6 +648,7 @@ process_hotkey: | |||
| 615 | 648 | ||
| 616 | /* Tag samples to be skipped. */ | 649 | /* Tag samples to be skipped. */ |
| 617 | static const char *skip_symbols[] = { | 650 | static const char *skip_symbols[] = { |
| 651 | "intel_idle", | ||
| 618 | "default_idle", | 652 | "default_idle", |
| 619 | "native_safe_halt", | 653 | "native_safe_halt", |
| 620 | "cpu_idle", | 654 | "cpu_idle", |
diff --git a/tools/perf/perf-archive.sh b/tools/perf/perf-archive.sh index 677e59d62a8d..95b6f8b6177a 100644 --- a/tools/perf/perf-archive.sh +++ b/tools/perf/perf-archive.sh | |||
| @@ -29,13 +29,14 @@ if [ ! -s $BUILDIDS ] ; then | |||
| 29 | fi | 29 | fi |
| 30 | 30 | ||
| 31 | MANIFEST=$(mktemp /tmp/perf-archive-manifest.XXXXXX) | 31 | MANIFEST=$(mktemp /tmp/perf-archive-manifest.XXXXXX) |
| 32 | PERF_BUILDID_LINKDIR=$(readlink -f $PERF_BUILDID_DIR)/ | ||
| 32 | 33 | ||
| 33 | cut -d ' ' -f 1 $BUILDIDS | \ | 34 | cut -d ' ' -f 1 $BUILDIDS | \ |
| 34 | while read build_id ; do | 35 | while read build_id ; do |
| 35 | linkname=$PERF_BUILDID_DIR.build-id/${build_id:0:2}/${build_id:2} | 36 | linkname=$PERF_BUILDID_DIR.build-id/${build_id:0:2}/${build_id:2} |
| 36 | filename=$(readlink -f $linkname) | 37 | filename=$(readlink -f $linkname) |
| 37 | echo ${linkname#$PERF_BUILDID_DIR} >> $MANIFEST | 38 | echo ${linkname#$PERF_BUILDID_DIR} >> $MANIFEST |
| 38 | echo ${filename#$PERF_BUILDID_DIR} >> $MANIFEST | 39 | echo ${filename#$PERF_BUILDID_LINKDIR} >> $MANIFEST |
| 39 | done | 40 | done |
| 40 | 41 | ||
| 41 | tar cfj $PERF_DATA.tar.bz2 -C $PERF_BUILDID_DIR -T $MANIFEST | 42 | tar cfj $PERF_DATA.tar.bz2 -C $PERF_BUILDID_DIR -T $MANIFEST |
diff --git a/tools/perf/util/annotate.c b/tools/perf/util/annotate.c index 199f69ec656f..08c6d138a655 100644 --- a/tools/perf/util/annotate.c +++ b/tools/perf/util/annotate.c | |||
| @@ -64,8 +64,8 @@ int symbol__inc_addr_samples(struct symbol *sym, struct map *map, | |||
| 64 | 64 | ||
| 65 | pr_debug3("%s: addr=%#" PRIx64 "\n", __func__, map->unmap_ip(map, addr)); | 65 | pr_debug3("%s: addr=%#" PRIx64 "\n", __func__, map->unmap_ip(map, addr)); |
| 66 | 66 | ||
| 67 | if (addr > sym->end) | 67 | if (addr < sym->start || addr > sym->end) |
| 68 | return 0; | 68 | return -ERANGE; |
| 69 | 69 | ||
| 70 | offset = addr - sym->start; | 70 | offset = addr - sym->start; |
| 71 | h = annotation__histogram(notes, evidx); | 71 | h = annotation__histogram(notes, evidx); |
| @@ -561,16 +561,12 @@ void symbol__annotate_decay_histogram(struct symbol *sym, int evidx) | |||
| 561 | { | 561 | { |
| 562 | struct annotation *notes = symbol__annotation(sym); | 562 | struct annotation *notes = symbol__annotation(sym); |
| 563 | struct sym_hist *h = annotation__histogram(notes, evidx); | 563 | struct sym_hist *h = annotation__histogram(notes, evidx); |
| 564 | struct objdump_line *pos; | 564 | int len = sym->end - sym->start, offset; |
| 565 | int len = sym->end - sym->start; | ||
| 566 | 565 | ||
| 567 | h->sum = 0; | 566 | h->sum = 0; |
| 568 | 567 | for (offset = 0; offset < len; ++offset) { | |
| 569 | list_for_each_entry(pos, ¬es->src->source, node) { | 568 | h->addr[offset] = h->addr[offset] * 7 / 8; |
| 570 | if (pos->offset != -1 && pos->offset < len) { | 569 | h->sum += h->addr[offset]; |
| 571 | h->addr[pos->offset] = h->addr[pos->offset] * 7 / 8; | ||
| 572 | h->sum += h->addr[pos->offset]; | ||
| 573 | } | ||
| 574 | } | 570 | } |
| 575 | } | 571 | } |
| 576 | 572 | ||
diff --git a/tools/perf/util/hist.c b/tools/perf/util/hist.c index 2ec4b60aff6c..9f6d630d5316 100644 --- a/tools/perf/util/hist.c +++ b/tools/perf/util/hist.c | |||
| @@ -256,6 +256,18 @@ static struct hist_entry *add_hist_entry(struct hists *hists, | |||
| 256 | if (!cmp) { | 256 | if (!cmp) { |
| 257 | he->period += period; | 257 | he->period += period; |
| 258 | ++he->nr_events; | 258 | ++he->nr_events; |
| 259 | |||
| 260 | /* If the map of an existing hist_entry has | ||
| 261 | * become out-of-date due to an exec() or | ||
| 262 | * similar, update it. Otherwise we will | ||
| 263 | * mis-adjust symbol addresses when computing | ||
| 264 | * the history counter to increment. | ||
| 265 | */ | ||
| 266 | if (he->ms.map != entry->ms.map) { | ||
| 267 | he->ms.map = entry->ms.map; | ||
| 268 | if (he->ms.map) | ||
| 269 | he->ms.map->referenced = true; | ||
| 270 | } | ||
| 259 | goto out; | 271 | goto out; |
| 260 | } | 272 | } |
| 261 | 273 | ||
diff --git a/tools/perf/util/map.c b/tools/perf/util/map.c index dea6d1c1a954..35ae56864e4f 100644 --- a/tools/perf/util/map.c +++ b/tools/perf/util/map.c | |||
| @@ -38,6 +38,7 @@ void map__init(struct map *self, enum map_type type, | |||
| 38 | RB_CLEAR_NODE(&self->rb_node); | 38 | RB_CLEAR_NODE(&self->rb_node); |
| 39 | self->groups = NULL; | 39 | self->groups = NULL; |
| 40 | self->referenced = false; | 40 | self->referenced = false; |
| 41 | self->erange_warned = false; | ||
| 41 | } | 42 | } |
| 42 | 43 | ||
| 43 | struct map *map__new(struct list_head *dsos__list, u64 start, u64 len, | 44 | struct map *map__new(struct list_head *dsos__list, u64 start, u64 len, |
diff --git a/tools/perf/util/map.h b/tools/perf/util/map.h index b100c20b7f94..81371bad4ef0 100644 --- a/tools/perf/util/map.h +++ b/tools/perf/util/map.h | |||
| @@ -33,6 +33,7 @@ struct map { | |||
| 33 | u64 end; | 33 | u64 end; |
| 34 | u8 /* enum map_type */ type; | 34 | u8 /* enum map_type */ type; |
| 35 | bool referenced; | 35 | bool referenced; |
| 36 | bool erange_warned; | ||
| 36 | u32 priv; | 37 | u32 priv; |
| 37 | u64 pgoff; | 38 | u64 pgoff; |
| 38 | 39 | ||
diff --git a/tools/perf/util/session.c b/tools/perf/util/session.c index 9412e3b05f68..1efd3bee6336 100644 --- a/tools/perf/util/session.c +++ b/tools/perf/util/session.c | |||
| @@ -826,8 +826,16 @@ static struct machine * | |||
| 826 | { | 826 | { |
| 827 | const u8 cpumode = event->header.misc & PERF_RECORD_MISC_CPUMODE_MASK; | 827 | const u8 cpumode = event->header.misc & PERF_RECORD_MISC_CPUMODE_MASK; |
| 828 | 828 | ||
| 829 | if (cpumode == PERF_RECORD_MISC_GUEST_KERNEL && perf_guest) | 829 | if (cpumode == PERF_RECORD_MISC_GUEST_KERNEL && perf_guest) { |
| 830 | return perf_session__find_machine(session, event->ip.pid); | 830 | u32 pid; |
| 831 | |||
| 832 | if (event->header.type == PERF_RECORD_MMAP) | ||
| 833 | pid = event->mmap.pid; | ||
| 834 | else | ||
| 835 | pid = event->ip.pid; | ||
| 836 | |||
| 837 | return perf_session__find_machine(session, pid); | ||
| 838 | } | ||
| 831 | 839 | ||
| 832 | return perf_session__find_host_machine(session); | 840 | return perf_session__find_host_machine(session); |
| 833 | } | 841 | } |
| @@ -868,11 +876,11 @@ static int perf_session_deliver_event(struct perf_session *session, | |||
| 868 | dump_sample(session, event, sample); | 876 | dump_sample(session, event, sample); |
| 869 | if (evsel == NULL) { | 877 | if (evsel == NULL) { |
| 870 | ++session->hists.stats.nr_unknown_id; | 878 | ++session->hists.stats.nr_unknown_id; |
| 871 | return -1; | 879 | return 0; |
| 872 | } | 880 | } |
| 873 | if (machine == NULL) { | 881 | if (machine == NULL) { |
| 874 | ++session->hists.stats.nr_unprocessable_samples; | 882 | ++session->hists.stats.nr_unprocessable_samples; |
| 875 | return -1; | 883 | return 0; |
| 876 | } | 884 | } |
| 877 | return tool->sample(tool, event, sample, evsel, machine); | 885 | return tool->sample(tool, event, sample, evsel, machine); |
| 878 | case PERF_RECORD_MMAP: | 886 | case PERF_RECORD_MMAP: |
diff --git a/tools/perf/util/ui/browsers/hists.c b/tools/perf/util/ui/browsers/hists.c index d7a1c4afe28b..2f83e5dc9967 100644 --- a/tools/perf/util/ui/browsers/hists.c +++ b/tools/perf/util/ui/browsers/hists.c | |||
| @@ -125,6 +125,9 @@ static int callchain__count_rows(struct rb_root *chain) | |||
| 125 | 125 | ||
| 126 | static bool map_symbol__toggle_fold(struct map_symbol *self) | 126 | static bool map_symbol__toggle_fold(struct map_symbol *self) |
| 127 | { | 127 | { |
| 128 | if (!self) | ||
| 129 | return false; | ||
| 130 | |||
| 128 | if (!self->has_children) | 131 | if (!self->has_children) |
| 129 | return false; | 132 | return false; |
| 130 | 133 | ||
diff --git a/virt/kvm/iommu.c b/virt/kvm/iommu.c index a457d2138f49..e9fff9830bf0 100644 --- a/virt/kvm/iommu.c +++ b/virt/kvm/iommu.c | |||
| @@ -240,9 +240,13 @@ int kvm_iommu_map_guest(struct kvm *kvm) | |||
| 240 | return -ENODEV; | 240 | return -ENODEV; |
| 241 | } | 241 | } |
| 242 | 242 | ||
| 243 | mutex_lock(&kvm->slots_lock); | ||
| 244 | |||
| 243 | kvm->arch.iommu_domain = iommu_domain_alloc(&pci_bus_type); | 245 | kvm->arch.iommu_domain = iommu_domain_alloc(&pci_bus_type); |
| 244 | if (!kvm->arch.iommu_domain) | 246 | if (!kvm->arch.iommu_domain) { |
| 245 | return -ENOMEM; | 247 | r = -ENOMEM; |
| 248 | goto out_unlock; | ||
| 249 | } | ||
| 246 | 250 | ||
| 247 | if (!allow_unsafe_assigned_interrupts && | 251 | if (!allow_unsafe_assigned_interrupts && |
| 248 | !iommu_domain_has_cap(kvm->arch.iommu_domain, | 252 | !iommu_domain_has_cap(kvm->arch.iommu_domain, |
| @@ -253,17 +257,16 @@ int kvm_iommu_map_guest(struct kvm *kvm) | |||
| 253 | " module option.\n", __func__); | 257 | " module option.\n", __func__); |
| 254 | iommu_domain_free(kvm->arch.iommu_domain); | 258 | iommu_domain_free(kvm->arch.iommu_domain); |
| 255 | kvm->arch.iommu_domain = NULL; | 259 | kvm->arch.iommu_domain = NULL; |
| 256 | return -EPERM; | 260 | r = -EPERM; |
| 261 | goto out_unlock; | ||
| 257 | } | 262 | } |
| 258 | 263 | ||
| 259 | r = kvm_iommu_map_memslots(kvm); | 264 | r = kvm_iommu_map_memslots(kvm); |
| 260 | if (r) | 265 | if (r) |
| 261 | goto out_unmap; | 266 | kvm_iommu_unmap_memslots(kvm); |
| 262 | |||
| 263 | return 0; | ||
| 264 | 267 | ||
| 265 | out_unmap: | 268 | out_unlock: |
| 266 | kvm_iommu_unmap_memslots(kvm); | 269 | mutex_unlock(&kvm->slots_lock); |
| 267 | return r; | 270 | return r; |
| 268 | } | 271 | } |
| 269 | 272 | ||
| @@ -310,6 +313,11 @@ static void kvm_iommu_put_pages(struct kvm *kvm, | |||
| 310 | } | 313 | } |
| 311 | } | 314 | } |
| 312 | 315 | ||
| 316 | void kvm_iommu_unmap_pages(struct kvm *kvm, struct kvm_memory_slot *slot) | ||
| 317 | { | ||
| 318 | kvm_iommu_put_pages(kvm, slot->base_gfn, slot->npages); | ||
| 319 | } | ||
| 320 | |||
| 313 | static int kvm_iommu_unmap_memslots(struct kvm *kvm) | 321 | static int kvm_iommu_unmap_memslots(struct kvm *kvm) |
| 314 | { | 322 | { |
| 315 | int idx; | 323 | int idx; |
| @@ -320,7 +328,7 @@ static int kvm_iommu_unmap_memslots(struct kvm *kvm) | |||
| 320 | slots = kvm_memslots(kvm); | 328 | slots = kvm_memslots(kvm); |
| 321 | 329 | ||
| 322 | kvm_for_each_memslot(memslot, slots) | 330 | kvm_for_each_memslot(memslot, slots) |
| 323 | kvm_iommu_put_pages(kvm, memslot->base_gfn, memslot->npages); | 331 | kvm_iommu_unmap_pages(kvm, memslot); |
| 324 | 332 | ||
| 325 | srcu_read_unlock(&kvm->srcu, idx); | 333 | srcu_read_unlock(&kvm->srcu, idx); |
| 326 | 334 | ||
| @@ -335,7 +343,11 @@ int kvm_iommu_unmap_guest(struct kvm *kvm) | |||
| 335 | if (!domain) | 343 | if (!domain) |
| 336 | return 0; | 344 | return 0; |
| 337 | 345 | ||
| 346 | mutex_lock(&kvm->slots_lock); | ||
| 338 | kvm_iommu_unmap_memslots(kvm); | 347 | kvm_iommu_unmap_memslots(kvm); |
| 348 | kvm->arch.iommu_domain = NULL; | ||
| 349 | mutex_unlock(&kvm->slots_lock); | ||
| 350 | |||
| 339 | iommu_domain_free(domain); | 351 | iommu_domain_free(domain); |
| 340 | return 0; | 352 | return 0; |
| 341 | } | 353 | } |
diff --git a/virt/kvm/kvm_main.c b/virt/kvm/kvm_main.c index 42b73930a6de..9739b533ca2e 100644 --- a/virt/kvm/kvm_main.c +++ b/virt/kvm/kvm_main.c | |||
| @@ -808,12 +808,13 @@ int __kvm_set_memory_region(struct kvm *kvm, | |||
| 808 | if (r) | 808 | if (r) |
| 809 | goto out_free; | 809 | goto out_free; |
| 810 | 810 | ||
| 811 | /* map the pages in iommu page table */ | 811 | /* map/unmap the pages in iommu page table */ |
| 812 | if (npages) { | 812 | if (npages) { |
| 813 | r = kvm_iommu_map_pages(kvm, &new); | 813 | r = kvm_iommu_map_pages(kvm, &new); |
| 814 | if (r) | 814 | if (r) |
| 815 | goto out_free; | 815 | goto out_free; |
| 816 | } | 816 | } else |
| 817 | kvm_iommu_unmap_pages(kvm, &old); | ||
| 817 | 818 | ||
| 818 | r = -ENOMEM; | 819 | r = -ENOMEM; |
| 819 | slots = kmemdup(kvm->memslots, sizeof(struct kvm_memslots), | 820 | slots = kmemdup(kvm->memslots, sizeof(struct kvm_memslots), |
