Name
Setup — Preparing the Raspberry Pi for eCos Development
Overview
In a typical development environment, the board boots from the SD/eMMC and runs the RedBoot ROM monitor from SDRAM. eCos applications are configured for RAM startup and then downloaded and run on the board via the debugger arm-eabi-gdb. Preparing the board therefore usually involves programming a suitable RedBoot image into an SD card.
Initial Installation
A Raspberry Pi boots initially to the GPU which then reads and executes a second-level GPU bootstrap image from the SD card. This then reads an ARM executable image from the card into SDRAM and executes it. For eCos development we want RedBoot to be the ARM image loaded from the SD card.
The SD card used to boot RedBoot is prepared in exactly the same way as a card is prepared to boot Raspian or any other operating system for the RPi. A complete disk image must be written to the card, typically from a host system running either Windows or Linux. You will need a 2GB, or larger, SD card for this purpose.
A prebuilt bootable SD card image is supplied as part of the
eCosPro release. This image is universal and will boot RedBoot
on all Raspberry Pi variants.
The eCosPro_RedBoot_RPi_2Mb.img
image is
located within your eCosPro installation in the
eCosPro/ecos-
directory. This RedBoot uses 2Mb/s as its default serial speed.
VERSION
/loaders/rpi
A few non-FTDI based USB to serial converters have been found to be
incapable of reliably handling the high-speed 2Mb/s default baud
rate used by the standard RedBoot image. For these systems an
alternative eCosPro_RedBoot_RPi_115k.img
image
has been provided in the same location. This defaults to a baud rate
of 115200, but is otherwise identical. This may also be useful if you
encounter any communications issues with slow host machines, or
with specific operations such as x/ymodem transfers. Alternatively you
could dynamically change the communications speed used by RedBoot with
its baudrate command.
Installation from Windows to an SD card
The following steps describe how to create a bootable RedBoot SD card for your Raspberry Pi. The best Windows-based tool for this purpose is the freely available balenaEtcher SD card image burning utility (previously and often still referred to as Etcher). This is also the recommended utility for writing Raspian and other RPi Linux images.
Visit www.balena.io/etcher to download and install the balenaEtcher SD Burner utility.
- Insert the SD card to be programmed into the PC's card reader.
-
Start the balenaEtcher utility and click
Select image, then browse to and
select the RedBoot Raspberry Pi image from within the
loaders/rpi
directory. - Click Select drive and select your SD card drive. Note that balenaEtcher may have already pre-selected the SD drive. You can click on Change if this is not the correct drive.
- Click Flash! to write the image to the SD card. You'll see a progress bar that tells you how much is left to do. Once complete, the utility will automatically unmount the SD card so it's safe to immediately remove it from the computer.
Installation from Linux to an SD card
Installation on Linux should be done using the dd command.
- Locate a Linux PC with an SD card reader and insert the SD card to be programmed into the reader.
-
Identify the device name that Linux has assigned to
the SD card. This can be done either by monitoring the
system log, or by using lsblk before and after
inserting the card. In this example we will use
/dev/sd
as a placeholder.X
Execute the following command in a shell:
$ dd status=progress if=/path/to/eCosPro_RedBoot_RPi_2Mb.img of=/dev/sd
X
Depending on permissions and user group membership, it may be necessary to prefix this command with sudo or run it in a root shell.
- Execute the sync command. This may not be strictly necessary, but it will ensure that all data is safely written to the card.
- The card is now ready and may be removed.
Installation from Windows to Compute Module eMMC
Installation to the compute module eMMC requires the installation of a driver and a boot utility tool.
- Download and run the Windows Installer to install the drivers and boot tool.
- Follow the instructions on the Raspberry Pi website for installing the driver. Make sure the J4 jumper is in the EN position.
- Run the RPiBoot.exe tool. The compute module will then appear as a USB mass storage disk drive under Windows.
- You can now use the balenaEtcher tool to write the RedBoot image to the drive as described above for an SD card.
- Once complete, the USB cable can be detached. Power off the CMIO board and move J4 back to its original position. On re-applying power, RedBoot will start.
Installation from Linux to Compute Module eMMC
To program an image from Linux it is necessary to download and compile the rpiboot utility program.
- The utility program is in a github repository, so ensure that git is installed. The program also needs libusb-1, so ensure that this is also installed.
Clone the git repository into a convenient directory.
$ git clone --depth=1 https://github.com/raspberrypi/usbboot Cloning into 'usbboot'... remote: Counting objects: 21, done. remote: Compressing objects: 100% (19/19), done. remote: Total 21 (delta 1), reused 14 (delta 0), pack-reused 0 Unpacking objects: 100% (21/21), done. $
Build the tool:
$ cd usbboot $ make cc -Wall -Wextra -g -o rpiboot main.c -lusb-1.0 $
- Move J4 on the compute module IO board to the EN position. Connect a USB cable between the USB SLAVE port and the host and power up the board.
Run the rpiboot just built from the build directory:
$ sudo ./rpiboot Waiting for BCM2835/6/7 Sending bootcode.bin Successful read 4 bytes Waiting for BCM2835/6/7 Second stage boot server File read: start.elf Second stage boot server done $
-
The CM board will now be visible to Linux as a new USB
mass storage device. Identify the device name that
Linux has assigned to the SD card. This can be done
either by monitoring the system log, or by using lsblk
before and after inserting the card. In this example
we will use
/dev/sd
as a placeholder.x
Execute the following command in a shell:
$ dd status=progress if=/path/to/eCosPro_RedBoot_RPi_2Mb.img of=/dev/sd
x
Depending on permissions and user group membership, it may be necessary to prefix this command with sudo or run it in a root shell.
- Execute the sync command. This may not be strictly necessary, but it will ensure that all data is safely written to the eMMC.
- Remove power from the compute module, move J4 back to its original position and detach the USB cable from the USB SLAVE port.
- Restore power to the compute module and RedBoot should boot.
RedBoot Startup
Once the RedBoot image has been flashed, insert the SD card into your RPi board's SD socket. If the board has an Ethernet socket insert an Ethernet cable. Connect an RS232 TTL transceiver to the Raspberry Pi's UART pins. On the host run a terminal emulator and connect to the transceiver's serial port, setting it to 2Mb/s (2000000 baud), 8 data bits, no parity, one stop bit (8N1).
Note | |
---|---|
Suitable low cost USB RS232 TTL transceivers include the FTDI Raspberry Pi Cable: TTL-232R-RPI or FTDI LC234X module. The FTDI cable can be connected directly to the Raspberry Pi, whereas connecting the module will reqire set of additional jumper cables. These FTDI products are fully supported by drivers on both Windows and Linux hosts. Whatever transceiver is used, it will need connecting to the Raspberry Pi's GND, GPIO14 TXD (transceiver RXD) and GPIO15 RXD (transceiver TXD) pins on the GPIO header. For the 40 way expansion header on standard RPi's these are pins 6, 8 and 10 respectively. We do NOT recommend connecting any other signals that the transceiver might provide, in particular 3V3 or 5V lines. |
Note | |
---|---|
There are a wide range of freely available terminal emulation programs to choose from - we can recommend Minicom on Linux and PuTTY on Windows. |
When the above connections have been made, apply power to the board and similar output to the following should be seen on the terminal:
+USB LOG: HCD register DWC ports 1 USB LOG: hub 01 attach on port 1 USB LOG: hub attach 03 USB LOG: hub 03 attach on port 1 USB LOG: hub attach 04 USB LOG: hub 04 attach on port 1 USB LOG: device attach 05 [ff:00] [0424:7800] ... waiting for BOOTP information Ethernet eth0: MAC address b8:27:eb:30:d0:7b IP: 10.0.2.2/255.0.0.0, Gateway: 10.0.0.3 Default server: 0.0.0.0 DNS server IP: 10.0.0.5, DNS domain name: <null> Mount /dev/mmcsd0/1 on /boot type fatfs:sync=write RedBoot(tm) bootstrap and debug environment [ROM] eCosCentric certified release, version v4_2_0 - built 17:03:10, Jun 12 2018 Copyright (C) 2000-2009 Free Software Foundation, Inc. Copyright (C) 2003-2018 eCosCentric Limited The RedBoot bootloader is a component of the eCos real-time operating system. This is free software, covered by the eCosPro Non-Commercial Public License and eCos Public License. You are welcome to change it and/or distribute copies of it under certain conditions. Under the license terms, RedBoot's source code and full license terms must have been made available to you. Redboot comes with ABSOLUTELY NO WARRANTY. Platform: Raspberry Pi B3 (BCM2837 - Cortex-A53) RAM: 0x00000000-0x3e000000 [0x0004eeb0-0x3de00000 available] Arena: base 0x3de00000, size 0x200000, 95% free, maxfree 0x1eaf3c == Executing boot script in 1.000 seconds - enter ^C to abort RedBoot> fs exec /boot/redboot.txt RedBoot> jtag 22 23 24 25 26 27 PIN FUNC 22 ARM_TRST 23 ARM_RTCK 24 ARM_TDO 25 ARM_TCK 26 ARM_TDI 27 ARM_TMS RedBoot> fs exec RedBoot>
Before loading RedBoot, the GPU configures the board
according to the contents of the
config.txt
file in the boot
partition. eCosPro currently makes minimal use of the
settings in this file, the default
config.txt
for eCosPro just sets the
GPU reserved memory to its minimum of 16MiB. No other
configuration settings have been tested, so change them at
your peril. Full details of the file contents can be found
in the Raspberry
Pi Foundation documentation.
Note | |
---|---|
If a RPi board supports Ethernet and you do not connect an Ethernet cable, or the network does not provide a dhcp server, then you will experience a delay before the full RedBoot banner and prompt are displayed. |
Resizing the Second SD Partition
The standard eCosPro disk image is sized to fit into a 2GB SD card with two partitions. The first partition is located 4MB from the beginning of the SD card and contains RedBoot and other system files necessary to boot the Raspberry Pi. The second partition follows the first and contains an initially empty VFAT filesystem of 1.23GB in size. If you have a larger card, and wish to utilise all the available storage capacity from eCos, you will need to expand the second partition to incorporate the unused capacity. As an embedded system eCosPro does not have the ability to repartition the disk itself. This needs to be done from a host system running either Windows or Linux.
Resizing from Windows
In Windows you need to run the Windows Disk Management tool to remove the second partition and create the new partition sized as required:
- To start the tool you can click on the Start Menu and type "disk management", click on the "Create and format hard disk partitions control panel" entry that appears.
- Remove the second partition (1.23GB FAT32) by right clicking on second partition and selecting "Delete Volume...". Click "Yes" to confirm.
- Create a new volume of the required size (typically the remaining space on the SD) by right clicking on the "Unallocated" space and selecting "New Simple Volume...".
- In the New Simple Volume Wizard's initial dialog click "Next >" to move to the "Specify Volume Size" dialog, then choose the disk size required (default is the remaining space on the SD) and click "Next >" again.
- In the "Assign Drive Letter or Path" dialog choose the drive letter of your choice, typically the default provided and click "Next >".
- In the final "Format Partition" dialog, choose the file system type - this should be the default "FAT32", then select the allocation size - choose "Default" or 4096 and then enter the "Volume label" of your choice. Leaving the "Perform a quick format" checkbox ticked, click "Next >". Review the settings and then click "Finish".
Your SD card should now contain two partitions. The first is the original boot partition containing RedBoot (or your own application, named as kernel*.img) and the second is a new partition expanded to incorporate the remaining SD card capacity.
Resizing from Linux
There are a variety of Linux tools in different distributions for resizing a partition, many are GUI based and similar to the Windows tool. The following example uses just command line tools and should work on all Linux distributions.
- Depending on permissions, it may be best to perform the following actions as root. Either start a root shell, or prefix all commands with sudo.
-
Insert the SD card into the card reader and identify
the device name assigned to it. This can be done
either by monitoring the system log, or by using lsblk
before and after inserting the card. In this example
we will use
/dev/sd
as a placeholder.X
Run fdisk on the device and type
p
to print the partition table:# fdisk /dev/sd
X
Welcome to fdisk (util-linux 2.28). Changes will remain in memory only, until you decide to write them. Be careful before using the write command. Command (m for help): p Disk /dev/sdX
: 14.9 GiB, 15931539456 bytes, 31116288 sectors Units: sectors of 1 * 512 = 512 bytes Sector size (logical/physical): 512 bytes / 512 bytes I/O size (minimum/optimal): 512 bytes / 512 bytes Disklabel type: dos Disk identifier: 0xec05ec05 Device Boot Start End Sectors Size Id Type /dev/sdX
1 8192 137215 129024 63M c W95 FAT32 (LBA) /dev/sdX
2 137216 2715647 2578432 1.2G c W95 FAT32 (LBA) Command (m for help):Check that things like the disk identifier and the partition parameters match the above to ensure you have the right device.
Use the
d
command to delete partition 2:Command (m for help): d Partition number (1,2, default 2): 2 Partition 2 has been deleted. Command (m for help):
Ensuring you set the first sector to 137216, since there is 3MB of free space before the first partition which should NOT be used, use the
n
command to create a new partition. Check that the new partition fills the remaining card space with thep
command.Command (m for help): n Partition type p primary (1 primary, 0 extended, 3 free) e extended (container for logical partitions) Select (default p): p Partition number (2-4, default 2): 2 First sector (2048-31116287, default 2048): 137216 Last sector, +sectors or +size{K,M,G,T,P} (137216-31116287, default 31116287): Created a new partition 2 of type 'Linux' and of size 14.8 GiB. Command (m for help): p Disk /dev/sd
X
: 14.9 GiB, 15931539456 bytes, 31116288 sectors Units: sectors of 1 * 512 = 512 bytes Sector size (logical/physical): 512 bytes / 512 bytes I/O size (minimum/optimal): 512 bytes / 512 bytes Disklabel type: dos Disk identifier: 0xec05ec05 Device Boot Start End Sectors Size Id Type /dev/sdX
1 8192 137215 129024 63M c W95 FAT32 (LBA) /dev/sdX
2 137216 31116287 30979072 14.8G 83 Linux Command (m for help):Fdisk has set the new partition's type to
Linux
, use thet
command to change the type to FAT32:Command (m for help): t Partition number (1,2, default 2): 2 Partition type (type L to list all types): c Changed type of partition 'Linux' to 'W95 FAT32 (LBA)'. Command (m for help):
-
Finally use the
w
command to write the partition table back and exit fdisk. The new partition now needs to be formatted with a FAT32 filesystem. This can be done using the mkfs.fat command:
# mkfs.fat -v -F 32 /dev/sd
X
2 mkfs.fat 3.0.26 (2014-03-07) /dev/sdX
2 has 64 heads and 32 sectors per track, hidden sectors 0x21800; logical sector size is 512, using 0xf8 media descriptor, with 30979072 sectors; drive number 0x80; filesystem has 2 32-bit FATs and 16 sectors per cluster. FAT size is 15112 sectors, and provides 1934301 clusters. There are 32 reserved sectors. Volume ID is e2a0eca8, no volume label. #- Execute the sync command. This may not be strictly necessary, but it will ensure that all data is safely written to the card.
- The card is now ready and may be removed.
Installing user applications onto an SD card
If you wish to install a ROM startup application onto an SD to be automatically booted instead of RedBoot, then you can do this by replacing the appropriate kernel image file in the SD card boot partition.
First prepare an SD card as per the Initial Installation section above. The card should then be remounted and your application copied over, replacing the relevant kernel image file(s) within the boot partition. Applications are compiled and linked to ELF format, and need to be converted to binary before copying to the the SD card. This can be done as follows using objcopy:
$ arm-eabi-objcopy -O binary app.elf kernel.img
If you have built the application for the BCM2835 (Pi1/Pi0)
based boards, replace kernel.img
, and
for the BCM2836 (Pi2) or BCM2837 (Pi3) based boards, replace
kernel7.img
. Replacing the wrong file
may result in the board failing to boot.
For widest compatibility you can replace both
kernel.img
and kernel7.img
with suitably built versions of your application.
Rebuilding RedBoot
Typical users should never need to rebuild RedBoot. If you do intend to modify RedBoot then please note that rebuilding it is currently only supported from the Linux command line.
The following RedBoot configurations are supported:
Configuration | Description | Use | File |
---|---|---|---|
ROM_2Mb | RedBoot loaded from SD card to SDRAM, Standard version with default baud rate of 2Mb/s | redboot_ROM_2Mb.ecm | redboot_ROM_2Mb.bin |
ROM_115k | RedBoot loaded from SD card to SDRAM, alternative version with default baud rate of 115200 | redboot_ROM_115k.ecm | redboot_ROM_115k.bin |
JTAG | RedBoot loaded via a JTAG debugger, for RedBoot developers only | redboot_JTAG.ecm | redboot_JTAG.bin |
The JTAG configuration is only required if you wish to build a version of RedBoot to load and debug over JTAG, before ultimately creating a final ROM version to be booted from SD.
Note that the use of the term ROM for the initial RedBoot configuration is a historical accident. RedBoot actually runs from SDRAM after being loaded there from the SD card by the GPU bootstrap. The use of ROM for this configuration is intended to indicate that it initializes the microprocessor and board peripherals, as opposed to a RAM configuration which assumes that this has already been done.
The ROM_115k configuration is provided as an alternative to the ROM_2Mb configuration, for compatibility with low performance USB to serial converters. It simply lowers the default baud rate to 115200 and is otherwise identical.
The final stage of the RedBoot build process will create a bootable
RedBoot SD image. This is handled within the
eCosPro/ecos-
script. In order for the script to complete successfully, the user
must either have sudo privileges to mount and
cp, or the user must be able to mount
VERSION
/packages/hal/arm/cortexa/pi/current/host/buildimg.sh/tmp/sd_pi
on /tmp/sd
.
For the latter case, the following entry in
/etc/fstab
is advised:
/tmp/sd_pi /tmp/sd vfat user,noauto,rw,loop,offset=4194304 0 0
The steps needed to rebuild the ROM version of RedBoot are:
$ mkdir redboot_rpi2_rom
$ cd redboot_rpi2_rom
$ ecosconfig new raspberry_pi2 redboot
$ ecosconfig import $ECOS_REPOSITORY/hal/arm/cortexa/pi/VERSION
/misc/redboot_ROM_2Mb.ecm
$ ecosconfig resolve
$ ecosconfig tree
$ make
At the end of the build the install/bin
subdirectory should
contain the file sd_pi.img
. This file
is the SD card image and is suitable at this point for
booting Pi2 and Pi3 boards, including the CM3, since it only
contains a kernel7.img
file. To make it
also capable of booting a Pi1 or Pi0 board repeat the above
command sequence with the following changes:
$ mkdir redboot_rpi1b_rom
$ cd redboot_rpi1b_rom
$ ecosconfig new raspberry_pi1b redboot
$ ecosconfig import $ECOS_REPOSITORY/hal/arm/cortexa/pi/VERSION
/misc/redboot_ROM_2Mb.ecm
$ ecosconfig resolve
$ ecosconfig tree
$ make
At the end of this build the install/bin
subdirectory will
contain a new sd_pi.img
file. This
should be a copy of the previous image with the addition of
kernel.img
.
This image should then be written to an SD card as per the above
Linux hosted setup instructions. e.g:
sudo dd status=progress if=install/bin/sd_pi.img of=/dev/sdX
The SD created should now be able to boot all RPi variants.
To build a RedBoot that uses a different default UART baud
rate to the standard 2Mb/s, then edit the
ecos.ecc
file after each ecosconfig import
stage as described above. Set user_value for both
cdl_option CYGNUM_HAL_VIRTUAL_VECTOR_DEBUG_CHANNEL_BAUD
and cdl_option CYGNUM_HAL_VIRTUAL_VECTOR_CONSOLE_CHANNEL_BAUD
to your desired baud rate. For example:
cdl_option CYGNUM_HAL_VIRTUAL_VECTOR_DEBUG_CHANNEL_BAUD { # Flavor: data # No user value, uncomment the following line to provide one. user_value 115200 # value_source default # Default value: 2000000 # Legal values: 9600 19200 38400 57600 115200 230400 460800 500000 576000 921600 1000000 1152000 1500000 2000000 2500000 3000000 };
You will then need to use this baud rate when connecting to the new RedBoot via a terminal or gdb debug session. The highest attainable reliable baud rate can depend upon the specific model Raspberry Pi, transceiver and/or host PC/OS used. The default 2MB/s has been found to work reliably across the Pi family members, using FTDI transceivers, connected to either Linux or Windows hosts. Use of other transceivers may require you to reduce the baud rate.
2025-01-10 | eCosPro Non-Commercial Public License |