blob: ae414aea6dc7114b4063accf6f6cb59329118c59 [file] [log] [blame]
Neale Ranns0bfe5d82016-08-25 15:29:12 +01001/*
2 * Copyright (c) 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 * Midchain Adjacency sub-type. These adjs represent an L3 peer on a
17 * tunnel interface. The tunnel's adjacency is thus not the end of the chain,
18 * and needs to stack on/link to another chain (or portion of the graph) to
19 * reach the tunnel's destination.
20 */
21
22#ifndef __ADJ_MIDCHAIN_H__
23#define __ADJ_MIDCHAIN_H__
24
25#include <vnet/adj/adj.h>
26
27/**
Neale Ranns5e575b12016-10-03 09:40:25 +010028 * @brief Flags controlling the midchain adjacency
29 */
30typedef enum adj_midchain_flag_t_
31{
32 /**
33 * No flags
34 */
35 ADJ_MIDCHAIN_FLAG_NONE = 0,
36
37 /**
38 * Packets TX through the midchain do not increment the interface
39 * counters. This should be used when the adj is associated with an L2
40 * interface and that L2 interface is in a bridege domain. In that case
41 * the packet will have traversed the interface's TX node, and hence have
42 * been counted, before it traverses ths midchain
43 */
44 ADJ_MIDCHAIN_FLAG_NO_COUNT = (1 << 0),
45} adj_midchain_flag_t;
46
47/**
Neale Ranns0bfe5d82016-08-25 15:29:12 +010048 * @brief
49 * Convert an existing neighbour adjacency into a midchain
50 *
51 * @param adj_index
52 * The index of the neighbour adjacency.
53 *
54 * @param post_rewrite_node
55 * The VLIB graph node that provides the post-encap fixup.
56 * where 'fixup' is e.g., correcting chksum, length, etc.
57 *
58 * @param rewrite
59 * The rewrite.
60 */
61extern void adj_nbr_midchain_update_rewrite(adj_index_t adj_index,
Neale Ranns5e575b12016-10-03 09:40:25 +010062 adj_midchain_fixup_t fixup,
63 adj_midchain_flag_t flags,
Neale Ranns0bfe5d82016-08-25 15:29:12 +010064 u8 *rewrite);
65
66/**
67 * @brief
68 * [re]stack a midchain. 'Stacking' is the act of forming parent-child
69 * relationships in the data-plane graph.
70 *
71 * @param adj_index
72 * The index of the midchain to stack
73 *
74 * @param dpo
75 * The parent DPO to stack onto (i.e. become a child of).
76 */
77extern void adj_nbr_midchain_stack(adj_index_t adj_index,
78 const dpo_id_t *dpo);
79
80/**
81 * @brief
Neale Ranns5e575b12016-10-03 09:40:25 +010082 * unstack a midchain. This will break the chain between the midchain and
83 * the next graph section. This is a implemented as stack-on-drop
84 *
85 * @param adj_index
86 * The index of the midchain to stack
87 */
88extern void adj_nbr_midchain_unstack(adj_index_t adj_index);
89
90/**
91 * @brief
Neale Ranns0bfe5d82016-08-25 15:29:12 +010092 * Module initialisation
93 */
94extern void adj_midchain_module_init(void);
95
96/**
97 * @brief
98 * Format a midchain adjacency
99 */
100extern u8* format_adj_midchain(u8* s, va_list *ap);
101
102#endif