Skip to content

Commit

Permalink
staging: brcm80211: handle missing firmware better
Browse files Browse the repository at this point in the history
Handle non-extistent firmware more gracefully.

Signed-off-by: Brett Rudley <brudley@broadcom.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
  • Loading branch information
Brett Rudley authored and Greg Kroah-Hartman committed Sep 30, 2010
1 parent a200adb commit 683b505
Showing 1 changed file with 25 additions and 18 deletions.
43 changes: 25 additions & 18 deletions drivers/staging/brcm80211/sys/wl_mac80211.c
Original file line number Diff line number Diff line change
Expand Up @@ -187,6 +187,7 @@ static struct pci_device_id wl_id_table[] = {
};

MODULE_DEVICE_TABLE(pci, wl_id_table);
static void __devexit wl_remove(struct pci_dev *pdev);
#endif /* !BCMSDIO */

#ifdef BCMSDIO
Expand Down Expand Up @@ -902,9 +903,11 @@ static wl_info_t *wl_attach(uint16 vendor, uint16 device, ulong regs,
#ifndef WLC_HIGH_ONLY
/* prepare ucode */
if (wl_request_fw(wl, (struct pci_dev *)btparam)) {
printf("%s: %s driver failed\n", KBUILD_MODNAME,
EPI_VERSION_STR);
goto fail;
printf("%s: Failed to find firmware usually in %s\n",
KBUILD_MODNAME, "/lib/firmware/brcm");
wl_release_fw(wl);
wl_remove((struct pci_dev *)btparam);
goto fail1;
}
#endif

Expand All @@ -915,8 +918,8 @@ static wl_info_t *wl_attach(uint16 vendor, uint16 device, ulong regs,
wl_release_fw(wl);
#endif
if (!wl->wlc) {
printf("%s: %s driver failed with code %d\n", KBUILD_MODNAME,
EPI_VERSION_STR, err);
printf("%s: %s wlc_attach() failed with code %d\n",
KBUILD_MODNAME, EPI_VERSION_STR, err);
goto fail;
}
wl->pub = wlc_pub(wl->wlc);
Expand Down Expand Up @@ -1018,6 +1021,7 @@ static wl_info_t *wl_attach(uint16 vendor, uint16 device, ulong regs,

fail:
wl_free(wl);
fail1:
return NULL;
}

Expand Down Expand Up @@ -1189,9 +1193,6 @@ static void wl_dbus_disconnect_cb(void *arg)
}
#endif /* WLC_HIGH_ONLY */

#ifndef BCMSDIO
static void __devexit wl_remove(struct pci_dev *pdev);
#endif

#define CHAN2GHZ(channel, freqency, chflags) { \
.band = IEEE80211_BAND_2GHZ, \
Expand Down Expand Up @@ -1510,6 +1511,11 @@ wl_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
wl = wl_attach(pdev->vendor, pdev->device, pci_resource_start(pdev, 0),
PCI_BUS, pdev, pdev->irq);

if (!wl) {
WL_ERROR(("%s: %s: wl_attach failed!\n",
KBUILD_MODNAME, __func__));
return -ENODEV;
}
return 0;
err_1:
WL_ERROR(("%s: err_1: Major hoarkage\n", __func__));
Expand Down Expand Up @@ -1594,14 +1600,13 @@ static void __devexit wl_remove(struct pci_dev *pdev)
WL_ERROR(("wl: wl_remove: wlc_chipmatch failed\n"));
return;
}

ieee80211_unregister_hw(hw);

WL_LOCK(wl);
wl_down(wl);
WL_UNLOCK(wl);
WL_NONE(("%s: Down\n", __func__));

if (wl->wlc) {
ieee80211_unregister_hw(hw);
WL_LOCK(wl);
wl_down(wl);
WL_UNLOCK(wl);
WL_NONE(("%s: Down\n", __func__));
}
pci_disable_device(pdev);

wl_free(wl);
Expand Down Expand Up @@ -2511,7 +2516,8 @@ static int wl_request_fw(wl_info_t *wl, struct pci_dev *pdev)
WL_NONE(("request fw %s\n", fw_name));
status = request_firmware(&wl->fw.fw_bin[i], fw_name, device);
if (status) {
printf("fail to request firmware %s\n", fw_name);
printf("%s: fail to load firmware %s\n",
KBUILD_MODNAME, fw_name);
wl_release_fw(wl);
return status;
}
Expand All @@ -2520,7 +2526,8 @@ static int wl_request_fw(wl_info_t *wl, struct pci_dev *pdev)
UCODE_LOADER_API_VER);
status = request_firmware(&wl->fw.fw_hdr[i], fw_name, device);
if (status) {
printf("fail to request firmware %s\n", fw_name);
printf("%s: fail to load firmware %s\n",
KBUILD_MODNAME, fw_name);
wl_release_fw(wl);
return status;
}
Expand Down

0 comments on commit 683b505

Please sign in to comment.