OSDN Git Service

Bluetooth: hci_h5: btrtl: Add support for RTL8822C
authorMax Chou <max.chou@realtek.com>
Mon, 17 Feb 2020 08:14:55 +0000 (16:14 +0800)
committerMarcel Holtmann <marcel@holtmann.org>
Tue, 18 Feb 2020 08:22:22 +0000 (09:22 +0100)
Add new compatible and FW loading support for RTL8822C.

Signed-off-by: Max Chou <max.chou@realtek.com>
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
drivers/bluetooth/Kconfig
drivers/bluetooth/btrtl.c
drivers/bluetooth/hci_h5.c

index ca0356d..4e73a53 100644 (file)
@@ -211,7 +211,7 @@ config BT_HCIUART_RTL
        depends on BT_HCIUART
        depends on BT_HCIUART_SERDEV
        depends on GPIOLIB
-       depends on ACPI
+       depends on (ACPI || SERIAL_DEV_CTRL_TTYPORT)
        select BT_HCIUART_3WIRE
        select BT_RTL
        help
index 577cfa3..67f4bc2 100644 (file)
@@ -136,6 +136,18 @@ static const struct id_table ic_id_table[] = {
          .fw_name  = "rtl_bt/rtl8761a_fw.bin",
          .cfg_name = "rtl_bt/rtl8761a_config" },
 
+       /* 8822C with UART interface */
+       { .match_flags = IC_MATCH_FL_LMPSUBV | IC_MATCH_FL_HCIREV |
+                        IC_MATCH_FL_HCIBUS,
+         .lmp_subver = RTL_ROM_LMP_8822B,
+         .hci_rev = 0x000c,
+         .hci_ver = 0x0a,
+         .hci_bus = HCI_UART,
+         .config_needed = true,
+         .has_rom_version = true,
+         .fw_name  = "rtl_bt/rtl8822cs_fw.bin",
+         .cfg_name = "rtl_bt/rtl8822cs_config" },
+
        /* 8822C with USB interface */
        { IC_INFO(RTL_ROM_LMP_8822B, 0xc),
          .config_needed = false,
index 0b14547..1d81738 100644 (file)
@@ -11,6 +11,7 @@
 #include <linux/gpio/consumer.h>
 #include <linux/kernel.h>
 #include <linux/mod_devicetable.h>
+#include <linux/of_device.h>
 #include <linux/serdev.h>
 #include <linux/skbuff.h>
 
@@ -810,8 +811,17 @@ static int h5_serdev_probe(struct serdev_device *serdev)
                if (h5->vnd->acpi_gpio_map)
                        devm_acpi_dev_add_driver_gpios(dev,
                                                       h5->vnd->acpi_gpio_map);
+       } else {
+               const void *data;
+
+               data = of_device_get_match_data(dev);
+               if (!data)
+                       return -ENODEV;
+
+               h5->vnd = (const struct h5_vnd *)data;
        }
 
+
        h5->enable_gpio = devm_gpiod_get_optional(dev, "enable", GPIOD_OUT_LOW);
        if (IS_ERR(h5->enable_gpio))
                return PTR_ERR(h5->enable_gpio);
@@ -1003,6 +1013,15 @@ static const struct dev_pm_ops h5_serdev_pm_ops = {
        SET_SYSTEM_SLEEP_PM_OPS(h5_serdev_suspend, h5_serdev_resume)
 };
 
+static const struct of_device_id rtl_bluetooth_of_match[] = {
+#ifdef CONFIG_BT_HCIUART_RTL
+       { .compatible = "realtek,rtl8822cs-bt",
+         .data = (const void *)&rtl_vnd },
+#endif
+       { },
+};
+MODULE_DEVICE_TABLE(of, rtl_bluetooth_of_match);
+
 static struct serdev_device_driver h5_serdev_driver = {
        .probe = h5_serdev_probe,
        .remove = h5_serdev_remove,
@@ -1010,6 +1029,7 @@ static struct serdev_device_driver h5_serdev_driver = {
                .name = "hci_uart_h5",
                .acpi_match_table = ACPI_PTR(h5_acpi_match),
                .pm = &h5_serdev_pm_ops,
+               .of_match_table = rtl_bluetooth_of_match,
        },
 };