blob: 41722046b9370c1861a51787dceabfe2b6215274 [file] [log] [blame]
Johannes Berg3d23e342009-09-29 23:27:28 +02001config WIRELESS_EXT
2 bool
3
4config WEXT_CORE
5 def_bool y
6 depends on CFG80211_WEXT || WIRELESS_EXT
7
8config WEXT_PROC
9 def_bool y
10 depends on PROC_FS
11 depends on WEXT_CORE
12
13config WEXT_SPY
14 bool
15
16config WEXT_PRIV
17 bool
18
Johannes Berg704232c2007-04-23 12:20:05 -070019config CFG80211
Luis R. Rodriguezb275f282009-09-01 08:53:49 -070020 tristate "cfg80211 - wireless configuration API"
Johannes Berg1f87f7d2009-06-02 13:01:41 +020021 depends on RFKILL || !RFKILL
Johannes Berg007f6c52015-10-15 11:22:58 +020022 select FW_LOADER
Johannes Berg01a95b22017-11-24 09:35:25 +010023 # may need to update this when certificates are changed and are
24 # using a different algorithm, though right now they shouldn't
25 # (this is here rather than below to allow it to be a module)
26 select CRYPTO_SHA256 if CFG80211_USE_KERNEL_REGDB_KEYS
Luis R. Rodriguezb275f282009-09-01 08:53:49 -070027 ---help---
28 cfg80211 is the Linux wireless LAN (802.11) configuration API.
29 Enable this if you have a wireless device.
30
31 For more information refer to documentation on the wireless wiki:
32
33 http://wireless.kernel.org/en/developers/Documentation/cfg80211
34
35 When built as a module it will be called cfg80211.
Johannes Berg704232c2007-04-23 12:20:05 -070036
Romain Naoura7887232018-02-25 13:39:56 +010037if CFG80211
38
Johannes Bergaff89a92009-07-01 21:26:51 +020039config NL80211_TESTMODE
40 bool "nl80211 testmode command"
Johannes Bergaff89a92009-07-01 21:26:51 +020041 help
42 The nl80211 testmode command helps implementing things like
43 factory calibration or validation tools for wireless chips.
44
45 Select this option ONLY for kernels that are specifically
46 built for such purposes.
47
48 Debugging tools that are supposed to end up in the hands of
49 users should better be implemented with debugfs.
50
51 Say N.
52
Johannes Bergf7969962009-08-21 12:23:49 +020053config CFG80211_DEVELOPER_WARNINGS
54 bool "enable developer warnings"
Johannes Bergf7969962009-08-21 12:23:49 +020055 default n
56 help
57 This option enables some additional warnings that help
Ola Olsson573a2b52016-01-10 18:41:42 +010058 cfg80211 developers and driver developers, but beware that
59 they can also trigger due to races with userspace.
Johannes Bergf7969962009-08-21 12:23:49 +020060
61 For example, when a driver reports that it was disconnected
62 from the AP, but the user disconnects manually at the same
63 time, the warning might trigger spuriously due to races.
64
65 Say Y only if you are developing cfg80211 or a driver based
66 on it (or mac80211).
67
68
Luis R. Rodriguezb594bab2012-07-12 11:49:17 -070069config CFG80211_CERTIFICATION_ONUS
70 bool "cfg80211 certification onus"
Romain Naoura7887232018-02-25 13:39:56 +010071 depends on EXPERT
Luis R. Rodriguezb594bab2012-07-12 11:49:17 -070072 default n
73 ---help---
74 You should disable this option unless you are both capable
75 and willing to ensure your system will remain regulatory
76 compliant with the features available under this option.
77 Some options may still be under heavy development and
78 for whatever reason regulatory compliance has not or
79 cannot yet be verified. Regulatory verification may at
80 times only be possible until you have the final system
81 in place.
82
83 This option should only be enabled by system integrators
84 or distributions that have done work necessary to ensure
85 regulatory certification on the system with the enabled
86 features. Alternatively you can enable this option if
87 you are a wireless researcher and are working in a controlled
88 and approved environment by your local regulatory agency.
89
Johannes Berg90a53e42017-09-13 22:21:08 +020090config CFG80211_REQUIRE_SIGNED_REGDB
91 bool "require regdb signature" if CFG80211_CERTIFICATION_ONUS
92 default y
93 select SYSTEM_DATA_VERIFICATION
94 help
95 Require that in addition to the "regulatory.db" file a
96 "regulatory.db.p7s" can be loaded with a valid PKCS#7
97 signature for the regulatory.db file made by one of the
98 keys in the certs/ directory.
99
100config CFG80211_USE_KERNEL_REGDB_KEYS
101 bool "allow regdb keys shipped with the kernel" if CFG80211_CERTIFICATION_ONUS
102 default y
103 depends on CFG80211_REQUIRE_SIGNED_REGDB
104 help
105 Allow the regulatory database to be signed by one of the keys for
106 which certificates are part of the kernel sources
107 (in net/wireless/certs/).
108
109 This is currently only Seth Forshee's key, who is the regulatory
110 database maintainer.
111
112config CFG80211_EXTRA_REGDB_KEYDIR
113 string "additional regdb key directory" if CFG80211_CERTIFICATION_ONUS
114 depends on CFG80211_REQUIRE_SIGNED_REGDB
115 help
116 If selected, point to a directory with DER-encoded X.509
117 certificates like in the kernel sources (net/wireless/certs/)
118 that shall be accepted for a signed regulatory database.
119
Johannes Berg01a95b22017-11-24 09:35:25 +0100120 Note that you need to also select the correct CRYPTO_<hash> modules
121 for your certificates, and if cfg80211 is built-in they also must be.
122
Ilan Peer94fc6612014-02-23 09:13:00 +0200123config CFG80211_REG_CELLULAR_HINTS
124 bool "cfg80211 regulatory support for cellular base station hints"
125 depends on CFG80211_CERTIFICATION_ONUS
126 ---help---
127 This option enables support for parsing regulatory hints
128 from cellular base stations. If enabled and at least one driver
129 claims support for parsing cellular base station hints the
130 regulatory core will allow and parse these regulatory hints.
131 The regulatory core will only apply these regulatory hints on
132 drivers that support this feature. You should only enable this
133 feature if you have tested and validated this feature on your
134 systems.
135
Ilan Peer174e0cd2014-02-23 09:13:01 +0200136config CFG80211_REG_RELAX_NO_IR
137 bool "cfg80211 support for NO_IR relaxation"
138 depends on CFG80211_CERTIFICATION_ONUS
139 ---help---
140 This option enables support for relaxation of the NO_IR flag for
141 situations that certain regulatory bodies have provided clarifications
142 on how relaxation can occur. This feature has an inherent dependency on
143 userspace features which must have been properly tested and as such is
144 not enabled by default.
145
146 A relaxation feature example is allowing the operation of a P2P group
147 owner (GO) on channels marked with NO_IR if there is an additional BSS
148 interface which associated to an AP which userspace assumes or confirms
149 to be an authorized master, i.e., with radar detection support and DFS
150 capabilities. However, note that in order to not create daisy chain
Ola Olsson573a2b52016-01-10 18:41:42 +0100151 scenarios, this relaxation is not allowed in cases where the BSS client
Ilan Peer174e0cd2014-02-23 09:13:01 +0200152 is associated to P2P GO and in addition the P2P GO instantiated on
153 a channel due to this relaxation should not allow connection from
154 non P2P clients.
155
156 The regulatory core will apply these relaxations only for drivers that
157 support this feature by declaring the appropriate channel flags and
158 capabilities in their registration flow.
159
Johannes Bergbc92afd2009-07-01 21:26:57 +0200160config CFG80211_DEFAULT_PS
161 bool "enable powersave by default"
Johannes Bergbc92afd2009-07-01 21:26:57 +0200162 default y
163 help
164 This option enables powersave mode by default.
165
166 If this causes your applications to misbehave you should fix your
167 applications instead -- they need to register their network
168 latency requirement, see Documentation/power/pm_qos_interface.txt.
169
Luis R. Rodriguez1ac61302009-05-02 00:37:21 -0400170config CFG80211_DEBUGFS
171 bool "cfg80211 DebugFS entries"
Johannes Berg3d23e342009-09-29 23:27:28 +0200172 depends on DEBUG_FS
Luis R. Rodriguez1ac61302009-05-02 00:37:21 -0400173 ---help---
Ola Olsson573a2b52016-01-10 18:41:42 +0100174 You can enable this if you want debugfs entries for cfg80211.
Luis R. Rodriguez1ac61302009-05-02 00:37:21 -0400175
176 If unsure, say N.
177
Johannes Bergb6863032015-10-15 09:25:18 +0200178config CFG80211_CRDA_SUPPORT
Johannes Bergc8c240e2015-10-15 14:35:41 +0200179 bool "support CRDA" if EXPERT
Johannes Bergb6863032015-10-15 09:25:18 +0200180 default y
Johannes Bergb6863032015-10-15 09:25:18 +0200181 help
182 You should enable this option unless you know for sure you have no
Johannes Berg007f6c52015-10-15 11:22:58 +0200183 need for it, for example when using internal regdb (above) or the
184 database loaded as a firmware file.
Johannes Bergb6863032015-10-15 09:25:18 +0200185
186 If unsure, say Y.
187
Johannes Berg3d23e342009-09-29 23:27:28 +0200188config CFG80211_WEXT
Johannes Berg6d00ec02015-04-08 09:16:32 +0200189 bool "cfg80211 wireless extensions compatibility" if !CFG80211_WEXT_EXPORT
Johannes Berg3d23e342009-09-29 23:27:28 +0200190 select WEXT_CORE
Johannes Berg2afe38d2015-01-06 14:00:53 +0100191 default y if CFG80211_WEXT_EXPORT
Johannes Berg3d23e342009-09-29 23:27:28 +0200192 help
193 Enable this option if you need old userspace for wireless
194 extensions with cfg80211-based drivers.
Johannes Berg22bb1be2008-07-10 11:16:47 +0200195
Johannes Berg2afe38d2015-01-06 14:00:53 +0100196config CFG80211_WEXT_EXPORT
197 bool
Johannes Berg2afe38d2015-01-06 14:00:53 +0100198 help
199 Drivers should select this option if they require cfg80211's
200 wext compatibility symbols to be exported.
201
Romain Naoura7887232018-02-25 13:39:56 +0100202endif # CFG80211
203
John W. Linville7e272fc2008-09-24 18:13:14 -0400204config LIB80211
Johannes Bergf3684342012-11-16 00:06:20 +0100205 tristate
John W. Linville7e272fc2008-09-24 18:13:14 -0400206 default n
207 help
208 This options enables a library of common routines used
209 by IEEE802.11 wireless LAN drivers.
210
Johannes Bergf3684342012-11-16 00:06:20 +0100211 Drivers should select this themselves if needed.
John W. Linville274bfb82008-10-29 11:35:05 -0400212
213config LIB80211_CRYPT_WEP
214 tristate
215
216config LIB80211_CRYPT_CCMP
217 tristate
218
219config LIB80211_CRYPT_TKIP
220 tristate
John W. Linville6f16bf32009-03-11 11:05:25 -0400221
222config LIB80211_DEBUG
223 bool "lib80211 debugging messages"
224 depends on LIB80211
225 default n
226 ---help---
227 You can enable this if you want verbose debugging messages
228 from lib80211.
229
230 If unsure, say N.