Input: hil_mlc - convert timeval to jiffies
struct timeval is not y2038 safe, and what mlc->instart do is scheduling a task in a fixed timeout, so jiffies is the simplest choice here. In hilse_donode(), the expires in mod_timer equals jiffies + intimeout - (now - instart) If we use jiffies in 'now', the expires equals instart + intimeout So, all we need to do is that making sure expires is a future timestamp before passed it to mod_timer. [arnd: slightly simplified patch further] Link: https://lists.linaro.org/pipermail/y2038/2015-October/000937.html Signed-off-by: WEN Pingbo <pingbo.wen@linaro.org> Signed-off-by: Arnd Bergmann <arnd@arndb.de> Patchwork-Id: 10076615 Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
This commit is contained in:
parent
ac45e6293f
commit
59d805af41
@ -602,8 +602,8 @@ static inline void hilse_setup_input(hil_mlc *mlc, const struct hilse_node *node
|
|||||||
BUG();
|
BUG();
|
||||||
}
|
}
|
||||||
mlc->istarted = 1;
|
mlc->istarted = 1;
|
||||||
mlc->intimeout = node->arg;
|
mlc->intimeout = usecs_to_jiffies(node->arg);
|
||||||
do_gettimeofday(&(mlc->instart));
|
mlc->instart = jiffies;
|
||||||
mlc->icount = 15;
|
mlc->icount = 15;
|
||||||
memset(mlc->ipacket, 0, 16 * sizeof(hil_packet));
|
memset(mlc->ipacket, 0, 16 * sizeof(hil_packet));
|
||||||
BUG_ON(down_trylock(&mlc->isem));
|
BUG_ON(down_trylock(&mlc->isem));
|
||||||
@ -708,7 +708,7 @@ static int hilse_donode(hil_mlc *mlc)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
mlc->ostarted = 0;
|
mlc->ostarted = 0;
|
||||||
do_gettimeofday(&(mlc->instart));
|
mlc->instart = jiffies;
|
||||||
write_unlock_irqrestore(&mlc->lock, flags);
|
write_unlock_irqrestore(&mlc->lock, flags);
|
||||||
nextidx = HILSEN_NEXT;
|
nextidx = HILSEN_NEXT;
|
||||||
break;
|
break;
|
||||||
@ -729,18 +729,14 @@ static int hilse_donode(hil_mlc *mlc)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
while (nextidx & HILSEN_SCHED) {
|
while (nextidx & HILSEN_SCHED) {
|
||||||
struct timeval tv;
|
unsigned long now = jiffies;
|
||||||
|
|
||||||
if (!sched_long)
|
if (!sched_long)
|
||||||
goto sched;
|
goto sched;
|
||||||
|
|
||||||
do_gettimeofday(&tv);
|
if (time_after(now, mlc->instart + mlc->intimeout))
|
||||||
tv.tv_usec += USEC_PER_SEC * (tv.tv_sec - mlc->instart.tv_sec);
|
goto sched;
|
||||||
tv.tv_usec -= mlc->instart.tv_usec;
|
mod_timer(&hil_mlcs_kicker, mlc->instart + mlc->intimeout);
|
||||||
if (tv.tv_usec >= mlc->intimeout) goto sched;
|
|
||||||
tv.tv_usec = (mlc->intimeout - tv.tv_usec) * HZ / USEC_PER_SEC;
|
|
||||||
if (!tv.tv_usec) goto sched;
|
|
||||||
mod_timer(&hil_mlcs_kicker, jiffies + tv.tv_usec);
|
|
||||||
break;
|
break;
|
||||||
sched:
|
sched:
|
||||||
tasklet_schedule(&hil_mlcs_tasklet);
|
tasklet_schedule(&hil_mlcs_tasklet);
|
||||||
|
@ -149,7 +149,6 @@ static int hp_sdc_mlc_in(hil_mlc *mlc, suseconds_t timeout)
|
|||||||
|
|
||||||
/* Try to down the semaphore */
|
/* Try to down the semaphore */
|
||||||
if (down_trylock(&mlc->isem)) {
|
if (down_trylock(&mlc->isem)) {
|
||||||
struct timeval tv;
|
|
||||||
if (priv->emtestmode) {
|
if (priv->emtestmode) {
|
||||||
mlc->ipacket[0] =
|
mlc->ipacket[0] =
|
||||||
HIL_ERR_INT | (mlc->opacket &
|
HIL_ERR_INT | (mlc->opacket &
|
||||||
@ -160,9 +159,7 @@ static int hp_sdc_mlc_in(hil_mlc *mlc, suseconds_t timeout)
|
|||||||
/* printk(KERN_DEBUG PREFIX ">[%x]\n", mlc->ipacket[0]); */
|
/* printk(KERN_DEBUG PREFIX ">[%x]\n", mlc->ipacket[0]); */
|
||||||
goto wasup;
|
goto wasup;
|
||||||
}
|
}
|
||||||
do_gettimeofday(&tv);
|
if (time_after(jiffies, mlc->instart + mlc->intimeout)) {
|
||||||
tv.tv_usec += USEC_PER_SEC * (tv.tv_sec - mlc->instart.tv_sec);
|
|
||||||
if (tv.tv_usec - mlc->instart.tv_usec > mlc->intimeout) {
|
|
||||||
/* printk("!%i %i",
|
/* printk("!%i %i",
|
||||||
tv.tv_usec - mlc->instart.tv_usec,
|
tv.tv_usec - mlc->instart.tv_usec,
|
||||||
mlc->intimeout);
|
mlc->intimeout);
|
||||||
|
@ -144,8 +144,8 @@ struct hil_mlc {
|
|||||||
hil_packet ipacket[16];
|
hil_packet ipacket[16];
|
||||||
hil_packet imatch;
|
hil_packet imatch;
|
||||||
int icount;
|
int icount;
|
||||||
struct timeval instart;
|
unsigned long instart;
|
||||||
suseconds_t intimeout;
|
unsigned long intimeout;
|
||||||
|
|
||||||
int ddi; /* Last operational device id */
|
int ddi; /* Last operational device id */
|
||||||
int lcv; /* LCV to throttle loops */
|
int lcv; /* LCV to throttle loops */
|
||||||
|
Loading…
Reference in New Issue
Block a user