summaryrefslogtreecommitdiff
path: root/drivers
diff options
context:
space:
mode:
authorAl Cho <acho@novell.com>2010-09-16 03:51:48 (GMT)
committerGreg Kroah-Hartman <gregkh@suse.de>2010-09-16 19:37:35 (GMT)
commita871869245d79ab8d8ee465139144c7cb89e1854 (patch)
treea16befa3b4fe5ca04bbe97da6f76031a4179cebf /drivers
parentb411f12174af8ccea513bd1cc2ea9f80875fb648 (diff)
downloadlinux-a871869245d79ab8d8ee465139144c7cb89e1854.tar.xz
staging: keucr: fix keucr lost disconnect
keucr lost the disconnect, so keucr crash when plug-in and then plug-out SD-card quickly. unmark the part of usb disconnect Signed-off-by: Al Cho <acho@novell.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/staging/keucr/usb.c23
1 files changed, 11 insertions, 12 deletions
diff --git a/drivers/staging/keucr/usb.c b/drivers/staging/keucr/usb.c
index 260828e..606053d 100644
--- a/drivers/staging/keucr/usb.c
+++ b/drivers/staging/keucr/usb.c
@@ -21,6 +21,8 @@ MODULE_AUTHOR("Domao");
MODULE_DESCRIPTION("ENE USB Mass Storage driver for Linux");
MODULE_LICENSE("GPL");
+static unsigned int delay_use = 1;
+
static struct usb_device_id eucr_usb_ids [] = {
{ USB_DEVICE(0x058f, 0x6366) },
{ USB_DEVICE(0x0cf2, 0x6230) },
@@ -181,11 +183,10 @@ static int usb_stor_control_thread(void * __us)
mutex_lock(&(us->dev_mutex));
/* if the device has disconnected, we are free to exit */
-/* if (test_bit(US_FLIDX_DISCONNECTING, &us->flags))
- {
+ if (test_bit(US_FLIDX_DISCONNECTING, &us->dflags)) {
mutex_unlock(&us->dev_mutex);
break;
- }*/
+ }
/* lock access to the state */
scsi_lock(host);
@@ -551,15 +552,13 @@ static int usb_stor_scan_thread(void * __us)
printk("usb --- usb_stor_scan_thread\n");
printk("EUCR : device found at %d\n", us->pusb_dev->devnum);
-// Have we to add this code ?
-// set_freezable();
-// /* Wait for the timeout to expire or for a disconnect */
-// if (delay_use > 0)
-// {
-// wait_event_freezable_timeout(us->delay_wait,
-// test_bit(US_FLIDX_DONT_SCAN, &us->dflags),
-// delay_use * HZ);
-// }
+ set_freezable();
+ /* Wait for the timeout to expire or for a disconnect */
+ if (delay_use > 0) {
+ wait_event_freezable_timeout(us->delay_wait,
+ test_bit(US_FLIDX_DONT_SCAN, &us->dflags),
+ delay_use * HZ);
+ }
/* If the device is still connected, perform the scanning */
if (!test_bit(US_FLIDX_DONT_SCAN, &us->dflags))