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