123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126 |
- /* StarPU --- Runtime system for heterogeneous multicore architectures.
- *
- * Copyright (C) 2009-2021 Université de Bordeaux, CNRS (LaBRI UMR 5800), Inria
- *
- * 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 <common/config.h>
- #include <datawizard/datawizard.h>
- #include <datawizard/memalloc.h>
- #include <datawizard/memory_nodes.h>
- #include <core/workers.h>
- #include <core/progress_hook.h>
- #include <core/topology.h>
- #ifdef STARPU_SIMGRID
- #include <core/simgrid.h>
- #endif
- int ___starpu_datawizard_progress(unsigned memory_node, unsigned peer_node, enum _starpu_data_request_inout inout, unsigned may_alloc, unsigned push_requests)
- {
- int ret = 0;
- #ifdef STARPU_SIMGRID
- /* XXX */
- starpu_sleep(0.000001);
- #endif
- STARPU_UYIELD();
- /* in case some other driver requested data */
- if (_starpu_handle_pending_node_data_requests(memory_node, peer_node, inout))
- ret = 1;
- starpu_memchunk_tidy(memory_node);
- if (ret || push_requests)
- {
- /* Some transfers have finished, or the driver requests to really push more */
- unsigned pushed;
- if (_starpu_handle_node_data_requests(memory_node, peer_node, inout, may_alloc, &pushed) == 0)
- {
- if (pushed)
- ret = 1;
- /* We pushed all pending requests, we can afford pushing
- * prefetch requests */
- _starpu_handle_node_prefetch_requests(memory_node, peer_node, inout, may_alloc, &pushed);
- if (_starpu_check_that_no_data_request_is_pending(memory_node, peer_node, inout))
- /* No pending transfer, push some idle transfer */
- _starpu_handle_node_idle_requests(memory_node, peer_node, inout, may_alloc, &pushed);
- }
- if (pushed)
- ret = 1;
- }
- _starpu_execute_registered_progression_hooks();
- return ret;
- }
- int __starpu_datawizard_progress(unsigned may_alloc, unsigned push_requests)
- {
- struct _starpu_worker *worker = _starpu_get_local_worker_key();
- unsigned memnode, memnode2;
- if (!worker)
- {
- /* Call from main application, only make RAM requests progress */
- int ret = 0;
- int nnumas = starpu_memory_nodes_get_numa_count();
- int numa, numa2;
- for (numa = 0; numa < nnumas; numa++)
- for (numa2 = 0; numa2 < nnumas; numa2++)
- {
- ret |= ___starpu_datawizard_progress(numa, numa2, _STARPU_DATA_REQUEST_IN, may_alloc, push_requests);
- ret |= ___starpu_datawizard_progress(numa, numa2, _STARPU_DATA_REQUEST_OUT, may_alloc, push_requests);
- }
- return ret;
- }
- if (worker->set)
- /* Runing one of the workers of a worker set. The reference for
- * driving memory is its worker 0 (see registrations in topology.c) */
- worker = &worker->set->workers[0];
- unsigned current_worker_id = worker->workerid;
- int ret = 0;
- unsigned nnodes = starpu_memory_nodes_get_count();
- for (memnode = 0; memnode < nnodes; memnode++)
- {
- if (_starpu_worker_drives_memory[current_worker_id][memnode] == 1)
- for (memnode2 = 0; memnode2 < nnodes; memnode2++)
- {
- ret |= ___starpu_datawizard_progress(memnode, memnode2, _STARPU_DATA_REQUEST_IN, may_alloc, push_requests);
- ret |= ___starpu_datawizard_progress(memnode, memnode2, _STARPU_DATA_REQUEST_OUT, may_alloc, push_requests);
- }
- }
- return ret;
- }
- void _starpu_datawizard_progress(unsigned may_alloc)
- {
- __starpu_datawizard_progress(may_alloc, 1);
- }
- void _starpu_datawizard_handle_all_pending_node_data_requests(unsigned memnode)
- {
- unsigned nnodes = starpu_memory_nodes_get_count();
- unsigned memnode2;
- for (memnode2 = 0; memnode2 < nnodes; memnode2++)
- {
- _starpu_handle_all_pending_node_data_requests(memnode, memnode2, _STARPU_DATA_REQUEST_IN);
- _starpu_handle_all_pending_node_data_requests(memnode, memnode2, _STARPU_DATA_REQUEST_OUT);
- }
- }
|