Details
- Reviewers
spatel
Diff Detail
Event Timeline
I think this is the right change for IR (I'm trying to do something similar with D50992 but that's been held up while we try to get the backend in shape). .
- I see that the new code is copying the existing handling of binops around line 315, but can we update this to use 'match()' and reduce the duplication?
- There should be a test that shows the benefit of using 'isCheapToScalarize()'. IIUC, that would involve a sequence with multiple binops and/or compares between an insertelement and the trailing extract.
- Please commit the tests with baseline checks as a preliminary commit, so we only show the diffs in this patch.
I don't think there's much of a useful way to combine this with the BinOp handling. At most it's going to share the pair of extracts, and would require more ugly code when creating the new operation so I think it would be overall worse
I added a binop test like this here:
rL348417
...and it shows a missed opportunity. AFAICT, there was no test coverage for anything beyond the simplest cases for isCheapToScalarize(), so please do add something like that for cmp.
Also, I used 'match' to reduce the binop code:
rL348418
cmp should be similar:
Value *X, *Y; CmpInst::Predicate Pred; if (match(SrcVec, m_Cmp(Pred, m_Value(X), m_Value(Y))) && cheapToScalarize(SrcVec, IndexC)) { // extelt (cmp X, Y), Index --> cmp (extelt X, Index), (extelt Y, Index) Value *E0 = Builder.CreateExtractElement(X, Index); Value *E1 = Builder.CreateExtractElement(Y, Index); return CmpInst::Create(cast<CmpInst>(SrcVec)->getOpcode(), Pred, E0, E1); }
LGTM - but I think there's a bug in cheapToScalarize() that I didn't notice before. Please put a FIXME note in there.
test/Transforms/InstCombine/scalarization.ll | ||
---|---|---|
86–87 | This doesn't look right to start with. I don't think we can justify leaving more instructions than we started with as a target-independent combine. |
This doesn't look right to start with. I don't think we can justify leaving more instructions than we started with as a target-independent combine.