blob: 1fe7062f1cda1f8ea292075b444525a84de1864a [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
Tobias Lorenz1ff15e82006-10-08 22:56:40 -070069/* modified by Tobias Lorenz <tobias.lorenz@gmx.net> */
70UNUSUAL_DEV( 0x03ee, 0x6901, 0x0000, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -070071 "Mitsumi",
72 "USB FDD",
73 US_SC_DEVICE, US_PR_DEVICE, NULL,
74 US_FL_SINGLE_LUN ),
75
Rodolfo Quesada9d5847b2006-03-06 10:45:42 -050076/* Reported by Rodolfo Quesada <rquesada@roqz.net> */
77UNUSUAL_DEV( 0x03ee, 0x6906, 0x0003, 0x0003,
78 "VIA Technologies Inc.",
79 "Mitsumi multi cardreader",
80 US_SC_DEVICE, US_PR_DEVICE, NULL,
81 US_FL_IGNORE_RESIDUE ),
82
S.Caglar Onurc0e0c192007-07-04 13:52:47 -070083UNUSUAL_DEV( 0x03f0, 0x0107, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -070084 "HP",
85 "CD-Writer+",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -070086 US_SC_8070, US_PR_CB, NULL, 0),
Linus Torvalds1da177e2005-04-16 15:20:36 -070087
88#ifdef CONFIG_USB_STORAGE_USBAT
S.Caglar Onurc0e0c192007-07-04 13:52:47 -070089UNUSUAL_DEV( 0x03f0, 0x0207, 0x0001, 0x0001,
Linus Torvalds1da177e2005-04-16 15:20:36 -070090 "HP",
91 "CD-Writer+ 8200e",
Peter Chubbbdcfd9e2006-05-02 18:29:34 +010092 US_SC_8070, US_PR_USBAT, init_usbat_cd, 0),
Linus Torvalds1da177e2005-04-16 15:20:36 -070093
S.Caglar Onurc0e0c192007-07-04 13:52:47 -070094UNUSUAL_DEV( 0x03f0, 0x0307, 0x0001, 0x0001,
Linus Torvalds1da177e2005-04-16 15:20:36 -070095 "HP",
96 "CD-Writer+ CD-4e",
Peter Chubbbdcfd9e2006-05-02 18:29:34 +010097 US_SC_8070, US_PR_USBAT, init_usbat_cd, 0),
Linus Torvalds1da177e2005-04-16 15:20:36 -070098#endif
99
Ben Efrosdbe6e0c02008-11-23 20:06:38 -0800100/* Reported by Ben Efros <ben@pc-doctor.com> */
101UNUSUAL_DEV( 0x03f0, 0x070c, 0x0000, 0x0000,
102 "HP",
103 "Personal Media Drive",
104 US_SC_DEVICE, US_PR_DEVICE, NULL,
105 US_FL_SANE_SENSE ),
106
Grant Grundler4b24f912008-01-23 21:31:03 -0800107/* Reported by Grant Grundler <grundler@parisc-linux.org>
108 * HP r707 camera in "Disk" mode with 2.00.23 or 2.00.24 firmware.
109 */
110UNUSUAL_DEV( 0x03f0, 0x4002, 0x0001, 0x0001,
111 "HP",
112 "PhotoSmart R707",
113 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_FIX_CAPACITY),
114
Phil Dibowitz1ea640c2005-08-29 22:38:28 -0700115/* Reported by Sebastian Kapfer <sebastian_kapfer@gmx.net>
116 * and Olaf Hering <olh@suse.de> (different bcd's, same vendor/product)
117 * for USB floppies that need the SINGLE_LUN enforcement.
118 */
119UNUSUAL_DEV( 0x0409, 0x0040, 0x0000, 0x9999,
120 "NEC",
121 "NEC USB UF000x",
122 US_SC_DEVICE, US_PR_DEVICE, NULL,
123 US_FL_SINGLE_LUN ),
124
Phil Dibowitz3e220e92005-12-18 21:30:02 -0800125/* Patch submitted by Mihnea-Costin Grigore <mihnea@zulu.ro> */
126UNUSUAL_DEV( 0x040d, 0x6205, 0x0003, 0x0003,
127 "VIA Technologies Inc.",
128 "USB 2.0 Card Reader",
129 US_SC_DEVICE, US_PR_DEVICE, NULL,
130 US_FL_IGNORE_RESIDUE ),
131
Linus Torvalds1da177e2005-04-16 15:20:36 -0700132/* Deduced by Jonathan Woithe <jwoithe@physics.adelaide.edu.au>
133 * Entry needed for flags: US_FL_FIX_INQUIRY because initial inquiry message
134 * always fails and confuses drive.
135 */
136UNUSUAL_DEV( 0x0411, 0x001c, 0x0113, 0x0113,
137 "Buffalo",
138 "DUB-P40G HDD",
139 US_SC_DEVICE, US_PR_DEVICE, NULL,
140 US_FL_FIX_INQUIRY ),
141
Ernisd8840d62006-06-26 16:02:43 -0400142/* Submitted by Ernestas Vaiciukevicius <ernisv@gmail.com> */
143UNUSUAL_DEV( 0x0419, 0x0100, 0x0100, 0x0100,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700144 "Samsung Info. Systems America, Inc.",
145 "MP3 Player",
146 US_SC_DEVICE, US_PR_DEVICE, NULL,
147 US_FL_IGNORE_RESIDUE ),
Ernisd8840d62006-06-26 16:02:43 -0400148
Phil Dibowitz5501a482006-07-04 12:46:43 -0700149/* Reported by Orgad Shaneh <orgads@gmail.com> */
150UNUSUAL_DEV( 0x0419, 0xaace, 0x0100, 0x0100,
151 "Samsung", "MP3 Player",
152 US_SC_DEVICE, US_PR_DEVICE, NULL,
153 US_FL_IGNORE_RESIDUE ),
154
Alan Stern1d614a42006-02-13 10:15:22 -0500155/* Reported by Christian Leber <christian@leber.de> */
156UNUSUAL_DEV( 0x0419, 0xaaf5, 0x0100, 0x0100,
157 "TrekStor",
158 "i.Beat 115 2.0",
159 US_SC_DEVICE, US_PR_DEVICE, NULL,
160 US_FL_IGNORE_RESIDUE | US_FL_NOT_LOCKABLE ),
161
Phil Dibowitze4a16e02005-09-30 00:20:15 -0700162/* Reported by Stefan Werner <dustbln@gmx.de> */
163UNUSUAL_DEV( 0x0419, 0xaaf6, 0x0100, 0x0100,
164 "TrekStor",
165 "i.Beat Joy 2.0",
166 US_SC_DEVICE, US_PR_DEVICE, NULL,
167 US_FL_IGNORE_RESIDUE ),
168
Pete Zaitcev23b78852006-03-05 21:45:44 -0800169/* Reported by Pete Zaitcev <zaitcev@redhat.com>, bz#176584 */
170UNUSUAL_DEV( 0x0420, 0x0001, 0x0100, 0x0100,
171 "GENERIC", "MP3 PLAYER", /* MyMusix PD-205 on the outside. */
172 US_SC_DEVICE, US_PR_DEVICE, NULL,
173 US_FL_IGNORE_RESIDUE ),
174
Andrew Nayenko0d8c7ae2007-02-25 00:40:20 -0800175/* Reported by Andrew Nayenko <relan@bk.ru> */
176UNUSUAL_DEV( 0x0421, 0x0019, 0x0592, 0x0592,
177 "Nokia",
178 "Nokia 6288",
179 US_SC_DEVICE, US_PR_DEVICE, NULL,
180 US_FL_MAX_SECTORS_64 ),
181
Alan Sternde1caa42006-07-31 10:10:28 -0400182/* Reported by Mario Rettig <mariorettig@web.de> */
183UNUSUAL_DEV( 0x0421, 0x042e, 0x0100, 0x0100,
184 "Nokia",
185 "Nokia 3250",
186 US_SC_DEVICE, US_PR_DEVICE, NULL,
187 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
188
Andrew Mortonfe1ec342006-12-04 15:22:40 -0800189/* Reported by <honkkis@gmail.com> */
190UNUSUAL_DEV( 0x0421, 0x0433, 0x0100, 0x0100,
191 "Nokia",
192 "E70",
193 US_SC_DEVICE, US_PR_DEVICE, NULL,
194 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
195
Alan Stern79238112006-09-28 12:11:56 -0400196/* Reported by Jon Hart <Jon.Hart@web.de> */
197UNUSUAL_DEV( 0x0421, 0x0434, 0x0100, 0x0100,
198 "Nokia",
199 "E60",
200 US_SC_DEVICE, US_PR_DEVICE, NULL,
201 US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
202
Alan Stern9a013552006-07-07 13:45:13 -0400203/* Reported by Sumedha Swamy <sumedhaswamy@gmail.com> and
204 * Einar Th. Einarsson <einarthered@gmail.com> */
205UNUSUAL_DEV( 0x0421, 0x0444, 0x0100, 0x0100,
206 "Nokia",
207 "N91",
208 US_SC_DEVICE, US_PR_DEVICE, NULL,
209 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
210
Alan Sternd5681fe2006-06-13 09:59:32 -0400211/* Reported by Jiri Slaby <jirislaby@gmail.com> and
212 * Rene C. Castberg <Rene@Castberg.org> */
213UNUSUAL_DEV( 0x0421, 0x0446, 0x0100, 0x0100,
214 "Nokia",
215 "N80",
216 US_SC_DEVICE, US_PR_DEVICE, NULL,
217 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
218
Alan Stern57b01b12006-07-10 11:51:12 -0400219/* Reported by Matthew Bloch <matthew@bytemark.co.uk> */
220UNUSUAL_DEV( 0x0421, 0x044e, 0x0100, 0x0100,
221 "Nokia",
222 "E61",
223 US_SC_DEVICE, US_PR_DEVICE, NULL,
224 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
225
Alan Sterne4a20da2006-10-04 16:31:15 -0400226/* Reported by Bardur Arantsson <bardur@scientician.net> */
Alan Stern393e5512007-09-18 10:09:32 -0400227UNUSUAL_DEV( 0x0421, 0x047c, 0x0370, 0x0610,
Alan Sterne4a20da2006-10-04 16:31:15 -0400228 "Nokia",
229 "6131",
230 US_SC_DEVICE, US_PR_DEVICE, NULL,
231 US_FL_MAX_SECTORS_64 ),
232
Manuel Osdoba39559b42007-01-18 21:28:45 +0100233/* Reported by Manuel Osdoba <manuel.osdoba@tu-ilmenau.de> */
Moritz Muehlenhoff716a9c82009-03-14 00:43:21 +0100234UNUSUAL_DEV( 0x0421, 0x0492, 0x0452, 0x9999,
Manuel Osdoba39559b42007-01-18 21:28:45 +0100235 "Nokia",
236 "Nokia 6233",
237 US_SC_DEVICE, US_PR_DEVICE, NULL,
238 US_FL_MAX_SECTORS_64 ),
239
Alan Stern3ccf25c2006-10-13 09:59:17 -0400240/* Reported by Alex Corcoles <alex@corcoles.net> */
241UNUSUAL_DEV( 0x0421, 0x0495, 0x0370, 0x0370,
242 "Nokia",
243 "6234",
244 US_SC_DEVICE, US_PR_DEVICE, NULL,
245 US_FL_MAX_SECTORS_64 ),
246
Phil Dibowitz1ea640c2005-08-29 22:38:28 -0700247/* Reported by Olaf Hering <olh@suse.de> from novell bug #105878 */
248UNUSUAL_DEV( 0x0424, 0x0fdc, 0x0210, 0x0210,
249 "SMSC",
250 "FDC GOLD-2.30",
251 US_SC_DEVICE, US_PR_DEVICE, NULL,
252 US_FL_SINGLE_LUN ),
253
Alan Stern0ff71882009-02-12 14:47:49 -0500254#ifdef NO_SDDR09
Alan Sternc20b15f2008-12-01 10:36:15 -0500255UNUSUAL_DEV( 0x0436, 0x0005, 0x0100, 0x0100,
256 "Microtech",
257 "CameraMate",
258 US_SC_SCSI, US_PR_CB, NULL,
259 US_FL_SINGLE_LUN ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700260#endif
261
Phil Dibowitz16f05be2006-02-13 15:59:42 -0800262/* Patch submitted by Daniel Drake <dsd@gentoo.org>
263 * Device reports nonsense bInterfaceProtocol 6 when connected over USB2 */
264UNUSUAL_DEV( 0x0451, 0x5416, 0x0100, 0x0100,
265 "Neuros Audio",
266 "USB 2.0 HD 2.5",
267 US_SC_DEVICE, US_PR_BULK, NULL,
268 US_FL_NEED_OVERRIDE ),
269
Pete Zaitcev490dce12005-08-23 07:46:13 -0700270/*
271 * Pete Zaitcev <zaitcev@yahoo.com>, from Patrick C. F. Ernzer, bz#162559.
272 * The key does not actually break, but it returns zero sense which
273 * makes our SCSI stack to print confusing messages.
274 */
275UNUSUAL_DEV( 0x0457, 0x0150, 0x0100, 0x0100,
276 "USBest Technology", /* sold by Transcend */
277 "USB Mass Storage Device",
278 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_NOT_LOCKABLE ),
279
Phil Dibowitz16f05be2006-02-13 15:59:42 -0800280/*
281* Bohdan Linda <bohdan.linda@gmail.com>
282* 1GB USB sticks MyFlash High Speed. I have restricted
283* the revision to my model only
284*/
285UNUSUAL_DEV( 0x0457, 0x0151, 0x0100, 0x0100,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700286 "USB 2.0",
287 "Flash Disk",
288 US_SC_DEVICE, US_PR_DEVICE, NULL,
289 US_FL_NOT_LOCKABLE ),
Daniel Drakee1c37b82005-08-31 16:38:41 +0100290
Andrew Morton7f38aa02006-09-25 17:00:52 -0700291#ifdef CONFIG_USB_STORAGE_KARMA
Matthew Dharmabb02fd2005-12-30 19:06:53 -0800292UNUSUAL_DEV( 0x045a, 0x5210, 0x0101, 0x0101,
293 "Rio",
294 "Rio Karma",
Matthew Dharmdfe0d3b2006-08-13 17:30:14 -0700295 US_SC_SCSI, US_PR_KARMA, rio_karma_init, 0),
Andrew Morton7f38aa02006-09-25 17:00:52 -0700296#endif
Matthew Dharmabb02fd2005-12-30 19:06:53 -0800297
Alan Sterna6b7b032008-11-21 16:15:12 -0500298/* Reported by Tamas Kerecsen <kerecsen@bigfoot.com>
299 * Obviously the PROM has not been customized by the VAR;
300 * the Vendor and Product string descriptors are:
301 * Generic Mass Storage (PROTOTYPE--Remember to change idVendor)
302 * Generic Manufacturer (PROTOTYPE--Remember to change idVendor)
303 */
304UNUSUAL_DEV( 0x045e, 0xffff, 0x0000, 0x0000,
305 "Mitac",
306 "GPS",
307 US_SC_DEVICE, US_PR_DEVICE, NULL,
308 US_FL_MAX_SECTORS_64 ),
309
Pete Zaitcev379885a2007-01-13 15:17:46 -0800310/*
311 * This virtual floppy is found in Sun equipment (x4600, x4200m2, etc.)
312 * Reported by Pete Zaitcev <zaitcev@redhat.com>
313 * This device chokes on both version of MODE SENSE which we have, so
314 * use_10_for_ms is not effective, and we use US_FL_NO_WP_DETECT.
315 */
316UNUSUAL_DEV( 0x046b, 0xff40, 0x0100, 0x0100,
317 "AMI",
318 "Virtual Floppy",
319 US_SC_DEVICE, US_PR_DEVICE, NULL,
320 US_FL_NO_WP_DETECT),
321
Linus Torvalds1da177e2005-04-16 15:20:36 -0700322/* Patch submitted by Philipp Friedrich <philipp@void.at> */
323UNUSUAL_DEV( 0x0482, 0x0100, 0x0100, 0x0100,
324 "Kyocera",
325 "Finecam S3x",
326 US_SC_8070, US_PR_CB, NULL, US_FL_FIX_INQUIRY),
327
328/* Patch submitted by Philipp Friedrich <philipp@void.at> */
329UNUSUAL_DEV( 0x0482, 0x0101, 0x0100, 0x0100,
330 "Kyocera",
331 "Finecam S4",
332 US_SC_8070, US_PR_CB, NULL, US_FL_FIX_INQUIRY),
333
334/* Patch submitted by Stephane Galles <stephane.galles@free.fr> */
335UNUSUAL_DEV( 0x0482, 0x0103, 0x0100, 0x0100,
336 "Kyocera",
337 "Finecam S5",
338 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_FIX_INQUIRY),
339
Jens Taprogge74511bb2008-10-26 18:16:09 +0100340/* Patch submitted by Jens Taprogge <jens.taprogge@taprogge.org> */
341UNUSUAL_DEV( 0x0482, 0x0107, 0x0100, 0x0100,
342 "Kyocera",
343 "CONTAX SL300R T*",
344 US_SC_DEVICE, US_PR_DEVICE, NULL,
345 US_FL_FIX_CAPACITY | US_FL_NOT_LOCKABLE),
346
Linus Torvalds1da177e2005-04-16 15:20:36 -0700347/* Reported by Paul Stewart <stewart@wetlogic.net>
348 * This entry is needed because the device reports Sub=ff */
349UNUSUAL_DEV( 0x04a4, 0x0004, 0x0001, 0x0001,
350 "Hitachi",
351 "DVD-CAM DZ-MV100A Camcorder",
352 US_SC_SCSI, US_PR_CB, NULL, US_FL_SINGLE_LUN),
353
Alan Sternf9dc8f92008-11-18 14:08:07 -0500354/* BENQ DC5330
355 * Reported by Manuel Fombuena <mfombuena@ya.com> and
356 * Frank Copeland <fjc@thingy.apana.org.au> */
357UNUSUAL_DEV( 0x04a5, 0x3010, 0x0100, 0x0100,
358 "Tekom Technologies, Inc",
359 "300_CAMERA",
360 US_SC_DEVICE, US_PR_DEVICE, NULL,
361 US_FL_IGNORE_RESIDUE ),
362
fabien COSSE17fa6e52005-11-30 01:16:00 -0800363/* Patch for Nikon coolpix 2000
364 * Submitted by Fabien Cosse <fabien.cosse@wanadoo.fr>*/
365UNUSUAL_DEV( 0x04b0, 0x0301, 0x0010, 0x0010,
366 "NIKON",
367 "NIKON DSC E2000",
368 US_SC_DEVICE, US_PR_DEVICE,NULL,
369 US_FL_NOT_LOCKABLE ),
370
Doug Maxey33abc042007-12-05 23:36:45 -0600371/* Reported by Doug Maxey (dwm@austin.ibm.com) */
372UNUSUAL_DEV( 0x04b3, 0x4001, 0x0110, 0x0110,
373 "IBM",
374 "IBM RSA2",
375 US_SC_DEVICE, US_PR_CB, NULL,
376 US_FL_MAX_SECTORS_MIN),
377
Phil Dibowitzed3e8fc2008-05-03 18:04:30 -0700378#ifdef CONFIG_USB_STORAGE_CYPRESS_ATACB
matthieu castete72616f2008-06-16 19:49:06 +0200379/* CY7C68300 : support atacb */
Phil Dibowitzed3e8fc2008-05-03 18:04:30 -0700380UNUSUAL_DEV( 0x04b4, 0x6830, 0x0000, 0x9999,
381 "Cypress",
382 "Cypress AT2LP",
Alan Sternc7257bd2008-05-21 13:53:01 -0400383 US_SC_CYP_ATACB, US_PR_DEVICE, NULL,
Phil Dibowitzed3e8fc2008-05-03 18:04:30 -0700384 0),
matthieu castete72616f2008-06-16 19:49:06 +0200385
386/* CY7C68310 : support atacb and atacb2 */
387UNUSUAL_DEV( 0x04b4, 0x6831, 0x0000, 0x9999,
388 "Cypress",
389 "Cypress ISD-300LP",
390 US_SC_CYP_ATACB, US_PR_DEVICE, NULL,
391 0),
Phil Dibowitzed3e8fc2008-05-03 18:04:30 -0700392#endif
393
Linus Torvalds1da177e2005-04-16 15:20:36 -0700394/* Reported by Simon Levitt <simon@whattf.com>
395 * This entry needs Sub and Proto fields */
396UNUSUAL_DEV( 0x04b8, 0x0601, 0x0100, 0x0100,
397 "Epson",
398 "875DC Storage",
399 US_SC_SCSI, US_PR_CB, NULL, US_FL_FIX_INQUIRY),
400
401/* Reported by Khalid Aziz <khalid@gonehiking.org>
402 * This entry is needed because the device reports Sub=ff */
403UNUSUAL_DEV( 0x04b8, 0x0602, 0x0110, 0x0110,
404 "Epson",
405 "785EPX Storage",
406 US_SC_SCSI, US_PR_BULK, NULL, US_FL_SINGLE_LUN),
407
408/* Not sure who reported this originally but
409 * Pavel Machek <pavel@ucw.cz> reported that the extra US_FL_SINGLE_LUN
410 * flag be added */
411UNUSUAL_DEV( 0x04cb, 0x0100, 0x0000, 0x2210,
412 "Fujifilm",
413 "FinePix 1400Zoom",
414 US_SC_UFI, US_PR_DEVICE, NULL, US_FL_FIX_INQUIRY | US_FL_SINGLE_LUN),
415
Jan Engelhardt96de0e22007-10-19 23:21:04 +0200416/* Reported by Peter Wächtler <pwaechtler@loewe-komp.de>
Linus Torvalds1da177e2005-04-16 15:20:36 -0700417 * The device needs the flags only.
418 */
419UNUSUAL_DEV( 0x04ce, 0x0002, 0x0074, 0x0074,
420 "ScanLogic",
421 "SL11R-IDE",
422 US_SC_DEVICE, US_PR_DEVICE, NULL,
423 US_FL_FIX_INQUIRY),
424
425/* Reported by Kriston Fincher <kriston@airmail.net>
426 * Patch submitted by Sean Millichamp <sean@bruenor.org>
427 * This is to support the Panasonic PalmCam PV-SD4090
428 * This entry is needed because the device reports Sub=ff
429 */
430UNUSUAL_DEV( 0x04da, 0x0901, 0x0100, 0x0200,
431 "Panasonic",
432 "LS-120 Camera",
433 US_SC_UFI, US_PR_DEVICE, NULL, 0),
434
435/* From Yukihiro Nakai, via zaitcev@yahoo.com.
436 * This is needed for CB instead of CBI */
437UNUSUAL_DEV( 0x04da, 0x0d05, 0x0000, 0x0000,
438 "Sharp CE-CW05",
439 "CD-R/RW Drive",
440 US_SC_8070, US_PR_CB, NULL, 0),
441
442/* Reported by Adriaan Penning <a.penning@luon.net> */
443UNUSUAL_DEV( 0x04da, 0x2372, 0x0000, 0x9999,
444 "Panasonic",
445 "DMC-LCx Camera",
446 US_SC_DEVICE, US_PR_DEVICE, NULL,
447 US_FL_FIX_CAPACITY | US_FL_NOT_LOCKABLE ),
448
Simeon Simeonovdcab4ea2005-10-19 11:32:14 -0400449/* Reported by Simeon Simeonov <simeonov_2000@yahoo.com> */
450UNUSUAL_DEV( 0x04da, 0x2373, 0x0000, 0x9999,
451 "LEICA",
452 "D-LUX Camera",
453 US_SC_DEVICE, US_PR_DEVICE, NULL,
454 US_FL_FIX_CAPACITY | US_FL_NOT_LOCKABLE ),
455
Linus Torvalds1da177e2005-04-16 15:20:36 -0700456/* Most of the following entries were developed with the help of
457 * Shuttle/SCM directly.
458 */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700459UNUSUAL_DEV( 0x04e6, 0x0001, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700460 "Matshita",
461 "LS-120",
462 US_SC_8020, US_PR_CB, NULL, 0),
463
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700464UNUSUAL_DEV( 0x04e6, 0x0002, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700465 "Shuttle",
466 "eUSCSI Bridge",
467 US_SC_DEVICE, US_PR_DEVICE, usb_stor_euscsi_init,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700468 US_FL_SCM_MULT_TARG ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700469
Alan Stern0ff71882009-02-12 14:47:49 -0500470#ifdef NO_SDDR09
Alan Sternc20b15f2008-12-01 10:36:15 -0500471UNUSUAL_DEV( 0x04e6, 0x0005, 0x0100, 0x0208,
472 "SCM Microsystems",
473 "eUSB CompactFlash Adapter",
474 US_SC_SCSI, US_PR_CB, NULL,
475 US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700476#endif
477
478/* Reported by Markus Demleitner <msdemlei@cl.uni-heidelberg.de> */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700479UNUSUAL_DEV( 0x04e6, 0x0006, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700480 "SCM Microsystems Inc.",
481 "eUSB MMC Adapter",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700482 US_SC_SCSI, US_PR_CB, NULL,
483 US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700484
485/* Reported by Daniel Nouri <dpunktnpunkt@web.de> */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700486UNUSUAL_DEV( 0x04e6, 0x0006, 0x0205, 0x0205,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700487 "Shuttle",
488 "eUSB MMC Adapter",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700489 US_SC_SCSI, US_PR_DEVICE, NULL,
490 US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700491
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700492UNUSUAL_DEV( 0x04e6, 0x0007, 0x0100, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700493 "Sony",
494 "Hifd",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700495 US_SC_SCSI, US_PR_CB, NULL,
496 US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700497
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700498UNUSUAL_DEV( 0x04e6, 0x0009, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700499 "Shuttle",
500 "eUSB ATA/ATAPI Adapter",
501 US_SC_8020, US_PR_CB, NULL, 0),
502
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700503UNUSUAL_DEV( 0x04e6, 0x000a, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700504 "Shuttle",
505 "eUSB CompactFlash Adapter",
506 US_SC_8020, US_PR_CB, NULL, 0),
507
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700508UNUSUAL_DEV( 0x04e6, 0x000B, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700509 "Shuttle",
510 "eUSCSI Bridge",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700511 US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700512 US_FL_SCM_MULT_TARG ),
513
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700514UNUSUAL_DEV( 0x04e6, 0x000C, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700515 "Shuttle",
516 "eUSCSI Bridge",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700517 US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
518 US_FL_SCM_MULT_TARG ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700519
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700520UNUSUAL_DEV( 0x04e6, 0x0101, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700521 "Shuttle",
522 "CD-RW Device",
523 US_SC_8020, US_PR_CB, NULL, 0),
524
Linus Torvalds1da177e2005-04-16 15:20:36 -0700525#ifdef CONFIG_USB_STORAGE_USBAT
526UNUSUAL_DEV( 0x04e6, 0x1010, 0x0000, 0x9999,
Daniel Drakeb7b1e652005-09-30 12:49:36 +0100527 "Shuttle/SCM",
528 "USBAT-02",
Daniel Drakef9347c52006-05-08 23:43:02 +0100529 US_SC_SCSI, US_PR_USBAT, init_usbat_flash,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700530 US_FL_SINGLE_LUN),
531#endif
532
Alan Sternb28884c2008-04-28 10:26:13 -0400533/* Reported by Dmitry Khlystov <adminimus@gmail.com> */
534UNUSUAL_DEV( 0x04e8, 0x507c, 0x0220, 0x0220,
535 "Samsung",
536 "YP-U3",
537 US_SC_DEVICE, US_PR_DEVICE, NULL,
538 US_FL_MAX_SECTORS_64),
539
Phil Dibowitzed3e8fc2008-05-03 18:04:30 -0700540/* Entry and supporting patch by Theodore Kilgore <kilgota@auburn.edu>.
541 * Device uses standards-violating 32-byte Bulk Command Block Wrappers and
542 * reports itself as "Proprietary SCSI Bulk." Cf. device entry 0x084d:0x0011.
543 */
544UNUSUAL_DEV( 0x04fc, 0x80c2, 0x0100, 0x0100,
545 "Kobian Mercury",
546 "Binocam DCB-132",
547 US_SC_DEVICE, US_PR_DEVICE, NULL,
548 US_FL_BULK32),
549
Linus Torvalds1da177e2005-04-16 15:20:36 -0700550/* Reported by Bob Sass <rls@vectordb.com> -- only rev 1.33 tested */
551UNUSUAL_DEV( 0x050d, 0x0115, 0x0133, 0x0133,
552 "Belkin",
553 "USB SCSI Adaptor",
554 US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
555 US_FL_SCM_MULT_TARG ),
556
557/* Iomega Clik! Drive
558 * Reported by David Chatenay <dchatenay@hotmail.com>
559 * The reason this is needed is not fully known.
560 */
561UNUSUAL_DEV( 0x0525, 0xa140, 0x0100, 0x0100,
562 "Iomega",
563 "USB Clik! 40",
Phil Dibowitz21206382006-04-16 19:18:36 -0700564 US_SC_8070, US_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700565 US_FL_FIX_INQUIRY ),
566
Alan Stern25ff1c32008-12-15 12:43:41 -0500567/* Added by Alan Stern <stern@rowland.harvard.edu> */
568COMPLIANT_DEV(0x0525, 0xa4a5, 0x0000, 0x9999,
569 "Linux",
570 "File-backed Storage Gadget",
571 US_SC_DEVICE, US_PR_DEVICE, NULL,
572 US_FL_CAPACITY_OK ),
573
Linus Torvalds1da177e2005-04-16 15:20:36 -0700574/* Yakumo Mega Image 37
575 * Submitted by Stephan Fuhrmann <atomenergie@t-online.de> */
576UNUSUAL_DEV( 0x052b, 0x1801, 0x0100, 0x0100,
577 "Tekom Technologies, Inc",
578 "300_CAMERA",
579 US_SC_DEVICE, US_PR_DEVICE, NULL,
580 US_FL_IGNORE_RESIDUE ),
581
582/* Another Yakumo camera.
583 * Reported by Michele Alzetta <michele.alzetta@aliceposta.it> */
584UNUSUAL_DEV( 0x052b, 0x1804, 0x0100, 0x0100,
585 "Tekom Technologies, Inc",
586 "300_CAMERA",
587 US_SC_DEVICE, US_PR_DEVICE, NULL,
588 US_FL_IGNORE_RESIDUE ),
589
590/* Reported by Iacopo Spalletti <avvisi@spalletti.it> */
591UNUSUAL_DEV( 0x052b, 0x1807, 0x0100, 0x0100,
592 "Tekom Technologies, Inc",
593 "300_CAMERA",
594 US_SC_DEVICE, US_PR_DEVICE, NULL,
595 US_FL_IGNORE_RESIDUE ),
596
597/* Yakumo Mega Image 47
598 * Reported by Bjoern Paetzel <kolrabi@kolrabi.de> */
599UNUSUAL_DEV( 0x052b, 0x1905, 0x0100, 0x0100,
600 "Tekom Technologies, Inc",
601 "400_CAMERA",
602 US_SC_DEVICE, US_PR_DEVICE, NULL,
603 US_FL_IGNORE_RESIDUE ),
604
605/* Reported by Paul Ortyl <ortylp@3miasto.net>
606 * Note that it's similar to the device above, only different prodID */
607UNUSUAL_DEV( 0x052b, 0x1911, 0x0100, 0x0100,
608 "Tekom Technologies, Inc",
609 "400_CAMERA",
610 US_SC_DEVICE, US_PR_DEVICE, NULL,
611 US_FL_IGNORE_RESIDUE ),
612
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700613UNUSUAL_DEV( 0x054c, 0x0010, 0x0106, 0x0450,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700614 "Sony",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700615 "DSC-S30/S70/S75/505V/F505/F707/F717/P8",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700616 US_SC_SCSI, US_PR_DEVICE, NULL,
617 US_FL_SINGLE_LUN | US_FL_NOT_LOCKABLE | US_FL_NO_WP_DETECT ),
618
Lars Jacob7e3bd122006-07-10 11:53:58 -0400619/* Submitted by Lars Jacob <jacob.lars@googlemail.com>
620 * This entry is needed because the device reports Sub=ff */
621UNUSUAL_DEV( 0x054c, 0x0010, 0x0500, 0x0610,
Alexandre Duret-Lutzec7dc8d2005-12-26 23:04:24 -0800622 "Sony",
Lars Jacob7e3bd122006-07-10 11:53:58 -0400623 "DSC-T1/T5/H5",
Alexandre Duret-Lutzec7dc8d2005-12-26 23:04:24 -0800624 US_SC_8070, US_PR_DEVICE, NULL,
625 US_FL_SINGLE_LUN ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700626
627
628/* Reported by wim@geeks.nl */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700629UNUSUAL_DEV( 0x054c, 0x0025, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700630 "Sony",
631 "Memorystick NW-MS7",
632 US_SC_DEVICE, US_PR_DEVICE, NULL,
633 US_FL_SINGLE_LUN ),
634
635#ifdef CONFIG_USB_STORAGE_ISD200
636UNUSUAL_DEV( 0x054c, 0x002b, 0x0100, 0x0110,
637 "Sony",
638 "Portable USB Harddrive V2",
639 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
640 0 ),
641#endif
642
643/* Submitted by Olaf Hering, <olh@suse.de> SuSE Bugzilla #49049 */
Luiz Fernando N. Capitulino20b2e282007-01-24 16:19:37 -0200644UNUSUAL_DEV( 0x054c, 0x002c, 0x0501, 0x2000,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700645 "Sony",
646 "USB Floppy Drive",
647 US_SC_DEVICE, US_PR_DEVICE, NULL,
648 US_FL_SINGLE_LUN ),
649
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700650UNUSUAL_DEV( 0x054c, 0x002d, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700651 "Sony",
652 "Memorystick MSAC-US1",
653 US_SC_DEVICE, US_PR_DEVICE, NULL,
654 US_FL_SINGLE_LUN ),
655
656/* Submitted by Klaus Mueller <k.mueller@intershop.de> */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700657UNUSUAL_DEV( 0x054c, 0x002e, 0x0106, 0x0310,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700658 "Sony",
659 "Handycam",
660 US_SC_SCSI, US_PR_DEVICE, NULL,
661 US_FL_SINGLE_LUN ),
662
663/* Submitted by Rajesh Kumble Nayak <nayak@obs-nice.fr> */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700664UNUSUAL_DEV( 0x054c, 0x002e, 0x0500, 0x0500,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700665 "Sony",
666 "Handycam HC-85",
667 US_SC_UFI, US_PR_DEVICE, NULL,
668 US_FL_SINGLE_LUN ),
669
670UNUSUAL_DEV( 0x054c, 0x0032, 0x0000, 0x9999,
671 "Sony",
672 "Memorystick MSC-U01N",
673 US_SC_DEVICE, US_PR_DEVICE, NULL,
674 US_FL_SINGLE_LUN ),
675
676/* Submitted by Michal Mlotek <mlotek@foobar.pl> */
677UNUSUAL_DEV( 0x054c, 0x0058, 0x0000, 0x9999,
678 "Sony",
679 "PEG N760c Memorystick",
680 US_SC_DEVICE, US_PR_DEVICE, NULL,
681 US_FL_FIX_INQUIRY ),
682
683UNUSUAL_DEV( 0x054c, 0x0069, 0x0000, 0x9999,
684 "Sony",
685 "Memorystick MSC-U03",
686 US_SC_UFI, US_PR_CB, NULL,
687 US_FL_SINGLE_LUN ),
688
689/* Submitted by Nathan Babb <nathan@lexi.com> */
690UNUSUAL_DEV( 0x054c, 0x006d, 0x0000, 0x9999,
691 "Sony",
692 "PEG Mass Storage",
693 US_SC_DEVICE, US_PR_DEVICE, NULL,
694 US_FL_FIX_INQUIRY ),
695
Alan Sternf9dc8f92008-11-18 14:08:07 -0500696/* Submitted by Frank Engel <frankie@cse.unsw.edu.au> */
697UNUSUAL_DEV( 0x054c, 0x0099, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700698 "Sony",
699 "PEG Mass Storage",
700 US_SC_DEVICE, US_PR_DEVICE, NULL,
701 US_FL_FIX_INQUIRY ),
Alan Sternf9dc8f92008-11-18 14:08:07 -0500702
703/* Submitted by Mike Alborn <malborn@deandra.homeip.net> */
704UNUSUAL_DEV( 0x054c, 0x016a, 0x0000, 0x9999,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700705 "Sony",
706 "PEG Mass Storage",
707 US_SC_DEVICE, US_PR_DEVICE, NULL,
708 US_FL_FIX_INQUIRY ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700709
juergen.mell@t-online.de082fdd12006-08-28 13:53:53 -0700710/* floppy reports multiple luns */
711UNUSUAL_DEV( 0x055d, 0x2020, 0x0000, 0x0210,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700712 "SAMSUNG",
713 "SFD-321U [FW 0C]",
714 US_SC_DEVICE, US_PR_DEVICE, NULL,
715 US_FL_SINGLE_LUN ),
juergen.mell@t-online.de082fdd12006-08-28 13:53:53 -0700716
Linus Torvalds1da177e2005-04-16 15:20:36 -0700717
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700718UNUSUAL_DEV( 0x057b, 0x0000, 0x0000, 0x0299,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700719 "Y-E Data",
720 "Flashbuster-U",
721 US_SC_DEVICE, US_PR_CB, NULL,
722 US_FL_SINGLE_LUN),
723
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700724UNUSUAL_DEV( 0x057b, 0x0000, 0x0300, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700725 "Y-E Data",
726 "Flashbuster-U",
727 US_SC_DEVICE, US_PR_DEVICE, NULL,
728 US_FL_SINGLE_LUN),
729
730/* Reported by Johann Cardon <johann.cardon@free.fr>
731 * This entry is needed only because the device reports
732 * bInterfaceClass = 0xff (vendor-specific)
733 */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700734UNUSUAL_DEV( 0x057b, 0x0022, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700735 "Y-E Data",
736 "Silicon Media R/W",
737 US_SC_DEVICE, US_PR_DEVICE, NULL, 0),
738
Matthew Dharme80b0fa2005-12-04 22:02:44 -0800739#ifdef CONFIG_USB_STORAGE_ALAUDA
740UNUSUAL_DEV( 0x0584, 0x0008, 0x0102, 0x0102,
741 "Fujifilm",
742 "DPC-R1 (Alauda)",
743 US_SC_SCSI, US_PR_ALAUDA, init_alauda, 0 ),
744#endif
745
Alan Sternf1e8de0d2007-11-26 10:23:05 -0500746/* Reported by RTE <raszilki@yandex.ru> */
747UNUSUAL_DEV( 0x058f, 0x6387, 0x0141, 0x0141,
748 "JetFlash",
749 "TS1GJF2A/120",
750 US_SC_DEVICE, US_PR_DEVICE, NULL,
751 US_FL_MAX_SECTORS_64 ),
752
Linus Torvalds1da177e2005-04-16 15:20:36 -0700753/* Fabrizio Fellini <fello@libero.it> */
754UNUSUAL_DEV( 0x0595, 0x4343, 0x0000, 0x2210,
755 "Fujifilm",
756 "Digital Camera EX-20 DSC",
757 US_SC_8070, US_PR_DEVICE, NULL, 0 ),
758
Alan Sterna4625492008-02-13 10:45:28 -0500759/* Reported by Andre Welter <a.r.welter@gmx.de>
760 * This antique device predates the release of the Bulk-only Transport
761 * spec, and if it gets a Get-Max-LUN then it requires the host to do a
762 * Clear-Halt on the bulk endpoints. The SINGLE_LUN flag will prevent
763 * us from sending the request.
764 */
765UNUSUAL_DEV( 0x059b, 0x0001, 0x0100, 0x0100,
766 "Iomega",
767 "ZIP 100",
768 US_SC_DEVICE, US_PR_DEVICE, NULL,
769 US_FL_SINGLE_LUN ),
770
Alan Sternb97b1962006-09-14 15:18:54 -0400771/* Reported by <Hendryk.Pfeiffer@gmx.de> */
772UNUSUAL_DEV( 0x059f, 0x0643, 0x0000, 0x0000,
773 "LaCie",
774 "DVD+-RW",
775 US_SC_DEVICE, US_PR_DEVICE, NULL,
776 US_FL_GO_SLOW ),
777
Linus Torvalds1da177e2005-04-16 15:20:36 -0700778/* Submitted by Joel Bourquard <numlock@freesurf.ch>
779 * Some versions of this device need the SubClass and Protocol overrides
780 * while others don't.
781 */
782UNUSUAL_DEV( 0x05ab, 0x0060, 0x1104, 0x1110,
783 "In-System",
784 "PyroGate External CD-ROM Enclosure (FCD-523)",
785 US_SC_SCSI, US_PR_BULK, NULL,
786 US_FL_NEED_OVERRIDE ),
787
788#ifdef CONFIG_USB_STORAGE_ISD200
789UNUSUAL_DEV( 0x05ab, 0x0031, 0x0100, 0x0110,
790 "In-System",
791 "USB/IDE Bridge (ATA/ATAPI)",
792 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
793 0 ),
794
795UNUSUAL_DEV( 0x05ab, 0x0301, 0x0100, 0x0110,
796 "In-System",
797 "Portable USB Harddrive V2",
798 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
799 0 ),
800
801UNUSUAL_DEV( 0x05ab, 0x0351, 0x0100, 0x0110,
802 "In-System",
803 "Portable USB Harddrive V2",
804 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
805 0 ),
806
807UNUSUAL_DEV( 0x05ab, 0x5701, 0x0100, 0x0110,
808 "In-System",
809 "USB Storage Adapter V2",
810 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
811 0 ),
812#endif
813
Sven Anderson35f4a0c2005-04-22 15:06:58 -0700814/* Submitted by Sven Anderson <sven-linux@anderson.de>
815 * There are at least four ProductIDs used for iPods, so I added 0x1202 and
816 * 0x1204. They just need the US_FL_FIX_CAPACITY. As the bcdDevice appears
817 * to change with firmware updates, I changed the range to maximum for all
818 * iPod entries.
819 */
820UNUSUAL_DEV( 0x05ac, 0x1202, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700821 "Apple",
822 "iPod",
823 US_SC_DEVICE, US_PR_DEVICE, NULL,
824 US_FL_FIX_CAPACITY ),
825
Sven Anderson35f4a0c2005-04-22 15:06:58 -0700826/* Reported by Avi Kivity <avi@argo.co.il> */
827UNUSUAL_DEV( 0x05ac, 0x1203, 0x0000, 0x9999,
828 "Apple",
829 "iPod",
830 US_SC_DEVICE, US_PR_DEVICE, NULL,
831 US_FL_FIX_CAPACITY ),
832
833UNUSUAL_DEV( 0x05ac, 0x1204, 0x0000, 0x9999,
834 "Apple",
835 "iPod",
836 US_SC_DEVICE, US_PR_DEVICE, NULL,
Pete Zaitcevad1428c2006-12-31 13:43:26 -0800837 US_FL_FIX_CAPACITY | US_FL_NOT_LOCKABLE ),
Sven Anderson35f4a0c2005-04-22 15:06:58 -0700838
839UNUSUAL_DEV( 0x05ac, 0x1205, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700840 "Apple",
841 "iPod",
842 US_SC_DEVICE, US_PR_DEVICE, NULL,
843 US_FL_FIX_CAPACITY ),
844
Phil Dibowitz880a9b52005-09-30 00:27:36 -0700845/*
846 * Reported by Tyson Vinson <lornoss@gmail.com>
847 * This particular productId is the iPod Nano
848 */
849UNUSUAL_DEV( 0x05ac, 0x120a, 0x0000, 0x9999,
850 "Apple",
851 "iPod",
852 US_SC_DEVICE, US_PR_DEVICE, NULL,
853 US_FL_FIX_CAPACITY ),
854
Dan Williams281b0642008-12-14 12:39:22 -0500855/* Reported by Dan Williams <dcbw@redhat.com>
856 * Option N.V. mobile broadband modems
857 * Ignore driver CD mode and force into modem mode by default.
858 */
859
860/* Globetrotter HSDPA; mass storage shows up as Qualcomm for vendor */
861UNUSUAL_DEV( 0x05c6, 0x1000, 0x0000, 0x9999,
862 "Option N.V.",
863 "Mass Storage",
864 US_SC_DEVICE, US_PR_DEVICE, option_ms_init,
865 0),
866
Linus Torvalds1da177e2005-04-16 15:20:36 -0700867#ifdef CONFIG_USB_STORAGE_JUMPSHOT
868UNUSUAL_DEV( 0x05dc, 0x0001, 0x0000, 0x0001,
869 "Lexar",
870 "Jumpshot USB CF Reader",
871 US_SC_SCSI, US_PR_JUMPSHOT, NULL,
872 US_FL_NEED_OVERRIDE ),
873#endif
874
875/* Reported by Blake Matheny <bmatheny@purdue.edu> */
876UNUSUAL_DEV( 0x05dc, 0xb002, 0x0000, 0x0113,
877 "Lexar",
878 "USB CF Reader",
879 US_SC_DEVICE, US_PR_DEVICE, NULL,
880 US_FL_FIX_INQUIRY ),
881
882/* The following two entries are for a Genesys USB to IDE
883 * converter chip, but it changes its ProductId depending
884 * on whether or not a disk or an optical device is enclosed
885 * They were originally reported by Alexander Oltu
886 * <alexander@all-2.com> and Peter Marks <peter.marks@turner.com>
887 * respectively.
Phil Dibowitz883d9892006-06-24 17:27:10 -0700888 *
889 * US_FL_GO_SLOW and US_FL_MAX_SECTORS_64 added by Phil Dibowitz
890 * <phil@ipom.com> as these flags were made and hard-coded
891 * special-cases were pulled from scsiglue.c.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700892 */
893UNUSUAL_DEV( 0x05e3, 0x0701, 0x0000, 0xffff,
894 "Genesys Logic",
895 "USB to IDE Optical",
896 US_SC_DEVICE, US_PR_DEVICE, NULL,
Alan Stern5126a262009-02-23 12:02:05 -0500897 US_FL_GO_SLOW | US_FL_MAX_SECTORS_64 | US_FL_IGNORE_RESIDUE ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700898
899UNUSUAL_DEV( 0x05e3, 0x0702, 0x0000, 0xffff,
900 "Genesys Logic",
901 "USB to IDE Disk",
902 US_SC_DEVICE, US_PR_DEVICE, NULL,
Alan Stern5126a262009-02-23 12:02:05 -0500903 US_FL_GO_SLOW | US_FL_MAX_SECTORS_64 | US_FL_IGNORE_RESIDUE ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700904
Ben Efrosdbe6e0c02008-11-23 20:06:38 -0800905/* Reported by Ben Efros <ben@pc-doctor.com> */
906UNUSUAL_DEV( 0x05e3, 0x0723, 0x9451, 0x9451,
907 "Genesys Logic",
908 "USB to SATA",
909 US_SC_DEVICE, US_PR_DEVICE, NULL,
910 US_FL_SANE_SENSE ),
911
Linus Torvalds1da177e2005-04-16 15:20:36 -0700912/* Reported by Hanno Boeck <hanno@gmx.de>
913 * Taken from the Lycoris Kernel */
914UNUSUAL_DEV( 0x0636, 0x0003, 0x0000, 0x9999,
915 "Vivitar",
916 "Vivicam 35Xx",
917 US_SC_SCSI, US_PR_BULK, NULL,
918 US_FL_FIX_INQUIRY ),
919
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700920UNUSUAL_DEV( 0x0644, 0x0000, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700921 "TEAC",
922 "Floppy Drive",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700923 US_SC_UFI, US_PR_CB, NULL, 0 ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700924
Linus Torvalds1da177e2005-04-16 15:20:36 -0700925/* Reported by Darsen Lu <darsen@micro.ee.nthu.edu.tw> */
926UNUSUAL_DEV( 0x066f, 0x8000, 0x0001, 0x0001,
927 "SigmaTel",
928 "USBMSC Audio Player",
929 US_SC_DEVICE, US_PR_DEVICE, NULL,
930 US_FL_FIX_CAPACITY ),
931
932/* Reported by Richard -=[]=- <micro_flyer@hotmail.com> */
Thomas Bartosik8a0845c2009-03-16 16:04:38 +0100933/* Change to bcdDeviceMin (0x0100 to 0x0001) reported by
934 * Thomas Bartosik <tbartdev@gmx-topmail.de> */
935UNUSUAL_DEV( 0x067b, 0x2507, 0x0001, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700936 "Prolific Technology Inc.",
937 "Mass Storage Device",
938 US_SC_DEVICE, US_PR_DEVICE, NULL,
939 US_FL_FIX_CAPACITY | US_FL_GO_SLOW ),
940
941/* Reported by Alex Butcher <alex.butcher@assursys.co.uk> */
Oliver Neukumb1636392008-12-12 11:01:45 +0100942UNUSUAL_DEV( 0x067b, 0x3507, 0x0001, 0x0101,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700943 "Prolific Technology Inc.",
944 "ATAPI-6 Bridge Controller",
945 US_SC_DEVICE, US_PR_DEVICE, NULL,
946 US_FL_FIX_CAPACITY | US_FL_GO_SLOW ),
947
948/* Submitted by Benny Sjostrand <benny@hostmobility.com> */
949UNUSUAL_DEV( 0x0686, 0x4011, 0x0001, 0x0001,
950 "Minolta",
951 "Dimage F300",
952 US_SC_SCSI, US_PR_BULK, NULL, 0 ),
953
954/* Reported by Miguel A. Fosas <amn3s1a@ono.com> */
955UNUSUAL_DEV( 0x0686, 0x4017, 0x0001, 0x0001,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700956 "Minolta",
957 "DIMAGE E223",
958 US_SC_SCSI, US_PR_DEVICE, NULL, 0 ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700959
Linus Torvalds1da177e2005-04-16 15:20:36 -0700960UNUSUAL_DEV( 0x0693, 0x0005, 0x0100, 0x0100,
961 "Hagiwara",
962 "Flashgate",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700963 US_SC_SCSI, US_PR_BULK, NULL, 0 ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700964
Alan Stern754501b2006-02-23 10:19:25 -0500965/* Reported by David Hamilton <niftimusmaximus@lycos.com> */
966UNUSUAL_DEV( 0x069b, 0x3004, 0x0001, 0x0001,
967 "Thomson Multimedia Inc.",
968 "RCA RD1080 MP3 Player",
969 US_SC_DEVICE, US_PR_DEVICE, NULL,
970 US_FL_FIX_CAPACITY ),
971
Alan Sternfe1926a2008-09-04 09:56:35 -0400972/* Reported by Adrian Pilchowiec <adi1981@epf.pl> */
973UNUSUAL_DEV( 0x071b, 0x3203, 0x0000, 0x0000,
974 "RockChip",
975 "MP3",
976 US_SC_DEVICE, US_PR_DEVICE, NULL,
977 US_FL_NO_WP_DETECT | US_FL_MAX_SECTORS_64),
978
Jean-Baptiste Onofre64915092008-12-20 20:11:55 +0100979/* Reported by Jean-Baptiste Onofre <jb@nanthrax.net>
980 * Support the following product :
981 * "Dane-Elec MediaTouch"
982 */
983UNUSUAL_DEV( 0x071b, 0x32bb, 0x0000, 0x0000,
984 "RockChip",
985 "MTP",
986 US_SC_DEVICE, US_PR_DEVICE, NULL,
987 US_FL_NO_WP_DETECT | US_FL_MAX_SECTORS_64),
988
Massimiliano Ghilardic4766562007-09-04 22:53:43 +0200989/* Reported by Massimiliano Ghilardi <massimiliano.ghilardi@gmail.com>
990 * This USB MP3/AVI player device fails and disconnects if more than 128
991 * sectors (64kB) are read/written in a single command, and may be present
992 * at least in the following products:
993 * "Magnex Digital Video Panel DVP 1800"
994 * "MP4 AIGO 4GB SLOT SD"
995 * "Teclast TL-C260 MP3"
996 * "i.Meizu PMP MP3/MP4"
997 * "Speed MV8 MP4 Audio Player"
998 */
999UNUSUAL_DEV( 0x071b, 0x3203, 0x0100, 0x0100,
1000 "RockChip",
1001 "ROCK MP3",
1002 US_SC_DEVICE, US_PR_DEVICE, NULL,
1003 US_FL_MAX_SECTORS_64),
1004
Olivier Blondeauf430c402006-04-16 19:19:25 -07001005/* Reported by Olivier Blondeau <zeitoun@gmail.com> */
1006UNUSUAL_DEV( 0x0727, 0x0306, 0x0100, 0x0100,
1007 "ATMEL",
1008 "SND1 Storage",
1009 US_SC_DEVICE, US_PR_DEVICE, NULL,
1010 US_FL_IGNORE_RESIDUE),
1011
Phil Dibowitz1e7a5a82006-03-05 21:36:51 -08001012/* Submitted by Roman Hodek <roman@hodek.net> */
1013UNUSUAL_DEV( 0x0781, 0x0001, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001014 "Sandisk",
1015 "ImageMate SDDR-05a",
1016 US_SC_SCSI, US_PR_CB, NULL,
1017 US_FL_SINGLE_LUN ),
1018
Phil Dibowitz1e7a5a82006-03-05 21:36:51 -08001019UNUSUAL_DEV( 0x0781, 0x0002, 0x0009, 0x0009,
1020 "SanDisk Corporation",
1021 "ImageMate CompactFlash USB",
1022 US_SC_DEVICE, US_PR_DEVICE, NULL,
1023 US_FL_FIX_CAPACITY ),
1024
Daniel Drake094ec602005-09-30 12:58:13 +01001025#ifdef CONFIG_USB_STORAGE_USBAT
1026UNUSUAL_DEV( 0x0781, 0x0005, 0x0005, 0x0005,
1027 "Sandisk",
1028 "ImageMate SDDR-05b",
Peter Chubbbdcfd9e2006-05-02 18:29:34 +01001029 US_SC_SCSI, US_PR_USBAT, init_usbat_flash,
Daniel Drake094ec602005-09-30 12:58:13 +01001030 US_FL_SINGLE_LUN ),
1031#endif
1032
Linus Torvalds1da177e2005-04-16 15:20:36 -07001033UNUSUAL_DEV( 0x0781, 0x0100, 0x0100, 0x0100,
1034 "Sandisk",
1035 "ImageMate SDDR-12",
1036 US_SC_SCSI, US_PR_CB, NULL,
1037 US_FL_SINGLE_LUN ),
1038
Linus Torvalds1da177e2005-04-16 15:20:36 -07001039#ifdef CONFIG_USB_STORAGE_FREECOM
1040UNUSUAL_DEV( 0x07ab, 0xfc01, 0x0000, 0x9999,
1041 "Freecom",
1042 "USB-IDE",
1043 US_SC_QIC, US_PR_FREECOM, freecom_init, 0),
1044#endif
1045
1046/* Reported by Eero Volotinen <eero@ping-viini.org> */
Phil Dibowitze5278322005-10-23 23:52:39 -07001047UNUSUAL_DEV( 0x07ab, 0xfccd, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001048 "Freecom Technologies",
1049 "FHD-Classic",
1050 US_SC_DEVICE, US_PR_DEVICE, NULL,
1051 US_FL_FIX_CAPACITY),
1052
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001053UNUSUAL_DEV( 0x07af, 0x0004, 0x0100, 0x0133,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001054 "Microtech",
1055 "USB-SCSI-DB25",
1056 US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
1057 US_FL_SCM_MULT_TARG ),
1058
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001059UNUSUAL_DEV( 0x07af, 0x0005, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001060 "Microtech",
1061 "USB-SCSI-HD50",
Phil Dibowitze8116e82005-06-22 22:47:13 -07001062 US_SC_DEVICE, US_PR_DEVICE, usb_stor_euscsi_init,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001063 US_FL_SCM_MULT_TARG ),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001064
Alan Stern0ff71882009-02-12 14:47:49 -05001065#ifdef NO_SDDR09
Alan Sternc20b15f2008-12-01 10:36:15 -05001066UNUSUAL_DEV( 0x07af, 0x0006, 0x0100, 0x0100,
1067 "Microtech",
1068 "CameraMate",
1069 US_SC_SCSI, US_PR_CB, NULL,
1070 US_FL_SINGLE_LUN ),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001071#endif
1072
Matthew Dharme80b0fa2005-12-04 22:02:44 -08001073#ifdef CONFIG_USB_STORAGE_ALAUDA
1074UNUSUAL_DEV( 0x07b4, 0x010a, 0x0102, 0x0102,
1075 "Olympus",
1076 "MAUSB-10 (Alauda)",
1077 US_SC_SCSI, US_PR_ALAUDA, init_alauda, 0 ),
1078#endif
1079
Linus Torvalds1da177e2005-04-16 15:20:36 -07001080#ifdef CONFIG_USB_STORAGE_DATAFAB
1081UNUSUAL_DEV( 0x07c4, 0xa000, 0x0000, 0x0015,
1082 "Datafab",
1083 "MDCFE-B USB CF Reader",
1084 US_SC_SCSI, US_PR_DATAFAB, NULL,
1085 0 ),
1086
1087/*
1088 * The following Datafab-based devices may or may not work
1089 * using the current driver...the 0xffff is arbitrary since I
1090 * don't know what device versions exist for these guys.
1091 *
1092 * The 0xa003 and 0xa004 devices in particular I'm curious about.
1093 * I'm told they exist but so far nobody has come forward to say that
1094 * they work with this driver. Given the success we've had getting
1095 * other Datafab-based cards operational with this driver, I've decided
1096 * to leave these two devices in the list.
1097 */
1098UNUSUAL_DEV( 0x07c4, 0xa001, 0x0000, 0xffff,
1099 "SIIG/Datafab",
1100 "SIIG/Datafab Memory Stick+CF Reader/Writer",
1101 US_SC_SCSI, US_PR_DATAFAB, NULL,
1102 0 ),
1103
1104/* Reported by Josef Reisinger <josef.reisinger@netcologne.de> */
1105UNUSUAL_DEV( 0x07c4, 0xa002, 0x0000, 0xffff,
1106 "Datafab/Unknown",
1107 "MD2/MD3 Disk enclosure",
1108 US_SC_SCSI, US_PR_DATAFAB, NULL,
1109 US_FL_SINGLE_LUN ),
1110
1111UNUSUAL_DEV( 0x07c4, 0xa003, 0x0000, 0xffff,
1112 "Datafab/Unknown",
1113 "Datafab-based Reader",
1114 US_SC_SCSI, US_PR_DATAFAB, NULL,
1115 0 ),
1116
1117UNUSUAL_DEV( 0x07c4, 0xa004, 0x0000, 0xffff,
1118 "Datafab/Unknown",
1119 "Datafab-based Reader",
1120 US_SC_SCSI, US_PR_DATAFAB, NULL,
1121 0 ),
1122
1123UNUSUAL_DEV( 0x07c4, 0xa005, 0x0000, 0xffff,
1124 "PNY/Datafab",
1125 "PNY/Datafab CF+SM Reader",
1126 US_SC_SCSI, US_PR_DATAFAB, NULL,
1127 0 ),
1128
1129UNUSUAL_DEV( 0x07c4, 0xa006, 0x0000, 0xffff,
1130 "Simple Tech/Datafab",
1131 "Simple Tech/Datafab CF+SM Reader",
1132 US_SC_SCSI, US_PR_DATAFAB, NULL,
1133 0 ),
1134#endif
1135
1136#ifdef CONFIG_USB_STORAGE_SDDR55
1137/* Contributed by Peter Waechtler */
1138UNUSUAL_DEV( 0x07c4, 0xa103, 0x0000, 0x9999,
1139 "Datafab",
1140 "MDSM-B reader",
1141 US_SC_SCSI, US_PR_SDDR55, NULL,
1142 US_FL_FIX_INQUIRY ),
1143#endif
1144
1145#ifdef CONFIG_USB_STORAGE_DATAFAB
1146/* Submitted by Olaf Hering <olh@suse.de> */
1147UNUSUAL_DEV( 0x07c4, 0xa109, 0x0000, 0xffff,
1148 "Datafab Systems, Inc.",
1149 "USB to CF + SM Combo (LC1)",
1150 US_SC_SCSI, US_PR_DATAFAB, NULL,
1151 0 ),
1152#endif
1153#ifdef CONFIG_USB_STORAGE_SDDR55
1154/* SM part - aeb <Andries.Brouwer@cwi.nl> */
1155UNUSUAL_DEV( 0x07c4, 0xa109, 0x0000, 0xffff,
1156 "Datafab Systems, Inc.",
1157 "USB to CF + SM Combo (LC1)",
1158 US_SC_SCSI, US_PR_SDDR55, NULL,
1159 US_FL_SINGLE_LUN ),
1160#endif
1161
felix@derklecks.ded6427cf2005-04-18 17:39:28 -07001162#ifdef CONFIG_USB_STORAGE_DATAFAB
1163/* Reported by Felix Moeller <felix@derklecks.de>
1164 * in Germany this is sold by Hama with the productnumber 46952
1165 * as "DualSlot CompactFlash(TM) & MStick Drive USB"
1166 */
1167UNUSUAL_DEV( 0x07c4, 0xa10b, 0x0000, 0xffff,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001168 "DataFab Systems Inc.",
1169 "USB CF+MS",
1170 US_SC_SCSI, US_PR_DATAFAB, NULL,
1171 0 ),
felix@derklecks.ded6427cf2005-04-18 17:39:28 -07001172
1173#endif
1174
Linus Torvalds1da177e2005-04-16 15:20:36 -07001175/* Datafab KECF-USB / Sagatek DCS-CF / Simpletech Flashlink UCF-100
1176 * Only revision 1.13 tested (same for all of the above devices,
1177 * based on the Datafab DF-UG-07 chip). Needed for US_FL_FIX_INQUIRY.
1178 * Submitted by Marek Michalkiewicz <marekm@amelek.gda.pl>.
1179 * See also http://martin.wilck.bei.t-online.de/#kecf .
1180 */
1181UNUSUAL_DEV( 0x07c4, 0xa400, 0x0000, 0xffff,
1182 "Datafab",
1183 "KECF-USB",
1184 US_SC_DEVICE, US_PR_DEVICE, NULL,
Nick Holloway049a6ac2009-01-25 16:58:43 +00001185 US_FL_FIX_INQUIRY | US_FL_FIX_CAPACITY ),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001186
Alan Stern368ee642008-07-21 10:08:28 -04001187/* Reported by Rauch Wolke <rauchwolke@gmx.net> */
1188UNUSUAL_DEV( 0x07c4, 0xa4a5, 0x0000, 0xffff,
1189 "Simple Tech/Datafab",
1190 "CF+SM Reader",
1191 US_SC_DEVICE, US_PR_DEVICE, NULL,
1192 US_FL_IGNORE_RESIDUE ),
1193
Linus Torvalds1da177e2005-04-16 15:20:36 -07001194/* Casio QV 2x00/3x00/4000/8000 digital still cameras are not conformant
1195 * to the USB storage specification in two ways:
1196 * - They tell us they are using transport protocol CBI. In reality they
1197 * are using transport protocol CB.
1198 * - They don't like the INQUIRY command. So we must handle this command
1199 * of the SCSI layer ourselves.
1200 * - Some cameras with idProduct=0x1001 and bcdDevice=0x1000 have
1201 * bInterfaceProtocol=0x00 (US_PR_CBI) while others have 0x01 (US_PR_CB).
1202 * So don't remove the US_PR_CB override!
1203 * - Cameras with bcdDevice=0x9009 require the US_SC_8070 override.
1204 */
1205UNUSUAL_DEV( 0x07cf, 0x1001, 0x1000, 0x9999,
1206 "Casio",
1207 "QV DigitalCamera",
1208 US_SC_8070, US_PR_CB, NULL,
1209 US_FL_NEED_OVERRIDE | US_FL_FIX_INQUIRY ),
1210
1211/* Submitted by Hartmut Wahl <hwahl@hwahl.de>*/
1212UNUSUAL_DEV( 0x0839, 0x000a, 0x0001, 0x0001,
1213 "Samsung",
1214 "Digimax 410",
1215 US_SC_DEVICE, US_PR_DEVICE, NULL,
1216 US_FL_FIX_INQUIRY),
1217
Alan Stern8010e062008-11-04 11:33:35 -05001218/* Reported by Luciano Rocha <luciano@eurotux.com> */
1219UNUSUAL_DEV( 0x0840, 0x0082, 0x0001, 0x0001,
1220 "Argosy",
1221 "Storage",
1222 US_SC_DEVICE, US_PR_DEVICE, NULL,
1223 US_FL_FIX_CAPACITY),
1224
Nguyen Anh Quynhe2673b22008-12-11 15:04:11 -08001225/* Reported and patched by Nguyen Anh Quynh <aquynh@gmail.com> */
1226UNUSUAL_DEV( 0x0840, 0x0084, 0x0001, 0x0001,
1227 "Argosy",
1228 "Storage",
1229 US_SC_DEVICE, US_PR_DEVICE, NULL,
1230 US_FL_FIX_CAPACITY),
1231
Phil Dibowitzaa23c8d2009-01-20 23:42:52 +01001232/* Reported by Martijn Hijdra <martijn.hijdra@gmail.com> */
1233UNUSUAL_DEV( 0x0840, 0x0085, 0x0001, 0x0001,
1234 "Argosy",
1235 "Storage",
1236 US_SC_DEVICE, US_PR_DEVICE, NULL,
1237 US_FL_FIX_CAPACITY),
1238
Linus Torvalds1da177e2005-04-16 15:20:36 -07001239/* Entry and supporting patch by Theodore Kilgore <kilgota@auburn.edu>.
1240 * Flag will support Bulk devices which use a standards-violating 32-byte
1241 * Command Block Wrapper. Here, the "DC2MEGA" cameras (several brands) with
1242 * Grandtech GT892x chip, which request "Proprietary SCSI Bulk" support.
1243 */
1244
1245UNUSUAL_DEV( 0x084d, 0x0011, 0x0110, 0x0110,
1246 "Grandtech",
1247 "DC2MEGA",
1248 US_SC_DEVICE, US_PR_DEVICE, NULL,
1249 US_FL_BULK32),
1250
Andrew Lunnf7687212008-04-24 19:36:39 +02001251/* Andrew Lunn <andrew@lunn.ch>
1252 * PanDigital Digital Picture Frame. Does not like ALLOW_MEDIUM_REMOVAL
1253 * on LUN 4.
1254 * Note: Vend:Prod clash with "Ltd Maxell WS30 Slim Digital Camera"
1255*/
1256UNUSUAL_DEV( 0x0851, 0x1543, 0x0200, 0x0200,
1257 "PanDigital",
1258 "Photo Frame",
1259 US_SC_DEVICE, US_PR_DEVICE, NULL,
1260 US_FL_NOT_LOCKABLE),
1261
Alan Sternba3e93a2006-01-30 10:19:43 -05001262/* Submitted by Jan De Luyck <lkml@kcore.org> */
1263UNUSUAL_DEV( 0x08bd, 0x1100, 0x0000, 0x0000,
1264 "CITIZEN",
1265 "X1DE-USB",
1266 US_SC_DEVICE, US_PR_DEVICE, NULL,
1267 US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001268
Dylan Tafta7e555b2007-02-05 16:41:01 -08001269/* Submitted by Dylan Taft <d13f00l@gmail.com>
1270 * US_FL_IGNORE_RESIDUE Needed
1271 */
1272UNUSUAL_DEV( 0x08ca, 0x3103, 0x0100, 0x0100,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001273 "AIPTEK",
1274 "Aiptek USB Keychain MP3 Player",
1275 US_SC_DEVICE, US_PR_DEVICE, NULL,
1276 US_FL_IGNORE_RESIDUE),
Dylan Tafta7e555b2007-02-05 16:41:01 -08001277
Linus Torvalds1da177e2005-04-16 15:20:36 -07001278/* Entry needed for flags. Moreover, all devices with this ID use
1279 * bulk-only transport, but _some_ falsely report Control/Bulk instead.
1280 * One example is "Trumpion Digital Research MYMP3".
1281 * Submitted by Bjoern Brill <brill(at)fs.math.uni-frankfurt.de>
1282 */
1283UNUSUAL_DEV( 0x090a, 0x1001, 0x0100, 0x0100,
1284 "Trumpion",
1285 "t33520 USB Flash Card Controller",
1286 US_SC_DEVICE, US_PR_BULK, NULL,
1287 US_FL_NEED_OVERRIDE ),
1288
Phil Dibowitz17247572005-05-21 00:45:55 -07001289/* Reported by Filippo Bardelli <filibard@libero.it>
1290 * The device reports a subclass of RBC, which is wrong.
1291 */
1292UNUSUAL_DEV( 0x090a, 0x1050, 0x0100, 0x0100,
1293 "Trumpion Microelectronics, Inc.",
1294 "33520 USB Digital Voice Recorder",
1295 US_SC_UFI, US_PR_DEVICE, NULL,
1296 0),
1297
Linus Torvalds1da177e2005-04-16 15:20:36 -07001298/* Trumpion Microelectronics MP3 player (felipe_alfaro@linuxmail.org) */
1299UNUSUAL_DEV( 0x090a, 0x1200, 0x0000, 0x9999,
1300 "Trumpion",
1301 "MP3 player",
1302 US_SC_RBC, US_PR_BULK, NULL,
1303 0 ),
1304
1305/* aeb */
1306UNUSUAL_DEV( 0x090c, 0x1132, 0x0000, 0xffff,
1307 "Feiya",
1308 "5-in-1 Card Reader",
1309 US_SC_DEVICE, US_PR_DEVICE, NULL,
1310 US_FL_FIX_CAPACITY ),
1311
1312/* This Pentax still camera is not conformant
1313 * to the USB storage specification: -
1314 * - It does not like the INQUIRY command. So we must handle this command
1315 * of the SCSI layer ourselves.
1316 * Tested on Rev. 10.00 (0x1000)
1317 * Submitted by James Courtier-Dutton <James@superbug.demon.co.uk>
1318 */
1319UNUSUAL_DEV( 0x0a17, 0x0004, 0x1000, 0x1000,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001320 "Pentax",
1321 "Optio 2/3/400",
1322 US_SC_DEVICE, US_PR_DEVICE, NULL,
1323 US_FL_FIX_INQUIRY ),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001324
Ben Collins67fa1062007-05-26 03:06:32 -07001325/* These are virtual windows driver CDs, which the zd1211rw driver
1326 * automatically converts into WLAN devices. */
Daniel Drake3c332422006-07-26 13:59:23 +01001327UNUSUAL_DEV( 0x0ace, 0x2011, 0x0101, 0x0101,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001328 "ZyXEL",
1329 "G-220F USB-WLAN Install",
1330 US_SC_DEVICE, US_PR_DEVICE, NULL,
1331 US_FL_IGNORE_DEVICE ),
Daniel Drake3c332422006-07-26 13:59:23 +01001332
Matthew Davidson64902cb2007-05-01 01:15:01 +01001333UNUSUAL_DEV( 0x0ace, 0x20ff, 0x0101, 0x0101,
1334 "SiteCom",
1335 "WL-117 USB-WLAN Install",
1336 US_SC_DEVICE, US_PR_DEVICE, NULL,
1337 US_FL_IGNORE_DEVICE ),
1338
Dan Williams281b0642008-12-14 12:39:22 -05001339/* Reported by Dan Williams <dcbw@redhat.com>
1340 * Option N.V. mobile broadband modems
1341 * Ignore driver CD mode and force into modem mode by default.
1342 */
1343
1344/* iCON 225 */
1345UNUSUAL_DEV( 0x0af0, 0x6971, 0x0000, 0x9999,
1346 "Option N.V.",
1347 "Mass Storage",
1348 US_SC_DEVICE, US_PR_DEVICE, option_ms_init,
1349 0),
1350
Filip Abene7c6f802008-05-08 10:48:12 -07001351/* Reported by F. Aben <f.aben@option.com>
1352 * This device (wrongly) has a vendor-specific device descriptor.
1353 * The entry is needed so usb-storage can bind to it's mass-storage
1354 * interface as an interface driver */
1355UNUSUAL_DEV( 0x0af0, 0x7401, 0x0000, 0x0000,
1356 "Option",
1357 "GI 0401 SD-Card",
1358 US_SC_DEVICE, US_PR_DEVICE, NULL,
1359 0 ),
1360
Jan Dumonc497e712009-03-10 17:29:47 +01001361/* Reported by Jan Dumon <j.dumon@option.com>
1362 * This device (wrongly) has a vendor-specific device descriptor.
1363 * The entry is needed so usb-storage can bind to it's mass-storage
1364 * interface as an interface driver */
1365UNUSUAL_DEV( 0x0af0, 0x7501, 0x0000, 0x0000,
1366 "Option",
1367 "GI 0431 SD-Card",
1368 US_SC_DEVICE, US_PR_DEVICE, NULL,
1369 0 ),
1370
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001371/* Reported by Ben Efros <ben@pc-doctor.com> */
1372UNUSUAL_DEV( 0x0bc2, 0x3010, 0x0000, 0x0000,
1373 "Seagate",
1374 "FreeAgent Pro",
1375 US_SC_DEVICE, US_PR_DEVICE, NULL,
1376 US_FL_SANE_SENSE ),
1377
Linus Torvalds1da177e2005-04-16 15:20:36 -07001378#ifdef CONFIG_USB_STORAGE_ISD200
1379UNUSUAL_DEV( 0x0bf6, 0xa001, 0x0100, 0x0110,
1380 "ATI",
1381 "USB Cable 205",
1382 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
1383 0 ),
1384#endif
1385
1386#ifdef CONFIG_USB_STORAGE_DATAFAB
1387UNUSUAL_DEV( 0x0c0b, 0xa109, 0x0000, 0xffff,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001388 "Acomdata",
1389 "CF",
1390 US_SC_SCSI, US_PR_DATAFAB, NULL,
1391 US_FL_SINGLE_LUN ),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001392#endif
1393#ifdef CONFIG_USB_STORAGE_SDDR55
1394UNUSUAL_DEV( 0x0c0b, 0xa109, 0x0000, 0xffff,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001395 "Acomdata",
1396 "SM",
1397 US_SC_SCSI, US_PR_SDDR55, NULL,
1398 US_FL_SINGLE_LUN ),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001399#endif
1400
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001401UNUSUAL_DEV( 0x0d49, 0x7310, 0x0000, 0x9999,
1402 "Maxtor",
1403 "USB to SATA",
1404 US_SC_DEVICE, US_PR_DEVICE, NULL,
1405 US_FL_SANE_SENSE),
1406
Alan Sternf9dc8f92008-11-18 14:08:07 -05001407/*
1408 * Pete Zaitcev <zaitcev@yahoo.com>, bz#164688.
1409 * The device blatantly ignores LUN and returns 1 in GetMaxLUN.
1410 */
1411UNUSUAL_DEV( 0x0c45, 0x1060, 0x0100, 0x0100,
1412 "Unknown",
1413 "Unknown",
1414 US_SC_DEVICE, US_PR_DEVICE, NULL,
1415 US_FL_SINGLE_LUN ),
1416
Matthew Dharm34008db2005-07-28 14:49:01 -07001417/* Submitted by: Nick Sillik <n.sillik@temple.edu>
1418 * Needed for OneTouch extension to usb-storage
1419 *
1420 */
1421#ifdef CONFIG_USB_STORAGE_ONETOUCH
Antti Andreimann94656632005-11-17 09:47:53 -08001422 UNUSUAL_DEV( 0x0d49, 0x7000, 0x0000, 0x9999,
1423 "Maxtor",
1424 "OneTouch External Harddrive",
1425 US_SC_DEVICE, US_PR_DEVICE, onetouch_connect_input,
1426 0),
Matthew Dharm34008db2005-07-28 14:49:01 -07001427 UNUSUAL_DEV( 0x0d49, 0x7010, 0x0000, 0x9999,
1428 "Maxtor",
1429 "OneTouch External Harddrive",
1430 US_SC_DEVICE, US_PR_DEVICE, onetouch_connect_input,
1431 0),
1432#endif
1433
Linus Torvalds1da177e2005-04-16 15:20:36 -07001434/* Submitted by Joris Struyve <joris@struyve.be> */
1435UNUSUAL_DEV( 0x0d96, 0x410a, 0x0001, 0xffff,
1436 "Medion",
1437 "MD 7425",
1438 US_SC_DEVICE, US_PR_DEVICE, NULL,
1439 US_FL_FIX_INQUIRY),
1440
1441/*
1442 * Entry for Jenoptik JD 5200z3
1443 *
1444 * email: car.busse@gmx.de
1445 */
1446UNUSUAL_DEV( 0x0d96, 0x5200, 0x0001, 0x0200,
1447 "Jenoptik",
1448 "JD 5200 z3",
1449 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_FIX_INQUIRY),
1450
Sergey Ovcharenko3b438e32008-12-17 19:28:06 +03001451/* Reported by Jason Johnston <killean@shaw.ca> */
1452UNUSUAL_DEV( 0x0dc4, 0x0073, 0x0000, 0x0000,
1453 "Macpower Technology Co.LTD.",
1454 "USB 2.0 3.5\" DEVICE",
1455 US_SC_DEVICE, US_PR_DEVICE, NULL,
1456 US_FL_FIX_CAPACITY),
1457
Linus Torvalds1da177e2005-04-16 15:20:36 -07001458/* Reported by Lubomir Blaha <tritol@trilogic.cz>
1459 * I _REALLY_ don't know what 3rd, 4th number and all defines mean, but this
1460 * works for me. Can anybody correct these values? (I able to test corrected
1461 * version.)
1462 */
1463UNUSUAL_DEV( 0x0dd8, 0x1060, 0x0000, 0xffff,
1464 "Netac",
1465 "USB-CF-Card",
1466 US_SC_DEVICE, US_PR_DEVICE, NULL,
1467 US_FL_FIX_INQUIRY ),
1468
Ben Collins67fa1062007-05-26 03:06:32 -07001469/* Reported by Edward Chapman (taken from linux-usb mailing list)
1470 Netac OnlyDisk Mini U2CV2 512MB USB 2.0 Flash Drive */
1471UNUSUAL_DEV( 0x0dd8, 0xd202, 0x0000, 0x9999,
1472 "Netac",
1473 "USB Flash Disk",
1474 US_SC_DEVICE, US_PR_DEVICE, NULL,
1475 US_FL_IGNORE_RESIDUE ),
1476
1477
Linus Torvalds1da177e2005-04-16 15:20:36 -07001478/* Patch by Stephan Walter <stephan.walter@epfl.ch>
1479 * I don't know why, but it works... */
1480UNUSUAL_DEV( 0x0dda, 0x0001, 0x0012, 0x0012,
1481 "WINWARD",
1482 "Music Disk",
1483 US_SC_DEVICE, US_PR_DEVICE, NULL,
1484 US_FL_IGNORE_RESIDUE ),
1485
1486/* Reported by Ian McConnell <ian at emit.demon.co.uk> */
1487UNUSUAL_DEV( 0x0dda, 0x0301, 0x0012, 0x0012,
1488 "PNP_MP3",
1489 "PNP_MP3 PLAYER",
1490 US_SC_DEVICE, US_PR_DEVICE, NULL,
1491 US_FL_IGNORE_RESIDUE ),
1492
Alan Stern982db2a2006-02-13 10:16:04 -05001493/* Reported by Jim McCloskey <mcclosk@ucsc.edu> */
1494UNUSUAL_DEV( 0x0e21, 0x0520, 0x0100, 0x0100,
1495 "Cowon Systems",
1496 "iAUDIO M5",
1497 US_SC_DEVICE, US_PR_BULK, NULL,
Phil Dibowitzbc724b92006-10-19 00:11:17 -07001498 US_FL_NEED_OVERRIDE ),
Alan Stern982db2a2006-02-13 10:16:04 -05001499
Linus Torvalds1da177e2005-04-16 15:20:36 -07001500/* Submitted by Antoine Mairesse <antoine.mairesse@free.fr> */
1501UNUSUAL_DEV( 0x0ed1, 0x6660, 0x0100, 0x0300,
1502 "USB",
1503 "Solid state disk",
1504 US_SC_DEVICE, US_PR_DEVICE, NULL,
1505 US_FL_FIX_INQUIRY ),
1506
1507/* Submitted by Daniel Drake <dsd@gentoo.org>
1508 * Reported by dayul on the Gentoo Forums */
1509UNUSUAL_DEV( 0x0ea0, 0x2168, 0x0110, 0x0110,
1510 "Ours Technology",
1511 "Flash Disk",
1512 US_SC_DEVICE, US_PR_DEVICE, NULL,
1513 US_FL_IGNORE_RESIDUE ),
1514
1515/* Reported by Rastislav Stanik <rs_kernel@yahoo.com> */
1516UNUSUAL_DEV( 0x0ea0, 0x6828, 0x0110, 0x0110,
1517 "USB",
1518 "Flash Disk",
1519 US_SC_DEVICE, US_PR_DEVICE, NULL,
1520 US_FL_IGNORE_RESIDUE ),
1521
Phil Dibowitz883d9892006-06-24 17:27:10 -07001522/* Reported by Benjamin Schiller <sbenni@gmx.de>
1523 * It is also sold by Easylite as DJ 20 */
1524UNUSUAL_DEV( 0x0ed1, 0x7636, 0x0103, 0x0103,
1525 "Typhoon",
1526 "My DJ 1820",
1527 US_SC_DEVICE, US_PR_DEVICE, NULL,
1528 US_FL_IGNORE_RESIDUE | US_FL_GO_SLOW | US_FL_MAX_SECTORS_64),
1529
Robert Spitzenpfeil4e584072008-02-20 12:11:22 -05001530/* Patch by Leonid Petrov mail at lpetrov.net
1531 * Reported by Robert Spitzenpfeil <robert@spitzenpfeil.org>
1532 * http://www.qbik.ch/usb/devices/showdev.php?id=1705
1533 * Updated to 103 device by MJ Ray mjr at phonecoop.coop
1534 */
1535UNUSUAL_DEV( 0x0f19, 0x0103, 0x0100, 0x0100,
1536 "Oracom Co., Ltd",
1537 "ORC-200M",
1538 US_SC_DEVICE, US_PR_DEVICE, NULL,
1539 US_FL_IGNORE_RESIDUE ),
1540
David Kuehlingb41ee5d2006-08-07 10:18:48 -04001541/* David Kuehling <dvdkhlng@gmx.de>:
1542 * for MP3-Player AVOX WSX-300ER (bought in Japan). Reports lots of SCSI
1543 * errors when trying to write.
1544 */
1545UNUSUAL_DEV( 0x0f19, 0x0105, 0x0100, 0x0100,
1546 "C-MEX",
1547 "A-VOX",
1548 US_SC_DEVICE, US_PR_DEVICE, NULL,
1549 US_FL_IGNORE_RESIDUE ),
1550
Jeremy Katzc17b49e2007-07-19 09:37:42 -04001551/* Jeremy Katz <katzj@redhat.com>:
1552 * The Blackberry Pearl can run in two modes; a usb-storage only mode
1553 * and a mode that allows access via mass storage and to its database.
1554 * The berry_charge module will set the device to dual mode and thus we
1555 * should ignore its native mode if that module is built
1556 */
1557#ifdef CONFIG_USB_BERRY_CHARGE
1558UNUSUAL_DEV( 0x0fca, 0x0006, 0x0001, 0x0001,
1559 "RIM",
1560 "Blackberry Pearl",
1561 US_SC_DEVICE, US_PR_DEVICE, NULL,
1562 US_FL_IGNORE_DEVICE ),
1563#endif
1564
Linus Torvalds1da177e2005-04-16 15:20:36 -07001565/* Reported by Michael Stattmann <michael@stattmann.com> */
1566UNUSUAL_DEV( 0x0fce, 0xd008, 0x0000, 0x0000,
1567 "Sony Ericsson",
1568 "V800-Vodafone 802",
1569 US_SC_DEVICE, US_PR_DEVICE, NULL,
1570 US_FL_NO_WP_DETECT ),
1571
Phil Dibowitza83775b2009-01-20 23:48:36 +01001572/* Reported by The Solutor <thesolutor@gmail.com> */
1573UNUSUAL_DEV( 0x0fce, 0xd0e1, 0x0000, 0x0000,
1574 "Sony Ericsson",
1575 "MD400",
1576 US_SC_DEVICE, US_PR_DEVICE, NULL,
1577 US_FL_IGNORE_DEVICE),
1578
Alan Sternb544d742007-01-31 10:57:55 -05001579/* Reported by Jan Mate <mate@fiit.stuba.sk>
1580 * and by Soeren Sonnenburg <kernel@nn7.de> */
Phil Dibowitz39c2f3a2006-09-11 00:27:40 -07001581UNUSUAL_DEV( 0x0fce, 0xe030, 0x0000, 0x0000,
1582 "Sony Ericsson",
1583 "P990i",
1584 US_SC_DEVICE, US_PR_DEVICE, NULL,
Alan Sternb544d742007-01-31 10:57:55 -05001585 US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
Phil Dibowitz39c2f3a2006-09-11 00:27:40 -07001586
Phil Dibowitzc9c770e2006-08-27 23:54:37 -07001587/* Reported by Emmanuel Vasilakis <evas@forthnet.gr> */
1588UNUSUAL_DEV( 0x0fce, 0xe031, 0x0000, 0x0000,
1589 "Sony Ericsson",
1590 "M600i",
1591 US_SC_DEVICE, US_PR_DEVICE, NULL,
Phil Dibowitzc5f23b02008-05-26 21:33:58 +02001592 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
Phil Dibowitzc9c770e2006-08-27 23:54:37 -07001593
Alan Sternf9dc8f92008-11-18 14:08:07 -05001594/* Reported by Ricardo Barberis <ricardo@dattatec.com> */
1595UNUSUAL_DEV( 0x0fce, 0xe092, 0x0000, 0x0000,
1596 "Sony Ericsson",
1597 "P1i",
1598 US_SC_DEVICE, US_PR_DEVICE, NULL,
1599 US_FL_IGNORE_RESIDUE ),
1600
Linus Torvalds1da177e2005-04-16 15:20:36 -07001601/* Reported by Kevin Cernekee <kpc-usbdev@gelato.uiuc.edu>
1602 * Tested on hardware version 1.10.
1603 * Entry is needed only for the initializer function override.
Phil Dibowitz51b5bce2006-11-02 23:14:10 -08001604 * Devices with bcd > 110 seem to not need it while those
1605 * with bcd < 110 appear to need it.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001606 */
Phil Dibowitz51b5bce2006-11-02 23:14:10 -08001607UNUSUAL_DEV( 0x1019, 0x0c55, 0x0000, 0x0110,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001608 "Desknote",
1609 "UCR-61S2B",
1610 US_SC_DEVICE, US_PR_DEVICE, usb_stor_ucr61s2b_init,
1611 0 ),
1612
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001613UNUSUAL_DEV( 0x1058, 0x0704, 0x0000, 0x9999,
1614 "Western Digital",
1615 "External HDD",
1616 US_SC_DEVICE, US_PR_DEVICE, NULL,
1617 US_FL_SANE_SENSE),
1618
Alan Stern274399d2008-02-20 12:10:04 -05001619/* Reported by Fabio Venturi <f.venturi@tdnet.it>
1620 * The device reports a vendor-specific bDeviceClass.
1621 */
1622UNUSUAL_DEV( 0x10d6, 0x2200, 0x0100, 0x0100,
1623 "Actions Semiconductor",
1624 "Mtp device",
1625 US_SC_DEVICE, US_PR_DEVICE, NULL,
1626 0),
1627
Kevin Lloyd112225b2007-07-16 13:49:27 -07001628/* Reported by Kevin Lloyd <linux@sierrawireless.com>
1629 * Entry is needed for the initializer function override,
1630 * which instructs the device to load as a modem
1631 * device.
1632 */
1633UNUSUAL_DEV( 0x1199, 0x0fff, 0x0000, 0x9999,
1634 "Sierra Wireless",
1635 "USB MMC Storage",
Kevin Lloyd32fe5e32008-07-10 14:14:57 -07001636 US_SC_DEVICE, US_PR_DEVICE, sierra_ms_init,
1637 0),
Kevin Lloyd112225b2007-07-16 13:49:27 -07001638
Jaco Kroon49314372006-11-15 01:02:08 -08001639/* Reported by Jaco Kroon <jaco@kroon.co.za>
1640 * The usb-storage module found on the Digitech GNX4 (and supposedly other
1641 * devices) misbehaves and causes a bunch of invalid I/O errors.
1642 */
1643UNUSUAL_DEV( 0x1210, 0x0003, 0x0100, 0x0100,
1644 "Digitech HMG",
1645 "DigiTech Mass Storage",
1646 US_SC_DEVICE, US_PR_DEVICE, NULL,
1647 US_FL_IGNORE_RESIDUE ),
1648
fangxiaozhiaad8a272008-04-10 14:51:06 +08001649/* Reported by fangxiaozhi <huananhu@huawei.com>
1650 * This brings the HUAWEI data card devices into multi-port mode
Johann Wilhelmd853d872007-09-05 13:49:29 +02001651 */
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001652UNUSUAL_DEV( 0x12d1, 0x1001, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001653 "HUAWEI MOBILE",
1654 "Mass Storage",
1655 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1656 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001657UNUSUAL_DEV( 0x12d1, 0x1003, 0x0000, 0x0000,
Johann Wilhelmd853d872007-09-05 13:49:29 +02001658 "HUAWEI MOBILE",
1659 "Mass Storage",
1660 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1661 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001662UNUSUAL_DEV( 0x12d1, 0x1004, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001663 "HUAWEI MOBILE",
1664 "Mass Storage",
1665 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1666 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001667UNUSUAL_DEV( 0x12d1, 0x1401, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001668 "HUAWEI MOBILE",
1669 "Mass Storage",
1670 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1671 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001672UNUSUAL_DEV( 0x12d1, 0x1402, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001673 "HUAWEI MOBILE",
1674 "Mass Storage",
1675 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1676 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001677UNUSUAL_DEV( 0x12d1, 0x1403, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001678 "HUAWEI MOBILE",
1679 "Mass Storage",
1680 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1681 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001682UNUSUAL_DEV( 0x12d1, 0x1404, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001683 "HUAWEI MOBILE",
1684 "Mass Storage",
1685 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1686 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001687UNUSUAL_DEV( 0x12d1, 0x1405, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001688 "HUAWEI MOBILE",
1689 "Mass Storage",
1690 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1691 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001692UNUSUAL_DEV( 0x12d1, 0x1406, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001693 "HUAWEI MOBILE",
1694 "Mass Storage",
1695 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1696 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001697UNUSUAL_DEV( 0x12d1, 0x1407, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001698 "HUAWEI MOBILE",
1699 "Mass Storage",
1700 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1701 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001702UNUSUAL_DEV( 0x12d1, 0x1408, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001703 "HUAWEI MOBILE",
1704 "Mass Storage",
1705 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1706 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001707UNUSUAL_DEV( 0x12d1, 0x1409, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001708 "HUAWEI MOBILE",
1709 "Mass Storage",
1710 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1711 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001712UNUSUAL_DEV( 0x12d1, 0x140A, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001713 "HUAWEI MOBILE",
1714 "Mass Storage",
1715 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1716 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001717UNUSUAL_DEV( 0x12d1, 0x140B, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001718 "HUAWEI MOBILE",
1719 "Mass Storage",
1720 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1721 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001722UNUSUAL_DEV( 0x12d1, 0x140C, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001723 "HUAWEI MOBILE",
1724 "Mass Storage",
1725 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1726 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001727UNUSUAL_DEV( 0x12d1, 0x140D, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001728 "HUAWEI MOBILE",
1729 "Mass Storage",
1730 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1731 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001732UNUSUAL_DEV( 0x12d1, 0x140E, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001733 "HUAWEI MOBILE",
1734 "Mass Storage",
1735 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1736 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001737UNUSUAL_DEV( 0x12d1, 0x140F, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001738 "HUAWEI MOBILE",
1739 "Mass Storage",
1740 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1741 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001742UNUSUAL_DEV( 0x12d1, 0x1410, 0x0000, 0x0000,
1743 "HUAWEI MOBILE",
1744 "Mass Storage",
1745 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1746 0),
1747UNUSUAL_DEV( 0x12d1, 0x1411, 0x0000, 0x0000,
1748 "HUAWEI MOBILE",
1749 "Mass Storage",
1750 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1751 0),
1752UNUSUAL_DEV( 0x12d1, 0x1412, 0x0000, 0x0000,
1753 "HUAWEI MOBILE",
1754 "Mass Storage",
1755 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1756 0),
1757UNUSUAL_DEV( 0x12d1, 0x1413, 0x0000, 0x0000,
1758 "HUAWEI MOBILE",
1759 "Mass Storage",
1760 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1761 0),
1762UNUSUAL_DEV( 0x12d1, 0x1414, 0x0000, 0x0000,
1763 "HUAWEI MOBILE",
1764 "Mass Storage",
1765 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1766 0),
1767UNUSUAL_DEV( 0x12d1, 0x1415, 0x0000, 0x0000,
1768 "HUAWEI MOBILE",
1769 "Mass Storage",
1770 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1771 0),
1772UNUSUAL_DEV( 0x12d1, 0x1416, 0x0000, 0x0000,
1773 "HUAWEI MOBILE",
1774 "Mass Storage",
1775 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1776 0),
1777UNUSUAL_DEV( 0x12d1, 0x1417, 0x0000, 0x0000,
1778 "HUAWEI MOBILE",
1779 "Mass Storage",
1780 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1781 0),
1782UNUSUAL_DEV( 0x12d1, 0x1418, 0x0000, 0x0000,
1783 "HUAWEI MOBILE",
1784 "Mass Storage",
1785 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1786 0),
1787UNUSUAL_DEV( 0x12d1, 0x1419, 0x0000, 0x0000,
1788 "HUAWEI MOBILE",
1789 "Mass Storage",
1790 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1791 0),
1792UNUSUAL_DEV( 0x12d1, 0x141A, 0x0000, 0x0000,
1793 "HUAWEI MOBILE",
1794 "Mass Storage",
1795 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1796 0),
1797UNUSUAL_DEV( 0x12d1, 0x141B, 0x0000, 0x0000,
1798 "HUAWEI MOBILE",
1799 "Mass Storage",
1800 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1801 0),
1802UNUSUAL_DEV( 0x12d1, 0x141C, 0x0000, 0x0000,
1803 "HUAWEI MOBILE",
1804 "Mass Storage",
1805 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1806 0),
1807UNUSUAL_DEV( 0x12d1, 0x141D, 0x0000, 0x0000,
1808 "HUAWEI MOBILE",
1809 "Mass Storage",
1810 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1811 0),
1812UNUSUAL_DEV( 0x12d1, 0x141E, 0x0000, 0x0000,
1813 "HUAWEI MOBILE",
1814 "Mass Storage",
1815 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1816 0),
1817UNUSUAL_DEV( 0x12d1, 0x141F, 0x0000, 0x0000,
1818 "HUAWEI MOBILE",
1819 "Mass Storage",
1820 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1821 0),
1822UNUSUAL_DEV( 0x12d1, 0x1420, 0x0000, 0x0000,
1823 "HUAWEI MOBILE",
1824 "Mass Storage",
1825 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1826 0),
1827UNUSUAL_DEV( 0x12d1, 0x1421, 0x0000, 0x0000,
1828 "HUAWEI MOBILE",
1829 "Mass Storage",
1830 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1831 0),
1832UNUSUAL_DEV( 0x12d1, 0x1422, 0x0000, 0x0000,
1833 "HUAWEI MOBILE",
1834 "Mass Storage",
1835 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1836 0),
1837UNUSUAL_DEV( 0x12d1, 0x1423, 0x0000, 0x0000,
1838 "HUAWEI MOBILE",
1839 "Mass Storage",
1840 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1841 0),
1842UNUSUAL_DEV( 0x12d1, 0x1424, 0x0000, 0x0000,
1843 "HUAWEI MOBILE",
1844 "Mass Storage",
1845 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1846 0),
1847UNUSUAL_DEV( 0x12d1, 0x1425, 0x0000, 0x0000,
1848 "HUAWEI MOBILE",
1849 "Mass Storage",
1850 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1851 0),
1852UNUSUAL_DEV( 0x12d1, 0x1426, 0x0000, 0x0000,
1853 "HUAWEI MOBILE",
1854 "Mass Storage",
1855 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1856 0),
1857UNUSUAL_DEV( 0x12d1, 0x1427, 0x0000, 0x0000,
1858 "HUAWEI MOBILE",
1859 "Mass Storage",
1860 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1861 0),
1862UNUSUAL_DEV( 0x12d1, 0x1428, 0x0000, 0x0000,
1863 "HUAWEI MOBILE",
1864 "Mass Storage",
1865 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1866 0),
1867UNUSUAL_DEV( 0x12d1, 0x1429, 0x0000, 0x0000,
1868 "HUAWEI MOBILE",
1869 "Mass Storage",
1870 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1871 0),
1872UNUSUAL_DEV( 0x12d1, 0x142A, 0x0000, 0x0000,
1873 "HUAWEI MOBILE",
1874 "Mass Storage",
1875 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1876 0),
1877UNUSUAL_DEV( 0x12d1, 0x142B, 0x0000, 0x0000,
1878 "HUAWEI MOBILE",
1879 "Mass Storage",
1880 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1881 0),
1882UNUSUAL_DEV( 0x12d1, 0x142C, 0x0000, 0x0000,
1883 "HUAWEI MOBILE",
1884 "Mass Storage",
1885 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1886 0),
1887UNUSUAL_DEV( 0x12d1, 0x142D, 0x0000, 0x0000,
1888 "HUAWEI MOBILE",
1889 "Mass Storage",
1890 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1891 0),
1892UNUSUAL_DEV( 0x12d1, 0x142E, 0x0000, 0x0000,
1893 "HUAWEI MOBILE",
1894 "Mass Storage",
1895 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1896 0),
1897UNUSUAL_DEV( 0x12d1, 0x142F, 0x0000, 0x0000,
1898 "HUAWEI MOBILE",
1899 "Mass Storage",
1900 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1901 0),
1902UNUSUAL_DEV( 0x12d1, 0x1430, 0x0000, 0x0000,
1903 "HUAWEI MOBILE",
1904 "Mass Storage",
1905 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1906 0),
1907UNUSUAL_DEV( 0x12d1, 0x1431, 0x0000, 0x0000,
1908 "HUAWEI MOBILE",
1909 "Mass Storage",
1910 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1911 0),
1912UNUSUAL_DEV( 0x12d1, 0x1432, 0x0000, 0x0000,
1913 "HUAWEI MOBILE",
1914 "Mass Storage",
1915 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1916 0),
1917UNUSUAL_DEV( 0x12d1, 0x1433, 0x0000, 0x0000,
1918 "HUAWEI MOBILE",
1919 "Mass Storage",
1920 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1921 0),
1922UNUSUAL_DEV( 0x12d1, 0x1434, 0x0000, 0x0000,
1923 "HUAWEI MOBILE",
1924 "Mass Storage",
1925 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1926 0),
1927UNUSUAL_DEV( 0x12d1, 0x1435, 0x0000, 0x0000,
1928 "HUAWEI MOBILE",
1929 "Mass Storage",
1930 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1931 0),
1932UNUSUAL_DEV( 0x12d1, 0x1436, 0x0000, 0x0000,
1933 "HUAWEI MOBILE",
1934 "Mass Storage",
1935 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1936 0),
1937UNUSUAL_DEV( 0x12d1, 0x1437, 0x0000, 0x0000,
1938 "HUAWEI MOBILE",
1939 "Mass Storage",
1940 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1941 0),
1942UNUSUAL_DEV( 0x12d1, 0x1438, 0x0000, 0x0000,
1943 "HUAWEI MOBILE",
1944 "Mass Storage",
1945 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1946 0),
1947UNUSUAL_DEV( 0x12d1, 0x1439, 0x0000, 0x0000,
1948 "HUAWEI MOBILE",
1949 "Mass Storage",
1950 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1951 0),
1952UNUSUAL_DEV( 0x12d1, 0x143A, 0x0000, 0x0000,
1953 "HUAWEI MOBILE",
1954 "Mass Storage",
1955 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1956 0),
1957UNUSUAL_DEV( 0x12d1, 0x143B, 0x0000, 0x0000,
1958 "HUAWEI MOBILE",
1959 "Mass Storage",
1960 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1961 0),
1962UNUSUAL_DEV( 0x12d1, 0x143C, 0x0000, 0x0000,
1963 "HUAWEI MOBILE",
1964 "Mass Storage",
1965 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1966 0),
1967UNUSUAL_DEV( 0x12d1, 0x143D, 0x0000, 0x0000,
1968 "HUAWEI MOBILE",
1969 "Mass Storage",
1970 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1971 0),
1972UNUSUAL_DEV( 0x12d1, 0x143E, 0x0000, 0x0000,
1973 "HUAWEI MOBILE",
1974 "Mass Storage",
1975 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1976 0),
1977UNUSUAL_DEV( 0x12d1, 0x143F, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001978 "HUAWEI MOBILE",
1979 "Mass Storage",
1980 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1981 0),
Johann Wilhelmd853d872007-09-05 13:49:29 +02001982
Phil Dibowitz7b1cbeb2005-05-02 23:54:28 -07001983/* Reported by Vilius Bilinkevicius <vilisas AT xxx DOT lt) */
1984UNUSUAL_DEV( 0x132b, 0x000b, 0x0001, 0x0001,
1985 "Minolta",
1986 "Dimage Z10",
1987 US_SC_DEVICE, US_PR_DEVICE, NULL,
1988 0 ),
1989
Linus Torvalds1da177e2005-04-16 15:20:36 -07001990/* Reported by Kotrla Vitezslav <kotrla@ceb.cz> */
1991UNUSUAL_DEV( 0x1370, 0x6828, 0x0110, 0x0110,
1992 "SWISSBIT",
1993 "Black Silver",
1994 US_SC_DEVICE, US_PR_DEVICE, NULL,
1995 US_FL_IGNORE_RESIDUE ),
1996
Phil Dibowitzf1cd4ad2006-12-31 00:19:50 -08001997/* Reported by Francesco Foresti <frafore@tiscali.it> */
1998UNUSUAL_DEV( 0x14cd, 0x6600, 0x0201, 0x0201,
1999 "Super Top",
2000 "IDE DEVICE",
2001 US_SC_DEVICE, US_PR_DEVICE, NULL,
2002 US_FL_IGNORE_RESIDUE ),
2003
Phil Dibowitz3030ca42008-10-19 08:17:54 +02002004/* Reported by Alexandre Oliva <oliva@lsd.ic.unicamp.br>
2005 * JMicron responds to USN and several other SCSI ioctls with a
2006 * residue that causes subsequent I/O requests to fail. */
2007UNUSUAL_DEV( 0x152d, 0x2329, 0x0100, 0x0100,
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08002008 "JMicron",
2009 "USB to ATA/ATAPI Bridge",
2010 US_SC_DEVICE, US_PR_DEVICE, NULL,
2011 US_FL_IGNORE_RESIDUE | US_FL_SANE_SENSE ),
Phil Dibowitz3030ca42008-10-19 08:17:54 +02002012
Phil Dibowitzf1cd4ad2006-12-31 00:19:50 -08002013/* Reported by Robert Schedel <r.schedel@yahoo.de>
2014 * Note: this is a 'super top' device like the above 14cd/6600 device */
2015UNUSUAL_DEV( 0x1652, 0x6600, 0x0201, 0x0201,
2016 "Teac",
2017 "HD-35PUK-B",
2018 US_SC_DEVICE, US_PR_DEVICE, NULL,
2019 US_FL_IGNORE_RESIDUE ),
2020
Oliver Neukumb90de8a2009-01-14 16:17:19 +01002021UNUSUAL_DEV( 0x2116, 0x0320, 0x0001, 0x0001,
2022 "ST",
2023 "2A",
2024 US_SC_DEVICE, US_PR_DEVICE, NULL,
2025 US_FL_FIX_CAPACITY),
2026
Davide Perini0ddc0632006-06-19 17:07:39 -04002027/* patch submitted by Davide Perini <perini.davide@dpsoftware.org>
2028 * and Renato Perini <rperini@email.it>
2029 */
2030UNUSUAL_DEV( 0x22b8, 0x3010, 0x0001, 0x0001,
2031 "Motorola",
2032 "RAZR V3x",
2033 US_SC_DEVICE, US_PR_DEVICE, NULL,
2034 US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
2035
Pete Zaitceva7f3dd52007-03-10 15:17:16 -08002036/*
Constantin Baranovcc36bdd2008-03-16 20:04:23 +00002037 * Patch by Constantin Baranov <const@tltsu.ru>
2038 * Report by Andreas Koenecke.
2039 * Motorola ROKR Z6.
2040 */
2041UNUSUAL_DEV( 0x22b8, 0x6426, 0x0101, 0x0101,
2042 "Motorola",
2043 "MSnc.",
2044 US_SC_DEVICE, US_PR_DEVICE, NULL,
2045 US_FL_FIX_INQUIRY | US_FL_FIX_CAPACITY | US_FL_BULK_IGNORE_TAG),
2046
Linus Torvalds1da177e2005-04-16 15:20:36 -07002047/* Reported by Radovan Garabik <garabik@kassiopeia.juls.savba.sk> */
2048UNUSUAL_DEV( 0x2735, 0x100b, 0x0000, 0x9999,
2049 "MPIO",
2050 "HS200",
2051 US_SC_DEVICE, US_PR_DEVICE, NULL,
2052 US_FL_GO_SLOW ),
2053
Phil Dibowitzed3e8fc2008-05-03 18:04:30 -07002054/* Reported by Rohan Hart <rohan.hart17@gmail.com> */
2055UNUSUAL_DEV( 0x2770, 0x915d, 0x0010, 0x0010,
2056 "INTOVA",
2057 "Pixtreme",
2058 US_SC_DEVICE, US_PR_DEVICE, NULL,
2059 US_FL_FIX_CAPACITY ),
2060
Frédéric Marchale8fab4c2008-10-13 14:00:11 +02002061/* Reported by Frederic Marchal <frederic.marchal@wowcompany.com>
2062 * Mio Moov 330
2063 */
2064UNUSUAL_DEV( 0x3340, 0xffff, 0x0000, 0x0000,
2065 "Mitac",
2066 "Mio DigiWalker USB Sync",
2067 US_SC_DEVICE,US_PR_DEVICE,NULL,
2068 US_FL_MAX_SECTORS_64 ),
2069
Alan Stern368ee642008-07-21 10:08:28 -04002070/* Reported by Andrey Rahmatullin <wrar@altlinux.org> */
2071UNUSUAL_DEV( 0x4102, 0x1020, 0x0100, 0x0100,
2072 "iRiver",
2073 "MP3 T10",
2074 US_SC_DEVICE, US_PR_DEVICE, NULL,
2075 US_FL_IGNORE_RESIDUE ),
2076
David Härdeman63dc3ff2005-11-23 15:45:49 -08002077/*
Jan Engelhardt96de0e22007-10-19 23:21:04 +02002078 * David Härdeman <david@2gen.com>
David Härdeman63dc3ff2005-11-23 15:45:49 -08002079 * The key makes the SCSI stack print confusing (but harmless) messages
2080 */
2081UNUSUAL_DEV( 0x4146, 0xba01, 0x0100, 0x0100,
2082 "Iomega",
2083 "Micro Mini 1GB",
2084 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_NOT_LOCKABLE ),
2085
Linus Torvalds1da177e2005-04-16 15:20:36 -07002086#ifdef CONFIG_USB_STORAGE_SDDR55
2087UNUSUAL_DEV( 0x55aa, 0xa103, 0x0000, 0x9999,
2088 "Sandisk",
2089 "ImageMate SDDR55",
2090 US_SC_SCSI, US_PR_SDDR55, NULL,
2091 US_FL_SINGLE_LUN),
2092#endif
Pete Zaitceva00828e2005-10-22 20:15:09 -07002093
Alan Sterna2149bc2006-02-02 09:52:45 -05002094/* Reported by Andrew Simmons <andrew.simmons@gmail.com> */
2095UNUSUAL_DEV( 0xed06, 0x4500, 0x0001, 0x0001,
2096 "DataStor",
2097 "USB4500 FW1.04",
2098 US_SC_DEVICE, US_PR_DEVICE, NULL,
Oliver Neukum61bf54b2007-02-08 09:04:48 +01002099 US_FL_CAPACITY_HEURISTICS),
Alan Sterna2149bc2006-02-02 09:52:45 -05002100
Pete Zaitceva00828e2005-10-22 20:15:09 -07002101/* Control/Bulk transport for all SubClass values */
2102USUAL_DEV(US_SC_RBC, US_PR_CB, USB_US_TYPE_STOR),
2103USUAL_DEV(US_SC_8020, US_PR_CB, USB_US_TYPE_STOR),
2104USUAL_DEV(US_SC_QIC, US_PR_CB, USB_US_TYPE_STOR),
2105USUAL_DEV(US_SC_UFI, US_PR_CB, USB_US_TYPE_STOR),
2106USUAL_DEV(US_SC_8070, US_PR_CB, USB_US_TYPE_STOR),
2107USUAL_DEV(US_SC_SCSI, US_PR_CB, USB_US_TYPE_STOR),
2108
2109/* Control/Bulk/Interrupt transport for all SubClass values */
2110USUAL_DEV(US_SC_RBC, US_PR_CBI, USB_US_TYPE_STOR),
2111USUAL_DEV(US_SC_8020, US_PR_CBI, USB_US_TYPE_STOR),
2112USUAL_DEV(US_SC_QIC, US_PR_CBI, USB_US_TYPE_STOR),
2113USUAL_DEV(US_SC_UFI, US_PR_CBI, USB_US_TYPE_STOR),
2114USUAL_DEV(US_SC_8070, US_PR_CBI, USB_US_TYPE_STOR),
2115USUAL_DEV(US_SC_SCSI, US_PR_CBI, USB_US_TYPE_STOR),
2116
2117/* Bulk-only transport for all SubClass values */
2118USUAL_DEV(US_SC_RBC, US_PR_BULK, USB_US_TYPE_STOR),
2119USUAL_DEV(US_SC_8020, US_PR_BULK, USB_US_TYPE_STOR),
2120USUAL_DEV(US_SC_QIC, US_PR_BULK, USB_US_TYPE_STOR),
2121USUAL_DEV(US_SC_UFI, US_PR_BULK, USB_US_TYPE_STOR),
2122USUAL_DEV(US_SC_8070, US_PR_BULK, USB_US_TYPE_STOR),
2123USUAL_DEV(US_SC_SCSI, US_PR_BULK, 0),