aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
authorEric Dumazet <eric.dumazet@gmail.com>2010-11-16 22:27:18 -0500
committerJeff Kirsher <jeffrey.t.kirsher@intel.com>2010-11-16 22:27:18 -0500
commite2ddeba95c09d0d44719ff005e915dc06ff46571 (patch)
tree840662eeaec906826885de85b7238afd6c8c1345 /drivers/net
parentb93a22260f6f4bcf6c92c54de8530a97d3e921f0 (diff)
ixgbe: refactor ixgbe_alloc_queues()
I noticed ring variable was initialized before allocations, and that memory node management was a bit ugly. We also leak memory in case of ring allocations error. Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/ixgbe/ixgbe_main.c72
1 files changed, 28 insertions, 44 deletions
diff --git a/drivers/net/ixgbe/ixgbe_main.c b/drivers/net/ixgbe/ixgbe_main.c
index b859a298cd2a..5409af3da06c 100644
--- a/drivers/net/ixgbe/ixgbe_main.c
+++ b/drivers/net/ixgbe/ixgbe_main.c
@@ -4676,71 +4676,55 @@ static void ixgbe_cache_ring_register(struct ixgbe_adapter *adapter)
4676 **/ 4676 **/
4677static int ixgbe_alloc_queues(struct ixgbe_adapter *adapter) 4677static int ixgbe_alloc_queues(struct ixgbe_adapter *adapter)
4678{ 4678{
4679 int i; 4679 int rx = 0, tx = 0, nid = adapter->node;
4680 int rx_count;
4681 int orig_node = adapter->node;
4682 4680
4683 for (i = 0; i < adapter->num_tx_queues; i++) { 4681 if (nid < 0 || !node_online(nid))
4684 struct ixgbe_ring *ring = adapter->tx_ring[i]; 4682 nid = first_online_node;
4685 if (orig_node == -1) { 4683
4686 int cur_node = next_online_node(adapter->node); 4684 for (; tx < adapter->num_tx_queues; tx++) {
4687 if (cur_node == MAX_NUMNODES) 4685 struct ixgbe_ring *ring;
4688 cur_node = first_online_node; 4686
4689 adapter->node = cur_node; 4687 ring = kzalloc_node(sizeof(*ring), GFP_KERNEL, nid);
4690 }
4691 ring = kzalloc_node(sizeof(struct ixgbe_ring), GFP_KERNEL,
4692 adapter->node);
4693 if (!ring) 4688 if (!ring)
4694 ring = kzalloc(sizeof(struct ixgbe_ring), GFP_KERNEL); 4689 ring = kzalloc(sizeof(*ring), GFP_KERNEL);
4695 if (!ring) 4690 if (!ring)
4696 goto err_tx_ring_allocation; 4691 goto err_allocation;
4697 ring->count = adapter->tx_ring_count; 4692 ring->count = adapter->tx_ring_count;
4698 ring->queue_index = i; 4693 ring->queue_index = tx;
4694 ring->numa_node = nid;
4699 ring->dev = &adapter->pdev->dev; 4695 ring->dev = &adapter->pdev->dev;
4700 ring->netdev = adapter->netdev; 4696 ring->netdev = adapter->netdev;
4701 ring->numa_node = adapter->node;
4702 4697
4703 adapter->tx_ring[i] = ring; 4698 adapter->tx_ring[tx] = ring;
4704 } 4699 }
4705 4700
4706 /* Restore the adapter's original node */ 4701 for (; rx < adapter->num_rx_queues; rx++) {
4707 adapter->node = orig_node; 4702 struct ixgbe_ring *ring;
4708 4703
4709 rx_count = adapter->rx_ring_count; 4704 ring = kzalloc_node(sizeof(*ring), GFP_KERNEL, nid);
4710 for (i = 0; i < adapter->num_rx_queues; i++) {
4711 struct ixgbe_ring *ring = adapter->rx_ring[i];
4712 if (orig_node == -1) {
4713 int cur_node = next_online_node(adapter->node);
4714 if (cur_node == MAX_NUMNODES)
4715 cur_node = first_online_node;
4716 adapter->node = cur_node;
4717 }
4718 ring = kzalloc_node(sizeof(struct ixgbe_ring), GFP_KERNEL,
4719 adapter->node);
4720 if (!ring) 4705 if (!ring)
4721 ring = kzalloc(sizeof(struct ixgbe_ring), GFP_KERNEL); 4706 ring = kzalloc(sizeof(*ring), GFP_KERNEL);
4722 if (!ring) 4707 if (!ring)
4723 goto err_rx_ring_allocation; 4708 goto err_allocation;
4724 ring->count = rx_count; 4709 ring->count = adapter->rx_ring_count;
4725 ring->queue_index = i; 4710 ring->queue_index = rx;
4711 ring->numa_node = nid;
4726 ring->dev = &adapter->pdev->dev; 4712 ring->dev = &adapter->pdev->dev;
4727 ring->netdev = adapter->netdev; 4713 ring->netdev = adapter->netdev;
4728 ring->numa_node = adapter->node;
4729 4714
4730 adapter->rx_ring[i] = ring; 4715 adapter->rx_ring[rx] = ring;
4731 } 4716 }
4732 4717
4733 /* Restore the adapter's original node */
4734 adapter->node = orig_node;
4735
4736 ixgbe_cache_ring_register(adapter); 4718 ixgbe_cache_ring_register(adapter);
4737 4719
4738 return 0; 4720 return 0;
4739 4721
4740err_rx_ring_allocation: 4722err_allocation:
4741 for (i = 0; i < adapter->num_tx_queues; i++) 4723 while (tx)
4742 kfree(adapter->tx_ring[i]); 4724 kfree(adapter->tx_ring[--tx]);
4743err_tx_ring_allocation: 4725
4726 while (rx)
4727 kfree(adapter->rx_ring[--rx]);
4744 return -ENOMEM; 4728 return -ENOMEM;
4745} 4729}
4746 4730