diff options
author | Larry Finger <Larry.Finger@lwfinger.net> | 2012-01-30 10:54:49 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2012-01-30 15:48:50 -0500 |
commit | b0302aba812bcc39291cdab9ad7e37008f352a91 (patch) | |
tree | 82915b1e24f204babeb65e1d517115c0e31cfd9a /drivers/net/wireless/rtlwifi/rtl8192ce/sw.c | |
parent | feced2012e665468258a5c89b7f2a90b4e5695a4 (diff) |
rtlwifi: Convert to asynchronous firmware load
This patch addresses a kernel bugzilla report and two recent mail threads.
The kernel bugzilla report is https://bugzilla.kernel.org/show_bug.cgi?id=42632,
which reports a udev timeout on boot.
The first mail thread, which was on LKML (http://lkml.indiana.edu/hypermail/
linux/kernel/1112.3/00965.html) was for a WARNING that occurs after a
suspend/resume cycle for rtl8192cu.
The scond mail thread (http://marc.info/?l=linux-wireless&m=132655490826766&w=2)
concerned changes in udev that break drivers that delay while firmware is loaded
on modprobe.
This patch converts all rtlwifi-based drivers to use the asynchronous firmware
loading mechanism. Drivers rtl8192ce, rtl8192cu and rtl8192de share a common
callback routine. Driver rtl8192se needs different handling of the firmware,
thus it has its own code.
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/rtlwifi/rtl8192ce/sw.c')
-rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8192ce/sw.c | 24 |
1 files changed, 8 insertions, 16 deletions
diff --git a/drivers/net/wireless/rtlwifi/rtl8192ce/sw.c b/drivers/net/wireless/rtlwifi/rtl8192ce/sw.c index 460dc925b4e4..2c3b73366cd2 100644 --- a/drivers/net/wireless/rtlwifi/rtl8192ce/sw.c +++ b/drivers/net/wireless/rtlwifi/rtl8192ce/sw.c | |||
@@ -91,9 +91,7 @@ int rtl92c_init_sw_vars(struct ieee80211_hw *hw) | |||
91 | int err; | 91 | int err; |
92 | struct rtl_priv *rtlpriv = rtl_priv(hw); | 92 | struct rtl_priv *rtlpriv = rtl_priv(hw); |
93 | struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw)); | 93 | struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw)); |
94 | const struct firmware *firmware; | ||
95 | struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw)); | 94 | struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw)); |
96 | char *fw_name = NULL; | ||
97 | 95 | ||
98 | rtl8192ce_bt_reg_init(hw); | 96 | rtl8192ce_bt_reg_init(hw); |
99 | 97 | ||
@@ -165,26 +163,20 @@ int rtl92c_init_sw_vars(struct ieee80211_hw *hw) | |||
165 | /* request fw */ | 163 | /* request fw */ |
166 | if (IS_VENDOR_UMC_A_CUT(rtlhal->version) && | 164 | if (IS_VENDOR_UMC_A_CUT(rtlhal->version) && |
167 | !IS_92C_SERIAL(rtlhal->version)) | 165 | !IS_92C_SERIAL(rtlhal->version)) |
168 | fw_name = "rtlwifi/rtl8192cfwU.bin"; | 166 | rtlpriv->cfg->fw_name = "rtlwifi/rtl8192cfwU.bin"; |
169 | else if (IS_81xxC_VENDOR_UMC_B_CUT(rtlhal->version)) | 167 | else if (IS_81xxC_VENDOR_UMC_B_CUT(rtlhal->version)) |
170 | fw_name = "rtlwifi/rtl8192cfwU_B.bin"; | 168 | rtlpriv->cfg->fw_name = "rtlwifi/rtl8192cfwU_B.bin"; |
171 | else | 169 | |
172 | fw_name = rtlpriv->cfg->fw_name; | 170 | rtlpriv->max_fw_size = 0x4000; |
173 | err = request_firmware(&firmware, fw_name, rtlpriv->io.dev); | 171 | pr_info("Using firmware %s\n", rtlpriv->cfg->fw_name); |
172 | err = request_firmware_nowait(THIS_MODULE, 1, rtlpriv->cfg->fw_name, | ||
173 | rtlpriv->io.dev, GFP_KERNEL, hw, | ||
174 | rtl_fw_cb); | ||
174 | if (err) { | 175 | if (err) { |
175 | RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG, | 176 | RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG, |
176 | "Failed to request firmware!\n"); | 177 | "Failed to request firmware!\n"); |
177 | return 1; | 178 | return 1; |
178 | } | 179 | } |
179 | if (firmware->size > 0x4000) { | ||
180 | RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG, | ||
181 | "Firmware is too big!\n"); | ||
182 | release_firmware(firmware); | ||
183 | return 1; | ||
184 | } | ||
185 | memcpy(rtlpriv->rtlhal.pfirmware, firmware->data, firmware->size); | ||
186 | rtlpriv->rtlhal.fwsize = firmware->size; | ||
187 | release_firmware(firmware); | ||
188 | 180 | ||
189 | return 0; | 181 | return 0; |
190 | } | 182 | } |