[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <adaeipmqxmv.fsf@cisco.com>
Date: Thu, 01 Oct 2009 20:32:08 -0700
From: Roland Dreier <rdreier@...co.com>
To: Yevgeny Petrilin <yevgenyp@...lanox.co.il>
Cc: davem@...emloft.net, netdev@...r.kernel.org
Subject: Re: [PATCH 1/7] mlx4: Added interrupts test support
This feels like a pretty risky thing to do while the device might be
handling all sorts of other traffic at the same time. Are you sure
there are no races you expose here? Have you actually seen cases where
the interrupt test during initialization works but then this test
catches a problem? (My experience has been that if any MSI-X interrupts
work from a device, then they'll all work)
> +/* A test that verifies that we can accept interrupts on all
> + * the irq vectors of the device.
> + * Interrupts are checked using the NOP command.
> + */
> +int mlx4_test_interrupts(struct mlx4_dev *dev)
> +{
> + struct mlx4_priv *priv = mlx4_priv(dev);
> + int i;
> + int err;
> +
> + err = mlx4_NOP(dev);
> + /* When not in MSI_X, there is only one irq to check */
> + if (!(dev->flags & MLX4_FLAG_MSI_X))
> + return err;
> +
> + /* A loop over all completion vectors, for each vector we will check
> + * whether it works by mapping command completions to that vector
> + * and performing a NOP command
> + */
> + for (i = 0; !err && (i < dev->caps.num_comp_vectors); ++i) {
> + /* Temporary use polling for command completions */
you want the adverb form here: "Temporarily"
> + mlx4_cmd_use_polling(dev);
> +
> + /* Map the new eq to handle all asyncronous events */
"asynchronous"
> + err = mlx4_MAP_EQ(dev, MLX4_ASYNC_EVENT_MASK, 0,
> + priv->eq_table.eq[i].eqn);
> + if (err) {
> + mlx4_warn(dev, "Failed mapping eq for interrupt test\n");
> + mlx4_cmd_use_events(dev);
> + break;
> + }
> +
> + /* Go back to using events */
> + mlx4_cmd_use_events(dev);
> + err = mlx4_NOP(dev);
You could simplify the code a bit by moving the mlx4_cmd_use_events() to
before where you test err, ie:
err = mlx4_MAP_EQ(...);
mlx4_cmd_user_events(dev);
if (err)
mlx4_warn(dev, ...)
else
err = mlx4_NOP(dev);
> + }
> +
> + /* Return to default */
> + mlx4_MAP_EQ(dev, MLX4_ASYNC_EVENT_MASK, 0,
> + priv->eq_table.eq[dev->caps.num_comp_vectors].eqn);
> + return err;
> +}
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists