batman-adv: split neigh_new function into generic and batman iv specific parts

Signed-off-by: Marek Lindner <lindner_marek@yahoo.de>
Acked-by: Simon Wunderlich <siwu@hrz.tu-chemnitz.de>
Signed-off-by: Antonio Quartulli <ordex@autistici.org>
This commit is contained in:
Marek Lindner 2012-03-01 15:35:21 +08:00 committed by Antonio Quartulli
parent 0b0094e000
commit 7ae8b2852f
3 changed files with 48 additions and 27 deletions

View File

@ -30,6 +30,32 @@
#include "send.h" #include "send.h"
#include "bat_algo.h" #include "bat_algo.h"
static struct neigh_node *bat_iv_ogm_neigh_new(struct hard_iface *hard_iface,
const uint8_t *neigh_addr,
struct orig_node *orig_node,
struct orig_node *orig_neigh,
uint32_t seqno)
{
struct neigh_node *neigh_node;
neigh_node = batadv_neigh_node_new(hard_iface, neigh_addr, seqno);
if (!neigh_node)
goto out;
INIT_LIST_HEAD(&neigh_node->bonding_list);
spin_lock_init(&neigh_node->tq_lock);
neigh_node->orig_node = orig_neigh;
neigh_node->if_incoming = hard_iface;
spin_lock_bh(&orig_node->neigh_list_lock);
hlist_add_head_rcu(&neigh_node->list, &orig_node->neigh_list);
spin_unlock_bh(&orig_node->neigh_list_lock);
out:
return neigh_node;
}
static int bat_iv_ogm_iface_enable(struct hard_iface *hard_iface) static int bat_iv_ogm_iface_enable(struct hard_iface *hard_iface)
{ {
struct batman_ogm_packet *batman_ogm_packet; struct batman_ogm_packet *batman_ogm_packet;
@ -638,8 +664,9 @@ static void bat_iv_ogm_orig_update(struct bat_priv *bat_priv,
if (!orig_tmp) if (!orig_tmp)
goto unlock; goto unlock;
neigh_node = create_neighbor(orig_node, orig_tmp, neigh_node = bat_iv_ogm_neigh_new(if_incoming, ethhdr->h_source,
ethhdr->h_source, if_incoming); orig_node, orig_tmp,
batman_ogm_packet->seqno);
orig_node_free_ref(orig_tmp); orig_node_free_ref(orig_tmp);
if (!neigh_node) if (!neigh_node)
@ -764,10 +791,11 @@ static int bat_iv_ogm_calc_tq(struct orig_node *orig_node,
rcu_read_unlock(); rcu_read_unlock();
if (!neigh_node) if (!neigh_node)
neigh_node = create_neighbor(orig_neigh_node, neigh_node = bat_iv_ogm_neigh_new(if_incoming,
orig_neigh_node, orig_neigh_node->orig,
orig_neigh_node->orig, orig_neigh_node,
if_incoming); orig_neigh_node,
batman_ogm_packet->seqno);
if (!neigh_node) if (!neigh_node)
goto out; goto out;

View File

@ -85,35 +85,29 @@ struct neigh_node *orig_node_get_router(struct orig_node *orig_node)
return router; return router;
} }
struct neigh_node *create_neighbor(struct orig_node *orig_node, struct neigh_node *batadv_neigh_node_new(struct hard_iface *hard_iface,
struct orig_node *orig_neigh_node, const uint8_t *neigh_addr,
const uint8_t *neigh, uint32_t seqno)
struct hard_iface *if_incoming)
{ {
struct bat_priv *bat_priv = netdev_priv(if_incoming->soft_iface); struct bat_priv *bat_priv = netdev_priv(hard_iface->soft_iface);
struct neigh_node *neigh_node; struct neigh_node *neigh_node;
bat_dbg(DBG_BATMAN, bat_priv,
"Creating new last-hop neighbor of originator\n");
neigh_node = kzalloc(sizeof(*neigh_node), GFP_ATOMIC); neigh_node = kzalloc(sizeof(*neigh_node), GFP_ATOMIC);
if (!neigh_node) if (!neigh_node)
return NULL; goto out;
INIT_HLIST_NODE(&neigh_node->list); INIT_HLIST_NODE(&neigh_node->list);
INIT_LIST_HEAD(&neigh_node->bonding_list);
spin_lock_init(&neigh_node->tq_lock);
memcpy(neigh_node->addr, neigh, ETH_ALEN); memcpy(neigh_node->addr, neigh_addr, ETH_ALEN);
neigh_node->orig_node = orig_neigh_node;
neigh_node->if_incoming = if_incoming;
/* extra reference for return */ /* extra reference for return */
atomic_set(&neigh_node->refcount, 2); atomic_set(&neigh_node->refcount, 2);
spin_lock_bh(&orig_node->neigh_list_lock); bat_dbg(DBG_BATMAN, bat_priv,
hlist_add_head_rcu(&neigh_node->list, &orig_node->neigh_list); "Creating new neighbor %pM, initial seqno %d\n",
spin_unlock_bh(&orig_node->neigh_list_lock); neigh_addr, seqno);
out:
return neigh_node; return neigh_node;
} }

View File

@ -29,10 +29,9 @@ void originator_free(struct bat_priv *bat_priv);
void purge_orig_ref(struct bat_priv *bat_priv); void purge_orig_ref(struct bat_priv *bat_priv);
void orig_node_free_ref(struct orig_node *orig_node); void orig_node_free_ref(struct orig_node *orig_node);
struct orig_node *get_orig_node(struct bat_priv *bat_priv, const uint8_t *addr); struct orig_node *get_orig_node(struct bat_priv *bat_priv, const uint8_t *addr);
struct neigh_node *create_neighbor(struct orig_node *orig_node, struct neigh_node *batadv_neigh_node_new(struct hard_iface *hard_iface,
struct orig_node *orig_neigh_node, const uint8_t *neigh_addr,
const uint8_t *neigh, uint32_t seqno);
struct hard_iface *if_incoming);
void neigh_node_free_ref(struct neigh_node *neigh_node); void neigh_node_free_ref(struct neigh_node *neigh_node);
struct neigh_node *orig_node_get_router(struct orig_node *orig_node); struct neigh_node *orig_node_get_router(struct orig_node *orig_node);
int orig_seq_print_text(struct seq_file *seq, void *offset); int orig_seq_print_text(struct seq_file *seq, void *offset);