Bluetooth: Populate hci_set_hw_info for Intel and Realtek
authorArchie Pusaka <apusaka@chromium.org>
Mon, 22 Apr 2024 09:20:28 +0000 (17:20 +0800)
committerLuiz Augusto von Dentz <luiz.von.dentz@intel.com>
Tue, 14 May 2024 14:51:05 +0000 (10:51 -0400)
The hardware information surfaced via debugfs might be usable by the
userspace to set some configuration knobs. This patch sets the hw_info
for Intel and Realtek chipsets.

Below are some possible output of the hardware_info debugfs file.
INTEL platform=55 variant=24
RTL lmp_subver=34898 hci_rev=10 hci_ver=11 hci_bus=1

Signed-off-by: Archie Pusaka <apusaka@chromium.org>
Reviewed-by: Abhishek Pandit-Subedi <abhishekpandit@google.com>
Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
drivers/bluetooth/btintel.c
drivers/bluetooth/btrtl.c

index a19ebe47bd951080ef14ae46debbea60f5ec8c26..dc48352166a524ae1330ddeb64853ebf1bc2c023 100644 (file)
@@ -2956,6 +2956,11 @@ static int btintel_setup_combined(struct hci_dev *hdev)
                        err = -EINVAL;
                }
 
+               hci_set_hw_info(hdev,
+                               "INTEL platform=%u variant=%u revision=%u",
+                               ver.hw_platform, ver.hw_variant,
+                               ver.hw_revision);
+
                goto exit_error;
        }
 
@@ -3060,6 +3065,10 @@ static int btintel_setup_combined(struct hci_dev *hdev)
                break;
        }
 
+       hci_set_hw_info(hdev, "INTEL platform=%u variant=%u",
+                       INTEL_HW_PLATFORM(ver_tlv.cnvi_bt),
+                       INTEL_HW_VARIANT(ver_tlv.cnvi_bt));
+
 exit_error:
        kfree_skb(skb);
 
index cc50de69e8dc98cac6d388e18cfc0602ca6487c8..4f1e37b4f7802daceffc1ea46bd943215fcba4bd 100644 (file)
@@ -1339,6 +1339,13 @@ int btrtl_setup_realtek(struct hci_dev *hdev)
 
        btrtl_set_quirks(hdev, btrtl_dev);
 
+       hci_set_hw_info(hdev,
+                       "RTL lmp_subver=%u hci_rev=%u hci_ver=%u hci_bus=%u",
+                       btrtl_dev->ic_info->lmp_subver,
+                       btrtl_dev->ic_info->hci_rev,
+                       btrtl_dev->ic_info->hci_ver,
+                       btrtl_dev->ic_info->hci_bus);
+
        btrtl_free(btrtl_dev);
        return ret;
 }