diff options
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-agn.c | 43 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-core.c | 41 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-core.h | 1 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl3945-base.c | 49 |
4 files changed, 44 insertions, 90 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-agn.c b/drivers/net/wireless/iwlwifi/iwl-agn.c index d14146fa751f..124a477ebd99 100644 --- a/drivers/net/wireless/iwlwifi/iwl-agn.c +++ b/drivers/net/wireless/iwlwifi/iwl-agn.c | |||
@@ -1443,10 +1443,6 @@ static int iwl_read_ucode(struct iwl_priv *priv) | |||
1443 | return ret; | 1443 | return ret; |
1444 | } | 1444 | } |
1445 | 1445 | ||
1446 | /* temporary */ | ||
1447 | static int iwl_mac_beacon_update(struct ieee80211_hw *hw, | ||
1448 | struct sk_buff *skb); | ||
1449 | |||
1450 | /** | 1446 | /** |
1451 | * iwl_alive_start - called after REPLY_ALIVE notification received | 1447 | * iwl_alive_start - called after REPLY_ALIVE notification received |
1452 | * from protocol/runtime uCode (initialization uCode's | 1448 | * from protocol/runtime uCode (initialization uCode's |
@@ -2657,45 +2653,6 @@ static void iwl_mac_reset_tsf(struct ieee80211_hw *hw) | |||
2657 | IWL_DEBUG_MAC80211(priv, "leave\n"); | 2653 | IWL_DEBUG_MAC80211(priv, "leave\n"); |
2658 | } | 2654 | } |
2659 | 2655 | ||
2660 | static int iwl_mac_beacon_update(struct ieee80211_hw *hw, struct sk_buff *skb) | ||
2661 | { | ||
2662 | struct iwl_priv *priv = hw->priv; | ||
2663 | unsigned long flags; | ||
2664 | __le64 timestamp; | ||
2665 | |||
2666 | IWL_DEBUG_MAC80211(priv, "enter\n"); | ||
2667 | |||
2668 | if (!iwl_is_ready_rf(priv)) { | ||
2669 | IWL_DEBUG_MAC80211(priv, "leave - RF not ready\n"); | ||
2670 | return -EIO; | ||
2671 | } | ||
2672 | |||
2673 | if (priv->iw_mode != NL80211_IFTYPE_ADHOC) { | ||
2674 | IWL_DEBUG_MAC80211(priv, "leave - not IBSS\n"); | ||
2675 | return -EIO; | ||
2676 | } | ||
2677 | |||
2678 | spin_lock_irqsave(&priv->lock, flags); | ||
2679 | |||
2680 | if (priv->ibss_beacon) | ||
2681 | dev_kfree_skb(priv->ibss_beacon); | ||
2682 | |||
2683 | priv->ibss_beacon = skb; | ||
2684 | |||
2685 | priv->assoc_id = 0; | ||
2686 | timestamp = ((struct ieee80211_mgmt *)skb->data)->u.beacon.timestamp; | ||
2687 | priv->timestamp = le64_to_cpu(timestamp); | ||
2688 | |||
2689 | IWL_DEBUG_MAC80211(priv, "leave\n"); | ||
2690 | spin_unlock_irqrestore(&priv->lock, flags); | ||
2691 | |||
2692 | iwl_reset_qos(priv); | ||
2693 | |||
2694 | priv->cfg->ops->lib->post_associate(priv); | ||
2695 | |||
2696 | |||
2697 | return 0; | ||
2698 | } | ||
2699 | 2656 | ||
2700 | /***************************************************************************** | 2657 | /***************************************************************************** |
2701 | * | 2658 | * |
diff --git a/drivers/net/wireless/iwlwifi/iwl-core.c b/drivers/net/wireless/iwlwifi/iwl-core.c index 15691829e023..eaeeb4dae0ed 100644 --- a/drivers/net/wireless/iwlwifi/iwl-core.c +++ b/drivers/net/wireless/iwlwifi/iwl-core.c | |||
@@ -2293,6 +2293,47 @@ void iwl_bss_info_changed(struct ieee80211_hw *hw, | |||
2293 | } | 2293 | } |
2294 | EXPORT_SYMBOL(iwl_bss_info_changed); | 2294 | EXPORT_SYMBOL(iwl_bss_info_changed); |
2295 | 2295 | ||
2296 | int iwl_mac_beacon_update(struct ieee80211_hw *hw, struct sk_buff *skb) | ||
2297 | { | ||
2298 | struct iwl_priv *priv = hw->priv; | ||
2299 | unsigned long flags; | ||
2300 | __le64 timestamp; | ||
2301 | |||
2302 | IWL_DEBUG_MAC80211(priv, "enter\n"); | ||
2303 | |||
2304 | if (!iwl_is_ready_rf(priv)) { | ||
2305 | IWL_DEBUG_MAC80211(priv, "leave - RF not ready\n"); | ||
2306 | return -EIO; | ||
2307 | } | ||
2308 | |||
2309 | if (priv->iw_mode != NL80211_IFTYPE_ADHOC) { | ||
2310 | IWL_DEBUG_MAC80211(priv, "leave - not IBSS\n"); | ||
2311 | return -EIO; | ||
2312 | } | ||
2313 | |||
2314 | spin_lock_irqsave(&priv->lock, flags); | ||
2315 | |||
2316 | if (priv->ibss_beacon) | ||
2317 | dev_kfree_skb(priv->ibss_beacon); | ||
2318 | |||
2319 | priv->ibss_beacon = skb; | ||
2320 | |||
2321 | priv->assoc_id = 0; | ||
2322 | timestamp = ((struct ieee80211_mgmt *)skb->data)->u.beacon.timestamp; | ||
2323 | priv->timestamp = le64_to_cpu(timestamp); | ||
2324 | |||
2325 | IWL_DEBUG_MAC80211(priv, "leave\n"); | ||
2326 | spin_unlock_irqrestore(&priv->lock, flags); | ||
2327 | |||
2328 | iwl_reset_qos(priv); | ||
2329 | |||
2330 | priv->cfg->ops->lib->post_associate(priv); | ||
2331 | |||
2332 | |||
2333 | return 0; | ||
2334 | } | ||
2335 | EXPORT_SYMBOL(iwl_mac_beacon_update); | ||
2336 | |||
2296 | #ifdef CONFIG_PM | 2337 | #ifdef CONFIG_PM |
2297 | 2338 | ||
2298 | int iwl_pci_suspend(struct pci_dev *pdev, pm_message_t state) | 2339 | int iwl_pci_suspend(struct pci_dev *pdev, pm_message_t state) |
diff --git a/drivers/net/wireless/iwlwifi/iwl-core.h b/drivers/net/wireless/iwlwifi/iwl-core.h index 4ad8465ae5fb..04473858b9b5 100644 --- a/drivers/net/wireless/iwlwifi/iwl-core.h +++ b/drivers/net/wireless/iwlwifi/iwl-core.h | |||
@@ -258,6 +258,7 @@ void iwl_bss_info_changed(struct ieee80211_hw *hw, | |||
258 | struct ieee80211_vif *vif, | 258 | struct ieee80211_vif *vif, |
259 | struct ieee80211_bss_conf *bss_conf, | 259 | struct ieee80211_bss_conf *bss_conf, |
260 | u32 changes); | 260 | u32 changes); |
261 | int iwl_mac_beacon_update(struct ieee80211_hw *hw, struct sk_buff *skb); | ||
261 | 262 | ||
262 | /***************************************************** | 263 | /***************************************************** |
263 | * RX handlers. | 264 | * RX handlers. |
diff --git a/drivers/net/wireless/iwlwifi/iwl3945-base.c b/drivers/net/wireless/iwlwifi/iwl3945-base.c index 6f44abc2dce0..857393a69016 100644 --- a/drivers/net/wireless/iwlwifi/iwl3945-base.c +++ b/drivers/net/wireless/iwlwifi/iwl3945-base.c | |||
@@ -2792,11 +2792,6 @@ static void iwl3945_init_alive_start(struct iwl_priv *priv) | |||
2792 | queue_work(priv->workqueue, &priv->restart); | 2792 | queue_work(priv->workqueue, &priv->restart); |
2793 | } | 2793 | } |
2794 | 2794 | ||
2795 | |||
2796 | /* temporary */ | ||
2797 | static int iwl3945_mac_beacon_update(struct ieee80211_hw *hw, | ||
2798 | struct sk_buff *skb); | ||
2799 | |||
2800 | /** | 2795 | /** |
2801 | * iwl3945_alive_start - called after REPLY_ALIVE notification received | 2796 | * iwl3945_alive_start - called after REPLY_ALIVE notification received |
2802 | * from protocol/runtime uCode (initialization uCode's | 2797 | * from protocol/runtime uCode (initialization uCode's |
@@ -2904,7 +2899,7 @@ static void iwl3945_alive_start(struct iwl_priv *priv) | |||
2904 | struct sk_buff *beacon = ieee80211_beacon_get(priv->hw, | 2899 | struct sk_buff *beacon = ieee80211_beacon_get(priv->hw, |
2905 | priv->vif); | 2900 | priv->vif); |
2906 | if (beacon) | 2901 | if (beacon) |
2907 | iwl3945_mac_beacon_update(priv->hw, beacon); | 2902 | iwl_mac_beacon_update(priv->hw, beacon); |
2908 | } | 2903 | } |
2909 | 2904 | ||
2910 | return; | 2905 | return; |
@@ -3837,7 +3832,7 @@ static int iwl3945_mac_config_interface(struct ieee80211_hw *hw, | |||
3837 | if (!beacon) | 3832 | if (!beacon) |
3838 | return -ENOMEM; | 3833 | return -ENOMEM; |
3839 | mutex_lock(&priv->mutex); | 3834 | mutex_lock(&priv->mutex); |
3840 | rc = iwl3945_mac_beacon_update(hw, beacon); | 3835 | rc = iwl_mac_beacon_update(hw, beacon); |
3841 | mutex_unlock(&priv->mutex); | 3836 | mutex_unlock(&priv->mutex); |
3842 | if (rc) | 3837 | if (rc) |
3843 | return rc; | 3838 | return rc; |
@@ -4089,46 +4084,6 @@ static void iwl3945_mac_reset_tsf(struct ieee80211_hw *hw) | |||
4089 | 4084 | ||
4090 | } | 4085 | } |
4091 | 4086 | ||
4092 | static int iwl3945_mac_beacon_update(struct ieee80211_hw *hw, struct sk_buff *skb) | ||
4093 | { | ||
4094 | struct iwl_priv *priv = hw->priv; | ||
4095 | unsigned long flags; | ||
4096 | __le64 timestamp; | ||
4097 | |||
4098 | IWL_DEBUG_MAC80211(priv, "enter\n"); | ||
4099 | |||
4100 | if (!iwl_is_ready_rf(priv)) { | ||
4101 | IWL_DEBUG_MAC80211(priv, "leave - RF not ready\n"); | ||
4102 | return -EIO; | ||
4103 | } | ||
4104 | |||
4105 | if (priv->iw_mode != NL80211_IFTYPE_ADHOC) { | ||
4106 | IWL_DEBUG_MAC80211(priv, "leave - not IBSS\n"); | ||
4107 | return -EIO; | ||
4108 | } | ||
4109 | |||
4110 | spin_lock_irqsave(&priv->lock, flags); | ||
4111 | |||
4112 | if (priv->ibss_beacon) | ||
4113 | dev_kfree_skb(priv->ibss_beacon); | ||
4114 | |||
4115 | priv->ibss_beacon = skb; | ||
4116 | |||
4117 | priv->assoc_id = 0; | ||
4118 | timestamp = ((struct ieee80211_mgmt *)skb->data)->u.beacon.timestamp; | ||
4119 | priv->timestamp = le64_to_cpu(timestamp); | ||
4120 | |||
4121 | IWL_DEBUG_MAC80211(priv, "leave\n"); | ||
4122 | spin_unlock_irqrestore(&priv->lock, flags); | ||
4123 | |||
4124 | iwl_reset_qos(priv); | ||
4125 | |||
4126 | priv->cfg->ops->lib->post_associate(priv); | ||
4127 | |||
4128 | |||
4129 | return 0; | ||
4130 | } | ||
4131 | |||
4132 | /***************************************************************************** | 4087 | /***************************************************************************** |
4133 | * | 4088 | * |
4134 | * sysfs attributes | 4089 | * sysfs attributes |