iproute: Add support for MPLS LWT ttl attribute
Add support for setting and displaying the ttl attribute for MPLS IP lighweight tunnels. Signed-off-by: Robert Shearman <rshearma@brocade.com> Acked-by: David Ahern <dsa@cumulusnetworks.com>
This commit is contained in:
parent
c44d18ea96
commit
9688cf3b7a
|
|
@ -84,6 +84,9 @@ static void print_encap_mpls(FILE *fp, struct rtattr *encap)
|
||||||
if (tb[MPLS_IPTUNNEL_DST])
|
if (tb[MPLS_IPTUNNEL_DST])
|
||||||
fprintf(fp, " %s ",
|
fprintf(fp, " %s ",
|
||||||
format_host_rta(AF_MPLS, tb[MPLS_IPTUNNEL_DST]));
|
format_host_rta(AF_MPLS, tb[MPLS_IPTUNNEL_DST]));
|
||||||
|
if (tb[MPLS_IPTUNNEL_TTL])
|
||||||
|
fprintf(fp, "ttl %u ",
|
||||||
|
rta_getattr_u8(tb[MPLS_IPTUNNEL_TTL]));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void print_encap_ip(FILE *fp, struct rtattr *encap)
|
static void print_encap_ip(FILE *fp, struct rtattr *encap)
|
||||||
|
|
@ -247,6 +250,7 @@ static int parse_encap_mpls(struct rtattr *rta, size_t len,
|
||||||
inet_prefix addr;
|
inet_prefix addr;
|
||||||
int argc = *argcp;
|
int argc = *argcp;
|
||||||
char **argv = *argvp;
|
char **argv = *argvp;
|
||||||
|
int ttl_ok = 0;
|
||||||
|
|
||||||
if (get_addr(&addr, *argv, AF_MPLS)) {
|
if (get_addr(&addr, *argv, AF_MPLS)) {
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
|
|
@ -258,8 +262,31 @@ static int parse_encap_mpls(struct rtattr *rta, size_t len,
|
||||||
rta_addattr_l(rta, len, MPLS_IPTUNNEL_DST, &addr.data,
|
rta_addattr_l(rta, len, MPLS_IPTUNNEL_DST, &addr.data,
|
||||||
addr.bytelen);
|
addr.bytelen);
|
||||||
|
|
||||||
*argcp = argc;
|
argc--;
|
||||||
*argvp = argv;
|
argv++;
|
||||||
|
|
||||||
|
while (argc > 0) {
|
||||||
|
if (strcmp(*argv, "ttl") == 0) {
|
||||||
|
__u8 ttl;
|
||||||
|
|
||||||
|
NEXT_ARG();
|
||||||
|
if (ttl_ok++)
|
||||||
|
duparg2("ttl", *argv);
|
||||||
|
if (get_u8(&ttl, *argv, 0))
|
||||||
|
invarg("\"ttl\" value is invalid\n", *argv);
|
||||||
|
rta_addattr8(rta, len, MPLS_IPTUNNEL_TTL, ttl);
|
||||||
|
} else {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
argc--; argv++;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* argv is currently the first unparsed argument,
|
||||||
|
* but the lwt_parse_encap() caller will move to the next,
|
||||||
|
* so step back
|
||||||
|
*/
|
||||||
|
*argcp = argc + 1;
|
||||||
|
*argvp = argv - 1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -181,7 +181,9 @@ throw " | " unreachable " | " prohibit " | " blackhole " | " nat " ]"
|
||||||
.ti -8
|
.ti -8
|
||||||
.IR ENCAP_MPLS " := "
|
.IR ENCAP_MPLS " := "
|
||||||
.BR mpls " [ "
|
.BR mpls " [ "
|
||||||
.IR LABEL " ]"
|
.IR LABEL " ] ["
|
||||||
|
.B ttl
|
||||||
|
.IR TTL " ]"
|
||||||
|
|
||||||
.ti -8
|
.ti -8
|
||||||
.IR ENCAP_IP " := "
|
.IR ENCAP_IP " := "
|
||||||
|
|
@ -666,6 +668,11 @@ is a set of encapsulation attributes specific to the
|
||||||
.I MPLSLABEL
|
.I MPLSLABEL
|
||||||
- mpls label stack with labels separated by
|
- mpls label stack with labels separated by
|
||||||
.I "/"
|
.I "/"
|
||||||
|
.sp
|
||||||
|
|
||||||
|
.B ttl
|
||||||
|
.I TTL
|
||||||
|
- TTL to use for MPLS header or 0 to inherit from IP header
|
||||||
.in -2
|
.in -2
|
||||||
.sp
|
.sp
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue