blob: 07a05e9c0ed397e63e20d94c3d0b26cb4da72da8 [file] [log] [blame]
Linus Walleij3e667ae2007-10-29 23:29:39 +00001/**
Linus Walleij1a673de2007-10-29 23:10:05 +00002 * \file music-players.h
3 * List of music players as USB ids.
4 *
5 * Copyright (C) 2005-2007 Richard A. Low <richard@wentnet.com>
Linus Walleij2c414c42008-01-19 07:11:19 +00006 * Copyright (C) 2005-2008 Linus Walleij <triad@df.lth.se>
Linus Walleij1a673de2007-10-29 23:10:05 +00007 * Copyright (C) 2006-2007 Marcus Meissner
8 * Copyright (C) 2007 Ted Bullock
9 *
10 * This library is free software; you can redistribute it and/or
11 * modify it under the terms of the GNU Lesser General Public
12 * License as published by the Free Software Foundation; either
13 * version 2 of the License, or (at your option) any later version.
14 *
15 * This library is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 * Lesser General Public License for more details.
19 *
20 * You should have received a copy of the GNU Lesser General Public
21 * License along with this library; if not, write to the
22 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
23 * Boston, MA 02111-1307, USA.
24 *
Linus Walleij1a673de2007-10-29 23:10:05 +000025 * This file is supposed to be included within a struct from both libmtp
26 * and libgphoto2.
Linus Walleijf0702982008-10-25 21:37:43 +000027 *
28 * Information can be harvested from Windows driver .INF files, see:
29 * http://msdn.microsoft.com/en-us/library/aa973606.aspx
Linus Walleij1a673de2007-10-29 23:10:05 +000030 */
Linus Walleij1a673de2007-10-29 23:10:05 +000031/*
32 * MTP device list, trying real bad to get all devices into
33 * this list by stealing from everyone I know.
34 */
35
36 /*
37 * Creative Technology
38 * Initially the Creative devices was all we supported so these are
39 * the most thoroughly tested devices. Presumably only the devices
40 * with older firmware (the ones that have 32bit object size) will
Linus Walleijcc2cf972007-11-22 20:23:43 +000041 * need the DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL flag. This bug
42 * manifest itself when you have a lot of folders on the device,
43 * some of the folders will start to disappear when getting all objects
44 * and properties.
Linus Walleij1a673de2007-10-29 23:10:05 +000045 */
Linus Walleij780b3902008-09-11 22:17:00 +000046 { "Creative", 0x041e, "ZEN Vision", 0x411f, DEVICE_FLAG_NONE },
47 { "Creative", 0x041e, "Portable Media Center", 0x4123, DEVICE_FLAG_NONE },
48 { "Creative", 0x041e, "ZEN Xtra (MTP mode)", 0x4128, DEVICE_FLAG_NONE },
49 { "Dell", 0x041e, "DJ (2nd generation)", 0x412f, DEVICE_FLAG_NONE },
50 { "Creative", 0x041e, "ZEN Micro (MTP mode)", 0x4130, DEVICE_FLAG_NONE },
51 { "Creative", 0x041e, "ZEN Touch (MTP mode)", 0x4131, DEVICE_FLAG_NONE },
52 { "Dell", 0x041e, "Dell Pocket DJ (MTP mode)", 0x4132, DEVICE_FLAG_NONE },
53 { "Creative", 0x041e, "ZEN Sleek (MTP mode)", 0x4137, DEVICE_FLAG_NONE },
54 { "Creative", 0x041e, "ZEN MicroPhoto", 0x413c, DEVICE_FLAG_NONE },
55 { "Creative", 0x041e, "ZEN Sleek Photo", 0x413d, DEVICE_FLAG_NONE },
56 { "Creative", 0x041e, "ZEN Vision:M", 0x413e, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +000057 // Reported by marazm@o2.pl
Linus Walleij780b3902008-09-11 22:17:00 +000058 { "Creative", 0x041e, "ZEN V", 0x4150, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +000059 // Reported by danielw@iinet.net.au
60 // This version of the Vision:M needs the no release interface flag,
61 // unclear whether the other version above need it too or not.
Linus Walleij1d0e84f2007-11-02 21:05:35 +000062 { "Creative", 0x041e, "ZEN Vision:M (DVP-HD0004)", 0x4151,
Linus Walleij780b3902008-09-11 22:17:00 +000063 DEVICE_FLAG_NO_RELEASE_INTERFACE },
Linus Walleij1a673de2007-10-29 23:10:05 +000064 // Reported by Darel on the XNJB forums
65 { "Creative", 0x041e, "ZEN V Plus", 0x4152, DEVICE_FLAG_NONE },
66 { "Creative", 0x041e, "ZEN Vision W", 0x4153, DEVICE_FLAG_NONE },
Richard Lowa11a6ad2008-01-21 17:23:55 +000067 // Don't add 0x4155: this is a Zen Stone device which is not MTP
Linus Walleij1a673de2007-10-29 23:10:05 +000068 // Reported by Paul Kurczaba <paul@kurczaba.com>
Richard Lowef197312008-11-01 18:29:41 +000069 { "Creative", 0x041e, "ZEN", 0x4157, DEVICE_FLAG_IGNORE_HEADER_ERRORS | DEVICE_FLAG_BROKEN_SET_SAMPLE_DIMENSIONS | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +000070 // Reported by Ringofan <mcroman@users.sourceforge.net>
71 { "Creative", 0x041e, "ZEN V 2GB", 0x4158, DEVICE_FLAG_NONE },
Linus Walleijf0ea0292008-09-10 06:52:16 +000072 // Reported by j norment <stormzen@gmail.com>
73 { "Creative", 0x041e, "ZEN Mozaic", 0x4161, DEVICE_FLAG_NONE },
Linus Walleijc2bc9732008-08-14 21:12:44 +000074 // Reported by Aaron F. Gonzalez <sub_tex@users.sourceforge.net>
75 { "Creative", 0x041e, "ZEN X-Fi", 0x4162, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +000076
77 /*
78 * Samsung
79 * We suspect that more of these are dual mode.
Linus Walleij46da8742007-11-20 11:11:03 +000080 * We suspect more of these might need DEVICE_FLAG_NO_ZERO_READS
Linus Walleijf3c44052008-08-16 21:14:56 +000081 * We suspect more of these might need DEVICE_FLAG_PLAYLIST_SPL_V1
82 * or DEVICE_FLAG_PLAYLIST_SPL_V2 to get playlists working.
Linus Walleijcc2cf972007-11-22 20:23:43 +000083 * YP-NEU, YP-NDU, YP-20, YP-800, YP-MF Series, YP-100, YP-30
84 * YP-700 and YP-90 are NOT MTP, but use a Samsung custom protocol.
Linus Walleij1a673de2007-10-29 23:10:05 +000085 */
Linus Walleij6e1f7f42007-11-15 23:27:25 +000086 // From anonymous SourceForge user, not verified
87 { "Samsung", 0x04e8, "YP-900", 0x0409, DEVICE_FLAG_NONE },
Linus Walleijc2bc9732008-08-14 21:12:44 +000088 // From MItch <dbaker@users.sourceforge.net>
89 { "Samsung", 0x04e8, "I550W Phone", 0x04a4, DEVICE_FLAG_NONE },
Linus Walleijca8b20a2008-08-14 07:02:16 +000090 // From Gabriel Nunes <gabrielkm1@yahoo.com.br>
91 { "Samsung", 0x04e8, "YH-920 (501d)", 0x501d, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +000092 // From Soren O'Neill
Linus Walleijca8b20a2008-08-14 07:02:16 +000093 { "Samsung", 0x04e8, "YH-920 (5022)", 0x5022, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +000094 // Contributed by aronvanammers on SourceForge
95 { "Samsung", 0x04e8, "YH-925GS", 0x5024, DEVICE_FLAG_NONE },
96 // From libgphoto2, according to tests by Stephan Fabel it cannot
97 // get all objects with the getobjectproplist command..
98 { "Samsung", 0x04e8, "YH-820", 0x502e, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
99 // Contributed by polux2001@users.sourceforge.net
Linus Walleijca8b20a2008-08-14 07:02:16 +0000100 { "Samsung", 0x04e8, "YH-925(-GS)", 0x502f, DEVICE_FLAG_UNLOAD_DRIVER |
101 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000102 // Contributed by anonymous person on SourceForge
103 { "Samsung", 0x04e8, "YH-J70J", 0x5033, DEVICE_FLAG_UNLOAD_DRIVER },
104 // From XNJB user
Linus Walleijf3c44052008-08-16 21:14:56 +0000105 // Guessing on .spl flag
106 { "Samsung", 0x04e8, "YP-Z5", 0x503c, DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Richard Lowef197312008-11-01 18:29:41 +0000107 // Don't add 0x5041 as this is YP-Z5 in USB mode
Linus Walleij1a673de2007-10-29 23:10:05 +0000108 // Contributed by anonymous person on SourceForge
109 { "Samsung", 0x04e8, "YP-T7J", 0x5047, DEVICE_FLAG_NONE },
110 // Reported by cstrickler@gmail.com
111 { "Samsung", 0x04e8, "YP-U2J (YP-U2JXB/XAA)", 0x5054, DEVICE_FLAG_UNLOAD_DRIVER },
112 // Reported by Andrew Benson
113 { "Samsung", 0x04e8, "YP-F2J", 0x5057, DEVICE_FLAG_UNLOAD_DRIVER },
114 // Reported by Patrick <skibler@gmail.com>
Linus Walleijf3c44052008-08-16 21:14:56 +0000115 // Just guessing but looks like .spl v1 http://www.anythingbutipod.com/forum/showthread.php?t=14160
116 { "Samsung", 0x04e8, "YP-K5", 0x505a, DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij10796872007-12-28 22:56:02 +0000117 // From dev.local@gmail.com - 0x4e8/0x507c is the UMS mode, apparently
Linus Walleij23ab1542008-01-06 22:10:34 +0000118 // do not add that device.
Linus Walleij1a673de2007-10-29 23:10:05 +0000119 // From m.eik michalke
Linus Walleijf3c44052008-08-16 21:14:56 +0000120 // Guessing on .spl flag
121 { "Samsung", 0x04e8, "YP-U3", 0x507d, DEVICE_FLAG_NONE | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij1a673de2007-10-29 23:10:05 +0000122 // Reported by Matthew Wilcox <matthew@wil.cx>
Linus Walleijb1058e02008-05-21 00:01:16 +0000123 // Sergio <sfrdll@tiscali.it> reports this device need the BROKEN ALL flag.
Linus Walleijf3c44052008-08-16 21:14:56 +0000124 // Guessing on .spl flag
125 { "Samsung", 0x04e8, "YP-T9", 0x507f, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij1a673de2007-10-29 23:10:05 +0000126 // From Paul Clinch
Linus Walleijf3c44052008-08-16 21:14:56 +0000127 // Just guessing but looks like .spl v1 http://www.anythingbutipod.com/forum/showthread.php?t=14160
128 { "Samsung", 0x04e8, "YP-K3", 0x5081, DEVICE_FLAG_NONE | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Richard Low6a2f3b82007-11-04 18:39:17 +0000129 // From XNJB user
Linus Walleijf3c44052008-08-16 21:14:56 +0000130 // From Alistair Boyle, .spl v2 required for playlists
131 { "Samsung", 0x04e8, "YP-P2", 0x5083, DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_PLAYLIST_SPL_V2 },
Linus Walleij5a6bcf72007-10-31 20:52:42 +0000132 // From Paul Clinch
Linus Walleijf3c44052008-08-16 21:14:56 +0000133 // Guessing on .spl flag
Richard Low4d9165f2008-09-23 20:13:17 +0000134 { "Samsung", 0x04e8, "YP-T10", 0x508a, DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_PLAYLIST_SPL_V1 | DEVICE_FLAG_NO_ZERO_READS },
Linus Walleij4b43bbf2008-04-07 09:16:44 +0000135 // From Wim Verwimp <wimverwimp@gmail.com>
136 // Not sure about the Ogg and broken proplist flags here. Just guessing.
Linus Walleijf3c44052008-08-16 21:14:56 +0000137 // Guessing on .spl flag
138 { "Samsung", 0x04e8, "YP-S5", 0x508b, DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij07bb5382008-07-31 20:21:09 +0000139 // From Ludovic Danigo
Linus Walleijf3c44052008-08-16 21:14:56 +0000140 // Guessing on .spl flag
141 { "Samsung", 0x04e8, "YP-S3", 0x5091, DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij1a673de2007-10-29 23:10:05 +0000142 // From a rouge .INF file,
Linus Walleij23ab1542008-01-06 22:10:34 +0000143 // this device ID seems to have been recycled for:
144 // the Samsung SGH-A707 Cingular cellphone
145 // the Samsung L760-V cellphone
Richard Lowbb9fb4a2008-05-18 14:49:34 +0000146 { "Samsung", 0x04e8, "YH-999 Portable Media Center/SGH-A707/SGH-L760V", 0x5a0f, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij2350b712008-01-14 22:54:37 +0000147 // From Santi Béjar <sbejar@gmail.com> - not sure this is MTP...
148 // { "Samsung", 0x04e8, "Z170 Mobile Phone", 0x6601, DEVICE_FLAG_UNLOAD_DRIVER },
149 // From Santi Béjar <sbejar@gmail.com> - not sure this is MTP...
150 // { "Samsung", 0x04e8, "E250 Mobile Phone", 0x663e, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000151 // From Lionel Bouton
152 { "Samsung", 0x04e8, "X830 Mobile Phone", 0x6702, DEVICE_FLAG_NONE },
153 // From James <jamestech@gmail.com>
154 { "Samsung", 0x04e8, "U600 Mobile Phone", 0x6709, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijc50e7682007-11-02 00:01:17 +0000155 // From Charlie Todd 2007-10-31
156 { "Samsung", 0x04e8, "Juke (SCH-U470)", 0x6734, DEVICE_FLAG_UNLOAD_DRIVER},
Linus Walleij1a673de2007-10-29 23:10:05 +0000157
158 /*
159 * Intel
160 */
161 { "Intel", 0x045e, "Bandon Portable Media Center", 0x00c9, DEVICE_FLAG_NONE },
Linus Walleij414aca02008-06-02 23:16:49 +0000162 // Reported by Tadimarri Sarath <sarath.tadi@gmail.com>
163 // No idea why this use an Intel PID, perhaps a leftover from
164 // the early PMC development days when Intel and Microsoft were
165 // partnering.
166 { "Microsoft", 0x045e, "Windows MTP Simulator", 0x0622, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000167
168 /*
169 * JVC
170 */
171 // From Mark Veinot
172 { "JVC", 0x04f1, "Alneo XA-HD500", 0x6105, DEVICE_FLAG_NONE },
173
174 /*
175 * Philips
176 */
177 { "Philips", 0x0471, "HDD6320/00 or HDD6330/17", 0x014b, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
178 // Anonymous SourceForge user
Linus Walleijf0702982008-10-25 21:37:43 +0000179 { "Philips", 0x0471, "HDD14XX,HDD1620 or HDD1630/17", 0x014c, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000180 // from discussion forum
181 { "Philips", 0x0471, "HDD085/00 or HDD082/17", 0x014d, DEVICE_FLAG_NONE },
182 // from XNJB forum
Richard Low641d1e32008-02-24 20:47:20 +0000183 { "Philips", 0x0471, "GoGear SA9200", 0x014f, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000184 // From John Coppens <jcoppens@users.sourceforge.net>
185 { "Philips", 0x0471, "SA1115/55", 0x0164, DEVICE_FLAG_NONE },
186 // From Gerhard Mekenkamp
187 { "Philips", 0x0471, "GoGear Audio", 0x0165, DEVICE_FLAG_NONE },
188 // from David Holm <wormie@alberg.dk>
189 { "Philips", 0x0471, "Shoqbox", 0x0172, DEVICE_FLAG_ONLY_7BIT_FILENAMES },
190 // from npedrosa
191 { "Philips", 0x0471, "PSA610", 0x0181, DEVICE_FLAG_NONE },
192 // From libgphoto2 source
193 { "Philips", 0x0471, "HDD6320", 0x01eb, DEVICE_FLAG_NONE },
194 // From Detlef Meier <dm@emlix.com>
Linus Walleija8ba8c72008-03-29 00:02:27 +0000195 { "Philips", 0x0471, "GoGear SA6014/SA6015/SA6024/SA6025/SA6044/SA6045", 0x084e, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij23ab1542008-01-06 22:10:34 +0000196 // From anonymous Sourceforge user SA5145/02
Linus Walleija8ba8c72008-03-29 00:02:27 +0000197 { "Philips", 0x0471, "GoGear SA5145", 0x0857, DEVICE_FLAG_UNLOAD_DRIVER },
198 // From a
199 { "Philips", 0x0471, "GoGear SA6125/SA6145/SA6185", 0x2002, DEVICE_FLAG_UNLOAD_DRIVER },
200 // From anonymous Sourceforge user, not verified to be MTP!
201 { "Philips", 0x0471, "GoGear SA3345", 0x2004, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000202 // from XNJB user
203 { "Philips", 0x0471, "PSA235", 0x7e01, DEVICE_FLAG_NONE },
204
205
206 /*
207 * SanDisk
208 * several devices (c150 for sure) are definately dual-mode and must
209 * have the USB mass storage driver that hooks them unloaded first.
210 * They all have problematic dual-mode making the device unload effect
Linus Walleij5e202562008-06-03 11:35:05 +0000211 * uncertain on these devices.
212 *
213 * All older devices seem to need DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL.
214 * Old chipsets: e200/c200 use PP5024 from Nvidia (formerly PortalPlayer).
215 * m200 use TCC770 from Telechips.
216 *
217 * The newer Sansa v2 chipset, AD3525 from Austriamicrosystems (AMS) found
218 * in e280 v2 c200 v2, Clip, Fuze etc require DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST
219 * and DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR to work properly.
220 *
221 * For more info see: http://daniel.haxx.se/sansa/v2.html
Linus Walleij1a673de2007-10-29 23:10:05 +0000222 */
223 // Reported by Brian Robison
224 { "SanDisk", 0x0781, "Sansa m230/m240", 0x7400,
225 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000226 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000227 // Reported by tangent_@users.sourceforge.net
228 { "SanDisk", 0x0781, "Sansa c150", 0x7410,
229 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000230 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000231 // From libgphoto2 source
232 // Reported by <gonkflea@users.sourceforge.net>
233 // Reported by Mike Owen <mikeowen@computerbaseusa.com>
234 { "SanDisk", 0x0781, "Sansa e200/e250/e260/e270/e280", 0x7420,
235 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000236 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000237 // Reported by XNJB user
238 { "SanDisk", 0x0781, "Sansa e280", 0x7421,
239 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000240 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000241 // Reported by XNJB user
Linus Walleijf3296622008-09-04 20:53:56 +0000242 { "SanDisk", 0x0781, "Sansa e260/e280 v2", 0x7422,
Linus Walleij5e202562008-06-03 11:35:05 +0000243 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij37588142008-10-16 19:10:47 +0000244 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000245 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Richard Lowd56e8a62007-12-08 16:59:11 +0000246 // Reported by XNJB user
Linus Walleij1a673de2007-10-29 23:10:05 +0000247 { "SanDisk", 0x0781, "Sansa m240", 0x7430,
248 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000249 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij077a8902007-11-15 21:18:12 +0000250 // Reported by Eugene Brevdo <ebrevdo@princeton.edu>
Linus Walleij5e202562008-06-03 11:35:05 +0000251 { "SanDisk", 0x0781, "Sansa Clip", 0x7432,
252 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij37588142008-10-16 19:10:47 +0000253 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000254 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
Linus Walleij39f9a452008-11-15 09:39:39 +0000255 // Reported by HackAR <hackar@users.sourceforge.net>
256 { "SanDisk", 0x0781, "Sansa Clip 8GiB", 0x7434,
257 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
258 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
259 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
Linus Walleij1a673de2007-10-29 23:10:05 +0000260 // Reported by anonymous user at sourceforge.net
261 { "SanDisk", 0x0781, "Sansa c240/c250", 0x7450,
262 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000263 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000264 // Reported by Troy Curtis Jr.
265 { "SanDisk", 0x0781, "Sansa Express", 0x7460,
266 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000267 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000268 // Reported by XNJB user, and Miguel de Icaza <miguel@gnome.org>
269 // This has no dual-mode so no need to unload any driver.
270 // This is a Linux based device!
271 { "SanDisk", 0x0781, "Sansa Connect", 0x7480, DEVICE_FLAG_NONE },
272 // Reported by anonymous SourceForge user
273 { "SanDisk", 0x0781, "Sansa View", 0x74b0,
274 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000275 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij690a3162008-03-31 21:40:23 +0000276 // Reported by Patrick <skibler@gmail.com>
277 // There are apparently problems with this device.
278 { "SanDisk", 0x0781, "Sansa Fuze", 0x74c0,
Linus Walleij5e202562008-06-03 11:35:05 +0000279 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij37588142008-10-16 19:10:47 +0000280 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000281 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000282
283 /*
284 * iRiver
285 * we assume that PTP_OC_MTP_GetObjPropList is essentially
286 * broken on all iRiver devices, meaning it simply won't return
287 * all properties for a file when asking for metadata 0xffffffff.
288 * Please test on your device if you believe it isn't broken!
Linus Walleij1a673de2007-10-29 23:10:05 +0000289 */
290 { "iRiver", 0x1006, "Portable Media Center", 0x4002,
291 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
292 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
293 { "iRiver", 0x1006, "Portable Media Center", 0x4003,
294 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
295 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
296 // From an anonymous person at SourceForge
297 { "iRiver", 0x4102, "iFP-880", 0x1008,
298 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
299 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
300 // From libgphoto2 source
301 { "iRiver", 0x4102, "T10", 0x1113,
302 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
303 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
304 { "iRiver", 0x4102, "T20 FM", 0x1114,
305 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
306 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
307 // This appears at the MTP-UMS site
308 { "iRiver", 0x4102, "T20", 0x1115,
309 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
310 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
311 { "iRiver", 0x4102, "U10", 0x1116,
312 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
313 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleijfcd4d372007-11-18 21:56:32 +0000314 { "iRiver", 0x4102, "T10a", 0x1117,
Linus Walleij1a673de2007-10-29 23:10:05 +0000315 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
316 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
317 { "iRiver", 0x4102, "T20", 0x1118,
318 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
319 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
320 { "iRiver", 0x4102, "T30", 0x1119,
321 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
322 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
323 // Reported by David Wolpoff
324 { "iRiver", 0x4102, "T10 2GB", 0x1120,
325 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
326 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
327 // Rough guess this is the MTP device ID...
328 { "iRiver", 0x4102, "N12", 0x1122,
329 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
330 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
331 // Reported by Philip Antoniades <philip@mysql.com>
332 // Newer iriver devices seem to have shaped-up firmware without any
333 // of the annoying bugs.
334 { "iRiver", 0x4102, "Clix2", 0x1126, DEVICE_FLAG_NONE },
335 // Reported by Adam Torgerson
336 { "iRiver", 0x4102, "Clix", 0x112a,
337 DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
338 // Reported by Douglas Roth <dougaus@gmail.com>
339 { "iRiver", 0x4102, "X20", 0x1132,
340 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
341 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
342 // Reported by Robert Ugo <robert_ugo@users.sourceforge.net>
343 { "iRiver", 0x4102, "T60", 0x1134,
344 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
345 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000346 // Reported by two anonymous SourceForge users
Linus Walleij07bb5382008-07-31 20:21:09 +0000347 // Needs the stronger OGG_IS_UNKNOWN flag to support OGG properly,
348 // be aware of newer players that may be needing this too.
Linus Walleijf8c251e2008-06-08 21:32:01 +0000349 { "iRiver", 0x4102, "E100", 0x1141,
350 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij07bb5382008-07-31 20:21:09 +0000351 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000352 // Reported by anonymous SourceForge user
353 // Need verification of whether this firmware really need all these flags
354 { "iRiver", 0x4102, "E100 v2", 0x1142,
355 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
356 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +0000357 // Reported by Scott Call
Linus Walleij07bb5382008-07-31 20:21:09 +0000358 // Assume this actually supports OGG though it reports it doesn't.
Linus Walleij1a673de2007-10-29 23:10:05 +0000359 { "iRiver", 0x4102, "H10 20GB", 0x2101,
360 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij07bb5382008-07-31 20:21:09 +0000361 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +0000362 { "iRiver", 0x4102, "H10", 0x2102,
363 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij07bb5382008-07-31 20:21:09 +0000364 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +0000365
366
367 /*
368 * Dell
369 */
370 { "Dell, Inc", 0x413c, "DJ Itty", 0x4500, DEVICE_FLAG_NONE },
371
372 /*
373 * Toshiba
374 */
375 { "Toshiba", 0x0930, "Gigabeat MEGF-40", 0x0009, DEVICE_FLAG_NONE },
376 { "Toshiba", 0x0930, "Gigabeat", 0x000c, DEVICE_FLAG_NONE },
377 // Reported by Nicholas Tripp
378 { "Toshiba", 0x0930, "Gigabeat P20", 0x000f, DEVICE_FLAG_NONE },
379 // From libgphoto2
380 { "Toshiba", 0x0930, "Gigabeat S", 0x0010, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
381 // Reported by Rob Brown
382 { "Toshiba", 0x0930, "Gigabeat P10", 0x0011, DEVICE_FLAG_NONE },
Linus Walleij51dde6b2007-11-03 23:14:59 +0000383 // Reported by solanum@users.sourceforge.net
384 { "Toshiba", 0x0930, "Gigabeat V30", 0x0014, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000385 // Reported by Michael Davis <slithy@yahoo.com>
386 { "Toshiba", 0x0930, "Gigabeat U", 0x0016, DEVICE_FLAG_NONE },
Linus Walleij804cc622008-02-03 21:26:26 +0000387 // Reported by Devon Jacobs <devo@godevo.com>
Linus Walleij360b5a12008-02-03 21:31:52 +0000388 { "Toshiba", 0x0930, "Gigabeat MEU202", 0x0018, DEVICE_FLAG_NO_RELEASE_INTERFACE },
Linus Walleijc76e2f72007-12-09 22:14:35 +0000389 // Reported by Rolf <japan (at) dl3lar.de>
390 { "Toshiba", 0x0930, "Gigabeat T", 0x0019, DEVICE_FLAG_NONE },
Linus Walleij07bb5382008-07-31 20:21:09 +0000391 // Reported by Phil Ingram <ukpbert@users.sourceforge.net>
392 // Tentatively added - no real reports of this device ID being MTP,
393 // reports as USB Mass Storage currently.
394 { "Toshiba", 0x0930, "Gigabeat MEU201", 0x001a, DEVICE_FLAG_NONE },
Linus Walleij922880f2008-10-29 17:31:42 +0000395 // Reported by anonymous SourceForge user
396 { "Toshiba", 0x0930, "Gigabeat MET401", 0x001d, DEVICE_FLAG_NONE },
Linus Walleij804cc622008-02-03 21:26:26 +0000397
Linus Walleij1a673de2007-10-29 23:10:05 +0000398
399 /*
400 * Archos
401 * These devices have some dual-mode interfaces which will really
402 * respect the driver unloading, so DEVICE_FLAG_UNLOAD_DRIVER
403 * really work on these devices!
404 */
405 // Reported by Alexander Haertig <AlexanderHaertig@gmx.de>
406 { "Archos", 0x0e79, "Gmini XS100", 0x1207, DEVICE_FLAG_UNLOAD_DRIVER },
407 // Added by Jan Binder
408 { "Archos", 0x0e79, "XS202 (MTP mode)", 0x1208, DEVICE_FLAG_NONE },
409 // Reported by gudul1@users.sourceforge.net
410 { "Archos", 0x0e79, "104 (MTP mode)", 0x120a, DEVICE_FLAG_NONE },
Linus Walleij4c3cd682008-01-27 22:18:05 +0000411 // Reported by anonymous Sourceforge user.
412 { "Archos", 0x0e79, "404 (MTP mode)", 0x1301, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000413 // Reported by Etienne Chauchot <chauchot.etienne@free.fr>
414 { "Archos", 0x0e79, "504 (MTP mode)", 0x1307, DEVICE_FLAG_UNLOAD_DRIVER },
415 // Reported by Kay McCormick <kaym@modsystems.com>
416 { "Archos", 0x0e79, "704 mobile dvr", 0x130d, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij121b7f22007-12-08 21:37:35 +0000417 // Reported by Joe Rabinoff
Linus Walleije71639a2007-12-08 21:36:00 +0000418 { "Archos", 0x0e79, "605 (MTP mode)", 0x1313, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000419
420 /*
421 * Dunlop (OEM of EGOMAN ltd?) reported by Nanomad
422 * This unit is falsely detected as USB mass storage in Linux
423 * prior to kernel 2.6.19 (fixed by patch from Alan Stern)
424 * so on older kernels special care is needed to remove the
425 * USB mass storage driver that erroneously binds to the device
426 * interface.
427 */
428 { "Dunlop", 0x10d6, "MP3 player 1GB / EGOMAN MD223AFD", 0x2200, DEVICE_FLAG_UNLOAD_DRIVER},
Linus Walleij07bb5382008-07-31 20:21:09 +0000429 // Reported by Steven Black <stevenblack1956@users.sourceforge.net>
430 // Obviously this company goes by many names.
Linus Walleij103a78e2008-08-25 20:48:52 +0000431 // This device is USB 2.0 only.
432 { "Memorex", 0x10d6, "MMP 8585/8586", 0x2300, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000433
434 /*
435 * Microsoft
436 */
Linus Walleij07bb5382008-07-31 20:21:09 +0000437 // Reported by Farooq Zaman (used for all Zunes)
Linus Walleij1a673de2007-10-29 23:10:05 +0000438 { "Microsoft", 0x045e, "Zune", 0x0710, DEVICE_FLAG_NONE },
439
440 /*
441 * Sirius
442 */
443 { "Sirius", 0x18f6, "Stiletto", 0x0102, DEVICE_FLAG_NONE },
Linus Walleij30a7dd92008-04-09 20:33:51 +0000444 // Reported by Chris Bagwell <chris@cnpbagwell.com>
Linus Walleij2f622812008-08-30 22:06:58 +0000445 { "Sirius", 0x18f6, "Stiletto 2", 0x0110, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000446
447 /*
448 * Canon
449 * This is actually a camera, but it has a Microsoft device descriptor
450 * and reports itself as supporting the MTP extension.
451 */
Linus Walleij00e6a5e2008-10-17 07:13:30 +0000452 { "Canon", 0x04a9, "PowerShot A640 (PTP/MTP mode)", 0x3139,
453 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000454
455 /*
456 * Nokia
Linus Walleij21704fd2008-02-29 22:50:29 +0000457 * Please verify the low device IDs here, I suspect these might be for
458 * things like USB storage or modem mode actually, whereas the higher
Linus Walleij9462f552008-10-25 19:16:53 +0000459 * range (0x04nn) could be for MTP. Some of the devices were gathered
460 * from the Nokia WMP drivers:
461 * http://nds2.nokia.com/files/support/global/phones/software/
462 * Address was gathered from going to:
463 * nseries.com
464 * -> support
465 * -> select supported device
466 * -> PC software
467 * -> Music software
468 * -> Windows Media Player 10 driver
Linus Walleij1a673de2007-10-29 23:10:05 +0000469 */
470 // From: DoomHammer <gaczek@users.sourceforge.net>
Linus Walleijb5a4f922008-05-11 20:15:00 +0000471 { "Nokia", 0x0421, "N81 Mobile Phone", 0x000a, DEVICE_FLAG_NONE },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000472 // From an anonymous SourceForge user
473 { "Nokia", 0x0421, "6120c Classic Mobile Phone", 0x002e, DEVICE_FLAG_NONE },
Linus Walleijace7f4c2008-11-01 21:07:34 +0000474 // From Martijn van de Streek <martijn@vandestreek.net>
Linus Walleij4c8b6e12008-10-31 22:04:14 +0000475 { "Nokia", 0x0421, "6500c Classic Mobile Phone", 0x003c, DEVICE_FLAG_NONE },
Linus Walleijb5a4f922008-05-11 20:15:00 +0000476 // From: DoomHammer <gaczek@users.sourceforge.net>
Linus Walleij1a673de2007-10-29 23:10:05 +0000477 { "Nokia", 0x0421, "3110c Mobile Phone", 0x005f, DEVICE_FLAG_NONE },
Linus Walleija8ba8c72008-03-29 00:02:27 +0000478 // From: Vasily <spc-@users.sourceforge.net>
479 { "Nokia", 0x0421, "3109c Mobile Phone", 0x0065, DEVICE_FLAG_NONE },
Linus Walleij07bb5382008-07-31 20:21:09 +0000480 // From: <rawc@users.sourceforge.net>
481 { "Nokia", 0x0421, "5310 XpressMusic", 0x006c, DEVICE_FLAG_NONE },
Linus Walleij21704fd2008-02-29 22:50:29 +0000482 // From: robin (AT) headbank D0Tco DOTuk
483 { "Nokia", 0x0421, "N95 Mobile Phone 8GB", 0x006e, DEVICE_FLAG_NONE },
Linus Walleijcfd143d2008-10-24 20:52:48 +0000484 // From Bastien Nocera <hadess@hadess.net>
485 { "Nokia", 0x0421, "N82 Mobile Phone", 0x0074, DEVICE_FLAG_NONE },
Linus Walleijace7f4c2008-11-01 21:07:34 +0000486 // From Martijn van de Streek <martijn@vandestreek.net>
Linus Walleij4c8b6e12008-10-31 22:04:14 +0000487 { "Nokia", 0x0421, "N78 Mobile Phone", 0x0079, DEVICE_FLAG_NONE },
Linus Walleij07bb5382008-07-31 20:21:09 +0000488 // From: danielw
489 { "Nokia", 0x0421, "E71", 0x00e4, DEVICE_FLAG_NONE },
Linus Walleijf3296622008-09-04 20:53:56 +0000490 // From: Laurent Bigonville <bigon@users.sourceforge.net>
491 { "Nokia", 0x0421, "E66", 0x00e5, DEVICE_FLAG_NONE },
Linus Walleij60144512008-10-25 19:11:48 +0000492 // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_3250_WMP10_driver.inf
493 { "Nokia", 0x0421, "3250 Mobile Phone", 0x0462, DEVICE_FLAG_NONE },
494 // From http://nds2.nokia.com/files/support/global/phones/software/Nokia_N93_WMP10_Driver.inf
495 { "Nokia", 0x0421, "N93 Mobile Phone", 0x0478, DEVICE_FLAG_NONE },
496 // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_5500_Sport_WMP10_driver.inf
497 { "Nokia", 0x0421, "5500 Sport Mobile Phone", 0x047e, DEVICE_FLAG_NONE },
498 // From http://nds2.nokia.com/files/support/global/phones/software/Nokia_N91_WMP10_Driver.inf
499 { "Nokia", 0x0421, "N91 Mobile Phone", 0x0485, DEVICE_FLAG_NONE },
Linus Walleij250ef742008-04-05 20:11:44 +0000500 // From: Christian Rusa <kristous@users.sourceforge.net>
501 { "Nokia", 0x0421, "5700 XpressMusic Mobile Phone", 0x04b4, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000502 // From: Mitchell Hicks <mitchix@yahoo.com>
503 { "Nokia", 0x0421, "5300 Mobile Phone", 0x04ba, DEVICE_FLAG_NONE },
504 // From Christian Arnold <webmaster@arctic-media.de>
505 { "Nokia", 0x0421, "N73 Mobile Phone", 0x04d1, DEVICE_FLAG_UNLOAD_DRIVER },
506 // From Swapan <swapan@yahoo.com>
507 { "Nokia", 0x0421, "N75 Mobile Phone", 0x04e1, DEVICE_FLAG_NONE },
Linus Walleij60144512008-10-25 19:11:48 +0000508 // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_N93i_WMP10_driver.inf
509 { "Nokia", 0x0421, "N93i Mobile Phone", 0x04e5, DEVICE_FLAG_NONE },
Linus Walleija6d0d482007-10-31 08:54:56 +0000510 // From Anonymous Sourceforge User
511 { "Nokia", 0x0421, "N95 Mobile Phone", 0x04ef, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000512 // From: Pat Nicholls <pat@patandannie.co.uk>
513 { "Nokia", 0x0421, "N80 Internet Edition (Media Player)", 0x04f1, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000514 // Reported by anonymous SourceForge user
515 // One thing stated by reporter (Nokia model) another by the detect log...
516 { "Nokia/Verizon", 0x05c6, "6205 Balboa/Verizon Music Phone", 0x3196, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000517
Linus Walleija6d0d482007-10-31 08:54:56 +0000518
Linus Walleij1a673de2007-10-29 23:10:05 +0000519 /*
520 * LOGIK
521 * Sold in the UK, seem to be manufactured by CCTech in China.
522 */
523 { "Logik", 0x13d1, "LOG DAX MP3 and DAB Player", 0x7002, DEVICE_FLAG_UNLOAD_DRIVER },
524
525 /*
526 * RCA / Thomson
527 */
528 // From kiki <omkiki@users.sourceforge.net>
529 { "Thomson", 0x069b, "EM28 Series", 0x0774, DEVICE_FLAG_NONE },
Richard Low957ffba2008-01-21 17:31:20 +0000530 { "Thomson / RCA", 0x069b, "Opal / Lyra MC4002", 0x0777, DEVICE_FLAG_NONE },
Linus Walleij2c414c42008-01-19 07:11:19 +0000531 { "Thomson", 0x069b, "RCA H106", 0x301a, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000532 // From Svenna <svenna@svenna.de>
533 // Not confirmed to be MTP.
534 { "Thomson", 0x069b, "scenium E308", 0x3028, DEVICE_FLAG_NONE },
Richard Lowa11a6ad2008-01-21 17:23:55 +0000535 // From XNJB user
Richard Low957ffba2008-01-21 17:31:20 +0000536 { "Thomson / RCA", 0x069b, "Lyra HC308A", 0x3035, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000537
538 /*
539 * NTT DoCoMo
540 */
541 { "FOMA", 0x04c5, "F903iX HIGH-SPEED", 0x1140, DEVICE_FLAG_NONE },
542
543 /*
544 * Palm device userland program named Pocket Tunes
545 * Reported by Peter Gyongyosi <gyp@impulzus.com>
546 */
Linus Walleijfc438072008-10-31 21:12:43 +0000547 { "NormSoft, Inc.", 0x1703, "Pocket Tunes", 0x0001, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000548 // Reported by anonymous submission
Linus Walleijfc438072008-10-31 21:12:43 +0000549 { "NormSoft, Inc.", 0x1703, "Pocket Tunes 4", 0x0002, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000550
551 /*
Linus Walleij07bb5382008-07-31 20:21:09 +0000552 * TrekStor and Medion devices
Linus Walleij1a673de2007-10-29 23:10:05 +0000553 * Their datasheet claims their devices are dualmode so probably needs to
554 * unload the attached drivers here.
555 */
556 // Reported by Stefan Voss <svoss@web.de>
Linus Walleij10b06d42007-11-05 11:32:07 +0000557 // This is a Sigmatel SoC with a hard disk.
Linus Walleij089bc132007-11-03 23:00:23 +0000558 { "TrekStor", 0x066f, "Vibez 8/12GB", 0x842a,
Linus Walleij07bb5382008-07-31 20:21:09 +0000559 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
560 // Reported by anonymous SourceForge user.
561 // This one done for Medion, whatever that is. Error reported so assume
562 // the same bug flag as its ancestor above.
563 { "Medion", 0x066f, "MD8333", 0x8550,
564 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000565 // Reported by Cristi Magherusan <majeru@gentoo.ro>
Linus Walleij10b06d42007-11-05 11:32:07 +0000566 { "TrekStor", 0x0402, "i.Beat Sweez FM", 0x0611,
Linus Walleij07bb5382008-07-31 20:21:09 +0000567 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000568
569 /*
Linus Walleij21704fd2008-02-29 22:50:29 +0000570 * Disney/Tevion (have had no reports of these actually working.)
Linus Walleij1a673de2007-10-29 23:10:05 +0000571 */
572 // Reported by XNJB user
573 { "Disney", 0x0aa6, "MixMax", 0x6021, DEVICE_FLAG_NONE },
Linus Walleij21704fd2008-02-29 22:50:29 +0000574 // Reported by anonymous Sourceforge user
575 { "Tevion", 0x0aa6, "MD 81488", 0x3011, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000576
577 /*
578 * Cowon Systems, Inc.
579 * The iAudio audiophile devices don't encourage the use of MTP.
580 */
581 // Reported by Patrik Johansson <Patrik.Johansson@qivalue.com>
582 { "Cowon", 0x0e21, "iAudio U3 (MTP mode)", 0x0701, DEVICE_FLAG_NONE },
Linus Walleijee387d72008-11-12 23:42:02 +0000583 // Reported by Kevin Michael Smith <hai-etlik@users.sourceforge.net>
584 { "Cowon", 0x0e21, "iAudio 6 (MTP mode)", 0x0711, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000585 // Reported by Roberth Karman
586 { "Cowon", 0x0e21, "iAudio 7 (MTP mode)", 0x0751, DEVICE_FLAG_NONE },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000587 // Reported by an anonymous SourceForge user
588 { "Cowon", 0x0e21, "iAudio U5 (MTP mode)", 0x0761, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000589 // Reported by TJ Something <tjbk_tjb@users.sourceforge.net>
590 { "Cowon", 0x0e21, "iAudio D2 (MTP mode)", 0x0801,
591 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
592
593 /*
594 * Insignia, dual-mode.
595 */
596 { "Insignia", 0x19ff, "NS-DV45", 0x0303, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij478ddb92007-11-26 21:01:29 +0000597 // Reported by Rajan Bella <rajanbella@yahoo.com>
598 { "Insignia", 0x19ff, "Sport Player", 0x0307, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000599 // Reported by "brad" (anonymous, sourceforge)
600 { "Insignia", 0x19ff, "Pilot 4GB", 0x0309, DEVICE_FLAG_UNLOAD_DRIVER },
601
602 /*
603 * LG Electronics
604 */
605 // Not verified - anonymous submission
Linus Walleij7b4794f2008-08-13 13:17:17 +0000606 { "LG Electronics Inc.", 0x043e, "UP3", 0x70b1, DEVICE_FLAG_NONE },
607 // Reported by Joseph Nahmias <joe@nahimas.net>
608 { "LG Electronics Inc.", 0x1004, "VX8550 V CAST Mobile Phone", 0x6010,
609 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR },
Linus Walleij1a673de2007-10-29 23:10:05 +0000610
611 /*
612 * Sony
Linus Walleijbc3ed4d2008-01-03 13:54:23 +0000613 * It could be that these PIDs are one-per hundred series, so
614 * NWZ-A8xx is 0325, NWZ-S5xx is 0x326 etc. We need more devices
615 * reported to see a pattern here.
Linus Walleij1a673de2007-10-29 23:10:05 +0000616 */
Linus Walleija8ba8c72008-03-29 00:02:27 +0000617 // Reported by Alessandro Radaelli <alessandro.radaelli@aruba.it>
Linus Walleijd4241552008-02-03 21:38:54 +0000618 { "Sony", 0x054c, "Walkman NWZ-A815/NWZ-A818", 0x0325, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij5d709a52007-12-28 21:37:17 +0000619 // Reported by anonymous Sourceforge user.
620 { "Sony", 0x054c, "Walkman NWZ-S516", 0x0326, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000621 // Reported by Endre Oma <endre.88.oma@gmail.com>
Linus Walleijf044aa12008-03-22 21:45:19 +0000622 { "Sony", 0x054c, "Walkman NWZ-S615F/NWZ-S616F/NWZ-S618F", 0x0327, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij062ec7d2008-05-19 12:06:32 +0000623 // Reported by Jean-Marc Bourguet <jm@bourguet.org>
624 { "Sony", 0x054c, "Walkman NWZ-S716F", 0x035a, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij0c98ce82008-05-25 11:08:36 +0000625 // Reported by Anon SF User / Anthon van der Neut <avanderneut@avid.com>
Linus Walleij45b843e2008-10-09 08:33:01 +0000626 { "Sony", 0x054c, "Walkman NWZ-A826/NWZ-A828/NWZ-A829", 0x035b, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleija8ba8c72008-03-29 00:02:27 +0000627 // Reported by Niek Klaverstijn <niekez@users.sourceforge.net>
628 { "Sony", 0x054c, "Walkman NWZ-A728B", 0x035c, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij45b843e2008-10-09 08:33:01 +0000629 // Reported by Mehdi AMINI <mehdi.amini - at - ulp.u-strasbg.fr>
630 { "Sony", 0x054c, "Walkman NWZ-B135", 0x036e, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijd8f1feb2008-10-08 09:16:42 +0000631 // Reported by Marco Filipe Nunes Soares Abrantes Pereira <marcopereira@ua.pt>
632 { "Sony", 0x054c, "Walkman NWZ-S638F", 0x038e, DEVICE_FLAG_UNLOAD_DRIVER },
633
Linus Walleij1a673de2007-10-29 23:10:05 +0000634
635 /*
Linus Walleijaa6b0192007-10-29 23:39:48 +0000636 * SonyEricsson
Linus Walleijc7756412008-10-21 14:24:24 +0000637 * These initially seemed to support GetObjPropList but later revisions
638 * of the firmware seem to have broken it, so all are flagged as broken
639 * for now.
Linus Walleijaa6b0192007-10-29 23:39:48 +0000640 */
Linus Walleijb3b29e72007-11-05 22:29:53 +0000641 // Reported by Øyvind Stegard <stegaro@users.sourceforge.net>
Linus Walleijc7756412008-10-21 14:24:24 +0000642 { "SonyEricsson", 0x0fce, "K850i", 0x0075, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijaa6b0192007-10-29 23:39:48 +0000643 // Reported by Michael Eriksson
Linus Walleijc7756412008-10-21 14:24:24 +0000644 { "SonyEricsson", 0x0fce, "W910", 0x0076, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijb5a4f922008-05-11 20:15:00 +0000645 // Reported by Zack <zackdvd@users.sourceforge.net>
Linus Walleijc7756412008-10-21 14:24:24 +0000646 { "SonyEricsson", 0x0fce, "W890i", 0x00b3, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000647 // Reported by robert dot ahlskog at gmail
Linus Walleijc7756412008-10-21 14:24:24 +0000648 { "SonyEricsson", 0x0fce, "W760i", 0x00c6, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000649 // Reported by Linus Åkesson <linusakesson@users.sourceforge.net>
Linus Walleijc7756412008-10-21 14:24:24 +0000650 { "SonyEricsson", 0x0fce, "C902", 0x00d4, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij07bb5382008-07-31 20:21:09 +0000651 // Reported by an anonymous SourceForge user
Linus Walleijc7756412008-10-21 14:24:24 +0000652 { "SonyEricsson", 0x0fce, "C702", 0x00d9, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijdb6da7c2008-10-16 18:46:34 +0000653 // Reported by Christian Zuckschwerdt <christian@zuckschwerdt.org>
Linus Walleijc7756412008-10-21 14:24:24 +0000654 { "SonyEricsson", 0x0fce, "W980", 0x00da, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijaa6b0192007-10-29 23:39:48 +0000655
656 /*
Linus Walleij1a673de2007-10-29 23:10:05 +0000657 * Motorola
658 * Assume DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST on all of these.
659 */
Linus Walleij37c21662008-05-16 21:16:01 +0000660 // Reported by David Boyd <tiggrdave@users.sourceforge.net>
Linus Walleijf3296622008-09-04 20:53:56 +0000661 { "Motorola", 0x22b8, "V3m/V750 verizon", 0x2a65, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST |
Linus Walleij37c21662008-05-16 21:16:01 +0000662 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000663 // Reported by Marcus Meissner to libptp2
664 { "Motorola", 0x22b8, "K1", 0x4811, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
665 // Reported by Hans-Joachim Baader <hjb@pro-linux.de> to libptp2
666 { "Motorola", 0x22b8, "A1200", 0x60ca, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleijf0702982008-10-25 21:37:43 +0000667 // http://mark.cdmaforums.com/Files/Motdmmtp.inf
668 { "Motorola", 0x22b8, "MTP Test Command Interface", 0x6413, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000669 // Reported by anonymous user
Linus Walleij238704e2008-09-08 22:54:15 +0000670 { "Motorola", 0x22b8, "RAZR2 V8/U9/Z6", 0x6415, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleij37c21662008-05-16 21:16:01 +0000671
Linus Walleij1a673de2007-10-29 23:10:05 +0000672
673 /*
Linus Walleij478ddb92007-11-26 21:01:29 +0000674 * Media Keg
675 */
676 // Reported by Rajan Bella <rajanbella@yahoo.com>
677 { "Kenwood", 0x0b28, "Media Keg HD10GB7 Sport Player", 0x100c, DEVICE_FLAG_UNLOAD_DRIVER},
678
Linus Walleij5d675112008-02-16 21:46:46 +0000679 /*
680 * Micro-Star International (MSI)
681 */
682 // Reported by anonymous sourceforge user.
683 { "Micro-Star International", 0x0db0, "P610/Model MS-5557", 0x5572, DEVICE_FLAG_NONE },
684
Linus Walleijf044aa12008-03-22 21:45:19 +0000685 /*
686 * FOMA
687 */
688 { "FOMA", 0x06d3, "D905i", 0x21ba, DEVICE_FLAG_NONE },
Linus Walleij166c8ff2008-01-14 23:15:08 +0000689
Linus Walleij478ddb92007-11-26 21:01:29 +0000690 /*
Linus Walleijb5a4f922008-05-11 20:15:00 +0000691 * Haier
692 */
693 // Both reported by an anonymous SourceForge user
694 // This is the 30 GiB model
695 { "Haier", 0x1302, "Ibiza Rhapsody", 0x1016, DEVICE_FLAG_NONE },
696 // This is the 4/8 GiB model
697 { "Haier", 0x1302, "Ibiza Rhapsody", 0x1017, DEVICE_FLAG_NONE },
Richard Low4d93a992008-09-07 12:52:14 +0000698
699 /*
700 * Panasonic
701 */
702 // Reported by dmizer
703 { "Panasonic", 0x04da, "P905i", 0x2145, DEVICE_FLAG_NONE },
Linus Walleijb5a4f922008-05-11 20:15:00 +0000704
705 /*
Linus Walleij1a673de2007-10-29 23:10:05 +0000706 * Other strange stuff.
707 */
708 { "Isabella", 0x0b20, "Her Prototype", 0xddee, DEVICE_FLAG_NONE }