/* Check the result of a ternary operation. */ static void check_result_for_ternary(const irop_t *op, const test_data_t *data) { const opnd_t *result = &data->result; const opnd_t *opnd1 = &data->opnds[0]; const opnd_t *opnd2 = &data->opnds[1]; const opnd_t *opnd3 = &data->opnds[2]; vbits_t expected_vbits; /* Only handle those undef-kinds that actually occur. */ switch (op->undef_kind) { case UNDEF_ALL: expected_vbits = undefined_vbits(result->vbits.num_bits); break; case UNDEF_SAME: // SAME with respect to the 1-bits in all operands expected_vbits = or_vbits(or_vbits(opnd1->vbits, opnd2->vbits), opnd3->vbits); break; default: panic(__func__); } if (! equal_vbits(result->vbits, expected_vbits)) complain(op, data, expected_vbits); }
/* Check the result of a ternary operation. */ static void check_result_for_ternary(const irop_t *op, const test_data_t *data) { const opnd_t *result = &data->result; const opnd_t *opnd1 = &data->opnds[0]; const opnd_t *opnd2 = &data->opnds[1]; const opnd_t *opnd3 = &data->opnds[2]; vbits_t expected_vbits; /* Only handle those undef-kinds that actually occur. */ switch (op->undef_kind) { case UNDEF_ALL: expected_vbits = undefined_vbits(result->vbits.num_bits); break; case UNDEF_SAME: // SAME with respect to the 1-bits in all operands expected_vbits = or_vbits(or_vbits(opnd1->vbits, opnd2->vbits), opnd3->vbits); break; case UNDEF_SOME: expected_vbits.num_bits = result->vbits.num_bits; if ((result->vbits.bits.u128[0] != 0) || (result->vbits.bits.u128[1] != 0)) { expected_vbits.bits.u128[0] = result->vbits.bits.u128[0]; expected_vbits.bits.u128[1] = result->vbits.bits.u128[1]; } else { /* The input had at least one vbit set but the result doesn't have any * bit set. Set them all so we will trigger the error on the call * to complain(). */ expected_vbits.bits.u128[0] = ~0x0ULL; expected_vbits.bits.u128[1] = ~0x0ULL; } break; default: panic(__func__); } if (! equal_vbits(result->vbits, expected_vbits)) complain(op, data, expected_vbits); }