Commit 29bb2373 authored by Daniel Borkmann's avatar Daniel Borkmann Committed by Stephen Hemminger

geneve: add support to set flow label

Follow-up for kernel commit 8eb3b99554b8 ("geneve: support setting
IPv6 flow label") to allow setting the label for the device config.
Signed-off-by: default avatarDaniel Borkmann <daniel@iogearbox.net>
parent f8eb79a6
...@@ -18,7 +18,7 @@ ...@@ -18,7 +18,7 @@
static void print_explain(FILE *f) static void print_explain(FILE *f)
{ {
fprintf(f, "Usage: ... geneve id VNI remote ADDR\n"); fprintf(f, "Usage: ... geneve id VNI remote ADDR\n");
fprintf(f, " [ ttl TTL ] [ tos TOS ]\n"); fprintf(f, " [ ttl TTL ] [ tos TOS ] [ flowlabel LABEL ]\n");
fprintf(f, " [ dstport PORT ] [ [no]external ]\n"); fprintf(f, " [ dstport PORT ] [ [no]external ]\n");
fprintf(f, " [ [no]udpcsum ] [ [no]udp6zerocsumtx ] [ [no]udp6zerocsumrx ]\n"); fprintf(f, " [ [no]udpcsum ] [ [no]udp6zerocsumtx ] [ [no]udp6zerocsumrx ]\n");
fprintf(f, "\n"); fprintf(f, "\n");
...@@ -26,6 +26,7 @@ static void print_explain(FILE *f) ...@@ -26,6 +26,7 @@ static void print_explain(FILE *f)
fprintf(f, " ADDR := IP_ADDRESS\n"); fprintf(f, " ADDR := IP_ADDRESS\n");
fprintf(f, " TOS := { NUMBER | inherit }\n"); fprintf(f, " TOS := { NUMBER | inherit }\n");
fprintf(f, " TTL := { 1..255 | inherit }\n"); fprintf(f, " TTL := { 1..255 | inherit }\n");
fprintf(f, " LABEL := 0-1048575\n");
} }
static void explain(void) static void explain(void)
...@@ -40,6 +41,7 @@ static int geneve_parse_opt(struct link_util *lu, int argc, char **argv, ...@@ -40,6 +41,7 @@ static int geneve_parse_opt(struct link_util *lu, int argc, char **argv,
int vni_set = 0; int vni_set = 0;
__u32 daddr = 0; __u32 daddr = 0;
struct in6_addr daddr6 = IN6ADDR_ANY_INIT; struct in6_addr daddr6 = IN6ADDR_ANY_INIT;
__u32 label = 0;
__u8 ttl = 0; __u8 ttl = 0;
__u8 tos = 0; __u8 tos = 0;
__u16 dstport = 0; __u16 dstport = 0;
...@@ -90,6 +92,15 @@ static int geneve_parse_opt(struct link_util *lu, int argc, char **argv, ...@@ -90,6 +92,15 @@ static int geneve_parse_opt(struct link_util *lu, int argc, char **argv,
tos = uval; tos = uval;
} else } else
tos = 1; tos = 1;
} else if (!matches(*argv, "label") ||
!matches(*argv, "flowlabel")) {
__u32 uval;
NEXT_ARG();
if (get_u32(&uval, *argv, 0) ||
(uval & ~LABEL_MAX_MASK))
invarg("invalid flowlabel", *argv);
label = htonl(uval);
} else if (!matches(*argv, "dstport")) { } else if (!matches(*argv, "dstport")) {
NEXT_ARG(); NEXT_ARG();
if (get_u16(&dstport, *argv, 0)) if (get_u16(&dstport, *argv, 0))
...@@ -150,6 +161,7 @@ static int geneve_parse_opt(struct link_util *lu, int argc, char **argv, ...@@ -150,6 +161,7 @@ static int geneve_parse_opt(struct link_util *lu, int argc, char **argv,
addattr_l(n, 1024, IFLA_GENEVE_REMOTE, &daddr, 4); addattr_l(n, 1024, IFLA_GENEVE_REMOTE, &daddr, 4);
if (memcmp(&daddr6, &in6addr_any, sizeof(daddr6)) != 0) if (memcmp(&daddr6, &in6addr_any, sizeof(daddr6)) != 0)
addattr_l(n, 1024, IFLA_GENEVE_REMOTE6, &daddr6, sizeof(struct in6_addr)); addattr_l(n, 1024, IFLA_GENEVE_REMOTE6, &daddr6, sizeof(struct in6_addr));
addattr32(n, 1024, IFLA_GENEVE_LABEL, label);
addattr8(n, 1024, IFLA_GENEVE_TTL, ttl); addattr8(n, 1024, IFLA_GENEVE_TTL, ttl);
addattr8(n, 1024, IFLA_GENEVE_TOS, tos); addattr8(n, 1024, IFLA_GENEVE_TOS, tos);
if (dstport) if (dstport)
...@@ -213,6 +225,13 @@ static void geneve_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[]) ...@@ -213,6 +225,13 @@ static void geneve_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
fprintf(f, "tos %#x ", tos); fprintf(f, "tos %#x ", tos);
} }
if (tb[IFLA_GENEVE_LABEL]) {
__u32 label = rta_getattr_u32(tb[IFLA_GENEVE_LABEL]);
if (label)
fprintf(f, "flowlabel %#x ", ntohl(label));
}
if (tb[IFLA_GENEVE_PORT]) if (tb[IFLA_GENEVE_PORT])
fprintf(f, "dstport %u ", fprintf(f, "dstport %u ",
ntohs(rta_getattr_u16(tb[IFLA_GENEVE_PORT]))); ntohs(rta_getattr_u16(tb[IFLA_GENEVE_PORT])));
......
...@@ -752,6 +752,8 @@ the following additional arguments are supported: ...@@ -752,6 +752,8 @@ the following additional arguments are supported:
.BI ttl " TTL " .BI ttl " TTL "
] [ ] [
.BI tos " TOS " .BI tos " TOS "
] [
.BI flowlabel " FLOWLABEL "
] ]
.in +8 .in +8
...@@ -771,6 +773,10 @@ the following additional arguments are supported: ...@@ -771,6 +773,10 @@ the following additional arguments are supported:
.BI tos " TOS" .BI tos " TOS"
- specifies the TOS value to use in outgoing packets. - specifies the TOS value to use in outgoing packets.
.sp
.BI flowlabel " FLOWLABEL"
- specifies the flow label to use in outgoing packets.
.in -8 .in -8
.TP .TP
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment