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