mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 01:14:37 +00:00 
			
		
		
		
	rtlil: handle all-zeros case in Const::compress
This commit is contained in:
		
							parent
							
								
									4cd2e04da4
								
							
						
					
					
						commit
						07fb8af05b
					
				
					 1 changed files with 9 additions and 7 deletions
				
			
		|  | @ -286,20 +286,22 @@ void RTLIL::Const::compress(bool is_signed) | |||
| 
 | ||||
| 	// back to front (MSB to LSB)
 | ||||
| 	RTLIL::State leading_bit; | ||||
| 	if(is_signed) | ||||
| 	if (is_signed) | ||||
| 		leading_bit = (bits.back() == RTLIL::State::Sx) ? RTLIL::State::S0 : bits.back(); | ||||
| 	else | ||||
| 		leading_bit = RTLIL::State::S0; | ||||
| 
 | ||||
|     size_t idx = bits.size(); | ||||
|     while (idx > 0 && bits[idx -1] == leading_bit) { | ||||
|         --idx; | ||||
|     } | ||||
| 	size_t idx = bits.size(); | ||||
| 	while (idx > 0 && bits[idx -1] == leading_bit) { | ||||
| 		idx--; | ||||
| 	} | ||||
| 
 | ||||
| 	// signed needs one leading bit
 | ||||
| 	if (is_signed && idx < bits.size()) { | ||||
|         ++idx; | ||||
|     } | ||||
| 		idx++; | ||||
| 	} | ||||
| 	// must be at least one bit
 | ||||
| 	idx = (idx == 0) ? 1 : idx; | ||||
| 
 | ||||
| 	bits.erase(bits.begin() + idx, bits.end()); | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue