Port-amd64 archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

Re: current kernel on amd64 crashes



On Thu, Jan 10, 2008 at 02:55:52PM +0100, Manuel Bouyer wrote:
> 
> Ha OK, it's on a HVM guest. 
> I guess the relevant NetBSD code is x86/isa/clock.c
> 
> Could it be this change ?
> - low = inb(IO_TIMER1 + TIMER_CNTR0);
> - high = inb(IO_TIMER1 + TIMER_CNTR0);
> - count = rtclock_tval - ((high << 8) | low);
> -
> + /* insb to make the read atomic */
> + insb(IO_TIMER1+TIMER_CNTR0, &rdval, 2);
> + count = rtclock_tval - rdval;
I don't know, but I also have no reason to believe that the comment (and
hence the modified code) is correct.
In order to get a consistent view of the counter, you have to latch it.
Any other attempted procedure (eg reading high-low-high) is doomed to
failure because some systems don't even report consitent byte values
when unlatched. (and soeme just return junk occaisionally).
 David
-- 
David Laight: david%l8s.co.uk@localhost


Home | Main Index | Thread Index | Old Index

AltStyle によって変換されたページ (->オリジナル) /