ba85c8c3fc
libgfortran/ChangeLog: 2016-11-30 Andre Vehreschild <vehre@gcc.gnu.org> * caf/libcaf.h: Add new action types for (de-)registration of allocatable components in derived type coarrays. Add _caf_is_present prototype. * caf/single.c (_gfortran_caf_register): Add support for registration only and allocation of already registered allocatable components in derived type coarrays. (_gfortran_caf_deregister): Add mode to deallocate but not deregister an allocatable component in a derived type coarray. (_gfortran_caf_is_present): New function. Query whether an allocatable component in a derived type coarray on a remote image is allocated. gcc/testsuite/ChangeLog: 2016-11-30 Andre Vehreschild <vehre@gcc.gnu.org> * gfortran.dg/coarray/alloc_comp_1.f90: Fix tree-dump scans to adhere to the changed interfaces. * gfortran.dg/coarray_alloc_comp_1.f08: Likewise. * gfortran.dg/coarray_allocate_7.f08: Likewise. * gfortran.dg/coarray_lib_alloc_1.f90: Likewise. * gfortran.dg/coarray_lib_alloc_2.f90: Likewise. * gfortran.dg/coarray_lib_alloc_3.f90: Likewise. * gfortran.dg/coarray_lib_comm_1.f90: Likewise. * gfortran.dg/coarray_lib_alloc_4.f90: New test. gcc/fortran/ChangeLog: 2016-11-30 Andre Vehreschild <vehre@gcc.gnu.org> * check.c (gfc_check_allocated): By pass the caf_get call and check on the array. * gfortran.h: Add optional flag to gfc_caf_attr. * gfortran.texi: Document new enum values and _caf_is_present function. * primary.c (caf_variable_attr): Add optional flag to indicate that the expression is reffing a component. (gfc_caf_attr): Likewise. * trans-array.c (gfc_array_deallocate): Handle deallocation mode for coarray deregistration. (gfc_trans_dealloc_allocated): Likewise. (duplicate_allocatable): Use constants instead of creating custom constant tree node of zero or one. Use gfc_add_modify convenience function. (duplicate_allocatable_coarray): This function is similar to duplicate_allocatable but tailored to handle coarrays. (caf_enabled): Check whether in-derived-type coarray processing is enabled. (caf_in_coarray): Check that in-derived-type coarray processing is enabled and currently in a derived-typed coarray. (gfc_caf_is_dealloc_only): Return true, when deallocate only is desired for components in derived typed coarrays. (structure_alloc_comps): A mode for handling coarrays, that is no longer encode in the purpose. This makes the use cases of the routine more flexible without repeating. Allocatable components in derived type coarrays are now registered only when nullifying an object and allocated before copying data into them. (gfc_nullify_alloc_comp): Use the caf_mode of structure_alloc_comps now. (gfc_deallocate_alloc_comp): Likewise. (gfc_deallocate_alloc_comp_no_caf): Likewise. (gfc_reassign_alloc_comp_caf): Likewise. (gfc_copy_alloc_comp): Likewise. (gfc_copy_only_alloc_comp): Likewise. (gfc_alloc_allocatable_for_assignment): Make use to the cheaper way of reallocating a coarray without deregistering and reregistering it. (gfc_trans_deferred_array): Initialize the coarray token correctly for deferred variables and tear them down on exit. * trans-array.h: Change some prototypes to add the coarray (de-) registration modes. Add prototype for checking if deallocate only is selected for components in derived typed coarrays. * trans-decl.c (gfc_build_builtin_function_decls): Generate the declarations for the changed/new caf-lib routines. (gfc_trans_deferred_vars): Ensure deferred variables are (de-) registered correctly on procedure entry/exit. (generate_coarray_sym_init): Use constants. * trans-expr.c (gfc_conv_procedure_call): Propagate coarray allocation modes accordingly. (gfc_trans_alloc_subarray_assign): Likewise. (gfc_trans_subcomponent_assign): Likewise. (gfc_trans_structure_assign): Generate code to register the components of a derived type coarray prior to initialization. (gfc_conv_structure): Set flag that the structure is in a coarray. (gfc_trans_scalar_assign): Add flag to indicate being in a coarray and set the structure_alloc_comps modes correctly. (gfc_trans_assignment_1): Figure being in a coarray expression. * trans-intrinsic.c (gfc_conv_intrinsic_caf_get): Adapt to new structure_alloc_comps interface. (conv_caf_send): Use the old API as long as possible. (trans_caf_is_present): Generate code to check whether an allocatable component in a derived typed coarray is allocated on a remote image. (caf_this_image_ref): Return true, when only reffing this image. (gfc_conv_allocated): Convert allocated queries on allocatable components to the library API. (conv_intrinsic_move_alloc): Adapt to new interface of structure_alloc_comps. * trans-openmp.c (gfc_walk_alloc_comps): Likewise. (gfc_omp_clause_assign_op): Likewise. (gfc_omp_clause_dtor): Likewise. * trans-stmt.c (gfc_trans_deallocate): Figure which mode to use when deallocating allocatable components in derived type coarras. * trans.c (gfc_allocate_using_lib): Renamed to gfc_allcate_using_caf_lib. (gfc_allocate_allocatable): Set the registration mode/type of caf- register calls adapting to all the possible allocatable objects. (gfc_deallocate_with_status): Add deregistration mode for allocatable components in derived type coarrays. (gfc_deallocate_scalar_with_status): Likewise. * trans.h (enum gfc_coarray_type): Renamed to gfc_coarray_regtype to avoid collision with gfc_coarray_deregtype. From-SVN: r243021
249 lines
9.0 KiB
C
249 lines
9.0 KiB
C
/* Common declarations for all of GNU Fortran libcaf implementations.
|
|
Copyright (C) 2011-2016 Free Software Foundation, Inc.
|
|
Contributed by Tobias Burnus <burnus@net-b.de>
|
|
|
|
This file is part of the GNU Fortran Coarray Runtime Library (libcaf).
|
|
|
|
Libcaf is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3, or (at your option)
|
|
any later version.
|
|
|
|
Libcaf is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
Under Section 7 of GPL version 3, you are granted additional
|
|
permissions described in the GCC Runtime Library Exception, version
|
|
3.1, as published by the Free Software Foundation.
|
|
|
|
You should have received a copy of the GNU General Public License and
|
|
a copy of the GCC Runtime Library Exception along with this program;
|
|
see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
|
|
<http://www.gnu.org/licenses/>. */
|
|
|
|
#ifndef LIBCAF_H
|
|
#define LIBCAF_H
|
|
|
|
#include <stdbool.h>
|
|
#include <stddef.h> /* For size_t. */
|
|
#include <stdint.h> /* For int32_t. */
|
|
|
|
#include "libgfortran.h"
|
|
|
|
#if 0
|
|
#ifndef __GNUC__
|
|
#define __attribute__(x)
|
|
#define likely(x) (x)
|
|
#define unlikely(x) (x)
|
|
#else
|
|
#define likely(x) __builtin_expect(!!(x), 1)
|
|
#define unlikely(x) __builtin_expect(!!(x), 0)
|
|
#endif
|
|
|
|
/* Definitions of the Fortran 2008 standard; need to kept in sync with
|
|
ISO_FORTRAN_ENV, cf. libgfortran.h. */
|
|
#define STAT_UNLOCKED 0
|
|
#define STAT_LOCKED 1
|
|
#define STAT_LOCKED_OTHER_IMAGE 2
|
|
#define STAT_STOPPED_IMAGE 6000
|
|
#endif
|
|
|
|
/* Describes what type of array we are registerring. Keep in sync with
|
|
gcc/fortran/trans.h. */
|
|
typedef enum caf_register_t {
|
|
CAF_REGTYPE_COARRAY_STATIC,
|
|
CAF_REGTYPE_COARRAY_ALLOC,
|
|
CAF_REGTYPE_LOCK_STATIC,
|
|
CAF_REGTYPE_LOCK_ALLOC,
|
|
CAF_REGTYPE_CRITICAL,
|
|
CAF_REGTYPE_EVENT_STATIC,
|
|
CAF_REGTYPE_EVENT_ALLOC,
|
|
CAF_REGTYPE_COARRAY_ALLOC_REGISTER_ONLY,
|
|
CAF_REGTYPE_COARRAY_ALLOC_ALLOCATE_ONLY
|
|
}
|
|
caf_register_t;
|
|
|
|
/* Describes the action to take on _caf_deregister. Keep in sync with
|
|
gcc/fortran/trans.h. */
|
|
typedef enum caf_deregister_t {
|
|
CAF_DEREGTYPE_COARRAY_DEREGISTER,
|
|
CAF_DEREGTYPE_COARRAY_DEALLOCATE_ONLY
|
|
}
|
|
caf_deregister_t;
|
|
|
|
typedef void* caf_token_t;
|
|
typedef gfc_array_void gfc_descriptor_t;
|
|
|
|
/* Linked list of static coarrays registered. */
|
|
typedef struct caf_static_t {
|
|
caf_token_t token;
|
|
struct caf_static_t *prev;
|
|
}
|
|
caf_static_t;
|
|
|
|
/* When there is a vector subscript in this dimension, nvec == 0, otherwise,
|
|
lower_bound, upper_bound, stride contains the bounds relative to the declared
|
|
bounds; kind denotes the integer kind of the elements of vector[]. */
|
|
typedef struct caf_vector_t {
|
|
size_t nvec;
|
|
union {
|
|
struct {
|
|
void *vector;
|
|
int kind;
|
|
} v;
|
|
struct {
|
|
ptrdiff_t lower_bound, upper_bound, stride;
|
|
} triplet;
|
|
} u;
|
|
}
|
|
caf_vector_t;
|
|
|
|
typedef enum caf_ref_type_t {
|
|
/* Reference a component of a derived type, either regular one or an
|
|
allocatable or pointer type. For regular ones idx in caf_reference_t is
|
|
set to -1. */
|
|
CAF_REF_COMPONENT,
|
|
/* Reference an allocatable array. */
|
|
CAF_REF_ARRAY,
|
|
/* Reference a non-allocatable/non-pointer array. */
|
|
CAF_REF_STATIC_ARRAY
|
|
} caf_ref_type_t;
|
|
|
|
typedef enum caf_array_ref_t {
|
|
/* No array ref. This terminates the array ref. */
|
|
CAF_ARR_REF_NONE = 0,
|
|
/* Reference array elements given by a vector. Only for this mode
|
|
caf_reference_t.u.a.dim[i].v is valid. */
|
|
CAF_ARR_REF_VECTOR,
|
|
/* A full array ref (:). */
|
|
CAF_ARR_REF_FULL,
|
|
/* Reference a range on elements given by start, end and stride. */
|
|
CAF_ARR_REF_RANGE,
|
|
/* Only a single item is referenced given in the start member. */
|
|
CAF_ARR_REF_SINGLE,
|
|
/* An array ref of the kind (i:), where i is an arbitrary valid index in the
|
|
array. The index i is given in the start member. */
|
|
CAF_ARR_REF_OPEN_END,
|
|
/* An array ref of the kind (:i), where the lower bound of the array ref
|
|
is given by the remote side. The index i is given in the end member. */
|
|
CAF_ARR_REF_OPEN_START
|
|
} caf_array_ref_t;
|
|
|
|
/* References to remote components of a derived type. */
|
|
typedef struct caf_reference_t {
|
|
/* A pointer to the next ref or NULL. */
|
|
struct caf_reference_t *next;
|
|
/* The type of the reference. */
|
|
/* caf_ref_type_t, replaced by int to allow specification in fortran FE. */
|
|
int type;
|
|
/* The size of an item referenced in bytes. I.e. in an array ref this is
|
|
the factor to advance the array pointer with to get to the next item.
|
|
For component refs this gives just the size of the element referenced. */
|
|
size_t item_size;
|
|
union {
|
|
struct {
|
|
/* The offset (in bytes) of the component in the derived type. */
|
|
ptrdiff_t offset;
|
|
/* The offset (in bytes) to the caf_token associated with this
|
|
component. NULL, when not allocatable/pointer ref. */
|
|
ptrdiff_t caf_token_offset;
|
|
} c;
|
|
struct {
|
|
/* The mode of the array ref. See CAF_ARR_REF_*. */
|
|
/* caf_array_ref_t, replaced by unsigend char to allow specification in
|
|
fortran FE. */
|
|
unsigned char mode[GFC_MAX_DIMENSIONS];
|
|
/* The type of a static array. Unset for array's with descriptors. */
|
|
int static_array_type;
|
|
/* Subscript refs (s) or vector refs (v). */
|
|
union {
|
|
struct {
|
|
/* The start and end boundary of the ref and the stride. */
|
|
index_type start, end, stride;
|
|
} s;
|
|
struct {
|
|
/* nvec entries of kind giving the elements to reference. */
|
|
void *vector;
|
|
/* The number of entries in vector. */
|
|
size_t nvec;
|
|
/* The integer kind used for the elements in vector. */
|
|
int kind;
|
|
} v;
|
|
} dim[GFC_MAX_DIMENSIONS];
|
|
} a;
|
|
} u;
|
|
} caf_reference_t;
|
|
|
|
void _gfortran_caf_init (int *, char ***);
|
|
void _gfortran_caf_finalize (void);
|
|
|
|
int _gfortran_caf_this_image (int);
|
|
int _gfortran_caf_num_images (int, int);
|
|
|
|
void _gfortran_caf_register (size_t, caf_register_t, caf_token_t *,
|
|
gfc_descriptor_t *, int *, char *, int);
|
|
void _gfortran_caf_deregister (caf_token_t *, caf_deregister_t, int *, char *,
|
|
int);
|
|
|
|
void _gfortran_caf_sync_all (int *, char *, int);
|
|
void _gfortran_caf_sync_memory (int *, char *, int);
|
|
void _gfortran_caf_sync_images (int, int[], int *, char *, int);
|
|
|
|
void _gfortran_caf_stop_numeric (int32_t)
|
|
__attribute__ ((noreturn));
|
|
void _gfortran_caf_stop_str (const char *, int32_t)
|
|
__attribute__ ((noreturn));
|
|
void _gfortran_caf_error_stop_str (const char *, int32_t)
|
|
__attribute__ ((noreturn));
|
|
void _gfortran_caf_error_stop (int32_t) __attribute__ ((noreturn));
|
|
|
|
void _gfortran_caf_co_broadcast (gfc_descriptor_t *, int, int *, char *, int);
|
|
void _gfortran_caf_co_sum (gfc_descriptor_t *, int, int *, char *, int);
|
|
void _gfortran_caf_co_min (gfc_descriptor_t *, int, int *, char *, int, int);
|
|
void _gfortran_caf_co_max (gfc_descriptor_t *, int, int *, char *, int, int);
|
|
void _gfortran_caf_co_reduce (gfc_descriptor_t *, void* (*) (void *, void*),
|
|
int, int, int *, char *, int, int);
|
|
|
|
void _gfortran_caf_get (caf_token_t, size_t, int, gfc_descriptor_t *,
|
|
caf_vector_t *, gfc_descriptor_t *, int, int, bool,
|
|
int *);
|
|
void _gfortran_caf_send (caf_token_t, size_t, int, gfc_descriptor_t *,
|
|
caf_vector_t *, gfc_descriptor_t *, int, int, bool,
|
|
int *);
|
|
void _gfortran_caf_sendget (caf_token_t, size_t, int, gfc_descriptor_t *,
|
|
caf_vector_t *, caf_token_t, size_t, int,
|
|
gfc_descriptor_t *, caf_vector_t *, int, int, bool);
|
|
|
|
void _gfortran_caf_get_by_ref (caf_token_t token, int image_idx,
|
|
gfc_descriptor_t *dst, caf_reference_t *refs, int dst_kind,
|
|
int src_kind, bool may_require_tmp, bool dst_reallocatable, int *stat);
|
|
void _gfortran_caf_send_by_ref (caf_token_t token, int image_index,
|
|
gfc_descriptor_t *src, caf_reference_t *refs, int dst_kind,
|
|
int src_kind, bool may_require_tmp, bool dst_reallocatable, int *stat);
|
|
void _gfortran_caf_sendget_by_ref (
|
|
caf_token_t dst_token, int dst_image_index, caf_reference_t *dst_refs,
|
|
caf_token_t src_token, int src_image_index, caf_reference_t *src_refs,
|
|
int dst_kind, int src_kind, bool may_require_tmp, int *dst_stat,
|
|
int *src_stat);
|
|
|
|
void _gfortran_caf_atomic_define (caf_token_t, size_t, int, void *, int *,
|
|
int, int);
|
|
void _gfortran_caf_atomic_ref (caf_token_t, size_t, int, void *, int *,
|
|
int, int);
|
|
void _gfortran_caf_atomic_cas (caf_token_t, size_t, int, void *, void *,
|
|
void *, int *, int, int);
|
|
void _gfortran_caf_atomic_op (int, caf_token_t, size_t, int, void *, void *,
|
|
int *, int, int);
|
|
|
|
void _gfortran_caf_lock (caf_token_t, size_t, int, int *, int *, char *, int);
|
|
void _gfortran_caf_unlock (caf_token_t, size_t, int, int *, char *, int);
|
|
void _gfortran_caf_event_post (caf_token_t, size_t, int, int *, char *, int);
|
|
void _gfortran_caf_event_wait (caf_token_t, size_t, int, int *, char *, int);
|
|
void _gfortran_caf_event_query (caf_token_t, size_t, int, int *, int *);
|
|
|
|
int _gfortran_caf_is_present (caf_token_t, int, caf_reference_t *);
|
|
|
|
#endif /* LIBCAF_H */
|