Bluetooth: Expose current voice setting in debugfs
authorMarcel Holtmann <marcel@holtmann.org>
Thu, 17 Oct 2013 19:02:31 +0000 (12:02 -0700)
committerJohan Hedberg <johan.hedberg@intel.com>
Thu, 17 Oct 2013 20:55:58 +0000 (23:55 +0300)
For easier debugging of the current voice setting, expose the value
in debugfs if the controller is BR/EDR capable.

Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
net/bluetooth/hci_core.c

index 3c1014c2dcde02af9af58a9ee5e7dcaf7e112938..b7c4ada1beb6b3ac92e688406928375b62a96210 100644 (file)
@@ -93,6 +93,20 @@ static const struct file_operations inquiry_cache_fops = {
        .release        = single_release,
 };
 
+static int voice_setting_get(void *data, u64 *val)
+{
+       struct hci_dev *hdev = data;
+
+       hci_dev_lock(hdev);
+       *val = hdev->voice_setting;
+       hci_dev_unlock(hdev);
+
+       return 0;
+}
+
+DEFINE_SIMPLE_ATTRIBUTE(voice_setting_fops, voice_setting_get,
+                       NULL, "0x%4.4llx\n");
+
 static int auto_accept_delay_set(void *data, u64 val)
 {
        struct hci_dev *hdev = data;
@@ -833,6 +847,8 @@ static int __hci_init(struct hci_dev *hdev)
        if (lmp_bredr_capable(hdev)) {
                debugfs_create_file("inquiry_cache", 0444, hdev->debugfs,
                                    hdev, &inquiry_cache_fops);
+               debugfs_create_file("voice_setting", 0444, hdev->debugfs,
+                                   hdev, &voice_setting_fops);
        }
 
        if (lmp_ssp_capable(hdev))