summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--test/Transforms/ConstantHoisting/X86/large-immediate-2.ll6
1 files changed, 4 insertions, 2 deletions
diff --git a/test/Transforms/ConstantHoisting/X86/large-immediate-2.ll b/test/Transforms/ConstantHoisting/X86/large-immediate-2.ll
index 5f23e0a329..883be355bd 100644
--- a/test/Transforms/ConstantHoisting/X86/large-immediate-2.ll
+++ b/test/Transforms/ConstantHoisting/X86/large-immediate-2.ll
@@ -1,8 +1,10 @@
; RUN: llc < %s -O3 -march=x86-64 |FileCheck %s
define i64 @foo(i1 %z, i192* %p, i192* %q)
{
-; CHECK: movq 16(%rsi), %rax
-; CHECK-NEXT: retq
+; If const 128 is hoisted to a variable, then in basic block L_val2 we would
+; have %lshr2 = lshr i192 %data2, %const, and the definition of %const would
+; be in another basic block. As a result, a very inefficient code might be
+; produced. Here we check that this doesn't occur.
entry:
%data1 = load i192* %p, align 8
%lshr1 = lshr i192 %data1, 128