Replicated tasks
This MR aims at adding functionalities to StarPU-MPI so that a task can be replicated across several nodes, and the results of replicated tasks used by other nodes.
As of creating this MR, it is implemented the following way, following discussions with the StarPU team:
- A node n that is not the
home_node
h of ahandle
D can execute a task without sending the result back to h by using theSTARPU_SAME
flag ; this sets the cache for D as if n received a coherent value : we expect the application to have h executing the same task (h should be the last of the replicating nodes to insert the task because of sequential consistency). - In order for this data to be used, i.e. for
n
to be a source of D, other nodes should setn
as a source ford
throughset_source
function. - A function
insert_tasks(..., ON:list_of_nodes)
should be provided to ease usage.
To-do list:
-
insert_tasks
-
examples -
(re)set_source -
use starpu_same -
combine both
-
-
tests (assuming H is owned by P0) -
P1 becomes an alternative source of H for P2 then P0 writes H : P1 and P2 should receive H from P0 if they read it -
P2 reads H then P1 becomes an alternative source of H for P2 then P2 reads H : either P2 forgets it has a valid value of P0 and the second read happens or P1 receives the cache state of P0 to avoid the unnecessary send -
P1 becomes an alternative source of H for P2 then P2 read H without P0 knowing then P2 resets their alternative source before reading H : either P2 receives H from P0 (reset = flush) or P1 sends its cache to P0 (reset = exchange)
-
-
fortran interface -
docs
Edited by Antoine Jego