blob: be0323055d87e9f05e5549f641f59b528a4500d6 [file] [log] [blame]
Andrew Yourtchenko815d7d52018-02-07 11:37:02 +01001/*
2 * Copyright (c) 2015 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#ifndef __included_vnet_in_out_acl_h__
17#define __included_vnet_in_out_acl_h__
18
19#include <vlib/vlib.h>
20#include <vnet/vnet.h>
21#include <vnet/classify/vnet_classify.h>
22
23typedef enum
24{
25 ACL_NEXT_INDEX_DENY,
26 ACL_NEXT_INDEX_N_NEXT,
27} acl_next_index_t;
28
29typedef enum
30{
31 IN_OUT_ACL_TABLE_IP4,
32 IN_OUT_ACL_TABLE_IP6,
33 IN_OUT_ACL_TABLE_L2,
34 IN_OUT_ACL_N_TABLES,
35} in_out_acl_table_id_t;
36
37typedef enum
38{
39 IN_OUT_ACL_INPUT_TABLE_GROUP,
40 IN_OUT_ACL_OUTPUT_TABLE_GROUP,
41 IN_OUT_ACL_N_TABLE_GROUPS
42} in_out_acl_table_group_id_t;
43
44typedef struct
45{
46
47 /* classifier table vectors */
48 u32
49 * classify_table_index_by_sw_if_index[IN_OUT_ACL_N_TABLE_GROUPS]
50 [IN_OUT_ACL_N_TABLES];
51
52 /* convenience variables */
53 vlib_main_t *vlib_main;
54 vnet_main_t *vnet_main;
55 vnet_classify_main_t *vnet_classify_main;
56 vnet_config_main_t
57 * vnet_config_main[IN_OUT_ACL_N_TABLE_GROUPS][IN_OUT_ACL_N_TABLES];
58} in_out_acl_main_t;
59
60extern in_out_acl_main_t in_out_acl_main;
61
62int vnet_set_in_out_acl_intfc (vlib_main_t * vm, u32 sw_if_index,
63 u32 ip4_table_index,
64 u32 ip6_table_index,
65 u32 l2_table_index, u32 is_add, u32 is_output);
66
67int vnet_set_input_acl_intfc (vlib_main_t * vm, u32 sw_if_index,
68 u32 ip4_table_index,
69 u32 ip6_table_index,
70 u32 l2_table_index, u32 is_add);
71
72int vnet_set_output_acl_intfc (vlib_main_t * vm, u32 sw_if_index,
73 u32 ip4_table_index,
74 u32 ip6_table_index,
75 u32 l2_table_index, u32 is_add);
76
77#endif /* __included_vnet_in_out_acl_h__ */
78
79/*
80 * fd.io coding-style-patch-verification: ON
81 *
82 * Local Variables:
83 * eval: (c-set-style "gnu")
84 * End:
85 */