1 
   2 
   3 
   4 
   5 
   6 
   7 
   8 
   9 
  10 
  11 
  12 #include "oshmem_config.h"
  13 #include "oshmem/shmem/fortran/bindings.h"
  14 #include "oshmem/include/shmem.h"
  15 #include "oshmem/constants.h"
  16 #include "oshmem/mca/scoll/scoll.h"
  17 #include "oshmem/proc/proc.h"
  18 #include "oshmem/op/op.h"
  19 
  20 #if OSHMEM_PROFILING
  21 #include "oshmem/shmem/fortran/profile/pbindings.h"
  22 SHMEM_GENERATE_WEAK_BINDINGS(SHMEM_BROADCAST4, shmem_broadcast4)
  23 SHMEM_GENERATE_WEAK_BINDINGS(SHMEM_BROADCAST8, shmem_broadcast8)
  24 SHMEM_GENERATE_WEAK_BINDINGS(SHMEM_BROADCAST32, shmem_broadcast32)
  25 SHMEM_GENERATE_WEAK_BINDINGS(SHMEM_BROADCAST64, shmem_broadcast64)
  26 #include "oshmem/shmem/fortran/profile/defines.h"
  27 #endif
  28 
  29 SHMEM_GENERATE_FORTRAN_BINDINGS_SUB (void,
  30         SHMEM_BROADCAST4,
  31         shmem_broadcast4_,
  32         shmem_broadcast4__,
  33         shmem_broadcast4_f,
  34         (FORTRAN_POINTER_T target, FORTRAN_POINTER_T source, MPI_Fint *nlong, MPI_Fint *PE_root, MPI_Fint *PE_start, MPI_Fint * logPE_stride, MPI_Fint *PE_size, FORTRAN_POINTER_T pSync),
  35         (target, source, nlong, PE_root, PE_start, logPE_stride, PE_size, pSync))
  36 
  37 SHMEM_GENERATE_FORTRAN_BINDINGS_SUB (void,
  38         SHMEM_BROADCAST8,
  39         shmem_broadcast8_,
  40         shmem_broadcast8__,
  41         shmem_broadcast8_f,
  42         (FORTRAN_POINTER_T target, FORTRAN_POINTER_T source, MPI_Fint *nlong, MPI_Fint *PE_root, MPI_Fint *PE_start, MPI_Fint * logPE_stride, MPI_Fint *PE_size, FORTRAN_POINTER_T pSync),
  43         (target, source, nlong, PE_root, PE_start, logPE_stride, PE_size, pSync))
  44 
  45 SHMEM_GENERATE_FORTRAN_BINDINGS_SUB (void,
  46         SHMEM_BROADCAST32,
  47         shmem_broadcast32_,
  48         shmem_broadcast32__,
  49         shmem_broadcast32_f,
  50         (FORTRAN_POINTER_T target, FORTRAN_POINTER_T source, MPI_Fint *nlong, MPI_Fint *PE_root, MPI_Fint *PE_start, MPI_Fint * logPE_stride, MPI_Fint *PE_size, FORTRAN_POINTER_T pSync),
  51         (target, source, nlong, PE_root, PE_start, logPE_stride, PE_size, pSync))
  52 
  53 SHMEM_GENERATE_FORTRAN_BINDINGS_SUB (void,
  54         SHMEM_BROADCAST64,
  55         shmem_broadcast64_,
  56         shmem_broadcast64__,
  57         shmem_broadcast64_f,
  58         (FORTRAN_POINTER_T target, FORTRAN_POINTER_T source, MPI_Fint *nlong, MPI_Fint *PE_root, MPI_Fint *PE_start, MPI_Fint * logPE_stride, MPI_Fint *PE_size, FORTRAN_POINTER_T pSync),
  59         (target, source, nlong, PE_root, PE_start, logPE_stride, PE_size, pSync))
  60 
  61 #define SHMEM_BROADCAST(F_NAME, T_NAME) void F_NAME(FORTRAN_POINTER_T target, \
  62     FORTRAN_POINTER_T source, \
  63     MPI_Fint *nlong,\
  64     MPI_Fint *PE_root, \
  65     MPI_Fint *PE_start, \
  66     MPI_Fint *logPE_stride, \
  67     MPI_Fint *PE_size, \
  68     FORTRAN_POINTER_T pSync)\
  69 {\
  70     int rc;\
  71     oshmem_group_t *group;\
  72     int rel_PE_root = 0;\
  73     oshmem_op_t* op = T_NAME;\
  74 \
  75     if ((0 <= OMPI_FINT_2_INT(*PE_root)) && \
  76             (OMPI_FINT_2_INT(*PE_root) < OMPI_FINT_2_INT(*PE_size)))\
  77     {\
  78         group = oshmem_proc_group_create_nofail(OMPI_FINT_2_INT(*PE_start), \
  79                 (1 << OMPI_FINT_2_INT(*logPE_stride)), \
  80                 OMPI_FINT_2_INT(*PE_size));\
  81         if (OMPI_FINT_2_INT(*PE_root) >= group->proc_count)\
  82         {\
  83             rc = OSHMEM_ERROR;\
  84             goto out;\
  85         }\
  86         \
  87         \
  88         rel_PE_root = oshmem_proc_pe(group->proc_array[OMPI_FINT_2_INT(*PE_root)]);\
  89         \
  90         \
  91         rc = group->g_scoll.scoll_broadcast( group, \
  92                 rel_PE_root, \
  93                 FPTR_2_VOID_PTR(target), \
  94                 FPTR_2_VOID_PTR(source), \
  95                 OMPI_FINT_2_INT(*nlong) * op->dt_size, \
  96                 FPTR_2_VOID_PTR(pSync), \
  97                 true, \
  98                 SCOLL_DEFAULT_ALG );\
  99     out: \
 100         oshmem_proc_group_destroy(group);\
 101         RUNTIME_CHECK_RC(rc); \
 102   }\
 103 }
 104 
 105 SHMEM_BROADCAST(shmem_broadcast4_f, oshmem_op_prod_fint4)
 106 SHMEM_BROADCAST(shmem_broadcast8_f, oshmem_op_prod_fint8)
 107 SHMEM_BROADCAST(shmem_broadcast32_f, oshmem_op_prod_fint4)
 108 SHMEM_BROADCAST(shmem_broadcast64_f, oshmem_op_prod_fint8)