mirror of
				https://git.proxmox.com/git/mirror_frr
				synced 2025-11-04 15:30:26 +00:00 
			
		
		
		
	*: new cli-nodes for BGP SRv6 VPNv4 (step4)
This commit add just CLI-nodes for MP-BGP VPN configuration with SRv6 backend rather than MPLS. Actual configuration cli will be implemented after this commit. Example Configuration follow. This cli design is based on Cisco IOS-XR but actual cli tree design is defferent between FRR and Cisco. It's just based on cisco. ref: https://www.cisco.com/c/en/us/td/docs/routers/asr9000/software/asr9k-r6-6/segment-routing/configuration/guide/b-segment-routing-cg-asr9000-66x/b-segment-routing-cg-asr9000-66x_chapter_011.html#concept_hwj_trf_dlb router bgp 1 bgp router-id 1.1.1.1 ! segment-routing srv6 ! new cli-node locator LOC1 ! this cli will be added after this commit. ! ! Signed-off-by: Hiroki Shirokura <slank.dev@gmail.com>
This commit is contained in:
		
							parent
							
								
									b83127e156
								
							
						
					
					
						commit
						bfaab44d1e
					
				@ -9858,6 +9858,17 @@ DEFUN_NOSH (address_family_evpn,
 | 
			
		||||
	return CMD_SUCCESS;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
DEFUN_NOSH (bgp_segment_routing_srv6,
 | 
			
		||||
            bgp_segment_routing_srv6_cmd,
 | 
			
		||||
            "segment-routing srv6",
 | 
			
		||||
            "Segment-Routing configuration\n"
 | 
			
		||||
            "Segment-Routing SRv6 configuration\n")
 | 
			
		||||
{
 | 
			
		||||
	VTY_DECLVAR_CONTEXT(bgp, bgp);
 | 
			
		||||
	vty->node = BGP_SRV6_NODE;
 | 
			
		||||
	return CMD_SUCCESS;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
DEFUN_NOSH (exit_address_family,
 | 
			
		||||
       exit_address_family_cmd,
 | 
			
		||||
       "exit-address-family",
 | 
			
		||||
@ -18020,6 +18031,13 @@ static struct cmd_node bgp_flowspecv6_node = {
 | 
			
		||||
	.prompt = "%s(config-router-af-vpnv6)# ",
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
static struct cmd_node bgp_srv6_node = {
 | 
			
		||||
	.name = "bgp srv6",
 | 
			
		||||
	.node = BGP_SRV6_NODE,
 | 
			
		||||
	.parent_node = BGP_NODE,
 | 
			
		||||
	.prompt = "%s(config-router-srv6)# ",
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
static void community_list_vty(void);
 | 
			
		||||
 | 
			
		||||
static void bgp_ac_neighbor(vector comps, struct cmd_token *token)
 | 
			
		||||
@ -18094,6 +18112,7 @@ void bgp_vty_init(void)
 | 
			
		||||
	install_node(&bgp_evpn_vni_node);
 | 
			
		||||
	install_node(&bgp_flowspecv4_node);
 | 
			
		||||
	install_node(&bgp_flowspecv6_node);
 | 
			
		||||
	install_node(&bgp_srv6_node);
 | 
			
		||||
 | 
			
		||||
	/* Install default VTY commands to new nodes.  */
 | 
			
		||||
	install_default(BGP_NODE);
 | 
			
		||||
@ -18109,6 +18128,7 @@ void bgp_vty_init(void)
 | 
			
		||||
	install_default(BGP_FLOWSPECV6_NODE);
 | 
			
		||||
	install_default(BGP_EVPN_NODE);
 | 
			
		||||
	install_default(BGP_EVPN_VNI_NODE);
 | 
			
		||||
	install_default(BGP_SRV6_NODE);
 | 
			
		||||
 | 
			
		||||
	/* "bgp local-mac" hidden commands. */
 | 
			
		||||
	install_element(CONFIG_NODE, &bgp_local_mac_cmd);
 | 
			
		||||
@ -19437,6 +19457,9 @@ void bgp_vty_init(void)
 | 
			
		||||
	/* tcp-mss command */
 | 
			
		||||
	install_element(BGP_NODE, &neighbor_tcp_mss_cmd);
 | 
			
		||||
	install_element(BGP_NODE, &no_neighbor_tcp_mss_cmd);
 | 
			
		||||
 | 
			
		||||
	/* srv6 commands */
 | 
			
		||||
	install_element(BGP_NODE, &bgp_segment_routing_srv6_cmd);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#include "memory.h"
 | 
			
		||||
 | 
			
		||||
@ -120,6 +120,7 @@ enum node_type {
 | 
			
		||||
	BGP_VNC_L2_GROUP_NODE,   /* BGP VNC L2 group */
 | 
			
		||||
	RFP_DEFAULTS_NODE,       /* RFP defaults node */
 | 
			
		||||
	BGP_EVPN_NODE,		 /* BGP EVPN node. */
 | 
			
		||||
	BGP_SRV6_NODE,		 /* BGP SRv6 node. */
 | 
			
		||||
	OSPF_NODE,		 /* OSPF protocol mode */
 | 
			
		||||
	OSPF6_NODE,		 /* OSPF protocol for IPv6 mode */
 | 
			
		||||
	LDP_NODE,		 /* LDP protocol mode */
 | 
			
		||||
 | 
			
		||||
@ -1507,6 +1507,13 @@ static struct cmd_node bmp_node = {
 | 
			
		||||
	.parent_node = BGP_NODE,
 | 
			
		||||
	.prompt = "%s(config-bgp-bmp)# "
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
static struct cmd_node bgp_srv6_node = {
 | 
			
		||||
	.name = "bgp srv6",
 | 
			
		||||
	.node = BGP_SRV6_NODE,
 | 
			
		||||
	.parent_node = BGP_NODE,
 | 
			
		||||
	.prompt = "%s(config-router-srv6)# ",
 | 
			
		||||
};
 | 
			
		||||
#endif /* HAVE_BGPD */
 | 
			
		||||
 | 
			
		||||
#ifdef HAVE_OSPFD
 | 
			
		||||
@ -1862,6 +1869,39 @@ DEFUNSH(VTYSH_BGPD,
 | 
			
		||||
	return CMD_SUCCESS;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
DEFUNSH(VTYSH_BGPD,
 | 
			
		||||
        bgp_srv6,
 | 
			
		||||
        bgp_srv6_cmd,
 | 
			
		||||
        "segment-routing srv6",
 | 
			
		||||
        "Segment-Routing configuration\n"
 | 
			
		||||
        "Segment-Routing SRv6 configuration\n")
 | 
			
		||||
{
 | 
			
		||||
	vty->node = BGP_SRV6_NODE;
 | 
			
		||||
	return CMD_SUCCESS;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
DEFUNSH(VTYSH_BGPD,
 | 
			
		||||
        exit_bgp_srv6,
 | 
			
		||||
        exit_bgp_srv6_cmd,
 | 
			
		||||
        "exit",
 | 
			
		||||
        "exit Segment-Routing SRv6 configuration\n")
 | 
			
		||||
{
 | 
			
		||||
	if (vty->node == BGP_SRV6_NODE)
 | 
			
		||||
		vty->node = BGP_NODE;
 | 
			
		||||
	return CMD_SUCCESS;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
DEFUNSH(VTYSH_BGPD,
 | 
			
		||||
        quit_bgp_srv6,
 | 
			
		||||
        quit_bgp_srv6_cmd,
 | 
			
		||||
        "quit",
 | 
			
		||||
        "quit Segment-Routing SRv6 configuration\n")
 | 
			
		||||
{
 | 
			
		||||
	if (vty->node == BGP_SRV6_NODE)
 | 
			
		||||
		vty->node = BGP_NODE;
 | 
			
		||||
	return CMD_SUCCESS;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
DEFUNSH(VTYSH_BGPD, address_family_evpn, address_family_evpn_cmd,
 | 
			
		||||
	"address-family <l2vpn evpn>",
 | 
			
		||||
	"Enter Address Family command mode\n"
 | 
			
		||||
@ -4201,6 +4241,12 @@ void vtysh_init_vty(void)
 | 
			
		||||
	install_element(BMP_NODE, &bmp_exit_cmd);
 | 
			
		||||
	install_element(BMP_NODE, &bmp_quit_cmd);
 | 
			
		||||
	install_element(BMP_NODE, &vtysh_end_all_cmd);
 | 
			
		||||
 | 
			
		||||
	install_node(&bgp_srv6_node);
 | 
			
		||||
	install_element(BGP_NODE, &bgp_srv6_cmd);
 | 
			
		||||
	install_element(BGP_SRV6_NODE, &exit_bgp_srv6_cmd);
 | 
			
		||||
	install_element(BGP_SRV6_NODE, &quit_bgp_srv6_cmd);
 | 
			
		||||
	install_element(BGP_SRV6_NODE, &vtysh_end_all_cmd);
 | 
			
		||||
#endif /* HAVE_BGPD */
 | 
			
		||||
 | 
			
		||||
	/* ripd */
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user