blob: 6b4b7874e3eaa9e3aa0e9973d31087d4b6bab004 [file] [log] [blame]
lh9ed821d2023-04-07 01:36:19 -07001/*
2 * netlink/utils.h Utility Functions
3 *
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation version 2.1
7 * of the License.
8 *
9 * Copyright (c) 2003-2012 Thomas Graf <tgraf@suug.ch>
10 */
11
12#ifndef NETLINK_UTILS_H_
13#define NETLINK_UTILS_H_
14
15#include <netlink/netlink.h>
16#include <netlink/list.h>
17
18#ifdef __cplusplus
19extern "C" {
20#endif
21
22/**
23 * @name Probability Constants
24 * @{
25 */
26
27/**
28 * Lower probability limit
29 * @ingroup utils
30 */
31#define NL_PROB_MIN 0x0
32
33/**
34 * Upper probability limit nl_dump_type
35 * @ingroup utils
36 */
37#define NL_PROB_MAX 0xffffffff
38
39/** @} */
40
41enum {
42 NL_BYTE_RATE,
43 NL_BIT_RATE,
44};
45
46/* unit pretty-printing */
47extern double nl_cancel_down_bytes(unsigned long long, char **);
48extern double nl_cancel_down_bits(unsigned long long, char **);
49extern int nl_rate2str(unsigned long long, int, char *, size_t);
50extern double nl_cancel_down_us(uint32_t, char **);
51
52/* generic unit translations */
53extern long nl_size2int(const char *);
54extern char * nl_size2str(const size_t, char *, const size_t);
55extern long nl_prob2int(const char *);
56
57/* time translations */
58extern int nl_get_user_hz(void);
59extern int nl_get_psched_hz(void);
60extern uint32_t nl_us2ticks(uint32_t);
61extern uint32_t nl_ticks2us(uint32_t);
62extern int nl_str2msec(const char *, uint64_t *);
63extern char * nl_msec2str(uint64_t, char *, size_t);
64
65/* link layer protocol translations */
66extern char * nl_llproto2str(int, char *, size_t);
67extern int nl_str2llproto(const char *);
68
69/* ethernet protocol translations */
70extern char * nl_ether_proto2str(int, char *, size_t);
71extern int nl_str2ether_proto(const char *);
72
73/* IP protocol translations */
74extern char * nl_ip_proto2str(int, char *, size_t);
75extern int nl_str2ip_proto(const char *);
76
77/* Dumping helpers */
78extern void nl_new_line(struct nl_dump_params *);
79extern void nl_dump(struct nl_dump_params *, const char *, ...);
80extern void nl_dump_line(struct nl_dump_params *, const char *, ...);
81
82enum {
83 NL_CAPABILITY_NONE,
84
85 /**
86 * rtnl_route_build_msg() no longer guesses the route scope
87 * if explicitly set to RT_SCOPE_NOWHERE.
88 * @ingroup utils
89 */
90 NL_CAPABILITY_ROUTE_BUILD_MSG_SET_SCOPE = 1,
91#define NL_CAPABILITY_ROUTE_BUILD_MSG_SET_SCOPE NL_CAPABILITY_ROUTE_BUILD_MSG_SET_SCOPE
92
93 /**
94 * rtnl_link_veth_get_peer() now returns a reference that is owned by the
95 * caller and must be released by the caller with rtnl_link_put().
96 */
97 NL_CAPABILITY_ROUTE_LINK_VETH_GET_PEER_OWN_REFERENCE = 2,
98#define NL_CAPABILITY_ROUTE_LINK_VETH_GET_PEER_OWN_REFERENCE NL_CAPABILITY_ROUTE_LINK_VETH_GET_PEER_OWN_REFERENCE
99
100 /**
101 * rtnl_u32_add_action() and rtnl_basic_add_action() now grab a reference to act
102 * caller are free to release its own
103 */
104 NL_CAPABILITY_ROUTE_LINK_CLS_ADD_ACT_OWN_REFERENCE = 3,
105#define NL_CAPABILITY_ROUTE_LINK_CLS_ADD_ACT_OWN_REFERENCE NL_CAPABILITY_ROUTE_LINK_CLS_ADD_ACT_OWN_REFERENCE
106
107 /**
108 * Indicate that the local port is unspecified until the user accesses
109 * it (via nl_socket_get_local_port()) or until nl_connect(). More importantly,
110 * if the port is left unspecified, nl_connect() will retry generating another
111 * port when bind() fails with ADDRINUSE.
112 */
113 NL_CAPABILITY_NL_CONNECT_RETRY_GENERATE_PORT_ON_ADDRINUSE = 4,
114#define NL_CAPABILITY_NL_CONNECT_RETRY_GENERATE_PORT_ON_ADDRINUSE NL_CAPABILITY_NL_CONNECT_RETRY_GENERATE_PORT_ON_ADDRINUSE
115
116 __NL_CAPABILITY_MAX
117#define NL_CAPABILITY_MAX (__NL_CAPABILITY_MAX - 1)
118};
119int nl_has_capability (int capability);
120
121#ifdef __cplusplus
122}
123#endif
124
125#endif