Okay, so This is the third (and hopefully final) walkthrough for getting your iPhone to sync with Gentoo and now I am incorporating file transfer and music management. The process is actually very simple, but you should make sure to follow all of the steps. I encountered some problems along the way as well; I received an error from one of the commands that used in other walkthroughs “Couldn’t read xml sysinfo from uuid.” I simply fixed it by “READING” all of the steps properly and everything worked, so if you don’t read, you won’t get it!
Even though I have thanked him once before, thanks again to Marcan and his blog. His hard work has made this possible. I recommend reading his walkthrough to get a better understanding of everything. This walkthrough is a similar walkthrough to his, but targets Gentoo. As stated in all other walkthroughs, you do not need to jailbreak your phone, but I recommend it, makes everything easier. I nor any developer or provider is responsible for any damages that you cause by following our walkthroughs, so, if you brick, it is on you. Lastly, your iPhone should have already been plugged into iTunes and received a song at least once.
The way I did it might not be the way it SHOULD be done, but it did work. If you know of a better way, please bring it to light.
First, you will need the Rion overlay like I wrote in earlier posts.
# layman -a rion
# layman -S
# echo `PORTDIR_OVERLAY="/usr/local/portage/layman/rion"` >> /etc/make.conf
# env-update
# eix-update
Next, you will need to emerge a few needed packages. I found that the libgpod package in portage isn’t going to work, so will have to manually install that one from the sourceforge project page. In the mean time, I will try writing an ebuild for it so that it can be emerged. (I emerged it, an then built new one over it) Additionally, the versions that you have will also matter, but the 9999 versions mostly don’t work yet, so a couple of entries into your package.keywords and package.use will be necessary. Also, before emerging any of this, I would recommend adding “ipod” you your USE flags in your /etc/make.conf file.
# echo "media-libs/libgpod gtk hal python test" >> /etc/portage/package.use
# echo "dev-util/gtk-doc debug doc" >> /etc/portage/package.use
# echo "=app-pda/libplist-9999" >> /etc/portage/package.mask
# echo "=app-pda/libiphone-9999" >> /etc/portage/package.mask
# echo "=app-pda/ifuse-9999" >> /etc/portage/package.mask
# echo "dev-libs/libusb **" >> /etc/portage/package.keywords
# echo "app-pda/ifuse **" >> /etc/portage/package.keywords
# echo "app-pda/libplist **" >> /etc/portage/package.keywords
# echo "app-pda/libiphone **" >> /etc/portage/package.keywords
# echo "app-pda/usbmuxd **" >> /etc/portage/package.keywords
# emerge -va libusb libiphone ifuse libplist usbmuxd libgpod gtk-doc gtkpod dev-util/git
Next, you will need to build the custom version of libgpod. If everything is built right on your system, then you should be fine, but if you get any errors, of course you will need to fix them before you continue. You will need git in order to obtain this build from the sourceforge repository. Find a nice location on your drive, and as root, execute the following.
# cd libgpod
# CFLAGS="-g -O0" sh autogen.sh --prefix=/usr
# make
# make install
Now, we have start testing everything out. We need to make sure that your phone is fully connected once you plug it in, and we need to make sure that usbmuxd is detecting your phone. We have to create the usbmux user so that usbmuxd will work properly. You will have to make sure that this user has access to usb and plugdev. I added wheel too, but it isn’t necessary.
Once everything is emerged successfully, you need to test out and make sure that your iphone is being registered when it connects. First you will have to modify the udev rules so that you can see the output. Increase the syslog debug level by editing “/lib/udev/rules.d/85-usbmuxd.rules” and adding “-v -v” flags to the end of both RUN statements. Now you can run the following and see if usbmuxd is seeing your iphone.
Jan 9 12:43:24 ghost kernel: [139025.359663] ehci_hcd 0000:00:1d.7: GetStatus port 2 status 001403 POWER sig=k CSC CONNECT
Jan 9 12:43:24 ghost kernel: [139025.359670] hub 2-0:1.0: port 2, status 0501, change 0001, 480 Mb/s
Jan 9 12:43:24 ghost kernel: [139025.385242] ehci_hcd 0000:00:1d.7: GetStatus port 2 status 001002 POWER sig=se0 CSC
Jan 9 12:43:24 ghost kernel: [139025.463060] ehci_hcd 0000:00:1d.7: GetStatus port 2 status 001803 POWER sig=j CSC CONNECT
Jan 9 12:43:24 ghost kernel: [139025.567304] hub 2-0:1.0: debounce: port 2: total 200ms stable 100ms status 0x501
Jan 9 12:43:24 ghost kernel: [139025.618227] ehci_hcd 0000:00:1d.7: port 2 high speed
Jan 9 12:43:24 ghost kernel: [139025.618232] ehci_hcd 0000:00:1d.7: GetStatus port 2 status 001005 POWER sig=se0 PE CONNECT
Jan 9 12:43:24 ghost kernel: [139025.669065] usb 2-2: new high speed USB device using ehci_hcd and address 14
Jan 9 12:43:24 ghost kernel: [139025.720353] ehci_hcd 0000:00:1d.7: port 2 high speed
Jan 9 12:43:24 ghost kernel: [139025.720358] ehci_hcd 0000:00:1d.7: GetStatus port 2 status 001005 POWER sig=se0 PE CONNECT
Jan 9 12:43:24 ghost kernel: [139025.785527] usb 2-2: skipped 3 descriptors after interface
Jan 9 12:43:24 ghost kernel: [139025.785530] usb 2-2: skipped 2 descriptors after interface
Jan 9 12:43:24 ghost kernel: [139025.785533] usb 2-2: skipped 1 descriptor after endpoint
Jan 9 12:43:24 ghost kernel: [139025.785535] usb 2-2: skipped 1 descriptor after interface
Jan 9 12:43:24 ghost kernel: [139025.788140] usb 2-2: default language 0x0409
Jan 9 12:43:24 ghost kernel: [139025.789388] usb 2-2: udev 14, busnum 2, minor = 141
Jan 9 12:43:24 ghost kernel: [139025.789391] usb 2-2: New USB device found, idVendor=05ac, idProduct=1292
Jan 9 12:43:24 ghost kernel: [139025.789393] usb 2-2: New USB device strings: Mfr=1, Product=2, SerialNumber=3
Jan 9 12:43:24 ghost kernel: [139025.789395] usb 2-2: Product: iPhone
Jan 9 12:43:24 ghost kernel: [139025.789397] usb 2-2: Manufacturer: Apple Inc.
Jan 9 12:43:24 ghost kernel: [139025.789399] usb 2-2: SerialNumber: 69a4294a91a56958927f3fafe0086bf90ccd2d2b
Jan 9 12:43:24 ghost kernel: [139025.789469] usb 2-2: uevent
Jan 9 12:43:24 ghost kernel: [139025.789486] usb 2-2: usb_probe_device
Jan 9 12:43:24 ghost kernel: [139025.789489] usb 2-2: configuration #1 chosen from 4 choices
Jan 9 12:43:24 ghost kernel: [139025.791263] usb 2-2: adding 2-2:1.0 (config #1, interface 0)
Jan 9 12:43:24 ghost kernel: [139025.791282] usb 2-2:1.0: uevent
Jan 9 12:43:24 ghost kernel: [139025.791351] drivers/usb/core/inode.c: creating file '014'
Jan 9 12:43:24 ghost kernel: [139025.791371] hub 2-0:1.0: state 7 ports 6 chg 0000 evt 0004
Jan 9 12:43:24 ghost kernel: [139025.791385] usb 2-2: usb_disable_device nuking non-ep0 URBs
Jan 9 12:43:24 ghost kernel: [139025.791388] usb 2-2: unregistering interface 2-2:1.0
Jan 9 12:43:24 ghost kernel: [139025.791434] usb 2-2:1.0: uevent
Jan 9 12:43:24 ghost kernel: [139025.793892] usb 2-2: adding 2-2:4.0 (config #4, interface 0)
Jan 9 12:43:24 ghost kernel: [139025.793929] usb 2-2:4.0: uevent
Jan 9 12:43:24 ghost kernel: [139025.793989] usb 2-2: adding 2-2:4.1 (config #4, interface 1)
Jan 9 12:43:24 ghost kernel: [139025.794005] usb 2-2:4.1: uevent
Jan 9 12:43:24 ghost kernel: [139025.794035] usb 2-2: adding 2-2:4.2 (config #4, interface 2)
Jan 9 12:43:24 ghost kernel: [139025.794053] usb 2-2:4.2: uevent
Jan 9 12:43:24 ghost kernel: [139025.811303] usb 2-2: uevent
Now it is time to mount the device, create some required folders, and get your UUID. Since you now have ifuse, you can easily mount your device, but in order to do this, it is required to be in a specific location. Additionally, if you want your users (not root) to also have ifuse privileges, you will need to edit the config files to do that.
# mkdir /mnt/ipod
# chmod 777 /mnt/ipod
# ifuse /mnt/ipod
# mkdir /mnt/ipod/iTunes_Control/Device
Now obtain your UUID either from the logs, or by running…
Your UUID is a long hexadecimal string that is roughly 40 characters long. In the longs above, mine is 69a4294a91a56958927f3fafe0086bf90ccd2d2b. Now, lets generate the XML file for your phone, simply run…
This will create the file iTunes_Control/Device/SysInfoExtended file. Make sure there is stuff in it, and it is not empty. It should be a large XML file with a bunch of info.
If there were no errors, then you are good to go. You can now sync up with linux and transfer music. In the future, when you plug your device in, you simply need to run…
I have been using GTKPod to transfer my music over to the device, however, it should work with other applications like RhythmBox or Amarok. I haven’t tried them out yet, but I would be interested to see if anyone gets that working.
0 Responses to “iPhone 3.x Sync’ed in Linux (Full Gentoo Guide)”