a47b33678b
Use threads to help process multicast messages. This commit was SVN r24009.
200 строки
6.4 KiB
C
200 строки
6.4 KiB
C
/* -*- C -*-
|
|
*
|
|
* $HEADER$
|
|
*
|
|
*/
|
|
#include <stdio.h>
|
|
#include <unistd.h>
|
|
|
|
#include "opal/dss/dss.h"
|
|
#include "opal/mca/event/event.h"
|
|
#include "opal/util/output.h"
|
|
|
|
#include "orte/util/proc_info.h"
|
|
#include "orte/util/name_fns.h"
|
|
#include "orte/runtime/orte_globals.h"
|
|
#include "orte/runtime/runtime.h"
|
|
#include "orte/runtime/orte_wait.h"
|
|
#include "orte/mca/errmgr/errmgr.h"
|
|
#include "orte/mca/rmcast/rmcast.h"
|
|
#include "orte/mca/grpcomm/grpcomm.h"
|
|
|
|
static void cbfunc(int status,
|
|
orte_rmcast_channel_t channel,
|
|
orte_rmcast_seq_t seq_num,
|
|
orte_rmcast_tag_t tag,
|
|
orte_process_name_t *sender,
|
|
opal_buffer_t *buf, void *cbdata);
|
|
static void cbfunc_buf_snt(int status,
|
|
orte_rmcast_channel_t channel,
|
|
orte_rmcast_seq_t seq_num,
|
|
orte_rmcast_tag_t tag,
|
|
orte_process_name_t *sender,
|
|
opal_buffer_t *buf, void *cbdata);
|
|
|
|
static void cbfunc_iovec(int status,
|
|
orte_rmcast_channel_t channel,
|
|
orte_rmcast_seq_t seq_num,
|
|
orte_rmcast_tag_t tag,
|
|
orte_process_name_t *sender,
|
|
struct iovec *msg, int count, void* cbdata);
|
|
|
|
static int datasize=1024;
|
|
static orte_rmcast_seq_t recvd_seq_num=0;
|
|
static orte_rmcast_seq_t sent_seq_num=0;
|
|
|
|
static void send_data(int fd, short flags, void *arg)
|
|
{
|
|
opal_buffer_t buf, *bfptr;
|
|
int32_t *i32;
|
|
struct iovec iovec_array[3];
|
|
int rc, i;
|
|
opal_event_t *tmp = (opal_event_t*)arg;
|
|
struct timeval now;
|
|
|
|
bfptr = OBJ_NEW(opal_buffer_t);
|
|
i32 = (int32_t*)malloc(datasize*sizeof(int32_t));
|
|
for (i=0; i < datasize; i++) {
|
|
i32[i] = -1;
|
|
}
|
|
opal_dss.pack(bfptr, i32, datasize, OPAL_INT32);
|
|
if (ORTE_SUCCESS != (rc = orte_rmcast.send_buffer_nb(ORTE_RMCAST_GROUP_OUTPUT_CHANNEL,
|
|
ORTE_RMCAST_TAG_OUTPUT, bfptr,
|
|
cbfunc_buf_snt, NULL))) {
|
|
ORTE_ERROR_LOG(rc);
|
|
return;
|
|
}
|
|
sent_seq_num++;
|
|
/* create an iovec array */
|
|
for (i=0; i < 3; i++) {
|
|
iovec_array[i].iov_base = (uint8_t*)malloc(datasize);
|
|
iovec_array[i].iov_len = datasize;
|
|
}
|
|
/* send it out */
|
|
if (ORTE_SUCCESS != (rc = orte_rmcast.send(ORTE_RMCAST_GROUP_OUTPUT_CHANNEL,
|
|
ORTE_RMCAST_TAG_OUTPUT,
|
|
iovec_array, 3))) {
|
|
ORTE_ERROR_LOG(rc);
|
|
return;
|
|
}
|
|
sent_seq_num++;
|
|
|
|
if (0 == (sent_seq_num % 100)) {
|
|
opal_output(0, "SENT SEQ_NUM %lu", sent_seq_num);
|
|
}
|
|
|
|
/* reset the timer */
|
|
now.tv_sec = 0;
|
|
now.tv_usec = 1000;
|
|
opal_event_evtimer_add(tmp, &now);
|
|
}
|
|
|
|
int main(int argc, char* argv[])
|
|
{
|
|
int rc, i;
|
|
char hostname[512];
|
|
pid_t pid;
|
|
opal_buffer_t buf, *bfptr;
|
|
int32_t i32=1;
|
|
struct iovec iovec_array[3];
|
|
|
|
if (0 > (rc = orte_init(&argc, &argv, ORTE_PROC_NON_MPI))) {
|
|
fprintf(stderr, "orte_mcast: couldn't init orte - error code %d\n", rc);
|
|
return rc;
|
|
}
|
|
|
|
gethostname(hostname, 512);
|
|
pid = getpid();
|
|
|
|
if (1 < argc) {
|
|
datasize = strtol(argv[1], NULL, 10);
|
|
}
|
|
|
|
printf("orte_mcast: Node %s Name %s Pid %ld datasize %d\n",
|
|
hostname, ORTE_NAME_PRINT(ORTE_PROC_MY_NAME), (long)pid, datasize);
|
|
|
|
|
|
|
|
if (0 == ORTE_PROC_MY_NAME->vpid) {
|
|
orte_grpcomm.barrier();
|
|
|
|
/* wake up every 5 seconds and send something */
|
|
ORTE_TIMER_EVENT(0, 1000, send_data);
|
|
} else {
|
|
/* setup to recv data on our channel */
|
|
if (ORTE_SUCCESS != (rc = orte_rmcast.recv_buffer_nb(ORTE_RMCAST_GROUP_OUTPUT_CHANNEL,
|
|
ORTE_RMCAST_TAG_OUTPUT,
|
|
ORTE_RMCAST_PERSISTENT,
|
|
cbfunc, NULL))) {
|
|
ORTE_ERROR_LOG(rc);
|
|
}
|
|
if (ORTE_SUCCESS != (rc = orte_rmcast.recv_nb(ORTE_RMCAST_GROUP_OUTPUT_CHANNEL,
|
|
ORTE_RMCAST_TAG_OUTPUT,
|
|
ORTE_RMCAST_PERSISTENT,
|
|
cbfunc_iovec, NULL))) {
|
|
ORTE_ERROR_LOG(rc);
|
|
}
|
|
orte_grpcomm.barrier(); /* ensure the public recv is ready */
|
|
}
|
|
opal_event_dispatch(opal_event_base);
|
|
|
|
blast:
|
|
orte_finalize();
|
|
return 0;
|
|
}
|
|
|
|
static void cbfunc(int status,
|
|
orte_rmcast_channel_t channel,
|
|
orte_rmcast_seq_t seq_num,
|
|
orte_rmcast_tag_t tag,
|
|
orte_process_name_t *sender,
|
|
opal_buffer_t *buffer, void *cbdata)
|
|
{
|
|
int32_t i32, rc;
|
|
|
|
/* retrieve the value sent */
|
|
rc = 1;
|
|
opal_dss.unpack(buffer, &i32, &rc, OPAL_INT32);
|
|
|
|
if (0 < recvd_seq_num) {
|
|
if ((seq_num - recvd_seq_num) != 1) {
|
|
opal_output(0, "%s MESSAGE LOST seq %lu recvd_seq %lu",
|
|
ORTE_NAME_PRINT(ORTE_PROC_MY_NAME), seq_num, recvd_seq_num);
|
|
}
|
|
}
|
|
recvd_seq_num = seq_num;
|
|
if (0 == (recvd_seq_num % 100)) {
|
|
opal_output(0, "RECVD SEQ_NUM %lu", recvd_seq_num);
|
|
}
|
|
|
|
}
|
|
|
|
static void cbfunc_iovec(int status,
|
|
orte_rmcast_channel_t channel,
|
|
orte_rmcast_seq_t seq_num,
|
|
orte_rmcast_tag_t tag,
|
|
orte_process_name_t *sender,
|
|
struct iovec *msg, int count, void* cbdata)
|
|
{
|
|
if (0 < recvd_seq_num) {
|
|
if ((seq_num - recvd_seq_num) != 1) {
|
|
opal_output(0, "%s MESSAGE LOST seq %lu recvd_seq %lu",
|
|
ORTE_NAME_PRINT(ORTE_PROC_MY_NAME), seq_num, recvd_seq_num);
|
|
}
|
|
}
|
|
recvd_seq_num = seq_num;
|
|
if (0 == (recvd_seq_num % 100)) {
|
|
opal_output(0, "RECVD SEQ_NUM %lu", recvd_seq_num);
|
|
}
|
|
}
|
|
|
|
static void cbfunc_buf_snt(int status,
|
|
orte_rmcast_channel_t channel,
|
|
orte_rmcast_seq_t seq_num,
|
|
orte_rmcast_tag_t tag,
|
|
orte_process_name_t *sender,
|
|
opal_buffer_t *buf, void *cbdata)
|
|
{
|
|
OBJ_RELEASE(buf);
|
|
}
|