unusual_devs.h 50 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766
  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. /* Reported by Rohan Hart <rohan.hart17@gmail.com> */
  1177. UNUSUAL_DEV( 0x2770, 0x915d, 0x0010, 0x0010,
  1178. "INTOVA",
  1179. "Pixtreme",
  1180. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1181. US_FL_FIX_CAPACITY ),
  1182. /*
  1183. * Entry for Jenoptik JD 5200z3
  1184. *
  1185. * email: car.busse@gmx.de
  1186. */
  1187. UNUSUAL_DEV( 0x0d96, 0x5200, 0x0001, 0x0200,
  1188. "Jenoptik",
  1189. "JD 5200 z3",
  1190. US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_FIX_INQUIRY),
  1191. /* Reported by Lubomir Blaha <tritol@trilogic.cz>
  1192. * I _REALLY_ don't know what 3rd, 4th number and all defines mean, but this
  1193. * works for me. Can anybody correct these values? (I able to test corrected
  1194. * version.)
  1195. */
  1196. UNUSUAL_DEV( 0x0dd8, 0x1060, 0x0000, 0xffff,
  1197. "Netac",
  1198. "USB-CF-Card",
  1199. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1200. US_FL_FIX_INQUIRY ),
  1201. /* Reported by Edward Chapman (taken from linux-usb mailing list)
  1202. Netac OnlyDisk Mini U2CV2 512MB USB 2.0 Flash Drive */
  1203. UNUSUAL_DEV( 0x0dd8, 0xd202, 0x0000, 0x9999,
  1204. "Netac",
  1205. "USB Flash Disk",
  1206. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1207. US_FL_IGNORE_RESIDUE ),
  1208. /* Patch by Stephan Walter <stephan.walter@epfl.ch>
  1209. * I don't know why, but it works... */
  1210. UNUSUAL_DEV( 0x0dda, 0x0001, 0x0012, 0x0012,
  1211. "WINWARD",
  1212. "Music Disk",
  1213. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1214. US_FL_IGNORE_RESIDUE ),
  1215. /* Reported by Ian McConnell <ian at emit.demon.co.uk> */
  1216. UNUSUAL_DEV( 0x0dda, 0x0301, 0x0012, 0x0012,
  1217. "PNP_MP3",
  1218. "PNP_MP3 PLAYER",
  1219. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1220. US_FL_IGNORE_RESIDUE ),
  1221. /* Reported by Jim McCloskey <mcclosk@ucsc.edu> */
  1222. UNUSUAL_DEV( 0x0e21, 0x0520, 0x0100, 0x0100,
  1223. "Cowon Systems",
  1224. "iAUDIO M5",
  1225. US_SC_DEVICE, US_PR_BULK, NULL,
  1226. US_FL_NEED_OVERRIDE ),
  1227. /* Submitted by Antoine Mairesse <antoine.mairesse@free.fr> */
  1228. UNUSUAL_DEV( 0x0ed1, 0x6660, 0x0100, 0x0300,
  1229. "USB",
  1230. "Solid state disk",
  1231. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1232. US_FL_FIX_INQUIRY ),
  1233. /* Submitted by Daniel Drake <dsd@gentoo.org>
  1234. * Reported by dayul on the Gentoo Forums */
  1235. UNUSUAL_DEV( 0x0ea0, 0x2168, 0x0110, 0x0110,
  1236. "Ours Technology",
  1237. "Flash Disk",
  1238. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1239. US_FL_IGNORE_RESIDUE ),
  1240. /* Reported by Rastislav Stanik <rs_kernel@yahoo.com> */
  1241. UNUSUAL_DEV( 0x0ea0, 0x6828, 0x0110, 0x0110,
  1242. "USB",
  1243. "Flash Disk",
  1244. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1245. US_FL_IGNORE_RESIDUE ),
  1246. /* Reported by Benjamin Schiller <sbenni@gmx.de>
  1247. * It is also sold by Easylite as DJ 20 */
  1248. UNUSUAL_DEV( 0x0ed1, 0x7636, 0x0103, 0x0103,
  1249. "Typhoon",
  1250. "My DJ 1820",
  1251. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1252. US_FL_IGNORE_RESIDUE | US_FL_GO_SLOW | US_FL_MAX_SECTORS_64),
  1253. /* Patch by Leonid Petrov mail at lpetrov.net
  1254. * Reported by Robert Spitzenpfeil <robert@spitzenpfeil.org>
  1255. * http://www.qbik.ch/usb/devices/showdev.php?id=1705
  1256. * Updated to 103 device by MJ Ray mjr at phonecoop.coop
  1257. */
  1258. UNUSUAL_DEV( 0x0f19, 0x0103, 0x0100, 0x0100,
  1259. "Oracom Co., Ltd",
  1260. "ORC-200M",
  1261. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1262. US_FL_IGNORE_RESIDUE ),
  1263. /* David Kuehling <dvdkhlng@gmx.de>:
  1264. * for MP3-Player AVOX WSX-300ER (bought in Japan). Reports lots of SCSI
  1265. * errors when trying to write.
  1266. */
  1267. UNUSUAL_DEV( 0x0f19, 0x0105, 0x0100, 0x0100,
  1268. "C-MEX",
  1269. "A-VOX",
  1270. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1271. US_FL_IGNORE_RESIDUE ),
  1272. /* Jeremy Katz <katzj@redhat.com>:
  1273. * The Blackberry Pearl can run in two modes; a usb-storage only mode
  1274. * and a mode that allows access via mass storage and to its database.
  1275. * The berry_charge module will set the device to dual mode and thus we
  1276. * should ignore its native mode if that module is built
  1277. */
  1278. #ifdef CONFIG_USB_BERRY_CHARGE
  1279. UNUSUAL_DEV( 0x0fca, 0x0006, 0x0001, 0x0001,
  1280. "RIM",
  1281. "Blackberry Pearl",
  1282. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1283. US_FL_IGNORE_DEVICE ),
  1284. #endif
  1285. /* Reported by Michael Stattmann <michael@stattmann.com> */
  1286. UNUSUAL_DEV( 0x0fce, 0xd008, 0x0000, 0x0000,
  1287. "Sony Ericsson",
  1288. "V800-Vodafone 802",
  1289. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1290. US_FL_NO_WP_DETECT ),
  1291. /* Reported by Jan Mate <mate@fiit.stuba.sk>
  1292. * and by Soeren Sonnenburg <kernel@nn7.de> */
  1293. UNUSUAL_DEV( 0x0fce, 0xe030, 0x0000, 0x0000,
  1294. "Sony Ericsson",
  1295. "P990i",
  1296. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1297. US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
  1298. /* Reported by Ricardo Barberis <ricardo@dattatec.com> */
  1299. UNUSUAL_DEV( 0x0fce, 0xe092, 0x0000, 0x0000,
  1300. "Sony Ericsson",
  1301. "P1i",
  1302. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1303. US_FL_IGNORE_RESIDUE ),
  1304. /* Reported by Emmanuel Vasilakis <evas@forthnet.gr> */
  1305. UNUSUAL_DEV( 0x0fce, 0xe031, 0x0000, 0x0000,
  1306. "Sony Ericsson",
  1307. "M600i",
  1308. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1309. US_FL_FIX_CAPACITY ),
  1310. /* Reported by Kevin Cernekee <kpc-usbdev@gelato.uiuc.edu>
  1311. * Tested on hardware version 1.10.
  1312. * Entry is needed only for the initializer function override.
  1313. * Devices with bcd > 110 seem to not need it while those
  1314. * with bcd < 110 appear to need it.
  1315. */
  1316. UNUSUAL_DEV( 0x1019, 0x0c55, 0x0000, 0x0110,
  1317. "Desknote",
  1318. "UCR-61S2B",
  1319. US_SC_DEVICE, US_PR_DEVICE, usb_stor_ucr61s2b_init,
  1320. 0 ),
  1321. /* Reported by Fabio Venturi <f.venturi@tdnet.it>
  1322. * The device reports a vendor-specific bDeviceClass.
  1323. */
  1324. UNUSUAL_DEV( 0x10d6, 0x2200, 0x0100, 0x0100,
  1325. "Actions Semiconductor",
  1326. "Mtp device",
  1327. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1328. 0),
  1329. /* Reported by Kevin Lloyd <linux@sierrawireless.com>
  1330. * Entry is needed for the initializer function override,
  1331. * which instructs the device to load as a modem
  1332. * device.
  1333. */
  1334. UNUSUAL_DEV( 0x1199, 0x0fff, 0x0000, 0x9999,
  1335. "Sierra Wireless",
  1336. "USB MMC Storage",
  1337. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1338. US_FL_IGNORE_DEVICE),
  1339. /* Reported by Jaco Kroon <jaco@kroon.co.za>
  1340. * The usb-storage module found on the Digitech GNX4 (and supposedly other
  1341. * devices) misbehaves and causes a bunch of invalid I/O errors.
  1342. */
  1343. UNUSUAL_DEV( 0x1210, 0x0003, 0x0100, 0x0100,
  1344. "Digitech HMG",
  1345. "DigiTech Mass Storage",
  1346. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1347. US_FL_IGNORE_RESIDUE ),
  1348. /* Reported by fangxiaozhi <huananhu@huawei.com>
  1349. * This brings the HUAWEI data card devices into multi-port mode
  1350. */
  1351. UNUSUAL_DEV( 0x12d1, 0x1001, 0x0000, 0x0000,
  1352. "HUAWEI MOBILE",
  1353. "Mass Storage",
  1354. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1355. 0),
  1356. UNUSUAL_DEV( 0x12d1, 0x1003, 0x0000, 0x0000,
  1357. "HUAWEI MOBILE",
  1358. "Mass Storage",
  1359. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1360. 0),
  1361. UNUSUAL_DEV( 0x12d1, 0x1004, 0x0000, 0x0000,
  1362. "HUAWEI MOBILE",
  1363. "Mass Storage",
  1364. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1365. 0),
  1366. UNUSUAL_DEV( 0x12d1, 0x1401, 0x0000, 0x0000,
  1367. "HUAWEI MOBILE",
  1368. "Mass Storage",
  1369. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1370. 0),
  1371. UNUSUAL_DEV( 0x12d1, 0x1403, 0x0000, 0x0000,
  1372. "HUAWEI MOBILE",
  1373. "Mass Storage",
  1374. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1375. 0),
  1376. UNUSUAL_DEV( 0x12d1, 0x1405, 0x0000, 0x0000,
  1377. "HUAWEI MOBILE",
  1378. "Mass Storage",
  1379. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1380. 0),
  1381. UNUSUAL_DEV( 0x12d1, 0x1406, 0x0000, 0x0000,
  1382. "HUAWEI MOBILE",
  1383. "Mass Storage",
  1384. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1385. 0),
  1386. UNUSUAL_DEV( 0x12d1, 0x1408, 0x0000, 0x0000,
  1387. "HUAWEI MOBILE",
  1388. "Mass Storage",
  1389. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1390. 0),
  1391. UNUSUAL_DEV( 0x12d1, 0x1409, 0x0000, 0x0000,
  1392. "HUAWEI MOBILE",
  1393. "Mass Storage",
  1394. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1395. 0),
  1396. UNUSUAL_DEV( 0x12d1, 0x1410, 0x0000, 0x0000,
  1397. "HUAWEI MOBILE",
  1398. "Mass Storage",
  1399. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1400. 0),
  1401. UNUSUAL_DEV( 0x12d1, 0x1411, 0x0000, 0x0000,
  1402. "HUAWEI MOBILE",
  1403. "Mass Storage",
  1404. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1405. 0),
  1406. UNUSUAL_DEV( 0x12d1, 0x1412, 0x0000, 0x0000,
  1407. "HUAWEI MOBILE",
  1408. "Mass Storage",
  1409. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1410. 0),
  1411. UNUSUAL_DEV( 0x12d1, 0x1413, 0x0000, 0x0000,
  1412. "HUAWEI MOBILE",
  1413. "Mass Storage",
  1414. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1415. 0),
  1416. UNUSUAL_DEV( 0x12d1, 0x1414, 0x0000, 0x0000,
  1417. "HUAWEI MOBILE",
  1418. "Mass Storage",
  1419. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1420. 0),
  1421. UNUSUAL_DEV( 0x12d1, 0x1415, 0x0000, 0x0000,
  1422. "HUAWEI MOBILE",
  1423. "Mass Storage",
  1424. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1425. 0),
  1426. UNUSUAL_DEV( 0x12d1, 0x1416, 0x0000, 0x0000,
  1427. "HUAWEI MOBILE",
  1428. "Mass Storage",
  1429. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1430. 0),
  1431. UNUSUAL_DEV( 0x12d1, 0x1417, 0x0000, 0x0000,
  1432. "HUAWEI MOBILE",
  1433. "Mass Storage",
  1434. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1435. 0),
  1436. UNUSUAL_DEV( 0x12d1, 0x1418, 0x0000, 0x0000,
  1437. "HUAWEI MOBILE",
  1438. "Mass Storage",
  1439. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1440. 0),
  1441. UNUSUAL_DEV( 0x12d1, 0x1419, 0x0000, 0x0000,
  1442. "HUAWEI MOBILE",
  1443. "Mass Storage",
  1444. US_SC_DEVICE, US_PR_DEVICE, usb_stor_huawei_e220_init,
  1445. 0),
  1446. /* Reported by Vilius Bilinkevicius <vilisas AT xxx DOT lt) */
  1447. UNUSUAL_DEV( 0x132b, 0x000b, 0x0001, 0x0001,
  1448. "Minolta",
  1449. "Dimage Z10",
  1450. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1451. 0 ),
  1452. /* Reported by Kotrla Vitezslav <kotrla@ceb.cz> */
  1453. UNUSUAL_DEV( 0x1370, 0x6828, 0x0110, 0x0110,
  1454. "SWISSBIT",
  1455. "Black Silver",
  1456. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1457. US_FL_IGNORE_RESIDUE ),
  1458. /* Reported by Francesco Foresti <frafore@tiscali.it> */
  1459. UNUSUAL_DEV( 0x14cd, 0x6600, 0x0201, 0x0201,
  1460. "Super Top",
  1461. "IDE DEVICE",
  1462. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1463. US_FL_IGNORE_RESIDUE ),
  1464. /* Reported by Robert Schedel <r.schedel@yahoo.de>
  1465. * Note: this is a 'super top' device like the above 14cd/6600 device */
  1466. UNUSUAL_DEV( 0x1652, 0x6600, 0x0201, 0x0201,
  1467. "Teac",
  1468. "HD-35PUK-B",
  1469. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1470. US_FL_IGNORE_RESIDUE ),
  1471. /* patch submitted by Davide Perini <perini.davide@dpsoftware.org>
  1472. * and Renato Perini <rperini@email.it>
  1473. */
  1474. UNUSUAL_DEV( 0x22b8, 0x3010, 0x0001, 0x0001,
  1475. "Motorola",
  1476. "RAZR V3x",
  1477. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1478. US_FL_FIX_CAPACITY | US_FL_IGNORE_RESIDUE ),
  1479. /*
  1480. * Patch by Pete Zaitcev <zaitcev@redhat.com>
  1481. * Report by Mark Patton. Red Hat bz#208928.
  1482. */
  1483. UNUSUAL_DEV( 0x22b8, 0x4810, 0x0001, 0x0001,
  1484. "Motorola",
  1485. "RAZR V3i",
  1486. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1487. US_FL_FIX_CAPACITY),
  1488. /*
  1489. * Patch by Constantin Baranov <const@tltsu.ru>
  1490. * Report by Andreas Koenecke.
  1491. * Motorola ROKR Z6.
  1492. */
  1493. UNUSUAL_DEV( 0x22b8, 0x6426, 0x0101, 0x0101,
  1494. "Motorola",
  1495. "MSnc.",
  1496. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1497. US_FL_FIX_INQUIRY | US_FL_FIX_CAPACITY | US_FL_BULK_IGNORE_TAG),
  1498. /* Reported by Radovan Garabik <garabik@kassiopeia.juls.savba.sk> */
  1499. UNUSUAL_DEV( 0x2735, 0x100b, 0x0000, 0x9999,
  1500. "MPIO",
  1501. "HS200",
  1502. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1503. US_FL_GO_SLOW ),
  1504. /*
  1505. * David Härdeman <david@2gen.com>
  1506. * The key makes the SCSI stack print confusing (but harmless) messages
  1507. */
  1508. UNUSUAL_DEV( 0x4146, 0xba01, 0x0100, 0x0100,
  1509. "Iomega",
  1510. "Micro Mini 1GB",
  1511. US_SC_DEVICE, US_PR_DEVICE, NULL, US_FL_NOT_LOCKABLE ),
  1512. #ifdef CONFIG_USB_STORAGE_SDDR55
  1513. UNUSUAL_DEV( 0x55aa, 0xa103, 0x0000, 0x9999,
  1514. "Sandisk",
  1515. "ImageMate SDDR55",
  1516. US_SC_SCSI, US_PR_SDDR55, NULL,
  1517. US_FL_SINGLE_LUN),
  1518. #endif
  1519. /* Reported by Andrew Simmons <andrew.simmons@gmail.com> */
  1520. UNUSUAL_DEV( 0xed06, 0x4500, 0x0001, 0x0001,
  1521. "DataStor",
  1522. "USB4500 FW1.04",
  1523. US_SC_DEVICE, US_PR_DEVICE, NULL,
  1524. US_FL_CAPACITY_HEURISTICS),
  1525. #ifdef CONFIG_USB_STORAGE_CYPRESS_ATACB
  1526. UNUSUAL_DEV( 0x04b4, 0x6830, 0x0000, 0x9999,
  1527. "Cypress",
  1528. "Cypress AT2LP",
  1529. US_SC_CYP_ATACB, US_PR_BULK, NULL,
  1530. 0),
  1531. #endif
  1532. /* Control/Bulk transport for all SubClass values */
  1533. USUAL_DEV(US_SC_RBC, US_PR_CB, USB_US_TYPE_STOR),
  1534. USUAL_DEV(US_SC_8020, US_PR_CB, USB_US_TYPE_STOR),
  1535. USUAL_DEV(US_SC_QIC, US_PR_CB, USB_US_TYPE_STOR),
  1536. USUAL_DEV(US_SC_UFI, US_PR_CB, USB_US_TYPE_STOR),
  1537. USUAL_DEV(US_SC_8070, US_PR_CB, USB_US_TYPE_STOR),
  1538. USUAL_DEV(US_SC_SCSI, US_PR_CB, USB_US_TYPE_STOR),
  1539. /* Control/Bulk/Interrupt transport for all SubClass values */
  1540. USUAL_DEV(US_SC_RBC, US_PR_CBI, USB_US_TYPE_STOR),
  1541. USUAL_DEV(US_SC_8020, US_PR_CBI, USB_US_TYPE_STOR),
  1542. USUAL_DEV(US_SC_QIC, US_PR_CBI, USB_US_TYPE_STOR),
  1543. USUAL_DEV(US_SC_UFI, US_PR_CBI, USB_US_TYPE_STOR),
  1544. USUAL_DEV(US_SC_8070, US_PR_CBI, USB_US_TYPE_STOR),
  1545. USUAL_DEV(US_SC_SCSI, US_PR_CBI, USB_US_TYPE_STOR),
  1546. /* Bulk-only transport for all SubClass values */
  1547. USUAL_DEV(US_SC_RBC, US_PR_BULK, USB_US_TYPE_STOR),
  1548. USUAL_DEV(US_SC_8020, US_PR_BULK, USB_US_TYPE_STOR),
  1549. USUAL_DEV(US_SC_QIC, US_PR_BULK, USB_US_TYPE_STOR),
  1550. USUAL_DEV(US_SC_UFI, US_PR_BULK, USB_US_TYPE_STOR),
  1551. USUAL_DEV(US_SC_8070, US_PR_BULK, USB_US_TYPE_STOR),
  1552. USUAL_DEV(US_SC_SCSI, US_PR_BULK, 0),