/** * * @file starpu/codelet_zlascal.c * * @copyright 2009-2014 The University of Tennessee and The University of * Tennessee Research Foundation. All rights reserved. * @copyright 2012-2020 Bordeaux INP, CNRS (LaBRI UMR 5800), Inria, * Univ. Bordeaux. All rights reserved. * *** * * @brief Chameleon zlascal StarPU codelet * * @version 1.0.0 * @author Dalal Sukkari * @author Lucas Barros de Assis * @date 2020-03-03 * @precisions normal z -> c d s * */ #include "chameleon_starpu.h" #include "runtime_codelet_z.h" struct cl_zlascal_args_s { cham_uplo_t uplo; int m; int n; CHAMELEON_Complex64_t alpha; CHAM_tile_t *tileA; }; #if !defined(CHAMELEON_SIMULATION) static void cl_zlascal_cpu_func( void *descr[], void *cl_arg ) { struct cl_zlascal_args_s clargs; CHAM_tile_t *tileA; tileA = cti_interface_get(descr[0]); starpu_codelet_unpack_args( cl_arg, &clargs ); TCORE_zlascal( clargs.uplo, clargs.m, clargs.n, clargs.alpha, tileA ); } #endif /* !defined(CHAMELEON_SIMULATION) */ /* * Codelet definition */ CODELETS_CPU( zlascal, cl_zlascal_cpu_func ) void INSERT_TASK_zlascal( const RUNTIME_option_t *options, cham_uplo_t uplo, int m, int n, int nb, CHAMELEON_Complex64_t alpha, const CHAM_desc_t *A, int Am, int An ) { if ( alpha == 0. ) { return INSERT_TASK_zlaset( options, uplo, m, n, alpha, alpha, A, Am, An ); } else if ( alpha == 1. ) { return; } struct cl_zlascal_args_s clargs = { .uplo = uplo, .m = m, .n = n, .alpha = alpha, .tileA = A->get_blktile( A, Am, An ), }; void (*callback)(void*); RUNTIME_request_t *request = options->request; starpu_option_request_t *schedopt = (starpu_option_request_t *)(request->schedopt); int workerid; char *cl_name = "zlascal"; /* Handle cache */ CHAMELEON_BEGIN_ACCESS_DECLARATION; CHAMELEON_ACCESS_RW(A, Am, An); CHAMELEON_END_ACCESS_DECLARATION; /* Callback fro profiling information */ callback = options->profiling ? cl_zlascal_callback : NULL; /* Fix the worker id */ workerid = (schedopt == NULL) ? -1 : schedopt->workerid; /* Insert the task */ rt_starpu_insert_task( &cl_zlascal, /* Task codelet arguments */ STARPU_VALUE, &clargs, sizeof(struct cl_zlascal_args_s), STARPU_RW, RTBLKADDR(A, CHAMELEON_Complex64_t, Am, An), /* Common task arguments */ STARPU_PRIORITY, options->priority, STARPU_CALLBACK, callback, STARPU_EXECUTE_ON_WORKER, workerid, #if defined(CHAMELEON_CODELETS_HAVE_NAME) STARPU_NAME, cl_name, #endif 0 ); (void)nb; }