提交 59101399 编写于 作者: S Sharvari Harisangam 提交者: Greg Kroah-Hartman

mwifiex: update set_mac_address logic

commit 7afb94da3cd8a28ed7ae268143117bf1ac8a3371 upstream.

In set_mac_address, driver check for interfaces with same bss_type
For first STA entry, this would return 3 interfaces since all priv's have
bss_type as 0 due to kzalloc. Thus mac address gets changed for STA
unexpected. This patch adds check for first STA and avoids mac address
change. This patch also adds mac_address change for p2p based on bss_num
type.
Signed-off-by: NSharvari Harisangam <sharvari@marvell.com>
Signed-off-by: NGanapathi Bhat <gbhat@marvell.com>
Signed-off-by: NKalle Valo <kvalo@codeaurora.org>
Cc: Brian Norris <briannorris@google.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 a1371a61
...@@ -960,10 +960,10 @@ int mwifiex_set_mac_address(struct mwifiex_private *priv, ...@@ -960,10 +960,10 @@ int mwifiex_set_mac_address(struct mwifiex_private *priv,
mac_addr = old_mac_addr; mac_addr = old_mac_addr;
if (priv->bss_type == MWIFIEX_BSS_TYPE_P2P) if (priv->bss_type == MWIFIEX_BSS_TYPE_P2P) {
mac_addr |= BIT_ULL(MWIFIEX_MAC_LOCAL_ADMIN_BIT); mac_addr |= BIT_ULL(MWIFIEX_MAC_LOCAL_ADMIN_BIT);
mac_addr += priv->bss_num;
if (mwifiex_get_intf_num(priv->adapter, priv->bss_type) > 1) { } else if (priv->adapter->priv[0] != priv) {
/* Set mac address based on bss_type/bss_num */ /* Set mac address based on bss_type/bss_num */
mac_addr ^= BIT_ULL(priv->bss_type + 8); mac_addr ^= BIT_ULL(priv->bss_type + 8);
mac_addr += priv->bss_num; mac_addr += priv->bss_num;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册