|
@@ -212,6 +212,24 @@ static int conn_info_max_age_get(void *data, u64 *val)
|
|
DEFINE_SIMPLE_ATTRIBUTE(conn_info_max_age_fops, conn_info_max_age_get,
|
|
DEFINE_SIMPLE_ATTRIBUTE(conn_info_max_age_fops, conn_info_max_age_get,
|
|
conn_info_max_age_set, "%llu\n");
|
|
conn_info_max_age_set, "%llu\n");
|
|
|
|
|
|
|
|
+static ssize_t sc_only_mode_read(struct file *file, char __user *user_buf,
|
|
|
|
+ size_t count, loff_t *ppos)
|
|
|
|
+{
|
|
|
|
+ struct hci_dev *hdev = file->private_data;
|
|
|
|
+ char buf[3];
|
|
|
|
+
|
|
|
|
+ buf[0] = test_bit(HCI_SC_ONLY, &hdev->dev_flags) ? 'Y': 'N';
|
|
|
|
+ buf[1] = '\n';
|
|
|
|
+ buf[2] = '\0';
|
|
|
|
+ return simple_read_from_buffer(user_buf, count, ppos, buf, 2);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+static const struct file_operations sc_only_mode_fops = {
|
|
|
|
+ .open = simple_open,
|
|
|
|
+ .read = sc_only_mode_read,
|
|
|
|
+ .llseek = default_llseek,
|
|
|
|
+};
|
|
|
|
+
|
|
void hci_debugfs_create_common(struct hci_dev *hdev)
|
|
void hci_debugfs_create_common(struct hci_dev *hdev)
|
|
{
|
|
{
|
|
debugfs_create_file("features", 0444, hdev->debugfs, hdev,
|
|
debugfs_create_file("features", 0444, hdev->debugfs, hdev,
|
|
@@ -230,6 +248,10 @@ void hci_debugfs_create_common(struct hci_dev *hdev)
|
|
&conn_info_min_age_fops);
|
|
&conn_info_min_age_fops);
|
|
debugfs_create_file("conn_info_max_age", 0644, hdev->debugfs, hdev,
|
|
debugfs_create_file("conn_info_max_age", 0644, hdev->debugfs, hdev,
|
|
&conn_info_max_age_fops);
|
|
&conn_info_max_age_fops);
|
|
|
|
+
|
|
|
|
+ if (lmp_sc_capable(hdev) || lmp_le_capable(hdev))
|
|
|
|
+ debugfs_create_file("sc_only_mode", 0444, hdev->debugfs,
|
|
|
|
+ hdev, &sc_only_mode_fops);
|
|
}
|
|
}
|
|
|
|
|
|
static int inquiry_cache_show(struct seq_file *f, void *p)
|
|
static int inquiry_cache_show(struct seq_file *f, void *p)
|
|
@@ -357,24 +379,6 @@ static int auto_accept_delay_get(void *data, u64 *val)
|
|
DEFINE_SIMPLE_ATTRIBUTE(auto_accept_delay_fops, auto_accept_delay_get,
|
|
DEFINE_SIMPLE_ATTRIBUTE(auto_accept_delay_fops, auto_accept_delay_get,
|
|
auto_accept_delay_set, "%llu\n");
|
|
auto_accept_delay_set, "%llu\n");
|
|
|
|
|
|
-static ssize_t sc_only_mode_read(struct file *file, char __user *user_buf,
|
|
|
|
- size_t count, loff_t *ppos)
|
|
|
|
-{
|
|
|
|
- struct hci_dev *hdev = file->private_data;
|
|
|
|
- char buf[3];
|
|
|
|
-
|
|
|
|
- buf[0] = test_bit(HCI_SC_ONLY, &hdev->dev_flags) ? 'Y': 'N';
|
|
|
|
- buf[1] = '\n';
|
|
|
|
- buf[2] = '\0';
|
|
|
|
- return simple_read_from_buffer(user_buf, count, ppos, buf, 2);
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
-static const struct file_operations sc_only_mode_fops = {
|
|
|
|
- .open = simple_open,
|
|
|
|
- .read = sc_only_mode_read,
|
|
|
|
- .llseek = default_llseek,
|
|
|
|
-};
|
|
|
|
-
|
|
|
|
static int idle_timeout_set(void *data, u64 val)
|
|
static int idle_timeout_set(void *data, u64 val)
|
|
{
|
|
{
|
|
struct hci_dev *hdev = data;
|
|
struct hci_dev *hdev = data;
|
|
@@ -470,12 +474,9 @@ void hci_debugfs_create_bredr(struct hci_dev *hdev)
|
|
debugfs_create_file("voice_setting", 0444, hdev->debugfs, hdev,
|
|
debugfs_create_file("voice_setting", 0444, hdev->debugfs, hdev,
|
|
&voice_setting_fops);
|
|
&voice_setting_fops);
|
|
|
|
|
|
- if (lmp_ssp_capable(hdev)) {
|
|
|
|
|
|
+ if (lmp_ssp_capable(hdev))
|
|
debugfs_create_file("auto_accept_delay", 0644, hdev->debugfs,
|
|
debugfs_create_file("auto_accept_delay", 0644, hdev->debugfs,
|
|
hdev, &auto_accept_delay_fops);
|
|
hdev, &auto_accept_delay_fops);
|
|
- debugfs_create_file("sc_only_mode", 0444, hdev->debugfs,
|
|
|
|
- hdev, &sc_only_mode_fops);
|
|
|
|
- }
|
|
|
|
|
|
|
|
if (lmp_sniff_capable(hdev)) {
|
|
if (lmp_sniff_capable(hdev)) {
|
|
debugfs_create_file("idle_timeout", 0644, hdev->debugfs,
|
|
debugfs_create_file("idle_timeout", 0644, hdev->debugfs,
|