summaryrefslogtreecommitdiffstats
path: root/src/plugins/gbp/gbp_classify.c
blob: 5735f359af0e2db0750308574d7b87d65747854c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
/*
 * gbp.h : Group Based Policy
 *
 * Copyright (c) 2018 Cisco and/or its affiliates.
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at:
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#include <plugins/gbp/gbp.h>
#include <plugins/gbp/gbp_classify.h>
#include <vnet/l2/l2_input.h>

gbp_src_classify_main_t gbp_src_classify_main;

static clib_error_t *
gbp_src_classify_init (vlib_main_t * vm)
{
  gbp_src_classify_main_t *em = &gbp_src_classify_main;

  vlib_node_t *node = vlib_get_node_by_name (vm, (u8 *) "gbp-src-classify");

  /* Initialize the feature next-node indexes */
  feat_bitmap_init_next_nodes (vm,
			       node->index,
			       L2INPUT_N_FEAT,
			       l2input_get_feat_names (),
			       em->l2_input_feat_next[GBP_SRC_CLASSIFY_NULL]);

  node = vlib_get_node_by_name (vm, (u8 *) "gbp-null-classify");
  feat_bitmap_init_next_nodes (vm,
			       node->index,
			       L2INPUT_N_FEAT,
			       l2input_get_feat_names (),
			       em->l2_input_feat_next[GBP_SRC_CLASSIFY_PORT]);

  node = vlib_get_node_by_name (vm, (u8 *) "l2-gbp-lpm-classify");
  feat_bitmap_init_next_nodes (vm,
			       node->index,
			       L2INPUT_N_FEAT,
			       l2input_get_feat_names (),
			       em->l2_input_feat_next[GBP_SRC_CLASSIFY_LPM]);

  return 0;
}

VLIB_INIT_FUNCTION (gbp_src_classify_init);

/*
 * fd.io coding-style-patch-verification: ON
 *
 * Local Variables:
 * eval: (c-set-style "gnu")
 * End:
 */
{ .format = "avf[%d] aq_enq_req: send_to_pf flags 0x%x datalen %d " "v_opcode %s (%d)", .format_args = "i4i2i2t2i2", .n_enum_strings = VIRTCHNL_N_OPS, .enum_strings = { #define _(v, n) [v] = #n, foreach_virtchnl_op #undef _ }, }; struct { u32 dev_instance; u16 flags; u16 datalen; u16 v_opcode; u16 v_opcode_val; } * ed; ed = ELOG_DATA (&vlib_global_main.elog_main, el); ed->dev_instance = ad->dev_instance; ed->flags = d->flags; ed->datalen = d->datalen; ed->v_opcode = ed->v_opcode_val = d->v_opcode; } else { ELOG_TYPE_DECLARE (el) = { .format = "avf[%d] aq_enq_req: opcode 0x%x flags 0x%x datalen %d", .format_args = "i4i2i2i2" }; struct { u32 dev_instance; u16 opcode; u16 flags; u16 datalen; } * ed; ed = ELOG_DATA (&vlib_global_main.elog_main, el); ed->dev_instance = ad->dev_instance; ed->opcode = d->opcode; ed->flags = d->flags; ed->datalen = d->datalen; } } void avf_elog_aq_enq_resp (avf_device_t *ad, avf_aq_desc_t *d) { ELOG_TYPE_DECLARE (el) = { .format = "avf[%d] aq_enq_resp: flags 0x%x retval %d", .format_args = "i4i2i2" }; struct { u32 dev_instance; u16 flags; u16 retval; } * ed; ed = ELOG_DATA (&vlib_global_main.elog_main, el); ed->dev_instance = ad->dev_instance; ed->flags = d->flags; ed->retval = d->retval; } void avf_elog_arq_desc (avf_device_t *ad, avf_aq_desc_t *d) { if (d->opcode == 0x802) { ELOG_TYPE_DECLARE (el) = { .format = "avf[%d] arq_desc: msg_from_pf flags 0x%x retval %d " "v_opcode %s (%d) v_retval %d", .format_args = "i4i2i2t2i2i2", .n_enum_strings = VIRTCHNL_N_OPS, .enum_strings = { #define _(v, n) [v] = #n, foreach_virtchnl_op #undef _ }, }; struct { u32 dev_instance; u16 flags; u16 retval; u16 v_opcode; u16 v_opcode_val; u16 v_retval; } * ed; ed = ELOG_DATA (&vlib_global_main.elog_main, el); ed->dev_instance = ad->dev_instance; ed->flags = d->flags; ed->retval = d->retval; ed->v_opcode = ed->v_opcode_val = d->v_opcode; ed->v_retval = d->v_retval; } else { ELOG_TYPE_DECLARE ( el) = { .format = "avf[%d] arq_desc: flags 0x%x retval %d opcode 0x%x", .format_args = "i4i2i2i2" }; struct { u32 dev_instance; u16 flags; u16 retval; u16 opcode; } * ed; ed = ELOG_DATA (&vlib_global_main.elog_main, el); ed->dev_instance = ad->dev_instance; ed->flags = d->flags; ed->retval = d->retval; ed->opcode = d->opcode; } } void avf_elog_reg (avf_device_t *ad, u32 addr, u32 val, int is_read) { uword *p; ELOG_TYPE_DECLARE (el) = { .format = "avf[%d] reg: %s %s [0x%04x] val 0x%08x", .format_args = "i4s4s4i4i4", }; struct { u32 dev_instance; char rw[4]; char reg_name[24]; u32 addr; u32 val; } * ed; ed = ELOG_DATA (&vlib_global_main.elog_main, el); ed->dev_instance = ad->dev_instance; ed->addr = addr; ed->val = val; ed->rw[0] = is_read ? 'r' : 'w'; ed->rw[1] = 0; p = hash_get (register_name_by_addr, addr); strncpy (ed->reg_name, p ? (char *) p[0] : "unknown", 24); ed->reg_name[23] = 0; } void avf_elog_init (void) { if (register_name_by_addr) return; register_name_by_addr = hash_create (0, sizeof (uword)); hash_set (register_name_by_addr, AVFINT_ICR0, "AVFINT_ICR0"); hash_set (register_name_by_addr, AVFINT_ICR0_ENA1, "INT_ICR0_ENA1"); hash_set (register_name_by_addr, AVFINT_DYN_CTL0, "INT_DYN_CTL0"); hash_set (register_name_by_addr, AVF_ARQBAH, "ARQBAH"); hash_set (register_name_by_addr, AVF_ATQH, "ATQH"); hash_set (register_name_by_addr, AVF_ATQLEN, "ATQLEN"); hash_set (register_name_by_addr, AVF_ARQBAL, "ARQBAL"); hash_set (register_name_by_addr, AVF_ARQT, "ARQT"); hash_set (register_name_by_addr, AVF_ARQH, "ARQH"); hash_set (register_name_by_addr, AVF_ATQBAH, "ATQBAH"); hash_set (register_name_by_addr, AVF_ATQBAL, "ATQBAL"); hash_set (register_name_by_addr, AVF_ARQLEN, "ARQLEN"); hash_set (register_name_by_addr, AVF_ATQT, "ATQT"); hash_set (register_name_by_addr, AVFGEN_RSTAT, "GEN_RSTAT"); for (int i = 0; i < 16; i++) { hash_set (register_name_by_addr, AVFINT_DYN_CTLN (i), format (0, "INT_DYN_CTLN(%u)%c", i, 0)); hash_set (register_name_by_addr, AVF_QTX_TAIL (i), format (0, "QTX_TAIL(%u)%c", i, 0)); hash_set (register_name_by_addr, AVF_QRX_TAIL (i), format (0, "QRX_TAIL(%u)%c", i, 0)); } }