xref: /llvm-project/flang/test/Lower/array-elemental-calls-char-byval.f90 (revision a88677edc0792534ba3157bf7d7a1b98e470f2fb)
1656b8d6cSValentin Clement! Test lowering of elemental calls with character argument
2656b8d6cSValentin Clement! with the VALUE attribute.
3*a88677edSYusuke MINATO! RUN: bbc -hlfir=false -fwrapv -o - %s | FileCheck %s
4656b8d6cSValentin Clement
5656b8d6cSValentin Clement
6656b8d6cSValentin Clementmodule char_elem_byval
7656b8d6cSValentin Clement
8656b8d6cSValentin Clementinterface
9656b8d6cSValentin Clementelemental integer function elem(c, j)
10656b8d6cSValentin Clement  character(*), value :: c
11656b8d6cSValentin Clement  integer, intent(in) :: j
12656b8d6cSValentin Clementend function
13656b8d6cSValentin Clementend interface
14656b8d6cSValentin Clement
15656b8d6cSValentin Clementcontains
16656b8d6cSValentin Clement! CHECK-LABEL: func @_QMchar_elem_byvalPfoo1(
17656b8d6cSValentin Clement! CHECK-SAME: %[[VAL_22:[^:]+]]: !fir.ref<!fir.array<10xi32>>{{.*}}, %[[VAL_19:[^:]+]]: !fir.ref<!fir.array<10xi32>>{{.*}}, %[[VAL_5:.*]]: !fir.boxchar<1>{{.*}}) {
18656b8d6cSValentin Clementsubroutine foo1(i, j, c)
19656b8d6cSValentin Clement  integer :: i(10), j(10)
20656b8d6cSValentin Clement  character(*) :: c(10)
21656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_0:.*]] = arith.constant false
22656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_1:.*]] = arith.constant 10 : index
23656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_2:.*]] = arith.constant 0 : index
24656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_3:.*]] = arith.constant 1 : index
25656b8d6cSValentin Clement! CHECK:   %[[VAL_4:.*]]:2 = fir.unboxchar %[[VAL_5]] : (!fir.boxchar<1>) -> (!fir.ref<!fir.char<1,?>>, index)
26656b8d6cSValentin Clement! CHECK:   %[[VAL_6:.*]] = fir.convert %[[VAL_4]]#0 : (!fir.ref<!fir.char<1,?>>) -> !fir.ref<!fir.array<10x!fir.char<1,?>>>
27656b8d6cSValentin Clement! CHECK:   %[[VAL_7:.*]] = fir.shape %[[VAL_1]] : (index) -> !fir.shape<1>
28656b8d6cSValentin Clement! CHECK:   br ^bb1(%[[VAL_2]], %[[VAL_1]] : index, index)
29656b8d6cSValentin Clement! CHECK: ^bb1(%[[VAL_8:.*]]: index, %[[VAL_9:.*]]: index):
30656b8d6cSValentin Clement! CHECK:   %[[VAL_10:.*]] = arith.cmpi sgt, %[[VAL_9]], %[[VAL_2]] : index
31656b8d6cSValentin Clement! CHECK:   cond_br %[[VAL_10]], ^bb2, ^bb3
32656b8d6cSValentin Clement! CHECK: ^bb2:
33656b8d6cSValentin Clement! CHECK:   %[[VAL_11:.*]] = arith.addi %[[VAL_8]], %[[VAL_3]] : index
34656b8d6cSValentin Clement! CHECK:   %[[VAL_12:.*]] = fir.array_coor %[[VAL_6]](%[[VAL_7]]) %[[VAL_11]] typeparams %[[VAL_4]]#1 : (!fir.ref<!fir.array<10x!fir.char<1,?>>>, !fir.shape<1>, index, index) -> !fir.ref<!fir.char<1,?>>
35656b8d6cSValentin Clement! CHECK:   %[[VAL_13:.*]] = fir.alloca !fir.char<1,?>(%[[VAL_4]]#1 : index) {bindc_name = ".chrtmp"}
36656b8d6cSValentin Clement! CHECK:   %[[VAL_14:.*]] = fir.convert %[[VAL_4]]#1 : (index) -> i64
37656b8d6cSValentin Clement! CHECK:   %[[VAL_15:.*]] = fir.convert %[[VAL_13]] : (!fir.ref<!fir.char<1,?>>) -> !fir.ref<i8>
38656b8d6cSValentin Clement! CHECK:   %[[VAL_16:.*]] = fir.convert %[[VAL_12]] : (!fir.ref<!fir.char<1,?>>) -> !fir.ref<i8>
394cc9437aSTom Eccles! CHECK:   fir.call @llvm.memmove.p0.p0.i64(%[[VAL_15]], %[[VAL_16]], %[[VAL_14]], %[[VAL_0]]) {{.*}}: (!fir.ref<i8>, !fir.ref<i8>, i64, i1) -> ()
40656b8d6cSValentin Clement! CHECK:   %[[VAL_17:.*]] = fir.emboxchar %[[VAL_13]], %[[VAL_4]]#1 : (!fir.ref<!fir.char<1,?>>, index) -> !fir.boxchar<1>
41656b8d6cSValentin Clement! CHECK:   %[[VAL_18:.*]] = fir.array_coor %[[VAL_19]](%[[VAL_7]]) %[[VAL_11]] : (!fir.ref<!fir.array<10xi32>>, !fir.shape<1>, index) -> !fir.ref<i32>
424cc9437aSTom Eccles! CHECK:   %[[VAL_20:.*]] = fir.call @_QPelem(%[[VAL_17]], %[[VAL_18]]) {{.*}}: (!fir.boxchar<1>, !fir.ref<i32>) -> i32
43656b8d6cSValentin Clement! CHECK:   %[[VAL_21:.*]] = fir.array_coor %[[VAL_22]](%[[VAL_7]]) %[[VAL_11]] : (!fir.ref<!fir.array<10xi32>>, !fir.shape<1>, index) -> !fir.ref<i32>
44656b8d6cSValentin Clement! CHECK:   fir.store %[[VAL_20]] to %[[VAL_21]] : !fir.ref<i32>
45656b8d6cSValentin Clement! CHECK:   %[[VAL_23:.*]] = arith.subi %[[VAL_9]], %[[VAL_3]] : index
46656b8d6cSValentin Clement! CHECK:   br ^bb1(%[[VAL_11]], %[[VAL_23]] : index, index)
47656b8d6cSValentin Clement! CHECK: ^bb3:
48656b8d6cSValentin Clement! CHECK:   return
49656b8d6cSValentin Clement  i = elem(c, j)
50656b8d6cSValentin Clementend subroutine
51656b8d6cSValentin Clement
52656b8d6cSValentin Clement! CHECK-LABEL: func @_QMchar_elem_byvalPfoo2(
53656b8d6cSValentin Clement! CHECK-SAME: %[[VAL_44:[^:]+]]: !fir.ref<!fir.array<10xi32>>{{.*}}, %[[VAL_41:[^:]+]]: !fir.ref<!fir.array<10xi32>>{{.*}}, %[[VAL_29:.*]]: !fir.boxchar<1>{{.*}}) {
54656b8d6cSValentin Clementsubroutine foo2(i, j, c)
55656b8d6cSValentin Clement  integer :: i(10), j(10)
56656b8d6cSValentin Clement  character(*) :: c
57656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_24:.*]] = arith.constant false
58656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_25:.*]] = arith.constant 10 : index
59656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_26:.*]] = arith.constant 0 : index
60656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_27:.*]] = arith.constant 1 : index
61656b8d6cSValentin Clement! CHECK:   %[[VAL_28:.*]]:2 = fir.unboxchar %[[VAL_29]] : (!fir.boxchar<1>) -> (!fir.ref<!fir.char<1,?>>, index)
62656b8d6cSValentin Clement! CHECK:   %[[VAL_30:.*]] = fir.shape %[[VAL_25]] : (index) -> !fir.shape<1>
63656b8d6cSValentin Clement! CHECK:   %[[VAL_31:.*]] = fir.alloca !fir.char<1,?>(%[[VAL_28]]#1 : index) {bindc_name = ".chrtmp"}
64656b8d6cSValentin Clement! CHECK:   %[[VAL_32:.*]] = fir.convert %[[VAL_28]]#1 : (index) -> i64
65656b8d6cSValentin Clement! CHECK:   %[[VAL_33:.*]] = fir.convert %[[VAL_31]] : (!fir.ref<!fir.char<1,?>>) -> !fir.ref<i8>
66656b8d6cSValentin Clement! CHECK:   %[[VAL_34:.*]] = fir.convert %[[VAL_28]]#0 : (!fir.ref<!fir.char<1,?>>) -> !fir.ref<i8>
674cc9437aSTom Eccles! CHECK:   fir.call @llvm.memmove.p0.p0.i64(%[[VAL_33]], %[[VAL_34]], %[[VAL_32]], %[[VAL_24]]) {{.*}}: (!fir.ref<i8>, !fir.ref<i8>, i64, i1) -> ()
68656b8d6cSValentin Clement! CHECK:   br ^bb1(%[[VAL_26]], %[[VAL_25]] : index, index)
69656b8d6cSValentin Clement! CHECK: ^bb1(%[[VAL_35:.*]]: index, %[[VAL_36:.*]]: index):
70656b8d6cSValentin Clement! CHECK:   %[[VAL_37:.*]] = arith.cmpi sgt, %[[VAL_36]], %[[VAL_26]] : index
71656b8d6cSValentin Clement! CHECK:   cond_br %[[VAL_37]], ^bb2, ^bb3
72656b8d6cSValentin Clement! CHECK: ^bb2:
73656b8d6cSValentin Clement! CHECK:   %[[VAL_38:.*]] = fir.emboxchar %[[VAL_31]], %[[VAL_28]]#1 : (!fir.ref<!fir.char<1,?>>, index) -> !fir.boxchar<1>
74656b8d6cSValentin Clement! CHECK:   %[[VAL_39:.*]] = arith.addi %[[VAL_35]], %[[VAL_27]] : index
75656b8d6cSValentin Clement! CHECK:   %[[VAL_40:.*]] = fir.array_coor %[[VAL_41]](%[[VAL_30]]) %[[VAL_39]] : (!fir.ref<!fir.array<10xi32>>, !fir.shape<1>, index) -> !fir.ref<i32>
764cc9437aSTom Eccles! CHECK:   %[[VAL_42:.*]] = fir.call @_QPelem(%[[VAL_38]], %[[VAL_40]]) {{.*}}: (!fir.boxchar<1>, !fir.ref<i32>) -> i32
77656b8d6cSValentin Clement! CHECK:   %[[VAL_43:.*]] = fir.array_coor %[[VAL_44]](%[[VAL_30]]) %[[VAL_39]] : (!fir.ref<!fir.array<10xi32>>, !fir.shape<1>, index) -> !fir.ref<i32>
78656b8d6cSValentin Clement! CHECK:   fir.store %[[VAL_42]] to %[[VAL_43]] : !fir.ref<i32>
79656b8d6cSValentin Clement! CHECK:   %[[VAL_45:.*]] = arith.subi %[[VAL_36]], %[[VAL_27]] : index
80656b8d6cSValentin Clement! CHECK:   br ^bb1(%[[VAL_39]], %[[VAL_45]] : index, index)
81656b8d6cSValentin Clement! CHECK: ^bb3:
82656b8d6cSValentin Clement! CHECK:   return
83656b8d6cSValentin Clement  i = elem(c, j)
84656b8d6cSValentin Clementend subroutine
85656b8d6cSValentin Clement
86656b8d6cSValentin Clement! CHECK-LABEL: func @_QMchar_elem_byvalPfoo3(
87656b8d6cSValentin Clement! CHECK-SAME: %[[VAL_65:[^:]+]]: !fir.ref<!fir.array<10xi32>>{{.*}}, %[[VAL_55:[^:]+]]: !fir.ref<!fir.array<10xi32>>{{.*}}) {
88656b8d6cSValentin Clementsubroutine foo3(i, j)
89656b8d6cSValentin Clement  integer :: i(10), j(10)
90656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_46:.*]] = arith.constant 10 : index
91656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_47:.*]] = arith.constant 0 : index
92656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_48:.*]] = arith.constant 1 : index
93656b8d6cSValentin Clement! CHECK:   %[[VAL_49:.*]] = fir.shape %[[VAL_46]] : (index) -> !fir.shape<1>
94656b8d6cSValentin Clement! CHECK:   br ^bb1(%[[VAL_47]], %[[VAL_46]] : index, index)
95656b8d6cSValentin Clement! CHECK: ^bb1(%[[VAL_50:.*]]: index, %[[VAL_51:.*]]: index):
96656b8d6cSValentin Clement! CHECK:   %[[VAL_52:.*]] = arith.cmpi sgt, %[[VAL_51]], %[[VAL_47]] : index
97656b8d6cSValentin Clement! CHECK:   cond_br %[[VAL_52]], ^bb2, ^bb3
98656b8d6cSValentin Clement! CHECK: ^bb2:
99656b8d6cSValentin Clement! CHECK:   %[[VAL_53:.*]] = arith.addi %[[VAL_50]], %[[VAL_48]] : index
100656b8d6cSValentin Clement! CHECK:   %[[VAL_54:.*]] = fir.array_coor %[[VAL_55]](%[[VAL_49]]) %[[VAL_53]] : (!fir.ref<!fir.array<10xi32>>, !fir.shape<1>, index) -> !fir.ref<i32>
101656b8d6cSValentin Clement! CHECK:   %[[VAL_56:.*]] = fir.load %[[VAL_54]] : !fir.ref<i32>
102656b8d6cSValentin Clement! CHECK:   %[[VAL_57:.*]] = fir.convert %[[VAL_56]] : (i32) -> i8
103656b8d6cSValentin Clement! CHECK:   %[[VAL_58:.*]] = fir.undefined !fir.char<1>
104656b8d6cSValentin Clement! CHECK:   %[[VAL_59:.*]] = fir.insert_value %[[VAL_58]], %[[VAL_57]], [0 : index] : (!fir.char<1>, i8) -> !fir.char<1>
105656b8d6cSValentin Clement! CHECK:   %[[VAL_60:.*]] = fir.alloca !fir.char<1> {bindc_name = ".chrtmp"}
106656b8d6cSValentin Clement! CHECK:   fir.store %[[VAL_59]] to %[[VAL_60]] : !fir.ref<!fir.char<1>>
107c0cb8f73SjeanPerier! CHECK:   %[[VAL_62:.*]] = fir.emboxchar %[[VAL_60]], %[[VAL_48]] : (!fir.ref<!fir.char<1>>, index) -> !fir.boxchar<1>
1084cc9437aSTom Eccles! CHECK:   %[[VAL_63:.*]] = fir.call @_QPelem(%[[VAL_62]], %[[VAL_54]]) {{.*}}: (!fir.boxchar<1>, !fir.ref<i32>) -> i32
109656b8d6cSValentin Clement! CHECK:   %[[VAL_64:.*]] = fir.array_coor %[[VAL_65]](%[[VAL_49]]) %[[VAL_53]] : (!fir.ref<!fir.array<10xi32>>, !fir.shape<1>, index) -> !fir.ref<i32>
110656b8d6cSValentin Clement! CHECK:   fir.store %[[VAL_63]] to %[[VAL_64]] : !fir.ref<i32>
111656b8d6cSValentin Clement! CHECK:   %[[VAL_66:.*]] = arith.subi %[[VAL_51]], %[[VAL_48]] : index
112656b8d6cSValentin Clement! CHECK:   br ^bb1(%[[VAL_53]], %[[VAL_66]] : index, index)
113656b8d6cSValentin Clement! CHECK: ^bb3:
114656b8d6cSValentin Clement! CHECK:   return
115656b8d6cSValentin Clement  i = elem(char(j), j)
116656b8d6cSValentin Clementend subroutine
117656b8d6cSValentin Clement
118656b8d6cSValentin Clement! CHECK-LABEL: func @_QMchar_elem_byvalPfoo4(
119656b8d6cSValentin Clement! CHECK-SAME: %[[VAL_93:[^:]+]]: !fir.ref<!fir.array<10xi32>>{{.*}}, %[[VAL_74:[^:]+]]: !fir.ref<!fir.array<10xi32>>{{.*}}) {
120656b8d6cSValentin Clementsubroutine foo4(i, j)
121656b8d6cSValentin Clement  integer :: i(10), j(10)
122656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_67:.*]] = arith.constant 0 : i64
123656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_68:.*]] = arith.constant false
124656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_69:.*]] = arith.constant 10 : index
125656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_70:.*]] = arith.constant 0 : index
126656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_71:.*]] = arith.constant 1 : index
127656b8d6cSValentin Clement! CHECK:   %[[VAL_66:.*]] = fir.alloca !fir.char<1> {adapt.valuebyref}
128656b8d6cSValentin Clement! CHECK:   %[[VAL_72:.*]] = fir.shape %[[VAL_69]] : (index) -> !fir.shape<1>
129656b8d6cSValentin Clement! CHECK:   %[[VAL_73:.*]] = fir.coordinate_of %[[VAL_74]], %[[VAL_67]] : (!fir.ref<!fir.array<10xi32>>, i64) -> !fir.ref<i32>
130656b8d6cSValentin Clement! CHECK:   %[[VAL_75:.*]] = fir.load %[[VAL_73]] : !fir.ref<i32>
131656b8d6cSValentin Clement! CHECK:   %[[VAL_76:.*]] = fir.convert %[[VAL_75]] : (i32) -> i8
132656b8d6cSValentin Clement! CHECK:   %[[VAL_77:.*]] = fir.undefined !fir.char<1>
133656b8d6cSValentin Clement! CHECK:   %[[VAL_78:.*]] = fir.insert_value %[[VAL_77]], %[[VAL_76]], [0 : index] : (!fir.char<1>, i8) -> !fir.char<1>
134656b8d6cSValentin Clement! CHECK:   fir.store %[[VAL_78]] to %[[VAL_66]] : !fir.ref<!fir.char<1>>
135656b8d6cSValentin Clement! CHECK:   %[[VAL_80:.*]] = fir.alloca !fir.char<1> {bindc_name = ".chrtmp"}
136656b8d6cSValentin Clement! CHECK:   %[[VAL_81:.*]] = fir.convert %[[VAL_71]] : (index) -> i64
137656b8d6cSValentin Clement! CHECK:   %[[VAL_82:.*]] = fir.convert %[[VAL_80]] : (!fir.ref<!fir.char<1>>) -> !fir.ref<i8>
138656b8d6cSValentin Clement! CHECK:   %[[VAL_83:.*]] = fir.convert %[[VAL_66]] : (!fir.ref<!fir.char<1>>) -> !fir.ref<i8>
1394cc9437aSTom Eccles! CHECK:   fir.call @llvm.memmove.p0.p0.i64(%[[VAL_82]], %[[VAL_83]], %[[VAL_81]], %[[VAL_68]]) {{.*}}: (!fir.ref<i8>, !fir.ref<i8>, i64, i1) -> ()
140656b8d6cSValentin Clement! CHECK:   br ^bb1(%[[VAL_70]], %[[VAL_69]] : index, index)
141656b8d6cSValentin Clement! CHECK: ^bb1(%[[VAL_84:.*]]: index, %[[VAL_85:.*]]: index):
142656b8d6cSValentin Clement! CHECK:   %[[VAL_86:.*]] = arith.cmpi sgt, %[[VAL_85]], %[[VAL_70]] : index
143656b8d6cSValentin Clement! CHECK:   cond_br %[[VAL_86]], ^bb2, ^bb3
144656b8d6cSValentin Clement! CHECK: ^bb2:
145c0cb8f73SjeanPerier! CHECK:   %[[VAL_88:.*]] = fir.emboxchar %[[VAL_80]], %[[VAL_71]] : (!fir.ref<!fir.char<1>>, index) -> !fir.boxchar<1>
146656b8d6cSValentin Clement! CHECK:   %[[VAL_89:.*]] = arith.addi %[[VAL_84]], %[[VAL_71]] : index
147656b8d6cSValentin Clement! CHECK:   %[[VAL_90:.*]] = fir.array_coor %[[VAL_74]](%[[VAL_72]]) %[[VAL_89]] : (!fir.ref<!fir.array<10xi32>>, !fir.shape<1>, index) -> !fir.ref<i32>
1484cc9437aSTom Eccles! CHECK:   %[[VAL_91:.*]] = fir.call @_QPelem(%[[VAL_88]], %[[VAL_90]]) {{.*}}: (!fir.boxchar<1>, !fir.ref<i32>) -> i32
149656b8d6cSValentin Clement! CHECK:   %[[VAL_92:.*]] = fir.array_coor %[[VAL_93]](%[[VAL_72]]) %[[VAL_89]] : (!fir.ref<!fir.array<10xi32>>, !fir.shape<1>, index) -> !fir.ref<i32>
150656b8d6cSValentin Clement! CHECK:   fir.store %[[VAL_91]] to %[[VAL_92]] : !fir.ref<i32>
151656b8d6cSValentin Clement! CHECK:   %[[VAL_94:.*]] = arith.subi %[[VAL_85]], %[[VAL_71]] : index
152656b8d6cSValentin Clement! CHECK:   br ^bb1(%[[VAL_89]], %[[VAL_94]] : index, index)
153656b8d6cSValentin Clement! CHECK: ^bb3:
154656b8d6cSValentin Clement! CHECK:   return
155656b8d6cSValentin Clement  i = elem(char(j(1)), j)
156656b8d6cSValentin Clementend subroutine
157656b8d6cSValentin Clement
158656b8d6cSValentin Clement! Note: the copy of the constant is important because VALUE argument can be
159656b8d6cSValentin Clement! modified on the caller side.
160656b8d6cSValentin Clement
161656b8d6cSValentin Clement! CHECK-LABEL: func @_QMchar_elem_byvalPfoo5(
162656b8d6cSValentin Clement! CHECK-SAME: %[[VAL_116:[^:]+]]: !fir.ref<!fir.array<10xi32>>{{.*}}, %[[VAL_113:[^:]+]]: !fir.ref<!fir.array<10xi32>>{{.*}}) {
163656b8d6cSValentin Clementsubroutine foo5(i, j)
164656b8d6cSValentin Clement  integer :: i(10), j(10)
165656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_95:.*]] = arith.constant 5 : index
166656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_96:.*]] = arith.constant false
167656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_97:.*]] = arith.constant 10 : index
168656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_98:.*]] = arith.constant 0 : index
169656b8d6cSValentin Clement! CHECK-DAG:   %[[VAL_99:.*]] = arith.constant 1 : index
170656b8d6cSValentin Clement! CHECK:   %[[VAL_100:.*]] = fir.shape %[[VAL_97]] : (index) -> !fir.shape<1>
171656b8d6cSValentin Clement! CHECK:   %[[VAL_101:.*]] = fir.address_of(@{{.*}}) : !fir.ref<!fir.char<1,5>>
172656b8d6cSValentin Clement! CHECK:   %[[VAL_102:.*]] = fir.alloca !fir.char<1,5> {bindc_name = ".chrtmp"}
173656b8d6cSValentin Clement! CHECK:   %[[VAL_103:.*]] = fir.convert %[[VAL_95]] : (index) -> i64
174656b8d6cSValentin Clement! CHECK:   %[[VAL_104:.*]] = fir.convert %[[VAL_102]] : (!fir.ref<!fir.char<1,5>>) -> !fir.ref<i8>
175656b8d6cSValentin Clement! CHECK:   %[[VAL_105:.*]] = fir.convert %[[VAL_101]] : (!fir.ref<!fir.char<1,5>>) -> !fir.ref<i8>
1764cc9437aSTom Eccles! CHECK:   fir.call @llvm.memmove.p0.p0.i64(%[[VAL_104]], %[[VAL_105]], %[[VAL_103]], %[[VAL_96]]) {{.*}}: (!fir.ref<i8>, !fir.ref<i8>, i64, i1) -> ()
177656b8d6cSValentin Clement! CHECK:   br ^bb1(%[[VAL_98]], %[[VAL_97]] : index, index)
178656b8d6cSValentin Clement! CHECK: ^bb1(%[[VAL_106:.*]]: index, %[[VAL_107:.*]]: index):
179656b8d6cSValentin Clement! CHECK:   %[[VAL_108:.*]] = arith.cmpi sgt, %[[VAL_107]], %[[VAL_98]] : index
180656b8d6cSValentin Clement! CHECK:   cond_br %[[VAL_108]], ^bb2, ^bb3
181656b8d6cSValentin Clement! CHECK: ^bb2:
182c0cb8f73SjeanPerier! CHECK:   %[[VAL_110:.*]] = fir.emboxchar %[[VAL_102]], %[[VAL_95]] : (!fir.ref<!fir.char<1,5>>, index) -> !fir.boxchar<1>
183656b8d6cSValentin Clement! CHECK:   %[[VAL_111:.*]] = arith.addi %[[VAL_106]], %[[VAL_99]] : index
184656b8d6cSValentin Clement! CHECK:   %[[VAL_112:.*]] = fir.array_coor %[[VAL_113]](%[[VAL_100]]) %[[VAL_111]] : (!fir.ref<!fir.array<10xi32>>, !fir.shape<1>, index) -> !fir.ref<i32>
1854cc9437aSTom Eccles! CHECK:   %[[VAL_114:.*]] = fir.call @_QPelem(%[[VAL_110]], %[[VAL_112]]) {{.*}}: (!fir.boxchar<1>, !fir.ref<i32>) -> i32
186656b8d6cSValentin Clement! CHECK:   %[[VAL_115:.*]] = fir.array_coor %[[VAL_116]](%[[VAL_100]]) %[[VAL_111]] : (!fir.ref<!fir.array<10xi32>>, !fir.shape<1>, index) -> !fir.ref<i32>
187656b8d6cSValentin Clement! CHECK:   fir.store %[[VAL_114]] to %[[VAL_115]] : !fir.ref<i32>
188656b8d6cSValentin Clement! CHECK:   %[[VAL_117:.*]] = arith.subi %[[VAL_107]], %[[VAL_99]] : index
189656b8d6cSValentin Clement! CHECK:   br ^bb1(%[[VAL_111]], %[[VAL_117]] : index, index)
190656b8d6cSValentin Clement! CHECK: ^bb3:
191656b8d6cSValentin Clement! CHECK:   return
192656b8d6cSValentin Clement  i = elem("hello", j)
193656b8d6cSValentin Clementend subroutine
194656b8d6cSValentin Clement
195656b8d6cSValentin Clementend module
196