blob: aa2e2537a739297f76afa54b30d87d69976d35d2 [file] [log] [blame]
Antonio Quartulli0b873932013-01-04 03:05:31 +01001/* Copyright (C) 2007-2013 B.A.T.M.A.N. contributors:
Sven Eckelmannc6c8fea2010-12-13 11:19:28 +00002 *
3 * Marek Lindner, Simon Wunderlich
4 *
5 * This program is free software; you can redistribute it and/or
6 * modify it under the terms of version 2 of the GNU General Public
7 * License as published by the Free Software Foundation.
8 *
9 * This program is distributed in the hope that it will be useful, but
10 * WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
17 * 02110-1301, USA
Sven Eckelmannc6c8fea2010-12-13 11:19:28 +000018 */
19
20#ifndef _NET_BATMAN_ADV_SEND_H_
21#define _NET_BATMAN_ADV_SEND_H_
22
Sven Eckelmann56303d32012-06-05 22:31:31 +020023int batadv_send_skb_packet(struct sk_buff *skb,
24 struct batadv_hard_iface *hard_iface,
Sven Eckelmann9455e342012-05-12 02:09:37 +020025 const uint8_t *dst_addr);
Martin Hundebølle91ecfc2013-04-20 13:54:39 +020026int batadv_send_skb_to_orig(struct sk_buff *skb,
27 struct batadv_orig_node *orig_node,
28 struct batadv_hard_iface *recv_if);
Sven Eckelmann56303d32012-06-05 22:31:31 +020029void batadv_schedule_bat_ogm(struct batadv_hard_iface *hard_iface);
30int batadv_add_bcast_packet_to_list(struct batadv_priv *bat_priv,
Sven Eckelmann9455e342012-05-12 02:09:37 +020031 const struct sk_buff *skb,
32 unsigned long delay);
33void batadv_send_outstanding_bat_ogm_packet(struct work_struct *work);
Sven Eckelmann56303d32012-06-05 22:31:31 +020034void
35batadv_purge_outstanding_packets(struct batadv_priv *bat_priv,
36 const struct batadv_hard_iface *hard_iface);
Martin Hundebøllf097e252013-05-23 16:53:01 +020037bool batadv_send_skb_prepare_unicast_4addr(struct batadv_priv *bat_priv,
38 struct sk_buff *skb,
39 struct batadv_orig_node *orig_node,
40 int packet_subtype);
Linus Lüssinge300d312013-07-03 10:40:00 +020041int batadv_send_skb_via_tt_generic(struct batadv_priv *bat_priv,
42 struct sk_buff *skb, int packet_type,
43 int packet_subtype, unsigned short vid);
44int batadv_send_skb_via_gw(struct batadv_priv *bat_priv, struct sk_buff *skb,
45 unsigned short vid);
Martin Hundebøllf097e252013-05-23 16:53:01 +020046
47/**
Linus Lüssinge300d312013-07-03 10:40:00 +020048 * batadv_send_skb_via_tt - send an skb via TT lookup
Martin Hundebøllf097e252013-05-23 16:53:01 +020049 * @bat_priv: the bat priv with all the soft interface information
50 * @skb: the payload to send
Antonio Quartullic018ad32013-06-04 12:11:39 +020051 * @vid: the vid to be used to search the translation table
Martin Hundebøllf097e252013-05-23 16:53:01 +020052 *
Linus Lüssinge300d312013-07-03 10:40:00 +020053 * Look up the recipient node for the destination address in the ethernet
54 * header via the translation table. Wrap the given skb into a batman-adv
55 * unicast header. Then send this frame to the according destination node.
56 *
57 * Returns NET_XMIT_DROP in case of error or NET_XMIT_SUCCESS otherwise.
Martin Hundebøllf097e252013-05-23 16:53:01 +020058 */
Linus Lüssinge300d312013-07-03 10:40:00 +020059static inline int batadv_send_skb_via_tt(struct batadv_priv *bat_priv,
60 struct sk_buff *skb,
61 unsigned short vid)
Martin Hundebøllf097e252013-05-23 16:53:01 +020062{
Linus Lüssinge300d312013-07-03 10:40:00 +020063 return batadv_send_skb_via_tt_generic(bat_priv, skb, BATADV_UNICAST, 0,
64 vid);
Martin Hundebøllf097e252013-05-23 16:53:01 +020065}
66
67/**
Linus Lüssinge300d312013-07-03 10:40:00 +020068 * batadv_send_skb_via_tt_4addr - send an skb via TT lookup
Martin Hundebøllf097e252013-05-23 16:53:01 +020069 * @bat_priv: the bat priv with all the soft interface information
70 * @skb: the payload to send
71 * @packet_subtype: the unicast 4addr packet subtype to use
Antonio Quartullic018ad32013-06-04 12:11:39 +020072 * @vid: the vid to be used to search the translation table
Martin Hundebøllf097e252013-05-23 16:53:01 +020073 *
Linus Lüssinge300d312013-07-03 10:40:00 +020074 * Look up the recipient node for the destination address in the ethernet
75 * header via the translation table. Wrap the given skb into a batman-adv
76 * unicast-4addr header. Then send this frame to the according destination
77 * node.
78 *
79 * Returns NET_XMIT_DROP in case of error or NET_XMIT_SUCCESS otherwise.
Martin Hundebøllf097e252013-05-23 16:53:01 +020080 */
Linus Lüssinge300d312013-07-03 10:40:00 +020081static inline int batadv_send_skb_via_tt_4addr(struct batadv_priv *bat_priv,
82 struct sk_buff *skb,
83 int packet_subtype,
84 unsigned short vid)
Martin Hundebøllf097e252013-05-23 16:53:01 +020085{
Linus Lüssinge300d312013-07-03 10:40:00 +020086 return batadv_send_skb_via_tt_generic(bat_priv, skb,
87 BATADV_UNICAST_4ADDR,
88 packet_subtype, vid);
Martin Hundebøllf097e252013-05-23 16:53:01 +020089}
Sven Eckelmannc6c8fea2010-12-13 11:19:28 +000090
91#endif /* _NET_BATMAN_ADV_SEND_H_ */