Commit e391d5f6 authored by Matthew Dharm's avatar Matthew Dharm Committed by Linus Torvalds

[PATCH] usb-storage: convert to common transfer functions

This patch makes all sub-drivers use the same data-moving functions.  It
also eliminates the duplicate functions from raw_bulk.c
parent 2167f96c
...@@ -67,25 +67,23 @@ static int datafab_determine_lun(struct us_data *us, ...@@ -67,25 +67,23 @@ static int datafab_determine_lun(struct us_data *us,
static inline int static inline int
datafab_bulk_read(struct us_data *us, unsigned char *data, unsigned int len) { datafab_bulk_read(struct us_data *us, unsigned char *data, unsigned int len) {
unsigned int act_len; /* ignored */
if (len == 0) if (len == 0)
return USB_STOR_XFER_GOOD; return USB_STOR_XFER_GOOD;
US_DEBUGP("datafab_bulk_read: len = %d\n", len); US_DEBUGP("datafab_bulk_read: len = %d\n", len);
return usb_storage_raw_bulk(us, SCSI_DATA_READ, data, len, &act_len); return usb_stor_bulk_transfer_buf(us, us->recv_bulk_pipe,
data, len, NULL);
} }
static inline int static inline int
datafab_bulk_write(struct us_data *us, unsigned char *data, unsigned int len) { datafab_bulk_write(struct us_data *us, unsigned char *data, unsigned int len) {
unsigned int act_len; /* ignored */
if (len == 0) if (len == 0)
return USB_STOR_XFER_GOOD; return USB_STOR_XFER_GOOD;
US_DEBUGP("datafab_bulk_write: len = %d\n", len); US_DEBUGP("datafab_bulk_write: len = %d\n", len);
return usb_storage_raw_bulk(us, SCSI_DATA_WRITE, data, len, &act_len); return usb_stor_bulk_transfer_buf(us, us->send_bulk_pipe,
data, len, NULL);
} }
......
...@@ -62,13 +62,12 @@ static inline int jumpshot_bulk_read(struct us_data *us, ...@@ -62,13 +62,12 @@ static inline int jumpshot_bulk_read(struct us_data *us,
unsigned char *data, unsigned char *data,
unsigned int len) unsigned int len)
{ {
unsigned int act_len; /* ignored */
if (len == 0) if (len == 0)
return USB_STOR_XFER_GOOD; return USB_STOR_XFER_GOOD;
US_DEBUGP("jumpshot_bulk_read: len = %d\n", len); US_DEBUGP("jumpshot_bulk_read: len = %d\n", len);
return usb_storage_raw_bulk(us, SCSI_DATA_READ, data, len, &act_len); return usb_stor_bulk_transfer_buf(us, us->recv_bulk_pipe,
data, len, NULL);
} }
...@@ -76,13 +75,12 @@ static inline int jumpshot_bulk_write(struct us_data *us, ...@@ -76,13 +75,12 @@ static inline int jumpshot_bulk_write(struct us_data *us,
unsigned char *data, unsigned char *data,
unsigned int len) unsigned int len)
{ {
unsigned int act_len; /* ignored */
if (len == 0) if (len == 0)
return USB_STOR_XFER_GOOD; return USB_STOR_XFER_GOOD;
US_DEBUGP("jumpshot_bulk_write: len = %d\n", len); US_DEBUGP("jumpshot_bulk_write: len = %d\n", len);
return usb_storage_raw_bulk(us, SCSI_DATA_WRITE, data, len, &act_len); return usb_stor_bulk_transfer_buf(us, us->send_bulk_pipe,
data, len, NULL);
} }
...@@ -95,11 +93,11 @@ static int jumpshot_get_status(struct us_data *us) ...@@ -95,11 +93,11 @@ static int jumpshot_get_status(struct us_data *us)
return USB_STOR_TRANSPORT_ERROR; return USB_STOR_TRANSPORT_ERROR;
// send the setup // send the setup
rc = usb_storage_send_control(us, us->recv_ctrl_pipe, rc = usb_stor_ctrl_transfer(us, us->recv_ctrl_pipe,
0, 0xA0, 0, 7, &reply, 1); 0, 0xA0, 0, 7, &reply, 1);
if (rc != USB_STOR_TRANSPORT_GOOD) if (rc != USB_STOR_XFER_GOOD)
return rc; return USB_STOR_TRANSPORT_ERROR;
if (reply != 0x50) { if (reply != 0x50) {
US_DEBUGP("jumpshot_get_status: 0x%2x\n", US_DEBUGP("jumpshot_get_status: 0x%2x\n",
...@@ -159,9 +157,9 @@ static int jumpshot_read_data(struct us_data *us, ...@@ -159,9 +157,9 @@ static int jumpshot_read_data(struct us_data *us,
command[5] |= (sector >> 24) & 0x0F; command[5] |= (sector >> 24) & 0x0F;
// send the setup + command // send the setup + command
result = usb_storage_send_control(us, us->send_ctrl_pipe, result = usb_stor_ctrl_transfer(us, us->send_ctrl_pipe,
0, 0x20, 0, 1, command, 7); 0, 0x20, 0, 1, command, 7);
if (result != USB_STOR_TRANSPORT_GOOD) if (result != USB_STOR_XFER_GOOD)
goto leave; goto leave;
// read the result // read the result
...@@ -245,8 +243,10 @@ static int jumpshot_write_data(struct us_data *us, ...@@ -245,8 +243,10 @@ static int jumpshot_write_data(struct us_data *us,
command[5] |= (sector >> 24) & 0x0F; command[5] |= (sector >> 24) & 0x0F;
// send the setup + command // send the setup + command
result = usb_storage_send_control(us, us->send_ctrl_pipe, result = usb_stor_ctrl_transfer(us, us->send_ctrl_pipe,
0, 0x20, 0, 1, command, 7); 0, 0x20, 0, 1, command, 7);
if (result != USB_STOR_XFER_GOOD)
goto leave;
// send the data // send the data
result = jumpshot_bulk_write(us, ptr, len); result = jumpshot_bulk_write(us, ptr, len);
...@@ -299,10 +299,10 @@ static int jumpshot_id_device(struct us_data *us, ...@@ -299,10 +299,10 @@ static int jumpshot_id_device(struct us_data *us,
return USB_STOR_TRANSPORT_ERROR; return USB_STOR_TRANSPORT_ERROR;
// send the setup // send the setup
rc = usb_storage_send_control(us, us->send_ctrl_pipe, rc = usb_stor_ctrl_transfer(us, us->send_ctrl_pipe,
0, 0x20, 0, 6, command, 2); 0, 0x20, 0, 6, command, 2);
if (rc != USB_STOR_TRANSPORT_GOOD) { if (rc != USB_STOR_XFER_GOOD) {
US_DEBUGP("jumpshot_id_device: Gah! " US_DEBUGP("jumpshot_id_device: Gah! "
"send_control for read_capacity failed\n"); "send_control for read_capacity failed\n");
return rc; return rc;
......
...@@ -13,219 +13,6 @@ ...@@ -13,219 +13,6 @@
#include "transport.h" #include "transport.h"
#include "raw_bulk.h" #include "raw_bulk.h"
#ifdef CONFIG_USB_STORAGE_DEBUG
#define DEBUG_PRCT 12
#else
#define DEBUG_PRCT 0
#endif
/*
* Send a control message and wait for the response.
*
* us - the pointer to the us_data structure for the device to use
*
* request - the URB Setup Packet's first 6 bytes. The first byte always
* corresponds to the request type, and the second byte always corresponds
* to the request. The other 4 bytes do not correspond to value and index,
* since they are used in a custom way by the SCM protocol.
*
* xfer_data - a buffer from which to get, or to which to store, any data
* that gets send or received, respectively, with the URB. Even though
* it looks like we allocate a buffer in this code for the data, xfer_data
* must contain enough allocated space.
*
* xfer_len - the number of bytes to send or receive with the URB.
*
*/
int
usb_storage_send_control(struct us_data *us,
unsigned int pipe,
unsigned char request,
unsigned char requesttype,
unsigned int value,
unsigned int index,
unsigned char *xfer_data,
unsigned int xfer_len) {
int result;
// Send the URB to the device and wait for a response.
/* Why are request and request type reversed in this call? */
result = usb_stor_control_msg(us, pipe,
request, requesttype, value, index,
xfer_data, xfer_len);
/* did we abort this command? */
if (atomic_read(&us->sm_state) == US_STATE_ABORTING) {
US_DEBUGP("usb_stor_send_control(): transfer aborted\n");
return USB_STOR_TRANSPORT_ABORTED;
}
// Check the return code for the command.
if (result < 0) {
/* a stall indicates a protocol error */
if (result == -EPIPE) {
US_DEBUGP("-- Stall on control pipe\n");
return USB_STOR_TRANSPORT_ERROR;
}
/* Uh oh... serious problem here */
return USB_STOR_TRANSPORT_ERROR;
}
return USB_STOR_TRANSPORT_GOOD;
}
int
usb_storage_raw_bulk(struct us_data *us, int direction, unsigned char *data,
unsigned int len, unsigned int *act_len) {
int result;
unsigned int pipe;
if (direction == SCSI_DATA_READ)
pipe = us->recv_bulk_pipe;
else
pipe = us->send_bulk_pipe;
result = usb_stor_bulk_msg(us, data, pipe, len, act_len);
/* if we stall, we need to clear it before we go on */
if (result == -EPIPE) {
US_DEBUGP("EPIPE: clearing endpoint halt for"
" pipe 0x%x, stalled at %d bytes\n",
pipe, *act_len);
if (usb_stor_clear_halt(us, pipe) < 0)
return USB_STOR_XFER_ERROR;
return USB_STOR_XFER_STALLED;
}
/* did we abort this command? */
if (atomic_read(&us->sm_state) == US_STATE_ABORTING) {
US_DEBUGP("usb_storage_raw_bulk(): transfer aborted\n");
return USB_STOR_XFER_ABORTED;
}
if (result) {
/* NAK - that means we've retried a few times already */
if (result == -ETIMEDOUT)
US_DEBUGP("raw_bulk(): device NAKed\n");
else if (result == -EOVERFLOW)
US_DEBUGP("raw_bulk(): babble/overflow\n");
else if (result == -ECONNRESET)
US_DEBUGP("raw_bulk(): asynchronous reset\n");
else if (result != -EPIPE)
US_DEBUGP("raw_bulk(): unknown error %d\n",
result);
return USB_STOR_XFER_ERROR;
}
if (*act_len != len) {
US_DEBUGP("Warning: Transferred only %d of %d bytes\n",
*act_len, len);
return USB_STOR_XFER_SHORT;
}
#if 0
US_DEBUGP("raw_bulk(): Transferred %s %d of %d bytes\n",
(direction == SCSI_DATA_READ) ? "in" : "out",
*act_len, len);
#endif
return USB_STOR_XFER_GOOD;
}
int
usb_storage_bulk_transport(struct us_data *us, int direction,
unsigned char *data, unsigned int len,
int use_sg) {
int result = USB_STOR_XFER_ERROR;
int transferred = 0;
int i;
struct scatterlist *sg;
unsigned int act_len;
if (len == 0)
return USB_STOR_XFER_GOOD;
#if DEBUG_PRCT
if (direction == SCSI_DATA_WRITE && !use_sg) {
char string[64];
/* Debug-print the first N bytes of the write transfer */
strcpy(string, "wr: ");
for (i=0; i<len && i<DEBUG_PRCT; i++) {
sprintf(string+strlen(string), "%02X ", data[i]);
if ((i%16) == 15) {
US_DEBUGP("%s\n", string);
strcpy(string, "wr: ");
}
}
if ((i%16)!=0)
US_DEBUGP("%s\n", string);
}
US_DEBUGP("SCM data %s transfer %d sg buffers %d\n",
(direction == SCSI_DATA_READ) ? "in" : "out",
len, use_sg);
#endif /* DEBUG_PRCT */
if (!use_sg)
result = usb_storage_raw_bulk(us, direction,
data, len, &act_len);
else {
sg = (struct scatterlist *)data;
for (i=0; i<use_sg && transferred<len; i++) {
unsigned char *buf;
unsigned int length;
buf = sg_address(sg[i]);
length = len-transferred;
if (length > sg[i].length)
length = sg[i].length;
result = usb_storage_raw_bulk(us, direction,
buf, length, &act_len);
if (result != USB_STOR_XFER_GOOD)
break;
transferred += length;
}
}
#if DEBUG_PRCT
if (direction == SCSI_DATA_READ && !use_sg) {
char string[64];
/* Debug-print the first N bytes of the read transfer */
strcpy(string, "rd: ");
for (i=0; i<len && i<act_len && i<DEBUG_PRCT; i++) {
sprintf(string+strlen(string), "%02X ", data[i]);
if ((i%16) == 15) {
US_DEBUGP("%s\n", string);
strcpy(string, "rd: ");
}
}
if ((i%16)!=0)
US_DEBUGP("%s\n", string);
}
#endif /* DEBUG_PRCT */
return result;
}
/* /*
* The routines below convert scatter-gather to single buffer. * The routines below convert scatter-gather to single buffer.
* Some drivers claim this is necessary. * Some drivers claim this is necessary.
......
#ifndef _USB_STORAGE_RAW_BULK_H_ #ifndef _USB_STORAGE_RAW_BULK_H_
#define _USB_STORAGE_RAW_BULK_H_ #define _USB_STORAGE_RAW_BULK_H_
/* usb bulk */
extern int usb_storage_send_control(
struct us_data *us, unsigned int pipe,
unsigned char request, unsigned char requesttype,
unsigned int value, unsigned int index,
unsigned char *xfer_data, unsigned int xfer_len);
extern int usb_storage_raw_bulk(
struct us_data *us, int direction,
unsigned char *data, unsigned int len, unsigned int *act_len);
extern int usb_storage_bulk_transport(
struct us_data *us, int direction,
unsigned char *data, unsigned int len, int use_sg);
/* scatter-gather */ /* scatter-gather */
extern unsigned char *us_copy_from_sgbuf( extern unsigned char *us_copy_from_sgbuf(
unsigned char *content, int buflen, unsigned char *content, int buflen,
......
...@@ -226,6 +226,7 @@ sddr09_send_command(struct us_data *us, ...@@ -226,6 +226,7 @@ sddr09_send_command(struct us_data *us,
unsigned int xfer_len) { unsigned int xfer_len) {
unsigned int pipe; unsigned int pipe;
unsigned char requesttype = (0x41 | direction); unsigned char requesttype = (0x41 | direction);
int rc;
// Get the receive or send control pipe number // Get the receive or send control pipe number
...@@ -234,8 +235,10 @@ sddr09_send_command(struct us_data *us, ...@@ -234,8 +235,10 @@ sddr09_send_command(struct us_data *us,
else else
pipe = us->send_ctrl_pipe; pipe = us->send_ctrl_pipe;
return usb_storage_send_control(us, pipe, request, requesttype, rc = usb_stor_ctrl_transfer(us, pipe, request, requesttype,
0, 0, xfer_data, xfer_len); 0, 0, xfer_data, xfer_len);
return (rc == USB_STOR_XFER_GOOD ? USB_STOR_TRANSPORT_GOOD :
USB_STOR_TRANSPORT_ERROR);
} }
static int static int
...@@ -276,7 +279,6 @@ sddr09_request_sense(struct us_data *us, unsigned char *sensebuf, int buflen) { ...@@ -276,7 +279,6 @@ sddr09_request_sense(struct us_data *us, unsigned char *sensebuf, int buflen) {
0x03, LUNBITS, 0, 0, buflen, 0, 0, 0, 0, 0, 0, 0 0x03, LUNBITS, 0, 0, buflen, 0, 0, 0, 0, 0, 0, 0
}; };
int result; int result;
unsigned int act_len;
result = sddr09_send_scsi_command(us, command, sizeof(command)); result = sddr09_send_scsi_command(us, command, sizeof(command));
if (result != USB_STOR_TRANSPORT_GOOD) { if (result != USB_STOR_TRANSPORT_GOOD) {
...@@ -284,7 +286,8 @@ sddr09_request_sense(struct us_data *us, unsigned char *sensebuf, int buflen) { ...@@ -284,7 +286,8 @@ sddr09_request_sense(struct us_data *us, unsigned char *sensebuf, int buflen) {
return result; return result;
} }
result = usb_storage_raw_bulk(us, SCSI_DATA_READ, sensebuf, buflen, &act_len); result = usb_stor_bulk_transfer_buf(us, us->recv_bulk_pipe,
sensebuf, buflen, NULL);
if (result != USB_STOR_XFER_GOOD) { if (result != USB_STOR_XFER_GOOD) {
US_DEBUGP("request sense bulk in failed\n"); US_DEBUGP("request sense bulk in failed\n");
return USB_STOR_TRANSPORT_ERROR; return USB_STOR_TRANSPORT_ERROR;
...@@ -343,11 +346,11 @@ sddr09_readX(struct us_data *us, int x, unsigned long fromaddress, ...@@ -343,11 +346,11 @@ sddr09_readX(struct us_data *us, int x, unsigned long fromaddress,
return result; return result;
} }
result = usb_storage_bulk_transport(us, SCSI_DATA_READ, result = usb_stor_bulk_transfer_sg(us, us->recv_bulk_pipe,
buf, bulklen, use_sg); buf, bulklen, use_sg, NULL);
if (result != USB_STOR_XFER_GOOD) { if (result != USB_STOR_XFER_GOOD) {
US_DEBUGP("Result for bulk_transport in sddr09_read2%d %d\n", US_DEBUGP("Result for bulk_transfer in sddr09_read2%d %d\n",
x, result); x, result);
return USB_STOR_TRANSPORT_ERROR; return USB_STOR_TRANSPORT_ERROR;
} }
...@@ -510,11 +513,11 @@ sddr09_writeX(struct us_data *us, ...@@ -510,11 +513,11 @@ sddr09_writeX(struct us_data *us,
return result; return result;
} }
result = usb_storage_bulk_transport(us, SCSI_DATA_WRITE, result = usb_stor_bulk_transfer_sg(us, us->send_bulk_pipe,
buf, bulklen, use_sg); buf, bulklen, use_sg, NULL);
if (result != USB_STOR_XFER_GOOD) { if (result != USB_STOR_XFER_GOOD) {
US_DEBUGP("Result for bulk_transport in sddr09_writeX %d\n", US_DEBUGP("Result for bulk_transfer in sddr09_writeX %d\n",
result); result);
return USB_STOR_TRANSPORT_ERROR; return USB_STOR_TRANSPORT_ERROR;
} }
...@@ -592,11 +595,11 @@ sddr09_read_sg_test_only(struct us_data *us) { ...@@ -592,11 +595,11 @@ sddr09_read_sg_test_only(struct us_data *us) {
if (!buf) if (!buf)
return USB_STOR_TRANSPORT_ERROR; return USB_STOR_TRANSPORT_ERROR;
result = usb_storage_bulk_transport(us, SCSI_DATA_READ, result = usb_stor_bulk_transfer_buf(us, us->recv_bulk_pipe,
buf, bulklen, 0); buf, bulklen, NULL);
kfree(buf); kfree(buf);
if (result != USB_STOR_XFER_GOOD) { if (result != USB_STOR_XFER_GOOD) {
US_DEBUGP("Result for bulk_transport in sddr09_read_sg %d\n", US_DEBUGP("Result for bulk_transfer in sddr09_read_sg %d\n",
result); result);
return USB_STOR_TRANSPORT_ERROR; return USB_STOR_TRANSPORT_ERROR;
} }
...@@ -631,8 +634,8 @@ sddr09_read_status(struct us_data *us, unsigned char *status) { ...@@ -631,8 +634,8 @@ sddr09_read_status(struct us_data *us, unsigned char *status) {
if (result != USB_STOR_TRANSPORT_GOOD) if (result != USB_STOR_TRANSPORT_GOOD)
return result; return result;
result = usb_storage_bulk_transport(us, SCSI_DATA_READ, result = usb_stor_bulk_transfer_buf(us, us->recv_bulk_pipe,
data, sizeof(data), 0); data, sizeof(data), NULL);
*status = data[0]; *status = data[0];
return (result == USB_STOR_XFER_GOOD ? return (result == USB_STOR_XFER_GOOD ?
USB_STOR_TRANSPORT_GOOD : USB_STOR_TRANSPORT_ERROR); USB_STOR_TRANSPORT_GOOD : USB_STOR_TRANSPORT_ERROR);
...@@ -954,7 +957,8 @@ sddr09_read_deviceID(struct us_data *us, unsigned char *deviceID) { ...@@ -954,7 +957,8 @@ sddr09_read_deviceID(struct us_data *us, unsigned char *deviceID) {
if (result != USB_STOR_TRANSPORT_GOOD) if (result != USB_STOR_TRANSPORT_GOOD)
return result; return result;
result = usb_storage_bulk_transport(us, SCSI_DATA_READ, content, 64, 0); result = usb_stor_bulk_transfer_buf(us, us->recv_bulk_pipe,
content, 64, NULL);
for (i = 0; i < 4; i++) for (i = 0; i < 4; i++)
deviceID[i] = content[i]; deviceID[i] = content[i];
...@@ -1545,17 +1549,16 @@ int sddr09_transport(Scsi_Cmnd *srb, struct us_data *us) ...@@ -1545,17 +1549,16 @@ int sddr09_transport(Scsi_Cmnd *srb, struct us_data *us)
if (srb->sc_data_direction == SCSI_DATA_WRITE || if (srb->sc_data_direction == SCSI_DATA_WRITE ||
srb->sc_data_direction == SCSI_DATA_READ) { srb->sc_data_direction == SCSI_DATA_READ) {
unsigned int pipe = (srb->sc_data_direction == SCSI_DATA_WRITE)
? us->send_bulk_pipe : us->recv_bulk_pipe;
US_DEBUGP("SDDR09: %s %d bytes\n", US_DEBUGP("SDDR09: %s %d bytes\n",
(srb->sc_data_direction == SCSI_DATA_WRITE) ? (srb->sc_data_direction == SCSI_DATA_WRITE) ?
"sending" : "receiving", "sending" : "receiving",
srb->request_bufflen); srb->request_bufflen);
result = usb_storage_bulk_transport(us, result = usb_stor_bulk_transfer_srb(us, pipe, srb,
srb->sc_data_direction, srb->request_bufflen);
srb->request_buffer,
srb->request_bufflen,
srb->use_sg);
return (result == USB_STOR_XFER_GOOD ? return (result == USB_STOR_XFER_GOOD ?
USB_STOR_TRANSPORT_GOOD : USB_STOR_TRANSPORT_ERROR); USB_STOR_TRANSPORT_GOOD : USB_STOR_TRANSPORT_ERROR);
......
...@@ -75,10 +75,13 @@ static int ...@@ -75,10 +75,13 @@ static int
sddr55_bulk_transport(struct us_data *us, int direction, sddr55_bulk_transport(struct us_data *us, int direction,
unsigned char *data, unsigned int len) { unsigned char *data, unsigned int len) {
struct sddr55_card_info *info = (struct sddr55_card_info *)us->extra; struct sddr55_card_info *info = (struct sddr55_card_info *)us->extra;
unsigned int pipe = (direction == SCSI_DATA_READ) ?
us->recv_bulk_pipe : us->send_bulk_pipe;
if (len) if (!len)
info->last_access = jiffies; return USB_STOR_XFER_GOOD;
return usb_storage_bulk_transport(us, direction, data, len, 0); info->last_access = jiffies;
return usb_stor_bulk_transfer_buf(us, pipe, data, len, NULL);
} }
/* check if card inserted, if there is, update read_only status /* check if card inserted, if there is, update read_only status
......
...@@ -63,7 +63,7 @@ int usbat_read(struct us_data *us, ...@@ -63,7 +63,7 @@ int usbat_read(struct us_data *us,
int result; int result;
result = usb_storage_send_control(us, result = usb_stor_ctrl_transfer(us,
us->recv_ctrl_pipe, us->recv_ctrl_pipe,
access, access,
0xC0, 0xC0,
...@@ -82,7 +82,7 @@ int usbat_write(struct us_data *us, ...@@ -82,7 +82,7 @@ int usbat_write(struct us_data *us,
int result; int result;
result = usb_storage_send_control(us, result = usb_stor_ctrl_transfer(us,
us->send_ctrl_pipe, us->send_ctrl_pipe,
access|0x01, access|0x01,
0x40, 0x40,
...@@ -108,7 +108,7 @@ int usbat_set_shuttle_features(struct us_data *us, ...@@ -108,7 +108,7 @@ int usbat_set_shuttle_features(struct us_data *us,
test_pattern, mask_byte, subcountL, subcountH test_pattern, mask_byte, subcountL, subcountH
}; };
result = usb_storage_send_control(us, result = usb_stor_ctrl_transfer(us,
us->send_ctrl_pipe, us->send_ctrl_pipe,
0x80, 0x80,
0x40, 0x40,
...@@ -133,7 +133,10 @@ int usbat_read_block(struct us_data *us, ...@@ -133,7 +133,10 @@ int usbat_read_block(struct us_data *us,
LSB_of(len), MSB_of(len) LSB_of(len), MSB_of(len)
}; };
result = usb_storage_send_control(us, if (!len)
return USB_STOR_TRANSPORT_GOOD;
result = usb_stor_ctrl_transfer(us,
us->send_ctrl_pipe, us->send_ctrl_pipe,
0x80, 0x80,
0x40, 0x40,
...@@ -142,10 +145,11 @@ int usbat_read_block(struct us_data *us, ...@@ -142,10 +145,11 @@ int usbat_read_block(struct us_data *us,
command, command,
8); 8);
if (result != USB_STOR_TRANSPORT_GOOD) if (result != USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
result = usb_storage_bulk_transport(us, SCSI_DATA_READ, content, len, use_sg); result = usb_stor_bulk_transfer_sg(us, us->recv_bulk_pipe,
content, len, use_sg, NULL);
return (result == USB_STOR_XFER_GOOD ? return (result == USB_STOR_XFER_GOOD ?
USB_STOR_TRANSPORT_GOOD : USB_STOR_TRANSPORT_ERROR); USB_STOR_TRANSPORT_GOOD : USB_STOR_TRANSPORT_ERROR);
...@@ -172,8 +176,8 @@ int usbat_wait_not_busy(struct us_data *us, int minutes) { ...@@ -172,8 +176,8 @@ int usbat_wait_not_busy(struct us_data *us, int minutes) {
result = usbat_read(us, USBAT_ATA, 0x17, &status); result = usbat_read(us, USBAT_ATA, 0x17, &status);
if (result!=USB_STOR_TRANSPORT_GOOD) if (result!=USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
if (status&0x01) { // check condition if (status&0x01) { // check condition
result = usbat_read(us, USBAT_ATA, 0x10, &status); result = usbat_read(us, USBAT_ATA, 0x10, &status);
return USB_STOR_TRANSPORT_FAILED; return USB_STOR_TRANSPORT_FAILED;
...@@ -215,7 +219,10 @@ int usbat_write_block(struct us_data *us, ...@@ -215,7 +219,10 @@ int usbat_write_block(struct us_data *us,
LSB_of(len), MSB_of(len) LSB_of(len), MSB_of(len)
}; };
result = usb_storage_send_control(us, if (!len)
return USB_STOR_TRANSPORT_GOOD;
result = usb_stor_ctrl_transfer(us,
us->send_ctrl_pipe, us->send_ctrl_pipe,
0x80, 0x80,
0x40, 0x40,
...@@ -224,10 +231,11 @@ int usbat_write_block(struct us_data *us, ...@@ -224,10 +231,11 @@ int usbat_write_block(struct us_data *us,
command, command,
8); 8);
if (result != USB_STOR_TRANSPORT_GOOD) if (result != USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
result = usb_storage_bulk_transport(us, SCSI_DATA_WRITE, content, len, use_sg); result = usb_stor_bulk_transfer_sg(us, us->send_bulk_pipe,
content, len, use_sg, NULL);
if (result != USB_STOR_XFER_GOOD) if (result != USB_STOR_XFER_GOOD)
return USB_STOR_TRANSPORT_ERROR; return USB_STOR_TRANSPORT_ERROR;
...@@ -251,6 +259,8 @@ int usbat_rw_block_test(struct us_data *us, ...@@ -251,6 +259,8 @@ int usbat_rw_block_test(struct us_data *us,
int minutes) { int minutes) {
int result; int result;
unsigned int pipe = (direction == SCSI_DATA_READ) ?
us->recv_bulk_pipe : us->send_bulk_pipe;
// Not really sure the 0x07, 0x17, 0xfc, 0xe7 is necessary here, // Not really sure the 0x07, 0x17, 0xfc, 0xe7 is necessary here,
// but that's what came out of the trace every single time. // but that's what came out of the trace every single time.
...@@ -286,7 +296,7 @@ int usbat_rw_block_test(struct us_data *us, ...@@ -286,7 +296,7 @@ int usbat_rw_block_test(struct us_data *us,
* that, we just return a failure. * that, we just return a failure.
*/ */
result = usb_storage_send_control(us, result = usb_stor_ctrl_transfer(us,
us->send_ctrl_pipe, us->send_ctrl_pipe,
0x80, 0x80,
0x40, 0x40,
...@@ -295,16 +305,16 @@ int usbat_rw_block_test(struct us_data *us, ...@@ -295,16 +305,16 @@ int usbat_rw_block_test(struct us_data *us,
(i==0 ? command : command+8), (i==0 ? command : command+8),
(i==0 ? 16 : 8)); (i==0 ? 16 : 8));
if (result != USB_STOR_TRANSPORT_GOOD) if (result != USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
if (i==0) { if (i==0) {
result = usb_storage_bulk_transport(us, result = usb_stor_bulk_transfer_buf(us,
SCSI_DATA_WRITE, us->send_bulk_pipe,
data, num_registers*2, 0); data, num_registers*2, NULL);
if (result!=USB_STOR_XFER_GOOD) if (result != USB_STOR_XFER_GOOD)
return USB_STOR_TRANSPORT_ERROR; return USB_STOR_TRANSPORT_ERROR;
} }
...@@ -314,8 +324,8 @@ int usbat_rw_block_test(struct us_data *us, ...@@ -314,8 +324,8 @@ int usbat_rw_block_test(struct us_data *us,
// direction == SCSI_DATA_WRITE ? "out" : "in", // direction == SCSI_DATA_WRITE ? "out" : "in",
// len, use_sg); // len, use_sg);
result = usb_storage_bulk_transport(us, result = usb_stor_bulk_transfer_sg(us,
direction, content, len, use_sg); pipe, content, len, use_sg, NULL);
/* /*
* If we get a stall on the bulk download, we'll retry * If we get a stall on the bulk download, we'll retry
...@@ -358,8 +368,8 @@ int usbat_rw_block_test(struct us_data *us, ...@@ -358,8 +368,8 @@ int usbat_rw_block_test(struct us_data *us,
direction==SCSI_DATA_WRITE ? 0x17 : 0x0E, direction==SCSI_DATA_WRITE ? 0x17 : 0x0E,
&status); &status);
if (result!=USB_STOR_TRANSPORT_GOOD) if (result!=USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
if (status&0x01) // check condition if (status&0x01) // check condition
return USB_STOR_TRANSPORT_FAILED; return USB_STOR_TRANSPORT_FAILED;
if (status&0x20) // device fault if (status&0x20) // device fault
...@@ -405,7 +415,7 @@ int usbat_multiple_write(struct us_data *us, ...@@ -405,7 +415,7 @@ int usbat_multiple_write(struct us_data *us,
data[1+(i<<1)] = data_out[i]; data[1+(i<<1)] = data_out[i];
} }
result = usb_storage_send_control(us, result = usb_stor_ctrl_transfer(us,
us->send_ctrl_pipe, us->send_ctrl_pipe,
0x80, 0x80,
0x40, 0x40,
...@@ -414,11 +424,11 @@ int usbat_multiple_write(struct us_data *us, ...@@ -414,11 +424,11 @@ int usbat_multiple_write(struct us_data *us,
command, command,
8); 8);
if (result != USB_STOR_TRANSPORT_GOOD) if (result != USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
result = usb_storage_bulk_transport(us, result = usb_stor_bulk_transfer_buf(us,
SCSI_DATA_WRITE, data, num_registers*2, 0); us->send_bulk_pipe, data, num_registers*2, NULL);
if (result != USB_STOR_XFER_GOOD) if (result != USB_STOR_XFER_GOOD)
return USB_STOR_TRANSPORT_ERROR; return USB_STOR_TRANSPORT_ERROR;
...@@ -431,7 +441,7 @@ int usbat_read_user_io(struct us_data *us, ...@@ -431,7 +441,7 @@ int usbat_read_user_io(struct us_data *us,
int result; int result;
result = usb_storage_send_control(us, result = usb_stor_ctrl_transfer(us,
us->recv_ctrl_pipe, us->recv_ctrl_pipe,
0x82, 0x82,
0xC0, 0xC0,
...@@ -449,7 +459,7 @@ int usbat_write_user_io(struct us_data *us, ...@@ -449,7 +459,7 @@ int usbat_write_user_io(struct us_data *us,
int result; int result;
result = usb_storage_send_control(us, result = usb_stor_ctrl_transfer(us,
us->send_ctrl_pipe, us->send_ctrl_pipe,
0x82, 0x82,
0x40, 0x40,
...@@ -582,7 +592,6 @@ int usbat_handle_read10(struct us_data *us, ...@@ -582,7 +592,6 @@ int usbat_handle_read10(struct us_data *us,
static int hp_8200e_select_and_test_registers(struct us_data *us) { static int hp_8200e_select_and_test_registers(struct us_data *us) {
int result;
int selector; int selector;
unsigned char status; unsigned char status;
...@@ -590,44 +599,44 @@ static int hp_8200e_select_and_test_registers(struct us_data *us) { ...@@ -590,44 +599,44 @@ static int hp_8200e_select_and_test_registers(struct us_data *us) {
for (selector = 0xA0; selector <= 0xB0; selector += 0x10) { for (selector = 0xA0; selector <= 0xB0; selector += 0x10) {
if ( (result = usbat_write(us, USBAT_ATA, 0x16, selector)) != if (usbat_write(us, USBAT_ATA, 0x16, selector) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
if ( (result = usbat_read(us, USBAT_ATA, 0x17, &status)) != if (usbat_read(us, USBAT_ATA, 0x17, &status) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
if ( (result = usbat_read(us, USBAT_ATA, 0x16, &status)) != if (usbat_read(us, USBAT_ATA, 0x16, &status) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
if ( (result = usbat_read(us, USBAT_ATA, 0x14, &status)) != if (usbat_read(us, USBAT_ATA, 0x14, &status) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
if ( (result = usbat_read(us, USBAT_ATA, 0x15, &status)) != if (usbat_read(us, USBAT_ATA, 0x15, &status) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
if ( (result = usbat_write(us, USBAT_ATA, 0x14, 0x55)) != if (usbat_write(us, USBAT_ATA, 0x14, 0x55) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
if ( (result = usbat_write(us, USBAT_ATA, 0x15, 0xAA)) != if (usbat_write(us, USBAT_ATA, 0x15, 0xAA) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
if ( (result = usbat_read(us, USBAT_ATA, 0x14, &status)) != if (usbat_read(us, USBAT_ATA, 0x14, &status) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
if ( (result = usbat_read(us, USBAT_ATA, 0x15, &status)) != if (usbat_read(us, USBAT_ATA, 0x15, &status) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
} }
return result; return USB_STOR_TRANSPORT_GOOD;
} }
int init_8200e(struct us_data *us) { int init_8200e(struct us_data *us) {
...@@ -637,44 +646,44 @@ int init_8200e(struct us_data *us) { ...@@ -637,44 +646,44 @@ int init_8200e(struct us_data *us) {
// Enable peripheral control signals // Enable peripheral control signals
if ( (result = usbat_write_user_io(us, if (usbat_write_user_io(us,
USBAT_UIO_OE1 | USBAT_UIO_OE0, USBAT_UIO_OE1 | USBAT_UIO_OE0,
USBAT_UIO_EPAD | USBAT_UIO_1)) != USB_STOR_TRANSPORT_GOOD) USBAT_UIO_EPAD | USBAT_UIO_1) != USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
US_DEBUGP("INIT 1\n"); US_DEBUGP("INIT 1\n");
wait_ms(2000); wait_ms(2000);
if ( (result = usbat_read_user_io(us, &status)) != if (usbat_read_user_io(us, &status) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
US_DEBUGP("INIT 2\n"); US_DEBUGP("INIT 2\n");
if ( (result = usbat_read_user_io(us, &status)) != if (usbat_read_user_io(us, &status) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
US_DEBUGP("INIT 3\n"); US_DEBUGP("INIT 3\n");
// Reset peripheral, enable periph control signals // Reset peripheral, enable periph control signals
// (bring reset signal up) // (bring reset signal up)
if ( (result = usbat_write_user_io(us, if (usbat_write_user_io(us,
USBAT_UIO_DRVRST | USBAT_UIO_OE1 | USBAT_UIO_OE0, USBAT_UIO_DRVRST | USBAT_UIO_OE1 | USBAT_UIO_OE0,
USBAT_UIO_EPAD | USBAT_UIO_1)) != USB_STOR_TRANSPORT_GOOD) USBAT_UIO_EPAD | USBAT_UIO_1) != USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
US_DEBUGP("INIT 4\n"); US_DEBUGP("INIT 4\n");
// Enable periph control signals // Enable periph control signals
// (bring reset signal down) // (bring reset signal down)
if ( (result = usbat_write_user_io(us, if (usbat_write_user_io(us,
USBAT_UIO_OE1 | USBAT_UIO_OE0, USBAT_UIO_OE1 | USBAT_UIO_OE0,
USBAT_UIO_EPAD | USBAT_UIO_1)) != USB_STOR_TRANSPORT_GOOD) USBAT_UIO_EPAD | USBAT_UIO_1) != USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
US_DEBUGP("INIT 5\n"); US_DEBUGP("INIT 5\n");
...@@ -682,23 +691,23 @@ int init_8200e(struct us_data *us) { ...@@ -682,23 +691,23 @@ int init_8200e(struct us_data *us) {
// Write 0x80 to ISA port 0x3F // Write 0x80 to ISA port 0x3F
if ( (result = usbat_write(us, USBAT_ISA, 0x3F, 0x80)) != if (usbat_write(us, USBAT_ISA, 0x3F, 0x80) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
US_DEBUGP("INIT 6\n"); US_DEBUGP("INIT 6\n");
// Read ISA port 0x27 // Read ISA port 0x27
if ( (result = usbat_read(us, USBAT_ISA, 0x27, &status)) != if (usbat_read(us, USBAT_ISA, 0x27, &status) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
US_DEBUGP("INIT 7\n"); US_DEBUGP("INIT 7\n");
if ( (result = usbat_read_user_io(us, &status)) != if (usbat_read_user_io(us, &status) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
US_DEBUGP("INIT 8\n"); US_DEBUGP("INIT 8\n");
...@@ -708,32 +717,32 @@ int init_8200e(struct us_data *us) { ...@@ -708,32 +717,32 @@ int init_8200e(struct us_data *us) {
US_DEBUGP("INIT 9\n"); US_DEBUGP("INIT 9\n");
if ( (result = usbat_read_user_io(us, &status)) != if (usbat_read_user_io(us, &status) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
US_DEBUGP("INIT 10\n"); US_DEBUGP("INIT 10\n");
// Enable periph control signals and card detect // Enable periph control signals and card detect
if ( (result = usbat_write_user_io(us, if (usbat_write_user_io(us,
USBAT_UIO_ACKD |USBAT_UIO_OE1 | USBAT_UIO_OE0, USBAT_UIO_ACKD |USBAT_UIO_OE1 | USBAT_UIO_OE0,
USBAT_UIO_EPAD | USBAT_UIO_1)) != USB_STOR_TRANSPORT_GOOD) USBAT_UIO_EPAD | USBAT_UIO_1) != USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
US_DEBUGP("INIT 11\n"); US_DEBUGP("INIT 11\n");
if ( (result = usbat_read_user_io(us, &status)) != if (usbat_read_user_io(us, &status) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
US_DEBUGP("INIT 12\n"); US_DEBUGP("INIT 12\n");
wait_ms(1400); wait_ms(1400);
if ( (result = usbat_read_user_io(us, &status)) != if (usbat_read_user_io(us, &status) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
US_DEBUGP("INIT 13\n"); US_DEBUGP("INIT 13\n");
...@@ -743,14 +752,14 @@ int init_8200e(struct us_data *us) { ...@@ -743,14 +752,14 @@ int init_8200e(struct us_data *us) {
US_DEBUGP("INIT 14\n"); US_DEBUGP("INIT 14\n");
if ( (result = usbat_set_shuttle_features(us, if (usbat_set_shuttle_features(us,
0x83, 0x00, 0x88, 0x08, 0x15, 0x14)) != 0x83, 0x00, 0x88, 0x08, 0x15, 0x14) !=
USB_STOR_TRANSPORT_GOOD) USB_STOR_XFER_GOOD)
return result; return USB_STOR_TRANSPORT_ERROR;
US_DEBUGP("INIT 15\n"); US_DEBUGP("INIT 15\n");
return result; return USB_STOR_TRANSPORT_ERROR;
} }
/* /*
...@@ -857,17 +866,16 @@ int hp8200e_transport(Scsi_Cmnd *srb, struct us_data *us) ...@@ -857,17 +866,16 @@ int hp8200e_transport(Scsi_Cmnd *srb, struct us_data *us)
// How many bytes to read in? Check cylL register // How many bytes to read in? Check cylL register
if ( (result = usbat_read(us, USBAT_ATA, 0x14, &status)) != if (usbat_read(us, USBAT_ATA, 0x14, &status) !=
USB_STOR_TRANSPORT_GOOD) { USB_STOR_XFER_GOOD) {
return result; return USB_STOR_TRANSPORT_ERROR;
} }
if (len>0xFF) { // need to read cylH also if (len > 0xFF) { // need to read cylH also
len = status; len = status;
if ( (result = usbat_read(us, USBAT_ATA, 0x15, if (usbat_read(us, USBAT_ATA, 0x15, &status) !=
&status)) != USB_STOR_XFER_GOOD) {
USB_STOR_TRANSPORT_GOOD) { return USB_STOR_TRANSPORT_ERROR;
return result;
} }
len += ((unsigned int)status)<<8; len += ((unsigned int)status)<<8;
} }
......
...@@ -579,7 +579,7 @@ int usb_stor_ctrl_transfer(struct us_data *us, unsigned int pipe, ...@@ -579,7 +579,7 @@ int usb_stor_ctrl_transfer(struct us_data *us, unsigned int pipe,
/* was the entire command transferred? */ /* was the entire command transferred? */
if (result < size) { if (result < size) {
US_DEBUGP("-- transfer was short\n"); US_DEBUGP("-- transferred only %d bytes\n", result);
return USB_STOR_XFER_SHORT; return USB_STOR_XFER_SHORT;
} }
...@@ -614,7 +614,8 @@ int usb_stor_bulk_transfer_buf(struct us_data *us, unsigned int pipe, ...@@ -614,7 +614,8 @@ int usb_stor_bulk_transfer_buf(struct us_data *us, unsigned int pipe,
/* if we stall, we need to clear it before we go on */ /* if we stall, we need to clear it before we go on */
if (result == -EPIPE) { if (result == -EPIPE) {
US_DEBUGP("clearing endpoint halt for pipe 0x%x\n", pipe); US_DEBUGP("clearing endpoint halt for pipe 0x%x,"
" stalled at %d bytes\n", pipe, partial);
if (usb_stor_clear_halt(us, pipe) < 0) if (usb_stor_clear_halt(us, pipe) < 0)
return USB_STOR_XFER_ERROR; return USB_STOR_XFER_ERROR;
return USB_STOR_XFER_STALLED; return USB_STOR_XFER_STALLED;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment