mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-11-03 21:09:12 +00:00 
			
		
		
		
	check: Assert edges data is not out-of-bounds
This commit is contained in:
		
							parent
							
								
									e1e77a7fa9
								
							
						
					
					
						commit
						4fdcf388d3
					
				
					 1 changed files with 6 additions and 2 deletions
				
			
		| 
						 | 
				
			
			@ -160,8 +160,12 @@ struct CheckPass : public Pass {
 | 
			
		|||
 | 
			
		||||
				void add_edge(RTLIL::Cell *cell, RTLIL::IdString from_port, int from_bit,
 | 
			
		||||
							  RTLIL::IdString to_port, int to_bit, int) override {
 | 
			
		||||
					SigBit from = sigmap(cell->getPort(from_port))[from_bit];
 | 
			
		||||
					SigBit to = sigmap(cell->getPort(to_port))[to_bit];
 | 
			
		||||
					SigSpec from_portsig = cell->getPort(from_port);
 | 
			
		||||
					SigSpec to_portsig = cell->getPort(to_port);
 | 
			
		||||
					log_assert(from_bit >= 0 && from_bit < from_portsig.size());
 | 
			
		||||
					log_assert(to_bit >= 0 && to_bit < to_portsig.size());
 | 
			
		||||
					SigBit from = sigmap(from_portsig[from_bit]);
 | 
			
		||||
					SigBit to = sigmap(to_portsig[to_bit]);
 | 
			
		||||
 | 
			
		||||
					if (from.wire && to.wire)
 | 
			
		||||
						topo.edge(std::make_pair(from.wire->name, from.offset), std::make_pair(to.wire->name, to.offset));
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue