1
1
openmpi/ompi/mpi/java/c/mpi_Comm.c

1919 строки
60 KiB
C
Исходник Обычный вид История

/*
* Copyright (c) 2004-2007 The Trustees of Indiana University and Indiana
* University Research and Technology
* Corporation. All rights reserved.
* Copyright (c) 2004-2005 The University of Tennessee and The University
* of Tennessee Research Foundation. All rights
* reserved.
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
* University of Stuttgart. All rights reserved.
* Copyright (c) 2004-2005 The Regents of the University of California.
* All rights reserved.
* $COPYRIGHT$
*
* Additional copyrights may follow
*
* $HEADER$
*/
/*
* This file is almost a complete re-write for Open MPI compared to the
* original mpiJava package. Its license and copyright are listed below.
* See <path to ompi/mpi/java/README> for more information.
*/
/*
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
/*
* File : mpi_Comm.c
* Headerfile : mpi_Comm.h
* Author : Sung-Hoon Ko, Xinying Li, Sang Lim, Bryan Carpenter
* Created : Thu Apr 9 12:22:15 1998
* Revision : $Revision: 1.17 $
* Updated : $Date: 2003/01/16 16:39:34 $
* Copyright: Northeast Parallel Architectures Center
* at Syracuse University 1998
*/
#include "ompi_config.h"
#include <stdlib.h>
#include <assert.h>
#ifdef HAVE_TARGETCONDITIONALS_H
#include <TargetConditionals.h>
#endif
#include "mpi.h"
#include "mpi_Comm.h"
#include "mpiJava.h" /* must come AFTER the related .h so JNI is included */
static void* getArrayPtr(void** bufBase, JNIEnv *env,
jobject buf, int baseType, int offset)
{
switch(baseType)
{
case 0: /* NULL */
*bufBase = NULL;
return NULL;
case 1: {
jbyte* els = (*env)->GetByteArrayElements(env, buf, NULL);
*bufBase = els;
return els + offset;
}
case 2: {
jchar* els = (*env)->GetCharArrayElements(env, buf, NULL);
*bufBase = els;
return els + offset;
}
case 3: {
jshort* els = (*env)->GetShortArrayElements(env, buf, NULL);
*bufBase = els;
return els + offset;
}
case 4: {
jboolean* els = (*env)->GetBooleanArrayElements(env, buf, NULL);
*bufBase = els;
return els + offset;
}
case 5: {
jint* els = (*env)->GetIntArrayElements(env, buf, NULL);
*bufBase = els;
return els + offset;
}
case 6: {
jlong* els = (*env)->GetLongArrayElements(env, buf, NULL);
*bufBase = els;
return els + offset;
}
case 7: {
jfloat* els = (*env)->GetFloatArrayElements(env, buf, NULL);
*bufBase = els;
return els + offset;
}
case 8: {
jdouble* els = (*env)->GetDoubleArrayElements(env, buf, NULL);
*bufBase = els;
return els + offset;
}
case 9: {
jbyte* els = (*env)->GetByteArrayElements(env, buf, NULL);
*bufBase = els;
return els + offset;
}
default:
*bufBase = NULL;
return NULL; /* 'UNDEFINED' */
}
}
static void releaseArrayPtr(JNIEnv *e, jobject buf, void *bufBase,
int baseType, jint mode)
{
switch(baseType)
{
case 0:
break;
case 1:
(*e)->ReleaseByteArrayElements(e, buf, (jbyte*)bufBase, mode);
break;
case 2:
(*e)->ReleaseCharArrayElements(e, buf, (jchar*)bufBase, mode);
break;
case 3:
(*e)->ReleaseShortArrayElements(e, buf, (jshort*)bufBase, mode);
break;
case 4:
(*e)->ReleaseBooleanArrayElements(e, buf, (jboolean*)bufBase, mode);
break;
case 5:
(*e)->ReleaseIntArrayElements(e, buf, (jint*)bufBase, mode);
break;
case 6:
(*e)->ReleaseLongArrayElements(e, buf, (jlong*)bufBase, mode);
break;
case 7:
(*e)->ReleaseFloatArrayElements(e, buf, (jfloat*)bufBase, mode);
break;
case 8:
(*e)->ReleaseDoubleArrayElements(e, buf, (jdouble*)bufBase, mode);
break;
case 9:
(*e)->ReleaseByteArrayElements(e, buf, (jbyte*)bufBase, mode);
break;
default:
break;
}
}
void* ompi_java_getBufPtr(void** bufBase, JNIEnv *env, jobject buf,
jboolean db, int baseType, int offset)
{
if(buf == NULL)
{
/* Allow NULL buffers to send/recv 0 items as control messages. */
*bufBase = NULL;
return NULL;
}
else if(db)
{
*bufBase = (*env)->GetDirectBufferAddress(env, buf);
assert(offset == 0);
return *bufBase;
}
else
{
return getArrayPtr(bufBase, env, buf, baseType, offset);
}
}
void ompi_java_releaseBufPtr(JNIEnv *env, jobject buf, jboolean db,
void* bufBase, int baseType)
{
if(!db && buf)
releaseArrayPtr(env, buf, bufBase, baseType, 0);
}
void ompi_java_releaseReadBufPtr(JNIEnv *env, jobject buf, jboolean db,
void *bufBase, int baseType)
{
if(!db && buf)
releaseArrayPtr(env, buf, bufBase, baseType, JNI_ABORT);
}
void* ompi_java_getDirectBufferAddress(JNIEnv *env, jobject buf)
{
/* Allow NULL buffers to send/recv 0 items as control messages. */
return buf == NULL ? NULL : (*env)->GetDirectBufferAddress(env, buf);
}
/* `getArrayCritical' is used in
getMPIBuf, releaseMPIBuf...
for getting pointer from `jobject buf'
*/
static void* getArrayCritical(void** bufBase, JNIEnv *env,
jobject buf, int baseType, int offset)
{
*bufBase = (jbyte*)(*env)->GetPrimitiveArrayCritical(env, buf, NULL);
switch(baseType)
{
case 0:
return NULL;
case 1:
return ((jbyte*)*bufBase) + offset;
case 2:
return ((jchar*)*bufBase) + offset;
case 3:
return ((jshort*)*bufBase) + offset;
case 4:
return ((jboolean*)*bufBase) + offset;
case 5:
return ((jint*)*bufBase) + offset;
case 6:
return ((jlong*)*bufBase) + offset;
case 7:
return ((jfloat*)*bufBase) + offset;
case 8:
return ((jdouble*)*bufBase) + offset;
case 9:
return ((jbyte*)*bufBase) + offset;
default:
return NULL;
}
}
static void* getBufCritical(
void** bufBase, JNIEnv *env,
jobject buf, jboolean db, int baseType, int offset)
{
if(buf == NULL)
{
/* Allow NULL buffers to send/recv 0 items as control messages. */
*bufBase = NULL;
return NULL;
}
else if(db)
{
*bufBase = (*env)->GetDirectBufferAddress(env, buf);
assert(offset == 0);
return *bufBase;
}
else
{
return getArrayCritical(bufBase, env, buf, baseType, offset);
}
}
static void releaseBufCritical(
JNIEnv *env, jobject buf, jboolean db, void* bufBase)
{
if(!db && buf)
(*env)->ReleasePrimitiveArrayCritical(env, buf, bufBase, 0);
}
static int isInter(JNIEnv *env, MPI_Comm comm)
{
int rc, flag;
rc = MPI_Comm_test_inter(comm, &flag);
ompi_java_exceptionCheck(env, rc);
return flag;
}
JNIEXPORT void JNICALL Java_mpi_Comm_init(JNIEnv *env, jclass clazz)
{
jfieldID nullHandleID = (*env)->GetStaticFieldID(
env, clazz, "nullHandle", "J");
(*env)->SetStaticLongField(env, clazz, nullHandleID, (jlong)MPI_COMM_NULL);
ompi_java.CommHandle = (*env)->GetFieldID(env,clazz,"handle","J");
}
JNIEXPORT void JNICALL Java_mpi_Comm_getComm(JNIEnv *env, jobject jthis,
jint type)
{
switch (type) {
case 0:
(*env)->SetLongField(env,jthis, ompi_java.CommHandle,(jlong)MPI_COMM_NULL);
break;
case 1:
(*env)->SetLongField(env,jthis, ompi_java.CommHandle,(jlong)MPI_COMM_SELF);
break;
case 2:
(*env)->SetLongField(env,jthis, ompi_java.CommHandle,(jlong)MPI_COMM_WORLD);
break;
}
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_dup(JNIEnv *env, jobject jthis)
{
MPI_Comm comm, newcomm;
comm = (MPI_Comm)(*env)->GetLongField(env, jthis, ompi_java.CommHandle);
int rc = MPI_Comm_dup(comm, &newcomm);
ompi_java_exceptionCheck(env, rc);
return (jlong)newcomm;
}
JNIEXPORT jint JNICALL Java_mpi_Comm_getSize(
JNIEnv *env, jobject jthis, jlong comm)
{
int rc, size;
rc = MPI_Comm_size((MPI_Comm)comm, &size);
ompi_java_exceptionCheck(env, rc);
return size;
}
JNIEXPORT jint JNICALL Java_mpi_Comm_getRank(
JNIEnv *env, jobject jthis, jlong comm)
{
int rc, rank;
rc = MPI_Comm_rank((MPI_Comm)comm, &rank);
ompi_java_exceptionCheck(env, rc);
return rank;
}
JNIEXPORT jint JNICALL Java_mpi_Comm_compare(
JNIEnv *env, jclass jthis, jlong comm1, jlong comm2)
{
int rc, result;
rc = MPI_Comm_compare((MPI_Comm)comm1, (MPI_Comm)comm2, &result);
ompi_java_exceptionCheck(env, rc);
return result;
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_free(
JNIEnv *env, jobject jthis, jlong handle)
{
MPI_Comm comm = (MPI_Comm)handle;
int rc = MPI_Comm_free(&comm);
ompi_java_exceptionCheck(env, rc);
return (jlong)comm;
}
JNIEXPORT void JNICALL Java_mpi_Comm_setInfo(
JNIEnv *env, jobject jthis, jlong comm, jlong info)
{
int rc = MPI_Comm_set_info((MPI_Comm)comm, (MPI_Info)info);
ompi_java_exceptionCheck(env, rc);
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_getInfo(
JNIEnv *env, jobject jthis, jlong comm)
{
MPI_Info info;
int rc = MPI_Comm_get_info((MPI_Comm)comm, &info);
ompi_java_exceptionCheck(env, rc);
return (jlong)info;
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_disconnect(
JNIEnv *env, jobject jthis, jlong handle)
{
MPI_Comm comm = (MPI_Comm)handle;
int rc = MPI_Comm_disconnect(&comm);
ompi_java_exceptionCheck(env, rc);
return (jlong)comm;
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_getGroup(
JNIEnv *env, jobject jthis, jlong comm)
{
MPI_Group group;
int rc = MPI_Comm_group((MPI_Comm)comm, &group);
ompi_java_exceptionCheck(env, rc);
return (jlong)group;
}
JNIEXPORT jboolean JNICALL Java_mpi_Comm_isInter(
JNIEnv *env, jobject jthis, jlong comm)
{
return isInter(env, (MPI_Comm)comm) ? JNI_TRUE : JNI_FALSE;
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_createIntercomm(
JNIEnv *env, jobject jthis, jlong comm, jlong localComm,
jint localLeader, jint remoteLeader, jint tag)
{
MPI_Comm newintercomm;
int rc = MPI_Intercomm_create(
(MPI_Comm)localComm, localLeader,
(MPI_Comm)comm, remoteLeader, tag, &newintercomm);
ompi_java_exceptionCheck(env, rc);
return (jlong)newintercomm;
}
JNIEXPORT void JNICALL Java_mpi_Comm_send(
JNIEnv *env, jobject jthis, jlong jComm,
jobject buf, jboolean db, jint offset, jint count,
jlong jType, jint baseType, jint dest, jint tag)
{
MPI_Comm comm = (MPI_Comm)jComm;
MPI_Datatype type = (MPI_Datatype)jType;
void *bufPtr, *bufBase;
bufPtr = ompi_java_getBufPtr(&bufBase, env, buf, db, baseType, offset);
int rc = MPI_Send(bufPtr, count, type, dest, tag, comm);
ompi_java_exceptionCheck(env, rc);
ompi_java_releaseReadBufPtr(env, buf, db, bufBase, baseType);
}
JNIEXPORT void JNICALL Java_mpi_Comm_recv(
JNIEnv *env, jobject jthis, jlong jComm,
jobject buf, jboolean db, jint offset, jint count,
jlong jType, jint baseType,
jint source, jint tag, jlongArray jStatus)
{
MPI_Comm comm = (MPI_Comm)jComm;
MPI_Datatype type = (MPI_Datatype)jType;
void *bufPtr, *bufBase;
bufPtr = ompi_java_getBufPtr(&bufBase, env, buf, db, baseType, offset);
MPI_Status status;
int rc = MPI_Recv(bufPtr, count, type, source, tag, comm, &status);
ompi_java_exceptionCheck(env, rc);
ompi_java_releaseBufPtr(env, buf, db, bufBase, baseType);
ompi_java_status_set(env, jStatus, &status);
}
JNIEXPORT void JNICALL Java_mpi_Comm_sendRecv(
JNIEnv *env, jobject jthis, jlong jComm,
jobject sBuf, jboolean sdb, jint sOffset, jint sCount,
jlong sjType, jint sBaseType, jint dest, jint sTag,
jobject rBuf, jboolean rdb, jint rOffset, jint rCount,
jlong rjType, jint rBaseType, jint source, jint rTag,
jlongArray jStatus)
{
MPI_Comm comm = (MPI_Comm)jComm;
MPI_Datatype sType = (MPI_Datatype)sjType;
MPI_Datatype rType = (MPI_Datatype)rjType;
void *sBufPtr, *sBufBase,
*rBufPtr, *rBufBase;
sBufPtr = ompi_java_getBufPtr(&sBufBase, env, sBuf, sdb, sBaseType, sOffset);
rBufPtr = ompi_java_getBufPtr(&rBufBase, env, rBuf, rdb, rBaseType, rOffset);
MPI_Status status;
int rc = MPI_Sendrecv(sBufPtr, sCount, sType, dest, sTag,
rBufPtr, rCount, rType, source, rTag,
comm, &status);
ompi_java_exceptionCheck(env, rc);
ompi_java_releaseReadBufPtr(env, sBuf, sdb, sBufBase, sBaseType);
ompi_java_releaseBufPtr(env, rBuf, rdb, rBufBase, rBaseType);
ompi_java_status_set(env, jStatus, &status);
}
JNIEXPORT void JNICALL Java_mpi_Comm_sendRecvReplace(
JNIEnv *env, jobject jthis, jlong jComm,
jobject buf, jboolean db, jint offset,
jint count, jlong jType, jint baseType,
jint dest, jint sTag, jint source, jint rTag, jlongArray jStatus)
{
MPI_Comm comm = (MPI_Comm)jComm;
MPI_Datatype type = (MPI_Datatype)jType;
MPI_Status status;
void *bufPtr, *bufBase;
bufPtr = ompi_java_getBufPtr(&bufBase, env, buf, db, baseType, offset);
int rc = MPI_Sendrecv_replace(bufPtr, count, type, dest,
sTag, source, rTag, comm, &status);
ompi_java_exceptionCheck(env, rc);
ompi_java_releaseBufPtr(env, buf, db, bufBase, baseType);
ompi_java_status_set(env, jStatus, &status);
}
JNIEXPORT void JNICALL Java_mpi_Comm_bSend(
JNIEnv *env, jobject jthis, jlong jComm,
jobject buf, jboolean db, jint offset,
jint count, jlong jType, jint baseType, jint dest, jint tag)
{
MPI_Comm comm = (MPI_Comm)jComm;
MPI_Datatype type = (MPI_Datatype)jType;
void *bufPtr, *bufBase;
bufPtr = ompi_java_getBufPtr(&bufBase, env, buf, db, baseType, offset);
int rc = MPI_Bsend(bufPtr, count, type, dest, tag, comm);
ompi_java_exceptionCheck(env, rc);
ompi_java_releaseReadBufPtr(env, buf, db, bufBase, baseType);
}
JNIEXPORT void JNICALL Java_mpi_Comm_sSend(
JNIEnv *env, jobject jthis, jlong jComm,
jobject buf, jboolean db, jint offset,
jint count, jlong jType, jint baseType, jint dest, jint tag)
{
MPI_Comm comm = (MPI_Comm)jComm;
MPI_Datatype type = (MPI_Datatype)jType;
void *bufPtr, *bufBase;
bufPtr = ompi_java_getBufPtr(&bufBase, env, buf, db, baseType, offset);
int rc = MPI_Ssend(bufPtr, count, type, dest, tag, comm);
ompi_java_exceptionCheck(env, rc);
ompi_java_releaseReadBufPtr(env, buf, db, bufBase, baseType);
}
JNIEXPORT void JNICALL Java_mpi_Comm_rSend(
JNIEnv *env, jobject jthis, jlong jComm,
jobject buf, jboolean db, jint offset,
jint count, jlong jType, jint baseType, jint dest, jint tag)
{
MPI_Comm comm = (MPI_Comm)jComm;
MPI_Datatype type = (MPI_Datatype)jType;
void *bufPtr, *bufBase;
bufPtr = ompi_java_getBufPtr(&bufBase, env, buf, db, baseType, offset);
int rc = MPI_Rsend(bufPtr, count, type, dest, tag, comm);
ompi_java_exceptionCheck(env, rc);
ompi_java_releaseReadBufPtr(env, buf, db, bufBase, baseType);
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_iSend(
JNIEnv *env, jobject jthis, jlong comm,
jobject buf, jint count, jlong type, jint dest, jint tag)
{
void *ptr = ompi_java_getDirectBufferAddress(env, buf);
MPI_Request request;
int rc = MPI_Isend(ptr, count, (MPI_Datatype)type,
dest, tag, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_ibSend(
JNIEnv *env, jobject jthis, jlong comm,
jobject buf, jint count, jlong type, jint dest, jint tag)
{
void *ptr = ompi_java_getDirectBufferAddress(env, buf);
MPI_Request request;
int rc = MPI_Ibsend(ptr, count, (MPI_Datatype)type,
dest, tag, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_isSend(
JNIEnv *env, jobject jthis, jlong comm,
jobject buf, jint count, jlong type, jint dest, jint tag)
{
void *ptr = ompi_java_getDirectBufferAddress(env, buf);
MPI_Request request;
int rc = MPI_Issend(ptr, count, (MPI_Datatype)type,
dest, tag, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_irSend(
JNIEnv *env, jobject jthis, jlong comm,
jobject buf, jint count, jlong type, jint dest, jint tag)
{
void *ptr = ompi_java_getDirectBufferAddress(env, buf);
MPI_Request request;
int rc = MPI_Irsend(ptr, count, (MPI_Datatype)type,
dest, tag, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_iRecv(
JNIEnv *env, jobject jthis, jlong comm,
jobject buf, jint count, jlong type, jint source, jint tag)
{
void *ptr = ompi_java_getDirectBufferAddress(env, buf);
MPI_Request request;
int rc = MPI_Irecv(ptr, count, (MPI_Datatype)type,
source, tag, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_sendInit(
JNIEnv *env, jobject jthis, jlong comm,
jobject buf, jint count, jlong type, jint dest, jint tag)
{
void *ptr = ompi_java_getDirectBufferAddress(env, buf);
MPI_Request request;
int rc = MPI_Send_init(ptr, count, (MPI_Datatype)type,
dest, tag, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_bSendInit(
JNIEnv *env, jobject jthis, jlong comm,
jobject buf, jint count, jlong type, jint dest, jint tag)
{
void *ptr = ompi_java_getDirectBufferAddress(env, buf);
MPI_Request request;
int rc = MPI_Bsend_init(ptr, count, (MPI_Datatype)type,
dest, tag, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_sSendInit(
JNIEnv *env, jobject jthis, jlong comm,
jobject buf, jint count, jlong type, jint dest, jint tag)
{
void *ptr = ompi_java_getDirectBufferAddress(env, buf);
MPI_Request request;
int rc = MPI_Ssend_init(ptr, count, (MPI_Datatype)type,
dest, tag, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_rSendInit(
JNIEnv *env, jobject jthis, jlong comm,
jobject buf, jint count, jlong type, jint dest, jint tag)
{
void *ptr = ompi_java_getDirectBufferAddress(env, buf);
MPI_Request request;
int rc = MPI_Rsend_init(ptr, count, (MPI_Datatype)type,
dest, tag, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_recvInit(
JNIEnv *env, jobject jthis, jlong comm,
jobject buf, jint count, jlong type, jint source, jint tag)
{
void *ptr = ompi_java_getDirectBufferAddress(env, buf);
MPI_Request request;
int rc = MPI_Recv_init(ptr, count, (MPI_Datatype)type,
source, tag, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT jint JNICALL Java_mpi_Comm_pack(
JNIEnv *env, jobject jthis, jlong jComm,
jobject inBuf, jboolean indb, jint offset,
jint inCount, jlong jType, jint bType, jbyteArray outBuf, jint position)
{
MPI_Comm comm = (MPI_Comm)jComm;
MPI_Datatype type = (MPI_Datatype)jType;
int outSize = (*env)->GetArrayLength(env, outBuf);
void *oBufPtr, *iBufPtr, *iBufBase;
oBufPtr = (*env)->GetPrimitiveArrayCritical(env, outBuf, NULL);
iBufPtr = getBufCritical(&iBufBase, env, inBuf, indb, bType, offset);
if(inCount != 0 && outSize != position)
{
/* LAM doesn't like count = 0 */
int rc = MPI_Pack(iBufPtr, inCount, type,
oBufPtr, outSize, &position, comm);
ompi_java_exceptionCheck(env, rc);
}
releaseBufCritical(env, inBuf, indb, iBufBase);
(*env)->ReleasePrimitiveArrayCritical(env, outBuf, oBufPtr, 0);
return position;
}
JNIEXPORT jint JNICALL Java_mpi_Comm_unpack(
JNIEnv *env, jobject jthis, jlong jComm,
jbyteArray inBuf, jint position, jobject outBuf, jboolean outdb,
jint offset, jint outCount, jlong jType, jint bType)
{
MPI_Comm comm = (MPI_Comm)jComm;
MPI_Datatype type = (MPI_Datatype)jType;
int inSize = (*env)->GetArrayLength(env, inBuf);
void *iBufPtr, *oBufPtr, *oBufBase;
iBufPtr = (*env)->GetPrimitiveArrayCritical(env, inBuf, NULL);
oBufPtr = getBufCritical(&oBufBase, env, outBuf, outdb, bType, offset);
int rc = MPI_Unpack(iBufPtr, inSize, &position,
oBufPtr, outCount, type, comm);
ompi_java_exceptionCheck(env, rc);
(*env)->ReleasePrimitiveArrayCritical(env, inBuf, iBufPtr, 0);
releaseBufCritical(env, outBuf, outdb, oBufBase);
return position;
}
JNIEXPORT jint JNICALL Java_mpi_Comm_packSize(
JNIEnv *env, jobject jthis, jlong comm, jint incount, jlong type)
{
int rc, size;
rc = MPI_Pack_size(incount, (MPI_Datatype)type, (MPI_Comm)comm, &size);
ompi_java_exceptionCheck(env, rc);
return size;
}
JNIEXPORT jobject JNICALL Java_mpi_Comm_iProbe(
JNIEnv *env, jobject jthis, jlong comm, jint source, jint tag)
{
int flag;
MPI_Status status;
int rc = MPI_Iprobe(source, tag, (MPI_Comm)comm, &flag, &status);
ompi_java_exceptionCheck(env, rc);
return flag ? ompi_java_status_new(env, &status) : NULL;
}
JNIEXPORT void JNICALL Java_mpi_Comm_probe(
JNIEnv *env, jobject jthis, jlong comm,
jint source, jint tag, jlongArray jStatus)
{
MPI_Status status;
int rc = MPI_Probe(source, tag, (MPI_Comm)comm, &status);
ompi_java_exceptionCheck(env, rc);
ompi_java_status_set(env, jStatus, &status);
}
JNIEXPORT jint JNICALL Java_mpi_Comm_getTopology(
JNIEnv *env, jobject jthis, jlong comm)
{
int rc, status;
rc = MPI_Topo_test((MPI_Comm)comm, &status);
ompi_java_exceptionCheck(env, rc);
return status;
}
JNIEXPORT void JNICALL Java_mpi_Comm_abort(
JNIEnv *env, jobject jthis, jlong comm, jint errorcode)
{
int rc = MPI_Abort((MPI_Comm)comm, errorcode);
ompi_java_exceptionCheck(env, rc);
}
JNIEXPORT void JNICALL Java_mpi_Comm_setErrhandler(
JNIEnv *env, jobject jthis, jlong comm, jlong errhandler)
{
int rc = MPI_Errhandler_set((MPI_Comm)comm, (MPI_Errhandler)errhandler);
ompi_java_exceptionCheck(env, rc);
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_getErrhandler(
JNIEnv *env, jobject jthis, jlong comm)
{
MPI_Errhandler errhandler;
int rc = MPI_Errhandler_get((MPI_Comm)comm, &errhandler);
ompi_java_exceptionCheck(env, rc);
return (jlong)errhandler;
}
static int commCopyAttr(MPI_Comm oldcomm, int keyval, void *extraState,
void *attrValIn, void *attrValOut, int *flag)
{
return ompi_java_attrCopy(attrValIn, attrValOut, flag);
}
static int commDeleteAttr(MPI_Comm oldcomm, int keyval,
void *attrVal, void *extraState)
{
return ompi_java_attrDelete(attrVal);
}
JNIEXPORT jint JNICALL Java_mpi_Comm_createKeyval_1jni(
JNIEnv *env, jclass clazz)
{
int rc, keyval;
rc = MPI_Comm_create_keyval(commCopyAttr, commDeleteAttr, &keyval, NULL);
ompi_java_exceptionCheck(env, rc);
return keyval;
}
JNIEXPORT void JNICALL Java_mpi_Comm_freeKeyval_1jni(
JNIEnv *env, jclass clazz, jint keyval)
{
int rc = MPI_Comm_free_keyval((int*)(&keyval));
ompi_java_exceptionCheck(env, rc);
}
JNIEXPORT void JNICALL Java_mpi_Comm_setAttr(
JNIEnv *env, jobject jthis, jlong comm, jint keyval, jbyteArray jval)
{
void *cval = ompi_java_attrSet(env, jval);
int rc = MPI_Comm_set_attr((MPI_Comm)comm, keyval, cval);
ompi_java_exceptionCheck(env, rc);
}
JNIEXPORT jobject JNICALL Java_mpi_Comm_getAttr_1predefined(
JNIEnv *env, jobject jthis, jlong comm, jint keyval)
{
int flag, *val;
int rc = MPI_Comm_get_attr((MPI_Comm)comm, keyval, &val, &flag);
if(ompi_java_exceptionCheck(env, rc) || !flag)
return NULL;
return ompi_java_Integer_valueOf(env, (jint)(*val));
}
JNIEXPORT jbyteArray JNICALL Java_mpi_Comm_getAttr(
JNIEnv *env, jobject jthis, jlong comm, jint keyval)
{
int flag;
void *cval;
int rc = MPI_Comm_get_attr((MPI_Comm)comm, keyval, &cval, &flag);
if(ompi_java_exceptionCheck(env, rc) || !flag)
return NULL;
return ompi_java_attrGet(env, cval);
}
JNIEXPORT void JNICALL Java_mpi_Comm_deleteAttr(
JNIEnv *env, jobject jthis, jlong comm, jint keyval)
{
int rc = MPI_Comm_delete_attr((MPI_Comm)comm, keyval);
ompi_java_exceptionCheck(env, rc);
}
JNIEXPORT void JNICALL Java_mpi_Comm_barrier(
JNIEnv *env, jobject jthis, jlong comm)
{
int rc = MPI_Barrier((MPI_Comm)comm);
ompi_java_exceptionCheck(env, rc);
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_iBarrier(
JNIEnv *env, jobject jthis, jlong comm)
{
MPI_Request request;
int rc = MPI_Ibarrier((MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT void JNICALL Java_mpi_Comm_bcast(
JNIEnv *env, jobject jthis, jlong jComm, jobject buf, jboolean db,
jint offset, jint count, jlong jType, jint baseType, jint root)
{
MPI_Comm comm = (MPI_Comm)jComm;
MPI_Datatype type = (MPI_Datatype)jType;
void *bufPtr, *bufBase;
bufPtr = ompi_java_getBufPtr(&bufBase, env, buf, db, baseType, offset);
int rc = MPI_Bcast(bufPtr, count, type, root, comm);
ompi_java_exceptionCheck(env, rc);
ompi_java_releaseBufPtr(env, buf, db, bufBase, baseType);
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_iBcast(
JNIEnv *env, jobject jthis, jlong comm,
jobject buf, jint count, jlong type, jint root)
{
void *ptr = ompi_java_getDirectBufferAddress(env, buf);
MPI_Request request;
int rc = MPI_Ibcast(ptr, count, (MPI_Datatype)type,
root, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT void JNICALL Java_mpi_Comm_gather(
JNIEnv *env, jobject jthis, jlong jComm,
jobject sendBuf, jboolean sdb, jint sOffset, jint sCount,
jlong sjType, jint sBType,
jobject recvBuf, jboolean rdb, jint rOffset, jint rCount,
jlong rjType, jint rBType, jint root)
{
MPI_Comm comm = (MPI_Comm)jComm;
int id;
int rc = MPI_Comm_rank(comm, &id);
int rootOrInter = id == root || isInter(env, comm);
if(ompi_java_exceptionCheck(env, rc))
return;
void *sPtr, *sBase, *rPtr = NULL, *rBase;
MPI_Datatype sType;
if(sjType == 0)
{
assert(sendBuf == NULL);
sType = MPI_DATATYPE_NULL;
sPtr = MPI_IN_PLACE;
sBase = NULL;
}
else
{
sType = (MPI_Datatype)sjType;
sPtr = ompi_java_getBufPtr(&sBase, env, sendBuf, sdb, sBType, sOffset);
}
MPI_Datatype rType = (MPI_Datatype)rjType;
if(rootOrInter || sPtr == MPI_IN_PLACE)
{
/*
* In principle need the "id == root" check here and elsewere for
* correctness, in case arguments that are not supposed to be
* significant except on root are legitimately passed in as `null',
* say. Shouldn't produce null pointer exception.
*
* (However in this case MPICH complains if `mpi_rtype' is not defined
* in all processes, notwithstanding what the spec says.)
*/
rPtr = ompi_java_getBufPtr(&rBase, env, recvBuf, rdb, rBType, rOffset);
if(!rootOrInter)
{
/* The receive buffer is ignored for all non-root processes.
* As we are using MPI_IN_PLACE version, we use the receive
* buffer as the send buffer.
*/
assert(sendBuf == NULL);
sPtr = rPtr;
sCount = rCount;
sType = rType;
}
}
rc = MPI_Gather(sPtr, sCount, sType, rPtr, rCount, rType, root, comm);
ompi_java_exceptionCheck(env, rc);
if(rootOrInter || sendBuf == NULL)
ompi_java_releaseBufPtr(env, recvBuf, rdb, rBase, rBType);
if(sendBuf != NULL)
ompi_java_releaseReadBufPtr(env, sendBuf, sdb, sBase, sBType);
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_iGather(
JNIEnv *env, jobject jthis, jlong comm,
jobject sendBuf, jint sCount, jlong sType,
jobject recvBuf, jint rCount, jlong rType, jint root)
{
int id;
int rc = MPI_Comm_rank((MPI_Comm)comm, &id);
int rootOrInter = id == root || isInter(env, (MPI_Comm)comm);
if(ompi_java_exceptionCheck(env, rc))
return (jlong)MPI_REQUEST_NULL;
MPI_Request request;
void *sPtr, *rPtr = NULL;
if(sType == 0)
{
assert(sendBuf == NULL);
sType = (jlong)MPI_DATATYPE_NULL;
sPtr = MPI_IN_PLACE;
}
else
{
sPtr = ompi_java_getDirectBufferAddress(env, sendBuf);
}
if(rootOrInter || sPtr == MPI_IN_PLACE)
{
/*
* In principle need the "id == root" check here and elsewere for
* correctness, in case arguments that are not supposed to be
* significant except on root are legitimately passed in as `null',
* say. Shouldn't produce null pointer exception.
*
* (However in this case MPICH complains if `mpi_rtype' is not defined
* in all processes, notwithstanding what the spec says.)
*/
rPtr = ompi_java_getDirectBufferAddress(env, recvBuf);
if(!rootOrInter)
{
/* The receive buffer is ignored for all non-root processes.
* As we are using MPI_IN_PLACE version, we use the receive
* buffer as the send buffer.
*/
assert(sendBuf == NULL);
sPtr = rPtr;
sCount = rCount;
sType = rType;
}
}
rc = MPI_Igather(sPtr, sCount, (MPI_Datatype)sType,
rPtr, rCount, (MPI_Datatype)rType,
root, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT void JNICALL Java_mpi_Comm_gatherv(
JNIEnv *env, jobject jthis, jlong jComm,
jobject sendBuf, jboolean sdb, jint sOffset,
jint sCount, jlong sjType, jint sBType,
jobject recvBuf, jboolean rdb, jint rOffset, jintArray rCounts,
jintArray displs, jlong rjType, jint rBType, jint root)
{
MPI_Comm comm = (MPI_Comm)jComm;
int id;
int rc = MPI_Comm_rank(comm, &id);
int rootOrInter = id == root || isInter(env, comm);
if(ompi_java_exceptionCheck(env, rc))
return;
void *sPtr, *sBase, *rPtr = NULL, *rBase;
MPI_Datatype sType;
if(sjType == 0)
{
assert(sendBuf == NULL);
sType = MPI_DATATYPE_NULL;
sPtr = MPI_IN_PLACE;
sBase = NULL;
}
else
{
sType = (MPI_Datatype)sjType;
sPtr = ompi_java_getBufPtr(&sBase, env, sendBuf, sdb, sBType, sOffset);
}
jint *jRCounts = NULL, *jDispls = NULL;
int *cRCounts = NULL, *cDispls = NULL;
MPI_Datatype rType = sType;
if(rootOrInter)
{
ompi_java_getIntArray(env, rCounts, &jRCounts, &cRCounts);
ompi_java_getIntArray(env, displs, &jDispls, &cDispls);
rType = (MPI_Datatype)rjType;
rPtr = ompi_java_getBufPtr(&rBase, env, recvBuf, rdb, rBType, rOffset);
}
rc = MPI_Gatherv(sPtr, sCount, sType, rPtr, cRCounts,
cDispls, rType, root, comm);
ompi_java_exceptionCheck(env, rc);
if(sendBuf != NULL)
ompi_java_releaseReadBufPtr(env, sendBuf, sdb, sBase, sBType);
if(rootOrInter)
{
ompi_java_releaseBufPtr(env, recvBuf, rdb, rBase, rBType);
ompi_java_forgetIntArray(env, rCounts, jRCounts, cRCounts);
ompi_java_forgetIntArray(env, displs, jDispls, cDispls);
}
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_iGatherv(
JNIEnv *env, jobject jthis, jlong comm,
jobject sendBuf, jint sCount, jlong sType,
jobject recvBuf, jintArray rCounts,
jintArray displs, jlong rType, jint root)
{
int id;
int rc = MPI_Comm_rank((MPI_Comm)comm, &id);
int rootOrInter = id == root || isInter(env, (MPI_Comm)comm);
if(ompi_java_exceptionCheck(env, rc))
return (jlong)MPI_REQUEST_NULL;
MPI_Request request;
void *sPtr, *rPtr = NULL;
if(sType == 0)
{
assert(sendBuf == NULL);
sType = (jlong)MPI_DATATYPE_NULL;
sPtr = MPI_IN_PLACE;
}
else
{
sPtr = ompi_java_getDirectBufferAddress(env, sendBuf);
}
jint *jRCounts, *jDispls;
int *cRCounts, *cDispls;
if(rootOrInter)
{
ompi_java_getIntArray(env, rCounts, &jRCounts, &cRCounts);
ompi_java_getIntArray(env, displs, &jDispls, &cDispls);
rPtr = ompi_java_getDirectBufferAddress(env, recvBuf);
}
else
{
jRCounts = jDispls = NULL;
cRCounts = cDispls = NULL;
rType = sType;
}
rc = MPI_Igatherv(sPtr, sCount, (MPI_Datatype)sType, rPtr,
cRCounts, cDispls, (MPI_Datatype)rType,
root, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
if(rootOrInter)
{
ompi_java_forgetIntArray(env, rCounts, jRCounts, cRCounts);
ompi_java_forgetIntArray(env, displs, jDispls, cDispls);
}
return (jlong)request;
}
JNIEXPORT void JNICALL Java_mpi_Comm_scatter(
JNIEnv *env, jobject jthis, jlong jComm,
jobject sendBuf, jboolean sdb, jint sOffset, jint sCount,
jlong sjType, jint sBType,
jobject recvBuf, jboolean rdb, jint rOffset, jint rCount,
jlong rjType, jint rBType, jint root)
{
MPI_Comm comm = (MPI_Comm)jComm;
int id;
int rc = MPI_Comm_rank(comm, &id);
int rootOrInter = id == root || isInter(env, comm);
if(ompi_java_exceptionCheck(env, rc))
return;
void *sPtr = NULL, *sBase, *rPtr, *rBase;
MPI_Datatype sType, rType;
if(rjType == 0)
{
assert(recvBuf == NULL);
rType = MPI_DATATYPE_NULL;
rPtr = MPI_IN_PLACE;
}
else
{
rType = (MPI_Datatype)rjType;
rPtr = ompi_java_getBufPtr(&rBase, env, recvBuf, rdb, rBType, rOffset);
}
sType = (MPI_Datatype)sjType;
if(rootOrInter || rPtr == MPI_IN_PLACE)
{
sPtr = ompi_java_getBufPtr(&sBase, env, sendBuf, sdb, sBType, sOffset);
if(!rootOrInter)
{
/* The send buffer is ignored for all non-root processes.
* As we are using MPI_IN_PLACE version, we use the send
* buffer as the receive buffer.
*/
assert(recvBuf == NULL);
rPtr = sPtr;
rCount = sCount;
rType = sType;
}
}
rc = MPI_Scatter(sPtr, sCount, sType, rPtr, rCount, rType, root, comm);
ompi_java_exceptionCheck(env, rc);
if(rootOrInter || recvBuf == NULL)
ompi_java_releaseBufPtr(env, sendBuf, sdb, sBase, sBType);
if(recvBuf != NULL)
ompi_java_releaseBufPtr(env, recvBuf, rdb, rBase, rBType);
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_iScatter(
JNIEnv *env, jobject jthis, jlong comm,
jobject sendBuf, jint sCount, jlong sType,
jobject recvBuf, jint rCount, jlong rType, jint root)
{
int id;
int rc = MPI_Comm_rank((MPI_Comm)comm, &id);
int rootOrInter = id == root || isInter(env, (MPI_Comm)comm);
if(ompi_java_exceptionCheck(env, rc))
return (jlong)MPI_REQUEST_NULL;
void *sPtr = NULL, *rPtr;
MPI_Request request;
if(rType == 0)
{
assert(recvBuf == NULL);
rType = (jlong)MPI_DATATYPE_NULL;
rPtr = MPI_IN_PLACE;
}
else
{
rPtr = ompi_java_getDirectBufferAddress(env, recvBuf);
}
if(rootOrInter || rPtr == MPI_IN_PLACE)
{
sPtr = ompi_java_getDirectBufferAddress(env, sendBuf);
if(!rootOrInter)
{
/* The send buffer is ignored for all non-root processes.
* As we are using MPI_IN_PLACE version, we use the send
* buffer as the receive buffer.
*/
assert(recvBuf == NULL);
rPtr = sPtr;
rCount = sCount;
rType = sType;
}
}
rc = MPI_Iscatter(sPtr, sCount, (MPI_Datatype)sType,
rPtr, rCount, (MPI_Datatype)rType,
root, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT void JNICALL Java_mpi_Comm_scatterv(
JNIEnv *env, jobject jthis, jlong jComm,
jobject sendBuf, jboolean sdb, jint sOffset, jintArray sCounts,
jintArray displs, jlong sjType, jint sBType,
jobject recvBuf, jboolean rdb, jint rOffset, jint rCount,
jlong rjType, jint rBType, jint root)
{
MPI_Comm comm = (MPI_Comm)jComm;
int id;
int rc = MPI_Comm_rank(comm, &id);
int rootOrInter = id == root || isInter(env, comm);
if(ompi_java_exceptionCheck(env, rc))
return;
void *sPtr = NULL, *sBase, *rPtr, *rBase;
MPI_Datatype rType;
if(rjType == 0)
{
assert(recvBuf == NULL);
rType = MPI_DATATYPE_NULL;
rPtr = MPI_IN_PLACE;
rBase = NULL;
}
else
{
rType = (MPI_Datatype)rjType;
rPtr = ompi_java_getBufPtr(&rBase, env, recvBuf, rdb, rBType, rOffset);
}
jint *jSCounts = NULL, *jDispls = NULL;
int *cSCounts = NULL, *cDispls = NULL;
MPI_Datatype sType = rType;
if(rootOrInter)
{
ompi_java_getIntArray(env, sCounts, &jSCounts, &cSCounts);
ompi_java_getIntArray(env, displs, &jDispls, &cDispls);
sType = (MPI_Datatype)sjType;
sPtr = ompi_java_getBufPtr(&sBase, env, sendBuf, sdb, sBType, sOffset);
}
rc = MPI_Scatterv(sPtr, cSCounts, cDispls, sType,
rPtr, rCount, rType, root, comm);
ompi_java_exceptionCheck(env, rc);
if(recvBuf != NULL)
ompi_java_releaseBufPtr(env, recvBuf, rdb, rBase, rBType);
if(rootOrInter)
{
ompi_java_releaseBufPtr(env, sendBuf, sdb, sBase, sBType);
ompi_java_forgetIntArray(env, sCounts, jSCounts, cSCounts);
ompi_java_forgetIntArray(env, displs, jDispls, cDispls);
}
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_iScatterv(
JNIEnv *env, jobject jthis, jlong comm,
jobject sendBuf, jintArray sCounts, jintArray displs, jlong sType,
jobject recvBuf, jint rCount, jlong rType, jint root)
{
int id;
int rc = MPI_Comm_rank((MPI_Comm)comm, &id);
int rootOrInter = id == root || isInter(env, (MPI_Comm)comm);
if(ompi_java_exceptionCheck(env, rc))
return (jlong)MPI_REQUEST_NULL;
MPI_Request request;
void *sPtr = NULL, *rPtr;
if(rType == 0)
{
assert(recvBuf == NULL);
rType = (jlong)MPI_DATATYPE_NULL;
rPtr = MPI_IN_PLACE;
}
else
{
rPtr = ompi_java_getDirectBufferAddress(env, recvBuf);
}
jint *jSCounts, *jDispls;
int *cSCounts, *cDispls;
if(rootOrInter)
{
ompi_java_getIntArray(env, sCounts, &jSCounts, &cSCounts);
ompi_java_getIntArray(env, displs, &jDispls, &cDispls);
sPtr = ompi_java_getDirectBufferAddress(env, sendBuf);
}
else
{
jSCounts = jDispls = NULL;
cSCounts = cDispls = NULL;
sType = rType;
}
rc = MPI_Iscatterv(sPtr, cSCounts, cDispls, (MPI_Datatype)sType,
rPtr, rCount, (MPI_Datatype)rType, root,
(MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
if(rootOrInter)
{
ompi_java_forgetIntArray(env, sCounts, jSCounts, cSCounts);
ompi_java_forgetIntArray(env, displs, jDispls, cDispls);
}
return (jlong)request;
}
JNIEXPORT void JNICALL Java_mpi_Comm_allGather(
JNIEnv *env, jobject jthis, jlong jComm,
jobject sendBuf, jboolean sdb, jint sOffset,
jint sCount, jlong sjType, jint sBType,
jobject recvBuf, jboolean rdb, jint rOffset,
jint rCount, jlong rjType, jint rBType)
{
MPI_Comm comm = (MPI_Comm)jComm;
MPI_Datatype sType;
void *sPtr, *sBase, *rPtr, *rBase;
if(sjType == 0)
{
assert(sendBuf == NULL);
sType = MPI_DATATYPE_NULL;
sPtr = MPI_IN_PLACE;
sBase = NULL;
}
else
{
sType = (MPI_Datatype)sjType;
sPtr = ompi_java_getBufPtr(&sBase, env, sendBuf, sdb, sBType, sOffset);
}
MPI_Datatype rType = (MPI_Datatype)rjType;
rPtr = ompi_java_getBufPtr(&rBase, env, recvBuf, rdb, rBType, rOffset);
int rc = MPI_Allgather(sPtr, sCount, sType, rPtr, rCount, rType, comm);
ompi_java_exceptionCheck(env, rc);
ompi_java_releaseBufPtr(env, recvBuf, rdb, rBase, rBType);
if(sendBuf != NULL)
ompi_java_releaseReadBufPtr(env, sendBuf, sdb, sBase, sBType);
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_iAllGather(
JNIEnv *env, jobject jthis, jlong comm,
jobject sendBuf, jint sCount, jlong sType,
jobject recvBuf, jint rCount, jlong rType)
{
void *sPtr, *rPtr;
MPI_Request request;
if(sType == 0)
{
assert(sendBuf == NULL);
sType = (jlong)MPI_DATATYPE_NULL;
sPtr = MPI_IN_PLACE;
}
else
{
sPtr = ompi_java_getDirectBufferAddress(env, sendBuf);
}
rPtr = ompi_java_getDirectBufferAddress(env, recvBuf);
int rc = MPI_Iallgather(sPtr, sCount, (MPI_Datatype)sType,
rPtr, rCount, (MPI_Datatype)rType,
(MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT void JNICALL Java_mpi_Comm_allGatherv(
JNIEnv *env, jobject jthis, jlong jComm,
jobject sendBuf, jboolean sdb, jint sOffset,
jint sCount, jlong sjType, jint sBType,
jobject recvBuf, jboolean rdb, jint rOffset,
jintArray rCounts, jintArray displs, jlong rjType, jint rBType)
{
MPI_Comm comm = (MPI_Comm)jComm;
void *sPtr, *sBase, *rPtr, *rBase;
MPI_Datatype sType;
if(sjType == 0)
{
assert(sendBuf == NULL);
sType = MPI_DATATYPE_NULL;
sPtr = MPI_IN_PLACE;
sBase = NULL;
}
else
{
sType = (MPI_Datatype)sjType;
sPtr = ompi_java_getBufPtr(&sBase, env, sendBuf, sdb, sBType, sOffset);
}
MPI_Datatype rType = (MPI_Datatype)rjType;
jint *jRCounts, *jDispls;
int *cRCounts, *cDispls;
ompi_java_getIntArray(env, rCounts, &jRCounts, &cRCounts);
ompi_java_getIntArray(env, displs, &jDispls, &cDispls);
rPtr = ompi_java_getBufPtr(&rBase, env, recvBuf, rdb, rBType, rOffset);
int rc = MPI_Allgatherv(sPtr, sCount, sType, rPtr,
cRCounts, cDispls, rType, comm);
ompi_java_exceptionCheck(env, rc);
ompi_java_releaseBufPtr(env, recvBuf, rdb, rBase, rBType);
if(sendBuf != NULL)
ompi_java_releaseReadBufPtr(env, sendBuf, sdb, sBase, sBType);
ompi_java_forgetIntArray(env, rCounts, jRCounts, cRCounts);
ompi_java_forgetIntArray(env, displs, jDispls, cDispls);
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_iAllGatherv(
JNIEnv *env, jobject jthis, jlong comm,
jobject sendBuf, jint sCount, jlong sType,
jobject recvBuf, jintArray rCounts, jintArray displs, jlong rType)
{
MPI_Request request;
void *sPtr, *rPtr;
if(sType == 0)
{
assert(sendBuf == NULL);
sType = (jlong)MPI_DATATYPE_NULL;
sPtr = MPI_IN_PLACE;
}
else
{
sPtr = ompi_java_getDirectBufferAddress(env, sendBuf);
}
jint *jRCounts, *jDispls;
int *cRCounts, *cDispls;
ompi_java_getIntArray(env, rCounts, &jRCounts, &cRCounts);
ompi_java_getIntArray(env, displs, &jDispls, &cDispls);
rPtr = ompi_java_getDirectBufferAddress(env, recvBuf);
int rc = MPI_Iallgatherv(sPtr, sCount, (MPI_Datatype)sType,
rPtr, cRCounts, cDispls, (MPI_Datatype)rType,
(MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
ompi_java_forgetIntArray(env, rCounts, jRCounts, cRCounts);
ompi_java_forgetIntArray(env, displs, jDispls, cDispls);
return (jlong)request;
}
JNIEXPORT void JNICALL Java_mpi_Comm_allToAll(
JNIEnv *env, jobject jthis, jlong jComm,
jobject sendBuf, jboolean sdb, jint sOffset,
jint sCount, jlong sjType, jint sBType,
jobject recvBuf, jboolean rdb, jint rOffset,
jint rCount, jlong rjType, jint rBType)
{
MPI_Comm comm = (MPI_Comm)jComm;
MPI_Datatype sType = (MPI_Datatype)sjType;
MPI_Datatype rType = (MPI_Datatype)rjType;
void *sPtr, *sBase, *rPtr, *rBase;
rPtr = ompi_java_getBufPtr(&rBase, env, recvBuf, rdb, rBType, rOffset);
sPtr = ompi_java_getBufPtr(&sBase, env, sendBuf, sdb, sBType, sOffset);
int rc = MPI_Alltoall(sPtr, sCount, sType, rPtr, rCount, rType, comm);
ompi_java_exceptionCheck(env, rc);
ompi_java_releaseReadBufPtr(env, sendBuf, sdb, sBase, sBType);
ompi_java_releaseBufPtr(env, recvBuf, rdb, rBase, rBType);
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_iAllToAll(
JNIEnv *env, jobject jthis, jlong comm,
jobject sendBuf, jint sCount, jlong sType,
jobject recvBuf, jint rCount, jlong rType)
{
void *sPtr = ompi_java_getDirectBufferAddress(env, sendBuf),
*rPtr = ompi_java_getDirectBufferAddress(env, recvBuf);
MPI_Request request;
int rc = MPI_Ialltoall(sPtr, sCount, (MPI_Datatype)sType,
rPtr, rCount, (MPI_Datatype)rType,
(MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT void JNICALL Java_mpi_Comm_allToAllv(
JNIEnv *env, jobject jthis, jlong jComm,
jobject sendBuf, jboolean sdb, jint sOffset, jintArray sCount,
jintArray sDispls, jlong sjType, jint sBType,
jobject recvBuf, jboolean rdb, jint rOffset, jintArray rCount,
jintArray rDispls, jlong rjType, jint rBType)
{
MPI_Comm comm = (MPI_Comm)jComm;
MPI_Datatype sType = (MPI_Datatype)sjType;
MPI_Datatype rType = (MPI_Datatype)rjType;
jint *jSCount, *jRCount, *jSDispls, *jRDispls;
int *cSCount, *cRCount, *cSDispls, *cRDispls;
ompi_java_getIntArray(env, sCount, &jSCount, &cSCount);
ompi_java_getIntArray(env, rCount, &jRCount, &cRCount);
ompi_java_getIntArray(env, sDispls, &jSDispls, &cSDispls);
ompi_java_getIntArray(env, rDispls, &jRDispls, &cRDispls);
void *sPtr, *sBase, *rPtr, *rBase;
rPtr = ompi_java_getBufPtr(&rBase, env, recvBuf, rdb, rBType, rOffset);
sPtr = ompi_java_getBufPtr(&sBase, env, sendBuf, sdb, sBType, sOffset);
int rc = MPI_Alltoallv(sPtr, cSCount, cSDispls, sType,
rPtr, cRCount, cRDispls, rType, comm);
ompi_java_exceptionCheck(env, rc);
ompi_java_releaseReadBufPtr(env, sendBuf, sdb, sBase, sBType);
ompi_java_releaseBufPtr(env, recvBuf, rdb, rBase, rBType);
ompi_java_forgetIntArray(env, sCount, jSCount, cSCount);
ompi_java_forgetIntArray(env, rCount, jRCount, cRCount);
ompi_java_forgetIntArray(env, sDispls, jSDispls, cSDispls);
ompi_java_forgetIntArray(env, rDispls, jRDispls, cRDispls);
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_iAllToAllv(
JNIEnv *env, jobject jthis, jlong comm,
jobject sendBuf, jintArray sCount, jintArray sDispls, jlong sType,
jobject recvBuf, jintArray rCount, jintArray rDispls, jlong rType)
{
jint *jSCount, *jRCount, *jSDispls, *jRDispls;
int *cSCount, *cRCount, *cSDispls, *cRDispls;
ompi_java_getIntArray(env, sCount, &jSCount, &cSCount);
ompi_java_getIntArray(env, rCount, &jRCount, &cRCount);
ompi_java_getIntArray(env, sDispls, &jSDispls, &cSDispls);
ompi_java_getIntArray(env, rDispls, &jRDispls, &cRDispls);
void *sPtr = ompi_java_getDirectBufferAddress(env, sendBuf),
*rPtr = ompi_java_getDirectBufferAddress(env, recvBuf);
MPI_Request request;
int rc = MPI_Ialltoallv(sPtr, cSCount, cSDispls, (MPI_Datatype)sType,
rPtr, cRCount, cRDispls, (MPI_Datatype)rType,
(MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
ompi_java_forgetIntArray(env, sCount, jSCount, cSCount);
ompi_java_forgetIntArray(env, rCount, jRCount, cRCount);
ompi_java_forgetIntArray(env, sDispls, jSDispls, cSDispls);
ompi_java_forgetIntArray(env, rDispls, jRDispls, cRDispls);
return (jlong)request;
}
JNIEXPORT void JNICALL Java_mpi_Comm_reduce(
JNIEnv *env, jobject jthis, jlong jComm,
jobject sendBuf, jboolean sdb, jint sOffset,
jobject recvBuf, jboolean rdb, jint rOffset, jint count,
jlong jType, jint baseType, jobject jOp, jlong hOp, jint root)
{
MPI_Comm comm = (MPI_Comm)jComm;
int id;
int rc = MPI_Comm_rank(comm, &id);
int rootOrInter = id == root || isInter(env, comm);
if(ompi_java_exceptionCheck(env, rc))
return;
MPI_Datatype type = (MPI_Datatype)jType;
void *sPtr, *sBase, *rPtr = NULL, *rBase;
if(sendBuf == NULL)
sPtr = MPI_IN_PLACE;
else
sPtr = ompi_java_getBufPtr(&sBase, env, sendBuf, sdb, baseType, sOffset);
if(rootOrInter || sendBuf == NULL)
{
rPtr = ompi_java_getBufPtr(&rBase, env, recvBuf, rdb, baseType, rOffset);
if(!rootOrInter)
{
/* The receive buffer is ignored for all non-root processes.
* As we are using MPI_IN_PLACE version, we use the receive
* buffer as the send buffer.
*/
assert(sendBuf == NULL);
sPtr = rPtr;
}
}
MPI_Op op = ompi_java_op_getHandle(env, jOp, hOp, baseType);
rc = MPI_Reduce(sPtr, rPtr, count, type, op, root, comm);
ompi_java_exceptionCheck(env, rc);
if(sendBuf != NULL)
ompi_java_releaseReadBufPtr(env, sendBuf, sdb, sBase, baseType);
if(rootOrInter || sendBuf == NULL)
ompi_java_releaseBufPtr(env, recvBuf, rdb, rBase, baseType);
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_iReduce(
JNIEnv *env, jobject jthis, jlong comm,
jobject sendBuf, jobject recvBuf, int count,
jlong type, jint baseType, jobject jOp, jlong hOp, jint root)
{
int id;
int rc = MPI_Comm_rank((MPI_Comm)comm, &id);
int rootOrInter = id == root || isInter(env, (MPI_Comm)comm);
if(ompi_java_exceptionCheck(env, rc))
return (jlong)MPI_REQUEST_NULL;
void *sPtr, *rPtr = NULL;
MPI_Request request;
if(sendBuf == NULL)
sPtr = MPI_IN_PLACE;
else
sPtr = (*env)->GetDirectBufferAddress(env, sendBuf);
if(rootOrInter || sendBuf == NULL)
{
rPtr = (*env)->GetDirectBufferAddress(env, recvBuf);
if(!rootOrInter)
{
/* The receive buffer is ignored for all non-root processes.
* As we are using MPI_IN_PLACE version, we use the receive
* buffer as the send buffer.
*/
assert(sendBuf == NULL);
sPtr = rPtr;
}
}
MPI_Op op = ompi_java_op_getHandle(env, jOp, hOp, baseType);
rc = MPI_Ireduce(sPtr, rPtr, count, (MPI_Datatype)type,
op, root, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT void JNICALL Java_mpi_Comm_allReduce(
JNIEnv *env, jobject jthis, jlong jComm,
jobject sendBuf, jboolean sdb, jint sendOffset,
jobject recvBuf, jboolean rdb, jint recvOffset,
jint count, jlong jType, jint baseType, jobject jOp, jlong hOp)
{
MPI_Comm comm = (MPI_Comm)jComm;
MPI_Datatype type = (MPI_Datatype)jType;
void *sPtr, *sBase, *rPtr, *rBase;
if(sendBuf == NULL)
sPtr = MPI_IN_PLACE;
else
sPtr = ompi_java_getBufPtr(&sBase, env, sendBuf, sdb, baseType, sendOffset);
rPtr = ompi_java_getBufPtr(&rBase, env, recvBuf, rdb, baseType, recvOffset);
MPI_Op op = ompi_java_op_getHandle(env, jOp, hOp, baseType);
int rc = MPI_Allreduce(sPtr, rPtr, count, type, op, comm);
ompi_java_exceptionCheck(env, rc);
ompi_java_releaseBufPtr(env, recvBuf, rdb, rBase, baseType);
if(sendBuf != NULL)
ompi_java_releaseReadBufPtr(env, sendBuf, sdb, sBase, baseType);
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_iAllReduce(
JNIEnv *env, jobject jthis, jlong comm,
jobject sendBuf, jobject recvBuf, jint count,
jlong type, jint baseType, jobject jOp, jlong hOp)
{
MPI_Request request;
void *sPtr, *rPtr;
if(sendBuf == NULL)
sPtr = MPI_IN_PLACE;
else
sPtr = (*env)->GetDirectBufferAddress(env, sendBuf);
rPtr = (*env)->GetDirectBufferAddress(env, recvBuf);
MPI_Op op = ompi_java_op_getHandle(env, jOp, hOp, baseType);
int rc = MPI_Iallreduce(sPtr, rPtr, count, (MPI_Datatype)type,
op, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT void JNICALL Java_mpi_Comm_reduceScatter(
JNIEnv *env, jobject jthis, jlong jComm,
jobject sendBuf, jboolean sdb, jint sOffset,
jobject recvBuf, jboolean rdb, jint rOffset,
jintArray rCounts, jlong jType, jint bType, jobject jOp, jlong hOp)
{
MPI_Comm comm = (MPI_Comm)jComm;
MPI_Datatype type = (MPI_Datatype)jType;
void *sPtr, *sBase, *rPtr, *rBase;
if(sendBuf == NULL)
sPtr = MPI_IN_PLACE;
else
sPtr = ompi_java_getBufPtr(&sBase, env, sendBuf, sdb, bType, sOffset);
rPtr = ompi_java_getBufPtr(&rBase, env, recvBuf, rdb, bType, rOffset);
MPI_Op op = ompi_java_op_getHandle(env, jOp, hOp, bType);
jint *jRCounts;
int *cRCounts;
ompi_java_getIntArray(env, rCounts, &jRCounts, &cRCounts);
int rc = MPI_Reduce_scatter(sPtr, rPtr, cRCounts, type, op, comm);
ompi_java_exceptionCheck(env, rc);
ompi_java_releaseBufPtr(env, recvBuf, rdb, rBase, bType);
ompi_java_forgetIntArray(env, rCounts, jRCounts, cRCounts);
if(sendBuf != NULL)
ompi_java_releaseReadBufPtr(env, sendBuf, sdb, sBase, bType);
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_iReduceScatter(
JNIEnv *env, jobject jthis, jlong comm,
jobject sendBuf, jobject recvBuf, jintArray rCounts,
jlong type, int bType, jobject jOp, jlong hOp)
{
void *sPtr, *rPtr;
if(sendBuf == NULL)
sPtr = MPI_IN_PLACE;
else
sPtr = (*env)->GetDirectBufferAddress(env, sendBuf);
rPtr = (*env)->GetDirectBufferAddress(env, recvBuf);
MPI_Op op = ompi_java_op_getHandle(env, jOp, hOp, bType);
MPI_Request request;
jint *jRCounts;
int *cRCounts;
ompi_java_getIntArray(env, rCounts, &jRCounts, &cRCounts);
int rc = MPI_Ireduce_scatter(sPtr, rPtr, cRCounts, (MPI_Datatype)type,
op, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
ompi_java_forgetIntArray(env, rCounts, jRCounts, cRCounts);
return (jlong)request;
}
JNIEXPORT void JNICALL Java_mpi_Comm_reduceScatterBlock(
JNIEnv *env, jobject jthis, jlong jComm,
jobject sendBuf, jboolean sdb, jint sOffset,
jobject recvBuf, jboolean rdb, jint rOffset,
jint count, jlong jType, jint bType, jobject jOp, jlong hOp)
{
MPI_Comm comm = (MPI_Comm)jComm;
MPI_Datatype type = (MPI_Datatype)jType;
void *sPtr, *sBase, *rPtr, *rBase;
if(sendBuf == NULL)
sPtr = MPI_IN_PLACE;
else
sPtr = ompi_java_getBufPtr(&sBase, env, sendBuf, sdb, bType, sOffset);
rPtr = ompi_java_getBufPtr(&rBase, env, recvBuf, rdb, bType, rOffset);
MPI_Op op = ompi_java_op_getHandle(env, jOp, hOp, bType);
int rc = MPI_Reduce_scatter_block(sPtr, rPtr, count, type, op, comm);
ompi_java_exceptionCheck(env, rc);
ompi_java_releaseBufPtr(env, recvBuf, rdb, rBase, bType);
if(sendBuf != NULL)
ompi_java_releaseReadBufPtr(env, sendBuf, sdb, sBase, bType);
}
JNIEXPORT jlong JNICALL Java_mpi_Comm_iReduceScatterBlock(
JNIEnv *env, jobject jthis, jlong comm, jobject sendBuf,
jobject recvBuf, jint count, jlong type, jint bType,
jobject jOp, jlong hOp)
{
void *sPtr, *rPtr;
if(sendBuf == NULL)
sPtr = MPI_IN_PLACE;
else
sPtr = (*env)->GetDirectBufferAddress(env, sendBuf);
rPtr = (*env)->GetDirectBufferAddress(env, recvBuf);
MPI_Op op = ompi_java_op_getHandle(env, jOp, hOp, bType);
MPI_Request request;
int rc = MPI_Ireduce_scatter_block(sPtr, rPtr, count, (MPI_Datatype)type,
op, (MPI_Comm)comm, &request);
ompi_java_exceptionCheck(env, rc);
return (jlong)request;
}
JNIEXPORT void JNICALL Java_mpi_Comm_reduceLocal(
JNIEnv *env, jclass clazz, jobject inBuf, jboolean idb, jint inOff,
jobject inOutBuf, jboolean iodb, jint inOutOff, jint count,
jlong jType, jint bType, jlong op)
{
MPI_Datatype type = (MPI_Datatype)jType;
void *inPtr, *inBase, *inOutPtr, *inOutBase;
inPtr = getBufCritical(&inBase, env, inBuf, idb, bType, inOff);
inOutPtr = getBufCritical(&inOutBase, env, inOutBuf, iodb, bType, inOutOff);
int rc = MPI_Reduce_local(inPtr, inOutPtr, count, type, (MPI_Op)op);
ompi_java_exceptionCheck(env, rc);
releaseBufCritical(env, inBuf, idb, inBase);
releaseBufCritical(env, inOutBuf, iodb, inOutBase);
}
JNIEXPORT void JNICALL Java_mpi_Comm_reduceLocalUf(
JNIEnv *env, jclass clazz, jobject inBuf, jboolean idb, jint inOff,
jobject inOutBuf, jboolean iodb, jint inOutOff, jint count,
jlong jType, jint bType, jobject jOp, jlong hOp)
{
MPI_Datatype type = (MPI_Datatype)jType;
void *inPtr, *inBase, *inOutPtr, *inOutBase;
inPtr = ompi_java_getBufPtr(&inBase, env, inBuf, idb, bType, inOff);
inOutPtr = ompi_java_getBufPtr(&inOutBase,env,inOutBuf,iodb,bType,inOutOff);
MPI_Op op = ompi_java_op_getHandle(env, jOp, hOp, bType);
int rc = MPI_Reduce_local(inPtr, inOutPtr, count, type, op);
ompi_java_exceptionCheck(env, rc);
ompi_java_releaseReadBufPtr(env, inBuf, idb, inBase, bType);
ompi_java_releaseBufPtr(env, inOutBuf, iodb, inOutBase, bType);
}
JNIEXPORT void JNICALL Java_mpi_Comm_setName(
JNIEnv *env, jobject jthis, jlong handle, jstring jname)
{
const char *name = (*env)->GetStringUTFChars(env, jname, NULL);
int rc = MPI_Comm_set_name((MPI_Comm)handle, (char*)name);
ompi_java_exceptionCheck(env, rc);
(*env)->ReleaseStringUTFChars(env, jname, name);
}
JNIEXPORT jstring JNICALL Java_mpi_Comm_getName(
JNIEnv *env, jobject jthis, jlong handle)
{
char name[MPI_MAX_OBJECT_NAME];
int len;
int rc = MPI_Comm_get_name((MPI_Comm)handle, name, &len);
if(ompi_java_exceptionCheck(env, rc))
return NULL;
return (*env)->NewStringUTF(env, name);
}