mirror of
				git://git.openwrt.org/openwrt/openwrt.git
				synced 2025-10-30 21:44:27 -04:00 
			
		
		
		
	This makes brcmfmac use the same wiphy after PCIe reset to help user space handle corner cases (e.g. firmware crash). Signed-off-by: Rafał Miłecki <rafal@milecki.pl>
		
			
				
	
	
		
			52 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From a1f5aac1765afbeace9581afa27da34085f68e1d Mon Sep 17 00:00:00 2001
 | |
| From: =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= <rafal@milecki.pl>
 | |
| Date: Tue, 3 Sep 2019 06:29:28 +0200
 | |
| Subject: [PATCH 3/3] brcmfmac: don't realloc wiphy during PCIe reset
 | |
| MIME-Version: 1.0
 | |
| Content-Type: text/plain; charset=UTF-8
 | |
| Content-Transfer-Encoding: 8bit
 | |
| 
 | |
| Providing a new wiphy on every PCIe reset was confusing and was causing
 | |
| configuration problems for some users (supplicant and authenticators).
 | |
| Sticking to the existing wiphy should make error recovery much simpler
 | |
| and more reliable.
 | |
| 
 | |
| Signed-off-by: Rafał Miłecki <rafal@milecki.pl>
 | |
| Acked-by: Arend van Spriel <arend.vanspriel@broadcom.com>
 | |
| Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
 | |
| ---
 | |
|  drivers/net/wireless/broadcom/brcm80211/brcmfmac/pcie.c | 8 ++++----
 | |
|  1 file changed, 4 insertions(+), 4 deletions(-)
 | |
| 
 | |
| --- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/pcie.c
 | |
| +++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/pcie.c
 | |
| @@ -1430,7 +1430,6 @@ static int brcmf_pcie_reset(struct devic
 | |
|  	brcmf_pcie_bus_console_read(devinfo, true);
 | |
|  
 | |
|  	brcmf_detach(dev);
 | |
| -	brcmf_free(dev);
 | |
|  
 | |
|  	brcmf_pcie_release_irq(devinfo);
 | |
|  	brcmf_pcie_release_scratchbuffers(devinfo);
 | |
| @@ -1826,9 +1825,6 @@ static void brcmf_pcie_setup(struct devi
 | |
|  	brcmf_pcie_intr_enable(devinfo);
 | |
|  	brcmf_pcie_hostready(devinfo);
 | |
|  
 | |
| -	ret = brcmf_alloc(&devinfo->pdev->dev, devinfo->settings);
 | |
| -	if (ret)
 | |
| -		goto fail;
 | |
|  	ret = brcmf_attach(&devinfo->pdev->dev);
 | |
|  	if (ret)
 | |
|  		goto fail;
 | |
| @@ -1931,6 +1927,10 @@ brcmf_pcie_probe(struct pci_dev *pdev, c
 | |
|  	bus->wowl_supported = pci_pme_capable(pdev, PCI_D3hot);
 | |
|  	dev_set_drvdata(&pdev->dev, bus);
 | |
|  
 | |
| +	ret = brcmf_alloc(&devinfo->pdev->dev, devinfo->settings);
 | |
| +	if (ret)
 | |
| +		goto fail_bus;
 | |
| +
 | |
|  	fwreq = brcmf_pcie_prepare_fw_request(devinfo);
 | |
|  	if (!fwreq) {
 | |
|  		ret = -ENOMEM;
 |