[mips][mips16] MIPS16 is not a CPU/Architecture but is an ASE.
[oota-llvm.git] / test / CodeGen / Mips / ex2.ll
1 ; RUN: llc  -march=mipsel -mattr=mips16 -relocation-model=pic -O3 < %s | FileCheck %s -check-prefix=16
2
3 @.str = private unnamed_addr constant [6 x i8] c"hello\00", align 1
4 @_ZTIPKc = external constant i8*
5
6 define i32 @main() {
7 ; 16-LABEL: main:
8 ; 16:   .cfi_startproc
9 ; 16:   save    $16, $17, $ra, 32 # 16 bit inst
10 ; 16:   .cfi_def_cfa_offset 32
11 ; 16:   .cfi_offset 31, -4
12 ; 16:   .cfi_offset 17, -8
13 ; 16:   .cfi_offset 16, -12
14 ; 16:   .cfi_endproc
15 entry:
16   %retval = alloca i32, align 4
17   store i32 0, i32* %retval
18   %exception = call i8* @__cxa_allocate_exception(i32 4) nounwind
19   %0 = bitcast i8* %exception to i8**
20   store i8* getelementptr inbounds ([6 x i8], [6 x i8]* @.str, i32 0, i32 0), i8** %0
21   call void @__cxa_throw(i8* %exception, i8* bitcast (i8** @_ZTIPKc to i8*), i8* null) noreturn
22   unreachable
23
24 return:                                           ; No predecessors!
25   %1 = load i32, i32* %retval
26   ret i32 %1
27 }
28
29 declare i8* @__cxa_allocate_exception(i32)
30
31 declare void @__cxa_throw(i8*, i8*, i8*)