linux-wireless.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v2 0/3] Add BCM43752 chipset support
@ 2021-08-11 15:28 Angus Ainslie
  2021-08-11 15:28 ` [PATCH v2 1/3] brcmfmac: add 43752 device ids Angus Ainslie
                   ` (2 more replies)
  0 siblings, 3 replies; 8+ messages in thread
From: Angus Ainslie @ 2021-08-11 15:28 UTC (permalink / raw)
  To: kernel
  Cc: Arend van Spriel, Franky Lin, Kalle Valo, linux-wireless,
	brcm80211-dev-list.pdl, Angus Ainslie

The SparkLan AP6275 SDIO M.2 card contains a BCM43752 based module and these
patches were tested with that card.

This was tested on the 5.13 kernel with a minor substition BRCMF_FW_DEF for
BRCMF_FW_CLM_DEF.

It should apply and build on the wireless-next branch.

Changes since v1:

Add bluetooth patchram definition

Angus Ainslie (3):
  brcmfmac: add 43752 device ids
  brcmfmac: add initializers for the 43752
  brcmfmac: add patch ram for bluetooth

 drivers/bluetooth/btbcm.c                                 | 1 +
 drivers/net/wireless/broadcom/brcm80211/brcmfmac/bcmsdh.c | 1 +
 drivers/net/wireless/broadcom/brcm80211/brcmfmac/chip.c   | 3 +++
 drivers/net/wireless/broadcom/brcm80211/brcmfmac/sdio.c   | 8 ++++++--
 .../net/wireless/broadcom/brcm80211/include/brcm_hw_ids.h | 1 +
 include/linux/mmc/sdio_ids.h                              | 1 +
 6 files changed, 13 insertions(+), 2 deletions(-)

-- 
2.25.1


^ permalink raw reply	[flat|nested] 8+ messages in thread

* [PATCH v2 1/3] brcmfmac: add 43752 device ids
  2021-08-11 15:28 [PATCH v2 0/3] Add BCM43752 chipset support Angus Ainslie
@ 2021-08-11 15:28 ` Angus Ainslie
  2021-08-11 15:28 ` [PATCH v2 2/3] brcmfmac: add initializers for the 43752 Angus Ainslie
  2021-08-11 15:28 ` [PATCH v2 3/3] brcmfmac: add patch ram for bluetooth Angus Ainslie
  2 siblings, 0 replies; 8+ messages in thread
From: Angus Ainslie @ 2021-08-11 15:28 UTC (permalink / raw)
  To: kernel
  Cc: Arend van Spriel, Franky Lin, Kalle Valo, linux-wireless,
	brcm80211-dev-list.pdl, Angus Ainslie

Add HW and SDIO ids for use with the SparkLan AP6275S

Signed-off-by: Angus Ainslie <angus@akkea.ca>
---
 drivers/net/wireless/broadcom/brcm80211/brcmfmac/bcmsdh.c     | 1 +
 drivers/net/wireless/broadcom/brcm80211/brcmfmac/chip.c       | 2 ++
 drivers/net/wireless/broadcom/brcm80211/include/brcm_hw_ids.h | 1 +
 include/linux/mmc/sdio_ids.h                                  | 1 +
 4 files changed, 5 insertions(+)

diff --git a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/bcmsdh.c b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/bcmsdh.c
index 633d0ab19031..485ddeb436ae 100644
--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/bcmsdh.c
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/bcmsdh.c
@@ -990,6 +990,7 @@ static const struct sdio_device_id brcmf_sdmmc_ids[] = {
 	BRCMF_SDIO_DEVICE(SDIO_DEVICE_ID_BROADCOM_4359),
 	BRCMF_SDIO_DEVICE(SDIO_DEVICE_ID_BROADCOM_CYPRESS_4373),
 	BRCMF_SDIO_DEVICE(SDIO_DEVICE_ID_BROADCOM_CYPRESS_43012),
+	BRCMF_SDIO_DEVICE(SDIO_DEVICE_ID_BROADCOM_CYPRESS_43752),
 	BRCMF_SDIO_DEVICE(SDIO_DEVICE_ID_BROADCOM_CYPRESS_89359),
 	{ /* end: all zeroes */ }
 };
diff --git a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/chip.c b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/chip.c
index 45037decba40..c9954da6c5cd 100644
--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/chip.c
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/chip.c
@@ -727,6 +727,8 @@ static u32 brcmf_chip_tcm_rambase(struct brcmf_chip_priv *ci)
 	case BRCM_CC_4364_CHIP_ID:
 	case CY_CC_4373_CHIP_ID:
 		return 0x160000;
+	case CY_CC_43752_CHIP_ID:
+		return 0x170000;
 	default:
 		brcmf_err("unknown chip: %s\n", ci->pub.name);
 		break;
diff --git a/drivers/net/wireless/broadcom/brcm80211/include/brcm_hw_ids.h b/drivers/net/wireless/broadcom/brcm80211/include/brcm_hw_ids.h
index 00309b272a0e..9d81320164ce 100644
--- a/drivers/net/wireless/broadcom/brcm80211/include/brcm_hw_ids.h
+++ b/drivers/net/wireless/broadcom/brcm80211/include/brcm_hw_ids.h
@@ -52,6 +52,7 @@
 #define BRCM_CC_4371_CHIP_ID		0x4371
 #define CY_CC_4373_CHIP_ID		0x4373
 #define CY_CC_43012_CHIP_ID		43012
+#define CY_CC_43752_CHIP_ID		43752
 
 /* USB Device IDs */
 #define BRCM_USB_43143_DEVICE_ID	0xbd1e
diff --git a/include/linux/mmc/sdio_ids.h b/include/linux/mmc/sdio_ids.h
index 12036619346c..a85c9f0bd470 100644
--- a/include/linux/mmc/sdio_ids.h
+++ b/include/linux/mmc/sdio_ids.h
@@ -75,6 +75,7 @@
 #define SDIO_DEVICE_ID_BROADCOM_43364		0xa9a4
 #define SDIO_DEVICE_ID_BROADCOM_43430		0xa9a6
 #define SDIO_DEVICE_ID_BROADCOM_43455		0xa9bf
+#define SDIO_DEVICE_ID_BROADCOM_CYPRESS_43752	0xaae8
 
 #define SDIO_VENDOR_ID_MARVELL			0x02df
 #define SDIO_DEVICE_ID_MARVELL_LIBERTAS		0x9103
-- 
2.25.1


^ permalink raw reply related	[flat|nested] 8+ messages in thread

* [PATCH v2 2/3] brcmfmac: add initializers for the 43752
  2021-08-11 15:28 [PATCH v2 0/3] Add BCM43752 chipset support Angus Ainslie
  2021-08-11 15:28 ` [PATCH v2 1/3] brcmfmac: add 43752 device ids Angus Ainslie
@ 2021-08-11 15:28 ` Angus Ainslie
  2021-08-12 11:36   ` Arend van Spriel
  2021-08-11 15:28 ` [PATCH v2 3/3] brcmfmac: add patch ram for bluetooth Angus Ainslie
  2 siblings, 1 reply; 8+ messages in thread
From: Angus Ainslie @ 2021-08-11 15:28 UTC (permalink / raw)
  To: kernel
  Cc: Arend van Spriel, Franky Lin, Kalle Valo, linux-wireless,
	brcm80211-dev-list.pdl, Angus Ainslie

Add the firmware mapping structures for the BRCM43752 chipset.
The 43752 needs some things setup similar to the 43012 chipset.
The WATERMARK shows better performance when initialized to the 4373 value.

Signed-off-by: Angus Ainslie <angus@akkea.ca>
---
 drivers/net/wireless/broadcom/brcm80211/brcmfmac/chip.c | 1 +
 drivers/net/wireless/broadcom/brcm80211/brcmfmac/sdio.c | 8 ++++++--
 2 files changed, 7 insertions(+), 2 deletions(-)

diff --git a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/chip.c b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/chip.c
index c9954da6c5cd..cc41ba5421f4 100644
--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/chip.c
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/chip.c
@@ -1413,6 +1413,7 @@ bool brcmf_chip_sr_capable(struct brcmf_chip *pub)
 		reg = chip->ops->read32(chip->ctx, addr);
 		return (reg & CC_SR_CTL0_ENABLE_MASK) != 0;
 	case BRCM_CC_4359_CHIP_ID:
+	case CY_CC_43752_CHIP_ID:
 	case CY_CC_43012_CHIP_ID:
 		addr = CORE_CC_REG(pmu->base, retention_ctl);
 		reg = chip->ops->read32(chip->ctx, addr);
diff --git a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/sdio.c b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/sdio.c
index 97ee9e2e2e35..84d8ddff2aef 100644
--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/sdio.c
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/sdio.c
@@ -624,6 +624,7 @@ BRCMF_FW_CLM_DEF(4356, "brcmfmac4356-sdio");
 BRCMF_FW_DEF(4359, "brcmfmac4359-sdio");
 BRCMF_FW_CLM_DEF(4373, "brcmfmac4373-sdio");
 BRCMF_FW_CLM_DEF(43012, "brcmfmac43012-sdio");
+BRCMF_FW_CLM_DEF(43752, "brcmfmac43752-sdio");
 
 /* firmware config files */
 MODULE_FIRMWARE(BRCMF_FW_DEFAULT_PATH "brcmfmac*-sdio.*.txt");
@@ -650,7 +651,8 @@ static const struct brcmf_firmware_mapping brcmf_sdio_fwnames[] = {
 	BRCMF_FW_ENTRY(BRCM_CC_4356_CHIP_ID, 0xFFFFFFFF, 4356),
 	BRCMF_FW_ENTRY(BRCM_CC_4359_CHIP_ID, 0xFFFFFFFF, 4359),
 	BRCMF_FW_ENTRY(CY_CC_4373_CHIP_ID, 0xFFFFFFFF, 4373),
-	BRCMF_FW_ENTRY(CY_CC_43012_CHIP_ID, 0xFFFFFFFF, 43012)
+	BRCMF_FW_ENTRY(CY_CC_43012_CHIP_ID, 0xFFFFFFFF, 43012),
+	BRCMF_FW_ENTRY(CY_CC_43752_CHIP_ID, 0xFFFFFFFF, 43752)
 };
 
 #define TXCTL_CREDITS	2
@@ -3416,7 +3418,8 @@ static int brcmf_sdio_download_firmware(struct brcmf_sdio *bus,
 
 static bool brcmf_sdio_aos_no_decode(struct brcmf_sdio *bus)
 {
-	if (bus->ci->chip == CY_CC_43012_CHIP_ID)
+	if (bus->ci->chip == CY_CC_43012_CHIP_ID ||
+	    bus->ci->chip == CY_CC_43752_CHIP_ID)
 		return true;
 	else
 		return false;
@@ -4257,6 +4260,7 @@ static void brcmf_sdio_firmware_callback(struct device *dev, int err,
 
 		switch (sdiod->func1->device) {
 		case SDIO_DEVICE_ID_BROADCOM_CYPRESS_4373:
+		case SDIO_DEVICE_ID_BROADCOM_CYPRESS_43752:
 			brcmf_dbg(INFO, "set F2 watermark to 0x%x*4 bytes\n",
 				  CY_4373_F2_WATERMARK);
 			brcmf_sdiod_writeb(sdiod, SBSDIO_WATERMARK,
-- 
2.25.1


^ permalink raw reply related	[flat|nested] 8+ messages in thread

* [PATCH v2 3/3] brcmfmac: add patch ram for bluetooth
  2021-08-11 15:28 [PATCH v2 0/3] Add BCM43752 chipset support Angus Ainslie
  2021-08-11 15:28 ` [PATCH v2 1/3] brcmfmac: add 43752 device ids Angus Ainslie
  2021-08-11 15:28 ` [PATCH v2 2/3] brcmfmac: add initializers for the 43752 Angus Ainslie
@ 2021-08-11 15:28 ` Angus Ainslie
  2021-08-12 11:40   ` Arend van Spriel
  2 siblings, 1 reply; 8+ messages in thread
From: Angus Ainslie @ 2021-08-11 15:28 UTC (permalink / raw)
  To: kernel
  Cc: Arend van Spriel, Franky Lin, Kalle Valo, linux-wireless,
	brcm80211-dev-list.pdl, Angus Ainslie

Bluetooth on the BCM43752 needs a patchram file to function correctly.

Signed-off-by: Angus Ainslie <angus@akkea.ca>
---
 drivers/bluetooth/btbcm.c | 1 +
 1 file changed, 1 insertion(+)

diff --git a/drivers/bluetooth/btbcm.c b/drivers/bluetooth/btbcm.c
index e5d706ed55ea..e4182acee488 100644
--- a/drivers/bluetooth/btbcm.c
+++ b/drivers/bluetooth/btbcm.c
@@ -387,6 +387,7 @@ struct bcm_subver_table {
 };
 
 static const struct bcm_subver_table bcm_uart_subver_table[] = {
+	{ 0x1111, "BCM4362A2"	},	/* 000.017.017 */
 	{ 0x4103, "BCM4330B1"	},	/* 002.001.003 */
 	{ 0x410d, "BCM4334B0"	},	/* 002.001.013 */
 	{ 0x410e, "BCM43341B0"	},	/* 002.001.014 */
-- 
2.25.1


^ permalink raw reply related	[flat|nested] 8+ messages in thread

* Re: [PATCH v2 2/3] brcmfmac: add initializers for the 43752
  2021-08-11 15:28 ` [PATCH v2 2/3] brcmfmac: add initializers for the 43752 Angus Ainslie
@ 2021-08-12 11:36   ` Arend van Spriel
  0 siblings, 0 replies; 8+ messages in thread
From: Arend van Spriel @ 2021-08-12 11:36 UTC (permalink / raw)
  To: Angus Ainslie, kernel
  Cc: Arend van Spriel, Franky Lin, Kalle Valo, linux-wireless,
	brcm80211-dev-list.pdl

[-- Attachment #1: Type: text/plain, Size: 1410 bytes --]

On 8/11/2021 5:28 PM, Angus Ainslie wrote:
> Add the firmware mapping structures for the BRCM43752 chipset.
> The 43752 needs some things setup similar to the 43012 chipset.
> The WATERMARK shows better performance when initialized to the 4373 value.

Don't see much value in having this in separate patch. Please collapse 
with the first patch in this series.

Regards,
Arend

> Signed-off-by: Angus Ainslie <angus@akkea.ca>
> ---
>   drivers/net/wireless/broadcom/brcm80211/brcmfmac/chip.c | 1 +
>   drivers/net/wireless/broadcom/brcm80211/brcmfmac/sdio.c | 8 ++++++--
>   2 files changed, 7 insertions(+), 2 deletions(-)

-- 
This electronic communication and the information and any files transmitted 
with it, or attached to it, are confidential and are intended solely for 
the use of the individual or entity to whom it is addressed and may contain 
information that is confidential, legally privileged, protected by privacy 
laws, or otherwise restricted from disclosure to anyone else. If you are 
not the intended recipient or the person responsible for delivering the 
e-mail to the intended recipient, you are hereby notified that any use, 
copying, distributing, dissemination, forwarding, printing, or copying of 
this e-mail is strictly prohibited. If you received this e-mail in error, 
please return the e-mail to the sender, delete it from your computer, and 
destroy any printed copy of it.

[-- Attachment #2: S/MIME Cryptographic Signature --]
[-- Type: application/pkcs7-signature, Size: 4219 bytes --]

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH v2 3/3] brcmfmac: add patch ram for bluetooth
  2021-08-11 15:28 ` [PATCH v2 3/3] brcmfmac: add patch ram for bluetooth Angus Ainslie
@ 2021-08-12 11:40   ` Arend van Spriel
  2021-08-12 11:42     ` Arend van Spriel
  0 siblings, 1 reply; 8+ messages in thread
From: Arend van Spriel @ 2021-08-12 11:40 UTC (permalink / raw)
  To: Angus Ainslie, kernel
  Cc: Arend van Spriel, Franky Lin, Kalle Valo, linux-wireless,
	brcm80211-dev-list.pdl

[-- Attachment #1: Type: text/plain, Size: 1689 bytes --]

On 8/11/2021 5:28 PM, Angus Ainslie wrote:
> Bluetooth on the BCM43752 needs a patchram file to function correctly.

this patch is dealing with bluetooth so you should add the proper 
mailing list.

> Signed-off-by: Angus Ainslie <angus@akkea.ca>
> ---
>   drivers/bluetooth/btbcm.c | 1 +
>   1 file changed, 1 insertion(+)
> 
> diff --git a/drivers/bluetooth/btbcm.c b/drivers/bluetooth/btbcm.c
> index e5d706ed55ea..e4182acee488 100644
> --- a/drivers/bluetooth/btbcm.c
> +++ b/drivers/bluetooth/btbcm.c
> @@ -387,6 +387,7 @@ struct bcm_subver_table {
>   };
>   
>   static const struct bcm_subver_table bcm_uart_subver_table[] = {
> +	{ 0x1111, "BCM4362A2"	},	/* 000.017.017 */

This seems odd. 4362 vs 43752? What is the story here?

Regards,
Arend

>   	{ 0x4103, "BCM4330B1"	},	/* 002.001.003 */
>   	{ 0x410d, "BCM4334B0"	},	/* 002.001.013 */
>   	{ 0x410e, "BCM43341B0"	},	/* 002.001.014 */
> 

-- 
This electronic communication and the information and any files transmitted 
with it, or attached to it, are confidential and are intended solely for 
the use of the individual or entity to whom it is addressed and may contain 
information that is confidential, legally privileged, protected by privacy 
laws, or otherwise restricted from disclosure to anyone else. If you are 
not the intended recipient or the person responsible for delivering the 
e-mail to the intended recipient, you are hereby notified that any use, 
copying, distributing, dissemination, forwarding, printing, or copying of 
this e-mail is strictly prohibited. If you received this e-mail in error, 
please return the e-mail to the sender, delete it from your computer, and 
destroy any printed copy of it.

[-- Attachment #2: S/MIME Cryptographic Signature --]
[-- Type: application/pkcs7-signature, Size: 4219 bytes --]

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH v2 3/3] brcmfmac: add patch ram for bluetooth
  2021-08-12 11:40   ` Arend van Spriel
@ 2021-08-12 11:42     ` Arend van Spriel
  2021-08-12 13:01       ` Angus Ainslie
  0 siblings, 1 reply; 8+ messages in thread
From: Arend van Spriel @ 2021-08-12 11:42 UTC (permalink / raw)
  To: Angus Ainslie, kernel
  Cc: Arend van Spriel, Franky Lin, Kalle Valo, linux-wireless,
	brcm80211-dev-list.pdl

[-- Attachment #1: Type: text/plain, Size: 1153 bytes --]

On 8/12/2021 1:40 PM, Arend van Spriel wrote:
> On 8/11/2021 5:28 PM, Angus Ainslie wrote:
>> Bluetooth on the BCM43752 needs a patchram file to function correctly.
> 
> this patch is dealing with bluetooth so you should add the proper 
> mailing list.

...and the 'brcmfmac:' prefix in the subject is inappropriate. It should 
  be 'btbcm:' instead.

Regards,
Arend

-- 
This electronic communication and the information and any files transmitted 
with it, or attached to it, are confidential and are intended solely for 
the use of the individual or entity to whom it is addressed and may contain 
information that is confidential, legally privileged, protected by privacy 
laws, or otherwise restricted from disclosure to anyone else. If you are 
not the intended recipient or the person responsible for delivering the 
e-mail to the intended recipient, you are hereby notified that any use, 
copying, distributing, dissemination, forwarding, printing, or copying of 
this e-mail is strictly prohibited. If you received this e-mail in error, 
please return the e-mail to the sender, delete it from your computer, and 
destroy any printed copy of it.

[-- Attachment #2: S/MIME Cryptographic Signature --]
[-- Type: application/pkcs7-signature, Size: 4219 bytes --]

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH v2 3/3] brcmfmac: add patch ram for bluetooth
  2021-08-12 11:42     ` Arend van Spriel
@ 2021-08-12 13:01       ` Angus Ainslie
  0 siblings, 0 replies; 8+ messages in thread
From: Angus Ainslie @ 2021-08-12 13:01 UTC (permalink / raw)
  To: Arend van Spriel
  Cc: kernel, Arend van Spriel, Franky Lin, Kalle Valo, linux-wireless,
	brcm80211-dev-list.pdl

Hi Arend,

On 2021-08-12 04:42, Arend van Spriel wrote:
> On 8/12/2021 1:40 PM, Arend van Spriel wrote:
>> On 8/11/2021 5:28 PM, Angus Ainslie wrote:
>>> Bluetooth on the BCM43752 needs a patchram file to function 
>>> correctly.
>> 
>> this patch is dealing with bluetooth so you should add the proper 
>> mailing list.
> 
> ...and the 'brcmfmac:' prefix in the subject is inappropriate. It
> should  be 'btbcm:' instead.
> 

Thanks for looking at the patches I'll fix them up for v3.

Angus

> Regards,
> Arend

^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2021-08-12 13:02 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-08-11 15:28 [PATCH v2 0/3] Add BCM43752 chipset support Angus Ainslie
2021-08-11 15:28 ` [PATCH v2 1/3] brcmfmac: add 43752 device ids Angus Ainslie
2021-08-11 15:28 ` [PATCH v2 2/3] brcmfmac: add initializers for the 43752 Angus Ainslie
2021-08-12 11:36   ` Arend van Spriel
2021-08-11 15:28 ` [PATCH v2 3/3] brcmfmac: add patch ram for bluetooth Angus Ainslie
2021-08-12 11:40   ` Arend van Spriel
2021-08-12 11:42     ` Arend van Spriel
2021-08-12 13:01       ` Angus Ainslie

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).