aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPekka Enberg <penberg@kernel.org>2010-09-19 06:01:03 -0400
committerGreg Kroah-Hartman <gregkh@suse.de>2010-09-21 13:46:03 -0400
commit11c9a55d08d3d79c7a690312966567f70758886a (patch)
tree7988e2306279e0c92ab76190c0c5562f4873bd7f
parent80a284bd154ee3a9d38ee9c264a3a2bf6114385e (diff)
staging: w35und: Inline MLMESendFrame() to wbsoft_tx()
The wbsoft_tx() function is a simple wrapper on top of MLMESendFrame() so inline the latter to the former. Cc: Lars Lindley <lindley@coyote.org> Cc: Pavel Machek <pavel@ucw.cz> Cc: Ruslan Pisarev <ruslan@rpisarev.org.ua> Signed-off-by: Pekka Enberg <penberg@kernel.org> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-rw-r--r--drivers/staging/winbond/mlmetxrx.c25
-rw-r--r--drivers/staging/winbond/mlmetxrx_f.h1
-rw-r--r--drivers/staging/winbond/wbusb.c21
3 files changed, 20 insertions, 27 deletions
diff --git a/drivers/staging/winbond/mlmetxrx.c b/drivers/staging/winbond/mlmetxrx.c
index 6b28898485d..7425a23f12e 100644
--- a/drivers/staging/winbond/mlmetxrx.c
+++ b/drivers/staging/winbond/mlmetxrx.c
@@ -19,31 +19,6 @@
19 19
20#include "mds_f.h" 20#include "mds_f.h"
21 21
22#include <linux/netdevice.h>
23
24int MLMESendFrame(struct wbsoft_priv *adapter, u8 *pMMPDU, u16 len, u8 DataType)
25{
26 if (adapter->sMlmeFrame.IsInUsed != PACKET_FREE_TO_USE) {
27 adapter->sMlmeFrame.wNumTxMMPDUDiscarded++;
28 return NETDEV_TX_BUSY;
29 }
30 adapter->sMlmeFrame.IsInUsed = PACKET_COME_FROM_MLME;
31
32 /* Keep information for sending */
33 adapter->sMlmeFrame.pMMPDU = pMMPDU;
34 adapter->sMlmeFrame.DataType = DataType;
35 /* len must be the last setting due to QUERY_SIZE_SECOND of Mds */
36 adapter->sMlmeFrame.len = len;
37 adapter->sMlmeFrame.wNumTxMMPDU++;
38
39 /* H/W will enter power save by set the register. S/W don't send null frame
40 with PWRMgt bit enbled to enter power save now. */
41
42 Mds_Tx(adapter);
43
44 return NETDEV_TX_OK;
45}
46
47void MLME_GetNextPacket(struct wbsoft_priv *adapter, struct wb35_descriptor *desc) 22void MLME_GetNextPacket(struct wbsoft_priv *adapter, struct wb35_descriptor *desc)
48{ 23{
49 desc->InternalUsed = desc->buffer_start_index + desc->buffer_number; 24 desc->InternalUsed = desc->buffer_start_index + desc->buffer_number;
diff --git a/drivers/staging/winbond/mlmetxrx_f.h b/drivers/staging/winbond/mlmetxrx_f.h
index ddccbc2e1cd..012507fc49e 100644
--- a/drivers/staging/winbond/mlmetxrx_f.h
+++ b/drivers/staging/winbond/mlmetxrx_f.h
@@ -11,7 +11,6 @@
11#include "core.h" 11#include "core.h"
12 12
13void MLME_GetNextPacket(struct wbsoft_priv *adapter, struct wb35_descriptor *pDes); 13void MLME_GetNextPacket(struct wbsoft_priv *adapter, struct wb35_descriptor *pDes);
14int MLMESendFrame(struct wbsoft_priv *adapter, u8 *pMMPDU, u16 len, u8 DataType);
15 14
16void 15void
17MLME_SendComplete(struct wbsoft_priv *adapter, u8 PacketID, 16MLME_SendComplete(struct wbsoft_priv *adapter, u8 PacketID,
diff --git a/drivers/staging/winbond/wbusb.c b/drivers/staging/winbond/wbusb.c
index 157c05bf257..3f60cf7e6ec 100644
--- a/drivers/staging/winbond/wbusb.c
+++ b/drivers/staging/winbond/wbusb.c
@@ -121,7 +121,26 @@ static int wbsoft_tx(struct ieee80211_hw *dev, struct sk_buff *skb)
121{ 121{
122 struct wbsoft_priv *priv = dev->priv; 122 struct wbsoft_priv *priv = dev->priv;
123 123
124 return MLMESendFrame(priv, skb->data, skb->len, FRAME_TYPE_802_11_MANAGEMENT); 124 if (priv->sMlmeFrame.IsInUsed != PACKET_FREE_TO_USE) {
125 priv->sMlmeFrame.wNumTxMMPDUDiscarded++;
126 return NETDEV_TX_BUSY;
127 }
128
129 priv->sMlmeFrame.IsInUsed = PACKET_COME_FROM_MLME;
130
131 priv->sMlmeFrame.pMMPDU = skb->data;
132 priv->sMlmeFrame.DataType = FRAME_TYPE_802_11_MANAGEMENT;
133 priv->sMlmeFrame.len = skb->len;
134 priv->sMlmeFrame.wNumTxMMPDU++;
135
136 /*
137 * H/W will enter power save by set the register. S/W don't send null
138 * frame with PWRMgt bit enbled to enter power save now.
139 */
140
141 Mds_Tx(priv);
142
143 return NETDEV_TX_OK;
125} 144}
126 145
127static int wbsoft_start(struct ieee80211_hw *dev) 146static int wbsoft_start(struct ieee80211_hw *dev)