1 /****************************************************************************
3 * GNAT COMPILER COMPONENTS *
9 * Copyright (C) 1992-2009, Free Software Foundation, Inc. *
11 * GNAT is free software; you can redistribute it and/or modify it under *
12 * terms of the GNU General Public License as published by the Free Soft- *
13 * ware Foundation; either version 3, or (at your option) any later ver- *
14 * sion. GNAT is distributed in the hope that it will be useful, but WITH- *
15 * OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY *
16 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License *
17 * for more details. You should have received a copy of the GNU General *
18 * Public License distributed with GNAT; see file COPYING3. If not see *
19 * <http://www.gnu.org/licenses/>. *
21 * GNAT was originally developed by the GNAT team at New York University. *
22 * Extensive contributions were provided by Ada Core Technologies Inc. *
24 ****************************************************************************/
26 /* Functions for retrieving target types. See Ada package Get_Targ */
30 #include "coretypes.h"
51 /* If we don't have a specific size for Ada's equivalent of `long', use that
53 #ifndef ADA_LONG_TYPE_SIZE
54 #define ADA_LONG_TYPE_SIZE LONG_TYPE_SIZE
57 #ifndef WIDEST_HARDWARE_FP_SIZE
58 #define WIDEST_HARDWARE_FP_SIZE LONG_DOUBLE_TYPE_SIZE
61 /* The following provide a functional interface for the front end Ada code
62 to determine the sizes that are used for various C types. */
65 get_target_bits_per_unit (void)
71 get_target_bits_per_word (void)
77 get_target_char_size (void)
79 return CHAR_TYPE_SIZE;
83 get_target_wchar_t_size (void)
85 /* We never want wide characters less than "short" in Ada. */
86 return MAX (SHORT_TYPE_SIZE, WCHAR_TYPE_SIZE);
90 get_target_short_size (void)
92 return SHORT_TYPE_SIZE;
96 get_target_int_size (void)
102 get_target_long_size (void)
104 return ADA_LONG_TYPE_SIZE;
108 get_target_long_long_size (void)
110 return LONG_LONG_TYPE_SIZE;
114 get_target_float_size (void)
116 return fp_prec_to_size (FLOAT_TYPE_SIZE);
120 get_target_double_size (void)
122 return fp_prec_to_size (DOUBLE_TYPE_SIZE);
126 get_target_long_double_size (void)
128 return fp_prec_to_size (WIDEST_HARDWARE_FP_SIZE);
133 get_target_pointer_size (void)
138 /* Alignment related values, mapped to attributes for functional and
139 documentation purposes. */
141 /* Standard'Maximum_Default_Alignment. Maximum alignment that the compiler
142 might choose by default for a type or object.
144 Stricter alignment requests trigger gigi's aligning_type circuitry for
145 stack objects or objects allocated by the default allocator. */
148 get_target_maximum_default_alignment (void)
150 return BIGGEST_ALIGNMENT / BITS_PER_UNIT;
153 /* Standard'Default_Allocator_Alignment. Alignment guaranteed to be honored
154 by the default allocator (System.Memory.Alloc or malloc if we have no
155 run-time library at hand).
157 Stricter alignment requests trigger gigi's aligning_type circuitry for
158 objects allocated by the default allocator. */
160 /* ??? Need a way to get info about __gnat_malloc from here (whether it is
161 handy and what alignment it honors). In the meantime, resort to malloc
162 considerations only. */
165 get_target_default_allocator_alignment (void)
167 return MALLOC_ABI_ALIGNMENT / BITS_PER_UNIT;
170 /* Standard'Maximum_Allowed_Alignment. Maximum alignment that we may
171 accept for any type or object. */
173 #ifndef MAX_OFILE_ALIGNMENT
174 #define MAX_OFILE_ALIGNMENT BIGGEST_ALIGNMENT
178 get_target_maximum_allowed_alignment (void)
180 return MAX_OFILE_ALIGNMENT / BITS_PER_UNIT;
183 /* Standard'Maximum_Alignment. The single attribute initially made
184 available, now a synonym of Standard'Maximum_Default_Alignment. */
187 get_target_maximum_alignment (void)
189 return get_target_maximum_default_alignment ();
192 #ifndef FLOAT_WORDS_BIG_ENDIAN
193 #define FLOAT_WORDS_BIG_ENDIAN WORDS_BIG_ENDIAN
197 get_float_words_be (void)
199 return FLOAT_WORDS_BIG_ENDIAN;
205 return WORDS_BIG_ENDIAN;
211 return BYTES_BIG_ENDIAN;
217 return BITS_BIG_ENDIAN;
221 get_strict_alignment (void)
223 return STRICT_ALIGNMENT;