Kalle, Please drop this patch as I need to make some changes to it. I will send v2 soon. Regards, Rishi -----Original Message----- From: Panjwani, Rishi Sent: Tuesday, October 18, 2011 5:37 PM To: Valo, Kalle Cc: linux-wireless@xxxxxxxxxxxxxxx; Panjwani, Rishi Subject: [PATCH] ath6kl: Implement support for listen interval from userspace In order to allow user space based control of listen interval, we use available debugfs infrastructure. Listen interval implies how frequently we want the WLAN chip to wake up and synchronize the beacons in case it is in sleep mode. The user has to write the listen interval (in msecs) to the listen_interval file in ath6kl debug directory. The minimum value is 15 and maximum is 5000. Example: echo "30" > listen_interval This will make the listen interval approximately 30 msecs. Signed-off-by: Rishi Panjwani <rpanjwan@xxxxxxxxxxxxxxxx> --- drivers/net/wireless/ath/ath6kl/debug.c | 50 +++++++++++++++++++++++++++++++ 1 files changed, 50 insertions(+), 0 deletions(-) diff --git a/drivers/net/wireless/ath/ath6kl/debug.c b/drivers/net/wireless/ath/ath6kl/debug.c index 3eaa291..41f36d2 100644 --- a/drivers/net/wireless/ath/ath6kl/debug.c +++ b/drivers/net/wireless/ath/ath6kl/debug.c @@ -1488,6 +1488,53 @@ static const struct file_operations fops_bgscan_int = { .owner = THIS_MODULE, .llseek = default_llseek, }; +static ssize_t ath6kl_listen_int_write(struct file *file, + const char __user *user_buf, + size_t count, loff_t *ppos) +{ + struct ath6kl *ar = file->private_data; + u16 listen_int; + char buf[32]; + ssize_t len; + + len = min(count, sizeof(buf) - 1); + if (copy_from_user(buf, user_buf, len)) + return -EFAULT; + + buf[len] = '\0'; + if (kstrtou16(buf, 0, &listen_int)) + return -EINVAL; + + if ((listen_int >= 15) && (listen_int <= 5000)) { + ar->listen_intvl_t = listen_int; + ath6kl_wmi_listeninterval_cmd(ar->wmi, ar->listen_intvl_t, 0); + } else { + return -EINVAL; + } + + return count; +} + +static ssize_t ath6kl_listen_int_read(struct file *file, + char __user *user_buf, + size_t count, loff_t *ppos) +{ + struct ath6kl *ar = file->private_data; + char buf[16]; + int len; + + len = snprintf(buf, sizeof(buf), "%u\n", ar->listen_intvl_t); + + return simple_read_from_buffer(user_buf, count, ppos, buf, len); } + +static const struct file_operations fops_listen_int = { + .read = ath6kl_listen_int_read, + .write = ath6kl_listen_int_write, + .open = ath6kl_debugfs_open, + .owner = THIS_MODULE, + .llseek = default_llseek, +}; int ath6kl_debug_init(struct ath6kl *ar) { @@ -1571,6 +1618,9 @@ int ath6kl_debug_init(struct ath6kl *ar) debugfs_create_file("bgscan_interval", S_IWUSR, ar->debugfs_phy, ar, &fops_bgscan_int); + debugfs_create_file("listen_interval", S_IWUSR, ar->debugfs_phy, ar, + &fops_listen_int); + return 0; } -- 1.7.0.4 -- To unsubscribe from this list: send the line "unsubscribe linux-wireless" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html