mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-31 11:42:30 +00:00 
			
		
		
		
	- Rewrite all Python features to use the pybind11 library instead of boost::python. Unlike boost::python, pybind11 is a header-only library that is just included by Pyosys code, saving a lot of compile time on wheels. - Factor out as much "translation" code from the generator into proper C++ files - Fix running the embedded interpreter not supporting "from pyosys import libyosys as ys" like wheels - Move Python-related elements to `pyosys` directory at the root of the repo - Slight shift in bridging semantics: - Containers are declared as "opaque types" and are passed by reference to Python - many methods have been implemented to make them feel right at home without the overhead/ambiguity of copying to Python and then copying back after mutation - Monitor/Pass use "trampoline" pattern to support virual methods overridable in Python: virtual methods no longer require `py_` prefix - Create really short test set for pyosys that just exercises basic functionality
		
			
				
	
	
		
			34 lines
		
	
	
	
		
			881 B
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			34 lines
		
	
	
	
		
			881 B
		
	
	
	
		
			Python
		
	
	
	
	
	
| from pyosys import libyosys as ys
 | |
| 
 | |
| import json
 | |
| from pathlib import Path
 | |
| 
 | |
| __file_dir__ = Path(__file__).absolute().parent
 | |
| 
 | |
| class CellStatsPass(ys.Pass):
 | |
| 	def __init__(self):
 | |
| 		super().__init__(
 | |
| 			"cell_stats",
 | |
| 			"dumps cell statistics in JSON format"
 | |
| 		)
 | |
| 
 | |
| 	def execute(self, args, design):
 | |
| 		ys.log_header(design, "Dumping cell stats\n")
 | |
| 		ys.log_push()
 | |
| 		cell_stats = {}
 | |
| 		for module in design.all_selected_whole_modules():
 | |
| 			for cell in module.selected_cells():
 | |
| 				if cell.type.str() in cell_stats:
 | |
| 					cell_stats[cell.type.str()] += 1
 | |
| 				else:
 | |
| 					cell_stats[cell.type.str()] = 1
 | |
| 		ys.log(json.dumps(cell_stats))
 | |
| 		ys.log_pop()
 | |
| 
 | |
| p = CellStatsPass() # registration
 | |
| 
 | |
| design = ys.Design()
 | |
| ys.run_pass(f"read_verilog {__file_dir__.parent / 'simple' / 'fiedler-cooley.v'}", design)
 | |
| ys.run_pass("prep", design)
 | |
| ys.run_pass("opt -full", design)
 | |
| ys.run_pass("cell_stats", design)
 |