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