]>
Commit | Line | Data |
---|---|---|
7db7d9f3 | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
68e039f9 | 2 | /* Copyright (C) 2007-2020 B.A.T.M.A.N. contributors: |
c6c8fea2 SE |
3 | * |
4 | * Marek Lindner, Simon Wunderlich | |
c6c8fea2 SE |
5 | */ |
6 | ||
7 | #ifndef _NET_BATMAN_ADV_HARD_INTERFACE_H_ | |
8 | #define _NET_BATMAN_ADV_HARD_INTERFACE_H_ | |
9 | ||
1e2c2a4f SE |
10 | #include "main.h" |
11 | ||
1e2c2a4f | 12 | #include <linux/compiler.h> |
7a659d56 | 13 | #include <linux/kref.h> |
68a600de | 14 | #include <linux/netdevice.h> |
1e2c2a4f SE |
15 | #include <linux/notifier.h> |
16 | #include <linux/rcupdate.h> | |
17 | #include <linux/stddef.h> | |
18 | #include <linux/types.h> | |
68a600de | 19 | #include <net/net_namespace.h> |
1e2c2a4f | 20 | |
73844a8c SE |
21 | /** |
22 | * enum batadv_hard_if_state - State of a hard interface | |
23 | */ | |
e9a4f295 | 24 | enum batadv_hard_if_state { |
73844a8c SE |
25 | /** |
26 | * @BATADV_IF_NOT_IN_USE: interface is not used as slave interface of a | |
27 | * batman-adv soft interface | |
28 | */ | |
e9a4f295 | 29 | BATADV_IF_NOT_IN_USE, |
73844a8c SE |
30 | |
31 | /** | |
32 | * @BATADV_IF_TO_BE_REMOVED: interface will be removed from soft | |
33 | * interface | |
34 | */ | |
e9a4f295 | 35 | BATADV_IF_TO_BE_REMOVED, |
73844a8c SE |
36 | |
37 | /** @BATADV_IF_INACTIVE: interface is deactivated */ | |
e9a4f295 | 38 | BATADV_IF_INACTIVE, |
73844a8c SE |
39 | |
40 | /** @BATADV_IF_ACTIVE: interface is used */ | |
e9a4f295 | 41 | BATADV_IF_ACTIVE, |
73844a8c SE |
42 | |
43 | /** @BATADV_IF_TO_BE_ACTIVATED: interface is getting activated */ | |
e9a4f295 | 44 | BATADV_IF_TO_BE_ACTIVATED, |
e8958dbf | 45 | }; |
c6c8fea2 | 46 | |
3111beed LL |
47 | /** |
48 | * enum batadv_hard_if_bcast - broadcast avoidance options | |
3111beed LL |
49 | */ |
50 | enum batadv_hard_if_bcast { | |
8b84cc4f | 51 | /** @BATADV_HARDIF_BCAST_OK: Do broadcast on according hard interface */ |
3111beed | 52 | BATADV_HARDIF_BCAST_OK = 0, |
8b84cc4f SE |
53 | |
54 | /** | |
55 | * @BATADV_HARDIF_BCAST_NORECIPIENT: Broadcast not needed, there is no | |
56 | * recipient | |
57 | */ | |
3111beed | 58 | BATADV_HARDIF_BCAST_NORECIPIENT, |
8b84cc4f SE |
59 | |
60 | /** | |
61 | * @BATADV_HARDIF_BCAST_DUPFWD: There is just the neighbor we got it | |
62 | * from | |
63 | */ | |
3111beed | 64 | BATADV_HARDIF_BCAST_DUPFWD, |
8b84cc4f SE |
65 | |
66 | /** @BATADV_HARDIF_BCAST_DUPORIG: There is just the originator */ | |
3111beed LL |
67 | BATADV_HARDIF_BCAST_DUPORIG, |
68 | }; | |
69 | ||
9563877e | 70 | extern struct notifier_block batadv_hard_if_notifier; |
c6c8fea2 | 71 | |
1942de1b | 72 | struct net_device *batadv_get_real_netdev(struct net_device *net_device); |
10b1bbb4 SE |
73 | bool batadv_is_cfg80211_hardif(struct batadv_hard_iface *hard_iface); |
74 | bool batadv_is_wifi_hardif(struct batadv_hard_iface *hard_iface); | |
56303d34 | 75 | struct batadv_hard_iface* |
9563877e | 76 | batadv_hardif_get_by_netdev(const struct net_device *net_dev); |
56303d34 | 77 | int batadv_hardif_enable_interface(struct batadv_hard_iface *hard_iface, |
2cd45a06 | 78 | struct net *net, const char *iface_name); |
a962cb29 | 79 | void batadv_hardif_disable_interface(struct batadv_hard_iface *hard_iface); |
9563877e SE |
80 | int batadv_hardif_min_mtu(struct net_device *soft_iface); |
81 | void batadv_update_min_mtu(struct net_device *soft_iface); | |
7a659d56 | 82 | void batadv_hardif_release(struct kref *ref); |
3111beed LL |
83 | int batadv_hardif_no_broadcast(struct batadv_hard_iface *if_outgoing, |
84 | u8 *orig_addr, u8 *orig_neigh); | |
c6c8fea2 | 85 | |
89652331 | 86 | /** |
7e9a8c2c | 87 | * batadv_hardif_put() - decrement the hard interface refcounter and possibly |
7a659d56 | 88 | * release it |
89652331 SW |
89 | * @hard_iface: the hard interface to free |
90 | */ | |
82047ad7 | 91 | static inline void batadv_hardif_put(struct batadv_hard_iface *hard_iface) |
c6c8fea2 | 92 | { |
7a659d56 | 93 | kref_put(&hard_iface->refcount, batadv_hardif_release); |
c6c8fea2 SE |
94 | } |
95 | ||
e57acf8e SE |
96 | /** |
97 | * batadv_primary_if_get_selected() - Get reference to primary interface | |
98 | * @bat_priv: the bat priv with all the soft interface information | |
99 | * | |
100 | * Return: primary interface (with increased refcnt), otherwise NULL | |
101 | */ | |
56303d34 SE |
102 | static inline struct batadv_hard_iface * |
103 | batadv_primary_if_get_selected(struct batadv_priv *bat_priv) | |
32ae9b22 | 104 | { |
56303d34 | 105 | struct batadv_hard_iface *hard_iface; |
32ae9b22 ML |
106 | |
107 | rcu_read_lock(); | |
108 | hard_iface = rcu_dereference(bat_priv->primary_if); | |
109 | if (!hard_iface) | |
110 | goto out; | |
111 | ||
7a659d56 | 112 | if (!kref_get_unless_zero(&hard_iface->refcount)) |
32ae9b22 ML |
113 | hard_iface = NULL; |
114 | ||
115 | out: | |
116 | rcu_read_unlock(); | |
117 | return hard_iface; | |
118 | } | |
119 | ||
c6c8fea2 | 120 | #endif /* _NET_BATMAN_ADV_HARD_INTERFACE_H_ */ |