blob: d89598d25c21873e2ffd3e240890a2b47433ab0d [file] [log] [blame]
Ben Cheng655a7c02013-10-16 16:09:24 -07001/****************************************************************************
2 ****************************************************************************
3 ***
4 *** This header was automatically generated from a Linux kernel header
5 *** of the same name, to make information necessary for userspace to
6 *** call into the kernel available to libc. It contains only constants,
7 *** structures, and macros generated from the original header, and thus,
8 *** contains no copyrightable information.
9 ***
10 *** To edit the content of this header, modify the corresponding
11 *** source file (e.g. under external/kernel-headers/original/) then
12 *** run bionic/libc/kernel/tools/update_all.py
13 ***
14 *** Any manual change here will be lost the next time this script will
15 *** be run. You've been warned!
16 ***
17 ****************************************************************************
18 ****************************************************************************/
19#ifndef _IP_VS_H
20#define _IP_VS_H
21#include <linux/types.h>
22#define IP_VS_VERSION_CODE 0x010201
Tao Baod7db5942015-01-28 10:07:51 -080023#define NVERSION(version) (version >> 16) & 0xFF, (version >> 8) & 0xFF, version & 0xFF
Ben Cheng655a7c02013-10-16 16:09:24 -070024#define IP_VS_SVC_F_PERSISTENT 0x0001
25#define IP_VS_SVC_F_HASHED 0x0002
26#define IP_VS_SVC_F_ONEPACKET 0x0004
Christopher Ferris38062f92014-07-09 15:33:25 -070027#define IP_VS_SVC_F_SCHED1 0x0008
28#define IP_VS_SVC_F_SCHED2 0x0010
29#define IP_VS_SVC_F_SCHED3 0x0020
30#define IP_VS_SVC_F_SCHED_SH_FALLBACK IP_VS_SVC_F_SCHED1
Christopher Ferris38062f92014-07-09 15:33:25 -070031#define IP_VS_SVC_F_SCHED_SH_PORT IP_VS_SVC_F_SCHED2
Ben Cheng655a7c02013-10-16 16:09:24 -070032#define IP_VS_DEST_F_AVAILABLE 0x0001
33#define IP_VS_DEST_F_OVERLOAD 0x0002
34#define IP_VS_STATE_NONE 0x0000
Christopher Ferris38062f92014-07-09 15:33:25 -070035#define IP_VS_STATE_MASTER 0x0001
Ben Cheng655a7c02013-10-16 16:09:24 -070036#define IP_VS_STATE_BACKUP 0x0002
Tao Baod7db5942015-01-28 10:07:51 -080037#define IP_VS_BASE_CTL (64 + 1024 + 64)
Ben Cheng655a7c02013-10-16 16:09:24 -070038#define IP_VS_SO_SET_NONE IP_VS_BASE_CTL
Tao Baod7db5942015-01-28 10:07:51 -080039#define IP_VS_SO_SET_INSERT (IP_VS_BASE_CTL + 1)
40#define IP_VS_SO_SET_ADD (IP_VS_BASE_CTL + 2)
41#define IP_VS_SO_SET_EDIT (IP_VS_BASE_CTL + 3)
42#define IP_VS_SO_SET_DEL (IP_VS_BASE_CTL + 4)
Tao Baod7db5942015-01-28 10:07:51 -080043#define IP_VS_SO_SET_FLUSH (IP_VS_BASE_CTL + 5)
44#define IP_VS_SO_SET_LIST (IP_VS_BASE_CTL + 6)
45#define IP_VS_SO_SET_ADDDEST (IP_VS_BASE_CTL + 7)
46#define IP_VS_SO_SET_DELDEST (IP_VS_BASE_CTL + 8)
Tao Baod7db5942015-01-28 10:07:51 -080047#define IP_VS_SO_SET_EDITDEST (IP_VS_BASE_CTL + 9)
48#define IP_VS_SO_SET_TIMEOUT (IP_VS_BASE_CTL + 10)
49#define IP_VS_SO_SET_STARTDAEMON (IP_VS_BASE_CTL + 11)
50#define IP_VS_SO_SET_STOPDAEMON (IP_VS_BASE_CTL + 12)
Tao Baod7db5942015-01-28 10:07:51 -080051#define IP_VS_SO_SET_RESTORE (IP_VS_BASE_CTL + 13)
52#define IP_VS_SO_SET_SAVE (IP_VS_BASE_CTL + 14)
53#define IP_VS_SO_SET_ZERO (IP_VS_BASE_CTL + 15)
Ben Cheng655a7c02013-10-16 16:09:24 -070054#define IP_VS_SO_SET_MAX IP_VS_SO_SET_ZERO
Christopher Ferris38062f92014-07-09 15:33:25 -070055#define IP_VS_SO_GET_VERSION IP_VS_BASE_CTL
Tao Baod7db5942015-01-28 10:07:51 -080056#define IP_VS_SO_GET_INFO (IP_VS_BASE_CTL + 1)
57#define IP_VS_SO_GET_SERVICES (IP_VS_BASE_CTL + 2)
58#define IP_VS_SO_GET_SERVICE (IP_VS_BASE_CTL + 3)
Tao Baod7db5942015-01-28 10:07:51 -080059#define IP_VS_SO_GET_DESTS (IP_VS_BASE_CTL + 4)
60#define IP_VS_SO_GET_DEST (IP_VS_BASE_CTL + 5)
61#define IP_VS_SO_GET_TIMEOUT (IP_VS_BASE_CTL + 6)
62#define IP_VS_SO_GET_DAEMON (IP_VS_BASE_CTL + 7)
Christopher Ferris38062f92014-07-09 15:33:25 -070063#define IP_VS_SO_GET_MAX IP_VS_SO_GET_DAEMON
Ben Cheng655a7c02013-10-16 16:09:24 -070064#define IP_VS_CONN_F_FWD_MASK 0x0007
65#define IP_VS_CONN_F_MASQ 0x0000
66#define IP_VS_CONN_F_LOCALNODE 0x0001
Christopher Ferris38062f92014-07-09 15:33:25 -070067#define IP_VS_CONN_F_TUNNEL 0x0002
Ben Cheng655a7c02013-10-16 16:09:24 -070068#define IP_VS_CONN_F_DROUTE 0x0003
69#define IP_VS_CONN_F_BYPASS 0x0004
70#define IP_VS_CONN_F_SYNC 0x0020
Christopher Ferris38062f92014-07-09 15:33:25 -070071#define IP_VS_CONN_F_HASHED 0x0040
Ben Cheng655a7c02013-10-16 16:09:24 -070072#define IP_VS_CONN_F_NOOUTPUT 0x0080
73#define IP_VS_CONN_F_INACTIVE 0x0100
74#define IP_VS_CONN_F_OUT_SEQ 0x0200
Christopher Ferris38062f92014-07-09 15:33:25 -070075#define IP_VS_CONN_F_IN_SEQ 0x0400
Ben Cheng655a7c02013-10-16 16:09:24 -070076#define IP_VS_CONN_F_SEQ_MASK 0x0600
77#define IP_VS_CONN_F_NO_CPORT 0x0800
78#define IP_VS_CONN_F_TEMPLATE 0x1000
Christopher Ferris38062f92014-07-09 15:33:25 -070079#define IP_VS_CONN_F_ONE_PACKET 0x2000
Tao Baod7db5942015-01-28 10:07:51 -080080#define IP_VS_CONN_F_BACKUP_MASK (IP_VS_CONN_F_FWD_MASK | IP_VS_CONN_F_NOOUTPUT | IP_VS_CONN_F_INACTIVE | IP_VS_CONN_F_SEQ_MASK | IP_VS_CONN_F_NO_CPORT | IP_VS_CONN_F_TEMPLATE)
81#define IP_VS_CONN_F_BACKUP_UPD_MASK (IP_VS_CONN_F_INACTIVE | IP_VS_CONN_F_SEQ_MASK)
Ben Cheng655a7c02013-10-16 16:09:24 -070082#define IP_VS_CONN_F_NFCT (1 << 16)
Tao Baod7db5942015-01-28 10:07:51 -080083#define IP_VS_CONN_F_DEST_MASK (IP_VS_CONN_F_FWD_MASK | IP_VS_CONN_F_ONE_PACKET | IP_VS_CONN_F_NFCT | 0)
Ben Cheng655a7c02013-10-16 16:09:24 -070084#define IP_VS_SCHEDNAME_MAXLEN 16
85#define IP_VS_PENAME_MAXLEN 16
86#define IP_VS_IFNAME_MAXLEN 16
Christopher Ferris38062f92014-07-09 15:33:25 -070087#define IP_VS_PEDATA_MAXLEN 255
Ben Cheng655a7c02013-10-16 16:09:24 -070088struct ip_vs_service_user {
Tao Baod7db5942015-01-28 10:07:51 -080089 __u16 protocol;
90 __be32 addr;
Tao Baod7db5942015-01-28 10:07:51 -080091 __be16 port;
92 __u32 fwmark;
93 char sched_name[IP_VS_SCHEDNAME_MAXLEN];
94 unsigned int flags;
Tao Baod7db5942015-01-28 10:07:51 -080095 unsigned int timeout;
96 __be32 netmask;
Ben Cheng655a7c02013-10-16 16:09:24 -070097};
98struct ip_vs_dest_user {
Tao Baod7db5942015-01-28 10:07:51 -080099 __be32 addr;
100 __be16 port;
101 unsigned int conn_flags;
102 int weight;
Tao Baod7db5942015-01-28 10:07:51 -0800103 __u32 u_threshold;
104 __u32 l_threshold;
Ben Cheng655a7c02013-10-16 16:09:24 -0700105};
106struct ip_vs_stats_user {
Tao Baod7db5942015-01-28 10:07:51 -0800107 __u32 conns;
108 __u32 inpkts;
109 __u32 outpkts;
110 __u64 inbytes;
Tao Baod7db5942015-01-28 10:07:51 -0800111 __u64 outbytes;
112 __u32 cps;
113 __u32 inpps;
114 __u32 outpps;
Tao Baod7db5942015-01-28 10:07:51 -0800115 __u32 inbps;
116 __u32 outbps;
Ben Cheng655a7c02013-10-16 16:09:24 -0700117};
118struct ip_vs_getinfo {
Tao Baod7db5942015-01-28 10:07:51 -0800119 unsigned int version;
120 unsigned int size;
121 unsigned int num_services;
Ben Cheng655a7c02013-10-16 16:09:24 -0700122};
Christopher Ferris38062f92014-07-09 15:33:25 -0700123struct ip_vs_service_entry {
Tao Baod7db5942015-01-28 10:07:51 -0800124 __u16 protocol;
125 __be32 addr;
126 __be16 port;
Tao Baod7db5942015-01-28 10:07:51 -0800127 __u32 fwmark;
128 char sched_name[IP_VS_SCHEDNAME_MAXLEN];
129 unsigned int flags;
130 unsigned int timeout;
Tao Baod7db5942015-01-28 10:07:51 -0800131 __be32 netmask;
132 unsigned int num_dests;
133 struct ip_vs_stats_user stats;
Ben Cheng655a7c02013-10-16 16:09:24 -0700134};
Christopher Ferris38062f92014-07-09 15:33:25 -0700135struct ip_vs_dest_entry {
Tao Baod7db5942015-01-28 10:07:51 -0800136 __be32 addr;
137 __be16 port;
138 unsigned int conn_flags;
Tao Baod7db5942015-01-28 10:07:51 -0800139 int weight;
140 __u32 u_threshold;
141 __u32 l_threshold;
142 __u32 activeconns;
Tao Baod7db5942015-01-28 10:07:51 -0800143 __u32 inactconns;
144 __u32 persistconns;
145 struct ip_vs_stats_user stats;
Ben Cheng655a7c02013-10-16 16:09:24 -0700146};
Christopher Ferris38062f92014-07-09 15:33:25 -0700147struct ip_vs_get_dests {
Tao Baod7db5942015-01-28 10:07:51 -0800148 __u16 protocol;
149 __be32 addr;
150 __be16 port;
Tao Baod7db5942015-01-28 10:07:51 -0800151 __u32 fwmark;
152 unsigned int num_dests;
153 struct ip_vs_dest_entry entrytable[0];
Ben Cheng655a7c02013-10-16 16:09:24 -0700154};
Christopher Ferris38062f92014-07-09 15:33:25 -0700155struct ip_vs_get_services {
Tao Baod7db5942015-01-28 10:07:51 -0800156 unsigned int num_services;
157 struct ip_vs_service_entry entrytable[0];
Ben Cheng655a7c02013-10-16 16:09:24 -0700158};
Christopher Ferris38062f92014-07-09 15:33:25 -0700159struct ip_vs_timeout_user {
Tao Baod7db5942015-01-28 10:07:51 -0800160 int tcp_timeout;
161 int tcp_fin_timeout;
162 int udp_timeout;
Christopher Ferris38062f92014-07-09 15:33:25 -0700163};
Ben Cheng655a7c02013-10-16 16:09:24 -0700164struct ip_vs_daemon_user {
Tao Baod7db5942015-01-28 10:07:51 -0800165 int state;
166 char mcast_ifn[IP_VS_IFNAME_MAXLEN];
Tao Baod7db5942015-01-28 10:07:51 -0800167 int syncid;
Ben Cheng655a7c02013-10-16 16:09:24 -0700168};
169#define IPVS_GENL_NAME "IPVS"
170#define IPVS_GENL_VERSION 0x1
Christopher Ferris38062f92014-07-09 15:33:25 -0700171struct ip_vs_flags {
Tao Baod7db5942015-01-28 10:07:51 -0800172 __u32 flags;
173 __u32 mask;
Ben Cheng655a7c02013-10-16 16:09:24 -0700174};
Christopher Ferris38062f92014-07-09 15:33:25 -0700175enum {
Tao Baod7db5942015-01-28 10:07:51 -0800176 IPVS_CMD_UNSPEC = 0,
177 IPVS_CMD_NEW_SERVICE,
178 IPVS_CMD_SET_SERVICE,
Tao Baod7db5942015-01-28 10:07:51 -0800179 IPVS_CMD_DEL_SERVICE,
180 IPVS_CMD_GET_SERVICE,
181 IPVS_CMD_NEW_DEST,
182 IPVS_CMD_SET_DEST,
Tao Baod7db5942015-01-28 10:07:51 -0800183 IPVS_CMD_DEL_DEST,
184 IPVS_CMD_GET_DEST,
185 IPVS_CMD_NEW_DAEMON,
186 IPVS_CMD_DEL_DAEMON,
Tao Baod7db5942015-01-28 10:07:51 -0800187 IPVS_CMD_GET_DAEMON,
188 IPVS_CMD_SET_CONFIG,
189 IPVS_CMD_GET_CONFIG,
190 IPVS_CMD_SET_INFO,
Tao Baod7db5942015-01-28 10:07:51 -0800191 IPVS_CMD_GET_INFO,
192 IPVS_CMD_ZERO,
193 IPVS_CMD_FLUSH,
194 __IPVS_CMD_MAX,
Christopher Ferris38062f92014-07-09 15:33:25 -0700195};
Ben Cheng655a7c02013-10-16 16:09:24 -0700196#define IPVS_CMD_MAX (__IPVS_CMD_MAX - 1)
197enum {
Tao Baod7db5942015-01-28 10:07:51 -0800198 IPVS_CMD_ATTR_UNSPEC = 0,
Tao Baod7db5942015-01-28 10:07:51 -0800199 IPVS_CMD_ATTR_SERVICE,
200 IPVS_CMD_ATTR_DEST,
201 IPVS_CMD_ATTR_DAEMON,
202 IPVS_CMD_ATTR_TIMEOUT_TCP,
Tao Baod7db5942015-01-28 10:07:51 -0800203 IPVS_CMD_ATTR_TIMEOUT_TCP_FIN,
204 IPVS_CMD_ATTR_TIMEOUT_UDP,
205 __IPVS_CMD_ATTR_MAX,
Ben Cheng655a7c02013-10-16 16:09:24 -0700206};
Christopher Ferris38062f92014-07-09 15:33:25 -0700207#define IPVS_CMD_ATTR_MAX (__IPVS_CMD_ATTR_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700208enum {
Tao Baod7db5942015-01-28 10:07:51 -0800209 IPVS_SVC_ATTR_UNSPEC = 0,
210 IPVS_SVC_ATTR_AF,
Tao Baod7db5942015-01-28 10:07:51 -0800211 IPVS_SVC_ATTR_PROTOCOL,
212 IPVS_SVC_ATTR_ADDR,
213 IPVS_SVC_ATTR_PORT,
214 IPVS_SVC_ATTR_FWMARK,
Tao Baod7db5942015-01-28 10:07:51 -0800215 IPVS_SVC_ATTR_SCHED_NAME,
216 IPVS_SVC_ATTR_FLAGS,
217 IPVS_SVC_ATTR_TIMEOUT,
218 IPVS_SVC_ATTR_NETMASK,
Tao Baod7db5942015-01-28 10:07:51 -0800219 IPVS_SVC_ATTR_STATS,
220 IPVS_SVC_ATTR_PE_NAME,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800221 IPVS_SVC_ATTR_STATS64,
Tao Baod7db5942015-01-28 10:07:51 -0800222 __IPVS_SVC_ATTR_MAX,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800223};
Christopher Ferris38062f92014-07-09 15:33:25 -0700224#define IPVS_SVC_ATTR_MAX (__IPVS_SVC_ATTR_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700225enum {
Tao Baod7db5942015-01-28 10:07:51 -0800226 IPVS_DEST_ATTR_UNSPEC = 0,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800227 IPVS_DEST_ATTR_ADDR,
Tao Baod7db5942015-01-28 10:07:51 -0800228 IPVS_DEST_ATTR_PORT,
229 IPVS_DEST_ATTR_FWD_METHOD,
230 IPVS_DEST_ATTR_WEIGHT,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800231 IPVS_DEST_ATTR_U_THRESH,
Tao Baod7db5942015-01-28 10:07:51 -0800232 IPVS_DEST_ATTR_L_THRESH,
233 IPVS_DEST_ATTR_ACTIVE_CONNS,
234 IPVS_DEST_ATTR_INACT_CONNS,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800235 IPVS_DEST_ATTR_PERSIST_CONNS,
Tao Baod7db5942015-01-28 10:07:51 -0800236 IPVS_DEST_ATTR_STATS,
237 IPVS_DEST_ATTR_ADDR_FAMILY,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800238 IPVS_DEST_ATTR_STATS64,
Tao Baod7db5942015-01-28 10:07:51 -0800239 __IPVS_DEST_ATTR_MAX,
Ben Cheng655a7c02013-10-16 16:09:24 -0700240};
Christopher Ferris82d75042015-01-26 10:57:07 -0800241#define IPVS_DEST_ATTR_MAX (__IPVS_DEST_ATTR_MAX - 1)
Christopher Ferris38062f92014-07-09 15:33:25 -0700242enum {
Tao Baod7db5942015-01-28 10:07:51 -0800243 IPVS_DAEMON_ATTR_UNSPEC = 0,
244 IPVS_DAEMON_ATTR_STATE,
Tao Baod7db5942015-01-28 10:07:51 -0800245 IPVS_DAEMON_ATTR_MCAST_IFN,
246 IPVS_DAEMON_ATTR_SYNC_ID,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800247 IPVS_DAEMON_ATTR_SYNC_MAXLEN,
248 IPVS_DAEMON_ATTR_MCAST_GROUP,
249 IPVS_DAEMON_ATTR_MCAST_GROUP6,
250 IPVS_DAEMON_ATTR_MCAST_PORT,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800251 IPVS_DAEMON_ATTR_MCAST_TTL,
Tao Baod7db5942015-01-28 10:07:51 -0800252 __IPVS_DAEMON_ATTR_MAX,
Ben Cheng655a7c02013-10-16 16:09:24 -0700253};
Christopher Ferris82d75042015-01-26 10:57:07 -0800254#define IPVS_DAEMON_ATTR_MAX (__IPVS_DAEMON_ATTR_MAX - 1)
Christopher Ferris38062f92014-07-09 15:33:25 -0700255enum {
Tao Baod7db5942015-01-28 10:07:51 -0800256 IPVS_STATS_ATTR_UNSPEC = 0,
257 IPVS_STATS_ATTR_CONNS,
Tao Baod7db5942015-01-28 10:07:51 -0800258 IPVS_STATS_ATTR_INPKTS,
259 IPVS_STATS_ATTR_OUTPKTS,
260 IPVS_STATS_ATTR_INBYTES,
261 IPVS_STATS_ATTR_OUTBYTES,
Tao Baod7db5942015-01-28 10:07:51 -0800262 IPVS_STATS_ATTR_CPS,
263 IPVS_STATS_ATTR_INPPS,
264 IPVS_STATS_ATTR_OUTPPS,
265 IPVS_STATS_ATTR_INBPS,
Tao Baod7db5942015-01-28 10:07:51 -0800266 IPVS_STATS_ATTR_OUTBPS,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700267 IPVS_STATS_ATTR_PAD,
Tao Baod7db5942015-01-28 10:07:51 -0800268 __IPVS_STATS_ATTR_MAX,
Ben Cheng655a7c02013-10-16 16:09:24 -0700269};
270#define IPVS_STATS_ATTR_MAX (__IPVS_STATS_ATTR_MAX - 1)
Christopher Ferris106b3a82016-08-24 12:15:38 -0700271enum {
Tao Baod7db5942015-01-28 10:07:51 -0800272 IPVS_INFO_ATTR_UNSPEC = 0,
273 IPVS_INFO_ATTR_VERSION,
274 IPVS_INFO_ATTR_CONN_TAB_SIZE,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700275 __IPVS_INFO_ATTR_MAX,
Christopher Ferris38062f92014-07-09 15:33:25 -0700276};
Ben Cheng655a7c02013-10-16 16:09:24 -0700277#define IPVS_INFO_ATTR_MAX (__IPVS_INFO_ATTR_MAX - 1)
278#endif