back.verilog: add workaround for evaluation Verific behavior.
The evaluation version of Verific prints its license information to stdout, and since it is against the EULA to change that in any way, this behavior is not possible to fix in Yosys. Add a workaround in nMigen instead.
This commit is contained in:
		
							parent
							
								
									875579ea50
								
							
						
					
					
						commit
						ed0f508e8a
					
				|  | @ -1,6 +1,7 @@ | |||
| import os | ||||
| import re | ||||
| import subprocess | ||||
| import itertools | ||||
| 
 | ||||
| from .._toolchain import * | ||||
| from . import rtlil | ||||
|  | @ -17,6 +18,7 @@ def _yosys_version(): | |||
|     yosys_path = require_tool("yosys") | ||||
|     version = subprocess.check_output([yosys_path, "-V"], encoding="utf-8") | ||||
|     # If Yosys is built with Verific, then Verific license information is printed first. | ||||
|     # See below for details. | ||||
|     m = re.search(r"^Yosys ([\d.]+)(?:\+(\d+))?", version, flags=re.M) | ||||
|     tag, offset = m[1], m[2] or 0 | ||||
|     return tuple(map(int, tag.split("."))), offset | ||||
|  | @ -65,6 +67,13 @@ write_verilog -norename {write_verilog_opts} | |||
|     if popen.returncode: | ||||
|         raise YosysError(error.strip()) | ||||
|     else: | ||||
|         # If Yosys is built with an evaluation version of Verific, then Verific license information  | ||||
|         # is printed first. It consists of empty lines and lines starting with `--`, which are not | ||||
|         # valid at the start of a Verilog file, and thus may be reliably removed. | ||||
|         verilog_text = "\n".join(itertools.dropwhile( | ||||
|             lambda x: x == "" or x.startswith("--"), | ||||
|             verilog_text.splitlines() | ||||
|         )) | ||||
|         return verilog_text | ||||
| 
 | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 Teguh Hofstee
						Teguh Hofstee