blob: 0c4fce22a8946d694dc38da5116e345ede345abd [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 Walleij9ea512e2010-01-08 11:08:01 +0000181 // From HolgerK02@gmx.de
182 { "Samsung", 0x04e8, "YP-M1", 0x5118, DEVICE_FLAG_UNLOAD_DRIVER |
183 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_PLAYLIST_SPL_V2 },
Linus Walleijb49a9f72009-05-14 20:46:07 +0000184 // From Anonymous SourceForge user
185 // Guessing on .spl flag
Linus Walleij84072342009-06-24 08:08:26 +0000186 { "Samsung", 0x04e8, "YP-P3", 0x511a, DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleijb49a9f72009-05-14 20:46:07 +0000187 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
188 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij316628c2009-06-15 19:55:41 +0000189 // From Anonymous SourceForge user
190 // Guessing on .spl flag
Linus Walleij84072342009-06-24 08:08:26 +0000191 { "Samsung", 0x04e8, "YP-Q2", 0x511d, DEVICE_FLAG_UNLOAD_DRIVER |
192 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
193 DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij41e94cf2009-05-19 22:44:53 +0000194 // From Marco Pizzocaro <mpizzocaro@users.sourceforge.net>
195 // Guessing on .spl flag
196 { "Samsung", 0x04e8, "YP-U5", 0x5121,
197 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleijc2cdbfc2009-11-20 21:28:17 +0000198 // From Leonardo Accorsi <laccorsi@users.sourceforge.net>
199 // Guessing on .spl flag
200 { "Samsung", 0x04e8, "YP-R0", 0x5125,
201 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleij1a673de2007-10-29 23:10:05 +0000202 // From a rouge .INF file,
Linus Walleij23ab1542008-01-06 22:10:34 +0000203 // this device ID seems to have been recycled for:
204 // the Samsung SGH-A707 Cingular cellphone
205 // the Samsung L760-V cellphone
Linus Walleij5b03d302008-11-25 20:39:27 +0000206 // the Samsung SGH-U900 cellphone
Linus Walleijc1a82f12009-11-30 00:06:28 +0000207 { "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 +0000208 // From Santi Béjar <sbejar@gmail.com> - not sure this is MTP...
209 // { "Samsung", 0x04e8, "Z170 Mobile Phone", 0x6601, DEVICE_FLAG_UNLOAD_DRIVER },
210 // From Santi Béjar <sbejar@gmail.com> - not sure this is MTP...
211 // { "Samsung", 0x04e8, "E250 Mobile Phone", 0x663e, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000212 // From Lionel Bouton
Linus Walleij84072342009-06-24 08:08:26 +0000213 { "Samsung", 0x04e8, "X830 Mobile Phone", 0x6702, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000214 // From James <jamestech@gmail.com>
215 { "Samsung", 0x04e8, "U600 Mobile Phone", 0x6709, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij5b03d302008-11-25 20:39:27 +0000216 // From Cesar Cardoso <cesar@cesarcardoso.tk>
217 // No confirmation that this is really MTP.
218 { "Samsung", 0x04e8, "F250 Mobile Phone", 0x6727, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijc50e7682007-11-02 00:01:17 +0000219 // From Charlie Todd 2007-10-31
220 { "Samsung", 0x04e8, "Juke (SCH-U470)", 0x6734, DEVICE_FLAG_UNLOAD_DRIVER},
Linus Walleij34b421f2009-07-23 22:30:51 +0000221 // Reported by Tenn
222 { "Samsung", 0x04e8, "GT-B2700", 0x6752, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij5f0814f2009-07-23 21:53:38 +0000223 // Added by Greg Fitzgerald <netzdamon@gmail.com>
224 { "Samsung", 0x04e8, "SAMSUNG Trance", 0x6763, DEVICE_FLAG_UNLOAD_DRIVER |
225 DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_PLAYLIST_SPL_V1 },
Linus Walleijd866d242009-08-23 21:50:39 +0000226 // From anonymous Sourceforge user
227 { "Samsung", 0x04e8, "GT-S5230", 0xe20c, DEVICE_FLAG_NONE },
228
Linus Walleij1a673de2007-10-29 23:10:05 +0000229
230 /*
Linus Walleij414a0832009-09-18 23:04:05 +0000231 * Microsoft & Intel
Linus Walleij1a673de2007-10-29 23:10:05 +0000232 */
233 { "Intel", 0x045e, "Bandon Portable Media Center", 0x00c9, DEVICE_FLAG_NONE },
Linus Walleij414aca02008-06-02 23:16:49 +0000234 // Reported by Tadimarri Sarath <sarath.tadi@gmail.com>
235 // No idea why this use an Intel PID, perhaps a leftover from
236 // the early PMC development days when Intel and Microsoft were
237 // partnering.
238 { "Microsoft", 0x045e, "Windows MTP Simulator", 0x0622, DEVICE_FLAG_NONE },
Linus Walleij414a0832009-09-18 23:04:05 +0000239 // Reported by Edward Hutchins (used for Zune HDs)
240 { "Microsoft", 0x045e, "Zune HD", 0x063e, DEVICE_FLAG_NONE },
241 // Reported by Farooq Zaman (used for all Zunes)
242 { "Microsoft", 0x045e, "Zune", 0x0710, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000243
244 /*
245 * JVC
246 */
247 // From Mark Veinot
248 { "JVC", 0x04f1, "Alneo XA-HD500", 0x6105, DEVICE_FLAG_NONE },
249
250 /*
251 * Philips
252 */
253 { "Philips", 0x0471, "HDD6320/00 or HDD6330/17", 0x014b, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
254 // Anonymous SourceForge user
Linus Walleijf0702982008-10-25 21:37:43 +0000255 { "Philips", 0x0471, "HDD14XX,HDD1620 or HDD1630/17", 0x014c, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000256 // from discussion forum
257 { "Philips", 0x0471, "HDD085/00 or HDD082/17", 0x014d, DEVICE_FLAG_NONE },
258 // from XNJB forum
Richard Low641d1e32008-02-24 20:47:20 +0000259 { "Philips", 0x0471, "GoGear SA9200", 0x014f, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000260 // From John Coppens <jcoppens@users.sourceforge.net>
261 { "Philips", 0x0471, "SA1115/55", 0x0164, DEVICE_FLAG_NONE },
262 // From Gerhard Mekenkamp
263 { "Philips", 0x0471, "GoGear Audio", 0x0165, DEVICE_FLAG_NONE },
264 // from David Holm <wormie@alberg.dk>
265 { "Philips", 0x0471, "Shoqbox", 0x0172, DEVICE_FLAG_ONLY_7BIT_FILENAMES },
266 // from npedrosa
267 { "Philips", 0x0471, "PSA610", 0x0181, DEVICE_FLAG_NONE },
268 // From libgphoto2 source
269 { "Philips", 0x0471, "HDD6320", 0x01eb, DEVICE_FLAG_NONE },
270 // From Detlef Meier <dm@emlix.com>
Linus Walleija8ba8c72008-03-29 00:02:27 +0000271 { "Philips", 0x0471, "GoGear SA6014/SA6015/SA6024/SA6025/SA6044/SA6045", 0x084e, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij23ab1542008-01-06 22:10:34 +0000272 // From anonymous Sourceforge user SA5145/02
Linus Walleija8ba8c72008-03-29 00:02:27 +0000273 { "Philips", 0x0471, "GoGear SA5145", 0x0857, DEVICE_FLAG_UNLOAD_DRIVER },
274 // From a
275 { "Philips", 0x0471, "GoGear SA6125/SA6145/SA6185", 0x2002, DEVICE_FLAG_UNLOAD_DRIVER },
276 // From anonymous Sourceforge user, not verified to be MTP!
277 { "Philips", 0x0471, "GoGear SA3345", 0x2004, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij2242b022009-01-02 01:44:00 +0000278 // From Roberto Vidmar <rvidmar@libero.it>
279 { "Philips", 0x0471, "SA5285", 0x2022, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij15ed3b32009-07-23 22:19:43 +0000280 // From Elie De Brauwer <elie@de-brauwer.be>
281 { "Philips", 0x0471, "GoGear ViBE SA1VBE04", 0x2075,
282 DEVICE_FLAG_UNLOAD_DRIVER },
283 // From Elie De Brauwer <elie@de-brauwer.be>
284 { "Philips", 0x0471, "GoGear ViBE SA1VBE08", 0x207b,
285 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijd866d242009-08-23 21:50:39 +0000286 // From josmtx <josmtx@users.sourceforge.net>
287 { "Philips", 0x0471, "GoGear Aria", 0x207c,
288 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000289 // from XNJB user
290 { "Philips", 0x0471, "PSA235", 0x7e01, DEVICE_FLAG_NONE },
291
292
293 /*
294 * SanDisk
295 * several devices (c150 for sure) are definately dual-mode and must
296 * have the USB mass storage driver that hooks them unloaded first.
297 * They all have problematic dual-mode making the device unload effect
Linus Walleij5e202562008-06-03 11:35:05 +0000298 * uncertain on these devices.
299 *
300 * All older devices seem to need DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL.
301 * Old chipsets: e200/c200 use PP5024 from Nvidia (formerly PortalPlayer).
302 * m200 use TCC770 from Telechips.
303 *
304 * The newer Sansa v2 chipset, AD3525 from Austriamicrosystems (AMS) found
305 * in e280 v2 c200 v2, Clip, Fuze etc require DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST
306 * and DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR to work properly.
307 *
308 * For more info see: http://daniel.haxx.se/sansa/v2.html
Linus Walleij1a673de2007-10-29 23:10:05 +0000309 */
310 // Reported by Brian Robison
Linus Walleijde1620f2009-06-15 20:02:02 +0000311 { "SanDisk", 0x0781, "Sansa m230/m240", 0x7400,
Linus Walleij1a673de2007-10-29 23:10:05 +0000312 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000313 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij18ed0162009-05-06 16:51:08 +0000314 // From Rockbox device listing
Linus Walleijde1620f2009-06-15 20:02:02 +0000315 { "SanDisk", 0x0781, "Sansa m200-tcc (MTP mode)", 0x7401,
Linus Walleij18ed0162009-05-06 16:51:08 +0000316 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
317 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000318 // Reported by tangent_@users.sourceforge.net
Linus Walleijde1620f2009-06-15 20:02:02 +0000319 { "SanDisk", 0x0781, "Sansa c150", 0x7410,
Linus Walleij1a673de2007-10-29 23:10:05 +0000320 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000321 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000322 // From libgphoto2 source
323 // Reported by <gonkflea@users.sourceforge.net>
324 // Reported by Mike Owen <mikeowen@computerbaseusa.com>
Linus Walleij18ed0162009-05-06 16:51:08 +0000325 { "SanDisk", 0x0781, "Sansa e200/e250/e260/e270/e280", 0x7420,
Linus Walleij1a673de2007-10-29 23:10:05 +0000326 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000327 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Richard Low58f5afe2009-04-30 13:24:06 +0000328 // Don't add 0x7421 as this is e280 in MSC mode
Linus Walleij1a673de2007-10-29 23:10:05 +0000329 // Reported by XNJB user
Linus Walleij18ed0162009-05-06 16:51:08 +0000330 { "SanDisk", 0x0781, "Sansa e260/e280 v2", 0x7422,
Linus Walleij5e202562008-06-03 11:35:05 +0000331 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij37588142008-10-16 19:10:47 +0000332 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000333 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Richard Lowd56e8a62007-12-08 16:59:11 +0000334 // Reported by XNJB user
Linus Walleijde1620f2009-06-15 20:02:02 +0000335 { "SanDisk", 0x0781, "Sansa m240/m250", 0x7430,
Linus Walleij1a673de2007-10-29 23:10:05 +0000336 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000337 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij077a8902007-11-15 21:18:12 +0000338 // Reported by Eugene Brevdo <ebrevdo@princeton.edu>
Linus Walleij5e202562008-06-03 11:35:05 +0000339 { "SanDisk", 0x0781, "Sansa Clip", 0x7432,
340 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij37588142008-10-16 19:10:47 +0000341 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000342 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
Linus Walleij39f9a452008-11-15 09:39:39 +0000343 // Reported by HackAR <hackar@users.sourceforge.net>
Linus Walleij624a15a2009-01-06 00:31:34 +0000344 { "SanDisk", 0x0781, "Sansa Clip v2", 0x7434,
Linus Walleij39f9a452008-11-15 09:39:39 +0000345 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
346 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
347 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
Linus Walleij1a673de2007-10-29 23:10:05 +0000348 // Reported by anonymous user at sourceforge.net
Linus Walleijde1620f2009-06-15 20:02:02 +0000349 { "SanDisk", 0x0781, "Sansa c240/c250", 0x7450,
Linus Walleij1a673de2007-10-29 23:10:05 +0000350 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000351 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij2242b022009-01-02 01:44:00 +0000352 // Reported by anonymous SourceForge user
Linus Walleijde1620f2009-06-15 20:02:02 +0000353 { "SanDisk", 0x0781, "Sansa c250 v2", 0x7452,
Linus Walleij2242b022009-01-02 01:44:00 +0000354 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
355 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000356 // Reported by Troy Curtis Jr.
Linus Walleijde1620f2009-06-15 20:02:02 +0000357 { "SanDisk", 0x0781, "Sansa Express", 0x7460,
358 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000359 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij1a673de2007-10-29 23:10:05 +0000360 // Reported by XNJB user, and Miguel de Icaza <miguel@gnome.org>
361 // This has no dual-mode so no need to unload any driver.
362 // This is a Linux based device!
363 { "SanDisk", 0x0781, "Sansa Connect", 0x7480, DEVICE_FLAG_NONE },
364 // Reported by anonymous SourceForge user
Linus Walleijde1620f2009-06-15 20:02:02 +0000365 { "SanDisk", 0x0781, "Sansa View", 0x74b0,
Linus Walleij1a673de2007-10-29 23:10:05 +0000366 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000367 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleij690a3162008-03-31 21:40:23 +0000368 // Reported by Patrick <skibler@gmail.com>
369 // There are apparently problems with this device.
Linus Walleij25a16302009-03-04 13:56:33 +0000370 { "SanDisk", 0x0781, "Sansa Fuze", 0x74c0,
371 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
372 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
373 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
374 // Harry Phillips <tuxcomputers@users.sourceforge.net>
375 { "SanDisk", 0x0781, "Sansa Fuze v2", 0x74c2,
Linus Walleij5e202562008-06-03 11:35:05 +0000376 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij37588142008-10-16 19:10:47 +0000377 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
Linus Walleijcf8dc2b2008-10-21 13:58:36 +0000378 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED },
Linus Walleija5cb5c92009-10-10 22:03:38 +0000379 // Reported by anonymous SourceForge user
380 { "SanDisk", 0x0781, "Sansa Clip+", 0x74d0,
381 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
382 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR |
383 DEVICE_FLAG_CANNOT_HANDLE_DATEMODIFIED},
384
Linus Walleij1a673de2007-10-29 23:10:05 +0000385
386 /*
387 * iRiver
388 * we assume that PTP_OC_MTP_GetObjPropList is essentially
389 * broken on all iRiver devices, meaning it simply won't return
390 * all properties for a file when asking for metadata 0xffffffff.
391 * Please test on your device if you believe it isn't broken!
Linus Walleij1a673de2007-10-29 23:10:05 +0000392 */
Linus Walleij18ed0162009-05-06 16:51:08 +0000393 { "iRiver", 0x1006, "H300 Series MTP", 0x3004,
Linus Walleij1a673de2007-10-29 23:10:05 +0000394 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
395 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij18ed0162009-05-06 16:51:08 +0000396 { "iRiver", 0x1006, "Portable Media Center", 0x4002,
397 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
398 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
399 { "iRiver", 0x1006, "Portable Media Center", 0x4003,
Linus Walleij1a673de2007-10-29 23:10:05 +0000400 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
401 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij2242b022009-01-02 01:44:00 +0000402 // From [st]anislav <iamstanislav@gmail.com>
Linus Walleijdeb1aca2009-01-02 23:20:06 +0000403 { "iRiver", 0x1042, "T7 Volcano", 0x1143, DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij80a2a692008-12-05 20:36:40 +0000404 // From an anonymous person at SourceForge, uncertain about this one
Linus Walleij1a673de2007-10-29 23:10:05 +0000405 { "iRiver", 0x4102, "iFP-880", 0x1008,
406 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
407 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleij80a2a692008-12-05 20:36:40 +0000408 // 0x4102, 0x1042 is a USB mass storage mode for E100 v2/Lplayer
Linus Walleij1a673de2007-10-29 23:10:05 +0000409 // From libgphoto2 source
410 { "iRiver", 0x4102, "T10", 0x1113,
411 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
412 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
413 { "iRiver", 0x4102, "T20 FM", 0x1114,
414 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
415 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
416 // This appears at the MTP-UMS site
417 { "iRiver", 0x4102, "T20", 0x1115,
418 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
419 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
420 { "iRiver", 0x4102, "U10", 0x1116,
421 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
422 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleijfcd4d372007-11-18 21:56:32 +0000423 { "iRiver", 0x4102, "T10a", 0x1117,
Linus Walleij1a673de2007-10-29 23:10:05 +0000424 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
425 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
426 { "iRiver", 0x4102, "T20", 0x1118,
427 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
428 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
429 { "iRiver", 0x4102, "T30", 0x1119,
430 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
431 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
432 // Reported by David Wolpoff
433 { "iRiver", 0x4102, "T10 2GB", 0x1120,
434 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
435 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
436 // Rough guess this is the MTP device ID...
437 { "iRiver", 0x4102, "N12", 0x1122,
438 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
439 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
440 // Reported by Philip Antoniades <philip@mysql.com>
441 // Newer iriver devices seem to have shaped-up firmware without any
442 // of the annoying bugs.
443 { "iRiver", 0x4102, "Clix2", 0x1126, DEVICE_FLAG_NONE },
444 // Reported by Adam Torgerson
445 { "iRiver", 0x4102, "Clix", 0x112a,
446 DEVICE_FLAG_NO_ZERO_READS | DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
447 // Reported by Douglas Roth <dougaus@gmail.com>
448 { "iRiver", 0x4102, "X20", 0x1132,
449 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
450 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
451 // Reported by Robert Ugo <robert_ugo@users.sourceforge.net>
452 { "iRiver", 0x4102, "T60", 0x1134,
453 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
454 DEVICE_FLAG_IRIVER_OGG_ALZHEIMER },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000455 // Reported by two anonymous SourceForge users
Linus Walleij07bb5382008-07-31 20:21:09 +0000456 // Needs the stronger OGG_IS_UNKNOWN flag to support OGG properly,
457 // be aware of newer players that may be needing this too.
Linus Walleijf8c251e2008-06-08 21:32:01 +0000458 { "iRiver", 0x4102, "E100", 0x1141,
459 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij07bb5382008-07-31 20:21:09 +0000460 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000461 // Reported by anonymous SourceForge user
462 // Need verification of whether this firmware really need all these flags
Linus Walleij80a2a692008-12-05 20:36:40 +0000463 { "iRiver", 0x4102, "E100 v2/Lplayer", 0x1142,
Linus Walleijc2bc9732008-08-14 21:12:44 +0000464 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
465 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij6e680ad2009-01-07 21:22:45 +0000466 // Reported by Richard Vennemann <vennemann@users.sourceforge.net>
Linus Walleij16ee3422009-01-08 23:15:52 +0000467 // In USB Mass Storage mode it is 0x4102/0x1047
Linus Walleijb57167c2009-01-10 22:37:51 +0000468 // Seems to use the new shaped-up firmware.
469 { "iRiver", 0x4102, "Spinn", 0x1147, DEVICE_FLAG_NONE },
Linus Walleije84dcf12009-05-14 20:33:05 +0000470 // Reported by Tony Janssen <tonyjanssen@users.sourceforge.net>
471 { "iRiver", 0x4102, "E50", 0x1151,
472 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
473 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +0000474 // Reported by Scott Call
Linus Walleij07bb5382008-07-31 20:21:09 +0000475 // Assume this actually supports OGG though it reports it doesn't.
Linus Walleij1a673de2007-10-29 23:10:05 +0000476 { "iRiver", 0x4102, "H10 20GB", 0x2101,
477 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij07bb5382008-07-31 20:21:09 +0000478 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij18ed0162009-05-06 16:51:08 +0000479 { "iRiver", 0x4102, "H10 5GB", 0x2102,
480 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
481 DEVICE_FLAG_OGG_IS_UNKNOWN },
482 // From Rockbox device listing
483 { "iRiver", 0x4102, "H10 5.6GB", 0x2105,
Linus Walleij1a673de2007-10-29 23:10:05 +0000484 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_NO_ZERO_READS |
Linus Walleij07bb5382008-07-31 20:21:09 +0000485 DEVICE_FLAG_OGG_IS_UNKNOWN },
Linus Walleij1a673de2007-10-29 23:10:05 +0000486
487
488 /*
489 * Dell
490 */
491 { "Dell, Inc", 0x413c, "DJ Itty", 0x4500, DEVICE_FLAG_NONE },
492
493 /*
494 * Toshiba
Linus Walleij7e3b3072009-01-19 22:51:17 +0000495 * Tentatively flagged all Toshiba devices with
496 * DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST after one of them
497 * showed erroneous behaviour.
Linus Walleij1a673de2007-10-29 23:10:05 +0000498 */
Linus Walleij7e3b3072009-01-19 22:51:17 +0000499 { "Toshiba", 0x0930, "Gigabeat MEGF-40", 0x0009,
500 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
501 { "Toshiba", 0x0930, "Gigabeat", 0x000c,
502 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000503 // Reported by Nicholas Tripp
Linus Walleij7e3b3072009-01-19 22:51:17 +0000504 { "Toshiba", 0x0930, "Gigabeat P20", 0x000f,
505 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000506 // From libgphoto2
Linus Walleij7e3b3072009-01-19 22:51:17 +0000507 { "Toshiba", 0x0930, "Gigabeat S", 0x0010, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL |
508 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000509 // Reported by Rob Brown
Linus Walleij7e3b3072009-01-19 22:51:17 +0000510 { "Toshiba", 0x0930, "Gigabeat P10", 0x0011,
511 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij51dde6b2007-11-03 23:14:59 +0000512 // Reported by solanum@users.sourceforge.net
Linus Walleij7e3b3072009-01-19 22:51:17 +0000513 { "Toshiba", 0x0930, "Gigabeat V30", 0x0014,
514 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000515 // Reported by Michael Davis <slithy@yahoo.com>
Linus Walleij7e3b3072009-01-19 22:51:17 +0000516 { "Toshiba", 0x0930, "Gigabeat U", 0x0016,
517 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij804cc622008-02-03 21:26:26 +0000518 // Reported by Devon Jacobs <devo@godevo.com>
Linus Walleijf67c1ad2009-01-14 21:39:50 +0000519 { "Toshiba", 0x0930, "Gigabeat MEU202", 0x0018,
520 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleijc76e2f72007-12-09 22:14:35 +0000521 // Reported by Rolf <japan (at) dl3lar.de>
Linus Walleij7e3b3072009-01-19 22:51:17 +0000522 { "Toshiba", 0x0930, "Gigabeat T", 0x0019,
523 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij07bb5382008-07-31 20:21:09 +0000524 // Reported by Phil Ingram <ukpbert@users.sourceforge.net>
525 // Tentatively added - no real reports of this device ID being MTP,
526 // reports as USB Mass Storage currently.
Linus Walleij7e3b3072009-01-19 22:51:17 +0000527 { "Toshiba", 0x0930, "Gigabeat MEU201", 0x001a,
528 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij922880f2008-10-29 17:31:42 +0000529 // Reported by anonymous SourceForge user
Linus Walleij7e3b3072009-01-19 22:51:17 +0000530 { "Toshiba", 0x0930, "Gigabeat MET401", 0x001d,
531 DEVICE_FLAG_NO_RELEASE_INTERFACE | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
Linus Walleij804cc622008-02-03 21:26:26 +0000532
Linus Walleij1a673de2007-10-29 23:10:05 +0000533 /*
534 * Archos
535 * These devices have some dual-mode interfaces which will really
536 * respect the driver unloading, so DEVICE_FLAG_UNLOAD_DRIVER
537 * really work on these devices!
538 */
539 // Reported by Alexander Haertig <AlexanderHaertig@gmx.de>
540 { "Archos", 0x0e79, "Gmini XS100", 0x1207, DEVICE_FLAG_UNLOAD_DRIVER },
541 // Added by Jan Binder
542 { "Archos", 0x0e79, "XS202 (MTP mode)", 0x1208, DEVICE_FLAG_NONE },
543 // Reported by gudul1@users.sourceforge.net
544 { "Archos", 0x0e79, "104 (MTP mode)", 0x120a, DEVICE_FLAG_NONE },
Richard Lowe525e542009-11-09 21:09:52 +0000545 // Reported by Archos
546 { "Archos", 0x0e79, "204 (MTP mode)", 0x120c, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij4c3cd682008-01-27 22:18:05 +0000547 // Reported by anonymous Sourceforge user.
548 { "Archos", 0x0e79, "404 (MTP mode)", 0x1301, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000549 // Reported by Archos
550 { "Archos", 0x0e79, "404CAM (MTP mode)", 0x1303, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000551 // Reported by Etienne Chauchot <chauchot.etienne@free.fr>
552 { "Archos", 0x0e79, "504 (MTP mode)", 0x1307, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000553 // Reported by Archos
554 { "Archos", 0x0e79, "604 (MTP mode)", 0x1309, DEVICE_FLAG_UNLOAD_DRIVER },
555 { "Archos", 0x0e79, "604WIFI (MTP mode)", 0x130b, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000556 // Reported by Kay McCormick <kaym@modsystems.com>
557 { "Archos", 0x0e79, "704 mobile dvr", 0x130d, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000558 // Reported by Archos
559 { "Archos", 0x0e79, "704TV (MTP mode)", 0x130f, DEVICE_FLAG_UNLOAD_DRIVER },
560 { "Archos", 0x0e79, "405 (MTP mode)", 0x1311, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij121b7f22007-12-08 21:37:35 +0000561 // Reported by Joe Rabinoff
Linus Walleije71639a2007-12-08 21:36:00 +0000562 { "Archos", 0x0e79, "605 (MTP mode)", 0x1313, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000563 // Reported by Archos
564 { "Archos", 0x0e79, "605F (MTP mode)", 0x1315, DEVICE_FLAG_UNLOAD_DRIVER },
565 { "Archos", 0x0e79, "705 (MTP mode)", 0x1319, DEVICE_FLAG_UNLOAD_DRIVER },
566 { "Archos", 0x0e79, "TV+ (MTP mode)", 0x131b, DEVICE_FLAG_UNLOAD_DRIVER },
567 { "Archos", 0x0e79, "105 (MTP mode)", 0x131d, DEVICE_FLAG_UNLOAD_DRIVER },
568 { "Archos", 0x0e79, "405HDD (MTP mode)", 0x1321, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij4aa66dc2009-05-02 06:36:59 +0000569 // Reported by Jim Krehl <jimmuhk@users.sourceforge.net>
570 { "Archos", 0x0e79, "5 (MTP mode)", 0x1331, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij8c725002008-11-25 20:33:13 +0000571 // Reported by Adrien Guichard <tmor@users.sourceforge.net>
572 { "Archos", 0x0e79, "5 (MTP mode)", 0x1333, DEVICE_FLAG_UNLOAD_DRIVER },
Richard Lowe525e542009-11-09 21:09:52 +0000573 // Reported by Archos
574 { "Archos", 0x0e79, "7 (MTP mode)", 0x1335, DEVICE_FLAG_UNLOAD_DRIVER },
575 { "Archos", 0x0e79, "SPOD (MTP mode)", 0x1341, DEVICE_FLAG_UNLOAD_DRIVER },
576 { "Archos", 0x0e79, "5S IT (MTP mode)", 0x1351, DEVICE_FLAG_UNLOAD_DRIVER },
577 { "Archos", 0x0e79, "5H IT (MTP mode)", 0x1357, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000578
579 /*
580 * Dunlop (OEM of EGOMAN ltd?) reported by Nanomad
581 * This unit is falsely detected as USB mass storage in Linux
582 * prior to kernel 2.6.19 (fixed by patch from Alan Stern)
583 * so on older kernels special care is needed to remove the
584 * USB mass storage driver that erroneously binds to the device
585 * interface.
586 */
587 { "Dunlop", 0x10d6, "MP3 player 1GB / EGOMAN MD223AFD", 0x2200, DEVICE_FLAG_UNLOAD_DRIVER},
Linus Walleij07bb5382008-07-31 20:21:09 +0000588 // Reported by Steven Black <stevenblack1956@users.sourceforge.net>
589 // Obviously this company goes by many names.
Linus Walleij102a72d2008-11-27 23:16:47 +0000590 // This device is USB 2.0 only. Broken pipe on closing.
591 { "Memorex", 0x10d6, "MMP 8585/8586", 0x2300, DEVICE_FLAG_UNLOAD_DRIVER |
592 DEVICE_FLAG_NO_RELEASE_INTERFACE},
Linus Walleij414a0832009-09-18 23:04:05 +0000593
Linus Walleij1a673de2007-10-29 23:10:05 +0000594 /*
595 * Sirius
596 */
597 { "Sirius", 0x18f6, "Stiletto", 0x0102, DEVICE_FLAG_NONE },
Linus Walleij30a7dd92008-04-09 20:33:51 +0000598 // Reported by Chris Bagwell <chris@cnpbagwell.com>
Linus Walleij2f622812008-08-30 22:06:58 +0000599 { "Sirius", 0x18f6, "Stiletto 2", 0x0110, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000600
601 /*
602 * Canon
Linus Walleija1a2eb72009-10-14 21:51:12 +0000603 * These are actually cameras, but they have a Microsoft device descriptor
604 * and reports themselves as supporting the MTP extension.
Linus Walleij1a673de2007-10-29 23:10:05 +0000605 */
Linus Walleija1a2eb72009-10-14 21:51:12 +0000606 { "Canon", 0x04a9, "Ixus Digital 700 (PTP/MTP mode)", 0x30f2,
607 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij00e6a5e2008-10-17 07:13:30 +0000608 { "Canon", 0x04a9, "PowerShot A640 (PTP/MTP mode)", 0x3139,
609 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000610
611 /*
612 * Nokia
Linus Walleij21704fd2008-02-29 22:50:29 +0000613 * Please verify the low device IDs here, I suspect these might be for
614 * things like USB storage or modem mode actually, whereas the higher
Linus Walleij9462f552008-10-25 19:16:53 +0000615 * range (0x04nn) could be for MTP. Some of the devices were gathered
616 * from the Nokia WMP drivers:
617 * http://nds2.nokia.com/files/support/global/phones/software/
618 * Address was gathered from going to:
619 * nseries.com
620 * -> support
621 * -> select supported device
622 * -> PC software
623 * -> Music software
624 * -> Windows Media Player 10 driver
Linus Walleij1a673de2007-10-29 23:10:05 +0000625 */
626 // From: DoomHammer <gaczek@users.sourceforge.net>
Linus Walleijb5a4f922008-05-11 20:15:00 +0000627 { "Nokia", 0x0421, "N81 Mobile Phone", 0x000a, DEVICE_FLAG_NONE },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000628 // From an anonymous SourceForge user
629 { "Nokia", 0x0421, "6120c Classic Mobile Phone", 0x002e, DEVICE_FLAG_NONE },
Linus Walleijbddfd192008-11-25 20:26:52 +0000630 // From Stefano
631 { "Nokia", 0x0421, "N96 Mobile Phone", 0x0039, DEVICE_FLAG_NONE },
Linus Walleijace7f4c2008-11-01 21:07:34 +0000632 // From Martijn van de Streek <martijn@vandestreek.net>
Linus Walleij4c8b6e12008-10-31 22:04:14 +0000633 { "Nokia", 0x0421, "6500c Classic Mobile Phone", 0x003c, DEVICE_FLAG_NONE },
Linus Walleijb5a4f922008-05-11 20:15:00 +0000634 // From: DoomHammer <gaczek@users.sourceforge.net>
Linus Walleij1a673de2007-10-29 23:10:05 +0000635 { "Nokia", 0x0421, "3110c Mobile Phone", 0x005f, DEVICE_FLAG_NONE },
Linus Walleija8ba8c72008-03-29 00:02:27 +0000636 // From: Vasily <spc-@users.sourceforge.net>
637 { "Nokia", 0x0421, "3109c Mobile Phone", 0x0065, DEVICE_FLAG_NONE },
Linus Walleij07bb5382008-07-31 20:21:09 +0000638 // From: <rawc@users.sourceforge.net>
639 { "Nokia", 0x0421, "5310 XpressMusic", 0x006c, DEVICE_FLAG_NONE },
Linus Walleij21704fd2008-02-29 22:50:29 +0000640 // From: robin (AT) headbank D0Tco DOTuk
641 { "Nokia", 0x0421, "N95 Mobile Phone 8GB", 0x006e, DEVICE_FLAG_NONE },
Linus Walleijcfd143d2008-10-24 20:52:48 +0000642 // From Bastien Nocera <hadess@hadess.net>
643 { "Nokia", 0x0421, "N82 Mobile Phone", 0x0074, DEVICE_FLAG_NONE },
Linus Walleijace7f4c2008-11-01 21:07:34 +0000644 // From Martijn van de Streek <martijn@vandestreek.net>
Linus Walleij4c8b6e12008-10-31 22:04:14 +0000645 { "Nokia", 0x0421, "N78 Mobile Phone", 0x0079, DEVICE_FLAG_NONE },
Linus Walleij22e4bfc2009-02-09 23:24:58 +0000646 // From William Pettersson <the_enigma@users.sourceforge.net>
647 { "Nokia", 0x0421, "6220 Classic", 0x008d, DEVICE_FLAG_NONE },
Linus Walleijbbf5e7f2009-03-05 21:04:42 +0000648 // From kellerkev@gmail.com
649 { "Nokia", 0x0421, "N85 Mobile Phone", 0x0092, DEVICE_FLAG_NONE },
Linus Walleij07bb5382008-07-31 20:21:09 +0000650 // From: danielw
651 { "Nokia", 0x0421, "E71", 0x00e4, DEVICE_FLAG_NONE },
Linus Walleijf3296622008-09-04 20:53:56 +0000652 // From: Laurent Bigonville <bigon@users.sourceforge.net>
653 { "Nokia", 0x0421, "E66", 0x00e5, DEVICE_FLAG_NONE },
Linus Walleij1d139362009-05-02 06:22:44 +0000654 // From: Pier <pierlucalino@users.sourceforge.net>
655 { "Nokia", 0x0421, "5320 XpressMusic", 0x00ea, DEVICE_FLAG_NONE },
Linus Walleij18faccb2009-08-03 20:21:55 +0000656 // From: Gausie <innerdreams@users.sourceforge.net>
657 { "Nokia", 0x0421, "5800 XpressMusic", 0x0154, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij79547002009-02-02 21:05:14 +0000658 // From: Willy Gardiol (web) <willy@gardiol.org>
Linus Walleij22e4bfc2009-02-09 23:24:58 +0000659 // Spurious errors for getting all objects, lead me to believe this flag atleast is needed
Linus Walleij18faccb2009-08-03 20:21:55 +0000660 { "Nokia", 0x0421, "5800 XpressMusic v2", 0x0155, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij5b4d8e02009-01-07 21:44:59 +0000661 // From an anonymous SourceForge user
662 // Not verified to be MTP
663 { "Nokia", 0x0421, "E63", 0x0179, DEVICE_FLAG_NONE },
Linus Walleij4fe08902009-08-03 20:27:27 +0000664 // From: FunkyPenguin <awafaa@users.sourceforge.net>
665 { "Nokia", 0x0421, "N97", 0x01f5, DEVICE_FLAG_NONE },
Linus Walleij5ffcec92009-09-03 21:16:36 +0000666 // From: Alexander Kojevnikov <alex-kay@users.sourceforge.net>
667 { "Nokia", 0x0421, "6600i", 0x0297, DEVICE_FLAG_NONE },
Linus Walleij89af6bb2009-04-06 22:02:51 +0000668 // https://sourceforge.net/tracker/index.php?func=detail&aid=2692473&group_id=8874&atid=358874
669 { "Nokia", 0x0421, "5200", 0x0421, DEVICE_FLAG_NONE },
Linus Walleij60144512008-10-25 19:11:48 +0000670 // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_3250_WMP10_driver.inf
671 { "Nokia", 0x0421, "3250 Mobile Phone", 0x0462, DEVICE_FLAG_NONE },
672 // From http://nds2.nokia.com/files/support/global/phones/software/Nokia_N93_WMP10_Driver.inf
673 { "Nokia", 0x0421, "N93 Mobile Phone", 0x0478, DEVICE_FLAG_NONE },
674 // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_5500_Sport_WMP10_driver.inf
675 { "Nokia", 0x0421, "5500 Sport Mobile Phone", 0x047e, DEVICE_FLAG_NONE },
676 // From http://nds2.nokia.com/files/support/global/phones/software/Nokia_N91_WMP10_Driver.inf
677 { "Nokia", 0x0421, "N91 Mobile Phone", 0x0485, DEVICE_FLAG_NONE },
Linus Walleij250ef742008-04-05 20:11:44 +0000678 // From: Christian Rusa <kristous@users.sourceforge.net>
679 { "Nokia", 0x0421, "5700 XpressMusic Mobile Phone", 0x04b4, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000680 // From: Mitchell Hicks <mitchix@yahoo.com>
681 { "Nokia", 0x0421, "5300 Mobile Phone", 0x04ba, DEVICE_FLAG_NONE },
682 // From Christian Arnold <webmaster@arctic-media.de>
683 { "Nokia", 0x0421, "N73 Mobile Phone", 0x04d1, DEVICE_FLAG_UNLOAD_DRIVER },
684 // From Swapan <swapan@yahoo.com>
685 { "Nokia", 0x0421, "N75 Mobile Phone", 0x04e1, DEVICE_FLAG_NONE },
Linus Walleij60144512008-10-25 19:11:48 +0000686 // From: http://nds2.nokia.com/files/support/global/phones/software/Nokia_N93i_WMP10_driver.inf
687 { "Nokia", 0x0421, "N93i Mobile Phone", 0x04e5, DEVICE_FLAG_NONE },
Linus Walleija6d0d482007-10-31 08:54:56 +0000688 // From Anonymous Sourceforge User
689 { "Nokia", 0x0421, "N95 Mobile Phone", 0x04ef, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000690 // From: Pat Nicholls <pat@patandannie.co.uk>
691 { "Nokia", 0x0421, "N80 Internet Edition (Media Player)", 0x04f1, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij67465c12009-08-23 21:56:26 +0000692 // Reported by Richard Wall <richard@the-moon.net>
693 { "Nokia", 0x05c6, "5530 Xpressmusic", 0x0229, DEVICE_FLAG_NONE },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000694 // Reported by anonymous SourceForge user
695 // One thing stated by reporter (Nokia model) another by the detect log...
696 { "Nokia/Verizon", 0x05c6, "6205 Balboa/Verizon Music Phone", 0x3196, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000697
Linus Walleija6d0d482007-10-31 08:54:56 +0000698
Linus Walleij1a673de2007-10-29 23:10:05 +0000699 /*
Linus Walleij83475632009-11-07 14:36:44 +0000700 * Vendor ID 0x13d1 is some offshoring company in China,
701 * in one source named "A-Max Technology Macao Commercial
702 * Offshore Co. Ltd." sometime "CCTech".
Linus Walleij1a673de2007-10-29 23:10:05 +0000703 */
Linus Walleij83475632009-11-07 14:36:44 +0000704 // Logik brand
Linus Walleij1a673de2007-10-29 23:10:05 +0000705 { "Logik", 0x13d1, "LOG DAX MP3 and DAB Player", 0x7002, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij83475632009-11-07 14:36:44 +0000706 // Technika brand
707 // Reported by <Ooblick@users.sourceforge.net>
708 { "Technika", 0x13d1, "MP-709", 0x7017, DEVICE_FLAG_UNLOAD_DRIVER },
709
Linus Walleij1a673de2007-10-29 23:10:05 +0000710
711 /*
712 * RCA / Thomson
713 */
714 // From kiki <omkiki@users.sourceforge.net>
715 { "Thomson", 0x069b, "EM28 Series", 0x0774, DEVICE_FLAG_NONE },
Richard Low957ffba2008-01-21 17:31:20 +0000716 { "Thomson / RCA", 0x069b, "Opal / Lyra MC4002", 0x0777, DEVICE_FLAG_NONE },
Linus Walleij01fc9c82009-03-10 23:52:09 +0000717 { "Thomson", 0x069b, "Lyra MC5104B (M51 Series)", 0x077c, DEVICE_FLAG_NONE },
Linus Walleij2c414c42008-01-19 07:11:19 +0000718 { "Thomson", 0x069b, "RCA H106", 0x301a, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000719 // From Svenna <svenna@svenna.de>
720 // Not confirmed to be MTP.
721 { "Thomson", 0x069b, "scenium E308", 0x3028, DEVICE_FLAG_NONE },
Richard Lowa11a6ad2008-01-21 17:23:55 +0000722 // From XNJB user
Richard Low957ffba2008-01-21 17:31:20 +0000723 { "Thomson / RCA", 0x069b, "Lyra HC308A", 0x3035, DEVICE_FLAG_NONE },
Linus Walleij2aa35742009-11-07 14:39:03 +0000724
Linus Walleij1a673de2007-10-29 23:10:05 +0000725 /*
726 * NTT DoCoMo
727 */
728 { "FOMA", 0x04c5, "F903iX HIGH-SPEED", 0x1140, DEVICE_FLAG_NONE },
729
730 /*
731 * Palm device userland program named Pocket Tunes
732 * Reported by Peter Gyongyosi <gyp@impulzus.com>
733 */
Linus Walleijfc438072008-10-31 21:12:43 +0000734 { "NormSoft, Inc.", 0x1703, "Pocket Tunes", 0x0001, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000735 // Reported by anonymous submission
Linus Walleijfc438072008-10-31 21:12:43 +0000736 { "NormSoft, Inc.", 0x1703, "Pocket Tunes 4", 0x0002, DEVICE_FLAG_NONE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000737
738 /*
Linus Walleijf6612032009-07-23 22:50:57 +0000739 * TrekStor, Medion and Maxfield devices
Linus Walleij1a673de2007-10-29 23:10:05 +0000740 * Their datasheet claims their devices are dualmode so probably needs to
741 * unload the attached drivers here.
742 */
743 // Reported by Stefan Voss <svoss@web.de>
Linus Walleij10b06d42007-11-05 11:32:07 +0000744 // This is a Sigmatel SoC with a hard disk.
Linus Walleijd866d242009-08-23 21:50:39 +0000745 { "TrekStor", 0x066f, "Vibez 8/12GB", 0x842a,
Linus Walleij07bb5382008-07-31 20:21:09 +0000746 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
747 // Reported by anonymous SourceForge user.
748 // This one done for Medion, whatever that is. Error reported so assume
749 // the same bug flag as its ancestor above.
750 { "Medion", 0x066f, "MD8333", 0x8550,
751 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijf6612032009-07-23 22:50:57 +0000752 // Reported by anonymous SourceForge user
Linus Walleijdc33ef92008-11-15 09:45:53 +0000753 { "Medion", 0x066f, "MD8333", 0x8588,
754 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijf6612032009-07-23 22:50:57 +0000755 // Reported by anonymous SourceForge user
756 { "Maxfield", 0x066f, "G-Flash NG 1GB", 0x846c,
757 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000758 // Reported by Cristi Magherusan <majeru@gentoo.ro>
Linus Walleijd866d242009-08-23 21:50:39 +0000759 { "TrekStor", 0x0402, "i.Beat Sweez FM", 0x0611,
760 DEVICE_FLAG_UNLOAD_DRIVER },
761 // Reported by Fox-ino <fox-ino@users.sourceforge.net>
762 { "ALi Corp.", 0x0402, "MPMAN 2GB", 0x5668,
Linus Walleij07bb5382008-07-31 20:21:09 +0000763 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij2a7c6c72009-05-19 22:33:43 +0000764 // Reported by Anonymous SourceForge user
765 {"TrekStor", 0x1e68, "i.Beat Organix 2.0", 0x0002,
766 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleijd866d242009-08-23 21:50:39 +0000767
Linus Walleij1a673de2007-10-29 23:10:05 +0000768 /*
Linus Walleijf88b5a42009-04-20 22:36:41 +0000769 * Disney/Tevion/MyMusix
Linus Walleij1a673de2007-10-29 23:10:05 +0000770 */
771 // Reported by XNJB user
772 { "Disney", 0x0aa6, "MixMax", 0x6021, DEVICE_FLAG_NONE },
Linus Walleij21704fd2008-02-29 22:50:29 +0000773 // Reported by anonymous Sourceforge user
774 { "Tevion", 0x0aa6, "MD 81488", 0x3011, DEVICE_FLAG_NONE },
Linus Walleijf88b5a42009-04-20 22:36:41 +0000775 // Reported by Peter Hedlund <peter@peterandlinda.com>
776 { "MyMusix", 0x0aa6, "PD-6070", 0x9601, DEVICE_FLAG_UNLOAD_DRIVER |
777 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
778 DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST |
779 DEVICE_FLAG_NO_RELEASE_INTERFACE },
Linus Walleij1a673de2007-10-29 23:10:05 +0000780
781 /*
782 * Cowon Systems, Inc.
783 * The iAudio audiophile devices don't encourage the use of MTP.
784 */
785 // Reported by Patrik Johansson <Patrik.Johansson@qivalue.com>
Linus Walleij7e3b3072009-01-19 22:51:17 +0000786 { "Cowon", 0x0e21, "iAudio U3 (MTP mode)", 0x0701,
787 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijee387d72008-11-12 23:42:02 +0000788 // Reported by Kevin Michael Smith <hai-etlik@users.sourceforge.net>
Linus Walleij7e3b3072009-01-19 22:51:17 +0000789 { "Cowon", 0x0e21, "iAudio 6 (MTP mode)", 0x0711,
790 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000791 // Reported by Roberth Karman
Linus Walleij7e3b3072009-01-19 22:51:17 +0000792 { "Cowon", 0x0e21, "iAudio 7 (MTP mode)", 0x0751,
793 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000794 // Reported by an anonymous SourceForge user
Linus Walleij7e3b3072009-01-19 22:51:17 +0000795 { "Cowon", 0x0e21, "iAudio U5 (MTP mode)", 0x0761,
796 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000797 // Reported by TJ Something <tjbk_tjb@users.sourceforge.net>
Linus Walleij4a779562009-03-29 23:36:45 +0000798 { "Cowon", 0x0e21, "iAudio D2 (MTP mode)", 0x0801,
799 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijd09f65e2009-05-04 23:18:29 +0000800 // Reported by anonymous Sourceforge user
Linus Walleij18ed0162009-05-06 16:51:08 +0000801 { "Cowon", 0x0e21, "iAudio D2+ FW 2.x (MTP mode)", 0x0861,
802 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
803 // From Rockbox device listing
804 { "Cowon", 0x0e21, "iAudio D2+ DAB FW 4.x (MTP mode)", 0x0871,
805 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
806 // From Rockbox device listing
807 { "Cowon", 0x0e21, "iAudio D2+ FW 3.x (MTP mode)", 0x0881,
808 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
809 // From Rockbox device listing
810 { "Cowon", 0x0e21, "iAudio D2+ DMB FW 1.x (MTP mode)", 0x0891,
Linus Walleijd09f65e2009-05-04 23:18:29 +0000811 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij4a779562009-03-29 23:36:45 +0000812 // Reported by <twkonefal@users.sourceforge.net>
813 { "Cowon", 0x0e21, "iAudio S9 (MTP mode)", 0x0901,
Linus Walleij48946ff2009-06-24 08:15:39 +0000814 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
Linus Walleij89bb1cd2009-07-24 21:03:36 +0000815 DEVICE_FLAG_OGG_IS_UNKNOWN | DEVICE_FLAG_FLAC_IS_UNKNOWN },
Linus Walleij4d3618b2009-11-30 00:19:56 +0000816 // Reported by Dan Nicholson <dbn.lists@gmail.com>
817 { "Cowon", 0x0e21, "iAudio 9 (MTP mode)", 0x0911,
818 DEVICE_FLAG_UNLOAD_DRIVER | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000819
820 /*
821 * Insignia, dual-mode.
822 */
823 { "Insignia", 0x19ff, "NS-DV45", 0x0303, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij478ddb92007-11-26 21:01:29 +0000824 // Reported by Rajan Bella <rajanbella@yahoo.com>
825 { "Insignia", 0x19ff, "Sport Player", 0x0307, DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000826 // Reported by "brad" (anonymous, sourceforge)
827 { "Insignia", 0x19ff, "Pilot 4GB", 0x0309, DEVICE_FLAG_UNLOAD_DRIVER },
828
829 /*
830 * LG Electronics
831 */
Linus Walleij1291ce02009-11-07 14:26:57 +0000832 // From anonymous SourceForge user
833 // Uncertain if this is really the MTP mode device ID...
834 { "LG Electronics Inc.", 0x043e, "T54", 0x7040,
835 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000836 // Not verified - anonymous submission
Linus Walleij7b4794f2008-08-13 13:17:17 +0000837 { "LG Electronics Inc.", 0x043e, "UP3", 0x70b1, DEVICE_FLAG_NONE },
838 // Reported by Joseph Nahmias <joe@nahimas.net>
839 { "LG Electronics Inc.", 0x1004, "VX8550 V CAST Mobile Phone", 0x6010,
840 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST | DEVICE_FLAG_ALWAYS_PROBE_DESCRIPTOR },
Linus Walleij2242b022009-01-02 01:44:00 +0000841 // Reported by Cyrille Potereau <cyrille.potereau@wanadoo.fr>
842 { "LG Electronics Inc.", 0x1004, "KC910 Renoir Mobile Phone", 0x608f,
843 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij7fe2b4f2009-05-02 07:07:50 +0000844 // Reported by anonymous sourceforge user
845 { "LG Electronics Inc.", 0x1004, "KM900", 0x6132,
846 DEVICE_FLAG_UNLOAD_DRIVER },
Linus Walleij1a673de2007-10-29 23:10:05 +0000847
848 /*
849 * Sony
Linus Walleijbc3ed4d2008-01-03 13:54:23 +0000850 * It could be that these PIDs are one-per hundred series, so
851 * NWZ-A8xx is 0325, NWZ-S5xx is 0x326 etc. We need more devices
852 * reported to see a pattern here.
Linus Walleij1a673de2007-10-29 23:10:05 +0000853 */
Linus Walleija8ba8c72008-03-29 00:02:27 +0000854 // Reported by Alessandro Radaelli <alessandro.radaelli@aruba.it>
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000855 { "Sony", 0x054c, "Walkman NWZ-A815/NWZ-A818", 0x0325,
856 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000857 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
858 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij5d709a52007-12-28 21:37:17 +0000859 // Reported by anonymous Sourceforge user.
Linus Walleij46b909a2009-09-23 06:55:14 +0000860 { "Sony", 0x054c, "Walkman NWZ-S516", 0x0326,
861 DEVICE_FLAG_UNLOAD_DRIVER |
862 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
863 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij1a673de2007-10-29 23:10:05 +0000864 // Reported by Endre Oma <endre.88.oma@gmail.com>
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000865 { "Sony", 0x054c, "Walkman NWZ-S615F/NWZ-S616F/NWZ-S618F", 0x0327,
866 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000867 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
868 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij062ec7d2008-05-19 12:06:32 +0000869 // Reported by Jean-Marc Bourguet <jm@bourguet.org>
Linus Walleij46b909a2009-09-23 06:55:14 +0000870 { "Sony", 0x054c, "Walkman NWZ-S716F", 0x035a,
871 DEVICE_FLAG_UNLOAD_DRIVER |
872 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
873 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij0c98ce82008-05-25 11:08:36 +0000874 // Reported by Anon SF User / Anthon van der Neut <avanderneut@avid.com>
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000875 { "Sony", 0x054c, "Walkman NWZ-A826/NWZ-A828/NWZ-A829", 0x035b,
876 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000877 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
878 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleija8ba8c72008-03-29 00:02:27 +0000879 // Reported by Niek Klaverstijn <niekez@users.sourceforge.net>
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000880 { "Sony", 0x054c, "Walkman NWZ-A726/NWZ-A728/NWZ-A768", 0x035c,
881 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000882 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
883 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij45b843e2008-10-09 08:33:01 +0000884 // Reported by Mehdi AMINI <mehdi.amini - at - ulp.u-strasbg.fr>
Linus Walleij46b909a2009-09-23 06:55:14 +0000885 { "Sony", 0x054c, "Walkman NWZ-B135", 0x036e,
886 DEVICE_FLAG_UNLOAD_DRIVER |
887 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
888 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij2242b022009-01-02 01:44:00 +0000889 // Reported by <tiagoboldt@users.sourceforge.net>
Linus Walleij46b909a2009-09-23 06:55:14 +0000890 { "Sony", 0x054c, "Walkman NWZ-E436F", 0x0385,
891 DEVICE_FLAG_UNLOAD_DRIVER |
892 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
893 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij7fe2b4f2009-05-02 07:07:50 +0000894 // Reported by Michael Wilkinson
Linus Walleij46b909a2009-09-23 06:55:14 +0000895 { "Sony", 0x054c, "Walkman NWZ-W202", 0x0388,
896 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij094b4502009-09-22 22:28:33 +0000897 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
898 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij25a16302009-03-04 13:56:33 +0000899 // Reported by Ondrej Sury <ondrej@sury.org>
Linus Walleij46b909a2009-09-23 06:55:14 +0000900 { "Sony", 0x054c, "Walkman NWZ-S739F", 0x038c,
901 DEVICE_FLAG_UNLOAD_DRIVER |
902 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
903 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleijd8f1feb2008-10-08 09:16:42 +0000904 // Reported by Marco Filipe Nunes Soares Abrantes Pereira <marcopereira@ua.pt>
Linus Walleij46b909a2009-09-23 06:55:14 +0000905 { "Sony", 0x054c, "Walkman NWZ-S638F", 0x038e,
906 DEVICE_FLAG_UNLOAD_DRIVER |
907 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
908 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij0c6808e2009-07-23 22:44:38 +0000909 // Reported by Elliot <orwells@users.sourceforge.net>
Linus Walleij8d799eb2009-07-23 22:58:06 +0000910 { "Sony", 0x054c, "Walkman NWZ-X1050B/NWZ-X1060B",
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000911 0x0397, DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000912 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
913 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij8d799eb2009-07-23 22:58:06 +0000914 // Reported by Silvio J. Gutierrez <silviogutierrez@users.sourceforge.net>
Linus Walleij6d6e2d12009-09-10 23:17:02 +0000915 { "Sony", 0x054c, "Walkman NWZ-X1051/NWZ-X1061", 0x0398,
916 DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleij46b909a2009-09-23 06:55:14 +0000917 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
918 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleij2aa35742009-11-07 14:39:03 +0000919 // Reported by Gregory Boddin <gregory@siwhine.net>
920 { "Sony", 0x054c, "Walkman NWZ-B142F", 0x03d8,
921 DEVICE_FLAG_UNLOAD_DRIVER |
922 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
923 DEVICE_FLAG_UNIQUE_FILENAMES },
Linus Walleijd8f1feb2008-10-08 09:16:42 +0000924
Linus Walleij1a673de2007-10-29 23:10:05 +0000925
926 /*
Linus Walleijaa6b0192007-10-29 23:39:48 +0000927 * SonyEricsson
Linus Walleijc7756412008-10-21 14:24:24 +0000928 * These initially seemed to support GetObjPropList but later revisions
929 * of the firmware seem to have broken it, so all are flagged as broken
930 * for now.
Linus Walleijaa6b0192007-10-29 23:39:48 +0000931 */
Linus Walleijd866d242009-08-23 21:50:39 +0000932 // Reported by Thomas Schweitzer <thomas_-_s@users.sourceforge.net>
933 { "SonyEricsson", 0x0fce, "K550i", 0xe000, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijb3b29e72007-11-05 22:29:53 +0000934 // Reported by Øyvind Stegard <stegaro@users.sourceforge.net>
Linus Walleijc7756412008-10-21 14:24:24 +0000935 { "SonyEricsson", 0x0fce, "K850i", 0x0075, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijaa6b0192007-10-29 23:39:48 +0000936 // Reported by Michael Eriksson
Linus Walleijc7756412008-10-21 14:24:24 +0000937 { "SonyEricsson", 0x0fce, "W910", 0x0076, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijb5a4f922008-05-11 20:15:00 +0000938 // Reported by Zack <zackdvd@users.sourceforge.net>
Linus Walleijc7756412008-10-21 14:24:24 +0000939 { "SonyEricsson", 0x0fce, "W890i", 0x00b3, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijc2bc9732008-08-14 21:12:44 +0000940 // Reported by robert dot ahlskog at gmail
Linus Walleijc7756412008-10-21 14:24:24 +0000941 { "SonyEricsson", 0x0fce, "W760i", 0x00c6, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijf8c251e2008-06-08 21:32:01 +0000942 // Reported by Linus Åkesson <linusakesson@users.sourceforge.net>
Linus Walleijc7756412008-10-21 14:24:24 +0000943 { "SonyEricsson", 0x0fce, "C902", 0x00d4, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij07bb5382008-07-31 20:21:09 +0000944 // Reported by an anonymous SourceForge user
Linus Walleijc7756412008-10-21 14:24:24 +0000945 { "SonyEricsson", 0x0fce, "C702", 0x00d9, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleijdb6da7c2008-10-16 18:46:34 +0000946 // Reported by Christian Zuckschwerdt <christian@zuckschwerdt.org>
Linus Walleijc7756412008-10-21 14:24:24 +0000947 { "SonyEricsson", 0x0fce, "W980", 0x00da, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij76edf7e2009-05-19 22:37:07 +0000948 // Reported by David Taylor <davidt-libmtp@yadt.co.uk>
949 { "SonyEricsson", 0x0fce, "C905", 0x00ef, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij4aa66dc2009-05-02 06:36:59 +0000950 // Reported by David House <dmhouse@users.sourceforge.net>
951 { "SonyEricsson", 0x0fce, "W595", 0x00f3,
Linus Walleijdab453b2009-05-26 20:55:58 +0000952 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL | DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleij2c34d432008-12-13 22:01:32 +0000953 // Reported by Mattias Evensson <mevensson@users.sourceforge.net>
954 { "SonyEricsson", 0x0fce, "W902", 0x00f5, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleij5ffcec92009-09-03 21:16:36 +0000955 // Reported by Sarunas <sarunas@users.sourceforge.net>
956 // Doesn't need any flags according to reporter
Linus Walleij572cb972009-09-08 20:03:29 +0000957 { "SonyEricsson", 0x0fce, "T700", 0x00fb, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij4a779562009-03-29 23:36:45 +0000958 // Reported by Stéphane Pontier <shadow_walker@users.sourceforge.net>
Linus Walleijffffa272009-08-03 19:03:38 +0000959 { "SonyEricsson", 0x0fce, "W705/W715", 0x0105, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
Linus Walleije7ab9482009-07-23 23:50:51 +0000960 // Reported by Håkan Kvist
961 { "SonyEricsson", 0x0fce, "W995", 0x0112, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
962
Linus Walleijaa6b0192007-10-29 23:39:48 +0000963
964 /*
Linus Walleij1a673de2007-10-29 23:10:05 +0000965 * Motorola
966 * Assume DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST on all of these.
967 */
Linus Walleij37c21662008-05-16 21:16:01 +0000968 // Reported by David Boyd <tiggrdave@users.sourceforge.net>
Linus Walleijf3296622008-09-04 20:53:56 +0000969 { "Motorola", 0x22b8, "V3m/V750 verizon", 0x2a65, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST |
Linus Walleij37c21662008-05-16 21:16:01 +0000970 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij1a673de2007-10-29 23:10:05 +0000971 // Reported by Marcus Meissner to libptp2
972 { "Motorola", 0x22b8, "K1", 0x4811, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
973 // Reported by Hans-Joachim Baader <hjb@pro-linux.de> to libptp2
974 { "Motorola", 0x22b8, "A1200", 0x60ca, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleijf0702982008-10-25 21:37:43 +0000975 // http://mark.cdmaforums.com/Files/Motdmmtp.inf
976 { "Motorola", 0x22b8, "MTP Test Command Interface", 0x6413, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleij1a673de2007-10-29 23:10:05 +0000977 // Reported by anonymous user
Linus Walleij238704e2008-09-08 22:54:15 +0000978 { "Motorola", 0x22b8, "RAZR2 V8/U9/Z6", 0x6415, DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST },
Linus Walleij37c21662008-05-16 21:16:01 +0000979
Linus Walleij1a673de2007-10-29 23:10:05 +0000980
981 /*
Linus Walleij478ddb92007-11-26 21:01:29 +0000982 * Media Keg
983 */
984 // Reported by Rajan Bella <rajanbella@yahoo.com>
985 { "Kenwood", 0x0b28, "Media Keg HD10GB7 Sport Player", 0x100c, DEVICE_FLAG_UNLOAD_DRIVER},
986
Linus Walleij5d675112008-02-16 21:46:46 +0000987 /*
988 * Micro-Star International (MSI)
989 */
990 // Reported by anonymous sourceforge user.
991 { "Micro-Star International", 0x0db0, "P610/Model MS-5557", 0x5572, DEVICE_FLAG_NONE },
992
Linus Walleijf044aa12008-03-22 21:45:19 +0000993 /*
994 * FOMA
995 */
996 { "FOMA", 0x06d3, "D905i", 0x21ba, DEVICE_FLAG_NONE },
Linus Walleij166c8ff2008-01-14 23:15:08 +0000997
Linus Walleij478ddb92007-11-26 21:01:29 +0000998 /*
Linus Walleijb5a4f922008-05-11 20:15:00 +0000999 * Haier
1000 */
1001 // Both reported by an anonymous SourceForge user
1002 // This is the 30 GiB model
1003 { "Haier", 0x1302, "Ibiza Rhapsody", 0x1016, DEVICE_FLAG_NONE },
1004 // This is the 4/8 GiB model
1005 { "Haier", 0x1302, "Ibiza Rhapsody", 0x1017, DEVICE_FLAG_NONE },
Richard Low4d93a992008-09-07 12:52:14 +00001006
1007 /*
1008 * Panasonic
1009 */
1010 // Reported by dmizer
1011 { "Panasonic", 0x04da, "P905i", 0x2145, DEVICE_FLAG_NONE },
Linus Walleijb5a4f922008-05-11 20:15:00 +00001012
1013 /*
Linus Walleij80a2a692008-12-05 20:36:40 +00001014 * Polaroid
1015 */
1016 { "Polaroid", 0x0546, "Freescape/MPU-433158", 0x2035, DEVICE_FLAG_NONE },
1017
1018 /*
Linus Walleij2242b022009-01-02 01:44:00 +00001019 * Pioneer
1020 */
1021 // Reported by Dan Allen <dan.j.allen@gmail.com>
1022 { "Pioneer", 0x08e4, "XMP3", 0x0148, DEVICE_FLAG_NONE },
1023
1024 /*
Linus Walleij4096c882009-03-16 23:32:34 +00001025 * Slacker Inc.
1026 * Put in all evilness flags because it looks fragile.
1027 */
1028 // Reported by Pug Fantus <pugfantus@users.sourceforge.net>
1029 { "Slacker Inc.", 0x1bdc, "Slacker Portable Media Player", 0xfabf,
1030 DEVICE_FLAG_BROKEN_BATTERY_LEVEL | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST |
1031 DEVICE_FLAG_BROKEN_SET_OBJECT_PROPLIST | DEVICE_FLAG_BROKEN_SEND_OBJECT_PROPLIST },
1032
Linus Walleij6e3997e2009-04-12 23:40:40 +00001033 // Reported by Demadridsur <demadridsur@gmail.com>
1034 { "O2 Sistemas", 0x1e53, "ZoltarTV", 0x0006, DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST },
1035
Linus Walleij6fb9a5f2009-09-12 06:25:17 +00001036 // Reported by Sense Hofstede <qense@users.sourceforge.net>
1037 { "Perception Digital, Ltd", 0x0aa6, "Gigaware GX400", 0x9702, DEVICE_FLAG_NONE },
Linus Walleij5f3c44b2009-09-12 21:03:06 +00001038
1039 /*
1040 * RIM's BlackBerry
1041 */
1042 // Reported by Nicolas VIVIEN <nicolas@vivien.fr>
Linus Walleijfea4f532009-09-22 22:08:35 +00001043 { "RIM", 0x0fca, "BlackBerry Storm", 0x8007, DEVICE_FLAG_UNLOAD_DRIVER |
Linus Walleijcea83ff2009-09-25 21:44:38 +00001044 DEVICE_FLAG_SWITCH_MODE_BLACKBERRY | DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL },
Linus Walleij5f3c44b2009-09-12 21:03:06 +00001045
Linus Walleij4096c882009-03-16 23:32:34 +00001046 /*
Linus Walleij1a673de2007-10-29 23:10:05 +00001047 * Other strange stuff.
1048 */
1049 { "Isabella", 0x0b20, "Her Prototype", 0xddee, DEVICE_FLAG_NONE }