static short _rtl92e_is_tx_queue_empty(struct net_device *dev);
 static void _rtl92e_watchdog_wq_cb(void *data);
-static void _rtl92e_watchdog_timer_cb(unsigned long data);
+static void _rtl92e_watchdog_timer_cb(struct timer_list *t);
 static void _rtl92e_hard_data_xmit(struct sk_buff *skb, struct net_device *dev,
                                   int rate);
 static int _rtl92e_hard_start_xmit(struct sk_buff *skb, struct net_device *dev);
        priv->bfirst_init = false;
 
        if (priv->polling_timer_on == 0)
-               rtl92e_check_rfctrl_gpio_timer((unsigned long)dev);
+               rtl92e_check_rfctrl_gpio_timer(&priv->gpio_polling_timer);
 
        if (priv->rtllib->state != RTLLIB_LINKED)
                rtllib_softmac_start_protocol(priv->rtllib, 0);
        rtllib_reset_queue(priv->rtllib);
-       _rtl92e_watchdog_timer_cb((unsigned long)dev);
+       _rtl92e_watchdog_timer_cb(&priv->watch_dog_timer);
 
        if (!netif_queue_stopped(dev))
                netif_start_queue(dev);
 
        rtl92e_dm_init(dev);
 
-       setup_timer(&priv->watch_dog_timer,
-                   _rtl92e_watchdog_timer_cb,
-                   (unsigned long)dev);
+       timer_setup(&priv->watch_dog_timer, _rtl92e_watchdog_timer_cb, 0);
 
-       setup_timer(&priv->gpio_polling_timer,
-                   rtl92e_check_rfctrl_gpio_timer,
-                   (unsigned long)dev);
+       timer_setup(&priv->gpio_polling_timer, rtl92e_check_rfctrl_gpio_timer,
+                   0);
 
        rtl92e_irq_disable(dev);
        if (request_irq(dev->irq, _rtl92e_irq, IRQF_SHARED, dev->name, dev)) {
        RT_TRACE(COMP_TRACE, " <==RtUsbCheckForHangWorkItemCallback()\n");
 }
 
-static void _rtl92e_watchdog_timer_cb(unsigned long data)
+static void _rtl92e_watchdog_timer_cb(struct timer_list *t)
 {
-       struct r8192_priv *priv = rtllib_priv((struct net_device *)data);
+       struct r8192_priv *priv = from_timer(priv, t, watch_dog_timer);
 
        schedule_delayed_work(&priv->watch_dog_wq, 0);
        mod_timer(&priv->watch_dog_timer, jiffies +
        RT_TRACE(COMP_INIT, "dev name: %s\n", dev->name);
 
        if (priv->polling_timer_on == 0)
-               rtl92e_check_rfctrl_gpio_timer((unsigned long)dev);
+               rtl92e_check_rfctrl_gpio_timer(&priv->gpio_polling_timer);
 
        RT_TRACE(COMP_INIT, "Driver probe completed\n");
        return 0;
 
 module_pci_driver(rtl8192_pci_driver);
 
-void rtl92e_check_rfctrl_gpio_timer(unsigned long data)
+void rtl92e_check_rfctrl_gpio_timer(struct timer_list *t)
 {
-       struct r8192_priv *priv = rtllib_priv((struct net_device *)data);
+       struct r8192_priv *priv = from_timer(priv, t, gpio_polling_timer);
 
        priv->polling_timer_on = 1;
 
 
 void rtl92e_hw_sleep_wq(void *data);
 void rtl92e_commit(struct net_device *dev);
 
-void rtl92e_check_rfctrl_gpio_timer(unsigned long data);
+void rtl92e_check_rfctrl_gpio_timer(struct timer_list *t);
 
 void rtl92e_hw_wakeup_wq(void *data);
 
 
 static  void _rtl92e_dm_check_ac_dc_power(struct net_device *dev);
 static void _rtl92e_dm_check_fsync(struct net_device *dev);
 static void _rtl92e_dm_check_rf_ctrl_gpio(void *data);
-static void _rtl92e_dm_fsync_timer_callback(unsigned long data);
+static void _rtl92e_dm_fsync_timer_callback(struct timer_list *t);
 
 /*---------------------Define local function prototype-----------------------*/
 
        priv->rtllib->fsync_state = Default_Fsync;
        priv->framesyncMonitor = 1;
 
-       setup_timer(&priv->fsync_timer, _rtl92e_dm_fsync_timer_callback,
-                   (unsigned long)dev);
+       timer_setup(&priv->fsync_timer, _rtl92e_dm_fsync_timer_callback, 0);
 }
 
 
        del_timer_sync(&priv->fsync_timer);
 }
 
-static void _rtl92e_dm_fsync_timer_callback(unsigned long data)
+static void _rtl92e_dm_fsync_timer_callback(struct timer_list *t)
 {
-       struct net_device *dev = (struct net_device *)data;
-       struct r8192_priv *priv = rtllib_priv((struct net_device *)data);
+       struct r8192_priv *priv = from_timer(priv, t, fsync_timer);
+       struct net_device *dev = priv->rtllib->dev;
        u32 rate_index, rate_count = 0, rate_count_diff = 0;
        bool            bSwitchFromCountDiff = false;
        bool            bDoubleTimeInterval = false;
 
        pci_enable_wake(pdev, PCI_D0, 0);
 
        if (priv->polling_timer_on == 0)
-               rtl92e_check_rfctrl_gpio_timer((unsigned long)dev);
+               rtl92e_check_rfctrl_gpio_timer(&priv->gpio_polling_timer);
 
        if (!netif_running(dev)) {
                netdev_info(dev,
 
        }
 }
 
-void BaSetupTimeOut(unsigned long data)
+void BaSetupTimeOut(struct timer_list *t)
 {
-       struct tx_ts_record *pTxTs = (struct tx_ts_record *)data;
+       struct tx_ts_record *pTxTs = from_timer(pTxTs, t,
+                                             TxPendingBARecord.Timer);
 
        pTxTs->bAddBaReqInProgress = false;
        pTxTs->bAddBaReqDelayed = true;
        pTxTs->TxPendingBARecord.bValid = false;
 }
 
-void TxBaInactTimeout(unsigned long data)
+void TxBaInactTimeout(struct timer_list *t)
 {
-       struct tx_ts_record *pTxTs = (struct tx_ts_record *)data;
+       struct tx_ts_record *pTxTs = from_timer(pTxTs, t,
+                                             TxAdmittedBARecord.Timer);
        struct rtllib_device *ieee = container_of(pTxTs, struct rtllib_device,
                                     TxTsRecord[pTxTs->num]);
        TxTsDeleteBA(ieee, pTxTs);
                          DELBA_REASON_TIMEOUT);
 }
 
-void RxBaInactTimeout(unsigned long data)
+void RxBaInactTimeout(struct timer_list *t)
 {
-       struct rx_ts_record *pRxTs = (struct rx_ts_record *)data;
+       struct rx_ts_record *pRxTs = from_timer(pRxTs, t,
+                                             RxAdmittedBARecord.Timer);
        struct rtllib_device *ieee = container_of(pRxTs, struct rtllib_device,
                                     RxTsRecord[pRxTs->num]);
 
 
 #include <linux/etherdevice.h>
 #include "rtl819x_TS.h"
 
-static void TsSetupTimeOut(unsigned long data)
+static void TsSetupTimeOut(struct timer_list *unused)
 {
 }
 
-static void TsInactTimeout(unsigned long data)
+static void TsInactTimeout(struct timer_list *unused)
 {
 }
 
-static void RxPktPendingTimeout(unsigned long data)
+static void RxPktPendingTimeout(struct timer_list *t)
 {
-       struct rx_ts_record *pRxTs = (struct rx_ts_record *)data;
+       struct rx_ts_record *pRxTs = from_timer(pRxTs, t,
+                                                    RxPktPendingTimer);
        struct rtllib_device *ieee = container_of(pRxTs, struct rtllib_device,
                                                  RxTsRecord[pRxTs->num]);
 
        spin_unlock_irqrestore(&(ieee->reorder_spinlock), flags);
 }
 
-static void TsAddBaProcess(unsigned long data)
+static void TsAddBaProcess(struct timer_list *t)
 {
-       struct tx_ts_record *pTxTs = (struct tx_ts_record *)data;
+       struct tx_ts_record *pTxTs = from_timer(pTxTs, t, TsAddBaTimer);
        u8 num = pTxTs->num;
        struct rtllib_device *ieee = container_of(pTxTs, struct rtllib_device,
                                     TxTsRecord[num]);
 
        for (count = 0; count < TOTAL_TS_NUM; count++) {
                pTxTS->num = count;
-               setup_timer(&pTxTS->TsCommonInfo.SetupTimer,
-                           TsSetupTimeOut,
-                           (unsigned long) pTxTS);
+               timer_setup(&pTxTS->TsCommonInfo.SetupTimer, TsSetupTimeOut,
+                           0);
 
-               setup_timer(&pTxTS->TsCommonInfo.InactTimer,
-                           TsInactTimeout,
-                           (unsigned long) pTxTS);
+               timer_setup(&pTxTS->TsCommonInfo.InactTimer, TsInactTimeout,
+                           0);
 
-               setup_timer(&pTxTS->TsAddBaTimer,
-                           TsAddBaProcess,
-                           (unsigned long) pTxTS);
+               timer_setup(&pTxTS->TsAddBaTimer, TsAddBaProcess, 0);
 
-               setup_timer(&pTxTS->TxPendingBARecord.Timer,
-                           BaSetupTimeOut,
-                           (unsigned long) pTxTS);
-               setup_timer(&pTxTS->TxAdmittedBARecord.Timer,
-                           TxBaInactTimeout,
-                           (unsigned long) pTxTS);
+               timer_setup(&pTxTS->TxPendingBARecord.Timer, BaSetupTimeOut,
+                           0);
+               timer_setup(&pTxTS->TxAdmittedBARecord.Timer,
+                           TxBaInactTimeout, 0);
 
                ResetTxTsEntry(pTxTS);
                list_add_tail(&pTxTS->TsCommonInfo.List,
                pRxTS->num = count;
                INIT_LIST_HEAD(&pRxTS->RxPendingPktList);
 
-               setup_timer(&pRxTS->TsCommonInfo.SetupTimer,
-                           TsSetupTimeOut,
-                           (unsigned long) pRxTS);
+               timer_setup(&pRxTS->TsCommonInfo.SetupTimer, TsSetupTimeOut,
+                           0);
 
-               setup_timer(&pRxTS->TsCommonInfo.InactTimer,
-                           TsInactTimeout,
-                           (unsigned long) pRxTS);
+               timer_setup(&pRxTS->TsCommonInfo.InactTimer, TsInactTimeout,
+                           0);
 
-               setup_timer(&pRxTS->RxAdmittedBARecord.Timer,
-                           RxBaInactTimeout,
-                           (unsigned long) pRxTS);
+               timer_setup(&pRxTS->RxAdmittedBARecord.Timer,
+                           RxBaInactTimeout, 0);
 
-               setup_timer(&pRxTS->RxPktPendingTimer,
-                           RxPktPendingTimeout,
-                           (unsigned long) pRxTS);
+               timer_setup(&pRxTS->RxPktPendingTimer, RxPktPendingTimeout, 0);
 
                ResetRxTsEntry(pRxTS);
                list_add_tail(&pRxTS->TsCommonInfo.List,
 
 void TsInitDelBA(struct rtllib_device *ieee,
                 struct ts_common_info *pTsCommonInfo,
                 enum tr_select TxRxSelect);
-void BaSetupTimeOut(unsigned long data);
-void TxBaInactTimeout(unsigned long data);
-void RxBaInactTimeout(unsigned long data);
+void BaSetupTimeOut(struct timer_list *t);
+void TxBaInactTimeout(struct timer_list *t);
+void RxBaInactTimeout(struct timer_list *t);
 void ResetBaEntry(struct ba_record *pBA);
 bool GetTs(struct rtllib_device *ieee, struct ts_common_info **ppTS, u8 *Addr,
           u8 TID, enum tr_select TxRxSelect, bool bAddNewTs);
 
 }
 
 
-static void rtllib_send_beacon_cb(unsigned long _ieee)
+static void rtllib_send_beacon_cb(struct timer_list *t)
 {
        struct rtllib_device *ieee =
-               (struct rtllib_device *) _ieee;
+               from_timer(ieee, t, beacon_timer);
        unsigned long flags;
 
        spin_lock_irqsave(&ieee->beacon_lock, flags);
        spin_unlock_irqrestore(&ieee->lock, flags);
 }
 
-static void rtllib_associate_abort_cb(unsigned long dev)
+static void rtllib_associate_abort_cb(struct timer_list *t)
 {
-       rtllib_associate_abort((struct rtllib_device *) dev);
+       struct rtllib_device *dev = from_timer(dev, t, associate_timer);
+
+       rtllib_associate_abort(dev);
 }
 
 static void rtllib_associate_step1(struct rtllib_device *ieee, u8 *daddr)
 
        ieee->tx_pending.txb = NULL;
 
-       setup_timer(&ieee->associate_timer,
-                   rtllib_associate_abort_cb,
-                   (unsigned long) ieee);
+       timer_setup(&ieee->associate_timer, rtllib_associate_abort_cb, 0);
 
-       setup_timer(&ieee->beacon_timer,
-                   rtllib_send_beacon_cb,
-                   (unsigned long) ieee);
+       timer_setup(&ieee->beacon_timer, rtllib_send_beacon_cb, 0);
 
        INIT_DELAYED_WORK_RSL(&ieee->link_change_wq,
                              (void *)rtllib_link_change_wq, ieee);