staging: vt6656: rxtx.c s_vFillRTSHead Parse out struct vnt_rts_ab to new function.
authorMalcolm Priestley <tvboxspy@gmail.com>
Mon, 26 Aug 2013 10:09:38 +0000 (11:09 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 26 Aug 2013 13:26:47 +0000 (06:26 -0700)
Parse out vnt_rts_ab code to new function vnt_rxtx_rts_ab_head.

Signed-off-by: Malcolm Priestley <tvboxspy@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/vt6656/rxtx.c

index 5cfdfafda6f4cbe5e686c9d90b6d4a0bd18e22b2..ce8018e2b16e5451b648d0281a099465f66b7ecf 100644 (file)
@@ -674,6 +674,24 @@ static int vnt_rxtx_rts_g_fb_head(struct vnt_private *priv,
        return 0;
 }
 
+static int vnt_rxtx_rts_ab_head(struct vnt_private *priv,
+       struct vnt_rts_ab *buf, struct ethhdr *eth_hdr,
+       u8 pkt_type, u32 frame_len, int need_ack,
+       u16 current_rate, u8 fb_option)
+{
+       u16 rts_frame_len = 20;
+
+       BBvCalculateParameter(priv, rts_frame_len,
+               priv->byTopOFDMBasicRate, pkt_type, &buf->ab);
+
+       buf->wDuration = s_uGetRTSCTSDuration(priv, RTSDUR_AA, frame_len,
+               pkt_type, current_rate, need_ack, fb_option);
+
+       vnt_fill_ieee80211_rts(priv, &buf->data, eth_hdr, buf->wDuration);
+
+       return 0;
+}
+
 static void s_vFillRTSHead(struct vnt_private *pDevice, u8 byPktType,
        void *pvRTS, u32 cbFrameLength, int bNeedAck,
        struct ethhdr *psEthHeader, u16 wCurrentRate, u8 byFBOption)
@@ -704,27 +722,10 @@ static void s_vFillRTSHead(struct vnt_private *pDevice, u8 byPktType,
     else if (byPktType == PK_TYPE_11A) {
         if (byFBOption == AUTO_FB_NONE) {
                struct vnt_rts_ab *pBuf = (struct vnt_rts_ab *)pvRTS;
-            //Get SignalField,ServiceField,Length
-               BBvCalculateParameter(pDevice, uRTSFrameLen,
-                       pDevice->byTopOFDMBasicRate, byPktType, &pBuf->ab);
-            //Get Duration
-               pBuf->wDuration = s_uGetRTSCTSDuration(pDevice, RTSDUR_AA,
-                       cbFrameLength, byPktType, wCurrentRate,
-                               bNeedAck, byFBOption);
-               pBuf->data.duration = pBuf->wDuration;
-               /* Get RTS Frame body */
-               pBuf->data.frame_control = TYPE_CTL_RTS;
-
-               if (pDevice->eOPMode == OP_MODE_ADHOC ||
-                               pDevice->eOPMode == OP_MODE_AP)
-                       memcpy(pBuf->data.ra, psEthHeader->h_dest, ETH_ALEN);
-               else
-                       memcpy(pBuf->data.ra, pDevice->abyBSSID, ETH_ALEN);
 
-               if (pDevice->eOPMode == OP_MODE_AP)
-                       memcpy(pBuf->data.ta, pDevice->abyBSSID, ETH_ALEN);
-               else
-                       memcpy(pBuf->data.ta, psEthHeader->h_source, ETH_ALEN);
+               vnt_rxtx_rts_ab_head(pDevice, pBuf,
+                               psEthHeader, byPktType, cbFrameLength,
+                               bNeedAck, wCurrentRate, byFBOption);
         }
         else {
                struct vnt_rts_a_fb *pBuf = (struct vnt_rts_a_fb *)pvRTS;
@@ -759,28 +760,10 @@ static void s_vFillRTSHead(struct vnt_private *pDevice, u8 byPktType,
     }
     else if (byPktType == PK_TYPE_11B) {
        struct vnt_rts_ab *pBuf = (struct vnt_rts_ab *)pvRTS;
-        //Get SignalField,ServiceField,Length
-       BBvCalculateParameter(pDevice, uRTSFrameLen, pDevice->byTopCCKBasicRate,
-               PK_TYPE_11B, &pBuf->ab);
-        //Get Duration
-       pBuf->wDuration = s_uGetRTSCTSDuration(pDevice, RTSDUR_BB,
-               cbFrameLength, byPktType, wCurrentRate,
-               bNeedAck, byFBOption);
-
-       pBuf->data.duration = pBuf->wDuration;
-       /* Get RTS Frame body */
-       pBuf->data.frame_control = TYPE_CTL_RTS;
-
-       if (pDevice->eOPMode == OP_MODE_ADHOC ||
-                       pDevice->eOPMode == OP_MODE_AP)
-               memcpy(pBuf->data.ra, psEthHeader->h_dest, ETH_ALEN);
-       else
-               memcpy(pBuf->data.ra, pDevice->abyBSSID, ETH_ALEN);
 
-       if (pDevice->eOPMode == OP_MODE_AP)
-               memcpy(pBuf->data.ta, pDevice->abyBSSID, ETH_ALEN);
-       else
-               memcpy(pBuf->data.ta, psEthHeader->h_source, ETH_ALEN);
+       vnt_rxtx_rts_ab_head(pDevice, pBuf,
+                       psEthHeader, byPktType, cbFrameLength,
+                       bNeedAck, wCurrentRate, byFBOption);
     }
 }