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:
WEN Pingbo 2018-01-01 21:31:18 -08:00 committed by Dmitry Torokhov
parent ac45e6293f
commit 59d805af41
3 changed files with 10 additions and 17 deletions

View file

@ -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);

View file

@ -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);

View file

@ -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 */