mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 09:24:37 +00:00 
			
		
		
		
	Reorganising documentation
Also changing to furo theme.
This commit is contained in:
		
							parent
							
								
									4f1cd66829
								
							
						
					
					
						commit
						045c04096e
					
				
					 40 changed files with 661 additions and 1282 deletions
				
			
		|  | @ -1,8 +1,99 @@ | |||
| What is Yosys | ||||
| ============= | ||||
| 
 | ||||
| .. TODO: rewrite to not be a thesis abstract | ||||
| 
 | ||||
| :Abstract: | ||||
| 	Most of today's digital design is done in HDL code (mostly Verilog or  | ||||
| 	VHDL) and with the help of HDL synthesis tools. | ||||
| 
 | ||||
| 	In special cases such as synthesis for coarse-grain cell libraries or | ||||
| 	when testing new synthesis algorithms it might be necessary to write a | ||||
| 	custom HDL synthesis tool or add new features to an existing one. In | ||||
| 	these cases the availability of a Free and Open Source (FOSS) synthesis | ||||
| 	tool that can be used as basis for custom tools would be helpful. | ||||
| 
 | ||||
| 	In the absence of such a tool, the Yosys Open SYnthesis Suite (Yosys) | ||||
| 	was developed. This document covers the design and implementation of | ||||
| 	this tool. At the moment the main focus of Yosys lies on the high-level | ||||
| 	aspects of digital synthesis. The pre-existing FOSS logic-synthesis tool | ||||
| 	ABC is used by Yosys to perform advanced gate-level optimizations. | ||||
| 
 | ||||
| 	An evaluation of Yosys based on real-world designs is included. It is | ||||
| 	shown that Yosys can be used as-is to synthesize such designs. The | ||||
| 	results produced by Yosys in this tests where successfully verified | ||||
| 	using formal verification and are comparable in quality to the results | ||||
| 	produced by a commercial synthesis tool. | ||||
| 
 | ||||
| 	This document was originally published as bachelor thesis at the Vienna | ||||
| 	University of Technology :cite:p:`BACC`. | ||||
| 
 | ||||
| Yosys is a tool for synthesising (behavioural) Verilog HDL code to target | ||||
| architecture netlists. Yosys aims at a wide range of application domains and | ||||
| thus must be flexible and easy to adapt to new tasks. | ||||
| 
 | ||||
| What you can do with Yosys | ||||
| -------------------------- | ||||
| 
 | ||||
| The extended Yosys universe | ||||
| --------------------------- | ||||
| 
 | ||||
| In no particular order: | ||||
| 
 | ||||
| - SBY for formal verification | ||||
| - EQY for equivalence checking | ||||
| - MCY for mutation coverage | ||||
| 
 | ||||
| History of Yosys | ||||
| ---------------- | ||||
| 
 | ||||
| .. TODO: copypaste | ||||
| 
 | ||||
| A Hardware Description Language (HDL) is a computer language used to describe | ||||
| circuits. A HDL synthesis tool is a computer program that takes a formal | ||||
| description of a circuit written in an HDL as input and generates a netlist that | ||||
| implements the given circuit as output. | ||||
| 
 | ||||
| Currently the most widely used and supported HDLs for digital circuits are | ||||
| Verilog :cite:p:`Verilog2005,VerilogSynth` and :abbr:`VHDL (VHSIC HDL, where | ||||
| VHSIC is an acronym for Very-High-Speed Integrated Circuits)` | ||||
| :cite:p:`VHDL,VHDLSynth`. Both HDLs are used for test and verification purposes | ||||
| as well as logic synthesis, resulting in a set of synthesizable and a set of | ||||
| non-synthesizable language features. In this document we only look at the | ||||
| synthesizable subset of the language features. | ||||
| 
 | ||||
| In recent work on heterogeneous coarse-grain reconfigurable logic | ||||
| :cite:p:`intersynth` the need for a custom application-specific HDL synthesis | ||||
| tool emerged. It was soon realised that a synthesis tool that understood Verilog | ||||
| or VHDL would be preferred over a synthesis tool for a custom HDL. Given an | ||||
| existing Verilog or VHDL front end, the work for writing the necessary | ||||
| additional features and integrating them in an existing tool can be estimated to | ||||
| be about the same as writing a new tool with support for a minimalistic custom | ||||
| HDL. | ||||
| 
 | ||||
| The proposed custom HDL synthesis tool should be licensed under a Free and Open | ||||
| Source Software (FOSS) licence. So an existing FOSS Verilog or VHDL synthesis | ||||
| tool would have been needed as basis to build upon. The main advantages of | ||||
| choosing Verilog or VHDL is the ability to synthesize existing HDL code and to | ||||
| mitigate the requirement for circuit-designers to learn a new language. In order | ||||
| to take full advantage of any existing FOSS Verilog or VHDL tool, such a tool | ||||
| would have to provide a feature-complete implementation of the synthesizable HDL | ||||
| subset. | ||||
| 
 | ||||
| Basic RTL synthesis is a well understood field :cite:p:`LogicSynthesis`. Lexing, | ||||
| parsing and processing of computer languages :cite:p:`Dragonbook` is a | ||||
| thoroughly researched field. All the information required to write such tools | ||||
| has been openly available for a long time, and it is therefore likely that a | ||||
| FOSS HDL synthesis tool with a feature-complete Verilog or VHDL front end must | ||||
| exist which can be used as a basis for a custom RTL synthesis tool. | ||||
| 
 | ||||
| Due to the author's preference for Verilog over VHDL it was decided early on to | ||||
| go for Verilog instead of VHDL [#]_. So the existing FOSS Verilog synthesis | ||||
| tools were evaluated. The results of this evaluation are utterly devastating. | ||||
| Therefore a completely new Verilog synthesis tool was implemented and is | ||||
| recommended as basis for custom synthesis tools. This is the tool that is | ||||
| discussed in this document. | ||||
| 
 | ||||
| .. [#] | ||||
|    A quick investigation into FOSS VHDL tools yielded similar grim results for | ||||
|    FOSS VHDL synthesis tools. | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue