• Home
  • Raw
  • Download

Lines Matching full:us

67  * sets the machine state and the ABORTING bit in us->dflags to prevent
69 * below, which atomically tests-and-clears the URB_ACTIVE bit in us->dflags
74 * When a disconnect occurs, the DISCONNECTING bit in us->dflags is set to
98 * This is the completion handler which will wake us up when an URB
115 static int usb_stor_msg_common(struct us_data *us, int timeout) in usb_stor_msg_common() argument
122 if (test_bit(US_FLIDX_ABORTING, &us->dflags)) in usb_stor_msg_common()
129 us->current_urb->context = &urb_done; in usb_stor_msg_common()
130 us->current_urb->transfer_flags = 0; in usb_stor_msg_common()
133 * we assume that if transfer_buffer isn't us->iobuf then it in usb_stor_msg_common()
135 * easier than always having the caller tell us whether the in usb_stor_msg_common()
138 if (us->current_urb->transfer_buffer == us->iobuf) in usb_stor_msg_common()
139 us->current_urb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP; in usb_stor_msg_common()
140 us->current_urb->transfer_dma = us->iobuf_dma; in usb_stor_msg_common()
143 status = usb_submit_urb(us->current_urb, GFP_NOIO); in usb_stor_msg_common()
153 set_bit(US_FLIDX_URB_ACTIVE, &us->dflags); in usb_stor_msg_common()
156 if (test_bit(US_FLIDX_ABORTING, &us->dflags)) { in usb_stor_msg_common()
159 if (test_and_clear_bit(US_FLIDX_URB_ACTIVE, &us->dflags)) { in usb_stor_msg_common()
160 usb_stor_dbg(us, "-- cancelling URB\n"); in usb_stor_msg_common()
161 usb_unlink_urb(us->current_urb); in usb_stor_msg_common()
169 clear_bit(US_FLIDX_URB_ACTIVE, &us->dflags); in usb_stor_msg_common()
172 usb_stor_dbg(us, "%s -- cancelling URB\n", in usb_stor_msg_common()
174 usb_kill_urb(us->current_urb); in usb_stor_msg_common()
178 return us->current_urb->status; in usb_stor_msg_common()
185 int usb_stor_control_msg(struct us_data *us, unsigned int pipe, in usb_stor_control_msg() argument
191 usb_stor_dbg(us, "rq=%02x rqtype=%02x value=%04x index=%02x len=%u\n", in usb_stor_control_msg()
195 us->cr->bRequestType = requesttype; in usb_stor_control_msg()
196 us->cr->bRequest = request; in usb_stor_control_msg()
197 us->cr->wValue = cpu_to_le16(value); in usb_stor_control_msg()
198 us->cr->wIndex = cpu_to_le16(index); in usb_stor_control_msg()
199 us->cr->wLength = cpu_to_le16(size); in usb_stor_control_msg()
202 usb_fill_control_urb(us->current_urb, us->pusb_dev, pipe, in usb_stor_control_msg()
203 (unsigned char*) us->cr, data, size, in usb_stor_control_msg()
205 status = usb_stor_msg_common(us, timeout); in usb_stor_control_msg()
209 status = us->current_urb->actual_length; in usb_stor_control_msg()
227 int usb_stor_clear_halt(struct us_data *us, unsigned int pipe) in usb_stor_clear_halt() argument
235 result = usb_stor_control_msg(us, us->send_ctrl_pipe, in usb_stor_clear_halt()
241 usb_reset_endpoint(us->pusb_dev, endp); in usb_stor_clear_halt()
243 usb_stor_dbg(us, "result = %d\n", result); in usb_stor_clear_halt()
256 static int interpret_urb_result(struct us_data *us, unsigned int pipe, in interpret_urb_result() argument
259 usb_stor_dbg(us, "Status code %d; transferred %u/%u\n", in interpret_urb_result()
266 usb_stor_dbg(us, "-- short transfer\n"); in interpret_urb_result()
270 usb_stor_dbg(us, "-- transfer complete\n"); in interpret_urb_result()
280 usb_stor_dbg(us, "-- stall on control pipe\n"); in interpret_urb_result()
285 usb_stor_dbg(us, "clearing endpoint halt for pipe 0x%x\n", in interpret_urb_result()
287 if (usb_stor_clear_halt(us, pipe) < 0) in interpret_urb_result()
293 usb_stor_dbg(us, "-- babble\n"); in interpret_urb_result()
298 usb_stor_dbg(us, "-- transfer cancelled\n"); in interpret_urb_result()
303 usb_stor_dbg(us, "-- short read transfer\n"); in interpret_urb_result()
308 usb_stor_dbg(us, "-- abort or disconnect in progress\n"); in interpret_urb_result()
313 usb_stor_dbg(us, "-- unknown error\n"); in interpret_urb_result()
322 int usb_stor_ctrl_transfer(struct us_data *us, unsigned int pipe, in usb_stor_ctrl_transfer() argument
328 usb_stor_dbg(us, "rq=%02x rqtype=%02x value=%04x index=%02x len=%u\n", in usb_stor_ctrl_transfer()
332 us->cr->bRequestType = requesttype; in usb_stor_ctrl_transfer()
333 us->cr->bRequest = request; in usb_stor_ctrl_transfer()
334 us->cr->wValue = cpu_to_le16(value); in usb_stor_ctrl_transfer()
335 us->cr->wIndex = cpu_to_le16(index); in usb_stor_ctrl_transfer()
336 us->cr->wLength = cpu_to_le16(size); in usb_stor_ctrl_transfer()
339 usb_fill_control_urb(us->current_urb, us->pusb_dev, pipe, in usb_stor_ctrl_transfer()
340 (unsigned char*) us->cr, data, size, in usb_stor_ctrl_transfer()
342 result = usb_stor_msg_common(us, 0); in usb_stor_ctrl_transfer()
344 return interpret_urb_result(us, pipe, size, result, in usb_stor_ctrl_transfer()
345 us->current_urb->actual_length); in usb_stor_ctrl_transfer()
353 * This routine always uses us->recv_intr_pipe as the pipe and
354 * us->ep_bInterval as the interrupt interval.
356 static int usb_stor_intr_transfer(struct us_data *us, void *buf, in usb_stor_intr_transfer() argument
360 unsigned int pipe = us->recv_intr_pipe; in usb_stor_intr_transfer()
363 usb_stor_dbg(us, "xfer %u bytes\n", length); in usb_stor_intr_transfer()
366 maxp = usb_maxpacket(us->pusb_dev, pipe, usb_pipeout(pipe)); in usb_stor_intr_transfer()
371 usb_fill_int_urb(us->current_urb, us->pusb_dev, pipe, buf, in usb_stor_intr_transfer()
373 us->ep_bInterval); in usb_stor_intr_transfer()
374 result = usb_stor_msg_common(us, 0); in usb_stor_intr_transfer()
376 return interpret_urb_result(us, pipe, length, result, in usb_stor_intr_transfer()
377 us->current_urb->actual_length); in usb_stor_intr_transfer()
385 int usb_stor_bulk_transfer_buf(struct us_data *us, unsigned int pipe, in usb_stor_bulk_transfer_buf() argument
390 usb_stor_dbg(us, "xfer %u bytes\n", length); in usb_stor_bulk_transfer_buf()
393 usb_fill_bulk_urb(us->current_urb, us->pusb_dev, pipe, buf, length, in usb_stor_bulk_transfer_buf()
395 result = usb_stor_msg_common(us, 0); in usb_stor_bulk_transfer_buf()
399 *act_len = us->current_urb->actual_length; in usb_stor_bulk_transfer_buf()
400 return interpret_urb_result(us, pipe, length, result, in usb_stor_bulk_transfer_buf()
401 us->current_urb->actual_length); in usb_stor_bulk_transfer_buf()
411 static int usb_stor_bulk_transfer_sglist(struct us_data *us, unsigned int pipe, in usb_stor_bulk_transfer_sglist() argument
418 if (test_bit(US_FLIDX_ABORTING, &us->dflags)) in usb_stor_bulk_transfer_sglist()
422 usb_stor_dbg(us, "xfer %u bytes, %d entries\n", length, num_sg); in usb_stor_bulk_transfer_sglist()
423 result = usb_sg_init(&us->current_sg, us->pusb_dev, pipe, 0, in usb_stor_bulk_transfer_sglist()
426 usb_stor_dbg(us, "usb_sg_init returned %d\n", result); in usb_stor_bulk_transfer_sglist()
434 set_bit(US_FLIDX_SG_ACTIVE, &us->dflags); in usb_stor_bulk_transfer_sglist()
437 if (test_bit(US_FLIDX_ABORTING, &us->dflags)) { in usb_stor_bulk_transfer_sglist()
440 if (test_and_clear_bit(US_FLIDX_SG_ACTIVE, &us->dflags)) { in usb_stor_bulk_transfer_sglist()
441 usb_stor_dbg(us, "-- cancelling sg request\n"); in usb_stor_bulk_transfer_sglist()
442 usb_sg_cancel(&us->current_sg); in usb_stor_bulk_transfer_sglist()
447 usb_sg_wait(&us->current_sg); in usb_stor_bulk_transfer_sglist()
448 clear_bit(US_FLIDX_SG_ACTIVE, &us->dflags); in usb_stor_bulk_transfer_sglist()
450 result = us->current_sg.status; in usb_stor_bulk_transfer_sglist()
452 *act_len = us->current_sg.bytes; in usb_stor_bulk_transfer_sglist()
453 return interpret_urb_result(us, pipe, length, result, in usb_stor_bulk_transfer_sglist()
454 us->current_sg.bytes); in usb_stor_bulk_transfer_sglist()
461 int usb_stor_bulk_srb(struct us_data* us, unsigned int pipe, in usb_stor_bulk_srb() argument
465 int result = usb_stor_bulk_transfer_sglist(us, pipe, scsi_sglist(srb), in usb_stor_bulk_srb()
483 int usb_stor_bulk_transfer_sg(struct us_data* us, unsigned int pipe, in usb_stor_bulk_transfer_sg() argument
492 result = usb_stor_bulk_transfer_sglist(us, pipe, in usb_stor_bulk_transfer_sg()
498 result = usb_stor_bulk_transfer_buf(us, pipe, buf, in usb_stor_bulk_transfer_sg()
519 static void last_sector_hacks(struct us_data *us, struct scsi_cmnd *srb) in last_sector_hacks() argument
539 if (!us->use_last_sector_hacks) in last_sector_hacks()
564 us->use_last_sector_hacks = 0; in last_sector_hacks()
576 if (++us->last_sector_retries < 3) in last_sector_hacks()
590 us->last_sector_retries = 0; in last_sector_hacks()
599 void usb_stor_invoke_transport(struct scsi_cmnd *srb, struct us_data *us) in usb_stor_invoke_transport() argument
606 result = us->transport(srb, us); in usb_stor_invoke_transport()
612 if (test_bit(US_FLIDX_TIMED_OUT, &us->dflags)) { in usb_stor_invoke_transport()
613 usb_stor_dbg(us, "-- command was aborted\n"); in usb_stor_invoke_transport()
620 usb_stor_dbg(us, "-- transport indicates error, resetting\n"); in usb_stor_invoke_transport()
628 last_sector_hacks(us, srb); in usb_stor_invoke_transport()
648 if ((us->protocol == USB_PR_CB || us->protocol == USB_PR_DPCM_USB) && in usb_stor_invoke_transport()
650 usb_stor_dbg(us, "-- CB transport device requiring auto-sense\n"); in usb_stor_invoke_transport()
655 if ((us->fflags & US_FL_SENSE_AFTER_SYNC) && in usb_stor_invoke_transport()
657 usb_stor_dbg(us, "-- sense after SYNC CACHE\n"); in usb_stor_invoke_transport()
667 usb_stor_dbg(us, "-- transport indicates command failure\n"); in usb_stor_invoke_transport()
679 !(us->fflags & US_FL_SANE_SENSE) && in usb_stor_invoke_transport()
680 !(us->fflags & US_FL_BAD_SENSE) && in usb_stor_invoke_transport()
682 usb_stor_dbg(us, "-- SAT supported, increasing auto-sense\n"); in usb_stor_invoke_transport()
683 us->fflags |= US_FL_SANE_SENSE; in usb_stor_invoke_transport()
696 usb_stor_dbg(us, "-- unexpectedly short transfer\n"); in usb_stor_invoke_transport()
709 if (us->fflags & US_FL_SANE_SENSE) in usb_stor_invoke_transport()
712 usb_stor_dbg(us, "Issuing auto-REQUEST_SENSE\n"); in usb_stor_invoke_transport()
717 if (us->subclass == USB_SC_RBC || us->subclass == USB_SC_SCSI || in usb_stor_invoke_transport()
718 us->subclass == USB_SC_CYP_ATACB) in usb_stor_invoke_transport()
725 temp_result = us->transport(us->srb, us); in usb_stor_invoke_transport()
730 if (test_bit(US_FLIDX_TIMED_OUT, &us->dflags)) { in usb_stor_invoke_transport()
731 usb_stor_dbg(us, "-- auto-sense aborted\n"); in usb_stor_invoke_transport()
736 us->fflags &= ~US_FL_SANE_SENSE; in usb_stor_invoke_transport()
737 us->fflags |= US_FL_BAD_SENSE; in usb_stor_invoke_transport()
750 usb_stor_dbg(us, "-- auto-sense failure, retry small sense\n"); in usb_stor_invoke_transport()
752 us->fflags &= ~US_FL_SANE_SENSE; in usb_stor_invoke_transport()
753 us->fflags |= US_FL_BAD_SENSE; in usb_stor_invoke_transport()
759 usb_stor_dbg(us, "-- auto-sense failure\n"); in usb_stor_invoke_transport()
767 if (!(us->fflags & US_FL_SCM_MULT_TARG)) in usb_stor_invoke_transport()
778 !(us->fflags & US_FL_SANE_SENSE) && in usb_stor_invoke_transport()
779 !(us->fflags & US_FL_BAD_SENSE) && in usb_stor_invoke_transport()
781 usb_stor_dbg(us, "-- SANE_SENSE support enabled\n"); in usb_stor_invoke_transport()
782 us->fflags |= US_FL_SANE_SENSE; in usb_stor_invoke_transport()
788 usb_stor_dbg(us, "-- Sense data truncated to %i from %i\n", in usb_stor_invoke_transport()
797 usb_stor_dbg(us, "-- Result from auto-sense is %d\n", in usb_stor_invoke_transport()
799 usb_stor_dbg(us, "-- code: 0x%x, key: 0x%x, ASC: 0x%x, ASCQ: 0x%x\n", in usb_stor_invoke_transport()
803 usb_stor_show_sense(us, sshdr.sense_key, sshdr.asc, sshdr.ascq); in usb_stor_invoke_transport()
864 if (unlikely((us->fflags & US_FL_INITIAL_READ10) && in usb_stor_invoke_transport()
867 set_bit(US_FLIDX_READ10_WORKED, &us->dflags); in usb_stor_invoke_transport()
868 } else if (test_bit(US_FLIDX_READ10_WORKED, &us->dflags)) { in usb_stor_invoke_transport()
869 clear_bit(US_FLIDX_READ10_WORKED, &us->dflags); in usb_stor_invoke_transport()
870 set_bit(US_FLIDX_REDO_READ10, &us->dflags); in usb_stor_invoke_transport()
878 if (test_bit(US_FLIDX_REDO_READ10, &us->dflags)) { in usb_stor_invoke_transport()
879 clear_bit(US_FLIDX_REDO_READ10, &us->dflags); in usb_stor_invoke_transport()
890 last_sector_hacks(us, srb); in usb_stor_invoke_transport()
904 scsi_lock(us_to_host(us)); in usb_stor_invoke_transport()
905 set_bit(US_FLIDX_RESETTING, &us->dflags); in usb_stor_invoke_transport()
906 clear_bit(US_FLIDX_ABORTING, &us->dflags); in usb_stor_invoke_transport()
907 scsi_unlock(us_to_host(us)); in usb_stor_invoke_transport()
913 mutex_unlock(&us->dev_mutex); in usb_stor_invoke_transport()
914 result = usb_stor_port_reset(us); in usb_stor_invoke_transport()
915 mutex_lock(&us->dev_mutex); in usb_stor_invoke_transport()
918 scsi_lock(us_to_host(us)); in usb_stor_invoke_transport()
919 usb_stor_report_device_reset(us); in usb_stor_invoke_transport()
920 scsi_unlock(us_to_host(us)); in usb_stor_invoke_transport()
921 us->transport_reset(us); in usb_stor_invoke_transport()
923 clear_bit(US_FLIDX_RESETTING, &us->dflags); in usb_stor_invoke_transport()
924 last_sector_hacks(us, srb); in usb_stor_invoke_transport()
928 void usb_stor_stop_transport(struct us_data *us) in usb_stor_stop_transport() argument
936 if (test_and_clear_bit(US_FLIDX_URB_ACTIVE, &us->dflags)) { in usb_stor_stop_transport()
937 usb_stor_dbg(us, "-- cancelling URB\n"); in usb_stor_stop_transport()
938 usb_unlink_urb(us->current_urb); in usb_stor_stop_transport()
942 if (test_and_clear_bit(US_FLIDX_SG_ACTIVE, &us->dflags)) { in usb_stor_stop_transport()
943 usb_stor_dbg(us, "-- cancelling sg request\n"); in usb_stor_stop_transport()
944 usb_sg_cancel(&us->current_sg); in usb_stor_stop_transport()
952 int usb_stor_CB_transport(struct scsi_cmnd *srb, struct us_data *us) in usb_stor_CB_transport() argument
962 * Stack may be vmallocated. So no DMA for us. Make a copy. in usb_stor_CB_transport()
964 memcpy(us->iobuf, srb->cmnd, srb->cmd_len); in usb_stor_CB_transport()
965 result = usb_stor_ctrl_transfer(us, us->send_ctrl_pipe, in usb_stor_CB_transport()
968 us->ifnum, us->iobuf, srb->cmd_len); in usb_stor_CB_transport()
971 usb_stor_dbg(us, "Call to usb_stor_ctrl_transfer() returned %d\n", in usb_stor_CB_transport()
988 us->recv_bulk_pipe : us->send_bulk_pipe; in usb_stor_CB_transport()
989 result = usb_stor_bulk_srb(us, pipe, srb); in usb_stor_CB_transport()
990 usb_stor_dbg(us, "CBI data stage result is 0x%x\n", result); in usb_stor_CB_transport()
1005 if (us->protocol != USB_PR_CBI) in usb_stor_CB_transport()
1008 result = usb_stor_intr_transfer(us, us->iobuf, 2); in usb_stor_CB_transport()
1009 usb_stor_dbg(us, "Got interrupt data (0x%x, 0x%x)\n", in usb_stor_CB_transport()
1010 us->iobuf[0], us->iobuf[1]); in usb_stor_CB_transport()
1015 * UFI gives us ASC and ASCQ, like a request sense in usb_stor_CB_transport()
1022 if (us->subclass == USB_SC_UFI) { in usb_stor_CB_transport()
1026 if (us->iobuf[0]) in usb_stor_CB_transport()
1038 if (us->iobuf[0]) { in usb_stor_CB_transport()
1039 usb_stor_dbg(us, "CBI IRQ data showed reserved bType 0x%x\n", in usb_stor_CB_transport()
1040 us->iobuf[0]); in usb_stor_CB_transport()
1046 switch (us->iobuf[1] & 0x0F) { in usb_stor_CB_transport()
1060 usb_stor_clear_halt(us, pipe); in usb_stor_CB_transport()
1070 int usb_stor_Bulk_max_lun(struct us_data *us) in usb_stor_Bulk_max_lun() argument
1075 us->iobuf[0] = 0; in usb_stor_Bulk_max_lun()
1076 result = usb_stor_control_msg(us, us->recv_ctrl_pipe, in usb_stor_Bulk_max_lun()
1080 0, us->ifnum, us->iobuf, 1, 10*HZ); in usb_stor_Bulk_max_lun()
1082 usb_stor_dbg(us, "GetMaxLUN command result is %d, data is %d\n", in usb_stor_Bulk_max_lun()
1083 result, us->iobuf[0]); in usb_stor_Bulk_max_lun()
1091 if (us->iobuf[0] < 16) { in usb_stor_Bulk_max_lun()
1092 return us->iobuf[0]; in usb_stor_Bulk_max_lun()
1094 dev_info(&us->pusb_intf->dev, in usb_stor_Bulk_max_lun()
1096 us->iobuf[0]); in usb_stor_Bulk_max_lun()
1110 int usb_stor_Bulk_transport(struct scsi_cmnd *srb, struct us_data *us) in usb_stor_Bulk_transport() argument
1112 struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf; in usb_stor_Bulk_transport()
1113 struct bulk_cs_wrap *bcs = (struct bulk_cs_wrap *) us->iobuf; in usb_stor_Bulk_transport()
1122 if (unlikely(us->fflags & US_FL_BULK32)) { in usb_stor_Bulk_transport()
1124 us->iobuf[31] = 0; in usb_stor_Bulk_transport()
1132 bcb->Tag = ++us->tag; in usb_stor_Bulk_transport()
1134 if (us->fflags & US_FL_SCM_MULT_TARG) in usb_stor_Bulk_transport()
1143 usb_stor_dbg(us, "Bulk Command S 0x%x T 0x%x L %d F %d Trg %d LUN %d CL %d\n", in usb_stor_Bulk_transport()
1148 result = usb_stor_bulk_transfer_buf(us, us->send_bulk_pipe, in usb_stor_Bulk_transport()
1150 usb_stor_dbg(us, "Bulk command transfer result=%d\n", result); in usb_stor_Bulk_transport()
1158 * Some USB-IDE converter chips need a 100us delay between the in usb_stor_Bulk_transport()
1162 if (unlikely(us->fflags & US_FL_GO_SLOW)) in usb_stor_Bulk_transport()
1167 us->recv_bulk_pipe : us->send_bulk_pipe; in usb_stor_Bulk_transport()
1168 result = usb_stor_bulk_srb(us, pipe, srb); in usb_stor_Bulk_transport()
1169 usb_stor_dbg(us, "Bulk data transfer result 0x%x\n", result); in usb_stor_Bulk_transport()
1175 * amount requested, the spec requires us to transfer in usb_stor_Bulk_transport()
1202 usb_stor_dbg(us, "Device skipped data phase\n"); in usb_stor_Bulk_transport()
1215 usb_stor_dbg(us, "Attempting to get CSW...\n"); in usb_stor_Bulk_transport()
1216 result = usb_stor_bulk_transfer_buf(us, us->recv_bulk_pipe, in usb_stor_Bulk_transport()
1225 usb_stor_dbg(us, "Received 0-length CSW; retrying...\n"); in usb_stor_Bulk_transport()
1226 result = usb_stor_bulk_transfer_buf(us, us->recv_bulk_pipe, in usb_stor_Bulk_transport()
1234 usb_stor_dbg(us, "Attempting to get CSW (2nd try)...\n"); in usb_stor_Bulk_transport()
1235 result = usb_stor_bulk_transfer_buf(us, us->recv_bulk_pipe, in usb_stor_Bulk_transport()
1240 usb_stor_dbg(us, "Bulk status result = %d\n", result); in usb_stor_Bulk_transport()
1247 usb_stor_dbg(us, "Bulk Status S 0x%x T 0x%x R %u Stat 0x%x\n", in usb_stor_Bulk_transport()
1250 if (!(bcs->Tag == us->tag || (us->fflags & US_FL_BULK_IGNORE_TAG)) || in usb_stor_Bulk_transport()
1252 usb_stor_dbg(us, "Bulk logical error\n"); in usb_stor_Bulk_transport()
1261 if (!us->bcs_signature) { in usb_stor_Bulk_transport()
1262 us->bcs_signature = bcs->Signature; in usb_stor_Bulk_transport()
1263 if (us->bcs_signature != cpu_to_le32(US_BULK_CS_SIGN)) in usb_stor_Bulk_transport()
1264 usb_stor_dbg(us, "Learnt BCS signature 0x%08X\n", in usb_stor_Bulk_transport()
1265 le32_to_cpu(us->bcs_signature)); in usb_stor_Bulk_transport()
1266 } else if (bcs->Signature != us->bcs_signature) { in usb_stor_Bulk_transport()
1267 usb_stor_dbg(us, "Signature mismatch: got %08X, expecting %08X\n", in usb_stor_Bulk_transport()
1269 le32_to_cpu(us->bcs_signature)); in usb_stor_Bulk_transport()
1275 * was really transferred and what the device tells us in usb_stor_Bulk_transport()
1277 if (residue && !(us->fflags & US_FL_IGNORE_RESIDUE)) { in usb_stor_Bulk_transport()
1290 us->fflags |= US_FL_IGNORE_RESIDUE; in usb_stor_Bulk_transport()
1342 static int usb_stor_reset_common(struct us_data *us, in usb_stor_reset_common() argument
1349 if (test_bit(US_FLIDX_DISCONNECTING, &us->dflags)) { in usb_stor_reset_common()
1350 usb_stor_dbg(us, "No reset during disconnect\n"); in usb_stor_reset_common()
1354 result = usb_stor_control_msg(us, us->send_ctrl_pipe, in usb_stor_reset_common()
1358 usb_stor_dbg(us, "Soft reset failed: %d\n", result); in usb_stor_reset_common()
1366 wait_event_interruptible_timeout(us->delay_wait, in usb_stor_reset_common()
1367 test_bit(US_FLIDX_DISCONNECTING, &us->dflags), in usb_stor_reset_common()
1369 if (test_bit(US_FLIDX_DISCONNECTING, &us->dflags)) { in usb_stor_reset_common()
1370 usb_stor_dbg(us, "Reset interrupted by disconnect\n"); in usb_stor_reset_common()
1374 usb_stor_dbg(us, "Soft reset: clearing bulk-in endpoint halt\n"); in usb_stor_reset_common()
1375 result = usb_stor_clear_halt(us, us->recv_bulk_pipe); in usb_stor_reset_common()
1377 usb_stor_dbg(us, "Soft reset: clearing bulk-out endpoint halt\n"); in usb_stor_reset_common()
1378 result2 = usb_stor_clear_halt(us, us->send_bulk_pipe); in usb_stor_reset_common()
1384 usb_stor_dbg(us, "Soft reset failed\n"); in usb_stor_reset_common()
1386 usb_stor_dbg(us, "Soft reset done\n"); in usb_stor_reset_common()
1393 int usb_stor_CB_reset(struct us_data *us) in usb_stor_CB_reset() argument
1395 memset(us->iobuf, 0xFF, CB_RESET_CMD_SIZE); in usb_stor_CB_reset()
1396 us->iobuf[0] = SEND_DIAGNOSTIC; in usb_stor_CB_reset()
1397 us->iobuf[1] = 4; in usb_stor_CB_reset()
1398 return usb_stor_reset_common(us, US_CBI_ADSC, in usb_stor_CB_reset()
1400 0, us->ifnum, us->iobuf, CB_RESET_CMD_SIZE); in usb_stor_CB_reset()
1408 int usb_stor_Bulk_reset(struct us_data *us) in usb_stor_Bulk_reset() argument
1410 return usb_stor_reset_common(us, US_BULK_RESET_REQUEST, in usb_stor_Bulk_reset()
1412 0, us->ifnum, NULL, 0); in usb_stor_Bulk_reset()
1418 * us->dev_mutex.
1420 int usb_stor_port_reset(struct us_data *us) in usb_stor_port_reset() argument
1425 if (us->pusb_dev->quirks & USB_QUIRK_RESET) in usb_stor_port_reset()
1428 result = usb_lock_device_for_reset(us->pusb_dev, us->pusb_intf); in usb_stor_port_reset()
1430 usb_stor_dbg(us, "unable to lock device for reset: %d\n", in usb_stor_port_reset()
1434 if (test_bit(US_FLIDX_DISCONNECTING, &us->dflags)) { in usb_stor_port_reset()
1436 usb_stor_dbg(us, "No reset during disconnect\n"); in usb_stor_port_reset()
1438 result = usb_reset_device(us->pusb_dev); in usb_stor_port_reset()
1439 usb_stor_dbg(us, "usb_reset_device returns %d\n", in usb_stor_port_reset()
1442 usb_unlock_device(us->pusb_dev); in usb_stor_port_reset()