diff options
author | Alan Stern <stern@rowland.harvard.edu> | 2008-05-01 15:35:18 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2008-07-21 18:15:53 -0400 |
commit | 7e4d6c387994294ac8198b624ee71e75de60dfd2 (patch) | |
tree | 09c8c519a6284f79c38f49347eb7fdf44d8de13e | |
parent | 2742fd8899328345d97a3443fb787b051b79ebae (diff) |
usb-storage: separate dynamic flags from fixed flags
This patch (as1089) separates out the dynamic atomic bitflags and the
static bitfields in usb-storage. Until now the two sorts of flags
have been sharing the same word; this has always been awkward.
To help prevent possible confusion, the two new fields each have a
different name from the original. us->fflags contains the fixed
bitfields (mostly taken from the USB ID table in unusual_devs.h), and
us->dflags contains the dynamic atomic bitflags (used with set_bit,
test_bit, and so on).
Signed-off-by: Alan Stern <stern@rowland.harvard.edu>
Cc: Matthew Dharm <mdharm-usb@one-eyed-alien.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-rw-r--r-- | drivers/usb/storage/isd200.c | 6 | ||||
-rw-r--r-- | drivers/usb/storage/scsiglue.c | 24 | ||||
-rw-r--r-- | drivers/usb/storage/transport.c | 68 | ||||
-rw-r--r-- | drivers/usb/storage/usb.c | 34 | ||||
-rw-r--r-- | drivers/usb/storage/usb.h | 17 |
5 files changed, 75 insertions, 74 deletions
diff --git a/drivers/usb/storage/isd200.c b/drivers/usb/storage/isd200.c index 3addcd8f827b..a153335f3648 100644 --- a/drivers/usb/storage/isd200.c +++ b/drivers/usb/storage/isd200.c | |||
@@ -586,7 +586,7 @@ static void isd200_invoke_transport( struct us_data *us, | |||
586 | /* if the command gets aborted by the higher layers, we need to | 586 | /* if the command gets aborted by the higher layers, we need to |
587 | * short-circuit all other processing | 587 | * short-circuit all other processing |
588 | */ | 588 | */ |
589 | if (test_bit(US_FLIDX_TIMED_OUT, &us->flags)) { | 589 | if (test_bit(US_FLIDX_TIMED_OUT, &us->dflags)) { |
590 | US_DEBUGP("-- command was aborted\n"); | 590 | US_DEBUGP("-- command was aborted\n"); |
591 | goto Handle_Abort; | 591 | goto Handle_Abort; |
592 | } | 592 | } |
@@ -633,7 +633,7 @@ static void isd200_invoke_transport( struct us_data *us, | |||
633 | 633 | ||
634 | if (need_auto_sense) { | 634 | if (need_auto_sense) { |
635 | result = isd200_read_regs(us); | 635 | result = isd200_read_regs(us); |
636 | if (test_bit(US_FLIDX_TIMED_OUT, &us->flags)) { | 636 | if (test_bit(US_FLIDX_TIMED_OUT, &us->dflags)) { |
637 | US_DEBUGP("-- auto-sense aborted\n"); | 637 | US_DEBUGP("-- auto-sense aborted\n"); |
638 | goto Handle_Abort; | 638 | goto Handle_Abort; |
639 | } | 639 | } |
@@ -663,7 +663,7 @@ static void isd200_invoke_transport( struct us_data *us, | |||
663 | srb->result = DID_ABORT << 16; | 663 | srb->result = DID_ABORT << 16; |
664 | 664 | ||
665 | /* permit the reset transfer to take place */ | 665 | /* permit the reset transfer to take place */ |
666 | clear_bit(US_FLIDX_ABORTING, &us->flags); | 666 | clear_bit(US_FLIDX_ABORTING, &us->dflags); |
667 | /* Need reset here */ | 667 | /* Need reset here */ |
668 | } | 668 | } |
669 | 669 | ||
diff --git a/drivers/usb/storage/scsiglue.c b/drivers/usb/storage/scsiglue.c index 3fcde9f0fa5f..1caf3f7af349 100644 --- a/drivers/usb/storage/scsiglue.c +++ b/drivers/usb/storage/scsiglue.c | |||
@@ -116,10 +116,10 @@ static int slave_configure(struct scsi_device *sdev) | |||
116 | * while others have trouble with more than 64K. At this time we | 116 | * while others have trouble with more than 64K. At this time we |
117 | * are limiting both to 32K (64 sectores). | 117 | * are limiting both to 32K (64 sectores). |
118 | */ | 118 | */ |
119 | if (us->flags & (US_FL_MAX_SECTORS_64 | US_FL_MAX_SECTORS_MIN)) { | 119 | if (us->fflags & (US_FL_MAX_SECTORS_64 | US_FL_MAX_SECTORS_MIN)) { |
120 | unsigned int max_sectors = 64; | 120 | unsigned int max_sectors = 64; |
121 | 121 | ||
122 | if (us->flags & US_FL_MAX_SECTORS_MIN) | 122 | if (us->fflags & US_FL_MAX_SECTORS_MIN) |
123 | max_sectors = PAGE_CACHE_SIZE >> 9; | 123 | max_sectors = PAGE_CACHE_SIZE >> 9; |
124 | if (sdev->request_queue->max_sectors > max_sectors) | 124 | if (sdev->request_queue->max_sectors > max_sectors) |
125 | blk_queue_max_sectors(sdev->request_queue, | 125 | blk_queue_max_sectors(sdev->request_queue, |
@@ -148,7 +148,7 @@ static int slave_configure(struct scsi_device *sdev) | |||
148 | * majority of devices work fine, but a few still can't | 148 | * majority of devices work fine, but a few still can't |
149 | * handle it. The sd driver will simply assume those | 149 | * handle it. The sd driver will simply assume those |
150 | * devices are write-enabled. */ | 150 | * devices are write-enabled. */ |
151 | if (us->flags & US_FL_NO_WP_DETECT) | 151 | if (us->fflags & US_FL_NO_WP_DETECT) |
152 | sdev->skip_ms_page_3f = 1; | 152 | sdev->skip_ms_page_3f = 1; |
153 | 153 | ||
154 | /* A number of devices have problems with MODE SENSE for | 154 | /* A number of devices have problems with MODE SENSE for |
@@ -158,13 +158,13 @@ static int slave_configure(struct scsi_device *sdev) | |||
158 | /* Some disks return the total number of blocks in response | 158 | /* Some disks return the total number of blocks in response |
159 | * to READ CAPACITY rather than the highest block number. | 159 | * to READ CAPACITY rather than the highest block number. |
160 | * If this device makes that mistake, tell the sd driver. */ | 160 | * If this device makes that mistake, tell the sd driver. */ |
161 | if (us->flags & US_FL_FIX_CAPACITY) | 161 | if (us->fflags & US_FL_FIX_CAPACITY) |
162 | sdev->fix_capacity = 1; | 162 | sdev->fix_capacity = 1; |
163 | 163 | ||
164 | /* A few disks have two indistinguishable version, one of | 164 | /* A few disks have two indistinguishable version, one of |
165 | * which reports the correct capacity and the other does not. | 165 | * which reports the correct capacity and the other does not. |
166 | * The sd driver has to guess which is the case. */ | 166 | * The sd driver has to guess which is the case. */ |
167 | if (us->flags & US_FL_CAPACITY_HEURISTICS) | 167 | if (us->fflags & US_FL_CAPACITY_HEURISTICS) |
168 | sdev->guess_capacity = 1; | 168 | sdev->guess_capacity = 1; |
169 | 169 | ||
170 | /* Some devices report a SCSI revision level above 2 but are | 170 | /* Some devices report a SCSI revision level above 2 but are |
@@ -213,7 +213,7 @@ static int slave_configure(struct scsi_device *sdev) | |||
213 | 213 | ||
214 | /* Some devices choke when they receive a PREVENT-ALLOW MEDIUM | 214 | /* Some devices choke when they receive a PREVENT-ALLOW MEDIUM |
215 | * REMOVAL command, so suppress those commands. */ | 215 | * REMOVAL command, so suppress those commands. */ |
216 | if (us->flags & US_FL_NOT_LOCKABLE) | 216 | if (us->fflags & US_FL_NOT_LOCKABLE) |
217 | sdev->lockable = 0; | 217 | sdev->lockable = 0; |
218 | 218 | ||
219 | /* this is to satisfy the compiler, tho I don't think the | 219 | /* this is to satisfy the compiler, tho I don't think the |
@@ -238,7 +238,7 @@ static int queuecommand(struct scsi_cmnd *srb, | |||
238 | } | 238 | } |
239 | 239 | ||
240 | /* fail the command if we are disconnecting */ | 240 | /* fail the command if we are disconnecting */ |
241 | if (test_bit(US_FLIDX_DISCONNECTING, &us->flags)) { | 241 | if (test_bit(US_FLIDX_DISCONNECTING, &us->dflags)) { |
242 | US_DEBUGP("Fail command during disconnect\n"); | 242 | US_DEBUGP("Fail command during disconnect\n"); |
243 | srb->result = DID_NO_CONNECT << 16; | 243 | srb->result = DID_NO_CONNECT << 16; |
244 | done(srb); | 244 | done(srb); |
@@ -280,9 +280,9 @@ static int command_abort(struct scsi_cmnd *srb) | |||
280 | * with the reset). Note that we must retain the host lock while | 280 | * with the reset). Note that we must retain the host lock while |
281 | * calling usb_stor_stop_transport(); otherwise it might interfere | 281 | * calling usb_stor_stop_transport(); otherwise it might interfere |
282 | * with an auto-reset that begins as soon as we release the lock. */ | 282 | * with an auto-reset that begins as soon as we release the lock. */ |
283 | set_bit(US_FLIDX_TIMED_OUT, &us->flags); | 283 | set_bit(US_FLIDX_TIMED_OUT, &us->dflags); |
284 | if (!test_bit(US_FLIDX_RESETTING, &us->flags)) { | 284 | if (!test_bit(US_FLIDX_RESETTING, &us->dflags)) { |
285 | set_bit(US_FLIDX_ABORTING, &us->flags); | 285 | set_bit(US_FLIDX_ABORTING, &us->dflags); |
286 | usb_stor_stop_transport(us); | 286 | usb_stor_stop_transport(us); |
287 | } | 287 | } |
288 | scsi_unlock(us_to_host(us)); | 288 | scsi_unlock(us_to_host(us)); |
@@ -329,7 +329,7 @@ void usb_stor_report_device_reset(struct us_data *us) | |||
329 | struct Scsi_Host *host = us_to_host(us); | 329 | struct Scsi_Host *host = us_to_host(us); |
330 | 330 | ||
331 | scsi_report_device_reset(host, 0, 0); | 331 | scsi_report_device_reset(host, 0, 0); |
332 | if (us->flags & US_FL_SCM_MULT_TARG) { | 332 | if (us->fflags & US_FL_SCM_MULT_TARG) { |
333 | for (i = 1; i < host->max_id; ++i) | 333 | for (i = 1; i < host->max_id; ++i) |
334 | scsi_report_device_reset(host, 0, i); | 334 | scsi_report_device_reset(host, 0, i); |
335 | } | 335 | } |
@@ -400,7 +400,7 @@ static int proc_info (struct Scsi_Host *host, char *buffer, | |||
400 | pos += sprintf(pos, " Quirks:"); | 400 | pos += sprintf(pos, " Quirks:"); |
401 | 401 | ||
402 | #define US_FLAG(name, value) \ | 402 | #define US_FLAG(name, value) \ |
403 | if (us->flags & value) pos += sprintf(pos, " " #name); | 403 | if (us->fflags & value) pos += sprintf(pos, " " #name); |
404 | US_DO_ALL_FLAGS | 404 | US_DO_ALL_FLAGS |
405 | #undef US_FLAG | 405 | #undef US_FLAG |
406 | 406 | ||
diff --git a/drivers/usb/storage/transport.c b/drivers/usb/storage/transport.c index 6610d2dd1e7f..2f88bb958bad 100644 --- a/drivers/usb/storage/transport.c +++ b/drivers/usb/storage/transport.c | |||
@@ -75,14 +75,14 @@ | |||
75 | * by a separate code path.) | 75 | * by a separate code path.) |
76 | * | 76 | * |
77 | * The abort function (usb_storage_command_abort() in scsiglue.c) first | 77 | * The abort function (usb_storage_command_abort() in scsiglue.c) first |
78 | * sets the machine state and the ABORTING bit in us->flags to prevent | 78 | * sets the machine state and the ABORTING bit in us->dflags to prevent |
79 | * new URBs from being submitted. It then calls usb_stor_stop_transport() | 79 | * new URBs from being submitted. It then calls usb_stor_stop_transport() |
80 | * below, which atomically tests-and-clears the URB_ACTIVE bit in us->flags | 80 | * below, which atomically tests-and-clears the URB_ACTIVE bit in us->dflags |
81 | * to see if the current_urb needs to be stopped. Likewise, the SG_ACTIVE | 81 | * to see if the current_urb needs to be stopped. Likewise, the SG_ACTIVE |
82 | * bit is tested to see if the current_sg scatter-gather request needs to be | 82 | * bit is tested to see if the current_sg scatter-gather request needs to be |
83 | * stopped. The timeout callback routine does much the same thing. | 83 | * stopped. The timeout callback routine does much the same thing. |
84 | * | 84 | * |
85 | * When a disconnect occurs, the DISCONNECTING bit in us->flags is set to | 85 | * When a disconnect occurs, the DISCONNECTING bit in us->dflags is set to |
86 | * prevent new URBs from being submitted, and usb_stor_stop_transport() is | 86 | * prevent new URBs from being submitted, and usb_stor_stop_transport() is |
87 | * called to stop any ongoing requests. | 87 | * called to stop any ongoing requests. |
88 | * | 88 | * |
@@ -128,7 +128,7 @@ static int usb_stor_msg_common(struct us_data *us, int timeout) | |||
128 | int status; | 128 | int status; |
129 | 129 | ||
130 | /* don't submit URBs during abort/disconnect processing */ | 130 | /* don't submit URBs during abort/disconnect processing */ |
131 | if (us->flags & ABORTING_OR_DISCONNECTING) | 131 | if (us->dflags & ABORTING_OR_DISCONNECTING) |
132 | return -EIO; | 132 | return -EIO; |
133 | 133 | ||
134 | /* set up data structures for the wakeup system */ | 134 | /* set up data structures for the wakeup system */ |
@@ -159,13 +159,13 @@ static int usb_stor_msg_common(struct us_data *us, int timeout) | |||
159 | 159 | ||
160 | /* since the URB has been submitted successfully, it's now okay | 160 | /* since the URB has been submitted successfully, it's now okay |
161 | * to cancel it */ | 161 | * to cancel it */ |
162 | set_bit(US_FLIDX_URB_ACTIVE, &us->flags); | 162 | set_bit(US_FLIDX_URB_ACTIVE, &us->dflags); |
163 | 163 | ||
164 | /* did an abort/disconnect occur during the submission? */ | 164 | /* did an abort/disconnect occur during the submission? */ |
165 | if (us->flags & ABORTING_OR_DISCONNECTING) { | 165 | if (us->dflags & ABORTING_OR_DISCONNECTING) { |
166 | 166 | ||
167 | /* cancel the URB, if it hasn't been cancelled already */ | 167 | /* cancel the URB, if it hasn't been cancelled already */ |
168 | if (test_and_clear_bit(US_FLIDX_URB_ACTIVE, &us->flags)) { | 168 | if (test_and_clear_bit(US_FLIDX_URB_ACTIVE, &us->dflags)) { |
169 | US_DEBUGP("-- cancelling URB\n"); | 169 | US_DEBUGP("-- cancelling URB\n"); |
170 | usb_unlink_urb(us->current_urb); | 170 | usb_unlink_urb(us->current_urb); |
171 | } | 171 | } |
@@ -175,7 +175,7 @@ static int usb_stor_msg_common(struct us_data *us, int timeout) | |||
175 | timeleft = wait_for_completion_interruptible_timeout( | 175 | timeleft = wait_for_completion_interruptible_timeout( |
176 | &urb_done, timeout ? : MAX_SCHEDULE_TIMEOUT); | 176 | &urb_done, timeout ? : MAX_SCHEDULE_TIMEOUT); |
177 | 177 | ||
178 | clear_bit(US_FLIDX_URB_ACTIVE, &us->flags); | 178 | clear_bit(US_FLIDX_URB_ACTIVE, &us->dflags); |
179 | 179 | ||
180 | if (timeleft <= 0) { | 180 | if (timeleft <= 0) { |
181 | US_DEBUGP("%s -- cancelling URB\n", | 181 | US_DEBUGP("%s -- cancelling URB\n", |
@@ -420,7 +420,7 @@ static int usb_stor_bulk_transfer_sglist(struct us_data *us, unsigned int pipe, | |||
420 | int result; | 420 | int result; |
421 | 421 | ||
422 | /* don't submit s-g requests during abort/disconnect processing */ | 422 | /* don't submit s-g requests during abort/disconnect processing */ |
423 | if (us->flags & ABORTING_OR_DISCONNECTING) | 423 | if (us->dflags & ABORTING_OR_DISCONNECTING) |
424 | return USB_STOR_XFER_ERROR; | 424 | return USB_STOR_XFER_ERROR; |
425 | 425 | ||
426 | /* initialize the scatter-gather request block */ | 426 | /* initialize the scatter-gather request block */ |
@@ -435,13 +435,13 @@ static int usb_stor_bulk_transfer_sglist(struct us_data *us, unsigned int pipe, | |||
435 | 435 | ||
436 | /* since the block has been initialized successfully, it's now | 436 | /* since the block has been initialized successfully, it's now |
437 | * okay to cancel it */ | 437 | * okay to cancel it */ |
438 | set_bit(US_FLIDX_SG_ACTIVE, &us->flags); | 438 | set_bit(US_FLIDX_SG_ACTIVE, &us->dflags); |
439 | 439 | ||
440 | /* did an abort/disconnect occur during the submission? */ | 440 | /* did an abort/disconnect occur during the submission? */ |
441 | if (us->flags & ABORTING_OR_DISCONNECTING) { | 441 | if (us->dflags & ABORTING_OR_DISCONNECTING) { |
442 | 442 | ||
443 | /* cancel the request, if it hasn't been cancelled already */ | 443 | /* cancel the request, if it hasn't been cancelled already */ |
444 | if (test_and_clear_bit(US_FLIDX_SG_ACTIVE, &us->flags)) { | 444 | if (test_and_clear_bit(US_FLIDX_SG_ACTIVE, &us->dflags)) { |
445 | US_DEBUGP("-- cancelling sg request\n"); | 445 | US_DEBUGP("-- cancelling sg request\n"); |
446 | usb_sg_cancel(&us->current_sg); | 446 | usb_sg_cancel(&us->current_sg); |
447 | } | 447 | } |
@@ -449,7 +449,7 @@ static int usb_stor_bulk_transfer_sglist(struct us_data *us, unsigned int pipe, | |||
449 | 449 | ||
450 | /* wait for the completion of the transfer */ | 450 | /* wait for the completion of the transfer */ |
451 | usb_sg_wait(&us->current_sg); | 451 | usb_sg_wait(&us->current_sg); |
452 | clear_bit(US_FLIDX_SG_ACTIVE, &us->flags); | 452 | clear_bit(US_FLIDX_SG_ACTIVE, &us->dflags); |
453 | 453 | ||
454 | result = us->current_sg.status; | 454 | result = us->current_sg.status; |
455 | if (act_len) | 455 | if (act_len) |
@@ -530,7 +530,7 @@ void usb_stor_invoke_transport(struct scsi_cmnd *srb, struct us_data *us) | |||
530 | /* if the command gets aborted by the higher layers, we need to | 530 | /* if the command gets aborted by the higher layers, we need to |
531 | * short-circuit all other processing | 531 | * short-circuit all other processing |
532 | */ | 532 | */ |
533 | if (test_bit(US_FLIDX_TIMED_OUT, &us->flags)) { | 533 | if (test_bit(US_FLIDX_TIMED_OUT, &us->dflags)) { |
534 | US_DEBUGP("-- command was aborted\n"); | 534 | US_DEBUGP("-- command was aborted\n"); |
535 | srb->result = DID_ABORT << 16; | 535 | srb->result = DID_ABORT << 16; |
536 | goto Handle_Errors; | 536 | goto Handle_Errors; |
@@ -616,7 +616,7 @@ void usb_stor_invoke_transport(struct scsi_cmnd *srb, struct us_data *us) | |||
616 | /* let's clean up right away */ | 616 | /* let's clean up right away */ |
617 | scsi_eh_restore_cmnd(srb, &ses); | 617 | scsi_eh_restore_cmnd(srb, &ses); |
618 | 618 | ||
619 | if (test_bit(US_FLIDX_TIMED_OUT, &us->flags)) { | 619 | if (test_bit(US_FLIDX_TIMED_OUT, &us->dflags)) { |
620 | US_DEBUGP("-- auto-sense aborted\n"); | 620 | US_DEBUGP("-- auto-sense aborted\n"); |
621 | srb->result = DID_ABORT << 16; | 621 | srb->result = DID_ABORT << 16; |
622 | goto Handle_Errors; | 622 | goto Handle_Errors; |
@@ -629,7 +629,7 @@ void usb_stor_invoke_transport(struct scsi_cmnd *srb, struct us_data *us) | |||
629 | * auto-sense is perfectly valid | 629 | * auto-sense is perfectly valid |
630 | */ | 630 | */ |
631 | srb->result = DID_ERROR << 16; | 631 | srb->result = DID_ERROR << 16; |
632 | if (!(us->flags & US_FL_SCM_MULT_TARG)) | 632 | if (!(us->fflags & US_FL_SCM_MULT_TARG)) |
633 | goto Handle_Errors; | 633 | goto Handle_Errors; |
634 | return; | 634 | return; |
635 | } | 635 | } |
@@ -679,8 +679,8 @@ void usb_stor_invoke_transport(struct scsi_cmnd *srb, struct us_data *us) | |||
679 | /* Set the RESETTING bit, and clear the ABORTING bit so that | 679 | /* Set the RESETTING bit, and clear the ABORTING bit so that |
680 | * the reset may proceed. */ | 680 | * the reset may proceed. */ |
681 | scsi_lock(us_to_host(us)); | 681 | scsi_lock(us_to_host(us)); |
682 | set_bit(US_FLIDX_RESETTING, &us->flags); | 682 | set_bit(US_FLIDX_RESETTING, &us->dflags); |
683 | clear_bit(US_FLIDX_ABORTING, &us->flags); | 683 | clear_bit(US_FLIDX_ABORTING, &us->dflags); |
684 | scsi_unlock(us_to_host(us)); | 684 | scsi_unlock(us_to_host(us)); |
685 | 685 | ||
686 | /* We must release the device lock because the pre_reset routine | 686 | /* We must release the device lock because the pre_reset routine |
@@ -695,7 +695,7 @@ void usb_stor_invoke_transport(struct scsi_cmnd *srb, struct us_data *us) | |||
695 | scsi_unlock(us_to_host(us)); | 695 | scsi_unlock(us_to_host(us)); |
696 | us->transport_reset(us); | 696 | us->transport_reset(us); |
697 | } | 697 | } |
698 | clear_bit(US_FLIDX_RESETTING, &us->flags); | 698 | clear_bit(US_FLIDX_RESETTING, &us->dflags); |
699 | } | 699 | } |
700 | 700 | ||
701 | /* Stop the current URB transfer */ | 701 | /* Stop the current URB transfer */ |
@@ -707,13 +707,13 @@ void usb_stor_stop_transport(struct us_data *us) | |||
707 | * let's wake it up. The test_and_clear_bit() call | 707 | * let's wake it up. The test_and_clear_bit() call |
708 | * guarantees that if a URB has just been submitted, | 708 | * guarantees that if a URB has just been submitted, |
709 | * it won't be cancelled more than once. */ | 709 | * it won't be cancelled more than once. */ |
710 | if (test_and_clear_bit(US_FLIDX_URB_ACTIVE, &us->flags)) { | 710 | if (test_and_clear_bit(US_FLIDX_URB_ACTIVE, &us->dflags)) { |
711 | US_DEBUGP("-- cancelling URB\n"); | 711 | US_DEBUGP("-- cancelling URB\n"); |
712 | usb_unlink_urb(us->current_urb); | 712 | usb_unlink_urb(us->current_urb); |
713 | } | 713 | } |
714 | 714 | ||
715 | /* If we are waiting for a scatter-gather operation, cancel it. */ | 715 | /* If we are waiting for a scatter-gather operation, cancel it. */ |
716 | if (test_and_clear_bit(US_FLIDX_SG_ACTIVE, &us->flags)) { | 716 | if (test_and_clear_bit(US_FLIDX_SG_ACTIVE, &us->dflags)) { |
717 | US_DEBUGP("-- cancelling sg request\n"); | 717 | US_DEBUGP("-- cancelling sg request\n"); |
718 | usb_sg_cancel(&us->current_sg); | 718 | usb_sg_cancel(&us->current_sg); |
719 | } | 719 | } |
@@ -914,7 +914,7 @@ int usb_stor_Bulk_transport(struct scsi_cmnd *srb, struct us_data *us) | |||
914 | unsigned int cbwlen = US_BULK_CB_WRAP_LEN; | 914 | unsigned int cbwlen = US_BULK_CB_WRAP_LEN; |
915 | 915 | ||
916 | /* Take care of BULK32 devices; set extra byte to 0 */ | 916 | /* Take care of BULK32 devices; set extra byte to 0 */ |
917 | if ( unlikely(us->flags & US_FL_BULK32)) { | 917 | if (unlikely(us->fflags & US_FL_BULK32)) { |
918 | cbwlen = 32; | 918 | cbwlen = 32; |
919 | us->iobuf[31] = 0; | 919 | us->iobuf[31] = 0; |
920 | } | 920 | } |
@@ -925,7 +925,7 @@ int usb_stor_Bulk_transport(struct scsi_cmnd *srb, struct us_data *us) | |||
925 | bcb->Flags = srb->sc_data_direction == DMA_FROM_DEVICE ? 1 << 7 : 0; | 925 | bcb->Flags = srb->sc_data_direction == DMA_FROM_DEVICE ? 1 << 7 : 0; |
926 | bcb->Tag = ++us->tag; | 926 | bcb->Tag = ++us->tag; |
927 | bcb->Lun = srb->device->lun; | 927 | bcb->Lun = srb->device->lun; |
928 | if (us->flags & US_FL_SCM_MULT_TARG) | 928 | if (us->fflags & US_FL_SCM_MULT_TARG) |
929 | bcb->Lun |= srb->device->id << 4; | 929 | bcb->Lun |= srb->device->id << 4; |
930 | bcb->Length = srb->cmd_len; | 930 | bcb->Length = srb->cmd_len; |
931 | 931 | ||
@@ -951,7 +951,7 @@ int usb_stor_Bulk_transport(struct scsi_cmnd *srb, struct us_data *us) | |||
951 | /* Some USB-IDE converter chips need a 100us delay between the | 951 | /* Some USB-IDE converter chips need a 100us delay between the |
952 | * command phase and the data phase. Some devices need a little | 952 | * command phase and the data phase. Some devices need a little |
953 | * more than that, probably because of clock rate inaccuracies. */ | 953 | * more than that, probably because of clock rate inaccuracies. */ |
954 | if (unlikely(us->flags & US_FL_GO_SLOW)) | 954 | if (unlikely(us->fflags & US_FL_GO_SLOW)) |
955 | udelay(125); | 955 | udelay(125); |
956 | 956 | ||
957 | if (transfer_length) { | 957 | if (transfer_length) { |
@@ -1010,7 +1010,7 @@ int usb_stor_Bulk_transport(struct scsi_cmnd *srb, struct us_data *us) | |||
1010 | US_DEBUGP("Bulk Status S 0x%x T 0x%x R %u Stat 0x%x\n", | 1010 | US_DEBUGP("Bulk Status S 0x%x T 0x%x R %u Stat 0x%x\n", |
1011 | le32_to_cpu(bcs->Signature), bcs->Tag, | 1011 | le32_to_cpu(bcs->Signature), bcs->Tag, |
1012 | residue, bcs->Status); | 1012 | residue, bcs->Status); |
1013 | if (!(bcs->Tag == us->tag || (us->flags & US_FL_BULK_IGNORE_TAG)) || | 1013 | if (!(bcs->Tag == us->tag || (us->fflags & US_FL_BULK_IGNORE_TAG)) || |
1014 | bcs->Status > US_BULK_STAT_PHASE) { | 1014 | bcs->Status > US_BULK_STAT_PHASE) { |
1015 | US_DEBUGP("Bulk logical error\n"); | 1015 | US_DEBUGP("Bulk logical error\n"); |
1016 | return USB_STOR_TRANSPORT_ERROR; | 1016 | return USB_STOR_TRANSPORT_ERROR; |
@@ -1035,7 +1035,7 @@ int usb_stor_Bulk_transport(struct scsi_cmnd *srb, struct us_data *us) | |||
1035 | /* try to compute the actual residue, based on how much data | 1035 | /* try to compute the actual residue, based on how much data |
1036 | * was really transferred and what the device tells us */ | 1036 | * was really transferred and what the device tells us */ |
1037 | if (residue) { | 1037 | if (residue) { |
1038 | if (!(us->flags & US_FL_IGNORE_RESIDUE)) { | 1038 | if (!(us->fflags & US_FL_IGNORE_RESIDUE)) { |
1039 | residue = min(residue, transfer_length); | 1039 | residue = min(residue, transfer_length); |
1040 | scsi_set_resid(srb, max(scsi_get_resid(srb), | 1040 | scsi_set_resid(srb, max(scsi_get_resid(srb), |
1041 | (int) residue)); | 1041 | (int) residue)); |
@@ -1090,7 +1090,7 @@ static int usb_stor_reset_common(struct us_data *us, | |||
1090 | int result; | 1090 | int result; |
1091 | int result2; | 1091 | int result2; |
1092 | 1092 | ||
1093 | if (test_bit(US_FLIDX_DISCONNECTING, &us->flags)) { | 1093 | if (test_bit(US_FLIDX_DISCONNECTING, &us->dflags)) { |
1094 | US_DEBUGP("No reset during disconnect\n"); | 1094 | US_DEBUGP("No reset during disconnect\n"); |
1095 | return -EIO; | 1095 | return -EIO; |
1096 | } | 1096 | } |
@@ -1103,12 +1103,12 @@ static int usb_stor_reset_common(struct us_data *us, | |||
1103 | return result; | 1103 | return result; |
1104 | } | 1104 | } |
1105 | 1105 | ||
1106 | /* Give the device some time to recover from the reset, | 1106 | /* Give the device some time to recover from the reset, |
1107 | * but don't delay disconnect processing. */ | 1107 | * but don't delay disconnect processing. */ |
1108 | wait_event_interruptible_timeout(us->delay_wait, | 1108 | wait_event_interruptible_timeout(us->delay_wait, |
1109 | test_bit(US_FLIDX_DISCONNECTING, &us->flags), | 1109 | test_bit(US_FLIDX_DISCONNECTING, &us->dflags), |
1110 | HZ*6); | 1110 | HZ*6); |
1111 | if (test_bit(US_FLIDX_DISCONNECTING, &us->flags)) { | 1111 | if (test_bit(US_FLIDX_DISCONNECTING, &us->dflags)) { |
1112 | US_DEBUGP("Reset interrupted by disconnect\n"); | 1112 | US_DEBUGP("Reset interrupted by disconnect\n"); |
1113 | return -EIO; | 1113 | return -EIO; |
1114 | } | 1114 | } |
@@ -1170,7 +1170,7 @@ int usb_stor_port_reset(struct us_data *us) | |||
1170 | US_DEBUGP("unable to lock device for reset: %d\n", result); | 1170 | US_DEBUGP("unable to lock device for reset: %d\n", result); |
1171 | else { | 1171 | else { |
1172 | /* Were we disconnected while waiting for the lock? */ | 1172 | /* Were we disconnected while waiting for the lock? */ |
1173 | if (test_bit(US_FLIDX_DISCONNECTING, &us->flags)) { | 1173 | if (test_bit(US_FLIDX_DISCONNECTING, &us->dflags)) { |
1174 | result = -EIO; | 1174 | result = -EIO; |
1175 | US_DEBUGP("No reset during disconnect\n"); | 1175 | US_DEBUGP("No reset during disconnect\n"); |
1176 | } else { | 1176 | } else { |
diff --git a/drivers/usb/storage/usb.c b/drivers/usb/storage/usb.c index e268aacb773a..78c0c7ee6b99 100644 --- a/drivers/usb/storage/usb.c +++ b/drivers/usb/storage/usb.c | |||
@@ -321,7 +321,7 @@ static int usb_stor_control_thread(void * __us) | |||
321 | mutex_lock(&(us->dev_mutex)); | 321 | mutex_lock(&(us->dev_mutex)); |
322 | 322 | ||
323 | /* if the device has disconnected, we are free to exit */ | 323 | /* if the device has disconnected, we are free to exit */ |
324 | if (test_bit(US_FLIDX_DISCONNECTING, &us->flags)) { | 324 | if (test_bit(US_FLIDX_DISCONNECTING, &us->dflags)) { |
325 | US_DEBUGP("-- exiting\n"); | 325 | US_DEBUGP("-- exiting\n"); |
326 | mutex_unlock(&us->dev_mutex); | 326 | mutex_unlock(&us->dev_mutex); |
327 | break; | 327 | break; |
@@ -331,7 +331,7 @@ static int usb_stor_control_thread(void * __us) | |||
331 | scsi_lock(host); | 331 | scsi_lock(host); |
332 | 332 | ||
333 | /* has the command timed out *already* ? */ | 333 | /* has the command timed out *already* ? */ |
334 | if (test_bit(US_FLIDX_TIMED_OUT, &us->flags)) { | 334 | if (test_bit(US_FLIDX_TIMED_OUT, &us->dflags)) { |
335 | us->srb->result = DID_ABORT << 16; | 335 | us->srb->result = DID_ABORT << 16; |
336 | goto SkipForAbort; | 336 | goto SkipForAbort; |
337 | } | 337 | } |
@@ -350,7 +350,7 @@ static int usb_stor_control_thread(void * __us) | |||
350 | * the maximum known LUN | 350 | * the maximum known LUN |
351 | */ | 351 | */ |
352 | else if (us->srb->device->id && | 352 | else if (us->srb->device->id && |
353 | !(us->flags & US_FL_SCM_MULT_TARG)) { | 353 | !(us->fflags & US_FL_SCM_MULT_TARG)) { |
354 | US_DEBUGP("Bad target number (%d:%d)\n", | 354 | US_DEBUGP("Bad target number (%d:%d)\n", |
355 | us->srb->device->id, us->srb->device->lun); | 355 | us->srb->device->id, us->srb->device->lun); |
356 | us->srb->result = DID_BAD_TARGET << 16; | 356 | us->srb->result = DID_BAD_TARGET << 16; |
@@ -365,7 +365,7 @@ static int usb_stor_control_thread(void * __us) | |||
365 | /* Handle those devices which need us to fake | 365 | /* Handle those devices which need us to fake |
366 | * their inquiry data */ | 366 | * their inquiry data */ |
367 | else if ((us->srb->cmnd[0] == INQUIRY) && | 367 | else if ((us->srb->cmnd[0] == INQUIRY) && |
368 | (us->flags & US_FL_FIX_INQUIRY)) { | 368 | (us->fflags & US_FL_FIX_INQUIRY)) { |
369 | unsigned char data_ptr[36] = { | 369 | unsigned char data_ptr[36] = { |
370 | 0x00, 0x80, 0x02, 0x02, | 370 | 0x00, 0x80, 0x02, 0x02, |
371 | 0x1F, 0x00, 0x00, 0x00}; | 371 | 0x1F, 0x00, 0x00, 0x00}; |
@@ -403,12 +403,12 @@ SkipForAbort: | |||
403 | * the TIMED_OUT flag, not srb->result == DID_ABORT, because | 403 | * the TIMED_OUT flag, not srb->result == DID_ABORT, because |
404 | * the timeout might have occurred after the command had | 404 | * the timeout might have occurred after the command had |
405 | * already completed with a different result code. */ | 405 | * already completed with a different result code. */ |
406 | if (test_bit(US_FLIDX_TIMED_OUT, &us->flags)) { | 406 | if (test_bit(US_FLIDX_TIMED_OUT, &us->dflags)) { |
407 | complete(&(us->notify)); | 407 | complete(&(us->notify)); |
408 | 408 | ||
409 | /* Allow USB transfers to resume */ | 409 | /* Allow USB transfers to resume */ |
410 | clear_bit(US_FLIDX_ABORTING, &us->flags); | 410 | clear_bit(US_FLIDX_ABORTING, &us->dflags); |
411 | clear_bit(US_FLIDX_TIMED_OUT, &us->flags); | 411 | clear_bit(US_FLIDX_TIMED_OUT, &us->dflags); |
412 | } | 412 | } |
413 | 413 | ||
414 | /* finished working on this command */ | 414 | /* finished working on this command */ |
@@ -500,9 +500,9 @@ static int get_device_info(struct us_data *us, const struct usb_device_id *id) | |||
500 | us->protocol = (unusual_dev->useTransport == US_PR_DEVICE) ? | 500 | us->protocol = (unusual_dev->useTransport == US_PR_DEVICE) ? |
501 | idesc->bInterfaceProtocol : | 501 | idesc->bInterfaceProtocol : |
502 | unusual_dev->useTransport; | 502 | unusual_dev->useTransport; |
503 | us->flags = USB_US_ORIG_FLAGS(id->driver_info); | 503 | us->fflags = USB_US_ORIG_FLAGS(id->driver_info); |
504 | 504 | ||
505 | if (us->flags & US_FL_IGNORE_DEVICE) { | 505 | if (us->fflags & US_FL_IGNORE_DEVICE) { |
506 | printk(KERN_INFO USB_STORAGE "device ignored\n"); | 506 | printk(KERN_INFO USB_STORAGE "device ignored\n"); |
507 | return -ENODEV; | 507 | return -ENODEV; |
508 | } | 508 | } |
@@ -512,7 +512,7 @@ static int get_device_info(struct us_data *us, const struct usb_device_id *id) | |||
512 | * disable it if we're in full-speed | 512 | * disable it if we're in full-speed |
513 | */ | 513 | */ |
514 | if (dev->speed != USB_SPEED_HIGH) | 514 | if (dev->speed != USB_SPEED_HIGH) |
515 | us->flags &= ~US_FL_GO_SLOW; | 515 | us->fflags &= ~US_FL_GO_SLOW; |
516 | 516 | ||
517 | /* Log a message if a non-generic unusual_dev entry contains an | 517 | /* Log a message if a non-generic unusual_dev entry contains an |
518 | * unnecessary subclass or protocol override. This may stimulate | 518 | * unnecessary subclass or protocol override. This may stimulate |
@@ -533,7 +533,7 @@ static int get_device_info(struct us_data *us, const struct usb_device_id *id) | |||
533 | if (unusual_dev->useTransport != US_PR_DEVICE && | 533 | if (unusual_dev->useTransport != US_PR_DEVICE && |
534 | us->protocol == idesc->bInterfaceProtocol) | 534 | us->protocol == idesc->bInterfaceProtocol) |
535 | msg += 2; | 535 | msg += 2; |
536 | if (msg >= 0 && !(us->flags & US_FL_NEED_OVERRIDE)) | 536 | if (msg >= 0 && !(us->fflags & US_FL_NEED_OVERRIDE)) |
537 | printk(KERN_NOTICE USB_STORAGE "This device " | 537 | printk(KERN_NOTICE USB_STORAGE "This device " |
538 | "(%04x,%04x,%04x S %02x P %02x)" | 538 | "(%04x,%04x,%04x S %02x P %02x)" |
539 | " has %s in unusual_devs.h (kernel" | 539 | " has %s in unusual_devs.h (kernel" |
@@ -663,7 +663,7 @@ static int get_transport(struct us_data *us) | |||
663 | US_DEBUGP("Transport: %s\n", us->transport_name); | 663 | US_DEBUGP("Transport: %s\n", us->transport_name); |
664 | 664 | ||
665 | /* fix for single-lun devices */ | 665 | /* fix for single-lun devices */ |
666 | if (us->flags & US_FL_SINGLE_LUN) | 666 | if (us->fflags & US_FL_SINGLE_LUN) |
667 | us->max_lun = 0; | 667 | us->max_lun = 0; |
668 | return 0; | 668 | return 0; |
669 | } | 669 | } |
@@ -824,7 +824,7 @@ static void usb_stor_release_resources(struct us_data *us) | |||
824 | * any more commands. | 824 | * any more commands. |
825 | */ | 825 | */ |
826 | US_DEBUGP("-- sending exit command to thread\n"); | 826 | US_DEBUGP("-- sending exit command to thread\n"); |
827 | set_bit(US_FLIDX_DISCONNECTING, &us->flags); | 827 | set_bit(US_FLIDX_DISCONNECTING, &us->dflags); |
828 | up(&us->sema); | 828 | up(&us->sema); |
829 | if (us->ctl_thread) | 829 | if (us->ctl_thread) |
830 | kthread_stop(us->ctl_thread); | 830 | kthread_stop(us->ctl_thread); |
@@ -868,7 +868,7 @@ static void quiesce_and_remove_host(struct us_data *us) | |||
868 | /* Prevent new USB transfers, stop the current command, and | 868 | /* Prevent new USB transfers, stop the current command, and |
869 | * interrupt a SCSI-scan or device-reset delay */ | 869 | * interrupt a SCSI-scan or device-reset delay */ |
870 | scsi_lock(host); | 870 | scsi_lock(host); |
871 | set_bit(US_FLIDX_DISCONNECTING, &us->flags); | 871 | set_bit(US_FLIDX_DISCONNECTING, &us->dflags); |
872 | scsi_unlock(host); | 872 | scsi_unlock(host); |
873 | usb_stor_stop_transport(us); | 873 | usb_stor_stop_transport(us); |
874 | wake_up(&us->delay_wait); | 874 | wake_up(&us->delay_wait); |
@@ -919,16 +919,16 @@ static int usb_stor_scan_thread(void * __us) | |||
919 | printk(KERN_DEBUG "usb-storage: waiting for device " | 919 | printk(KERN_DEBUG "usb-storage: waiting for device " |
920 | "to settle before scanning\n"); | 920 | "to settle before scanning\n"); |
921 | wait_event_freezable_timeout(us->delay_wait, | 921 | wait_event_freezable_timeout(us->delay_wait, |
922 | test_bit(US_FLIDX_DISCONNECTING, &us->flags), | 922 | test_bit(US_FLIDX_DISCONNECTING, &us->dflags), |
923 | delay_use * HZ); | 923 | delay_use * HZ); |
924 | } | 924 | } |
925 | 925 | ||
926 | /* If the device is still connected, perform the scanning */ | 926 | /* If the device is still connected, perform the scanning */ |
927 | if (!test_bit(US_FLIDX_DISCONNECTING, &us->flags)) { | 927 | if (!test_bit(US_FLIDX_DISCONNECTING, &us->dflags)) { |
928 | 928 | ||
929 | /* For bulk-only devices, determine the max LUN value */ | 929 | /* For bulk-only devices, determine the max LUN value */ |
930 | if (us->protocol == US_PR_BULK && | 930 | if (us->protocol == US_PR_BULK && |
931 | !(us->flags & US_FL_SINGLE_LUN)) { | 931 | !(us->fflags & US_FL_SINGLE_LUN)) { |
932 | mutex_lock(&us->dev_mutex); | 932 | mutex_lock(&us->dev_mutex); |
933 | us->max_lun = usb_stor_Bulk_max_lun(us); | 933 | us->max_lun = usb_stor_Bulk_max_lun(us); |
934 | mutex_unlock(&us->dev_mutex); | 934 | mutex_unlock(&us->dev_mutex); |
diff --git a/drivers/usb/storage/usb.h b/drivers/usb/storage/usb.h index 8d87503e2560..b169132f021b 100644 --- a/drivers/usb/storage/usb.h +++ b/drivers/usb/storage/usb.h | |||
@@ -67,15 +67,15 @@ struct us_unusual_dev { | |||
67 | }; | 67 | }; |
68 | 68 | ||
69 | 69 | ||
70 | /* Dynamic flag definitions: used in set_bit() etc. */ | 70 | /* Dynamic bitflag definitions (us->dflags): used in set_bit() etc. */ |
71 | #define US_FLIDX_URB_ACTIVE 18 /* 0x00040000 current_urb is in use */ | 71 | #define US_FLIDX_URB_ACTIVE 0 /* current_urb is in use */ |
72 | #define US_FLIDX_SG_ACTIVE 19 /* 0x00080000 current_sg is in use */ | 72 | #define US_FLIDX_SG_ACTIVE 1 /* current_sg is in use */ |
73 | #define US_FLIDX_ABORTING 20 /* 0x00100000 abort is in progress */ | 73 | #define US_FLIDX_ABORTING 2 /* abort is in progress */ |
74 | #define US_FLIDX_DISCONNECTING 21 /* 0x00200000 disconnect in progress */ | 74 | #define US_FLIDX_DISCONNECTING 3 /* disconnect in progress */ |
75 | #define ABORTING_OR_DISCONNECTING ((1UL << US_FLIDX_ABORTING) | \ | 75 | #define ABORTING_OR_DISCONNECTING ((1UL << US_FLIDX_ABORTING) | \ |
76 | (1UL << US_FLIDX_DISCONNECTING)) | 76 | (1UL << US_FLIDX_DISCONNECTING)) |
77 | #define US_FLIDX_RESETTING 22 /* 0x00400000 device reset in progress */ | 77 | #define US_FLIDX_RESETTING 4 /* device reset in progress */ |
78 | #define US_FLIDX_TIMED_OUT 23 /* 0x00800000 SCSI midlayer timed out */ | 78 | #define US_FLIDX_TIMED_OUT 5 /* SCSI midlayer timed out */ |
79 | 79 | ||
80 | 80 | ||
81 | #define USB_STOR_STRING_LEN 32 | 81 | #define USB_STOR_STRING_LEN 32 |
@@ -109,7 +109,8 @@ struct us_data { | |||
109 | struct usb_device *pusb_dev; /* this usb_device */ | 109 | struct usb_device *pusb_dev; /* this usb_device */ |
110 | struct usb_interface *pusb_intf; /* this interface */ | 110 | struct usb_interface *pusb_intf; /* this interface */ |
111 | struct us_unusual_dev *unusual_dev; /* device-filter entry */ | 111 | struct us_unusual_dev *unusual_dev; /* device-filter entry */ |
112 | unsigned long flags; /* from filter initially */ | 112 | unsigned long fflags; /* fixed flags from filter */ |
113 | unsigned long dflags; /* dynamic atomic bitflags */ | ||
113 | unsigned int send_bulk_pipe; /* cached pipe values */ | 114 | unsigned int send_bulk_pipe; /* cached pipe values */ |
114 | unsigned int recv_bulk_pipe; | 115 | unsigned int recv_bulk_pipe; |
115 | unsigned int send_ctrl_pipe; | 116 | unsigned int send_ctrl_pipe; |