Commit 26190d41 authored by Arnd Bergmann's avatar Arnd Bergmann Committed by Greg Kroah-Hartman

staging: rtl8192u: move stats_IndicateArray off stack

Putting 128 pointers on the stack is rather wasteful, in particular
on 64-bit architectures:

drivers/staging/rtl8192u/ieee80211/rtl819x_TSProc.c: In function 'RxPktPendingTimeout':
drivers/staging/rtl8192u/ieee80211/rtl819x_TSProc.c:92:1: warning: the frame size of 1072 bytes is larger than 1024 bytes [-Wframe-larger-than=]

The rtl8192e driver has the exact same function, except that stores the
array in its 'ieee' structure. Let's do it the same way here for consistency.
Signed-off-by: default avatarArnd Bergmann <arnd@arndb.de>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 15665008
...@@ -1894,6 +1894,7 @@ struct ieee80211_device { ...@@ -1894,6 +1894,7 @@ struct ieee80211_device {
//u32 STA_EDCA_PARAM[4]; //u32 STA_EDCA_PARAM[4];
//CHANNEL_ACCESS_SETTING ChannelAccessSetting; //CHANNEL_ACCESS_SETTING ChannelAccessSetting;
struct ieee80211_rxb *stats_IndicateArray[REORDER_WIN_SIZE];
/* Callback functions */ /* Callback functions */
void (*set_security)(struct net_device *dev, void (*set_security)(struct net_device *dev,
......
...@@ -31,7 +31,6 @@ static void RxPktPendingTimeout(unsigned long data) ...@@ -31,7 +31,6 @@ static void RxPktPendingTimeout(unsigned long data)
//u32 flags = 0; //u32 flags = 0;
unsigned long flags = 0; unsigned long flags = 0;
struct ieee80211_rxb *stats_IndicateArray[REORDER_WIN_SIZE];
u8 index = 0; u8 index = 0;
bool bPktInBuf = false; bool bPktInBuf = false;
...@@ -55,7 +54,7 @@ static void RxPktPendingTimeout(unsigned long data) ...@@ -55,7 +54,7 @@ static void RxPktPendingTimeout(unsigned long data)
pRxTs->RxIndicateSeq = (pRxTs->RxIndicateSeq + 1) % 4096; pRxTs->RxIndicateSeq = (pRxTs->RxIndicateSeq + 1) % 4096;
IEEE80211_DEBUG(IEEE80211_DL_REORDER,"RxPktPendingTimeout(): IndicateSeq: %d\n", pReorderEntry->SeqNum); IEEE80211_DEBUG(IEEE80211_DL_REORDER,"RxPktPendingTimeout(): IndicateSeq: %d\n", pReorderEntry->SeqNum);
stats_IndicateArray[index] = pReorderEntry->prxb; ieee->stats_IndicateArray[index] = pReorderEntry->prxb;
index++; index++;
list_add_tail(&pReorderEntry->List, &ieee->RxReorder_Unused_List); list_add_tail(&pReorderEntry->List, &ieee->RxReorder_Unused_List);
...@@ -79,7 +78,7 @@ static void RxPktPendingTimeout(unsigned long data) ...@@ -79,7 +78,7 @@ static void RxPktPendingTimeout(unsigned long data)
spin_unlock_irqrestore(&(ieee->reorder_spinlock), flags); spin_unlock_irqrestore(&(ieee->reorder_spinlock), flags);
return; return;
} }
ieee80211_indicate_packets(ieee, stats_IndicateArray, index); ieee80211_indicate_packets(ieee, ieee->stats_IndicateArray, index);
} }
if(bPktInBuf && (pRxTs->RxTimeoutIndicateSeq==0xffff)) if(bPktInBuf && (pRxTs->RxTimeoutIndicateSeq==0xffff))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment