2 BlueZ - Bluetooth protocol stack for Linux
4 Copyright (C) 2014 Intel Corporation
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License version 2 as
8 published by the Free Software Foundation;
10 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
11 OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
12 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS.
13 IN NO EVENT SHALL THE COPYRIGHT HOLDER(S) AND AUTHOR(S) BE LIABLE FOR ANY
14 CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES
15 WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
16 ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
17 OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
19 ALL LIABILITY, INCLUDING LIABILITY FOR INFRINGEMENT OF ANY PATENTS,
20 COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS, RELATING TO USE OF THIS
21 SOFTWARE IS DISCLAIMED.
24 #include <linux/debugfs.h>
26 #include <net/bluetooth/bluetooth.h>
27 #include <net/bluetooth/hci_core.h>
30 #include "hci_request.h"
31 #include "hci_debugfs.h"
33 #define DEFINE_QUIRK_ATTRIBUTE(__name, __quirk) \
34 static ssize_t __name ## _read(struct file *file, \
35 char __user *user_buf, \
36 size_t count, loff_t *ppos) \
38 struct hci_dev *hdev = file->private_data; \
41 buf[0] = test_bit(__quirk, &hdev->quirks) ? 'Y' : 'N'; \
44 return simple_read_from_buffer(user_buf, count, ppos, buf, 2); \
47 static ssize_t __name ## _write(struct file *file, \
48 const char __user *user_buf, \
49 size_t count, loff_t *ppos) \
51 struct hci_dev *hdev = file->private_data; \
55 if (test_bit(HCI_UP, &hdev->flags)) \
58 err = kstrtobool_from_user(user_buf, count, &enable); \
62 if (enable == test_bit(__quirk, &hdev->quirks)) \
65 change_bit(__quirk, &hdev->quirks); \
70 static const struct file_operations __name ## _fops = { \
71 .open = simple_open, \
72 .read = __name ## _read, \
73 .write = __name ## _write, \
74 .llseek = default_llseek, \
77 #define DEFINE_INFO_ATTRIBUTE(__name, __field) \
78 static int __name ## _show(struct seq_file *f, void *ptr) \
80 struct hci_dev *hdev = f->private; \
83 seq_printf(f, "%s\n", hdev->__field ? : ""); \
84 hci_dev_unlock(hdev); \
89 DEFINE_SHOW_ATTRIBUTE(__name)
91 static int features_show(struct seq_file *f, void *ptr)
93 struct hci_dev *hdev = f->private;
97 for (p = 0; p < HCI_MAX_PAGES && p <= hdev->max_page; p++)
98 seq_printf(f, "%2u: %8ph\n", p, hdev->features[p]);
99 if (lmp_le_capable(hdev))
100 seq_printf(f, "LE: %8ph\n", hdev->le_features);
101 hci_dev_unlock(hdev);
106 DEFINE_SHOW_ATTRIBUTE(features);
108 static int device_id_show(struct seq_file *f, void *ptr)
110 struct hci_dev *hdev = f->private;
113 seq_printf(f, "%4.4x:%4.4x:%4.4x:%4.4x\n", hdev->devid_source,
114 hdev->devid_vendor, hdev->devid_product, hdev->devid_version);
115 hci_dev_unlock(hdev);
120 DEFINE_SHOW_ATTRIBUTE(device_id);
122 static int device_list_show(struct seq_file *f, void *ptr)
124 struct hci_dev *hdev = f->private;
125 struct hci_conn_params *p;
126 struct bdaddr_list *b;
129 list_for_each_entry(b, &hdev->accept_list, list)
130 seq_printf(f, "%pMR (type %u)\n", &b->bdaddr, b->bdaddr_type);
131 list_for_each_entry(p, &hdev->le_conn_params, list) {
132 seq_printf(f, "%pMR (type %u) %u\n", &p->addr, p->addr_type,
135 hci_dev_unlock(hdev);
140 DEFINE_SHOW_ATTRIBUTE(device_list);
142 static int blacklist_show(struct seq_file *f, void *p)
144 struct hci_dev *hdev = f->private;
145 struct bdaddr_list *b;
148 list_for_each_entry(b, &hdev->reject_list, list)
149 seq_printf(f, "%pMR (type %u)\n", &b->bdaddr, b->bdaddr_type);
150 hci_dev_unlock(hdev);
155 DEFINE_SHOW_ATTRIBUTE(blacklist);
157 static int blocked_keys_show(struct seq_file *f, void *p)
159 struct hci_dev *hdev = f->private;
160 struct blocked_key *key;
163 list_for_each_entry_rcu(key, &hdev->blocked_keys, list)
164 seq_printf(f, "%u %*phN\n", key->type, 16, key->val);
170 DEFINE_SHOW_ATTRIBUTE(blocked_keys);
172 static int uuids_show(struct seq_file *f, void *p)
174 struct hci_dev *hdev = f->private;
175 struct bt_uuid *uuid;
178 list_for_each_entry(uuid, &hdev->uuids, list) {
181 /* The Bluetooth UUID values are stored in big endian,
182 * but with reversed byte order. So convert them into
183 * the right order for the %pUb modifier.
185 for (i = 0; i < 16; i++)
186 val[i] = uuid->uuid[15 - i];
188 seq_printf(f, "%pUb\n", val);
190 hci_dev_unlock(hdev);
195 DEFINE_SHOW_ATTRIBUTE(uuids);
197 static int remote_oob_show(struct seq_file *f, void *ptr)
199 struct hci_dev *hdev = f->private;
200 struct oob_data *data;
203 list_for_each_entry(data, &hdev->remote_oob_data, list) {
204 seq_printf(f, "%pMR (type %u) %u %*phN %*phN %*phN %*phN\n",
205 &data->bdaddr, data->bdaddr_type, data->present,
206 16, data->hash192, 16, data->rand192,
207 16, data->hash256, 16, data->rand256);
209 hci_dev_unlock(hdev);
214 DEFINE_SHOW_ATTRIBUTE(remote_oob);
216 static int conn_info_min_age_set(void *data, u64 val)
218 struct hci_dev *hdev = data;
221 if (val == 0 || val > hdev->conn_info_max_age) {
222 hci_dev_unlock(hdev);
226 hdev->conn_info_min_age = val;
227 hci_dev_unlock(hdev);
232 static int conn_info_min_age_get(void *data, u64 *val)
234 struct hci_dev *hdev = data;
237 *val = hdev->conn_info_min_age;
238 hci_dev_unlock(hdev);
243 DEFINE_DEBUGFS_ATTRIBUTE(conn_info_min_age_fops, conn_info_min_age_get,
244 conn_info_min_age_set, "%llu\n");
246 static int conn_info_max_age_set(void *data, u64 val)
248 struct hci_dev *hdev = data;
251 if (val == 0 || val < hdev->conn_info_min_age) {
252 hci_dev_unlock(hdev);
256 hdev->conn_info_max_age = val;
257 hci_dev_unlock(hdev);
262 static int conn_info_max_age_get(void *data, u64 *val)
264 struct hci_dev *hdev = data;
267 *val = hdev->conn_info_max_age;
268 hci_dev_unlock(hdev);
273 DEFINE_DEBUGFS_ATTRIBUTE(conn_info_max_age_fops, conn_info_max_age_get,
274 conn_info_max_age_set, "%llu\n");
276 static ssize_t use_debug_keys_read(struct file *file, char __user *user_buf,
277 size_t count, loff_t *ppos)
279 struct hci_dev *hdev = file->private_data;
282 buf[0] = hci_dev_test_flag(hdev, HCI_USE_DEBUG_KEYS) ? 'Y' : 'N';
285 return simple_read_from_buffer(user_buf, count, ppos, buf, 2);
288 static const struct file_operations use_debug_keys_fops = {
290 .read = use_debug_keys_read,
291 .llseek = default_llseek,
294 static ssize_t sc_only_mode_read(struct file *file, char __user *user_buf,
295 size_t count, loff_t *ppos)
297 struct hci_dev *hdev = file->private_data;
300 buf[0] = hci_dev_test_flag(hdev, HCI_SC_ONLY) ? 'Y' : 'N';
303 return simple_read_from_buffer(user_buf, count, ppos, buf, 2);
306 static const struct file_operations sc_only_mode_fops = {
308 .read = sc_only_mode_read,
309 .llseek = default_llseek,
312 DEFINE_INFO_ATTRIBUTE(hardware_info, hw_info);
313 DEFINE_INFO_ATTRIBUTE(firmware_info, fw_info);
315 void hci_debugfs_create_common(struct hci_dev *hdev)
317 debugfs_create_file("features", 0444, hdev->debugfs, hdev,
319 debugfs_create_u16("manufacturer", 0444, hdev->debugfs,
320 &hdev->manufacturer);
321 debugfs_create_u8("hci_version", 0444, hdev->debugfs, &hdev->hci_ver);
322 debugfs_create_u16("hci_revision", 0444, hdev->debugfs, &hdev->hci_rev);
323 debugfs_create_u8("hardware_error", 0444, hdev->debugfs,
324 &hdev->hw_error_code);
325 debugfs_create_file("device_id", 0444, hdev->debugfs, hdev,
328 debugfs_create_file("device_list", 0444, hdev->debugfs, hdev,
330 debugfs_create_file("blacklist", 0444, hdev->debugfs, hdev,
332 debugfs_create_file("blocked_keys", 0444, hdev->debugfs, hdev,
334 debugfs_create_file("uuids", 0444, hdev->debugfs, hdev, &uuids_fops);
335 debugfs_create_file("remote_oob", 0400, hdev->debugfs, hdev,
338 debugfs_create_file("conn_info_min_age", 0644, hdev->debugfs, hdev,
339 &conn_info_min_age_fops);
340 debugfs_create_file("conn_info_max_age", 0644, hdev->debugfs, hdev,
341 &conn_info_max_age_fops);
343 if (lmp_ssp_capable(hdev) || lmp_le_capable(hdev))
344 debugfs_create_file("use_debug_keys", 0444, hdev->debugfs,
345 hdev, &use_debug_keys_fops);
347 if (lmp_sc_capable(hdev) || lmp_le_capable(hdev))
348 debugfs_create_file("sc_only_mode", 0444, hdev->debugfs,
349 hdev, &sc_only_mode_fops);
352 debugfs_create_file("hardware_info", 0444, hdev->debugfs,
353 hdev, &hardware_info_fops);
356 debugfs_create_file("firmware_info", 0444, hdev->debugfs,
357 hdev, &firmware_info_fops);
360 static int inquiry_cache_show(struct seq_file *f, void *p)
362 struct hci_dev *hdev = f->private;
363 struct discovery_state *cache = &hdev->discovery;
364 struct inquiry_entry *e;
368 list_for_each_entry(e, &cache->all, all) {
369 struct inquiry_data *data = &e->data;
370 seq_printf(f, "%pMR %d %d %d 0x%.2x%.2x%.2x 0x%.4x %d %d %u\n",
372 data->pscan_rep_mode, data->pscan_period_mode,
373 data->pscan_mode, data->dev_class[2],
374 data->dev_class[1], data->dev_class[0],
375 __le16_to_cpu(data->clock_offset),
376 data->rssi, data->ssp_mode, e->timestamp);
379 hci_dev_unlock(hdev);
384 DEFINE_SHOW_ATTRIBUTE(inquiry_cache);
386 static int link_keys_show(struct seq_file *f, void *ptr)
388 struct hci_dev *hdev = f->private;
389 struct link_key *key;
392 list_for_each_entry_rcu(key, &hdev->link_keys, list)
393 seq_printf(f, "%pMR %u %*phN %u\n", &key->bdaddr, key->type,
394 HCI_LINK_KEY_SIZE, key->val, key->pin_len);
400 DEFINE_SHOW_ATTRIBUTE(link_keys);
402 static int dev_class_show(struct seq_file *f, void *ptr)
404 struct hci_dev *hdev = f->private;
407 seq_printf(f, "0x%.2x%.2x%.2x\n", hdev->dev_class[2],
408 hdev->dev_class[1], hdev->dev_class[0]);
409 hci_dev_unlock(hdev);
414 DEFINE_SHOW_ATTRIBUTE(dev_class);
416 static int voice_setting_get(void *data, u64 *val)
418 struct hci_dev *hdev = data;
421 *val = hdev->voice_setting;
422 hci_dev_unlock(hdev);
427 DEFINE_DEBUGFS_ATTRIBUTE(voice_setting_fops, voice_setting_get,
428 NULL, "0x%4.4llx\n");
430 static ssize_t ssp_debug_mode_read(struct file *file, char __user *user_buf,
431 size_t count, loff_t *ppos)
433 struct hci_dev *hdev = file->private_data;
436 buf[0] = hdev->ssp_debug_mode ? 'Y' : 'N';
439 return simple_read_from_buffer(user_buf, count, ppos, buf, 2);
442 static const struct file_operations ssp_debug_mode_fops = {
444 .read = ssp_debug_mode_read,
445 .llseek = default_llseek,
448 static int auto_accept_delay_set(void *data, u64 val)
450 struct hci_dev *hdev = data;
453 hdev->auto_accept_delay = val;
454 hci_dev_unlock(hdev);
459 static int min_encrypt_key_size_set(void *data, u64 val)
461 struct hci_dev *hdev = data;
463 if (val < 1 || val > 16)
467 hdev->min_enc_key_size = val;
468 hci_dev_unlock(hdev);
473 static int min_encrypt_key_size_get(void *data, u64 *val)
475 struct hci_dev *hdev = data;
478 *val = hdev->min_enc_key_size;
479 hci_dev_unlock(hdev);
484 DEFINE_DEBUGFS_ATTRIBUTE(min_encrypt_key_size_fops,
485 min_encrypt_key_size_get,
486 min_encrypt_key_size_set, "%llu\n");
488 static int auto_accept_delay_get(void *data, u64 *val)
490 struct hci_dev *hdev = data;
493 *val = hdev->auto_accept_delay;
494 hci_dev_unlock(hdev);
499 DEFINE_DEBUGFS_ATTRIBUTE(auto_accept_delay_fops, auto_accept_delay_get,
500 auto_accept_delay_set, "%llu\n");
502 static ssize_t force_bredr_smp_read(struct file *file,
503 char __user *user_buf,
504 size_t count, loff_t *ppos)
506 struct hci_dev *hdev = file->private_data;
509 buf[0] = hci_dev_test_flag(hdev, HCI_FORCE_BREDR_SMP) ? 'Y' : 'N';
512 return simple_read_from_buffer(user_buf, count, ppos, buf, 2);
515 static ssize_t force_bredr_smp_write(struct file *file,
516 const char __user *user_buf,
517 size_t count, loff_t *ppos)
519 struct hci_dev *hdev = file->private_data;
523 err = kstrtobool_from_user(user_buf, count, &enable);
527 err = smp_force_bredr(hdev, enable);
534 static const struct file_operations force_bredr_smp_fops = {
536 .read = force_bredr_smp_read,
537 .write = force_bredr_smp_write,
538 .llseek = default_llseek,
541 static int idle_timeout_set(void *data, u64 val)
543 struct hci_dev *hdev = data;
545 if (val != 0 && (val < 500 || val > 3600000))
549 hdev->idle_timeout = val;
550 hci_dev_unlock(hdev);
555 static int idle_timeout_get(void *data, u64 *val)
557 struct hci_dev *hdev = data;
560 *val = hdev->idle_timeout;
561 hci_dev_unlock(hdev);
566 DEFINE_DEBUGFS_ATTRIBUTE(idle_timeout_fops, idle_timeout_get,
567 idle_timeout_set, "%llu\n");
569 static int sniff_min_interval_set(void *data, u64 val)
571 struct hci_dev *hdev = data;
574 if (val == 0 || val % 2 || val > hdev->sniff_max_interval) {
575 hci_dev_unlock(hdev);
579 hdev->sniff_min_interval = val;
580 hci_dev_unlock(hdev);
585 static int sniff_min_interval_get(void *data, u64 *val)
587 struct hci_dev *hdev = data;
590 *val = hdev->sniff_min_interval;
591 hci_dev_unlock(hdev);
596 DEFINE_DEBUGFS_ATTRIBUTE(sniff_min_interval_fops, sniff_min_interval_get,
597 sniff_min_interval_set, "%llu\n");
599 static int sniff_max_interval_set(void *data, u64 val)
601 struct hci_dev *hdev = data;
604 if (val == 0 || val % 2 || val < hdev->sniff_min_interval) {
605 hci_dev_unlock(hdev);
609 hdev->sniff_max_interval = val;
610 hci_dev_unlock(hdev);
615 static int sniff_max_interval_get(void *data, u64 *val)
617 struct hci_dev *hdev = data;
620 *val = hdev->sniff_max_interval;
621 hci_dev_unlock(hdev);
626 DEFINE_DEBUGFS_ATTRIBUTE(sniff_max_interval_fops, sniff_max_interval_get,
627 sniff_max_interval_set, "%llu\n");
629 void hci_debugfs_create_bredr(struct hci_dev *hdev)
631 debugfs_create_file("inquiry_cache", 0444, hdev->debugfs, hdev,
632 &inquiry_cache_fops);
633 debugfs_create_file("link_keys", 0400, hdev->debugfs, hdev,
635 debugfs_create_file("dev_class", 0444, hdev->debugfs, hdev,
637 debugfs_create_file("voice_setting", 0444, hdev->debugfs, hdev,
638 &voice_setting_fops);
640 /* If the controller does not support BR/EDR Secure Connections
641 * feature, then the BR/EDR SMP channel shall not be present.
643 * To test this with Bluetooth 4.0 controllers, create a debugfs
644 * switch that allows forcing BR/EDR SMP support and accepting
645 * cross-transport pairing on non-AES encrypted connections.
647 if (!lmp_sc_capable(hdev))
648 debugfs_create_file("force_bredr_smp", 0644, hdev->debugfs,
649 hdev, &force_bredr_smp_fops);
651 if (lmp_ssp_capable(hdev)) {
652 debugfs_create_file("ssp_debug_mode", 0444, hdev->debugfs,
653 hdev, &ssp_debug_mode_fops);
654 debugfs_create_file("min_encrypt_key_size", 0644, hdev->debugfs,
655 hdev, &min_encrypt_key_size_fops);
656 debugfs_create_file("auto_accept_delay", 0644, hdev->debugfs,
657 hdev, &auto_accept_delay_fops);
660 if (lmp_sniff_capable(hdev)) {
661 debugfs_create_file("idle_timeout", 0644, hdev->debugfs,
662 hdev, &idle_timeout_fops);
663 debugfs_create_file("sniff_min_interval", 0644, hdev->debugfs,
664 hdev, &sniff_min_interval_fops);
665 debugfs_create_file("sniff_max_interval", 0644, hdev->debugfs,
666 hdev, &sniff_max_interval_fops);
670 static int identity_show(struct seq_file *f, void *p)
672 struct hci_dev *hdev = f->private;
678 hci_copy_identity_address(hdev, &addr, &addr_type);
680 seq_printf(f, "%pMR (type %u) %*phN %pMR\n", &addr, addr_type,
681 16, hdev->irk, &hdev->rpa);
683 hci_dev_unlock(hdev);
688 DEFINE_SHOW_ATTRIBUTE(identity);
690 static int rpa_timeout_set(void *data, u64 val)
692 struct hci_dev *hdev = data;
694 /* Require the RPA timeout to be at least 30 seconds and at most
697 if (val < 30 || val > (60 * 60 * 24))
701 hdev->rpa_timeout = val;
702 hci_dev_unlock(hdev);
707 static int rpa_timeout_get(void *data, u64 *val)
709 struct hci_dev *hdev = data;
712 *val = hdev->rpa_timeout;
713 hci_dev_unlock(hdev);
718 DEFINE_DEBUGFS_ATTRIBUTE(rpa_timeout_fops, rpa_timeout_get,
719 rpa_timeout_set, "%llu\n");
721 static int random_address_show(struct seq_file *f, void *p)
723 struct hci_dev *hdev = f->private;
726 seq_printf(f, "%pMR\n", &hdev->random_addr);
727 hci_dev_unlock(hdev);
732 DEFINE_SHOW_ATTRIBUTE(random_address);
734 static int static_address_show(struct seq_file *f, void *p)
736 struct hci_dev *hdev = f->private;
739 seq_printf(f, "%pMR\n", &hdev->static_addr);
740 hci_dev_unlock(hdev);
745 DEFINE_SHOW_ATTRIBUTE(static_address);
747 static ssize_t force_static_address_read(struct file *file,
748 char __user *user_buf,
749 size_t count, loff_t *ppos)
751 struct hci_dev *hdev = file->private_data;
754 buf[0] = hci_dev_test_flag(hdev, HCI_FORCE_STATIC_ADDR) ? 'Y' : 'N';
757 return simple_read_from_buffer(user_buf, count, ppos, buf, 2);
760 static ssize_t force_static_address_write(struct file *file,
761 const char __user *user_buf,
762 size_t count, loff_t *ppos)
764 struct hci_dev *hdev = file->private_data;
768 if (test_bit(HCI_UP, &hdev->flags))
771 err = kstrtobool_from_user(user_buf, count, &enable);
775 if (enable == hci_dev_test_flag(hdev, HCI_FORCE_STATIC_ADDR))
778 hci_dev_change_flag(hdev, HCI_FORCE_STATIC_ADDR);
783 static const struct file_operations force_static_address_fops = {
785 .read = force_static_address_read,
786 .write = force_static_address_write,
787 .llseek = default_llseek,
790 static int white_list_show(struct seq_file *f, void *ptr)
792 struct hci_dev *hdev = f->private;
793 struct bdaddr_list *b;
796 list_for_each_entry(b, &hdev->le_accept_list, list)
797 seq_printf(f, "%pMR (type %u)\n", &b->bdaddr, b->bdaddr_type);
798 hci_dev_unlock(hdev);
803 DEFINE_SHOW_ATTRIBUTE(white_list);
805 static int resolv_list_show(struct seq_file *f, void *ptr)
807 struct hci_dev *hdev = f->private;
808 struct bdaddr_list *b;
811 list_for_each_entry(b, &hdev->le_resolv_list, list)
812 seq_printf(f, "%pMR (type %u)\n", &b->bdaddr, b->bdaddr_type);
813 hci_dev_unlock(hdev);
818 DEFINE_SHOW_ATTRIBUTE(resolv_list);
820 static int identity_resolving_keys_show(struct seq_file *f, void *ptr)
822 struct hci_dev *hdev = f->private;
826 list_for_each_entry_rcu(irk, &hdev->identity_resolving_keys, list) {
827 seq_printf(f, "%pMR (type %u) %*phN %pMR\n",
828 &irk->bdaddr, irk->addr_type,
829 16, irk->val, &irk->rpa);
836 DEFINE_SHOW_ATTRIBUTE(identity_resolving_keys);
838 static int long_term_keys_show(struct seq_file *f, void *ptr)
840 struct hci_dev *hdev = f->private;
844 list_for_each_entry_rcu(ltk, &hdev->long_term_keys, list)
845 seq_printf(f, "%pMR (type %u) %u 0x%02x %u %.4x %.16llx %*phN\n",
846 <k->bdaddr, ltk->bdaddr_type, ltk->authenticated,
847 ltk->type, ltk->enc_size, __le16_to_cpu(ltk->ediv),
848 __le64_to_cpu(ltk->rand), 16, ltk->val);
854 DEFINE_SHOW_ATTRIBUTE(long_term_keys);
856 static int conn_min_interval_set(void *data, u64 val)
858 struct hci_dev *hdev = data;
861 if (val < 0x0006 || val > 0x0c80 || val > hdev->le_conn_max_interval) {
862 hci_dev_unlock(hdev);
866 hdev->le_conn_min_interval = val;
867 hci_dev_unlock(hdev);
872 static int conn_min_interval_get(void *data, u64 *val)
874 struct hci_dev *hdev = data;
877 *val = hdev->le_conn_min_interval;
878 hci_dev_unlock(hdev);
883 DEFINE_DEBUGFS_ATTRIBUTE(conn_min_interval_fops, conn_min_interval_get,
884 conn_min_interval_set, "%llu\n");
886 static int conn_max_interval_set(void *data, u64 val)
888 struct hci_dev *hdev = data;
891 if (val < 0x0006 || val > 0x0c80 || val < hdev->le_conn_min_interval) {
892 hci_dev_unlock(hdev);
896 hdev->le_conn_max_interval = val;
897 hci_dev_unlock(hdev);
902 static int conn_max_interval_get(void *data, u64 *val)
904 struct hci_dev *hdev = data;
907 *val = hdev->le_conn_max_interval;
908 hci_dev_unlock(hdev);
913 DEFINE_DEBUGFS_ATTRIBUTE(conn_max_interval_fops, conn_max_interval_get,
914 conn_max_interval_set, "%llu\n");
916 static int conn_latency_set(void *data, u64 val)
918 struct hci_dev *hdev = data;
924 hdev->le_conn_latency = val;
925 hci_dev_unlock(hdev);
930 static int conn_latency_get(void *data, u64 *val)
932 struct hci_dev *hdev = data;
935 *val = hdev->le_conn_latency;
936 hci_dev_unlock(hdev);
941 DEFINE_DEBUGFS_ATTRIBUTE(conn_latency_fops, conn_latency_get,
942 conn_latency_set, "%llu\n");
944 static int supervision_timeout_set(void *data, u64 val)
946 struct hci_dev *hdev = data;
948 if (val < 0x000a || val > 0x0c80)
952 hdev->le_supv_timeout = val;
953 hci_dev_unlock(hdev);
958 static int supervision_timeout_get(void *data, u64 *val)
960 struct hci_dev *hdev = data;
963 *val = hdev->le_supv_timeout;
964 hci_dev_unlock(hdev);
969 DEFINE_DEBUGFS_ATTRIBUTE(supervision_timeout_fops, supervision_timeout_get,
970 supervision_timeout_set, "%llu\n");
972 static int adv_channel_map_set(void *data, u64 val)
974 struct hci_dev *hdev = data;
976 if (val < 0x01 || val > 0x07)
980 hdev->le_adv_channel_map = val;
981 hci_dev_unlock(hdev);
986 static int adv_channel_map_get(void *data, u64 *val)
988 struct hci_dev *hdev = data;
991 *val = hdev->le_adv_channel_map;
992 hci_dev_unlock(hdev);
997 DEFINE_DEBUGFS_ATTRIBUTE(adv_channel_map_fops, adv_channel_map_get,
998 adv_channel_map_set, "%llu\n");
1000 static int adv_min_interval_set(void *data, u64 val)
1002 struct hci_dev *hdev = data;
1005 if (val < 0x0020 || val > 0x4000 || val > hdev->le_adv_max_interval) {
1006 hci_dev_unlock(hdev);
1010 hdev->le_adv_min_interval = val;
1011 hci_dev_unlock(hdev);
1016 static int adv_min_interval_get(void *data, u64 *val)
1018 struct hci_dev *hdev = data;
1021 *val = hdev->le_adv_min_interval;
1022 hci_dev_unlock(hdev);
1027 DEFINE_DEBUGFS_ATTRIBUTE(adv_min_interval_fops, adv_min_interval_get,
1028 adv_min_interval_set, "%llu\n");
1030 static int adv_max_interval_set(void *data, u64 val)
1032 struct hci_dev *hdev = data;
1035 if (val < 0x0020 || val > 0x4000 || val < hdev->le_adv_min_interval) {
1036 hci_dev_unlock(hdev);
1040 hdev->le_adv_max_interval = val;
1041 hci_dev_unlock(hdev);
1046 static int adv_max_interval_get(void *data, u64 *val)
1048 struct hci_dev *hdev = data;
1051 *val = hdev->le_adv_max_interval;
1052 hci_dev_unlock(hdev);
1057 DEFINE_DEBUGFS_ATTRIBUTE(adv_max_interval_fops, adv_max_interval_get,
1058 adv_max_interval_set, "%llu\n");
1060 static int min_key_size_set(void *data, u64 val)
1062 struct hci_dev *hdev = data;
1065 if (val > hdev->le_max_key_size || val < SMP_MIN_ENC_KEY_SIZE) {
1066 hci_dev_unlock(hdev);
1070 hdev->le_min_key_size = val;
1071 hci_dev_unlock(hdev);
1076 static int min_key_size_get(void *data, u64 *val)
1078 struct hci_dev *hdev = data;
1081 *val = hdev->le_min_key_size;
1082 hci_dev_unlock(hdev);
1087 DEFINE_DEBUGFS_ATTRIBUTE(min_key_size_fops, min_key_size_get,
1088 min_key_size_set, "%llu\n");
1090 static int max_key_size_set(void *data, u64 val)
1092 struct hci_dev *hdev = data;
1095 if (val > SMP_MAX_ENC_KEY_SIZE || val < hdev->le_min_key_size) {
1096 hci_dev_unlock(hdev);
1100 hdev->le_max_key_size = val;
1101 hci_dev_unlock(hdev);
1106 static int max_key_size_get(void *data, u64 *val)
1108 struct hci_dev *hdev = data;
1111 *val = hdev->le_max_key_size;
1112 hci_dev_unlock(hdev);
1117 DEFINE_DEBUGFS_ATTRIBUTE(max_key_size_fops, max_key_size_get,
1118 max_key_size_set, "%llu\n");
1120 static int auth_payload_timeout_set(void *data, u64 val)
1122 struct hci_dev *hdev = data;
1124 if (val < 0x0001 || val > 0xffff)
1128 hdev->auth_payload_timeout = val;
1129 hci_dev_unlock(hdev);
1134 static int auth_payload_timeout_get(void *data, u64 *val)
1136 struct hci_dev *hdev = data;
1139 *val = hdev->auth_payload_timeout;
1140 hci_dev_unlock(hdev);
1145 DEFINE_DEBUGFS_ATTRIBUTE(auth_payload_timeout_fops,
1146 auth_payload_timeout_get,
1147 auth_payload_timeout_set, "%llu\n");
1149 static ssize_t force_no_mitm_read(struct file *file,
1150 char __user *user_buf,
1151 size_t count, loff_t *ppos)
1153 struct hci_dev *hdev = file->private_data;
1156 buf[0] = hci_dev_test_flag(hdev, HCI_FORCE_NO_MITM) ? 'Y' : 'N';
1159 return simple_read_from_buffer(user_buf, count, ppos, buf, 2);
1162 static ssize_t force_no_mitm_write(struct file *file,
1163 const char __user *user_buf,
1164 size_t count, loff_t *ppos)
1166 struct hci_dev *hdev = file->private_data;
1168 size_t buf_size = min(count, (sizeof(buf) - 1));
1171 if (copy_from_user(buf, user_buf, buf_size))
1174 buf[buf_size] = '\0';
1175 if (strtobool(buf, &enable))
1178 if (enable == hci_dev_test_flag(hdev, HCI_FORCE_NO_MITM))
1181 hci_dev_change_flag(hdev, HCI_FORCE_NO_MITM);
1186 static const struct file_operations force_no_mitm_fops = {
1187 .open = simple_open,
1188 .read = force_no_mitm_read,
1189 .write = force_no_mitm_write,
1190 .llseek = default_llseek,
1193 DEFINE_QUIRK_ATTRIBUTE(quirk_strict_duplicate_filter,
1194 HCI_QUIRK_STRICT_DUPLICATE_FILTER);
1195 DEFINE_QUIRK_ATTRIBUTE(quirk_simultaneous_discovery,
1196 HCI_QUIRK_SIMULTANEOUS_DISCOVERY);
1198 void hci_debugfs_create_le(struct hci_dev *hdev)
1200 debugfs_create_file("identity", 0400, hdev->debugfs, hdev,
1202 debugfs_create_file("rpa_timeout", 0644, hdev->debugfs, hdev,
1204 debugfs_create_file("random_address", 0444, hdev->debugfs, hdev,
1205 &random_address_fops);
1206 debugfs_create_file("static_address", 0444, hdev->debugfs, hdev,
1207 &static_address_fops);
1209 /* For controllers with a public address, provide a debug
1210 * option to force the usage of the configured static
1211 * address. By default the public address is used.
1213 if (bacmp(&hdev->bdaddr, BDADDR_ANY))
1214 debugfs_create_file("force_static_address", 0644,
1215 hdev->debugfs, hdev,
1216 &force_static_address_fops);
1218 debugfs_create_u8("white_list_size", 0444, hdev->debugfs,
1219 &hdev->le_accept_list_size);
1220 debugfs_create_file("white_list", 0444, hdev->debugfs, hdev,
1222 debugfs_create_u8("resolv_list_size", 0444, hdev->debugfs,
1223 &hdev->le_resolv_list_size);
1224 debugfs_create_file("resolv_list", 0444, hdev->debugfs, hdev,
1226 debugfs_create_file("identity_resolving_keys", 0400, hdev->debugfs,
1227 hdev, &identity_resolving_keys_fops);
1228 debugfs_create_file("long_term_keys", 0400, hdev->debugfs, hdev,
1229 &long_term_keys_fops);
1230 debugfs_create_file("conn_min_interval", 0644, hdev->debugfs, hdev,
1231 &conn_min_interval_fops);
1232 debugfs_create_file("conn_max_interval", 0644, hdev->debugfs, hdev,
1233 &conn_max_interval_fops);
1234 debugfs_create_file("conn_latency", 0644, hdev->debugfs, hdev,
1235 &conn_latency_fops);
1236 debugfs_create_file("supervision_timeout", 0644, hdev->debugfs, hdev,
1237 &supervision_timeout_fops);
1238 debugfs_create_file("adv_channel_map", 0644, hdev->debugfs, hdev,
1239 &adv_channel_map_fops);
1240 debugfs_create_file("adv_min_interval", 0644, hdev->debugfs, hdev,
1241 &adv_min_interval_fops);
1242 debugfs_create_file("adv_max_interval", 0644, hdev->debugfs, hdev,
1243 &adv_max_interval_fops);
1244 debugfs_create_u16("discov_interleaved_timeout", 0644, hdev->debugfs,
1245 &hdev->discov_interleaved_timeout);
1246 debugfs_create_file("min_key_size", 0644, hdev->debugfs, hdev,
1247 &min_key_size_fops);
1248 debugfs_create_file("max_key_size", 0644, hdev->debugfs, hdev,
1249 &max_key_size_fops);
1250 debugfs_create_file("auth_payload_timeout", 0644, hdev->debugfs, hdev,
1251 &auth_payload_timeout_fops);
1252 debugfs_create_file("force_no_mitm", 0644, hdev->debugfs, hdev,
1253 &force_no_mitm_fops);
1255 debugfs_create_file("quirk_strict_duplicate_filter", 0644,
1256 hdev->debugfs, hdev,
1257 &quirk_strict_duplicate_filter_fops);
1258 debugfs_create_file("quirk_simultaneous_discovery", 0644,
1259 hdev->debugfs, hdev,
1260 &quirk_simultaneous_discovery_fops);
1263 void hci_debugfs_create_conn(struct hci_conn *conn)
1265 struct hci_dev *hdev = conn->hdev;
1268 if (IS_ERR_OR_NULL(hdev->debugfs) || conn->debugfs)
1271 snprintf(name, sizeof(name), "%u", conn->handle);
1272 conn->debugfs = debugfs_create_dir(name, hdev->debugfs);
1275 static ssize_t dut_mode_read(struct file *file, char __user *user_buf,
1276 size_t count, loff_t *ppos)
1278 struct hci_dev *hdev = file->private_data;
1281 buf[0] = hci_dev_test_flag(hdev, HCI_DUT_MODE) ? 'Y' : 'N';
1284 return simple_read_from_buffer(user_buf, count, ppos, buf, 2);
1287 static ssize_t dut_mode_write(struct file *file, const char __user *user_buf,
1288 size_t count, loff_t *ppos)
1290 struct hci_dev *hdev = file->private_data;
1291 struct sk_buff *skb;
1295 if (!test_bit(HCI_UP, &hdev->flags))
1298 err = kstrtobool_from_user(user_buf, count, &enable);
1302 if (enable == hci_dev_test_flag(hdev, HCI_DUT_MODE))
1305 hci_req_sync_lock(hdev);
1307 skb = __hci_cmd_sync(hdev, HCI_OP_ENABLE_DUT_MODE, 0, NULL,
1310 skb = __hci_cmd_sync(hdev, HCI_OP_RESET, 0, NULL,
1312 hci_req_sync_unlock(hdev);
1315 return PTR_ERR(skb);
1319 hci_dev_change_flag(hdev, HCI_DUT_MODE);
1324 static const struct file_operations dut_mode_fops = {
1325 .open = simple_open,
1326 .read = dut_mode_read,
1327 .write = dut_mode_write,
1328 .llseek = default_llseek,
1331 static ssize_t vendor_diag_read(struct file *file, char __user *user_buf,
1332 size_t count, loff_t *ppos)
1334 struct hci_dev *hdev = file->private_data;
1337 buf[0] = hci_dev_test_flag(hdev, HCI_VENDOR_DIAG) ? 'Y' : 'N';
1340 return simple_read_from_buffer(user_buf, count, ppos, buf, 2);
1343 static ssize_t vendor_diag_write(struct file *file, const char __user *user_buf,
1344 size_t count, loff_t *ppos)
1346 struct hci_dev *hdev = file->private_data;
1350 err = kstrtobool_from_user(user_buf, count, &enable);
1354 /* When the diagnostic flags are not persistent and the transport
1355 * is not active or in user channel operation, then there is no need
1356 * for the vendor callback. Instead just store the desired value and
1357 * the setting will be programmed when the controller gets powered on.
1359 if (test_bit(HCI_QUIRK_NON_PERSISTENT_DIAG, &hdev->quirks) &&
1360 (!test_bit(HCI_RUNNING, &hdev->flags) ||
1361 hci_dev_test_flag(hdev, HCI_USER_CHANNEL)))
1364 hci_req_sync_lock(hdev);
1365 err = hdev->set_diag(hdev, enable);
1366 hci_req_sync_unlock(hdev);
1373 hci_dev_set_flag(hdev, HCI_VENDOR_DIAG);
1375 hci_dev_clear_flag(hdev, HCI_VENDOR_DIAG);
1380 static const struct file_operations vendor_diag_fops = {
1381 .open = simple_open,
1382 .read = vendor_diag_read,
1383 .write = vendor_diag_write,
1384 .llseek = default_llseek,
1387 void hci_debugfs_create_basic(struct hci_dev *hdev)
1389 debugfs_create_file("dut_mode", 0644, hdev->debugfs, hdev,
1393 debugfs_create_file("vendor_diag", 0644, hdev->debugfs, hdev,