mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-12 22:20:35 +05:00
TaskManager - sleep when no jobs for some time
This commit is contained in:
parent
f802197576
commit
a1b43088a4
@ -485,6 +485,7 @@ namespace ngcore
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
size_t no_job_counter = 0;
|
||||||
while (!done)
|
while (!done)
|
||||||
{
|
{
|
||||||
if (complete[mynode] > jobdone)
|
if (complete[mynode] > jobdone)
|
||||||
@ -492,11 +493,12 @@ namespace ngcore
|
|||||||
|
|
||||||
if (jobnr == jobdone)
|
if (jobnr == jobdone)
|
||||||
{
|
{
|
||||||
|
no_job_counter++;
|
||||||
// RegionTracer t(ti.thread_nr, tCASyield, ti.task_nr);
|
// RegionTracer t(ti.thread_nr, tCASyield, ti.task_nr);
|
||||||
while (ProcessTask()); // do the nested tasks
|
while (ProcessTask()) no_job_counter = 0; // do the nested tasks
|
||||||
|
|
||||||
if(sleep)
|
if(sleep || no_job_counter > 10000)
|
||||||
std::this_thread::sleep_for(std::chrono::microseconds(sleep_usecs));
|
std::this_thread::sleep_for(std::chrono::microseconds(10));
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
@ -537,6 +539,7 @@ namespace ngcore
|
|||||||
|
|
||||||
ti.task_nr = mytasks.First()+mytask;
|
ti.task_nr = mytasks.First()+mytask;
|
||||||
ti.ntasks = ntasks;
|
ti.ntasks = ntasks;
|
||||||
|
no_job_counter = 0;
|
||||||
|
|
||||||
{
|
{
|
||||||
RegionTracer t(ti.thread_nr, jobnr, RegionTracer::ID_JOB, ti.task_nr);
|
RegionTracer t(ti.thread_nr, jobnr, RegionTracer::ID_JOB, ti.task_nr);
|
||||||
|
Loading…
Reference in New Issue
Block a user