mac80211: add brcmfmac patch reading NVRAM from platform
This allows e.g. BCM43602 to work out of box, without dumping a proper MTD partition to /lib/firmware/ NVRAM file. Signed-off-by: Rafał Miłecki <zajec5@gmail.com> SVN-Revision: 45931
This commit is contained in:
		@@ -0,0 +1,80 @@
 | 
			
		||||
From: =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= <zajec5@gmail.com>
 | 
			
		||||
Date: Mon, 8 Jun 2015 16:59:31 +0200
 | 
			
		||||
Subject: [PATCH] brcmfmac: use bcm47xx platform NVRAM as fallback
 | 
			
		||||
MIME-Version: 1.0
 | 
			
		||||
Content-Type: text/plain; charset=UTF-8
 | 
			
		||||
Content-Transfer-Encoding: 8bit
 | 
			
		||||
 | 
			
		||||
Signed-off-by: Rafał Miłecki <zajec5@gmail.com>
 | 
			
		||||
---
 | 
			
		||||
 | 
			
		||||
--- a/drivers/net/wireless/brcm80211/brcmfmac/firmware.c
 | 
			
		||||
+++ b/drivers/net/wireless/brcm80211/brcmfmac/firmware.c
 | 
			
		||||
@@ -19,6 +19,9 @@
 | 
			
		||||
 #include <linux/device.h>
 | 
			
		||||
 #include <linux/firmware.h>
 | 
			
		||||
 #include <linux/module.h>
 | 
			
		||||
+#if IS_ENABLED(CONFIG_BCM47XX_NVRAM)
 | 
			
		||||
+#include <linux/bcm47xx_nvram.h>
 | 
			
		||||
+#endif
 | 
			
		||||
 
 | 
			
		||||
 #include "debug.h"
 | 
			
		||||
 #include "firmware.h"
 | 
			
		||||
@@ -424,17 +427,42 @@ struct brcmf_fw {
 | 
			
		||||
 static void brcmf_fw_request_nvram_done(const struct firmware *fw, void *ctx)
 | 
			
		||||
 {
 | 
			
		||||
 	struct brcmf_fw *fwctx = ctx;
 | 
			
		||||
+#if IS_ENABLED(CONFIG_BCM47XX_NVRAM)
 | 
			
		||||
+	const u8 *bcm47xx_nvram = NULL;
 | 
			
		||||
+	size_t bcm47xx_nvram_len;
 | 
			
		||||
+#endif
 | 
			
		||||
+	const u8 *data = NULL;
 | 
			
		||||
+	size_t data_len;
 | 
			
		||||
 	u32 nvram_length = 0;
 | 
			
		||||
 	void *nvram = NULL;
 | 
			
		||||
 
 | 
			
		||||
 	brcmf_dbg(TRACE, "enter: dev=%s\n", dev_name(fwctx->dev));
 | 
			
		||||
-	if (!fw && !(fwctx->flags & BRCMF_FW_REQ_NV_OPTIONAL))
 | 
			
		||||
+	if (fw) {
 | 
			
		||||
+		data = fw->data;
 | 
			
		||||
+		data_len = fw->size;
 | 
			
		||||
+	}
 | 
			
		||||
+#if IS_ENABLED(CONFIG_BCM47XX_NVRAM)
 | 
			
		||||
+	else {
 | 
			
		||||
+		bcm47xx_nvram = bcm47xx_nvram_get_contents(&bcm47xx_nvram_len);
 | 
			
		||||
+		if (bcm47xx_nvram) {
 | 
			
		||||
+			data = bcm47xx_nvram;
 | 
			
		||||
+			data_len = bcm47xx_nvram_len;
 | 
			
		||||
+			brcmf_err("Found platform NVRAM (%zu B)\n", data_len);
 | 
			
		||||
+		}
 | 
			
		||||
+	}
 | 
			
		||||
+#endif
 | 
			
		||||
+	if (!data && !(fwctx->flags & BRCMF_FW_REQ_NV_OPTIONAL))
 | 
			
		||||
 		goto fail;
 | 
			
		||||
 
 | 
			
		||||
-	if (fw) {
 | 
			
		||||
-		nvram = brcmf_fw_nvram_strip(fw->data, fw->size, &nvram_length,
 | 
			
		||||
+	if (data) {
 | 
			
		||||
+		nvram = brcmf_fw_nvram_strip(data, data_len, &nvram_length,
 | 
			
		||||
 					     fwctx->domain_nr, fwctx->bus_nr);
 | 
			
		||||
-		release_firmware(fw);
 | 
			
		||||
+		if (fw)
 | 
			
		||||
+			release_firmware(fw);
 | 
			
		||||
+#if IS_ENABLED(CONFIG_BCM47XX_NVRAM)
 | 
			
		||||
+		if (bcm47xx_nvram)
 | 
			
		||||
+			bcm47xx_nvram_release_contents(bcm47xx_nvram);
 | 
			
		||||
+#endif
 | 
			
		||||
 		if (!nvram && !(fwctx->flags & BRCMF_FW_REQ_NV_OPTIONAL))
 | 
			
		||||
 			goto fail;
 | 
			
		||||
 	}
 | 
			
		||||
--- a/drivers/net/wireless/brcm80211/brcmfmac/debug.h
 | 
			
		||||
+++ b/drivers/net/wireless/brcm80211/brcmfmac/debug.h
 | 
			
		||||
@@ -17,6 +17,8 @@
 | 
			
		||||
 #ifndef BRCMFMAC_DEBUG_H
 | 
			
		||||
 #define BRCMFMAC_DEBUG_H
 | 
			
		||||
 
 | 
			
		||||
+#include <linux/net.h>
 | 
			
		||||
+
 | 
			
		||||
 /* message levels */
 | 
			
		||||
 #define BRCMF_TRACE_VAL		0x00000002
 | 
			
		||||
 #define BRCMF_INFO_VAL		0x00000004
 | 
			
		||||
		Reference in New Issue
	
	Block a user