summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorVasileios Porpodas <vasileios.porpodas@intel.com>2019-08-16 17:21:18 +0000
committerVasileios Porpodas <vasileios.porpodas@intel.com>2019-08-16 17:21:18 +0000
commit1d254f3dae64c061ff5206366fd1dc948911b873 (patch)
tree062e11295d55fc94aab9c4ef5b86a9a33c82dc0b /clang
parent7e106445efddf4bc2f4c2cb0c798f51c6773def0 (diff)
downloadbcm5719-llvm-1d254f3dae64c061ff5206366fd1dc948911b873.tar.gz
bcm5719-llvm-1d254f3dae64c061ff5206366fd1dc948911b873.zip
[SLPVectorizer] Make the scheduler aware of the TreeEntry operands.
Summary: The scheduler's dependence graph gets the use-def dependencies by accessing the operands of the instructions in a bundle. However, buildTree_rec() may change the order of the operands in TreeEntry, and the scheduler is currently not aware of this. This is not causing any functional issues currently, because reordering is restricted to the operands of a single instruction. Once we support operand reordering across multiple TreeEntries, as shown here: http://www.llvm.org/devmtg/2019-04/slides/Poster-Porpodas-Supernode_SLP.pdf , the scheduler will need to get the correct operands from TreeEntry and not from the individual instructions. In short, this patch: - Connects the scheduler's bundle with the corresponding TreeEntry. It introduces new TE and Lane fields in ScheduleData. - Moves the location where the operands of the TreeEntry are initialized. This used to take place in newTreeEntry() setting one operand at a time, but is now moved pre-order just before the recursion of buildTree_rec(). This is required because the scheduler needs to access both operands of the TreeEntry in tryScheduleBundle(). - Updates the scheduler to access the instruction operands through the TreeEntry operands instead of accessing the instruction operands directly. Reviewers: ABataev, RKSimon, dtemirbulatov, Ayal, dorit, hfinkel Reviewed By: ABataev Subscribers: hiraditya, llvm-commits, lebedev.ri, rcorcs Tags: #llvm Differential Revision: https://reviews.llvm.org/D62432 llvm-svn: 369131
Diffstat (limited to 'clang')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud