|
@@ -109,7 +109,8 @@ static int tx4939_rtc_read_time(struct device *dev, struct rtc_time *tm)
|
|
for (i = 2; i < 6; i++)
|
|
for (i = 2; i < 6; i++)
|
|
buf[i] = __raw_readl(&rtcreg->dat);
|
|
buf[i] = __raw_readl(&rtcreg->dat);
|
|
spin_unlock_irq(&pdata->lock);
|
|
spin_unlock_irq(&pdata->lock);
|
|
- sec = (buf[5] << 24) | (buf[4] << 16) | (buf[3] << 8) | buf[2];
|
|
|
|
|
|
+ sec = ((unsigned long)buf[5] << 24) | (buf[4] << 16) |
|
|
|
|
+ (buf[3] << 8) | buf[2];
|
|
rtc_time_to_tm(sec, tm);
|
|
rtc_time_to_tm(sec, tm);
|
|
return rtc_valid_tm(tm);
|
|
return rtc_valid_tm(tm);
|
|
}
|
|
}
|
|
@@ -170,7 +171,8 @@ static int tx4939_rtc_read_alarm(struct device *dev, struct rtc_wkalrm *alrm)
|
|
alrm->enabled = (ctl & TX4939_RTCCTL_ALME) ? 1 : 0;
|
|
alrm->enabled = (ctl & TX4939_RTCCTL_ALME) ? 1 : 0;
|
|
alrm->pending = (ctl & TX4939_RTCCTL_ALMD) ? 1 : 0;
|
|
alrm->pending = (ctl & TX4939_RTCCTL_ALMD) ? 1 : 0;
|
|
spin_unlock_irq(&pdata->lock);
|
|
spin_unlock_irq(&pdata->lock);
|
|
- sec = (buf[5] << 24) | (buf[4] << 16) | (buf[3] << 8) | buf[2];
|
|
|
|
|
|
+ sec = ((unsigned long)buf[5] << 24) | (buf[4] << 16) |
|
|
|
|
+ (buf[3] << 8) | buf[2];
|
|
rtc_time_to_tm(sec, &alrm->time);
|
|
rtc_time_to_tm(sec, &alrm->time);
|
|
return rtc_valid_tm(&alrm->time);
|
|
return rtc_valid_tm(&alrm->time);
|
|
}
|
|
}
|