Commit 9f8b97f8 authored by Alexander Aring's avatar Alexander Aring Committed by Marcel Holtmann

fakelb: don't deliver when one phy

A real phy don't transmit the transmitted frame back to the phy. This
behaviour will confuse the 6LoWPAN and the upper IPv6 neighbour
discovery cache. We need now at least two virtual phy's to creating a
virtual wpan network.
Signed-off-by: default avatarAlexander Aring <alex.aring@gmail.com>
Signed-off-by: default avatarMarcel Holtmann <marcel@holtmann.org>
parent db3f5d0d
......@@ -80,20 +80,16 @@ fakelb_hw_xmit(struct ieee802154_hw *hw, struct sk_buff *skb)
{
struct fakelb_phy *current_phy = hw->priv;
struct fakelb_priv *fake = current_phy->fake;
struct fakelb_phy *phy;
read_lock_bh(&fake->lock);
if (current_phy->list.next == current_phy->list.prev) {
/* we are the only one device */
fakelb_hw_deliver(current_phy, skb);
} else {
struct fakelb_phy *phy;
list_for_each_entry(phy, &current_phy->fake->list, list) {
if (current_phy != phy &&
(phy->hw->phy->current_channel ==
current_phy->hw->phy->current_channel))
fakelb_hw_deliver(phy, skb);
}
list_for_each_entry(phy, &current_phy->fake->list, list) {
if (current_phy == phy)
continue;
if (phy->hw->phy->current_channel ==
current_phy->hw->phy->current_channel)
fakelb_hw_deliver(phy, skb);
}
read_unlock_bh(&fake->lock);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment