Commit 7cfa3802 authored by Atzm Watanabe's avatar Atzm Watanabe Committed by Stephen Hemminger

vxlan: Allow setting destination to unicast address.

This patch allows setting VXLAN destination to unicast address.
It allows that VXLAN can be used as peer-to-peer tunnel without
multicast.

v6: change back to the v3 except for using new attribute because
    replacing command-line parameters breaks existing scripts,
    based by Cong Wang's comments.

v5: rebase on the latest.

v4: replace "group" with "remote" based by David Stevens's comments.

v3: move a new attribute REMOTE into the last of an enum list
    based by Stephen Hemminger's comments.
    fix the usage to show explicitly that both "remote" and "group"
    cannot be specified, based by Ben Hutchings's comments.

v2: use a new argument "remote" instead of "group" based by
    Stephen Hemminger's comments.
Signed-off-by: default avatarAtzm Watanabe <atzm@stratosphere.co.jp>
parent cc71ad3d
...@@ -23,7 +23,7 @@ ...@@ -23,7 +23,7 @@
static void explain(void) static void explain(void)
{ {
fprintf(stderr, "Usage: ... vxlan id VNI [ group ADDR ] [ local ADDR ]\n"); fprintf(stderr, "Usage: ... vxlan id VNI [ { group | remote } ADDR ] [ local ADDR ]\n");
fprintf(stderr, " [ ttl TTL ] [ tos TOS ] [ dev PHYS_DEV ]\n"); fprintf(stderr, " [ ttl TTL ] [ tos TOS ] [ dev PHYS_DEV ]\n");
fprintf(stderr, " [ port MIN MAX ] [ [no]learning ]\n"); fprintf(stderr, " [ port MIN MAX ] [ [no]learning ]\n");
fprintf(stderr, " [ [no]proxy ] [ [no]rsc ]\n"); fprintf(stderr, " [ [no]proxy ] [ [no]rsc ]\n");
...@@ -42,6 +42,7 @@ static int vxlan_parse_opt(struct link_util *lu, int argc, char **argv, ...@@ -42,6 +42,7 @@ static int vxlan_parse_opt(struct link_util *lu, int argc, char **argv,
int vni_set = 0; int vni_set = 0;
__u32 saddr = 0; __u32 saddr = 0;
__u32 gaddr = 0; __u32 gaddr = 0;
__u32 daddr = 0;
unsigned link = 0; unsigned link = 0;
__u8 tos = 0; __u8 tos = 0;
__u8 ttl = 0; __u8 ttl = 0;
...@@ -68,7 +69,13 @@ static int vxlan_parse_opt(struct link_util *lu, int argc, char **argv, ...@@ -68,7 +69,13 @@ static int vxlan_parse_opt(struct link_util *lu, int argc, char **argv,
gaddr = get_addr32(*argv); gaddr = get_addr32(*argv);
if (!IN_MULTICAST(ntohl(gaddr))) if (!IN_MULTICAST(ntohl(gaddr)))
invarg("invald group address", *argv); invarg("invalid group address", *argv);
} else if (!matches(*argv, "remote")) {
NEXT_ARG();
daddr = get_addr32(*argv);
if (IN_MULTICAST(ntohl(daddr)))
invarg("invalid remote address", *argv);
} else if (!matches(*argv, "local")) { } else if (!matches(*argv, "local")) {
NEXT_ARG(); NEXT_ARG();
if (strcmp(*argv, "any")) if (strcmp(*argv, "any"))
...@@ -160,9 +167,15 @@ static int vxlan_parse_opt(struct link_util *lu, int argc, char **argv, ...@@ -160,9 +167,15 @@ static int vxlan_parse_opt(struct link_util *lu, int argc, char **argv,
fprintf(stderr, "vxlan: missing virtual network identifier\n"); fprintf(stderr, "vxlan: missing virtual network identifier\n");
return -1; return -1;
} }
if (gaddr && daddr) {
fprintf(stderr, "vxlan: both group and remote cannot be specified\n");
return -1;
}
addattr32(n, 1024, IFLA_VXLAN_ID, vni); addattr32(n, 1024, IFLA_VXLAN_ID, vni);
if (gaddr) if (gaddr)
addattr_l(n, 1024, IFLA_VXLAN_GROUP, &gaddr, 4); addattr_l(n, 1024, IFLA_VXLAN_GROUP, &gaddr, 4);
else if (daddr)
addattr_l(n, 1024, IFLA_VXLAN_GROUP, &daddr, 4);
if (saddr) if (saddr)
addattr_l(n, 1024, IFLA_VXLAN_LOCAL, &saddr, 4); addattr_l(n, 1024, IFLA_VXLAN_LOCAL, &saddr, 4);
if (link) if (link)
...@@ -208,9 +221,14 @@ static void vxlan_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[]) ...@@ -208,9 +221,14 @@ static void vxlan_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
if (tb[IFLA_VXLAN_GROUP]) { if (tb[IFLA_VXLAN_GROUP]) {
__be32 addr = rta_getattr_u32(tb[IFLA_VXLAN_GROUP]); __be32 addr = rta_getattr_u32(tb[IFLA_VXLAN_GROUP]);
if (addr) if (addr) {
if (IN_MULTICAST(ntohl(addr)))
fprintf(f, "group %s ", fprintf(f, "group %s ",
format_host(AF_INET, 4, &addr, s1, sizeof(s1))); format_host(AF_INET, 4, &addr, s1, sizeof(s1)));
else
fprintf(f, "remote %s ",
format_host(AF_INET, 4, &addr, s1, sizeof(s1)));
}
} }
if (tb[IFLA_VXLAN_LOCAL]) { if (tb[IFLA_VXLAN_LOCAL]) {
......
...@@ -206,8 +206,8 @@ the following additional arguments are supported: ...@@ -206,8 +206,8 @@ the following additional arguments are supported:
.BI type " vxlan " id " ID .BI type " vxlan " id " ID
.R " [ " .R " [ "
.BI dev " PHYS_DEV " .BI dev " PHYS_DEV "
.R " ] [ " .RB " ] [ { " group " | " remote " } "
.BI group " IPADDR " .I IPADDR
.R " ] [ " .R " ] [ "
.BI local " IPADDR " .BI local " IPADDR "
.R " ] [ " .R " ] [ "
...@@ -240,6 +240,17 @@ Identifier) to use. ...@@ -240,6 +240,17 @@ Identifier) to use.
.sp .sp
.BI group " IPADDR" .BI group " IPADDR"
- specifies the multicast IP address to join. - specifies the multicast IP address to join.
This parameter cannot be specified with the
.B remote
parameter.
.sp
.BI remote " IPADDR"
- specifies the unicast destination IP address to use in outgoing packets
when the destination link layer address is not known in the VXLAN device
forwarding database. This parameter cannot be specified with the
.B group
parameter.
.sp .sp
.BI local " IPADDR" .BI local " IPADDR"
......
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