aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorEric Botcazou <ebotcazou@adacore.com>2011-03-26 10:18:54 +0000
committerEric Botcazou <ebotcazou@gcc.gnu.org>2011-03-26 10:18:54 +0000
commit51c7954daf0d223599ad0aeea64b63816ee1e354 (patch)
tree5584c686f2c797da62ca728685356ce85163698f /gcc
parent6ddf9843628ab87261d2ec8dc3d14ac057e76014 (diff)
downloadgcc-51c7954daf0d223599ad0aeea64b63816ee1e354.zip
gcc-51c7954daf0d223599ad0aeea64b63816ee1e354.tar.gz
gcc-51c7954daf0d223599ad0aeea64b63816ee1e354.tar.bz2
decl.c (gnat_to_gnu_entity): Create TYPE_DECL for the padded type built to support a specified size or alignment.
* gcc-interface/decl.c (gnat_to_gnu_entity) <object>: Create TYPE_DECL for the padded type built to support a specified size or alignment. From-SVN: r171554
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ada/ChangeLog5
-rw-r--r--gcc/ada/gcc-interface/decl.c17
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gnat.dg/discr27.adb31
-rw-r--r--gcc/testsuite/gnat.dg/discr27.ads7
5 files changed, 61 insertions, 3 deletions
diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog
index a4d45a5..91725e4 100644
--- a/gcc/ada/ChangeLog
+++ b/gcc/ada/ChangeLog
@@ -1,5 +1,10 @@
2011-03-26 Eric Botcazou <ebotcazou@adacore.com>
+ * gcc-interface/decl.c (gnat_to_gnu_entity) <object>: Create TYPE_DECL
+ for the padded type built to support a specified size or alignment.
+
+2011-03-26 Eric Botcazou <ebotcazou@adacore.com>
+
* gcc-interface/gigi.h (finalize_from_with_types): Adjust comment.
* gcc-interface/decl.c (gnat_to_gnu_entity) <E_Access_Type>: Defer
unconditionally to the end of the unit when the designated type is
diff --git a/gcc/ada/gcc-interface/decl.c b/gcc/ada/gcc-interface/decl.c
index d3d2b96..cea8d3d 100644
--- a/gcc/ada/gcc-interface/decl.c
+++ b/gcc/ada/gcc-interface/decl.c
@@ -911,9 +911,20 @@ gnat_to_gnu_entity (Entity_Id gnat_entity, tree gnu_expr, int definition)
size of the object. */
gnu_object_size = gnu_size ? gnu_size : TYPE_SIZE (gnu_type);
if (gnu_size || align > 0)
- gnu_type = maybe_pad_type (gnu_type, gnu_size, align, gnat_entity,
- false, false, definition,
- gnu_size ? true : false);
+ {
+ tree orig_type = gnu_type;
+
+ gnu_type = maybe_pad_type (gnu_type, gnu_size, align, gnat_entity,
+ false, false, definition,
+ gnu_size ? true : false);
+
+ /* If a padding record was made, declare it now since it will
+ never be declared otherwise. This is necessary to ensure
+ that its subtrees are properly marked. */
+ if (gnu_type != orig_type && !DECL_P (TYPE_NAME (gnu_type)))
+ create_type_decl (TYPE_NAME (gnu_type), gnu_type, NULL, true,
+ debug_info_p, gnat_entity);
+ }
/* If this is a renaming, avoid as much as possible to create a new
object. However, in several cases, creating it is required.
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 4f1fa8a..28ab5b9 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,9 @@
2011-03-26 Eric Botcazou <ebotcazou@adacore.com>
+ * gnat.dg/discr27.ad[sb]: New test.
+
+2011-03-26 Eric Botcazou <ebotcazou@adacore.com>
+
* gnat.dg/limited_with2.ad[sb]: New test.
* gnat.dg/limited_with2_pkg1.ads: New helper.
* gnat.dg/imited_with2_pkg2.ads: Likewise.
diff --git a/gcc/testsuite/gnat.dg/discr27.adb b/gcc/testsuite/gnat.dg/discr27.adb
new file mode 100644
index 0000000..cfaba34
--- /dev/null
+++ b/gcc/testsuite/gnat.dg/discr27.adb
@@ -0,0 +1,31 @@
+package body Discr27 is
+
+ subtype Index is Positive range 1..4096;
+
+ function F return String is
+ S : String(1..1) := (others =>'w');
+ begin
+ return S;
+ end;
+
+ type Enum is (One, Two);
+
+ type Rec (D : Enum := One; Len : Index := 1) is record
+ case D is
+ when One => I : Integer;
+ when Two => A : String(1..Len);
+ end case;
+ end record;
+
+ procedure Nothing is
+ M : constant String := F;
+ C : constant Rec := (Two, M'Length, M);
+ begin
+ null;
+ end;
+
+ procedure Proc is begin
+ null;
+ end;
+
+end Discr27;
diff --git a/gcc/testsuite/gnat.dg/discr27.ads b/gcc/testsuite/gnat.dg/discr27.ads
new file mode 100644
index 0000000..db1914a
--- /dev/null
+++ b/gcc/testsuite/gnat.dg/discr27.ads
@@ -0,0 +1,7 @@
+-- { dg-do compile }
+
+package Discr27 is
+
+ procedure Proc;
+
+end Discr27;