vendor.intel: add Mistral toolchain support.
This commit is contained in:
		
							parent
							
								
									11914a1e67
								
							
						
					
					
						commit
						177f1b2e40
					
				|  | @ -9,6 +9,9 @@ __all__ = ["IntelPlatform"] | ||||||
| 
 | 
 | ||||||
| class IntelPlatform(TemplatedPlatform): | class IntelPlatform(TemplatedPlatform): | ||||||
|     """ |     """ | ||||||
|  |     Quartus toolchain | ||||||
|  |     ----------------- | ||||||
|  | 
 | ||||||
|     Required tools: |     Required tools: | ||||||
|         * ``quartus_map`` |         * ``quartus_map`` | ||||||
|         * ``quartus_fit`` |         * ``quartus_fit`` | ||||||
|  | @ -31,15 +34,36 @@ class IntelPlatform(TemplatedPlatform): | ||||||
|         * ``*.rpt``: toolchain reports. |         * ``*.rpt``: toolchain reports. | ||||||
|         * ``{{name}}.sof``: bitstream as SRAM object file. |         * ``{{name}}.sof``: bitstream as SRAM object file. | ||||||
|         * ``{{name}}.rbf``: bitstream as raw binary file. |         * ``{{name}}.rbf``: bitstream as raw binary file. | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     Mistral toolchain | ||||||
|  |     ----------------- | ||||||
|  | 
 | ||||||
|  |     Required tools: | ||||||
|  |         * ``yosys`` | ||||||
|  |         * ``nextpnr-mistral`` | ||||||
|  | 
 | ||||||
|  |     The environment is populated by running the script specified in the environment variable | ||||||
|  |     ``NMIGEN_ENV_Mistral``, if present. | ||||||
|  | 
 | ||||||
|  |         * ``verbose``: enables logging of informational messages to standard error. | ||||||
|  |         * ``read_verilog_opts``: adds options for ``read_verilog`` Yosys command. | ||||||
|  |         * ``synth_opts``: adds options for ``synth_intel_alm`` Yosys command. | ||||||
|  |         * ``script_after_read``: inserts commands after ``read_ilang`` in Yosys script. | ||||||
|  |         * ``script_after_synth``: inserts commands after ``synth_intel_alm`` in Yosys script. | ||||||
|  |         * ``yosys_opts``: adds extra options for ``yosys``. | ||||||
|  |         * ``nextpnr_opts``: adds extra options for ``nextpnr-mistral``. | ||||||
|     """ |     """ | ||||||
| 
 | 
 | ||||||
|     toolchain = "Quartus" |     toolchain = None # selected when creating platform | ||||||
| 
 | 
 | ||||||
|     device  = abstractproperty() |     device  = abstractproperty() | ||||||
|     package = abstractproperty() |     package = abstractproperty() | ||||||
|     speed   = abstractproperty() |     speed   = abstractproperty() | ||||||
|     suffix  = "" |     suffix  = "" | ||||||
| 
 | 
 | ||||||
|  |     # Quartus templates | ||||||
|  | 
 | ||||||
|     quartus_suppressed_warnings = [ |     quartus_suppressed_warnings = [ | ||||||
|         10264,  # All case item expressions in this case statement are onehot |         10264,  # All case item expressions in this case statement are onehot | ||||||
|         10270,  # Incomplete Verilog case statement has no default case item |         10270,  # Incomplete Verilog case statement has no default case item | ||||||
|  | @ -51,14 +75,14 @@ class IntelPlatform(TemplatedPlatform): | ||||||
|         292013, # Feature is only available with a valid subscription license |         292013, # Feature is only available with a valid subscription license | ||||||
|     ] |     ] | ||||||
| 
 | 
 | ||||||
|     required_tools = [ |     quartus_required_tools = [ | ||||||
|         "quartus_map", |         "quartus_map", | ||||||
|         "quartus_fit", |         "quartus_fit", | ||||||
|         "quartus_asm", |         "quartus_asm", | ||||||
|         "quartus_sta", |         "quartus_sta", | ||||||
|     ] |     ] | ||||||
| 
 | 
 | ||||||
|     file_templates = { |     quartus_file_templates = { | ||||||
|         **TemplatedPlatform.build_script_templates, |         **TemplatedPlatform.build_script_templates, | ||||||
|         "build_{{name}}.sh": r""" |         "build_{{name}}.sh": r""" | ||||||
|             # {{autogenerated}} |             # {{autogenerated}} | ||||||
|  | @ -124,7 +148,7 @@ class IntelPlatform(TemplatedPlatform): | ||||||
|             {% endfor %} |             {% endfor %} | ||||||
|         """, |         """, | ||||||
|     } |     } | ||||||
|     command_templates = [ |     quartus_command_templates = [ | ||||||
|         r""" |         r""" | ||||||
|         {{invoke_tool("quartus_map")}} |         {{invoke_tool("quartus_map")}} | ||||||
|             {{get_override("quartus_map_opts")|options}} |             {{get_override("quartus_map_opts")|options}} | ||||||
|  | @ -147,6 +171,104 @@ class IntelPlatform(TemplatedPlatform): | ||||||
|         """, |         """, | ||||||
|     ] |     ] | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  |     # Mistral templates | ||||||
|  | 
 | ||||||
|  |     mistral_required_tools = [ | ||||||
|  |         "yosys", | ||||||
|  |         "nextpnr-mistral" | ||||||
|  |     ] | ||||||
|  |     mistral_file_templates = { | ||||||
|  |         **TemplatedPlatform.build_script_templates, | ||||||
|  |         "{{name}}.il": r""" | ||||||
|  |             # {{autogenerated}} | ||||||
|  |             {{emit_rtlil()}} | ||||||
|  |         """, | ||||||
|  |         "{{name}}.debug.v": r""" | ||||||
|  |             /* {{autogenerated}} */ | ||||||
|  |             {{emit_debug_verilog()}} | ||||||
|  |         """, | ||||||
|  |         "{{name}}.ys": r""" | ||||||
|  |             # {{autogenerated}} | ||||||
|  |             {% for file in platform.iter_files(".v") -%} | ||||||
|  |                 read_verilog {{get_override("read_verilog_opts")|options}} {{file}} | ||||||
|  |             {% endfor %} | ||||||
|  |             {% for file in platform.iter_files(".sv") -%} | ||||||
|  |                 read_verilog -sv {{get_override("read_verilog_opts")|options}} {{file}} | ||||||
|  |             {% endfor %} | ||||||
|  |             {% for file in platform.iter_files(".il") -%} | ||||||
|  |                 read_ilang {{file}} | ||||||
|  |             {% endfor %} | ||||||
|  |             read_ilang {{name}}.il | ||||||
|  |             delete w:$verilog_initial_trigger | ||||||
|  |             {{get_override("script_after_read")|default("# (script_after_read placeholder)")}} | ||||||
|  |             synth_intel_alm {{get_override("synth_opts")|options}} -top {{name}} | ||||||
|  |             {{get_override("script_after_synth")|default("# (script_after_synth placeholder)")}} | ||||||
|  |             write_json {{name}}.json | ||||||
|  |         """, | ||||||
|  |         "{{name}}.qsf": r""" | ||||||
|  |             # {{autogenerated}} | ||||||
|  |             {% for port_name, pin_name, attrs in platform.iter_port_constraints_bits() -%} | ||||||
|  |                 set_location_assignment -to {{port_name|tcl_quote}} PIN_{{pin_name}} | ||||||
|  |                 {% for key, value in attrs.items() -%} | ||||||
|  |                     set_instance_assignment -to {{port_name|tcl_quote}} -name {{key}} {{value|tcl_quote}} | ||||||
|  |                 {% endfor %} | ||||||
|  |             {% endfor %} | ||||||
|  |         """, | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  |     mistral_command_templates = [ | ||||||
|  |         r""" | ||||||
|  |         {{invoke_tool("yosys")}} | ||||||
|  |             {{quiet("-q")}} | ||||||
|  |             {{get_override("yosys_opts")|options}} | ||||||
|  |             -l {{name}}.rpt | ||||||
|  |             {{name}}.ys | ||||||
|  |         """, | ||||||
|  |         r""" | ||||||
|  |         {{invoke_tool("nextpnr-mistral")}} | ||||||
|  |             {{quiet("--quiet")}} | ||||||
|  |             {{get_override("nextpnr_opts")|options}} | ||||||
|  |             --log {{name}}.tim | ||||||
|  |             --device {{platform.device}}{{platform.package}}{{platform.speed}}{{platform.suffix}} | ||||||
|  |             --json {{name}}.json | ||||||
|  |             --qsf {{name}}.qsf | ||||||
|  |             --rbf {{name}}.rbf | ||||||
|  |         """ | ||||||
|  |     ] | ||||||
|  | 
 | ||||||
|  |     # Common logic | ||||||
|  | 
 | ||||||
|  |     def __init__(self, *, toolchain="Quartus"): | ||||||
|  |         super().__init__() | ||||||
|  | 
 | ||||||
|  |         assert toolchain in ("Quartus", "Mistral") | ||||||
|  |         self.toolchain = toolchain | ||||||
|  | 
 | ||||||
|  |     @property | ||||||
|  |     def required_tools(self): | ||||||
|  |         if self.toolchain == "Quartus": | ||||||
|  |             return self.quartus_required_tools | ||||||
|  |         if self.toolchain == "Mistral": | ||||||
|  |             return self.mistral_required_tools | ||||||
|  |         assert False | ||||||
|  | 
 | ||||||
|  |     @property | ||||||
|  |     def file_templates(self): | ||||||
|  |         if self.toolchain == "Quartus": | ||||||
|  |             return self.quartus_file_templates | ||||||
|  |         if self.toolchain == "Mistral": | ||||||
|  |             return self.mistral_file_templates | ||||||
|  |         assert False | ||||||
|  | 
 | ||||||
|  |     @property | ||||||
|  |     def command_templates(self): | ||||||
|  |         if self.toolchain == "Quartus": | ||||||
|  |             return self.quartus_command_templates | ||||||
|  |         if self.toolchain == "Mistral": | ||||||
|  |             return self.mistral_command_templates | ||||||
|  |         assert False | ||||||
|  | 
 | ||||||
|     def add_clock_constraint(self, clock, frequency): |     def add_clock_constraint(self, clock, frequency): | ||||||
|         super().add_clock_constraint(clock, frequency) |         super().add_clock_constraint(clock, frequency) | ||||||
|         clock.attrs["keep"] = "true" |         clock.attrs["keep"] = "true" | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Olivier Galibert
						Olivier Galibert