mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-25 17:04:37 +00:00 
			
		
		
		
	Add $bmux and $demux cells.
This commit is contained in:
		
							parent
							
								
									db33b1e535
								
							
						
					
					
						commit
						93508d58da
					
				
					 25 changed files with 694 additions and 49 deletions
				
			
		|  | @ -142,6 +142,36 @@ void mux_op(AbstractCellEdgesDatabase *db, RTLIL::Cell *cell) | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| void bmux_op(AbstractCellEdgesDatabase *db, RTLIL::Cell *cell) | ||||
| { | ||||
| 	int width = GetSize(cell->getPort(ID::Y)); | ||||
| 	int a_width = GetSize(cell->getPort(ID::A)); | ||||
| 	int s_width = GetSize(cell->getPort(ID::S)); | ||||
| 
 | ||||
| 	for (int i = 0; i < width; i++) | ||||
| 	{ | ||||
| 		for (int k = i; k < a_width; k += width) | ||||
| 			db->add_edge(cell, ID::A, k, ID::Y, i, -1); | ||||
| 
 | ||||
| 		for (int k = 0; k < s_width; k++) | ||||
| 			db->add_edge(cell, ID::S, k, ID::Y, i, -1); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| void demux_op(AbstractCellEdgesDatabase *db, RTLIL::Cell *cell) | ||||
| { | ||||
| 	int width = GetSize(cell->getPort(ID::Y)); | ||||
| 	int a_width = GetSize(cell->getPort(ID::A)); | ||||
| 	int s_width = GetSize(cell->getPort(ID::S)); | ||||
| 
 | ||||
| 	for (int i = 0; i < width; i++) | ||||
| 	{ | ||||
| 		db->add_edge(cell, ID::A, i % a_width, ID::Y, i, -1); | ||||
| 		for (int k = 0; k < s_width; k++) | ||||
| 			db->add_edge(cell, ID::S, k, ID::Y, i, -1); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
| 
 | ||||
| bool YOSYS_NAMESPACE_PREFIX AbstractCellEdgesDatabase::add_edges_from_cell(RTLIL::Cell *cell) | ||||
|  | @ -187,6 +217,16 @@ bool YOSYS_NAMESPACE_PREFIX AbstractCellEdgesDatabase::add_edges_from_cell(RTLIL | |||
| 		return true; | ||||
| 	} | ||||
| 
 | ||||
| 	if (cell->type == ID($bmux)) { | ||||
| 		bmux_op(this, cell); | ||||
| 		return true; | ||||
| 	} | ||||
| 
 | ||||
| 	if (cell->type == ID($demux)) { | ||||
| 		demux_op(this, cell); | ||||
| 		return true; | ||||
| 	} | ||||
| 
 | ||||
| 	// FIXME: $mul $div $mod $divfloor $modfloor $slice $concat
 | ||||
| 	// FIXME: $lut $sop $alu $lcu $macc $fa
 | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue