aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/usb/storage/initializers.h4
-rw-r--r--drivers/usb/storage/sddr09.c72
-rw-r--r--drivers/usb/storage/sddr09.h15
-rw-r--r--drivers/usb/storage/unusual_devs.h14
-rw-r--r--drivers/usb/storage/usb.c22
5 files changed, 64 insertions, 63 deletions
diff --git a/drivers/usb/storage/initializers.h b/drivers/usb/storage/initializers.h
index 7372386f33d5..4c1b2bd2e2e4 100644
--- a/drivers/usb/storage/initializers.h
+++ b/drivers/usb/storage/initializers.h
@@ -45,10 +45,6 @@
45 * mode */ 45 * mode */
46int usb_stor_euscsi_init(struct us_data *us); 46int usb_stor_euscsi_init(struct us_data *us);
47 47
48#ifdef CONFIG_USB_STORAGE_SDDR09
49int sddr09_init(struct us_data *us);
50#endif
51
52/* This function is required to activate all four slots on the UCR-61S2B 48/* This function is required to activate all four slots on the UCR-61S2B
53 * flash reader */ 49 * flash reader */
54int usb_stor_ucr61s2b_init(struct us_data *us); 50int usb_stor_ucr61s2b_init(struct us_data *us);
diff --git a/drivers/usb/storage/sddr09.c b/drivers/usb/storage/sddr09.c
index 0a6efae452fb..6c379b6b43d1 100644
--- a/drivers/usb/storage/sddr09.c
+++ b/drivers/usb/storage/sddr09.c
@@ -214,6 +214,20 @@ static void nand_store_ecc(unsigned char *data, unsigned char *ecc) {
214 * The actual driver starts here. 214 * The actual driver starts here.
215 */ 215 */
216 216
217struct sddr09_card_info {
218 unsigned long capacity; /* Size of card in bytes */
219 int pagesize; /* Size of page in bytes */
220 int pageshift; /* log2 of pagesize */
221 int blocksize; /* Size of block in pages */
222 int blockshift; /* log2 of blocksize */
223 int blockmask; /* 2^blockshift - 1 */
224 int *lba_to_pba; /* logical to physical map */
225 int *pba_to_lba; /* physical to logical map */
226 int lbact; /* number of available pages */
227 int flags;
228#define SDDR09_WP 1 /* write protected */
229};
230
217/* 231/*
218 * On my 16MB card, control blocks have size 64 (16 real control bytes, 232 * On my 16MB card, control blocks have size 64 (16 real control bytes,
219 * and 48 junk bytes). In reality of course the card uses 16 control bytes, 233 * and 48 junk bytes). In reality of course the card uses 16 control bytes,
@@ -1342,27 +1356,51 @@ sddr09_card_info_destructor(void *extra) {
1342 kfree(info->pba_to_lba); 1356 kfree(info->pba_to_lba);
1343} 1357}
1344 1358
1345static void 1359static int
1346sddr09_init_card_info(struct us_data *us) { 1360sddr09_common_init(struct us_data *us) {
1347 if (!us->extra) { 1361 int result;
1348 us->extra = kmalloc(sizeof(struct sddr09_card_info), GFP_NOIO); 1362
1349 if (us->extra) { 1363 /* set the configuration -- STALL is an acceptable response here */
1350 memset(us->extra, 0, sizeof(struct sddr09_card_info)); 1364 if (us->pusb_dev->actconfig->desc.bConfigurationValue != 1) {
1351 us->extra_destructor = sddr09_card_info_destructor; 1365 US_DEBUGP("active config #%d != 1 ??\n", us->pusb_dev
1352 } 1366 ->actconfig->desc.bConfigurationValue);
1367 return -EINVAL;
1368 }
1369
1370 result = usb_reset_configuration(us->pusb_dev);
1371 US_DEBUGP("Result of usb_reset_configuration is %d\n", result);
1372 if (result == -EPIPE) {
1373 US_DEBUGP("-- stall on control interface\n");
1374 } else if (result != 0) {
1375 /* it's not a stall, but another error -- time to bail */
1376 US_DEBUGP("-- Unknown error. Rejecting device\n");
1377 return -EINVAL;
1353 } 1378 }
1379
1380 us->extra = kzalloc(sizeof(struct sddr09_card_info), GFP_NOIO);
1381 if (!us->extra)
1382 return -ENOMEM;
1383 us->extra_destructor = sddr09_card_info_destructor;
1384
1385 nand_init_ecc();
1386 return 0;
1354} 1387}
1355 1388
1389
1356/* 1390/*
1357 * This is needed at a very early stage. If this is not listed in the 1391 * This is needed at a very early stage. If this is not listed in the
1358 * unusual devices list but called from here then LUN 0 of the combo reader 1392 * unusual devices list but called from here then LUN 0 of the combo reader
1359 * is not recognized. But I do not know what precisely these calls do. 1393 * is not recognized. But I do not know what precisely these calls do.
1360 */ 1394 */
1361int 1395int
1362sddr09_init(struct us_data *us) { 1396usb_stor_sddr09_dpcm_init(struct us_data *us) {
1363 int result; 1397 int result;
1364 unsigned char *data = us->iobuf; 1398 unsigned char *data = us->iobuf;
1365 1399
1400 result = sddr09_common_init(us);
1401 if (result)
1402 return result;
1403
1366 result = sddr09_send_command(us, 0x01, USB_DIR_IN, data, 2); 1404 result = sddr09_send_command(us, 0x01, USB_DIR_IN, data, 2);
1367 if (result != USB_STOR_TRANSPORT_GOOD) { 1405 if (result != USB_STOR_TRANSPORT_GOOD) {
1368 US_DEBUGP("sddr09_init: send_command fails\n"); 1406 US_DEBUGP("sddr09_init: send_command fails\n");
@@ -1398,7 +1436,7 @@ sddr09_init(struct us_data *us) {
1398 1436
1399 // test unit ready 1437 // test unit ready
1400 1438
1401 return USB_STOR_TRANSPORT_GOOD; /* not result */ 1439 return 0; /* not result */
1402} 1440}
1403 1441
1404/* 1442/*
@@ -1427,13 +1465,6 @@ int sddr09_transport(struct scsi_cmnd *srb, struct us_data *us)
1427 }; 1465 };
1428 1466
1429 info = (struct sddr09_card_info *)us->extra; 1467 info = (struct sddr09_card_info *)us->extra;
1430 if (!info) {
1431 nand_init_ecc();
1432 sddr09_init_card_info(us);
1433 info = (struct sddr09_card_info *)us->extra;
1434 if (!info)
1435 return USB_STOR_TRANSPORT_ERROR;
1436 }
1437 1468
1438 if (srb->cmnd[0] == REQUEST_SENSE && havefakesense) { 1469 if (srb->cmnd[0] == REQUEST_SENSE && havefakesense) {
1439 /* for a faked command, we have to follow with a faked sense */ 1470 /* for a faked command, we have to follow with a faked sense */
@@ -1606,3 +1637,10 @@ int sddr09_transport(struct scsi_cmnd *srb, struct us_data *us)
1606 return USB_STOR_TRANSPORT_GOOD; 1637 return USB_STOR_TRANSPORT_GOOD;
1607} 1638}
1608 1639
1640/*
1641 * Initialization routine for the sddr09 subdriver
1642 */
1643int
1644usb_stor_sddr09_init(struct us_data *us) {
1645 return sddr09_common_init(us);
1646}
diff --git a/drivers/usb/storage/sddr09.h b/drivers/usb/storage/sddr09.h
index c9d78d6188b1..c03089a9ec38 100644
--- a/drivers/usb/storage/sddr09.h
+++ b/drivers/usb/storage/sddr09.h
@@ -31,18 +31,7 @@
31 31
32extern int sddr09_transport(struct scsi_cmnd *srb, struct us_data *us); 32extern int sddr09_transport(struct scsi_cmnd *srb, struct us_data *us);
33 33
34struct sddr09_card_info { 34extern int usb_stor_sddr09_dpcm_init(struct us_data *us);
35 unsigned long capacity; /* Size of card in bytes */ 35extern int usb_stor_sddr09_init(struct us_data *us);
36 int pagesize; /* Size of page in bytes */
37 int pageshift; /* log2 of pagesize */
38 int blocksize; /* Size of block in pages */
39 int blockshift; /* log2 of blocksize */
40 int blockmask; /* 2^blockshift - 1 */
41 int *lba_to_pba; /* logical to physical map */
42 int *pba_to_lba; /* physical to logical map */
43 int lbact; /* number of available pages */
44 int flags;
45#define SDDR09_WP 1 /* write protected */
46};
47 36
48#endif 37#endif
diff --git a/drivers/usb/storage/unusual_devs.h b/drivers/usb/storage/unusual_devs.h
index 100f53c2097e..be3c06d17533 100644
--- a/drivers/usb/storage/unusual_devs.h
+++ b/drivers/usb/storage/unusual_devs.h
@@ -284,14 +284,14 @@ UNUSUAL_DEV( 0x04e6, 0x0002, 0x0100, 0x0100,
284UNUSUAL_DEV( 0x04e6, 0x0003, 0x0000, 0x9999, 284UNUSUAL_DEV( 0x04e6, 0x0003, 0x0000, 0x9999,
285 "Sandisk", 285 "Sandisk",
286 "ImageMate SDDR09", 286 "ImageMate SDDR09",
287 US_SC_SCSI, US_PR_EUSB_SDDR09, NULL, 287 US_SC_SCSI, US_PR_EUSB_SDDR09, usb_stor_sddr09_init,
288 US_FL_SINGLE_LUN ), 288 0),
289 289
290/* This entry is from Andries.Brouwer@cwi.nl */ 290/* This entry is from Andries.Brouwer@cwi.nl */
291UNUSUAL_DEV( 0x04e6, 0x0005, 0x0100, 0x0208, 291UNUSUAL_DEV( 0x04e6, 0x0005, 0x0100, 0x0208,
292 "SCM Microsystems", 292 "SCM Microsystems",
293 "eUSB SmartMedia / CompactFlash Adapter", 293 "eUSB SmartMedia / CompactFlash Adapter",
294 US_SC_SCSI, US_PR_DPCM_USB, sddr09_init, 294 US_SC_SCSI, US_PR_DPCM_USB, usb_stor_sddr09_dpcm_init,
295 0), 295 0),
296#endif 296#endif
297 297
@@ -681,8 +681,8 @@ UNUSUAL_DEV( 0x0644, 0x0000, 0x0100, 0x0100,
681UNUSUAL_DEV( 0x066b, 0x0105, 0x0100, 0x0100, 681UNUSUAL_DEV( 0x066b, 0x0105, 0x0100, 0x0100,
682 "Olympus", 682 "Olympus",
683 "Camedia MAUSB-2", 683 "Camedia MAUSB-2",
684 US_SC_SCSI, US_PR_EUSB_SDDR09, NULL, 684 US_SC_SCSI, US_PR_EUSB_SDDR09, usb_stor_sddr09_init,
685 US_FL_SINGLE_LUN ), 685 0),
686#endif 686#endif
687 687
688/* Reported by Darsen Lu <darsen@micro.ee.nthu.edu.tw> */ 688/* Reported by Darsen Lu <darsen@micro.ee.nthu.edu.tw> */
@@ -747,8 +747,8 @@ UNUSUAL_DEV( 0x0781, 0x0100, 0x0100, 0x0100,
747UNUSUAL_DEV( 0x0781, 0x0200, 0x0000, 0x9999, 747UNUSUAL_DEV( 0x0781, 0x0200, 0x0000, 0x9999,
748 "Sandisk", 748 "Sandisk",
749 "ImageMate SDDR-09", 749 "ImageMate SDDR-09",
750 US_SC_SCSI, US_PR_EUSB_SDDR09, NULL, 750 US_SC_SCSI, US_PR_EUSB_SDDR09, usb_stor_sddr09_init,
751 US_FL_SINGLE_LUN ), 751 0),
752#endif 752#endif
753 753
754#ifdef CONFIG_USB_STORAGE_FREECOM 754#ifdef CONFIG_USB_STORAGE_FREECOM
diff --git a/drivers/usb/storage/usb.c b/drivers/usb/storage/usb.c
index ca02ae97be86..85c8c17b3c0c 100644
--- a/drivers/usb/storage/usb.c
+++ b/drivers/usb/storage/usb.c
@@ -919,28 +919,6 @@ static int storage_probe(struct usb_interface *intf,
919 */ 919 */
920 get_device_info(us, id); 920 get_device_info(us, id);
921 921
922#ifdef CONFIG_USB_STORAGE_SDDR09
923 if (us->protocol == US_PR_EUSB_SDDR09 ||
924 us->protocol == US_PR_DPCM_USB) {
925 /* set the configuration -- STALL is an acceptable response here */
926 if (us->pusb_dev->actconfig->desc.bConfigurationValue != 1) {
927 US_DEBUGP("active config #%d != 1 ??\n", us->pusb_dev
928 ->actconfig->desc.bConfigurationValue);
929 goto BadDevice;
930 }
931 result = usb_reset_configuration(us->pusb_dev);
932
933 US_DEBUGP("Result of usb_reset_configuration is %d\n", result);
934 if (result == -EPIPE) {
935 US_DEBUGP("-- stall on control interface\n");
936 } else if (result != 0) {
937 /* it's not a stall, but another error -- time to bail */
938 US_DEBUGP("-- Unknown error. Rejecting device\n");
939 goto BadDevice;
940 }
941 }
942#endif
943
944 /* Get the transport, protocol, and pipe settings */ 922 /* Get the transport, protocol, and pipe settings */
945 result = get_transport(us); 923 result = get_transport(us);
946 if (result) 924 if (result)