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$
|
|
|
|
|
*
|
|
|
|
|
* This program is an adaptation of examples found in the man pages
|
|
|
|
|
* of SGI’s SHMEM implementation.
|
|
|
|
|
*
|
|
|
|
|
* In this program, iput is used to select 5 elements from array source separated by
|
|
|
|
|
* a stride of 2 and write them to array target using a stride of 1.
|
|
|
|
|
*
|
|
|
|
|
* Given the array source = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }
|
|
|
|
|
* iput will select 5 elements from array source on PE 0, using a stride of 2:
|
|
|
|
|
*
|
|
|
|
|
* selected elements = { 1, 3, 5, 7, 9 }
|
|
|
|
|
*
|
|
|
|
|
* These elements will then be written to the array source on PE 1 using a stride of 1:
|
|
|
|
|
*
|
|
|
|
|
* target = { 1, 3, 5, 7, 9 }
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
#include <shmem.h>
|
|
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
|
{
|
|
|
|
|
short source[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
|
|
|
|
|
static short target[10];
|
|
|
|
|
int me;
|
|
|
|
|
|
2016-10-21 12:36:53 +06:00
|
|
|
|
shmem_init();
|
|
|
|
|
me = shmem_my_pe();
|
2014-04-19 05:03:44 +00:00
|
|
|
|
|
|
|
|
|
if (me == 0) {
|
|
|
|
|
/* put 10 words into target on PE 1 */
|
|
|
|
|
shmem_short_iput(target, source, 1, 2, 5, 1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
shmem_barrier_all(); /* sync sender and receiver */
|
|
|
|
|
|
|
|
|
|
if (me == 1) {
|
|
|
|
|
printf("target on PE %d is %hd %hd %hd %hd %hd\n", me,
|
|
|
|
|
target[0], target[1], target[2],
|
|
|
|
|
target[3], target[4] );
|
|
|
|
|
}
|
|
|
|
|
shmem_barrier_all(); /* sync before exiting */
|
2016-10-21 12:36:53 +06:00
|
|
|
|
shmem_finalize();
|
2014-04-19 05:03:44 +00:00
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|