diff options
author | Kevin O'Connor <kevin@koconnor.net> | 2009-02-16 10:14:10 -0500 |
---|---|---|
committer | Kevin O'Connor <kevin@koconnor.net> | 2009-02-16 10:14:10 -0500 |
commit | 4f5586c657152add8854b79e85d12242315524b6 (patch) | |
tree | 13121a0ee88c4129a5be3925fc8dd2605843eaad /src/clock.c | |
parent | 94fd47e071f0198ed3a04f1fb9ac953107487e9d (diff) | |
download | seabios-hppa-4f5586c657152add8854b79e85d12242315524b6.zip seabios-hppa-4f5586c657152add8854b79e85d12242315524b6.tar.gz seabios-hppa-4f5586c657152add8854b79e85d12242315524b6.tar.bz2 |
Fix RTC UIP timing.
The "Update In Progress" bit can be set for up to 2.2ms, so wait for
up to 3ms for it to clear.
Diffstat (limited to 'src/clock.c')
-rw-r--r-- | src/clock.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/src/clock.c b/src/clock.c index e0f7dd2..55b8f95 100644 --- a/src/clock.c +++ b/src/clock.c @@ -138,12 +138,12 @@ rtc_updating() // If it is set, it tries to wait until there is a transition // to 0, and will return 0 if such a transition occurs. A -1 // is returned only after timing out. The maximum period - // that this bit should be set is constrained to 244useconds, so - // we wait for 1 msec max. + // that this bit should be set is constrained to (1984+244) + // useconds, so we wait for 3 msec max. if ((inb_cmos(CMOS_STATUS_A) & RTC_A_UIP) == 0) return 0; - u64 end = calc_future_tsc(1); + u64 end = calc_future_tsc(3); do { if ((inb_cmos(CMOS_STATUS_A) & RTC_A_UIP) == 0) return 0; @@ -166,7 +166,7 @@ pit_setup() static void init_rtc() { - outb_cmos(0x26, CMOS_STATUS_A); // 976.5625us updates + outb_cmos(0x26, CMOS_STATUS_A); // 32,768Khz src, 976.5625us updates u8 regB = inb_cmos(CMOS_STATUS_B); outb_cmos((regB & RTC_B_DSE) | RTC_B_24HR, CMOS_STATUS_B); inb_cmos(CMOS_STATUS_C); |