| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 | /* StarPU --- Runtime system for heterogeneous multicore architectures. * * Copyright (C) 2010, 2011  Centre National de la Recherche Scientifique * Copyright (C) 2010, 2011  Université de Bordeaux 1 * * Redistribution  and  use  in  source and binary forms, with or without * modification,  are  permitted  provided  that the following conditions * are met: * * * Redistributions  of  source  code  must  retain  the above copyright *   notice,  this  list  of  conditions  and  the  following  disclaimer. * * Redistributions  in  binary  form must reproduce the above copyright *   notice,  this list of conditions and the following disclaimer in the *   documentation  and/or other materials provided with the distribution. * * The name of the author may not be used to endorse or promote products *   derived from this software without specific prior written permission. * * THIS  SOFTWARE  IS  PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * ``AS IS''  AND  ANY  EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED  TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A  PARTICULAR  PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL * SPECIAL,  EXEMPLARY,  OR  CONSEQUENTIAL  DAMAGES  (INCLUDING,  BUT NOT * LIMITED  TO,  PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE * DATA,  OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY  OF  LIABILITY,  WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF  THIS  SOFTWARE,  EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */#include <starpu.h>struct params {    int i;    float f;};void cpu_func(void *buffers[], void *cl_arg){    struct params *params = cl_arg;    printf("Hello world (params = {%i, %f} )\n", params->i, params->f);}struct starpu_codelet cl ={    .where = STARPU_CPU,    .cpu_funcs = {cpu_func, NULL},    .nbuffers = 0};void callback_func(void *callback_arg){    printf("Callback function (arg %x)\n", callback_arg);}int main(int argc, char **argv){    /* initialize StarPU */    starpu_init(NULL);    struct starpu_task *task = starpu_task_create();    task->cl = &cl; /* Pointer to the codelet defined above */    struct params params = { 1, 2.0f };    task->cl_arg = ¶ms;    task->cl_arg_size = sizeof(params);    task->callback_func = callback_func;    task->callback_arg = 0x42;    /* starpu_task_submit will be a blocking call */    task->synchronous = 1;    /* submit the task to StarPU */    starpu_task_submit(task);    /* terminate StarPU */    starpu_shutdown();    return 0;}
 |