1dc8d70acSjiajie zhang! RUN: bbc -emit-fir %s -o - | FileCheck %s 2dc8d70acSjiajie zhang 3dc8d70acSjiajie zhang! CHECK-LABEL: func.func @_QPetime_test( 4dc8d70acSjiajie zhang! CHECK-SAME: %[[valuesArg:.*]]: !fir.ref<!fir.array<2xf32>> {fir.bindc_name = "values"}, 5dc8d70acSjiajie zhang! CHECK-SAME: %[[timeArg:.*]]: !fir.ref<f32> {fir.bindc_name = "time"}) { 6dc8d70acSjiajie zhangsubroutine etime_test(values, time) 7dc8d70acSjiajie zhang REAL(4), DIMENSION(2) :: values 8dc8d70acSjiajie zhang REAL(4) :: time 9dc8d70acSjiajie zhang time = etime(values) 10dc8d70acSjiajie zhang ! CHECK-NEXT: %[[c9:.*]] = arith.constant 9 : i32 11dc8d70acSjiajie zhang ! CHECK-NEXT: %[[c2:.*]] = arith.constant 2 : index 12dc8d70acSjiajie zhang ! CHECK-NEXT: %[[timeTmpAddr:.*]] = fir.alloca f32 13dc8d70acSjiajie zhang ! CHECK-NEXT: %[[DSCOPE:.*]] = fir.dummy_scope : !fir.dscope 14dc8d70acSjiajie zhang ! CHECK-NEXT: %[[timeDeclare:.*]] = fir.declare %[[timeArg]] dummy_scope %[[DSCOPE]] {uniq_name = "_QFetime_testEtime"} : (!fir.ref<f32>, !fir.dscope) -> !fir.ref<f32> 15dc8d70acSjiajie zhang ! CHECK-NEXT: %[[shape:.*]] = fir.shape %[[c2]] : (index) -> !fir.shape<1> 16dc8d70acSjiajie zhang ! CHECK-NEXT: %[[valuesDeclare:.*]] = fir.declare %[[valuesArg]](%[[shape]]) dummy_scope %[[DSCOPE]] {uniq_name = "_QFetime_testEvalues"} : (!fir.ref<!fir.array<2xf32>>, !fir.shape<1>, !fir.dscope) -> !fir.ref<!fir.array<2xf32>> 17dc8d70acSjiajie zhang ! CHECK-NEXT: %[[valuesBox:.*]] = fir.embox %[[valuesDeclare]](%[[shape]]) : (!fir.ref<!fir.array<2xf32>>, !fir.shape<1>) -> !fir.box<!fir.array<2xf32>> 18dc8d70acSjiajie zhang ! CHECK-NEXT: %[[timeTmpBox:.*]] = fir.embox %[[timeTmpAddr]] : (!fir.ref<f32>) -> !fir.box<f32> 19dc8d70acSjiajie zhang ! CHECK: %[[values:.*]] = fir.convert %[[valuesBox]] : (!fir.box<!fir.array<2xf32>>) -> !fir.box<none> 20dc8d70acSjiajie zhang ! CHECK: %[[timeTmp:.*]] = fir.convert %[[timeTmpBox]] : (!fir.box<f32>) -> !fir.box<none> 21*12ba74e1SValentin Clement (バレンタイン クレメン) ! CHECK: fir.call @_FortranAEtime(%[[values]], %[[timeTmp]], %[[VAL_7:.*]], %[[c9]]) fastmath<contract> : (!fir.box<none>, !fir.box<none>, !fir.ref<i8>, i32) -> () 22dc8d70acSjiajie zhang ! CHECK-NEXT: %[[timeValue:.*]] = fir.load %[[timeTmpAddr]] : !fir.ref<f32> 23dc8d70acSjiajie zhang ! CHECK-NEXT: fir.store %[[timeValue]] to %[[timeDeclare]] : !fir.ref<f32> 24dc8d70acSjiajie zhang ! CHECK-NEXT: return 25dc8d70acSjiajie zhangend subroutine etime_test 26