diff options
author | Chirag Shah <chirag@cumulusnetworks.com> | 2020-02-25 03:40:29 +0100 |
---|---|---|
committer | Santosh P K <sapk@vmware.com> | 2020-04-16 17:51:38 +0200 |
commit | 09268680bb99f237517281638aecba740ed20e94 (patch) | |
tree | b1cf177355e18a804392d321f3fffe87aa73412e /zebra/zebra_nb_state.c | |
parent | lib: remove gcc 4.x workaround for nb structure (diff) | |
download | frr-09268680bb99f237517281638aecba740ed20e94.tar.xz frr-09268680bb99f237517281638aecba740ed20e94.zip |
zebra: add northbound support for zebra interface
Signed-off-by: Chirag Shah <chirag@cumulusnetworks.com>
Diffstat (limited to 'zebra/zebra_nb_state.c')
-rw-r--r-- | zebra/zebra_nb_state.c | 69 |
1 files changed, 57 insertions, 12 deletions
diff --git a/zebra/zebra_nb_state.c b/zebra/zebra_nb_state.c index 925f90b7c..788998106 100644 --- a/zebra/zebra_nb_state.c +++ b/zebra/zebra_nb_state.c @@ -21,6 +21,7 @@ #include "northbound.h" #include "libfrr.h" #include "zebra_nb.h" +#include "zebra/interface.h" /* * XPath: /frr-interface:lib/interface/frr-zebra:zebra/state/up-count @@ -29,8 +30,12 @@ struct yang_data * lib_interface_zebra_state_up_count_get_elem(const char *xpath, const void *list_entry) { - /* TODO: implement me. */ - return NULL; + const struct interface *ifp = list_entry; + struct zebra_if *zebra_if; + + zebra_if = ifp->info; + + return yang_data_new_uint16(xpath, zebra_if->up_count); } /* @@ -40,8 +45,12 @@ struct yang_data * lib_interface_zebra_state_down_count_get_elem(const char *xpath, const void *list_entry) { - /* TODO: implement me. */ - return NULL; + const struct interface *ifp = list_entry; + struct zebra_if *zebra_if; + + zebra_if = ifp->info; + + return yang_data_new_uint16(xpath, zebra_if->down_count); } /* @@ -73,8 +82,17 @@ struct yang_data * lib_interface_zebra_state_vlan_id_get_elem(const char *xpath, const void *list_entry) { - /* TODO: implement me. */ - return NULL; + const struct interface *ifp = list_entry; + struct zebra_if *zebra_if; + struct zebra_l2info_vlan *vlan_info; + + if (!IS_ZEBRA_IF_VLAN(ifp)) + return NULL; + + zebra_if = ifp->info; + vlan_info = &zebra_if->l2info.vl; + + return yang_data_new_uint16(xpath, vlan_info->vid); } /* @@ -84,8 +102,17 @@ struct yang_data * lib_interface_zebra_state_vni_id_get_elem(const char *xpath, const void *list_entry) { - /* TODO: implement me. */ - return NULL; + const struct interface *ifp = list_entry; + struct zebra_if *zebra_if; + struct zebra_l2info_vxlan *vxlan_info; + + if (!IS_ZEBRA_IF_VXLAN(ifp)) + return NULL; + + zebra_if = ifp->info; + vxlan_info = &zebra_if->l2info.vxl; + + return yang_data_new_uint32(xpath, vxlan_info->vni); } /* @@ -95,8 +122,17 @@ struct yang_data * lib_interface_zebra_state_remote_vtep_get_elem(const char *xpath, const void *list_entry) { - /* TODO: implement me. */ - return NULL; + const struct interface *ifp = list_entry; + struct zebra_if *zebra_if; + struct zebra_l2info_vxlan *vxlan_info; + + if (!IS_ZEBRA_IF_VXLAN(ifp)) + return NULL; + + zebra_if = ifp->info; + vxlan_info = &zebra_if->l2info.vxl; + + return yang_data_new_ipv4(xpath, &vxlan_info->vtep_ip); } /* @@ -106,8 +142,17 @@ struct yang_data * lib_interface_zebra_state_mcast_group_get_elem(const char *xpath, const void *list_entry) { - /* TODO: implement me. */ - return NULL; + const struct interface *ifp = list_entry; + struct zebra_if *zebra_if; + struct zebra_l2info_vxlan *vxlan_info; + + if (!IS_ZEBRA_IF_VXLAN(ifp)) + return NULL; + + zebra_if = ifp->info; + vxlan_info = &zebra_if->l2info.vxl; + + return yang_data_new_ipv4(xpath, &vxlan_info->mcast_grp); } const void *lib_vrf_ribs_rib_get_next(const void *parent_list_entry, |