blob: 69269f739563d7669a0ca7ba7d83b6f23e6b28bb [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
Vivian Bregier8af60be2005-05-03 02:16:34 +020056/* patch submitted by Vivian Bregier <Vivian.Bregier@imag.fr>
57 */
58UNUSUAL_DEV( 0x03eb, 0x2002, 0x0100, 0x0100,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -070059 "ATMEL",
60 "SND1 Storage",
61 US_SC_DEVICE, US_PR_DEVICE, NULL,
62 US_FL_IGNORE_RESIDUE),
Vivian Bregier8af60be2005-05-03 02:16:34 +020063
Tobias Lorenz1ff15e82006-10-08 22:56:40 -070064/* modified by Tobias Lorenz <tobias.lorenz@gmx.net> */
65UNUSUAL_DEV( 0x03ee, 0x6901, 0x0000, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -070066 "Mitsumi",
67 "USB FDD",
68 US_SC_DEVICE, US_PR_DEVICE, NULL,
69 US_FL_SINGLE_LUN ),
70
Rodolfo Quesada9d5847b2006-03-06 10:45:42 -050071/* Reported by Rodolfo Quesada <rquesada@roqz.net> */
72UNUSUAL_DEV( 0x03ee, 0x6906, 0x0003, 0x0003,
73 "VIA Technologies Inc.",
74 "Mitsumi multi cardreader",
75 US_SC_DEVICE, US_PR_DEVICE, NULL,
76 US_FL_IGNORE_RESIDUE ),
77
S.Caglar Onurc0e0c192007-07-04 13:52:47 -070078UNUSUAL_DEV( 0x03f0, 0x0107, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -070079 "HP",
80 "CD-Writer+",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -070081 US_SC_8070, US_PR_CB, NULL, 0),
Linus Torvalds1da177e2005-04-16 15:20:36 -070082
83#ifdef CONFIG_USB_STORAGE_USBAT
S.Caglar Onurc0e0c192007-07-04 13:52:47 -070084UNUSUAL_DEV( 0x03f0, 0x0207, 0x0001, 0x0001,
Linus Torvalds1da177e2005-04-16 15:20:36 -070085 "HP",
86 "CD-Writer+ 8200e",
Peter Chubbbdcfd9e2006-05-02 18:29:34 +010087 US_SC_8070, US_PR_USBAT, init_usbat_cd, 0),
Linus Torvalds1da177e2005-04-16 15:20:36 -070088
S.Caglar Onurc0e0c192007-07-04 13:52:47 -070089UNUSUAL_DEV( 0x03f0, 0x0307, 0x0001, 0x0001,
Linus Torvalds1da177e2005-04-16 15:20:36 -070090 "HP",
91 "CD-Writer+ CD-4e",
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#endif
94
Ben Efrosdbe6e0c02008-11-23 20:06:38 -080095/* Reported by Ben Efros <ben@pc-doctor.com> */
96UNUSUAL_DEV( 0x03f0, 0x070c, 0x0000, 0x0000,
97 "HP",
98 "Personal Media Drive",
99 US_SC_DEVICE, US_PR_DEVICE, NULL,
100 US_FL_SANE_SENSE ),
101
Grant Grundler4b24f912008-01-23 21:31:03 -0800102/* Reported by Grant Grundler <grundler@parisc-linux.org>
103 * HP r707 camera in "Disk" mode with 2.00.23 or 2.00.24 firmware.
104 */
105UNUSUAL_DEV( 0x03f0, 0x4002, 0x0001, 0x0001,
106 "HP",
107 "PhotoSmart R707",
108 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_FIX_CAPACITY),
109
Phil Dibowitz1ea640c2005-08-29 22:38:28 -0700110/* Reported by Sebastian Kapfer <sebastian_kapfer@gmx.net>
111 * and Olaf Hering <olh@suse.de> (different bcd's, same vendor/product)
112 * for USB floppies that need the SINGLE_LUN enforcement.
113 */
114UNUSUAL_DEV( 0x0409, 0x0040, 0x0000, 0x9999,
115 "NEC",
116 "NEC USB UF000x",
117 US_SC_DEVICE, US_PR_DEVICE, NULL,
118 US_FL_SINGLE_LUN ),
119
Phil Dibowitz3e220e92005-12-18 21:30:02 -0800120/* Patch submitted by Mihnea-Costin Grigore <mihnea@zulu.ro> */
121UNUSUAL_DEV( 0x040d, 0x6205, 0x0003, 0x0003,
122 "VIA Technologies Inc.",
123 "USB 2.0 Card Reader",
124 US_SC_DEVICE, US_PR_DEVICE, NULL,
125 US_FL_IGNORE_RESIDUE ),
126
Linus Torvalds1da177e2005-04-16 15:20:36 -0700127/* Deduced by Jonathan Woithe <jwoithe@physics.adelaide.edu.au>
128 * Entry needed for flags: US_FL_FIX_INQUIRY because initial inquiry message
129 * always fails and confuses drive.
130 */
131UNUSUAL_DEV( 0x0411, 0x001c, 0x0113, 0x0113,
132 "Buffalo",
133 "DUB-P40G HDD",
134 US_SC_DEVICE, US_PR_DEVICE, NULL,
135 US_FL_FIX_INQUIRY ),
136
Ernisd8840d62006-06-26 16:02:43 -0400137/* Submitted by Ernestas Vaiciukevicius <ernisv@gmail.com> */
138UNUSUAL_DEV( 0x0419, 0x0100, 0x0100, 0x0100,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700139 "Samsung Info. Systems America, Inc.",
140 "MP3 Player",
141 US_SC_DEVICE, US_PR_DEVICE, NULL,
142 US_FL_IGNORE_RESIDUE ),
Ernisd8840d62006-06-26 16:02:43 -0400143
Phil Dibowitz5501a482006-07-04 12:46:43 -0700144/* Reported by Orgad Shaneh <orgads@gmail.com> */
145UNUSUAL_DEV( 0x0419, 0xaace, 0x0100, 0x0100,
146 "Samsung", "MP3 Player",
147 US_SC_DEVICE, US_PR_DEVICE, NULL,
148 US_FL_IGNORE_RESIDUE ),
149
Alan Stern1d614a42006-02-13 10:15:22 -0500150/* Reported by Christian Leber <christian@leber.de> */
151UNUSUAL_DEV( 0x0419, 0xaaf5, 0x0100, 0x0100,
152 "TrekStor",
153 "i.Beat 115 2.0",
154 US_SC_DEVICE, US_PR_DEVICE, NULL,
155 US_FL_IGNORE_RESIDUE | US_FL_NOT_LOCKABLE ),
156
Phil Dibowitze4a16e02005-09-30 00:20:15 -0700157/* Reported by Stefan Werner <dustbln@gmx.de> */
158UNUSUAL_DEV( 0x0419, 0xaaf6, 0x0100, 0x0100,
159 "TrekStor",
160 "i.Beat Joy 2.0",
161 US_SC_DEVICE, US_PR_DEVICE, NULL,
162 US_FL_IGNORE_RESIDUE ),
163
Pete Zaitcev23b78852006-03-05 21:45:44 -0800164/* Reported by Pete Zaitcev <zaitcev@redhat.com>, bz#176584 */
165UNUSUAL_DEV( 0x0420, 0x0001, 0x0100, 0x0100,
166 "GENERIC", "MP3 PLAYER", /* MyMusix PD-205 on the outside. */
167 US_SC_DEVICE, US_PR_DEVICE, NULL,
168 US_FL_IGNORE_RESIDUE ),
169
Andrew Nayenko0d8c7aea2007-02-25 00:40:20 -0800170/* Reported by Andrew Nayenko <relan@bk.ru> */
171UNUSUAL_DEV( 0x0421, 0x0019, 0x0592, 0x0592,
172 "Nokia",
173 "Nokia 6288",
174 US_SC_DEVICE, US_PR_DEVICE, NULL,
175 US_FL_MAX_SECTORS_64 ),
176
Alan Sternde1caa42006-07-31 10:10:28 -0400177/* Reported by Mario Rettig <mariorettig@web.de> */
178UNUSUAL_DEV( 0x0421, 0x042e, 0x0100, 0x0100,
179 "Nokia",
180 "Nokia 3250",
181 US_SC_DEVICE, US_PR_DEVICE, NULL,
182 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
183
Andrew Mortonfe1ec342006-12-04 15:22:40 -0800184/* Reported by <honkkis@gmail.com> */
185UNUSUAL_DEV( 0x0421, 0x0433, 0x0100, 0x0100,
186 "Nokia",
187 "E70",
188 US_SC_DEVICE, US_PR_DEVICE, NULL,
189 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
190
Alan Stern79238112006-09-28 12:11:56 -0400191/* Reported by Jon Hart <Jon.Hart@web.de> */
192UNUSUAL_DEV( 0x0421, 0x0434, 0x0100, 0x0100,
193 "Nokia",
194 "E60",
195 US_SC_DEVICE, US_PR_DEVICE, NULL,
196 US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
197
Alan Stern9a013552006-07-07 13:45:13 -0400198/* Reported by Sumedha Swamy <sumedhaswamy@gmail.com> and
199 * Einar Th. Einarsson <einarthered@gmail.com> */
200UNUSUAL_DEV( 0x0421, 0x0444, 0x0100, 0x0100,
201 "Nokia",
202 "N91",
203 US_SC_DEVICE, US_PR_DEVICE, NULL,
204 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
205
Alan Sternd5681fe2006-06-13 09:59:32 -0400206/* Reported by Jiri Slaby <jirislaby@gmail.com> and
207 * Rene C. Castberg <Rene@Castberg.org> */
208UNUSUAL_DEV( 0x0421, 0x0446, 0x0100, 0x0100,
209 "Nokia",
210 "N80",
211 US_SC_DEVICE, US_PR_DEVICE, NULL,
212 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
213
Alan Stern57b01b12006-07-10 11:51:12 -0400214/* Reported by Matthew Bloch <matthew@bytemark.co.uk> */
215UNUSUAL_DEV( 0x0421, 0x044e, 0x0100, 0x0100,
216 "Nokia",
217 "E61",
218 US_SC_DEVICE, US_PR_DEVICE, NULL,
219 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
220
Alan Sterne4a20da2006-10-04 16:31:15 -0400221/* Reported by Bardur Arantsson <bardur@scientician.net> */
Alan Stern393e5512007-09-18 10:09:32 -0400222UNUSUAL_DEV( 0x0421, 0x047c, 0x0370, 0x0610,
Alan Sterne4a20da2006-10-04 16:31:15 -0400223 "Nokia",
224 "6131",
225 US_SC_DEVICE, US_PR_DEVICE, NULL,
226 US_FL_MAX_SECTORS_64 ),
227
Manuel Osdoba39559b42007-01-18 21:28:45 +0100228/* Reported by Manuel Osdoba <manuel.osdoba@tu-ilmenau.de> */
229UNUSUAL_DEV( 0x0421, 0x0492, 0x0452, 0x0452,
230 "Nokia",
231 "Nokia 6233",
232 US_SC_DEVICE, US_PR_DEVICE, NULL,
233 US_FL_MAX_SECTORS_64 ),
234
Alan Stern3ccf25c2006-10-13 09:59:17 -0400235/* Reported by Alex Corcoles <alex@corcoles.net> */
236UNUSUAL_DEV( 0x0421, 0x0495, 0x0370, 0x0370,
237 "Nokia",
238 "6234",
239 US_SC_DEVICE, US_PR_DEVICE, NULL,
240 US_FL_MAX_SECTORS_64 ),
241
Phil Dibowitz1ea640c2005-08-29 22:38:28 -0700242/* Reported by Olaf Hering <olh@suse.de> from novell bug #105878 */
243UNUSUAL_DEV( 0x0424, 0x0fdc, 0x0210, 0x0210,
244 "SMSC",
245 "FDC GOLD-2.30",
246 US_SC_DEVICE, US_PR_DEVICE, NULL,
247 US_FL_SINGLE_LUN ),
248
Alan Sternc20b15f2008-12-01 10:36:15 -0500249#ifdef CONFIG_USB_STORAGE_SDDR09
Linus Torvalds1da177e2005-04-16 15:20:36 -0700250UNUSUAL_DEV( 0x0436, 0x0005, 0x0100, 0x0100,
251 "Microtech",
252 "CameraMate (DPCM_USB)",
253 US_SC_SCSI, US_PR_DPCM_USB, NULL, 0 ),
Alan Sternc20b15f2008-12-01 10:36:15 -0500254#else
255UNUSUAL_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
470#ifdef CONFIG_USB_STORAGE_SDDR09
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700471UNUSUAL_DEV( 0x04e6, 0x0003, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700472 "Sandisk",
473 "ImageMate SDDR09",
Matthew Dharmf5b8cb92005-12-04 21:57:51 -0800474 US_SC_SCSI, US_PR_EUSB_SDDR09, usb_stor_sddr09_init,
475 0),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700476
477/* This entry is from Andries.Brouwer@cwi.nl */
478UNUSUAL_DEV( 0x04e6, 0x0005, 0x0100, 0x0208,
479 "SCM Microsystems",
480 "eUSB SmartMedia / CompactFlash Adapter",
Matthew Dharmf5b8cb92005-12-04 21:57:51 -0800481 US_SC_SCSI, US_PR_DPCM_USB, usb_stor_sddr09_dpcm_init,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700482 0),
Alan Sternc20b15f2008-12-01 10:36:15 -0500483#else
484UNUSUAL_DEV( 0x04e6, 0x0005, 0x0100, 0x0208,
485 "SCM Microsystems",
486 "eUSB CompactFlash Adapter",
487 US_SC_SCSI, US_PR_CB, NULL,
488 US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700489#endif
490
491/* Reported by Markus Demleitner <msdemlei@cl.uni-heidelberg.de> */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700492UNUSUAL_DEV( 0x04e6, 0x0006, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700493 "SCM Microsystems Inc.",
494 "eUSB MMC Adapter",
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
498/* Reported by Daniel Nouri <dpunktnpunkt@web.de> */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700499UNUSUAL_DEV( 0x04e6, 0x0006, 0x0205, 0x0205,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700500 "Shuttle",
501 "eUSB MMC Adapter",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700502 US_SC_SCSI, US_PR_DEVICE, NULL,
503 US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700504
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700505UNUSUAL_DEV( 0x04e6, 0x0007, 0x0100, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700506 "Sony",
507 "Hifd",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700508 US_SC_SCSI, US_PR_CB, NULL,
509 US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700510
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700511UNUSUAL_DEV( 0x04e6, 0x0009, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700512 "Shuttle",
513 "eUSB ATA/ATAPI Adapter",
514 US_SC_8020, US_PR_CB, NULL, 0),
515
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700516UNUSUAL_DEV( 0x04e6, 0x000a, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700517 "Shuttle",
518 "eUSB CompactFlash Adapter",
519 US_SC_8020, US_PR_CB, NULL, 0),
520
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700521UNUSUAL_DEV( 0x04e6, 0x000B, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700522 "Shuttle",
523 "eUSCSI Bridge",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700524 US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700525 US_FL_SCM_MULT_TARG ),
526
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700527UNUSUAL_DEV( 0x04e6, 0x000C, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700528 "Shuttle",
529 "eUSCSI Bridge",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700530 US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
531 US_FL_SCM_MULT_TARG ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700532
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700533UNUSUAL_DEV( 0x04e6, 0x0101, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700534 "Shuttle",
535 "CD-RW Device",
536 US_SC_8020, US_PR_CB, NULL, 0),
537
Linus Torvalds1da177e2005-04-16 15:20:36 -0700538#ifdef CONFIG_USB_STORAGE_USBAT
539UNUSUAL_DEV( 0x04e6, 0x1010, 0x0000, 0x9999,
Daniel Drakeb7b1e652005-09-30 12:49:36 +0100540 "Shuttle/SCM",
541 "USBAT-02",
Daniel Drakef9347c52006-05-08 23:43:02 +0100542 US_SC_SCSI, US_PR_USBAT, init_usbat_flash,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700543 US_FL_SINGLE_LUN),
544#endif
545
Alan Sternb28884c2008-04-28 10:26:13 -0400546/* Reported by Dmitry Khlystov <adminimus@gmail.com> */
547UNUSUAL_DEV( 0x04e8, 0x507c, 0x0220, 0x0220,
548 "Samsung",
549 "YP-U3",
550 US_SC_DEVICE, US_PR_DEVICE, NULL,
551 US_FL_MAX_SECTORS_64),
552
Phil Dibowitzed3e8fc2008-05-03 18:04:30 -0700553/* Entry and supporting patch by Theodore Kilgore <kilgota@auburn.edu>.
554 * Device uses standards-violating 32-byte Bulk Command Block Wrappers and
555 * reports itself as "Proprietary SCSI Bulk." Cf. device entry 0x084d:0x0011.
556 */
557UNUSUAL_DEV( 0x04fc, 0x80c2, 0x0100, 0x0100,
558 "Kobian Mercury",
559 "Binocam DCB-132",
560 US_SC_DEVICE, US_PR_DEVICE, NULL,
561 US_FL_BULK32),
562
Linus Torvalds1da177e2005-04-16 15:20:36 -0700563/* Reported by Bob Sass <rls@vectordb.com> -- only rev 1.33 tested */
564UNUSUAL_DEV( 0x050d, 0x0115, 0x0133, 0x0133,
565 "Belkin",
566 "USB SCSI Adaptor",
567 US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
568 US_FL_SCM_MULT_TARG ),
569
570/* Iomega Clik! Drive
571 * Reported by David Chatenay <dchatenay@hotmail.com>
572 * The reason this is needed is not fully known.
573 */
574UNUSUAL_DEV( 0x0525, 0xa140, 0x0100, 0x0100,
575 "Iomega",
576 "USB Clik! 40",
Phil Dibowitz21206382006-04-16 19:18:36 -0700577 US_SC_8070, US_PR_DEVICE, NULL,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700578 US_FL_FIX_INQUIRY ),
579
Alan Stern25ff1c32008-12-15 12:43:41 -0500580/* Added by Alan Stern <stern@rowland.harvard.edu> */
581COMPLIANT_DEV(0x0525, 0xa4a5, 0x0000, 0x9999,
582 "Linux",
583 "File-backed Storage Gadget",
584 US_SC_DEVICE, US_PR_DEVICE, NULL,
585 US_FL_CAPACITY_OK ),
586
Linus Torvalds1da177e2005-04-16 15:20:36 -0700587/* Yakumo Mega Image 37
588 * Submitted by Stephan Fuhrmann <atomenergie@t-online.de> */
589UNUSUAL_DEV( 0x052b, 0x1801, 0x0100, 0x0100,
590 "Tekom Technologies, Inc",
591 "300_CAMERA",
592 US_SC_DEVICE, US_PR_DEVICE, NULL,
593 US_FL_IGNORE_RESIDUE ),
594
595/* Another Yakumo camera.
596 * Reported by Michele Alzetta <michele.alzetta@aliceposta.it> */
597UNUSUAL_DEV( 0x052b, 0x1804, 0x0100, 0x0100,
598 "Tekom Technologies, Inc",
599 "300_CAMERA",
600 US_SC_DEVICE, US_PR_DEVICE, NULL,
601 US_FL_IGNORE_RESIDUE ),
602
603/* Reported by Iacopo Spalletti <avvisi@spalletti.it> */
604UNUSUAL_DEV( 0x052b, 0x1807, 0x0100, 0x0100,
605 "Tekom Technologies, Inc",
606 "300_CAMERA",
607 US_SC_DEVICE, US_PR_DEVICE, NULL,
608 US_FL_IGNORE_RESIDUE ),
609
610/* Yakumo Mega Image 47
611 * Reported by Bjoern Paetzel <kolrabi@kolrabi.de> */
612UNUSUAL_DEV( 0x052b, 0x1905, 0x0100, 0x0100,
613 "Tekom Technologies, Inc",
614 "400_CAMERA",
615 US_SC_DEVICE, US_PR_DEVICE, NULL,
616 US_FL_IGNORE_RESIDUE ),
617
618/* Reported by Paul Ortyl <ortylp@3miasto.net>
619 * Note that it's similar to the device above, only different prodID */
620UNUSUAL_DEV( 0x052b, 0x1911, 0x0100, 0x0100,
621 "Tekom Technologies, Inc",
622 "400_CAMERA",
623 US_SC_DEVICE, US_PR_DEVICE, NULL,
624 US_FL_IGNORE_RESIDUE ),
625
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700626UNUSUAL_DEV( 0x054c, 0x0010, 0x0106, 0x0450,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700627 "Sony",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700628 "DSC-S30/S70/S75/505V/F505/F707/F717/P8",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700629 US_SC_SCSI, US_PR_DEVICE, NULL,
630 US_FL_SINGLE_LUN | US_FL_NOT_LOCKABLE | US_FL_NO_WP_DETECT ),
631
Lars Jacob7e3bd122006-07-10 11:53:58 -0400632/* Submitted by Lars Jacob <jacob.lars@googlemail.com>
633 * This entry is needed because the device reports Sub=ff */
634UNUSUAL_DEV( 0x054c, 0x0010, 0x0500, 0x0610,
Alexandre Duret-Lutzec7dc8d2005-12-26 23:04:24 -0800635 "Sony",
Lars Jacob7e3bd122006-07-10 11:53:58 -0400636 "DSC-T1/T5/H5",
Alexandre Duret-Lutzec7dc8d2005-12-26 23:04:24 -0800637 US_SC_8070, US_PR_DEVICE, NULL,
638 US_FL_SINGLE_LUN ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700639
640
641/* Reported by wim@geeks.nl */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700642UNUSUAL_DEV( 0x054c, 0x0025, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700643 "Sony",
644 "Memorystick NW-MS7",
645 US_SC_DEVICE, US_PR_DEVICE, NULL,
646 US_FL_SINGLE_LUN ),
647
648#ifdef CONFIG_USB_STORAGE_ISD200
649UNUSUAL_DEV( 0x054c, 0x002b, 0x0100, 0x0110,
650 "Sony",
651 "Portable USB Harddrive V2",
652 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
653 0 ),
654#endif
655
656/* Submitted by Olaf Hering, <olh@suse.de> SuSE Bugzilla #49049 */
Luiz Fernando N. Capitulino20b2e282007-01-24 16:19:37 -0200657UNUSUAL_DEV( 0x054c, 0x002c, 0x0501, 0x2000,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700658 "Sony",
659 "USB Floppy Drive",
660 US_SC_DEVICE, US_PR_DEVICE, NULL,
661 US_FL_SINGLE_LUN ),
662
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700663UNUSUAL_DEV( 0x054c, 0x002d, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700664 "Sony",
665 "Memorystick MSAC-US1",
666 US_SC_DEVICE, US_PR_DEVICE, NULL,
667 US_FL_SINGLE_LUN ),
668
669/* Submitted by Klaus Mueller <k.mueller@intershop.de> */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700670UNUSUAL_DEV( 0x054c, 0x002e, 0x0106, 0x0310,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700671 "Sony",
672 "Handycam",
673 US_SC_SCSI, US_PR_DEVICE, NULL,
674 US_FL_SINGLE_LUN ),
675
676/* Submitted by Rajesh Kumble Nayak <nayak@obs-nice.fr> */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700677UNUSUAL_DEV( 0x054c, 0x002e, 0x0500, 0x0500,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700678 "Sony",
679 "Handycam HC-85",
680 US_SC_UFI, US_PR_DEVICE, NULL,
681 US_FL_SINGLE_LUN ),
682
683UNUSUAL_DEV( 0x054c, 0x0032, 0x0000, 0x9999,
684 "Sony",
685 "Memorystick MSC-U01N",
686 US_SC_DEVICE, US_PR_DEVICE, NULL,
687 US_FL_SINGLE_LUN ),
688
689/* Submitted by Michal Mlotek <mlotek@foobar.pl> */
690UNUSUAL_DEV( 0x054c, 0x0058, 0x0000, 0x9999,
691 "Sony",
692 "PEG N760c Memorystick",
693 US_SC_DEVICE, US_PR_DEVICE, NULL,
694 US_FL_FIX_INQUIRY ),
695
696UNUSUAL_DEV( 0x054c, 0x0069, 0x0000, 0x9999,
697 "Sony",
698 "Memorystick MSC-U03",
699 US_SC_UFI, US_PR_CB, NULL,
700 US_FL_SINGLE_LUN ),
701
702/* Submitted by Nathan Babb <nathan@lexi.com> */
703UNUSUAL_DEV( 0x054c, 0x006d, 0x0000, 0x9999,
704 "Sony",
705 "PEG Mass Storage",
706 US_SC_DEVICE, US_PR_DEVICE, NULL,
707 US_FL_FIX_INQUIRY ),
708
Alan Sternf9dc8f92008-11-18 14:08:07 -0500709/* Submitted by Frank Engel <frankie@cse.unsw.edu.au> */
710UNUSUAL_DEV( 0x054c, 0x0099, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700711 "Sony",
712 "PEG Mass Storage",
713 US_SC_DEVICE, US_PR_DEVICE, NULL,
714 US_FL_FIX_INQUIRY ),
Alan Sternf9dc8f92008-11-18 14:08:07 -0500715
716/* Submitted by Mike Alborn <malborn@deandra.homeip.net> */
717UNUSUAL_DEV( 0x054c, 0x016a, 0x0000, 0x9999,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700718 "Sony",
719 "PEG Mass Storage",
720 US_SC_DEVICE, US_PR_DEVICE, NULL,
721 US_FL_FIX_INQUIRY ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700722
juergen.mell@t-online.de082fdd12006-08-28 13:53:53 -0700723/* floppy reports multiple luns */
724UNUSUAL_DEV( 0x055d, 0x2020, 0x0000, 0x0210,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700725 "SAMSUNG",
726 "SFD-321U [FW 0C]",
727 US_SC_DEVICE, US_PR_DEVICE, NULL,
728 US_FL_SINGLE_LUN ),
juergen.mell@t-online.de082fdd12006-08-28 13:53:53 -0700729
Linus Torvalds1da177e2005-04-16 15:20:36 -0700730
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700731UNUSUAL_DEV( 0x057b, 0x0000, 0x0000, 0x0299,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700732 "Y-E Data",
733 "Flashbuster-U",
734 US_SC_DEVICE, US_PR_CB, NULL,
735 US_FL_SINGLE_LUN),
736
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700737UNUSUAL_DEV( 0x057b, 0x0000, 0x0300, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700738 "Y-E Data",
739 "Flashbuster-U",
740 US_SC_DEVICE, US_PR_DEVICE, NULL,
741 US_FL_SINGLE_LUN),
742
743/* Reported by Johann Cardon <johann.cardon@free.fr>
744 * This entry is needed only because the device reports
745 * bInterfaceClass = 0xff (vendor-specific)
746 */
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700747UNUSUAL_DEV( 0x057b, 0x0022, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700748 "Y-E Data",
749 "Silicon Media R/W",
750 US_SC_DEVICE, US_PR_DEVICE, NULL, 0),
751
Matthew Dharme80b0fa2005-12-04 22:02:44 -0800752#ifdef CONFIG_USB_STORAGE_ALAUDA
753UNUSUAL_DEV( 0x0584, 0x0008, 0x0102, 0x0102,
754 "Fujifilm",
755 "DPC-R1 (Alauda)",
756 US_SC_SCSI, US_PR_ALAUDA, init_alauda, 0 ),
757#endif
758
Alan Sternf1e8de0d2007-11-26 10:23:05 -0500759/* Reported by RTE <raszilki@yandex.ru> */
760UNUSUAL_DEV( 0x058f, 0x6387, 0x0141, 0x0141,
761 "JetFlash",
762 "TS1GJF2A/120",
763 US_SC_DEVICE, US_PR_DEVICE, NULL,
764 US_FL_MAX_SECTORS_64 ),
765
Linus Torvalds1da177e2005-04-16 15:20:36 -0700766/* Fabrizio Fellini <fello@libero.it> */
767UNUSUAL_DEV( 0x0595, 0x4343, 0x0000, 0x2210,
768 "Fujifilm",
769 "Digital Camera EX-20 DSC",
770 US_SC_8070, US_PR_DEVICE, NULL, 0 ),
771
Alan Sterna4625492008-02-13 10:45:28 -0500772/* Reported by Andre Welter <a.r.welter@gmx.de>
773 * This antique device predates the release of the Bulk-only Transport
774 * spec, and if it gets a Get-Max-LUN then it requires the host to do a
775 * Clear-Halt on the bulk endpoints. The SINGLE_LUN flag will prevent
776 * us from sending the request.
777 */
778UNUSUAL_DEV( 0x059b, 0x0001, 0x0100, 0x0100,
779 "Iomega",
780 "ZIP 100",
781 US_SC_DEVICE, US_PR_DEVICE, NULL,
782 US_FL_SINGLE_LUN ),
783
Alan Sternb97b1962006-09-14 15:18:54 -0400784/* Reported by <Hendryk.Pfeiffer@gmx.de> */
785UNUSUAL_DEV( 0x059f, 0x0643, 0x0000, 0x0000,
786 "LaCie",
787 "DVD+-RW",
788 US_SC_DEVICE, US_PR_DEVICE, NULL,
789 US_FL_GO_SLOW ),
790
Linus Torvalds1da177e2005-04-16 15:20:36 -0700791/* Submitted by Joel Bourquard <numlock@freesurf.ch>
792 * Some versions of this device need the SubClass and Protocol overrides
793 * while others don't.
794 */
795UNUSUAL_DEV( 0x05ab, 0x0060, 0x1104, 0x1110,
796 "In-System",
797 "PyroGate External CD-ROM Enclosure (FCD-523)",
798 US_SC_SCSI, US_PR_BULK, NULL,
799 US_FL_NEED_OVERRIDE ),
800
801#ifdef CONFIG_USB_STORAGE_ISD200
802UNUSUAL_DEV( 0x05ab, 0x0031, 0x0100, 0x0110,
803 "In-System",
804 "USB/IDE Bridge (ATA/ATAPI)",
805 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
806 0 ),
807
808UNUSUAL_DEV( 0x05ab, 0x0301, 0x0100, 0x0110,
809 "In-System",
810 "Portable USB Harddrive V2",
811 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
812 0 ),
813
814UNUSUAL_DEV( 0x05ab, 0x0351, 0x0100, 0x0110,
815 "In-System",
816 "Portable USB Harddrive V2",
817 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
818 0 ),
819
820UNUSUAL_DEV( 0x05ab, 0x5701, 0x0100, 0x0110,
821 "In-System",
822 "USB Storage Adapter V2",
823 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
824 0 ),
825#endif
826
Sven Anderson35f4a0c2005-04-22 15:06:58 -0700827/* Submitted by Sven Anderson <sven-linux@anderson.de>
828 * There are at least four ProductIDs used for iPods, so I added 0x1202 and
829 * 0x1204. They just need the US_FL_FIX_CAPACITY. As the bcdDevice appears
830 * to change with firmware updates, I changed the range to maximum for all
831 * iPod entries.
832 */
833UNUSUAL_DEV( 0x05ac, 0x1202, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700834 "Apple",
835 "iPod",
836 US_SC_DEVICE, US_PR_DEVICE, NULL,
837 US_FL_FIX_CAPACITY ),
838
Sven Anderson35f4a0c2005-04-22 15:06:58 -0700839/* Reported by Avi Kivity <avi@argo.co.il> */
840UNUSUAL_DEV( 0x05ac, 0x1203, 0x0000, 0x9999,
841 "Apple",
842 "iPod",
843 US_SC_DEVICE, US_PR_DEVICE, NULL,
844 US_FL_FIX_CAPACITY ),
845
846UNUSUAL_DEV( 0x05ac, 0x1204, 0x0000, 0x9999,
847 "Apple",
848 "iPod",
849 US_SC_DEVICE, US_PR_DEVICE, NULL,
Pete Zaitcevad1428c2006-12-31 13:43:26 -0800850 US_FL_FIX_CAPACITY | US_FL_NOT_LOCKABLE ),
Sven Anderson35f4a0c2005-04-22 15:06:58 -0700851
852UNUSUAL_DEV( 0x05ac, 0x1205, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700853 "Apple",
854 "iPod",
855 US_SC_DEVICE, US_PR_DEVICE, NULL,
856 US_FL_FIX_CAPACITY ),
857
Phil Dibowitz880a9b52005-09-30 00:27:36 -0700858/*
859 * Reported by Tyson Vinson <lornoss@gmail.com>
860 * This particular productId is the iPod Nano
861 */
862UNUSUAL_DEV( 0x05ac, 0x120a, 0x0000, 0x9999,
863 "Apple",
864 "iPod",
865 US_SC_DEVICE, US_PR_DEVICE, NULL,
866 US_FL_FIX_CAPACITY ),
867
Dan Williams281b0642008-12-14 12:39:22 -0500868/* Reported by Dan Williams <dcbw@redhat.com>
869 * Option N.V. mobile broadband modems
870 * Ignore driver CD mode and force into modem mode by default.
871 */
872
873/* Globetrotter HSDPA; mass storage shows up as Qualcomm for vendor */
874UNUSUAL_DEV( 0x05c6, 0x1000, 0x0000, 0x9999,
875 "Option N.V.",
876 "Mass Storage",
877 US_SC_DEVICE, US_PR_DEVICE, option_ms_init,
878 0),
879
Linus Torvalds1da177e2005-04-16 15:20:36 -0700880#ifdef CONFIG_USB_STORAGE_JUMPSHOT
881UNUSUAL_DEV( 0x05dc, 0x0001, 0x0000, 0x0001,
882 "Lexar",
883 "Jumpshot USB CF Reader",
884 US_SC_SCSI, US_PR_JUMPSHOT, NULL,
885 US_FL_NEED_OVERRIDE ),
886#endif
887
888/* Reported by Blake Matheny <bmatheny@purdue.edu> */
889UNUSUAL_DEV( 0x05dc, 0xb002, 0x0000, 0x0113,
890 "Lexar",
891 "USB CF Reader",
892 US_SC_DEVICE, US_PR_DEVICE, NULL,
893 US_FL_FIX_INQUIRY ),
894
895/* The following two entries are for a Genesys USB to IDE
896 * converter chip, but it changes its ProductId depending
897 * on whether or not a disk or an optical device is enclosed
898 * They were originally reported by Alexander Oltu
899 * <alexander@all-2.com> and Peter Marks <peter.marks@turner.com>
900 * respectively.
Phil Dibowitz883d9892006-06-24 17:27:10 -0700901 *
902 * US_FL_GO_SLOW and US_FL_MAX_SECTORS_64 added by Phil Dibowitz
903 * <phil@ipom.com> as these flags were made and hard-coded
904 * special-cases were pulled from scsiglue.c.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700905 */
906UNUSUAL_DEV( 0x05e3, 0x0701, 0x0000, 0xffff,
907 "Genesys Logic",
908 "USB to IDE Optical",
909 US_SC_DEVICE, US_PR_DEVICE, NULL,
Phil Dibowitz883d9892006-06-24 17:27:10 -0700910 US_FL_GO_SLOW | US_FL_MAX_SECTORS_64 ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700911
912UNUSUAL_DEV( 0x05e3, 0x0702, 0x0000, 0xffff,
913 "Genesys Logic",
914 "USB to IDE Disk",
915 US_SC_DEVICE, US_PR_DEVICE, NULL,
Phil Dibowitz883d9892006-06-24 17:27:10 -0700916 US_FL_GO_SLOW | US_FL_MAX_SECTORS_64 ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700917
Ben Efrosdbe6e0c02008-11-23 20:06:38 -0800918/* Reported by Ben Efros <ben@pc-doctor.com> */
919UNUSUAL_DEV( 0x05e3, 0x0723, 0x9451, 0x9451,
920 "Genesys Logic",
921 "USB to SATA",
922 US_SC_DEVICE, US_PR_DEVICE, NULL,
923 US_FL_SANE_SENSE ),
924
Linus Torvalds1da177e2005-04-16 15:20:36 -0700925/* Reported by Hanno Boeck <hanno@gmx.de>
926 * Taken from the Lycoris Kernel */
927UNUSUAL_DEV( 0x0636, 0x0003, 0x0000, 0x9999,
928 "Vivitar",
929 "Vivicam 35Xx",
930 US_SC_SCSI, US_PR_BULK, NULL,
931 US_FL_FIX_INQUIRY ),
932
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700933UNUSUAL_DEV( 0x0644, 0x0000, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700934 "TEAC",
935 "Floppy Drive",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700936 US_SC_UFI, US_PR_CB, NULL, 0 ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700937
938#ifdef CONFIG_USB_STORAGE_SDDR09
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700939UNUSUAL_DEV( 0x066b, 0x0105, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700940 "Olympus",
941 "Camedia MAUSB-2",
Matthew Dharmf5b8cb92005-12-04 21:57:51 -0800942 US_SC_SCSI, US_PR_EUSB_SDDR09, usb_stor_sddr09_init,
943 0),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700944#endif
945
946/* Reported by Darsen Lu <darsen@micro.ee.nthu.edu.tw> */
947UNUSUAL_DEV( 0x066f, 0x8000, 0x0001, 0x0001,
948 "SigmaTel",
949 "USBMSC Audio Player",
950 US_SC_DEVICE, US_PR_DEVICE, NULL,
951 US_FL_FIX_CAPACITY ),
952
953/* Reported by Richard -=[]=- <micro_flyer@hotmail.com> */
954UNUSUAL_DEV( 0x067b, 0x2507, 0x0100, 0x0100,
955 "Prolific Technology Inc.",
956 "Mass Storage Device",
957 US_SC_DEVICE, US_PR_DEVICE, NULL,
958 US_FL_FIX_CAPACITY | US_FL_GO_SLOW ),
959
960/* Reported by Alex Butcher <alex.butcher@assursys.co.uk> */
Oliver Neukumb1636392008-12-12 11:01:45 +0100961UNUSUAL_DEV( 0x067b, 0x3507, 0x0001, 0x0101,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700962 "Prolific Technology Inc.",
963 "ATAPI-6 Bridge Controller",
964 US_SC_DEVICE, US_PR_DEVICE, NULL,
965 US_FL_FIX_CAPACITY | US_FL_GO_SLOW ),
966
967/* Submitted by Benny Sjostrand <benny@hostmobility.com> */
968UNUSUAL_DEV( 0x0686, 0x4011, 0x0001, 0x0001,
969 "Minolta",
970 "Dimage F300",
971 US_SC_SCSI, US_PR_BULK, NULL, 0 ),
972
973/* Reported by Miguel A. Fosas <amn3s1a@ono.com> */
974UNUSUAL_DEV( 0x0686, 0x4017, 0x0001, 0x0001,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700975 "Minolta",
976 "DIMAGE E223",
977 US_SC_SCSI, US_PR_DEVICE, NULL, 0 ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700978
Linus Torvalds1da177e2005-04-16 15:20:36 -0700979UNUSUAL_DEV( 0x0693, 0x0005, 0x0100, 0x0100,
980 "Hagiwara",
981 "Flashgate",
S.Caglar Onurc0e0c192007-07-04 13:52:47 -0700982 US_SC_SCSI, US_PR_BULK, NULL, 0 ),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700983
Alan Stern754501b2006-02-23 10:19:25 -0500984/* Reported by David Hamilton <niftimusmaximus@lycos.com> */
985UNUSUAL_DEV( 0x069b, 0x3004, 0x0001, 0x0001,
986 "Thomson Multimedia Inc.",
987 "RCA RD1080 MP3 Player",
988 US_SC_DEVICE, US_PR_DEVICE, NULL,
989 US_FL_FIX_CAPACITY ),
990
Alan Sternfe1926a2008-09-04 09:56:35 -0400991/* Reported by Adrian Pilchowiec <adi1981@epf.pl> */
992UNUSUAL_DEV( 0x071b, 0x3203, 0x0000, 0x0000,
993 "RockChip",
994 "MP3",
995 US_SC_DEVICE, US_PR_DEVICE, NULL,
996 US_FL_NO_WP_DETECT | US_FL_MAX_SECTORS_64),
997
Jean-Baptiste Onofre64915092008-12-20 20:11:55 +0100998/* Reported by Jean-Baptiste Onofre <jb@nanthrax.net>
999 * Support the following product :
1000 * "Dane-Elec MediaTouch"
1001 */
1002UNUSUAL_DEV( 0x071b, 0x32bb, 0x0000, 0x0000,
1003 "RockChip",
1004 "MTP",
1005 US_SC_DEVICE, US_PR_DEVICE, NULL,
1006 US_FL_NO_WP_DETECT | US_FL_MAX_SECTORS_64),
1007
Massimiliano Ghilardic4766562007-09-04 22:53:43 +02001008/* Reported by Massimiliano Ghilardi <massimiliano.ghilardi@gmail.com>
1009 * This USB MP3/AVI player device fails and disconnects if more than 128
1010 * sectors (64kB) are read/written in a single command, and may be present
1011 * at least in the following products:
1012 * "Magnex Digital Video Panel DVP 1800"
1013 * "MP4 AIGO 4GB SLOT SD"
1014 * "Teclast TL-C260 MP3"
1015 * "i.Meizu PMP MP3/MP4"
1016 * "Speed MV8 MP4 Audio Player"
1017 */
1018UNUSUAL_DEV( 0x071b, 0x3203, 0x0100, 0x0100,
1019 "RockChip",
1020 "ROCK MP3",
1021 US_SC_DEVICE, US_PR_DEVICE, NULL,
1022 US_FL_MAX_SECTORS_64),
1023
Olivier Blondeauf430c402006-04-16 19:19:25 -07001024/* Reported by Olivier Blondeau <zeitoun@gmail.com> */
1025UNUSUAL_DEV( 0x0727, 0x0306, 0x0100, 0x0100,
1026 "ATMEL",
1027 "SND1 Storage",
1028 US_SC_DEVICE, US_PR_DEVICE, NULL,
1029 US_FL_IGNORE_RESIDUE),
1030
Phil Dibowitz1e7a5a82006-03-05 21:36:51 -08001031/* Submitted by Roman Hodek <roman@hodek.net> */
1032UNUSUAL_DEV( 0x0781, 0x0001, 0x0200, 0x0200,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001033 "Sandisk",
1034 "ImageMate SDDR-05a",
1035 US_SC_SCSI, US_PR_CB, NULL,
1036 US_FL_SINGLE_LUN ),
1037
Phil Dibowitz1e7a5a82006-03-05 21:36:51 -08001038UNUSUAL_DEV( 0x0781, 0x0002, 0x0009, 0x0009,
1039 "SanDisk Corporation",
1040 "ImageMate CompactFlash USB",
1041 US_SC_DEVICE, US_PR_DEVICE, NULL,
1042 US_FL_FIX_CAPACITY ),
1043
Daniel Drake094ec602005-09-30 12:58:13 +01001044#ifdef CONFIG_USB_STORAGE_USBAT
1045UNUSUAL_DEV( 0x0781, 0x0005, 0x0005, 0x0005,
1046 "Sandisk",
1047 "ImageMate SDDR-05b",
Peter Chubbbdcfd9e2006-05-02 18:29:34 +01001048 US_SC_SCSI, US_PR_USBAT, init_usbat_flash,
Daniel Drake094ec602005-09-30 12:58:13 +01001049 US_FL_SINGLE_LUN ),
1050#endif
1051
Linus Torvalds1da177e2005-04-16 15:20:36 -07001052UNUSUAL_DEV( 0x0781, 0x0100, 0x0100, 0x0100,
1053 "Sandisk",
1054 "ImageMate SDDR-12",
1055 US_SC_SCSI, US_PR_CB, NULL,
1056 US_FL_SINGLE_LUN ),
1057
1058#ifdef CONFIG_USB_STORAGE_SDDR09
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001059UNUSUAL_DEV( 0x0781, 0x0200, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001060 "Sandisk",
1061 "ImageMate SDDR-09",
Matthew Dharmf5b8cb92005-12-04 21:57:51 -08001062 US_SC_SCSI, US_PR_EUSB_SDDR09, usb_stor_sddr09_init,
1063 0),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001064#endif
1065
1066#ifdef CONFIG_USB_STORAGE_FREECOM
1067UNUSUAL_DEV( 0x07ab, 0xfc01, 0x0000, 0x9999,
1068 "Freecom",
1069 "USB-IDE",
1070 US_SC_QIC, US_PR_FREECOM, freecom_init, 0),
1071#endif
1072
1073/* Reported by Eero Volotinen <eero@ping-viini.org> */
Phil Dibowitze5278322005-10-23 23:52:39 -07001074UNUSUAL_DEV( 0x07ab, 0xfccd, 0x0000, 0x9999,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001075 "Freecom Technologies",
1076 "FHD-Classic",
1077 US_SC_DEVICE, US_PR_DEVICE, NULL,
1078 US_FL_FIX_CAPACITY),
1079
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001080UNUSUAL_DEV( 0x07af, 0x0004, 0x0100, 0x0133,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001081 "Microtech",
1082 "USB-SCSI-DB25",
1083 US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
1084 US_FL_SCM_MULT_TARG ),
1085
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001086UNUSUAL_DEV( 0x07af, 0x0005, 0x0100, 0x0100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001087 "Microtech",
1088 "USB-SCSI-HD50",
Phil Dibowitze8116e82005-06-22 22:47:13 -07001089 US_SC_DEVICE, US_PR_DEVICE, usb_stor_euscsi_init,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001090 US_FL_SCM_MULT_TARG ),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001091
Alan Sternc20b15f2008-12-01 10:36:15 -05001092#ifdef CONFIG_USB_STORAGE_SDDR09
Linus Torvalds1da177e2005-04-16 15:20:36 -07001093UNUSUAL_DEV( 0x07af, 0x0006, 0x0100, 0x0100,
1094 "Microtech",
1095 "CameraMate (DPCM_USB)",
1096 US_SC_SCSI, US_PR_DPCM_USB, NULL, 0 ),
Alan Sternc20b15f2008-12-01 10:36:15 -05001097#else
1098UNUSUAL_DEV( 0x07af, 0x0006, 0x0100, 0x0100,
1099 "Microtech",
1100 "CameraMate",
1101 US_SC_SCSI, US_PR_CB, NULL,
1102 US_FL_SINGLE_LUN ),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001103#endif
1104
Matthew Dharme80b0fa2005-12-04 22:02:44 -08001105#ifdef CONFIG_USB_STORAGE_ALAUDA
1106UNUSUAL_DEV( 0x07b4, 0x010a, 0x0102, 0x0102,
1107 "Olympus",
1108 "MAUSB-10 (Alauda)",
1109 US_SC_SCSI, US_PR_ALAUDA, init_alauda, 0 ),
1110#endif
1111
Linus Torvalds1da177e2005-04-16 15:20:36 -07001112#ifdef CONFIG_USB_STORAGE_DATAFAB
1113UNUSUAL_DEV( 0x07c4, 0xa000, 0x0000, 0x0015,
1114 "Datafab",
1115 "MDCFE-B USB CF Reader",
1116 US_SC_SCSI, US_PR_DATAFAB, NULL,
1117 0 ),
1118
1119/*
1120 * The following Datafab-based devices may or may not work
1121 * using the current driver...the 0xffff is arbitrary since I
1122 * don't know what device versions exist for these guys.
1123 *
1124 * The 0xa003 and 0xa004 devices in particular I'm curious about.
1125 * I'm told they exist but so far nobody has come forward to say that
1126 * they work with this driver. Given the success we've had getting
1127 * other Datafab-based cards operational with this driver, I've decided
1128 * to leave these two devices in the list.
1129 */
1130UNUSUAL_DEV( 0x07c4, 0xa001, 0x0000, 0xffff,
1131 "SIIG/Datafab",
1132 "SIIG/Datafab Memory Stick+CF Reader/Writer",
1133 US_SC_SCSI, US_PR_DATAFAB, NULL,
1134 0 ),
1135
1136/* Reported by Josef Reisinger <josef.reisinger@netcologne.de> */
1137UNUSUAL_DEV( 0x07c4, 0xa002, 0x0000, 0xffff,
1138 "Datafab/Unknown",
1139 "MD2/MD3 Disk enclosure",
1140 US_SC_SCSI, US_PR_DATAFAB, NULL,
1141 US_FL_SINGLE_LUN ),
1142
1143UNUSUAL_DEV( 0x07c4, 0xa003, 0x0000, 0xffff,
1144 "Datafab/Unknown",
1145 "Datafab-based Reader",
1146 US_SC_SCSI, US_PR_DATAFAB, NULL,
1147 0 ),
1148
1149UNUSUAL_DEV( 0x07c4, 0xa004, 0x0000, 0xffff,
1150 "Datafab/Unknown",
1151 "Datafab-based Reader",
1152 US_SC_SCSI, US_PR_DATAFAB, NULL,
1153 0 ),
1154
1155UNUSUAL_DEV( 0x07c4, 0xa005, 0x0000, 0xffff,
1156 "PNY/Datafab",
1157 "PNY/Datafab CF+SM Reader",
1158 US_SC_SCSI, US_PR_DATAFAB, NULL,
1159 0 ),
1160
1161UNUSUAL_DEV( 0x07c4, 0xa006, 0x0000, 0xffff,
1162 "Simple Tech/Datafab",
1163 "Simple Tech/Datafab CF+SM Reader",
1164 US_SC_SCSI, US_PR_DATAFAB, NULL,
1165 0 ),
1166#endif
1167
1168#ifdef CONFIG_USB_STORAGE_SDDR55
1169/* Contributed by Peter Waechtler */
1170UNUSUAL_DEV( 0x07c4, 0xa103, 0x0000, 0x9999,
1171 "Datafab",
1172 "MDSM-B reader",
1173 US_SC_SCSI, US_PR_SDDR55, NULL,
1174 US_FL_FIX_INQUIRY ),
1175#endif
1176
1177#ifdef CONFIG_USB_STORAGE_DATAFAB
1178/* Submitted by Olaf Hering <olh@suse.de> */
1179UNUSUAL_DEV( 0x07c4, 0xa109, 0x0000, 0xffff,
1180 "Datafab Systems, Inc.",
1181 "USB to CF + SM Combo (LC1)",
1182 US_SC_SCSI, US_PR_DATAFAB, NULL,
1183 0 ),
1184#endif
1185#ifdef CONFIG_USB_STORAGE_SDDR55
1186/* SM part - aeb <Andries.Brouwer@cwi.nl> */
1187UNUSUAL_DEV( 0x07c4, 0xa109, 0x0000, 0xffff,
1188 "Datafab Systems, Inc.",
1189 "USB to CF + SM Combo (LC1)",
1190 US_SC_SCSI, US_PR_SDDR55, NULL,
1191 US_FL_SINGLE_LUN ),
1192#endif
1193
felix@derklecks.ded6427cf2005-04-18 17:39:28 -07001194#ifdef CONFIG_USB_STORAGE_DATAFAB
1195/* Reported by Felix Moeller <felix@derklecks.de>
1196 * in Germany this is sold by Hama with the productnumber 46952
1197 * as "DualSlot CompactFlash(TM) & MStick Drive USB"
1198 */
1199UNUSUAL_DEV( 0x07c4, 0xa10b, 0x0000, 0xffff,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001200 "DataFab Systems Inc.",
1201 "USB CF+MS",
1202 US_SC_SCSI, US_PR_DATAFAB, NULL,
1203 0 ),
felix@derklecks.ded6427cf2005-04-18 17:39:28 -07001204
1205#endif
1206
Linus Torvalds1da177e2005-04-16 15:20:36 -07001207/* Datafab KECF-USB / Sagatek DCS-CF / Simpletech Flashlink UCF-100
1208 * Only revision 1.13 tested (same for all of the above devices,
1209 * based on the Datafab DF-UG-07 chip). Needed for US_FL_FIX_INQUIRY.
1210 * Submitted by Marek Michalkiewicz <marekm@amelek.gda.pl>.
1211 * See also http://martin.wilck.bei.t-online.de/#kecf .
1212 */
1213UNUSUAL_DEV( 0x07c4, 0xa400, 0x0000, 0xffff,
1214 "Datafab",
1215 "KECF-USB",
1216 US_SC_DEVICE, US_PR_DEVICE, NULL,
1217 US_FL_FIX_INQUIRY ),
1218
Alan Stern368ee642008-07-21 10:08:28 -04001219/* Reported by Rauch Wolke <rauchwolke@gmx.net> */
1220UNUSUAL_DEV( 0x07c4, 0xa4a5, 0x0000, 0xffff,
1221 "Simple Tech/Datafab",
1222 "CF+SM Reader",
1223 US_SC_DEVICE, US_PR_DEVICE, NULL,
1224 US_FL_IGNORE_RESIDUE ),
1225
Linus Torvalds1da177e2005-04-16 15:20:36 -07001226/* Casio QV 2x00/3x00/4000/8000 digital still cameras are not conformant
1227 * to the USB storage specification in two ways:
1228 * - They tell us they are using transport protocol CBI. In reality they
1229 * are using transport protocol CB.
1230 * - They don't like the INQUIRY command. So we must handle this command
1231 * of the SCSI layer ourselves.
1232 * - Some cameras with idProduct=0x1001 and bcdDevice=0x1000 have
1233 * bInterfaceProtocol=0x00 (US_PR_CBI) while others have 0x01 (US_PR_CB).
1234 * So don't remove the US_PR_CB override!
1235 * - Cameras with bcdDevice=0x9009 require the US_SC_8070 override.
1236 */
1237UNUSUAL_DEV( 0x07cf, 0x1001, 0x1000, 0x9999,
1238 "Casio",
1239 "QV DigitalCamera",
1240 US_SC_8070, US_PR_CB, NULL,
1241 US_FL_NEED_OVERRIDE | US_FL_FIX_INQUIRY ),
1242
1243/* Submitted by Hartmut Wahl <hwahl@hwahl.de>*/
1244UNUSUAL_DEV( 0x0839, 0x000a, 0x0001, 0x0001,
1245 "Samsung",
1246 "Digimax 410",
1247 US_SC_DEVICE, US_PR_DEVICE, NULL,
1248 US_FL_FIX_INQUIRY),
1249
Alan Stern8010e062008-11-04 11:33:35 -05001250/* Reported by Luciano Rocha <luciano@eurotux.com> */
1251UNUSUAL_DEV( 0x0840, 0x0082, 0x0001, 0x0001,
1252 "Argosy",
1253 "Storage",
1254 US_SC_DEVICE, US_PR_DEVICE, NULL,
1255 US_FL_FIX_CAPACITY),
1256
Nguyen Anh Quynhe2673b22008-12-11 15:04:11 -08001257/* Reported and patched by Nguyen Anh Quynh <aquynh@gmail.com> */
1258UNUSUAL_DEV( 0x0840, 0x0084, 0x0001, 0x0001,
1259 "Argosy",
1260 "Storage",
1261 US_SC_DEVICE, US_PR_DEVICE, NULL,
1262 US_FL_FIX_CAPACITY),
1263
Phil Dibowitzaa23c8d2009-01-20 23:42:52 +01001264/* Reported by Martijn Hijdra <martijn.hijdra@gmail.com> */
1265UNUSUAL_DEV( 0x0840, 0x0085, 0x0001, 0x0001,
1266 "Argosy",
1267 "Storage",
1268 US_SC_DEVICE, US_PR_DEVICE, NULL,
1269 US_FL_FIX_CAPACITY),
1270
Linus Torvalds1da177e2005-04-16 15:20:36 -07001271/* Entry and supporting patch by Theodore Kilgore <kilgota@auburn.edu>.
1272 * Flag will support Bulk devices which use a standards-violating 32-byte
1273 * Command Block Wrapper. Here, the "DC2MEGA" cameras (several brands) with
1274 * Grandtech GT892x chip, which request "Proprietary SCSI Bulk" support.
1275 */
1276
1277UNUSUAL_DEV( 0x084d, 0x0011, 0x0110, 0x0110,
1278 "Grandtech",
1279 "DC2MEGA",
1280 US_SC_DEVICE, US_PR_DEVICE, NULL,
1281 US_FL_BULK32),
1282
Andrew Lunnf7687212008-04-24 19:36:39 +02001283/* Andrew Lunn <andrew@lunn.ch>
1284 * PanDigital Digital Picture Frame. Does not like ALLOW_MEDIUM_REMOVAL
1285 * on LUN 4.
1286 * Note: Vend:Prod clash with "Ltd Maxell WS30 Slim Digital Camera"
1287*/
1288UNUSUAL_DEV( 0x0851, 0x1543, 0x0200, 0x0200,
1289 "PanDigital",
1290 "Photo Frame",
1291 US_SC_DEVICE, US_PR_DEVICE, NULL,
1292 US_FL_NOT_LOCKABLE),
1293
Alan Sternba3e93a2006-01-30 10:19:43 -05001294/* Submitted by Jan De Luyck <lkml@kcore.org> */
1295UNUSUAL_DEV( 0x08bd, 0x1100, 0x0000, 0x0000,
1296 "CITIZEN",
1297 "X1DE-USB",
1298 US_SC_DEVICE, US_PR_DEVICE, NULL,
1299 US_FL_SINGLE_LUN),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001300
Dylan Tafta7e555b2007-02-05 16:41:01 -08001301/* Submitted by Dylan Taft <d13f00l@gmail.com>
1302 * US_FL_IGNORE_RESIDUE Needed
1303 */
1304UNUSUAL_DEV( 0x08ca, 0x3103, 0x0100, 0x0100,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001305 "AIPTEK",
1306 "Aiptek USB Keychain MP3 Player",
1307 US_SC_DEVICE, US_PR_DEVICE, NULL,
1308 US_FL_IGNORE_RESIDUE),
Dylan Tafta7e555b2007-02-05 16:41:01 -08001309
Linus Torvalds1da177e2005-04-16 15:20:36 -07001310/* Entry needed for flags. Moreover, all devices with this ID use
1311 * bulk-only transport, but _some_ falsely report Control/Bulk instead.
1312 * One example is "Trumpion Digital Research MYMP3".
1313 * Submitted by Bjoern Brill <brill(at)fs.math.uni-frankfurt.de>
1314 */
1315UNUSUAL_DEV( 0x090a, 0x1001, 0x0100, 0x0100,
1316 "Trumpion",
1317 "t33520 USB Flash Card Controller",
1318 US_SC_DEVICE, US_PR_BULK, NULL,
1319 US_FL_NEED_OVERRIDE ),
1320
Phil Dibowitz17247572005-05-21 00:45:55 -07001321/* Reported by Filippo Bardelli <filibard@libero.it>
1322 * The device reports a subclass of RBC, which is wrong.
1323 */
1324UNUSUAL_DEV( 0x090a, 0x1050, 0x0100, 0x0100,
1325 "Trumpion Microelectronics, Inc.",
1326 "33520 USB Digital Voice Recorder",
1327 US_SC_UFI, US_PR_DEVICE, NULL,
1328 0),
1329
Linus Torvalds1da177e2005-04-16 15:20:36 -07001330/* Trumpion Microelectronics MP3 player (felipe_alfaro@linuxmail.org) */
1331UNUSUAL_DEV( 0x090a, 0x1200, 0x0000, 0x9999,
1332 "Trumpion",
1333 "MP3 player",
1334 US_SC_RBC, US_PR_BULK, NULL,
1335 0 ),
1336
1337/* aeb */
1338UNUSUAL_DEV( 0x090c, 0x1132, 0x0000, 0xffff,
1339 "Feiya",
1340 "5-in-1 Card Reader",
1341 US_SC_DEVICE, US_PR_DEVICE, NULL,
1342 US_FL_FIX_CAPACITY ),
1343
1344/* This Pentax still camera is not conformant
1345 * to the USB storage specification: -
1346 * - It does not like the INQUIRY command. So we must handle this command
1347 * of the SCSI layer ourselves.
1348 * Tested on Rev. 10.00 (0x1000)
1349 * Submitted by James Courtier-Dutton <James@superbug.demon.co.uk>
1350 */
1351UNUSUAL_DEV( 0x0a17, 0x0004, 0x1000, 0x1000,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001352 "Pentax",
1353 "Optio 2/3/400",
1354 US_SC_DEVICE, US_PR_DEVICE, NULL,
1355 US_FL_FIX_INQUIRY ),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001356
1357
1358/* Submitted by Per Winkvist <per.winkvist@uk.com> */
1359UNUSUAL_DEV( 0x0a17, 0x006, 0x0000, 0xffff,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001360 "Pentax",
1361 "Optio S/S4",
1362 US_SC_DEVICE, US_PR_DEVICE, NULL,
1363 US_FL_FIX_INQUIRY ),
Daniel Drake3c332422006-07-26 13:59:23 +01001364
Daniel Drakee3f47f82008-12-10 23:28:25 +02001365/* Reported by Jaak Ristioja <Ristioja@gmail.com> */
1366UNUSUAL_DEV( 0x0a17, 0x006e, 0x0100, 0x0100,
1367 "Pentax",
1368 "K10D",
1369 US_SC_DEVICE, US_PR_DEVICE, NULL,
1370 US_FL_FIX_CAPACITY ),
1371
Ben Collins67fa1062007-05-26 03:06:32 -07001372/* These are virtual windows driver CDs, which the zd1211rw driver
1373 * automatically converts into WLAN devices. */
Daniel Drake3c332422006-07-26 13:59:23 +01001374UNUSUAL_DEV( 0x0ace, 0x2011, 0x0101, 0x0101,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001375 "ZyXEL",
1376 "G-220F USB-WLAN Install",
1377 US_SC_DEVICE, US_PR_DEVICE, NULL,
1378 US_FL_IGNORE_DEVICE ),
Daniel Drake3c332422006-07-26 13:59:23 +01001379
Matthew Davidson64902cb2007-05-01 01:15:01 +01001380UNUSUAL_DEV( 0x0ace, 0x20ff, 0x0101, 0x0101,
1381 "SiteCom",
1382 "WL-117 USB-WLAN Install",
1383 US_SC_DEVICE, US_PR_DEVICE, NULL,
1384 US_FL_IGNORE_DEVICE ),
1385
Dan Williams281b0642008-12-14 12:39:22 -05001386/* Reported by Dan Williams <dcbw@redhat.com>
1387 * Option N.V. mobile broadband modems
1388 * Ignore driver CD mode and force into modem mode by default.
1389 */
1390
1391/* iCON 225 */
1392UNUSUAL_DEV( 0x0af0, 0x6971, 0x0000, 0x9999,
1393 "Option N.V.",
1394 "Mass Storage",
1395 US_SC_DEVICE, US_PR_DEVICE, option_ms_init,
1396 0),
1397
Filip Abene7c6f802008-05-08 10:48:12 -07001398/* Reported by F. Aben <f.aben@option.com>
1399 * This device (wrongly) has a vendor-specific device descriptor.
1400 * The entry is needed so usb-storage can bind to it's mass-storage
1401 * interface as an interface driver */
1402UNUSUAL_DEV( 0x0af0, 0x7401, 0x0000, 0x0000,
1403 "Option",
1404 "GI 0401 SD-Card",
1405 US_SC_DEVICE, US_PR_DEVICE, NULL,
1406 0 ),
1407
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001408/* Reported by Ben Efros <ben@pc-doctor.com> */
1409UNUSUAL_DEV( 0x0bc2, 0x3010, 0x0000, 0x0000,
1410 "Seagate",
1411 "FreeAgent Pro",
1412 US_SC_DEVICE, US_PR_DEVICE, NULL,
1413 US_FL_SANE_SENSE ),
1414
Linus Torvalds1da177e2005-04-16 15:20:36 -07001415#ifdef CONFIG_USB_STORAGE_ISD200
1416UNUSUAL_DEV( 0x0bf6, 0xa001, 0x0100, 0x0110,
1417 "ATI",
1418 "USB Cable 205",
1419 US_SC_ISD200, US_PR_BULK, isd200_Initialization,
1420 0 ),
1421#endif
1422
1423#ifdef CONFIG_USB_STORAGE_DATAFAB
1424UNUSUAL_DEV( 0x0c0b, 0xa109, 0x0000, 0xffff,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001425 "Acomdata",
1426 "CF",
1427 US_SC_SCSI, US_PR_DATAFAB, NULL,
1428 US_FL_SINGLE_LUN ),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001429#endif
1430#ifdef CONFIG_USB_STORAGE_SDDR55
1431UNUSUAL_DEV( 0x0c0b, 0xa109, 0x0000, 0xffff,
S.Caglar Onurc0e0c192007-07-04 13:52:47 -07001432 "Acomdata",
1433 "SM",
1434 US_SC_SCSI, US_PR_SDDR55, NULL,
1435 US_FL_SINGLE_LUN ),
Linus Torvalds1da177e2005-04-16 15:20:36 -07001436#endif
1437
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001438UNUSUAL_DEV( 0x0d49, 0x7310, 0x0000, 0x9999,
1439 "Maxtor",
1440 "USB to SATA",
1441 US_SC_DEVICE, US_PR_DEVICE, NULL,
1442 US_FL_SANE_SENSE),
1443
Alan Sternf9dc8f92008-11-18 14:08:07 -05001444/*
1445 * Pete Zaitcev <zaitcev@yahoo.com>, bz#164688.
1446 * The device blatantly ignores LUN and returns 1 in GetMaxLUN.
1447 */
1448UNUSUAL_DEV( 0x0c45, 0x1060, 0x0100, 0x0100,
1449 "Unknown",
1450 "Unknown",
1451 US_SC_DEVICE, US_PR_DEVICE, NULL,
1452 US_FL_SINGLE_LUN ),
1453
Matthew Dharm34008db2005-07-28 14:49:01 -07001454/* Submitted by: Nick Sillik <n.sillik@temple.edu>
1455 * Needed for OneTouch extension to usb-storage
1456 *
1457 */
1458#ifdef CONFIG_USB_STORAGE_ONETOUCH
Antti Andreimann94656632005-11-17 09:47:53 -08001459 UNUSUAL_DEV( 0x0d49, 0x7000, 0x0000, 0x9999,
1460 "Maxtor",
1461 "OneTouch External Harddrive",
1462 US_SC_DEVICE, US_PR_DEVICE, onetouch_connect_input,
1463 0),
Matthew Dharm34008db2005-07-28 14:49:01 -07001464 UNUSUAL_DEV( 0x0d49, 0x7010, 0x0000, 0x9999,
1465 "Maxtor",
1466 "OneTouch External Harddrive",
1467 US_SC_DEVICE, US_PR_DEVICE, onetouch_connect_input,
1468 0),
1469#endif
1470
Linus Torvalds1da177e2005-04-16 15:20:36 -07001471/* Submitted by Joris Struyve <joris@struyve.be> */
1472UNUSUAL_DEV( 0x0d96, 0x410a, 0x0001, 0xffff,
1473 "Medion",
1474 "MD 7425",
1475 US_SC_DEVICE, US_PR_DEVICE, NULL,
1476 US_FL_FIX_INQUIRY),
1477
1478/*
1479 * Entry for Jenoptik JD 5200z3
1480 *
1481 * email: car.busse@gmx.de
1482 */
1483UNUSUAL_DEV( 0x0d96, 0x5200, 0x0001, 0x0200,
1484 "Jenoptik",
1485 "JD 5200 z3",
1486 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_FIX_INQUIRY),
1487
Sergey Ovcharenko3b438e32008-12-17 19:28:06 +03001488/* Reported by Jason Johnston <killean@shaw.ca> */
1489UNUSUAL_DEV( 0x0dc4, 0x0073, 0x0000, 0x0000,
1490 "Macpower Technology Co.LTD.",
1491 "USB 2.0 3.5\" DEVICE",
1492 US_SC_DEVICE, US_PR_DEVICE, NULL,
1493 US_FL_FIX_CAPACITY),
1494
Linus Torvalds1da177e2005-04-16 15:20:36 -07001495/* Reported by Lubomir Blaha <tritol@trilogic.cz>
1496 * I _REALLY_ don't know what 3rd, 4th number and all defines mean, but this
1497 * works for me. Can anybody correct these values? (I able to test corrected
1498 * version.)
1499 */
1500UNUSUAL_DEV( 0x0dd8, 0x1060, 0x0000, 0xffff,
1501 "Netac",
1502 "USB-CF-Card",
1503 US_SC_DEVICE, US_PR_DEVICE, NULL,
1504 US_FL_FIX_INQUIRY ),
1505
Ben Collins67fa1062007-05-26 03:06:32 -07001506/* Reported by Edward Chapman (taken from linux-usb mailing list)
1507 Netac OnlyDisk Mini U2CV2 512MB USB 2.0 Flash Drive */
1508UNUSUAL_DEV( 0x0dd8, 0xd202, 0x0000, 0x9999,
1509 "Netac",
1510 "USB Flash Disk",
1511 US_SC_DEVICE, US_PR_DEVICE, NULL,
1512 US_FL_IGNORE_RESIDUE ),
1513
1514
Linus Torvalds1da177e2005-04-16 15:20:36 -07001515/* Patch by Stephan Walter <stephan.walter@epfl.ch>
1516 * I don't know why, but it works... */
1517UNUSUAL_DEV( 0x0dda, 0x0001, 0x0012, 0x0012,
1518 "WINWARD",
1519 "Music Disk",
1520 US_SC_DEVICE, US_PR_DEVICE, NULL,
1521 US_FL_IGNORE_RESIDUE ),
1522
1523/* Reported by Ian McConnell <ian at emit.demon.co.uk> */
1524UNUSUAL_DEV( 0x0dda, 0x0301, 0x0012, 0x0012,
1525 "PNP_MP3",
1526 "PNP_MP3 PLAYER",
1527 US_SC_DEVICE, US_PR_DEVICE, NULL,
1528 US_FL_IGNORE_RESIDUE ),
1529
Alan Stern982db2a2006-02-13 10:16:04 -05001530/* Reported by Jim McCloskey <mcclosk@ucsc.edu> */
1531UNUSUAL_DEV( 0x0e21, 0x0520, 0x0100, 0x0100,
1532 "Cowon Systems",
1533 "iAUDIO M5",
1534 US_SC_DEVICE, US_PR_BULK, NULL,
Phil Dibowitzbc724b92006-10-19 00:11:17 -07001535 US_FL_NEED_OVERRIDE ),
Alan Stern982db2a2006-02-13 10:16:04 -05001536
Linus Torvalds1da177e2005-04-16 15:20:36 -07001537/* Submitted by Antoine Mairesse <antoine.mairesse@free.fr> */
1538UNUSUAL_DEV( 0x0ed1, 0x6660, 0x0100, 0x0300,
1539 "USB",
1540 "Solid state disk",
1541 US_SC_DEVICE, US_PR_DEVICE, NULL,
1542 US_FL_FIX_INQUIRY ),
1543
1544/* Submitted by Daniel Drake <dsd@gentoo.org>
1545 * Reported by dayul on the Gentoo Forums */
1546UNUSUAL_DEV( 0x0ea0, 0x2168, 0x0110, 0x0110,
1547 "Ours Technology",
1548 "Flash Disk",
1549 US_SC_DEVICE, US_PR_DEVICE, NULL,
1550 US_FL_IGNORE_RESIDUE ),
1551
1552/* Reported by Rastislav Stanik <rs_kernel@yahoo.com> */
1553UNUSUAL_DEV( 0x0ea0, 0x6828, 0x0110, 0x0110,
1554 "USB",
1555 "Flash Disk",
1556 US_SC_DEVICE, US_PR_DEVICE, NULL,
1557 US_FL_IGNORE_RESIDUE ),
1558
Phil Dibowitz883d9892006-06-24 17:27:10 -07001559/* Reported by Benjamin Schiller <sbenni@gmx.de>
1560 * It is also sold by Easylite as DJ 20 */
1561UNUSUAL_DEV( 0x0ed1, 0x7636, 0x0103, 0x0103,
1562 "Typhoon",
1563 "My DJ 1820",
1564 US_SC_DEVICE, US_PR_DEVICE, NULL,
1565 US_FL_IGNORE_RESIDUE | US_FL_GO_SLOW | US_FL_MAX_SECTORS_64),
1566
Robert Spitzenpfeil4e584072008-02-20 12:11:22 -05001567/* Patch by Leonid Petrov mail at lpetrov.net
1568 * Reported by Robert Spitzenpfeil <robert@spitzenpfeil.org>
1569 * http://www.qbik.ch/usb/devices/showdev.php?id=1705
1570 * Updated to 103 device by MJ Ray mjr at phonecoop.coop
1571 */
1572UNUSUAL_DEV( 0x0f19, 0x0103, 0x0100, 0x0100,
1573 "Oracom Co., Ltd",
1574 "ORC-200M",
1575 US_SC_DEVICE, US_PR_DEVICE, NULL,
1576 US_FL_IGNORE_RESIDUE ),
1577
David Kuehlingb41ee5d2006-08-07 10:18:48 -04001578/* David Kuehling <dvdkhlng@gmx.de>:
1579 * for MP3-Player AVOX WSX-300ER (bought in Japan). Reports lots of SCSI
1580 * errors when trying to write.
1581 */
1582UNUSUAL_DEV( 0x0f19, 0x0105, 0x0100, 0x0100,
1583 "C-MEX",
1584 "A-VOX",
1585 US_SC_DEVICE, US_PR_DEVICE, NULL,
1586 US_FL_IGNORE_RESIDUE ),
1587
Jeremy Katzc17b49e2007-07-19 09:37:42 -04001588/* Jeremy Katz <katzj@redhat.com>:
1589 * The Blackberry Pearl can run in two modes; a usb-storage only mode
1590 * and a mode that allows access via mass storage and to its database.
1591 * The berry_charge module will set the device to dual mode and thus we
1592 * should ignore its native mode if that module is built
1593 */
1594#ifdef CONFIG_USB_BERRY_CHARGE
1595UNUSUAL_DEV( 0x0fca, 0x0006, 0x0001, 0x0001,
1596 "RIM",
1597 "Blackberry Pearl",
1598 US_SC_DEVICE, US_PR_DEVICE, NULL,
1599 US_FL_IGNORE_DEVICE ),
1600#endif
1601
Linus Torvalds1da177e2005-04-16 15:20:36 -07001602/* Reported by Michael Stattmann <michael@stattmann.com> */
1603UNUSUAL_DEV( 0x0fce, 0xd008, 0x0000, 0x0000,
1604 "Sony Ericsson",
1605 "V800-Vodafone 802",
1606 US_SC_DEVICE, US_PR_DEVICE, NULL,
1607 US_FL_NO_WP_DETECT ),
1608
Phil Dibowitza83775b2009-01-20 23:48:36 +01001609/* Reported by The Solutor <thesolutor@gmail.com> */
1610UNUSUAL_DEV( 0x0fce, 0xd0e1, 0x0000, 0x0000,
1611 "Sony Ericsson",
1612 "MD400",
1613 US_SC_DEVICE, US_PR_DEVICE, NULL,
1614 US_FL_IGNORE_DEVICE),
1615
Alan Sternb544d742007-01-31 10:57:55 -05001616/* Reported by Jan Mate <mate@fiit.stuba.sk>
1617 * and by Soeren Sonnenburg <kernel@nn7.de> */
Phil Dibowitz39c2f3ac2006-09-11 00:27:40 -07001618UNUSUAL_DEV( 0x0fce, 0xe030, 0x0000, 0x0000,
1619 "Sony Ericsson",
1620 "P990i",
1621 US_SC_DEVICE, US_PR_DEVICE, NULL,
Alan Sternb544d742007-01-31 10:57:55 -05001622 US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
Phil Dibowitz39c2f3ac2006-09-11 00:27:40 -07001623
Phil Dibowitzc9c770e2006-08-27 23:54:37 -07001624/* Reported by Emmanuel Vasilakis <evas@forthnet.gr> */
1625UNUSUAL_DEV( 0x0fce, 0xe031, 0x0000, 0x0000,
1626 "Sony Ericsson",
1627 "M600i",
1628 US_SC_DEVICE, US_PR_DEVICE, NULL,
Phil Dibowitzc5f23b02008-05-26 21:33:58 +02001629 US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
Phil Dibowitzc9c770e2006-08-27 23:54:37 -07001630
Alan Sternf9dc8f92008-11-18 14:08:07 -05001631/* Reported by Ricardo Barberis <ricardo@dattatec.com> */
1632UNUSUAL_DEV( 0x0fce, 0xe092, 0x0000, 0x0000,
1633 "Sony Ericsson",
1634 "P1i",
1635 US_SC_DEVICE, US_PR_DEVICE, NULL,
1636 US_FL_IGNORE_RESIDUE ),
1637
Linus Torvalds1da177e2005-04-16 15:20:36 -07001638/* Reported by Kevin Cernekee <kpc-usbdev@gelato.uiuc.edu>
1639 * Tested on hardware version 1.10.
1640 * Entry is needed only for the initializer function override.
Phil Dibowitz51b5bce2006-11-02 23:14:10 -08001641 * Devices with bcd > 110 seem to not need it while those
1642 * with bcd < 110 appear to need it.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001643 */
Phil Dibowitz51b5bce2006-11-02 23:14:10 -08001644UNUSUAL_DEV( 0x1019, 0x0c55, 0x0000, 0x0110,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001645 "Desknote",
1646 "UCR-61S2B",
1647 US_SC_DEVICE, US_PR_DEVICE, usb_stor_ucr61s2b_init,
1648 0 ),
1649
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08001650UNUSUAL_DEV( 0x1058, 0x0704, 0x0000, 0x9999,
1651 "Western Digital",
1652 "External HDD",
1653 US_SC_DEVICE, US_PR_DEVICE, NULL,
1654 US_FL_SANE_SENSE),
1655
Alan Stern274399d2008-02-20 12:10:04 -05001656/* Reported by Fabio Venturi <f.venturi@tdnet.it>
1657 * The device reports a vendor-specific bDeviceClass.
1658 */
1659UNUSUAL_DEV( 0x10d6, 0x2200, 0x0100, 0x0100,
1660 "Actions Semiconductor",
1661 "Mtp device",
1662 US_SC_DEVICE, US_PR_DEVICE, NULL,
1663 0),
1664
Kevin Lloyd112225b2007-07-16 13:49:27 -07001665/* Reported by Kevin Lloyd <linux@sierrawireless.com>
1666 * Entry is needed for the initializer function override,
1667 * which instructs the device to load as a modem
1668 * device.
1669 */
1670UNUSUAL_DEV( 0x1199, 0x0fff, 0x0000, 0x9999,
1671 "Sierra Wireless",
1672 "USB MMC Storage",
Kevin Lloyd32fe5e32008-07-10 14:14:57 -07001673 US_SC_DEVICE, US_PR_DEVICE, sierra_ms_init,
1674 0),
Kevin Lloyd112225b2007-07-16 13:49:27 -07001675
Jaco Kroon49314372006-11-15 01:02:08 -08001676/* Reported by Jaco Kroon <jaco@kroon.co.za>
1677 * The usb-storage module found on the Digitech GNX4 (and supposedly other
1678 * devices) misbehaves and causes a bunch of invalid I/O errors.
1679 */
1680UNUSUAL_DEV( 0x1210, 0x0003, 0x0100, 0x0100,
1681 "Digitech HMG",
1682 "DigiTech Mass Storage",
1683 US_SC_DEVICE, US_PR_DEVICE, NULL,
1684 US_FL_IGNORE_RESIDUE ),
1685
fangxiaozhiaad8a272008-04-10 14:51:06 +08001686/* Reported by fangxiaozhi <huananhu@huawei.com>
1687 * This brings the HUAWEI data card devices into multi-port mode
Johann Wilhelmd853d872007-09-05 13:49:29 +02001688 */
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001689UNUSUAL_DEV( 0x12d1, 0x1001, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001690 "HUAWEI MOBILE",
1691 "Mass Storage",
1692 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1693 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001694UNUSUAL_DEV( 0x12d1, 0x1003, 0x0000, 0x0000,
Johann Wilhelmd853d872007-09-05 13:49:29 +02001695 "HUAWEI MOBILE",
1696 "Mass Storage",
1697 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1698 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001699UNUSUAL_DEV( 0x12d1, 0x1004, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001700 "HUAWEI MOBILE",
1701 "Mass Storage",
1702 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1703 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001704UNUSUAL_DEV( 0x12d1, 0x1401, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001705 "HUAWEI MOBILE",
1706 "Mass Storage",
1707 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1708 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001709UNUSUAL_DEV( 0x12d1, 0x1402, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001710 "HUAWEI MOBILE",
1711 "Mass Storage",
1712 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1713 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001714UNUSUAL_DEV( 0x12d1, 0x1403, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001715 "HUAWEI MOBILE",
1716 "Mass Storage",
1717 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1718 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001719UNUSUAL_DEV( 0x12d1, 0x1404, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001720 "HUAWEI MOBILE",
1721 "Mass Storage",
1722 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1723 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001724UNUSUAL_DEV( 0x12d1, 0x1405, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001725 "HUAWEI MOBILE",
1726 "Mass Storage",
1727 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1728 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001729UNUSUAL_DEV( 0x12d1, 0x1406, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001730 "HUAWEI MOBILE",
1731 "Mass Storage",
1732 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1733 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001734UNUSUAL_DEV( 0x12d1, 0x1407, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001735 "HUAWEI MOBILE",
1736 "Mass Storage",
1737 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1738 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001739UNUSUAL_DEV( 0x12d1, 0x1408, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001740 "HUAWEI MOBILE",
1741 "Mass Storage",
1742 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1743 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001744UNUSUAL_DEV( 0x12d1, 0x1409, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001745 "HUAWEI MOBILE",
1746 "Mass Storage",
1747 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1748 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001749UNUSUAL_DEV( 0x12d1, 0x140A, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001750 "HUAWEI MOBILE",
1751 "Mass Storage",
1752 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1753 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001754UNUSUAL_DEV( 0x12d1, 0x140B, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001755 "HUAWEI MOBILE",
1756 "Mass Storage",
1757 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1758 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001759UNUSUAL_DEV( 0x12d1, 0x140C, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001760 "HUAWEI MOBILE",
1761 "Mass Storage",
1762 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1763 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001764UNUSUAL_DEV( 0x12d1, 0x140D, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001765 "HUAWEI MOBILE",
1766 "Mass Storage",
1767 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1768 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001769UNUSUAL_DEV( 0x12d1, 0x140E, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001770 "HUAWEI MOBILE",
1771 "Mass Storage",
1772 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1773 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001774UNUSUAL_DEV( 0x12d1, 0x140F, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08001775 "HUAWEI MOBILE",
1776 "Mass Storage",
1777 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1778 0),
fangxiaozhi1460e5e2008-10-15 14:15:36 +08001779UNUSUAL_DEV( 0x12d1, 0x1410, 0x0000, 0x0000,
1780 "HUAWEI MOBILE",
1781 "Mass Storage",
1782 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1783 0),
1784UNUSUAL_DEV( 0x12d1, 0x1411, 0x0000, 0x0000,
1785 "HUAWEI MOBILE",
1786 "Mass Storage",
1787 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1788 0),
1789UNUSUAL_DEV( 0x12d1, 0x1412, 0x0000, 0x0000,
1790 "HUAWEI MOBILE",
1791 "Mass Storage",
1792 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1793 0),
1794UNUSUAL_DEV( 0x12d1, 0x1413, 0x0000, 0x0000,
1795 "HUAWEI MOBILE",
1796 "Mass Storage",
1797 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1798 0),
1799UNUSUAL_DEV( 0x12d1, 0x1414, 0x0000, 0x0000,
1800 "HUAWEI MOBILE",
1801 "Mass Storage",
1802 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1803 0),
1804UNUSUAL_DEV( 0x12d1, 0x1415, 0x0000, 0x0000,
1805 "HUAWEI MOBILE",
1806 "Mass Storage",
1807 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1808 0),
1809UNUSUAL_DEV( 0x12d1, 0x1416, 0x0000, 0x0000,
1810 "HUAWEI MOBILE",
1811 "Mass Storage",
1812 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1813 0),
1814UNUSUAL_DEV( 0x12d1, 0x1417, 0x0000, 0x0000,
1815 "HUAWEI MOBILE",
1816 "Mass Storage",
1817 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1818 0),
1819UNUSUAL_DEV( 0x12d1, 0x1418, 0x0000, 0x0000,
1820 "HUAWEI MOBILE",
1821 "Mass Storage",
1822 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1823 0),
1824UNUSUAL_DEV( 0x12d1, 0x1419, 0x0000, 0x0000,
1825 "HUAWEI MOBILE",
1826 "Mass Storage",
1827 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1828 0),
1829UNUSUAL_DEV( 0x12d1, 0x141A, 0x0000, 0x0000,
1830 "HUAWEI MOBILE",
1831 "Mass Storage",
1832 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1833 0),
1834UNUSUAL_DEV( 0x12d1, 0x141B, 0x0000, 0x0000,
1835 "HUAWEI MOBILE",
1836 "Mass Storage",
1837 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1838 0),
1839UNUSUAL_DEV( 0x12d1, 0x141C, 0x0000, 0x0000,
1840 "HUAWEI MOBILE",
1841 "Mass Storage",
1842 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1843 0),
1844UNUSUAL_DEV( 0x12d1, 0x141D, 0x0000, 0x0000,
1845 "HUAWEI MOBILE",
1846 "Mass Storage",
1847 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1848 0),
1849UNUSUAL_DEV( 0x12d1, 0x141E, 0x0000, 0x0000,
1850 "HUAWEI MOBILE",
1851 "Mass Storage",
1852 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1853 0),
1854UNUSUAL_DEV( 0x12d1, 0x141F, 0x0000, 0x0000,
1855 "HUAWEI MOBILE",
1856 "Mass Storage",
1857 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1858 0),
1859UNUSUAL_DEV( 0x12d1, 0x1420, 0x0000, 0x0000,
1860 "HUAWEI MOBILE",
1861 "Mass Storage",
1862 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1863 0),
1864UNUSUAL_DEV( 0x12d1, 0x1421, 0x0000, 0x0000,
1865 "HUAWEI MOBILE",
1866 "Mass Storage",
1867 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1868 0),
1869UNUSUAL_DEV( 0x12d1, 0x1422, 0x0000, 0x0000,
1870 "HUAWEI MOBILE",
1871 "Mass Storage",
1872 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1873 0),
1874UNUSUAL_DEV( 0x12d1, 0x1423, 0x0000, 0x0000,
1875 "HUAWEI MOBILE",
1876 "Mass Storage",
1877 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1878 0),
1879UNUSUAL_DEV( 0x12d1, 0x1424, 0x0000, 0x0000,
1880 "HUAWEI MOBILE",
1881 "Mass Storage",
1882 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1883 0),
1884UNUSUAL_DEV( 0x12d1, 0x1425, 0x0000, 0x0000,
1885 "HUAWEI MOBILE",
1886 "Mass Storage",
1887 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1888 0),
1889UNUSUAL_DEV( 0x12d1, 0x1426, 0x0000, 0x0000,
1890 "HUAWEI MOBILE",
1891 "Mass Storage",
1892 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1893 0),
1894UNUSUAL_DEV( 0x12d1, 0x1427, 0x0000, 0x0000,
1895 "HUAWEI MOBILE",
1896 "Mass Storage",
1897 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1898 0),
1899UNUSUAL_DEV( 0x12d1, 0x1428, 0x0000, 0x0000,
1900 "HUAWEI MOBILE",
1901 "Mass Storage",
1902 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1903 0),
1904UNUSUAL_DEV( 0x12d1, 0x1429, 0x0000, 0x0000,
1905 "HUAWEI MOBILE",
1906 "Mass Storage",
1907 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1908 0),
1909UNUSUAL_DEV( 0x12d1, 0x142A, 0x0000, 0x0000,
1910 "HUAWEI MOBILE",
1911 "Mass Storage",
1912 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1913 0),
1914UNUSUAL_DEV( 0x12d1, 0x142B, 0x0000, 0x0000,
1915 "HUAWEI MOBILE",
1916 "Mass Storage",
1917 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1918 0),
1919UNUSUAL_DEV( 0x12d1, 0x142C, 0x0000, 0x0000,
1920 "HUAWEI MOBILE",
1921 "Mass Storage",
1922 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1923 0),
1924UNUSUAL_DEV( 0x12d1, 0x142D, 0x0000, 0x0000,
1925 "HUAWEI MOBILE",
1926 "Mass Storage",
1927 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1928 0),
1929UNUSUAL_DEV( 0x12d1, 0x142E, 0x0000, 0x0000,
1930 "HUAWEI MOBILE",
1931 "Mass Storage",
1932 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1933 0),
1934UNUSUAL_DEV( 0x12d1, 0x142F, 0x0000, 0x0000,
1935 "HUAWEI MOBILE",
1936 "Mass Storage",
1937 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1938 0),
1939UNUSUAL_DEV( 0x12d1, 0x1430, 0x0000, 0x0000,
1940 "HUAWEI MOBILE",
1941 "Mass Storage",
1942 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1943 0),
1944UNUSUAL_DEV( 0x12d1, 0x1431, 0x0000, 0x0000,
1945 "HUAWEI MOBILE",
1946 "Mass Storage",
1947 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1948 0),
1949UNUSUAL_DEV( 0x12d1, 0x1432, 0x0000, 0x0000,
1950 "HUAWEI MOBILE",
1951 "Mass Storage",
1952 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1953 0),
1954UNUSUAL_DEV( 0x12d1, 0x1433, 0x0000, 0x0000,
1955 "HUAWEI MOBILE",
1956 "Mass Storage",
1957 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1958 0),
1959UNUSUAL_DEV( 0x12d1, 0x1434, 0x0000, 0x0000,
1960 "HUAWEI MOBILE",
1961 "Mass Storage",
1962 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1963 0),
1964UNUSUAL_DEV( 0x12d1, 0x1435, 0x0000, 0x0000,
1965 "HUAWEI MOBILE",
1966 "Mass Storage",
1967 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1968 0),
1969UNUSUAL_DEV( 0x12d1, 0x1436, 0x0000, 0x0000,
1970 "HUAWEI MOBILE",
1971 "Mass Storage",
1972 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1973 0),
1974UNUSUAL_DEV( 0x12d1, 0x1437, 0x0000, 0x0000,
1975 "HUAWEI MOBILE",
1976 "Mass Storage",
1977 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1978 0),
1979UNUSUAL_DEV( 0x12d1, 0x1438, 0x0000, 0x0000,
1980 "HUAWEI MOBILE",
1981 "Mass Storage",
1982 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1983 0),
1984UNUSUAL_DEV( 0x12d1, 0x1439, 0x0000, 0x0000,
1985 "HUAWEI MOBILE",
1986 "Mass Storage",
1987 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1988 0),
1989UNUSUAL_DEV( 0x12d1, 0x143A, 0x0000, 0x0000,
1990 "HUAWEI MOBILE",
1991 "Mass Storage",
1992 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1993 0),
1994UNUSUAL_DEV( 0x12d1, 0x143B, 0x0000, 0x0000,
1995 "HUAWEI MOBILE",
1996 "Mass Storage",
1997 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
1998 0),
1999UNUSUAL_DEV( 0x12d1, 0x143C, 0x0000, 0x0000,
2000 "HUAWEI MOBILE",
2001 "Mass Storage",
2002 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
2003 0),
2004UNUSUAL_DEV( 0x12d1, 0x143D, 0x0000, 0x0000,
2005 "HUAWEI MOBILE",
2006 "Mass Storage",
2007 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
2008 0),
2009UNUSUAL_DEV( 0x12d1, 0x143E, 0x0000, 0x0000,
2010 "HUAWEI MOBILE",
2011 "Mass Storage",
2012 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
2013 0),
2014UNUSUAL_DEV( 0x12d1, 0x143F, 0x0000, 0x0000,
fangxiaozhiaad8a272008-04-10 14:51:06 +08002015 "HUAWEI MOBILE",
2016 "Mass Storage",
2017 US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
2018 0),
Johann Wilhelmd853d872007-09-05 13:49:29 +02002019
Phil Dibowitz7b1cbeb2005-05-02 23:54:28 -07002020/* Reported by Vilius Bilinkevicius <vilisas AT xxx DOT lt) */
2021UNUSUAL_DEV( 0x132b, 0x000b, 0x0001, 0x0001,
2022 "Minolta",
2023 "Dimage Z10",
2024 US_SC_DEVICE, US_PR_DEVICE, NULL,
2025 0 ),
2026
Linus Torvalds1da177e2005-04-16 15:20:36 -07002027/* Reported by Kotrla Vitezslav <kotrla@ceb.cz> */
2028UNUSUAL_DEV( 0x1370, 0x6828, 0x0110, 0x0110,
2029 "SWISSBIT",
2030 "Black Silver",
2031 US_SC_DEVICE, US_PR_DEVICE, NULL,
2032 US_FL_IGNORE_RESIDUE ),
2033
Phil Dibowitzf1cd4ad2006-12-31 00:19:50 -08002034/* Reported by Francesco Foresti <frafore@tiscali.it> */
2035UNUSUAL_DEV( 0x14cd, 0x6600, 0x0201, 0x0201,
2036 "Super Top",
2037 "IDE DEVICE",
2038 US_SC_DEVICE, US_PR_DEVICE, NULL,
2039 US_FL_IGNORE_RESIDUE ),
2040
Phil Dibowitz3030ca42008-10-19 08:17:54 +02002041/* Reported by Alexandre Oliva <oliva@lsd.ic.unicamp.br>
2042 * JMicron responds to USN and several other SCSI ioctls with a
2043 * residue that causes subsequent I/O requests to fail. */
2044UNUSUAL_DEV( 0x152d, 0x2329, 0x0100, 0x0100,
Ben Efrosdbe6e0c02008-11-23 20:06:38 -08002045 "JMicron",
2046 "USB to ATA/ATAPI Bridge",
2047 US_SC_DEVICE, US_PR_DEVICE, NULL,
2048 US_FL_IGNORE_RESIDUE | US_FL_SANE_SENSE ),
Phil Dibowitz3030ca42008-10-19 08:17:54 +02002049
Phil Dibowitzf1cd4ad2006-12-31 00:19:50 -08002050/* Reported by Robert Schedel <r.schedel@yahoo.de>
2051 * Note: this is a 'super top' device like the above 14cd/6600 device */
2052UNUSUAL_DEV( 0x1652, 0x6600, 0x0201, 0x0201,
2053 "Teac",
2054 "HD-35PUK-B",
2055 US_SC_DEVICE, US_PR_DEVICE, NULL,
2056 US_FL_IGNORE_RESIDUE ),
2057
Oliver Neukumb90de8a2009-01-14 16:17:19 +01002058UNUSUAL_DEV( 0x2116, 0x0320, 0x0001, 0x0001,
2059 "ST",
2060 "2A",
2061 US_SC_DEVICE, US_PR_DEVICE, NULL,
2062 US_FL_FIX_CAPACITY),
2063
Davide Perini0ddc0632006-06-19 17:07:39 -04002064/* patch submitted by Davide Perini <perini.davide@dpsoftware.org>
2065 * and Renato Perini <rperini@email.it>
2066 */
2067UNUSUAL_DEV( 0x22b8, 0x3010, 0x0001, 0x0001,
2068 "Motorola",
2069 "RAZR V3x",
2070 US_SC_DEVICE, US_PR_DEVICE, NULL,
2071 US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
2072
Pete Zaitceva7f3dd52007-03-10 15:17:16 -08002073/*
Constantin Baranovcc36bdd2008-03-16 20:04:23 +00002074 * Patch by Constantin Baranov <const@tltsu.ru>
2075 * Report by Andreas Koenecke.
2076 * Motorola ROKR Z6.
2077 */
2078UNUSUAL_DEV( 0x22b8, 0x6426, 0x0101, 0x0101,
2079 "Motorola",
2080 "MSnc.",
2081 US_SC_DEVICE, US_PR_DEVICE, NULL,
2082 US_FL_FIX_INQUIRY | US_FL_FIX_CAPACITY | US_FL_BULK_IGNORE_TAG),
2083
Linus Torvalds1da177e2005-04-16 15:20:36 -07002084/* Reported by Radovan Garabik <garabik@kassiopeia.juls.savba.sk> */
2085UNUSUAL_DEV( 0x2735, 0x100b, 0x0000, 0x9999,
2086 "MPIO",
2087 "HS200",
2088 US_SC_DEVICE, US_PR_DEVICE, NULL,
2089 US_FL_GO_SLOW ),
2090
Phil Dibowitzed3e8fc2008-05-03 18:04:30 -07002091/* Reported by Rohan Hart <rohan.hart17@gmail.com> */
2092UNUSUAL_DEV( 0x2770, 0x915d, 0x0010, 0x0010,
2093 "INTOVA",
2094 "Pixtreme",
2095 US_SC_DEVICE, US_PR_DEVICE, NULL,
2096 US_FL_FIX_CAPACITY ),
2097
Frédéric Marchale8fab4c2008-10-13 14:00:11 +02002098/* Reported by Frederic Marchal <frederic.marchal@wowcompany.com>
2099 * Mio Moov 330
2100 */
2101UNUSUAL_DEV( 0x3340, 0xffff, 0x0000, 0x0000,
2102 "Mitac",
2103 "Mio DigiWalker USB Sync",
2104 US_SC_DEVICE,US_PR_DEVICE,NULL,
2105 US_FL_MAX_SECTORS_64 ),
2106
Alan Stern368ee642008-07-21 10:08:28 -04002107/* Reported by Andrey Rahmatullin <wrar@altlinux.org> */
2108UNUSUAL_DEV( 0x4102, 0x1020, 0x0100, 0x0100,
2109 "iRiver",
2110 "MP3 T10",
2111 US_SC_DEVICE, US_PR_DEVICE, NULL,
2112 US_FL_IGNORE_RESIDUE ),
2113
David Härdeman63dc3ff2005-11-23 15:45:49 -08002114/*
Jan Engelhardt96de0e22007-10-19 23:21:04 +02002115 * David Härdeman <david@2gen.com>
David Härdeman63dc3ff2005-11-23 15:45:49 -08002116 * The key makes the SCSI stack print confusing (but harmless) messages
2117 */
2118UNUSUAL_DEV( 0x4146, 0xba01, 0x0100, 0x0100,
2119 "Iomega",
2120 "Micro Mini 1GB",
2121 US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_NOT_LOCKABLE ),
2122
Linus Torvalds1da177e2005-04-16 15:20:36 -07002123#ifdef CONFIG_USB_STORAGE_SDDR55
2124UNUSUAL_DEV( 0x55aa, 0xa103, 0x0000, 0x9999,
2125 "Sandisk",
2126 "ImageMate SDDR55",
2127 US_SC_SCSI, US_PR_SDDR55, NULL,
2128 US_FL_SINGLE_LUN),
2129#endif
Pete Zaitceva00828e2005-10-22 20:15:09 -07002130
Alan Sterna2149bc2006-02-02 09:52:45 -05002131/* Reported by Andrew Simmons <andrew.simmons@gmail.com> */
2132UNUSUAL_DEV( 0xed06, 0x4500, 0x0001, 0x0001,
2133 "DataStor",
2134 "USB4500 FW1.04",
2135 US_SC_DEVICE, US_PR_DEVICE, NULL,
Oliver Neukum61bf54b2007-02-08 09:04:48 +01002136 US_FL_CAPACITY_HEURISTICS),
Alan Sterna2149bc2006-02-02 09:52:45 -05002137
Pete Zaitceva00828e2005-10-22 20:15:09 -07002138/* Control/Bulk transport for all SubClass values */
2139USUAL_DEV(US_SC_RBC, US_PR_CB, USB_US_TYPE_STOR),
2140USUAL_DEV(US_SC_8020, US_PR_CB, USB_US_TYPE_STOR),
2141USUAL_DEV(US_SC_QIC, US_PR_CB, USB_US_TYPE_STOR),
2142USUAL_DEV(US_SC_UFI, US_PR_CB, USB_US_TYPE_STOR),
2143USUAL_DEV(US_SC_8070, US_PR_CB, USB_US_TYPE_STOR),
2144USUAL_DEV(US_SC_SCSI, US_PR_CB, USB_US_TYPE_STOR),
2145
2146/* Control/Bulk/Interrupt transport for all SubClass values */
2147USUAL_DEV(US_SC_RBC, US_PR_CBI, USB_US_TYPE_STOR),
2148USUAL_DEV(US_SC_8020, US_PR_CBI, USB_US_TYPE_STOR),
2149USUAL_DEV(US_SC_QIC, US_PR_CBI, USB_US_TYPE_STOR),
2150USUAL_DEV(US_SC_UFI, US_PR_CBI, USB_US_TYPE_STOR),
2151USUAL_DEV(US_SC_8070, US_PR_CBI, USB_US_TYPE_STOR),
2152USUAL_DEV(US_SC_SCSI, US_PR_CBI, USB_US_TYPE_STOR),
2153
2154/* Bulk-only transport for all SubClass values */
2155USUAL_DEV(US_SC_RBC, US_PR_BULK, USB_US_TYPE_STOR),
2156USUAL_DEV(US_SC_8020, US_PR_BULK, USB_US_TYPE_STOR),
2157USUAL_DEV(US_SC_QIC, US_PR_BULK, USB_US_TYPE_STOR),
2158USUAL_DEV(US_SC_UFI, US_PR_BULK, USB_US_TYPE_STOR),
2159USUAL_DEV(US_SC_8070, US_PR_BULK, USB_US_TYPE_STOR),
2160USUAL_DEV(US_SC_SCSI, US_PR_BULK, 0),