]> git.ipfire.org Git - thirdparty/iw.git/blob - iw.h
iw: nan: Handle NAN Events
[thirdparty/iw.git] / iw.h
1 #ifndef __IW_H
2 #define __IW_H
3
4 #include <stdbool.h>
5 #include <netlink/netlink.h>
6 #include <netlink/genl/genl.h>
7 #include <netlink/genl/family.h>
8 #include <netlink/genl/ctrl.h>
9 #include <endian.h>
10
11 #include "nl80211.h"
12 #include "ieee80211.h"
13
14 /* support for extack if compilation headers are too old */
15 #ifndef NETLINK_EXT_ACK
16 #define NETLINK_EXT_ACK 11
17 enum nlmsgerr_attrs {
18 NLMSGERR_ATTR_UNUSED,
19 NLMSGERR_ATTR_MSG,
20 NLMSGERR_ATTR_OFFS,
21 NLMSGERR_ATTR_COOKIE,
22
23 __NLMSGERR_ATTR_MAX,
24 NLMSGERR_ATTR_MAX = __NLMSGERR_ATTR_MAX - 1
25 };
26 #endif
27 #ifndef NLM_F_CAPPED
28 #define NLM_F_CAPPED 0x100
29 #endif
30 #ifndef NLM_F_ACK_TLVS
31 #define NLM_F_ACK_TLVS 0x200
32 #endif
33 #ifndef SOL_NETLINK
34 #define SOL_NETLINK 270
35 #endif
36
37 #define ETH_ALEN 6
38 #define VHT_MUMIMO_GROUP_LEN 24
39
40 /* libnl 1.x compatibility code */
41 #if !defined(CONFIG_LIBNL20) && !defined(CONFIG_LIBNL30)
42 # define nl_sock nl_handle
43 #endif
44
45 struct nl80211_state {
46 struct nl_sock *nl_sock;
47 int nl80211_id;
48 };
49
50 enum command_identify_by {
51 CIB_NONE,
52 CIB_PHY,
53 CIB_NETDEV,
54 CIB_WDEV,
55 };
56
57 enum id_input {
58 II_NONE,
59 II_NETDEV,
60 II_PHY_NAME,
61 II_PHY_IDX,
62 II_WDEV,
63 };
64
65 #define HANDLER_RET_USAGE 1
66 #define HANDLER_RET_DONE 3
67
68 struct cmd {
69 const char *name;
70 const char *args;
71 const char *help;
72 const enum nl80211_commands cmd;
73 int nl_msg_flags;
74 int hidden;
75 const enum command_identify_by idby;
76 /*
77 * The handler should return a negative error code,
78 * zero on success, 1 if the arguments were wrong.
79 * Return 2 iff you provide the error message yourself.
80 */
81 int (*handler)(struct nl80211_state *state,
82 struct nl_msg *msg,
83 int argc, char **argv,
84 enum id_input id);
85 const struct cmd *(*selector)(int argc, char **argv);
86 const struct cmd *parent;
87 };
88
89 struct chanmode {
90 const char *name;
91 unsigned int width;
92 int freq1_diff;
93 int chantype; /* for older kernel */
94 };
95
96 struct chandef {
97 enum nl80211_chan_width width;
98
99 unsigned int control_freq;
100 unsigned int center_freq1;
101 unsigned int center_freq2;
102 };
103
104 #define ARRAY_SIZE(ar) (sizeof(ar)/sizeof(ar[0]))
105 #define DIV_ROUND_UP(x, y) (((x) + (y - 1)) / (y))
106
107 #define __COMMAND(_section, _symname, _name, _args, _nlcmd, _flags, _hidden, _idby, _handler, _help, _sel)\
108 static struct cmd \
109 __cmd ## _ ## _symname ## _ ## _handler ## _ ## _nlcmd ## _ ## _idby ## _ ## _hidden\
110 __attribute__((used)) __attribute__((section("__cmd"))) = { \
111 .name = (_name), \
112 .args = (_args), \
113 .cmd = (_nlcmd), \
114 .nl_msg_flags = (_flags), \
115 .hidden = (_hidden), \
116 .idby = (_idby), \
117 .handler = (_handler), \
118 .help = (_help), \
119 .parent = _section, \
120 .selector = (_sel), \
121 }
122 #define __ACMD(_section, _symname, _name, _args, _nlcmd, _flags, _hidden, _idby, _handler, _help, _sel, _alias)\
123 __COMMAND(_section, _symname, _name, _args, _nlcmd, _flags, _hidden, _idby, _handler, _help, _sel);\
124 static const struct cmd *_alias = &__cmd ## _ ## _symname ## _ ## _handler ## _ ## _nlcmd ## _ ## _idby ## _ ## _hidden
125 #define COMMAND(section, name, args, cmd, flags, idby, handler, help) \
126 __COMMAND(&(__section ## _ ## section), name, #name, args, cmd, flags, 0, idby, handler, help, NULL)
127 #define COMMAND_ALIAS(section, name, args, cmd, flags, idby, handler, help, selector, alias)\
128 __ACMD(&(__section ## _ ## section), name, #name, args, cmd, flags, 0, idby, handler, help, selector, alias)
129 #define HIDDEN(section, name, args, cmd, flags, idby, handler) \
130 __COMMAND(&(__section ## _ ## section), name, #name, args, cmd, flags, 1, idby, handler, NULL, NULL)
131
132 #define TOPLEVEL(_name, _args, _nlcmd, _flags, _idby, _handler, _help) \
133 extern struct cmd __section ## _ ## _name; /* sparse */ \
134 struct cmd \
135 __section ## _ ## _name \
136 __attribute__((used)) __attribute__((section("__cmd"))) = { \
137 .name = (#_name), \
138 .args = (_args), \
139 .cmd = (_nlcmd), \
140 .nl_msg_flags = (_flags), \
141 .idby = (_idby), \
142 .handler = (_handler), \
143 .help = (_help), \
144 }
145 #define SECTION(_name) \
146 extern struct cmd __section ## _ ## _name; /* sparse */ \
147 struct cmd __section ## _ ## _name \
148 __attribute__((used)) __attribute__((section("__cmd"))) = { \
149 .name = (#_name), \
150 .hidden = 1, \
151 }
152
153 #define DECLARE_SECTION(_name) \
154 extern struct cmd __section ## _ ## _name;
155
156 extern const char iw_version[];
157
158 extern int iw_debug;
159
160 int handle_cmd(struct nl80211_state *state, enum id_input idby,
161 int argc, char **argv);
162
163 struct print_event_args {
164 struct timeval ts; /* internal */
165 bool have_ts; /* must be set false */
166 bool frame, time, reltime;
167 };
168
169 __u32 listen_events(struct nl80211_state *state,
170 const int n_waits, const __u32 *waits);
171 int __prepare_listen_events(struct nl80211_state *state);
172 __u32 __do_listen_events(struct nl80211_state *state,
173 const int n_waits, const __u32 *waits,
174 struct print_event_args *args);
175
176 int valid_handler(struct nl_msg *msg, void *arg);
177 void register_handler(int (*handler)(struct nl_msg *, void *), void *data);
178
179 int mac_addr_a2n(unsigned char *mac_addr, char *arg);
180 void mac_addr_n2a(char *mac_addr, const unsigned char *arg);
181 int parse_hex_mask(char *hexmask, unsigned char **result, size_t *result_len,
182 unsigned char **mask);
183 unsigned char *parse_hex(char *hex, size_t *outlen);
184
185 int parse_keys(struct nl_msg *msg, char **argv[], int *argc);
186 int parse_freqchan(struct chandef *chandef, bool chan, int argc, char **argv, int *parsed);
187 enum nl80211_chan_width str_to_bw(const char *str);
188 int parse_txq_stats(char *buf, int buflen, struct nlattr *tid_stats_attr, int header,
189 int tid, const char *indent);
190 int put_chandef(struct nl_msg *msg, struct chandef *chandef);
191
192 void print_ht_mcs(const __u8 *mcs);
193 void print_ampdu_length(__u8 exponent);
194 void print_ampdu_spacing(__u8 spacing);
195 void print_ht_capability(__u16 cap);
196 void print_vht_info(__u32 capa, const __u8 *mcs);
197
198 char *channel_width_name(enum nl80211_chan_width width);
199 const char *iftype_name(enum nl80211_iftype iftype);
200 const char *command_name(enum nl80211_commands cmd);
201 int ieee80211_channel_to_frequency(int chan, enum nl80211_band band);
202 int ieee80211_frequency_to_channel(int freq);
203
204 void print_ssid_escaped(const uint8_t len, const uint8_t *data);
205
206 int nl_get_multicast_id(struct nl_sock *sock, const char *family, const char *group);
207
208 char *reg_initiator_to_string(__u8 initiator);
209
210 const char *get_reason_str(uint16_t reason);
211 const char *get_status_str(uint16_t status);
212
213 enum print_ie_type {
214 PRINT_SCAN,
215 PRINT_LINK,
216 };
217
218 #define BIT(x) (1ULL<<(x))
219
220 void print_ies(unsigned char *ie, int ielen, bool unknown,
221 enum print_ie_type ptype);
222
223 void parse_bitrate(struct nlattr *bitrate_attr, char *buf, int buflen);
224 void iw_hexdump(const char *prefix, const __u8 *data, size_t len);
225
226 int get_cf1(const struct chanmode *chanmode, unsigned long freq);
227
228 #define SCHED_SCAN_OPTIONS "[interval <in_msecs> | scan_plans [<interval_secs:iterations>*] <interval_secs>] " \
229 "[delay <in_secs>] [freqs <freq>+] [matches [ssid <ssid>]+]] [active [ssid <ssid>]+|passive] " \
230 "[randomise[=<addr>/<mask>]]"
231 int parse_sched_scan(struct nl_msg *msg, int *argc, char ***argv);
232
233 DECLARE_SECTION(switch);
234 DECLARE_SECTION(set);
235 DECLARE_SECTION(get);
236
237 char *hex2bin(const char *hex, char *buf);
238
239 #endif /* __IW_H */