Bump version to 19.1.0-rc3
[llvm-project.git] / llvm / test / Bitcode / callbr.ll
blob5f6283dd035d6a3abc9e46815479fd87be846ab8
1 ; RUN:  llvm-dis < %s.bc | FileCheck %s
2 ; callbr.ll.bc was generated by passing this file to llvm-as.
4 ; RUN: llvm-as < %s | llvm-dis | FileCheck %s
6 define i32 @test_asm_goto(i32 %x){
7 entry:
8 ; CHECK: callbr void asm "", "r,!i"(i32 %x)
9 ; CHECK-NEXT: to label %normal [label %fail]
10   callbr void asm "", "r,!i"(i32 %x) to label %normal [label %fail]
11 normal:
12   ret i32 1
13 fail:
14   ret i32 0
17 define i32 @test_asm_goto2(i32 %x){
18 entry:
19 ; CHECK: callbr void asm "", "r,!i,!i"(i32 %x)
20 ; CHECK-NEXT: to label %normal [label %fail, label %fail2]
21   callbr void asm "", "r,!i,!i"(i32 %x) to label %normal [label %fail, label %fail2]
22 normal:
23   ret i32 1
24 fail:
25   ret i32 0
26 fail2:
27   ret i32 2
30 define i32 @test_asm_goto3(i32 %x){
31 entry:
32 ; CHECK:     callbr void asm "", "r,i,!i"(i32 %x, ptr blockaddress(@test_asm_goto3, %unrelated))
33 ; CHECK-NEXT: to label %normal [label %fail]
34   callbr void asm "", "r,i,!i"(i32 %x, i8* blockaddress(@test_asm_goto3, %unrelated)) to label %normal [label %fail]
35 normal:
36   ret i32 1
37 fail:
38   ret i32 0
39 unrelated:
40   ret i32 2