| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 | 
							- /* StarPU --- Runtime system for heterogeneous multicore architectures.
 
-  *
 
-  * Copyright (C) 2009-2020  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 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))
 
- 		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, 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, may_alloc, &pushed);
 
- 			if (_starpu_check_that_no_data_request_is_pending(memory_node))
 
- 				/* No pending transfer, push some idle transfer */
 
- 				_starpu_handle_node_idle_requests(memory_node, 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;
 
- 	if (!worker)
 
- 	{
 
- 		/* Call from main application, only make RAM requests progress */
 
- 		int ret = 0;
 
- 		int nnumas = starpu_memory_nodes_get_numa_count();
 
- 		int numa;
 
- 		for (numa = 0; numa < nnumas; numa++)
 
- 			ret |=  ___starpu_datawizard_progress(numa, 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)
 
-                         ret |= ___starpu_datawizard_progress(memnode, may_alloc, push_requests);
 
-         }
 
-         return ret;
 
- }
 
- void _starpu_datawizard_progress(unsigned may_alloc)
 
- {
 
-         __starpu_datawizard_progress(may_alloc, 1);
 
- }
 
 
  |