MFcalloutng (r244251 with minor changes):
Specify that precision of 0.5s is enough for resource limitation. Sponsored by: Google Summer of Code 2012, iXsystems inc. Tested by: flo, marius, ian, markj, Fabian Keil
This commit is contained in:
parent
36d0b73102
commit
4601bab1fb
@ -645,7 +645,8 @@ lim_cb(void *arg)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ((p->p_flag & P_WEXIT) == 0)
|
if ((p->p_flag & P_WEXIT) == 0)
|
||||||
callout_reset(&p->p_limco, hz, lim_cb, p);
|
callout_reset_sbt(&p->p_limco, SBT_1S, 0,
|
||||||
|
lim_cb, p, C_PREL(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
@ -697,7 +698,8 @@ kern_proc_setrlimit(struct thread *td, struct proc *p, u_int which,
|
|||||||
case RLIMIT_CPU:
|
case RLIMIT_CPU:
|
||||||
if (limp->rlim_cur != RLIM_INFINITY &&
|
if (limp->rlim_cur != RLIM_INFINITY &&
|
||||||
p->p_cpulimit == RLIM_INFINITY)
|
p->p_cpulimit == RLIM_INFINITY)
|
||||||
callout_reset(&p->p_limco, hz, lim_cb, p);
|
callout_reset_sbt(&p->p_limco, SBT_1S, 0,
|
||||||
|
lim_cb, p, C_PREL(1));
|
||||||
p->p_cpulimit = limp->rlim_cur;
|
p->p_cpulimit = limp->rlim_cur;
|
||||||
break;
|
break;
|
||||||
case RLIMIT_DATA:
|
case RLIMIT_DATA:
|
||||||
@ -1137,7 +1139,8 @@ lim_fork(struct proc *p1, struct proc *p2)
|
|||||||
p2->p_limit = lim_hold(p1->p_limit);
|
p2->p_limit = lim_hold(p1->p_limit);
|
||||||
callout_init_mtx(&p2->p_limco, &p2->p_mtx, 0);
|
callout_init_mtx(&p2->p_limco, &p2->p_mtx, 0);
|
||||||
if (p1->p_cpulimit != RLIM_INFINITY)
|
if (p1->p_cpulimit != RLIM_INFINITY)
|
||||||
callout_reset(&p2->p_limco, hz, lim_cb, p2);
|
callout_reset_sbt(&p2->p_limco, SBT_1S, 0,
|
||||||
|
lim_cb, p2, C_PREL(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
Loading…
Reference in New Issue
Block a user