From af6797eacc9e43e796e7b9f2fe848f0e03871f8c Mon Sep 17 00:00:00 2001 From: DaniPopes <57450786+DaniPopes@users.noreply.github.com> Date: Sat, 15 Jun 2024 17:38:32 +0200 Subject: [PATCH] chore(interpreter): use U256::arithmetic_shr in SAR (#1525) --- .../interpreter/src/instructions/bitwise.rs | 23 ++++--------------- 1 file changed, 5 insertions(+), 18 deletions(-) diff --git a/crates/interpreter/src/instructions/bitwise.rs b/crates/interpreter/src/instructions/bitwise.rs index 62edf11c5a..a02058419f 100644 --- a/crates/interpreter/src/instructions/bitwise.rs +++ b/crates/interpreter/src/instructions/bitwise.rs @@ -112,25 +112,12 @@ pub fn sar(interpreter: &mut Interpreter, _host: & pop_top!(interpreter, op1, op2); let shift = as_usize_saturated!(op1); - *op2 = if shift >= 256 { - // If the shift is 256 or more, the result depends on the sign of the last bit. - if op2.bit(255) { - U256::MAX // Negative number, all bits set to one. - } else { - U256::ZERO // Non-negative number, all bits set to zero. - } + *op2 = if shift < 256 { + op2.arithmetic_shr(shift) + } else if op2.bit(255) { + U256::MAX } else { - // Normal shift - if op2.bit(255) { - // Check the most significant bit. - // Arithmetic right shift for negative numbers. - let shifted_value = *op2 >> shift; - let mask = U256::MAX << (256 - shift); // Mask for the sign bits. - shifted_value | mask // Apply the mask to simulate the filling of sign bits. - } else { - // Logical right shift for non-negative numbers. - *op2 >> shift - } + U256::ZERO }; }