aboutsummaryrefslogtreecommitdiffstats
path: root/src/scvpp/inc/scvpp/ip.h
blob: f8805b3d0163c20f582a826b3e959dda20188242 (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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
/*
 * Copyright (c) 2018 PANTHEON.tech.
 *
 * 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.
 */


#ifndef __BAPI_IP_H__
#define __BAPI_IP_H__

#include <vapi/interface.api.vapi.h>
#include <vapi/ip.api.vapi.h>

typedef vapi_payload_ip_fib_details fib_dump_t;

/*
 * @brief Dump IPv4/IPv6 address from an interface.
 * @param interface_name - name of the interface to get ip from.
 * @param ip_addr - where dump will store IP. If IP not found, returns 0.0.0.0
 * @param prefix_len - pointer where dump will store prefix
 * @param is_ipv6 - true = IPv6, false = IPv4
 * @return 0 on success, or nergative SCVPP error code
 */
extern int ipv46_address_dump(const char *interface_name, char *ip_addr,
                              u8 *prefix_len, bool is_ipv6);

/**
 * @brief Add or remove IPv4/IPv6 address to/from an interface.
 * @param interface_name - name of interface to configure
 * @param addr - address to add
 * @param prefix_len - prefix length of interface
 * @param is_ipv6 - true if ipv6, false otherwise
 * @param add - true to add, false to remove
 */
extern int ipv46_config_add_remove(const char *interface_name, const char *addr,
                                   uint8_t prefix_len, bool is_ipv6, bool add);

/*
 * TODO should add a field is_ipv6 because it only do ipv4 now
 * @brief Add or remove an IP route
 * @param dst_address - subnet IP you wish to route
 * @param dst_address_length - prefix length for subnet you wish to route
 * @param next_address - Next hop IP (can use next_hop_interface instead)
 * @param is_add - true to add, false to remove
 * @param table_id - id of the tab in FIB
 * @param next_hop_interface - Next hop interface (can use next_address instead)
 */
extern int
ipv46_config_add_del_route(const char* dst_address, u8 dst_address_length,
                           const char* next_address, u8 is_add, u32 table_id,
                           const char *next_hop_interface);

/**
 * @brief Dump all FIB tables entries
 * @return stacked answers on success, or NULL on failure
 */
extern struct elt* ipv4_fib_dump_all();

/*
 * @brief Dump information about a prefix, based on fib_dump_all
 * @param prefix_xpath - prefix to look for in FIB
 * @param reply - FIB entry dump replied
 * @return SCVPP_OK if prefix found or SCVPP_NOT_FOUND
 */
extern int ipv4_fib_dump_prefix(const char *prefix_xpath, fib_dump_t **reply);

#endif /* __BAPI_IP_H__ */