Commit 53270955 authored by Michael Widenius's avatar Michael Widenius

Change in PBXT to only use pth_set_priority() (not setpriority()) to set priority

parent bf0e1f44
...@@ -547,44 +547,23 @@ xtPublic void xt_p_init_threading(void) ...@@ -547,44 +547,23 @@ xtPublic void xt_p_init_threading(void)
xtPublic int xt_p_set_low_priority(pthread_t thr) xtPublic int xt_p_set_low_priority(pthread_t thr)
{ {
if (pth_min_priority == pth_max_priority) { if (pth_min_priority != pth_max_priority)
/* Under Linux the priority of normal (non-runtime)
* threads are set using the standard methods
* for setting process priority.
*/
/* We could set who == 0 because it should have the same affect
* as using the PID.
*/
/* -20 = highest, 20 = lowest */
#ifdef SET_GLOBAL_PRIORITY
if (setpriority(PRIO_PROCESS, getpid(), 20) == -1)
return errno;
#endif
return 0;
}
return pth_set_priority(thr, pth_min_priority); return pth_set_priority(thr, pth_min_priority);
return 0;
} }
xtPublic int xt_p_set_normal_priority(pthread_t thr) xtPublic int xt_p_set_normal_priority(pthread_t thr)
{ {
if (pth_min_priority == pth_max_priority) { if (pth_min_priority != pth_max_priority)
if (setpriority(PRIO_PROCESS, getpid(), 0) == -1)
return errno;
return 0;
}
return pth_set_priority(thr, pth_normal_priority); return pth_set_priority(thr, pth_normal_priority);
return 0;
} }
xtPublic int xt_p_set_high_priority(pthread_t thr) xtPublic int xt_p_set_high_priority(pthread_t thr)
{ {
if (pth_min_priority == pth_max_priority) { if (pth_min_priority != pth_max_priority)
if (setpriority(PRIO_PROCESS, getpid(), -20) == -1)
return errno;
return 0;
}
return pth_set_priority(thr, pth_max_priority); return pth_set_priority(thr, pth_max_priority);
return 0;
} }
#ifdef DEBUG_LOCKING #ifdef DEBUG_LOCKING
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment