aboutsummaryrefslogtreecommitdiffstats
diff options
authorGreg Kroah-Hartman <gregkh@suse.de>2008-05-29 11:49:42 -0700
committerGreg Kroah-Hartman <gregkh@suse.de>2008-05-29 11:49:42 -0700
commit5edf9bc84c7c03dd62ba7dd547bc08af9a0f66ee (patch)
treebceb2a653559b16c69bc5fd7a32d445739fc3e1a
parent22179caeb2405e15edb390f49f7e9336fc6de5a7 (diff)
downloadpatches-5edf9bc84c7c03dd62ba7dd547bc08af9a0f66ee.tar.gz
usb bugfix
-rw-r--r--series2
-rw-r--r--usb.current/usb-fsl_usb2_udc-fix-recursive-lock.patch65
2 files changed, 67 insertions, 0 deletions
diff --git a/series b/series
index 2f3347317410c1..b18fea2f5c615d 100644
--- a/series
+++ b/series
@@ -34,6 +34,7 @@ usb.current/usb-add-support-for-rokr-w5-in-unusual_devs.h.patch
usb.current/usb-add-another-scanner-quirk.patch
usb.current/usb-pl2303-another-product-id.patch
usb.current/usb-usb-serial-option-don-t-match-huawei-driver-cd-images.patch
+usb.current/usb-fsl_usb2_udc-fix-recursive-lock.patch
#####################################################################
# Stuff to be merged after 2.6.26 is out
@@ -254,3 +255,4 @@ ldp/oms-add-oms-maxp-driver.patch
kill-bus_id.patch
+
diff --git a/usb.current/usb-fsl_usb2_udc-fix-recursive-lock.patch b/usb.current/usb-fsl_usb2_udc-fix-recursive-lock.patch
new file mode 100644
index 00000000000000..1f41084a8de83d
--- /dev/null
+++ b/usb.current/usb-fsl_usb2_udc-fix-recursive-lock.patch
@@ -0,0 +1,65 @@
+From leoli@freescale.com Thu May 29 11:47:13 2008
+From: Li Yang <leoli@freescale.com>
+Date: Thu, 29 May 2008 21:04:45 +0800
+Subject: USB: fsl_usb2_udc: fix recursive lock
+To: gregkh@suse.de
+Cc: linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, Li Yang <leoli@freescale.com>, "Eugene T. Bordenkircher" <Eugene_Bordenkircher@selinc.com>, David Brownell <david-b@pacbell.net>
+Message-ID: <1212066285-6013-1-git-send-email-leoli@freescale.com>
+
+
+UDC needs to release lock before calling out to gadget driver, since
+it may need to reenter. The change fixes kernel BUG observed on rt
+kernel.
+
+> kernel BUG at kernel/rtmutex.c:683!
+> stopped custom tracer.
+> Oops: Exception in kernel mode, sig: 5 [#1]
+> PREEMPT MPC834x ITX
+> NIP: c021629c LR: c0216270 CTR: 00000000
+> REGS: df761d70 TRAP: 0700 Not tainted (2.6.23.9-rt13)
+> MSR: 00021032 <ME,IR,DR> CR: 28000022 XER: 00000000
+> TASK = df632080[241] 'IRQ-38' THREAD: df760000
+> GPR00: 00000001 df761e20 df632080 00000000 11111111 00000000 df761e6c
+> 00000000
+> GPR08: df761e48 00000000 df761e50 00000000 80000000 ede5cdde 1fffd000
+> 00800000
+> GPR16: ffffffff 00000000 007fff00 00000040 00000000 007ffeb0 00000000
+> 1fff8b08
+> GPR24: 00000000 00000026 00000000 df79a320 c026b2e8 c02240bc 00009032
+> df79a320
+> NIP [c021629c] rt_spin_lock_slowlock+0x9c/0x200
+> LR [c0216270] rt_spin_lock_slowlock+0x70/0x200
+> Call Trace:
+> [df761e20] [c0216270] rt_spin_lock_slowlock+0x70/0x200 (unreliable)
+> [df761e90] [c0182828] fsl_ep_disable+0xcc/0x154
+> [df761eb0] [c0184d30] eth_reset_config+0x88/0x1d0
+> [df761ed0] [c0184ec0] eth_disconnect+0x48/0x64
+> [df761ef0] [c01831a4] reset_queues+0x60/0x78
+> [df761f00] [c0183b74] fsl_udc_irq+0x9b8/0xa58
+> [df761f50] [c003ef30] handle_IRQ_event+0x64/0x100
+> [df761f80] [c003f758] thread_simple_irq+0x6c/0xc8
+> [df761fa0] [c003f888] do_irqd+0xd4/0x2e4
+> [df761fd0] [c0032284] kthread+0x50/0x8c
+> [df761ff0] [c000f9b4] kernel_thread+0x44/0x60
+
+Signed-off-by: Li Yang <leoli@freescale.com>
+Cc: Eugene T. Bordenkircher <Eugene_Bordenkircher@selinc.com>
+Acked-by: David Brownell <dbrownell@users.sourceforge.net>
+Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
+
+---
+ drivers/usb/gadget/fsl_usb2_udc.c | 2 ++
+ 1 file changed, 2 insertions(+)
+
+--- a/drivers/usb/gadget/fsl_usb2_udc.c
++++ b/drivers/usb/gadget/fsl_usb2_udc.c
+@@ -1627,7 +1627,9 @@ static int reset_queues(struct fsl_udc *
+ udc_reset_ep_queue(udc, pipe);
+
+ /* report disconnect; the driver is already quiesced */
++ spin_unlock(&udc->lock);
+ udc->driver->disconnect(&udc->gadget);
++ spin_lock(&udc->lock);
+
+ return 0;
+ }