mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	Try again for passes/pmgen/ice40_dsp_pm.h rule
Tested on both in-tree and out-of-tree builds
This commit is contained in:
		
							parent
							
								
									a02d61576e
								
							
						
					
					
						commit
						57f8bb471f
					
				
					 2 changed files with 9 additions and 8 deletions
				
			
		|  | @ -9,7 +9,8 @@ pp = pprint.PrettyPrinter(indent=4) | |||
| pmgfile = sys.argv[1] | ||||
| assert pmgfile.endswith(".pmg") | ||||
| prefix = pmgfile[0:-4] | ||||
| pmname = prefix.split('/')[-1] | ||||
| prefix = prefix.split('/')[-1] | ||||
| outfile = sys.argv[2] | ||||
| 
 | ||||
| state_types = dict() | ||||
| udata_types = dict() | ||||
|  | @ -179,7 +180,7 @@ with open(pmgfile, "r") as f: | |||
| 
 | ||||
|             blocks.append(block) | ||||
| 
 | ||||
| with open("%s_pm.h" % prefix, "w") as f: | ||||
| with open(outfile, "w") as f: | ||||
|     print("// Generated by pmgen.py from {}.pgm".format(prefix), file=f) | ||||
|     print("", file=f) | ||||
| 
 | ||||
|  | @ -190,10 +191,10 @@ with open("%s_pm.h" % prefix, "w") as f: | |||
|     print("YOSYS_NAMESPACE_BEGIN", file=f) | ||||
|     print("", file=f) | ||||
| 
 | ||||
|     print("struct {}_pm {{".format(pmname), file=f) | ||||
|     print("struct {}_pm {{".format(prefix), file=f) | ||||
|     print("  Module *module;", file=f) | ||||
|     print("  SigMap sigmap;", file=f) | ||||
|     print("  std::function<void()> on_accept;".format(pmname), file=f) | ||||
|     print("  std::function<void()> on_accept;".format(prefix), file=f) | ||||
|     print("", file=f) | ||||
| 
 | ||||
|     for index in range(len(blocks)): | ||||
|  | @ -291,7 +292,7 @@ with open("%s_pm.h" % prefix, "w") as f: | |||
|     print("  }", file=f) | ||||
|     print("", file=f) | ||||
| 
 | ||||
|     print("  {}_pm(Module *module, const vector<Cell*> &cells) :".format(pmname), file=f) | ||||
|     print("  {}_pm(Module *module, const vector<Cell*> &cells) :".format(prefix), file=f) | ||||
|     print("      module(module), sigmap(module) {", file=f) | ||||
|     for s, t in sorted(udata_types.items()): | ||||
|         if t.endswith("*"): | ||||
|  | @ -321,7 +322,7 @@ with open("%s_pm.h" % prefix, "w") as f: | |||
|     print("  }", file=f) | ||||
|     print("", file=f) | ||||
| 
 | ||||
|     print("  ~{}_pm() {{".format(pmname), file=f) | ||||
|     print("  ~{}_pm() {{".format(prefix), file=f) | ||||
|     print("    for (auto cell : autoremove_cells)", file=f) | ||||
|     print("      module->remove(cell);", file=f) | ||||
|     print("  }", file=f) | ||||
|  | @ -340,7 +341,7 @@ with open("%s_pm.h" % prefix, "w") as f: | |||
|     print("  }", file=f) | ||||
|     print("", file=f) | ||||
| 
 | ||||
|     print("  void run(std::function<void({}_pm&)> on_accept_f) {{".format(pmname), file=f) | ||||
|     print("  void run(std::function<void({}_pm&)> on_accept_f) {{".format(prefix), file=f) | ||||
|     print("    run([&](){on_accept_f(*this);});", file=f) | ||||
|     print("  }", file=f) | ||||
|     print("", file=f) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue