Commit 0d1ae7f4 authored by Alexander Duyck's avatar Alexander Duyck Committed by Jeff Kirsher

igb: avoid unnecessarily creating a local copy of the q_vector

This is mostly a drop of unnecessary pointer defines for q_vector when we
don't have issues with line width and don't have multiple references to
the pointer.
Signed-off-by: default avatarAlexander Duyck <alexander.h.duyck@intel.com>
Tested-by: default avatarAaron Brown  <aaron.f.brown@intel.com>
Signed-off-by: default avatarJeff Kirsher <jeffrey.t.kirsher@intel.com>
parent 15d447ec
...@@ -1317,11 +1317,9 @@ static void igb_free_irq(struct igb_adapter *adapter) ...@@ -1317,11 +1317,9 @@ static void igb_free_irq(struct igb_adapter *adapter)
free_irq(adapter->msix_entries[vector++].vector, adapter); free_irq(adapter->msix_entries[vector++].vector, adapter);
for (i = 0; i < adapter->num_q_vectors; i++) { for (i = 0; i < adapter->num_q_vectors; i++)
struct igb_q_vector *q_vector = adapter->q_vector[i];
free_irq(adapter->msix_entries[vector++].vector, free_irq(adapter->msix_entries[vector++].vector,
q_vector); adapter->q_vector[i]);
}
} else { } else {
free_irq(adapter->pdev->irq, adapter); free_irq(adapter->pdev->irq, adapter);
} }
...@@ -1523,10 +1521,9 @@ int igb_up(struct igb_adapter *adapter) ...@@ -1523,10 +1521,9 @@ int igb_up(struct igb_adapter *adapter)
clear_bit(__IGB_DOWN, &adapter->state); clear_bit(__IGB_DOWN, &adapter->state);
for (i = 0; i < adapter->num_q_vectors; i++) { for (i = 0; i < adapter->num_q_vectors; i++)
struct igb_q_vector *q_vector = adapter->q_vector[i]; napi_enable(&(adapter->q_vector[i]->napi));
napi_enable(&q_vector->napi);
}
if (adapter->msix_entries) if (adapter->msix_entries)
igb_configure_msix(adapter); igb_configure_msix(adapter);
else else
...@@ -1578,10 +1575,8 @@ void igb_down(struct igb_adapter *adapter) ...@@ -1578,10 +1575,8 @@ void igb_down(struct igb_adapter *adapter)
wrfl(); wrfl();
msleep(10); msleep(10);
for (i = 0; i < adapter->num_q_vectors; i++) { for (i = 0; i < adapter->num_q_vectors; i++)
struct igb_q_vector *q_vector = adapter->q_vector[i]; napi_disable(&(adapter->q_vector[i]->napi));
napi_disable(&q_vector->napi);
}
igb_irq_disable(adapter); igb_irq_disable(adapter);
...@@ -2546,10 +2541,8 @@ static int igb_open(struct net_device *netdev) ...@@ -2546,10 +2541,8 @@ static int igb_open(struct net_device *netdev)
/* From here on the code is the same as igb_up() */ /* From here on the code is the same as igb_up() */
clear_bit(__IGB_DOWN, &adapter->state); clear_bit(__IGB_DOWN, &adapter->state);
for (i = 0; i < adapter->num_q_vectors; i++) { for (i = 0; i < adapter->num_q_vectors; i++)
struct igb_q_vector *q_vector = adapter->q_vector[i]; napi_enable(&(adapter->q_vector[i]->napi));
napi_enable(&q_vector->napi);
}
/* Clear any pending interrupts. */ /* Clear any pending interrupts. */
rd32(E1000_ICR); rd32(E1000_ICR);
...@@ -3769,10 +3762,8 @@ static void igb_watchdog_task(struct work_struct *work) ...@@ -3769,10 +3762,8 @@ static void igb_watchdog_task(struct work_struct *work)
/* Cause software interrupt to ensure rx ring is cleaned */ /* Cause software interrupt to ensure rx ring is cleaned */
if (adapter->msix_entries) { if (adapter->msix_entries) {
u32 eics = 0; u32 eics = 0;
for (i = 0; i < adapter->num_q_vectors; i++) { for (i = 0; i < adapter->num_q_vectors; i++)
struct igb_q_vector *q_vector = adapter->q_vector[i]; eics |= adapter->q_vector[i]->eims_value;
eics |= q_vector->eims_value;
}
wr32(E1000_EICS, eics); wr32(E1000_EICS, eics);
} else { } else {
wr32(E1000_ICS, E1000_ICS_RXDMT0); wr32(E1000_ICS, E1000_ICS_RXDMT0);
...@@ -6671,18 +6662,15 @@ static void igb_netpoll(struct net_device *netdev) ...@@ -6671,18 +6662,15 @@ static void igb_netpoll(struct net_device *netdev)
{ {
struct igb_adapter *adapter = netdev_priv(netdev); struct igb_adapter *adapter = netdev_priv(netdev);
struct e1000_hw *hw = &adapter->hw; struct e1000_hw *hw = &adapter->hw;
struct igb_q_vector *q_vector;
int i; int i;
if (!adapter->msix_entries) {
struct igb_q_vector *q_vector = adapter->q_vector[0];
igb_irq_disable(adapter);
napi_schedule(&q_vector->napi);
return;
}
for (i = 0; i < adapter->num_q_vectors; i++) { for (i = 0; i < adapter->num_q_vectors; i++) {
struct igb_q_vector *q_vector = adapter->q_vector[i]; q_vector = adapter->q_vector[i];
if (adapter->msix_entries)
wr32(E1000_EIMC, q_vector->eims_value); wr32(E1000_EIMC, q_vector->eims_value);
else
igb_irq_disable(adapter);
napi_schedule(&q_vector->napi); napi_schedule(&q_vector->napi);
} }
} }
......
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