blob: b8f938da52b097731078bb53d848593075cc4a51 [file] [log] [blame]
#!/bin/bash
# SPDX-FileCopyrightText: 2020 Efabless Corporation
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# SPDX-License-Identifier: Apache-2.0
export RUN_ROOT=$(pwd)
# By default skip timing since we don't need the libs in any of the CI tests
export SKIP_TIMING=${1:-1}
export OPENLANE_TAG=rc7
export IMAGE_NAME=efabless/openlane:$OPENLANE_TAG
docker pull $IMAGE_NAME
cd $RUN_ROOT/..
export PDK_ROOT=$(pwd)/pdks
mkdir $PDK_ROOT
echo $PDK_ROOT
echo $RUN_ROOT
cd $RUN_ROOT
make skywater-pdk
make skywater-library
# The following section is for running on the CI.
# If you're running locally you should replace them with: `make skywater-library`
# This is because sometimes while setting up the conda env (skywater's make timing) it fails to fetch something
# Then it exits without retrying. So, here we're retrying, and if something goes wrong it will exit after 5 retries.
# Section Begin
if [ $SKIP_TIMING -eq 0 ]; then
cnt=0
until make skywater-timing; do
cnt=$((cnt+1))
if [ $cnt -eq 5 ]; then
exit 2
fi
rm -rf $PDK_ROOT/skywater-pdk
make skywater-pdk
make skywater-library
done
fi
# Section End
make open_pdks
docker run -v $RUN_ROOT:/openLANE_flow -v $PDK_ROOT:$PDK_ROOT -e PDK_ROOT=$PDK_ROOT -u $(id -u $USER):$(id -g $USER) $IMAGE_NAME bash -c "make build-pdk"
echo "done installing"
echo "Delete docker image:"
docker rmi $IMAGE_NAME
echo "Cleaning up PDK installation directory"
rm -rf $PDK_ROOT/skywater-pdk/
rm -rf $PDK_ROOT/open_pdks/
cd $RUN_ROOT
exit 0