_yosys: handle unparseable versions
Do not use yosys binaries with unparseable version numbers. This ensures that nmigen always knows what version of yosys it is generating RTLIL for. The effect of this change is that if the version number of the system yosys is unparsable, nmigen will attempt to fallback to the builtin Yosys. Fixes #409.
This commit is contained in:
		
							parent
							
								
									706eb03e6b
								
							
						
					
					
						commit
						303ea18cb6
					
				|  | @ -53,6 +53,8 @@ class YosysBinary: | ||||||
| 
 | 
 | ||||||
|         Returns |         Returns | ||||||
|         ------- |         ------- | ||||||
|  |         ``None`` if version number could not be determined, or a 3-tuple ``(major, minor, distance)`` if it could. | ||||||
|  | 
 | ||||||
|         major : int |         major : int | ||||||
|             Major version. |             Major version. | ||||||
|         minor : int |         minor : int | ||||||
|  | @ -151,7 +153,10 @@ class _SystemYosys(YosysBinary): | ||||||
|     def version(cls): |     def version(cls): | ||||||
|         version = cls.run(["-V"]) |         version = cls.run(["-V"]) | ||||||
|         match = re.match(r"^Yosys (\d+)\.(\d+)(?:\+(\d+))?", version) |         match = re.match(r"^Yosys (\d+)\.(\d+)(?:\+(\d+))?", version) | ||||||
|         return (int(match[1]), int(match[2]), int(match[3] or 0)) |         if match: | ||||||
|  |             return (int(match[1]), int(match[2]), int(match[3] or 0)) | ||||||
|  |         else: | ||||||
|  |             return None | ||||||
| 
 | 
 | ||||||
|     @classmethod |     @classmethod | ||||||
|     def data_dir(cls): |     def data_dir(cls): | ||||||
|  | @ -208,8 +213,10 @@ def find_yosys(requirement): | ||||||
|                              "an unrecognized clause {!r}" |                              "an unrecognized clause {!r}" | ||||||
|                              .format(clause)) |                              .format(clause)) | ||||||
|     for proxy in proxies: |     for proxy in proxies: | ||||||
|         if proxy.available() and requirement(proxy.version()): |         if proxy.available(): | ||||||
|             return proxy |             version = proxy.version() | ||||||
|  |             if version is not None and requirement(version): | ||||||
|  |                 return proxy | ||||||
|     else: |     else: | ||||||
|         if "NMIGEN_USE_YOSYS" in os.environ: |         if "NMIGEN_USE_YOSYS" in os.environ: | ||||||
|             raise YosysError("Could not find an acceptable Yosys binary. Searched: {}" |             raise YosysError("Could not find an acceptable Yosys binary. Searched: {}" | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Alan Green
						Alan Green