diff options
author | Christoph Fritz <chf.fritz@googlemail.com> | 2011-05-08 16:50:09 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2011-05-10 15:54:50 -0400 |
commit | b53575ecf939a4f752de87eabf1adbcfa4478a6c (patch) | |
tree | 0e98918a3602d0abd1ff6bcc5dea9cef0763c99d /drivers/net/wireless/mwifiex/11n_aggr.c | |
parent | 3ed3f49473985718ce51f84d990ed5b8b6472598 (diff) |
mwifiex: fix null derefs, mem leaks and trivia
This patch:
- adds kfree() where necessary
- prevents potential null dereferences
- makes use of kfree_skb()
- replaces -1 for failed kzallocs with -ENOMEM
Signed-off-by: Christoph Fritz <chf.fritz@googlemail.com>
Reviewed-by: Kiran Divekar <dkiran@marvell.com>
Tested-by: Amitkumar Karwar <akarwar@marvell.com>
Acked-by: Bing Zhao <bzhao@marvell.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/mwifiex/11n_aggr.c')
-rw-r--r-- | drivers/net/wireless/mwifiex/11n_aggr.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/drivers/net/wireless/mwifiex/11n_aggr.c b/drivers/net/wireless/mwifiex/11n_aggr.c index 12cf4246f96b..2b2cca5e6d0f 100644 --- a/drivers/net/wireless/mwifiex/11n_aggr.c +++ b/drivers/net/wireless/mwifiex/11n_aggr.c | |||
@@ -318,7 +318,8 @@ mwifiex_11n_aggregate_pkt(struct mwifiex_private *priv, | |||
318 | else | 318 | else |
319 | skb_src = NULL; | 319 | skb_src = NULL; |
320 | 320 | ||
321 | pra_list->total_pkts_size -= skb_src->len; | 321 | if (skb_src) |
322 | pra_list->total_pkts_size -= skb_src->len; | ||
322 | 323 | ||
323 | spin_unlock_irqrestore(&priv->wmm.ra_list_spinlock, | 324 | spin_unlock_irqrestore(&priv->wmm.ra_list_spinlock, |
324 | ra_list_flags); | 325 | ra_list_flags); |
@@ -373,7 +374,8 @@ mwifiex_11n_aggregate_pkt(struct mwifiex_private *priv, | |||
373 | (adapter->pps_uapsd_mode) && | 374 | (adapter->pps_uapsd_mode) && |
374 | (adapter->tx_lock_flag)) { | 375 | (adapter->tx_lock_flag)) { |
375 | priv->adapter->tx_lock_flag = false; | 376 | priv->adapter->tx_lock_flag = false; |
376 | ptx_pd->flags = 0; | 377 | if (ptx_pd) |
378 | ptx_pd->flags = 0; | ||
377 | } | 379 | } |
378 | 380 | ||
379 | skb_queue_tail(&pra_list->skb_head, skb_aggr); | 381 | skb_queue_tail(&pra_list->skb_head, skb_aggr); |