提交 8d05eb22 编写于 作者: A Avinash Patil 提交者: Kalle Valo

mwifiex: store permanant mac address in adapter structure

This would be used to set mac address while changing virtual
interface to different types.
Signed-off-by: NAvinash Patil <patila@marvell.com>
Signed-off-by: NAmitkumar Karwar <akarwar@marvell.com>
Signed-off-by: NCathy Luo <cluo@marvell.com>
Signed-off-by: NKalle Valo <kvalo@codeaurora.org>
上级 4facc34a
...@@ -2974,7 +2974,7 @@ int mwifiex_register_cfg80211(struct mwifiex_adapter *adapter) ...@@ -2974,7 +2974,7 @@ int mwifiex_register_cfg80211(struct mwifiex_adapter *adapter)
wiphy->cipher_suites = mwifiex_cipher_suites; wiphy->cipher_suites = mwifiex_cipher_suites;
wiphy->n_cipher_suites = ARRAY_SIZE(mwifiex_cipher_suites); wiphy->n_cipher_suites = ARRAY_SIZE(mwifiex_cipher_suites);
memcpy(wiphy->perm_addr, priv->curr_addr, ETH_ALEN); ether_addr_copy(wiphy->perm_addr, adapter->perm_addr);
wiphy->signal_type = CFG80211_SIGNAL_TYPE_MBM; wiphy->signal_type = CFG80211_SIGNAL_TYPE_MBM;
wiphy->flags |= WIPHY_FLAG_HAVE_AP_SME | wiphy->flags |= WIPHY_FLAG_HAVE_AP_SME |
WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD | WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD |
......
...@@ -1582,9 +1582,7 @@ int mwifiex_ret_get_hw_spec(struct mwifiex_private *priv, ...@@ -1582,9 +1582,7 @@ int mwifiex_ret_get_hw_spec(struct mwifiex_private *priv,
le16_to_cpu(hw_spec->hw_if_version), le16_to_cpu(hw_spec->hw_if_version),
le16_to_cpu(hw_spec->version)); le16_to_cpu(hw_spec->version));
if (priv->curr_addr[0] == 0xff) ether_addr_copy(priv->adapter->perm_addr, hw_spec->permanent_addr);
memmove(priv->curr_addr, hw_spec->permanent_addr, ETH_ALEN);
adapter->region_code = le16_to_cpu(hw_spec->region_code); adapter->region_code = le16_to_cpu(hw_spec->region_code);
for (i = 0; i < MWIFIEX_MAX_REGION_CODE; i++) for (i = 0; i < MWIFIEX_MAX_REGION_CODE; i++)
......
...@@ -297,6 +297,7 @@ static void mwifiex_init_adapter(struct mwifiex_adapter *adapter) ...@@ -297,6 +297,7 @@ static void mwifiex_init_adapter(struct mwifiex_adapter *adapter)
adapter->ext_scan = false; adapter->ext_scan = false;
adapter->key_api_major_ver = 0; adapter->key_api_major_ver = 0;
adapter->key_api_minor_ver = 0; adapter->key_api_minor_ver = 0;
memset(adapter->perm_addr, 0xff, ETH_ALEN);
setup_timer(&adapter->wakeup_timer, wakeup_timer_fn, setup_timer(&adapter->wakeup_timer, wakeup_timer_fn,
(unsigned long)adapter); (unsigned long)adapter);
......
...@@ -975,6 +975,7 @@ void mwifiex_init_priv_params(struct mwifiex_private *priv, ...@@ -975,6 +975,7 @@ void mwifiex_init_priv_params(struct mwifiex_private *priv,
priv->assocresp_idx = MWIFIEX_AUTO_IDX_MASK; priv->assocresp_idx = MWIFIEX_AUTO_IDX_MASK;
priv->rsn_idx = MWIFIEX_AUTO_IDX_MASK; priv->rsn_idx = MWIFIEX_AUTO_IDX_MASK;
priv->num_tx_timeout = 0; priv->num_tx_timeout = 0;
ether_addr_copy(priv->curr_addr, priv->adapter->perm_addr);
memcpy(dev->dev_addr, priv->curr_addr, ETH_ALEN); memcpy(dev->dev_addr, priv->curr_addr, ETH_ALEN);
if (GET_BSS_ROLE(priv) == MWIFIEX_BSS_ROLE_STA || if (GET_BSS_ROLE(priv) == MWIFIEX_BSS_ROLE_STA ||
......
...@@ -737,6 +737,7 @@ struct mwifiex_adapter { ...@@ -737,6 +737,7 @@ struct mwifiex_adapter {
int winner; int winner;
struct device *dev; struct device *dev;
struct wiphy *wiphy; struct wiphy *wiphy;
u8 perm_addr[ETH_ALEN];
bool surprise_removed; bool surprise_removed;
u32 fw_release_number; u32 fw_release_number;
u16 init_wait_q_woken; u16 init_wait_q_woken;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册