staging: vt6656: rxtx.c create structure to join vnt_tx_data_head with vnt_tx_head.
authorMalcolm Priestley <tvboxspy@gmail.com>
Thu, 26 Sep 2013 17:49:44 +0000 (18:49 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 26 Sep 2013 23:40:13 +0000 (16:40 -0700)
Create struct vnt_tx_mic_hdr for with union vnt_tx_data_head
for mic mode.

Create union vnt_tx for mic and non mic mode.

Attach vnt_rrv_time_* to relevant tx_head.

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

index 7b05ee8b702c7d51aeee54e0fa764fee8dee7f4e..c80a809d4a41099bfd2447cf9ceabf758e21257d 100644 (file)
@@ -870,7 +870,7 @@ static void s_vGenerateTxParameter(struct vnt_private *pDevice,
     if (byPktType == PK_TYPE_11GB || byPktType == PK_TYPE_11GA) {
        if (need_rts) {
             //Fill RsvTime
-               struct vnt_rrv_time_rts *pBuf = &tx_buffer->tx_head.rts;
+               struct vnt_rrv_time_rts *pBuf = &tx_buffer->tx_head.tx_rts.rts;
 
                pBuf->wRTSTxRrvTime_aa = s_uGetRTSCTSRsvTime(pDevice, 2,
                                byPktType, cbFrameSize, wCurrentRate);
@@ -889,7 +889,7 @@ static void s_vGenerateTxParameter(struct vnt_private *pDevice,
         }
         else {//RTS_needless, PCF mode
             //Fill RsvTime
-               struct vnt_rrv_time_cts *pBuf = &tx_buffer->tx_head.cts;
+               struct vnt_rrv_time_cts *pBuf = &tx_buffer->tx_head.tx_cts.cts;
 
                pBuf->wTxRrvTime_a = vnt_rxtx_rsvtime_le16(pDevice, byPktType,
                        cbFrameSize, wCurrentRate, bNeedACK);
@@ -906,7 +906,7 @@ static void s_vGenerateTxParameter(struct vnt_private *pDevice,
     else if (byPktType == PK_TYPE_11A) {
        if (need_rts) {
             //Fill RsvTime
-               struct vnt_rrv_time_ab *pBuf = &tx_buffer->tx_head.ab;
+               struct vnt_rrv_time_ab *pBuf = &tx_buffer->tx_head.tx_ab.ab;
 
                pBuf->wRTSTxRrvTime = s_uGetRTSCTSRsvTime(pDevice, 2,
                                byPktType, cbFrameSize, wCurrentRate);
@@ -917,7 +917,7 @@ static void s_vGenerateTxParameter(struct vnt_private *pDevice,
                        bNeedACK, psEthHeader, wCurrentRate, byFBOption);
        } else {
             //Fill RsvTime
-               struct vnt_rrv_time_ab *pBuf = &tx_buffer->tx_head.ab;
+               struct vnt_rrv_time_ab *pBuf = &tx_buffer->tx_head.tx_ab.ab;
 
                pBuf->wTxRrvTime = vnt_rxtx_rsvtime_le16(pDevice, PK_TYPE_11A,
                        cbFrameSize, wCurrentRate, bNeedACK);
@@ -926,7 +926,7 @@ static void s_vGenerateTxParameter(struct vnt_private *pDevice,
     else if (byPktType == PK_TYPE_11B) {
        if (need_rts) {
             //Fill RsvTime
-               struct vnt_rrv_time_ab *pBuf = &tx_buffer->tx_head.ab;
+               struct vnt_rrv_time_ab *pBuf = &tx_buffer->tx_head.tx_ab.ab;
 
                pBuf->wRTSTxRrvTime = s_uGetRTSCTSRsvTime(pDevice, 0,
                                byPktType, cbFrameSize, wCurrentRate);
@@ -938,7 +938,7 @@ static void s_vGenerateTxParameter(struct vnt_private *pDevice,
         }
         else { //RTS_needless, non PCF mode
             //Fill RsvTime
-               struct vnt_rrv_time_ab *pBuf = &tx_buffer->tx_head.ab;
+               struct vnt_rrv_time_ab *pBuf = &tx_buffer->tx_head.tx_ab.ab;
 
                pBuf->wTxRrvTime = vnt_rxtx_rsvtime_le16(pDevice, PK_TYPE_11B,
                        cbFrameSize, wCurrentRate, bNeedACK);
index 78b7b749ef9635ebc35f3cccb6c898de4f8b6ab8..bbda9a3a83c030f36e72af9a4c18fae2f75ba81e 100644 (file)
@@ -180,10 +180,29 @@ union vnt_tx_data_head {
        struct vnt_cts_fb cts_g_fb;
 };
 
+struct vnt_tx_mic_hdr {
+       struct vnt_mic_hdr hdr;
+       union vnt_tx_data_head head;
+} __packed;
+
+union vnt_tx {
+       struct vnt_tx_mic_hdr mic;
+       union vnt_tx_data_head head;
+};
+
 union vnt_tx_head {
-       struct vnt_rrv_time_rts rts;
-       struct vnt_rrv_time_cts cts;
-       struct vnt_rrv_time_ab ab;
+       struct {
+               struct vnt_rrv_time_rts rts;
+               union vnt_tx tx;
+       } __packed tx_rts;
+       struct {
+               struct vnt_rrv_time_cts cts;
+               union vnt_tx tx;
+       } __packed tx_cts;
+       struct {
+               struct vnt_rrv_time_ab ab;
+               union vnt_tx tx;
+       } __packed tx_ab;
 };
 
 struct vnt_tx_fifo_head {