[PATCH] D68247: [X86] Add a DAG combine to shrink vXi64 gather/scatter indices that are constant with sufficient sign bits to fit in vXi32
Craig Topper via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Oct 1 08:44:09 PDT 2019
craig.topper marked an inline comment as done.
craig.topper added inline comments.
================
Comment at: llvm/lib/Target/X86/X86ISelLowering.cpp:42384
+ if (DCI.isBeforeLegalize()) {
+ if (auto *BV = dyn_cast<BuildVectorSDNode>(Index)) {
+ unsigned IndexWidth = Index.getScalarValueSizeInBits();
----------------
RKSimon wrote:
> Does it have to be build vector? General truncations should be pretty good in these cases whatever.
No. I guess you could truncate anytime the index element is wider than the data element and the index type isn't legal and is a type that needs to be split or a type that will be widened to a type that will be split. You wouldn't want to truncate if it won't prevent a split since you'd just be adding more code. Unless it was sext/zext which would be removed, but that's already handled below. Is that what you were thinking?
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D68247/new/
https://reviews.llvm.org/D68247
More information about the llvm-commits
mailing list