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