mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-26 04:25:27 +08:00
7cdcf6dddc
The current unicast packet type does not contain the orig source address. This patches add a new unicast packet (called UNICAST_4ADDR) which provides two new fields: the originator source address and the subtype (the type of the data contained in the packet payload). The former is useful to identify the node which injected the packet into the network and the latter is useful to avoid creating new unicast packet types in the future: a macro defining a new subtype will be enough. Signed-off-by: Antonio Quartulli <ordex@autistici.org>
89 lines
2.9 KiB
C
89 lines
2.9 KiB
C
/* Copyright (C) 2010-2012 B.A.T.M.A.N. contributors:
|
|
*
|
|
* Andreas Langer
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of version 2 of the GNU General Public
|
|
* License as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
* 02110-1301, USA
|
|
*/
|
|
|
|
#ifndef _NET_BATMAN_ADV_UNICAST_H_
|
|
#define _NET_BATMAN_ADV_UNICAST_H_
|
|
|
|
#include "packet.h"
|
|
|
|
#define BATADV_FRAG_TIMEOUT 10000 /* purge frag list entries after time in ms */
|
|
#define BATADV_FRAG_BUFFER_SIZE 6 /* number of list elements in buffer */
|
|
|
|
int batadv_frag_reassemble_skb(struct sk_buff *skb,
|
|
struct batadv_priv *bat_priv,
|
|
struct sk_buff **new_skb);
|
|
void batadv_frag_list_free(struct list_head *head);
|
|
int batadv_frag_send_skb(struct sk_buff *skb, struct batadv_priv *bat_priv,
|
|
struct batadv_hard_iface *hard_iface,
|
|
const uint8_t dstaddr[]);
|
|
int batadv_unicast_generic_send_skb(struct batadv_priv *bat_priv,
|
|
struct sk_buff *skb, int packet_type,
|
|
int packet_subtype);
|
|
|
|
|
|
/**
|
|
* batadv_unicast_send_skb - send the skb encapsulated in a unicast packet
|
|
* @bat_priv: the bat priv with all the soft interface information
|
|
* @skb: the payload to send
|
|
*/
|
|
static inline int batadv_unicast_send_skb(struct batadv_priv *bat_priv,
|
|
struct sk_buff *skb)
|
|
{
|
|
return batadv_unicast_generic_send_skb(bat_priv, skb, BATADV_UNICAST,
|
|
0);
|
|
}
|
|
|
|
/**
|
|
* batadv_unicast_send_skb - send the skb encapsulated in a unicast4addr packet
|
|
* @bat_priv: the bat priv with all the soft interface information
|
|
* @skb: the payload to send
|
|
* @packet_subtype: the batman 4addr packet subtype to use
|
|
*/
|
|
static inline int batadv_unicast_4addr_send_skb(struct batadv_priv *bat_priv,
|
|
struct sk_buff *skb,
|
|
int packet_subtype)
|
|
{
|
|
return batadv_unicast_generic_send_skb(bat_priv, skb,
|
|
BATADV_UNICAST_4ADDR,
|
|
packet_subtype);
|
|
}
|
|
|
|
static inline int batadv_frag_can_reassemble(const struct sk_buff *skb, int mtu)
|
|
{
|
|
const struct batadv_unicast_frag_packet *unicast_packet;
|
|
int uneven_correction = 0;
|
|
unsigned int merged_size;
|
|
|
|
unicast_packet = (struct batadv_unicast_frag_packet *)skb->data;
|
|
|
|
if (unicast_packet->flags & BATADV_UNI_FRAG_LARGETAIL) {
|
|
if (unicast_packet->flags & BATADV_UNI_FRAG_HEAD)
|
|
uneven_correction = 1;
|
|
else
|
|
uneven_correction = -1;
|
|
}
|
|
|
|
merged_size = (skb->len - sizeof(*unicast_packet)) * 2;
|
|
merged_size += sizeof(struct batadv_unicast_packet) + uneven_correction;
|
|
|
|
return merged_size <= mtu;
|
|
}
|
|
|
|
#endif /* _NET_BATMAN_ADV_UNICAST_H_ */
|