From ba1bb08c2e89ed52aa2639a929e0c2e969e30999 Mon Sep 17 00:00:00 2001 From: mukeshmv Date: Tue, 18 Jun 2024 23:06:26 +0000 Subject: [PATCH 1/2] Add support for DPU scope DPU driven HA --- .wordlist.txt | 3 + dash-pipeline/SAI/specs/dash_eni.yaml | 13 +++++ dash-pipeline/SAI/specs/dash_ha.yaml | 78 ++++++++++++++++++++++++++ dash-pipeline/bmv2/stages/ha.p4 | 14 +++-- documentation/high-avail/ha-api-hld.md | 44 ++++++++++++++- 5 files changed, 147 insertions(+), 5 deletions(-) diff --git a/.wordlist.txt b/.wordlist.txt index d53aa7e48..11c8d37d7 100644 --- a/.wordlist.txt +++ b/.wordlist.txt @@ -377,6 +377,7 @@ Novus NPL NPU NPUS +NPUs NSG NSGs num @@ -736,3 +737,5 @@ validonly pb proto smac +BFD +hamgrd diff --git a/dash-pipeline/SAI/specs/dash_eni.yaml b/dash-pipeline/SAI/specs/dash_eni.yaml index 1dba8cad1..2cf2b98d2 100644 --- a/dash-pipeline/SAI/specs/dash_eni.yaml +++ b/dash-pipeline/SAI/specs/dash_eni.yaml @@ -585,6 +585,19 @@ sai_apis: valid_only: null is_vlan: false deprecated: false + - !!python/object:utils.sai_spec.sai_attribute.SaiAttribute + name: SAI_ENI_ATTR_IS_HA_FLOW_OWNER + description: Action parameter is HA flow owner + type: bool + attr_value_field: booldata + default: 'false' + isresourcetype: false + flags: CREATE_AND_SET + object_name: null + allow_null: false + valid_only: null + is_vlan: false + deprecated: false stats: - !!python/object:utils.sai_spec.sai_attribute.SaiAttribute name: SAI_ENI_STAT_RX_BYTES diff --git a/dash-pipeline/SAI/specs/dash_ha.yaml b/dash-pipeline/SAI/specs/dash_ha.yaml index 2911f8df8..d6809a8b2 100644 --- a/dash-pipeline/SAI/specs/dash_ha.yaml +++ b/dash-pipeline/SAI/specs/dash_ha.yaml @@ -127,6 +127,19 @@ sai_apis: valid_only: null is_vlan: false deprecated: false + - !!python/object:utils.sai_spec.sai_attribute.SaiAttribute + name: SAI_HA_SET_ATTR_SWITCHOVER_NETWORK_CONVERGENCE_TIME_MS + description: Action parameter switchover network convergence time ms + type: sai_uint32_t + attr_value_field: u32 + default: '0' + isresourcetype: false + flags: CREATE_AND_SET + object_name: null + allow_null: false + valid_only: null + is_vlan: false + deprecated: false stats: - !!python/object:utils.sai_spec.sai_attribute.SaiAttribute name: SAI_HA_SET_STAT_DP_PROBE_REQ_RX_BYTES @@ -469,6 +482,71 @@ sai_apis: valid_only: null is_vlan: false deprecated: false + - !!python/object:utils.sai_spec.sai_attribute.SaiAttribute + name: SAI_HA_SCOPE_ATTR_VIP_V4 + description: Action parameter VIP v4 + type: sai_ip_address_t + attr_value_field: ipaddr + default: 0.0.0.0 + isresourcetype: false + flags: CREATE_AND_SET + object_name: null + allow_null: false + valid_only: null + is_vlan: false + deprecated: false + - !!python/object:utils.sai_spec.sai_attribute.SaiAttribute + name: SAI_HA_SCOPE_ATTR_VIP_V6 + description: Action parameter VIP v6 + type: sai_ip_address_t + attr_value_field: ipaddr + default: 0.0.0.0 + isresourcetype: false + flags: CREATE_AND_SET + object_name: null + allow_null: false + valid_only: null + is_vlan: false + deprecated: false + - !!python/object:utils.sai_spec.sai_attribute.SaiAttribute + name: SAI_HA_SCOPE_ATTR_ADMIN_STATE + description: Action parameter admin state + type: bool + attr_value_field: booldata + default: 'false' + isresourcetype: false + flags: CREATE_AND_SET + object_name: null + allow_null: false + valid_only: null + is_vlan: false + deprecated: false + - !!python/object:utils.sai_spec.sai_attribute.SaiAttribute + name: SAI_HA_SCOPE_ATTR_ACTIVATE_ROLE + description: Action parameter activate role + type: bool + attr_value_field: booldata + default: 'false' + isresourcetype: false + flags: CREATE_AND_SET + object_name: null + allow_null: false + valid_only: null + is_vlan: false + deprecated: false + - !!python/object:utils.sai_spec.sai_attribute.SaiAttribute + name: SAI_HA_SCOPE_ATTR_DASH_HA_STATE + description: Action parameter DASH HA state + type: sai_dash_ha_state_t + attr_value_field: s32 + default: null + isresourcetype: false + flags: READ_ONLY + object_name: null + allow_null: false + valid_only: null + is_vlan: false + deprecated: false stats: [] p4_meta: !!python/object:utils.sai_spec.sai_api_p4_meta.SaiApiP4Meta tables: diff --git a/dash-pipeline/bmv2/stages/ha.p4 b/dash-pipeline/bmv2/stages/ha.p4 index 988626fd1..54e037524 100644 --- a/dash-pipeline/bmv2/stages/ha.p4 +++ b/dash-pipeline/bmv2/stages/ha.p4 @@ -12,7 +12,12 @@ control ha_stage(inout headers_t hdr, @SaiVal[type="sai_dash_ha_role_t"] dash_ha_role_t dash_ha_role, @SaiVal[isreadonly="true"] bit<32> flow_version, bit<1> flow_reconcile_requested, - @SaiVal[isreadonly="true"] bit<1> flow_reconcile_needed + @SaiVal[isreadonly="true"] bit<1> flow_reconcile_needed, + @SaiVal[type="sai_ip_address_t"] IPv4Address vip_v4, + IPv6Address vip_v6, + bit<1> admin_state, + bit<1> activate_role, + @SaiVal[isreadonly="true", type="sai_dash_ha_state_t"] dash_ha_state_t dash_ha_state ) { meta.ha.ha_set_id = ha_set_id; meta.ha.ha_role = dash_ha_role; @@ -65,11 +70,12 @@ control ha_stage(inout headers_t hdr, bit<16> dp_channel_max_src_port, bit<32> dp_channel_probe_interval_ms, bit<32> dp_channel_probe_fail_threshold, - @SaiVal[isreadonly="true"] bit<1> dp_channel_is_alive + @SaiVal[isreadonly="true"] bit<1> dp_channel_is_alive, + bit<32> switchover_network_convergence_time_ms ) { meta.ha.peer_ip_is_v6 = peer_ip_is_v6; meta.ha.peer_ip = peer_ip; - + meta.ha.dp_channel_dst_port = dp_channel_dst_port; meta.ha.dp_channel_src_port_min = dp_channel_min_src_port; meta.ha.dp_channel_src_port_max = dp_channel_max_src_port; @@ -97,7 +103,7 @@ control ha_stage(inout headers_t hdr, return; } ha_set.apply(); - + // TODO: HA state machine handling. } } diff --git a/documentation/high-avail/ha-api-hld.md b/documentation/high-avail/ha-api-hld.md index f76b470f1..946ef9730 100644 --- a/documentation/high-avail/ha-api-hld.md +++ b/documentation/high-avail/ha-api-hld.md @@ -8,6 +8,7 @@ | 0.4 | 04/01/2024 | Riff Jiang | Added capabilities for HA owner, simplified capabilities for HA topology. | | 0.5 | 04/08/2024 | Riff Jiang | Added support for bulk sync. | | 0.6 | 04/09/2024 | Riff Jiang | Added support for flow reconcile for planned and unplanned switchover. | +| 0.7 | 06/20/2024 | Mukesh Velayudhan | Added DPU scope DPU driven attributes and description. | 1. [1. Terminology](#1-terminology) 2. [2. Background](#2-background) @@ -62,6 +63,8 @@ The DASH high availability APIs are a set of APIs to support flow HA feature for For how the network topology is setup and how flow HA works, such as lifetime management, inline sync, bulk sync, and packet format, please refer to the [SmartSwitch high availability design](https://github.com/sonic-net/SONiC/blob/master/doc/smart-switch/high-availability/smart-switch-ha-hld.md). In this doc, we will only focus on the design from SAI API perspective. +These APIs also support the mode described in [SmartSwitch HA Design - DPU-scope-DPU-driven setup](https://github.com/sonic-net/SONiC/blob/master/doc/smart-switch/high-availability/smart-switch-ha-dpu-scope-dpu-driven-setup.md), in which the vendor SDK on the DPU owns the HA state machine and drives state transitions on its own by directly communicating with its HA pair underneath the SAI layer. + ## 3. Overview To support the [SmartSwitch HA workflows](https://github.com/sonic-net/SONiC/blob/master/doc/smart-switch/high-availability/smart-switch-ha-hld.md), from SAI perspective, there are a few key components involved: @@ -70,7 +73,7 @@ To support the [SmartSwitch HA workflows](https://github.com/sonic-net/SONiC/blo - **HA scope**: It controls the failover scope, such as HA role, such as active, standby or standalone, and expected flow version for new flows. Depends on the HA role of the ENI, the packet will be processed differently to get the flow synched. - **Flow table**: It is the container of all flow entries. It can be attached to all ENIs in a DPU or being attached to a single DPU, depends on at which level we like to provide the flow HA, i.e. HA scope. - **Flow**: It is used to represent a network connection, which contains match conditions and packet transformations. In HA, each flow will have it own HA-related states, such flow version, flow sync state and etc. -- **ENI**: In ENI-level HA, each ENI will be connected to a HA scope. +- **ENI**: In ENI-level HA, each ENI will be connected to a different HA scope. In DPU scope HA, all ENIs or a group of ENIs will be associated with a HA scope. The components is designed to be conceptually simple and reusable, hence we can use these components to support different HA setup. For example, to support the current ENI-level HA design, these components can be put together as below: @@ -105,6 +108,7 @@ HA set is defined as a SAI object and contains the following SAI attributes: | SAI_HA_SET_ATTR_DP_CHANNEL_PROBE_INTERVAL_MS | `sai_uint32_t` | The interval of the data plane channel probe. | | SAI_HA_SET_ATTR_DP_CHANNEL_PROBE_FAIL_THRESHOLD | `sai_uint32_t` | The threshold of the data plane channel probe fail. | | SAI_HA_SET_ATTR_DP_CHANNEL_IS_ALIVE | `bool` | (Read-only) Is data plane channel alive. | +| SAI_HA_SET_ATTR_SWITCHOVER_NETWORK_CONVERGENCE_TIME_MS | sai_uint32_t | Time for which DPU driven HA state machine needs to wait for the network to switchover traffic during planned shutdown of the other DPU in the HA pair. | ### 4.2. HA Scope @@ -117,6 +121,11 @@ HA scope is also defined as a SAI object and contains the following SAI attribut | SAI_HA_SCOPE_ATTR_FLOW_VERSION | `sai_uint32_t` | The flow version for new flows. | | SAI_HA_SCOPE_ATTR_FLOW_RECONCILE_REQUESTED | `bool` | When set to true, flow reconcile will be initiated. | | SAI_HA_SCOPE_ATTR_FLOW_RECONCILE_NEEDED | `bool` | (Read-only) If true, flow reconcile is needed. | +| SAI_HA_SCOPE_ATTR_VIP_V4 | `sai_ip_address_t` | Dedicated IPv4 VIP for DPU HA scope. | +| SAI_HA_SCOPE_ATTR_VIP_V6 | `sai_ip_address_t` | Dedicated IPv6 VIP for DPU HA scope. | +| SAI_HA_SCOPE_ATTR_ADMIN_STATE | `bool` | Start or stop the DPU driven HA state machine. | +| SAI_HA_SCOPE_ATTR_HA_STATE | `sai_dash_ha_state_t` | Read-only state in case of DPU driven state machine. | +| SAI_HA_SCOPE_ATTR_ACTIVATE_ROLE | `bool` | Trigger DPU driven HA state machine to transition to steady state and prepare to start receiving traffic destined to VIP. | The HA role is defined as below: @@ -131,12 +140,35 @@ typedef enum _sai_dash_ha_role_t } sai_dash_ha_role_t; ``` +The read-only HA state for DPU driven HA state machine is defined as below: + +```c +typedef enum _sai_dash_ha_state_t +{ + SAI_DASH_HA_STATE_DEAD, + SAI_DASH_HA_STATE_CONNECTING, + SAI_DASH_HA_STATE_CONNECTED, + SAI_DASH_HA_STATE_INITIALIZING_TO_ACTIVE, + SAI_DASH_HA_STATE_INITIALIZING_TO_STANDBY, + SAI_DASH_HA_STATE_PENDING_STANDALONE_ACTIVATION, + SAI_DASH_HA_STATE_PENDING_ACTIVE_ACTIVATION, + SAI_DASH_HA_STATE_PENDING_STANDBY_ACTIVATION, + SAI_DASH_HA_STATE_STANDALONE, + SAI_DASH_HA_STATE_ACTIVE, + SAI_DASH_HA_STATE_STANDBY, + SAI_DASH_HA_STATE_DESTROYING, + SAI_DASH_HA_STATE_SWITCHING_TO_STANDALONE, +} sai_dash_ha_state_t; +``` + ### 4.3. Flow table HA uses the DASH flow table to achieve the flow state manipulation. Since the flow table already provides the CRUD operations, we don't need any extra APIs from flow table. For more information, please refer to DASH flow API documentation. +In the case of DPU driven mode, the flow table is fully managed by the vendor SDK on the DPU and is not exposed via the DASH flow APIs. + ### 4.4. Flow To support HA, each flow contains the following SAI attributes: @@ -192,6 +224,7 @@ To provide the ENI-level HA control, each ENI will have the following SAI attrib | Attribute name | Type | Description | | -------------- | ---- | ----------- | | SAI_ENI_ATTR_HA_SCOPE_ID | `sai_object_id_t` | The HA scope ID of the ENI. | +| SAI_ENI_ATTR_IS_HA_FLOW_OWNER | `bool` | Determines which DPU in the pair creates flows belonging to this ENI in steady-state. Typically this is set to True for the ENIs on the Active DPU and False for the Standby DPU. | ### 4.6. Event notifications @@ -283,6 +316,9 @@ typedef struct _sai_ha_scope_event_data_t /** Flow version */ sai_uint32_t flow_version; + /** HA role */ + sai_dash_ha_state_t ha_state; + } sai_ha_scope_event_data_t; /** @@ -675,3 +711,9 @@ sequenceDiagram Note over S0N,S1N: hamgrd continue to drive HA
state machine and update
nexthop on all switches. ``` + +### 6.2. DPU scope DPU driven HA + +The HA workflows for this mode are described in [SmartSwitch HA Design - DPU-scope-DPU-driven setup](https://github.com/sonic-net/SONiC/blob/master/doc/smart-switch/high-availability/smart-switch-ha-dpu-scope-dpu-driven-setup.md). In this mode, the hamgrd / swss act as pass-through and relay any HA state machine triggers from the SDN controller to the DPU via SAI API calls. + +As described in the [DPU-driven setup HA set creation](https://github.com/sonic-net/SONiC/blob/master/doc/smart-switch/high-availability/smart-switch-ha-dpu-scope-dpu-driven-setup.md#81-ha-set-creation), the hamgrd/swss also listen to the HA state change event notification from the DPU and start BFD responder on the DPU to the NPUs based on the HA state. From a3e278411327230555ac5ac6dc95688f4192c54c Mon Sep 17 00:00:00 2001 From: mukeshmv Date: Wed, 10 Jul 2024 19:20:06 +0000 Subject: [PATCH 2/2] Fix doc comments, rebase to resolve conflicts --- dash-pipeline/SAI/specs/sai_spec.yaml | 56 ++++++++++++++++++++++++++ dash-pipeline/bmv2/dash_metadata.p4 | 35 ++++++++++++++-- dash-pipeline/bmv2/dash_pipeline.p4 | 7 ++-- documentation/high-avail/ha-api-hld.md | 19 +++++---- 4 files changed, 103 insertions(+), 14 deletions(-) diff --git a/dash-pipeline/SAI/specs/sai_spec.yaml b/dash-pipeline/SAI/specs/sai_spec.yaml index e30f92dce..e05a5f456 100644 --- a/dash-pipeline/SAI/specs/sai_spec.yaml +++ b/dash-pipeline/SAI/specs/sai_spec.yaml @@ -314,6 +314,62 @@ enums: name: NONE description: '' value: '0' +- !!python/object:utils.sai_spec.sai_enum.SaiEnum + name: sai_dash_ha_state_t + description: '' + members: + - !!python/object:utils.sai_spec.sai_enum_member.SaiEnumMember + name: DEAD + description: '' + value: '0' + - !!python/object:utils.sai_spec.sai_enum_member.SaiEnumMember + name: CONNECTING + description: '' + value: '1' + - !!python/object:utils.sai_spec.sai_enum_member.SaiEnumMember + name: CONNECTED + description: '' + value: '2' + - !!python/object:utils.sai_spec.sai_enum_member.SaiEnumMember + name: INITIALIZING_TO_ACTIVE + description: '' + value: '3' + - !!python/object:utils.sai_spec.sai_enum_member.SaiEnumMember + name: INITIALIZING_TO_STANDBY + description: '' + value: '4' + - !!python/object:utils.sai_spec.sai_enum_member.SaiEnumMember + name: PENDING_STANDALONE_ACTIVATION + description: '' + value: '5' + - !!python/object:utils.sai_spec.sai_enum_member.SaiEnumMember + name: PENDING_ACTIVE_ACTIVATION + description: '' + value: '6' + - !!python/object:utils.sai_spec.sai_enum_member.SaiEnumMember + name: PENDING_STANDBY_ACTIVATION + description: '' + value: '7' + - !!python/object:utils.sai_spec.sai_enum_member.SaiEnumMember + name: STANDALONE + description: '' + value: '8' + - !!python/object:utils.sai_spec.sai_enum_member.SaiEnumMember + name: ACTIVE + description: '' + value: '9' + - !!python/object:utils.sai_spec.sai_enum_member.SaiEnumMember + name: STANDBY + description: '' + value: '10' + - !!python/object:utils.sai_spec.sai_enum_member.SaiEnumMember + name: DESTROYING + description: '' + value: '11' + - !!python/object:utils.sai_spec.sai_enum_member.SaiEnumMember + name: SWITCHING_TO_STANDALONE + description: '' + value: '12' port_extenstion: !!python/object:utils.sai_spec.sai_api_extension.SaiApiExtension attributes: [] stats: diff --git a/dash-pipeline/bmv2/dash_metadata.p4 b/dash-pipeline/bmv2/dash_metadata.p4 index 19df49058..90654c7ff 100644 --- a/dash-pipeline/bmv2/dash_metadata.p4 +++ b/dash-pipeline/bmv2/dash_metadata.p4 @@ -106,7 +106,7 @@ enum bit<16> dash_flow_entry_bulk_get_session_filter_key_t DST_IP_ADDR = 5, SRC_L4_PORT = 6, DST_L4_PORT = 7, - KEY_VERSION = 8 + KEY_VERSION = 8 } enum bit<8> dash_flow_entry_bulk_get_session_op_key_t @@ -123,7 +123,7 @@ struct conntrack_data_t { bool allow_in; bool allow_out; flow_table_data_t flow_table; - EthernetAddress eni_mac; + EthernetAddress eni_mac; flow_data_t flow_data; flow_key_t flow_key; flow_key_t reverse_flow_key; @@ -169,7 +169,7 @@ struct encap_data_t { dash_encapsulation_t dash_encapsulation; EthernetAddress underlay_smac; EthernetAddress underlay_dmac; -} +} struct overlay_rewrite_data_t { bool is_ipv6; @@ -189,6 +189,35 @@ enum bit<8> dash_ha_role_t { SWITCHING_TO_ACTIVE = 4 }; +// HA states +enum bit<8> dash_ha_state_t { + DEAD = 0, + // trying to connect to HA pair + CONNECTING = 1, + // bulk sync in progress + CONNECTED = 2, + // connection successful, bulk sync in progress + INITIALIZING_TO_ACTIVE = 3, + // connection successful, bulk sync in progress + INITIALIZING_TO_STANDBY = 4, + // ready to be in STANDALONE state, waiting for activation of admin role + PENDING_STANDALONE_ACTIVATION = 5, + // ready to be in ACTIVE state, waiting for activation of admin role + PENDING_ACTIVE_ACTIVATION = 6, + // ready to be in STANDBY state, waiting for activation of admin role + PENDING_STANDBY_ACTIVATION = 7, + // activation done, fowarding traffic + STANDALONE = 8, + // activation done, fowarding traffic and syncing flows with HA pair + ACTIVE = 9, + // activation done, ready to fowarding traffic if pair fails + STANDBY = 10, + // going down for planned shutdown + DESTROYING = 11, + // gracefully transitioning from paired state to stand-alone + SWITCHING_TO_STANDALONE = 12 +}; + // Flow sync state enum bit<8> dash_ha_flow_sync_state_t { FLOW_MISS = 0, // Flow not created yet diff --git a/dash-pipeline/bmv2/dash_pipeline.p4 b/dash-pipeline/bmv2/dash_pipeline.p4 index b6a7bac8d..0113ec195 100644 --- a/dash-pipeline/bmv2/dash_pipeline.p4 +++ b/dash-pipeline/bmv2/dash_pipeline.p4 @@ -113,7 +113,8 @@ control dash_ingress( bit<1> disable_fast_path_icmp_flow_redirection, bit<1> full_flow_resimulation_requested, bit<64> max_resimulated_flow_per_second, - @SaiVal[type="sai_object_id_t"] bit<16> outbound_routing_group_id) + @SaiVal[type="sai_object_id_t"] bit<16> outbound_routing_group_id, + bit<1> is_ha_flow_owner) { meta.eni_data.cps = cps; meta.eni_data.pps = pps; @@ -338,7 +339,7 @@ control dash_ingress( } conntrack_lookup_stage.apply(hdr, meta); - + UPDATE_ENI_COUNTER(eni_rx); if (meta.is_fast_path_icmp_flow_redirection_packet) { UPDATE_ENI_COUNTER(eni_lb_fast_path_icmp_in); @@ -375,7 +376,7 @@ control dash_ingress( #endif // TARGET_BMV2_V1MODEL #ifdef TARGET_DPDK_PNA , istd - #endif // TARGET_DPDK_PNA + #endif // TARGET_DPDK_PNA ); if (meta.eni_data.dscp_mode == dash_tunnel_dscp_mode_t.PIPE_MODEL) { diff --git a/documentation/high-avail/ha-api-hld.md b/documentation/high-avail/ha-api-hld.md index 946ef9730..30406b894 100644 --- a/documentation/high-avail/ha-api-hld.md +++ b/documentation/high-avail/ha-api-hld.md @@ -108,7 +108,7 @@ HA set is defined as a SAI object and contains the following SAI attributes: | SAI_HA_SET_ATTR_DP_CHANNEL_PROBE_INTERVAL_MS | `sai_uint32_t` | The interval of the data plane channel probe. | | SAI_HA_SET_ATTR_DP_CHANNEL_PROBE_FAIL_THRESHOLD | `sai_uint32_t` | The threshold of the data plane channel probe fail. | | SAI_HA_SET_ATTR_DP_CHANNEL_IS_ALIVE | `bool` | (Read-only) Is data plane channel alive. | -| SAI_HA_SET_ATTR_SWITCHOVER_NETWORK_CONVERGENCE_TIME_MS | sai_uint32_t | Time for which DPU driven HA state machine needs to wait for the network to switchover traffic during planned shutdown of the other DPU in the HA pair. | +| SAI_HA_SET_ATTR_DPU_DRIVEN_HA_SWITCHOVER_WAIT_TIME_MS | sai_uint32_t | Time to wait for the network to switchover traffic in DPU driven HA mode. | ### 4.2. HA Scope @@ -121,10 +121,10 @@ HA scope is also defined as a SAI object and contains the following SAI attribut | SAI_HA_SCOPE_ATTR_FLOW_VERSION | `sai_uint32_t` | The flow version for new flows. | | SAI_HA_SCOPE_ATTR_FLOW_RECONCILE_REQUESTED | `bool` | When set to true, flow reconcile will be initiated. | | SAI_HA_SCOPE_ATTR_FLOW_RECONCILE_NEEDED | `bool` | (Read-only) If true, flow reconcile is needed. | -| SAI_HA_SCOPE_ATTR_VIP_V4 | `sai_ip_address_t` | Dedicated IPv4 VIP for DPU HA scope. | -| SAI_HA_SCOPE_ATTR_VIP_V6 | `sai_ip_address_t` | Dedicated IPv6 VIP for DPU HA scope. | -| SAI_HA_SCOPE_ATTR_ADMIN_STATE | `bool` | Start or stop the DPU driven HA state machine. | -| SAI_HA_SCOPE_ATTR_HA_STATE | `sai_dash_ha_state_t` | Read-only state in case of DPU driven state machine. | +| SAI_HA_SCOPE_ATTR_VIP_V4 | `sai_ip_address_t` | IPv4 VIP of the HA scope (Used in DPU driven HA mode only). | +| SAI_HA_SCOPE_ATTR_VIP_V6 | `sai_ip_address_t` | IPv6 VIP of the HA scope (Used in DPU driven HA mode only). | +| SAI_HA_SCOPE_ATTR_ADMIN_STATE | `bool` | Administrative control of HA scope (In case of DPU driven HA mode, this is used to start or stop HA state machine). | +| SAI_HA_SCOPE_ATTR_HA_STATE | `sai_dash_ha_state_t` | (Read-only) Operational HA state. | | SAI_HA_SCOPE_ATTR_ACTIVATE_ROLE | `bool` | Trigger DPU driven HA state machine to transition to steady state and prepare to start receiving traffic destined to VIP. | The HA role is defined as below: @@ -292,10 +292,13 @@ Similar to HA set, whenever any HA scope state is changed, it will be reported b typedef enum _sai_ha_scope_event_t { /** HA scope state changed */ - SAI_HA_SCOPE_STATE_CHANGED, + SAI_HA_SCOPE_EVENT_STATE_CHANGED, /** Flow reconcile is needed */ - SAI_HA_SCOPE_FLOW_RECONCILE_NEEDED, + SAI_HA_SCOPE_EVENT_FLOW_RECONCILE_NEEDED, + + /** DPU driven HA split brain detected */ + SAI_HA_SCOPE_EVENT_SPLIT_BRAIN_DETECTED, } sai_ha_scope_event_t; @@ -316,7 +319,7 @@ typedef struct _sai_ha_scope_event_data_t /** Flow version */ sai_uint32_t flow_version; - /** HA role */ + /** HA state */ sai_dash_ha_state_t ha_state; } sai_ha_scope_event_data_t;