]> git.ipfire.org Git - thirdparty/iw.git/blame - phy.c
update nl80211.h
[thirdparty/iw.git] / phy.c
CommitLineData
379f8397 1#include <stdbool.h>
0f55e0b8 2#include <errno.h>
0f55e0b8
JB
3#include <net/if.h>
4
5#include <netlink/genl/genl.h>
6#include <netlink/genl/family.h>
7#include <netlink/genl/ctrl.h>
8#include <netlink/msg.h>
9#include <netlink/attr.h>
10
f408e01b 11#include "nl80211.h"
0f55e0b8
JB
12#include "iw.h"
13
7c37a24d
JB
14static int handle_name(struct nl80211_state *state,
15 struct nl_cb *cb,
0f55e0b8
JB
16 struct nl_msg *msg,
17 int argc, char **argv)
18{
0f55e0b8 19 if (argc != 1)
5e75fd04 20 return 1;
0f55e0b8
JB
21
22 NLA_PUT_STRING(msg, NL80211_ATTR_WIPHY_NAME, *argv);
23
70391ccf 24 return 0;
0f55e0b8 25 nla_put_failure:
70391ccf 26 return -ENOBUFS;
0f55e0b8 27}
cea8fa1c
JB
28COMMAND(set, name, "<new name>", NL80211_CMD_SET_WIPHY, 0, CIB_PHY, handle_name,
29 "Rename this wireless device.");
b822cda9 30
379f8397
JB
31static int handle_freqchan(struct nl_msg *msg, bool chan,
32 int argc, char **argv)
b822cda9
JB
33{
34 static const struct {
35 const char *name;
36 unsigned int val;
37 } htmap[] = {
68632dc7
JB
38 { .name = "HT20", .val = NL80211_CHAN_HT20, },
39 { .name = "HT40+", .val = NL80211_CHAN_HT40PLUS, },
40 { .name = "HT40-", .val = NL80211_CHAN_HT40MINUS, },
b822cda9 41 };
68632dc7 42 unsigned int htval = NL80211_CHAN_NO_HT;
b822cda9
JB
43 unsigned int freq;
44 int i;
45
46 if (!argc || argc > 2)
47 return 1;
48
49 if (argc == 2) {
7d736016 50 for (i = 0; i < ARRAY_SIZE(htmap); i++) {
b822cda9
JB
51 if (strcasecmp(htmap[i].name, argv[1]) == 0) {
52 htval = htmap[i].val;
53 break;
54 }
55 }
68632dc7 56 if (htval == NL80211_CHAN_NO_HT)
b822cda9
JB
57 return 1;
58 }
59
60 freq = strtoul(argv[0], NULL, 10);
379f8397
JB
61 if (chan)
62 freq = ieee80211_channel_to_frequency(freq);
b822cda9
JB
63
64 NLA_PUT_U32(msg, NL80211_ATTR_WIPHY_FREQ, freq);
68632dc7 65 NLA_PUT_U32(msg, NL80211_ATTR_WIPHY_CHANNEL_TYPE, htval);
b822cda9
JB
66
67 return 0;
68 nla_put_failure:
69 return -ENOBUFS;
70}
379f8397 71
7c37a24d
JB
72static int handle_freq(struct nl80211_state *state,
73 struct nl_cb *cb, struct nl_msg *msg,
379f8397
JB
74 int argc, char **argv)
75{
76 return handle_freqchan(msg, false, argc, argv);
77}
b822cda9 78COMMAND(set, freq, "<freq> [HT20|HT40+|HT40-]",
00c448b2
JB
79 NL80211_CMD_SET_WIPHY, 0, CIB_PHY, handle_freq,
80 "Set frequency/channel the hardware is using, including HT\n"
81 "configuration.");
b822cda9 82COMMAND(set, freq, "<freq> [HT20|HT40+|HT40-]",
01ae06f9 83 NL80211_CMD_SET_WIPHY, 0, CIB_NETDEV, handle_freq, NULL);
379f8397 84
7c37a24d
JB
85static int handle_chan(struct nl80211_state *state,
86 struct nl_cb *cb, struct nl_msg *msg,
379f8397
JB
87 int argc, char **argv)
88{
89 return handle_freqchan(msg, true, argc, argv);
90}
91COMMAND(set, channel, "<channel> [HT20|HT40+|HT40-]",
01ae06f9 92 NL80211_CMD_SET_WIPHY, 0, CIB_PHY, handle_chan, NULL);
379f8397 93COMMAND(set, channel, "<channel> [HT20|HT40+|HT40-]",
01ae06f9 94 NL80211_CMD_SET_WIPHY, 0, CIB_NETDEV, handle_chan, NULL);
625aa4ae
JB
95
96static int handle_fragmentation(struct nl80211_state *state,
97 struct nl_cb *cb, struct nl_msg *msg,
98 int argc, char **argv)
99{
100 unsigned int frag;
101
102 if (argc != 1)
103 return 1;
104
105 if (strcmp("off", argv[0]) == 0)
106 frag = -1;
107 else
108 frag = strtoul(argv[0], NULL, 10);
109
110 NLA_PUT_U32(msg, NL80211_ATTR_WIPHY_FRAG_THRESHOLD, frag);
111
112 return 0;
113 nla_put_failure:
114 return -ENOBUFS;
115}
116COMMAND(set, frag, "<fragmentation threshold|off>",
117 NL80211_CMD_SET_WIPHY, 0, CIB_PHY, handle_fragmentation,
118 "Set fragmentation threshold.");
119
120static int handle_rts(struct nl80211_state *state,
121 struct nl_cb *cb, struct nl_msg *msg,
122 int argc, char **argv)
123{
124 unsigned int rts;
125
126 if (argc != 1)
127 return 1;
128
129 if (strcmp("off", argv[0]) == 0)
130 rts = -1;
131 else
132 rts = strtoul(argv[0], NULL, 10);
133
134 NLA_PUT_U32(msg, NL80211_ATTR_WIPHY_RTS_THRESHOLD, rts);
135
136 return 0;
137 nla_put_failure:
138 return -ENOBUFS;
139}
140COMMAND(set, rts, "<rts threshold|off>",
141 NL80211_CMD_SET_WIPHY, 0, CIB_PHY, handle_rts,
142 "Set rts threshold.");
e960e066
JB
143
144static int handle_netns(struct nl80211_state *state,
145 struct nl_cb *cb,
146 struct nl_msg *msg,
147 int argc, char **argv)
148{
149 char *end;
150
151 if (argc != 1)
152 return 1;
153
154 NLA_PUT_U32(msg, NL80211_ATTR_PID,
155 strtoul(argv[0], &end, 10));
156
157 if (*end != '\0')
158 return 1;
159
160 return 0;
161 nla_put_failure:
162 return -ENOBUFS;
163}
164COMMAND(set, netns, "<pid>",
165 NL80211_CMD_SET_WIPHY_NETNS, 0, CIB_PHY, handle_netns,
166 "Put this wireless device into a different network namespace");