diff options
author | Chunyan Zhang <zhang.chunyan@linaro.org> | 2015-01-07 23:01:30 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2015-01-11 21:39:40 -0500 |
commit | 4c3bd197a0f9b98343c5a6533e76a259271855b4 (patch) | |
tree | ffbcb7d4aa1c1173ed25aa73cc1dde58f3ef03b2 /drivers/net/irda/nsc-ircc.c | |
parent | ca98278a14b76916cd09c2c899c21c29a0748d15 (diff) |
irda: nsc-ircc: Replace timeval with ktime_t
The nsc ircc driver uses 'timeval', which we try to remove in the kernel
because all 32-bit time types will break in the year 2038.
This patch also changes do_gettimeofday() to ktime_get() accordingly,
since ktime_get returns a ktime_t, but do_gettimeofday returns a
struct timeval, and the other reason is that ktime_get() uses
the monotonic clock.
This patch uses ktime_us_delta to get the elapsed time, and in this
way it no longer needs to check for the overflow, because
ktime_us_delta returns time difference of microsecond.
Signed-off-by: Chunyan Zhang <zhang.chunyan@linaro.org>
Reviewed-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/irda/nsc-ircc.c')
-rw-r--r-- | drivers/net/irda/nsc-ircc.c | 7 |
1 files changed, 2 insertions, 5 deletions
diff --git a/drivers/net/irda/nsc-ircc.c b/drivers/net/irda/nsc-ircc.c index e7317b104bfb..dc0dbd8dd0b5 100644 --- a/drivers/net/irda/nsc-ircc.c +++ b/drivers/net/irda/nsc-ircc.c | |||
@@ -1501,10 +1501,7 @@ static netdev_tx_t nsc_ircc_hard_xmit_fir(struct sk_buff *skb, | |||
1501 | mtt = irda_get_mtt(skb); | 1501 | mtt = irda_get_mtt(skb); |
1502 | if (mtt) { | 1502 | if (mtt) { |
1503 | /* Check how much time we have used already */ | 1503 | /* Check how much time we have used already */ |
1504 | do_gettimeofday(&self->now); | 1504 | diff = ktime_us_delta(ktime_get(), self->stamp); |
1505 | diff = self->now.tv_usec - self->stamp.tv_usec; | ||
1506 | if (diff < 0) | ||
1507 | diff += 1000000; | ||
1508 | 1505 | ||
1509 | /* Check if the mtt is larger than the time we have | 1506 | /* Check if the mtt is larger than the time we have |
1510 | * already used by all the protocol processing | 1507 | * already used by all the protocol processing |
@@ -1867,7 +1864,7 @@ static int nsc_ircc_dma_receive_complete(struct nsc_ircc_cb *self, int iobase) | |||
1867 | * reduce the min turn time a bit since we will know | 1864 | * reduce the min turn time a bit since we will know |
1868 | * how much time we have used for protocol processing | 1865 | * how much time we have used for protocol processing |
1869 | */ | 1866 | */ |
1870 | do_gettimeofday(&self->stamp); | 1867 | self->stamp = ktime_get(); |
1871 | 1868 | ||
1872 | skb = dev_alloc_skb(len+1); | 1869 | skb = dev_alloc_skb(len+1); |
1873 | if (skb == NULL) { | 1870 | if (skb == NULL) { |