2016-09-28 23:25:55 +03:00
|
|
|
#include "orte_config.h"
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <signal.h>
|
|
|
|
#include <math.h>
|
|
|
|
#include <sys/time.h>
|
|
|
|
|
|
|
|
#include "opal/runtime/opal_progress.h"
|
|
|
|
|
|
|
|
#include "orte/util/proc_info.h"
|
|
|
|
#include "orte/util/name_fns.h"
|
|
|
|
#include "orte/runtime/orte_globals.h"
|
|
|
|
#include "orte/mca/rml/rml.h"
|
|
|
|
#include "orte/mca/errmgr/errmgr.h"
|
|
|
|
|
|
|
|
#include "orte/runtime/runtime.h"
|
|
|
|
#include "orte/runtime/orte_wait.h"
|
|
|
|
#include "orte/util/attr.h"
|
|
|
|
|
|
|
|
#define MY_TAG 12345
|
|
|
|
#define MAX_COUNT 3
|
|
|
|
|
|
|
|
static bool msg_recvd;
|
|
|
|
static volatile bool msg_active;
|
|
|
|
|
|
|
|
static void send_callback(int status, orte_process_name_t *peer,
|
|
|
|
opal_buffer_t* buffer, orte_rml_tag_t tag,
|
|
|
|
void* cbdata)
|
|
|
|
|
|
|
|
{
|
|
|
|
OBJ_RELEASE(buffer);
|
|
|
|
if (ORTE_SUCCESS != status) {
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
msg_active = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
main(int argc, char *argv[]){
|
|
|
|
int count;
|
|
|
|
int msgsize;
|
|
|
|
uint8_t *msg;
|
|
|
|
int i, j, rc;
|
|
|
|
orte_process_name_t peer;
|
|
|
|
double maxpower;
|
|
|
|
opal_buffer_t *buf;
|
|
|
|
orte_rml_recv_cb_t blob;
|
|
|
|
int conduit_id = 0; //use the first available conduit
|
|
|
|
struct timeval start, end;
|
|
|
|
opal_list_t *conduit_attr;
|
2016-10-21 23:14:25 +03:00
|
|
|
|
2016-09-28 23:25:55 +03:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Init
|
|
|
|
*/
|
|
|
|
orte_init(&argc, &argv, ORTE_PROC_NON_MPI);
|
|
|
|
|
2016-10-21 23:14:25 +03:00
|
|
|
|
2016-09-28 23:25:55 +03:00
|
|
|
conduit_attr = OBJ_NEW(opal_list_t);
|
2016-10-21 23:14:25 +03:00
|
|
|
if( ORTE_SUCCESS ==
|
|
|
|
( orte_set_attribute( conduit_attr, ORTE_RML_PROVIDER_ATTRIB, ORTE_ATTR_GLOBAL,"sockets",OPAL_STRING))) {
|
|
|
|
if( ORTE_SUCCESS ==
|
2016-09-28 23:25:55 +03:00
|
|
|
( orte_set_attribute( conduit_attr, ORTE_RML_INCLUDE_COMP_ATTRIB, ORTE_ATTR_GLOBAL,"ofi",OPAL_STRING))) {
|
|
|
|
opal_output(0, "%s calling open_conduit with ORTE_RML_INCLUDE_COMP_ATTRIB and ORTE_RML_OFI_PROV_NAME_ATTRIB",
|
|
|
|
ORTE_NAME_PRINT(ORTE_PROC_MY_NAME));
|
|
|
|
conduit_id = orte_rml_API_open_conduit(conduit_attr);
|
|
|
|
if (0 > conduit_id ) {
|
|
|
|
opal_output(0, "Conduit could not be opened for OFI, exiting");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
opal_output(0, "Using conduit-id %d ", conduit_id);
|
|
|
|
|
|
|
|
if (argc > 1) {
|
|
|
|
count = atoi(argv[1]);
|
|
|
|
if (count < 0) {
|
|
|
|
count = INT_MAX-1;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
count = MAX_COUNT;
|
|
|
|
}
|
|
|
|
|
|
|
|
peer.jobid = ORTE_PROC_MY_NAME->jobid;
|
|
|
|
peer.vpid = ORTE_PROC_MY_NAME->vpid + 1;
|
|
|
|
if (peer.vpid == orte_process_info.num_procs) {
|
|
|
|
peer.vpid = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
gettimeofday(&start, NULL);
|
|
|
|
for (j=1; j < count+1; j++) {
|
|
|
|
/* rank0 starts ring */
|
|
|
|
if (ORTE_PROC_MY_NAME->vpid == 0) {
|
|
|
|
/* setup the initiating buffer - put random sized message in it */
|
|
|
|
buf = OBJ_NEW(opal_buffer_t);
|
|
|
|
|
|
|
|
maxpower = (double)(j%7);
|
|
|
|
msgsize = (int)pow(10.0, maxpower);
|
|
|
|
opal_output(0, "Ring %d message size %d bytes", j, msgsize);
|
|
|
|
msg = (uint8_t*)malloc(msgsize);
|
|
|
|
opal_dss.pack(buf, msg, msgsize, OPAL_BYTE);
|
|
|
|
free(msg);
|
2016-10-23 21:36:05 +03:00
|
|
|
orte_rml.send_buffer_nb(conduit_id,&peer, buf, MY_TAG, orte_rml_send_callback, NULL);
|
2016-09-28 23:25:55 +03:00
|
|
|
|
|
|
|
/* wait for it to come around */
|
|
|
|
OBJ_CONSTRUCT(&blob, orte_rml_recv_cb_t);
|
|
|
|
blob.active = true;
|
|
|
|
orte_rml.recv_buffer_nb(ORTE_NAME_WILDCARD, MY_TAG,
|
|
|
|
ORTE_RML_NON_PERSISTENT,
|
|
|
|
orte_rml_recv_callback, &blob);
|
|
|
|
ORTE_WAIT_FOR_COMPLETION(blob.active);
|
|
|
|
OBJ_DESTRUCT(&blob);
|
|
|
|
|
|
|
|
opal_output(0, "%s Ring %d completed", ORTE_NAME_PRINT(ORTE_PROC_MY_NAME), j);
|
|
|
|
} else {
|
|
|
|
/* wait for msg */
|
|
|
|
OBJ_CONSTRUCT(&blob, orte_rml_recv_cb_t);
|
|
|
|
blob.active = true;
|
|
|
|
orte_rml.recv_buffer_nb(ORTE_NAME_WILDCARD, MY_TAG,
|
|
|
|
ORTE_RML_NON_PERSISTENT,
|
|
|
|
orte_rml_recv_callback, &blob);
|
|
|
|
ORTE_WAIT_FOR_COMPLETION(blob.active);
|
|
|
|
|
|
|
|
opal_output(0, "%s received message %d from %s", ORTE_NAME_PRINT(ORTE_PROC_MY_NAME), j, ORTE_NAME_PRINT(&blob.name));
|
|
|
|
|
|
|
|
/* send it along */
|
|
|
|
buf = OBJ_NEW(opal_buffer_t);
|
|
|
|
opal_dss.copy_payload(buf, &blob.data);
|
|
|
|
OBJ_DESTRUCT(&blob);
|
|
|
|
msg_active = true;
|
2016-10-23 21:36:05 +03:00
|
|
|
orte_rml.send_buffer_nb(conduit_id,&peer, buf, MY_TAG, send_callback, NULL);
|
2016-09-28 23:25:55 +03:00
|
|
|
ORTE_WAIT_FOR_COMPLETION(msg_active);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
gettimeofday(&end, NULL);
|
|
|
|
orte_finalize();
|
|
|
|
printf("start: %d secs, %d usecs\n",start.tv_sec,start.tv_usec);
|
|
|
|
printf("end: %d secs, %d usecs\n",end.tv_sec,end.tv_usec);
|
|
|
|
printf("Total minutes = %d, Total seconds = %d", (end.tv_sec - start.tv_sec)/60, (end.tv_sec - start.tv_sec) );
|
|
|
|
return 0;
|
|
|
|
}
|