Merge branch 'for-john' of git://git.kernel.org/pub/scm/linux/kernel/git/jberg/mac80211
This commit is contained in:
commit
c6b6eedc29
1 changed files with 16 additions and 22 deletions
|
@ -1811,37 +1811,31 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb,
|
||||||
meshhdrlen = ieee80211_new_mesh_header(&mesh_hdr,
|
meshhdrlen = ieee80211_new_mesh_header(&mesh_hdr,
|
||||||
sdata, NULL, NULL);
|
sdata, NULL, NULL);
|
||||||
} else {
|
} else {
|
||||||
int is_mesh_mcast = 1;
|
/* DS -> MBSS (802.11-2012 13.11.3.3).
|
||||||
const u8 *mesh_da;
|
* For unicast with unknown forwarding information,
|
||||||
|
* destination might be in the MBSS or if that fails
|
||||||
|
* forwarded to another mesh gate. In either case
|
||||||
|
* resolution will be handled in ieee80211_xmit(), so
|
||||||
|
* leave the original DA. This also works for mcast */
|
||||||
|
const u8 *mesh_da = skb->data;
|
||||||
|
|
||||||
if (is_multicast_ether_addr(skb->data))
|
if (mppath)
|
||||||
/* DA TA mSA AE:SA */
|
|
||||||
mesh_da = skb->data;
|
|
||||||
else {
|
|
||||||
static const u8 bcast[ETH_ALEN] =
|
|
||||||
{ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };
|
|
||||||
if (mppath) {
|
|
||||||
/* RA TA mDA mSA AE:DA SA */
|
|
||||||
mesh_da = mppath->mpp;
|
mesh_da = mppath->mpp;
|
||||||
is_mesh_mcast = 0;
|
else if (mpath)
|
||||||
} else if (mpath) {
|
|
||||||
mesh_da = mpath->dst;
|
mesh_da = mpath->dst;
|
||||||
is_mesh_mcast = 0;
|
rcu_read_unlock();
|
||||||
} else {
|
|
||||||
/* DA TA mSA AE:SA */
|
|
||||||
mesh_da = bcast;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
hdrlen = ieee80211_fill_mesh_addresses(&hdr, &fc,
|
hdrlen = ieee80211_fill_mesh_addresses(&hdr, &fc,
|
||||||
mesh_da, sdata->vif.addr);
|
mesh_da, sdata->vif.addr);
|
||||||
rcu_read_unlock();
|
if (is_multicast_ether_addr(mesh_da))
|
||||||
if (is_mesh_mcast)
|
/* DA TA mSA AE:SA */
|
||||||
meshhdrlen =
|
meshhdrlen =
|
||||||
ieee80211_new_mesh_header(&mesh_hdr,
|
ieee80211_new_mesh_header(&mesh_hdr,
|
||||||
sdata,
|
sdata,
|
||||||
skb->data + ETH_ALEN,
|
skb->data + ETH_ALEN,
|
||||||
NULL);
|
NULL);
|
||||||
else
|
else
|
||||||
|
/* RA TA mDA mSA AE:DA SA */
|
||||||
meshhdrlen =
|
meshhdrlen =
|
||||||
ieee80211_new_mesh_header(&mesh_hdr,
|
ieee80211_new_mesh_header(&mesh_hdr,
|
||||||
sdata,
|
sdata,
|
||||||
|
|
Loading…
Reference in a new issue