summaryrefslogtreecommitdiff
path: root/rtl/core/shifter.sv
diff options
context:
space:
mode:
Diffstat (limited to 'rtl/core/shifter.sv')
-rw-r--r--rtl/core/shifter.sv2
1 files changed, 1 insertions, 1 deletions
diff --git a/rtl/core/shifter.sv b/rtl/core/shifter.sv
index 994e76c..2b5739d 100644
--- a/rtl/core/shifter.sv
+++ b/rtl/core/shifter.sv
@@ -20,7 +20,7 @@ module core_shifter
assign sign_mask = {(W + 1){ctrl.sign_extend & base[W - 1]}};
assign {c_shl, q_shl} = {c_in, base} << shift;
- assign {q_shr, c_shr} = {base, c_in} >> shift | ~(sign_mask >> shift);
+ assign {q_shr, c_shr} = {base, c_in} >> shift | (sign_mask & ~(sign_mask >> shift));
logic ror_cycle;
logic[LOG - 1:0] ror_shift;