blob: 9dbbb1b3f7535799bcc587a311ec876d4940f0e8 [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 Walleij6e50b1b2012-01-11 07:50:52 +01006 * Copyright (C) 2005-2012 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.
Linus Walleij18ed0162009-05-06 16:51:08 +000034 * Some devices taken from the Rockbox device listing:
35 * http://www.rockbox.org/twiki/bin/view/Main/DeviceDetection
Linus Walleij1a673de2007-10-29 23:10:05 +000036 */
37
38 /*
Linus Walleijcfe8f3f2009-09-12 06:34:27 +000039 * Creative Technology and ZiiLABS
Linus Walleij1a673de2007-10-29 23:10:05 +000040 * Initially the Creative devices was all we supported so these are
41 * the most thoroughly tested devices. Presumably only the devices
42 * with older firmware (the ones that have 32bit object size) will
Linus Walleijcc2cf972007-11-22 20:23:43 +000043 * need the DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL flag. This bug
44 * manifest itself when you have a lot of folders on the device,
45 * some of the folders will start to disappear when getting all objects
46 * and properties.
Linus Walleij1a673de2007-10-29 23:10:05 +000047 */
Linus Walleijb989cf12011-11-25 09:20:13 +010048 { "Creative", 0x041e, "ZEN Vision", 0x411f,
49 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
50 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
51 { "Creative", 0x041e, "Portable Media Center", 0x4123,
52 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
53 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
54 { "Creative", 0x041e, "ZEN Xtra (MTP mode)", 0x4128,
55 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
56 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
57 { "Dell", 0x041e, "DJ (2nd generation)", 0x412f,
58 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
59 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
60 { "Creative", 0x041e, "ZEN Micro (MTP mode)", 0x4130,
61 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
62 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
63 { "Creative", 0x041e, "ZEN Touch (MTP mode)", 0x4131,
64 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
65 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
66 { "Dell", 0x041e, "Dell Pocket DJ (MTP mode)", 0x4132,
67 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
68 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
69 { "Creative", 0x041e, "ZEN MicroPhoto (alternate version)", 0x4133,
70 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
71 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
72 { "Creative", 0x041e, "ZEN Sleek (MTP mode)", 0x4137,
73 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
74 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
75 { "Creative", 0x041e, "ZEN MicroPhoto", 0x413c,
76 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
77 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
78 { "Creative", 0x041e, "ZEN Sleek Photo", 0x413d,
79 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
80 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
81 { "Creative", 0x041e, "ZEN Vision:M", 0x413e,
82 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
83 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
Linus Walleij1a673de2007-10-29 23:10:05 +000084 // Reported by marazm@o2.pl
Linus Walleijb989cf12011-11-25 09:20:13 +010085 { "Creative", 0x041e, "ZEN V", 0x4150,
86 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
87 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
Linus Walleij1a673de2007-10-29 23:10:05 +000088 // Reported by danielw@iinet.net.au
89 // This version of the Vision:M needs the no release interface flag,
90 // unclear whether the other version above need it too or not.
Linus Walleijb989cf12011-11-25 09:20:13 +010091 { "Creative", 0x041e, "ZEN Vision:M (DVP-HD0004)", 0x4151,
Linus Walleij6222f732009-06-24 08:27:08 +000092 DEVICE_FLAG_NO_RELEASE_INTERFACE |
Linus Walleijb989cf12011-11-25 09:20:13 +010093 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
94 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
Linus Walleij1a673de2007-10-29 23:10:05 +000095 // Reported by Darel on the XNJB forums
Linus Walleij6222f732009-06-24 08:27:08 +000096 { "Creative", 0x041e, "ZEN V Plus", 0x4152,
Linus Walleijb989cf12011-11-25 09:20:13 +010097 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
98 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
Linus Walleij6222f732009-06-24 08:27:08 +000099 { "Creative", 0x041e, "ZEN Vision W", 0x4153,
Linus Walleijb989cf12011-11-25 09:20:13 +0100100 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
101 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
Richard Lowa11a6ad2008-01-21 17:23:55 +0000102 // Don't add 0x4155: this is a Zen Stone device which is not MTP
Linus Walleij1a673de2007-10-29 23:10:05 +0000103 // Reported by Paul Kurczaba <paul@kurczaba.com>
Linus Walleijb989cf12011-11-25 09:20:13 +0100104 { "Creative", 0x041e, "ZEN", 0x4157,
105 DEVICE_FLAG_IGNORE_HEADER_ERRORS |
106 DEVICE_FLAG_BROKEN_SET_SAMPLE_DIMENSIONS |
107 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
108 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000109 // Reported by Ringofan <mcroman@users.sourceforge.net>
Linus Walleij6222f732009-06-24 08:27:08 +0000110 { "Creative", 0x041e, "ZEN V 2GB", 0x4158,
Linus Walleijb989cf12011-11-25 09:20:13 +0100111 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
112 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
Linus Walleijf0ea0292008-09-10 06:52:16 +0000113 // Reported by j norment <stormzen@gmail.com>
Linus Walleij6222f732009-06-24 08:27:08 +0000114 { "Creative", 0x041e, "ZEN Mozaic", 0x4161,
Linus Walleijb989cf12011-11-25 09:20:13 +0100115 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
116 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000117 // Reported by Aaron F. Gonzalez <sub_tex@users.sourceforge.net>
Linus Walleij6222f732009-06-24 08:27:08 +0000118 { "Creative", 0x041e, "ZEN X-Fi", 0x4162,
Linus Walleijb989cf12011-11-25 09:20:13 +0100119 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
120 DEVICE_FLAG_BROKEN_GET_OBJECT_PROPVAL },
Linus Walleija9058aa2009-09-12 06:36:18 +0000121 // Reported by Todor Gyumyushev <yodor1@users.sourceforge.net>
Linus Walleijcfe8f3f2009-09-12 06:34:27 +0000122 { "ZiiLABS", 0x041e, "Zii EGG", 0x6000,
Linus Walleijbf1469f2009-09-15 16:50:40 +0000123 DEVICE_FLAG_UNLOAD_DRIVER |
124 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
125 DEVICE_FLAG_NO_RELEASE_INTERFACE |
126 DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
127 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000128
129 /*
130 * Samsung
131 * We suspect that more of these are dual mode.
Linus Walleij46da8742007-11-20 11:11:03 +0000132 * We suspect more of these might need DEVICE_FLAG_NO_ZERO_READS
Linus Walleijf3c44052008-08-16 21:14:56 +0000133 * We suspect more of these might need DEVICE_FLAG_PLAYLIST_SPL_V1
134 * or DEVICE_FLAG_PLAYLIST_SPL_V2 to get playlists working.
Linus Walleijcc2cf972007-11-22 20:23:43 +0000135 * YP-NEU, YP-NDU, YP-20, YP-800, YP-MF Series, YP-100, YP-30
136 * YP-700 and YP-90 are NOT MTP, but use a Samsung custom protocol.
Linus Walleij2d54eba2010-05-23 23:37:10 +0000137 * See: http://wiki.xiph.org/index.php/PortablePlayers for Ogg
138 * status.
Linus Walleij1a673de2007-10-29 23:10:05 +0000139 */
Linus Walleij6e1f7f42007-11-15 23:27:25 +0000140 // From anonymous SourceForge user, not verified
141 { "Samsung", 0x04e8, "YP-900", 0x0409, DEVICE_FLAG_NONE },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000142 // From MItch <dbaker@users.sourceforge.net>
143 { "Samsung", 0x04e8, "I550W Phone", 0x04a4, DEVICE_FLAG_NONE },
Linus Walleij5e44ed52010-01-30 08:06:11 +0000144 // From Manfred Enning <menning@users.sourceforge.net>
145 { "Samsung", 0x04e8, "Jet S8000", 0x4f1f, DEVICE_FLAG_NONE },
Linus Walleijca8b20a2008-08-14 07:02:16 +0000146 // From Gabriel Nunes <gabrielkm1@yahoo.com.br>
147 { "Samsung", 0x04e8, "YH-920 (501d)", 0x501d, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000148 // From Soren O'Neill
Linus Walleijca8b20a2008-08-14 07:02:16 +0000149 { "Samsung", 0x04e8, "YH-920 (5022)", 0x5022, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000150 // Contributed by aronvanammers on SourceForge
151 { "Samsung", 0x04e8, "YH-925GS", 0x5024, DEVICE_FLAG_NONE },
152 // From libgphoto2, according to tests by Stephan Fabel it cannot
153 // get all objects with the getobjectproplist command..
Linus Walleij7b3e3022012-01-19 17:10:25 +0100154 { "Samsung", 0x04e8, "YH-820", 0x502e,
155 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000156 // Contributed by polux2001@users.sourceforge.net
Linus Walleij7b3e3022012-01-19 17:10:25 +0100157 { "Samsung", 0x04e8, "YH-925(-GS)", 0x502f,
158 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleijca8b20a2008-08-14 07:02:16 +0000159 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000160 // Contributed by anonymous person on SourceForge
Linus Walleij7b3e3022012-01-19 17:10:25 +0100161 { "Samsung", 0x04e8, "YH-J70J", 0x5033,
162 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000163 // From XNJB user
Linus Walleijf3c44052008-08-16 21:14:56 +0000164 // Guessing on .spl flag
Linus Walleij7b3e3022012-01-19 17:10:25 +0100165 { "Samsung", 0x04e8, "YP-Z5", 0x503c,
166 DEVICE_FLAG_UNLOAD_DRIVER |
167 DEVICE_FLAG_OGG_IS_UNKNOWN |
168 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Richard Lowef197312008-11-01 18:29:41 +0000169 // Don't add 0x5041 as this is YP-Z5 in USB mode
Linus Walleij1a673de2007-10-29 23:10:05 +0000170 // Contributed by anonymous person on SourceForge
Linus Walleij7b3e3022012-01-19 17:10:25 +0100171 { "Samsung", 0x04e8, "YP-T7J", 0x5047,
172 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij2d54eba2010-05-23 23:37:10 +0000173 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +0000174 // Reported by cstrickler@gmail.com
Linus Walleij2d54eba2010-05-23 23:37:10 +0000175 { "Samsung", 0x04e8, "YP-U2J (YP-U2JXB/XAA)", 0x5054,
Linus Walleij7b3e3022012-01-19 17:10:25 +0100176 DEVICE_FLAG_UNLOAD_DRIVER |
177 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +0000178 // Reported by Andrew Benson
Linus Walleij7b3e3022012-01-19 17:10:25 +0100179 { "Samsung", 0x04e8, "YP-F2J", 0x5057,
180 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000181 // Reported by Patrick <skibler@gmail.com>
Linus Walleijf3c44052008-08-16 21:14:56 +0000182 // Just guessing but looks like .spl v1 http://www.anythingbutipod.com/forum/showthread.php?t=14160
Linus Walleij7b3e3022012-01-19 17:10:25 +0100183 { "Samsung", 0x04e8, "YP-K5", 0x505a,
184 DEVICE_FLAG_UNLOAD_DRIVER |
185 DEVICE_FLAG_NO_ZERO_READS |
186 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij10796872007-12-28 22:56:02 +0000187 // From dev.local@gmail.com - 0x4e8/0x507c is the UMS mode, apparently
Linus Walleij23ab1542008-01-06 22:10:34 +0000188 // do not add that device.
Linus Walleij1a673de2007-10-29 23:10:05 +0000189 // From m.eik michalke
Linus Walleije9b4e912008-11-30 00:09:17 +0000190 // This device does NOT use the special SPL playlist according to sypqgjxu@gmx.de.
Linus Walleij7b3e3022012-01-19 17:10:25 +0100191 { "Samsung", 0x04e8, "YP-U3", 0x507d,
192 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij2d54eba2010-05-23 23:37:10 +0000193 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +0000194 // Reported by Matthew Wilcox <matthew@wil.cx>
Linus Walleijb1058e02008-05-21 00:01:16 +0000195 // Sergio <sfrdll@tiscali.it> reports this device need the BROKEN ALL flag.
Linus Walleijf3c44052008-08-16 21:14:56 +0000196 // Guessing on .spl flag
Linus Walleij7b3e3022012-01-19 17:10:25 +0100197 { "Samsung", 0x04e8, "YP-T9", 0x507f,
198 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij2d54eba2010-05-23 23:37:10 +0000199 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleij7b3e3022012-01-19 17:10:25 +0100200 DEVICE_FLAG_OGG_IS_UNKNOWN |
201 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij1a673de2007-10-29 23:10:05 +0000202 // From Paul Clinch
Linus Walleijf3c44052008-08-16 21:14:56 +0000203 // Just guessing but looks like .spl v1 http://www.anythingbutipod.com/forum/showthread.php?t=14160
Linus Walleij1e0eba72009-02-21 07:26:29 +0000204 // Some versions of the firmware reportedly support OGG, reportedly only the
205 // UMS versions, so MTP+OGG is not possible on this device.
Linus Walleij7b3e3022012-01-19 17:10:25 +0100206 { "Samsung", 0x04e8, "YP-K3", 0x5081,
207 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij84072342009-06-24 08:08:26 +0000208 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Richard Low6a2f3b82007-11-04 18:39:17 +0000209 // From XNJB user
Linus Walleijf3c44052008-08-16 21:14:56 +0000210 // From Alistair Boyle, .spl v2 required for playlists
Linus Walleijd4157be2009-02-21 07:23:26 +0000211 // According to the device log it properly supports OGG
Linus Walleij7b3e3022012-01-19 17:10:25 +0100212 { "Samsung", 0x04e8, "YP-P2", 0x5083,
213 DEVICE_FLAG_UNLOAD_DRIVER |
214 DEVICE_FLAG_NO_ZERO_READS |
215 DEVICE_FLAG_OGG_IS_UNKNOWN |
Linus Walleij2d54eba2010-05-23 23:37:10 +0000216 DEVICE_FLAG_PLAYLIST_SPL_V2 },
Linus Walleij5a6bcf72007-10-31 20:52:42 +0000217 // From Paul Clinch
Linus Walleijf3c44052008-08-16 21:14:56 +0000218 // Guessing on .spl flag
Linus Walleij7b3e3022012-01-19 17:10:25 +0100219 { "Samsung", 0x04e8, "YP-T10", 0x508a,
220 DEVICE_FLAG_UNLOAD_DRIVER |
221 DEVICE_FLAG_OGG_IS_UNKNOWN |
222 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
223 DEVICE_FLAG_PLAYLIST_SPL_V1 |
224 DEVICE_FLAG_NO_ZERO_READS },
Linus Walleij4b43bbf2008-04-07 09:16:44 +0000225 // From Wim Verwimp <wimverwimp@gmail.com>
226 // Not sure about the Ogg and broken proplist flags here. Just guessing.
Linus Walleijf3c44052008-08-16 21:14:56 +0000227 // Guessing on .spl flag
Linus Walleij7b3e3022012-01-19 17:10:25 +0100228 { "Samsung", 0x04e8, "YP-S5", 0x508b,
229 DEVICE_FLAG_UNLOAD_DRIVER |
230 DEVICE_FLAG_OGG_IS_UNKNOWN |
231 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij84072342009-06-24 08:08:26 +0000232 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij07bb5382008-07-31 20:21:09 +0000233 // From Ludovic Danigo
Linus Walleijf3c44052008-08-16 21:14:56 +0000234 // Guessing on .spl flag
Linus Walleij7b3e3022012-01-19 17:10:25 +0100235 { "Samsung", 0x04e8, "YP-S3", 0x5091,
236 DEVICE_FLAG_UNLOAD_DRIVER |
237 DEVICE_FLAG_OGG_IS_UNKNOWN |
238 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij84072342009-06-24 08:08:26 +0000239 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij2288a6a2009-01-27 21:16:38 +0000240 // From Adrian Levi <adrian.levi@gmail.com>
241 // Guessing on .spl flag
Linus Walleijd4157be2009-02-21 07:23:26 +0000242 // This one supports OGG properly through the correct MTP type.
Linus Walleij84072342009-06-24 08:08:26 +0000243 { "Samsung", 0x04e8, "YP-U4", 0x5093, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijc3a6eeb2010-01-30 07:32:41 +0000244 // From Chris Le Sueur <thefishface@gmail.com>
245 // Guessing on .spl flag
246 // This one supports OGG properly through the correct MTP type.
Linus Walleij7b3e3022012-01-19 17:10:25 +0100247 { "Samsung", 0x04e8, "YP-R1", 0x510f,
248 DEVICE_FLAG_UNLOAD_DRIVER |
249 DEVICE_FLAG_UNIQUE_FILENAMES |
250 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijebf32cc2010-04-04 23:07:25 +0000251 // From Anonymous SourceForge user
Linus Walleij2b8c8492008-12-12 00:16:48 +0000252 // Guessing on .spl flag
Linus Walleij7b3e3022012-01-19 17:10:25 +0100253 { "Samsung", 0x04e8, "YP-Q1", 0x5115,
254 DEVICE_FLAG_UNLOAD_DRIVER |
255 DEVICE_FLAG_OGG_IS_UNKNOWN |
256 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij84072342009-06-24 08:08:26 +0000257 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij6e3d9532010-01-08 11:09:50 +0000258 // From Holger
Linus Walleij7b3e3022012-01-19 17:10:25 +0100259 { "Samsung", 0x04e8, "YP-M1", 0x5118,
260 DEVICE_FLAG_UNLOAD_DRIVER |
261 DEVICE_FLAG_OGG_IS_UNKNOWN |
262 DEVICE_FLAG_PLAYLIST_SPL_V2 },
Linus Walleijb49a9f72009-05-14 20:46:07 +0000263 // From Anonymous SourceForge user
264 // Guessing on .spl flag
Linus Walleij7b3e3022012-01-19 17:10:25 +0100265 { "Samsung", 0x04e8, "YP-P3", 0x511a,
266 DEVICE_FLAG_UNLOAD_DRIVER |
267 DEVICE_FLAG_OGG_IS_UNKNOWN |
268 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleijb49a9f72009-05-14 20:46:07 +0000269 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij316628c2009-06-15 19:55:41 +0000270 // From Anonymous SourceForge user
271 // Guessing on .spl flag
Linus Walleij7b3e3022012-01-19 17:10:25 +0100272 { "Samsung", 0x04e8, "YP-Q2", 0x511d,
273 DEVICE_FLAG_UNLOAD_DRIVER |
274 DEVICE_FLAG_OGG_IS_UNKNOWN |
275 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij84072342009-06-24 08:08:26 +0000276 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij41e94cf2009-05-19 22:44:53 +0000277 // From Marco Pizzocaro <mpizzocaro@users.sourceforge.net>
278 // Guessing on .spl flag
279 { "Samsung", 0x04e8, "YP-U5", 0x5121,
Linus Walleij7b3e3022012-01-19 17:10:25 +0100280 DEVICE_FLAG_UNLOAD_DRIVER |
281 DEVICE_FLAG_PLAYLIST_SPL_V1 |
282 DEVICE_FLAG_UNIQUE_FILENAMES |
283 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijc2cdbfc2009-11-20 21:28:17 +0000284 // From Leonardo Accorsi <laccorsi@users.sourceforge.net>
285 // Guessing on .spl flag
286 { "Samsung", 0x04e8, "YP-R0", 0x5125,
Linus Walleij7b3e3022012-01-19 17:10:25 +0100287 DEVICE_FLAG_UNLOAD_DRIVER |
288 DEVICE_FLAG_PLAYLIST_SPL_V1 |
289 DEVICE_FLAG_UNIQUE_FILENAMES |
290 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij509cd652011-03-04 20:34:02 +0100291 // From Manuel Carro
292 // Copied from Q2
Linus Walleij7b3e3022012-01-19 17:10:25 +0100293 { "Samsung", 0x04e8, "YP-Q3", 0x5130,
294 DEVICE_FLAG_UNLOAD_DRIVER |
295 DEVICE_FLAG_OGG_IS_UNKNOWN |
296 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij509cd652011-03-04 20:34:02 +0100297 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleijb551e962011-11-03 16:38:17 +0100298 // Reported by: traaf <traaf@users.sourceforge.net>
299 // Guessing on the playlist type!
300 // Appears to present itself properly as a PTP device with MTP extensions!
Linus Walleij7b3e3022012-01-19 17:10:25 +0100301 { "Samsung", 0x04e8, "YP-Z3", 0x5137,
302 DEVICE_FLAG_UNLOAD_DRIVER |
303 DEVICE_FLAG_OGG_IS_UNKNOWN |
304 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleijb551e962011-11-03 16:38:17 +0100305 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleije8079072010-04-02 12:25:50 +0000306 // From a rouge .INF file
Linus Walleij23ab1542008-01-06 22:10:34 +0000307 // this device ID seems to have been recycled for:
308 // the Samsung SGH-A707 Cingular cellphone
309 // the Samsung L760-V cellphone
Linus Walleij5b03d302008-11-25 20:39:27 +0000310 // the Samsung SGH-U900 cellphone
Linus Walleij8f86b0e2011-05-27 00:05:55 +0200311 // the Samsung Fascinate player
Linus Walleijfa7782a2011-12-29 18:52:45 +0100312 { "Samsung", 0x04e8,
313 "YH-999 Portable Media Center/SGH-A707/SGH-L760V/SGH-U900/Verizon Intensity/Fascinate",
314 0x5a0f, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij2350b712008-01-14 22:54:37 +0000315 // From Santi Béjar <sbejar@gmail.com> - not sure this is MTP...
316 // { "Samsung", 0x04e8, "Z170 Mobile Phone", 0x6601, DEVICE_FLAG_UNLOAD_DRIVER },
317 // From Santi Béjar <sbejar@gmail.com> - not sure this is MTP...
318 // { "Samsung", 0x04e8, "E250 Mobile Phone", 0x663e, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij07637a62010-05-22 22:52:58 +0000319 // From an anonymous SF user
Linus Walleij7b3e3022012-01-19 17:10:25 +0100320 { "Samsung", 0x04e8, "M7600 Beat/GT-S8300T/SGH-F490/S8300", 0x6642,
321 DEVICE_FLAG_UNLOAD_DRIVER |
322 DEVICE_FLAG_BROKEN_BATTERY_LEVEL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000323 // From Lionel Bouton
Linus Walleij7b3e3022012-01-19 17:10:25 +0100324 { "Samsung", 0x04e8, "X830 Mobile Phone", 0x6702,
325 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000326 // From James <jamestech@gmail.com>
Linus Walleij7b3e3022012-01-19 17:10:25 +0100327 { "Samsung", 0x04e8, "U600 Mobile Phone", 0x6709,
328 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij5b03d302008-11-25 20:39:27 +0000329 // From Cesar Cardoso <cesar@cesarcardoso.tk>
330 // No confirmation that this is really MTP.
Linus Walleij7b3e3022012-01-19 17:10:25 +0100331 { "Samsung", 0x04e8, "F250 Mobile Phone", 0x6727,
332 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijc50e7682007-11-02 00:01:17 +0000333 // From Charlie Todd 2007-10-31
Linus Walleij7b3e3022012-01-19 17:10:25 +0100334 { "Samsung", 0x04e8, "Juke (SCH-U470)", 0x6734,
335 DEVICE_FLAG_UNLOAD_DRIVER},
Linus Walleij34b421f2009-07-23 22:30:51 +0000336 // Reported by Tenn
Linus Walleij7b3e3022012-01-19 17:10:25 +0100337 { "Samsung", 0x04e8, "GT-B2700", 0x6752,
338 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij5f0814f2009-07-23 21:53:38 +0000339 // Added by Greg Fitzgerald <netzdamon@gmail.com>
Linus Walleij7b3e3022012-01-19 17:10:25 +0100340 { "Samsung", 0x04e8, "SAMSUNG Trance", 0x6763,
341 DEVICE_FLAG_UNLOAD_DRIVER |
342 DEVICE_FLAG_NO_ZERO_READS |
343 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij1753a6c2011-02-11 18:46:08 +0100344 // From anonymous sourceforge user
345 // Guessing on .spl flag, maybe needs NO_ZERO_READS, whatdoIknow
346 { "Samsung", 0x04e8, "GT-S8500", 0x6819,
Linus Walleij7b3e3022012-01-19 17:10:25 +0100347 DEVICE_FLAG_UNLOAD_DRIVER |
348 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleijfa7782a2011-12-29 18:52:45 +0100349 // From Harrison Metzger <harrisonmetz@gmail.com>
Linus Walleij14cee672012-01-06 12:54:47 +0100350 { "Samsung", 0x04e8,
351 "Galaxy Nexus/Galaxy S i9000, Android 4.0 updates", 0x685c,
Linus Walleij74339382012-01-18 19:56:13 +0100352 DEVICE_FLAGS_ANDROID_BUGS |
353 DEVICE_FLAG_PLAYLIST_SPL_V2 },
Linus Walleij2c5470f2011-08-08 11:34:41 +0200354 // Reported by anonymous sourceforge user - this is an Android
355 // device. It seems to be hard to use this device under Linux,
356 // which may be because it seems to implement fairly strong
357 // Microsoft DRM stuff.
Linus Walleij475e8802012-01-06 17:40:12 +0100358 // Seems also to be used with Galaxy Nexus debug mode and on
359 // US markets for some weird reason.
Linus Walleij14cee672012-01-06 12:54:47 +0100360 { "Samsung", 0x04e8,
Linus Walleij3244fd72012-02-22 03:58:23 +0100361 "GT-P7510/Galaxy Tab 7.7/10.1/S2/GT-N7000/Galaxy Nexus", 0x6860,
Linus Walleij3dd6eeb2011-05-27 00:38:13 +0200362 DEVICE_FLAG_UNLOAD_DRIVER |
363 DEVICE_FLAG_LONG_TIMEOUT },
Linus Walleij4467c7f2010-08-20 22:09:00 +0000364 // From: Erik Berglund <erikjber@users.sourceforge.net>
365 // Logs indicate this needs DEVICE_FLAG_NO_ZERO_READS
Linus Walleije04a1b92011-03-09 18:00:24 +0100366 // No Samsung platlists on this device.
Linus Walleijbfb8e642010-08-29 07:38:15 +0000367 // https://sourceforge.net/tracker/?func=detail&atid=809061&aid=3026337&group_id=158745
Linus Walleij14cee672012-01-06 12:54:47 +0100368 // i5800 duplicate reported by igel <igel-kun@users.sourceforge.net>
Linus Walleij7b3e3022012-01-19 17:10:25 +0100369 { "Samsung", 0x04e8, "Galaxy S GT-I9000/Galaxy 3 i5800/Kies mode", 0x6877,
Linus Walleij3dd6eeb2011-05-27 00:38:13 +0200370 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleije04a1b92011-03-09 18:00:24 +0100371 DEVICE_FLAG_LONG_TIMEOUT },
Linus Walleij3dd6eeb2011-05-27 00:38:13 +0200372 // From: John Gorkos <ab0oo@users.sourceforge.net> and
373 // Akos Maroy <darkeye@users.sourceforge.net>
Linus Walleij7b3e3022012-01-19 17:10:25 +0100374 { "Samsung", 0x04e8, "Vibrant SGH-T959/Captivate/Media player mode", 0x68a9,
Linus Walleijb8a9be22011-05-27 00:24:35 +0200375 DEVICE_FLAG_UNLOAD_DRIVER |
376 DEVICE_FLAG_PLAYLIST_SPL_V1 },
377 // Reported by Sleep.Walker <froser@users.sourceforge.net>
378 { "Samsung", 0x04e8, "GT-B2710/Xcover 271", 0x68af,
379 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleijbfb8e642010-08-29 07:38:15 +0000380 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleijd866d242009-08-23 21:50:39 +0000381 // From anonymous Sourceforge user
382 { "Samsung", 0x04e8, "GT-S5230", 0xe20c, DEVICE_FLAG_NONE },
383
Linus Walleij1a673de2007-10-29 23:10:05 +0000384
385 /*
Linus Walleij414a0832009-09-18 23:04:05 +0000386 * Microsoft & Intel
Linus Walleij1a673de2007-10-29 23:10:05 +0000387 */
388 { "Intel", 0x045e, "Bandon Portable Media Center", 0x00c9, DEVICE_FLAG_NONE },
Linus Walleij14cee672012-01-06 12:54:47 +0100389 // Reported by anonymous sourceforge user
Linus Walleij2ad98c82012-02-22 04:06:32 +0100390 // HTC Mozart is using the PID, as is Nokia Lumia 800
Linus Walleijb1dcb702012-01-12 23:34:04 +0100391 // May need MTPZ to work
Linus Walleij14cee672012-01-06 12:54:47 +0100392 { "Microsoft", 0x045e, "Windows Phone", 0x04ec, DEVICE_FLAG_NONE },
Linus Walleij414aca02008-06-02 23:16:49 +0000393 // Reported by Tadimarri Sarath <sarath.tadi@gmail.com>
394 // No idea why this use an Intel PID, perhaps a leftover from
395 // the early PMC development days when Intel and Microsoft were
396 // partnering.
397 { "Microsoft", 0x045e, "Windows MTP Simulator", 0x0622, DEVICE_FLAG_NONE },
Linus Walleij414a0832009-09-18 23:04:05 +0000398 // Reported by Edward Hutchins (used for Zune HDs)
399 { "Microsoft", 0x045e, "Zune HD", 0x063e, DEVICE_FLAG_NONE },
Linus Walleij1753a6c2011-02-11 18:46:08 +0100400 // Reported by anonymous sourceforge user
401 { "Microsoft", 0x045e, "Kin 1", 0x0640, DEVICE_FLAG_NONE },
Linus Walleij414a0832009-09-18 23:04:05 +0000402 // Reported by Farooq Zaman (used for all Zunes)
Linus Walleij1753a6c2011-02-11 18:46:08 +0100403 { "Microsoft", 0x045e, "Zune", 0x0710, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000404
405 /*
406 * JVC
407 */
408 // From Mark Veinot
409 { "JVC", 0x04f1, "Alneo XA-HD500", 0x6105, DEVICE_FLAG_NONE },
410
411 /*
412 * Philips
413 */
414 { "Philips", 0x0471, "HDD6320/00 or HDD6330/17", 0x014b, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
415 // Anonymous SourceForge user
Linus Walleijf0702982008-10-25 21:37:43 +0000416 { "Philips", 0x0471, "HDD14XX,HDD1620 or HDD1630/17", 0x014c, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000417 // from discussion forum
418 { "Philips", 0x0471, "HDD085/00 or HDD082/17", 0x014d, DEVICE_FLAG_NONE },
419 // from XNJB forum
Richard Low641d1e32008-02-24 20:47:20 +0000420 { "Philips", 0x0471, "GoGear SA9200", 0x014f, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000421 // From John Coppens <jcoppens@users.sourceforge.net>
422 { "Philips", 0x0471, "SA1115/55", 0x0164, DEVICE_FLAG_NONE },
423 // From Gerhard Mekenkamp
424 { "Philips", 0x0471, "GoGear Audio", 0x0165, DEVICE_FLAG_NONE },
425 // from David Holm <wormie@alberg.dk>
426 { "Philips", 0x0471, "Shoqbox", 0x0172, DEVICE_FLAG_ONLY_7BIT_FILENAMES },
427 // from npedrosa
428 { "Philips", 0x0471, "PSA610", 0x0181, DEVICE_FLAG_NONE },
429 // From libgphoto2 source
430 { "Philips", 0x0471, "HDD6320", 0x01eb, DEVICE_FLAG_NONE },
431 // From Detlef Meier <dm@emlix.com>
Linus Walleija8ba8c72008-03-29 00:02:27 +0000432 { "Philips", 0x0471, "GoGear SA6014/SA6015/SA6024/SA6025/SA6044/SA6045", 0x084e, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij23ab1542008-01-06 22:10:34 +0000433 // From anonymous Sourceforge user SA5145/02
Linus Walleija8ba8c72008-03-29 00:02:27 +0000434 { "Philips", 0x0471, "GoGear SA5145", 0x0857, DEVICE_FLAG_UNLOAD_DRIVER },
435 // From a
436 { "Philips", 0x0471, "GoGear SA6125/SA6145/SA6185", 0x2002, DEVICE_FLAG_UNLOAD_DRIVER },
437 // From anonymous Sourceforge user, not verified to be MTP!
438 { "Philips", 0x0471, "GoGear SA3345", 0x2004, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij2242b022009-01-02 01:44:00 +0000439 // From Roberto Vidmar <rvidmar@libero.it>
440 { "Philips", 0x0471, "SA5285", 0x2022, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij15ed3b32009-07-23 22:19:43 +0000441 // From Elie De Brauwer <elie@de-brauwer.be>
442 { "Philips", 0x0471, "GoGear ViBE SA1VBE04", 0x2075,
443 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij99d390e2010-01-19 01:17:39 +0000444 // From Anonymous SourceForge user
445 { "Philips", 0x0471, "GoGear Muse", 0x2077,
446 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij15ed3b32009-07-23 22:19:43 +0000447 // From Elie De Brauwer <elie@de-brauwer.be>
Linus Walleijcd8eb5c2010-05-15 00:22:47 +0000448 { "Philips", 0x0471, "GoGear ViBE SA1VBE04/08", 0x207b,
Linus Walleij15ed3b32009-07-23 22:19:43 +0000449 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijd866d242009-08-23 21:50:39 +0000450 // From josmtx <josmtx@users.sourceforge.net>
451 { "Philips", 0x0471, "GoGear Aria", 0x207c,
452 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij5e44ed52010-01-30 08:06:11 +0000453 // From epklein
454 { "Philips", 0x0471, "GoGear SA1VBE08KX/78", 0x208e,
455 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij5a446622010-10-17 21:56:05 +0000456 // From Anonymous SourceForge User
Linus Walleij01d5a732011-01-08 22:40:26 +0000457 { "Philips", 0x0471, "GoGear VIBE SA2VBE[08|16]K/02", 0x20b7,
Linus Walleij7c710892011-05-26 23:44:48 +0200458 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij7c1b9072011-06-26 20:08:11 +0200459 // From Anonymous SourceForge User
460 { "Philips", 0x0471, "GoGear Ariaz", 0x20b9,
461 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij126e1542011-10-22 00:16:20 +0200462 // From Anonymous SourceForge User
463 { "Philips", 0x0471, "GoGear Vibe/02", 0x20e5,
464 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000465 // from XNJB user
466 { "Philips", 0x0471, "PSA235", 0x7e01, DEVICE_FLAG_NONE },
467
Linus Walleij1a673de2007-10-29 23:10:05 +0000468 /*
Linus Walleij7c710892011-05-26 23:44:48 +0200469 * Acer
470 */
Linus Walleijea936352011-05-27 00:12:10 +0200471 // Reported by anonymous sourceforge user
Linus Walleij59b56fd2012-01-12 22:09:57 +0100472 { "Acer", 0x0502, "Iconia TAB A500 v1", 0x3325, DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij7c710892011-05-26 23:44:48 +0200473 // Reported by: Franck VDL <franckv@users.sourceforge.net>
Linus Walleij59b56fd2012-01-12 22:09:57 +0100474 { "Acer", 0x0502, "Iconia TAB A500 v2", 0x3341, DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij7ac993a2012-01-19 17:28:48 +0100475 // Reported by: anonymous sourceforge user
476 { "Acer", 0x0502, "Iconia TAB A100", 0x3348, DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij03f0c032011-10-22 00:01:14 +0200477 // Reported by: Arvin Schnell <arvins@users.sourceforge.net>
Linus Walleij7ac993a2012-01-19 17:28:48 +0100478 { "Acer", 0x0502, "Iconia TAB A100 ID2", 0x3349, DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij59b56fd2012-01-12 22:09:57 +0100479 // Reported by anonymous sourceforge user
480 { "Acer", 0x0502, "Iconia TAB A200", 0x337c, DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij7c710892011-05-26 23:44:48 +0200481
482 /*
Linus Walleij1a673de2007-10-29 23:10:05 +0000483 * SanDisk
Linus Walleij8f86b0e2011-05-27 00:05:55 +0200484 * several devices (c150 for sure) are definately dual-mode and must
Linus Walleij1a673de2007-10-29 23:10:05 +0000485 * have the USB mass storage driver that hooks them unloaded first.
486 * They all have problematic dual-mode making the device unload effect
Linus Walleij5e202562008-06-03 11:35:05 +0000487 * uncertain on these devices.
488 *
489 * All older devices seem to need DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL.
490 * Old chipsets: e200/c200 use PP5024 from Nvidia (formerly PortalPlayer).
491 * m200 use TCC770 from Telechips.
492 *
Linus Walleij8f86b0e2011-05-27 00:05:55 +0200493 * The newer Sansa v2 chipset, AD3525 from Austriamicrosystems (AMS) found
494 * in e280 v2 c200 v2, Clip, Fuze etc require
495 * DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST
Linus Walleij5e202562008-06-03 11:35:05 +0000496 * and DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR to work properly.
497 *
498 * For more info see: http://daniel.haxx.se/sansa/v2.html
Linus Walleij1a673de2007-10-29 23:10:05 +0000499 */
500 // Reported by Brian Robison
Linus Walleijde1620f2009-06-15 20:02:02 +0000501 { "SanDisk", 0x0781, "Sansa m230/m240", 0x7400,
Linus Walleij1a673de2007-10-29 23:10:05 +0000502 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000503 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij18ed0162009-05-06 16:51:08 +0000504 // From Rockbox device listing
Linus Walleijde1620f2009-06-15 20:02:02 +0000505 { "SanDisk", 0x0781, "Sansa m200-tcc (MTP mode)", 0x7401,
Linus Walleij18ed0162009-05-06 16:51:08 +0000506 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
507 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000508 // Reported by tangent_@users.sourceforge.net
Linus Walleijde1620f2009-06-15 20:02:02 +0000509 { "SanDisk", 0x0781, "Sansa c150", 0x7410,
Linus Walleij1a673de2007-10-29 23:10:05 +0000510 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000511 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000512 // From libgphoto2 source
513 // Reported by <gonkflea@users.sourceforge.net>
514 // Reported by Mike Owen <mikeowen@computerbaseusa.com>
Linus Walleij18ed0162009-05-06 16:51:08 +0000515 { "SanDisk", 0x0781, "Sansa e200/e250/e260/e270/e280", 0x7420,
Linus Walleij1a673de2007-10-29 23:10:05 +0000516 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000517 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Richard Low58f5afe2009-04-30 13:24:06 +0000518 // Don't add 0x7421 as this is e280 in MSC mode
Linus Walleij1a673de2007-10-29 23:10:05 +0000519 // Reported by XNJB user
Linus Walleij18ed0162009-05-06 16:51:08 +0000520 { "SanDisk", 0x0781, "Sansa e260/e280 v2", 0x7422,
Linus Walleij5e202562008-06-03 11:35:05 +0000521 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij37588142008-10-16 19:10:47 +0000522 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000523 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Richard Lowd56e8a62007-12-08 16:59:11 +0000524 // Reported by XNJB user
Linus Walleijde1620f2009-06-15 20:02:02 +0000525 { "SanDisk", 0x0781, "Sansa m240/m250", 0x7430,
Linus Walleij1a673de2007-10-29 23:10:05 +0000526 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000527 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij077a8902007-11-15 21:18:12 +0000528 // Reported by Eugene Brevdo <ebrevdo@princeton.edu>
Linus Walleij5e202562008-06-03 11:35:05 +0000529 { "SanDisk", 0x0781, "Sansa Clip", 0x7432,
530 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij37588142008-10-16 19:10:47 +0000531 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000532 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
Linus Walleij39f9a452008-11-15 09:39:39 +0000533 // Reported by HackAR <hackar@users.sourceforge.net>
Linus Walleij624a15a2009-01-06 00:31:34 +0000534 { "SanDisk", 0x0781, "Sansa Clip v2", 0x7434,
Linus Walleij39f9a452008-11-15 09:39:39 +0000535 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
536 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
537 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
Linus Walleij1a673de2007-10-29 23:10:05 +0000538 // Reported by anonymous user at sourceforge.net
Linus Walleijde1620f2009-06-15 20:02:02 +0000539 { "SanDisk", 0x0781, "Sansa c240/c250", 0x7450,
Linus Walleij1a673de2007-10-29 23:10:05 +0000540 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000541 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij2242b022009-01-02 01:44:00 +0000542 // Reported by anonymous SourceForge user
Linus Walleijde1620f2009-06-15 20:02:02 +0000543 { "SanDisk", 0x0781, "Sansa c250 v2", 0x7452,
Linus Walleij2242b022009-01-02 01:44:00 +0000544 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
545 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000546 // Reported by Troy Curtis Jr.
Linus Walleijde1620f2009-06-15 20:02:02 +0000547 { "SanDisk", 0x0781, "Sansa Express", 0x7460,
548 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000549 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000550 // Reported by XNJB user, and Miguel de Icaza <miguel@gnome.org>
551 // This has no dual-mode so no need to unload any driver.
552 // This is a Linux based device!
553 { "SanDisk", 0x0781, "Sansa Connect", 0x7480, DEVICE_FLAG_NONE },
554 // Reported by anonymous SourceForge user
Linus Walleijde1620f2009-06-15 20:02:02 +0000555 { "SanDisk", 0x0781, "Sansa View", 0x74b0,
Linus Walleij1a673de2007-10-29 23:10:05 +0000556 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000557 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij690a3162008-03-31 21:40:23 +0000558 // Reported by Patrick <skibler@gmail.com>
559 // There are apparently problems with this device.
Linus Walleij25a16302009-03-04 13:56:33 +0000560 { "SanDisk", 0x0781, "Sansa Fuze", 0x74c0,
561 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
562 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleij19c05422011-01-08 23:00:16 +0000563 DEVICE_FLAG_BROKEN_SET_SAMPLE_DIMENSIONS |
Linus Walleij25a16302009-03-04 13:56:33 +0000564 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
565 // Harry Phillips <tuxcomputers@users.sourceforge.net>
566 { "SanDisk", 0x0781, "Sansa Fuze v2", 0x74c2,
Linus Walleij5e202562008-06-03 11:35:05 +0000567 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij37588142008-10-16 19:10:47 +0000568 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleij19c05422011-01-08 23:00:16 +0000569 DEVICE_FLAG_BROKEN_SET_SAMPLE_DIMENSIONS |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000570 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleija5cb5c92009-10-10 22:03:38 +0000571 // Reported by anonymous SourceForge user
Linus Walleij19c05422011-01-08 23:00:16 +0000572 // Need BROKEN_SET_SAMPLE_DIMENSIONS accordning to
573 // Michael <mpapet@users.sourceforge.net>
Linus Walleija5cb5c92009-10-10 22:03:38 +0000574 { "SanDisk", 0x0781, "Sansa Clip+", 0x74d0,
575 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
576 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleij19c05422011-01-08 23:00:16 +0000577 DEVICE_FLAG_BROKEN_SET_SAMPLE_DIMENSIONS |
Linus Walleija5cb5c92009-10-10 22:03:38 +0000578 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
Linus Walleij3d707582010-11-24 15:13:45 +0000579 // Reported by anonymous SourceForge user
580 { "SanDisk", 0x0781, "Sansa Fuze+", 0x74e0,
581 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
582 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleij19c05422011-01-08 23:00:16 +0000583 DEVICE_FLAG_BROKEN_SET_SAMPLE_DIMENSIONS |
Linus Walleij3d707582010-11-24 15:13:45 +0000584 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
Linus Walleij7cf3d3f2011-10-22 00:36:09 +0200585 // Reported by mattyj2001@users.sourceforge.net
586 { "SanDisk", 0x0781, "Sansa Clip Zip", 0x74e4,
587 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
588 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
589 DEVICE_FLAG_BROKEN_SET_SAMPLE_DIMENSIONS |
590 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
Linus Walleij1a673de2007-10-29 23:10:05 +0000591
592 /*
593 * iRiver
594 * we assume that PTP_OC_MTP_GetObjPropList is essentially
595 * broken on all iRiver devices, meaning it simply won't return
Linus Walleij688e5542010-02-01 11:35:15 +0000596 * all properties for a file when asking for metadata 0xffffffff.
Linus Walleij1a673de2007-10-29 23:10:05 +0000597 * Please test on your device if you believe it isn't broken!
Linus Walleij1a673de2007-10-29 23:10:05 +0000598 */
Linus Walleij18ed0162009-05-06 16:51:08 +0000599 { "iRiver", 0x1006, "H300 Series MTP", 0x3004,
Linus Walleij688e5542010-02-01 11:35:15 +0000600 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000601 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij18ed0162009-05-06 16:51:08 +0000602 { "iRiver", 0x1006, "Portable Media Center", 0x4002,
Linus Walleij688e5542010-02-01 11:35:15 +0000603 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij18ed0162009-05-06 16:51:08 +0000604 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
605 { "iRiver", 0x1006, "Portable Media Center", 0x4003,
Linus Walleij688e5542010-02-01 11:35:15 +0000606 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000607 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij2242b022009-01-02 01:44:00 +0000608 // From [st]anislav <iamstanislav@gmail.com>
Linus Walleijdeb1aca2009-01-02 23:20:06 +0000609 { "iRiver", 0x1042, "T7 Volcano", 0x1143, DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij80a2a692008-12-05 20:36:40 +0000610 // From an anonymous person at SourceForge, uncertain about this one
Linus Walleij688e5542010-02-01 11:35:15 +0000611 { "iRiver", 0x4102, "iFP-880", 0x1008,
612 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000613 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij80a2a692008-12-05 20:36:40 +0000614 // 0x4102, 0x1042 is a USB mass storage mode for E100 v2/Lplayer
Linus Walleij1a673de2007-10-29 23:10:05 +0000615 // From libgphoto2 source
Linus Walleij688e5542010-02-01 11:35:15 +0000616 { "iRiver", 0x4102, "T10", 0x1113,
617 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000618 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij688e5542010-02-01 11:35:15 +0000619 { "iRiver", 0x4102, "T20 FM", 0x1114,
620 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000621 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
622 // This appears at the MTP-UMS site
Linus Walleij688e5542010-02-01 11:35:15 +0000623 { "iRiver", 0x4102, "T20", 0x1115,
624 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000625 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij688e5542010-02-01 11:35:15 +0000626 { "iRiver", 0x4102, "U10", 0x1116,
627 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000628 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij688e5542010-02-01 11:35:15 +0000629 { "iRiver", 0x4102, "T10a", 0x1117,
630 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000631 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij688e5542010-02-01 11:35:15 +0000632 { "iRiver", 0x4102, "T20", 0x1118,
633 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000634 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij688e5542010-02-01 11:35:15 +0000635 { "iRiver", 0x4102, "T30", 0x1119,
636 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000637 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
638 // Reported by David Wolpoff
Linus Walleij688e5542010-02-01 11:35:15 +0000639 { "iRiver", 0x4102, "T10 2GB", 0x1120,
640 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000641 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
642 // Rough guess this is the MTP device ID...
Linus Walleij688e5542010-02-01 11:35:15 +0000643 { "iRiver", 0x4102, "N12", 0x1122,
644 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000645 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
646 // Reported by Philip Antoniades <philip@mysql.com>
647 // Newer iriver devices seem to have shaped-up firmware without any
648 // of the annoying bugs.
649 { "iRiver", 0x4102, "Clix2", 0x1126, DEVICE_FLAG_NONE },
650 // Reported by Adam Torgerson
Linus Walleij688e5542010-02-01 11:35:15 +0000651 { "iRiver", 0x4102, "Clix", 0x112a,
Linus Walleij1a673de2007-10-29 23:10:05 +0000652 DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
653 // Reported by Douglas Roth <dougaus@gmail.com>
Linus Walleij688e5542010-02-01 11:35:15 +0000654 { "iRiver", 0x4102, "X20", 0x1132,
655 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000656 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
657 // Reported by Robert Ugo <robert_ugo@users.sourceforge.net>
Linus Walleij688e5542010-02-01 11:35:15 +0000658 { "iRiver", 0x4102, "T60", 0x1134,
659 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000660 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000661 // Reported by two anonymous SourceForge users
Linus Walleij07bb5382008-07-31 20:21:09 +0000662 // Needs the stronger OGG_IS_UNKNOWN flag to support OGG properly,
663 // be aware of newer players that may be needing this too.
Linus Walleij688e5542010-02-01 11:35:15 +0000664 { "iRiver", 0x4102, "E100", 0x1141,
665 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij07bb5382008-07-31 20:21:09 +0000666 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000667 // Reported by anonymous SourceForge user
668 // Need verification of whether this firmware really need all these flags
Linus Walleij688e5542010-02-01 11:35:15 +0000669 { "iRiver", 0x4102, "E100 v2/Lplayer", 0x1142,
670 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleijc2bc9732008-08-14 21:12:44 +0000671 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij6e680ad2009-01-07 21:22:45 +0000672 // Reported by Richard Vennemann <vennemann@users.sourceforge.net>
Linus Walleij16ee3422009-01-08 23:15:52 +0000673 // In USB Mass Storage mode it is 0x4102/0x1047
Linus Walleijb57167c2009-01-10 22:37:51 +0000674 // Seems to use the new shaped-up firmware.
675 { "iRiver", 0x4102, "Spinn", 0x1147, DEVICE_FLAG_NONE },
Linus Walleije84dcf12009-05-14 20:33:05 +0000676 // Reported by Tony Janssen <tonyjanssen@users.sourceforge.net>
677 { "iRiver", 0x4102, "E50", 0x1151,
Linus Walleij688e5542010-02-01 11:35:15 +0000678 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
679 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij92741922010-10-14 22:05:56 +0000680 // Reported by Jakub Matraszek <jakub.matraszek@gmail.com>
681 { "iRiver", 0x4102, "T5", 0x1153,
682 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
683 DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij688e5542010-02-01 11:35:15 +0000684 // Reported by pyalex@users.sourceforge.net
685 // Guessing that this needs the FLAG_NO_ZERO_READS...
686 { "iRiver", 0x4102, "E30", 0x1167,
687 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleije84dcf12009-05-14 20:33:05 +0000688 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +0000689 // Reported by Scott Call
Linus Walleij07bb5382008-07-31 20:21:09 +0000690 // Assume this actually supports OGG though it reports it doesn't.
Linus Walleij688e5542010-02-01 11:35:15 +0000691 { "iRiver", 0x4102, "H10 20GB", 0x2101,
692 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij07bb5382008-07-31 20:21:09 +0000693 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij688e5542010-02-01 11:35:15 +0000694 { "iRiver", 0x4102, "H10 5GB", 0x2102,
695 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij18ed0162009-05-06 16:51:08 +0000696 DEVICE_FLAG_OGG_IS_UNKNOWN },
697 // From Rockbox device listing
Linus Walleij688e5542010-02-01 11:35:15 +0000698 { "iRiver", 0x4102, "H10 5.6GB", 0x2105,
699 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij07bb5382008-07-31 20:21:09 +0000700 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +0000701
702
703 /*
704 * Dell
705 */
706 { "Dell, Inc", 0x413c, "DJ Itty", 0x4500, DEVICE_FLAG_NONE },
Linus Walleij15c12e02011-10-22 00:06:18 +0200707 /* Reported by: JR */
708 { "Dell, Inc", 0x413c, "Dell Streak 7", 0xb10b, DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij8f86b0e2011-05-27 00:05:55 +0200709
Linus Walleij1a673de2007-10-29 23:10:05 +0000710 /*
711 * Toshiba
Linus Walleij7e3b3072009-01-19 22:51:17 +0000712 * Tentatively flagged all Toshiba devices with
713 * DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST after one of them
714 * showed erroneous behaviour.
Linus Walleij1a673de2007-10-29 23:10:05 +0000715 */
Linus Walleij7e3b3072009-01-19 22:51:17 +0000716 { "Toshiba", 0x0930, "Gigabeat MEGF-40", 0x0009,
Linus Walleij6e50b1b2012-01-11 07:50:52 +0100717 DEVICE_FLAG_NO_RELEASE_INTERFACE |
718 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij7e3b3072009-01-19 22:51:17 +0000719 { "Toshiba", 0x0930, "Gigabeat", 0x000c,
Linus Walleij6e50b1b2012-01-11 07:50:52 +0100720 DEVICE_FLAG_NO_RELEASE_INTERFACE |
721 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000722 // Reported by Nicholas Tripp
Linus Walleij7e3b3072009-01-19 22:51:17 +0000723 { "Toshiba", 0x0930, "Gigabeat P20", 0x000f,
Linus Walleij6e50b1b2012-01-11 07:50:52 +0100724 DEVICE_FLAG_NO_RELEASE_INTERFACE |
725 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000726 // From libgphoto2
Linus Walleij6e50b1b2012-01-11 07:50:52 +0100727 { "Toshiba", 0x0930, "Gigabeat S", 0x0010,
728 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
729 DEVICE_FLAG_NO_RELEASE_INTERFACE |
730 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000731 // Reported by Rob Brown
Linus Walleij7e3b3072009-01-19 22:51:17 +0000732 { "Toshiba", 0x0930, "Gigabeat P10", 0x0011,
Linus Walleij6e50b1b2012-01-11 07:50:52 +0100733 DEVICE_FLAG_NO_RELEASE_INTERFACE |
734 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij51dde6b2007-11-03 23:14:59 +0000735 // Reported by solanum@users.sourceforge.net
Linus Walleij7e3b3072009-01-19 22:51:17 +0000736 { "Toshiba", 0x0930, "Gigabeat V30", 0x0014,
Linus Walleij6e50b1b2012-01-11 07:50:52 +0100737 DEVICE_FLAG_NO_RELEASE_INTERFACE |
738 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000739 // Reported by Michael Davis <slithy@yahoo.com>
Linus Walleij7e3b3072009-01-19 22:51:17 +0000740 { "Toshiba", 0x0930, "Gigabeat U", 0x0016,
Linus Walleij6e50b1b2012-01-11 07:50:52 +0100741 DEVICE_FLAG_NO_RELEASE_INTERFACE |
742 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij804cc622008-02-03 21:26:26 +0000743 // Reported by Devon Jacobs <devo@godevo.com>
Linus Walleijf67c1ad2009-01-14 21:39:50 +0000744 { "Toshiba", 0x0930, "Gigabeat MEU202", 0x0018,
Linus Walleij6e50b1b2012-01-11 07:50:52 +0100745 DEVICE_FLAG_NO_RELEASE_INTERFACE |
746 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleijc76e2f72007-12-09 22:14:35 +0000747 // Reported by Rolf <japan (at) dl3lar.de>
Linus Walleij7e3b3072009-01-19 22:51:17 +0000748 { "Toshiba", 0x0930, "Gigabeat T", 0x0019,
Linus Walleij6e50b1b2012-01-11 07:50:52 +0100749 DEVICE_FLAG_NO_RELEASE_INTERFACE |
750 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij07bb5382008-07-31 20:21:09 +0000751 // Reported by Phil Ingram <ukpbert@users.sourceforge.net>
752 // Tentatively added - no real reports of this device ID being MTP,
753 // reports as USB Mass Storage currently.
Linus Walleij7e3b3072009-01-19 22:51:17 +0000754 { "Toshiba", 0x0930, "Gigabeat MEU201", 0x001a,
Linus Walleij6e50b1b2012-01-11 07:50:52 +0100755 DEVICE_FLAG_NO_RELEASE_INTERFACE |
756 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij922880f2008-10-29 17:31:42 +0000757 // Reported by anonymous SourceForge user
Linus Walleij7e3b3072009-01-19 22:51:17 +0000758 { "Toshiba", 0x0930, "Gigabeat MET401", 0x001d,
Linus Walleij6e50b1b2012-01-11 07:50:52 +0100759 DEVICE_FLAG_NO_RELEASE_INTERFACE |
760 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
761 // Reported by Nigel Cunningham <nigel@tuxonice.net>
762 // Guessing on Android bugs
763 { "Toshiba", 0x0930, "Thrive AT105", 0x7100,
764 DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij804cc622008-02-03 21:26:26 +0000765
Linus Walleij1a673de2007-10-29 23:10:05 +0000766 /*
767 * Archos
768 * These devices have some dual-mode interfaces which will really
769 * respect the driver unloading, so DEVICE_FLAG_UNLOAD_DRIVER
770 * really work on these devices!
771 */
772 // Reported by Alexander Haertig <AlexanderHaertig@gmx.de>
773 { "Archos", 0x0e79, "Gmini XS100", 0x1207, DEVICE_FLAG_UNLOAD_DRIVER },
774 // Added by Jan Binder
775 { "Archos", 0x0e79, "XS202 (MTP mode)", 0x1208, DEVICE_FLAG_NONE },
776 // Reported by gudul1@users.sourceforge.net
777 { "Archos", 0x0e79, "104 (MTP mode)", 0x120a, DEVICE_FLAG_NONE },
Richard Lowe525e542009-11-09 21:09:52 +0000778 // Reported by Archos
779 { "Archos", 0x0e79, "204 (MTP mode)", 0x120c, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij4c3cd682008-01-27 22:18:05 +0000780 // Reported by anonymous Sourceforge user.
781 { "Archos", 0x0e79, "404 (MTP mode)", 0x1301, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000782 // Reported by Archos
783 { "Archos", 0x0e79, "404CAM (MTP mode)", 0x1303, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000784 // Reported by Etienne Chauchot <chauchot.etienne@free.fr>
785 { "Archos", 0x0e79, "504 (MTP mode)", 0x1307, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000786 // Reported by Archos
787 { "Archos", 0x0e79, "604 (MTP mode)", 0x1309, DEVICE_FLAG_UNLOAD_DRIVER },
788 { "Archos", 0x0e79, "604WIFI (MTP mode)", 0x130b, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000789 // Reported by Kay McCormick <kaym@modsystems.com>
790 { "Archos", 0x0e79, "704 mobile dvr", 0x130d, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000791 // Reported by Archos
792 { "Archos", 0x0e79, "704TV (MTP mode)", 0x130f, DEVICE_FLAG_UNLOAD_DRIVER },
793 { "Archos", 0x0e79, "405 (MTP mode)", 0x1311, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij121b7f22007-12-08 21:37:35 +0000794 // Reported by Joe Rabinoff
Linus Walleije71639a2007-12-08 21:36:00 +0000795 { "Archos", 0x0e79, "605 (MTP mode)", 0x1313, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000796 // Reported by Archos
797 { "Archos", 0x0e79, "605F (MTP mode)", 0x1315, DEVICE_FLAG_UNLOAD_DRIVER },
798 { "Archos", 0x0e79, "705 (MTP mode)", 0x1319, DEVICE_FLAG_UNLOAD_DRIVER },
799 { "Archos", 0x0e79, "TV+ (MTP mode)", 0x131b, DEVICE_FLAG_UNLOAD_DRIVER },
800 { "Archos", 0x0e79, "105 (MTP mode)", 0x131d, DEVICE_FLAG_UNLOAD_DRIVER },
801 { "Archos", 0x0e79, "405HDD (MTP mode)", 0x1321, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij4aa66dc2009-05-02 06:36:59 +0000802 // Reported by Jim Krehl <jimmuhk@users.sourceforge.net>
803 { "Archos", 0x0e79, "5 (MTP mode)", 0x1331, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij8c725002008-11-25 20:33:13 +0000804 // Reported by Adrien Guichard <tmor@users.sourceforge.net>
805 { "Archos", 0x0e79, "5 (MTP mode)", 0x1333, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000806 // Reported by Archos
807 { "Archos", 0x0e79, "7 (MTP mode)", 0x1335, DEVICE_FLAG_UNLOAD_DRIVER },
808 { "Archos", 0x0e79, "SPOD (MTP mode)", 0x1341, DEVICE_FLAG_UNLOAD_DRIVER },
809 { "Archos", 0x0e79, "5S IT (MTP mode)", 0x1351, DEVICE_FLAG_UNLOAD_DRIVER },
810 { "Archos", 0x0e79, "5H IT (MTP mode)", 0x1357, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijaa43ff72012-01-06 17:58:25 +0100811 // Reported by anonymous Sourceforge user
812 { "Archos", 0x0e79, "8o G9 (MTP mode)", 0x1508, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij0de5b192012-01-30 17:17:24 +0100813 // Reported by Clément <clemvangelis@users.sourceforge.net>
814 { "Archos", 0x0e79, "8o G9 Turbo (MTP mode)", 0x1509, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijcb9a1d12011-10-31 11:27:35 +0100815 // Reported by Till <Till@users.sourceforge.net>
Linus Walleijbdde28b2011-12-29 18:55:55 +0100816 { "Archos", 0x0e79, "101 G9", 0x1528, DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij1a673de2007-10-29 23:10:05 +0000817
818 /*
819 * Dunlop (OEM of EGOMAN ltd?) reported by Nanomad
820 * This unit is falsely detected as USB mass storage in Linux
821 * prior to kernel 2.6.19 (fixed by patch from Alan Stern)
822 * so on older kernels special care is needed to remove the
823 * USB mass storage driver that erroneously binds to the device
824 * interface.
Linus Walleij2c5470f2011-08-08 11:34:41 +0200825 *
826 * More problematic, this manufacturer+device ID seems to be
827 * reused in a USB Mass Storage device named "Zipy Fox 8GB",
828 * which means libmtp may mistreat it.
Linus Walleij1a673de2007-10-29 23:10:05 +0000829 */
830 { "Dunlop", 0x10d6, "MP3 player 1GB / EGOMAN MD223AFD", 0x2200, DEVICE_FLAG_UNLOAD_DRIVER},
Linus Walleij07bb5382008-07-31 20:21:09 +0000831 // Reported by Steven Black <stevenblack1956@users.sourceforge.net>
832 // Obviously this company goes by many names.
Linus Walleij102a72d2008-11-27 23:16:47 +0000833 // This device is USB 2.0 only. Broken pipe on closing.
Linus Walleijb7e8f972010-01-19 00:38:11 +0000834 // A later report indicates that this is also used by the iRiver E200
Linus Walleije3388702010-02-03 10:02:13 +0000835 { "Memorex or iRiver", 0x10d6, "MMP 8585/8586 or iRiver E200", 0x2300,
836 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij102a72d2008-11-27 23:16:47 +0000837 DEVICE_FLAG_NO_RELEASE_INTERFACE},
Linus Walleijb7e8f972010-01-19 00:38:11 +0000838
Linus Walleij1a673de2007-10-29 23:10:05 +0000839 /*
840 * Sirius
841 */
842 { "Sirius", 0x18f6, "Stiletto", 0x0102, DEVICE_FLAG_NONE },
Linus Walleij30a7dd92008-04-09 20:33:51 +0000843 // Reported by Chris Bagwell <chris@cnpbagwell.com>
Linus Walleij2f622812008-08-30 22:06:58 +0000844 { "Sirius", 0x18f6, "Stiletto 2", 0x0110, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000845
846 /*
847 * Canon
Linus Walleija1a2eb72009-10-14 21:51:12 +0000848 * These are actually cameras, but they have a Microsoft device descriptor
849 * and reports themselves as supporting the MTP extension.
Linus Walleij1a673de2007-10-29 23:10:05 +0000850 */
Linus Walleija1a2eb72009-10-14 21:51:12 +0000851 { "Canon", 0x04a9, "Ixus Digital 700 (PTP/MTP mode)", 0x30f2,
852 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij00e6a5e2008-10-17 07:13:30 +0000853 { "Canon", 0x04a9, "PowerShot A640 (PTP/MTP mode)", 0x3139,
854 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij99d390e2010-01-19 01:17:39 +0000855 // From Peter <pjeremy@users.sourceforge.net>
856 { "Canon", 0x04a9, "PowerShot SX20IS (PTP/MTP mode)", 0x31e4,
857 DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000858
859 /*
860 * Nokia
Linus Walleij21704fd2008-02-29 22:50:29 +0000861 * Please verify the low device IDs here, I suspect these might be for
862 * things like USB storage or modem mode actually, whereas the higher
Linus Walleij9462f552008-10-25 19:16:53 +0000863 * range (0x04nn) could be for MTP. Some of the devices were gathered
864 * from the Nokia WMP drivers:
865 * http://nds2.nokia.com/files/support/global/phones/software/
866 * Address was gathered from going to:
867 * nseries.com
868 * -> support
869 * -> select supported device
870 * -> PC software
871 * -> Music software
872 * -> Windows Media Player 10 driver
Linus Walleij1a673de2007-10-29 23:10:05 +0000873 */
874 // From: DoomHammer <gaczek@users.sourceforge.net>
Linus Walleijb5a4f922008-05-11 20:15:00 +0000875 { "Nokia", 0x0421, "N81 Mobile Phone", 0x000a, DEVICE_FLAG_NONE },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000876 // From an anonymous SourceForge user
877 { "Nokia", 0x0421, "6120c Classic Mobile Phone", 0x002e, DEVICE_FLAG_NONE },
Linus Walleijbddfd192008-11-25 20:26:52 +0000878 // From Stefano
879 { "Nokia", 0x0421, "N96 Mobile Phone", 0x0039, DEVICE_FLAG_NONE },
Linus Walleijace7f4c2008-11-01 21:07:34 +0000880 // From Martijn van de Streek <martijn@vandestreek.net>
Linus Walleij4c8b6e12008-10-31 22:04:14 +0000881 { "Nokia", 0x0421, "6500c Classic Mobile Phone", 0x003c, DEVICE_FLAG_NONE },
Linus Walleijb5a4f922008-05-11 20:15:00 +0000882 // From: DoomHammer <gaczek@users.sourceforge.net>
Linus Walleij1a673de2007-10-29 23:10:05 +0000883 { "Nokia", 0x0421, "3110c Mobile Phone", 0x005f, DEVICE_FLAG_NONE },
Linus Walleija8ba8c72008-03-29 00:02:27 +0000884 // From: Vasily <spc-@users.sourceforge.net>
885 { "Nokia", 0x0421, "3109c Mobile Phone", 0x0065, DEVICE_FLAG_NONE },
Linus Walleij07bb5382008-07-31 20:21:09 +0000886 // From: <rawc@users.sourceforge.net>
887 { "Nokia", 0x0421, "5310 XpressMusic", 0x006c, DEVICE_FLAG_NONE },
Linus Walleij21704fd2008-02-29 22:50:29 +0000888 // From: robin (AT) headbank D0Tco DOTuk
889 { "Nokia", 0x0421, "N95 Mobile Phone 8GB", 0x006e, DEVICE_FLAG_NONE },
Linus Walleijcfd143d2008-10-24 20:52:48 +0000890 // From Bastien Nocera <hadess@hadess.net>
Linus Walleije3388702010-02-03 10:02:13 +0000891 { "Nokia", 0x0421, "N82 Mobile Phone", 0x0074,
892 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijace7f4c2008-11-01 21:07:34 +0000893 // From Martijn van de Streek <martijn@vandestreek.net>
Linus Walleij4c8b6e12008-10-31 22:04:14 +0000894 { "Nokia", 0x0421, "N78 Mobile Phone", 0x0079, DEVICE_FLAG_NONE },
Linus Walleij22e4bfc2009-02-09 23:24:58 +0000895 // From William Pettersson <the_enigma@users.sourceforge.net>
896 { "Nokia", 0x0421, "6220 Classic", 0x008d, DEVICE_FLAG_NONE },
Linus Walleijbbf5e7f2009-03-05 21:04:42 +0000897 // From kellerkev@gmail.com
898 { "Nokia", 0x0421, "N85 Mobile Phone", 0x0092, DEVICE_FLAG_NONE },
Linus Walleij7ef50152010-05-22 22:57:36 +0000899 // From Alexandre LISSY <lissyx@users.sourceforge.net>
900 { "Nokia", 0x0421, "6210 Navigator", 0x0098, DEVICE_FLAG_NONE },
Linus Walleij07bb5382008-07-31 20:21:09 +0000901 // From: danielw
902 { "Nokia", 0x0421, "E71", 0x00e4, DEVICE_FLAG_NONE },
Linus Walleijf3296622008-09-04 20:53:56 +0000903 // From: Laurent Bigonville <bigon@users.sourceforge.net>
904 { "Nokia", 0x0421, "E66", 0x00e5, DEVICE_FLAG_NONE },
Linus Walleij1d139362009-05-02 06:22:44 +0000905 // From: Pier <pierlucalino@users.sourceforge.net>
906 { "Nokia", 0x0421, "5320 XpressMusic", 0x00ea, DEVICE_FLAG_NONE },
Linus Walleij18faccb2009-08-03 20:21:55 +0000907 // From: Gausie <innerdreams@users.sourceforge.net>
Linus Walleije3388702010-02-03 10:02:13 +0000908 { "Nokia", 0x0421, "5800 XpressMusic", 0x0154,
909 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij79547002009-02-02 21:05:14 +0000910 // From: Willy Gardiol (web) <willy@gardiol.org>
Linus Walleijebf32cc2010-04-04 23:07:25 +0000911 // Spurious errors for getting all objects, lead me to believe
912 // this flag atleast is needed
Linus Walleije3388702010-02-03 10:02:13 +0000913 { "Nokia", 0x0421, "5800 XpressMusic v2", 0x0155,
914 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij33a4f2d2011-09-29 19:56:01 +0200915 // Yet another version... I think
916 { "Nokia", 0x0421, "5800 XpressMusic v3", 0x0159,
917 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij5b4d8e02009-01-07 21:44:59 +0000918 // From an anonymous SourceForge user
919 // Not verified to be MTP
920 { "Nokia", 0x0421, "E63", 0x0179, DEVICE_FLAG_NONE },
Linus Walleijebf32cc2010-04-04 23:07:25 +0000921 // From an anonymous SourceForge user
922 { "Nokia", 0x0421, "E71x", 0x01a1, DEVICE_FLAG_NONE },
Linus Walleij01d5a732011-01-08 22:40:26 +0000923 // From Ser <ser@users.sourceforge.net>
924 { "Nokia", 0x0421, "E52", 0x01cf, DEVICE_FLAG_NONE },
Linus Walleij07637a62010-05-22 22:52:58 +0000925 // From Marcus Meissner
926 { "Nokia", 0x0421, "3710", 0x01ee, DEVICE_FLAG_NONE },
Linus Walleij99d390e2010-01-19 01:17:39 +0000927 // From: AxeL <axel__17@users.sourceforge.net>
928 { "Nokia", 0x0421, "N97-1", 0x01f4, DEVICE_FLAG_NONE },
Linus Walleij4fe08902009-08-03 20:27:27 +0000929 // From: FunkyPenguin <awafaa@users.sourceforge.net>
930 { "Nokia", 0x0421, "N97", 0x01f5, DEVICE_FLAG_NONE },
Linus Walleijc18f1aa2010-01-19 00:19:12 +0000931 // From: Anonymous SourceForge user
932 { "Nokia", 0x0421, "5130 XpressMusic", 0x0209, DEVICE_FLAG_NONE },
Linus Walleij247b3d62010-05-22 22:22:41 +0000933 // From: Anonymous SourceForge user
934 { "Nokia", 0x0421, "E72", 0x0221, DEVICE_FLAG_NONE },
935 // From: Anonymous SourceForge user
936 { "Nokia", 0x0421, "5530", 0x0229, DEVICE_FLAG_NONE },
Linus Walleij8e1ef542010-05-22 22:46:22 +0000937 // From: Anonymous SourceForge user
938 { "Nokia", 0x0421, "N97 mini", 0x026b, DEVICE_FLAG_NONE },
Linus Walleij5ffcec92009-09-03 21:16:36 +0000939 // From: Alexander Kojevnikov <alex-kay@users.sourceforge.net>
940 { "Nokia", 0x0421, "6600i", 0x0297, DEVICE_FLAG_NONE },
Linus Walleij5f5360f2010-11-24 13:37:50 +0000941 // From: Karthik Paithankar <whyagain2005@users.sourceforge.net>
942 { "Nokia", 0x0421, "2710", 0x02c1, DEVICE_FLAG_NONE },
Linus Walleij8f86b0e2011-05-27 00:05:55 +0200943 // From: Mick Stephenson <MickStep@users.sourceforge.net>
Linus Walleijd13f8c22010-11-24 13:48:12 +0000944 { "Nokia", 0x0421, "5230", 0x02e2, DEVICE_FLAG_NONE },
Linus Walleij1ed0a832010-10-27 15:39:11 +0000945 // From: Lan Liu at Nokia <lan.liu@nokia.com>
946 { "Nokia", 0x0421, "N8", 0x02fe, DEVICE_FLAG_NONE },
947 // From: Lan Liu at Nokia <lan.liu@nokia.com>
948 { "Nokia", 0x0421, "N8 (Ovi mode)", 0x0302, DEVICE_FLAG_NONE },
Linus Walleij36463172011-09-29 22:48:51 +0200949 // From: Martijn Hoogendoorn <m.hoogendoorn@gmail.com>
950 { "Nokia", 0x0421, "E7", 0x0334, DEVICE_FLAG_NONE },
Raul Metsma9426a062011-03-22 23:19:08 +0100951 // From: Raul Metsma <raul@innovaatik.ee>
Linus Walleij36463172011-09-29 22:48:51 +0200952 { "Nokia", 0x0421, "E7 (Ovi mode)", 0x0335, DEVICE_FLAG_NONE },
Linus Walleij14cee672012-01-06 12:54:47 +0100953 // Reported by Serg <rd77@users.sourceforge.net>
Linus Walleijb1dcb702012-01-12 23:34:04 +0100954 // Symbian phone
Linus Walleij14cee672012-01-06 12:54:47 +0100955 { "Nokia", 0x0421, "C7", 0x03c1, DEVICE_FLAG_NONE },
Linus Walleij36463172011-09-29 22:48:51 +0200956 // Reported by Anonymous SourceForge user
957 { "Nokia", 0x0421, "N950", 0x03d2, DEVICE_FLAG_NONE },
Linus Walleij60144512008-10-25 19:11:48 +0000958 // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_3250_WMP10_driver.inf
959 { "Nokia", 0x0421, "3250 Mobile Phone", 0x0462, DEVICE_FLAG_NONE },
960 // From http://nds2.nokia.com/files/support/global/phones/software/Nokia_N93_WMP10_Driver.inf
961 { "Nokia", 0x0421, "N93 Mobile Phone", 0x0478, DEVICE_FLAG_NONE },
962 // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_5500_Sport_WMP10_driver.inf
963 { "Nokia", 0x0421, "5500 Sport Mobile Phone", 0x047e, DEVICE_FLAG_NONE },
964 // From http://nds2.nokia.com/files/support/global/phones/software/Nokia_N91_WMP10_Driver.inf
965 { "Nokia", 0x0421, "N91 Mobile Phone", 0x0485, DEVICE_FLAG_NONE },
Linus Walleij250ef742008-04-05 20:11:44 +0000966 // From: Christian Rusa <kristous@users.sourceforge.net>
967 { "Nokia", 0x0421, "5700 XpressMusic Mobile Phone", 0x04b4, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000968 // From: Mitchell Hicks <mitchix@yahoo.com>
969 { "Nokia", 0x0421, "5300 Mobile Phone", 0x04ba, DEVICE_FLAG_NONE },
Linus Walleij9dfb1f82011-05-27 00:43:44 +0200970 // https://sourceforge.net/tracker/index.php?func=detail&aid=2692473&group_id=8874&atid=358874
971 // From: Tiburce <tiburce@users.sourceforge.net>
972 { "Nokia", 0x0421, "5200 Mobile Phone", 0x04be,
973 DEVICE_FLAG_BROKEN_BATTERY_LEVEL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000974 // From Christian Arnold <webmaster@arctic-media.de>
975 { "Nokia", 0x0421, "N73 Mobile Phone", 0x04d1, DEVICE_FLAG_UNLOAD_DRIVER },
976 // From Swapan <swapan@yahoo.com>
977 { "Nokia", 0x0421, "N75 Mobile Phone", 0x04e1, DEVICE_FLAG_NONE },
Linus Walleij60144512008-10-25 19:11:48 +0000978 // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_N93i_WMP10_driver.inf
979 { "Nokia", 0x0421, "N93i Mobile Phone", 0x04e5, DEVICE_FLAG_NONE },
Linus Walleija6d0d482007-10-31 08:54:56 +0000980 // From Anonymous Sourceforge User
981 { "Nokia", 0x0421, "N95 Mobile Phone", 0x04ef, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000982 // From: Pat Nicholls <pat@patandannie.co.uk>
Linus Walleijf8d796f2011-11-28 18:52:22 +0100983 { "Nokia", 0x0421, "N80 Internet Edition (Media Player)", 0x04f1,
984 DEVICE_FLAG_UNLOAD_DRIVER },
985 // From: Maxin B. John <maxin.john@gmail.com>
986 { "Nokia", 0x0421, "N9", 0x051a, DEVICE_FLAG_NONE },
Linus Walleij67465c12009-08-23 21:56:26 +0000987 // Reported by Richard Wall <richard@the-moon.net>
988 { "Nokia", 0x05c6, "5530 Xpressmusic", 0x0229, DEVICE_FLAG_NONE },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000989 // Reported by anonymous SourceForge user
990 // One thing stated by reporter (Nokia model) another by the detect log...
991 { "Nokia/Verizon", 0x05c6, "6205 Balboa/Verizon Music Phone", 0x3196, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000992
Linus Walleija6d0d482007-10-31 08:54:56 +0000993
Linus Walleij1a673de2007-10-29 23:10:05 +0000994 /*
Linus Walleij83475632009-11-07 14:36:44 +0000995 * Vendor ID 0x13d1 is some offshoring company in China,
996 * in one source named "A-Max Technology Macao Commercial
997 * Offshore Co. Ltd." sometime "CCTech".
Linus Walleij1a673de2007-10-29 23:10:05 +0000998 */
Linus Walleij83475632009-11-07 14:36:44 +0000999 // Logik brand
Linus Walleij1a673de2007-10-29 23:10:05 +00001000 { "Logik", 0x13d1, "LOG DAX MP3 and DAB Player", 0x7002, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij83475632009-11-07 14:36:44 +00001001 // Technika brand
1002 // Reported by <Ooblick@users.sourceforge.net>
1003 { "Technika", 0x13d1, "MP-709", 0x7017, DEVICE_FLAG_UNLOAD_DRIVER },
1004
Linus Walleij1a673de2007-10-29 23:10:05 +00001005
1006 /*
1007 * RCA / Thomson
1008 */
1009 // From kiki <omkiki@users.sourceforge.net>
1010 { "Thomson", 0x069b, "EM28 Series", 0x0774, DEVICE_FLAG_NONE },
Richard Low957ffba2008-01-21 17:31:20 +00001011 { "Thomson / RCA", 0x069b, "Opal / Lyra MC4002", 0x0777, DEVICE_FLAG_NONE },
Linus Walleij01fc9c82009-03-10 23:52:09 +00001012 { "Thomson", 0x069b, "Lyra MC5104B (M51 Series)", 0x077c, DEVICE_FLAG_NONE },
Linus Walleij2c414c42008-01-19 07:11:19 +00001013 { "Thomson", 0x069b, "RCA H106", 0x301a, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +00001014 // From Svenna <svenna@svenna.de>
1015 // Not confirmed to be MTP.
1016 { "Thomson", 0x069b, "scenium E308", 0x3028, DEVICE_FLAG_NONE },
Richard Lowa11a6ad2008-01-21 17:23:55 +00001017 // From XNJB user
Richard Low957ffba2008-01-21 17:31:20 +00001018 { "Thomson / RCA", 0x069b, "Lyra HC308A", 0x3035, DEVICE_FLAG_NONE },
Linus Walleij2aa35742009-11-07 14:39:03 +00001019
Linus Walleij1a673de2007-10-29 23:10:05 +00001020 /*
1021 * NTT DoCoMo
1022 */
1023 { "FOMA", 0x04c5, "F903iX HIGH-SPEED", 0x1140, DEVICE_FLAG_NONE },
1024
1025 /*
1026 * Palm device userland program named Pocket Tunes
1027 * Reported by Peter Gyongyosi <gyp@impulzus.com>
1028 */
Linus Walleijfc438072008-10-31 21:12:43 +00001029 { "NormSoft, Inc.", 0x1703, "Pocket Tunes", 0x0001, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +00001030 // Reported by anonymous submission
Linus Walleijfc438072008-10-31 21:12:43 +00001031 { "NormSoft, Inc.", 0x1703, "Pocket Tunes 4", 0x0002, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +00001032
1033 /*
Linus Walleijf6612032009-07-23 22:50:57 +00001034 * TrekStor, Medion and Maxfield devices
Linus Walleij1a673de2007-10-29 23:10:05 +00001035 * Their datasheet claims their devices are dualmode so probably needs to
1036 * unload the attached drivers here.
1037 */
1038 // Reported by Stefan Voss <svoss@web.de>
Linus Walleij10b06d42007-11-05 11:32:07 +00001039 // This is a Sigmatel SoC with a hard disk.
Linus Walleijd866d242009-08-23 21:50:39 +00001040 { "TrekStor", 0x066f, "Vibez 8/12GB", 0x842a,
Linus Walleij07bb5382008-07-31 20:21:09 +00001041 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
1042 // Reported by anonymous SourceForge user.
1043 // This one done for Medion, whatever that is. Error reported so assume
1044 // the same bug flag as its ancestor above.
1045 { "Medion", 0x066f, "MD8333", 0x8550,
1046 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijf6612032009-07-23 22:50:57 +00001047 // Reported by anonymous SourceForge user
Linus Walleijdc33ef92008-11-15 09:45:53 +00001048 { "Medion", 0x066f, "MD8333", 0x8588,
1049 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij14cee672012-01-06 12:54:47 +01001050 // The vendor ID is "Quanta Computer, Inc."
1051 // same as Olivetti Olipad 110
1052 // Guessing on device flags
1053 { "Medion", 0x0408, "MD99000 (P9514)/Olivetti Olipad 110", 0xb009,
1054 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijf6612032009-07-23 22:50:57 +00001055 // Reported by anonymous SourceForge user
1056 { "Maxfield", 0x066f, "G-Flash NG 1GB", 0x846c,
1057 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij966ec9b2010-04-25 05:03:18 +00001058 // Reported by PaoloC <efmpsc@users.sourceforge.net>
1059 // Apparently SigmaTel has an SDK for MTP players with this ID
1060 { "SigmaTel Inc.", 0x066f, "MTPMSCN Audio Player", 0xa010,
1061 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +00001062 // Reported by Cristi Magherusan <majeru@gentoo.ro>
Linus Walleijd866d242009-08-23 21:50:39 +00001063 { "TrekStor", 0x0402, "i.Beat Sweez FM", 0x0611,
1064 DEVICE_FLAG_UNLOAD_DRIVER },
1065 // Reported by Fox-ino <fox-ino@users.sourceforge.net>
Linus Walleij2cf6aa82010-10-31 17:19:59 +00001066 // No confirmation that this is really MTP so commented it out.
1067 // { "ALi Corp.", 0x0402, "MPMAN 2GB", 0x5668,
Linus Walleij5f5360f2010-11-24 13:37:50 +00001068 // DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij2a7c6c72009-05-19 22:33:43 +00001069 // Reported by Anonymous SourceForge user
1070 {"TrekStor", 0x1e68, "i.Beat Organix 2.0", 0x0002,
1071 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijd866d242009-08-23 21:50:39 +00001072
Linus Walleij1a673de2007-10-29 23:10:05 +00001073 /*
Linus Walleijf88b5a42009-04-20 22:36:41 +00001074 * Disney/Tevion/MyMusix
Linus Walleij1a673de2007-10-29 23:10:05 +00001075 */
1076 // Reported by XNJB user
1077 { "Disney", 0x0aa6, "MixMax", 0x6021, DEVICE_FLAG_NONE },
Linus Walleij8f86b0e2011-05-27 00:05:55 +02001078 // Reported by anonymous Sourceforge user
Linus Walleij21704fd2008-02-29 22:50:29 +00001079 { "Tevion", 0x0aa6, "MD 81488", 0x3011, DEVICE_FLAG_NONE },
Linus Walleijf88b5a42009-04-20 22:36:41 +00001080 // Reported by Peter Hedlund <peter@peterandlinda.com>
1081 { "MyMusix", 0x0aa6, "PD-6070", 0x9601, DEVICE_FLAG_UNLOAD_DRIVER |
1082 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1083 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST |
1084 DEVICE_FLAG_NO_RELEASE_INTERFACE },
Linus Walleij1a673de2007-10-29 23:10:05 +00001085
1086 /*
1087 * Cowon Systems, Inc.
1088 * The iAudio audiophile devices don't encourage the use of MTP.
Linus Walleij2d54eba2010-05-23 23:37:10 +00001089 * See: http://wiki.xiph.org/index.php/PortablePlayers for Ogg
1090 * status
Linus Walleij1a673de2007-10-29 23:10:05 +00001091 */
1092 // Reported by Patrik Johansson <Patrik.Johansson@qivalue.com>
Linus Walleij7e3b3072009-01-19 22:51:17 +00001093 { "Cowon", 0x0e21, "iAudio U3 (MTP mode)", 0x0701,
Linus Walleij2d54eba2010-05-23 23:37:10 +00001094 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1095 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_FLAC_IS_UNKNOWN },
Linus Walleijee387d72008-11-12 23:42:02 +00001096 // Reported by Kevin Michael Smith <hai-etlik@users.sourceforge.net>
Linus Walleij7e3b3072009-01-19 22:51:17 +00001097 { "Cowon", 0x0e21, "iAudio 6 (MTP mode)", 0x0711,
1098 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +00001099 // Reported by Roberth Karman
Linus Walleij7e3b3072009-01-19 22:51:17 +00001100 { "Cowon", 0x0e21, "iAudio 7 (MTP mode)", 0x0751,
Linus Walleij2d54eba2010-05-23 23:37:10 +00001101 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1102 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_FLAC_IS_UNKNOWN },
Linus Walleijf8c251e2008-06-08 21:32:01 +00001103 // Reported by an anonymous SourceForge user
Linus Walleij7e3b3072009-01-19 22:51:17 +00001104 { "Cowon", 0x0e21, "iAudio U5 (MTP mode)", 0x0761,
Linus Walleij2d54eba2010-05-23 23:37:10 +00001105 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1106 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_FLAC_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +00001107 // Reported by TJ Something <tjbk_tjb@users.sourceforge.net>
Linus Walleij4a779562009-03-29 23:36:45 +00001108 { "Cowon", 0x0e21, "iAudio D2 (MTP mode)", 0x0801,
Linus Walleijecbe7452010-05-15 00:15:37 +00001109 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1110 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_FLAC_IS_UNKNOWN },
Linus Walleijd09f65e2009-05-04 23:18:29 +00001111 // Reported by anonymous Sourceforge user
Linus Walleij18ed0162009-05-06 16:51:08 +00001112 { "Cowon", 0x0e21, "iAudio D2+ FW 2.x (MTP mode)", 0x0861,
Linus Walleijecbe7452010-05-15 00:15:37 +00001113 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1114 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_FLAC_IS_UNKNOWN },
Linus Walleij18ed0162009-05-06 16:51:08 +00001115 // From Rockbox device listing
1116 { "Cowon", 0x0e21, "iAudio D2+ DAB FW 4.x (MTP mode)", 0x0871,
Linus Walleijecbe7452010-05-15 00:15:37 +00001117 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1118 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_FLAC_IS_UNKNOWN },
Linus Walleij18ed0162009-05-06 16:51:08 +00001119 // From Rockbox device listing
1120 { "Cowon", 0x0e21, "iAudio D2+ FW 3.x (MTP mode)", 0x0881,
Linus Walleijecbe7452010-05-15 00:15:37 +00001121 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1122 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_FLAC_IS_UNKNOWN },
Linus Walleij18ed0162009-05-06 16:51:08 +00001123 // From Rockbox device listing
1124 { "Cowon", 0x0e21, "iAudio D2+ DMB FW 1.x (MTP mode)", 0x0891,
Linus Walleijecbe7452010-05-15 00:15:37 +00001125 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1126 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_FLAC_IS_UNKNOWN },
Linus Walleij4a779562009-03-29 23:36:45 +00001127 // Reported by <twkonefal@users.sourceforge.net>
1128 { "Cowon", 0x0e21, "iAudio S9 (MTP mode)", 0x0901,
Linus Walleij48946ff2009-06-24 08:15:39 +00001129 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij89bb1cd2009-07-24 21:03:36 +00001130 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_FLAC_IS_UNKNOWN },
Linus Walleij4d3618b2009-11-30 00:19:56 +00001131 // Reported by Dan Nicholson <dbn.lists@gmail.com>
1132 { "Cowon", 0x0e21, "iAudio 9 (MTP mode)", 0x0911,
Linus Walleijecbe7452010-05-15 00:15:37 +00001133 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1134 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_FLAC_IS_UNKNOWN },
Linus Walleij568022b2010-08-20 22:24:04 +00001135 // Reported by Franck VDL <franckv@users.sourceforge.net>
1136 { "Cowon", 0x0e21, "iAudio J3 (MTP mode)", 0x0921,
1137 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1138 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_FLAC_IS_UNKNOWN },
Linus Walleij4de35d72011-05-25 00:54:47 +02001139 // Reported by anonymous SourceForge user
1140 { "Cowon", 0x0e21, "iAudio X7 (MTP mode)", 0x0931,
1141 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1142 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_FLAC_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +00001143
1144 /*
1145 * Insignia, dual-mode.
1146 */
1147 { "Insignia", 0x19ff, "NS-DV45", 0x0303, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij478ddb92007-11-26 21:01:29 +00001148 // Reported by Rajan Bella <rajanbella@yahoo.com>
1149 { "Insignia", 0x19ff, "Sport Player", 0x0307, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +00001150 // Reported by "brad" (anonymous, sourceforge)
1151 { "Insignia", 0x19ff, "Pilot 4GB", 0x0309, DEVICE_FLAG_UNLOAD_DRIVER },
1152
1153 /*
1154 * LG Electronics
1155 */
Linus Walleij1291ce02009-11-07 14:26:57 +00001156 // From anonymous SourceForge user
1157 // Uncertain if this is really the MTP mode device ID...
1158 { "LG Electronics Inc.", 0x043e, "T54", 0x7040,
1159 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +00001160 // Not verified - anonymous submission
Linus Walleij7b4794f2008-08-13 13:17:17 +00001161 { "LG Electronics Inc.", 0x043e, "UP3", 0x70b1, DEVICE_FLAG_NONE },
1162 // Reported by Joseph Nahmias <joe@nahimas.net>
1163 { "LG Electronics Inc.", 0x1004, "VX8550 V CAST Mobile Phone", 0x6010,
Linus Walleij7c710892011-05-26 23:44:48 +02001164 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1165 DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR },
Linus Walleij2242b022009-01-02 01:44:00 +00001166 // Reported by Cyrille Potereau <cyrille.potereau@wanadoo.fr>
1167 { "LG Electronics Inc.", 0x1004, "KC910 Renoir Mobile Phone", 0x608f,
1168 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij4e36ced2010-01-19 00:51:43 +00001169 // Reported by Aaron Slunt <tongle@users.sourceforge.net>
1170 { "LG Electronics Inc.", 0x1004, "GR-500 Music Player", 0x611b,
Linus Walleij7c710892011-05-26 23:44:48 +02001171 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1172 DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR },
Linus Walleij7fe2b4f2009-05-02 07:07:50 +00001173 // Reported by anonymous sourceforge user
1174 { "LG Electronics Inc.", 0x1004, "KM900", 0x6132,
Linus Walleij7c710892011-05-26 23:44:48 +02001175 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1176 DEVICE_FLAG_UNLOAD_DRIVER },
1177 // Reported by anonymous sourceforge user
Linus Walleij8f86b0e2011-05-27 00:05:55 +02001178 { "LG Electronics Inc.", 0x1004, "LG8575", 0x619a,
1179 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1180 DEVICE_FLAG_UNLOAD_DRIVER },
1181 // Reported by anonymous sourceforge user
Linus Walleij7c710892011-05-26 23:44:48 +02001182 { "LG Electronics Inc.", 0x1004, "V909 G-Slate", 0x61f9,
Linus Walleij8f86b0e2011-05-27 00:05:55 +02001183 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij7c710892011-05-26 23:44:48 +02001184 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +00001185
1186 /*
1187 * Sony
Linus Walleijbc3ed4d2008-01-03 13:54:23 +00001188 * It could be that these PIDs are one-per hundred series, so
1189 * NWZ-A8xx is 0325, NWZ-S5xx is 0x326 etc. We need more devices
1190 * reported to see a pattern here.
Linus Walleij1a673de2007-10-29 23:10:05 +00001191 */
Linus Walleija8ba8c72008-03-29 00:02:27 +00001192 // Reported by Alessandro Radaelli <alessandro.radaelli@aruba.it>
Linus Walleij6d6e2d12009-09-10 23:17:02 +00001193 { "Sony", 0x054c, "Walkman NWZ-A815/NWZ-A818", 0x0325,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001194 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij5d709a52007-12-28 21:37:17 +00001195 // Reported by anonymous Sourceforge user.
Linus Walleij46b909a2009-09-23 06:55:14 +00001196 { "Sony", 0x054c, "Walkman NWZ-S516", 0x0326,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001197 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij1a673de2007-10-29 23:10:05 +00001198 // Reported by Endre Oma <endre.88.oma@gmail.com>
Linus Walleij6d6e2d12009-09-10 23:17:02 +00001199 { "Sony", 0x054c, "Walkman NWZ-S615F/NWZ-S616F/NWZ-S618F", 0x0327,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001200 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij062ec7d2008-05-19 12:06:32 +00001201 // Reported by Jean-Marc Bourguet <jm@bourguet.org>
Linus Walleij46b909a2009-09-23 06:55:14 +00001202 { "Sony", 0x054c, "Walkman NWZ-S716F", 0x035a,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001203 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij0c98ce82008-05-25 11:08:36 +00001204 // Reported by Anon SF User / Anthon van der Neut <avanderneut@avid.com>
Linus Walleij6d6e2d12009-09-10 23:17:02 +00001205 { "Sony", 0x054c, "Walkman NWZ-A826/NWZ-A828/NWZ-A829", 0x035b,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001206 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleija8ba8c72008-03-29 00:02:27 +00001207 // Reported by Niek Klaverstijn <niekez@users.sourceforge.net>
Linus Walleij6d6e2d12009-09-10 23:17:02 +00001208 { "Sony", 0x054c, "Walkman NWZ-A726/NWZ-A728/NWZ-A768", 0x035c,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001209 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij45b843e2008-10-09 08:33:01 +00001210 // Reported by Mehdi AMINI <mehdi.amini - at - ulp.u-strasbg.fr>
Linus Walleij46b909a2009-09-23 06:55:14 +00001211 { "Sony", 0x054c, "Walkman NWZ-B135", 0x036e,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001212 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij2242b022009-01-02 01:44:00 +00001213 // Reported by <tiagoboldt@users.sourceforge.net>
Linus Walleij46b909a2009-09-23 06:55:14 +00001214 { "Sony", 0x054c, "Walkman NWZ-E436F", 0x0385,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001215 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij7fe2b4f2009-05-02 07:07:50 +00001216 // Reported by Michael Wilkinson
Linus Walleij46b909a2009-09-23 06:55:14 +00001217 { "Sony", 0x054c, "Walkman NWZ-W202", 0x0388,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001218 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij25a16302009-03-04 13:56:33 +00001219 // Reported by Ondrej Sury <ondrej@sury.org>
Linus Walleij46b909a2009-09-23 06:55:14 +00001220 { "Sony", 0x054c, "Walkman NWZ-S739F", 0x038c,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001221 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleijd8f1feb2008-10-08 09:16:42 +00001222 // Reported by Marco Filipe Nunes Soares Abrantes Pereira <marcopereira@ua.pt>
Linus Walleij46b909a2009-09-23 06:55:14 +00001223 { "Sony", 0x054c, "Walkman NWZ-S638F", 0x038e,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001224 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij0c6808e2009-07-23 22:44:38 +00001225 // Reported by Elliot <orwells@users.sourceforge.net>
Linus Walleij8d799eb2009-07-23 22:58:06 +00001226 { "Sony", 0x054c, "Walkman NWZ-X1050B/NWZ-X1060B",
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001227 0x0397, DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij8d799eb2009-07-23 22:58:06 +00001228 // Reported by Silvio J. Gutierrez <silviogutierrez@users.sourceforge.net>
Linus Walleij6d6e2d12009-09-10 23:17:02 +00001229 { "Sony", 0x054c, "Walkman NWZ-X1051/NWZ-X1061", 0x0398,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001230 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij2aa35742009-11-07 14:39:03 +00001231 // Reported by Gregory Boddin <gregory@siwhine.net>
1232 { "Sony", 0x054c, "Walkman NWZ-B142F", 0x03d8,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001233 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleijbe7f77b2010-05-22 22:43:46 +00001234 // Reported by Rick Warner <rick@reptileroom.net>
1235 { "Sony", 0x054c, "Walkman NWZ-E344", 0x03fc,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001236 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij5e44ed52010-01-30 08:06:11 +00001237 // Reported by Jonathan Stowe <gellyfish@users.sourceforge.net>
1238 { "Sony", 0x054c, "Walkman NWZ-E445", 0x03fd,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001239 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij99d390e2010-01-19 01:17:39 +00001240 // Reported by Anonymous SourceForge user
1241 { "Sony", 0x054c, "Walkman NWZ-S545", 0x03fe,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001242 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij36efffb2010-10-17 21:46:58 +00001243 { "Sony", 0x054c, "Walkman NWZ-A845", 0x0404,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001244 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij36463172011-09-29 22:48:51 +02001245 // Reported by anonymous SourceForge user
1246 { "Sony", 0x054c, "Walkman NWZ-W252B", 0x04bb,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001247 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij36463172011-09-29 22:48:51 +02001248 // Suspect this device has strong DRM features
1249 // See https://answers.launchpad.net/ubuntu/+source/libmtp/+question/149587
Linus Walleijd959bed2010-11-24 13:42:44 +00001250 { "Sony", 0x054c, "Walkman NWZ-B153F", 0x04be,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001251 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij96d40c62010-11-24 14:37:10 +00001252 { "Sony", 0x054c, "Walkman NWZ-E354", 0x04cb,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001253 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij4de35d72011-05-25 00:54:47 +02001254 // Reported by Toni Burgarello
1255 { "Sony", 0x054c, "Walkman NWZ-S754", 0x04cc,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001256 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij14cee672012-01-06 12:54:47 +01001257 // Reported by anonymous Sourceforge user
1258 // guessing on device flags...
1259 { "Sony", 0x054c, "Walkman NWZ-E464", 0x05a6,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001260 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleijaa43ff72012-01-06 17:58:25 +01001261 // Reported by Jan Rheinlaender <jrheinlaender@users.sourceforge.net>
1262 { "Sony", 0x054c, "NWZ-S765", 0x05a8,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001263 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleij6d91ac02012-01-29 02:52:16 +01001264 // Reported by ghalambaz <ghalambaz@users.sourceforge.net>
1265 { "Sony", 0x054c, "Sony Tablet S1", 0x05b4,
1266 DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij14735952010-04-25 04:56:49 +00001267 // Reported by Anonymous SourceForge user
Richard Low3c9366e2010-06-19 11:12:46 +00001268 { "Sony", 0x054c, "DCR-SR75", 0x1294,
Linus Walleij15c7d1b2012-01-07 01:37:31 +01001269 DEVICE_FLAGS_SONY_NWZ_BUGS },
Linus Walleijd8f1feb2008-10-08 09:16:42 +00001270
Linus Walleij1a673de2007-10-29 23:10:05 +00001271 /*
Linus Walleijaa6b0192007-10-29 23:39:48 +00001272 * SonyEricsson
Linus Walleijc7756412008-10-21 14:24:24 +00001273 * These initially seemed to support GetObjPropList but later revisions
1274 * of the firmware seem to have broken it, so all are flagged as broken
1275 * for now.
Linus Walleijaa6b0192007-10-29 23:39:48 +00001276 */
Linus Walleijb3b29e72007-11-05 22:29:53 +00001277 // Reported by Øyvind Stegard <stegaro@users.sourceforge.net>
Linus Walleijbe770922011-10-04 22:06:27 +02001278 { "SonyEricsson", 0x0fce, "K850i", 0x0075,
1279 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijaa6b0192007-10-29 23:39:48 +00001280 // Reported by Michael Eriksson
Linus Walleijbe770922011-10-04 22:06:27 +02001281 { "SonyEricsson", 0x0fce, "W910", 0x0076,
1282 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijb5a4f922008-05-11 20:15:00 +00001283 // Reported by Zack <zackdvd@users.sourceforge.net>
Linus Walleijbe770922011-10-04 22:06:27 +02001284 { "SonyEricsson", 0x0fce, "W890i", 0x00b3,
1285 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijc2bc9732008-08-14 21:12:44 +00001286 // Reported by robert dot ahlskog at gmail
Linus Walleijbe770922011-10-04 22:06:27 +02001287 { "SonyEricsson", 0x0fce, "W760i", 0x00c6,
1288 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijf8c251e2008-06-08 21:32:01 +00001289 // Reported by Linus Åkesson <linusakesson@users.sourceforge.net>
Linus Walleijbe770922011-10-04 22:06:27 +02001290 { "SonyEricsson", 0x0fce, "C902", 0x00d4,
1291 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij07bb5382008-07-31 20:21:09 +00001292 // Reported by an anonymous SourceForge user
Linus Walleijbe770922011-10-04 22:06:27 +02001293 { "SonyEricsson", 0x0fce, "C702", 0x00d9,
1294 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijdb6da7c2008-10-16 18:46:34 +00001295 // Reported by Christian Zuckschwerdt <christian@zuckschwerdt.org>
Linus Walleijbe770922011-10-04 22:06:27 +02001296 { "SonyEricsson", 0x0fce, "W980", 0x00da,
1297 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij76edf7e2009-05-19 22:37:07 +00001298 // Reported by David Taylor <davidt-libmtp@yadt.co.uk>
Linus Walleijbe770922011-10-04 22:06:27 +02001299 { "SonyEricsson", 0x0fce, "C905", 0x00ef,
1300 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij4aa66dc2009-05-02 06:36:59 +00001301 // Reported by David House <dmhouse@users.sourceforge.net>
1302 { "SonyEricsson", 0x0fce, "W595", 0x00f3,
Linus Walleijbe770922011-10-04 22:06:27 +02001303 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
1304 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleij2c34d432008-12-13 22:01:32 +00001305 // Reported by Mattias Evensson <mevensson@users.sourceforge.net>
Linus Walleijbe770922011-10-04 22:06:27 +02001306 { "SonyEricsson", 0x0fce, "W902", 0x00f5,
1307 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij5ffcec92009-09-03 21:16:36 +00001308 // Reported by Sarunas <sarunas@users.sourceforge.net>
1309 // Doesn't need any flags according to reporter
Linus Walleijbe770922011-10-04 22:06:27 +02001310 { "SonyEricsson", 0x0fce, "T700", 0x00fb,
1311 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij4a779562009-03-29 23:36:45 +00001312 // Reported by Stéphane Pontier <shadow_walker@users.sourceforge.net>
Linus Walleijbe770922011-10-04 22:06:27 +02001313 { "SonyEricsson", 0x0fce, "W705/W715", 0x0105,
1314 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleije7ab9482009-07-23 23:50:51 +00001315 // Reported by Håkan Kvist
Linus Walleijbe770922011-10-04 22:06:27 +02001316 { "SonyEricsson", 0x0fce, "W995", 0x0112,
1317 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij96a50382010-07-24 23:32:17 +00001318 // Reported by anonymous SourceForge user
Linus Walleijbe770922011-10-04 22:06:27 +02001319 { "SonyEricsson", 0x0fce, "U5", 0x0133,
1320 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleija8e6bc62011-01-08 23:04:20 +00001321 // Reported by Flo <lhugsereg@users.sourceforge.net>
Linus Walleijbe770922011-10-04 22:06:27 +02001322 { "SonyEricsson", 0x0fce, "U8i", 0x013a,
1323 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij4de35d72011-05-25 00:54:47 +02001324 // Reported by xirotyu <xirotyu@users.sourceforge.net>
Linus Walleijbe770922011-10-04 22:06:27 +02001325 { "SonyEricsson", 0x0fce, "j10i2 (Elm)", 0x0144,
1326 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij9b525fe2011-10-22 00:30:50 +02001327 // Reported by Serge Chirik <schirik@users.sourceforge.net>
1328 { "SonyEricsson", 0x0fce, "j108i (Cedar)", 0x014e,
1329 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij5d4ec212011-04-18 07:45:18 +02001330 // Reported by Jonas Salling <>
1331 // Erroneous MTP implementation seems to be from Aricent, returns
1332 // broken transaction ID.
Linus Walleij59b56fd2012-01-12 22:09:57 +01001333 { "SonyEricsson", 0x0fce, "LT15i (Xperia arc S)", 0x14f,
Linus Walleijbe770922011-10-04 22:06:27 +02001334 DEVICE_FLAG_IGNORE_HEADER_ERRORS },
Linus Walleij05a0f282011-10-22 00:22:20 +02001335 // Reported by Eamonn Webster <eweb@users.sourceforge.net>
1336 // Guessing on the ignore errors flag
1337 { "SonyEricsson", 0x0fce, "Xperia Neo", 0x0156,
1338 DEVICE_FLAG_IGNORE_HEADER_ERRORS },
Linus Walleijbe770922011-10-04 22:06:27 +02001339 // Reported by <wealas@users.sourceforge.net>
Linus Walleijb1dcb702012-01-12 23:34:04 +01001340 // Android with homebrew MTP stack, possibly Aricent
1341 { "SonyEricsson", 0x0fce, "ST18a Xperia Ray", 0x0161,
1342 DEVICE_FLAG_IGNORE_HEADER_ERRORS |
1343 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST |
1344 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijbe7f77b2010-05-22 22:43:46 +00001345 // Reported by Jonas Nyrén <spectralmks@users.sourceforge.net>
Linus Walleijbe770922011-10-04 22:06:27 +02001346 { "SonyEricsson", 0x0fce, "W302", 0x10c8,
1347 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijbdac9c42011-06-08 00:41:50 +02001348 // Reported by Anonymous Sourceforge user
Linus Walleijbe770922011-10-04 22:06:27 +02001349 { "SonyEricsson", 0x0fce, "j10i (Elm)", 0xd144,
1350 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij59b56fd2012-01-12 22:09:57 +01001351 // Reported by Thomas Schweitzer <thomas_-_s@users.sourceforge.net>
1352 { "SonyEricsson", 0x0fce, "K550i", 0xe000,
1353 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleije7ab9482009-07-23 23:50:51 +00001354
Linus Walleijaa6b0192007-10-29 23:39:48 +00001355
1356 /*
Linus Walleij1a673de2007-10-29 23:10:05 +00001357 * Motorola
1358 * Assume DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST on all of these.
1359 */
Linus Walleij37c21662008-05-16 21:16:01 +00001360 // Reported by David Boyd <tiggrdave@users.sourceforge.net>
Linus Walleij351df602010-04-04 23:16:42 +00001361 { "Motorola", 0x22b8, "V3m/V750 verizon", 0x2a65,
1362 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST |
1363 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij7de3a292010-08-20 22:29:22 +00001364 // Reported by Steven Roemen <sdroemen@users.sourceforge.net>
Linus Walleij4de35d72011-05-25 00:54:47 +02001365 { "Motorola", 0x22b8, "Droid X/MB525 (Defy)", 0x41d6,
Linus Walleij7de3a292010-08-20 22:29:22 +00001366 DEVICE_FLAG_NONE },
Linus Walleij351df602010-04-04 23:16:42 +00001367 // Reported by anonymous user
1368 { "Motorola", 0x22b8, "Milestone / Verizon Droid", 0x41dc,
Richard Lowb58de742010-04-09 15:53:14 +00001369 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST |
1370 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST |
1371 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
1372 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijbac1eed2011-02-04 23:55:19 +01001373 // Reported by anonymous user
1374 { "Motorola", 0x22b8, "DROID2", 0x42a7,
1375 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST |
1376 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST |
1377 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
1378 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijaa43ff72012-01-06 17:58:25 +01001379 { "Motorola", 0x22b8, "Xoom 2 Media Edition", 0x4311,
1380 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST |
1381 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST |
1382 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
1383 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +00001384 // Reported by Marcus Meissner to libptp2
Linus Walleij5000cb52011-11-03 16:30:16 +01001385 { "Motorola", 0x22b8, "IdeaPad K1", 0x4811,
1386 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +00001387 // Reported by Hans-Joachim Baader <hjb@pro-linux.de> to libptp2
Linus Walleij351df602010-04-04 23:16:42 +00001388 { "Motorola", 0x22b8, "A1200", 0x60ca,
1389 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleijf0702982008-10-25 21:37:43 +00001390 // http://mark.cdmaforums.com/Files/Motdmmtp.inf
Linus Walleij351df602010-04-04 23:16:42 +00001391 { "Motorola", 0x22b8, "MTP Test Command Interface", 0x6413,
1392 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +00001393 // Reported by anonymous user
Linus Walleij351df602010-04-04 23:16:42 +00001394 { "Motorola", 0x22b8, "RAZR2 V8/U9/Z6", 0x6415,
1395 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Yavor Goulishevddd89812011-02-25 19:36:24 +01001396 // Reported by Google Inc's Yavor Goulishev <yavor@google.com>
Linus Walleij21864042011-04-18 07:57:30 +02001397 // Android 3.0 MTP stack seems to announce that it supports the
1398 // list operations, but they do not work?
Linus Walleij03f0c032011-10-22 00:01:14 +02001399 { "Motorola", 0x22b8, "Xoom (ID 1)", 0x70a8, DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij14cee672012-01-06 12:54:47 +01001400 // Reported by anonymous Sourceforge user
1401 // "carried by C Spire and other CDMA US carriers"
1402 { "Motorola", 0x22b8, "Milestone X2", 0x70ca, DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij36463172011-09-29 22:48:51 +02001403
1404 /*
1405 * Google
1406 * These guys lend their Vendor ID to anyone who comes down the
1407 * road to produce an Android tablet it seems... The Vendor ID
1408 * was originally used for Nexus phones
1409 */
1410 { "Google Inc (for Sony)", 0x18d1, "S1", 0x05b3,
Linus Walleij03f0c032011-10-22 00:01:14 +02001411 DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij14cee672012-01-06 12:54:47 +01001412 // Reported by anonymous Sourceforge user
Linus Walleijbc62ee12012-01-21 23:49:44 +01001413 { "Google Inc (for Barnes & Noble)", 0x18d1, "Nook Color", 0x2d02,
1414 DEVICE_FLAGS_ANDROID_BUGS },
1415 // Reported by anonymous Sourceforge user
Linus Walleij14cee672012-01-06 12:54:47 +01001416 { "Google Inc (for Asus)", 0x18d1, "TF101 Transformer", 0x4e0f,
1417 DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij36463172011-09-29 22:48:51 +02001418 // WiFi-only version of Xoom
1419 // See: http://bugzilla.gnome.org/show_bug.cgi?id=647506
1420 { "Google Inc (for Motorola)", 0x18d1, "Xoom (MZ604)", 0x70a8,
Linus Walleij03f0c032011-10-22 00:01:14 +02001421 DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij36463172011-09-29 22:48:51 +02001422 { "Google Inc (for Motorola)", 0x22b8, "Xoom (ID 2)", 0x70a9,
Linus Walleij03f0c032011-10-22 00:01:14 +02001423 DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij3244fd72012-02-22 03:58:23 +01001424 { "Google Inc (for Toshiba)", 0x18d1, "Thrive 7", 0x7102,
1425 DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij14cee672012-01-06 12:54:47 +01001426 // Another OEM for Medion
1427 { "Google Inc (for Medion)", 0x18d1, "MD99000 (P9514)", 0xb00a,
1428 DEVICE_FLAGS_ANDROID_BUGS },
1429
Linus Walleij1a673de2007-10-29 23:10:05 +00001430 /*
Linus Walleij478ddb92007-11-26 21:01:29 +00001431 * Media Keg
1432 */
1433 // Reported by Rajan Bella <rajanbella@yahoo.com>
1434 { "Kenwood", 0x0b28, "Media Keg HD10GB7 Sport Player", 0x100c, DEVICE_FLAG_UNLOAD_DRIVER},
1435
Linus Walleij5d675112008-02-16 21:46:46 +00001436 /*
1437 * Micro-Star International (MSI)
1438 */
1439 // Reported by anonymous sourceforge user.
1440 { "Micro-Star International", 0x0db0, "P610/Model MS-5557", 0x5572, DEVICE_FLAG_NONE },
1441
Linus Walleijf044aa12008-03-22 21:45:19 +00001442 /*
1443 * FOMA
1444 */
1445 { "FOMA", 0x06d3, "D905i", 0x21ba, DEVICE_FLAG_NONE },
Linus Walleij166c8ff2008-01-14 23:15:08 +00001446
Linus Walleij478ddb92007-11-26 21:01:29 +00001447 /*
Linus Walleijb5a4f922008-05-11 20:15:00 +00001448 * Haier
1449 */
1450 // Both reported by an anonymous SourceForge user
1451 // This is the 30 GiB model
1452 { "Haier", 0x1302, "Ibiza Rhapsody", 0x1016, DEVICE_FLAG_NONE },
1453 // This is the 4/8 GiB model
1454 { "Haier", 0x1302, "Ibiza Rhapsody", 0x1017, DEVICE_FLAG_NONE },
Linus Walleij5e44ed52010-01-30 08:06:11 +00001455
Richard Low4d93a992008-09-07 12:52:14 +00001456 /*
1457 * Panasonic
1458 */
1459 // Reported by dmizer
1460 { "Panasonic", 0x04da, "P905i", 0x2145, DEVICE_FLAG_NONE },
Linus Walleij5e44ed52010-01-30 08:06:11 +00001461 // Reported by Taku
1462 { "Panasonic", 0x04da, "P906i", 0x2158, DEVICE_FLAG_NONE },
Linus Walleijb5a4f922008-05-11 20:15:00 +00001463
1464 /*
Linus Walleij80a2a692008-12-05 20:36:40 +00001465 * Polaroid
1466 */
1467 { "Polaroid", 0x0546, "Freescape/MPU-433158", 0x2035, DEVICE_FLAG_NONE },
1468
1469 /*
Linus Walleij2242b022009-01-02 01:44:00 +00001470 * Pioneer
1471 */
1472 // Reported by Dan Allen <dan.j.allen@gmail.com>
1473 { "Pioneer", 0x08e4, "XMP3", 0x0148, DEVICE_FLAG_NONE },
1474
1475 /*
Linus Walleij4096c882009-03-16 23:32:34 +00001476 * Slacker Inc.
1477 * Put in all evilness flags because it looks fragile.
1478 */
1479 // Reported by Pug Fantus <pugfantus@users.sourceforge.net>
1480 { "Slacker Inc.", 0x1bdc, "Slacker Portable Media Player", 0xfabf,
1481 DEVICE_FLAG_BROKEN_BATTERY_LEVEL | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1482 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
1483
Linus Walleijbac1eed2011-02-04 23:55:19 +01001484 // Reported by anonymous user
1485 { "Conceptronic", 0x1e53, "CMTD2", 0x0005, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij6e3997e2009-04-12 23:40:40 +00001486 // Reported by Demadridsur <demadridsur@gmail.com>
1487 { "O2 Sistemas", 0x1e53, "ZoltarTV", 0x0006, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij2f082452010-09-02 18:57:30 +00001488 // Reported by da-beat <dabeat@gmail.com>
1489 { "Wyplay", 0x1e53, "Wyplayer", 0x0007, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij6e3997e2009-04-12 23:40:40 +00001490
Linus Walleij6fb9a5f2009-09-12 06:25:17 +00001491 // Reported by Sense Hofstede <qense@users.sourceforge.net>
1492 { "Perception Digital, Ltd", 0x0aa6, "Gigaware GX400", 0x9702, DEVICE_FLAG_NONE },
Linus Walleij5f3c44b2009-09-12 21:03:06 +00001493
1494 /*
Linus Walleijc18f1aa2010-01-19 00:19:12 +00001495 * RIM's BlackBerry
Linus Walleij5f3c44b2009-09-12 21:03:06 +00001496 */
1497 // Reported by Nicolas VIVIEN <nicolas@vivien.fr>
Linus Walleij84559e82010-05-25 19:44:09 +00001498 { "RIM", 0x0fca, "BlackBerry Storm/9650", 0x8007, DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleijcea83ff2009-09-25 21:44:38 +00001499 DEVICE_FLAG_SWITCH_MODE_BLACKBERRY | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij5f3c44b2009-09-12 21:03:06 +00001500
Linus Walleij4096c882009-03-16 23:32:34 +00001501 /*
Linus Walleij99d390e2010-01-19 01:17:39 +00001502 * Nextar
1503 */
Linus Walleij6d0a5122010-08-20 22:40:35 +00001504 { "Nextar", 0x0402, "MA715A-8R", 0x5668, DEVICE_FLAG_NONE },
Linus Walleijbd0347e2010-08-20 22:17:13 +00001505
1506 /*
1507 * Coby
1508 */
Linus Walleij6d0a5122010-08-20 22:40:35 +00001509 { "Coby", 0x1e74, "COBY MP705", 0x6512, DEVICE_FLAG_NONE },
Linus Walleijbd0347e2010-08-20 22:17:13 +00001510
Richard Low3c9366e2010-06-19 11:12:46 +00001511 /*
1512 * Apple devices, which are not MTP natively but can be made to speak MTP
1513 * using PwnTunes (http://www.pwntunes.net/)
1514 */
Linus Walleij6d0a5122010-08-20 22:40:35 +00001515 { "Apple", 0x05ac, "iPhone", 0x1290, DEVICE_FLAG_NONE },
1516 { "Apple", 0x05ac, "iPod Touch 1st Gen", 0x1291, DEVICE_FLAG_NONE },
1517 { "Apple", 0x05ac, "iPhone 3G", 0x1292, DEVICE_FLAG_NONE },
1518 { "Apple", 0x05ac, "iPod Touch 2nd Gen", 0x1293, DEVICE_FLAG_NONE },
1519 { "Apple", 0x05ac, "iPhone 3GS", 0x1294, DEVICE_FLAG_NONE },
1520 { "Apple", 0x05ac, "0x1296", 0x1296, DEVICE_FLAG_NONE },
1521 { "Apple", 0x05ac, "0x1297", 0x1297, DEVICE_FLAG_NONE },
1522 { "Apple", 0x05ac, "0x1298", 0x1298, DEVICE_FLAG_NONE },
1523 { "Apple", 0x05ac, "iPod Touch 3rd Gen", 0x1299, DEVICE_FLAG_NONE },
1524 { "Apple", 0x05ac, "iPad", 0x129a, DEVICE_FLAG_NONE },
Linus Walleij99d390e2010-01-19 01:17:39 +00001525
Linus Walleij4de35d72011-05-25 00:54:47 +02001526 // Reported by anonymous SourceForge user, also reported as
1527 // Pantech Crux, claming to be:
1528 // Manufacturer: Qualcomm
1529 // Model: Windows Simulator
1530 // Device version: Qualcomm MTP1.0
Linus Walleij1753a6c2011-02-11 18:46:08 +01001531 { "Curitel Communications, Inc.", 0x106c,
1532 "Verizon Wireless Device", 0x3215, DEVICE_FLAG_NONE },
Linus Walleij8f86b0e2011-05-27 00:05:55 +02001533 // Reported by: Jim Hanrahan <goshawkjim@users.sourceforge.net>
1534 { "Pantech", 0x106c, "Crux", 0xf003, DEVICE_FLAG_NONE },
1535
1536 /*
1537 * Asus
1538 */
Linus Walleij475e8802012-01-06 17:40:12 +01001539 // Reported by anonymous Sourceforge user
Linus Walleij6e50b1b2012-01-11 07:50:52 +01001540 { "Asus", 0x0b05, "TF201 Transformer Prime (keyboard dock)", 0x4d00,
Linus Walleij475e8802012-01-06 17:40:12 +01001541 DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij6e50b1b2012-01-11 07:50:52 +01001542 { "Asus", 0x0b05, "TF201 Transformer Prime (tablet only)", 0x4d01,
Linus Walleij475e8802012-01-06 17:40:12 +01001543 DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleijc575c172011-11-10 00:49:17 +01001544 { "Asus", 0x0b05, "TF101 Eeepad Transformer", 0x4e0f,
1545 DEVICE_FLAGS_ANDROID_BUGS },
1546 { "Asus", 0x0b05, "TF101 Eeepad Transformer (debug mode)", 0x4e1f,
1547 DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij1753a6c2011-02-11 18:46:08 +01001548
Linus Walleij16466ec2011-10-04 22:00:54 +02001549
1550 /*
1551 * Lenovo
1552 */
Linus Walleijb3f3dd32011-10-31 11:38:54 +01001553 // Reported by Richard Körber <shredzone@users.sourceforge.net>
1554 { "Lenovo", 0x17ef, "K1", 0x740a,
1555 DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij16466ec2011-10-04 22:00:54 +02001556 // Reported by anonymous sourceforge user
1557 // Adding Android default bug flags since it appears to be an Android
Linus Walleijb3f3dd32011-10-31 11:38:54 +01001558 { "Lenovo", 0x17ef, "ThinkPad Tablet", 0x741c,
Linus Walleij03f0c032011-10-22 00:01:14 +02001559 DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij16466ec2011-10-04 22:00:54 +02001560
Linus Walleij14cee672012-01-06 12:54:47 +01001561 /*
1562 * Huawei
1563 */
1564 // Reported by Bearsh <bearsh@users.sourceforge.net>
1565 { "Huawei", 0x12d1, "Mediapad", 0x361f, DEVICE_FLAGS_ANDROID_BUGS },
Linus Walleij94715ae2011-11-03 17:01:05 +01001566
1567 /*
1568 * ZTE
1569 * Android devices reported by junwang <lovewjlove@users.sourceforge.net>
1570 */
1571 { "ZTE", 0x19d2, "V55 ID 1", 0x0244, DEVICE_FLAGS_ANDROID_BUGS },
1572 { "ZTE", 0x19d2, "V55 ID 2", 0x0245, DEVICE_FLAGS_ANDROID_BUGS },
1573
Linus Walleij99d390e2010-01-19 01:17:39 +00001574 /*
Linus Walleij6eabd662012-01-19 16:31:10 +01001575 * Hewlett-Packard (HP)
1576 */
1577 // These identify themselves as "cm_tenderloin", fun...
1578 { "Hewlett-Packard", 0x0bb4, "HP Touchpad", 0x685c,
1579 DEVICE_FLAGS_ANDROID_BUGS },
1580 { "Hewlett-Packard", 0x0bb4, "HP Touchpad (debug mode)",
1581 0x6860, DEVICE_FLAGS_ANDROID_BUGS },
1582
1583 /*
Linus Walleij1a673de2007-10-29 23:10:05 +00001584 * Other strange stuff.
1585 */
1586 { "Isabella", 0x0b20, "Her Prototype", 0xddee, DEVICE_FLAG_NONE }