music-players.h

Go to the documentation of this file.
00001 
00031 /*
00032  * MTP device list, trying real bad to get all devices into
00033  * this list by stealing from everyone I know.
00034  */
00035 
00036   /*
00037    * Creative Technology
00038    * Initially the Creative devices was all we supported so these are
00039    * the most thoroughly tested devices. Presumably only the devices
00040    * with older firmware (the ones that have 32bit object size) will
00041    * need the DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL flag. This bug
00042    * manifest itself when you have a lot of folders on the device,
00043    * some of the folders will start to disappear when getting all objects
00044    * and properties.
00045    */
00046   { "Creative", 0x041e, "ZEN Vision", 0x411f, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00047   { "Creative", 0x041e, "Portable Media Center", 0x4123, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00048   { "Creative", 0x041e, "ZEN Xtra (MTP mode)", 0x4128, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00049   { "Dell", 0x041e, "DJ (2nd generation)", 0x412f, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00050   { "Creative", 0x041e, "ZEN Micro (MTP mode)", 0x4130, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00051   { "Creative", 0x041e, "ZEN Touch (MTP mode)", 0x4131, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00052   { "Dell", 0x041e, "Dell Pocket DJ (MTP mode)", 0x4132, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00053   { "Creative", 0x041e, "ZEN Sleek (MTP mode)", 0x4137, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00054   { "Creative", 0x041e, "ZEN MicroPhoto", 0x413c, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00055   { "Creative", 0x041e, "ZEN Sleek Photo", 0x413d, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00056   { "Creative", 0x041e, "ZEN Vision:M", 0x413e, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00057   // Reported by marazm@o2.pl
00058   { "Creative", 0x041e, "ZEN V", 0x4150, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00059   // Reported by danielw@iinet.net.au
00060   // This version of the Vision:M needs the no release interface flag,
00061   // unclear whether the other version above need it too or not.
00062   { "Creative", 0x041e, "ZEN Vision:M (DVP-HD0004)", 0x4151, 
00063       DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL},
00064   // Reported by Darel on the XNJB forums
00065   { "Creative", 0x041e, "ZEN V Plus", 0x4152, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00066   { "Creative", 0x041e, "ZEN Vision W", 0x4153, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00067   // Don't add 0x4155: this is a Zen Stone device which is not MTP
00068   // Reported by Paul Kurczaba <paul@kurczaba.com>
00069   { "Creative", 0x041e, "ZEN", 0x4157, DEVICE_FLAG_IGNORE_HEADER_ERRORS |
00070     DEVICE_FLAG_BROKEN_SET_SAMPLE_DIMENSIONS | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00071   // Reported by Ringofan <mcroman@users.sourceforge.net>
00072   { "Creative", 0x041e, "ZEN V 2GB", 0x4158, DEVICE_FLAG_NONE },
00073   // Reported by j norment <stormzen@gmail.com>
00074   { "Creative", 0x041e, "ZEN Mozaic", 0x4161, DEVICE_FLAG_NONE },
00075   // Reported by Aaron F. Gonzalez <sub_tex@users.sourceforge.net>
00076   { "Creative", 0x041e, "ZEN X-Fi", 0x4162, DEVICE_FLAG_NONE },
00077 
00078   /*
00079    * Samsung
00080    * We suspect that more of these are dual mode.
00081    * We suspect more of these might need DEVICE_FLAG_NO_ZERO_READS
00082    * We suspect more of these might need DEVICE_FLAG_PLAYLIST_SPL_V1
00083    *  or DEVICE_FLAG_PLAYLIST_SPL_V2 to get playlists working.
00084    * YP-NEU, YP-NDU, YP-20, YP-800, YP-MF Series, YP-100, YP-30
00085    * YP-700 and YP-90 are NOT MTP, but use a Samsung custom protocol.
00086    */
00087   // From anonymous SourceForge user, not verified
00088   { "Samsung", 0x04e8, "YP-900", 0x0409, DEVICE_FLAG_NONE },
00089   // From MItch <dbaker@users.sourceforge.net>
00090   { "Samsung", 0x04e8, "I550W Phone", 0x04a4, DEVICE_FLAG_NONE },
00091   // From Gabriel Nunes <gabrielkm1@yahoo.com.br>
00092   { "Samsung", 0x04e8, "YH-920 (501d)", 0x501d, DEVICE_FLAG_UNLOAD_DRIVER },
00093   // From Soren O'Neill
00094   { "Samsung", 0x04e8, "YH-920 (5022)", 0x5022, DEVICE_FLAG_UNLOAD_DRIVER },
00095   // Contributed by aronvanammers on SourceForge
00096   { "Samsung", 0x04e8, "YH-925GS", 0x5024, DEVICE_FLAG_NONE },
00097   // From libgphoto2, according to tests by Stephan Fabel it cannot
00098   // get all objects with the getobjectproplist command..
00099   { "Samsung", 0x04e8, "YH-820", 0x502e, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00100   // Contributed by polux2001@users.sourceforge.net
00101   { "Samsung", 0x04e8, "YH-925(-GS)", 0x502f, DEVICE_FLAG_UNLOAD_DRIVER | 
00102       DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00103   // Contributed by anonymous person on SourceForge
00104   { "Samsung", 0x04e8, "YH-J70J", 0x5033, DEVICE_FLAG_UNLOAD_DRIVER },
00105   // From XNJB user
00106   // Guessing on .spl flag
00107   { "Samsung", 0x04e8, "YP-Z5", 0x503c, DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_PLAYLIST_SPL_V1 },
00108   // Don't add 0x5041 as this is YP-Z5 in USB mode
00109   // Contributed by anonymous person on SourceForge
00110   { "Samsung", 0x04e8, "YP-T7J", 0x5047, DEVICE_FLAG_NONE },
00111   // Reported by cstrickler@gmail.com
00112   { "Samsung", 0x04e8, "YP-U2J (YP-U2JXB/XAA)", 0x5054, DEVICE_FLAG_UNLOAD_DRIVER },
00113   // Reported by Andrew Benson
00114   { "Samsung", 0x04e8, "YP-F2J", 0x5057, DEVICE_FLAG_UNLOAD_DRIVER },
00115   // Reported by Patrick <skibler@gmail.com>
00116   // Just guessing but looks like .spl v1 http://www.anythingbutipod.com/forum/showthread.php?t=14160
00117   { "Samsung", 0x04e8, "YP-K5", 0x505a, DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_PLAYLIST_SPL_V1 },
00118   // From dev.local@gmail.com - 0x4e8/0x507c is the UMS mode, apparently
00119   // do not add that device.
00120   // From m.eik michalke
00121   // This device does NOT use the special SPL playlist according to sypqgjxu@gmx.de.
00122   { "Samsung", 0x04e8, "YP-U3", 0x507d, DEVICE_FLAG_NONE },
00123   // Reported by Matthew Wilcox <matthew@wil.cx>
00124   // Sergio <sfrdll@tiscali.it> reports this device need the BROKEN ALL flag.
00125   // Guessing on .spl flag
00126   { "Samsung", 0x04e8, "YP-T9", 0x507f, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL | DEVICE_FLAG_PLAYLIST_SPL_V1 },
00127   // From Paul Clinch
00128   // Just guessing but looks like .spl v1 http://www.anythingbutipod.com/forum/showthread.php?t=14160
00129   // Some versions of the firmware reportedly support OGG, reportedly only the
00130   // UMS versions, so MTP+OGG is not possible on this device.
00131   { "Samsung", 0x04e8, "YP-K3", 0x5081, DEVICE_FLAG_NONE | DEVICE_FLAG_PLAYLIST_SPL_V1 },
00132   // From XNJB user
00133   // From Alistair Boyle, .spl v2 required for playlists
00134   // According to the device log it properly supports OGG
00135   { "Samsung", 0x04e8, "YP-P2", 0x5083, DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_PLAYLIST_SPL_V2 },
00136   // From Paul Clinch
00137   // Guessing on .spl flag
00138   { "Samsung", 0x04e8, "YP-T10", 0x508a, DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_PLAYLIST_SPL_V1 | DEVICE_FLAG_NO_ZERO_READS },
00139   // From Wim Verwimp <wimverwimp@gmail.com>
00140   // Not sure about the Ogg and broken proplist flags here. Just guessing.
00141   // Guessing on .spl flag
00142   { "Samsung", 0x04e8, "YP-S5", 0x508b, DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_PLAYLIST_SPL_V1 },
00143   // From Ludovic Danigo
00144   // Guessing on .spl flag
00145   { "Samsung", 0x04e8, "YP-S3", 0x5091, DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_PLAYLIST_SPL_V1 },
00146   // From Adrian Levi <adrian.levi@gmail.com>
00147   // Guessing on .spl flag
00148   // This one supports OGG properly through the correct MTP type.
00149   { "Samsung", 0x04e8, "YP-U4", 0x5093, DEVICE_FLAG_NONE },
00150   // From Anonymous SourceForge user, NOT VERIFIED TO BE MTP
00151   // Guessing on .spl flag
00152   { "Samsung", 0x04e8, "YP-Q1", 0x5115, DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_PLAYLIST_SPL_V1 },
00153   // From a rouge .INF file,
00154   // this device ID seems to have been recycled for:
00155   // the Samsung SGH-A707 Cingular cellphone
00156   // the Samsung L760-V cellphone
00157   // the Samsung SGH-U900 cellphone
00158   { "Samsung", 0x04e8, "YH-999 Portable Media Center/SGH-A707/SGH-L760V/SGH-U900", 0x5a0f, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00159   // From Santi Béjar <sbejar@gmail.com> - not sure this is MTP...
00160   // { "Samsung", 0x04e8, "Z170 Mobile Phone", 0x6601, DEVICE_FLAG_UNLOAD_DRIVER },
00161   // From Santi Béjar <sbejar@gmail.com> - not sure this is MTP...
00162   // { "Samsung", 0x04e8, "E250 Mobile Phone", 0x663e, DEVICE_FLAG_UNLOAD_DRIVER },
00163   // From Lionel Bouton
00164   { "Samsung", 0x04e8, "X830 Mobile Phone", 0x6702, DEVICE_FLAG_NONE },
00165   // From James <jamestech@gmail.com>
00166   { "Samsung", 0x04e8, "U600 Mobile Phone", 0x6709, DEVICE_FLAG_UNLOAD_DRIVER },
00167   // From Cesar Cardoso <cesar@cesarcardoso.tk>
00168   // No confirmation that this is really MTP.
00169   { "Samsung", 0x04e8, "F250 Mobile Phone", 0x6727, DEVICE_FLAG_UNLOAD_DRIVER },
00170   // From Charlie Todd  2007-10-31
00171   { "Samsung", 0x04e8, "Juke (SCH-U470)", 0x6734, DEVICE_FLAG_UNLOAD_DRIVER},
00172 
00173   /*
00174    * Intel
00175    */
00176   { "Intel", 0x045e, "Bandon Portable Media Center", 0x00c9, DEVICE_FLAG_NONE },
00177   // Reported by Tadimarri Sarath <sarath.tadi@gmail.com>
00178   // No idea why this use an Intel PID, perhaps a leftover from
00179   // the early PMC development days when Intel and Microsoft were
00180   // partnering.
00181   { "Microsoft", 0x045e, "Windows MTP Simulator", 0x0622, DEVICE_FLAG_NONE },
00182 
00183   /*
00184    * JVC
00185    */
00186   // From Mark Veinot
00187   { "JVC", 0x04f1, "Alneo XA-HD500", 0x6105, DEVICE_FLAG_NONE },
00188 
00189   /*
00190    * Philips
00191    */
00192   { "Philips", 0x0471, "HDD6320/00 or HDD6330/17", 0x014b, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00193   // Anonymous SourceForge user
00194   { "Philips", 0x0471, "HDD14XX,HDD1620 or HDD1630/17", 0x014c, DEVICE_FLAG_NONE },
00195   // from discussion forum
00196   { "Philips", 0x0471, "HDD085/00 or HDD082/17", 0x014d, DEVICE_FLAG_NONE },
00197   // from XNJB forum
00198   { "Philips", 0x0471, "GoGear SA9200", 0x014f, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00199   // From John Coppens <jcoppens@users.sourceforge.net>
00200   { "Philips", 0x0471, "SA1115/55", 0x0164, DEVICE_FLAG_NONE },
00201   // From Gerhard Mekenkamp
00202   { "Philips", 0x0471, "GoGear Audio", 0x0165, DEVICE_FLAG_NONE },
00203   // from David Holm <wormie@alberg.dk>
00204   { "Philips", 0x0471, "Shoqbox", 0x0172, DEVICE_FLAG_ONLY_7BIT_FILENAMES },
00205   // from npedrosa
00206   { "Philips", 0x0471, "PSA610", 0x0181, DEVICE_FLAG_NONE },
00207   // From libgphoto2 source
00208   { "Philips", 0x0471, "HDD6320", 0x01eb, DEVICE_FLAG_NONE },
00209   // From Detlef Meier <dm@emlix.com>
00210   { "Philips", 0x0471, "GoGear SA6014/SA6015/SA6024/SA6025/SA6044/SA6045", 0x084e, DEVICE_FLAG_UNLOAD_DRIVER },
00211   // From anonymous Sourceforge user SA5145/02
00212   { "Philips", 0x0471, "GoGear SA5145", 0x0857, DEVICE_FLAG_UNLOAD_DRIVER },
00213   // From a
00214   { "Philips", 0x0471, "GoGear SA6125/SA6145/SA6185", 0x2002, DEVICE_FLAG_UNLOAD_DRIVER },
00215   // From anonymous Sourceforge user, not verified to be MTP!
00216   { "Philips", 0x0471, "GoGear SA3345", 0x2004, DEVICE_FLAG_UNLOAD_DRIVER },
00217   // From Roberto Vidmar <rvidmar@libero.it>
00218   { "Philips", 0x0471, "SA5285", 0x2022, DEVICE_FLAG_UNLOAD_DRIVER },
00219   // from XNJB user
00220   { "Philips", 0x0471, "PSA235", 0x7e01, DEVICE_FLAG_NONE },
00221 
00222 
00223   /*
00224    * SanDisk
00225    * several devices (c150 for sure) are definately dual-mode and must 
00226    * have the USB mass storage driver that hooks them unloaded first.
00227    * They all have problematic dual-mode making the device unload effect
00228    * uncertain on these devices.
00229    *
00230    * All older devices seem to need DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL.
00231    * Old chipsets: e200/c200 use PP5024 from Nvidia (formerly PortalPlayer).
00232    * m200 use TCC770 from Telechips.
00233    *
00234    * The newer Sansa v2 chipset, AD3525 from Austriamicrosystems (AMS) found 
00235    * in e280 v2 c200 v2, Clip, Fuze etc require DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST
00236    * and DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR to work properly.
00237    *
00238    * For more info see: http://daniel.haxx.se/sansa/v2.html
00239    */
00240   // Reported by Brian Robison
00241   { "SanDisk", 0x0781, "Sansa m230/m240", 0x7400, 
00242     DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
00243     DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
00244   // Reported by tangent_@users.sourceforge.net
00245   { "SanDisk", 0x0781, "Sansa c150", 0x7410, 
00246     DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
00247     DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
00248   // From libgphoto2 source
00249   // Reported by <gonkflea@users.sourceforge.net>
00250   // Reported by Mike Owen <mikeowen@computerbaseusa.com>
00251   { "SanDisk", 0x0781, "Sansa e200/e250/e260/e270/e280", 0x7420, 
00252     DEVICE_FLAG_UNLOAD_DRIVER |  DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
00253     DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
00254   // Reported by XNJB user
00255   { "SanDisk", 0x0781, "Sansa e280", 0x7421, 
00256     DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
00257     DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
00258   // Reported by XNJB user
00259   { "SanDisk", 0x0781, "Sansa e260/e280 v2", 0x7422, 
00260     DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
00261     DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
00262     DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
00263   // Reported by XNJB user
00264   { "SanDisk", 0x0781, "Sansa m240/m250", 0x7430, 
00265     DEVICE_FLAG_UNLOAD_DRIVER |  DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
00266     DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
00267   // Reported by Eugene Brevdo <ebrevdo@princeton.edu>
00268   { "SanDisk", 0x0781, "Sansa Clip", 0x7432,
00269     DEVICE_FLAG_UNLOAD_DRIVER |  DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
00270     DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
00271     DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
00272   // Reported by HackAR <hackar@users.sourceforge.net>
00273   { "SanDisk", 0x0781, "Sansa Clip v2", 0x7434,
00274     DEVICE_FLAG_UNLOAD_DRIVER |  DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
00275     DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
00276     DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
00277   // Reported by anonymous user at sourceforge.net
00278   { "SanDisk", 0x0781, "Sansa c240/c250", 0x7450, 
00279     DEVICE_FLAG_UNLOAD_DRIVER |  DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
00280     DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
00281   // Reported by anonymous SourceForge user
00282   { "SanDisk", 0x0781, "Sansa c250 v2", 0x7452, 
00283     DEVICE_FLAG_UNLOAD_DRIVER |  DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
00284     DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
00285   // Reported by Troy Curtis Jr.
00286   { "SanDisk", 0x0781, "Sansa Express", 0x7460, 
00287     DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | 
00288     DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
00289   // Reported by XNJB user, and Miguel de Icaza <miguel@gnome.org>
00290   // This has no dual-mode so no need to unload any driver.
00291   // This is a Linux based device!
00292   { "SanDisk", 0x0781, "Sansa Connect", 0x7480, DEVICE_FLAG_NONE },
00293   // Reported by anonymous SourceForge user
00294   { "SanDisk", 0x0781, "Sansa View", 0x74b0, 
00295     DEVICE_FLAG_UNLOAD_DRIVER |  DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
00296     DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
00297   // Reported by Patrick <skibler@gmail.com>
00298   // There are apparently problems with this device.
00299   { "SanDisk", 0x0781, "Sansa Fuze", 0x74c0,
00300     DEVICE_FLAG_UNLOAD_DRIVER |  DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
00301     DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
00302     DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
00303   // Harry Phillips <tuxcomputers@users.sourceforge.net>
00304   { "SanDisk", 0x0781, "Sansa Fuze v2", 0x74c2,
00305     DEVICE_FLAG_UNLOAD_DRIVER |  DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
00306     DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
00307     DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
00308 
00309   /*
00310    * iRiver
00311    * we assume that PTP_OC_MTP_GetObjPropList is essentially
00312    * broken on all iRiver devices, meaning it simply won't return
00313    * all properties for a file when asking for metadata 0xffffffff. 
00314    * Please test on your device if you believe it isn't broken!
00315    */
00316   { "iRiver", 0x1006, "Portable Media Center", 0x4002, 
00317     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00318     DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
00319   { "iRiver", 0x1006, "Portable Media Center", 0x4003, 
00320     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00321     DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
00322   // From [st]anislav <iamstanislav@gmail.com>
00323   { "iRiver", 0x1042, "T7 Volcano", 0x1143, DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
00324   // From an anonymous person at SourceForge, uncertain about this one
00325   { "iRiver", 0x4102, "iFP-880", 0x1008, 
00326     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00327     DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
00328   // 0x4102, 0x1042 is a USB mass storage mode for E100 v2/Lplayer
00329   // From libgphoto2 source
00330   { "iRiver", 0x4102, "T10", 0x1113, 
00331     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00332     DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
00333   { "iRiver", 0x4102, "T20 FM", 0x1114, 
00334     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00335     DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
00336   // This appears at the MTP-UMS site
00337   { "iRiver", 0x4102, "T20", 0x1115, 
00338     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00339     DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
00340   { "iRiver", 0x4102, "U10", 0x1116, 
00341     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00342     DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
00343   { "iRiver", 0x4102, "T10a", 0x1117, 
00344     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00345     DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
00346   { "iRiver", 0x4102, "T20", 0x1118, 
00347     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00348     DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
00349   { "iRiver", 0x4102, "T30", 0x1119, 
00350     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00351     DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
00352   // Reported by David Wolpoff
00353   { "iRiver", 0x4102, "T10 2GB", 0x1120, 
00354     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00355     DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
00356   // Rough guess this is the MTP device ID...
00357   { "iRiver", 0x4102, "N12", 0x1122, 
00358     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00359     DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
00360   // Reported by Philip Antoniades <philip@mysql.com>
00361   // Newer iriver devices seem to have shaped-up firmware without any
00362   // of the annoying bugs.
00363   { "iRiver", 0x4102, "Clix2", 0x1126, DEVICE_FLAG_NONE },
00364   // Reported by Adam Torgerson
00365   { "iRiver", 0x4102, "Clix", 0x112a, 
00366     DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
00367   // Reported by Douglas Roth <dougaus@gmail.com>
00368   { "iRiver", 0x4102, "X20", 0x1132, 
00369     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00370     DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
00371   // Reported by Robert Ugo <robert_ugo@users.sourceforge.net>
00372   { "iRiver", 0x4102, "T60", 0x1134, 
00373     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00374     DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
00375   // Reported by two anonymous SourceForge users
00376   // Needs the stronger OGG_IS_UNKNOWN flag to support OGG properly,
00377   // be aware of newer players that may be needing this too.
00378   { "iRiver", 0x4102, "E100", 0x1141, 
00379     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00380     DEVICE_FLAG_OGG_IS_UNKNOWN },
00381   // Reported by anonymous SourceForge user
00382   // Need verification of whether this firmware really need all these flags
00383   { "iRiver", 0x4102, "E100 v2/Lplayer", 0x1142, 
00384     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00385     DEVICE_FLAG_OGG_IS_UNKNOWN },
00386   // Reported by Richard Vennemann <vennemann@users.sourceforge.net>
00387   // In USB Mass Storage mode it is 0x4102/0x1047
00388   // Seems to use the new shaped-up firmware.
00389   { "iRiver", 0x4102, "Spinn", 0x1147, DEVICE_FLAG_NONE },
00390   // Reported by Scott Call
00391   // Assume this actually supports OGG though it reports it doesn't.
00392   { "iRiver", 0x4102, "H10 20GB", 0x2101, 
00393     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00394     DEVICE_FLAG_OGG_IS_UNKNOWN },
00395   { "iRiver", 0x4102, "H10", 0x2102, 
00396     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS | 
00397     DEVICE_FLAG_OGG_IS_UNKNOWN },
00398 
00399 
00400   /*
00401    * Dell
00402    */
00403   { "Dell, Inc", 0x413c, "DJ Itty", 0x4500, DEVICE_FLAG_NONE },
00404   
00405   /*
00406    * Toshiba
00407    * Tentatively flagged all Toshiba devices with
00408    * DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST after one of them
00409    * showed erroneous behaviour.
00410    */
00411   { "Toshiba", 0x0930, "Gigabeat MEGF-40", 0x0009,
00412     DEVICE_FLAG_NO_RELEASE_INTERFACE |  DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
00413   { "Toshiba", 0x0930, "Gigabeat", 0x000c,
00414     DEVICE_FLAG_NO_RELEASE_INTERFACE |  DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
00415   // Reported by Nicholas Tripp
00416   { "Toshiba", 0x0930, "Gigabeat P20", 0x000f,
00417     DEVICE_FLAG_NO_RELEASE_INTERFACE |  DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
00418   // From libgphoto2
00419   { "Toshiba", 0x0930, "Gigabeat S", 0x0010, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
00420       DEVICE_FLAG_NO_RELEASE_INTERFACE |  DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
00421   // Reported by Rob Brown
00422   { "Toshiba", 0x0930, "Gigabeat P10", 0x0011,
00423     DEVICE_FLAG_NO_RELEASE_INTERFACE |  DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
00424   // Reported by solanum@users.sourceforge.net
00425   { "Toshiba", 0x0930, "Gigabeat V30", 0x0014,
00426     DEVICE_FLAG_NO_RELEASE_INTERFACE |  DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
00427   // Reported by Michael Davis <slithy@yahoo.com>
00428   { "Toshiba", 0x0930, "Gigabeat U", 0x0016,
00429     DEVICE_FLAG_NO_RELEASE_INTERFACE |  DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
00430   // Reported by Devon Jacobs <devo@godevo.com>
00431   { "Toshiba", 0x0930, "Gigabeat MEU202", 0x0018,
00432     DEVICE_FLAG_NO_RELEASE_INTERFACE |  DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
00433   // Reported by Rolf <japan (at) dl3lar.de>
00434   { "Toshiba", 0x0930, "Gigabeat T", 0x0019,
00435     DEVICE_FLAG_NO_RELEASE_INTERFACE |  DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
00436   // Reported by Phil Ingram <ukpbert@users.sourceforge.net>
00437   // Tentatively added - no real reports of this device ID being MTP,
00438   // reports as USB Mass Storage currently.
00439   { "Toshiba", 0x0930, "Gigabeat MEU201", 0x001a,
00440     DEVICE_FLAG_NO_RELEASE_INTERFACE |  DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
00441   // Reported by anonymous SourceForge user
00442   { "Toshiba", 0x0930, "Gigabeat MET401", 0x001d,
00443     DEVICE_FLAG_NO_RELEASE_INTERFACE |  DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
00444 
00445   
00446   /*
00447    * Archos
00448    * These devices have some dual-mode interfaces which will really
00449    * respect the driver unloading, so DEVICE_FLAG_UNLOAD_DRIVER
00450    * really work on these devices!
00451    */
00452   // Reported by Alexander Haertig <AlexanderHaertig@gmx.de>
00453   { "Archos", 0x0e79, "Gmini XS100", 0x1207, DEVICE_FLAG_UNLOAD_DRIVER },
00454   // Added by Jan Binder
00455   { "Archos", 0x0e79, "XS202 (MTP mode)", 0x1208, DEVICE_FLAG_NONE },
00456   // Reported by gudul1@users.sourceforge.net
00457   { "Archos", 0x0e79, "104 (MTP mode)", 0x120a, DEVICE_FLAG_NONE },
00458   // Reported by anonymous Sourceforge user.
00459   { "Archos", 0x0e79, "404 (MTP mode)", 0x1301, DEVICE_FLAG_UNLOAD_DRIVER },
00460   // Reported by Etienne Chauchot <chauchot.etienne@free.fr>
00461   { "Archos", 0x0e79, "504 (MTP mode)", 0x1307, DEVICE_FLAG_UNLOAD_DRIVER },
00462   // Reported by Kay McCormick <kaym@modsystems.com>
00463   { "Archos", 0x0e79, "704 mobile dvr", 0x130d, DEVICE_FLAG_UNLOAD_DRIVER },
00464   // Reported by Joe Rabinoff
00465   { "Archos", 0x0e79, "605 (MTP mode)", 0x1313, DEVICE_FLAG_UNLOAD_DRIVER },
00466   // Reported by Adrien Guichard <tmor@users.sourceforge.net>
00467   { "Archos", 0x0e79, "5 (MTP mode)", 0x1333, DEVICE_FLAG_UNLOAD_DRIVER },
00468 
00469   /*
00470    * Dunlop (OEM of EGOMAN ltd?) reported by Nanomad
00471    * This unit is falsely detected as USB mass storage in Linux
00472    * prior to kernel 2.6.19 (fixed by patch from Alan Stern)
00473    * so on older kernels special care is needed to remove the
00474    * USB mass storage driver that erroneously binds to the device
00475    * interface.
00476    */
00477   { "Dunlop", 0x10d6, "MP3 player 1GB / EGOMAN MD223AFD", 0x2200, DEVICE_FLAG_UNLOAD_DRIVER},
00478   // Reported by Steven Black <stevenblack1956@users.sourceforge.net>
00479   // Obviously this company goes by many names.
00480   // This device is USB 2.0 only. Broken pipe on closing.
00481   { "Memorex", 0x10d6, "MMP 8585/8586", 0x2300, DEVICE_FLAG_UNLOAD_DRIVER | 
00482       DEVICE_FLAG_NO_RELEASE_INTERFACE},
00483   
00484   /*
00485    * Microsoft
00486    */
00487   // Reported by Farooq Zaman (used for all Zunes)
00488   { "Microsoft", 0x045e, "Zune", 0x0710, DEVICE_FLAG_NONE }, 
00489   
00490   /*
00491    * Sirius
00492    */
00493   { "Sirius", 0x18f6, "Stiletto", 0x0102, DEVICE_FLAG_NONE },
00494   // Reported by Chris Bagwell <chris@cnpbagwell.com>
00495   { "Sirius", 0x18f6, "Stiletto 2", 0x0110, DEVICE_FLAG_NONE },
00496 
00497   /*
00498    * Canon
00499    * This is actually a camera, but it has a Microsoft device descriptor
00500    * and reports itself as supporting the MTP extension.
00501    */
00502   { "Canon", 0x04a9, "PowerShot A640 (PTP/MTP mode)", 0x3139,
00503      DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00504 
00505   /*
00506    * Nokia
00507    * Please verify the low device IDs here, I suspect these might be for
00508    * things like USB storage or modem mode actually, whereas the higher
00509    * range (0x04nn) could be for MTP. Some of the devices were gathered
00510    * from the Nokia WMP drivers:
00511    * http://nds2.nokia.com/files/support/global/phones/software/
00512    * Address was gathered from going to:
00513    * nseries.com
00514    * -> support
00515    * -> select supported device
00516    *  -> PC software
00517    *    -> Music software
00518    *      -> Windows Media Player 10 driver
00519    */
00520   // From: DoomHammer <gaczek@users.sourceforge.net>
00521   { "Nokia", 0x0421, "N81 Mobile Phone", 0x000a, DEVICE_FLAG_NONE },
00522   // From an anonymous SourceForge user
00523   { "Nokia", 0x0421, "6120c Classic Mobile Phone", 0x002e, DEVICE_FLAG_NONE },
00524   // From Stefano
00525   { "Nokia", 0x0421, "N96 Mobile Phone", 0x0039, DEVICE_FLAG_NONE },
00526   // From Martijn van de Streek <martijn@vandestreek.net>
00527   { "Nokia", 0x0421, "6500c Classic Mobile Phone", 0x003c, DEVICE_FLAG_NONE },
00528   // From: DoomHammer <gaczek@users.sourceforge.net>
00529   { "Nokia", 0x0421, "3110c Mobile Phone", 0x005f, DEVICE_FLAG_NONE },
00530   // From: Vasily <spc-@users.sourceforge.net>
00531   { "Nokia", 0x0421, "3109c Mobile Phone", 0x0065, DEVICE_FLAG_NONE },
00532   // From: <rawc@users.sourceforge.net>
00533   { "Nokia", 0x0421, "5310 XpressMusic", 0x006c, DEVICE_FLAG_NONE },
00534   // From: robin (AT) headbank D0Tco DOTuk
00535   { "Nokia", 0x0421, "N95 Mobile Phone 8GB", 0x006e, DEVICE_FLAG_NONE },
00536   // From Bastien Nocera <hadess@hadess.net>
00537   { "Nokia", 0x0421, "N82 Mobile Phone", 0x0074, DEVICE_FLAG_NONE },
00538   // From Martijn van de Streek <martijn@vandestreek.net>
00539   { "Nokia", 0x0421, "N78 Mobile Phone", 0x0079, DEVICE_FLAG_NONE },
00540   // From William Pettersson <the_enigma@users.sourceforge.net>
00541   { "Nokia", 0x0421, "6220 Classic", 0x008d, DEVICE_FLAG_NONE },
00542   // From kellerkev@gmail.com
00543   { "Nokia", 0x0421, "N85 Mobile Phone", 0x0092, DEVICE_FLAG_NONE },
00544   // From: danielw
00545   { "Nokia", 0x0421, "E71", 0x00e4, DEVICE_FLAG_NONE },
00546   // From: Laurent Bigonville <bigon@users.sourceforge.net>
00547   { "Nokia", 0x0421, "E66", 0x00e5, DEVICE_FLAG_NONE },
00548   // From: Willy Gardiol (web) <willy@gardiol.org>
00549   // Spurious errors for getting all objects, lead me to believe this flag atleast is needed
00550   { "Nokia", 0x0421, "5800 XpressMusic", 0x0155, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00551   // From an anonymous SourceForge user
00552   // Not verified to be MTP
00553   { "Nokia", 0x0421, "E63", 0x0179, DEVICE_FLAG_NONE },
00554   // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_3250_WMP10_driver.inf
00555   { "Nokia", 0x0421, "3250 Mobile Phone", 0x0462, DEVICE_FLAG_NONE },
00556   // From http://nds2.nokia.com/files/support/global/phones/software/Nokia_N93_WMP10_Driver.inf
00557   { "Nokia", 0x0421, "N93 Mobile Phone", 0x0478, DEVICE_FLAG_NONE },
00558   // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_5500_Sport_WMP10_driver.inf
00559   { "Nokia", 0x0421, "5500 Sport Mobile Phone", 0x047e, DEVICE_FLAG_NONE },
00560   // From http://nds2.nokia.com/files/support/global/phones/software/Nokia_N91_WMP10_Driver.inf
00561   { "Nokia", 0x0421, "N91 Mobile Phone", 0x0485, DEVICE_FLAG_NONE },
00562   // From: Christian Rusa <kristous@users.sourceforge.net>
00563   { "Nokia", 0x0421, "5700 XpressMusic Mobile Phone", 0x04b4, DEVICE_FLAG_NONE },
00564   // From: Mitchell Hicks <mitchix@yahoo.com>
00565   { "Nokia", 0x0421, "5300 Mobile Phone", 0x04ba, DEVICE_FLAG_NONE },
00566   // From Christian Arnold <webmaster@arctic-media.de>
00567   { "Nokia", 0x0421, "N73 Mobile Phone", 0x04d1, DEVICE_FLAG_UNLOAD_DRIVER },
00568   // From Swapan <swapan@yahoo.com>
00569   { "Nokia", 0x0421, "N75 Mobile Phone", 0x04e1, DEVICE_FLAG_NONE },
00570   // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_N93i_WMP10_driver.inf
00571   { "Nokia", 0x0421, "N93i Mobile Phone", 0x04e5, DEVICE_FLAG_NONE },
00572   // From Anonymous Sourceforge User
00573   { "Nokia", 0x0421, "N95 Mobile Phone", 0x04ef, DEVICE_FLAG_NONE },
00574   // From: Pat Nicholls <pat@patandannie.co.uk>
00575   { "Nokia", 0x0421, "N80 Internet Edition (Media Player)", 0x04f1, DEVICE_FLAG_UNLOAD_DRIVER },
00576   // Reported by anonymous SourceForge user
00577   // One thing stated by reporter (Nokia model) another by the detect log...
00578   { "Nokia/Verizon", 0x05c6, "6205 Balboa/Verizon Music Phone", 0x3196, DEVICE_FLAG_NONE },
00579 
00580 
00581   /*
00582    * LOGIK
00583    * Sold in the UK, seem to be manufactured by CCTech in China.
00584    */
00585   { "Logik", 0x13d1, "LOG DAX MP3 and DAB Player", 0x7002, DEVICE_FLAG_UNLOAD_DRIVER },
00586 
00587   /*
00588    * RCA / Thomson
00589    */
00590   // From kiki <omkiki@users.sourceforge.net>
00591   { "Thomson", 0x069b, "EM28 Series", 0x0774, DEVICE_FLAG_NONE },
00592   { "Thomson / RCA", 0x069b, "Opal / Lyra MC4002", 0x0777, DEVICE_FLAG_NONE },
00593   { "Thomson", 0x069b, "Lyra MC5104B (M51 Series)", 0x077c, DEVICE_FLAG_NONE },
00594   { "Thomson", 0x069b, "RCA H106", 0x301a, DEVICE_FLAG_UNLOAD_DRIVER },
00595   // From Svenna <svenna@svenna.de>
00596   // Not confirmed to be MTP.
00597   { "Thomson", 0x069b, "scenium E308", 0x3028, DEVICE_FLAG_NONE },
00598   // From XNJB user
00599   { "Thomson / RCA", 0x069b, "Lyra HC308A", 0x3035, DEVICE_FLAG_NONE },
00600   
00601   /*
00602    * NTT DoCoMo
00603    */
00604   { "FOMA", 0x04c5, "F903iX HIGH-SPEED", 0x1140, DEVICE_FLAG_NONE },
00605 
00606   /*
00607    * Palm device userland program named Pocket Tunes
00608    * Reported by Peter Gyongyosi <gyp@impulzus.com>
00609    */
00610   { "NormSoft, Inc.", 0x1703, "Pocket Tunes", 0x0001, DEVICE_FLAG_NONE },
00611   // Reported by anonymous submission
00612   { "NormSoft, Inc.", 0x1703, "Pocket Tunes 4", 0x0002, DEVICE_FLAG_NONE },
00613 
00614   /*
00615    * TrekStor and Medion devices
00616    * Their datasheet claims their devices are dualmode so probably needs to
00617    * unload the attached drivers here.
00618    */
00619   // Reported by Stefan Voss <svoss@web.de>
00620   // This is a Sigmatel SoC with a hard disk.
00621   { "TrekStor", 0x066f, "Vibez 8/12GB", 0x842a, 
00622     DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
00623   // Reported by anonymous SourceForge user.
00624   // This one done for Medion, whatever that is. Error reported so assume
00625   // the same bug flag as its ancestor above.
00626   { "Medion", 0x066f, "MD8333", 0x8550,
00627     DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
00628   // Reported by anonymous Sourceforge user
00629   { "Medion", 0x066f, "MD8333", 0x8588,
00630     DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
00631   // Reported by Cristi Magherusan <majeru@gentoo.ro>
00632   { "TrekStor", 0x0402, "i.Beat Sweez FM", 0x0611, 
00633     DEVICE_FLAG_UNLOAD_DRIVER },
00634   
00635   /*
00636    * Disney/Tevion (have had no reports of these actually working.)
00637    */
00638   // Reported by XNJB user
00639   { "Disney", 0x0aa6, "MixMax", 0x6021, DEVICE_FLAG_NONE },
00640   // Reported by anonymous Sourceforge user 
00641   { "Tevion", 0x0aa6, "MD 81488", 0x3011, DEVICE_FLAG_NONE },
00642 
00643   /*
00644    * Cowon Systems, Inc.
00645    * The iAudio audiophile devices don't encourage the use of MTP.
00646    */
00647   // Reported by Patrik Johansson <Patrik.Johansson@qivalue.com>
00648   { "Cowon", 0x0e21, "iAudio U3 (MTP mode)", 0x0701,
00649    DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
00650   // Reported by Kevin Michael Smith <hai-etlik@users.sourceforge.net>
00651   { "Cowon", 0x0e21, "iAudio 6 (MTP mode)", 0x0711,
00652    DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
00653   // Reported by Roberth Karman
00654   { "Cowon", 0x0e21, "iAudio 7 (MTP mode)", 0x0751,
00655    DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
00656   // Reported by an anonymous SourceForge user
00657   { "Cowon", 0x0e21, "iAudio U5 (MTP mode)", 0x0761,
00658    DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
00659   // Reported by TJ Something <tjbk_tjb@users.sourceforge.net>
00660   { "Cowon", 0x0e21, "iAudio D2 (MTP mode)", 0x0801, 
00661    DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
00662 
00663   /*
00664    * Insignia, dual-mode.
00665    */
00666   { "Insignia", 0x19ff, "NS-DV45", 0x0303, DEVICE_FLAG_UNLOAD_DRIVER },
00667   // Reported by Rajan Bella <rajanbella@yahoo.com>
00668   { "Insignia", 0x19ff, "Sport Player", 0x0307, DEVICE_FLAG_UNLOAD_DRIVER },
00669   // Reported by "brad" (anonymous, sourceforge)
00670   { "Insignia", 0x19ff, "Pilot 4GB", 0x0309, DEVICE_FLAG_UNLOAD_DRIVER },
00671 
00672   /*
00673    * LG Electronics
00674    */
00675   // Not verified - anonymous submission
00676   { "LG Electronics Inc.", 0x043e, "UP3", 0x70b1, DEVICE_FLAG_NONE },
00677   // Reported by Joseph Nahmias <joe@nahimas.net>
00678   { "LG Electronics Inc.", 0x1004, "VX8550 V CAST Mobile Phone", 0x6010,
00679       DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR },
00680   // Reported by Cyrille Potereau <cyrille.potereau@wanadoo.fr>
00681   { "LG Electronics Inc.", 0x1004, "KC910 Renoir Mobile Phone", 0x608f,
00682       DEVICE_FLAG_UNLOAD_DRIVER },
00683 
00684   /*
00685    * Sony
00686    * It could be that these PIDs are one-per hundred series, so
00687    * NWZ-A8xx is 0325, NWZ-S5xx is 0x326 etc. We need more devices
00688    * reported to see a pattern here.
00689    */
00690   // Reported by Alessandro Radaelli <alessandro.radaelli@aruba.it>
00691   { "Sony", 0x054c, "Walkman NWZ-A815/NWZ-A818", 0x0325, DEVICE_FLAG_UNLOAD_DRIVER },
00692   // Reported by anonymous Sourceforge user.
00693   { "Sony", 0x054c, "Walkman NWZ-S516", 0x0326, DEVICE_FLAG_UNLOAD_DRIVER },
00694   // Reported by Endre Oma <endre.88.oma@gmail.com>
00695   { "Sony", 0x054c, "Walkman NWZ-S615F/NWZ-S616F/NWZ-S618F", 0x0327, DEVICE_FLAG_UNLOAD_DRIVER },
00696   // Reported by Jean-Marc Bourguet <jm@bourguet.org>
00697   { "Sony", 0x054c, "Walkman NWZ-S716F", 0x035a, DEVICE_FLAG_UNLOAD_DRIVER },
00698   // Reported by Anon SF User / Anthon van der Neut <avanderneut@avid.com>
00699   { "Sony", 0x054c, "Walkman NWZ-A826/NWZ-A828/NWZ-A829", 0x035b, DEVICE_FLAG_UNLOAD_DRIVER },
00700   // Reported by Niek Klaverstijn <niekez@users.sourceforge.net>
00701   { "Sony", 0x054c, "Walkman NWZ-A726/NWZ-A728/NWZ-A768", 0x035c, DEVICE_FLAG_UNLOAD_DRIVER },
00702   // Reported by Mehdi AMINI <mehdi.amini - at - ulp.u-strasbg.fr>
00703   { "Sony", 0x054c, "Walkman NWZ-B135", 0x036e, DEVICE_FLAG_UNLOAD_DRIVER },
00704   // Reported by <tiagoboldt@users.sourceforge.net>
00705   { "Sony", 0x054c, "Walkman NWZ-E436F", 0x0385, DEVICE_FLAG_UNLOAD_DRIVER },
00706   // Reported by Ondrej Sury <ondrej@sury.org>
00707   { "Sony", 0x054c, "Walkman NWZ-S739F", 0x038c, DEVICE_FLAG_UNLOAD_DRIVER },
00708   // Reported by Marco Filipe Nunes Soares Abrantes Pereira <marcopereira@ua.pt>
00709   { "Sony", 0x054c, "Walkman NWZ-S638F", 0x038e, DEVICE_FLAG_UNLOAD_DRIVER },
00710 
00711 
00712   /*
00713    * SonyEricsson
00714    * These initially seemed to support GetObjPropList but later revisions
00715    * of the firmware seem to have broken it, so all are flagged as broken
00716    * for now.
00717    */
00718   // Reported by Øyvind Stegard <stegaro@users.sourceforge.net>
00719   { "SonyEricsson", 0x0fce, "K850i", 0x0075, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
00720   // Reported by Michael Eriksson
00721   { "SonyEricsson", 0x0fce, "W910", 0x0076, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
00722   // Reported by Zack <zackdvd@users.sourceforge.net>
00723   { "SonyEricsson", 0x0fce, "W890i", 0x00b3, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
00724   // Reported by robert dot ahlskog at gmail
00725   { "SonyEricsson", 0x0fce, "W760i", 0x00c6, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
00726   // Reported by Linus Åkesson <linusakesson@users.sourceforge.net>
00727   { "SonyEricsson", 0x0fce, "C902", 0x00d4, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
00728   // Reported by an anonymous SourceForge user
00729   { "SonyEricsson", 0x0fce, "C702", 0x00d9, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
00730   // Reported by Christian Zuckschwerdt <christian@zuckschwerdt.org>
00731   { "SonyEricsson", 0x0fce, "W980", 0x00da, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
00732   // Reported by Mattias Evensson <mevensson@users.sourceforge.net>
00733   { "SonyEricsson", 0x0fce, "W902", 0x00f5, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
00734 
00735   /*
00736    * Motorola
00737    * Assume DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST on all of these.
00738    */
00739   // Reported by David Boyd <tiggrdave@users.sourceforge.net>
00740   { "Motorola", 0x22b8, "V3m/V750 verizon", 0x2a65, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST |
00741     DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
00742   // Reported by Marcus Meissner to libptp2
00743   { "Motorola", 0x22b8, "K1", 0x4811, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
00744   // Reported by Hans-Joachim Baader <hjb@pro-linux.de> to libptp2
00745   { "Motorola", 0x22b8, "A1200", 0x60ca, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
00746   // http://mark.cdmaforums.com/Files/Motdmmtp.inf
00747   { "Motorola", 0x22b8, "MTP Test Command Interface", 0x6413, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
00748   // Reported by anonymous user
00749   { "Motorola", 0x22b8, "RAZR2 V8/U9/Z6", 0x6415, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
00750   
00751 
00752   /*
00753    * Media Keg
00754    */
00755   // Reported by Rajan Bella <rajanbella@yahoo.com>
00756   { "Kenwood", 0x0b28, "Media Keg HD10GB7 Sport Player", 0x100c, DEVICE_FLAG_UNLOAD_DRIVER},
00757 
00758   /*
00759    * Micro-Star International (MSI)
00760    */
00761   // Reported by anonymous sourceforge user.
00762   { "Micro-Star International", 0x0db0, "P610/Model MS-5557", 0x5572, DEVICE_FLAG_NONE },
00763 
00764   /*
00765    * FOMA
00766    */
00767   { "FOMA", 0x06d3, "D905i", 0x21ba, DEVICE_FLAG_NONE },
00768 
00769   /*
00770    * Haier
00771    */
00772   // Both reported by an anonymous SourceForge user
00773   // This is the 30 GiB model
00774   { "Haier", 0x1302, "Ibiza Rhapsody", 0x1016, DEVICE_FLAG_NONE },
00775   // This is the 4/8 GiB model
00776   { "Haier", 0x1302, "Ibiza Rhapsody", 0x1017, DEVICE_FLAG_NONE },
00777   
00778   /*
00779    * Panasonic
00780    */
00781   // Reported by dmizer
00782   { "Panasonic", 0x04da, "P905i", 0x2145, DEVICE_FLAG_NONE },
00783 
00784   /*
00785    * Polaroid
00786    */
00787   { "Polaroid", 0x0546, "Freescape/MPU-433158", 0x2035, DEVICE_FLAG_NONE },
00788 
00789   /*
00790    * Pioneer
00791    */
00792   // Reported by Dan Allen <dan.j.allen@gmail.com>
00793   { "Pioneer", 0x08e4, "XMP3", 0x0148, DEVICE_FLAG_NONE },
00794 
00795   /*
00796    * Slacker Inc.
00797    * Put in all evilness flags because it looks fragile.
00798    */
00799   // Reported by Pug Fantus <pugfantus@users.sourceforge.net>
00800   { "Slacker Inc.", 0x1bdc, "Slacker Portable Media Player", 0xfabf,
00801     DEVICE_FLAG_BROKEN_BATTERY_LEVEL | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
00802     DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
00803 
00804   /*
00805    * Other strange stuff.
00806    */
00807   { "Isabella", 0x0b20, "Her Prototype", 0xddee, DEVICE_FLAG_NONE }

Generated on Sun Aug 23 04:57:15 2009 for libmtp by  doxygen 1.5.8