7db7d9f369
The "Linux kernel licensing rules" require that each file has a SPDX license identifier as first line (and sometimes as second line). The FSFE REUSE practices [1] would also require the same tags but have no restrictions on the placement in the source file. Using the "Linux kernel licensing rules" is therefore also fulfilling the FSFE REUSE practices requirements at the same time. [1] https://reuse.software/practices/ Signed-off-by: Sven Eckelmann <sven@narfation.org> Signed-off-by: Simon Wunderlich <sw@simonwunderlich.de>
58 lines
1.9 KiB
C
58 lines
1.9 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/* Copyright (C) 2013-2017 B.A.T.M.A.N. contributors:
|
|
*
|
|
* Martin Hundebøll <martin@hundeboll.net>
|
|
*
|
|
* 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, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef _NET_BATMAN_ADV_FRAGMENTATION_H_
|
|
#define _NET_BATMAN_ADV_FRAGMENTATION_H_
|
|
|
|
#include "main.h"
|
|
|
|
#include <linux/compiler.h>
|
|
#include <linux/list.h>
|
|
#include <linux/stddef.h>
|
|
#include <linux/types.h>
|
|
|
|
struct sk_buff;
|
|
|
|
void batadv_frag_purge_orig(struct batadv_orig_node *orig,
|
|
bool (*check_cb)(struct batadv_frag_table_entry *));
|
|
bool batadv_frag_skb_fwd(struct sk_buff *skb,
|
|
struct batadv_hard_iface *recv_if,
|
|
struct batadv_orig_node *orig_node_src);
|
|
bool batadv_frag_skb_buffer(struct sk_buff **skb,
|
|
struct batadv_orig_node *orig_node);
|
|
int batadv_frag_send_packet(struct sk_buff *skb,
|
|
struct batadv_orig_node *orig_node,
|
|
struct batadv_neigh_node *neigh_node);
|
|
|
|
/**
|
|
* batadv_frag_check_entry - check if a list of fragments has timed out
|
|
* @frags_entry: table entry to check
|
|
*
|
|
* Return: true if the frags entry has timed out, false otherwise.
|
|
*/
|
|
static inline bool
|
|
batadv_frag_check_entry(struct batadv_frag_table_entry *frags_entry)
|
|
{
|
|
if (!hlist_empty(&frags_entry->fragment_list) &&
|
|
batadv_has_timed_out(frags_entry->timestamp, BATADV_FRAG_TIMEOUT))
|
|
return true;
|
|
return false;
|
|
}
|
|
|
|
#endif /* _NET_BATMAN_ADV_FRAGMENTATION_H_ */
|