From cea44fd4b9b30e5c329b6347442a39cb1cf695db Mon Sep 17 00:00:00 2001 From: Cyril Koenig Date: Fri, 1 Mar 2024 10:55:31 +0100 Subject: [PATCH] fpga: Configurable remote boot --- target/fpga/Makefile | 11 +++++------ target/fpga/bootrom/Makefile | 4 ++-- target/fpga/bootrom/mac_address.dtsi | 2 ++ target/fpga/bootrom/occamy.dts | 4 ++-- target/fpga/bootrom/remote_boot.dtsi | 0 target/fpga/bootrom/src/main.c | 2 +- target/fpga/occamy_vcu128_flash.tcl | 10 +++++----- target/fpga/occamy_vcu128_flashrun.tcl | 15 ++++++++------- target/fpga/occamy_vcu128_procs.tcl | 6 +++--- 9 files changed, 28 insertions(+), 26 deletions(-) create mode 100644 target/fpga/bootrom/mac_address.dtsi create mode 100644 target/fpga/bootrom/remote_boot.dtsi diff --git a/target/fpga/Makefile b/target/fpga/Makefile index 47733aa7a..b5addbb0f 100644 --- a/target/fpga/Makefile +++ b/target/fpga/Makefile @@ -7,12 +7,11 @@ MKFILE_PATH := $(abspath $(lastword $(MAKEFILE_LIST))) MKFILE_DIR := $(dir $(MKFILE_PATH)) ROOT := ${MKFILE_DIR}../../../.. -CVA6_SDK ?= ${ROOT}/../cva6-sdk +CVA6_SDK ?= DEBUG ?= 0 EXT_JTAG ?= 0 -VCU ?= 01 -FPGA_ID := -HW_SERVER := +FPGA_PATH := $(XILINX_FPGA_PATH) +HW_SERVER := $(XILINX_HOST):$(XILINX_PORT) BENDER ?= bender VIVADO ?= vitis-2020.2 vivado # Do not proceed with implem (CI) @@ -54,12 +53,12 @@ program: ${VIVADO} -mode batch -source occamy_vcu128_program.tcl -tclargs ${VCU} flash: ${FILE} - ${VIVADO} -mode batch -source occamy_vcu128_flash.tcl -tclargs ${HW_SERVER} ${FPGA_ID} flash.mcs ${OFFSET} ${FILE} + ${VIVADO} -mode batch -source occamy_vcu128_flash.tcl -tclargs ${HW_SERVER} ${FPGA_PATH} flash.mcs ${OFFSET} ${FILE} rm flash.mcs # Flash only uboot (made for TFTP bootmode), overwrite the bootrom, and reset the board flashrun: ${UBOOT_ITB} - ${VIVADO} -mode batch -source occamy_vcu128_flashrun.tcl -tclargs ${HW_SERVER} ${FPGA_ID} flash.mcs 6000000 ${UBOOT_ITB} + ${VIVADO} -mode batch -source occamy_vcu128_flashrun.tcl -tclargs ${HW_SERVER} ${FPGA_PATH} flash.mcs 6000000 ${UBOOT_ITB} rm flash.mcs flash-u-boot: diff --git a/target/fpga/bootrom/Makefile b/target/fpga/bootrom/Makefile index d156130cb..ff8cbe736 100644 --- a/target/fpga/bootrom/Makefile +++ b/target/fpga/bootrom/Makefile @@ -38,8 +38,8 @@ all: bootrom-spl.coe bootrom.tcl bootrom-spl.tcl $(CC) $(CFLAGS) -DGIT_SHA=\"$(GIT_SHA)\" $(INCLUDES) -c $< -o $@ @echo "CC <= $<" -%.dtb: %.dts - dtc -I dts $< -O dtb -o $@ +%.dtb: %.dts $(wildcard *.dtsi) + dtc -@ -I dts $< -O dtb -o $@ bootrom.elf bootrom.dump bootrom.bin: bootrom.S $(OBJS_C) bootrom.ld occamy.dtb $(CC) $(CFLAGS) $(INCLUDES) -Tbootrom.ld $< $(OBJS_C) -o bootrom.elf diff --git a/target/fpga/bootrom/mac_address.dtsi b/target/fpga/bootrom/mac_address.dtsi new file mode 100644 index 000000000..8ad365a59 --- /dev/null +++ b/target/fpga/bootrom/mac_address.dtsi @@ -0,0 +1,2 @@ +local-mac-address = [ 00 00 00 00 00 00 ]; +mac-address = [ 00 00 00 00 00 00 ]; diff --git a/target/fpga/bootrom/occamy.dts b/target/fpga/bootrom/occamy.dts index dcd2d3954..0e8e785a2 100644 --- a/target/fpga/bootrom/occamy.dts +++ b/target/fpga/bootrom/occamy.dts @@ -191,8 +191,8 @@ clock-names = "s_axi_lite_clk", "axis_clk"; // interrupt and mac_irq interrupts-extended = <&PLIC0 1 &PLIC0 6>; - local-mac-address = [ 00 0A 35 07 D5 DD ]; // hero-vcu128-03 - mac-address = [ 00 0A 35 07 D5 DD ]; // hero-vcu128-03 + /include/ "mac_address.dtsi" + /include/ "remote_boot.dtsi" device_type = "network"; axistream-connected = <ð_dma0>; axistream-control-connected = <ð_dma0>; diff --git a/target/fpga/bootrom/remote_boot.dtsi b/target/fpga/bootrom/remote_boot.dtsi new file mode 100644 index 000000000..e69de29bb diff --git a/target/fpga/bootrom/src/main.c b/target/fpga/bootrom/src/main.c index 92da79812..987d07035 100644 --- a/target/fpga/bootrom/src/main.c +++ b/target/fpga/bootrom/src/main.c @@ -79,7 +79,7 @@ int main() { // Copy the DBT at (SPM+4) print_uart("\r\nCopying DTB at "); - print_uart_addr(SPL_DEST + 1); + print_uart_addr(SPL_DEST + 4); for (int i = 0; i < totalsize; i++) *(uint8_t *)(SPL_DEST + 4 + i) = *(((uint8_t *)__dtb_start) + i); diff --git a/target/fpga/occamy_vcu128_flash.tcl b/target/fpga/occamy_vcu128_flash.tcl index 22c3e5964..c3efb6fab 100644 --- a/target/fpga/occamy_vcu128_flash.tcl +++ b/target/fpga/occamy_vcu128_flash.tcl @@ -8,17 +8,17 @@ # Programs the SPI Flash of the VCU128 board with with two partitions # # HW_SERVER host:port URL to the server where the FPGA board is connected to -# FPGA_ID Serial of the FPGA to target +# FPGA_PATH Serial of the FPGA to target # MCS Output flash configuration file # OFFSET0 Address offset of partition 0 # FILE0 File to program to partition 0 # Parse arguments if {$argc < 5} { - error "usage: occamy_vcu_138_flash.tcl HW_SERVER FPGA_ID MCS OFFSET0 FILE0" + error "usage: occamy_vcu_138_flash.tcl HW_SERVER FPGA_PATH MCS OFFSET0 FILE0" } set HW_SERVER [lindex $argv 0] -set FPGA_ID [lindex $argv 1] +set FPGA_PATH [lindex $argv 1] set MCS [lindex $argv 2] set OFFSET0 [lindex $argv 3] set FILE0 [lindex $argv 4] @@ -38,8 +38,8 @@ write_cfgmem -force -format mcs -size 256 -interface SPIx4 \ # Open and connect HW manager open_hw_manager connect_hw_server -url ${HW_SERVER} -allow_non_jtag -current_hw_target [get_hw_targets */xilinx_tcf/Xilinx/${FPGA_ID}] -set_property PARAM.FREQUENCY 15000000 [get_hw_targets */xilinx_tcf/Xilinx/${FPGA_ID}] +current_hw_target [get_hw_targets ${FPGA_PATH}] +set_property PARAM.FREQUENCY 15000000 [get_hw_targets ${FPGA_PATH}] open_hw_target current_hw_device [get_hw_devices xcvu37p_0] diff --git a/target/fpga/occamy_vcu128_flashrun.tcl b/target/fpga/occamy_vcu128_flashrun.tcl index 9f9d59508..c92c925e9 100644 --- a/target/fpga/occamy_vcu128_flashrun.tcl +++ b/target/fpga/occamy_vcu128_flashrun.tcl @@ -9,7 +9,7 @@ # Afterwards programs the real bitstream and runs the bootrom # # HW_SERVER host:port URL to the server where the FPGA board is connected to -# FPGA_ID Serial of the FPGA to target +# FPGA_PATH Serial of the FPGA to target # MCS Output flash configuration file # OFFSET0 Address offset of partition 0 # FILE0 File to program to partition 0 @@ -18,10 +18,10 @@ source occamy_vcu128_procs.tcl # Parse arguments if {$argc < 5} { - error "usage: occamy_vcu_138_flash.tcl HW_SERVER FPGA_ID MCS OFFSET0 FILE0" + error "usage: occamy_vcu_138_flash.tcl HW_SERVER FPGA_PATH MCS OFFSET0 FILE0" } set HW_SERVER [lindex $argv 0] -set FPGA_ID [lindex $argv 1] +set FPGA_PATH [lindex $argv 1] set MCS [lindex $argv 2] set OFFSET0 [lindex $argv 3] set FILE0 [lindex $argv 4] @@ -37,8 +37,9 @@ write_cfgmem -force -format mcs -size 256 -interface SPIx4 \ # Open and connect HW manager open_hw_manager connect_hw_server -url ${HW_SERVER} -allow_non_jtag -current_hw_target [get_hw_targets */xilinx_tcf/Xilinx/${FPGA_ID}] -set_property PARAM.FREQUENCY 15000000 [get_hw_targets */xilinx_tcf/Xilinx/${FPGA_ID}] + +current_hw_target [get_hw_targets *${FPGA_PATH}] +set_property PARAM.FREQUENCY 15000000 [get_hw_targets *${FPGA_PATH}] open_hw_target current_hw_device [get_hw_devices xcvu37p_0] @@ -66,11 +67,11 @@ program_hw_cfgmem -hw_cfgmem $hw_cfgmem # Program BIT global occ_hw_server -global occ_target_serial +global occ_target_path global occ_hw_device global occ_bit_stem set occ_hw_server $HW_SERVER -set occ_target_serial $FPGA_ID +set occ_target_path $FPGA_PATH set occ_hw_device xcvu37p_0 set occ_bit_stem occamy_vcu128/occamy_vcu128.runs/impl_1/occamy_vcu128_wrapper diff --git a/target/fpga/occamy_vcu128_procs.tcl b/target/fpga/occamy_vcu128_procs.tcl index 6e2054c39..12c9ede1a 100644 --- a/target/fpga/occamy_vcu128_procs.tcl +++ b/target/fpga/occamy_vcu128_procs.tcl @@ -37,12 +37,12 @@ proc target_03 {} { proc occ_connect { } { global occ_hw_server - global occ_target_serial + global occ_target_path global occ_hw_device open_hw_manager connect_hw_server -url ${occ_hw_server} -allow_non_jtag - current_hw_target [get_hw_targets */xilinx_tcf/Xilinx/${occ_target_serial}] - set_property PARAM.FREQUENCY 15000000 [get_hw_targets */xilinx_tcf/Xilinx/${occ_target_serial}] + current_hw_target [get_hw_targets ${occ_target_path}] + set_property PARAM.FREQUENCY 15000000 [get_hw_targets ${occ_target_path}] open_hw_target current_hw_device [get_hw_devices ${occ_hw_device}] refresh_hw_device -update_hw_probes false [lindex [get_hw_devices ${occ_hw_device}] 0]