Jump to content

Hempl/emBLOD

From Wikibooks, open books for an open world

Overview

[edit | edit source]

Normally, the boot sequence is:

  • the USB DFU bootloader at 0x8000000-80001FFF (8KB), which checks if the user button is pressed and, if it isn't, runs:
  • the Hempl (miniPicoLisp) interpreter at 0x80002000

emBLOD is an embedded boot loader that replaces eLua at 0x80002000 and loads a modified version of the eLua interpreter code from a file on a FAT-formatted SD card into the start of the 32MB SDRAM then executes it there. It is fast to start up (a fraction of a second) and gets round the 120KB code size limit of the Mizar32 model C.

The downside is that when loaded into SDRAM instead of Flash, the Hempl interpreter runs at one sixth of the speed. However, if you need peripheral support on a Mizar32 model C, this is the only way to do it.

Compiling emBLOD from source

[edit | edit source]

emBLOD is an open source code project hosted at http://github.com/cmp1084/emBLOD

To fetch and build the source on Ubuntu you will need to install:

apt-get install git dfu-programmer 

and the avr32 GCC cross-compiler, for which instructions are at the start of the compiling Hempl page.

The boot loader can be built from source as follows:

git clone https://github.com/cmp1084/emBLOD
cd emBLOD
make

which creates two versions of the same object file: emblod.elf and bin/emblod.bin. However, dfu-programmer requires a .hex file, so convert it:

avr32-objcopy -O ihex emblod.elf emblod.hex

then connect the Mizar32 to your PC over USB, reset or power-on the board while holding SW2 depressed and issue these commands on the PC:

dfu-programmer at32uc3a0128 erase
dfu-programmer at32uc3a0128 flash emblod.hex
dfu-programmer at32uc3a0128 start

If you have the serial port connected at 115200-8-N-1, you will see messages issued by emBLOD.

Compiling Hempl for emBLOD

[edit | edit source]

You should already be familiar with compiling Hempl.

Use Hempl, and add

bootloader=emblod

to the scons compilation command. This will create an ELF file, which you should convert to a BIN file using

avr32-objcopy -O binary *.elf autorun.bin

and copy autorun.bin to the root of a FAT-formatted micro SD card for the Mizar32.