Re: cpufreq driver + wrong cpu time
From: Alexander Shaposhnikov
Date: Mon Oct 31 2005 - 00:44:33 EST
Hello Eric,
Its my first foray into kernel driver programming,
so please don't be too hard on me:)
The total elapsed time (by "time foo") is OK.
The problem is, cputime reported by, for example, "top"
utility, is wrong. The same problem with fortran intrinsic routine
"ETIME", so quantum chemistry codes i use (all written in fortran)
reports wrong cputime, but correct "wall(elapsed) time".
I've attached the code. I was able to test it only on my own dual
Opteron system, so have no idea about other MB.
P.S.
Please include me in CC explicitly!
Best Regards,
Alexander Shaposhnikov
On Mon, 2005-10-31 at 06:21 +0900, Eric Piel wrote:
> Alexander Shaposhnikov wrote:
> > Hello to everyone.
> >
> Hello Alexander,
>
> > I have written cpufreq_nForce4 kernel driver for cpufreq subsystem.
> > It allows for CPU frequency changing by adjusting FSB speed, for nForce4
> > based motherboards.
> > Works for single-cpu systems, as well as for SMP.
> > The problem is, after changing CPU(s) speed on SMP systems, programs
> > report wrong cpu time (wall time is OK).
> What do you mean by CPU time? Do you mean the output of "time foo" ? How
> do you know the *right* CPU time? Could you provide some examples :-)
>
> Well, anyway, by _rough_ guess, if on UP it works and on SMP it doesn't,
> we could imagine that the difference comes from the fact the tick
> interrupt source is not the same on those systems. You could try to boot
> a UP kernel with local APIC (selectable in the .config) on the
> multi-processor computer to check. Then it might mean that after
> changing the FSB speed, the interrupt source has to be re-programmed...
>
> > What would be the best way to fix this, and shouldn't this be done by
> > the cpufreq subsystem, rather than by hardware driver?
> >
> Probably the best place to discuss about cpufreq is the dedicated
> mailing list : cpufreq@xxxxxxxxxxxxxxxxxx . If you don't mind, you could
> continue there.
>
> Also please, provide the sources of your driver to have a look :-)
>
> cu,
> Eric
Attachment:
cpufreq_nForce4.tar.bz2
Description: application/bzip-compressed-tar