back.rtlil: extend shorter operand of a binop when matching sign.
This is necessary because converting a large unsigned value to a signed value of the same width may change its sign. Fixes #271.
This commit is contained in:
		
							parent
							
								
									834fe3c700
								
							
						
					
					
						commit
						7c322e562a
					
				|  | @ -490,6 +490,7 @@ class _RHSValueCompiler(_ValueCompiler): | |||
|             rhs_wire = self(rhs) | ||||
|         else: | ||||
|             lhs_sign = rhs_sign = True | ||||
|             lhs_bits = rhs_bits = max(lhs_bits, rhs_bits) | ||||
|             lhs_wire = self.match_shape(lhs, lhs_bits, lhs_sign) | ||||
|             rhs_wire = self.match_shape(rhs, rhs_bits, rhs_sign) | ||||
|         res_bits, res_sign = value.shape() | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 whitequark
						whitequark