On Tue, Sep 05, 2017 at 02:56:39PM +0200, Adrien Mazarguil wrote: > Since interrupt handler is the only function relying on it, merging them > simplifies the code as there is no need for an API to return collected > events. > > Signed-off-by: Adrien Mazarguil <adrien.mazarg...@6wind.com> > --- > drivers/net/mlx4/mlx4_intr.c | 94 +++++++++++++-------------------------- > 1 file changed, 30 insertions(+), 64 deletions(-) > > diff --git a/drivers/net/mlx4/mlx4_intr.c b/drivers/net/mlx4/mlx4_intr.c > index e1e6c05..3806322 100644 > --- a/drivers/net/mlx4/mlx4_intr.c > +++ b/drivers/net/mlx4/mlx4_intr.c > @@ -135,53 +135,6 @@ mlx4_rx_intr_vec_enable(struct priv *priv) > } > > /** > - * Collect interrupt events. > - * > - * @param priv > - * Pointer to private structure. > - * @param events > - * Pointer to event flags holder. > - * > - * @return > - * Number of events. > - */ > -static int > -mlx4_collect_interrupt_events(struct priv *priv, uint32_t *events) > -{ > - struct ibv_async_event event; > - const struct rte_intr_conf *const intr_conf = > - &priv->dev->data->dev_conf.intr_conf; > - int ret = 0; > - > - *events = 0; > - /* Read all message and acknowledge them. */ > - for (;;) { > - if (ibv_get_async_event(priv->ctx, &event)) > - break; > - switch (event.event_type) { > - case IBV_EVENT_PORT_ACTIVE: > - case IBV_EVENT_PORT_ERR: > - if (!intr_conf->lsc || mlx4_link_status_check(priv)) > - break; > - *events |= (1 << RTE_ETH_EVENT_INTR_LSC); > - ret++; > - break; > - case IBV_EVENT_DEVICE_FATAL: > - if (!intr_conf->rmv) > - break; > - *events |= (1 << RTE_ETH_EVENT_INTR_RMV); > - ret++; > - break; > - default: > - DEBUG("event type %d on port %d not handled", > - event.event_type, event.element.port_num); > - } > - ibv_ack_async_event(&event); > - } > - return ret; > -} > - > -/** > * Process scheduled link status check. > * > * If LSC interrupts are requested, process related callback. > @@ -250,26 +203,39 @@ mlx4_link_status_check(struct priv *priv) > static void > mlx4_interrupt_handler(struct priv *priv) > { > - int ret; > - uint32_t ev; > - int i; > + enum { LSC, RMV, }; > + static const enum rte_eth_event_type type[] = { > + [LSC] = RTE_ETH_EVENT_INTR_LSC, > + [RMV] = RTE_ETH_EVENT_INTR_RMV, > + }; > + uint32_t caught[RTE_DIM(type)] = { 0 };
This is nicely written > + struct ibv_async_event event; > + const struct rte_intr_conf *const intr_conf = > + &priv->dev->data->dev_conf.intr_conf; > + unsigned int i; > > - ret = mlx4_collect_interrupt_events(priv, &ev); > - if (ret > 0) { > - for (i = RTE_ETH_EVENT_UNKNOWN; > - i < RTE_ETH_EVENT_MAX; > - i++) { > - if (ev & (1 << i)) { > - ev &= ~(1 << i); > - _rte_eth_dev_callback_process(priv->dev, i, > - NULL, NULL); > - ret--; > - } > + /* Read all message and acknowledge them. */ > + while (!ibv_get_async_event(priv->ctx, &event)) { > + switch (event.event_type) { > + case IBV_EVENT_PORT_ACTIVE: > + case IBV_EVENT_PORT_ERR: > + if (intr_conf->lsc && !mlx4_link_status_check(priv)) > + ++caught[LSC]; > + break; > + case IBV_EVENT_DEVICE_FATAL: > + if (intr_conf->rmv) > + ++caught[RMV]; > + break; > + default: > + DEBUG("event type %d on physical port %d not handled", > + event.event_type, event.element.port_num); > } > - if (ret) > - WARN("%d event%s not processed", ret, > - (ret > 1 ? "s were" : " was")); > + ibv_ack_async_event(&event); > } > + for (i = 0; i != RTE_DIM(caught); ++i) > + if (caught[i]) > + _rte_eth_dev_callback_process(priv->dev, type[i], > + NULL, NULL); > } > > /** > -- > 2.1.4 > -- Gaëtan Rivet 6WIND