aboutsummaryrefslogtreecommitdiff
path: root/test/CodeGen/MIR/llvmIR.mir
blob: 7a7b46b626386150d634cedbb621a9bd2621f720 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
# RUN: llc -start-after branch-folder -stop-after branch-folder -o /dev/null %s | FileCheck %s
# This test ensures that the LLVM IR that's embedded with MIR is parsed
# correctly.

--- |
  ; CHECK: define i32 @foo(i32 %x, i32 %y)
  ; CHECK: %z = alloca i32, align 4
  ; CHECK: store i32 %x, i32* %z, align 4
  ; CHECK: br label %Test
  ; CHECK: Test:
  ; CHECK: %m = load i32, i32* %z, align 4
  ; CHECK: %cond = icmp eq i32 %y, %m
  ; CHECK: br i1 %cond, label %IfEqual, label %IfUnequal
  ; CHECK: IfEqual:
  ; CHECK: ret i32 1
  ; CHECK: IfUnequal:
  ; CHECK: ret i32 0
  define i32 @foo(i32 %x, i32 %y) {
    %z = alloca i32, align 4
    store i32 %x, i32* %z, align 4
    br label %Test
  Test:
    %m = load i32, i32* %z, align 4
    %cond = icmp eq i32 %y, %m
    br i1 %cond, label %IfEqual, label %IfUnequal
  IfEqual:
    ret i32 1
  IfUnequal:
    ret i32 0
  }
  
...