Refactor the TX code to prepare for aggregation.

Signed-off-by: Ali Bahar <[email protected]>
Signed-off-by: Larry Finger <[email protected]>
---
 drivers/staging/rtl8712/rtl8712_xmit.c |   48 ++++++++++++++++----------------
 drivers/staging/rtl8712/rtl871x_xmit.c |   17 +++++++++--
 drivers/staging/rtl8712/rtl871x_xmit.h |    5 +++
 3 files changed, 43 insertions(+), 27 deletions(-)

diff --git a/drivers/staging/rtl8712/rtl8712_xmit.c 
b/drivers/staging/rtl8712/rtl8712_xmit.c
index 88a1504..c1e4784 100644
--- a/drivers/staging/rtl8712/rtl8712_xmit.c
+++ b/drivers/staging/rtl8712/rtl8712_xmit.c
@@ -423,31 +423,31 @@ int r8712_xmitframe_complete(struct _adapter *padapter,
                if (!pxmitbuf)
                        return false;
        }
-       do {
-               pxmitframe = dequeue_xframe_ex(pxmitpriv, phwxmits, hwentry);
-               if (pxmitframe) {
-                       pxmitframe->pxmitbuf = pxmitbuf;
-                       pxmitframe->pxmit_urb[0] = pxmitbuf->pxmit_urb[0];
-                       pxmitframe->buf_addr = pxmitbuf->pbuf;
-                       if (pxmitframe->frame_tag == DATA_FRAMETAG) {
-                               if (pxmitframe->attrib.priority <= 15)
-                                       res = r8712_xmitframe_coalesce(padapter,
-                                             pxmitframe->pkt, pxmitframe);
-                               /* always return ndis_packet after
-                                *  r8712_xmitframe_coalesce */
-                               r8712_xmit_complete(padapter, pxmitframe);
-                       }
-                       if (res == _SUCCESS)
-                               dump_xframe(padapter, pxmitframe);
-                       else
-                               r8712_free_xmitframe_ex(pxmitpriv, pxmitframe);
-                       xcnt++;
-               } else {
-                       r8712_free_xmitbuf(pxmitpriv, pxmitbuf);
-                       return false;
+       /* 1st frame dequeued */
+       pxmitframe = dequeue_xframe_ex(pxmitpriv, phwxmits, hwentry);
+       /* need to remember the 1st frame */
+       if (pxmitframe != NULL) {
+
+
+               xmitframe_xmitbuf_attach(pxmitframe, pxmitbuf);
+               if (pxmitframe->frame_tag == DATA_FRAMETAG) {
+                       if (pxmitframe->attrib.priority <= 15)
+                               res = r8712_xmitframe_coalesce(padapter,
+                                       pxmitframe->pkt, pxmitframe);
+                       /* always return ndis_packet after
+                        * r8712_xmitframe_coalesce */
+                       r8712_xmit_complete(padapter, pxmitframe);
                }
-               break;
-       } while (0);
+               if (res == _SUCCESS)
+                       dump_xframe(padapter, pxmitframe);
+               else
+                       r8712_free_xmitframe_ex(pxmitpriv, pxmitframe);
+               xcnt++;
+
+       } else { /* pxmitframe == NULL && p2ndxmitframe == NULL */
+               r8712_free_xmitbuf(pxmitpriv, pxmitbuf);
+               return false;
+       }
        return true;
 }
 
diff --git a/drivers/staging/rtl8712/rtl871x_xmit.c 
b/drivers/staging/rtl8712/rtl871x_xmit.c
index ccf0891..073493b 100644
--- a/drivers/staging/rtl8712/rtl871x_xmit.c
+++ b/drivers/staging/rtl8712/rtl871x_xmit.c
@@ -1011,6 +1011,19 @@ static void init_hwxmits(struct hw_xmit *phwxmit, sint 
entry)
        }
 }
 
+void xmitframe_xmitbuf_attach(struct xmit_frame *pxmitframe,
+                       struct xmit_buf *pxmitbuf)
+{
+       /* pxmitbuf attach to pxmitframe */
+       pxmitframe->pxmitbuf = pxmitbuf;
+       /* urb and irp connection */
+       pxmitframe->pxmit_urb[0] = pxmitbuf->pxmit_urb[0];
+       /* buffer addr assoc */
+       pxmitframe->buf_addr = pxmitbuf->pbuf;
+       /* pxmitframe attach to pxmitbuf */
+       pxmitbuf->priv_data = pxmitframe;
+}
+
 /*
  * tx_action == 0 == no frames to transmit
  * tx_action > 0 ==> we have frames to transmit
@@ -1042,9 +1055,7 @@ int r8712_pre_xmit(struct _adapter *padapter, struct 
xmit_frame *pxmitframe)
        } else { /*dump packet directly*/
                spin_unlock_irqrestore(&pxmitpriv->lock, irqL);
                ret = true;
-               pxmitframe->pxmitbuf = pxmitbuf;
-               pxmitframe->pxmit_urb[0] = pxmitbuf->pxmit_urb[0];
-               pxmitframe->buf_addr = pxmitbuf->pbuf;
+               xmitframe_xmitbuf_attach(pxmitframe, pxmitbuf);
                r8712_xmit_direct(padapter, pxmitframe);
        }
        return ret;
diff --git a/drivers/staging/rtl8712/rtl871x_xmit.h 
b/drivers/staging/rtl8712/rtl871x_xmit.h
index 6304100..8198778 100644
--- a/drivers/staging/rtl8712/rtl871x_xmit.h
+++ b/drivers/staging/rtl8712/rtl871x_xmit.h
@@ -135,7 +135,9 @@ struct xmit_buf {
 
        u8 *pallocated_buf;
        u8 *pbuf;
+       void *priv_data;
        struct urb *pxmit_urb[8];
+       u32 aggr_nr;
 };
 
 struct xmit_frame {
@@ -280,6 +282,9 @@ int r8712_xmit_enqueue(struct _adapter *padapter,
 int r8712_xmit_direct(struct _adapter *padapter, struct xmit_frame 
*pxmitframe);
 void r8712_xmit_bh(void *priv);
 
+void xmitframe_xmitbuf_attach(struct xmit_frame *pxmitframe,
+                       struct xmit_buf *pxmitbuf);
+
 #include "rtl8712_xmit.h"
 
 #endif /*_RTL871X_XMIT_H_*/
-- 
1.7.6

_______________________________________________
devel mailing list
[email protected]
http://driverdev.linuxdriverproject.org/mailman/listinfo/devel

Reply via email to