blob: 2c897eefadde592f9a0c6c4d671d0556acc764ca [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",
66 US_SC_DEVICE, US_PR_DEVICE, NULL,
67 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",
73 US_SC_DEVICE, US_PR_DEVICE, NULL,
74 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+",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -070079 US_SC_8070, US_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",
85 US_SC_DEVICE, US_PR_DEVICE, NULL,
86 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",
94 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_FIX_CAPACITY),
95
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",
103 US_SC_DEVICE, US_PR_DEVICE, NULL,
104 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",
110 US_SC_DEVICE, US_PR_DEVICE, NULL,
111 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",
120 US_SC_DEVICE, US_PR_DEVICE, NULL,
121 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",
127 US_SC_DEVICE, US_PR_DEVICE, NULL,
128 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",
133 US_SC_DEVICE, US_PR_DEVICE, NULL,
134 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",
140 US_SC_DEVICE, US_PR_DEVICE, NULL,
141 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",
147 US_SC_DEVICE, US_PR_DEVICE, NULL,
148 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. */
153 US_SC_DEVICE, US_PR_DEVICE, NULL,
154 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",
161 US_SC_DEVICE, US_PR_DEVICE, NULL,
162 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",
168 US_SC_DEVICE, US_PR_DEVICE, NULL,
169 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",
175 US_SC_DEVICE, US_PR_DEVICE, NULL,
176 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",
182 US_SC_DEVICE, US_PR_DEVICE, NULL,
183 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",
190 US_SC_DEVICE, US_PR_DEVICE, NULL,
191 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",
198 US_SC_DEVICE, US_PR_DEVICE, NULL,
199 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",
205 US_SC_DEVICE, US_PR_DEVICE, NULL,
206 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",
212 US_SC_DEVICE, US_PR_DEVICE, NULL,
213 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",
219 US_SC_DEVICE, US_PR_DEVICE, NULL,
220 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",
226 US_SC_DEVICE, US_PR_DEVICE, NULL,
227 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",
233 US_SC_SCSI, US_PR_CB, NULL,
234 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",
242 US_SC_DEVICE, US_PR_BULK, NULL,
243 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",
253 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_NOT_LOCKABLE ),
254
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",
263 US_SC_DEVICE, US_PR_DEVICE, NULL,
264 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",
275 US_SC_DEVICE, US_PR_DEVICE, NULL,
276 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",
287 US_SC_DEVICE, US_PR_DEVICE, NULL,
288 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",
294 US_SC_8070, US_PR_CB, NULL, US_FL_FIX_INQUIRY),
295
296/* Patch submitted by Philipp Friedrich <philipp@void.at> */
297UNUSUAL_DEV( 0x0482, 0x0101, 0x0100, 0x0100,
298 "Kyocera",
299 "Finecam S4",
300 US_SC_8070, US_PR_CB, NULL, US_FL_FIX_INQUIRY),
301
302/* Patch submitted by Stephane Galles <stephane.galles@free.fr> */
303UNUSUAL_DEV( 0x0482, 0x0103, 0x0100, 0x0100,
304 "Kyocera",
305 "Finecam S5",
306 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_FIX_INQUIRY),
307
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*",
312 US_SC_DEVICE, US_PR_DEVICE, NULL,
313 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",
320 US_SC_SCSI, US_PR_CB, NULL, US_FL_SINGLE_LUN),
321
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",
328 US_SC_DEVICE, US_PR_DEVICE, NULL,
329 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",
336 US_SC_DEVICE, US_PR_DEVICE,NULL,
337 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",
343 US_SC_DEVICE, US_PR_CB, NULL,
344 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",
351 US_SC_SCSI, US_PR_CB, NULL, US_FL_FIX_INQUIRY),
352
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",
358 US_SC_SCSI, US_PR_BULK, NULL, US_FL_SINGLE_LUN),
359
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",
366 US_SC_UFI, US_PR_DEVICE, NULL, US_FL_FIX_INQUIRY | US_FL_SINGLE_LUN),
367
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",
374 US_SC_DEVICE, US_PR_DEVICE, NULL,
375 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",
385 US_SC_UFI, US_PR_DEVICE, NULL, 0),
386
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",
392 US_SC_8070, US_PR_CB, NULL, 0),
393
394/* Reported by Adriaan Penning <a.penning@luon.net> */
395UNUSUAL_DEV( 0x04da, 0x2372, 0x0000, 0x9999,
396 "Panasonic",
397 "DMC-LCx Camera",
398 US_SC_DEVICE, US_PR_DEVICE, NULL,
399 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",
405 US_SC_DEVICE, US_PR_DEVICE, NULL,
406 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",
414 US_SC_8020, US_PR_CB, NULL, 0),
415
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",
419 US_SC_DEVICE, US_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",
426 US_SC_SCSI, US_PR_CB, NULL,
427 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",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700434 US_SC_SCSI, US_PR_CB, NULL,
435 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",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700441 US_SC_SCSI, US_PR_DEVICE, NULL,
442 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",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700447 US_SC_SCSI, US_PR_CB, NULL,
448 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",
453 US_SC_8020, US_PR_CB, NULL, 0),
454
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",
458 US_SC_8020, US_PR_CB, NULL, 0),
459
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",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700463 US_SC_SCSI, US_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",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700469 US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
470 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",
475 US_SC_8020, US_PR_CB, NULL, 0),
476
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",
481 US_SC_DEVICE, US_PR_DEVICE, NULL,
482 US_FL_MAX_SECTORS_64),
483
Phil Dibowitzed3e8fc2008-05-03 18:04:30 -0700484/* Entry and supporting patch by Theodore Kilgore <kilgota@auburn.edu>.
485 * Device uses standards-violating 32-byte Bulk Command Block Wrappers and
486 * reports itself as "Proprietary SCSI Bulk." Cf. device entry 0x084d:0x0011.
487 */
488UNUSUAL_DEV( 0x04fc, 0x80c2, 0x0100, 0x0100,
489 "Kobian Mercury",
490 "Binocam DCB-132",
491 US_SC_DEVICE, US_PR_DEVICE, NULL,
492 US_FL_BULK32),
493
Linus Torvalds1da177e2005-04-16 15:20:36 -0700494/* Reported by Bob Sass <rls@vectordb.com> -- only rev 1.33 tested */
495UNUSUAL_DEV( 0x050d, 0x0115, 0x0133, 0x0133,
496 "Belkin",
497 "USB SCSI Adaptor",
498 US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
499 US_FL_SCM_MULT_TARG ),
500
501/* Iomega Clik! Drive
502 * Reported by David Chatenay <dchatenay@hotmail.com>
503 * The reason this is needed is not fully known.
504 */
505UNUSUAL_DEV( 0x0525, 0xa140, 0x0100, 0x0100,
506 "Iomega",
507 "USB Clik! 40",
Phil Dibowitz21206382006-04-16 19:18:36 -0700508 US_SC_8070, US_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700509 US_FL_FIX_INQUIRY ),
510
Alan Stern25ff1c32008-12-15 12:43:41 -0500511/* Added by Alan Stern <stern@rowland.harvard.edu> */
512COMPLIANT_DEV(0x0525, 0xa4a5, 0x0000, 0x9999,
513 "Linux",
514 "File-backed Storage Gadget",
515 US_SC_DEVICE, US_PR_DEVICE, NULL,
516 US_FL_CAPACITY_OK ),
517
Linus Torvalds1da177e2005-04-16 15:20:36 -0700518/* Yakumo Mega Image 37
519 * Submitted by Stephan Fuhrmann <atomenergie@t-online.de> */
520UNUSUAL_DEV( 0x052b, 0x1801, 0x0100, 0x0100,
521 "Tekom Technologies, Inc",
522 "300_CAMERA",
523 US_SC_DEVICE, US_PR_DEVICE, NULL,
524 US_FL_IGNORE_RESIDUE ),
525
526/* Another Yakumo camera.
527 * Reported by Michele Alzetta <michele.alzetta@aliceposta.it> */
528UNUSUAL_DEV( 0x052b, 0x1804, 0x0100, 0x0100,
529 "Tekom Technologies, Inc",
530 "300_CAMERA",
531 US_SC_DEVICE, US_PR_DEVICE, NULL,
532 US_FL_IGNORE_RESIDUE ),
533
534/* Reported by Iacopo Spalletti <avvisi@spalletti.it> */
535UNUSUAL_DEV( 0x052b, 0x1807, 0x0100, 0x0100,
536 "Tekom Technologies, Inc",
537 "300_CAMERA",
538 US_SC_DEVICE, US_PR_DEVICE, NULL,
539 US_FL_IGNORE_RESIDUE ),
540
541/* Yakumo Mega Image 47
542 * Reported by Bjoern Paetzel <kolrabi@kolrabi.de> */
543UNUSUAL_DEV( 0x052b, 0x1905, 0x0100, 0x0100,
544 "Tekom Technologies, Inc",
545 "400_CAMERA",
546 US_SC_DEVICE, US_PR_DEVICE, NULL,
547 US_FL_IGNORE_RESIDUE ),
548
549/* Reported by Paul Ortyl <ortylp@3miasto.net>
550 * Note that it's similar to the device above, only different prodID */
551UNUSUAL_DEV( 0x052b, 0x1911, 0x0100, 0x0100,
552 "Tekom Technologies, Inc",
553 "400_CAMERA",
554 US_SC_DEVICE, US_PR_DEVICE, NULL,
555 US_FL_IGNORE_RESIDUE ),
556
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700557UNUSUAL_DEV( 0x054c, 0x0010, 0x0106, 0x0450,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700558 "Sony",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700559 "DSC-S30/S70/S75/505V/F505/F707/F717/P8",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700560 US_SC_SCSI, US_PR_DEVICE, NULL,
561 US_FL_SINGLE_LUN | US_FL_NOT_LOCKABLE | US_FL_NO_WP_DETECT ),
562
Lars Jacob7e3bd122006-07-10 11:53:58 -0400563/* Submitted by Lars Jacob <jacob.lars@googlemail.com>
564 * This entry is needed because the device reports Sub=ff */
565UNUSUAL_DEV( 0x054c, 0x0010, 0x0500, 0x0610,
Alexandre Duret-Lutzec7dc8d2005-12-26 23:04:24 -0800566 "Sony",
Lars Jacob7e3bd122006-07-10 11:53:58 -0400567 "DSC-T1/T5/H5",
Alexandre Duret-Lutzec7dc8d2005-12-26 23:04:24 -0800568 US_SC_8070, US_PR_DEVICE, NULL,
569 US_FL_SINGLE_LUN ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700570
571
572/* Reported by wim@geeks.nl */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700573UNUSUAL_DEV( 0x054c, 0x0025, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700574 "Sony",
575 "Memorystick NW-MS7",
576 US_SC_DEVICE, US_PR_DEVICE, NULL,
577 US_FL_SINGLE_LUN ),
578
Linus Torvalds1da177e2005-04-16 15:20:36 -0700579/* Submitted by Olaf Hering, <olh@suse.de> SuSE Bugzilla #49049 */
Luiz Fernando N. Capitulino20b2e282007-01-24 16:19:37 -0200580UNUSUAL_DEV( 0x054c, 0x002c, 0x0501, 0x2000,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700581 "Sony",
582 "USB Floppy Drive",
583 US_SC_DEVICE, US_PR_DEVICE, NULL,
584 US_FL_SINGLE_LUN ),
585
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700586UNUSUAL_DEV( 0x054c, 0x002d, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700587 "Sony",
588 "Memorystick MSAC-US1",
589 US_SC_DEVICE, US_PR_DEVICE, NULL,
590 US_FL_SINGLE_LUN ),
591
592/* Submitted by Klaus Mueller <k.mueller@intershop.de> */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700593UNUSUAL_DEV( 0x054c, 0x002e, 0x0106, 0x0310,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700594 "Sony",
595 "Handycam",
596 US_SC_SCSI, US_PR_DEVICE, NULL,
597 US_FL_SINGLE_LUN ),
598
599/* Submitted by Rajesh Kumble Nayak <nayak@obs-nice.fr> */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700600UNUSUAL_DEV( 0x054c, 0x002e, 0x0500, 0x0500,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700601 "Sony",
602 "Handycam HC-85",
603 US_SC_UFI, US_PR_DEVICE, NULL,
604 US_FL_SINGLE_LUN ),
605
606UNUSUAL_DEV( 0x054c, 0x0032, 0x0000, 0x9999,
607 "Sony",
608 "Memorystick MSC-U01N",
609 US_SC_DEVICE, US_PR_DEVICE, NULL,
610 US_FL_SINGLE_LUN ),
611
612/* Submitted by Michal Mlotek <mlotek@foobar.pl> */
613UNUSUAL_DEV( 0x054c, 0x0058, 0x0000, 0x9999,
614 "Sony",
615 "PEG N760c Memorystick",
616 US_SC_DEVICE, US_PR_DEVICE, NULL,
617 US_FL_FIX_INQUIRY ),
618
619UNUSUAL_DEV( 0x054c, 0x0069, 0x0000, 0x9999,
620 "Sony",
621 "Memorystick MSC-U03",
622 US_SC_UFI, US_PR_CB, NULL,
623 US_FL_SINGLE_LUN ),
624
625/* Submitted by Nathan Babb <nathan@lexi.com> */
626UNUSUAL_DEV( 0x054c, 0x006d, 0x0000, 0x9999,
627 "Sony",
628 "PEG Mass Storage",
629 US_SC_DEVICE, US_PR_DEVICE, NULL,
630 US_FL_FIX_INQUIRY ),
631
Alan Sternf9dc8f92008-11-18 14:08:07 -0500632/* Submitted by Frank Engel <frankie@cse.unsw.edu.au> */
633UNUSUAL_DEV( 0x054c, 0x0099, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700634 "Sony",
635 "PEG Mass Storage",
636 US_SC_DEVICE, US_PR_DEVICE, NULL,
637 US_FL_FIX_INQUIRY ),
Alan Sternf9dc8f92008-11-18 14:08:07 -0500638
639/* Submitted by Mike Alborn <malborn@deandra.homeip.net> */
640UNUSUAL_DEV( 0x054c, 0x016a, 0x0000, 0x9999,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700641 "Sony",
642 "PEG Mass Storage",
643 US_SC_DEVICE, US_PR_DEVICE, NULL,
644 US_FL_FIX_INQUIRY ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700645
juergen.mell@t-online.de082fdd12006-08-28 13:53:53 -0700646/* floppy reports multiple luns */
647UNUSUAL_DEV( 0x055d, 0x2020, 0x0000, 0x0210,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700648 "SAMSUNG",
649 "SFD-321U [FW 0C]",
650 US_SC_DEVICE, US_PR_DEVICE, NULL,
651 US_FL_SINGLE_LUN ),
juergen.mell@t-online.de082fdd12006-08-28 13:53:53 -0700652
Pete Zaitcevfd4f3a92009-08-20 20:00:19 -0600653/* We keep this entry to force the transport; firmware 3.00 and later is ok. */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700654UNUSUAL_DEV( 0x057b, 0x0000, 0x0000, 0x0299,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700655 "Y-E Data",
656 "Flashbuster-U",
657 US_SC_DEVICE, US_PR_CB, NULL,
658 US_FL_SINGLE_LUN),
659
Linus Torvalds1da177e2005-04-16 15:20:36 -0700660/* Reported by Johann Cardon <johann.cardon@free.fr>
661 * This entry is needed only because the device reports
662 * bInterfaceClass = 0xff (vendor-specific)
663 */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700664UNUSUAL_DEV( 0x057b, 0x0022, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700665 "Y-E Data",
666 "Silicon Media R/W",
667 US_SC_DEVICE, US_PR_DEVICE, NULL, 0),
668
Alan Sternf1e8de0d2007-11-26 10:23:05 -0500669/* Reported by RTE <raszilki@yandex.ru> */
670UNUSUAL_DEV( 0x058f, 0x6387, 0x0141, 0x0141,
671 "JetFlash",
672 "TS1GJF2A/120",
673 US_SC_DEVICE, US_PR_DEVICE, NULL,
674 US_FL_MAX_SECTORS_64 ),
675
Linus Torvalds1da177e2005-04-16 15:20:36 -0700676/* Fabrizio Fellini <fello@libero.it> */
677UNUSUAL_DEV( 0x0595, 0x4343, 0x0000, 0x2210,
678 "Fujifilm",
679 "Digital Camera EX-20 DSC",
680 US_SC_8070, US_PR_DEVICE, NULL, 0 ),
681
Alan Sterna4625492008-02-13 10:45:28 -0500682/* Reported by Andre Welter <a.r.welter@gmx.de>
683 * This antique device predates the release of the Bulk-only Transport
684 * spec, and if it gets a Get-Max-LUN then it requires the host to do a
685 * Clear-Halt on the bulk endpoints. The SINGLE_LUN flag will prevent
686 * us from sending the request.
687 */
688UNUSUAL_DEV( 0x059b, 0x0001, 0x0100, 0x0100,
689 "Iomega",
690 "ZIP 100",
691 US_SC_DEVICE, US_PR_DEVICE, NULL,
692 US_FL_SINGLE_LUN ),
693
Alan Sternb97b1962006-09-14 15:18:54 -0400694/* Reported by <Hendryk.Pfeiffer@gmx.de> */
695UNUSUAL_DEV( 0x059f, 0x0643, 0x0000, 0x0000,
696 "LaCie",
697 "DVD+-RW",
698 US_SC_DEVICE, US_PR_DEVICE, NULL,
699 US_FL_GO_SLOW ),
700
Linus Torvalds1da177e2005-04-16 15:20:36 -0700701/* Submitted by Joel Bourquard <numlock@freesurf.ch>
702 * Some versions of this device need the SubClass and Protocol overrides
703 * while others don't.
704 */
705UNUSUAL_DEV( 0x05ab, 0x0060, 0x1104, 0x1110,
706 "In-System",
707 "PyroGate External CD-ROM Enclosure (FCD-523)",
708 US_SC_SCSI, US_PR_BULK, NULL,
709 US_FL_NEED_OVERRIDE ),
710
Sven Anderson35f4a0c2005-04-22 15:06:58 -0700711/* Submitted by Sven Anderson <sven-linux@anderson.de>
712 * There are at least four ProductIDs used for iPods, so I added 0x1202 and
713 * 0x1204. They just need the US_FL_FIX_CAPACITY. As the bcdDevice appears
714 * to change with firmware updates, I changed the range to maximum for all
715 * iPod entries.
716 */
717UNUSUAL_DEV( 0x05ac, 0x1202, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700718 "Apple",
719 "iPod",
720 US_SC_DEVICE, US_PR_DEVICE, NULL,
721 US_FL_FIX_CAPACITY ),
722
Sven Anderson35f4a0c2005-04-22 15:06:58 -0700723/* Reported by Avi Kivity <avi@argo.co.il> */
724UNUSUAL_DEV( 0x05ac, 0x1203, 0x0000, 0x9999,
725 "Apple",
726 "iPod",
727 US_SC_DEVICE, US_PR_DEVICE, NULL,
728 US_FL_FIX_CAPACITY ),
729
730UNUSUAL_DEV( 0x05ac, 0x1204, 0x0000, 0x9999,
731 "Apple",
732 "iPod",
733 US_SC_DEVICE, US_PR_DEVICE, NULL,
Pete Zaitcevad1428c2006-12-31 13:43:26 -0800734 US_FL_FIX_CAPACITY | US_FL_NOT_LOCKABLE ),
Sven Anderson35f4a0c2005-04-22 15:06:58 -0700735
736UNUSUAL_DEV( 0x05ac, 0x1205, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700737 "Apple",
738 "iPod",
739 US_SC_DEVICE, US_PR_DEVICE, NULL,
740 US_FL_FIX_CAPACITY ),
741
Phil Dibowitz880a9b52005-09-30 00:27:36 -0700742/*
743 * Reported by Tyson Vinson <lornoss@gmail.com>
744 * This particular productId is the iPod Nano
745 */
746UNUSUAL_DEV( 0x05ac, 0x120a, 0x0000, 0x9999,
747 "Apple",
748 "iPod",
749 US_SC_DEVICE, US_PR_DEVICE, NULL,
750 US_FL_FIX_CAPACITY ),
751
Dan Williams281b0642008-12-14 12:39:22 -0500752/* Reported by Dan Williams <dcbw@redhat.com>
753 * Option N.V. mobile broadband modems
754 * Ignore driver CD mode and force into modem mode by default.
755 */
756
757/* Globetrotter HSDPA; mass storage shows up as Qualcomm for vendor */
758UNUSUAL_DEV( 0x05c6, 0x1000, 0x0000, 0x9999,
759 "Option N.V.",
760 "Mass Storage",
761 US_SC_DEVICE, US_PR_DEVICE, option_ms_init,
762 0),
763
Linus Torvalds1da177e2005-04-16 15:20:36 -0700764/* Reported by Blake Matheny <bmatheny@purdue.edu> */
765UNUSUAL_DEV( 0x05dc, 0xb002, 0x0000, 0x0113,
766 "Lexar",
767 "USB CF Reader",
768 US_SC_DEVICE, US_PR_DEVICE, NULL,
769 US_FL_FIX_INQUIRY ),
770
771/* The following two entries are for a Genesys USB to IDE
772 * converter chip, but it changes its ProductId depending
773 * on whether or not a disk or an optical device is enclosed
774 * They were originally reported by Alexander Oltu
775 * <alexander@all-2.com> and Peter Marks <peter.marks@turner.com>
776 * respectively.
Phil Dibowitz883d9892006-06-24 17:27:10 -0700777 *
778 * US_FL_GO_SLOW and US_FL_MAX_SECTORS_64 added by Phil Dibowitz
779 * <phil@ipom.com> as these flags were made and hard-coded
780 * special-cases were pulled from scsiglue.c.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700781 */
782UNUSUAL_DEV( 0x05e3, 0x0701, 0x0000, 0xffff,
783 "Genesys Logic",
784 "USB to IDE Optical",
785 US_SC_DEVICE, US_PR_DEVICE, NULL,
Alan Stern5126a262009-02-23 12:02:05 -0500786 US_FL_GO_SLOW | US_FL_MAX_SECTORS_64 | US_FL_IGNORE_RESIDUE ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700787
788UNUSUAL_DEV( 0x05e3, 0x0702, 0x0000, 0xffff,
789 "Genesys Logic",
790 "USB to IDE Disk",
791 US_SC_DEVICE, US_PR_DEVICE, NULL,
Alan Stern5126a262009-02-23 12:02:05 -0500792 US_FL_GO_SLOW | US_FL_MAX_SECTORS_64 | US_FL_IGNORE_RESIDUE ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700793
Ben Efrosdbe6e0c02008-11-23 20:06:38 -0800794/* Reported by Ben Efros <ben@pc-doctor.com> */
795UNUSUAL_DEV( 0x05e3, 0x0723, 0x9451, 0x9451,
796 "Genesys Logic",
797 "USB to SATA",
798 US_SC_DEVICE, US_PR_DEVICE, NULL,
799 US_FL_SANE_SENSE ),
800
Linus Torvalds1da177e2005-04-16 15:20:36 -0700801/* Reported by Hanno Boeck <hanno@gmx.de>
802 * Taken from the Lycoris Kernel */
803UNUSUAL_DEV( 0x0636, 0x0003, 0x0000, 0x9999,
804 "Vivitar",
805 "Vivicam 35Xx",
806 US_SC_SCSI, US_PR_BULK, NULL,
807 US_FL_FIX_INQUIRY ),
808
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700809UNUSUAL_DEV( 0x0644, 0x0000, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700810 "TEAC",
811 "Floppy Drive",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700812 US_SC_UFI, US_PR_CB, NULL, 0 ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700813
Linus Torvalds1da177e2005-04-16 15:20:36 -0700814/* Reported by Darsen Lu <darsen@micro.ee.nthu.edu.tw> */
815UNUSUAL_DEV( 0x066f, 0x8000, 0x0001, 0x0001,
816 "SigmaTel",
817 "USBMSC Audio Player",
818 US_SC_DEVICE, US_PR_DEVICE, NULL,
819 US_FL_FIX_CAPACITY ),
820
Alan Sterna0bb1082009-12-07 16:39:16 -0500821/* Reported by Daniel Kukula <daniel.kuku@gmail.com> */
822UNUSUAL_DEV( 0x067b, 0x1063, 0x0100, 0x0100,
823 "Prolific Technology, Inc.",
824 "Prolific Storage Gadget",
825 US_SC_DEVICE, US_PR_DEVICE, NULL,
826 US_FL_BAD_SENSE ),
827
Rogerio Britoc15e3ca2009-08-06 15:20:19 -0700828/* Reported by Rogerio Brito <rbrito@ime.usp.br> */
829UNUSUAL_DEV( 0x067b, 0x2317, 0x0001, 0x001,
830 "Prolific Technology, Inc.",
831 "Mass Storage Device",
832 US_SC_DEVICE, US_PR_DEVICE, NULL,
833 US_FL_NOT_LOCKABLE ),
834
Linus Torvalds1da177e2005-04-16 15:20:36 -0700835/* Reported by Richard -=[]=- <micro_flyer@hotmail.com> */
Thomas Bartosik8a0845c2009-03-16 16:04:38 +0100836/* Change to bcdDeviceMin (0x0100 to 0x0001) reported by
837 * Thomas Bartosik <tbartdev@gmx-topmail.de> */
838UNUSUAL_DEV( 0x067b, 0x2507, 0x0001, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700839 "Prolific Technology Inc.",
840 "Mass Storage Device",
841 US_SC_DEVICE, US_PR_DEVICE, NULL,
842 US_FL_FIX_CAPACITY | US_FL_GO_SLOW ),
843
844/* Reported by Alex Butcher <alex.butcher@assursys.co.uk> */
Oliver Neukumb1636392008-12-12 11:01:45 +0100845UNUSUAL_DEV( 0x067b, 0x3507, 0x0001, 0x0101,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700846 "Prolific Technology Inc.",
847 "ATAPI-6 Bridge Controller",
848 US_SC_DEVICE, US_PR_DEVICE, NULL,
849 US_FL_FIX_CAPACITY | US_FL_GO_SLOW ),
850
851/* Submitted by Benny Sjostrand <benny@hostmobility.com> */
852UNUSUAL_DEV( 0x0686, 0x4011, 0x0001, 0x0001,
853 "Minolta",
854 "Dimage F300",
855 US_SC_SCSI, US_PR_BULK, NULL, 0 ),
856
857/* Reported by Miguel A. Fosas <amn3s1a@ono.com> */
858UNUSUAL_DEV( 0x0686, 0x4017, 0x0001, 0x0001,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700859 "Minolta",
860 "DIMAGE E223",
861 US_SC_SCSI, US_PR_DEVICE, NULL, 0 ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700862
Linus Torvalds1da177e2005-04-16 15:20:36 -0700863UNUSUAL_DEV( 0x0693, 0x0005, 0x0100, 0x0100,
864 "Hagiwara",
865 "Flashgate",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700866 US_SC_SCSI, US_PR_BULK, NULL, 0 ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700867
Alan Stern754501b2006-02-23 10:19:25 -0500868/* Reported by David Hamilton <niftimusmaximus@lycos.com> */
869UNUSUAL_DEV( 0x069b, 0x3004, 0x0001, 0x0001,
870 "Thomson Multimedia Inc.",
871 "RCA RD1080 MP3 Player",
872 US_SC_DEVICE, US_PR_DEVICE, NULL,
873 US_FL_FIX_CAPACITY ),
874
Alan Sternfe1926a2008-09-04 09:56:35 -0400875/* Reported by Adrian Pilchowiec <adi1981@epf.pl> */
876UNUSUAL_DEV( 0x071b, 0x3203, 0x0000, 0x0000,
877 "RockChip",
878 "MP3",
879 US_SC_DEVICE, US_PR_DEVICE, NULL,
880 US_FL_NO_WP_DETECT | US_FL_MAX_SECTORS_64),
881
Jean-Baptiste Onofre64915092008-12-20 20:11:55 +0100882/* Reported by Jean-Baptiste Onofre <jb@nanthrax.net>
883 * Support the following product :
884 * "Dane-Elec MediaTouch"
885 */
886UNUSUAL_DEV( 0x071b, 0x32bb, 0x0000, 0x0000,
887 "RockChip",
888 "MTP",
889 US_SC_DEVICE, US_PR_DEVICE, NULL,
890 US_FL_NO_WP_DETECT | US_FL_MAX_SECTORS_64),
891
Massimiliano Ghilardic4766562007-09-04 22:53:43 +0200892/* Reported by Massimiliano Ghilardi <massimiliano.ghilardi@gmail.com>
893 * This USB MP3/AVI player device fails and disconnects if more than 128
894 * sectors (64kB) are read/written in a single command, and may be present
895 * at least in the following products:
896 * "Magnex Digital Video Panel DVP 1800"
897 * "MP4 AIGO 4GB SLOT SD"
898 * "Teclast TL-C260 MP3"
899 * "i.Meizu PMP MP3/MP4"
900 * "Speed MV8 MP4 Audio Player"
901 */
902UNUSUAL_DEV( 0x071b, 0x3203, 0x0100, 0x0100,
903 "RockChip",
904 "ROCK MP3",
905 US_SC_DEVICE, US_PR_DEVICE, NULL,
906 US_FL_MAX_SECTORS_64),
907
Olivier Blondeauf430c402006-04-16 19:19:25 -0700908/* Reported by Olivier Blondeau <zeitoun@gmail.com> */
909UNUSUAL_DEV( 0x0727, 0x0306, 0x0100, 0x0100,
910 "ATMEL",
911 "SND1 Storage",
912 US_SC_DEVICE, US_PR_DEVICE, NULL,
913 US_FL_IGNORE_RESIDUE),
914
Phil Dibowitz1e7a5a82006-03-05 21:36:51 -0800915/* Submitted by Roman Hodek <roman@hodek.net> */
916UNUSUAL_DEV( 0x0781, 0x0001, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700917 "Sandisk",
918 "ImageMate SDDR-05a",
919 US_SC_SCSI, US_PR_CB, NULL,
920 US_FL_SINGLE_LUN ),
921
Phil Dibowitz1e7a5a82006-03-05 21:36:51 -0800922UNUSUAL_DEV( 0x0781, 0x0002, 0x0009, 0x0009,
923 "SanDisk Corporation",
924 "ImageMate CompactFlash USB",
925 US_SC_DEVICE, US_PR_DEVICE, NULL,
926 US_FL_FIX_CAPACITY ),
927
Linus Torvalds1da177e2005-04-16 15:20:36 -0700928UNUSUAL_DEV( 0x0781, 0x0100, 0x0100, 0x0100,
929 "Sandisk",
930 "ImageMate SDDR-12",
931 US_SC_SCSI, US_PR_CB, NULL,
932 US_FL_SINGLE_LUN ),
933
Linus Torvalds1da177e2005-04-16 15:20:36 -0700934/* Reported by Eero Volotinen <eero@ping-viini.org> */
Phil Dibowitze5278322005-10-23 23:52:39 -0700935UNUSUAL_DEV( 0x07ab, 0xfccd, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700936 "Freecom Technologies",
937 "FHD-Classic",
938 US_SC_DEVICE, US_PR_DEVICE, NULL,
939 US_FL_FIX_CAPACITY),
940
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700941UNUSUAL_DEV( 0x07af, 0x0004, 0x0100, 0x0133,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700942 "Microtech",
943 "USB-SCSI-DB25",
Phil Dibowitz39232b3d2010-01-16 19:52:17 +0100944 US_SC_DEVICE, US_PR_DEVICE, usb_stor_euscsi_init,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700945 US_FL_SCM_MULT_TARG ),
946
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700947UNUSUAL_DEV( 0x07af, 0x0005, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700948 "Microtech",
949 "USB-SCSI-HD50",
Phil Dibowitze8116e82005-06-22 22:47:13 -0700950 US_SC_DEVICE, US_PR_DEVICE, usb_stor_euscsi_init,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700951 US_FL_SCM_MULT_TARG ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700952
Alan Stern0ff71882009-02-12 14:47:49 -0500953#ifdef NO_SDDR09
Alan Sternc20b15f2008-12-01 10:36:15 -0500954UNUSUAL_DEV( 0x07af, 0x0006, 0x0100, 0x0100,
955 "Microtech",
956 "CameraMate",
957 US_SC_SCSI, US_PR_CB, NULL,
958 US_FL_SINGLE_LUN ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700959#endif
960
Linus Torvalds1da177e2005-04-16 15:20:36 -0700961/* Datafab KECF-USB / Sagatek DCS-CF / Simpletech Flashlink UCF-100
962 * Only revision 1.13 tested (same for all of the above devices,
963 * based on the Datafab DF-UG-07 chip). Needed for US_FL_FIX_INQUIRY.
964 * Submitted by Marek Michalkiewicz <marekm@amelek.gda.pl>.
965 * See also http://martin.wilck.bei.t-online.de/#kecf .
966 */
967UNUSUAL_DEV( 0x07c4, 0xa400, 0x0000, 0xffff,
968 "Datafab",
969 "KECF-USB",
970 US_SC_DEVICE, US_PR_DEVICE, NULL,
Nick Holloway049a6ac2009-01-25 16:58:43 +0000971 US_FL_FIX_INQUIRY | US_FL_FIX_CAPACITY ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700972
Alan Sterne4813ee2009-03-24 10:39:13 -0400973/* Reported by Rauch Wolke <rauchwolke@gmx.net>
974 * and augmented by binbin <binbinsh@gmail.com> (Bugzilla #12882)
975 */
Alan Stern368ee642008-07-21 10:08:28 -0400976UNUSUAL_DEV( 0x07c4, 0xa4a5, 0x0000, 0xffff,
977 "Simple Tech/Datafab",
978 "CF+SM Reader",
979 US_SC_DEVICE, US_PR_DEVICE, NULL,
Alan Sterne4813ee2009-03-24 10:39:13 -0400980 US_FL_IGNORE_RESIDUE | US_FL_MAX_SECTORS_64 ),
Alan Stern368ee642008-07-21 10:08:28 -0400981
Linus Torvalds1da177e2005-04-16 15:20:36 -0700982/* Casio QV 2x00/3x00/4000/8000 digital still cameras are not conformant
983 * to the USB storage specification in two ways:
984 * - They tell us they are using transport protocol CBI. In reality they
985 * are using transport protocol CB.
986 * - They don't like the INQUIRY command. So we must handle this command
987 * of the SCSI layer ourselves.
988 * - Some cameras with idProduct=0x1001 and bcdDevice=0x1000 have
989 * bInterfaceProtocol=0x00 (US_PR_CBI) while others have 0x01 (US_PR_CB).
990 * So don't remove the US_PR_CB override!
991 * - Cameras with bcdDevice=0x9009 require the US_SC_8070 override.
992 */
993UNUSUAL_DEV( 0x07cf, 0x1001, 0x1000, 0x9999,
994 "Casio",
995 "QV DigitalCamera",
996 US_SC_8070, US_PR_CB, NULL,
997 US_FL_NEED_OVERRIDE | US_FL_FIX_INQUIRY ),
998
999/* Submitted by Hartmut Wahl <hwahl@hwahl.de>*/
1000UNUSUAL_DEV( 0x0839, 0x000a, 0x0001, 0x0001,
1001 "Samsung",
1002 "Digimax 410",
1003 US_SC_DEVICE, US_PR_DEVICE, NULL,
1004 US_FL_FIX_INQUIRY),
1005
Alan Stern8010e062008-11-04 11:33:35 -05001006/* Reported by Luciano Rocha <luciano@eurotux.com> */
1007UNUSUAL_DEV( 0x0840, 0x0082, 0x0001, 0x0001,
1008 "Argosy",
1009 "Storage",
1010 US_SC_DEVICE, US_PR_DEVICE, NULL,
1011 US_FL_FIX_CAPACITY),
1012
Nguyen Anh Quynhe2673b22008-12-11 15:04:11 -08001013/* Reported and patched by Nguyen Anh Quynh <aquynh@gmail.com> */
1014UNUSUAL_DEV( 0x0840, 0x0084, 0x0001, 0x0001,
1015 "Argosy",
1016 "Storage",
1017 US_SC_DEVICE, US_PR_DEVICE, NULL,
1018 US_FL_FIX_CAPACITY),
1019
Phil Dibowitzaa23c8d2009-01-20 23:42:52 +01001020/* Reported by Martijn Hijdra <martijn.hijdra@gmail.com> */
1021UNUSUAL_DEV( 0x0840, 0x0085, 0x0001, 0x0001,
1022 "Argosy",
1023 "Storage",
1024 US_SC_DEVICE, US_PR_DEVICE, NULL,
1025 US_FL_FIX_CAPACITY),
1026
Linus Torvalds1da177e2005-04-16 15:20:36 -07001027/* Entry and supporting patch by Theodore Kilgore <kilgota@auburn.edu>.
1028 * Flag will support Bulk devices which use a standards-violating 32-byte
1029 * Command Block Wrapper. Here, the "DC2MEGA" cameras (several brands) with
1030 * Grandtech GT892x chip, which request "Proprietary SCSI Bulk" support.
1031 */
1032
1033UNUSUAL_DEV( 0x084d, 0x0011, 0x0110, 0x0110,
1034 "Grandtech",
1035 "DC2MEGA",
1036 US_SC_DEVICE, US_PR_DEVICE, NULL,
1037 US_FL_BULK32),
1038
Andrew Lunnf7687212008-04-24 19:36:39 +02001039/* Andrew Lunn <andrew@lunn.ch>
1040 * PanDigital Digital Picture Frame. Does not like ALLOW_MEDIUM_REMOVAL
1041 * on LUN 4.
1042 * Note: Vend:Prod clash with "Ltd Maxell WS30 Slim Digital Camera"
1043*/
1044UNUSUAL_DEV( 0x0851, 0x1543, 0x0200, 0x0200,
1045 "PanDigital",
1046 "Photo Frame",
1047 US_SC_DEVICE, US_PR_DEVICE, NULL,
1048 US_FL_NOT_LOCKABLE),
1049
Alan Sternba3e93a2006-01-30 10:19:43 -05001050/* Submitted by Jan De Luyck <lkml@kcore.org> */
1051UNUSUAL_DEV( 0x08bd, 0x1100, 0x0000, 0x0000,
1052 "CITIZEN",
1053 "X1DE-USB",
1054 US_SC_DEVICE, US_PR_DEVICE, NULL,
1055 US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001056
Dylan Tafta7e555b2007-02-05 16:41:01 -08001057/* Submitted by Dylan Taft <d13f00l@gmail.com>
1058 * US_FL_IGNORE_RESIDUE Needed
1059 */
1060UNUSUAL_DEV( 0x08ca, 0x3103, 0x0100, 0x0100,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001061 "AIPTEK",
1062 "Aiptek USB Keychain MP3 Player",
1063 US_SC_DEVICE, US_PR_DEVICE, NULL,
1064 US_FL_IGNORE_RESIDUE),
Dylan Tafta7e555b2007-02-05 16:41:01 -08001065
Linus Torvalds1da177e2005-04-16 15:20:36 -07001066/* Entry needed for flags. Moreover, all devices with this ID use
1067 * bulk-only transport, but _some_ falsely report Control/Bulk instead.
1068 * One example is "Trumpion Digital Research MYMP3".
1069 * Submitted by Bjoern Brill <brill(at)fs.math.uni-frankfurt.de>
1070 */
1071UNUSUAL_DEV( 0x090a, 0x1001, 0x0100, 0x0100,
1072 "Trumpion",
1073 "t33520 USB Flash Card Controller",
1074 US_SC_DEVICE, US_PR_BULK, NULL,
1075 US_FL_NEED_OVERRIDE ),
1076
Phil Dibowitz17247572005-05-21 00:45:55 -07001077/* Reported by Filippo Bardelli <filibard@libero.it>
1078 * The device reports a subclass of RBC, which is wrong.
1079 */
1080UNUSUAL_DEV( 0x090a, 0x1050, 0x0100, 0x0100,
1081 "Trumpion Microelectronics, Inc.",
1082 "33520 USB Digital Voice Recorder",
1083 US_SC_UFI, US_PR_DEVICE, NULL,
1084 0),
1085
Linus Torvalds1da177e2005-04-16 15:20:36 -07001086/* Trumpion Microelectronics MP3 player (felipe_alfaro@linuxmail.org) */
1087UNUSUAL_DEV( 0x090a, 0x1200, 0x0000, 0x9999,
1088 "Trumpion",
1089 "MP3 player",
1090 US_SC_RBC, US_PR_BULK, NULL,
1091 0 ),
1092
1093/* aeb */
1094UNUSUAL_DEV( 0x090c, 0x1132, 0x0000, 0xffff,
1095 "Feiya",
1096 "5-in-1 Card Reader",
1097 US_SC_DEVICE, US_PR_DEVICE, NULL,
1098 US_FL_FIX_CAPACITY ),
1099
1100/* This Pentax still camera is not conformant
1101 * to the USB storage specification: -
1102 * - It does not like the INQUIRY command. So we must handle this command
1103 * of the SCSI layer ourselves.
1104 * Tested on Rev. 10.00 (0x1000)
1105 * Submitted by James Courtier-Dutton <James@superbug.demon.co.uk>
1106 */
1107UNUSUAL_DEV( 0x0a17, 0x0004, 0x1000, 0x1000,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001108 "Pentax",
1109 "Optio 2/3/400",
1110 US_SC_DEVICE, US_PR_DEVICE, NULL,
1111 US_FL_FIX_INQUIRY ),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001112
Ben Collins67fa1062007-05-26 03:06:32 -07001113/* These are virtual windows driver CDs, which the zd1211rw driver
1114 * automatically converts into WLAN devices. */
Daniel Drake3c332422006-07-26 13:59:23 +01001115UNUSUAL_DEV( 0x0ace, 0x2011, 0x0101, 0x0101,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001116 "ZyXEL",
1117 "G-220F USB-WLAN Install",
1118 US_SC_DEVICE, US_PR_DEVICE, NULL,
1119 US_FL_IGNORE_DEVICE ),
Daniel Drake3c332422006-07-26 13:59:23 +01001120
Matthew Davidson64902cb2007-05-01 01:15:01 +01001121UNUSUAL_DEV( 0x0ace, 0x20ff, 0x0101, 0x0101,
1122 "SiteCom",
1123 "WL-117 USB-WLAN Install",
1124 US_SC_DEVICE, US_PR_DEVICE, NULL,
1125 US_FL_IGNORE_DEVICE ),
1126
Dan Williams281b0642008-12-14 12:39:22 -05001127/* Reported by Dan Williams <dcbw@redhat.com>
1128 * Option N.V. mobile broadband modems
1129 * Ignore driver CD mode and force into modem mode by default.
1130 */
1131
1132/* iCON 225 */
1133UNUSUAL_DEV( 0x0af0, 0x6971, 0x0000, 0x9999,
1134 "Option N.V.",
1135 "Mass Storage",
1136 US_SC_DEVICE, US_PR_DEVICE, option_ms_init,
1137 0),
1138
Filip Abene7c6f802008-05-08 10:48:12 -07001139/* Reported by F. Aben <f.aben@option.com>
1140 * This device (wrongly) has a vendor-specific device descriptor.
1141 * The entry is needed so usb-storage can bind to it's mass-storage
1142 * interface as an interface driver */
1143UNUSUAL_DEV( 0x0af0, 0x7401, 0x0000, 0x0000,
1144 "Option",
1145 "GI 0401 SD-Card",
1146 US_SC_DEVICE, US_PR_DEVICE, NULL,
1147 0 ),
1148
Jan Dumonc497e712009-03-10 17:29:47 +01001149/* Reported by Jan Dumon <j.dumon@option.com>
Jan Dumon46216e42010-01-05 15:53:26 +01001150 * These devices (wrongly) have a vendor-specific device descriptor.
1151 * These entries are needed so usb-storage can bind to their mass-storage
Jan Dumonc497e712009-03-10 17:29:47 +01001152 * interface as an interface driver */
1153UNUSUAL_DEV( 0x0af0, 0x7501, 0x0000, 0x0000,
1154 "Option",
1155 "GI 0431 SD-Card",
1156 US_SC_DEVICE, US_PR_DEVICE, NULL,
1157 0 ),
1158
Jan Dumon46216e42010-01-05 15:53:26 +01001159UNUSUAL_DEV( 0x0af0, 0x7701, 0x0000, 0x0000,
1160 "Option",
1161 "GI 0451 SD-Card",
1162 US_SC_DEVICE, US_PR_DEVICE, NULL,
1163 0 ),
1164
1165UNUSUAL_DEV( 0x0af0, 0x7706, 0x0000, 0x0000,
1166 "Option",
1167 "GI 0451 SD-Card",
1168 US_SC_DEVICE, US_PR_DEVICE, NULL,
1169 0 ),
1170
1171UNUSUAL_DEV( 0x0af0, 0x7901, 0x0000, 0x0000,
1172 "Option",
1173 "GI 0452 SD-Card",
1174 US_SC_DEVICE, US_PR_DEVICE, NULL,
1175 0 ),
1176
1177UNUSUAL_DEV( 0x0af0, 0x7A01, 0x0000, 0x0000,
1178 "Option",
1179 "GI 0461 SD-Card",
1180 US_SC_DEVICE, US_PR_DEVICE, NULL,
1181 0 ),
1182
1183UNUSUAL_DEV( 0x0af0, 0x7A05, 0x0000, 0x0000,
1184 "Option",
1185 "GI 0461 SD-Card",
1186 US_SC_DEVICE, US_PR_DEVICE, NULL,
1187 0 ),
1188
1189UNUSUAL_DEV( 0x0af0, 0x8300, 0x0000, 0x0000,
1190 "Option",
1191 "GI 033x SD-Card",
1192 US_SC_DEVICE, US_PR_DEVICE, NULL,
1193 0 ),
1194
1195UNUSUAL_DEV( 0x0af0, 0x8302, 0x0000, 0x0000,
1196 "Option",
1197 "GI 033x SD-Card",
1198 US_SC_DEVICE, US_PR_DEVICE, NULL,
1199 0 ),
1200
1201UNUSUAL_DEV( 0x0af0, 0x8304, 0x0000, 0x0000,
1202 "Option",
1203 "GI 033x SD-Card",
1204 US_SC_DEVICE, US_PR_DEVICE, NULL,
1205 0 ),
1206
1207UNUSUAL_DEV( 0x0af0, 0xc100, 0x0000, 0x0000,
1208 "Option",
1209 "GI 070x SD-Card",
1210 US_SC_DEVICE, US_PR_DEVICE, NULL,
1211 0 ),
1212
1213UNUSUAL_DEV( 0x0af0, 0xd057, 0x0000, 0x0000,
1214 "Option",
1215 "GI 1505 SD-Card",
1216 US_SC_DEVICE, US_PR_DEVICE, NULL,
1217 0 ),
1218
1219UNUSUAL_DEV( 0x0af0, 0xd058, 0x0000, 0x0000,
1220 "Option",
1221 "GI 1509 SD-Card",
1222 US_SC_DEVICE, US_PR_DEVICE, NULL,
1223 0 ),
1224
1225UNUSUAL_DEV( 0x0af0, 0xd157, 0x0000, 0x0000,
1226 "Option",
1227 "GI 1515 SD-Card",
1228 US_SC_DEVICE, US_PR_DEVICE, NULL,
1229 0 ),
1230
1231UNUSUAL_DEV( 0x0af0, 0xd257, 0x0000, 0x0000,
1232 "Option",
1233 "GI 1215 SD-Card",
1234 US_SC_DEVICE, US_PR_DEVICE, NULL,
1235 0 ),
1236
1237UNUSUAL_DEV( 0x0af0, 0xd357, 0x0000, 0x0000,
1238 "Option",
1239 "GI 1505 SD-Card",
1240 US_SC_DEVICE, US_PR_DEVICE, NULL,
1241 0 ),
1242
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001243/* Reported by Ben Efros <ben@pc-doctor.com> */
1244UNUSUAL_DEV( 0x0bc2, 0x3010, 0x0000, 0x0000,
1245 "Seagate",
1246 "FreeAgent Pro",
1247 US_SC_DEVICE, US_PR_DEVICE, NULL,
1248 US_FL_SANE_SENSE ),
1249
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001250UNUSUAL_DEV( 0x0d49, 0x7310, 0x0000, 0x9999,
1251 "Maxtor",
1252 "USB to SATA",
1253 US_SC_DEVICE, US_PR_DEVICE, NULL,
1254 US_FL_SANE_SENSE),
1255
Alan Sternf9dc8f92008-11-18 14:08:07 -05001256/*
1257 * Pete Zaitcev <zaitcev@yahoo.com>, bz#164688.
1258 * The device blatantly ignores LUN and returns 1 in GetMaxLUN.
1259 */
1260UNUSUAL_DEV( 0x0c45, 0x1060, 0x0100, 0x0100,
1261 "Unknown",
1262 "Unknown",
1263 US_SC_DEVICE, US_PR_DEVICE, NULL,
1264 US_FL_SINGLE_LUN ),
1265
Linus Torvalds1da177e2005-04-16 15:20:36 -07001266/* Submitted by Joris Struyve <joris@struyve.be> */
1267UNUSUAL_DEV( 0x0d96, 0x410a, 0x0001, 0xffff,
1268 "Medion",
1269 "MD 7425",
1270 US_SC_DEVICE, US_PR_DEVICE, NULL,
1271 US_FL_FIX_INQUIRY),
1272
1273/*
1274 * Entry for Jenoptik JD 5200z3
1275 *
1276 * email: car.busse@gmx.de
1277 */
1278UNUSUAL_DEV( 0x0d96, 0x5200, 0x0001, 0x0200,
1279 "Jenoptik",
1280 "JD 5200 z3",
1281 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_FIX_INQUIRY),
1282
Sergey Ovcharenko3b438e32008-12-17 19:28:06 +03001283/* Reported by Jason Johnston <killean@shaw.ca> */
1284UNUSUAL_DEV( 0x0dc4, 0x0073, 0x0000, 0x0000,
1285 "Macpower Technology Co.LTD.",
1286 "USB 2.0 3.5\" DEVICE",
1287 US_SC_DEVICE, US_PR_DEVICE, NULL,
1288 US_FL_FIX_CAPACITY),
1289
Linus Torvalds1da177e2005-04-16 15:20:36 -07001290/* Reported by Lubomir Blaha <tritol@trilogic.cz>
1291 * I _REALLY_ don't know what 3rd, 4th number and all defines mean, but this
1292 * works for me. Can anybody correct these values? (I able to test corrected
1293 * version.)
1294 */
1295UNUSUAL_DEV( 0x0dd8, 0x1060, 0x0000, 0xffff,
1296 "Netac",
1297 "USB-CF-Card",
1298 US_SC_DEVICE, US_PR_DEVICE, NULL,
1299 US_FL_FIX_INQUIRY ),
1300
Ben Collins67fa1062007-05-26 03:06:32 -07001301/* Reported by Edward Chapman (taken from linux-usb mailing list)
1302 Netac OnlyDisk Mini U2CV2 512MB USB 2.0 Flash Drive */
1303UNUSUAL_DEV( 0x0dd8, 0xd202, 0x0000, 0x9999,
1304 "Netac",
1305 "USB Flash Disk",
1306 US_SC_DEVICE, US_PR_DEVICE, NULL,
1307 US_FL_IGNORE_RESIDUE ),
1308
1309
Linus Torvalds1da177e2005-04-16 15:20:36 -07001310/* Patch by Stephan Walter <stephan.walter@epfl.ch>
1311 * I don't know why, but it works... */
1312UNUSUAL_DEV( 0x0dda, 0x0001, 0x0012, 0x0012,
1313 "WINWARD",
1314 "Music Disk",
1315 US_SC_DEVICE, US_PR_DEVICE, NULL,
1316 US_FL_IGNORE_RESIDUE ),
1317
1318/* Reported by Ian McConnell <ian at emit.demon.co.uk> */
1319UNUSUAL_DEV( 0x0dda, 0x0301, 0x0012, 0x0012,
1320 "PNP_MP3",
1321 "PNP_MP3 PLAYER",
1322 US_SC_DEVICE, US_PR_DEVICE, NULL,
1323 US_FL_IGNORE_RESIDUE ),
1324
Alan Stern982db2a2006-02-13 10:16:04 -05001325/* Reported by Jim McCloskey <mcclosk@ucsc.edu> */
1326UNUSUAL_DEV( 0x0e21, 0x0520, 0x0100, 0x0100,
1327 "Cowon Systems",
1328 "iAUDIO M5",
1329 US_SC_DEVICE, US_PR_BULK, NULL,
Phil Dibowitzbc724b92006-10-19 00:11:17 -07001330 US_FL_NEED_OVERRIDE ),
Alan Stern982db2a2006-02-13 10:16:04 -05001331
Linus Torvalds1da177e2005-04-16 15:20:36 -07001332/* Submitted by Antoine Mairesse <antoine.mairesse@free.fr> */
1333UNUSUAL_DEV( 0x0ed1, 0x6660, 0x0100, 0x0300,
1334 "USB",
1335 "Solid state disk",
1336 US_SC_DEVICE, US_PR_DEVICE, NULL,
1337 US_FL_FIX_INQUIRY ),
1338
1339/* Submitted by Daniel Drake <dsd@gentoo.org>
1340 * Reported by dayul on the Gentoo Forums */
1341UNUSUAL_DEV( 0x0ea0, 0x2168, 0x0110, 0x0110,
1342 "Ours Technology",
1343 "Flash Disk",
1344 US_SC_DEVICE, US_PR_DEVICE, NULL,
1345 US_FL_IGNORE_RESIDUE ),
1346
1347/* Reported by Rastislav Stanik <rs_kernel@yahoo.com> */
1348UNUSUAL_DEV( 0x0ea0, 0x6828, 0x0110, 0x0110,
1349 "USB",
1350 "Flash Disk",
1351 US_SC_DEVICE, US_PR_DEVICE, NULL,
1352 US_FL_IGNORE_RESIDUE ),
1353
Phil Dibowitz883d9892006-06-24 17:27:10 -07001354/* Reported by Benjamin Schiller <sbenni@gmx.de>
1355 * It is also sold by Easylite as DJ 20 */
1356UNUSUAL_DEV( 0x0ed1, 0x7636, 0x0103, 0x0103,
1357 "Typhoon",
1358 "My DJ 1820",
1359 US_SC_DEVICE, US_PR_DEVICE, NULL,
1360 US_FL_IGNORE_RESIDUE | US_FL_GO_SLOW | US_FL_MAX_SECTORS_64),
1361
Robert Spitzenpfeil4e584072008-02-20 12:11:22 -05001362/* Patch by Leonid Petrov mail at lpetrov.net
1363 * Reported by Robert Spitzenpfeil <robert@spitzenpfeil.org>
1364 * http://www.qbik.ch/usb/devices/showdev.php?id=1705
1365 * Updated to 103 device by MJ Ray mjr at phonecoop.coop
1366 */
1367UNUSUAL_DEV( 0x0f19, 0x0103, 0x0100, 0x0100,
1368 "Oracom Co., Ltd",
1369 "ORC-200M",
1370 US_SC_DEVICE, US_PR_DEVICE, NULL,
1371 US_FL_IGNORE_RESIDUE ),
1372
David Kuehlingb41ee5d2006-08-07 10:18:48 -04001373/* David Kuehling <dvdkhlng@gmx.de>:
1374 * for MP3-Player AVOX WSX-300ER (bought in Japan). Reports lots of SCSI
1375 * errors when trying to write.
1376 */
1377UNUSUAL_DEV( 0x0f19, 0x0105, 0x0100, 0x0100,
1378 "C-MEX",
1379 "A-VOX",
1380 US_SC_DEVICE, US_PR_DEVICE, NULL,
1381 US_FL_IGNORE_RESIDUE ),
1382
Linus Torvalds1da177e2005-04-16 15:20:36 -07001383/* Reported by Michael Stattmann <michael@stattmann.com> */
1384UNUSUAL_DEV( 0x0fce, 0xd008, 0x0000, 0x0000,
1385 "Sony Ericsson",
1386 "V800-Vodafone 802",
1387 US_SC_DEVICE, US_PR_DEVICE, NULL,
1388 US_FL_NO_WP_DETECT ),
1389
Phil Dibowitza83775b2009-01-20 23:48:36 +01001390/* Reported by The Solutor <thesolutor@gmail.com> */
1391UNUSUAL_DEV( 0x0fce, 0xd0e1, 0x0000, 0x0000,
1392 "Sony Ericsson",
1393 "MD400",
1394 US_SC_DEVICE, US_PR_DEVICE, NULL,
1395 US_FL_IGNORE_DEVICE),
1396
Alan Sternb544d742007-01-31 10:57:55 -05001397/* Reported by Jan Mate <mate@fiit.stuba.sk>
1398 * and by Soeren Sonnenburg <kernel@nn7.de> */
Phil Dibowitz39c2f3a2006-09-11 00:27:40 -07001399UNUSUAL_DEV( 0x0fce, 0xe030, 0x0000, 0x0000,
1400 "Sony Ericsson",
1401 "P990i",
1402 US_SC_DEVICE, US_PR_DEVICE, NULL,
Alan Sternb544d742007-01-31 10:57:55 -05001403 US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
Phil Dibowitz39c2f3a2006-09-11 00:27:40 -07001404
Phil Dibowitzc9c770e2006-08-27 23:54:37 -07001405/* Reported by Emmanuel Vasilakis <evas@forthnet.gr> */
1406UNUSUAL_DEV( 0x0fce, 0xe031, 0x0000, 0x0000,
1407 "Sony Ericsson",
1408 "M600i",
1409 US_SC_DEVICE, US_PR_DEVICE, NULL,
Phil Dibowitzc5f23b02008-05-26 21:33:58 +02001410 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
Phil Dibowitzc9c770e2006-08-27 23:54:37 -07001411
Alan Sternf9dc8f92008-11-18 14:08:07 -05001412/* Reported by Ricardo Barberis <ricardo@dattatec.com> */
1413UNUSUAL_DEV( 0x0fce, 0xe092, 0x0000, 0x0000,
1414 "Sony Ericsson",
1415 "P1i",
1416 US_SC_DEVICE, US_PR_DEVICE, NULL,
1417 US_FL_IGNORE_RESIDUE ),
1418
Linus Torvalds1da177e2005-04-16 15:20:36 -07001419/* Reported by Kevin Cernekee <kpc-usbdev@gelato.uiuc.edu>
1420 * Tested on hardware version 1.10.
1421 * Entry is needed only for the initializer function override.
Phil Dibowitz51b5bce2006-11-02 23:14:10 -08001422 * Devices with bcd > 110 seem to not need it while those
1423 * with bcd < 110 appear to need it.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001424 */
Phil Dibowitz51b5bce2006-11-02 23:14:10 -08001425UNUSUAL_DEV( 0x1019, 0x0c55, 0x0000, 0x0110,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001426 "Desknote",
1427 "UCR-61S2B",
1428 US_SC_DEVICE, US_PR_DEVICE, usb_stor_ucr61s2b_init,
1429 0 ),
1430
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001431UNUSUAL_DEV( 0x1058, 0x0704, 0x0000, 0x9999,
1432 "Western Digital",
1433 "External HDD",
1434 US_SC_DEVICE, US_PR_DEVICE, NULL,
1435 US_FL_SANE_SENSE),
1436
Alan Stern274399d2008-02-20 12:10:04 -05001437/* Reported by Fabio Venturi <f.venturi@tdnet.it>
1438 * The device reports a vendor-specific bDeviceClass.
1439 */
1440UNUSUAL_DEV( 0x10d6, 0x2200, 0x0100, 0x0100,
1441 "Actions Semiconductor",
1442 "Mtp device",
1443 US_SC_DEVICE, US_PR_DEVICE, NULL,
1444 0),
1445
Pascal Terjanc00deaa2009-04-07 14:40:42 +02001446/* Reported by Pascal Terjan <pterjan@mandriva.com>
1447 * Ignore driver CD mode and force into modem mode by default.
1448 */
1449UNUSUAL_DEV( 0x1186, 0x3e04, 0x0000, 0x0000,
1450 "D-Link",
1451 "USB Mass Storage",
Pascal Terjanc5be1b52009-04-16 19:00:45 +02001452 US_SC_DEVICE, US_PR_DEVICE, option_ms_init, US_FL_IGNORE_DEVICE),
Pascal Terjanc00deaa2009-04-07 14:40:42 +02001453
Kevin Lloyd112225b2007-07-16 13:49:27 -07001454/* Reported by Kevin Lloyd <linux@sierrawireless.com>
1455 * Entry is needed for the initializer function override,
1456 * which instructs the device to load as a modem
1457 * device.
1458 */
1459UNUSUAL_DEV( 0x1199, 0x0fff, 0x0000, 0x9999,
1460 "Sierra Wireless",
1461 "USB MMC Storage",
Kevin Lloyd32fe5e32008-07-10 14:14:57 -07001462 US_SC_DEVICE, US_PR_DEVICE, sierra_ms_init,
1463 0),
Kevin Lloyd112225b2007-07-16 13:49:27 -07001464
Jaco Kroon49314372006-11-15 01:02:08 -08001465/* Reported by Jaco Kroon <jaco@kroon.co.za>
1466 * The usb-storage module found on the Digitech GNX4 (and supposedly other
1467 * devices) misbehaves and causes a bunch of invalid I/O errors.
1468 */
1469UNUSUAL_DEV( 0x1210, 0x0003, 0x0100, 0x0100,
1470 "Digitech HMG",
1471 "DigiTech Mass Storage",
1472 US_SC_DEVICE, US_PR_DEVICE, NULL,
1473 US_FL_IGNORE_RESIDUE ),
1474
fangxiaozhiaad8a272008-04-10 14:51:06 +08001475/* Reported by fangxiaozhi <huananhu@huawei.com>
1476 * This brings the HUAWEI data card devices into multi-port mode
Johann Wilhelmd853d872007-09-05 13:49:29 +02001477 */
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001478UNUSUAL_DEV( 0x12d1, 0x1001, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001479 "HUAWEI MOBILE",
1480 "Mass Storage",
1481 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1482 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001483UNUSUAL_DEV( 0x12d1, 0x1003, 0x0000, 0x0000,
Johann Wilhelmd853d872007-09-05 13:49:29 +02001484 "HUAWEI MOBILE",
1485 "Mass Storage",
1486 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1487 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001488UNUSUAL_DEV( 0x12d1, 0x1004, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001489 "HUAWEI MOBILE",
1490 "Mass Storage",
1491 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1492 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001493UNUSUAL_DEV( 0x12d1, 0x1401, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001494 "HUAWEI MOBILE",
1495 "Mass Storage",
1496 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1497 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001498UNUSUAL_DEV( 0x12d1, 0x1402, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001499 "HUAWEI MOBILE",
1500 "Mass Storage",
1501 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1502 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001503UNUSUAL_DEV( 0x12d1, 0x1403, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001504 "HUAWEI MOBILE",
1505 "Mass Storage",
1506 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1507 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001508UNUSUAL_DEV( 0x12d1, 0x1404, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001509 "HUAWEI MOBILE",
1510 "Mass Storage",
1511 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1512 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001513UNUSUAL_DEV( 0x12d1, 0x1405, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001514 "HUAWEI MOBILE",
1515 "Mass Storage",
1516 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1517 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001518UNUSUAL_DEV( 0x12d1, 0x1406, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001519 "HUAWEI MOBILE",
1520 "Mass Storage",
1521 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1522 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001523UNUSUAL_DEV( 0x12d1, 0x1407, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001524 "HUAWEI MOBILE",
1525 "Mass Storage",
1526 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1527 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001528UNUSUAL_DEV( 0x12d1, 0x1408, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001529 "HUAWEI MOBILE",
1530 "Mass Storage",
1531 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1532 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001533UNUSUAL_DEV( 0x12d1, 0x1409, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001534 "HUAWEI MOBILE",
1535 "Mass Storage",
1536 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1537 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001538UNUSUAL_DEV( 0x12d1, 0x140A, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001539 "HUAWEI MOBILE",
1540 "Mass Storage",
1541 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1542 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001543UNUSUAL_DEV( 0x12d1, 0x140B, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001544 "HUAWEI MOBILE",
1545 "Mass Storage",
1546 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1547 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001548UNUSUAL_DEV( 0x12d1, 0x140C, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001549 "HUAWEI MOBILE",
1550 "Mass Storage",
1551 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1552 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001553UNUSUAL_DEV( 0x12d1, 0x140D, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001554 "HUAWEI MOBILE",
1555 "Mass Storage",
1556 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1557 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001558UNUSUAL_DEV( 0x12d1, 0x140E, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001559 "HUAWEI MOBILE",
1560 "Mass Storage",
1561 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1562 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001563UNUSUAL_DEV( 0x12d1, 0x140F, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001564 "HUAWEI MOBILE",
1565 "Mass Storage",
1566 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1567 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001568UNUSUAL_DEV( 0x12d1, 0x1410, 0x0000, 0x0000,
1569 "HUAWEI MOBILE",
1570 "Mass Storage",
1571 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1572 0),
1573UNUSUAL_DEV( 0x12d1, 0x1411, 0x0000, 0x0000,
1574 "HUAWEI MOBILE",
1575 "Mass Storage",
1576 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1577 0),
1578UNUSUAL_DEV( 0x12d1, 0x1412, 0x0000, 0x0000,
1579 "HUAWEI MOBILE",
1580 "Mass Storage",
1581 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1582 0),
1583UNUSUAL_DEV( 0x12d1, 0x1413, 0x0000, 0x0000,
1584 "HUAWEI MOBILE",
1585 "Mass Storage",
1586 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1587 0),
1588UNUSUAL_DEV( 0x12d1, 0x1414, 0x0000, 0x0000,
1589 "HUAWEI MOBILE",
1590 "Mass Storage",
1591 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1592 0),
1593UNUSUAL_DEV( 0x12d1, 0x1415, 0x0000, 0x0000,
1594 "HUAWEI MOBILE",
1595 "Mass Storage",
1596 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1597 0),
1598UNUSUAL_DEV( 0x12d1, 0x1416, 0x0000, 0x0000,
1599 "HUAWEI MOBILE",
1600 "Mass Storage",
1601 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1602 0),
1603UNUSUAL_DEV( 0x12d1, 0x1417, 0x0000, 0x0000,
1604 "HUAWEI MOBILE",
1605 "Mass Storage",
1606 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1607 0),
1608UNUSUAL_DEV( 0x12d1, 0x1418, 0x0000, 0x0000,
1609 "HUAWEI MOBILE",
1610 "Mass Storage",
1611 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1612 0),
1613UNUSUAL_DEV( 0x12d1, 0x1419, 0x0000, 0x0000,
1614 "HUAWEI MOBILE",
1615 "Mass Storage",
1616 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1617 0),
1618UNUSUAL_DEV( 0x12d1, 0x141A, 0x0000, 0x0000,
1619 "HUAWEI MOBILE",
1620 "Mass Storage",
1621 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1622 0),
1623UNUSUAL_DEV( 0x12d1, 0x141B, 0x0000, 0x0000,
1624 "HUAWEI MOBILE",
1625 "Mass Storage",
1626 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1627 0),
1628UNUSUAL_DEV( 0x12d1, 0x141C, 0x0000, 0x0000,
1629 "HUAWEI MOBILE",
1630 "Mass Storage",
1631 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1632 0),
1633UNUSUAL_DEV( 0x12d1, 0x141D, 0x0000, 0x0000,
1634 "HUAWEI MOBILE",
1635 "Mass Storage",
1636 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1637 0),
1638UNUSUAL_DEV( 0x12d1, 0x141E, 0x0000, 0x0000,
1639 "HUAWEI MOBILE",
1640 "Mass Storage",
1641 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1642 0),
1643UNUSUAL_DEV( 0x12d1, 0x141F, 0x0000, 0x0000,
1644 "HUAWEI MOBILE",
1645 "Mass Storage",
1646 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1647 0),
1648UNUSUAL_DEV( 0x12d1, 0x1420, 0x0000, 0x0000,
1649 "HUAWEI MOBILE",
1650 "Mass Storage",
1651 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1652 0),
1653UNUSUAL_DEV( 0x12d1, 0x1421, 0x0000, 0x0000,
1654 "HUAWEI MOBILE",
1655 "Mass Storage",
1656 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1657 0),
1658UNUSUAL_DEV( 0x12d1, 0x1422, 0x0000, 0x0000,
1659 "HUAWEI MOBILE",
1660 "Mass Storage",
1661 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1662 0),
1663UNUSUAL_DEV( 0x12d1, 0x1423, 0x0000, 0x0000,
1664 "HUAWEI MOBILE",
1665 "Mass Storage",
1666 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1667 0),
1668UNUSUAL_DEV( 0x12d1, 0x1424, 0x0000, 0x0000,
1669 "HUAWEI MOBILE",
1670 "Mass Storage",
1671 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1672 0),
1673UNUSUAL_DEV( 0x12d1, 0x1425, 0x0000, 0x0000,
1674 "HUAWEI MOBILE",
1675 "Mass Storage",
1676 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1677 0),
1678UNUSUAL_DEV( 0x12d1, 0x1426, 0x0000, 0x0000,
1679 "HUAWEI MOBILE",
1680 "Mass Storage",
1681 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1682 0),
1683UNUSUAL_DEV( 0x12d1, 0x1427, 0x0000, 0x0000,
1684 "HUAWEI MOBILE",
1685 "Mass Storage",
1686 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1687 0),
1688UNUSUAL_DEV( 0x12d1, 0x1428, 0x0000, 0x0000,
1689 "HUAWEI MOBILE",
1690 "Mass Storage",
1691 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1692 0),
1693UNUSUAL_DEV( 0x12d1, 0x1429, 0x0000, 0x0000,
1694 "HUAWEI MOBILE",
1695 "Mass Storage",
1696 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1697 0),
1698UNUSUAL_DEV( 0x12d1, 0x142A, 0x0000, 0x0000,
1699 "HUAWEI MOBILE",
1700 "Mass Storage",
1701 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1702 0),
1703UNUSUAL_DEV( 0x12d1, 0x142B, 0x0000, 0x0000,
1704 "HUAWEI MOBILE",
1705 "Mass Storage",
1706 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1707 0),
1708UNUSUAL_DEV( 0x12d1, 0x142C, 0x0000, 0x0000,
1709 "HUAWEI MOBILE",
1710 "Mass Storage",
1711 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1712 0),
1713UNUSUAL_DEV( 0x12d1, 0x142D, 0x0000, 0x0000,
1714 "HUAWEI MOBILE",
1715 "Mass Storage",
1716 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1717 0),
1718UNUSUAL_DEV( 0x12d1, 0x142E, 0x0000, 0x0000,
1719 "HUAWEI MOBILE",
1720 "Mass Storage",
1721 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1722 0),
1723UNUSUAL_DEV( 0x12d1, 0x142F, 0x0000, 0x0000,
1724 "HUAWEI MOBILE",
1725 "Mass Storage",
1726 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1727 0),
1728UNUSUAL_DEV( 0x12d1, 0x1430, 0x0000, 0x0000,
1729 "HUAWEI MOBILE",
1730 "Mass Storage",
1731 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1732 0),
1733UNUSUAL_DEV( 0x12d1, 0x1431, 0x0000, 0x0000,
1734 "HUAWEI MOBILE",
1735 "Mass Storage",
1736 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1737 0),
1738UNUSUAL_DEV( 0x12d1, 0x1432, 0x0000, 0x0000,
1739 "HUAWEI MOBILE",
1740 "Mass Storage",
1741 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1742 0),
1743UNUSUAL_DEV( 0x12d1, 0x1433, 0x0000, 0x0000,
1744 "HUAWEI MOBILE",
1745 "Mass Storage",
1746 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1747 0),
1748UNUSUAL_DEV( 0x12d1, 0x1434, 0x0000, 0x0000,
1749 "HUAWEI MOBILE",
1750 "Mass Storage",
1751 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1752 0),
1753UNUSUAL_DEV( 0x12d1, 0x1435, 0x0000, 0x0000,
1754 "HUAWEI MOBILE",
1755 "Mass Storage",
1756 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1757 0),
1758UNUSUAL_DEV( 0x12d1, 0x1436, 0x0000, 0x0000,
1759 "HUAWEI MOBILE",
1760 "Mass Storage",
1761 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1762 0),
1763UNUSUAL_DEV( 0x12d1, 0x1437, 0x0000, 0x0000,
1764 "HUAWEI MOBILE",
1765 "Mass Storage",
1766 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1767 0),
1768UNUSUAL_DEV( 0x12d1, 0x1438, 0x0000, 0x0000,
1769 "HUAWEI MOBILE",
1770 "Mass Storage",
1771 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1772 0),
1773UNUSUAL_DEV( 0x12d1, 0x1439, 0x0000, 0x0000,
1774 "HUAWEI MOBILE",
1775 "Mass Storage",
1776 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1777 0),
1778UNUSUAL_DEV( 0x12d1, 0x143A, 0x0000, 0x0000,
1779 "HUAWEI MOBILE",
1780 "Mass Storage",
1781 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1782 0),
1783UNUSUAL_DEV( 0x12d1, 0x143B, 0x0000, 0x0000,
1784 "HUAWEI MOBILE",
1785 "Mass Storage",
1786 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1787 0),
1788UNUSUAL_DEV( 0x12d1, 0x143C, 0x0000, 0x0000,
1789 "HUAWEI MOBILE",
1790 "Mass Storage",
1791 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1792 0),
1793UNUSUAL_DEV( 0x12d1, 0x143D, 0x0000, 0x0000,
1794 "HUAWEI MOBILE",
1795 "Mass Storage",
1796 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1797 0),
1798UNUSUAL_DEV( 0x12d1, 0x143E, 0x0000, 0x0000,
1799 "HUAWEI MOBILE",
1800 "Mass Storage",
1801 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1802 0),
1803UNUSUAL_DEV( 0x12d1, 0x143F, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001804 "HUAWEI MOBILE",
1805 "Mass Storage",
1806 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1807 0),
Johann Wilhelmd853d872007-09-05 13:49:29 +02001808
Phil Dibowitz7b1cbeb2005-05-02 23:54:28 -07001809/* Reported by Vilius Bilinkevicius <vilisas AT xxx DOT lt) */
1810UNUSUAL_DEV( 0x132b, 0x000b, 0x0001, 0x0001,
1811 "Minolta",
1812 "Dimage Z10",
1813 US_SC_DEVICE, US_PR_DEVICE, NULL,
1814 0 ),
1815
Linus Torvalds1da177e2005-04-16 15:20:36 -07001816/* Reported by Kotrla Vitezslav <kotrla@ceb.cz> */
1817UNUSUAL_DEV( 0x1370, 0x6828, 0x0110, 0x0110,
1818 "SWISSBIT",
1819 "Black Silver",
1820 US_SC_DEVICE, US_PR_DEVICE, NULL,
1821 US_FL_IGNORE_RESIDUE ),
1822
Phil Dibowitzf1cd4ad2006-12-31 00:19:50 -08001823/* Reported by Francesco Foresti <frafore@tiscali.it> */
1824UNUSUAL_DEV( 0x14cd, 0x6600, 0x0201, 0x0201,
1825 "Super Top",
1826 "IDE DEVICE",
1827 US_SC_DEVICE, US_PR_DEVICE, NULL,
1828 US_FL_IGNORE_RESIDUE ),
1829
Phil Dibowitz3030ca42008-10-19 08:17:54 +02001830/* Reported by Alexandre Oliva <oliva@lsd.ic.unicamp.br>
1831 * JMicron responds to USN and several other SCSI ioctls with a
1832 * residue that causes subsequent I/O requests to fail. */
1833UNUSUAL_DEV( 0x152d, 0x2329, 0x0100, 0x0100,
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001834 "JMicron",
1835 "USB to ATA/ATAPI Bridge",
1836 US_SC_DEVICE, US_PR_DEVICE, NULL,
1837 US_FL_IGNORE_RESIDUE | US_FL_SANE_SENSE ),
Phil Dibowitz3030ca42008-10-19 08:17:54 +02001838
Phil Dibowitzf1cd4ad2006-12-31 00:19:50 -08001839/* Reported by Robert Schedel <r.schedel@yahoo.de>
1840 * Note: this is a 'super top' device like the above 14cd/6600 device */
1841UNUSUAL_DEV( 0x1652, 0x6600, 0x0201, 0x0201,
1842 "Teac",
1843 "HD-35PUK-B",
1844 US_SC_DEVICE, US_PR_DEVICE, NULL,
1845 US_FL_IGNORE_RESIDUE ),
1846
Hans de Goedea78f4f12010-04-29 12:59:04 +02001847/* Reported by Hans de Goede <hdegoede@redhat.com>
1848 * These Appotech controllers are found in Picture Frames, they provide a
1849 * (buggy) emulation of a cdrom drive which contains the windows software
1850 * Uploading of pictures happens over the corresponding /dev/sg device. */
1851UNUSUAL_DEV( 0x1908, 0x1315, 0x0000, 0x0000,
1852 "BUILDWIN",
1853 "Photo Frame",
1854 US_SC_DEVICE, US_PR_DEVICE, NULL,
1855 US_FL_BAD_SENSE ),
1856UNUSUAL_DEV( 0x1908, 0x1320, 0x0000, 0x0000,
1857 "BUILDWIN",
1858 "Photo Frame",
1859 US_SC_DEVICE, US_PR_DEVICE, NULL,
1860 US_FL_BAD_SENSE ),
1861
Oliver Neukumb90de8a2009-01-14 16:17:19 +01001862UNUSUAL_DEV( 0x2116, 0x0320, 0x0001, 0x0001,
1863 "ST",
1864 "2A",
1865 US_SC_DEVICE, US_PR_DEVICE, NULL,
1866 US_FL_FIX_CAPACITY),
1867
Davide Perini0ddc0632006-06-19 17:07:39 -04001868/* patch submitted by Davide Perini <perini.davide@dpsoftware.org>
1869 * and Renato Perini <rperini@email.it>
1870 */
1871UNUSUAL_DEV( 0x22b8, 0x3010, 0x0001, 0x0001,
1872 "Motorola",
1873 "RAZR V3x",
1874 US_SC_DEVICE, US_PR_DEVICE, NULL,
1875 US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
1876
Pete Zaitceva7f3dd52007-03-10 15:17:16 -08001877/*
Constantin Baranovcc36bdd2008-03-16 20:04:23 +00001878 * Patch by Constantin Baranov <const@tltsu.ru>
1879 * Report by Andreas Koenecke.
1880 * Motorola ROKR Z6.
1881 */
1882UNUSUAL_DEV( 0x22b8, 0x6426, 0x0101, 0x0101,
1883 "Motorola",
1884 "MSnc.",
1885 US_SC_DEVICE, US_PR_DEVICE, NULL,
1886 US_FL_FIX_INQUIRY | US_FL_FIX_CAPACITY | US_FL_BULK_IGNORE_TAG),
1887
Linus Torvalds1da177e2005-04-16 15:20:36 -07001888/* Reported by Radovan Garabik <garabik@kassiopeia.juls.savba.sk> */
1889UNUSUAL_DEV( 0x2735, 0x100b, 0x0000, 0x9999,
1890 "MPIO",
1891 "HS200",
1892 US_SC_DEVICE, US_PR_DEVICE, NULL,
1893 US_FL_GO_SLOW ),
1894
Frédéric Marchale8fab4c2008-10-13 14:00:11 +02001895/* Reported by Frederic Marchal <frederic.marchal@wowcompany.com>
1896 * Mio Moov 330
1897 */
1898UNUSUAL_DEV( 0x3340, 0xffff, 0x0000, 0x0000,
1899 "Mitac",
1900 "Mio DigiWalker USB Sync",
1901 US_SC_DEVICE,US_PR_DEVICE,NULL,
1902 US_FL_MAX_SECTORS_64 ),
1903
Alan Stern368ee642008-07-21 10:08:28 -04001904/* Reported by Andrey Rahmatullin <wrar@altlinux.org> */
1905UNUSUAL_DEV( 0x4102, 0x1020, 0x0100, 0x0100,
1906 "iRiver",
1907 "MP3 T10",
1908 US_SC_DEVICE, US_PR_DEVICE, NULL,
1909 US_FL_IGNORE_RESIDUE ),
1910
Sergey Pinaev2f136122009-09-17 17:26:50 +04001911/* Reported by Sergey Pinaev <dfo@antex.ru> */
1912UNUSUAL_DEV( 0x4102, 0x1059, 0x0000, 0x0000,
1913 "iRiver",
1914 "P7K",
1915 US_SC_DEVICE, US_PR_DEVICE, NULL,
1916 US_FL_MAX_SECTORS_64 ),
1917
David Härdeman63dc3ff2005-11-23 15:45:49 -08001918/*
Jan Engelhardt96de0e22007-10-19 23:21:04 +02001919 * David Härdeman <david@2gen.com>
David Härdeman63dc3ff2005-11-23 15:45:49 -08001920 * The key makes the SCSI stack print confusing (but harmless) messages
1921 */
1922UNUSUAL_DEV( 0x4146, 0xba01, 0x0100, 0x0100,
1923 "Iomega",
1924 "Micro Mini 1GB",
1925 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_NOT_LOCKABLE ),
1926
Alan Sterna2149bc2006-02-02 09:52:45 -05001927/* Reported by Andrew Simmons <andrew.simmons@gmail.com> */
1928UNUSUAL_DEV( 0xed06, 0x4500, 0x0001, 0x0001,
1929 "DataStor",
1930 "USB4500 FW1.04",
1931 US_SC_DEVICE, US_PR_DEVICE, NULL,
Oliver Neukum61bf54b2007-02-08 09:04:48 +01001932 US_FL_CAPACITY_HEURISTICS),
Alan Sterna2149bc2006-02-02 09:52:45 -05001933
Chuck Short46c6e932009-04-14 20:50:31 +02001934/* Reported by Alessio Treglia <quadrispro@ubuntu.com> */
1935UNUSUAL_DEV( 0xed10, 0x7636, 0x0001, 0x0001,
1936 "TGE",
1937 "Digital MP3 Audio Player",
1938 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_NOT_LOCKABLE ),
1939
Pete Zaitceva00828e2005-10-22 20:15:09 -07001940/* Control/Bulk transport for all SubClass values */
1941USUAL_DEV(US_SC_RBC, US_PR_CB, USB_US_TYPE_STOR),
1942USUAL_DEV(US_SC_8020, US_PR_CB, USB_US_TYPE_STOR),
1943USUAL_DEV(US_SC_QIC, US_PR_CB, USB_US_TYPE_STOR),
1944USUAL_DEV(US_SC_UFI, US_PR_CB, USB_US_TYPE_STOR),
1945USUAL_DEV(US_SC_8070, US_PR_CB, USB_US_TYPE_STOR),
1946USUAL_DEV(US_SC_SCSI, US_PR_CB, USB_US_TYPE_STOR),
1947
1948/* Control/Bulk/Interrupt transport for all SubClass values */
1949USUAL_DEV(US_SC_RBC, US_PR_CBI, USB_US_TYPE_STOR),
1950USUAL_DEV(US_SC_8020, US_PR_CBI, USB_US_TYPE_STOR),
1951USUAL_DEV(US_SC_QIC, US_PR_CBI, USB_US_TYPE_STOR),
1952USUAL_DEV(US_SC_UFI, US_PR_CBI, USB_US_TYPE_STOR),
1953USUAL_DEV(US_SC_8070, US_PR_CBI, USB_US_TYPE_STOR),
1954USUAL_DEV(US_SC_SCSI, US_PR_CBI, USB_US_TYPE_STOR),
1955
1956/* Bulk-only transport for all SubClass values */
1957USUAL_DEV(US_SC_RBC, US_PR_BULK, USB_US_TYPE_STOR),
1958USUAL_DEV(US_SC_8020, US_PR_BULK, USB_US_TYPE_STOR),
1959USUAL_DEV(US_SC_QIC, US_PR_BULK, USB_US_TYPE_STOR),
1960USUAL_DEV(US_SC_UFI, US_PR_BULK, USB_US_TYPE_STOR),
1961USUAL_DEV(US_SC_8070, US_PR_BULK, USB_US_TYPE_STOR),
1962USUAL_DEV(US_SC_SCSI, US_PR_BULK, 0),