OpenFPGA/openfpga.sh

123 lines
3.9 KiB
Bash
Raw Normal View History

2019-11-16 14:19:00 -06:00
#!/bin/bash
#title : openfpga.sh
#description : This script provides shortcut commands <bash functions>
# for several simple operations in OpenFPGA project
#author : Ganesh Gore <ganesh.gore@utah.edu>
#==============================================================================
2021-02-08 15:07:01 -06:00
if [ -z $OPENFPGA_PATH ]; then
echo "OPENFPGA_PATH variable not found"
export OPENFPGA_PATH=$(pwd);
echo "Setting OPENFPGA_PATH=${OPENFPGA_PATH}"
else
echo "OPENFPGA_PATH=${OPENFPGA_PATH}"
fi
2021-02-07 23:35:13 -06:00
export OPENFPGA_SCRIPT_PATH="${OPENFPGA_PATH}/openfpga_flow/scripts"
export OPENFPGA_TASK_PATH="${OPENFPGA_PATH}/openfpga_flow/tasks"
2019-11-16 16:52:32 -06:00
if [ -z $PYTHON_EXEC ]; then export PYTHON_EXEC="python3"; fi
2019-11-16 14:19:00 -06:00
2021-09-07 06:38:30 -05:00
# Add yosys bin folder in PATH, this is required by yosys-plugins
# to install plugins in yosys folder
export PATH="${OPENFPGA_PATH}/yosys/install/bin:${PATH}"
2019-11-16 14:19:00 -06:00
# This function checks the path and
# raises warning if the command is not executing
# inside current OpendFPGA folder
check_execution_path (){
if [[ $1 != *"${OPENFPGA_PATH}"* ]]; then
echo -e "\e[33mCommand is not executed from configured OPNEFPGA directory\e[0m"
fi
}
run-task-with-modelsim () {
2020-09-23 15:06:33 -05:00
echo "Script as to be run as \"run-task-with-modelsim task_name --maxthreads nb_threads other_run-modelsim_options\""
$PYTHON_EXEC $OPENFPGA_SCRIPT_PATH/run_fpga_task.py $1 $2 $3
$PYTHON_EXEC $OPENFPGA_SCRIPT_PATH/run_modelsim.py "$@"
}
2019-11-16 16:52:32 -06:00
run-task () {
$PYTHON_EXEC $OPENFPGA_SCRIPT_PATH/run_fpga_task.py "$@"
}
2021-02-03 11:34:34 -06:00
clean-run () {
rm -rf ./openfpga_flow/**/run???
}
2019-11-16 20:10:04 -06:00
run-modelsim () {
$PYTHON_EXEC $OPENFPGA_SCRIPT_PATH/run_modelsim.py "$@"
}
2019-11-16 16:52:32 -06:00
run-flow () {
$PYTHON_EXEC $OPENFPGA_SCRIPT_PATH/run_fpga_flow.py "$@"
}
2019-11-16 14:19:00 -06:00
# lists all the configure task in task directory
list-tasks () {
check_execution_path "$(pwd)"
2021-02-07 23:35:13 -06:00
tree -P 'task.conf' --prune | sed "/.* task.conf/d" | sed "/.* config/d" | sed '$d'
2019-11-16 14:19:00 -06:00
}
# Switch directory to root of OpenFPGA
goto-root () {
cd $OPENFPGA_PATH
}
2021-02-03 11:34:34 -06:00
# Run regression test locally
run-regression-local () {
cd ${OPENFPGA_PATH}
bash .github/workflows/*reg_test.sh
}
2019-11-16 14:19:00 -06:00
# Changes directory to task directory [goto_task <task_name> <run_num[default 0]>]
goto-task () {
if [ -z $1 ]; then
echo "requires task name goto_task <task_name> <run_num[default 0]>"
return
fi
goto_path=$OPENFPGA_TASK_PATH/$1
2021-02-03 11:34:34 -06:00
# Selects the run directory
2019-11-16 16:52:32 -06:00
run_num=""
2019-11-16 14:19:00 -06:00
if [ ! -d $goto_path ]; then echo "Task directory not found"; return; fi
2019-11-16 16:52:32 -06:00
if [[ "$2" =~ '^[0-9]+$' ]] ; then
if ! [[ $2 == '0' ]] ; then run_num="$(printf run%03d $2)"; else run_num="latest"; fi
if [ ! -d "$goto_path/$run_num" ]; then run_num="latest"; fi
2019-11-16 14:19:00 -06:00
fi
if [ ! -d $goto_path/$run_num ]; then
2019-11-16 16:52:32 -06:00
echo "\e[33mTask run directory not found -" $goto_path/$run_num "\e[0m"
2019-11-16 14:19:00 -06:00
else
2019-11-16 16:52:32 -06:00
echo "Switching current dirctory to" $goto_path/$run_num
2019-11-16 14:19:00 -06:00
cd $goto_path/$run_num
fi
2021-02-03 11:34:34 -06:00
# Selects benchmark directory
select benchRun in $(ls -d **/arch | sed "s/\/arch//" | head -n 20)
do
[ -d ${benchRun} ] && cd ${benchRun}
break
done
2019-11-16 14:19:00 -06:00
}
# Clears enviroment variables and fucntions
2019-11-16 16:52:32 -06:00
unset-openfpga (){
2019-11-16 14:19:00 -06:00
unset -v OPENFPGA_PATH
2019-11-16 16:52:32 -06:00
unset -f list-tasks run-task run-flow goto-task goto-root >/dev/null 2>&1
}
# Allow autocompletion of task
if [[ $(ps -p $$ -oargs=) == *"zsh"* ]]; then
autoload -U +X bashcompinit; bashcompinit;
fi
2021-02-08 15:07:01 -06:00
command -v shopt && shopt -s globstar
2021-02-07 23:35:13 -06:00
# TaskList=$(ls -tdalh ${OPENFPGA_TASK_PATH}/* | awk '{system("basename " $9)}' | awk '{printf("%s ",$1)}')
TaskList=$(ls -tdalh ${OPENFPGA_TASK_PATH}/**/task.conf |
awk '{print $9}' | sed -e "s/\/config\/task.conf//" |
sed -e "s/${OPENFPGA_PATH//\//\\/}\/openfpga_flow\/tasks\///" |
awk '{printf("%s ",$1)}')
2019-11-16 16:52:32 -06:00
complete -W "${TaskList}" goto-task
2019-11-16 20:10:04 -06:00
complete -W "${TaskList}" run-task
2020-04-06 01:35:28 -05:00
complete -W "${TaskList}" run-shell-task
complete -W "${TaskList}" run-modelsim