[llvm] r229258 - [optnone] Skip pass Constant Hoisting on optnone functions.

Andrea Di Biagio Andrea_DiBiagio at sn.scee.net
Sat Feb 14 07:11:49 PST 2015


Author: adibiagio
Date: Sat Feb 14 09:11:48 2015
New Revision: 229258

URL: http://llvm.org/viewvc/llvm-project?rev=229258&view=rev
Log:
[optnone] Skip pass Constant Hoisting on optnone functions.

Added test CodeGen/X86/constant-hoisting-optnone.ll to verify that
pass Constant Hoisting is not run on optnone functions.

Added:
    llvm/trunk/test/CodeGen/X86/constant-hoisting-optnone.ll
Modified:
    llvm/trunk/lib/Transforms/Scalar/ConstantHoisting.cpp

Modified: llvm/trunk/lib/Transforms/Scalar/ConstantHoisting.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Scalar/ConstantHoisting.cpp?rev=229258&r1=229257&r2=229258&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/Scalar/ConstantHoisting.cpp (original)
+++ llvm/trunk/lib/Transforms/Scalar/ConstantHoisting.cpp Sat Feb 14 09:11:48 2015
@@ -186,6 +186,9 @@ FunctionPass *llvm::createConstantHoisti
 
 /// \brief Perform the constant hoisting optimization for the given function.
 bool ConstantHoisting::runOnFunction(Function &Fn) {
+  if (skipOptnoneFunction(Fn))
+    return false;
+
   DEBUG(dbgs() << "********** Begin Constant Hoisting **********\n");
   DEBUG(dbgs() << "********** Function: " << Fn.getName() << '\n');
 

Added: llvm/trunk/test/CodeGen/X86/constant-hoisting-optnone.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/X86/constant-hoisting-optnone.ll?rev=229258&view=auto
==============================================================================
--- llvm/trunk/test/CodeGen/X86/constant-hoisting-optnone.ll (added)
+++ llvm/trunk/test/CodeGen/X86/constant-hoisting-optnone.ll Sat Feb 14 09:11:48 2015
@@ -0,0 +1,21 @@
+; RUN: llc < %s -mtriple=x86_64-unknown-unknown -mcpu=generic | FileCheck %s
+;
+; Verify that pass 'Constant Hoisting' is not run on optnone functions.
+; Without optnone, Pass 'Constant Hoisting' would firstly hoist
+; constant 0xBEEBEEBEC, and then rebase the other constant
+; (i.e. constant 0xBEEBEEBF4) with respect to the previous one.
+; With optnone, we check that constants are not coalesced.
+
+define i64 @constant_hoisting_optnone() #0 {
+; CHECK-LABEL: @constant_hoisting_optnone
+; CHECK-DAG: movabsq {{.*#+}} imm = 0xBEEBEEBF4
+; CHECK-DAG: movabsq {{.*#+}} imm = 0xBEEBEEBEC
+; CHECK: ret
+entry:
+  %0 = load i64* inttoptr (i64 51250129900 to i64*)
+  %1 = load i64* inttoptr (i64 51250129908 to i64*)
+  %2 = add i64 %0, %1
+  ret i64 %2
+}
+
+attributes #0 = { optnone noinline }





More information about the llvm-commits mailing list