forked from aws/aws-fpga
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhdk_setup.sh
268 lines (234 loc) · 9.08 KB
/
hdk_setup.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
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
# Amazon FPGA Hardware Development Kit
#
# Copyright 2016 Amazon.com, Inc. or its affiliates. All Rights Reserved.
#
# Licensed under the Amazon Software License (the "License"). You may not use
# this file except in compliance with the License. A copy of the License is
# located at
#
# http://aws.amazon.com/asl/
#
# or in the "license" file accompanying this file. This file is distributed on
# an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, express or
# implied. See the License for the specific language governing permissions and
# limitations under the License.
# Script must be sourced from a bash shell or it will not work
# When being sourced $0 will be the interactive shell and $BASH_SOURCE_ will contain the script being sourced
# When being run $0 and $_ will be the same.
script=${BASH_SOURCE[0]}
if [ $script == $0 ]; then
echo "ERROR: You must source this script"
exit 2
fi
full_script=$(readlink -f $script)
script_name=$(basename $full_script)
script_dir=$(dirname $full_script)
current_dir=$(pwd)
source $script_dir/shared/bin/message_functions.sh
debug=0
# This function checks if an environment module exists
# Returns 0 if it exists, and returns 1 if it doesn't
function does_module_exist() {
output=`/usr/bin/ls /usr/local/Modules/$MODULE_VERSION/modulefiles | grep $1`
if [[ $output == "$1" ]]; then
return 0;
else
return 1;
fi
}
function usage {
echo -e "USAGE: source [\$AWS_FPGA_REPO_DIR/]$script_name [-d|-debug] [-h|-help]"
}
function help {
info_msg "$script_name"
info_msg " "
info_msg "Sets up the environment for AWS FPGA HDK tools."
info_msg " "
info_msg "hdk_setup.sh script will:"
info_msg " (1) Check if Xilinx Vivado is installed,"
info_msg " (2) Set up key environment variables HDK_*, and"
info_msg " (3) Download/update the HDK shell's checkpoint"
info_msg " (4) Prepare DRAM controller and PCIe IP modules if they are not already available in your directory."
echo " "
usage
}
# Process command line args
args=( "$@" )
for (( i = 0; i < ${#args[@]}; i++ )); do
arg=${args[$i]}
case $arg in
-d|-debug)
debug=1
;;
-h|-help)
help
return 0
;;
*)
err_msg "Invalid option: $arg\n"
usage
return 1
esac
done
source $script_dir/shared/bin/set_AWS_FPGA_REPO_DIR.sh
debug_msg "Checking for Vivado install:"
# before going too far make sure Vivado is available
if ! vivado -version > /dev/null 2>&1; then
err_msg "Please install/enable Vivado."
err_msg " If you are using the FPGA Developer AMI then please request support."
return 1
fi
#Searching for Vivado version and comparing it with the list of supported versions
export VIVADO_VER=`vivado -version | grep Vivado | head -1`
info_msg "Using $VIVADO_VER"
if grep -Fxq "$VIVADO_VER" $AWS_FPGA_REPO_DIR/hdk/supported_vivado_versions.txt
then
debug_msg "$VIVADO_VER is supported by this HDK release."
else
err_msg "$VIVADO_VER is not supported by this HDK release."
err_msg "Supported versions are:"
cat $AWS_FPGA_REPO_DIR/hdk/supported_vivado_versions.txt
return 1
fi
debug_msg "Vivado check succeeded"
info_msg "Setting up environment variables"
# Clear environment variables
unset HDK_DIR
unset HDK_COMMON_DIR
unset HDK_SHELL_DIR
unset HDK_SHELL_DESIGN_DIR
# Don't unset CL_DIR if designer has already set it.
#unset CL_DIR
export HDK_DIR=$AWS_FPGA_REPO_DIR/hdk
# The next variable should not be modified and should always point to the /common directory under HDK_DIR
export HDK_COMMON_DIR=$HDK_DIR/common
# Point to the latest version of AWS shell
export HDK_SHELL_DIR=$(readlink -f $HDK_COMMON_DIR/shell_stable)
hdk_shell_version=$(readlink $HDK_COMMON_DIR/shell_stable)
# Set the common shell design dir
export HDK_SHELL_DESIGN_DIR=$HDK_SHELL_DIR/design
export PATH=$(echo $PATH | sed -e 's/\(^\|:\)[^:]\+\/hdk\/common\/scripts\(:\|$\)/:/g; s/^://; s/:$//')
PATH=$AWS_FPGA_REPO_DIR/hdk/common/scripts:$PATH
# Update PYTHONPATH with libraries used for unit testing
python_lib=$AWS_FPGA_REPO_DIR/shared/lib
export PYTHONPATH=$(echo $PATH | sed -e 's/\(^\|:\)[^:]\+$python_lib\(:\|$\)/:/g; s/^://; s/:$//')
PYTHONPATH=$python_lib:$PYTHONPATH
# The CL_DIR is where the actual Custom Logic design resides. The developer is expected to override this.
# export CL_DIR=$HDK_DIR/cl/developer_designs
debug_msg "Done setting environment variables.";
# Download correct shell DCP
info_msg "Using HDK shell version $hdk_shell_version"
debug_msg "Checking HDK shell's checkpoint version"
hdk_shell_s3_bucket=aws-fpga-hdk-resources
declare -a s3_hdk_ltx_files=("cl_hello_world.debug_probes.ltx"
"cl_dram_dma.debug_probes.ltx"
)
# Shell files to be downloaded
declare -a s3_hdk_files=("SH_CL_BB_routed.dcp"
"cl_hello_world.debug_probes.ltx"
"cl_dram_dma.debug_probes.ltx"
)
# Downloading the shell files
for shell_file in "${s3_hdk_files[@]}"
do
# Determine if shell or debug probe
if [ $shell_file == "SH_CL_BB_routed.dcp" ]; then
sub_dir="checkpoints"
else
sub_dir="debug_probes"
fi
hdk_shell_dir=$HDK_SHELL_DIR/build/$sub_dir/from_aws
hdk_file=$hdk_shell_dir/$shell_file
s3_shell_dir=$hdk_shell_s3_bucket/hdk/$hdk_shell_version/build/$sub_dir/from_aws
# Download the sha256
if [ ! -e $hdk_shell_dir ]; then
mkdir -p $hdk_shell_dir || { err_msg "Failed to create $hdk_shell_dir"; return 2; }
fi
# Use curl instead of AWS CLI so that credentials aren't required.
curl -s https://s3.amazonaws.com/$s3_shell_dir/$shell_file.sha256 -o $hdk_file.sha256 || { err_msg "Failed to download HDK shell's $shell_file version from $s3_shell_dir/$shell_file.sha256 -o $hdk_file.sha256"; return 2; }
if grep -q '<?xml version' $hdk_file.sha256; then
err_msg "Failed to download HDK shell's $shell_file version from $s3_shell_dir/$shell_file.sha256"
cat $hdk_file.sha256
return 2
fi
exp_sha256=$(cat $hdk_file.sha256)
debug_msg " $shell_file latest version=$exp_sha256"
# If shell file already downloaded check its sha256
if [ -e $hdk_file ]; then
act_sha256=$( sha256sum $hdk_file | awk '{ print $1 }' )
debug_msg " $shell_file existing version=$act_sha256"
if [[ $act_sha256 != $exp_sha256 ]]; then
info_msg "HDK shell's $shell_file version is incorrect"
info_msg " Saving old file to $hdk_file.back"
mv $hdk_file $hdk_file.back
fi
else
info_msg "HDK shell's $shell_file hasn't been downloaded yet."
fi
if [ ! -e $hdk_file ]; then
info_msg "Downloading latest HDK shell $shell_file from $s3_shell_dir/$shell_file"
# Use curl instead of AWS CLI so that credentials aren't required.
curl -s https://s3.amazonaws.com/$s3_shell_dir/$shell_file -o $hdk_file || { err_msg "HDK shell checkpoint download failed"; return 2; }
fi
# Check sha256
act_sha256=$( sha256sum $hdk_file | awk '{ print $1 }' )
if [[ $act_sha256 != $exp_sha256 ]]; then
err_msg "Incorrect HDK shell checkpoint version:"
err_msg " expected version=$exp_sha256"
err_msg " actual version=$act_sha256"
err_msg " There may be an issue with the uploaded checkpoint or the download failed."
return 2
fi
info_msg "HDK shell is up-to-date"
done
# Create DDR and PCIe IP models and patch PCIe
models_dir=$HDK_COMMON_DIR/verif/models
ddr4_model_dir=$models_dir/ddr4_model
if [ -f $ddr4_model_dir/arch_defines.v ]; then
# Models already built
# Check to make sure they were built with this version of vivado
if [[ -f $models_dir/.vivado_version ]]; then
models_vivado_version=$(cat $models_dir/.vivado_version)
info_msg "DDR4 model files in $ddr4_model_dir/ were built with $models_vivado_version"
if [[ $models_vivado_version != $VIVADO_VER ]]; then
info_msg " Wrong vivado version so rebuilding with $VIVADO_VER"
fi
else
models_vivado_version=UNKNOWN
info_msg "DDR4 model files in $ddr4_model_dir/ were built with UNKNOWN Vivado version so rebuilding."
fi
else
# Models haven't been built
models_vivado_version=NOT_BUILT
info_msg "DDR4 model files in "$ddr4_model_dir/" do NOT exist. Running model creation step.";
fi
if [[ $models_vivado_version != $VIVADO_VER ]]; then
ddr4_build_dir=$AWS_FPGA_REPO_DIR/ddr4_model_build
info_msg " Building in $ddr4_build_dir"
info_msg " This could take 5-10 minutes, please be patient!";
mkdir -p $ddr4_build_dir
pushd $ddr4_build_dir &> /dev/null
# Run init.sh then clean-up
if ! $HDK_DIR/common/verif/scripts/init.sh $models_dir; then
err_msg "DDR4 model build failed."
err_msg " Build dir=$ddr4_build_dir"
popd &> /dev/null
return 2
fi
info_msg "DDR4 model build passed."
popd &> /dev/null
rm -rf $ddr4_build_dir
else
debug_msg "DDR4 model files exist in "$ddr4_model_dir/". Skipping model creation step.";
fi
if [[ ":$CL_DIR" == ':' ]]; then
info_msg "ATTENTION: Don't forget to set the CL_DIR variable for the directory of your Custom Logic.";
else
info_msg "CL_DIR is $CL_DIR"
if [ ! -d $CL_DIR ]; then
err_msg "CL_DIR doesn't exist. Set CL_DIR to a valid directory."
unset CL_DIR
fi
fi
cd $current_dir
info_msg "AWS HDK setup PASSED.";