Set P_NOLOAD on the pagezero kthread so that it doesn't artificially skew
the loadav. This is not real load. If you have a nice process running in the background, pagezero may sit in the run queue for ages and add one to the loadav, and thereby affecting other scheduling decisions.
This commit is contained in:
parent
1926ab155f
commit
febe98ab98
@ -107,17 +107,23 @@ vm_page_zero_idle_wakeup(void)
|
||||
static void
|
||||
vm_pagezero(void)
|
||||
{
|
||||
struct thread *td = curthread;
|
||||
struct thread *td;
|
||||
struct proc *p;
|
||||
struct rtprio rtp;
|
||||
int pages = 0;
|
||||
int pri;
|
||||
|
||||
td = curthread;
|
||||
p = td->td_proc;
|
||||
rtp.prio = RTP_PRIO_MAX;
|
||||
rtp.type = RTP_PRIO_IDLE;
|
||||
mtx_lock_spin(&sched_lock);
|
||||
rtp_to_pri(&rtp, td->td_ksegrp);
|
||||
pri = td->td_priority;
|
||||
mtx_unlock_spin(&sched_lock);
|
||||
PROC_LOCK(p);
|
||||
p->p_flag |= P_NOLOAD;
|
||||
PROC_UNLOCK(p);
|
||||
|
||||
for (;;) {
|
||||
if (vm_page_zero_check()) {
|
||||
|
Loading…
Reference in New Issue
Block a user