diff options
author | Roland Dreier <rolandd@cisco.com> | 2007-06-07 11:51:58 -0700 |
---|---|---|
committer | Roland Dreier <rolandd@cisco.com> | 2007-06-07 11:51:58 -0700 |
commit | b581401ed0cc83a4483ed39c00a14a60bacecc3a (patch) | |
tree | fa83991f1f429c0bf9876856d5255cf4a8be79fe /drivers/net/mlx4/intf.c | |
parent | 09360d5408cb641abff0f32a172a3332f02e8e88 (diff) | |
download | talos-op-linux-b581401ed0cc83a4483ed39c00a14a60bacecc3a.tar.gz talos-op-linux-b581401ed0cc83a4483ed39c00a14a60bacecc3a.zip |
mlx4_core: Initialize ctx_list and ctx_lock earlier
We may call mlx4_dispatch_event() before mlx4_register_device() is
called for a device, because for example a catastrophic error happens
immediately after we enable interrupts. Therefore priv->ctx_list and
priv->ctx_lock need to be initialized earlier.
This bug was actually exposed by the MSI-X bug that returned IRQ numbers
to drivers in reverse order, so that the first FW command
interrupt looked to mlx4 like a catastrophic error.
Signed-off-by: Roland Dreier <rolandd@cisco.com>
Diffstat (limited to 'drivers/net/mlx4/intf.c')
-rw-r--r-- | drivers/net/mlx4/intf.c | 3 |
1 files changed, 0 insertions, 3 deletions
diff --git a/drivers/net/mlx4/intf.c b/drivers/net/mlx4/intf.c index 65854f9e9c76..9ae951bf6aa6 100644 --- a/drivers/net/mlx4/intf.c +++ b/drivers/net/mlx4/intf.c @@ -135,9 +135,6 @@ int mlx4_register_device(struct mlx4_dev *dev) struct mlx4_priv *priv = mlx4_priv(dev); struct mlx4_interface *intf; - INIT_LIST_HEAD(&priv->ctx_list); - spin_lock_init(&priv->ctx_lock); - mutex_lock(&intf_mutex); list_add_tail(&priv->dev_list, &dev_list); |