162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci/* Copyright (C) B.A.T.M.A.N. contributors:
362306a36Sopenharmony_ci *
462306a36Sopenharmony_ci * Simon Wunderlich, Marek Lindner
562306a36Sopenharmony_ci */
662306a36Sopenharmony_ci
762306a36Sopenharmony_ci#ifndef _NET_BATMAN_ADV_BITARRAY_H_
862306a36Sopenharmony_ci#define _NET_BATMAN_ADV_BITARRAY_H_
962306a36Sopenharmony_ci
1062306a36Sopenharmony_ci#include "main.h"
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_ci#include <linux/bitops.h>
1362306a36Sopenharmony_ci#include <linux/compiler.h>
1462306a36Sopenharmony_ci#include <linux/stddef.h>
1562306a36Sopenharmony_ci#include <linux/types.h>
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_ci/**
1862306a36Sopenharmony_ci * batadv_test_bit() - check if bit is set in the current window
1962306a36Sopenharmony_ci *
2062306a36Sopenharmony_ci * @seq_bits: pointer to the sequence number receive packet
2162306a36Sopenharmony_ci * @last_seqno: latest sequence number in seq_bits
2262306a36Sopenharmony_ci * @curr_seqno: sequence number to test for
2362306a36Sopenharmony_ci *
2462306a36Sopenharmony_ci * Return: true if the corresponding bit in the given seq_bits indicates true
2562306a36Sopenharmony_ci * and curr_seqno is within range of last_seqno. Otherwise returns false.
2662306a36Sopenharmony_ci */
2762306a36Sopenharmony_cistatic inline bool batadv_test_bit(const unsigned long *seq_bits,
2862306a36Sopenharmony_ci				   u32 last_seqno, u32 curr_seqno)
2962306a36Sopenharmony_ci{
3062306a36Sopenharmony_ci	s32 diff;
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci	diff = last_seqno - curr_seqno;
3362306a36Sopenharmony_ci	if (diff < 0 || diff >= BATADV_TQ_LOCAL_WINDOW_SIZE)
3462306a36Sopenharmony_ci		return false;
3562306a36Sopenharmony_ci	return test_bit(diff, seq_bits) != 0;
3662306a36Sopenharmony_ci}
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_ci/**
3962306a36Sopenharmony_ci * batadv_set_bit() - Turn corresponding bit on, so we can remember that we got
4062306a36Sopenharmony_ci *  the packet
4162306a36Sopenharmony_ci * @seq_bits: bitmap of the packet receive window
4262306a36Sopenharmony_ci * @n: relative sequence number of newly received packet
4362306a36Sopenharmony_ci */
4462306a36Sopenharmony_cistatic inline void batadv_set_bit(unsigned long *seq_bits, s32 n)
4562306a36Sopenharmony_ci{
4662306a36Sopenharmony_ci	/* if too old, just drop it */
4762306a36Sopenharmony_ci	if (n < 0 || n >= BATADV_TQ_LOCAL_WINDOW_SIZE)
4862306a36Sopenharmony_ci		return;
4962306a36Sopenharmony_ci
5062306a36Sopenharmony_ci	set_bit(n, seq_bits); /* turn the position on */
5162306a36Sopenharmony_ci}
5262306a36Sopenharmony_ci
5362306a36Sopenharmony_cibool batadv_bit_get_packet(void *priv, unsigned long *seq_bits,
5462306a36Sopenharmony_ci			   s32 seq_num_diff, int set_mark);
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_ci#endif /* _NET_BATMAN_ADV_BITARRAY_H_ */
57