[PATCH] ath10k: Debugfs entry to enable/disable BTC feature
YanBo
dreamfly281 at gmail.com
Tue Jun 9 11:58:55 PDT 2015
On Mon, Jun 8, 2015 at 6:44 AM, Kalle Valo <kvalo at qca.qualcomm.com> wrote:
> "Li, Yanbo" <yanbol at qca.qualcomm.com> writes:
>
>>> -----Original Message-----
>>> From: Valo, Kalle
>>> Sent: Wednesday, May 27, 2015 5:57 AM
>>> To: Li, Yanbo
>>> Cc: dreamfly281 at gmail.com; linux-wireless at vger.kernel.org;
>>> michal.kazior at tieto.com; ath10k at lists.infradead.org
>>> Subject: Re: [PATCH] ath10k: Debugfs entry to enable/disable BTC feature
>>>
>>> Yanbo Li <yanbol at qca.qualcomm.com> writes:
>>>
>>> > As some radio have no connection with BT modules, enable the BTC
>>> > feature will has some side effect if the radio's GPIO connect with any
>>> > other HW modules. Add the control switcher "btc_feature" at debugfs
>>> > and set the feature as disable by default to avoid such case.
>>> >
>>> > To enable this feature, execute:
>>> > echo 1 > /sys/kernel/debug/ieee80211/phyX/ath10k/btc_feature
>>> > To disable:
>>> > echo 0 > /sys/kernel/debug/ieee80211/phyX/ath10k/btc_feature
>>>
>>> I suspect "BTC" does not really tell much for most of the people and
>>> acronyms should be always spelled out at least once.
>>>
>>> > Signed-off-by: Yanbo Li <yanbol at qca.qualcomm.com>
>>> >
>>> > diff --git a/drivers/net/wireless/ath/ath10k/core.h
>>> > b/drivers/net/wireless/ath/ath10k/core.h
>>> > index 8444adf42195..6852e7fc5d5f 100644
>>> > --- a/drivers/net/wireless/ath/ath10k/core.h
>>> > +++ b/drivers/net/wireless/ath/ath10k/core.h
>>> > @@ -720,6 +720,8 @@ struct ath10k {
>>> > u32 fw_cold_reset_counter;
>>> > } stats;
>>> >
>>> > + bool btc_feature;
>>>
>>> Could we use ar->dev_flags instead?
>>
>> This dev_flags currently used to mark some status, like the cradh, CAC running,
>> The BTcoex feature is more likely a HW feature, there are seems different set.
>>
>> Maybe a separately hw_feature_flag is needed as there are some other HW feature
>> That we want to enable/disable from user space.
>
> I think we don't need a separate bitmap, we can use dev_flags just fine
> for this.
>
>>> > +static ssize_t ath10k_write_btc_feature(struct file *file,
>>> > + const char __user *ubuf,
>>> > + size_t count, loff_t *ppos)
>>> > +{
>>> > + struct ath10k *ar = file->private_data;
>>> > + char buf[32];
>>> > + size_t buf_size;
>>> > + bool val;
>>> > +
>>> > + buf_size = min(count, (sizeof(buf) - 1));
>>> > + if (copy_from_user(buf, ubuf, buf_size))
>>> > + return -EFAULT;
>>> > +
>>> > + buf[buf_size] = '\0';
>>> > + if (strtobool(buf, &val) != 0) {
>>> > + ath10k_warn(ar, "Wrong BTC feature setting\n");
>>> > + return -EINVAL;
>>> > + }
>>> > +
>>> > + mutex_lock(&ar->conf_mutex);
>>> > + ar->btc_feature = val;
>>> > + queue_work(ar->workqueue, &ar->restart_work);
>>> > + mutex_unlock(&ar->conf_mutex);
>>>
>>> Shouldn't we test ATH10K_STATE_ON first?
>>
>> The restart process will judge by itself whether the device is on or not, and print below warning in that case:
>>
>> [797424.496190] ath10k_pci 0000:05:00.0: cannot restart a device that
>> hasn't been started
>
> That's just buggy, ath10k should not print anything if a setting is
> changed while interface is down. It's much better we have the check for
> ATH10K_STATE_ON here.
>
Agree, will send v3 include these changes.
BR /Yanbo
More information about the ath10k
mailing list