summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--test/CodeGen/X86/2004-04-09-SameValueCoalescing.llx19
1 files changed, 19 insertions, 0 deletions
diff --git a/test/CodeGen/X86/2004-04-09-SameValueCoalescing.llx b/test/CodeGen/X86/2004-04-09-SameValueCoalescing.llx
new file mode 100644
index 0000000..70ebc23
--- /dev/null
+++ b/test/CodeGen/X86/2004-04-09-SameValueCoalescing.llx
@@ -0,0 +1,19 @@
+; Linear scan does not currently coalesce any two variables that have
+; overlapping live intervals. When two overlapping intervals have the same
+; value, they can be joined though.
+;
+; RUN: llvm-as < %s | llc -march=x86 -regalloc=linearscan | not grep 'mov %[A-Z]\{2,3\}, %[A-Z]\{2,3\}'
+
+int %main() {
+ %ptr = alloca uint
+ br label %Loop
+Loop:
+ %I = phi int [0, %0], [%i2, %Loop]
+ %i2 = add int %I, 1
+ %i3 = cast int %i2 to uint
+ store uint %i3, uint* %ptr
+ %C = seteq int %i2, 10
+ br bool %C, label %Out, label %Loop
+Out:
+ ret int 0
+}