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 /python | |
parent | b3fb89f445108677d405c62865b25aeea209d10a (diff) | |
download | libnl-162c906bf2d323b69ab2044ea03545360e71da16.zip libnl-162c906bf2d323b69ab2044ea03545360e71da16.tar.gz libnl-162c906bf2d323b69ab2044ea03545360e71da16.tar.bz2 |
Add VXLAN support.
Diffstat (limited to 'python')
-rw-r--r-- | python/netlink/route/capi.i | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/python/netlink/route/capi.i b/python/netlink/route/capi.i index 949a5ed..356df12 100644 --- a/python/netlink/route/capi.i +++ b/python/netlink/route/capi.i @@ -4,6 +4,7 @@ #include <netlink/route/link.h> #include <netlink/route/link/vlan.h> #include <netlink/route/link/macvlan.h> +#include <netlink/route/link/vxlan.h> #include <netlink/route/link/inet.h> #include <netlink/route/tc.h> @@ -185,6 +186,68 @@ extern int rtnl_link_macvlan_set_flags(struct rtnl_link *, uint16_t); extern int rtnl_link_macvlan_unset_flags(struct rtnl_link *, uint16_t); extern uint16_t rtnl_link_macvlan_get_flags(struct rtnl_link *); +/* <netlink/route/link/vxlan.h> */ + +#define VXLAN_ID_MAX 16777215 + +extern struct rtnl_link *rtnl_link_vxlan_alloc(void); + +extern int rtnl_link_is_vxlan(struct rtnl_link *); + +extern int rtnl_link_vxlan_set_id(struct rtnl_link *, uint32_t); +extern int rtnl_link_vxlan_get_id(struct rtnl_link *, uint32_t *); + +extern int rtnl_link_vxlan_set_group(struct rtnl_link *, struct nl_addr *); +extern int rtnl_link_vxlan_get_group(struct rtnl_link *, struct nl_addr **); + +extern int rtnl_link_vxlan_set_link(struct rtnl_link *, uint32_t); +extern int rtnl_link_vxlan_get_link(struct rtnl_link *, uint32_t *); + +extern int rtnl_link_vxlan_set_local(struct rtnl_link *, struct nl_addr *); +extern int rtnl_link_vxlan_get_local(struct rtnl_link *, struct nl_addr **); + +extern int rtnl_link_vxlan_set_ttl(struct rtnl_link *, uint8_t); +extern int rtnl_link_vxlan_get_ttl(struct rtnl_link *); + +extern int rtnl_link_vxlan_set_tos(struct rtnl_link *, uint8_t); +extern int rtnl_link_vxlan_get_tos(struct rtnl_link *); + +extern int rtnl_link_vxlan_set_learning(struct rtnl_link *, uint8_t); +extern int rtnl_link_vxlan_get_learning(struct rtnl_link *); +extern int rtnl_link_vxlan_enable_learning(struct rtnl_link *); +extern int rtnl_link_vxlan_disable_learning(struct rtnl_link *); + +extern int rtnl_link_vxlan_set_ageing(struct rtnl_link *, uint32_t); +extern int rtnl_link_vxlan_get_ageing(struct rtnl_link *, uint32_t *); + +extern int rtnl_link_vxlan_set_limit(struct rtnl_link *, uint32_t); +extern int rtnl_link_vxlan_get_limit(struct rtnl_link *, uint32_t *); + +extern int rtnl_link_vxlan_set_port_range(struct rtnl_link *, + struct ifla_vxlan_port_range *); +extern int rtnl_link_vxlan_get_port_range(struct rtnl_link *, + struct ifla_vxlan_port_range *); + +extern int rtnl_link_vxlan_set_proxy(struct rtnl_link *, uint8_t); +extern int rtnl_link_vxlan_get_proxy(struct rtnl_link *); +extern int rtnl_link_vxlan_enable_proxy(struct rtnl_link *); +extern int rtnl_link_vxlan_disable_proxy(struct rtnl_link *); + +extern int rtnl_link_vxlan_set_rsc(struct rtnl_link *, uint8_t); +extern int rtnl_link_vxlan_get_rsc(struct rtnl_link *); +extern int rtnl_link_vxlan_enable_rsc(struct rtnl_link *); +extern int rtnl_link_vxlan_disable_rsc(struct rtnl_link *); + +extern int rtnl_link_vxlan_set_l2miss(struct rtnl_link *, uint8_t); +extern int rtnl_link_vxlan_get_l2miss(struct rtnl_link *); +extern int rtnl_link_vxlan_enable_l2miss(struct rtnl_link *); +extern int rtnl_link_vxlan_disable_l2miss(struct rtnl_link *); + +extern int rtnl_link_vxlan_set_l3miss(struct rtnl_link *, uint8_t); +extern int rtnl_link_vxlan_get_l3miss(struct rtnl_link *); +extern int rtnl_link_vxlan_enable_l3miss(struct rtnl_link *); +extern int rtnl_link_vxlan_disable_l3miss(struct rtnl_link *); + /* <netlink/route/link/inet.h> */ %cstring_output_maxsize(char *buf, size_t len) extern const char *rtnl_link_inet_devconf2str(int, char *buf, size_t len); |