unusual_devs.h 51 KB

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