diff options
Diffstat (limited to 'drivers/net/e1000/e1000_main.c')
-rw-r--r-- | drivers/net/e1000/e1000_main.c | 29 |
1 files changed, 12 insertions, 17 deletions
diff --git a/drivers/net/e1000/e1000_main.c b/drivers/net/e1000/e1000_main.c index ed638d676fcf..7b124840bbcc 100644 --- a/drivers/net/e1000/e1000_main.c +++ b/drivers/net/e1000/e1000_main.c | |||
@@ -1354,31 +1354,27 @@ e1000_sw_init(struct e1000_adapter *adapter) | |||
1354 | static int __devinit | 1354 | static int __devinit |
1355 | e1000_alloc_queues(struct e1000_adapter *adapter) | 1355 | e1000_alloc_queues(struct e1000_adapter *adapter) |
1356 | { | 1356 | { |
1357 | int size; | 1357 | adapter->tx_ring = kcalloc(adapter->num_tx_queues, |
1358 | 1358 | sizeof(struct e1000_tx_ring), GFP_KERNEL); | |
1359 | size = sizeof(struct e1000_tx_ring) * adapter->num_tx_queues; | ||
1360 | adapter->tx_ring = kmalloc(size, GFP_KERNEL); | ||
1361 | if (!adapter->tx_ring) | 1359 | if (!adapter->tx_ring) |
1362 | return -ENOMEM; | 1360 | return -ENOMEM; |
1363 | memset(adapter->tx_ring, 0, size); | ||
1364 | 1361 | ||
1365 | size = sizeof(struct e1000_rx_ring) * adapter->num_rx_queues; | 1362 | adapter->rx_ring = kcalloc(adapter->num_rx_queues, |
1366 | adapter->rx_ring = kmalloc(size, GFP_KERNEL); | 1363 | sizeof(struct e1000_rx_ring), GFP_KERNEL); |
1367 | if (!adapter->rx_ring) { | 1364 | if (!adapter->rx_ring) { |
1368 | kfree(adapter->tx_ring); | 1365 | kfree(adapter->tx_ring); |
1369 | return -ENOMEM; | 1366 | return -ENOMEM; |
1370 | } | 1367 | } |
1371 | memset(adapter->rx_ring, 0, size); | ||
1372 | 1368 | ||
1373 | #ifdef CONFIG_E1000_NAPI | 1369 | #ifdef CONFIG_E1000_NAPI |
1374 | size = sizeof(struct net_device) * adapter->num_rx_queues; | 1370 | adapter->polling_netdev = kcalloc(adapter->num_rx_queues, |
1375 | adapter->polling_netdev = kmalloc(size, GFP_KERNEL); | 1371 | sizeof(struct net_device), |
1372 | GFP_KERNEL); | ||
1376 | if (!adapter->polling_netdev) { | 1373 | if (!adapter->polling_netdev) { |
1377 | kfree(adapter->tx_ring); | 1374 | kfree(adapter->tx_ring); |
1378 | kfree(adapter->rx_ring); | 1375 | kfree(adapter->rx_ring); |
1379 | return -ENOMEM; | 1376 | return -ENOMEM; |
1380 | } | 1377 | } |
1381 | memset(adapter->polling_netdev, 0, size); | ||
1382 | #endif | 1378 | #endif |
1383 | 1379 | ||
1384 | return E1000_SUCCESS; | 1380 | return E1000_SUCCESS; |
@@ -1774,18 +1770,18 @@ e1000_setup_rx_resources(struct e1000_adapter *adapter, | |||
1774 | } | 1770 | } |
1775 | memset(rxdr->buffer_info, 0, size); | 1771 | memset(rxdr->buffer_info, 0, size); |
1776 | 1772 | ||
1777 | size = sizeof(struct e1000_ps_page) * rxdr->count; | 1773 | rxdr->ps_page = kcalloc(rxdr->count, sizeof(struct e1000_ps_page), |
1778 | rxdr->ps_page = kmalloc(size, GFP_KERNEL); | 1774 | GFP_KERNEL); |
1779 | if (!rxdr->ps_page) { | 1775 | if (!rxdr->ps_page) { |
1780 | vfree(rxdr->buffer_info); | 1776 | vfree(rxdr->buffer_info); |
1781 | DPRINTK(PROBE, ERR, | 1777 | DPRINTK(PROBE, ERR, |
1782 | "Unable to allocate memory for the receive descriptor ring\n"); | 1778 | "Unable to allocate memory for the receive descriptor ring\n"); |
1783 | return -ENOMEM; | 1779 | return -ENOMEM; |
1784 | } | 1780 | } |
1785 | memset(rxdr->ps_page, 0, size); | ||
1786 | 1781 | ||
1787 | size = sizeof(struct e1000_ps_page_dma) * rxdr->count; | 1782 | rxdr->ps_page_dma = kcalloc(rxdr->count, |
1788 | rxdr->ps_page_dma = kmalloc(size, GFP_KERNEL); | 1783 | sizeof(struct e1000_ps_page_dma), |
1784 | GFP_KERNEL); | ||
1789 | if (!rxdr->ps_page_dma) { | 1785 | if (!rxdr->ps_page_dma) { |
1790 | vfree(rxdr->buffer_info); | 1786 | vfree(rxdr->buffer_info); |
1791 | kfree(rxdr->ps_page); | 1787 | kfree(rxdr->ps_page); |
@@ -1793,7 +1789,6 @@ e1000_setup_rx_resources(struct e1000_adapter *adapter, | |||
1793 | "Unable to allocate memory for the receive descriptor ring\n"); | 1789 | "Unable to allocate memory for the receive descriptor ring\n"); |
1794 | return -ENOMEM; | 1790 | return -ENOMEM; |
1795 | } | 1791 | } |
1796 | memset(rxdr->ps_page_dma, 0, size); | ||
1797 | 1792 | ||
1798 | if (adapter->hw.mac_type <= e1000_82547_rev_2) | 1793 | if (adapter->hw.mac_type <= e1000_82547_rev_2) |
1799 | desc_len = sizeof(struct e1000_rx_desc); | 1794 | desc_len = sizeof(struct e1000_rx_desc); |