| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206 | /* StarPU --- Runtime system for heterogeneous multicore architectures. * * Copyright (C) 2011-2013                                Inria * Copyright (C) 2010-2013,2015,2017,2019                 CNRS * Copyright (C) 2012,2013,2017                           Université de Bordeaux * * 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 <starpu.h>#include "../test_interfaces.h"#include "../../../helper.h"/* * In this test, we use the following matrix:  * *   +----------------+ *   |  0   1   0   0 | *   |  2   3   0   0 | *   |  4   5   8   9 | *   |  6   7  10  11 | *   +----------------+ * * nzval  = [0, 1, 2, 3] ++ [4, 5, 6, 7] ++ [8, 9, 10, 11] * colind = [0, 0, 1] * rowptr = [0, 1, 3 ] * r = c = 2 *//* Size of the blocks */#define R              2#define C              2#define NNZ_BLOCKS     3   /* out of 4 */#define NZVAL_SIZE     (R*C*NNZ_BLOCKS)#define NROWS          2#ifdef STARPU_USE_CPUvoid test_bcsr_cpu_func(void *buffers[], void *args);#endif /* !STARPU_USE_CPU */#ifdef STARPU_USE_CUDAextern void test_bcsr_cuda_func(void *buffers[], void *_args);#endif /* !STARPU_USE_CUDA */#ifdef STARPU_USE_OPENCLextern void test_bcsr_opencl_func(void *buffers[], void *args);#endif /* !STARPU_USE_OPENCL */static int nzval[NZVAL_SIZE]  ={	0, 1, 2, 3,    /* First block  */	4, 5, 6, 7,    /* Second block */	8, 9, 10, 11   /* Third block  */};static int nzval2[NZVAL_SIZE];static uint32_t colind[NNZ_BLOCKS] = { 0, 0, 1 };static uint32_t colind2[NNZ_BLOCKS];static uint32_t rowptr[NROWS+1] = { 0, 1, NNZ_BLOCKS };static uint32_t rowptr2[NROWS+1] = { 0, 0, NNZ_BLOCKS };static starpu_data_handle_t bcsr_handle;static starpu_data_handle_t bcsr2_handle;struct test_config bcsr_config ={#ifdef STARPU_USE_CPU	.cpu_func      = test_bcsr_cpu_func,#endif /* !STARPU_USE_CPU */#ifdef STARPU_USE_CUDA	.cuda_func     = test_bcsr_cuda_func,#endif /* !STARPU_USE_CUDA */#ifdef STARPU_USE_OPENCL	.opencl_func   = test_bcsr_opencl_func,#endif /* !STARPU_USE_OPENCL */#ifdef STARPU_USE_MIC	.cpu_func_name = "test_bcsr_cpu_func",#endif	.handle        = &bcsr_handle,	.dummy_handle  = &bcsr2_handle,	.copy_failed   = SUCCESS,	.name          = "bcsr_interface"};static voidregister_data(void){	starpu_bcsr_data_register(&bcsr_handle,				  STARPU_MAIN_RAM,				  NNZ_BLOCKS,				  NROWS,				  (uintptr_t) nzval,				  colind,				  rowptr,				  0, /* firstentry */				  R,				  C,				  sizeof(nzval[0]));	starpu_bcsr_data_register(&bcsr2_handle,				  STARPU_MAIN_RAM,				  NNZ_BLOCKS,				  NROWS,				  (uintptr_t) nzval2,				  colind2,				  rowptr2,				  0, /* firstentry */				  R,				  C,				  sizeof(nzval2[0]));}static voidunregister_data(void){	starpu_data_unregister(bcsr_handle);	starpu_data_unregister(bcsr2_handle);}voidtest_bcsr_cpu_func(void *buffers[], void *args){	STARPU_SKIP_IF_VALGRIND;	int *val;	int factor;	int i;	uint32_t nnz = STARPU_BCSR_GET_NNZ(buffers[0]); 	uint32_t r   = ((struct starpu_bcsr_interface *)buffers[0])->r; 	uint32_t c   = ((struct starpu_bcsr_interface *)buffers[0])->c;	if (r != R || c != C)	{		bcsr_config.copy_failed = FAILURE;		return;	}	nnz *= (r*c);	val = (int *) STARPU_BCSR_GET_NZVAL(buffers[0]);	factor = *(int *) args;	for (i = 0; i < (int)nnz; i++)	{		if (val[i] != i * factor)		{			bcsr_config.copy_failed = FAILURE;			return;		}		val[i] *= -1;	}#if 0	/* TODO */	/* Check colind */	uint32_t *col = STARPU_BCSR_GET_COLIND(buffers[0]);	for (i = 0; i < NNZ_BLOCKS; i++)		if (col[i] != colind[i])			bcsr_config.copy_failed = FAILURE;	/* Check rowptr */	uint32_t *row = STARPU_BCSR_GET_ROWPTR(buffers[0]);	for (i = 0; i < 1 + WIDTH/R; i++)		if (row[i] != rowptr[i])			bcsr_config.copy_failed = FAILURE;#endif}intmain(int argc, char **argv){	struct data_interface_test_summary summary;	struct starpu_conf conf;	starpu_conf_init(&conf);	conf.ncuda = 2;	conf.nopencl = 1;	conf.nmic = -1;	if (starpu_initialize(&conf, &argc, &argv) == -ENODEV || starpu_cpu_worker_get_count() == 0)		return STARPU_TEST_SKIPPED;	register_data();	run_tests(&bcsr_config, &summary);	unregister_data();	starpu_shutdown();	data_interface_test_summary_print(stderr, &summary);	return data_interface_test_summary_success(&summary);}
 |