The Switch Abstraction Interface defines the APIs to provide a vendor-independent way of controlling forwarding elements, such as a switching ASIC, an NPU or a software switch in a uniform manner.
This document describes the SAI changes done for new features, enhancements on existing features/sub-features and various bug fixes.
List of new features is as follows.
- TAM APIs
- NAT APIs
- sFlow APIs
- Generic Resource Monitoring
- SAI counters
- Drop Counters
Telemetry And Monitoring (TAM) has been enhanced from 1.0 to 2.0 to achieve the following goals:
- Express top-level Telemetry and Monitoring domain for Inband Telemetry
- Remain backwards compatible for application with minimal or no change in the application code
- Provide extensibility for new functions/capability in each domain/subdomain and always remain backward compatible
- Remove any hard coded assumptions about domain or domain’s capabilities
- Provide full abstraction for operators to dynamically learn the number of domains supported within a networking element
- Provide full abstraction for operators to dynamically learn domains capabilities
- Provide flexibility to add new APIs for a given domain/subdomain
- Support local mathematical functions for hierarchical analysis
- create_tam_int: This API is to create a TAM object. This will further be used to create a binding to the switch
sai_status_t (*sai_create_tam_report_fn)( _Out_ sai_object_id_t *tam_report_id, _In_ sai_object_id_t switch_id, _In_ uint32_t attr_count, _In_ const sai_attribute_t *attr_list);
- remove_tam_int: This API is to remove the TAM object that is already created
sai_status_t (*sai_remove_tam_int_fn)( _In_ sai_object_id_t tam_int_id);
- set_tam_int_attribute: This API is used to set value for a specified interface object attribute
sai_status_t (*sai_set_tam_int_attribute_fn)( _In_ sai_object_id_t tam_int_id, _In_ const sai_attribute_t *attr);
- get_tam_int_attribute: This API is used to get values for specified interface object attributes
sai_status_t (*sai_get_tam_int_attribute_fn)( _In_ sai_object_id_t tam_int_id, _In_ uint32_t attr_count, _Inout_ sai_attribute_t *attr_list);
- tam_telemetry_get_data: This will return data of all the source objects bound to the TAM object or data pertaining to the source only based on the option chosen in the attribute list
sai_status_t (*sai_tam_telemetry_get_data_fn)( _In_ sai_object_id_t switch_id, _In_ uint32_t attr_count, _In_ const sai_attribute_t *attr_list);
More details about this feature enhancement are available at TAM2.0 Spec PRs related to this feature are PR958 and PR959
Provisioning of APIs to configure NAT feature. API set is generic to configure various types of NAT. A SAI pipeline including NAT is added in this release.
Features:
- Basic NAT (SNAT, DNAT)
- subnet based NAT
- NAPT
- Double NAT
- NAT Exceptions
- NAT Hairpin
New SAI APIs are introduced for configuring the following.
- NAT Zones: NAT zones are translation domains configured by SONiC. Each RIF can be member of single NAT Zone only. NAT happens when packet crosses NAT zone boundary. Translations within the same domain is considered as NAT HAIRPINING and requires DOUBLE NAT.
- Enabling NAT: This defines the SAI NAT specifications with attributes such as 'range', set', 'get', 'remove' etc
- Enable Traps for SNAT, DNAT and HAIRPIN Miss Packets: Traps are configured to record the count of packets based on the source and destination Network Address Translation.
- TAM GET API: Besides configuration, this API can read the NAT table to get aging details.
-
create_nat_range: This API will create a NAT range that will include the start and end values
sai_status_t (*sai_create_nat_range_fn)( _Out_ sai_object_id_t *nat_range_id, _In_ sai_object_id_t switch_id, _In_ uint32_t attr_count, _In_ const sai_attribute_t *attr_list);
-
remove_nat_range: This API deletes a specified NAT range_object and also single specified NAT range
sai_status_t (*sai_remove_nat_range_fn)( _In_ sai_object_id_t nat_range_id);
-
set_nat_range_attribute: This API sets the NAT range attribute values for adapter specific extensions
sai_status_t (*sai_get_nat_range_attribute_fn)( _In_ sai_object_id_t nat_range_id, _In_ uint32_t attr_count, _Inout_ sai_attribute_t *attr_list);
-
get_nat_range_attribute: This API gets values for specified NAT range attribute
sai_status_t (*sai_get_nat_range_attribute_fn)( _In_ sai_object_id_t nat_range_id, _In_ uint32_t attr_count, _Inout_ sai_attribute_t *attr_list);
-
create_nat: This API creates and returns a NAT range object
sai_status_t (*sai_create_nat_fn)( _Out_ sai_object_id_t *nat_id, _In_ sai_object_id_t switch_id, _In_ uint32_t attr_count, _In_ const sai_attribute_t *attr_list);
-
remove_nat: This API deletes a specified NAT range_object and also single specified NAT range
sai_status_t (*sai_remove_nat_fn)( _In_ sai_object_id_t nat_id);
-
set_nat_attribute: This API sets NAT attribute value(s) for adapter specific extensions
sai_status_t (*sai_set_nat_attribute_fn)( _In_ sai_object_id_t nat_id, _In_ const sai_attribute_t *attr);
-
get_nat_attribute: This API gets values for specified NAT attributes for adapter specific extensions
sai_status_t (*sai_get_nat_attribute_fn)( _In_ sai_object_id_t nat_id, _In_ uint32_t attr_count, _Inout_ sai_attribute_t *attr_list);
PRs related to this feature is PR937
sFlow (defined in https://sflow.org/sflow_version_5.txt) is a standard-based sampling technology the meets the key requirements of network traffic monitoring on switches and routers. sFlow uses two types of sampling:
- A statistical packet-based sampling of switched or routed packet flows to provide visibility into network usage and active routes
- A time-based sampling of interface counters.
The sFlow monitoring system consists of:
- sFlow agents that reside in network equipment which gather network traffic and port counters and combines the flow samples and interface counters into sFlow datagrams and forwards them to the sFlow collector at regular intervals over a UDP socket
- sFlow collectors which receive and analyze the sFlow data.
sFlow support in SAI requires both sample packet proposal and host-if proposal changes. The sample packet APIs haven't changed and is used as-is. Host-if is updated to create a new Generic Netlink based interface to lift sFlow samples to the application (sFlow agents) using the following new attributes:
- SAI_HOSTIF_TYPE_GENETLINK
- SAI_HOSTIF_ATTR_GENETLINK_MCGRP_NAME
- SAI_HOSTIF_TABLE_ENTRY_CHANNEL_TYPE_GENETLINK
PRs related to Host-if proposal changes are 936 and 997
SAI manages ASIC resources. It is important for the user to query the current resources usage in the ASIC for different types of SAI objects. It is also essential to make as much resources availability exposed as possible.
- sai_object_type_get_availability: This is a generic API for SAI resource monitoring. The function accepts an object type for which availability is queried. A new annotation is added to mark object attributes that are used to distinguish between different resource pools of the same object type.
sai_status_t sai_object_type_get_availability(
_In_ sai_object_type_t object_type,
_In_ uint32_t attr_count,
_In_ const sai_attribute_t *attr_list,
_Out_ uint64_t *count);
PRs related to Resource monitoring function addition is 942
Defining counters explicitly per object type imposes restrictions to their usage. Hence the new counter's model introduces APIs to query which objects support which counters and create a counter object that can be dynamically attached to other objects
- sai_create_counter: This API creates a counter that can be attached to an object to collect the statistics. Attaching a counter to an object does not clear it's stats values.
sai_status_t (*sai_create_counter_fn)(
_Out_ sai_object_id_t *counter_id,
_In_ sai_object_id_t switch_id,
_In_ uint32_t attr_count,
_In_ const sai_attribute_t *attr_list);
- sai_remove_counter: This API removes a counter that is attached to an object to collect the statistics. Detaching a counter from an object does not clear it's stats values
sai_status_t (*sai_remove_counter_fn)(
_In_ sai_object_id_t counter_id);
-
sai_set_counter_attribute: This API sets the attribute value for the given object ID
sai_status_t (*sai_set_counter_attribute_fn)( _In_ sai_object_id_t counter_id, _In_ const sai_attribute_t *attr);
-
sai_get_counter_attribute: This API gets the counter's attribute values for the given object ID
sai_status_t (*sai_get_counter_attribute_fn)( _In_ sai_object_id_t counter_id, _In_ uint32_t attr_count, _Inout_ sai_attribute_t *attr_list);
-
sai_get_counter_stats: This API gets the counter statistics values
sai_status_t (*sai_get_counter_stats_fn)( _In_ sai_object_id_t counter_id, _In_ uint32_t number_of_counters, _In_ const sai_stat_id_t *counter_ids, _Out_ uint64_t *counters);
-
sai_get_counter_stats_ext: This API gets the statistics of the IP packets collected from the counters
sai_status_t (*sai_get_counter_stats_ext_fn)( _In_ sai_object_id_t counter_id, _In_ uint32_t number_of_counters, _In_ const sai_stat_id_t *counter_ids, _In_ sai_stats_mode_t mode, _Out_ uint64_t *counters);
-
sai_clear_counter_stats: This API clears the statistics collected in the counters
sai_status_t (*sai_clear_counter_stats_fn)( _In_ sai_object_id_t counter_id, _In_ uint32_t number_of_counters, _In_ const sai_stat_id_t *counter_ids);
PRs related to Resource monitoring function addition is 939
NOTE: The APIs that define certain attributes are Adapter-specific extensions to SAI, most typically to expose differentiated functionality in the underlying forwarding element. These are added to minimize compatibility issues with versioning of structures and to allow API extensibility
A new list of drop counters is added in the structure "sai_port_in_drop_reason_t", that includes dropping reasons like source mac being multicast, source mac same as destination mac etc. as given in the design document.
A new set of SAI API's is added as follows to support this feature.
-
sai_create_debug_counter_fn: This API is used to create debug counter
sai_status_t (*sai_create_debug_counter_fn)( _Out_ sai_object_id_t *debug_counter_id, _In_ sai_object_id_t switch_id, _In_ uint32_t attr_count, _In_ const sai_attribute_t *attr_list);
-
sai_remove_debug_counter_fn: This API is used to remove debug counter
sai_status_t (*sai_remove_debug_counter_fn)( _In_ sai_object_id_t debug_counter_id);
-
sai_set_debug_counter_attribute_fn: This API is used to set debug counter attribute Value
sai_status_t (*sai_set_debug_counter_attribute_fn)( _In_ sai_object_id_t debug_counter_id, _In_ const sai_attribute_t *attr);
-
sai_get_debug_counter_attribute_fn: This API is used to get debug counter attribute Value
sai_status_t (*sai_get_debug_counter_attribute_fn)( _In_ sai_object_id_t debug_counter_id, _In_ uint32_t attr_count, _Inout_ sai_attribute_t *attr_list);
PRs related to this feature is PR985
- PR918: checksymbols.pl: Relax metadata symbols placement in data section
- PR928: saiswitch.h A copy of the original packet is sent to CPU port, the original packet is forcefully forwarded in the pipeline.
- PR929: saibridge.h: Added bridge port type router to facilitate flooding to the router or a tunnel, on top of the regular behaviour of flooding to all local ports, without needing to manage the list of local ports, by choosing the combined flood type. A sample use case for flooding to the router, is VXLAN L3 peering use case, demonstrated in OCP, where unknown unicast traffic is sent to the router.
- PR936: saihostif.h: Added a generic Netlink interface (over a loopback) to receive trapped packets/buffers from the SAI driver. This can be used as an alternative to callback/FD based mechanisms.
- PR937: sainat.h: Added Network Address Translation (NAT) specific API definitions.
- PR938: TAM: Introduced a special data pull function in the existing API structure.
- PR939: saicounter.h: Generic counters are added for better visibility and debugging. Tx packet and byte count for statistics along with stats in custom range base is added. The behaviour of the counter is that it can be attached/detached multiple times during its lifetime. Attaching or detaching a counter from an object does not clear its stats values. Counter can be attached to multiple objects at the same time.
- PR942: SAI.h: SAI generic resource monitoring. To help differentiate between different resource pools for the same object type; attributes that are annotated with
@isresourcetype
must be passed to the function with corresponding values - PR946: saihostif.h: Added support for BFD packets to be trapped to CPU
- PR947: saiswitch.h: Added an RO attribute for STP Max Instances on the switch object.
- PR948: saiport.h: Added an attribute for controlling Link Training on the ports, for improving interoperability among devices.
- PR958: TAM: Added attributes to associate telemetry objects and probes. Created an object in the driver for tracking the buffer usage.
- PR959: TAM: Added optional attribute in ACL to bind a TAM INT object. Enhanced sai_tam_int_type enum to distinguish between P4 INT v1 and v2 and added a codepoint for direct export.
- PR960: saibfd.h, saiswitch.h: Added capabilities for the SAI/BFD API to allow applications to query the list of supported offloads (SAI_BFD_SESSION_OFFLOAD_TYPE_FULL, SAI_BFD_SESSION_OFFLOAD_TYPE_SUSTENANCE & SAI_BFD_SESSION_OFFLOAD_TYPE_NONE) and choose an offload while creating a BFD session.
- PR962: saiacl.h: Fixed SAI_ACL_ENTRY_ATTR_ACTION_PACKET_ACTION description.
- PR964: saitypes.h: Fixed qosmap comment in sai_attribute_value_t.
- PR969: saiseraialize.c, saiseraializetest.c: Fixes for ARM32 bit in the usage of printf format specifiers.
- PR970: saihostif.h: Added an RO attribute to trap object, to count the packets trapped to CPU.
- PR971: saiport.h: added attribute SAI_PORT_ATTR_PTP_MODE to port-obj for timestamping for PTP packets.
- PR974: saibfd.h: Added additional attributes for BFD Session like SAI_BFD_ENCAPSULATION_TYPE_NONE to sai_bfd_encapsulation_type_t, Negotiated Transmit interval, Negotiated Receive interval, Local Diagnostic code field, Remote Diagnostic code field and Remote time Multiplier to sai_bfd_session_attr_t, mostly for diagnostics purpose.
- PR980: saibuffer: Added more explanation to include headroom pool in the ingress buffer pool.
- PR983: Added additional fields for hashing - inner ip protocol, inner ethertype, inner l4 src/dst port, inner src/dst mac that can be used for tunneled packets.
- PR985: As explained in section 1.6.1 of drop counters.
- PR988: saitam.h: Add support for an INT type where the metadata (ingress and egress timestamps) are inserted at the end of the packet before the Ethernet CRC
- PR991: saitam.h: Added an optional attribute to tam/report object to add support for Aggregate reporting for TAM Events. This is an optional attribute, the current functionality of reporting every event is unaffected. User can select 'aggregate' mode for the report mode attribute and specify an interval. When chosen, aggregate-reports are sent at the chosen interval.
- PR993: saiserialize.c: Fix for Unsigned long usage in 32bit arch using ULL macro
- PR996: saibuffer.h : The currently defined 32bit type can't hold large sizes for the buffers. Changed the buffer size data type from 32bit to 64bits.
- PR997: saihostif.h: Changing the genetlink multicast sampling group attribute from ID to name.
- PR998: sairouterinterface.h: While creating a sub port router interface the necessity to create an object id for vlan has been removed.
- PR916: SAITEST: Added new test scripts SAI PTF tests for the below tests. Added sai_thrift_set_neighbor_attribute proc to update the MAC entry. L2MtuTest, L3MtuTest, L2MacMoveTestI, L2MacMoveTestII, L2MacMoveTestIII, L3IPv4NeighborMacTest, L3IPv6NeighborMacTest.
- PR921: SAITEST: Added L3 Directed Broadcast tests into SAI PTF tests for L3DirectedBroadcast-I, II.
- PR922: SAITEST: Added new test script SAI PTF tests for NeighborFdbAgeoutTest. Closed this PR and opened another PR-961 to resolve conflicts.
- PR923: SAITEST: fix saithrift compilation with newer thrift
- PR924: SAITEST: Added new test script SAI PTF tests for IPv4/IPv6 ECMP Group member (L3IPv4EcmpGroupMemberTest-I, II, III), L3IPv6EcmpGroupMemberTest-I, II).
- PR925: SAITEST: Added new test script SAI PTF tests for LAG ACL (L3AclTableTest, L3AclTableGroupTest).
- PR933: SAITEST: Adding SAI PTF tests for L3IPV4EcmpHashSeed
- PR934: SAITEST: Added SAI PTF Test for LAGHashseedTest.
- PR935: SAITEST: Added SAI PTF tests for BridgePortTest-I.
- PR949: SAITEST: Implementation of a buffer pool statistics counter in a Broadcom DUT is executed.
- PR950: SAITEST: Metafiles 'saiserializetest.c', 'saisanitycheck.c', 'Makefile', 'test.pm' are updated to work on GCC & PERL.
- PR956: SAITEST: Added enhancements for L2 VLAN broadcast/Unicast. The enhancements are removing the MAC from the MAC table after testing and removing only the testing ports from default VLAN before the testing.
- PR961: SAITEST: Added SAI PTF tests for NeighborFdbAgeoutTest.
- PR963: SAITEST: Fixed the wrong argument for api sai_thrift_flush_fdb_by_vlan.
- PR967: SAITEST: Fixed SAI PTF Script error in L3IPv6EcmpGroupMemberTest.
- PR972: SAITEST: Added new test scripts to SAI PTF tests for L3LpbkSubnetTest.
- PR973: SAITEST: Added a new test scripts to SAI PTF tests for L3IPv4_32Test.
- PR975: SAITEST: Added new test script to SAI PTF test for L3AclTableGroupTestII.
- PR976: SAITEST: Added new test scripts to SAI PTF tests for 3AclTableTest_II and L3AclTableTest_III.
- PR977: SAITEST: Local routes that are needed in addition to a neighbour and next hop are added.
- PR978: SAITEST: Supported SAI_ACL_ENTRY_ATTR_FIELD_DST_IP in client.
- PR979: SAITEST: Bugfix: Added object declaration so that the lifetime of the objects will be extended to the cleanup stage. This is done to resolve the error message "ERROR: saiacl.L3AclTableGroupTestI" that appears in the final block if the traffic test is failed.
- PR981: SAITEST: Bugfix: rif_id1 is created using lag_id1, modified to remove rif_id1 before removing lag_id1.
- PR982: SAITEST: Default value of ACL entry fields is 'false'. Modified to enable ACL entry action and field when creating ACL entry in PTF client.
- PR1000: SAITEST: switch_sai_rpc_server.cpp: Fixed ACL mirror session attributes at client, change from acl_field_data to acl_action_data, changed from oid to objlist according to SAI header. Added support for SAI_PORT_ATTR_EGRESS_ACL,Fixed memory leak when parsing SAI_ACL_ENTRY_ATTR_FIELD_IN_PORTS and Added support for ACL OUT_PORTS, MIRROR_INGRESS and MIRROR_EGRESS