]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
b43: only reload config after successful initialization
authorSeth Forshee <seth.forshee@canonical.com>
Wed, 25 Apr 2012 22:28:00 +0000 (17:28 -0500)
committerBen Hutchings <ben@decadent.org.uk>
Fri, 11 May 2012 12:14:52 +0000 (13:14 +0100)
commit dbdedbdf4fbff3d4962a0786f37aa86dfdc48a7e upstream.

Commit 2a19032 (b43: reload phy and bss settings after core restarts)
introduced an unconditional call to b43_op_config() at the end of
b43_op_start(). When firmware fails to load this can wedge the system.
There's no need to reload the configuration after a failed
initialization anyway, so only make the call if initialization was
successful.

BugLink: http://bugs.launchpad.net/bugs/950295
Cc: Felix Fietkau <nbd@openwrt.org>
Signed-off-by: Seth Forshee <seth.forshee@canonical.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
drivers/net/wireless/b43/main.c

index 5634d9a9965bcd91addc69408224caccee7a7746..680709c4a72633895bbc4858f8c4c899cc6aa64e 100644 (file)
@@ -4820,8 +4820,14 @@ static int b43_op_start(struct ieee80211_hw *hw)
  out_mutex_unlock:
        mutex_unlock(&wl->mutex);
 
-       /* reload configuration */
-       b43_op_config(hw, ~0);
+       /*
+        * Configuration may have been overwritten during initialization.
+        * Reload the configuration, but only if initialization was
+        * successful. Reloading the configuration after a failed init
+        * may hang the system.
+        */
+       if (!err)
+               b43_op_config(hw, ~0);
 
        return err;
 }