]> www.infradead.org Git - nvme.git/commitdiff
Bluetooth: btnxpuart: Add support for AW693 A1 chipset
authorNeeraj Sanjay Kale <neeraj.sanjaykale@nxp.com>
Thu, 4 Jul 2024 13:20:57 +0000 (18:50 +0530)
committerLuiz Augusto von Dentz <luiz.von.dentz@intel.com>
Mon, 15 Jul 2024 14:11:59 +0000 (10:11 -0400)
This adds support for AW693 A1 chipset with it's bootloader signature
and firmware file.

No firmware name change needed for AW693 A0 chipset.

Signed-off-by: Neeraj Sanjay Kale <neeraj.sanjaykale@nxp.com>
Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
drivers/bluetooth/btnxpuart.c

index da18fd4f54f374cfc983a09605bbf2b84e764298..e81c995748da5f30a32134b173bb5d553aabf8ce 100644 (file)
@@ -46,6 +46,8 @@
 #define FIRMWARE_SECURE_IW624  "uartiw624_bt.bin.se"
 #define FIRMWARE_AW693         "uartaw693_bt.bin"
 #define FIRMWARE_SECURE_AW693  "uartaw693_bt.bin.se"
+#define FIRMWARE_AW693_A1              "uartaw693_bt_v1.bin"
+#define FIRMWARE_SECURE_AW693_A1       "uartaw693_bt_v1.bin.se"
 #define FIRMWARE_HELPER                "helper_uart_3000000.bin"
 
 #define CHIP_ID_W9098          0x5c03
@@ -53,7 +55,8 @@
 #define CHIP_ID_IW612          0x7601
 #define CHIP_ID_IW624a         0x8000
 #define CHIP_ID_IW624c         0x8001
-#define CHIP_ID_AW693          0x8200
+#define CHIP_ID_AW693a0                0x8200
+#define CHIP_ID_AW693a1                0x8201
 
 #define FW_SECURE_MASK         0xc0
 #define FW_OPEN                        0x00
@@ -906,7 +909,7 @@ static char *nxp_get_fw_name_from_chipid(struct hci_dev *hdev, u16 chipid,
                else
                        bt_dev_err(hdev, "Illegal loader version %02x", loader_ver);
                break;
-       case CHIP_ID_AW693:
+       case CHIP_ID_AW693a0:
                if ((loader_ver & FW_SECURE_MASK) == FW_OPEN)
                        fw_name = FIRMWARE_AW693;
                else if ((loader_ver & FW_SECURE_MASK) != FW_AUTH_ILLEGAL)
@@ -914,6 +917,14 @@ static char *nxp_get_fw_name_from_chipid(struct hci_dev *hdev, u16 chipid,
                else
                        bt_dev_err(hdev, "Illegal loader version %02x", loader_ver);
                break;
+       case CHIP_ID_AW693a1:
+               if ((loader_ver & FW_SECURE_MASK) == FW_OPEN)
+                       fw_name = FIRMWARE_AW693_A1;
+               else if ((loader_ver & FW_SECURE_MASK) != FW_AUTH_ILLEGAL)
+                       fw_name = FIRMWARE_SECURE_AW693_A1;
+               else
+                       bt_dev_err(hdev, "Illegal loader version %02x", loader_ver);
+               break;
        default:
                bt_dev_err(hdev, "Unknown chip signature %04x", chipid);
                break;