1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */
2*4882a593Smuzhiyun /* Copyright (C) 2007-2020 B.A.T.M.A.N. contributors:
3*4882a593Smuzhiyun *
4*4882a593Smuzhiyun * Marek Lindner, Simon Wunderlich
5*4882a593Smuzhiyun */
6*4882a593Smuzhiyun
7*4882a593Smuzhiyun #ifndef _NET_BATMAN_ADV_ORIGINATOR_H_
8*4882a593Smuzhiyun #define _NET_BATMAN_ADV_ORIGINATOR_H_
9*4882a593Smuzhiyun
10*4882a593Smuzhiyun #include "main.h"
11*4882a593Smuzhiyun
12*4882a593Smuzhiyun #include <linux/compiler.h>
13*4882a593Smuzhiyun #include <linux/if_ether.h>
14*4882a593Smuzhiyun #include <linux/jhash.h>
15*4882a593Smuzhiyun #include <linux/kref.h>
16*4882a593Smuzhiyun #include <linux/netlink.h>
17*4882a593Smuzhiyun #include <linux/seq_file.h>
18*4882a593Smuzhiyun #include <linux/skbuff.h>
19*4882a593Smuzhiyun #include <linux/types.h>
20*4882a593Smuzhiyun
21*4882a593Smuzhiyun bool batadv_compare_orig(const struct hlist_node *node, const void *data2);
22*4882a593Smuzhiyun int batadv_originator_init(struct batadv_priv *bat_priv);
23*4882a593Smuzhiyun void batadv_originator_free(struct batadv_priv *bat_priv);
24*4882a593Smuzhiyun void batadv_purge_orig_ref(struct batadv_priv *bat_priv);
25*4882a593Smuzhiyun void batadv_orig_node_release(struct kref *ref);
26*4882a593Smuzhiyun struct batadv_orig_node *batadv_orig_node_new(struct batadv_priv *bat_priv,
27*4882a593Smuzhiyun const u8 *addr);
28*4882a593Smuzhiyun struct batadv_hardif_neigh_node *
29*4882a593Smuzhiyun batadv_hardif_neigh_get(const struct batadv_hard_iface *hard_iface,
30*4882a593Smuzhiyun const u8 *neigh_addr);
31*4882a593Smuzhiyun void batadv_hardif_neigh_release(struct kref *ref);
32*4882a593Smuzhiyun struct batadv_neigh_node *
33*4882a593Smuzhiyun batadv_neigh_node_get_or_create(struct batadv_orig_node *orig_node,
34*4882a593Smuzhiyun struct batadv_hard_iface *hard_iface,
35*4882a593Smuzhiyun const u8 *neigh_addr);
36*4882a593Smuzhiyun void batadv_neigh_node_release(struct kref *ref);
37*4882a593Smuzhiyun struct batadv_neigh_node *
38*4882a593Smuzhiyun batadv_orig_router_get(struct batadv_orig_node *orig_node,
39*4882a593Smuzhiyun const struct batadv_hard_iface *if_outgoing);
40*4882a593Smuzhiyun struct batadv_neigh_ifinfo *
41*4882a593Smuzhiyun batadv_neigh_ifinfo_new(struct batadv_neigh_node *neigh,
42*4882a593Smuzhiyun struct batadv_hard_iface *if_outgoing);
43*4882a593Smuzhiyun struct batadv_neigh_ifinfo *
44*4882a593Smuzhiyun batadv_neigh_ifinfo_get(struct batadv_neigh_node *neigh,
45*4882a593Smuzhiyun struct batadv_hard_iface *if_outgoing);
46*4882a593Smuzhiyun void batadv_neigh_ifinfo_release(struct kref *ref);
47*4882a593Smuzhiyun
48*4882a593Smuzhiyun int batadv_hardif_neigh_dump(struct sk_buff *msg, struct netlink_callback *cb);
49*4882a593Smuzhiyun int batadv_hardif_neigh_seq_print_text(struct seq_file *seq, void *offset);
50*4882a593Smuzhiyun
51*4882a593Smuzhiyun struct batadv_orig_ifinfo *
52*4882a593Smuzhiyun batadv_orig_ifinfo_get(struct batadv_orig_node *orig_node,
53*4882a593Smuzhiyun struct batadv_hard_iface *if_outgoing);
54*4882a593Smuzhiyun struct batadv_orig_ifinfo *
55*4882a593Smuzhiyun batadv_orig_ifinfo_new(struct batadv_orig_node *orig_node,
56*4882a593Smuzhiyun struct batadv_hard_iface *if_outgoing);
57*4882a593Smuzhiyun void batadv_orig_ifinfo_release(struct kref *ref);
58*4882a593Smuzhiyun
59*4882a593Smuzhiyun int batadv_orig_seq_print_text(struct seq_file *seq, void *offset);
60*4882a593Smuzhiyun int batadv_orig_dump(struct sk_buff *msg, struct netlink_callback *cb);
61*4882a593Smuzhiyun int batadv_orig_hardif_seq_print_text(struct seq_file *seq, void *offset);
62*4882a593Smuzhiyun struct batadv_orig_node_vlan *
63*4882a593Smuzhiyun batadv_orig_node_vlan_new(struct batadv_orig_node *orig_node,
64*4882a593Smuzhiyun unsigned short vid);
65*4882a593Smuzhiyun struct batadv_orig_node_vlan *
66*4882a593Smuzhiyun batadv_orig_node_vlan_get(struct batadv_orig_node *orig_node,
67*4882a593Smuzhiyun unsigned short vid);
68*4882a593Smuzhiyun void batadv_orig_node_vlan_release(struct kref *ref);
69*4882a593Smuzhiyun
70*4882a593Smuzhiyun /**
71*4882a593Smuzhiyun * batadv_choose_orig() - Return the index of the orig entry in the hash table
72*4882a593Smuzhiyun * @data: mac address of the originator node
73*4882a593Smuzhiyun * @size: the size of the hash table
74*4882a593Smuzhiyun *
75*4882a593Smuzhiyun * Return: the hash index where the object represented by @data should be
76*4882a593Smuzhiyun * stored at.
77*4882a593Smuzhiyun */
batadv_choose_orig(const void * data,u32 size)78*4882a593Smuzhiyun static inline u32 batadv_choose_orig(const void *data, u32 size)
79*4882a593Smuzhiyun {
80*4882a593Smuzhiyun u32 hash = 0;
81*4882a593Smuzhiyun
82*4882a593Smuzhiyun hash = jhash(data, ETH_ALEN, hash);
83*4882a593Smuzhiyun return hash % size;
84*4882a593Smuzhiyun }
85*4882a593Smuzhiyun
86*4882a593Smuzhiyun struct batadv_orig_node *
87*4882a593Smuzhiyun batadv_orig_hash_find(struct batadv_priv *bat_priv, const void *data);
88*4882a593Smuzhiyun
89*4882a593Smuzhiyun /**
90*4882a593Smuzhiyun * batadv_orig_node_vlan_put() - decrement the refcounter and possibly release
91*4882a593Smuzhiyun * the originator-vlan object
92*4882a593Smuzhiyun * @orig_vlan: the originator-vlan object to release
93*4882a593Smuzhiyun */
94*4882a593Smuzhiyun static inline void
batadv_orig_node_vlan_put(struct batadv_orig_node_vlan * orig_vlan)95*4882a593Smuzhiyun batadv_orig_node_vlan_put(struct batadv_orig_node_vlan *orig_vlan)
96*4882a593Smuzhiyun {
97*4882a593Smuzhiyun if (!orig_vlan)
98*4882a593Smuzhiyun return;
99*4882a593Smuzhiyun
100*4882a593Smuzhiyun kref_put(&orig_vlan->refcount, batadv_orig_node_vlan_release);
101*4882a593Smuzhiyun }
102*4882a593Smuzhiyun
103*4882a593Smuzhiyun /**
104*4882a593Smuzhiyun * batadv_neigh_ifinfo_put() - decrement the refcounter and possibly release
105*4882a593Smuzhiyun * the neigh_ifinfo
106*4882a593Smuzhiyun * @neigh_ifinfo: the neigh_ifinfo object to release
107*4882a593Smuzhiyun */
108*4882a593Smuzhiyun static inline void
batadv_neigh_ifinfo_put(struct batadv_neigh_ifinfo * neigh_ifinfo)109*4882a593Smuzhiyun batadv_neigh_ifinfo_put(struct batadv_neigh_ifinfo *neigh_ifinfo)
110*4882a593Smuzhiyun {
111*4882a593Smuzhiyun if (!neigh_ifinfo)
112*4882a593Smuzhiyun return;
113*4882a593Smuzhiyun
114*4882a593Smuzhiyun kref_put(&neigh_ifinfo->refcount, batadv_neigh_ifinfo_release);
115*4882a593Smuzhiyun }
116*4882a593Smuzhiyun
117*4882a593Smuzhiyun /**
118*4882a593Smuzhiyun * batadv_hardif_neigh_put() - decrement the hardif neighbors refcounter
119*4882a593Smuzhiyun * and possibly release it
120*4882a593Smuzhiyun * @hardif_neigh: hardif neigh neighbor to free
121*4882a593Smuzhiyun */
122*4882a593Smuzhiyun static inline void
batadv_hardif_neigh_put(struct batadv_hardif_neigh_node * hardif_neigh)123*4882a593Smuzhiyun batadv_hardif_neigh_put(struct batadv_hardif_neigh_node *hardif_neigh)
124*4882a593Smuzhiyun {
125*4882a593Smuzhiyun if (!hardif_neigh)
126*4882a593Smuzhiyun return;
127*4882a593Smuzhiyun
128*4882a593Smuzhiyun kref_put(&hardif_neigh->refcount, batadv_hardif_neigh_release);
129*4882a593Smuzhiyun }
130*4882a593Smuzhiyun
131*4882a593Smuzhiyun /**
132*4882a593Smuzhiyun * batadv_neigh_node_put() - decrement the neighbors refcounter and possibly
133*4882a593Smuzhiyun * release it
134*4882a593Smuzhiyun * @neigh_node: neigh neighbor to free
135*4882a593Smuzhiyun */
batadv_neigh_node_put(struct batadv_neigh_node * neigh_node)136*4882a593Smuzhiyun static inline void batadv_neigh_node_put(struct batadv_neigh_node *neigh_node)
137*4882a593Smuzhiyun {
138*4882a593Smuzhiyun if (!neigh_node)
139*4882a593Smuzhiyun return;
140*4882a593Smuzhiyun
141*4882a593Smuzhiyun kref_put(&neigh_node->refcount, batadv_neigh_node_release);
142*4882a593Smuzhiyun }
143*4882a593Smuzhiyun
144*4882a593Smuzhiyun /**
145*4882a593Smuzhiyun * batadv_orig_ifinfo_put() - decrement the refcounter and possibly release
146*4882a593Smuzhiyun * the orig_ifinfo
147*4882a593Smuzhiyun * @orig_ifinfo: the orig_ifinfo object to release
148*4882a593Smuzhiyun */
149*4882a593Smuzhiyun static inline void
batadv_orig_ifinfo_put(struct batadv_orig_ifinfo * orig_ifinfo)150*4882a593Smuzhiyun batadv_orig_ifinfo_put(struct batadv_orig_ifinfo *orig_ifinfo)
151*4882a593Smuzhiyun {
152*4882a593Smuzhiyun if (!orig_ifinfo)
153*4882a593Smuzhiyun return;
154*4882a593Smuzhiyun
155*4882a593Smuzhiyun kref_put(&orig_ifinfo->refcount, batadv_orig_ifinfo_release);
156*4882a593Smuzhiyun }
157*4882a593Smuzhiyun
158*4882a593Smuzhiyun /**
159*4882a593Smuzhiyun * batadv_orig_node_put() - decrement the orig node refcounter and possibly
160*4882a593Smuzhiyun * release it
161*4882a593Smuzhiyun * @orig_node: the orig node to free
162*4882a593Smuzhiyun */
batadv_orig_node_put(struct batadv_orig_node * orig_node)163*4882a593Smuzhiyun static inline void batadv_orig_node_put(struct batadv_orig_node *orig_node)
164*4882a593Smuzhiyun {
165*4882a593Smuzhiyun if (!orig_node)
166*4882a593Smuzhiyun return;
167*4882a593Smuzhiyun
168*4882a593Smuzhiyun kref_put(&orig_node->refcount, batadv_orig_node_release);
169*4882a593Smuzhiyun }
170*4882a593Smuzhiyun
171*4882a593Smuzhiyun #endif /* _NET_BATMAN_ADV_ORIGINATOR_H_ */
172