blob: 94773b70f4c4f143c942e20c9fb2558a5bc1ec93 [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 Walleij2242b022009-01-02 01:44:00 +00006 * Copyright (C) 2005-2009 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 Walleijca8b20a2008-08-14 07:02:16 +0000107 // From Gabriel Nunes <gabrielkm1@yahoo.com.br>
108 { "Samsung", 0x04e8, "YH-920 (501d)", 0x501d, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000109 // From Soren O'Neill
Linus Walleijca8b20a2008-08-14 07:02:16 +0000110 { "Samsung", 0x04e8, "YH-920 (5022)", 0x5022, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000111 // Contributed by aronvanammers on SourceForge
112 { "Samsung", 0x04e8, "YH-925GS", 0x5024, DEVICE_FLAG_NONE },
113 // From libgphoto2, according to tests by Stephan Fabel it cannot
114 // get all objects with the getobjectproplist command..
115 { "Samsung", 0x04e8, "YH-820", 0x502e, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
116 // Contributed by polux2001@users.sourceforge.net
Linus Walleijca8b20a2008-08-14 07:02:16 +0000117 { "Samsung", 0x04e8, "YH-925(-GS)", 0x502f, DEVICE_FLAG_UNLOAD_DRIVER |
118 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000119 // Contributed by anonymous person on SourceForge
120 { "Samsung", 0x04e8, "YH-J70J", 0x5033, DEVICE_FLAG_UNLOAD_DRIVER },
121 // From XNJB user
Linus Walleijf3c44052008-08-16 21:14:56 +0000122 // Guessing on .spl flag
123 { "Samsung", 0x04e8, "YP-Z5", 0x503c, DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Richard Lowef197312008-11-01 18:29:41 +0000124 // Don't add 0x5041 as this is YP-Z5 in USB mode
Linus Walleij1a673de2007-10-29 23:10:05 +0000125 // Contributed by anonymous person on SourceForge
Linus Walleij84072342009-06-24 08:08:26 +0000126 { "Samsung", 0x04e8, "YP-T7J", 0x5047, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000127 // Reported by cstrickler@gmail.com
128 { "Samsung", 0x04e8, "YP-U2J (YP-U2JXB/XAA)", 0x5054, DEVICE_FLAG_UNLOAD_DRIVER },
129 // Reported by Andrew Benson
130 { "Samsung", 0x04e8, "YP-F2J", 0x5057, DEVICE_FLAG_UNLOAD_DRIVER },
131 // Reported by Patrick <skibler@gmail.com>
Linus Walleijf3c44052008-08-16 21:14:56 +0000132 // Just guessing but looks like .spl v1 http://www.anythingbutipod.com/forum/showthread.php?t=14160
Linus Walleij84072342009-06-24 08:08:26 +0000133 { "Samsung", 0x04e8, "YP-K5", 0x505a, DEVICE_FLAG_UNLOAD_DRIVER |
134 DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij10796872007-12-28 22:56:02 +0000135 // From dev.local@gmail.com - 0x4e8/0x507c is the UMS mode, apparently
Linus Walleij23ab1542008-01-06 22:10:34 +0000136 // do not add that device.
Linus Walleij1a673de2007-10-29 23:10:05 +0000137 // From m.eik michalke
Linus Walleije9b4e912008-11-30 00:09:17 +0000138 // This device does NOT use the special SPL playlist according to sypqgjxu@gmx.de.
Linus Walleij84072342009-06-24 08:08:26 +0000139 { "Samsung", 0x04e8, "YP-U3", 0x507d, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000140 // Reported by Matthew Wilcox <matthew@wil.cx>
Linus Walleijb1058e02008-05-21 00:01:16 +0000141 // Sergio <sfrdll@tiscali.it> reports this device need the BROKEN ALL flag.
Linus Walleijf3c44052008-08-16 21:14:56 +0000142 // Guessing on .spl flag
Linus Walleij84072342009-06-24 08:08:26 +0000143 { "Samsung", 0x04e8, "YP-T9", 0x507f, DEVICE_FLAG_UNLOAD_DRIVER |
144 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij1a673de2007-10-29 23:10:05 +0000145 // From Paul Clinch
Linus Walleijf3c44052008-08-16 21:14:56 +0000146 // Just guessing but looks like .spl v1 http://www.anythingbutipod.com/forum/showthread.php?t=14160
Linus Walleij1e0eba72009-02-21 07:26:29 +0000147 // Some versions of the firmware reportedly support OGG, reportedly only the
148 // UMS versions, so MTP+OGG is not possible on this device.
Linus Walleij84072342009-06-24 08:08:26 +0000149 { "Samsung", 0x04e8, "YP-K3", 0x5081, DEVICE_FLAG_UNLOAD_DRIVER |
150 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Richard Low6a2f3b82007-11-04 18:39:17 +0000151 // From XNJB user
Linus Walleijf3c44052008-08-16 21:14:56 +0000152 // From Alistair Boyle, .spl v2 required for playlists
Linus Walleijd4157be2009-02-21 07:23:26 +0000153 // According to the device log it properly supports OGG
Linus Walleij84072342009-06-24 08:08:26 +0000154 { "Samsung", 0x04e8, "YP-P2", 0x5083, DEVICE_FLAG_UNLOAD_DRIVER |
155 DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_PLAYLIST_SPL_V2 },
Linus Walleij5a6bcf72007-10-31 20:52:42 +0000156 // From Paul Clinch
Linus Walleijf3c44052008-08-16 21:14:56 +0000157 // Guessing on .spl flag
Linus Walleij84072342009-06-24 08:08:26 +0000158 { "Samsung", 0x04e8, "YP-T10", 0x508a, DEVICE_FLAG_UNLOAD_DRIVER |
159 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
160 DEVICE_FLAG_PLAYLIST_SPL_V1 | DEVICE_FLAG_NO_ZERO_READS },
Linus Walleij4b43bbf2008-04-07 09:16:44 +0000161 // From Wim Verwimp <wimverwimp@gmail.com>
162 // Not sure about the Ogg and broken proplist flags here. Just guessing.
Linus Walleijf3c44052008-08-16 21:14:56 +0000163 // Guessing on .spl flag
Linus Walleij84072342009-06-24 08:08:26 +0000164 { "Samsung", 0x04e8, "YP-S5", 0x508b, DEVICE_FLAG_UNLOAD_DRIVER |
165 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
166 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij07bb5382008-07-31 20:21:09 +0000167 // From Ludovic Danigo
Linus Walleijf3c44052008-08-16 21:14:56 +0000168 // Guessing on .spl flag
Linus Walleij84072342009-06-24 08:08:26 +0000169 { "Samsung", 0x04e8, "YP-S3", 0x5091, DEVICE_FLAG_UNLOAD_DRIVER |
170 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
171 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij2288a6a2009-01-27 21:16:38 +0000172 // From Adrian Levi <adrian.levi@gmail.com>
173 // Guessing on .spl flag
Linus Walleijd4157be2009-02-21 07:23:26 +0000174 // This one supports OGG properly through the correct MTP type.
Linus Walleij84072342009-06-24 08:08:26 +0000175 { "Samsung", 0x04e8, "YP-U4", 0x5093, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij2b8c8492008-12-12 00:16:48 +0000176 // From Anonymous SourceForge user, NOT VERIFIED TO BE MTP
177 // Guessing on .spl flag
Linus Walleij84072342009-06-24 08:08:26 +0000178 { "Samsung", 0x04e8, "YP-Q1", 0x5115, DEVICE_FLAG_UNLOAD_DRIVER |
179 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
180 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleijb49a9f72009-05-14 20:46:07 +0000181 // From Anonymous SourceForge user
182 // Guessing on .spl flag
Linus Walleij84072342009-06-24 08:08:26 +0000183 { "Samsung", 0x04e8, "YP-P3", 0x511a, DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleijb49a9f72009-05-14 20:46:07 +0000184 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
185 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij316628c2009-06-15 19:55:41 +0000186 // From Anonymous SourceForge user
187 // Guessing on .spl flag
Linus Walleij84072342009-06-24 08:08:26 +0000188 { "Samsung", 0x04e8, "YP-Q2", 0x511d, DEVICE_FLAG_UNLOAD_DRIVER |
189 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
190 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij41e94cf2009-05-19 22:44:53 +0000191 // From Marco Pizzocaro <mpizzocaro@users.sourceforge.net>
192 // Guessing on .spl flag
193 { "Samsung", 0x04e8, "YP-U5", 0x5121,
194 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleijc2cdbfc2009-11-20 21:28:17 +0000195 // From Leonardo Accorsi <laccorsi@users.sourceforge.net>
196 // Guessing on .spl flag
197 { "Samsung", 0x04e8, "YP-R0", 0x5125,
198 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij1a673de2007-10-29 23:10:05 +0000199 // From a rouge .INF file,
Linus Walleij23ab1542008-01-06 22:10:34 +0000200 // this device ID seems to have been recycled for:
201 // the Samsung SGH-A707 Cingular cellphone
202 // the Samsung L760-V cellphone
Linus Walleij5b03d302008-11-25 20:39:27 +0000203 // the Samsung SGH-U900 cellphone
Linus Walleijc1a82f12009-11-30 00:06:28 +0000204 { "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 +0000205 // From Santi Béjar <sbejar@gmail.com> - not sure this is MTP...
206 // { "Samsung", 0x04e8, "Z170 Mobile Phone", 0x6601, DEVICE_FLAG_UNLOAD_DRIVER },
207 // From Santi Béjar <sbejar@gmail.com> - not sure this is MTP...
208 // { "Samsung", 0x04e8, "E250 Mobile Phone", 0x663e, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000209 // From Lionel Bouton
Linus Walleij84072342009-06-24 08:08:26 +0000210 { "Samsung", 0x04e8, "X830 Mobile Phone", 0x6702, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000211 // From James <jamestech@gmail.com>
212 { "Samsung", 0x04e8, "U600 Mobile Phone", 0x6709, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij5b03d302008-11-25 20:39:27 +0000213 // From Cesar Cardoso <cesar@cesarcardoso.tk>
214 // No confirmation that this is really MTP.
215 { "Samsung", 0x04e8, "F250 Mobile Phone", 0x6727, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijc50e7682007-11-02 00:01:17 +0000216 // From Charlie Todd 2007-10-31
217 { "Samsung", 0x04e8, "Juke (SCH-U470)", 0x6734, DEVICE_FLAG_UNLOAD_DRIVER},
Linus Walleij34b421f2009-07-23 22:30:51 +0000218 // Reported by Tenn
219 { "Samsung", 0x04e8, "GT-B2700", 0x6752, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij5f0814f2009-07-23 21:53:38 +0000220 // Added by Greg Fitzgerald <netzdamon@gmail.com>
221 { "Samsung", 0x04e8, "SAMSUNG Trance", 0x6763, DEVICE_FLAG_UNLOAD_DRIVER |
222 DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleijd866d242009-08-23 21:50:39 +0000223 // From anonymous Sourceforge user
224 { "Samsung", 0x04e8, "GT-S5230", 0xe20c, DEVICE_FLAG_NONE },
225
Linus Walleij1a673de2007-10-29 23:10:05 +0000226
227 /*
Linus Walleij414a0832009-09-18 23:04:05 +0000228 * Microsoft & Intel
Linus Walleij1a673de2007-10-29 23:10:05 +0000229 */
230 { "Intel", 0x045e, "Bandon Portable Media Center", 0x00c9, DEVICE_FLAG_NONE },
Linus Walleij414aca02008-06-02 23:16:49 +0000231 // Reported by Tadimarri Sarath <sarath.tadi@gmail.com>
232 // No idea why this use an Intel PID, perhaps a leftover from
233 // the early PMC development days when Intel and Microsoft were
234 // partnering.
235 { "Microsoft", 0x045e, "Windows MTP Simulator", 0x0622, DEVICE_FLAG_NONE },
Linus Walleij414a0832009-09-18 23:04:05 +0000236 // Reported by Edward Hutchins (used for Zune HDs)
237 { "Microsoft", 0x045e, "Zune HD", 0x063e, DEVICE_FLAG_NONE },
238 // Reported by Farooq Zaman (used for all Zunes)
239 { "Microsoft", 0x045e, "Zune", 0x0710, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000240
241 /*
242 * JVC
243 */
244 // From Mark Veinot
245 { "JVC", 0x04f1, "Alneo XA-HD500", 0x6105, DEVICE_FLAG_NONE },
246
247 /*
248 * Philips
249 */
250 { "Philips", 0x0471, "HDD6320/00 or HDD6330/17", 0x014b, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
251 // Anonymous SourceForge user
Linus Walleijf0702982008-10-25 21:37:43 +0000252 { "Philips", 0x0471, "HDD14XX,HDD1620 or HDD1630/17", 0x014c, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000253 // from discussion forum
254 { "Philips", 0x0471, "HDD085/00 or HDD082/17", 0x014d, DEVICE_FLAG_NONE },
255 // from XNJB forum
Richard Low641d1e32008-02-24 20:47:20 +0000256 { "Philips", 0x0471, "GoGear SA9200", 0x014f, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000257 // From John Coppens <jcoppens@users.sourceforge.net>
258 { "Philips", 0x0471, "SA1115/55", 0x0164, DEVICE_FLAG_NONE },
259 // From Gerhard Mekenkamp
260 { "Philips", 0x0471, "GoGear Audio", 0x0165, DEVICE_FLAG_NONE },
261 // from David Holm <wormie@alberg.dk>
262 { "Philips", 0x0471, "Shoqbox", 0x0172, DEVICE_FLAG_ONLY_7BIT_FILENAMES },
263 // from npedrosa
264 { "Philips", 0x0471, "PSA610", 0x0181, DEVICE_FLAG_NONE },
265 // From libgphoto2 source
266 { "Philips", 0x0471, "HDD6320", 0x01eb, DEVICE_FLAG_NONE },
267 // From Detlef Meier <dm@emlix.com>
Linus Walleija8ba8c72008-03-29 00:02:27 +0000268 { "Philips", 0x0471, "GoGear SA6014/SA6015/SA6024/SA6025/SA6044/SA6045", 0x084e, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij23ab1542008-01-06 22:10:34 +0000269 // From anonymous Sourceforge user SA5145/02
Linus Walleija8ba8c72008-03-29 00:02:27 +0000270 { "Philips", 0x0471, "GoGear SA5145", 0x0857, DEVICE_FLAG_UNLOAD_DRIVER },
271 // From a
272 { "Philips", 0x0471, "GoGear SA6125/SA6145/SA6185", 0x2002, DEVICE_FLAG_UNLOAD_DRIVER },
273 // From anonymous Sourceforge user, not verified to be MTP!
274 { "Philips", 0x0471, "GoGear SA3345", 0x2004, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij2242b022009-01-02 01:44:00 +0000275 // From Roberto Vidmar <rvidmar@libero.it>
276 { "Philips", 0x0471, "SA5285", 0x2022, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij15ed3b32009-07-23 22:19:43 +0000277 // From Elie De Brauwer <elie@de-brauwer.be>
278 { "Philips", 0x0471, "GoGear ViBE SA1VBE04", 0x2075,
279 DEVICE_FLAG_UNLOAD_DRIVER },
280 // From Elie De Brauwer <elie@de-brauwer.be>
281 { "Philips", 0x0471, "GoGear ViBE SA1VBE08", 0x207b,
282 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijd866d242009-08-23 21:50:39 +0000283 // From josmtx <josmtx@users.sourceforge.net>
284 { "Philips", 0x0471, "GoGear Aria", 0x207c,
285 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000286 // from XNJB user
287 { "Philips", 0x0471, "PSA235", 0x7e01, DEVICE_FLAG_NONE },
288
289
290 /*
291 * SanDisk
292 * several devices (c150 for sure) are definately dual-mode and must
293 * have the USB mass storage driver that hooks them unloaded first.
294 * They all have problematic dual-mode making the device unload effect
Linus Walleij5e202562008-06-03 11:35:05 +0000295 * uncertain on these devices.
296 *
297 * All older devices seem to need DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL.
298 * Old chipsets: e200/c200 use PP5024 from Nvidia (formerly PortalPlayer).
299 * m200 use TCC770 from Telechips.
300 *
301 * The newer Sansa v2 chipset, AD3525 from Austriamicrosystems (AMS) found
302 * in e280 v2 c200 v2, Clip, Fuze etc require DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST
303 * and DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR to work properly.
304 *
305 * For more info see: http://daniel.haxx.se/sansa/v2.html
Linus Walleij1a673de2007-10-29 23:10:05 +0000306 */
307 // Reported by Brian Robison
Linus Walleijde1620f2009-06-15 20:02:02 +0000308 { "SanDisk", 0x0781, "Sansa m230/m240", 0x7400,
Linus Walleij1a673de2007-10-29 23:10:05 +0000309 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000310 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij18ed0162009-05-06 16:51:08 +0000311 // From Rockbox device listing
Linus Walleijde1620f2009-06-15 20:02:02 +0000312 { "SanDisk", 0x0781, "Sansa m200-tcc (MTP mode)", 0x7401,
Linus Walleij18ed0162009-05-06 16:51:08 +0000313 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
314 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000315 // Reported by tangent_@users.sourceforge.net
Linus Walleijde1620f2009-06-15 20:02:02 +0000316 { "SanDisk", 0x0781, "Sansa c150", 0x7410,
Linus Walleij1a673de2007-10-29 23:10:05 +0000317 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000318 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000319 // From libgphoto2 source
320 // Reported by <gonkflea@users.sourceforge.net>
321 // Reported by Mike Owen <mikeowen@computerbaseusa.com>
Linus Walleij18ed0162009-05-06 16:51:08 +0000322 { "SanDisk", 0x0781, "Sansa e200/e250/e260/e270/e280", 0x7420,
Linus Walleij1a673de2007-10-29 23:10:05 +0000323 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000324 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Richard Low58f5afe2009-04-30 13:24:06 +0000325 // Don't add 0x7421 as this is e280 in MSC mode
Linus Walleij1a673de2007-10-29 23:10:05 +0000326 // Reported by XNJB user
Linus Walleij18ed0162009-05-06 16:51:08 +0000327 { "SanDisk", 0x0781, "Sansa e260/e280 v2", 0x7422,
Linus Walleij5e202562008-06-03 11:35:05 +0000328 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij37588142008-10-16 19:10:47 +0000329 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000330 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Richard Lowd56e8a62007-12-08 16:59:11 +0000331 // Reported by XNJB user
Linus Walleijde1620f2009-06-15 20:02:02 +0000332 { "SanDisk", 0x0781, "Sansa m240/m250", 0x7430,
Linus Walleij1a673de2007-10-29 23:10:05 +0000333 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000334 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij077a8902007-11-15 21:18:12 +0000335 // Reported by Eugene Brevdo <ebrevdo@princeton.edu>
Linus Walleij5e202562008-06-03 11:35:05 +0000336 { "SanDisk", 0x0781, "Sansa Clip", 0x7432,
337 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij37588142008-10-16 19:10:47 +0000338 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000339 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
Linus Walleij39f9a452008-11-15 09:39:39 +0000340 // Reported by HackAR <hackar@users.sourceforge.net>
Linus Walleij624a15a2009-01-06 00:31:34 +0000341 { "SanDisk", 0x0781, "Sansa Clip v2", 0x7434,
Linus Walleij39f9a452008-11-15 09:39:39 +0000342 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
343 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
344 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
Linus Walleij1a673de2007-10-29 23:10:05 +0000345 // Reported by anonymous user at sourceforge.net
Linus Walleijde1620f2009-06-15 20:02:02 +0000346 { "SanDisk", 0x0781, "Sansa c240/c250", 0x7450,
Linus Walleij1a673de2007-10-29 23:10:05 +0000347 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000348 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij2242b022009-01-02 01:44:00 +0000349 // Reported by anonymous SourceForge user
Linus Walleijde1620f2009-06-15 20:02:02 +0000350 { "SanDisk", 0x0781, "Sansa c250 v2", 0x7452,
Linus Walleij2242b022009-01-02 01:44:00 +0000351 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
352 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000353 // Reported by Troy Curtis Jr.
Linus Walleijde1620f2009-06-15 20:02:02 +0000354 { "SanDisk", 0x0781, "Sansa Express", 0x7460,
355 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000356 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000357 // Reported by XNJB user, and Miguel de Icaza <miguel@gnome.org>
358 // This has no dual-mode so no need to unload any driver.
359 // This is a Linux based device!
360 { "SanDisk", 0x0781, "Sansa Connect", 0x7480, DEVICE_FLAG_NONE },
361 // Reported by anonymous SourceForge user
Linus Walleijde1620f2009-06-15 20:02:02 +0000362 { "SanDisk", 0x0781, "Sansa View", 0x74b0,
Linus Walleij1a673de2007-10-29 23:10:05 +0000363 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000364 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij690a3162008-03-31 21:40:23 +0000365 // Reported by Patrick <skibler@gmail.com>
366 // There are apparently problems with this device.
Linus Walleij25a16302009-03-04 13:56:33 +0000367 { "SanDisk", 0x0781, "Sansa Fuze", 0x74c0,
368 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
369 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
370 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
371 // Harry Phillips <tuxcomputers@users.sourceforge.net>
372 { "SanDisk", 0x0781, "Sansa Fuze v2", 0x74c2,
Linus Walleij5e202562008-06-03 11:35:05 +0000373 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij37588142008-10-16 19:10:47 +0000374 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000375 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleija5cb5c92009-10-10 22:03:38 +0000376 // Reported by anonymous SourceForge user
377 { "SanDisk", 0x0781, "Sansa Clip+", 0x74d0,
378 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
379 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
380 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
381
Linus Walleij1a673de2007-10-29 23:10:05 +0000382
383 /*
384 * iRiver
385 * we assume that PTP_OC_MTP_GetObjPropList is essentially
386 * broken on all iRiver devices, meaning it simply won't return
387 * all properties for a file when asking for metadata 0xffffffff.
388 * Please test on your device if you believe it isn't broken!
Linus Walleij1a673de2007-10-29 23:10:05 +0000389 */
Linus Walleij18ed0162009-05-06 16:51:08 +0000390 { "iRiver", 0x1006, "H300 Series MTP", 0x3004,
Linus Walleij1a673de2007-10-29 23:10:05 +0000391 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
392 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij18ed0162009-05-06 16:51:08 +0000393 { "iRiver", 0x1006, "Portable Media Center", 0x4002,
394 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
395 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
396 { "iRiver", 0x1006, "Portable Media Center", 0x4003,
Linus Walleij1a673de2007-10-29 23:10:05 +0000397 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
398 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij2242b022009-01-02 01:44:00 +0000399 // From [st]anislav <iamstanislav@gmail.com>
Linus Walleijdeb1aca2009-01-02 23:20:06 +0000400 { "iRiver", 0x1042, "T7 Volcano", 0x1143, DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij80a2a692008-12-05 20:36:40 +0000401 // From an anonymous person at SourceForge, uncertain about this one
Linus Walleij1a673de2007-10-29 23:10:05 +0000402 { "iRiver", 0x4102, "iFP-880", 0x1008,
403 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
404 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij80a2a692008-12-05 20:36:40 +0000405 // 0x4102, 0x1042 is a USB mass storage mode for E100 v2/Lplayer
Linus Walleij1a673de2007-10-29 23:10:05 +0000406 // From libgphoto2 source
407 { "iRiver", 0x4102, "T10", 0x1113,
408 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
409 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
410 { "iRiver", 0x4102, "T20 FM", 0x1114,
411 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
412 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
413 // This appears at the MTP-UMS site
414 { "iRiver", 0x4102, "T20", 0x1115,
415 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
416 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
417 { "iRiver", 0x4102, "U10", 0x1116,
418 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
419 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleijfcd4d372007-11-18 21:56:32 +0000420 { "iRiver", 0x4102, "T10a", 0x1117,
Linus Walleij1a673de2007-10-29 23:10:05 +0000421 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
422 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
423 { "iRiver", 0x4102, "T20", 0x1118,
424 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
425 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
426 { "iRiver", 0x4102, "T30", 0x1119,
427 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
428 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
429 // Reported by David Wolpoff
430 { "iRiver", 0x4102, "T10 2GB", 0x1120,
431 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
432 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
433 // Rough guess this is the MTP device ID...
434 { "iRiver", 0x4102, "N12", 0x1122,
435 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
436 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
437 // Reported by Philip Antoniades <philip@mysql.com>
438 // Newer iriver devices seem to have shaped-up firmware without any
439 // of the annoying bugs.
440 { "iRiver", 0x4102, "Clix2", 0x1126, DEVICE_FLAG_NONE },
441 // Reported by Adam Torgerson
442 { "iRiver", 0x4102, "Clix", 0x112a,
443 DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
444 // Reported by Douglas Roth <dougaus@gmail.com>
445 { "iRiver", 0x4102, "X20", 0x1132,
446 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
447 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
448 // Reported by Robert Ugo <robert_ugo@users.sourceforge.net>
449 { "iRiver", 0x4102, "T60", 0x1134,
450 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
451 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000452 // Reported by two anonymous SourceForge users
Linus Walleij07bb5382008-07-31 20:21:09 +0000453 // Needs the stronger OGG_IS_UNKNOWN flag to support OGG properly,
454 // be aware of newer players that may be needing this too.
Linus Walleijf8c251e2008-06-08 21:32:01 +0000455 { "iRiver", 0x4102, "E100", 0x1141,
456 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij07bb5382008-07-31 20:21:09 +0000457 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000458 // Reported by anonymous SourceForge user
459 // Need verification of whether this firmware really need all these flags
Linus Walleij80a2a692008-12-05 20:36:40 +0000460 { "iRiver", 0x4102, "E100 v2/Lplayer", 0x1142,
Linus Walleijc2bc9732008-08-14 21:12:44 +0000461 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
462 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij6e680ad2009-01-07 21:22:45 +0000463 // Reported by Richard Vennemann <vennemann@users.sourceforge.net>
Linus Walleij16ee3422009-01-08 23:15:52 +0000464 // In USB Mass Storage mode it is 0x4102/0x1047
Linus Walleijb57167c2009-01-10 22:37:51 +0000465 // Seems to use the new shaped-up firmware.
466 { "iRiver", 0x4102, "Spinn", 0x1147, DEVICE_FLAG_NONE },
Linus Walleije84dcf12009-05-14 20:33:05 +0000467 // Reported by Tony Janssen <tonyjanssen@users.sourceforge.net>
468 { "iRiver", 0x4102, "E50", 0x1151,
469 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
470 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +0000471 // Reported by Scott Call
Linus Walleij07bb5382008-07-31 20:21:09 +0000472 // Assume this actually supports OGG though it reports it doesn't.
Linus Walleij1a673de2007-10-29 23:10:05 +0000473 { "iRiver", 0x4102, "H10 20GB", 0x2101,
474 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij07bb5382008-07-31 20:21:09 +0000475 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij18ed0162009-05-06 16:51:08 +0000476 { "iRiver", 0x4102, "H10 5GB", 0x2102,
477 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
478 DEVICE_FLAG_OGG_IS_UNKNOWN },
479 // From Rockbox device listing
480 { "iRiver", 0x4102, "H10 5.6GB", 0x2105,
Linus Walleij1a673de2007-10-29 23:10:05 +0000481 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij07bb5382008-07-31 20:21:09 +0000482 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +0000483
484
485 /*
486 * Dell
487 */
488 { "Dell, Inc", 0x413c, "DJ Itty", 0x4500, DEVICE_FLAG_NONE },
489
490 /*
491 * Toshiba
Linus Walleij7e3b3072009-01-19 22:51:17 +0000492 * Tentatively flagged all Toshiba devices with
493 * DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST after one of them
494 * showed erroneous behaviour.
Linus Walleij1a673de2007-10-29 23:10:05 +0000495 */
Linus Walleij7e3b3072009-01-19 22:51:17 +0000496 { "Toshiba", 0x0930, "Gigabeat MEGF-40", 0x0009,
497 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
498 { "Toshiba", 0x0930, "Gigabeat", 0x000c,
499 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000500 // Reported by Nicholas Tripp
Linus Walleij7e3b3072009-01-19 22:51:17 +0000501 { "Toshiba", 0x0930, "Gigabeat P20", 0x000f,
502 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000503 // From libgphoto2
Linus Walleij7e3b3072009-01-19 22:51:17 +0000504 { "Toshiba", 0x0930, "Gigabeat S", 0x0010, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
505 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000506 // Reported by Rob Brown
Linus Walleij7e3b3072009-01-19 22:51:17 +0000507 { "Toshiba", 0x0930, "Gigabeat P10", 0x0011,
508 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij51dde6b2007-11-03 23:14:59 +0000509 // Reported by solanum@users.sourceforge.net
Linus Walleij7e3b3072009-01-19 22:51:17 +0000510 { "Toshiba", 0x0930, "Gigabeat V30", 0x0014,
511 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000512 // Reported by Michael Davis <slithy@yahoo.com>
Linus Walleij7e3b3072009-01-19 22:51:17 +0000513 { "Toshiba", 0x0930, "Gigabeat U", 0x0016,
514 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij804cc622008-02-03 21:26:26 +0000515 // Reported by Devon Jacobs <devo@godevo.com>
Linus Walleijf67c1ad2009-01-14 21:39:50 +0000516 { "Toshiba", 0x0930, "Gigabeat MEU202", 0x0018,
517 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleijc76e2f72007-12-09 22:14:35 +0000518 // Reported by Rolf <japan (at) dl3lar.de>
Linus Walleij7e3b3072009-01-19 22:51:17 +0000519 { "Toshiba", 0x0930, "Gigabeat T", 0x0019,
520 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij07bb5382008-07-31 20:21:09 +0000521 // Reported by Phil Ingram <ukpbert@users.sourceforge.net>
522 // Tentatively added - no real reports of this device ID being MTP,
523 // reports as USB Mass Storage currently.
Linus Walleij7e3b3072009-01-19 22:51:17 +0000524 { "Toshiba", 0x0930, "Gigabeat MEU201", 0x001a,
525 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij922880f2008-10-29 17:31:42 +0000526 // Reported by anonymous SourceForge user
Linus Walleij7e3b3072009-01-19 22:51:17 +0000527 { "Toshiba", 0x0930, "Gigabeat MET401", 0x001d,
528 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij804cc622008-02-03 21:26:26 +0000529
Linus Walleij1a673de2007-10-29 23:10:05 +0000530 /*
531 * Archos
532 * These devices have some dual-mode interfaces which will really
533 * respect the driver unloading, so DEVICE_FLAG_UNLOAD_DRIVER
534 * really work on these devices!
535 */
536 // Reported by Alexander Haertig <AlexanderHaertig@gmx.de>
537 { "Archos", 0x0e79, "Gmini XS100", 0x1207, DEVICE_FLAG_UNLOAD_DRIVER },
538 // Added by Jan Binder
539 { "Archos", 0x0e79, "XS202 (MTP mode)", 0x1208, DEVICE_FLAG_NONE },
540 // Reported by gudul1@users.sourceforge.net
541 { "Archos", 0x0e79, "104 (MTP mode)", 0x120a, DEVICE_FLAG_NONE },
Richard Lowe525e542009-11-09 21:09:52 +0000542 // Reported by Archos
543 { "Archos", 0x0e79, "204 (MTP mode)", 0x120c, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij4c3cd682008-01-27 22:18:05 +0000544 // Reported by anonymous Sourceforge user.
545 { "Archos", 0x0e79, "404 (MTP mode)", 0x1301, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000546 // Reported by Archos
547 { "Archos", 0x0e79, "404CAM (MTP mode)", 0x1303, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000548 // Reported by Etienne Chauchot <chauchot.etienne@free.fr>
549 { "Archos", 0x0e79, "504 (MTP mode)", 0x1307, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000550 // Reported by Archos
551 { "Archos", 0x0e79, "604 (MTP mode)", 0x1309, DEVICE_FLAG_UNLOAD_DRIVER },
552 { "Archos", 0x0e79, "604WIFI (MTP mode)", 0x130b, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000553 // Reported by Kay McCormick <kaym@modsystems.com>
554 { "Archos", 0x0e79, "704 mobile dvr", 0x130d, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000555 // Reported by Archos
556 { "Archos", 0x0e79, "704TV (MTP mode)", 0x130f, DEVICE_FLAG_UNLOAD_DRIVER },
557 { "Archos", 0x0e79, "405 (MTP mode)", 0x1311, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij121b7f22007-12-08 21:37:35 +0000558 // Reported by Joe Rabinoff
Linus Walleije71639a2007-12-08 21:36:00 +0000559 { "Archos", 0x0e79, "605 (MTP mode)", 0x1313, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000560 // Reported by Archos
561 { "Archos", 0x0e79, "605F (MTP mode)", 0x1315, DEVICE_FLAG_UNLOAD_DRIVER },
562 { "Archos", 0x0e79, "705 (MTP mode)", 0x1319, DEVICE_FLAG_UNLOAD_DRIVER },
563 { "Archos", 0x0e79, "TV+ (MTP mode)", 0x131b, DEVICE_FLAG_UNLOAD_DRIVER },
564 { "Archos", 0x0e79, "105 (MTP mode)", 0x131d, DEVICE_FLAG_UNLOAD_DRIVER },
565 { "Archos", 0x0e79, "405HDD (MTP mode)", 0x1321, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij4aa66dc2009-05-02 06:36:59 +0000566 // Reported by Jim Krehl <jimmuhk@users.sourceforge.net>
567 { "Archos", 0x0e79, "5 (MTP mode)", 0x1331, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij8c725002008-11-25 20:33:13 +0000568 // Reported by Adrien Guichard <tmor@users.sourceforge.net>
569 { "Archos", 0x0e79, "5 (MTP mode)", 0x1333, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000570 // Reported by Archos
571 { "Archos", 0x0e79, "7 (MTP mode)", 0x1335, DEVICE_FLAG_UNLOAD_DRIVER },
572 { "Archos", 0x0e79, "SPOD (MTP mode)", 0x1341, DEVICE_FLAG_UNLOAD_DRIVER },
573 { "Archos", 0x0e79, "5S IT (MTP mode)", 0x1351, DEVICE_FLAG_UNLOAD_DRIVER },
574 { "Archos", 0x0e79, "5H IT (MTP mode)", 0x1357, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000575
576 /*
577 * Dunlop (OEM of EGOMAN ltd?) reported by Nanomad
578 * This unit is falsely detected as USB mass storage in Linux
579 * prior to kernel 2.6.19 (fixed by patch from Alan Stern)
580 * so on older kernels special care is needed to remove the
581 * USB mass storage driver that erroneously binds to the device
582 * interface.
583 */
584 { "Dunlop", 0x10d6, "MP3 player 1GB / EGOMAN MD223AFD", 0x2200, DEVICE_FLAG_UNLOAD_DRIVER},
Linus Walleij07bb5382008-07-31 20:21:09 +0000585 // Reported by Steven Black <stevenblack1956@users.sourceforge.net>
586 // Obviously this company goes by many names.
Linus Walleij102a72d2008-11-27 23:16:47 +0000587 // This device is USB 2.0 only. Broken pipe on closing.
588 { "Memorex", 0x10d6, "MMP 8585/8586", 0x2300, DEVICE_FLAG_UNLOAD_DRIVER |
589 DEVICE_FLAG_NO_RELEASE_INTERFACE},
Linus Walleij414a0832009-09-18 23:04:05 +0000590
Linus Walleij1a673de2007-10-29 23:10:05 +0000591 /*
592 * Sirius
593 */
594 { "Sirius", 0x18f6, "Stiletto", 0x0102, DEVICE_FLAG_NONE },
Linus Walleij30a7dd92008-04-09 20:33:51 +0000595 // Reported by Chris Bagwell <chris@cnpbagwell.com>
Linus Walleij2f622812008-08-30 22:06:58 +0000596 { "Sirius", 0x18f6, "Stiletto 2", 0x0110, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000597
598 /*
599 * Canon
Linus Walleija1a2eb72009-10-14 21:51:12 +0000600 * These are actually cameras, but they have a Microsoft device descriptor
601 * and reports themselves as supporting the MTP extension.
Linus Walleij1a673de2007-10-29 23:10:05 +0000602 */
Linus Walleija1a2eb72009-10-14 21:51:12 +0000603 { "Canon", 0x04a9, "Ixus Digital 700 (PTP/MTP mode)", 0x30f2,
604 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij00e6a5e2008-10-17 07:13:30 +0000605 { "Canon", 0x04a9, "PowerShot A640 (PTP/MTP mode)", 0x3139,
606 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000607
608 /*
609 * Nokia
Linus Walleij21704fd2008-02-29 22:50:29 +0000610 * Please verify the low device IDs here, I suspect these might be for
611 * things like USB storage or modem mode actually, whereas the higher
Linus Walleij9462f552008-10-25 19:16:53 +0000612 * range (0x04nn) could be for MTP. Some of the devices were gathered
613 * from the Nokia WMP drivers:
614 * http://nds2.nokia.com/files/support/global/phones/software/
615 * Address was gathered from going to:
616 * nseries.com
617 * -> support
618 * -> select supported device
619 * -> PC software
620 * -> Music software
621 * -> Windows Media Player 10 driver
Linus Walleij1a673de2007-10-29 23:10:05 +0000622 */
623 // From: DoomHammer <gaczek@users.sourceforge.net>
Linus Walleijb5a4f922008-05-11 20:15:00 +0000624 { "Nokia", 0x0421, "N81 Mobile Phone", 0x000a, DEVICE_FLAG_NONE },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000625 // From an anonymous SourceForge user
626 { "Nokia", 0x0421, "6120c Classic Mobile Phone", 0x002e, DEVICE_FLAG_NONE },
Linus Walleijbddfd192008-11-25 20:26:52 +0000627 // From Stefano
628 { "Nokia", 0x0421, "N96 Mobile Phone", 0x0039, DEVICE_FLAG_NONE },
Linus Walleijace7f4c2008-11-01 21:07:34 +0000629 // From Martijn van de Streek <martijn@vandestreek.net>
Linus Walleij4c8b6e12008-10-31 22:04:14 +0000630 { "Nokia", 0x0421, "6500c Classic Mobile Phone", 0x003c, DEVICE_FLAG_NONE },
Linus Walleijb5a4f922008-05-11 20:15:00 +0000631 // From: DoomHammer <gaczek@users.sourceforge.net>
Linus Walleij1a673de2007-10-29 23:10:05 +0000632 { "Nokia", 0x0421, "3110c Mobile Phone", 0x005f, DEVICE_FLAG_NONE },
Linus Walleija8ba8c72008-03-29 00:02:27 +0000633 // From: Vasily <spc-@users.sourceforge.net>
634 { "Nokia", 0x0421, "3109c Mobile Phone", 0x0065, DEVICE_FLAG_NONE },
Linus Walleij07bb5382008-07-31 20:21:09 +0000635 // From: <rawc@users.sourceforge.net>
636 { "Nokia", 0x0421, "5310 XpressMusic", 0x006c, DEVICE_FLAG_NONE },
Linus Walleij21704fd2008-02-29 22:50:29 +0000637 // From: robin (AT) headbank D0Tco DOTuk
638 { "Nokia", 0x0421, "N95 Mobile Phone 8GB", 0x006e, DEVICE_FLAG_NONE },
Linus Walleijcfd143d2008-10-24 20:52:48 +0000639 // From Bastien Nocera <hadess@hadess.net>
640 { "Nokia", 0x0421, "N82 Mobile Phone", 0x0074, DEVICE_FLAG_NONE },
Linus Walleijace7f4c2008-11-01 21:07:34 +0000641 // From Martijn van de Streek <martijn@vandestreek.net>
Linus Walleij4c8b6e12008-10-31 22:04:14 +0000642 { "Nokia", 0x0421, "N78 Mobile Phone", 0x0079, DEVICE_FLAG_NONE },
Linus Walleij22e4bfc2009-02-09 23:24:58 +0000643 // From William Pettersson <the_enigma@users.sourceforge.net>
644 { "Nokia", 0x0421, "6220 Classic", 0x008d, DEVICE_FLAG_NONE },
Linus Walleijbbf5e7f2009-03-05 21:04:42 +0000645 // From kellerkev@gmail.com
646 { "Nokia", 0x0421, "N85 Mobile Phone", 0x0092, DEVICE_FLAG_NONE },
Linus Walleij07bb5382008-07-31 20:21:09 +0000647 // From: danielw
648 { "Nokia", 0x0421, "E71", 0x00e4, DEVICE_FLAG_NONE },
Linus Walleijf3296622008-09-04 20:53:56 +0000649 // From: Laurent Bigonville <bigon@users.sourceforge.net>
650 { "Nokia", 0x0421, "E66", 0x00e5, DEVICE_FLAG_NONE },
Linus Walleij1d139362009-05-02 06:22:44 +0000651 // From: Pier <pierlucalino@users.sourceforge.net>
652 { "Nokia", 0x0421, "5320 XpressMusic", 0x00ea, DEVICE_FLAG_NONE },
Linus Walleij18faccb2009-08-03 20:21:55 +0000653 // From: Gausie <innerdreams@users.sourceforge.net>
654 { "Nokia", 0x0421, "5800 XpressMusic", 0x0154, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij79547002009-02-02 21:05:14 +0000655 // From: Willy Gardiol (web) <willy@gardiol.org>
Linus Walleij22e4bfc2009-02-09 23:24:58 +0000656 // Spurious errors for getting all objects, lead me to believe this flag atleast is needed
Linus Walleij18faccb2009-08-03 20:21:55 +0000657 { "Nokia", 0x0421, "5800 XpressMusic v2", 0x0155, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij5b4d8e02009-01-07 21:44:59 +0000658 // From an anonymous SourceForge user
659 // Not verified to be MTP
660 { "Nokia", 0x0421, "E63", 0x0179, DEVICE_FLAG_NONE },
Linus Walleij4fe08902009-08-03 20:27:27 +0000661 // From: FunkyPenguin <awafaa@users.sourceforge.net>
662 { "Nokia", 0x0421, "N97", 0x01f5, DEVICE_FLAG_NONE },
Linus Walleij5ffcec92009-09-03 21:16:36 +0000663 // From: Alexander Kojevnikov <alex-kay@users.sourceforge.net>
664 { "Nokia", 0x0421, "6600i", 0x0297, DEVICE_FLAG_NONE },
Linus Walleij89af6bb2009-04-06 22:02:51 +0000665 // https://sourceforge.net/tracker/index.php?func=detail&aid=2692473&group_id=8874&atid=358874
666 { "Nokia", 0x0421, "5200", 0x0421, DEVICE_FLAG_NONE },
Linus Walleij60144512008-10-25 19:11:48 +0000667 // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_3250_WMP10_driver.inf
668 { "Nokia", 0x0421, "3250 Mobile Phone", 0x0462, DEVICE_FLAG_NONE },
669 // From http://nds2.nokia.com/files/support/global/phones/software/Nokia_N93_WMP10_Driver.inf
670 { "Nokia", 0x0421, "N93 Mobile Phone", 0x0478, DEVICE_FLAG_NONE },
671 // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_5500_Sport_WMP10_driver.inf
672 { "Nokia", 0x0421, "5500 Sport Mobile Phone", 0x047e, DEVICE_FLAG_NONE },
673 // From http://nds2.nokia.com/files/support/global/phones/software/Nokia_N91_WMP10_Driver.inf
674 { "Nokia", 0x0421, "N91 Mobile Phone", 0x0485, DEVICE_FLAG_NONE },
Linus Walleij250ef742008-04-05 20:11:44 +0000675 // From: Christian Rusa <kristous@users.sourceforge.net>
676 { "Nokia", 0x0421, "5700 XpressMusic Mobile Phone", 0x04b4, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000677 // From: Mitchell Hicks <mitchix@yahoo.com>
678 { "Nokia", 0x0421, "5300 Mobile Phone", 0x04ba, DEVICE_FLAG_NONE },
679 // From Christian Arnold <webmaster@arctic-media.de>
680 { "Nokia", 0x0421, "N73 Mobile Phone", 0x04d1, DEVICE_FLAG_UNLOAD_DRIVER },
681 // From Swapan <swapan@yahoo.com>
682 { "Nokia", 0x0421, "N75 Mobile Phone", 0x04e1, DEVICE_FLAG_NONE },
Linus Walleij60144512008-10-25 19:11:48 +0000683 // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_N93i_WMP10_driver.inf
684 { "Nokia", 0x0421, "N93i Mobile Phone", 0x04e5, DEVICE_FLAG_NONE },
Linus Walleija6d0d482007-10-31 08:54:56 +0000685 // From Anonymous Sourceforge User
686 { "Nokia", 0x0421, "N95 Mobile Phone", 0x04ef, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000687 // From: Pat Nicholls <pat@patandannie.co.uk>
688 { "Nokia", 0x0421, "N80 Internet Edition (Media Player)", 0x04f1, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij67465c12009-08-23 21:56:26 +0000689 // Reported by Richard Wall <richard@the-moon.net>
690 { "Nokia", 0x05c6, "5530 Xpressmusic", 0x0229, DEVICE_FLAG_NONE },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000691 // Reported by anonymous SourceForge user
692 // One thing stated by reporter (Nokia model) another by the detect log...
693 { "Nokia/Verizon", 0x05c6, "6205 Balboa/Verizon Music Phone", 0x3196, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000694
Linus Walleija6d0d482007-10-31 08:54:56 +0000695
Linus Walleij1a673de2007-10-29 23:10:05 +0000696 /*
Linus Walleij83475632009-11-07 14:36:44 +0000697 * Vendor ID 0x13d1 is some offshoring company in China,
698 * in one source named "A-Max Technology Macao Commercial
699 * Offshore Co. Ltd." sometime "CCTech".
Linus Walleij1a673de2007-10-29 23:10:05 +0000700 */
Linus Walleij83475632009-11-07 14:36:44 +0000701 // Logik brand
Linus Walleij1a673de2007-10-29 23:10:05 +0000702 { "Logik", 0x13d1, "LOG DAX MP3 and DAB Player", 0x7002, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij83475632009-11-07 14:36:44 +0000703 // Technika brand
704 // Reported by <Ooblick@users.sourceforge.net>
705 { "Technika", 0x13d1, "MP-709", 0x7017, DEVICE_FLAG_UNLOAD_DRIVER },
706
Linus Walleij1a673de2007-10-29 23:10:05 +0000707
708 /*
709 * RCA / Thomson
710 */
711 // From kiki <omkiki@users.sourceforge.net>
712 { "Thomson", 0x069b, "EM28 Series", 0x0774, DEVICE_FLAG_NONE },
Richard Low957ffba2008-01-21 17:31:20 +0000713 { "Thomson / RCA", 0x069b, "Opal / Lyra MC4002", 0x0777, DEVICE_FLAG_NONE },
Linus Walleij01fc9c82009-03-10 23:52:09 +0000714 { "Thomson", 0x069b, "Lyra MC5104B (M51 Series)", 0x077c, DEVICE_FLAG_NONE },
Linus Walleij2c414c42008-01-19 07:11:19 +0000715 { "Thomson", 0x069b, "RCA H106", 0x301a, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000716 // From Svenna <svenna@svenna.de>
717 // Not confirmed to be MTP.
718 { "Thomson", 0x069b, "scenium E308", 0x3028, DEVICE_FLAG_NONE },
Richard Lowa11a6ad2008-01-21 17:23:55 +0000719 // From XNJB user
Richard Low957ffba2008-01-21 17:31:20 +0000720 { "Thomson / RCA", 0x069b, "Lyra HC308A", 0x3035, DEVICE_FLAG_NONE },
Linus Walleij2aa35742009-11-07 14:39:03 +0000721
Linus Walleij1a673de2007-10-29 23:10:05 +0000722 /*
723 * NTT DoCoMo
724 */
725 { "FOMA", 0x04c5, "F903iX HIGH-SPEED", 0x1140, DEVICE_FLAG_NONE },
726
727 /*
728 * Palm device userland program named Pocket Tunes
729 * Reported by Peter Gyongyosi <gyp@impulzus.com>
730 */
Linus Walleijfc438072008-10-31 21:12:43 +0000731 { "NormSoft, Inc.", 0x1703, "Pocket Tunes", 0x0001, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000732 // Reported by anonymous submission
Linus Walleijfc438072008-10-31 21:12:43 +0000733 { "NormSoft, Inc.", 0x1703, "Pocket Tunes 4", 0x0002, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000734
735 /*
Linus Walleijf6612032009-07-23 22:50:57 +0000736 * TrekStor, Medion and Maxfield devices
Linus Walleij1a673de2007-10-29 23:10:05 +0000737 * Their datasheet claims their devices are dualmode so probably needs to
738 * unload the attached drivers here.
739 */
740 // Reported by Stefan Voss <svoss@web.de>
Linus Walleij10b06d42007-11-05 11:32:07 +0000741 // This is a Sigmatel SoC with a hard disk.
Linus Walleijd866d242009-08-23 21:50:39 +0000742 { "TrekStor", 0x066f, "Vibez 8/12GB", 0x842a,
Linus Walleij07bb5382008-07-31 20:21:09 +0000743 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
744 // Reported by anonymous SourceForge user.
745 // This one done for Medion, whatever that is. Error reported so assume
746 // the same bug flag as its ancestor above.
747 { "Medion", 0x066f, "MD8333", 0x8550,
748 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijf6612032009-07-23 22:50:57 +0000749 // Reported by anonymous SourceForge user
Linus Walleijdc33ef92008-11-15 09:45:53 +0000750 { "Medion", 0x066f, "MD8333", 0x8588,
751 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijf6612032009-07-23 22:50:57 +0000752 // Reported by anonymous SourceForge user
753 { "Maxfield", 0x066f, "G-Flash NG 1GB", 0x846c,
754 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000755 // Reported by Cristi Magherusan <majeru@gentoo.ro>
Linus Walleijd866d242009-08-23 21:50:39 +0000756 { "TrekStor", 0x0402, "i.Beat Sweez FM", 0x0611,
757 DEVICE_FLAG_UNLOAD_DRIVER },
758 // Reported by Fox-ino <fox-ino@users.sourceforge.net>
759 { "ALi Corp.", 0x0402, "MPMAN 2GB", 0x5668,
Linus Walleij07bb5382008-07-31 20:21:09 +0000760 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij2a7c6c72009-05-19 22:33:43 +0000761 // Reported by Anonymous SourceForge user
762 {"TrekStor", 0x1e68, "i.Beat Organix 2.0", 0x0002,
763 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijd866d242009-08-23 21:50:39 +0000764
Linus Walleij1a673de2007-10-29 23:10:05 +0000765 /*
Linus Walleijf88b5a42009-04-20 22:36:41 +0000766 * Disney/Tevion/MyMusix
Linus Walleij1a673de2007-10-29 23:10:05 +0000767 */
768 // Reported by XNJB user
769 { "Disney", 0x0aa6, "MixMax", 0x6021, DEVICE_FLAG_NONE },
Linus Walleij21704fd2008-02-29 22:50:29 +0000770 // Reported by anonymous Sourceforge user
771 { "Tevion", 0x0aa6, "MD 81488", 0x3011, DEVICE_FLAG_NONE },
Linus Walleijf88b5a42009-04-20 22:36:41 +0000772 // Reported by Peter Hedlund <peter@peterandlinda.com>
773 { "MyMusix", 0x0aa6, "PD-6070", 0x9601, DEVICE_FLAG_UNLOAD_DRIVER |
774 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
775 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST |
776 DEVICE_FLAG_NO_RELEASE_INTERFACE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000777
778 /*
779 * Cowon Systems, Inc.
780 * The iAudio audiophile devices don't encourage the use of MTP.
781 */
782 // Reported by Patrik Johansson <Patrik.Johansson@qivalue.com>
Linus Walleij7e3b3072009-01-19 22:51:17 +0000783 { "Cowon", 0x0e21, "iAudio U3 (MTP mode)", 0x0701,
784 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijee387d72008-11-12 23:42:02 +0000785 // Reported by Kevin Michael Smith <hai-etlik@users.sourceforge.net>
Linus Walleij7e3b3072009-01-19 22:51:17 +0000786 { "Cowon", 0x0e21, "iAudio 6 (MTP mode)", 0x0711,
787 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000788 // Reported by Roberth Karman
Linus Walleij7e3b3072009-01-19 22:51:17 +0000789 { "Cowon", 0x0e21, "iAudio 7 (MTP mode)", 0x0751,
790 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000791 // Reported by an anonymous SourceForge user
Linus Walleij7e3b3072009-01-19 22:51:17 +0000792 { "Cowon", 0x0e21, "iAudio U5 (MTP mode)", 0x0761,
793 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000794 // Reported by TJ Something <tjbk_tjb@users.sourceforge.net>
Linus Walleij4a779562009-03-29 23:36:45 +0000795 { "Cowon", 0x0e21, "iAudio D2 (MTP mode)", 0x0801,
796 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijd09f65e2009-05-04 23:18:29 +0000797 // Reported by anonymous Sourceforge user
Linus Walleij18ed0162009-05-06 16:51:08 +0000798 { "Cowon", 0x0e21, "iAudio D2+ FW 2.x (MTP mode)", 0x0861,
799 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
800 // From Rockbox device listing
801 { "Cowon", 0x0e21, "iAudio D2+ DAB FW 4.x (MTP mode)", 0x0871,
802 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
803 // From Rockbox device listing
804 { "Cowon", 0x0e21, "iAudio D2+ FW 3.x (MTP mode)", 0x0881,
805 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
806 // From Rockbox device listing
807 { "Cowon", 0x0e21, "iAudio D2+ DMB FW 1.x (MTP mode)", 0x0891,
Linus Walleijd09f65e2009-05-04 23:18:29 +0000808 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij4a779562009-03-29 23:36:45 +0000809 // Reported by <twkonefal@users.sourceforge.net>
810 { "Cowon", 0x0e21, "iAudio S9 (MTP mode)", 0x0901,
Linus Walleij48946ff2009-06-24 08:15:39 +0000811 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij89bb1cd2009-07-24 21:03:36 +0000812 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_FLAC_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +0000813
814 /*
815 * Insignia, dual-mode.
816 */
817 { "Insignia", 0x19ff, "NS-DV45", 0x0303, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij478ddb92007-11-26 21:01:29 +0000818 // Reported by Rajan Bella <rajanbella@yahoo.com>
819 { "Insignia", 0x19ff, "Sport Player", 0x0307, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000820 // Reported by "brad" (anonymous, sourceforge)
821 { "Insignia", 0x19ff, "Pilot 4GB", 0x0309, DEVICE_FLAG_UNLOAD_DRIVER },
822
823 /*
824 * LG Electronics
825 */
Linus Walleij1291ce02009-11-07 14:26:57 +0000826 // From anonymous SourceForge user
827 // Uncertain if this is really the MTP mode device ID...
828 { "LG Electronics Inc.", 0x043e, "T54", 0x7040,
829 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000830 // Not verified - anonymous submission
Linus Walleij7b4794f2008-08-13 13:17:17 +0000831 { "LG Electronics Inc.", 0x043e, "UP3", 0x70b1, DEVICE_FLAG_NONE },
832 // Reported by Joseph Nahmias <joe@nahimas.net>
833 { "LG Electronics Inc.", 0x1004, "VX8550 V CAST Mobile Phone", 0x6010,
834 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR },
Linus Walleij2242b022009-01-02 01:44:00 +0000835 // Reported by Cyrille Potereau <cyrille.potereau@wanadoo.fr>
836 { "LG Electronics Inc.", 0x1004, "KC910 Renoir Mobile Phone", 0x608f,
837 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij7fe2b4f2009-05-02 07:07:50 +0000838 // Reported by anonymous sourceforge user
839 { "LG Electronics Inc.", 0x1004, "KM900", 0x6132,
840 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000841
842 /*
843 * Sony
Linus Walleijbc3ed4d2008-01-03 13:54:23 +0000844 * It could be that these PIDs are one-per hundred series, so
845 * NWZ-A8xx is 0325, NWZ-S5xx is 0x326 etc. We need more devices
846 * reported to see a pattern here.
Linus Walleij1a673de2007-10-29 23:10:05 +0000847 */
Linus Walleija8ba8c72008-03-29 00:02:27 +0000848 // Reported by Alessandro Radaelli <alessandro.radaelli@aruba.it>
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000849 { "Sony", 0x054c, "Walkman NWZ-A815/NWZ-A818", 0x0325,
850 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000851 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
852 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij5d709a52007-12-28 21:37:17 +0000853 // Reported by anonymous Sourceforge user.
Linus Walleij46b909a2009-09-23 06:55:14 +0000854 { "Sony", 0x054c, "Walkman NWZ-S516", 0x0326,
855 DEVICE_FLAG_UNLOAD_DRIVER |
856 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
857 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij1a673de2007-10-29 23:10:05 +0000858 // Reported by Endre Oma <endre.88.oma@gmail.com>
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000859 { "Sony", 0x054c, "Walkman NWZ-S615F/NWZ-S616F/NWZ-S618F", 0x0327,
860 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000861 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
862 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij062ec7d2008-05-19 12:06:32 +0000863 // Reported by Jean-Marc Bourguet <jm@bourguet.org>
Linus Walleij46b909a2009-09-23 06:55:14 +0000864 { "Sony", 0x054c, "Walkman NWZ-S716F", 0x035a,
865 DEVICE_FLAG_UNLOAD_DRIVER |
866 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
867 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij0c98ce82008-05-25 11:08:36 +0000868 // Reported by Anon SF User / Anthon van der Neut <avanderneut@avid.com>
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000869 { "Sony", 0x054c, "Walkman NWZ-A826/NWZ-A828/NWZ-A829", 0x035b,
870 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000871 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
872 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleija8ba8c72008-03-29 00:02:27 +0000873 // Reported by Niek Klaverstijn <niekez@users.sourceforge.net>
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000874 { "Sony", 0x054c, "Walkman NWZ-A726/NWZ-A728/NWZ-A768", 0x035c,
875 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000876 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
877 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij45b843e2008-10-09 08:33:01 +0000878 // Reported by Mehdi AMINI <mehdi.amini - at - ulp.u-strasbg.fr>
Linus Walleij46b909a2009-09-23 06:55:14 +0000879 { "Sony", 0x054c, "Walkman NWZ-B135", 0x036e,
880 DEVICE_FLAG_UNLOAD_DRIVER |
881 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
882 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij2242b022009-01-02 01:44:00 +0000883 // Reported by <tiagoboldt@users.sourceforge.net>
Linus Walleij46b909a2009-09-23 06:55:14 +0000884 { "Sony", 0x054c, "Walkman NWZ-E436F", 0x0385,
885 DEVICE_FLAG_UNLOAD_DRIVER |
886 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
887 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij7fe2b4f2009-05-02 07:07:50 +0000888 // Reported by Michael Wilkinson
Linus Walleij46b909a2009-09-23 06:55:14 +0000889 { "Sony", 0x054c, "Walkman NWZ-W202", 0x0388,
890 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij094b4502009-09-22 22:28:33 +0000891 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
892 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij25a16302009-03-04 13:56:33 +0000893 // Reported by Ondrej Sury <ondrej@sury.org>
Linus Walleij46b909a2009-09-23 06:55:14 +0000894 { "Sony", 0x054c, "Walkman NWZ-S739F", 0x038c,
895 DEVICE_FLAG_UNLOAD_DRIVER |
896 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
897 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleijd8f1feb2008-10-08 09:16:42 +0000898 // Reported by Marco Filipe Nunes Soares Abrantes Pereira <marcopereira@ua.pt>
Linus Walleij46b909a2009-09-23 06:55:14 +0000899 { "Sony", 0x054c, "Walkman NWZ-S638F", 0x038e,
900 DEVICE_FLAG_UNLOAD_DRIVER |
901 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
902 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij0c6808e2009-07-23 22:44:38 +0000903 // Reported by Elliot <orwells@users.sourceforge.net>
Linus Walleij8d799eb2009-07-23 22:58:06 +0000904 { "Sony", 0x054c, "Walkman NWZ-X1050B/NWZ-X1060B",
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000905 0x0397, DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000906 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
907 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij8d799eb2009-07-23 22:58:06 +0000908 // Reported by Silvio J. Gutierrez <silviogutierrez@users.sourceforge.net>
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000909 { "Sony", 0x054c, "Walkman NWZ-X1051/NWZ-X1061", 0x0398,
910 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000911 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
912 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij2aa35742009-11-07 14:39:03 +0000913 // Reported by Gregory Boddin <gregory@siwhine.net>
914 { "Sony", 0x054c, "Walkman NWZ-B142F", 0x03d8,
915 DEVICE_FLAG_UNLOAD_DRIVER |
916 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
917 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleijd8f1feb2008-10-08 09:16:42 +0000918
Linus Walleij1a673de2007-10-29 23:10:05 +0000919
920 /*
Linus Walleijaa6b0192007-10-29 23:39:48 +0000921 * SonyEricsson
Linus Walleijc7756412008-10-21 14:24:24 +0000922 * These initially seemed to support GetObjPropList but later revisions
923 * of the firmware seem to have broken it, so all are flagged as broken
924 * for now.
Linus Walleijaa6b0192007-10-29 23:39:48 +0000925 */
Linus Walleijd866d242009-08-23 21:50:39 +0000926 // Reported by Thomas Schweitzer <thomas_-_s@users.sourceforge.net>
927 { "SonyEricsson", 0x0fce, "K550i", 0xe000, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijb3b29e72007-11-05 22:29:53 +0000928 // Reported by Øyvind Stegard <stegaro@users.sourceforge.net>
Linus Walleijc7756412008-10-21 14:24:24 +0000929 { "SonyEricsson", 0x0fce, "K850i", 0x0075, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijaa6b0192007-10-29 23:39:48 +0000930 // Reported by Michael Eriksson
Linus Walleijc7756412008-10-21 14:24:24 +0000931 { "SonyEricsson", 0x0fce, "W910", 0x0076, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijb5a4f922008-05-11 20:15:00 +0000932 // Reported by Zack <zackdvd@users.sourceforge.net>
Linus Walleijc7756412008-10-21 14:24:24 +0000933 { "SonyEricsson", 0x0fce, "W890i", 0x00b3, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000934 // Reported by robert dot ahlskog at gmail
Linus Walleijc7756412008-10-21 14:24:24 +0000935 { "SonyEricsson", 0x0fce, "W760i", 0x00c6, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000936 // Reported by Linus Åkesson <linusakesson@users.sourceforge.net>
Linus Walleijc7756412008-10-21 14:24:24 +0000937 { "SonyEricsson", 0x0fce, "C902", 0x00d4, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij07bb5382008-07-31 20:21:09 +0000938 // Reported by an anonymous SourceForge user
Linus Walleijc7756412008-10-21 14:24:24 +0000939 { "SonyEricsson", 0x0fce, "C702", 0x00d9, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijdb6da7c2008-10-16 18:46:34 +0000940 // Reported by Christian Zuckschwerdt <christian@zuckschwerdt.org>
Linus Walleijc7756412008-10-21 14:24:24 +0000941 { "SonyEricsson", 0x0fce, "W980", 0x00da, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij76edf7e2009-05-19 22:37:07 +0000942 // Reported by David Taylor <davidt-libmtp@yadt.co.uk>
943 { "SonyEricsson", 0x0fce, "C905", 0x00ef, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij4aa66dc2009-05-02 06:36:59 +0000944 // Reported by David House <dmhouse@users.sourceforge.net>
945 { "SonyEricsson", 0x0fce, "W595", 0x00f3,
Linus Walleijdab453b2009-05-26 20:55:58 +0000946 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL | DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleij2c34d432008-12-13 22:01:32 +0000947 // Reported by Mattias Evensson <mevensson@users.sourceforge.net>
948 { "SonyEricsson", 0x0fce, "W902", 0x00f5, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij5ffcec92009-09-03 21:16:36 +0000949 // Reported by Sarunas <sarunas@users.sourceforge.net>
950 // Doesn't need any flags according to reporter
Linus Walleij572cb972009-09-08 20:03:29 +0000951 { "SonyEricsson", 0x0fce, "T700", 0x00fb, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij4a779562009-03-29 23:36:45 +0000952 // Reported by Stéphane Pontier <shadow_walker@users.sourceforge.net>
Linus Walleijffffa272009-08-03 19:03:38 +0000953 { "SonyEricsson", 0x0fce, "W705/W715", 0x0105, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleije7ab9482009-07-23 23:50:51 +0000954 // Reported by Håkan Kvist
955 { "SonyEricsson", 0x0fce, "W995", 0x0112, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
956
Linus Walleijaa6b0192007-10-29 23:39:48 +0000957
958 /*
Linus Walleij1a673de2007-10-29 23:10:05 +0000959 * Motorola
960 * Assume DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST on all of these.
961 */
Linus Walleij37c21662008-05-16 21:16:01 +0000962 // Reported by David Boyd <tiggrdave@users.sourceforge.net>
Linus Walleijf3296622008-09-04 20:53:56 +0000963 { "Motorola", 0x22b8, "V3m/V750 verizon", 0x2a65, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST |
Linus Walleij37c21662008-05-16 21:16:01 +0000964 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000965 // Reported by Marcus Meissner to libptp2
966 { "Motorola", 0x22b8, "K1", 0x4811, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
967 // Reported by Hans-Joachim Baader <hjb@pro-linux.de> to libptp2
968 { "Motorola", 0x22b8, "A1200", 0x60ca, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleijf0702982008-10-25 21:37:43 +0000969 // http://mark.cdmaforums.com/Files/Motdmmtp.inf
970 { "Motorola", 0x22b8, "MTP Test Command Interface", 0x6413, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000971 // Reported by anonymous user
Linus Walleij238704e2008-09-08 22:54:15 +0000972 { "Motorola", 0x22b8, "RAZR2 V8/U9/Z6", 0x6415, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleij37c21662008-05-16 21:16:01 +0000973
Linus Walleij1a673de2007-10-29 23:10:05 +0000974
975 /*
Linus Walleij478ddb92007-11-26 21:01:29 +0000976 * Media Keg
977 */
978 // Reported by Rajan Bella <rajanbella@yahoo.com>
979 { "Kenwood", 0x0b28, "Media Keg HD10GB7 Sport Player", 0x100c, DEVICE_FLAG_UNLOAD_DRIVER},
980
Linus Walleij5d675112008-02-16 21:46:46 +0000981 /*
982 * Micro-Star International (MSI)
983 */
984 // Reported by anonymous sourceforge user.
985 { "Micro-Star International", 0x0db0, "P610/Model MS-5557", 0x5572, DEVICE_FLAG_NONE },
986
Linus Walleijf044aa12008-03-22 21:45:19 +0000987 /*
988 * FOMA
989 */
990 { "FOMA", 0x06d3, "D905i", 0x21ba, DEVICE_FLAG_NONE },
Linus Walleij166c8ff2008-01-14 23:15:08 +0000991
Linus Walleij478ddb92007-11-26 21:01:29 +0000992 /*
Linus Walleijb5a4f922008-05-11 20:15:00 +0000993 * Haier
994 */
995 // Both reported by an anonymous SourceForge user
996 // This is the 30 GiB model
997 { "Haier", 0x1302, "Ibiza Rhapsody", 0x1016, DEVICE_FLAG_NONE },
998 // This is the 4/8 GiB model
999 { "Haier", 0x1302, "Ibiza Rhapsody", 0x1017, DEVICE_FLAG_NONE },
Richard Low4d93a992008-09-07 12:52:14 +00001000
1001 /*
1002 * Panasonic
1003 */
1004 // Reported by dmizer
1005 { "Panasonic", 0x04da, "P905i", 0x2145, DEVICE_FLAG_NONE },
Linus Walleijb5a4f922008-05-11 20:15:00 +00001006
1007 /*
Linus Walleij80a2a692008-12-05 20:36:40 +00001008 * Polaroid
1009 */
1010 { "Polaroid", 0x0546, "Freescape/MPU-433158", 0x2035, DEVICE_FLAG_NONE },
1011
1012 /*
Linus Walleij2242b022009-01-02 01:44:00 +00001013 * Pioneer
1014 */
1015 // Reported by Dan Allen <dan.j.allen@gmail.com>
1016 { "Pioneer", 0x08e4, "XMP3", 0x0148, DEVICE_FLAG_NONE },
1017
1018 /*
Linus Walleij4096c882009-03-16 23:32:34 +00001019 * Slacker Inc.
1020 * Put in all evilness flags because it looks fragile.
1021 */
1022 // Reported by Pug Fantus <pugfantus@users.sourceforge.net>
1023 { "Slacker Inc.", 0x1bdc, "Slacker Portable Media Player", 0xfabf,
1024 DEVICE_FLAG_BROKEN_BATTERY_LEVEL | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1025 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
1026
Linus Walleij6e3997e2009-04-12 23:40:40 +00001027 // Reported by Demadridsur <demadridsur@gmail.com>
1028 { "O2 Sistemas", 0x1e53, "ZoltarTV", 0x0006, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
1029
Linus Walleij6fb9a5f2009-09-12 06:25:17 +00001030 // Reported by Sense Hofstede <qense@users.sourceforge.net>
1031 { "Perception Digital, Ltd", 0x0aa6, "Gigaware GX400", 0x9702, DEVICE_FLAG_NONE },
Linus Walleij5f3c44b2009-09-12 21:03:06 +00001032
1033 /*
1034 * RIM's BlackBerry
1035 */
1036 // Reported by Nicolas VIVIEN <nicolas@vivien.fr>
Linus Walleijfea4f532009-09-22 22:08:35 +00001037 { "RIM", 0x0fca, "BlackBerry Storm", 0x8007, DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleijcea83ff2009-09-25 21:44:38 +00001038 DEVICE_FLAG_SWITCH_MODE_BLACKBERRY | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij5f3c44b2009-09-12 21:03:06 +00001039
Linus Walleij4096c882009-03-16 23:32:34 +00001040 /*
Linus Walleij1a673de2007-10-29 23:10:05 +00001041 * Other strange stuff.
1042 */
1043 { "Isabella", 0x0b20, "Her Prototype", 0xddee, DEVICE_FLAG_NONE }