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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
/*
* 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 <vnet/vnet.h>
#include <vlibmemory/api.h>
#include <vnet/mfib/mfib_api.h>
#include <vnet/mfib/mfib_table.h>
#include <vnet/fib/fib_api.h>
#include <vnet/ip/ip_types_api.h>
static vl_api_mfib_itf_flags_t
mfib_api_path_itf_flags_encode (mfib_itf_flags_t flags)
{
vl_api_mfib_itf_flags_t out = MFIB_API_ITF_FLAG_NONE;
switch (flags)
{
case MFIB_ITF_FLAG_NONE:
out = MFIB_API_ITF_FLAG_NONE;
break;
case MFIB_ITF_FLAG_NEGATE_SIGNAL:
out = MFIB_API_ITF_FLAG_NEGATE_SIGNAL;
break;
case MFIB_ITF_FLAG_ACCEPT:
out = MFIB_API_ITF_FLAG_ACCEPT;
break;
case MFIB_ITF_FLAG_FORWARD:
out = MFIB_API_ITF_FLAG_FORWARD;
break;
case MFIB_ITF_FLAG_SIGNAL_PRESENT:
out = MFIB_API_ITF_FLAG_SIGNAL_PRESENT;
break;
case MFIB_ITF_FLAG_DONT_PRESERVE:
out = MFIB_API_ITF_FLAG_DONT_PRESERVE;
break;
}
return (ntohl(out));
}
void
mfib_api_path_encode (const fib_route_path_t *in,
vl_api_mfib_path_t *out)
{
out->itf_flags = mfib_api_path_itf_flags_encode(in->frp_mitf_flags);
fib_api_path_encode(in, &out->path);
}
static void
mfib_api_path_itf_flags_decode (vl_api_mfib_itf_flags_t in,
mfib_itf_flags_t *out)
{
in = clib_net_to_host_u32(in);
if (in & MFIB_API_ITF_FLAG_NEGATE_SIGNAL)
*out |= MFIB_ITF_FLAG_NEGATE_SIGNAL;
if (in & MFIB_API_ITF_FLAG_ACCEPT)
*out |= MFIB_ITF_FLAG_ACCEPT;
if (in & MFIB_API_ITF_FLAG_FORWARD)
*out |= MFIB_ITF_FLAG_FORWARD;
if (in & MFIB_API_ITF_FLAG_SIGNAL_PRESENT)
*out |= MFIB_ITF_FLAG_SIGNAL_PRESENT;
if (in & MFIB_API_ITF_FLAG_DONT_PRESERVE)
*out |= MFIB_ITF_FLAG_DONT_PRESERVE;
}
mfib_entry_flags_t
mfib_api_path_entry_flags_decode (vl_api_mfib_entry_flags_t in)
{
mfib_entry_flags_t out;
out = MFIB_ENTRY_FLAG_NONE;
in = clib_net_to_host_u32(in);
if (in & MFIB_API_ENTRY_FLAG_SIGNAL)
out |= MFIB_ENTRY_FLAG_SIGNAL;
if (in & MFIB_API_ENTRY_FLAG_DROP)
out |= MFIB_ENTRY_FLAG_DROP;
if (in & MFIB_API_ENTRY_FLAG_CONNECTED)
out |= MFIB_ENTRY_FLAG_CONNECTED;
if (in & MFIB_API_ENTRY_FLAG_ACCEPT_ALL_ITF)
out |= MFIB_ENTRY_FLAG_ACCEPT_ALL_ITF;
return (out);
}
int
mfib_api_path_decode (vl_api_mfib_path_t *in,
fib_route_path_t *out)
{
mfib_api_path_itf_flags_decode(in->itf_flags, &out->frp_mitf_flags);
return (fib_api_path_decode(&in->path, out));
}
int
mfib_api_table_id_decode (fib_protocol_t fproto,
u32 table_id,
u32 *fib_index)
{
*fib_index = mfib_table_find(fproto, table_id);
if (INDEX_INVALID == *fib_index)
{
return VNET_API_ERROR_NO_SUCH_FIB;
}
return (0);
}
|