summaryrefslogtreecommitdiffstats
path: root/src/scvpp/src/sc_vpp_ip.c
diff options
context:
space:
mode:
authorYohanPipereau <ypiperea@cisco.com>2019-03-06 14:01:58 +0100
committerYohanPipereau <ypiperea@cisco.com>2019-03-29 14:39:36 +0100
commita760dfb253161911fc3aa3c8b879c461d53ade6e (patch)
tree0e79953f4ed5615879a58f49a74df3f9c6739a42 /src/scvpp/src/sc_vpp_ip.c
parent2b9b6b9b130b75799a40989c0ebe5040fa3e45fb (diff)
Sweetcomb global cleanup
-Merge IETF and Openconfig to use SCVPP 2 -Move L2 bridge from sc_vpp_interface to sc_vpp_v3po -Implement tav2 dump -Make openconfig-interfaces functions static -Try one more dispatch after failure in VAPI_CALL -Add error return code for scvpp -Remove unused length maccros -Return appropriate error code for interface dump when interface not found -Improve scvpp test suite -Change get_interface_id prototype -Use interface_dump_iface in openconfig_interface. -No more vapi types in openconfig_interfaces.c -Move openconfig_local_routing VAPI operations to sc_vpp_ip -Implement a multiple dump with a stack data structure -Comment out state_cb code from openconfig_local_routing to use new functions later. -Rename YANG model to their fully qualified name : <module>@<revision> -Remove headers almost empty and put registration declaration in sc_model.h -Shorten vapi context global variable name -Reorganize scvpp unit test suite -Add instructions to Makefile to install/uninstall YANG models in sysrepo. -Add this new instructions to README.md. -Reimplement interface_dump_all -Use a common message at INFO Log Level to know when sysrepo callbacks are triggered -Remove old structure to perform dump of all interfaces -Reimplement get_interface_name and add scvpp test for it -Clean sys_util -Use UNUSED maccro everywhere to have lighter prototypes -Have ietf-interfaces:interfaces-state work with new dump function -Add setup and teardown for NAT tests -Remove unused tapv2 dump -Remove useless sysrepo module callback -Remove xpath_find_first_key usage in openconfig-interfaces -Remove xpath_find_first_key in oc_local_routing and in the rest of sweetcomb -Reorganize scvpp include dir and fix scvpp_test new warnings -Fix scvpp tests for ip routes -Factorize scvpp nat and test return code of its function -Correct test_dump_if_all if there is an existing hardware interface -Implement a per-prefix dump in scvpp -free changes iterator in ietf-interfaces -Add new XPATH in oc local-routing -Introduce helper methods for sysrepo config callbacks -Factorize config callback -Refactor the openconfig-local-routing config callback -Use common foreach_change to iterate over changes in all models -Create a sample directory gathering example of configurations supposed to work with sweetcomb -Fix state callback of oc-local-routing -Add new sample for get operation on next-hop -foreach_elt maccro condition forgets to read one element Change-Id: I8e87fce577a00337977588f057a6e095a20f457c Signed-off-by: YohanPipereau <ypiperea@cisco.com>
Diffstat (limited to 'src/scvpp/src/sc_vpp_ip.c')
-rw-r--r--src/scvpp/src/sc_vpp_ip.c206
1 files changed, 0 insertions, 206 deletions
diff --git a/src/scvpp/src/sc_vpp_ip.c b/src/scvpp/src/sc_vpp_ip.c
deleted file mode 100644
index 0dfd108..0000000
--- a/src/scvpp/src/sc_vpp_ip.c
+++ /dev/null
@@ -1,206 +0,0 @@
-/*
- * 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.
- */
-
-#include "sc_vpp_comm.h"
-#include "sc_vpp_ip.h"
-
-#include "sc_vpp_interface.h"
-
-#include <assert.h>
-
-// Use VAPI macros to define symbols
-DEFINE_VAPI_MSG_IDS_IP_API_JSON
-
-VAPI_RETVAL_CB(sw_interface_add_del_address);
-
-static vapi_error_e
-bin_api_sw_interface_add_del_address(u32 sw_if_index, bool is_add, bool is_ipv6,
- bool del_all, u8 address_length,
- const char *ip_address)
-{
- vapi_msg_sw_interface_add_del_address *mp;
- vapi_error_e rv;
-
- ARG_CHECK(VAPI_EINVAL, ip_address);
-
- mp = vapi_alloc_sw_interface_add_del_address(g_vapi_ctx_instance);
- assert(NULL != mp);
-
- mp->payload.sw_if_index = sw_if_index;
- mp->payload.is_add = is_add;
- mp->payload.is_ipv6 = is_ipv6;
- mp->payload.del_all = del_all;
- mp->payload.address_length = address_length;
- if (sc_aton(ip_address, mp->payload.address, sizeof(mp->payload.address)))
- return VAPI_EINVAL;
-
- VAPI_CALL(vapi_sw_interface_add_del_address(g_vapi_ctx_instance, mp,
- sw_interface_add_del_address_cb, NULL));
-
- return rv;
-}
-
-VAPI_COPY_CB(ip_add_del_route)
-
-static vapi_error_e
-bin_api_ip_add_del_route(vapi_payload_ip_add_del_route_reply * reply,
- const char* dst_address, uint8_t dst_address_length,
- const char* next_hop, uint8_t is_add,
- uint32_t table_id, const char *interface_name)
-{
- sw_interface_details_query_t query = {0};
- vapi_msg_ip_add_del_route *mp;
-
- ARG_CHECK4(VAPI_EINVAL, reply, dst_address, next_hop, interface_name);
-
- sw_interface_details_query_set_name(&query, interface_name);
-
- if (!get_interface_id(&query))
- return VAPI_EINVAL;
-
- mp = vapi_alloc_ip_add_del_route (g_vapi_ctx_instance, 1);
- assert(NULL != mp);
-
- //ip route add 2.2.2.2/24 via 5.5.5.5
- //show ip fib table 0 2.2.2.0/24 detail
-
- mp->payload.is_add = is_add;
- mp->payload.dst_address_length = dst_address_length;
- mp->payload.table_id = table_id;
- mp->payload.next_hop_sw_if_index = query.sw_interface_details.sw_if_index;
-
- if (sc_aton(dst_address, mp->payload.dst_address,
- sizeof(mp->payload.dst_address)))
- return VAPI_EINVAL;
- if (sc_aton(next_hop, mp->payload.next_hop_address,
- sizeof(mp->payload.next_hop_address)))
- return VAPI_EINVAL;
-
- vapi_error_e rv ;
- VAPI_CALL(vapi_ip_add_del_route(g_vapi_ctx_instance, mp, ip_add_del_route_cb, reply));
-
- return rv;
-}
-
-static vapi_error_e
-ip_address_dump_cb (struct vapi_ctx_s *ctx, void *callback_ctx, vapi_error_e rv,
- bool is_last, vapi_payload_ip_address_details *reply)
-{
- UNUSED(rv);
- ARG_CHECK3(VAPI_EINVAL, ctx, callback_ctx, reply);
-
- //copy dump reply in callback context
- if (!is_last && callback_ctx) {
- vapi_payload_ip_address_details *passed =
- (vapi_payload_ip_address_details *) callback_ctx;
- *passed = *reply;
- }
-
- return VAPI_OK;
-}
-
-static vapi_error_e
-bin_api_ip_address_dump(u32 sw_if_index, bool is_ipv6,
- vapi_payload_ip_address_details *dctx)
-{
- vapi_msg_ip_address_dump *mp;
- vapi_error_e rv;
-
- mp = vapi_alloc_ip_address_dump(g_vapi_ctx_instance);
- mp->payload.sw_if_index = sw_if_index;
- mp->payload.is_ipv6 = is_ipv6;
-
- VAPI_CALL(vapi_ip_address_dump(g_vapi_ctx_instance, mp, ip_address_dump_cb,
- dctx));
- if (rv != VAPI_OK)
- return rv;
-
- return VAPI_OK;
-}
-
-/*
- * @brief Dump IPv4/IPv6 address from an interface.
- * @param interface_name Name of the interface to dump.
- * @param ip_addr pointer where dump will store IP.
- * @param prefix_len pointer where dump will store prefix
- */
-int ipv46_address_dump(const char *interface_name, char *ip_addr,
- u8 *prefix_len, bool is_ipv6)
-{
- vapi_payload_ip_address_details dctx = {0};
- sw_interface_details_query_t query = {0};
- vapi_error_e rv;
-
- sw_interface_details_query_set_name(&query, interface_name);
-
- if (!get_interface_id(&query))
- return -EINVAL;
-
- rv = bin_api_ip_address_dump(query.sw_interface_details.sw_if_index, is_ipv6, &dctx);
- if (rv != VAPI_OK)
- return -EAGAIN;
-
- strcpy(ip_addr, sc_ntoa(dctx.ip)); //IP string
- *prefix_len = dctx.prefix_length; //prefix length
-
- return 0;
-}
-
-/**
- * @brief Add or remove IPv4/IPv6 address to/from an interface.
- */
-int ipv46_config_add_remove(const char *if_name, const char *addr,
- uint8_t prefix, bool is_ipv6, bool add)
-{
- vapi_error_e rv;
- int rc;
-
- ARG_CHECK2(-1, if_name, addr);
-
- /* get interface index */
- sw_interface_details_query_t query = {0};
- sw_interface_details_query_set_name(&query, if_name);
- rc = get_interface_id(&query);
- if (!rc)
- return -EINVAL;
-
- /* add del addr */
- rv = bin_api_sw_interface_add_del_address(query.sw_interface_details.sw_if_index,
- add, is_ipv6, 0, prefix, addr);
- if (rv != VAPI_OK)
- return -EINVAL;
-
- return 0;
-}
-
-/*
- * @brief Add or remove an IP route
- */
-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 *interface)
-{
- vapi_payload_ip_add_del_route_reply reply = {0};
- vapi_error_e rv;
-
- rv = bin_api_ip_add_del_route(&reply, dst_address, dst_address_length,
- next_address, is_add, table_id, interface);
- if (VAPI_OK != rv || reply.retval > 0) {
- return -EINVAL;
- }
-
- return 0;
-}