Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 89a07e17 authored by Chunyan Zhang's avatar Chunyan Zhang Committed by David S. Miller
Browse files

irda: stir4200: Replace timeval with ktime_t



The stir4200 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 of microsecond.

Signed-off-by: default avatarChunyan Zhang <zhang.chunyan@linaro.org>
Reviewed-by: default avatarArnd Bergmann <arnd@arndb.de>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 4c3bd197
Loading
Loading
Loading
Loading
+7 −9
Original line number Original line Diff line number Diff line
@@ -40,6 +40,7 @@
#include <linux/moduleparam.h>
#include <linux/moduleparam.h>


#include <linux/kernel.h>
#include <linux/kernel.h>
#include <linux/ktime.h>
#include <linux/types.h>
#include <linux/types.h>
#include <linux/time.h>
#include <linux/time.h>
#include <linux/skbuff.h>
#include <linux/skbuff.h>
@@ -174,7 +175,7 @@ struct stir_cb {
	__u8		  *fifo_status;
	__u8		  *fifo_status;


	iobuff_t  	  rx_buff;	/* receive unwrap state machine */
	iobuff_t  	  rx_buff;	/* receive unwrap state machine */
	struct timeval	  rx_time;
	ktime_t		rx_time;
	int		  receiving;
	int		  receiving;
	struct urb	 *rx_urb;
	struct urb	 *rx_urb;
};
};
@@ -650,15 +651,12 @@ static int fifo_txwait(struct stir_cb *stir, int space)
static void turnaround_delay(const struct stir_cb *stir, long us)
static void turnaround_delay(const struct stir_cb *stir, long us)
{
{
	long ticks;
	long ticks;
	struct timeval now;


	if (us <= 0)
	if (us <= 0)
		return;
		return;


	do_gettimeofday(&now);
	us -= ktime_us_delta(ktime_get(), stir->rx_time);
	if (now.tv_sec - stir->rx_time.tv_sec > 0)

		us -= USEC_PER_SEC;
	us -= now.tv_usec - stir->rx_time.tv_usec;
	if (us < 10)
	if (us < 10)
		return;
		return;


@@ -824,7 +822,7 @@ static void stir_rcv_irq(struct urb *urb)
		unwrap_chars(stir, urb->transfer_buffer,
		unwrap_chars(stir, urb->transfer_buffer,
			     urb->actual_length);
			     urb->actual_length);


		do_gettimeofday(&stir->rx_time);
		stir->rx_time = ktime_get();
	}
	}


	/* kernel thread is stopping receiver don't resubmit */
	/* kernel thread is stopping receiver don't resubmit */
@@ -876,7 +874,7 @@ static int stir_net_open(struct net_device *netdev)


	skb_reserve(stir->rx_buff.skb, 1);
	skb_reserve(stir->rx_buff.skb, 1);
	stir->rx_buff.head = stir->rx_buff.skb->data;
	stir->rx_buff.head = stir->rx_buff.skb->data;
	do_gettimeofday(&stir->rx_time);
	stir->rx_time = ktime_get();


	stir->rx_urb = usb_alloc_urb(0, GFP_KERNEL);
	stir->rx_urb = usb_alloc_urb(0, GFP_KERNEL);
	if (!stir->rx_urb) 
	if (!stir->rx_urb)