]>
Commit | Line | Data |
---|---|---|
7db7d9f3 | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
68e039f9 | 2 | /* Copyright (C) 2011-2020 B.A.T.M.A.N. contributors: |
23721387 SW |
3 | * |
4 | * Simon Wunderlich | |
23721387 SW |
5 | */ |
6 | ||
7 | #ifndef _NET_BATMAN_ADV_BLA_H_ | |
8 | #define _NET_BATMAN_ADV_BLA_H_ | |
9 | ||
1e2c2a4f SE |
10 | #include "main.h" |
11 | ||
d3e9768a | 12 | #include <linux/compiler.h> |
68a600de SE |
13 | #include <linux/netdevice.h> |
14 | #include <linux/netlink.h> | |
68a600de | 15 | #include <linux/skbuff.h> |
d3e9768a | 16 | #include <linux/stddef.h> |
1e2c2a4f SE |
17 | #include <linux/types.h> |
18 | ||
d3e9768a | 19 | /** |
7e9a8c2c SE |
20 | * batadv_bla_is_loopdetect_mac() - check if the mac address is from a loop |
21 | * detect frame sent by bridge loop avoidance | |
d3e9768a SW |
22 | * @mac: mac address to check |
23 | * | |
24 | * Return: true if the it looks like a loop detect frame | |
25 | * (mac starts with BA:BE), false otherwise | |
26 | */ | |
27 | static inline bool batadv_bla_is_loopdetect_mac(const uint8_t *mac) | |
28 | { | |
29 | if (mac[0] == 0xba && mac[1] == 0xbe) | |
30 | return true; | |
31 | ||
32 | return false; | |
33 | } | |
34 | ||
7a5cc242 | 35 | #ifdef CONFIG_BATMAN_ADV_BLA |
4b426b10 | 36 | bool batadv_bla_rx(struct batadv_priv *bat_priv, struct sk_buff *skb, |
74c09b72 | 37 | unsigned short vid, int packet_type); |
4b426b10 SE |
38 | bool batadv_bla_tx(struct batadv_priv *bat_priv, struct sk_buff *skb, |
39 | unsigned short vid); | |
40 | bool batadv_bla_is_backbone_gw(struct sk_buff *skb, | |
41 | struct batadv_orig_node *orig_node, | |
42 | int hdr_size); | |
04f3f5bf | 43 | int batadv_bla_claim_dump(struct sk_buff *msg, struct netlink_callback *cb); |
ea4152e1 | 44 | int batadv_bla_backbone_dump(struct sk_buff *msg, struct netlink_callback *cb); |
6b5e971a | 45 | bool batadv_bla_is_backbone_gw_orig(struct batadv_priv *bat_priv, u8 *orig, |
cfd4f757 | 46 | unsigned short vid); |
4b426b10 SE |
47 | bool batadv_bla_check_bcast_duplist(struct batadv_priv *bat_priv, |
48 | struct sk_buff *skb); | |
56303d34 SE |
49 | void batadv_bla_update_orig_address(struct batadv_priv *bat_priv, |
50 | struct batadv_hard_iface *primary_if, | |
51 | struct batadv_hard_iface *oldif); | |
d68081a2 | 52 | void batadv_bla_status_update(struct net_device *net_dev); |
56303d34 SE |
53 | int batadv_bla_init(struct batadv_priv *bat_priv); |
54 | void batadv_bla_free(struct batadv_priv *bat_priv); | |
04f3f5bf | 55 | int batadv_bla_claim_dump(struct sk_buff *msg, struct netlink_callback *cb); |
00311de5 AP |
56 | #ifdef CONFIG_BATMAN_ADV_DAT |
57 | bool batadv_bla_check_claim(struct batadv_priv *bat_priv, u8 *addr, | |
58 | unsigned short vid); | |
59 | #endif | |
3964f728 | 60 | #define BATADV_BLA_CRC_INIT 0 |
7a5cc242 SW |
61 | #else /* ifdef CONFIG_BATMAN_ADV_BLA */ |
62 | ||
4b426b10 SE |
63 | static inline bool batadv_bla_rx(struct batadv_priv *bat_priv, |
64 | struct sk_buff *skb, unsigned short vid, | |
74c09b72 | 65 | int packet_type) |
7a5cc242 | 66 | { |
4b426b10 | 67 | return false; |
7a5cc242 SW |
68 | } |
69 | ||
4b426b10 SE |
70 | static inline bool batadv_bla_tx(struct batadv_priv *bat_priv, |
71 | struct sk_buff *skb, unsigned short vid) | |
7a5cc242 | 72 | { |
4b426b10 | 73 | return false; |
7a5cc242 SW |
74 | } |
75 | ||
4b426b10 SE |
76 | static inline bool batadv_bla_is_backbone_gw(struct sk_buff *skb, |
77 | struct batadv_orig_node *orig_node, | |
78 | int hdr_size) | |
7a5cc242 | 79 | { |
4b426b10 | 80 | return false; |
7a5cc242 SW |
81 | } |
82 | ||
cfd4f757 | 83 | static inline bool batadv_bla_is_backbone_gw_orig(struct batadv_priv *bat_priv, |
6b5e971a | 84 | u8 *orig, unsigned short vid) |
7a5cc242 | 85 | { |
cfd4f757 | 86 | return false; |
7a5cc242 SW |
87 | } |
88 | ||
4b426b10 | 89 | static inline bool |
56303d34 | 90 | batadv_bla_check_bcast_duplist(struct batadv_priv *bat_priv, |
004e86fc | 91 | struct sk_buff *skb) |
7a5cc242 | 92 | { |
4b426b10 | 93 | return false; |
7a5cc242 SW |
94 | } |
95 | ||
08adf151 | 96 | static inline void |
56303d34 SE |
97 | batadv_bla_update_orig_address(struct batadv_priv *bat_priv, |
98 | struct batadv_hard_iface *primary_if, | |
99 | struct batadv_hard_iface *oldif) | |
7a5cc242 SW |
100 | { |
101 | } | |
102 | ||
56303d34 | 103 | static inline int batadv_bla_init(struct batadv_priv *bat_priv) |
7a5cc242 SW |
104 | { |
105 | return 1; | |
106 | } | |
107 | ||
56303d34 | 108 | static inline void batadv_bla_free(struct batadv_priv *bat_priv) |
7a5cc242 SW |
109 | { |
110 | } | |
111 | ||
04f3f5bf AL |
112 | static inline int batadv_bla_claim_dump(struct sk_buff *msg, |
113 | struct netlink_callback *cb) | |
114 | { | |
115 | return -EOPNOTSUPP; | |
116 | } | |
117 | ||
ea4152e1 SW |
118 | static inline int batadv_bla_backbone_dump(struct sk_buff *msg, |
119 | struct netlink_callback *cb) | |
120 | { | |
121 | return -EOPNOTSUPP; | |
122 | } | |
123 | ||
00311de5 AP |
124 | static inline |
125 | bool batadv_bla_check_claim(struct batadv_priv *bat_priv, u8 *addr, | |
126 | unsigned short vid) | |
127 | { | |
128 | return true; | |
129 | } | |
130 | ||
7a5cc242 | 131 | #endif /* ifdef CONFIG_BATMAN_ADV_BLA */ |
23721387 SW |
132 | |
133 | #endif /* ifndef _NET_BATMAN_ADV_BLA_H_ */ |