Subject: Re: sparc64 pmap optimizations
To: David Laight <david@l8s.co.uk>
From: Chuck Silvers <chuq@chuq.com>
List: tech-kern
Date: 08/26/2002 22:35:44
On Mon, Aug 26, 2002 at 11:46:15AM +0100, David Laight wrote:
> >
> > fork+exit
> > orig 0.025u 0.979s 0:09.22 10.7% 0+0k 0+1io 0pf+0w
> > chuq 0.014u 0.674s 0:07.51 9.0% 0+0k 0+0io 0pf+0w
> > improvement 18.5%
> >
> > for+exec+exit
> > orig 0.076u 2.232s 0:07.57 30.3% 0+0k 0+3io 0pf+0w
> > chuq 0.137u 1.609s 0:05.92 29.2% 0+0k 0+1io 0pf+0w
> > improvement 21.8%
>
> What are you using to get those timings?
that's tcsh's "time" built-in. I was only looking at the wall-clock time.
> The kernel counting of process time contains (at least) 2 bugs:
>
> 1) processes that are never interrupted by a clock tick are
> not give any cpu time.
> calcru returns 0 if (tot == 0), rather than (say) setting
> tot = u = 1 so that all the time is given to the user.
>
> 2) the time from the last process switch/clock tick until the
> process exits is ignored.
> exit1 sets p->p_stat = SDEAD before calling caclru - which
> check p->p_stat == SONPROC to collect tim for the current
> process.
> Move the code that sets the process state (in exit1) to
> below the calcru bit.
could you open a PR with this info?
-Chuck