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