2014-11-04 23:24:02

by Ben Greear

[permalink] [raw]
Subject: [PATCH 1/2] ath9k: fix misc debugfs when not using chan context

From: Ben Greear <[email protected]>

When channel-context is not enabled, all vifs belong to
the first context, but it is not configured as 'assigned'.

Fix misc debugfs file to print out info for non-assigned
contexts, and also print whether ctx is assigned or not.

Signed-off-by: Ben Greear <[email protected]>
---

This is not overly critical, but fixes regression in 3.17 kernel.

drivers/net/wireless/ath/ath9k/debug.c | 7 ++++---
1 file changed, 4 insertions(+), 3 deletions(-)

diff --git a/drivers/net/wireless/ath/ath9k/debug.c b/drivers/net/wireless/ath/ath9k/debug.c
index 46f20a3..3f6d971 100644
--- a/drivers/net/wireless/ath/ath9k/debug.c
+++ b/drivers/net/wireless/ath/ath9k/debug.c
@@ -828,13 +828,14 @@ static ssize_t read_file_misc(struct file *file, char __user *user_buf,

i = 0;
ath_for_each_chanctx(sc, ctx) {
- if (!ctx->assigned || list_empty(&ctx->vifs))
+ if (list_empty(&ctx->vifs))
continue;
ath9k_calculate_iter_data(sc, ctx, &iter_data);

len += scnprintf(buf + len, sizeof(buf) - len,
- "VIF-COUNTS: CTX %i AP: %i STA: %i MESH: %i WDS: %i",
- i++, iter_data.naps, iter_data.nstations,
+ "VIFS: CTX %i(%i) AP: %i STA: %i MESH: %i WDS: %i",
+ i++, (int)(ctx->assigned), iter_data.naps,
+ iter_data.nstations,
iter_data.nmeshes, iter_data.nwds);
len += scnprintf(buf + len, sizeof(buf) - len,
" ADHOC: %i TOTAL: %hi BEACON-VIF: %hi\n",
--
1.9.3



2014-11-04 23:24:02

by Ben Greear

[permalink] [raw]
Subject: [PATCH 2/2] ath9k: fix regression in bssidmask calculation

From: Ben Greear <[email protected]>

The commit that went into 3.17:

ath9k: Summarize hw state per channel context

Group and set hw state (opmode, primary_sta, beacon conf) per
channel context instead of whole list of vifs. This would allow
each channel context to run in different mode (STA/AP).

Signed-off-by: Felix Fietkau <[email protected]>
Signed-off-by: Rajkumar Manoharan <[email protected]>
Signed-off-by: John W. Linville <[email protected]>

broke multi-vif configuration due to not properly calculating
the bssid mask.

The test case that caught this was:

create wlan0 and sta0-4 (6 total), not sure how much that matters.
associate all 6 (works fine)
disconnect 5 of them, leaving sta0 up
Start trying to bring up the other 5 one at a time. It will
fail, with iw events looking like this (in these logs, several
sta are trying to come up, but symptom is the same with just one)

The patch causing the regression made quite a few changes, but
the part I think caused this particular problem was not
recalculating the bssid mask when adding and removing interfaces.

Re-adding those calls fixes my test case. Fix bad comment
as well.

Signed-off-by: Ben Greear <[email protected]>
---

This needs to be reviewed by ath9k driver folks that added
the original patch, at least.

And, should be considered for 3.17 stable if fix is accepted upstream.

drivers/net/wireless/ath/ath9k/main.c | 9 ++++++---
1 file changed, 6 insertions(+), 3 deletions(-)

diff --git a/drivers/net/wireless/ath/ath9k/main.c b/drivers/net/wireless/ath/ath9k/main.c
index fbf23ac..d2ad9e95 100644
--- a/drivers/net/wireless/ath/ath9k/main.c
+++ b/drivers/net/wireless/ath/ath9k/main.c
@@ -947,9 +947,8 @@ void ath9k_calculate_iter_data(struct ath_softc *sc,
struct ath_vif *avp;

/*
- * Pick the MAC address of the first interface as the new hardware
- * MAC address. The hardware will use it together with the BSSID mask
- * when matching addresses.
+ * The hardware will use primary station addr together with the
+ * BSSID mask when matching addresses.
*/
memset(iter_data, 0, sizeof(*iter_data));
memset(&iter_data->mask, 0xff, ETH_ALEN);
@@ -1169,6 +1168,8 @@ static int ath9k_add_interface(struct ieee80211_hw *hw,
list_add_tail(&avp->list, &avp->chanctx->vifs);
}

+ ath9k_calculate_summary_state(sc, avp->chanctx);
+
ath9k_assign_hw_queues(hw, vif);

an->sc = sc;
@@ -1238,6 +1239,8 @@ static void ath9k_remove_interface(struct ieee80211_hw *hw,

ath_tx_node_cleanup(sc, &avp->mcast_node);

+ ath9k_calculate_summary_state(sc, avp->chanctx);
+
mutex_unlock(&sc->mutex);
}

--
1.9.3


2014-11-12 07:38:07

by Sujith Manoharan

[permalink] [raw]
Subject: Re: [PATCH 2/2] ath9k: fix regression in bssidmask calculation

John W. Linville wrote:
> Any word from the ath9k posse?

Looks good to me...

Sujith

2014-11-11 21:30:19

by John W. Linville

[permalink] [raw]
Subject: Re: [PATCH 2/2] ath9k: fix regression in bssidmask calculation

On Tue, Nov 04, 2014 at 03:22:50PM -0800, [email protected] wrote:
> From: Ben Greear <[email protected]>
>
> The commit that went into 3.17:
>
> ath9k: Summarize hw state per channel context
>
> Group and set hw state (opmode, primary_sta, beacon conf) per
> channel context instead of whole list of vifs. This would allow
> each channel context to run in different mode (STA/AP).
>
> Signed-off-by: Felix Fietkau <[email protected]>
> Signed-off-by: Rajkumar Manoharan <[email protected]>
> Signed-off-by: John W. Linville <[email protected]>
>
> broke multi-vif configuration due to not properly calculating
> the bssid mask.
>
> The test case that caught this was:
>
> create wlan0 and sta0-4 (6 total), not sure how much that matters.
> associate all 6 (works fine)
> disconnect 5 of them, leaving sta0 up
> Start trying to bring up the other 5 one at a time. It will
> fail, with iw events looking like this (in these logs, several
> sta are trying to come up, but symptom is the same with just one)
>
> The patch causing the regression made quite a few changes, but
> the part I think caused this particular problem was not
> recalculating the bssid mask when adding and removing interfaces.
>
> Re-adding those calls fixes my test case. Fix bad comment
> as well.
>
> Signed-off-by: Ben Greear <[email protected]>
> ---
>
> This needs to be reviewed by ath9k driver folks that added
> the original patch, at least.

Any word from the ath9k posse?

> And, should be considered for 3.17 stable if fix is accepted upstream.
>
> drivers/net/wireless/ath/ath9k/main.c | 9 ++++++---
> 1 file changed, 6 insertions(+), 3 deletions(-)
>
> diff --git a/drivers/net/wireless/ath/ath9k/main.c b/drivers/net/wireless/ath/ath9k/main.c
> index fbf23ac..d2ad9e95 100644
> --- a/drivers/net/wireless/ath/ath9k/main.c
> +++ b/drivers/net/wireless/ath/ath9k/main.c
> @@ -947,9 +947,8 @@ void ath9k_calculate_iter_data(struct ath_softc *sc,
> struct ath_vif *avp;
>
> /*
> - * Pick the MAC address of the first interface as the new hardware
> - * MAC address. The hardware will use it together with the BSSID mask
> - * when matching addresses.
> + * The hardware will use primary station addr together with the
> + * BSSID mask when matching addresses.
> */
> memset(iter_data, 0, sizeof(*iter_data));
> memset(&iter_data->mask, 0xff, ETH_ALEN);
> @@ -1169,6 +1168,8 @@ static int ath9k_add_interface(struct ieee80211_hw *hw,
> list_add_tail(&avp->list, &avp->chanctx->vifs);
> }
>
> + ath9k_calculate_summary_state(sc, avp->chanctx);
> +
> ath9k_assign_hw_queues(hw, vif);
>
> an->sc = sc;
> @@ -1238,6 +1239,8 @@ static void ath9k_remove_interface(struct ieee80211_hw *hw,
>
> ath_tx_node_cleanup(sc, &avp->mcast_node);
>
> + ath9k_calculate_summary_state(sc, avp->chanctx);
> +
> mutex_unlock(&sc->mutex);
> }
>
> --
> 1.9.3
>
> --
> 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
>

--
John W. Linville Someday the world will need a hero, and you
[email protected] might be all we have. Be ready.