123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264 |
- # (C) 2001-2022 Altera Corporation. All rights reserved.
- # Your use of Altera Corporation's design tools, logic functions and
- # other software and tools, and its AMPP partner logic functions, and
- # any output files any of the foregoing (including device programming
- # or simulation files), and any associated documentation or information
- # are expressly subject to the terms and conditions of the Altera
- # Program License Subscription Agreement, Altera MegaCore Function
- # License Agreement, or other applicable license agreement, including,
- # without limitation, that your use is for the sole purpose of
- # programming logic devices manufactured by Altera and sold by Altera
- # or its authorized distributors. Please refer to the applicable
- # agreement for further details.
- # ----------------------------------------
- # Auto-generated simulation script msim_setup.tcl
- # ----------------------------------------
- # This script provides commands to simulate the following IP detected in
- # your Quartus project:
- # clkMux
- #
- # Altera recommends that you source this Quartus-generated IP simulation
- # script from your own customized top-level script, and avoid editing this
- # generated script.
- #
- # To write a top-level script that compiles Altera simulation libraries and
- # the Quartus-generated IP in your project, along with your design and
- # testbench files, copy the text from the TOP-LEVEL TEMPLATE section below
- # into a new file, e.g. named "mentor.do", and modify the text as directed.
- #
- # ----------------------------------------
- # # TOP-LEVEL TEMPLATE - BEGIN
- # #
- # # QSYS_SIMDIR is used in the Quartus-generated IP simulation script to
- # # construct paths to the files required to simulate the IP in your Quartus
- # # project. By default, the IP script assumes that you are launching the
- # # simulator from the IP script location. If launching from another
- # # location, set QSYS_SIMDIR to the output directory you specified when you
- # # generated the IP script, relative to the directory from which you launch
- # # the simulator.
- # #
- # set QSYS_SIMDIR <script generation output directory>
- # #
- # # Source the generated IP simulation script.
- # source $QSYS_SIMDIR/mentor/msim_setup.tcl
- # #
- # # Set any compilation options you require (this is unusual).
- # set USER_DEFINED_COMPILE_OPTIONS <compilation options>
- # set USER_DEFINED_VHDL_COMPILE_OPTIONS <compilation options for VHDL>
- # set USER_DEFINED_VERILOG_COMPILE_OPTIONS <compilation options for Verilog>
- # #
- # # Call command to compile the Quartus EDA simulation library.
- # dev_com
- # #
- # # Call command to compile the Quartus-generated IP simulation files.
- # com
- # #
- # # Add commands to compile all design files and testbench files, including
- # # the top level. (These are all the files required for simulation other
- # # than the files compiled by the Quartus-generated IP simulation script)
- # #
- # vlog <compilation options> <design and testbench files>
- # #
- # # Set the top-level simulation or testbench module/entity name, which is
- # # used by the elab command to elaborate the top level.
- # #
- # set TOP_LEVEL_NAME <simulation top>
- # #
- # # Set any elaboration options you require.
- # set USER_DEFINED_ELAB_OPTIONS <elaboration options>
- # #
- # # Call command to elaborate your design and testbench.
- # elab
- # #
- # # Run the simulation.
- # run -a
- # #
- # # Report success to the shell.
- # exit -code 0
- # #
- # # TOP-LEVEL TEMPLATE - END
- # ----------------------------------------
- #
- # IP SIMULATION SCRIPT
- # ----------------------------------------
- # If clkMux is one of several IP cores in your
- # Quartus project, you can generate a simulation script
- # suitable for inclusion in your top-level simulation
- # script by running the following command line:
- #
- # ip-setup-simulation --quartus-project=<quartus project>
- #
- # ip-setup-simulation will discover the Altera IP
- # within the Quartus project, and generate a unified
- # script which supports all the Altera IP within the design.
- # ----------------------------------------
- # ACDS 21.1 850 linux 2022.07.04.11:59:13
- # ----------------------------------------
- # Initialize variables
- if ![info exists SYSTEM_INSTANCE_NAME] {
- set SYSTEM_INSTANCE_NAME ""
- } elseif { ![ string match "" $SYSTEM_INSTANCE_NAME ] } {
- set SYSTEM_INSTANCE_NAME "/$SYSTEM_INSTANCE_NAME"
- }
- if ![info exists TOP_LEVEL_NAME] {
- set TOP_LEVEL_NAME "clkMux"
- }
- if ![info exists QSYS_SIMDIR] {
- set QSYS_SIMDIR "./../"
- }
- if ![info exists QUARTUS_INSTALL_DIR] {
- set QUARTUS_INSTALL_DIR "/home/bart/intelFPGA_lite/21.1/quartus/"
- }
- if ![info exists USER_DEFINED_COMPILE_OPTIONS] {
- set USER_DEFINED_COMPILE_OPTIONS ""
- }
- if ![info exists USER_DEFINED_VHDL_COMPILE_OPTIONS] {
- set USER_DEFINED_VHDL_COMPILE_OPTIONS ""
- }
- if ![info exists USER_DEFINED_VERILOG_COMPILE_OPTIONS] {
- set USER_DEFINED_VERILOG_COMPILE_OPTIONS ""
- }
- if ![info exists USER_DEFINED_ELAB_OPTIONS] {
- set USER_DEFINED_ELAB_OPTIONS ""
- }
- # ----------------------------------------
- # Initialize simulation properties - DO NOT MODIFY!
- set ELAB_OPTIONS ""
- set SIM_OPTIONS ""
- if ![ string match "*-64 vsim*" [ vsim -version ] ] {
- } else {
- }
- # ----------------------------------------
- # Copy ROM/RAM files to simulation directory
- alias file_copy {
- echo "\[exec\] file_copy"
- }
- # ----------------------------------------
- # Create compilation libraries
- proc ensure_lib { lib } { if ![file isdirectory $lib] { vlib $lib } }
- ensure_lib ./libraries/
- ensure_lib ./libraries/work/
- vmap work ./libraries/work/
- vmap work_lib ./libraries/work/
- if ![ string match "*Intel*FPGA*" [ vsim -version ] ] {
- ensure_lib ./libraries/altera_ver/
- vmap altera_ver ./libraries/altera_ver/
- ensure_lib ./libraries/lpm_ver/
- vmap lpm_ver ./libraries/lpm_ver/
- ensure_lib ./libraries/sgate_ver/
- vmap sgate_ver ./libraries/sgate_ver/
- ensure_lib ./libraries/altera_mf_ver/
- vmap altera_mf_ver ./libraries/altera_mf_ver/
- ensure_lib ./libraries/altera_lnsim_ver/
- vmap altera_lnsim_ver ./libraries/altera_lnsim_ver/
- ensure_lib ./libraries/cycloneive_ver/
- vmap cycloneive_ver ./libraries/cycloneive_ver/
- }
- ensure_lib ./libraries/altclkctrl_0/
- vmap altclkctrl_0 ./libraries/altclkctrl_0/
- # ----------------------------------------
- # Compile device library files
- alias dev_com {
- echo "\[exec\] dev_com"
- if ![ string match "*Intel*FPGA*" [ vsim -version ] ] {
- eval vlog $USER_DEFINED_VERILOG_COMPILE_OPTIONS $USER_DEFINED_COMPILE_OPTIONS "$QUARTUS_INSTALL_DIR/eda/sim_lib/altera_primitives.v" -work altera_ver
- eval vlog $USER_DEFINED_VERILOG_COMPILE_OPTIONS $USER_DEFINED_COMPILE_OPTIONS "$QUARTUS_INSTALL_DIR/eda/sim_lib/220model.v" -work lpm_ver
- eval vlog $USER_DEFINED_VERILOG_COMPILE_OPTIONS $USER_DEFINED_COMPILE_OPTIONS "$QUARTUS_INSTALL_DIR/eda/sim_lib/sgate.v" -work sgate_ver
- eval vlog $USER_DEFINED_VERILOG_COMPILE_OPTIONS $USER_DEFINED_COMPILE_OPTIONS "$QUARTUS_INSTALL_DIR/eda/sim_lib/altera_mf.v" -work altera_mf_ver
- eval vlog -sv $USER_DEFINED_VERILOG_COMPILE_OPTIONS $USER_DEFINED_COMPILE_OPTIONS "$QUARTUS_INSTALL_DIR/eda/sim_lib/altera_lnsim.sv" -work altera_lnsim_ver
- eval vlog $USER_DEFINED_VERILOG_COMPILE_OPTIONS $USER_DEFINED_COMPILE_OPTIONS "$QUARTUS_INSTALL_DIR/eda/sim_lib/cycloneive_atoms.v" -work cycloneive_ver
- }
- }
- # ----------------------------------------
- # Compile the design files in correct order
- alias com {
- echo "\[exec\] com"
- eval vlog $USER_DEFINED_VERILOG_COMPILE_OPTIONS $USER_DEFINED_COMPILE_OPTIONS "$QSYS_SIMDIR/submodules/clkMux_altclkctrl_0.v" -work altclkctrl_0
- eval vlog $USER_DEFINED_VERILOG_COMPILE_OPTIONS $USER_DEFINED_COMPILE_OPTIONS "$QSYS_SIMDIR/clkMux.v"
- }
- # ----------------------------------------
- # Elaborate top level design
- alias elab {
- echo "\[exec\] elab"
- eval vsim -t ps $ELAB_OPTIONS $USER_DEFINED_ELAB_OPTIONS -L work -L work_lib -L altclkctrl_0 -L altera_ver -L lpm_ver -L sgate_ver -L altera_mf_ver -L altera_lnsim_ver -L cycloneive_ver $TOP_LEVEL_NAME
- }
- # ----------------------------------------
- # Elaborate the top level design with -voptargs=+acc option
- alias elab_debug {
- echo "\[exec\] elab_debug"
- eval vsim -voptargs=+acc -t ps $ELAB_OPTIONS $USER_DEFINED_ELAB_OPTIONS -L work -L work_lib -L altclkctrl_0 -L altera_ver -L lpm_ver -L sgate_ver -L altera_mf_ver -L altera_lnsim_ver -L cycloneive_ver $TOP_LEVEL_NAME
- }
- # ----------------------------------------
- # Compile all the design files and elaborate the top level design
- alias ld "
- dev_com
- com
- elab
- "
- # ----------------------------------------
- # Compile all the design files and elaborate the top level design with -voptargs=+acc
- alias ld_debug "
- dev_com
- com
- elab_debug
- "
- # ----------------------------------------
- # Print out user commmand line aliases
- alias h {
- echo "List Of Command Line Aliases"
- echo
- echo "file_copy -- Copy ROM/RAM files to simulation directory"
- echo
- echo "dev_com -- Compile device library files"
- echo
- echo "com -- Compile the design files in correct order"
- echo
- echo "elab -- Elaborate top level design"
- echo
- echo "elab_debug -- Elaborate the top level design with -voptargs=+acc option"
- echo
- echo "ld -- Compile all the design files and elaborate the top level design"
- echo
- echo "ld_debug -- Compile all the design files and elaborate the top level design with -voptargs=+acc"
- echo
- echo
- echo
- echo "List Of Variables"
- echo
- echo "TOP_LEVEL_NAME -- Top level module name."
- echo " For most designs, this should be overridden"
- echo " to enable the elab/elab_debug aliases."
- echo
- echo "SYSTEM_INSTANCE_NAME -- Instantiated system module name inside top level module."
- echo
- echo "QSYS_SIMDIR -- Platform Designer base simulation directory."
- echo
- echo "QUARTUS_INSTALL_DIR -- Quartus installation directory."
- echo
- echo "USER_DEFINED_COMPILE_OPTIONS -- User-defined compile options, added to com/dev_com aliases."
- echo
- echo "USER_DEFINED_ELAB_OPTIONS -- User-defined elaboration options, added to elab/elab_debug aliases."
- echo
- echo "USER_DEFINED_VHDL_COMPILE_OPTIONS -- User-defined vhdl compile options, added to com/dev_com aliases."
- echo
- echo "USER_DEFINED_VERILOG_COMPILE_OPTIONS -- User-defined verilog compile options, added to com/dev_com aliases."
- }
- file_copy
- h
|