2002-10-31 23:03:09 +00:00
|
|
|
/*
|
|
|
|
* ng_source.h
|
2005-01-07 01:45:51 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*-
|
2002-10-31 23:03:09 +00:00
|
|
|
* Copyright 2002 Sandvine Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Subject to the following obligations and disclaimer of warranty, use and
|
|
|
|
* redistribution of this software, in source or object code forms, with or
|
2005-03-10 21:50:50 +00:00
|
|
|
* without modifications are expressly permitted by Sandvine Inc.; provided,
|
2002-10-31 23:03:09 +00:00
|
|
|
* however, that:
|
2005-03-10 21:50:50 +00:00
|
|
|
* 1. Any and all reproductions of the source or object code must include the
|
|
|
|
* copyright notice above and the following disclaimer of warranties; and
|
2002-10-31 23:03:09 +00:00
|
|
|
* 2. No rights are granted, in any manner or form, to use Sandvine Inc.
|
2005-03-10 21:50:50 +00:00
|
|
|
* trademarks, including the mark "SANDVINE" on advertising, endorsements,
|
|
|
|
* or otherwise except as such appears in the above copyright notice or in
|
2002-10-31 23:03:09 +00:00
|
|
|
* the software.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS BEING PROVIDED BY SANDVINE "AS IS", AND TO THE MAXIMUM
|
2005-03-10 21:50:50 +00:00
|
|
|
* EXTENT PERMITTED BY LAW, SANDVINE MAKES NO REPRESENTATIONS OR WARRANTIES,
|
|
|
|
* EXPRESS OR IMPLIED, REGARDING THIS SOFTWARE, INCLUDING WITHOUT LIMITATION,
|
|
|
|
* ANY AND ALL IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
2002-10-31 23:03:09 +00:00
|
|
|
* PURPOSE, OR NON-INFRINGEMENT. SANDVINE DOES NOT WARRANT, GUARANTEE, OR
|
|
|
|
* MAKE ANY REPRESENTATIONS REGARDING THE USE OF, OR THE RESULTS OF THE
|
|
|
|
* USE OF THIS SOFTWARE IN TERMS OF ITS CORRECTNESS, ACCURACY, RELIABILITY
|
|
|
|
* OR OTHERWISE. IN NO EVENT SHALL SANDVINE BE LIABLE FOR ANY DAMAGES
|
|
|
|
* RESULTING FROM OR ARISING OUT OF ANY USE OF THIS SOFTWARE, INCLUDING
|
2005-03-10 21:50:50 +00:00
|
|
|
* WITHOUT LIMITATION, ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
|
2002-10-31 23:03:09 +00:00
|
|
|
* PUNITIVE, OR CONSEQUENTIAL DAMAGES, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
|
|
* SERVICES, LOSS OF USE, DATA OR PROFITS, HOWEVER CAUSED AND UNDER ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
* THIS SOFTWARE, EVEN IF SANDVINE IS ADVISED OF THE POSSIBILITY OF SUCH
|
|
|
|
* DAMAGE.
|
|
|
|
*
|
|
|
|
* Author: Dave Chapeskie <dchapeskie@sandvine.com>
|
|
|
|
*
|
|
|
|
* $FreeBSD$
|
|
|
|
*/
|
|
|
|
|
2003-11-11 12:30:37 +00:00
|
|
|
#ifndef _NETGRAPH_NG_SOURCE_H_
|
|
|
|
#define _NETGRAPH_NG_SOURCE_H_
|
2002-10-31 23:03:09 +00:00
|
|
|
|
|
|
|
/* Node type name and magic cookie */
|
|
|
|
#define NG_SOURCE_NODE_TYPE "source"
|
2005-04-05 17:22:05 +00:00
|
|
|
#define NGM_SOURCE_COOKIE 1110646684
|
2002-10-31 23:03:09 +00:00
|
|
|
|
|
|
|
/* Hook names */
|
|
|
|
#define NG_SOURCE_HOOK_INPUT "input"
|
|
|
|
#define NG_SOURCE_HOOK_OUTPUT "output"
|
|
|
|
|
|
|
|
/* Statistics structure returned by NGM_SOURCE_GET_STATS */
|
|
|
|
struct ng_source_stats {
|
2005-12-23 19:14:38 +00:00
|
|
|
uint64_t outOctets;
|
|
|
|
uint64_t outFrames;
|
|
|
|
uint32_t queueOctets;
|
|
|
|
uint32_t queueFrames;
|
|
|
|
uint32_t maxPps;
|
2002-10-31 23:03:09 +00:00
|
|
|
struct timeval startTime;
|
|
|
|
struct timeval endTime;
|
|
|
|
struct timeval elapsedTime;
|
2005-12-23 19:14:38 +00:00
|
|
|
struct timeval lastTime;
|
2002-10-31 23:03:09 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
extern const struct ng_parse_type ng_source_timeval_type;
|
|
|
|
/* Keep this in sync with the above structure definition */
|
|
|
|
#define NG_SOURCE_STATS_TYPE_INFO { \
|
|
|
|
{ "outOctets", &ng_parse_uint64_type }, \
|
|
|
|
{ "outFrames", &ng_parse_uint64_type }, \
|
|
|
|
{ "queueOctets", &ng_parse_uint32_type }, \
|
|
|
|
{ "queueFrames", &ng_parse_uint32_type }, \
|
2005-12-23 19:14:38 +00:00
|
|
|
{ "maxPps", &ng_parse_uint32_type }, \
|
2002-10-31 23:03:09 +00:00
|
|
|
{ "startTime", &ng_source_timeval_type }, \
|
|
|
|
{ "endTime", &ng_source_timeval_type }, \
|
|
|
|
{ "elapsedTime", &ng_source_timeval_type }, \
|
2005-12-23 19:14:38 +00:00
|
|
|
{ "lastTime", &ng_source_timeval_type }, \
|
2002-10-31 23:03:09 +00:00
|
|
|
{ NULL } \
|
|
|
|
}
|
|
|
|
|
2007-03-01 23:16:17 +00:00
|
|
|
/* Packet embedding info for NGM_SOURCE_GET/SET_TIMESTAMP */
|
|
|
|
struct ng_source_embed_info {
|
|
|
|
uint16_t offset; /* offset from ethernet header */
|
|
|
|
uint8_t flags;
|
|
|
|
uint8_t spare;
|
|
|
|
};
|
|
|
|
#define NGM_SOURCE_EMBED_ENABLE 0x01 /* enable embedding */
|
2007-03-02 01:44:04 +00:00
|
|
|
#define NGM_SOURCE_INC_CNT_PER_LIST 0x02 /* increment once per list */
|
2007-03-01 23:16:17 +00:00
|
|
|
|
|
|
|
/* Keep this in sync with the above structure definition. */
|
|
|
|
#define NG_SOURCE_EMBED_TYPE_INFO { \
|
|
|
|
{ "offset", &ng_parse_hint16_type }, \
|
|
|
|
{ "flags", &ng_parse_hint8_type }, \
|
|
|
|
{ NULL } \
|
|
|
|
}
|
|
|
|
|
2007-03-02 01:44:04 +00:00
|
|
|
/* Packet embedding info for NGM_SOURCE_GET/SET_COUNTER */
|
|
|
|
#define NG_SOURCE_COUNTERS 4
|
|
|
|
struct ng_source_embed_cnt_info {
|
|
|
|
uint16_t offset; /* offset from ethernet header */
|
|
|
|
uint8_t flags; /* as above */
|
|
|
|
uint8_t width; /* in bytes (1, 2, 4) */
|
|
|
|
uint32_t next_val;
|
|
|
|
uint32_t min_val;
|
|
|
|
uint32_t max_val;
|
|
|
|
int32_t increment;
|
|
|
|
uint8_t index; /* which counter (0..3) */
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Keep this in sync with the above structure definition. */
|
|
|
|
#define NG_SOURCE_EMBED_CNT_TYPE_INFO { \
|
|
|
|
{ "offset", &ng_parse_hint16_type }, \
|
|
|
|
{ "flags", &ng_parse_hint8_type }, \
|
|
|
|
{ "width", &ng_parse_uint8_type }, \
|
|
|
|
{ "next_val", &ng_parse_uint32_type }, \
|
|
|
|
{ "min_val", &ng_parse_uint32_type }, \
|
|
|
|
{ "max_val", &ng_parse_uint32_type }, \
|
|
|
|
{ "increment", &ng_parse_int32_type }, \
|
|
|
|
{ "index", &ng_parse_uint8_type }, \
|
|
|
|
{ NULL } \
|
|
|
|
}
|
|
|
|
|
2002-10-31 23:03:09 +00:00
|
|
|
/* Netgraph commands */
|
|
|
|
enum {
|
|
|
|
NGM_SOURCE_GET_STATS = 1, /* get stats */
|
|
|
|
NGM_SOURCE_CLR_STATS, /* clear stats */
|
|
|
|
NGM_SOURCE_GETCLR_STATS, /* atomically get and clear stats */
|
|
|
|
NGM_SOURCE_START, /* start sending queued data */
|
|
|
|
NGM_SOURCE_STOP, /* stop sending queued data */
|
|
|
|
NGM_SOURCE_CLR_DATA, /* clear the queued data */
|
2005-04-05 17:22:05 +00:00
|
|
|
NGM_SOURCE_SETIFACE, /* configure downstream iface */
|
2005-12-23 19:14:38 +00:00
|
|
|
NGM_SOURCE_SETPPS, /* rate-limiting packets per second */
|
2007-03-01 23:16:17 +00:00
|
|
|
NGM_SOURCE_SET_TIMESTAMP, /* embed xmit timestamp */
|
|
|
|
NGM_SOURCE_GET_TIMESTAMP,
|
2007-03-02 01:44:04 +00:00
|
|
|
NGM_SOURCE_SET_COUNTER, /* embed counter */
|
|
|
|
NGM_SOURCE_GET_COUNTER,
|
2002-10-31 23:03:09 +00:00
|
|
|
};
|
|
|
|
|
2003-11-11 12:30:37 +00:00
|
|
|
#endif /* _NETGRAPH_NG_SOURCE_H_ */
|