Subject: Re: sparc64 pmap optimizations
To: <>
From: David Laight <david@l8s.co.uk>
List: port-sparc64
Date: 08/26/2002 11:46:15
>
> 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?
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.
David
--
David Laight: david@l8s.co.uk