2012-02-21 02:12:43 +04:00
|
|
|
/*
|
|
|
|
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_Status.c
|
2013-09-27 01:44:39 +04:00
|
|
|
* Headerfile : mpi_Status.h
|
2012-02-21 02:12:43 +04:00
|
|
|
* Author : Sung-Hoon Ko, Xinying Li
|
|
|
|
* Created : Thu Apr 9 12:22:15 1998
|
|
|
|
* Revision : $Revision: 1.9 $
|
|
|
|
* Updated : $Date: 2003/01/16 16:39:34 $
|
|
|
|
* Copyright: Northeast Parallel Architectures Center
|
|
|
|
* at Syracuse University 1998
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "ompi_config.h"
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
#ifdef HAVE_TARGETCONDITIONALS_H
|
|
|
|
#include <TargetConditionals.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "mpi.h"
|
|
|
|
#include "mpi_Status.h"
|
|
|
|
#include "mpiJava.h"
|
|
|
|
|
2014-02-24 00:08:53 +04:00
|
|
|
static void getStatus(MPI_Status *status, jint source, jint tag,
|
|
|
|
jint error, jint cancelled, jlong ucount)
|
2012-02-21 02:12:43 +04:00
|
|
|
{
|
2014-02-24 00:08:53 +04:00
|
|
|
/* Copy the whole thing to C */
|
|
|
|
status->MPI_SOURCE = source;
|
|
|
|
status->MPI_TAG = tag;
|
|
|
|
status->MPI_ERROR = error;
|
|
|
|
status->_cancelled = cancelled;
|
|
|
|
status->_ucount = ucount;
|
|
|
|
}
|
2012-02-21 02:12:43 +04:00
|
|
|
|
2014-02-24 00:08:53 +04:00
|
|
|
JNIEXPORT jint JNICALL Java_mpi_Status_getCount(
|
|
|
|
JNIEnv *env, jobject jthis, jint source, jint tag,
|
|
|
|
jint error, jint cancelled, jlong ucount, jlong jType)
|
|
|
|
{
|
2013-09-27 01:44:39 +04:00
|
|
|
int count;
|
2014-02-24 00:08:53 +04:00
|
|
|
MPI_Status stat;
|
|
|
|
getStatus(&stat, source, tag, error, cancelled, ucount);
|
|
|
|
MPI_Datatype datatype = (MPI_Datatype)jType;
|
2013-09-27 01:44:39 +04:00
|
|
|
int rc = MPI_Get_count(&stat, datatype, &count);
|
|
|
|
ompi_java_exceptionCheck(env, rc);
|
2012-02-21 02:12:43 +04:00
|
|
|
return count;
|
|
|
|
}
|
|
|
|
|
2014-02-24 00:08:53 +04:00
|
|
|
JNIEXPORT jboolean JNICALL Java_mpi_Status_isCancelled(
|
|
|
|
JNIEnv *env, jobject jthis, jint source, jint tag,
|
|
|
|
jint error, jint cancelled, jlong ucount)
|
2012-02-21 02:12:43 +04:00
|
|
|
{
|
|
|
|
int flag;
|
2013-09-27 01:44:39 +04:00
|
|
|
MPI_Status stat;
|
2014-02-24 00:08:53 +04:00
|
|
|
getStatus(&stat, source, tag, error, cancelled, ucount);
|
2013-09-27 01:44:39 +04:00
|
|
|
int rc = MPI_Test_cancelled(&stat, &flag);
|
|
|
|
ompi_java_exceptionCheck(env, rc);
|
|
|
|
return flag==0 ? JNI_FALSE : JNI_TRUE;
|
2012-02-21 02:12:43 +04:00
|
|
|
}
|
|
|
|
|
2014-02-24 00:08:53 +04:00
|
|
|
JNIEXPORT jint JNICALL Java_mpi_Status_getElements(
|
|
|
|
JNIEnv *env, jobject jthis, jint source, jint tag,
|
|
|
|
jint error, jint cancelled, jlong ucount, jlong jType)
|
2012-02-21 02:12:43 +04:00
|
|
|
{
|
2013-09-27 01:44:39 +04:00
|
|
|
int count;
|
2014-02-24 00:08:53 +04:00
|
|
|
MPI_Status stat;
|
|
|
|
getStatus(&stat, source, tag, error, cancelled, ucount);
|
|
|
|
MPI_Datatype datatype = (MPI_Datatype)jType;
|
2013-09-27 01:44:39 +04:00
|
|
|
int rc = MPI_Get_elements(&stat, datatype, &count);
|
|
|
|
ompi_java_exceptionCheck(env, rc);
|
2012-02-21 02:12:43 +04:00
|
|
|
return count;
|
2013-09-27 01:44:39 +04:00
|
|
|
}
|
2012-02-21 02:12:43 +04:00
|
|
|
|
2014-03-01 23:54:36 +04:00
|
|
|
void ompi_java_status_set(JNIEnv *env, jlongArray jData, MPI_Status *status)
|
|
|
|
{
|
|
|
|
/* Copy the whole thing to Java */
|
|
|
|
int i = 0;
|
|
|
|
jlong *data = (*env)->GetPrimitiveArrayCritical(env, jData, NULL);
|
|
|
|
data[i++] = status->MPI_SOURCE;
|
|
|
|
data[i++] = status->MPI_TAG;
|
|
|
|
data[i++] = status->MPI_ERROR;
|
|
|
|
data[i++] = status->_cancelled;
|
|
|
|
data[i++] = status->_ucount;
|
|
|
|
(*env)->ReleasePrimitiveArrayCritical(env, jData, data, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
void ompi_java_status_setIndex(
|
|
|
|
JNIEnv *env, jlongArray jData, MPI_Status *status, int index)
|
2013-09-27 01:44:39 +04:00
|
|
|
{
|
|
|
|
/* Copy the whole thing to Java */
|
2014-03-01 23:54:36 +04:00
|
|
|
int i = 0;
|
|
|
|
jlong *data = (*env)->GetPrimitiveArrayCritical(env, jData, NULL);
|
|
|
|
data[i++] = status->MPI_SOURCE;
|
|
|
|
data[i++] = status->MPI_TAG;
|
|
|
|
data[i++] = status->MPI_ERROR;
|
|
|
|
data[i++] = status->_cancelled;
|
|
|
|
data[i++] = status->_ucount;
|
|
|
|
data[i++] = index;
|
|
|
|
(*env)->ReleasePrimitiveArrayCritical(env, jData, data, 0);
|
2013-09-27 01:44:39 +04:00
|
|
|
}
|