Commit 2bc29a1a authored by Arnd Bergmann's avatar Arnd Bergmann Committed by Greg Kroah-Hartman

staging: gdm72xx: Replace timeval with ktime_t

struct sdu_stamp in the gdm_sdio.h is a timeval type.
'struct timeval now' is used for calculating elapsed time.

32-bit systems using 'struct timeval' will break in the year 2038,
so we have to replace that code with more appropriate types.
This patch changes the gdm72xx driver to use ktime_t.

ktime_get() is  better than using do_gettimeofday(),
because it uses the monotonic clock. ktime_sub
are used to subtract two ktime variables.

Build tested this by saying Y to WIMAX_GDM72XX.
Signed-off-by: default avatarTapasweni Pathak <tapaswenipathak@gmail.com>
Reviewed-by: default avatarArnd Bergmann <arnd@arndb.de>
Signed-off-by: default avatarArnd Bergmann <arnd@arndb.de>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 02c34ccc
...@@ -36,7 +36,7 @@ ...@@ -36,7 +36,7 @@
#define RX_BUF_SIZE (25*1024) #define RX_BUF_SIZE (25*1024)
#define TX_HZ 2000 #define TX_HZ 2000
#define TX_INTERVAL (1000000/TX_HZ) #define TX_INTERVAL (NSEC_PER_SEC/TX_HZ)
static struct sdio_tx *alloc_tx_struct(struct tx_cxt *tx) static struct sdio_tx *alloc_tx_struct(struct tx_cxt *tx)
{ {
...@@ -303,7 +303,7 @@ static void send_sdu(struct sdio_func *func, struct tx_cxt *tx) ...@@ -303,7 +303,7 @@ static void send_sdu(struct sdio_func *func, struct tx_cxt *tx)
put_tx_struct(t->tx_cxt, t); put_tx_struct(t->tx_cxt, t);
} }
do_gettimeofday(&tx->sdu_stamp); tx->sdu_stamp = ktime_get();
spin_unlock_irqrestore(&tx->lock, flags); spin_unlock_irqrestore(&tx->lock, flags);
} }
...@@ -330,7 +330,7 @@ static void do_tx(struct work_struct *work) ...@@ -330,7 +330,7 @@ static void do_tx(struct work_struct *work)
struct sdio_func *func = sdev->func; struct sdio_func *func = sdev->func;
struct tx_cxt *tx = &sdev->tx; struct tx_cxt *tx = &sdev->tx;
struct sdio_tx *t = NULL; struct sdio_tx *t = NULL;
struct timeval now, *before; ktime_t now, before;
int is_sdu = 0; int is_sdu = 0;
long diff; long diff;
unsigned long flags; unsigned long flags;
...@@ -346,11 +346,10 @@ static void do_tx(struct work_struct *work) ...@@ -346,11 +346,10 @@ static void do_tx(struct work_struct *work)
list_del(&t->list); list_del(&t->list);
is_sdu = 0; is_sdu = 0;
} else if (!tx->stop_sdu_tx && !list_empty(&tx->sdu_list)) { } else if (!tx->stop_sdu_tx && !list_empty(&tx->sdu_list)) {
do_gettimeofday(&now); now = ktime_get();
before = &tx->sdu_stamp; before = tx->sdu_stamp;
diff = (now.tv_sec - before->tv_sec) * 1000000 + diff = ktime_to_ns(ktime_sub(now, before));
(now.tv_usec - before->tv_usec);
if (diff >= 0 && diff < TX_INTERVAL) { if (diff >= 0 && diff < TX_INTERVAL) {
schedule_work(&sdev->ws); schedule_work(&sdev->ws);
spin_unlock_irqrestore(&tx->lock, flags); spin_unlock_irqrestore(&tx->lock, flags);
......
...@@ -15,7 +15,7 @@ ...@@ -15,7 +15,7 @@
#define __GDM72XX_GDM_SDIO_H__ #define __GDM72XX_GDM_SDIO_H__
#include <linux/types.h> #include <linux/types.h>
#include <linux/time.h> #include <linux/ktime.h>
#define MAX_NR_SDU_BUF 64 #define MAX_NR_SDU_BUF 64
...@@ -32,7 +32,7 @@ struct tx_cxt { ...@@ -32,7 +32,7 @@ struct tx_cxt {
struct list_head free_list; struct list_head free_list;
struct list_head sdu_list; struct list_head sdu_list;
struct list_head hci_list; struct list_head hci_list;
struct timeval sdu_stamp; ktime_t sdu_stamp;
u8 *sdu_buf; u8 *sdu_buf;
spinlock_t lock; spinlock_t lock;
int can_send; int can_send;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment