FD.io VPP  v19.04.2-12-g66b1689
Vector Packet Processing
policer.api
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2015-2016 Cisco and/or its affiliates.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at:
6  *
7  * http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 option version = "1.0.0";
17 
18 /** \brief Add/del policer
19  @param client_index - opaque cookie to identify the sender
20  @param context - sender context, to match reply w/ request
21  @param is_add - add policer if non-zero, else delete
22  @param name - policer name
23  @param cir - CIR
24  @param eir - EIR
25  @param cb - Committed Burst
26  @param eb - Excess or Peak Burst
27  @param rate_type - rate type
28  @param round_type - rounding type
29  @param type - policer algorithm
30  @param color_aware - 0=color-blind, 1=color-aware
31  @param conform_action_type - conform action type
32  @param conform_dscp - DSCP for conform mar-and-transmit action
33  @param exceed_action_type - exceed action type
34  @param exceed_dscp - DSCP for exceed mar-and-transmit action
35  @param violate_action_type - violate action type
36  @param violate_dscp - DSCP for violate mar-and-transmit action
37 */
39 {
42 
44  u8 name[64];
59 };
60 
61 /** \brief Add/del policer response
62  @param context - sender context, to match reply w/ request
63  @param retval - return value for request
64  @param policer_index - for add, returned index of the new policer
65 */
66 define policer_add_del_reply
67 {
71 };
72 
73 /** \brief Get list of policers
74  @param client_index - opaque cookie to identify the sender
75  @param context - sender context, to match reply w/ request
76  @param match_name_valid - if 0 request all policers otherwise use match_name
77  @param match_name - policer name
78 */
79 define policer_dump
80 {
83 
85  u8 match_name[64];
86 };
87 
88 /** \brief Policer operational state response.
89  @param context - sender context, to match reply w/ request
90  @param name - policer name
91  @param cir - CIR
92  @param eir - EIR
93  @param cb - Committed Burst
94  @param eb - Excess or Peak Burst
95  @param rate_type - rate type
96  @param round_type - rounding type
97  @param type - policer algorithm
98  @param conform_action_type - conform action type
99  @param conform_dscp - DSCP for conform mar-and-transmit action
100  @param exceed_action_type - exceed action type
101  @param exceed_dscp - DSCP for exceed mar-and-transmit action
102  @param violate_action_type - violate action type
103  @param violate_dscp - DSCP for violate mar-and-transmit action
104  @param single_rate - 1 = single rate policer, 0 = two rate policer
105  @param color_aware - for hierarchical policing
106  @param scale - power-of-2 shift amount for lower rates
107  @param cir_tokens_per_period - number of tokens for each period
108  @param pir_tokens_per_period - number of tokens for each period for 2-rate policer
109  @param current_limit - current limit
110  @param current_bucket - current bucket
111  @param extended_limit - extended limit
112  @param extended_bucket - extended bucket
113  @param last_update_time - last update time
114 */
115 define policer_details
116 {
118 
119  u8 name[64];
143 };
144 
145 /*
146  * Local Variables:
147  * eval: (c-set-style "gnu")
148  * End:
149  */
unsigned long u64
Definition: types.h:89
option version
Definition: policer.api:16
unsigned char u8
Definition: types.h:56
unsigned int u32
Definition: types.h:88
u8 name[64]
Definition: memclnt.api:152
signed int i32
Definition: types.h:77
clib_error_t * policer_add_del(vlib_main_t *vm, u8 *name, sse2_qos_pol_cfg_params_st *cfg, u32 *policer_index, u8 is_add)
Definition: policer.c:22