860-brcmfmac-register-wiphy-s-during-module_init.patch 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. From: =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= <[email protected]>
  2. Date: Mon, 8 Jun 2015 16:11:40 +0200
  3. Subject: [PATCH] brcmfmac: register wiphy(s) during module_init
  4. MIME-Version: 1.0
  5. Content-Type: text/plain; charset=UTF-8
  6. Content-Transfer-Encoding: 8bit
  7. This is needed by OpenWrt which expects all PHYs to be created after
  8. module loads successfully.
  9. Signed-off-by: Rafał Miłecki <[email protected]>
  10. ---
  11. --- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/core.c
  12. +++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/core.c
  13. @@ -1310,6 +1310,7 @@ int __init brcmf_core_init(void)
  14. {
  15. if (!schedule_work(&brcmf_driver_work))
  16. return -EBUSY;
  17. + flush_work(&brcmf_driver_work);
  18. return 0;
  19. }
  20. --- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/firmware.c
  21. +++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/firmware.c
  22. @@ -444,6 +444,7 @@ struct brcmf_fw {
  23. u16 bus_nr;
  24. void (*done)(struct device *dev, int err, const struct firmware *fw,
  25. void *nvram_image, u32 nvram_len);
  26. + struct completion *completion;
  27. };
  28. static void brcmf_fw_request_nvram_done(const struct firmware *fw, void *ctx)
  29. @@ -478,6 +479,8 @@ static void brcmf_fw_request_nvram_done(
  30. goto fail;
  31. fwctx->done(fwctx->dev, 0, fwctx->code, nvram, nvram_length);
  32. + if (fwctx->completion)
  33. + complete(fwctx->completion);
  34. kfree(fwctx);
  35. return;
  36. @@ -485,6 +488,8 @@ fail:
  37. brcmf_dbg(TRACE, "failed: dev=%s\n", dev_name(fwctx->dev));
  38. release_firmware(fwctx->code);
  39. fwctx->done(fwctx->dev, -ENOENT, NULL, NULL, 0);
  40. + if (fwctx->completion)
  41. + complete(fwctx->completion);
  42. kfree(fwctx);
  43. }
  44. @@ -516,6 +521,8 @@ fail:
  45. brcmf_dbg(TRACE, "failed: dev=%s\n", dev_name(fwctx->dev));
  46. done:
  47. fwctx->done(fwctx->dev, ret, fw, NULL, 0);
  48. + if (fwctx->completion)
  49. + complete(fwctx->completion);
  50. kfree(fwctx);
  51. }
  52. @@ -527,6 +534,8 @@ int brcmf_fw_get_firmwares_pcie(struct d
  53. u16 domain_nr, u16 bus_nr)
  54. {
  55. struct brcmf_fw *fwctx;
  56. + struct completion completion;
  57. + int err;
  58. brcmf_dbg(TRACE, "enter: dev=%s\n", dev_name(dev));
  59. if (!fw_cb || !code)
  60. @@ -547,9 +556,17 @@ int brcmf_fw_get_firmwares_pcie(struct d
  61. fwctx->domain_nr = domain_nr;
  62. fwctx->bus_nr = bus_nr;
  63. - return request_firmware_nowait(THIS_MODULE, true, code, dev,
  64. + init_completion(&completion);
  65. + fwctx->completion = &completion;
  66. +
  67. + err = request_firmware_nowait(THIS_MODULE, true, code, dev,
  68. GFP_KERNEL, fwctx,
  69. brcmf_fw_request_code_done);
  70. + if (!err)
  71. + wait_for_completion_timeout(fwctx->completion,
  72. + msecs_to_jiffies(5000));
  73. + fwctx->completion = NULL;
  74. + return err;
  75. }
  76. int brcmf_fw_get_firmwares(struct device *dev, u16 flags,