source: arduino-1-6-7/trunk/fuentes/arduino-ide-amd64/hardware/tools/avr/lib/gcc/avr/4.9.2/plugin/include/stor-layout.h @ 4837

Last change on this file since 4837 was 4837, checked in by daduve, 2 years ago

Adding new version

File size: 4.9 KB
Line 
1/* Definitions and declarations for stor-layout.c.
2   Copyright (C) 2013-2014 Free Software Foundation, Inc.
3
4This file is part of GCC.
5
6GCC is free software; you can redistribute it and/or modify it under
7the terms of the GNU General Public License as published by the Free
8Software Foundation; either version 3, or (at your option) any later
9version.
10
11GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12WARRANTY; without even the implied warranty of MERCHANTABILITY or
13FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
14for more details.
15
16You should have received a copy of the GNU General Public License
17along with GCC; see the file COPYING3.  If not see
18<http://www.gnu.org/licenses/>.  */
19
20#ifndef GCC_STOR_LAYOUT_H
21#define GCC_STOR_LAYOUT_H
22
23extern void set_min_and_max_values_for_integral_type (tree, int, bool);
24extern void fixup_signed_type (tree);
25extern void internal_reference_types (void);
26extern unsigned int update_alignment_for_field (record_layout_info, tree,
27                                                unsigned int);
28extern record_layout_info start_record_layout (tree);
29extern tree bit_from_pos (tree, tree);
30extern tree byte_from_pos (tree, tree);
31extern void pos_from_bit (tree *, tree *, unsigned int, tree);
32extern void normalize_offset (tree *, tree *, unsigned int);
33extern tree rli_size_unit_so_far (record_layout_info);
34extern tree rli_size_so_far (record_layout_info);
35extern void normalize_rli (record_layout_info);
36extern void place_field (record_layout_info, tree);
37extern void compute_record_mode (tree);
38extern void finish_record_layout (record_layout_info, int);
39extern unsigned int element_precision (const_tree);
40extern void finalize_size_functions (void);
41extern void fixup_unsigned_type (tree);
42extern void initialize_sizetypes (void);
43
44/* Finish up a builtin RECORD_TYPE. Give it a name and provide its
45   fields. Optionally specify an alignment, and then lay it out.  */
46extern void finish_builtin_struct (tree, const char *, tree, tree);
47
48/* Given a VAR_DECL, PARM_DECL, RESULT_DECL or FIELD_DECL node,
49   calculates the DECL_SIZE, DECL_SIZE_UNIT, DECL_ALIGN and DECL_MODE
50   fields.  Call this only once for any given decl node.
51
52   Second argument is the boundary that this field can be assumed to
53   be starting at (in bits).  Zero means it can be assumed aligned
54   on any boundary that may be needed.  */
55extern void layout_decl (tree, unsigned);
56
57/* Given a ..._TYPE node, calculate the TYPE_SIZE, TYPE_SIZE_UNIT,
58   TYPE_ALIGN and TYPE_MODE fields.  If called more than once on one
59   node, does nothing except for the first time.  */
60extern void layout_type (tree);
61
62/* Construct various nodes representing fract or accum data types.  */
63extern tree make_fract_type (int, int, int);
64extern tree make_accum_type (int, int, int);
65
66#define make_signed_fract_type(P) make_fract_type (P, 0, 0)
67#define make_unsigned_fract_type(P) make_fract_type (P, 1, 0)
68#define make_sat_signed_fract_type(P) make_fract_type (P, 0, 1)
69#define make_sat_unsigned_fract_type(P) make_fract_type (P, 1, 1)
70#define make_signed_accum_type(P) make_accum_type (P, 0, 0)
71#define make_unsigned_accum_type(P) make_accum_type (P, 1, 0)
72#define make_sat_signed_accum_type(P) make_accum_type (P, 0, 1)
73#define make_sat_unsigned_accum_type(P) make_accum_type (P, 1, 1)
74
75#define make_or_reuse_signed_fract_type(P) \
76                make_or_reuse_fract_type (P, 0, 0)
77#define make_or_reuse_unsigned_fract_type(P) \
78                make_or_reuse_fract_type (P, 1, 0)
79#define make_or_reuse_sat_signed_fract_type(P) \
80                make_or_reuse_fract_type (P, 0, 1)
81#define make_or_reuse_sat_unsigned_fract_type(P) \
82                make_or_reuse_fract_type (P, 1, 1)
83#define make_or_reuse_signed_accum_type(P) \
84                make_or_reuse_accum_type (P, 0, 0)
85#define make_or_reuse_unsigned_accum_type(P) \
86                make_or_reuse_accum_type (P, 1, 0)
87#define make_or_reuse_sat_signed_accum_type(P) \
88                make_or_reuse_accum_type (P, 0, 1)
89#define make_or_reuse_sat_unsigned_accum_type(P) \
90                make_or_reuse_accum_type (P, 1, 1)
91
92extern tree make_signed_type (int);
93extern tree make_unsigned_type (int);
94
95/* Return the mode for data of a given size SIZE and mode class CLASS.
96   If LIMIT is nonzero, then don't use modes bigger than MAX_FIXED_MODE_SIZE.
97   The value is BLKmode if no other mode is found.  This is like
98   mode_for_size, but is passed a tree.  */
99extern enum machine_mode mode_for_size_tree (const_tree, enum mode_class, int);
100
101/* Given a VAR_DECL, PARM_DECL or RESULT_DECL, clears the results of
102   a previous call to layout_decl and calls it again.  */
103extern void relayout_decl (tree);
104
105/* variable_size (EXP) is like save_expr (EXP) except that it
106   is for the special case of something that is part of a
107   variable size for a data type.  It makes special arrangements
108   to compute the value at the right time when the data type
109   belongs to a function parameter.  */
110extern tree variable_size (tree);
111
112/* Vector types need to check target flags to determine type.  */
113extern enum machine_mode vector_type_mode (const_tree);
114
115#endif  // GCC_STOR_LAYOUT_H
Note: See TracBrowser for help on using the repository browser.