2005-12-09 10:22:18 +00:00
|
|
|
#! /bin/sh
|
|
|
|
#
|
2024-01-26 22:10:16 +00:00
|
|
|
# qucs_run_hdl - wrapper script for digital simulation
|
2005-12-09 10:22:18 +00:00
|
|
|
#
|
|
|
|
# Copyright (C) 2005 Michael Margraf <michael.margraf@alumni.tu-berlin.de>
|
2009-10-11 15:36:44 +00:00
|
|
|
# Copyright (C) 2005, 2006, 2008, 2009 Stefan Jahn <stefan@lkcc.org>
|
2005-12-10 23:49:39 +00:00
|
|
|
# Copyright (C) 2005 Raimund Jacob <raimi@lkcc.org>
|
2005-12-09 10:22:18 +00:00
|
|
|
#
|
|
|
|
# This is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation; either version 2, or (at your option)
|
|
|
|
# any later version.
|
|
|
|
#
|
|
|
|
# This software is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this package; see the file COPYING. If not, write to
|
|
|
|
# the Free Software Foundation, Inc., 51 Franklin Street - Fifth Floor,
|
|
|
|
# Boston, MA 02110-1301, USA.
|
|
|
|
#
|
2005-12-05 07:11:11 +00:00
|
|
|
|
2005-12-10 23:49:39 +00:00
|
|
|
# Bail out on any error
|
|
|
|
set -e
|
|
|
|
|
2006-01-23 07:12:06 +00:00
|
|
|
# catch termination signal and kill all child processes
|
2024-01-26 22:10:16 +00:00
|
|
|
# trap 'kill 0; exit 0' SIGTERM
|
2006-01-23 07:12:06 +00:00
|
|
|
|
2009-10-11 15:36:44 +00:00
|
|
|
if [ "$#" != 6 ]; then
|
|
|
|
if [ "$#" != 7 ]; then
|
|
|
|
echo "Usage: $0 <netlist.txt> <output.dat> <time> <directory> <bindirectory> <vlibs> [<convoption>]"
|
2006-06-02 07:47:24 +00:00
|
|
|
echo "Directory has to contain the file 'netlist.txt'."
|
2006-05-08 06:13:04 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
2009-10-11 15:36:44 +00:00
|
|
|
OPTION=$7
|
2005-12-10 23:49:39 +00:00
|
|
|
fi
|
|
|
|
|
2005-12-05 07:11:11 +00:00
|
|
|
NAME=$1
|
2006-01-16 07:19:57 +00:00
|
|
|
NAMEOUT=$2
|
|
|
|
TIME=$3
|
|
|
|
DIR=$4
|
|
|
|
BINDIR=$5
|
2024-01-26 22:10:16 +00:00
|
|
|
|
|
|
|
# echo "Filename: $NAME\nOutput: $NAMEOUT\nRuntime: $TIME\nDir: $DIR\nBinary Dir: $BINDIR\nOption: $OPTION"
|
2005-12-05 07:11:11 +00:00
|
|
|
|
2005-12-10 23:49:39 +00:00
|
|
|
if [ ! -d "$DIR" ]; then
|
|
|
|
echo "$DIR: Not a directory"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
cd $DIR
|
|
|
|
|
|
|
|
if [ ! -f $NAME ]; then
|
|
|
|
echo "$NAME: No such file"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2005-12-05 07:11:11 +00:00
|
|
|
cp $NAME digi.vhdl
|
|
|
|
NAME="digi"
|
|
|
|
|
2024-01-26 22:10:16 +00:00
|
|
|
echo -n "running GHDL analysis pass..."
|
|
|
|
ghdl -a $NAME.vhdl
|
2005-12-09 10:22:18 +00:00
|
|
|
echo " done."
|
2005-12-05 07:11:11 +00:00
|
|
|
|
2024-01-26 22:10:16 +00:00
|
|
|
echo -n "running GHDL elaboration pass..."
|
|
|
|
ghdl -e TestBench
|
2005-12-09 10:22:18 +00:00
|
|
|
echo " done."
|
2005-12-05 07:11:11 +00:00
|
|
|
|
2006-08-09 08:12:38 +00:00
|
|
|
echo "simulating..."
|
2024-01-26 22:10:16 +00:00
|
|
|
ghdl -r TestBench --vcd=digi.vcd --stop-time=$TIME
|
2006-01-23 07:12:06 +00:00
|
|
|
wait $!
|
2006-01-09 09:51:55 +00:00
|
|
|
|
|
|
|
echo -n "running VCD conversion..."
|
2024-03-19 10:04:10 +03:00
|
|
|
$BINDIR/qucsconv_rf $OPTION -if vcd -of qucsdata -i $NAME.vcd -o "$NAMEOUT"
|
2006-01-09 09:51:55 +00:00
|
|
|
echo " done."
|
2013-06-10 11:42:53 +02:00
|
|
|
|