|  | #!/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 | 
|  |  | 
|  | # comma seperated test ids | 
|  | IDS=$1 | 
|  | # simulation mode : RTL/GL | 
|  | SIM_MODE=$2 | 
|  |  | 
|  | DV_TEST_IDS=(${IDS//,/ }) | 
|  |  | 
|  | export TARGET_PATH=$(pwd) | 
|  | export CARAVEL_ROOT=$(pwd)/caravel | 
|  |  | 
|  | if [ ! -d $TARGET_PATH ] | 
|  | then | 
|  | echo "Directory /path/to/dir DOES NOT exists." | 
|  | exit 9999 | 
|  | fi | 
|  |  | 
|  | cd .. | 
|  |  | 
|  | export PDK_PATH=$(pwd)/pdks/sky130A | 
|  | if [ ! -d $PDK_PATH ] | 
|  | then | 
|  | echo "Directory /path/to/dir DOES NOT exists." | 
|  | exit 9999 | 
|  | fi | 
|  |  | 
|  | DV_PATH=$TARGET_PATH/verilog/dv | 
|  | if [ ! -d $DV_PATH ] | 
|  | then | 
|  | echo "Directory /path/to/dir DOES NOT exists." | 
|  | exit 9999 | 
|  | fi | 
|  |  | 
|  | for id in "${DV_TEST_IDS[@]}" | 
|  | do | 
|  | docker run -v $TARGET_PATH:$TARGET_PATH -v $PDK_PATH:$PDK_PATH \ | 
|  | -v $CARAVEL_ROOT:$CARAVEL_ROOT \ | 
|  | -e TARGET_PATH=$TARGET_PATH -e PDK_PATH=$PDK_PATH \ | 
|  | -e CARAVEL_ROOT=$CARAVEL_ROOT \ | 
|  | -u $(id -u $USER):$(id -g $USER) efabless/dv_setup:latest \ | 
|  | bash -c "bash $TARGET_PATH/.github/scripts/dv/run-dv.sh $PDK_PATH $DV_PATH $id $SIM_MODE" | 
|  |  | 
|  | echo "DONE!" | 
|  |  | 
|  | VERDICT_FILE=$TARGET_PATH/verilog/dv/$id.out | 
|  |  | 
|  | if [ -f $VERDICT_FILE ]; then | 
|  | cnt=$(grep "Pass" $VERDICT_FILE -s | wc -l) | 
|  | if ! [[ $cnt ]]; then cnt = 0; fi | 
|  | else | 
|  | echo "DV check failed due to subscript failure. Please review the logs"; | 
|  | exit 2; | 
|  | fi | 
|  |  | 
|  | echo "Verdict: $cnt" | 
|  |  | 
|  | if [[ $cnt -ne 1 ]]; then | 
|  | exit 2; | 
|  | fi | 
|  | done | 
|  |  | 
|  | exit 0; |