Bare-metal Rust on the Xilinx Zynq ZC706 devkit
Go to file
2020-03-31 18:57:01 +02:00
.cargo update rust + smoltcp 2019-11-11 00:28:46 +01:00
experiments experiments: setup IoPll to 1 GHz to fix eth 2020-03-31 18:47:36 +02:00
libasync libasync: wrap_waker() 2020-03-31 18:57:01 +02:00
libboard_zynq libboard_zynq: wrap eth Buffer for alignment 2020-03-29 00:08:43 +01:00
libcortex_a9 libcortex_a9: set DDR pages non-bufferable to fix eth dma 2020-03-31 01:09:28 +02:00
libregister regs: add more #[inline] annotations 2020-02-03 00:50:13 +01:00
libsupport_zynq move smoltcp dependency to libboard_zynq only 2020-03-25 22:23:30 +01:00
openocd add support for cora z7 in tmux script 2020-01-24 07:51:29 +08:00
.gitignore remove zc706.elf from gitignore 2020-01-16 02:13:11 +08:00
armv7-none-eabihf.json define custom target, use with cargo-xbuild 2019-08-06 22:03:04 +02:00
build.rs PoC: boot, uart output in qemu 2019-05-05 14:56:23 +02:00
build.sh improved the development process 2020-01-15 05:22:35 +08:00
Cargo.lock libasync: start smoltcp support 2020-03-31 01:16:58 +02:00
Cargo.toml libasync: adapt from async-on-embedded/async-cortex-m 2020-03-26 01:35:05 +01:00
channel-rust-nightly.toml update rust-nightly + linked_list_allocator 2020-03-25 21:47:51 +01:00
default.nix libasync: adapt from async-on-embedded/async-cortex-m 2020-03-26 01:35:05 +01:00
link.x link.x: simplify while used with jtag only 2020-02-02 23:37:18 +01:00
qemu.gdb PoC: boot, uart output in qemu 2019-05-05 14:56:23 +02:00
README.md default.nix: fix 2020-01-26 01:45:49 +01:00
runner.sh PoC: boot, uart output in qemu 2019-05-05 14:56:23 +02:00
shell.nix default.nix: build zc706 2019-09-26 17:54:37 +02:00
tmux.sh add support for cora z7 in tmux script 2020-01-24 07:51:29 +08:00

Build

nix-shell --command "cargo xbuild --release"

Currently the ELF output is placed at target/armv7-none-eabihf/release/experiments

Debug

Using the Xilinx toolchain

Tested with the ZC706 board.

Run the Xilinx Microprocessor Debugger:

/opt/Xilinx/14.7/ISE_DS/EDK/bin/lin64/xmd

Connect to target (given it is connected and you have permissions):

connect arm hw

Leave xmd running.

Start the Xilinx version of the GNU debugger with your latest build:

/opt/Xilinx/14.7/ISE_DS/EDK/gnu/arm/lin/bin/arm-xilinx-linux-gnueabi-gdb zc706

Connect the debugger to xmd over TCP on localhost:

target remote :1234

Proceed using gdb with load, c

Using OpenOCD

Running on the ZC706

nix-shell --command "cargo xbuild --release"
cd openocd
openocd -f zc706.cfg

Running on the Cora Z7-10

nix-shell --command "cd experiments && cargo xbuild --release --no-default-features --features=target_cora_z7_10"
cd openocd
openocd -f cora-z7-10.cfg

Loading a bitstream into volatile memory

  openocd -f zc706.cfg -c "pld load 0 blinker_migen.bit; exit"

Development Process

Clone this repo onto your development/build machine and the raspberry pi that controls the Xilinx 7000 board

On the dev machine, the below script builds zc706 and secure copies it to the target pi (in your pi $HOME directory)

cd ~/zc706
./build.sh $your_user/ssh_id

On the pi, we need an information rich environment that includes a relatively reliable gdb experience (that includes ctrl-p and ctrl-n command history that persists across cgdb executions), run:

ssh pi4
cd zc706
./tmux.sh

Time to run your code with:

zynq-connect
zynq-restart
c

or, for a more succinct experience, (identical to above)

dc
dr
c

After every build on your dev machine, simply run:

dr
c

Sometimes you might need to type load after dr.