* [PATCH] net/ixgbe: don't create a delayed interrupt handler if one already exists [not found] <CANDF9xC+4yBVxX8sgXzM0EdYcQFhzonG8FnnTQ1trSDxAkvAaQ@mail.gmail.com> @ 2024-04-18 13:53 ` edwin.brossette 2024-05-16 11:41 ` Burakov, Anatoly 0 siblings, 1 reply; 3+ messages in thread From: edwin.brossette @ 2024-04-18 13:53 UTC (permalink / raw) To: dev; +Cc: olivier.matz, Edwin Brossette, stable From: Edwin Brossette <edwin.brossette@6wind.com> Since link state may need some time to stabilize after a link state change, we cannot update the link state right after one occurs. So link state change interrupts (lsc) are handled after a delay. To do this, an alarm to call a delayed handler is programmed. This delayed handler is tasked with updating the link after a variable delay of one to four seconds which should be enough time for the link state to become stable again. However, a problem can occur with some models of network cards. For example, ixgbe_mac_X550EM_x may trigger this interrupt twice because another interrupt signal is received on the General Purpose Interrupt pin SPD0, which has the same interrupt handler. In such a case, the delayed interrupt handler would be programmed to be executed twice. Since we save the original interrupt mask value to restore it after the delayed handler is done with its work, we end up overwritting its value after the second alarm is programmed. Even worse: when restoring it the first time, the saved original mask variable is reset to 0, so we end up completely disabling all interrupts when trying to restore this mask after the second time the delayed handler is executed. Add a check on the interrupt mask value when programming the alarm for the delayed handler. If the bit for lsc interrupts is unset, it means an alarm was already programmed for the delayed handler. In this case, skip the alarm creation. Fixes: 9b667210700e ("net/ixgbe: fix blocked interrupts") Cc: stable@dpdk.org Signed-off-by: Edwin Brossette <edwin.brossette@6wind.com> --- drivers/net/ixgbe/ixgbe_ethdev.c | 22 ++++++++++++++-------- 1 file changed, 14 insertions(+), 8 deletions(-) diff --git a/drivers/net/ixgbe/ixgbe_ethdev.c b/drivers/net/ixgbe/ixgbe_ethdev.c index c61c52b2966b..52cafcbc965f 100644 --- a/drivers/net/ixgbe/ixgbe_ethdev.c +++ b/drivers/net/ixgbe/ixgbe_ethdev.c @@ -4667,14 +4667,20 @@ ixgbe_dev_interrupt_action(struct rte_eth_dev *dev) timeout = IXGBE_LINK_DOWN_CHECK_TIMEOUT; ixgbe_dev_link_status_print(dev); - if (rte_eal_alarm_set(timeout * 1000, - ixgbe_dev_interrupt_delayed_handler, (void *)dev) < 0) - PMD_DRV_LOG(ERR, "Error setting alarm"); - else { - /* remember original mask */ - intr->mask_original = intr->mask; - /* only disable lsc interrupt */ - intr->mask &= ~IXGBE_EIMS_LSC; + + /* Don't program delayed handler if LSC interrupt is disabled. + * It means one is already programmed. + */ + if (intr->mask & IXGBE_EIMS_LSC){ + if (rte_eal_alarm_set(timeout * 1000, + ixgbe_dev_interrupt_delayed_handler, (void *)dev) < 0) + PMD_DRV_LOG(ERR, "Error setting alarm"); + else { + /* remember original mask */ + intr->mask_original = intr->mask; + /* only disable lsc interrupt */ + intr->mask &= ~IXGBE_EIMS_LSC; + } } } -- 2.35.0.4.g44a5d4affccf ^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH] net/ixgbe: don't create a delayed interrupt handler if one already exists 2024-04-18 13:53 ` [PATCH] net/ixgbe: don't create a delayed interrupt handler if one already exists edwin.brossette @ 2024-05-16 11:41 ` Burakov, Anatoly 2024-05-21 14:50 ` Bruce Richardson 0 siblings, 1 reply; 3+ messages in thread From: Burakov, Anatoly @ 2024-05-16 11:41 UTC (permalink / raw) To: edwin.brossette, dev; +Cc: olivier.matz, stable On 4/18/2024 3:53 PM, edwin.brossette@6wind.com wrote: > From: Edwin Brossette <edwin.brossette@6wind.com> > > Since link state may need some time to stabilize after a link state > change, we cannot update the link state right after one occurs. So link > state change interrupts (lsc) are handled after a delay. To do this, an > alarm to call a delayed handler is programmed. This delayed handler is > tasked with updating the link after a variable delay of one to four > seconds which should be enough time for the link state to become stable > again. > > However, a problem can occur with some models of network cards. For > example, ixgbe_mac_X550EM_x may trigger this interrupt twice because > another interrupt signal is received on the General Purpose Interrupt > pin SPD0, which has the same interrupt handler. In such a case, the > delayed interrupt handler would be programmed to be executed twice. > > Since we save the original interrupt mask value to restore it after the > delayed handler is done with its work, we end up overwritting its value > after the second alarm is programmed. Even worse: when restoring it the > first time, the saved original mask variable is reset to 0, so we end up > completely disabling all interrupts when trying to restore this mask > after the second time the delayed handler is executed. > > Add a check on the interrupt mask value when programming the alarm for > the delayed handler. If the bit for lsc interrupts is unset, it means an > alarm was already programmed for the delayed handler. In this case, skip > the alarm creation. > > Fixes: 9b667210700e ("net/ixgbe: fix blocked interrupts") > Cc: stable@dpdk.org > > Signed-off-by: Edwin Brossette <edwin.brossette@6wind.com> > --- Reviewed-by: Anatoly Burakov <anatoly.burakov@intel.com> -- Thanks, Anatoly ^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH] net/ixgbe: don't create a delayed interrupt handler if one already exists 2024-05-16 11:41 ` Burakov, Anatoly @ 2024-05-21 14:50 ` Bruce Richardson 0 siblings, 0 replies; 3+ messages in thread From: Bruce Richardson @ 2024-05-21 14:50 UTC (permalink / raw) To: Burakov, Anatoly; +Cc: edwin.brossette, dev, olivier.matz, stable On Thu, May 16, 2024 at 01:41:22PM +0200, Burakov, Anatoly wrote: > On 4/18/2024 3:53 PM, edwin.brossette@6wind.com wrote: > > From: Edwin Brossette <edwin.brossette@6wind.com> > > > > Since link state may need some time to stabilize after a link state > > change, we cannot update the link state right after one occurs. So link > > state change interrupts (lsc) are handled after a delay. To do this, an > > alarm to call a delayed handler is programmed. This delayed handler is > > tasked with updating the link after a variable delay of one to four > > seconds which should be enough time for the link state to become stable > > again. > > > > However, a problem can occur with some models of network cards. For > > example, ixgbe_mac_X550EM_x may trigger this interrupt twice because > > another interrupt signal is received on the General Purpose Interrupt > > pin SPD0, which has the same interrupt handler. In such a case, the > > delayed interrupt handler would be programmed to be executed twice. > > > > Since we save the original interrupt mask value to restore it after the > > delayed handler is done with its work, we end up overwritting its value > > after the second alarm is programmed. Even worse: when restoring it the > > first time, the saved original mask variable is reset to 0, so we end up > > completely disabling all interrupts when trying to restore this mask > > after the second time the delayed handler is executed. > > > > Add a check on the interrupt mask value when programming the alarm for > > the delayed handler. If the bit for lsc interrupts is unset, it means an > > alarm was already programmed for the delayed handler. In this case, skip > > the alarm creation. > > > > Fixes: 9b667210700e ("net/ixgbe: fix blocked interrupts") > > Cc: stable@dpdk.org > > > > Signed-off-by: Edwin Brossette <edwin.brossette@6wind.com> > > --- > Reviewed-by: Anatoly Burakov <anatoly.burakov@intel.com> > Applied to dpdk-next-net-intel Thanks, /Bruce ^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2024-05-21 14:50 UTC | newest] Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- [not found] <CANDF9xC+4yBVxX8sgXzM0EdYcQFhzonG8FnnTQ1trSDxAkvAaQ@mail.gmail.com> 2024-04-18 13:53 ` [PATCH] net/ixgbe: don't create a delayed interrupt handler if one already exists edwin.brossette 2024-05-16 11:41 ` Burakov, Anatoly 2024-05-21 14:50 ` Bruce Richardson
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).