From: Antonio Quartulli <ordex@autistici.org>
To: The list for a Better Approach To Mobile Ad-hoc Networking
<b.a.t.m.a.n@lists.open-mesh.org>
Subject: Re: [B.A.T.M.A.N.] [PATCH 3/3] batman-adv: Modified forwarding behaviour for multicast packets
Date: Sun, 12 May 2013 01:29:29 +0200 [thread overview]
Message-ID: <20130511232929.GF901@ritirata.org> (raw)
In-Reply-To: <1368293014-30742-4-git-send-email-linus.luessing@web.de>
[-- Attachment #1: Type: text/plain, Size: 3920 bytes --]
On Sat, May 11, 2013 at 07:23:27PM +0200, Linus Lüssing wrote:
> With this patch a multicast packet is not always simply flooded anymore,
> the bevahiour for the following cases is changed to reduce
> unnecessary overhead:
>
> If all nodes within the horizon of a certain node have signalized
> multicast listener announcement capability
> (BATADV_MCAST_LISTENER_ANNOUNCEMENT) then an IPv6 multicast packet
> with a destination of IPv6 link-local scope coming from the upstream
> of this node...
>
> * ...is dropped if there is no according multicast listener in the
> translation table.
> * ...is forwarded via unicast if there is a single node with interested
> multicast listeners.
>
othwerwise? Does it get flooded like now if there is more than one receiver?
>
> /**
> + * batadv_mcast_flood - Checks on how to forward a multicast packet
> + * @skb: The multicast packet to check
> + * @bat_priv: the bat priv with all the soft interface information
> + *
> + * Returns 1 if the packet should be flooded, 0 if it should be forwarded
> + * via unicast or -1 if it should be drooped.
> + */
> +int batadv_mcast_flood(struct sk_buff *skb, struct batadv_priv *bat_priv)
> +{
> + struct ethhdr *ethhdr = (struct ethhdr *)(skb->data);
> + struct ipv6hdr *ip6hdr;
> + int count, ret = 1;
> +
> + if (atomic_read(&bat_priv->mcast_group_awareness) &&
> + !atomic_read(&bat_priv->mcast_num_non_aware) &&
> + ntohs(ethhdr->h_proto) == ETH_P_IPV6) {
mh..this would not work for VLANs..did you plan to introduce support for VLANs
later? or you simply overlooked it? :)
> + if (!pskb_may_pull(skb, sizeof(*ethhdr) + sizeof(*ip6hdr))) {
> + ret = -1;
> + goto out;
> + }
> +
> + ip6hdr = ipv6_hdr(skb);
> +
> + /* TODO: Implement Multicast Router Discovery, then add
> + * scope >= IPV6_ADDR_SCOPE_LINKLOCAL, too */
> + if (IPV6_ADDR_MC_SCOPE(&ip6hdr->daddr) !=
> + IPV6_ADDR_SCOPE_LINKLOCAL)
> + goto out;
> +
> + count = batadv_tt_global_hash_count(bat_priv, ethhdr->h_dest);
> +
> + if (!count)
> + ret = -1;
> + else if (count == 1)
> + ret = 0;
how can this function return more than one?
When there is more than one originator announcing the same MAC address then we
have _a single_ global entry having a list of orig_entry. but stil only one
global entry.
so you may want to count the orig_entries rather than the global_entries?
> diff --git a/translation-table.c b/translation-table.c
> index 37e7d47..1d2d618 100644
> --- a/translation-table.c
> +++ b/translation-table.c
> @@ -83,6 +83,40 @@ batadv_tt_hash_find(struct batadv_hashtable *hash, const void *data)
> return tt_common_entry_tmp;
> }
>
> +/**
> + * batadv_tt_hash_count - Counts the number of tt entries for the given data
> + * @hash: hash table containing the tt entries
> + * @data: The data to count entries for
One line saying what you are returning would be nice :)
> + */
> +static int batadv_tt_hash_count(struct batadv_hashtable *hash, const void *data)
> +{
> + struct hlist_head *head;
> + struct batadv_tt_common_entry *tt_common_entry;
> + uint32_t index;
> + int count = 0;
> +
> + if (!hash)
> + goto out;
> +
> + index = batadv_choose_orig(data, hash->size);
> + head = &hash->table[index];
> +
> + rcu_read_lock();
> + hlist_for_each_entry_rcu(tt_common_entry, head, hash_entry) {
> + if (!batadv_compare_eth(tt_common_entry, data))
> + continue;
> +
> + if (!atomic_read(&tt_common_entry->refcount))
> + continue;
> +
> + count++;
> + }
> + rcu_read_unlock();
> +
> +out:
> + return count;
> +}
as I asked before: this function cannot return >1 because the same address is
never stored twice.
Nice job so far!
Thanks for working on this cool feature!
Cheers,
--
Antonio Quartulli
..each of us alone is worth nothing..
Ernesto "Che" Guevara
[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 836 bytes --]
next prev parent reply other threads:[~2013-05-11 23:29 UTC|newest]
Thread overview: 20+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-05-11 17:23 [B.A.T.M.A.N.] Basic Multicast Optimizations Linus Lüssing
2013-05-11 17:23 ` [B.A.T.M.A.N.] [PATCH 1/3] batman-adv: Multicast Listener Announcements via Translation Table Linus Lüssing
2013-05-11 22:55 ` Antonio Quartulli
2013-05-16 18:16 ` Linus Lüssing
2013-05-16 19:36 ` Antonio Quartulli
2013-05-11 17:23 ` [B.A.T.M.A.N.] [PATCH 2/3] batman-adv: Announce new capability via multicast TVLV Linus Lüssing
2013-05-11 23:11 ` Antonio Quartulli
2013-05-16 18:19 ` Linus Lüssing
2013-05-16 19:41 ` Antonio Quartulli
2013-05-16 22:34 ` Linus Lüssing
2013-05-11 17:23 ` [B.A.T.M.A.N.] [PATCH 3/3] batman-adv: Modified forwarding behaviour for multicast packets Linus Lüssing
2013-05-11 23:29 ` Antonio Quartulli [this message]
2013-05-16 18:22 ` Linus Lüssing
2013-05-16 19:43 ` Antonio Quartulli
2013-05-16 11:51 ` [B.A.T.M.A.N.] Basic Multicast Optimizations Simon Wunderlich
2013-05-16 17:42 ` Linus Lüssing
2013-05-16 18:31 ` Simon Wunderlich
2013-05-17 1:38 ` Linus Lüssing
2013-05-17 10:24 ` Simon Wunderlich
-- strict thread matches above, loose matches on Subject: below --
2013-06-10 6:28 Linus Lüssing
2013-06-10 6:28 ` [B.A.T.M.A.N.] [PATCH 3/3] batman-adv: Modified forwarding behaviour for multicast packets Linus Lüssing
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20130511232929.GF901@ritirata.org \
--to=ordex@autistici.org \
--cc=b.a.t.m.a.n@lists.open-mesh.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.