expr.c (get_inner_reference): Use sbitsizetype for type sizes.
* expr.c (get_inner_reference): Use sbitsizetype for type sizes.
* fold-const.c (size_int): Replace with
(size_int_wide).
(make_bit_field_ref): Use bitsize_int for bit position.
* stor-layout.c (sizetype): Delete.
(sizetype_tab, sbitsizetype, ubitsizetype): Declare.
(layout_record, layout_union, layout_type):
Use bitsize_int for bit size.
(set_sizetype): New function.
(make_signed_type, make_unsigned_type): Use it.
* c-decl.c (init_decl_processing): Likewise.
* tree.h (size_int): Don't delcare, #define.
(size_int_wide, sizetype_tab, sbitsize, ubitsize): Declare.
(set_sizetype): Declare.
(bitsize_int, size_int_2, BITS_PER_UNIT_LOG, sizetype, bitsizetype):
Define.
* c-typeck.c (c_sizeof, c_sizeof_nowarn, c_size_in_bytes):
Convert result to sizetype.
(really_start_incremental_init, push_init_level):
Set type of constructor_bit_index to sbitsizetype.
(push_init_level): Use unsigned arithmetic to determine padding.
(output_init_element): Likewise.
From-SVN: r17577
1998-02-01 06:47:59 -05:00
|
|
|
Right now there is no documentation for the GCC tree -> rtl interfaces
|
|
|
|
(or more generally the interfaces for adding new languages).
|
|
|
|
|
|
|
|
Such documentation would be of great benefit to the project. Until such
|
|
|
|
time as we can formally start documenting the interface this file will
|
|
|
|
serve as a repository for information on these interface and any incompatable
|
|
|
|
changes we've made.
|
|
|
|
|
1998-09-02 05:59:57 -04:00
|
|
|
Aug 31, 1998:
|
|
|
|
The interface to HANDLE_PRAGMA has changed. It now takes three arguments.
|
|
|
|
The first two are pointers to functions that should be used to read characters
|
|
|
|
from the input stream, and to push them back into the input stream respectively.
|
|
|
|
The third argument is a pointer to a null terminate string which is the first
|
|
|
|
word after #pragma. The expression supplied by HANDLE_PRAGMA should return
|
|
|
|
non-zero if it parsed and implemented the pragma. Otherwise it should return
|
|
|
|
zero, and leave the input stream as it was before the expression was evaluated.
|
|
|
|
|
|
|
|
A new back-end definable macro has been added: INSERT_ATTRIBUTES. This macro
|
|
|
|
allows backend to add attributes to decls as they are created.
|
|
|
|
|
1998-06-10 06:12:36 -04:00
|
|
|
Jun 10, 1998:
|
|
|
|
The interface to lang_decode_option has changed. It now uses and argc/argv
|
|
|
|
interface to allow for options that use more than one input string. The new
|
|
|
|
declaration is: int lang_decode_option (int argc, char** argv). It now
|
|
|
|
returns the number of input strings processed, or 0 if the option is
|
|
|
|
unknown.
|
|
|
|
|
1998-06-07 10:06:47 -04:00
|
|
|
Jun 7, 1998:
|
|
|
|
Front-ends must now define lang_init_options. It is safe for this
|
|
|
|
function to do nothing. See c-lang.c.
|
|
|
|
|
1998-04-21 09:25:56 -04:00
|
|
|
Apr 21, 1998:
|
|
|
|
Front ends which link with c-common or other files from the C/C++
|
|
|
|
front-ends may need to handle TI types. Look for references to
|
|
|
|
[unsigned]int_DI_type_node in your front end. If you have references
|
|
|
|
to these variables, you'll need up update the front end.
|
|
|
|
|
|
|
|
To update the front end you must mirror all the code which currently
|
|
|
|
deals with intDI_type_node to also handle intTI_type_node.
|
|
|
|
|
|
|
|
|
1998-04-09 06:55:36 -04:00
|
|
|
Apr 7, 1998:
|
|
|
|
The interface between toplev.c and the language front ends for opening the
|
|
|
|
source file has changed:
|
|
|
|
|
|
|
|
o init_lex() has been renamed to init_parse (char *filename) where filename
|
|
|
|
is the name of the source file.
|
|
|
|
o The code in toplev.c which opened the source file should be moved to
|
|
|
|
the new init_parse function.
|
|
|
|
o toplev.c now calls finish_parse() instead of closing the source file
|
|
|
|
using fclose(). This should now be done in finish_parse, if necessary.
|
|
|
|
|
1998-04-08 07:40:54 -04:00
|
|
|
Apr 1, 1998:
|
|
|
|
Front-ends must now define lang_print_xnode. It is safe for this
|
|
|
|
function to do nothing. See c-lang.c.
|
expr.c (get_inner_reference): Use sbitsizetype for type sizes.
* expr.c (get_inner_reference): Use sbitsizetype for type sizes.
* fold-const.c (size_int): Replace with
(size_int_wide).
(make_bit_field_ref): Use bitsize_int for bit position.
* stor-layout.c (sizetype): Delete.
(sizetype_tab, sbitsizetype, ubitsizetype): Declare.
(layout_record, layout_union, layout_type):
Use bitsize_int for bit size.
(set_sizetype): New function.
(make_signed_type, make_unsigned_type): Use it.
* c-decl.c (init_decl_processing): Likewise.
* tree.h (size_int): Don't delcare, #define.
(size_int_wide, sizetype_tab, sbitsize, ubitsize): Declare.
(set_sizetype): Declare.
(bitsize_int, size_int_2, BITS_PER_UNIT_LOG, sizetype, bitsizetype):
Define.
* c-typeck.c (c_sizeof, c_sizeof_nowarn, c_size_in_bytes):
Convert result to sizetype.
(really_start_incremental_init, push_init_level):
Set type of constructor_bit_index to sbitsizetype.
(push_init_level): Use unsigned arithmetic to determine padding.
(output_init_element): Likewise.
From-SVN: r17577
1998-02-01 06:47:59 -05:00
|
|
|
|
|
|
|
Feb 1, 1998:
|
|
|
|
|
|
|
|
GCC used to store structure sizes & offsets to elements as bitsize
|
|
|
|
quantities. This causes problems because a structure can only be
|
|
|
|
(target memsize / 8) bytes long (this may effect arrays too). This
|
|
|
|
is particularly problematical on machines with small address spaces.
|
|
|
|
|
|
|
|
So:
|
|
|
|
|
|
|
|
All trees that represent sizes in bits should have a TREE_TYPE of
|
|
|
|
bitsizetype (rather than sizetype).
|
|
|
|
|
|
|
|
Accordingly, when such values are computed / initialized, care has to
|
|
|
|
be takes to use / compute the proper type.
|
|
|
|
|
|
|
|
When a size in bits is converted into a size in bytes, which is expressed
|
|
|
|
in trees, care should be taken to change the tree's type again to sizetype.
|
|
|
|
|
|
|
|
We've updated C, C++, Fortran & Objective-C to work with the new
|
|
|
|
scheme. Other languages will need to be updated accordingly.
|
|
|
|
Contact amylaar@cygnus.com for additional information.
|
|
|
|
|
1998-02-05 08:55:13 -05:00
|
|
|
?? 1997:
|
expr.c (get_inner_reference): Use sbitsizetype for type sizes.
* expr.c (get_inner_reference): Use sbitsizetype for type sizes.
* fold-const.c (size_int): Replace with
(size_int_wide).
(make_bit_field_ref): Use bitsize_int for bit position.
* stor-layout.c (sizetype): Delete.
(sizetype_tab, sbitsizetype, ubitsizetype): Declare.
(layout_record, layout_union, layout_type):
Use bitsize_int for bit size.
(set_sizetype): New function.
(make_signed_type, make_unsigned_type): Use it.
* c-decl.c (init_decl_processing): Likewise.
* tree.h (size_int): Don't delcare, #define.
(size_int_wide, sizetype_tab, sbitsize, ubitsize): Declare.
(set_sizetype): Declare.
(bitsize_int, size_int_2, BITS_PER_UNIT_LOG, sizetype, bitsizetype):
Define.
* c-typeck.c (c_sizeof, c_sizeof_nowarn, c_size_in_bytes):
Convert result to sizetype.
(really_start_incremental_init, push_init_level):
Set type of constructor_bit_index to sbitsizetype.
(push_init_level): Use unsigned arithmetic to determine padding.
(output_init_element): Likewise.
From-SVN: r17577
1998-02-01 06:47:59 -05:00
|
|
|
|
1998-02-05 08:55:13 -05:00
|
|
|
In an effort to decrease cache thrashing and useless loads we've changed the
|
|
|
|
third argument to the DEFTREECODE macro to be a single char. This will
|
|
|
|
effect languages that defined their own tree codes (usually in a .def file).
|
|
|
|
|
|
|
|
Old way:
|
|
|
|
|
|
|
|
DEFTREECODE (CLASS_METHOD_DECL, "class_method_decl", "d", 0)
|
|
|
|
|
|
|
|
New way:
|
|
|
|
|
|
|
|
DEFTREECODE (CLASS_METHOD_DECL, "class_method_decl", 'd', 0)
|