====== Booting From Usb Otg Port ======
//__About this Article__//
* **Author**: benn --- benn@cubietech.com --- 2013/10/24 17:02
* **Copyrights**: [[http://creativecommons.org/licenses/by-sa/3.0/|CC Attribution-Share Alike 3.0 Unported]]
* **Contributors**: [[http://cubieboard.org/|Cubieboard Community]] : ...
===== Abstract =====
Here we provide a simple way to boot linux from USB OTG port. It's very useful when our system damaged somehow, and we can fix it if we could access to the storeage, e.g. nand, sata, or SD Card.
===== Host Enviroment =====
Ubuntu 12.04 x86_64
===== Step-by-step =====
==== Download all we need ====
$wget http://dl.cubieboard.org/software/a20-cubietruck/common/usbboot-fel.tar.gz
$tar -zxvf usbboot-fel.tar.gz
to check the md5sum(optional)
$wget http://dl.cubieboard.org/software/a20-cubietruck/common/usbboot-fel.tar.gz.md5
$ md5sum usbboot-fel.tar.gz
f09f92833dc419207c7c9cd71ad65cc4 usbboot-fel.tar.gz
$ cat usbboot-fel.tar.gz.md5
f09f92833dc419207c7c9cd71ad65cc4 usbboot-fel.tar.gz
==== Enter FEL Mode ====
FEL is a low-level subroutine containing in the BootROM on allwinner devices. It is used for provisioning and recovery of devices using USB. When the chip goes to FEL mode, the chip will be waiting for communication from PC though USB. The primary purpose for FEL is for flashing the NAND with the PC tool LiveSuit. For more detailed please refer to [[http://linux-sunxi.org/FEL|FEL MODE]]
To enter FEL mode here:
- Power off the device
- Press and hold FEL key
- Press and hold power key for about 2s (power on the device, when powering on, if a key is pressed, the devices will not boot until key released)
After entering FEL mode, we suggest you to plug in AC adapter if you have SATA drive on board, avoiding low current from USB.
==== Upload Images ====
$cd usbboot-fel
$ ./usb-boot ./u-boot-spl.bin ./u-boot.bin ./uImage ./script.bin ./initramfs.img
fel write 0x2000 ./u-boot-spl.bin
fel exe 0x2000
fel write 0x4a000000 ./u-boot.bin
fel write 0x41000000 ./bin/ramboot.scr
fel write 0x43000000 ./script.bin
fel write 0x44000000 ./uImage
fel write 0x4c000000 ./initramfs.img
fel exe 0x4a000000
==== Tips ====
*Setting GMAC
udhcpc
*default user and password
root/root
*Change to VGA output
$cd usbboot-fel/
$ ls
adb-devprobe.sh bin2fex fel fex2bin initramfs.img pio u-boot.bin uImage
bin bootinfo fel-gpio fexc nand-part script.bin u-boot-spl.bin usb-boot
./bin2fex script.bin 1.fex
fexc-bin: script.bin: version: 0.1.2
fexc-bin: script.bin: size: 46472 (85 sections)
vim 1.fex (here change the output type
./fex2bin 1.fex script.bin
=====Customizing=====
====Replace fel/usb-boot====
The fel/usb-boot in this manual is X86_64bit version. If you want to use it under I386 or even arm platform, you need to compile the tools by yourself. fel/usb-boot are part of sunxi-tools, and the latest source code can be found at http://github.com/linux-sunxi/sunxi-tools.git.
* Getting Source Code
$git clone git://github.com/linux-sunxi/sunxi-tools.git
* Compiling
$cd sunxi-tools
$make
and then replace the tools with the one you built
====initramfs.img====
*Refer to http://github.com/hno/miniroot
=== See Also ===
*http://linux-sunxi.org/FEL
*http://linux-sunxi.org/FEL/USBBoot
{{tag>Cubieboard Cubietruck}}