Linux
Contents
Current: Freemyipod Linux
We are working on supporting Samsung/S5L-based devices which have an MMU. Currently our main focus is the Nano 5G, and an experimental source tree is available on github.com/freemyipod/linux.
User Guide
Not yet available, as the Linux port isn't yet practical to use. We have no storage drivers, no screen driver, no sound driver...
Developer Guide
If you're somewhat familiar with embedded Linux, you can get started on the Nano 5G by building wInd3x, U-Boot and the Kernel as described below. However, you will have to provide your own userland (eg. buildroot, archlinux arm, ... anything armv6 compatible) and either run it from an initramfs or over NFS. A serial cable is not necessary, but very useful to troubleshoot boot issues.
Build everything
These are not copy-paste instructions. You are expected to understand what's happening.'
You will need an arm-none-eabi- toolchain into your $PATH, eg. gcc-arm-embedded from your package manager.
First, wInd3x: this will be used to run u-boot.
$ git clone https://github.com/freemyipod/wInd3x $ cd wInd3x $ go build ./
Second, U-Boot:
$ git clone https://github.com/freemyipod/u-boot $ cd u-boot $ git checkout n5g-wip $ make nano5g_defconfig $ make CROSS_COMPILE=arm-none-eabi- u-boot.bin -j 32
Third, Linux:
$ git clone https://github.com/freemyipod/linux $ cd linux $ git checkout n5g-wip $ make ARCH=arm nano5g_defconfig $ make ARCH=arm CROSS_COMPILE=arm-none-eabi- -j 32 zImage
By this point, have a initramfs ready. If you wanna boot directly from nfs, edit CMDLINE in the kernel .config accordingly.
Finally, bundle together an u-boot image containing the kernel, your initramfs, and the device-tree (built by u-boot):
$ mkimage -A arm -C none -O linux -T multi -a 0x08000000 -e 0x08000000 -d arch/arm/boot/zImage:initramfs.gz:../u-boot/arch/arm/dts/s5l8730.dtb mImage
mImage is your combined image.
Running
Connect your Nano 5G in DFU mode.
Run u-boot using wInd3x:
$ ./wInd3x cfw run ../u-boot/u-boot.bin
This should start u-boot. Running this for the first time will take a while, as some bootloader stages need to be downloaded, decrypted and modified. A new USB device (05ac:2137) appear on your host. Use dfu-util to upload mImage:
dfu-util -d 05ac:2137 -D linux/mImage -R
Then, in the serial console you'll see Linux booting:
## Booting kernel from Legacy Image at 08000000 ... ... Starting kernel ... [ 0.000000] Booting Linux on physical CPU 0x0 [ 0.000000] Linux version 6.2.0-rc4-00476-g4c4af4d7e53c (q3k@mimeomia) (arm-none-eabi-gcc (GNU Arm Embedded Toolchain 10.3-2021.10) 10.3.1 20210824 (release), GNU ld (GNU Arm Embedded Toolchain 10.3-2021.10) 2.36.1.20210621) #70 Fri Jan 20 18:02:56 CET 2023 ...
The LCD display should start up and show a boot log. If not, try adding console=tty0
to your CMDLINE? You might also use fbcon=rotate:1
to rotate the framebuffer 90 degrees.
If everything goes well, the kernel should boot up and attempt to mount a rootfs. It's up to you to get this part working, at least until we streamline the process. The USB CDC EEM ethernet gadget should also appear on your host (probably as usb0, or some long systemd predictable name). The other end will be visible as 'usb0' on the device.
Now go on and have a go at reverse-engineering some peripherals! :)
Legacy: iPodLinux
The iPodLinux project supports all the PortalPlayer based iPods: iPod 1G-4G, Photo/Color, Video/5G/5.5G, Mini, iPod Nano 1G. It is currently semi-abandoned, and uses a very old ucLinux kernel build.