blob: 8abcbca14b6a32002f3cbeb50d802844f570ebc7 [file] [log] [blame]
Matthias Schiffer09748a22016-05-09 18:41:08 +02001/* Copyright (C) 2016 B.A.T.M.A.N. contributors:
2 *
3 * Matthias Schiffer
4 *
5 * Permission to use, copy, modify, and/or distribute this software for any
6 * purpose with or without fee is hereby granted, provided that the above
7 * copyright notice and this permission notice appear in all copies.
8 *
9 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
16 */
17
18#ifndef _UAPI_LINUX_BATMAN_ADV_H_
19#define _UAPI_LINUX_BATMAN_ADV_H_
20
21#define BATADV_NL_NAME "batadv"
22
Antonio Quartulli33a3bb42016-05-05 13:09:43 +020023#define BATADV_NL_MCAST_GROUP_TPMETER "tpmeter"
24
Matthias Schiffer09748a22016-05-09 18:41:08 +020025/**
26 * enum batadv_nl_attrs - batman-adv netlink attributes
27 *
28 * @BATADV_ATTR_UNSPEC: unspecified attribute to catch errors
Matthias Schiffer5da0aef2016-05-09 18:41:09 +020029 * @BATADV_ATTR_VERSION: batman-adv version string
30 * @BATADV_ATTR_ALGO_NAME: name of routing algorithm
31 * @BATADV_ATTR_MESH_IFINDEX: index of the batman-adv interface
32 * @BATADV_ATTR_MESH_IFNAME: name of the batman-adv interface
33 * @BATADV_ATTR_MESH_ADDRESS: mac address of the batman-adv interface
34 * @BATADV_ATTR_HARD_IFINDEX: index of the non-batman-adv interface
35 * @BATADV_ATTR_HARD_IFNAME: name of the non-batman-adv interface
36 * @BATADV_ATTR_HARD_ADDRESS: mac address of the non-batman-adv interface
Antonio Quartulli33a3bb42016-05-05 13:09:43 +020037 * @BATADV_ATTR_ORIG_ADDRESS: originator mac address
38 * @BATADV_ATTR_TPMETER_RESULT: result of run (see batadv_tp_meter_status)
39 * @BATADV_ATTR_TPMETER_TEST_TIME: time (msec) the run took
40 * @BATADV_ATTR_TPMETER_BYTES: amount of acked bytes during run
41 * @BATADV_ATTR_TPMETER_COOKIE: session cookie to match tp_meter session
42 * @BATADV_ATTR_PAD: attribute used for padding for 64-bit alignment
Matthias Schifferb60620c2016-07-03 13:31:36 +020043 * @BATADV_ATTR_ACTIVE: Flag indicating if the hard interface is active
Matthias Schiffer09748a22016-05-09 18:41:08 +020044 * @__BATADV_ATTR_AFTER_LAST: internal use
45 * @NUM_BATADV_ATTR: total number of batadv_nl_attrs available
46 * @BATADV_ATTR_MAX: highest attribute number currently defined
47 */
48enum batadv_nl_attrs {
49 BATADV_ATTR_UNSPEC,
Matthias Schiffer5da0aef2016-05-09 18:41:09 +020050 BATADV_ATTR_VERSION,
51 BATADV_ATTR_ALGO_NAME,
52 BATADV_ATTR_MESH_IFINDEX,
53 BATADV_ATTR_MESH_IFNAME,
54 BATADV_ATTR_MESH_ADDRESS,
55 BATADV_ATTR_HARD_IFINDEX,
56 BATADV_ATTR_HARD_IFNAME,
57 BATADV_ATTR_HARD_ADDRESS,
Antonio Quartulli33a3bb42016-05-05 13:09:43 +020058 BATADV_ATTR_ORIG_ADDRESS,
59 BATADV_ATTR_TPMETER_RESULT,
60 BATADV_ATTR_TPMETER_TEST_TIME,
61 BATADV_ATTR_TPMETER_BYTES,
62 BATADV_ATTR_TPMETER_COOKIE,
63 BATADV_ATTR_PAD,
Matthias Schifferb60620c2016-07-03 13:31:36 +020064 BATADV_ATTR_ACTIVE,
Matthias Schiffer09748a22016-05-09 18:41:08 +020065 /* add attributes above here, update the policy in netlink.c */
66 __BATADV_ATTR_AFTER_LAST,
67 NUM_BATADV_ATTR = __BATADV_ATTR_AFTER_LAST,
68 BATADV_ATTR_MAX = __BATADV_ATTR_AFTER_LAST - 1
69};
70
71/**
72 * enum batadv_nl_commands - supported batman-adv netlink commands
73 *
74 * @BATADV_CMD_UNSPEC: unspecified command to catch errors
Matthias Schiffer5da0aef2016-05-09 18:41:09 +020075 * @BATADV_CMD_GET_MESH_INFO: Query basic information about batman-adv device
Antonio Quartulli33a3bb42016-05-05 13:09:43 +020076 * @BATADV_CMD_TP_METER: Start a tp meter session
77 * @BATADV_CMD_TP_METER_CANCEL: Cancel a tp meter session
Matthias Schiffer07a30612016-07-03 13:31:35 +020078 * @BATADV_CMD_GET_ROUTING_ALGOS: Query the list of routing algorithms.
Matthias Schifferb60620c2016-07-03 13:31:36 +020079 * @BATADV_CMD_GET_HARDIFS: Query list of hard interfaces
Matthias Schiffer09748a22016-05-09 18:41:08 +020080 * @__BATADV_CMD_AFTER_LAST: internal use
81 * @BATADV_CMD_MAX: highest used command number
82 */
83enum batadv_nl_commands {
84 BATADV_CMD_UNSPEC,
Matthias Schiffer5da0aef2016-05-09 18:41:09 +020085 BATADV_CMD_GET_MESH_INFO,
Antonio Quartulli33a3bb42016-05-05 13:09:43 +020086 BATADV_CMD_TP_METER,
87 BATADV_CMD_TP_METER_CANCEL,
Matthias Schiffer07a30612016-07-03 13:31:35 +020088 BATADV_CMD_GET_ROUTING_ALGOS,
Matthias Schifferb60620c2016-07-03 13:31:36 +020089 BATADV_CMD_GET_HARDIFS,
Matthias Schiffer09748a22016-05-09 18:41:08 +020090 /* add new commands above here */
91 __BATADV_CMD_AFTER_LAST,
92 BATADV_CMD_MAX = __BATADV_CMD_AFTER_LAST - 1
93};
94
Antonio Quartulli33a3bb42016-05-05 13:09:43 +020095/**
96 * enum batadv_tp_meter_reason - reason of a tp meter test run stop
97 * @BATADV_TP_REASON_COMPLETE: sender finished tp run
98 * @BATADV_TP_REASON_CANCEL: sender was stopped during run
99 * @BATADV_TP_REASON_DST_UNREACHABLE: receiver could not be reached or didn't
100 * answer
101 * @BATADV_TP_REASON_RESEND_LIMIT: (unused) sender retry reached limit
102 * @BATADV_TP_REASON_ALREADY_ONGOING: test to or from the same node already
103 * ongoing
104 * @BATADV_TP_REASON_MEMORY_ERROR: test was stopped due to low memory
105 * @BATADV_TP_REASON_CANT_SEND: failed to send via outgoing interface
106 * @BATADV_TP_REASON_TOO_MANY: too many ongoing sessions
107 */
108enum batadv_tp_meter_reason {
109 BATADV_TP_REASON_COMPLETE = 3,
110 BATADV_TP_REASON_CANCEL = 4,
111 /* error status >= 128 */
112 BATADV_TP_REASON_DST_UNREACHABLE = 128,
113 BATADV_TP_REASON_RESEND_LIMIT = 129,
114 BATADV_TP_REASON_ALREADY_ONGOING = 130,
115 BATADV_TP_REASON_MEMORY_ERROR = 131,
116 BATADV_TP_REASON_CANT_SEND = 132,
117 BATADV_TP_REASON_TOO_MANY = 133,
118};
119
Matthias Schiffer09748a22016-05-09 18:41:08 +0200120#endif /* _UAPI_LINUX_BATMAN_ADV_H_ */