forked from aws/aws-fpga
-
Notifications
You must be signed in to change notification settings - Fork 3
/
sdaccel_setup.sh
329 lines (288 loc) · 11.3 KB
/
sdaccel_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
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
# 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/set_common_functions.sh
source $script_dir/shared/bin/set_common_env_vars.sh
# Source sdk_setup.sh
info_msg "Sourcing sdk_setup.sh"
if ! source $AWS_FPGA_REPO_DIR/sdk_setup.sh; then
return 1
fi
if [ -z "$SDK_DIR" ]; then
err_msg "SDK_DIR environment variable is not set. Please use 'source sdk_setup.sh' from the aws-fpga directory."
return 1
fi
debug=0
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 SDAccel tools."
info_msg " "
info_msg "sdaccel_setup.sh script will:"
info_msg " (1) install FPGA Management Tools,"
info_msg " (2) check if Xilinx tools are available,"
info_msg " (3) check if required packages are installed,"
info_msg " (4) Download lastest AWS Platform,"
info_msg " (5) Install Runtime drivers "
echo " "
usage
}
function check_set_xilinx_sdx {
if [[ ":$XILINX_SDX" == ':' ]]; then
debug_msg "XILINX_SDX is not set"
which sdx
RET=$?
if [ $RET != 0 ]; then
debug_msg "sdx not found in path."
err_msg "XILINX_SDX variable not set and sdx not in the path"
err_msg "Please set XILINX_SDX variable to point to your location of your Xilinx installation or add location of sdx exectuable to your PATH variable"
return $RET
else
export XILINX_SDX=`which sdx | sed 's:/bin/sdx::'`
info_msg "Setting XILINX_SDX to $XILINX_SDX"
fi
else
info_msg "XILINX_SDX is already set to $XILINX_SDX"
fi
# get sdaccel release version, i.e. "2017.1"
RELEASE_VER=$(basename $XILINX_SDX)
RELEASE_VER=${RELEASE_VER:0:6}
export RELEASE_VER=$RELEASE_VER
echo "RELEASE_VER equals $RELEASE_VER"
}
function check_install_packages_centos {
#TODO: Check required packages are installed or install them
#TODO: Check version of gcc is above 4.8.5 (4.6.3 does not work)
for pkg in `cat $SDACCEL_DIR/packages.txt`; do
if yum list installed "$pkg" >/dev/null 2>&1; then
true
else
warn_msg " $pkg not installed - please run: sudo yum install $pkg "
fi
done
}
function check_install_packages_ubuntu {
for pkg in `cat $SDACCEL_DIR/packages.txt`; do
if apt -qq list "$pkg" >/dev/null 2>&1; then
true
else
warn_msg " $pkg not installed - please run: sudo apt-get install $pkg "
fi
done
}
function check_internet {
curl --silent --head -m 30 http://www.amazon.com
RET=$?
if [ $RET != 0 ]; then
err_msg "curl cannot connect to the internet using please check your internet connection or proxy settings"
err_msg "To check your connection run: curl --silent --head -m 30 http://www.amazon.com "
return $RET
else
info_msg "Internet Access OK"
fi
}
function check_icd {
info_msg "Checking ICD is installed"
if grep -q 'libxilinxopencl.so' /etc/OpenCL/vendors/xilinx.icd; then
info_msg "Found 'libxilinxopencl.so"
else
info_msg "/etc/OpenCL/vendors/xilinx.icd does not exist or does not contain lbixilinxopencl.so creating and adding libxilinxopencl.so to it"
sudo sh -c "echo libxilinxopencl.so > /etc/OpenCL/vendors/xilinx.icd"
RET=$?
if [ $RET != 0 ]; then
err_msg "/etc/OpenCL/vendors/xilinx.icd does not exist and cannot be created, sudo permissions needed to update it."
err_msg "Run the following with sudo permissions: sudo sh -c \"echo libxilinxopencl.so > /etc/OpenCL/vendors/xilinx.icd\" "
return $RET
else
echo "Done with ICD installation"
fi
fi
}
# 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
# Check XILINX_SDX is set
if ! check_set_xilinx_sdx; then
return 1
fi
info_msg " XILINX_SDX is set to $XILINX_SDX"
# Install patches as required.
info_msg " Checking & installing required patches"
setup_patches
# Update Xilinx SDAccel Examples from GitHub
info_msg "Using SDx $RELEASE_VER"
if [[ $RELEASE_VER =~ .*2017\.4.* || $RELEASE_VER =~ .*2018\.2.* ]]; then
info_msg "Updating Xilinx SDAccel Examples $RELEASE_VER"
git submodule update --init -- SDAccel/examples/xilinx_$RELEASE_VER
export VIVADO_TOOL_VER=$RELEASE_VER
if [ -e $SDACCEL_DIR/examples/xilinx ]; then
if [ ! -L $SDACCEL_DIR/examples/xilinx ]; then
err_msg "ERROR: SDAccel/examples/xilinx is not a symbolic link. Backup any data and remove SDAccel/examples/xilinx directory. The setup needs to create a symbolic link from SDAccel/examples/xilinx to SDAccel/examples/xilinx_$RELEASE_VER"
return 1
fi
fi
ln -sf $SDACCEL_DIR/examples/xilinx_$RELEASE_VER $SDACCEL_DIR/examples/xilinx
else
echo " $RELEASE_VER is not supported (2017.4 or 2018.2).\n"
exit 2
fi
# settings64 removal - once we put this in the AMI, we will add a check
#export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$XILINX_SDX/lib/lnx64.o
export LD_LIBRARY_PATH=`$XILINX_SDX/bin/ldlibpath.sh $XILINX_SDX/lib/lnx64.o`:$XILINX_SDX/runtime/lib/x86_64
export LD_LIBRARY_PATH=$XILINX_SDX/lnx64/tools/opencv/:$LD_LIBRARY_PATH
# add variable to allow compilation using 2017.4 and 2018.2 on newer OSes
export XOCC_ADD_OPTIONS="--xp param:compiler.useHlsGpp=1"
# Check if internet connection is available
if ! check_internet; then
return 1
fi
# Check ICD is installed
if ! check_icd; then
return 1
fi
# Check correct packages are installed
if [ -f "/etc/redhat-release" ]; then
if ! check_install_packages_centos; then
return 1
fi
else
if ! check_install_packages_ubuntu; then
return 1
fi
fi
function setup_dsa {
if [ "$#" -ne 3 ]; then
err_msg "Illegal number of parameters sent to the setup_dsa function!"
return 1
fi
DSA=$1
DSA_S3_BASE_DIR=$2
PLATFORM_ENV_VAR_NAME=$3
dsa_dir=$SDACCEL_DIR/aws_platform/$DSA/hw/
sdk_dsa=$dsa_dir/$DSA.dsa
sdk_dsa_s3_bucket=aws-fpga-hdk-resources
s3_sdk_dsa=$sdk_dsa_s3_bucket/SDAccel/$DSA_S3_BASE_DIR/$DSA/$DSA.dsa
# set a variable to point to the platform for build and emulation runs
export "$PLATFORM_ENV_VAR_NAME"=$SDACCEL_DIR/aws_platform/$DSA/$DSA.xpfm
# Download the sha256
if [ ! -e $dsa_dir ]; then
mkdir -p $dsa_dir || { err_msg "Failed to create $dsa_dir"; return 2; }
fi
# Use curl instead of AWS CLI so that credentials aren't required.
curl -s https://s3.amazonaws.com/$s3_sdk_dsa.sha256 -o $sdk_dsa.sha256 || { err_msg "Failed to download DSA checkpoint version from $s3_sdk_dsa.sha256 -o $sdk_dsa.sha256"; return 2; }
if grep -q '<?xml version' $sdk_dsa.sha256; then
err_msg "Failed to download SDK DSA checkpoint version from $s3_sdk_dsa.sha256"
cat sdk_dsa.sha256
return 2
fi
exp_sha256=$(cat $sdk_dsa.sha256)
debug_msg " latest version=$exp_sha256"
# If DSA already downloaded check its sha256
if [ -e $sdk_dsa ]; then
act_sha256=$( sha256sum $sdk_dsa | awk '{ print $1 }' )
debug_msg " existing version=$act_sha256"
if [[ $act_sha256 != $exp_sha256 ]]; then
info_msg "SDK DSA checkpoint version is incorrect"
info_msg " Saving old checkpoint to $sdk_dsa.back"
mv $sdk_dsa $sdk_dsa.back
fi
else
info_msg "SDK DSA hasn't been downloaded yet."
fi
if [ ! -e $sdk_dsa ]; then
info_msg "Downloading latest SDK DSA checkpoint from $s3_sdk_dsa"
# Use curl instead of AWS CLI so that credentials aren't required.
curl -s https://s3.amazonaws.com/$s3_sdk_dsa -o $sdk_dsa || { err_msg "SDK dsa checkpoint download failed"; return 2; }
fi
# Check sha256
act_sha256=$( sha256sum $sdk_dsa | awk '{ print $1 }' )
if [[ $act_sha256 != $exp_sha256 ]]; then
err_msg "Incorrect SDK dsa 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
}
#-------------------Dynamic 5.0 Platform----------------------
setup_dsa xilinx_aws-vu9p-f1-04261818_dynamic_5_0 dsa_v062918_shell_v04261818 AWS_PLATFORM_DYNAMIC_5_0
info_msg "AWS Platform: Dynamic 5.0 Platform is up-to-date"
#-------------------Dynamic 5.0 Platform----------------------
# Start of runtime xdma driver install
if [[ $RELEASE_VER == "2017.4" ]]; then
cd $SDACCEL_DIR
info_msg "Building SDAccel runtime"
if ! make ec2=1 debug=1 RELEASE_VER=$RELEASE_VER; then
err_msg "Build of SDAccel runtime FAILED"
return 1
fi
info_msg "Installing SDAccel runtime"
export INSTALL_ROOT=/opt/Xilinx/SDx/${RELEASE_VER}.rte.dyn
if ! sudo make ec2=1 debug=1 INSTALL_ROOT=$INSTALL_ROOT SDK_DIR=$SDK_DIR XILINX_SDX=$XILINX_SDX SDACCEL_DIR=$SDACCEL_DIR RELEASE_VER=$RELEASE_VER DSA=xilinx_aws-vu9p-f1-04261818_dynamic_5_0 install ; then
err_msg "Install of SDAccel runtime FAILED"
return 1
fi
info_msg "SDAccel runtime installed"
cd $current_dir
elif [[ $RELEASE_VER == "2018.2" ]]; then
# Check if XRT is installed
if [ -e /opt/xilinx/xrt ]; then
export XILINX_XRT=/opt/xilinx/xrt
export LD_LIBRARY_PATH=$XILINX_XRT/lib:$LD_LIBRARY_PATH
# copy libstdc++ from $XILINX_SDX/lib
if [[ $(lsb_release -si) == "Ubuntu" ]]; then
sudo cp $XILINX_SDX/lib/lnx64.o/Ubuntu/libstdc++.so* /opt/xilinx/xrt/lib/
elif [[ $(lsb_release -si) == "CentOS" ]]; then
sudo cp $XILINX_SDX/lib/lnx64.o/Default/libstdc++.so* /opt/xilinx/xrt/lib/
else
info_msg "Unsupported OS."
return 1
fi
else
info_msg "SDAccel runtime not installed - This is required if you are running on F1 instance."
fi
fi
export AWS_PLATFORM=$AWS_PLATFORM_DYNAMIC_5_0
info_msg "The default AWS Platform has been set to: \"AWS_PLATFORM=\$AWS_PLATFORM_DYNAMIC_5_0\" "
info_msg "SDAccel Setup PASSED"