1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-16 18:19:55 +00:00

Merge branch 'thread_idle_priority' into 'master'

Set idle priority for navmesh generation thread

See merge request OpenMW/openmw!632
This commit is contained in:
psi29a 2021-04-15 19:32:23 +00:00
commit c686dd05d0
4 changed files with 87 additions and 1 deletions

View file

@ -87,7 +87,7 @@ add_component_dir (esmterrain
)
add_component_dir (misc
constants utf8stream stringops resourcehelpers rng messageformatparser weakcache
constants utf8stream stringops resourcehelpers rng messageformatparser weakcache thread
)
add_component_dir (debug

View file

@ -4,6 +4,7 @@
#include "settings.hpp"
#include <components/debug/debuglog.hpp>
#include <components/misc/thread.hpp>
#include <osg/Stats>
@ -135,6 +136,7 @@ namespace DetourNavigator
void AsyncNavMeshUpdater::process() noexcept
{
Log(Debug::Debug) << "Start process navigator jobs by thread=" << std::this_thread::get_id();
Misc::setCurrentThreadIdlePriority();
while (!mShouldStop)
{
try

View file

@ -0,0 +1,73 @@
#include "thread.hpp"
#include <components/debug/debuglog.hpp>
#include <cstring>
#include <thread>
#ifdef __linux__
#include <pthread.h>
#include <sched.h>
namespace Misc
{
void setCurrentThreadIdlePriority()
{
sched_param param;
param.sched_priority = 0;
if (pthread_setschedparam(pthread_self(), SCHED_IDLE, &param) == 0)
Log(Debug::Verbose) << "Using idle priority for thread=" << std::this_thread::get_id();
else
Log(Debug::Warning) << "Failed to set idle priority for thread=" << std::this_thread::get_id() << ": " << std::strerror(errno);
}
}
#elif defined(WIN32)
#undef WIN32_LEAN_AND_MEAN
#define WIN32_LEAN_AND_MEAN
#include <windows.h>
namespace Misc
{
void setCurrentThreadIdlePriority()
{
if (SetThreadPriority(GetCurrentThread(), THREAD_PRIORITY_LOWEST))
Log(Debug::Verbose) << "Using idle priority for thread=" << std::this_thread::get_id();
else
Log(Debug::Warning) << "Failed to set idle priority for thread=" << std::this_thread::get_id() << ": " << GetLastError();
}
}
#elif defined(__FreeBSD__)
#include <sys/types.h>
#include <sys/rtprio.h>
namespace Misc
{
void setCurrentThreadIdlePriority()
{
rtprio prio;
prio.type = RTP_PRIO_IDLE;
prio.prio = RTP_PRIO_MAX;
if (rtprio_thread(RTP_SET, 0, &prio) == 0)
Log(Debug::Verbose) << "Using idle priority for thread=" << std::this_thread::get_id();
else
Log(Debug::Warning) << "Failed to set idle priority for thread=" << std::this_thread::get_id() << ": " << std::strerror(errno);
}
}
#else
namespace Misc
{
void setCurrentThreadIdlePriority()
{
Log(Debug::Warning) << "Idle thread priority is not supported on this system";
}
}
#endif

View file

@ -0,0 +1,11 @@
#ifndef OPENMW_COMPONENTS_MISC_THREAD_H
#define OPENMW_COMPONENTS_MISC_THREAD_H
#include <thread>
namespace Misc
{
void setCurrentThreadIdlePriority();
}
#endif