svn merge -r102224:107263 svn+ssh://gcc.gnu.org/svn/gcc/branches/gcc-3_4-branch
[official-gcc.git] / gcc / c-decl.c
blobc017806c4d47d4935fbc7c45e817d80048e57156
1 /* Process declarations and variables for C compiler.
2 Copyright (C) 1988, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000,
3 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
5 This file is part of GCC.
7 GCC is free software; you can redistribute it and/or modify it under
8 the terms of the GNU General Public License as published by the Free
9 Software Foundation; either version 2, or (at your option) any later
10 version.
12 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
15 for more details.
17 You should have received a copy of the GNU General Public License
18 along with GCC; see the file COPYING. If not, write to the Free
19 Software Foundation, 59 Temple Place - Suite 330, Boston, MA
20 02111-1307, USA. */
22 /* Process declarations and symbol lookup for C front end.
23 Also constructs types; the standard scalar types at initialization,
24 and structure, union, array and enum types when they are declared. */
26 /* ??? not all decl nodes are given the most useful possible
27 line numbers. For example, the CONST_DECLs for enum values. */
29 #include "config.h"
30 #include "system.h"
31 #include "coretypes.h"
32 #include "tm.h"
33 #include "intl.h"
34 #include "tree.h"
35 #include "tree-inline.h"
36 #include "rtl.h"
37 #include "flags.h"
38 #include "function.h"
39 #include "output.h"
40 #include "expr.h"
41 #include "c-tree.h"
42 #include "toplev.h"
43 #include "ggc.h"
44 #include "tm_p.h"
45 #include "cpplib.h"
46 #include "target.h"
47 #include "debug.h"
48 #include "opts.h"
49 #include "timevar.h"
50 #include "c-common.h"
51 #include "c-pragma.h"
52 #include "cgraph.h"
53 #include "hashtab.h"
54 #include "libfuncs.h"
55 #include "except.h"
56 #include "langhooks-def.h"
58 /* In grokdeclarator, distinguish syntactic contexts of declarators. */
59 enum decl_context
60 { NORMAL, /* Ordinary declaration */
61 FUNCDEF, /* Function definition */
62 PARM, /* Declaration of parm before function body */
63 FIELD, /* Declaration inside struct or union */
64 TYPENAME}; /* Typename (inside cast or sizeof) */
67 /* Nonzero if we have seen an invalid cross reference
68 to a struct, union, or enum, but not yet printed the message. */
70 tree pending_invalid_xref;
71 /* File and line to appear in the eventual error message. */
72 location_t pending_invalid_xref_location;
74 /* While defining an enum type, this is 1 plus the last enumerator
75 constant value. Note that will do not have to save this or `enum_overflow'
76 around nested function definition since such a definition could only
77 occur in an enum value expression and we don't use these variables in
78 that case. */
80 static tree enum_next_value;
82 /* Nonzero means that there was overflow computing enum_next_value. */
84 static int enum_overflow;
86 /* Parsing a function declarator leaves a list of parameter names
87 or a chain of parameter decls here. */
89 static tree last_function_parms;
91 /* ... and a chain of structure and enum types declared in the
92 parmlist here. */
94 static tree last_function_parm_tags;
96 /* ... and a chain of all non-parameter declarations (such as
97 CONST_DECLs from enumerations) here. */
99 static tree last_function_parm_others;
101 /* After parsing the declarator that starts a function definition,
102 `start_function' puts the list of parameter names or chain of decls here
103 for `store_parm_decls' to find. */
105 static tree current_function_parms;
107 /* Similar, for last_function_parm_tags. */
109 static tree current_function_parm_tags;
111 /* And for last_function_parm_others. */
113 static tree current_function_parm_others;
115 /* Similar, for the file and line that the prototype came from if this is
116 an old-style definition. */
118 static location_t current_function_prototype_locus;
120 /* The current statement tree. */
122 static GTY(()) struct stmt_tree_s c_stmt_tree;
124 /* The current scope statement stack. */
126 static GTY(()) tree c_scope_stmt_stack;
128 /* State saving variables. */
129 int c_in_iteration_stmt;
130 int c_in_case_stmt;
132 /* A list of external DECLs that appeared at block scope when there was
133 some other global meaning for that identifier. */
134 static GTY(()) tree truly_local_externals;
136 /* All the builtins; this is a subset of the entries of global_scope. */
138 static GTY(()) tree first_builtin_decl;
139 static GTY(()) tree last_builtin_decl;
141 /* A DECL for the current file-scope context. */
143 static GTY(()) tree current_file_decl;
145 /* Set to 0 at beginning of a function definition, set to 1 if
146 a return statement that specifies a return value is seen. */
148 int current_function_returns_value;
150 /* Set to 0 at beginning of a function definition, set to 1 if
151 a return statement with no argument is seen. */
153 int current_function_returns_null;
155 /* Set to 0 at beginning of a function definition, set to 1 if
156 a call to a noreturn function is seen. */
158 int current_function_returns_abnormally;
160 /* Set to nonzero by `grokdeclarator' for a function
161 whose return type is defaulted, if warnings for this are desired. */
163 static int warn_about_return_type;
165 /* Nonzero when starting a function declared `extern inline'. */
167 static int current_extern_inline;
169 /* Each c_scope structure describes the complete contents of one scope.
170 Three scopes are distinguished specially: the innermost or current
171 scope, the innermost function scope, and the outermost or file scope.
173 Most declarations are recorded in the current scope.
175 All normal label declarations are recorded in the innermost
176 function scope, as are bindings of undeclared identifiers to
177 error_mark_node. (GCC permits nested functions as an extension,
178 hence the 'innermost' qualifier.) Explicitly declared labels
179 (using the __label__ extension) appear in the current scope.
181 Being in the global scope (current_scope == global_scope) causes
182 special behavior in several places below. Also, under some
183 conditions the Objective-C front end records declarations in the
184 global scope even though that isn't the current scope.
186 The order of the names, parms, and blocks lists matters, and they
187 are frequently appended to. To avoid having to walk all the way to
188 the end of the list on each insertion, or reverse the lists later,
189 we maintain a pointer to the last list entry for each of the lists.
191 The order of the tags, shadowed, and shadowed_tags
192 lists does not matter, so we just prepend to these lists. */
194 struct c_scope GTY(())
196 /* The scope containing this one. */
197 struct c_scope *outer;
199 /* The next outermost function scope. */
200 struct c_scope *outer_function;
202 /* All variables, constants, functions, labels, and typedef names. */
203 tree names;
204 tree names_last;
206 /* All parameter declarations. Used only in the outermost scope of
207 a function. */
208 tree parms;
209 tree parms_last;
211 /* All structure, union, and enum type tags. */
212 tree tags;
214 /* For each scope, a list of shadowed outer-scope definitions
215 to be restored when this scope is popped.
216 Each link is a TREE_LIST whose TREE_PURPOSE is an identifier and
217 whose TREE_VALUE is its old definition (a kind of ..._DECL node). */
218 tree shadowed;
220 /* For each scope, a list of shadowed outer-scope tag definitions
221 to be restored when this scope is popped.
222 Each link is a TREE_LIST whose TREE_PURPOSE is an identifier and
223 whose TREE_VALUE is its old definition (a kind of ..._TYPE node). */
224 tree shadowed_tags;
226 /* For each scope (except the global one), a chain of BLOCK nodes
227 for all the scopes that were entered and exited one level down. */
228 tree blocks;
229 tree blocks_last;
231 /* True if we are currently filling this scope with parameter
232 declarations. */
233 BOOL_BITFIELD parm_flag : 1;
235 /* True if we already complained about forward parameter decls
236 in this scope. This prevents double warnings on
237 foo (int a; int b; ...) */
238 BOOL_BITFIELD warned_forward_parm_decls : 1;
240 /* True if this is the outermost block scope of a function body.
241 This scope contains the parameters, the local variables declared
242 in the outermost block, and all the labels (except those in
243 nested functions, or declared at block scope with __label__). */
244 BOOL_BITFIELD function_body : 1;
246 /* True means make a BLOCK for this scope no matter what. */
247 BOOL_BITFIELD keep : 1;
250 /* The scope currently in effect. */
252 static GTY(()) struct c_scope *current_scope;
254 /* A chain of c_scope structures awaiting reuse. */
256 static GTY((deletable (""))) struct c_scope *scope_freelist;
258 /* The innermost function scope. Ordinary (not explicitly declared)
259 labels, bindings to error_mark_node, and the lazily-created
260 bindings of __func__ and its friends get this scope. */
262 static GTY(()) struct c_scope *current_function_scope;
264 /* The outermost scope, corresponding to the C "file scope". This is
265 created when the compiler is started and exists through the entire run. */
267 static GTY(()) struct c_scope *global_scope;
269 /* Append VAR to LIST in scope SCOPE. */
270 #define SCOPE_LIST_APPEND(scope, list, decl) do { \
271 struct c_scope *s_ = (scope); \
272 tree d_ = (decl); \
273 if (s_->list##_last) \
274 TREE_CHAIN (s_->list##_last) = d_; \
275 else \
276 s_->list = d_; \
277 s_->list##_last = d_; \
278 } while (0)
280 /* Concatenate FROM in scope FSCOPE onto TO in scope TSCOPE. */
281 #define SCOPE_LIST_CONCAT(tscope, to, fscope, from) do { \
282 struct c_scope *t_ = (tscope); \
283 struct c_scope *f_ = (fscope); \
284 if (t_->to##_last) \
285 TREE_CHAIN (t_->to##_last) = f_->from; \
286 else \
287 t_->to = f_->from; \
288 t_->to##_last = f_->from##_last; \
289 } while (0)
291 /* True means unconditionally make a BLOCK for the next scope pushed. */
293 static bool keep_next_level_flag;
295 /* True means the next call to pushlevel will be the outermost scope
296 of a function body, so do not push a new scope, merely cease
297 expecting parameter decls. */
299 static bool next_is_function_body;
301 /* Functions called automatically at the beginning and end of execution. */
303 tree static_ctors, static_dtors;
305 /* Forward declarations. */
307 static struct c_scope *make_scope (void);
308 static void pop_scope (void);
309 static tree make_label (tree, location_t);
310 static void bind_label (tree, tree, struct c_scope *);
311 static void implicit_decl_warning (tree);
312 static tree lookup_tag (enum tree_code, tree, int);
313 static tree lookup_name_current_level (tree);
314 static tree grokdeclarator (tree, tree, enum decl_context, int, tree *);
315 static tree grokparms (tree, int);
316 static void layout_array_type (tree);
317 static void store_parm_decls_newstyle (void);
318 static void store_parm_decls_oldstyle (void);
319 static tree c_make_fname_decl (tree, int);
320 static void c_expand_body_1 (tree, int);
321 static tree any_external_decl (tree);
322 static void record_external_decl (tree);
323 static void warn_if_shadowing (tree, tree);
324 static void check_bitfield_type_and_width (tree *, tree *, const char *);
325 static void clone_underlying_type (tree);
326 static bool flexible_array_type_p (tree);
327 static hashval_t link_hash_hash (const void *);
328 static int link_hash_eq (const void *, const void *);
330 /* States indicating how grokdeclarator() should handle declspecs marked
331 with __attribute__((deprecated)). An object declared as
332 __attribute__((deprecated)) suppresses warnings of uses of other
333 deprecated items. */
335 enum deprecated_states {
336 DEPRECATED_NORMAL,
337 DEPRECATED_SUPPRESS
340 static enum deprecated_states deprecated_state = DEPRECATED_NORMAL;
342 void
343 c_print_identifier (FILE *file, tree node, int indent)
345 print_node (file, "symbol", IDENTIFIER_SYMBOL_VALUE (node), indent + 4);
346 print_node (file, "tag", IDENTIFIER_TAG_VALUE (node), indent + 4);
347 print_node (file, "label", IDENTIFIER_LABEL_VALUE (node), indent + 4);
348 if (C_IS_RESERVED_WORD (node))
350 tree rid = ridpointers[C_RID_CODE (node)];
351 indent_to (file, indent + 4);
352 fprintf (file, "rid " HOST_PTR_PRINTF " \"%s\"",
353 (void *) rid, IDENTIFIER_POINTER (rid));
357 /* Hook called at end of compilation to assume 1 elt
358 for a file-scope tentative array defn that wasn't complete before. */
360 void
361 c_finish_incomplete_decl (tree decl)
363 if (TREE_CODE (decl) == VAR_DECL)
365 tree type = TREE_TYPE (decl);
366 if (type != error_mark_node
367 && TREE_CODE (type) == ARRAY_TYPE
368 && ! DECL_EXTERNAL (decl)
369 && TYPE_DOMAIN (type) == 0)
371 warning ("%Jarray '%D' assumed to have one element", decl, decl);
373 complete_array_type (type, NULL_TREE, 1);
375 layout_decl (decl, 0);
380 /* Reuse or create a struct for this scope. */
382 static struct c_scope *
383 make_scope (void)
385 struct c_scope *result;
386 if (scope_freelist)
388 result = scope_freelist;
389 scope_freelist = result->outer;
391 else
392 result = ggc_alloc_cleared (sizeof (struct c_scope));
394 return result;
397 /* Remove the topmost scope from the stack and add it to the
398 free list, updating current_function_scope if necessary. */
400 static void
401 pop_scope (void)
403 struct c_scope *scope = current_scope;
405 current_scope = scope->outer;
406 if (scope->function_body)
407 current_function_scope = scope->outer_function;
409 memset (scope, 0, sizeof (struct c_scope));
410 scope->outer = scope_freelist;
411 scope_freelist = scope;
414 /* The Objective-C front-end often needs to determine the current scope. */
416 void *
417 get_current_scope (void)
419 return current_scope;
422 /* The following function is used only by Objective-C. It needs to live here
423 because it accesses the innards of c_scope. */
425 void
426 objc_mark_locals_volatile (void *enclosing_blk)
428 struct c_scope *scope;
430 for (scope = current_scope;
431 scope && scope != enclosing_blk;
432 scope = scope->outer)
434 tree decl;
436 for (decl = scope->names; decl; decl = TREE_CHAIN (decl))
438 DECL_REGISTER (decl) = 0;
439 TREE_THIS_VOLATILE (decl) = 1;
441 /* Do not climb up past the current function. */
442 if (scope->function_body)
443 break;
447 /* Nonzero if we are currently in the global scope. */
450 global_bindings_p (void)
452 return current_scope == global_scope;
455 void
456 keep_next_level (void)
458 keep_next_level_flag = true;
461 /* Identify this scope as currently being filled with parameters. */
463 void
464 declare_parm_level (void)
466 current_scope->parm_flag = true;
469 /* Nonzero if currently making parm declarations. */
472 in_parm_level_p (void)
474 return current_scope->parm_flag;
477 /* Enter a new scope. The dummy parameter is for signature
478 compatibility with lang_hooks.decls.pushlevel. */
480 void
481 pushlevel (int dummy ATTRIBUTE_UNUSED)
483 if (next_is_function_body)
485 /* This is the transition from the parameters to the top level
486 of the function body. These are the same scope
487 (C99 6.2.1p4,6) so we do not push another scope structure.
488 next_is_function_body is set only by store_parm_decls, which
489 in turn is called when and only when we are about to
490 encounter the opening curly brace for the function body.
492 The outermost block of a function always gets a BLOCK node,
493 because the debugging output routines expect that each
494 function has at least one BLOCK. */
495 current_scope->parm_flag = false;
496 current_scope->function_body = true;
497 current_scope->keep = true;
498 current_scope->outer_function = current_function_scope;
499 current_function_scope = current_scope;
501 keep_next_level_flag = false;
502 next_is_function_body = false;
504 else
506 struct c_scope *scope = make_scope ();
508 scope->keep = keep_next_level_flag;
509 scope->outer = current_scope;
510 current_scope = scope;
511 keep_next_level_flag = false;
515 /* Exit a scope. Restore the state of the identifier-decl mappings
516 that were in effect when this scope was entered.
518 If KEEP is KEEP_YES (1), this scope had explicit declarations, so
519 create a BLOCK node to record its declarations and subblocks for
520 debugging output. If KEEP is KEEP_MAYBE, do so only if the names
521 or tags lists are nonempty.
523 The second parameter is ignored; it is present only for
524 signature compatibility with lang_hooks.decls.poplevel.
526 If FUNCTIONBODY is nonzero, this level is the body of a function,
527 even if current_scope->function_body is not set. This is used
528 by language-independent code that generates synthetic functions,
529 and cannot set current_scope->function_body.
531 FIXME: Eliminate the need for all arguments. */
533 tree
534 poplevel (int keep, int dummy ATTRIBUTE_UNUSED, int functionbody)
536 struct c_scope *scope = current_scope;
537 tree block;
538 tree decl;
539 tree p;
541 /* The following line does not use |= due to a bug in HP's C compiler. */
542 scope->function_body = scope->function_body | functionbody;
544 if (keep == KEEP_MAYBE)
545 keep = (scope->names || scope->tags);
547 keep |= scope->keep;
548 keep |= scope->function_body;
550 /* If appropriate, create a BLOCK to record the decls for the life
551 of this function. */
552 block = 0;
553 if (keep)
555 block = make_node (BLOCK);
556 BLOCK_VARS (block) = scope->names;
557 BLOCK_SUBBLOCKS (block) = scope->blocks;
558 TREE_USED (block) = 1;
561 /* In each subblock, record that this is its superior. */
562 for (p = scope->blocks; p; p = TREE_CHAIN (p))
563 BLOCK_SUPERCONTEXT (p) = block;
565 /* Clear out the variable bindings in this scope.
567 Propagate TREE_ADDRESSABLE from nested functions to their
568 containing functions.
570 Issue warnings for unused variables and labels, and errors for
571 undefined labels, if there are any. */
573 for (p = scope->names; p; p = TREE_CHAIN (p))
575 switch (TREE_CODE (p))
577 case LABEL_DECL:
578 if (TREE_USED (p) && !DECL_INITIAL (p))
580 error ("%Jlabel `%D' used but not defined", p, p);
581 DECL_INITIAL (p) = error_mark_node;
583 else if (!TREE_USED (p) && warn_unused_label)
585 if (DECL_INITIAL (p))
586 warning ("%Jlabel `%D' defined but not used", p, p);
587 else
588 warning ("%Jlabel `%D' declared but not defined", p, p);
591 IDENTIFIER_LABEL_VALUE (DECL_NAME (p)) = 0;
592 break;
594 case FUNCTION_DECL:
595 if (! TREE_ASM_WRITTEN (p)
596 && DECL_INITIAL (p) != 0
597 && TREE_ADDRESSABLE (p)
598 && DECL_ABSTRACT_ORIGIN (p) != 0
599 && DECL_ABSTRACT_ORIGIN (p) != p)
600 TREE_ADDRESSABLE (DECL_ABSTRACT_ORIGIN (p)) = 1;
601 goto normal;
603 case VAR_DECL:
604 /* Keep this in sync with stmt.c:warn_about_unused_variables.
605 No warnings when the global scope is popped because the
606 global scope isn't popped for the last translation unit,
607 so the warnings are done in c_write_global_declaration. */
608 if (warn_unused_variable && scope != global_scope
609 && !TREE_USED (p)
610 && !DECL_IN_SYSTEM_HEADER (p)
611 && DECL_NAME (p)
612 && !DECL_ARTIFICIAL (p))
613 warning ("%Junused variable `%D'", p, p);
614 /* fall through */
616 default:
617 normal:
618 if (DECL_NAME (p))
620 if (DECL_EXTERNAL (p) && scope != global_scope)
621 /* External decls stay in the symbol-value slot but are
622 inaccessible. */
623 C_DECL_INVISIBLE (p) = 1;
624 else
625 IDENTIFIER_SYMBOL_VALUE (DECL_NAME (p)) = 0;
627 break;
631 /* Clear out the parameter bindings in this scope, if any.
632 Unused-parameter warnings are handled by function.c. */
633 for (p = scope->parms; p; p = TREE_CHAIN (p))
634 if (DECL_NAME (p))
635 IDENTIFIER_SYMBOL_VALUE (DECL_NAME (p)) = 0;
637 /* Clear out the tag-meanings declared in this scope.
639 Set the TYPE_CONTEXTs for all of the tagged types belonging to
640 this scope so that they point to the appropriate construct, i.e.
641 either to the current FUNCTION_DECL node, or else to the BLOCK
642 node we just constructed.
644 Note that for tagged types whose scope is just the formal
645 parameter list for some function type specification, we can't
646 properly set their TYPE_CONTEXTs here, because we don't have a
647 pointer to the appropriate FUNCTION_TYPE node readily available
648 to us. For those cases, the TYPE_CONTEXTs of the relevant tagged
649 type nodes get set in `grokdeclarator' as soon as we have created
650 the FUNCTION_TYPE node which will represent the "scope" for these
651 "parameter list local" tagged types. */
653 decl = scope->function_body ? current_function_decl : block;
654 for (p = scope->tags; p; p = TREE_CHAIN (p))
656 if (TREE_PURPOSE (p))
657 IDENTIFIER_TAG_VALUE (TREE_PURPOSE (p)) = 0;
658 if (decl)
659 TYPE_CONTEXT (TREE_VALUE (p)) = decl;
662 /* Restore all name- and label-meanings from outer scopes that were
663 shadowed by this scope. */
664 for (p = scope->shadowed; p; p = TREE_CHAIN (p))
665 if (TREE_VALUE (p) && TREE_CODE (TREE_VALUE (p)) == LABEL_DECL)
666 IDENTIFIER_LABEL_VALUE (TREE_PURPOSE (p)) = TREE_VALUE (p);
667 else
668 IDENTIFIER_SYMBOL_VALUE (TREE_PURPOSE (p)) = TREE_VALUE (p);
670 /* Restore all tag-meanings from outer scopes that were shadowed by
671 this scope. */
672 for (p = scope->shadowed_tags; p; p = TREE_CHAIN (p))
673 IDENTIFIER_TAG_VALUE (TREE_PURPOSE (p)) = TREE_VALUE (p);
675 /* Dispose of the block that we just made inside some higher level. */
676 if (scope->function_body && current_function_decl)
677 DECL_INITIAL (current_function_decl) = block;
678 else if (scope->outer)
680 if (block)
681 SCOPE_LIST_APPEND (scope->outer, blocks, block);
682 /* If we did not make a block for the scope just exited, any
683 blocks made for inner scopes must be carried forward so they
684 will later become subblocks of something else. */
685 else if (scope->blocks)
686 SCOPE_LIST_CONCAT (scope->outer, blocks, scope, blocks);
689 /* Pop the current scope, and free the structure for reuse. */
690 pop_scope ();
692 return block;
695 /* Insert BLOCK at the end of the list of subblocks of the current
696 scope. This is used when a BIND_EXPR is expanded, to handle the
697 BLOCK node inside the BIND_EXPR. */
699 void
700 insert_block (tree block)
702 TREE_USED (block) = 1;
703 SCOPE_LIST_APPEND (current_scope, blocks, block);
706 /* Set the BLOCK node for the innermost scope (the one we are
707 currently in). The RTL expansion machinery requires us to provide
708 this hook, but it is not useful in function-at-a-time mode. */
710 void
711 set_block (tree block ATTRIBUTE_UNUSED)
715 /* Push a definition or a declaration of struct, union or enum tag "name".
716 "type" should be the type node.
717 We assume that the tag "name" is not already defined.
719 Note that the definition may really be just a forward reference.
720 In that case, the TYPE_SIZE will be zero. */
722 void
723 pushtag (tree name, tree type)
725 struct c_scope *b = current_scope;
727 /* Record the identifier as the type's name if it has none. */
728 if (name)
730 if (TYPE_NAME (type) == 0)
731 TYPE_NAME (type) = name;
733 if (IDENTIFIER_TAG_VALUE (name))
734 b->shadowed_tags = tree_cons (name, IDENTIFIER_TAG_VALUE (name),
735 b->shadowed_tags);
736 IDENTIFIER_TAG_VALUE (name) = type;
739 b->tags = tree_cons (name, type, b->tags);
741 /* Create a fake NULL-named TYPE_DECL node whose TREE_TYPE will be the
742 tagged type we just added to the current scope. This fake
743 NULL-named TYPE_DECL node helps dwarfout.c to know when it needs
744 to output a representation of a tagged type, and it also gives
745 us a convenient place to record the "scope start" address for the
746 tagged type. */
748 TYPE_STUB_DECL (type) = pushdecl (build_decl (TYPE_DECL, NULL_TREE, type));
750 /* An approximation for now, so we can tell this is a function-scope tag.
751 This will be updated in poplevel. */
752 TYPE_CONTEXT (type) = DECL_CONTEXT (TYPE_STUB_DECL (type));
755 /* Subroutine of compare_decls. Allow harmless mismatches in return
756 and argument types provided that the type modes match. This function
757 return a unified type given a suitable match, and 0 otherwise. */
759 static tree
760 match_builtin_function_types (tree newtype, tree oldtype)
762 tree newrettype, oldrettype;
763 tree newargs, oldargs;
764 tree trytype, tryargs;
766 /* Accept the return type of the new declaration if same modes. */
767 oldrettype = TREE_TYPE (oldtype);
768 newrettype = TREE_TYPE (newtype);
770 if (TYPE_MODE (oldrettype) != TYPE_MODE (newrettype))
771 return 0;
773 oldargs = TYPE_ARG_TYPES (oldtype);
774 newargs = TYPE_ARG_TYPES (newtype);
775 tryargs = newargs;
777 while (oldargs || newargs)
779 if (! oldargs
780 || ! newargs
781 || ! TREE_VALUE (oldargs)
782 || ! TREE_VALUE (newargs)
783 || TYPE_MODE (TREE_VALUE (oldargs))
784 != TYPE_MODE (TREE_VALUE (newargs)))
785 return 0;
787 oldargs = TREE_CHAIN (oldargs);
788 newargs = TREE_CHAIN (newargs);
791 trytype = build_function_type (newrettype, tryargs);
792 return build_type_attribute_variant (trytype, TYPE_ATTRIBUTES (oldtype));
795 /* Subroutine of diagnose_mismathed_decls. Check for function type
796 mismatch involving an empty arglist vs a nonempty one and give clearer
797 diagnostics. */
798 static void
799 diagnose_arglist_conflict (tree newdecl, tree olddecl,
800 tree newtype, tree oldtype)
802 tree t;
804 if (TREE_CODE (olddecl) != FUNCTION_DECL
805 || !comptypes (TREE_TYPE (oldtype), TREE_TYPE (newtype), COMPARE_STRICT)
806 || !((TYPE_ARG_TYPES (oldtype) == 0 && DECL_INITIAL (olddecl) == 0)
808 (TYPE_ARG_TYPES (newtype) == 0 && DECL_INITIAL (newdecl) == 0)))
809 return;
811 t = TYPE_ARG_TYPES (oldtype);
812 if (t == 0)
813 t = TYPE_ARG_TYPES (newtype);
814 for (; t; t = TREE_CHAIN (t))
816 tree type = TREE_VALUE (t);
818 if (TREE_CHAIN (t) == 0
819 && TYPE_MAIN_VARIANT (type) != void_type_node)
821 inform ("a parameter list with an ellipsis can't match "
822 "an empty parameter name list declaration");
823 break;
826 if (c_type_promotes_to (type) != type)
828 inform ("an argument type that has a default promotion can't match "
829 "an empty parameter name list declaration");
830 break;
835 /* Another subroutine of diagnose_mismatched_decls. OLDDECL is an
836 old-style function definition, NEWDECL is a prototype declaration.
837 Diagnose inconsistencies in the argument list. Returns TRUE if
838 the prototype is compatible, FALSE if not. */
839 static bool
840 validate_proto_after_old_defn (tree newdecl, tree newtype, tree oldtype)
842 tree newargs, oldargs;
843 int i;
845 /* ??? Elsewhere TYPE_MAIN_VARIANT is not used in this context. */
846 #define END_OF_ARGLIST(t) (TYPE_MAIN_VARIANT (t) == void_type_node)
848 oldargs = TYPE_ACTUAL_ARG_TYPES (oldtype);
849 newargs = TYPE_ARG_TYPES (newtype);
850 i = 1;
852 for (;;)
854 tree oldargtype = TREE_VALUE (oldargs);
855 tree newargtype = TREE_VALUE (newargs);
857 if (END_OF_ARGLIST (oldargtype) && END_OF_ARGLIST (newargtype))
858 break;
860 /* Reaching the end of just one list means the two decls don't
861 agree on the number of arguments. */
862 if (END_OF_ARGLIST (oldargtype))
864 error ("%Jprototype for '%D' declares more arguments "
865 "than previous old-style definition", newdecl, newdecl);
866 return false;
868 else if (END_OF_ARGLIST (newargtype))
870 error ("%Jprototype for '%D' declares fewer arguments "
871 "than previous old-style definition", newdecl, newdecl);
872 return false;
875 /* Type for passing arg must be consistent with that declared
876 for the arg. */
877 else if (! comptypes (oldargtype, newargtype, COMPARE_STRICT))
879 error ("%Jprototype for '%D' declares arg %d with incompatible type",
880 newdecl, newdecl, i);
881 return false;
884 oldargs = TREE_CHAIN (oldargs);
885 newargs = TREE_CHAIN (newargs);
886 i++;
889 /* If we get here, no errors were found, but do issue a warning
890 for this poor-style construct. */
891 warning ("%Jprototype for '%D' follows non-prototype definition",
892 newdecl, newdecl);
893 return true;
894 #undef END_OF_ARGLIST
897 /* Subroutine of diagnose_mismatched_decls. Report the location of DECL,
898 first in a pair of mismatched declarations, using the diagnostic
899 function DIAG. */
900 static void
901 locate_old_decl (tree decl, void (*diag)(const char *, ...))
903 if (TREE_CODE (decl) == FUNCTION_DECL && DECL_BUILT_IN (decl))
905 else if (DECL_INITIAL (decl))
906 diag (N_("%Jprevious definition of '%D' was here"), decl, decl);
907 else if (C_DECL_IMPLICIT (decl))
908 diag (N_("%Jprevious implicit declaration of '%D' was here"), decl, decl);
909 else
910 diag (N_("%Jprevious declaration of '%D' was here"), decl, decl);
913 /* Subroutine of duplicate_decls. Compare NEWDECL to OLDDECL.
914 Returns true if the caller should proceed to merge the two, false
915 if OLDDECL should simply be discarded. As a side effect, issues
916 all necessary diagnostics for invalid or poor-style combinations.
917 If it returns true, writes the types of NEWDECL and OLDDECL to
918 *NEWTYPEP and *OLDTYPEP - these may have been adjusted from
919 TREE_TYPE (NEWDECL, OLDDECL) respectively. */
921 static bool
922 diagnose_mismatched_decls (tree newdecl, tree olddecl,
923 tree *newtypep, tree *oldtypep)
925 tree newtype, oldtype;
926 bool pedwarned = false;
927 bool warned = false;
929 /* If we have error_mark_node for either decl or type, just discard
930 the previous decl - we're in an error cascade already. */
931 if (olddecl == error_mark_node || newdecl == error_mark_node)
932 return false;
933 *oldtypep = oldtype = TREE_TYPE (olddecl);
934 *newtypep = newtype = TREE_TYPE (newdecl);
935 if (oldtype == error_mark_node || newtype == error_mark_node)
936 return false;
938 /* Two different categories of symbol altogether. This is an error
939 unless OLDDECL is a builtin. OLDDECL will be discarded in any case. */
940 if (TREE_CODE (olddecl) != TREE_CODE (newdecl))
942 if (TREE_CODE (olddecl) != FUNCTION_DECL
943 || !DECL_BUILT_IN (olddecl) || !C_DECL_INVISIBLE (olddecl))
945 error ("%J'%D' redeclared as different kind of symbol",
946 newdecl, newdecl);
947 locate_old_decl (olddecl, error);
949 else if (TREE_PUBLIC (newdecl))
950 warning ("%Jbuilt-in function '%D' declared as non-function",
951 newdecl, newdecl);
952 else if (warn_shadow)
953 warning ("%Jshadowing built-in function '%D'",
954 newdecl, newdecl);
955 return false;
958 /* Enumerators have no linkage, so may only be declared once in a
959 given scope. */
960 if (TREE_CODE (olddecl) == CONST_DECL)
962 error ("%Jredeclaration of enumerator `%D'", newdecl, newdecl);
963 locate_old_decl (olddecl, error);
964 return false;
967 if (!comptypes (oldtype, newtype, COMPARE_STRICT))
969 if (TREE_CODE (olddecl) == FUNCTION_DECL
970 && DECL_BUILT_IN (olddecl) && C_DECL_INVISIBLE (olddecl))
972 /* Accept harmless mismatch in function types.
973 This is for the ffs and fprintf builtins. */
974 tree trytype = match_builtin_function_types (newtype, oldtype);
976 if (trytype && comptypes (newtype, trytype, COMPARE_STRICT))
977 *oldtypep = oldtype = trytype;
978 else
980 /* If types don't match for a built-in, throw away the
981 built-in. No point in calling locate_old_decl here, it
982 won't print anything. */
983 warning ("%Jconflicting types for built-in function '%D'",
984 newdecl, newdecl);
985 return false;
988 else if (TREE_CODE (olddecl) == FUNCTION_DECL
989 && DECL_SOURCE_LINE (olddecl) == 0)
991 /* A conflicting function declaration for a predeclared
992 function that isn't actually built in. Objective C uses
993 these. The new declaration silently overrides everything
994 but the volatility (i.e. noreturn) indication. See also
995 below. FIXME: Make Objective C use normal builtins. */
996 TREE_THIS_VOLATILE (newdecl) |= TREE_THIS_VOLATILE (olddecl);
997 return false;
999 /* Permit void foo (...) to match int foo (...) if the latter is
1000 the definition and implicit int was used. See
1001 c-torture/compile/920625-2.c. */
1002 else if (TREE_CODE (newdecl) == FUNCTION_DECL && DECL_INITIAL (newdecl)
1003 && TYPE_MAIN_VARIANT (TREE_TYPE (oldtype)) == void_type_node
1004 && TYPE_MAIN_VARIANT (TREE_TYPE (newtype)) == integer_type_node
1005 && C_FUNCTION_IMPLICIT_INT (newdecl))
1007 pedwarn ("%Jconflicting types for '%D'", newdecl, newdecl);
1008 /* Make sure we keep void as the return type. */
1009 TREE_TYPE (newdecl) = *newtypep = newtype = oldtype;
1010 C_FUNCTION_IMPLICIT_INT (newdecl) = 0;
1011 pedwarned = true;
1013 else
1015 error ("%Jconflicting types for '%D'", newdecl, newdecl);
1016 diagnose_arglist_conflict (newdecl, olddecl, newtype, oldtype);
1017 locate_old_decl (olddecl, error);
1018 return false;
1022 /* Redeclaration of a type is a constraint violation (6.7.2.3p1),
1023 but silently ignore the redeclaration if either is in a system
1024 header. (Conflicting redeclarations were handled above.) */
1025 if (TREE_CODE (newdecl) == TYPE_DECL)
1027 if (DECL_IN_SYSTEM_HEADER (newdecl) || DECL_IN_SYSTEM_HEADER (olddecl))
1028 return true; /* allow OLDDECL to continue in use */
1030 error ("%Jredefinition of typedef '%D'", newdecl, newdecl);
1031 locate_old_decl (olddecl, error);
1032 return false;
1035 /* Function declarations can either be 'static' or 'extern' (no
1036 qualifier is equivalent to 'extern' - C99 6.2.2p5) and therefore
1037 can never conflict with each other on account of linkage (6.2.2p4).
1038 Multiple definitions are not allowed (6.9p3,5) but GCC permits
1039 two definitions if one is 'extern inline' and one is not. The non-
1040 extern-inline definition supersedes the extern-inline definition. */
1041 else if (TREE_CODE (newdecl) == FUNCTION_DECL)
1043 /* If you declare a built-in function name as static, or
1044 define the built-in with an old-style definition (so we
1045 can't validate the argument list) the built-in definition is
1046 overridden, but optionally warn this was a bad choice of name. */
1047 if (DECL_BUILT_IN (olddecl)
1048 && C_DECL_INVISIBLE (olddecl)
1049 && (!TREE_PUBLIC (newdecl)
1050 || (DECL_INITIAL (newdecl)
1051 && !TYPE_ARG_TYPES (TREE_TYPE (newdecl)))))
1053 if (warn_shadow)
1054 warning ("%Jshadowing built-in function '%D'", newdecl, newdecl);
1055 /* Discard the old built-in function. */
1056 return false;
1059 if (DECL_INITIAL (newdecl))
1061 if (DECL_INITIAL (olddecl)
1062 && !(DECL_DECLARED_INLINE_P (olddecl)
1063 && DECL_EXTERNAL (olddecl)
1064 && !(DECL_DECLARED_INLINE_P (newdecl)
1065 && DECL_EXTERNAL (newdecl))))
1067 error ("%Jredefinition of '%D'", newdecl, newdecl);
1068 locate_old_decl (olddecl, error);
1069 return false;
1072 /* If we have a prototype after an old-style function definition,
1073 the argument types must be checked specially. */
1074 else if (DECL_INITIAL (olddecl)
1075 && !TYPE_ARG_TYPES (oldtype) && TYPE_ARG_TYPES (newtype)
1076 && TYPE_ACTUAL_ARG_TYPES (oldtype)
1077 && !validate_proto_after_old_defn (newdecl, newtype, oldtype))
1079 locate_old_decl (olddecl, error);
1080 return false;
1082 /* Mismatched non-static and static is considered poor style.
1083 We only diagnose static then non-static if -Wtraditional,
1084 because it is the most convenient way to get some effects
1085 (see e.g. what unwind-dw2-fde-glibc.c does to the definition
1086 of _Unwind_Find_FDE in unwind-dw2-fde.c). Revisit? */
1087 if (TREE_PUBLIC (olddecl) && !TREE_PUBLIC (newdecl))
1089 /* A static function declaration for a predeclared function
1090 that isn't actually built in, silently overrides the
1091 default. Objective C uses these. See also above.
1092 FIXME: Make Objective C use normal builtins. */
1093 if (TREE_CODE (olddecl) == FUNCTION_DECL
1094 && DECL_SOURCE_LINE (olddecl) == 0)
1095 return false;
1096 else
1098 warning ("%Jstatic declaration of '%D' follows "
1099 "non-static declaration", newdecl, newdecl);
1100 warned = true;
1103 else if (TREE_PUBLIC (newdecl) && !TREE_PUBLIC (olddecl)
1104 && warn_traditional)
1106 warning ("%Jnon-static declaration of '%D' follows "
1107 "static declaration", newdecl, newdecl);
1108 warned = true;
1111 else if (TREE_CODE (newdecl) == VAR_DECL)
1113 /* Only variables can be thread-local, and all declarations must
1114 agree on this property. */
1115 if (DECL_THREAD_LOCAL (newdecl) != DECL_THREAD_LOCAL (olddecl))
1117 if (DECL_THREAD_LOCAL (newdecl))
1118 error ("%Jthread-local declaration of '%D' follows "
1119 "non-thread-local declaration", newdecl, newdecl);
1120 else
1121 error ("%Jnon-thread-local declaration of '%D' follows "
1122 "thread-local declaration", newdecl, newdecl);
1124 locate_old_decl (olddecl, error);
1125 return false;
1128 /* Multiple initialized definitions are not allowed (6.9p3,5). */
1129 if (DECL_INITIAL (newdecl) && DECL_INITIAL (olddecl))
1131 error ("%Jredefinition of '%D'", newdecl, newdecl);
1132 locate_old_decl (olddecl, error);
1133 return false;
1136 /* Objects declared at file scope: if at least one is 'extern',
1137 it's fine (6.2.2p4); otherwise the linkage must agree (6.2.2p7). */
1138 if (DECL_FILE_SCOPE_P (newdecl))
1140 if (!DECL_EXTERNAL (newdecl)
1141 && !DECL_EXTERNAL (olddecl)
1142 && TREE_PUBLIC (newdecl) != TREE_PUBLIC (olddecl))
1144 if (TREE_PUBLIC (newdecl))
1145 error ("%Jnon-static declaration of '%D' follows "
1146 "static declaration", newdecl, newdecl);
1147 else
1148 error ("%Jstatic declaration of '%D' follows "
1149 "non-static declaration", newdecl, newdecl);
1151 locate_old_decl (olddecl, error);
1152 return false;
1155 /* Two objects with the same name declared at the same block
1156 scope must both be external references (6.7p3). */
1157 else if (DECL_CONTEXT (newdecl) == DECL_CONTEXT (olddecl)
1158 && (!DECL_EXTERNAL (newdecl) || !DECL_EXTERNAL (olddecl)))
1160 if (DECL_EXTERNAL (newdecl))
1161 error ("%Jextern declaration of '%D' follows "
1162 "declaration with no linkage", newdecl, newdecl);
1163 else if (DECL_EXTERNAL (olddecl))
1164 error ("%Jdeclaration of '%D' with no linkage follows "
1165 "extern declaration", newdecl, newdecl);
1166 else
1167 error ("%Jredeclaration of '%D' with no linkage",
1168 newdecl, newdecl);
1170 locate_old_decl (olddecl, error);
1171 return false;
1175 /* warnings */
1176 /* All decls must agree on a visibility. */
1177 if (DECL_VISIBILITY_SPECIFIED (newdecl) && DECL_VISIBILITY_SPECIFIED (olddecl)
1178 && DECL_VISIBILITY (newdecl) != DECL_VISIBILITY (olddecl))
1180 warning ("%Jredeclaration of '%D' with different visibility "
1181 "(old visibility preserved)", newdecl, newdecl);
1182 warned = true;
1185 if (TREE_CODE (newdecl) == FUNCTION_DECL)
1187 /* Diagnose inline __attribute__ ((noinline)) which is silly. */
1188 if (DECL_DECLARED_INLINE_P (newdecl)
1189 && lookup_attribute ("noinline", DECL_ATTRIBUTES (olddecl)))
1191 warning ("%Jinline declaration of '%D' follows "
1192 "declaration with attribute noinline", newdecl, newdecl);
1193 warned = true;
1195 else if (DECL_DECLARED_INLINE_P (olddecl)
1196 && lookup_attribute ("noinline", DECL_ATTRIBUTES (newdecl)))
1198 warning ("%Jdeclaration of '%D' with attribute noinline follows "
1199 "inline declaration ", newdecl, newdecl);
1200 warned = true;
1203 /* Inline declaration after use or definition.
1204 ??? Should we still warn about this now we have unit-at-a-time
1205 mode and can get it right? */
1206 if (DECL_DECLARED_INLINE_P (newdecl) && !DECL_DECLARED_INLINE_P (olddecl))
1208 if (TREE_USED (olddecl))
1210 warning ("%J'%D' declared inline after being called",
1211 olddecl, olddecl);
1212 warned = true;
1214 else if (DECL_INITIAL (olddecl))
1216 warning ("%J'%D' declared inline after its definition",
1217 olddecl, olddecl);
1218 warned = true;
1222 else /* PARM_DECL, VAR_DECL */
1224 /* Redeclaration of a PARM_DECL is invalid unless this is the
1225 real position of a forward-declared parameter (GCC extension). */
1226 if (TREE_CODE (newdecl) == PARM_DECL
1227 && (!TREE_ASM_WRITTEN (olddecl) || TREE_ASM_WRITTEN (newdecl)))
1229 error ("%Jredefinition of parameter '%D'", newdecl, newdecl);
1230 locate_old_decl (olddecl, error);
1231 return false;
1234 /* These bits are only type qualifiers when applied to objects. */
1235 if (TREE_THIS_VOLATILE (newdecl) != TREE_THIS_VOLATILE (olddecl))
1237 if (TREE_THIS_VOLATILE (newdecl))
1238 pedwarn ("%Jvolatile declaration of '%D' follows "
1239 "non-volatile declaration", newdecl, newdecl);
1240 else
1241 pedwarn ("%Jnon-volatile declaration of '%D' follows "
1242 "volatile declaration", newdecl, newdecl);
1243 pedwarned = true;
1245 if (TREE_READONLY (newdecl) != TREE_READONLY (olddecl))
1247 if (TREE_READONLY (newdecl))
1248 pedwarn ("%Jconst declaration of '%D' follows "
1249 "non-const declaration", newdecl, newdecl);
1250 else
1251 pedwarn ("%Jnon-const declaration of '%D' follows "
1252 "const declaration", newdecl, newdecl);
1253 pedwarned = true;
1257 /* Optional warning for completely redundant decls. */
1258 if (!warned && !pedwarned
1259 && warn_redundant_decls
1260 /* Don't warn about a function declaration followed by a
1261 definition. */
1262 && !(TREE_CODE (newdecl) == FUNCTION_DECL
1263 && DECL_INITIAL (newdecl) && !DECL_INITIAL (olddecl))
1264 /* Don't warn about redundant redeclarations of builtins. */
1265 && !(TREE_CODE (newdecl) == FUNCTION_DECL
1266 && !DECL_BUILT_IN (newdecl)
1267 && DECL_BUILT_IN (olddecl)
1268 && C_DECL_INVISIBLE (olddecl))
1269 /* Don't warn about an extern followed by a definition. */
1270 && !(DECL_EXTERNAL (olddecl) && !DECL_EXTERNAL (newdecl))
1271 /* Don't warn about forward parameter decls. */
1272 && !(TREE_CODE (newdecl) == PARM_DECL
1273 && TREE_ASM_WRITTEN (olddecl) && !TREE_ASM_WRITTEN (newdecl))
1274 /* Don't warn about a variable definition following a declaration. */
1275 && !(TREE_CODE (newdecl) == VAR_DECL
1276 && DECL_INITIAL (newdecl) && !DECL_INITIAL (olddecl)))
1278 warning ("%Jredundant redeclaration of '%D'", newdecl, newdecl);
1279 warned = true;
1282 /* Report location of previous decl/defn in a consistent manner. */
1283 if (warned || pedwarned)
1284 locate_old_decl (olddecl, pedwarned ? pedwarn : warning);
1286 return true;
1289 /* Subroutine of duplicate_decls. NEWDECL has been found to be
1290 consistent with OLDDECL, but carries new information. Merge the
1291 new information into OLDDECL. This function issues no
1292 diagnostics. */
1294 static void
1295 merge_decls (tree newdecl, tree olddecl, tree newtype, tree oldtype)
1297 int new_is_definition = (TREE_CODE (newdecl) == FUNCTION_DECL
1298 && DECL_INITIAL (newdecl) != 0);
1300 /* For real parm decl following a forward decl, return 1 so old decl
1301 will be reused. Only allow this to happen once. */
1302 if (TREE_CODE (newdecl) == PARM_DECL
1303 && TREE_ASM_WRITTEN (olddecl) && ! TREE_ASM_WRITTEN (newdecl))
1305 TREE_ASM_WRITTEN (olddecl) = 0;
1306 return;
1309 DECL_ATTRIBUTES (newdecl)
1310 = (*targetm.merge_decl_attributes) (olddecl, newdecl);
1312 /* Merge the data types specified in the two decls. */
1313 TREE_TYPE (newdecl)
1314 = TREE_TYPE (olddecl)
1315 = common_type (newtype, oldtype);
1317 /* Lay the type out, unless already done. */
1318 if (oldtype != TREE_TYPE (newdecl))
1320 if (TREE_TYPE (newdecl) != error_mark_node)
1321 layout_type (TREE_TYPE (newdecl));
1322 if (TREE_CODE (newdecl) != FUNCTION_DECL
1323 && TREE_CODE (newdecl) != TYPE_DECL
1324 && TREE_CODE (newdecl) != CONST_DECL)
1325 layout_decl (newdecl, 0);
1327 else
1329 /* Since the type is OLDDECL's, make OLDDECL's size go with. */
1330 DECL_SIZE (newdecl) = DECL_SIZE (olddecl);
1331 DECL_SIZE_UNIT (newdecl) = DECL_SIZE_UNIT (olddecl);
1332 DECL_MODE (newdecl) = DECL_MODE (olddecl);
1333 if (TREE_CODE (olddecl) != FUNCTION_DECL)
1334 if (DECL_ALIGN (olddecl) > DECL_ALIGN (newdecl))
1336 DECL_ALIGN (newdecl) = DECL_ALIGN (olddecl);
1337 DECL_USER_ALIGN (newdecl) |= DECL_ALIGN (olddecl);
1341 /* Keep the old rtl since we can safely use it. */
1342 COPY_DECL_RTL (olddecl, newdecl);
1344 /* Merge the type qualifiers. */
1345 if (TREE_READONLY (newdecl))
1346 TREE_READONLY (olddecl) = 1;
1348 if (TREE_THIS_VOLATILE (newdecl))
1350 TREE_THIS_VOLATILE (olddecl) = 1;
1351 if (TREE_CODE (newdecl) == VAR_DECL)
1352 make_var_volatile (newdecl);
1355 /* Keep source location of definition rather than declaration. */
1356 if (DECL_INITIAL (newdecl) == 0 && DECL_INITIAL (olddecl) != 0)
1357 DECL_SOURCE_LOCATION (newdecl) = DECL_SOURCE_LOCATION (olddecl);
1359 /* Merge the unused-warning information. */
1360 if (DECL_IN_SYSTEM_HEADER (olddecl))
1361 DECL_IN_SYSTEM_HEADER (newdecl) = 1;
1362 else if (DECL_IN_SYSTEM_HEADER (newdecl))
1363 DECL_IN_SYSTEM_HEADER (olddecl) = 1;
1365 /* Merge the initialization information. */
1366 if (DECL_INITIAL (newdecl) == 0)
1367 DECL_INITIAL (newdecl) = DECL_INITIAL (olddecl);
1369 /* Merge the section attribute.
1370 We want to issue an error if the sections conflict but that must be
1371 done later in decl_attributes since we are called before attributes
1372 are assigned. */
1373 if (DECL_SECTION_NAME (newdecl) == NULL_TREE)
1374 DECL_SECTION_NAME (newdecl) = DECL_SECTION_NAME (olddecl);
1376 /* Copy the assembler name.
1377 Currently, it can only be defined in the prototype. */
1378 COPY_DECL_ASSEMBLER_NAME (olddecl, newdecl);
1380 /* Use visibility of whichever declaration had it specified */
1381 if (DECL_VISIBILITY_SPECIFIED (olddecl))
1383 DECL_VISIBILITY (newdecl) = DECL_VISIBILITY (olddecl);
1384 DECL_VISIBILITY_SPECIFIED (newdecl) = 1;
1387 if (TREE_CODE (newdecl) == FUNCTION_DECL)
1389 DECL_STATIC_CONSTRUCTOR(newdecl) |= DECL_STATIC_CONSTRUCTOR(olddecl);
1390 DECL_STATIC_DESTRUCTOR (newdecl) |= DECL_STATIC_DESTRUCTOR (olddecl);
1391 DECL_NO_LIMIT_STACK (newdecl) |= DECL_NO_LIMIT_STACK (olddecl);
1392 DECL_NO_INSTRUMENT_FUNCTION_ENTRY_EXIT (newdecl)
1393 |= DECL_NO_INSTRUMENT_FUNCTION_ENTRY_EXIT (olddecl);
1394 TREE_THIS_VOLATILE (newdecl) |= TREE_THIS_VOLATILE (olddecl);
1395 TREE_READONLY (newdecl) |= TREE_READONLY (olddecl);
1396 DECL_IS_MALLOC (newdecl) |= DECL_IS_MALLOC (olddecl);
1397 DECL_IS_PURE (newdecl) |= DECL_IS_PURE (olddecl);
1400 /* Merge the storage class information. */
1401 merge_weak (newdecl, olddecl);
1403 /* For functions, static overrides non-static. */
1404 if (TREE_CODE (newdecl) == FUNCTION_DECL)
1406 TREE_PUBLIC (newdecl) &= TREE_PUBLIC (olddecl);
1407 /* This is since we don't automatically
1408 copy the attributes of NEWDECL into OLDDECL. */
1409 TREE_PUBLIC (olddecl) = TREE_PUBLIC (newdecl);
1410 /* If this clears `static', clear it in the identifier too. */
1411 if (! TREE_PUBLIC (olddecl))
1412 TREE_PUBLIC (DECL_NAME (olddecl)) = 0;
1414 if (DECL_EXTERNAL (newdecl))
1416 TREE_STATIC (newdecl) = TREE_STATIC (olddecl);
1417 DECL_EXTERNAL (newdecl) = DECL_EXTERNAL (olddecl);
1419 /* An extern decl does not override previous storage class. */
1420 TREE_PUBLIC (newdecl) = TREE_PUBLIC (olddecl);
1421 if (! DECL_EXTERNAL (newdecl))
1423 DECL_CONTEXT (newdecl) = DECL_CONTEXT (olddecl);
1424 DECL_COMMON (newdecl) = DECL_COMMON (olddecl);
1427 else
1429 TREE_STATIC (olddecl) = TREE_STATIC (newdecl);
1430 TREE_PUBLIC (olddecl) = TREE_PUBLIC (newdecl);
1433 if (TREE_CODE (newdecl) == FUNCTION_DECL)
1435 /* If we're redefining a function previously defined as extern
1436 inline, make sure we emit debug info for the inline before we
1437 throw it away, in case it was inlined into a function that hasn't
1438 been written out yet. */
1439 if (new_is_definition && DECL_INITIAL (olddecl))
1441 if (TREE_USED (olddecl)
1442 /* In unit-at-a-time mode we never inline re-defined extern
1443 inline functions. */
1444 && !flag_unit_at_a_time
1445 && cgraph_function_possibly_inlined_p (olddecl))
1446 (*debug_hooks->outlining_inline_function) (olddecl);
1448 /* The new defn must not be inline. */
1449 DECL_INLINE (newdecl) = 0;
1450 DECL_UNINLINABLE (newdecl) = 1;
1452 else
1454 /* If either decl says `inline', this fn is inline,
1455 unless its definition was passed already. */
1456 if (DECL_DECLARED_INLINE_P (newdecl)
1457 || DECL_DECLARED_INLINE_P (olddecl))
1458 DECL_DECLARED_INLINE_P (newdecl) = 1;
1460 DECL_UNINLINABLE (newdecl) = DECL_UNINLINABLE (olddecl)
1461 = (DECL_UNINLINABLE (newdecl) || DECL_UNINLINABLE (olddecl));
1464 if (DECL_BUILT_IN (olddecl))
1466 /* If redeclaring a builtin function, it stays built in. */
1467 DECL_BUILT_IN_CLASS (newdecl) = DECL_BUILT_IN_CLASS (olddecl);
1468 DECL_FUNCTION_CODE (newdecl) = DECL_FUNCTION_CODE (olddecl);
1471 /* Also preserve various other info from the definition. */
1472 if (! new_is_definition)
1474 DECL_RESULT (newdecl) = DECL_RESULT (olddecl);
1475 DECL_INITIAL (newdecl) = DECL_INITIAL (olddecl);
1476 DECL_SAVED_INSNS (newdecl) = DECL_SAVED_INSNS (olddecl);
1477 DECL_SAVED_TREE (newdecl) = DECL_SAVED_TREE (olddecl);
1478 DECL_ARGUMENTS (newdecl) = DECL_ARGUMENTS (olddecl);
1480 /* Set DECL_INLINE on the declaration if we've got a body
1481 from which to instantiate. */
1482 if (DECL_INLINE (olddecl) && ! DECL_UNINLINABLE (newdecl))
1484 DECL_INLINE (newdecl) = 1;
1485 DECL_ABSTRACT_ORIGIN (newdecl)
1486 = DECL_ABSTRACT_ORIGIN (olddecl);
1489 else
1491 /* If a previous declaration said inline, mark the
1492 definition as inlinable. */
1493 if (DECL_DECLARED_INLINE_P (newdecl)
1494 && ! DECL_UNINLINABLE (newdecl))
1495 DECL_INLINE (newdecl) = 1;
1499 /* Copy most of the decl-specific fields of NEWDECL into OLDDECL.
1500 But preserve OLDDECL's DECL_UID and C_DECL_INVISIBLE. */
1502 unsigned olddecl_uid = DECL_UID (olddecl);
1503 unsigned olddecl_invisible = C_DECL_INVISIBLE (olddecl);
1505 memcpy ((char *) olddecl + sizeof (struct tree_common),
1506 (char *) newdecl + sizeof (struct tree_common),
1507 sizeof (struct tree_decl) - sizeof (struct tree_common));
1508 DECL_UID (olddecl) = olddecl_uid;
1509 C_DECL_INVISIBLE (olddecl) = olddecl_invisible;
1512 /* If OLDDECL had its DECL_RTL instantiated, re-invoke make_decl_rtl
1513 so that encode_section_info has a chance to look at the new decl
1514 flags and attributes. */
1515 if (DECL_RTL_SET_P (olddecl)
1516 && (TREE_CODE (olddecl) == FUNCTION_DECL
1517 || (TREE_CODE (olddecl) == VAR_DECL
1518 && TREE_STATIC (olddecl))))
1519 make_decl_rtl (olddecl, NULL);
1522 /* Handle when a new declaration NEWDECL has the same name as an old
1523 one OLDDECL in the same binding contour. Prints an error message
1524 if appropriate.
1526 If safely possible, alter OLDDECL to look like NEWDECL, and return
1527 true. Otherwise, return false. */
1529 static bool
1530 duplicate_decls (tree newdecl, tree olddecl)
1532 tree newtype, oldtype;
1534 if (!diagnose_mismatched_decls (newdecl, olddecl, &newtype, &oldtype))
1535 return false;
1537 merge_decls (newdecl, olddecl, newtype, oldtype);
1538 return true;
1542 /* Return any external DECL associated with ID, whether or not it is
1543 currently in scope. */
1545 static tree
1546 any_external_decl (tree id)
1548 tree decl = IDENTIFIER_SYMBOL_VALUE (id);
1549 tree t;
1551 if (decl == 0 || TREE_CODE (decl) == ERROR_MARK)
1552 return 0;
1553 else if (TREE_CODE (decl) != TYPE_DECL && DECL_EXTERNAL (decl))
1554 return decl;
1556 t = purpose_member (id, truly_local_externals);
1557 if (t)
1558 return TREE_VALUE (t);
1560 return 0;
1563 /* Record an external decl DECL. This only does something if a
1564 shadowing decl already exists. */
1565 static void
1566 record_external_decl (tree decl)
1568 tree name = DECL_NAME (decl);
1569 if (!IDENTIFIER_SYMBOL_VALUE (name))
1570 return;
1572 truly_local_externals = tree_cons (name, decl, truly_local_externals);
1575 /* Check whether decl-node X shadows an existing declaration.
1576 OLD is the old IDENTIFIER_SYMBOL_VALUE of the DECL_NAME of X,
1577 which might be a NULL_TREE. */
1578 static void
1579 warn_if_shadowing (tree x, tree old)
1581 /* Nothing to shadow? */
1582 if (old == 0
1583 /* Shadow warnings not wanted? */
1584 || !warn_shadow
1585 /* No shadow warnings for internally generated vars. */
1586 || DECL_SOURCE_LINE (x) == 0
1587 /* No shadow warnings for vars made for inlining. */
1588 || DECL_FROM_INLINE (x)
1589 /* Don't warn about the parm names in function declarator
1590 within a function declarator.
1591 It would be nice to avoid warning in any function
1592 declarator in a declaration, as opposed to a definition,
1593 but there is no way to tell it's not a definition. */
1594 || (TREE_CODE (x) == PARM_DECL && current_scope->outer->parm_flag)
1595 /* Shadow warnings only apply to local variables and parameters. */
1596 || (TREE_CODE (x) != PARM_DECL && DECL_FILE_SCOPE_P (x)))
1597 return;
1599 if (TREE_CODE (old) == PARM_DECL)
1600 warning ("%Jdeclaration of '%D' shadows a parameter", x, x);
1601 else if (DECL_FILE_SCOPE_P (old))
1602 warning ("%Jdeclaration of '%D' shadows a global declaration", x, x);
1603 else
1604 warning ("%Jdeclaration of '%D' shadows a previous local", x, x);
1606 warning ("%Jshadowed declaration is here", old);
1610 /* Subroutine of pushdecl.
1612 X is a TYPE_DECL for a typedef statement. Create a brand new
1613 ..._TYPE node (which will be just a variant of the existing
1614 ..._TYPE node with identical properties) and then install X
1615 as the TYPE_NAME of this brand new (duplicate) ..._TYPE node.
1617 The whole point here is to end up with a situation where each
1618 and every ..._TYPE node the compiler creates will be uniquely
1619 associated with AT MOST one node representing a typedef name.
1620 This way, even though the compiler substitutes corresponding
1621 ..._TYPE nodes for TYPE_DECL (i.e. "typedef name") nodes very
1622 early on, later parts of the compiler can always do the reverse
1623 translation and get back the corresponding typedef name. For
1624 example, given:
1626 typedef struct S MY_TYPE;
1627 MY_TYPE object;
1629 Later parts of the compiler might only know that `object' was of
1630 type `struct S' if it were not for code just below. With this
1631 code however, later parts of the compiler see something like:
1633 struct S' == struct S
1634 typedef struct S' MY_TYPE;
1635 struct S' object;
1637 And they can then deduce (from the node for type struct S') that
1638 the original object declaration was:
1640 MY_TYPE object;
1642 Being able to do this is important for proper support of protoize,
1643 and also for generating precise symbolic debugging information
1644 which takes full account of the programmer's (typedef) vocabulary.
1646 Obviously, we don't want to generate a duplicate ..._TYPE node if
1647 the TYPE_DECL node that we are now processing really represents a
1648 standard built-in type.
1650 Since all standard types are effectively declared at line zero
1651 in the source file, we can easily check to see if we are working
1652 on a standard type by checking the current value of lineno. */
1654 static void
1655 clone_underlying_type (tree x)
1657 if (DECL_SOURCE_LINE (x) == 0)
1659 if (TYPE_NAME (TREE_TYPE (x)) == 0)
1660 TYPE_NAME (TREE_TYPE (x)) = x;
1662 else if (TREE_TYPE (x) != error_mark_node
1663 && DECL_ORIGINAL_TYPE (x) == NULL_TREE)
1665 tree tt = TREE_TYPE (x);
1666 DECL_ORIGINAL_TYPE (x) = tt;
1667 tt = build_type_copy (tt);
1668 TYPE_NAME (tt) = x;
1669 TREE_USED (tt) = TREE_USED (x);
1670 TREE_TYPE (x) = tt;
1674 /* Record a decl-node X as belonging to the current lexical scope.
1675 Check for errors (such as an incompatible declaration for the same
1676 name already seen in the same scope).
1678 Returns either X or an old decl for the same name.
1679 If an old decl is returned, it may have been smashed
1680 to agree with what X says. */
1682 tree
1683 pushdecl (tree x)
1685 tree name = DECL_NAME (x);
1686 struct c_scope *scope = current_scope;
1688 #ifdef ENABLE_CHECKING
1689 if (error_mark_node == 0)
1690 /* Called too early. */
1691 abort ();
1692 #endif
1694 /* Functions need the lang_decl data. */
1695 if (TREE_CODE (x) == FUNCTION_DECL && ! DECL_LANG_SPECIFIC (x))
1696 DECL_LANG_SPECIFIC (x) = ggc_alloc_cleared (sizeof (struct lang_decl));
1698 /* A local extern declaration for a function doesn't constitute nesting.
1699 A local auto declaration does, since it's a forward decl
1700 for a nested function coming later. */
1701 if (current_function_decl == NULL
1702 || ((TREE_CODE (x) == FUNCTION_DECL || TREE_CODE (x) == VAR_DECL)
1703 && DECL_INITIAL (x) == 0 && DECL_EXTERNAL (x)))
1704 DECL_CONTEXT (x) = current_file_decl;
1705 else
1706 DECL_CONTEXT (x) = current_function_decl;
1708 if (name)
1710 tree old;
1712 if (warn_nested_externs
1713 && scope != global_scope
1714 && DECL_EXTERNAL (x)
1715 && !DECL_IN_SYSTEM_HEADER (x))
1716 warning ("nested extern declaration of `%s'",
1717 IDENTIFIER_POINTER (name));
1719 old = lookup_name_current_level (name);
1720 if (old && duplicate_decls (x, old))
1722 /* For PARM_DECLs, old may be a forward declaration.
1723 If so, we want to remove it from its old location
1724 (in the variables chain) and rechain it in the
1725 location given by the new declaration. */
1726 if (TREE_CODE (x) == PARM_DECL)
1728 tree *p;
1729 for (p = &scope->names; *p; p = &TREE_CHAIN (*p))
1730 if (*p == old)
1732 *p = TREE_CHAIN (old);
1733 SCOPE_LIST_APPEND (scope, parms, old);
1734 break;
1737 return old;
1739 if (DECL_EXTERNAL (x) || scope == global_scope)
1741 /* Find and check against a previous, not-in-scope, external
1742 decl for this identifier. (C99 6.2.7p2: All declarations
1743 that refer to the same object or function shall have
1744 compatible type; otherwise, the behavior is undefined.) */
1745 tree ext = any_external_decl (name);
1746 if (ext)
1748 if (duplicate_decls (x, ext))
1749 x = copy_node (ext);
1751 else
1752 record_external_decl (x);
1755 if (TREE_CODE (x) == TYPE_DECL)
1756 clone_underlying_type (x);
1758 /* If storing a local value, there may already be one
1759 (inherited). If so, record it for restoration when this
1760 scope ends. Take care not to do this if we are replacing an
1761 older decl in the same scope (i.e. duplicate_decls returned
1762 false, above). */
1763 if (scope != global_scope)
1765 tree inherited_decl = lookup_name (name);
1766 if (inherited_decl && inherited_decl != old)
1768 warn_if_shadowing (x, inherited_decl);
1769 scope->shadowed = tree_cons (name, inherited_decl,
1770 scope->shadowed);
1774 /* Install the new declaration in the requested scope. */
1775 IDENTIFIER_SYMBOL_VALUE (name) = x;
1776 C_DECL_INVISIBLE (x) = 0;
1778 /* If x's type is incomplete because it's based on a
1779 structure or union which has not yet been fully declared,
1780 attach it to that structure or union type, so we can go
1781 back and complete the variable declaration later, if the
1782 structure or union gets fully declared.
1784 If the input is erroneous, we can have error_mark in the type
1785 slot (e.g. "f(void a, ...)") - that doesn't count as an
1786 incomplete type. */
1787 if (TREE_TYPE (x) != error_mark_node
1788 && !COMPLETE_TYPE_P (TREE_TYPE (x)))
1790 tree element = TREE_TYPE (x);
1792 while (TREE_CODE (element) == ARRAY_TYPE)
1793 element = TREE_TYPE (element);
1794 element = TYPE_MAIN_VARIANT (element);
1796 if ((TREE_CODE (element) == RECORD_TYPE
1797 || TREE_CODE (element) == UNION_TYPE)
1798 && (TREE_CODE (x) != TYPE_DECL
1799 || TREE_CODE (TREE_TYPE (x)) == ARRAY_TYPE)
1800 && !COMPLETE_TYPE_P (element))
1801 C_TYPE_INCOMPLETE_VARS (element)
1802 = tree_cons (NULL_TREE, x, C_TYPE_INCOMPLETE_VARS (element));
1806 if (TREE_CODE (x) == PARM_DECL)
1807 SCOPE_LIST_APPEND (scope, parms, x);
1808 else
1809 SCOPE_LIST_APPEND (scope, names, x);
1811 return x;
1814 /* Record X as belonging to the global scope (C99 "file scope").
1815 This is used only internally by the Objective-C front end,
1816 and is limited to its needs. duplicate_decls is not called;
1817 if there is any preexisting decl for this identifier, it is an ICE. */
1819 tree
1820 pushdecl_top_level (tree x)
1822 tree name;
1824 if (TREE_CODE (x) != VAR_DECL)
1825 abort ();
1827 name = DECL_NAME (x);
1829 if (IDENTIFIER_SYMBOL_VALUE (name))
1830 abort ();
1832 DECL_CONTEXT (x) = current_file_decl;
1833 IDENTIFIER_SYMBOL_VALUE (name) = x;
1835 SCOPE_LIST_APPEND (global_scope, names, x);
1836 return x;
1839 /* Generate an implicit declaration for identifier FUNCTIONID as a
1840 function of type int (). */
1842 tree
1843 implicitly_declare (tree functionid)
1845 tree decl = any_external_decl (functionid);
1847 if (decl)
1849 /* Implicit declaration of a function already declared
1850 (somehow) in a different scope, or as a built-in.
1851 If this is the first time this has happened, warn;
1852 then recycle the old declaration. */
1853 if (!C_DECL_IMPLICIT (decl))
1855 implicit_decl_warning (DECL_NAME (decl));
1856 if (! DECL_FILE_SCOPE_P (decl))
1857 warning ("%Jprevious declaration of '%D'", decl, decl);
1858 C_DECL_IMPLICIT (decl) = 1;
1860 /* If this function is global, then it must already be in the
1861 global scope, so there's no need to push it again. */
1862 if (current_scope == global_scope)
1863 return decl;
1864 /* If this is a local declaration, make a copy; we can't have
1865 the same DECL listed in two different scopes. */
1866 return pushdecl (copy_node (decl));
1869 /* Not seen before. */
1870 decl = build_decl (FUNCTION_DECL, functionid, default_function_type);
1871 DECL_EXTERNAL (decl) = 1;
1872 TREE_PUBLIC (decl) = 1;
1873 C_DECL_IMPLICIT (decl) = 1;
1874 implicit_decl_warning (functionid);
1876 /* C89 says implicit declarations are in the innermost block.
1877 So we record the decl in the standard fashion. */
1878 decl = pushdecl (decl);
1880 /* No need to call objc_check_decl here - it's a function type. */
1881 rest_of_decl_compilation (decl, NULL, 0, 0);
1883 /* Write a record describing this implicit function declaration
1884 to the prototypes file (if requested). */
1885 gen_aux_info_record (decl, 0, 1, 0);
1887 /* Possibly apply some default attributes to this implicit declaration. */
1888 decl_attributes (&decl, NULL_TREE, 0);
1890 return decl;
1893 static void
1894 implicit_decl_warning (tree id)
1896 const char *name = IDENTIFIER_POINTER (id);
1897 if (mesg_implicit_function_declaration == 2)
1898 error ("implicit declaration of function `%s'", name);
1899 else if (mesg_implicit_function_declaration == 1)
1900 warning ("implicit declaration of function `%s'", name);
1903 /* Issue an error message for a reference to an undeclared variable
1904 ID, including a reference to a builtin outside of function-call
1905 context. Establish a binding of the identifier to error_mark_node
1906 in an appropriate scope, which will suppress further errors for the
1907 same identifier. */
1908 void
1909 undeclared_variable (tree id)
1911 static bool already = false;
1912 struct c_scope *scope;
1914 if (current_function_decl == 0)
1916 error ("`%s' undeclared here (not in a function)",
1917 IDENTIFIER_POINTER (id));
1918 scope = current_scope;
1920 else
1922 error ("`%s' undeclared (first use in this function)",
1923 IDENTIFIER_POINTER (id));
1925 if (! already)
1927 error ("(Each undeclared identifier is reported only once");
1928 error ("for each function it appears in.)");
1929 already = true;
1932 scope = current_function_scope;
1935 scope->shadowed = tree_cons (id, IDENTIFIER_SYMBOL_VALUE (id),
1936 scope->shadowed);
1937 IDENTIFIER_SYMBOL_VALUE (id) = error_mark_node;
1940 /* Subroutine of lookup_label, declare_label, define_label: construct a
1941 LABEL_DECL with all the proper frills. */
1943 static tree
1944 make_label (tree name, location_t location)
1946 tree label = build_decl (LABEL_DECL, name, void_type_node);
1948 DECL_CONTEXT (label) = current_function_decl;
1949 DECL_MODE (label) = VOIDmode;
1950 DECL_SOURCE_LOCATION (label) = location;
1952 return label;
1955 /* Another subroutine of lookup_label, declare_label, define_label:
1956 set up the binding of name to LABEL_DECL in the given SCOPE. */
1958 static void
1959 bind_label (tree name, tree label, struct c_scope *scope)
1961 if (IDENTIFIER_LABEL_VALUE (name))
1962 scope->shadowed = tree_cons (name, IDENTIFIER_LABEL_VALUE (name),
1963 scope->shadowed);
1964 IDENTIFIER_LABEL_VALUE (name) = label;
1966 SCOPE_LIST_APPEND (scope, names, label);
1969 /* Get the LABEL_DECL corresponding to identifier NAME as a label.
1970 Create one if none exists so far for the current function.
1971 This is called when a label is used in a goto expression or
1972 has its address taken. */
1974 tree
1975 lookup_label (tree name)
1977 tree label;
1979 if (current_function_decl == 0)
1981 error ("label %s referenced outside of any function",
1982 IDENTIFIER_POINTER (name));
1983 return 0;
1986 /* Use a label already defined or ref'd with this name, but not if
1987 it is inherited from a containing function and wasn't declared
1988 using __label__. */
1989 label = IDENTIFIER_LABEL_VALUE (name);
1990 if (label && (DECL_CONTEXT (label) == current_function_decl
1991 || C_DECLARED_LABEL_FLAG (label)))
1993 /* If the label has only been declared, update its apparent
1994 location to point here, for better diagnostics if it
1995 turns out not to have been defined. */
1996 if (!TREE_USED (label))
1997 DECL_SOURCE_LOCATION (label) = input_location;
1998 return label;
2001 /* No label binding for that identifier; make one. */
2002 label = make_label (name, input_location);
2004 /* Ordinary labels go in the current function scope. */
2005 bind_label (name, label, current_function_scope);
2006 return label;
2009 /* Make a label named NAME in the current function, shadowing silently
2010 any that may be inherited from containing functions or containing
2011 scopes. This is called for __label__ declarations. */
2013 /* Note that valid use, if the label being shadowed comes from another
2014 scope in the same function, requires calling declare_nonlocal_label
2015 right away. (Is this still true? -zw 2003-07-17) */
2017 tree
2018 declare_label (tree name)
2020 tree label = IDENTIFIER_LABEL_VALUE (name);
2021 tree dup;
2023 /* Check to make sure that the label hasn't already been declared
2024 at this scope */
2025 for (dup = current_scope->names; dup; dup = TREE_CHAIN (dup))
2026 if (dup == label)
2028 error ("duplicate label declaration `%s'", IDENTIFIER_POINTER (name));
2029 error ("%Jthis is a previous declaration", dup);
2031 /* Just use the previous declaration. */
2032 return dup;
2035 label = make_label (name, input_location);
2036 C_DECLARED_LABEL_FLAG (label) = 1;
2038 /* Declared labels go in the current scope. */
2039 bind_label (name, label, current_scope);
2040 return label;
2043 /* Define a label, specifying the location in the source file.
2044 Return the LABEL_DECL node for the label, if the definition is valid.
2045 Otherwise return 0. */
2047 tree
2048 define_label (location_t location, tree name)
2050 tree label;
2052 /* Find any preexisting label with this name. It is an error
2053 if that label has already been defined in this function, or
2054 if there is a containing function with a declared label with
2055 the same name. */
2056 label = IDENTIFIER_LABEL_VALUE (name);
2058 if (label
2059 && ((DECL_CONTEXT (label) == current_function_decl
2060 && DECL_INITIAL (label) != 0)
2061 || (DECL_CONTEXT (label) != current_function_decl
2062 && C_DECLARED_LABEL_FLAG (label))))
2064 error ("%Hduplicate label `%D'", &location, label);
2065 if (DECL_INITIAL (label))
2066 error ("%J`%D' previously defined here", label, label);
2067 else
2068 error ("%J`%D' previously declared here", label, label);
2069 return 0;
2071 else if (label && DECL_CONTEXT (label) == current_function_decl)
2073 /* The label has been used or declared already in this function,
2074 but not defined. Update its location to point to this
2075 definition. */
2076 DECL_SOURCE_LOCATION (label) = location;
2078 else
2080 /* No label binding for that identifier; make one. */
2081 label = make_label (name, location);
2083 /* Ordinary labels go in the current function scope. */
2084 bind_label (name, label, current_function_scope);
2087 if (warn_traditional && !in_system_header && lookup_name (name))
2088 warning ("%Htraditional C lacks a separate namespace for labels, "
2089 "identifier `%s' conflicts", &location,
2090 IDENTIFIER_POINTER (name));
2092 /* Mark label as having been defined. */
2093 DECL_INITIAL (label) = error_mark_node;
2094 return label;
2097 /* Return the list of declarations of the current scope. */
2099 tree
2100 getdecls (void)
2102 return current_scope->names;
2106 /* Given NAME, an IDENTIFIER_NODE,
2107 return the structure (or union or enum) definition for that name.
2108 If THISLEVEL_ONLY is nonzero, searches only the current_scope.
2109 CODE says which kind of type the caller wants;
2110 it is RECORD_TYPE or UNION_TYPE or ENUMERAL_TYPE.
2111 If the wrong kind of type is found, an error is reported. */
2113 static tree
2114 lookup_tag (enum tree_code code, tree name, int thislevel_only)
2116 tree tag = IDENTIFIER_TAG_VALUE (name);
2117 int thislevel = 0;
2119 if (!tag)
2120 return 0;
2122 /* We only care about whether it's in this level if
2123 thislevel_only was set or it might be a type clash. */
2124 if (thislevel_only || TREE_CODE (tag) != code)
2126 if (current_scope == global_scope
2127 || purpose_member (name, current_scope->tags))
2128 thislevel = 1;
2131 if (thislevel_only && !thislevel)
2132 return 0;
2134 if (TREE_CODE (tag) != code)
2136 /* Definition isn't the kind we were looking for. */
2137 pending_invalid_xref = name;
2138 pending_invalid_xref_location = input_location;
2140 /* If in the same binding level as a declaration as a tag
2141 of a different type, this must not be allowed to
2142 shadow that tag, so give the error immediately.
2143 (For example, "struct foo; union foo;" is invalid.) */
2144 if (thislevel)
2145 pending_xref_error ();
2147 return tag;
2150 /* Print an error message now
2151 for a recent invalid struct, union or enum cross reference.
2152 We don't print them immediately because they are not invalid
2153 when used in the `struct foo;' construct for shadowing. */
2155 void
2156 pending_xref_error (void)
2158 if (pending_invalid_xref != 0)
2159 error ("%H`%s' defined as wrong kind of tag",
2160 &pending_invalid_xref_location,
2161 IDENTIFIER_POINTER (pending_invalid_xref));
2162 pending_invalid_xref = 0;
2166 /* Look up NAME in the current scope and its superiors
2167 in the namespace of variables, functions and typedefs.
2168 Return a ..._DECL node of some kind representing its definition,
2169 or return 0 if it is undefined. */
2171 tree
2172 lookup_name (tree name)
2174 tree decl = IDENTIFIER_SYMBOL_VALUE (name);
2175 if (decl == 0 || decl == error_mark_node)
2176 return decl;
2177 if (C_DECL_INVISIBLE (decl))
2178 return 0;
2179 return decl;
2182 /* Similar to `lookup_name' but look only at the current scope. */
2184 static tree
2185 lookup_name_current_level (tree name)
2187 tree decl = IDENTIFIER_SYMBOL_VALUE (name);
2189 if (decl == 0 || decl == error_mark_node || C_DECL_INVISIBLE (decl))
2190 return 0;
2192 if (current_scope == global_scope)
2193 return decl;
2195 /* Scan the current scope for a decl with name NAME.
2196 For PARM_DECLs, we have to look at both ->parms and ->names, since
2197 forward parameter declarations wind up on the ->names list. */
2198 if (TREE_CODE (decl) == PARM_DECL
2199 && chain_member (decl, current_scope->parms))
2200 return decl;
2201 if (chain_member (decl, current_scope->names))
2202 return decl;
2204 return 0;
2207 /* Create the predefined scalar types of C,
2208 and some nodes representing standard constants (0, 1, (void *) 0).
2209 Initialize the global scope.
2210 Make definitions for built-in primitive functions. */
2212 void
2213 c_init_decl_processing (void)
2215 tree endlink;
2216 tree ptr_ftype_void, ptr_ftype_ptr;
2217 location_t save_loc = input_location;
2219 /* Adds some ggc roots, and reserved words for c-parse.in. */
2220 c_parse_init ();
2222 current_function_decl = 0;
2224 /* Make the c_scope structure for global names. */
2225 pushlevel (0);
2226 global_scope = current_scope;
2228 /* Declarations from c_common_nodes_and_builtins must not be associated
2229 with this input file, lest we get differences between using and not
2230 using preprocessed headers. */
2231 input_location.file = "<internal>";
2232 input_location.line = 0;
2234 /* Make the DECL for the toplevel file scope. */
2235 current_file_decl = build_decl (TRANSLATION_UNIT_DECL, NULL, NULL);
2237 build_common_tree_nodes (flag_signed_char);
2239 c_common_nodes_and_builtins ();
2241 /* In C, comparisons and TRUTH_* expressions have type int. */
2242 truthvalue_type_node = integer_type_node;
2243 truthvalue_true_node = integer_one_node;
2244 truthvalue_false_node = integer_zero_node;
2246 /* Even in C99, which has a real boolean type. */
2247 pushdecl (build_decl (TYPE_DECL, get_identifier ("_Bool"),
2248 boolean_type_node));
2250 endlink = void_list_node;
2251 ptr_ftype_void = build_function_type (ptr_type_node, endlink);
2252 ptr_ftype_ptr
2253 = build_function_type (ptr_type_node,
2254 tree_cons (NULL_TREE, ptr_type_node, endlink));
2256 input_location = save_loc;
2258 pedantic_lvalues = pedantic;
2260 make_fname_decl = c_make_fname_decl;
2261 start_fname_decls ();
2263 first_builtin_decl = global_scope->names;
2264 last_builtin_decl = global_scope->names_last;
2267 /* Create the VAR_DECL for __FUNCTION__ etc. ID is the name to give the
2268 decl, NAME is the initialization string and TYPE_DEP indicates whether
2269 NAME depended on the type of the function. As we don't yet implement
2270 delayed emission of static data, we mark the decl as emitted
2271 so it is not placed in the output. Anything using it must therefore pull
2272 out the STRING_CST initializer directly. FIXME. */
2274 static tree
2275 c_make_fname_decl (tree id, int type_dep)
2277 const char *name = fname_as_string (type_dep);
2278 tree decl, type, init;
2279 size_t length = strlen (name);
2281 type = build_array_type
2282 (build_qualified_type (char_type_node, TYPE_QUAL_CONST),
2283 build_index_type (size_int (length)));
2285 decl = build_decl (VAR_DECL, id, type);
2287 TREE_STATIC (decl) = 1;
2288 TREE_READONLY (decl) = 1;
2289 DECL_ARTIFICIAL (decl) = 1;
2291 init = build_string (length + 1, name);
2292 TREE_TYPE (init) = type;
2293 DECL_INITIAL (decl) = init;
2295 TREE_USED (decl) = 1;
2297 if (current_function_decl)
2299 DECL_CONTEXT (decl) = current_function_decl;
2300 IDENTIFIER_SYMBOL_VALUE (id) = decl;
2301 SCOPE_LIST_APPEND (current_function_scope, names, decl);
2304 finish_decl (decl, init, NULL_TREE);
2306 return decl;
2309 /* Return a definition for a builtin function named NAME and whose data type
2310 is TYPE. TYPE should be a function type with argument types.
2311 FUNCTION_CODE tells later passes how to compile calls to this function.
2312 See tree.h for its possible values.
2314 If LIBRARY_NAME is nonzero, use that for DECL_ASSEMBLER_NAME,
2315 the name to be called if we can't opencode the function. If
2316 ATTRS is nonzero, use that for the function's attribute list. */
2318 tree
2319 builtin_function (const char *name, tree type, int function_code,
2320 enum built_in_class class, const char *library_name,
2321 tree attrs)
2323 tree decl = build_decl (FUNCTION_DECL, get_identifier (name), type);
2324 DECL_EXTERNAL (decl) = 1;
2325 TREE_PUBLIC (decl) = 1;
2326 if (library_name)
2327 SET_DECL_ASSEMBLER_NAME (decl, get_identifier (library_name));
2328 make_decl_rtl (decl, NULL);
2329 pushdecl (decl);
2330 DECL_BUILT_IN_CLASS (decl) = class;
2331 DECL_FUNCTION_CODE (decl) = function_code;
2333 /* Warn if a function in the namespace for users
2334 is used without an occasion to consider it declared. */
2335 if (name[0] != '_' || name[1] != '_')
2336 C_DECL_INVISIBLE (decl) = 1;
2338 /* Possibly apply some default attributes to this built-in function. */
2339 if (attrs)
2340 decl_attributes (&decl, attrs, ATTR_FLAG_BUILT_IN);
2341 else
2342 decl_attributes (&decl, NULL_TREE, 0);
2344 return decl;
2347 /* Called when a declaration is seen that contains no names to declare.
2348 If its type is a reference to a structure, union or enum inherited
2349 from a containing scope, shadow that tag name for the current scope
2350 with a forward reference.
2351 If its type defines a new named structure or union
2352 or defines an enum, it is valid but we need not do anything here.
2353 Otherwise, it is an error. */
2355 void
2356 shadow_tag (tree declspecs)
2358 shadow_tag_warned (declspecs, 0);
2361 void
2362 shadow_tag_warned (tree declspecs, int warned)
2365 /* 1 => we have done a pedwarn. 2 => we have done a warning, but
2366 no pedwarn. */
2368 int found_tag = 0;
2369 tree link;
2370 tree specs, attrs;
2372 pending_invalid_xref = 0;
2374 /* Remove the attributes from declspecs, since they will confuse the
2375 following code. */
2376 split_specs_attrs (declspecs, &specs, &attrs);
2378 for (link = specs; link; link = TREE_CHAIN (link))
2380 tree value = TREE_VALUE (link);
2381 enum tree_code code = TREE_CODE (value);
2383 if (code == RECORD_TYPE || code == UNION_TYPE || code == ENUMERAL_TYPE)
2384 /* Used to test also that TYPE_SIZE (value) != 0.
2385 That caused warning for `struct foo;' at top level in the file. */
2387 tree name = TYPE_NAME (value);
2388 tree t;
2390 found_tag++;
2392 if (name == 0)
2394 if (warned != 1 && code != ENUMERAL_TYPE)
2395 /* Empty unnamed enum OK */
2397 pedwarn ("unnamed struct/union that defines no instances");
2398 warned = 1;
2401 else
2403 t = lookup_tag (code, name, 1);
2405 if (t == 0)
2407 t = make_node (code);
2408 pushtag (name, t);
2412 else
2414 if (!warned && ! in_system_header)
2416 warning ("useless keyword or type name in empty declaration");
2417 warned = 2;
2422 if (found_tag > 1)
2423 error ("two types specified in one empty declaration");
2425 if (warned != 1)
2427 if (found_tag == 0)
2428 pedwarn ("empty declaration");
2432 /* Construct an array declarator. EXPR is the expression inside [], or
2433 NULL_TREE. QUALS are the type qualifiers inside the [] (to be applied
2434 to the pointer to which a parameter array is converted). STATIC_P is
2435 nonzero if "static" is inside the [], zero otherwise. VLA_UNSPEC_P
2436 is nonzero is the array is [*], a VLA of unspecified length which is
2437 nevertheless a complete type (not currently implemented by GCC),
2438 zero otherwise. The declarator is constructed as an ARRAY_REF
2439 (to be decoded by grokdeclarator), whose operand 0 is what's on the
2440 left of the [] (filled by in set_array_declarator_type) and operand 1
2441 is the expression inside; whose TREE_TYPE is the type qualifiers and
2442 which has TREE_STATIC set if "static" is used. */
2444 tree
2445 build_array_declarator (tree expr, tree quals, int static_p, int vla_unspec_p)
2447 tree decl;
2448 decl = build_nt (ARRAY_REF, NULL_TREE, expr);
2449 TREE_TYPE (decl) = quals;
2450 TREE_STATIC (decl) = (static_p ? 1 : 0);
2451 if (pedantic && !flag_isoc99)
2453 if (static_p || quals != NULL_TREE)
2454 pedwarn ("ISO C90 does not support `static' or type qualifiers in parameter array declarators");
2455 if (vla_unspec_p)
2456 pedwarn ("ISO C90 does not support `[*]' array declarators");
2458 if (vla_unspec_p)
2459 warning ("GCC does not yet properly implement `[*]' array declarators");
2460 return decl;
2463 /* Set the type of an array declarator. DECL is the declarator, as
2464 constructed by build_array_declarator; TYPE is what appears on the left
2465 of the [] and goes in operand 0. ABSTRACT_P is nonzero if it is an
2466 abstract declarator, zero otherwise; this is used to reject static and
2467 type qualifiers in abstract declarators, where they are not in the
2468 C99 grammar. */
2470 tree
2471 set_array_declarator_type (tree decl, tree type, int abstract_p)
2473 TREE_OPERAND (decl, 0) = type;
2474 if (abstract_p && (TREE_TYPE (decl) != NULL_TREE || TREE_STATIC (decl)))
2475 error ("static or type qualifiers in abstract declarator");
2476 return decl;
2479 /* Decode a "typename", such as "int **", returning a ..._TYPE node. */
2481 tree
2482 groktypename (tree typename)
2484 tree specs, attrs;
2486 if (TREE_CODE (typename) != TREE_LIST)
2487 return typename;
2489 split_specs_attrs (TREE_PURPOSE (typename), &specs, &attrs);
2491 typename = grokdeclarator (TREE_VALUE (typename), specs, TYPENAME, 0,
2492 NULL);
2494 /* Apply attributes. */
2495 decl_attributes (&typename, attrs, 0);
2497 return typename;
2500 /* Return a PARM_DECL node for a given pair of specs and declarator. */
2502 tree
2503 groktypename_in_parm_context (tree typename)
2505 if (TREE_CODE (typename) != TREE_LIST)
2506 return typename;
2507 return grokdeclarator (TREE_VALUE (typename),
2508 TREE_PURPOSE (typename),
2509 PARM, 0, NULL);
2512 /* Decode a declarator in an ordinary declaration or data definition.
2513 This is called as soon as the type information and variable name
2514 have been parsed, before parsing the initializer if any.
2515 Here we create the ..._DECL node, fill in its type,
2516 and put it on the list of decls for the current context.
2517 The ..._DECL node is returned as the value.
2519 Exception: for arrays where the length is not specified,
2520 the type is left null, to be filled in by `finish_decl'.
2522 Function definitions do not come here; they go to start_function
2523 instead. However, external and forward declarations of functions
2524 do go through here. Structure field declarations are done by
2525 grokfield and not through here. */
2527 tree
2528 start_decl (tree declarator, tree declspecs, int initialized, tree attributes)
2530 tree decl;
2531 tree tem;
2533 /* An object declared as __attribute__((deprecated)) suppresses
2534 warnings of uses of other deprecated items. */
2535 if (lookup_attribute ("deprecated", attributes))
2536 deprecated_state = DEPRECATED_SUPPRESS;
2538 decl = grokdeclarator (declarator, declspecs,
2539 NORMAL, initialized, NULL);
2541 deprecated_state = DEPRECATED_NORMAL;
2543 if (warn_main > 0 && TREE_CODE (decl) != FUNCTION_DECL
2544 && MAIN_NAME_P (DECL_NAME (decl)))
2545 warning ("%J'%D' is usually a function", decl, decl);
2547 if (initialized)
2548 /* Is it valid for this decl to have an initializer at all?
2549 If not, set INITIALIZED to zero, which will indirectly
2550 tell `finish_decl' to ignore the initializer once it is parsed. */
2551 switch (TREE_CODE (decl))
2553 case TYPE_DECL:
2554 error ("typedef `%s' is initialized (use __typeof__ instead)",
2555 IDENTIFIER_POINTER (DECL_NAME (decl)));
2556 initialized = 0;
2557 break;
2559 case FUNCTION_DECL:
2560 error ("function `%s' is initialized like a variable",
2561 IDENTIFIER_POINTER (DECL_NAME (decl)));
2562 initialized = 0;
2563 break;
2565 case PARM_DECL:
2566 /* DECL_INITIAL in a PARM_DECL is really DECL_ARG_TYPE. */
2567 error ("parameter `%s' is initialized",
2568 IDENTIFIER_POINTER (DECL_NAME (decl)));
2569 initialized = 0;
2570 break;
2572 default:
2573 /* Don't allow initializations for incomplete types
2574 except for arrays which might be completed by the initialization. */
2576 /* This can happen if the array size is an undefined macro. We already
2577 gave a warning, so we don't need another one. */
2578 if (TREE_TYPE (decl) == error_mark_node)
2579 initialized = 0;
2580 else if (COMPLETE_TYPE_P (TREE_TYPE (decl)))
2582 /* A complete type is ok if size is fixed. */
2584 if (TREE_CODE (TYPE_SIZE (TREE_TYPE (decl))) != INTEGER_CST
2585 || C_DECL_VARIABLE_SIZE (decl))
2587 error ("variable-sized object may not be initialized");
2588 initialized = 0;
2591 else if (TREE_CODE (TREE_TYPE (decl)) != ARRAY_TYPE)
2593 error ("variable `%s' has initializer but incomplete type",
2594 IDENTIFIER_POINTER (DECL_NAME (decl)));
2595 initialized = 0;
2597 else if (!COMPLETE_TYPE_P (TREE_TYPE (TREE_TYPE (decl))))
2599 error ("elements of array `%s' have incomplete type",
2600 IDENTIFIER_POINTER (DECL_NAME (decl)));
2601 initialized = 0;
2605 if (initialized)
2607 DECL_EXTERNAL (decl) = 0;
2608 if (current_scope == global_scope)
2609 TREE_STATIC (decl) = 1;
2611 /* Tell `pushdecl' this is an initialized decl
2612 even though we don't yet have the initializer expression.
2613 Also tell `finish_decl' it may store the real initializer. */
2614 DECL_INITIAL (decl) = error_mark_node;
2617 /* If this is a function declaration, write a record describing it to the
2618 prototypes file (if requested). */
2620 if (TREE_CODE (decl) == FUNCTION_DECL)
2621 gen_aux_info_record (decl, 0, 0, TYPE_ARG_TYPES (TREE_TYPE (decl)) != 0);
2623 /* ANSI specifies that a tentative definition which is not merged with
2624 a non-tentative definition behaves exactly like a definition with an
2625 initializer equal to zero. (Section 3.7.2)
2627 -fno-common gives strict ANSI behavior, though this tends to break
2628 a large body of code that grew up without this rule.
2630 Thread-local variables are never common, since there's no entrenched
2631 body of code to break, and it allows more efficient variable references
2632 in the presence of dynamic linking. */
2634 if (TREE_CODE (decl) == VAR_DECL
2635 && !initialized
2636 && TREE_PUBLIC (decl)
2637 && !DECL_THREAD_LOCAL (decl)
2638 && !flag_no_common)
2639 DECL_COMMON (decl) = 1;
2641 /* Set attributes here so if duplicate decl, will have proper attributes. */
2642 decl_attributes (&decl, attributes, 0);
2644 if (TREE_CODE (decl) == FUNCTION_DECL
2645 && targetm.calls.promote_prototypes (TREE_TYPE (decl)))
2647 tree ce = declarator;
2649 if (TREE_CODE (ce) == INDIRECT_REF)
2650 ce = TREE_OPERAND (declarator, 0);
2651 if (TREE_CODE (ce) == CALL_EXPR)
2653 tree args = TREE_PURPOSE (TREE_OPERAND (ce, 1));
2654 for (; args; args = TREE_CHAIN (args))
2656 tree type = TREE_TYPE (args);
2657 if (INTEGRAL_TYPE_P (type)
2658 && TYPE_PRECISION (type) < TYPE_PRECISION (integer_type_node))
2659 DECL_ARG_TYPE (args) = integer_type_node;
2664 if (TREE_CODE (decl) == FUNCTION_DECL
2665 && DECL_DECLARED_INLINE_P (decl)
2666 && DECL_UNINLINABLE (decl)
2667 && lookup_attribute ("noinline", DECL_ATTRIBUTES (decl)))
2668 warning ("%Jinline function '%D' given attribute noinline", decl, decl);
2670 /* Add this decl to the current scope.
2671 TEM may equal DECL or it may be a previous decl of the same name. */
2672 tem = pushdecl (decl);
2674 /* For a local variable, define the RTL now. */
2675 if (current_scope != global_scope
2676 /* But not if this is a duplicate decl
2677 and we preserved the rtl from the previous one
2678 (which may or may not happen). */
2679 && !DECL_RTL_SET_P (tem)
2680 && DECL_FILE_SCOPE_P (tem))
2682 if (TREE_TYPE (tem) != error_mark_node
2683 && (COMPLETE_TYPE_P (TREE_TYPE (tem))
2684 || (TREE_CODE (TREE_TYPE (tem)) == ARRAY_TYPE
2685 && DECL_INITIAL (tem) != 0)))
2686 expand_decl (tem);
2689 return tem;
2692 /* Finish processing of a declaration;
2693 install its initial value.
2694 If the length of an array type is not known before,
2695 it must be determined now, from the initial value, or it is an error. */
2697 void
2698 finish_decl (tree decl, tree init, tree asmspec_tree)
2700 tree type = TREE_TYPE (decl);
2701 int was_incomplete = (DECL_SIZE (decl) == 0);
2702 const char *asmspec = 0;
2704 /* If a name was specified, get the string. */
2705 if (current_scope == global_scope)
2706 asmspec_tree = maybe_apply_renaming_pragma (decl, asmspec_tree);
2707 if (asmspec_tree)
2708 asmspec = TREE_STRING_POINTER (asmspec_tree);
2710 /* If `start_decl' didn't like having an initialization, ignore it now. */
2711 if (init != 0 && DECL_INITIAL (decl) == 0)
2712 init = 0;
2714 /* Don't crash if parm is initialized. */
2715 if (TREE_CODE (decl) == PARM_DECL)
2716 init = 0;
2718 if (init)
2719 store_init_value (decl, init);
2721 if (c_dialect_objc () && (TREE_CODE (decl) == VAR_DECL
2722 || TREE_CODE (decl) == FUNCTION_DECL
2723 || TREE_CODE (decl) == FIELD_DECL))
2724 objc_check_decl (decl);
2726 /* Deduce size of array from initialization, if not already known. */
2727 if (TREE_CODE (type) == ARRAY_TYPE
2728 && TYPE_DOMAIN (type) == 0
2729 && TREE_CODE (decl) != TYPE_DECL)
2731 int do_default
2732 = (TREE_STATIC (decl)
2733 /* Even if pedantic, an external linkage array
2734 may have incomplete type at first. */
2735 ? pedantic && !TREE_PUBLIC (decl)
2736 : !DECL_EXTERNAL (decl));
2737 int failure
2738 = complete_array_type (type, DECL_INITIAL (decl), do_default);
2740 /* Get the completed type made by complete_array_type. */
2741 type = TREE_TYPE (decl);
2743 if (failure == 1)
2744 error ("%Jinitializer fails to determine size of '%D'", decl, decl);
2746 else if (failure == 2)
2748 if (do_default)
2749 error ("%Jarray size missing in '%D'", decl, decl);
2750 /* If a `static' var's size isn't known,
2751 make it extern as well as static, so it does not get
2752 allocated.
2753 If it is not `static', then do not mark extern;
2754 finish_incomplete_decl will give it a default size
2755 and it will get allocated. */
2756 else if (!pedantic && TREE_STATIC (decl) && ! TREE_PUBLIC (decl))
2757 DECL_EXTERNAL (decl) = 1;
2760 /* TYPE_MAX_VALUE is always one less than the number of elements
2761 in the array, because we start counting at zero. Therefore,
2762 warn only if the value is less than zero. */
2763 else if (pedantic && TYPE_DOMAIN (type) != 0
2764 && tree_int_cst_sgn (TYPE_MAX_VALUE (TYPE_DOMAIN (type))) < 0)
2765 error ("%Jzero or negative size array '%D'", decl, decl);
2767 layout_decl (decl, 0);
2770 if (TREE_CODE (decl) == VAR_DECL)
2772 if (DECL_SIZE (decl) == 0 && TREE_TYPE (decl) != error_mark_node
2773 && COMPLETE_TYPE_P (TREE_TYPE (decl)))
2774 layout_decl (decl, 0);
2776 if (DECL_SIZE (decl) == 0
2777 /* Don't give an error if we already gave one earlier. */
2778 && TREE_TYPE (decl) != error_mark_node
2779 && (TREE_STATIC (decl)
2781 /* A static variable with an incomplete type
2782 is an error if it is initialized.
2783 Also if it is not file scope.
2784 Otherwise, let it through, but if it is not `extern'
2785 then it may cause an error message later. */
2786 (DECL_INITIAL (decl) != 0
2787 || !DECL_FILE_SCOPE_P (decl))
2789 /* An automatic variable with an incomplete type
2790 is an error. */
2791 !DECL_EXTERNAL (decl)))
2793 error ("%Jstorage size of '%D' isn't known", decl, decl);
2794 TREE_TYPE (decl) = error_mark_node;
2797 if ((DECL_EXTERNAL (decl) || TREE_STATIC (decl))
2798 && DECL_SIZE (decl) != 0)
2800 if (TREE_CODE (DECL_SIZE (decl)) == INTEGER_CST)
2801 constant_expression_warning (DECL_SIZE (decl));
2802 else
2803 error ("%Jstorage size of '%D' isn't constant", decl, decl);
2806 if (TREE_USED (type))
2807 TREE_USED (decl) = 1;
2810 /* If this is a function and an assembler name is specified, reset DECL_RTL
2811 so we can give it its new name. Also, update built_in_decls if it
2812 was a normal built-in. */
2813 if (TREE_CODE (decl) == FUNCTION_DECL && asmspec)
2815 /* ASMSPEC is given, and not the name of a register. Mark the
2816 name with a star so assemble_name won't munge it. */
2817 char *starred = alloca (strlen (asmspec) + 2);
2818 starred[0] = '*';
2819 strcpy (starred + 1, asmspec);
2821 if (DECL_BUILT_IN_CLASS (decl) == BUILT_IN_NORMAL)
2823 tree builtin = built_in_decls [DECL_FUNCTION_CODE (decl)];
2824 SET_DECL_RTL (builtin, NULL_RTX);
2825 SET_DECL_ASSEMBLER_NAME (builtin, get_identifier (starred));
2826 #ifdef TARGET_MEM_FUNCTIONS
2827 if (DECL_FUNCTION_CODE (decl) == BUILT_IN_MEMCPY)
2828 init_block_move_fn (starred);
2829 else if (DECL_FUNCTION_CODE (decl) == BUILT_IN_MEMSET)
2830 init_block_clear_fn (starred);
2831 #else
2832 if (DECL_FUNCTION_CODE (decl) == BUILT_IN_BCOPY)
2833 init_block_move_fn (starred);
2834 else if (DECL_FUNCTION_CODE (decl) == BUILT_IN_BZERO)
2835 init_block_clear_fn (starred);
2836 #endif
2838 SET_DECL_RTL (decl, NULL_RTX);
2839 change_decl_assembler_name (decl, get_identifier (starred));
2842 /* If #pragma weak was used, mark the decl weak now. */
2843 if (current_scope == global_scope)
2844 maybe_apply_pragma_weak (decl);
2846 /* Output the assembler code and/or RTL code for variables and functions,
2847 unless the type is an undefined structure or union.
2848 If not, it will get done when the type is completed. */
2850 if (TREE_CODE (decl) == VAR_DECL || TREE_CODE (decl) == FUNCTION_DECL)
2852 /* This is a no-op in c-lang.c or something real in objc-act.c. */
2853 if (c_dialect_objc ())
2854 objc_check_decl (decl);
2856 if (DECL_FILE_SCOPE_P (decl))
2858 if (DECL_INITIAL (decl) == NULL_TREE
2859 || DECL_INITIAL (decl) == error_mark_node)
2860 /* Don't output anything
2861 when a tentative file-scope definition is seen.
2862 But at end of compilation, do output code for them. */
2863 DECL_DEFER_OUTPUT (decl) = 1;
2864 rest_of_decl_compilation (decl, asmspec, true, 0);
2866 else
2868 /* This is a local variable. If there is an ASMSPEC, the
2869 user has requested that we handle it specially. */
2870 if (asmspec)
2872 /* In conjunction with an ASMSPEC, the `register'
2873 keyword indicates that we should place the variable
2874 in a particular register. */
2875 if (DECL_REGISTER (decl))
2876 DECL_C_HARD_REGISTER (decl) = 1;
2878 /* If this is not a static variable, issue a warning.
2879 It doesn't make any sense to give an ASMSPEC for an
2880 ordinary, non-register local variable. Historically,
2881 GCC has accepted -- but ignored -- the ASMSPEC in
2882 this case. */
2883 if (TREE_CODE (decl) == VAR_DECL
2884 && !DECL_REGISTER (decl)
2885 && !TREE_STATIC (decl))
2886 warning ("%Jignoring asm-specifier for non-static local "
2887 "variable '%D'", decl, decl);
2888 else
2889 change_decl_assembler_name (decl, get_identifier (asmspec));
2892 if (TREE_CODE (decl) != FUNCTION_DECL)
2893 add_decl_stmt (decl);
2896 if (!DECL_FILE_SCOPE_P (decl))
2898 /* Recompute the RTL of a local array now
2899 if it used to be an incomplete type. */
2900 if (was_incomplete
2901 && ! TREE_STATIC (decl) && ! DECL_EXTERNAL (decl))
2903 /* If we used it already as memory, it must stay in memory. */
2904 TREE_ADDRESSABLE (decl) = TREE_USED (decl);
2905 /* If it's still incomplete now, no init will save it. */
2906 if (DECL_SIZE (decl) == 0)
2907 DECL_INITIAL (decl) = 0;
2912 /* If this was marked 'used', be sure it will be output. */
2913 if (lookup_attribute ("used", DECL_ATTRIBUTES (decl)))
2914 mark_referenced (DECL_ASSEMBLER_NAME (decl));
2916 if (TREE_CODE (decl) == TYPE_DECL)
2917 rest_of_decl_compilation (decl, NULL, DECL_FILE_SCOPE_P (decl), 0);
2919 /* At the end of a declaration, throw away any variable type sizes
2920 of types defined inside that declaration. There is no use
2921 computing them in the following function definition. */
2922 if (current_scope == global_scope)
2923 get_pending_sizes ();
2925 /* Install a cleanup (aka destructor) if one was given. */
2926 if (TREE_CODE (decl) == VAR_DECL && !TREE_STATIC (decl))
2928 tree attr = lookup_attribute ("cleanup", DECL_ATTRIBUTES (decl));
2929 if (attr)
2931 static bool eh_initialized_p;
2933 tree cleanup_id = TREE_VALUE (TREE_VALUE (attr));
2934 tree cleanup_decl = lookup_name (cleanup_id);
2935 tree cleanup;
2937 /* Build "cleanup(&decl)" for the destructor. */
2938 cleanup = build_unary_op (ADDR_EXPR, decl, 0);
2939 cleanup = build_tree_list (NULL_TREE, cleanup);
2940 cleanup = build_function_call (cleanup_decl, cleanup);
2942 /* Don't warn about decl unused; the cleanup uses it. */
2943 TREE_USED (decl) = 1;
2945 /* Initialize EH, if we've been told to do so. */
2946 if (flag_exceptions && !eh_initialized_p)
2948 eh_initialized_p = true;
2949 eh_personality_libfunc
2950 = init_one_libfunc (USING_SJLJ_EXCEPTIONS
2951 ? "__gcc_personality_sj0"
2952 : "__gcc_personality_v0");
2953 using_eh_for_cleanups ();
2956 add_stmt (build_stmt (CLEANUP_STMT, decl, cleanup));
2961 /* Given a parsed parameter declaration, decode it into a PARM_DECL
2962 and push that on the current scope. */
2964 void
2965 push_parm_decl (tree parm)
2967 tree decl;
2968 int old_dont_save_pending_sizes_p = 0;
2970 /* Don't attempt to expand sizes while parsing this decl.
2971 (We can get here with i_s_e 1 somehow from Objective-C.) */
2972 int save_immediate_size_expand = immediate_size_expand;
2973 immediate_size_expand = 0;
2975 /* If this is a nested function, we do want to keep SAVE_EXPRs for
2976 the argument sizes, regardless of the parent's setting. */
2977 if (cfun)
2979 old_dont_save_pending_sizes_p = cfun->x_dont_save_pending_sizes_p;
2980 cfun->x_dont_save_pending_sizes_p = 0;
2983 decl = grokdeclarator (TREE_VALUE (TREE_PURPOSE (parm)),
2984 TREE_PURPOSE (TREE_PURPOSE (parm)),
2985 PARM, 0, NULL);
2986 decl_attributes (&decl, TREE_VALUE (parm), 0);
2988 decl = pushdecl (decl);
2990 finish_decl (decl, NULL_TREE, NULL_TREE);
2992 if (cfun)
2993 cfun->x_dont_save_pending_sizes_p = old_dont_save_pending_sizes_p;
2994 immediate_size_expand = save_immediate_size_expand;
2997 /* Mark all the parameter declarations to date as forward decls,
2998 shift them to the variables list, and reset the parameters list.
2999 Also diagnose use of this extension. */
3001 void
3002 mark_forward_parm_decls (void)
3004 tree parm;
3006 if (pedantic && !current_scope->warned_forward_parm_decls)
3008 pedwarn ("ISO C forbids forward parameter declarations");
3009 current_scope->warned_forward_parm_decls = true;
3012 for (parm = current_scope->parms; parm; parm = TREE_CHAIN (parm))
3013 TREE_ASM_WRITTEN (parm) = 1;
3015 SCOPE_LIST_CONCAT (current_scope, names, current_scope, parms);
3016 current_scope->parms = 0;
3017 current_scope->parms_last = 0;
3020 static GTY(()) int compound_literal_number;
3022 /* Build a COMPOUND_LITERAL_EXPR. TYPE is the type given in the compound
3023 literal, which may be an incomplete array type completed by the
3024 initializer; INIT is a CONSTRUCTOR that initializes the compound
3025 literal. */
3027 tree
3028 build_compound_literal (tree type, tree init)
3030 /* We do not use start_decl here because we have a type, not a declarator;
3031 and do not use finish_decl because the decl should be stored inside
3032 the COMPOUND_LITERAL_EXPR rather than added elsewhere as a DECL_STMT. */
3033 tree decl = build_decl (VAR_DECL, NULL_TREE, type);
3034 tree complit;
3035 tree stmt;
3036 DECL_EXTERNAL (decl) = 0;
3037 TREE_PUBLIC (decl) = 0;
3038 TREE_STATIC (decl) = (current_scope == global_scope);
3039 DECL_CONTEXT (decl) = current_function_decl;
3040 TREE_USED (decl) = 1;
3041 TREE_TYPE (decl) = type;
3042 TREE_READONLY (decl) = TREE_READONLY (type);
3043 store_init_value (decl, init);
3045 if (TREE_CODE (type) == ARRAY_TYPE && !COMPLETE_TYPE_P (type))
3047 int failure = complete_array_type (type, DECL_INITIAL (decl), 1);
3048 if (failure)
3049 abort ();
3052 type = TREE_TYPE (decl);
3053 if (type == error_mark_node || !COMPLETE_TYPE_P (type))
3054 return error_mark_node;
3056 stmt = build_stmt (DECL_STMT, decl);
3057 complit = build1 (COMPOUND_LITERAL_EXPR, TREE_TYPE (decl), stmt);
3058 TREE_SIDE_EFFECTS (complit) = 1;
3060 layout_decl (decl, 0);
3062 if (TREE_STATIC (decl))
3064 /* This decl needs a name for the assembler output. We also need
3065 a unique suffix to be added to the name. */
3066 char *name;
3068 ASM_FORMAT_PRIVATE_NAME (name, "__compound_literal",
3069 compound_literal_number);
3070 compound_literal_number++;
3071 DECL_NAME (decl) = get_identifier (name);
3072 DECL_DEFER_OUTPUT (decl) = 1;
3073 DECL_COMDAT (decl) = 1;
3074 DECL_ARTIFICIAL (decl) = 1;
3075 pushdecl (decl);
3076 rest_of_decl_compilation (decl, NULL, 1, 0);
3079 return complit;
3082 /* Make TYPE a complete type based on INITIAL_VALUE.
3083 Return 0 if successful, 1 if INITIAL_VALUE can't be deciphered,
3084 2 if there was no information (in which case assume 1 if DO_DEFAULT). */
3087 complete_array_type (tree type, tree initial_value, int do_default)
3089 tree maxindex = NULL_TREE;
3090 int value = 0;
3092 if (initial_value)
3094 /* Note MAXINDEX is really the maximum index,
3095 one less than the size. */
3096 if (TREE_CODE (initial_value) == STRING_CST)
3098 int eltsize
3099 = int_size_in_bytes (TREE_TYPE (TREE_TYPE (initial_value)));
3100 maxindex = build_int_2 ((TREE_STRING_LENGTH (initial_value)
3101 / eltsize) - 1, 0);
3103 else if (TREE_CODE (initial_value) == CONSTRUCTOR)
3105 tree elts = CONSTRUCTOR_ELTS (initial_value);
3106 maxindex = build_int_2 (-1, -1);
3107 for (; elts; elts = TREE_CHAIN (elts))
3109 if (TREE_PURPOSE (elts))
3110 maxindex = TREE_PURPOSE (elts);
3111 else
3112 maxindex = fold (build (PLUS_EXPR, integer_type_node,
3113 maxindex, integer_one_node));
3115 maxindex = copy_node (maxindex);
3117 else
3119 /* Make an error message unless that happened already. */
3120 if (initial_value != error_mark_node)
3121 value = 1;
3123 /* Prevent further error messages. */
3124 maxindex = build_int_2 (0, 0);
3128 if (!maxindex)
3130 if (do_default)
3131 maxindex = build_int_2 (0, 0);
3132 value = 2;
3135 if (maxindex)
3137 TYPE_DOMAIN (type) = build_index_type (maxindex);
3138 if (!TREE_TYPE (maxindex))
3139 TREE_TYPE (maxindex) = TYPE_DOMAIN (type);
3142 /* Lay out the type now that we can get the real answer. */
3144 layout_type (type);
3146 return value;
3149 /* Determine whether TYPE is a structure with a flexible array member,
3150 or a union containing such a structure (possibly recursively). */
3152 static bool
3153 flexible_array_type_p (tree type)
3155 tree x;
3156 switch (TREE_CODE (type))
3158 case RECORD_TYPE:
3159 x = TYPE_FIELDS (type);
3160 if (x == NULL_TREE)
3161 return false;
3162 while (TREE_CHAIN (x) != NULL_TREE)
3163 x = TREE_CHAIN (x);
3164 if (TREE_CODE (TREE_TYPE (x)) == ARRAY_TYPE
3165 && TYPE_SIZE (TREE_TYPE (x)) == NULL_TREE
3166 && TYPE_DOMAIN (TREE_TYPE (x)) != NULL_TREE
3167 && TYPE_MAX_VALUE (TYPE_DOMAIN (TREE_TYPE (x))) == NULL_TREE)
3168 return true;
3169 return false;
3170 case UNION_TYPE:
3171 for (x = TYPE_FIELDS (type); x != NULL_TREE; x = TREE_CHAIN (x))
3173 if (flexible_array_type_p (TREE_TYPE (x)))
3174 return true;
3176 return false;
3177 default:
3178 return false;
3182 /* Performs sanity checks on the TYPE and WIDTH of the bit-field NAME,
3183 replacing with appropriate values if they are invalid. */
3184 static void
3185 check_bitfield_type_and_width (tree *type, tree *width, const char *orig_name)
3187 tree type_mv;
3188 unsigned int max_width;
3189 unsigned HOST_WIDE_INT w;
3190 const char *name = orig_name ? orig_name: _("<anonymous>");
3192 /* Necessary? */
3193 STRIP_NOPS (*width);
3195 /* Detect and ignore out of range field width and process valid
3196 field widths. */
3197 if (TREE_CODE (*width) != INTEGER_CST)
3199 error ("bit-field `%s' width not an integer constant", name);
3200 *width = integer_one_node;
3202 else
3204 constant_expression_warning (*width);
3205 if (tree_int_cst_sgn (*width) < 0)
3207 error ("negative width in bit-field `%s'", name);
3208 *width = integer_one_node;
3210 else if (integer_zerop (*width) && orig_name)
3212 error ("zero width for bit-field `%s'", name);
3213 *width = integer_one_node;
3217 /* Detect invalid bit-field type. */
3218 if (TREE_CODE (*type) != INTEGER_TYPE
3219 && TREE_CODE (*type) != BOOLEAN_TYPE
3220 && TREE_CODE (*type) != ENUMERAL_TYPE)
3222 error ("bit-field `%s' has invalid type", name);
3223 *type = unsigned_type_node;
3226 type_mv = TYPE_MAIN_VARIANT (*type);
3227 if (pedantic
3228 && type_mv != integer_type_node
3229 && type_mv != unsigned_type_node
3230 && type_mv != boolean_type_node)
3231 pedwarn ("type of bit-field `%s' is a GCC extension", name);
3233 if (type_mv == boolean_type_node)
3234 max_width = CHAR_TYPE_SIZE;
3235 else
3236 max_width = TYPE_PRECISION (*type);
3238 if (0 < compare_tree_int (*width, max_width))
3240 error ("width of `%s' exceeds its type", name);
3241 w = max_width;
3242 *width = build_int_2 (w, 0);
3244 else
3245 w = tree_low_cst (*width, 1);
3247 if (TREE_CODE (*type) == ENUMERAL_TYPE
3248 && (w < min_precision (TYPE_MIN_VALUE (*type), TREE_UNSIGNED (*type))
3249 || w < min_precision (TYPE_MAX_VALUE (*type), TREE_UNSIGNED (*type))))
3250 warning ("`%s' is narrower than values of its type", name);
3253 /* Given declspecs and a declarator,
3254 determine the name and type of the object declared
3255 and construct a ..._DECL node for it.
3256 (In one case we can return a ..._TYPE node instead.
3257 For invalid input we sometimes return 0.)
3259 DECLSPECS is a chain of tree_list nodes whose value fields
3260 are the storage classes and type specifiers.
3262 DECL_CONTEXT says which syntactic context this declaration is in:
3263 NORMAL for most contexts. Make a VAR_DECL or FUNCTION_DECL or TYPE_DECL.
3264 FUNCDEF for a function definition. Like NORMAL but a few different
3265 error messages in each case. Return value may be zero meaning
3266 this definition is too screwy to try to parse.
3267 PARM for a parameter declaration (either within a function prototype
3268 or before a function body). Make a PARM_DECL, or return void_type_node.
3269 TYPENAME if for a typename (in a cast or sizeof).
3270 Don't make a DECL node; just return the ..._TYPE node.
3271 FIELD for a struct or union field; make a FIELD_DECL.
3272 INITIALIZED is 1 if the decl has an initializer.
3273 WIDTH is non-NULL for bit-fields, and is a pointer to an INTEGER_CST node
3274 representing the width of the bit-field.
3276 In the TYPENAME case, DECLARATOR is really an absolute declarator.
3277 It may also be so in the PARM case, for a prototype where the
3278 argument type is specified but not the name.
3280 This function is where the complicated C meanings of `static'
3281 and `extern' are interpreted. */
3283 static tree
3284 grokdeclarator (tree declarator, tree declspecs,
3285 enum decl_context decl_context, int initialized, tree *width)
3287 int specbits = 0;
3288 tree spec;
3289 tree type = NULL_TREE;
3290 int longlong = 0;
3291 int constp;
3292 int restrictp;
3293 int volatilep;
3294 int type_quals = TYPE_UNQUALIFIED;
3295 int inlinep;
3296 int explicit_int = 0;
3297 int explicit_char = 0;
3298 int defaulted_int = 0;
3299 tree typedef_decl = 0;
3300 const char *name, *orig_name;
3301 tree typedef_type = 0;
3302 int funcdef_flag = 0;
3303 enum tree_code innermost_code = ERROR_MARK;
3304 int size_varies = 0;
3305 tree decl_attr = NULL_TREE;
3306 tree array_ptr_quals = NULL_TREE;
3307 int array_parm_static = 0;
3308 tree returned_attrs = NULL_TREE;
3309 bool bitfield = width != NULL;
3310 tree element_type;
3312 if (decl_context == FUNCDEF)
3313 funcdef_flag = 1, decl_context = NORMAL;
3315 /* Look inside a declarator for the name being declared
3316 and get it as a string, for an error message. */
3318 tree decl = declarator;
3319 name = 0;
3321 while (decl)
3322 switch (TREE_CODE (decl))
3324 case ARRAY_REF:
3325 case INDIRECT_REF:
3326 case CALL_EXPR:
3327 innermost_code = TREE_CODE (decl);
3328 decl = TREE_OPERAND (decl, 0);
3329 break;
3331 case TREE_LIST:
3332 decl = TREE_VALUE (decl);
3333 break;
3335 case IDENTIFIER_NODE:
3336 name = IDENTIFIER_POINTER (decl);
3337 decl = 0;
3338 break;
3340 default:
3341 abort ();
3343 orig_name = name;
3344 if (name == 0)
3345 name = "type name";
3348 /* A function definition's declarator must have the form of
3349 a function declarator. */
3351 if (funcdef_flag && innermost_code != CALL_EXPR)
3352 return 0;
3354 /* If this looks like a function definition, make it one,
3355 even if it occurs where parms are expected.
3356 Then store_parm_decls will reject it and not use it as a parm. */
3357 if (decl_context == NORMAL && !funcdef_flag
3358 && current_scope->parm_flag)
3359 decl_context = PARM;
3361 /* Look through the decl specs and record which ones appear.
3362 Some typespecs are defined as built-in typenames.
3363 Others, the ones that are modifiers of other types,
3364 are represented by bits in SPECBITS: set the bits for
3365 the modifiers that appear. Storage class keywords are also in SPECBITS.
3367 If there is a typedef name or a type, store the type in TYPE.
3368 This includes builtin typedefs such as `int'.
3370 Set EXPLICIT_INT or EXPLICIT_CHAR if the type is `int' or `char'
3371 and did not come from a user typedef.
3373 Set LONGLONG if `long' is mentioned twice. */
3375 for (spec = declspecs; spec; spec = TREE_CHAIN (spec))
3377 tree id = TREE_VALUE (spec);
3379 /* If the entire declaration is itself tagged as deprecated then
3380 suppress reports of deprecated items. */
3381 if (id && TREE_DEPRECATED (id))
3383 if (deprecated_state != DEPRECATED_SUPPRESS)
3384 warn_deprecated_use (id);
3387 if (id == ridpointers[(int) RID_INT])
3388 explicit_int = 1;
3389 if (id == ridpointers[(int) RID_CHAR])
3390 explicit_char = 1;
3392 if (TREE_CODE (id) == IDENTIFIER_NODE && C_IS_RESERVED_WORD (id))
3394 enum rid i = C_RID_CODE (id);
3395 if ((int) i <= (int) RID_LAST_MODIFIER)
3397 if (i == RID_LONG && (specbits & (1 << (int) RID_LONG)))
3399 if (longlong)
3400 error ("`long long long' is too long for GCC");
3401 else
3403 if (pedantic && !flag_isoc99 && ! in_system_header
3404 && warn_long_long)
3405 pedwarn ("ISO C90 does not support `long long'");
3406 longlong = 1;
3409 else if (specbits & (1 << (int) i))
3411 if (i == RID_CONST || i == RID_VOLATILE || i == RID_RESTRICT)
3413 if (pedantic && !flag_isoc99)
3414 pedwarn ("duplicate `%s'", IDENTIFIER_POINTER (id));
3416 else
3417 error ("duplicate `%s'", IDENTIFIER_POINTER (id));
3420 /* Diagnose "__thread extern". Recall that this list
3421 is in the reverse order seen in the text. */
3422 if (i == RID_THREAD
3423 && (specbits & (1 << (int) RID_EXTERN
3424 | 1 << (int) RID_STATIC)))
3426 if (specbits & 1 << (int) RID_EXTERN)
3427 error ("`__thread' before `extern'");
3428 else
3429 error ("`__thread' before `static'");
3432 specbits |= 1 << (int) i;
3433 goto found;
3436 if (type)
3437 error ("two or more data types in declaration of `%s'", name);
3438 /* Actual typedefs come to us as TYPE_DECL nodes. */
3439 else if (TREE_CODE (id) == TYPE_DECL)
3441 if (TREE_TYPE (id) == error_mark_node)
3442 ; /* Allow the type to default to int to avoid cascading errors. */
3443 else
3445 type = TREE_TYPE (id);
3446 decl_attr = DECL_ATTRIBUTES (id);
3447 typedef_decl = id;
3450 /* Built-in types come as identifiers. */
3451 else if (TREE_CODE (id) == IDENTIFIER_NODE)
3453 tree t = lookup_name (id);
3454 if (TREE_TYPE (t) == error_mark_node)
3456 else if (!t || TREE_CODE (t) != TYPE_DECL)
3457 error ("`%s' fails to be a typedef or built in type",
3458 IDENTIFIER_POINTER (id));
3459 else
3461 type = TREE_TYPE (t);
3462 typedef_decl = t;
3465 else if (TREE_CODE (id) != ERROR_MARK)
3466 type = id;
3468 found:
3472 typedef_type = type;
3473 if (type)
3474 size_varies = C_TYPE_VARIABLE_SIZE (type);
3476 /* No type at all: default to `int', and set DEFAULTED_INT
3477 because it was not a user-defined typedef. */
3479 if (type == 0)
3481 if ((! (specbits & ((1 << (int) RID_LONG) | (1 << (int) RID_SHORT)
3482 | (1 << (int) RID_SIGNED)
3483 | (1 << (int) RID_UNSIGNED)
3484 | (1 << (int) RID_COMPLEX))))
3485 /* Don't warn about typedef foo = bar. */
3486 && ! (specbits & (1 << (int) RID_TYPEDEF) && initialized)
3487 && ! in_system_header)
3489 /* Issue a warning if this is an ISO C 99 program or if -Wreturn-type
3490 and this is a function, or if -Wimplicit; prefer the former
3491 warning since it is more explicit. */
3492 if ((warn_implicit_int || warn_return_type || flag_isoc99)
3493 && funcdef_flag)
3494 warn_about_return_type = 1;
3495 else if (warn_implicit_int || flag_isoc99)
3496 pedwarn_c99 ("type defaults to `int' in declaration of `%s'",
3497 name);
3500 defaulted_int = 1;
3501 type = integer_type_node;
3504 /* Now process the modifiers that were specified
3505 and check for invalid combinations. */
3507 /* Long double is a special combination. */
3509 if ((specbits & 1 << (int) RID_LONG) && ! longlong
3510 && TYPE_MAIN_VARIANT (type) == double_type_node)
3512 specbits &= ~(1 << (int) RID_LONG);
3513 type = long_double_type_node;
3516 /* Check all other uses of type modifiers. */
3518 if (specbits & ((1 << (int) RID_LONG) | (1 << (int) RID_SHORT)
3519 | (1 << (int) RID_UNSIGNED) | (1 << (int) RID_SIGNED)))
3521 int ok = 0;
3523 if ((specbits & 1 << (int) RID_LONG)
3524 && (specbits & 1 << (int) RID_SHORT))
3525 error ("both long and short specified for `%s'", name);
3526 else if (((specbits & 1 << (int) RID_LONG)
3527 || (specbits & 1 << (int) RID_SHORT))
3528 && explicit_char)
3529 error ("long or short specified with char for `%s'", name);
3530 else if (((specbits & 1 << (int) RID_LONG)
3531 || (specbits & 1 << (int) RID_SHORT))
3532 && TREE_CODE (type) == REAL_TYPE)
3534 static int already = 0;
3536 error ("long or short specified with floating type for `%s'", name);
3537 if (! already && ! pedantic)
3539 error ("the only valid combination is `long double'");
3540 already = 1;
3543 else if ((specbits & 1 << (int) RID_SIGNED)
3544 && (specbits & 1 << (int) RID_UNSIGNED))
3545 error ("both signed and unsigned specified for `%s'", name);
3546 else if (TREE_CODE (type) != INTEGER_TYPE)
3547 error ("long, short, signed or unsigned invalid for `%s'", name);
3548 else
3550 ok = 1;
3551 if (!explicit_int && !defaulted_int && !explicit_char)
3553 error ("long, short, signed or unsigned used invalidly for `%s'",
3554 name);
3555 ok = 0;
3559 /* Discard the type modifiers if they are invalid. */
3560 if (! ok)
3562 specbits &= ~((1 << (int) RID_LONG) | (1 << (int) RID_SHORT)
3563 | (1 << (int) RID_UNSIGNED) | (1 << (int) RID_SIGNED));
3564 longlong = 0;
3568 if ((specbits & (1 << (int) RID_COMPLEX))
3569 && TREE_CODE (type) != INTEGER_TYPE && TREE_CODE (type) != REAL_TYPE)
3571 error ("complex invalid for `%s'", name);
3572 specbits &= ~(1 << (int) RID_COMPLEX);
3575 /* Decide whether an integer type is signed or not.
3576 Optionally treat bit-fields as signed by default. */
3577 if (specbits & 1 << (int) RID_UNSIGNED
3578 || (bitfield && ! flag_signed_bitfields
3579 && (explicit_int || defaulted_int || explicit_char
3580 /* A typedef for plain `int' without `signed'
3581 can be controlled just like plain `int'. */
3582 || ! (typedef_decl != 0
3583 && C_TYPEDEF_EXPLICITLY_SIGNED (typedef_decl)))
3584 && TREE_CODE (type) != ENUMERAL_TYPE
3585 && !(specbits & 1 << (int) RID_SIGNED)))
3587 if (longlong)
3588 type = long_long_unsigned_type_node;
3589 else if (specbits & 1 << (int) RID_LONG)
3590 type = long_unsigned_type_node;
3591 else if (specbits & 1 << (int) RID_SHORT)
3592 type = short_unsigned_type_node;
3593 else if (type == char_type_node)
3594 type = unsigned_char_type_node;
3595 else if (typedef_decl)
3596 type = c_common_unsigned_type (type);
3597 else
3598 type = unsigned_type_node;
3600 else if ((specbits & 1 << (int) RID_SIGNED)
3601 && type == char_type_node)
3602 type = signed_char_type_node;
3603 else if (longlong)
3604 type = long_long_integer_type_node;
3605 else if (specbits & 1 << (int) RID_LONG)
3606 type = long_integer_type_node;
3607 else if (specbits & 1 << (int) RID_SHORT)
3608 type = short_integer_type_node;
3610 if (specbits & 1 << (int) RID_COMPLEX)
3612 if (pedantic && !flag_isoc99)
3613 pedwarn ("ISO C90 does not support complex types");
3614 /* If we just have "complex", it is equivalent to
3615 "complex double", but if any modifiers at all are specified it is
3616 the complex form of TYPE. E.g, "complex short" is
3617 "complex short int". */
3619 if (defaulted_int && ! longlong
3620 && ! (specbits & ((1 << (int) RID_LONG) | (1 << (int) RID_SHORT)
3621 | (1 << (int) RID_SIGNED)
3622 | (1 << (int) RID_UNSIGNED))))
3624 if (pedantic)
3625 pedwarn ("ISO C does not support plain `complex' meaning `double complex'");
3626 type = complex_double_type_node;
3628 else if (type == integer_type_node)
3630 if (pedantic)
3631 pedwarn ("ISO C does not support complex integer types");
3632 type = complex_integer_type_node;
3634 else if (type == float_type_node)
3635 type = complex_float_type_node;
3636 else if (type == double_type_node)
3637 type = complex_double_type_node;
3638 else if (type == long_double_type_node)
3639 type = complex_long_double_type_node;
3640 else
3642 if (pedantic)
3643 pedwarn ("ISO C does not support complex integer types");
3644 type = build_complex_type (type);
3648 /* Figure out the type qualifiers for the declaration. There are
3649 two ways a declaration can become qualified. One is something
3650 like `const int i' where the `const' is explicit. Another is
3651 something like `typedef const int CI; CI i' where the type of the
3652 declaration contains the `const'. A third possibility is that
3653 there is a type qualifier on the element type of a typedefed
3654 array type, in which case we should extract that qualifier so
3655 that c_apply_type_quals_to_decls receives the full list of
3656 qualifiers to work with (C90 is not entirely clear about whether
3657 duplicate qualifiers should be diagnosed in this case, but it
3658 seems most appropriate to do so). */
3659 element_type = strip_array_types (type);
3660 constp = !! (specbits & 1 << (int) RID_CONST) + TYPE_READONLY (element_type);
3661 restrictp
3662 = !! (specbits & 1 << (int) RID_RESTRICT) + TYPE_RESTRICT (element_type);
3663 volatilep
3664 = !! (specbits & 1 << (int) RID_VOLATILE) + TYPE_VOLATILE (element_type);
3665 inlinep = !! (specbits & (1 << (int) RID_INLINE));
3666 if (pedantic && !flag_isoc99)
3668 if (constp > 1)
3669 pedwarn ("duplicate `const'");
3670 if (restrictp > 1)
3671 pedwarn ("duplicate `restrict'");
3672 if (volatilep > 1)
3673 pedwarn ("duplicate `volatile'");
3675 if (! flag_gen_aux_info && (TYPE_QUALS (type)))
3676 type = TYPE_MAIN_VARIANT (type);
3677 type_quals = ((constp ? TYPE_QUAL_CONST : 0)
3678 | (restrictp ? TYPE_QUAL_RESTRICT : 0)
3679 | (volatilep ? TYPE_QUAL_VOLATILE : 0));
3681 /* Warn if two storage classes are given. Default to `auto'. */
3684 int nclasses = 0;
3686 if (specbits & 1 << (int) RID_AUTO) nclasses++;
3687 if (specbits & 1 << (int) RID_STATIC) nclasses++;
3688 if (specbits & 1 << (int) RID_EXTERN) nclasses++;
3689 if (specbits & 1 << (int) RID_REGISTER) nclasses++;
3690 if (specbits & 1 << (int) RID_TYPEDEF) nclasses++;
3692 /* "static __thread" and "extern __thread" are allowed. */
3693 if ((specbits & (1 << (int) RID_THREAD
3694 | 1 << (int) RID_STATIC
3695 | 1 << (int) RID_EXTERN)) == (1 << (int) RID_THREAD))
3696 nclasses++;
3698 /* Warn about storage classes that are invalid for certain
3699 kinds of declarations (parameters, typenames, etc.). */
3701 if (nclasses > 1)
3702 error ("multiple storage classes in declaration of `%s'", name);
3703 else if (funcdef_flag
3704 && (specbits
3705 & ((1 << (int) RID_REGISTER)
3706 | (1 << (int) RID_AUTO)
3707 | (1 << (int) RID_TYPEDEF)
3708 | (1 << (int) RID_THREAD))))
3710 if (specbits & 1 << (int) RID_AUTO
3711 && (pedantic || current_scope == global_scope))
3712 pedwarn ("function definition declared `auto'");
3713 if (specbits & 1 << (int) RID_REGISTER)
3714 error ("function definition declared `register'");
3715 if (specbits & 1 << (int) RID_TYPEDEF)
3716 error ("function definition declared `typedef'");
3717 if (specbits & 1 << (int) RID_THREAD)
3718 error ("function definition declared `__thread'");
3719 specbits &= ~((1 << (int) RID_TYPEDEF) | (1 << (int) RID_REGISTER)
3720 | (1 << (int) RID_AUTO) | (1 << (int) RID_THREAD));
3722 else if (decl_context != NORMAL && nclasses > 0)
3724 if (decl_context == PARM && specbits & 1 << (int) RID_REGISTER)
3726 else
3728 switch (decl_context)
3730 case FIELD:
3731 error ("storage class specified for structure field `%s'",
3732 name);
3733 break;
3734 case PARM:
3735 error ("storage class specified for parameter `%s'", name);
3736 break;
3737 default:
3738 error ("storage class specified for typename");
3739 break;
3741 specbits &= ~((1 << (int) RID_TYPEDEF) | (1 << (int) RID_REGISTER)
3742 | (1 << (int) RID_AUTO) | (1 << (int) RID_STATIC)
3743 | (1 << (int) RID_EXTERN) | (1 << (int) RID_THREAD));
3746 else if (specbits & 1 << (int) RID_EXTERN && initialized && ! funcdef_flag)
3748 /* `extern' with initialization is invalid if not at file scope. */
3749 if (current_scope == global_scope)
3750 warning ("`%s' initialized and declared `extern'", name);
3751 else
3752 error ("`%s' has both `extern' and initializer", name);
3754 else if (current_scope == global_scope)
3756 if (specbits & 1 << (int) RID_AUTO)
3757 error ("file-scope declaration of `%s' specifies `auto'", name);
3759 else
3761 if (specbits & 1 << (int) RID_EXTERN && funcdef_flag)
3762 error ("nested function `%s' declared `extern'", name);
3763 else if ((specbits & (1 << (int) RID_THREAD
3764 | 1 << (int) RID_EXTERN
3765 | 1 << (int) RID_STATIC))
3766 == (1 << (int) RID_THREAD))
3768 error ("function-scope `%s' implicitly auto and declared `__thread'",
3769 name);
3770 specbits &= ~(1 << (int) RID_THREAD);
3775 /* Now figure out the structure of the declarator proper.
3776 Descend through it, creating more complex types, until we reach
3777 the declared identifier (or NULL_TREE, in an absolute declarator). */
3779 while (declarator && TREE_CODE (declarator) != IDENTIFIER_NODE)
3781 if (type == error_mark_node)
3783 declarator = TREE_OPERAND (declarator, 0);
3784 continue;
3787 /* Each level of DECLARATOR is either an ARRAY_REF (for ...[..]),
3788 an INDIRECT_REF (for *...),
3789 a CALL_EXPR (for ...(...)),
3790 a TREE_LIST (for nested attributes),
3791 an identifier (for the name being declared)
3792 or a null pointer (for the place in an absolute declarator
3793 where the name was omitted).
3794 For the last two cases, we have just exited the loop.
3796 At this point, TYPE is the type of elements of an array,
3797 or for a function to return, or for a pointer to point to.
3798 After this sequence of ifs, TYPE is the type of the
3799 array or function or pointer, and DECLARATOR has had its
3800 outermost layer removed. */
3802 if (array_ptr_quals != NULL_TREE || array_parm_static)
3804 /* Only the innermost declarator (making a parameter be of
3805 array type which is converted to pointer type)
3806 may have static or type qualifiers. */
3807 error ("static or type qualifiers in non-parameter array declarator");
3808 array_ptr_quals = NULL_TREE;
3809 array_parm_static = 0;
3812 if (TREE_CODE (declarator) == TREE_LIST)
3814 /* We encode a declarator with embedded attributes using
3815 a TREE_LIST. */
3816 tree attrs = TREE_PURPOSE (declarator);
3817 tree inner_decl;
3818 int attr_flags = 0;
3819 declarator = TREE_VALUE (declarator);
3820 inner_decl = declarator;
3821 while (inner_decl != NULL_TREE
3822 && TREE_CODE (inner_decl) == TREE_LIST)
3823 inner_decl = TREE_VALUE (inner_decl);
3824 if (inner_decl == NULL_TREE
3825 || TREE_CODE (inner_decl) == IDENTIFIER_NODE)
3826 attr_flags |= (int) ATTR_FLAG_DECL_NEXT;
3827 else if (TREE_CODE (inner_decl) == CALL_EXPR)
3828 attr_flags |= (int) ATTR_FLAG_FUNCTION_NEXT;
3829 else if (TREE_CODE (inner_decl) == ARRAY_REF)
3830 attr_flags |= (int) ATTR_FLAG_ARRAY_NEXT;
3831 returned_attrs = decl_attributes (&type,
3832 chainon (returned_attrs, attrs),
3833 attr_flags);
3835 else if (TREE_CODE (declarator) == ARRAY_REF)
3837 tree itype = NULL_TREE;
3838 tree size = TREE_OPERAND (declarator, 1);
3839 /* The index is a signed object `sizetype' bits wide. */
3840 tree index_type = c_common_signed_type (sizetype);
3842 array_ptr_quals = TREE_TYPE (declarator);
3843 array_parm_static = TREE_STATIC (declarator);
3845 declarator = TREE_OPERAND (declarator, 0);
3847 /* Check for some types that there cannot be arrays of. */
3849 if (VOID_TYPE_P (type))
3851 error ("declaration of `%s' as array of voids", name);
3852 type = error_mark_node;
3855 if (TREE_CODE (type) == FUNCTION_TYPE)
3857 error ("declaration of `%s' as array of functions", name);
3858 type = error_mark_node;
3861 if (pedantic && !in_system_header && flexible_array_type_p (type))
3862 pedwarn ("invalid use of structure with flexible array member");
3864 if (size == error_mark_node)
3865 type = error_mark_node;
3867 if (type == error_mark_node)
3868 continue;
3870 /* If size was specified, set ITYPE to a range-type for that size.
3871 Otherwise, ITYPE remains null. finish_decl may figure it out
3872 from an initial value. */
3874 if (size)
3876 /* Strip NON_LVALUE_EXPRs since we aren't using as an lvalue. */
3877 STRIP_TYPE_NOPS (size);
3879 if (! INTEGRAL_TYPE_P (TREE_TYPE (size)))
3881 error ("size of array `%s' has non-integer type", name);
3882 size = integer_one_node;
3885 if (pedantic && integer_zerop (size))
3886 pedwarn ("ISO C forbids zero-size array `%s'", name);
3888 if (TREE_CODE (size) == INTEGER_CST)
3890 constant_expression_warning (size);
3891 if (tree_int_cst_sgn (size) < 0)
3893 error ("size of array `%s' is negative", name);
3894 size = integer_one_node;
3897 else
3899 /* Make sure the array size remains visibly nonconstant
3900 even if it is (eg) a const variable with known value. */
3901 size_varies = 1;
3903 if (!flag_isoc99 && pedantic)
3905 if (TREE_CONSTANT (size))
3906 pedwarn ("ISO C90 forbids array `%s' whose size can't be evaluated",
3907 name);
3908 else
3909 pedwarn ("ISO C90 forbids variable-size array `%s'",
3910 name);
3914 if (integer_zerop (size))
3916 /* A zero-length array cannot be represented with an
3917 unsigned index type, which is what we'll get with
3918 build_index_type. Create an open-ended range instead. */
3919 itype = build_range_type (sizetype, size, NULL_TREE);
3921 else
3923 /* Compute the maximum valid index, that is, size - 1.
3924 Do the calculation in index_type, so that if it is
3925 a variable the computations will be done in the
3926 proper mode. */
3927 itype = fold (build (MINUS_EXPR, index_type,
3928 convert (index_type, size),
3929 convert (index_type, size_one_node)));
3931 /* If that overflowed, the array is too big.
3932 ??? While a size of INT_MAX+1 technically shouldn't
3933 cause an overflow (because we subtract 1), the overflow
3934 is recorded during the conversion to index_type, before
3935 the subtraction. Handling this case seems like an
3936 unnecessary complication. */
3937 if (TREE_OVERFLOW (itype))
3939 error ("size of array `%s' is too large", name);
3940 type = error_mark_node;
3941 continue;
3944 if (size_varies)
3946 /* We must be able to distinguish the
3947 SAVE_EXPR_CONTEXT for the variably-sized type
3948 so that we can set it correctly in
3949 set_save_expr_context. The convention is
3950 that all SAVE_EXPRs that need to be reset
3951 have NULL_TREE for their SAVE_EXPR_CONTEXT. */
3952 tree cfd = current_function_decl;
3953 if (decl_context == PARM)
3954 current_function_decl = NULL_TREE;
3955 itype = variable_size (itype);
3956 if (decl_context == PARM)
3957 current_function_decl = cfd;
3959 itype = build_index_type (itype);
3962 else if (decl_context == FIELD)
3964 if (pedantic && !flag_isoc99 && !in_system_header)
3965 pedwarn ("ISO C90 does not support flexible array members");
3967 /* ISO C99 Flexible array members are effectively identical
3968 to GCC's zero-length array extension. */
3969 itype = build_range_type (sizetype, size_zero_node, NULL_TREE);
3972 /* If pedantic, complain about arrays of incomplete types. */
3974 if (pedantic && !COMPLETE_TYPE_P (type))
3975 pedwarn ("array type has incomplete element type");
3977 /* Build the array type itself, then merge any constancy or
3978 volatility into the target type. We must do it in this order
3979 to ensure that the TYPE_MAIN_VARIANT field of the array type
3980 is set correctly. */
3982 type = build_array_type (type, itype);
3983 if (type_quals)
3984 type = c_build_qualified_type (type, type_quals);
3986 if (size_varies)
3987 C_TYPE_VARIABLE_SIZE (type) = 1;
3989 /* The GCC extension for zero-length arrays differs from
3990 ISO flexible array members in that sizeof yields zero. */
3991 if (size && integer_zerop (size))
3993 layout_type (type);
3994 TYPE_SIZE (type) = bitsize_zero_node;
3995 TYPE_SIZE_UNIT (type) = size_zero_node;
3997 if (decl_context != PARM
3998 && (array_ptr_quals != NULL_TREE || array_parm_static))
4000 error ("static or type qualifiers in non-parameter array declarator");
4001 array_ptr_quals = NULL_TREE;
4002 array_parm_static = 0;
4005 else if (TREE_CODE (declarator) == CALL_EXPR)
4007 /* Say it's a definition only for the declarator closest to
4008 the identifier, apart possibly from some attributes. */
4009 bool really_funcdef = false;
4010 tree arg_types;
4011 if (funcdef_flag)
4013 tree t = TREE_OPERAND (declarator, 0);
4014 while (TREE_CODE (t) == TREE_LIST)
4015 t = TREE_VALUE (t);
4016 really_funcdef = (TREE_CODE (t) == IDENTIFIER_NODE);
4019 /* Declaring a function type.
4020 Make sure we have a valid type for the function to return. */
4021 if (type == error_mark_node)
4022 continue;
4024 size_varies = 0;
4026 /* Warn about some types functions can't return. */
4028 if (TREE_CODE (type) == FUNCTION_TYPE)
4030 error ("`%s' declared as function returning a function", name);
4031 type = integer_type_node;
4033 if (TREE_CODE (type) == ARRAY_TYPE)
4035 error ("`%s' declared as function returning an array", name);
4036 type = integer_type_node;
4039 /* Construct the function type and go to the next
4040 inner layer of declarator. */
4042 arg_types = grokparms (TREE_OPERAND (declarator, 1),
4043 really_funcdef);
4044 /* Type qualifiers before the return type of the function
4045 qualify the return type, not the function type. */
4046 if (type_quals)
4048 /* Type qualifiers on a function return type are normally
4049 permitted by the standard but have no effect, so give a
4050 warning at -Wextra. Qualifiers on a void return type have
4051 meaning as a GNU extension, and are banned on function
4052 definitions in ISO C. FIXME: strictly we shouldn't
4053 pedwarn for qualified void return types except on function
4054 definitions, but not doing so could lead to the undesirable
4055 state of a "volatile void" function return type not being
4056 warned about, and a use of the function being compiled
4057 with GNU semantics, with no diagnostics under -pedantic. */
4058 if (VOID_TYPE_P (type) && pedantic && !in_system_header)
4059 pedwarn ("ISO C forbids qualified void function return type");
4060 else if (extra_warnings
4061 && !(VOID_TYPE_P (type)
4062 && type_quals == TYPE_QUAL_VOLATILE))
4063 warning ("type qualifiers ignored on function return type");
4065 type = c_build_qualified_type (type, type_quals);
4067 type_quals = TYPE_UNQUALIFIED;
4069 type = build_function_type (type, arg_types);
4070 declarator = TREE_OPERAND (declarator, 0);
4072 /* Set the TYPE_CONTEXTs for each tagged type which is local to
4073 the formal parameter list of this FUNCTION_TYPE to point to
4074 the FUNCTION_TYPE node itself. */
4077 tree link;
4079 for (link = last_function_parm_tags;
4080 link;
4081 link = TREE_CHAIN (link))
4082 TYPE_CONTEXT (TREE_VALUE (link)) = type;
4085 else if (TREE_CODE (declarator) == INDIRECT_REF)
4087 /* Merge any constancy or volatility into the target type
4088 for the pointer. */
4090 if (pedantic && TREE_CODE (type) == FUNCTION_TYPE
4091 && type_quals)
4092 pedwarn ("ISO C forbids qualified function types");
4093 if (type_quals)
4094 type = c_build_qualified_type (type, type_quals);
4095 type_quals = TYPE_UNQUALIFIED;
4096 size_varies = 0;
4098 type = build_pointer_type (type);
4100 /* Process a list of type modifier keywords
4101 (such as const or volatile) that were given inside the `*'. */
4103 if (TREE_TYPE (declarator))
4105 tree typemodlist;
4106 int erred = 0;
4108 constp = 0;
4109 volatilep = 0;
4110 restrictp = 0;
4111 for (typemodlist = TREE_TYPE (declarator); typemodlist;
4112 typemodlist = TREE_CHAIN (typemodlist))
4114 tree qualifier = TREE_VALUE (typemodlist);
4116 if (C_IS_RESERVED_WORD (qualifier))
4118 if (C_RID_CODE (qualifier) == RID_CONST)
4119 constp++;
4120 else if (C_RID_CODE (qualifier) == RID_VOLATILE)
4121 volatilep++;
4122 else if (C_RID_CODE (qualifier) == RID_RESTRICT)
4123 restrictp++;
4124 else
4125 erred++;
4127 else
4128 erred++;
4131 if (erred)
4132 error ("invalid type modifier within pointer declarator");
4133 if (pedantic && !flag_isoc99)
4135 if (constp > 1)
4136 pedwarn ("duplicate `const'");
4137 if (volatilep > 1)
4138 pedwarn ("duplicate `volatile'");
4139 if (restrictp > 1)
4140 pedwarn ("duplicate `restrict'");
4143 type_quals = ((constp ? TYPE_QUAL_CONST : 0)
4144 | (restrictp ? TYPE_QUAL_RESTRICT : 0)
4145 | (volatilep ? TYPE_QUAL_VOLATILE : 0));
4148 declarator = TREE_OPERAND (declarator, 0);
4150 else
4151 abort ();
4155 /* Now TYPE has the actual type. */
4157 /* Check the type and width of a bit-field. */
4158 if (bitfield)
4159 check_bitfield_type_and_width (&type, width, orig_name);
4161 /* Did array size calculations overflow? */
4163 if (TREE_CODE (type) == ARRAY_TYPE
4164 && COMPLETE_TYPE_P (type)
4165 && TREE_OVERFLOW (TYPE_SIZE (type)))
4167 error ("size of array `%s' is too large", name);
4168 /* If we proceed with the array type as it is, we'll eventually
4169 crash in tree_low_cst(). */
4170 type = error_mark_node;
4173 /* If this is declaring a typedef name, return a TYPE_DECL. */
4175 if (specbits & (1 << (int) RID_TYPEDEF))
4177 tree decl;
4178 /* Note that the grammar rejects storage classes
4179 in typenames, fields or parameters */
4180 if (pedantic && TREE_CODE (type) == FUNCTION_TYPE
4181 && type_quals)
4182 pedwarn ("ISO C forbids qualified function types");
4183 if (type_quals)
4184 type = c_build_qualified_type (type, type_quals);
4185 decl = build_decl (TYPE_DECL, declarator, type);
4186 if ((specbits & (1 << (int) RID_SIGNED))
4187 || (typedef_decl && C_TYPEDEF_EXPLICITLY_SIGNED (typedef_decl)))
4188 C_TYPEDEF_EXPLICITLY_SIGNED (decl) = 1;
4189 decl_attributes (&decl, returned_attrs, 0);
4190 return decl;
4193 /* Detect the case of an array type of unspecified size
4194 which came, as such, direct from a typedef name.
4195 We must copy the type, so that each identifier gets
4196 a distinct type, so that each identifier's size can be
4197 controlled separately by its own initializer. */
4199 if (type != 0 && typedef_type != 0
4200 && TREE_CODE (type) == ARRAY_TYPE && TYPE_DOMAIN (type) == 0
4201 && TYPE_MAIN_VARIANT (type) == TYPE_MAIN_VARIANT (typedef_type))
4203 type = build_array_type (TREE_TYPE (type), 0);
4204 if (size_varies)
4205 C_TYPE_VARIABLE_SIZE (type) = 1;
4208 /* If this is a type name (such as, in a cast or sizeof),
4209 compute the type and return it now. */
4211 if (decl_context == TYPENAME)
4213 /* Note that the grammar rejects storage classes
4214 in typenames, fields or parameters */
4215 if (pedantic && TREE_CODE (type) == FUNCTION_TYPE
4216 && type_quals)
4217 pedwarn ("ISO C forbids const or volatile function types");
4218 if (type_quals)
4219 type = c_build_qualified_type (type, type_quals);
4220 decl_attributes (&type, returned_attrs, 0);
4221 return type;
4224 /* Aside from typedefs and type names (handle above),
4225 `void' at top level (not within pointer)
4226 is allowed only in public variables.
4227 We don't complain about parms either, but that is because
4228 a better error message can be made later. */
4230 if (VOID_TYPE_P (type) && decl_context != PARM
4231 && ! ((decl_context != FIELD && TREE_CODE (type) != FUNCTION_TYPE)
4232 && ((specbits & (1 << (int) RID_EXTERN))
4233 || (current_scope == global_scope
4234 && !(specbits
4235 & ((1 << (int) RID_STATIC) | (1 << (int) RID_REGISTER)))))))
4237 error ("variable or field `%s' declared void", name);
4238 type = integer_type_node;
4241 /* Now create the decl, which may be a VAR_DECL, a PARM_DECL
4242 or a FUNCTION_DECL, depending on DECL_CONTEXT and TYPE. */
4245 tree decl;
4247 if (decl_context == PARM)
4249 tree type_as_written;
4250 tree promoted_type;
4252 /* A parameter declared as an array of T is really a pointer to T.
4253 One declared as a function is really a pointer to a function. */
4255 if (TREE_CODE (type) == ARRAY_TYPE)
4257 /* Transfer const-ness of array into that of type pointed to. */
4258 type = TREE_TYPE (type);
4259 if (type_quals)
4260 type = c_build_qualified_type (type, type_quals);
4261 type = build_pointer_type (type);
4262 type_quals = TYPE_UNQUALIFIED;
4263 if (array_ptr_quals)
4265 tree new_ptr_quals, new_ptr_attrs;
4266 int erred = 0;
4267 split_specs_attrs (array_ptr_quals, &new_ptr_quals, &new_ptr_attrs);
4268 /* We don't yet implement attributes in this context. */
4269 if (new_ptr_attrs != NULL_TREE)
4270 warning ("attributes in parameter array declarator ignored");
4272 constp = 0;
4273 volatilep = 0;
4274 restrictp = 0;
4275 for (; new_ptr_quals; new_ptr_quals = TREE_CHAIN (new_ptr_quals))
4277 tree qualifier = TREE_VALUE (new_ptr_quals);
4279 if (C_IS_RESERVED_WORD (qualifier))
4281 if (C_RID_CODE (qualifier) == RID_CONST)
4282 constp++;
4283 else if (C_RID_CODE (qualifier) == RID_VOLATILE)
4284 volatilep++;
4285 else if (C_RID_CODE (qualifier) == RID_RESTRICT)
4286 restrictp++;
4287 else
4288 erred++;
4290 else
4291 erred++;
4294 if (erred)
4295 error ("invalid type modifier within array declarator");
4297 type_quals = ((constp ? TYPE_QUAL_CONST : 0)
4298 | (restrictp ? TYPE_QUAL_RESTRICT : 0)
4299 | (volatilep ? TYPE_QUAL_VOLATILE : 0));
4301 size_varies = 0;
4303 else if (TREE_CODE (type) == FUNCTION_TYPE)
4305 if (pedantic && type_quals)
4306 pedwarn ("ISO C forbids qualified function types");
4307 if (type_quals)
4308 type = c_build_qualified_type (type, type_quals);
4309 type = build_pointer_type (type);
4310 type_quals = TYPE_UNQUALIFIED;
4312 else if (type_quals)
4313 type = c_build_qualified_type (type, type_quals);
4315 type_as_written = type;
4317 decl = build_decl (PARM_DECL, declarator, type);
4318 if (size_varies)
4319 C_DECL_VARIABLE_SIZE (decl) = 1;
4321 /* Compute the type actually passed in the parmlist,
4322 for the case where there is no prototype.
4323 (For example, shorts and chars are passed as ints.)
4324 When there is a prototype, this is overridden later. */
4326 if (type == error_mark_node)
4327 promoted_type = type;
4328 else
4329 promoted_type = c_type_promotes_to (type);
4331 DECL_ARG_TYPE (decl) = promoted_type;
4332 DECL_ARG_TYPE_AS_WRITTEN (decl) = type_as_written;
4334 else if (decl_context == FIELD)
4336 /* Structure field. It may not be a function. */
4338 if (TREE_CODE (type) == FUNCTION_TYPE)
4340 error ("field `%s' declared as a function", name);
4341 type = build_pointer_type (type);
4343 else if (TREE_CODE (type) != ERROR_MARK
4344 && !COMPLETE_OR_UNBOUND_ARRAY_TYPE_P (type))
4346 error ("field `%s' has incomplete type", name);
4347 type = error_mark_node;
4349 /* Move type qualifiers down to element of an array. */
4350 if (TREE_CODE (type) == ARRAY_TYPE && type_quals)
4351 type = build_array_type (c_build_qualified_type (TREE_TYPE (type),
4352 type_quals),
4353 TYPE_DOMAIN (type));
4354 decl = build_decl (FIELD_DECL, declarator, type);
4355 DECL_NONADDRESSABLE_P (decl) = bitfield;
4357 if (size_varies)
4358 C_DECL_VARIABLE_SIZE (decl) = 1;
4360 else if (TREE_CODE (type) == FUNCTION_TYPE)
4362 /* Every function declaration is "external"
4363 except for those which are inside a function body
4364 in which `auto' is used.
4365 That is a case not specified by ANSI C,
4366 and we use it for forward declarations for nested functions. */
4367 int extern_ref = (!(specbits & (1 << (int) RID_AUTO))
4368 || current_scope == global_scope);
4370 if (specbits & (1 << (int) RID_AUTO)
4371 && (pedantic || current_scope == global_scope))
4372 pedwarn ("invalid storage class for function `%s'", name);
4373 if (specbits & (1 << (int) RID_REGISTER))
4374 error ("invalid storage class for function `%s'", name);
4375 if (specbits & (1 << (int) RID_THREAD))
4376 error ("invalid storage class for function `%s'", name);
4377 /* Function declaration not at file scope.
4378 Storage classes other than `extern' are not allowed
4379 and `extern' makes no difference. */
4380 if (current_scope != global_scope
4381 && (specbits & ((1 << (int) RID_STATIC) | (1 << (int) RID_INLINE)))
4382 && pedantic)
4383 pedwarn ("invalid storage class for function `%s'", name);
4385 decl = build_decl (FUNCTION_DECL, declarator, type);
4386 decl = build_decl_attribute_variant (decl, decl_attr);
4388 DECL_LANG_SPECIFIC (decl)
4389 = ggc_alloc_cleared (sizeof (struct lang_decl));
4391 if (pedantic && type_quals && ! DECL_IN_SYSTEM_HEADER (decl))
4392 pedwarn ("ISO C forbids qualified function types");
4394 /* GNU C interprets a `volatile void' return type to indicate
4395 that the function does not return. */
4396 if ((type_quals & TYPE_QUAL_VOLATILE)
4397 && !VOID_TYPE_P (TREE_TYPE (TREE_TYPE (decl))))
4398 warning ("`noreturn' function returns non-void value");
4400 if (extern_ref)
4401 DECL_EXTERNAL (decl) = 1;
4402 /* Record absence of global scope for `static' or `auto'. */
4403 TREE_PUBLIC (decl)
4404 = !(specbits & ((1 << (int) RID_STATIC) | (1 << (int) RID_AUTO)));
4406 if (defaulted_int)
4407 C_FUNCTION_IMPLICIT_INT (decl) = 1;
4409 /* Record presence of `inline', if it is reasonable. */
4410 if (MAIN_NAME_P (declarator))
4412 if (inlinep)
4413 warning ("cannot inline function `main'");
4415 else if (inlinep)
4417 /* Record that the function is declared `inline'. */
4418 DECL_DECLARED_INLINE_P (decl) = 1;
4420 /* Do not mark bare declarations as DECL_INLINE. Doing so
4421 in the presence of multiple declarations can result in
4422 the abstract origin pointing between the declarations,
4423 which will confuse dwarf2out. */
4424 if (initialized)
4426 DECL_INLINE (decl) = 1;
4427 if (specbits & (1 << (int) RID_EXTERN))
4428 current_extern_inline = 1;
4431 /* If -finline-functions, assume it can be inlined. This does
4432 two things: let the function be deferred until it is actually
4433 needed, and let dwarf2 know that the function is inlinable. */
4434 else if (flag_inline_trees == 2 && initialized)
4435 DECL_INLINE (decl) = 1;
4437 else
4439 /* It's a variable. */
4440 /* An uninitialized decl with `extern' is a reference. */
4441 int extern_ref = !initialized && (specbits & (1 << (int) RID_EXTERN));
4443 /* Move type qualifiers down to element of an array. */
4444 if (TREE_CODE (type) == ARRAY_TYPE && type_quals)
4446 int saved_align = TYPE_ALIGN(type);
4447 type = build_array_type (c_build_qualified_type (TREE_TYPE (type),
4448 type_quals),
4449 TYPE_DOMAIN (type));
4450 TYPE_ALIGN (type) = saved_align;
4452 else if (type_quals)
4453 type = c_build_qualified_type (type, type_quals);
4455 /* It is invalid to create an `extern' declaration for a
4456 variable if there is a global declaration that is
4457 `static' and the global declaration is not visible. */
4458 if (extern_ref && current_scope != global_scope)
4460 tree global_decl;
4462 global_decl = identifier_global_value (declarator);
4463 if (global_decl
4464 && TREE_CODE (global_decl) == VAR_DECL
4465 && lookup_name (declarator) != global_decl
4466 && !TREE_PUBLIC (global_decl))
4467 error ("variable previously declared `static' redeclared "
4468 "`extern'");
4471 decl = build_decl (VAR_DECL, declarator, type);
4472 if (size_varies)
4473 C_DECL_VARIABLE_SIZE (decl) = 1;
4475 if (inlinep)
4476 pedwarn ("%Jvariable '%D' declared `inline'", decl, decl);
4478 DECL_EXTERNAL (decl) = extern_ref;
4480 /* At file scope, the presence of a `static' or `register' storage
4481 class specifier, or the absence of all storage class specifiers
4482 makes this declaration a definition (perhaps tentative). Also,
4483 the absence of both `static' and `register' makes it public. */
4484 if (current_scope == global_scope)
4486 TREE_PUBLIC (decl) = !(specbits & ((1 << (int) RID_STATIC)
4487 | (1 << (int) RID_REGISTER)));
4488 TREE_STATIC (decl) = !extern_ref;
4490 /* Not at file scope, only `static' makes a static definition. */
4491 else
4493 TREE_STATIC (decl) = (specbits & (1 << (int) RID_STATIC)) != 0;
4494 TREE_PUBLIC (decl) = extern_ref;
4497 if (specbits & 1 << (int) RID_THREAD)
4499 if (targetm.have_tls)
4500 DECL_THREAD_LOCAL (decl) = 1;
4501 else
4502 /* A mere warning is sure to result in improper semantics
4503 at runtime. Don't bother to allow this to compile. */
4504 error ("thread-local storage not supported for this target");
4508 /* Record `register' declaration for warnings on &
4509 and in case doing stupid register allocation. */
4511 if (specbits & (1 << (int) RID_REGISTER))
4512 DECL_REGISTER (decl) = 1;
4514 /* Record constancy and volatility. */
4515 c_apply_type_quals_to_decl (type_quals, decl);
4517 /* If a type has volatile components, it should be stored in memory.
4518 Otherwise, the fact that those components are volatile
4519 will be ignored, and would even crash the compiler. */
4520 if (C_TYPE_FIELDS_VOLATILE (TREE_TYPE (decl)))
4521 c_mark_addressable (decl);
4523 #ifdef ENABLE_CHECKING
4524 /* This is the earliest point at which we might know the assembler
4525 name of a variable. Thus, if it's known before this, die horribly. */
4526 if (DECL_ASSEMBLER_NAME_SET_P (decl))
4527 abort ();
4528 #endif
4530 decl_attributes (&decl, returned_attrs, 0);
4532 return decl;
4536 /* Decode the parameter-list info for a function type or function definition.
4537 The argument is the value returned by `get_parm_info' (or made in parse.y
4538 if there is an identifier list instead of a parameter decl list).
4539 These two functions are separate because when a function returns
4540 or receives functions then each is called multiple times but the order
4541 of calls is different. The last call to `grokparms' is always the one
4542 that contains the formal parameter names of a function definition.
4544 Store in `last_function_parms' a chain of the decls of parms.
4545 Also store in `last_function_parm_tags' a chain of the struct, union,
4546 and enum tags declared among the parms.
4548 Return a list of arg types to use in the FUNCTION_TYPE for this function.
4550 FUNCDEF_FLAG is nonzero for a function definition, 0 for
4551 a mere declaration. A nonempty identifier-list gets an error message
4552 when FUNCDEF_FLAG is zero. */
4554 static tree
4555 grokparms (tree parms_info, int funcdef_flag)
4557 tree first_parm = TREE_CHAIN (parms_info);
4559 last_function_parms = TREE_PURPOSE (parms_info);
4560 last_function_parm_tags = TREE_VALUE (parms_info);
4561 last_function_parm_others = TREE_TYPE (parms_info);
4563 if (warn_strict_prototypes && first_parm == 0 && !funcdef_flag
4564 && !in_system_header)
4565 warning ("function declaration isn't a prototype");
4567 if (first_parm != 0
4568 && TREE_CODE (TREE_VALUE (first_parm)) == IDENTIFIER_NODE)
4570 if (! funcdef_flag)
4571 pedwarn ("parameter names (without types) in function declaration");
4573 last_function_parms = first_parm;
4574 return 0;
4576 else
4578 tree parm;
4579 tree typelt;
4580 /* If the arg types are incomplete in a declaration,
4581 they must include undefined tags.
4582 These tags can never be defined in the scope of the declaration,
4583 so the types can never be completed,
4584 and no call can be compiled successfully. */
4586 for (parm = last_function_parms, typelt = first_parm;
4587 parm;
4588 parm = TREE_CHAIN (parm))
4589 /* Skip over any enumeration constants declared here. */
4590 if (TREE_CODE (parm) == PARM_DECL)
4592 /* Barf if the parameter itself has an incomplete type. */
4593 tree type = TREE_VALUE (typelt);
4594 if (type == error_mark_node)
4595 continue;
4596 if (!COMPLETE_TYPE_P (type))
4598 if (funcdef_flag && DECL_NAME (parm) != 0)
4599 error ("parameter `%s' has incomplete type",
4600 IDENTIFIER_POINTER (DECL_NAME (parm)));
4601 else
4602 warning ("parameter has incomplete type");
4603 if (funcdef_flag)
4605 TREE_VALUE (typelt) = error_mark_node;
4606 TREE_TYPE (parm) = error_mark_node;
4609 typelt = TREE_CHAIN (typelt);
4612 return first_parm;
4616 /* Return a tree_list node with info on a parameter list just parsed.
4617 The TREE_PURPOSE is a list of decls of those parms.
4618 The TREE_VALUE is a list of structure, union and enum tags defined.
4619 The TREE_CHAIN is a list of argument types to go in the FUNCTION_TYPE.
4620 The TREE_TYPE is a list of non-parameter decls which appeared with the
4621 parameters.
4622 This tree_list node is later fed to `grokparms'.
4624 VOID_AT_END nonzero means append `void' to the end of the type-list.
4625 Zero means the parmlist ended with an ellipsis so don't append `void'. */
4627 tree
4628 get_parm_info (int void_at_end)
4630 tree decl, type, list;
4631 tree types = 0;
4632 tree *last_type = &types;
4633 tree tags = current_scope->tags;
4634 tree parms = current_scope->parms;
4635 tree others = current_scope->names;
4636 static bool explained_incomplete_types = false;
4637 bool gave_void_only_once_err = false;
4639 /* Just "void" (and no ellipsis) is special. There are really no parms.
4640 But if the "void" is qualified (by "const" or "volatile"), or has a
4641 storage class specifier ("register"), then the behavior is undefined;
4642 issue an error. Typedefs for "void" are OK (see DR#157). */
4643 if (void_at_end && parms != 0
4644 && TREE_CHAIN (parms) == 0
4645 && VOID_TYPE_P (TREE_TYPE (parms))
4646 && !DECL_NAME (parms))
4648 if (TREE_THIS_VOLATILE (parms)
4649 || TREE_READONLY (parms)
4650 || DECL_REGISTER (parms))
4651 error ("\"void\" as only parameter may not be qualified");
4653 return tree_cons (0, 0, tree_cons (0, void_type_node, 0));
4656 /* Sanity check all of the parameter declarations. */
4657 for (decl = parms; decl; decl = TREE_CHAIN (decl))
4659 if (TREE_CODE (decl) != PARM_DECL)
4660 abort ();
4661 if (TREE_ASM_WRITTEN (decl))
4662 abort ();
4664 /* Since there is a prototype, args are passed in their
4665 declared types. The back end may override this. */
4666 type = TREE_TYPE (decl);
4667 DECL_ARG_TYPE (decl) = type;
4669 /* Check for (..., void, ...) and issue an error. */
4670 if (VOID_TYPE_P (type) && !DECL_NAME (decl) && !gave_void_only_once_err)
4672 error ("\"void\" must be the only parameter");
4673 gave_void_only_once_err = true;
4676 type = build_tree_list (0, type);
4677 *last_type = type;
4678 last_type = &TREE_CHAIN (type);
4681 /* Check the list of non-parameter decls for any forward parm decls
4682 that never got real decls. */
4683 for (decl = others; decl; decl = TREE_CHAIN (decl))
4684 if (TREE_CODE (decl) == PARM_DECL)
4686 if (!TREE_ASM_WRITTEN (decl))
4687 abort ();
4689 error ("%Jparameter \"%D\" has just a forward declaration",
4690 decl, decl);
4693 /* Warn about any struct, union or enum tags defined within this
4694 list. The scope of such types is limited to this declaration,
4695 which is rarely if ever desirable (it's impossible to call such
4696 a function with type-correct arguments). */
4697 for (decl = tags; decl; decl = TREE_CHAIN (decl))
4699 enum tree_code code = TREE_CODE (TREE_VALUE (decl));
4700 const char *keyword;
4701 /* An anonymous union parm type is meaningful as a GNU extension.
4702 So don't warn for that. */
4703 if (code == UNION_TYPE && TREE_PURPOSE (decl) == 0 && !pedantic)
4704 continue;
4706 /* The keyword should not be translated. */
4707 switch (code)
4709 case RECORD_TYPE: keyword = "struct"; break;
4710 case UNION_TYPE: keyword = "union"; break;
4711 case ENUMERAL_TYPE: keyword = "enum"; break;
4712 default: abort ();
4715 if (TREE_PURPOSE (decl))
4716 /* The first %s will be one of 'struct', 'union', or 'enum'. */
4717 warning ("\"%s %s\" declared inside parameter list",
4718 keyword, IDENTIFIER_POINTER (TREE_PURPOSE (decl)));
4719 else
4720 /* The %s will be one of 'struct', 'union', or 'enum'. */
4721 warning ("anonymous %s declared inside parameter list", keyword);
4723 if (! explained_incomplete_types)
4725 warning ("its scope is only this definition or declaration,"
4726 " which is probably not what you want");
4727 explained_incomplete_types = true;
4732 if (void_at_end)
4734 type = build_tree_list (0, void_type_node);
4735 *last_type = type;
4738 list = tree_cons (parms, tags, types);
4739 TREE_TYPE (list) = others;
4740 return list;
4743 /* Get the struct, enum or union (CODE says which) with tag NAME.
4744 Define the tag as a forward-reference if it is not defined. */
4746 tree
4747 xref_tag (enum tree_code code, tree name)
4749 /* If a cross reference is requested, look up the type
4750 already defined for this tag and return it. */
4752 tree ref = lookup_tag (code, name, 0);
4753 /* If this is the right type of tag, return what we found.
4754 (This reference will be shadowed by shadow_tag later if appropriate.)
4755 If this is the wrong type of tag, do not return it. If it was the
4756 wrong type in the same scope, we will have had an error
4757 message already; if in a different scope and declaring
4758 a name, pending_xref_error will give an error message; but if in a
4759 different scope and not declaring a name, this tag should
4760 shadow the previous declaration of a different type of tag, and
4761 this would not work properly if we return the reference found.
4762 (For example, with "struct foo" in an outer scope, "union foo;"
4763 must shadow that tag with a new one of union type.) */
4764 if (ref && TREE_CODE (ref) == code)
4765 return ref;
4767 /* If no such tag is yet defined, create a forward-reference node
4768 and record it as the "definition".
4769 When a real declaration of this type is found,
4770 the forward-reference will be altered into a real type. */
4772 ref = make_node (code);
4773 if (code == ENUMERAL_TYPE)
4775 /* Give the type a default layout like unsigned int
4776 to avoid crashing if it does not get defined. */
4777 TYPE_MODE (ref) = TYPE_MODE (unsigned_type_node);
4778 TYPE_ALIGN (ref) = TYPE_ALIGN (unsigned_type_node);
4779 TYPE_USER_ALIGN (ref) = 0;
4780 TREE_UNSIGNED (ref) = 1;
4781 TYPE_PRECISION (ref) = TYPE_PRECISION (unsigned_type_node);
4782 TYPE_MIN_VALUE (ref) = TYPE_MIN_VALUE (unsigned_type_node);
4783 TYPE_MAX_VALUE (ref) = TYPE_MAX_VALUE (unsigned_type_node);
4786 pushtag (name, ref);
4788 return ref;
4791 /* Make sure that the tag NAME is defined *in the current scope*
4792 at least as a forward reference.
4793 CODE says which kind of tag NAME ought to be. */
4795 tree
4796 start_struct (enum tree_code code, tree name)
4798 /* If there is already a tag defined at this scope
4799 (as a forward reference), just return it. */
4801 tree ref = 0;
4803 if (name != 0)
4804 ref = lookup_tag (code, name, 1);
4805 if (ref && TREE_CODE (ref) == code)
4807 if (TYPE_SIZE (ref))
4809 if (code == UNION_TYPE)
4810 error ("redefinition of `union %s'", IDENTIFIER_POINTER (name));
4811 else
4812 error ("redefinition of `struct %s'", IDENTIFIER_POINTER (name));
4814 else if (C_TYPE_BEING_DEFINED (ref))
4816 if (code == UNION_TYPE)
4817 error ("nested redefinition of `union %s'",
4818 IDENTIFIER_POINTER (name));
4819 else
4820 error ("nested redefinition of `struct %s'",
4821 IDENTIFIER_POINTER (name));
4824 else
4826 /* Otherwise create a forward-reference just so the tag is in scope. */
4828 ref = make_node (code);
4829 pushtag (name, ref);
4832 C_TYPE_BEING_DEFINED (ref) = 1;
4833 TYPE_PACKED (ref) = flag_pack_struct;
4834 return ref;
4837 /* Process the specs, declarator (NULL if omitted) and width (NULL if omitted)
4838 of a structure component, returning a FIELD_DECL node.
4839 WIDTH is non-NULL for bit-fields only, and is an INTEGER_CST node.
4841 This is done during the parsing of the struct declaration.
4842 The FIELD_DECL nodes are chained together and the lot of them
4843 are ultimately passed to `build_struct' to make the RECORD_TYPE node. */
4845 tree
4846 grokfield (tree declarator, tree declspecs, tree width)
4848 tree value;
4850 if (declarator == NULL_TREE && width == NULL_TREE)
4852 /* This is an unnamed decl.
4854 If we have something of the form "union { list } ;" then this
4855 is the anonymous union extension. Similarly for struct.
4857 If this is something of the form "struct foo;", then
4858 If MS extensions are enabled, this is handled as an
4859 anonymous struct.
4860 Otherwise this is a forward declaration of a structure tag.
4862 If this is something of the form "foo;" and foo is a TYPE_DECL, then
4863 If MS extensions are enabled and foo names a structure, then
4864 again this is an anonymous struct.
4865 Otherwise this is an error.
4867 Oh what a horrid tangled web we weave. I wonder if MS consciously
4868 took this from Plan 9 or if it was an accident of implementation
4869 that took root before someone noticed the bug... */
4871 tree type = TREE_VALUE (declspecs);
4873 if (flag_ms_extensions && TREE_CODE (type) == TYPE_DECL)
4874 type = TREE_TYPE (type);
4875 if (TREE_CODE (type) == RECORD_TYPE || TREE_CODE (type) == UNION_TYPE)
4877 if (flag_ms_extensions)
4878 ; /* ok */
4879 else if (flag_iso)
4880 goto warn_unnamed_field;
4881 else if (TYPE_NAME (type) == NULL)
4882 ; /* ok */
4883 else
4884 goto warn_unnamed_field;
4886 else
4888 warn_unnamed_field:
4889 warning ("declaration does not declare anything");
4890 return NULL_TREE;
4894 value = grokdeclarator (declarator, declspecs, FIELD, 0,
4895 width ? &width : NULL);
4897 finish_decl (value, NULL_TREE, NULL_TREE);
4898 DECL_INITIAL (value) = width;
4900 return value;
4903 /* Generate an error for any duplicate field names in FIELDLIST. Munge
4904 the list such that this does not present a problem later. */
4906 static void
4907 detect_field_duplicates (tree fieldlist)
4909 tree x, y;
4910 int timeout = 10;
4912 /* First, see if there are more than "a few" fields.
4913 This is trivially true if there are zero or one fields. */
4914 if (!fieldlist)
4915 return;
4916 x = TREE_CHAIN (fieldlist);
4917 if (!x)
4918 return;
4919 do {
4920 timeout--;
4921 x = TREE_CHAIN (x);
4922 } while (timeout > 0 && x);
4924 /* If there were "few" fields, avoid the overhead of allocating
4925 a hash table. Instead just do the nested traversal thing. */
4926 if (timeout > 0)
4928 for (x = TREE_CHAIN (fieldlist); x ; x = TREE_CHAIN (x))
4929 if (DECL_NAME (x))
4931 for (y = fieldlist; y != x; y = TREE_CHAIN (y))
4932 if (DECL_NAME (y) == DECL_NAME (x))
4934 error ("%Jduplicate member '%D'", x, x);
4935 DECL_NAME (x) = NULL_TREE;
4939 else
4941 htab_t htab = htab_create (37, htab_hash_pointer, htab_eq_pointer, NULL);
4942 void **slot;
4944 for (x = fieldlist; x ; x = TREE_CHAIN (x))
4945 if ((y = DECL_NAME (x)) != 0)
4947 slot = htab_find_slot (htab, y, INSERT);
4948 if (*slot)
4950 error ("%Jduplicate member '%D'", x, x);
4951 DECL_NAME (x) = NULL_TREE;
4953 *slot = y;
4956 htab_delete (htab);
4960 /* Fill in the fields of a RECORD_TYPE or UNION_TYPE node, T.
4961 FIELDLIST is a chain of FIELD_DECL nodes for the fields.
4962 ATTRIBUTES are attributes to be applied to the structure. */
4964 tree
4965 finish_struct (tree t, tree fieldlist, tree attributes)
4967 tree x;
4968 int toplevel = global_scope == current_scope;
4969 int saw_named_field;
4971 /* If this type was previously laid out as a forward reference,
4972 make sure we lay it out again. */
4974 TYPE_SIZE (t) = 0;
4976 decl_attributes (&t, attributes, (int) ATTR_FLAG_TYPE_IN_PLACE);
4978 /* Nameless union parm types are useful as GCC extension. */
4979 if (! (TREE_CODE (t) == UNION_TYPE && TYPE_NAME (t) == 0) && !pedantic)
4980 /* Otherwise, warn about any struct or union def. in parmlist. */
4981 if (in_parm_level_p ())
4983 if (pedantic)
4984 pedwarn ("%s defined inside parms",
4985 TREE_CODE (t) == UNION_TYPE ? _("union") : _("structure"));
4986 else
4987 warning ("%s defined inside parms",
4988 TREE_CODE (t) == UNION_TYPE ? _("union") : _("structure"));
4991 if (pedantic)
4993 for (x = fieldlist; x; x = TREE_CHAIN (x))
4994 if (DECL_NAME (x) != 0)
4995 break;
4997 if (x == 0)
4998 pedwarn ("%s has no %s",
4999 TREE_CODE (t) == UNION_TYPE ? _("union") : _("struct"),
5000 fieldlist ? _("named members") : _("members"));
5003 /* Install struct as DECL_CONTEXT of each field decl.
5004 Also process specified field sizes,m which is found in the DECL_INITIAL.
5005 Store 0 there, except for ": 0" fields (so we can find them
5006 and delete them, below). */
5008 saw_named_field = 0;
5009 for (x = fieldlist; x; x = TREE_CHAIN (x))
5011 DECL_CONTEXT (x) = t;
5012 DECL_PACKED (x) |= TYPE_PACKED (t);
5014 /* If any field is const, the structure type is pseudo-const. */
5015 if (TREE_READONLY (x))
5016 C_TYPE_FIELDS_READONLY (t) = 1;
5017 else
5019 /* A field that is pseudo-const makes the structure likewise. */
5020 tree t1 = TREE_TYPE (x);
5021 while (TREE_CODE (t1) == ARRAY_TYPE)
5022 t1 = TREE_TYPE (t1);
5023 if ((TREE_CODE (t1) == RECORD_TYPE || TREE_CODE (t1) == UNION_TYPE)
5024 && C_TYPE_FIELDS_READONLY (t1))
5025 C_TYPE_FIELDS_READONLY (t) = 1;
5028 /* Any field that is volatile means variables of this type must be
5029 treated in some ways as volatile. */
5030 if (TREE_THIS_VOLATILE (x))
5031 C_TYPE_FIELDS_VOLATILE (t) = 1;
5033 /* Any field of nominal variable size implies structure is too. */
5034 if (C_DECL_VARIABLE_SIZE (x))
5035 C_TYPE_VARIABLE_SIZE (t) = 1;
5037 if (DECL_INITIAL (x))
5039 unsigned HOST_WIDE_INT width = tree_low_cst (DECL_INITIAL (x), 1);
5040 DECL_SIZE (x) = bitsize_int (width);
5041 DECL_BIT_FIELD (x) = 1;
5042 SET_DECL_C_BIT_FIELD (x);
5045 DECL_INITIAL (x) = 0;
5047 /* Detect flexible array member in an invalid context. */
5048 if (TREE_CODE (TREE_TYPE (x)) == ARRAY_TYPE
5049 && TYPE_SIZE (TREE_TYPE (x)) == NULL_TREE
5050 && TYPE_DOMAIN (TREE_TYPE (x)) != NULL_TREE
5051 && TYPE_MAX_VALUE (TYPE_DOMAIN (TREE_TYPE (x))) == NULL_TREE)
5053 if (TREE_CODE (t) == UNION_TYPE)
5055 error ("%Jflexible array member in union", x);
5056 TREE_TYPE (x) = error_mark_node;
5058 else if (TREE_CHAIN (x) != NULL_TREE)
5060 error ("%Jflexible array member not at end of struct", x);
5061 TREE_TYPE (x) = error_mark_node;
5063 else if (! saw_named_field)
5065 error ("%Jflexible array member in otherwise empty struct", x);
5066 TREE_TYPE (x) = error_mark_node;
5070 if (pedantic && !in_system_header && TREE_CODE (t) == RECORD_TYPE
5071 && flexible_array_type_p (TREE_TYPE (x)))
5072 pedwarn ("%Jinvalid use of structure with flexible array member", x);
5074 if (DECL_NAME (x))
5075 saw_named_field = 1;
5078 detect_field_duplicates (fieldlist);
5080 /* Now we have the nearly final fieldlist. Record it,
5081 then lay out the structure or union (including the fields). */
5083 TYPE_FIELDS (t) = fieldlist;
5085 layout_type (t);
5087 /* Delete all zero-width bit-fields from the fieldlist. */
5089 tree *fieldlistp = &fieldlist;
5090 while (*fieldlistp)
5091 if (TREE_CODE (*fieldlistp) == FIELD_DECL && DECL_INITIAL (*fieldlistp))
5092 *fieldlistp = TREE_CHAIN (*fieldlistp);
5093 else
5094 fieldlistp = &TREE_CHAIN (*fieldlistp);
5097 /* Now we have the truly final field list.
5098 Store it in this type and in the variants. */
5100 TYPE_FIELDS (t) = fieldlist;
5102 /* If there are lots of fields, sort so we can look through them fast.
5103 We arbitrarily consider 16 or more elts to be "a lot". */
5106 int len = 0;
5108 for (x = fieldlist; x; x = TREE_CHAIN (x))
5110 if (len > 15 || DECL_NAME (x) == NULL)
5111 break;
5112 len += 1;
5115 if (len > 15)
5117 tree *field_array;
5118 struct lang_type *space;
5119 struct sorted_fields_type *space2;
5121 len += list_length (x);
5123 /* Use the same allocation policy here that make_node uses, to
5124 ensure that this lives as long as the rest of the struct decl.
5125 All decls in an inline function need to be saved. */
5127 space = ggc_alloc (sizeof (struct lang_type));
5128 space2 = ggc_alloc (sizeof (struct sorted_fields_type) + len * sizeof (tree));
5130 len = 0;
5131 space->s = space2;
5132 field_array = &space2->elts[0];
5133 for (x = fieldlist; x; x = TREE_CHAIN (x))
5135 field_array[len++] = x;
5137 /* If there is anonymous struct or union, break out of the loop. */
5138 if (DECL_NAME (x) == NULL)
5139 break;
5141 /* Found no anonymous struct/union. Add the TYPE_LANG_SPECIFIC. */
5142 if (x == NULL)
5144 TYPE_LANG_SPECIFIC (t) = space;
5145 TYPE_LANG_SPECIFIC (t)->s->len = len;
5146 field_array = TYPE_LANG_SPECIFIC (t)->s->elts;
5147 qsort (field_array, len, sizeof (tree), field_decl_cmp);
5152 for (x = TYPE_MAIN_VARIANT (t); x; x = TYPE_NEXT_VARIANT (x))
5154 TYPE_FIELDS (x) = TYPE_FIELDS (t);
5155 TYPE_LANG_SPECIFIC (x) = TYPE_LANG_SPECIFIC (t);
5156 TYPE_ALIGN (x) = TYPE_ALIGN (t);
5157 TYPE_USER_ALIGN (x) = TYPE_USER_ALIGN (t);
5158 C_TYPE_FIELDS_READONLY (x) = C_TYPE_FIELDS_READONLY (t);
5159 C_TYPE_FIELDS_VOLATILE (x) = C_TYPE_FIELDS_VOLATILE (t);
5160 C_TYPE_VARIABLE_SIZE (x) = C_TYPE_VARIABLE_SIZE (t);
5163 /* If this was supposed to be a transparent union, but we can't
5164 make it one, warn and turn off the flag. */
5165 if (TREE_CODE (t) == UNION_TYPE
5166 && TYPE_TRANSPARENT_UNION (t)
5167 && (!TYPE_FIELDS (t) || TYPE_MODE (t) != DECL_MODE (TYPE_FIELDS (t))))
5169 TYPE_TRANSPARENT_UNION (t) = 0;
5170 warning ("union cannot be made transparent");
5173 /* If this structure or union completes the type of any previous
5174 variable declaration, lay it out and output its rtl. */
5175 for (x = C_TYPE_INCOMPLETE_VARS (TYPE_MAIN_VARIANT (t));
5177 x = TREE_CHAIN (x))
5179 tree decl = TREE_VALUE (x);
5180 if (TREE_CODE (TREE_TYPE (decl)) == ARRAY_TYPE)
5181 layout_array_type (TREE_TYPE (decl));
5182 if (TREE_CODE (decl) != TYPE_DECL)
5184 layout_decl (decl, 0);
5185 if (c_dialect_objc ())
5186 objc_check_decl (decl);
5187 rest_of_decl_compilation (decl, NULL, toplevel, 0);
5188 if (! toplevel)
5189 expand_decl (decl);
5192 C_TYPE_INCOMPLETE_VARS (TYPE_MAIN_VARIANT (t)) = 0;
5194 /* Finish debugging output for this type. */
5195 rest_of_type_compilation (t, toplevel);
5197 return t;
5200 /* Lay out the type T, and its element type, and so on. */
5202 static void
5203 layout_array_type (tree t)
5205 if (TREE_CODE (TREE_TYPE (t)) == ARRAY_TYPE)
5206 layout_array_type (TREE_TYPE (t));
5207 layout_type (t);
5210 /* Begin compiling the definition of an enumeration type.
5211 NAME is its name (or null if anonymous).
5212 Returns the type object, as yet incomplete.
5213 Also records info about it so that build_enumerator
5214 may be used to declare the individual values as they are read. */
5216 tree
5217 start_enum (tree name)
5219 tree enumtype = 0;
5221 /* If this is the real definition for a previous forward reference,
5222 fill in the contents in the same object that used to be the
5223 forward reference. */
5225 if (name != 0)
5226 enumtype = lookup_tag (ENUMERAL_TYPE, name, 1);
5228 if (enumtype == 0 || TREE_CODE (enumtype) != ENUMERAL_TYPE)
5230 enumtype = make_node (ENUMERAL_TYPE);
5231 pushtag (name, enumtype);
5234 if (C_TYPE_BEING_DEFINED (enumtype))
5235 error ("nested redefinition of `enum %s'", IDENTIFIER_POINTER (name));
5237 C_TYPE_BEING_DEFINED (enumtype) = 1;
5239 if (TYPE_VALUES (enumtype) != 0)
5241 /* This enum is a named one that has been declared already. */
5242 error ("redeclaration of `enum %s'", IDENTIFIER_POINTER (name));
5244 /* Completely replace its old definition.
5245 The old enumerators remain defined, however. */
5246 TYPE_VALUES (enumtype) = 0;
5249 enum_next_value = integer_zero_node;
5250 enum_overflow = 0;
5252 if (flag_short_enums)
5253 TYPE_PACKED (enumtype) = 1;
5255 return enumtype;
5258 /* After processing and defining all the values of an enumeration type,
5259 install their decls in the enumeration type and finish it off.
5260 ENUMTYPE is the type object, VALUES a list of decl-value pairs,
5261 and ATTRIBUTES are the specified attributes.
5262 Returns ENUMTYPE. */
5264 tree
5265 finish_enum (tree enumtype, tree values, tree attributes)
5267 tree pair, tem;
5268 tree minnode = 0, maxnode = 0, enum_value_type;
5269 int precision, unsign;
5270 int toplevel = (global_scope == current_scope);
5272 if (in_parm_level_p ())
5273 warning ("enum defined inside parms");
5275 decl_attributes (&enumtype, attributes, (int) ATTR_FLAG_TYPE_IN_PLACE);
5277 /* Calculate the maximum value of any enumerator in this type. */
5279 if (values == error_mark_node)
5280 minnode = maxnode = integer_zero_node;
5281 else
5283 minnode = maxnode = TREE_VALUE (values);
5284 for (pair = TREE_CHAIN (values); pair; pair = TREE_CHAIN (pair))
5286 tree value = TREE_VALUE (pair);
5287 if (tree_int_cst_lt (maxnode, value))
5288 maxnode = value;
5289 if (tree_int_cst_lt (value, minnode))
5290 minnode = value;
5294 /* Construct the final type of this enumeration. It is the same
5295 as one of the integral types - the narrowest one that fits, except
5296 that normally we only go as narrow as int - and signed iff any of
5297 the values are negative. */
5298 unsign = (tree_int_cst_sgn (minnode) >= 0);
5299 precision = MAX (min_precision (minnode, unsign),
5300 min_precision (maxnode, unsign));
5301 if (TYPE_PACKED (enumtype) || precision > TYPE_PRECISION (integer_type_node))
5303 tree narrowest = c_common_type_for_size (precision, unsign);
5304 if (narrowest == 0)
5306 warning ("enumeration values exceed range of largest integer");
5307 narrowest = long_long_integer_type_node;
5310 precision = TYPE_PRECISION (narrowest);
5312 else
5313 precision = TYPE_PRECISION (integer_type_node);
5315 if (precision == TYPE_PRECISION (integer_type_node))
5316 enum_value_type = c_common_type_for_size (precision, 0);
5317 else
5318 enum_value_type = enumtype;
5320 TYPE_MIN_VALUE (enumtype) = minnode;
5321 TYPE_MAX_VALUE (enumtype) = maxnode;
5322 TREE_UNSIGNED (enumtype) = unsign;
5323 TYPE_SIZE (enumtype) = 0;
5325 /* If the precision of the type was specific with an attribute and it
5326 was too small, give an error. Otherwise, use it. */
5327 if (TYPE_PRECISION (enumtype))
5329 if (precision > TYPE_PRECISION (enumtype))
5330 error ("specified mode too small for enumeral values");
5332 else
5333 TYPE_PRECISION (enumtype) = precision;
5335 layout_type (enumtype);
5337 if (values != error_mark_node)
5339 /* Change the type of the enumerators to be the enum type. We
5340 need to do this irrespective of the size of the enum, for
5341 proper type checking. Replace the DECL_INITIALs of the
5342 enumerators, and the value slots of the list, with copies
5343 that have the enum type; they cannot be modified in place
5344 because they may be shared (e.g. integer_zero_node) Finally,
5345 change the purpose slots to point to the names of the decls. */
5346 for (pair = values; pair; pair = TREE_CHAIN (pair))
5348 tree enu = TREE_PURPOSE (pair);
5350 TREE_TYPE (enu) = enumtype;
5352 /* The ISO C Standard mandates enumerators to have type int,
5353 even though the underlying type of an enum type is
5354 unspecified. Here we convert any enumerators that fit in
5355 an int to type int, to avoid promotions to unsigned types
5356 when comparing integers with enumerators that fit in the
5357 int range. When -pedantic is given, build_enumerator()
5358 would have already taken care of those that don't fit. */
5359 if (int_fits_type_p (DECL_INITIAL (enu), enum_value_type))
5360 DECL_INITIAL (enu) = convert (enum_value_type, DECL_INITIAL (enu));
5361 else
5362 DECL_INITIAL (enu) = convert (enumtype, DECL_INITIAL (enu));
5364 TREE_PURPOSE (pair) = DECL_NAME (enu);
5365 TREE_VALUE (pair) = DECL_INITIAL (enu);
5368 TYPE_VALUES (enumtype) = values;
5371 /* Fix up all variant types of this enum type. */
5372 for (tem = TYPE_MAIN_VARIANT (enumtype); tem; tem = TYPE_NEXT_VARIANT (tem))
5374 if (tem == enumtype)
5375 continue;
5376 TYPE_VALUES (tem) = TYPE_VALUES (enumtype);
5377 TYPE_MIN_VALUE (tem) = TYPE_MIN_VALUE (enumtype);
5378 TYPE_MAX_VALUE (tem) = TYPE_MAX_VALUE (enumtype);
5379 TYPE_SIZE (tem) = TYPE_SIZE (enumtype);
5380 TYPE_SIZE_UNIT (tem) = TYPE_SIZE_UNIT (enumtype);
5381 TYPE_MODE (tem) = TYPE_MODE (enumtype);
5382 TYPE_PRECISION (tem) = TYPE_PRECISION (enumtype);
5383 TYPE_ALIGN (tem) = TYPE_ALIGN (enumtype);
5384 TYPE_USER_ALIGN (tem) = TYPE_USER_ALIGN (enumtype);
5385 TREE_UNSIGNED (tem) = TREE_UNSIGNED (enumtype);
5388 /* Finish debugging output for this type. */
5389 rest_of_type_compilation (enumtype, toplevel);
5391 return enumtype;
5394 /* Build and install a CONST_DECL for one value of the
5395 current enumeration type (one that was begun with start_enum).
5396 Return a tree-list containing the CONST_DECL and its value.
5397 Assignment of sequential values by default is handled here. */
5399 tree
5400 build_enumerator (tree name, tree value)
5402 tree decl, type;
5404 /* Validate and default VALUE. */
5406 /* Remove no-op casts from the value. */
5407 if (value)
5408 STRIP_TYPE_NOPS (value);
5410 if (value != 0)
5412 if (TREE_CODE (value) == INTEGER_CST)
5414 value = default_conversion (value);
5415 constant_expression_warning (value);
5417 else
5419 error ("enumerator value for `%s' not integer constant",
5420 IDENTIFIER_POINTER (name));
5421 value = 0;
5425 /* Default based on previous value. */
5426 /* It should no longer be possible to have NON_LVALUE_EXPR
5427 in the default. */
5428 if (value == 0)
5430 value = enum_next_value;
5431 if (enum_overflow)
5432 error ("overflow in enumeration values");
5435 if (pedantic && ! int_fits_type_p (value, integer_type_node))
5437 pedwarn ("ISO C restricts enumerator values to range of `int'");
5438 value = convert (integer_type_node, value);
5441 /* Set basis for default for next value. */
5442 enum_next_value = build_binary_op (PLUS_EXPR, value, integer_one_node, 0);
5443 enum_overflow = tree_int_cst_lt (enum_next_value, value);
5445 /* Now create a declaration for the enum value name. */
5447 type = TREE_TYPE (value);
5448 type = c_common_type_for_size (MAX (TYPE_PRECISION (type),
5449 TYPE_PRECISION (integer_type_node)),
5450 (TYPE_PRECISION (type)
5451 >= TYPE_PRECISION (integer_type_node)
5452 && TREE_UNSIGNED (type)));
5454 decl = build_decl (CONST_DECL, name, type);
5455 DECL_INITIAL (decl) = convert (type, value);
5456 pushdecl (decl);
5458 return tree_cons (decl, value, NULL_TREE);
5462 /* Create the FUNCTION_DECL for a function definition.
5463 DECLSPECS, DECLARATOR and ATTRIBUTES are the parts of
5464 the declaration; they describe the function's name and the type it returns,
5465 but twisted together in a fashion that parallels the syntax of C.
5467 This function creates a binding context for the function body
5468 as well as setting up the FUNCTION_DECL in current_function_decl.
5470 Returns 1 on success. If the DECLARATOR is not suitable for a function
5471 (it defines a datum instead), we return 0, which tells
5472 yyparse to report a parse error. */
5475 start_function (tree declspecs, tree declarator, tree attributes)
5477 tree decl1, old_decl;
5478 tree restype;
5479 int old_immediate_size_expand = immediate_size_expand;
5481 current_function_returns_value = 0; /* Assume, until we see it does. */
5482 current_function_returns_null = 0;
5483 current_function_returns_abnormally = 0;
5484 warn_about_return_type = 0;
5485 current_extern_inline = 0;
5486 c_in_iteration_stmt = 0;
5487 c_in_case_stmt = 0;
5489 /* Don't expand any sizes in the return type of the function. */
5490 immediate_size_expand = 0;
5492 decl1 = grokdeclarator (declarator, declspecs, FUNCDEF, 1, NULL);
5494 /* If the declarator is not suitable for a function definition,
5495 cause a syntax error. */
5496 if (decl1 == 0)
5498 immediate_size_expand = old_immediate_size_expand;
5499 return 0;
5502 decl_attributes (&decl1, attributes, 0);
5504 if (DECL_DECLARED_INLINE_P (decl1)
5505 && DECL_UNINLINABLE (decl1)
5506 && lookup_attribute ("noinline", DECL_ATTRIBUTES (decl1)))
5507 warning ("%Jinline function '%D' given attribute noinline", decl1, decl1);
5509 announce_function (decl1);
5511 if (!COMPLETE_OR_VOID_TYPE_P (TREE_TYPE (TREE_TYPE (decl1))))
5513 error ("return type is an incomplete type");
5514 /* Make it return void instead. */
5515 TREE_TYPE (decl1)
5516 = build_function_type (void_type_node,
5517 TYPE_ARG_TYPES (TREE_TYPE (decl1)));
5520 if (warn_about_return_type)
5521 pedwarn_c99 ("return type defaults to `int'");
5523 /* Save the parm names or decls from this function's declarator
5524 where store_parm_decls will find them. */
5525 current_function_parms = last_function_parms;
5526 current_function_parm_tags = last_function_parm_tags;
5527 current_function_parm_others = last_function_parm_others;
5529 /* Make the init_value nonzero so pushdecl knows this is not tentative.
5530 error_mark_node is replaced below (in poplevel) with the BLOCK. */
5531 DECL_INITIAL (decl1) = error_mark_node;
5533 /* If this definition isn't a prototype and we had a prototype declaration
5534 before, copy the arg type info from that prototype.
5535 But not if what we had before was a builtin function. */
5536 old_decl = lookup_name_current_level (DECL_NAME (decl1));
5537 if (old_decl != 0 && TREE_CODE (TREE_TYPE (old_decl)) == FUNCTION_TYPE
5538 && !DECL_BUILT_IN (old_decl)
5539 && (TYPE_MAIN_VARIANT (TREE_TYPE (TREE_TYPE (decl1)))
5540 == TYPE_MAIN_VARIANT (TREE_TYPE (TREE_TYPE (old_decl))))
5541 && TYPE_ARG_TYPES (TREE_TYPE (decl1)) == 0)
5543 TREE_TYPE (decl1) = TREE_TYPE (old_decl);
5544 current_function_prototype_locus = DECL_SOURCE_LOCATION (old_decl);
5547 /* Optionally warn of old-fashioned def with no previous prototype. */
5548 if (warn_strict_prototypes
5549 && TYPE_ARG_TYPES (TREE_TYPE (decl1)) == 0
5550 && C_DECL_ISNT_PROTOTYPE (old_decl))
5551 warning ("function declaration isn't a prototype");
5552 /* Optionally warn of any global def with no previous prototype. */
5553 else if (warn_missing_prototypes
5554 && TREE_PUBLIC (decl1)
5555 && ! MAIN_NAME_P (DECL_NAME (decl1))
5556 && C_DECL_ISNT_PROTOTYPE (old_decl))
5557 warning ("%Jno previous prototype for '%D'", decl1, decl1);
5558 /* Optionally warn of any def with no previous prototype
5559 if the function has already been used. */
5560 else if (warn_missing_prototypes
5561 && old_decl != 0 && TREE_USED (old_decl)
5562 && TYPE_ARG_TYPES (TREE_TYPE (old_decl)) == 0)
5563 warning ("%J'%D' was used with no prototype before its definition",
5564 decl1, decl1);
5565 /* Optionally warn of any global def with no previous declaration. */
5566 else if (warn_missing_declarations
5567 && TREE_PUBLIC (decl1)
5568 && old_decl == 0
5569 && ! MAIN_NAME_P (DECL_NAME (decl1)))
5570 warning ("%Jno previous declaration for '%D'", decl1, decl1);
5571 /* Optionally warn of any def with no previous declaration
5572 if the function has already been used. */
5573 else if (warn_missing_declarations
5574 && old_decl != 0 && TREE_USED (old_decl)
5575 && C_DECL_IMPLICIT (old_decl))
5576 warning ("%J`%D' was used with no declaration before its definition",
5577 decl1, decl1);
5579 /* This is a definition, not a reference.
5580 So normally clear DECL_EXTERNAL.
5581 However, `extern inline' acts like a declaration
5582 except for defining how to inline. So set DECL_EXTERNAL in that case. */
5583 DECL_EXTERNAL (decl1) = current_extern_inline;
5585 /* This function exists in static storage.
5586 (This does not mean `static' in the C sense!) */
5587 TREE_STATIC (decl1) = 1;
5589 /* A nested function is not global. */
5590 if (current_function_decl != 0)
5591 TREE_PUBLIC (decl1) = 0;
5593 #ifdef ENABLE_CHECKING
5594 /* This is the earliest point at which we might know the assembler
5595 name of the function. Thus, if it's set before this, die horribly. */
5596 if (DECL_ASSEMBLER_NAME_SET_P (decl1))
5597 abort ();
5598 #endif
5600 /* If #pragma weak was used, mark the decl weak now. */
5601 if (current_scope == global_scope)
5602 maybe_apply_pragma_weak (decl1);
5604 /* Warn for unlikely, improbable, or stupid declarations of `main'. */
5605 if (warn_main > 0 && MAIN_NAME_P (DECL_NAME (decl1)))
5607 tree args;
5608 int argct = 0;
5610 if (TYPE_MAIN_VARIANT (TREE_TYPE (TREE_TYPE (decl1)))
5611 != integer_type_node)
5612 pedwarn ("%Jreturn type of '%D' is not `int'", decl1, decl1);
5614 for (args = TYPE_ARG_TYPES (TREE_TYPE (decl1)); args;
5615 args = TREE_CHAIN (args))
5617 tree type = args ? TREE_VALUE (args) : 0;
5619 if (type == void_type_node)
5620 break;
5622 ++argct;
5623 switch (argct)
5625 case 1:
5626 if (TYPE_MAIN_VARIANT (type) != integer_type_node)
5627 pedwarn ("%Jfirst argument of '%D' should be `int'",
5628 decl1, decl1);
5629 break;
5631 case 2:
5632 if (TREE_CODE (type) != POINTER_TYPE
5633 || TREE_CODE (TREE_TYPE (type)) != POINTER_TYPE
5634 || (TYPE_MAIN_VARIANT (TREE_TYPE (TREE_TYPE (type)))
5635 != char_type_node))
5636 pedwarn ("%Jsecond argument of '%D' should be 'char **'",
5637 decl1, decl1);
5638 break;
5640 case 3:
5641 if (TREE_CODE (type) != POINTER_TYPE
5642 || TREE_CODE (TREE_TYPE (type)) != POINTER_TYPE
5643 || (TYPE_MAIN_VARIANT (TREE_TYPE (TREE_TYPE (type)))
5644 != char_type_node))
5645 pedwarn ("%Jthird argument of '%D' should probably be "
5646 "'char **'", decl1, decl1);
5647 break;
5651 /* It is intentional that this message does not mention the third
5652 argument because it's only mentioned in an appendix of the
5653 standard. */
5654 if (argct > 0 && (argct < 2 || argct > 3))
5655 pedwarn ("%J'%D' takes only zero or two arguments", decl1, decl1);
5657 if (! TREE_PUBLIC (decl1))
5658 pedwarn ("%J'%D' is normally a non-static function", decl1, decl1);
5661 /* Record the decl so that the function name is defined.
5662 If we already have a decl for this name, and it is a FUNCTION_DECL,
5663 use the old decl. */
5665 current_function_decl = pushdecl (decl1);
5667 pushlevel (0);
5668 declare_parm_level ();
5670 make_decl_rtl (current_function_decl, NULL);
5672 restype = TREE_TYPE (TREE_TYPE (current_function_decl));
5673 /* Promote the value to int before returning it. */
5674 if (c_promoting_integer_type_p (restype))
5676 /* It retains unsignedness if not really getting wider. */
5677 if (TREE_UNSIGNED (restype)
5678 && (TYPE_PRECISION (restype)
5679 == TYPE_PRECISION (integer_type_node)))
5680 restype = unsigned_type_node;
5681 else
5682 restype = integer_type_node;
5684 DECL_RESULT (current_function_decl)
5685 = build_decl (RESULT_DECL, NULL_TREE, restype);
5687 /* If this fcn was already referenced via a block-scope `extern' decl
5688 (or an implicit decl), propagate certain information about the usage. */
5689 if (TREE_ADDRESSABLE (DECL_ASSEMBLER_NAME (current_function_decl)))
5690 TREE_ADDRESSABLE (current_function_decl) = 1;
5692 immediate_size_expand = old_immediate_size_expand;
5694 start_fname_decls ();
5696 return 1;
5699 /* Subroutine of store_parm_decls which handles new-style function
5700 definitions (prototype format). The parms already have decls, so we
5701 need only record them as in effect and complain if any redundant
5702 old-style parm decls were written. */
5703 static void
5704 store_parm_decls_newstyle (void)
5706 tree decl, last;
5707 tree fndecl = current_function_decl;
5708 tree parms = current_function_parms;
5709 tree tags = current_function_parm_tags;
5710 tree others = current_function_parm_others;
5712 if (current_scope->parms || current_scope->names || current_scope->tags)
5714 error ("%Jold-style parameter declarations in prototyped "
5715 "function definition", fndecl);
5717 /* Get rid of the old-style declarations. */
5718 poplevel (0, 0, 0);
5719 pushlevel (0);
5722 /* Now make all the parameter declarations visible in the function body.
5723 We can bypass most of the grunt work of pushdecl. */
5724 for (last = 0, decl = parms; decl; last = decl, decl = TREE_CHAIN (decl))
5726 DECL_CONTEXT (decl) = current_function_decl;
5727 if (DECL_NAME (decl) == 0)
5728 error ("%Jparameter name omitted", decl);
5729 else
5731 if (IDENTIFIER_SYMBOL_VALUE (DECL_NAME (decl)))
5732 current_scope->shadowed
5733 = tree_cons (DECL_NAME (decl),
5734 IDENTIFIER_SYMBOL_VALUE (DECL_NAME (decl)),
5735 current_scope->shadowed);
5736 IDENTIFIER_SYMBOL_VALUE (DECL_NAME (decl)) = decl;
5739 current_scope->parms = parms;
5740 current_scope->parms_last = last;
5742 /* Record the parameter list in the function declaration. */
5743 DECL_ARGUMENTS (fndecl) = parms;
5745 /* Now make all the ancillary declarations visible, likewise. */
5746 for (last = 0, decl = others; decl; last = decl, decl = TREE_CHAIN (decl))
5748 DECL_CONTEXT (decl) = current_function_decl;
5749 if (DECL_NAME (decl)
5750 && TYPE_MAIN_VARIANT (TREE_TYPE (decl)) != void_type_node)
5752 if (IDENTIFIER_SYMBOL_VALUE (DECL_NAME (decl)))
5753 current_scope->shadowed
5754 = tree_cons (DECL_NAME (decl),
5755 IDENTIFIER_SYMBOL_VALUE (DECL_NAME (decl)),
5756 current_scope->shadowed);
5757 IDENTIFIER_SYMBOL_VALUE (DECL_NAME (decl)) = decl;
5760 current_scope->names = others;
5761 current_scope->names_last = last;
5763 /* And all the tag declarations. */
5764 for (decl = tags; decl; decl = TREE_CHAIN (decl))
5765 if (TREE_PURPOSE (decl))
5767 if (IDENTIFIER_TAG_VALUE (TREE_PURPOSE (decl)))
5768 current_scope->shadowed_tags
5769 = tree_cons (TREE_PURPOSE (decl),
5770 IDENTIFIER_SYMBOL_VALUE (TREE_PURPOSE (decl)),
5771 current_scope->shadowed_tags);
5772 IDENTIFIER_TAG_VALUE (TREE_PURPOSE (decl)) = TREE_VALUE (decl);
5774 current_scope->tags = tags;
5777 /* Subroutine of store_parm_decls which handles old-style function
5778 definitions (separate parameter list and declarations). */
5780 static void
5781 store_parm_decls_oldstyle (void)
5783 tree parm, decl, last;
5784 tree fndecl = current_function_decl;
5786 /* This is the identifier list from the function declarator. */
5787 tree parmids = current_function_parms;
5789 /* We use DECL_WEAK as a flag to show which parameters have been
5790 seen already, since it is not used on PARM_DECL. */
5791 #ifdef ENABLE_CHECKING
5792 for (parm = current_scope->parms; parm; parm = TREE_CHAIN (parm))
5793 if (DECL_WEAK (parm))
5794 abort ();
5795 #endif
5797 /* Match each formal parameter name with its declaration. Save each
5798 decl in the appropriate TREE_PURPOSE slot of the parmids chain. */
5799 for (parm = parmids; parm; parm = TREE_CHAIN (parm))
5801 if (TREE_VALUE (parm) == 0)
5803 error ("%Jparameter name missing from parameter list", fndecl);
5804 TREE_PURPOSE (parm) = 0;
5805 continue;
5808 decl = IDENTIFIER_SYMBOL_VALUE (TREE_VALUE (parm));
5809 if (decl && DECL_CONTEXT (decl) == fndecl)
5811 /* If we got something other than a PARM_DECL it is an error. */
5812 if (TREE_CODE (decl) != PARM_DECL)
5813 error ("%J\"%D\" declared as a non-parameter", decl, decl);
5814 /* If the declaration is already marked, we have a duplicate
5815 name. Complain and ignore the duplicate. */
5816 else if (DECL_WEAK (decl))
5818 error ("%Jmultiple parameters named \"%D\"", decl, decl);
5819 TREE_PURPOSE (parm) = 0;
5820 continue;
5822 /* If the declaration says "void", complain and turn it into
5823 an int. */
5824 else if (VOID_TYPE_P (TREE_TYPE (decl)))
5826 error ("%Jparameter \"%D\" declared void", decl, decl);
5827 TREE_TYPE (decl) = integer_type_node;
5828 DECL_ARG_TYPE (decl) = integer_type_node;
5829 layout_decl (decl, 0);
5832 /* If no declaration found, default to int. */
5833 else
5835 decl = build_decl (PARM_DECL, TREE_VALUE (parm), integer_type_node);
5836 DECL_ARG_TYPE (decl) = TREE_TYPE (decl);
5837 DECL_SOURCE_LOCATION (decl) = DECL_SOURCE_LOCATION (fndecl);
5838 pushdecl (decl);
5840 if (flag_isoc99)
5841 pedwarn ("%Jtype of \"%D\" defaults to \"int\"", decl, decl);
5842 else if (extra_warnings)
5843 warning ("%Jtype of \"%D\" defaults to \"int\"", decl, decl);
5846 TREE_PURPOSE (parm) = decl;
5847 DECL_WEAK (decl) = 1;
5850 /* Now examine the parms chain for incomplete declarations
5851 and declarations with no corresponding names. */
5853 for (parm = current_scope->parms; parm; parm = TREE_CHAIN (parm))
5855 if (!COMPLETE_TYPE_P (TREE_TYPE (parm)))
5857 error ("%Jparameter \"%D\" has incomplete type", parm, parm);
5858 TREE_TYPE (parm) = error_mark_node;
5861 if (! DECL_WEAK (parm))
5863 error ("%Jdeclaration for parameter \"%D\" but no such parameter",
5864 parm, parm);
5866 /* Pretend the parameter was not missing.
5867 This gets us to a standard state and minimizes
5868 further error messages. */
5869 parmids = chainon (parmids, tree_cons (parm, 0, 0));
5873 /* Chain the declarations together in the order of the list of
5874 names. Store that chain in the function decl, replacing the
5875 list of names. Update the current scope to match. */
5876 DECL_ARGUMENTS (fndecl) = 0;
5878 for (parm = parmids; parm; parm = TREE_CHAIN (parm))
5879 if (TREE_PURPOSE (parm))
5880 break;
5881 if (parm && TREE_PURPOSE (parm))
5883 last = TREE_PURPOSE (parm);
5884 DECL_ARGUMENTS (fndecl) = last;
5885 current_scope->parms = last;
5886 DECL_WEAK (last) = 0;
5888 for (parm = TREE_CHAIN (parm); parm; parm = TREE_CHAIN (parm))
5889 if (TREE_PURPOSE (parm))
5891 TREE_CHAIN (last) = TREE_PURPOSE (parm);
5892 last = TREE_PURPOSE (parm);
5893 DECL_WEAK (last) = 0;
5895 current_scope->parms_last = last;
5896 TREE_CHAIN (last) = 0;
5899 /* If there was a previous prototype,
5900 set the DECL_ARG_TYPE of each argument according to
5901 the type previously specified, and report any mismatches. */
5903 if (TYPE_ARG_TYPES (TREE_TYPE (fndecl)))
5905 tree type;
5906 for (parm = DECL_ARGUMENTS (fndecl),
5907 type = TYPE_ARG_TYPES (TREE_TYPE (fndecl));
5908 parm || (type && (TYPE_MAIN_VARIANT (TREE_VALUE (type))
5909 != void_type_node));
5910 parm = TREE_CHAIN (parm), type = TREE_CHAIN (type))
5912 if (parm == 0 || type == 0
5913 || TYPE_MAIN_VARIANT (TREE_VALUE (type)) == void_type_node)
5915 error ("number of arguments doesn't match prototype");
5916 error ("%Hprototype declaration",
5917 &current_function_prototype_locus);
5918 break;
5920 /* Type for passing arg must be consistent with that
5921 declared for the arg. ISO C says we take the unqualified
5922 type for parameters declared with qualified type. */
5923 if (! comptypes (TYPE_MAIN_VARIANT (DECL_ARG_TYPE (parm)),
5924 TYPE_MAIN_VARIANT (TREE_VALUE (type)),
5925 COMPARE_STRICT))
5927 if (TYPE_MAIN_VARIANT (TREE_TYPE (parm))
5928 == TYPE_MAIN_VARIANT (TREE_VALUE (type)))
5930 /* Adjust argument to match prototype. E.g. a previous
5931 `int foo(float);' prototype causes
5932 `int foo(x) float x; {...}' to be treated like
5933 `int foo(float x) {...}'. This is particularly
5934 useful for argument types like uid_t. */
5935 DECL_ARG_TYPE (parm) = TREE_TYPE (parm);
5937 if (targetm.calls.promote_prototypes (TREE_TYPE (current_function_decl))
5938 && INTEGRAL_TYPE_P (TREE_TYPE (parm))
5939 && TYPE_PRECISION (TREE_TYPE (parm))
5940 < TYPE_PRECISION (integer_type_node))
5941 DECL_ARG_TYPE (parm) = integer_type_node;
5943 if (pedantic)
5945 pedwarn ("promoted argument \"%D\" "
5946 "doesn't match prototype", parm);
5947 pedwarn ("%Hprototype declaration",
5948 &current_function_prototype_locus);
5951 else
5953 error ("argument \"%D\" doesn't match prototype", parm);
5954 error ("%Hprototype declaration",
5955 &current_function_prototype_locus);
5959 TYPE_ACTUAL_ARG_TYPES (TREE_TYPE (fndecl)) = 0;
5962 /* Otherwise, create a prototype that would match. */
5964 else
5966 tree actual = 0, last = 0, type;
5968 for (parm = DECL_ARGUMENTS (fndecl); parm; parm = TREE_CHAIN (parm))
5970 type = tree_cons (NULL_TREE, DECL_ARG_TYPE (parm), NULL_TREE);
5971 if (last)
5972 TREE_CHAIN (last) = type;
5973 else
5974 actual = type;
5975 last = type;
5977 type = tree_cons (NULL_TREE, void_type_node, NULL_TREE);
5978 if (last)
5979 TREE_CHAIN (last) = type;
5980 else
5981 actual = type;
5983 /* We are going to assign a new value for the TYPE_ACTUAL_ARG_TYPES
5984 of the type of this function, but we need to avoid having this
5985 affect the types of other similarly-typed functions, so we must
5986 first force the generation of an identical (but separate) type
5987 node for the relevant function type. The new node we create
5988 will be a variant of the main variant of the original function
5989 type. */
5991 TREE_TYPE (fndecl) = build_type_copy (TREE_TYPE (fndecl));
5993 TYPE_ACTUAL_ARG_TYPES (TREE_TYPE (fndecl)) = actual;
5997 /* Store the parameter declarations into the current function declaration.
5998 This is called after parsing the parameter declarations, before
5999 digesting the body of the function.
6001 For an old-style definition, construct a prototype out of the old-style
6002 parameter declarations and inject it into the function's type. */
6004 void
6005 store_parm_decls (void)
6007 tree fndecl = current_function_decl;
6009 /* True if this definition is written with a prototype. */
6010 bool prototype = (current_function_parms
6011 && TREE_CODE (current_function_parms) != TREE_LIST);
6013 if (prototype)
6014 store_parm_decls_newstyle ();
6015 else
6016 store_parm_decls_oldstyle ();
6018 /* The next call to pushlevel will be a function body. */
6020 next_is_function_body = true;
6022 /* Write a record describing this function definition to the prototypes
6023 file (if requested). */
6025 gen_aux_info_record (fndecl, 1, 0, prototype);
6027 /* Initialize the RTL code for the function. */
6028 allocate_struct_function (fndecl);
6030 /* Begin the statement tree for this function. */
6031 begin_stmt_tree (&DECL_SAVED_TREE (fndecl));
6033 /* Save away the sizes of any variable-size types so that we can
6034 expand them when generating RTL. */
6035 DECL_LANG_SPECIFIC (fndecl)->pending_sizes = get_pending_sizes ();
6037 /* This function is being processed in whole-function mode. */
6038 cfun->x_whole_function_mode_p = 1;
6040 /* Even though we're inside a function body, we still don't want to
6041 call expand_expr to calculate the size of a variable-sized array.
6042 We haven't necessarily assigned RTL to all variables yet, so it's
6043 not safe to try to expand expressions involving them. */
6044 immediate_size_expand = 0;
6045 cfun->x_dont_save_pending_sizes_p = 1;
6048 /* Finish up a function declaration and compile that function
6049 all the way to assembler language output. The free the storage
6050 for the function definition.
6052 This is called after parsing the body of the function definition. */
6054 void
6055 finish_function (void)
6057 tree fndecl = current_function_decl;
6059 /* When a function declaration is totally empty, e.g.
6060 void foo(void) { }
6061 (the argument list is irrelevant) the compstmt rule will not
6062 bother calling pushlevel/poplevel, which means we get here with
6063 the scope stack out of sync. Detect this situation by noticing
6064 that current_scope is still as store_parm_decls left it, and do
6065 a dummy push/pop to get back to consistency.
6066 Note that the call to pushlevel does not actually push another
6067 scope - see there for details. */
6069 if (current_scope->parm_flag && next_is_function_body)
6071 pushlevel (0);
6072 poplevel (0, 0, 0);
6075 if (TREE_CODE (fndecl) == FUNCTION_DECL
6076 && targetm.calls.promote_prototypes (TREE_TYPE (fndecl)))
6078 tree args = DECL_ARGUMENTS (fndecl);
6079 for (; args; args = TREE_CHAIN (args))
6081 tree type = TREE_TYPE (args);
6082 if (INTEGRAL_TYPE_P (type)
6083 && TYPE_PRECISION (type) < TYPE_PRECISION (integer_type_node))
6084 DECL_ARG_TYPE (args) = integer_type_node;
6088 if (DECL_INITIAL (fndecl) && DECL_INITIAL (fndecl) != error_mark_node)
6089 BLOCK_SUPERCONTEXT (DECL_INITIAL (fndecl)) = fndecl;
6091 /* Must mark the RESULT_DECL as being in this function. */
6093 if (DECL_RESULT (fndecl) && DECL_RESULT (fndecl) != error_mark_node)
6094 DECL_CONTEXT (DECL_RESULT (fndecl)) = fndecl;
6096 if (MAIN_NAME_P (DECL_NAME (fndecl)) && flag_hosted)
6098 if (TYPE_MAIN_VARIANT (TREE_TYPE (TREE_TYPE (fndecl)))
6099 != integer_type_node)
6101 /* If warn_main is 1 (-Wmain) or 2 (-Wall), we have already warned.
6102 If warn_main is -1 (-Wno-main) we don't want to be warned. */
6103 if (!warn_main)
6104 pedwarn ("%Jreturn type of '%D' is not `int'", fndecl, fndecl);
6106 else
6108 #ifdef DEFAULT_MAIN_RETURN
6109 /* Make it so that `main' always returns success by default. */
6110 DEFAULT_MAIN_RETURN;
6111 #else
6112 if (flag_isoc99)
6113 c_expand_return (integer_zero_node);
6114 #endif
6118 finish_fname_decls ();
6120 /* Tie off the statement tree for this function. */
6121 finish_stmt_tree (&DECL_SAVED_TREE (fndecl));
6123 /* Complain if there's just no return statement. */
6124 if (warn_return_type
6125 && TREE_CODE (TREE_TYPE (TREE_TYPE (fndecl))) != VOID_TYPE
6126 && !current_function_returns_value && !current_function_returns_null
6127 /* Don't complain if we abort. */
6128 && !current_function_returns_abnormally
6129 /* Don't warn for main(). */
6130 && !MAIN_NAME_P (DECL_NAME (fndecl))
6131 /* Or if they didn't actually specify a return type. */
6132 && !C_FUNCTION_IMPLICIT_INT (fndecl)
6133 /* Normally, with -Wreturn-type, flow will complain. Unless we're an
6134 inline function, as we might never be compiled separately. */
6135 && DECL_INLINE (fndecl))
6136 warning ("no return statement in function returning non-void");
6138 /* With just -Wextra, complain only if function returns both with
6139 and without a value. */
6140 if (extra_warnings
6141 && current_function_returns_value
6142 && current_function_returns_null)
6143 warning ("this function may return with or without a value");
6145 /* We're leaving the context of this function, so zap cfun. It's still in
6146 DECL_SAVED_INSNS, and we'll restore it in tree_rest_of_compilation. */
6147 cfun = NULL;
6149 /* ??? Objc emits functions after finalizing the compilation unit.
6150 This should be cleaned up later and this conditional removed. */
6151 if (!cgraph_global_info_ready)
6152 cgraph_finalize_function (fndecl, false);
6153 else
6154 c_expand_body (fndecl);
6155 current_function_decl = NULL;
6158 /* Generate the RTL for a deferred function FNDECL. */
6160 void
6161 c_expand_deferred_function (tree fndecl)
6163 /* DECL_INLINE or DECL_RESULT might got cleared after the inline
6164 function was deferred, e.g. in duplicate_decls. */
6165 if (DECL_INLINE (fndecl) && DECL_RESULT (fndecl))
6167 if (flag_inline_trees)
6169 timevar_push (TV_INTEGRATION);
6170 optimize_inline_calls (fndecl);
6171 timevar_pop (TV_INTEGRATION);
6173 c_expand_body (fndecl);
6174 current_function_decl = NULL;
6178 /* Generate the RTL for the body of FNDECL. If NESTED_P is nonzero,
6179 then we are already in the process of generating RTL for another
6180 function. */
6182 static void
6183 c_expand_body_1 (tree fndecl, int nested_p)
6185 if (nested_p)
6186 /* Squirrel away our current state. */
6187 push_function_context ();
6189 /* Make sure that we will evaluate variable-sized types involved
6190 in our function's type. */
6191 put_pending_sizes (DECL_LANG_SPECIFIC (fndecl)->pending_sizes);
6192 tree_rest_of_compilation (fndecl, nested_p);
6194 if (nested_p)
6195 /* Return to the enclosing function. */
6196 pop_function_context ();
6198 if (DECL_STATIC_CONSTRUCTOR (fndecl))
6200 if (targetm.have_ctors_dtors)
6201 (* targetm.asm_out.constructor) (XEXP (DECL_RTL (fndecl), 0),
6202 DEFAULT_INIT_PRIORITY);
6203 else
6204 static_ctors = tree_cons (NULL_TREE, fndecl, static_ctors);
6207 if (DECL_STATIC_DESTRUCTOR (fndecl))
6209 if (targetm.have_ctors_dtors)
6210 (* targetm.asm_out.destructor) (XEXP (DECL_RTL (fndecl), 0),
6211 DEFAULT_INIT_PRIORITY);
6212 else
6213 static_dtors = tree_cons (NULL_TREE, fndecl, static_dtors);
6217 /* Like c_expand_body_1 but only for unnested functions. */
6219 void
6220 c_expand_body (tree fndecl)
6223 if (DECL_INITIAL (fndecl) && DECL_INITIAL (fndecl) != error_mark_node)
6224 c_expand_body_1 (fndecl, 0);
6227 /* Check the declarations given in a for-loop for satisfying the C99
6228 constraints. */
6229 void
6230 check_for_loop_decls (void)
6232 tree t;
6234 if (!flag_isoc99)
6236 /* If we get here, declarations have been used in a for loop without
6237 the C99 for loop scope. This doesn't make much sense, so don't
6238 allow it. */
6239 error ("'for' loop initial declaration used outside C99 mode");
6240 return;
6242 /* C99 subclause 6.8.5 paragraph 3:
6244 [#3] The declaration part of a for statement shall only
6245 declare identifiers for objects having storage class auto or
6246 register.
6248 It isn't clear whether, in this sentence, "identifiers" binds to
6249 "shall only declare" or to "objects" - that is, whether all identifiers
6250 declared must be identifiers for objects, or whether the restriction
6251 only applies to those that are. (A question on this in comp.std.c
6252 in November 2000 received no answer.) We implement the strictest
6253 interpretation, to avoid creating an extension which later causes
6254 problems. */
6256 for (t = current_scope->tags; t; t = TREE_CHAIN (t))
6258 if (TREE_PURPOSE (t) != 0)
6260 enum tree_code code = TREE_CODE (TREE_VALUE (t));
6262 if (code == RECORD_TYPE)
6263 error ("'struct %s' declared in 'for' loop initial declaration",
6264 IDENTIFIER_POINTER (TREE_PURPOSE (t)));
6265 else if (code == UNION_TYPE)
6266 error ("'union %s' declared in 'for' loop initial declaration",
6267 IDENTIFIER_POINTER (TREE_PURPOSE (t)));
6268 else
6269 error ("'enum %s' declared in 'for' loop initial declaration",
6270 IDENTIFIER_POINTER (TREE_PURPOSE (t)));
6274 for (t = getdecls (); t; t = TREE_CHAIN (t))
6276 if (TREE_CODE (t) != VAR_DECL && DECL_NAME (t))
6277 error ("%Jdeclaration of non-variable '%D' in 'for' loop "
6278 "initial declaration", t, t);
6279 else if (TREE_STATIC (t))
6280 error ("%Jdeclaration of static variable '%D' in 'for' loop "
6281 "initial declaration", t, t);
6282 else if (DECL_EXTERNAL (t))
6283 error ("%Jdeclaration of 'extern' variable '%D' in 'for' loop "
6284 "initial declaration", t, t);
6288 /* Save and reinitialize the variables
6289 used during compilation of a C function. */
6291 void
6292 c_push_function_context (struct function *f)
6294 struct language_function *p;
6295 p = ggc_alloc (sizeof (struct language_function));
6296 f->language = p;
6298 p->base.x_stmt_tree = c_stmt_tree;
6299 p->base.x_scope_stmt_stack = c_scope_stmt_stack;
6300 p->x_in_iteration_stmt = c_in_iteration_stmt;
6301 p->x_in_case_stmt = c_in_case_stmt;
6302 p->returns_value = current_function_returns_value;
6303 p->returns_null = current_function_returns_null;
6304 p->returns_abnormally = current_function_returns_abnormally;
6305 p->warn_about_return_type = warn_about_return_type;
6306 p->extern_inline = current_extern_inline;
6309 /* Restore the variables used during compilation of a C function. */
6311 void
6312 c_pop_function_context (struct function *f)
6314 struct language_function *p = f->language;
6316 if (DECL_SAVED_INSNS (current_function_decl) == 0
6317 && DECL_SAVED_TREE (current_function_decl) == NULL_TREE)
6319 /* Stop pointing to the local nodes about to be freed. */
6320 /* But DECL_INITIAL must remain nonzero so we know this
6321 was an actual function definition. */
6322 DECL_INITIAL (current_function_decl) = error_mark_node;
6323 DECL_ARGUMENTS (current_function_decl) = 0;
6326 c_stmt_tree = p->base.x_stmt_tree;
6327 c_scope_stmt_stack = p->base.x_scope_stmt_stack;
6328 c_in_iteration_stmt = p->x_in_iteration_stmt;
6329 c_in_case_stmt = p->x_in_case_stmt;
6330 current_function_returns_value = p->returns_value;
6331 current_function_returns_null = p->returns_null;
6332 current_function_returns_abnormally = p->returns_abnormally;
6333 warn_about_return_type = p->warn_about_return_type;
6334 current_extern_inline = p->extern_inline;
6336 f->language = NULL;
6339 /* Copy the DECL_LANG_SPECIFIC data associated with DECL. */
6341 void
6342 c_dup_lang_specific_decl (tree decl)
6344 struct lang_decl *ld;
6346 if (!DECL_LANG_SPECIFIC (decl))
6347 return;
6349 ld = ggc_alloc (sizeof (struct lang_decl));
6350 memcpy (ld, DECL_LANG_SPECIFIC (decl), sizeof (struct lang_decl));
6351 DECL_LANG_SPECIFIC (decl) = ld;
6354 /* The functions below are required for functionality of doing
6355 function at once processing in the C front end. Currently these
6356 functions are not called from anywhere in the C front end, but as
6357 these changes continue, that will change. */
6359 /* Returns nonzero if the current statement is a full expression,
6360 i.e. temporaries created during that statement should be destroyed
6361 at the end of the statement. */
6364 stmts_are_full_exprs_p (void)
6366 return 0;
6369 /* Returns the stmt_tree (if any) to which statements are currently
6370 being added. If there is no active statement-tree, NULL is
6371 returned. */
6373 stmt_tree
6374 current_stmt_tree (void)
6376 return &c_stmt_tree;
6379 /* Returns the stack of SCOPE_STMTs for the current function. */
6381 tree *
6382 current_scope_stmt_stack (void)
6384 return &c_scope_stmt_stack;
6387 /* Nonzero if TYPE is an anonymous union or struct type. Always 0 in
6388 C. */
6391 anon_aggr_type_p (tree node ATTRIBUTE_UNUSED)
6393 return 0;
6396 /* Dummy function in place of callback used by C++. */
6398 void
6399 extract_interface_info (void)
6403 /* Return a new COMPOUND_STMT, after adding it to the current
6404 statement tree. */
6406 tree
6407 c_begin_compound_stmt (void)
6409 tree stmt;
6411 /* Create the COMPOUND_STMT. */
6412 stmt = add_stmt (build_stmt (COMPOUND_STMT, error_mark_node));
6414 return stmt;
6417 /* Expand T (a DECL_STMT) if it declares an entity not handled by the
6418 common code. */
6420 void
6421 c_expand_decl_stmt (tree t)
6423 tree decl = DECL_STMT_DECL (t);
6425 /* Expand nested functions. */
6426 if (TREE_CODE (decl) == FUNCTION_DECL
6427 && DECL_CONTEXT (decl) == current_function_decl
6428 && DECL_SAVED_TREE (decl))
6429 c_expand_body_1 (decl, 1);
6432 /* Return the global value of T as a symbol. */
6434 tree
6435 identifier_global_value (tree t)
6437 tree decl = IDENTIFIER_SYMBOL_VALUE (t);
6438 if (decl == 0 || DECL_FILE_SCOPE_P (decl))
6439 return decl;
6441 /* Shadowed by something else; find the true global value. */
6442 for (decl = global_scope->names; decl; decl = TREE_CHAIN (decl))
6443 if (DECL_NAME (decl) == t)
6444 return decl;
6446 /* Only local values for this decl. */
6447 return 0;
6450 /* Record a builtin type for C. If NAME is non-NULL, it is the name used;
6451 otherwise the name is found in ridpointers from RID_INDEX. */
6453 void
6454 record_builtin_type (enum rid rid_index, const char *name, tree type)
6456 tree id;
6457 if (name == 0)
6458 id = ridpointers[(int) rid_index];
6459 else
6460 id = get_identifier (name);
6461 pushdecl (build_decl (TYPE_DECL, id, type));
6464 /* Build the void_list_node (void_type_node having been created). */
6465 tree
6466 build_void_list_node (void)
6468 tree t = build_tree_list (NULL_TREE, void_type_node);
6469 return t;
6472 /* Return something to represent absolute declarators containing a *.
6473 TARGET is the absolute declarator that the * contains.
6474 TYPE_QUALS_ATTRS is a list of modifiers such as const or volatile
6475 to apply to the pointer type, represented as identifiers, possible mixed
6476 with attributes.
6478 We return an INDIRECT_REF whose "contents" are TARGET (inside a TREE_LIST,
6479 if attributes are present) and whose type is the modifier list. */
6481 tree
6482 make_pointer_declarator (tree type_quals_attrs, tree target)
6484 tree quals, attrs;
6485 tree itarget = target;
6486 split_specs_attrs (type_quals_attrs, &quals, &attrs);
6487 if (attrs != NULL_TREE)
6488 itarget = tree_cons (attrs, target, NULL_TREE);
6489 return build1 (INDIRECT_REF, quals, itarget);
6492 /* A wrapper around lhd_set_decl_assembler_name that gives static
6493 variables their C names if they are at file scope and only one
6494 translation unit is being compiled, for backwards compatibility
6495 with certain bizarre assembler hacks (like crtstuff.c). */
6497 void
6498 c_static_assembler_name (tree decl)
6500 if (num_in_fnames == 1
6501 && !TREE_PUBLIC (decl) && DECL_CONTEXT (decl)
6502 && TREE_CODE (DECL_CONTEXT (decl)) == TRANSLATION_UNIT_DECL)
6503 SET_DECL_ASSEMBLER_NAME (decl, DECL_NAME (decl));
6504 else
6505 lhd_set_decl_assembler_name (decl);
6508 /* Hash and equality functions for link_hash_table: key off
6509 DECL_ASSEMBLER_NAME. */
6511 static hashval_t
6512 link_hash_hash (const void *x_p)
6514 tree x = (tree)x_p;
6515 return (hashval_t) (long)DECL_ASSEMBLER_NAME (x);
6518 static int
6519 link_hash_eq (const void *x1_p, const void *x2_p)
6521 tree x1 = (tree)x1_p;
6522 tree x2 = (tree)x2_p;
6523 return DECL_ASSEMBLER_NAME (x1) == DECL_ASSEMBLER_NAME (x2);
6526 /* Propagate information between definitions and uses between multiple
6527 translation units in TU_LIST based on linkage rules. */
6529 void
6530 merge_translation_unit_decls (void)
6532 const tree tu_list = current_file_decl;
6533 tree tu;
6534 tree decl;
6535 htab_t link_hash_table;
6536 tree block;
6538 /* Create the BLOCK that poplevel would have created, but don't
6539 actually call poplevel since that's expensive. */
6540 block = make_node (BLOCK);
6541 BLOCK_VARS (block) = current_scope->names;
6542 TREE_USED (block) = 1;
6543 DECL_INITIAL (current_file_decl) = block;
6545 /* If only one translation unit seen, no copying necessary. */
6546 if (TREE_CHAIN (tu_list) == NULL_TREE)
6547 return;
6549 link_hash_table = htab_create (1021, link_hash_hash, link_hash_eq, NULL);
6551 /* Enter any actual definitions into the hash table. */
6552 for (tu = tu_list; tu; tu = TREE_CHAIN (tu))
6553 for (decl = BLOCK_VARS (DECL_INITIAL (tu)); decl; decl = TREE_CHAIN (decl))
6554 if (TREE_PUBLIC (decl) && ! DECL_EXTERNAL (decl))
6556 PTR *slot;
6557 slot = htab_find_slot (link_hash_table, decl, INSERT);
6559 /* If we've already got a definition, work out which one is
6560 the real one, put it into the hash table, and make the
6561 other one DECL_EXTERNAL. This is important to avoid
6562 putting out two definitions of the same symbol in the
6563 assembly output. */
6564 if (*slot != NULL)
6566 tree old_decl = (tree) *slot;
6568 /* If this is weak or common or whatever, suppress it
6569 in favor of the other definition. */
6570 if (DECL_WEAK (decl))
6571 DECL_EXTERNAL (decl) = 1;
6572 else if (DECL_WEAK (old_decl) && ! DECL_WEAK (decl))
6573 DECL_EXTERNAL (old_decl) = 1;
6574 else if (DECL_COMMON (decl) || DECL_ONE_ONLY (decl))
6575 DECL_EXTERNAL (decl) = 1;
6576 else if (DECL_COMMON (old_decl) || DECL_ONE_ONLY (old_decl))
6577 DECL_EXTERNAL (old_decl) = 1;
6579 if (DECL_EXTERNAL (decl))
6581 DECL_INITIAL (decl) = NULL_TREE;
6582 DECL_COMMON (decl) = 0;
6583 DECL_ONE_ONLY (decl) = 0;
6584 DECL_WEAK (decl) = 0;
6586 else if (DECL_EXTERNAL (old_decl))
6588 DECL_INITIAL (old_decl) = NULL_TREE;
6589 DECL_COMMON (old_decl) = 0;
6590 DECL_ONE_ONLY (old_decl) = 0;
6591 DECL_WEAK (old_decl) = 0;
6592 *slot = decl;
6594 else
6596 error ("%Jredefinition of global '%D'", decl, decl);
6597 error ("%J'%D' previously defined here", old_decl, old_decl);
6600 else
6601 *slot = decl;
6604 /* Now insert the desired information from all the definitions
6605 into any plain declarations. */
6606 for (tu = tu_list; tu; tu = TREE_CHAIN (tu))
6607 for (decl = BLOCK_VARS (DECL_INITIAL (tu)); decl; decl = TREE_CHAIN (decl))
6608 if (TREE_PUBLIC (decl) && DECL_EXTERNAL (decl))
6610 tree global_decl;
6611 global_decl = htab_find (link_hash_table, decl);
6613 if (! global_decl)
6614 continue;
6616 /* Print any appropriate error messages, and partially merge
6617 the decls. */
6618 (void) duplicate_decls (decl, global_decl);
6621 htab_delete (link_hash_table);
6624 /* Perform final processing on file-scope data. */
6626 void
6627 c_write_global_declarations(void)
6629 tree link;
6631 for (link = current_file_decl; link; link = TREE_CHAIN (link))
6633 tree globals = BLOCK_VARS (DECL_INITIAL (link));
6634 int len = list_length (globals);
6635 tree *vec = xmalloc (sizeof (tree) * len);
6636 int i;
6637 tree decl;
6639 /* Process the decls in the order they were written. */
6641 for (i = 0, decl = globals; i < len; i++, decl = TREE_CHAIN (decl))
6642 vec[i] = decl;
6644 wrapup_global_declarations (vec, len);
6646 check_global_declarations (vec, len);
6648 /* Clean up. */
6649 free (vec);
6653 /* Reset the parser's state in preparation for a new file. */
6655 void
6656 c_reset_state (void)
6658 tree link;
6659 tree file_scope_decl;
6661 /* Pop the global scope. */
6662 if (current_scope != global_scope)
6663 current_scope = global_scope;
6664 file_scope_decl = current_file_decl;
6665 DECL_INITIAL (file_scope_decl) = poplevel (1, 0, 0);
6666 BLOCK_SUPERCONTEXT (DECL_INITIAL (file_scope_decl)) = file_scope_decl;
6667 truly_local_externals = NULL_TREE;
6669 /* Start a new global binding level. */
6670 pushlevel (0);
6671 global_scope = current_scope;
6672 current_file_decl = build_decl (TRANSLATION_UNIT_DECL, NULL, NULL);
6673 TREE_CHAIN (current_file_decl) = file_scope_decl;
6675 /* Reintroduce the builtin declarations. */
6676 for (link = first_builtin_decl;
6677 link != TREE_CHAIN (last_builtin_decl);
6678 link = TREE_CHAIN (link))
6679 pushdecl (copy_node (link));
6682 #include "gt-c-decl.h"