blob: 6141295f9db40af674c59a39b2deadb3b4beb936 [file] [log] [blame]
Linus Walleij0dd71e92006-05-04 18:47:07 +00001Building and Installing
2-----------------------
Linus Walleij6fd2f082006-03-28 07:19:22 +00003
Linus Walleij0dd71e92006-05-04 18:47:07 +00004See the "INSTALL" file.
5
6
Linus Walleij3f7529c2010-07-24 20:33:41 +00007Initiator and Responder
8-----------------------
9
10libmtp implements an MTP initiator, which means it initiate
11MTP sessions with devices. The devices responding are known
12as MTP responders. libmtp runs on something with a USB host
13controller interface, using libusb to access the host
14controller.
15
16If you're more interested in the MTP responders, gadgets like
17MP3 players, mobile phones etc, look into MeeGo:s Buteo Sync:
18http://wiki.meego.com/Buteo - these guys are creating a fully
19open source MTP responder.
20
21
Linus Walleij0dd71e92006-05-04 18:47:07 +000022Heritage
23--------
24
25libmtp is based on several ancestors:
26
27* libptp2 by Mariusz Woloszyn was the starting point used
28 by Richard A. Low for the initial starter port. You can
29 find it at http://libptp.sourceforge.net/
30
31* libgphoto2 by Mariusz Woloszyn and Marcus Meissner was
32 used at a later stage since it was (is) more actively
33 maintained. libmtp tracks the PTP implementation in
34 libgphoto2 and considers it an upstream project. We will
35 try to submit anything generally useful back to libgphoto2
36 and not make double efforts. In practice this means we
37 use ptp.c, ptp.h and ptp-pack.c verbatim from the libgphoto2
38 source code. If you need to change things in these files,
39 make sure it is so general that libgphoto2 will want to
40 merge it to their codebase too. You find libgphoto2 as part
41 of gPhoto: http://gphoto.sourceforge.net/
42
43* libnjb was a project that Richard and Linus were working
Linus Walleijfcf88912006-06-05 13:23:33 +000044 on before libmtp. When Linus took Richards initial port
Linus Walleij0dd71e92006-05-04 18:47:07 +000045 and made an generic C API he re-used the philosophy and
46 much code from libnjb. Many of the sample programs are for
47 example taken quite literally from libnjb. You find it here:
48 http://libnjb.sourceforge.net/
49
50
Linus Walleijea7d45b2009-02-23 22:26:09 +000051Contacting and Contributing
52---------------------------
53
54See the project page at http://libmtp.sourceforge.net/
55We always need your help. There is a mailinglist and a
56bug report system there.
57
58People who want to discuss MTP devices in fora seem to
59hang out on the forums at AnythingbutiPod:
60http://www.anythingbutipod.com/forum/
61
62
Linus Walleij0dd71e92006-05-04 18:47:07 +000063Compiling programs for libmtp
64-----------------------------
65
66libmtp has support for the pkg-config script by adding a libmtp.pc
67entry in $(prefix)/lib/pkgconfig. To compile a libmtp program,
68"just" write:
69
70gcc -o foo `pkg-config --cflags --libs libmtp` foo.c
71
72This also simplifies compilation using autoconf and pkg-config: just
73write e.g.
74
75PKG_CHECK_MODULES(MTP, libmtp)
76AC_SUBST(MTP_CFLAGS)
77AC_SUBST(MTP_LIBS)
78
79To have libmtp LIBS and CFLAGS defined. Needless to say, this will
80only work if you have pkgconfig installed on your system, but most
81people have nowadays.
82
83If your library is installed in e.g. /usr/local you may have to tell
84this to pkgconfig by setting the PKG_CONFIG_PATH thus:
85
86export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig
87
88
89Documentation
90-------------
91
92Read the API documentation that can be generated with doxygen.
93It will be output in doc/html if you have Doxygen properly
94installed. (It will not be created unless you have Doxygen!)
95
96For information about the Media Transfer Protocol, see:
97http://en.wikipedia.org/wiki/Media_Transfer_Protocol
98
Linus Walleij7a83e552008-07-29 21:30:43 +000099The official 1.0 specification for MTP was released by the
100USB Implementers Forum in may, 2008. Prior to this, only a
101proprietary Microsoft version was available, and quite a few
102devices out there still use some aspects of the Microsoft
103version, which deviates from the specified standard. You can
104find the official specification here:
105http://www.usb.org/developers/devclass_docs/MTP_1.0.zip
Linus Walleij0dd71e92006-05-04 18:47:07 +0000106
Linus Walleij1b91ca62008-10-17 07:07:56 +0000107
108The Examples
109------------
110
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000111In the subdirectory "examples" you find a number of
Linus Walleij1b91ca62008-10-17 07:07:56 +0000112command-line tools, illustrating the use of libmtp in very
113simple terms.
114
115Please do not complain about the usability or documentation
116of these examples, they look like they do for two reasons:
117
1181. They are examples, not tools. If they were intended for
119 day-to-day usage by commandline freaks, I would have
120 called them "tools" not "examples".
121
1222. The MTP usage paradigm is that a daemon should hook
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000123 the device upon connection, and that it should be
Linus Walleij1b91ca62008-10-17 07:07:56 +0000124 released by unplugging. GUI tools utilizing HAL (hald)
125 and D-Bus do this much better than any commandline
126 program ever can. (See below on bugs.) Specificationwise
127 this is a bug, however it is present in many, many
128 devices.
129
130That said, if you want to pick up and maintain the examples,
131please volunteer.
132
133
Linus Walleija1b66f22007-05-10 20:02:16 +0000134New Devices
135-----------
136
Linus Walleijfcf88912006-06-05 13:23:33 +0000137If you happen upon a device which libmtp claims it cannot
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000138autodetect, please submit the vendor ID and device ID
Linus Walleij9ee29402007-10-31 20:24:48 +0000139(these can be obtained from the "lsusb" and "lsusb -n"
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000140commands run as root) as a bug, patch or feature request
141on the Sourceforge bug tracker at our homepage. If it
142gives a sensible output from "mtp-detect" then please attach
143the result as well as it teach us some stuff about your
144device. If you've done some additional hacking, join our
Linus Walleij9ee29402007-10-31 20:24:48 +0000145mailinglist and post your experiences there.
Linus Walleijda558be2007-03-10 21:42:25 +0000146
Linus Walleija1b66f22007-05-10 20:02:16 +0000147If you want to be able to hack some more and you're not
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000148afraid of C hacking, add an entry for your device's
149vendor/product ID and a descriptive string to the database
Linus Walleij6dc01682007-11-15 21:23:46 +0000150in the file src/music-players.h.
Linus Walleija1b66f22007-05-10 20:02:16 +0000151
152If you want to poke around to see if your device has some
153special pecularities, you can test some special device
Linus Walleij6dc01682007-11-15 21:23:46 +0000154flags (defined in src/device-flags.h) by inserting them
155together with your device entry in src/music-players.h.
Linus Walleija1b66f22007-05-10 20:02:16 +0000156Flags can be tested in isolation or catenated with "|"
157(binary OR). If relatives to your device use a certain
158flag, chances are high that a new device will need it
159too, typically from the same manufacturer.
160
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000161The most common flag that needs to be set is the
Linus Walleija1b66f22007-05-10 20:02:16 +0000162DEVICE_FLAG_UNLOAD_DRIVER that detach any Linux kernel
163drivers that may have attached to the device making
Linus Walleij94f23d52007-08-04 19:37:28 +0000164MTP access impossible. This is however not expected to
165really work: this is a problem being tracked as of
166now (2007-08-04). See the "last resort" solutions below
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000167if you really need to get your dual-mode device to work
Linus Walleij94f23d52007-08-04 19:37:28 +0000168with MTP.
Linus Walleija1b66f22007-05-10 20:02:16 +0000169
Linus Walleijcc2cf972007-11-22 20:23:43 +0000170Another flag which is easy to identify is the
171DEVICE_FLAG_NO_ZERO_READS, which remedies connection
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000172timeouts when getting files, and some timeouts on e.g.
Linus Walleijcc2cf972007-11-22 20:23:43 +0000173successive "mtp-connect" calls.
174
Linus Walleija1b66f22007-05-10 20:02:16 +0000175If your device is very problematic we are curious of how it
Linus Walleijda558be2007-03-10 21:42:25 +0000176works under Windows, so we enjoy reading USB packet sniffs
177that reveal the low-level traffic carried out between
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000178Windows Media Player and your device. This can be done
Linus Walleij61c25682007-09-04 14:46:21 +0000179using e.g.:
180
181* USBsnoop:
182 http://benoit.papillault.free.fr/usbsnoop/
183
184* The trial version of HHD Softwares software-only
185 USB monitor. You need to get a copy of version 2.37 since
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000186 the newer trial versions won't let you carry out the
Linus Walleij61c25682007-09-04 14:46:21 +0000187 needed packet sniffs. (As of 2007-03-10 a copy can be found
188 at: http://www.cobbleware.com/files/usb-monitor-237.exe)
189
Linus Walleijda558be2007-03-10 21:42:25 +0000190There are other USB monitors as well, some more expensive
191alternatives use hardware and even measure electronic
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000192characteristics of the traffic (which is far too much
Linus Walleijda558be2007-03-10 21:42:25 +0000193detail for us).
194
Linus Walleij91fb0282007-09-03 21:16:08 +0000195Device sniffs are an easy read since the PTP/MTP protocol
196is nicely structured. All commands will have a structure such
197as this in the log, we examplify with a object list request:
198
199PTP REQEUST:
200000120: Bulk or Interrupt Transfer (UP), 03.09.2007 12:49:25.9843750 +0.0
201Pipe Handle: 0x863ce234 (Endpoint Address: 0x2)
202Send 0x20 bytes to the device:
203 20 00 00 00 01 00 05 98 23 00 00 00 27 03 00 10 ......?#...'...
204 Length TYPE CMD Trans# Param1
205
206 00 00 00 00 02 DC 00 00 00 00 00 00 00 00 00 00 .....Ü..........
207 Param2 Param3 Param4 Param5
208
209[OPTIONAL] DATA PHASE:
210000121: Bulk or Interrupt Transfer (UP), 03.09.2007 12:49:26.0 +0.0156250
211Pipe Handle: 0x863ce214 (Endpoint Address: 0x81)
212Get 0x1a bytes from the device:
213 1A 00 00 00 02 00 05 98 23 00 00 00 01 00 00 00 .......?#.......
214 Length TYPE CMD Trans# DATA
215
216 27 03 00 10 02 DC 04 00 00 30 '....Ü...0
217
218RESPONSE:
219000122: Bulk or Interrupt Transfer (UP), 03.09.2007 12:49:26.0 +0.0
220Pipe Handle: 0x863ce214 (Endpoint Address: 0x81)
221Get 0xc bytes from the device:
222 0C 00 00 00 03 00 01 20 23 00 00 00 ....... #...
223 Length TYPE CODE Trans#
224
225* One send (OUT to the device), two reads (IN from the device).
226
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000227* All three byte chunks commands are
228 sent/recieved/recieeved by the function ptp_transaction()
Linus Walleij91fb0282007-09-03 21:16:08 +0000229 in the file ptp.c.
230
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000231* It boils down to ptp_usb_sendreq(), optionally ptp_usb_senddata()
232 or ptp_usb_getdata() and finally ptp_usb_getresp() in the file
Linus Walleij91fb0282007-09-03 21:16:08 +0000233 libusb-glue.c. Notice ptp_usb_sendreq() and ptp_usb_getresp()
234 are ALWAYS called. The TYPE field correspond to this, so the
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000235 TYPES in this case are "COMMAND" (0x0001), "DATA" (0x0002),
Linus Walleij91fb0282007-09-03 21:16:08 +0000236 and "RESPONSE" (0x0003).
237
238* Notice that the byte order is little endian, so you need to read
239 each field from right to left.
240
241* This COMMAND has:
242 CMD 0x99805, we see in ptp.h that this is PTP_OC_MTP_GetObjPropList.
243 Transaction# 0x00000023.
244 REQUEST parameters 0x10000327, 0x00000000, 0x0000DC02, 0x00000000
245 0x00000000, in this case it means "get props for object 0x10000327",
246 "any format", "property 0xDC02" (PTP_OPC_ObjectFormat), then two
247 parameters that are always zero (no idea what they mean or their
248 use).
249
250* The DATA has:
251 CMD 0x99805, we see in ptp.h that this is PTP_OC_MTP_GetObjPropList.
252 Transaction# 0x00000023.
253 Then comes data 0x00000001, 0x10000327, 0xDC02, 0x0004, 0x3000
254 Which means in this case, (and this is the tricky part) "here
255 you have 1 property", "for object 0x10000327", "it is property
256 0xDC02" (PTP_OPC_ObjectFormat), "which is of type 0x0004"
257 (PTP_DTC_UINT16), "and set to 0x3000" (PTP_OFC_Undefined, it
258 is perfectly valid to have undefined object formats, since it
259 is a legal value defining this).
260
261* This RESPONSE has:
262 CMD 0x99805, we see in ptp.h that this is PTP_OC_MTP_GetObjPropList.
263 Return Code ("RC") = 0x2001, PTP_RC_OK, all went fine.
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000264 Transaction# 0x00000023.
Linus Walleijfcf88912006-06-05 13:23:33 +0000265
Linus Walleijd05fce62007-09-29 20:17:23 +0000266If you want to compare the Windows behaviour with a similar
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000267operation using libmtp you can go into the src/libusb-glue.c
Linus Walleij6dc01682007-11-15 21:23:46 +0000268file and uncomment the row that reads:
Linus Walleijd05fce62007-09-29 20:17:23 +0000269
270//#define ENABLE_USB_BULK_DEBUG
271
272(I.e. remove the two //.)
273
274This will make libmtp print out a hex dump of every bulk USB
275transaction. The bulk transactions contain all the PTP/MTP layer
276data, which is usually where the problems appear.
277
Linus Walleij6fd2f082006-03-28 07:19:22 +0000278
Darran Kartaschewa476ae92011-08-08 09:07:30 +0200279Notes to assist with debugging new devices:
280-------------------------------------------
281
282In debugging new hardware, we highly recommend that you only
283use the example mtp-* applications that come with libmtp, as other
284applications may have their own bugs that may interfere with your
285new device working correctly. Using another application instead of
286those that come with libmtp just adds another point of failure.
287
288For debugging, there are 3 main options:
289
2901. Use the env variable: LIBMTP_DEBUG to increase the
291verboseness of the debugging output for any application using
292libmtp. Relevant codes are:
293* 0x00 [0000 0000] : no debug (default)
294* 0x01 [0000 0001] : PTP debug
295* 0x02 [0000 0010] : Playlist debug
296* 0x04 [0000 0100] : USB debug
297* 0x08 [0000 1000] : USB data debug
298// Codes are hex and binary respectively. Simple add them togther
299// to get your desired level of output.
300
301(Assuming bash)
302eg:
303$ export LIBMTP_DEBUG=12
304$ mtp-detect
305 // To get USB debug and USB data debug information.
306
307$ export LIBMTP_DEBUG=2
308$ mtp-detect
309 // To get Playlist debug information.
310
311Also note, an application may also use the LIBMTP_debug() API
312function to achieve the same options as listed above.
313
3142. Use "strace" on the various mtp-* commands to see where/what
315is falling over or getting stuck at.
316* On Solaris and FreeBSD, use "truss" or "dtrace" instead on "strace".
317* On Mac OS X, use "ktrace" or "dtrace" instead of "strace".
318* On OpenBSD and NetBSD, use "ktrace" instead of "strace".
319
320This will at least help pinpoint where the application is failing, or
321a device is reporting incorrect information. (This is extremely helpful
322with devices that have odd disconnection requirements).
323
324The use of these tools may also pinpoint issues with libusb as
325implemented by each OS vendor or issues with the MTP implementation
326on the new device as well, so please be prepared for either case.
327
3283. Use "gdb" or similar debugger to step through the code as it is
329run. This is time consuming, and not needed just to pinpoint where
330the fault is.
331
332The use of gdb or another debugger may also miss or actually cause
333command and data timing issues with some devices, leading to false
334information. So please consider this a last resort option.
335
336Also please read the "It's Not Our Bug!" section below, as it does
337contain some useful information that may assist with your device.
338
339
Linus Walleij8d799eb2009-07-23 22:58:06 +0000340Dual-mode devices does not work - last resort:
341----------------------------------------------
Linus Walleijbd7624c2007-05-28 10:48:54 +0000342
343Some devices that are dual-mode are simply impossible to get
344to work under Linux because the usb-storage(.ko) kernel
345module hook them first, and refuse to release them, even
Linus Walleij94f23d52007-08-04 19:37:28 +0000346when we specify the DEVICE_FLAG_UNLOAD_DRIVER flag. (Maybe
347it DOES release it but the device will immediately be probed
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000348at the USB mass storage interface AGAIN because it
Linus Walleij94f23d52007-08-04 19:37:28 +0000349enumerates.)
Linus Walleijbd7624c2007-05-28 10:48:54 +0000350
Linus Walleij8d799eb2009-07-23 22:58:06 +0000351Here is what some people do:
352
353 1. Plug in the device.
354 2. USB-mass storage folder will open automatically.
355 3. Unmount the device.
356 4. Run mtp-detect. It will most likely fail the first time.
357 5. Run mtp-detect again, it might work this time, or fail. Keep running
358 till it works. 99% it works by the third try.
359 6. Once mtp-detect gives you an "Ok", open either Rhythmbox or Gnomad2,
360 everything should work.
361
Linus Walleije20abaf2007-12-10 11:20:34 +0000362Linux: Try this, if you have a recent 2.6.x Linux kernel,
Linus Walleij584eb8d2007-09-05 19:51:27 +0000363run (as root) something like:
364
365> rmmod usb_storage ; mtp-detect
366
367You can run most any command or a client like gnomad2 or
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000368Amarok immediately after the rmmod command. This works
Linus Walleij584eb8d2007-09-05 19:51:27 +0000369sometimes. Another way:
Linus Walleijbd7624c2007-05-28 10:48:54 +0000370
Linus Walleij94f23d52007-08-04 19:37:28 +0000371* Edit /etc/modprobe.d/blacklist
Linus Walleijbd7624c2007-05-28 10:48:54 +0000372
373* Add the line "blacklist usb-storage"
374
375* Reboot.
376
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000377Now none of you USB disks, flash memory sticks etc will be
Linus Walleijbd7624c2007-05-28 10:48:54 +0000378working (you just disabled them all). However you *can* try
379your device, and it might have started working because there
380is no longer a USB mass storage driver that tries to hook onto
381the mass storage interface of your device.
382
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000383If not even blacklisting works (check with
Linus Walleij94f23d52007-08-04 19:37:28 +0000384"lsmod | grep usb-storage"), there is some problem with
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000385something else and you may need to remove or rename the file
Linus Walleij94f23d52007-08-04 19:37:28 +0000386/lib/modules/<VERSION>/kernel/drivers/usb/storage/usb-storage.ko
387manually.
388
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000389If you find the PerfectSolution(TM) to this dilemma, so you
Linus Walleijbd7624c2007-05-28 10:48:54 +0000390can properly switch for individual devices whether to use it
391as USB mass storage or not, please tell us how you did it. We
392know we cannot use udev, because udev is called after-the-fact:
393the device is already configured for USB mass storage when
394udev is called.
395
Linus Walleije20abaf2007-12-10 11:20:34 +0000396On Mac OS there is another ugly hack:
397
3981. Open up a terminal window
3992. Type:
400sudo mv /System/Library/Extensions/IOUSBMassStorageClass.kext
401/System/Library/Extensions/IOUSBMassStorageClass.kext.disabled
402
403and when prompted enter your password.
404
4053. Restart.
406
407To reverse this change, just reverse the filenames:
408
409sudo mv /System/Library/Extensions/
410IOUSBMassStorageClass.kext.disabled /System/Library/Extensions/
411IOUSBMassStorageClass.kext
412
413and restart.
414
Linus Walleijbd7624c2007-05-28 10:48:54 +0000415
Linus Walleij15def332006-09-19 14:27:02 +0000416Calendar and contact support:
417-----------------------------
Linus Walleijd3bdf762006-02-20 22:21:56 +0000418
Linus Walleij3c16fe42006-04-30 07:53:41 +0000419The Creative Zen series can read VCALENDAR2 (.ics) files
Linus Walleij15def332006-09-19 14:27:02 +0000420and VCard (.vcf) files from programs like for example
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000421Evolution with the following limitations/conditions:
Linus Walleijd3bdf762006-02-20 22:21:56 +0000422
Linus Walleij3c16fe42006-04-30 07:53:41 +0000423- The file must be in DOS (CR/LF) format, use the unix2dos
424 program to convert if needed
Linus Walleij15def332006-09-19 14:27:02 +0000425
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000426- Repeat events in calendar files do not seem to be supported,
Linus Walleij15def332006-09-19 14:27:02 +0000427 entries will only appear once.
428
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000429- Calendar (.ics) files should be stored in the folder "My Organizer"
Linus Walleij15def332006-09-19 14:27:02 +0000430 when sent to the device (this directory should be autodetected
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000431 for use with calendar files, otherwise use the option
Linus Walleij15def332006-09-19 14:27:02 +0000432 -f "My Organizer" to sendfile for this) Apparently this file can
433 also contain tasklists.
434
435- Contact (.vcf) files should be stored in the folder "My Contacts"
436 when sent to the device. (-f "My Contacts")
437
438- Some devices are picky about the name of the calendar and
439 contact files. For example the Zen Microphoto wants:
440
Linus Walleijb1318d12006-09-25 14:59:26 +0000441 Calendar: My Organizer/6651416.ics
442 Contacts: My Organizer/6651416.vcf
443
444
445Syncing in with Evolution and Creative Devices
446----------------------------------------------
447
448Evolution can easily export .ics an .vcf files, but you currently
449need some command-line hacking to get you stuff copied over in
450one direction host -> device. The examples/ directory contains a script
451created for the Creative Zen Microphoto by Nicolas Tetreault.
452
Linus Walleij6e8cef42006-12-03 20:45:04 +0000453
454It's Not Our Bug!
455-----------------
456
457Some MTP devices have strange pecularities. We try to work around
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000458these whenever we can, sometimes we cannot work around it or we
Linus Walleij6e8cef42006-12-03 20:45:04 +0000459cannot test your solution.
460
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000461* Generic MTP/PTP disconnect misbehaviour: we have noticed that
Linus Walleij67038b92008-04-16 15:01:40 +0000462 Windows Media Player apparently never close the session to an MTP
463 device. There is a daemon in Windows that "hooks" the device
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000464 by opening a PTP session to any MTP device, whenever it is
465 plugged in. This daemon proxies any subsequent transactions
Linus Walleij67038b92008-04-16 15:01:40 +0000466 to/from the device and will never close the session, thus
467 Windows simply does not close sessions at all.
468
Linus Walleije2f65662008-12-07 20:44:11 +0000469 Typical sign of this illness: broken pipes on closing sessions,
470 on the main transfer pipes(s) or the interrupt pipe:
471
472 Closing session
473 usb_clear_halt() on INTERRUPT endpoint: Broken pipe
474 OK.
475
Linus Walleij67038b92008-04-16 15:01:40 +0000476 This means that device manufacturers doesn't notice any problems
477 with devices that do not correctly handle closing PTP/MTP
478 sessions, since Windows never do it. The proper way of closing
479 a session in Windows is to unplug the device, simply put.
480
481 Since libmtp actually tries to close sessions, some devices
482 may fail since the close session functionality has never been
483 properly tested, and "it works with Windows" is sort of the
484 testing criteria at some companies.
485
486 You can get Windows-like behaviour on Linux by running a HAL-aware
487 libmtp GUI client like Rhythmbox or Gnomad2, which will "hook"
488 the device when you plug it in, and "release" it if you unplug
489 it.
490
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000491 If this bug in your device annoys you, contact your device
492 manufacturer and ask them to test their product with some libmtp
Linus Walleij67038b92008-04-16 15:01:40 +0000493 program.
494
Linus Walleijc3a6eeb2010-01-30 07:32:41 +0000495* Generic certificate misbehaviour. All devices are actually
496 required to support a device certificate to be able to
497 encrypt Windows Media (WMA/WMV) files. However there are
498 obviously a lot of devices out there which doesn't support
499 this at all but instead crash. Typical printout:
500
501 Error 2: PTP Layer error 02ff: get_device_unicode_property(): failed
502 to get unicode property.
503
Linus Walleijb715ba62008-02-12 23:41:49 +0000504* Generic USB misbehaviour: some devices behave badly under MTP
505 and USB mass storage alike, even down to the lowest layers
506 of USB. You can always discuss such issues at the linux-usb
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000507 mailing list if you're using Linux:
Linus Walleijb715ba62008-02-12 23:41:49 +0000508 http://www.linux-usb.org/mailing.html
509
Linus Walleij76b185d2008-02-12 23:46:14 +0000510 If you have a problem specific to USB mass storage mode, there
511 is a list of strange behaving devices in the Linux kernel:
512 http://lxr.linux.no/linux/drivers/usb/storage/unusual_devs.h
Linus Walleijf7d8df12008-02-13 00:02:17 +0000513 You can discuss this too on the mentioned list, for understanding
514 the quirks, see:
515 http://www2.one-eyed-alien.net/~mdharm/linux-usb/target_offenses.txt
Linus Walleij76b185d2008-02-12 23:46:14 +0000516
Linus Walleijdeddc342008-08-16 23:52:06 +0000517* Kernel bug on Linux. Linux 2.6.16 is generally speaking required
518 to use any MTP device under USB 2.0. This is because the EHCI
519 driver previously did not support zero-length writes to endpoints.
520 It should work in most cases however, or if you connect it
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000521 to an UHCI/OHCI port instead (yielding lower speed). But
Linus Walleijdeddc342008-08-16 23:52:06 +0000522 please just use a recent kernel.
523
Linus Walleij07bb5382008-07-31 20:21:09 +0000524* Zen models AVI file seeking problem: the Zens cannot parse the
525 files for the runlength metadata. Do not transfer file with e.g.
526 mtp-sendfile, use mtp-sendtr and set the length of the track to
527 the apropriate number of seconds and it will work. In graphical
528 clients, use a "track transfer" function to send these AVI files,
529 the Zens need the metadata associated with tracks to play back
530 movies properly. Movies are considered "tracks" in the MTP world.
531
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000532* Some devices that disregard the metadata sent with the MTP
Linus Walleij64e2e982008-08-01 21:51:13 +0000533 commands will parse the files for e.g. ID3 metadata. Some still
534 of these devices expect only ID3v2.3 metadata and will fail with
535 a modern ID3v2,4 tag writer, like many of those found in Linux
536 applications. Windows Media Player use ID3v2.3 only, so many
537 manufacturers only test this version.
538
Linus Walleij6e8cef42006-12-03 20:45:04 +0000539* The Zen Vision:M (possibly more Creative Zens) has a firmware bug
540 that makes it drop the last two characters off a playlist name.
541 It is fixed in later firmware.
542
Linus Walleijc41f2e82007-03-12 22:26:00 +0000543* For Creative Technology devices, there are hard limits on how
544 many files can be put onto the device. For a 30 GiB device (like
545 the Zen Xtra) the limit is 6000, for a 60 GiB device the limit
546 is 15000 files. For further Creative pecularities, see the
547 FAQ sections at www.nomadness.net.
548
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000549* Sandisk sansa c150 and probably several other Sandisk devices
Linus Walleijd24a7ab2007-03-07 21:48:43 +0000550 (and possibly devices from other manufacturers) have a dual
551 mode with MTP and USB mass storage. The device will initially
552 claim to be mass storage so udev will capture is and make the
Linus Walleijda558be2007-03-10 21:42:25 +0000553 use of MTP mode impossible. One way of avoiding it could be to
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000554 be to blacklist the "usb-storage" module in
Linus Walleijd24a7ab2007-03-07 21:48:43 +0000555 /etc/modprobe.c/blacklist with a row like this:
Linus Walleijda558be2007-03-10 21:42:25 +0000556 "blacklist usb-storage". Some have even removed the
557 "usb-storage.ko" (kernel module file) to avoid loading.
Linus Walleijd24a7ab2007-03-07 21:48:43 +0000558
Linus Walleij2242b022009-01-02 01:44:00 +0000559* Sandisk Sansa Fuze has three modes: auto, MTP or mass storage
560 (MSC). Please set it to MTP to avoid problems with libmtp.
561
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000562* The iriver devices (possibly all of them) cannot handle the
563 enhanced GetObjectPropList MTP command (0x9805) properly. So
Linus Walleij6e8cef42006-12-03 20:45:04 +0000564 they have been banned from using it.
565
Linus Walleijda558be2007-03-10 21:42:25 +0000566* iriver devices have problems with older versions of libmtp and
Linus Walleij82265222007-03-04 19:47:08 +0000567 with new devices libmtp does not know of as of yet, since it
568 has an oldstyle USB device controller that cannot handle zero
Linus Walleijda558be2007-03-10 21:42:25 +0000569 writes. (Register your device with us!) All their devices are
570 likely to need a special device flag in the src/libusb-glue.c
571 database.
Linus Walleij82265222007-03-04 19:47:08 +0000572
Linus Walleij6e8cef42006-12-03 20:45:04 +0000573* The Samsung Yepp T9 has several strange characteristics, some
574 that we've managed to work around. (For example it will return
575 multiple PTP packages in a single transaction.)
576
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000577* The early firmware for Philips HDD players is known to be
Linus Walleijf2711b32007-02-26 20:18:40 +0000578 problematic. Please upgrade to as new firmware as you can get.
579 (Yes this requires some kind of Windows Installation I think.)
580
Linus Walleijb5a4f922008-05-11 20:15:00 +0000581* Philips HDD 1630/16 or 1630/17 etc may lock themselves up,
582 turning inresponsive due to internal corruption. This typically
583 gives an error in opening the PTP session. Apparently you can
584 do a "repair" with the firmware utility (Windows only) which
585 will often fix this problem and make the device responsive
586 again.
587
Linus Walleij9340aac2007-10-01 10:02:05 +0000588* Some devices that implement GetObjectPropList (0x9805) will
589 not return the entire object list if you request a list for object
590 0xffffffffu. (But they should.) So they may need the special
591 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST_ALL.
592
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000593* Some (smaller) subset of devices cannot even get all the
Linus Walleij9340aac2007-10-01 10:02:05 +0000594 properties for a single object in one go, these need the
595 DEVICE_FLAG_BROKEN_MTPGETOBJPROPLIST. Currently only the
596 iriver devices seem to have this bug.
597
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000598* The Toshiba Gigabeat S (and probably its sibling the
Linus Walleij9340aac2007-10-01 10:02:05 +0000599 Microsoft Zune and other Toshiba devices) will only display
600 album information tags for a song in case there is also
601 an abstract album (created with the album interface) with
602 the exact same name.
Linus Walleijd132d8e2007-04-03 23:24:54 +0000603
Linus Walleij265b9d62007-11-25 20:08:15 +0000604* The Zen Vision:M has an older firmware which is very corrupt,
605 it is incompatible with the Linux USB stack altogether. The
606 kernel dmesg will look something like this, and you have to
607 upgrade the firmware using Windows:
608 usb 4-5: new high speed USB device using ehci_hcd and address 5
609 usb 4-5: configuration #1 chosen from 1 choice
610 usb 4-5: can't set config #1, error -110
Linus Walleijd132d8e2007-04-03 23:24:54 +0000611
Linus Walleij103a78e2008-08-25 20:48:52 +0000612* The Sirus Stiletto does not seem to allow you to copy any files
613 off the device. This may be someone's idea of copy protection.
Linus Walleijb715ba62008-02-12 23:41:49 +0000614
Linus Walleij25a16302009-03-04 13:56:33 +0000615* The Samsung P2 assigns parent folder ID 0 to all unknown file
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000616 types.(i.e. moves them to the root folder)
Linus Walleij1b91ca62008-10-17 07:07:56 +0000617
Linus Walleij7c64a062010-02-06 01:13:08 +0000618* The Sandisk Sansa Clip+ needs a firmware upgrade in earlier
619 versions in order to work properly.
620
Linus Walleijd132d8e2007-04-03 23:24:54 +0000621Lost symbols
622------------
623
624Shared libraries can be troublesome to users not experienced with
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000625them. The following is a condensed version of a generic question
Linus Walleijd132d8e2007-04-03 23:24:54 +0000626that has appeared on the libmtp mailing list from time to time.
627
628> PTP: Opening session
629> Queried Creative Zen Vision:M
630> gnomad2: relocation error: gnomad2: undefined symbol:
631> LIBMTP_Get_Storageinfo
632> (...)
633> Are these type of errors related to libmtp or something else?
634
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000635The problem is of a generic nature, and related to dynamic library
Linus Walleijd132d8e2007-04-03 23:24:54 +0000636loading. It is colloquially known as "dependency hell".
637(http://en.wikipedia.org/wiki/Dependency_hell)
638
639The gnomad2 application calls upon the dynamic linker in Linux to
640resolve the symbol "LIBMTP_Get_Storageinfo" or any other symbol
641(ELF symbol, or link point or whatever you want to call them, a
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000642symbol is a label on a memory address that the linker shall
Linus Walleijd132d8e2007-04-03 23:24:54 +0000643resolve from label to actual address.)
644For generic information on this subject see the INSTALL file and
645this Wikipedia page:
646
647http://en.wikipedia.org/wiki/Library_(computing)
648
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000649When Linux /lib/ld-linux.so.X is called to link the symbols compiled
650into gnomad2 (or any other executable using libmtp), it examines the
651ELF file for the libmtp.so.X file it finds first and cannot resolve
Linus Walleijd132d8e2007-04-03 23:24:54 +0000652the symbol "LIBMTP_Get_Storageinfo" (or whichever symbol you have a
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000653problem witj) from it, since it's probably not there. There are many
Linus Walleijd132d8e2007-04-03 23:24:54 +0000654possible causes of this symbol breakage:
655
6561) You installed precompiled libmtp and gnomad2 packages (RPMs, debs
657 whatever) that do not match up. Typical cause: your gnomad2 package was
658 built against a newer version of libmtp than what's installed on your
659 machine. Another typical cause: you installed a package you found on
660 the web, somewhere, the dependency resolution system did not protest
661 properly (as it should) or you forced it to install anyway, ignoring
662 some warnings.
663
6642) You compiled libmtp and/or gnomad2 from source, installing both or
665 either in /usr/local/lib and /usr/local/bin. This means at compile-time
666 gnomad2 finds the libmtp library in /usr/local/lib but at runtime, it
667 depends on the Linux system wide library loader (/lib/ld-linux.so.X) in
668 order to resolve the symbols. This loader will look into the file
669 /etc/ld.so.conf and/or the folder /etc/ld.so.conf.d in order to find
670 paths to libraries to be used for resolving the symbols. If you have
671 some older version of libmtp in e.g. /usr/lib (typically installed by a
672 package manager) it will take precedence over the new version you just
673 installed in /usr/local/lib and the newly compiled library in
674 /usr/local/lib will *not* be used, resulting in this error message.
675
6763) You really did install the very latest versions (as of writing libmtp
677 0.1.5 and gnomad2 2.8.11) from source and there really is no
678 pre-installed package of either on your machine. In that case I'm
679 totally lost, I have no idea what's causing this.
680
681Typical remedies:
682
6831) If you don't want to mess around with your system and risk these
684 situations, only use pre-packaged software that came with the
685 distribution or its official support channels. If it still breaks,
686 blame your distribution, they're not packaging correctly. Relying on
687 properly packaged software and not installing things yourself *is* the
688 Linux solution to the "dependency hell" problem.
689
6902) Read about dynamically linked library handling until the stuff I wrote
691 about in the previous list sounds like music to your ears, inspect
692 your /lib, /usr/lib, /usr/local/lib, /etc/ld.so.conf and the
693 /etc/ld.so.conf.d, remove all pre-packed versions using RPM, APT,
694 YaST or whatever your distribution uses, compile libmtp and gnomad2
695 (or whatever) from source only and you will be enlighted.
696
697I don't know if this helps you, it's the best answer we can give.
Linus Walleij387e37a2008-10-29 17:22:22 +0000698
699
700API is obscure - I want plain files!
701------------------------------------
702
703PTP/MTP devices does not actually contain "files", they contain
704objects. These objects have file names, but that is actually
705just a name tag on the object.
706
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000707Folders/directories aren't really such entities: they are just
Linus Walleij387e37a2008-10-29 17:22:22 +0000708objects too, albeit objects that can act as parent to other
Linus Walleij8aba06d2008-12-28 08:26:57 +0000709objects. They are called "associations" and are created in atomic
Linus Walleij387e37a2008-10-29 17:22:22 +0000710fashion and even though there is an MTP command to get all the
Linus Walleij8aba06d2008-12-28 08:26:57 +0000711associations of a certain association, this command is optional
712so it is perfectly possible (and most common, actually) to create
713devices where the "folders" (which are actually associations) have
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000714no idea whatsoever of what files they are associated as parents to
Linus Walleij387e37a2008-10-29 17:22:22 +0000715(i.e. which files they contain). This is very easy for device
Linus Walleij8aba06d2008-12-28 08:26:57 +0000716manufacturers to implement, all the association (i.e. finding out
717which files are in a certain folder) has to be done by the MTP
718Initiator / host computer.
Linus Walleij387e37a2008-10-29 17:22:22 +0000719
720Moving a file to a new folder is for example very simple in a
721"real" file system. In PTP/MTP devices it is often not even possible,
722some devices *may* be able to do that. But actually the only
723reliable way of doing that is to upload the file to the host,
Linus Walleij8aba06d2008-12-28 08:26:57 +0000724download it with the new parent, then delete the old file.
Linus Walleij387e37a2008-10-29 17:22:22 +0000725We have played with the idea of implementing this time consuming
726function, perhaps we will.
727
Linus Walleij8aba06d2008-12-28 08:26:57 +0000728Then the issue that in PTP/MTP it is legal for two files to have
729exactly the same path as long as their object IDs differ. A
730folder/association can contain two files with the exact same name.
731(And on the Creative devices this even works, too, though most devices
732implicitly fail at this.) Perhaps one could add some custom hook for
733handling that, so they become /Foo.mp3 and /Foo.mp3(1) or something
734similar, but it's really a bit kludgy.
735
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000736Playlists and albums aren't really files, thinking about
Linus Walleij387e37a2008-10-29 17:22:22 +0000737them as files like the hacks in libgphoto2 is really backwards. They are
738called associations and are more like a symbolic link that links in a
739star-shaped pattern to all the files that are part of the album/playlist.
740Some devices (Samsung) thought that was too complicated and have a
741different way of storing playlists in an UTF-16 encoded .spl-like file
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000742instead! This is why playlists/albums must have their own structs and
Linus Walleij387e37a2008-10-29 17:22:22 +0000743functions.
744
Linus Walleij8aba06d2008-12-28 08:26:57 +0000745Plain file access also assumes to be able to write files of an
746undetermined size, which is simply not possible in a transactional
747file system like PTP/MTP. (See further below.)
748
Linus Walleij387e37a2008-10-29 17:22:22 +0000749
750I Want Streaming!
751-----------------
752
753Streaming reads is easy. Just connect the output file descriptor from
754LIBMTP_Get_File_To_File_Descriptor() (and a similar function for tracks)
755wherever you want.
756
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000757People have connected this to TCP sockets for streaming web servers
758etc, works like a charm. Some devices will even survive if the callback
Linus Walleij387e37a2008-10-29 17:22:22 +0000759functions return non-zero and cancel the download. Some devices will
760lock up and even require a reset if you do that. Devices are poorly
761implemented so that's life. If you want to stream off a device, the
762best idea is always to stream the entire file and discard the stuff
763at the end you don't want. It will incur a delay if you e.g. want to
764skip between tracks, sadly.
765
766Then we get to the complicated things: streaming WRITES...
767
768There is a function:
769LIBMTP_Send_File_From_File_Descriptor() (and similar for tracks)
770which will write a file to a device from a file descriptor, which may
771be a socket or whatever.
772
773HOWEVER: this requires a piece of metadata with the .filesize properly
774set first.
775
776This is not because we think it is funny to require that, the protocol
777requires it. The reason is that PTP/MTP is a transactional file system
778and it wants to be able to deny file transfer if the file won't fit on
779the device, so the transaction never even starts, it's impossible to
780start a transaction without giving file length.
781
782People really want streaming so I tried a lot of hacks to see if they
783would work, such as setting file size to 0xffffffffU or something other
784unnaturally big and then aborting the file transfer when the stream ends.
785It doesn't work: either the device crashes or the file simply disappears
786since the device rolls back all failed transactions.
787
788So this is an inherent limitation of the PTP/MTP protocol.
Linus Walleijbe8b03b2009-10-16 21:19:35 +0000789
790
791I make MTP devices!
792-------------------
793
794If you are a device vendor there is a lot you can do for libmtp:
795
796* Please consider assigning one of your employees as a contact person
797 for libmtp, have them sign up to the libmtp development list and answer
798 questions and post new device ID:s as they are released to our
799 mailing list.
800
801* If you want to help even more, assign someone to look deeper into
802 error reports on your specific devices, understand why your firmware
803 may require some special device flags and what can be done about it.
804
805* Do you have spare devices you can give us? Send them to Richard (Mac
806 support) or Linus (Linux support). (So far nobody did that except for
807 Microsoft who sent us a Zune by proxy!)
808
809Vendors do need help from libmtp too, especially we want to help
810vendors improve their MTP stacks, because they all suffer from the
811same problem: the lack of a proper conformance test has made many devices
812incompliant with the MTP specification as it is published today: most
813devices are just compliant with the Windows MTP stack, and don't work
814out-of-the-box with libmtp. We need someone on the inside to help in
815bug reporting vendors MTP stacks internally so these issues are raised.
816A good way to go toward better MTP compliance is to test with an
817alternative implementation of the stack. In e.g. IETF standardization
818it is compulsory for an RFC to have atleast two independent implementations
819for it to reach the status as standard.
820
821Being compliant with libmtp is also more and more important for
822vendors: libmtp is being deployed in some embedded systems like
823set-top-boxes etc. It will be very irritating for customers if a device
824will not dock properly with some home entertainment equipment just because
825it is based on Linux and libmtp and not the Windows MTP stack.
Linus Walleij5f5c69f2011-06-26 14:34:13 +0200826
827Autodetect with gudev
828---------------------
829
830Previously you would use HAL to detect devices being plugged in. Nowadays
831we use udev directly, or though the GNOME libgudev library. LIBMTPs
832default udev rules export the proper properties to detect any MTP device
833automatically, here is a verbose example derived from gnomad2:
834
835#define G_UDEV_API_IS_SUBJECT_TO_CHANGE
836#include <gudev/gudev.h>
837const char * const gudev_subsystems[] = { "usb", NULL };
838GUdevClient *gudev_client;
839guint uevent_id;
840guint uevent_bus_hooked = 0;
841guint uevent_device_hooked = 0;
842
843
844static void uevent_cb(GUdevClient *client, const char *action, GUdevDevice *device, void *data)
845{
846 guint64 devicenum;
847 guint vendor;
848 guint model;
849 guint busnum;
850 guint devnum;
851 guint mtpdevice;
852
853 devicenum = (guint64) g_udev_device_get_device_number(device);
854 g_print("%s event for %s (%"G_GINT64_MODIFIER"x)", action,
855 g_udev_device_get_sysfs_path (device), devicenum);
856
857 /* get device info */
858 vendor = get_property_as_int(device, "ID_VENDOR_ID", 16);
859 model = get_property_as_int(device, "ID_MODEL_ID", 16);
860 busnum = get_property_as_int(device, "BUSNUM", 10);
861 devnum = get_property_as_int(device, "DEVNUM", 10);
862 mtpdevice = get_property_as_int(device, "ID_MTP_DEVICE", 10);
863
864 if (vendor == 0 || model == 0) {
865 g_print("couldn't get vendor or model ID for device at (%x:%x)\n",
866 busnum, devnum);
867 return;
868 } else {
869 g_print("vendor = %x, model = %x, bus = %x, device = %x\n",
870 vendor, model, busnum, devnum);
871 }
872
873 if (mtpdevice) {
874 g_print("device is MTP compliant\n");
875
876 if (g_str_equal(action, "add") &&
877 uevent_bus_hooked == 0 &&
878 uevent_device_hooked == 0) {
879 g_print(MTP device plugged in!\n");
880 uevent_bus_hooked = busnum;
881 uevent_device_hooked = devnum;
882 scan_jukebox(NULL);
883 } else if (g_str_equal (action, "remove") &&
884 uevent_bus_hooked == busnum &&
885 uevent_device_hooked == devnum) {
886 g_print("MTP device removed!\n");
887 uevent_bus_hooked = 0;
888 uevent_device_hooked = 0;
889 }
890 }
891}
892
893
894
895(...)
896 /*
897 * Monitor udev device events - we're only really interested in events
898 * for USB devices.
899 */
900 gudev_client = g_udev_client_new(gudev_subsystems);
901 uevent_id = g_signal_connect_object(gudev_client,
902 "uevent",
903 G_CALLBACK(uevent_cb),
904 NULL, 0);