summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/BranchFolding.cpp
diff options
context:
space:
mode:
authorChandler Carruth <chandlerc@gmail.com>2012-04-07 20:01:31 +0000
committerChandler Carruth <chandlerc@gmail.com>2012-04-07 20:01:31 +0000
commit75a1cf327a96f1b1ea9a033a1d80fd49830ddaac (patch)
tree8aaf3b7974f0f58954bdaa7e9b3dfb99f7258735 /llvm/lib/CodeGen/BranchFolding.cpp
parent28192c93980948293b7b2570154faca9ef30d892 (diff)
downloadbcm5719-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
OpenPOWER on IntegriCloud