1 /* Driver for USB Mass Storage compliant devices
 
   4  * Current development and maintenance by:
 
   5  *   (c) 2000-2002 Matthew Dharm (mdharm-usb@one-eyed-alien.net)
 
   8  *   (c) 2000 Adam J. Richter (adam@yggdrasil.com), Yggdrasil Computing, Inc.
 
  10  * Please see http://www.one-eyed-alien.net/~mdharm/linux-usb for more
 
  11  * information about this driver.
 
  13  * This program is free software; you can redistribute it and/or modify it
 
  14  * under the terms of the GNU General Public License as published by the
 
  15  * Free Software Foundation; either version 2, or (at your option) any
 
  18  * This program is distributed in the hope that it will be useful, but
 
  19  * WITHOUT ANY WARRANTY; without even the implied warranty of
 
  20  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 
  21  * General Public License for more details.
 
  23  * You should have received a copy of the GNU General Public License along
 
  24  * with this program; if not, write to the Free Software Foundation, Inc.,
 
  25  * 675 Mass Ave, Cambridge, MA 02139, USA.
 
  28 /* IMPORTANT NOTE: This file must be included in another file which does
 
  29  * the following thing for it to work:
 
  30  * The macro UNUSUAL_DEV() must be defined before this file is included
 
  33 /* If you edit this file, please try to keep it sorted first by VendorID,
 
  36  * If you want to add an entry for this file, be sure to include the
 
  37  * following information:
 
  38  *      - a patch that adds the entry for your device, including your
 
  39  *        email address right above the entry (plus maybe a brief
 
  40  *        explanation of the reason for the entry),
 
  41  *      - a copy of /proc/bus/usb/devices with your device plugged in
 
  42  *        running with this patch.
 
  43  * Send your submission to either Phil Dibowitz <phil@ipom.com> or
 
  44  * Alan Stern <stern@rowland.harvard.edu>, and don't forget to CC: the
 
  45  * USB development list <linux-usb@vger.kernel.org> and the USB storage list
 
  46  * <usb-storage@lists.one-eyed-alien.net>
 
  49 /* patch submitted by Vivian Bregier <Vivian.Bregier@imag.fr>
 
  51 UNUSUAL_DEV(  0x03eb, 0x2002, 0x0100, 0x0100,
 
  54                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
  55                 US_FL_IGNORE_RESIDUE),
 
  57 /* modified by Tobias Lorenz <tobias.lorenz@gmx.net> */
 
  58 UNUSUAL_DEV(  0x03ee, 0x6901, 0x0000, 0x0200,
 
  61                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
  64 /* Reported by Rodolfo Quesada <rquesada@roqz.net> */
 
  65 UNUSUAL_DEV(  0x03ee, 0x6906, 0x0003, 0x0003,
 
  66                 "VIA Technologies Inc.",
 
  67                 "Mitsumi multi cardreader",
 
  68                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
  69                 US_FL_IGNORE_RESIDUE ),
 
  71 UNUSUAL_DEV(  0x03f0, 0x0107, 0x0200, 0x0200,
 
  74                 US_SC_8070, US_PR_CB, NULL, 0),
 
  76 #ifdef CONFIG_USB_STORAGE_USBAT
 
  77 UNUSUAL_DEV(  0x03f0, 0x0207, 0x0001, 0x0001,
 
  80                 US_SC_8070, US_PR_USBAT, init_usbat_cd, 0),
 
  82 UNUSUAL_DEV(  0x03f0, 0x0307, 0x0001, 0x0001,
 
  85                 US_SC_8070, US_PR_USBAT, init_usbat_cd, 0),
 
  88 /* Reported by Grant Grundler <grundler@parisc-linux.org>
 
  89  * HP r707 camera in "Disk" mode with 2.00.23 or 2.00.24 firmware.
 
  91 UNUSUAL_DEV(  0x03f0, 0x4002, 0x0001, 0x0001,
 
  94                 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_FIX_CAPACITY),
 
  96 /* Reported by Sebastian Kapfer <sebastian_kapfer@gmx.net>
 
  97  * and Olaf Hering <olh@suse.de> (different bcd's, same vendor/product)
 
  98  * for USB floppies that need the SINGLE_LUN enforcement.
 
 100 UNUSUAL_DEV(  0x0409, 0x0040, 0x0000, 0x9999,
 
 103                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 106 /* Patch submitted by Mihnea-Costin Grigore <mihnea@zulu.ro> */
 
 107 UNUSUAL_DEV(  0x040d, 0x6205, 0x0003, 0x0003,
 
 108                 "VIA Technologies Inc.",
 
 109                 "USB 2.0 Card Reader",
 
 110                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 111                 US_FL_IGNORE_RESIDUE ),
 
 113 /* Deduced by Jonathan Woithe <jwoithe@physics.adelaide.edu.au>
 
 114  * Entry needed for flags: US_FL_FIX_INQUIRY because initial inquiry message
 
 115  * always fails and confuses drive.
 
 117 UNUSUAL_DEV(  0x0411, 0x001c, 0x0113, 0x0113,
 
 120                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 123 /* Submitted by Ernestas Vaiciukevicius <ernisv@gmail.com> */
 
 124 UNUSUAL_DEV(  0x0419, 0x0100, 0x0100, 0x0100,
 
 125                 "Samsung Info. Systems America, Inc.",
 
 127                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 128                 US_FL_IGNORE_RESIDUE ),
 
 130 /* Reported by Orgad Shaneh <orgads@gmail.com> */
 
 131 UNUSUAL_DEV(  0x0419, 0xaace, 0x0100, 0x0100,
 
 132                 "Samsung", "MP3 Player",
 
 133                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 134                 US_FL_IGNORE_RESIDUE ),
 
 136 /* Reported by Christian Leber <christian@leber.de> */
 
 137 UNUSUAL_DEV(  0x0419, 0xaaf5, 0x0100, 0x0100,
 
 140                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 141                 US_FL_IGNORE_RESIDUE | US_FL_NOT_LOCKABLE ),
 
 143 /* Reported by Stefan Werner <dustbln@gmx.de> */
 
 144 UNUSUAL_DEV(  0x0419, 0xaaf6, 0x0100, 0x0100,
 
 147                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 148                 US_FL_IGNORE_RESIDUE ),
 
 150 /* Reported by Pete Zaitcev <zaitcev@redhat.com>, bz#176584 */
 
 151 UNUSUAL_DEV(  0x0420, 0x0001, 0x0100, 0x0100,
 
 152                 "GENERIC", "MP3 PLAYER", /* MyMusix PD-205 on the outside. */
 
 153                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 154                 US_FL_IGNORE_RESIDUE ),
 
 156 /* Reported by Andrew Nayenko <relan@bk.ru> */
 
 157 UNUSUAL_DEV(  0x0421, 0x0019, 0x0592, 0x0592,
 
 160                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 161                 US_FL_MAX_SECTORS_64 ),
 
 163 /* Reported by Mario Rettig <mariorettig@web.de> */
 
 164 UNUSUAL_DEV(  0x0421, 0x042e, 0x0100, 0x0100,
 
 167                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 168                 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
 
 170 /* Reported by <honkkis@gmail.com> */
 
 171 UNUSUAL_DEV(  0x0421, 0x0433, 0x0100, 0x0100,
 
 174                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 175                 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
 
 177 /* Reported by Jon Hart <Jon.Hart@web.de> */
 
 178 UNUSUAL_DEV(  0x0421, 0x0434, 0x0100, 0x0100,
 
 181                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 182                 US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
 
 184 /* Reported by Sumedha Swamy <sumedhaswamy@gmail.com> and
 
 185  * Einar Th. Einarsson <einarthered@gmail.com> */
 
 186 UNUSUAL_DEV(  0x0421, 0x0444, 0x0100, 0x0100,
 
 189                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 190                 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
 
 192 /* Reported by Jiri Slaby <jirislaby@gmail.com> and
 
 193  * Rene C. Castberg <Rene@Castberg.org> */
 
 194 UNUSUAL_DEV(  0x0421, 0x0446, 0x0100, 0x0100,
 
 197                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 198                 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
 
 200 /* Reported by Matthew Bloch <matthew@bytemark.co.uk> */
 
 201 UNUSUAL_DEV(  0x0421, 0x044e, 0x0100, 0x0100,
 
 204                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 205                 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
 
 207 /* Reported by Bardur Arantsson <bardur@scientician.net> */
 
 208 UNUSUAL_DEV(  0x0421, 0x047c, 0x0370, 0x0610,
 
 211                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 212                 US_FL_MAX_SECTORS_64 ),
 
 214 /* Reported by Manuel Osdoba <manuel.osdoba@tu-ilmenau.de> */
 
 215 UNUSUAL_DEV( 0x0421, 0x0492, 0x0452, 0x0452,
 
 218                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 219                 US_FL_MAX_SECTORS_64 ),
 
 221 /* Reported by Alex Corcoles <alex@corcoles.net> */
 
 222 UNUSUAL_DEV(  0x0421, 0x0495, 0x0370, 0x0370,
 
 225                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 226                 US_FL_MAX_SECTORS_64 ),
 
 228 /* Reported by Olaf Hering <olh@suse.de> from novell bug #105878 */
 
 229 UNUSUAL_DEV(  0x0424, 0x0fdc, 0x0210, 0x0210,
 
 232                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 235 #ifdef CONFIG_USB_STORAGE_DPCM
 
 236 UNUSUAL_DEV(  0x0436, 0x0005, 0x0100, 0x0100,
 
 238                 "CameraMate (DPCM_USB)",
 
 239                 US_SC_SCSI, US_PR_DPCM_USB, NULL, 0 ),
 
 242 /* Patch submitted by Daniel Drake <dsd@gentoo.org>
 
 243  * Device reports nonsense bInterfaceProtocol 6 when connected over USB2 */
 
 244 UNUSUAL_DEV(  0x0451, 0x5416, 0x0100, 0x0100,
 
 247                 US_SC_DEVICE, US_PR_BULK, NULL,
 
 248                 US_FL_NEED_OVERRIDE ),
 
 251  * Pete Zaitcev <zaitcev@yahoo.com>, from Patrick C. F. Ernzer, bz#162559.
 
 252  * The key does not actually break, but it returns zero sense which
 
 253  * makes our SCSI stack to print confusing messages.
 
 255 UNUSUAL_DEV(  0x0457, 0x0150, 0x0100, 0x0100,
 
 256                 "USBest Technology",    /* sold by Transcend */
 
 257                 "USB Mass Storage Device",
 
 258                 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_NOT_LOCKABLE ),
 
 261 * Bohdan Linda <bohdan.linda@gmail.com>
 
 262 * 1GB USB sticks MyFlash High Speed. I have restricted
 
 263 * the revision to my model only
 
 265 UNUSUAL_DEV(  0x0457, 0x0151, 0x0100, 0x0100,
 
 268                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 269                 US_FL_NOT_LOCKABLE ),
 
 271 #ifdef CONFIG_USB_STORAGE_KARMA
 
 272 UNUSUAL_DEV(  0x045a, 0x5210, 0x0101, 0x0101,
 
 275                 US_SC_SCSI, US_PR_KARMA, rio_karma_init, 0),
 
 279  * This virtual floppy is found in Sun equipment (x4600, x4200m2, etc.)
 
 280  * Reported by Pete Zaitcev <zaitcev@redhat.com>
 
 281  * This device chokes on both version of MODE SENSE which we have, so
 
 282  * use_10_for_ms is not effective, and we use US_FL_NO_WP_DETECT.
 
 284 UNUSUAL_DEV(  0x046b, 0xff40, 0x0100, 0x0100,
 
 287                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 290 /* Patch submitted by Philipp Friedrich <philipp@void.at> */
 
 291 UNUSUAL_DEV(  0x0482, 0x0100, 0x0100, 0x0100,
 
 294                 US_SC_8070, US_PR_CB, NULL, US_FL_FIX_INQUIRY),
 
 296 /* Patch submitted by Philipp Friedrich <philipp@void.at> */
 
 297 UNUSUAL_DEV(  0x0482, 0x0101, 0x0100, 0x0100,
 
 300                 US_SC_8070, US_PR_CB, NULL, US_FL_FIX_INQUIRY),
 
 302 /* Patch submitted by Stephane Galles <stephane.galles@free.fr> */
 
 303 UNUSUAL_DEV(  0x0482, 0x0103, 0x0100, 0x0100,
 
 306                 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_FIX_INQUIRY),
 
 308 /* Reported by Paul Stewart <stewart@wetlogic.net>
 
 309  * This entry is needed because the device reports Sub=ff */
 
 310 UNUSUAL_DEV(  0x04a4, 0x0004, 0x0001, 0x0001,
 
 312                 "DVD-CAM DZ-MV100A Camcorder",
 
 313                 US_SC_SCSI, US_PR_CB, NULL, US_FL_SINGLE_LUN),
 
 315 /* Patch for Nikon coolpix 2000
 
 316  * Submitted by Fabien Cosse <fabien.cosse@wanadoo.fr>*/
 
 317 UNUSUAL_DEV(  0x04b0, 0x0301, 0x0010, 0x0010,
 
 320                 US_SC_DEVICE, US_PR_DEVICE,NULL,
 
 321                 US_FL_NOT_LOCKABLE ),
 
 323 /* Reported by Stefan de Konink <skinkie@xs4all.nl> */
 
 324 UNUSUAL_DEV(  0x04b0, 0x0401, 0x0200, 0x0200,
 
 327                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 330 /* Reported by Milinevsky Dmitry <niam.niam@gmail.com> */
 
 331 UNUSUAL_DEV(  0x04b0, 0x0409, 0x0100, 0x0100,
 
 334                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 337 /* Reported by Andreas Bockhold <andreas@bockionline.de> */
 
 338 UNUSUAL_DEV(  0x04b0, 0x0405, 0x0100, 0x0100,
 
 341                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 344 /* Reported by Jamie Kitson <jamie@staberinde.fsnet.co.uk> */
 
 345 UNUSUAL_DEV(  0x04b0, 0x040d, 0x0100, 0x0100,
 
 348                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 351 /* Reported by Graber and Mike Pagano <mpagano-kernel@mpagano.com> */
 
 352 UNUSUAL_DEV(  0x04b0, 0x040f, 0x0100, 0x0200,
 
 355                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 358 /* Reported by Emil Larsson <emil@swip.net> */
 
 359 UNUSUAL_DEV(  0x04b0, 0x0411, 0x0100, 0x0110,
 
 362                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 365 /* Reported by Ortwin Glueck <odi@odi.ch> */
 
 366 UNUSUAL_DEV(  0x04b0, 0x0413, 0x0110, 0x0110,
 
 369                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 372 /* Reported by Paul Check <paul@openstreet.com> */
 
 373 UNUSUAL_DEV(  0x04b0, 0x0415, 0x0100, 0x0100,
 
 376                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 379 /* Reported by Shan Destromp (shansan@gmail.com) */
 
 380 UNUSUAL_DEV(  0x04b0, 0x0417, 0x0100, 0x0100,
 
 383                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 386 /* Reported by Doug Maxey (dwm@austin.ibm.com) */
 
 387 UNUSUAL_DEV(  0x04b3, 0x4001, 0x0110, 0x0110,
 
 390                 US_SC_DEVICE, US_PR_CB, NULL,
 
 391                 US_FL_MAX_SECTORS_MIN),
 
 394  * Reported by Manuel Fombuena <mfombuena@ya.com> and
 
 395  * Frank Copeland <fjc@thingy.apana.org.au> */
 
 396 UNUSUAL_DEV(  0x04a5, 0x3010, 0x0100, 0x0100,
 
 397                 "Tekom Technologies, Inc",
 
 399                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 400                 US_FL_IGNORE_RESIDUE ),
 
 402 #ifdef CONFIG_USB_STORAGE_CYPRESS_ATACB
 
 403 /* CY7C68300 : support atacb */
 
 404 UNUSUAL_DEV(  0x04b4, 0x6830, 0x0000, 0x9999,
 
 407                 US_SC_CYP_ATACB, US_PR_DEVICE, NULL,
 
 410 /* CY7C68310 : support atacb and atacb2 */
 
 411 UNUSUAL_DEV(  0x04b4, 0x6831, 0x0000, 0x9999,
 
 414                 US_SC_CYP_ATACB, US_PR_DEVICE, NULL,
 
 418 /* Reported by Simon Levitt <simon@whattf.com>
 
 419  * This entry needs Sub and Proto fields */
 
 420 UNUSUAL_DEV(  0x04b8, 0x0601, 0x0100, 0x0100,
 
 423                 US_SC_SCSI, US_PR_CB, NULL, US_FL_FIX_INQUIRY),
 
 425 /* Reported by Khalid Aziz <khalid@gonehiking.org>
 
 426  * This entry is needed because the device reports Sub=ff */
 
 427 UNUSUAL_DEV(  0x04b8, 0x0602, 0x0110, 0x0110,
 
 430                 US_SC_SCSI, US_PR_BULK, NULL, US_FL_SINGLE_LUN),
 
 432 /* Not sure who reported this originally but
 
 433  * Pavel Machek <pavel@ucw.cz> reported that the extra US_FL_SINGLE_LUN
 
 435 UNUSUAL_DEV(  0x04cb, 0x0100, 0x0000, 0x2210,
 
 438                 US_SC_UFI, US_PR_DEVICE, NULL, US_FL_FIX_INQUIRY | US_FL_SINGLE_LUN),
 
 440 /* Reported by Peter Wächtler <pwaechtler@loewe-komp.de>
 
 441  * The device needs the flags only.
 
 443 UNUSUAL_DEV(  0x04ce, 0x0002, 0x0074, 0x0074,
 
 446                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 449 /* Reported by Kriston Fincher <kriston@airmail.net>
 
 450  * Patch submitted by Sean Millichamp <sean@bruenor.org>
 
 451  * This is to support the Panasonic PalmCam PV-SD4090
 
 452  * This entry is needed because the device reports Sub=ff 
 
 454 UNUSUAL_DEV(  0x04da, 0x0901, 0x0100, 0x0200,
 
 457                 US_SC_UFI, US_PR_DEVICE, NULL, 0),
 
 459 /* From Yukihiro Nakai, via zaitcev@yahoo.com.
 
 460  * This is needed for CB instead of CBI */
 
 461 UNUSUAL_DEV(  0x04da, 0x0d05, 0x0000, 0x0000,
 
 464                 US_SC_8070, US_PR_CB, NULL, 0),
 
 466 /* Reported by Adriaan Penning <a.penning@luon.net> */
 
 467 UNUSUAL_DEV(  0x04da, 0x2372, 0x0000, 0x9999,
 
 470                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 471                 US_FL_FIX_CAPACITY | US_FL_NOT_LOCKABLE ),
 
 473 /* Reported by Simeon Simeonov <simeonov_2000@yahoo.com> */
 
 474 UNUSUAL_DEV(  0x04da, 0x2373, 0x0000, 0x9999,
 
 477                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 478                 US_FL_FIX_CAPACITY | US_FL_NOT_LOCKABLE ),
 
 480 /* Most of the following entries were developed with the help of
 
 481  * Shuttle/SCM directly.
 
 483 UNUSUAL_DEV(  0x04e6, 0x0001, 0x0200, 0x0200,
 
 486                 US_SC_8020, US_PR_CB, NULL, 0),
 
 488 UNUSUAL_DEV(  0x04e6, 0x0002, 0x0100, 0x0100,
 
 491                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_euscsi_init, 
 
 492                 US_FL_SCM_MULT_TARG ),
 
 494 #ifdef CONFIG_USB_STORAGE_SDDR09
 
 495 UNUSUAL_DEV(  0x04e6, 0x0003, 0x0000, 0x9999,
 
 498                 US_SC_SCSI, US_PR_EUSB_SDDR09, usb_stor_sddr09_init,
 
 501 /* This entry is from Andries.Brouwer@cwi.nl */
 
 502 UNUSUAL_DEV(  0x04e6, 0x0005, 0x0100, 0x0208,
 
 504                 "eUSB SmartMedia / CompactFlash Adapter",
 
 505                 US_SC_SCSI, US_PR_DPCM_USB, usb_stor_sddr09_dpcm_init,
 
 509 /* Reported by Markus Demleitner <msdemlei@cl.uni-heidelberg.de> */
 
 510 UNUSUAL_DEV(  0x04e6, 0x0006, 0x0100, 0x0100,
 
 511                 "SCM Microsystems Inc.",
 
 513                 US_SC_SCSI, US_PR_CB, NULL,
 
 516 /* Reported by Daniel Nouri <dpunktnpunkt@web.de> */
 
 517 UNUSUAL_DEV(  0x04e6, 0x0006, 0x0205, 0x0205,
 
 520                 US_SC_SCSI, US_PR_DEVICE, NULL,
 
 523 UNUSUAL_DEV(  0x04e6, 0x0007, 0x0100, 0x0200,
 
 526                 US_SC_SCSI, US_PR_CB, NULL,
 
 529 UNUSUAL_DEV(  0x04e6, 0x0009, 0x0200, 0x0200,
 
 531                 "eUSB ATA/ATAPI Adapter",
 
 532                 US_SC_8020, US_PR_CB, NULL, 0),
 
 534 UNUSUAL_DEV(  0x04e6, 0x000a, 0x0200, 0x0200,
 
 536                 "eUSB CompactFlash Adapter",
 
 537                 US_SC_8020, US_PR_CB, NULL, 0),
 
 539 UNUSUAL_DEV(  0x04e6, 0x000B, 0x0100, 0x0100,
 
 542                 US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
 
 543                 US_FL_SCM_MULT_TARG ), 
 
 545 UNUSUAL_DEV(  0x04e6, 0x000C, 0x0100, 0x0100,
 
 548                 US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
 
 549                 US_FL_SCM_MULT_TARG ),
 
 551 UNUSUAL_DEV(  0x04e6, 0x0101, 0x0200, 0x0200,
 
 554                 US_SC_8020, US_PR_CB, NULL, 0),
 
 556 #ifdef CONFIG_USB_STORAGE_USBAT
 
 557 UNUSUAL_DEV(  0x04e6, 0x1010, 0x0000, 0x9999,
 
 560                 US_SC_SCSI, US_PR_USBAT, init_usbat_flash,
 
 564 /* Reported by Dmitry Khlystov <adminimus@gmail.com> */
 
 565 UNUSUAL_DEV(  0x04e8, 0x507c, 0x0220, 0x0220,
 
 568                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 569                 US_FL_MAX_SECTORS_64),
 
 571 /* Entry and supporting patch by Theodore Kilgore <kilgota@auburn.edu>.
 
 572  * Device uses standards-violating 32-byte Bulk Command Block Wrappers and
 
 573  * reports itself as "Proprietary SCSI Bulk." Cf. device entry 0x084d:0x0011.
 
 575 UNUSUAL_DEV(  0x04fc, 0x80c2, 0x0100, 0x0100,
 
 578                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 581 /* Reported by Bob Sass <rls@vectordb.com> -- only rev 1.33 tested */
 
 582 UNUSUAL_DEV(  0x050d, 0x0115, 0x0133, 0x0133,
 
 585                 US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
 
 586                 US_FL_SCM_MULT_TARG ),
 
 588 /* Iomega Clik! Drive 
 
 589  * Reported by David Chatenay <dchatenay@hotmail.com>
 
 590  * The reason this is needed is not fully known.
 
 592 UNUSUAL_DEV(  0x0525, 0xa140, 0x0100, 0x0100,
 
 595                 US_SC_8070, US_PR_DEVICE, NULL,
 
 598 /* Yakumo Mega Image 37
 
 599  * Submitted by Stephan Fuhrmann <atomenergie@t-online.de> */
 
 600 UNUSUAL_DEV(  0x052b, 0x1801, 0x0100, 0x0100,
 
 601                 "Tekom Technologies, Inc",
 
 603                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 604                 US_FL_IGNORE_RESIDUE ),
 
 606 /* Another Yakumo camera.
 
 607  * Reported by Michele Alzetta <michele.alzetta@aliceposta.it> */
 
 608 UNUSUAL_DEV(  0x052b, 0x1804, 0x0100, 0x0100,
 
 609                 "Tekom Technologies, Inc",
 
 611                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 612                 US_FL_IGNORE_RESIDUE ),
 
 614 /* Reported by Iacopo Spalletti <avvisi@spalletti.it> */
 
 615 UNUSUAL_DEV(  0x052b, 0x1807, 0x0100, 0x0100,
 
 616                 "Tekom Technologies, Inc",
 
 618                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 619                 US_FL_IGNORE_RESIDUE ),
 
 621 /* Yakumo Mega Image 47
 
 622  * Reported by Bjoern Paetzel <kolrabi@kolrabi.de> */
 
 623 UNUSUAL_DEV(  0x052b, 0x1905, 0x0100, 0x0100,
 
 624                 "Tekom Technologies, Inc",
 
 626                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 627                 US_FL_IGNORE_RESIDUE ),
 
 629 /* Reported by Paul Ortyl <ortylp@3miasto.net>
 
 630  * Note that it's similar to the device above, only different prodID */
 
 631 UNUSUAL_DEV(  0x052b, 0x1911, 0x0100, 0x0100,
 
 632                 "Tekom Technologies, Inc",
 
 634                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 635                 US_FL_IGNORE_RESIDUE ),
 
 637 UNUSUAL_DEV(  0x054c, 0x0010, 0x0106, 0x0450,
 
 639                 "DSC-S30/S70/S75/505V/F505/F707/F717/P8",
 
 640                 US_SC_SCSI, US_PR_DEVICE, NULL,
 
 641                 US_FL_SINGLE_LUN | US_FL_NOT_LOCKABLE | US_FL_NO_WP_DETECT ),
 
 643 /* Submitted by Lars Jacob <jacob.lars@googlemail.com>
 
 644  * This entry is needed because the device reports Sub=ff */
 
 645 UNUSUAL_DEV(  0x054c, 0x0010, 0x0500, 0x0610,
 
 648                 US_SC_8070, US_PR_DEVICE, NULL,
 
 652 /* Reported by wim@geeks.nl */
 
 653 UNUSUAL_DEV(  0x054c, 0x0025, 0x0100, 0x0100,
 
 655                 "Memorystick NW-MS7",
 
 656                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 659 #ifdef CONFIG_USB_STORAGE_ISD200
 
 660 UNUSUAL_DEV(  0x054c, 0x002b, 0x0100, 0x0110,
 
 662                 "Portable USB Harddrive V2",
 
 663                 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
 
 667 /* Submitted by Olaf Hering, <olh@suse.de> SuSE Bugzilla #49049 */
 
 668 UNUSUAL_DEV(  0x054c, 0x002c, 0x0501, 0x2000,
 
 671                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 674 UNUSUAL_DEV(  0x054c, 0x002d, 0x0100, 0x0100,
 
 676                 "Memorystick MSAC-US1",
 
 677                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 680 /* Submitted by Klaus Mueller <k.mueller@intershop.de> */
 
 681 UNUSUAL_DEV(  0x054c, 0x002e, 0x0106, 0x0310,
 
 684                 US_SC_SCSI, US_PR_DEVICE, NULL,
 
 687 /* Submitted by Rajesh Kumble Nayak <nayak@obs-nice.fr> */
 
 688 UNUSUAL_DEV(  0x054c, 0x002e, 0x0500, 0x0500,
 
 691                 US_SC_UFI, US_PR_DEVICE, NULL,
 
 694 UNUSUAL_DEV(  0x054c, 0x0032, 0x0000, 0x9999,
 
 696                 "Memorystick MSC-U01N",
 
 697                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 700 /* Submitted by Michal Mlotek <mlotek@foobar.pl> */
 
 701 UNUSUAL_DEV(  0x054c, 0x0058, 0x0000, 0x9999,
 
 703                 "PEG N760c Memorystick",
 
 704                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 707 UNUSUAL_DEV(  0x054c, 0x0069, 0x0000, 0x9999,
 
 709                 "Memorystick MSC-U03",
 
 710                 US_SC_UFI, US_PR_CB, NULL,
 
 713 /* Submitted by Nathan Babb <nathan@lexi.com> */
 
 714 UNUSUAL_DEV(  0x054c, 0x006d, 0x0000, 0x9999,
 
 717                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 720 /* Submitted by Mike Alborn <malborn@deandra.homeip.net> */
 
 721 UNUSUAL_DEV(  0x054c, 0x016a, 0x0000, 0x9999,
 
 724                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 727 /* Submitted by Frank Engel <frankie@cse.unsw.edu.au> */
 
 728 UNUSUAL_DEV(  0x054c, 0x0099, 0x0000, 0x9999,
 
 731                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 734 /* floppy reports multiple luns */
 
 735 UNUSUAL_DEV(  0x055d, 0x2020, 0x0000, 0x0210,
 
 738                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 742 UNUSUAL_DEV(  0x057b, 0x0000, 0x0000, 0x0299,
 
 745                 US_SC_DEVICE,  US_PR_CB, NULL,
 
 748 UNUSUAL_DEV(  0x057b, 0x0000, 0x0300, 0x9999,
 
 751                 US_SC_DEVICE,  US_PR_DEVICE, NULL,
 
 754 /* Reported by Johann Cardon <johann.cardon@free.fr>
 
 755  * This entry is needed only because the device reports
 
 756  * bInterfaceClass = 0xff (vendor-specific)
 
 758 UNUSUAL_DEV(  0x057b, 0x0022, 0x0000, 0x9999,
 
 761                 US_SC_DEVICE, US_PR_DEVICE, NULL, 0),
 
 763 #ifdef CONFIG_USB_STORAGE_ALAUDA
 
 764 UNUSUAL_DEV(  0x0584, 0x0008, 0x0102, 0x0102,
 
 767                 US_SC_SCSI, US_PR_ALAUDA, init_alauda, 0 ),
 
 770 /* Reported by RTE <raszilki@yandex.ru> */
 
 771 UNUSUAL_DEV(  0x058f, 0x6387, 0x0141, 0x0141,
 
 774                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 775                 US_FL_MAX_SECTORS_64 ),
 
 777 /* Fabrizio Fellini <fello@libero.it> */
 
 778 UNUSUAL_DEV(  0x0595, 0x4343, 0x0000, 0x2210,
 
 780                 "Digital Camera EX-20 DSC",
 
 781                 US_SC_8070, US_PR_DEVICE, NULL, 0 ),
 
 783 /* Reported by Andre Welter <a.r.welter@gmx.de>
 
 784  * This antique device predates the release of the Bulk-only Transport
 
 785  * spec, and if it gets a Get-Max-LUN then it requires the host to do a
 
 786  * Clear-Halt on the bulk endpoints.  The SINGLE_LUN flag will prevent
 
 787  * us from sending the request.
 
 789 UNUSUAL_DEV(  0x059b, 0x0001, 0x0100, 0x0100,
 
 792                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 795 /* Reported by <Hendryk.Pfeiffer@gmx.de> */
 
 796 UNUSUAL_DEV(  0x059f, 0x0643, 0x0000, 0x0000,
 
 799                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 802 /* Submitted by Joel Bourquard <numlock@freesurf.ch>
 
 803  * Some versions of this device need the SubClass and Protocol overrides
 
 804  * while others don't.
 
 806 UNUSUAL_DEV(  0x05ab, 0x0060, 0x1104, 0x1110,
 
 808                 "PyroGate External CD-ROM Enclosure (FCD-523)",
 
 809                 US_SC_SCSI, US_PR_BULK, NULL,
 
 810                 US_FL_NEED_OVERRIDE ),
 
 812 #ifdef CONFIG_USB_STORAGE_ISD200
 
 813 UNUSUAL_DEV(  0x05ab, 0x0031, 0x0100, 0x0110,
 
 815                 "USB/IDE Bridge (ATA/ATAPI)",
 
 816                 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
 
 819 UNUSUAL_DEV(  0x05ab, 0x0301, 0x0100, 0x0110,
 
 821                 "Portable USB Harddrive V2",
 
 822                 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
 
 825 UNUSUAL_DEV(  0x05ab, 0x0351, 0x0100, 0x0110,
 
 827                 "Portable USB Harddrive V2",
 
 828                 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
 
 831 UNUSUAL_DEV(  0x05ab, 0x5701, 0x0100, 0x0110,
 
 833                 "USB Storage Adapter V2",
 
 834                 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
 
 838 /* Submitted by Sven Anderson <sven-linux@anderson.de>
 
 839  * There are at least four ProductIDs used for iPods, so I added 0x1202 and
 
 840  * 0x1204. They just need the US_FL_FIX_CAPACITY. As the bcdDevice appears
 
 841  * to change with firmware updates, I changed the range to maximum for all
 
 844 UNUSUAL_DEV( 0x05ac, 0x1202, 0x0000, 0x9999,
 
 847                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 848                 US_FL_FIX_CAPACITY ),
 
 850 /* Reported by Avi Kivity <avi@argo.co.il> */
 
 851 UNUSUAL_DEV( 0x05ac, 0x1203, 0x0000, 0x9999,
 
 854                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 855                 US_FL_FIX_CAPACITY ),
 
 857 UNUSUAL_DEV( 0x05ac, 0x1204, 0x0000, 0x9999,
 
 860                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 861                 US_FL_FIX_CAPACITY | US_FL_NOT_LOCKABLE ),
 
 863 UNUSUAL_DEV( 0x05ac, 0x1205, 0x0000, 0x9999,
 
 866                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 867                 US_FL_FIX_CAPACITY ),
 
 870  * Reported by Tyson Vinson <lornoss@gmail.com>
 
 871  * This particular productId is the iPod Nano
 
 873 UNUSUAL_DEV( 0x05ac, 0x120a, 0x0000, 0x9999,
 
 876                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 877                 US_FL_FIX_CAPACITY ),
 
 879 #ifdef CONFIG_USB_STORAGE_JUMPSHOT
 
 880 UNUSUAL_DEV(  0x05dc, 0x0001, 0x0000, 0x0001,
 
 882                 "Jumpshot USB CF Reader",
 
 883                 US_SC_SCSI, US_PR_JUMPSHOT, NULL,
 
 884                 US_FL_NEED_OVERRIDE ),
 
 887 /* Reported by Blake Matheny <bmatheny@purdue.edu> */
 
 888 UNUSUAL_DEV(  0x05dc, 0xb002, 0x0000, 0x0113,
 
 891                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 894 /* The following two entries are for a Genesys USB to IDE
 
 895  * converter chip, but it changes its ProductId depending
 
 896  * on whether or not a disk or an optical device is enclosed
 
 897  * They were originally reported by Alexander Oltu
 
 898  * <alexander@all-2.com> and Peter Marks <peter.marks@turner.com>
 
 901  * US_FL_GO_SLOW and US_FL_MAX_SECTORS_64 added by Phil Dibowitz
 
 902  * <phil@ipom.com> as these flags were made and hard-coded
 
 903  * special-cases were pulled from scsiglue.c.
 
 905 UNUSUAL_DEV(  0x05e3, 0x0701, 0x0000, 0xffff,
 
 907                 "USB to IDE Optical",
 
 908                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 909                 US_FL_GO_SLOW | US_FL_MAX_SECTORS_64 ),
 
 911 UNUSUAL_DEV(  0x05e3, 0x0702, 0x0000, 0xffff,
 
 914                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 915                 US_FL_GO_SLOW | US_FL_MAX_SECTORS_64 ),
 
 917 /* Reported by Hanno Boeck <hanno@gmx.de>
 
 918  * Taken from the Lycoris Kernel */
 
 919 UNUSUAL_DEV(  0x0636, 0x0003, 0x0000, 0x9999,
 
 922                 US_SC_SCSI, US_PR_BULK, NULL,
 
 925 UNUSUAL_DEV(  0x0644, 0x0000, 0x0100, 0x0100,
 
 928                 US_SC_UFI, US_PR_CB, NULL, 0 ),
 
 930 #ifdef CONFIG_USB_STORAGE_SDDR09
 
 931 UNUSUAL_DEV(  0x066b, 0x0105, 0x0100, 0x0100,
 
 934                 US_SC_SCSI, US_PR_EUSB_SDDR09, usb_stor_sddr09_init,
 
 938 /* Reported by Darsen Lu <darsen@micro.ee.nthu.edu.tw> */
 
 939 UNUSUAL_DEV( 0x066f, 0x8000, 0x0001, 0x0001,
 
 941                 "USBMSC Audio Player",
 
 942                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 943                 US_FL_FIX_CAPACITY ),
 
 945 /* Reported by Richard -=[]=- <micro_flyer@hotmail.com> */
 
 946 UNUSUAL_DEV( 0x067b, 0x2507, 0x0100, 0x0100,
 
 947                 "Prolific Technology Inc.",
 
 948                 "Mass Storage Device",
 
 949                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 950                 US_FL_FIX_CAPACITY | US_FL_GO_SLOW ),
 
 952 /* Reported by Alex Butcher <alex.butcher@assursys.co.uk> */
 
 953 UNUSUAL_DEV( 0x067b, 0x3507, 0x0001, 0x0001,
 
 954                 "Prolific Technology Inc.",
 
 955                 "ATAPI-6 Bridge Controller",
 
 956                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 957                 US_FL_FIX_CAPACITY | US_FL_GO_SLOW ),
 
 959 /* Submitted by Benny Sjostrand <benny@hostmobility.com> */
 
 960 UNUSUAL_DEV( 0x0686, 0x4011, 0x0001, 0x0001,
 
 963                 US_SC_SCSI, US_PR_BULK, NULL, 0 ),
 
 965 /* Reported by Miguel A. Fosas <amn3s1a@ono.com> */
 
 966 UNUSUAL_DEV(  0x0686, 0x4017, 0x0001, 0x0001,
 
 969                 US_SC_SCSI, US_PR_DEVICE, NULL, 0 ),
 
 971 UNUSUAL_DEV(  0x0693, 0x0005, 0x0100, 0x0100,
 
 974                 US_SC_SCSI, US_PR_BULK, NULL, 0 ),
 
 976 /* Reported by David Hamilton <niftimusmaximus@lycos.com> */
 
 977 UNUSUAL_DEV(  0x069b, 0x3004, 0x0001, 0x0001,
 
 978                 "Thomson Multimedia Inc.",
 
 979                 "RCA RD1080 MP3 Player",
 
 980                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 981                 US_FL_FIX_CAPACITY ),
 
 983 /* Reported by Massimiliano Ghilardi <massimiliano.ghilardi@gmail.com>
 
 984  * This USB MP3/AVI player device fails and disconnects if more than 128
 
 985  * sectors (64kB) are read/written in a single command, and may be present
 
 986  * at least in the following products:
 
 987  *   "Magnex Digital Video Panel DVP 1800"
 
 988  *   "MP4 AIGO 4GB SLOT SD"
 
 989  *   "Teclast TL-C260 MP3"
 
 990  *   "i.Meizu PMP MP3/MP4"
 
 991  *   "Speed MV8 MP4 Audio Player"
 
 993 UNUSUAL_DEV(  0x071b, 0x3203, 0x0100, 0x0100,
 
 996                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
 997                 US_FL_MAX_SECTORS_64),
 
 999 /* Reported by Olivier Blondeau <zeitoun@gmail.com> */
 
1000 UNUSUAL_DEV(  0x0727, 0x0306, 0x0100, 0x0100,
 
1003                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1004                 US_FL_IGNORE_RESIDUE),
 
1006 /* Submitted by Roman Hodek <roman@hodek.net> */
 
1007 UNUSUAL_DEV(  0x0781, 0x0001, 0x0200, 0x0200,
 
1009                 "ImageMate SDDR-05a",
 
1010                 US_SC_SCSI, US_PR_CB, NULL,
 
1013 UNUSUAL_DEV(  0x0781, 0x0002, 0x0009, 0x0009,
 
1014                 "SanDisk Corporation",
 
1015                 "ImageMate CompactFlash USB",
 
1016                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1017                 US_FL_FIX_CAPACITY ),
 
1019 #ifdef CONFIG_USB_STORAGE_USBAT
 
1020 UNUSUAL_DEV(  0x0781, 0x0005, 0x0005, 0x0005,
 
1022                 "ImageMate SDDR-05b",
 
1023                 US_SC_SCSI, US_PR_USBAT, init_usbat_flash,
 
1027 UNUSUAL_DEV(  0x0781, 0x0100, 0x0100, 0x0100,
 
1029                 "ImageMate SDDR-12",
 
1030                 US_SC_SCSI, US_PR_CB, NULL,
 
1033 #ifdef CONFIG_USB_STORAGE_SDDR09
 
1034 UNUSUAL_DEV(  0x0781, 0x0200, 0x0000, 0x9999,
 
1036                 "ImageMate SDDR-09",
 
1037                 US_SC_SCSI, US_PR_EUSB_SDDR09, usb_stor_sddr09_init,
 
1041 #ifdef CONFIG_USB_STORAGE_FREECOM
 
1042 UNUSUAL_DEV(  0x07ab, 0xfc01, 0x0000, 0x9999,
 
1045                 US_SC_QIC, US_PR_FREECOM, freecom_init, 0),
 
1048 /* Reported by Eero Volotinen <eero@ping-viini.org> */
 
1049 UNUSUAL_DEV(  0x07ab, 0xfccd, 0x0000, 0x9999,
 
1050                 "Freecom Technologies",
 
1052                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1053                 US_FL_FIX_CAPACITY),
 
1055 UNUSUAL_DEV(  0x07af, 0x0004, 0x0100, 0x0133,
 
1058                 US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
 
1059                 US_FL_SCM_MULT_TARG ), 
 
1061 UNUSUAL_DEV(  0x07af, 0x0005, 0x0100, 0x0100,
 
1064                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_euscsi_init,
 
1065                 US_FL_SCM_MULT_TARG ),
 
1067 #ifdef CONFIG_USB_STORAGE_DPCM
 
1068 UNUSUAL_DEV(  0x07af, 0x0006, 0x0100, 0x0100,
 
1070                 "CameraMate (DPCM_USB)",
 
1071                 US_SC_SCSI, US_PR_DPCM_USB, NULL, 0 ),
 
1074 #ifdef CONFIG_USB_STORAGE_ALAUDA
 
1075 UNUSUAL_DEV(  0x07b4, 0x010a, 0x0102, 0x0102,
 
1077                 "MAUSB-10 (Alauda)",
 
1078                 US_SC_SCSI, US_PR_ALAUDA, init_alauda, 0 ),
 
1081 #ifdef CONFIG_USB_STORAGE_DATAFAB
 
1082 UNUSUAL_DEV(  0x07c4, 0xa000, 0x0000, 0x0015,
 
1084                 "MDCFE-B USB CF Reader",
 
1085                 US_SC_SCSI, US_PR_DATAFAB, NULL,
 
1089  * The following Datafab-based devices may or may not work
 
1090  * using the current driver...the 0xffff is arbitrary since I
 
1091  * don't know what device versions exist for these guys.
 
1093  * The 0xa003 and 0xa004 devices in particular I'm curious about.
 
1094  * I'm told they exist but so far nobody has come forward to say that
 
1095  * they work with this driver.  Given the success we've had getting
 
1096  * other Datafab-based cards operational with this driver, I've decided
 
1097  * to leave these two devices in the list.
 
1099 UNUSUAL_DEV( 0x07c4, 0xa001, 0x0000, 0xffff,
 
1101                 "SIIG/Datafab Memory Stick+CF Reader/Writer",
 
1102                 US_SC_SCSI, US_PR_DATAFAB, NULL,
 
1105 /* Reported by Josef Reisinger <josef.reisinger@netcologne.de> */
 
1106 UNUSUAL_DEV( 0x07c4, 0xa002, 0x0000, 0xffff,
 
1108                 "MD2/MD3 Disk enclosure",
 
1109                 US_SC_SCSI, US_PR_DATAFAB, NULL,
 
1112 UNUSUAL_DEV( 0x07c4, 0xa003, 0x0000, 0xffff,
 
1114                 "Datafab-based Reader",
 
1115                 US_SC_SCSI, US_PR_DATAFAB, NULL,
 
1118 UNUSUAL_DEV( 0x07c4, 0xa004, 0x0000, 0xffff,
 
1120                 "Datafab-based Reader",
 
1121                 US_SC_SCSI, US_PR_DATAFAB, NULL,
 
1124 UNUSUAL_DEV( 0x07c4, 0xa005, 0x0000, 0xffff,
 
1126                 "PNY/Datafab CF+SM Reader",
 
1127                 US_SC_SCSI, US_PR_DATAFAB, NULL,
 
1130 UNUSUAL_DEV( 0x07c4, 0xa006, 0x0000, 0xffff,
 
1131                 "Simple Tech/Datafab",
 
1132                 "Simple Tech/Datafab CF+SM Reader",
 
1133                 US_SC_SCSI, US_PR_DATAFAB, NULL,
 
1137 #ifdef CONFIG_USB_STORAGE_SDDR55
 
1138 /* Contributed by Peter Waechtler */
 
1139 UNUSUAL_DEV( 0x07c4, 0xa103, 0x0000, 0x9999,
 
1142                 US_SC_SCSI, US_PR_SDDR55, NULL,
 
1143                 US_FL_FIX_INQUIRY ),
 
1146 #ifdef CONFIG_USB_STORAGE_DATAFAB
 
1147 /* Submitted by Olaf Hering <olh@suse.de> */
 
1148 UNUSUAL_DEV(  0x07c4, 0xa109, 0x0000, 0xffff,
 
1149                 "Datafab Systems, Inc.",
 
1150                 "USB to CF + SM Combo (LC1)",
 
1151                 US_SC_SCSI, US_PR_DATAFAB, NULL,
 
1154 #ifdef CONFIG_USB_STORAGE_SDDR55
 
1155 /* SM part - aeb <Andries.Brouwer@cwi.nl> */
 
1156 UNUSUAL_DEV(  0x07c4, 0xa109, 0x0000, 0xffff,
 
1157                 "Datafab Systems, Inc.",
 
1158                 "USB to CF + SM Combo (LC1)",
 
1159                 US_SC_SCSI, US_PR_SDDR55, NULL,
 
1163 #ifdef CONFIG_USB_STORAGE_DATAFAB
 
1164 /* Reported by Felix Moeller <felix@derklecks.de>
 
1165  * in Germany this is sold by Hama with the productnumber 46952
 
1166  * as "DualSlot CompactFlash(TM) & MStick Drive USB"
 
1168 UNUSUAL_DEV(  0x07c4, 0xa10b, 0x0000, 0xffff,
 
1169                 "DataFab Systems Inc.",
 
1171                 US_SC_SCSI, US_PR_DATAFAB, NULL,
 
1176 /* Datafab KECF-USB / Sagatek DCS-CF / Simpletech Flashlink UCF-100
 
1177  * Only revision 1.13 tested (same for all of the above devices,
 
1178  * based on the Datafab DF-UG-07 chip).  Needed for US_FL_FIX_INQUIRY.
 
1179  * Submitted by Marek Michalkiewicz <marekm@amelek.gda.pl>.
 
1180  * See also http://martin.wilck.bei.t-online.de/#kecf .
 
1182 UNUSUAL_DEV(  0x07c4, 0xa400, 0x0000, 0xffff,
 
1185                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1186                 US_FL_FIX_INQUIRY ),
 
1188 /* Casio QV 2x00/3x00/4000/8000 digital still cameras are not conformant
 
1189  * to the USB storage specification in two ways:
 
1190  * - They tell us they are using transport protocol CBI. In reality they
 
1191  *   are using transport protocol CB.
 
1192  * - They don't like the INQUIRY command. So we must handle this command
 
1193  *   of the SCSI layer ourselves.
 
1194  * - Some cameras with idProduct=0x1001 and bcdDevice=0x1000 have
 
1195  *   bInterfaceProtocol=0x00 (US_PR_CBI) while others have 0x01 (US_PR_CB).
 
1196  *   So don't remove the US_PR_CB override!
 
1197  * - Cameras with bcdDevice=0x9009 require the US_SC_8070 override.
 
1199 UNUSUAL_DEV( 0x07cf, 0x1001, 0x1000, 0x9999,
 
1202                 US_SC_8070, US_PR_CB, NULL,
 
1203                 US_FL_NEED_OVERRIDE | US_FL_FIX_INQUIRY ),
 
1205 /* Submitted by Hartmut Wahl <hwahl@hwahl.de>*/
 
1206 UNUSUAL_DEV( 0x0839, 0x000a, 0x0001, 0x0001,
 
1209                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1212 /* Entry and supporting patch by Theodore Kilgore <kilgota@auburn.edu>.
 
1213  * Flag will support Bulk devices which use a standards-violating 32-byte
 
1214  * Command Block Wrapper. Here, the "DC2MEGA" cameras (several brands) with
 
1215  * Grandtech GT892x chip, which request "Proprietary SCSI Bulk" support.
 
1218 UNUSUAL_DEV(  0x084d, 0x0011, 0x0110, 0x0110,
 
1221                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1224 /* Andrew Lunn <andrew@lunn.ch>
 
1225  * PanDigital Digital Picture Frame. Does not like ALLOW_MEDIUM_REMOVAL
 
1227  * Note: Vend:Prod clash with "Ltd Maxell WS30 Slim Digital Camera"
 
1229 UNUSUAL_DEV(  0x0851, 0x1543, 0x0200, 0x0200,
 
1232                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1233                 US_FL_NOT_LOCKABLE),
 
1235 /* Andrew Lunn <andrew@lunn.ch>
 
1236  * PanDigital Digital Picture Frame. Does not like ALLOW_MEDIUM_REMOVAL
 
1238  * Note: Vend:Prod clash with "Ltd Maxell WS30 Slim Digital Camera"
 
1240 UNUSUAL_DEV(  0x0851, 0x1543, 0x0200, 0x0200,
 
1243                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1244                 US_FL_NOT_LOCKABLE),
 
1246 /* Submitted by Jan De Luyck <lkml@kcore.org> */
 
1247 UNUSUAL_DEV(  0x08bd, 0x1100, 0x0000, 0x0000,
 
1250                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1253 /* Submitted by Dylan Taft <d13f00l@gmail.com>
 
1254  * US_FL_IGNORE_RESIDUE Needed
 
1256 UNUSUAL_DEV(  0x08ca, 0x3103, 0x0100, 0x0100,
 
1258                 "Aiptek USB Keychain MP3 Player",
 
1259                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1260                 US_FL_IGNORE_RESIDUE),
 
1262 /* Entry needed for flags. Moreover, all devices with this ID use
 
1263  * bulk-only transport, but _some_ falsely report Control/Bulk instead.
 
1264  * One example is "Trumpion Digital Research MYMP3".
 
1265  * Submitted by Bjoern Brill <brill(at)fs.math.uni-frankfurt.de>
 
1267 UNUSUAL_DEV(  0x090a, 0x1001, 0x0100, 0x0100,
 
1269                 "t33520 USB Flash Card Controller",
 
1270                 US_SC_DEVICE, US_PR_BULK, NULL,
 
1271                 US_FL_NEED_OVERRIDE ),
 
1273 /* Reported by Filippo Bardelli <filibard@libero.it>
 
1274  * The device reports a subclass of RBC, which is wrong.
 
1276 UNUSUAL_DEV(  0x090a, 0x1050, 0x0100, 0x0100,
 
1277                 "Trumpion Microelectronics, Inc.",
 
1278                 "33520 USB Digital Voice Recorder",
 
1279                 US_SC_UFI, US_PR_DEVICE, NULL,
 
1282 /* Trumpion Microelectronics MP3 player (felipe_alfaro@linuxmail.org) */
 
1283 UNUSUAL_DEV( 0x090a, 0x1200, 0x0000, 0x9999,
 
1286                 US_SC_RBC, US_PR_BULK, NULL,
 
1290 UNUSUAL_DEV( 0x090c, 0x1132, 0x0000, 0xffff,
 
1292                 "5-in-1 Card Reader",
 
1293                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1294                 US_FL_FIX_CAPACITY ),
 
1296 /* This Pentax still camera is not conformant
 
1297  * to the USB storage specification: -
 
1298  * - It does not like the INQUIRY command. So we must handle this command
 
1299  *   of the SCSI layer ourselves.
 
1300  * Tested on Rev. 10.00 (0x1000)
 
1301  * Submitted by James Courtier-Dutton <James@superbug.demon.co.uk>
 
1303 UNUSUAL_DEV( 0x0a17, 0x0004, 0x1000, 0x1000,
 
1306                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1307                 US_FL_FIX_INQUIRY ),
 
1310 /* Submitted by Per Winkvist <per.winkvist@uk.com> */
 
1311 UNUSUAL_DEV( 0x0a17, 0x006, 0x0000, 0xffff,
 
1314                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1315                 US_FL_FIX_INQUIRY ),
 
1317 /* These are virtual windows driver CDs, which the zd1211rw driver
 
1318  * automatically converts into WLAN devices. */
 
1319 UNUSUAL_DEV( 0x0ace, 0x2011, 0x0101, 0x0101,
 
1321                 "G-220F USB-WLAN Install",
 
1322                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1323                 US_FL_IGNORE_DEVICE ),
 
1325 UNUSUAL_DEV( 0x0ace, 0x20ff, 0x0101, 0x0101,
 
1327                 "WL-117 USB-WLAN Install",
 
1328                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1329                 US_FL_IGNORE_DEVICE ),
 
1331 /* Reported by F. Aben <f.aben@option.com>
 
1332  * This device (wrongly) has a vendor-specific device descriptor.
 
1333  * The entry is needed so usb-storage can bind to it's mass-storage
 
1334  * interface as an interface driver */
 
1335 UNUSUAL_DEV( 0x0af0, 0x7401, 0x0000, 0x0000,
 
1338                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1341 #ifdef CONFIG_USB_STORAGE_ISD200
 
1342 UNUSUAL_DEV(  0x0bf6, 0xa001, 0x0100, 0x0110,
 
1345                 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
 
1349 #ifdef CONFIG_USB_STORAGE_DATAFAB
 
1350 UNUSUAL_DEV( 0x0c0b, 0xa109, 0x0000, 0xffff,
 
1353                 US_SC_SCSI, US_PR_DATAFAB, NULL,
 
1356 #ifdef CONFIG_USB_STORAGE_SDDR55
 
1357 UNUSUAL_DEV( 0x0c0b, 0xa109, 0x0000, 0xffff,
 
1360                 US_SC_SCSI, US_PR_SDDR55, NULL,
 
1364 /* Submitted by: Nick Sillik <n.sillik@temple.edu>
 
1365  * Needed for OneTouch extension to usb-storage
 
1368 #ifdef CONFIG_USB_STORAGE_ONETOUCH
 
1369         UNUSUAL_DEV(  0x0d49, 0x7000, 0x0000, 0x9999,
 
1371                         "OneTouch External Harddrive",
 
1372                         US_SC_DEVICE, US_PR_DEVICE, onetouch_connect_input,
 
1374         UNUSUAL_DEV(  0x0d49, 0x7010, 0x0000, 0x9999,
 
1376                         "OneTouch External Harddrive",
 
1377                         US_SC_DEVICE, US_PR_DEVICE, onetouch_connect_input,
 
1382  * Pete Zaitcev <zaitcev@yahoo.com>, bz#164688.
 
1383  * The device blatantly ignores LUN and returns 1 in GetMaxLUN.
 
1385 UNUSUAL_DEV( 0x0c45, 0x1060, 0x0100, 0x0100,
 
1388                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1391 /* Submitted by Joris Struyve <joris@struyve.be> */
 
1392 UNUSUAL_DEV( 0x0d96, 0x410a, 0x0001, 0xffff,
 
1395                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1399  * Entry for Jenoptik JD 5200z3
 
1401  * email: car.busse@gmx.de
 
1403 UNUSUAL_DEV(  0x0d96, 0x5200, 0x0001, 0x0200,
 
1406                 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_FIX_INQUIRY),
 
1408 /* Reported by Lubomir Blaha <tritol@trilogic.cz>
 
1409  * I _REALLY_ don't know what 3rd, 4th number and all defines mean, but this
 
1410  * works for me. Can anybody correct these values? (I able to test corrected
 
1413 UNUSUAL_DEV( 0x0dd8, 0x1060, 0x0000, 0xffff,
 
1416                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1417                 US_FL_FIX_INQUIRY ),
 
1419 /* Reported by Edward Chapman (taken from linux-usb mailing list)
 
1420    Netac OnlyDisk Mini U2CV2 512MB USB 2.0 Flash Drive */
 
1421 UNUSUAL_DEV( 0x0dd8, 0xd202, 0x0000, 0x9999,
 
1424                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1425                 US_FL_IGNORE_RESIDUE ),
 
1428 /* Patch by Stephan Walter <stephan.walter@epfl.ch>
 
1429  * I don't know why, but it works... */
 
1430 UNUSUAL_DEV( 0x0dda, 0x0001, 0x0012, 0x0012,
 
1433                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1434                 US_FL_IGNORE_RESIDUE ),
 
1436 /* Reported by Ian McConnell <ian at emit.demon.co.uk> */
 
1437 UNUSUAL_DEV(  0x0dda, 0x0301, 0x0012, 0x0012,
 
1440                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1441                 US_FL_IGNORE_RESIDUE ),
 
1443 /* Reported by Jim McCloskey <mcclosk@ucsc.edu> */
 
1444 UNUSUAL_DEV( 0x0e21, 0x0520, 0x0100, 0x0100,
 
1447                 US_SC_DEVICE, US_PR_BULK, NULL,
 
1448                 US_FL_NEED_OVERRIDE ),
 
1450 /* Submitted by Antoine Mairesse <antoine.mairesse@free.fr> */
 
1451 UNUSUAL_DEV( 0x0ed1, 0x6660, 0x0100, 0x0300,
 
1454                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1455                 US_FL_FIX_INQUIRY ),
 
1457 /* Submitted by Daniel Drake <dsd@gentoo.org>
 
1458  * Reported by dayul on the Gentoo Forums */
 
1459 UNUSUAL_DEV(  0x0ea0, 0x2168, 0x0110, 0x0110,
 
1462                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1463                 US_FL_IGNORE_RESIDUE ),
 
1465 /* Reported by Rastislav Stanik <rs_kernel@yahoo.com> */
 
1466 UNUSUAL_DEV(  0x0ea0, 0x6828, 0x0110, 0x0110,
 
1469                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1470                 US_FL_IGNORE_RESIDUE ),
 
1472 /* Reported by Benjamin Schiller <sbenni@gmx.de>
 
1473  * It is also sold by Easylite as DJ 20 */
 
1474 UNUSUAL_DEV(  0x0ed1, 0x7636, 0x0103, 0x0103,
 
1477                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1478                 US_FL_IGNORE_RESIDUE | US_FL_GO_SLOW | US_FL_MAX_SECTORS_64),
 
1480 /* Patch by Leonid Petrov mail at lpetrov.net
 
1481  * Reported by Robert Spitzenpfeil <robert@spitzenpfeil.org>
 
1482  * http://www.qbik.ch/usb/devices/showdev.php?id=1705
 
1483  * Updated to 103 device by MJ Ray mjr at phonecoop.coop
 
1485 UNUSUAL_DEV(  0x0f19, 0x0103, 0x0100, 0x0100,
 
1488                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1489                 US_FL_IGNORE_RESIDUE ),
 
1491 /* David Kuehling <dvdkhlng@gmx.de>:
 
1492  * for MP3-Player AVOX WSX-300ER (bought in Japan).  Reports lots of SCSI
 
1493  * errors when trying to write.
 
1495 UNUSUAL_DEV(  0x0f19, 0x0105, 0x0100, 0x0100,
 
1498                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1499                 US_FL_IGNORE_RESIDUE ),
 
1501 /* Jeremy Katz <katzj@redhat.com>:
 
1502  * The Blackberry Pearl can run in two modes; a usb-storage only mode
 
1503  * and a mode that allows access via mass storage and to its database.
 
1504  * The berry_charge module will set the device to dual mode and thus we
 
1505  * should ignore its native mode if that module is built
 
1507 #ifdef CONFIG_USB_BERRY_CHARGE
 
1508 UNUSUAL_DEV(  0x0fca, 0x0006, 0x0001, 0x0001,
 
1511                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1512                 US_FL_IGNORE_DEVICE ),
 
1515 /* Reported by Michael Stattmann <michael@stattmann.com> */
 
1516 UNUSUAL_DEV(  0x0fce, 0xd008, 0x0000, 0x0000,
 
1518                 "V800-Vodafone 802",
 
1519                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1520                 US_FL_NO_WP_DETECT ),
 
1522 /* Reported by Jan Mate <mate@fiit.stuba.sk>
 
1523  * and by Soeren Sonnenburg <kernel@nn7.de> */
 
1524 UNUSUAL_DEV(  0x0fce, 0xe030, 0x0000, 0x0000,
 
1527                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1528                 US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
 
1530 /* Reported by Ricardo Barberis <ricardo@dattatec.com> */
 
1531 UNUSUAL_DEV(  0x0fce, 0xe092, 0x0000, 0x0000,
 
1534                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1535                 US_FL_IGNORE_RESIDUE ),
 
1537 /* Reported by Emmanuel Vasilakis <evas@forthnet.gr> */
 
1538 UNUSUAL_DEV(  0x0fce, 0xe031, 0x0000, 0x0000,
 
1541                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1542                 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
 
1544 /* Reported by Kevin Cernekee <kpc-usbdev@gelato.uiuc.edu>
 
1545  * Tested on hardware version 1.10.
 
1546  * Entry is needed only for the initializer function override.
 
1547  * Devices with bcd > 110 seem to not need it while those
 
1548  * with bcd < 110 appear to need it.
 
1550 UNUSUAL_DEV(  0x1019, 0x0c55, 0x0000, 0x0110,
 
1553                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_ucr61s2b_init,
 
1556 /* Reported by Fabio Venturi <f.venturi@tdnet.it>
 
1557  * The device reports a vendor-specific bDeviceClass.
 
1559 UNUSUAL_DEV(  0x10d6, 0x2200, 0x0100, 0x0100,
 
1560                 "Actions Semiconductor",
 
1562                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1565 /* Reported by Kevin Lloyd <linux@sierrawireless.com>
 
1566  * Entry is needed for the initializer function override,
 
1567  * which instructs the device to load as a modem
 
1570 UNUSUAL_DEV(  0x1199, 0x0fff, 0x0000, 0x9999,
 
1573                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1574                 US_FL_IGNORE_DEVICE),
 
1576 /* Reported by Jaco Kroon <jaco@kroon.co.za>
 
1577  * The usb-storage module found on the Digitech GNX4 (and supposedly other
 
1578  * devices) misbehaves and causes a bunch of invalid I/O errors.
 
1580 UNUSUAL_DEV(  0x1210, 0x0003, 0x0100, 0x0100,
 
1582                 "DigiTech Mass Storage",
 
1583                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1584                 US_FL_IGNORE_RESIDUE ),
 
1586 /* Reported by fangxiaozhi <huananhu@huawei.com>
 
1587  * This brings the HUAWEI data card devices into multi-port mode
 
1589 UNUSUAL_DEV( 0x12d1, 0x1001, 0x0000, 0x0000,
 
1592                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1594 UNUSUAL_DEV( 0x12d1, 0x1003, 0x0000, 0x0000,
 
1597                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1599 UNUSUAL_DEV( 0x12d1, 0x1004, 0x0000, 0x0000,
 
1602                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1604 UNUSUAL_DEV( 0x12d1, 0x1401, 0x0000, 0x0000,
 
1607                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1609 UNUSUAL_DEV( 0x12d1, 0x1403, 0x0000, 0x0000,
 
1612                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1614 UNUSUAL_DEV( 0x12d1, 0x1405, 0x0000, 0x0000,
 
1617                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1619 UNUSUAL_DEV( 0x12d1, 0x1406, 0x0000, 0x0000,
 
1622                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1624 UNUSUAL_DEV( 0x12d1, 0x1408, 0x0000, 0x0000,
 
1627                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1629 UNUSUAL_DEV( 0x12d1, 0x1409, 0x0000, 0x0000,
 
1632                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1634 UNUSUAL_DEV( 0x12d1, 0x1410, 0x0000, 0x0000,
 
1637                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1639 UNUSUAL_DEV( 0x12d1, 0x1411, 0x0000, 0x0000,
 
1642                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1644 UNUSUAL_DEV( 0x12d1, 0x1412, 0x0000, 0x0000,
 
1647                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1649 UNUSUAL_DEV( 0x12d1, 0x1413, 0x0000, 0x0000,
 
1652                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1654 UNUSUAL_DEV( 0x12d1, 0x1414, 0x0000, 0x0000,
 
1657                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1659 UNUSUAL_DEV( 0x12d1, 0x1415, 0x0000, 0x0000,
 
1662                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1664 UNUSUAL_DEV( 0x12d1, 0x1416, 0x0000, 0x0000,
 
1667                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1669 UNUSUAL_DEV( 0x12d1, 0x1417, 0x0000, 0x0000,
 
1672                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1674 UNUSUAL_DEV( 0x12d1, 0x1418, 0x0000, 0x0000,
 
1677                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1679 UNUSUAL_DEV( 0x12d1, 0x1419, 0x0000, 0x0000,
 
1682                 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
 
1685 /* Reported by Vilius Bilinkevicius <vilisas AT xxx DOT lt) */
 
1686 UNUSUAL_DEV(  0x132b, 0x000b, 0x0001, 0x0001,
 
1689                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1692 /* Reported by Kotrla Vitezslav <kotrla@ceb.cz> */
 
1693 UNUSUAL_DEV(  0x1370, 0x6828, 0x0110, 0x0110,
 
1696                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1697                 US_FL_IGNORE_RESIDUE ),
 
1699 /* Reported by Francesco Foresti <frafore@tiscali.it> */
 
1700 UNUSUAL_DEV(  0x14cd, 0x6600, 0x0201, 0x0201,
 
1703                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1704                 US_FL_IGNORE_RESIDUE ),
 
1706 /* Reported by Robert Schedel <r.schedel@yahoo.de>
 
1707  * Note: this is a 'super top' device like the above 14cd/6600 device */
 
1708 UNUSUAL_DEV(  0x1652, 0x6600, 0x0201, 0x0201,
 
1711                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1712                 US_FL_IGNORE_RESIDUE ),
 
1714 /* Reported by Mauro Andreolini <andreoli@weblab.ing.unimo.it>
 
1715  * This entry is needed to bypass the ZeroCD mechanism
 
1716  * and to properly load as a modem device.
 
1718 UNUSUAL_DEV(  0x19d2, 0x2000, 0x0000, 0x0000,
 
1721                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1722                 US_FL_IGNORE_DEVICE),
 
1724 /* patch submitted by Davide Perini <perini.davide@dpsoftware.org>
 
1725  * and Renato Perini <rperini@email.it>
 
1727 UNUSUAL_DEV(  0x22b8, 0x3010, 0x0001, 0x0001,
 
1730                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1731                 US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
 
1734  * Patch by Pete Zaitcev <zaitcev@redhat.com>
 
1735  * Report by Mark Patton. Red Hat bz#208928.
 
1736  * Added support for rev 0x0002 (Motorola ROKR W5)
 
1737  * by Javier Smaldone <javier@smaldone.com.ar>
 
1739 UNUSUAL_DEV(  0x22b8, 0x4810, 0x0001, 0x0002,
 
1742                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1743                 US_FL_FIX_CAPACITY),
 
1746  * Patch by Constantin Baranov <const@tltsu.ru>
 
1747  * Report by Andreas Koenecke.
 
1750 UNUSUAL_DEV(  0x22b8, 0x6426, 0x0101, 0x0101,
 
1753                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1754                 US_FL_FIX_INQUIRY | US_FL_FIX_CAPACITY | US_FL_BULK_IGNORE_TAG),
 
1756 /* Reported by Radovan Garabik <garabik@kassiopeia.juls.savba.sk> */
 
1757 UNUSUAL_DEV(  0x2735, 0x100b, 0x0000, 0x9999,
 
1760                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1763 /* Reported by Rohan Hart <rohan.hart17@gmail.com> */
 
1764 UNUSUAL_DEV(  0x2770, 0x915d, 0x0010, 0x0010,
 
1767                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1768                 US_FL_FIX_CAPACITY ),
 
1771  * David Härdeman <david@2gen.com>
 
1772  * The key makes the SCSI stack print confusing (but harmless) messages
 
1774 UNUSUAL_DEV(  0x4146, 0xba01, 0x0100, 0x0100,
 
1777                 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_NOT_LOCKABLE ),
 
1779 #ifdef CONFIG_USB_STORAGE_SDDR55
 
1780 UNUSUAL_DEV(  0x55aa, 0xa103, 0x0000, 0x9999, 
 
1783                 US_SC_SCSI, US_PR_SDDR55, NULL,
 
1787 /* Reported by Andrew Simmons <andrew.simmons@gmail.com> */
 
1788 UNUSUAL_DEV(  0xed06, 0x4500, 0x0001, 0x0001,
 
1791                 US_SC_DEVICE, US_PR_DEVICE, NULL,
 
1792                 US_FL_CAPACITY_HEURISTICS),
 
1794 /* Control/Bulk transport for all SubClass values */
 
1795 USUAL_DEV(US_SC_RBC, US_PR_CB, USB_US_TYPE_STOR),
 
1796 USUAL_DEV(US_SC_8020, US_PR_CB, USB_US_TYPE_STOR),
 
1797 USUAL_DEV(US_SC_QIC, US_PR_CB, USB_US_TYPE_STOR),
 
1798 USUAL_DEV(US_SC_UFI, US_PR_CB, USB_US_TYPE_STOR),
 
1799 USUAL_DEV(US_SC_8070, US_PR_CB, USB_US_TYPE_STOR),
 
1800 USUAL_DEV(US_SC_SCSI, US_PR_CB, USB_US_TYPE_STOR),
 
1802 /* Control/Bulk/Interrupt transport for all SubClass values */
 
1803 USUAL_DEV(US_SC_RBC, US_PR_CBI, USB_US_TYPE_STOR),
 
1804 USUAL_DEV(US_SC_8020, US_PR_CBI, USB_US_TYPE_STOR),
 
1805 USUAL_DEV(US_SC_QIC, US_PR_CBI, USB_US_TYPE_STOR),
 
1806 USUAL_DEV(US_SC_UFI, US_PR_CBI, USB_US_TYPE_STOR),
 
1807 USUAL_DEV(US_SC_8070, US_PR_CBI, USB_US_TYPE_STOR),
 
1808 USUAL_DEV(US_SC_SCSI, US_PR_CBI, USB_US_TYPE_STOR),
 
1810 /* Bulk-only transport for all SubClass values */
 
1811 USUAL_DEV(US_SC_RBC, US_PR_BULK, USB_US_TYPE_STOR),
 
1812 USUAL_DEV(US_SC_8020, US_PR_BULK, USB_US_TYPE_STOR),
 
1813 USUAL_DEV(US_SC_QIC, US_PR_BULK, USB_US_TYPE_STOR),
 
1814 USUAL_DEV(US_SC_UFI, US_PR_BULK, USB_US_TYPE_STOR),
 
1815 USUAL_DEV(US_SC_8070, US_PR_BULK, USB_US_TYPE_STOR),
 
1816 USUAL_DEV(US_SC_SCSI, US_PR_BULK, 0),