|
@@ -1240,6 +1240,220 @@ static const struct file_operations fops_disconnect_timeout = {
|
|
|
.llseek = default_llseek,
|
|
|
};
|
|
|
|
|
|
+static ssize_t ath6kl_create_qos_write(struct file *file,
|
|
|
+ const char __user *user_buf,
|
|
|
+ size_t count, loff_t *ppos)
|
|
|
+{
|
|
|
+
|
|
|
+ struct ath6kl *ar = file->private_data;
|
|
|
+ char buf[100];
|
|
|
+ ssize_t len;
|
|
|
+ char *sptr, *token;
|
|
|
+ struct wmi_create_pstream_cmd pstream;
|
|
|
+ u32 val32;
|
|
|
+ u16 val16;
|
|
|
+
|
|
|
+ len = min(count, sizeof(buf) - 1);
|
|
|
+ if (copy_from_user(buf, user_buf, len))
|
|
|
+ return -EFAULT;
|
|
|
+ buf[len] = '\0';
|
|
|
+ sptr = buf;
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou8(token, 0, &pstream.user_pri))
|
|
|
+ return -EINVAL;
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou8(token, 0, &pstream.traffic_direc))
|
|
|
+ return -EINVAL;
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou8(token, 0, &pstream.traffic_class))
|
|
|
+ return -EINVAL;
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou8(token, 0, &pstream.traffic_type))
|
|
|
+ return -EINVAL;
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou8(token, 0, &pstream.voice_psc_cap))
|
|
|
+ return -EINVAL;
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou32(token, 0, &val32))
|
|
|
+ return -EINVAL;
|
|
|
+ pstream.min_service_int = cpu_to_le32(val32);
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou32(token, 0, &val32))
|
|
|
+ return -EINVAL;
|
|
|
+ pstream.max_service_int = cpu_to_le32(val32);
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou32(token, 0, &val32))
|
|
|
+ return -EINVAL;
|
|
|
+ pstream.inactivity_int = cpu_to_le32(val32);
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou32(token, 0, &val32))
|
|
|
+ return -EINVAL;
|
|
|
+ pstream.suspension_int = cpu_to_le32(val32);
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou32(token, 0, &val32))
|
|
|
+ return -EINVAL;
|
|
|
+ pstream.service_start_time = cpu_to_le32(val32);
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou8(token, 0, &pstream.tsid))
|
|
|
+ return -EINVAL;
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou16(token, 0, &val16))
|
|
|
+ return -EINVAL;
|
|
|
+ pstream.nominal_msdu = cpu_to_le16(val16);
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou16(token, 0, &val16))
|
|
|
+ return -EINVAL;
|
|
|
+ pstream.max_msdu = cpu_to_le16(val16);
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou32(token, 0, &val32))
|
|
|
+ return -EINVAL;
|
|
|
+ pstream.min_data_rate = cpu_to_le32(val32);
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou32(token, 0, &val32))
|
|
|
+ return -EINVAL;
|
|
|
+ pstream.mean_data_rate = cpu_to_le32(val32);
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou32(token, 0, &val32))
|
|
|
+ return -EINVAL;
|
|
|
+ pstream.peak_data_rate = cpu_to_le32(val32);
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou32(token, 0, &val32))
|
|
|
+ return -EINVAL;
|
|
|
+ pstream.max_burst_size = cpu_to_le32(val32);
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou32(token, 0, &val32))
|
|
|
+ return -EINVAL;
|
|
|
+ pstream.delay_bound = cpu_to_le32(val32);
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou32(token, 0, &val32))
|
|
|
+ return -EINVAL;
|
|
|
+ pstream.min_phy_rate = cpu_to_le32(val32);
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou32(token, 0, &val32))
|
|
|
+ return -EINVAL;
|
|
|
+ pstream.sba = cpu_to_le32(val32);
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou32(token, 0, &val32))
|
|
|
+ return -EINVAL;
|
|
|
+ pstream.medium_time = cpu_to_le32(val32);
|
|
|
+
|
|
|
+ ath6kl_wmi_create_pstream_cmd(ar->wmi, &pstream);
|
|
|
+
|
|
|
+ return count;
|
|
|
+}
|
|
|
+
|
|
|
+static const struct file_operations fops_create_qos = {
|
|
|
+ .write = ath6kl_create_qos_write,
|
|
|
+ .open = ath6kl_debugfs_open,
|
|
|
+ .owner = THIS_MODULE,
|
|
|
+ .llseek = default_llseek,
|
|
|
+};
|
|
|
+
|
|
|
+static ssize_t ath6kl_delete_qos_write(struct file *file,
|
|
|
+ const char __user *user_buf,
|
|
|
+ size_t count, loff_t *ppos)
|
|
|
+{
|
|
|
+
|
|
|
+ struct ath6kl *ar = file->private_data;
|
|
|
+ char buf[100];
|
|
|
+ ssize_t len;
|
|
|
+ char *sptr, *token;
|
|
|
+ u8 traffic_class;
|
|
|
+ u8 tsid;
|
|
|
+
|
|
|
+ len = min(count, sizeof(buf) - 1);
|
|
|
+ if (copy_from_user(buf, user_buf, len))
|
|
|
+ return -EFAULT;
|
|
|
+ buf[len] = '\0';
|
|
|
+ sptr = buf;
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou8(token, 0, &traffic_class))
|
|
|
+ return -EINVAL;
|
|
|
+
|
|
|
+ token = strsep(&sptr, " ");
|
|
|
+ if (!token)
|
|
|
+ return -EINVAL;
|
|
|
+ if (kstrtou8(token, 0, &tsid))
|
|
|
+ return -EINVAL;
|
|
|
+
|
|
|
+ ath6kl_wmi_delete_pstream_cmd(ar->wmi, traffic_class, tsid);
|
|
|
+
|
|
|
+ return count;
|
|
|
+}
|
|
|
+
|
|
|
+static const struct file_operations fops_delete_qos = {
|
|
|
+ .write = ath6kl_delete_qos_write,
|
|
|
+ .open = ath6kl_debugfs_open,
|
|
|
+ .owner = THIS_MODULE,
|
|
|
+ .llseek = default_llseek,
|
|
|
+};
|
|
|
+
|
|
|
int ath6kl_debug_init(struct ath6kl *ar)
|
|
|
{
|
|
|
ar->debug.fwlog_buf.buf = vmalloc(ATH6KL_FWLOG_SIZE);
|
|
@@ -1313,6 +1527,12 @@ int ath6kl_debug_init(struct ath6kl *ar)
|
|
|
debugfs_create_file("disconnect_timeout", S_IRUSR | S_IWUSR,
|
|
|
ar->debugfs_phy, ar, &fops_disconnect_timeout);
|
|
|
|
|
|
+ debugfs_create_file("create_qos", S_IWUSR, ar->debugfs_phy, ar,
|
|
|
+ &fops_create_qos);
|
|
|
+
|
|
|
+ debugfs_create_file("delete_qos", S_IWUSR, ar->debugfs_phy, ar,
|
|
|
+ &fops_delete_qos);
|
|
|
+
|
|
|
return 0;
|
|
|
}
|
|
|
|