From: ebotcazou Date: Tue, 21 Apr 2009 07:27:26 +0000 (+0000) Subject: * gcc-interface/decl.c (gnat_to_gnu_entity): Do not set force_global X-Git-Tag: upstream/4.9.2~36584 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=ee162cd7be5d231a3e164f552ed72ceff939a027;p=platform%2Fupstream%2Flinaro-gcc.git * gcc-interface/decl.c (gnat_to_gnu_entity): Do not set force_global for imported subprograms. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@146469 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog index d771e98..3b93881 100644 --- a/gcc/ada/ChangeLog +++ b/gcc/ada/ChangeLog @@ -1,5 +1,10 @@ 2009-04-21 Eric Botcazou + * gcc-interface/decl.c (gnat_to_gnu_entity): Do not set force_global + for imported subprograms. + +2009-04-21 Eric Botcazou + * gcc-interface/decl.c (gnat_to_gnu_entity) : Do not make constant objects covered by 13.3(19) volatile. diff --git a/gcc/ada/gcc-interface/decl.c b/gcc/ada/gcc-interface/decl.c index 18ebeff..898af24 100644 --- a/gcc/ada/gcc-interface/decl.c +++ b/gcc/ada/gcc-interface/decl.c @@ -332,13 +332,12 @@ gnat_to_gnu_entity (Entity_Id gnat_entity, tree gnu_expr, int definition) another compilation unit) public entities, show we are at global level for the purpose of computing scopes. Don't do this for components or discriminants since the relevant test is whether or not the record is - being defined. But do this for Imported functions or procedures in - all cases. */ - if ((!definition && Is_Public (gnat_entity) - && !Is_Statically_Allocated (gnat_entity) - && kind != E_Discriminant && kind != E_Component) - || (Is_Imported (gnat_entity) - && (kind == E_Function || kind == E_Procedure))) + being defined. */ + if (!definition + && Is_Public (gnat_entity) + && !Is_Statically_Allocated (gnat_entity) + && kind != E_Component + && kind != E_Discriminant) force_global++, this_global = true; /* Handle any attributes directly attached to the entity. */ diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 5b16c6a..a81f64a 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,6 +1,11 @@ +2009-04-21 Eric Botcazou + + * gnat.dg/import1.ad[sb]: New test. + 2009-04-20 Andrew Pinski - * objc/execute/exceptions/handler-1.m: For the NeXT runtime, just return 0. + * objc/execute/exceptions/handler-1.m: For the NeXT runtime, just + return 0. 2009-04-20 Tobias Burnus diff --git a/gcc/testsuite/gnat.dg/import1.adb b/gcc/testsuite/gnat.dg/import1.adb new file mode 100644 index 0000000..4e40560 --- /dev/null +++ b/gcc/testsuite/gnat.dg/import1.adb @@ -0,0 +1,17 @@ +-- { dg-do compile } +-- { dg-options "-g" } + +package body Import1 is + + procedure Create (Bounds : Arr) is + type Bound_Array is array (Bounds'Range) of Integer; + + procedure Proc (Ptr : access Bound_Array); + pragma Import (C, Proc); + + Temp : aliased Bound_Array; + begin + Proc (Temp'Access); + end; + +end Import1; diff --git a/gcc/testsuite/gnat.dg/import1.ads b/gcc/testsuite/gnat.dg/import1.ads new file mode 100644 index 0000000..cb00a0c --- /dev/null +++ b/gcc/testsuite/gnat.dg/import1.ads @@ -0,0 +1,7 @@ +package Import1 is + + type Arr is array (Positive range <>) of Integer; + + procedure Create (Bounds : Arr); + +end Import1;