blob: 856ad92c40de9b603b4f11c2e362c12eb2d06eb6 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/* Driver for USB Mass Storage compliant devices
Steven Cole093cf722005-05-03 19:07:24 -06002 * Unusual Devices File
Linus Torvalds1da177e2005-04-16 15:20:36 -07003 *
Linus Torvalds1da177e2005-04-16 15:20:36 -07004 * Current development and maintenance by:
5 * (c) 2000-2002 Matthew Dharm (mdharm-usb@one-eyed-alien.net)
6 *
7 * Initial work by:
8 * (c) 2000 Adam J. Richter (adam@yggdrasil.com), Yggdrasil Computing, Inc.
9 *
10 * Please see http://www.one-eyed-alien.net/~mdharm/linux-usb for more
11 * information about this driver.
12 *
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
16 * later version.
17 *
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.
22 *
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.
26 */
27
28/* IMPORTANT NOTE: This file must be included in another file which does
29 * the following thing for it to work:
Alan Stern25ff1c32008-12-15 12:43:41 -050030 * The UNUSUAL_DEV, COMPLIANT_DEV, and USUAL_DEV macros must be defined
31 * before this file is included.
Linus Torvalds1da177e2005-04-16 15:20:36 -070032 */
Linus Torvalds1da177e2005-04-16 15:20:36 -070033
34/* If you edit this file, please try to keep it sorted first by VendorID,
35 * then by ProductID.
36 *
37 * If you want to add an entry for this file, be sure to include the
38 * following information:
39 * - a patch that adds the entry for your device, including your
40 * email address right above the entry (plus maybe a brief
41 * explanation of the reason for the entry),
42 * - a copy of /proc/bus/usb/devices with your device plugged in
43 * running with this patch.
44 * Send your submission to either Phil Dibowitz <phil@ipom.com> or
45 * Alan Stern <stern@rowland.harvard.edu>, and don't forget to CC: the
Andrew Lunncef03f82008-04-23 22:04:30 +020046 * USB development list <linux-usb@vger.kernel.org> and the USB storage list
47 * <usb-storage@lists.one-eyed-alien.net>
Linus Torvalds1da177e2005-04-16 15:20:36 -070048 */
49
Alan Stern25ff1c32008-12-15 12:43:41 -050050/* Note: If you add an entry only in order to set the CAPACITY_OK flag,
51 * use the COMPLIANT_DEV macro instead of UNUSUAL_DEV. This is
52 * because such entries mark devices which actually work correctly,
53 * as opposed to devices that do something strangely or wrongly.
54 */
55
Alan Stern0ff71882009-02-12 14:47:49 -050056#if !defined(CONFIG_USB_STORAGE_SDDR09) && \
57 !defined(CONFIG_USB_STORAGE_SDDR09_MODULE)
58#define NO_SDDR09
59#endif
60
Vivian Bregier8af60be2005-05-03 02:16:34 +020061/* patch submitted by Vivian Bregier <Vivian.Bregier@imag.fr>
62 */
63UNUSUAL_DEV( 0x03eb, 0x2002, 0x0100, 0x0100,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -070064 "ATMEL",
65 "SND1 Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +020066 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -070067 US_FL_IGNORE_RESIDUE),
Vivian Bregier8af60be2005-05-03 02:16:34 +020068
Rodolfo Quesada9d5847b2006-03-06 10:45:42 -050069/* Reported by Rodolfo Quesada <rquesada@roqz.net> */
70UNUSUAL_DEV( 0x03ee, 0x6906, 0x0003, 0x0003,
71 "VIA Technologies Inc.",
72 "Mitsumi multi cardreader",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +020073 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Rodolfo Quesada9d5847b2006-03-06 10:45:42 -050074 US_FL_IGNORE_RESIDUE ),
75
S.Caglar Onurc0e0c192007-07-04 13:52:47 -070076UNUSUAL_DEV( 0x03f0, 0x0107, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -070077 "HP",
78 "CD-Writer+",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +020079 USB_SC_8070, USB_PR_CB, NULL, 0),
Linus Torvalds1da177e2005-04-16 15:20:36 -070080
Ben Efrosdbe6e0c02008-11-23 20:06:38 -080081/* Reported by Ben Efros <ben@pc-doctor.com> */
82UNUSUAL_DEV( 0x03f0, 0x070c, 0x0000, 0x0000,
83 "HP",
84 "Personal Media Drive",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +020085 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Ben Efrosdbe6e0c02008-11-23 20:06:38 -080086 US_FL_SANE_SENSE ),
87
Grant Grundler4b24f912008-01-23 21:31:03 -080088/* Reported by Grant Grundler <grundler@parisc-linux.org>
89 * HP r707 camera in "Disk" mode with 2.00.23 or 2.00.24 firmware.
90 */
91UNUSUAL_DEV( 0x03f0, 0x4002, 0x0001, 0x0001,
92 "HP",
93 "PhotoSmart R707",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +020094 USB_SC_DEVICE, USB_PR_DEVICE, NULL, US_FL_FIX_CAPACITY),
Grant Grundler4b24f912008-01-23 21:31:03 -080095
Phil Dibowitz1ea640c2005-08-29 22:38:28 -070096/* 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.
99 */
100UNUSUAL_DEV( 0x0409, 0x0040, 0x0000, 0x9999,
101 "NEC",
102 "NEC USB UF000x",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200103 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Phil Dibowitz1ea640c2005-08-29 22:38:28 -0700104 US_FL_SINGLE_LUN ),
105
Phil Dibowitz3e220e92005-12-18 21:30:02 -0800106/* Patch submitted by Mihnea-Costin Grigore <mihnea@zulu.ro> */
107UNUSUAL_DEV( 0x040d, 0x6205, 0x0003, 0x0003,
108 "VIA Technologies Inc.",
109 "USB 2.0 Card Reader",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200110 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Phil Dibowitz3e220e92005-12-18 21:30:02 -0800111 US_FL_IGNORE_RESIDUE ),
112
Linus Torvalds1da177e2005-04-16 15:20:36 -0700113/* 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.
116 */
117UNUSUAL_DEV( 0x0411, 0x001c, 0x0113, 0x0113,
118 "Buffalo",
119 "DUB-P40G HDD",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200120 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700121 US_FL_FIX_INQUIRY ),
122
Ernisd8840d62006-06-26 16:02:43 -0400123/* Submitted by Ernestas Vaiciukevicius <ernisv@gmail.com> */
124UNUSUAL_DEV( 0x0419, 0x0100, 0x0100, 0x0100,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700125 "Samsung Info. Systems America, Inc.",
126 "MP3 Player",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200127 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700128 US_FL_IGNORE_RESIDUE ),
Ernisd8840d62006-06-26 16:02:43 -0400129
Phil Dibowitz5501a482006-07-04 12:46:43 -0700130/* Reported by Orgad Shaneh <orgads@gmail.com> */
131UNUSUAL_DEV( 0x0419, 0xaace, 0x0100, 0x0100,
132 "Samsung", "MP3 Player",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200133 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Phil Dibowitz5501a482006-07-04 12:46:43 -0700134 US_FL_IGNORE_RESIDUE ),
135
Alan Stern1d614a42006-02-13 10:15:22 -0500136/* Reported by Christian Leber <christian@leber.de> */
137UNUSUAL_DEV( 0x0419, 0xaaf5, 0x0100, 0x0100,
138 "TrekStor",
139 "i.Beat 115 2.0",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200140 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Stern1d614a42006-02-13 10:15:22 -0500141 US_FL_IGNORE_RESIDUE | US_FL_NOT_LOCKABLE ),
142
Phil Dibowitze4a16e02005-09-30 00:20:15 -0700143/* Reported by Stefan Werner <dustbln@gmx.de> */
144UNUSUAL_DEV( 0x0419, 0xaaf6, 0x0100, 0x0100,
145 "TrekStor",
146 "i.Beat Joy 2.0",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200147 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Phil Dibowitze4a16e02005-09-30 00:20:15 -0700148 US_FL_IGNORE_RESIDUE ),
149
Pete Zaitcev23b78852006-03-05 21:45:44 -0800150/* Reported by Pete Zaitcev <zaitcev@redhat.com>, bz#176584 */
151UNUSUAL_DEV( 0x0420, 0x0001, 0x0100, 0x0100,
152 "GENERIC", "MP3 PLAYER", /* MyMusix PD-205 on the outside. */
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200153 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Pete Zaitcev23b78852006-03-05 21:45:44 -0800154 US_FL_IGNORE_RESIDUE ),
155
Phil Dibowitz031defd2009-04-26 12:47:51 +0200156/* Reported by Andrew Nayenko <relan@bk.ru>
157 * Updated for new firmware by Phillip Potter <phillipinda@hotmail.com> */
158UNUSUAL_DEV( 0x0421, 0x0019, 0x0592, 0x0610,
Andrew Nayenko0d8c7ae2007-02-25 00:40:20 -0800159 "Nokia",
160 "Nokia 6288",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200161 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Andrew Nayenko0d8c7ae2007-02-25 00:40:20 -0800162 US_FL_MAX_SECTORS_64 ),
163
Alan Sternde1caa42006-07-31 10:10:28 -0400164/* Reported by Mario Rettig <mariorettig@web.de> */
165UNUSUAL_DEV( 0x0421, 0x042e, 0x0100, 0x0100,
166 "Nokia",
167 "Nokia 3250",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200168 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Sternde1caa42006-07-31 10:10:28 -0400169 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
170
Andrew Mortonfe1ec342006-12-04 15:22:40 -0800171/* Reported by <honkkis@gmail.com> */
172UNUSUAL_DEV( 0x0421, 0x0433, 0x0100, 0x0100,
173 "Nokia",
174 "E70",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200175 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Andrew Mortonfe1ec342006-12-04 15:22:40 -0800176 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
177
Alan Stern79238112006-09-28 12:11:56 -0400178/* Reported by Jon Hart <Jon.Hart@web.de> */
179UNUSUAL_DEV( 0x0421, 0x0434, 0x0100, 0x0100,
180 "Nokia",
181 "E60",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200182 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Stern79238112006-09-28 12:11:56 -0400183 US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
184
Alan Stern9a013552006-07-07 13:45:13 -0400185/* Reported by Sumedha Swamy <sumedhaswamy@gmail.com> and
186 * Einar Th. Einarsson <einarthered@gmail.com> */
187UNUSUAL_DEV( 0x0421, 0x0444, 0x0100, 0x0100,
188 "Nokia",
189 "N91",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200190 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Stern9a013552006-07-07 13:45:13 -0400191 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
192
Alan Sternd5681fe2006-06-13 09:59:32 -0400193/* Reported by Jiri Slaby <jirislaby@gmail.com> and
194 * Rene C. Castberg <Rene@Castberg.org> */
195UNUSUAL_DEV( 0x0421, 0x0446, 0x0100, 0x0100,
196 "Nokia",
197 "N80",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200198 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Sternd5681fe2006-06-13 09:59:32 -0400199 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
200
Alan Stern57b01b12006-07-10 11:51:12 -0400201/* Reported by Matthew Bloch <matthew@bytemark.co.uk> */
202UNUSUAL_DEV( 0x0421, 0x044e, 0x0100, 0x0100,
203 "Nokia",
204 "E61",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200205 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Stern57b01b12006-07-10 11:51:12 -0400206 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
207
Alan Sterne4a20da2006-10-04 16:31:15 -0400208/* Reported by Bardur Arantsson <bardur@scientician.net> */
Alan Stern393e5512007-09-18 10:09:32 -0400209UNUSUAL_DEV( 0x0421, 0x047c, 0x0370, 0x0610,
Alan Sterne4a20da2006-10-04 16:31:15 -0400210 "Nokia",
211 "6131",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200212 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Sterne4a20da2006-10-04 16:31:15 -0400213 US_FL_MAX_SECTORS_64 ),
214
Manuel Osdoba39559b42007-01-18 21:28:45 +0100215/* Reported by Manuel Osdoba <manuel.osdoba@tu-ilmenau.de> */
Moritz Muehlenhoff716a9c82009-03-14 00:43:21 +0100216UNUSUAL_DEV( 0x0421, 0x0492, 0x0452, 0x9999,
Manuel Osdoba39559b42007-01-18 21:28:45 +0100217 "Nokia",
218 "Nokia 6233",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200219 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Manuel Osdoba39559b42007-01-18 21:28:45 +0100220 US_FL_MAX_SECTORS_64 ),
221
Alan Stern3ccf25c2006-10-13 09:59:17 -0400222/* Reported by Alex Corcoles <alex@corcoles.net> */
223UNUSUAL_DEV( 0x0421, 0x0495, 0x0370, 0x0370,
224 "Nokia",
225 "6234",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200226 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Stern3ccf25c2006-10-13 09:59:17 -0400227 US_FL_MAX_SECTORS_64 ),
228
Alan Stern0ff71882009-02-12 14:47:49 -0500229#ifdef NO_SDDR09
Alan Sternc20b15f2008-12-01 10:36:15 -0500230UNUSUAL_DEV( 0x0436, 0x0005, 0x0100, 0x0100,
231 "Microtech",
232 "CameraMate",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200233 USB_SC_SCSI, USB_PR_CB, NULL,
Alan Sternc20b15f2008-12-01 10:36:15 -0500234 US_FL_SINGLE_LUN ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700235#endif
236
Phil Dibowitz16f05be2006-02-13 15:59:42 -0800237/* Patch submitted by Daniel Drake <dsd@gentoo.org>
238 * Device reports nonsense bInterfaceProtocol 6 when connected over USB2 */
239UNUSUAL_DEV( 0x0451, 0x5416, 0x0100, 0x0100,
240 "Neuros Audio",
241 "USB 2.0 HD 2.5",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200242 USB_SC_DEVICE, USB_PR_BULK, NULL,
Phil Dibowitz16f05be2006-02-13 15:59:42 -0800243 US_FL_NEED_OVERRIDE ),
244
Pete Zaitcev490dce12005-08-23 07:46:13 -0700245/*
246 * Pete Zaitcev <zaitcev@yahoo.com>, from Patrick C. F. Ernzer, bz#162559.
247 * The key does not actually break, but it returns zero sense which
248 * makes our SCSI stack to print confusing messages.
249 */
250UNUSUAL_DEV( 0x0457, 0x0150, 0x0100, 0x0100,
251 "USBest Technology", /* sold by Transcend */
252 "USB Mass Storage Device",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200253 USB_SC_DEVICE, USB_PR_DEVICE, NULL, US_FL_NOT_LOCKABLE ),
Pete Zaitcev490dce12005-08-23 07:46:13 -0700254
Phil Dibowitz16f05be2006-02-13 15:59:42 -0800255/*
256* Bohdan Linda <bohdan.linda@gmail.com>
257* 1GB USB sticks MyFlash High Speed. I have restricted
258* the revision to my model only
259*/
260UNUSUAL_DEV( 0x0457, 0x0151, 0x0100, 0x0100,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700261 "USB 2.0",
262 "Flash Disk",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200263 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700264 US_FL_NOT_LOCKABLE ),
Daniel Drakee1c37b82005-08-31 16:38:41 +0100265
Alan Sterna6b7b032008-11-21 16:15:12 -0500266/* Reported by Tamas Kerecsen <kerecsen@bigfoot.com>
267 * Obviously the PROM has not been customized by the VAR;
268 * the Vendor and Product string descriptors are:
269 * Generic Mass Storage (PROTOTYPE--Remember to change idVendor)
270 * Generic Manufacturer (PROTOTYPE--Remember to change idVendor)
271 */
272UNUSUAL_DEV( 0x045e, 0xffff, 0x0000, 0x0000,
273 "Mitac",
274 "GPS",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200275 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Sterna6b7b032008-11-21 16:15:12 -0500276 US_FL_MAX_SECTORS_64 ),
277
Pete Zaitcev379885a2007-01-13 15:17:46 -0800278/*
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.
283 */
284UNUSUAL_DEV( 0x046b, 0xff40, 0x0100, 0x0100,
285 "AMI",
286 "Virtual Floppy",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200287 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Pete Zaitcev379885a2007-01-13 15:17:46 -0800288 US_FL_NO_WP_DETECT),
289
Linus Torvalds1da177e2005-04-16 15:20:36 -0700290/* Patch submitted by Philipp Friedrich <philipp@void.at> */
291UNUSUAL_DEV( 0x0482, 0x0100, 0x0100, 0x0100,
292 "Kyocera",
293 "Finecam S3x",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200294 USB_SC_8070, USB_PR_CB, NULL, US_FL_FIX_INQUIRY),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700295
296/* Patch submitted by Philipp Friedrich <philipp@void.at> */
297UNUSUAL_DEV( 0x0482, 0x0101, 0x0100, 0x0100,
298 "Kyocera",
299 "Finecam S4",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200300 USB_SC_8070, USB_PR_CB, NULL, US_FL_FIX_INQUIRY),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700301
302/* Patch submitted by Stephane Galles <stephane.galles@free.fr> */
303UNUSUAL_DEV( 0x0482, 0x0103, 0x0100, 0x0100,
304 "Kyocera",
305 "Finecam S5",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200306 USB_SC_DEVICE, USB_PR_DEVICE, NULL, US_FL_FIX_INQUIRY),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700307
Jens Taprogge74511bb2008-10-26 18:16:09 +0100308/* Patch submitted by Jens Taprogge <jens.taprogge@taprogge.org> */
309UNUSUAL_DEV( 0x0482, 0x0107, 0x0100, 0x0100,
310 "Kyocera",
311 "CONTAX SL300R T*",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200312 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jens Taprogge74511bb2008-10-26 18:16:09 +0100313 US_FL_FIX_CAPACITY | US_FL_NOT_LOCKABLE),
314
Linus Torvalds1da177e2005-04-16 15:20:36 -0700315/* Reported by Paul Stewart <stewart@wetlogic.net>
316 * This entry is needed because the device reports Sub=ff */
317UNUSUAL_DEV( 0x04a4, 0x0004, 0x0001, 0x0001,
318 "Hitachi",
319 "DVD-CAM DZ-MV100A Camcorder",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200320 USB_SC_SCSI, USB_PR_CB, NULL, US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700321
Alan Sternf9dc8f92008-11-18 14:08:07 -0500322/* BENQ DC5330
323 * Reported by Manuel Fombuena <mfombuena@ya.com> and
324 * Frank Copeland <fjc@thingy.apana.org.au> */
325UNUSUAL_DEV( 0x04a5, 0x3010, 0x0100, 0x0100,
326 "Tekom Technologies, Inc",
327 "300_CAMERA",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200328 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Sternf9dc8f92008-11-18 14:08:07 -0500329 US_FL_IGNORE_RESIDUE ),
330
fabien COSSE17fa6e52005-11-30 01:16:00 -0800331/* Patch for Nikon coolpix 2000
332 * Submitted by Fabien Cosse <fabien.cosse@wanadoo.fr>*/
333UNUSUAL_DEV( 0x04b0, 0x0301, 0x0010, 0x0010,
334 "NIKON",
335 "NIKON DSC E2000",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200336 USB_SC_DEVICE, USB_PR_DEVICE,NULL,
fabien COSSE17fa6e52005-11-30 01:16:00 -0800337 US_FL_NOT_LOCKABLE ),
338
Doug Maxey33abc042007-12-05 23:36:45 -0600339/* Reported by Doug Maxey (dwm@austin.ibm.com) */
340UNUSUAL_DEV( 0x04b3, 0x4001, 0x0110, 0x0110,
341 "IBM",
342 "IBM RSA2",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200343 USB_SC_DEVICE, USB_PR_CB, NULL,
Doug Maxey33abc042007-12-05 23:36:45 -0600344 US_FL_MAX_SECTORS_MIN),
345
Linus Torvalds1da177e2005-04-16 15:20:36 -0700346/* Reported by Simon Levitt <simon@whattf.com>
347 * This entry needs Sub and Proto fields */
348UNUSUAL_DEV( 0x04b8, 0x0601, 0x0100, 0x0100,
349 "Epson",
350 "875DC Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200351 USB_SC_SCSI, USB_PR_CB, NULL, US_FL_FIX_INQUIRY),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700352
353/* Reported by Khalid Aziz <khalid@gonehiking.org>
354 * This entry is needed because the device reports Sub=ff */
355UNUSUAL_DEV( 0x04b8, 0x0602, 0x0110, 0x0110,
356 "Epson",
357 "785EPX Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200358 USB_SC_SCSI, USB_PR_BULK, NULL, US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700359
360/* Not sure who reported this originally but
361 * Pavel Machek <pavel@ucw.cz> reported that the extra US_FL_SINGLE_LUN
362 * flag be added */
363UNUSUAL_DEV( 0x04cb, 0x0100, 0x0000, 0x2210,
364 "Fujifilm",
365 "FinePix 1400Zoom",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200366 USB_SC_UFI, USB_PR_DEVICE, NULL, US_FL_FIX_INQUIRY | US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700367
Ondrej Zarycd0e8aa2010-02-27 22:56:28 +0100368/* Reported by Ondrej Zary <linux@rainbow-software.org>
369 * The device reports one sector more and breaks when that sector is accessed
370 */
371UNUSUAL_DEV( 0x04ce, 0x0002, 0x026c, 0x026c,
372 "ScanLogic",
373 "SL11R-IDE",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200374 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Ondrej Zarycd0e8aa2010-02-27 22:56:28 +0100375 US_FL_FIX_CAPACITY),
376
Linus Torvalds1da177e2005-04-16 15:20:36 -0700377/* Reported by Kriston Fincher <kriston@airmail.net>
378 * Patch submitted by Sean Millichamp <sean@bruenor.org>
379 * This is to support the Panasonic PalmCam PV-SD4090
380 * This entry is needed because the device reports Sub=ff
381 */
382UNUSUAL_DEV( 0x04da, 0x0901, 0x0100, 0x0200,
383 "Panasonic",
384 "LS-120 Camera",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200385 USB_SC_UFI, USB_PR_DEVICE, NULL, 0),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700386
387/* From Yukihiro Nakai, via zaitcev@yahoo.com.
388 * This is needed for CB instead of CBI */
389UNUSUAL_DEV( 0x04da, 0x0d05, 0x0000, 0x0000,
390 "Sharp CE-CW05",
391 "CD-R/RW Drive",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200392 USB_SC_8070, USB_PR_CB, NULL, 0),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700393
394/* Reported by Adriaan Penning <a.penning@luon.net> */
395UNUSUAL_DEV( 0x04da, 0x2372, 0x0000, 0x9999,
396 "Panasonic",
397 "DMC-LCx Camera",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200398 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700399 US_FL_FIX_CAPACITY | US_FL_NOT_LOCKABLE ),
400
Simeon Simeonovdcab4ea2005-10-19 11:32:14 -0400401/* Reported by Simeon Simeonov <simeonov_2000@yahoo.com> */
402UNUSUAL_DEV( 0x04da, 0x2373, 0x0000, 0x9999,
403 "LEICA",
404 "D-LUX Camera",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200405 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Simeon Simeonovdcab4ea2005-10-19 11:32:14 -0400406 US_FL_FIX_CAPACITY | US_FL_NOT_LOCKABLE ),
407
Linus Torvalds1da177e2005-04-16 15:20:36 -0700408/* Most of the following entries were developed with the help of
409 * Shuttle/SCM directly.
410 */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700411UNUSUAL_DEV( 0x04e6, 0x0001, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700412 "Matshita",
413 "LS-120",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200414 USB_SC_8020, USB_PR_CB, NULL, 0),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700415
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700416UNUSUAL_DEV( 0x04e6, 0x0002, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700417 "Shuttle",
418 "eUSCSI Bridge",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200419 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_euscsi_init,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700420 US_FL_SCM_MULT_TARG ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700421
Alan Stern0ff71882009-02-12 14:47:49 -0500422#ifdef NO_SDDR09
Alan Sternc20b15f2008-12-01 10:36:15 -0500423UNUSUAL_DEV( 0x04e6, 0x0005, 0x0100, 0x0208,
424 "SCM Microsystems",
425 "eUSB CompactFlash Adapter",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200426 USB_SC_SCSI, USB_PR_CB, NULL,
Alan Sternc20b15f2008-12-01 10:36:15 -0500427 US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700428#endif
429
430/* Reported by Markus Demleitner <msdemlei@cl.uni-heidelberg.de> */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700431UNUSUAL_DEV( 0x04e6, 0x0006, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700432 "SCM Microsystems Inc.",
433 "eUSB MMC Adapter",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200434 USB_SC_SCSI, USB_PR_CB, NULL,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700435 US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700436
437/* Reported by Daniel Nouri <dpunktnpunkt@web.de> */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700438UNUSUAL_DEV( 0x04e6, 0x0006, 0x0205, 0x0205,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700439 "Shuttle",
440 "eUSB MMC Adapter",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200441 USB_SC_SCSI, USB_PR_DEVICE, NULL,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700442 US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700443
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700444UNUSUAL_DEV( 0x04e6, 0x0007, 0x0100, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700445 "Sony",
446 "Hifd",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200447 USB_SC_SCSI, USB_PR_CB, NULL,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700448 US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700449
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700450UNUSUAL_DEV( 0x04e6, 0x0009, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700451 "Shuttle",
452 "eUSB ATA/ATAPI Adapter",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200453 USB_SC_8020, USB_PR_CB, NULL, 0),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700454
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700455UNUSUAL_DEV( 0x04e6, 0x000a, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700456 "Shuttle",
457 "eUSB CompactFlash Adapter",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200458 USB_SC_8020, USB_PR_CB, NULL, 0),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700459
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700460UNUSUAL_DEV( 0x04e6, 0x000B, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700461 "Shuttle",
462 "eUSCSI Bridge",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200463 USB_SC_SCSI, USB_PR_BULK, usb_stor_euscsi_init,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700464 US_FL_SCM_MULT_TARG ),
465
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700466UNUSUAL_DEV( 0x04e6, 0x000C, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700467 "Shuttle",
468 "eUSCSI Bridge",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200469 USB_SC_SCSI, USB_PR_BULK, usb_stor_euscsi_init,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700470 US_FL_SCM_MULT_TARG ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700471
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700472UNUSUAL_DEV( 0x04e6, 0x0101, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700473 "Shuttle",
474 "CD-RW Device",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200475 USB_SC_8020, USB_PR_CB, NULL, 0),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700476
Alan Sternb28884c2008-04-28 10:26:13 -0400477/* Reported by Dmitry Khlystov <adminimus@gmail.com> */
478UNUSUAL_DEV( 0x04e8, 0x507c, 0x0220, 0x0220,
479 "Samsung",
480 "YP-U3",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200481 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Sternb28884c2008-04-28 10:26:13 -0400482 US_FL_MAX_SECTORS_64),
483
Vitaly Kuznetsovd73a9b32010-12-14 10:16:49 -0500484/* Reported by Vitaly Kuznetsov <vitty@altlinux.ru> */
485UNUSUAL_DEV( 0x04e8, 0x5122, 0x0000, 0x9999,
486 "Samsung",
487 "YP-CP3",
488 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
489 US_FL_MAX_SECTORS_64 | US_FL_BULK_IGNORE_TAG),
490
Phil Dibowitzed3e8fc2008-05-03 18:04:30 -0700491/* Entry and supporting patch by Theodore Kilgore <kilgota@auburn.edu>.
492 * Device uses standards-violating 32-byte Bulk Command Block Wrappers and
493 * reports itself as "Proprietary SCSI Bulk." Cf. device entry 0x084d:0x0011.
494 */
495UNUSUAL_DEV( 0x04fc, 0x80c2, 0x0100, 0x0100,
496 "Kobian Mercury",
497 "Binocam DCB-132",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200498 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Phil Dibowitzed3e8fc2008-05-03 18:04:30 -0700499 US_FL_BULK32),
500
Linus Torvalds1da177e2005-04-16 15:20:36 -0700501/* Reported by Bob Sass <rls@vectordb.com> -- only rev 1.33 tested */
502UNUSUAL_DEV( 0x050d, 0x0115, 0x0133, 0x0133,
503 "Belkin",
504 "USB SCSI Adaptor",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200505 USB_SC_SCSI, USB_PR_BULK, usb_stor_euscsi_init,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700506 US_FL_SCM_MULT_TARG ),
507
508/* Iomega Clik! Drive
509 * Reported by David Chatenay <dchatenay@hotmail.com>
510 * The reason this is needed is not fully known.
511 */
512UNUSUAL_DEV( 0x0525, 0xa140, 0x0100, 0x0100,
513 "Iomega",
514 "USB Clik! 40",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200515 USB_SC_8070, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700516 US_FL_FIX_INQUIRY ),
517
Alan Stern25ff1c32008-12-15 12:43:41 -0500518/* Added by Alan Stern <stern@rowland.harvard.edu> */
519COMPLIANT_DEV(0x0525, 0xa4a5, 0x0000, 0x9999,
520 "Linux",
521 "File-backed Storage Gadget",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200522 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Stern25ff1c32008-12-15 12:43:41 -0500523 US_FL_CAPACITY_OK ),
524
Linus Torvalds1da177e2005-04-16 15:20:36 -0700525/* Yakumo Mega Image 37
526 * Submitted by Stephan Fuhrmann <atomenergie@t-online.de> */
527UNUSUAL_DEV( 0x052b, 0x1801, 0x0100, 0x0100,
528 "Tekom Technologies, Inc",
529 "300_CAMERA",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200530 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700531 US_FL_IGNORE_RESIDUE ),
532
533/* Another Yakumo camera.
534 * Reported by Michele Alzetta <michele.alzetta@aliceposta.it> */
535UNUSUAL_DEV( 0x052b, 0x1804, 0x0100, 0x0100,
536 "Tekom Technologies, Inc",
537 "300_CAMERA",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200538 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700539 US_FL_IGNORE_RESIDUE ),
540
541/* Reported by Iacopo Spalletti <avvisi@spalletti.it> */
542UNUSUAL_DEV( 0x052b, 0x1807, 0x0100, 0x0100,
543 "Tekom Technologies, Inc",
544 "300_CAMERA",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200545 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700546 US_FL_IGNORE_RESIDUE ),
547
548/* Yakumo Mega Image 47
549 * Reported by Bjoern Paetzel <kolrabi@kolrabi.de> */
550UNUSUAL_DEV( 0x052b, 0x1905, 0x0100, 0x0100,
551 "Tekom Technologies, Inc",
552 "400_CAMERA",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200553 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700554 US_FL_IGNORE_RESIDUE ),
555
556/* Reported by Paul Ortyl <ortylp@3miasto.net>
557 * Note that it's similar to the device above, only different prodID */
558UNUSUAL_DEV( 0x052b, 0x1911, 0x0100, 0x0100,
559 "Tekom Technologies, Inc",
560 "400_CAMERA",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200561 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700562 US_FL_IGNORE_RESIDUE ),
563
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700564UNUSUAL_DEV( 0x054c, 0x0010, 0x0106, 0x0450,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700565 "Sony",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700566 "DSC-S30/S70/S75/505V/F505/F707/F717/P8",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200567 USB_SC_SCSI, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700568 US_FL_SINGLE_LUN | US_FL_NOT_LOCKABLE | US_FL_NO_WP_DETECT ),
569
Lars Jacob7e3bd122006-07-10 11:53:58 -0400570/* Submitted by Lars Jacob <jacob.lars@googlemail.com>
571 * This entry is needed because the device reports Sub=ff */
572UNUSUAL_DEV( 0x054c, 0x0010, 0x0500, 0x0610,
Alexandre Duret-Lutzec7dc8d2005-12-26 23:04:24 -0800573 "Sony",
Lars Jacob7e3bd122006-07-10 11:53:58 -0400574 "DSC-T1/T5/H5",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200575 USB_SC_8070, USB_PR_DEVICE, NULL,
Alexandre Duret-Lutzec7dc8d2005-12-26 23:04:24 -0800576 US_FL_SINGLE_LUN ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700577
578
579/* Reported by wim@geeks.nl */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700580UNUSUAL_DEV( 0x054c, 0x0025, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700581 "Sony",
582 "Memorystick NW-MS7",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200583 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700584 US_FL_SINGLE_LUN ),
585
Linus Torvalds1da177e2005-04-16 15:20:36 -0700586/* Submitted by Olaf Hering, <olh@suse.de> SuSE Bugzilla #49049 */
Luiz Fernando N. Capitulino20b2e282007-01-24 16:19:37 -0200587UNUSUAL_DEV( 0x054c, 0x002c, 0x0501, 0x2000,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700588 "Sony",
589 "USB Floppy Drive",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200590 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700591 US_FL_SINGLE_LUN ),
592
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700593UNUSUAL_DEV( 0x054c, 0x002d, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700594 "Sony",
595 "Memorystick MSAC-US1",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200596 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700597 US_FL_SINGLE_LUN ),
598
599/* Submitted by Klaus Mueller <k.mueller@intershop.de> */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700600UNUSUAL_DEV( 0x054c, 0x002e, 0x0106, 0x0310,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700601 "Sony",
602 "Handycam",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200603 USB_SC_SCSI, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700604 US_FL_SINGLE_LUN ),
605
606/* Submitted by Rajesh Kumble Nayak <nayak@obs-nice.fr> */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700607UNUSUAL_DEV( 0x054c, 0x002e, 0x0500, 0x0500,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700608 "Sony",
609 "Handycam HC-85",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200610 USB_SC_UFI, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700611 US_FL_SINGLE_LUN ),
612
613UNUSUAL_DEV( 0x054c, 0x0032, 0x0000, 0x9999,
614 "Sony",
615 "Memorystick MSC-U01N",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200616 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700617 US_FL_SINGLE_LUN ),
618
619/* Submitted by Michal Mlotek <mlotek@foobar.pl> */
620UNUSUAL_DEV( 0x054c, 0x0058, 0x0000, 0x9999,
621 "Sony",
622 "PEG N760c Memorystick",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200623 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700624 US_FL_FIX_INQUIRY ),
625
626UNUSUAL_DEV( 0x054c, 0x0069, 0x0000, 0x9999,
627 "Sony",
628 "Memorystick MSC-U03",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200629 USB_SC_UFI, USB_PR_CB, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700630 US_FL_SINGLE_LUN ),
631
632/* Submitted by Nathan Babb <nathan@lexi.com> */
633UNUSUAL_DEV( 0x054c, 0x006d, 0x0000, 0x9999,
634 "Sony",
635 "PEG Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200636 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700637 US_FL_FIX_INQUIRY ),
638
Alan Sternf9dc8f92008-11-18 14:08:07 -0500639/* Submitted by Frank Engel <frankie@cse.unsw.edu.au> */
640UNUSUAL_DEV( 0x054c, 0x0099, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700641 "Sony",
642 "PEG Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200643 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700644 US_FL_FIX_INQUIRY ),
Alan Sternf9dc8f92008-11-18 14:08:07 -0500645
646/* Submitted by Mike Alborn <malborn@deandra.homeip.net> */
647UNUSUAL_DEV( 0x054c, 0x016a, 0x0000, 0x9999,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700648 "Sony",
649 "PEG Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200650 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700651 US_FL_FIX_INQUIRY ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700652
juergen.mell@t-online.de082fdd12006-08-28 13:53:53 -0700653/* floppy reports multiple luns */
654UNUSUAL_DEV( 0x055d, 0x2020, 0x0000, 0x0210,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700655 "SAMSUNG",
656 "SFD-321U [FW 0C]",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200657 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700658 US_FL_SINGLE_LUN ),
juergen.mell@t-online.de082fdd12006-08-28 13:53:53 -0700659
Pete Zaitcevfd4f3a92009-08-20 20:00:19 -0600660/* We keep this entry to force the transport; firmware 3.00 and later is ok. */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700661UNUSUAL_DEV( 0x057b, 0x0000, 0x0000, 0x0299,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700662 "Y-E Data",
663 "Flashbuster-U",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200664 USB_SC_DEVICE, USB_PR_CB, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700665 US_FL_SINGLE_LUN),
666
Linus Torvalds1da177e2005-04-16 15:20:36 -0700667/* Reported by Johann Cardon <johann.cardon@free.fr>
668 * This entry is needed only because the device reports
669 * bInterfaceClass = 0xff (vendor-specific)
670 */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700671UNUSUAL_DEV( 0x057b, 0x0022, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700672 "Y-E Data",
673 "Silicon Media R/W",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200674 USB_SC_DEVICE, USB_PR_DEVICE, NULL, 0),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700675
Alan Sternf1e8de0d2007-11-26 10:23:05 -0500676/* Reported by RTE <raszilki@yandex.ru> */
677UNUSUAL_DEV( 0x058f, 0x6387, 0x0141, 0x0141,
678 "JetFlash",
679 "TS1GJF2A/120",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200680 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Sternf1e8de0d2007-11-26 10:23:05 -0500681 US_FL_MAX_SECTORS_64 ),
682
Linus Torvalds1da177e2005-04-16 15:20:36 -0700683/* Fabrizio Fellini <fello@libero.it> */
684UNUSUAL_DEV( 0x0595, 0x4343, 0x0000, 0x2210,
685 "Fujifilm",
686 "Digital Camera EX-20 DSC",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200687 USB_SC_8070, USB_PR_DEVICE, NULL, 0 ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700688
Alan Sterna4625492008-02-13 10:45:28 -0500689/* Reported by Andre Welter <a.r.welter@gmx.de>
690 * This antique device predates the release of the Bulk-only Transport
691 * spec, and if it gets a Get-Max-LUN then it requires the host to do a
692 * Clear-Halt on the bulk endpoints. The SINGLE_LUN flag will prevent
693 * us from sending the request.
694 */
695UNUSUAL_DEV( 0x059b, 0x0001, 0x0100, 0x0100,
696 "Iomega",
697 "ZIP 100",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200698 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Sterna4625492008-02-13 10:45:28 -0500699 US_FL_SINGLE_LUN ),
700
Alan Sternb97b1962006-09-14 15:18:54 -0400701/* Reported by <Hendryk.Pfeiffer@gmx.de> */
702UNUSUAL_DEV( 0x059f, 0x0643, 0x0000, 0x0000,
703 "LaCie",
704 "DVD+-RW",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200705 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Sternb97b1962006-09-14 15:18:54 -0400706 US_FL_GO_SLOW ),
707
Linus Torvalds1da177e2005-04-16 15:20:36 -0700708/* Submitted by Joel Bourquard <numlock@freesurf.ch>
709 * Some versions of this device need the SubClass and Protocol overrides
710 * while others don't.
711 */
712UNUSUAL_DEV( 0x05ab, 0x0060, 0x1104, 0x1110,
713 "In-System",
714 "PyroGate External CD-ROM Enclosure (FCD-523)",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200715 USB_SC_SCSI, USB_PR_BULK, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700716 US_FL_NEED_OVERRIDE ),
717
Sven Anderson35f4a0c2005-04-22 15:06:58 -0700718/* Submitted by Sven Anderson <sven-linux@anderson.de>
719 * There are at least four ProductIDs used for iPods, so I added 0x1202 and
720 * 0x1204. They just need the US_FL_FIX_CAPACITY. As the bcdDevice appears
721 * to change with firmware updates, I changed the range to maximum for all
722 * iPod entries.
723 */
724UNUSUAL_DEV( 0x05ac, 0x1202, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700725 "Apple",
726 "iPod",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200727 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700728 US_FL_FIX_CAPACITY ),
729
Sven Anderson35f4a0c2005-04-22 15:06:58 -0700730/* Reported by Avi Kivity <avi@argo.co.il> */
731UNUSUAL_DEV( 0x05ac, 0x1203, 0x0000, 0x9999,
732 "Apple",
733 "iPod",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200734 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Sven Anderson35f4a0c2005-04-22 15:06:58 -0700735 US_FL_FIX_CAPACITY ),
736
737UNUSUAL_DEV( 0x05ac, 0x1204, 0x0000, 0x9999,
738 "Apple",
739 "iPod",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200740 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Pete Zaitcevad1428c2006-12-31 13:43:26 -0800741 US_FL_FIX_CAPACITY | US_FL_NOT_LOCKABLE ),
Sven Anderson35f4a0c2005-04-22 15:06:58 -0700742
743UNUSUAL_DEV( 0x05ac, 0x1205, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700744 "Apple",
745 "iPod",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200746 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700747 US_FL_FIX_CAPACITY ),
748
Phil Dibowitz880a9b52005-09-30 00:27:36 -0700749/*
750 * Reported by Tyson Vinson <lornoss@gmail.com>
751 * This particular productId is the iPod Nano
752 */
753UNUSUAL_DEV( 0x05ac, 0x120a, 0x0000, 0x9999,
754 "Apple",
755 "iPod",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200756 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Phil Dibowitz880a9b52005-09-30 00:27:36 -0700757 US_FL_FIX_CAPACITY ),
758
Dan Williams281b0642008-12-14 12:39:22 -0500759/* Reported by Dan Williams <dcbw@redhat.com>
760 * Option N.V. mobile broadband modems
761 * Ignore driver CD mode and force into modem mode by default.
762 */
763
764/* Globetrotter HSDPA; mass storage shows up as Qualcomm for vendor */
765UNUSUAL_DEV( 0x05c6, 0x1000, 0x0000, 0x9999,
766 "Option N.V.",
767 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200768 USB_SC_DEVICE, USB_PR_DEVICE, option_ms_init,
Dan Williams281b0642008-12-14 12:39:22 -0500769 0),
770
Linus Torvalds1da177e2005-04-16 15:20:36 -0700771/* Reported by Blake Matheny <bmatheny@purdue.edu> */
772UNUSUAL_DEV( 0x05dc, 0xb002, 0x0000, 0x0113,
773 "Lexar",
774 "USB CF Reader",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200775 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700776 US_FL_FIX_INQUIRY ),
777
778/* The following two entries are for a Genesys USB to IDE
779 * converter chip, but it changes its ProductId depending
780 * on whether or not a disk or an optical device is enclosed
781 * They were originally reported by Alexander Oltu
782 * <alexander@all-2.com> and Peter Marks <peter.marks@turner.com>
783 * respectively.
Phil Dibowitz883d9892006-06-24 17:27:10 -0700784 *
785 * US_FL_GO_SLOW and US_FL_MAX_SECTORS_64 added by Phil Dibowitz
786 * <phil@ipom.com> as these flags were made and hard-coded
787 * special-cases were pulled from scsiglue.c.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700788 */
789UNUSUAL_DEV( 0x05e3, 0x0701, 0x0000, 0xffff,
790 "Genesys Logic",
791 "USB to IDE Optical",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200792 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Stern5126a262009-02-23 12:02:05 -0500793 US_FL_GO_SLOW | US_FL_MAX_SECTORS_64 | US_FL_IGNORE_RESIDUE ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700794
795UNUSUAL_DEV( 0x05e3, 0x0702, 0x0000, 0xffff,
796 "Genesys Logic",
797 "USB to IDE Disk",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200798 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Stern5126a262009-02-23 12:02:05 -0500799 US_FL_GO_SLOW | US_FL_MAX_SECTORS_64 | US_FL_IGNORE_RESIDUE ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700800
Ben Efrosdbe6e0c02008-11-23 20:06:38 -0800801/* Reported by Ben Efros <ben@pc-doctor.com> */
802UNUSUAL_DEV( 0x05e3, 0x0723, 0x9451, 0x9451,
803 "Genesys Logic",
804 "USB to SATA",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200805 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Ben Efrosdbe6e0c02008-11-23 20:06:38 -0800806 US_FL_SANE_SENSE ),
807
Linus Torvalds1da177e2005-04-16 15:20:36 -0700808/* Reported by Hanno Boeck <hanno@gmx.de>
809 * Taken from the Lycoris Kernel */
810UNUSUAL_DEV( 0x0636, 0x0003, 0x0000, 0x9999,
811 "Vivitar",
812 "Vivicam 35Xx",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200813 USB_SC_SCSI, USB_PR_BULK, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700814 US_FL_FIX_INQUIRY ),
815
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700816UNUSUAL_DEV( 0x0644, 0x0000, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700817 "TEAC",
818 "Floppy Drive",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200819 USB_SC_UFI, USB_PR_CB, NULL, 0 ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700820
Linus Torvalds1da177e2005-04-16 15:20:36 -0700821/* Reported by Darsen Lu <darsen@micro.ee.nthu.edu.tw> */
822UNUSUAL_DEV( 0x066f, 0x8000, 0x0001, 0x0001,
823 "SigmaTel",
824 "USBMSC Audio Player",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200825 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700826 US_FL_FIX_CAPACITY ),
827
Alan Sterna0bb1082009-12-07 16:39:16 -0500828/* Reported by Daniel Kukula <daniel.kuku@gmail.com> */
829UNUSUAL_DEV( 0x067b, 0x1063, 0x0100, 0x0100,
830 "Prolific Technology, Inc.",
831 "Prolific Storage Gadget",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200832 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Sterna0bb1082009-12-07 16:39:16 -0500833 US_FL_BAD_SENSE ),
834
Rogerio Britoc15e3ca2009-08-06 15:20:19 -0700835/* Reported by Rogerio Brito <rbrito@ime.usp.br> */
836UNUSUAL_DEV( 0x067b, 0x2317, 0x0001, 0x001,
837 "Prolific Technology, Inc.",
838 "Mass Storage Device",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200839 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Rogerio Britoc15e3ca2009-08-06 15:20:19 -0700840 US_FL_NOT_LOCKABLE ),
841
Linus Torvalds1da177e2005-04-16 15:20:36 -0700842/* Reported by Richard -=[]=- <micro_flyer@hotmail.com> */
Thomas Bartosik8a0845c2009-03-16 16:04:38 +0100843/* Change to bcdDeviceMin (0x0100 to 0x0001) reported by
844 * Thomas Bartosik <tbartdev@gmx-topmail.de> */
845UNUSUAL_DEV( 0x067b, 0x2507, 0x0001, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700846 "Prolific Technology Inc.",
847 "Mass Storage Device",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200848 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700849 US_FL_FIX_CAPACITY | US_FL_GO_SLOW ),
850
851/* Reported by Alex Butcher <alex.butcher@assursys.co.uk> */
Oliver Neukumb1636392008-12-12 11:01:45 +0100852UNUSUAL_DEV( 0x067b, 0x3507, 0x0001, 0x0101,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700853 "Prolific Technology Inc.",
854 "ATAPI-6 Bridge Controller",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200855 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700856 US_FL_FIX_CAPACITY | US_FL_GO_SLOW ),
857
858/* Submitted by Benny Sjostrand <benny@hostmobility.com> */
859UNUSUAL_DEV( 0x0686, 0x4011, 0x0001, 0x0001,
860 "Minolta",
861 "Dimage F300",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200862 USB_SC_SCSI, USB_PR_BULK, NULL, 0 ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700863
864/* Reported by Miguel A. Fosas <amn3s1a@ono.com> */
865UNUSUAL_DEV( 0x0686, 0x4017, 0x0001, 0x0001,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700866 "Minolta",
867 "DIMAGE E223",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200868 USB_SC_SCSI, USB_PR_DEVICE, NULL, 0 ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700869
Linus Torvalds1da177e2005-04-16 15:20:36 -0700870UNUSUAL_DEV( 0x0693, 0x0005, 0x0100, 0x0100,
871 "Hagiwara",
872 "Flashgate",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200873 USB_SC_SCSI, USB_PR_BULK, NULL, 0 ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700874
Alan Stern754501b2006-02-23 10:19:25 -0500875/* Reported by David Hamilton <niftimusmaximus@lycos.com> */
876UNUSUAL_DEV( 0x069b, 0x3004, 0x0001, 0x0001,
877 "Thomson Multimedia Inc.",
878 "RCA RD1080 MP3 Player",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200879 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Stern754501b2006-02-23 10:19:25 -0500880 US_FL_FIX_CAPACITY ),
881
Alan Sternfe1926a2008-09-04 09:56:35 -0400882/* Reported by Adrian Pilchowiec <adi1981@epf.pl> */
883UNUSUAL_DEV( 0x071b, 0x3203, 0x0000, 0x0000,
884 "RockChip",
885 "MP3",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200886 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Hans de Goede00914022010-10-01 14:20:11 -0700887 US_FL_NO_WP_DETECT | US_FL_MAX_SECTORS_64 |
888 US_FL_NO_READ_CAPACITY_16),
Alan Sternfe1926a2008-09-04 09:56:35 -0400889
Jean-Baptiste Onofre64915092008-12-20 20:11:55 +0100890/* Reported by Jean-Baptiste Onofre <jb@nanthrax.net>
891 * Support the following product :
892 * "Dane-Elec MediaTouch"
893 */
894UNUSUAL_DEV( 0x071b, 0x32bb, 0x0000, 0x0000,
895 "RockChip",
896 "MTP",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200897 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jean-Baptiste Onofre64915092008-12-20 20:11:55 +0100898 US_FL_NO_WP_DETECT | US_FL_MAX_SECTORS_64),
899
Massimiliano Ghilardic4766562007-09-04 22:53:43 +0200900/* Reported by Massimiliano Ghilardi <massimiliano.ghilardi@gmail.com>
901 * This USB MP3/AVI player device fails and disconnects if more than 128
902 * sectors (64kB) are read/written in a single command, and may be present
903 * at least in the following products:
904 * "Magnex Digital Video Panel DVP 1800"
905 * "MP4 AIGO 4GB SLOT SD"
906 * "Teclast TL-C260 MP3"
907 * "i.Meizu PMP MP3/MP4"
908 * "Speed MV8 MP4 Audio Player"
909 */
910UNUSUAL_DEV( 0x071b, 0x3203, 0x0100, 0x0100,
911 "RockChip",
912 "ROCK MP3",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200913 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Massimiliano Ghilardic4766562007-09-04 22:53:43 +0200914 US_FL_MAX_SECTORS_64),
915
Olivier Blondeauf430c402006-04-16 19:19:25 -0700916/* Reported by Olivier Blondeau <zeitoun@gmail.com> */
917UNUSUAL_DEV( 0x0727, 0x0306, 0x0100, 0x0100,
918 "ATMEL",
919 "SND1 Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200920 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Olivier Blondeauf430c402006-04-16 19:19:25 -0700921 US_FL_IGNORE_RESIDUE),
922
Phil Dibowitz1e7a5a82006-03-05 21:36:51 -0800923/* Submitted by Roman Hodek <roman@hodek.net> */
924UNUSUAL_DEV( 0x0781, 0x0001, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700925 "Sandisk",
926 "ImageMate SDDR-05a",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200927 USB_SC_SCSI, USB_PR_CB, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700928 US_FL_SINGLE_LUN ),
929
Phil Dibowitz1e7a5a82006-03-05 21:36:51 -0800930UNUSUAL_DEV( 0x0781, 0x0002, 0x0009, 0x0009,
931 "SanDisk Corporation",
932 "ImageMate CompactFlash USB",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200933 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Phil Dibowitz1e7a5a82006-03-05 21:36:51 -0800934 US_FL_FIX_CAPACITY ),
935
Linus Torvalds1da177e2005-04-16 15:20:36 -0700936UNUSUAL_DEV( 0x0781, 0x0100, 0x0100, 0x0100,
937 "Sandisk",
938 "ImageMate SDDR-12",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200939 USB_SC_SCSI, USB_PR_CB, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700940 US_FL_SINGLE_LUN ),
941
Linus Torvalds1da177e2005-04-16 15:20:36 -0700942/* Reported by Eero Volotinen <eero@ping-viini.org> */
Phil Dibowitze5278322005-10-23 23:52:39 -0700943UNUSUAL_DEV( 0x07ab, 0xfccd, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700944 "Freecom Technologies",
945 "FHD-Classic",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200946 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700947 US_FL_FIX_CAPACITY),
948
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700949UNUSUAL_DEV( 0x07af, 0x0004, 0x0100, 0x0133,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700950 "Microtech",
951 "USB-SCSI-DB25",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200952 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_euscsi_init,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700953 US_FL_SCM_MULT_TARG ),
954
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700955UNUSUAL_DEV( 0x07af, 0x0005, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700956 "Microtech",
957 "USB-SCSI-HD50",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200958 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_euscsi_init,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700959 US_FL_SCM_MULT_TARG ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700960
Alan Stern0ff71882009-02-12 14:47:49 -0500961#ifdef NO_SDDR09
Alan Sternc20b15f2008-12-01 10:36:15 -0500962UNUSUAL_DEV( 0x07af, 0x0006, 0x0100, 0x0100,
963 "Microtech",
964 "CameraMate",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200965 USB_SC_SCSI, USB_PR_CB, NULL,
Alan Sternc20b15f2008-12-01 10:36:15 -0500966 US_FL_SINGLE_LUN ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700967#endif
968
Linus Torvalds1da177e2005-04-16 15:20:36 -0700969/* Datafab KECF-USB / Sagatek DCS-CF / Simpletech Flashlink UCF-100
970 * Only revision 1.13 tested (same for all of the above devices,
971 * based on the Datafab DF-UG-07 chip). Needed for US_FL_FIX_INQUIRY.
972 * Submitted by Marek Michalkiewicz <marekm@amelek.gda.pl>.
973 * See also http://martin.wilck.bei.t-online.de/#kecf .
974 */
975UNUSUAL_DEV( 0x07c4, 0xa400, 0x0000, 0xffff,
976 "Datafab",
977 "KECF-USB",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200978 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Nick Holloway049a6ac2009-01-25 16:58:43 +0000979 US_FL_FIX_INQUIRY | US_FL_FIX_CAPACITY ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700980
Alan Sterne4813ee2009-03-24 10:39:13 -0400981/* Reported by Rauch Wolke <rauchwolke@gmx.net>
982 * and augmented by binbin <binbinsh@gmail.com> (Bugzilla #12882)
983 */
Alan Stern368ee642008-07-21 10:08:28 -0400984UNUSUAL_DEV( 0x07c4, 0xa4a5, 0x0000, 0xffff,
985 "Simple Tech/Datafab",
986 "CF+SM Reader",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200987 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Sterne4813ee2009-03-24 10:39:13 -0400988 US_FL_IGNORE_RESIDUE | US_FL_MAX_SECTORS_64 ),
Alan Stern368ee642008-07-21 10:08:28 -0400989
Linus Torvalds1da177e2005-04-16 15:20:36 -0700990/* Casio QV 2x00/3x00/4000/8000 digital still cameras are not conformant
991 * to the USB storage specification in two ways:
992 * - They tell us they are using transport protocol CBI. In reality they
993 * are using transport protocol CB.
994 * - They don't like the INQUIRY command. So we must handle this command
995 * of the SCSI layer ourselves.
996 * - Some cameras with idProduct=0x1001 and bcdDevice=0x1000 have
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +0200997 * bInterfaceProtocol=0x00 (USB_PR_CBI) while others have 0x01 (USB_PR_CB).
998 * So don't remove the USB_PR_CB override!
999 * - Cameras with bcdDevice=0x9009 require the USB_SC_8070 override.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001000 */
1001UNUSUAL_DEV( 0x07cf, 0x1001, 0x1000, 0x9999,
1002 "Casio",
1003 "QV DigitalCamera",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001004 USB_SC_8070, USB_PR_CB, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001005 US_FL_NEED_OVERRIDE | US_FL_FIX_INQUIRY ),
1006
1007/* Submitted by Hartmut Wahl <hwahl@hwahl.de>*/
1008UNUSUAL_DEV( 0x0839, 0x000a, 0x0001, 0x0001,
1009 "Samsung",
1010 "Digimax 410",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001011 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001012 US_FL_FIX_INQUIRY),
1013
Alan Stern8010e062008-11-04 11:33:35 -05001014/* Reported by Luciano Rocha <luciano@eurotux.com> */
1015UNUSUAL_DEV( 0x0840, 0x0082, 0x0001, 0x0001,
1016 "Argosy",
1017 "Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001018 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Stern8010e062008-11-04 11:33:35 -05001019 US_FL_FIX_CAPACITY),
1020
Nguyen Anh Quynhe2673b22008-12-11 15:04:11 -08001021/* Reported and patched by Nguyen Anh Quynh <aquynh@gmail.com> */
1022UNUSUAL_DEV( 0x0840, 0x0084, 0x0001, 0x0001,
1023 "Argosy",
1024 "Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001025 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Nguyen Anh Quynhe2673b22008-12-11 15:04:11 -08001026 US_FL_FIX_CAPACITY),
1027
Phil Dibowitzaa23c8d2009-01-20 23:42:52 +01001028/* Reported by Martijn Hijdra <martijn.hijdra@gmail.com> */
1029UNUSUAL_DEV( 0x0840, 0x0085, 0x0001, 0x0001,
1030 "Argosy",
1031 "Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001032 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Phil Dibowitzaa23c8d2009-01-20 23:42:52 +01001033 US_FL_FIX_CAPACITY),
1034
Linus Torvalds1da177e2005-04-16 15:20:36 -07001035/* Entry and supporting patch by Theodore Kilgore <kilgota@auburn.edu>.
1036 * Flag will support Bulk devices which use a standards-violating 32-byte
1037 * Command Block Wrapper. Here, the "DC2MEGA" cameras (several brands) with
1038 * Grandtech GT892x chip, which request "Proprietary SCSI Bulk" support.
1039 */
1040
1041UNUSUAL_DEV( 0x084d, 0x0011, 0x0110, 0x0110,
1042 "Grandtech",
1043 "DC2MEGA",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001044 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001045 US_FL_BULK32),
1046
Alan Stern12f68c42011-01-03 16:47:49 -05001047/* Reported by <ttkspam@free.fr>
1048 * The device reports a vendor-specific device class, requiring an
1049 * explicit vendor/product match.
1050 */
1051UNUSUAL_DEV( 0x0851, 0x1542, 0x0002, 0x0002,
1052 "MagicPixel",
1053 "FW_Omega2",
1054 USB_SC_DEVICE, USB_PR_DEVICE, NULL, 0),
1055
Andrew Lunnf7687212008-04-24 19:36:39 +02001056/* Andrew Lunn <andrew@lunn.ch>
1057 * PanDigital Digital Picture Frame. Does not like ALLOW_MEDIUM_REMOVAL
1058 * on LUN 4.
1059 * Note: Vend:Prod clash with "Ltd Maxell WS30 Slim Digital Camera"
1060*/
1061UNUSUAL_DEV( 0x0851, 0x1543, 0x0200, 0x0200,
1062 "PanDigital",
1063 "Photo Frame",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001064 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Andrew Lunnf7687212008-04-24 19:36:39 +02001065 US_FL_NOT_LOCKABLE),
1066
Alan Sternba3e93a2006-01-30 10:19:43 -05001067/* Submitted by Jan De Luyck <lkml@kcore.org> */
1068UNUSUAL_DEV( 0x08bd, 0x1100, 0x0000, 0x0000,
1069 "CITIZEN",
1070 "X1DE-USB",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001071 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Sternba3e93a2006-01-30 10:19:43 -05001072 US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001073
Dylan Tafta7e555b2007-02-05 16:41:01 -08001074/* Submitted by Dylan Taft <d13f00l@gmail.com>
1075 * US_FL_IGNORE_RESIDUE Needed
1076 */
1077UNUSUAL_DEV( 0x08ca, 0x3103, 0x0100, 0x0100,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001078 "AIPTEK",
1079 "Aiptek USB Keychain MP3 Player",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001080 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001081 US_FL_IGNORE_RESIDUE),
Dylan Tafta7e555b2007-02-05 16:41:01 -08001082
Linus Torvalds1da177e2005-04-16 15:20:36 -07001083/* Entry needed for flags. Moreover, all devices with this ID use
1084 * bulk-only transport, but _some_ falsely report Control/Bulk instead.
1085 * One example is "Trumpion Digital Research MYMP3".
1086 * Submitted by Bjoern Brill <brill(at)fs.math.uni-frankfurt.de>
1087 */
1088UNUSUAL_DEV( 0x090a, 0x1001, 0x0100, 0x0100,
1089 "Trumpion",
1090 "t33520 USB Flash Card Controller",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001091 USB_SC_DEVICE, USB_PR_BULK, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001092 US_FL_NEED_OVERRIDE ),
1093
Phil Dibowitz17247572005-05-21 00:45:55 -07001094/* Reported by Filippo Bardelli <filibard@libero.it>
1095 * The device reports a subclass of RBC, which is wrong.
1096 */
1097UNUSUAL_DEV( 0x090a, 0x1050, 0x0100, 0x0100,
1098 "Trumpion Microelectronics, Inc.",
1099 "33520 USB Digital Voice Recorder",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001100 USB_SC_UFI, USB_PR_DEVICE, NULL,
Phil Dibowitz17247572005-05-21 00:45:55 -07001101 0),
1102
Linus Torvalds1da177e2005-04-16 15:20:36 -07001103/* Trumpion Microelectronics MP3 player (felipe_alfaro@linuxmail.org) */
1104UNUSUAL_DEV( 0x090a, 0x1200, 0x0000, 0x9999,
1105 "Trumpion",
1106 "MP3 player",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001107 USB_SC_RBC, USB_PR_BULK, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001108 0 ),
1109
1110/* aeb */
1111UNUSUAL_DEV( 0x090c, 0x1132, 0x0000, 0xffff,
1112 "Feiya",
1113 "5-in-1 Card Reader",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001114 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001115 US_FL_FIX_CAPACITY ),
1116
Alan Stern21c13a42011-06-07 11:35:52 -04001117/* Reported by Paul Hartman <paul.hartman+linux@gmail.com>
1118 * This card reader returns "Illegal Request, Logical Block Address
1119 * Out of Range" for the first READ(10) after a new card is inserted.
1120 */
1121UNUSUAL_DEV( 0x090c, 0x6000, 0x0100, 0x0100,
1122 "Feiya",
1123 "SD/SDHC Card Reader",
1124 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
1125 US_FL_INITIAL_READ10 ),
1126
Linus Torvalds1da177e2005-04-16 15:20:36 -07001127/* This Pentax still camera is not conformant
1128 * to the USB storage specification: -
1129 * - It does not like the INQUIRY command. So we must handle this command
1130 * of the SCSI layer ourselves.
1131 * Tested on Rev. 10.00 (0x1000)
1132 * Submitted by James Courtier-Dutton <James@superbug.demon.co.uk>
1133 */
1134UNUSUAL_DEV( 0x0a17, 0x0004, 0x1000, 0x1000,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001135 "Pentax",
1136 "Optio 2/3/400",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001137 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001138 US_FL_FIX_INQUIRY ),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001139
Ben Collins67fa1062007-05-26 03:06:32 -07001140/* These are virtual windows driver CDs, which the zd1211rw driver
1141 * automatically converts into WLAN devices. */
Daniel Drake3c332422006-07-26 13:59:23 +01001142UNUSUAL_DEV( 0x0ace, 0x2011, 0x0101, 0x0101,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001143 "ZyXEL",
1144 "G-220F USB-WLAN Install",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001145 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001146 US_FL_IGNORE_DEVICE ),
Daniel Drake3c332422006-07-26 13:59:23 +01001147
Matthew Davidson64902cb2007-05-01 01:15:01 +01001148UNUSUAL_DEV( 0x0ace, 0x20ff, 0x0101, 0x0101,
1149 "SiteCom",
1150 "WL-117 USB-WLAN Install",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001151 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Matthew Davidson64902cb2007-05-01 01:15:01 +01001152 US_FL_IGNORE_DEVICE ),
1153
Dan Williams281b0642008-12-14 12:39:22 -05001154/* Reported by Dan Williams <dcbw@redhat.com>
1155 * Option N.V. mobile broadband modems
1156 * Ignore driver CD mode and force into modem mode by default.
1157 */
1158
1159/* iCON 225 */
1160UNUSUAL_DEV( 0x0af0, 0x6971, 0x0000, 0x9999,
1161 "Option N.V.",
1162 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001163 USB_SC_DEVICE, USB_PR_DEVICE, option_ms_init,
Dan Williams281b0642008-12-14 12:39:22 -05001164 0),
1165
Filip Abene7c6f802008-05-08 10:48:12 -07001166/* Reported by F. Aben <f.aben@option.com>
1167 * This device (wrongly) has a vendor-specific device descriptor.
1168 * The entry is needed so usb-storage can bind to it's mass-storage
1169 * interface as an interface driver */
1170UNUSUAL_DEV( 0x0af0, 0x7401, 0x0000, 0x0000,
1171 "Option",
1172 "GI 0401 SD-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001173 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Filip Abene7c6f802008-05-08 10:48:12 -07001174 0 ),
1175
Jan Dumonc497e712009-03-10 17:29:47 +01001176/* Reported by Jan Dumon <j.dumon@option.com>
Jan Dumon46216e42010-01-05 15:53:26 +01001177 * These devices (wrongly) have a vendor-specific device descriptor.
1178 * These entries are needed so usb-storage can bind to their mass-storage
Jan Dumonc497e712009-03-10 17:29:47 +01001179 * interface as an interface driver */
1180UNUSUAL_DEV( 0x0af0, 0x7501, 0x0000, 0x0000,
1181 "Option",
1182 "GI 0431 SD-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001183 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jan Dumonc497e712009-03-10 17:29:47 +01001184 0 ),
1185
Jan Dumon46216e42010-01-05 15:53:26 +01001186UNUSUAL_DEV( 0x0af0, 0x7701, 0x0000, 0x0000,
1187 "Option",
1188 "GI 0451 SD-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001189 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jan Dumon46216e42010-01-05 15:53:26 +01001190 0 ),
1191
1192UNUSUAL_DEV( 0x0af0, 0x7706, 0x0000, 0x0000,
1193 "Option",
1194 "GI 0451 SD-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001195 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jan Dumon46216e42010-01-05 15:53:26 +01001196 0 ),
1197
1198UNUSUAL_DEV( 0x0af0, 0x7901, 0x0000, 0x0000,
1199 "Option",
1200 "GI 0452 SD-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001201 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jan Dumon46216e42010-01-05 15:53:26 +01001202 0 ),
1203
1204UNUSUAL_DEV( 0x0af0, 0x7A01, 0x0000, 0x0000,
1205 "Option",
1206 "GI 0461 SD-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001207 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jan Dumon46216e42010-01-05 15:53:26 +01001208 0 ),
1209
1210UNUSUAL_DEV( 0x0af0, 0x7A05, 0x0000, 0x0000,
1211 "Option",
1212 "GI 0461 SD-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001213 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jan Dumon46216e42010-01-05 15:53:26 +01001214 0 ),
1215
1216UNUSUAL_DEV( 0x0af0, 0x8300, 0x0000, 0x0000,
1217 "Option",
1218 "GI 033x SD-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001219 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jan Dumon46216e42010-01-05 15:53:26 +01001220 0 ),
1221
1222UNUSUAL_DEV( 0x0af0, 0x8302, 0x0000, 0x0000,
1223 "Option",
1224 "GI 033x SD-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001225 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jan Dumon46216e42010-01-05 15:53:26 +01001226 0 ),
1227
1228UNUSUAL_DEV( 0x0af0, 0x8304, 0x0000, 0x0000,
1229 "Option",
1230 "GI 033x SD-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001231 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jan Dumon46216e42010-01-05 15:53:26 +01001232 0 ),
1233
1234UNUSUAL_DEV( 0x0af0, 0xc100, 0x0000, 0x0000,
1235 "Option",
1236 "GI 070x SD-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001237 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jan Dumon46216e42010-01-05 15:53:26 +01001238 0 ),
1239
1240UNUSUAL_DEV( 0x0af0, 0xd057, 0x0000, 0x0000,
1241 "Option",
1242 "GI 1505 SD-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001243 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jan Dumon46216e42010-01-05 15:53:26 +01001244 0 ),
1245
1246UNUSUAL_DEV( 0x0af0, 0xd058, 0x0000, 0x0000,
1247 "Option",
1248 "GI 1509 SD-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001249 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jan Dumon46216e42010-01-05 15:53:26 +01001250 0 ),
1251
1252UNUSUAL_DEV( 0x0af0, 0xd157, 0x0000, 0x0000,
1253 "Option",
1254 "GI 1515 SD-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001255 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jan Dumon46216e42010-01-05 15:53:26 +01001256 0 ),
1257
1258UNUSUAL_DEV( 0x0af0, 0xd257, 0x0000, 0x0000,
1259 "Option",
1260 "GI 1215 SD-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001261 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jan Dumon46216e42010-01-05 15:53:26 +01001262 0 ),
1263
1264UNUSUAL_DEV( 0x0af0, 0xd357, 0x0000, 0x0000,
1265 "Option",
1266 "GI 1505 SD-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001267 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jan Dumon46216e42010-01-05 15:53:26 +01001268 0 ),
1269
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001270/* Reported by Ben Efros <ben@pc-doctor.com> */
1271UNUSUAL_DEV( 0x0bc2, 0x3010, 0x0000, 0x0000,
1272 "Seagate",
1273 "FreeAgent Pro",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001274 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001275 US_FL_SANE_SENSE ),
1276
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001277UNUSUAL_DEV( 0x0d49, 0x7310, 0x0000, 0x9999,
1278 "Maxtor",
1279 "USB to SATA",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001280 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001281 US_FL_SANE_SENSE),
1282
Alan Sternf9dc8f92008-11-18 14:08:07 -05001283/*
1284 * Pete Zaitcev <zaitcev@yahoo.com>, bz#164688.
1285 * The device blatantly ignores LUN and returns 1 in GetMaxLUN.
1286 */
1287UNUSUAL_DEV( 0x0c45, 0x1060, 0x0100, 0x0100,
1288 "Unknown",
1289 "Unknown",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001290 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Sternf9dc8f92008-11-18 14:08:07 -05001291 US_FL_SINGLE_LUN ),
1292
Linus Torvalds1da177e2005-04-16 15:20:36 -07001293/* Submitted by Joris Struyve <joris@struyve.be> */
1294UNUSUAL_DEV( 0x0d96, 0x410a, 0x0001, 0xffff,
1295 "Medion",
1296 "MD 7425",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001297 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001298 US_FL_FIX_INQUIRY),
1299
1300/*
1301 * Entry for Jenoptik JD 5200z3
1302 *
1303 * email: car.busse@gmx.de
1304 */
1305UNUSUAL_DEV( 0x0d96, 0x5200, 0x0001, 0x0200,
1306 "Jenoptik",
1307 "JD 5200 z3",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001308 USB_SC_DEVICE, USB_PR_DEVICE, NULL, US_FL_FIX_INQUIRY),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001309
Sergey Ovcharenko3b438e32008-12-17 19:28:06 +03001310/* Reported by Jason Johnston <killean@shaw.ca> */
1311UNUSUAL_DEV( 0x0dc4, 0x0073, 0x0000, 0x0000,
1312 "Macpower Technology Co.LTD.",
1313 "USB 2.0 3.5\" DEVICE",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001314 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Sergey Ovcharenko3b438e32008-12-17 19:28:06 +03001315 US_FL_FIX_CAPACITY),
1316
Linus Torvalds1da177e2005-04-16 15:20:36 -07001317/* Reported by Lubomir Blaha <tritol@trilogic.cz>
1318 * I _REALLY_ don't know what 3rd, 4th number and all defines mean, but this
1319 * works for me. Can anybody correct these values? (I able to test corrected
1320 * version.)
1321 */
1322UNUSUAL_DEV( 0x0dd8, 0x1060, 0x0000, 0xffff,
1323 "Netac",
1324 "USB-CF-Card",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001325 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001326 US_FL_FIX_INQUIRY ),
1327
Ben Collins67fa1062007-05-26 03:06:32 -07001328/* Reported by Edward Chapman (taken from linux-usb mailing list)
1329 Netac OnlyDisk Mini U2CV2 512MB USB 2.0 Flash Drive */
1330UNUSUAL_DEV( 0x0dd8, 0xd202, 0x0000, 0x9999,
1331 "Netac",
1332 "USB Flash Disk",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001333 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Ben Collins67fa1062007-05-26 03:06:32 -07001334 US_FL_IGNORE_RESIDUE ),
1335
1336
Linus Torvalds1da177e2005-04-16 15:20:36 -07001337/* Patch by Stephan Walter <stephan.walter@epfl.ch>
1338 * I don't know why, but it works... */
1339UNUSUAL_DEV( 0x0dda, 0x0001, 0x0012, 0x0012,
1340 "WINWARD",
1341 "Music Disk",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001342 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001343 US_FL_IGNORE_RESIDUE ),
1344
1345/* Reported by Ian McConnell <ian at emit.demon.co.uk> */
1346UNUSUAL_DEV( 0x0dda, 0x0301, 0x0012, 0x0012,
1347 "PNP_MP3",
1348 "PNP_MP3 PLAYER",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001349 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001350 US_FL_IGNORE_RESIDUE ),
1351
Alan Stern982db2a2006-02-13 10:16:04 -05001352/* Reported by Jim McCloskey <mcclosk@ucsc.edu> */
1353UNUSUAL_DEV( 0x0e21, 0x0520, 0x0100, 0x0100,
1354 "Cowon Systems",
1355 "iAUDIO M5",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001356 USB_SC_DEVICE, USB_PR_BULK, NULL,
Phil Dibowitzbc724b92006-10-19 00:11:17 -07001357 US_FL_NEED_OVERRIDE ),
Alan Stern982db2a2006-02-13 10:16:04 -05001358
Linus Torvalds1da177e2005-04-16 15:20:36 -07001359/* Submitted by Antoine Mairesse <antoine.mairesse@free.fr> */
1360UNUSUAL_DEV( 0x0ed1, 0x6660, 0x0100, 0x0300,
1361 "USB",
1362 "Solid state disk",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001363 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001364 US_FL_FIX_INQUIRY ),
1365
1366/* Submitted by Daniel Drake <dsd@gentoo.org>
1367 * Reported by dayul on the Gentoo Forums */
1368UNUSUAL_DEV( 0x0ea0, 0x2168, 0x0110, 0x0110,
1369 "Ours Technology",
1370 "Flash Disk",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001371 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001372 US_FL_IGNORE_RESIDUE ),
1373
1374/* Reported by Rastislav Stanik <rs_kernel@yahoo.com> */
1375UNUSUAL_DEV( 0x0ea0, 0x6828, 0x0110, 0x0110,
1376 "USB",
1377 "Flash Disk",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001378 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001379 US_FL_IGNORE_RESIDUE ),
1380
Phil Dibowitz883d9892006-06-24 17:27:10 -07001381/* Reported by Benjamin Schiller <sbenni@gmx.de>
1382 * It is also sold by Easylite as DJ 20 */
1383UNUSUAL_DEV( 0x0ed1, 0x7636, 0x0103, 0x0103,
1384 "Typhoon",
1385 "My DJ 1820",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001386 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Phil Dibowitz883d9892006-06-24 17:27:10 -07001387 US_FL_IGNORE_RESIDUE | US_FL_GO_SLOW | US_FL_MAX_SECTORS_64),
1388
Robert Spitzenpfeil4e584072008-02-20 12:11:22 -05001389/* Patch by Leonid Petrov mail at lpetrov.net
1390 * Reported by Robert Spitzenpfeil <robert@spitzenpfeil.org>
1391 * http://www.qbik.ch/usb/devices/showdev.php?id=1705
1392 * Updated to 103 device by MJ Ray mjr at phonecoop.coop
1393 */
1394UNUSUAL_DEV( 0x0f19, 0x0103, 0x0100, 0x0100,
1395 "Oracom Co., Ltd",
1396 "ORC-200M",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001397 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Robert Spitzenpfeil4e584072008-02-20 12:11:22 -05001398 US_FL_IGNORE_RESIDUE ),
1399
David Kuehlingb41ee5d2006-08-07 10:18:48 -04001400/* David Kuehling <dvdkhlng@gmx.de>:
1401 * for MP3-Player AVOX WSX-300ER (bought in Japan). Reports lots of SCSI
1402 * errors when trying to write.
1403 */
1404UNUSUAL_DEV( 0x0f19, 0x0105, 0x0100, 0x0100,
1405 "C-MEX",
1406 "A-VOX",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001407 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
David Kuehlingb41ee5d2006-08-07 10:18:48 -04001408 US_FL_IGNORE_RESIDUE ),
1409
Nick Hollowayc25f6b12011-01-26 21:47:43 +00001410/* Submitted by Nick Holloway */
1411UNUSUAL_DEV( 0x0f88, 0x042e, 0x0100, 0x0100,
1412 "VTech",
1413 "Kidizoom",
1414 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
1415 US_FL_FIX_CAPACITY ),
1416
Linus Torvalds1da177e2005-04-16 15:20:36 -07001417/* Reported by Michael Stattmann <michael@stattmann.com> */
1418UNUSUAL_DEV( 0x0fce, 0xd008, 0x0000, 0x0000,
1419 "Sony Ericsson",
1420 "V800-Vodafone 802",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001421 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001422 US_FL_NO_WP_DETECT ),
1423
Phil Dibowitza83775b2009-01-20 23:48:36 +01001424/* Reported by The Solutor <thesolutor@gmail.com> */
1425UNUSUAL_DEV( 0x0fce, 0xd0e1, 0x0000, 0x0000,
1426 "Sony Ericsson",
1427 "MD400",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001428 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Phil Dibowitza83775b2009-01-20 23:48:36 +01001429 US_FL_IGNORE_DEVICE),
1430
Alan Sternb544d742007-01-31 10:57:55 -05001431/* Reported by Jan Mate <mate@fiit.stuba.sk>
1432 * and by Soeren Sonnenburg <kernel@nn7.de> */
Phil Dibowitz39c2f3a2006-09-11 00:27:40 -07001433UNUSUAL_DEV( 0x0fce, 0xe030, 0x0000, 0x0000,
1434 "Sony Ericsson",
1435 "P990i",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001436 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Sternb544d742007-01-31 10:57:55 -05001437 US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
Phil Dibowitz39c2f3a2006-09-11 00:27:40 -07001438
Phil Dibowitzc9c770e2006-08-27 23:54:37 -07001439/* Reported by Emmanuel Vasilakis <evas@forthnet.gr> */
1440UNUSUAL_DEV( 0x0fce, 0xe031, 0x0000, 0x0000,
1441 "Sony Ericsson",
1442 "M600i",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001443 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Phil Dibowitzc5f23b02008-05-26 21:33:58 +02001444 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
Phil Dibowitzc9c770e2006-08-27 23:54:37 -07001445
Alan Sternf9dc8f92008-11-18 14:08:07 -05001446/* Reported by Ricardo Barberis <ricardo@dattatec.com> */
1447UNUSUAL_DEV( 0x0fce, 0xe092, 0x0000, 0x0000,
1448 "Sony Ericsson",
1449 "P1i",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001450 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Sternf9dc8f92008-11-18 14:08:07 -05001451 US_FL_IGNORE_RESIDUE ),
1452
Linus Torvalds1da177e2005-04-16 15:20:36 -07001453/* Reported by Kevin Cernekee <kpc-usbdev@gelato.uiuc.edu>
1454 * Tested on hardware version 1.10.
1455 * Entry is needed only for the initializer function override.
Phil Dibowitz51b5bce2006-11-02 23:14:10 -08001456 * Devices with bcd > 110 seem to not need it while those
1457 * with bcd < 110 appear to need it.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001458 */
Phil Dibowitz51b5bce2006-11-02 23:14:10 -08001459UNUSUAL_DEV( 0x1019, 0x0c55, 0x0000, 0x0110,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001460 "Desknote",
1461 "UCR-61S2B",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001462 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_ucr61s2b_init,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001463 0 ),
1464
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001465UNUSUAL_DEV( 0x1058, 0x0704, 0x0000, 0x9999,
1466 "Western Digital",
1467 "External HDD",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001468 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001469 US_FL_SANE_SENSE),
1470
Alan Stern274399d2008-02-20 12:10:04 -05001471/* Reported by Fabio Venturi <f.venturi@tdnet.it>
1472 * The device reports a vendor-specific bDeviceClass.
1473 */
1474UNUSUAL_DEV( 0x10d6, 0x2200, 0x0100, 0x0100,
1475 "Actions Semiconductor",
1476 "Mtp device",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001477 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Stern274399d2008-02-20 12:10:04 -05001478 0),
1479
Pascal Terjanc00deaa2009-04-07 14:40:42 +02001480/* Reported by Pascal Terjan <pterjan@mandriva.com>
1481 * Ignore driver CD mode and force into modem mode by default.
1482 */
1483UNUSUAL_DEV( 0x1186, 0x3e04, 0x0000, 0x0000,
1484 "D-Link",
1485 "USB Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001486 USB_SC_DEVICE, USB_PR_DEVICE, option_ms_init, US_FL_IGNORE_DEVICE),
Pascal Terjanc00deaa2009-04-07 14:40:42 +02001487
Kevin Lloyd112225b2007-07-16 13:49:27 -07001488/* Reported by Kevin Lloyd <linux@sierrawireless.com>
1489 * Entry is needed for the initializer function override,
1490 * which instructs the device to load as a modem
1491 * device.
1492 */
1493UNUSUAL_DEV( 0x1199, 0x0fff, 0x0000, 0x9999,
1494 "Sierra Wireless",
1495 "USB MMC Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001496 USB_SC_DEVICE, USB_PR_DEVICE, sierra_ms_init,
Kevin Lloyd32fe5e32008-07-10 14:14:57 -07001497 0),
Kevin Lloyd112225b2007-07-16 13:49:27 -07001498
Jaco Kroon49314372006-11-15 01:02:08 -08001499/* Reported by Jaco Kroon <jaco@kroon.co.za>
1500 * The usb-storage module found on the Digitech GNX4 (and supposedly other
1501 * devices) misbehaves and causes a bunch of invalid I/O errors.
1502 */
1503UNUSUAL_DEV( 0x1210, 0x0003, 0x0100, 0x0100,
1504 "Digitech HMG",
1505 "DigiTech Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001506 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Jaco Kroon49314372006-11-15 01:02:08 -08001507 US_FL_IGNORE_RESIDUE ),
1508
fangxiaozhiaad8a272008-04-10 14:51:06 +08001509/* Reported by fangxiaozhi <huananhu@huawei.com>
1510 * This brings the HUAWEI data card devices into multi-port mode
Johann Wilhelmd853d872007-09-05 13:49:29 +02001511 */
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001512UNUSUAL_DEV( 0x12d1, 0x1001, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001513 "HUAWEI MOBILE",
1514 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001515 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001516 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001517UNUSUAL_DEV( 0x12d1, 0x1003, 0x0000, 0x0000,
Johann Wilhelmd853d872007-09-05 13:49:29 +02001518 "HUAWEI MOBILE",
1519 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001520 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
Johann Wilhelmd853d872007-09-05 13:49:29 +02001521 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001522UNUSUAL_DEV( 0x12d1, 0x1004, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001523 "HUAWEI MOBILE",
1524 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001525 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001526 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001527UNUSUAL_DEV( 0x12d1, 0x1401, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001528 "HUAWEI MOBILE",
1529 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001530 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001531 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001532UNUSUAL_DEV( 0x12d1, 0x1402, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001533 "HUAWEI MOBILE",
1534 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001535 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001536 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001537UNUSUAL_DEV( 0x12d1, 0x1403, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001538 "HUAWEI MOBILE",
1539 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001540 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001541 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001542UNUSUAL_DEV( 0x12d1, 0x1404, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001543 "HUAWEI MOBILE",
1544 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001545 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001546 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001547UNUSUAL_DEV( 0x12d1, 0x1405, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001548 "HUAWEI MOBILE",
1549 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001550 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001551 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001552UNUSUAL_DEV( 0x12d1, 0x1406, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001553 "HUAWEI MOBILE",
1554 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001555 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001556 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001557UNUSUAL_DEV( 0x12d1, 0x1407, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001558 "HUAWEI MOBILE",
1559 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001560 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001561 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001562UNUSUAL_DEV( 0x12d1, 0x1408, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001563 "HUAWEI MOBILE",
1564 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001565 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001566 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001567UNUSUAL_DEV( 0x12d1, 0x1409, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001568 "HUAWEI MOBILE",
1569 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001570 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001571 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001572UNUSUAL_DEV( 0x12d1, 0x140A, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001573 "HUAWEI MOBILE",
1574 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001575 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001576 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001577UNUSUAL_DEV( 0x12d1, 0x140B, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001578 "HUAWEI MOBILE",
1579 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001580 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001581 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001582UNUSUAL_DEV( 0x12d1, 0x140C, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001583 "HUAWEI MOBILE",
1584 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001585 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001586 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001587UNUSUAL_DEV( 0x12d1, 0x140D, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001588 "HUAWEI MOBILE",
1589 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001590 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001591 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001592UNUSUAL_DEV( 0x12d1, 0x140E, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001593 "HUAWEI MOBILE",
1594 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001595 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001596 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001597UNUSUAL_DEV( 0x12d1, 0x140F, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001598 "HUAWEI MOBILE",
1599 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001600 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001601 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001602UNUSUAL_DEV( 0x12d1, 0x1410, 0x0000, 0x0000,
1603 "HUAWEI MOBILE",
1604 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001605 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001606 0),
1607UNUSUAL_DEV( 0x12d1, 0x1411, 0x0000, 0x0000,
1608 "HUAWEI MOBILE",
1609 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001610 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001611 0),
1612UNUSUAL_DEV( 0x12d1, 0x1412, 0x0000, 0x0000,
1613 "HUAWEI MOBILE",
1614 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001615 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001616 0),
1617UNUSUAL_DEV( 0x12d1, 0x1413, 0x0000, 0x0000,
1618 "HUAWEI MOBILE",
1619 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001620 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001621 0),
1622UNUSUAL_DEV( 0x12d1, 0x1414, 0x0000, 0x0000,
1623 "HUAWEI MOBILE",
1624 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001625 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001626 0),
1627UNUSUAL_DEV( 0x12d1, 0x1415, 0x0000, 0x0000,
1628 "HUAWEI MOBILE",
1629 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001630 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001631 0),
1632UNUSUAL_DEV( 0x12d1, 0x1416, 0x0000, 0x0000,
1633 "HUAWEI MOBILE",
1634 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001635 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001636 0),
1637UNUSUAL_DEV( 0x12d1, 0x1417, 0x0000, 0x0000,
1638 "HUAWEI MOBILE",
1639 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001640 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001641 0),
1642UNUSUAL_DEV( 0x12d1, 0x1418, 0x0000, 0x0000,
1643 "HUAWEI MOBILE",
1644 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001645 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001646 0),
1647UNUSUAL_DEV( 0x12d1, 0x1419, 0x0000, 0x0000,
1648 "HUAWEI MOBILE",
1649 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001650 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001651 0),
1652UNUSUAL_DEV( 0x12d1, 0x141A, 0x0000, 0x0000,
1653 "HUAWEI MOBILE",
1654 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001655 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001656 0),
1657UNUSUAL_DEV( 0x12d1, 0x141B, 0x0000, 0x0000,
1658 "HUAWEI MOBILE",
1659 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001660 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001661 0),
1662UNUSUAL_DEV( 0x12d1, 0x141C, 0x0000, 0x0000,
1663 "HUAWEI MOBILE",
1664 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001665 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001666 0),
1667UNUSUAL_DEV( 0x12d1, 0x141D, 0x0000, 0x0000,
1668 "HUAWEI MOBILE",
1669 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001670 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001671 0),
1672UNUSUAL_DEV( 0x12d1, 0x141E, 0x0000, 0x0000,
1673 "HUAWEI MOBILE",
1674 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001675 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001676 0),
1677UNUSUAL_DEV( 0x12d1, 0x141F, 0x0000, 0x0000,
1678 "HUAWEI MOBILE",
1679 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001680 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001681 0),
1682UNUSUAL_DEV( 0x12d1, 0x1420, 0x0000, 0x0000,
1683 "HUAWEI MOBILE",
1684 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001685 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001686 0),
1687UNUSUAL_DEV( 0x12d1, 0x1421, 0x0000, 0x0000,
1688 "HUAWEI MOBILE",
1689 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001690 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001691 0),
1692UNUSUAL_DEV( 0x12d1, 0x1422, 0x0000, 0x0000,
1693 "HUAWEI MOBILE",
1694 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001695 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001696 0),
1697UNUSUAL_DEV( 0x12d1, 0x1423, 0x0000, 0x0000,
1698 "HUAWEI MOBILE",
1699 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001700 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001701 0),
1702UNUSUAL_DEV( 0x12d1, 0x1424, 0x0000, 0x0000,
1703 "HUAWEI MOBILE",
1704 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001705 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001706 0),
1707UNUSUAL_DEV( 0x12d1, 0x1425, 0x0000, 0x0000,
1708 "HUAWEI MOBILE",
1709 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001710 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001711 0),
1712UNUSUAL_DEV( 0x12d1, 0x1426, 0x0000, 0x0000,
1713 "HUAWEI MOBILE",
1714 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001715 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001716 0),
1717UNUSUAL_DEV( 0x12d1, 0x1427, 0x0000, 0x0000,
1718 "HUAWEI MOBILE",
1719 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001720 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001721 0),
1722UNUSUAL_DEV( 0x12d1, 0x1428, 0x0000, 0x0000,
1723 "HUAWEI MOBILE",
1724 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001725 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001726 0),
1727UNUSUAL_DEV( 0x12d1, 0x1429, 0x0000, 0x0000,
1728 "HUAWEI MOBILE",
1729 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001730 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001731 0),
1732UNUSUAL_DEV( 0x12d1, 0x142A, 0x0000, 0x0000,
1733 "HUAWEI MOBILE",
1734 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001735 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001736 0),
1737UNUSUAL_DEV( 0x12d1, 0x142B, 0x0000, 0x0000,
1738 "HUAWEI MOBILE",
1739 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001740 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001741 0),
1742UNUSUAL_DEV( 0x12d1, 0x142C, 0x0000, 0x0000,
1743 "HUAWEI MOBILE",
1744 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001745 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001746 0),
1747UNUSUAL_DEV( 0x12d1, 0x142D, 0x0000, 0x0000,
1748 "HUAWEI MOBILE",
1749 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001750 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001751 0),
1752UNUSUAL_DEV( 0x12d1, 0x142E, 0x0000, 0x0000,
1753 "HUAWEI MOBILE",
1754 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001755 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001756 0),
1757UNUSUAL_DEV( 0x12d1, 0x142F, 0x0000, 0x0000,
1758 "HUAWEI MOBILE",
1759 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001760 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001761 0),
1762UNUSUAL_DEV( 0x12d1, 0x1430, 0x0000, 0x0000,
1763 "HUAWEI MOBILE",
1764 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001765 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001766 0),
1767UNUSUAL_DEV( 0x12d1, 0x1431, 0x0000, 0x0000,
1768 "HUAWEI MOBILE",
1769 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001770 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001771 0),
1772UNUSUAL_DEV( 0x12d1, 0x1432, 0x0000, 0x0000,
1773 "HUAWEI MOBILE",
1774 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001775 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001776 0),
1777UNUSUAL_DEV( 0x12d1, 0x1433, 0x0000, 0x0000,
1778 "HUAWEI MOBILE",
1779 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001780 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001781 0),
1782UNUSUAL_DEV( 0x12d1, 0x1434, 0x0000, 0x0000,
1783 "HUAWEI MOBILE",
1784 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001785 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001786 0),
1787UNUSUAL_DEV( 0x12d1, 0x1435, 0x0000, 0x0000,
1788 "HUAWEI MOBILE",
1789 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001790 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001791 0),
1792UNUSUAL_DEV( 0x12d1, 0x1436, 0x0000, 0x0000,
1793 "HUAWEI MOBILE",
1794 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001795 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001796 0),
1797UNUSUAL_DEV( 0x12d1, 0x1437, 0x0000, 0x0000,
1798 "HUAWEI MOBILE",
1799 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001800 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001801 0),
1802UNUSUAL_DEV( 0x12d1, 0x1438, 0x0000, 0x0000,
1803 "HUAWEI MOBILE",
1804 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001805 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001806 0),
1807UNUSUAL_DEV( 0x12d1, 0x1439, 0x0000, 0x0000,
1808 "HUAWEI MOBILE",
1809 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001810 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001811 0),
1812UNUSUAL_DEV( 0x12d1, 0x143A, 0x0000, 0x0000,
1813 "HUAWEI MOBILE",
1814 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001815 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001816 0),
1817UNUSUAL_DEV( 0x12d1, 0x143B, 0x0000, 0x0000,
1818 "HUAWEI MOBILE",
1819 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001820 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001821 0),
1822UNUSUAL_DEV( 0x12d1, 0x143C, 0x0000, 0x0000,
1823 "HUAWEI MOBILE",
1824 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001825 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001826 0),
1827UNUSUAL_DEV( 0x12d1, 0x143D, 0x0000, 0x0000,
1828 "HUAWEI MOBILE",
1829 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001830 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001831 0),
1832UNUSUAL_DEV( 0x12d1, 0x143E, 0x0000, 0x0000,
1833 "HUAWEI MOBILE",
1834 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001835 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001836 0),
1837UNUSUAL_DEV( 0x12d1, 0x143F, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001838 "HUAWEI MOBILE",
1839 "Mass Storage",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001840 USB_SC_DEVICE, USB_PR_DEVICE, usb_stor_huawei_e220_init,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001841 0),
Johann Wilhelmd853d872007-09-05 13:49:29 +02001842
Phil Dibowitz7b1cbeb2005-05-02 23:54:28 -07001843/* Reported by Vilius Bilinkevicius <vilisas AT xxx DOT lt) */
1844UNUSUAL_DEV( 0x132b, 0x000b, 0x0001, 0x0001,
1845 "Minolta",
1846 "Dimage Z10",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001847 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Phil Dibowitz7b1cbeb2005-05-02 23:54:28 -07001848 0 ),
1849
Linus Torvalds1da177e2005-04-16 15:20:36 -07001850/* Reported by Kotrla Vitezslav <kotrla@ceb.cz> */
1851UNUSUAL_DEV( 0x1370, 0x6828, 0x0110, 0x0110,
1852 "SWISSBIT",
1853 "Black Silver",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001854 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001855 US_FL_IGNORE_RESIDUE ),
1856
Qinglin Yecec28a52011-11-23 23:39:32 +08001857/* Reported by Qinglin Ye <yestyle@gmail.com> */
1858UNUSUAL_DEV( 0x13fe, 0x3600, 0x0100, 0x0100,
1859 "Kingston",
1860 "DT 101 G2",
1861 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
1862 US_FL_BULK_IGNORE_TAG ),
1863
Phil Dibowitzf1cd4ad2006-12-31 00:19:50 -08001864/* Reported by Francesco Foresti <frafore@tiscali.it> */
1865UNUSUAL_DEV( 0x14cd, 0x6600, 0x0201, 0x0201,
1866 "Super Top",
1867 "IDE DEVICE",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001868 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Phil Dibowitzf1cd4ad2006-12-31 00:19:50 -08001869 US_FL_IGNORE_RESIDUE ),
1870
Phil Dibowitz3030ca42008-10-19 08:17:54 +02001871/* Reported by Alexandre Oliva <oliva@lsd.ic.unicamp.br>
1872 * JMicron responds to USN and several other SCSI ioctls with a
1873 * residue that causes subsequent I/O requests to fail. */
1874UNUSUAL_DEV( 0x152d, 0x2329, 0x0100, 0x0100,
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001875 "JMicron",
1876 "USB to ATA/ATAPI Bridge",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001877 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001878 US_FL_IGNORE_RESIDUE | US_FL_SANE_SENSE ),
Phil Dibowitz3030ca42008-10-19 08:17:54 +02001879
Phil Dibowitzf1cd4ad2006-12-31 00:19:50 -08001880/* Reported by Robert Schedel <r.schedel@yahoo.de>
1881 * Note: this is a 'super top' device like the above 14cd/6600 device */
1882UNUSUAL_DEV( 0x1652, 0x6600, 0x0201, 0x0201,
1883 "Teac",
1884 "HD-35PUK-B",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001885 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Phil Dibowitzf1cd4ad2006-12-31 00:19:50 -08001886 US_FL_IGNORE_RESIDUE ),
1887
Hans de Goedea78f4f12010-04-29 12:59:04 +02001888/* Reported by Hans de Goede <hdegoede@redhat.com>
1889 * These Appotech controllers are found in Picture Frames, they provide a
1890 * (buggy) emulation of a cdrom drive which contains the windows software
1891 * Uploading of pictures happens over the corresponding /dev/sg device. */
1892UNUSUAL_DEV( 0x1908, 0x1315, 0x0000, 0x0000,
1893 "BUILDWIN",
1894 "Photo Frame",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001895 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Hans de Goedea78f4f12010-04-29 12:59:04 +02001896 US_FL_BAD_SENSE ),
1897UNUSUAL_DEV( 0x1908, 0x1320, 0x0000, 0x0000,
1898 "BUILDWIN",
1899 "Photo Frame",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001900 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Hans de Goedea78f4f12010-04-29 12:59:04 +02001901 US_FL_BAD_SENSE ),
Hans de Goedeae38c782010-10-01 14:20:10 -07001902UNUSUAL_DEV( 0x1908, 0x3335, 0x0200, 0x0200,
1903 "BUILDWIN",
1904 "Photo Frame",
1905 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
1906 US_FL_NO_READ_DISC_INFO ),
Hans de Goedea78f4f12010-04-29 12:59:04 +02001907
Alan Stern21c13a42011-06-07 11:35:52 -04001908/* Reported by Sven Geggus <sven-usbst@geggus.net>
1909 * This encrypted pen drive returns bogus data for the initial READ(10).
1910 */
1911UNUSUAL_DEV( 0x1b1c, 0x1ab5, 0x0200, 0x0200,
1912 "Corsair",
1913 "Padlock v2",
1914 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
1915 US_FL_INITIAL_READ10 ),
1916
Al Virod36b6912011-12-29 17:09:01 -05001917/* Patch by Richard Schütz <r.schtz@t-online.de>
Richard Schütz7e1e7bd2010-12-22 14:28:56 +01001918 * This external hard drive enclosure uses a JMicron chip which
1919 * needs the US_FL_IGNORE_RESIDUE flag to work properly. */
1920UNUSUAL_DEV( 0x1e68, 0x001b, 0x0000, 0x0000,
1921 "TrekStor GmbH & Co. KG",
1922 "DataStation maxi g.u",
1923 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
1924 US_FL_IGNORE_RESIDUE | US_FL_SANE_SENSE ),
1925
Alan Stern3ea3c9b2011-01-25 13:07:04 -05001926/* Reported by Jasper Mackenzie <scarletpimpernal@hotmail.com> */
1927UNUSUAL_DEV( 0x1e74, 0x4621, 0x0000, 0x0000,
1928 "Coby Electronics",
1929 "MP3 Player",
1930 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
1931 US_FL_BULK_IGNORE_TAG | US_FL_MAX_SECTORS_64 ),
1932
Oliver Neukumb90de8a2009-01-14 16:17:19 +01001933UNUSUAL_DEV( 0x2116, 0x0320, 0x0001, 0x0001,
1934 "ST",
1935 "2A",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001936 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Oliver Neukumb90de8a2009-01-14 16:17:19 +01001937 US_FL_FIX_CAPACITY),
1938
Davide Perini0ddc0632006-06-19 17:07:39 -04001939/* patch submitted by Davide Perini <perini.davide@dpsoftware.org>
1940 * and Renato Perini <rperini@email.it>
1941 */
1942UNUSUAL_DEV( 0x22b8, 0x3010, 0x0001, 0x0001,
1943 "Motorola",
1944 "RAZR V3x",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001945 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Davide Perini0ddc0632006-06-19 17:07:39 -04001946 US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
1947
Pete Zaitceva7f3dd52007-03-10 15:17:16 -08001948/*
Constantin Baranovcc36bdd2008-03-16 20:04:23 +00001949 * Patch by Constantin Baranov <const@tltsu.ru>
1950 * Report by Andreas Koenecke.
1951 * Motorola ROKR Z6.
1952 */
1953UNUSUAL_DEV( 0x22b8, 0x6426, 0x0101, 0x0101,
1954 "Motorola",
1955 "MSnc.",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001956 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Constantin Baranovcc36bdd2008-03-16 20:04:23 +00001957 US_FL_FIX_INQUIRY | US_FL_FIX_CAPACITY | US_FL_BULK_IGNORE_TAG),
1958
Linus Torvalds1da177e2005-04-16 15:20:36 -07001959/* Reported by Radovan Garabik <garabik@kassiopeia.juls.savba.sk> */
1960UNUSUAL_DEV( 0x2735, 0x100b, 0x0000, 0x9999,
1961 "MPIO",
1962 "HS200",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001963 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001964 US_FL_GO_SLOW ),
1965
Frédéric Marchale8fab4c2008-10-13 14:00:11 +02001966/* Reported by Frederic Marchal <frederic.marchal@wowcompany.com>
1967 * Mio Moov 330
1968 */
1969UNUSUAL_DEV( 0x3340, 0xffff, 0x0000, 0x0000,
1970 "Mitac",
1971 "Mio DigiWalker USB Sync",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001972 USB_SC_DEVICE,USB_PR_DEVICE,NULL,
Frédéric Marchale8fab4c2008-10-13 14:00:11 +02001973 US_FL_MAX_SECTORS_64 ),
1974
Alan Stern368ee642008-07-21 10:08:28 -04001975/* Reported by Andrey Rahmatullin <wrar@altlinux.org> */
1976UNUSUAL_DEV( 0x4102, 0x1020, 0x0100, 0x0100,
1977 "iRiver",
1978 "MP3 T10",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001979 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Alan Stern368ee642008-07-21 10:08:28 -04001980 US_FL_IGNORE_RESIDUE ),
1981
Sergey Pinaev2f136122009-09-17 17:26:50 +04001982/* Reported by Sergey Pinaev <dfo@antex.ru> */
1983UNUSUAL_DEV( 0x4102, 0x1059, 0x0000, 0x0000,
1984 "iRiver",
1985 "P7K",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001986 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Sergey Pinaev2f136122009-09-17 17:26:50 +04001987 US_FL_MAX_SECTORS_64 ),
1988
David Härdeman63dc3ff2005-11-23 15:45:49 -08001989/*
Jan Engelhardt96de0e22007-10-19 23:21:04 +02001990 * David Härdeman <david@2gen.com>
David Härdeman63dc3ff2005-11-23 15:45:49 -08001991 * The key makes the SCSI stack print confusing (but harmless) messages
1992 */
1993UNUSUAL_DEV( 0x4146, 0xba01, 0x0100, 0x0100,
1994 "Iomega",
1995 "Micro Mini 1GB",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02001996 USB_SC_DEVICE, USB_PR_DEVICE, NULL, US_FL_NOT_LOCKABLE ),
David Härdeman63dc3ff2005-11-23 15:45:49 -08001997
Nick Bowlera871e4f2011-07-13 11:40:09 -04001998/*
1999 * Nick Bowler <nbowler@elliptictech.com>
2000 * SCSI stack spams (otherwise harmless) error messages.
2001 */
2002UNUSUAL_DEV( 0xc251, 0x4003, 0x0100, 0x0100,
2003 "Keil Software, Inc.",
2004 "V2M MotherBoard",
2005 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
2006 US_FL_NOT_LOCKABLE),
2007
Alan Sterna2149bc2006-02-02 09:52:45 -05002008/* Reported by Andrew Simmons <andrew.simmons@gmail.com> */
2009UNUSUAL_DEV( 0xed06, 0x4500, 0x0001, 0x0001,
2010 "DataStor",
2011 "USB4500 FW1.04",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02002012 USB_SC_DEVICE, USB_PR_DEVICE, NULL,
Oliver Neukum61bf54b2007-02-08 09:04:48 +01002013 US_FL_CAPACITY_HEURISTICS),
Alan Sterna2149bc2006-02-02 09:52:45 -05002014
Chuck Short46c6e932009-04-14 20:50:31 +02002015/* Reported by Alessio Treglia <quadrispro@ubuntu.com> */
2016UNUSUAL_DEV( 0xed10, 0x7636, 0x0001, 0x0001,
2017 "TGE",
2018 "Digital MP3 Audio Player",
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02002019 USB_SC_DEVICE, USB_PR_DEVICE, NULL, US_FL_NOT_LOCKABLE ),
Chuck Short46c6e932009-04-14 20:50:31 +02002020
Pete Zaitceva00828e2005-10-22 20:15:09 -07002021/* Control/Bulk transport for all SubClass values */
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02002022USUAL_DEV(USB_SC_RBC, USB_PR_CB, USB_US_TYPE_STOR),
2023USUAL_DEV(USB_SC_8020, USB_PR_CB, USB_US_TYPE_STOR),
2024USUAL_DEV(USB_SC_QIC, USB_PR_CB, USB_US_TYPE_STOR),
2025USUAL_DEV(USB_SC_UFI, USB_PR_CB, USB_US_TYPE_STOR),
2026USUAL_DEV(USB_SC_8070, USB_PR_CB, USB_US_TYPE_STOR),
2027USUAL_DEV(USB_SC_SCSI, USB_PR_CB, USB_US_TYPE_STOR),
Pete Zaitceva00828e2005-10-22 20:15:09 -07002028
2029/* Control/Bulk/Interrupt transport for all SubClass values */
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02002030USUAL_DEV(USB_SC_RBC, USB_PR_CBI, USB_US_TYPE_STOR),
2031USUAL_DEV(USB_SC_8020, USB_PR_CBI, USB_US_TYPE_STOR),
2032USUAL_DEV(USB_SC_QIC, USB_PR_CBI, USB_US_TYPE_STOR),
2033USUAL_DEV(USB_SC_UFI, USB_PR_CBI, USB_US_TYPE_STOR),
2034USUAL_DEV(USB_SC_8070, USB_PR_CBI, USB_US_TYPE_STOR),
2035USUAL_DEV(USB_SC_SCSI, USB_PR_CBI, USB_US_TYPE_STOR),
Pete Zaitceva00828e2005-10-22 20:15:09 -07002036
2037/* Bulk-only transport for all SubClass values */
Michal Nazarewicz8fa7fd72010-10-07 13:05:21 +02002038USUAL_DEV(USB_SC_RBC, USB_PR_BULK, USB_US_TYPE_STOR),
2039USUAL_DEV(USB_SC_8020, USB_PR_BULK, USB_US_TYPE_STOR),
2040USUAL_DEV(USB_SC_QIC, USB_PR_BULK, USB_US_TYPE_STOR),
2041USUAL_DEV(USB_SC_UFI, USB_PR_BULK, USB_US_TYPE_STOR),
2042USUAL_DEV(USB_SC_8070, USB_PR_BULK, USB_US_TYPE_STOR),
2043USUAL_DEV(USB_SC_SCSI, USB_PR_BULK, 0),