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:
Родитель
0b0094e000
Коммит
7ae8b2852f
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Загрузка…
Ссылка в новой задаче