| /* SPDX-License-Identifier: GPL-2.0 */ |
| /* Copyright (C) 2011-2020 B.A.T.M.A.N. contributors: |
| * |
| * Antonio Quartulli |
| */ |
| |
| #ifndef _NET_BATMAN_ADV_DISTRIBUTED_ARP_TABLE_H_ |
| #define _NET_BATMAN_ADV_DISTRIBUTED_ARP_TABLE_H_ |
| |
| #include "main.h" |
| |
| #include <linux/compiler.h> |
| #include <linux/netdevice.h> |
| #include <linux/netlink.h> |
| #include <linux/seq_file.h> |
| #include <linux/skbuff.h> |
| #include <linux/types.h> |
| #include <uapi/linux/batadv_packet.h> |
| |
| #include "originator.h" |
| |
| #ifdef CONFIG_BATMAN_ADV_DAT |
| |
| /* BATADV_DAT_ADDR_MAX - maximum address value in the DHT space */ |
| #define BATADV_DAT_ADDR_MAX ((batadv_dat_addr_t)~(batadv_dat_addr_t)0) |
| |
| void batadv_dat_status_update(struct net_device *net_dev); |
| bool batadv_dat_snoop_outgoing_arp_request(struct batadv_priv *bat_priv, |
| struct sk_buff *skb); |
| bool batadv_dat_snoop_incoming_arp_request(struct batadv_priv *bat_priv, |
| struct sk_buff *skb, int hdr_size); |
| void batadv_dat_snoop_outgoing_arp_reply(struct batadv_priv *bat_priv, |
| struct sk_buff *skb); |
| bool batadv_dat_snoop_incoming_arp_reply(struct batadv_priv *bat_priv, |
| struct sk_buff *skb, int hdr_size); |
| void batadv_dat_snoop_outgoing_dhcp_ack(struct batadv_priv *bat_priv, |
| struct sk_buff *skb, |
| __be16 proto, |
| unsigned short vid); |
| void batadv_dat_snoop_incoming_dhcp_ack(struct batadv_priv *bat_priv, |
| struct sk_buff *skb, int hdr_size); |
| bool batadv_dat_drop_broadcast_packet(struct batadv_priv *bat_priv, |
| struct batadv_forw_packet *forw_packet); |
| |
| /** |
| * batadv_dat_init_orig_node_addr() - assign a DAT address to the orig_node |
| * @orig_node: the node to assign the DAT address to |
| */ |
| static inline void |
| batadv_dat_init_orig_node_addr(struct batadv_orig_node *orig_node) |
| { |
| u32 addr; |
| |
| addr = batadv_choose_orig(orig_node->orig, BATADV_DAT_ADDR_MAX); |
| orig_node->dat_addr = (batadv_dat_addr_t)addr; |
| } |
| |
| /** |
| * batadv_dat_init_own_addr() - assign a DAT address to the node itself |
| * @bat_priv: the bat priv with all the soft interface information |
| * @primary_if: a pointer to the primary interface |
| */ |
| static inline void |
| batadv_dat_init_own_addr(struct batadv_priv *bat_priv, |
| struct batadv_hard_iface *primary_if) |
| { |
| u32 addr; |
| |
| addr = batadv_choose_orig(primary_if->net_dev->dev_addr, |
| BATADV_DAT_ADDR_MAX); |
| |
| bat_priv->dat.addr = (batadv_dat_addr_t)addr; |
| } |
| |
| int batadv_dat_init(struct batadv_priv *bat_priv); |
| void batadv_dat_free(struct batadv_priv *bat_priv); |
| int batadv_dat_cache_seq_print_text(struct seq_file *seq, void *offset); |
| int batadv_dat_cache_dump(struct sk_buff *msg, struct netlink_callback *cb); |
| |
| /** |
| * batadv_dat_inc_counter() - increment the correct DAT packet counter |
| * @bat_priv: the bat priv with all the soft interface information |
| * @subtype: the 4addr subtype of the packet to be counted |
| * |
| * Updates the ethtool statistics for the received packet if it is a DAT subtype |
| */ |
| static inline void batadv_dat_inc_counter(struct batadv_priv *bat_priv, |
| u8 subtype) |
| { |
| switch (subtype) { |
| case BATADV_P_DAT_DHT_GET: |
| batadv_inc_counter(bat_priv, |
| BATADV_CNT_DAT_GET_RX); |
| break; |
| case BATADV_P_DAT_DHT_PUT: |
| batadv_inc_counter(bat_priv, |
| BATADV_CNT_DAT_PUT_RX); |
| break; |
| } |
| } |
| |
| #else |
| |
| static inline void batadv_dat_status_update(struct net_device *net_dev) |
| { |
| } |
| |
| static inline bool |
| batadv_dat_snoop_outgoing_arp_request(struct batadv_priv *bat_priv, |
| struct sk_buff *skb) |
| { |
| return false; |
| } |
| |
| static inline bool |
| batadv_dat_snoop_incoming_arp_request(struct batadv_priv *bat_priv, |
| struct sk_buff *skb, int hdr_size) |
| { |
| return false; |
| } |
| |
| static inline bool |
| batadv_dat_snoop_outgoing_arp_reply(struct batadv_priv *bat_priv, |
| struct sk_buff *skb) |
| { |
| return false; |
| } |
| |
| static inline bool |
| batadv_dat_snoop_incoming_arp_reply(struct batadv_priv *bat_priv, |
| struct sk_buff *skb, int hdr_size) |
| { |
| return false; |
| } |
| |
| static inline void |
| batadv_dat_snoop_outgoing_dhcp_ack(struct batadv_priv *bat_priv, |
| struct sk_buff *skb, __be16 proto, |
| unsigned short vid) |
| { |
| } |
| |
| static inline void |
| batadv_dat_snoop_incoming_dhcp_ack(struct batadv_priv *bat_priv, |
| struct sk_buff *skb, int hdr_size) |
| { |
| } |
| |
| static inline bool |
| batadv_dat_drop_broadcast_packet(struct batadv_priv *bat_priv, |
| struct batadv_forw_packet *forw_packet) |
| { |
| return false; |
| } |
| |
| static inline void |
| batadv_dat_init_orig_node_addr(struct batadv_orig_node *orig_node) |
| { |
| } |
| |
| static inline void batadv_dat_init_own_addr(struct batadv_priv *bat_priv, |
| struct batadv_hard_iface *iface) |
| { |
| } |
| |
| static inline int batadv_dat_init(struct batadv_priv *bat_priv) |
| { |
| return 0; |
| } |
| |
| static inline void batadv_dat_free(struct batadv_priv *bat_priv) |
| { |
| } |
| |
| static inline int |
| batadv_dat_cache_dump(struct sk_buff *msg, struct netlink_callback *cb) |
| { |
| return -EOPNOTSUPP; |
| } |
| |
| static inline void batadv_dat_inc_counter(struct batadv_priv *bat_priv, |
| u8 subtype) |
| { |
| } |
| |
| #endif /* CONFIG_BATMAN_ADV_DAT */ |
| |
| #endif /* _NET_BATMAN_ADV_DISTRIBUTED_ARP_TABLE_H_ */ |