Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Srv6 static config HLD #1860

Merged
merged 26 commits into from
Jan 7, 2025
Merged
Show file tree
Hide file tree
Changes from 12 commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
ed6c1c2
init draft of srv6_static_config_hld.md
BYGX-wcr Nov 28, 2024
cb0a83d
add description for bgpcfgd changes and enrich the high-level picture
BYGX-wcr Nov 29, 2024
2301048
add doc/srv6/images/SRv6_bgpcfgd.png
BYGX-wcr Nov 29, 2024
100b3fc
refine YANG model definition and add UT test cases
BYGX-wcr Nov 30, 2024
7758034
update contents
BYGX-wcr Nov 30, 2024
906d87a
enrich UT cases and bgpcfgd changes' description
BYGX-wcr Dec 2, 2024
793e255
add arg_len back for completeness and add one more UT case
BYGX-wcr Dec 2, 2024
633fae3
add standard YANG model for srv6
BYGX-wcr Dec 4, 2024
c6f49cb
change uint16 to uint8 in YANG model
BYGX-wcr Dec 4, 2024
13720b9
remove uA; define enum for actions; set default vrf value
BYGX-wcr Dec 5, 2024
bd92ca2
remove uA test cases
BYGX-wcr Dec 6, 2024
098a038
add a note about the new FRR CLI
BYGX-wcr Dec 10, 2024
5fb2d75
add a table for supported behaviors
BYGX-wcr Dec 11, 2024
833483b
add dscp mode field in the SRV6_MY_SID_TABLE
BYGX-wcr Dec 12, 2024
3a8f49b
remove vrf field and add constraint for dscp_mode field
BYGX-wcr Dec 12, 2024
d0fcc74
move the complete definition of yang model to sonic-yang-models dir
BYGX-wcr Dec 13, 2024
21420cc
add vrf parameter back and remove uDT6
BYGX-wcr Dec 16, 2024
078dd6e
fix the YANG model rep
BYGX-wcr Dec 16, 2024
53c80e0
update the CONFIG_DB to use two tables
BYGX-wcr Dec 20, 2024
41d0cf2
remove the _TABLE suffix of the table names
BYGX-wcr Dec 22, 2024
81cc67d
supplement the missing prefix attribute of the SRV6_MY_LOCATORS table
BYGX-wcr Dec 22, 2024
fb20b35
Optimize the text
BYGX-wcr Dec 26, 2024
3c5f54b
update the HLD to use VRF as part of the key for SRV6_MY_SIDS table
BYGX-wcr Jan 2, 2025
49a62fc
fix typos
BYGX-wcr Jan 3, 2025
11ac46c
replace vrf with locator in the key combo of SRV6_MY_SIDS
BYGX-wcr Jan 4, 2025
c5b1b06
fix typos and add an example for my locators table
BYGX-wcr Jan 6, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Binary file added doc/srv6/images/SRv6_bgpcfgd.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
79 changes: 79 additions & 0 deletions doc/srv6/sonic-srv6.yang
Original file line number Diff line number Diff line change
@@ -0,0 +1,79 @@
module sonic-srv6 {
revision 2024-12-05 {
description
"Initial revision.";
}
namespace "http://github.com/sonic-net/sonic-srv6";

import ietf-yang-types {
prefix yang;
}

import ietf-inet-types {
prefix inet;
}

import sonic-common {
prefix scommon;
}

container sonic-srv6 {
scommon:db-name "CONFIG_DB";

list SRV6_MY_SID_TABLE {
key "ip-address";
scommon:key-delim "|";
scommon:key-pattern "SRV6_MY_SID_TABLE|{ip-address}";

leaf ip-address {
type inet:ipv6-address;
}

leaf block_len {
type uint8 {
range "1..128";
}

default 32;
}

leaf node_len {
type uint8 {
range "1..128";
}

default 16;
}

leaf func_len {
type uint8 {
range "1..128";
}

default 16;
}

leaf arg_len {
type uint8 {
range "1..128";
}

default 0;
}

leaf action {
type enumeration {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This might restrict the static configuration only for the 3 types below. Is the plan to support only these 3 types for now and later extend it?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, currently we only plan to support these 3 types of action.

enum uN;
Copy link
Collaborator

@venkatmahalingam venkatmahalingam Dec 11, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This means that you support only uSID not regular end.dt6, end.dt46..etc, correct?, we should mention clearly in the HLD that static SRv6 supports only uSID based handling now.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I added a table for the current list of supported behaviors. Feel free to extend the list after you add the necessary support and tests.

enum uDT6;
enum uDT46;
}
}

leaf vrf {
type leafref {
path "/vrf:sonic-vrf/VRF/VRF_LIST/name";
}
}
}
}
}
162 changes: 162 additions & 0 deletions doc/srv6/srv6_static_config_hld.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,162 @@
# Static Configuration of SRv6 in SONiC HLD

# Table of Contents

- [Revision](#revision)
- [Definition/Abbreviation](#definitionabbreviation)
- [About This Manual](#about-this-manual)
- [1 Introuduction and Scope](#1-introuduction-and-scope)
- [2 Feature Requirements](#2-feature-requirements)
- [2.1 Functional Requirements](#21-functional-requirements)
- [2.2 Configuration and Managment Requirements](#22-configuration-and-management-requirements)
- [2.3 Warm Boot Requirements](#23-warm-boot-requirements)
- [3 Feature Design](#3-feature-design)
- [3.1 New Table in ConfigDB](#31-new-table-in-configdb)
- [3.2 Bgpcfgd Changes](#32-bgpcfgd-changes)
- [3.3 YANG Model](#33-yang-model)
- [4 Unit Test](#4-unit-test)
- [5 References ](#5-references)

# Revision

| Rev | Date | Author | Change Description |
| :--: | :-------: | :------------------------: | :---------------------: |
| 0.1 | 12/5/2024 | Changrong Wu | Initial version |


# Definition/Abbreviation

### Table 1: Abbreviations

| ****Term**** | ****Meaning**** |
| -------- | ----------------------------------------- |
| BGP | Border Gateway Protocol |
| SID | Segment Identifier |
| SRv6 | Segment Routing IPv6 |
| SDN | Software Defined Network |
| uSID | Micro Segment |
| VRF | Virtual Routing and Forwarding |

# About this Manual

This document provides general information about the design of the enhancements in SONiC to support static configuration of Segmentation Routing over IPv6 protocol, which is crucial for SRv6 SDN deployment (without usage of BGP).
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Are we adding support only for end-point behaviors? how about steering the traffic to SRv6 at the head-end?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes. Right now, we only intend to add support for end-point behaviors because the traffic steering is done on the NICs in our use scenarios.

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit:
s/Segmentation Routing/Segment Routing


# 1 Introuduction and Scope

This document describes the high-level design of the new features in SONiC to support SRv6 SDN.
The new features include the addtion of a new table in CONFIG_DB to allow static configuration of SRv6 and the enhancement of bgpcfgd to program FRR with input from CONFIG_DB.
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi @BYGX-wcr, thanks for the HLD to support SRv6 uSID static configuration.

The static SRv6 uSID configuration model in FRR as follows:

  • Configure an SRv6 locator and identify its parameters (name, prefix, block-len, node-len, func-bits). The CLI for this is already in FRR mainline.
  • Configure a static SRv6 SID under the SRv6 locator and identify its parameters (behavior, vrf, etc.). The CLI for this is being added in this FRR PR (staticd: Add support for SRv6 Static SIDs FRRouting/frr#16894)

In the current HLD, the configuration model is different and hence can’t be mapped to the current SRv6 uSID configuration model in FRR.

To resolve this, I would propose the following:

  • Create a new table (SRV6_MY_LOCATOR) for the SRv6 locator config and its parameters (name, prefix, block-len, node-len, func-bits).
  • In the SRV6_MY_SID_TABLE, you add the locator as new parameter for the SID. The locator parameter points to one of the locators in SRV6_MY_LOCATOR via the locator’s name. This way you can map the config to FRR config.

FRR inherits the (block-len, node-len, func-bits) of the locator and install the static SID into SONiC APPL_DB via fpm-sonic-dplane. This is already mainline in FRR and SONiC.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copy link
Contributor

@abdosi abdosi Dec 12, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@ahsalam: I understand the logic being used by SRV6_MY_LOCATOR. However our current config db schema is good enough to program FRR. We do not want indirection logic using 2 different config tables. If you see in below example we have all the information to program frr. We will parse ipv6 address and extract the opcode prefix to FRR. Keeping one table in synch with APP_DB format is easier for us.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@ahsalam / @eddieruan-alibaba : We also planning to remove vrf from config db schema as our current use case is to use SAI_MY_SID_ENTRY_ATTR_TUNNEL_ID for uDT46 usecase. Currently Tunnel Decap Schema

### TUNNEL_DECAP_TERM_TABLE
does not support vrf for overlay interface so their is no point of specifying VRF as needed by SAI_MY_SID_ENTRY_ATTR_VRF.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

DT46 will use default VRF. Our use case is not a typical L3VPN use case.

Besides, this document also define new YANG model specification and unit-test cases used to validate the aforementioned features.


# 2 Feature Requirements

## 2.1 Functional Requirements

Provide ability to statically configure SRv6 SIDs for block IDs, locators and local functions from CONFIG_DB.

## 2.2 Configuration and Management Requirements

1. User should be able to statically configure block length, locator length and function length for SRv6.

2. User should be able to statically configure a number of SIDs/uSIDs for the local functions of the switch.

## 2.3 Warm Boot Requirements

Warm reboot is intended to be supported for planned system warm reboot.



# 3 Feature Design

At the time of writing this document, FRR has been able to program the SRv6 related tables in APPL_DB through fpmsyncd.
However, there is still one gap preventing SONiC being utilized for SRv6 SDN deployment.
Specifically, there is no mechamism in SONiC allowing SDN controllers or users to directly add configuration for SRv6 without involving BGP.

In this document, we first define a new **SRV6_MY_SID_TABLE** table in CONFIG_DB that serves as the configuration source of SRv6 in SONiC.
Then, we design a new SRv6 Manager module in bgpcfgd to subscribe to the **SRV6_MY_SID_TABLE** table and compile changes in CONFIG_DB to changes in the configurations of FRR (Note: the new SRv6 Manager relies on the new configuration CLI brought in by [FRR PR#16894](https://github.com/FRRouting/frr/pull/16894)).
To verify the correctness of the aforementioned flow, we also define the relevant YANG model specification.
The workflow of the new mechanism is shown in the following diagram.

![Static SRv6 Config flow](images/SRv6_bgpcfgd.png)

The design details of each step is described in the following subsections.

## 3.1 New Table in ConfigDB


**SRV6_MY_SID_TABLE**

Description: New table to hold local SID definition and SID to behavior mapping. (A simplified redefinition of SRV6_MY_SID_TABLE in [SRv6_HLD](./srv6_hld.md))

Schema:

```
; New table
; holds local SID to behavior mapping, allow 1:1 or n:1 mapping

key = SRV6_MY_SID_TABLE|ipv6address
; field = value
block_len = blen ; bit length of block portion in address, default 32
node_len = nlen ; bit length of node ID portion in address, default 16
func_len = flen ; bit length of function portion in address, default 16
arg_len = alen ; bit length of argument portion in address, default 0
action = behavior ; behaviors defined for the SID, default uN
vrf = VRF_TABLE.key ; Optional, VRF name for decapsulation actions, only applicable to "uDT6" and "uDT46" by now, default "default"

For example:
"SRV6_MY_SID_TABLE" : {
"FCBB:BBBB:20::" : {
"action": "uN"
},
"FCBB:BBBB:20:F1::" : {
"action": "uDT46",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

add decap_dscp_mode also in example

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

added

},
"FCBB:BBBB:20:F2::" : {
"action": "uDT46",
"vrf": "VRF-1001"
},
}
```


## 3.2 Bgpcfgd changes
Copy link
Collaborator

@venkatmahalingam venkatmahalingam Dec 11, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We're already using frrcfgd for SRv6, I would suggest to use frrcfgd for static SRv6 also for consistency, if there is any reason to use bpgcfgd, please state here.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi Venkatsen,

The primary reason is that we don't use frrcfgd in our daily operations. Since bgpcfgd has been leveraged to do static route configuration, we think it is not inappropriate to use bgpcfgd for static SRv6 configuration.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should we discuss it in Routing WG? @BYGX-wcr @venkatmahalingam @lguohan

Copy link
Collaborator

@venkatmahalingam venkatmahalingam Dec 11, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, it would be helpful for the WG to understand/aware the new changes coming in for static SRv6.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Azure Networking has an event tonight starting at 6pm so I am unable to join this week's routing WG meeting. May we discuss this in next week's routing WG meeting? I can start an email thread about this topic. @venkatmahalingam, may you share your email address with me?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@eddieruan-alibaba
Has static SRv6 meeting happened? Is there a recording

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copy link
Collaborator


Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you please capture the FRR configuration sample. It would be good if you can provide sonic field to FRR configuration mapping.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There is still some ongoing discussion on the details of the new FRR configuration CLI. We'd better add the config sample and mapping later.

To enable automatic programming SRv6 configurations from CONFIG_DB to FRR, we need to add a new module in bgpcfgd to watch changes in **SRV6_MY_SID_TABLE** and compile the corresponding changes in FRR's configurations.
Following the naming convention of modules in bgpcfgd, we call this new module SRv6 Manager.
The new SRv6 Manager are supposed to verify the validity of the configuration entries coming from the CONFIG_DB.
If it gets an invalid configuration input, it should log the event in the syslog and not compile the configuration into FRR.

## 3.3 YANG Model
The simplified version of the YANG model is defined below.
```
module: sonic-srv6
+--rw sonic-srv6
+--rw SRV6_MY_SID
| +--rw SRV6_MY_SID_LIST* [ip-address]
| +--rw ip-address inet:ipv6-address
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can't we have same ipv6 address exist across VRFs? should use VRF as a key instead of field in the table?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This table defines the MY_SID_LIST which should only have one instance in the current system. The VRF field is used to specify which VRF should be used for look up after the SRv6 functions decapsulates the packet. It is not used to specify which VRF the SID belongs to.

| +--rw block_len? uint8
| +--rw node_len? uint8
| +--rw func_len? uint8
| +--rw arg_len? uint8
| +--rw action? enum
| +--rw vrf? -> /vrf:sonic-vrf/VRF/VRF_LIST/name
```
Refer to [sonic-srv6.yang](./sonic-srv6.yang) for the YANG model defined with standard IETF syntax.

## 4 Unit Test

|Test Cases (done on default instance and VRF)| Test Result |
| :------ | :----- |
|add config for a SID with uN action in CONFIG_DB | verify the locator config entry is created in FRR config|
|add config for a SID with uDT46 action associated with VRF-1001 in CONFIG_DB | verify the opcode config entry is created in FRR config with correct VRF|
|add config for a SID with uDT46 action without VRF parameter in CONFIG_DB | verify the opcode config entry is created in FRR config with default VRF|
|(Negative case) add config for a SID without action in CONFIG_DB | verify that the configuration did not get into FRR config |
|(Negative case) add config for a SID with an unsupported action in CONFIG_DB | verify that the configuration did not get into FRR config |
|(Negative case) add config for a decap SID with an invalid VRF name in CONFIG_DB | verify that the configuration did not get into FRR config |
|delete config for a SID with uN action in CONFIG_DB | verify the locator config entry is deleted in FRR config|
|delete config for a SID with uDT46 action associated with VRF-1001 in CONFIG_DB | verify the opcode config entry for the uDT46 action is deleted in FRR config|

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@BYGX-wcr : can we add some failure UT case also. What will happen if bgpcfgd gets exception and exited ? I assume bgp/swss/syncd docker restart and everything should get reprommed but lets add the test case to confirm.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do you mean when bgpcfgd restarts, the SRv6 manager should retrieve all existing MY_SID config from CONFIG_DB and program them to FRR?


## 5 References