OSDN Git Service

* gcc-interface/decl.c (gnat_to_gnu_entity) <object>: Really strip
authorebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 12 Jan 2009 19:14:43 +0000 (19:14 +0000)
committerebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 12 Jan 2009 19:14:43 +0000 (19:14 +0000)
only useless conversions around renamed objects.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@143303 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ada/ChangeLog
gcc/ada/gcc-interface/decl.c
gcc/testsuite/ChangeLog
gcc/testsuite/gnat.dg/unchecked_convert3.adb [new file with mode: 0644]

index a8ef574..33eb988 100644 (file)
@@ -1,3 +1,8 @@
+2009-01-12  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * gcc-interface/decl.c (gnat_to_gnu_entity) <object>: Really strip
+       only useless conversions around renamed objects.
+
 2009-01-11  Eric Botcazou  <ebotcazou@adacore.com>
 
        * gcc-interface/decl.c (gnat_to_gnu_entity) <E_Record_Subtype>: Put
index 0c7321d..25c4d81 100644 (file)
@@ -843,7 +843,10 @@ gnat_to_gnu_entity (Entity_Id gnat_entity, tree gnu_expr, int definition)
                    == RECORD_TYPE
                 && TYPE_IS_PADDING_P (TREE_TYPE (TREE_OPERAND (gnu_expr, 0))))
                /* Strip useless conversions around the object.  */
-               || TREE_CODE (gnu_expr) == NOP_EXPR)
+               || (TREE_CODE (gnu_expr) == NOP_EXPR
+                   && gnat_types_compatible_p
+                      (TREE_TYPE (gnu_expr),
+                       TREE_TYPE (TREE_OPERAND (gnu_expr, 0)))))
              {
                gnu_expr = TREE_OPERAND (gnu_expr, 0);
                gnu_type = TREE_TYPE (gnu_expr);
index 28df5ac..bc3f3d2 100644 (file)
@@ -1,3 +1,7 @@
+2009-01-12  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * gnat.dg/unchecked_convert3.adb: New test.
+
 2009-01-12  Jakub Jelinek  <jakub@redhat.com>
 
        PR c++/38794
diff --git a/gcc/testsuite/gnat.dg/unchecked_convert3.adb b/gcc/testsuite/gnat.dg/unchecked_convert3.adb
new file mode 100644 (file)
index 0000000..1354752
--- /dev/null
@@ -0,0 +1,22 @@
+-- { dg-do run }
+-- { dg-options "-gnatVa" }
+
+with Unchecked_Conversion;
+
+procedure Unchecked_Convert3 is
+
+  type Word is range -(2**15) .. (2**15) - 1;
+  type UWord is mod (2**16);
+
+  function To_Word is new unchecked_conversion (UWord, Word);
+
+  function F return UWord is
+  begin
+    return 65036;
+  end;
+
+  W : Word := To_Word(F);
+
+begin
+  null;
+end;