summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorSusant Sahani <susant@redhat.com>2014-04-24 17:46:27 (GMT)
committerThomas Haller <thaller@redhat.com>2014-05-05 16:08:47 (GMT)
commit3a95fad5c92031201eeb83786057249f237c56ce (patch)
tree1a71f21174eef7de59245476fe597a12059c3515 /tests
parent0482cdcddbf3118dbc3be0144bca06817718db07 (diff)
downloadlibnl-3a95fad5c92031201eeb83786057249f237c56ce.zip
libnl-3a95fad5c92031201eeb83786057249f237c56ce.tar.gz
libnl-3a95fad5c92031201eeb83786057249f237c56ce.tar.bz2
introduce ipip tunnel support
This patch introduces ipip tunnel support. This works with kernel module ipip. Signed-off-by: Susant Sahani <susant@redhat.com> Acked-by: Thomas Graf <tgraf@suug.ch> [thaller@redhat.com: change WS to TAB, fix code doc] Signed-off-by: Thomas Haller <thaller@redhat.com>
Diffstat (limited to 'tests')
-rw-r--r--tests/.gitignore1
-rw-r--r--tests/Makefile.am1
-rw-r--r--tests/test-create-ipip.c56
3 files changed, 58 insertions, 0 deletions
diff --git a/tests/.gitignore b/tests/.gitignore
index 007d503..eaf1736 100644
--- a/tests/.gitignore
+++ b/tests/.gitignore
@@ -7,6 +7,7 @@
/test-complex-HTB-with-hash-filters
/test-create-bond
/test-create-bridge
+/test-create-ipip
/test-create-veth
/test-create-vlan
/test-create-vxlan
diff --git a/tests/Makefile.am b/tests/Makefile.am
index f5f2c26..ed7bd49 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -24,6 +24,7 @@ check_PROGRAMS = \
test-create-vxlan \
test-create-veth \
test-create-bridge \
+ test-create-ipip \
test-delete-link \
test-socket-creation \
test-complex-HTB-with-hash-filters \
diff --git a/tests/test-create-ipip.c b/tests/test-create-ipip.c
new file mode 100644
index 0000000..44b9b2c
--- /dev/null
+++ b/tests/test-create-ipip.c
@@ -0,0 +1,56 @@
+#include <netlink/route/link/ipip.h>
+#include <netlink-private/netlink.h>
+
+int main(int argc, char *argv[])
+{
+ struct nl_cache *link_cache;
+ struct rtnl_link *link;
+ struct in_addr addr;
+ struct nl_sock *sk;
+ int err, if_index;
+
+ sk = nl_socket_alloc();
+ if ((err = nl_connect(sk, NETLINK_ROUTE)) < 0) {
+ nl_perror(err, "Unable to connect socket");
+ return err;
+ }
+
+ err = rtnl_link_alloc_cache(sk, AF_UNSPEC, &link_cache);
+ if ( err < 0) {
+ nl_perror(err, "Unable to allocate cache");
+ return err;
+ }
+
+ if_index = rtnl_link_name2i(link_cache, "eno16777736");
+ if (!if_index) {
+ fprintf(stderr, "Unable to lookup eno16777736");
+ return -1;
+ }
+
+ link = rtnl_link_ipip_alloc();
+ if(!link) {
+ nl_perror(err, "Unable to allocate link");
+ return -1;
+ }
+
+ rtnl_link_set_name(link, "ipip-tun");
+ rtnl_link_ipip_set_link(link, if_index);
+
+ inet_pton(AF_INET, "192.168.254.12", &addr.s_addr);
+ rtnl_link_ipip_set_local(link, addr.s_addr);
+
+ inet_pton(AF_INET, "192.168.254.13", &addr.s_addr);
+ rtnl_link_ipip_set_remote(link, addr.s_addr);
+
+ rtnl_link_ipip_set_ttl(link, 64);
+ err = rtnl_link_add(sk, link, NLM_F_CREATE);
+ if (err < 0) {
+ nl_perror(err, "Unable to add link");
+ return err;
+ }
+
+ rtnl_link_put(link);
+ nl_close(sk);
+
+ return 0;
+}