aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/CodeGen/AssignmentTrackingAnalysis.cpp
diff options
context:
space:
mode:
authorDavid Green <david.green@arm.com>2023-03-29 14:17:10 +0100
committerDavid Green <david.green@arm.com>2023-03-29 14:17:10 +0100
commiteb64450afc96730f9a6ff87c817c34185a307a0f (patch)
tree56968f80ec5c0428f0bac997d62a3d939c2cee4a /llvm/lib/CodeGen/AssignmentTrackingAnalysis.cpp
parentac269d185c38ceadfff38c1573334b8d3415f56a (diff)
downloadllvm-eb64450afc96730f9a6ff87c817c34185a307a0f.zip
llvm-eb64450afc96730f9a6ff87c817c34185a307a0f.tar.gz
llvm-eb64450afc96730f9a6ff87c817c34185a307a0f.tar.bz2
[ARM] Convert active.lane.masks to vctp with non-zero starts
This attempts to expand the logic in the MVETailPredication pass to convert active lane masks that the vectorizer produces to vctp instructions that the backend can later turn into tail predicated loops. Especially for addrecs with non-zero starts that can be created from epilog vectorization. There is some adjustment to the logic to handle this, moving some of the code to check the addrec earlier so that we can get the start value. This start value is then incorporated into the logic of checkin the new vctp is valid, and there is a newly added check that it is known to be a multiple of the VF as we expect. Differential Revision: https://reviews.llvm.org/D146517
Diffstat (limited to 'llvm/lib/CodeGen/AssignmentTrackingAnalysis.cpp')
0 files changed, 0 insertions, 0 deletions