summaryrefslogtreecommitdiff
path: root/test/Transforms/MergeFunc
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2013-01-10 23:22:53 +0000
committerEvan Cheng <evan.cheng@apple.com>2013-01-10 23:22:53 +0000
commit582e4f278b95d50a45c6f56e33da5e78c19afc17 (patch)
tree40554ee8f36be2e6a9d9982303424bcf10e2d4e0 /test/Transforms/MergeFunc
parent0e4776ce61092e34ac2340c60534cbed29aba87b (diff)
downloadllvm-582e4f278b95d50a45c6f56e33da5e78c19afc17.tar.gz
llvm-582e4f278b95d50a45c6f56e33da5e78c19afc17.tar.bz2
llvm-582e4f278b95d50a45c6f56e33da5e78c19afc17.tar.xz
CastInst::castIsValid should return true if the dest type is the same as
Value's current type. The casting is trivial even for aggregate type. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@172143 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Transforms/MergeFunc')
-rw-r--r--test/Transforms/MergeFunc/2013-01-10-MergeFuncAssert.ll36
1 files changed, 36 insertions, 0 deletions
diff --git a/test/Transforms/MergeFunc/2013-01-10-MergeFuncAssert.ll b/test/Transforms/MergeFunc/2013-01-10-MergeFuncAssert.ll
new file mode 100644
index 0000000000..3f6a5ba157
--- /dev/null
+++ b/test/Transforms/MergeFunc/2013-01-10-MergeFuncAssert.ll
@@ -0,0 +1,36 @@
+; RUN: opt -mergefunc -disable-output < %s
+; This used to trigger a ConstantExpr::getBitCast assertion.
+
+define void @t1() unnamed_addr uwtable ssp align 2 {
+entry:
+ switch i32 undef, label %sw.bb12 [
+ i32 127, label %sw.bb
+ i32 126, label %sw.bb4
+ ]
+
+sw.bb: ; preds = %entry
+ unreachable
+
+sw.bb4: ; preds = %entry
+ unreachable
+
+sw.bb12: ; preds = %entry
+ ret void
+}
+
+define void @t2() unnamed_addr uwtable ssp align 2 {
+entry:
+ switch i32 undef, label %sw.bb8 [
+ i32 4, label %sw.bb
+ i32 3, label %sw.bb4
+ ]
+
+sw.bb: ; preds = %entry
+ unreachable
+
+sw.bb4: ; preds = %entry
+ ret void
+
+sw.bb8: ; preds = %entry
+ unreachable
+}