146 lines
6.4 KiB
Plaintext
146 lines
6.4 KiB
Plaintext
|
================================================================================
|
||
|
Useful notes on bulding and using of U-Boot on
|
||
|
ARC IoT Development Kit (AKA IoTDK)
|
||
|
================================================================================
|
||
|
|
||
|
BOARD OVERVIEW
|
||
|
|
||
|
The DesignWare ARC IoT Development Kit is a versatile platform that includes
|
||
|
the necessary hardware and software to accelerate software development and
|
||
|
debugging of sensor fusion, voice recognition and face detection designs.
|
||
|
|
||
|
The ARC IoT Development Kit includes a silicon implementation of the
|
||
|
ARC Data Fusion IP Subsystem running at 144 MHz on SMIC's
|
||
|
55-nm ultra-low power process, and a rich set of peripherals commonly used
|
||
|
in IoT designs such as USB, UART, SPI, I2C, PWM, SDIO and ADCs.
|
||
|
|
||
|
The board is shipped with pre-installed U-Boot in non-volatile memory
|
||
|
(eFlash) so on power-on user sees U-Boot start header and command line
|
||
|
prompt which might be used for U-Boot environment fine-tuning, manual
|
||
|
loading and execution of user application binaries etc.
|
||
|
|
||
|
The board has the following features useful for U-Boot:
|
||
|
* On-board 2-channel FTDI TTL-to-USB converter
|
||
|
- The first channel is used for serial debug port (which makes it possible
|
||
|
to use a serial connection on pretty much any host machine be it
|
||
|
Windows, Linux or Mac).
|
||
|
On Linux machine typucally FTDI serial port would be /dev/ttyUSB0.
|
||
|
There's no HW flow-control and baud-rate is 115200.
|
||
|
|
||
|
- The second channel is used for built-in Digilent USB JTAG probe.
|
||
|
That means no extra hardware is required to access ARC core from a
|
||
|
debugger on development host. Both proprietary MetaWare debugger and
|
||
|
open source OpenOCD + GDB client are supported.
|
||
|
|
||
|
- Also with help of this FTDI chip it is possible to reset entire
|
||
|
board with help of a special `rff-ftdi-reset` utility, see:
|
||
|
https://github.com/foss-for-synopsys-dwc-arc-processors/rff-ftdi-reset
|
||
|
|
||
|
* Micro SD-card slot
|
||
|
- U-Boot expects to see the very first partition on the card formatted as
|
||
|
FAT file-system and uses it for keeping its environment in `uboot.env`
|
||
|
file. Note uboot.env is not just a text file but it is auto-generated
|
||
|
file created by U-Boot on invocation of `saveenv` command.
|
||
|
It contains a checksum which makes this saved environment invalid in
|
||
|
case of maual modification.
|
||
|
|
||
|
- There might be more useful files on that first FAT partition like
|
||
|
user applications, data files etc.
|
||
|
|
||
|
* USB OTG connector
|
||
|
- U-Boot may access USB mass-storage devices attached to this connector.
|
||
|
Note only FAT file-system is supported. It might be used for storing
|
||
|
user application binaries as well as micro SD-card mentioned above.
|
||
|
|
||
|
* The following memories are avaialble on the board:
|
||
|
- eFlash: 256 KiB @ 0x0000_0000
|
||
|
A non-volatile memory from which ARC core may execute code directly.
|
||
|
Still is is not direcly writable, thus this is not an ordinary RAM.
|
||
|
|
||
|
- ICCM: 256 KiB @ 0x2000_0000
|
||
|
Instruction Closely Coupled Memory - fast on-chip memory primary used
|
||
|
for code being executed, still data could be placed in this memory too.
|
||
|
In that sense it's just a general purpose RAM.
|
||
|
|
||
|
- SRAM: 128 KiB @ 0x3000_0000
|
||
|
On-chip SRAM. From user perspective is the same as ICCM above.
|
||
|
|
||
|
- DCCM: 128 KiB @ 0x8000_0000
|
||
|
Data Closely Coupled Memory is similar to ICCM with a major difference -
|
||
|
ARC core cannot execute code from DCCM. So this is very special RAM
|
||
|
only suitable for data.
|
||
|
|
||
|
BUILDING U-BOOT
|
||
|
|
||
|
1. Configure U-Boot:
|
||
|
------------------------->8----------------------
|
||
|
make iot_devkit_defconfig
|
||
|
------------------------->8----------------------
|
||
|
|
||
|
2. To build Elf file (for example to be used with host debugger via JTAG
|
||
|
connection to the target board):
|
||
|
------------------------->8----------------------
|
||
|
make mdbtrick
|
||
|
------------------------->8----------------------
|
||
|
|
||
|
This will produce `u-boot` Elf file.
|
||
|
|
||
|
3. To build binary image to be put in "ROM":
|
||
|
------------------------->8----------------------
|
||
|
make u-boot.bin
|
||
|
------------------------->8----------------------
|
||
|
|
||
|
|
||
|
EXECUTING U-BOOT
|
||
|
|
||
|
1. The IoTDK board is supposed to auto-start U-Boot image stored in eFlash on
|
||
|
power-on. Note it's possible to update that image - follow instructions in
|
||
|
user's manual.
|
||
|
|
||
|
2. Though it is possible to load and start U-Boot as a simple Elf file
|
||
|
via JTAG right in ICCM. For that it's required to re-configure U-Boot
|
||
|
so it gets linked to ICCM address 0x2000_0000 (remember eFlash is not
|
||
|
direcly writable).
|
||
|
Run U-Boot's configuration utility with "make menuconfig", go to
|
||
|
"Boot images" and change "Text Base" from default 0x00000000 to
|
||
|
0x20000000. Exit & save new configuration. Now run "make mdbtrick" to
|
||
|
build new Elf.
|
||
|
|
||
|
2.1. In case of proprietary MetaWare debugger run:
|
||
|
------------------------->8----------------------
|
||
|
mdb -digilent u-boot
|
||
|
------------------------->8----------------------
|
||
|
|
||
|
USING U-BOOT
|
||
|
|
||
|
Note due to limited memory size it's supposed that user will run binary
|
||
|
images of their applications instead of loading Elf files.
|
||
|
|
||
|
1. To load and start application binary from micro SD-card execute
|
||
|
the following commands in U-Boot's shell:
|
||
|
------------------------->8----------------------
|
||
|
fatload mmc 0 0x20000000 yourapp.bin
|
||
|
go 0x20000000
|
||
|
------------------------->8----------------------
|
||
|
|
||
|
2. To load and start application binary from USB mass-storage device execute
|
||
|
the following commands in U-Boot's shell:
|
||
|
------------------------->8----------------------
|
||
|
usb start
|
||
|
fatload usb 0x20000000 yourapp.bin
|
||
|
go 0x20000000
|
||
|
------------------------->8----------------------
|
||
|
|
||
|
3. To have a sequence of commands executed on U-Boot start put those
|
||
|
commands in "bootcmd" with semicolon between them.
|
||
|
For example to get (1) done automatically:
|
||
|
------------------------->8----------------------
|
||
|
setenv bootcmd fatload mmc 0 0x20000000 yourapp.bin\; go 0x20000000
|
||
|
saveenv
|
||
|
------------------------->8----------------------
|
||
|
|
||
|
4. To reboot the board just run:
|
||
|
------------------------->8----------------------
|
||
|
reset
|
||
|
------------------------->8----------------------
|