====== U-BOOT Monitor ======
  * See also [[http://dns323.kood.org/hardware:serial|serial connections]].



===== Monitor Mode =====
  * Type the two keys **SPACE** and **1** before the monitor 3 second timeout.

===== Enabled Commands =====

The standard U-Boot on my B1 hardware has the following commands enabled:

  Marvell>> ?
  ?       - alias for 'help'
  bootm   - boot application image from memory
  cp      - memory copy
  echo    - echo args to console
  erase   - erase FLASH memory
  loadb   - load binary file over serial line (kermit mode)
  md      - memory display
  printenv- print environment variables
  run     - run commands in an environment variable
  setenv  - set environment variables
  Marvell>> 

It is pretty limited, but is enough to recover a failed firmware installation.

There is mention made of additional commands which may be enabled through setting the environment variable "enaMonExt" to "yes" ("setenv enaMonExt yes" at the U-Boot prompt). Examination of the Marvell sources confirm this variable name, and what it is supposed to do.

Unfortunately, it simply results in the following output for any "advanced" commands:

  Marvell>> tftpfs
  Unknown command 'FSrun' - try 'help'
  Marvell>> blah
  Unknown command 'FSrun' - try 'help'
  Marvell>> 

As you can see, the command is being translated to "FSrun", which indicates that the "enaMonExt" code path is being followed, but unfortunately, the version of U-Boot that I have was compiled without support for the "FSrun" command, which means that this has no meaningful effect on this hardware.

===== Exploring U-Boot =====

The version of U-Boot provided by DLink (on the B1 hardware) is EXTREMELY limited. Pretty much the only way to do anything in the bootloader is to chainload an additional program, because not even the "go" command is supported.

One way to achieve this is to build a new version of U-Boot, wrap it in a suitable header using "mkimage", and then booting the new U-Boot.

Until recently, there was no support for the Orion architecture in U-Boot trunk. That changed with the addition of support for the LaCie edminiv2, which is also based on the same SoC.

While the basic SoC is the same, the flash part is different. Once I have managed to determine the correct configuration to allow the flash chip to be recognized by U-Boot, I will contribute a patch to the U-Boot maintainers to enable that support.

Here are some basic steps that can be followed to build your own U-Boot loader. The build platform was Ubuntu 10.04, on i386.

First, obtain a suitable cross compiler. The easiest way to do this is to get them from the Emdebian project.

Add the Emdebian repo to your /etc/apt/sources.list:

  deb http://www.emdebian.org/debian/ lenny main

Then update the repositories:

  sudo apt-get update
  sudo apt-get install gcc-4.3-arm-linux-gnueabi
  sudo apt-get install binutils-arm-linux-gnueabi
  sudo apt-get install uboot-mkimage

Tell U-Boot which compiler you are using:

  export CROSS_COMPILE=arm-linux-gnueabi-

Not knowing whether this image would work on more than just the B1 hardware, I chose to name it more specifically than less.

  make clean mrproper dns323_b1_config
  make
  mkimage -A arm -O u-boot -T kernel -C none -a 0x8000 -e 0x8000 -n "UBoot dns323" -d u-boot.bin uImage.bin

The dns323_b1 board config specifically omits the low level initialisation code so that it can be chain loaded from an existing U-Boot loader. The image resulting from this process CANNOT be used to boot from poweroff!

In order to execute this new boot loader, it has to be uploaded to memory, using kermit. It goes without saying (I hope) that this requires a console cable already connected.

Here is my kermit connect script:

  #!/usr/bin/kermit
  echo connecting /dev/ttyUSB0 .....
  set line /dev/ttyUSB0
  set speed 115200
  set serial 8n1
  set carrier-watch off
  set flow-control none
  set handshake none
  set prefixing all
  set streaming off
  set parity none
  connect 

Once you are connected to the console, and have interrupted the boot process as described above (Press space, 1), you can then download this new boot loader into RAM:

  loadb

Then press Ctrl-\ (Control-Backslash), followed by "c" to return to a Kermit prompt. Then:

  send /path/to/uImage.bin

The "send" command takes a few seconds to actually start, but then it should show the progress of the upload. Once it is finished, type "c<Enter>" to return to the U-Boot console.

Now we can execute the new image:

  bootm 0x100000

The address 0x100000 is the default address used by "loadb". If your "loadb" uses a different address, you should update the "bootm" command above.

Now the new image should execute, and return you to a boot prompt, with a fully featured U-Boot loader ready to obey your commands, without having to run the risk of flashing something that may not boot, and having to recover using JTAG.

Current U-Boot now includes network support for Orion5x chips, and can easily be configured in a dns323 board config to enable DHCP, TFTP, etc. Work is under way to support booting from SATA as well as USB on the LaCie ED Miniv2, which is a very similar device to the DNS323.

Flash support is still lacking. Anyone who knows how to properly address the Spansion flash chip as used in the DNS323, and who would like to get this working in U-Boot is invited to post to the U-Boot list.