|  | ; 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-LABEL: main: | 
|  | ; 16: 	.cfi_startproc | 
|  | ; 16: 	save	$16, $17, $ra, 32 # 16 bit inst | 
|  | ; 16:   .cfi_def_cfa_offset 32 | 
|  | ; 16: 	.cfi_offset 31, -4 | 
|  | ; 16: 	.cfi_offset 17, -8 | 
|  | ; 16:   .cfi_offset 16, -12 | 
|  | ; 16:   .cfi_endproc | 
|  | 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], [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, i32* %retval | 
|  | ret i32 %1 | 
|  | } | 
|  |  | 
|  | declare i8* @__cxa_allocate_exception(i32) | 
|  |  | 
|  | declare void @__cxa_throw(i8*, i8*, i8*) |