diff options
author | Amit Kumar Salecha <amit.salecha@qlogic.com> | 2010-04-01 15:01:34 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-04-03 17:19:15 -0400 |
commit | 34ce36268331719894c4b237a9413fe9e1ab4f75 (patch) | |
tree | c20b62fdcd5485be277ed55abb5daaea621c04cd /drivers/net/qlcnic | |
parent | 65b5b420b5974d86ee030b0a15cd9e6f228071f4 (diff) |
qlcnic: fix interface attach sequence
Interface should be visible even if resource allocation fails.
netif_device_attach should be called for every netif_device_detach.
Signed-off-by: Amit Kumar Salecha <amit.salecha@qlogic.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/qlcnic')
-rw-r--r-- | drivers/net/qlcnic/qlcnic_main.c | 20 |
1 files changed, 10 insertions, 10 deletions
diff --git a/drivers/net/qlcnic/qlcnic_main.c b/drivers/net/qlcnic/qlcnic_main.c index 039f69382dc9..7ae464085b0d 100644 --- a/drivers/net/qlcnic/qlcnic_main.c +++ b/drivers/net/qlcnic/qlcnic_main.c | |||
@@ -952,11 +952,11 @@ void qlcnic_diag_free_res(struct net_device *netdev, int max_sds_rings) | |||
952 | adapter->max_sds_rings = max_sds_rings; | 952 | adapter->max_sds_rings = max_sds_rings; |
953 | 953 | ||
954 | if (qlcnic_attach(adapter)) | 954 | if (qlcnic_attach(adapter)) |
955 | return; | 955 | goto out; |
956 | 956 | ||
957 | if (netif_running(netdev)) | 957 | if (netif_running(netdev)) |
958 | __qlcnic_up(adapter, netdev); | 958 | __qlcnic_up(adapter, netdev); |
959 | 959 | out: | |
960 | netif_device_attach(netdev); | 960 | netif_device_attach(netdev); |
961 | } | 961 | } |
962 | 962 | ||
@@ -978,8 +978,10 @@ int qlcnic_diag_alloc_res(struct net_device *netdev, int test) | |||
978 | adapter->diag_test = test; | 978 | adapter->diag_test = test; |
979 | 979 | ||
980 | ret = qlcnic_attach(adapter); | 980 | ret = qlcnic_attach(adapter); |
981 | if (ret) | 981 | if (ret) { |
982 | netif_device_attach(netdev); | ||
982 | return ret; | 983 | return ret; |
984 | } | ||
983 | 985 | ||
984 | if (adapter->diag_test == QLCNIC_INTERRUPT_TEST) { | 986 | if (adapter->diag_test == QLCNIC_INTERRUPT_TEST) { |
985 | for (ring = 0; ring < adapter->max_sds_rings; ring++) { | 987 | for (ring = 0; ring < adapter->max_sds_rings; ring++) { |
@@ -1012,16 +1014,12 @@ qlcnic_reset_context(struct qlcnic_adapter *adapter) | |||
1012 | if (netif_running(netdev)) { | 1014 | if (netif_running(netdev)) { |
1013 | err = qlcnic_attach(adapter); | 1015 | err = qlcnic_attach(adapter); |
1014 | if (!err) | 1016 | if (!err) |
1015 | err = __qlcnic_up(adapter, netdev); | 1017 | __qlcnic_up(adapter, netdev); |
1016 | |||
1017 | if (err) | ||
1018 | goto done; | ||
1019 | } | 1018 | } |
1020 | 1019 | ||
1021 | netif_device_attach(netdev); | 1020 | netif_device_attach(netdev); |
1022 | } | 1021 | } |
1023 | 1022 | ||
1024 | done: | ||
1025 | clear_bit(__QLCNIC_RESETTING, &adapter->state); | 1023 | clear_bit(__QLCNIC_RESETTING, &adapter->state); |
1026 | return err; | 1024 | return err; |
1027 | } | 1025 | } |
@@ -1337,6 +1335,7 @@ err_out_detach: | |||
1337 | qlcnic_detach(adapter); | 1335 | qlcnic_detach(adapter); |
1338 | err_out: | 1336 | err_out: |
1339 | qlcnic_clr_all_drv_state(adapter); | 1337 | qlcnic_clr_all_drv_state(adapter); |
1338 | netif_device_attach(netdev); | ||
1340 | return err; | 1339 | return err; |
1341 | } | 1340 | } |
1342 | #endif | 1341 | #endif |
@@ -2152,6 +2151,7 @@ qlcnic_fwinit_work(struct work_struct *work) | |||
2152 | } | 2151 | } |
2153 | 2152 | ||
2154 | err_ret: | 2153 | err_ret: |
2154 | netif_device_attach(adapter->netdev); | ||
2155 | qlcnic_clr_all_drv_state(adapter); | 2155 | qlcnic_clr_all_drv_state(adapter); |
2156 | } | 2156 | } |
2157 | 2157 | ||
@@ -2190,6 +2190,7 @@ qlcnic_detach_work(struct work_struct *work) | |||
2190 | err_ret: | 2190 | err_ret: |
2191 | dev_err(&adapter->pdev->dev, "detach failed; status=%d temp=%d\n", | 2191 | dev_err(&adapter->pdev->dev, "detach failed; status=%d temp=%d\n", |
2192 | status, adapter->temp); | 2192 | status, adapter->temp); |
2193 | netif_device_attach(netdev); | ||
2193 | qlcnic_clr_all_drv_state(adapter); | 2194 | qlcnic_clr_all_drv_state(adapter); |
2194 | 2195 | ||
2195 | } | 2196 | } |
@@ -2252,9 +2253,8 @@ qlcnic_attach_work(struct work_struct *work) | |||
2252 | qlcnic_config_indev_addr(netdev, NETDEV_UP); | 2253 | qlcnic_config_indev_addr(netdev, NETDEV_UP); |
2253 | } | 2254 | } |
2254 | 2255 | ||
2255 | netif_device_attach(netdev); | ||
2256 | |||
2257 | done: | 2256 | done: |
2257 | netif_device_attach(netdev); | ||
2258 | adapter->fw_fail_cnt = 0; | 2258 | adapter->fw_fail_cnt = 0; |
2259 | clear_bit(__QLCNIC_RESETTING, &adapter->state); | 2259 | clear_bit(__QLCNIC_RESETTING, &adapter->state); |
2260 | 2260 | ||