diff options
author | Chandler Carruth <chandlerc@gmail.com> | 2012-04-07 20:01:31 +0000 |
---|---|---|
committer | Chandler Carruth <chandlerc@gmail.com> | 2012-04-07 20:01:31 +0000 |
commit | 75a1cf327a96f1b1ea9a033a1d80fd49830ddaac (patch) | |
tree | 8aaf3b7974f0f58954bdaa7e9b3dfb99f7258735 /llvm/lib/CodeGen/BranchFolding.cpp | |
parent | 28192c93980948293b7b2570154faca9ef30d892 (diff) | |
download | bcm5719-llvm-75a1cf327a96f1b1ea9a033a1d80fd49830ddaac.tar.gz bcm5719-llvm-75a1cf327a96f1b1ea9a033a1d80fd49830ddaac.zip |
Perform partial SROA on the helper hashing structure. I really wish the
optimizers could do this for us, but expecting partial SROA of classes
with template methods through cloning is probably expecting too much
heroics. With this change, the begin/end pointer pairs which indicate
the status of each loop iteration are actually passed directly into each
layer of the combine_data calls, and the inliner has a chance to see
when most of the combine_data function could be deleted by inlining.
Similarly for 'length'.
We have to be careful to limit the places where in/out reference
parameters are used as those will also defeat the inliner / optimizers
from properly propagating constants.
With this change, LLVM is able to fully inline and unroll the hash
computation of small sets of values, such as two or three pointers.
These now decompose into essentially straight-line code with no loops or
function calls.
There is still one code quality problem to be solved with the hashing --
LLVM is failing to nuke the alloca. It removes all loads from the
alloca, leaving only lifetime intrinsics and dead(!!) stores to the
alloca. =/ Very unfortunate.
llvm-svn: 154264
Diffstat (limited to 'llvm/lib/CodeGen/BranchFolding.cpp')
0 files changed, 0 insertions, 0 deletions