1*3b2bd0f6Slogwang /*
2*3b2bd0f6Slogwang  * ng_source.h
3*3b2bd0f6Slogwang  */
4*3b2bd0f6Slogwang 
5*3b2bd0f6Slogwang /*-
6*3b2bd0f6Slogwang  * Copyright 2002 Sandvine Inc.
7*3b2bd0f6Slogwang  * All rights reserved.
8*3b2bd0f6Slogwang  *
9*3b2bd0f6Slogwang  * Subject to the following obligations and disclaimer of warranty, use and
10*3b2bd0f6Slogwang  * redistribution of this software, in source or object code forms, with or
11*3b2bd0f6Slogwang  * without modifications are expressly permitted by Sandvine Inc.; provided,
12*3b2bd0f6Slogwang  * however, that:
13*3b2bd0f6Slogwang  * 1. Any and all reproductions of the source or object code must include the
14*3b2bd0f6Slogwang  *    copyright notice above and the following disclaimer of warranties; and
15*3b2bd0f6Slogwang  * 2. No rights are granted, in any manner or form, to use Sandvine Inc.
16*3b2bd0f6Slogwang  *    trademarks, including the mark "SANDVINE" on advertising, endorsements,
17*3b2bd0f6Slogwang  *    or otherwise except as such appears in the above copyright notice or in
18*3b2bd0f6Slogwang  *    the software.
19*3b2bd0f6Slogwang  *
20*3b2bd0f6Slogwang  * THIS SOFTWARE IS BEING PROVIDED BY SANDVINE "AS IS", AND TO THE MAXIMUM
21*3b2bd0f6Slogwang  * EXTENT PERMITTED BY LAW, SANDVINE MAKES NO REPRESENTATIONS OR WARRANTIES,
22*3b2bd0f6Slogwang  * EXPRESS OR IMPLIED, REGARDING THIS SOFTWARE, INCLUDING WITHOUT LIMITATION,
23*3b2bd0f6Slogwang  * ANY AND ALL IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
24*3b2bd0f6Slogwang  * PURPOSE, OR NON-INFRINGEMENT.  SANDVINE DOES NOT WARRANT, GUARANTEE, OR
25*3b2bd0f6Slogwang  * MAKE ANY REPRESENTATIONS REGARDING THE USE OF, OR THE RESULTS OF THE
26*3b2bd0f6Slogwang  * USE OF THIS SOFTWARE IN TERMS OF ITS CORRECTNESS, ACCURACY, RELIABILITY
27*3b2bd0f6Slogwang  * OR OTHERWISE.  IN NO EVENT SHALL SANDVINE BE LIABLE FOR ANY DAMAGES
28*3b2bd0f6Slogwang  * RESULTING FROM OR ARISING OUT OF ANY USE OF THIS SOFTWARE, INCLUDING
29*3b2bd0f6Slogwang  * WITHOUT LIMITATION, ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
30*3b2bd0f6Slogwang  * PUNITIVE, OR CONSEQUENTIAL DAMAGES, PROCUREMENT OF SUBSTITUTE GOODS OR
31*3b2bd0f6Slogwang  * SERVICES, LOSS OF USE, DATA OR PROFITS, HOWEVER CAUSED AND UNDER ANY
32*3b2bd0f6Slogwang  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
33*3b2bd0f6Slogwang  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
34*3b2bd0f6Slogwang  * THIS SOFTWARE, EVEN IF SANDVINE IS ADVISED OF THE POSSIBILITY OF SUCH
35*3b2bd0f6Slogwang  * DAMAGE.
36*3b2bd0f6Slogwang  *
37*3b2bd0f6Slogwang  * Author: Dave Chapeskie
38*3b2bd0f6Slogwang  *
39*3b2bd0f6Slogwang  * $FreeBSD$
40*3b2bd0f6Slogwang  */
41*3b2bd0f6Slogwang 
42*3b2bd0f6Slogwang #ifndef _NETGRAPH_NG_SOURCE_H_
43*3b2bd0f6Slogwang #define _NETGRAPH_NG_SOURCE_H_
44*3b2bd0f6Slogwang 
45*3b2bd0f6Slogwang /* Node type name and magic cookie */
46*3b2bd0f6Slogwang #define NG_SOURCE_NODE_TYPE	"source"
47*3b2bd0f6Slogwang #define NGM_SOURCE_COOKIE	1110646684
48*3b2bd0f6Slogwang 
49*3b2bd0f6Slogwang /* Hook names */
50*3b2bd0f6Slogwang #define NG_SOURCE_HOOK_INPUT	"input"
51*3b2bd0f6Slogwang #define NG_SOURCE_HOOK_OUTPUT	"output"
52*3b2bd0f6Slogwang 
53*3b2bd0f6Slogwang /* Statistics structure returned by NGM_SOURCE_GET_STATS */
54*3b2bd0f6Slogwang struct ng_source_stats {
55*3b2bd0f6Slogwang 	uint64_t	outOctets;
56*3b2bd0f6Slogwang 	uint64_t	outFrames;
57*3b2bd0f6Slogwang 	uint32_t	queueOctets;
58*3b2bd0f6Slogwang 	uint32_t	queueFrames;
59*3b2bd0f6Slogwang 	uint32_t	maxPps;
60*3b2bd0f6Slogwang 	struct timeval	startTime;
61*3b2bd0f6Slogwang 	struct timeval	endTime;
62*3b2bd0f6Slogwang 	struct timeval	elapsedTime;
63*3b2bd0f6Slogwang 	struct timeval	lastTime;
64*3b2bd0f6Slogwang };
65*3b2bd0f6Slogwang 
66*3b2bd0f6Slogwang extern const struct ng_parse_type ng_source_timeval_type;
67*3b2bd0f6Slogwang /* Keep this in sync with the above structure definition */
68*3b2bd0f6Slogwang #define NG_SOURCE_STATS_TYPE_INFO	{			\
69*3b2bd0f6Slogwang 	  { "outOctets",	&ng_parse_uint64_type	},	\
70*3b2bd0f6Slogwang 	  { "outFrames",	&ng_parse_uint64_type	},	\
71*3b2bd0f6Slogwang 	  { "queueOctets",	&ng_parse_uint32_type	},	\
72*3b2bd0f6Slogwang 	  { "queueFrames",	&ng_parse_uint32_type	},	\
73*3b2bd0f6Slogwang 	  { "maxPps",		&ng_parse_uint32_type	},	\
74*3b2bd0f6Slogwang 	  { "startTime",	&ng_source_timeval_type },	\
75*3b2bd0f6Slogwang 	  { "endTime",		&ng_source_timeval_type },	\
76*3b2bd0f6Slogwang 	  { "elapsedTime",	&ng_source_timeval_type },	\
77*3b2bd0f6Slogwang 	  { "lastTime",		&ng_source_timeval_type },	\
78*3b2bd0f6Slogwang 	  { NULL }						\
79*3b2bd0f6Slogwang }
80*3b2bd0f6Slogwang 
81*3b2bd0f6Slogwang /* Packet embedding info for NGM_SOURCE_GET/SET_TIMESTAMP */
82*3b2bd0f6Slogwang struct ng_source_embed_info {
83*3b2bd0f6Slogwang 	uint16_t	offset;		/* offset from ethernet header */
84*3b2bd0f6Slogwang 	uint8_t		flags;
85*3b2bd0f6Slogwang 	uint8_t		spare;
86*3b2bd0f6Slogwang };
87*3b2bd0f6Slogwang #define NGM_SOURCE_EMBED_ENABLE		0x01	/* enable embedding */
88*3b2bd0f6Slogwang #define	NGM_SOURCE_INC_CNT_PER_LIST	0x02	/* increment once per list */
89*3b2bd0f6Slogwang 
90*3b2bd0f6Slogwang /* Keep this in sync with the above structure definition. */
91*3b2bd0f6Slogwang #define NG_SOURCE_EMBED_TYPE_INFO {				\
92*3b2bd0f6Slogwang 	{ "offset",		&ng_parse_hint16_type	},	\
93*3b2bd0f6Slogwang 	{ "flags",		&ng_parse_hint8_type	},	\
94*3b2bd0f6Slogwang 	{ NULL }						\
95*3b2bd0f6Slogwang }
96*3b2bd0f6Slogwang 
97*3b2bd0f6Slogwang /* Packet embedding info for NGM_SOURCE_GET/SET_COUNTER */
98*3b2bd0f6Slogwang #define	NG_SOURCE_COUNTERS	4
99*3b2bd0f6Slogwang struct ng_source_embed_cnt_info {
100*3b2bd0f6Slogwang 	uint16_t	offset;		/* offset from ethernet header */
101*3b2bd0f6Slogwang 	uint8_t		flags;		/* as above */
102*3b2bd0f6Slogwang 	uint8_t		width;		/* in bytes (1, 2, 4) */
103*3b2bd0f6Slogwang 	uint32_t	next_val;
104*3b2bd0f6Slogwang 	uint32_t	min_val;
105*3b2bd0f6Slogwang 	uint32_t	max_val;
106*3b2bd0f6Slogwang 	int32_t		increment;
107*3b2bd0f6Slogwang 	uint8_t		index;		/* which counter (0..3) */
108*3b2bd0f6Slogwang };
109*3b2bd0f6Slogwang 
110*3b2bd0f6Slogwang /* Keep this in sync with the above structure definition. */
111*3b2bd0f6Slogwang #define NG_SOURCE_EMBED_CNT_TYPE_INFO {				\
112*3b2bd0f6Slogwang 	{ "offset",		&ng_parse_hint16_type	}, 	\
113*3b2bd0f6Slogwang 	{ "flags",		&ng_parse_hint8_type	},	\
114*3b2bd0f6Slogwang 	{ "width",		&ng_parse_uint8_type	},	\
115*3b2bd0f6Slogwang 	{ "next_val",		&ng_parse_uint32_type	},	\
116*3b2bd0f6Slogwang 	{ "min_val",		&ng_parse_uint32_type	},	\
117*3b2bd0f6Slogwang 	{ "max_val",		&ng_parse_uint32_type	},	\
118*3b2bd0f6Slogwang 	{ "increment",		&ng_parse_int32_type	},	\
119*3b2bd0f6Slogwang 	{ "index",		&ng_parse_uint8_type	},	\
120*3b2bd0f6Slogwang 	{ NULL }						\
121*3b2bd0f6Slogwang }
122*3b2bd0f6Slogwang 
123*3b2bd0f6Slogwang /* Netgraph commands */
124*3b2bd0f6Slogwang enum {
125*3b2bd0f6Slogwang 	NGM_SOURCE_GET_STATS = 1,	/* get stats */
126*3b2bd0f6Slogwang 	NGM_SOURCE_CLR_STATS,		/* clear stats */
127*3b2bd0f6Slogwang 	NGM_SOURCE_GETCLR_STATS,	/* atomically get and clear stats */
128*3b2bd0f6Slogwang 	NGM_SOURCE_START,		/* start sending queued data */
129*3b2bd0f6Slogwang 	NGM_SOURCE_STOP,		/* stop sending queued data */
130*3b2bd0f6Slogwang 	NGM_SOURCE_CLR_DATA,		/* clear the queued data */
131*3b2bd0f6Slogwang 	NGM_SOURCE_SETIFACE,		/* configure downstream iface */
132*3b2bd0f6Slogwang 	NGM_SOURCE_SETPPS,		/* rate-limiting packets per second */
133*3b2bd0f6Slogwang 	NGM_SOURCE_SET_TIMESTAMP,	/* embed xmit timestamp */
134*3b2bd0f6Slogwang 	NGM_SOURCE_GET_TIMESTAMP,
135*3b2bd0f6Slogwang 	NGM_SOURCE_SET_COUNTER,		/* embed counter */
136*3b2bd0f6Slogwang 	NGM_SOURCE_GET_COUNTER,
137*3b2bd0f6Slogwang };
138*3b2bd0f6Slogwang 
139*3b2bd0f6Slogwang #endif /* _NETGRAPH_NG_SOURCE_H_ */
140