提交 61d7f75f 编写于 作者: R Richard Cochran 提交者: Jeff Kirsher

igb: refactor time sync interrupt handling

The code that handles the time sync interrupt is repeated in three
different places. This patch refactors the identical code blocks into
a single helper function.
Signed-off-by: NRichard Cochran <richardcochran@gmail.com>
Tested-by: NAaron Brown <aaron.f.brown@intel.com>
Signed-off-by: NJeff Kirsher <jeffrey.t.kirsher@intel.com>
上级 ba5b8dcd
...@@ -5384,6 +5384,19 @@ void igb_update_stats(struct igb_adapter *adapter, ...@@ -5384,6 +5384,19 @@ void igb_update_stats(struct igb_adapter *adapter,
} }
} }
static void igb_tsync_interrupt(struct igb_adapter *adapter)
{
struct e1000_hw *hw = &adapter->hw;
u32 tsicr = rd32(E1000_TSICR);
if (tsicr & E1000_TSICR_TXTS) {
/* acknowledge the interrupt */
wr32(E1000_TSICR, E1000_TSICR_TXTS);
/* retrieve hardware timestamp */
schedule_work(&adapter->ptp_tx_work);
}
}
static irqreturn_t igb_msix_other(int irq, void *data) static irqreturn_t igb_msix_other(int irq, void *data)
{ {
struct igb_adapter *adapter = data; struct igb_adapter *adapter = data;
...@@ -5415,16 +5428,8 @@ static irqreturn_t igb_msix_other(int irq, void *data) ...@@ -5415,16 +5428,8 @@ static irqreturn_t igb_msix_other(int irq, void *data)
mod_timer(&adapter->watchdog_timer, jiffies + 1); mod_timer(&adapter->watchdog_timer, jiffies + 1);
} }
if (icr & E1000_ICR_TS) { if (icr & E1000_ICR_TS)
u32 tsicr = rd32(E1000_TSICR); igb_tsync_interrupt(adapter);
if (tsicr & E1000_TSICR_TXTS) {
/* acknowledge the interrupt */
wr32(E1000_TSICR, E1000_TSICR_TXTS);
/* retrieve hardware timestamp */
schedule_work(&adapter->ptp_tx_work);
}
}
wr32(E1000_EIMS, adapter->eims_other); wr32(E1000_EIMS, adapter->eims_other);
...@@ -6203,16 +6208,8 @@ static irqreturn_t igb_intr_msi(int irq, void *data) ...@@ -6203,16 +6208,8 @@ static irqreturn_t igb_intr_msi(int irq, void *data)
mod_timer(&adapter->watchdog_timer, jiffies + 1); mod_timer(&adapter->watchdog_timer, jiffies + 1);
} }
if (icr & E1000_ICR_TS) { if (icr & E1000_ICR_TS)
u32 tsicr = rd32(E1000_TSICR); igb_tsync_interrupt(adapter);
if (tsicr & E1000_TSICR_TXTS) {
/* acknowledge the interrupt */
wr32(E1000_TSICR, E1000_TSICR_TXTS);
/* retrieve hardware timestamp */
schedule_work(&adapter->ptp_tx_work);
}
}
napi_schedule(&q_vector->napi); napi_schedule(&q_vector->napi);
...@@ -6257,16 +6254,8 @@ static irqreturn_t igb_intr(int irq, void *data) ...@@ -6257,16 +6254,8 @@ static irqreturn_t igb_intr(int irq, void *data)
mod_timer(&adapter->watchdog_timer, jiffies + 1); mod_timer(&adapter->watchdog_timer, jiffies + 1);
} }
if (icr & E1000_ICR_TS) { if (icr & E1000_ICR_TS)
u32 tsicr = rd32(E1000_TSICR); igb_tsync_interrupt(adapter);
if (tsicr & E1000_TSICR_TXTS) {
/* acknowledge the interrupt */
wr32(E1000_TSICR, E1000_TSICR_TXTS);
/* retrieve hardware timestamp */
schedule_work(&adapter->ptp_tx_work);
}
}
napi_schedule(&q_vector->napi); napi_schedule(&q_vector->napi);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册