Merge the two conditions, sign != 0 && !(z_mask & sign),
by testing ~z_mask & sign. If sign == 0, the logical and
will produce false.
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
static bool fold_shift(OptContext *ctx, TCGOp *op)
{
- uint64_t s_mask, z_mask, sign;
+ uint64_t s_mask, z_mask;
TempOptInfo *t1, *t2;
if (fold_const2(ctx, op) ||
* If the sign bit is known zero, then logical right shift
* will not reduce the number of input sign repetitions.
*/
- sign = -s_mask;
- if (sign && !(z_mask & sign)) {
+ if (~z_mask & -s_mask) {
return fold_masks_s(ctx, op, s_mask);
}
break;