1*11fb1aa5SDiana Picus! RUN: bbc -emit-fir -o - %s | FileCheck %s
2*11fb1aa5SDiana Picus! RUN: %flang_fc1 -emit-fir -o - %s | FileCheck %s
3*11fb1aa5SDiana Picus
4*11fb1aa5SDiana Picus! Test a simple while loop.
5*11fb1aa5SDiana Picus! CHECK-LABEL: simple_loop
6*11fb1aa5SDiana Picussubroutine simple_loop
7*11fb1aa5SDiana Picus  ! CHECK: %[[I_REF:.*]] = fir.alloca i32 {bindc_name = "i", uniq_name = "_QFsimple_loopEi"}
8*11fb1aa5SDiana Picus  integer :: i
9*11fb1aa5SDiana Picus
10*11fb1aa5SDiana Picus  ! CHECK: %[[C5:.*]] = arith.constant 5 : i32
11*11fb1aa5SDiana Picus  ! CHECK: fir.store %[[C5]] to %[[I_REF]]
12*11fb1aa5SDiana Picus  i = 5
13*11fb1aa5SDiana Picus
14*11fb1aa5SDiana Picus  ! CHECK: br ^[[BB1:.*]]
15*11fb1aa5SDiana Picus  ! CHECK: ^[[BB1]]:  // 2 preds: ^{{.*}}, ^[[BB2:.*]]
16*11fb1aa5SDiana Picus  ! CHECK-DAG: %[[I:.*]] = fir.load %[[I_REF]] : !fir.ref<i32>
17*11fb1aa5SDiana Picus  ! CHECK-DAG: %[[C1:.*]] = arith.constant 1 : i32
18*11fb1aa5SDiana Picus  ! CHECK: %[[COND:.*]] = arith.cmpi sgt, %[[I]], %[[C1]] : i32
19*11fb1aa5SDiana Picus  ! CHECK: cond_br %[[COND]], ^[[BB2]], ^[[BB3:.*]]
20*11fb1aa5SDiana Picus  ! CHECK: ^[[BB2]]:  // pred: ^[[BB1]]
21*11fb1aa5SDiana Picus  ! CHECK-DAG: %[[I2:.*]] = fir.load %[[I_REF]] : !fir.ref<i32>
22*11fb1aa5SDiana Picus  ! CHECK-DAG: %[[C2:.*]] = arith.constant 2 : i32
23*11fb1aa5SDiana Picus  ! CHECK: %[[INC:.*]] = arith.subi %[[I2]], %[[C2]] : i32
24*11fb1aa5SDiana Picus  ! CHECK: fir.store %[[INC]] to %[[I_REF]] : !fir.ref<i32>
25*11fb1aa5SDiana Picus  ! CHECK: br ^[[BB1]]
26*11fb1aa5SDiana Picus  do while (i .gt. 1)
27*11fb1aa5SDiana Picus    i = i - 2
28*11fb1aa5SDiana Picus  end do
29*11fb1aa5SDiana Picus
30*11fb1aa5SDiana Picus  ! CHECK: ^[[BB3]]:  // pred: ^[[BB1]]
31*11fb1aa5SDiana Picus  ! CHECK: %[[I3:.*]] = fir.load %[[I_REF]] : !fir.ref<i32>
32*11fb1aa5SDiana Picus  ! CHECK: fir.call @_FortranAioOutputInteger32(%{{.*}}, %[[I3]]) : (!fir.ref<i8>, i32) -> i1
33*11fb1aa5SDiana Picus  print *, i
34*11fb1aa5SDiana Picusend subroutine
35*11fb1aa5SDiana Picus
36*11fb1aa5SDiana Picus! Test 2 nested while loops.
37*11fb1aa5SDiana Picus! CHECK-LABEL: while_inside_while_loop
38*11fb1aa5SDiana Picussubroutine while_inside_while_loop
39*11fb1aa5SDiana Picus  ! CHECK-DAG: %[[I_REF:.*]] = fir.alloca i32 {bindc_name = "i", uniq_name = "_QFwhile_inside_while_loopEi"}
40*11fb1aa5SDiana Picus  ! CHECK-DAG: %[[J_REF:.*]] = fir.alloca i32 {bindc_name = "j", uniq_name = "_QFwhile_inside_while_loopEj"}
41*11fb1aa5SDiana Picus  integer :: i, j
42*11fb1aa5SDiana Picus
43*11fb1aa5SDiana Picus  ! CHECK: %[[C13:.*]] = arith.constant 13 : i32
44*11fb1aa5SDiana Picus  ! CHECK: fir.store %[[C13]] to %[[I_REF]]
45*11fb1aa5SDiana Picus  i = 13
46*11fb1aa5SDiana Picus
47*11fb1aa5SDiana Picus  ! CHECK: br ^[[HDR1:.*]]
48*11fb1aa5SDiana Picus  ! CHECK: ^[[HDR1]]:  // 2 preds: ^{{.*}}, ^[[EXIT2:.*]]
49*11fb1aa5SDiana Picus  ! CHECK-DAG: %[[I:.*]] = fir.load %[[I_REF]] : !fir.ref<i32>
50*11fb1aa5SDiana Picus  ! CHECK-DAG: %[[C8:.*]] = arith.constant 8 : i32
51*11fb1aa5SDiana Picus  ! CHECK: %[[COND:.*]] = arith.cmpi sgt, %[[I]], %[[C8]] : i32
52*11fb1aa5SDiana Picus  ! CHECK: cond_br %[[COND]], ^[[BODY1:.*]], ^[[EXIT1:.*]]
53*11fb1aa5SDiana Picus  do while (i .gt. 8)
54*11fb1aa5SDiana Picus    ! CHECK: ^[[BODY1]]:  // pred: ^[[HDR1]]
55*11fb1aa5SDiana Picus    ! CHECK-DAG: %[[I2:.*]] = fir.load %[[I_REF]] : !fir.ref<i32>
56*11fb1aa5SDiana Picus    ! CHECK-DAG: %[[C5:.*]] = arith.constant 5 : i32
57*11fb1aa5SDiana Picus    ! CHECK: %[[INC:.*]] = arith.subi %[[I2]], %[[C5]] : i32
58*11fb1aa5SDiana Picus    ! CHECK: fir.store %[[INC]] to %[[I_REF]] : !fir.ref<i32>
59*11fb1aa5SDiana Picus    i = i - 5
60*11fb1aa5SDiana Picus
61*11fb1aa5SDiana Picus    ! CHECK: %[[C3:.*]] = arith.constant 3 : i32
62*11fb1aa5SDiana Picus    ! CHECK: fir.store %[[C3]] to %[[J_REF]]
63*11fb1aa5SDiana Picus    j = 3
64*11fb1aa5SDiana Picus
65*11fb1aa5SDiana Picus    ! CHECK: br ^[[HDR2:.*]]
66*11fb1aa5SDiana Picus    ! CHECK: ^[[HDR2]]:  // 2 preds: ^[[BODY1]], ^[[BODY2:.*]]
67*11fb1aa5SDiana Picus    ! CHECK-DAG: %[[J:.*]] = fir.load %[[J_REF]] : !fir.ref<i32>
68*11fb1aa5SDiana Picus    ! CHECK-DAG: %[[I3:.*]] = fir.load %[[I_REF]] : !fir.ref<i32>
69*11fb1aa5SDiana Picus    ! CHECK: %[[COND2:.*]] = arith.cmpi slt, %[[J]], %[[I3]] : i32
70*11fb1aa5SDiana Picus    ! CHECK: cond_br %[[COND2]], ^[[BODY2]], ^[[EXIT2]]
71*11fb1aa5SDiana Picus    do while (j .lt. i)
72*11fb1aa5SDiana Picus      ! CHECK: ^[[BODY2]]:  // pred: ^[[HDR2]]
73*11fb1aa5SDiana Picus      ! CHECK-DAG: %[[J2:.*]] = fir.load %[[J_REF]] : !fir.ref<i32>
74*11fb1aa5SDiana Picus      ! CHECK-DAG: %[[C2:.*]] = arith.constant 2 : i32
75*11fb1aa5SDiana Picus      ! CHECK: %[[INC2:.*]] = arith.muli %[[C2]], %[[J2]] : i32
76*11fb1aa5SDiana Picus      ! CHECK: fir.store %[[INC2]] to %[[J_REF]] : !fir.ref<i32>
77*11fb1aa5SDiana Picus      j = j * 2
78*11fb1aa5SDiana Picus    ! CHECK: br ^[[HDR2]]
79*11fb1aa5SDiana Picus    end do
80*11fb1aa5SDiana Picus
81*11fb1aa5SDiana Picus    ! CHECK: ^[[EXIT2]]: // pred: ^[[HDR2]]
82*11fb1aa5SDiana Picus    ! CHECK: br ^[[HDR1]]
83*11fb1aa5SDiana Picus  end do
84*11fb1aa5SDiana Picus
85*11fb1aa5SDiana Picus  ! CHECK: ^[[EXIT1]]:  // pred: ^[[HDR1]]
86*11fb1aa5SDiana Picus  ! CHECK: %[[IPRINT:.*]] = fir.load %[[I_REF]] : !fir.ref<i32>
87*11fb1aa5SDiana Picus  ! CHECK: fir.call @_FortranAioOutputInteger32(%{{.*}}, %[[IPRINT]]) : (!fir.ref<i8>, i32) -> i1
88*11fb1aa5SDiana Picus  ! CHECK: %[[JPRINT:.*]] = fir.load %[[J_REF]] : !fir.ref<i32>
89*11fb1aa5SDiana Picus  ! CHECK: fir.call @_FortranAioOutputInteger32(%{{.*}}, %[[JPRINT]]) : (!fir.ref<i8>, i32) -> i1
90*11fb1aa5SDiana Picus  print *, i, j
91*11fb1aa5SDiana Picusend subroutine
92