Skip to content

Commit

Permalink
Fixing vsel.
Browse files Browse the repository at this point in the history
  • Loading branch information
benvanik committed Sep 1, 2014
1 parent d30483b commit 080a0f8
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 5 deletions.
29 changes: 27 additions & 2 deletions src/alloy/backend/x64/x64_sequences.cc
Original file line number Diff line number Diff line change
Expand Up @@ -1913,7 +1913,7 @@ EMITTER(SELECT_F64, MATCH(I<OPCODE_SELECT, F64<>, I8<>, F64<>, F64<>>)) {
e.vpor(i.dest, e.xmm1);
}
};
EMITTER(SELECT_V128, MATCH(I<OPCODE_SELECT, V128<>, I8<>, V128<>, V128<>>)) {
EMITTER(SELECT_V128_I8, MATCH(I<OPCODE_SELECT, V128<>, I8<>, V128<>, V128<>>)) {
static void Emit(X64Emitter& e, const EmitArgType& i) {
// TODO(benvanik): find a shorter sequence.
// xmm0 = src1 != 0 ? 1111... : 0000....
Expand All @@ -1927,6 +1927,30 @@ EMITTER(SELECT_V128, MATCH(I<OPCODE_SELECT, V128<>, I8<>, V128<>, V128<>>)) {
e.vpor(i.dest, e.xmm1);
}
};
EMITTER(SELECT_V128_V128, MATCH(I<OPCODE_SELECT, V128<>, V128<>, V128<>, V128<>>)) {
static void Emit(X64Emitter& e, const EmitArgType& i) {
// TODO(benvanik): could be made shorter when consts involved.
if (i.src2.is_constant) {
if (i.src2.value->IsConstantZero()) {
e.vpxor(e.xmm1, e.xmm1);
} else {
assert_always();
}
} else {
e.vpandn(e.xmm1, i.src1, i.src2);
}
if (i.src3.is_constant) {
if (i.src3.value->IsConstantZero()) {
e.vpxor(i.dest, i.dest);
} else {
assert_always();
}
} else {
e.vpand(i.dest, i.src1, i.src3);
}
e.vpor(i.dest, e.xmm1);
}
};
EMITTER_OPCODE_TABLE(
OPCODE_SELECT,
SELECT_I8,
Expand All @@ -1935,7 +1959,8 @@ EMITTER_OPCODE_TABLE(
SELECT_I64,
SELECT_F32,
SELECT_F64,
SELECT_V128);
SELECT_V128_I8,
SELECT_V128_V128);


// ============================================================================
Expand Down
3 changes: 1 addition & 2 deletions src/alloy/frontend/ppc/ppc_emit_altivec.cc
Original file line number Diff line number Diff line change
Expand Up @@ -1332,8 +1332,7 @@ XEEMITTER(vrsqrtefp128, VX128_3(6, 1648), VX128_3)(PPCHIRBuilder& f,

int InstrEmit_vsel_(PPCHIRBuilder& f, uint32_t vd, uint32_t va, uint32_t vb,
uint32_t vc) {
Value* c = f.LoadVR(vc);
Value* v = f.Or(f.And(f.LoadVR(va), f.Not(c)), f.And(f.LoadVR(vb), c));
Value* v = f.Select(f.LoadVR(vc), f.LoadVR(va), f.LoadVR(vb));
f.StoreVR(vd, v);
return 0;
}
Expand Down
2 changes: 1 addition & 1 deletion src/alloy/hir/hir_builder.cc
Original file line number Diff line number Diff line change
Expand Up @@ -1182,7 +1182,7 @@ Value* HIRBuilder::VectorMin(Value* value1, Value* value2, TypeName part_type,
}

Value* HIRBuilder::Select(Value* cond, Value* value1, Value* value2) {
assert_true(cond->type == INT8_TYPE); // for now
assert_true(cond->type == INT8_TYPE || cond->type == VEC128_TYPE); // for now
ASSERT_TYPES_EQUAL(value1, value2);

if (cond->IsConstant()) {
Expand Down

0 comments on commit 080a0f8

Please sign in to comment.