aboutsummaryrefslogtreecommitdiffstats
path: root/.github/ci/build_common.sh
blob: 2a2d84475120580585c68ee27d220d9cada6626e (plain)
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
#!/bin/bash

# Install latest Yosys
function build_yosys {
    PREFIX=`pwd`/.yosys
    YOSYS_PATH=${DEPS_PATH}/yosys
    mkdir -p ${YOSYS_PATH}
    git clone --recursive https://github.com/YosysHQ/yosys ${YOSYS_PATH}
    pushd ${YOSYS_PATH}
    git reset --hard ${YOSYS_REVISION}
    make -j`nproc` PREFIX=$PREFIX
    make install PREFIX=$PREFIX
    popd
}

function build_icestorm {
    PREFIX=`pwd`/.icestorm
    ICESTORM_PATH=${DEPS_PATH}/icestorm
    mkdir -p ${ICESTORM_PATH}
    git clone --recursive https://github.com/YosysHQ/icestorm ${ICESTORM_PATH}
    pushd ${ICESTORM_PATH}
    git reset --hard ${ICESTORM_REVISION}
    make -j`nproc` PREFIX=${PREFIX}
    make install PREFIX=${PREFIX}
    popd
}

function build_trellis {
    PREFIX=`pwd`/.trellis
    TRELLIS_PATH=${DEPS_PATH}/prjtrellis
    mkdir -p ${TRELLIS_PATH}
    git clone --recursive https://github.com/YosysHQ/prjtrellis ${TRELLIS_PATH}
    pushd ${TRELLIS_PATH}
    git reset --hard ${TRELLIS_REVISION}
    mkdir -p libtrellis/build
    pushd libtrellis/build
    cmake -DCMAKE_INSTALL_PREFIX=${PREFIX} ..
    make -j`nproc`
    make install
    popd
    popd
}

function build_prjoxide {
    PREFIX=`pwd`/.prjoxide
    PRJOXIDE_PATH=${DEPS_PATH}/prjoxide
    curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y ;\
    mkdir -p ${PRJOXIDE_PATH}
    git clone --recursive https://github.com/gatecat/prjoxide ${PRJOXIDE_PATH}
    pushd ${PRJOXIDE_PATH}
    git reset --hard ${PRJOXIDE_REVISION}
    cd libprjoxide
    PATH=$PATH:$HOME/.cargo/bin cargo install --root $PREFIX --path prjoxide
    popd
}