2013-09-10 15:34:09 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2013 Mellanox Technologies, Inc.
|
|
|
|
* All rights reserved.
|
2013-09-15 09:32:07 +00:00
|
|
|
* Copyright (c) 2013 Cisco Systems, Inc. All rights reserved.
|
2014-09-01 08:14:13 +00:00
|
|
|
* Copyright (c) 2014 Research Organization for Information Science
|
|
|
|
* and Technology (RIST). All rights reserved.
|
2013-09-10 15:34:09 +00:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "oshmem_config.h"
|
2013-09-15 09:32:07 +00:00
|
|
|
#include "oshmem/shmem/fortran/bindings.h"
|
2013-09-10 15:34:09 +00:00
|
|
|
#include "oshmem/include/shmem.h"
|
|
|
|
#include "oshmem/shmem/shmem_api_logger.h"
|
|
|
|
#include "oshmem/runtime/runtime.h"
|
|
|
|
#include "stdio.h"
|
|
|
|
|
2014-04-23 18:56:37 +00:00
|
|
|
#if OSHMEM_PROFILING
|
|
|
|
#include "oshmem/shmem/fortran/profile/pbindings.h"
|
|
|
|
SHMEM_GENERATE_WEAK_BINDINGS(SHPALLOC, shpalloc)
|
|
|
|
#include "oshmem/shmem/fortran/profile/defines.h"
|
|
|
|
#endif
|
|
|
|
|
2013-09-17 16:39:56 +00:00
|
|
|
SHMEM_GENERATE_FORTRAN_BINDINGS_SUB (void,
|
2013-09-10 15:34:09 +00:00
|
|
|
SHPALLOC,
|
|
|
|
shpalloc_,
|
|
|
|
shpalloc__,
|
|
|
|
shpalloc_f,
|
|
|
|
(FORTRAN_POINTER_T *addr, MPI_Fint *length, MPI_Fint *errcode, MPI_Fint *abort),
|
|
|
|
(addr,length,errcode,abort) )
|
|
|
|
|
|
|
|
void shpalloc_f(FORTRAN_POINTER_T *addr, MPI_Fint *length, MPI_Fint *errcode, MPI_Fint *abort)
|
|
|
|
{
|
|
|
|
*errcode = 0;
|
|
|
|
/*current shmem spec implies that the length parameter to SHPALLOC function is the number of 32-bit words to allocate*/
|
|
|
|
uint32_t *address;
|
2014-09-01 08:14:13 +00:00
|
|
|
if (*length <= 0) {
|
|
|
|
*errcode = -1;
|
|
|
|
}
|
2013-09-10 15:34:09 +00:00
|
|
|
address = shmalloc(*length*4);
|
|
|
|
|
|
|
|
*addr = (FORTRAN_POINTER_T)(uintptr_t)address;
|
|
|
|
if (!(*addr))
|
|
|
|
{
|
2014-09-01 08:14:13 +00:00
|
|
|
*errcode = -2;
|
2013-09-10 15:34:09 +00:00
|
|
|
SHMEM_API_ERROR("could not allocate %i bytes in symmetric heap",*length*4);
|
|
|
|
if (*abort)
|
|
|
|
{
|
|
|
|
SHMEM_API_ERROR("nonzero abort value, aborting..");
|
|
|
|
oshmem_shmem_abort(-1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|