summaryrefslogtreecommitdiff
path: root/test/CodeGen/Mips/ex2.ll
diff options
context:
space:
mode:
authorReed Kotler <rkotler@mips.com>2012-12-21 00:55:10 +0000
committerReed Kotler <rkotler@mips.com>2012-12-21 00:55:10 +0000
commite30843ded90f9f7b22cc8dfa352922047ffedcc6 (patch)
tree9d52d935fcb0887712963f5edf3888a8d5209968 /test/CodeGen/Mips/ex2.ll
parenta40ba2b3b2c909c366e5479d4e51ed35a0ada934 (diff)
downloadllvm-e30843ded90f9f7b22cc8dfa352922047ffedcc6.tar.gz
llvm-e30843ded90f9f7b22cc8dfa352922047ffedcc6.tar.bz2
llvm-e30843ded90f9f7b22cc8dfa352922047ffedcc6.tar.xz
Add test case for r170674
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@170823 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/CodeGen/Mips/ex2.ll')
-rw-r--r--test/CodeGen/Mips/ex2.ll29
1 files changed, 29 insertions, 0 deletions
diff --git a/test/CodeGen/Mips/ex2.ll b/test/CodeGen/Mips/ex2.ll
new file mode 100644
index 0000000000..67d19e4b84
--- /dev/null
+++ b/test/CodeGen/Mips/ex2.ll
@@ -0,0 +1,29 @@
+; RUN: llc -march=mipsel -mcpu=mips16 -relocation-model=pic -O3 < %s | FileCheck %s -check-prefix=16
+
+@.str = private unnamed_addr constant [6 x i8] c"hello\00", align 1
+@_ZTIPKc = external constant i8*
+
+define i32 @main() {
+; 16: main:
+; 16: .cfi_startproc
+; 16: save $ra, $s0, $s1, 32
+; 16: .cfi_offset 17, -8
+; 16: .cfi_offset 16, -12
+; 16: .cfi_offset 31, -4
+entry:
+ %retval = alloca i32, align 4
+ store i32 0, i32* %retval
+ %exception = call i8* @__cxa_allocate_exception(i32 4) nounwind
+ %0 = bitcast i8* %exception to i8**
+ store i8* getelementptr inbounds ([6 x i8]* @.str, i32 0, i32 0), i8** %0
+ call void @__cxa_throw(i8* %exception, i8* bitcast (i8** @_ZTIPKc to i8*), i8* null) noreturn
+ unreachable
+
+return: ; No predecessors!
+ %1 = load i32* %retval
+ ret i32 %1
+}
+
+declare i8* @__cxa_allocate_exception(i32)
+
+declare void @__cxa_throw(i8*, i8*, i8*)