diff options
author | Yasunobu Chiba <yasu@dsl.gr.jp> | 2013-08-04 06:43:54 (GMT) |
---|---|---|
committer | Yasunobu Chiba <yasu@dsl.gr.jp> | 2013-08-04 06:43:54 (GMT) |
commit | 162c906bf2d323b69ab2044ea03545360e71da16 (patch) | |
tree | 7c9c3b91fb91f5ad76109a8fdbed3b2712063ae2 /tests | |
parent | b3fb89f445108677d405c62865b25aeea209d10a (diff) | |
download | libnl-162c906bf2d323b69ab2044ea03545360e71da16.zip libnl-162c906bf2d323b69ab2044ea03545360e71da16.tar.gz libnl-162c906bf2d323b69ab2044ea03545360e71da16.tar.bz2 |
Add VXLAN support.
Diffstat (limited to 'tests')
-rw-r--r-- | tests/test-create-vxlan.c | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/tests/test-create-vxlan.c b/tests/test-create-vxlan.c new file mode 100644 index 0000000..98a5103 --- /dev/null +++ b/tests/test-create-vxlan.c @@ -0,0 +1,47 @@ +#include <netlink/netlink.h> +#include <netlink/route/link.h> +#include <netlink/route/link/vxlan.h> + +int main(int argc, char *argv[]) +{ + struct rtnl_link *link; + struct nl_addr *addr; + struct nl_sock *sk; + int err; + + sk = nl_socket_alloc(); + if ((err = nl_connect(sk, NETLINK_ROUTE)) < 0) { + nl_perror(err, "Unable to connect socket"); + return err; + } + + link = rtnl_link_vxlan_alloc(); + + rtnl_link_set_name(link, "vxlan128"); + + if ((err = rtnl_link_vxlan_set_id(link, 128)) < 0) { + nl_perror(err, "Unable to set VXLAN network identifier"); + return err; + } + + if ((err = nl_addr_parse("239.0.0.1", AF_INET, &addr)) < 0) { + nl_perror(err, "Unable to parse IP address"); + return err; + } + + if ((err = rtnl_link_vxlan_set_group(link, addr)) < 0) { + nl_perror(err, "Unable to set multicast IP address"); + return err; + } + nl_addr_put(addr); + + if ((err = rtnl_link_add(sk, link, NLM_F_CREATE)) < 0) { + nl_perror(err, "Unable to add link"); + return err; + } + + rtnl_link_put(link); + nl_close(sk); + + return 0; +} |