6fbf66fa |
/*
* OpenVPN -- An application to securely tunnel IP networks
* over a single TCP/UDP port, with support for SSL/TLS-based
* session authentication and key exchange,
* packet encryption, packet authentication, and
* packet compression.
* |
49979459 |
* Copyright (C) 2002-2018 OpenVPN Inc <sales@openvpn.net> |
6fbf66fa |
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2
* 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.
* |
caa54ac3 |
* 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. |
6fbf66fa |
*/
#ifndef MBUF_H
#define MBUF_H
/*
* Handle both multicast and broadcast functions.
*/
#if P2MP
/* define this to enable special test mode */
/*#define MBUF_TEST*/
#include "basic.h"
#include "buffer.h"
struct multi_instance;
#define MBUF_INDEX(head, offset, size) (((head) + (offset)) & ((size)-1))
struct mbuf_buffer
{ |
81d882d5 |
struct buffer buf;
int refcount; |
6fbf66fa |
|
81d882d5 |
#define MF_UNICAST (1<<0)
unsigned int flags; |
6fbf66fa |
};
struct mbuf_item
{ |
81d882d5 |
struct mbuf_buffer *buffer;
struct multi_instance *instance; |
6fbf66fa |
};
struct mbuf_set
{ |
81d882d5 |
unsigned int head;
unsigned int len;
unsigned int capacity;
unsigned int max_queued;
struct mbuf_item *array; |
6fbf66fa |
};
|
81d882d5 |
struct mbuf_set *mbuf_init(unsigned int size); |
6fbf66fa |
|
81d882d5 |
void mbuf_free(struct mbuf_set *ms); |
6fbf66fa |
|
81d882d5 |
struct mbuf_buffer *mbuf_alloc_buf(const struct buffer *buf); |
6fbf66fa |
|
81d882d5 |
void mbuf_free_buf(struct mbuf_buffer *mb); |
6fbf66fa |
|
81d882d5 |
void mbuf_add_item(struct mbuf_set *ms, const struct mbuf_item *item);
bool mbuf_extract_item(struct mbuf_set *ms, struct mbuf_item *item);
void mbuf_dereference_instance(struct mbuf_set *ms, struct multi_instance *mi); |
6fbf66fa |
static inline bool |
81d882d5 |
mbuf_defined(const struct mbuf_set *ms) |
6fbf66fa |
{ |
81d882d5 |
return ms && ms->len; |
6fbf66fa |
}
|
0eb39850 |
static inline unsigned int |
81d882d5 |
mbuf_len(const struct mbuf_set *ms) |
6fbf66fa |
{ |
81d882d5 |
return ms->len; |
6fbf66fa |
}
static inline int |
81d882d5 |
mbuf_maximum_queued(const struct mbuf_set *ms) |
6fbf66fa |
{ |
81d882d5 |
return (int) ms->max_queued; |
6fbf66fa |
}
|
632af53a |
struct multi_instance *mbuf_peek_dowork(struct mbuf_set *ms);
|
6fbf66fa |
static inline struct multi_instance * |
81d882d5 |
mbuf_peek(struct mbuf_set *ms) |
6fbf66fa |
{ |
81d882d5 |
if (mbuf_defined(ms))
{
return mbuf_peek_dowork(ms);
}
else
{
return NULL;
} |
6fbf66fa |
}
|
81d882d5 |
#endif /* if P2MP */
#endif /* ifndef MBUF_H */ |