mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	Various updates to CodingReadme
This commit is contained in:
		
							parent
							
								
									5170b86108
								
							
						
					
					
						commit
						c3ce824af0
					
				
					 1 changed files with 13 additions and 10 deletions
				
			
		
							
								
								
									
										23
									
								
								CodingReadme
									
										
									
									
									
								
							
							
						
						
									
										23
									
								
								CodingReadme
									
										
									
									
									
								
							|  | @ -32,6 +32,10 @@ This can be built into a Yosys module using the following command: | ||||||
| 
 | 
 | ||||||
| 	yosys-config --exec --cxx --cxxflags --ldflags -o hello.so -shared hello.cc --ldlibs | 	yosys-config --exec --cxx --cxxflags --ldflags -o hello.so -shared hello.cc --ldlibs | ||||||
| 
 | 
 | ||||||
|  | Or short: | ||||||
|  | 
 | ||||||
|  | 	yosys-config --build hello.so hello.cc | ||||||
|  | 
 | ||||||
| And then executed using the following command: | And then executed using the following command: | ||||||
| 
 | 
 | ||||||
| 	yosys -m hello.so -p hello_world | 	yosys -m hello.so -p hello_world | ||||||
|  | @ -69,6 +73,9 @@ replacement for std::unordered_set<T>. The main characteristics are: | ||||||
| 	- iterators can be compared. it1 < it2 means that the position of t2 | 	- iterators can be compared. it1 < it2 means that the position of t2 | ||||||
| 	  can be reached via t1 but not vice versa. | 	  can be reached via t1 but not vice versa. | ||||||
| 
 | 
 | ||||||
|  | 	- the method .sort() can be used to sort the elements in the container | ||||||
|  | 	  the container stays sorted until elements are added or removed. | ||||||
|  | 
 | ||||||
| 	- dict<K, T> and pool<T> will have the same order of iteration across | 	- dict<K, T> and pool<T> will have the same order of iteration across | ||||||
| 	  all compilers, standard libraries and architectures. | 	  all compilers, standard libraries and architectures. | ||||||
| 
 | 
 | ||||||
|  | @ -109,8 +116,8 @@ the declarations for the following types in kernel/rtlil.h: | ||||||
| 		table.) | 		table.) | ||||||
| 
 | 
 | ||||||
| 	RTLIL::SigBit | 	RTLIL::SigBit | ||||||
| 		A single signal bit. I.e. either a constant (0, 1, x, z) or | 		A single signal bit. I.e. either a constant state (0, 1, | ||||||
| 		a single bit from a wire. | 		x, z) or a single bit from a wire. | ||||||
| 
 | 
 | ||||||
| 	RTLIL::SigSpec | 	RTLIL::SigSpec | ||||||
| 		Essentially a vector of SigBits. | 		Essentially a vector of SigBits. | ||||||
|  | @ -134,7 +141,7 @@ in Yosys. Most importantly there is SigMap (declared in kernel/sigtools.h). | ||||||
| 
 | 
 | ||||||
| When a design has many wires in it that are connected to each other, then a | When a design has many wires in it that are connected to each other, then a | ||||||
| single signal bit can have multiple valid names. The SigMap object can be used | single signal bit can have multiple valid names. The SigMap object can be used | ||||||
| to map SigSpecs or SigBits to unique SigSpecs and SigBits that consitently | to map SigSpecs or SigBits to unique SigSpecs and SigBits that consistently | ||||||
| only use one wire from such a group of connected wires. For example: | only use one wire from such a group of connected wires. For example: | ||||||
| 
 | 
 | ||||||
| 	SigBit a = module->addWire(NEW_ID); | 	SigBit a = module->addWire(NEW_ID); | ||||||
|  | @ -154,8 +161,7 @@ The following yosys commands are a good starting point if you are looking for ex | ||||||
| of how to use the Yosys API: | of how to use the Yosys API: | ||||||
| 
 | 
 | ||||||
| 	manual/CHAPTER_Prog/stubnets.cc | 	manual/CHAPTER_Prog/stubnets.cc | ||||||
| 	passes/opt/wreduce.cc | 	manual/PRESENTATION_Prog/my_cmd.cc | ||||||
| 	passes/techmap/maccmap.cc |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| Notes on the existing codebase | Notes on the existing codebase | ||||||
|  | @ -312,11 +318,8 @@ Also with default config setting: | ||||||
| 	cd ~yosys/techlibs/cmos | 	cd ~yosys/techlibs/cmos | ||||||
| 	bash testbench.sh | 	bash testbench.sh | ||||||
| 
 | 
 | ||||||
| 	cd ~yosys/techlibs/xilinx/example_sim_counter | 	cd ~yosys/techlibs/xilinx/example_basys3 | ||||||
| 	bash run_sim.sh | 	bash run.sh | ||||||
| 
 |  | ||||||
| 	cd ~yosys/techlibs/xilinx/example_mojo_counter |  | ||||||
| 	bash example.sh |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| Test building plugins with various of the standard passes: | Test building plugins with various of the standard passes: | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue