[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20230106072746.29516-1-iivanov@suse.de>
Date: Fri, 6 Jan 2023 09:27:46 +0200
From: "Ivan T. Ivanov" <iivanov@...e.de>
To: aspriel@...il.com, marcan@...can.st
Cc: franky.lin@...adcom.com, hante.meuleman@...adcom.com,
rmk+kernel@...linux.org.uk, kvalo@...nel.org, davem@...emloft.net,
devicetree@...r.kernel.org, edumazet@...gle.com,
krzysztof.kozlowski+dt@...aro.org, kuba@...nel.org,
pabeni@...hat.com, robh+dt@...nel.org,
linux-arm-kernel@...ts.infradead.org,
linux-wireless@...r.kernel.org, netdev@...r.kernel.org,
brcm80211-dev-list.pdl@...adcom.com,
SHA-cyfmac-dev-list@...ineon.com,
"Ivan T. Ivanov" <iivanov@...e.de>
Subject: [PATCH] brcmfmac: of: Use board compatible string for board type
When "brcm,board-type" is not explicitly set in devicetree
fallback to board compatible string for board type.
Some of the existing devices rely on the most compatible device
string to find best firmware files, including Raspberry PI's[1].
Fixes: 7682de8b3351 ("wifi: brcmfmac: of: Fetch Apple properties")
[1] https://bugzilla.opensuse.org/show_bug.cgi?id=1206697#c13
Signed-off-by: Ivan T. Ivanov <iivanov@...e.de>
---
drivers/net/wireless/broadcom/brcm80211/brcmfmac/of.c | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/of.c b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/of.c
index a83699de01ec..fdd0c9abc1a1 100644
--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/of.c
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/of.c
@@ -79,7 +79,8 @@ void brcmf_of_probe(struct device *dev, enum brcmf_bus_type bus_type,
/* Apple ARM64 platforms have their own idea of board type, passed in
* via the device tree. They also have an antenna SKU parameter
*/
- if (!of_property_read_string(np, "brcm,board-type", &prop))
+ err = of_property_read_string(np, "brcm,board-type", &prop);
+ if (!err)
settings->board_type = prop;
if (!of_property_read_string(np, "apple,antenna-sku", &prop))
@@ -87,7 +88,7 @@ void brcmf_of_probe(struct device *dev, enum brcmf_bus_type bus_type,
/* Set board-type to the first string of the machine compatible prop */
root = of_find_node_by_path("/");
- if (root && !settings->board_type) {
+ if (root && err) {
char *board_type;
const char *tmp;
--
2.35.3
Powered by blists - more mailing lists