-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathflow_alveo.sh
executable file
·125 lines (96 loc) · 3.63 KB
/
flow_alveo.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
#!/bin/bash
##
## Args
##
if [ "$1" == "-h" ]; then
echo "Usage: $0 <bitstream_path_within_base> <driver_path_within_base> <qsfp_port>" >&2
exit 0
fi
if ! [ -x "$(command -v vivado)" ]; then
echo "Vivado does NOT exist in the system."
exit 1
fi
BASE_PATH=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
PROGRAM_FPGA=1
DRV_INSERT=1
BIT_PATH=$1
DRV_PATH=$2
if [ -z "$3" ]; then
QSFP_PORT=0
else
QSFP_PORT=$3
fi
##
## Server IDs (u55c)
##
echo "*** Enter server IDs:"
read -a SERVID
BOARDSN=(XFL1QOQ1ATTYA XFL1O5FZSJEIA XFL1QGKZZ0HVA XFL11JYUKD4IA XFL1EN2C02C0A XFL1NMVTYXR4A XFL1WI3AMW4IA XFL1ELZXN2EGA XFL1W5OWZCXXA XFL1H2WA3T53A)
for servid in ${SERVID[@]}; do
# hostlist+="alveo-u55c-$(printf "%02d" $servid).ethz.ch "
hostlist+="alveo-u55c-$(printf "%02d" $servid) "
done
##
## Program FPGA
##
alveo_program()
{
SERVERADDR=$1
SERVERPORT=$2
BOARDSN=$3
DEVICENAME=$4
BITPATH=$5
vivado -nolog -nojournal -mode batch -source ./program_alveo.tcl -tclargs $SERVERADDR $SERVERPORT $BOARDSN $DEVICENAME $BITPATH
}
declare -n qsfp_ip=FPGA_$3_IP_ADDRESS_HEX
declare -n qsfp_mac=FPGA_$3_MAC_ADDRESS
if [ $PROGRAM_FPGA -eq 1 ]; then
# activate servers (login with passwd to enable the nfs home mounting)
echo "*** Activating server ..."
echo " ** "
#parallel-ssh -H "$hostlist" -A -O PreferredAuthentications=password "echo Login success!"
parallel-ssh -H "$hostlist" "echo Login success!"
echo "*** Enabling Vivado hw_server ..."
echo " ** "
# this step will be timeout after 2 secs to avoid the shell blocking
parallel-ssh -H "$hostlist" -t 4 "source /tools/Xilinx/Vivado/2022.1/settings64.sh && hw_server &"
echo "*** Programming FPGA... (path: $BIT_PATH)"
echo " ** "
for servid in "${SERVID[@]}"; do
boardidx=$(expr $servid - 1)
alveo_program alveo-u55c-$(printf "%02d" $servid) 3121 ${BOARDSN[boardidx]} xcu280_u55c_0 $BASE_PATH/$BIT_PATH &
done
wait
echo "*** FPGA programmed"
echo " ** "
fi
Driver insertion
if [ $DRV_INSERT -eq 1 ]; then
#NOTE: put -x '-tt' (pseudo terminal) here for sudo command
echo "*** Removing the driver ..."
echo " ** "
parallel-ssh -H "$hostlist" -x '-tt' "sudo rmmod coyote_drv"
echo "*** Rescan PCIe ..."
echo " ** "
#parallel-ssh -H "$hostlist" -x '-tt' 'sudo /opt/sgrt/cli/program/pci_hot_plug "$(hostname -s)"'
# read -p "Hot-reset done. Press enter to load the driver or Ctrl-C to exit."
parallel-ssh -H "$hostlist" -x '-tt' 'upstream_port=$(/opt/sgrt/cli/get/get_fpga_device_param 1 upstream_port) && root_port=$(/opt/sgrt/cli/get/get_fpga_device_param 1 root_port) && LinkCtl=$(/opt/sgrt/cli/get/get_fpga_device_param 1 LinkCtl) && sudo /opt/sgrt/cli/program/pci_hot_plug 1 $upstream_port $root_port $LinkCtl'
# read -p "Hot-reset done. Press enter to load the driver or Ctrl-C to exit."
echo "*** Compiling the driver ..."
echo " ** "
parallel-ssh -H "$hostlist" "make -C $BASE_PATH/$DRV_PATH"
echo "*** Loading the driver ..."
echo " ** "
qsfp_ip="DEVICE_1_IP_ADDRESS_HEX_$3"
qsfp_mac="DEVICE_1_MAC_ADDRESS_$3"
parallel-ssh -H "$hostlist" -x '-tt' "sudo insmod $BASE_PATH/$DRV_PATH/coyote_drv.ko ip_addr_q$3=\$$qsfp_ip mac_addr_q$3=\$$qsfp_mac"
parallel-ssh -H "$hostlist" -x '-tt' "sudo /opt/sgrt/cli/program/fpga_chmod 0"
# shopt -s nullglob
# dev_arr=(/dev/fpga*)
# for fdev in "${!dev_arr[@]}"; do
# echo $fdev
# parallel-ssh -H "$hostlist" -x '-tt' "sudo /opt/sgrt/cli/program/fpga_chmod $fdev"
# done
echo "*** Driver loaded"
echo " ** "
fi