| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 | /* StarPU --- Runtime system for heterogeneous multicore architectures. * * Copyright (C) 2010  Université de Bordeaux 1 * Copyright (C) 2010  Centre National de la Recherche Scientifique * * StarPU is free software; you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation; either version 2.1 of the License, or (at * your option) any later version. * * StarPU is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * * See the GNU Lesser General Public License in COPYING.LGPL for more details. */#include <stdio.h>#include <unistd.h>#include <errno.h>#include <starpu.h>#include <stdlib.h>#include <pthread.h>#define NBUFFERS	16#define NITER		128struct data {	unsigned index;	unsigned val;	starpu_data_handle handle;};struct data buffers[NBUFFERS];void callback_sync_data(void *arg){	struct data *data = arg;	data->val++;	starpu_data_release(data->handle);}int main(int argc, char **argv){	starpu_init(NULL);	unsigned b;	for (b = 0; b < NBUFFERS; b++)	{		buffers[b].index = b;		starpu_variable_data_register(&buffers[b].handle, 0, (uintptr_t)&buffers[b].val, sizeof(unsigned));	}	unsigned iter;	for (iter = 0; iter < NITER; iter++)	for (b = 0; b < NBUFFERS; b++)	{		starpu_data_acquire_cb(buffers[b].handle, STARPU_RW,							callback_sync_data, &buffers[b]);	}	starpu_task_wait_for_all();	/* do some cleanup */	for (b = 0; b < NBUFFERS; b++)	{		starpu_data_unregister(buffers[b].handle);		/* check result */		if (buffers[b].val != NITER)		{			fprintf(stderr, "buffer[%d] = %d should be %d\n", b, buffers[b].val, NITER);			STARPU_ABORT();		}	}	starpu_shutdown();	return 0;}
 |