[flang] Accept polymorphic component element in storage_size
[llvm-project.git] / flang / test / Lower / assignment.f90
blob8e836ce30cdb3e4a2fa7cfd28813fe38d0a5aa22
1 ! RUN: bbc %s -o "-" -emit-fir | FileCheck %s
3 subroutine sub1(a)
4 integer :: a
5 a = 1
6 end
8 ! CHECK-LABEL: func @_QPsub1(
9 ! CHECK-SAME: %[[ARG0:.*]]: !fir.ref<i32>
10 ! CHECK: %[[C1:.*]] = arith.constant 1 : i32
11 ! CHECK: fir.store %[[C1]] to %[[ARG0]] : !fir.ref<i32>
13 subroutine sub2(a, b)
14 integer(4) :: a
15 integer(8) :: b
16 a = b
17 end
19 ! CHECK-LABEL: func @_QPsub2(
20 ! CHECK: %[[A:.*]]: !fir.ref<i32> {fir.bindc_name = "a"}
21 ! CHECK: %[[B:.*]]: !fir.ref<i64> {fir.bindc_name = "b"}
22 ! CHECK: %[[B_VAL:.*]] = fir.load %arg1 : !fir.ref<i64>
23 ! CHECK: %[[B_CONV:.*]] = fir.convert %[[B_VAL]] : (i64) -> i32
24 ! CHECK: fir.store %[[B_CONV]] to %[[A]] : !fir.ref<i32>
26 integer function negi(a)
27 integer :: a
28 negi = -a
29 end
31 ! CHECK-LABEL: func @_QPnegi(
32 ! CHECK-SAME: %[[A:.*]]: !fir.ref<i32> {fir.bindc_name = "a"}) -> i32 {
33 ! CHECK: %[[FCTRES:.*]] = fir.alloca i32 {bindc_name = "negi", uniq_name = "_QFnegiEnegi"}
34 ! CHECK: %[[A_VAL:.*]] = fir.load %[[A]] : !fir.ref<i32>
35 ! CHECK: %[[C0:.*]] = arith.constant 0 : i32
36 ! CHECK: %[[NEG:.*]] = arith.subi %[[C0]], %[[A_VAL]] : i32
37 ! CHECK: fir.store %[[NEG]] to %[[FCTRES]] : !fir.ref<i32>
38 ! CHECK: %[[RET:.*]] = fir.load %[[FCTRES]] : !fir.ref<i32>
39 ! CHECK: return %[[RET]] : i32
41 real function negr(a)
42 real :: a
43 negr = -a
44 end
46 ! CHECK-LABEL: func @_QPnegr(
47 ! CHECK-SAME: %[[A:.*]]: !fir.ref<f32> {fir.bindc_name = "a"}) -> f32 {
48 ! CHECK: %[[FCTRES:.*]] = fir.alloca f32 {bindc_name = "negr", uniq_name = "_QFnegrEnegr"}
49 ! CHECK: %[[A_VAL:.*]] = fir.load %[[A]] : !fir.ref<f32>
50 ! CHECK: %[[NEG:.*]] = arith.negf %[[A_VAL]] {{.*}}: f32
51 ! CHECK: fir.store %[[NEG]] to %[[FCTRES]] : !fir.ref<f32>
52 ! CHECK: %[[RET:.*]] = fir.load %[[FCTRES]] : !fir.ref<f32>
53 ! CHECK: return %[[RET]] : f32
55 complex function negc(a)
56 complex :: a
57 negc = -a
58 end
60 ! CHECK-LABEL: func @_QPnegc(
61 ! CHECK-SAME: %[[A:.*]]: !fir.ref<!fir.complex<4>> {fir.bindc_name = "a"}) -> !fir.complex<4> {
62 ! CHECK: %[[FCTRES:.*]] = fir.alloca !fir.complex<4> {bindc_name = "negc", uniq_name = "_QFnegcEnegc"}
63 ! CHECK: %[[A_VAL:.*]] = fir.load %[[A]] : !fir.ref<!fir.complex<4>>
64 ! CHECK: %[[NEG:.*]] = fir.negc %[[A_VAL]] : !fir.complex<4>
65 ! CHECK: fir.store %[[NEG]] to %[[FCTRES]] : !fir.ref<!fir.complex<4>>
67 integer function addi(a, b)
68 integer :: a, b
69 addi = a + b
70 end
72 ! CHECK-LABEL: func @_QPaddi(
73 ! CHECK-SAME: %[[A:.*]]: !fir.ref<i32> {fir.bindc_name = "a"},
74 ! CHECK-SAME: %[[B:.*]]: !fir.ref<i32> {fir.bindc_name = "b"}
75 ! CHECK: %[[FCTRES:.*]] = fir.alloca i32
76 ! CHECK: %[[A_VAL:.*]] = fir.load %[[A]] : !fir.ref<i32>
77 ! CHECK: %[[B_VAL:.*]] = fir.load %[[B]] : !fir.ref<i32>
78 ! CHECK: %[[ADD:.*]] = arith.addi %[[A_VAL]], %[[B_VAL]] : i32
79 ! CHECK: fir.store %[[ADD]] to %[[FCTRES]] : !fir.ref<i32>
80 ! CHECK: %[[RET:.*]] = fir.load %[[FCTRES]] : !fir.ref<i32>
81 ! CHECK: return %[[RET]] : i32
83 integer function subi(a, b)
84 integer :: a, b
85 subi = a - b
86 end
88 ! CHECK-LABEL: func @_QPsubi(
89 ! CHECK-SAME: %[[A:.*]]: !fir.ref<i32> {fir.bindc_name = "a"},
90 ! CHECK-SAME: %[[B:.*]]: !fir.ref<i32> {fir.bindc_name = "b"}
91 ! CHECK: %[[FCTRES:.*]] = fir.alloca i32
92 ! CHECK: %[[A_VAL:.*]] = fir.load %[[A]] : !fir.ref<i32>
93 ! CHECK: %[[B_VAL:.*]] = fir.load %[[B]] : !fir.ref<i32>
94 ! CHECK: %[[SUB:.*]] = arith.subi %[[A_VAL]], %[[B_VAL]] : i32
95 ! CHECK: fir.store %[[SUB]] to %[[FCTRES]] : !fir.ref<i32>
96 ! CHECK: %[[RET:.*]] = fir.load %[[FCTRES]] : !fir.ref<i32>
97 ! CHECK: return %[[RET]] : i32
99 integer function muli(a, b)
100 integer :: a, b
101 muli = a * b
104 ! CHECK-LABEL: func @_QPmuli(
105 ! CHECK-SAME: %[[A:.*]]: !fir.ref<i32> {fir.bindc_name = "a"},
106 ! CHECK-SAME: %[[B:.*]]: !fir.ref<i32> {fir.bindc_name = "b"}
107 ! CHECK: %[[FCTRES:.*]] = fir.alloca i32
108 ! CHECK: %[[A_VAL:.*]] = fir.load %[[A]] : !fir.ref<i32>
109 ! CHECK: %[[B_VAL:.*]] = fir.load %[[B]] : !fir.ref<i32>
110 ! CHECK: %[[MUL:.*]] = arith.muli %[[A_VAL]], %[[B_VAL]] : i32
111 ! CHECK: fir.store %[[MUL]] to %[[FCTRES]] : !fir.ref<i32>
112 ! CHECK: %[[RET:.*]] = fir.load %[[FCTRES]] : !fir.ref<i32>
113 ! CHECK: return %[[RET]] : i32
115 integer function divi(a, b)
116 integer :: a, b
117 divi = a / b
120 ! CHECK-LABEL: func @_QPdivi(
121 ! CHECK-SAME: %[[A:.*]]: !fir.ref<i32> {fir.bindc_name = "a"},
122 ! CHECK-SAME: %[[B:.*]]: !fir.ref<i32> {fir.bindc_name = "b"}
123 ! CHECK: %[[FCTRES:.*]] = fir.alloca i32
124 ! CHECK: %[[A_VAL:.*]] = fir.load %[[A]] : !fir.ref<i32>
125 ! CHECK: %[[B_VAL:.*]] = fir.load %[[B]] : !fir.ref<i32>
126 ! CHECK: %[[DIV:.*]] = arith.divsi %[[A_VAL]], %[[B_VAL]] : i32
127 ! CHECK: fir.store %[[DIV]] to %[[FCTRES]] : !fir.ref<i32>
128 ! CHECK: %[[RET:.*]] = fir.load %[[FCTRES]] : !fir.ref<i32>
129 ! CHECK: return %[[RET]] : i32
131 real function addf(a, b)
132 real :: a, b
133 addf = a + b
136 ! CHECK-LABEL: func @_QPaddf(
137 ! CHECK-SAME: %[[A:.*]]: !fir.ref<f32> {fir.bindc_name = "a"},
138 ! CHECK-SAME: %[[B:.*]]: !fir.ref<f32> {fir.bindc_name = "b"}
139 ! CHECK: %[[FCTRES:.*]] = fir.alloca f32
140 ! CHECK: %[[A_VAL:.*]] = fir.load %[[A]] : !fir.ref<f32>
141 ! CHECK: %[[B_VAL:.*]] = fir.load %[[B]] : !fir.ref<f32>
142 ! CHECK: %[[ADD:.*]] = arith.addf %[[A_VAL]], %[[B_VAL]] {{.*}}: f32
143 ! CHECK: fir.store %[[ADD]] to %[[FCTRES]] : !fir.ref<f32>
144 ! CHECK: %[[RET:.*]] = fir.load %[[FCTRES]] : !fir.ref<f32>
145 ! CHECK: return %[[RET]] : f32
147 real function subf(a, b)
148 real :: a, b
149 subf = a - b
152 ! CHECK-LABEL: func @_QPsubf(
153 ! CHECK-SAME: %[[A:.*]]: !fir.ref<f32> {fir.bindc_name = "a"},
154 ! CHECK-SAME: %[[B:.*]]: !fir.ref<f32> {fir.bindc_name = "b"}
155 ! CHECK: %[[FCTRES:.*]] = fir.alloca f32
156 ! CHECK: %[[A_VAL:.*]] = fir.load %[[A]] : !fir.ref<f32>
157 ! CHECK: %[[B_VAL:.*]] = fir.load %[[B]] : !fir.ref<f32>
158 ! CHECK: %[[SUB:.*]] = arith.subf %[[A_VAL]], %[[B_VAL]] {{.*}}: f32
159 ! CHECK: fir.store %[[SUB]] to %[[FCTRES]] : !fir.ref<f32>
160 ! CHECK: %[[RET:.*]] = fir.load %[[FCTRES]] : !fir.ref<f32>
161 ! CHECK: return %[[RET]] : f32
163 real function mulf(a, b)
164 real :: a, b
165 mulf = a * b
168 ! CHECK-LABEL: func @_QPmulf(
169 ! CHECK-SAME: %[[A:.*]]: !fir.ref<f32> {fir.bindc_name = "a"},
170 ! CHECK-SAME: %[[B:.*]]: !fir.ref<f32> {fir.bindc_name = "b"}
171 ! CHECK: %[[FCTRES:.*]] = fir.alloca f32
172 ! CHECK: %[[A_VAL:.*]] = fir.load %[[A]] : !fir.ref<f32>
173 ! CHECK: %[[B_VAL:.*]] = fir.load %[[B]] : !fir.ref<f32>
174 ! CHECK: %[[MUL:.*]] = arith.mulf %[[A_VAL]], %[[B_VAL]] {{.*}}: f32
175 ! CHECK: fir.store %[[MUL]] to %[[FCTRES]] : !fir.ref<f32>
176 ! CHECK: %[[RET:.*]] = fir.load %[[FCTRES]] : !fir.ref<f32>
177 ! CHECK: return %[[RET]] : f32
179 real function divf(a, b)
180 real :: a, b
181 divf = a / b
184 ! CHECK-LABEL: func @_QPdivf(
185 ! CHECK-SAME: %[[A:.*]]: !fir.ref<f32> {fir.bindc_name = "a"},
186 ! CHECK-SAME: %[[B:.*]]: !fir.ref<f32> {fir.bindc_name = "b"}
187 ! CHECK: %[[FCTRES:.*]] = fir.alloca f32
188 ! CHECK: %[[A_VAL:.*]] = fir.load %[[A]] : !fir.ref<f32>
189 ! CHECK: %[[B_VAL:.*]] = fir.load %[[B]] : !fir.ref<f32>
190 ! CHECK: %[[DIV:.*]] = arith.divf %[[A_VAL]], %[[B_VAL]] {{.*}}: f32
191 ! CHECK: fir.store %[[DIV]] to %[[FCTRES]] : !fir.ref<f32>
192 ! CHECK: %[[RET:.*]] = fir.load %[[FCTRES]] : !fir.ref<f32>
193 ! CHECK: return %[[RET]] : f32
195 complex function addc(a, b)
196 complex :: a, b
197 addc = a + b
200 ! CHECK-LABEL: func @_QPaddc(
201 ! CHECK-SAME: %[[A:.*]]: !fir.ref<!fir.complex<4>> {fir.bindc_name = "a"},
202 ! CHECK-SAME: %[[B:.*]]: !fir.ref<!fir.complex<4>> {fir.bindc_name = "b"}
203 ! CHECK: %[[FCTRES:.*]] = fir.alloca !fir.complex<4>
204 ! CHECK: %[[A_VAL:.*]] = fir.load %[[A]] : !fir.ref<!fir.complex<4>>
205 ! CHECK: %[[B_VAL:.*]] = fir.load %[[B]] : !fir.ref<!fir.complex<4>>
206 ! CHECK: %[[ADD:.*]] = fir.addc %[[A_VAL]], %[[B_VAL]] : !fir.complex<4>
207 ! CHECK: fir.store %[[ADD]] to %[[FCTRES]] : !fir.ref<!fir.complex<4>>
208 ! CHECK: %[[RET:.*]] = fir.load %[[FCTRES]] : !fir.ref<!fir.complex<4>>
209 ! CHECK: return %[[RET]] : !fir.complex<4>
211 complex function subc(a, b)
212 complex :: a, b
213 subc = a - b
216 ! CHECK-LABEL: func @_QPsubc(
217 ! CHECK-SAME: %[[A:.*]]: !fir.ref<!fir.complex<4>> {fir.bindc_name = "a"},
218 ! CHECK-SAME: %[[B:.*]]: !fir.ref<!fir.complex<4>> {fir.bindc_name = "b"}
219 ! CHECK: %[[FCTRES:.*]] = fir.alloca !fir.complex<4>
220 ! CHECK: %[[A_VAL:.*]] = fir.load %[[A]] : !fir.ref<!fir.complex<4>>
221 ! CHECK: %[[B_VAL:.*]] = fir.load %[[B]] : !fir.ref<!fir.complex<4>>
222 ! CHECK: %[[SUB:.*]] = fir.subc %[[A_VAL]], %[[B_VAL]] : !fir.complex<4>
223 ! CHECK: fir.store %[[SUB]] to %[[FCTRES]] : !fir.ref<!fir.complex<4>>
224 ! CHECK: %[[RET:.*]] = fir.load %[[FCTRES]] : !fir.ref<!fir.complex<4>>
225 ! CHECK: return %[[RET]] : !fir.complex<4>
227 complex function mulc(a, b)
228 complex :: a, b
229 mulc = a * b
232 ! CHECK-LABEL: func @_QPmulc(
233 ! CHECK-SAME: %[[A:.*]]: !fir.ref<!fir.complex<4>> {fir.bindc_name = "a"},
234 ! CHECK-SAME: %[[B:.*]]: !fir.ref<!fir.complex<4>> {fir.bindc_name = "b"}
235 ! CHECK: %[[FCTRES:.*]] = fir.alloca !fir.complex<4>
236 ! CHECK: %[[A_VAL:.*]] = fir.load %[[A]] : !fir.ref<!fir.complex<4>>
237 ! CHECK: %[[B_VAL:.*]] = fir.load %[[B]] : !fir.ref<!fir.complex<4>>
238 ! CHECK: %[[MUL:.*]] = fir.mulc %[[A_VAL]], %[[B_VAL]] : !fir.complex<4>
239 ! CHECK: fir.store %[[MUL]] to %[[FCTRES]] : !fir.ref<!fir.complex<4>>
240 ! CHECK: %[[RET:.*]] = fir.load %[[FCTRES]] : !fir.ref<!fir.complex<4>>
241 ! CHECK: return %[[RET]] : !fir.complex<4>
243 complex function divc(a, b)
244 complex :: a, b
245 divc = a / b
248 ! CHECK-LABEL: func @_QPdivc(
249 ! CHECK-SAME: %[[A:.*]]: !fir.ref<!fir.complex<4>> {fir.bindc_name = "a"},
250 ! CHECK-SAME: %[[B:.*]]: !fir.ref<!fir.complex<4>> {fir.bindc_name = "b"}
251 ! CHECK: %[[FCTRES:.*]] = fir.alloca !fir.complex<4>
252 ! CHECK: %[[A_VAL:.*]] = fir.load %[[A]] : !fir.ref<!fir.complex<4>>
253 ! CHECK: %[[B_VAL:.*]] = fir.load %[[B]] : !fir.ref<!fir.complex<4>>
254 ! CHECK: %[[DIV:.*]] = fir.divc %[[A_VAL]], %[[B_VAL]] : !fir.complex<4>
255 ! CHECK: fir.store %[[DIV]] to %[[FCTRES]] : !fir.ref<!fir.complex<4>>
256 ! CHECK: %[[RET:.*]] = fir.load %[[FCTRES]] : !fir.ref<!fir.complex<4>>
257 ! CHECK: return %[[RET]] : !fir.complex<4>
259 subroutine real_constant()
260 real(2) :: a
261 real(4) :: b
262 real(8) :: c
263 real(10) :: d
264 real(16) :: e
265 a = 2.0_2
266 b = 4.0_4
267 c = 8.0_8
268 d = 10.0_10
269 e = 16.0_16
272 ! CHECK: %[[A:.*]] = fir.alloca f16
273 ! CHECK: %[[B:.*]] = fir.alloca f32
274 ! CHECK: %[[C:.*]] = fir.alloca f64
275 ! CHECK: %[[D:.*]] = fir.alloca f80
276 ! CHECK: %[[E:.*]] = fir.alloca f128
277 ! CHECK: %[[C2:.*]] = arith.constant 2.000000e+00 : f16
278 ! CHECK: fir.store %[[C2]] to %[[A]] : !fir.ref<f16>
279 ! CHECK: %[[C4:.*]] = arith.constant 4.000000e+00 : f32
280 ! CHECK: fir.store %[[C4]] to %[[B]] : !fir.ref<f32>
281 ! CHECK: %[[C8:.*]] = arith.constant 8.000000e+00 : f64
282 ! CHECK: fir.store %[[C8]] to %[[C]] : !fir.ref<f64>
283 ! CHECK: %[[C10:.*]] = arith.constant 1.000000e+01 : f80
284 ! CHECK: fir.store %[[C10]] to %[[D]] : !fir.ref<f80>
285 ! CHECK: %[[C16:.*]] = arith.constant 1.600000e+01 : f128
286 ! CHECK: fir.store %[[C16]] to %[[E]] : !fir.ref<f128>
288 subroutine complex_constant()
289 complex(4) :: a
290 a = (0, 1)
293 ! CHECK-LABEL: func @_QPcomplex_constant()
294 ! CHECK: %[[A:.*]] = fir.alloca !fir.complex<4> {bindc_name = "a", uniq_name = "_QFcomplex_constantEa"}
295 ! CHECK: %[[C0:.*]] = arith.constant 0.000000e+00 : f32
296 ! CHECK: %[[C1:.*]] = arith.constant 1.000000e+00 : f32
297 ! CHECK: %[[UNDEF:.*]] = fir.undefined !fir.complex<4>
298 ! CHECK: %[[INS0:.*]] = fir.insert_value %[[UNDEF]], %[[C0]], [0 : index] : (!fir.complex<4>, f32) -> !fir.complex<4>
299 ! CHECK: %[[INS1:.*]] = fir.insert_value %[[INS0]], %[[C1]], [1 : index] : (!fir.complex<4>, f32) -> !fir.complex<4>
300 ! CHECK: fir.store %[[INS1]] to %[[A]] : !fir.ref<!fir.complex<4>>
302 subroutine sub1_arr(a)
303 integer :: a(10)
304 a(2) = 10
307 ! CHECK-LABEL: func @_QPsub1_arr(
308 ! CHECK-SAME: %[[A:.*]]: !fir.ref<!fir.array<10xi32>> {fir.bindc_name = "a"})
309 ! CHECK-DAG: %[[C10:.*]] = arith.constant 10 : i32
310 ! CHECK-DAG: %[[C2:.*]] = arith.constant 2 : i64
311 ! CHECK-DAG: %[[C1:.*]] = arith.constant 1 : i64
312 ! CHECK: %[[ZERO_BASED_INDEX:.*]] = arith.subi %[[C2]], %[[C1]] : i64
313 ! CHECK: %[[COORD:.*]] = fir.coordinate_of %[[A]], %[[ZERO_BASED_INDEX]] : (!fir.ref<!fir.array<10xi32>>, i64) -> !fir.ref<i32>
314 ! CHECK: fir.store %[[C10]] to %[[COORD]] : !fir.ref<i32>
315 ! CHECK: return
317 subroutine sub2_arr(a)
318 integer :: a(10)
319 a = 10
322 ! CHECK-LABEL: func @_QPsub2_arr(
323 ! CHECK-SAME: %[[A:.*]]: !fir.ref<!fir.array<10xi32>> {fir.bindc_name = "a"})
324 ! CHECK-DAG: %[[C10_0:.*]] = arith.constant 10 : index
325 ! CHECK: %[[SHAPE:.*]] = fir.shape %[[C10_0]] : (index) -> !fir.shape<1>
326 ! CHECK: %[[LOAD:.*]] = fir.array_load %[[A]](%[[SHAPE]]) : (!fir.ref<!fir.array<10xi32>>, !fir.shape<1>) -> !fir.array<10xi32>
327 ! CHECK-DAG: %[[C10_1:.*]] = arith.constant 10 : i32
328 ! CHECK-DAG: %[[C1:.*]] = arith.constant 1 : index
329 ! CHECK-DAG: %[[C0:.*]] = arith.constant 0 : index
330 ! CHECK-DAG: %[[UB:.*]] = arith.subi %[[C10_0]], %c1 : index
331 ! CHECK: %[[DO_RES:.*]] = fir.do_loop %[[ARG1:.*]] = %[[C0]] to %[[UB]] step %[[C1]] unordered iter_args(%[[ARG2:.*]] = %[[LOAD]]) -> (!fir.array<10xi32>) {
332 ! CHECK: %[[RES:.*]] = fir.array_update %[[ARG2]], %[[C10_1]], %[[ARG1]] : (!fir.array<10xi32>, i32, index) -> !fir.array<10xi32>
333 ! CHECK: fir.result %[[RES]] : !fir.array<10xi32>
334 ! CHECK: }
335 ! CHECK: fir.array_merge_store %[[LOAD]], %[[DO_RES]] to %[[A]] : !fir.array<10xi32>, !fir.array<10xi32>, !fir.ref<!fir.array<10xi32>>
336 ! CHECK: return