2014-04-19 05:03:44 +00:00
|
|
|
/*
|
2016-10-21 12:36:53 +06:00
|
|
|
* Copyright (c) 2014-2016 Mellanox Technologies, Inc.
|
2014-04-19 05:03:44 +00:00
|
|
|
* All rights reserved.
|
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <shmem.h>
|
|
|
|
|
|
|
|
int main (void)
|
|
|
|
{
|
|
|
|
static int aaa, bbb;
|
|
|
|
int num_pes, my_pe, peer;
|
|
|
|
|
2016-10-21 12:36:53 +06:00
|
|
|
shmem_init();
|
2014-04-19 05:03:44 +00:00
|
|
|
|
2016-10-21 12:36:53 +06:00
|
|
|
num_pes = shmem_n_pes();
|
|
|
|
my_pe = shmem_my_pe();
|
2014-04-19 05:03:44 +00:00
|
|
|
|
|
|
|
peer = (my_pe + 1) % num_pes;
|
|
|
|
|
|
|
|
printf("Process %d gets message from %d (%d processes in ring)\n", my_pe, peer, num_pes);
|
|
|
|
shmem_int_get(&aaa, &bbb, 1, peer);
|
|
|
|
|
|
|
|
shmem_barrier_all();
|
|
|
|
printf("Process %d exiting\n", my_pe);
|
2016-10-21 12:36:53 +06:00
|
|
|
shmem_finalize();
|
2014-04-19 05:03:44 +00:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|