diff options
author | Simon Graham <simon.graham@virtualcomputer.com> | 2012-02-07 19:07:38 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2012-02-08 15:26:34 -0500 |
commit | 7f66c2f93e5779625c10d262c84537427a2673ca (patch) | |
tree | 460b71fcde64d7712751f3e48460f44e911bfc78 /drivers | |
parent | 79027596ff710f9662ccae5f5e85de43961420ed (diff) |
rtlwifi: Handle previous allocation failures when freeing device memory
Handle previous allocation failures when freeing device memory
Signed-off-by: Simon Graham <simon.graham@virtualcomputer.com>
Signed-off-by: Larry Finger <Larry.Finger@lwfinger.net>
Cc: Stable <stable@vger.kernel.org>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/wireless/rtlwifi/pci.c | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/drivers/net/wireless/rtlwifi/pci.c b/drivers/net/wireless/rtlwifi/pci.c index c5f6a322feb2..c503bd3b809e 100644 --- a/drivers/net/wireless/rtlwifi/pci.c +++ b/drivers/net/wireless/rtlwifi/pci.c | |||
@@ -1148,10 +1148,12 @@ static void _rtl_pci_free_tx_ring(struct ieee80211_hw *hw, | |||
1148 | ring->idx = (ring->idx + 1) % ring->entries; | 1148 | ring->idx = (ring->idx + 1) % ring->entries; |
1149 | } | 1149 | } |
1150 | 1150 | ||
1151 | pci_free_consistent(rtlpci->pdev, | 1151 | if (ring->desc) { |
1152 | sizeof(*ring->desc) * ring->entries, | 1152 | pci_free_consistent(rtlpci->pdev, |
1153 | ring->desc, ring->dma); | 1153 | sizeof(*ring->desc) * ring->entries, |
1154 | ring->desc = NULL; | 1154 | ring->desc, ring->dma); |
1155 | ring->desc = NULL; | ||
1156 | } | ||
1155 | } | 1157 | } |
1156 | 1158 | ||
1157 | static void _rtl_pci_free_rx_ring(struct rtl_pci *rtlpci) | 1159 | static void _rtl_pci_free_rx_ring(struct rtl_pci *rtlpci) |
@@ -1175,12 +1177,14 @@ static void _rtl_pci_free_rx_ring(struct rtl_pci *rtlpci) | |||
1175 | kfree_skb(skb); | 1177 | kfree_skb(skb); |
1176 | } | 1178 | } |
1177 | 1179 | ||
1178 | pci_free_consistent(rtlpci->pdev, | 1180 | if (rtlpci->rx_ring[rx_queue_idx].desc) { |
1181 | pci_free_consistent(rtlpci->pdev, | ||
1179 | sizeof(*rtlpci->rx_ring[rx_queue_idx]. | 1182 | sizeof(*rtlpci->rx_ring[rx_queue_idx]. |
1180 | desc) * rtlpci->rxringcount, | 1183 | desc) * rtlpci->rxringcount, |
1181 | rtlpci->rx_ring[rx_queue_idx].desc, | 1184 | rtlpci->rx_ring[rx_queue_idx].desc, |
1182 | rtlpci->rx_ring[rx_queue_idx].dma); | 1185 | rtlpci->rx_ring[rx_queue_idx].dma); |
1183 | rtlpci->rx_ring[rx_queue_idx].desc = NULL; | 1186 | rtlpci->rx_ring[rx_queue_idx].desc = NULL; |
1187 | } | ||
1184 | } | 1188 | } |
1185 | } | 1189 | } |
1186 | 1190 | ||