blob: 1c46e2eb1ef92615bcdb536cf9d134f3cee0c4b1 [file] [log] [blame]
Sven Eckelmann9cfc7bd2012-05-12 02:09:43 +02001/* Copyright (C) 2010-2012 B.A.T.M.A.N. contributors:
Sven Eckelmannc6c8fea2010-12-13 11:19:28 +00002 *
3 * Andreas Langer
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_UNICAST_H_
21#define _NET_BATMAN_ADV_UNICAST_H_
22
Sven Eckelmannae361ce2011-01-25 22:02:31 +000023#include "packet.h"
24
Sven Eckelmann4d5d2db82012-06-03 22:19:15 +020025#define BATADV_FRAG_TIMEOUT 10000 /* purge frag list entries after time in ms */
26#define BATADV_FRAG_BUFFER_SIZE 6 /* number of list elements in buffer */
Sven Eckelmannc6c8fea2010-12-13 11:19:28 +000027
Sven Eckelmann56303d32012-06-05 22:31:31 +020028int batadv_frag_reassemble_skb(struct sk_buff *skb,
29 struct batadv_priv *bat_priv,
Sven Eckelmann88ed1e772012-05-12 02:09:40 +020030 struct sk_buff **new_skb);
31void batadv_frag_list_free(struct list_head *head);
Sven Eckelmann56303d32012-06-05 22:31:31 +020032int batadv_unicast_send_skb(struct sk_buff *skb, struct batadv_priv *bat_priv);
33int batadv_frag_send_skb(struct sk_buff *skb, struct batadv_priv *bat_priv,
34 struct batadv_hard_iface *hard_iface,
Sven Eckelmann88ed1e772012-05-12 02:09:40 +020035 const uint8_t dstaddr[]);
Sven Eckelmannc6c8fea2010-12-13 11:19:28 +000036
Sven Eckelmannf0530ee2012-05-12 13:48:57 +020037static inline int batadv_frag_can_reassemble(const struct sk_buff *skb, int mtu)
Sven Eckelmannae361ce2011-01-25 22:02:31 +000038{
Sven Eckelmann96412692012-06-05 22:31:30 +020039 const struct batadv_unicast_frag_packet *unicast_packet;
Sven Eckelmannae361ce2011-01-25 22:02:31 +000040 int uneven_correction = 0;
41 unsigned int merged_size;
42
Sven Eckelmann96412692012-06-05 22:31:30 +020043 unicast_packet = (struct batadv_unicast_frag_packet *)skb->data;
Sven Eckelmannae361ce2011-01-25 22:02:31 +000044
Sven Eckelmannacd34af2012-06-03 22:19:21 +020045 if (unicast_packet->flags & BATADV_UNI_FRAG_LARGETAIL) {
46 if (unicast_packet->flags & BATADV_UNI_FRAG_HEAD)
Sven Eckelmannae361ce2011-01-25 22:02:31 +000047 uneven_correction = 1;
48 else
49 uneven_correction = -1;
50 }
51
Sven Eckelmann704509b2011-05-14 23:14:54 +020052 merged_size = (skb->len - sizeof(*unicast_packet)) * 2;
Sven Eckelmann96412692012-06-05 22:31:30 +020053 merged_size += sizeof(struct batadv_unicast_packet) + uneven_correction;
Sven Eckelmannae361ce2011-01-25 22:02:31 +000054
55 return merged_size <= mtu;
56}
57
Sven Eckelmannc6c8fea2010-12-13 11:19:28 +000058#endif /* _NET_BATMAN_ADV_UNICAST_H_ */