forked from tanchou/Verilog
		
	
		
			
	
	
		
			88 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Tcl
		
	
	
	
	
	
		
		
			
		
	
	
			88 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Tcl
		
	
	
	
	
	
|   | # Tcl script for iverilog simulation
 | ||
|  | namespace eval gtkwave { | ||
|  | 
 | ||
|  | 
 | ||
|  |   # Help information for this script
 | ||
|  |   proc print_help {} { | ||
|  |     variable script_file "run_gtkwave.tcl" | ||
|  |     puts "\nDescription:" | ||
|  |     puts "Runs the iverilog simulation.\n" | ||
|  |     puts "Syntax:" | ||
|  |     puts "$script_file" | ||
|  |     puts "$script_file \[action\] \[args\]" | ||
|  |     puts "Usage:" | ||
|  |     puts "Name                   Description" | ||
|  |     puts "-------------------------------------------------------------------------" | ||
|  |     puts "\[action\]             Determine the action to be performed. Default value: help\n" | ||
|  |     puts "                       Current actions: help, clean\n" | ||
|  |     puts "\[args\]               Arguments related to the action.\n" | ||
|  |     puts "                       --root <dir> changes the root reference for the project.\n" | ||
|  |     puts "-------------------------------------------------------------------------\n" | ||
|  |     exit 0 | ||
|  |   } | ||
|  | 
 | ||
|  | 
 | ||
|  |   proc main {} { | ||
|  | 
 | ||
|  |     variable root_dir | ||
|  |     # Set the reference directory to where the script is
 | ||
|  |     #set root_dir [file dirname [info script]]
 | ||
|  | 
 | ||
|  |     # Set the reference directory for source file relative paths (by default the value is script directory path)
 | ||
|  |     set root_dir "." | ||
|  | 
 | ||
|  |     if { [info exists ::root_dir_loc] } { | ||
|  |       set root_dir $::root_dir_loc | ||
|  |     } | ||
|  | 
 | ||
|  |     if { $::argc > 0 } { | ||
|  |       set root_dir [lindex $::argv 0] | ||
|  |     } | ||
|  | 
 | ||
|  |     puts "Starting gtkwave. The root dir is: $root_dir" | ||
|  | 
 | ||
|  |     #   variable root [file dirname [file normalize [info script]]]
 | ||
|  |     #   variable root [file dirname [file dirname [info script]]]
 | ||
|  |     variable root $root_dir | ||
|  | 
 | ||
|  |     variable view_file $root/runs/sim/iverilog/counter_tb.vcd  | ||
|  | 
 | ||
|  |     variable gtkwave_script $root/scripts/gtk_wave_all_signals.tcl  | ||
|  | 
 | ||
|  |     proc run_view {res} { | ||
|  |       set name [file rootname $res] | ||
|  |    | ||
|  |       # set iverilog_args "$sim_iverilog::additional_options -g2012 -Wall -I $sim_iverilog::source_path -Y .sv -y $sim_iverilog::source_path -o $sim_iverilog::output_dir/$name.vvp $sim_iverilog::tb_path/$tb $sim_iverilog::sources_full_path"
 | ||
|  |       #set gtkwave_args "-S $gtkwave::gtkwave_script $gtkwave::view_file"
 | ||
|  |       set gtkwave_args "$gtkwave::view_file" | ||
|  | 
 | ||
|  | 	  #puts $gtkwave_args
 | ||
|  |       try { | ||
|  |         set results [exec gtkwave {*}$gtkwave_args] | ||
|  |         set status 0 | ||
|  |       } trap CHILDSTATUS {results options} { | ||
|  |         set status [lindex [dict get $options -errorcode] 2] | ||
|  |       } | ||
|  | 
 | ||
|  |       if {$status != 0} { | ||
|  |         puts "Problem running gtkwave :" | ||
|  |         puts $results | ||
|  |         return | ||
|  |       } | ||
|  | 
 | ||
|  |       # output iverilog result
 | ||
|  |       puts $results | ||
|  | 
 | ||
|  |      | ||
|  |     } | ||
|  | 
 | ||
|  |     run_view $root_dir | ||
|  | 
 | ||
|  |     exit 0 | ||
|  |   } | ||
|  | 
 | ||
|  |   # run main
 | ||
|  | 
 | ||
|  |   main | ||
|  | 
 | ||
|  | } |