re PR fortran/33040 ([ISO_C_BINDING] ICE in gfc_trans_structure_assign)
[gcc.git] / gcc / fortran / trans-expr.c
1 /* Expression translation
2 Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007 Free Software
3 Foundation, Inc.
4 Contributed by Paul Brook <paul@nowt.org>
5 and Steven Bosscher <s.bosscher@student.tudelft.nl>
6
7 This file is part of GCC.
8
9 GCC is free software; you can redistribute it and/or modify it under
10 the terms of the GNU General Public License as published by the Free
11 Software Foundation; either version 3, or (at your option) any later
12 version.
13
14 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
15 WARRANTY; without even the implied warranty of MERCHANTABILITY or
16 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
17 for more details.
18
19 You should have received a copy of the GNU General Public License
20 along with GCC; see the file COPYING3. If not see
21 <http://www.gnu.org/licenses/>. */
22
23 /* trans-expr.c-- generate GENERIC trees for gfc_expr. */
24
25 #include "config.h"
26 #include "system.h"
27 #include "coretypes.h"
28 #include "tree.h"
29 #include "convert.h"
30 #include "ggc.h"
31 #include "toplev.h"
32 #include "real.h"
33 #include "tree-gimple.h"
34 #include "langhooks.h"
35 #include "flags.h"
36 #include "gfortran.h"
37 #include "trans.h"
38 #include "trans-const.h"
39 #include "trans-types.h"
40 #include "trans-array.h"
41 /* Only for gfc_trans_assign and gfc_trans_pointer_assign. */
42 #include "trans-stmt.h"
43 #include "dependency.h"
44
45 static tree gfc_trans_structure_assign (tree dest, gfc_expr * expr);
46 static int gfc_apply_interface_mapping_to_expr (gfc_interface_mapping *,
47 gfc_expr *);
48
49 /* Copy the scalarization loop variables. */
50
51 static void
52 gfc_copy_se_loopvars (gfc_se * dest, gfc_se * src)
53 {
54 dest->ss = src->ss;
55 dest->loop = src->loop;
56 }
57
58
59 /* Initialize a simple expression holder.
60
61 Care must be taken when multiple se are created with the same parent.
62 The child se must be kept in sync. The easiest way is to delay creation
63 of a child se until after after the previous se has been translated. */
64
65 void
66 gfc_init_se (gfc_se * se, gfc_se * parent)
67 {
68 memset (se, 0, sizeof (gfc_se));
69 gfc_init_block (&se->pre);
70 gfc_init_block (&se->post);
71
72 se->parent = parent;
73
74 if (parent)
75 gfc_copy_se_loopvars (se, parent);
76 }
77
78
79 /* Advances to the next SS in the chain. Use this rather than setting
80 se->ss = se->ss->next because all the parents needs to be kept in sync.
81 See gfc_init_se. */
82
83 void
84 gfc_advance_se_ss_chain (gfc_se * se)
85 {
86 gfc_se *p;
87
88 gcc_assert (se != NULL && se->ss != NULL && se->ss != gfc_ss_terminator);
89
90 p = se;
91 /* Walk down the parent chain. */
92 while (p != NULL)
93 {
94 /* Simple consistency check. */
95 gcc_assert (p->parent == NULL || p->parent->ss == p->ss);
96
97 p->ss = p->ss->next;
98
99 p = p->parent;
100 }
101 }
102
103
104 /* Ensures the result of the expression as either a temporary variable
105 or a constant so that it can be used repeatedly. */
106
107 void
108 gfc_make_safe_expr (gfc_se * se)
109 {
110 tree var;
111
112 if (CONSTANT_CLASS_P (se->expr))
113 return;
114
115 /* We need a temporary for this result. */
116 var = gfc_create_var (TREE_TYPE (se->expr), NULL);
117 gfc_add_modify_expr (&se->pre, var, se->expr);
118 se->expr = var;
119 }
120
121
122 /* Return an expression which determines if a dummy parameter is present.
123 Also used for arguments to procedures with multiple entry points. */
124
125 tree
126 gfc_conv_expr_present (gfc_symbol * sym)
127 {
128 tree decl;
129
130 gcc_assert (sym->attr.dummy);
131
132 decl = gfc_get_symbol_decl (sym);
133 if (TREE_CODE (decl) != PARM_DECL)
134 {
135 /* Array parameters use a temporary descriptor, we want the real
136 parameter. */
137 gcc_assert (GFC_DESCRIPTOR_TYPE_P (TREE_TYPE (decl))
138 || GFC_ARRAY_TYPE_P (TREE_TYPE (decl)));
139 decl = GFC_DECL_SAVED_DESCRIPTOR (decl);
140 }
141 return build2 (NE_EXPR, boolean_type_node, decl,
142 fold_convert (TREE_TYPE (decl), null_pointer_node));
143 }
144
145
146 /* Converts a missing, dummy argument into a null or zero. */
147
148 void
149 gfc_conv_missing_dummy (gfc_se * se, gfc_expr * arg, gfc_typespec ts)
150 {
151 tree present;
152 tree tmp;
153
154 present = gfc_conv_expr_present (arg->symtree->n.sym);
155 tmp = build3 (COND_EXPR, TREE_TYPE (se->expr), present, se->expr,
156 fold_convert (TREE_TYPE (se->expr), integer_zero_node));
157
158 tmp = gfc_evaluate_now (tmp, &se->pre);
159 se->expr = tmp;
160 if (ts.type == BT_CHARACTER)
161 {
162 tmp = build_int_cst (gfc_charlen_type_node, 0);
163 tmp = build3 (COND_EXPR, gfc_charlen_type_node, present,
164 se->string_length, tmp);
165 tmp = gfc_evaluate_now (tmp, &se->pre);
166 se->string_length = tmp;
167 }
168 return;
169 }
170
171
172 /* Get the character length of an expression, looking through gfc_refs
173 if necessary. */
174
175 tree
176 gfc_get_expr_charlen (gfc_expr *e)
177 {
178 gfc_ref *r;
179 tree length;
180
181 gcc_assert (e->expr_type == EXPR_VARIABLE
182 && e->ts.type == BT_CHARACTER);
183
184 length = NULL; /* To silence compiler warning. */
185
186 /* First candidate: if the variable is of type CHARACTER, the
187 expression's length could be the length of the character
188 variable. */
189 if (e->symtree->n.sym->ts.type == BT_CHARACTER)
190 length = e->symtree->n.sym->ts.cl->backend_decl;
191
192 /* Look through the reference chain for component references. */
193 for (r = e->ref; r; r = r->next)
194 {
195 switch (r->type)
196 {
197 case REF_COMPONENT:
198 if (r->u.c.component->ts.type == BT_CHARACTER)
199 length = r->u.c.component->ts.cl->backend_decl;
200 break;
201
202 case REF_ARRAY:
203 /* Do nothing. */
204 break;
205
206 default:
207 /* We should never got substring references here. These will be
208 broken down by the scalarizer. */
209 gcc_unreachable ();
210 }
211 }
212
213 gcc_assert (length != NULL);
214 return length;
215 }
216
217
218
219 /* Generate code to initialize a string length variable. Returns the
220 value. */
221
222 void
223 gfc_conv_string_length (gfc_charlen * cl, stmtblock_t * pblock)
224 {
225 gfc_se se;
226
227 gfc_init_se (&se, NULL);
228 gfc_conv_expr_type (&se, cl->length, gfc_charlen_type_node);
229 se.expr = fold_build2 (MAX_EXPR, gfc_charlen_type_node, se.expr,
230 build_int_cst (gfc_charlen_type_node, 0));
231 gfc_add_block_to_block (pblock, &se.pre);
232
233 if (cl->backend_decl)
234 gfc_add_modify_expr (pblock, cl->backend_decl, se.expr);
235 else
236 cl->backend_decl = gfc_evaluate_now (se.expr, pblock);
237 }
238
239
240 static void
241 gfc_conv_substring (gfc_se * se, gfc_ref * ref, int kind,
242 const char *name, locus *where)
243 {
244 tree tmp;
245 tree type;
246 tree var;
247 tree fault;
248 gfc_se start;
249 gfc_se end;
250 char *msg;
251
252 type = gfc_get_character_type (kind, ref->u.ss.length);
253 type = build_pointer_type (type);
254
255 var = NULL_TREE;
256 gfc_init_se (&start, se);
257 gfc_conv_expr_type (&start, ref->u.ss.start, gfc_charlen_type_node);
258 gfc_add_block_to_block (&se->pre, &start.pre);
259
260 if (integer_onep (start.expr))
261 gfc_conv_string_parameter (se);
262 else
263 {
264 /* Avoid multiple evaluation of substring start. */
265 if (!CONSTANT_CLASS_P (start.expr) && !DECL_P (start.expr))
266 start.expr = gfc_evaluate_now (start.expr, &se->pre);
267
268 /* Change the start of the string. */
269 if (TYPE_STRING_FLAG (TREE_TYPE (se->expr)))
270 tmp = se->expr;
271 else
272 tmp = build_fold_indirect_ref (se->expr);
273 tmp = gfc_build_array_ref (tmp, start.expr);
274 se->expr = gfc_build_addr_expr (type, tmp);
275 }
276
277 /* Length = end + 1 - start. */
278 gfc_init_se (&end, se);
279 if (ref->u.ss.end == NULL)
280 end.expr = se->string_length;
281 else
282 {
283 gfc_conv_expr_type (&end, ref->u.ss.end, gfc_charlen_type_node);
284 gfc_add_block_to_block (&se->pre, &end.pre);
285 }
286 if (!CONSTANT_CLASS_P (end.expr) && !DECL_P (end.expr))
287 end.expr = gfc_evaluate_now (end.expr, &se->pre);
288
289 if (flag_bounds_check)
290 {
291 tree nonempty = fold_build2 (LE_EXPR, boolean_type_node,
292 start.expr, end.expr);
293
294 /* Check lower bound. */
295 fault = fold_build2 (LT_EXPR, boolean_type_node, start.expr,
296 build_int_cst (gfc_charlen_type_node, 1));
297 fault = fold_build2 (TRUTH_ANDIF_EXPR, boolean_type_node,
298 nonempty, fault);
299 if (name)
300 asprintf (&msg, "Substring out of bounds: lower bound (%%ld) of '%s' "
301 "is less than one", name);
302 else
303 asprintf (&msg, "Substring out of bounds: lower bound (%%ld)"
304 "is less than one");
305 gfc_trans_runtime_check (fault, &se->pre, where, msg,
306 fold_convert (long_integer_type_node,
307 start.expr));
308 gfc_free (msg);
309
310 /* Check upper bound. */
311 fault = fold_build2 (GT_EXPR, boolean_type_node, end.expr,
312 se->string_length);
313 fault = fold_build2 (TRUTH_ANDIF_EXPR, boolean_type_node,
314 nonempty, fault);
315 if (name)
316 asprintf (&msg, "Substring out of bounds: upper bound (%%ld) of '%s' "
317 "exceeds string length (%%ld)", name);
318 else
319 asprintf (&msg, "Substring out of bounds: upper bound (%%ld) "
320 "exceeds string length (%%ld)");
321 gfc_trans_runtime_check (fault, &se->pre, where, msg,
322 fold_convert (long_integer_type_node, end.expr),
323 fold_convert (long_integer_type_node,
324 se->string_length));
325 gfc_free (msg);
326 }
327
328 tmp = fold_build2 (MINUS_EXPR, gfc_charlen_type_node,
329 build_int_cst (gfc_charlen_type_node, 1),
330 start.expr);
331 tmp = fold_build2 (PLUS_EXPR, gfc_charlen_type_node, end.expr, tmp);
332 tmp = fold_build2 (MAX_EXPR, gfc_charlen_type_node, tmp,
333 build_int_cst (gfc_charlen_type_node, 0));
334 se->string_length = tmp;
335 }
336
337
338 /* Convert a derived type component reference. */
339
340 static void
341 gfc_conv_component_ref (gfc_se * se, gfc_ref * ref)
342 {
343 gfc_component *c;
344 tree tmp;
345 tree decl;
346 tree field;
347
348 c = ref->u.c.component;
349
350 gcc_assert (c->backend_decl);
351
352 field = c->backend_decl;
353 gcc_assert (TREE_CODE (field) == FIELD_DECL);
354 decl = se->expr;
355 tmp = build3 (COMPONENT_REF, TREE_TYPE (field), decl, field, NULL_TREE);
356
357 se->expr = tmp;
358
359 if (c->ts.type == BT_CHARACTER)
360 {
361 tmp = c->ts.cl->backend_decl;
362 /* Components must always be constant length. */
363 gcc_assert (tmp && INTEGER_CST_P (tmp));
364 se->string_length = tmp;
365 }
366
367 if (c->pointer && c->dimension == 0 && c->ts.type != BT_CHARACTER)
368 se->expr = build_fold_indirect_ref (se->expr);
369 }
370
371
372 /* Return the contents of a variable. Also handles reference/pointer
373 variables (all Fortran pointer references are implicit). */
374
375 static void
376 gfc_conv_variable (gfc_se * se, gfc_expr * expr)
377 {
378 gfc_ref *ref;
379 gfc_symbol *sym;
380 tree parent_decl;
381 int parent_flag;
382 bool return_value;
383 bool alternate_entry;
384 bool entry_master;
385
386 sym = expr->symtree->n.sym;
387 if (se->ss != NULL)
388 {
389 /* Check that something hasn't gone horribly wrong. */
390 gcc_assert (se->ss != gfc_ss_terminator);
391 gcc_assert (se->ss->expr == expr);
392
393 /* A scalarized term. We already know the descriptor. */
394 se->expr = se->ss->data.info.descriptor;
395 se->string_length = se->ss->string_length;
396 for (ref = se->ss->data.info.ref; ref; ref = ref->next)
397 if (ref->type == REF_ARRAY && ref->u.ar.type != AR_ELEMENT)
398 break;
399 }
400 else
401 {
402 tree se_expr = NULL_TREE;
403
404 se->expr = gfc_get_symbol_decl (sym);
405
406 /* Deal with references to a parent results or entries by storing
407 the current_function_decl and moving to the parent_decl. */
408 return_value = sym->attr.function && sym->result == sym;
409 alternate_entry = sym->attr.function && sym->attr.entry
410 && sym->result == sym;
411 entry_master = sym->attr.result
412 && sym->ns->proc_name->attr.entry_master
413 && !gfc_return_by_reference (sym->ns->proc_name);
414 parent_decl = DECL_CONTEXT (current_function_decl);
415
416 if ((se->expr == parent_decl && return_value)
417 || (sym->ns && sym->ns->proc_name
418 && parent_decl
419 && sym->ns->proc_name->backend_decl == parent_decl
420 && (alternate_entry || entry_master)))
421 parent_flag = 1;
422 else
423 parent_flag = 0;
424
425 /* Special case for assigning the return value of a function.
426 Self recursive functions must have an explicit return value. */
427 if (return_value && (se->expr == current_function_decl || parent_flag))
428 se_expr = gfc_get_fake_result_decl (sym, parent_flag);
429
430 /* Similarly for alternate entry points. */
431 else if (alternate_entry
432 && (sym->ns->proc_name->backend_decl == current_function_decl
433 || parent_flag))
434 {
435 gfc_entry_list *el = NULL;
436
437 for (el = sym->ns->entries; el; el = el->next)
438 if (sym == el->sym)
439 {
440 se_expr = gfc_get_fake_result_decl (sym, parent_flag);
441 break;
442 }
443 }
444
445 else if (entry_master
446 && (sym->ns->proc_name->backend_decl == current_function_decl
447 || parent_flag))
448 se_expr = gfc_get_fake_result_decl (sym, parent_flag);
449
450 if (se_expr)
451 se->expr = se_expr;
452
453 /* Procedure actual arguments. */
454 else if (sym->attr.flavor == FL_PROCEDURE
455 && se->expr != current_function_decl)
456 {
457 gcc_assert (se->want_pointer);
458 if (!sym->attr.dummy)
459 {
460 gcc_assert (TREE_CODE (se->expr) == FUNCTION_DECL);
461 se->expr = build_fold_addr_expr (se->expr);
462 }
463 return;
464 }
465
466
467 /* Dereference the expression, where needed. Since characters
468 are entirely different from other types, they are treated
469 separately. */
470 if (sym->ts.type == BT_CHARACTER)
471 {
472 /* Dereference character pointer dummy arguments
473 or results. */
474 if ((sym->attr.pointer || sym->attr.allocatable)
475 && (sym->attr.dummy
476 || sym->attr.function
477 || sym->attr.result))
478 se->expr = build_fold_indirect_ref (se->expr);
479
480 }
481 else if (!sym->attr.value)
482 {
483 /* Dereference non-character scalar dummy arguments. */
484 if (sym->attr.dummy && !sym->attr.dimension)
485 se->expr = build_fold_indirect_ref (se->expr);
486
487 /* Dereference scalar hidden result. */
488 if (gfc_option.flag_f2c && sym->ts.type == BT_COMPLEX
489 && (sym->attr.function || sym->attr.result)
490 && !sym->attr.dimension && !sym->attr.pointer)
491 se->expr = build_fold_indirect_ref (se->expr);
492
493 /* Dereference non-character pointer variables.
494 These must be dummies, results, or scalars. */
495 if ((sym->attr.pointer || sym->attr.allocatable)
496 && (sym->attr.dummy
497 || sym->attr.function
498 || sym->attr.result
499 || !sym->attr.dimension))
500 se->expr = build_fold_indirect_ref (se->expr);
501 }
502
503 ref = expr->ref;
504 }
505
506 /* For character variables, also get the length. */
507 if (sym->ts.type == BT_CHARACTER)
508 {
509 /* If the character length of an entry isn't set, get the length from
510 the master function instead. */
511 if (sym->attr.entry && !sym->ts.cl->backend_decl)
512 se->string_length = sym->ns->proc_name->ts.cl->backend_decl;
513 else
514 se->string_length = sym->ts.cl->backend_decl;
515 gcc_assert (se->string_length);
516 }
517
518 while (ref)
519 {
520 switch (ref->type)
521 {
522 case REF_ARRAY:
523 /* Return the descriptor if that's what we want and this is an array
524 section reference. */
525 if (se->descriptor_only && ref->u.ar.type != AR_ELEMENT)
526 return;
527 /* TODO: Pointers to single elements of array sections, eg elemental subs. */
528 /* Return the descriptor for array pointers and allocations. */
529 if (se->want_pointer
530 && ref->next == NULL && (se->descriptor_only))
531 return;
532
533 gfc_conv_array_ref (se, &ref->u.ar, sym, &expr->where);
534 /* Return a pointer to an element. */
535 break;
536
537 case REF_COMPONENT:
538 gfc_conv_component_ref (se, ref);
539 break;
540
541 case REF_SUBSTRING:
542 gfc_conv_substring (se, ref, expr->ts.kind,
543 expr->symtree->name, &expr->where);
544 break;
545
546 default:
547 gcc_unreachable ();
548 break;
549 }
550 ref = ref->next;
551 }
552 /* Pointer assignment, allocation or pass by reference. Arrays are handled
553 separately. */
554 if (se->want_pointer)
555 {
556 if (expr->ts.type == BT_CHARACTER)
557 gfc_conv_string_parameter (se);
558 else
559 se->expr = build_fold_addr_expr (se->expr);
560 }
561 }
562
563
564 /* Unary ops are easy... Or they would be if ! was a valid op. */
565
566 static void
567 gfc_conv_unary_op (enum tree_code code, gfc_se * se, gfc_expr * expr)
568 {
569 gfc_se operand;
570 tree type;
571
572 gcc_assert (expr->ts.type != BT_CHARACTER);
573 /* Initialize the operand. */
574 gfc_init_se (&operand, se);
575 gfc_conv_expr_val (&operand, expr->value.op.op1);
576 gfc_add_block_to_block (&se->pre, &operand.pre);
577
578 type = gfc_typenode_for_spec (&expr->ts);
579
580 /* TRUTH_NOT_EXPR is not a "true" unary operator in GCC.
581 We must convert it to a compare to 0 (e.g. EQ_EXPR (op1, 0)).
582 All other unary operators have an equivalent GIMPLE unary operator. */
583 if (code == TRUTH_NOT_EXPR)
584 se->expr = build2 (EQ_EXPR, type, operand.expr,
585 build_int_cst (type, 0));
586 else
587 se->expr = build1 (code, type, operand.expr);
588
589 }
590
591 /* Expand power operator to optimal multiplications when a value is raised
592 to a constant integer n. See section 4.6.3, "Evaluation of Powers" of
593 Donald E. Knuth, "Seminumerical Algorithms", Vol. 2, "The Art of Computer
594 Programming", 3rd Edition, 1998. */
595
596 /* This code is mostly duplicated from expand_powi in the backend.
597 We establish the "optimal power tree" lookup table with the defined size.
598 The items in the table are the exponents used to calculate the index
599 exponents. Any integer n less than the value can get an "addition chain",
600 with the first node being one. */
601 #define POWI_TABLE_SIZE 256
602
603 /* The table is from builtins.c. */
604 static const unsigned char powi_table[POWI_TABLE_SIZE] =
605 {
606 0, 1, 1, 2, 2, 3, 3, 4, /* 0 - 7 */
607 4, 6, 5, 6, 6, 10, 7, 9, /* 8 - 15 */
608 8, 16, 9, 16, 10, 12, 11, 13, /* 16 - 23 */
609 12, 17, 13, 18, 14, 24, 15, 26, /* 24 - 31 */
610 16, 17, 17, 19, 18, 33, 19, 26, /* 32 - 39 */
611 20, 25, 21, 40, 22, 27, 23, 44, /* 40 - 47 */
612 24, 32, 25, 34, 26, 29, 27, 44, /* 48 - 55 */
613 28, 31, 29, 34, 30, 60, 31, 36, /* 56 - 63 */
614 32, 64, 33, 34, 34, 46, 35, 37, /* 64 - 71 */
615 36, 65, 37, 50, 38, 48, 39, 69, /* 72 - 79 */
616 40, 49, 41, 43, 42, 51, 43, 58, /* 80 - 87 */
617 44, 64, 45, 47, 46, 59, 47, 76, /* 88 - 95 */
618 48, 65, 49, 66, 50, 67, 51, 66, /* 96 - 103 */
619 52, 70, 53, 74, 54, 104, 55, 74, /* 104 - 111 */
620 56, 64, 57, 69, 58, 78, 59, 68, /* 112 - 119 */
621 60, 61, 61, 80, 62, 75, 63, 68, /* 120 - 127 */
622 64, 65, 65, 128, 66, 129, 67, 90, /* 128 - 135 */
623 68, 73, 69, 131, 70, 94, 71, 88, /* 136 - 143 */
624 72, 128, 73, 98, 74, 132, 75, 121, /* 144 - 151 */
625 76, 102, 77, 124, 78, 132, 79, 106, /* 152 - 159 */
626 80, 97, 81, 160, 82, 99, 83, 134, /* 160 - 167 */
627 84, 86, 85, 95, 86, 160, 87, 100, /* 168 - 175 */
628 88, 113, 89, 98, 90, 107, 91, 122, /* 176 - 183 */
629 92, 111, 93, 102, 94, 126, 95, 150, /* 184 - 191 */
630 96, 128, 97, 130, 98, 133, 99, 195, /* 192 - 199 */
631 100, 128, 101, 123, 102, 164, 103, 138, /* 200 - 207 */
632 104, 145, 105, 146, 106, 109, 107, 149, /* 208 - 215 */
633 108, 200, 109, 146, 110, 170, 111, 157, /* 216 - 223 */
634 112, 128, 113, 130, 114, 182, 115, 132, /* 224 - 231 */
635 116, 200, 117, 132, 118, 158, 119, 206, /* 232 - 239 */
636 120, 240, 121, 162, 122, 147, 123, 152, /* 240 - 247 */
637 124, 166, 125, 214, 126, 138, 127, 153, /* 248 - 255 */
638 };
639
640 /* If n is larger than lookup table's max index, we use the "window
641 method". */
642 #define POWI_WINDOW_SIZE 3
643
644 /* Recursive function to expand the power operator. The temporary
645 values are put in tmpvar. The function returns tmpvar[1] ** n. */
646 static tree
647 gfc_conv_powi (gfc_se * se, unsigned HOST_WIDE_INT n, tree * tmpvar)
648 {
649 tree op0;
650 tree op1;
651 tree tmp;
652 int digit;
653
654 if (n < POWI_TABLE_SIZE)
655 {
656 if (tmpvar[n])
657 return tmpvar[n];
658
659 op0 = gfc_conv_powi (se, n - powi_table[n], tmpvar);
660 op1 = gfc_conv_powi (se, powi_table[n], tmpvar);
661 }
662 else if (n & 1)
663 {
664 digit = n & ((1 << POWI_WINDOW_SIZE) - 1);
665 op0 = gfc_conv_powi (se, n - digit, tmpvar);
666 op1 = gfc_conv_powi (se, digit, tmpvar);
667 }
668 else
669 {
670 op0 = gfc_conv_powi (se, n >> 1, tmpvar);
671 op1 = op0;
672 }
673
674 tmp = fold_build2 (MULT_EXPR, TREE_TYPE (op0), op0, op1);
675 tmp = gfc_evaluate_now (tmp, &se->pre);
676
677 if (n < POWI_TABLE_SIZE)
678 tmpvar[n] = tmp;
679
680 return tmp;
681 }
682
683
684 /* Expand lhs ** rhs. rhs is a constant integer. If it expands successfully,
685 return 1. Else return 0 and a call to runtime library functions
686 will have to be built. */
687 static int
688 gfc_conv_cst_int_power (gfc_se * se, tree lhs, tree rhs)
689 {
690 tree cond;
691 tree tmp;
692 tree type;
693 tree vartmp[POWI_TABLE_SIZE];
694 HOST_WIDE_INT m;
695 unsigned HOST_WIDE_INT n;
696 int sgn;
697
698 /* If exponent is too large, we won't expand it anyway, so don't bother
699 with large integer values. */
700 if (!double_int_fits_in_shwi_p (TREE_INT_CST (rhs)))
701 return 0;
702
703 m = double_int_to_shwi (TREE_INT_CST (rhs));
704 /* There's no ABS for HOST_WIDE_INT, so here we go. It also takes care
705 of the asymmetric range of the integer type. */
706 n = (unsigned HOST_WIDE_INT) (m < 0 ? -m : m);
707
708 type = TREE_TYPE (lhs);
709 sgn = tree_int_cst_sgn (rhs);
710
711 if (((FLOAT_TYPE_P (type) && !flag_unsafe_math_optimizations)
712 || optimize_size) && (m > 2 || m < -1))
713 return 0;
714
715 /* rhs == 0 */
716 if (sgn == 0)
717 {
718 se->expr = gfc_build_const (type, integer_one_node);
719 return 1;
720 }
721
722 /* If rhs < 0 and lhs is an integer, the result is -1, 0 or 1. */
723 if ((sgn == -1) && (TREE_CODE (type) == INTEGER_TYPE))
724 {
725 tmp = build2 (EQ_EXPR, boolean_type_node, lhs,
726 build_int_cst (TREE_TYPE (lhs), -1));
727 cond = build2 (EQ_EXPR, boolean_type_node, lhs,
728 build_int_cst (TREE_TYPE (lhs), 1));
729
730 /* If rhs is even,
731 result = (lhs == 1 || lhs == -1) ? 1 : 0. */
732 if ((n & 1) == 0)
733 {
734 tmp = build2 (TRUTH_OR_EXPR, boolean_type_node, tmp, cond);
735 se->expr = build3 (COND_EXPR, type, tmp, build_int_cst (type, 1),
736 build_int_cst (type, 0));
737 return 1;
738 }
739 /* If rhs is odd,
740 result = (lhs == 1) ? 1 : (lhs == -1) ? -1 : 0. */
741 tmp = build3 (COND_EXPR, type, tmp, build_int_cst (type, -1),
742 build_int_cst (type, 0));
743 se->expr = build3 (COND_EXPR, type, cond, build_int_cst (type, 1), tmp);
744 return 1;
745 }
746
747 memset (vartmp, 0, sizeof (vartmp));
748 vartmp[1] = lhs;
749 if (sgn == -1)
750 {
751 tmp = gfc_build_const (type, integer_one_node);
752 vartmp[1] = build2 (RDIV_EXPR, type, tmp, vartmp[1]);
753 }
754
755 se->expr = gfc_conv_powi (se, n, vartmp);
756
757 return 1;
758 }
759
760
761 /* Power op (**). Constant integer exponent has special handling. */
762
763 static void
764 gfc_conv_power_op (gfc_se * se, gfc_expr * expr)
765 {
766 tree gfc_int4_type_node;
767 int kind;
768 int ikind;
769 gfc_se lse;
770 gfc_se rse;
771 tree fndecl;
772
773 gfc_init_se (&lse, se);
774 gfc_conv_expr_val (&lse, expr->value.op.op1);
775 lse.expr = gfc_evaluate_now (lse.expr, &lse.pre);
776 gfc_add_block_to_block (&se->pre, &lse.pre);
777
778 gfc_init_se (&rse, se);
779 gfc_conv_expr_val (&rse, expr->value.op.op2);
780 gfc_add_block_to_block (&se->pre, &rse.pre);
781
782 if (expr->value.op.op2->ts.type == BT_INTEGER
783 && expr->value.op.op2->expr_type == EXPR_CONSTANT)
784 if (gfc_conv_cst_int_power (se, lse.expr, rse.expr))
785 return;
786
787 gfc_int4_type_node = gfc_get_int_type (4);
788
789 kind = expr->value.op.op1->ts.kind;
790 switch (expr->value.op.op2->ts.type)
791 {
792 case BT_INTEGER:
793 ikind = expr->value.op.op2->ts.kind;
794 switch (ikind)
795 {
796 case 1:
797 case 2:
798 rse.expr = convert (gfc_int4_type_node, rse.expr);
799 /* Fall through. */
800
801 case 4:
802 ikind = 0;
803 break;
804
805 case 8:
806 ikind = 1;
807 break;
808
809 case 16:
810 ikind = 2;
811 break;
812
813 default:
814 gcc_unreachable ();
815 }
816 switch (kind)
817 {
818 case 1:
819 case 2:
820 if (expr->value.op.op1->ts.type == BT_INTEGER)
821 lse.expr = convert (gfc_int4_type_node, lse.expr);
822 else
823 gcc_unreachable ();
824 /* Fall through. */
825
826 case 4:
827 kind = 0;
828 break;
829
830 case 8:
831 kind = 1;
832 break;
833
834 case 10:
835 kind = 2;
836 break;
837
838 case 16:
839 kind = 3;
840 break;
841
842 default:
843 gcc_unreachable ();
844 }
845
846 switch (expr->value.op.op1->ts.type)
847 {
848 case BT_INTEGER:
849 if (kind == 3) /* Case 16 was not handled properly above. */
850 kind = 2;
851 fndecl = gfor_fndecl_math_powi[kind][ikind].integer;
852 break;
853
854 case BT_REAL:
855 /* Use builtins for real ** int4. */
856 if (ikind == 0)
857 {
858 switch (kind)
859 {
860 case 0:
861 fndecl = built_in_decls[BUILT_IN_POWIF];
862 break;
863
864 case 1:
865 fndecl = built_in_decls[BUILT_IN_POWI];
866 break;
867
868 case 2:
869 case 3:
870 fndecl = built_in_decls[BUILT_IN_POWIL];
871 break;
872
873 default:
874 gcc_unreachable ();
875 }
876 }
877 else
878 fndecl = gfor_fndecl_math_powi[kind][ikind].real;
879 break;
880
881 case BT_COMPLEX:
882 fndecl = gfor_fndecl_math_powi[kind][ikind].cmplx;
883 break;
884
885 default:
886 gcc_unreachable ();
887 }
888 break;
889
890 case BT_REAL:
891 switch (kind)
892 {
893 case 4:
894 fndecl = built_in_decls[BUILT_IN_POWF];
895 break;
896 case 8:
897 fndecl = built_in_decls[BUILT_IN_POW];
898 break;
899 case 10:
900 case 16:
901 fndecl = built_in_decls[BUILT_IN_POWL];
902 break;
903 default:
904 gcc_unreachable ();
905 }
906 break;
907
908 case BT_COMPLEX:
909 switch (kind)
910 {
911 case 4:
912 fndecl = gfor_fndecl_math_cpowf;
913 break;
914 case 8:
915 fndecl = gfor_fndecl_math_cpow;
916 break;
917 case 10:
918 fndecl = gfor_fndecl_math_cpowl10;
919 break;
920 case 16:
921 fndecl = gfor_fndecl_math_cpowl16;
922 break;
923 default:
924 gcc_unreachable ();
925 }
926 break;
927
928 default:
929 gcc_unreachable ();
930 break;
931 }
932
933 se->expr = build_call_expr (fndecl, 2, lse.expr, rse.expr);
934 }
935
936
937 /* Generate code to allocate a string temporary. */
938
939 tree
940 gfc_conv_string_tmp (gfc_se * se, tree type, tree len)
941 {
942 tree var;
943 tree tmp;
944
945 gcc_assert (TREE_TYPE (len) == gfc_charlen_type_node);
946
947 if (gfc_can_put_var_on_stack (len))
948 {
949 /* Create a temporary variable to hold the result. */
950 tmp = fold_build2 (MINUS_EXPR, gfc_charlen_type_node, len,
951 build_int_cst (gfc_charlen_type_node, 1));
952 tmp = build_range_type (gfc_array_index_type, gfc_index_zero_node, tmp);
953 tmp = build_array_type (gfc_character1_type_node, tmp);
954 var = gfc_create_var (tmp, "str");
955 var = gfc_build_addr_expr (type, var);
956 }
957 else
958 {
959 /* Allocate a temporary to hold the result. */
960 var = gfc_create_var (type, "pstr");
961 tmp = gfc_call_malloc (&se->pre, type, len);
962 gfc_add_modify_expr (&se->pre, var, tmp);
963
964 /* Free the temporary afterwards. */
965 tmp = gfc_call_free (convert (pvoid_type_node, var));
966 gfc_add_expr_to_block (&se->post, tmp);
967 }
968
969 return var;
970 }
971
972
973 /* Handle a string concatenation operation. A temporary will be allocated to
974 hold the result. */
975
976 static void
977 gfc_conv_concat_op (gfc_se * se, gfc_expr * expr)
978 {
979 gfc_se lse;
980 gfc_se rse;
981 tree len;
982 tree type;
983 tree var;
984 tree tmp;
985
986 gcc_assert (expr->value.op.op1->ts.type == BT_CHARACTER
987 && expr->value.op.op2->ts.type == BT_CHARACTER);
988
989 gfc_init_se (&lse, se);
990 gfc_conv_expr (&lse, expr->value.op.op1);
991 gfc_conv_string_parameter (&lse);
992 gfc_init_se (&rse, se);
993 gfc_conv_expr (&rse, expr->value.op.op2);
994 gfc_conv_string_parameter (&rse);
995
996 gfc_add_block_to_block (&se->pre, &lse.pre);
997 gfc_add_block_to_block (&se->pre, &rse.pre);
998
999 type = gfc_get_character_type (expr->ts.kind, expr->ts.cl);
1000 len = TYPE_MAX_VALUE (TYPE_DOMAIN (type));
1001 if (len == NULL_TREE)
1002 {
1003 len = fold_build2 (PLUS_EXPR, TREE_TYPE (lse.string_length),
1004 lse.string_length, rse.string_length);
1005 }
1006
1007 type = build_pointer_type (type);
1008
1009 var = gfc_conv_string_tmp (se, type, len);
1010
1011 /* Do the actual concatenation. */
1012 tmp = build_call_expr (gfor_fndecl_concat_string, 6,
1013 len, var,
1014 lse.string_length, lse.expr,
1015 rse.string_length, rse.expr);
1016 gfc_add_expr_to_block (&se->pre, tmp);
1017
1018 /* Add the cleanup for the operands. */
1019 gfc_add_block_to_block (&se->pre, &rse.post);
1020 gfc_add_block_to_block (&se->pre, &lse.post);
1021
1022 se->expr = var;
1023 se->string_length = len;
1024 }
1025
1026 /* Translates an op expression. Common (binary) cases are handled by this
1027 function, others are passed on. Recursion is used in either case.
1028 We use the fact that (op1.ts == op2.ts) (except for the power
1029 operator **).
1030 Operators need no special handling for scalarized expressions as long as
1031 they call gfc_conv_simple_val to get their operands.
1032 Character strings get special handling. */
1033
1034 static void
1035 gfc_conv_expr_op (gfc_se * se, gfc_expr * expr)
1036 {
1037 enum tree_code code;
1038 gfc_se lse;
1039 gfc_se rse;
1040 tree tmp, type;
1041 int lop;
1042 int checkstring;
1043
1044 checkstring = 0;
1045 lop = 0;
1046 switch (expr->value.op.operator)
1047 {
1048 case INTRINSIC_UPLUS:
1049 case INTRINSIC_PARENTHESES:
1050 gfc_conv_expr (se, expr->value.op.op1);
1051 return;
1052
1053 case INTRINSIC_UMINUS:
1054 gfc_conv_unary_op (NEGATE_EXPR, se, expr);
1055 return;
1056
1057 case INTRINSIC_NOT:
1058 gfc_conv_unary_op (TRUTH_NOT_EXPR, se, expr);
1059 return;
1060
1061 case INTRINSIC_PLUS:
1062 code = PLUS_EXPR;
1063 break;
1064
1065 case INTRINSIC_MINUS:
1066 code = MINUS_EXPR;
1067 break;
1068
1069 case INTRINSIC_TIMES:
1070 code = MULT_EXPR;
1071 break;
1072
1073 case INTRINSIC_DIVIDE:
1074 /* If expr is a real or complex expr, use an RDIV_EXPR. If op1 is
1075 an integer, we must round towards zero, so we use a
1076 TRUNC_DIV_EXPR. */
1077 if (expr->ts.type == BT_INTEGER)
1078 code = TRUNC_DIV_EXPR;
1079 else
1080 code = RDIV_EXPR;
1081 break;
1082
1083 case INTRINSIC_POWER:
1084 gfc_conv_power_op (se, expr);
1085 return;
1086
1087 case INTRINSIC_CONCAT:
1088 gfc_conv_concat_op (se, expr);
1089 return;
1090
1091 case INTRINSIC_AND:
1092 code = TRUTH_ANDIF_EXPR;
1093 lop = 1;
1094 break;
1095
1096 case INTRINSIC_OR:
1097 code = TRUTH_ORIF_EXPR;
1098 lop = 1;
1099 break;
1100
1101 /* EQV and NEQV only work on logicals, but since we represent them
1102 as integers, we can use EQ_EXPR and NE_EXPR for them in GIMPLE. */
1103 case INTRINSIC_EQ:
1104 case INTRINSIC_EQ_OS:
1105 case INTRINSIC_EQV:
1106 code = EQ_EXPR;
1107 checkstring = 1;
1108 lop = 1;
1109 break;
1110
1111 case INTRINSIC_NE:
1112 case INTRINSIC_NE_OS:
1113 case INTRINSIC_NEQV:
1114 code = NE_EXPR;
1115 checkstring = 1;
1116 lop = 1;
1117 break;
1118
1119 case INTRINSIC_GT:
1120 case INTRINSIC_GT_OS:
1121 code = GT_EXPR;
1122 checkstring = 1;
1123 lop = 1;
1124 break;
1125
1126 case INTRINSIC_GE:
1127 case INTRINSIC_GE_OS:
1128 code = GE_EXPR;
1129 checkstring = 1;
1130 lop = 1;
1131 break;
1132
1133 case INTRINSIC_LT:
1134 case INTRINSIC_LT_OS:
1135 code = LT_EXPR;
1136 checkstring = 1;
1137 lop = 1;
1138 break;
1139
1140 case INTRINSIC_LE:
1141 case INTRINSIC_LE_OS:
1142 code = LE_EXPR;
1143 checkstring = 1;
1144 lop = 1;
1145 break;
1146
1147 case INTRINSIC_USER:
1148 case INTRINSIC_ASSIGN:
1149 /* These should be converted into function calls by the frontend. */
1150 gcc_unreachable ();
1151
1152 default:
1153 fatal_error ("Unknown intrinsic op");
1154 return;
1155 }
1156
1157 /* The only exception to this is **, which is handled separately anyway. */
1158 gcc_assert (expr->value.op.op1->ts.type == expr->value.op.op2->ts.type);
1159
1160 if (checkstring && expr->value.op.op1->ts.type != BT_CHARACTER)
1161 checkstring = 0;
1162
1163 /* lhs */
1164 gfc_init_se (&lse, se);
1165 gfc_conv_expr (&lse, expr->value.op.op1);
1166 gfc_add_block_to_block (&se->pre, &lse.pre);
1167
1168 /* rhs */
1169 gfc_init_se (&rse, se);
1170 gfc_conv_expr (&rse, expr->value.op.op2);
1171 gfc_add_block_to_block (&se->pre, &rse.pre);
1172
1173 if (checkstring)
1174 {
1175 gfc_conv_string_parameter (&lse);
1176 gfc_conv_string_parameter (&rse);
1177
1178 lse.expr = gfc_build_compare_string (lse.string_length, lse.expr,
1179 rse.string_length, rse.expr);
1180 rse.expr = build_int_cst (TREE_TYPE (lse.expr), 0);
1181 gfc_add_block_to_block (&lse.post, &rse.post);
1182 }
1183
1184 type = gfc_typenode_for_spec (&expr->ts);
1185
1186 if (lop)
1187 {
1188 /* The result of logical ops is always boolean_type_node. */
1189 tmp = fold_build2 (code, boolean_type_node, lse.expr, rse.expr);
1190 se->expr = convert (type, tmp);
1191 }
1192 else
1193 se->expr = fold_build2 (code, type, lse.expr, rse.expr);
1194
1195 /* Add the post blocks. */
1196 gfc_add_block_to_block (&se->post, &rse.post);
1197 gfc_add_block_to_block (&se->post, &lse.post);
1198 }
1199
1200 /* If a string's length is one, we convert it to a single character. */
1201
1202 static tree
1203 gfc_to_single_character (tree len, tree str)
1204 {
1205 gcc_assert (POINTER_TYPE_P (TREE_TYPE (str)));
1206
1207 if (INTEGER_CST_P (len) && TREE_INT_CST_LOW (len) == 1
1208 && TREE_INT_CST_HIGH (len) == 0)
1209 {
1210 str = fold_convert (pchar_type_node, str);
1211 return build_fold_indirect_ref (str);
1212 }
1213
1214 return NULL_TREE;
1215 }
1216
1217
1218 void
1219 gfc_conv_scalar_char_value (gfc_symbol *sym, gfc_se *se, gfc_expr **expr)
1220 {
1221
1222 if (sym->backend_decl)
1223 {
1224 /* This becomes the nominal_type in
1225 function.c:assign_parm_find_data_types. */
1226 TREE_TYPE (sym->backend_decl) = unsigned_char_type_node;
1227 /* This becomes the passed_type in
1228 function.c:assign_parm_find_data_types. C promotes char to
1229 integer for argument passing. */
1230 DECL_ARG_TYPE (sym->backend_decl) = unsigned_type_node;
1231
1232 DECL_BY_REFERENCE (sym->backend_decl) = 0;
1233 }
1234
1235 if (expr != NULL)
1236 {
1237 /* If we have a constant character expression, make it into an
1238 integer. */
1239 if ((*expr)->expr_type == EXPR_CONSTANT)
1240 {
1241 gfc_typespec ts;
1242
1243 *expr = gfc_int_expr ((int)(*expr)->value.character.string[0]);
1244 if ((*expr)->ts.kind != gfc_c_int_kind)
1245 {
1246 /* The expr needs to be compatible with a C int. If the
1247 conversion fails, then the 2 causes an ICE. */
1248 ts.type = BT_INTEGER;
1249 ts.kind = gfc_c_int_kind;
1250 gfc_convert_type (*expr, &ts, 2);
1251 }
1252 }
1253 else if (se != NULL && (*expr)->expr_type == EXPR_VARIABLE)
1254 {
1255 if ((*expr)->ref == NULL)
1256 {
1257 se->expr = gfc_to_single_character
1258 (build_int_cst (integer_type_node, 1),
1259 gfc_build_addr_expr (pchar_type_node,
1260 gfc_get_symbol_decl
1261 ((*expr)->symtree->n.sym)));
1262 }
1263 else
1264 {
1265 gfc_conv_variable (se, *expr);
1266 se->expr = gfc_to_single_character
1267 (build_int_cst (integer_type_node, 1),
1268 gfc_build_addr_expr (pchar_type_node, se->expr));
1269 }
1270 }
1271 }
1272 }
1273
1274
1275 /* Compare two strings. If they are all single characters, the result is the
1276 subtraction of them. Otherwise, we build a library call. */
1277
1278 tree
1279 gfc_build_compare_string (tree len1, tree str1, tree len2, tree str2)
1280 {
1281 tree sc1;
1282 tree sc2;
1283 tree tmp;
1284
1285 gcc_assert (POINTER_TYPE_P (TREE_TYPE (str1)));
1286 gcc_assert (POINTER_TYPE_P (TREE_TYPE (str2)));
1287
1288 sc1 = gfc_to_single_character (len1, str1);
1289 sc2 = gfc_to_single_character (len2, str2);
1290
1291 /* Deal with single character specially. */
1292 if (sc1 != NULL_TREE && sc2 != NULL_TREE)
1293 {
1294 sc1 = fold_convert (integer_type_node, sc1);
1295 sc2 = fold_convert (integer_type_node, sc2);
1296 tmp = fold_build2 (MINUS_EXPR, integer_type_node, sc1, sc2);
1297 }
1298 else
1299 /* Build a call for the comparison. */
1300 tmp = build_call_expr (gfor_fndecl_compare_string, 4,
1301 len1, str1, len2, str2);
1302 return tmp;
1303 }
1304
1305 static void
1306 gfc_conv_function_val (gfc_se * se, gfc_symbol * sym)
1307 {
1308 tree tmp;
1309
1310 if (sym->attr.dummy)
1311 {
1312 tmp = gfc_get_symbol_decl (sym);
1313 gcc_assert (TREE_CODE (TREE_TYPE (tmp)) == POINTER_TYPE
1314 && TREE_CODE (TREE_TYPE (TREE_TYPE (tmp))) == FUNCTION_TYPE);
1315 }
1316 else
1317 {
1318 if (!sym->backend_decl)
1319 sym->backend_decl = gfc_get_extern_function_decl (sym);
1320
1321 tmp = sym->backend_decl;
1322 if (sym->attr.cray_pointee)
1323 tmp = convert (build_pointer_type (TREE_TYPE (tmp)),
1324 gfc_get_symbol_decl (sym->cp_pointer));
1325 if (!POINTER_TYPE_P (TREE_TYPE (tmp)))
1326 {
1327 gcc_assert (TREE_CODE (tmp) == FUNCTION_DECL);
1328 tmp = build_fold_addr_expr (tmp);
1329 }
1330 }
1331 se->expr = tmp;
1332 }
1333
1334
1335 /* Translate the call for an elemental subroutine call used in an operator
1336 assignment. This is a simplified version of gfc_conv_function_call. */
1337
1338 tree
1339 gfc_conv_operator_assign (gfc_se *lse, gfc_se *rse, gfc_symbol *sym)
1340 {
1341 tree args;
1342 tree tmp;
1343 gfc_se se;
1344 stmtblock_t block;
1345
1346 /* Only elemental subroutines with two arguments. */
1347 gcc_assert (sym->attr.elemental && sym->attr.subroutine);
1348 gcc_assert (sym->formal->next->next == NULL);
1349
1350 gfc_init_block (&block);
1351
1352 gfc_add_block_to_block (&block, &lse->pre);
1353 gfc_add_block_to_block (&block, &rse->pre);
1354
1355 /* Build the argument list for the call, including hidden string lengths. */
1356 args = gfc_chainon_list (NULL_TREE, build_fold_addr_expr (lse->expr));
1357 args = gfc_chainon_list (args, build_fold_addr_expr (rse->expr));
1358 if (lse->string_length != NULL_TREE)
1359 args = gfc_chainon_list (args, lse->string_length);
1360 if (rse->string_length != NULL_TREE)
1361 args = gfc_chainon_list (args, rse->string_length);
1362
1363 /* Build the function call. */
1364 gfc_init_se (&se, NULL);
1365 gfc_conv_function_val (&se, sym);
1366 tmp = TREE_TYPE (TREE_TYPE (TREE_TYPE (se.expr)));
1367 tmp = build_call_list (tmp, se.expr, args);
1368 gfc_add_expr_to_block (&block, tmp);
1369
1370 gfc_add_block_to_block (&block, &lse->post);
1371 gfc_add_block_to_block (&block, &rse->post);
1372
1373 return gfc_finish_block (&block);
1374 }
1375
1376
1377 /* Initialize MAPPING. */
1378
1379 void
1380 gfc_init_interface_mapping (gfc_interface_mapping * mapping)
1381 {
1382 mapping->syms = NULL;
1383 mapping->charlens = NULL;
1384 }
1385
1386
1387 /* Free all memory held by MAPPING (but not MAPPING itself). */
1388
1389 void
1390 gfc_free_interface_mapping (gfc_interface_mapping * mapping)
1391 {
1392 gfc_interface_sym_mapping *sym;
1393 gfc_interface_sym_mapping *nextsym;
1394 gfc_charlen *cl;
1395 gfc_charlen *nextcl;
1396
1397 for (sym = mapping->syms; sym; sym = nextsym)
1398 {
1399 nextsym = sym->next;
1400 gfc_free_symbol (sym->new->n.sym);
1401 gfc_free (sym->new);
1402 gfc_free (sym);
1403 }
1404 for (cl = mapping->charlens; cl; cl = nextcl)
1405 {
1406 nextcl = cl->next;
1407 gfc_free_expr (cl->length);
1408 gfc_free (cl);
1409 }
1410 }
1411
1412
1413 /* Return a copy of gfc_charlen CL. Add the returned structure to
1414 MAPPING so that it will be freed by gfc_free_interface_mapping. */
1415
1416 static gfc_charlen *
1417 gfc_get_interface_mapping_charlen (gfc_interface_mapping * mapping,
1418 gfc_charlen * cl)
1419 {
1420 gfc_charlen *new;
1421
1422 new = gfc_get_charlen ();
1423 new->next = mapping->charlens;
1424 new->length = gfc_copy_expr (cl->length);
1425
1426 mapping->charlens = new;
1427 return new;
1428 }
1429
1430
1431 /* A subroutine of gfc_add_interface_mapping. Return a descriptorless
1432 array variable that can be used as the actual argument for dummy
1433 argument SYM. Add any initialization code to BLOCK. PACKED is as
1434 for gfc_get_nodesc_array_type and DATA points to the first element
1435 in the passed array. */
1436
1437 static tree
1438 gfc_get_interface_mapping_array (stmtblock_t * block, gfc_symbol * sym,
1439 gfc_packed packed, tree data)
1440 {
1441 tree type;
1442 tree var;
1443
1444 type = gfc_typenode_for_spec (&sym->ts);
1445 type = gfc_get_nodesc_array_type (type, sym->as, packed);
1446
1447 var = gfc_create_var (type, "ifm");
1448 gfc_add_modify_expr (block, var, fold_convert (type, data));
1449
1450 return var;
1451 }
1452
1453
1454 /* A subroutine of gfc_add_interface_mapping. Set the stride, upper bounds
1455 and offset of descriptorless array type TYPE given that it has the same
1456 size as DESC. Add any set-up code to BLOCK. */
1457
1458 static void
1459 gfc_set_interface_mapping_bounds (stmtblock_t * block, tree type, tree desc)
1460 {
1461 int n;
1462 tree dim;
1463 tree offset;
1464 tree tmp;
1465
1466 offset = gfc_index_zero_node;
1467 for (n = 0; n < GFC_TYPE_ARRAY_RANK (type); n++)
1468 {
1469 dim = gfc_rank_cst[n];
1470 GFC_TYPE_ARRAY_STRIDE (type, n) = gfc_conv_array_stride (desc, n);
1471 if (GFC_TYPE_ARRAY_LBOUND (type, n) == NULL_TREE)
1472 {
1473 GFC_TYPE_ARRAY_LBOUND (type, n)
1474 = gfc_conv_descriptor_lbound (desc, dim);
1475 GFC_TYPE_ARRAY_UBOUND (type, n)
1476 = gfc_conv_descriptor_ubound (desc, dim);
1477 }
1478 else if (GFC_TYPE_ARRAY_UBOUND (type, n) == NULL_TREE)
1479 {
1480 tmp = fold_build2 (MINUS_EXPR, gfc_array_index_type,
1481 gfc_conv_descriptor_ubound (desc, dim),
1482 gfc_conv_descriptor_lbound (desc, dim));
1483 tmp = fold_build2 (PLUS_EXPR, gfc_array_index_type,
1484 GFC_TYPE_ARRAY_LBOUND (type, n),
1485 tmp);
1486 tmp = gfc_evaluate_now (tmp, block);
1487 GFC_TYPE_ARRAY_UBOUND (type, n) = tmp;
1488 }
1489 tmp = fold_build2 (MULT_EXPR, gfc_array_index_type,
1490 GFC_TYPE_ARRAY_LBOUND (type, n),
1491 GFC_TYPE_ARRAY_STRIDE (type, n));
1492 offset = fold_build2 (MINUS_EXPR, gfc_array_index_type, offset, tmp);
1493 }
1494 offset = gfc_evaluate_now (offset, block);
1495 GFC_TYPE_ARRAY_OFFSET (type) = offset;
1496 }
1497
1498
1499 /* Extend MAPPING so that it maps dummy argument SYM to the value stored
1500 in SE. The caller may still use se->expr and se->string_length after
1501 calling this function. */
1502
1503 void
1504 gfc_add_interface_mapping (gfc_interface_mapping * mapping,
1505 gfc_symbol * sym, gfc_se * se)
1506 {
1507 gfc_interface_sym_mapping *sm;
1508 tree desc;
1509 tree tmp;
1510 tree value;
1511 gfc_symbol *new_sym;
1512 gfc_symtree *root;
1513 gfc_symtree *new_symtree;
1514
1515 /* Create a new symbol to represent the actual argument. */
1516 new_sym = gfc_new_symbol (sym->name, NULL);
1517 new_sym->ts = sym->ts;
1518 new_sym->attr.referenced = 1;
1519 new_sym->attr.dimension = sym->attr.dimension;
1520 new_sym->attr.pointer = sym->attr.pointer;
1521 new_sym->attr.allocatable = sym->attr.allocatable;
1522 new_sym->attr.flavor = sym->attr.flavor;
1523
1524 /* Create a fake symtree for it. */
1525 root = NULL;
1526 new_symtree = gfc_new_symtree (&root, sym->name);
1527 new_symtree->n.sym = new_sym;
1528 gcc_assert (new_symtree == root);
1529
1530 /* Create a dummy->actual mapping. */
1531 sm = gfc_getmem (sizeof (*sm));
1532 sm->next = mapping->syms;
1533 sm->old = sym;
1534 sm->new = new_symtree;
1535 mapping->syms = sm;
1536
1537 /* Stabilize the argument's value. */
1538 se->expr = gfc_evaluate_now (se->expr, &se->pre);
1539
1540 if (sym->ts.type == BT_CHARACTER)
1541 {
1542 /* Create a copy of the dummy argument's length. */
1543 new_sym->ts.cl = gfc_get_interface_mapping_charlen (mapping, sym->ts.cl);
1544
1545 /* If the length is specified as "*", record the length that
1546 the caller is passing. We should use the callee's length
1547 in all other cases. */
1548 if (!new_sym->ts.cl->length)
1549 {
1550 se->string_length = gfc_evaluate_now (se->string_length, &se->pre);
1551 new_sym->ts.cl->backend_decl = se->string_length;
1552 }
1553 }
1554
1555 /* Use the passed value as-is if the argument is a function. */
1556 if (sym->attr.flavor == FL_PROCEDURE)
1557 value = se->expr;
1558
1559 /* If the argument is either a string or a pointer to a string,
1560 convert it to a boundless character type. */
1561 else if (!sym->attr.dimension && sym->ts.type == BT_CHARACTER)
1562 {
1563 tmp = gfc_get_character_type_len (sym->ts.kind, NULL);
1564 tmp = build_pointer_type (tmp);
1565 if (sym->attr.pointer)
1566 value = build_fold_indirect_ref (se->expr);
1567 else
1568 value = se->expr;
1569 value = fold_convert (tmp, value);
1570 }
1571
1572 /* If the argument is a scalar, a pointer to an array or an allocatable,
1573 dereference it. */
1574 else if (!sym->attr.dimension || sym->attr.pointer || sym->attr.allocatable)
1575 value = build_fold_indirect_ref (se->expr);
1576
1577 /* For character(*), use the actual argument's descriptor. */
1578 else if (sym->ts.type == BT_CHARACTER && !new_sym->ts.cl->length)
1579 value = build_fold_indirect_ref (se->expr);
1580
1581 /* If the argument is an array descriptor, use it to determine
1582 information about the actual argument's shape. */
1583 else if (POINTER_TYPE_P (TREE_TYPE (se->expr))
1584 && GFC_DESCRIPTOR_TYPE_P (TREE_TYPE (TREE_TYPE (se->expr))))
1585 {
1586 /* Get the actual argument's descriptor. */
1587 desc = build_fold_indirect_ref (se->expr);
1588
1589 /* Create the replacement variable. */
1590 tmp = gfc_conv_descriptor_data_get (desc);
1591 value = gfc_get_interface_mapping_array (&se->pre, sym,
1592 PACKED_NO, tmp);
1593
1594 /* Use DESC to work out the upper bounds, strides and offset. */
1595 gfc_set_interface_mapping_bounds (&se->pre, TREE_TYPE (value), desc);
1596 }
1597 else
1598 /* Otherwise we have a packed array. */
1599 value = gfc_get_interface_mapping_array (&se->pre, sym,
1600 PACKED_FULL, se->expr);
1601
1602 new_sym->backend_decl = value;
1603 }
1604
1605
1606 /* Called once all dummy argument mappings have been added to MAPPING,
1607 but before the mapping is used to evaluate expressions. Pre-evaluate
1608 the length of each argument, adding any initialization code to PRE and
1609 any finalization code to POST. */
1610
1611 void
1612 gfc_finish_interface_mapping (gfc_interface_mapping * mapping,
1613 stmtblock_t * pre, stmtblock_t * post)
1614 {
1615 gfc_interface_sym_mapping *sym;
1616 gfc_expr *expr;
1617 gfc_se se;
1618
1619 for (sym = mapping->syms; sym; sym = sym->next)
1620 if (sym->new->n.sym->ts.type == BT_CHARACTER
1621 && !sym->new->n.sym->ts.cl->backend_decl)
1622 {
1623 expr = sym->new->n.sym->ts.cl->length;
1624 gfc_apply_interface_mapping_to_expr (mapping, expr);
1625 gfc_init_se (&se, NULL);
1626 gfc_conv_expr (&se, expr);
1627
1628 se.expr = gfc_evaluate_now (se.expr, &se.pre);
1629 gfc_add_block_to_block (pre, &se.pre);
1630 gfc_add_block_to_block (post, &se.post);
1631
1632 sym->new->n.sym->ts.cl->backend_decl = se.expr;
1633 }
1634 }
1635
1636
1637 /* Like gfc_apply_interface_mapping_to_expr, but applied to
1638 constructor C. */
1639
1640 static void
1641 gfc_apply_interface_mapping_to_cons (gfc_interface_mapping * mapping,
1642 gfc_constructor * c)
1643 {
1644 for (; c; c = c->next)
1645 {
1646 gfc_apply_interface_mapping_to_expr (mapping, c->expr);
1647 if (c->iterator)
1648 {
1649 gfc_apply_interface_mapping_to_expr (mapping, c->iterator->start);
1650 gfc_apply_interface_mapping_to_expr (mapping, c->iterator->end);
1651 gfc_apply_interface_mapping_to_expr (mapping, c->iterator->step);
1652 }
1653 }
1654 }
1655
1656
1657 /* Like gfc_apply_interface_mapping_to_expr, but applied to
1658 reference REF. */
1659
1660 static void
1661 gfc_apply_interface_mapping_to_ref (gfc_interface_mapping * mapping,
1662 gfc_ref * ref)
1663 {
1664 int n;
1665
1666 for (; ref; ref = ref->next)
1667 switch (ref->type)
1668 {
1669 case REF_ARRAY:
1670 for (n = 0; n < ref->u.ar.dimen; n++)
1671 {
1672 gfc_apply_interface_mapping_to_expr (mapping, ref->u.ar.start[n]);
1673 gfc_apply_interface_mapping_to_expr (mapping, ref->u.ar.end[n]);
1674 gfc_apply_interface_mapping_to_expr (mapping, ref->u.ar.stride[n]);
1675 }
1676 gfc_apply_interface_mapping_to_expr (mapping, ref->u.ar.offset);
1677 break;
1678
1679 case REF_COMPONENT:
1680 break;
1681
1682 case REF_SUBSTRING:
1683 gfc_apply_interface_mapping_to_expr (mapping, ref->u.ss.start);
1684 gfc_apply_interface_mapping_to_expr (mapping, ref->u.ss.end);
1685 break;
1686 }
1687 }
1688
1689
1690 /* EXPR is a copy of an expression that appeared in the interface
1691 associated with MAPPING. Walk it recursively looking for references to
1692 dummy arguments that MAPPING maps to actual arguments. Replace each such
1693 reference with a reference to the associated actual argument. */
1694
1695 static int
1696 gfc_apply_interface_mapping_to_expr (gfc_interface_mapping * mapping,
1697 gfc_expr * expr)
1698 {
1699 gfc_interface_sym_mapping *sym;
1700 gfc_actual_arglist *actual;
1701 int seen_result = 0;
1702
1703 if (!expr)
1704 return 0;
1705
1706 /* Copying an expression does not copy its length, so do that here. */
1707 if (expr->ts.type == BT_CHARACTER && expr->ts.cl)
1708 {
1709 expr->ts.cl = gfc_get_interface_mapping_charlen (mapping, expr->ts.cl);
1710 gfc_apply_interface_mapping_to_expr (mapping, expr->ts.cl->length);
1711 }
1712
1713 /* Apply the mapping to any references. */
1714 gfc_apply_interface_mapping_to_ref (mapping, expr->ref);
1715
1716 /* ...and to the expression's symbol, if it has one. */
1717 if (expr->symtree)
1718 for (sym = mapping->syms; sym; sym = sym->next)
1719 if (sym->old == expr->symtree->n.sym)
1720 expr->symtree = sym->new;
1721
1722 /* ...and to subexpressions in expr->value. */
1723 switch (expr->expr_type)
1724 {
1725 case EXPR_VARIABLE:
1726 if (expr->symtree->n.sym->attr.result)
1727 seen_result = 1;
1728 case EXPR_CONSTANT:
1729 case EXPR_NULL:
1730 case EXPR_SUBSTRING:
1731 break;
1732
1733 case EXPR_OP:
1734 gfc_apply_interface_mapping_to_expr (mapping, expr->value.op.op1);
1735 gfc_apply_interface_mapping_to_expr (mapping, expr->value.op.op2);
1736 break;
1737
1738 case EXPR_FUNCTION:
1739 if (expr->value.function.esym == NULL
1740 && expr->value.function.isym != NULL
1741 && expr->value.function.isym->id == GFC_ISYM_LEN
1742 && expr->value.function.actual->expr->expr_type == EXPR_VARIABLE
1743 && gfc_apply_interface_mapping_to_expr (mapping,
1744 expr->value.function.actual->expr))
1745 {
1746 gfc_expr *new_expr;
1747 new_expr = gfc_copy_expr (expr->value.function.actual->expr->ts.cl->length);
1748 *expr = *new_expr;
1749 gfc_free (new_expr);
1750 gfc_apply_interface_mapping_to_expr (mapping, expr);
1751 break;
1752 }
1753
1754 for (sym = mapping->syms; sym; sym = sym->next)
1755 if (sym->old == expr->value.function.esym)
1756 expr->value.function.esym = sym->new->n.sym;
1757
1758 for (actual = expr->value.function.actual; actual; actual = actual->next)
1759 gfc_apply_interface_mapping_to_expr (mapping, actual->expr);
1760 break;
1761
1762 case EXPR_ARRAY:
1763 case EXPR_STRUCTURE:
1764 gfc_apply_interface_mapping_to_cons (mapping, expr->value.constructor);
1765 break;
1766 }
1767 return seen_result;
1768 }
1769
1770
1771 /* Evaluate interface expression EXPR using MAPPING. Store the result
1772 in SE. */
1773
1774 void
1775 gfc_apply_interface_mapping (gfc_interface_mapping * mapping,
1776 gfc_se * se, gfc_expr * expr)
1777 {
1778 expr = gfc_copy_expr (expr);
1779 gfc_apply_interface_mapping_to_expr (mapping, expr);
1780 gfc_conv_expr (se, expr);
1781 se->expr = gfc_evaluate_now (se->expr, &se->pre);
1782 gfc_free_expr (expr);
1783 }
1784
1785 /* Returns a reference to a temporary array into which a component of
1786 an actual argument derived type array is copied and then returned
1787 after the function call.
1788 TODO Get rid of this kludge, when array descriptors are capable of
1789 handling arrays with a bigger stride in bytes than size. */
1790
1791 void
1792 gfc_conv_aliased_arg (gfc_se * parmse, gfc_expr * expr,
1793 int g77, sym_intent intent)
1794 {
1795 gfc_se lse;
1796 gfc_se rse;
1797 gfc_ss *lss;
1798 gfc_ss *rss;
1799 gfc_loopinfo loop;
1800 gfc_loopinfo loop2;
1801 gfc_ss_info *info;
1802 tree offset;
1803 tree tmp_index;
1804 tree tmp;
1805 tree base_type;
1806 stmtblock_t body;
1807 int n;
1808
1809 gcc_assert (expr->expr_type == EXPR_VARIABLE);
1810
1811 gfc_init_se (&lse, NULL);
1812 gfc_init_se (&rse, NULL);
1813
1814 /* Walk the argument expression. */
1815 rss = gfc_walk_expr (expr);
1816
1817 gcc_assert (rss != gfc_ss_terminator);
1818
1819 /* Initialize the scalarizer. */
1820 gfc_init_loopinfo (&loop);
1821 gfc_add_ss_to_loop (&loop, rss);
1822
1823 /* Calculate the bounds of the scalarization. */
1824 gfc_conv_ss_startstride (&loop);
1825
1826 /* Build an ss for the temporary. */
1827 if (expr->ts.type == BT_CHARACTER && !expr->ts.cl->backend_decl)
1828 gfc_conv_string_length (expr->ts.cl, &parmse->pre);
1829
1830 base_type = gfc_typenode_for_spec (&expr->ts);
1831 if (GFC_ARRAY_TYPE_P (base_type)
1832 || GFC_DESCRIPTOR_TYPE_P (base_type))
1833 base_type = gfc_get_element_type (base_type);
1834
1835 loop.temp_ss = gfc_get_ss ();;
1836 loop.temp_ss->type = GFC_SS_TEMP;
1837 loop.temp_ss->data.temp.type = base_type;
1838
1839 if (expr->ts.type == BT_CHARACTER)
1840 loop.temp_ss->string_length = expr->ts.cl->backend_decl;
1841 else
1842 loop.temp_ss->string_length = NULL;
1843
1844 parmse->string_length = loop.temp_ss->string_length;
1845 loop.temp_ss->data.temp.dimen = loop.dimen;
1846 loop.temp_ss->next = gfc_ss_terminator;
1847
1848 /* Associate the SS with the loop. */
1849 gfc_add_ss_to_loop (&loop, loop.temp_ss);
1850
1851 /* Setup the scalarizing loops. */
1852 gfc_conv_loop_setup (&loop);
1853
1854 /* Pass the temporary descriptor back to the caller. */
1855 info = &loop.temp_ss->data.info;
1856 parmse->expr = info->descriptor;
1857
1858 /* Setup the gfc_se structures. */
1859 gfc_copy_loopinfo_to_se (&lse, &loop);
1860 gfc_copy_loopinfo_to_se (&rse, &loop);
1861
1862 rse.ss = rss;
1863 lse.ss = loop.temp_ss;
1864 gfc_mark_ss_chain_used (rss, 1);
1865 gfc_mark_ss_chain_used (loop.temp_ss, 1);
1866
1867 /* Start the scalarized loop body. */
1868 gfc_start_scalarized_body (&loop, &body);
1869
1870 /* Translate the expression. */
1871 gfc_conv_expr (&rse, expr);
1872
1873 gfc_conv_tmp_array_ref (&lse);
1874 gfc_advance_se_ss_chain (&lse);
1875
1876 if (intent != INTENT_OUT)
1877 {
1878 tmp = gfc_trans_scalar_assign (&lse, &rse, expr->ts, true, false);
1879 gfc_add_expr_to_block (&body, tmp);
1880 gcc_assert (rse.ss == gfc_ss_terminator);
1881 gfc_trans_scalarizing_loops (&loop, &body);
1882 }
1883 else
1884 {
1885 /* Make sure that the temporary declaration survives by merging
1886 all the loop declarations into the current context. */
1887 for (n = 0; n < loop.dimen; n++)
1888 {
1889 gfc_merge_block_scope (&body);
1890 body = loop.code[loop.order[n]];
1891 }
1892 gfc_merge_block_scope (&body);
1893 }
1894
1895 /* Add the post block after the second loop, so that any
1896 freeing of allocated memory is done at the right time. */
1897 gfc_add_block_to_block (&parmse->pre, &loop.pre);
1898
1899 /**********Copy the temporary back again.*********/
1900
1901 gfc_init_se (&lse, NULL);
1902 gfc_init_se (&rse, NULL);
1903
1904 /* Walk the argument expression. */
1905 lss = gfc_walk_expr (expr);
1906 rse.ss = loop.temp_ss;
1907 lse.ss = lss;
1908
1909 /* Initialize the scalarizer. */
1910 gfc_init_loopinfo (&loop2);
1911 gfc_add_ss_to_loop (&loop2, lss);
1912
1913 /* Calculate the bounds of the scalarization. */
1914 gfc_conv_ss_startstride (&loop2);
1915
1916 /* Setup the scalarizing loops. */
1917 gfc_conv_loop_setup (&loop2);
1918
1919 gfc_copy_loopinfo_to_se (&lse, &loop2);
1920 gfc_copy_loopinfo_to_se (&rse, &loop2);
1921
1922 gfc_mark_ss_chain_used (lss, 1);
1923 gfc_mark_ss_chain_used (loop.temp_ss, 1);
1924
1925 /* Declare the variable to hold the temporary offset and start the
1926 scalarized loop body. */
1927 offset = gfc_create_var (gfc_array_index_type, NULL);
1928 gfc_start_scalarized_body (&loop2, &body);
1929
1930 /* Build the offsets for the temporary from the loop variables. The
1931 temporary array has lbounds of zero and strides of one in all
1932 dimensions, so this is very simple. The offset is only computed
1933 outside the innermost loop, so the overall transfer could be
1934 optimized further. */
1935 info = &rse.ss->data.info;
1936
1937 tmp_index = gfc_index_zero_node;
1938 for (n = info->dimen - 1; n > 0; n--)
1939 {
1940 tree tmp_str;
1941 tmp = rse.loop->loopvar[n];
1942 tmp = fold_build2 (MINUS_EXPR, gfc_array_index_type,
1943 tmp, rse.loop->from[n]);
1944 tmp = fold_build2 (PLUS_EXPR, gfc_array_index_type,
1945 tmp, tmp_index);
1946
1947 tmp_str = fold_build2 (MINUS_EXPR, gfc_array_index_type,
1948 rse.loop->to[n-1], rse.loop->from[n-1]);
1949 tmp_str = fold_build2 (PLUS_EXPR, gfc_array_index_type,
1950 tmp_str, gfc_index_one_node);
1951
1952 tmp_index = fold_build2 (MULT_EXPR, gfc_array_index_type,
1953 tmp, tmp_str);
1954 }
1955
1956 tmp_index = fold_build2 (MINUS_EXPR, gfc_array_index_type,
1957 tmp_index, rse.loop->from[0]);
1958 gfc_add_modify_expr (&rse.loop->code[0], offset, tmp_index);
1959
1960 tmp_index = fold_build2 (PLUS_EXPR, gfc_array_index_type,
1961 rse.loop->loopvar[0], offset);
1962
1963 /* Now use the offset for the reference. */
1964 tmp = build_fold_indirect_ref (info->data);
1965 rse.expr = gfc_build_array_ref (tmp, tmp_index);
1966
1967 if (expr->ts.type == BT_CHARACTER)
1968 rse.string_length = expr->ts.cl->backend_decl;
1969
1970 gfc_conv_expr (&lse, expr);
1971
1972 gcc_assert (lse.ss == gfc_ss_terminator);
1973
1974 tmp = gfc_trans_scalar_assign (&lse, &rse, expr->ts, false, false);
1975 gfc_add_expr_to_block (&body, tmp);
1976
1977 /* Generate the copying loops. */
1978 gfc_trans_scalarizing_loops (&loop2, &body);
1979
1980 /* Wrap the whole thing up by adding the second loop to the post-block
1981 and following it by the post-block of the first loop. In this way,
1982 if the temporary needs freeing, it is done after use! */
1983 if (intent != INTENT_IN)
1984 {
1985 gfc_add_block_to_block (&parmse->post, &loop2.pre);
1986 gfc_add_block_to_block (&parmse->post, &loop2.post);
1987 }
1988
1989 gfc_add_block_to_block (&parmse->post, &loop.post);
1990
1991 gfc_cleanup_loop (&loop);
1992 gfc_cleanup_loop (&loop2);
1993
1994 /* Pass the string length to the argument expression. */
1995 if (expr->ts.type == BT_CHARACTER)
1996 parmse->string_length = expr->ts.cl->backend_decl;
1997
1998 /* We want either the address for the data or the address of the descriptor,
1999 depending on the mode of passing array arguments. */
2000 if (g77)
2001 parmse->expr = gfc_conv_descriptor_data_get (parmse->expr);
2002 else
2003 parmse->expr = build_fold_addr_expr (parmse->expr);
2004
2005 return;
2006 }
2007
2008 /* Is true if an array reference is followed by a component or substring
2009 reference. */
2010
2011 bool
2012 is_aliased_array (gfc_expr * e)
2013 {
2014 gfc_ref * ref;
2015 bool seen_array;
2016
2017 seen_array = false;
2018 for (ref = e->ref; ref; ref = ref->next)
2019 {
2020 if (ref->type == REF_ARRAY
2021 && ref->u.ar.type != AR_ELEMENT)
2022 seen_array = true;
2023
2024 if (seen_array
2025 && ref->type != REF_ARRAY)
2026 return seen_array;
2027 }
2028 return false;
2029 }
2030
2031 /* Generate the code for argument list functions. */
2032
2033 static void
2034 conv_arglist_function (gfc_se *se, gfc_expr *expr, const char *name)
2035 {
2036 /* Pass by value for g77 %VAL(arg), pass the address
2037 indirectly for %LOC, else by reference. Thus %REF
2038 is a "do-nothing" and %LOC is the same as an F95
2039 pointer. */
2040 if (strncmp (name, "%VAL", 4) == 0)
2041 gfc_conv_expr (se, expr);
2042 else if (strncmp (name, "%LOC", 4) == 0)
2043 {
2044 gfc_conv_expr_reference (se, expr);
2045 se->expr = gfc_build_addr_expr (NULL, se->expr);
2046 }
2047 else if (strncmp (name, "%REF", 4) == 0)
2048 gfc_conv_expr_reference (se, expr);
2049 else
2050 gfc_error ("Unknown argument list function at %L", &expr->where);
2051 }
2052
2053
2054 /* Generate code for a procedure call. Note can return se->post != NULL.
2055 If se->direct_byref is set then se->expr contains the return parameter.
2056 Return nonzero, if the call has alternate specifiers. */
2057
2058 int
2059 gfc_conv_function_call (gfc_se * se, gfc_symbol * sym,
2060 gfc_actual_arglist * arg, tree append_args)
2061 {
2062 gfc_interface_mapping mapping;
2063 tree arglist;
2064 tree retargs;
2065 tree tmp;
2066 tree fntype;
2067 gfc_se parmse;
2068 gfc_ss *argss;
2069 gfc_ss_info *info;
2070 int byref;
2071 int parm_kind;
2072 tree type;
2073 tree var;
2074 tree len;
2075 tree stringargs;
2076 gfc_formal_arglist *formal;
2077 int has_alternate_specifier = 0;
2078 bool need_interface_mapping;
2079 bool callee_alloc;
2080 gfc_typespec ts;
2081 gfc_charlen cl;
2082 gfc_expr *e;
2083 gfc_symbol *fsym;
2084 stmtblock_t post;
2085 enum {MISSING = 0, ELEMENTAL, SCALAR, SCALAR_POINTER, ARRAY};
2086
2087 arglist = NULL_TREE;
2088 retargs = NULL_TREE;
2089 stringargs = NULL_TREE;
2090 var = NULL_TREE;
2091 len = NULL_TREE;
2092
2093 if (sym->from_intmod == INTMOD_ISO_C_BINDING)
2094 {
2095 if (sym->intmod_sym_id == ISOCBINDING_LOC)
2096 {
2097 if (arg->expr->rank == 0)
2098 gfc_conv_expr_reference (se, arg->expr);
2099 else
2100 {
2101 int f;
2102 /* This is really the actual arg because no formal arglist is
2103 created for C_LOC. */
2104 fsym = arg->expr->symtree->n.sym;
2105
2106 /* We should want it to do g77 calling convention. */
2107 f = (fsym != NULL)
2108 && !(fsym->attr.pointer || fsym->attr.allocatable)
2109 && fsym->as->type != AS_ASSUMED_SHAPE;
2110 f = f || !sym->attr.always_explicit;
2111
2112 argss = gfc_walk_expr (arg->expr);
2113 gfc_conv_array_parameter (se, arg->expr, argss, f);
2114 }
2115
2116 return 0;
2117 }
2118 else if (sym->intmod_sym_id == ISOCBINDING_FUNLOC)
2119 {
2120 arg->expr->ts.type = sym->ts.derived->ts.type;
2121 arg->expr->ts.f90_type = sym->ts.derived->ts.f90_type;
2122 arg->expr->ts.kind = sym->ts.derived->ts.kind;
2123 gfc_conv_expr_reference (se, arg->expr);
2124
2125 return 0;
2126 }
2127 }
2128
2129 if (se->ss != NULL)
2130 {
2131 if (!sym->attr.elemental)
2132 {
2133 gcc_assert (se->ss->type == GFC_SS_FUNCTION);
2134 if (se->ss->useflags)
2135 {
2136 gcc_assert (gfc_return_by_reference (sym)
2137 && sym->result->attr.dimension);
2138 gcc_assert (se->loop != NULL);
2139
2140 /* Access the previously obtained result. */
2141 gfc_conv_tmp_array_ref (se);
2142 gfc_advance_se_ss_chain (se);
2143 return 0;
2144 }
2145 }
2146 info = &se->ss->data.info;
2147 }
2148 else
2149 info = NULL;
2150
2151 gfc_init_block (&post);
2152 gfc_init_interface_mapping (&mapping);
2153 need_interface_mapping = ((sym->ts.type == BT_CHARACTER
2154 && sym->ts.cl->length
2155 && sym->ts.cl->length->expr_type
2156 != EXPR_CONSTANT)
2157 || sym->attr.dimension);
2158 formal = sym->formal;
2159 /* Evaluate the arguments. */
2160 for (; arg != NULL; arg = arg->next, formal = formal ? formal->next : NULL)
2161 {
2162 e = arg->expr;
2163 fsym = formal ? formal->sym : NULL;
2164 parm_kind = MISSING;
2165 if (e == NULL)
2166 {
2167
2168 if (se->ignore_optional)
2169 {
2170 /* Some intrinsics have already been resolved to the correct
2171 parameters. */
2172 continue;
2173 }
2174 else if (arg->label)
2175 {
2176 has_alternate_specifier = 1;
2177 continue;
2178 }
2179 else
2180 {
2181 /* Pass a NULL pointer for an absent arg. */
2182 gfc_init_se (&parmse, NULL);
2183 parmse.expr = null_pointer_node;
2184 if (arg->missing_arg_type == BT_CHARACTER)
2185 parmse.string_length = build_int_cst (gfc_charlen_type_node, 0);
2186 }
2187 }
2188 else if (se->ss && se->ss->useflags)
2189 {
2190 /* An elemental function inside a scalarized loop. */
2191 gfc_init_se (&parmse, se);
2192 gfc_conv_expr_reference (&parmse, e);
2193 parm_kind = ELEMENTAL;
2194 }
2195 else
2196 {
2197 /* A scalar or transformational function. */
2198 gfc_init_se (&parmse, NULL);
2199 argss = gfc_walk_expr (e);
2200
2201 if (argss == gfc_ss_terminator)
2202 {
2203 if (fsym && fsym->attr.value)
2204 {
2205 if (fsym->ts.type == BT_CHARACTER
2206 && fsym->ts.is_c_interop
2207 && fsym->ns->proc_name != NULL
2208 && fsym->ns->proc_name->attr.is_bind_c)
2209 {
2210 parmse.expr = NULL;
2211 gfc_conv_scalar_char_value (fsym, &parmse, &e);
2212 if (parmse.expr == NULL)
2213 gfc_conv_expr (&parmse, e);
2214 }
2215 else
2216 gfc_conv_expr (&parmse, e);
2217 }
2218 else if (arg->name && arg->name[0] == '%')
2219 /* Argument list functions %VAL, %LOC and %REF are signalled
2220 through arg->name. */
2221 conv_arglist_function (&parmse, arg->expr, arg->name);
2222 else if ((e->expr_type == EXPR_FUNCTION)
2223 && e->symtree->n.sym->attr.pointer
2224 && fsym && fsym->attr.target)
2225 {
2226 gfc_conv_expr (&parmse, e);
2227 parmse.expr = build_fold_addr_expr (parmse.expr);
2228 }
2229 else
2230 {
2231 gfc_conv_expr_reference (&parmse, e);
2232 if (fsym && fsym->attr.pointer
2233 && fsym->attr.flavor != FL_PROCEDURE
2234 && e->expr_type != EXPR_NULL)
2235 {
2236 /* Scalar pointer dummy args require an extra level of
2237 indirection. The null pointer already contains
2238 this level of indirection. */
2239 parm_kind = SCALAR_POINTER;
2240 parmse.expr = build_fold_addr_expr (parmse.expr);
2241 }
2242 }
2243 }
2244 else
2245 {
2246 /* If the procedure requires an explicit interface, the actual
2247 argument is passed according to the corresponding formal
2248 argument. If the corresponding formal argument is a POINTER,
2249 ALLOCATABLE or assumed shape, we do not use g77's calling
2250 convention, and pass the address of the array descriptor
2251 instead. Otherwise we use g77's calling convention. */
2252 int f;
2253 f = (fsym != NULL)
2254 && !(fsym->attr.pointer || fsym->attr.allocatable)
2255 && fsym->as->type != AS_ASSUMED_SHAPE;
2256 f = f || !sym->attr.always_explicit;
2257
2258 if (e->expr_type == EXPR_VARIABLE
2259 && is_aliased_array (e))
2260 /* The actual argument is a component reference to an
2261 array of derived types. In this case, the argument
2262 is converted to a temporary, which is passed and then
2263 written back after the procedure call. */
2264 gfc_conv_aliased_arg (&parmse, e, f,
2265 fsym ? fsym->attr.intent : INTENT_INOUT);
2266 else
2267 gfc_conv_array_parameter (&parmse, e, argss, f);
2268
2269 /* If an ALLOCATABLE dummy argument has INTENT(OUT) and is
2270 allocated on entry, it must be deallocated. */
2271 if (fsym && fsym->attr.allocatable
2272 && fsym->attr.intent == INTENT_OUT)
2273 {
2274 tmp = build_fold_indirect_ref (parmse.expr);
2275 tmp = gfc_trans_dealloc_allocated (tmp);
2276 gfc_add_expr_to_block (&se->pre, tmp);
2277 }
2278
2279 }
2280 }
2281
2282 /* The case with fsym->attr.optional is that of a user subroutine
2283 with an interface indicating an optional argument. When we call
2284 an intrinsic subroutine, however, fsym is NULL, but we might still
2285 have an optional argument, so we proceed to the substitution
2286 just in case. */
2287 if (e && (fsym == NULL || fsym->attr.optional))
2288 {
2289 /* If an optional argument is itself an optional dummy argument,
2290 check its presence and substitute a null if absent. */
2291 if (e->expr_type == EXPR_VARIABLE
2292 && e->symtree->n.sym->attr.optional)
2293 gfc_conv_missing_dummy (&parmse, e, fsym ? fsym->ts : e->ts);
2294 }
2295
2296 if (fsym && e)
2297 {
2298 /* Obtain the character length of an assumed character length
2299 length procedure from the typespec. */
2300 if (fsym->ts.type == BT_CHARACTER
2301 && parmse.string_length == NULL_TREE
2302 && e->ts.type == BT_PROCEDURE
2303 && e->symtree->n.sym->ts.type == BT_CHARACTER
2304 && e->symtree->n.sym->ts.cl->length != NULL)
2305 {
2306 gfc_conv_const_charlen (e->symtree->n.sym->ts.cl);
2307 parmse.string_length = e->symtree->n.sym->ts.cl->backend_decl;
2308 }
2309 }
2310
2311 if (fsym && need_interface_mapping)
2312 gfc_add_interface_mapping (&mapping, fsym, &parmse);
2313
2314 gfc_add_block_to_block (&se->pre, &parmse.pre);
2315 gfc_add_block_to_block (&post, &parmse.post);
2316
2317 /* Allocated allocatable components of derived types must be
2318 deallocated for INTENT(OUT) dummy arguments and non-variable
2319 scalars. Non-variable arrays are dealt with in trans-array.c
2320 (gfc_conv_array_parameter). */
2321 if (e && e->ts.type == BT_DERIVED
2322 && e->ts.derived->attr.alloc_comp
2323 && ((formal && formal->sym->attr.intent == INTENT_OUT)
2324 ||
2325 (e->expr_type != EXPR_VARIABLE && !e->rank)))
2326 {
2327 int parm_rank;
2328 tmp = build_fold_indirect_ref (parmse.expr);
2329 parm_rank = e->rank;
2330 switch (parm_kind)
2331 {
2332 case (ELEMENTAL):
2333 case (SCALAR):
2334 parm_rank = 0;
2335 break;
2336
2337 case (SCALAR_POINTER):
2338 tmp = build_fold_indirect_ref (tmp);
2339 break;
2340 case (ARRAY):
2341 tmp = parmse.expr;
2342 break;
2343 }
2344
2345 tmp = gfc_deallocate_alloc_comp (e->ts.derived, tmp, parm_rank);
2346 if (e->expr_type == EXPR_VARIABLE && e->symtree->n.sym->attr.optional)
2347 tmp = build3_v (COND_EXPR, gfc_conv_expr_present (e->symtree->n.sym),
2348 tmp, build_empty_stmt ());
2349
2350 if (e->expr_type != EXPR_VARIABLE)
2351 /* Don't deallocate non-variables until they have been used. */
2352 gfc_add_expr_to_block (&se->post, tmp);
2353 else
2354 {
2355 gcc_assert (formal && formal->sym->attr.intent == INTENT_OUT);
2356 gfc_add_expr_to_block (&se->pre, tmp);
2357 }
2358 }
2359
2360 /* Character strings are passed as two parameters, a length and a
2361 pointer. */
2362 if (parmse.string_length != NULL_TREE)
2363 stringargs = gfc_chainon_list (stringargs, parmse.string_length);
2364
2365 arglist = gfc_chainon_list (arglist, parmse.expr);
2366 }
2367 gfc_finish_interface_mapping (&mapping, &se->pre, &se->post);
2368
2369 ts = sym->ts;
2370 if (ts.type == BT_CHARACTER)
2371 {
2372 if (sym->ts.cl->length == NULL)
2373 {
2374 /* Assumed character length results are not allowed by 5.1.1.5 of the
2375 standard and are trapped in resolve.c; except in the case of SPREAD
2376 (and other intrinsics?) and dummy functions. In the case of SPREAD,
2377 we take the character length of the first argument for the result.
2378 For dummies, we have to look through the formal argument list for
2379 this function and use the character length found there.*/
2380 if (!sym->attr.dummy)
2381 cl.backend_decl = TREE_VALUE (stringargs);
2382 else
2383 {
2384 formal = sym->ns->proc_name->formal;
2385 for (; formal; formal = formal->next)
2386 if (strcmp (formal->sym->name, sym->name) == 0)
2387 cl.backend_decl = formal->sym->ts.cl->backend_decl;
2388 }
2389 }
2390 else
2391 {
2392 tree tmp;
2393
2394 /* Calculate the length of the returned string. */
2395 gfc_init_se (&parmse, NULL);
2396 if (need_interface_mapping)
2397 gfc_apply_interface_mapping (&mapping, &parmse, sym->ts.cl->length);
2398 else
2399 gfc_conv_expr (&parmse, sym->ts.cl->length);
2400 gfc_add_block_to_block (&se->pre, &parmse.pre);
2401 gfc_add_block_to_block (&se->post, &parmse.post);
2402
2403 tmp = fold_convert (gfc_charlen_type_node, parmse.expr);
2404 tmp = fold_build2 (MAX_EXPR, gfc_charlen_type_node, tmp,
2405 build_int_cst (gfc_charlen_type_node, 0));
2406 cl.backend_decl = tmp;
2407 }
2408
2409 /* Set up a charlen structure for it. */
2410 cl.next = NULL;
2411 cl.length = NULL;
2412 ts.cl = &cl;
2413
2414 len = cl.backend_decl;
2415 }
2416
2417 byref = gfc_return_by_reference (sym);
2418 if (byref)
2419 {
2420 if (se->direct_byref)
2421 {
2422 /* Sometimes, too much indirection can be applied; eg. for
2423 function_result = array_valued_recursive_function. */
2424 if (TREE_TYPE (TREE_TYPE (se->expr))
2425 && TREE_TYPE (TREE_TYPE (TREE_TYPE (se->expr)))
2426 && GFC_DESCRIPTOR_TYPE_P
2427 (TREE_TYPE (TREE_TYPE (TREE_TYPE (se->expr)))))
2428 se->expr = build_fold_indirect_ref (se->expr);
2429
2430 retargs = gfc_chainon_list (retargs, se->expr);
2431 }
2432 else if (sym->result->attr.dimension)
2433 {
2434 gcc_assert (se->loop && info);
2435
2436 /* Set the type of the array. */
2437 tmp = gfc_typenode_for_spec (&ts);
2438 info->dimen = se->loop->dimen;
2439
2440 /* Evaluate the bounds of the result, if known. */
2441 gfc_set_loop_bounds_from_array_spec (&mapping, se, sym->result->as);
2442
2443 /* Create a temporary to store the result. In case the function
2444 returns a pointer, the temporary will be a shallow copy and
2445 mustn't be deallocated. */
2446 callee_alloc = sym->attr.allocatable || sym->attr.pointer;
2447 gfc_trans_create_temp_array (&se->pre, &se->post, se->loop, info, tmp,
2448 false, !sym->attr.pointer, callee_alloc);
2449
2450 /* Pass the temporary as the first argument. */
2451 tmp = info->descriptor;
2452 tmp = build_fold_addr_expr (tmp);
2453 retargs = gfc_chainon_list (retargs, tmp);
2454 }
2455 else if (ts.type == BT_CHARACTER)
2456 {
2457 /* Pass the string length. */
2458 type = gfc_get_character_type (ts.kind, ts.cl);
2459 type = build_pointer_type (type);
2460
2461 /* Return an address to a char[0:len-1]* temporary for
2462 character pointers. */
2463 if (sym->attr.pointer || sym->attr.allocatable)
2464 {
2465 /* Build char[0:len-1] * pstr. */
2466 tmp = fold_build2 (MINUS_EXPR, gfc_charlen_type_node, len,
2467 build_int_cst (gfc_charlen_type_node, 1));
2468 tmp = build_range_type (gfc_array_index_type,
2469 gfc_index_zero_node, tmp);
2470 tmp = build_array_type (gfc_character1_type_node, tmp);
2471 var = gfc_create_var (build_pointer_type (tmp), "pstr");
2472
2473 /* Provide an address expression for the function arguments. */
2474 var = build_fold_addr_expr (var);
2475 }
2476 else
2477 var = gfc_conv_string_tmp (se, type, len);
2478
2479 retargs = gfc_chainon_list (retargs, var);
2480 }
2481 else
2482 {
2483 gcc_assert (gfc_option.flag_f2c && ts.type == BT_COMPLEX);
2484
2485 type = gfc_get_complex_type (ts.kind);
2486 var = build_fold_addr_expr (gfc_create_var (type, "cmplx"));
2487 retargs = gfc_chainon_list (retargs, var);
2488 }
2489
2490 /* Add the string length to the argument list. */
2491 if (ts.type == BT_CHARACTER)
2492 retargs = gfc_chainon_list (retargs, len);
2493 }
2494 gfc_free_interface_mapping (&mapping);
2495
2496 /* Add the return arguments. */
2497 arglist = chainon (retargs, arglist);
2498
2499 /* Add the hidden string length parameters to the arguments. */
2500 arglist = chainon (arglist, stringargs);
2501
2502 /* We may want to append extra arguments here. This is used e.g. for
2503 calls to libgfortran_matmul_??, which need extra information. */
2504 if (append_args != NULL_TREE)
2505 arglist = chainon (arglist, append_args);
2506
2507 /* Generate the actual call. */
2508 gfc_conv_function_val (se, sym);
2509
2510 /* If there are alternate return labels, function type should be
2511 integer. Can't modify the type in place though, since it can be shared
2512 with other functions. For dummy arguments, the typing is done to
2513 to this result, even if it has to be repeated for each call. */
2514 if (has_alternate_specifier
2515 && TREE_TYPE (TREE_TYPE (TREE_TYPE (se->expr))) != integer_type_node)
2516 {
2517 if (!sym->attr.dummy)
2518 {
2519 TREE_TYPE (sym->backend_decl)
2520 = build_function_type (integer_type_node,
2521 TYPE_ARG_TYPES (TREE_TYPE (sym->backend_decl)));
2522 se->expr = build_fold_addr_expr (sym->backend_decl);
2523 }
2524 else
2525 TREE_TYPE (TREE_TYPE (TREE_TYPE (se->expr))) = integer_type_node;
2526 }
2527
2528 fntype = TREE_TYPE (TREE_TYPE (se->expr));
2529 se->expr = build_call_list (TREE_TYPE (fntype), se->expr, arglist);
2530
2531 /* If we have a pointer function, but we don't want a pointer, e.g.
2532 something like
2533 x = f()
2534 where f is pointer valued, we have to dereference the result. */
2535 if (!se->want_pointer && !byref && sym->attr.pointer)
2536 se->expr = build_fold_indirect_ref (se->expr);
2537
2538 /* f2c calling conventions require a scalar default real function to
2539 return a double precision result. Convert this back to default
2540 real. We only care about the cases that can happen in Fortran 77.
2541 */
2542 if (gfc_option.flag_f2c && sym->ts.type == BT_REAL
2543 && sym->ts.kind == gfc_default_real_kind
2544 && !sym->attr.always_explicit)
2545 se->expr = fold_convert (gfc_get_real_type (sym->ts.kind), se->expr);
2546
2547 /* A pure function may still have side-effects - it may modify its
2548 parameters. */
2549 TREE_SIDE_EFFECTS (se->expr) = 1;
2550 #if 0
2551 if (!sym->attr.pure)
2552 TREE_SIDE_EFFECTS (se->expr) = 1;
2553 #endif
2554
2555 if (byref)
2556 {
2557 /* Add the function call to the pre chain. There is no expression. */
2558 gfc_add_expr_to_block (&se->pre, se->expr);
2559 se->expr = NULL_TREE;
2560
2561 if (!se->direct_byref)
2562 {
2563 if (sym->attr.dimension)
2564 {
2565 if (flag_bounds_check)
2566 {
2567 /* Check the data pointer hasn't been modified. This would
2568 happen in a function returning a pointer. */
2569 tmp = gfc_conv_descriptor_data_get (info->descriptor);
2570 tmp = fold_build2 (NE_EXPR, boolean_type_node,
2571 tmp, info->data);
2572 gfc_trans_runtime_check (tmp, &se->pre, NULL, gfc_msg_fault);
2573 }
2574 se->expr = info->descriptor;
2575 /* Bundle in the string length. */
2576 se->string_length = len;
2577 }
2578 else if (sym->ts.type == BT_CHARACTER)
2579 {
2580 /* Dereference for character pointer results. */
2581 if (sym->attr.pointer || sym->attr.allocatable)
2582 se->expr = build_fold_indirect_ref (var);
2583 else
2584 se->expr = var;
2585
2586 se->string_length = len;
2587 }
2588 else
2589 {
2590 gcc_assert (sym->ts.type == BT_COMPLEX && gfc_option.flag_f2c);
2591 se->expr = build_fold_indirect_ref (var);
2592 }
2593 }
2594 }
2595
2596 /* Follow the function call with the argument post block. */
2597 if (byref)
2598 gfc_add_block_to_block (&se->pre, &post);
2599 else
2600 gfc_add_block_to_block (&se->post, &post);
2601
2602 return has_alternate_specifier;
2603 }
2604
2605
2606 /* Generate code to copy a string. */
2607
2608 static void
2609 gfc_trans_string_copy (stmtblock_t * block, tree dlength, tree dest,
2610 tree slength, tree src)
2611 {
2612 tree tmp, dlen, slen;
2613 tree dsc;
2614 tree ssc;
2615 tree cond;
2616 tree cond2;
2617 tree tmp2;
2618 tree tmp3;
2619 tree tmp4;
2620 stmtblock_t tempblock;
2621
2622 dlen = fold_convert (size_type_node, gfc_evaluate_now (dlength, block));
2623 slen = fold_convert (size_type_node, gfc_evaluate_now (slength, block));
2624
2625 /* Deal with single character specially. */
2626 dsc = gfc_to_single_character (dlen, dest);
2627 ssc = gfc_to_single_character (slen, src);
2628 if (dsc != NULL_TREE && ssc != NULL_TREE)
2629 {
2630 gfc_add_modify_expr (block, dsc, ssc);
2631 return;
2632 }
2633
2634 /* Do nothing if the destination length is zero. */
2635 cond = fold_build2 (GT_EXPR, boolean_type_node, dlen,
2636 build_int_cst (size_type_node, 0));
2637
2638 /* The following code was previously in _gfortran_copy_string:
2639
2640 // The two strings may overlap so we use memmove.
2641 void
2642 copy_string (GFC_INTEGER_4 destlen, char * dest,
2643 GFC_INTEGER_4 srclen, const char * src)
2644 {
2645 if (srclen >= destlen)
2646 {
2647 // This will truncate if too long.
2648 memmove (dest, src, destlen);
2649 }
2650 else
2651 {
2652 memmove (dest, src, srclen);
2653 // Pad with spaces.
2654 memset (&dest[srclen], ' ', destlen - srclen);
2655 }
2656 }
2657
2658 We're now doing it here for better optimization, but the logic
2659 is the same. */
2660
2661 /* Truncate string if source is too long. */
2662 cond2 = fold_build2 (GE_EXPR, boolean_type_node, slen, dlen);
2663 tmp2 = build_call_expr (built_in_decls[BUILT_IN_MEMMOVE],
2664 3, dest, src, dlen);
2665
2666 /* Else copy and pad with spaces. */
2667 tmp3 = build_call_expr (built_in_decls[BUILT_IN_MEMMOVE],
2668 3, dest, src, slen);
2669
2670 tmp4 = fold_build2 (POINTER_PLUS_EXPR, pchar_type_node, dest,
2671 fold_convert (sizetype, slen));
2672 tmp4 = build_call_expr (built_in_decls[BUILT_IN_MEMSET], 3,
2673 tmp4,
2674 build_int_cst (gfc_get_int_type (gfc_c_int_kind),
2675 lang_hooks.to_target_charset (' ')),
2676 fold_build2 (MINUS_EXPR, TREE_TYPE(dlen),
2677 dlen, slen));
2678
2679 gfc_init_block (&tempblock);
2680 gfc_add_expr_to_block (&tempblock, tmp3);
2681 gfc_add_expr_to_block (&tempblock, tmp4);
2682 tmp3 = gfc_finish_block (&tempblock);
2683
2684 /* The whole copy_string function is there. */
2685 tmp = fold_build3 (COND_EXPR, void_type_node, cond2, tmp2, tmp3);
2686 tmp = fold_build3 (COND_EXPR, void_type_node, cond, tmp, build_empty_stmt ());
2687 gfc_add_expr_to_block (block, tmp);
2688 }
2689
2690
2691 /* Translate a statement function.
2692 The value of a statement function reference is obtained by evaluating the
2693 expression using the values of the actual arguments for the values of the
2694 corresponding dummy arguments. */
2695
2696 static void
2697 gfc_conv_statement_function (gfc_se * se, gfc_expr * expr)
2698 {
2699 gfc_symbol *sym;
2700 gfc_symbol *fsym;
2701 gfc_formal_arglist *fargs;
2702 gfc_actual_arglist *args;
2703 gfc_se lse;
2704 gfc_se rse;
2705 gfc_saved_var *saved_vars;
2706 tree *temp_vars;
2707 tree type;
2708 tree tmp;
2709 int n;
2710
2711 sym = expr->symtree->n.sym;
2712 args = expr->value.function.actual;
2713 gfc_init_se (&lse, NULL);
2714 gfc_init_se (&rse, NULL);
2715
2716 n = 0;
2717 for (fargs = sym->formal; fargs; fargs = fargs->next)
2718 n++;
2719 saved_vars = (gfc_saved_var *)gfc_getmem (n * sizeof (gfc_saved_var));
2720 temp_vars = (tree *)gfc_getmem (n * sizeof (tree));
2721
2722 for (fargs = sym->formal, n = 0; fargs; fargs = fargs->next, n++)
2723 {
2724 /* Each dummy shall be specified, explicitly or implicitly, to be
2725 scalar. */
2726 gcc_assert (fargs->sym->attr.dimension == 0);
2727 fsym = fargs->sym;
2728
2729 /* Create a temporary to hold the value. */
2730 type = gfc_typenode_for_spec (&fsym->ts);
2731 temp_vars[n] = gfc_create_var (type, fsym->name);
2732
2733 if (fsym->ts.type == BT_CHARACTER)
2734 {
2735 /* Copy string arguments. */
2736 tree arglen;
2737
2738 gcc_assert (fsym->ts.cl && fsym->ts.cl->length
2739 && fsym->ts.cl->length->expr_type == EXPR_CONSTANT);
2740
2741 arglen = TYPE_MAX_VALUE (TYPE_DOMAIN (type));
2742 tmp = gfc_build_addr_expr (build_pointer_type (type),
2743 temp_vars[n]);
2744
2745 gfc_conv_expr (&rse, args->expr);
2746 gfc_conv_string_parameter (&rse);
2747 gfc_add_block_to_block (&se->pre, &lse.pre);
2748 gfc_add_block_to_block (&se->pre, &rse.pre);
2749
2750 gfc_trans_string_copy (&se->pre, arglen, tmp, rse.string_length,
2751 rse.expr);
2752 gfc_add_block_to_block (&se->pre, &lse.post);
2753 gfc_add_block_to_block (&se->pre, &rse.post);
2754 }
2755 else
2756 {
2757 /* For everything else, just evaluate the expression. */
2758 gfc_conv_expr (&lse, args->expr);
2759
2760 gfc_add_block_to_block (&se->pre, &lse.pre);
2761 gfc_add_modify_expr (&se->pre, temp_vars[n], lse.expr);
2762 gfc_add_block_to_block (&se->pre, &lse.post);
2763 }
2764
2765 args = args->next;
2766 }
2767
2768 /* Use the temporary variables in place of the real ones. */
2769 for (fargs = sym->formal, n = 0; fargs; fargs = fargs->next, n++)
2770 gfc_shadow_sym (fargs->sym, temp_vars[n], &saved_vars[n]);
2771
2772 gfc_conv_expr (se, sym->value);
2773
2774 if (sym->ts.type == BT_CHARACTER)
2775 {
2776 gfc_conv_const_charlen (sym->ts.cl);
2777
2778 /* Force the expression to the correct length. */
2779 if (!INTEGER_CST_P (se->string_length)
2780 || tree_int_cst_lt (se->string_length,
2781 sym->ts.cl->backend_decl))
2782 {
2783 type = gfc_get_character_type (sym->ts.kind, sym->ts.cl);
2784 tmp = gfc_create_var (type, sym->name);
2785 tmp = gfc_build_addr_expr (build_pointer_type (type), tmp);
2786 gfc_trans_string_copy (&se->pre, sym->ts.cl->backend_decl, tmp,
2787 se->string_length, se->expr);
2788 se->expr = tmp;
2789 }
2790 se->string_length = sym->ts.cl->backend_decl;
2791 }
2792
2793 /* Restore the original variables. */
2794 for (fargs = sym->formal, n = 0; fargs; fargs = fargs->next, n++)
2795 gfc_restore_sym (fargs->sym, &saved_vars[n]);
2796 gfc_free (saved_vars);
2797 }
2798
2799
2800 /* Translate a function expression. */
2801
2802 static void
2803 gfc_conv_function_expr (gfc_se * se, gfc_expr * expr)
2804 {
2805 gfc_symbol *sym;
2806
2807 if (expr->value.function.isym)
2808 {
2809 gfc_conv_intrinsic_function (se, expr);
2810 return;
2811 }
2812
2813 /* We distinguish statement functions from general functions to improve
2814 runtime performance. */
2815 if (expr->symtree->n.sym->attr.proc == PROC_ST_FUNCTION)
2816 {
2817 gfc_conv_statement_function (se, expr);
2818 return;
2819 }
2820
2821 /* expr.value.function.esym is the resolved (specific) function symbol for
2822 most functions. However this isn't set for dummy procedures. */
2823 sym = expr->value.function.esym;
2824 if (!sym)
2825 sym = expr->symtree->n.sym;
2826 gfc_conv_function_call (se, sym, expr->value.function.actual, NULL_TREE);
2827 }
2828
2829
2830 static void
2831 gfc_conv_array_constructor_expr (gfc_se * se, gfc_expr * expr)
2832 {
2833 gcc_assert (se->ss != NULL && se->ss != gfc_ss_terminator);
2834 gcc_assert (se->ss->expr == expr && se->ss->type == GFC_SS_CONSTRUCTOR);
2835
2836 gfc_conv_tmp_array_ref (se);
2837 gfc_advance_se_ss_chain (se);
2838 }
2839
2840
2841 /* Build a static initializer. EXPR is the expression for the initial value.
2842 The other parameters describe the variable of the component being
2843 initialized. EXPR may be null. */
2844
2845 tree
2846 gfc_conv_initializer (gfc_expr * expr, gfc_typespec * ts, tree type,
2847 bool array, bool pointer)
2848 {
2849 gfc_se se;
2850
2851 if (!(expr || pointer))
2852 return NULL_TREE;
2853
2854 if (expr != NULL && expr->ts.type == BT_DERIVED
2855 && expr->ts.is_iso_c && expr->ts.derived
2856 && (expr->symtree->n.sym->intmod_sym_id == ISOCBINDING_NULL_PTR
2857 || expr->symtree->n.sym->intmod_sym_id == ISOCBINDING_NULL_FUNPTR))
2858 expr = gfc_int_expr (0);
2859
2860 if (array)
2861 {
2862 /* Arrays need special handling. */
2863 if (pointer)
2864 return gfc_build_null_descriptor (type);
2865 else
2866 return gfc_conv_array_initializer (type, expr);
2867 }
2868 else if (pointer)
2869 return fold_convert (type, null_pointer_node);
2870 else
2871 {
2872 switch (ts->type)
2873 {
2874 case BT_DERIVED:
2875 gfc_init_se (&se, NULL);
2876 gfc_conv_structure (&se, expr, 1);
2877 return se.expr;
2878
2879 case BT_CHARACTER:
2880 return gfc_conv_string_init (ts->cl->backend_decl,expr);
2881
2882 default:
2883 gfc_init_se (&se, NULL);
2884 gfc_conv_constant (&se, expr);
2885 return se.expr;
2886 }
2887 }
2888 }
2889
2890 static tree
2891 gfc_trans_subarray_assign (tree dest, gfc_component * cm, gfc_expr * expr)
2892 {
2893 gfc_se rse;
2894 gfc_se lse;
2895 gfc_ss *rss;
2896 gfc_ss *lss;
2897 stmtblock_t body;
2898 stmtblock_t block;
2899 gfc_loopinfo loop;
2900 int n;
2901 tree tmp;
2902
2903 gfc_start_block (&block);
2904
2905 /* Initialize the scalarizer. */
2906 gfc_init_loopinfo (&loop);
2907
2908 gfc_init_se (&lse, NULL);
2909 gfc_init_se (&rse, NULL);
2910
2911 /* Walk the rhs. */
2912 rss = gfc_walk_expr (expr);
2913 if (rss == gfc_ss_terminator)
2914 {
2915 /* The rhs is scalar. Add a ss for the expression. */
2916 rss = gfc_get_ss ();
2917 rss->next = gfc_ss_terminator;
2918 rss->type = GFC_SS_SCALAR;
2919 rss->expr = expr;
2920 }
2921
2922 /* Create a SS for the destination. */
2923 lss = gfc_get_ss ();
2924 lss->type = GFC_SS_COMPONENT;
2925 lss->expr = NULL;
2926 lss->shape = gfc_get_shape (cm->as->rank);
2927 lss->next = gfc_ss_terminator;
2928 lss->data.info.dimen = cm->as->rank;
2929 lss->data.info.descriptor = dest;
2930 lss->data.info.data = gfc_conv_array_data (dest);
2931 lss->data.info.offset = gfc_conv_array_offset (dest);
2932 for (n = 0; n < cm->as->rank; n++)
2933 {
2934 lss->data.info.dim[n] = n;
2935 lss->data.info.start[n] = gfc_conv_array_lbound (dest, n);
2936 lss->data.info.stride[n] = gfc_index_one_node;
2937
2938 mpz_init (lss->shape[n]);
2939 mpz_sub (lss->shape[n], cm->as->upper[n]->value.integer,
2940 cm->as->lower[n]->value.integer);
2941 mpz_add_ui (lss->shape[n], lss->shape[n], 1);
2942 }
2943
2944 /* Associate the SS with the loop. */
2945 gfc_add_ss_to_loop (&loop, lss);
2946 gfc_add_ss_to_loop (&loop, rss);
2947
2948 /* Calculate the bounds of the scalarization. */
2949 gfc_conv_ss_startstride (&loop);
2950
2951 /* Setup the scalarizing loops. */
2952 gfc_conv_loop_setup (&loop);
2953
2954 /* Setup the gfc_se structures. */
2955 gfc_copy_loopinfo_to_se (&lse, &loop);
2956 gfc_copy_loopinfo_to_se (&rse, &loop);
2957
2958 rse.ss = rss;
2959 gfc_mark_ss_chain_used (rss, 1);
2960 lse.ss = lss;
2961 gfc_mark_ss_chain_used (lss, 1);
2962
2963 /* Start the scalarized loop body. */
2964 gfc_start_scalarized_body (&loop, &body);
2965
2966 gfc_conv_tmp_array_ref (&lse);
2967 if (cm->ts.type == BT_CHARACTER)
2968 lse.string_length = cm->ts.cl->backend_decl;
2969
2970 gfc_conv_expr (&rse, expr);
2971
2972 tmp = gfc_trans_scalar_assign (&lse, &rse, cm->ts, true, false);
2973 gfc_add_expr_to_block (&body, tmp);
2974
2975 gcc_assert (rse.ss == gfc_ss_terminator);
2976
2977 /* Generate the copying loops. */
2978 gfc_trans_scalarizing_loops (&loop, &body);
2979
2980 /* Wrap the whole thing up. */
2981 gfc_add_block_to_block (&block, &loop.pre);
2982 gfc_add_block_to_block (&block, &loop.post);
2983
2984 for (n = 0; n < cm->as->rank; n++)
2985 mpz_clear (lss->shape[n]);
2986 gfc_free (lss->shape);
2987
2988 gfc_cleanup_loop (&loop);
2989
2990 return gfc_finish_block (&block);
2991 }
2992
2993
2994 /* Assign a single component of a derived type constructor. */
2995
2996 static tree
2997 gfc_trans_subcomponent_assign (tree dest, gfc_component * cm, gfc_expr * expr)
2998 {
2999 gfc_se se;
3000 gfc_se lse;
3001 gfc_ss *rss;
3002 stmtblock_t block;
3003 tree tmp;
3004 tree offset;
3005 int n;
3006
3007 gfc_start_block (&block);
3008
3009 if (cm->pointer)
3010 {
3011 gfc_init_se (&se, NULL);
3012 /* Pointer component. */
3013 if (cm->dimension)
3014 {
3015 /* Array pointer. */
3016 if (expr->expr_type == EXPR_NULL)
3017 gfc_conv_descriptor_data_set (&block, dest, null_pointer_node);
3018 else
3019 {
3020 rss = gfc_walk_expr (expr);
3021 se.direct_byref = 1;
3022 se.expr = dest;
3023 gfc_conv_expr_descriptor (&se, expr, rss);
3024 gfc_add_block_to_block (&block, &se.pre);
3025 gfc_add_block_to_block (&block, &se.post);
3026 }
3027 }
3028 else
3029 {
3030 /* Scalar pointers. */
3031 se.want_pointer = 1;
3032 gfc_conv_expr (&se, expr);
3033 gfc_add_block_to_block (&block, &se.pre);
3034 gfc_add_modify_expr (&block, dest,
3035 fold_convert (TREE_TYPE (dest), se.expr));
3036 gfc_add_block_to_block (&block, &se.post);
3037 }
3038 }
3039 else if (cm->dimension)
3040 {
3041 if (cm->allocatable && expr->expr_type == EXPR_NULL)
3042 gfc_conv_descriptor_data_set (&block, dest, null_pointer_node);
3043 else if (cm->allocatable)
3044 {
3045 tree tmp2;
3046
3047 gfc_init_se (&se, NULL);
3048
3049 rss = gfc_walk_expr (expr);
3050 se.want_pointer = 0;
3051 gfc_conv_expr_descriptor (&se, expr, rss);
3052 gfc_add_block_to_block (&block, &se.pre);
3053
3054 tmp = fold_convert (TREE_TYPE (dest), se.expr);
3055 gfc_add_modify_expr (&block, dest, tmp);
3056
3057 if (cm->ts.type == BT_DERIVED && cm->ts.derived->attr.alloc_comp)
3058 tmp = gfc_copy_alloc_comp (cm->ts.derived, se.expr, dest,
3059 cm->as->rank);
3060 else
3061 tmp = gfc_duplicate_allocatable (dest, se.expr,
3062 TREE_TYPE(cm->backend_decl),
3063 cm->as->rank);
3064
3065 gfc_add_expr_to_block (&block, tmp);
3066
3067 gfc_add_block_to_block (&block, &se.post);
3068 gfc_conv_descriptor_data_set (&block, se.expr, null_pointer_node);
3069
3070 /* Shift the lbound and ubound of temporaries to being unity, rather
3071 than zero, based. Calculate the offset for all cases. */
3072 offset = gfc_conv_descriptor_offset (dest);
3073 gfc_add_modify_expr (&block, offset, gfc_index_zero_node);
3074 tmp2 =gfc_create_var (gfc_array_index_type, NULL);
3075 for (n = 0; n < expr->rank; n++)
3076 {
3077 if (expr->expr_type != EXPR_VARIABLE
3078 && expr->expr_type != EXPR_CONSTANT)
3079 {
3080 tree span;
3081 tmp = gfc_conv_descriptor_ubound (dest, gfc_rank_cst[n]);
3082 span = fold_build2 (MINUS_EXPR, gfc_array_index_type, tmp,
3083 gfc_conv_descriptor_lbound (dest, gfc_rank_cst[n]));
3084 gfc_add_modify_expr (&block, tmp,
3085 fold_build2 (PLUS_EXPR,
3086 gfc_array_index_type,
3087 span, gfc_index_one_node));
3088 tmp = gfc_conv_descriptor_lbound (dest, gfc_rank_cst[n]);
3089 gfc_add_modify_expr (&block, tmp, gfc_index_one_node);
3090 }
3091 tmp = fold_build2 (MULT_EXPR, gfc_array_index_type,
3092 gfc_conv_descriptor_lbound (dest,
3093 gfc_rank_cst[n]),
3094 gfc_conv_descriptor_stride (dest,
3095 gfc_rank_cst[n]));
3096 gfc_add_modify_expr (&block, tmp2, tmp);
3097 tmp = fold_build2 (MINUS_EXPR, gfc_array_index_type, offset, tmp2);
3098 gfc_add_modify_expr (&block, offset, tmp);
3099 }
3100 }
3101 else
3102 {
3103 tmp = gfc_trans_subarray_assign (dest, cm, expr);
3104 gfc_add_expr_to_block (&block, tmp);
3105 }
3106 }
3107 else if (expr->ts.type == BT_DERIVED)
3108 {
3109 if (expr->expr_type != EXPR_STRUCTURE)
3110 {
3111 gfc_init_se (&se, NULL);
3112 gfc_conv_expr (&se, expr);
3113 gfc_add_modify_expr (&block, dest,
3114 fold_convert (TREE_TYPE (dest), se.expr));
3115 }
3116 else
3117 {
3118 /* Nested constructors. */
3119 tmp = gfc_trans_structure_assign (dest, expr);
3120 gfc_add_expr_to_block (&block, tmp);
3121 }
3122 }
3123 else
3124 {
3125 /* Scalar component. */
3126 gfc_init_se (&se, NULL);
3127 gfc_init_se (&lse, NULL);
3128
3129 gfc_conv_expr (&se, expr);
3130 if (cm->ts.type == BT_CHARACTER)
3131 lse.string_length = cm->ts.cl->backend_decl;
3132 lse.expr = dest;
3133 tmp = gfc_trans_scalar_assign (&lse, &se, cm->ts, true, false);
3134 gfc_add_expr_to_block (&block, tmp);
3135 }
3136 return gfc_finish_block (&block);
3137 }
3138
3139 /* Assign a derived type constructor to a variable. */
3140
3141 static tree
3142 gfc_trans_structure_assign (tree dest, gfc_expr * expr)
3143 {
3144 gfc_constructor *c;
3145 gfc_component *cm;
3146 stmtblock_t block;
3147 tree field;
3148 tree tmp;
3149
3150 gfc_start_block (&block);
3151 cm = expr->ts.derived->components;
3152 for (c = expr->value.constructor; c; c = c->next, cm = cm->next)
3153 {
3154 /* Skip absent members in default initializers. */
3155 if (!c->expr)
3156 continue;
3157
3158 /* Update the type/kind of the expression if it represents either
3159 C_NULL_PTR or C_NULL_FUNPTR. This is done here because this may
3160 be the first place reached for initializing output variables that
3161 have components of type C_PTR/C_FUNPTR that are initialized. */
3162 if (c->expr->ts.type == BT_DERIVED && c->expr->ts.derived
3163 && c->expr->ts.derived->attr.is_iso_c)
3164 {
3165 c->expr->expr_type = EXPR_NULL;
3166 c->expr->ts.type = c->expr->ts.derived->ts.type;
3167 c->expr->ts.f90_type = c->expr->ts.derived->ts.f90_type;
3168 c->expr->ts.kind = c->expr->ts.derived->ts.kind;
3169 }
3170
3171 field = cm->backend_decl;
3172 tmp = build3 (COMPONENT_REF, TREE_TYPE (field), dest, field, NULL_TREE);
3173 tmp = gfc_trans_subcomponent_assign (tmp, cm, c->expr);
3174 gfc_add_expr_to_block (&block, tmp);
3175 }
3176 return gfc_finish_block (&block);
3177 }
3178
3179 /* Build an expression for a constructor. If init is nonzero then
3180 this is part of a static variable initializer. */
3181
3182 void
3183 gfc_conv_structure (gfc_se * se, gfc_expr * expr, int init)
3184 {
3185 gfc_constructor *c;
3186 gfc_component *cm;
3187 tree val;
3188 tree type;
3189 tree tmp;
3190 VEC(constructor_elt,gc) *v = NULL;
3191
3192 gcc_assert (se->ss == NULL);
3193 gcc_assert (expr->expr_type == EXPR_STRUCTURE);
3194 type = gfc_typenode_for_spec (&expr->ts);
3195
3196 if (!init)
3197 {
3198 /* Create a temporary variable and fill it in. */
3199 se->expr = gfc_create_var (type, expr->ts.derived->name);
3200 tmp = gfc_trans_structure_assign (se->expr, expr);
3201 gfc_add_expr_to_block (&se->pre, tmp);
3202 return;
3203 }
3204
3205 cm = expr->ts.derived->components;
3206
3207 for (c = expr->value.constructor; c; c = c->next, cm = cm->next)
3208 {
3209 /* Skip absent members in default initializers and allocatable
3210 components. Although the latter have a default initializer
3211 of EXPR_NULL,... by default, the static nullify is not needed
3212 since this is done every time we come into scope. */
3213 if (!c->expr || cm->allocatable)
3214 continue;
3215
3216 val = gfc_conv_initializer (c->expr, &cm->ts,
3217 TREE_TYPE (cm->backend_decl), cm->dimension, cm->pointer);
3218
3219 /* Append it to the constructor list. */
3220 CONSTRUCTOR_APPEND_ELT (v, cm->backend_decl, val);
3221 }
3222 se->expr = build_constructor (type, v);
3223 }
3224
3225
3226 /* Translate a substring expression. */
3227
3228 static void
3229 gfc_conv_substring_expr (gfc_se * se, gfc_expr * expr)
3230 {
3231 gfc_ref *ref;
3232
3233 ref = expr->ref;
3234
3235 gcc_assert (ref == NULL || ref->type == REF_SUBSTRING);
3236
3237 se->expr = gfc_build_string_const (expr->value.character.length,
3238 expr->value.character.string);
3239 se->string_length = TYPE_MAX_VALUE (TYPE_DOMAIN (TREE_TYPE (se->expr)));
3240 TYPE_STRING_FLAG (TREE_TYPE (se->expr)) = 1;
3241
3242 if (ref)
3243 gfc_conv_substring (se, ref, expr->ts.kind, NULL, &expr->where);
3244 }
3245
3246
3247 /* Entry point for expression translation. Evaluates a scalar quantity.
3248 EXPR is the expression to be translated, and SE is the state structure if
3249 called from within the scalarized. */
3250
3251 void
3252 gfc_conv_expr (gfc_se * se, gfc_expr * expr)
3253 {
3254 if (se->ss && se->ss->expr == expr
3255 && (se->ss->type == GFC_SS_SCALAR || se->ss->type == GFC_SS_REFERENCE))
3256 {
3257 /* Substitute a scalar expression evaluated outside the scalarization
3258 loop. */
3259 se->expr = se->ss->data.scalar.expr;
3260 se->string_length = se->ss->string_length;
3261 gfc_advance_se_ss_chain (se);
3262 return;
3263 }
3264
3265 /* We need to convert the expressions for the iso_c_binding derived types.
3266 C_NULL_PTR and C_NULL_FUNPTR will be made EXPR_NULL, which evaluates to
3267 null_pointer_node. C_PTR and C_FUNPTR are converted to match the
3268 typespec for the C_PTR and C_FUNPTR symbols, which has already been
3269 updated to be an integer with a kind equal to the size of a (void *). */
3270 if (expr->ts.type == BT_DERIVED && expr->ts.derived
3271 && expr->ts.derived->attr.is_iso_c)
3272 {
3273 if (expr->symtree->n.sym->intmod_sym_id == ISOCBINDING_NULL_PTR
3274 || expr->symtree->n.sym->intmod_sym_id == ISOCBINDING_NULL_FUNPTR)
3275 {
3276 /* Set expr_type to EXPR_NULL, which will result in
3277 null_pointer_node being used below. */
3278 expr->expr_type = EXPR_NULL;
3279 }
3280 else
3281 {
3282 /* Update the type/kind of the expression to be what the new
3283 type/kind are for the updated symbols of C_PTR/C_FUNPTR. */
3284 expr->ts.type = expr->ts.derived->ts.type;
3285 expr->ts.f90_type = expr->ts.derived->ts.f90_type;
3286 expr->ts.kind = expr->ts.derived->ts.kind;
3287 }
3288 }
3289
3290 switch (expr->expr_type)
3291 {
3292 case EXPR_OP:
3293 gfc_conv_expr_op (se, expr);
3294 break;
3295
3296 case EXPR_FUNCTION:
3297 gfc_conv_function_expr (se, expr);
3298 break;
3299
3300 case EXPR_CONSTANT:
3301 gfc_conv_constant (se, expr);
3302 break;
3303
3304 case EXPR_VARIABLE:
3305 gfc_conv_variable (se, expr);
3306 break;
3307
3308 case EXPR_NULL:
3309 se->expr = null_pointer_node;
3310 break;
3311
3312 case EXPR_SUBSTRING:
3313 gfc_conv_substring_expr (se, expr);
3314 break;
3315
3316 case EXPR_STRUCTURE:
3317 gfc_conv_structure (se, expr, 0);
3318 break;
3319
3320 case EXPR_ARRAY:
3321 gfc_conv_array_constructor_expr (se, expr);
3322 break;
3323
3324 default:
3325 gcc_unreachable ();
3326 break;
3327 }
3328 }
3329
3330 /* Like gfc_conv_expr_val, but the value is also suitable for use in the lhs
3331 of an assignment. */
3332 void
3333 gfc_conv_expr_lhs (gfc_se * se, gfc_expr * expr)
3334 {
3335 gfc_conv_expr (se, expr);
3336 /* All numeric lvalues should have empty post chains. If not we need to
3337 figure out a way of rewriting an lvalue so that it has no post chain. */
3338 gcc_assert (expr->ts.type == BT_CHARACTER || !se->post.head);
3339 }
3340
3341 /* Like gfc_conv_expr, but the POST block is guaranteed to be empty for
3342 numeric expressions. Used for scalar values where inserting cleanup code
3343 is inconvenient. */
3344 void
3345 gfc_conv_expr_val (gfc_se * se, gfc_expr * expr)
3346 {
3347 tree val;
3348
3349 gcc_assert (expr->ts.type != BT_CHARACTER);
3350 gfc_conv_expr (se, expr);
3351 if (se->post.head)
3352 {
3353 val = gfc_create_var (TREE_TYPE (se->expr), NULL);
3354 gfc_add_modify_expr (&se->pre, val, se->expr);
3355 se->expr = val;
3356 gfc_add_block_to_block (&se->pre, &se->post);
3357 }
3358 }
3359
3360 /* Helper to translate and expression and convert it to a particular type. */
3361 void
3362 gfc_conv_expr_type (gfc_se * se, gfc_expr * expr, tree type)
3363 {
3364 gfc_conv_expr_val (se, expr);
3365 se->expr = convert (type, se->expr);
3366 }
3367
3368
3369 /* Converts an expression so that it can be passed by reference. Scalar
3370 values only. */
3371
3372 void
3373 gfc_conv_expr_reference (gfc_se * se, gfc_expr * expr)
3374 {
3375 tree var;
3376
3377 if (se->ss && se->ss->expr == expr
3378 && se->ss->type == GFC_SS_REFERENCE)
3379 {
3380 se->expr = se->ss->data.scalar.expr;
3381 se->string_length = se->ss->string_length;
3382 gfc_advance_se_ss_chain (se);
3383 return;
3384 }
3385
3386 if (expr->ts.type == BT_CHARACTER)
3387 {
3388 gfc_conv_expr (se, expr);
3389 gfc_conv_string_parameter (se);
3390 return;
3391 }
3392
3393 if (expr->expr_type == EXPR_VARIABLE)
3394 {
3395 se->want_pointer = 1;
3396 gfc_conv_expr (se, expr);
3397 if (se->post.head)
3398 {
3399 var = gfc_create_var (TREE_TYPE (se->expr), NULL);
3400 gfc_add_modify_expr (&se->pre, var, se->expr);
3401 gfc_add_block_to_block (&se->pre, &se->post);
3402 se->expr = var;
3403 }
3404 return;
3405 }
3406
3407 if (expr->expr_type == EXPR_FUNCTION
3408 && expr->symtree->n.sym->attr.pointer
3409 && !expr->symtree->n.sym->attr.dimension)
3410 {
3411 se->want_pointer = 1;
3412 gfc_conv_expr (se, expr);
3413 var = gfc_create_var (TREE_TYPE (se->expr), NULL);
3414 gfc_add_modify_expr (&se->pre, var, se->expr);
3415 se->expr = var;
3416 return;
3417 }
3418
3419
3420 gfc_conv_expr (se, expr);
3421
3422 /* Create a temporary var to hold the value. */
3423 if (TREE_CONSTANT (se->expr))
3424 {
3425 tree tmp = se->expr;
3426 STRIP_TYPE_NOPS (tmp);
3427 var = build_decl (CONST_DECL, NULL, TREE_TYPE (tmp));
3428 DECL_INITIAL (var) = tmp;
3429 TREE_STATIC (var) = 1;
3430 pushdecl (var);
3431 }
3432 else
3433 {
3434 var = gfc_create_var (TREE_TYPE (se->expr), NULL);
3435 gfc_add_modify_expr (&se->pre, var, se->expr);
3436 }
3437 gfc_add_block_to_block (&se->pre, &se->post);
3438
3439 /* Take the address of that value. */
3440 se->expr = build_fold_addr_expr (var);
3441 }
3442
3443
3444 tree
3445 gfc_trans_pointer_assign (gfc_code * code)
3446 {
3447 return gfc_trans_pointer_assignment (code->expr, code->expr2);
3448 }
3449
3450
3451 /* Generate code for a pointer assignment. */
3452
3453 tree
3454 gfc_trans_pointer_assignment (gfc_expr * expr1, gfc_expr * expr2)
3455 {
3456 gfc_se lse;
3457 gfc_se rse;
3458 gfc_ss *lss;
3459 gfc_ss *rss;
3460 stmtblock_t block;
3461 tree desc;
3462 tree tmp;
3463
3464 gfc_start_block (&block);
3465
3466 gfc_init_se (&lse, NULL);
3467
3468 lss = gfc_walk_expr (expr1);
3469 rss = gfc_walk_expr (expr2);
3470 if (lss == gfc_ss_terminator)
3471 {
3472 /* Scalar pointers. */
3473 lse.want_pointer = 1;
3474 gfc_conv_expr (&lse, expr1);
3475 gcc_assert (rss == gfc_ss_terminator);
3476 gfc_init_se (&rse, NULL);
3477 rse.want_pointer = 1;
3478 gfc_conv_expr (&rse, expr2);
3479 gfc_add_block_to_block (&block, &lse.pre);
3480 gfc_add_block_to_block (&block, &rse.pre);
3481 gfc_add_modify_expr (&block, lse.expr,
3482 fold_convert (TREE_TYPE (lse.expr), rse.expr));
3483 gfc_add_block_to_block (&block, &rse.post);
3484 gfc_add_block_to_block (&block, &lse.post);
3485 }
3486 else
3487 {
3488 /* Array pointer. */
3489 gfc_conv_expr_descriptor (&lse, expr1, lss);
3490 switch (expr2->expr_type)
3491 {
3492 case EXPR_NULL:
3493 /* Just set the data pointer to null. */
3494 gfc_conv_descriptor_data_set (&lse.pre, lse.expr, null_pointer_node);
3495 break;
3496
3497 case EXPR_VARIABLE:
3498 /* Assign directly to the pointer's descriptor. */
3499 lse.direct_byref = 1;
3500 gfc_conv_expr_descriptor (&lse, expr2, rss);
3501 break;
3502
3503 default:
3504 /* Assign to a temporary descriptor and then copy that
3505 temporary to the pointer. */
3506 desc = lse.expr;
3507 tmp = gfc_create_var (TREE_TYPE (desc), "ptrtemp");
3508
3509 lse.expr = tmp;
3510 lse.direct_byref = 1;
3511 gfc_conv_expr_descriptor (&lse, expr2, rss);
3512 gfc_add_modify_expr (&lse.pre, desc, tmp);
3513 break;
3514 }
3515 gfc_add_block_to_block (&block, &lse.pre);
3516 gfc_add_block_to_block (&block, &lse.post);
3517 }
3518 return gfc_finish_block (&block);
3519 }
3520
3521
3522 /* Makes sure se is suitable for passing as a function string parameter. */
3523 /* TODO: Need to check all callers fo this function. It may be abused. */
3524
3525 void
3526 gfc_conv_string_parameter (gfc_se * se)
3527 {
3528 tree type;
3529
3530 if (TREE_CODE (se->expr) == STRING_CST)
3531 {
3532 se->expr = gfc_build_addr_expr (pchar_type_node, se->expr);
3533 return;
3534 }
3535
3536 type = TREE_TYPE (se->expr);
3537 if (TYPE_STRING_FLAG (type))
3538 {
3539 gcc_assert (TREE_CODE (se->expr) != INDIRECT_REF);
3540 se->expr = gfc_build_addr_expr (pchar_type_node, se->expr);
3541 }
3542
3543 gcc_assert (POINTER_TYPE_P (TREE_TYPE (se->expr)));
3544 gcc_assert (se->string_length
3545 && TREE_CODE (TREE_TYPE (se->string_length)) == INTEGER_TYPE);
3546 }
3547
3548
3549 /* Generate code for assignment of scalar variables. Includes character
3550 strings and derived types with allocatable components. */
3551
3552 tree
3553 gfc_trans_scalar_assign (gfc_se * lse, gfc_se * rse, gfc_typespec ts,
3554 bool l_is_temp, bool r_is_var)
3555 {
3556 stmtblock_t block;
3557 tree tmp;
3558 tree cond;
3559
3560 gfc_init_block (&block);
3561
3562 if (ts.type == BT_CHARACTER)
3563 {
3564 gcc_assert (lse->string_length != NULL_TREE
3565 && rse->string_length != NULL_TREE);
3566
3567 gfc_conv_string_parameter (lse);
3568 gfc_conv_string_parameter (rse);
3569
3570 gfc_add_block_to_block (&block, &lse->pre);
3571 gfc_add_block_to_block (&block, &rse->pre);
3572
3573 gfc_trans_string_copy (&block, lse->string_length, lse->expr,
3574 rse->string_length, rse->expr);
3575 }
3576 else if (ts.type == BT_DERIVED && ts.derived->attr.alloc_comp)
3577 {
3578 cond = NULL_TREE;
3579
3580 /* Are the rhs and the lhs the same? */
3581 if (r_is_var)
3582 {
3583 cond = fold_build2 (EQ_EXPR, boolean_type_node,
3584 build_fold_addr_expr (lse->expr),
3585 build_fold_addr_expr (rse->expr));
3586 cond = gfc_evaluate_now (cond, &lse->pre);
3587 }
3588
3589 /* Deallocate the lhs allocated components as long as it is not
3590 the same as the rhs. This must be done following the assignment
3591 to prevent deallocating data that could be used in the rhs
3592 expression. */
3593 if (!l_is_temp)
3594 {
3595 tmp = gfc_evaluate_now (lse->expr, &lse->pre);
3596 tmp = gfc_deallocate_alloc_comp (ts.derived, tmp, 0);
3597 if (r_is_var)
3598 tmp = build3_v (COND_EXPR, cond, build_empty_stmt (), tmp);
3599 gfc_add_expr_to_block (&lse->post, tmp);
3600 }
3601
3602 gfc_add_block_to_block (&block, &rse->pre);
3603 gfc_add_block_to_block (&block, &lse->pre);
3604
3605 gfc_add_modify_expr (&block, lse->expr,
3606 fold_convert (TREE_TYPE (lse->expr), rse->expr));
3607
3608 /* Do a deep copy if the rhs is a variable, if it is not the
3609 same as the lhs. */
3610 if (r_is_var)
3611 {
3612 tmp = gfc_copy_alloc_comp (ts.derived, rse->expr, lse->expr, 0);
3613 tmp = build3_v (COND_EXPR, cond, build_empty_stmt (), tmp);
3614 gfc_add_expr_to_block (&block, tmp);
3615 }
3616 }
3617 else
3618 {
3619 gfc_add_block_to_block (&block, &lse->pre);
3620 gfc_add_block_to_block (&block, &rse->pre);
3621
3622 gfc_add_modify_expr (&block, lse->expr,
3623 fold_convert (TREE_TYPE (lse->expr), rse->expr));
3624 }
3625
3626 gfc_add_block_to_block (&block, &lse->post);
3627 gfc_add_block_to_block (&block, &rse->post);
3628
3629 return gfc_finish_block (&block);
3630 }
3631
3632
3633 /* Try to translate array(:) = func (...), where func is a transformational
3634 array function, without using a temporary. Returns NULL is this isn't the
3635 case. */
3636
3637 static tree
3638 gfc_trans_arrayfunc_assign (gfc_expr * expr1, gfc_expr * expr2)
3639 {
3640 gfc_se se;
3641 gfc_ss *ss;
3642 gfc_ref * ref;
3643 bool seen_array_ref;
3644
3645 /* The caller has already checked rank>0 and expr_type == EXPR_FUNCTION. */
3646 if (expr2->value.function.isym && !gfc_is_intrinsic_libcall (expr2))
3647 return NULL;
3648
3649 /* Elemental functions don't need a temporary anyway. */
3650 if (expr2->value.function.esym != NULL
3651 && expr2->value.function.esym->attr.elemental)
3652 return NULL;
3653
3654 /* Fail if EXPR1 can't be expressed as a descriptor. */
3655 if (gfc_ref_needs_temporary_p (expr1->ref))
3656 return NULL;
3657
3658 /* Functions returning pointers need temporaries. */
3659 if (expr2->symtree->n.sym->attr.pointer
3660 || expr2->symtree->n.sym->attr.allocatable)
3661 return NULL;
3662
3663 /* Character array functions need temporaries unless the
3664 character lengths are the same. */
3665 if (expr2->ts.type == BT_CHARACTER && expr2->rank > 0)
3666 {
3667 if (expr1->ts.cl->length == NULL
3668 || expr1->ts.cl->length->expr_type != EXPR_CONSTANT)
3669 return NULL;
3670
3671 if (expr2->ts.cl->length == NULL
3672 || expr2->ts.cl->length->expr_type != EXPR_CONSTANT)
3673 return NULL;
3674
3675 if (mpz_cmp (expr1->ts.cl->length->value.integer,
3676 expr2->ts.cl->length->value.integer) != 0)
3677 return NULL;
3678 }
3679
3680 /* Check that no LHS component references appear during an array
3681 reference. This is needed because we do not have the means to
3682 span any arbitrary stride with an array descriptor. This check
3683 is not needed for the rhs because the function result has to be
3684 a complete type. */
3685 seen_array_ref = false;
3686 for (ref = expr1->ref; ref; ref = ref->next)
3687 {
3688 if (ref->type == REF_ARRAY)
3689 seen_array_ref= true;
3690 else if (ref->type == REF_COMPONENT && seen_array_ref)
3691 return NULL;
3692 }
3693
3694 /* Check for a dependency. */
3695 if (gfc_check_fncall_dependency (expr1, INTENT_OUT,
3696 expr2->value.function.esym,
3697 expr2->value.function.actual))
3698 return NULL;
3699
3700 /* The frontend doesn't seem to bother filling in expr->symtree for intrinsic
3701 functions. */
3702 gcc_assert (expr2->value.function.isym
3703 || (gfc_return_by_reference (expr2->value.function.esym)
3704 && expr2->value.function.esym->result->attr.dimension));
3705
3706 ss = gfc_walk_expr (expr1);
3707 gcc_assert (ss != gfc_ss_terminator);
3708 gfc_init_se (&se, NULL);
3709 gfc_start_block (&se.pre);
3710 se.want_pointer = 1;
3711
3712 gfc_conv_array_parameter (&se, expr1, ss, 0);
3713
3714 se.direct_byref = 1;
3715 se.ss = gfc_walk_expr (expr2);
3716 gcc_assert (se.ss != gfc_ss_terminator);
3717 gfc_conv_function_expr (&se, expr2);
3718 gfc_add_block_to_block (&se.pre, &se.post);
3719
3720 return gfc_finish_block (&se.pre);
3721 }
3722
3723 /* Determine whether the given EXPR_CONSTANT is a zero initializer. */
3724
3725 static bool
3726 is_zero_initializer_p (gfc_expr * expr)
3727 {
3728 if (expr->expr_type != EXPR_CONSTANT)
3729 return false;
3730
3731 /* We ignore constants with prescribed memory representations for now. */
3732 if (expr->representation.string)
3733 return false;
3734
3735 switch (expr->ts.type)
3736 {
3737 case BT_INTEGER:
3738 return mpz_cmp_si (expr->value.integer, 0) == 0;
3739
3740 case BT_REAL:
3741 return mpfr_zero_p (expr->value.real)
3742 && MPFR_SIGN (expr->value.real) >= 0;
3743
3744 case BT_LOGICAL:
3745 return expr->value.logical == 0;
3746
3747 case BT_COMPLEX:
3748 return mpfr_zero_p (expr->value.complex.r)
3749 && MPFR_SIGN (expr->value.complex.r) >= 0
3750 && mpfr_zero_p (expr->value.complex.i)
3751 && MPFR_SIGN (expr->value.complex.i) >= 0;
3752
3753 default:
3754 break;
3755 }
3756 return false;
3757 }
3758
3759 /* Try to efficiently translate array(:) = 0. Return NULL if this
3760 can't be done. */
3761
3762 static tree
3763 gfc_trans_zero_assign (gfc_expr * expr)
3764 {
3765 tree dest, len, type;
3766 tree tmp;
3767 gfc_symbol *sym;
3768
3769 sym = expr->symtree->n.sym;
3770 dest = gfc_get_symbol_decl (sym);
3771
3772 type = TREE_TYPE (dest);
3773 if (POINTER_TYPE_P (type))
3774 type = TREE_TYPE (type);
3775 if (!GFC_ARRAY_TYPE_P (type))
3776 return NULL_TREE;
3777
3778 /* Determine the length of the array. */
3779 len = GFC_TYPE_ARRAY_SIZE (type);
3780 if (!len || TREE_CODE (len) != INTEGER_CST)
3781 return NULL_TREE;
3782
3783 tmp = TYPE_SIZE_UNIT (gfc_get_element_type (type));
3784 len = fold_build2 (MULT_EXPR, gfc_array_index_type, len,
3785 fold_convert (gfc_array_index_type, tmp));
3786
3787 /* Convert arguments to the correct types. */
3788 if (!POINTER_TYPE_P (TREE_TYPE (dest)))
3789 dest = gfc_build_addr_expr (pvoid_type_node, dest);
3790 else
3791 dest = fold_convert (pvoid_type_node, dest);
3792 len = fold_convert (size_type_node, len);
3793
3794 /* Construct call to __builtin_memset. */
3795 tmp = build_call_expr (built_in_decls[BUILT_IN_MEMSET],
3796 3, dest, integer_zero_node, len);
3797 return fold_convert (void_type_node, tmp);
3798 }
3799
3800
3801 /* Helper for gfc_trans_array_copy and gfc_trans_array_constructor_copy
3802 that constructs the call to __builtin_memcpy. */
3803
3804 static tree
3805 gfc_build_memcpy_call (tree dst, tree src, tree len)
3806 {
3807 tree tmp;
3808
3809 /* Convert arguments to the correct types. */
3810 if (!POINTER_TYPE_P (TREE_TYPE (dst)))
3811 dst = gfc_build_addr_expr (pvoid_type_node, dst);
3812 else
3813 dst = fold_convert (pvoid_type_node, dst);
3814
3815 if (!POINTER_TYPE_P (TREE_TYPE (src)))
3816 src = gfc_build_addr_expr (pvoid_type_node, src);
3817 else
3818 src = fold_convert (pvoid_type_node, src);
3819
3820 len = fold_convert (size_type_node, len);
3821
3822 /* Construct call to __builtin_memcpy. */
3823 tmp = build_call_expr (built_in_decls[BUILT_IN_MEMCPY], 3, dst, src, len);
3824 return fold_convert (void_type_node, tmp);
3825 }
3826
3827
3828 /* Try to efficiently translate dst(:) = src(:). Return NULL if this
3829 can't be done. EXPR1 is the destination/lhs and EXPR2 is the
3830 source/rhs, both are gfc_full_array_ref_p which have been checked for
3831 dependencies. */
3832
3833 static tree
3834 gfc_trans_array_copy (gfc_expr * expr1, gfc_expr * expr2)
3835 {
3836 tree dst, dlen, dtype;
3837 tree src, slen, stype;
3838 tree tmp;
3839
3840 dst = gfc_get_symbol_decl (expr1->symtree->n.sym);
3841 src = gfc_get_symbol_decl (expr2->symtree->n.sym);
3842
3843 dtype = TREE_TYPE (dst);
3844 if (POINTER_TYPE_P (dtype))
3845 dtype = TREE_TYPE (dtype);
3846 stype = TREE_TYPE (src);
3847 if (POINTER_TYPE_P (stype))
3848 stype = TREE_TYPE (stype);
3849
3850 if (!GFC_ARRAY_TYPE_P (dtype) || !GFC_ARRAY_TYPE_P (stype))
3851 return NULL_TREE;
3852
3853 /* Determine the lengths of the arrays. */
3854 dlen = GFC_TYPE_ARRAY_SIZE (dtype);
3855 if (!dlen || TREE_CODE (dlen) != INTEGER_CST)
3856 return NULL_TREE;
3857 tmp = TYPE_SIZE_UNIT (gfc_get_element_type (dtype));
3858 dlen = fold_build2 (MULT_EXPR, gfc_array_index_type, dlen,
3859 fold_convert (gfc_array_index_type, tmp));
3860
3861 slen = GFC_TYPE_ARRAY_SIZE (stype);
3862 if (!slen || TREE_CODE (slen) != INTEGER_CST)
3863 return NULL_TREE;
3864 tmp = TYPE_SIZE_UNIT (gfc_get_element_type (stype));
3865 slen = fold_build2 (MULT_EXPR, gfc_array_index_type, slen,
3866 fold_convert (gfc_array_index_type, tmp));
3867
3868 /* Sanity check that they are the same. This should always be
3869 the case, as we should already have checked for conformance. */
3870 if (!tree_int_cst_equal (slen, dlen))
3871 return NULL_TREE;
3872
3873 return gfc_build_memcpy_call (dst, src, dlen);
3874 }
3875
3876
3877 /* Try to efficiently translate array(:) = (/ ... /). Return NULL if
3878 this can't be done. EXPR1 is the destination/lhs for which
3879 gfc_full_array_ref_p is true, and EXPR2 is the source/rhs. */
3880
3881 static tree
3882 gfc_trans_array_constructor_copy (gfc_expr * expr1, gfc_expr * expr2)
3883 {
3884 unsigned HOST_WIDE_INT nelem;
3885 tree dst, dtype;
3886 tree src, stype;
3887 tree len;
3888 tree tmp;
3889
3890 nelem = gfc_constant_array_constructor_p (expr2->value.constructor);
3891 if (nelem == 0)
3892 return NULL_TREE;
3893
3894 dst = gfc_get_symbol_decl (expr1->symtree->n.sym);
3895 dtype = TREE_TYPE (dst);
3896 if (POINTER_TYPE_P (dtype))
3897 dtype = TREE_TYPE (dtype);
3898 if (!GFC_ARRAY_TYPE_P (dtype))
3899 return NULL_TREE;
3900
3901 /* Determine the lengths of the array. */
3902 len = GFC_TYPE_ARRAY_SIZE (dtype);
3903 if (!len || TREE_CODE (len) != INTEGER_CST)
3904 return NULL_TREE;
3905
3906 /* Confirm that the constructor is the same size. */
3907 if (compare_tree_int (len, nelem) != 0)
3908 return NULL_TREE;
3909
3910 tmp = TYPE_SIZE_UNIT (gfc_get_element_type (dtype));
3911 len = fold_build2 (MULT_EXPR, gfc_array_index_type, len,
3912 fold_convert (gfc_array_index_type, tmp));
3913
3914 stype = gfc_typenode_for_spec (&expr2->ts);
3915 src = gfc_build_constant_array_constructor (expr2, stype);
3916
3917 stype = TREE_TYPE (src);
3918 if (POINTER_TYPE_P (stype))
3919 stype = TREE_TYPE (stype);
3920
3921 return gfc_build_memcpy_call (dst, src, len);
3922 }
3923
3924
3925 /* Subroutine of gfc_trans_assignment that actually scalarizes the
3926 assignment. EXPR1 is the destination/RHS and EXPR2 is the source/LHS. */
3927
3928 static tree
3929 gfc_trans_assignment_1 (gfc_expr * expr1, gfc_expr * expr2, bool init_flag)
3930 {
3931 gfc_se lse;
3932 gfc_se rse;
3933 gfc_ss *lss;
3934 gfc_ss *lss_section;
3935 gfc_ss *rss;
3936 gfc_loopinfo loop;
3937 tree tmp;
3938 stmtblock_t block;
3939 stmtblock_t body;
3940 bool l_is_temp;
3941
3942 /* Assignment of the form lhs = rhs. */
3943 gfc_start_block (&block);
3944
3945 gfc_init_se (&lse, NULL);
3946 gfc_init_se (&rse, NULL);
3947
3948 /* Walk the lhs. */
3949 lss = gfc_walk_expr (expr1);
3950 rss = NULL;
3951 if (lss != gfc_ss_terminator)
3952 {
3953 /* The assignment needs scalarization. */
3954 lss_section = lss;
3955
3956 /* Find a non-scalar SS from the lhs. */
3957 while (lss_section != gfc_ss_terminator
3958 && lss_section->type != GFC_SS_SECTION)
3959 lss_section = lss_section->next;
3960
3961 gcc_assert (lss_section != gfc_ss_terminator);
3962
3963 /* Initialize the scalarizer. */
3964 gfc_init_loopinfo (&loop);
3965
3966 /* Walk the rhs. */
3967 rss = gfc_walk_expr (expr2);
3968 if (rss == gfc_ss_terminator)
3969 {
3970 /* The rhs is scalar. Add a ss for the expression. */
3971 rss = gfc_get_ss ();
3972 rss->next = gfc_ss_terminator;
3973 rss->type = GFC_SS_SCALAR;
3974 rss->expr = expr2;
3975 }
3976 /* Associate the SS with the loop. */
3977 gfc_add_ss_to_loop (&loop, lss);
3978 gfc_add_ss_to_loop (&loop, rss);
3979
3980 /* Calculate the bounds of the scalarization. */
3981 gfc_conv_ss_startstride (&loop);
3982 /* Resolve any data dependencies in the statement. */
3983 gfc_conv_resolve_dependencies (&loop, lss, rss);
3984 /* Setup the scalarizing loops. */
3985 gfc_conv_loop_setup (&loop);
3986
3987 /* Setup the gfc_se structures. */
3988 gfc_copy_loopinfo_to_se (&lse, &loop);
3989 gfc_copy_loopinfo_to_se (&rse, &loop);
3990
3991 rse.ss = rss;
3992 gfc_mark_ss_chain_used (rss, 1);
3993 if (loop.temp_ss == NULL)
3994 {
3995 lse.ss = lss;
3996 gfc_mark_ss_chain_used (lss, 1);
3997 }
3998 else
3999 {
4000 lse.ss = loop.temp_ss;
4001 gfc_mark_ss_chain_used (lss, 3);
4002 gfc_mark_ss_chain_used (loop.temp_ss, 3);
4003 }
4004
4005 /* Start the scalarized loop body. */
4006 gfc_start_scalarized_body (&loop, &body);
4007 }
4008 else
4009 gfc_init_block (&body);
4010
4011 l_is_temp = (lss != gfc_ss_terminator && loop.temp_ss != NULL);
4012
4013 /* Translate the expression. */
4014 gfc_conv_expr (&rse, expr2);
4015
4016 if (l_is_temp)
4017 {
4018 gfc_conv_tmp_array_ref (&lse);
4019 gfc_advance_se_ss_chain (&lse);
4020 }
4021 else
4022 gfc_conv_expr (&lse, expr1);
4023
4024 tmp = gfc_trans_scalar_assign (&lse, &rse, expr1->ts,
4025 l_is_temp || init_flag,
4026 expr2->expr_type == EXPR_VARIABLE);
4027 gfc_add_expr_to_block (&body, tmp);
4028
4029 if (lss == gfc_ss_terminator)
4030 {
4031 /* Use the scalar assignment as is. */
4032 gfc_add_block_to_block (&block, &body);
4033 }
4034 else
4035 {
4036 gcc_assert (lse.ss == gfc_ss_terminator
4037 && rse.ss == gfc_ss_terminator);
4038
4039 if (l_is_temp)
4040 {
4041 gfc_trans_scalarized_loop_boundary (&loop, &body);
4042
4043 /* We need to copy the temporary to the actual lhs. */
4044 gfc_init_se (&lse, NULL);
4045 gfc_init_se (&rse, NULL);
4046 gfc_copy_loopinfo_to_se (&lse, &loop);
4047 gfc_copy_loopinfo_to_se (&rse, &loop);
4048
4049 rse.ss = loop.temp_ss;
4050 lse.ss = lss;
4051
4052 gfc_conv_tmp_array_ref (&rse);
4053 gfc_advance_se_ss_chain (&rse);
4054 gfc_conv_expr (&lse, expr1);
4055
4056 gcc_assert (lse.ss == gfc_ss_terminator
4057 && rse.ss == gfc_ss_terminator);
4058
4059 tmp = gfc_trans_scalar_assign (&lse, &rse, expr1->ts,
4060 false, false);
4061 gfc_add_expr_to_block (&body, tmp);
4062 }
4063
4064 /* Generate the copying loops. */
4065 gfc_trans_scalarizing_loops (&loop, &body);
4066
4067 /* Wrap the whole thing up. */
4068 gfc_add_block_to_block (&block, &loop.pre);
4069 gfc_add_block_to_block (&block, &loop.post);
4070
4071 gfc_cleanup_loop (&loop);
4072 }
4073
4074 return gfc_finish_block (&block);
4075 }
4076
4077
4078 /* Check whether EXPR is a copyable array. */
4079
4080 static bool
4081 copyable_array_p (gfc_expr * expr)
4082 {
4083 if (expr->expr_type != EXPR_VARIABLE)
4084 return false;
4085
4086 /* First check it's an array. */
4087 if (expr->rank < 1 || !expr->ref || expr->ref->next)
4088 return false;
4089
4090 if (!gfc_full_array_ref_p (expr->ref))
4091 return false;
4092
4093 /* Next check that it's of a simple enough type. */
4094 switch (expr->ts.type)
4095 {
4096 case BT_INTEGER:
4097 case BT_REAL:
4098 case BT_COMPLEX:
4099 case BT_LOGICAL:
4100 return true;
4101
4102 case BT_CHARACTER:
4103 return false;
4104
4105 case BT_DERIVED:
4106 return !expr->ts.derived->attr.alloc_comp;
4107
4108 default:
4109 break;
4110 }
4111
4112 return false;
4113 }
4114
4115 /* Translate an assignment. */
4116
4117 tree
4118 gfc_trans_assignment (gfc_expr * expr1, gfc_expr * expr2, bool init_flag)
4119 {
4120 tree tmp;
4121
4122 /* Special case a single function returning an array. */
4123 if (expr2->expr_type == EXPR_FUNCTION && expr2->rank > 0)
4124 {
4125 tmp = gfc_trans_arrayfunc_assign (expr1, expr2);
4126 if (tmp)
4127 return tmp;
4128 }
4129
4130 /* Special case assigning an array to zero. */
4131 if (copyable_array_p (expr1)
4132 && is_zero_initializer_p (expr2))
4133 {
4134 tmp = gfc_trans_zero_assign (expr1);
4135 if (tmp)
4136 return tmp;
4137 }
4138
4139 /* Special case copying one array to another. */
4140 if (copyable_array_p (expr1)
4141 && copyable_array_p (expr2)
4142 && gfc_compare_types (&expr1->ts, &expr2->ts)
4143 && !gfc_check_dependency (expr1, expr2, 0))
4144 {
4145 tmp = gfc_trans_array_copy (expr1, expr2);
4146 if (tmp)
4147 return tmp;
4148 }
4149
4150 /* Special case initializing an array from a constant array constructor. */
4151 if (copyable_array_p (expr1)
4152 && expr2->expr_type == EXPR_ARRAY
4153 && gfc_compare_types (&expr1->ts, &expr2->ts))
4154 {
4155 tmp = gfc_trans_array_constructor_copy (expr1, expr2);
4156 if (tmp)
4157 return tmp;
4158 }
4159
4160 /* Fallback to the scalarizer to generate explicit loops. */
4161 return gfc_trans_assignment_1 (expr1, expr2, init_flag);
4162 }
4163
4164 tree
4165 gfc_trans_init_assign (gfc_code * code)
4166 {
4167 return gfc_trans_assignment (code->expr, code->expr2, true);
4168 }
4169
4170 tree
4171 gfc_trans_assign (gfc_code * code)
4172 {
4173 return gfc_trans_assignment (code->expr, code->expr2, false);
4174 }