This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
uboot_common [2011/07/14 17:14] – simon | uboot_common [2011/07/15 23:28] (current) – delete page simon | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | ====== Extending U-Boot support (common) | ||
- | This page group together all the common [[http:// | ||
- | |||
- | ===== Repository ===== | ||
- | |||
- | Sources are available in the [[http:// | ||
- | |||
- | * **stable** is used to build the images distributed via a [[ftp:// | ||
- | * **master** is a development branch, holding the patches waiting to be merged mainline. | ||
- | |||
- | Checkout command: | ||
- | |||
- | git clone http:// | ||
- | or | ||
- | git clone git:// | ||
- | |||
- | ===== Build ===== | ||
- | |||
- | To compile U-Boot images, you could use the following commands (toolchain path, cross-compiler and board names to be replaced): | ||
- | |||
- | PATH=/ | ||
- | PATH=/ | ||
- | | ||
- | ===== Downloads ===== | ||
- | |||
- | For the supported boards, some pre-compiled U-Boot images are availables in the [[ftp:// | ||
- | |||
- | ===== Install from a LaCie stock U-Boot ===== | ||
- | |||
- | ==== Why ? ==== | ||
- | |||
- | * The LaCie stock U-Boot comes with a huge limitation. At reset, U-Boot reinitialize the boot environment variables (stored in Flash) with some built-in values. This includes the boot commands sequence. As a consequence, | ||
- | |||
- | * Save flash size (a LaCie U-Boot image size is ~450KB against ~230KB for a mainline one). | ||
- | |||
- | * Boot reliably from USB. | ||
- | |||
- | * Some command line enhancements: | ||
- | |||
- | * Be able to add a new feature. | ||
- | |||
- | ==== Update step by step ==== | ||
- | |||
- | This section present step by step how to update the stock U-Boot with a mainline version. A Network Space v2 board is used but the process should work with all the other LaCie boards supported by U-Boot mainline. | ||
- | |||
- | === Preparations === | ||
- | |||
- | * Create a work directory | ||
- | |||
- | $ mkdir /tmp/tools && cd /tmp/tools | ||
- | |||
- | * Get [[CLUNC|CLUNC]] | ||
- | |||
- | $ wget ftp:// | ||
- | $ tar xf clunc-1.1.tar.gz | ||
- | |||
- | * Get U-Boot **netconsole** utility | ||
- | |||
- | $ wget ftp:// | ||
- | $ tar xf u-boot-netconsole.tar.gz | ||
- | |||
- | * Setup and enable a TFTP server. The configuration really depends on your OS. For example, a Linux distribution could be use **inetd** (the configuration file is / | ||
- | |||
- | * Install the new u-boot image into the TFTP root directory (could be / | ||
- | |||
- | $ wget ftp:// | ||
- | | ||
- | === Run CLUNC and connect to the LaCie U-Boot console === | ||
- | |||
- | Both a serial or a network console can be used to connect to U-Boot. For this how-to, the netconsole way is preferred because it is cheaper. The user don't have to build/buy a serial cable. | ||
- | |||
- | $ cd / | ||
- | $ ./clunc -i < | ||
- | Marvell>> | ||
- | U-Boot 1.1.4 (Jan 17 2011 - 21:48:29) Marvell version: 3.4.16 | ||
- | | ||
- | === Flash the new U-Boot image === | ||
- | |||
- | Marvell>> | ||
- | Using egiga0 device | ||
- | TFTP from server 192.168.0.13; | ||
- | Filename ' | ||
- | Load address: 0x2000000 | ||
- | Loading: ########################################## | ||
- | done | ||
- | Bytes transferred = 214220 (344cc hex) | ||
- | Un-Protect Flash Monitor space | ||
- | | ||
- | **Warning** | ||
- | If U-Boot Endiannes is going to change (LE->BE or BE->LE), Then Env parameters should be overriden.. | ||
- | Override Env parameters? (y/n) n | ||
- | Erase 0 - 125 sectors... | ||
- | ................................................................. | ||
- | ............................................................. | ||
- | Copy to Flash... done | ||
- | Protect Flash Monitor space | ||
- | | ||
- | === Restart === | ||
- | |||
- | Marvell>> | ||
- | | ||
- | === Retrieve the NAS IP address === | ||
- | |||
- | U-Boot mainline don't provide a magic packet mechanism to configure the IP address. Instead DHCP is used. It means that [[CLUNC|CLUNC]] becomes useless from this point. | ||
- | |||
- | Some possible ways to retrieve the NAS IP address: | ||
- | |||
- | * Use an utility like **dhcpdump**. | ||
- | * Look in the DHCP server log. | ||
- | * Configure and run your own DHCP server. | ||
- | |||
- | === Connect to U-Boot via netconsole === | ||
- | |||
- | The netconsole configuration rely on some environment variables: **ipaddr**, **ncip**, **stdin**, **stdout** and **stderr** (for more information, | ||
- | |||
- | <note important> | ||
- | **netcat** don't handle the UDP broadcast messages. The dedicated U-Boot tools **netconsole** and **ncb** must be used. | ||
- | </ | ||
- | |||
- | * Run **netconsole** and interrupt boot process (Ctrl-C): | ||
- | |||
- | $ cd / | ||
- | $ ./ | ||
- | ^C | ||
- | ns2> version | ||
- | arm-none-eabi-gcc (Sourcery G++ Lite 2010q1-188) 4.4.1 | ||
- | GNU ld (Sourcery G++ Lite 2010q1-188) 2.19.51.20090709 | ||
- | |||
- | === Default configuration === | ||
- | |||
- | ns2> print | ||
- | autoload=no | ||
- | baudrate=115200 | ||
- | bootargs=console=ttyS0, | ||
- | bootcmd=dhcp && run netconsole; if run usbload || run diskload; then bootm; fi | ||
- | bootdelay=3 | ||
- | bootfile=uImage | ||
- | diskload=ide reset && ext2load ide 0:1 $loadaddr / | ||
- | dnsip=212.27.40.240 | ||
- | ethact=egiga0 | ||
- | ethaddr=02: | ||
- | gatewayip=192.168.0.254 | ||
- | ipaddr=192.168.0.15 | ||
- | loadaddr=0x800000 | ||
- | netconsole=set stdin $stdin,nc; set stdout $stdout,nc; set stderr $stderr,nc; | ||
- | netmask=255.255.255.0 | ||
- | stderr=serial, | ||
- | stdin=serial, | ||
- | stdout=serial, | ||
- | usbload=us | ||
- | Environment size: 604/4092 bytes | ||
- | |||
- | === Configure U-Boot to suit your own needs === | ||
- | |||
- | * Use GPIO button. | ||
- | |||
- | ===== Some usage examples ===== | ||
- | |||
- | ==== Save environment on a SPI flash ==== | ||
- | |||
- | Marvell>> | ||
- | Marvell>> | ||
- | Saving Environment to SPI Flash... | ||
- | SF: Detected MX25L4005A with page size 256, total 512 KiB | ||
- | Erasing SPI flash...Writing to SPI flash...done | ||
- | |||
- | ==== USB boot ==== | ||
- | |||
- | Marvell>> | ||
- | Marvell>> | ||
- | Device 0: Vendor: UFD Rev: 7.77 Prod: | ||
- | Type: Hard Disk | ||
- | Capacity: 125.0 MB = 0.1 GB (256000 x 512) | ||
- | Marvell>> | ||
- | boot/ | ||
- | | ||
- | 0 file(s), 1 dir(s) | ||
- | | ||
- | Marvell>> | ||
- | ./ | ||
- | ../ | ||
- | 4902372 | ||
- | | ||
- | 1 file(s), 2 dir(s) | ||
- | | ||
- | Marvell>> | ||
- | reading / | ||
- | | ||
- | 4902372 bytes read | ||
- | Marvell>> | ||
- | Marvell>> | ||
- | ## Booting kernel from Legacy Image at 00800000 ... | ||
- | Image Name: | ||
- | Image Type: ARM Linux Kernel Image (uncompressed) | ||
- | Data Size: 4902308 Bytes = 4.7 MiB | ||
- | Load Address: 00008000 | ||
- | Entry Point: | ||
- | | ||
- | | ||
- | OK | ||
- | | ||
- | Starting kernel ... | ||
- | |||
- | ==== Disk boot ==== | ||
- | |||
- | SoC: | ||
- | DRAM: 256 MiB | ||
- | SF: Detected MX25L4005A with page size 256, total 512 KiB | ||
- | *** Warning - bad CRC, using default environment | ||
- | | ||
- | In: serial | ||
- | Out: | ||
- | Err: | ||
- | Net: | ||
- | 88E1116 Initialized on egiga0 | ||
- | Marvell>> | ||
- | | ||
- | Reset IDE: Bus 0: ........OK | ||
- | Device 0: Model: SAMSUNG HD103SI | ||
- | Type: Hard Disk | ||
- | Supports 48-bit addressing | ||
- | Capacity: 953869.7 MB = 931.5 GB (1953525168 x 512) | ||
- | | ||
- | Marvell>> | ||
- | | ||
- | Partition Map for IDE device 0 -- | ||
- | | ||
- | Partition | ||
- | 1 | ||
- | 2 195334335 | ||
- | Marvell>> | ||
- | Failed to mount ext2 filesystem... | ||
- | < | ||
- | < | ||
- | | ||
- | | ||
- | Marvell>> | ||
- | Loading file "/ | ||
- | 4507632 bytes read | ||
- | Marvell>> | ||
- | ## Booting kernel from Legacy Image at 00800000 ... | ||
- | Image Name: | ||
- | Image Type: ARM Linux Kernel Image (uncompressed) | ||
- | Data Size: 4507568 Bytes = 4.3 MiB | ||
- | Load Address: 00008000 | ||
- | Entry Point: | ||
- | | ||
- | | ||
- | OK | ||
- | | ||
- | Starting kernel ... | ||
- | |||
- | ==== Update a mainline U-Boot version ==== | ||
- | |||
- | ns2> setenv ipaddr 192.168.0.17; | ||
- | ns2> tftpboot 0x800000 u-boot-netspace_v2.kwb | ||
- | Using egiga0 device | ||
- | TFTP from server 192.168.0.13; | ||
- | Filename ' | ||
- | Load address: 0x800000 | ||
- | Loading: ########################################## | ||
- | done | ||
- | Bytes transferred = 214220 (344cc hex) | ||
- | ns2> fl probe 0:0 | ||
- | SF: Detected MX25L4005A with page size 256, total 512 KiB | ||
- | 512 KiB MX25L4005A at 0:0 is now current device | ||
- | ns2> sf erase 0 0x40000 | ||
- | Usage: sf erase offset len | ||
- | ns2> sf erase 0 0x40000 | ||
- | ns2> sf write 0x800000 0 0x40000 | ||
- | ns2> reset | ||
- | resetting ... | ||
- | | ||
- | | ||
- | U-Boot 2010.12-00216-g5bbbf69 (Jan 24 2011 - 21:38:00) LaCie Network Space v2 | ||
- | | ||
- | SoC: | ||
- | DRAM: 256 MiB | ||
- | SF: Detected MX25L4005A with page size 256, total 512 KiB | ||
- | *** Warning - bad CRC, using default environment | ||
- | | ||
- | In: serial | ||
- | Out: | ||
- | Err: | ||
- | Net: | ||
- | 88E1116 Initialized on egiga0 | ||
- | Hit any key to stop autoboot: | ||
- | ns2> | ||
- | |||
- | ===== Links ===== | ||
- | |||
- | * [[http:// |