Commit 7f66c2f9 authored by Simon Graham's avatar Simon Graham Committed by John W. Linville

rtlwifi: Handle previous allocation failures when freeing device memory

Handle previous allocation failures when freeing device memory
Signed-off-by: default avatarSimon Graham <simon.graham@virtualcomputer.com>
Signed-off-by: default avatarLarry Finger <Larry.Finger@lwfinger.net>
Cc: Stable <stable@vger.kernel.org>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 79027596
...@@ -1148,10 +1148,12 @@ static void _rtl_pci_free_tx_ring(struct ieee80211_hw *hw, ...@@ -1148,10 +1148,12 @@ static void _rtl_pci_free_tx_ring(struct ieee80211_hw *hw,
ring->idx = (ring->idx + 1) % ring->entries; ring->idx = (ring->idx + 1) % ring->entries;
} }
pci_free_consistent(rtlpci->pdev, if (ring->desc) {
sizeof(*ring->desc) * ring->entries, pci_free_consistent(rtlpci->pdev,
ring->desc, ring->dma); sizeof(*ring->desc) * ring->entries,
ring->desc = NULL; ring->desc, ring->dma);
ring->desc = NULL;
}
} }
static void _rtl_pci_free_rx_ring(struct rtl_pci *rtlpci) 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,12 +1177,14 @@ static void _rtl_pci_free_rx_ring(struct rtl_pci *rtlpci)
kfree_skb(skb); kfree_skb(skb);
} }
pci_free_consistent(rtlpci->pdev, if (rtlpci->rx_ring[rx_queue_idx].desc) {
pci_free_consistent(rtlpci->pdev,
sizeof(*rtlpci->rx_ring[rx_queue_idx]. sizeof(*rtlpci->rx_ring[rx_queue_idx].
desc) * rtlpci->rxringcount, desc) * rtlpci->rxringcount,
rtlpci->rx_ring[rx_queue_idx].desc, rtlpci->rx_ring[rx_queue_idx].desc,
rtlpci->rx_ring[rx_queue_idx].dma); rtlpci->rx_ring[rx_queue_idx].dma);
rtlpci->rx_ring[rx_queue_idx].desc = NULL; rtlpci->rx_ring[rx_queue_idx].desc = NULL;
}
} }
} }
......
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