blob: 46f56db4f59d14eff429714419a1d06fdd36544d [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 Walleije3388702010-02-03 10:02:13 +00006 * Copyright (C) 2005-2010 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 Walleijee619552009-02-06 21:23:12 +000048 { "Creative", 0x041e, "ZEN Vision", 0x411f, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
49 { "Creative", 0x041e, "Portable Media Center", 0x4123, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
50 { "Creative", 0x041e, "ZEN Xtra (MTP mode)", 0x4128, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
51 { "Dell", 0x041e, "DJ (2nd generation)", 0x412f, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
52 { "Creative", 0x041e, "ZEN Micro (MTP mode)", 0x4130, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
53 { "Creative", 0x041e, "ZEN Touch (MTP mode)", 0x4131, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
54 { "Dell", 0x041e, "Dell Pocket DJ (MTP mode)", 0x4132, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
55 { "Creative", 0x041e, "ZEN Sleek (MTP mode)", 0x4137, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
56 { "Creative", 0x041e, "ZEN MicroPhoto", 0x413c, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
57 { "Creative", 0x041e, "ZEN Sleek Photo", 0x413d, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
58 { "Creative", 0x041e, "ZEN Vision:M", 0x413e, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +000059 // Reported by marazm@o2.pl
Linus Walleijee619552009-02-06 21:23:12 +000060 { "Creative", 0x041e, "ZEN V", 0x4150, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +000061 // Reported by danielw@iinet.net.au
62 // This version of the Vision:M needs the no release interface flag,
63 // unclear whether the other version above need it too or not.
Linus Walleij1d0e84f2007-11-02 21:05:35 +000064 { "Creative", 0x041e, "ZEN Vision:M (DVP-HD0004)", 0x4151,
Linus Walleij6222f732009-06-24 08:27:08 +000065 DEVICE_FLAG_NO_RELEASE_INTERFACE |
66 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL},
Linus Walleij1a673de2007-10-29 23:10:05 +000067 // Reported by Darel on the XNJB forums
Linus Walleij6222f732009-06-24 08:27:08 +000068 { "Creative", 0x041e, "ZEN V Plus", 0x4152,
69 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
70 { "Creative", 0x041e, "ZEN Vision W", 0x4153,
71 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Richard Lowa11a6ad2008-01-21 17:23:55 +000072 // Don't add 0x4155: this is a Zen Stone device which is not MTP
Linus Walleij1a673de2007-10-29 23:10:05 +000073 // Reported by Paul Kurczaba <paul@kurczaba.com>
Linus Walleijee619552009-02-06 21:23:12 +000074 { "Creative", 0x041e, "ZEN", 0x4157, DEVICE_FLAG_IGNORE_HEADER_ERRORS |
Linus Walleij6222f732009-06-24 08:27:08 +000075 DEVICE_FLAG_BROKEN_SET_SAMPLE_DIMENSIONS |
76 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +000077 // Reported by Ringofan <mcroman@users.sourceforge.net>
Linus Walleij6222f732009-06-24 08:27:08 +000078 { "Creative", 0x041e, "ZEN V 2GB", 0x4158,
79 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleijf0ea0292008-09-10 06:52:16 +000080 // Reported by j norment <stormzen@gmail.com>
Linus Walleij6222f732009-06-24 08:27:08 +000081 { "Creative", 0x041e, "ZEN Mozaic", 0x4161,
82 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleijc2bc9732008-08-14 21:12:44 +000083 // Reported by Aaron F. Gonzalez <sub_tex@users.sourceforge.net>
Linus Walleij6222f732009-06-24 08:27:08 +000084 { "Creative", 0x041e, "ZEN X-Fi", 0x4162,
85 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleija9058aa2009-09-12 06:36:18 +000086 // Reported by Todor Gyumyushev <yodor1@users.sourceforge.net>
Linus Walleijcfe8f3f2009-09-12 06:34:27 +000087 { "ZiiLABS", 0x041e, "Zii EGG", 0x6000,
Linus Walleijbf1469f2009-09-15 16:50:40 +000088 DEVICE_FLAG_UNLOAD_DRIVER |
89 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
90 DEVICE_FLAG_NO_RELEASE_INTERFACE |
91 DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
92 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +000093
94 /*
95 * Samsung
96 * We suspect that more of these are dual mode.
Linus Walleij46da8742007-11-20 11:11:03 +000097 * We suspect more of these might need DEVICE_FLAG_NO_ZERO_READS
Linus Walleijf3c44052008-08-16 21:14:56 +000098 * We suspect more of these might need DEVICE_FLAG_PLAYLIST_SPL_V1
99 * or DEVICE_FLAG_PLAYLIST_SPL_V2 to get playlists working.
Linus Walleijcc2cf972007-11-22 20:23:43 +0000100 * YP-NEU, YP-NDU, YP-20, YP-800, YP-MF Series, YP-100, YP-30
101 * YP-700 and YP-90 are NOT MTP, but use a Samsung custom protocol.
Linus Walleij1a673de2007-10-29 23:10:05 +0000102 */
Linus Walleij6e1f7f42007-11-15 23:27:25 +0000103 // From anonymous SourceForge user, not verified
104 { "Samsung", 0x04e8, "YP-900", 0x0409, DEVICE_FLAG_NONE },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000105 // From MItch <dbaker@users.sourceforge.net>
106 { "Samsung", 0x04e8, "I550W Phone", 0x04a4, DEVICE_FLAG_NONE },
Linus Walleij5e44ed52010-01-30 08:06:11 +0000107 // From Manfred Enning <menning@users.sourceforge.net>
108 { "Samsung", 0x04e8, "Jet S8000", 0x4f1f, DEVICE_FLAG_NONE },
Linus Walleijca8b20a2008-08-14 07:02:16 +0000109 // From Gabriel Nunes <gabrielkm1@yahoo.com.br>
110 { "Samsung", 0x04e8, "YH-920 (501d)", 0x501d, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000111 // From Soren O'Neill
Linus Walleijca8b20a2008-08-14 07:02:16 +0000112 { "Samsung", 0x04e8, "YH-920 (5022)", 0x5022, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000113 // Contributed by aronvanammers on SourceForge
114 { "Samsung", 0x04e8, "YH-925GS", 0x5024, DEVICE_FLAG_NONE },
115 // From libgphoto2, according to tests by Stephan Fabel it cannot
116 // get all objects with the getobjectproplist command..
117 { "Samsung", 0x04e8, "YH-820", 0x502e, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
118 // Contributed by polux2001@users.sourceforge.net
Linus Walleijca8b20a2008-08-14 07:02:16 +0000119 { "Samsung", 0x04e8, "YH-925(-GS)", 0x502f, DEVICE_FLAG_UNLOAD_DRIVER |
120 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000121 // Contributed by anonymous person on SourceForge
122 { "Samsung", 0x04e8, "YH-J70J", 0x5033, DEVICE_FLAG_UNLOAD_DRIVER },
123 // From XNJB user
Linus Walleijf3c44052008-08-16 21:14:56 +0000124 // Guessing on .spl flag
125 { "Samsung", 0x04e8, "YP-Z5", 0x503c, DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Richard Lowef197312008-11-01 18:29:41 +0000126 // Don't add 0x5041 as this is YP-Z5 in USB mode
Linus Walleij1a673de2007-10-29 23:10:05 +0000127 // Contributed by anonymous person on SourceForge
Linus Walleij84072342009-06-24 08:08:26 +0000128 { "Samsung", 0x04e8, "YP-T7J", 0x5047, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000129 // Reported by cstrickler@gmail.com
130 { "Samsung", 0x04e8, "YP-U2J (YP-U2JXB/XAA)", 0x5054, DEVICE_FLAG_UNLOAD_DRIVER },
131 // Reported by Andrew Benson
132 { "Samsung", 0x04e8, "YP-F2J", 0x5057, DEVICE_FLAG_UNLOAD_DRIVER },
133 // Reported by Patrick <skibler@gmail.com>
Linus Walleijf3c44052008-08-16 21:14:56 +0000134 // Just guessing but looks like .spl v1 http://www.anythingbutipod.com/forum/showthread.php?t=14160
Linus Walleij84072342009-06-24 08:08:26 +0000135 { "Samsung", 0x04e8, "YP-K5", 0x505a, DEVICE_FLAG_UNLOAD_DRIVER |
136 DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij10796872007-12-28 22:56:02 +0000137 // From dev.local@gmail.com - 0x4e8/0x507c is the UMS mode, apparently
Linus Walleij23ab1542008-01-06 22:10:34 +0000138 // do not add that device.
Linus Walleij1a673de2007-10-29 23:10:05 +0000139 // From m.eik michalke
Linus Walleije9b4e912008-11-30 00:09:17 +0000140 // This device does NOT use the special SPL playlist according to sypqgjxu@gmx.de.
Linus Walleij84072342009-06-24 08:08:26 +0000141 { "Samsung", 0x04e8, "YP-U3", 0x507d, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000142 // Reported by Matthew Wilcox <matthew@wil.cx>
Linus Walleijb1058e02008-05-21 00:01:16 +0000143 // Sergio <sfrdll@tiscali.it> reports this device need the BROKEN ALL flag.
Linus Walleijf3c44052008-08-16 21:14:56 +0000144 // Guessing on .spl flag
Linus Walleij84072342009-06-24 08:08:26 +0000145 { "Samsung", 0x04e8, "YP-T9", 0x507f, DEVICE_FLAG_UNLOAD_DRIVER |
146 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij1a673de2007-10-29 23:10:05 +0000147 // From Paul Clinch
Linus Walleijf3c44052008-08-16 21:14:56 +0000148 // Just guessing but looks like .spl v1 http://www.anythingbutipod.com/forum/showthread.php?t=14160
Linus Walleij1e0eba72009-02-21 07:26:29 +0000149 // Some versions of the firmware reportedly support OGG, reportedly only the
150 // UMS versions, so MTP+OGG is not possible on this device.
Linus Walleij84072342009-06-24 08:08:26 +0000151 { "Samsung", 0x04e8, "YP-K3", 0x5081, DEVICE_FLAG_UNLOAD_DRIVER |
152 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Richard Low6a2f3b82007-11-04 18:39:17 +0000153 // From XNJB user
Linus Walleijf3c44052008-08-16 21:14:56 +0000154 // From Alistair Boyle, .spl v2 required for playlists
Linus Walleijd4157be2009-02-21 07:23:26 +0000155 // According to the device log it properly supports OGG
Linus Walleij84072342009-06-24 08:08:26 +0000156 { "Samsung", 0x04e8, "YP-P2", 0x5083, DEVICE_FLAG_UNLOAD_DRIVER |
157 DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_PLAYLIST_SPL_V2 },
Linus Walleij5a6bcf72007-10-31 20:52:42 +0000158 // From Paul Clinch
Linus Walleijf3c44052008-08-16 21:14:56 +0000159 // Guessing on .spl flag
Linus Walleij84072342009-06-24 08:08:26 +0000160 { "Samsung", 0x04e8, "YP-T10", 0x508a, DEVICE_FLAG_UNLOAD_DRIVER |
161 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
162 DEVICE_FLAG_PLAYLIST_SPL_V1 | DEVICE_FLAG_NO_ZERO_READS },
Linus Walleij4b43bbf2008-04-07 09:16:44 +0000163 // From Wim Verwimp <wimverwimp@gmail.com>
164 // Not sure about the Ogg and broken proplist flags here. Just guessing.
Linus Walleijf3c44052008-08-16 21:14:56 +0000165 // Guessing on .spl flag
Linus Walleij84072342009-06-24 08:08:26 +0000166 { "Samsung", 0x04e8, "YP-S5", 0x508b, DEVICE_FLAG_UNLOAD_DRIVER |
167 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
168 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij07bb5382008-07-31 20:21:09 +0000169 // From Ludovic Danigo
Linus Walleijf3c44052008-08-16 21:14:56 +0000170 // Guessing on .spl flag
Linus Walleij84072342009-06-24 08:08:26 +0000171 { "Samsung", 0x04e8, "YP-S3", 0x5091, DEVICE_FLAG_UNLOAD_DRIVER |
172 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
173 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij2288a6a2009-01-27 21:16:38 +0000174 // From Adrian Levi <adrian.levi@gmail.com>
175 // Guessing on .spl flag
Linus Walleijd4157be2009-02-21 07:23:26 +0000176 // This one supports OGG properly through the correct MTP type.
Linus Walleij84072342009-06-24 08:08:26 +0000177 { "Samsung", 0x04e8, "YP-U4", 0x5093, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijc3a6eeb2010-01-30 07:32:41 +0000178 // From Chris Le Sueur <thefishface@gmail.com>
179 // Guessing on .spl flag
180 // This one supports OGG properly through the correct MTP type.
Linus Walleijebf32cc2010-04-04 23:07:25 +0000181 { "Samsung", 0x04e8, "YP-R1", 0x510f, DEVICE_FLAG_UNLOAD_DRIVER |
182 DEVICE_FLAG_UNIQUE_FILENAMES | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
183 // From Anonymous SourceForge user
Linus Walleij2b8c8492008-12-12 00:16:48 +0000184 // Guessing on .spl flag
Linus Walleij84072342009-06-24 08:08:26 +0000185 { "Samsung", 0x04e8, "YP-Q1", 0x5115, DEVICE_FLAG_UNLOAD_DRIVER |
186 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
187 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij6e3d9532010-01-08 11:09:50 +0000188 // From Holger
Linus Walleij9ea512e2010-01-08 11:08:01 +0000189 { "Samsung", 0x04e8, "YP-M1", 0x5118, DEVICE_FLAG_UNLOAD_DRIVER |
190 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_PLAYLIST_SPL_V2 },
Linus Walleijb49a9f72009-05-14 20:46:07 +0000191 // From Anonymous SourceForge user
192 // Guessing on .spl flag
Linus Walleij84072342009-06-24 08:08:26 +0000193 { "Samsung", 0x04e8, "YP-P3", 0x511a, DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleijb49a9f72009-05-14 20:46:07 +0000194 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
195 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij316628c2009-06-15 19:55:41 +0000196 // From Anonymous SourceForge user
197 // Guessing on .spl flag
Linus Walleij84072342009-06-24 08:08:26 +0000198 { "Samsung", 0x04e8, "YP-Q2", 0x511d, DEVICE_FLAG_UNLOAD_DRIVER |
199 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
200 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij41e94cf2009-05-19 22:44:53 +0000201 // From Marco Pizzocaro <mpizzocaro@users.sourceforge.net>
202 // Guessing on .spl flag
203 { "Samsung", 0x04e8, "YP-U5", 0x5121,
Linus Walleije8079072010-04-02 12:25:50 +0000204 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_PLAYLIST_SPL_V1 |
205 DEVICE_FLAG_UNIQUE_FILENAMES | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijc2cdbfc2009-11-20 21:28:17 +0000206 // From Leonardo Accorsi <laccorsi@users.sourceforge.net>
207 // Guessing on .spl flag
208 { "Samsung", 0x04e8, "YP-R0", 0x5125,
Linus Walleije8079072010-04-02 12:25:50 +0000209 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_PLAYLIST_SPL_V1 |
210 DEVICE_FLAG_UNIQUE_FILENAMES | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
211 // From a rouge .INF file
Linus Walleij23ab1542008-01-06 22:10:34 +0000212 // this device ID seems to have been recycled for:
213 // the Samsung SGH-A707 Cingular cellphone
214 // the Samsung L760-V cellphone
Linus Walleij5b03d302008-11-25 20:39:27 +0000215 // the Samsung SGH-U900 cellphone
Linus Walleijc1a82f12009-11-30 00:06:28 +0000216 { "Samsung", 0x04e8, "YH-999 Portable Media Center/SGH-A707/SGH-L760V/SGH-U900/Verizon Intensity", 0x5a0f, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij2350b712008-01-14 22:54:37 +0000217 // From Santi Béjar <sbejar@gmail.com> - not sure this is MTP...
218 // { "Samsung", 0x04e8, "Z170 Mobile Phone", 0x6601, DEVICE_FLAG_UNLOAD_DRIVER },
219 // From Santi Béjar <sbejar@gmail.com> - not sure this is MTP...
220 // { "Samsung", 0x04e8, "E250 Mobile Phone", 0x663e, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000221 // From Lionel Bouton
Linus Walleij84072342009-06-24 08:08:26 +0000222 { "Samsung", 0x04e8, "X830 Mobile Phone", 0x6702, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000223 // From James <jamestech@gmail.com>
224 { "Samsung", 0x04e8, "U600 Mobile Phone", 0x6709, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij5b03d302008-11-25 20:39:27 +0000225 // From Cesar Cardoso <cesar@cesarcardoso.tk>
226 // No confirmation that this is really MTP.
227 { "Samsung", 0x04e8, "F250 Mobile Phone", 0x6727, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijc50e7682007-11-02 00:01:17 +0000228 // From Charlie Todd 2007-10-31
229 { "Samsung", 0x04e8, "Juke (SCH-U470)", 0x6734, DEVICE_FLAG_UNLOAD_DRIVER},
Linus Walleij34b421f2009-07-23 22:30:51 +0000230 // Reported by Tenn
231 { "Samsung", 0x04e8, "GT-B2700", 0x6752, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij5f0814f2009-07-23 21:53:38 +0000232 // Added by Greg Fitzgerald <netzdamon@gmail.com>
233 { "Samsung", 0x04e8, "SAMSUNG Trance", 0x6763, DEVICE_FLAG_UNLOAD_DRIVER |
234 DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleijd866d242009-08-23 21:50:39 +0000235 // From anonymous Sourceforge user
236 { "Samsung", 0x04e8, "GT-S5230", 0xe20c, DEVICE_FLAG_NONE },
237
Linus Walleij1a673de2007-10-29 23:10:05 +0000238
239 /*
Linus Walleij414a0832009-09-18 23:04:05 +0000240 * Microsoft & Intel
Linus Walleij1a673de2007-10-29 23:10:05 +0000241 */
242 { "Intel", 0x045e, "Bandon Portable Media Center", 0x00c9, DEVICE_FLAG_NONE },
Linus Walleij414aca02008-06-02 23:16:49 +0000243 // Reported by Tadimarri Sarath <sarath.tadi@gmail.com>
244 // No idea why this use an Intel PID, perhaps a leftover from
245 // the early PMC development days when Intel and Microsoft were
246 // partnering.
247 { "Microsoft", 0x045e, "Windows MTP Simulator", 0x0622, DEVICE_FLAG_NONE },
Linus Walleij414a0832009-09-18 23:04:05 +0000248 // Reported by Edward Hutchins (used for Zune HDs)
249 { "Microsoft", 0x045e, "Zune HD", 0x063e, DEVICE_FLAG_NONE },
250 // Reported by Farooq Zaman (used for all Zunes)
251 { "Microsoft", 0x045e, "Zune", 0x0710, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000252
253 /*
254 * JVC
255 */
256 // From Mark Veinot
257 { "JVC", 0x04f1, "Alneo XA-HD500", 0x6105, DEVICE_FLAG_NONE },
258
259 /*
260 * Philips
261 */
262 { "Philips", 0x0471, "HDD6320/00 or HDD6330/17", 0x014b, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
263 // Anonymous SourceForge user
Linus Walleijf0702982008-10-25 21:37:43 +0000264 { "Philips", 0x0471, "HDD14XX,HDD1620 or HDD1630/17", 0x014c, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000265 // from discussion forum
266 { "Philips", 0x0471, "HDD085/00 or HDD082/17", 0x014d, DEVICE_FLAG_NONE },
267 // from XNJB forum
Richard Low641d1e32008-02-24 20:47:20 +0000268 { "Philips", 0x0471, "GoGear SA9200", 0x014f, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000269 // From John Coppens <jcoppens@users.sourceforge.net>
270 { "Philips", 0x0471, "SA1115/55", 0x0164, DEVICE_FLAG_NONE },
271 // From Gerhard Mekenkamp
272 { "Philips", 0x0471, "GoGear Audio", 0x0165, DEVICE_FLAG_NONE },
273 // from David Holm <wormie@alberg.dk>
274 { "Philips", 0x0471, "Shoqbox", 0x0172, DEVICE_FLAG_ONLY_7BIT_FILENAMES },
275 // from npedrosa
276 { "Philips", 0x0471, "PSA610", 0x0181, DEVICE_FLAG_NONE },
277 // From libgphoto2 source
278 { "Philips", 0x0471, "HDD6320", 0x01eb, DEVICE_FLAG_NONE },
279 // From Detlef Meier <dm@emlix.com>
Linus Walleija8ba8c72008-03-29 00:02:27 +0000280 { "Philips", 0x0471, "GoGear SA6014/SA6015/SA6024/SA6025/SA6044/SA6045", 0x084e, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij23ab1542008-01-06 22:10:34 +0000281 // From anonymous Sourceforge user SA5145/02
Linus Walleija8ba8c72008-03-29 00:02:27 +0000282 { "Philips", 0x0471, "GoGear SA5145", 0x0857, DEVICE_FLAG_UNLOAD_DRIVER },
283 // From a
284 { "Philips", 0x0471, "GoGear SA6125/SA6145/SA6185", 0x2002, DEVICE_FLAG_UNLOAD_DRIVER },
285 // From anonymous Sourceforge user, not verified to be MTP!
286 { "Philips", 0x0471, "GoGear SA3345", 0x2004, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij2242b022009-01-02 01:44:00 +0000287 // From Roberto Vidmar <rvidmar@libero.it>
288 { "Philips", 0x0471, "SA5285", 0x2022, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij15ed3b32009-07-23 22:19:43 +0000289 // From Elie De Brauwer <elie@de-brauwer.be>
290 { "Philips", 0x0471, "GoGear ViBE SA1VBE04", 0x2075,
291 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij99d390e2010-01-19 01:17:39 +0000292 // From Anonymous SourceForge user
293 { "Philips", 0x0471, "GoGear Muse", 0x2077,
294 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij15ed3b32009-07-23 22:19:43 +0000295 // From Elie De Brauwer <elie@de-brauwer.be>
296 { "Philips", 0x0471, "GoGear ViBE SA1VBE08", 0x207b,
297 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijd866d242009-08-23 21:50:39 +0000298 // From josmtx <josmtx@users.sourceforge.net>
299 { "Philips", 0x0471, "GoGear Aria", 0x207c,
300 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij5e44ed52010-01-30 08:06:11 +0000301 // From epklein
302 { "Philips", 0x0471, "GoGear SA1VBE08KX/78", 0x208e,
303 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000304 // from XNJB user
305 { "Philips", 0x0471, "PSA235", 0x7e01, DEVICE_FLAG_NONE },
306
307
308 /*
309 * SanDisk
310 * several devices (c150 for sure) are definately dual-mode and must
311 * have the USB mass storage driver that hooks them unloaded first.
312 * They all have problematic dual-mode making the device unload effect
Linus Walleij5e202562008-06-03 11:35:05 +0000313 * uncertain on these devices.
314 *
315 * All older devices seem to need DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL.
316 * Old chipsets: e200/c200 use PP5024 from Nvidia (formerly PortalPlayer).
317 * m200 use TCC770 from Telechips.
318 *
319 * The newer Sansa v2 chipset, AD3525 from Austriamicrosystems (AMS) found
320 * in e280 v2 c200 v2, Clip, Fuze etc require DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST
321 * and DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR to work properly.
322 *
323 * For more info see: http://daniel.haxx.se/sansa/v2.html
Linus Walleij1a673de2007-10-29 23:10:05 +0000324 */
325 // Reported by Brian Robison
Linus Walleijde1620f2009-06-15 20:02:02 +0000326 { "SanDisk", 0x0781, "Sansa m230/m240", 0x7400,
Linus Walleij1a673de2007-10-29 23:10:05 +0000327 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000328 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij18ed0162009-05-06 16:51:08 +0000329 // From Rockbox device listing
Linus Walleijde1620f2009-06-15 20:02:02 +0000330 { "SanDisk", 0x0781, "Sansa m200-tcc (MTP mode)", 0x7401,
Linus Walleij18ed0162009-05-06 16:51:08 +0000331 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
332 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000333 // Reported by tangent_@users.sourceforge.net
Linus Walleijde1620f2009-06-15 20:02:02 +0000334 { "SanDisk", 0x0781, "Sansa c150", 0x7410,
Linus Walleij1a673de2007-10-29 23:10:05 +0000335 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000336 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000337 // From libgphoto2 source
338 // Reported by <gonkflea@users.sourceforge.net>
339 // Reported by Mike Owen <mikeowen@computerbaseusa.com>
Linus Walleij18ed0162009-05-06 16:51:08 +0000340 { "SanDisk", 0x0781, "Sansa e200/e250/e260/e270/e280", 0x7420,
Linus Walleij1a673de2007-10-29 23:10:05 +0000341 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000342 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Richard Low58f5afe2009-04-30 13:24:06 +0000343 // Don't add 0x7421 as this is e280 in MSC mode
Linus Walleij1a673de2007-10-29 23:10:05 +0000344 // Reported by XNJB user
Linus Walleij18ed0162009-05-06 16:51:08 +0000345 { "SanDisk", 0x0781, "Sansa e260/e280 v2", 0x7422,
Linus Walleij5e202562008-06-03 11:35:05 +0000346 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij37588142008-10-16 19:10:47 +0000347 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000348 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Richard Lowd56e8a62007-12-08 16:59:11 +0000349 // Reported by XNJB user
Linus Walleijde1620f2009-06-15 20:02:02 +0000350 { "SanDisk", 0x0781, "Sansa m240/m250", 0x7430,
Linus Walleij1a673de2007-10-29 23:10:05 +0000351 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000352 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij077a8902007-11-15 21:18:12 +0000353 // Reported by Eugene Brevdo <ebrevdo@princeton.edu>
Linus Walleij5e202562008-06-03 11:35:05 +0000354 { "SanDisk", 0x0781, "Sansa Clip", 0x7432,
355 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij37588142008-10-16 19:10:47 +0000356 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000357 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
Linus Walleij39f9a452008-11-15 09:39:39 +0000358 // Reported by HackAR <hackar@users.sourceforge.net>
Linus Walleij624a15a2009-01-06 00:31:34 +0000359 { "SanDisk", 0x0781, "Sansa Clip v2", 0x7434,
Linus Walleij39f9a452008-11-15 09:39:39 +0000360 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
361 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
362 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
Linus Walleij1a673de2007-10-29 23:10:05 +0000363 // Reported by anonymous user at sourceforge.net
Linus Walleijde1620f2009-06-15 20:02:02 +0000364 { "SanDisk", 0x0781, "Sansa c240/c250", 0x7450,
Linus Walleij1a673de2007-10-29 23:10:05 +0000365 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000366 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij2242b022009-01-02 01:44:00 +0000367 // Reported by anonymous SourceForge user
Linus Walleijde1620f2009-06-15 20:02:02 +0000368 { "SanDisk", 0x0781, "Sansa c250 v2", 0x7452,
Linus Walleij2242b022009-01-02 01:44:00 +0000369 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
370 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000371 // Reported by Troy Curtis Jr.
Linus Walleijde1620f2009-06-15 20:02:02 +0000372 { "SanDisk", 0x0781, "Sansa Express", 0x7460,
373 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000374 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000375 // Reported by XNJB user, and Miguel de Icaza <miguel@gnome.org>
376 // This has no dual-mode so no need to unload any driver.
377 // This is a Linux based device!
378 { "SanDisk", 0x0781, "Sansa Connect", 0x7480, DEVICE_FLAG_NONE },
379 // Reported by anonymous SourceForge user
Linus Walleijde1620f2009-06-15 20:02:02 +0000380 { "SanDisk", 0x0781, "Sansa View", 0x74b0,
Linus Walleij1a673de2007-10-29 23:10:05 +0000381 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000382 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij690a3162008-03-31 21:40:23 +0000383 // Reported by Patrick <skibler@gmail.com>
384 // There are apparently problems with this device.
Linus Walleij25a16302009-03-04 13:56:33 +0000385 { "SanDisk", 0x0781, "Sansa Fuze", 0x74c0,
386 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
387 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
388 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
389 // Harry Phillips <tuxcomputers@users.sourceforge.net>
390 { "SanDisk", 0x0781, "Sansa Fuze v2", 0x74c2,
Linus Walleij5e202562008-06-03 11:35:05 +0000391 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij37588142008-10-16 19:10:47 +0000392 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000393 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleija5cb5c92009-10-10 22:03:38 +0000394 // Reported by anonymous SourceForge user
395 { "SanDisk", 0x0781, "Sansa Clip+", 0x74d0,
396 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
397 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
398 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
399
Linus Walleij1a673de2007-10-29 23:10:05 +0000400
401 /*
402 * iRiver
403 * we assume that PTP_OC_MTP_GetObjPropList is essentially
404 * broken on all iRiver devices, meaning it simply won't return
Linus Walleij688e5542010-02-01 11:35:15 +0000405 * all properties for a file when asking for metadata 0xffffffff.
Linus Walleij1a673de2007-10-29 23:10:05 +0000406 * Please test on your device if you believe it isn't broken!
Linus Walleij1a673de2007-10-29 23:10:05 +0000407 */
Linus Walleij18ed0162009-05-06 16:51:08 +0000408 { "iRiver", 0x1006, "H300 Series MTP", 0x3004,
Linus Walleij688e5542010-02-01 11:35:15 +0000409 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000410 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij18ed0162009-05-06 16:51:08 +0000411 { "iRiver", 0x1006, "Portable Media Center", 0x4002,
Linus Walleij688e5542010-02-01 11:35:15 +0000412 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij18ed0162009-05-06 16:51:08 +0000413 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
414 { "iRiver", 0x1006, "Portable Media Center", 0x4003,
Linus Walleij688e5542010-02-01 11:35:15 +0000415 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000416 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij2242b022009-01-02 01:44:00 +0000417 // From [st]anislav <iamstanislav@gmail.com>
Linus Walleijdeb1aca2009-01-02 23:20:06 +0000418 { "iRiver", 0x1042, "T7 Volcano", 0x1143, DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij80a2a692008-12-05 20:36:40 +0000419 // From an anonymous person at SourceForge, uncertain about this one
Linus Walleij688e5542010-02-01 11:35:15 +0000420 { "iRiver", 0x4102, "iFP-880", 0x1008,
421 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000422 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij80a2a692008-12-05 20:36:40 +0000423 // 0x4102, 0x1042 is a USB mass storage mode for E100 v2/Lplayer
Linus Walleij1a673de2007-10-29 23:10:05 +0000424 // From libgphoto2 source
Linus Walleij688e5542010-02-01 11:35:15 +0000425 { "iRiver", 0x4102, "T10", 0x1113,
426 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000427 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij688e5542010-02-01 11:35:15 +0000428 { "iRiver", 0x4102, "T20 FM", 0x1114,
429 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000430 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
431 // This appears at the MTP-UMS site
Linus Walleij688e5542010-02-01 11:35:15 +0000432 { "iRiver", 0x4102, "T20", 0x1115,
433 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000434 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij688e5542010-02-01 11:35:15 +0000435 { "iRiver", 0x4102, "U10", 0x1116,
436 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000437 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij688e5542010-02-01 11:35:15 +0000438 { "iRiver", 0x4102, "T10a", 0x1117,
439 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000440 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij688e5542010-02-01 11:35:15 +0000441 { "iRiver", 0x4102, "T20", 0x1118,
442 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000443 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij688e5542010-02-01 11:35:15 +0000444 { "iRiver", 0x4102, "T30", 0x1119,
445 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000446 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
447 // Reported by David Wolpoff
Linus Walleij688e5542010-02-01 11:35:15 +0000448 { "iRiver", 0x4102, "T10 2GB", 0x1120,
449 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000450 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
451 // Rough guess this is the MTP device ID...
Linus Walleij688e5542010-02-01 11:35:15 +0000452 { "iRiver", 0x4102, "N12", 0x1122,
453 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000454 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
455 // Reported by Philip Antoniades <philip@mysql.com>
456 // Newer iriver devices seem to have shaped-up firmware without any
457 // of the annoying bugs.
458 { "iRiver", 0x4102, "Clix2", 0x1126, DEVICE_FLAG_NONE },
459 // Reported by Adam Torgerson
Linus Walleij688e5542010-02-01 11:35:15 +0000460 { "iRiver", 0x4102, "Clix", 0x112a,
Linus Walleij1a673de2007-10-29 23:10:05 +0000461 DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
462 // Reported by Douglas Roth <dougaus@gmail.com>
Linus Walleij688e5542010-02-01 11:35:15 +0000463 { "iRiver", 0x4102, "X20", 0x1132,
464 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000465 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
466 // Reported by Robert Ugo <robert_ugo@users.sourceforge.net>
Linus Walleij688e5542010-02-01 11:35:15 +0000467 { "iRiver", 0x4102, "T60", 0x1134,
468 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij1a673de2007-10-29 23:10:05 +0000469 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000470 // Reported by two anonymous SourceForge users
Linus Walleij07bb5382008-07-31 20:21:09 +0000471 // Needs the stronger OGG_IS_UNKNOWN flag to support OGG properly,
472 // be aware of newer players that may be needing this too.
Linus Walleij688e5542010-02-01 11:35:15 +0000473 { "iRiver", 0x4102, "E100", 0x1141,
474 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij07bb5382008-07-31 20:21:09 +0000475 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000476 // Reported by anonymous SourceForge user
477 // Need verification of whether this firmware really need all these flags
Linus Walleij688e5542010-02-01 11:35:15 +0000478 { "iRiver", 0x4102, "E100 v2/Lplayer", 0x1142,
479 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleijc2bc9732008-08-14 21:12:44 +0000480 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij6e680ad2009-01-07 21:22:45 +0000481 // Reported by Richard Vennemann <vennemann@users.sourceforge.net>
Linus Walleij16ee3422009-01-08 23:15:52 +0000482 // In USB Mass Storage mode it is 0x4102/0x1047
Linus Walleijb57167c2009-01-10 22:37:51 +0000483 // Seems to use the new shaped-up firmware.
484 { "iRiver", 0x4102, "Spinn", 0x1147, DEVICE_FLAG_NONE },
Linus Walleije84dcf12009-05-14 20:33:05 +0000485 // Reported by Tony Janssen <tonyjanssen@users.sourceforge.net>
486 { "iRiver", 0x4102, "E50", 0x1151,
Linus Walleij688e5542010-02-01 11:35:15 +0000487 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
488 DEVICE_FLAG_OGG_IS_UNKNOWN },
489 // Reported by pyalex@users.sourceforge.net
490 // Guessing that this needs the FLAG_NO_ZERO_READS...
491 { "iRiver", 0x4102, "E30", 0x1167,
492 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleije84dcf12009-05-14 20:33:05 +0000493 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +0000494 // Reported by Scott Call
Linus Walleij07bb5382008-07-31 20:21:09 +0000495 // Assume this actually supports OGG though it reports it doesn't.
Linus Walleij688e5542010-02-01 11:35:15 +0000496 { "iRiver", 0x4102, "H10 20GB", 0x2101,
497 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij07bb5382008-07-31 20:21:09 +0000498 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij688e5542010-02-01 11:35:15 +0000499 { "iRiver", 0x4102, "H10 5GB", 0x2102,
500 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij18ed0162009-05-06 16:51:08 +0000501 DEVICE_FLAG_OGG_IS_UNKNOWN },
502 // From Rockbox device listing
Linus Walleij688e5542010-02-01 11:35:15 +0000503 { "iRiver", 0x4102, "H10 5.6GB", 0x2105,
504 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij07bb5382008-07-31 20:21:09 +0000505 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +0000506
507
508 /*
509 * Dell
510 */
511 { "Dell, Inc", 0x413c, "DJ Itty", 0x4500, DEVICE_FLAG_NONE },
512
513 /*
514 * Toshiba
Linus Walleij7e3b3072009-01-19 22:51:17 +0000515 * Tentatively flagged all Toshiba devices with
516 * DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST after one of them
517 * showed erroneous behaviour.
Linus Walleij1a673de2007-10-29 23:10:05 +0000518 */
Linus Walleij7e3b3072009-01-19 22:51:17 +0000519 { "Toshiba", 0x0930, "Gigabeat MEGF-40", 0x0009,
520 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
521 { "Toshiba", 0x0930, "Gigabeat", 0x000c,
522 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000523 // Reported by Nicholas Tripp
Linus Walleij7e3b3072009-01-19 22:51:17 +0000524 { "Toshiba", 0x0930, "Gigabeat P20", 0x000f,
525 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000526 // From libgphoto2
Linus Walleij7e3b3072009-01-19 22:51:17 +0000527 { "Toshiba", 0x0930, "Gigabeat S", 0x0010, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
528 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000529 // Reported by Rob Brown
Linus Walleij7e3b3072009-01-19 22:51:17 +0000530 { "Toshiba", 0x0930, "Gigabeat P10", 0x0011,
531 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij51dde6b2007-11-03 23:14:59 +0000532 // Reported by solanum@users.sourceforge.net
Linus Walleij7e3b3072009-01-19 22:51:17 +0000533 { "Toshiba", 0x0930, "Gigabeat V30", 0x0014,
534 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000535 // Reported by Michael Davis <slithy@yahoo.com>
Linus Walleij7e3b3072009-01-19 22:51:17 +0000536 { "Toshiba", 0x0930, "Gigabeat U", 0x0016,
537 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij804cc622008-02-03 21:26:26 +0000538 // Reported by Devon Jacobs <devo@godevo.com>
Linus Walleijf67c1ad2009-01-14 21:39:50 +0000539 { "Toshiba", 0x0930, "Gigabeat MEU202", 0x0018,
540 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleijc76e2f72007-12-09 22:14:35 +0000541 // Reported by Rolf <japan (at) dl3lar.de>
Linus Walleij7e3b3072009-01-19 22:51:17 +0000542 { "Toshiba", 0x0930, "Gigabeat T", 0x0019,
543 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij07bb5382008-07-31 20:21:09 +0000544 // Reported by Phil Ingram <ukpbert@users.sourceforge.net>
545 // Tentatively added - no real reports of this device ID being MTP,
546 // reports as USB Mass Storage currently.
Linus Walleij7e3b3072009-01-19 22:51:17 +0000547 { "Toshiba", 0x0930, "Gigabeat MEU201", 0x001a,
548 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij922880f2008-10-29 17:31:42 +0000549 // Reported by anonymous SourceForge user
Linus Walleij7e3b3072009-01-19 22:51:17 +0000550 { "Toshiba", 0x0930, "Gigabeat MET401", 0x001d,
551 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij804cc622008-02-03 21:26:26 +0000552
Linus Walleij1a673de2007-10-29 23:10:05 +0000553 /*
554 * Archos
555 * These devices have some dual-mode interfaces which will really
556 * respect the driver unloading, so DEVICE_FLAG_UNLOAD_DRIVER
557 * really work on these devices!
558 */
559 // Reported by Alexander Haertig <AlexanderHaertig@gmx.de>
560 { "Archos", 0x0e79, "Gmini XS100", 0x1207, DEVICE_FLAG_UNLOAD_DRIVER },
561 // Added by Jan Binder
562 { "Archos", 0x0e79, "XS202 (MTP mode)", 0x1208, DEVICE_FLAG_NONE },
563 // Reported by gudul1@users.sourceforge.net
564 { "Archos", 0x0e79, "104 (MTP mode)", 0x120a, DEVICE_FLAG_NONE },
Richard Lowe525e542009-11-09 21:09:52 +0000565 // Reported by Archos
566 { "Archos", 0x0e79, "204 (MTP mode)", 0x120c, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij4c3cd682008-01-27 22:18:05 +0000567 // Reported by anonymous Sourceforge user.
568 { "Archos", 0x0e79, "404 (MTP mode)", 0x1301, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000569 // Reported by Archos
570 { "Archos", 0x0e79, "404CAM (MTP mode)", 0x1303, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000571 // Reported by Etienne Chauchot <chauchot.etienne@free.fr>
572 { "Archos", 0x0e79, "504 (MTP mode)", 0x1307, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000573 // Reported by Archos
574 { "Archos", 0x0e79, "604 (MTP mode)", 0x1309, DEVICE_FLAG_UNLOAD_DRIVER },
575 { "Archos", 0x0e79, "604WIFI (MTP mode)", 0x130b, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000576 // Reported by Kay McCormick <kaym@modsystems.com>
577 { "Archos", 0x0e79, "704 mobile dvr", 0x130d, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000578 // Reported by Archos
579 { "Archos", 0x0e79, "704TV (MTP mode)", 0x130f, DEVICE_FLAG_UNLOAD_DRIVER },
580 { "Archos", 0x0e79, "405 (MTP mode)", 0x1311, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij121b7f22007-12-08 21:37:35 +0000581 // Reported by Joe Rabinoff
Linus Walleije71639a2007-12-08 21:36:00 +0000582 { "Archos", 0x0e79, "605 (MTP mode)", 0x1313, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000583 // Reported by Archos
584 { "Archos", 0x0e79, "605F (MTP mode)", 0x1315, DEVICE_FLAG_UNLOAD_DRIVER },
585 { "Archos", 0x0e79, "705 (MTP mode)", 0x1319, DEVICE_FLAG_UNLOAD_DRIVER },
586 { "Archos", 0x0e79, "TV+ (MTP mode)", 0x131b, DEVICE_FLAG_UNLOAD_DRIVER },
587 { "Archos", 0x0e79, "105 (MTP mode)", 0x131d, DEVICE_FLAG_UNLOAD_DRIVER },
588 { "Archos", 0x0e79, "405HDD (MTP mode)", 0x1321, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij4aa66dc2009-05-02 06:36:59 +0000589 // Reported by Jim Krehl <jimmuhk@users.sourceforge.net>
590 { "Archos", 0x0e79, "5 (MTP mode)", 0x1331, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij8c725002008-11-25 20:33:13 +0000591 // Reported by Adrien Guichard <tmor@users.sourceforge.net>
592 { "Archos", 0x0e79, "5 (MTP mode)", 0x1333, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000593 // Reported by Archos
594 { "Archos", 0x0e79, "7 (MTP mode)", 0x1335, DEVICE_FLAG_UNLOAD_DRIVER },
595 { "Archos", 0x0e79, "SPOD (MTP mode)", 0x1341, DEVICE_FLAG_UNLOAD_DRIVER },
596 { "Archos", 0x0e79, "5S IT (MTP mode)", 0x1351, DEVICE_FLAG_UNLOAD_DRIVER },
597 { "Archos", 0x0e79, "5H IT (MTP mode)", 0x1357, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000598
599 /*
600 * Dunlop (OEM of EGOMAN ltd?) reported by Nanomad
601 * This unit is falsely detected as USB mass storage in Linux
602 * prior to kernel 2.6.19 (fixed by patch from Alan Stern)
603 * so on older kernels special care is needed to remove the
604 * USB mass storage driver that erroneously binds to the device
605 * interface.
606 */
607 { "Dunlop", 0x10d6, "MP3 player 1GB / EGOMAN MD223AFD", 0x2200, DEVICE_FLAG_UNLOAD_DRIVER},
Linus Walleij07bb5382008-07-31 20:21:09 +0000608 // Reported by Steven Black <stevenblack1956@users.sourceforge.net>
609 // Obviously this company goes by many names.
Linus Walleij102a72d2008-11-27 23:16:47 +0000610 // This device is USB 2.0 only. Broken pipe on closing.
Linus Walleijb7e8f972010-01-19 00:38:11 +0000611 // A later report indicates that this is also used by the iRiver E200
Linus Walleije3388702010-02-03 10:02:13 +0000612 { "Memorex or iRiver", 0x10d6, "MMP 8585/8586 or iRiver E200", 0x2300,
613 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij102a72d2008-11-27 23:16:47 +0000614 DEVICE_FLAG_NO_RELEASE_INTERFACE},
Linus Walleijb7e8f972010-01-19 00:38:11 +0000615
Linus Walleij1a673de2007-10-29 23:10:05 +0000616 /*
617 * Sirius
618 */
619 { "Sirius", 0x18f6, "Stiletto", 0x0102, DEVICE_FLAG_NONE },
Linus Walleij30a7dd92008-04-09 20:33:51 +0000620 // Reported by Chris Bagwell <chris@cnpbagwell.com>
Linus Walleij2f622812008-08-30 22:06:58 +0000621 { "Sirius", 0x18f6, "Stiletto 2", 0x0110, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000622
623 /*
624 * Canon
Linus Walleija1a2eb72009-10-14 21:51:12 +0000625 * These are actually cameras, but they have a Microsoft device descriptor
626 * and reports themselves as supporting the MTP extension.
Linus Walleij1a673de2007-10-29 23:10:05 +0000627 */
Linus Walleija1a2eb72009-10-14 21:51:12 +0000628 { "Canon", 0x04a9, "Ixus Digital 700 (PTP/MTP mode)", 0x30f2,
629 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij00e6a5e2008-10-17 07:13:30 +0000630 { "Canon", 0x04a9, "PowerShot A640 (PTP/MTP mode)", 0x3139,
631 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij99d390e2010-01-19 01:17:39 +0000632 // From Peter <pjeremy@users.sourceforge.net>
633 { "Canon", 0x04a9, "PowerShot SX20IS (PTP/MTP mode)", 0x31e4,
634 DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000635
636 /*
637 * Nokia
Linus Walleij21704fd2008-02-29 22:50:29 +0000638 * Please verify the low device IDs here, I suspect these might be for
639 * things like USB storage or modem mode actually, whereas the higher
Linus Walleij9462f552008-10-25 19:16:53 +0000640 * range (0x04nn) could be for MTP. Some of the devices were gathered
641 * from the Nokia WMP drivers:
642 * http://nds2.nokia.com/files/support/global/phones/software/
643 * Address was gathered from going to:
644 * nseries.com
645 * -> support
646 * -> select supported device
647 * -> PC software
648 * -> Music software
649 * -> Windows Media Player 10 driver
Linus Walleij1a673de2007-10-29 23:10:05 +0000650 */
651 // From: DoomHammer <gaczek@users.sourceforge.net>
Linus Walleijb5a4f922008-05-11 20:15:00 +0000652 { "Nokia", 0x0421, "N81 Mobile Phone", 0x000a, DEVICE_FLAG_NONE },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000653 // From an anonymous SourceForge user
654 { "Nokia", 0x0421, "6120c Classic Mobile Phone", 0x002e, DEVICE_FLAG_NONE },
Linus Walleijbddfd192008-11-25 20:26:52 +0000655 // From Stefano
656 { "Nokia", 0x0421, "N96 Mobile Phone", 0x0039, DEVICE_FLAG_NONE },
Linus Walleijace7f4c2008-11-01 21:07:34 +0000657 // From Martijn van de Streek <martijn@vandestreek.net>
Linus Walleij4c8b6e12008-10-31 22:04:14 +0000658 { "Nokia", 0x0421, "6500c Classic Mobile Phone", 0x003c, DEVICE_FLAG_NONE },
Linus Walleijb5a4f922008-05-11 20:15:00 +0000659 // From: DoomHammer <gaczek@users.sourceforge.net>
Linus Walleij1a673de2007-10-29 23:10:05 +0000660 { "Nokia", 0x0421, "3110c Mobile Phone", 0x005f, DEVICE_FLAG_NONE },
Linus Walleija8ba8c72008-03-29 00:02:27 +0000661 // From: Vasily <spc-@users.sourceforge.net>
662 { "Nokia", 0x0421, "3109c Mobile Phone", 0x0065, DEVICE_FLAG_NONE },
Linus Walleij07bb5382008-07-31 20:21:09 +0000663 // From: <rawc@users.sourceforge.net>
664 { "Nokia", 0x0421, "5310 XpressMusic", 0x006c, DEVICE_FLAG_NONE },
Linus Walleij21704fd2008-02-29 22:50:29 +0000665 // From: robin (AT) headbank D0Tco DOTuk
666 { "Nokia", 0x0421, "N95 Mobile Phone 8GB", 0x006e, DEVICE_FLAG_NONE },
Linus Walleijcfd143d2008-10-24 20:52:48 +0000667 // From Bastien Nocera <hadess@hadess.net>
Linus Walleije3388702010-02-03 10:02:13 +0000668 { "Nokia", 0x0421, "N82 Mobile Phone", 0x0074,
669 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijace7f4c2008-11-01 21:07:34 +0000670 // From Martijn van de Streek <martijn@vandestreek.net>
Linus Walleij4c8b6e12008-10-31 22:04:14 +0000671 { "Nokia", 0x0421, "N78 Mobile Phone", 0x0079, DEVICE_FLAG_NONE },
Linus Walleij22e4bfc2009-02-09 23:24:58 +0000672 // From William Pettersson <the_enigma@users.sourceforge.net>
673 { "Nokia", 0x0421, "6220 Classic", 0x008d, DEVICE_FLAG_NONE },
Linus Walleijbbf5e7f2009-03-05 21:04:42 +0000674 // From kellerkev@gmail.com
675 { "Nokia", 0x0421, "N85 Mobile Phone", 0x0092, DEVICE_FLAG_NONE },
Linus Walleij07bb5382008-07-31 20:21:09 +0000676 // From: danielw
677 { "Nokia", 0x0421, "E71", 0x00e4, DEVICE_FLAG_NONE },
Linus Walleijf3296622008-09-04 20:53:56 +0000678 // From: Laurent Bigonville <bigon@users.sourceforge.net>
679 { "Nokia", 0x0421, "E66", 0x00e5, DEVICE_FLAG_NONE },
Linus Walleij1d139362009-05-02 06:22:44 +0000680 // From: Pier <pierlucalino@users.sourceforge.net>
681 { "Nokia", 0x0421, "5320 XpressMusic", 0x00ea, DEVICE_FLAG_NONE },
Linus Walleij18faccb2009-08-03 20:21:55 +0000682 // From: Gausie <innerdreams@users.sourceforge.net>
Linus Walleije3388702010-02-03 10:02:13 +0000683 { "Nokia", 0x0421, "5800 XpressMusic", 0x0154,
684 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij79547002009-02-02 21:05:14 +0000685 // From: Willy Gardiol (web) <willy@gardiol.org>
Linus Walleijebf32cc2010-04-04 23:07:25 +0000686 // Spurious errors for getting all objects, lead me to believe
687 // this flag atleast is needed
Linus Walleije3388702010-02-03 10:02:13 +0000688 { "Nokia", 0x0421, "5800 XpressMusic v2", 0x0155,
689 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij5b4d8e02009-01-07 21:44:59 +0000690 // From an anonymous SourceForge user
691 // Not verified to be MTP
692 { "Nokia", 0x0421, "E63", 0x0179, DEVICE_FLAG_NONE },
Linus Walleijebf32cc2010-04-04 23:07:25 +0000693 // From an anonymous SourceForge user
694 { "Nokia", 0x0421, "E71x", 0x01a1, DEVICE_FLAG_NONE },
Linus Walleij99d390e2010-01-19 01:17:39 +0000695 // From: AxeL <axel__17@users.sourceforge.net>
696 { "Nokia", 0x0421, "N97-1", 0x01f4, DEVICE_FLAG_NONE },
Linus Walleij4fe08902009-08-03 20:27:27 +0000697 // From: FunkyPenguin <awafaa@users.sourceforge.net>
698 { "Nokia", 0x0421, "N97", 0x01f5, DEVICE_FLAG_NONE },
Linus Walleijc18f1aa2010-01-19 00:19:12 +0000699 // From: Anonymous SourceForge user
700 { "Nokia", 0x0421, "5130 XpressMusic", 0x0209, DEVICE_FLAG_NONE },
Linus Walleij5ffcec92009-09-03 21:16:36 +0000701 // From: Alexander Kojevnikov <alex-kay@users.sourceforge.net>
702 { "Nokia", 0x0421, "6600i", 0x0297, DEVICE_FLAG_NONE },
Linus Walleij89af6bb2009-04-06 22:02:51 +0000703 // https://sourceforge.net/tracker/index.php?func=detail&aid=2692473&group_id=8874&atid=358874
704 { "Nokia", 0x0421, "5200", 0x0421, DEVICE_FLAG_NONE },
Linus Walleij60144512008-10-25 19:11:48 +0000705 // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_3250_WMP10_driver.inf
706 { "Nokia", 0x0421, "3250 Mobile Phone", 0x0462, DEVICE_FLAG_NONE },
707 // From http://nds2.nokia.com/files/support/global/phones/software/Nokia_N93_WMP10_Driver.inf
708 { "Nokia", 0x0421, "N93 Mobile Phone", 0x0478, DEVICE_FLAG_NONE },
709 // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_5500_Sport_WMP10_driver.inf
710 { "Nokia", 0x0421, "5500 Sport Mobile Phone", 0x047e, DEVICE_FLAG_NONE },
711 // From http://nds2.nokia.com/files/support/global/phones/software/Nokia_N91_WMP10_Driver.inf
712 { "Nokia", 0x0421, "N91 Mobile Phone", 0x0485, DEVICE_FLAG_NONE },
Linus Walleij250ef742008-04-05 20:11:44 +0000713 // From: Christian Rusa <kristous@users.sourceforge.net>
714 { "Nokia", 0x0421, "5700 XpressMusic Mobile Phone", 0x04b4, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000715 // From: Mitchell Hicks <mitchix@yahoo.com>
716 { "Nokia", 0x0421, "5300 Mobile Phone", 0x04ba, DEVICE_FLAG_NONE },
717 // From Christian Arnold <webmaster@arctic-media.de>
718 { "Nokia", 0x0421, "N73 Mobile Phone", 0x04d1, DEVICE_FLAG_UNLOAD_DRIVER },
719 // From Swapan <swapan@yahoo.com>
720 { "Nokia", 0x0421, "N75 Mobile Phone", 0x04e1, DEVICE_FLAG_NONE },
Linus Walleij60144512008-10-25 19:11:48 +0000721 // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_N93i_WMP10_driver.inf
722 { "Nokia", 0x0421, "N93i Mobile Phone", 0x04e5, DEVICE_FLAG_NONE },
Linus Walleija6d0d482007-10-31 08:54:56 +0000723 // From Anonymous Sourceforge User
724 { "Nokia", 0x0421, "N95 Mobile Phone", 0x04ef, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000725 // From: Pat Nicholls <pat@patandannie.co.uk>
726 { "Nokia", 0x0421, "N80 Internet Edition (Media Player)", 0x04f1, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij67465c12009-08-23 21:56:26 +0000727 // Reported by Richard Wall <richard@the-moon.net>
728 { "Nokia", 0x05c6, "5530 Xpressmusic", 0x0229, DEVICE_FLAG_NONE },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000729 // Reported by anonymous SourceForge user
730 // One thing stated by reporter (Nokia model) another by the detect log...
731 { "Nokia/Verizon", 0x05c6, "6205 Balboa/Verizon Music Phone", 0x3196, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000732
Linus Walleija6d0d482007-10-31 08:54:56 +0000733
Linus Walleij1a673de2007-10-29 23:10:05 +0000734 /*
Linus Walleij83475632009-11-07 14:36:44 +0000735 * Vendor ID 0x13d1 is some offshoring company in China,
736 * in one source named "A-Max Technology Macao Commercial
737 * Offshore Co. Ltd." sometime "CCTech".
Linus Walleij1a673de2007-10-29 23:10:05 +0000738 */
Linus Walleij83475632009-11-07 14:36:44 +0000739 // Logik brand
Linus Walleij1a673de2007-10-29 23:10:05 +0000740 { "Logik", 0x13d1, "LOG DAX MP3 and DAB Player", 0x7002, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij83475632009-11-07 14:36:44 +0000741 // Technika brand
742 // Reported by <Ooblick@users.sourceforge.net>
743 { "Technika", 0x13d1, "MP-709", 0x7017, DEVICE_FLAG_UNLOAD_DRIVER },
744
Linus Walleij1a673de2007-10-29 23:10:05 +0000745
746 /*
747 * RCA / Thomson
748 */
749 // From kiki <omkiki@users.sourceforge.net>
750 { "Thomson", 0x069b, "EM28 Series", 0x0774, DEVICE_FLAG_NONE },
Richard Low957ffba2008-01-21 17:31:20 +0000751 { "Thomson / RCA", 0x069b, "Opal / Lyra MC4002", 0x0777, DEVICE_FLAG_NONE },
Linus Walleij01fc9c82009-03-10 23:52:09 +0000752 { "Thomson", 0x069b, "Lyra MC5104B (M51 Series)", 0x077c, DEVICE_FLAG_NONE },
Linus Walleij2c414c42008-01-19 07:11:19 +0000753 { "Thomson", 0x069b, "RCA H106", 0x301a, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000754 // From Svenna <svenna@svenna.de>
755 // Not confirmed to be MTP.
756 { "Thomson", 0x069b, "scenium E308", 0x3028, DEVICE_FLAG_NONE },
Richard Lowa11a6ad2008-01-21 17:23:55 +0000757 // From XNJB user
Richard Low957ffba2008-01-21 17:31:20 +0000758 { "Thomson / RCA", 0x069b, "Lyra HC308A", 0x3035, DEVICE_FLAG_NONE },
Linus Walleij2aa35742009-11-07 14:39:03 +0000759
Linus Walleij1a673de2007-10-29 23:10:05 +0000760 /*
761 * NTT DoCoMo
762 */
763 { "FOMA", 0x04c5, "F903iX HIGH-SPEED", 0x1140, DEVICE_FLAG_NONE },
764
765 /*
766 * Palm device userland program named Pocket Tunes
767 * Reported by Peter Gyongyosi <gyp@impulzus.com>
768 */
Linus Walleijfc438072008-10-31 21:12:43 +0000769 { "NormSoft, Inc.", 0x1703, "Pocket Tunes", 0x0001, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000770 // Reported by anonymous submission
Linus Walleijfc438072008-10-31 21:12:43 +0000771 { "NormSoft, Inc.", 0x1703, "Pocket Tunes 4", 0x0002, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000772
773 /*
Linus Walleijf6612032009-07-23 22:50:57 +0000774 * TrekStor, Medion and Maxfield devices
Linus Walleij1a673de2007-10-29 23:10:05 +0000775 * Their datasheet claims their devices are dualmode so probably needs to
776 * unload the attached drivers here.
777 */
778 // Reported by Stefan Voss <svoss@web.de>
Linus Walleij10b06d42007-11-05 11:32:07 +0000779 // This is a Sigmatel SoC with a hard disk.
Linus Walleijd866d242009-08-23 21:50:39 +0000780 { "TrekStor", 0x066f, "Vibez 8/12GB", 0x842a,
Linus Walleij07bb5382008-07-31 20:21:09 +0000781 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
782 // Reported by anonymous SourceForge user.
783 // This one done for Medion, whatever that is. Error reported so assume
784 // the same bug flag as its ancestor above.
785 { "Medion", 0x066f, "MD8333", 0x8550,
786 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijf6612032009-07-23 22:50:57 +0000787 // Reported by anonymous SourceForge user
Linus Walleijdc33ef92008-11-15 09:45:53 +0000788 { "Medion", 0x066f, "MD8333", 0x8588,
789 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijf6612032009-07-23 22:50:57 +0000790 // Reported by anonymous SourceForge user
791 { "Maxfield", 0x066f, "G-Flash NG 1GB", 0x846c,
792 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000793 // Reported by Cristi Magherusan <majeru@gentoo.ro>
Linus Walleijd866d242009-08-23 21:50:39 +0000794 { "TrekStor", 0x0402, "i.Beat Sweez FM", 0x0611,
795 DEVICE_FLAG_UNLOAD_DRIVER },
796 // Reported by Fox-ino <fox-ino@users.sourceforge.net>
797 { "ALi Corp.", 0x0402, "MPMAN 2GB", 0x5668,
Linus Walleij07bb5382008-07-31 20:21:09 +0000798 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij2a7c6c72009-05-19 22:33:43 +0000799 // Reported by Anonymous SourceForge user
800 {"TrekStor", 0x1e68, "i.Beat Organix 2.0", 0x0002,
801 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijd866d242009-08-23 21:50:39 +0000802
Linus Walleij1a673de2007-10-29 23:10:05 +0000803 /*
Linus Walleijf88b5a42009-04-20 22:36:41 +0000804 * Disney/Tevion/MyMusix
Linus Walleij1a673de2007-10-29 23:10:05 +0000805 */
806 // Reported by XNJB user
807 { "Disney", 0x0aa6, "MixMax", 0x6021, DEVICE_FLAG_NONE },
Linus Walleij21704fd2008-02-29 22:50:29 +0000808 // Reported by anonymous Sourceforge user
809 { "Tevion", 0x0aa6, "MD 81488", 0x3011, DEVICE_FLAG_NONE },
Linus Walleijf88b5a42009-04-20 22:36:41 +0000810 // Reported by Peter Hedlund <peter@peterandlinda.com>
811 { "MyMusix", 0x0aa6, "PD-6070", 0x9601, DEVICE_FLAG_UNLOAD_DRIVER |
812 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
813 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST |
814 DEVICE_FLAG_NO_RELEASE_INTERFACE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000815
816 /*
817 * Cowon Systems, Inc.
818 * The iAudio audiophile devices don't encourage the use of MTP.
819 */
820 // Reported by Patrik Johansson <Patrik.Johansson@qivalue.com>
Linus Walleij7e3b3072009-01-19 22:51:17 +0000821 { "Cowon", 0x0e21, "iAudio U3 (MTP mode)", 0x0701,
822 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijee387d72008-11-12 23:42:02 +0000823 // Reported by Kevin Michael Smith <hai-etlik@users.sourceforge.net>
Linus Walleij7e3b3072009-01-19 22:51:17 +0000824 { "Cowon", 0x0e21, "iAudio 6 (MTP mode)", 0x0711,
825 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000826 // Reported by Roberth Karman
Linus Walleij7e3b3072009-01-19 22:51:17 +0000827 { "Cowon", 0x0e21, "iAudio 7 (MTP mode)", 0x0751,
828 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000829 // Reported by an anonymous SourceForge user
Linus Walleij7e3b3072009-01-19 22:51:17 +0000830 { "Cowon", 0x0e21, "iAudio U5 (MTP mode)", 0x0761,
831 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000832 // Reported by TJ Something <tjbk_tjb@users.sourceforge.net>
Linus Walleij4a779562009-03-29 23:36:45 +0000833 { "Cowon", 0x0e21, "iAudio D2 (MTP mode)", 0x0801,
834 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijd09f65e2009-05-04 23:18:29 +0000835 // Reported by anonymous Sourceforge user
Linus Walleij18ed0162009-05-06 16:51:08 +0000836 { "Cowon", 0x0e21, "iAudio D2+ FW 2.x (MTP mode)", 0x0861,
837 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
838 // From Rockbox device listing
839 { "Cowon", 0x0e21, "iAudio D2+ DAB FW 4.x (MTP mode)", 0x0871,
840 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
841 // From Rockbox device listing
842 { "Cowon", 0x0e21, "iAudio D2+ FW 3.x (MTP mode)", 0x0881,
843 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
844 // From Rockbox device listing
845 { "Cowon", 0x0e21, "iAudio D2+ DMB FW 1.x (MTP mode)", 0x0891,
Linus Walleijd09f65e2009-05-04 23:18:29 +0000846 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij4a779562009-03-29 23:36:45 +0000847 // Reported by <twkonefal@users.sourceforge.net>
848 { "Cowon", 0x0e21, "iAudio S9 (MTP mode)", 0x0901,
Linus Walleij48946ff2009-06-24 08:15:39 +0000849 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij89bb1cd2009-07-24 21:03:36 +0000850 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_FLAC_IS_UNKNOWN },
Linus Walleij4d3618b2009-11-30 00:19:56 +0000851 // Reported by Dan Nicholson <dbn.lists@gmail.com>
852 { "Cowon", 0x0e21, "iAudio 9 (MTP mode)", 0x0911,
853 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000854
855 /*
856 * Insignia, dual-mode.
857 */
858 { "Insignia", 0x19ff, "NS-DV45", 0x0303, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij478ddb92007-11-26 21:01:29 +0000859 // Reported by Rajan Bella <rajanbella@yahoo.com>
860 { "Insignia", 0x19ff, "Sport Player", 0x0307, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000861 // Reported by "brad" (anonymous, sourceforge)
862 { "Insignia", 0x19ff, "Pilot 4GB", 0x0309, DEVICE_FLAG_UNLOAD_DRIVER },
863
864 /*
865 * LG Electronics
866 */
Linus Walleij1291ce02009-11-07 14:26:57 +0000867 // From anonymous SourceForge user
868 // Uncertain if this is really the MTP mode device ID...
869 { "LG Electronics Inc.", 0x043e, "T54", 0x7040,
870 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000871 // Not verified - anonymous submission
Linus Walleij7b4794f2008-08-13 13:17:17 +0000872 { "LG Electronics Inc.", 0x043e, "UP3", 0x70b1, DEVICE_FLAG_NONE },
873 // Reported by Joseph Nahmias <joe@nahimas.net>
874 { "LG Electronics Inc.", 0x1004, "VX8550 V CAST Mobile Phone", 0x6010,
875 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR },
Linus Walleij2242b022009-01-02 01:44:00 +0000876 // Reported by Cyrille Potereau <cyrille.potereau@wanadoo.fr>
877 { "LG Electronics Inc.", 0x1004, "KC910 Renoir Mobile Phone", 0x608f,
878 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij4e36ced2010-01-19 00:51:43 +0000879 // Reported by Aaron Slunt <tongle@users.sourceforge.net>
880 { "LG Electronics Inc.", 0x1004, "GR-500 Music Player", 0x611b,
881 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR },
Linus Walleij7fe2b4f2009-05-02 07:07:50 +0000882 // Reported by anonymous sourceforge user
883 { "LG Electronics Inc.", 0x1004, "KM900", 0x6132,
884 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000885
886 /*
887 * Sony
Linus Walleijbc3ed4d2008-01-03 13:54:23 +0000888 * It could be that these PIDs are one-per hundred series, so
889 * NWZ-A8xx is 0325, NWZ-S5xx is 0x326 etc. We need more devices
890 * reported to see a pattern here.
Linus Walleij1a673de2007-10-29 23:10:05 +0000891 */
Linus Walleija8ba8c72008-03-29 00:02:27 +0000892 // Reported by Alessandro Radaelli <alessandro.radaelli@aruba.it>
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000893 { "Sony", 0x054c, "Walkman NWZ-A815/NWZ-A818", 0x0325,
894 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000895 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
896 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij5d709a52007-12-28 21:37:17 +0000897 // Reported by anonymous Sourceforge user.
Linus Walleij46b909a2009-09-23 06:55:14 +0000898 { "Sony", 0x054c, "Walkman NWZ-S516", 0x0326,
899 DEVICE_FLAG_UNLOAD_DRIVER |
900 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
901 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij1a673de2007-10-29 23:10:05 +0000902 // Reported by Endre Oma <endre.88.oma@gmail.com>
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000903 { "Sony", 0x054c, "Walkman NWZ-S615F/NWZ-S616F/NWZ-S618F", 0x0327,
904 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000905 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
906 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij062ec7d2008-05-19 12:06:32 +0000907 // Reported by Jean-Marc Bourguet <jm@bourguet.org>
Linus Walleij46b909a2009-09-23 06:55:14 +0000908 { "Sony", 0x054c, "Walkman NWZ-S716F", 0x035a,
909 DEVICE_FLAG_UNLOAD_DRIVER |
910 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
911 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij0c98ce82008-05-25 11:08:36 +0000912 // Reported by Anon SF User / Anthon van der Neut <avanderneut@avid.com>
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000913 { "Sony", 0x054c, "Walkman NWZ-A826/NWZ-A828/NWZ-A829", 0x035b,
914 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000915 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
916 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleija8ba8c72008-03-29 00:02:27 +0000917 // Reported by Niek Klaverstijn <niekez@users.sourceforge.net>
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000918 { "Sony", 0x054c, "Walkman NWZ-A726/NWZ-A728/NWZ-A768", 0x035c,
919 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000920 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
921 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij45b843e2008-10-09 08:33:01 +0000922 // Reported by Mehdi AMINI <mehdi.amini - at - ulp.u-strasbg.fr>
Linus Walleij46b909a2009-09-23 06:55:14 +0000923 { "Sony", 0x054c, "Walkman NWZ-B135", 0x036e,
924 DEVICE_FLAG_UNLOAD_DRIVER |
925 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
926 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij2242b022009-01-02 01:44:00 +0000927 // Reported by <tiagoboldt@users.sourceforge.net>
Linus Walleij46b909a2009-09-23 06:55:14 +0000928 { "Sony", 0x054c, "Walkman NWZ-E436F", 0x0385,
929 DEVICE_FLAG_UNLOAD_DRIVER |
930 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
931 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij7fe2b4f2009-05-02 07:07:50 +0000932 // Reported by Michael Wilkinson
Linus Walleij46b909a2009-09-23 06:55:14 +0000933 { "Sony", 0x054c, "Walkman NWZ-W202", 0x0388,
934 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij094b4502009-09-22 22:28:33 +0000935 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
936 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij25a16302009-03-04 13:56:33 +0000937 // Reported by Ondrej Sury <ondrej@sury.org>
Linus Walleij46b909a2009-09-23 06:55:14 +0000938 { "Sony", 0x054c, "Walkman NWZ-S739F", 0x038c,
939 DEVICE_FLAG_UNLOAD_DRIVER |
940 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
941 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleijd8f1feb2008-10-08 09:16:42 +0000942 // Reported by Marco Filipe Nunes Soares Abrantes Pereira <marcopereira@ua.pt>
Linus Walleij46b909a2009-09-23 06:55:14 +0000943 { "Sony", 0x054c, "Walkman NWZ-S638F", 0x038e,
944 DEVICE_FLAG_UNLOAD_DRIVER |
945 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
946 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij0c6808e2009-07-23 22:44:38 +0000947 // Reported by Elliot <orwells@users.sourceforge.net>
Linus Walleij8d799eb2009-07-23 22:58:06 +0000948 { "Sony", 0x054c, "Walkman NWZ-X1050B/NWZ-X1060B",
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000949 0x0397, DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000950 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
951 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij8d799eb2009-07-23 22:58:06 +0000952 // Reported by Silvio J. Gutierrez <silviogutierrez@users.sourceforge.net>
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000953 { "Sony", 0x054c, "Walkman NWZ-X1051/NWZ-X1061", 0x0398,
954 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000955 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
956 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij2aa35742009-11-07 14:39:03 +0000957 // Reported by Gregory Boddin <gregory@siwhine.net>
958 { "Sony", 0x054c, "Walkman NWZ-B142F", 0x03d8,
959 DEVICE_FLAG_UNLOAD_DRIVER |
960 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
961 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij5e44ed52010-01-30 08:06:11 +0000962 // Reported by Jonathan Stowe <gellyfish@users.sourceforge.net>
963 { "Sony", 0x054c, "Walkman NWZ-E445", 0x03fd,
964 DEVICE_FLAG_UNLOAD_DRIVER |
965 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
966 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij99d390e2010-01-19 01:17:39 +0000967 // Reported by Anonymous SourceForge user
968 { "Sony", 0x054c, "Walkman NWZ-S545", 0x03fe,
969 DEVICE_FLAG_UNLOAD_DRIVER |
970 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
971 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleijd8f1feb2008-10-08 09:16:42 +0000972
Linus Walleij1a673de2007-10-29 23:10:05 +0000973
974 /*
Linus Walleijaa6b0192007-10-29 23:39:48 +0000975 * SonyEricsson
Linus Walleijc7756412008-10-21 14:24:24 +0000976 * These initially seemed to support GetObjPropList but later revisions
977 * of the firmware seem to have broken it, so all are flagged as broken
978 * for now.
Linus Walleijaa6b0192007-10-29 23:39:48 +0000979 */
Linus Walleijd866d242009-08-23 21:50:39 +0000980 // Reported by Thomas Schweitzer <thomas_-_s@users.sourceforge.net>
981 { "SonyEricsson", 0x0fce, "K550i", 0xe000, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijb3b29e72007-11-05 22:29:53 +0000982 // Reported by Øyvind Stegard <stegaro@users.sourceforge.net>
Linus Walleijc7756412008-10-21 14:24:24 +0000983 { "SonyEricsson", 0x0fce, "K850i", 0x0075, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijaa6b0192007-10-29 23:39:48 +0000984 // Reported by Michael Eriksson
Linus Walleijc7756412008-10-21 14:24:24 +0000985 { "SonyEricsson", 0x0fce, "W910", 0x0076, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijb5a4f922008-05-11 20:15:00 +0000986 // Reported by Zack <zackdvd@users.sourceforge.net>
Linus Walleijc7756412008-10-21 14:24:24 +0000987 { "SonyEricsson", 0x0fce, "W890i", 0x00b3, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000988 // Reported by robert dot ahlskog at gmail
Linus Walleijc7756412008-10-21 14:24:24 +0000989 { "SonyEricsson", 0x0fce, "W760i", 0x00c6, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000990 // Reported by Linus Åkesson <linusakesson@users.sourceforge.net>
Linus Walleijc7756412008-10-21 14:24:24 +0000991 { "SonyEricsson", 0x0fce, "C902", 0x00d4, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij07bb5382008-07-31 20:21:09 +0000992 // Reported by an anonymous SourceForge user
Linus Walleijc7756412008-10-21 14:24:24 +0000993 { "SonyEricsson", 0x0fce, "C702", 0x00d9, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijdb6da7c2008-10-16 18:46:34 +0000994 // Reported by Christian Zuckschwerdt <christian@zuckschwerdt.org>
Linus Walleijc7756412008-10-21 14:24:24 +0000995 { "SonyEricsson", 0x0fce, "W980", 0x00da, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij76edf7e2009-05-19 22:37:07 +0000996 // Reported by David Taylor <davidt-libmtp@yadt.co.uk>
997 { "SonyEricsson", 0x0fce, "C905", 0x00ef, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij4aa66dc2009-05-02 06:36:59 +0000998 // Reported by David House <dmhouse@users.sourceforge.net>
999 { "SonyEricsson", 0x0fce, "W595", 0x00f3,
Linus Walleijdab453b2009-05-26 20:55:58 +00001000 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL | DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleij2c34d432008-12-13 22:01:32 +00001001 // Reported by Mattias Evensson <mevensson@users.sourceforge.net>
1002 { "SonyEricsson", 0x0fce, "W902", 0x00f5, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij5ffcec92009-09-03 21:16:36 +00001003 // Reported by Sarunas <sarunas@users.sourceforge.net>
1004 // Doesn't need any flags according to reporter
Linus Walleij572cb972009-09-08 20:03:29 +00001005 { "SonyEricsson", 0x0fce, "T700", 0x00fb, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij4a779562009-03-29 23:36:45 +00001006 // Reported by Stéphane Pontier <shadow_walker@users.sourceforge.net>
Linus Walleijffffa272009-08-03 19:03:38 +00001007 { "SonyEricsson", 0x0fce, "W705/W715", 0x0105, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleije7ab9482009-07-23 23:50:51 +00001008 // Reported by Håkan Kvist
1009 { "SonyEricsson", 0x0fce, "W995", 0x0112, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
1010
Linus Walleijaa6b0192007-10-29 23:39:48 +00001011
1012 /*
Linus Walleij1a673de2007-10-29 23:10:05 +00001013 * Motorola
1014 * Assume DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST on all of these.
1015 */
Linus Walleij37c21662008-05-16 21:16:01 +00001016 // Reported by David Boyd <tiggrdave@users.sourceforge.net>
Linus Walleij351df602010-04-04 23:16:42 +00001017 { "Motorola", 0x22b8, "V3m/V750 verizon", 0x2a65,
1018 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST |
1019 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
1020 // Reported by anonymous user
1021 { "Motorola", 0x22b8, "Milestone / Verizon Droid", 0x41dc,
Richard Lowb58de742010-04-09 15:53:14 +00001022 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST |
1023 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST |
1024 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
1025 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +00001026 // Reported by Marcus Meissner to libptp2
1027 { "Motorola", 0x22b8, "K1", 0x4811, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
1028 // Reported by Hans-Joachim Baader <hjb@pro-linux.de> to libptp2
Linus Walleij351df602010-04-04 23:16:42 +00001029 { "Motorola", 0x22b8, "A1200", 0x60ca,
1030 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleijf0702982008-10-25 21:37:43 +00001031 // http://mark.cdmaforums.com/Files/Motdmmtp.inf
Linus Walleij351df602010-04-04 23:16:42 +00001032 { "Motorola", 0x22b8, "MTP Test Command Interface", 0x6413,
1033 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +00001034 // Reported by anonymous user
Linus Walleij351df602010-04-04 23:16:42 +00001035 { "Motorola", 0x22b8, "RAZR2 V8/U9/Z6", 0x6415,
1036 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleij37c21662008-05-16 21:16:01 +00001037
Linus Walleij1a673de2007-10-29 23:10:05 +00001038
1039 /*
Linus Walleij478ddb92007-11-26 21:01:29 +00001040 * Media Keg
1041 */
1042 // Reported by Rajan Bella <rajanbella@yahoo.com>
1043 { "Kenwood", 0x0b28, "Media Keg HD10GB7 Sport Player", 0x100c, DEVICE_FLAG_UNLOAD_DRIVER},
1044
Linus Walleij5d675112008-02-16 21:46:46 +00001045 /*
1046 * Micro-Star International (MSI)
1047 */
1048 // Reported by anonymous sourceforge user.
1049 { "Micro-Star International", 0x0db0, "P610/Model MS-5557", 0x5572, DEVICE_FLAG_NONE },
1050
Linus Walleijf044aa12008-03-22 21:45:19 +00001051 /*
1052 * FOMA
1053 */
1054 { "FOMA", 0x06d3, "D905i", 0x21ba, DEVICE_FLAG_NONE },
Linus Walleij166c8ff2008-01-14 23:15:08 +00001055
Linus Walleij478ddb92007-11-26 21:01:29 +00001056 /*
Linus Walleijb5a4f922008-05-11 20:15:00 +00001057 * Haier
1058 */
1059 // Both reported by an anonymous SourceForge user
1060 // This is the 30 GiB model
1061 { "Haier", 0x1302, "Ibiza Rhapsody", 0x1016, DEVICE_FLAG_NONE },
1062 // This is the 4/8 GiB model
1063 { "Haier", 0x1302, "Ibiza Rhapsody", 0x1017, DEVICE_FLAG_NONE },
Linus Walleij5e44ed52010-01-30 08:06:11 +00001064
Richard Low4d93a992008-09-07 12:52:14 +00001065 /*
1066 * Panasonic
1067 */
1068 // Reported by dmizer
1069 { "Panasonic", 0x04da, "P905i", 0x2145, DEVICE_FLAG_NONE },
Linus Walleij5e44ed52010-01-30 08:06:11 +00001070 // Reported by Taku
1071 { "Panasonic", 0x04da, "P906i", 0x2158, DEVICE_FLAG_NONE },
Linus Walleijb5a4f922008-05-11 20:15:00 +00001072
1073 /*
Linus Walleij80a2a692008-12-05 20:36:40 +00001074 * Polaroid
1075 */
1076 { "Polaroid", 0x0546, "Freescape/MPU-433158", 0x2035, DEVICE_FLAG_NONE },
1077
1078 /*
Linus Walleij2242b022009-01-02 01:44:00 +00001079 * Pioneer
1080 */
1081 // Reported by Dan Allen <dan.j.allen@gmail.com>
1082 { "Pioneer", 0x08e4, "XMP3", 0x0148, DEVICE_FLAG_NONE },
1083
1084 /*
Linus Walleij4096c882009-03-16 23:32:34 +00001085 * Slacker Inc.
1086 * Put in all evilness flags because it looks fragile.
1087 */
1088 // Reported by Pug Fantus <pugfantus@users.sourceforge.net>
1089 { "Slacker Inc.", 0x1bdc, "Slacker Portable Media Player", 0xfabf,
1090 DEVICE_FLAG_BROKEN_BATTERY_LEVEL | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1091 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
1092
Linus Walleij6e3997e2009-04-12 23:40:40 +00001093 // Reported by Demadridsur <demadridsur@gmail.com>
1094 { "O2 Sistemas", 0x1e53, "ZoltarTV", 0x0006, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
1095
Linus Walleij6fb9a5f2009-09-12 06:25:17 +00001096 // Reported by Sense Hofstede <qense@users.sourceforge.net>
1097 { "Perception Digital, Ltd", 0x0aa6, "Gigaware GX400", 0x9702, DEVICE_FLAG_NONE },
Linus Walleij5f3c44b2009-09-12 21:03:06 +00001098
1099 /*
Linus Walleijc18f1aa2010-01-19 00:19:12 +00001100 * RIM's BlackBerry
Linus Walleij5f3c44b2009-09-12 21:03:06 +00001101 */
1102 // Reported by Nicolas VIVIEN <nicolas@vivien.fr>
Linus Walleijfea4f532009-09-22 22:08:35 +00001103 { "RIM", 0x0fca, "BlackBerry Storm", 0x8007, DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleijcea83ff2009-09-25 21:44:38 +00001104 DEVICE_FLAG_SWITCH_MODE_BLACKBERRY | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij5f3c44b2009-09-12 21:03:06 +00001105
Linus Walleij4096c882009-03-16 23:32:34 +00001106 /*
Linus Walleij99d390e2010-01-19 01:17:39 +00001107 * Nextar
1108 */
1109 { "Nextar", 0x0402, "MA715A-8R", 0x5668 },
1110
1111 /*
Linus Walleij1a673de2007-10-29 23:10:05 +00001112 * Other strange stuff.
1113 */
1114 { "Isabella", 0x0b20, "Her Prototype", 0xddee, DEVICE_FLAG_NONE }