]> Pileus Git - ~andy/linux/blobdiff - drivers/staging/rtl8192e/r8192E_dm.c
Merge branch 'for-linus' of git://git.open-osd.org/linux-open-osd
[~andy/linux] / drivers / staging / rtl8192e / r8192E_dm.c
index 1ade3672546e6a4bdb286e3667252a00d1f64561..688d29b558849d0342397617586b75aac5cb69c9 100644 (file)
@@ -38,214 +38,108 @@ dig_t     dm_digtable;
 // For Dynamic Rx Path Selection by Signal Strength
 DRxPathSel     DM_RxPathSelTable;
 
-
-/*--------------------Define export function prototype-----------------------*/
-extern void    init_hal_dm(struct net_device *dev);
-extern void deinit_hal_dm(struct net_device *dev);
-
-extern void hal_dm_watchdog(struct net_device *dev);
-
-
-extern void    init_rate_adaptive(struct net_device *dev);
-extern void    dm_txpower_trackingcallback(struct work_struct *work);
-
-extern void    dm_cck_txpower_adjust(struct net_device *dev,bool  binch14);
-extern void    dm_restore_dynamic_mechanism_state(struct net_device *dev);
-extern void    dm_backup_dynamic_mechanism_state(struct net_device *dev);
-extern void    dm_change_dynamic_initgain_thresh(struct net_device *dev,
-                                                               u32             dm_type,
-                                                               u32             dm_value);
-extern void    DM_ChangeFsyncSetting(struct net_device *dev,
-                                                                                               s32             DM_Type,
-                                                                                               s32             DM_Value);
-extern void dm_force_tx_fw_info(struct net_device *dev,
-                                                                               u32             force_type,
-                                                                               u32             force_value);
-extern void    dm_init_edca_turbo(struct net_device *dev);
-extern void    dm_rf_operation_test_callback(unsigned long data);
-extern void    dm_rf_pathcheck_workitemcallback(struct work_struct *work);
-extern void dm_fsync_timer_callback(unsigned long data);
-extern void dm_check_fsync(struct net_device *dev);
-extern void dm_initialize_txpower_tracking(struct net_device *dev);
-
-extern  void    dm_gpio_change_rf_callback(struct work_struct *work);
-
+void dm_gpio_change_rf_callback(struct work_struct *work);
 
 // DM --> Rate Adaptive
-static void    dm_check_rate_adaptive(struct net_device *dev);
+static void dm_check_rate_adaptive(struct r8192_priv *priv);
 
 // DM --> Bandwidth switch
-static void    dm_init_bandwidth_autoswitch(struct net_device *dev);
-static void    dm_bandwidth_autoswitch(        struct net_device *dev);
+static void dm_init_bandwidth_autoswitch(struct r8192_priv *priv);
+static void dm_bandwidth_autoswitch(struct r8192_priv *priv);
 
 // DM --> TX power control
-static void    dm_check_txpower_tracking(struct net_device *dev);
+static void dm_check_txpower_tracking(struct r8192_priv *priv);
 
 // DM --> Dynamic Init Gain by RSSI
-static void    dm_dig_init(struct net_device *dev);
-static void    dm_ctrl_initgain_byrssi(struct net_device *dev);
-static void    dm_ctrl_initgain_byrssi_highpwr(struct net_device *dev);
-static void    dm_ctrl_initgain_byrssi_by_driverrssi(  struct net_device *dev);
-static void    dm_ctrl_initgain_byrssi_by_fwfalse_alarm(struct net_device *dev);
-static void    dm_initial_gain(struct net_device *dev);
-static void    dm_pd_th(struct net_device *dev);
-static void    dm_cs_ratio(struct net_device *dev);
-
-static void dm_init_ctstoself(struct net_device *dev);
+static void dm_dig_init(struct r8192_priv *priv);
+static void dm_ctrl_initgain_byrssi(struct r8192_priv *priv);
+static void dm_ctrl_initgain_byrssi_highpwr(struct r8192_priv *priv);
+static void dm_ctrl_initgain_byrssi_by_driverrssi(struct r8192_priv *priv);
+static void dm_ctrl_initgain_byrssi_by_fwfalse_alarm(struct r8192_priv *priv);
+static void dm_initial_gain(struct r8192_priv *priv);
+static void dm_pd_th(struct r8192_priv *priv);
+static void dm_cs_ratio(struct r8192_priv *priv);
+
+static void dm_init_ctstoself(struct r8192_priv *priv);
 // DM --> EDCA turboe mode control
-static void    dm_check_edca_turbo(struct net_device *dev);
+static void dm_check_edca_turbo(struct r8192_priv *priv);
+static void dm_init_edca_turbo(struct r8192_priv *priv);
 
 // DM --> HW RF control
-static void    dm_check_rfctrl_gpio(struct net_device *dev);
-
-// DM --> Check PBC
-static void dm_check_pbc_gpio(struct net_device *dev);
+static void dm_check_rfctrl_gpio(struct r8192_priv *priv);
 
 // DM --> Check current RX RF path state
-static void    dm_check_rx_path_selection(struct net_device *dev);
-static         void dm_init_rxpath_selection(struct net_device *dev);
-static void dm_rxpath_sel_byrssi(struct net_device *dev);
+static void dm_check_rx_path_selection(struct r8192_priv *priv);
+static void dm_init_rxpath_selection(struct r8192_priv *priv);
+static void dm_rxpath_sel_byrssi(struct r8192_priv *priv);
 
 // DM --> Fsync for broadcom ap
-static void dm_init_fsync(struct net_device *dev);
-static void dm_deInit_fsync(struct net_device *dev);
+static void dm_init_fsync(struct r8192_priv *priv);
+static void dm_deInit_fsync(struct r8192_priv *priv);
 
-static void    dm_check_txrateandretrycount(struct net_device *dev);
+static void dm_check_txrateandretrycount(struct r8192_priv *priv);
+static void dm_check_fsync(struct r8192_priv *priv);
 
 
 /*---------------------Define of Tx Power Control For Near/Far Range --------*/   //Add by Jacken 2008/02/18
-static void    dm_init_dynamic_txpower(struct net_device *dev);
-static void    dm_dynamic_txpower(struct net_device *dev);
+static void dm_init_dynamic_txpower(struct r8192_priv *priv);
+static void dm_dynamic_txpower(struct r8192_priv *priv);
 
 // DM --> For rate adaptive and DIG, we must send RSSI to firmware
-static void dm_send_rssi_tofw(struct net_device *dev);
-static void    dm_ctstoself(struct net_device *dev);
+static void dm_send_rssi_tofw(struct r8192_priv *priv);
+static void dm_ctstoself(struct r8192_priv *priv);
+
+static void dm_fsync_timer_callback(unsigned long data);
 
 /*
  * Prepare SW resource for HW dynamic mechanism.
  * This function is only invoked at driver intialization once.
  */
-void init_hal_dm(struct net_device *dev)
+void init_hal_dm(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
-
        // Undecorated Smoothed Signal Strength, it can utilized to dynamic mechanism.
        priv->undecorated_smoothed_pwdb = -1;
 
        //Initial TX Power Control for near/far range , add by amy 2008/05/15, porting from windows code.
-       dm_init_dynamic_txpower(dev);
-       init_rate_adaptive(dev);
+       dm_init_dynamic_txpower(priv);
+       init_rate_adaptive(priv);
        //dm_initialize_txpower_tracking(dev);
-       dm_dig_init(dev);
-       dm_init_edca_turbo(dev);
-       dm_init_bandwidth_autoswitch(dev);
-       dm_init_fsync(dev);
-       dm_init_rxpath_selection(dev);
-       dm_init_ctstoself(dev);
+       dm_dig_init(priv);
+       dm_init_edca_turbo(priv);
+       dm_init_bandwidth_autoswitch(priv);
+       dm_init_fsync(priv);
+       dm_init_rxpath_selection(priv);
+       dm_init_ctstoself(priv);
        INIT_DELAYED_WORK(&priv->gpio_change_rf_wq,  dm_gpio_change_rf_callback);
 
 }
 
-void deinit_hal_dm(struct net_device *dev)
+void deinit_hal_dm(struct r8192_priv *priv)
 {
-
-       dm_deInit_fsync(dev);
-
+       dm_deInit_fsync(priv);
 }
 
-
-#ifdef USB_RX_AGGREGATION_SUPPORT
-void dm_CheckRxAggregation(struct net_device *dev) {
-       struct r8192_priv *priv = ieee80211_priv((struct net_device *)dev);
-       PRT_HIGH_THROUGHPUT     pHTInfo = priv->ieee80211->pHTInfo;
-       static unsigned long    lastTxOkCnt = 0;
-       static unsigned long    lastRxOkCnt = 0;
-       unsigned long           curTxOkCnt = 0;
-       unsigned long           curRxOkCnt = 0;
-
-       curTxOkCnt = priv->stats.txbytesunicast - lastTxOkCnt;
-       curRxOkCnt = priv->stats.rxbytesunicast - lastRxOkCnt;
-
-       if((curTxOkCnt + curRxOkCnt) < 15000000) {
-               return;
-       }
-
-       if(curTxOkCnt > 4*curRxOkCnt) {
-               if (priv->bCurrentRxAggrEnable) {
-                       write_nic_dword(priv, 0x1a8, 0);
-                       priv->bCurrentRxAggrEnable = false;
-               }
-       }else{
-               if (!priv->bCurrentRxAggrEnable && !pHTInfo->bCurrentRT2RTAggregation) {
-                       u32 ulValue;
-                       ulValue = (pHTInfo->UsbRxFwAggrEn<<24) | (pHTInfo->UsbRxFwAggrPageNum<<16) |
-                               (pHTInfo->UsbRxFwAggrPacketNum<<8) | (pHTInfo->UsbRxFwAggrTimeout);
-                       /*
-                        * If usb rx firmware aggregation is enabled,
-                        * when anyone of three threshold conditions above is reached,
-                        * firmware will send aggregated packet to driver.
-                        */
-                       write_nic_dword(priv, 0x1a8, ulValue);
-                       priv->bCurrentRxAggrEnable = true;
-               }
-       }
-
-       lastTxOkCnt = priv->stats.txbytesunicast;
-       lastRxOkCnt = priv->stats.rxbytesunicast;
-}
-#endif
-
-
-// call the script file to enable
-void dm_check_ac_dc_power(struct net_device *dev)
+void hal_dm_watchdog(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
-       static char *ac_dc_check_script_path = "/etc/acpi/wireless-rtl-ac-dc-power.sh";
-       char *argv[] = {ac_dc_check_script_path,DRV_NAME,NULL};
-       static char *envp[] = {"HOME=/",
-                       "TERM=linux",
-                       "PATH=/usr/bin:/bin",
-                        NULL};
-
-       if(priv->ResetProgress == RESET_TYPE_SILENT)
-       {
-               RT_TRACE((COMP_INIT | COMP_POWER | COMP_RF), "GPIOChangeRFWorkItemCallBack(): Silent Reseting!!!!!!!\n");
-               return;
-       }
-
-       if(priv->ieee80211->state != IEEE80211_LINKED) {
-               return;
-       }
-       call_usermodehelper(ac_dc_check_script_path,argv,envp,1);
-}
-
-void hal_dm_watchdog(struct net_device *dev)
-{
-       dm_check_ac_dc_power(dev);
 
        /*Add by amy 2008/05/15 ,porting from windows code.*/
-       dm_check_rate_adaptive(dev);
-       dm_dynamic_txpower(dev);
-       dm_check_txrateandretrycount(dev);
+       dm_check_rate_adaptive(priv);
+       dm_dynamic_txpower(priv);
+       dm_check_txrateandretrycount(priv);
 
-       dm_check_txpower_tracking(dev);
+       dm_check_txpower_tracking(priv);
 
-       dm_ctrl_initgain_byrssi(dev);
-       dm_check_edca_turbo(dev);
-       dm_bandwidth_autoswitch(dev);
+       dm_ctrl_initgain_byrssi(priv);
+       dm_check_edca_turbo(priv);
+       dm_bandwidth_autoswitch(priv);
 
-       dm_check_rfctrl_gpio(dev);
-       dm_check_rx_path_selection(dev);
-       dm_check_fsync(dev);
+       dm_check_rfctrl_gpio(priv);
+       dm_check_rx_path_selection(priv);
+       dm_check_fsync(priv);
 
        // Add by amy 2008-05-15 porting from windows code.
-       dm_check_pbc_gpio(dev);
-       dm_send_rssi_tofw(dev);
-       dm_ctstoself(dev);
-
-#ifdef USB_RX_AGGREGATION_SUPPORT
-       dm_CheckRxAggregation(dev);
-#endif
+       dm_send_rssi_tofw(priv);
+       dm_ctstoself(priv);
 }
 
 
@@ -255,11 +149,9 @@ void hal_dm_watchdog(struct net_device *dev)
   *    01/16/2008      MHC             RF_Type is assigned in ReadAdapterInfo(). We must call
   *                                            the function after making sure RF_Type.
   */
-void init_rate_adaptive(struct net_device * dev)
+void init_rate_adaptive(struct r8192_priv *priv)
 {
-
-       struct r8192_priv *priv = ieee80211_priv(dev);
-       prate_adaptive                  pra = (prate_adaptive)&priv->rate_adaptive;
+       prate_adaptive pra = &priv->rate_adaptive;
 
        pra->ratr_state = DM_RATR_STA_MAX;
        pra->high2low_rssi_thresh_for_ra = RateAdaptiveTH_High;
@@ -301,9 +193,8 @@ void init_rate_adaptive(struct net_device * dev)
 }
 
 
-static void dm_check_rate_adaptive(struct net_device * dev)
+static void dm_check_rate_adaptive(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        PRT_HIGH_THROUGHPUT     pHTInfo = priv->ieee80211->pHTInfo;
        prate_adaptive                  pra = (prate_adaptive)&priv->rate_adaptive;
        u32                                             currentRATR, targetRATR = 0;
@@ -415,7 +306,7 @@ static void dm_check_rate_adaptive(struct net_device * dev)
                }
 
                // For RTL819X, if pairwisekey = wep/tkip, we support only MCS0~7.
-               if(priv->ieee80211->GetHalfNmodeSupportByAPsHandler(dev))
+               if(priv->ieee80211->GetHalfNmodeSupportByAPsHandler(priv->ieee80211))
                        targetRATR &=  0xf00fffff;
 
                //
@@ -446,10 +337,8 @@ static void dm_check_rate_adaptive(struct net_device * dev)
 }
 
 
-static void dm_init_bandwidth_autoswitch(struct net_device * dev)
+static void dm_init_bandwidth_autoswitch(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
-
        priv->ieee80211->bandwidth_auto_switch.threshold_20Mhzto40Mhz = BW_AUTO_SWITCH_LOW_HIGH;
        priv->ieee80211->bandwidth_auto_switch.threshold_40Mhzto20Mhz = BW_AUTO_SWITCH_HIGH_LOW;
        priv->ieee80211->bandwidth_auto_switch.bforced_tx20Mhz = false;
@@ -458,10 +347,8 @@ static void dm_init_bandwidth_autoswitch(struct net_device * dev)
 }
 
 
-static void dm_bandwidth_autoswitch(struct net_device * dev)
+static void dm_bandwidth_autoswitch(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
-
        if(priv->CurrentChannelBW == HT_CHANNEL_WIDTH_20 ||!priv->ieee80211->bandwidth_auto_switch.bautoswitch_enable){
                return;
        }else{
@@ -533,9 +420,8 @@ static const u8 CCKSwingTable_Ch14[CCK_Table_length][8] = {
 #define                Tssi_Report_Value1                      0x134
 #define                Tssi_Report_Value2                      0x13e
 #define                FW_Busy_Flag                            0x13f
-static void dm_TXPowerTrackingCallback_TSSI(struct net_device * dev)
-       {
-       struct r8192_priv *priv = ieee80211_priv(dev);
+static void dm_TXPowerTrackingCallback_TSSI(struct r8192_priv *priv)
+{
        bool                                            bHighpowerstate, viviflag = FALSE;
        DCMD_TXCMD_T                    tx_cmd;
        u8                                      powerlevelOFDM24G;
@@ -565,7 +451,7 @@ static void dm_TXPowerTrackingCallback_TSSI(struct net_device * dev)
        tx_cmd.Op               = TXCMD_SET_TX_PWR_TRACKING;
        tx_cmd.Length   = 4;
        tx_cmd.Value            = Value;
-       cmpk_message_handle_tx(dev, (u8*)&tx_cmd, DESC_PACKET_TYPE_INIT, sizeof(DCMD_TXCMD_T));
+       cmpk_message_handle_tx(priv, (u8*)&tx_cmd, DESC_PACKET_TYPE_INIT, sizeof(DCMD_TXCMD_T));
        mdelay(1);
 
        for(i = 0;i <= 30; i++)
@@ -658,20 +544,20 @@ static void dm_TXPowerTrackingCallback_TSSI(struct net_device * dev)
                                        if(priv->rfa_txpowertrackingindex_real > 4)
                                        {
                                                priv->rfa_txpowertrackingindex_real--;
-                                               rtl8192_setBBreg(dev, rOFDM0_XATxIQImbalance, bMaskDWord, priv->txbbgain_table[priv->rfa_txpowertrackingindex_real].txbbgain_value);
+                                               rtl8192_setBBreg(priv, rOFDM0_XATxIQImbalance, bMaskDWord, priv->txbbgain_table[priv->rfa_txpowertrackingindex_real].txbbgain_value);
                                        }
 
                                        priv->rfc_txpowertrackingindex--;
                                        if(priv->rfc_txpowertrackingindex_real > 4)
                                        {
                                                priv->rfc_txpowertrackingindex_real--;
-                                               rtl8192_setBBreg(dev, rOFDM0_XCTxIQImbalance, bMaskDWord, priv->txbbgain_table[priv->rfc_txpowertrackingindex_real].txbbgain_value);
+                                               rtl8192_setBBreg(priv, rOFDM0_XCTxIQImbalance, bMaskDWord, priv->txbbgain_table[priv->rfc_txpowertrackingindex_real].txbbgain_value);
                                        }
                                                }
                                                else
                                                {
-                                                               rtl8192_setBBreg(dev, rOFDM0_XATxIQImbalance, bMaskDWord, priv->txbbgain_table[4].txbbgain_value);
-                                                               rtl8192_setBBreg(dev, rOFDM0_XCTxIQImbalance, bMaskDWord, priv->txbbgain_table[4].txbbgain_value);
+                                                               rtl8192_setBBreg(priv, rOFDM0_XATxIQImbalance, bMaskDWord, priv->txbbgain_table[4].txbbgain_value);
+                                                               rtl8192_setBBreg(priv, rOFDM0_XCTxIQImbalance, bMaskDWord, priv->txbbgain_table[4].txbbgain_value);
                                }
                        }
                        else
@@ -682,11 +568,11 @@ static void dm_TXPowerTrackingCallback_TSSI(struct net_device * dev)
                                                        if(priv->rfc_txpowertrackingindex_real > 4)
                                                        {
                                                                priv->rfc_txpowertrackingindex_real--;
-                                                               rtl8192_setBBreg(dev, rOFDM0_XCTxIQImbalance, bMaskDWord, priv->txbbgain_table[priv->rfc_txpowertrackingindex_real].txbbgain_value);
+                                                               rtl8192_setBBreg(priv, rOFDM0_XCTxIQImbalance, bMaskDWord, priv->txbbgain_table[priv->rfc_txpowertrackingindex_real].txbbgain_value);
                                                        }
                                                }
                                                else
-                                                       rtl8192_setBBreg(dev, rOFDM0_XCTxIQImbalance, bMaskDWord, priv->txbbgain_table[4].txbbgain_value);
+                                                       rtl8192_setBBreg(priv, rOFDM0_XCTxIQImbalance, bMaskDWord, priv->txbbgain_table[4].txbbgain_value);
                                }
                        }
                        else
@@ -697,15 +583,15 @@ static void dm_TXPowerTrackingCallback_TSSI(struct net_device * dev)
                                {
                                        priv->rfa_txpowertrackingindex++;
                                        priv->rfa_txpowertrackingindex_real++;
-                                       rtl8192_setBBreg(dev, rOFDM0_XATxIQImbalance, bMaskDWord, priv->txbbgain_table[priv->rfa_txpowertrackingindex_real].txbbgain_value);
+                                       rtl8192_setBBreg(priv, rOFDM0_XATxIQImbalance, bMaskDWord, priv->txbbgain_table[priv->rfa_txpowertrackingindex_real].txbbgain_value);
                                        priv->rfc_txpowertrackingindex++;
                                        priv->rfc_txpowertrackingindex_real++;
-                                       rtl8192_setBBreg(dev, rOFDM0_XCTxIQImbalance, bMaskDWord, priv->txbbgain_table[priv->rfc_txpowertrackingindex_real].txbbgain_value);
+                                       rtl8192_setBBreg(priv, rOFDM0_XCTxIQImbalance, bMaskDWord, priv->txbbgain_table[priv->rfc_txpowertrackingindex_real].txbbgain_value);
                                }
                                        else
                                        {
-                                               rtl8192_setBBreg(dev, rOFDM0_XATxIQImbalance, bMaskDWord, priv->txbbgain_table[TxBBGainTableLength - 1].txbbgain_value);
-                                               rtl8192_setBBreg(dev, rOFDM0_XCTxIQImbalance, bMaskDWord, priv->txbbgain_table[TxBBGainTableLength - 1].txbbgain_value);
+                                               rtl8192_setBBreg(priv, rOFDM0_XATxIQImbalance, bMaskDWord, priv->txbbgain_table[TxBBGainTableLength - 1].txbbgain_value);
+                                               rtl8192_setBBreg(priv, rOFDM0_XCTxIQImbalance, bMaskDWord, priv->txbbgain_table[TxBBGainTableLength - 1].txbbgain_value);
                        }
                                }
                                else
@@ -714,10 +600,10 @@ static void dm_TXPowerTrackingCallback_TSSI(struct net_device * dev)
                                        {
                                                        priv->rfc_txpowertrackingindex++;
                                                        priv->rfc_txpowertrackingindex_real++;
-                                                       rtl8192_setBBreg(dev, rOFDM0_XCTxIQImbalance, bMaskDWord, priv->txbbgain_table[priv->rfc_txpowertrackingindex_real].txbbgain_value);
+                                                       rtl8192_setBBreg(priv, rOFDM0_XCTxIQImbalance, bMaskDWord, priv->txbbgain_table[priv->rfc_txpowertrackingindex_real].txbbgain_value);
                                        }
                                        else
-                                                       rtl8192_setBBreg(dev, rOFDM0_XCTxIQImbalance, bMaskDWord, priv->txbbgain_table[TxBBGainTableLength - 1].txbbgain_value);
+                                                       rtl8192_setBBreg(priv, rOFDM0_XCTxIQImbalance, bMaskDWord, priv->txbbgain_table[TxBBGainTableLength - 1].txbbgain_value);
                                }
                        }
                        if (RF_Type == RF_2T4R)
@@ -744,15 +630,15 @@ static void dm_TXPowerTrackingCallback_TSSI(struct net_device * dev)
                                if(priv->ieee80211->current_network.channel == 14 && !priv->bcck_in_ch14)
                                {
                                        priv->bcck_in_ch14 = TRUE;
-                                       dm_cck_txpower_adjust(dev,priv->bcck_in_ch14);
+                                       dm_cck_txpower_adjust(priv, priv->bcck_in_ch14);
                                }
                                else if(priv->ieee80211->current_network.channel != 14 && priv->bcck_in_ch14)
                                {
                                        priv->bcck_in_ch14 = FALSE;
-                                       dm_cck_txpower_adjust(dev,priv->bcck_in_ch14);
+                                       dm_cck_txpower_adjust(priv, priv->bcck_in_ch14);
                                }
                                else
-                                       dm_cck_txpower_adjust(dev,priv->bcck_in_ch14);
+                                       dm_cck_txpower_adjust(priv, priv->bcck_in_ch14);
                        }
                RT_TRACE(COMP_POWER_TRACKING, "priv->rfa_txpowertrackingindex = %d\n", priv->rfa_txpowertrackingindex);
                RT_TRACE(COMP_POWER_TRACKING, "priv->rfa_txpowertrackingindex_real = %d\n", priv->rfa_txpowertrackingindex_real);
@@ -782,10 +668,9 @@ static void dm_TXPowerTrackingCallback_TSSI(struct net_device * dev)
                write_nic_byte(priv, Pw_Track_Flag, 0);
 }
 
-static void dm_TXPowerTrackingCallback_ThermalMeter(struct net_device * dev)
+static void dm_TXPowerTrackingCallback_ThermalMeter(struct r8192_priv *priv)
 {
 #define ThermalMeterVal        9
-       struct r8192_priv *priv = ieee80211_priv(dev);
        u32 tmpRegA, TempCCk;
        u8 tmpOFDMindex, tmpCCKindex, tmpCCK20Mindex, tmpCCK40Mindex, tmpval;
        int i =0, CCKSwingNeedUpdate=0;
@@ -793,7 +678,7 @@ static void dm_TXPowerTrackingCallback_ThermalMeter(struct net_device * dev)
        if(!priv->btxpower_trackingInit)
        {
                //Query OFDM default setting
-               tmpRegA= rtl8192_QueryBBReg(dev, rOFDM0_XATxIQImbalance, bMaskDWord);
+               tmpRegA = rtl8192_QueryBBReg(priv, rOFDM0_XATxIQImbalance, bMaskDWord);
                for(i=0; i<OFDM_Table_Length; i++)      //find the index
                {
                        if(tmpRegA == OFDMSwingTable[i])
@@ -805,7 +690,7 @@ static void dm_TXPowerTrackingCallback_ThermalMeter(struct net_device * dev)
                }
 
                //Query CCK default setting From 0xa22
-               TempCCk = rtl8192_QueryBBReg(dev, rCCK0_TxFilter1, bMaskByte2);
+               TempCCk = rtl8192_QueryBBReg(priv, rCCK0_TxFilter1, bMaskByte2);
                for(i=0 ; i<CCK_Table_length ; i++)
                {
                        if(TempCCk == (u32)CCKSwingTable_Ch1_Ch13[i][0])
@@ -822,13 +707,13 @@ static void dm_TXPowerTrackingCallback_ThermalMeter(struct net_device * dev)
        }
 
        // read and filter out unreasonable value
-       tmpRegA = rtl8192_phy_QueryRFReg(dev, RF90_PATH_A, 0x12, 0x078);        // 0x12: RF Reg[10:7]
-       RT_TRACE(COMP_POWER_TRACKING, "Readback ThermalMeterA = %d \n", tmpRegA);
+       tmpRegA = rtl8192_phy_QueryRFReg(priv, RF90_PATH_A, 0x12, 0x078);       // 0x12: RF Reg[10:7]
+       RT_TRACE(COMP_POWER_TRACKING, "Readback ThermalMeterA = %d\n", tmpRegA);
        if(tmpRegA < 3 || tmpRegA > 13)
                return;
        if(tmpRegA >= 12)       // if over 12, TP will be bad when high temperature
                tmpRegA = 12;
-       RT_TRACE(COMP_POWER_TRACKING, "Valid ThermalMeterA = %d \n", tmpRegA);
+       RT_TRACE(COMP_POWER_TRACKING, "Valid ThermalMeterA = %d\n", tmpRegA);
        priv->ThermalMeter[0] = ThermalMeterVal;        //We use fixed value by Bryant's suggestion
        priv->ThermalMeter[1] = ThermalMeterVal;        //We use fixed value by Bryant's suggestion
 
@@ -884,12 +769,12 @@ static void dm_TXPowerTrackingCallback_ThermalMeter(struct net_device * dev)
 
        if(CCKSwingNeedUpdate)
        {
-               dm_cck_txpower_adjust(dev, priv->bcck_in_ch14);
+               dm_cck_txpower_adjust(priv, priv->bcck_in_ch14);
        }
        if(priv->OFDM_index != tmpOFDMindex)
        {
                priv->OFDM_index = tmpOFDMindex;
-               rtl8192_setBBreg(dev, rOFDM0_XATxIQImbalance, bMaskDWord, OFDMSwingTable[priv->OFDM_index]);
+               rtl8192_setBBreg(priv, rOFDM0_XATxIQImbalance, bMaskDWord, OFDMSwingTable[priv->OFDM_index]);
                RT_TRACE(COMP_POWER_TRACKING, "Update OFDMSwing[%d] = 0x%x\n",
                        priv->OFDM_index, OFDMSwingTable[priv->OFDM_index]);
        }
@@ -899,13 +784,12 @@ static void dm_TXPowerTrackingCallback_ThermalMeter(struct net_device * dev)
 void dm_txpower_trackingcallback(struct work_struct *work)
 {
        struct delayed_work *dwork = container_of(work,struct delayed_work,work);
-       struct r8192_priv *priv = container_of(dwork,struct r8192_priv,txpower_tracking_wq);
-       struct net_device *dev = priv->ieee80211->dev;
+       struct r8192_priv *priv = container_of(dwork,struct r8192_priv,txpower_tracking_wq);
 
        if(priv->IC_Cut >= IC_VersionCut_D)
-               dm_TXPowerTrackingCallback_TSSI(dev);
+               dm_TXPowerTrackingCallback_TSSI(priv);
        else
-               dm_TXPowerTrackingCallback_ThermalMeter(dev);
+               dm_TXPowerTrackingCallback_ThermalMeter(priv);
 }
 
 
@@ -1009,10 +893,8 @@ static const ccktxbbgain_struct rtl8192_cck_txbbgain_ch14_table[] = {
        {{ 0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00 }},
 };
 
-static void dm_InitializeTXPowerTracking_TSSI(struct net_device *dev)
+static void dm_InitializeTXPowerTracking_TSSI(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
-
        priv->txbbgain_table = rtl8192_txbbgain_table;
        priv->cck_txbbgain_table = rtl8192_cck_txbbgain_table;
        priv->cck_txbbgain_ch14_table = rtl8192_cck_txbbgain_ch14_table;
@@ -1023,10 +905,8 @@ static void dm_InitializeTXPowerTracking_TSSI(struct net_device *dev)
 
 }
 
-static void dm_InitializeTXPowerTracking_ThermalMeter(struct net_device *dev)
+static void dm_InitializeTXPowerTracking_ThermalMeter(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
-
        // Tx Power tracking by Theremal Meter require Firmware R/W 3-wire. This mechanism
        // can be enabled only when Firmware R/W 3-wire is enabled. Otherwise, frequent r/w
        // 3-wire by driver cause RF goes into wrong state.
@@ -1038,20 +918,17 @@ static void dm_InitializeTXPowerTracking_ThermalMeter(struct net_device *dev)
        priv->btxpower_trackingInit = FALSE;
 }
 
-void dm_initialize_txpower_tracking(struct net_device *dev)
+void dm_initialize_txpower_tracking(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
-
        if(priv->IC_Cut >= IC_VersionCut_D)
-               dm_InitializeTXPowerTracking_TSSI(dev);
+               dm_InitializeTXPowerTracking_TSSI(priv);
        else
-               dm_InitializeTXPowerTracking_ThermalMeter(dev);
+               dm_InitializeTXPowerTracking_ThermalMeter(priv);
 }
 
 
-static void dm_CheckTXPowerTracking_TSSI(struct net_device *dev)
+static void dm_CheckTXPowerTracking_TSSI(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        static u32 tx_power_track_counter = 0;
        RT_TRACE(COMP_POWER_TRACKING,"%s()\n",__FUNCTION__);
        if(read_nic_byte(priv, 0x11e) ==1)
@@ -1066,9 +943,8 @@ static void dm_CheckTXPowerTracking_TSSI(struct net_device *dev)
        }
 }
 
-static void dm_CheckTXPowerTracking_ThermalMeter(struct net_device *dev)
+static void dm_CheckTXPowerTracking_ThermalMeter(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        static u8       TM_Trigger=0;
 
        if(!priv->btxpower_tracking)
@@ -1086,10 +962,10 @@ static void dm_CheckTXPowerTracking_ThermalMeter(struct net_device *dev)
        {
                //Attention!! You have to wirte all 12bits data to RF, or it may cause RF to crash
                //actually write reg0x02 bit1=0, then bit1=1.
-               rtl8192_phy_SetRFReg(dev, RF90_PATH_A, 0x02, bMask12Bits, 0x4d);
-               rtl8192_phy_SetRFReg(dev, RF90_PATH_A, 0x02, bMask12Bits, 0x4f);
-               rtl8192_phy_SetRFReg(dev, RF90_PATH_A, 0x02, bMask12Bits, 0x4d);
-               rtl8192_phy_SetRFReg(dev, RF90_PATH_A, 0x02, bMask12Bits, 0x4f);
+               rtl8192_phy_SetRFReg(priv, RF90_PATH_A, 0x02, bMask12Bits, 0x4d);
+               rtl8192_phy_SetRFReg(priv, RF90_PATH_A, 0x02, bMask12Bits, 0x4f);
+               rtl8192_phy_SetRFReg(priv, RF90_PATH_A, 0x02, bMask12Bits, 0x4d);
+               rtl8192_phy_SetRFReg(priv, RF90_PATH_A, 0x02, bMask12Bits, 0x4f);
                TM_Trigger = 1;
                return;
        }
@@ -1099,21 +975,18 @@ static void dm_CheckTXPowerTracking_ThermalMeter(struct net_device *dev)
        }
 }
 
-static void dm_check_txpower_tracking(struct net_device *dev)
+static void dm_check_txpower_tracking(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
-
        if(priv->IC_Cut >= IC_VersionCut_D)
-               dm_CheckTXPowerTracking_TSSI(dev);
+               dm_CheckTXPowerTracking_TSSI(priv);
        else
-               dm_CheckTXPowerTracking_ThermalMeter(dev);
+               dm_CheckTXPowerTracking_ThermalMeter(priv);
 }
 
 
-static void dm_CCKTxPowerAdjust_TSSI(struct net_device *dev, bool  bInCH14)
+static void dm_CCKTxPowerAdjust_TSSI(struct r8192_priv *priv, bool bInCH14)
 {
        u32 TempVal;
-       struct r8192_priv *priv = ieee80211_priv(dev);
        //Write 0xa22 0xa23
        TempVal = 0;
        if(!bInCH14){
@@ -1121,49 +994,49 @@ static void dm_CCKTxPowerAdjust_TSSI(struct net_device *dev, bool  bInCH14)
                TempVal =       (u32)(priv->cck_txbbgain_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[0] +
                                        (priv->cck_txbbgain_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[1]<<8)) ;
 
-               rtl8192_setBBreg(dev, rCCK0_TxFilter1,bMaskHWord, TempVal);
+               rtl8192_setBBreg(priv, rCCK0_TxFilter1, bMaskHWord, TempVal);
                //Write 0xa24 ~ 0xa27
                TempVal = 0;
                TempVal =       (u32)(priv->cck_txbbgain_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[2] +
                                        (priv->cck_txbbgain_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[3]<<8) +
                                        (priv->cck_txbbgain_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[4]<<16 )+
                                        (priv->cck_txbbgain_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[5]<<24));
-               rtl8192_setBBreg(dev, rCCK0_TxFilter2,bMaskDWord, TempVal);
+               rtl8192_setBBreg(priv, rCCK0_TxFilter2, bMaskDWord, TempVal);
                //Write 0xa28  0xa29
                TempVal = 0;
                TempVal =       (u32)(priv->cck_txbbgain_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[6] +
                                        (priv->cck_txbbgain_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[7]<<8)) ;
 
-               rtl8192_setBBreg(dev, rCCK0_DebugPort,bMaskLWord, TempVal);
+               rtl8192_setBBreg(priv, rCCK0_DebugPort, bMaskLWord, TempVal);
        }
        else
        {
                TempVal =       (u32)(priv->cck_txbbgain_ch14_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[0] +
                                        (priv->cck_txbbgain_ch14_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[1]<<8)) ;
 
-               rtl8192_setBBreg(dev, rCCK0_TxFilter1,bMaskHWord, TempVal);
+               rtl8192_setBBreg(priv, rCCK0_TxFilter1, bMaskHWord, TempVal);
                //Write 0xa24 ~ 0xa27
                TempVal = 0;
                TempVal =       (u32)(priv->cck_txbbgain_ch14_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[2] +
                                        (priv->cck_txbbgain_ch14_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[3]<<8) +
                                        (priv->cck_txbbgain_ch14_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[4]<<16 )+
                                        (priv->cck_txbbgain_ch14_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[5]<<24));
-               rtl8192_setBBreg(dev, rCCK0_TxFilter2,bMaskDWord, TempVal);
+               rtl8192_setBBreg(priv, rCCK0_TxFilter2, bMaskDWord, TempVal);
                //Write 0xa28  0xa29
                TempVal = 0;
                TempVal =       (u32)(priv->cck_txbbgain_ch14_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[6] +
                                        (priv->cck_txbbgain_ch14_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[7]<<8)) ;
 
-               rtl8192_setBBreg(dev, rCCK0_DebugPort,bMaskLWord, TempVal);
+               rtl8192_setBBreg(priv, rCCK0_DebugPort, bMaskLWord, TempVal);
        }
 
 
 }
 
-static void dm_CCKTxPowerAdjust_ThermalMeter(struct net_device *dev,   bool  bInCH14)
+static void dm_CCKTxPowerAdjust_ThermalMeter(struct r8192_priv *priv,
+                                            bool bInCH14)
 {
        u32 TempVal;
-       struct r8192_priv *priv = ieee80211_priv(dev);
 
        TempVal = 0;
        if(!bInCH14)
@@ -1171,7 +1044,7 @@ static void dm_CCKTxPowerAdjust_ThermalMeter(struct net_device *dev,      bool  bInCH
                //Write 0xa22 0xa23
                TempVal =       CCKSwingTable_Ch1_Ch13[priv->CCK_index][0] +
                                        (CCKSwingTable_Ch1_Ch13[priv->CCK_index][1]<<8) ;
-               rtl8192_setBBreg(dev, rCCK0_TxFilter1, bMaskHWord, TempVal);
+               rtl8192_setBBreg(priv, rCCK0_TxFilter1, bMaskHWord, TempVal);
                RT_TRACE(COMP_POWER_TRACKING, "CCK not chnl 14, reg 0x%x = 0x%x\n",
                        rCCK0_TxFilter1, TempVal);
                //Write 0xa24 ~ 0xa27
@@ -1180,7 +1053,7 @@ static void dm_CCKTxPowerAdjust_ThermalMeter(struct net_device *dev,      bool  bInCH
                                        (CCKSwingTable_Ch1_Ch13[priv->CCK_index][3]<<8) +
                                        (CCKSwingTable_Ch1_Ch13[priv->CCK_index][4]<<16 )+
                                        (CCKSwingTable_Ch1_Ch13[priv->CCK_index][5]<<24);
-               rtl8192_setBBreg(dev, rCCK0_TxFilter2, bMaskDWord, TempVal);
+               rtl8192_setBBreg(priv, rCCK0_TxFilter2, bMaskDWord, TempVal);
                RT_TRACE(COMP_POWER_TRACKING, "CCK not chnl 14, reg 0x%x = 0x%x\n",
                        rCCK0_TxFilter2, TempVal);
                //Write 0xa28  0xa29
@@ -1188,7 +1061,7 @@ static void dm_CCKTxPowerAdjust_ThermalMeter(struct net_device *dev,      bool  bInCH
                TempVal =       CCKSwingTable_Ch1_Ch13[priv->CCK_index][6] +
                                        (CCKSwingTable_Ch1_Ch13[priv->CCK_index][7]<<8) ;
 
-               rtl8192_setBBreg(dev, rCCK0_DebugPort, bMaskLWord, TempVal);
+               rtl8192_setBBreg(priv, rCCK0_DebugPort, bMaskLWord, TempVal);
                RT_TRACE(COMP_POWER_TRACKING, "CCK not chnl 14, reg 0x%x = 0x%x\n",
                        rCCK0_DebugPort, TempVal);
        }
@@ -1199,7 +1072,7 @@ static void dm_CCKTxPowerAdjust_ThermalMeter(struct net_device *dev,      bool  bInCH
                TempVal =       CCKSwingTable_Ch14[priv->CCK_index][0] +
                                        (CCKSwingTable_Ch14[priv->CCK_index][1]<<8) ;
 
-               rtl8192_setBBreg(dev, rCCK0_TxFilter1, bMaskHWord, TempVal);
+               rtl8192_setBBreg(priv, rCCK0_TxFilter1, bMaskHWord, TempVal);
                RT_TRACE(COMP_POWER_TRACKING, "CCK chnl 14, reg 0x%x = 0x%x\n",
                        rCCK0_TxFilter1, TempVal);
                //Write 0xa24 ~ 0xa27
@@ -1208,7 +1081,7 @@ static void dm_CCKTxPowerAdjust_ThermalMeter(struct net_device *dev,      bool  bInCH
                                        (CCKSwingTable_Ch14[priv->CCK_index][3]<<8) +
                                        (CCKSwingTable_Ch14[priv->CCK_index][4]<<16 )+
                                        (CCKSwingTable_Ch14[priv->CCK_index][5]<<24);
-               rtl8192_setBBreg(dev, rCCK0_TxFilter2, bMaskDWord, TempVal);
+               rtl8192_setBBreg(priv, rCCK0_TxFilter2, bMaskDWord, TempVal);
                RT_TRACE(COMP_POWER_TRACKING, "CCK chnl 14, reg 0x%x = 0x%x\n",
                        rCCK0_TxFilter2, TempVal);
                //Write 0xa28  0xa29
@@ -1216,96 +1089,23 @@ static void dm_CCKTxPowerAdjust_ThermalMeter(struct net_device *dev,    bool  bInCH
                TempVal =       CCKSwingTable_Ch14[priv->CCK_index][6] +
                                        (CCKSwingTable_Ch14[priv->CCK_index][7]<<8) ;
 
-               rtl8192_setBBreg(dev, rCCK0_DebugPort, bMaskLWord, TempVal);
+               rtl8192_setBBreg(priv, rCCK0_DebugPort, bMaskLWord, TempVal);
                RT_TRACE(COMP_POWER_TRACKING,"CCK chnl 14, reg 0x%x = 0x%x\n",
                        rCCK0_DebugPort, TempVal);
        }
 }
 
-void dm_cck_txpower_adjust(struct net_device *dev, bool binch14)
+void dm_cck_txpower_adjust(struct r8192_priv *priv, bool binch14)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
-
        if(priv->IC_Cut >= IC_VersionCut_D)
-               dm_CCKTxPowerAdjust_TSSI(dev, binch14);
+               dm_CCKTxPowerAdjust_TSSI(priv, binch14);
        else
-               dm_CCKTxPowerAdjust_ThermalMeter(dev, binch14);
-}
-
-
-void dm_change_dynamic_initgain_thresh(struct net_device *dev, u32 dm_type, u32        dm_value)
-{
-       if (dm_type == DIG_TYPE_THRESH_HIGH)
-       {
-               dm_digtable.rssi_high_thresh = dm_value;
-       }
-       else if (dm_type == DIG_TYPE_THRESH_LOW)
-       {
-               dm_digtable.rssi_low_thresh = dm_value;
-       }
-       else if (dm_type == DIG_TYPE_THRESH_HIGHPWR_HIGH)
-       {
-               dm_digtable.rssi_high_power_highthresh = dm_value;
-       }
-       else if (dm_type == DIG_TYPE_THRESH_HIGHPWR_HIGH)
-       {
-               dm_digtable.rssi_high_power_highthresh = dm_value;
-       }
-       else if (dm_type == DIG_TYPE_ENABLE)
-       {
-               dm_digtable.dig_state           = DM_STA_DIG_MAX;
-               dm_digtable.dig_enable_flag     = true;
-       }
-       else if (dm_type == DIG_TYPE_DISABLE)
-       {
-               dm_digtable.dig_state           = DM_STA_DIG_MAX;
-               dm_digtable.dig_enable_flag     = false;
-       }
-       else if (dm_type == DIG_TYPE_DBG_MODE)
-       {
-               if(dm_value >= DM_DBG_MAX)
-                       dm_value = DM_DBG_OFF;
-               dm_digtable.dbg_mode            = (u8)dm_value;
-       }
-       else if (dm_type == DIG_TYPE_RSSI)
-       {
-               if(dm_value > 100)
-                       dm_value = 30;
-               dm_digtable.rssi_val                    = (long)dm_value;
-       }
-       else if (dm_type == DIG_TYPE_ALGORITHM)
-       {
-               if (dm_value >= DIG_ALGO_MAX)
-                       dm_value = DIG_ALGO_BY_FALSE_ALARM;
-               if(dm_digtable.dig_algorithm != (u8)dm_value)
-                       dm_digtable.dig_algorithm_switch = 1;
-               dm_digtable.dig_algorithm       = (u8)dm_value;
-       }
-       else if (dm_type == DIG_TYPE_BACKOFF)
-       {
-               if(dm_value > 30)
-                       dm_value = 30;
-               dm_digtable.backoff_val         = (u8)dm_value;
-       }
-       else if(dm_type == DIG_TYPE_RX_GAIN_MIN)
-       {
-               if(dm_value == 0)
-                       dm_value = 0x1;
-               dm_digtable.rx_gain_range_min = (u8)dm_value;
-       }
-       else if(dm_type == DIG_TYPE_RX_GAIN_MAX)
-       {
-               if(dm_value > 0x50)
-                       dm_value = 0x50;
-               dm_digtable.rx_gain_range_max = (u8)dm_value;
-       }
+               dm_CCKTxPowerAdjust_ThermalMeter(priv, binch14);
 }
 
-
 /* Set DIG scheme init value. */
-static void dm_dig_init(struct net_device *dev)
+static void dm_dig_init(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        /* 2007/10/05 MH Disable DIG scheme now. Not tested. */
        dm_digtable.dig_enable_flag     = true;
        dm_digtable.dig_algorithm = DIG_ALGO_BY_RSSI;
@@ -1339,23 +1139,20 @@ static void dm_dig_init(struct net_device *dev)
  * gain according to different threshold. BB team provide the
  * suggested solution.
  */
-static void dm_ctrl_initgain_byrssi(struct net_device *dev)
+static void dm_ctrl_initgain_byrssi(struct r8192_priv *priv)
 {
-
        if (dm_digtable.dig_enable_flag == false)
                return;
 
        if(dm_digtable.dig_algorithm == DIG_ALGO_BY_FALSE_ALARM)
-               dm_ctrl_initgain_byrssi_by_fwfalse_alarm(dev);
+               dm_ctrl_initgain_byrssi_by_fwfalse_alarm(priv);
        else if(dm_digtable.dig_algorithm == DIG_ALGO_BY_RSSI)
-               dm_ctrl_initgain_byrssi_by_driverrssi(dev);
+               dm_ctrl_initgain_byrssi_by_driverrssi(priv);
 }
 
 
-static void dm_ctrl_initgain_byrssi_by_driverrssi(
-       struct net_device *dev)
+static void dm_ctrl_initgain_byrssi_by_driverrssi(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        u8 i;
        static u8       fw_dig=0;
 
@@ -1367,7 +1164,7 @@ static void dm_ctrl_initgain_byrssi_by_driverrssi(
        if(fw_dig <= 3) // execute several times to make sure the FW Dig is disabled
        {// FW DIG Off
                for(i=0; i<3; i++)
-                       rtl8192_setBBreg(dev, UFWP, bMaskByte1, 0x8);   // Only clear byte 1 and rewrite.
+                       rtl8192_setBBreg(priv, UFWP, bMaskByte1, 0x8);  // Only clear byte 1 and rewrite.
                fw_dig++;
                dm_digtable.dig_state = DM_STA_DIG_OFF; //fw dig off.
        }
@@ -1380,19 +1177,17 @@ static void dm_ctrl_initgain_byrssi_by_driverrssi(
        if(dm_digtable.dbg_mode == DM_DBG_OFF)
                dm_digtable.rssi_val = priv->undecorated_smoothed_pwdb;
 
-       dm_initial_gain(dev);
-       dm_pd_th(dev);
-       dm_cs_ratio(dev);
+       dm_initial_gain(priv);
+       dm_pd_th(priv);
+       dm_cs_ratio(priv);
        if(dm_digtable.dig_algorithm_switch)
                dm_digtable.dig_algorithm_switch = 0;
        dm_digtable.pre_connect_state = dm_digtable.cur_connect_state;
 
 }
 
-static void dm_ctrl_initgain_byrssi_by_fwfalse_alarm(
-       struct net_device *dev)
+static void dm_ctrl_initgain_byrssi_by_fwfalse_alarm(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        static u32 reset_cnt = 0;
        u8 i;
 
@@ -1404,7 +1199,7 @@ static void dm_ctrl_initgain_byrssi_by_fwfalse_alarm(
                dm_digtable.dig_state = DM_STA_DIG_MAX;
                // Fw DIG On.
                for(i=0; i<3; i++)
-                       rtl8192_setBBreg(dev, UFWP, bMaskByte1, 0x1);   // Only clear byte 1 and rewrite.
+                       rtl8192_setBBreg(priv, UFWP, bMaskByte1, 0x1);  // Only clear byte 1 and rewrite.
                dm_digtable.dig_algorithm_switch = 0;
        }
 
@@ -1439,7 +1234,7 @@ static void dm_ctrl_initgain_byrssi_by_fwfalse_alarm(
                dm_digtable.dig_state = DM_STA_DIG_OFF;
 
                // 1.1 DIG Off.
-               rtl8192_setBBreg(dev, UFWP, bMaskByte1, 0x8);   // Only clear byte 1 and rewrite.
+               rtl8192_setBBreg(priv, UFWP, bMaskByte1, 0x8);  // Only clear byte 1 and rewrite.
 
                // 1.2 Set initial gain.
                write_nic_byte(priv, rOFDM0_XAAGCCore1, 0x17);
@@ -1475,7 +1270,7 @@ static void dm_ctrl_initgain_byrssi_by_fwfalse_alarm(
                if (dm_digtable.dig_state == DM_STA_DIG_ON &&
                        (priv->reset_count == reset_cnt))
                {
-                       dm_ctrl_initgain_byrssi_highpwr(dev);
+                       dm_ctrl_initgain_byrssi_highpwr(priv);
                        return;
                }
                else
@@ -1523,18 +1318,16 @@ static void dm_ctrl_initgain_byrssi_by_fwfalse_alarm(
                //PlatformEFIOWrite4Byte(pAdapter, rOFDM0_ECCAThreshold, 0x346);
 
                // 2.5 DIG On.
-               rtl8192_setBBreg(dev, UFWP, bMaskByte1, 0x1);   // Only clear byte 1 and rewrite.
+               rtl8192_setBBreg(priv, UFWP, bMaskByte1, 0x1);  // Only clear byte 1 and rewrite.
 
        }
 
-       dm_ctrl_initgain_byrssi_highpwr(dev);
+       dm_ctrl_initgain_byrssi_highpwr(priv);
 
 }
 
-static void dm_ctrl_initgain_byrssi_highpwr(
-       struct net_device * dev)
+static void dm_ctrl_initgain_byrssi_highpwr(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        static u32 reset_cnt_highpwr = 0;
 
        // For smooth, we can not change high power DIG state in the range.
@@ -1589,10 +1382,8 @@ static void dm_ctrl_initgain_byrssi_highpwr(
 }
 
 
-static void dm_initial_gain(
-       struct net_device * dev)
+static void dm_initial_gain(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        u8                                      initial_gain=0;
        static u8                               initialized=0, force_write=0;
        static u32                      reset_cnt=0;
@@ -1655,10 +1446,8 @@ static void dm_initial_gain(
        }
 }
 
-static void dm_pd_th(
-       struct net_device * dev)
+static void dm_pd_th(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        static u8                               initialized=0, force_write=0;
        static u32                      reset_cnt = 0;
 
@@ -1745,10 +1534,8 @@ static void dm_pd_th(
        }
 }
 
-static void dm_cs_ratio(
-       struct net_device * dev)
+static void dm_cs_ratio(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        static u8                               initialized=0,force_write=0;
        static u32                      reset_cnt = 0;
 
@@ -1806,19 +1593,16 @@ static  void dm_cs_ratio(
        }
 }
 
-void dm_init_edca_turbo(struct net_device *dev)
+void dm_init_edca_turbo(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
 
        priv->bcurrent_turbo_EDCA = false;
        priv->ieee80211->bis_any_nonbepkts = false;
        priv->bis_cur_rdlstate = false;
 }
 
-static void dm_check_edca_turbo(
-       struct net_device * dev)
+static void dm_check_edca_turbo(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        PRT_HIGH_THROUGHPUT     pHTInfo = priv->ieee80211->pHTInfo;
        //PSTA_QOS                      pStaQos = pMgntInfo->pStaQos;
 
@@ -1880,7 +1664,7 @@ static void dm_check_edca_turbo(
                                u8 mode = priv->ieee80211->mode;
 
                        // For Each time updating EDCA parameter, reset EDCA turbo mode status.
-                               dm_init_edca_turbo(dev);
+                               dm_init_edca_turbo(priv);
                                u1bAIFS = qos_parameters->aifs[0] * ((mode&(IEEE_G|IEEE_N_24G)) ?9:20) + aSifsTime;
                                u4bAcParam = ((((u32)(qos_parameters->tx_op_limit[0]))<< AC_PARAM_TXOP_LIMIT_OFFSET)|
                                        (((u32)(qos_parameters->cw_max[0]))<< AC_PARAM_ECW_MAX_OFFSET)|
@@ -1922,17 +1706,14 @@ dm_CheckEdcaTurbo_EXIT:
        lastRxOkCnt = priv->stats.rxbytesunicast;
 }
 
-static void dm_init_ctstoself(struct net_device * dev)
+static void dm_init_ctstoself(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv((struct net_device *)dev);
-
        priv->ieee80211->bCTSToSelfEnable = TRUE;
        priv->ieee80211->CTSToSelfTH = CTSToSelfTHVal;
 }
 
-static void dm_ctstoself(struct net_device *dev)
+static void dm_ctstoself(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv((struct net_device *)dev);
        PRT_HIGH_THROUGHPUT     pHTInfo = priv->ieee80211->pHTInfo;
        static unsigned long                            lastTxOkCnt = 0;
        static unsigned long                            lastRxOkCnt = 0;
@@ -1971,9 +1752,8 @@ static void dm_ctstoself(struct net_device *dev)
 
 
 /* Copy 8187B template for 9xseries */
-static void dm_check_rfctrl_gpio(struct net_device * dev)
+static void dm_check_rfctrl_gpio(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
 
        // Walk around for DTM test, we will not enable HW - radio on/off because r/w
        // page 1 register before Lextra bus is enabled cause system fails when resuming
@@ -1983,17 +1763,11 @@ static void dm_check_rfctrl_gpio(struct net_device * dev)
        queue_delayed_work(priv->priv_wq,&priv->gpio_change_rf_wq,0);
 }
 
-/* Check if PBC button is pressed. */
-static void    dm_check_pbc_gpio(struct net_device *dev)
-{
-}
-
 /* PCI will not support workitem call back HW radio on-off control. */
 void dm_gpio_change_rf_callback(struct work_struct *work)
 {
        struct delayed_work *dwork = container_of(work,struct delayed_work,work);
        struct r8192_priv *priv = container_of(dwork,struct r8192_priv,gpio_change_rf_wq);
-       struct net_device *dev = priv->ieee80211->dev;
        u8 tmp1byte;
        RT_RF_POWER_STATE       eRfPowerStateToSet;
        bool bActuallySet = false;
@@ -2020,7 +1794,7 @@ void dm_gpio_change_rf_callback(struct work_struct *work)
 
                if (bActuallySet) {
                        priv->bHwRfOffAction = 1;
-                       MgntActSet_RF_State(dev, eRfPowerStateToSet, RF_CHANGE_BY_HW);
+                       MgntActSet_RF_State(priv, eRfPowerStateToSet, RF_CHANGE_BY_HW);
                        //DrvIFIndicateCurrentPhyStatus(pAdapter);
                } else {
                        msleep(2000);
@@ -2033,8 +1807,6 @@ void dm_rf_pathcheck_workitemcallback(struct work_struct *work)
 {
        struct delayed_work *dwork = container_of(work,struct delayed_work,work);
        struct r8192_priv *priv = container_of(dwork,struct r8192_priv,rfpath_check_wq);
-       struct net_device *dev =priv->ieee80211->dev;
-       //bool bactually_set = false;
        u8 rfpath = 0, i;
 
 
@@ -2053,13 +1825,13 @@ void dm_rf_pathcheck_workitemcallback(struct work_struct *work)
        if(!DM_RxPathSelTable.Enable)
                return;
 
-       dm_rxpath_sel_byrssi(dev);
+       dm_rxpath_sel_byrssi(priv);
 }
 
-static void dm_init_rxpath_selection(struct net_device * dev)
+static void dm_init_rxpath_selection(struct r8192_priv *priv)
 {
        u8 i;
-       struct r8192_priv *priv = ieee80211_priv(dev);
+
        DM_RxPathSelTable.Enable = 1;   //default enabled
        DM_RxPathSelTable.SS_TH_low = RxPathSelection_SS_TH_low;
        DM_RxPathSelTable.diff_TH = RxPathSelection_diff_TH;
@@ -2077,9 +1849,8 @@ static void dm_init_rxpath_selection(struct net_device * dev)
        }
 }
 
-static void dm_rxpath_sel_byrssi(struct net_device * dev)
+static void dm_rxpath_sel_byrssi(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        u8                              i, max_rssi_index=0, min_rssi_index=0, sec_rssi_index=0, rf_num=0;
        u8                              tmp_max_rssi=0, tmp_min_rssi=0, tmp_sec_rssi=0;
        u8                              cck_default_Rx=0x2;     //RF-C
@@ -2299,8 +2070,8 @@ static void dm_rxpath_sel_byrssi(struct net_device * dev)
                        //record the enabled rssi threshold
                        DM_RxPathSelTable.rf_enable_rssi_th[min_rssi_index] = tmp_max_rssi+5;
                        //disable the BB Rx path, OFDM
-                       rtl8192_setBBreg(dev, rOFDM0_TRxPathEnable, 0x1<<min_rssi_index, 0x0);  // 0xc04[3:0]
-                       rtl8192_setBBreg(dev, rOFDM1_TRxPathEnable, 0x1<<min_rssi_index, 0x0);  // 0xd04[3:0]
+                       rtl8192_setBBreg(priv, rOFDM0_TRxPathEnable, 0x1<<min_rssi_index, 0x0); // 0xc04[3:0]
+                       rtl8192_setBBreg(priv, rOFDM1_TRxPathEnable, 0x1<<min_rssi_index, 0x0); // 0xd04[3:0]
                        disabled_rf_cnt++;
                }
                if(DM_RxPathSelTable.cck_method == CCK_Rx_Version_1)
@@ -2315,7 +2086,7 @@ static void dm_rxpath_sel_byrssi(struct net_device * dev)
        if(update_cck_rx_path)
        {
                DM_RxPathSelTable.cck_Rx_path = (cck_default_Rx<<2)|(cck_optional_Rx);
-               rtl8192_setBBreg(dev, rCCK0_AFESetting, 0x0f000000, DM_RxPathSelTable.cck_Rx_path);
+               rtl8192_setBBreg(priv, rCCK0_AFESetting, 0x0f000000, DM_RxPathSelTable.cck_Rx_path);
        }
 
        if(DM_RxPathSelTable.disabledRF)
@@ -2327,8 +2098,8 @@ static void dm_rxpath_sel_byrssi(struct net_device * dev)
                                if(tmp_max_rssi >= DM_RxPathSelTable.rf_enable_rssi_th[i])
                                {
                                        //enable the BB Rx path
-                                       rtl8192_setBBreg(dev, rOFDM0_TRxPathEnable, 0x1<<i, 0x1);       // 0xc04[3:0]
-                                       rtl8192_setBBreg(dev, rOFDM1_TRxPathEnable, 0x1<<i, 0x1);       // 0xd04[3:0]
+                                       rtl8192_setBBreg(priv, rOFDM0_TRxPathEnable, 0x1<<i, 0x1);      // 0xc04[3:0]
+                                       rtl8192_setBBreg(priv, rOFDM1_TRxPathEnable, 0x1<<i, 0x1);      // 0xd04[3:0]
                                        DM_RxPathSelTable.rf_enable_rssi_th[i] = 100;
                                        disabled_rf_cnt--;
                                }
@@ -2340,16 +2111,13 @@ static void dm_rxpath_sel_byrssi(struct net_device * dev)
 /*
  * Call a workitem to check current RXRF path and Rx Path selection by RSSI.
  */
-static void dm_check_rx_path_selection(struct net_device *dev)
+static void dm_check_rx_path_selection(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        queue_delayed_work(priv->priv_wq,&priv->rfpath_check_wq,0);
 }
 
-static void dm_init_fsync (struct net_device *dev)
+static void dm_init_fsync(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
-
        priv->ieee80211->fsync_time_interval = 500;
        priv->ieee80211->fsync_rate_bitmap = 0x0f000800;
        priv->ieee80211->fsync_rssi_threshold = 30;
@@ -2361,20 +2129,19 @@ static void dm_init_fsync (struct net_device *dev)
        priv->framesyncMonitor = 1;     // current default 0xc38 monitor on
 
        init_timer(&priv->fsync_timer);
-       priv->fsync_timer.data = (unsigned long)dev;
+       priv->fsync_timer.data = (unsigned long)priv;
        priv->fsync_timer.function = dm_fsync_timer_callback;
 }
 
 
-static void dm_deInit_fsync(struct net_device *dev)
+static void dm_deInit_fsync(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        del_timer_sync(&priv->fsync_timer);
 }
 
-void dm_fsync_timer_callback(unsigned long data)
+static void dm_fsync_timer_callback(unsigned long data)
 {
-       struct r8192_priv *priv = ieee80211_priv((struct net_device *)data);
+       struct r8192_priv *priv = (struct r8192_priv *)data;
        u32 rate_index, rate_count = 0, rate_count_diff=0;
        bool            bSwitchFromCountDiff = false;
        bool            bDoubleTimeInterval = false;
@@ -2482,19 +2249,15 @@ void dm_fsync_timer_callback(unsigned long data)
        RT_TRACE(COMP_HALDM, "rateRecord %d rateCount %d, rateCountdiff %d bSwitchFsync %d\n", priv->rate_record, rate_count, rate_count_diff , priv->bswitch_fsync);
 }
 
-static void dm_StartHWFsync(struct net_device *dev)
+static void dm_StartHWFsync(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
-
        RT_TRACE(COMP_HALDM, "%s\n", __FUNCTION__);
        write_nic_dword(priv, rOFDM0_RxDetector2, 0x465c12cf);
        write_nic_byte(priv, 0xc3b, 0x41);
 }
 
-static void dm_EndSWFsync(struct net_device *dev)
+static void dm_EndSWFsync(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
-
        RT_TRACE(COMP_HALDM, "%s\n", __FUNCTION__);
        del_timer_sync(&(priv->fsync_timer));
 
@@ -2513,9 +2276,8 @@ static void dm_EndSWFsync(struct net_device *dev)
        write_nic_dword(priv, rOFDM0_RxDetector2, 0x465c52cd);
 }
 
-static void dm_StartSWFsync(struct net_device *dev)
+static void dm_StartSWFsync(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        u32                     rateIndex;
        u32                     rateBitmap;
 
@@ -2551,21 +2313,18 @@ static void dm_StartSWFsync(struct net_device *dev)
        write_nic_dword(priv, rOFDM0_RxDetector2, 0x465c12cd);
 }
 
-static void dm_EndHWFsync(struct net_device *dev)
+static void dm_EndHWFsync(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
-
        RT_TRACE(COMP_HALDM,"%s\n", __FUNCTION__);
        write_nic_dword(priv, rOFDM0_RxDetector2, 0x465c52cd);
        write_nic_byte(priv, 0xc3b, 0x49);
 }
 
-void dm_check_fsync(struct net_device *dev)
+static void dm_check_fsync(struct r8192_priv *priv)
 {
 #define        RegC38_Default                          0
 #define        RegC38_NonFsync_Other_AP        1
 #define        RegC38_Fsync_AP_BCM             2
-       struct r8192_priv *priv = ieee80211_priv(dev);
        //u32                   framesyncC34;
        static u8               reg_c38_State=RegC38_Default;
        static u32      reset_cnt=0;
@@ -2581,12 +2340,12 @@ void dm_check_fsync(struct net_device *dev)
                        switch(priv->ieee80211->fsync_state)
                        {
                                case Default_Fsync:
-                                       dm_StartHWFsync(dev);
+                                       dm_StartHWFsync(priv);
                                        priv->ieee80211->fsync_state = HW_Fsync;
                                        break;
                                case SW_Fsync:
-                                       dm_EndSWFsync(dev);
-                                       dm_StartHWFsync(dev);
+                                       dm_EndSWFsync(priv);
+                                       dm_StartHWFsync(priv);
                                        priv->ieee80211->fsync_state = HW_Fsync;
                                        break;
                                case HW_Fsync:
@@ -2599,12 +2358,12 @@ void dm_check_fsync(struct net_device *dev)
                        switch(priv->ieee80211->fsync_state)
                        {
                                case Default_Fsync:
-                                       dm_StartSWFsync(dev);
+                                       dm_StartSWFsync(priv);
                                        priv->ieee80211->fsync_state = SW_Fsync;
                                        break;
                                case HW_Fsync:
-                                       dm_EndHWFsync(dev);
-                                       dm_StartSWFsync(dev);
+                                       dm_EndHWFsync(priv);
+                                       dm_StartSWFsync(priv);
                                        priv->ieee80211->fsync_state = SW_Fsync;
                                        break;
                                case SW_Fsync:
@@ -2628,11 +2387,11 @@ void dm_check_fsync(struct net_device *dev)
                switch(priv->ieee80211->fsync_state)
                {
                        case HW_Fsync:
-                               dm_EndHWFsync(dev);
+                               dm_EndHWFsync(priv);
                                priv->ieee80211->fsync_state = Default_Fsync;
                                break;
                        case SW_Fsync:
-                               dm_EndSWFsync(dev);
+                               dm_EndSWFsync(priv);
                                priv->ieee80211->fsync_state = Default_Fsync;
                                break;
                        case Default_Fsync:
@@ -2695,10 +2454,8 @@ void dm_check_fsync(struct net_device *dev)
  * Detect Signal strength to control TX Registry
  * Tx Power Control For Near/Far Range
  */
-static void dm_init_dynamic_txpower(struct net_device *dev)
+static void dm_init_dynamic_txpower(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
-
        //Initial TX Power Control for near/far range , add by amy 2008/05/15, porting from windows code.
        priv->ieee80211->bdynamic_txpower_enable = true;    //Default to enable Tx Power Control
        priv->bLastDTPFlag_High = false;
@@ -2707,9 +2464,8 @@ static void dm_init_dynamic_txpower(struct net_device *dev)
        priv->bDynamicTxLowPower = false;
 }
 
-static void dm_dynamic_txpower(struct net_device *dev)
+static void dm_dynamic_txpower(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        unsigned int txhipower_threshhold=0;
         unsigned int txlowpower_threshold=0;
        if(priv->ieee80211->bdynamic_txpower_enable != true)
@@ -2728,7 +2484,7 @@ static void dm_dynamic_txpower(struct net_device *dev)
                txlowpower_threshold = TX_POWER_NEAR_FIELD_THRESH_LOW;
        }
 
-       RT_TRACE(COMP_TXAGC,"priv->undecorated_smoothed_pwdb = %ld \n" , priv->undecorated_smoothed_pwdb);
+       RT_TRACE(COMP_TXAGC, "priv->undecorated_smoothed_pwdb = %ld\n" , priv->undecorated_smoothed_pwdb);
 
        if(priv->ieee80211->state == IEEE80211_LINKED)
        {
@@ -2765,10 +2521,10 @@ static void dm_dynamic_txpower(struct net_device *dev)
        if( (priv->bDynamicTxHighPower != priv->bLastDTPFlag_High ) ||
                (priv->bDynamicTxLowPower != priv->bLastDTPFlag_Low ) )
        {
-               RT_TRACE(COMP_TXAGC,"SetTxPowerLevel8190()  channel = %d \n" , priv->ieee80211->current_network.channel);
+               RT_TRACE(COMP_TXAGC, "SetTxPowerLevel8190() channel = %d\n", priv->ieee80211->current_network.channel);
 
 
-               rtl8192_phy_setTxPower(dev,priv->ieee80211->current_network.channel);
+               rtl8192_phy_setTxPower(priv, priv->ieee80211->current_network.channel);
 
        }
        priv->bLastDTPFlag_High = priv->bDynamicTxHighPower;
@@ -2777,20 +2533,18 @@ static void dm_dynamic_txpower(struct net_device *dev)
 }
 
 //added by vivi, for read tx rate and retrycount
-static void dm_check_txrateandretrycount(struct net_device * dev)
+static void dm_check_txrateandretrycount(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
        struct ieee80211_device* ieee = priv->ieee80211;
+
        //for initial tx rate
        ieee->softmac_stats.last_packet_rate = read_nic_byte(priv ,Initial_Tx_Rate_Reg);
        //for tx tx retry count
        ieee->softmac_stats.txretrycount = read_nic_dword(priv, Tx_Retry_Count_Reg);
 }
 
-static void dm_send_rssi_tofw(struct net_device *dev)
+static void dm_send_rssi_tofw(struct r8192_priv *priv)
 {
-       struct r8192_priv *priv = ieee80211_priv(dev);
-
        // If we test chariot, we should stop the TX command ?
        // Because 92E will always silent reset when we send tx command. We use register
        // 0x1e0(byte) to botify driver.