cvs commit: src/sys/kern kern_exit.c kern_resource.c
John Baldwin
jhb at freebsd.org
Mon Jan 23 11:58:25 PST 2006
On Monday 23 January 2006 14:15, Stephan Uphoff wrote:
> ups 2006-01-23 19:15:13 UTC
>
> FreeBSD src repository
>
> Modified files:
> sys/kern kern_exit.c kern_resource.c
> Log:
> Hopefully fix the "calcru: runtime went backwards from ..." problem by
> keeping the resource values locked (where needed) while we use them
> for calculations.
>
> MFC after: 3 days
Why expand the locking in calcru()? calcru1() is working with a static
rusage_ext on calcru()'s stack, not the one for process p that is generated
while sched_lock is held. The 'p' for calcru1() is only used for printfs, no
actual data is taken from p. I think the ruadd() change might be the only
fix needed, though I think the updating of p->p_stats->p_ru.ru_nvcsw and
p->p_ru needs to be deferred as well since the race you seem to be fixing is
the case where exit1() is preempted, but with the current change you'd still
have stale data in p->p_ru (since it is a copy of p->p_stats->p_ru, not a
pointer) unless you move the updating of p->p_ru down to just before the
ruadd() as it was previously.
--
John Baldwin <jhb at FreeBSD.org> <>< http://www.FreeBSD.org/~jhb/
"Power Users Use the Power to Serve" = http://www.FreeBSD.org
More information about the cvs-all
mailing list