Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 24445
b: refs/heads/master
c: 6f0d7bd
h: refs/heads/master
i:
  24443: 9f9f68c
v: v3
  • Loading branch information
Matt Mackall authored and Linus Torvalds committed Mar 28, 2006
1 parent 1edcc84 commit ad4c5ad
Show file tree
Hide file tree
Showing 2 changed files with 3 additions and 23 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 4dc12ec7e26f287e33065e803bc0aede4c1dbdf3
refs/heads/master: 6f0d7bd6a14dcf5b258cfd809143c50e4897902b
24 changes: 2 additions & 22 deletions trunk/arch/powerpc/platforms/maple/time.c
Original file line number Diff line number Diff line change
Expand Up @@ -60,34 +60,14 @@ static void maple_clock_write(unsigned long val, int addr)

void maple_get_rtc_time(struct rtc_time *tm)
{
int uip, i;

/* The Linux interpretation of the CMOS clock register contents:
* When the Update-In-Progress (UIP) flag goes from 1 to 0, the
* RTC registers show the second which has precisely just started.
* Let's hope other operating systems interpret the RTC the same way.
*/

/* Since the UIP flag is set for about 2.2 ms and the clock
* is typically written with a precision of 1 jiffy, trying
* to obtain a precision better than a few milliseconds is
* an illusion. Only consistency is interesting, this also
* allows to use the routine for /dev/rtc without a potential
* 1 second kernel busy loop triggered by any reader of /dev/rtc.
*/

for (i = 0; i<1000000; i++) {
uip = maple_clock_read(RTC_FREQ_SELECT);
do {
tm->tm_sec = maple_clock_read(RTC_SECONDS);
tm->tm_min = maple_clock_read(RTC_MINUTES);
tm->tm_hour = maple_clock_read(RTC_HOURS);
tm->tm_mday = maple_clock_read(RTC_DAY_OF_MONTH);
tm->tm_mon = maple_clock_read(RTC_MONTH);
tm->tm_year = maple_clock_read(RTC_YEAR);
uip |= maple_clock_read(RTC_FREQ_SELECT);
if ((uip & RTC_UIP)==0)
break;
}
} while (tm->tm_sec != maple_clock_read(RTC_SECONDS));

if (!(maple_clock_read(RTC_CONTROL) & RTC_DM_BINARY)
|| RTC_ALWAYS_BCD) {
Expand Down

0 comments on commit ad4c5ad

Please sign in to comment.