On Wed, Jul 27, 2022 at 01:45:30PM +0200, Tobias Burnus wrote:
> OpenMP/C++: Allow classes with static members to be mappable
> 
> As this is the last lang-specific user of the omp_mappable_type hook,
> the hook is removed, keeping only a generic omp_mappable_type for
> incomplete types (or error_node).
> 
> gcc/c/ChangeLog:
> 
>       * c-decl.cc (c_decl_attributes, finish_decl): Call omp_mappable_type
>       instead of removed langhook.
>       * c-typeck.cc (c_finish_omp_clauses): Likewise.
> 
> gcc/cp/ChangeLog:
> 
>       * cp-objcp-common.h (LANG_HOOKS_OMP_MAPPABLE_TYPE): Remove.
>       * cp-tree.h (cp_omp_mappable_type, cp_omp_emit_unmappable_type_notes):
>       Remove.
>       * decl2.cc (cp_omp_mappable_type_1, cp_omp_mappable_type,
>       cp_omp_emit_unmappable_type_notes): Remove.
>       (cplus_decl_attributes): Call omp_mappable_type instead of
>       removed langhook.
>       * decl.cc (cp_finish_decl): Likewise; call cxx_incomplete_type_inform
>       in lieu of cp_omp_emit_unmappable_type_notes.
>       * semantics.cc (finish_omp_clauses): Likewise.
> 
> gcc/ChangeLog:
> 
>       * gimplify.cc (omp_notice_variable): Call omp_mappable_type
>         instead of removed langhook.
>       * omp-general.h (omp_mappable_type): New prototype.
>       * omp-general.cc (omp_mappable_type):  New; moved from ...
>       * langhooks.cc (lhd_omp_mappable_type): ... here.
>       * langhooks-def.h (lhd_omp_mappable_type,
>       LANG_HOOKS_OMP_MAPPABLE_TYPE): Remove.
>       (LANG_HOOKS_FOR_TYPES_INITIALIZER): Remote the latter.
>       * langhooks.h (struct lang_hooks_for_types): Remove
>       omp_mappable_type.
> 
> gcc/testsuite/ChangeLog:
> 
>       * g++.dg/gomp/unmappable-1.C: Remove dg-error; remove dg-note no
>       longer shown as TYPE_MAIN_DECL is NULL.
>       * c-c++-common/gomp/map-incomplete-type.c: New test.
> 
> Co-authored-by: Chung-Lin Tang <clt...@codesourcery.com>

Ok, thanks.

        Jakub

Reply via email to