summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--isisd/isis_tlvs.c34
-rw-r--r--isisd/isis_tlvs.h3
2 files changed, 37 insertions, 0 deletions
diff --git a/isisd/isis_tlvs.c b/isisd/isis_tlvs.c
index 8d0047de76..da62725311 100644
--- a/isisd/isis_tlvs.c
+++ b/isisd/isis_tlvs.c
@@ -7732,6 +7732,40 @@ void isis_tlvs_set_purge_originator(struct isis_tlvs *tlvs,
}
}
+/* Add an SRv6 End SID to the SRv6 End SID Sub-TLV */
+void isis_subtlvs_add_srv6_end_sid(struct isis_subtlvs *subtlvs,
+ struct isis_srv6_sid *sid)
+{
+ struct isis_srv6_end_sid_subtlv *sid_subtlv;
+
+ if (!sid)
+ return;
+
+ /* The SRv6 End SID Sub-TLV advertises SRv6 SIDs with Endpoint behaviors
+ * that do not require a particular neighbor in order to be correctly
+ * applied (e.g. End, End.DT6, ...). Before proceeding, let's make sure
+ * we are encoding one of the supported behaviors. */
+ if (sid->behavior != SRV6_ENDPOINT_BEHAVIOR_END &&
+ sid->behavior != SRV6_ENDPOINT_BEHAVIOR_END_NEXT_CSID &&
+ sid->behavior != SRV6_ENDPOINT_BEHAVIOR_END_DT6 &&
+ sid->behavior != SRV6_ENDPOINT_BEHAVIOR_END_DT6_USID &&
+ sid->behavior != SRV6_ENDPOINT_BEHAVIOR_END_DT4 &&
+ sid->behavior != SRV6_ENDPOINT_BEHAVIOR_END_DT4_USID &&
+ sid->behavior != SRV6_ENDPOINT_BEHAVIOR_END_DT46 &&
+ sid->behavior != SRV6_ENDPOINT_BEHAVIOR_END_DT46_USID)
+ return;
+
+ /* Allocate memory for the Sub-TLV */
+ sid_subtlv = XCALLOC(MTYPE_ISIS_SUBTLV, sizeof(*sid_subtlv));
+
+ /* Fill in the SRv6 End SID Sub-TLV according to the SRv6 SID
+ * configuration */
+ isis_srv6_end_sid2subtlv(sid, sid_subtlv);
+
+ /* Append the SRv6 End SID Sub-TLV to the Sub-TLVs list */
+ append_item(&subtlvs->srv6_end_sids, (struct isis_item *)sid_subtlv);
+}
+
/* Add an SRv6 Locator to the SRv6 Locator TLV */
void isis_tlvs_add_srv6_locator(struct isis_tlvs *tlvs, uint16_t mtid,
struct isis_srv6_locator *loc)
diff --git a/isisd/isis_tlvs.h b/isisd/isis_tlvs.h
index 552ffc151b..a03f9285c1 100644
--- a/isisd/isis_tlvs.h
+++ b/isisd/isis_tlvs.h
@@ -22,6 +22,7 @@ DECLARE_MTYPE(ISIS_SUBTLV);
struct lspdb_head;
struct sr_prefix_cfg;
+struct isis_srv6_sid;
struct isis_srv6_locator;
struct isis_area_address {
@@ -834,6 +835,8 @@ void isis_tlvs_set_purge_originator(struct isis_tlvs *tlvs,
const uint8_t *generator,
const uint8_t *sender);
+void isis_subtlvs_add_srv6_end_sid(struct isis_subtlvs *subtlvs,
+ struct isis_srv6_sid *sid);
void isis_tlvs_add_srv6_locator(struct isis_tlvs *tlvs, uint16_t mtid,
struct isis_srv6_locator *loc);
#endif