Daniel Sanders | 5dcbac5 | 2016-08-04 15:36:03 +0000 | [diff] [blame] | 1 | ; RUN: llc -mtriple=mipsel-linux-gnu < %s -asm-verbose -relocation-model=pic | \ |
| 2 | ; RUN: FileCheck -check-prefixes=ALL,LINUX,LINUX-O32,O32 %s |
| 3 | ; RUN: llc -mtriple=mipsel-linux-android < %s -asm-verbose -relocation-model=pic | \ |
| 4 | ; RUN: FileCheck -check-prefixes=ALL,LINUX,LINUX-O32,O32 %s |
| 5 | ; RUN: llc -mtriple=mips64el-linux-gnu -target-abi=n32 < %s -asm-verbose -relocation-model=pic | \ |
| 6 | ; RUN: FileCheck -check-prefixes=ALL,LINUX,LINUX-N32,N32 %s |
Daniel Sanders | 5dcbac5 | 2016-08-04 15:36:03 +0000 | [diff] [blame] | 7 | ; RUN: llc -mtriple=mips64el-linux-gnu < %s -asm-verbose -relocation-model=pic | \ |
| 8 | ; RUN: FileCheck -check-prefixes=ALL,LINUX,LINUX-N64,N64 %s |
| 9 | ; RUN: llc -mtriple=mips64el-linux-android < %s -asm-verbose -relocation-model=pic | \ |
| 10 | ; RUN: FileCheck -check-prefixes=ALL,LINUX,LINUX-N64,N64 %s |
| 11 | ; RUN: llc -mtriple=mips64el-linux-gnu < %s -asm-verbose -relocation-model=pic | \ |
| 12 | ; RUN: FileCheck -check-prefixes=ALL,LINUX,LINUX-N64,N64 %s |
| 13 | ; RUN: llc -mtriple=mips64-unknown-freebsd11.0 < %s -asm-verbose -relocation-model=pic | \ |
| 14 | ; RUN: FileCheck -check-prefixes=ALL,FREEBSD,FREEBSD-N64,N64 %s |
Daniel Sanders | c95f3f8 | 2015-06-02 20:32:50 +0000 | [diff] [blame] | 15 | |
| 16 | @_ZTISt9exception = external constant i8* |
Logan Chien | c002981 | 2014-05-30 16:48:56 +0000 | [diff] [blame] | 17 | |
David Majnemer | 7fddecc | 2015-06-17 20:52:32 +0000 | [diff] [blame] | 18 | define i32 @main() personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*) { |
Daniel Sanders | 196390e | 2015-05-20 13:19:19 +0000 | [diff] [blame] | 19 | ; ALL: .cfi_startproc |
Daniel Sanders | 5dcbac5 | 2016-08-04 15:36:03 +0000 | [diff] [blame] | 20 | |
| 21 | ; Linux must rely on the assembler/linker converting the encodings. |
| 22 | ; LINUX: .cfi_personality 128, DW.ref.__gxx_personality_v0 |
| 23 | ; LINUX-O32: .cfi_lsda 0, $exception0 |
| 24 | ; LINUX-NEW: .cfi_lsda 0, .Lexception0 |
| 25 | |
| 26 | ; FreeBSD can (and must) be more direct about the encodings it wants. |
| 27 | ; FREEBSD: .cfi_personality 155, DW.ref.__gxx_personality_v0 |
| 28 | ; FREEBSD-O32: .cfi_lsda 27, $exception0 |
| 29 | ; FREEBSD-NEW: .cfi_lsda 27, .Lexception0 |
Logan Chien | c002981 | 2014-05-30 16:48:56 +0000 | [diff] [blame] | 30 | |
| 31 | entry: |
| 32 | invoke void @foo() to label %cont unwind label %lpad |
Daniel Sanders | 196390e | 2015-05-20 13:19:19 +0000 | [diff] [blame] | 33 | ; ALL: foo |
| 34 | ; ALL: jalr |
Logan Chien | c002981 | 2014-05-30 16:48:56 +0000 | [diff] [blame] | 35 | |
| 36 | lpad: |
David Majnemer | 7fddecc | 2015-06-17 20:52:32 +0000 | [diff] [blame] | 37 | %0 = landingpad { i8*, i32 } |
Daniel Sanders | c95f3f8 | 2015-06-02 20:32:50 +0000 | [diff] [blame] | 38 | catch i8* null |
| 39 | catch i8* bitcast (i8** @_ZTISt9exception to i8*) |
Logan Chien | c002981 | 2014-05-30 16:48:56 +0000 | [diff] [blame] | 40 | ret i32 0 |
| 41 | |
| 42 | cont: |
| 43 | ret i32 0 |
| 44 | } |
Daniel Sanders | 196390e | 2015-05-20 13:19:19 +0000 | [diff] [blame] | 45 | ; ALL: .cfi_endproc |
Logan Chien | c002981 | 2014-05-30 16:48:56 +0000 | [diff] [blame] | 46 | |
| 47 | declare i32 @__gxx_personality_v0(...) |
| 48 | |
| 49 | declare void @foo() |
| 50 | |
Daniel Sanders | c95f3f8 | 2015-06-02 20:32:50 +0000 | [diff] [blame] | 51 | ; ALL: GCC_except_table{{[0-9]+}}: |
| 52 | ; ALL: .byte 155 # @TType Encoding = indirect pcrel sdata4 |
Daniel Sanders | 6a73883 | 2016-07-19 10:49:03 +0000 | [diff] [blame] | 53 | ; O32: [[PC_LABEL:\$tmp[0-9]+]]: |
| 54 | ; N32: [[PC_LABEL:\.Ltmp[0-9]+]]: |
| 55 | ; N64: [[PC_LABEL:\.Ltmp[0-9]+]]: |
| 56 | ; O32: .4byte ($_ZTISt9exception.DW.stub)-([[PC_LABEL]]) |
| 57 | ; N32: .4byte .L_ZTISt9exception.DW.stub-[[PC_LABEL]] |
| 58 | ; N64: .4byte .L_ZTISt9exception.DW.stub-[[PC_LABEL]] |
| 59 | ; O32: $_ZTISt9exception.DW.stub: |
| 60 | ; N32: .L_ZTISt9exception.DW.stub: |
| 61 | ; N64: .L_ZTISt9exception.DW.stub: |
Daniel Sanders | c95f3f8 | 2015-06-02 20:32:50 +0000 | [diff] [blame] | 62 | ; O32: .4byte _ZTISt9exception |
| 63 | ; N32: .4byte _ZTISt9exception |
| 64 | ; N64: .8byte _ZTISt9exception |
Daniel Sanders | 196390e | 2015-05-20 13:19:19 +0000 | [diff] [blame] | 65 | ; ALL: .hidden DW.ref.__gxx_personality_v0 |
| 66 | ; ALL: .weak DW.ref.__gxx_personality_v0 |
| 67 | ; ALL: .section .data.DW.ref.__gxx_personality_v0,"aGw",@progbits,DW.ref.__gxx_personality_v0,comdat |
Dan Gohman | 61d15ae | 2016-01-26 00:03:25 +0000 | [diff] [blame] | 68 | ; O32: .p2align 2 |
| 69 | ; N32: .p2align 2 |
| 70 | ; N64: .p2align 3 |
Daniel Sanders | 196390e | 2015-05-20 13:19:19 +0000 | [diff] [blame] | 71 | ; ALL: .type DW.ref.__gxx_personality_v0,@object |
| 72 | ; O32: .size DW.ref.__gxx_personality_v0, 4 |
| 73 | ; N32: .size DW.ref.__gxx_personality_v0, 4 |
| 74 | ; N64: .size DW.ref.__gxx_personality_v0, 8 |
| 75 | ; ALL: DW.ref.__gxx_personality_v0: |
| 76 | ; O32: .4byte __gxx_personality_v0 |
| 77 | ; N32: .4byte __gxx_personality_v0 |
| 78 | ; N64: .8byte __gxx_personality_v0 |