e4e3e411fc
Includes all MPI functions supported by Open MPI, including MPI-3 functions (as of about 2 weeks ago). Many changes compared to the prior generation of Java bindings; not much is left from the prior generation, actually. The changes include (but are not limited to): * Add support for more than just a subset of MPI-1 functions * Use typical Java case for symbol names * Support Java Direct buffers (giving darn-near "native C" performance) * Support "type struct" better than the prior generation * Make more of an effort for the Java bindings to be a thin layer over the back-end C bindings * ...and more A proper README with more information about what is supported, how to use these bindings, etc. will be committed shortly. This commit was SVN r29263.
334 строки
8.4 KiB
C
334 строки
8.4 KiB
C
#include "ompi_config.h"
|
|
|
|
#include <stdlib.h>
|
|
#ifdef HAVE_TARGETCONDITIONALS_H
|
|
#include <TargetConditionals.h>
|
|
#endif
|
|
|
|
#include "mpi.h"
|
|
#include "mpi_Win.h"
|
|
#include "mpiJava.h"
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: createWin
|
|
* Signature: (Ljava/nio/Buffer;IIJJ)J
|
|
*/
|
|
JNIEXPORT jlong JNICALL Java_mpi_Win_createWin(
|
|
JNIEnv *env, jobject jthis, jobject jBase,
|
|
jint size, jint dispUnit, jlong info, jlong comm)
|
|
{
|
|
void *base = (*env)->GetDirectBufferAddress(env, jBase);
|
|
MPI_Win win;
|
|
|
|
int rc = MPI_Win_create(base, (MPI_Aint)size, dispUnit,
|
|
(MPI_Info)info, (MPI_Comm)comm, &win);
|
|
|
|
ompi_java_exceptionCheck(env, rc);
|
|
return (jlong)win;
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: getGroup
|
|
* Signature: (J)J
|
|
*/
|
|
JNIEXPORT jlong JNICALL Java_mpi_Win_getGroup(
|
|
JNIEnv *env, jobject jthis, jlong win)
|
|
{
|
|
MPI_Group group;
|
|
int rc = MPI_Win_get_group((MPI_Win)win, &group);
|
|
ompi_java_exceptionCheck(env, rc);
|
|
return (jlong)group;
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: put
|
|
* Signature: (JLjava/lang/Object;IJIIIJI)V
|
|
*/
|
|
JNIEXPORT void JNICALL Java_mpi_Win_put(
|
|
JNIEnv *env, jobject jthis, jlong win, jobject origin,
|
|
jint orgCount, jlong orgType, jint targetRank, jint targetDisp,
|
|
jint targetCount, jlong targetType, jint baseType)
|
|
{
|
|
void *orgPtr = (*env)->GetDirectBufferAddress(env, origin);
|
|
|
|
int rc = MPI_Put(orgPtr, orgCount, (MPI_Datatype)orgType,
|
|
targetRank, (MPI_Aint)targetDisp, targetCount,
|
|
(MPI_Datatype)targetType, (MPI_Win)win);
|
|
|
|
ompi_java_exceptionCheck(env, rc);
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: get
|
|
* Signature: (JLjava/lang/Object;IJIIIJI)V
|
|
*/
|
|
JNIEXPORT void JNICALL Java_mpi_Win_get(
|
|
JNIEnv *env, jobject jthis, jlong win, jobject origin,
|
|
jint orgCount, jlong orgType, jint targetRank, jint targetDisp,
|
|
jint targetCount, jlong targetType, jint baseType)
|
|
{
|
|
void *orgPtr = (*env)->GetDirectBufferAddress(env, origin);
|
|
|
|
int rc = MPI_Get(orgPtr, orgCount, (MPI_Datatype)orgType,
|
|
targetRank, (MPI_Aint)targetDisp, targetCount,
|
|
(MPI_Datatype)targetType, (MPI_Win)win);
|
|
|
|
ompi_java_exceptionCheck(env, rc);
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: accumulate
|
|
* Signature: (JLjava/lang/Object;IJIIIJLmpi/Op;I)V
|
|
*/
|
|
JNIEXPORT void JNICALL Java_mpi_Win_accumulate(
|
|
JNIEnv *env, jobject jthis, jlong win,
|
|
jobject origin, jint orgCount, jlong orgType,
|
|
jint targetRank, jint targetDisp, jint targetCount, jlong targetType,
|
|
jobject op, jint baseType)
|
|
{
|
|
void *orgPtr = (*env)->GetDirectBufferAddress(env, origin);
|
|
|
|
MPI_Op mpiOp = ompi_java_op_getHandle(env, op, baseType);
|
|
|
|
int rc = MPI_Accumulate(orgPtr, orgCount, (MPI_Datatype)orgType,
|
|
targetRank, (MPI_Aint)targetDisp, targetCount,
|
|
(MPI_Datatype)targetType, mpiOp, (MPI_Win)win);
|
|
|
|
ompi_java_exceptionCheck(env, rc);
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: fence
|
|
* Signature: (JI)V
|
|
*/
|
|
JNIEXPORT void JNICALL Java_mpi_Win_fence(
|
|
JNIEnv *env, jobject jthis, jlong win, jint assertion)
|
|
{
|
|
int rc = MPI_Win_fence(assertion, (MPI_Win)win);
|
|
ompi_java_exceptionCheck(env, rc);
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: start
|
|
* Signature: (JJI)V
|
|
*/
|
|
JNIEXPORT void JNICALL Java_mpi_Win_start(
|
|
JNIEnv *env, jobject jthis, jlong win, jlong group, jint assertion)
|
|
{
|
|
int rc = MPI_Win_start((MPI_Group)group, assertion, (MPI_Win)win);
|
|
ompi_java_exceptionCheck(env, rc);
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: complete
|
|
* Signature: (J)V
|
|
*/
|
|
JNIEXPORT void JNICALL Java_mpi_Win_complete(
|
|
JNIEnv *env, jobject jthis, jlong win)
|
|
{
|
|
int rc = MPI_Win_complete((MPI_Win)win);
|
|
ompi_java_exceptionCheck(env, rc);
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: post
|
|
* Signature: (JJI)V
|
|
*/
|
|
JNIEXPORT void JNICALL Java_mpi_Win_post(
|
|
JNIEnv *env, jobject jthis, jlong win, jlong group, jint assertion)
|
|
{
|
|
int rc = MPI_Win_post((MPI_Group)group, assertion, (MPI_Win)win);
|
|
ompi_java_exceptionCheck(env, rc);
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: waitFor
|
|
* Signature: (J)V
|
|
*/
|
|
JNIEXPORT void JNICALL Java_mpi_Win_waitFor(
|
|
JNIEnv *env, jobject jthis, jlong win)
|
|
{
|
|
int rc = MPI_Win_wait((MPI_Win)win);
|
|
ompi_java_exceptionCheck(env, rc);
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: test
|
|
* Signature: (J)Z
|
|
*/
|
|
JNIEXPORT jboolean JNICALL Java_mpi_Win_test(
|
|
JNIEnv *env, jobject jthis, jlong win)
|
|
{
|
|
int flag;
|
|
int rc = MPI_Win_test((MPI_Win)win, &flag);
|
|
ompi_java_exceptionCheck(env, rc);
|
|
return flag ? JNI_TRUE : JNI_FALSE;
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: lock
|
|
* Signature: (JIII)V
|
|
*/
|
|
JNIEXPORT void JNICALL Java_mpi_Win_lock(
|
|
JNIEnv *env, jobject jthis, jlong win,
|
|
jint lockType, jint rank, jint assertion)
|
|
{
|
|
int rc = MPI_Win_lock(lockType, rank, assertion, (MPI_Win)win);
|
|
ompi_java_exceptionCheck(env, rc);
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: unlock
|
|
* Signature: (JI)V
|
|
*/
|
|
JNIEXPORT void JNICALL Java_mpi_Win_unlock(
|
|
JNIEnv *env, jobject jthis, jlong win, jint rank)
|
|
{
|
|
int rc = MPI_Win_unlock(rank, (MPI_Win)win);
|
|
ompi_java_exceptionCheck(env, rc);
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: setErrhandler
|
|
* Signature: (JJ)V
|
|
*/
|
|
JNIEXPORT void JNICALL Java_mpi_Win_setErrhandler(
|
|
JNIEnv *env, jobject jthis, jlong win, jlong errhandler)
|
|
{
|
|
int rc = MPI_Win_set_errhandler(
|
|
(MPI_Win)win, (MPI_Errhandler)MPI_ERRORS_RETURN);
|
|
|
|
ompi_java_exceptionCheck(env, rc);
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: callErrhandler
|
|
* Signature: (JI)V
|
|
*/
|
|
JNIEXPORT void JNICALL Java_mpi_Win_callErrhandler(
|
|
JNIEnv *env, jobject jthis, jlong win, jint errorCode)
|
|
{
|
|
int rc = MPI_Win_call_errhandler((MPI_Win)win, errorCode);
|
|
ompi_java_exceptionCheck(env, rc);
|
|
}
|
|
|
|
static int winCopyAttr(MPI_Win oldwin, int keyval, void *extraState,
|
|
void *attrValIn, void *attrValOut, int *flag)
|
|
{
|
|
return ompi_java_attrCopy(attrValIn, attrValOut, flag);
|
|
}
|
|
|
|
static int winDeleteAttr(MPI_Win oldwin, int keyval,
|
|
void *attrVal, void *extraState)
|
|
{
|
|
return ompi_java_attrDelete(attrVal);
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: createKeyval_jni
|
|
* Signature: ()I
|
|
*/
|
|
JNIEXPORT jint JNICALL Java_mpi_Win_createKeyval_1jni(JNIEnv *env, jclass clazz)
|
|
{
|
|
int rc, keyval;
|
|
rc = MPI_Win_create_keyval(winCopyAttr, winDeleteAttr, &keyval, NULL);
|
|
ompi_java_exceptionCheck(env, rc);
|
|
return keyval;
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: freeKeyval_jni
|
|
* Signature: (I)V
|
|
*/
|
|
JNIEXPORT void JNICALL Java_mpi_Win_freeKeyval_1jni(
|
|
JNIEnv *env, jclass clazz, jint keyval)
|
|
{
|
|
int rc = MPI_Win_free_keyval((int*)(&keyval));
|
|
ompi_java_exceptionCheck(env, rc);
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: setAttr_jni
|
|
* Signature: (JI[B)V
|
|
*/
|
|
JNIEXPORT void JNICALL Java_mpi_Win_setAttr(
|
|
JNIEnv *env, jobject jthis, jlong win, jint keyval, jbyteArray jval)
|
|
{
|
|
void *cval = ompi_java_attrSet(env, jval);
|
|
int rc = MPI_Win_set_attr((MPI_Win)win, keyval, cval);
|
|
ompi_java_exceptionCheck(env, rc);
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: getAttr_predefined
|
|
* Signature: (JI)Ljava/lang/Object;
|
|
*/
|
|
JNIEXPORT jobject JNICALL Java_mpi_Win_getAttr(
|
|
JNIEnv *env, jobject jthis, jlong win, jint keyval)
|
|
{
|
|
int flag;
|
|
void *val;
|
|
int rc = MPI_Win_get_attr((MPI_Win)win, keyval, &val, &flag);
|
|
|
|
if(ompi_java_exceptionCheck(env, rc) || !flag)
|
|
return NULL;
|
|
|
|
switch(keyval)
|
|
{
|
|
case MPI_WIN_SIZE:
|
|
return ompi_java_Integer_valueOf(env, (jint)(*((MPI_Aint*)val)));
|
|
case MPI_WIN_DISP_UNIT:
|
|
return ompi_java_Integer_valueOf(env, (jint)(*((int*)val)));
|
|
case MPI_WIN_BASE:
|
|
return ompi_java_Long_valueOf(env, (jlong)val);
|
|
default:
|
|
return ompi_java_attrGet(env, val);
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: deleteAttr_jni
|
|
* Signature: (I)V
|
|
*/
|
|
JNIEXPORT void JNICALL Java_mpi_Win_deleteAttr(
|
|
JNIEnv *env, jobject jthis, jlong win, jint keyval)
|
|
{
|
|
int rc = MPI_Win_delete_attr((MPI_Win)win, keyval);
|
|
ompi_java_exceptionCheck(env, rc);
|
|
}
|
|
|
|
/*
|
|
* Class: mpi_Win
|
|
* Method: free
|
|
* Signature: (J)J
|
|
*/
|
|
JNIEXPORT jlong JNICALL Java_mpi_Win_free(
|
|
JNIEnv *env, jobject jthis, jlong handle)
|
|
{
|
|
MPI_Win win = (MPI_Win)handle;
|
|
int rc = MPI_Win_free(&win);
|
|
ompi_java_exceptionCheck(env, rc);
|
|
return (jlong)win;
|
|
}
|