Commit 0ca4e20b authored by Tobias Regnery's avatar Tobias Regnery Committed by David S. Miller

alx: fix error handling in __alx_open

In commit 9ee7b683 we moved the enablement of msi interrupts earlier in
alx_init_intr. If there is an error in alx_alloc_rings, __alx_open returns
with an error but msi (or msi-x) interrupts stays enabled. Add a new error
label to disable msi (or msi-x) interrupts.

Fixes: 9ee7b683 ("alx: refactor msi enablement and disablement")
Signed-off-by: default avatarTobias Regnery <tobias.regnery@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 5400e54a
...@@ -1028,7 +1028,7 @@ static int __alx_open(struct alx_priv *alx, bool resume) ...@@ -1028,7 +1028,7 @@ static int __alx_open(struct alx_priv *alx, bool resume)
err = alx_alloc_rings(alx); err = alx_alloc_rings(alx);
if (err) if (err)
return err; goto out_disable_adv_intr;
alx_configure(alx); alx_configure(alx);
...@@ -1049,6 +1049,8 @@ static int __alx_open(struct alx_priv *alx, bool resume) ...@@ -1049,6 +1049,8 @@ static int __alx_open(struct alx_priv *alx, bool resume)
out_free_rings: out_free_rings:
alx_free_rings(alx); alx_free_rings(alx);
out_disable_adv_intr:
alx_disable_advanced_intr(alx);
return err; return err;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment