123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236 |
- /*
- * netlink/utils.h Utility Functions
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation version 2.1
- * of the License.
- *
- * Copyright (c) 2003-2012 Thomas Graf <tgraf@suug.ch>
- */
- #ifndef NETLINK_UTILS_H_
- #define NETLINK_UTILS_H_
- #include <netlink/netlink.h>
- #include <netlink/list.h>
- #ifdef __cplusplus
- extern "C" {
- #endif
- /**
- * @name Probability Constants
- * @{
- */
- /**
- * Lower probability limit
- * @ingroup utils
- */
- #define NL_PROB_MIN 0x0
- /**
- * Upper probability limit nl_dump_type
- * @ingroup utils
- */
- #define NL_PROB_MAX 0xffffffff
- /** @} */
- enum {
- NL_BYTE_RATE,
- NL_BIT_RATE,
- };
- /* unit pretty-printing */
- extern double nl_cancel_down_bytes(unsigned long long, char **);
- extern double nl_cancel_down_bits(unsigned long long, char **);
- extern int nl_rate2str(unsigned long long, int, char *, size_t);
- extern double nl_cancel_down_us(uint32_t, char **);
- /* generic unit translations */
- extern long nl_size2int(const char *);
- extern char * nl_size2str(const size_t, char *, const size_t);
- extern long nl_prob2int(const char *);
- /* time translations */
- extern int nl_get_user_hz(void);
- extern int nl_get_psched_hz(void);
- extern uint32_t nl_us2ticks(uint32_t);
- extern uint32_t nl_ticks2us(uint32_t);
- extern int nl_str2msec(const char *, uint64_t *);
- extern char * nl_msec2str(uint64_t, char *, size_t);
- /* link layer protocol translations */
- extern char * nl_llproto2str(int, char *, size_t);
- extern int nl_str2llproto(const char *);
- /* ethernet protocol translations */
- extern char * nl_ether_proto2str(int, char *, size_t);
- extern int nl_str2ether_proto(const char *);
- /* IP protocol translations */
- extern char * nl_ip_proto2str(int, char *, size_t);
- extern int nl_str2ip_proto(const char *);
- /* Dumping helpers */
- extern void nl_new_line(struct nl_dump_params *);
- extern void nl_dump(struct nl_dump_params *, const char *, ...);
- extern void nl_dump_line(struct nl_dump_params *, const char *, ...);
- enum {
- NL_CAPABILITY_NONE,
- /**
- * rtnl_route_build_msg() no longer guesses the route scope
- * if explicitly set to RT_SCOPE_NOWHERE.
- * @ingroup utils
- */
- NL_CAPABILITY_ROUTE_BUILD_MSG_SET_SCOPE = 1,
- #define NL_CAPABILITY_ROUTE_BUILD_MSG_SET_SCOPE NL_CAPABILITY_ROUTE_BUILD_MSG_SET_SCOPE
- /**
- * rtnl_link_veth_get_peer() now returns a reference that is owned by the
- * caller and must be released by the caller with rtnl_link_put().
- */
- NL_CAPABILITY_ROUTE_LINK_VETH_GET_PEER_OWN_REFERENCE = 2,
- #define NL_CAPABILITY_ROUTE_LINK_VETH_GET_PEER_OWN_REFERENCE NL_CAPABILITY_ROUTE_LINK_VETH_GET_PEER_OWN_REFERENCE
- /**
- * rtnl_u32_add_action() and rtnl_basic_add_action() now grab a reference to act
- * caller are free to release its own
- */
- NL_CAPABILITY_ROUTE_LINK_CLS_ADD_ACT_OWN_REFERENCE = 3,
- #define NL_CAPABILITY_ROUTE_LINK_CLS_ADD_ACT_OWN_REFERENCE NL_CAPABILITY_ROUTE_LINK_CLS_ADD_ACT_OWN_REFERENCE
- /**
- * Indicate that the local port is unspecified until the user accesses
- * it (via nl_socket_get_local_port()) or until nl_connect(). More importantly,
- * if the port is left unspecified, nl_connect() will retry generating another
- * port when bind() fails with ADDRINUSE.
- */
- NL_CAPABILITY_NL_CONNECT_RETRY_GENERATE_PORT_ON_ADDRINUSE = 4,
- #define NL_CAPABILITY_NL_CONNECT_RETRY_GENERATE_PORT_ON_ADDRINUSE NL_CAPABILITY_NL_CONNECT_RETRY_GENERATE_PORT_ON_ADDRINUSE
- /**
- * Indicate that rtnl_link_get_kernel() fails with -NLE_OPNOTSUPP in case
- * of older kernals not supporting lookup by ifname. This changes behavior
- * from returning -NLE_INVAL to return -NLE_OPNOTSUPP.
- */
- NL_CAPABILITY_ROUTE_LINK_GET_KERNEL_FAIL_OPNOTSUPP = 5,
- #define NL_CAPABILITY_ROUTE_LINK_GET_KERNEL_FAIL_OPNOTSUPP NL_CAPABILITY_ROUTE_LINK_GET_KERNEL_FAIL_OPNOTSUPP
- /**
- * Also consider the a_cacheinfo field (ADDR_ATTR_CACHEINFO) that contains the
- * address timestamps and expiry when comparing struct rtnl_addr objects with
- * nl_object_diff().
- */
- NL_CAPABILITY_ROUTE_ADDR_COMPARE_CACHEINFO = 6,
- #define NL_CAPABILITY_ROUTE_ADDR_COMPARE_CACHEINFO NL_CAPABILITY_ROUTE_ADDR_COMPARE_CACHEINFO
- /**
- * The library version is libnl3 3.2.26 or newer. This capability should never be backported.
- */
- NL_CAPABILITY_VERSION_3_2_26 = 7,
- #define NL_CAPABILITY_VERSION_3_2_26 NL_CAPABILITY_VERSION_3_2_26
- /**
- * nl_recv() fails with NLE_MSG_TRUNC if a message got truncated
- * with NL_MSG_PEEK disabled. Previously, the failed message was wrongly
- * discarded and the next message received.
- */
- NL_CAPABILITY_NL_RECV_FAIL_TRUNC_NO_PEEK = 8,
- #define NL_CAPABILITY_NL_RECV_FAIL_TRUNC_NO_PEEK NL_CAPABILITY_NL_RECV_FAIL_TRUNC_NO_PEEK
- /**
- * rtnl_link_build_change_request() and rtnl_link_change() would set ifi.ifi_flags but leave
- * ifi.ifi_change at zero. This was later fixed to set ifi.ifi_change to the flags that are actually
- * set in changes.
- */
- NL_CAPABILITY_LINK_BUILD_CHANGE_REQUEST_SET_CHANGE = 9,
- #define NL_CAPABILITY_LINK_BUILD_CHANGE_REQUEST_SET_CHANGE NL_CAPABILITY_LINK_BUILD_CHANGE_REQUEST_SET_CHANGE
- /**
- * Between 3.2.14 (64fcb47a36ec12d7e7f00605f6a8952ce985dd08) and 3.2.22 (8571f58f23763d8db7365d02c9b27832ad3d7005),
- * rtnl_neigh_get() behaved differently and only returned objects with family AF_UNSPEC.
- * This capability indicates, that the function was fixed. The absense of the capability,
- * doesn't indicate however which behavior the function will have. So beware. */
- NL_CAPABILITY_RTNL_NEIGH_GET_FILTER_AF_UNSPEC_FIX = 10,
- #define NL_CAPABILITY_RTNL_NEIGH_GET_FILTER_AF_UNSPEC_FIX NL_CAPABILITY_RTNL_NEIGH_GET_FILTER_AF_UNSPEC_FIX
- /**
- * The library version is libnl3 3.2.27 or newer. This capability should never be backported.
- */
- NL_CAPABILITY_VERSION_3_2_27 = 11,
- #define NL_CAPABILITY_VERSION_3_2_27 NL_CAPABILITY_VERSION_3_2_27
- /**
- * Properly serialize vlan protocol IFLA_VLAN_PROTOCOL.
- */
- NL_CAPABILITY_RTNL_LINK_VLAN_PROTOCOL_SERIALZE = 12,
- #define NL_CAPABILITY_RTNL_LINK_VLAN_PROTOCOL_SERIALZE NL_CAPABILITY_RTNL_LINK_VLAN_PROTOCOL_SERIALZE
- /**
- * Properly read gre REMOTE port.
- */
- NL_CAPABILITY_RTNL_LINK_PARSE_GRE_REMOTE = 13,
- #define NL_CAPABILITY_RTNL_LINK_PARSE_GRE_REMOTE NL_CAPABILITY_RTNL_LINK_PARSE_GRE_REMOTE
- /**
- * Don't skip over vlan ingress-map entries with "to" field zero when serializing
- * a netlink message. Previously such entires would be ignored which inhibits the
- * user from clearing ingress map entries.
- */
- NL_CAPABILITY_RTNL_LINK_VLAN_INGRESS_MAP_CLEAR = 14,
- #define NL_CAPABILITY_RTNL_LINK_VLAN_INGRESS_MAP_CLEAR NL_CAPABILITY_RTNL_LINK_VLAN_INGRESS_MAP_CLEAR
- /**
- * Consider vxlan link info for nl_object_diff().
- */
- NL_CAPABILITY_RTNL_LINK_VXLAN_IO_COMPARE = 15,
- #define NL_CAPABILITY_RTNL_LINK_VXLAN_IO_COMPARE NL_CAPABILITY_RTNL_LINK_VXLAN_IO_COMPARE
- /**
- * Support 64 bit attributes for nl_object_diff().
- */
- NL_CAPABILITY_NL_OBJECT_DIFF64 = 16,
- #define NL_CAPABILITY_NL_OBJECT_DIFF64 NL_CAPABILITY_NL_OBJECT_DIFF64
- /**
- * Support omitting @key argument to xfrmnl_sa_get_*_params() to check
- * for required buffer size for key.
- */
- NL_CAPABILITY_XFRM_SA_KEY_SIZE = 17,
- #define NL_CAPABILITY_XFRM_SA_KEY_SIZE NL_CAPABILITY_XFRM_SA_KEY_SIZE
- /**
- * Properly handle nl_object_identity() for AF_INET and AF_INET6 addresses
- * and properly handle the peer/IFA_ADDRESS for IPv4 addresses.
- */
- NL_CAPABILITY_RTNL_ADDR_PEER_FIX = 18,
- #define NL_CAPABILITY_RTNL_ADDR_PEER_FIX NL_CAPABILITY_RTNL_ADDR_PEER_FIX
- /**
- * The library version is libnl3 3.2.28 or newer. This capability should never be backported.
- */
- NL_CAPABILITY_VERSION_3_2_28 = 19,
- #define NL_CAPABILITY_VERSION_3_2_28 NL_CAPABILITY_VERSION_3_2_28
- __NL_CAPABILITY_MAX,
- NL_CAPABILITY_MAX = (__NL_CAPABILITY_MAX - 1),
- #define NL_CAPABILITY_MAX NL_CAPABILITY_MAX
- /**
- * The range 0x7000 to 0x7FFF is reserved for private capabilities. Upstream libnl3 will
- * not register capabilities in this range. However, instead of adding private capabilities,
- * better register their number with upstream libnl3. */
- #define NL_CAPABILITY_IS_USER_RESERVED(cap) ( ((cap) & ~0x0FFF) == 0x7000 )
- };
- int nl_has_capability (int capability);
- #ifdef __cplusplus
- }
- #endif
- #endif
|