xref: /f-stack/freebsd/netgraph/ng_sample.h (revision a1fd9364)
1*a1fd9364Slogwang /*
2*a1fd9364Slogwang  * ng_sample.h
3*a1fd9364Slogwang  */
4*a1fd9364Slogwang 
5*a1fd9364Slogwang /*-
6*a1fd9364Slogwang  * Copyright (c) 1996-1999 Whistle Communications, Inc.
7*a1fd9364Slogwang  * All rights reserved.
8*a1fd9364Slogwang  *
9*a1fd9364Slogwang  * Subject to the following obligations and disclaimer of warranty, use and
10*a1fd9364Slogwang  * redistribution of this software, in source or object code forms, with or
11*a1fd9364Slogwang  * without modifications are expressly permitted by Whistle Communications;
12*a1fd9364Slogwang  * provided, however, that:
13*a1fd9364Slogwang  * 1. Any and all reproductions of the source or object code must include the
14*a1fd9364Slogwang  *    copyright notice above and the following disclaimer of warranties; and
15*a1fd9364Slogwang  * 2. No rights are granted, in any manner or form, to use Whistle
16*a1fd9364Slogwang  *    Communications, Inc. trademarks, including the mark "WHISTLE
17*a1fd9364Slogwang  *    COMMUNICATIONS" on advertising, endorsements, or otherwise except as
18*a1fd9364Slogwang  *    such appears in the above copyright notice or in the software.
19*a1fd9364Slogwang  *
20*a1fd9364Slogwang  * THIS SOFTWARE IS BEING PROVIDED BY WHISTLE COMMUNICATIONS "AS IS", AND
21*a1fd9364Slogwang  * TO THE MAXIMUM EXTENT PERMITTED BY LAW, WHISTLE COMMUNICATIONS MAKES NO
22*a1fd9364Slogwang  * REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, REGARDING THIS SOFTWARE,
23*a1fd9364Slogwang  * INCLUDING WITHOUT LIMITATION, ANY AND ALL IMPLIED WARRANTIES OF
24*a1fd9364Slogwang  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT.
25*a1fd9364Slogwang  * WHISTLE COMMUNICATIONS DOES NOT WARRANT, GUARANTEE, OR MAKE ANY
26*a1fd9364Slogwang  * REPRESENTATIONS REGARDING THE USE OF, OR THE RESULTS OF THE USE OF THIS
27*a1fd9364Slogwang  * SOFTWARE IN TERMS OF ITS CORRECTNESS, ACCURACY, RELIABILITY OR OTHERWISE.
28*a1fd9364Slogwang  * IN NO EVENT SHALL WHISTLE COMMUNICATIONS BE LIABLE FOR ANY DAMAGES
29*a1fd9364Slogwang  * RESULTING FROM OR ARISING OUT OF ANY USE OF THIS SOFTWARE, INCLUDING
30*a1fd9364Slogwang  * WITHOUT LIMITATION, ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
31*a1fd9364Slogwang  * PUNITIVE, OR CONSEQUENTIAL DAMAGES, PROCUREMENT OF SUBSTITUTE GOODS OR
32*a1fd9364Slogwang  * SERVICES, LOSS OF USE, DATA OR PROFITS, HOWEVER CAUSED AND UNDER ANY
33*a1fd9364Slogwang  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
34*a1fd9364Slogwang  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
35*a1fd9364Slogwang  * THIS SOFTWARE, EVEN IF WHISTLE COMMUNICATIONS IS ADVISED OF THE POSSIBILITY
36*a1fd9364Slogwang  * OF SUCH DAMAGE.
37*a1fd9364Slogwang  *
38*a1fd9364Slogwang  * Author: Julian Elischer <[email protected]>
39*a1fd9364Slogwang  *
40*a1fd9364Slogwang  * $FreeBSD$
41*a1fd9364Slogwang  * $Whistle: ng_sample.h,v 1.3 1999/01/20 00:22:14 archie Exp $
42*a1fd9364Slogwang  */
43*a1fd9364Slogwang 
44*a1fd9364Slogwang #ifndef _NETGRAPH_NG_SAMPLE_H_
45*a1fd9364Slogwang #define _NETGRAPH_NG_SAMPLE_H_
46*a1fd9364Slogwang 
47*a1fd9364Slogwang /* Node type name. This should be unique among all netgraph node types */
48*a1fd9364Slogwang #define NG_XXX_NODE_TYPE	"sample"
49*a1fd9364Slogwang 
50*a1fd9364Slogwang /* Node type cookie. Should also be unique. This value MUST change whenever
51*a1fd9364Slogwang    an incompatible change is made to this header file, to insure consistency.
52*a1fd9364Slogwang    The de facto method for generating cookies is to take the output of the
53*a1fd9364Slogwang    date command: date -u +'%s' */
54*a1fd9364Slogwang #define NGM_XXX_COOKIE		915491374
55*a1fd9364Slogwang 
56*a1fd9364Slogwang /* Number of active DLCI's we can handle */
57*a1fd9364Slogwang #define	XXX_NUM_DLCIS		16
58*a1fd9364Slogwang 
59*a1fd9364Slogwang /* Hook names */
60*a1fd9364Slogwang #define NG_XXX_HOOK_DLCI_LEADIN	"dlci"
61*a1fd9364Slogwang #define NG_XXX_HOOK_DOWNSTREAM	"downstream"
62*a1fd9364Slogwang #define NG_XXX_HOOK_DEBUG	"debug"
63*a1fd9364Slogwang 
64*a1fd9364Slogwang /* Netgraph commands understood by this node type */
65*a1fd9364Slogwang enum {
66*a1fd9364Slogwang 	NGM_XXX_SET_FLAG = 1,
67*a1fd9364Slogwang 	NGM_XXX_GET_STATUS,
68*a1fd9364Slogwang };
69*a1fd9364Slogwang 
70*a1fd9364Slogwang /* This structure is returned by the NGM_XXX_GET_STATUS command */
71*a1fd9364Slogwang struct ngxxxstat {
72*a1fd9364Slogwang 	u_int32_t   packets_in;		/* packets in from downstream */
73*a1fd9364Slogwang 	u_int32_t   packets_out;	/* packets out towards downstream */
74*a1fd9364Slogwang };
75*a1fd9364Slogwang 
76*a1fd9364Slogwang /*
77*a1fd9364Slogwang  * This is used to define the 'parse type' for a struct ngxxxstat, which
78*a1fd9364Slogwang  * is bascially a description of how to convert a binary struct ngxxxstat
79*a1fd9364Slogwang  * to an ASCII string and back.  See ng_parse.h for more info.
80*a1fd9364Slogwang  *
81*a1fd9364Slogwang  * This needs to be kept in sync with the above structure definition
82*a1fd9364Slogwang  */
83*a1fd9364Slogwang #define NG_XXX_STATS_TYPE_INFO	{				\
84*a1fd9364Slogwang 	  { "packets_in",	&ng_parse_uint32_type	},	\
85*a1fd9364Slogwang 	  { "packets_out",	&ng_parse_uint32_type	},	\
86*a1fd9364Slogwang 	  { NULL }						\
87*a1fd9364Slogwang }
88*a1fd9364Slogwang 
89*a1fd9364Slogwang #endif /* _NETGRAPH_NG_SAMPLE_H_ */
90