unusual_devs.h 50 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759
  1. /* Driver for USB Mass Storage compliant devices
  2. * Unusual Devices File
  3. *
  4. * $Id: unusual_devs.h,v 1.32 2002/02/25 02:41:24 mdharm Exp $
  5. *
  6. * Current development and maintenance by:
  7. * (c) 2000-2002 Matthew Dharm (mdharm-usb@one-eyed-alien.net)
  8. *
  9. * Initial work by:
  10. * (c) 2000 Adam J. Richter (adam@yggdrasil.com), Yggdrasil Computing, Inc.
  11. *
  12. * Please see http://www.one-eyed-alien.net/~mdharm/linux-usb for more
  13. * information about this driver.
  14. *
  15. * This program is free software; you can redistribute it and/or modify it
  16. * under the terms of the GNU General Public License as published by the
  17. * Free Software Foundation; either version 2, or (at your option) any
  18. * later version.
  19. *
  20. * This program is distributed in the hope that it will be useful, but
  21. * WITHOUT ANY WARRANTY; without even the implied warranty of
  22. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  23. * General Public License for more details.
  24. *
  25. * You should have received a copy of the GNU General Public License along
  26. * with this program; if not, write to the Free Software Foundation, Inc.,
  27. * 675 Mass Ave, Cambridge, MA 02139, USA.
  28. */
  29. /* IMPORTANT NOTE: This file must be included in another file which does
  30. * the following thing for it to work:
  31. * The macro UNUSUAL_DEV() must be defined before this file is included
  32. */
  33. /* If you edit this file, please try to keep it sorted first by VendorID,
  34. * then by ProductID.
  35. *
  36. * If you want to add an entry for this file, be sure to include the
  37. * following information:
  38. * - a patch that adds the entry for your device, including your
  39. * email address right above the entry (plus maybe a brief
  40. * explanation of the reason for the entry),
  41. * - a copy of /proc/bus/usb/devices with your device plugged in
  42. * running with this patch.
  43. * Send your submission to either Phil Dibowitz <phil@ipom.com> or
  44. * Alan Stern <stern@rowland.harvard.edu>, and don't forget to CC: the
  45. * USB development list <linux-usb-devel@lists.sourceforge.net>.
  46. */
  47. /* patch submitted by Vivian Bregier <Vivian.Bregier@imag.fr>
  48. */
  49. UNUSUAL_DEV( 0x03eb, 0x2002, 0x0100, 0x0100,
  50. "ATMEL",
  51. "SND1 Storage",
  52. US_SC_DEVICE, US_PR_DEVICE, NULL,
  53. US_FL_IGNORE_RESIDUE),
  54. /* modified by Tobias Lorenz <tobias.lorenz@gmx.net> */
  55. UNUSUAL_DEV( 0x03ee, 0x6901, 0x0000, 0x0200,
  56. "Mitsumi",
  57. "USB FDD",
  58. US_SC_DEVICE, US_PR_DEVICE, NULL,
  59. US_FL_SINGLE_LUN ),
  60. /* Reported by Rodolfo Quesada <rquesada@roqz.net> */
  61. UNUSUAL_DEV( 0x03ee, 0x6906, 0x0003, 0x0003,
  62. "VIA Technologies Inc.",
  63. "Mitsumi multi cardreader",
  64. US_SC_DEVICE, US_PR_DEVICE, NULL,
  65. US_FL_IGNORE_RESIDUE ),
  66. UNUSUAL_DEV( 0x03f0, 0x0107, 0x0200, 0x0200,
  67. "HP",
  68. "CD-Writer+",
  69. US_SC_8070, US_PR_CB, NULL, 0),
  70. #ifdef CONFIG_USB_STORAGE_USBAT
  71. UNUSUAL_DEV( 0x03f0, 0x0207, 0x0001, 0x0001,
  72. "HP",
  73. "CD-Writer+ 8200e",
  74. US_SC_8070, US_PR_USBAT, init_usbat_cd, 0),
  75. UNUSUAL_DEV( 0x03f0, 0x0307, 0x0001, 0x0001,
  76. "HP",
  77. "CD-Writer+ CD-4e",
  78. US_SC_8070, US_PR_USBAT, init_usbat_cd, 0),
  79. #endif
  80. /* Reported by Grant Grundler <grundler@parisc-linux.org>
  81. * HP r707 camera in "Disk" mode with 2.00.23 or 2.00.24 firmware.
  82. */
  83. UNUSUAL_DEV( 0x03f0, 0x4002, 0x0001, 0x0001,
  84. "HP",
  85. "PhotoSmart R707",
  86. US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_FIX_CAPACITY),
  87. /* Reported by Sebastian Kapfer <sebastian_kapfer@gmx.net>
  88. * and Olaf Hering <olh@suse.de> (different bcd's, same vendor/product)
  89. * for USB floppies that need the SINGLE_LUN enforcement.
  90. */
  91. UNUSUAL_DEV( 0x0409, 0x0040, 0x0000, 0x9999,
  92. "NEC",
  93. "NEC USB UF000x",
  94. US_SC_DEVICE, US_PR_DEVICE, NULL,
  95. US_FL_SINGLE_LUN ),
  96. /* Patch submitted by Mihnea-Costin Grigore <mihnea@zulu.ro> */
  97. UNUSUAL_DEV( 0x040d, 0x6205, 0x0003, 0x0003,
  98. "VIA Technologies Inc.",
  99. "USB 2.0 Card Reader",
  100. US_SC_DEVICE, US_PR_DEVICE, NULL,
  101. US_FL_IGNORE_RESIDUE ),
  102. /* Deduced by Jonathan Woithe <jwoithe@physics.adelaide.edu.au>
  103. * Entry needed for flags: US_FL_FIX_INQUIRY because initial inquiry message
  104. * always fails and confuses drive.
  105. */
  106. UNUSUAL_DEV( 0x0411, 0x001c, 0x0113, 0x0113,
  107. "Buffalo",
  108. "DUB-P40G HDD",
  109. US_SC_DEVICE, US_PR_DEVICE, NULL,
  110. US_FL_FIX_INQUIRY ),
  111. /* Submitted by Ernestas Vaiciukevicius <ernisv@gmail.com> */
  112. UNUSUAL_DEV( 0x0419, 0x0100, 0x0100, 0x0100,
  113. "Samsung Info. Systems America, Inc.",
  114. "MP3 Player",
  115. US_SC_DEVICE, US_PR_DEVICE, NULL,
  116. US_FL_IGNORE_RESIDUE ),
  117. /* Reported by Orgad Shaneh <orgads@gmail.com> */
  118. UNUSUAL_DEV( 0x0419, 0xaace, 0x0100, 0x0100,
  119. "Samsung", "MP3 Player",
  120. US_SC_DEVICE, US_PR_DEVICE, NULL,
  121. US_FL_IGNORE_RESIDUE ),
  122. /* Reported by Christian Leber <christian@leber.de> */
  123. UNUSUAL_DEV( 0x0419, 0xaaf5, 0x0100, 0x0100,
  124. "TrekStor",
  125. "i.Beat 115 2.0",
  126. US_SC_DEVICE, US_PR_DEVICE, NULL,
  127. US_FL_IGNORE_RESIDUE | US_FL_NOT_LOCKABLE ),
  128. /* Reported by Stefan Werner <dustbln@gmx.de> */
  129. UNUSUAL_DEV( 0x0419, 0xaaf6, 0x0100, 0x0100,
  130. "TrekStor",
  131. "i.Beat Joy 2.0",
  132. US_SC_DEVICE, US_PR_DEVICE, NULL,
  133. US_FL_IGNORE_RESIDUE ),
  134. /* Reported by Pete Zaitcev <zaitcev@redhat.com>, bz#176584 */
  135. UNUSUAL_DEV( 0x0420, 0x0001, 0x0100, 0x0100,
  136. "GENERIC", "MP3 PLAYER", /* MyMusix PD-205 on the outside. */
  137. US_SC_DEVICE, US_PR_DEVICE, NULL,
  138. US_FL_IGNORE_RESIDUE ),
  139. /* Reported by Andrew Nayenko <relan@bk.ru> */
  140. UNUSUAL_DEV( 0x0421, 0x0019, 0x0592, 0x0592,
  141. "Nokia",
  142. "Nokia 6288",
  143. US_SC_DEVICE, US_PR_DEVICE, NULL,
  144. US_FL_MAX_SECTORS_64 ),
  145. /* Reported by Mario Rettig <mariorettig@web.de> */
  146. UNUSUAL_DEV( 0x0421, 0x042e, 0x0100, 0x0100,
  147. "Nokia",
  148. "Nokia 3250",
  149. US_SC_DEVICE, US_PR_DEVICE, NULL,
  150. US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
  151. /* Reported by <honkkis@gmail.com> */
  152. UNUSUAL_DEV( 0x0421, 0x0433, 0x0100, 0x0100,
  153. "Nokia",
  154. "E70",
  155. US_SC_DEVICE, US_PR_DEVICE, NULL,
  156. US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
  157. /* Reported by Jon Hart <Jon.Hart@web.de> */
  158. UNUSUAL_DEV( 0x0421, 0x0434, 0x0100, 0x0100,
  159. "Nokia",
  160. "E60",
  161. US_SC_DEVICE, US_PR_DEVICE, NULL,
  162. US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
  163. /* Reported by Sumedha Swamy <sumedhaswamy@gmail.com> and
  164. * Einar Th. Einarsson <einarthered@gmail.com> */
  165. UNUSUAL_DEV( 0x0421, 0x0444, 0x0100, 0x0100,
  166. "Nokia",
  167. "N91",
  168. US_SC_DEVICE, US_PR_DEVICE, NULL,
  169. US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
  170. /* Reported by Jiri Slaby <jirislaby@gmail.com> and
  171. * Rene C. Castberg <Rene@Castberg.org> */
  172. UNUSUAL_DEV( 0x0421, 0x0446, 0x0100, 0x0100,
  173. "Nokia",
  174. "N80",
  175. US_SC_DEVICE, US_PR_DEVICE, NULL,
  176. US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
  177. /* Reported by Matthew Bloch <matthew@bytemark.co.uk> */
  178. UNUSUAL_DEV( 0x0421, 0x044e, 0x0100, 0x0100,
  179. "Nokia",
  180. "E61",
  181. US_SC_DEVICE, US_PR_DEVICE, NULL,
  182. US_FL_IGNORE_RESIDUE | US_FL_FIX_CAPACITY ),
  183. /* Reported by Bardur Arantsson <bardur@scientician.net> */
  184. UNUSUAL_DEV( 0x0421, 0x047c, 0x0370, 0x0610,
  185. "Nokia",
  186. "6131",
  187. US_SC_DEVICE, US_PR_DEVICE, NULL,
  188. US_FL_MAX_SECTORS_64 ),
  189. /* Reported by Manuel Osdoba <manuel.osdoba@tu-ilmenau.de> */
  190. UNUSUAL_DEV( 0x0421, 0x0492, 0x0452, 0x0452,
  191. "Nokia",
  192. "Nokia 6233",
  193. US_SC_DEVICE, US_PR_DEVICE, NULL,
  194. US_FL_MAX_SECTORS_64 ),
  195. /* Reported by Alex Corcoles <alex@corcoles.net> */
  196. UNUSUAL_DEV( 0x0421, 0x0495, 0x0370, 0x0370,
  197. "Nokia",
  198. "6234",
  199. US_SC_DEVICE, US_PR_DEVICE, NULL,
  200. US_FL_MAX_SECTORS_64 ),
  201. /* Reported by Olaf Hering <olh@suse.de> from novell bug #105878 */
  202. UNUSUAL_DEV( 0x0424, 0x0fdc, 0x0210, 0x0210,
  203. "SMSC",
  204. "FDC GOLD-2.30",
  205. US_SC_DEVICE, US_PR_DEVICE, NULL,
  206. US_FL_SINGLE_LUN ),
  207. #ifdef CONFIG_USB_STORAGE_DPCM
  208. UNUSUAL_DEV( 0x0436, 0x0005, 0x0100, 0x0100,
  209. "Microtech",
  210. "CameraMate (DPCM_USB)",
  211. US_SC_SCSI, US_PR_DPCM_USB, NULL, 0 ),
  212. #endif
  213. /* Patch submitted by Daniel Drake <dsd@gentoo.org>
  214. * Device reports nonsense bInterfaceProtocol 6 when connected over USB2 */
  215. UNUSUAL_DEV( 0x0451, 0x5416, 0x0100, 0x0100,
  216. "Neuros Audio",
  217. "USB 2.0 HD 2.5",
  218. US_SC_DEVICE, US_PR_BULK, NULL,
  219. US_FL_NEED_OVERRIDE ),
  220. /*
  221. * Pete Zaitcev <zaitcev@yahoo.com>, from Patrick C. F. Ernzer, bz#162559.
  222. * The key does not actually break, but it returns zero sense which
  223. * makes our SCSI stack to print confusing messages.
  224. */
  225. UNUSUAL_DEV( 0x0457, 0x0150, 0x0100, 0x0100,
  226. "USBest Technology", /* sold by Transcend */
  227. "USB Mass Storage Device",
  228. US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_NOT_LOCKABLE ),
  229. /*
  230. * Bohdan Linda <bohdan.linda@gmail.com>
  231. * 1GB USB sticks MyFlash High Speed. I have restricted
  232. * the revision to my model only
  233. */
  234. UNUSUAL_DEV( 0x0457, 0x0151, 0x0100, 0x0100,
  235. "USB 2.0",
  236. "Flash Disk",
  237. US_SC_DEVICE, US_PR_DEVICE, NULL,
  238. US_FL_NOT_LOCKABLE ),
  239. #ifdef CONFIG_USB_STORAGE_KARMA
  240. UNUSUAL_DEV( 0x045a, 0x5210, 0x0101, 0x0101,
  241. "Rio",
  242. "Rio Karma",
  243. US_SC_SCSI, US_PR_KARMA, rio_karma_init, 0),
  244. #endif
  245. /*
  246. * This virtual floppy is found in Sun equipment (x4600, x4200m2, etc.)
  247. * Reported by Pete Zaitcev <zaitcev@redhat.com>
  248. * This device chokes on both version of MODE SENSE which we have, so
  249. * use_10_for_ms is not effective, and we use US_FL_NO_WP_DETECT.
  250. */
  251. UNUSUAL_DEV( 0x046b, 0xff40, 0x0100, 0x0100,
  252. "AMI",
  253. "Virtual Floppy",
  254. US_SC_DEVICE, US_PR_DEVICE, NULL,
  255. US_FL_NO_WP_DETECT),
  256. /* Patch submitted by Philipp Friedrich <philipp@void.at> */
  257. UNUSUAL_DEV( 0x0482, 0x0100, 0x0100, 0x0100,
  258. "Kyocera",
  259. "Finecam S3x",
  260. US_SC_8070, US_PR_CB, NULL, US_FL_FIX_INQUIRY),
  261. /* Patch submitted by Philipp Friedrich <philipp@void.at> */
  262. UNUSUAL_DEV( 0x0482, 0x0101, 0x0100, 0x0100,
  263. "Kyocera",
  264. "Finecam S4",
  265. US_SC_8070, US_PR_CB, NULL, US_FL_FIX_INQUIRY),
  266. /* Patch submitted by Stephane Galles <stephane.galles@free.fr> */
  267. UNUSUAL_DEV( 0x0482, 0x0103, 0x0100, 0x0100,
  268. "Kyocera",
  269. "Finecam S5",
  270. US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_FIX_INQUIRY),
  271. /* Reported by Paul Stewart <stewart@wetlogic.net>
  272. * This entry is needed because the device reports Sub=ff */
  273. UNUSUAL_DEV( 0x04a4, 0x0004, 0x0001, 0x0001,
  274. "Hitachi",
  275. "DVD-CAM DZ-MV100A Camcorder",
  276. US_SC_SCSI, US_PR_CB, NULL, US_FL_SINGLE_LUN),
  277. /* Patch for Nikon coolpix 2000
  278. * Submitted by Fabien Cosse <fabien.cosse@wanadoo.fr>*/
  279. UNUSUAL_DEV( 0x04b0, 0x0301, 0x0010, 0x0010,
  280. "NIKON",
  281. "NIKON DSC E2000",
  282. US_SC_DEVICE, US_PR_DEVICE,NULL,
  283. US_FL_NOT_LOCKABLE ),
  284. /* Reported by Stefan de Konink <skinkie@xs4all.nl> */
  285. UNUSUAL_DEV( 0x04b0, 0x0401, 0x0200, 0x0200,
  286. "NIKON",
  287. "NIKON DSC D100",
  288. US_SC_DEVICE, US_PR_DEVICE, NULL,
  289. US_FL_FIX_CAPACITY),
  290. /* Reported by Milinevsky Dmitry <niam.niam@gmail.com> */
  291. UNUSUAL_DEV( 0x04b0, 0x0409, 0x0100, 0x0100,
  292. "NIKON",
  293. "NIKON DSC D50",
  294. US_SC_DEVICE, US_PR_DEVICE, NULL,
  295. US_FL_FIX_CAPACITY),
  296. /* Reported by Andreas Bockhold <andreas@bockionline.de> */
  297. UNUSUAL_DEV( 0x04b0, 0x0405, 0x0100, 0x0100,
  298. "NIKON",
  299. "NIKON DSC D70",
  300. US_SC_DEVICE, US_PR_DEVICE, NULL,
  301. US_FL_FIX_CAPACITY),
  302. /* Reported by Jamie Kitson <jamie@staberinde.fsnet.co.uk> */
  303. UNUSUAL_DEV( 0x04b0, 0x040d, 0x0100, 0x0100,
  304. "NIKON",
  305. "NIKON DSC D70s",
  306. US_SC_DEVICE, US_PR_DEVICE, NULL,
  307. US_FL_FIX_CAPACITY),
  308. /* Reported by Graber and Mike Pagano <mpagano-kernel@mpagano.com> */
  309. UNUSUAL_DEV( 0x04b0, 0x040f, 0x0100, 0x0200,
  310. "NIKON",
  311. "NIKON DSC D200",
  312. US_SC_DEVICE, US_PR_DEVICE, NULL,
  313. US_FL_FIX_CAPACITY),
  314. /* Reported by Emil Larsson <emil@swip.net> */
  315. UNUSUAL_DEV( 0x04b0, 0x0411, 0x0100, 0x0110,
  316. "NIKON",
  317. "NIKON DSC D80",
  318. US_SC_DEVICE, US_PR_DEVICE, NULL,
  319. US_FL_FIX_CAPACITY),
  320. /* Reported by Ortwin Glueck <odi@odi.ch> */
  321. UNUSUAL_DEV( 0x04b0, 0x0413, 0x0110, 0x0110,
  322. "NIKON",
  323. "NIKON DSC D40",
  324. US_SC_DEVICE, US_PR_DEVICE, NULL,
  325. US_FL_FIX_CAPACITY),
  326. /* Reported by Paul Check <paul@openstreet.com> */
  327. UNUSUAL_DEV( 0x04b0, 0x0415, 0x0100, 0x0100,
  328. "NIKON",
  329. "NIKON DSC D2Xs",
  330. US_SC_DEVICE, US_PR_DEVICE, NULL,
  331. US_FL_FIX_CAPACITY),
  332. /* Reported by Shan Destromp (shansan@gmail.com) */
  333. UNUSUAL_DEV( 0x04b0, 0x0417, 0x0100, 0x0100,
  334. "NIKON",
  335. "NIKON DSC D40X",
  336. US_SC_DEVICE, US_PR_DEVICE, NULL,
  337. US_FL_FIX_CAPACITY),
  338. /* Reported by Doug Maxey (dwm@austin.ibm.com) */
  339. UNUSUAL_DEV( 0x04b3, 0x4001, 0x0110, 0x0110,
  340. "IBM",
  341. "IBM RSA2",
  342. US_SC_DEVICE, US_PR_CB, NULL,
  343. US_FL_MAX_SECTORS_MIN),
  344. /* BENQ DC5330
  345. * Reported by Manuel Fombuena <mfombuena@ya.com> and
  346. * Frank Copeland <fjc@thingy.apana.org.au> */
  347. UNUSUAL_DEV( 0x04a5, 0x3010, 0x0100, 0x0100,
  348. "Tekom Technologies, Inc",
  349. "300_CAMERA",
  350. US_SC_DEVICE, US_PR_DEVICE, NULL,
  351. US_FL_IGNORE_RESIDUE ),
  352. /* Reported by Simon Levitt <simon@whattf.com>
  353. * This entry needs Sub and Proto fields */
  354. UNUSUAL_DEV( 0x04b8, 0x0601, 0x0100, 0x0100,
  355. "Epson",
  356. "875DC Storage",
  357. US_SC_SCSI, US_PR_CB, NULL, US_FL_FIX_INQUIRY),
  358. /* Reported by Khalid Aziz <khalid@gonehiking.org>
  359. * This entry is needed because the device reports Sub=ff */
  360. UNUSUAL_DEV( 0x04b8, 0x0602, 0x0110, 0x0110,
  361. "Epson",
  362. "785EPX Storage",
  363. US_SC_SCSI, US_PR_BULK, NULL, US_FL_SINGLE_LUN),
  364. /* Not sure who reported this originally but
  365. * Pavel Machek <pavel@ucw.cz> reported that the extra US_FL_SINGLE_LUN
  366. * flag be added */
  367. UNUSUAL_DEV( 0x04cb, 0x0100, 0x0000, 0x2210,
  368. "Fujifilm",
  369. "FinePix 1400Zoom",
  370. US_SC_UFI, US_PR_DEVICE, NULL, US_FL_FIX_INQUIRY | US_FL_SINGLE_LUN),
  371. /* Reported by Peter Wächtler <pwaechtler@loewe-komp.de>
  372. * The device needs the flags only.
  373. */
  374. UNUSUAL_DEV( 0x04ce, 0x0002, 0x0074, 0x0074,
  375. "ScanLogic",
  376. "SL11R-IDE",
  377. US_SC_DEVICE, US_PR_DEVICE, NULL,
  378. US_FL_FIX_INQUIRY),
  379. /* Reported by Kriston Fincher <kriston@airmail.net>
  380. * Patch submitted by Sean Millichamp <sean@bruenor.org>
  381. * This is to support the Panasonic PalmCam PV-SD4090
  382. * This entry is needed because the device reports Sub=ff
  383. */
  384. UNUSUAL_DEV( 0x04da, 0x0901, 0x0100, 0x0200,
  385. "Panasonic",
  386. "LS-120 Camera",
  387. US_SC_UFI, US_PR_DEVICE, NULL, 0),
  388. /* From Yukihiro Nakai, via zaitcev@yahoo.com.
  389. * This is needed for CB instead of CBI */
  390. UNUSUAL_DEV( 0x04da, 0x0d05, 0x0000, 0x0000,
  391. "Sharp CE-CW05",
  392. "CD-R/RW Drive",
  393. US_SC_8070, US_PR_CB, NULL, 0),
  394. /* Reported by Adriaan Penning <a.penning@luon.net> */
  395. UNUSUAL_DEV( 0x04da, 0x2372, 0x0000, 0x9999,
  396. "Panasonic",
  397. "DMC-LCx Camera",
  398. US_SC_DEVICE, US_PR_DEVICE, NULL,
  399. US_FL_FIX_CAPACITY | US_FL_NOT_LOCKABLE ),
  400. /* Reported by Simeon Simeonov <simeonov_2000@yahoo.com> */
  401. UNUSUAL_DEV( 0x04da, 0x2373, 0x0000, 0x9999,
  402. "LEICA",
  403. "D-LUX Camera",
  404. US_SC_DEVICE, US_PR_DEVICE, NULL,
  405. US_FL_FIX_CAPACITY | US_FL_NOT_LOCKABLE ),
  406. /* Most of the following entries were developed with the help of
  407. * Shuttle/SCM directly.
  408. */
  409. UNUSUAL_DEV( 0x04e6, 0x0001, 0x0200, 0x0200,
  410. "Matshita",
  411. "LS-120",
  412. US_SC_8020, US_PR_CB, NULL, 0),
  413. UNUSUAL_DEV( 0x04e6, 0x0002, 0x0100, 0x0100,
  414. "Shuttle",
  415. "eUSCSI Bridge",
  416. US_SC_DEVICE, US_PR_DEVICE, usb_stor_euscsi_init,
  417. US_FL_SCM_MULT_TARG ),
  418. #ifdef CONFIG_USB_STORAGE_SDDR09
  419. UNUSUAL_DEV( 0x04e6, 0x0003, 0x0000, 0x9999,
  420. "Sandisk",
  421. "ImageMate SDDR09",
  422. US_SC_SCSI, US_PR_EUSB_SDDR09, usb_stor_sddr09_init,
  423. 0),
  424. /* This entry is from Andries.Brouwer@cwi.nl */
  425. UNUSUAL_DEV( 0x04e6, 0x0005, 0x0100, 0x0208,
  426. "SCM Microsystems",
  427. "eUSB SmartMedia / CompactFlash Adapter",
  428. US_SC_SCSI, US_PR_DPCM_USB, usb_stor_sddr09_dpcm_init,
  429. 0),
  430. #endif
  431. /* Reported by Markus Demleitner <msdemlei@cl.uni-heidelberg.de> */
  432. UNUSUAL_DEV( 0x04e6, 0x0006, 0x0100, 0x0100,
  433. "SCM Microsystems Inc.",
  434. "eUSB MMC Adapter",
  435. US_SC_SCSI, US_PR_CB, NULL,
  436. US_FL_SINGLE_LUN),
  437. /* Reported by Daniel Nouri <dpunktnpunkt@web.de> */
  438. UNUSUAL_DEV( 0x04e6, 0x0006, 0x0205, 0x0205,
  439. "Shuttle",
  440. "eUSB MMC Adapter",
  441. US_SC_SCSI, US_PR_DEVICE, NULL,
  442. US_FL_SINGLE_LUN),
  443. UNUSUAL_DEV( 0x04e6, 0x0007, 0x0100, 0x0200,
  444. "Sony",
  445. "Hifd",
  446. US_SC_SCSI, US_PR_CB, NULL,
  447. US_FL_SINGLE_LUN),
  448. UNUSUAL_DEV( 0x04e6, 0x0009, 0x0200, 0x0200,
  449. "Shuttle",
  450. "eUSB ATA/ATAPI Adapter",
  451. US_SC_8020, US_PR_CB, NULL, 0),
  452. UNUSUAL_DEV( 0x04e6, 0x000a, 0x0200, 0x0200,
  453. "Shuttle",
  454. "eUSB CompactFlash Adapter",
  455. US_SC_8020, US_PR_CB, NULL, 0),
  456. UNUSUAL_DEV( 0x04e6, 0x000B, 0x0100, 0x0100,
  457. "Shuttle",
  458. "eUSCSI Bridge",
  459. US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
  460. US_FL_SCM_MULT_TARG ),
  461. UNUSUAL_DEV( 0x04e6, 0x000C, 0x0100, 0x0100,
  462. "Shuttle",
  463. "eUSCSI Bridge",
  464. US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
  465. US_FL_SCM_MULT_TARG ),
  466. UNUSUAL_DEV( 0x04e6, 0x0101, 0x0200, 0x0200,
  467. "Shuttle",
  468. "CD-RW Device",
  469. US_SC_8020, US_PR_CB, NULL, 0),
  470. /* Entry and supporting patch by Theodore Kilgore <kilgota@auburn.edu>.
  471. * Device uses standards-violating 32-byte Bulk Command Block Wrappers and
  472. * reports itself as "Proprietary SCSI Bulk." Cf. device entry 0x084d:0x0011.
  473. */
  474. UNUSUAL_DEV( 0x04fc, 0x80c2, 0x0100, 0x0100,
  475. "Kobian Mercury",
  476. "Binocam DCB-132",
  477. US_SC_DEVICE, US_PR_DEVICE, NULL,
  478. US_FL_BULK32),
  479. #ifdef CONFIG_USB_STORAGE_USBAT
  480. UNUSUAL_DEV( 0x04e6, 0x1010, 0x0000, 0x9999,
  481. "Shuttle/SCM",
  482. "USBAT-02",
  483. US_SC_SCSI, US_PR_USBAT, init_usbat_flash,
  484. US_FL_SINGLE_LUN),
  485. #endif
  486. /* Reported by Dmitry Khlystov <adminimus@gmail.com> */
  487. UNUSUAL_DEV( 0x04e8, 0x507c, 0x0220, 0x0220,
  488. "Samsung",
  489. "YP-U3",
  490. US_SC_DEVICE, US_PR_DEVICE, NULL,
  491. US_FL_MAX_SECTORS_64),
  492. /* Reported by Bob Sass <rls@vectordb.com> -- only rev 1.33 tested */
  493. UNUSUAL_DEV( 0x050d, 0x0115, 0x0133, 0x0133,
  494. "Belkin",
  495. "USB SCSI Adaptor",
  496. US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
  497. US_FL_SCM_MULT_TARG ),
  498. /* Iomega Clik! Drive
  499. * Reported by David Chatenay <dchatenay@hotmail.com>
  500. * The reason this is needed is not fully known.
  501. */
  502. UNUSUAL_DEV( 0x0525, 0xa140, 0x0100, 0x0100,
  503. "Iomega",
  504. "USB Clik! 40",
  505. US_SC_8070, US_PR_DEVICE, NULL,
  506. US_FL_FIX_INQUIRY ),
  507. /* Yakumo Mega Image 37
  508. * Submitted by Stephan Fuhrmann <atomenergie@t-online.de> */
  509. UNUSUAL_DEV( 0x052b, 0x1801, 0x0100, 0x0100,
  510. "Tekom Technologies, Inc",
  511. "300_CAMERA",
  512. US_SC_DEVICE, US_PR_DEVICE, NULL,
  513. US_FL_IGNORE_RESIDUE ),
  514. /* Another Yakumo camera.
  515. * Reported by Michele Alzetta <michele.alzetta@aliceposta.it> */
  516. UNUSUAL_DEV( 0x052b, 0x1804, 0x0100, 0x0100,
  517. "Tekom Technologies, Inc",
  518. "300_CAMERA",
  519. US_SC_DEVICE, US_PR_DEVICE, NULL,
  520. US_FL_IGNORE_RESIDUE ),
  521. /* Reported by Iacopo Spalletti <avvisi@spalletti.it> */
  522. UNUSUAL_DEV( 0x052b, 0x1807, 0x0100, 0x0100,
  523. "Tekom Technologies, Inc",
  524. "300_CAMERA",
  525. US_SC_DEVICE, US_PR_DEVICE, NULL,
  526. US_FL_IGNORE_RESIDUE ),
  527. /* Yakumo Mega Image 47
  528. * Reported by Bjoern Paetzel <kolrabi@kolrabi.de> */
  529. UNUSUAL_DEV( 0x052b, 0x1905, 0x0100, 0x0100,
  530. "Tekom Technologies, Inc",
  531. "400_CAMERA",
  532. US_SC_DEVICE, US_PR_DEVICE, NULL,
  533. US_FL_IGNORE_RESIDUE ),
  534. /* Reported by Paul Ortyl <ortylp@3miasto.net>
  535. * Note that it's similar to the device above, only different prodID */
  536. UNUSUAL_DEV( 0x052b, 0x1911, 0x0100, 0x0100,
  537. "Tekom Technologies, Inc",
  538. "400_CAMERA",
  539. US_SC_DEVICE, US_PR_DEVICE, NULL,
  540. US_FL_IGNORE_RESIDUE ),
  541. UNUSUAL_DEV( 0x054c, 0x0010, 0x0106, 0x0450,
  542. "Sony",
  543. "DSC-S30/S70/S75/505V/F505/F707/F717/P8",
  544. US_SC_SCSI, US_PR_DEVICE, NULL,
  545. US_FL_SINGLE_LUN | US_FL_NOT_LOCKABLE | US_FL_NO_WP_DETECT ),
  546. /* Submitted by Lars Jacob <jacob.lars@googlemail.com>
  547. * This entry is needed because the device reports Sub=ff */
  548. UNUSUAL_DEV( 0x054c, 0x0010, 0x0500, 0x0610,
  549. "Sony",
  550. "DSC-T1/T5/H5",
  551. US_SC_8070, US_PR_DEVICE, NULL,
  552. US_FL_SINGLE_LUN ),
  553. /* Reported by wim@geeks.nl */
  554. UNUSUAL_DEV( 0x054c, 0x0025, 0x0100, 0x0100,
  555. "Sony",
  556. "Memorystick NW-MS7",
  557. US_SC_DEVICE, US_PR_DEVICE, NULL,
  558. US_FL_SINGLE_LUN ),
  559. #ifdef CONFIG_USB_STORAGE_ISD200
  560. UNUSUAL_DEV( 0x054c, 0x002b, 0x0100, 0x0110,
  561. "Sony",
  562. "Portable USB Harddrive V2",
  563. US_SC_ISD200, US_PR_BULK, isd200_Initialization,
  564. 0 ),
  565. #endif
  566. /* Submitted by Olaf Hering, <olh@suse.de> SuSE Bugzilla #49049 */
  567. UNUSUAL_DEV( 0x054c, 0x002c, 0x0501, 0x2000,
  568. "Sony",
  569. "USB Floppy Drive",
  570. US_SC_DEVICE, US_PR_DEVICE, NULL,
  571. US_FL_SINGLE_LUN ),
  572. UNUSUAL_DEV( 0x054c, 0x002d, 0x0100, 0x0100,
  573. "Sony",
  574. "Memorystick MSAC-US1",
  575. US_SC_DEVICE, US_PR_DEVICE, NULL,
  576. US_FL_SINGLE_LUN ),
  577. /* Submitted by Klaus Mueller <k.mueller@intershop.de> */
  578. UNUSUAL_DEV( 0x054c, 0x002e, 0x0106, 0x0310,
  579. "Sony",
  580. "Handycam",
  581. US_SC_SCSI, US_PR_DEVICE, NULL,
  582. US_FL_SINGLE_LUN ),
  583. /* Submitted by Rajesh Kumble Nayak <nayak@obs-nice.fr> */
  584. UNUSUAL_DEV( 0x054c, 0x002e, 0x0500, 0x0500,
  585. "Sony",
  586. "Handycam HC-85",
  587. US_SC_UFI, US_PR_DEVICE, NULL,
  588. US_FL_SINGLE_LUN ),
  589. UNUSUAL_DEV( 0x054c, 0x0032, 0x0000, 0x9999,
  590. "Sony",
  591. "Memorystick MSC-U01N",
  592. US_SC_DEVICE, US_PR_DEVICE, NULL,
  593. US_FL_SINGLE_LUN ),
  594. /* Submitted by Michal Mlotek <mlotek@foobar.pl> */
  595. UNUSUAL_DEV( 0x054c, 0x0058, 0x0000, 0x9999,
  596. "Sony",
  597. "PEG N760c Memorystick",
  598. US_SC_DEVICE, US_PR_DEVICE, NULL,
  599. US_FL_FIX_INQUIRY ),
  600. UNUSUAL_DEV( 0x054c, 0x0069, 0x0000, 0x9999,
  601. "Sony",
  602. "Memorystick MSC-U03",
  603. US_SC_UFI, US_PR_CB, NULL,
  604. US_FL_SINGLE_LUN ),
  605. /* Submitted by Nathan Babb <nathan@lexi.com> */
  606. UNUSUAL_DEV( 0x054c, 0x006d, 0x0000, 0x9999,
  607. "Sony",
  608. "PEG Mass Storage",
  609. US_SC_DEVICE, US_PR_DEVICE, NULL,
  610. US_FL_FIX_INQUIRY ),
  611. /* Submitted by Mike Alborn <malborn@deandra.homeip.net> */
  612. UNUSUAL_DEV( 0x054c, 0x016a, 0x0000, 0x9999,
  613. "Sony",
  614. "PEG Mass Storage",
  615. US_SC_DEVICE, US_PR_DEVICE, NULL,
  616. US_FL_FIX_INQUIRY ),
  617. /* Submitted by Frank Engel <frankie@cse.unsw.edu.au> */
  618. UNUSUAL_DEV( 0x054c, 0x0099, 0x0000, 0x9999,
  619. "Sony",
  620. "PEG Mass Storage",
  621. US_SC_DEVICE, US_PR_DEVICE, NULL,
  622. US_FL_FIX_INQUIRY ),
  623. /* floppy reports multiple luns */
  624. UNUSUAL_DEV( 0x055d, 0x2020, 0x0000, 0x0210,
  625. "SAMSUNG",
  626. "SFD-321U [FW 0C]",
  627. US_SC_DEVICE, US_PR_DEVICE, NULL,
  628. US_FL_SINGLE_LUN ),
  629. UNUSUAL_DEV( 0x057b, 0x0000, 0x0000, 0x0299,
  630. "Y-E Data",
  631. "Flashbuster-U",
  632. US_SC_DEVICE, US_PR_CB, NULL,
  633. US_FL_SINGLE_LUN),
  634. UNUSUAL_DEV( 0x057b, 0x0000, 0x0300, 0x9999,
  635. "Y-E Data",
  636. "Flashbuster-U",
  637. US_SC_DEVICE, US_PR_DEVICE, NULL,
  638. US_FL_SINGLE_LUN),
  639. /* Reported by Johann Cardon <johann.cardon@free.fr>
  640. * This entry is needed only because the device reports
  641. * bInterfaceClass = 0xff (vendor-specific)
  642. */
  643. UNUSUAL_DEV( 0x057b, 0x0022, 0x0000, 0x9999,
  644. "Y-E Data",
  645. "Silicon Media R/W",
  646. US_SC_DEVICE, US_PR_DEVICE, NULL, 0),
  647. #ifdef CONFIG_USB_STORAGE_ALAUDA
  648. UNUSUAL_DEV( 0x0584, 0x0008, 0x0102, 0x0102,
  649. "Fujifilm",
  650. "DPC-R1 (Alauda)",
  651. US_SC_SCSI, US_PR_ALAUDA, init_alauda, 0 ),
  652. #endif
  653. /* Reported by RTE <raszilki@yandex.ru> */
  654. UNUSUAL_DEV( 0x058f, 0x6387, 0x0141, 0x0141,
  655. "JetFlash",
  656. "TS1GJF2A/120",
  657. US_SC_DEVICE, US_PR_DEVICE, NULL,
  658. US_FL_MAX_SECTORS_64 ),
  659. /* Fabrizio Fellini <fello@libero.it> */
  660. UNUSUAL_DEV( 0x0595, 0x4343, 0x0000, 0x2210,
  661. "Fujifilm",
  662. "Digital Camera EX-20 DSC",
  663. US_SC_8070, US_PR_DEVICE, NULL, 0 ),
  664. /* Reported by Andre Welter <a.r.welter@gmx.de>
  665. * This antique device predates the release of the Bulk-only Transport
  666. * spec, and if it gets a Get-Max-LUN then it requires the host to do a
  667. * Clear-Halt on the bulk endpoints. The SINGLE_LUN flag will prevent
  668. * us from sending the request.
  669. */
  670. UNUSUAL_DEV( 0x059b, 0x0001, 0x0100, 0x0100,
  671. "Iomega",
  672. "ZIP 100",
  673. US_SC_DEVICE, US_PR_DEVICE, NULL,
  674. US_FL_SINGLE_LUN ),
  675. /* Reported by <Hendryk.Pfeiffer@gmx.de> */
  676. UNUSUAL_DEV( 0x059f, 0x0643, 0x0000, 0x0000,
  677. "LaCie",
  678. "DVD+-RW",
  679. US_SC_DEVICE, US_PR_DEVICE, NULL,
  680. US_FL_GO_SLOW ),
  681. /* Submitted by Joel Bourquard <numlock@freesurf.ch>
  682. * Some versions of this device need the SubClass and Protocol overrides
  683. * while others don't.
  684. */
  685. UNUSUAL_DEV( 0x05ab, 0x0060, 0x1104, 0x1110,
  686. "In-System",
  687. "PyroGate External CD-ROM Enclosure (FCD-523)",
  688. US_SC_SCSI, US_PR_BULK, NULL,
  689. US_FL_NEED_OVERRIDE ),
  690. #ifdef CONFIG_USB_STORAGE_ISD200
  691. UNUSUAL_DEV( 0x05ab, 0x0031, 0x0100, 0x0110,
  692. "In-System",
  693. "USB/IDE Bridge (ATA/ATAPI)",
  694. US_SC_ISD200, US_PR_BULK, isd200_Initialization,
  695. 0 ),
  696. UNUSUAL_DEV( 0x05ab, 0x0301, 0x0100, 0x0110,
  697. "In-System",
  698. "Portable USB Harddrive V2",
  699. US_SC_ISD200, US_PR_BULK, isd200_Initialization,
  700. 0 ),
  701. UNUSUAL_DEV( 0x05ab, 0x0351, 0x0100, 0x0110,
  702. "In-System",
  703. "Portable USB Harddrive V2",
  704. US_SC_ISD200, US_PR_BULK, isd200_Initialization,
  705. 0 ),
  706. UNUSUAL_DEV( 0x05ab, 0x5701, 0x0100, 0x0110,
  707. "In-System",
  708. "USB Storage Adapter V2",
  709. US_SC_ISD200, US_PR_BULK, isd200_Initialization,
  710. 0 ),
  711. #endif
  712. /* Submitted by Sven Anderson <sven-linux@anderson.de>
  713. * There are at least four ProductIDs used for iPods, so I added 0x1202 and
  714. * 0x1204. They just need the US_FL_FIX_CAPACITY. As the bcdDevice appears
  715. * to change with firmware updates, I changed the range to maximum for all
  716. * iPod entries.
  717. */
  718. UNUSUAL_DEV( 0x05ac, 0x1202, 0x0000, 0x9999,
  719. "Apple",
  720. "iPod",
  721. US_SC_DEVICE, US_PR_DEVICE, NULL,
  722. US_FL_FIX_CAPACITY ),
  723. /* Reported by Avi Kivity <avi@argo.co.il> */
  724. UNUSUAL_DEV( 0x05ac, 0x1203, 0x0000, 0x9999,
  725. "Apple",
  726. "iPod",
  727. US_SC_DEVICE, US_PR_DEVICE, NULL,
  728. US_FL_FIX_CAPACITY ),
  729. UNUSUAL_DEV( 0x05ac, 0x1204, 0x0000, 0x9999,
  730. "Apple",
  731. "iPod",
  732. US_SC_DEVICE, US_PR_DEVICE, NULL,
  733. US_FL_FIX_CAPACITY | US_FL_NOT_LOCKABLE ),
  734. UNUSUAL_DEV( 0x05ac, 0x1205, 0x0000, 0x9999,
  735. "Apple",
  736. "iPod",
  737. US_SC_DEVICE, US_PR_DEVICE, NULL,
  738. US_FL_FIX_CAPACITY ),
  739. /*
  740. * Reported by Tyson Vinson <lornoss@gmail.com>
  741. * This particular productId is the iPod Nano
  742. */
  743. UNUSUAL_DEV( 0x05ac, 0x120a, 0x0000, 0x9999,
  744. "Apple",
  745. "iPod",
  746. US_SC_DEVICE, US_PR_DEVICE, NULL,
  747. US_FL_FIX_CAPACITY ),
  748. #ifdef CONFIG_USB_STORAGE_JUMPSHOT
  749. UNUSUAL_DEV( 0x05dc, 0x0001, 0x0000, 0x0001,
  750. "Lexar",
  751. "Jumpshot USB CF Reader",
  752. US_SC_SCSI, US_PR_JUMPSHOT, NULL,
  753. US_FL_NEED_OVERRIDE ),
  754. #endif
  755. /* Reported by Blake Matheny <bmatheny@purdue.edu> */
  756. UNUSUAL_DEV( 0x05dc, 0xb002, 0x0000, 0x0113,
  757. "Lexar",
  758. "USB CF Reader",
  759. US_SC_DEVICE, US_PR_DEVICE, NULL,
  760. US_FL_FIX_INQUIRY ),
  761. /* The following two entries are for a Genesys USB to IDE
  762. * converter chip, but it changes its ProductId depending
  763. * on whether or not a disk or an optical device is enclosed
  764. * They were originally reported by Alexander Oltu
  765. * <alexander@all-2.com> and Peter Marks <peter.marks@turner.com>
  766. * respectively.
  767. *
  768. * US_FL_GO_SLOW and US_FL_MAX_SECTORS_64 added by Phil Dibowitz
  769. * <phil@ipom.com> as these flags were made and hard-coded
  770. * special-cases were pulled from scsiglue.c.
  771. */
  772. UNUSUAL_DEV( 0x05e3, 0x0701, 0x0000, 0xffff,
  773. "Genesys Logic",
  774. "USB to IDE Optical",
  775. US_SC_DEVICE, US_PR_DEVICE, NULL,
  776. US_FL_GO_SLOW | US_FL_MAX_SECTORS_64 ),
  777. UNUSUAL_DEV( 0x05e3, 0x0702, 0x0000, 0xffff,
  778. "Genesys Logic",
  779. "USB to IDE Disk",
  780. US_SC_DEVICE, US_PR_DEVICE, NULL,
  781. US_FL_GO_SLOW | US_FL_MAX_SECTORS_64 ),
  782. /* Reported by Hanno Boeck <hanno@gmx.de>
  783. * Taken from the Lycoris Kernel */
  784. UNUSUAL_DEV( 0x0636, 0x0003, 0x0000, 0x9999,
  785. "Vivitar",
  786. "Vivicam 35Xx",
  787. US_SC_SCSI, US_PR_BULK, NULL,
  788. US_FL_FIX_INQUIRY ),
  789. UNUSUAL_DEV( 0x0644, 0x0000, 0x0100, 0x0100,
  790. "TEAC",
  791. "Floppy Drive",
  792. US_SC_UFI, US_PR_CB, NULL, 0 ),
  793. #ifdef CONFIG_USB_STORAGE_SDDR09
  794. UNUSUAL_DEV( 0x066b, 0x0105, 0x0100, 0x0100,
  795. "Olympus",
  796. "Camedia MAUSB-2",
  797. US_SC_SCSI, US_PR_EUSB_SDDR09, usb_stor_sddr09_init,
  798. 0),
  799. #endif
  800. /* Reported by Darsen Lu <darsen@micro.ee.nthu.edu.tw> */
  801. UNUSUAL_DEV( 0x066f, 0x8000, 0x0001, 0x0001,
  802. "SigmaTel",
  803. "USBMSC Audio Player",
  804. US_SC_DEVICE, US_PR_DEVICE, NULL,
  805. US_FL_FIX_CAPACITY ),
  806. /* Reported by Richard -=[]=- <micro_flyer@hotmail.com> */
  807. UNUSUAL_DEV( 0x067b, 0x2507, 0x0100, 0x0100,
  808. "Prolific Technology Inc.",
  809. "Mass Storage Device",
  810. US_SC_DEVICE, US_PR_DEVICE, NULL,
  811. US_FL_FIX_CAPACITY | US_FL_GO_SLOW ),
  812. /* Reported by Alex Butcher <alex.butcher@assursys.co.uk> */
  813. UNUSUAL_DEV( 0x067b, 0x3507, 0x0001, 0x0001,
  814. "Prolific Technology Inc.",
  815. "ATAPI-6 Bridge Controller",
  816. US_SC_DEVICE, US_PR_DEVICE, NULL,
  817. US_FL_FIX_CAPACITY | US_FL_GO_SLOW ),
  818. /* Submitted by Benny Sjostrand <benny@hostmobility.com> */
  819. UNUSUAL_DEV( 0x0686, 0x4011, 0x0001, 0x0001,
  820. "Minolta",
  821. "Dimage F300",
  822. US_SC_SCSI, US_PR_BULK, NULL, 0 ),
  823. /* Reported by Miguel A. Fosas <amn3s1a@ono.com> */
  824. UNUSUAL_DEV( 0x0686, 0x4017, 0x0001, 0x0001,
  825. "Minolta",
  826. "DIMAGE E223",
  827. US_SC_SCSI, US_PR_DEVICE, NULL, 0 ),
  828. UNUSUAL_DEV( 0x0693, 0x0005, 0x0100, 0x0100,
  829. "Hagiwara",
  830. "Flashgate",
  831. US_SC_SCSI, US_PR_BULK, NULL, 0 ),
  832. /* Reported by David Hamilton <niftimusmaximus@lycos.com> */
  833. UNUSUAL_DEV( 0x069b, 0x3004, 0x0001, 0x0001,
  834. "Thomson Multimedia Inc.",
  835. "RCA RD1080 MP3 Player",
  836. US_SC_DEVICE, US_PR_DEVICE, NULL,
  837. US_FL_FIX_CAPACITY ),
  838. /* Reported by Massimiliano Ghilardi <massimiliano.ghilardi@gmail.com>
  839. * This USB MP3/AVI player device fails and disconnects if more than 128
  840. * sectors (64kB) are read/written in a single command, and may be present
  841. * at least in the following products:
  842. * "Magnex Digital Video Panel DVP 1800"
  843. * "MP4 AIGO 4GB SLOT SD"
  844. * "Teclast TL-C260 MP3"
  845. * "i.Meizu PMP MP3/MP4"
  846. * "Speed MV8 MP4 Audio Player"
  847. */
  848. UNUSUAL_DEV( 0x071b, 0x3203, 0x0100, 0x0100,
  849. "RockChip",
  850. "ROCK MP3",
  851. US_SC_DEVICE, US_PR_DEVICE, NULL,
  852. US_FL_MAX_SECTORS_64),
  853. /* Reported by Olivier Blondeau <zeitoun@gmail.com> */
  854. UNUSUAL_DEV( 0x0727, 0x0306, 0x0100, 0x0100,
  855. "ATMEL",
  856. "SND1 Storage",
  857. US_SC_DEVICE, US_PR_DEVICE, NULL,
  858. US_FL_IGNORE_RESIDUE),
  859. /* Submitted by Roman Hodek <roman@hodek.net> */
  860. UNUSUAL_DEV( 0x0781, 0x0001, 0x0200, 0x0200,
  861. "Sandisk",
  862. "ImageMate SDDR-05a",
  863. US_SC_SCSI, US_PR_CB, NULL,
  864. US_FL_SINGLE_LUN ),
  865. UNUSUAL_DEV( 0x0781, 0x0002, 0x0009, 0x0009,
  866. "SanDisk Corporation",
  867. "ImageMate CompactFlash USB",
  868. US_SC_DEVICE, US_PR_DEVICE, NULL,
  869. US_FL_FIX_CAPACITY ),
  870. #ifdef CONFIG_USB_STORAGE_USBAT
  871. UNUSUAL_DEV( 0x0781, 0x0005, 0x0005, 0x0005,
  872. "Sandisk",
  873. "ImageMate SDDR-05b",
  874. US_SC_SCSI, US_PR_USBAT, init_usbat_flash,
  875. US_FL_SINGLE_LUN ),
  876. #endif
  877. UNUSUAL_DEV( 0x0781, 0x0100, 0x0100, 0x0100,
  878. "Sandisk",
  879. "ImageMate SDDR-12",
  880. US_SC_SCSI, US_PR_CB, NULL,
  881. US_FL_SINGLE_LUN ),
  882. #ifdef CONFIG_USB_STORAGE_SDDR09
  883. UNUSUAL_DEV( 0x0781, 0x0200, 0x0000, 0x9999,
  884. "Sandisk",
  885. "ImageMate SDDR-09",
  886. US_SC_SCSI, US_PR_EUSB_SDDR09, usb_stor_sddr09_init,
  887. 0),
  888. #endif
  889. #ifdef CONFIG_USB_STORAGE_FREECOM
  890. UNUSUAL_DEV( 0x07ab, 0xfc01, 0x0000, 0x9999,
  891. "Freecom",
  892. "USB-IDE",
  893. US_SC_QIC, US_PR_FREECOM, freecom_init, 0),
  894. #endif
  895. /* Reported by Eero Volotinen <eero@ping-viini.org> */
  896. UNUSUAL_DEV( 0x07ab, 0xfccd, 0x0000, 0x9999,
  897. "Freecom Technologies",
  898. "FHD-Classic",
  899. US_SC_DEVICE, US_PR_DEVICE, NULL,
  900. US_FL_FIX_CAPACITY),
  901. UNUSUAL_DEV( 0x07af, 0x0004, 0x0100, 0x0133,
  902. "Microtech",
  903. "USB-SCSI-DB25",
  904. US_SC_SCSI, US_PR_BULK, usb_stor_euscsi_init,
  905. US_FL_SCM_MULT_TARG ),
  906. UNUSUAL_DEV( 0x07af, 0x0005, 0x0100, 0x0100,
  907. "Microtech",
  908. "USB-SCSI-HD50",
  909. US_SC_DEVICE, US_PR_DEVICE, usb_stor_euscsi_init,
  910. US_FL_SCM_MULT_TARG ),
  911. #ifdef CONFIG_USB_STORAGE_DPCM
  912. UNUSUAL_DEV( 0x07af, 0x0006, 0x0100, 0x0100,
  913. "Microtech",
  914. "CameraMate (DPCM_USB)",
  915. US_SC_SCSI, US_PR_DPCM_USB, NULL, 0 ),
  916. #endif
  917. #ifdef CONFIG_USB_STORAGE_ALAUDA
  918. UNUSUAL_DEV( 0x07b4, 0x010a, 0x0102, 0x0102,
  919. "Olympus",
  920. "MAUSB-10 (Alauda)",
  921. US_SC_SCSI, US_PR_ALAUDA, init_alauda, 0 ),
  922. #endif
  923. #ifdef CONFIG_USB_STORAGE_DATAFAB
  924. UNUSUAL_DEV( 0x07c4, 0xa000, 0x0000, 0x0015,
  925. "Datafab",
  926. "MDCFE-B USB CF Reader",
  927. US_SC_SCSI, US_PR_DATAFAB, NULL,
  928. 0 ),
  929. /*
  930. * The following Datafab-based devices may or may not work
  931. * using the current driver...the 0xffff is arbitrary since I
  932. * don't know what device versions exist for these guys.
  933. *
  934. * The 0xa003 and 0xa004 devices in particular I'm curious about.
  935. * I'm told they exist but so far nobody has come forward to say that
  936. * they work with this driver. Given the success we've had getting
  937. * other Datafab-based cards operational with this driver, I've decided
  938. * to leave these two devices in the list.
  939. */
  940. UNUSUAL_DEV( 0x07c4, 0xa001, 0x0000, 0xffff,
  941. "SIIG/Datafab",
  942. "SIIG/Datafab Memory Stick+CF Reader/Writer",
  943. US_SC_SCSI, US_PR_DATAFAB, NULL,
  944. 0 ),
  945. /* Reported by Josef Reisinger <josef.reisinger@netcologne.de> */
  946. UNUSUAL_DEV( 0x07c4, 0xa002, 0x0000, 0xffff,
  947. "Datafab/Unknown",
  948. "MD2/MD3 Disk enclosure",
  949. US_SC_SCSI, US_PR_DATAFAB, NULL,
  950. US_FL_SINGLE_LUN ),
  951. UNUSUAL_DEV( 0x07c4, 0xa003, 0x0000, 0xffff,
  952. "Datafab/Unknown",
  953. "Datafab-based Reader",
  954. US_SC_SCSI, US_PR_DATAFAB, NULL,
  955. 0 ),
  956. UNUSUAL_DEV( 0x07c4, 0xa004, 0x0000, 0xffff,
  957. "Datafab/Unknown",
  958. "Datafab-based Reader",
  959. US_SC_SCSI, US_PR_DATAFAB, NULL,
  960. 0 ),
  961. UNUSUAL_DEV( 0x07c4, 0xa005, 0x0000, 0xffff,
  962. "PNY/Datafab",
  963. "PNY/Datafab CF+SM Reader",
  964. US_SC_SCSI, US_PR_DATAFAB, NULL,
  965. 0 ),
  966. UNUSUAL_DEV( 0x07c4, 0xa006, 0x0000, 0xffff,
  967. "Simple Tech/Datafab",
  968. "Simple Tech/Datafab CF+SM Reader",
  969. US_SC_SCSI, US_PR_DATAFAB, NULL,
  970. 0 ),
  971. #endif
  972. #ifdef CONFIG_USB_STORAGE_SDDR55
  973. /* Contributed by Peter Waechtler */
  974. UNUSUAL_DEV( 0x07c4, 0xa103, 0x0000, 0x9999,
  975. "Datafab",
  976. "MDSM-B reader",
  977. US_SC_SCSI, US_PR_SDDR55, NULL,
  978. US_FL_FIX_INQUIRY ),
  979. #endif
  980. #ifdef CONFIG_USB_STORAGE_DATAFAB
  981. /* Submitted by Olaf Hering <olh@suse.de> */
  982. UNUSUAL_DEV( 0x07c4, 0xa109, 0x0000, 0xffff,
  983. "Datafab Systems, Inc.",
  984. "USB to CF + SM Combo (LC1)",
  985. US_SC_SCSI, US_PR_DATAFAB, NULL,
  986. 0 ),
  987. #endif
  988. #ifdef CONFIG_USB_STORAGE_SDDR55
  989. /* SM part - aeb <Andries.Brouwer@cwi.nl> */
  990. UNUSUAL_DEV( 0x07c4, 0xa109, 0x0000, 0xffff,
  991. "Datafab Systems, Inc.",
  992. "USB to CF + SM Combo (LC1)",
  993. US_SC_SCSI, US_PR_SDDR55, NULL,
  994. US_FL_SINGLE_LUN ),
  995. #endif
  996. #ifdef CONFIG_USB_STORAGE_DATAFAB
  997. /* Reported by Felix Moeller <felix@derklecks.de>
  998. * in Germany this is sold by Hama with the productnumber 46952
  999. * as "DualSlot CompactFlash(TM) & MStick Drive USB"
  1000. */
  1001. UNUSUAL_DEV( 0x07c4, 0xa10b, 0x0000, 0xffff,
  1002. "DataFab Systems Inc.",
  1003. "USB CF+MS",
  1004. US_SC_SCSI, US_PR_DATAFAB, NULL,
  1005. 0 ),
  1006. #endif
  1007. /* Datafab KECF-USB / Sagatek DCS-CF / Simpletech Flashlink UCF-100
  1008. * Only revision 1.13 tested (same for all of the above devices,
  1009. * based on the Datafab DF-UG-07 chip). Needed for US_FL_FIX_INQUIRY.
  1010. * Submitted by Marek Michalkiewicz <marekm@amelek.gda.pl>.
  1011. * See also http://martin.wilck.bei.t-online.de/#kecf .
  1012. */
  1013. UNUSUAL_DEV( 0x07c4, 0xa400, 0x0000, 0xffff,
  1014. "Datafab",
  1015. "KECF-USB",
  1016. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1017. US_FL_FIX_INQUIRY ),
  1018. /* Casio QV 2x00/3x00/4000/8000 digital still cameras are not conformant
  1019. * to the USB storage specification in two ways:
  1020. * - They tell us they are using transport protocol CBI. In reality they
  1021. * are using transport protocol CB.
  1022. * - They don't like the INQUIRY command. So we must handle this command
  1023. * of the SCSI layer ourselves.
  1024. * - Some cameras with idProduct=0x1001 and bcdDevice=0x1000 have
  1025. * bInterfaceProtocol=0x00 (US_PR_CBI) while others have 0x01 (US_PR_CB).
  1026. * So don't remove the US_PR_CB override!
  1027. * - Cameras with bcdDevice=0x9009 require the US_SC_8070 override.
  1028. */
  1029. UNUSUAL_DEV( 0x07cf, 0x1001, 0x1000, 0x9999,
  1030. "Casio",
  1031. "QV DigitalCamera",
  1032. US_SC_8070, US_PR_CB, NULL,
  1033. US_FL_NEED_OVERRIDE | US_FL_FIX_INQUIRY ),
  1034. /* Submitted by Hartmut Wahl <hwahl@hwahl.de>*/
  1035. UNUSUAL_DEV( 0x0839, 0x000a, 0x0001, 0x0001,
  1036. "Samsung",
  1037. "Digimax 410",
  1038. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1039. US_FL_FIX_INQUIRY),
  1040. /* Entry and supporting patch by Theodore Kilgore <kilgota@auburn.edu>.
  1041. * Flag will support Bulk devices which use a standards-violating 32-byte
  1042. * Command Block Wrapper. Here, the "DC2MEGA" cameras (several brands) with
  1043. * Grandtech GT892x chip, which request "Proprietary SCSI Bulk" support.
  1044. */
  1045. UNUSUAL_DEV( 0x084d, 0x0011, 0x0110, 0x0110,
  1046. "Grandtech",
  1047. "DC2MEGA",
  1048. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1049. US_FL_BULK32),
  1050. /* Submitted by Jan De Luyck <lkml@kcore.org> */
  1051. UNUSUAL_DEV( 0x08bd, 0x1100, 0x0000, 0x0000,
  1052. "CITIZEN",
  1053. "X1DE-USB",
  1054. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1055. US_FL_SINGLE_LUN),
  1056. /* Submitted by Dylan Taft <d13f00l@gmail.com>
  1057. * US_FL_IGNORE_RESIDUE Needed
  1058. */
  1059. UNUSUAL_DEV( 0x08ca, 0x3103, 0x0100, 0x0100,
  1060. "AIPTEK",
  1061. "Aiptek USB Keychain MP3 Player",
  1062. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1063. US_FL_IGNORE_RESIDUE),
  1064. /* Entry needed for flags. Moreover, all devices with this ID use
  1065. * bulk-only transport, but _some_ falsely report Control/Bulk instead.
  1066. * One example is "Trumpion Digital Research MYMP3".
  1067. * Submitted by Bjoern Brill <brill(at)fs.math.uni-frankfurt.de>
  1068. */
  1069. UNUSUAL_DEV( 0x090a, 0x1001, 0x0100, 0x0100,
  1070. "Trumpion",
  1071. "t33520 USB Flash Card Controller",
  1072. US_SC_DEVICE, US_PR_BULK, NULL,
  1073. US_FL_NEED_OVERRIDE ),
  1074. /* Reported by Filippo Bardelli <filibard@libero.it>
  1075. * The device reports a subclass of RBC, which is wrong.
  1076. */
  1077. UNUSUAL_DEV( 0x090a, 0x1050, 0x0100, 0x0100,
  1078. "Trumpion Microelectronics, Inc.",
  1079. "33520 USB Digital Voice Recorder",
  1080. US_SC_UFI, US_PR_DEVICE, NULL,
  1081. 0),
  1082. /* Trumpion Microelectronics MP3 player (felipe_alfaro@linuxmail.org) */
  1083. UNUSUAL_DEV( 0x090a, 0x1200, 0x0000, 0x9999,
  1084. "Trumpion",
  1085. "MP3 player",
  1086. US_SC_RBC, US_PR_BULK, NULL,
  1087. 0 ),
  1088. /* aeb */
  1089. UNUSUAL_DEV( 0x090c, 0x1132, 0x0000, 0xffff,
  1090. "Feiya",
  1091. "5-in-1 Card Reader",
  1092. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1093. US_FL_FIX_CAPACITY ),
  1094. /* This Pentax still camera is not conformant
  1095. * to the USB storage specification: -
  1096. * - It does not like the INQUIRY command. So we must handle this command
  1097. * of the SCSI layer ourselves.
  1098. * Tested on Rev. 10.00 (0x1000)
  1099. * Submitted by James Courtier-Dutton <James@superbug.demon.co.uk>
  1100. */
  1101. UNUSUAL_DEV( 0x0a17, 0x0004, 0x1000, 0x1000,
  1102. "Pentax",
  1103. "Optio 2/3/400",
  1104. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1105. US_FL_FIX_INQUIRY ),
  1106. /* Submitted by Per Winkvist <per.winkvist@uk.com> */
  1107. UNUSUAL_DEV( 0x0a17, 0x006, 0x0000, 0xffff,
  1108. "Pentax",
  1109. "Optio S/S4",
  1110. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1111. US_FL_FIX_INQUIRY ),
  1112. /* These are virtual windows driver CDs, which the zd1211rw driver
  1113. * automatically converts into WLAN devices. */
  1114. UNUSUAL_DEV( 0x0ace, 0x2011, 0x0101, 0x0101,
  1115. "ZyXEL",
  1116. "G-220F USB-WLAN Install",
  1117. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1118. US_FL_IGNORE_DEVICE ),
  1119. UNUSUAL_DEV( 0x0ace, 0x20ff, 0x0101, 0x0101,
  1120. "SiteCom",
  1121. "WL-117 USB-WLAN Install",
  1122. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1123. US_FL_IGNORE_DEVICE ),
  1124. #ifdef CONFIG_USB_STORAGE_ISD200
  1125. UNUSUAL_DEV( 0x0bf6, 0xa001, 0x0100, 0x0110,
  1126. "ATI",
  1127. "USB Cable 205",
  1128. US_SC_ISD200, US_PR_BULK, isd200_Initialization,
  1129. 0 ),
  1130. #endif
  1131. #ifdef CONFIG_USB_STORAGE_DATAFAB
  1132. UNUSUAL_DEV( 0x0c0b, 0xa109, 0x0000, 0xffff,
  1133. "Acomdata",
  1134. "CF",
  1135. US_SC_SCSI, US_PR_DATAFAB, NULL,
  1136. US_FL_SINGLE_LUN ),
  1137. #endif
  1138. #ifdef CONFIG_USB_STORAGE_SDDR55
  1139. UNUSUAL_DEV( 0x0c0b, 0xa109, 0x0000, 0xffff,
  1140. "Acomdata",
  1141. "SM",
  1142. US_SC_SCSI, US_PR_SDDR55, NULL,
  1143. US_FL_SINGLE_LUN ),
  1144. #endif
  1145. /* Submitted by: Nick Sillik <n.sillik@temple.edu>
  1146. * Needed for OneTouch extension to usb-storage
  1147. *
  1148. */
  1149. #ifdef CONFIG_USB_STORAGE_ONETOUCH
  1150. UNUSUAL_DEV( 0x0d49, 0x7000, 0x0000, 0x9999,
  1151. "Maxtor",
  1152. "OneTouch External Harddrive",
  1153. US_SC_DEVICE, US_PR_DEVICE, onetouch_connect_input,
  1154. 0),
  1155. UNUSUAL_DEV( 0x0d49, 0x7010, 0x0000, 0x9999,
  1156. "Maxtor",
  1157. "OneTouch External Harddrive",
  1158. US_SC_DEVICE, US_PR_DEVICE, onetouch_connect_input,
  1159. 0),
  1160. #endif
  1161. /*
  1162. * Pete Zaitcev <zaitcev@yahoo.com>, bz#164688.
  1163. * The device blatantly ignores LUN and returns 1 in GetMaxLUN.
  1164. */
  1165. UNUSUAL_DEV( 0x0c45, 0x1060, 0x0100, 0x0100,
  1166. "Unknown",
  1167. "Unknown",
  1168. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1169. US_FL_SINGLE_LUN ),
  1170. /* Submitted by Joris Struyve <joris@struyve.be> */
  1171. UNUSUAL_DEV( 0x0d96, 0x410a, 0x0001, 0xffff,
  1172. "Medion",
  1173. "MD 7425",
  1174. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1175. US_FL_FIX_INQUIRY),
  1176. /*
  1177. * Entry for Jenoptik JD 5200z3
  1178. *
  1179. * email: car.busse@gmx.de
  1180. */
  1181. UNUSUAL_DEV( 0x0d96, 0x5200, 0x0001, 0x0200,
  1182. "Jenoptik",
  1183. "JD 5200 z3",
  1184. US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_FIX_INQUIRY),
  1185. /* Reported by Lubomir Blaha <tritol@trilogic.cz>
  1186. * I _REALLY_ don't know what 3rd, 4th number and all defines mean, but this
  1187. * works for me. Can anybody correct these values? (I able to test corrected
  1188. * version.)
  1189. */
  1190. UNUSUAL_DEV( 0x0dd8, 0x1060, 0x0000, 0xffff,
  1191. "Netac",
  1192. "USB-CF-Card",
  1193. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1194. US_FL_FIX_INQUIRY ),
  1195. /* Reported by Edward Chapman (taken from linux-usb mailing list)
  1196. Netac OnlyDisk Mini U2CV2 512MB USB 2.0 Flash Drive */
  1197. UNUSUAL_DEV( 0x0dd8, 0xd202, 0x0000, 0x9999,
  1198. "Netac",
  1199. "USB Flash Disk",
  1200. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1201. US_FL_IGNORE_RESIDUE ),
  1202. /* Patch by Stephan Walter <stephan.walter@epfl.ch>
  1203. * I don't know why, but it works... */
  1204. UNUSUAL_DEV( 0x0dda, 0x0001, 0x0012, 0x0012,
  1205. "WINWARD",
  1206. "Music Disk",
  1207. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1208. US_FL_IGNORE_RESIDUE ),
  1209. /* Reported by Ian McConnell <ian at emit.demon.co.uk> */
  1210. UNUSUAL_DEV( 0x0dda, 0x0301, 0x0012, 0x0012,
  1211. "PNP_MP3",
  1212. "PNP_MP3 PLAYER",
  1213. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1214. US_FL_IGNORE_RESIDUE ),
  1215. /* Reported by Jim McCloskey <mcclosk@ucsc.edu> */
  1216. UNUSUAL_DEV( 0x0e21, 0x0520, 0x0100, 0x0100,
  1217. "Cowon Systems",
  1218. "iAUDIO M5",
  1219. US_SC_DEVICE, US_PR_BULK, NULL,
  1220. US_FL_NEED_OVERRIDE ),
  1221. /* Submitted by Antoine Mairesse <antoine.mairesse@free.fr> */
  1222. UNUSUAL_DEV( 0x0ed1, 0x6660, 0x0100, 0x0300,
  1223. "USB",
  1224. "Solid state disk",
  1225. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1226. US_FL_FIX_INQUIRY ),
  1227. /* Submitted by Daniel Drake <dsd@gentoo.org>
  1228. * Reported by dayul on the Gentoo Forums */
  1229. UNUSUAL_DEV( 0x0ea0, 0x2168, 0x0110, 0x0110,
  1230. "Ours Technology",
  1231. "Flash Disk",
  1232. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1233. US_FL_IGNORE_RESIDUE ),
  1234. /* Reported by Rastislav Stanik <rs_kernel@yahoo.com> */
  1235. UNUSUAL_DEV( 0x0ea0, 0x6828, 0x0110, 0x0110,
  1236. "USB",
  1237. "Flash Disk",
  1238. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1239. US_FL_IGNORE_RESIDUE ),
  1240. /* Reported by Benjamin Schiller <sbenni@gmx.de>
  1241. * It is also sold by Easylite as DJ 20 */
  1242. UNUSUAL_DEV( 0x0ed1, 0x7636, 0x0103, 0x0103,
  1243. "Typhoon",
  1244. "My DJ 1820",
  1245. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1246. US_FL_IGNORE_RESIDUE | US_FL_GO_SLOW | US_FL_MAX_SECTORS_64),
  1247. /* Patch by Leonid Petrov mail at lpetrov.net
  1248. * Reported by Robert Spitzenpfeil <robert@spitzenpfeil.org>
  1249. * http://www.qbik.ch/usb/devices/showdev.php?id=1705
  1250. * Updated to 103 device by MJ Ray mjr at phonecoop.coop
  1251. */
  1252. UNUSUAL_DEV( 0x0f19, 0x0103, 0x0100, 0x0100,
  1253. "Oracom Co., Ltd",
  1254. "ORC-200M",
  1255. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1256. US_FL_IGNORE_RESIDUE ),
  1257. /* David Kuehling <dvdkhlng@gmx.de>:
  1258. * for MP3-Player AVOX WSX-300ER (bought in Japan). Reports lots of SCSI
  1259. * errors when trying to write.
  1260. */
  1261. UNUSUAL_DEV( 0x0f19, 0x0105, 0x0100, 0x0100,
  1262. "C-MEX",
  1263. "A-VOX",
  1264. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1265. US_FL_IGNORE_RESIDUE ),
  1266. /* Jeremy Katz <katzj@redhat.com>:
  1267. * The Blackberry Pearl can run in two modes; a usb-storage only mode
  1268. * and a mode that allows access via mass storage and to its database.
  1269. * The berry_charge module will set the device to dual mode and thus we
  1270. * should ignore its native mode if that module is built
  1271. */
  1272. #ifdef CONFIG_USB_BERRY_CHARGE
  1273. UNUSUAL_DEV( 0x0fca, 0x0006, 0x0001, 0x0001,
  1274. "RIM",
  1275. "Blackberry Pearl",
  1276. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1277. US_FL_IGNORE_DEVICE ),
  1278. #endif
  1279. /* Reported by Michael Stattmann <michael@stattmann.com> */
  1280. UNUSUAL_DEV( 0x0fce, 0xd008, 0x0000, 0x0000,
  1281. "Sony Ericsson",
  1282. "V800-Vodafone 802",
  1283. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1284. US_FL_NO_WP_DETECT ),
  1285. /* Reported by Jan Mate <mate@fiit.stuba.sk>
  1286. * and by Soeren Sonnenburg <kernel@nn7.de> */
  1287. UNUSUAL_DEV( 0x0fce, 0xe030, 0x0000, 0x0000,
  1288. "Sony Ericsson",
  1289. "P990i",
  1290. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1291. US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
  1292. /* Reported by Ricardo Barberis <ricardo@dattatec.com> */
  1293. UNUSUAL_DEV( 0x0fce, 0xe092, 0x0000, 0x0000,
  1294. "Sony Ericsson",
  1295. "P1i",
  1296. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1297. US_FL_IGNORE_RESIDUE ),
  1298. /* Reported by Emmanuel Vasilakis <evas@forthnet.gr> */
  1299. UNUSUAL_DEV( 0x0fce, 0xe031, 0x0000, 0x0000,
  1300. "Sony Ericsson",
  1301. "M600i",
  1302. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1303. US_FL_FIX_CAPACITY ),
  1304. /* Reported by Kevin Cernekee <kpc-usbdev@gelato.uiuc.edu>
  1305. * Tested on hardware version 1.10.
  1306. * Entry is needed only for the initializer function override.
  1307. * Devices with bcd > 110 seem to not need it while those
  1308. * with bcd < 110 appear to need it.
  1309. */
  1310. UNUSUAL_DEV( 0x1019, 0x0c55, 0x0000, 0x0110,
  1311. "Desknote",
  1312. "UCR-61S2B",
  1313. US_SC_DEVICE, US_PR_DEVICE, usb_stor_ucr61s2b_init,
  1314. 0 ),
  1315. /* Reported by Fabio Venturi <f.venturi@tdnet.it>
  1316. * The device reports a vendor-specific bDeviceClass.
  1317. */
  1318. UNUSUAL_DEV( 0x10d6, 0x2200, 0x0100, 0x0100,
  1319. "Actions Semiconductor",
  1320. "Mtp device",
  1321. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1322. 0),
  1323. /* Reported by Kevin Lloyd <linux@sierrawireless.com>
  1324. * Entry is needed for the initializer function override,
  1325. * which instructs the device to load as a modem
  1326. * device.
  1327. */
  1328. UNUSUAL_DEV( 0x1199, 0x0fff, 0x0000, 0x9999,
  1329. "Sierra Wireless",
  1330. "USB MMC Storage",
  1331. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1332. US_FL_IGNORE_DEVICE),
  1333. /* Reported by Jaco Kroon <jaco@kroon.co.za>
  1334. * The usb-storage module found on the Digitech GNX4 (and supposedly other
  1335. * devices) misbehaves and causes a bunch of invalid I/O errors.
  1336. */
  1337. UNUSUAL_DEV( 0x1210, 0x0003, 0x0100, 0x0100,
  1338. "Digitech HMG",
  1339. "DigiTech Mass Storage",
  1340. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1341. US_FL_IGNORE_RESIDUE ),
  1342. /* Reported by fangxiaozhi <huananhu@huawei.com>
  1343. * This brings the HUAWEI data card devices into multi-port mode
  1344. */
  1345. UNUSUAL_DEV( 0x12d1, 0x1001, 0x0000, 0x0000,
  1346. "HUAWEI MOBILE",
  1347. "Mass Storage",
  1348. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1349. 0),
  1350. UNUSUAL_DEV( 0x12d1, 0x1003, 0x0000, 0x0000,
  1351. "HUAWEI MOBILE",
  1352. "Mass Storage",
  1353. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1354. 0),
  1355. UNUSUAL_DEV( 0x12d1, 0x1004, 0x0000, 0x0000,
  1356. "HUAWEI MOBILE",
  1357. "Mass Storage",
  1358. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1359. 0),
  1360. UNUSUAL_DEV( 0x12d1, 0x1401, 0x0000, 0x0000,
  1361. "HUAWEI MOBILE",
  1362. "Mass Storage",
  1363. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1364. 0),
  1365. UNUSUAL_DEV( 0x12d1, 0x1403, 0x0000, 0x0000,
  1366. "HUAWEI MOBILE",
  1367. "Mass Storage",
  1368. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1369. 0),
  1370. UNUSUAL_DEV( 0x12d1, 0x1405, 0x0000, 0x0000,
  1371. "HUAWEI MOBILE",
  1372. "Mass Storage",
  1373. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1374. 0),
  1375. UNUSUAL_DEV( 0x12d1, 0x1406, 0x0000, 0x0000,
  1376. "HUAWEI MOBILE",
  1377. "Mass Storage",
  1378. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1379. 0),
  1380. UNUSUAL_DEV( 0x12d1, 0x1408, 0x0000, 0x0000,
  1381. "HUAWEI MOBILE",
  1382. "Mass Storage",
  1383. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1384. 0),
  1385. UNUSUAL_DEV( 0x12d1, 0x1409, 0x0000, 0x0000,
  1386. "HUAWEI MOBILE",
  1387. "Mass Storage",
  1388. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1389. 0),
  1390. UNUSUAL_DEV( 0x12d1, 0x1410, 0x0000, 0x0000,
  1391. "HUAWEI MOBILE",
  1392. "Mass Storage",
  1393. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1394. 0),
  1395. UNUSUAL_DEV( 0x12d1, 0x1411, 0x0000, 0x0000,
  1396. "HUAWEI MOBILE",
  1397. "Mass Storage",
  1398. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1399. 0),
  1400. UNUSUAL_DEV( 0x12d1, 0x1412, 0x0000, 0x0000,
  1401. "HUAWEI MOBILE",
  1402. "Mass Storage",
  1403. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1404. 0),
  1405. UNUSUAL_DEV( 0x12d1, 0x1413, 0x0000, 0x0000,
  1406. "HUAWEI MOBILE",
  1407. "Mass Storage",
  1408. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1409. 0),
  1410. UNUSUAL_DEV( 0x12d1, 0x1414, 0x0000, 0x0000,
  1411. "HUAWEI MOBILE",
  1412. "Mass Storage",
  1413. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1414. 0),
  1415. UNUSUAL_DEV( 0x12d1, 0x1415, 0x0000, 0x0000,
  1416. "HUAWEI MOBILE",
  1417. "Mass Storage",
  1418. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1419. 0),
  1420. UNUSUAL_DEV( 0x12d1, 0x1416, 0x0000, 0x0000,
  1421. "HUAWEI MOBILE",
  1422. "Mass Storage",
  1423. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1424. 0),
  1425. UNUSUAL_DEV( 0x12d1, 0x1417, 0x0000, 0x0000,
  1426. "HUAWEI MOBILE",
  1427. "Mass Storage",
  1428. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1429. 0),
  1430. UNUSUAL_DEV( 0x12d1, 0x1418, 0x0000, 0x0000,
  1431. "HUAWEI MOBILE",
  1432. "Mass Storage",
  1433. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1434. 0),
  1435. UNUSUAL_DEV( 0x12d1, 0x1419, 0x0000, 0x0000,
  1436. "HUAWEI MOBILE",
  1437. "Mass Storage",
  1438. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1439. 0),
  1440. /* Reported by Vilius Bilinkevicius <vilisas AT xxx DOT lt) */
  1441. UNUSUAL_DEV( 0x132b, 0x000b, 0x0001, 0x0001,
  1442. "Minolta",
  1443. "Dimage Z10",
  1444. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1445. 0 ),
  1446. /* Reported by Kotrla Vitezslav <kotrla@ceb.cz> */
  1447. UNUSUAL_DEV( 0x1370, 0x6828, 0x0110, 0x0110,
  1448. "SWISSBIT",
  1449. "Black Silver",
  1450. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1451. US_FL_IGNORE_RESIDUE ),
  1452. /* Reported by Francesco Foresti <frafore@tiscali.it> */
  1453. UNUSUAL_DEV( 0x14cd, 0x6600, 0x0201, 0x0201,
  1454. "Super Top",
  1455. "IDE DEVICE",
  1456. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1457. US_FL_IGNORE_RESIDUE ),
  1458. /* Reported by Robert Schedel <r.schedel@yahoo.de>
  1459. * Note: this is a 'super top' device like the above 14cd/6600 device */
  1460. UNUSUAL_DEV( 0x1652, 0x6600, 0x0201, 0x0201,
  1461. "Teac",
  1462. "HD-35PUK-B",
  1463. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1464. US_FL_IGNORE_RESIDUE ),
  1465. /* patch submitted by Davide Perini <perini.davide@dpsoftware.org>
  1466. * and Renato Perini <rperini@email.it>
  1467. */
  1468. UNUSUAL_DEV( 0x22b8, 0x3010, 0x0001, 0x0001,
  1469. "Motorola",
  1470. "RAZR V3x",
  1471. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1472. US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
  1473. /*
  1474. * Patch by Pete Zaitcev <zaitcev@redhat.com>
  1475. * Report by Mark Patton. Red Hat bz#208928.
  1476. */
  1477. UNUSUAL_DEV( 0x22b8, 0x4810, 0x0001, 0x0001,
  1478. "Motorola",
  1479. "RAZR V3i",
  1480. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1481. US_FL_FIX_CAPACITY),
  1482. /*
  1483. * Patch by Constantin Baranov <const@tltsu.ru>
  1484. * Report by Andreas Koenecke.
  1485. * Motorola ROKR Z6.
  1486. */
  1487. UNUSUAL_DEV( 0x22b8, 0x6426, 0x0101, 0x0101,
  1488. "Motorola",
  1489. "MSnc.",
  1490. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1491. US_FL_FIX_INQUIRY | US_FL_FIX_CAPACITY | US_FL_BULK_IGNORE_TAG),
  1492. /* Reported by Radovan Garabik <garabik@kassiopeia.juls.savba.sk> */
  1493. UNUSUAL_DEV( 0x2735, 0x100b, 0x0000, 0x9999,
  1494. "MPIO",
  1495. "HS200",
  1496. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1497. US_FL_GO_SLOW ),
  1498. /*
  1499. * David Härdeman <david@2gen.com>
  1500. * The key makes the SCSI stack print confusing (but harmless) messages
  1501. */
  1502. UNUSUAL_DEV( 0x4146, 0xba01, 0x0100, 0x0100,
  1503. "Iomega",
  1504. "Micro Mini 1GB",
  1505. US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_NOT_LOCKABLE ),
  1506. #ifdef CONFIG_USB_STORAGE_SDDR55
  1507. UNUSUAL_DEV( 0x55aa, 0xa103, 0x0000, 0x9999,
  1508. "Sandisk",
  1509. "ImageMate SDDR55",
  1510. US_SC_SCSI, US_PR_SDDR55, NULL,
  1511. US_FL_SINGLE_LUN),
  1512. #endif
  1513. /* Reported by Andrew Simmons <andrew.simmons@gmail.com> */
  1514. UNUSUAL_DEV( 0xed06, 0x4500, 0x0001, 0x0001,
  1515. "DataStor",
  1516. "USB4500 FW1.04",
  1517. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1518. US_FL_CAPACITY_HEURISTICS),
  1519. #ifdef CONFIG_USB_STORAGE_CYPRESS_ATACB
  1520. UNUSUAL_DEV( 0x04b4, 0x6830, 0x0000, 0x9999,
  1521. "Cypress",
  1522. "Cypress AT2LP",
  1523. US_SC_CYP_ATACB, US_PR_BULK, NULL,
  1524. 0),
  1525. #endif
  1526. /* Control/Bulk transport for all SubClass values */
  1527. USUAL_DEV(US_SC_RBC, US_PR_CB, USB_US_TYPE_STOR),
  1528. USUAL_DEV(US_SC_8020, US_PR_CB, USB_US_TYPE_STOR),
  1529. USUAL_DEV(US_SC_QIC, US_PR_CB, USB_US_TYPE_STOR),
  1530. USUAL_DEV(US_SC_UFI, US_PR_CB, USB_US_TYPE_STOR),
  1531. USUAL_DEV(US_SC_8070, US_PR_CB, USB_US_TYPE_STOR),
  1532. USUAL_DEV(US_SC_SCSI, US_PR_CB, USB_US_TYPE_STOR),
  1533. /* Control/Bulk/Interrupt transport for all SubClass values */
  1534. USUAL_DEV(US_SC_RBC, US_PR_CBI, USB_US_TYPE_STOR),
  1535. USUAL_DEV(US_SC_8020, US_PR_CBI, USB_US_TYPE_STOR),
  1536. USUAL_DEV(US_SC_QIC, US_PR_CBI, USB_US_TYPE_STOR),
  1537. USUAL_DEV(US_SC_UFI, US_PR_CBI, USB_US_TYPE_STOR),
  1538. USUAL_DEV(US_SC_8070, US_PR_CBI, USB_US_TYPE_STOR),
  1539. USUAL_DEV(US_SC_SCSI, US_PR_CBI, USB_US_TYPE_STOR),
  1540. /* Bulk-only transport for all SubClass values */
  1541. USUAL_DEV(US_SC_RBC, US_PR_BULK, USB_US_TYPE_STOR),
  1542. USUAL_DEV(US_SC_8020, US_PR_BULK, USB_US_TYPE_STOR),
  1543. USUAL_DEV(US_SC_QIC, US_PR_BULK, USB_US_TYPE_STOR),
  1544. USUAL_DEV(US_SC_UFI, US_PR_BULK, USB_US_TYPE_STOR),
  1545. USUAL_DEV(US_SC_8070, US_PR_BULK, USB_US_TYPE_STOR),
  1546. USUAL_DEV(US_SC_SCSI, US_PR_BULK, 0),