diff options
author | Larry Finger <Larry.Finger@lwfinger.net> | 2014-01-12 16:11:38 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2014-01-13 14:50:02 -0500 |
commit | 0673effd41dba323d6a280ef37b5ef29f3f5a653 (patch) | |
tree | a77566c99cb389a3b41584431041312cbfc4104e /drivers/net/wireless/b43/b43.h | |
parent | 09164043f63c947a49797750a09ca1cd7c31108e (diff) |
b43: Fix unload oops if firmware is not available
The asyncronous firmware load uses a completion struct to hold firmware
processing until the user-space routines are up and running. There is.
however, a problem in that the waiter is nevered canceled during teardown.
As a result, unloading the driver when firmware is not available causes an oops.
To be able to access the completion structure at teardown, it had to be moved
into the b43_wldev structure.
This patch also fixes a typo in a comment.
Signed-off-by: Larry Finger <Larry.Finger@lwfinger.net>
Cc: Stable <stable@vger.kernel.org>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/b43/b43.h')
-rw-r--r-- | drivers/net/wireless/b43/b43.h | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/net/wireless/b43/b43.h b/drivers/net/wireless/b43/b43.h index 7f3d461f7e8d..54376fddfaf9 100644 --- a/drivers/net/wireless/b43/b43.h +++ b/drivers/net/wireless/b43/b43.h | |||
@@ -731,8 +731,6 @@ enum b43_firmware_file_type { | |||
731 | struct b43_request_fw_context { | 731 | struct b43_request_fw_context { |
732 | /* The device we are requesting the fw for. */ | 732 | /* The device we are requesting the fw for. */ |
733 | struct b43_wldev *dev; | 733 | struct b43_wldev *dev; |
734 | /* a completion event structure needed if this call is asynchronous */ | ||
735 | struct completion fw_load_complete; | ||
736 | /* a pointer to the firmware object */ | 734 | /* a pointer to the firmware object */ |
737 | const struct firmware *blob; | 735 | const struct firmware *blob; |
738 | /* The type of firmware to request. */ | 736 | /* The type of firmware to request. */ |
@@ -809,6 +807,8 @@ enum { | |||
809 | struct b43_wldev { | 807 | struct b43_wldev { |
810 | struct b43_bus_dev *dev; | 808 | struct b43_bus_dev *dev; |
811 | struct b43_wl *wl; | 809 | struct b43_wl *wl; |
810 | /* a completion event structure needed if this call is asynchronous */ | ||
811 | struct completion fw_load_complete; | ||
812 | 812 | ||
813 | /* The device initialization status. | 813 | /* The device initialization status. |
814 | * Use b43_status() to query. */ | 814 | * Use b43_status() to query. */ |