New testcase for bug found by Vikram
authorChris Lattner <sabre@nondot.org>
Thu, 2 May 2002 16:16:39 +0000 (16:16 +0000)
committerChris Lattner <sabre@nondot.org>
Thu, 2 May 2002 16:16:39 +0000 (16:16 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2426 91177308-0d34-0410-b5e6-96231b3b80d8

test/Transforms/LevelRaise/2002-05-02-BadCastElimination.ll [new file with mode: 0644]

diff --git a/test/Transforms/LevelRaise/2002-05-02-BadCastElimination.ll b/test/Transforms/LevelRaise/2002-05-02-BadCastElimination.ll
new file mode 100644 (file)
index 0000000..d78a946
--- /dev/null
@@ -0,0 +1,24 @@
+; This test contains two cast instructions that cannot be eliminated.  If the
+; input of the "test" function is negative, it should be correctly converted
+; to a 32 bit version of the number with all upper 16 bits clear (ushort->uint
+; involves no sign extension).  Optimizing this to a single cast is invalid!
+;
+; RUN: as < %s | opt -raise -q | lli -abort-on-exception
+;
+implementation
+
+uint "test"(short %argc)
+begin
+       %cast223 = cast short %argc to ushort           ; <ushort> [#uses=1]
+       %cast114 = cast ushort %cast223 to uint         ; <uint> [#uses=1]
+       ret uint %cast114
+end
+
+int "main"()
+begin
+       %Ret = call uint %test(short -1)
+       %test = cast uint %Ret to int
+       %Res = seteq int %test, -1        ; If it returns -1 as int, it's a failure
+       %Res = cast bool %Res to int
+       ret int %Res
+end