diff options
author | John W. Linville <linville@tuxdriver.com> | 2010-05-24 13:36:37 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2010-05-24 14:59:27 -0400 |
commit | 3dc3fc52ea1537f5f37ab301d2b1468a0e79988f (patch) | |
tree | 1d958b8f26d09c26ff4e3b05c4126e75c8f799da /drivers/net/wireless | |
parent | 617f3d0d71e2eae4d8d475cefe9363b140e52083 (diff) |
Revert "ath9k: Group Key fix for VAPs"
This reverts commit 03ceedea972a82d343fa5c2528b3952fa9e615d5.
This patch was reported to cause a regression in which connectivity is
lost and cannot be reestablished after a suspend/resume cycle.
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless')
-rw-r--r-- | drivers/net/wireless/ath/ath9k/main.c | 28 |
1 files changed, 3 insertions, 25 deletions
diff --git a/drivers/net/wireless/ath/ath9k/main.c b/drivers/net/wireless/ath/ath9k/main.c index 893b552981a0..abfa0493236f 100644 --- a/drivers/net/wireless/ath/ath9k/main.c +++ b/drivers/net/wireless/ath/ath9k/main.c | |||
@@ -752,7 +752,6 @@ static int ath_key_config(struct ath_common *common, | |||
752 | struct ath_hw *ah = common->ah; | 752 | struct ath_hw *ah = common->ah; |
753 | struct ath9k_keyval hk; | 753 | struct ath9k_keyval hk; |
754 | const u8 *mac = NULL; | 754 | const u8 *mac = NULL; |
755 | u8 gmac[ETH_ALEN]; | ||
756 | int ret = 0; | 755 | int ret = 0; |
757 | int idx; | 756 | int idx; |
758 | 757 | ||
@@ -776,30 +775,9 @@ static int ath_key_config(struct ath_common *common, | |||
776 | memcpy(hk.kv_val, key->key, key->keylen); | 775 | memcpy(hk.kv_val, key->key, key->keylen); |
777 | 776 | ||
778 | if (!(key->flags & IEEE80211_KEY_FLAG_PAIRWISE)) { | 777 | if (!(key->flags & IEEE80211_KEY_FLAG_PAIRWISE)) { |
779 | 778 | /* For now, use the default keys for broadcast keys. This may | |
780 | if (key->ap_addr) { | 779 | * need to change with virtual interfaces. */ |
781 | /* | 780 | idx = key->keyidx; |
782 | * Group keys on hardware that supports multicast frame | ||
783 | * key search use a mac that is the sender's address with | ||
784 | * the high bit set instead of the app-specified address. | ||
785 | */ | ||
786 | memcpy(gmac, key->ap_addr, ETH_ALEN); | ||
787 | gmac[0] |= 0x80; | ||
788 | mac = gmac; | ||
789 | |||
790 | if (key->alg == ALG_TKIP) | ||
791 | idx = ath_reserve_key_cache_slot_tkip(common); | ||
792 | else | ||
793 | idx = ath_reserve_key_cache_slot(common); | ||
794 | if (idx < 0) | ||
795 | mac = NULL; /* no free key cache entries */ | ||
796 | } | ||
797 | |||
798 | if (!mac) { | ||
799 | /* For now, use the default keys for broadcast keys. This may | ||
800 | * need to change with virtual interfaces. */ | ||
801 | idx = key->keyidx; | ||
802 | } | ||
803 | } else if (key->keyidx) { | 781 | } else if (key->keyidx) { |
804 | if (WARN_ON(!sta)) | 782 | if (WARN_ON(!sta)) |
805 | return -EOPNOTSUPP; | 783 | return -EOPNOTSUPP; |