summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaDeclAttr.cpp
diff options
context:
space:
mode:
authorJessica Paquette <jpaquette@apple.com>2019-07-20 01:55:35 +0000
committerJessica Paquette <jpaquette@apple.com>2019-07-20 01:55:35 +0000
commit41affad967d48b8223dd8cfee254ee787b87a7e6 (patch)
tree7817950d7af9ac443fa7ef8b1811709c76f6ed25 /clang/lib/Sema/SemaDeclAttr.cpp
parent5204f7611f4ad6549921f9fa757823e77f39ce32 (diff)
downloadbcm5719-llvm-41affad967d48b8223dd8cfee254ee787b87a7e6.tar.gz
bcm5719-llvm-41affad967d48b8223dd8cfee254ee787b87a7e6.zip
[GlobalISel][AArch64] Contract trivial same-size cross-bank copies into G_STOREs
Sometimes, you can end up with cross-bank copies between same-sized GPRs and FPRs, which feed into G_STOREs. When these copies feed only into stores, they aren't necessary; we can just store using the original register bank. This provides some minor code size savings for some floating point SPEC benchmarks. (Around 0.2% for 453.povray and 450.soplex) This issue doesn't seem to show up due to regbankselect or anything similar. So, this patch introduces an early select function, `contractCrossBankCopyIntoStore` which performs the contraction when possible. The selector then continues normally and selects the correct store opcode, eliminating needless copies along the way. Differential Revision: https://reviews.llvm.org/D65024 llvm-svn: 366625
Diffstat (limited to 'clang/lib/Sema/SemaDeclAttr.cpp')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud