From: Eric Botcazou Date: Wed, 6 Mar 2013 18:00:50 +0000 (+0000) Subject: decl.c (gnat_to_gnu_field): Remove the wrapper around a misaligned integral type... X-Git-Tag: upstream/12.2.0~70961 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=afb0fadf9d4128d2e7f508535fc070beb161ffc2;p=platform%2Fupstream%2Fgcc.git decl.c (gnat_to_gnu_field): Remove the wrapper around a misaligned integral type if... * gcc-interface/decl.c (gnat_to_gnu_field): Remove the wrapper around a misaligned integral type if a size is specified for the field. From-SVN: r196506 --- diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog index 9c6df96..4f0478a 100644 --- a/gcc/ada/ChangeLog +++ b/gcc/ada/ChangeLog @@ -1,4 +1,9 @@ -2013-06-03 Eric Botcazou +2013-03-06 Eric Botcazou + + * gcc-interface/decl.c (gnat_to_gnu_field): Remove the wrapper around + a misaligned integral type if a size is specified for the field. + +2013-03-06 Eric Botcazou * gcc-interface/trans.c (Raise_Error_to_gnu) : Record the unpadded type of the index type on the RCI stack. diff --git a/gcc/ada/gcc-interface/decl.c b/gcc/ada/gcc-interface/decl.c index 56b64a3..7342fa3 100644 --- a/gcc/ada/gcc-interface/decl.c +++ b/gcc/ada/gcc-interface/decl.c @@ -6619,6 +6619,13 @@ gnat_to_gnu_field (Entity_Id gnat_field, tree gnu_record_type, int packed, <= 0) gnu_field_type = TREE_TYPE (TYPE_FIELDS (gnu_field_type)); + /* Similarly if the field's type is a misaligned integral type, but + there is no restriction on the size as there is no justification. */ + if (!needs_strict_alignment + && TYPE_IS_PADDING_P (gnu_field_type) + && INTEGRAL_TYPE_P (TREE_TYPE (TYPE_FIELDS (gnu_field_type)))) + gnu_field_type = TREE_TYPE (TYPE_FIELDS (gnu_field_type)); + gnu_field_type = make_type_from_size (gnu_field_type, gnu_size, Has_Biased_Representation (gnat_field)); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 393e5a4..824f5f9 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,4 +1,8 @@ -2013-06-03 Eric Botcazou +2013-03-06 Eric Botcazou + + * gnat.dg/specs/aggr6.ads: New test. + +2013-03-06 Eric Botcazou * gnat.dg/loop_optimization15.ad[sb]: New test. diff --git a/gcc/testsuite/gnat.dg/specs/aggr6.ads b/gcc/testsuite/gnat.dg/specs/aggr6.ads new file mode 100644 index 0000000..8144105 --- /dev/null +++ b/gcc/testsuite/gnat.dg/specs/aggr6.ads @@ -0,0 +1,25 @@ +-- { dg-do compile } + +package Aggr6 is + + type B15_T is mod 2 ** 15; + for B15_T'Size use 15; + for B15_T'Alignment use 1; + + type B17_T is mod 2 ** 17; + for B17_T'Size use 17; + for B17_T'Alignment use 1; + + type Rec_T is record + A : B17_T; + B : B15_T; + end record; + for Rec_T use record + A at 0 range 0 .. 16; + B at 0 range 17 .. 31; + end record; + for Rec_T'Size use 32; + + C : constant Rec_T := (A => 1, B => 0); + +end Aggr6;