summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/nexthop.c26
-rw-r--r--lib/nexthop.h2
2 files changed, 28 insertions, 0 deletions
diff --git a/lib/nexthop.c b/lib/nexthop.c
index 98b05295b9..332581fbd8 100644
--- a/lib/nexthop.c
+++ b/lib/nexthop.c
@@ -581,6 +581,32 @@ void nexthop_del_labels(struct nexthop *nexthop)
nexthop->nh_label_type = ZEBRA_LSP_NONE;
}
+void nexthop_change_labels(struct nexthop *nexthop, struct mpls_label_stack *new_stack)
+{
+ struct mpls_label_stack *nh_label_tmp;
+ uint32_t i;
+
+ /* Enforce limit on label stack size */
+ if (new_stack->num_labels > MPLS_MAX_LABELS)
+ new_stack->num_labels = MPLS_MAX_LABELS;
+
+ /* Resize the array to accommodate the new label stack */
+ if (new_stack->num_labels > nexthop->nh_label->num_labels) {
+ nh_label_tmp = XREALLOC(MTYPE_NH_LABEL, nexthop->nh_label,
+ sizeof(struct mpls_label_stack) +
+ new_stack->num_labels * sizeof(mpls_label_t));
+ if (nh_label_tmp) {
+ nexthop->nh_label = nh_label_tmp;
+ nexthop->nh_label->num_labels = new_stack->num_labels;
+ } else
+ new_stack->num_labels = nexthop->nh_label->num_labels;
+ }
+
+ /* Copy the label stack into the array */
+ for (i = 0; i < new_stack->num_labels; i++)
+ nexthop->nh_label->label[i] = new_stack->label[i];
+}
+
void nexthop_add_srv6_seg6local(struct nexthop *nexthop, uint32_t action,
const struct seg6local_context *ctx)
{
diff --git a/lib/nexthop.h b/lib/nexthop.h
index 02ea4d96f2..5dfb58d846 100644
--- a/lib/nexthop.h
+++ b/lib/nexthop.h
@@ -154,6 +154,8 @@ void nexthops_free(struct nexthop *nexthop);
void nexthop_add_labels(struct nexthop *nexthop, enum lsp_types_t ltype,
uint8_t num_labels, const mpls_label_t *labels);
void nexthop_del_labels(struct nexthop *);
+void nexthop_change_labels(struct nexthop *nexthop, struct mpls_label_stack *new_stack);
+
void nexthop_add_srv6_seg6local(struct nexthop *nexthop, uint32_t action,
const struct seg6local_context *ctx);
void nexthop_del_srv6_seg6local(struct nexthop *nexthop);