Date: Sat, 25 Jul 2009 02:22:10 +0000 (UTC) From: Ed Maste <emaste@FreeBSD.org> To: cvs-src-old@freebsd.org Subject: cvs commit: src/sys/boot/i386/libi386 time.c Message-ID: <200907250222.n6P2MMAa016548@repoman.freebsd.org>
next in thread | raw e-mail | index | archive | help
emaste 2009-07-25 02:22:10 UTC
FreeBSD src repository
Modified files: (Branch: RELENG_7)
sys/boot/i386/libi386 time.c
Log:
SVN rev 195860 on 2009-07-25 02:22:10Z by emaste
MFC r179825 by olli:
Implement a workaround for a long-standing problem in
libi386's time(), caused by a qemu bug. The bug might
be present in other BIOSes, too.
qemu either does not simulate the AT RTC correctly or
has a broken BIOS 1A/02 implementation, and will return
an incorrect value if the RTC is read while it is being
updated.
The effect is worsened by the fact that qemu's INT 15/86
function ("wait" a.k.a. usleep) is non-implmeneted or
broken and returns immediately, causing beastie.4th to
spin in a tight loop calling the "read RTC" function
millions of times, triggering the problem quickly.
Therefore, we keep reading the BIOS value until we get
the same result twice. This change fixes beastie.4th's
countdown under qemu.
Revision Changes Path
1.5.20.1 +32 -8 src/sys/boot/i386/libi386/time.c
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200907250222.n6P2MMAa016548>
