mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-11-29 23:06:42 +07:00
Char: ds1286, eliminate busy waiting
ds1286_get_time(); is not called from atomic context, sleep for 20 ms is better choice than a (home-made) busy waiting for such a situation. Signed-off-by: Jiri Slaby <jirislaby@gmail.com> Acked-by: Ralf Baechle <ralf@linux-mips.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
4cea5ceb4c
commit
d05abab9a4
@ -443,7 +443,6 @@ static void ds1286_get_time(struct rtc_time *rtc_tm)
|
||||
{
|
||||
unsigned char save_control;
|
||||
unsigned long flags;
|
||||
unsigned long uip_watchdog = jiffies;
|
||||
|
||||
/*
|
||||
* read RTC once any update in progress is done. The update
|
||||
@ -456,8 +455,7 @@ static void ds1286_get_time(struct rtc_time *rtc_tm)
|
||||
*/
|
||||
|
||||
if (ds1286_is_updating() != 0)
|
||||
while (time_before(jiffies, uip_watchdog + 2*HZ/100))
|
||||
barrier();
|
||||
msleep(20);
|
||||
|
||||
/*
|
||||
* Only the values that we read from the RTC are set. We leave
|
||||
|
Loading…
Reference in New Issue
Block a user