2011-08-27 09:15:41

by Rajkumar Manoharan

[permalink] [raw]
Subject: [PATCH] ath9k_hw: Update IFS parameters properly

Configure IFS parameters read from chip in case of
full rate channel and non-AR9287 v1.3+. And also
read the ack and cts timeouts from chip and increase the
timeout when coverage class is defined. For half/Quarter
rate channel, IFS values needs to be reconfigured.
This patch removes the 2GHz workaround done for
acktimeout(64 us) because of reading acktime from chip.
The mentioned IFS parameters for AR9287 v1.3+ was
verified in HT40 2-chanin mode.

Signed-off-by: Rajkumar Manoharan <[email protected]>
---
drivers/net/wireless/ath/ath9k/hw.c | 30 +++++++++++++++++-------------
1 files changed, 17 insertions(+), 13 deletions(-)

diff --git a/drivers/net/wireless/ath/ath9k/hw.c b/drivers/net/wireless/ath/ath9k/hw.c
index 284d2a4..de31f2b 100644
--- a/drivers/net/wireless/ath/ath9k/hw.c
+++ b/drivers/net/wireless/ath/ath9k/hw.c
@@ -958,11 +958,11 @@ static bool ath9k_hw_set_global_txtimeout(struct ath_hw *ah, u32 tu)
void ath9k_hw_init_global_settings(struct ath_hw *ah)
{
struct ath_common *common = ath9k_hw_common(ah);
- struct ieee80211_conf *conf = &common->hw->conf;
const struct ath9k_channel *chan = ah->curchan;
int acktimeout;
int slottime;
int sifstime;
+ u32 ctstimeout;
int rx_lat = 0, tx_lat = 0, eifs = 0;
u32 reg;

@@ -1018,23 +1018,27 @@ void ath9k_hw_init_global_settings(struct ath_hw *ah)
sifstime = 10;
}

- /* As defined by IEEE 802.11-2007 17.3.8.6 */
- acktimeout = slottime + sifstime + 3 * ah->coverage_class;
+ if (AR_SREV_9287(ah) && AR_SREV_9287_13_OR_LATER(ah)) {
+ /* Verified values (us) in 2chanin HT40 mode */
+ acktimeout = 64;
+ ctstimeout = 48;
+ } else {
+ acktimeout = MS(REG_READ(ah, AR_TIME_OUT), AR_TIME_OUT_ACK)/
+ common->clockrate;
+ ctstimeout = MS(REG_READ(ah, AR_TIME_OUT), AR_TIME_OUT_CTS)/
+ common->clockrate;
+ }

- /*
- * Workaround for early ACK timeouts, add an offset to match the
- * initval's 64us ack timeout value.
- * This was initially only meant to work around an issue with delayed
- * BA frames in some implementations, but it has been found to fix ACK
- * timeout issues in other cases as well.
- */
- if (conf->channel && conf->channel->band == IEEE80211_BAND_2GHZ)
- acktimeout += 64 - sifstime - ah->slottime;
+ if (IS_CHAN_HALF_RATE(chan) || IS_CHAN_QUARTER_RATE(chan))
+ acktimeout = slottime + sifstime + 3 * ah->coverage_class;
+ else
+ acktimeout += 3 * ah->coverage_class;

ath9k_hw_set_sifs_time(ah, sifstime);
ath9k_hw_setslottime(ah, slottime);
ath9k_hw_set_ack_timeout(ah, acktimeout);
- ath9k_hw_set_cts_timeout(ah, acktimeout);
+ ath9k_hw_set_cts_timeout(ah, ctstimeout);
+
if (ah->globaltxtimeout != (u32) -1)
ath9k_hw_set_global_txtimeout(ah, ah->globaltxtimeout);

--
1.7.6.1



2011-08-29 05:23:44

by Rajkumar Manoharan

[permalink] [raw]
Subject: Re: [PATCH] ath9k_hw: Update IFS parameters properly

On Sun, Aug 28, 2011 at 01:28:15AM +0200, Felix Fietkau wrote:
> On 2011-08-27 11:16 AM, Rajkumar Manoharan wrote:
> >Configure IFS parameters read from chip in case of
> >full rate channel and non-AR9287 v1.3+. And also
> >read the ack and cts timeouts from chip and increase the
> >timeout when coverage class is defined. For half/Quarter
> >rate channel, IFS values needs to be reconfigured.
> >This patch removes the 2GHz workaround done for
> >acktimeout(64 us) because of reading acktime from chip.
> >The mentioned IFS parameters for AR9287 v1.3+ was
> >verified in HT40 2-chanin mode.
> >
> >Signed-off-by: Rajkumar Manoharan<[email protected]>
> >---
> > drivers/net/wireless/ath/ath9k/hw.c | 30 +++++++++++++++++-------------
> > 1 files changed, 17 insertions(+), 13 deletions(-)
> >
> >diff --git a/drivers/net/wireless/ath/ath9k/hw.c b/drivers/net/wireless/ath/ath9k/hw.c
> >index 284d2a4..de31f2b 100644
> >--- a/drivers/net/wireless/ath/ath9k/hw.c
> >+++ b/drivers/net/wireless/ath/ath9k/hw.c
> >@@ -958,11 +958,11 @@ static bool ath9k_hw_set_global_txtimeout(struct ath_hw *ah, u32 tu)
> > void ath9k_hw_init_global_settings(struct ath_hw *ah)
> > {
> > struct ath_common *common = ath9k_hw_common(ah);
> >- struct ieee80211_conf *conf =&common->hw->conf;
> > const struct ath9k_channel *chan = ah->curchan;
> > int acktimeout;
> > int slottime;
> > int sifstime;
> >+ u32 ctstimeout;
> > int rx_lat = 0, tx_lat = 0, eifs = 0;
> > u32 reg;
> >
> >@@ -1018,23 +1018,27 @@ void ath9k_hw_init_global_settings(struct ath_hw *ah)
> > sifstime = 10;
> > }
> >
> >- /* As defined by IEEE 802.11-2007 17.3.8.6 */
> >- acktimeout = slottime + sifstime + 3 * ah->coverage_class;
> >+ if (AR_SREV_9287(ah)&& AR_SREV_9287_13_OR_LATER(ah)) {
> >+ /* Verified values (us) in 2chanin HT40 mode */
> >+ acktimeout = 64;
> >+ ctstimeout = 48;
> >+ } else {
> >+ acktimeout = MS(REG_READ(ah, AR_TIME_OUT), AR_TIME_OUT_ACK)/
> >+ common->clockrate;
> >+ ctstimeout = MS(REG_READ(ah, AR_TIME_OUT), AR_TIME_OUT_CTS)/
> >+ common->clockrate;
> >+ }
> Why this mess of partially reused values from initvals? I think it's
> much better to just override these based on the standard 802.11
> values, and selectively add the 64-usec-minimum workaround for 2.4
> ghz as needed
As per the 802.11 spec, the ack/cts timeout calculation does not include
start delay factor. And also the current ctstimeout in 2.4 GHz is 30us (sifs+long slottime)
which is always lesser than the INI values. What is the point in reducing
cts timeouts and having workaround that again matches with INI values.

--
Rajkumar


2011-08-27 23:53:00

by Felix Fietkau

[permalink] [raw]
Subject: Re: [PATCH] ath9k_hw: Update IFS parameters properly

On 2011-08-28 1:28 AM, Felix Fietkau wrote:
> On 2011-08-27 11:16 AM, Rajkumar Manoharan wrote:
>> Configure IFS parameters read from chip in case of
>> full rate channel and non-AR9287 v1.3+. And also
>> read the ack and cts timeouts from chip and increase the
>> timeout when coverage class is defined. For half/Quarter
>> rate channel, IFS values needs to be reconfigured.
>> This patch removes the 2GHz workaround done for
>> acktimeout(64 us) because of reading acktime from chip.
>> The mentioned IFS parameters for AR9287 v1.3+ was
>> verified in HT40 2-chanin mode.
>>
>> @@ -1018,23 +1018,27 @@ void ath9k_hw_init_global_settings(struct ath_hw *ah)
>> sifstime = 10;
>> }
>>
>> - /* As defined by IEEE 802.11-2007 17.3.8.6 */
>> - acktimeout = slottime + sifstime + 3 * ah->coverage_class;
>> + if (AR_SREV_9287(ah)&& AR_SREV_9287_13_OR_LATER(ah)) {
>> + /* Verified values (us) in 2chanin HT40 mode */
>> + acktimeout = 64;
>> + ctstimeout = 48;
>> + } else {
>> + acktimeout = MS(REG_READ(ah, AR_TIME_OUT), AR_TIME_OUT_ACK)/
>> + common->clockrate;
>> + ctstimeout = MS(REG_READ(ah, AR_TIME_OUT), AR_TIME_OUT_CTS)/
>> + common->clockrate;
>> + }
> Why this mess of partially reused values from initvals? I think it's
> much better to just override these based on the standard 802.11 values,
> and selectively add the 64-usec-minimum workaround for 2.4 ghz as needed.
Just sent a smaller, less intrusive patch to replace this one.

- Felix

2011-08-27 23:28:24

by Felix Fietkau

[permalink] [raw]
Subject: Re: [PATCH] ath9k_hw: Update IFS parameters properly

On 2011-08-27 11:16 AM, Rajkumar Manoharan wrote:
> Configure IFS parameters read from chip in case of
> full rate channel and non-AR9287 v1.3+. And also
> read the ack and cts timeouts from chip and increase the
> timeout when coverage class is defined. For half/Quarter
> rate channel, IFS values needs to be reconfigured.
> This patch removes the 2GHz workaround done for
> acktimeout(64 us) because of reading acktime from chip.
> The mentioned IFS parameters for AR9287 v1.3+ was
> verified in HT40 2-chanin mode.
>
> Signed-off-by: Rajkumar Manoharan<[email protected]>
> ---
> drivers/net/wireless/ath/ath9k/hw.c | 30 +++++++++++++++++-------------
> 1 files changed, 17 insertions(+), 13 deletions(-)
>
> diff --git a/drivers/net/wireless/ath/ath9k/hw.c b/drivers/net/wireless/ath/ath9k/hw.c
> index 284d2a4..de31f2b 100644
> --- a/drivers/net/wireless/ath/ath9k/hw.c
> +++ b/drivers/net/wireless/ath/ath9k/hw.c
> @@ -958,11 +958,11 @@ static bool ath9k_hw_set_global_txtimeout(struct ath_hw *ah, u32 tu)
> void ath9k_hw_init_global_settings(struct ath_hw *ah)
> {
> struct ath_common *common = ath9k_hw_common(ah);
> - struct ieee80211_conf *conf =&common->hw->conf;
> const struct ath9k_channel *chan = ah->curchan;
> int acktimeout;
> int slottime;
> int sifstime;
> + u32 ctstimeout;
> int rx_lat = 0, tx_lat = 0, eifs = 0;
> u32 reg;
>
> @@ -1018,23 +1018,27 @@ void ath9k_hw_init_global_settings(struct ath_hw *ah)
> sifstime = 10;
> }
>
> - /* As defined by IEEE 802.11-2007 17.3.8.6 */
> - acktimeout = slottime + sifstime + 3 * ah->coverage_class;
> + if (AR_SREV_9287(ah)&& AR_SREV_9287_13_OR_LATER(ah)) {
> + /* Verified values (us) in 2chanin HT40 mode */
> + acktimeout = 64;
> + ctstimeout = 48;
> + } else {
> + acktimeout = MS(REG_READ(ah, AR_TIME_OUT), AR_TIME_OUT_ACK)/
> + common->clockrate;
> + ctstimeout = MS(REG_READ(ah, AR_TIME_OUT), AR_TIME_OUT_CTS)/
> + common->clockrate;
> + }
Why this mess of partially reused values from initvals? I think it's
much better to just override these based on the standard 802.11 values,
and selectively add the 64-usec-minimum workaround for 2.4 ghz as needed.

- Felix

2011-08-29 05:33:18

by Senthil Balasubramanian

[permalink] [raw]
Subject: Re: [PATCH] ath9k_hw: Update IFS parameters properly

On Mon, Aug 29, 2011 at 10:54:11AM +0530, Rajkumar Manoharan wrote:
> On Sun, Aug 28, 2011 at 01:28:15AM +0200, Felix Fietkau wrote:
> > On 2011-08-27 11:16 AM, Rajkumar Manoharan wrote:
> > >Configure IFS parameters read from chip in case of
> > >full rate channel and non-AR9287 v1.3+. And also
> > >read the ack and cts timeouts from chip and increase the
> > >timeout when coverage class is defined. For half/Quarter
> > >rate channel, IFS values needs to be reconfigured.
> > >This patch removes the 2GHz workaround done for
> > >acktimeout(64 us) because of reading acktime from chip.
> > >The mentioned IFS parameters for AR9287 v1.3+ was
> > >verified in HT40 2-chanin mode.
> > >
> > >Signed-off-by: Rajkumar Manoharan<[email protected]>
> > >---
> > > drivers/net/wireless/ath/ath9k/hw.c | 30 +++++++++++++++++-------------
> > > 1 files changed, 17 insertions(+), 13 deletions(-)
> > >
> > >diff --git a/drivers/net/wireless/ath/ath9k/hw.c b/drivers/net/wireless/ath/ath9k/hw.c
> > >index 284d2a4..de31f2b 100644
> > >--- a/drivers/net/wireless/ath/ath9k/hw.c
> > >+++ b/drivers/net/wireless/ath/ath9k/hw.c
> > >@@ -958,11 +958,11 @@ static bool ath9k_hw_set_global_txtimeout(struct ath_hw *ah, u32 tu)
> > > void ath9k_hw_init_global_settings(struct ath_hw *ah)
> > > {
> > > struct ath_common *common = ath9k_hw_common(ah);
> > >- struct ieee80211_conf *conf =&common->hw->conf;
> > > const struct ath9k_channel *chan = ah->curchan;
> > > int acktimeout;
> > > int slottime;
> > > int sifstime;
> > >+ u32 ctstimeout;
> > > int rx_lat = 0, tx_lat = 0, eifs = 0;
> > > u32 reg;
> > >
> > >@@ -1018,23 +1018,27 @@ void ath9k_hw_init_global_settings(struct ath_hw *ah)
> > > sifstime = 10;
> > > }
> > >
> > >- /* As defined by IEEE 802.11-2007 17.3.8.6 */
> > >- acktimeout = slottime + sifstime + 3 * ah->coverage_class;
> > >+ if (AR_SREV_9287(ah)&& AR_SREV_9287_13_OR_LATER(ah)) {
> > >+ /* Verified values (us) in 2chanin HT40 mode */
> > >+ acktimeout = 64;
> > >+ ctstimeout = 48;
> > >+ } else {
> > >+ acktimeout = MS(REG_READ(ah, AR_TIME_OUT), AR_TIME_OUT_ACK)/
> > >+ common->clockrate;
> > >+ ctstimeout = MS(REG_READ(ah, AR_TIME_OUT), AR_TIME_OUT_CTS)/
> > >+ common->clockrate;
> > >+ }
> > Why this mess of partially reused values from initvals? I think it's
> > much better to just override these based on the standard 802.11
> > values, and selectively add the 64-usec-minimum workaround for 2.4
> > ghz as needed
> As per the 802.11 spec, the ack/cts timeout calculation does not include
I think you meant ack/cts to does include start delay factor for 2.4GHz

s/does not/does

> start delay factor. And also the current ctstimeout in 2.4 GHz is 30us (sifs+long slottime)
> which is always lesser than the INI values. What is the point in reducing
> cts timeouts and having workaround that again matches with INI values.
>
> --
> Rajkumar
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-wireless" in
> the body of a message to [email protected]
> More majordomo info at http://vger.kernel.org/majordomo-info.html