aboutsummaryrefslogtreecommitdiff
path: root/gcc/ada/gcc-interface/decl.cc
diff options
context:
space:
mode:
authorEric Botcazou <ebotcazou@adacore.com>2022-09-01 16:21:07 +0200
committerMarc Poulhiès <poulhies@adacore.com>2022-09-12 10:16:53 +0200
commit643ae816f17745a77b62188b6bf169211609a59b (patch)
tree75ee85898298d81a7bfba9192e7824511330b3d0 /gcc/ada/gcc-interface/decl.cc
parent60bb81e0db60f1a0f6be8ece24a05052aba21b20 (diff)
downloadgcc-643ae816f17745a77b62188b6bf169211609a59b.zip
gcc-643ae816f17745a77b62188b6bf169211609a59b.tar.gz
gcc-643ae816f17745a77b62188b6bf169211609a59b.tar.bz2
[Ada] Fix immediate assertion failure with -gnatd.1
The switch enables the front-end unnesting pass. gcc/ada/ * gcc-interface/decl.cc (gnat_to_gnu_entity): Relax assertion when front-end unnesting is enabled.
Diffstat (limited to 'gcc/ada/gcc-interface/decl.cc')
-rw-r--r--gcc/ada/gcc-interface/decl.cc6
1 files changed, 5 insertions, 1 deletions
diff --git a/gcc/ada/gcc-interface/decl.cc b/gcc/ada/gcc-interface/decl.cc
index 504920d..c5a93fb 100644
--- a/gcc/ada/gcc-interface/decl.cc
+++ b/gcc/ada/gcc-interface/decl.cc
@@ -436,7 +436,8 @@ gnat_to_gnu_entity (Entity_Id gnat_entity, tree gnu_expr, bool definition)
/* If this is a numeric or enumeral type, or an access type, a nonzero Esize
must be specified unless it was specified by the programmer. Exceptions
are for access-to-protected-subprogram types and all access subtypes, as
- another GNAT type is used to lay out the GCC type for them. */
+ another GNAT type is used to lay out the GCC type for them, as well as
+ access-to-subprogram types if front-end unnesting is enabled. */
gcc_assert (!is_type
|| Known_Esize (gnat_entity)
|| Has_Size_Clause (gnat_entity)
@@ -445,6 +446,9 @@ gnat_to_gnu_entity (Entity_Id gnat_entity, tree gnu_expr, bool definition)
&& (!IN (kind, Access_Kind)
|| kind == E_Access_Protected_Subprogram_Type
|| kind == E_Anonymous_Access_Protected_Subprogram_Type
+ || ((kind == E_Access_Subprogram_Type
+ || kind == E_Anonymous_Access_Subprogram_Type)
+ && Unnest_Subprogram_Mode)
|| kind == E_Access_Subtype
|| type_annotate_only)));