mirror of
				https://github.com/openhwgroup/cvw
				synced 2025-02-11 06:05:49 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			23 lines
		
	
	
		
			1010 B
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			23 lines
		
	
	
		
			1010 B
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/bash
 | |
| # check for warnings in Verilog code
 | |
| # The verilator lint tool is faster and better than Modelsim so it is best to run this first.
 | |
| export PATH=$PATH:/usr/local/bin/
 | |
| verilator=`which verilator`
 | |
| 
 | |
| basepath=$(dirname $0)
 | |
| for config in rv64ic rv32ic; do
 | |
|     echo "$config linting..."
 | |
|     if !($verilator --lint-only "$@" --top-module wallypipelinedsoc "-I$basepath/config/shared" "-I$basepath/config/$config" $basepath/src/*/*.sv --relative-includes); then
 | |
|         echo "Exiting after $config lint due to errors or warnings"
 | |
|         exit 1
 | |
|     fi
 | |
| done
 | |
| echo "All lints run with no errors or warnings"
 | |
| 
 | |
| # --lint-only just runs lint rather than trying to compile and simulate
 | |
| # -I points to the include directory where files such as `include wally-config.vh  are found
 | |
| 
 | |
| # For more exhaustive (and sometimes spurious) warnings, run:
 | |
| # verilator --lint-only -Wall -Iconfig/rv64ic src/*
 | |
| # Unfortunately, this produces a bunch of UNUSED and UNDRIVEN signal warnings in blocks that are configured to not exist.
 |