xref: /linux/net/wireless/Kconfig (revision a3b018febccd3686c39e86e98b5081bde014fc66)
1ec8f24b7SThomas Gleixner# SPDX-License-Identifier: GPL-2.0-only
23d23e349SJohannes Bergconfig WIRELESS_EXT
33d23e349SJohannes Berg	bool
43d23e349SJohannes Berg
53d23e349SJohannes Bergconfig WEXT_CORE
63d23e349SJohannes Berg	def_bool y
73d23e349SJohannes Berg	depends on CFG80211_WEXT || WIRELESS_EXT
83d23e349SJohannes Berg
93d23e349SJohannes Bergconfig WEXT_PROC
103d23e349SJohannes Berg	def_bool y
113d23e349SJohannes Berg	depends on PROC_FS
123d23e349SJohannes Berg	depends on WEXT_CORE
133d23e349SJohannes Berg
143d23e349SJohannes Bergconfig WEXT_SPY
153d23e349SJohannes Berg	bool
163d23e349SJohannes Berg
173d23e349SJohannes Bergconfig WEXT_PRIV
183d23e349SJohannes Berg	bool
193d23e349SJohannes Berg
20704232c2SJohannes Bergconfig CFG80211
21b275f285SLuis R. Rodriguez	tristate "cfg80211 - wireless configuration API"
221f87f7d3SJohannes Berg	depends on RFKILL || !RFKILL
23007f6c5eSJohannes Berg	select FW_LOADER
2401a95b21SJohannes Berg	# may need to update this when certificates are changed and are
2501a95b21SJohannes Berg	# using a different algorithm, though right now they shouldn't
2601a95b21SJohannes Berg	# (this is here rather than below to allow it to be a module)
2701a95b21SJohannes Berg	select CRYPTO_SHA256 if CFG80211_USE_KERNEL_REGDB_KEYS
28b275f285SLuis R. Rodriguez	---help---
29b275f285SLuis R. Rodriguez	  cfg80211 is the Linux wireless LAN (802.11) configuration API.
30b275f285SLuis R. Rodriguez	  Enable this if you have a wireless device.
31b275f285SLuis R. Rodriguez
32b275f285SLuis R. Rodriguez	  For more information refer to documentation on the wireless wiki:
33b275f285SLuis R. Rodriguez
34b275f285SLuis R. Rodriguez	  http://wireless.kernel.org/en/developers/Documentation/cfg80211
35b275f285SLuis R. Rodriguez
36b275f285SLuis R. Rodriguez	  When built as a module it will be called cfg80211.
37704232c2SJohannes Berg
38a7887236SRomain Naourif CFG80211
39a7887236SRomain Naour
40aff89a9bSJohannes Bergconfig NL80211_TESTMODE
41aff89a9bSJohannes Berg	bool "nl80211 testmode command"
42aff89a9bSJohannes Berg	help
43aff89a9bSJohannes Berg	  The nl80211 testmode command helps implementing things like
44aff89a9bSJohannes Berg	  factory calibration or validation tools for wireless chips.
45aff89a9bSJohannes Berg
46aff89a9bSJohannes Berg	  Select this option ONLY for kernels that are specifically
47aff89a9bSJohannes Berg	  built for such purposes.
48aff89a9bSJohannes Berg
49aff89a9bSJohannes Berg	  Debugging tools that are supposed to end up in the hands of
50aff89a9bSJohannes Berg	  users should better be implemented with debugfs.
51aff89a9bSJohannes Berg
52aff89a9bSJohannes Berg	  Say N.
53aff89a9bSJohannes Berg
54f7969969SJohannes Bergconfig CFG80211_DEVELOPER_WARNINGS
55f7969969SJohannes Berg	bool "enable developer warnings"
56f7969969SJohannes Berg	default n
57f7969969SJohannes Berg	help
58f7969969SJohannes Berg	  This option enables some additional warnings that help
59573a2b51SOla Olsson	  cfg80211 developers and driver developers, but beware that
60573a2b51SOla Olsson	  they can also trigger due to races with userspace.
61f7969969SJohannes Berg
62f7969969SJohannes Berg	  For example, when a driver reports that it was disconnected
63f7969969SJohannes Berg	  from the AP, but the user disconnects manually at the same
64f7969969SJohannes Berg	  time, the warning might trigger spuriously due to races.
65f7969969SJohannes Berg
66f7969969SJohannes Berg	  Say Y only if you are developing cfg80211 or a driver based
67f7969969SJohannes Berg	  on it (or mac80211).
68f7969969SJohannes Berg
69f7969969SJohannes Berg
70b594bab9SLuis R. Rodriguezconfig CFG80211_CERTIFICATION_ONUS
71b594bab9SLuis R. Rodriguez	bool "cfg80211 certification onus"
72a7887236SRomain Naour	depends on EXPERT
73b594bab9SLuis R. Rodriguez	default n
74b594bab9SLuis R. Rodriguez	---help---
75b594bab9SLuis R. Rodriguez	  You should disable this option unless you are both capable
76b594bab9SLuis R. Rodriguez	  and willing to ensure your system will remain regulatory
77b594bab9SLuis R. Rodriguez	  compliant with the features available under this option.
78b594bab9SLuis R. Rodriguez	  Some options may still be under heavy development and
79b594bab9SLuis R. Rodriguez	  for whatever reason regulatory compliance has not or
80b594bab9SLuis R. Rodriguez	  cannot yet be verified. Regulatory verification may at
81b594bab9SLuis R. Rodriguez	  times only be possible until you have the final system
82b594bab9SLuis R. Rodriguez	  in place.
83b594bab9SLuis R. Rodriguez
84b594bab9SLuis R. Rodriguez	  This option should only be enabled by system integrators
85b594bab9SLuis R. Rodriguez	  or distributions that have done work necessary to ensure
86b594bab9SLuis R. Rodriguez	  regulatory certification on the system with the enabled
87b594bab9SLuis R. Rodriguez	  features. Alternatively you can enable this option if
88b594bab9SLuis R. Rodriguez	  you are a wireless researcher and are working in a controlled
89b594bab9SLuis R. Rodriguez	  and approved environment by your local regulatory agency.
90b594bab9SLuis R. Rodriguez
9190a53e44SJohannes Bergconfig CFG80211_REQUIRE_SIGNED_REGDB
9290a53e44SJohannes Berg	bool "require regdb signature" if CFG80211_CERTIFICATION_ONUS
9390a53e44SJohannes Berg	default y
9490a53e44SJohannes Berg	select SYSTEM_DATA_VERIFICATION
9590a53e44SJohannes Berg	help
9690a53e44SJohannes Berg	  Require that in addition to the "regulatory.db" file a
9790a53e44SJohannes Berg	  "regulatory.db.p7s" can be loaded with a valid PKCS#7
9890a53e44SJohannes Berg	  signature for the regulatory.db file made by one of the
9990a53e44SJohannes Berg	  keys in the certs/ directory.
10090a53e44SJohannes Berg
10190a53e44SJohannes Bergconfig CFG80211_USE_KERNEL_REGDB_KEYS
10290a53e44SJohannes Berg	bool "allow regdb keys shipped with the kernel" if CFG80211_CERTIFICATION_ONUS
10390a53e44SJohannes Berg	default y
10490a53e44SJohannes Berg	depends on CFG80211_REQUIRE_SIGNED_REGDB
10590a53e44SJohannes Berg	help
10690a53e44SJohannes Berg	  Allow the regulatory database to be signed by one of the keys for
10790a53e44SJohannes Berg	  which certificates are part of the kernel sources
10890a53e44SJohannes Berg	  (in net/wireless/certs/).
10990a53e44SJohannes Berg
11090a53e44SJohannes Berg	  This is currently only Seth Forshee's key, who is the regulatory
11190a53e44SJohannes Berg	  database maintainer.
11290a53e44SJohannes Berg
11390a53e44SJohannes Bergconfig CFG80211_EXTRA_REGDB_KEYDIR
11490a53e44SJohannes Berg	string "additional regdb key directory" if CFG80211_CERTIFICATION_ONUS
11590a53e44SJohannes Berg	depends on CFG80211_REQUIRE_SIGNED_REGDB
11690a53e44SJohannes Berg	help
11790a53e44SJohannes Berg	  If selected, point to a directory with DER-encoded X.509
11890a53e44SJohannes Berg	  certificates like in the kernel sources (net/wireless/certs/)
11990a53e44SJohannes Berg	  that shall be accepted for a signed regulatory database.
12090a53e44SJohannes Berg
12101a95b21SJohannes Berg	  Note that you need to also select the correct CRYPTO_<hash> modules
12201a95b21SJohannes Berg	  for your certificates, and if cfg80211 is built-in they also must be.
12301a95b21SJohannes Berg
12494fc661fSIlan Peerconfig CFG80211_REG_CELLULAR_HINTS
12594fc661fSIlan Peer	bool "cfg80211 regulatory support for cellular base station hints"
12694fc661fSIlan Peer	depends on CFG80211_CERTIFICATION_ONUS
12794fc661fSIlan Peer	---help---
12894fc661fSIlan Peer	  This option enables support for parsing regulatory hints
12994fc661fSIlan Peer	  from cellular base stations. If enabled and at least one driver
13094fc661fSIlan Peer	  claims support for parsing cellular base station hints the
13194fc661fSIlan Peer	  regulatory core will allow and parse these regulatory hints.
13294fc661fSIlan Peer	  The regulatory core will only apply these regulatory hints on
13394fc661fSIlan Peer	  drivers that support this feature. You should only enable this
13494fc661fSIlan Peer	  feature if you have tested and validated this feature on your
13594fc661fSIlan Peer	  systems.
13694fc661fSIlan Peer
137174e0cd2SIlan Peerconfig CFG80211_REG_RELAX_NO_IR
138174e0cd2SIlan Peer	bool "cfg80211 support for NO_IR relaxation"
139174e0cd2SIlan Peer	depends on CFG80211_CERTIFICATION_ONUS
140174e0cd2SIlan Peer	---help---
141174e0cd2SIlan Peer	 This option enables support for relaxation of the NO_IR flag for
142174e0cd2SIlan Peer	 situations that certain regulatory bodies have provided clarifications
143174e0cd2SIlan Peer	 on how relaxation can occur. This feature has an inherent dependency on
144174e0cd2SIlan Peer	 userspace features which must have been properly tested and as such is
145174e0cd2SIlan Peer	 not enabled by default.
146174e0cd2SIlan Peer
147174e0cd2SIlan Peer	 A relaxation feature example is allowing the operation of a P2P group
148174e0cd2SIlan Peer	 owner (GO) on channels marked with NO_IR if there is an additional BSS
149174e0cd2SIlan Peer	 interface which associated to an AP which userspace assumes or confirms
150174e0cd2SIlan Peer	 to be an authorized master, i.e., with radar detection support and DFS
151174e0cd2SIlan Peer	 capabilities. However, note that in order to not create daisy chain
152573a2b51SOla Olsson	 scenarios, this relaxation is not allowed in cases where the BSS client
153174e0cd2SIlan Peer	 is associated to P2P GO and in addition the P2P GO instantiated on
154174e0cd2SIlan Peer	 a channel due to this relaxation should not allow connection from
155174e0cd2SIlan Peer	 non P2P clients.
156174e0cd2SIlan Peer
157174e0cd2SIlan Peer	 The regulatory core will apply these relaxations only for drivers that
158174e0cd2SIlan Peer	 support this feature by declaring the appropriate channel flags and
159174e0cd2SIlan Peer	 capabilities in their registration flow.
160174e0cd2SIlan Peer
161bc92afd9SJohannes Bergconfig CFG80211_DEFAULT_PS
162bc92afd9SJohannes Berg	bool "enable powersave by default"
163bc92afd9SJohannes Berg	default y
164bc92afd9SJohannes Berg	help
165bc92afd9SJohannes Berg	  This option enables powersave mode by default.
166bc92afd9SJohannes Berg
167bc92afd9SJohannes Berg	  If this causes your applications to misbehave you should fix your
168bc92afd9SJohannes Berg	  applications instead -- they need to register their network
169151f4e2bSMauro Carvalho Chehab	  latency requirement, see Documentation/power/pm_qos_interface.rst.
170bc92afd9SJohannes Berg
1711ac61302SLuis R. Rodriguezconfig CFG80211_DEBUGFS
1721ac61302SLuis R. Rodriguez	bool "cfg80211 DebugFS entries"
1733d23e349SJohannes Berg	depends on DEBUG_FS
1741ac61302SLuis R. Rodriguez	---help---
175573a2b51SOla Olsson	  You can enable this if you want debugfs entries for cfg80211.
1761ac61302SLuis R. Rodriguez
1771ac61302SLuis R. Rodriguez	  If unsure, say N.
1781ac61302SLuis R. Rodriguez
179b6863036SJohannes Bergconfig CFG80211_CRDA_SUPPORT
180c8c240e2SJohannes Berg	bool "support CRDA" if EXPERT
181b6863036SJohannes Berg	default y
182b6863036SJohannes Berg	help
183b6863036SJohannes Berg	  You should enable this option unless you know for sure you have no
184*a3b018feSPatrick Steinhardt	  need for it, for example when using the regulatory database loaded as
185*a3b018feSPatrick Steinhardt	  a firmware file.
186b6863036SJohannes Berg
187b6863036SJohannes Berg	  If unsure, say Y.
188b6863036SJohannes Berg
1893d23e349SJohannes Bergconfig CFG80211_WEXT
1906d00ec05SJohannes Berg	bool "cfg80211 wireless extensions compatibility" if !CFG80211_WEXT_EXPORT
1913d23e349SJohannes Berg	select WEXT_CORE
1922afe38d1SJohannes Berg	default y if CFG80211_WEXT_EXPORT
1933d23e349SJohannes Berg	help
1943d23e349SJohannes Berg	  Enable this option if you need old userspace for wireless
1953d23e349SJohannes Berg	  extensions with cfg80211-based drivers.
19622bb1be4SJohannes Berg
1972afe38d1SJohannes Bergconfig CFG80211_WEXT_EXPORT
1982afe38d1SJohannes Berg	bool
1992afe38d1SJohannes Berg	help
2002afe38d1SJohannes Berg	  Drivers should select this option if they require cfg80211's
2012afe38d1SJohannes Berg	  wext compatibility symbols to be exported.
2022afe38d1SJohannes Berg
203a7887236SRomain Naourendif # CFG80211
204a7887236SRomain Naour
2057e272fcfSJohn W. Linvilleconfig LIB80211
206f3684343SJohannes Berg	tristate
2077e272fcfSJohn W. Linville	default n
2087e272fcfSJohn W. Linville	help
2097e272fcfSJohn W. Linville	  This options enables a library of common routines used
2107e272fcfSJohn W. Linville	  by IEEE802.11 wireless LAN drivers.
2117e272fcfSJohn W. Linville
212f3684343SJohannes Berg	  Drivers should select this themselves if needed.
213274bfb8dSJohn W. Linville
214274bfb8dSJohn W. Linvilleconfig LIB80211_CRYPT_WEP
215274bfb8dSJohn W. Linville	tristate
216af1f3d32SArd Biesheuvel	select CRYPTO_LIB_ARC4
217274bfb8dSJohn W. Linville
218274bfb8dSJohn W. Linvilleconfig LIB80211_CRYPT_CCMP
219274bfb8dSJohn W. Linville	tristate
220a11e2f85SArd Biesheuvel	select CRYPTO_AES
221a11e2f85SArd Biesheuvel	select CRYPTO_CCM
222274bfb8dSJohn W. Linville
223274bfb8dSJohn W. Linvilleconfig LIB80211_CRYPT_TKIP
224274bfb8dSJohn W. Linville	tristate
2254be29701SArd Biesheuvel	select CRYPTO_LIB_ARC4
2266f16bf3bSJohn W. Linville
2276f16bf3bSJohn W. Linvilleconfig LIB80211_DEBUG
2286f16bf3bSJohn W. Linville	bool "lib80211 debugging messages"
2296f16bf3bSJohn W. Linville	depends on LIB80211
2306f16bf3bSJohn W. Linville	default n
2316f16bf3bSJohn W. Linville	---help---
2326f16bf3bSJohn W. Linville	  You can enable this if you want verbose debugging messages
2336f16bf3bSJohn W. Linville	  from lib80211.
2346f16bf3bSJohn W. Linville
2356f16bf3bSJohn W. Linville	  If unsure, say N.
236