Instcombine shouldn't fold these casts.
authorChris Lattner <sabre@nondot.org>
Tue, 5 Dec 2006 23:43:20 +0000 (23:43 +0000)
committerChris Lattner <sabre@nondot.org>
Tue, 5 Dec 2006 23:43:20 +0000 (23:43 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@32243 91177308-0d34-0410-b5e6-96231b3b80d8

test/Transforms/InstCombine/2006-12-05-fp-to-int-ext.ll [new file with mode: 0644]

diff --git a/test/Transforms/InstCombine/2006-12-05-fp-to-int-ext.ll b/test/Transforms/InstCombine/2006-12-05-fp-to-int-ext.ll
new file mode 100644 (file)
index 0000000..ca552a5
--- /dev/null
@@ -0,0 +1,13 @@
+; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep zext
+
+; Never merge these two conversions, even though it's possible: this is
+; significantly more expensive than the two conversions on some targets
+; and it causes libgcc to be compile __fixunsdfdi into a recursive 
+; function.
+
+
+long %test(double %D) {
+       %A = fptoui double %D to uint
+       %B = zext uint %A to long
+       ret long %B
+}