summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/PowerPC/PPCMachineFunctionInfo.cpp
diff options
context:
space:
mode:
authorHiroshi Inoue <inouehrs@jp.ibm.com>2017-10-16 04:12:57 +0000
committerHiroshi Inoue <inouehrs@jp.ibm.com>2017-10-16 04:12:57 +0000
commite3a3e3c9e9d3c81e530431be213857cd34eecb56 (patch)
tree2ee7cb124ec989fd64f92b0f4d8f336eb99fe462 /llvm/lib/Target/PowerPC/PPCMachineFunctionInfo.cpp
parentea8711b88e6c299b1abdb652b813f54f9340c23b (diff)
downloadbcm5719-llvm-e3a3e3c9e9d3c81e530431be213857cd34eecb56.tar.gz
bcm5719-llvm-e3a3e3c9e9d3c81e530431be213857cd34eecb56.zip
[PowerPC] Eliminate sign- and zero-extensions if already sign- or zero-extended
This patch enables redundant sign- and zero-extension elimination in PowerPC MI Peephole pass. If the input value of a sign- or zero-extension is known to be already sign- or zero-extended, the operation is redundant and can be eliminated. One common case is sign-extensions for a method parameter or for a method return value; they must be sign- or zero-extended as defined in PPC ELF ABI. For example of the following simple code, two extsw instructions are generated before the invocation of int_func and before the return. With this patch, both extsw are eliminated. void int_func(int); void ii_test(int a) { if (a & 1) return int_func(a); } Such redundant sign- or zero-extensions are quite common in many programs; e.g. I observed about 60,000 occurrences of the elimination while compiling the LLVM+CLANG. Differential Revision: https://reviews.llvm.org/D31319 llvm-svn: 315888
Diffstat (limited to 'llvm/lib/Target/PowerPC/PPCMachineFunctionInfo.cpp')
-rw-r--r--llvm/lib/Target/PowerPC/PPCMachineFunctionInfo.cpp14
1 files changed, 14 insertions, 0 deletions
diff --git a/llvm/lib/Target/PowerPC/PPCMachineFunctionInfo.cpp b/llvm/lib/Target/PowerPC/PPCMachineFunctionInfo.cpp
index bc2d9a08b5e..3923417257e 100644
--- a/llvm/lib/Target/PowerPC/PPCMachineFunctionInfo.cpp
+++ b/llvm/lib/Target/PowerPC/PPCMachineFunctionInfo.cpp
@@ -43,3 +43,17 @@ MCSymbol *PPCFunctionInfo::getTOCOffsetSymbol() const {
"func_toc" +
Twine(MF.getFunctionNumber()));
}
+
+bool PPCFunctionInfo::isLiveInSExt(unsigned VReg) const {
+ for (const std::pair<unsigned, ISD::ArgFlagsTy> &LiveIn : LiveInAttrs)
+ if (LiveIn.first == VReg)
+ return LiveIn.second.isSExt();
+ return false;
+}
+
+bool PPCFunctionInfo::isLiveInZExt(unsigned VReg) const {
+ for (const std::pair<unsigned, ISD::ArgFlagsTy> &LiveIn : LiveInAttrs)
+ if (LiveIn.first == VReg)
+ return LiveIn.second.isZExt();
+ return false;
+}
OpenPOWER on IntegriCloud