-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathinstall_prjtrellis.sh
executable file
·74 lines (55 loc) · 2.99 KB
/
install_prjtrellis.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
#!/bin/bash
#"***************************************************************************************************"
# common initialization
#"***************************************************************************************************"
# select master or some GitHub hash version, and whether or not to force a clean
THIS_CHECKOUT=master
THIS_CLEAN=true
# perform some version control checks on this file
./gitcheck.sh $0
# initialize some environment variables and perform some sanity checks
. ./init.sh
# we don't want tee to capture exit codes
set -o pipefail
#"***************************************************************************************************"
# Install prjtrellis
#"***************************************************************************************************"
if [ "$APTGET" == 1 ]; then
sudo apt-get install python3-dev clang cmake 2>&1 | tee -a "$THIS_LOG"
fi
echo "***************************************************************************************************"
echo " prjtrellis (required for nextpnr-ecp5). Saving log to $THIS_LOG"
echo "***************************************************************************************************"
pushd .
cd $WORKSPACE
# Call the common github checkout:
$SAVED_CURRENT_PATH/fetch_github.sh https://github.com/YosysHQ/prjtrellis prjtrellis $THIS_CHECKOUT 2>&1 | tee -a "$THIS_LOG"
$SAVED_CURRENT_PATH/check_for_error.sh $? "$THIS_LOG"
cd "$WORKSPACE"/prjtrellis
source environment.sh
# cmake must run from the libtrellis directory
cd libtrellis
# Makefile will not exist the very first time, so nothing to do
# optional clean
if [ "$THIS_CLEAN" == "true" ]; then
if [ ! -f "Makefile" ]; then
echo "$0: File 'Makefile' not found. Not cleaning... (probably a fresh git clone)"
else
echo "" 2>&1 | tee -a "$THIS_LOG"
echo "make clean" 2>&1 | tee -a "$THIS_LOG"
make clean 2>&1 | tee -a "$THIS_LOG"
$SAVED_CURRENT_PATH/check_for_error.sh $? "$THIS_LOG"
fi
fi
cmake -DCMAKE_INSTALL_PREFIX=/usr . 2>&1 | tee -a "$THIS_LOG"
$SAVED_CURRENT_PATH/check_for_error.sh $? "$THIS_LOG"
# see https://stackoverflow.com/questions/9383014/cant-import-my-own-modules-in-python
# now set above
# export PYTHONPATH="~/workspace/prjtrellis/database"
make -j$(nproc) 2>&1 | tee -a "$THIS_LOG"
$SAVED_CURRENT_PATH/check_for_error.sh $? "$THIS_LOG"
sudo make install 2>&1 | tee -a "$THIS_LOG"
$SAVED_CURRENT_PATH/check_for_error.sh $? "$THIS_LOG"
popd
echo "Completed $0 " | tee -a "$THIS_LOG"
echo "----------------------------------"