diff options
author | Jo-Philipp Wich <jow@openwrt.org> | 2010-06-13 18:11:05 +0000 |
---|---|---|
committer | Jo-Philipp Wich <jow@openwrt.org> | 2010-06-13 18:11:05 +0000 |
commit | 6279e0ca5375e7d6059a03ae39320129566d6e70 (patch) | |
tree | 1ba66dcdb3d87bff4d29a5a8784e9573d78a356e /package/madwifi/patches/465-mc_list-2.6.35.patch | |
parent | 032959e72e8a0b8d6c1c674f2ed1b9df3e35e6ff (diff) | |
download | upstream-6279e0ca5375e7d6059a03ae39320129566d6e70.tar.gz upstream-6279e0ca5375e7d6059a03ae39320129566d6e70.tar.bz2 upstream-6279e0ca5375e7d6059a03ae39320129566d6e70.zip |
[package] madwifi: rename incorrectly named patch file (#7459)
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@21788 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/madwifi/patches/465-mc_list-2.6.35.patch')
-rw-r--r-- | package/madwifi/patches/465-mc_list-2.6.35.patch | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/package/madwifi/patches/465-mc_list-2.6.35.patch b/package/madwifi/patches/465-mc_list-2.6.35.patch new file mode 100644 index 0000000000..4931cfb282 --- /dev/null +++ b/package/madwifi/patches/465-mc_list-2.6.35.patch @@ -0,0 +1,40 @@ +--- a/ath/if_ath.c ++++ b/ath/if_ath.c +@@ -4466,7 +4466,11 @@ ath_merge_mcast(struct ath_softc *sc, u_ + { + struct ieee80211com *ic = &sc->sc_ic; + struct ieee80211vap *vap; ++ #if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35) ++ struct netdev_hw_addr *ha; ++ #else + struct dev_mc_list *mc; ++ #endif + u_int32_t val; + u_int8_t pos; + +@@ -4474,6 +4478,17 @@ ath_merge_mcast(struct ath_softc *sc, u_ + /* XXX locking */ + TAILQ_FOREACH(vap, &ic->ic_vaps, iv_next) { + struct net_device *dev = vap->iv_dev; ++ #if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35) ++ netdev_for_each_mc_addr(ha, dev) { ++ /* calculate XOR of eight 6-bit values */ ++ val = LE_READ_4(ha->addr + 0); ++ pos = (val >> 18) ^ (val >> 12) ^ (val >> 6) ^ val; ++ val = LE_READ_4(ha->addr + 3); ++ pos ^= (val >> 18) ^ (val >> 12) ^ (val >> 6) ^ val; ++ pos &= 0x3f; ++ mfilt[pos / 32] |= (1 << (pos % 32)); ++ } ++ #else + for (mc = dev->mc_list; mc; mc = mc->next) { + /* calculate XOR of eight 6-bit values */ + val = LE_READ_4(mc->dmi_addr + 0); +@@ -4483,6 +4498,7 @@ ath_merge_mcast(struct ath_softc *sc, u_ + pos &= 0x3f; + mfilt[pos / 32] |= (1 << (pos % 32)); + } ++ #endif + } + } + |