The following messages are used in IPv4, IPv6 Route, MPLS and PathGroup operations.
Messages | |
message | SLRouteGlobalsGetMsg |
Route Globals Get Message. More... | |
message | SLRouteGlobalsGetMsgRsp |
Route Globals Get Message Response. More... | |
message | SLRouteGlobalStatsGetMsg |
Route Global Stats Get Message. More... | |
message | SLRouteGlobalStatsGetMsgRsp |
Route Global Stats Get Message Response. More... | |
message | SLVrfReg |
VRF Registration message. More... | |
message | SLVrfRegMsg |
VRF Registration messages. More... | |
message | SLVrfRegMsgRes |
VRF Registration message Result. More... | |
message | SLVrfRegMsgRsp |
VRF Registration message Response. More... | |
message | SLVrfRegGetMsg |
VRF Get Message. More... | |
message | SLVrfRegGetMsgRsp |
VRF Get Message Response. More... | |
message | SLVRFGetStatsMsgRes |
VRF Get Stats Message Response. More... | |
message | SLVRFGetStatsMsgRsp |
VRF Get Stats Message Response. More... | |
message | SLRouteGetNotifMsg |
Common Get Notifications message. More... | |
message | SLRouteNotifStatus |
Common Route Notification Status message. More... | |
message | SLRouteNotifMarker |
Common Marker Notification message. More... | |
message | SLVrfNotif |
Common Vrf Notification message. More... | |
message | SLRouteGetMatch |
Get objects whose attibutes match one of below entries. More... | |
message | SLRouteCommon |
Common IPv4/IPv6 route attributes. More... | |
message | SLVxLANPath |
Attributes for constructing VxLAN encapsulation for a IP packet. More... | |
message | SLRoutePath |
Route Path attributes. More... | |
Enumerations | |
enum | SLNotifType { SL_EVENT_TYPE_RESERVED = 0x0, SL_EVENT_TYPE_ERROR = 0x1, SL_EVENT_TYPE_STATUS = 0x2, SL_EVENT_TYPE_ROUTE = 0x3, SL_EVENT_TYPE_START_MARKER = 0x4, SL_EVENT_TYPE_END_MARKER = 0x5, SL_EVENT_TYPE_VRF = 0x6 } |
L3 Event Notification types. More... | |
enum | SLRouteFlags { SL_ROUTE_FLAG_RESERVED = 0x00, SL_ROUTE_FLAG_PREFER_OVER_LDP = 0x01, SL_ROUTE_FLAG_DISABLE_LABEL_MERGE = 0x2, SL_ROUTE_FLAG_VIABLE_PATHS_ONLY = 0x04, SL_ROUTE_FLAG_ACTIVE_ON_VIABLE_PATH = 0x08 } |
enum | SLPathFlags { SL_PATH_FLAG_RESERVED = 0x00, SL_PATH_FLAG_SINGLE_PATH_OPT = 0x01 } |
message SLRouteGlobalsGetMsg |
Route Globals Get Message.
message SLRouteGlobalsGetMsgRsp |
Route Globals Get Message Response.
Attributes | |
SLErrorStatus | ErrStatus = 1 |
Corresponding error code. | |
uint32 | MaxVrfregPerVrfregmsg = 2 |
Max VrfReg objects within a single VrfRegMsg message. | |
uint32 | MaxRoutePerRoutemsg = 3 |
Max Route objects within a single RouteMsg message. | |
message SLRouteGlobalStatsGetMsg |
Route Global Stats Get Message.
message SLRouteGlobalStatsGetMsgRsp |
Route Global Stats Get Message Response.
Attributes | |
SLErrorStatus | ErrStatus = 1 |
Corresponding error code. | |
uint32 | VrfCount = 2 |
Num VRFs registered through the service layer for the requested client. | |
uint32 | RouteCount = 3 |
Num Routes added through the service layer for the requested client. | |
message SLVrfReg |
VRF Registration message.
Attributes | |
string | VrfName = 1 |
VRF Name. | |
uint32 | AdminDistance = 2 |
Default Admin distance for routes programmed by this application Range [0-255] This default value is used if route objects' AdminDistance is 0. More... | |
uint32 | VrfPurgeIntervalSeconds = 3 |
In case the Service Layer -> RIB connection is lost, this specifies the timeout period after which RIB will automatically purge the installed routes, unless the service layer: More... | |
uint32 SLVrfReg::AdminDistance = 2 |
Default Admin distance for routes programmed by this application Range [0-255] This default value is used if route objects' AdminDistance is 0.
Refer to SLRouteCommon
uint32 SLVrfReg::VrfPurgeIntervalSeconds = 3 |
In case the Service Layer -> RIB connection is lost, this specifies the timeout period after which RIB will automatically purge the installed routes, unless the service layer:
AdminDistance and VrfPurgeIntervalSeconds values are ignored for SL_PATH_GROUP_TABLE type registration
message SLVrfRegMsg |
VRF Registration messages.
Attributes | |
SLRegOp | Oper = 1 |
Registration Operation. | |
repeated SLVrfReg | VrfRegMsgs = 2 |
List of VRF registrations. | |
message SLVrfRegMsgRes |
VRF Registration message Result.
Attributes | |
SLErrorStatus | ErrStatus = 1 |
Corresponding error code. | |
string | VrfName = 2 |
VRF Name. | |
message SLVrfRegMsgRsp |
VRF Registration message Response.
Attributes | |
SLErrorStatus | StatusSummary = 1 |
Summary result of the bulk operation (refer to enum SLErrorStatus) In general, the StatusSummary implies one of 3 things: More... | |
repeated SLVrfRegMsgRes | Results = 2 |
In case of errors, this field indicates which entry in the bulk was erroneous. More... | |
repeated SLVrfRegMsgRes SLVrfRegMsgRsp::Results = 2 |
In case of errors, this field indicates which entry in the bulk was erroneous.
SLErrorStatus SLVrfRegMsgRsp::StatusSummary = 1 |
Summary result of the bulk operation (refer to enum SLErrorStatus) In general, the StatusSummary implies one of 3 things:
message SLVrfRegGetMsg |
VRF Get Message.
Attributes | |
string | VrfName = 1 |
VRF name (key). More... | |
uint32 | EntriesCount = 2 |
Number of entries requested. | |
bool | GetNext = 3 |
if GetNext is FALSE: request up to 'EntriesCount' entries starting from the key If GetNext is TRUE, or if the key exact match is not found: request up to 'EntriesCount' entries starting from the key's next GetNext does not get the routes in the next client. More... | |
bool SLVrfRegGetMsg::GetNext = 3 |
if GetNext is FALSE: request up to 'EntriesCount' entries starting from the key If GetNext is TRUE, or if the key exact match is not found: request up to 'EntriesCount' entries starting from the key's next GetNext does not get the routes in the next client.
string SLVrfRegGetMsg::VrfName = 1 |
VRF name (key).
If the Key is not specified, then request up to the first 'EntriesCount' entries.
message SLVrfRegGetMsgRsp |
VRF Get Message Response.
Attributes | |
bool | Eof = 1 |
End Of File. More... | |
SLErrorStatus | ErrStatus = 2 |
Status of the Get operation. | |
repeated SLVrfReg | Entries = 3 |
Returned entries as requested in the Get operation. More... | |
repeated SLVrfReg SLVrfRegGetMsgRsp::Entries = 3 |
Returned entries as requested in the Get operation.
if ErrStatus is SL_SUCCESS, Entries contains the info requested
bool SLVrfRegGetMsgRsp::Eof = 1 |
End Of File.
When set to True, it indicates that the server has returned M, where M < N, of the original N requested Entries.
message SLVRFGetStatsMsgRes |
VRF Get Stats Message Response.
Attributes | |
string | VrfName = 1 |
VRF name as key. | |
uint32 | RouteCount = 2 |
Num VRF Routes added through the service layer. | |
message SLVRFGetStatsMsgRsp |
VRF Get Stats Message Response.
Attributes | |
bool | Eof = 1 |
End Of File. More... | |
SLErrorStatus | ErrStatus = 2 |
Status of the Get Stats operation. | |
repeated SLVRFGetStatsMsgRes | Entries = 3 |
Returned entries as requested in the Get Stats operation on per client basis if ErrStatus is SL_SUCCESS, Entries contains the info requested. | |
bool SLVRFGetStatsMsgRsp::Eof = 1 |
End Of File.
When set to True, it indicates that the server has returned M, where M < N, of the original N requested Entries.
message SLRouteGetNotifMsg |
Common Get Notifications message.
Attributes | |
SLNotifOp | Oper = 1 |
Oper = SL_NOTIFOP_ENABLE This is to enable route notifications in a VRF Oper = SL_NOTIFOP_DISABLE This is to disable route notifications in a VRF. | |
uint64 | Correlator = 2 |
Correlator. More... | |
string | VrfName = 3 |
Vrf that the client is interested in. | |
string | SrcProto = 4 |
Source Protocol. More... | |
string | SrcProtoTag = 5 |
Source Protocol Tag. More... | |
uint64 SLRouteGetNotifMsg::Correlator = 2 |
Correlator.
This is used to correlate SLRouteGetNotifMsg with SLRouteNotifStatus. The server reflects this field in the reply. A client can send a SLRouteGetNotifMsg with the Correlator only. Once accepted and reply is sent, VRF notifications are sent. This is useful if a client wants to receive VRF notifications (SLVrfNotif) only and is not interested in receiving route notifications (SLRoutev4NotifRoute/SLRoutev6NotifRoute) from any VRF.
string SLRouteGetNotifMsg::SrcProto = 4 |
Source Protocol.
Only routes with specified source protocol and protocol tag will be notified. Contact Cisco for supported protocol string names.
string SLRouteGetNotifMsg::SrcProtoTag = 5 |
Source Protocol Tag.
This can be empty if N/A. Contact Cisco for supported protocol tags.
message SLRouteNotifStatus |
Common Route Notification Status message.
Attributes | |
uint64 | Correlator = 1 |
Correlator in the request. | |
string | VrfName = 2 |
Vrf in the request. | |
SLErrorStatus | NotifStatus = 3 |
The NotifStatus implies one of 2 things: SL_SUCCESS: signifies that the notification request was successful SL_XXX: signifies an error in setting up a notification for the Vrf. More... | |
SLErrorStatus SLRouteNotifStatus::NotifStatus = 3 |
The NotifStatus implies one of 2 things: SL_SUCCESS: signifies that the notification request was successful SL_XXX: signifies an error in setting up a notification for the Vrf.
Implies that notifications for this VRF will not be sent.
message SLRouteNotifMarker |
Common Marker Notification message.
Attributes | |
string | VrfName = 1 |
Vrf that this notification message applies to. | |
message SLVrfNotif |
Common Vrf Notification message.
Attributes | |
string | VrfName = 1 |
Vrf that this notification message applies to. | |
SLObjectOp | Status = 2 |
Status of this Vrf: add/update/delete. | |
message SLRouteGetMatch |
Get objects whose attibutes match one of below entries.
Specify a regular expression for PathGroup name or a numerical value for Vxlan VNI.
Attributes | |
oneof { | |
string PathGroupRegex = 1 | |
SLAFGetMsgRsp.AFList.AFOp.AFObject.entry.PathGroupKey.PathGroupId.Name. | |
uint32 VxlanVniId = 2 | |
SLAFGetMsgRsp.AFList.AFOp.AFObject.PathList.VxLANPath.VNI. | |
}; | |
message SLRouteCommon |
Common IPv4/IPv6 route attributes.
Attributes | |
uint32 | AdminDistance = 1 |
Adminstrative distance of the route. More... | |
uint32 | LocalLabel = 2 |
Local label associated with this route. More... | |
uint32 | Tag = 3 |
Route Tag. More... | |
string | SrcProto = 4 |
Source Protocol. More... | |
string | SrcProtoTag = 5 |
Source Protocol Tag. More... | |
uint32 | Flags = 6 |
Route Flags. More... | |
uint32 SLRouteCommon::AdminDistance = 1 |
Adminstrative distance of the route.
[0-255]. RIB uses this field to break the tie when multiple sources install the same route. Lower distance is preferred over higher distance. The per route object admin distance overrides the default admin distance set at VRF registration. see SLVrfReg
uint32 SLRouteCommon::Flags = 6 |
Route Flags.
Flags to control programming of the route to Routing Information Base. Each flag is indicated as a bit field. See SLRouteFlags for flag enumerations. Supported values are:
SL_ROUTE_FLAG_PREFER_OVER_LDP - This route takes precedence over a route learnt by LDP.
SL_ROUTE_FLAG_DISABLE_LABEL_MERGE If this route is preferred over any other producer of the same prefix and the latter is programmed with a SR label as well, do not merge that label's programming this route.
SL_ROUTE_FLAG_VIABLE_PATHS_ONLY - This flag on the route is applicable only if the route contains the PathList.
SL_ROUTE_FLAG_ACTIVE_ON_VIABLE_PATH - This flag is supported only for routes that contain the PathList.
All others are reserved.
uint32 SLRouteCommon::LocalLabel = 2 |
Local label associated with this route.
This is an optional field that can be used to simulatenously setup an ILM entry (e.g. head end of an MPLS LSP) for the same route. This is especially useful when setting up an MPLS LSP (a /32-route towards the remote LSP peer e.g. 2.2.2.2/32) which is required for MPLS VPN labeled routes.
Note: MPLS VPN labeled routes can resolve only on:
string SLRouteCommon::SrcProto = 4 |
Source Protocol.
For redistributed messages via notification stream only, ignored otherwise. Contact Cisco for supported protocol string names.
string SLRouteCommon::SrcProtoTag = 5 |
Source Protocol Tag.
This can be empty if N/A. For redistributed messages via notification stream only, ignored otherwise. Contact Cisco for supported protocol tags.
uint32 SLRouteCommon::Tag = 3 |
Route Tag.
Routes are usually tagged to prevent loops during redistribution between protocols.
message SLVxLANPath |
Attributes for constructing VxLAN encapsulation for a IP packet.
Attributes | |
uint32 | VNI = 1 |
Virtual network identifier. Client must set a valid non-zero idenifier. | |
bytes | SourceMacAddress = 2 |
Source MAC address is optional. | |
bytes | DestMacAddress = 3 |
Destination MAC address is optional. | |
SLIpAddress | SrcIpAddress = 4 |
Tunnel Source or Local IP address is mandatory. | |
SLIpAddress | DestIpAddress = 5 |
Tunnel Destination or Remote IP address is mandatory. | |
message SLRoutePath |
Route Path attributes.
In the multi-path associated with a IP route, MPLS label or a Path Group, paths with identical keys are coalesced and cannot be used as a mechanism to achieve unequal cost multi-path distribution.
Path key includes NextHopAdress, NextHopInterface, LabelStack and VrfName.
FRR Note: Failover from primary to backup is based on the trigger used (e.g. link down, BFD, etc.). Revertion is mainly timeout based. The timeout value is platform specific and is not configurable.
Attributes | |
SLIpAddress | NexthopAddress = 1 |
One of IPv4 or IPv6 address. More... | |
SLInterface | NexthopInterface = 2 |
Outgoing interface name for the path. More... | |
uint32 | LoadMetric = 3 |
Load metric for this path. More... | |
string | VrfName = 4 |
Path VRF name. More... | |
uint32 | Metric = 5 |
Route Metric. More... | |
uint32 | PathId = 6 |
Path identifier. More... | |
repeated uint64 | ProtectedPathBitmap = 7 |
Path protection bitmap. More... | |
repeated uint32 | LabelStack = 8 |
MPLS label stack. More... | |
repeated SLIpAddress | RemoteAddress = 9 |
MPLS Remote router backup address. More... | |
SLEncapType | EncapType = 10 |
For VxLAN, Encapsulation type must be set to SL_ENCAP_VXLAN. | |
bytes | VtepRouterMacAddress = 11 |
VTEP (VxLAN tunnel end point) router MAC address. More... | |
SLVxLANPath | VxLANPath = 12 |
Create L3 VxLAN tunnel endpoint. More... | |
uint32 | Flags = 13 |
Path Flags. More... | |
uint32 SLRoutePath::Flags = 13 |
Path Flags.
Each flag is indicated as a bit field. Supported values are:
repeated uint32 SLRoutePath::LabelStack = 8 |
MPLS label stack.
Stack of labels that is pushed when the packet is switched out. Label size is LSB 20 bits. Forwarding will set EXP, TTL and BOS. For primary path, typically only 1 label is used. For backup paths, more than 1 label can be used. If more than one label is used, remote backup addresses must be specified.
The maximum number of labels pushed for primary and backup are platform dependent.
uint32 SLRoutePath::LoadMetric = 3 |
Load metric for this path.
Used for equal/unequal cost load balancing of traffic distribution. For equal cost load balancing, all paths associated with the route, MPLS label or PathGroup must have a value of 0. For unequal cost load balancing, all paths must have non-zero value otherwise system defaults to equal cost load balancing.
uint32 SLRoutePath::Metric = 5 |
Route Metric.
The metric is typically based on information like load, hop count, MTU, reliability of the path, etc.
SLIpAddress SLRoutePath::NexthopAddress = 1 |
One of IPv4 or IPv6 address.
For ENCAP_VXLAN, this field is not supported and will be ignored.
SLInterface SLRoutePath::NexthopInterface = 2 |
Outgoing interface name for the path.
For ENCAP_VXLAN, this field is not supported and will be ignored. The client should listen to interface state change API for create/delete and reprogram the route or PG.
uint32 SLRoutePath::PathId = 6 |
Path identifier.
Path-id is used to uniquely identify a path when it comes to protection (Fast Re-Route - FRR). It is not used otherwise.
In general, for FRR, There are 3 main path attributes:
NOTE1: a primary path (A) can be simultaneously protected (by B), and acting as a backup for another path (C). In this example, the primary path C is protected by A (which happens to be primary). So the primary path (A) is Primary, Protected, and Backup.
The following are various path types based on combinations of attributes:
NOTE2: Pure backup path-id uses a different range than primary path-ids. The valid range of primary path IDs, and pure backup path IDS are platform dependent and can be retrieved through the client init message.
repeated uint64 SLRoutePath::ProtectedPathBitmap = 7 |
Path protection bitmap.
The bitmap of paths this Backup path is protecting. Example: If this path is protecting paths with IDs 4, 5 and 6, then set bitmap to: 0x38 ==> 0011 1000 || |– path 4 ||– path 5 |– path 6 (1 << (pathId_1 - 1)) | (1 << (pathId_2 - 1)) | (1 << (pathId_3 - 1))
repeated SLIpAddress SLRoutePath::RemoteAddress = 9 |
MPLS Remote router backup address.
This field is used only for backup MPLS path with more than one label For N+1 backup labels, N remote backup addresses must be specified.
string SLRoutePath::VrfName = 4 |
Path VRF name.
This field is optional and if not specified, VRF of the AF object containing this path is assumed. The client can set a different VRF name for certain use cases such as VPN or VxLAN encapsulation.
bytes SLRoutePath::VtepRouterMacAddress = 11 |
VTEP (VxLAN tunnel end point) router MAC address.
A unique system MAC address that other VTEPs can use for inter-VNI routing. The router MAC address is used as the inner destination MAC address for routed VXLAN packet. If this attribute is set, route can be only be signalled via BGP for EVPN use and local tunnel endpoint is not created.
This field and VxLANPath are mutually exclusive. This field is deprecated and will eventually be removed.
SLVxLANPath SLRoutePath::VxLANPath = 12 |
Create L3 VxLAN tunnel endpoint.
Apply VxLAN encapsulation on the IP packet.
enum SLNotifType |
L3 Event Notification types.
enum SLPathFlags |
enum SLRouteFlags |