_sphinx.addnodesdocument)}( rawsourcechildren]( translations LanguagesNode)}(hhh](h pending_xref)}(hhh]docutils.nodesTextChinese (Simplified)}parenthsba attributes}(ids]classes]names]dupnames]backrefs] refdomainstdreftypedoc reftarget-/translations/zh_CN/driver-api/80211/cfg80211modnameN classnameN refexplicitutagnamehhh ubh)}(hhh]hChinese (Traditional)}hh2sbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget-/translations/zh_TW/driver-api/80211/cfg80211modnameN classnameN refexplicituh1hhh ubh)}(hhh]hItalian}hhFsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget-/translations/it_IT/driver-api/80211/cfg80211modnameN classnameN refexplicituh1hhh ubh)}(hhh]hJapanese}hhZsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget-/translations/ja_JP/driver-api/80211/cfg80211modnameN classnameN refexplicituh1hhh ubh)}(hhh]hKorean}hhnsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget-/translations/ko_KR/driver-api/80211/cfg80211modnameN classnameN refexplicituh1hhh ubh)}(hhh]hSpanish}hhsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget-/translations/sp_SP/driver-api/80211/cfg80211modnameN classnameN refexplicituh1hhh ubeh}(h]h ]h"]h$]h&]current_languageEnglishuh1h hh _documenthsourceNlineNubhsection)}(hhh](htitle)}(hcfg80211 subsystemh]hcfg80211 subsystem}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhhhG/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211.rsthKubh paragraph)}(hXcfg80211 is the configuration API for 802.11 devices in Linux. It bridges userspace and drivers, and offers some utility functionality associated with 802.11. cfg80211 must, directly or indirectly via mac80211, be used by all modern wireless drivers in Linux, so that they offer a consistent API through nl80211. For backward compatibility, cfg80211 also offers wireless extensions to userspace, but hides them from drivers completely.h]hXcfg80211 is the configuration API for 802.11 devices in Linux. It bridges userspace and drivers, and offers some utility functionality associated with 802.11. cfg80211 must, directly or indirectly via mac80211, be used by all modern wireless drivers in Linux, so that they offer a consistent API through nl80211. For backward compatibility, cfg80211 also offers wireless extensions to userspace, but hides them from drivers completely.}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hh_/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:5: ./include/net/cfg80211.hhKhhhhubh)}(hZAdditionally, cfg80211 contains code to help enforce regulatory spectrum use restrictions.h]hZAdditionally, cfg80211 contains code to help enforce regulatory spectrum use restrictions.}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hh_/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:5: ./include/net/cfg80211.hhK$hhhhubh)}(hhh](h)}(hDevice registrationh]hDevice registration}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhhhhhK ubh)}(hIn order for a driver to use cfg80211, it must register the hardware device with cfg80211. This happens through a number of hardware capability structs described below.h]hIn order for a driver to use cfg80211, it must register the hardware device with cfg80211. This happens through a number of hardware capability structs described below.}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:11: ./include/net/cfg80211.hhK,hhhhubh)}(hXThe fundamental structure for each device is the 'wiphy', of which each instance describes a physical wireless device connected to the system. Each such wiphy can have zero, one, or many virtual interfaces associated with it, which need to be identified as such by pointing the network interface's **ieee80211_ptr** pointer to a :c:type:`struct wireless_dev ` which further describes the wireless part of the interface. Normally this struct is embedded in the network interface's private data area. Drivers can optionally allow creating or destroying virtual interfaces on the fly, but without at least one or the ability to create some the wireless device isn't useful.h](hX0The fundamental structure for each device is the ‘wiphy’, of which each instance describes a physical wireless device connected to the system. Each such wiphy can have zero, one, or many virtual interfaces associated with it, which need to be identified as such by pointing the network interface’s }(hhhhhNhNubhstrong)}(h**ieee80211_ptr**h]h ieee80211_ptr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhubh pointer to a }(hhhhhNhNubh)}(h,:c:type:`struct wireless_dev `h]hliteral)}(hjh]hstruct wireless_dev}(hjhhhNhNubah}(h]h ](xrefcc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocdriver-api/80211/cfg80211 refdomainj$reftypetype refexplicitrefwarn reftarget wireless_devuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:11: ./include/net/cfg80211.hhK0hhubhX; which further describes the wireless part of the interface. Normally this struct is embedded in the network interface’s private data area. Drivers can optionally allow creating or destroying virtual interfaces on the fly, but without at least one or the ability to create some the wireless device isn’t useful.}(hhhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj8hK0hhhhubh)}(hEach wiphy structure contains device capability information, and also has a pointer to the various operations the driver offers. The definitions and structures here describe these capabilities in detail.h]hEach wiphy structure contains device capability information, and also has a pointer to the various operations the driver offers. The definitions and structures here describe these capabilities in detail.}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:11: ./include/net/cfg80211.hhK:hhhhubhindex)}(hhh]h}(h]h ]h"]h$]h&]entries](single ieee80211_channel_flags (C enum)c.ieee80211_channel_flagshNtauh1jRhhhhhNhNubhdesc)}(hhh](hdesc_signature)}(hieee80211_channel_flagsh]hdesc_signature_line)}(henum ieee80211_channel_flagsh](hdesc_sig_keyword)}(henumh]henum}(hjvhhhNhNubah}(h]h ]kah"]h$]h&]uh1jthjphhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKubhdesc_sig_space)}(h h]h }(hjhhhNhNubah}(h]h ]wah"]h$]h&]uh1jhjphhhjhKubh desc_name)}(hieee80211_channel_flagsh]h desc_sig_name)}(hjlh]hieee80211_channel_flags}(hjhhhNhNubah}(h]h ]nah"]h$]h&]uh1jhjubah}(h]h ](sig-namedescnameeh"]h$]h&] xml:spacepreserveuh1jhjphhhjhKubeh}(h]h ]h"]h$]h&]jj add_permalinkuh1jnsphinx_line_type declaratorhjjhhhjhKubah}(h]jaah ](sig sig-objecteh"]h$]h&] is_multiline _toc_parts) _toc_namehuh1jhhjhKhjehhubh desc_content)}(hhh]h)}(h channel flagsh]h channel flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKHhjhhubah}(h]h ]h"]h$]h&]uh1jhjehhhjhKubeh}(h]h ](j$enumeh"]h$]h&]domainj$objtypejdesctypejnoindex noindexentrynocontentsentryuh1jchhhhhNhNubh container)}(hX **Constants** ``IEEE80211_CHAN_DISABLED`` This channel is disabled. ``IEEE80211_CHAN_NO_IR`` do not initiate radiation, this includes sending probe requests or beaconing. ``IEEE80211_CHAN_PSD`` Power spectral density (in dBm) is set for this channel. ``IEEE80211_CHAN_RADAR`` Radar detection is required on this channel. ``IEEE80211_CHAN_NO_HT40PLUS`` extension channel above this channel is not permitted. ``IEEE80211_CHAN_NO_HT40MINUS`` extension channel below this channel is not permitted. ``IEEE80211_CHAN_NO_OFDM`` OFDM is not allowed on this channel. ``IEEE80211_CHAN_NO_80MHZ`` If the driver supports 80 MHz on the band, this flag indicates that an 80 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions. ``IEEE80211_CHAN_NO_160MHZ`` If the driver supports 160 MHz on the band, this flag indicates that an 160 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions. ``IEEE80211_CHAN_INDOOR_ONLY`` see ``NL80211_FREQUENCY_ATTR_INDOOR_ONLY`` ``IEEE80211_CHAN_IR_CONCURRENT`` see ``NL80211_FREQUENCY_ATTR_IR_CONCURRENT`` ``IEEE80211_CHAN_NO_20MHZ`` 20 MHz bandwidth is not permitted on this channel. ``IEEE80211_CHAN_NO_10MHZ`` 10 MHz bandwidth is not permitted on this channel. ``IEEE80211_CHAN_NO_HE`` HE operation is not permitted on this channel. ``IEEE80211_CHAN_1MHZ`` 1 MHz bandwidth is permitted on this channel. ``IEEE80211_CHAN_2MHZ`` 2 MHz bandwidth is permitted on this channel. ``IEEE80211_CHAN_4MHZ`` 4 MHz bandwidth is permitted on this channel. ``IEEE80211_CHAN_8MHZ`` 8 MHz bandwidth is permitted on this channel. ``IEEE80211_CHAN_16MHZ`` 16 MHz bandwidth is permitted on this channel. ``IEEE80211_CHAN_NO_320MHZ`` If the driver supports 320 MHz on the band, this flag indicates that a 320 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions. ``IEEE80211_CHAN_NO_EHT`` EHT operation is not permitted on this channel. ``IEEE80211_CHAN_DFS_CONCURRENT`` See ``NL80211_RRF_DFS_CONCURRENT`` ``IEEE80211_CHAN_NO_6GHZ_VLP_CLIENT`` Client connection with VLP AP not permitted using this channel ``IEEE80211_CHAN_NO_6GHZ_AFC_CLIENT`` Client connection with AFC AP not permitted using this channel ``IEEE80211_CHAN_CAN_MONITOR`` This channel can be used for monitor mode even in the presence of other (regulatory) restrictions, even if it is otherwise disabled. ``IEEE80211_CHAN_ALLOW_6GHZ_VLP_AP`` Allow using this channel for AP operation with very low power (VLP), even if otherwise set to NO_IR. ``IEEE80211_CHAN_ALLOW_20MHZ_ACTIVITY`` Allow activity on a 20 MHz channel, even if otherwise set to NO_IR.h](h)}(h **Constants**h]j)}(hjh]h Constants}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKLhjubhdefinition_list)}(hhh](hdefinition_list_item)}(h6``IEEE80211_CHAN_DISABLED`` This channel is disabled. h](hterm)}(h``IEEE80211_CHAN_DISABLED``h]j)}(hjh]hIEEE80211_CHAN_DISABLED}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKOhjubh definition)}(hhh]h)}(hThis channel is disabled.h]hThis channel is disabled.}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4hKOhj7ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj4hKOhjubj)}(hg``IEEE80211_CHAN_NO_IR`` do not initiate radiation, this includes sending probe requests or beaconing. h](j)}(h``IEEE80211_CHAN_NO_IR``h]j)}(hjZh]hIEEE80211_CHAN_NO_IR}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKShjTubj6)}(hhh]h)}(hMdo not initiate radiation, this includes sending probe requests or beaconing.h]hMdo not initiate radiation, this includes sending probe requests or beaconing.}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKRhjpubah}(h]h ]h"]h$]h&]uh1j5hjTubeh}(h]h ]h"]h$]h&]uh1jhjohKShjubj)}(hP``IEEE80211_CHAN_PSD`` Power spectral density (in dBm) is set for this channel. h](j)}(h``IEEE80211_CHAN_PSD``h]j)}(hjh]hIEEE80211_CHAN_PSD}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKWhjubj6)}(hhh]h)}(h8Power spectral density (in dBm) is set for this channel.h]h8Power spectral density (in dBm) is set for this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKVhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKWhjubj)}(hF``IEEE80211_CHAN_RADAR`` Radar detection is required on this channel. h](j)}(h``IEEE80211_CHAN_RADAR``h]j)}(hjh]hIEEE80211_CHAN_RADAR}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKZhjubj6)}(hhh]h)}(h,Radar detection is required on this channel.h]h,Radar detection is required on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKZhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKZhjubj)}(hV``IEEE80211_CHAN_NO_HT40PLUS`` extension channel above this channel is not permitted. h](j)}(h``IEEE80211_CHAN_NO_HT40PLUS``h]j)}(hjh]hIEEE80211_CHAN_NO_HT40PLUS}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhK^hjubj6)}(hhh]h)}(h6extension channel above this channel is not permitted.h]h6extension channel above this channel is not permitted.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhK]hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhK^hjubj)}(hW``IEEE80211_CHAN_NO_HT40MINUS`` extension channel below this channel is not permitted. h](j)}(h``IEEE80211_CHAN_NO_HT40MINUS``h]j)}(hjAh]hIEEE80211_CHAN_NO_HT40MINUS}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKbhj;ubj6)}(hhh]h)}(h6extension channel below this channel is not permitted.h]h6extension channel below this channel is not permitted.}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKahjWubah}(h]h ]h"]h$]h&]uh1j5hj;ubeh}(h]h ]h"]h$]h&]uh1jhjVhKbhjubj)}(h@``IEEE80211_CHAN_NO_OFDM`` OFDM is not allowed on this channel. h](j)}(h``IEEE80211_CHAN_NO_OFDM``h]j)}(hj{h]hIEEE80211_CHAN_NO_OFDM}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKehjuubj6)}(hhh]h)}(h$OFDM is not allowed on this channel.h]h$OFDM is not allowed on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKehjubah}(h]h ]h"]h$]h&]uh1j5hjuubeh}(h]h ]h"]h$]h&]uh1jhjhKehjubj)}(hX``IEEE80211_CHAN_NO_80MHZ`` If the driver supports 80 MHz on the band, this flag indicates that an 80 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions. h](j)}(h``IEEE80211_CHAN_NO_80MHZ``h]j)}(hjh]hIEEE80211_CHAN_NO_80MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKlhjubj6)}(hhh]h)}(hIf the driver supports 80 MHz on the band, this flag indicates that an 80 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions.h]hIf the driver supports 80 MHz on the band, this flag indicates that an 80 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKlhjubj)}(hX ``IEEE80211_CHAN_NO_160MHZ`` If the driver supports 160 MHz on the band, this flag indicates that an 160 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions. h](j)}(h``IEEE80211_CHAN_NO_160MHZ``h]j)}(hjh]hIEEE80211_CHAN_NO_160MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKshjubj6)}(hhh]h)}(hIf the driver supports 160 MHz on the band, this flag indicates that an 160 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions.h]hIf the driver supports 160 MHz on the band, this flag indicates that an 160 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKohjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKshjubj)}(hJ``IEEE80211_CHAN_INDOOR_ONLY`` see ``NL80211_FREQUENCY_ATTR_INDOOR_ONLY`` h](j)}(h``IEEE80211_CHAN_INDOOR_ONLY``h]j)}(hj(h]hIEEE80211_CHAN_INDOOR_ONLY}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKvhj"ubj6)}(hhh]h)}(h*see ``NL80211_FREQUENCY_ATTR_INDOOR_ONLY``h](hsee }(hjAhhhNhNubj)}(h&``NL80211_FREQUENCY_ATTR_INDOOR_ONLY``h]h"NL80211_FREQUENCY_ATTR_INDOOR_ONLY}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAubeh}(h]h ]h"]h$]h&]uh1hhj=hKvhj>ubah}(h]h ]h"]h$]h&]uh1j5hj"ubeh}(h]h ]h"]h$]h&]uh1jhj=hKvhjubj)}(hN``IEEE80211_CHAN_IR_CONCURRENT`` see ``NL80211_FREQUENCY_ATTR_IR_CONCURRENT`` h](j)}(h ``IEEE80211_CHAN_IR_CONCURRENT``h]j)}(hjoh]hIEEE80211_CHAN_IR_CONCURRENT}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKyhjiubj6)}(hhh]h)}(h,see ``NL80211_FREQUENCY_ATTR_IR_CONCURRENT``h](hsee }(hjhhhNhNubj)}(h(``NL80211_FREQUENCY_ATTR_IR_CONCURRENT``h]h$NL80211_FREQUENCY_ATTR_IR_CONCURRENT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1hhjhKyhjubah}(h]h ]h"]h$]h&]uh1j5hjiubeh}(h]h ]h"]h$]h&]uh1jhjhKyhjubj)}(hO``IEEE80211_CHAN_NO_20MHZ`` 20 MHz bandwidth is not permitted on this channel. h](j)}(h``IEEE80211_CHAN_NO_20MHZ``h]j)}(hjh]hIEEE80211_CHAN_NO_20MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhK}hjubj6)}(hhh]h)}(h220 MHz bandwidth is not permitted on this channel.h]h220 MHz bandwidth is not permitted on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhK|hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhK}hjubj)}(hO``IEEE80211_CHAN_NO_10MHZ`` 10 MHz bandwidth is not permitted on this channel. h](j)}(h``IEEE80211_CHAN_NO_10MHZ``h]j)}(hjh]hIEEE80211_CHAN_NO_10MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(h210 MHz bandwidth is not permitted on this channel.h]h210 MHz bandwidth is not permitted on this channel.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hH``IEEE80211_CHAN_NO_HE`` HE operation is not permitted on this channel. h](j)}(h``IEEE80211_CHAN_NO_HE``h]j)}(hj*h]hIEEE80211_CHAN_NO_HE}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj$ubj6)}(hhh]h)}(h.HE operation is not permitted on this channel.h]h.HE operation is not permitted on this channel.}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hKhj@ubah}(h]h ]h"]h$]h&]uh1j5hj$ubeh}(h]h ]h"]h$]h&]uh1jhj?hKhjubj)}(hF``IEEE80211_CHAN_1MHZ`` 1 MHz bandwidth is permitted on this channel. h](j)}(h``IEEE80211_CHAN_1MHZ``h]j)}(hjch]hIEEE80211_CHAN_1MHZ}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj]ubj6)}(hhh]h)}(h-1 MHz bandwidth is permitted on this channel.h]h-1 MHz bandwidth is permitted on this channel.}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjyubah}(h]h ]h"]h$]h&]uh1j5hj]ubeh}(h]h ]h"]h$]h&]uh1jhjxhKhjubj)}(hF``IEEE80211_CHAN_2MHZ`` 2 MHz bandwidth is permitted on this channel. h](j)}(h``IEEE80211_CHAN_2MHZ``h]j)}(hjh]hIEEE80211_CHAN_2MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(h-2 MHz bandwidth is permitted on this channel.h]h-2 MHz bandwidth is permitted on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hF``IEEE80211_CHAN_4MHZ`` 4 MHz bandwidth is permitted on this channel. h](j)}(h``IEEE80211_CHAN_4MHZ``h]j)}(hjh]hIEEE80211_CHAN_4MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(h-4 MHz bandwidth is permitted on this channel.h]h-4 MHz bandwidth is permitted on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hF``IEEE80211_CHAN_8MHZ`` 8 MHz bandwidth is permitted on this channel. h](j)}(h``IEEE80211_CHAN_8MHZ``h]j)}(hjh]hIEEE80211_CHAN_8MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(h-8 MHz bandwidth is permitted on this channel.h]h-8 MHz bandwidth is permitted on this channel.}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj'ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj&hKhjubj)}(hH``IEEE80211_CHAN_16MHZ`` 16 MHz bandwidth is permitted on this channel. h](j)}(h``IEEE80211_CHAN_16MHZ``h]j)}(hjKh]hIEEE80211_CHAN_16MHZ}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjEubj6)}(hhh]h)}(h.16 MHz bandwidth is permitted on this channel.h]h.16 MHz bandwidth is permitted on this channel.}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjaubah}(h]h ]h"]h$]h&]uh1j5hjEubeh}(h]h ]h"]h$]h&]uh1jhj`hKhjubj)}(hX``IEEE80211_CHAN_NO_320MHZ`` If the driver supports 320 MHz on the band, this flag indicates that a 320 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions. h](j)}(h``IEEE80211_CHAN_NO_320MHZ``h]j)}(hjh]hIEEE80211_CHAN_NO_320MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(hIf the driver supports 320 MHz on the band, this flag indicates that a 320 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions.h]hIf the driver supports 320 MHz on the band, this flag indicates that a 320 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hJ``IEEE80211_CHAN_NO_EHT`` EHT operation is not permitted on this channel. h](j)}(h``IEEE80211_CHAN_NO_EHT``h]j)}(hjh]hIEEE80211_CHAN_NO_EHT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(h/EHT operation is not permitted on this channel.h]h/EHT operation is not permitted on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hE``IEEE80211_CHAN_DFS_CONCURRENT`` See ``NL80211_RRF_DFS_CONCURRENT`` h](j)}(h!``IEEE80211_CHAN_DFS_CONCURRENT``h]j)}(hjh]hIEEE80211_CHAN_DFS_CONCURRENT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(h"See ``NL80211_RRF_DFS_CONCURRENT``h](hSee }(hjhhhNhNubj)}(h``NL80211_RRF_DFS_CONCURRENT``h]hNL80211_RRF_DFS_CONCURRENT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1hhj hKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hKhjubj)}(he``IEEE80211_CHAN_NO_6GHZ_VLP_CLIENT`` Client connection with VLP AP not permitted using this channel h](j)}(h%``IEEE80211_CHAN_NO_6GHZ_VLP_CLIENT``h]j)}(hj?h]h!IEEE80211_CHAN_NO_6GHZ_VLP_CLIENT}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj9ubj6)}(hhh]h)}(h>Client connection with VLP AP not permitted using this channelh]h>Client connection with VLP AP not permitted using this channel}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjUubah}(h]h ]h"]h$]h&]uh1j5hj9ubeh}(h]h ]h"]h$]h&]uh1jhjThKhjubj)}(he``IEEE80211_CHAN_NO_6GHZ_AFC_CLIENT`` Client connection with AFC AP not permitted using this channel h](j)}(h%``IEEE80211_CHAN_NO_6GHZ_AFC_CLIENT``h]j)}(hjyh]h!IEEE80211_CHAN_NO_6GHZ_AFC_CLIENT}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjsubj6)}(hhh]h)}(h>Client connection with AFC AP not permitted using this channelh]h>Client connection with AFC AP not permitted using this channel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjsubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h``IEEE80211_CHAN_CAN_MONITOR`` This channel can be used for monitor mode even in the presence of other (regulatory) restrictions, even if it is otherwise disabled. h](j)}(h``IEEE80211_CHAN_CAN_MONITOR``h]j)}(hjh]hIEEE80211_CHAN_CAN_MONITOR}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(hThis channel can be used for monitor mode even in the presence of other (regulatory) restrictions, even if it is otherwise disabled.h]hThis channel can be used for monitor mode even in the presence of other (regulatory) restrictions, even if it is otherwise disabled.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h``IEEE80211_CHAN_ALLOW_6GHZ_VLP_AP`` Allow using this channel for AP operation with very low power (VLP), even if otherwise set to NO_IR. h](j)}(h$``IEEE80211_CHAN_ALLOW_6GHZ_VLP_AP``h]j)}(hjh]h IEEE80211_CHAN_ALLOW_6GHZ_VLP_AP}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(hdAllow using this channel for AP operation with very low power (VLP), even if otherwise set to NO_IR.h]hdAllow using this channel for AP operation with very low power (VLP), even if otherwise set to NO_IR.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hk``IEEE80211_CHAN_ALLOW_20MHZ_ACTIVITY`` Allow activity on a 20 MHz channel, even if otherwise set to NO_IR.h](j)}(h'``IEEE80211_CHAN_ALLOW_20MHZ_ACTIVITY``h]j)}(hj'h]h#IEEE80211_CHAN_ALLOW_20MHZ_ACTIVITY}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj!ubj6)}(hhh]h)}(hCAllow activity on a 20 MHz channel, even if otherwise set to NO_IR.h]hCAllow activity on a 20 MHz channel, even if otherwise set to NO_IR.}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hKhj=ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj<hKhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hjih]h Description}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjgubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhhhhubh)}(h1Channel flags set by the regulatory control code.h]h1Channel flags set by the regulatory control code.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKIhhhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ieee80211_channel (C struct)c.ieee80211_channelhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hieee80211_channelh]jo)}(hstruct ieee80211_channelh](ju)}(hstructh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKNubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhKNubj)}(hieee80211_channelh]j)}(hjh]hieee80211_channel}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhKNubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhKNubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhKNhjhhubj)}(hhh]h)}(hchannel definitionh]hchannel definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKNubeh}(h]h ](j$structeh"]h$]h&]jj$jj jj jjjuh1jchhhhhNhNubj)}(hXC**Definition**:: struct ieee80211_channel { enum nl80211_band band; u32 center_freq; u16 freq_offset; u16 hw_value; u32 flags; int max_antenna_gain; int max_power; int max_reg_power; bool beacon_found; u32 orig_flags; int orig_mag, orig_mpwr; enum nl80211_dfs_state dfs_state; unsigned long dfs_state_entered; unsigned int dfs_cac_ms; s8 psd; }; **Members** ``band`` band this channel belongs to. ``center_freq`` center frequency in MHz ``freq_offset`` offset from **center_freq**, in KHz ``hw_value`` hardware-specific value for the channel ``flags`` channel flags from :c:type:`enum ieee80211_channel_flags `. ``max_antenna_gain`` maximum antenna gain in dBi ``max_power`` maximum transmission power (in dBm) ``max_reg_power`` maximum regulatory transmission power (in dBm) ``beacon_found`` helper to regulatory code to indicate when a beacon has been found on this channel. Use regulatory_hint_found_beacon() to enable this, this is useful only on 5 GHz band. ``orig_flags`` channel flags at registration time, used by regulatory code to support devices with additional restrictions ``orig_mag`` internal use ``orig_mpwr`` internal use ``dfs_state`` current state of this channel. Only relevant if radar is required on this channel. ``dfs_state_entered`` timestamp (jiffies) when the dfs state was entered. ``dfs_cac_ms`` DFS CAC time in milliseconds, this is valid for DFS channels. ``psd`` power spectral density (in dBm)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubh:}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubh literal_block)}(hXstruct ieee80211_channel { enum nl80211_band band; u32 center_freq; u16 freq_offset; u16 hw_value; u32 flags; int max_antenna_gain; int max_power; int max_reg_power; bool beacon_found; u32 orig_flags; int orig_mag, orig_mpwr; enum nl80211_dfs_state dfs_state; unsigned long dfs_state_entered; unsigned int dfs_cac_ms; s8 psd; };h]hXstruct ieee80211_channel { enum nl80211_band band; u32 center_freq; u16 freq_offset; u16 hw_value; u32 flags; int max_antenna_gain; int max_power; int max_reg_power; bool beacon_found; u32 orig_flags; int orig_mag, orig_mpwr; enum nl80211_dfs_state dfs_state; unsigned long dfs_state_entered; unsigned int dfs_cac_ms; s8 psd; };}hj) sbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubh)}(h **Members**h]j)}(hj: h]hMembers}(hj< hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8 ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj)}(hhh](j)}(h'``band`` band this channel belongs to. h](j)}(h``band``h]j)}(hjY h]hband}(hj[ hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjW ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjS ubj6)}(hhh]h)}(hband this channel belongs to.h]hband this channel belongs to.}(hjr hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjn hKhjo ubah}(h]h ]h"]h$]h&]uh1j5hjS ubeh}(h]h ]h"]h$]h&]uh1jhjn hKhjP ubj)}(h(``center_freq`` center frequency in MHz h](j)}(h``center_freq``h]j)}(hj h]h center_freq}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(hcenter frequency in MHzh]hcenter frequency in MHz}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(h4``freq_offset`` offset from **center_freq**, in KHz h](j)}(h``freq_offset``h]j)}(hj h]h freq_offset}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(h#offset from **center_freq**, in KHzh](h offset from }(hj hhhNhNubj)}(h**center_freq**h]h center_freq}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubh, in KHz}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(h5``hw_value`` hardware-specific value for the channel h](j)}(h ``hw_value``h]j)}(hj h]hhw_value}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(h'hardware-specific value for the channelh]h'hardware-specific value for the channel}(hj/ hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj+ hKhj, ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj+ hKhjP ubj)}(h_``flags`` channel flags from :c:type:`enum ieee80211_channel_flags `. h](j)}(h ``flags``h]j)}(hjO h]hflags}(hjQ hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjM ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjI ubj6)}(hhh]h)}(hTchannel flags from :c:type:`enum ieee80211_channel_flags `.h](hchannel flags from }(hjh hhhNhNubh)}(h@:c:type:`enum ieee80211_channel_flags `h]j)}(hjr h]henum ieee80211_channel_flags}(hjt hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjp ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarn c:parent_keysphinx.domains.c LookupKey)}data]sbj6ieee80211_channel_flagsuh1hhjd hKhjh ubh.}(hjh hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjd hKhje ubah}(h]h ]h"]h$]h&]uh1j5hjI ubeh}(h]h ]h"]h$]h&]uh1jhjd hKhjP ubj)}(h1``max_antenna_gain`` maximum antenna gain in dBi h](j)}(h``max_antenna_gain``h]j)}(hj h]hmax_antenna_gain}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(hmaximum antenna gain in dBih]hmaximum antenna gain in dBi}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(h2``max_power`` maximum transmission power (in dBm) h](j)}(h ``max_power``h]j)}(hj h]h max_power}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(h#maximum transmission power (in dBm)h]h#maximum transmission power (in dBm)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(hA``max_reg_power`` maximum regulatory transmission power (in dBm) h](j)}(h``max_reg_power``h]j)}(hj% h]h max_reg_power}(hj' hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj# ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(h.maximum regulatory transmission power (in dBm)h]h.maximum regulatory transmission power (in dBm)}(hj> hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj: hKhj; ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj: hKhjP ubj)}(h``beacon_found`` helper to regulatory code to indicate when a beacon has been found on this channel. Use regulatory_hint_found_beacon() to enable this, this is useful only on 5 GHz band. h](j)}(h``beacon_found``h]j)}(hj^ h]h beacon_found}(hj` hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjX ubj6)}(hhh]h)}(hhelper to regulatory code to indicate when a beacon has been found on this channel. Use regulatory_hint_found_beacon() to enable this, this is useful only on 5 GHz band.h]hhelper to regulatory code to indicate when a beacon has been found on this channel. Use regulatory_hint_found_beacon() to enable this, this is useful only on 5 GHz band.}(hjw hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjt ubah}(h]h ]h"]h$]h&]uh1j5hjX ubeh}(h]h ]h"]h$]h&]uh1jhjs hKhjP ubj)}(h{``orig_flags`` channel flags at registration time, used by regulatory code to support devices with additional restrictions h](j)}(h``orig_flags``h]j)}(hj h]h orig_flags}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(hkchannel flags at registration time, used by regulatory code to support devices with additional restrictionsh]hkchannel flags at registration time, used by regulatory code to support devices with additional restrictions}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(h``orig_mag`` internal use h](j)}(h ``orig_mag``h]j)}(hj h]horig_mag}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(h internal useh]h internal use}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(h``orig_mpwr`` internal use h](j)}(h ``orig_mpwr``h]j)}(hj h]h orig_mpwr}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(h internal useh]h internal use}(hj$ hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj! ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(ha``dfs_state`` current state of this channel. Only relevant if radar is required on this channel. h](j)}(h ``dfs_state``h]j)}(hjD h]h dfs_state}(hjF hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjB ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj> ubj6)}(hhh]h)}(hRcurrent state of this channel. Only relevant if radar is required on this channel.h]hRcurrent state of this channel. Only relevant if radar is required on this channel.}(hj] hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjZ ubah}(h]h ]h"]h$]h&]uh1j5hj> ubeh}(h]h ]h"]h$]h&]uh1jhjY hKhjP ubj)}(hJ``dfs_state_entered`` timestamp (jiffies) when the dfs state was entered. h](j)}(h``dfs_state_entered``h]j)}(hj~ h]hdfs_state_entered}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj| ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjx ubj6)}(hhh]h)}(h3timestamp (jiffies) when the dfs state was entered.h]h3timestamp (jiffies) when the dfs state was entered.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j5hjx ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(hM``dfs_cac_ms`` DFS CAC time in milliseconds, this is valid for DFS channels. h](j)}(h``dfs_cac_ms``h]j)}(hj h]h dfs_cac_ms}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(h=DFS CAC time in milliseconds, this is valid for DFS channels.h]h=DFS CAC time in milliseconds, this is valid for DFS channels.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(h'``psd`` power spectral density (in dBm)h](j)}(h``psd``h]j)}(hj h]hpsd}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(hpower spectral density (in dBm)h]hpower spectral density (in dBm)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubeh}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hj3 h]h Description}(hj5 hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1 ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhhhhubh)}(h@This structure describes a single channel for use with cfg80211.h]h@This structure describes a single channel for use with cfg80211.}(hjI hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhhhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ieee80211_rate_flags (C enum)c.ieee80211_rate_flagshNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hieee80211_rate_flagsh]jo)}(henum ieee80211_rate_flagsh](ju)}(hjxh]henum}(hjq hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjm hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjm hhhj~ hKubj)}(hieee80211_rate_flagsh]j)}(hjk h]hieee80211_rate_flags}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjm hhhj~ hKubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhji hhhj~ hKubah}(h]jd ah ](jjeh"]h$]h&]jj)jhuh1jhhj~ hKhjf hhubj)}(hhh]h)}(h rate flagsh]h rate flags}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj hhubah}(h]h ]h"]h$]h&]uh1jhjf hhhj~ hKubeh}(h]h ](j$enumeh"]h$]h&]jj$jj jj jjjuh1jchhhhhNhNubj)}(hX`**Constants** ``IEEE80211_RATE_SHORT_PREAMBLE`` Hardware can send with short preamble on this bitrate; only relevant in 2.4GHz band and with CCK rates. ``IEEE80211_RATE_MANDATORY_A`` This bitrate is a mandatory rate when used with 802.11a (on the 5 GHz band); filled by the core code when registering the wiphy. ``IEEE80211_RATE_MANDATORY_B`` This bitrate is a mandatory rate when used with 802.11b (on the 2.4 GHz band); filled by the core code when registering the wiphy. ``IEEE80211_RATE_MANDATORY_G`` This bitrate is a mandatory rate when used with 802.11g (on the 2.4 GHz band); filled by the core code when registering the wiphy. ``IEEE80211_RATE_ERP_G`` This is an ERP rate in 802.11g mode. ``IEEE80211_RATE_SUPPORTS_5MHZ`` Rate can be used in 5 MHz mode ``IEEE80211_RATE_SUPPORTS_10MHZ`` Rate can be used in 10 MHz modeh](h)}(h **Constants**h]j)}(hj h]h Constants}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj)}(hhh](j)}(h``IEEE80211_RATE_SHORT_PREAMBLE`` Hardware can send with short preamble on this bitrate; only relevant in 2.4GHz band and with CCK rates. h](j)}(h!``IEEE80211_RATE_SHORT_PREAMBLE``h]j)}(hj h]hIEEE80211_RATE_SHORT_PREAMBLE}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(hgHardware can send with short preamble on this bitrate; only relevant in 2.4GHz band and with CCK rates.h]hgHardware can send with short preamble on this bitrate; only relevant in 2.4GHz band and with CCK rates.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhj ubj)}(h``IEEE80211_RATE_MANDATORY_A`` This bitrate is a mandatory rate when used with 802.11a (on the 5 GHz band); filled by the core code when registering the wiphy. h](j)}(h``IEEE80211_RATE_MANDATORY_A``h]j)}(hj.h]hIEEE80211_RATE_MANDATORY_A}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj(ubj6)}(hhh]h)}(hThis bitrate is a mandatory rate when used with 802.11a (on the 5 GHz band); filled by the core code when registering the wiphy.h]hThis bitrate is a mandatory rate when used with 802.11a (on the 5 GHz band); filled by the core code when registering the wiphy.}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjDubah}(h]h ]h"]h$]h&]uh1j5hj(ubeh}(h]h ]h"]h$]h&]uh1jhjChKhj ubj)}(h``IEEE80211_RATE_MANDATORY_B`` This bitrate is a mandatory rate when used with 802.11b (on the 2.4 GHz band); filled by the core code when registering the wiphy. h](j)}(h``IEEE80211_RATE_MANDATORY_B``h]j)}(hjhh]hIEEE80211_RATE_MANDATORY_B}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjbubj6)}(hhh]h)}(hThis bitrate is a mandatory rate when used with 802.11b (on the 2.4 GHz band); filled by the core code when registering the wiphy.h]hThis bitrate is a mandatory rate when used with 802.11b (on the 2.4 GHz band); filled by the core code when registering the wiphy.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj~ubah}(h]h ]h"]h$]h&]uh1j5hjbubeh}(h]h ]h"]h$]h&]uh1jhj}hKhj ubj)}(h``IEEE80211_RATE_MANDATORY_G`` This bitrate is a mandatory rate when used with 802.11g (on the 2.4 GHz band); filled by the core code when registering the wiphy. h](j)}(h``IEEE80211_RATE_MANDATORY_G``h]j)}(hjh]hIEEE80211_RATE_MANDATORY_G}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(hThis bitrate is a mandatory rate when used with 802.11g (on the 2.4 GHz band); filled by the core code when registering the wiphy.h]hThis bitrate is a mandatory rate when used with 802.11g (on the 2.4 GHz band); filled by the core code when registering the wiphy.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhj ubj)}(h>``IEEE80211_RATE_ERP_G`` This is an ERP rate in 802.11g mode. h](j)}(h``IEEE80211_RATE_ERP_G``h]j)}(hjh]hIEEE80211_RATE_ERP_G}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(h$This is an ERP rate in 802.11g mode.h]h$This is an ERP rate in 802.11g mode.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhj ubj)}(h@``IEEE80211_RATE_SUPPORTS_5MHZ`` Rate can be used in 5 MHz mode h](j)}(h ``IEEE80211_RATE_SUPPORTS_5MHZ``h]j)}(hjh]hIEEE80211_RATE_SUPPORTS_5MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(hRate can be used in 5 MHz modeh]hRate can be used in 5 MHz mode}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hKhj+ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj*hKhj ubj)}(hA``IEEE80211_RATE_SUPPORTS_10MHZ`` Rate can be used in 10 MHz modeh](j)}(h!``IEEE80211_RATE_SUPPORTS_10MHZ``h]j)}(hjNh]hIEEE80211_RATE_SUPPORTS_10MHZ}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjHubj6)}(hhh]h)}(hRate can be used in 10 MHz modeh]hRate can be used in 10 MHz mode}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjdubah}(h]h ]h"]h$]h&]uh1j5hjHubeh}(h]h ]h"]h$]h&]uh1jhjchKhj ubeh}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhhhhubh)}(hHardware/specification flags for rates. These are structured in a way that allows using the same bitrate structure for different bands/PHY modes.h]hHardware/specification flags for rates. These are structured in a way that allows using the same bitrate structure for different bands/PHY modes.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhhhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ieee80211_rate (C struct)c.ieee80211_ratehNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hieee80211_rateh]jo)}(hstruct ieee80211_rateh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhKubj)}(hieee80211_rateh]j)}(hjh]hieee80211_rate}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhKhjhhubj)}(hhh]h)}(hbitrate definitionh]hbitrate definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](j$structeh"]h$]h&]jj$jj)jj)jjjuh1jchhhhhNhNubj)}(hX**Definition**:: struct ieee80211_rate { u32 flags; u16 bitrate; u16 hw_value, hw_value_short; }; **Members** ``flags`` rate-specific flags from :c:type:`enum ieee80211_rate_flags ` ``bitrate`` bitrate in units of 100 Kbps ``hw_value`` driver/hardware value for this rate ``hw_value_short`` driver/hardware value for this rate when short preamble is usedh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1ubh:}(hj1hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj-ubj( )}(h\struct ieee80211_rate { u32 flags; u16 bitrate; u16 hw_value, hw_value_short; };h]h\struct ieee80211_rate { u32 flags; u16 bitrate; u16 hw_value, hw_value_short; };}hjNsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj-ubh)}(h **Members**h]j)}(hj_h]hMembers}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM%hj-ubj)}(hhh](j)}(h^``flags`` rate-specific flags from :c:type:`enum ieee80211_rate_flags ` h](j)}(h ``flags``h]j)}(hj~h]hflags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM!hjxubj6)}(hhh]h)}(hSrate-specific flags from :c:type:`enum ieee80211_rate_flags `h](hrate-specific flags from }(hjhhhNhNubh)}(h::c:type:`enum ieee80211_rate_flags `h]j)}(hjh]henum ieee80211_rate_flags}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6ieee80211_rate_flagsuh1hhjhM!hjubeh}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1j5hjxubeh}(h]h ]h"]h$]h&]uh1jhjhM!hjuubj)}(h)``bitrate`` bitrate in units of 100 Kbps h](j)}(h ``bitrate``h]j)}(hjh]hbitrate}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM"hjubj6)}(hhh]h)}(hbitrate in units of 100 Kbpsh]hbitrate in units of 100 Kbps}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM"hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM"hjuubj)}(h1``hw_value`` driver/hardware value for this rate h](j)}(h ``hw_value``h]j)}(hjh]hhw_value}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM#hj ubj6)}(hhh]h)}(h#driver/hardware value for this rateh]h#driver/hardware value for this rate}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$hM#hj%ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj$hM#hjuubj)}(hR``hw_value_short`` driver/hardware value for this rate when short preamble is usedh](j)}(h``hw_value_short``h]j)}(hjHh]hhw_value_short}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM$hjBubj6)}(hhh]h)}(h?driver/hardware value for this rate when short preamble is usedh]h?driver/hardware value for this rate when short preamble is used}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]hM$hj^ubah}(h]h ]h"]h$]h&]uh1j5hjBubeh}(h]h ]h"]h$]h&]uh1jhj]hM$hjuubeh}(h]h ]h"]h$]h&]uh1jhj-ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM(hhhhubh)}(hThis structure describes a bitrate that an 802.11 PHY can operate with. The two values **hw_value** and **hw_value_short** are only for driver use when pointers to this structure are passed around.h](hWThis structure describes a bitrate that an 802.11 PHY can operate with. The two values }(hjhhhNhNubj)}(h **hw_value**h]hhw_value}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh and }(hjhhhNhNubj)}(h**hw_value_short**h]hhw_value_short}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubhK are only for driver use when pointers to this structure are passed around.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhhhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ieee80211_sta_ht_cap (C struct)c.ieee80211_sta_ht_caphNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hieee80211_sta_ht_caph]jo)}(hstruct ieee80211_sta_ht_caph](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM"ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM"ubj)}(hieee80211_sta_ht_caph]j)}(hjh]hieee80211_sta_ht_cap}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM"ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM"ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM"hjhhubj)}(hhh]h)}(hSTA's HT capabilitiesh]hSTA’s HT capabilities}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMQhj+hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM"ubeh}(h]h ](j$structeh"]h$]h&]jj$jjFjjFjjjuh1jchhhhhNhNubj)}(hX**Definition**:: struct ieee80211_sta_ht_cap { u16 cap; bool ht_supported; u8 ampdu_factor; u8 ampdu_density; struct ieee80211_mcs_info mcs; }; **Members** ``cap`` HT capabilities map as described in 802.11n spec ``ht_supported`` is HT supported by the STA ``ampdu_factor`` Maximum A-MPDU length factor ``ampdu_density`` Minimum A-MPDU spacing ``mcs`` Supported MCS ratesh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjNubh:}(hjNhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMUhjJubj( )}(hstruct ieee80211_sta_ht_cap { u16 cap; bool ht_supported; u8 ampdu_factor; u8 ampdu_density; struct ieee80211_mcs_info mcs; };h]hstruct ieee80211_sta_ht_cap { u16 cap; bool ht_supported; u8 ampdu_factor; u8 ampdu_density; struct ieee80211_mcs_info mcs; };}hjksbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMWhjJubh)}(h **Members**h]j)}(hj|h]hMembers}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM_hjJubj)}(hhh](j)}(h9``cap`` HT capabilities map as described in 802.11n spec h](j)}(h``cap``h]j)}(hjh]hcap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMXhjubj6)}(hhh]h)}(h0HT capabilities map as described in 802.11n spech]h0HT capabilities map as described in 802.11n spec}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMXhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMXhjubj)}(h,``ht_supported`` is HT supported by the STA h](j)}(h``ht_supported``h]j)}(hjh]h ht_supported}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMWhjubj6)}(hhh]h)}(his HT supported by the STAh]his HT supported by the STA}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMWhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMWhjubj)}(h.``ampdu_factor`` Maximum A-MPDU length factor h](j)}(h``ampdu_factor``h]j)}(hj h]h ampdu_factor}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMYhjubj6)}(hhh]h)}(hMaximum A-MPDU length factorh]hMaximum A-MPDU length factor}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hMYhj#ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj"hMYhjubj)}(h)``ampdu_density`` Minimum A-MPDU spacing h](j)}(h``ampdu_density``h]j)}(hjFh]h ampdu_density}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMZhj@ubj6)}(hhh]h)}(hMinimum A-MPDU spacingh]hMinimum A-MPDU spacing}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hMZhj\ubah}(h]h ]h"]h$]h&]uh1j5hj@ubeh}(h]h ]h"]h$]h&]uh1jhj[hMZhjubj)}(h``mcs`` Supported MCS ratesh](j)}(h``mcs``h]j)}(hjh]hmcs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMZhjyubj6)}(hhh]h)}(hSupported MCS ratesh]hSupported MCS rates}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM[hjubah}(h]h ]h"]h$]h&]uh1j5hjyubeh}(h]h ]h"]h$]h&]uh1jhjhMZhjubeh}(h]h ]h"]h$]h&]uh1jhjJubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM^hhhhubh)}(hiThis structure describes most essential parameters needed to describe 802.11n HT capabilities for an STA.h]hiThis structure describes most essential parameters needed to describe 802.11n HT capabilities for an STA.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMRhhhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_#ieee80211_supported_band (C struct)c.ieee80211_supported_bandhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hieee80211_supported_bandh]jo)}(hstruct ieee80211_supported_bandh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMXubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhj hMXubj)}(hieee80211_supported_bandh]j)}(hjh]hieee80211_supported_band}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhj hMXubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhj hMXubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhj hMXhjhhubj)}(hhh]h)}(hfrequency band definitionh]hfrequency band definition}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM"hj?hhubah}(h]h ]h"]h$]h&]uh1jhjhhhj hMXubeh}(h]h ](j$structeh"]h$]h&]jj$jjZjjZjjjuh1jchhhhhNhNubj)}(hXS**Definition**:: struct ieee80211_supported_band { struct ieee80211_channel *channels; struct ieee80211_rate *bitrates; enum nl80211_band band; int n_channels; int n_bitrates; struct ieee80211_sta_ht_cap ht_cap; struct ieee80211_sta_vht_cap vht_cap; struct ieee80211_sta_s1g_cap s1g_cap; struct ieee80211_edmg edmg_cap; u16 n_iftype_data; const struct ieee80211_sband_iftype_data __iftd *iftype_data; }; **Members** ``channels`` Array of channels the hardware can operate with in this band. ``bitrates`` Array of bitrates the hardware can operate with in this band. Must be sorted to give a valid "supported rates" IE, i.e. CCK rates first, then OFDM. ``band`` the band this structure represents ``n_channels`` Number of channels in **channels** ``n_bitrates`` Number of bitrates in **bitrates** ``ht_cap`` HT capabilities in this band ``vht_cap`` VHT capabilities in this band ``s1g_cap`` S1G capabilities in this band (S1G band only, of course) ``edmg_cap`` EDMG capabilities in this band ``n_iftype_data`` number of iftype data entries ``iftype_data`` interface type data entries. Note that the bits in **types_mask** inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_data).h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbubh:}(hjbhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM&hj^ubj( )}(hXstruct ieee80211_supported_band { struct ieee80211_channel *channels; struct ieee80211_rate *bitrates; enum nl80211_band band; int n_channels; int n_bitrates; struct ieee80211_sta_ht_cap ht_cap; struct ieee80211_sta_vht_cap vht_cap; struct ieee80211_sta_s1g_cap s1g_cap; struct ieee80211_edmg edmg_cap; u16 n_iftype_data; const struct ieee80211_sband_iftype_data __iftd *iftype_data; };h]hXstruct ieee80211_supported_band { struct ieee80211_channel *channels; struct ieee80211_rate *bitrates; enum nl80211_band band; int n_channels; int n_bitrates; struct ieee80211_sta_ht_cap ht_cap; struct ieee80211_sta_vht_cap vht_cap; struct ieee80211_sta_s1g_cap s1g_cap; struct ieee80211_edmg edmg_cap; u16 n_iftype_data; const struct ieee80211_sband_iftype_data __iftd *iftype_data; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM(hj^ubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM6hj^ubj)}(hhh](j)}(hK``channels`` Array of channels the hardware can operate with in this band. h](j)}(h ``channels``h]j)}(hjh]hchannels}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM)hjubj6)}(hhh]h)}(h=Array of channels the hardware can operate with in this band.h]h=Array of channels the hardware can operate with in this band.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM(hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM)hjubj)}(h``bitrates`` Array of bitrates the hardware can operate with in this band. Must be sorted to give a valid "supported rates" IE, i.e. CCK rates first, then OFDM. h](j)}(h ``bitrates``h]j)}(hjh]hbitrates}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM.hjubj6)}(hhh]h)}(hArray of bitrates the hardware can operate with in this band. Must be sorted to give a valid "supported rates" IE, i.e. CCK rates first, then OFDM.h]hArray of bitrates the hardware can operate with in this band. Must be sorted to give a valid “supported rates” IE, i.e. CCK rates first, then OFDM.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM,hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM.hjubj)}(h,``band`` the band this structure represents h](j)}(h``band``h]j)}(hj#h]hband}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM*hjubj6)}(hhh]h)}(h"the band this structure representsh]h"the band this structure represents}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8hM*hj9ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj8hM*hjubj)}(h2``n_channels`` Number of channels in **channels** h](j)}(h``n_channels``h]j)}(hj\h]h n_channels}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM+hjVubj6)}(hhh]h)}(h"Number of channels in **channels**h](hNumber of channels in }(hjuhhhNhNubj)}(h **channels**h]hchannels}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuubeh}(h]h ]h"]h$]h&]uh1hhjqhM+hjrubah}(h]h ]h"]h$]h&]uh1j5hjVubeh}(h]h ]h"]h$]h&]uh1jhjqhM+hjubj)}(h2``n_bitrates`` Number of bitrates in **bitrates** h](j)}(h``n_bitrates``h]j)}(hjh]h n_bitrates}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM/hjubj6)}(hhh]h)}(h"Number of bitrates in **bitrates**h](hNumber of bitrates in }(hjhhhNhNubj)}(h **bitrates**h]hbitrates}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubeh}(h]h ]h"]h$]h&]uh1hhjhM/hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM/hjubj)}(h(``ht_cap`` HT capabilities in this band h](j)}(h ``ht_cap``h]j)}(hjh]hht_cap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM0hjubj6)}(hhh]h)}(hHT capabilities in this bandh]hHT capabilities in this band}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM0hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM0hjubj)}(h*``vht_cap`` VHT capabilities in this band h](j)}(h ``vht_cap``h]j)}(hj#h]hvht_cap}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM1hjubj6)}(hhh]h)}(hVHT capabilities in this bandh]hVHT capabilities in this band}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8hM1hj9ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj8hM1hjubj)}(hE``s1g_cap`` S1G capabilities in this band (S1G band only, of course) h](j)}(h ``s1g_cap``h]j)}(hj\h]hs1g_cap}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM4hjVubj6)}(hhh]h)}(h8S1G capabilities in this band (S1G band only, of course)h]h8S1G capabilities in this band (S1G band only, of course)}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjqhM4hjrubah}(h]h ]h"]h$]h&]uh1j5hjVubeh}(h]h ]h"]h$]h&]uh1jhjqhM4hjubj)}(h,``edmg_cap`` EDMG capabilities in this band h](j)}(h ``edmg_cap``h]j)}(hjh]hedmg_cap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM3hjubj6)}(hhh]h)}(hEDMG capabilities in this bandh]hEDMG capabilities in this band}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM3hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM3hjubj)}(h0``n_iftype_data`` number of iftype data entries h](j)}(h``n_iftype_data``h]j)}(hjh]h n_iftype_data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM5hjubj6)}(hhh]h)}(hnumber of iftype data entriesh]hnumber of iftype data entries}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM5hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM5hjubj)}(h``iftype_data`` interface type data entries. Note that the bits in **types_mask** inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_data).h](j)}(h``iftype_data``h]j)}(hjh]h iftype_data}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM8hjubj6)}(hhh]h)}(hinterface type data entries. Note that the bits in **types_mask** inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_data).h](h4interface type data entries. Note that the bits in }(hj hhhNhNubj)}(h**types_mask**h]h types_mask}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubh} inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_data).}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM6hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM8hjubeh}(h]h ]h"]h$]h&]uh1jhj^ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hj\h]h Description}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM<hhhhubh)}(hHThis structure describes a frequency band a wiphy is able to operate in.h]hHThis structure describes a frequency band a wiphy is able to operate in.}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM#hhhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_&wiphy_read_of_freq_limits (C function)c.wiphy_read_of_freq_limitshNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(h4void wiphy_read_of_freq_limits (struct wiphy *wiphy)h]jo)}(h3void wiphy_read_of_freq_limits(struct wiphy *wiphy)h](hdesc_sig_keyword_type)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]ktah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubj)}(hwiphy_read_of_freq_limitsh]j)}(hwiphy_read_of_freq_limitsh]hwiphy_read_of_freq_limits}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMubhdesc_parameterlist)}(h(struct wiphy *wiphy)h]hdesc_parameter)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftype identifier reftargetjmodnameN classnameNj j )}j ]j ASTIdentifier)}jjsbc.wiphy_read_of_freq_limitsasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubhdesc_sig_punctuation)}(h*h]h*}(hj/hhhNhNubah}(h]h ]pah"]h$]h&]uh1j-hjubj)}(hwiphyh]hwiphy}(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMhjhhubj)}(hhh]h)}(h&read frequency limits from device treeh]h&read frequency limits from device tree}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjehhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhhhNhNubj)}(hX:**Parameters** ``struct wiphy *wiphy`` the wireless device to get extra limits for **Description** Some devices may have extra limitations specified in DT. This may be useful for chipsets that normally support more bands but are limited due to board design (e.g. by antennas or external power amplifier). This function reads info from DT and uses it to *modify* channels (disable unavailable ones). It's usually a *bad* idea to use it in drivers with shared channel data as DT limitations are device specific. You should make sure to call it only if channels in wiphy are copied and can be modified without affecting other devices. As this function access device node it has to be called after set_wiphy_dev. It also modifies channels so they have to be set first. If using this helper, call it before wiphy_register().h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj)}(hhh]j)}(hD``struct wiphy *wiphy`` the wireless device to get extra limits for h](j)}(h``struct wiphy *wiphy``h]j)}(hjh]hstruct wiphy *wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h+the wireless device to get extra limits forh]h+the wireless device to get extra limits for}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubh)}(hSome devices may have extra limitations specified in DT. This may be useful for chipsets that normally support more bands but are limited due to board design (e.g. by antennas or external power amplifier).h]hSome devices may have extra limitations specified in DT. This may be useful for chipsets that normally support more bands but are limited due to board design (e.g. by antennas or external power amplifier).}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubh)}(hXFThis function reads info from DT and uses it to *modify* channels (disable unavailable ones). It's usually a *bad* idea to use it in drivers with shared channel data as DT limitations are device specific. You should make sure to call it only if channels in wiphy are copied and can be modified without affecting other devices.h](h0This function reads info from DT and uses it to }(hj hhhNhNubhemphasis)}(h*modify*h]hmodify}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh7 channels (disable unavailable ones). It’s usually a }(hj hhhNhNubj)}(h*bad*h]hbad}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh idea to use it in drivers with shared channel data as DT limitations are device specific. You should make sure to call it only if channels in wiphy are copied and can be modified without affecting other devices.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubh)}(hAs this function access device node it has to be called after set_wiphy_dev. It also modifies channels so they have to be set first. If using this helper, call it before wiphy_register().h]hAs this function access device node it has to be called after set_wiphy_dev. It also modifies channels so they have to be set first. If using this helper, call it before wiphy_register().}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_signal_type (C enum)c.cfg80211_signal_typehNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hcfg80211_signal_typeh]jo)}(henum cfg80211_signal_typeh](ju)}(hjxh]henum}(hjmhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjihhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjihhhjzhMubj)}(hcfg80211_signal_typeh]j)}(hjgh]hcfg80211_signal_type}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjihhhjzhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjehhhjzhMubah}(h]j`ah ](jjeh"]h$]h&]jj)jhuh1jhhjzhMhjbhhubj)}(hhh]h)}(h signal typeh]h signal type}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhjbhhhjzhMubeh}(h]h ](j$enumeh"]h$]h&]jj$jjjjjjjuh1jchhhhhNhNubj)}(h**Constants** ``CFG80211_SIGNAL_TYPE_NONE`` no signal strength information available ``CFG80211_SIGNAL_TYPE_MBM`` signal strength in mBm (100*dBm) ``CFG80211_SIGNAL_TYPE_UNSPEC`` signal strength, increasing from 0 through 100h](h)}(h **Constants**h]j)}(hjh]h Constants}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubj)}(hhh](j)}(hG``CFG80211_SIGNAL_TYPE_NONE`` no signal strength information available h](j)}(h``CFG80211_SIGNAL_TYPE_NONE``h]j)}(hjh]hCFG80211_SIGNAL_TYPE_NONE}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h(no signal strength information availableh]h(no signal strength information available}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h>``CFG80211_SIGNAL_TYPE_MBM`` signal strength in mBm (100*dBm) h](j)}(h``CFG80211_SIGNAL_TYPE_MBM``h]j)}(hj)h]hCFG80211_SIGNAL_TYPE_MBM}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj#ubj6)}(hhh]h)}(h signal strength in mBm (100*dBm)h]h signal strength in mBm (100*dBm)}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hM hj?ubah}(h]h ]h"]h$]h&]uh1j5hj#ubeh}(h]h ]h"]h$]h&]uh1jhj>hM hjubj)}(hN``CFG80211_SIGNAL_TYPE_UNSPEC`` signal strength, increasing from 0 through 100h](j)}(h``CFG80211_SIGNAL_TYPE_UNSPEC``h]j)}(hjbh]hCFG80211_SIGNAL_TYPE_UNSPEC}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj\ubj6)}(hhh]h)}(h.signal strength, increasing from 0 through 100h]h.signal strength, increasing from 0 through 100}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjxubah}(h]h ]h"]h$]h&]uh1j5hj\ubeh}(h]h ]h"]h$]h&]uh1jhjwhM hjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wiphy_params_flags (C enum)c.wiphy_params_flagshNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hwiphy_params_flagsh]jo)}(henum wiphy_params_flagsh](ju)}(hjxh]henum}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(hwiphy_params_flagsh]j)}(hjh]hwiphy_params_flags}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM hjhhubj)}(hhh]h)}(h set_wiphy_params bitfield valuesh]h set_wiphy_params bitfield values}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j$enumeh"]h$]h&]jj$jjjjjjjuh1jchhhhhNhNubj)}(hX3**Constants** ``WIPHY_PARAM_RETRY_SHORT`` wiphy->retry_short has changed ``WIPHY_PARAM_RETRY_LONG`` wiphy->retry_long has changed ``WIPHY_PARAM_FRAG_THRESHOLD`` wiphy->frag_threshold has changed ``WIPHY_PARAM_RTS_THRESHOLD`` wiphy->rts_threshold has changed ``WIPHY_PARAM_COVERAGE_CLASS`` coverage class changed ``WIPHY_PARAM_DYN_ACK`` dynack has been enabled ``WIPHY_PARAM_TXQ_LIMIT`` TXQ packet limit has been changed ``WIPHY_PARAM_TXQ_MEMORY_LIMIT`` TXQ memory limit has been changed ``WIPHY_PARAM_TXQ_QUANTUM`` TXQ scheduler quantumh](h)}(h **Constants**h]j)}(hj h]h Constants}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubj)}(hhh](j)}(h;``WIPHY_PARAM_RETRY_SHORT`` wiphy->retry_short has changed h](j)}(h``WIPHY_PARAM_RETRY_SHORT``h]j)}(hj?h]hWIPHY_PARAM_RETRY_SHORT}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj9ubj6)}(hhh]h)}(hwiphy->retry_short has changedh]hwiphy->retry_short has changed}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjThM hjUubah}(h]h ]h"]h$]h&]uh1j5hj9ubeh}(h]h ]h"]h$]h&]uh1jhjThM hj6ubj)}(h9``WIPHY_PARAM_RETRY_LONG`` wiphy->retry_long has changed h](j)}(h``WIPHY_PARAM_RETRY_LONG``h]j)}(hjxh]hWIPHY_PARAM_RETRY_LONG}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjrubj6)}(hhh]h)}(hwiphy->retry_long has changedh]hwiphy->retry_long has changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjrubeh}(h]h ]h"]h$]h&]uh1jhjhM hj6ubj)}(hA``WIPHY_PARAM_FRAG_THRESHOLD`` wiphy->frag_threshold has changed h](j)}(h``WIPHY_PARAM_FRAG_THRESHOLD``h]j)}(hjh]hWIPHY_PARAM_FRAG_THRESHOLD}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h!wiphy->frag_threshold has changedh]h!wiphy->frag_threshold has changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj6ubj)}(h?``WIPHY_PARAM_RTS_THRESHOLD`` wiphy->rts_threshold has changed h](j)}(h``WIPHY_PARAM_RTS_THRESHOLD``h]j)}(hjh]hWIPHY_PARAM_RTS_THRESHOLD}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h wiphy->rts_threshold has changedh]h wiphy->rts_threshold has changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj6ubj)}(h6``WIPHY_PARAM_COVERAGE_CLASS`` coverage class changed h](j)}(h``WIPHY_PARAM_COVERAGE_CLASS``h]j)}(hj#h]hWIPHY_PARAM_COVERAGE_CLASS}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hcoverage class changedh]hcoverage class changed}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8hM hj9ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj8hM hj6ubj)}(h0``WIPHY_PARAM_DYN_ACK`` dynack has been enabled h](j)}(h``WIPHY_PARAM_DYN_ACK``h]j)}(hj\h]hWIPHY_PARAM_DYN_ACK}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjVubj6)}(hhh]h)}(hdynack has been enabledh]hdynack has been enabled}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjqhM hjrubah}(h]h ]h"]h$]h&]uh1j5hjVubeh}(h]h ]h"]h$]h&]uh1jhjqhM hj6ubj)}(h<``WIPHY_PARAM_TXQ_LIMIT`` TXQ packet limit has been changed h](j)}(h``WIPHY_PARAM_TXQ_LIMIT``h]j)}(hjh]hWIPHY_PARAM_TXQ_LIMIT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h!TXQ packet limit has been changedh]h!TXQ packet limit has been changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj6ubj)}(hC``WIPHY_PARAM_TXQ_MEMORY_LIMIT`` TXQ memory limit has been changed h](j)}(h ``WIPHY_PARAM_TXQ_MEMORY_LIMIT``h]j)}(hjh]hWIPHY_PARAM_TXQ_MEMORY_LIMIT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h!TXQ memory limit has been changedh]h!TXQ memory limit has been changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj6ubj)}(h1``WIPHY_PARAM_TXQ_QUANTUM`` TXQ scheduler quantumh](j)}(h``WIPHY_PARAM_TXQ_QUANTUM``h]j)}(hjh]hWIPHY_PARAM_TXQ_QUANTUM}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hTXQ scheduler quantumh]hTXQ scheduler quantum}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj6ubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wiphy_flags (C enum) c.wiphy_flagshNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(h wiphy_flagsh]jo)}(henum wiphy_flagsh](ju)}(hjxh]henum}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj]hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]hhhjnhM ubj)}(h wiphy_flagsh]j)}(hj[h]h wiphy_flags}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj]hhhjnhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjYhhhjnhM ubah}(h]jTah ](jjeh"]h$]h&]jj)jhuh1jhhjnhM hjVhhubj)}(hhh]h)}(hwiphy capability flagsh]hwiphy capability flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjVhhhjnhM ubeh}(h]h ](j$enumeh"]h$]h&]jj$jjjjjjjuh1jchhhhhNhNubj)}(hX **Constants** ``WIPHY_FLAG_SUPPORTS_EXT_KEK_KCK`` The device supports bigger kek and kck keys ``WIPHY_FLAG_SUPPORTS_MLO`` This is a temporary flag gating the MLO APIs, in order to not have them reachable in normal drivers, until we have complete feature/interface combinations/etc. advertisement. No driver should set this flag for now. ``WIPHY_FLAG_SPLIT_SCAN_6GHZ`` if set to true, the scan request will be split into two, first for legacy bands and second for 6 GHz. ``WIPHY_FLAG_NETNS_OK`` if not set, do not allow changing the netns of this wiphy at all ``WIPHY_FLAG_PS_ON_BY_DEFAULT`` if set to true, powersave will be enabled by default -- this flag will be set depending on the kernel's default on wiphy_new(), but can be changed by the driver if it has a good reason to override the default ``WIPHY_FLAG_4ADDR_AP`` supports 4addr mode even on AP (with a single station on a VLAN interface). This flag also serves an extra purpose of supporting 4ADDR AP mode on devices which do not support AP/VLAN iftype. ``WIPHY_FLAG_4ADDR_STATION`` supports 4addr mode even as a station ``WIPHY_FLAG_CONTROL_PORT_PROTOCOL`` This device supports setting the control port protocol ethertype. The device also honours the control_port_no_encrypt flag. ``WIPHY_FLAG_IBSS_RSN`` The device supports IBSS RSN. ``WIPHY_FLAG_DISABLE_WEXT`` disable wireless extensions for this device ``WIPHY_FLAG_MESH_AUTH`` The device supports mesh authentication by routing auth frames to userspace. See **NL80211_MESH_SETUP_USERSPACE_AUTH**. ``WIPHY_FLAG_SUPPORTS_EXT_KCK_32`` The device supports 32-byte KCK keys. ``WIPHY_FLAG_SUPPORTS_NSTR_NONPRIMARY`` support connection to non-primary link of an NSTR mobile AP MLD. ``WIPHY_FLAG_SUPPORTS_FW_ROAM`` The device supports roaming feature in the firmware. ``WIPHY_FLAG_AP_UAPSD`` The device supports uapsd on AP. ``WIPHY_FLAG_SUPPORTS_TDLS`` The device supports TDLS (802.11z) operation. ``WIPHY_FLAG_TDLS_EXTERNAL_SETUP`` The device does not handle TDLS (802.11z) link setup/discovery operations internally. Setup, discovery and teardown packets should be sent through the **NL80211_CMD_TDLS_MGMT** command. When this flag is not set, **NL80211_CMD_TDLS_OPER** should be used for asking the driver/firmware to perform a TDLS operation. ``WIPHY_FLAG_HAVE_AP_SME`` device integrates AP SME ``WIPHY_FLAG_REPORTS_OBSS`` the device will report beacons from other BSSes when there are virtual interfaces in AP mode by calling cfg80211_report_obss_beacon(). ``WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD`` When operating as an AP, the device responds to probe-requests in hardware. ``WIPHY_FLAG_OFFCHAN_TX`` Device supports direct off-channel TX. ``WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL`` Device supports remain-on-channel call. ``WIPHY_FLAG_SUPPORTS_5_10_MHZ`` Device supports 5 MHz and 10 MHz channels. ``WIPHY_FLAG_HAS_CHANNEL_SWITCH`` Device supports channel switch in beaconing mode (AP, IBSS, Mesh, ...). ``WIPHY_FLAG_NOTIFY_REGDOM_BY_DRIVER`` The device could handle reg notify for NL80211_REGDOM_SET_BY_DRIVER. ``WIPHY_FLAG_CHANNEL_CHANGE_ON_BEACON`` reg_call_notifier() is called if driver set this flag to update channels on beacon hints.h](h)}(h **Constants**h]j)}(hjh]h Constants}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj)}(hhh](j)}(hP``WIPHY_FLAG_SUPPORTS_EXT_KEK_KCK`` The device supports bigger kek and kck keys h](j)}(h#``WIPHY_FLAG_SUPPORTS_EXT_KEK_KCK``h]j)}(hjh]hWIPHY_FLAG_SUPPORTS_EXT_KEK_KCK}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h+The device supports bigger kek and kck keysh]h+The device supports bigger kek and kck keys}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``WIPHY_FLAG_SUPPORTS_MLO`` This is a temporary flag gating the MLO APIs, in order to not have them reachable in normal drivers, until we have complete feature/interface combinations/etc. advertisement. No driver should set this flag for now. h](j)}(h``WIPHY_FLAG_SUPPORTS_MLO``h]j)}(hjh]hWIPHY_FLAG_SUPPORTS_MLO}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hThis is a temporary flag gating the MLO APIs, in order to not have them reachable in normal drivers, until we have complete feature/interface combinations/etc. advertisement. No driver should set this flag for now.h]hThis is a temporary flag gating the MLO APIs, in order to not have them reachable in normal drivers, until we have complete feature/interface combinations/etc. advertisement. No driver should set this flag for now.}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj3ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj2hM hjubj)}(h``WIPHY_FLAG_SPLIT_SCAN_6GHZ`` if set to true, the scan request will be split into two, first for legacy bands and second for 6 GHz. h](j)}(h``WIPHY_FLAG_SPLIT_SCAN_6GHZ``h]j)}(hjWh]hWIPHY_FLAG_SPLIT_SCAN_6GHZ}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjQubj6)}(hhh]h)}(heif set to true, the scan request will be split into two, first for legacy bands and second for 6 GHz.h]heif set to true, the scan request will be split into two, first for legacy bands and second for 6 GHz.}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjmubah}(h]h ]h"]h$]h&]uh1j5hjQubeh}(h]h ]h"]h$]h&]uh1jhjlhMhjubj)}(hY``WIPHY_FLAG_NETNS_OK`` if not set, do not allow changing the netns of this wiphy at all h](j)}(h``WIPHY_FLAG_NETNS_OK``h]j)}(hjh]hWIPHY_FLAG_NETNS_OK}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h@if not set, do not allow changing the netns of this wiphy at allh]h@if not set, do not allow changing the netns of this wiphy at all}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``WIPHY_FLAG_PS_ON_BY_DEFAULT`` if set to true, powersave will be enabled by default -- this flag will be set depending on the kernel's default on wiphy_new(), but can be changed by the driver if it has a good reason to override the default h](j)}(h``WIPHY_FLAG_PS_ON_BY_DEFAULT``h]j)}(hjh]hWIPHY_FLAG_PS_ON_BY_DEFAULT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hif set to true, powersave will be enabled by default -- this flag will be set depending on the kernel's default on wiphy_new(), but can be changed by the driver if it has a good reason to override the defaulth]hif set to true, powersave will be enabled by default -- this flag will be set depending on the kernel’s default on wiphy_new(), but can be changed by the driver if it has a good reason to override the default}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``WIPHY_FLAG_4ADDR_AP`` supports 4addr mode even on AP (with a single station on a VLAN interface). This flag also serves an extra purpose of supporting 4ADDR AP mode on devices which do not support AP/VLAN iftype. h](j)}(h``WIPHY_FLAG_4ADDR_AP``h]j)}(hjh]hWIPHY_FLAG_4ADDR_AP}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hsupports 4addr mode even on AP (with a single station on a VLAN interface). This flag also serves an extra purpose of supporting 4ADDR AP mode on devices which do not support AP/VLAN iftype.h]hsupports 4addr mode even on AP (with a single station on a VLAN interface). This flag also serves an extra purpose of supporting 4ADDR AP mode on devices which do not support AP/VLAN iftype.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hC``WIPHY_FLAG_4ADDR_STATION`` supports 4addr mode even as a station h](j)}(h``WIPHY_FLAG_4ADDR_STATION``h]j)}(hj?h]hWIPHY_FLAG_4ADDR_STATION}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM!hj9ubj6)}(hhh]h)}(h%supports 4addr mode even as a stationh]h%supports 4addr mode even as a station}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjThM!hjUubah}(h]h ]h"]h$]h&]uh1j5hj9ubeh}(h]h ]h"]h$]h&]uh1jhjThM!hjubj)}(h``WIPHY_FLAG_CONTROL_PORT_PROTOCOL`` This device supports setting the control port protocol ethertype. The device also honours the control_port_no_encrypt flag. h](j)}(h$``WIPHY_FLAG_CONTROL_PORT_PROTOCOL``h]j)}(hjxh]h WIPHY_FLAG_CONTROL_PORT_PROTOCOL}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM&hjrubj6)}(hhh]h)}(h{This device supports setting the control port protocol ethertype. The device also honours the control_port_no_encrypt flag.h]h{This device supports setting the control port protocol ethertype. The device also honours the control_port_no_encrypt flag.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM$hjubah}(h]h ]h"]h$]h&]uh1j5hjrubeh}(h]h ]h"]h$]h&]uh1jhjhM&hjubj)}(h6``WIPHY_FLAG_IBSS_RSN`` The device supports IBSS RSN. h](j)}(h``WIPHY_FLAG_IBSS_RSN``h]j)}(hjh]hWIPHY_FLAG_IBSS_RSN}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM)hjubj6)}(hhh]h)}(hThe device supports IBSS RSN.h]hThe device supports IBSS RSN.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM)hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM)hjubj)}(hH``WIPHY_FLAG_DISABLE_WEXT`` disable wireless extensions for this device h](j)}(h``WIPHY_FLAG_DISABLE_WEXT``h]j)}(hjh]hWIPHY_FLAG_DISABLE_WEXT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM,hjubj6)}(hhh]h)}(h+disable wireless extensions for this deviceh]h+disable wireless extensions for this device}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM,hj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hM,hjubj)}(h``WIPHY_FLAG_MESH_AUTH`` The device supports mesh authentication by routing auth frames to userspace. See **NL80211_MESH_SETUP_USERSPACE_AUTH**. h](j)}(h``WIPHY_FLAG_MESH_AUTH``h]j)}(hj$ h]hWIPHY_FLAG_MESH_AUTH}(hj& hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj" ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM0hj ubj6)}(hhh]h)}(hwThe device supports mesh authentication by routing auth frames to userspace. See **NL80211_MESH_SETUP_USERSPACE_AUTH**.h](hQThe device supports mesh authentication by routing auth frames to userspace. See }(hj= hhhNhNubj)}(h%**NL80211_MESH_SETUP_USERSPACE_AUTH**h]h!NL80211_MESH_SETUP_USERSPACE_AUTH}(hjE hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj= ubh.}(hj= hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM/hj: ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj9 hM0hjubj)}(hI``WIPHY_FLAG_SUPPORTS_EXT_KCK_32`` The device supports 32-byte KCK keys. h](j)}(h"``WIPHY_FLAG_SUPPORTS_EXT_KCK_32``h]j)}(hjp h]hWIPHY_FLAG_SUPPORTS_EXT_KCK_32}(hjr hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjn ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM3hjj ubj6)}(hhh]h)}(h%The device supports 32-byte KCK keys.h]h%The device supports 32-byte KCK keys.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM3hj ubah}(h]h ]h"]h$]h&]uh1j5hjj ubeh}(h]h ]h"]h$]h&]uh1jhj hM3hjubj)}(hi``WIPHY_FLAG_SUPPORTS_NSTR_NONPRIMARY`` support connection to non-primary link of an NSTR mobile AP MLD. h](j)}(h'``WIPHY_FLAG_SUPPORTS_NSTR_NONPRIMARY``h]j)}(hj h]h#WIPHY_FLAG_SUPPORTS_NSTR_NONPRIMARY}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM7hj ubj6)}(hhh]h)}(h@support connection to non-primary link of an NSTR mobile AP MLD.h]h@support connection to non-primary link of an NSTR mobile AP MLD.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM6hj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hM7hjubj)}(hU``WIPHY_FLAG_SUPPORTS_FW_ROAM`` The device supports roaming feature in the firmware. h](j)}(h``WIPHY_FLAG_SUPPORTS_FW_ROAM``h]j)}(hj h]hWIPHY_FLAG_SUPPORTS_FW_ROAM}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM;hj ubj6)}(hhh]h)}(h4The device supports roaming feature in the firmware.h]h4The device supports roaming feature in the firmware.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM:hj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hM;hjubj)}(h9``WIPHY_FLAG_AP_UAPSD`` The device supports uapsd on AP. h](j)}(h``WIPHY_FLAG_AP_UAPSD``h]j)}(hj!h]hWIPHY_FLAG_AP_UAPSD}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM>hj!ubj6)}(hhh]h)}(h The device supports uapsd on AP.h]h The device supports uapsd on AP.}(hj6!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2!hM>hj3!ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj2!hM>hjubj)}(hK``WIPHY_FLAG_SUPPORTS_TDLS`` The device supports TDLS (802.11z) operation. h](j)}(h``WIPHY_FLAG_SUPPORTS_TDLS``h]j)}(hjV!h]hWIPHY_FLAG_SUPPORTS_TDLS}(hjX!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjT!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMAhjP!ubj6)}(hhh]h)}(h-The device supports TDLS (802.11z) operation.h]h-The device supports TDLS (802.11z) operation.}(hjo!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjk!hMAhjl!ubah}(h]h ]h"]h$]h&]uh1j5hjP!ubeh}(h]h ]h"]h$]h&]uh1jhjk!hMAhjubj)}(hX]``WIPHY_FLAG_TDLS_EXTERNAL_SETUP`` The device does not handle TDLS (802.11z) link setup/discovery operations internally. Setup, discovery and teardown packets should be sent through the **NL80211_CMD_TDLS_MGMT** command. When this flag is not set, **NL80211_CMD_TDLS_OPER** should be used for asking the driver/firmware to perform a TDLS operation. h](j)}(h"``WIPHY_FLAG_TDLS_EXTERNAL_SETUP``h]j)}(hj!h]hWIPHY_FLAG_TDLS_EXTERNAL_SETUP}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMHhj!ubj6)}(hhh]h)}(hX9The device does not handle TDLS (802.11z) link setup/discovery operations internally. Setup, discovery and teardown packets should be sent through the **NL80211_CMD_TDLS_MGMT** command. When this flag is not set, **NL80211_CMD_TDLS_OPER** should be used for asking the driver/firmware to perform a TDLS operation.h](hThe device does not handle TDLS (802.11z) link setup/discovery operations internally. Setup, discovery and teardown packets should be sent through the }(hj!hhhNhNubj)}(h**NL80211_CMD_TDLS_MGMT**h]hNL80211_CMD_TDLS_MGMT}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!ubh% command. When this flag is not set, }(hj!hhhNhNubj)}(h**NL80211_CMD_TDLS_OPER**h]hNL80211_CMD_TDLS_OPER}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!ubhK should be used for asking the driver/firmware to perform a TDLS operation.}(hj!hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMDhj!ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj!hMHhjubj)}(h4``WIPHY_FLAG_HAVE_AP_SME`` device integrates AP SME h](j)}(h``WIPHY_FLAG_HAVE_AP_SME``h]j)}(hj!h]hWIPHY_FLAG_HAVE_AP_SME}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMKhj!ubj6)}(hhh]h)}(hdevice integrates AP SMEh]hdevice integrates AP SME}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hMKhj"ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj"hMKhjubj)}(h``WIPHY_FLAG_REPORTS_OBSS`` the device will report beacons from other BSSes when there are virtual interfaces in AP mode by calling cfg80211_report_obss_beacon(). h](j)}(h``WIPHY_FLAG_REPORTS_OBSS``h]j)}(hj&"h]hWIPHY_FLAG_REPORTS_OBSS}(hj("hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$"ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMPhj "ubj6)}(hhh]h)}(hthe device will report beacons from other BSSes when there are virtual interfaces in AP mode by calling cfg80211_report_obss_beacon().h]hthe device will report beacons from other BSSes when there are virtual interfaces in AP mode by calling cfg80211_report_obss_beacon().}(hj?"hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMNhj<"ubah}(h]h ]h"]h$]h&]uh1j5hj "ubeh}(h]h ]h"]h$]h&]uh1jhj;"hMPhjubj)}(hq``WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD`` When operating as an AP, the device responds to probe-requests in hardware. h](j)}(h$``WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD``h]j)}(hj`"h]h WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD}(hjb"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^"ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMThjZ"ubj6)}(hhh]h)}(hKWhen operating as an AP, the device responds to probe-requests in hardware.h]hKWhen operating as an AP, the device responds to probe-requests in hardware.}(hjy"hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMShjv"ubah}(h]h ]h"]h$]h&]uh1j5hjZ"ubeh}(h]h ]h"]h$]h&]uh1jhju"hMThjubj)}(hA``WIPHY_FLAG_OFFCHAN_TX`` Device supports direct off-channel TX. h](j)}(h``WIPHY_FLAG_OFFCHAN_TX``h]j)}(hj"h]hWIPHY_FLAG_OFFCHAN_TX}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMWhj"ubj6)}(hhh]h)}(h&Device supports direct off-channel TX.h]h&Device supports direct off-channel TX.}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hMWhj"ubah}(h]h ]h"]h$]h&]uh1j5hj"ubeh}(h]h ]h"]h$]h&]uh1jhj"hMWhjubj)}(hM``WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL`` Device supports remain-on-channel call. h](j)}(h$``WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL``h]j)}(hj"h]h WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMZhj"ubj6)}(hhh]h)}(h'Device supports remain-on-channel call.h]h'Device supports remain-on-channel call.}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hMZhj"ubah}(h]h ]h"]h$]h&]uh1j5hj"ubeh}(h]h ]h"]h$]h&]uh1jhj"hMZhjubj)}(hL``WIPHY_FLAG_SUPPORTS_5_10_MHZ`` Device supports 5 MHz and 10 MHz channels. h](j)}(h ``WIPHY_FLAG_SUPPORTS_5_10_MHZ``h]j)}(hj #h]hWIPHY_FLAG_SUPPORTS_5_10_MHZ}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj #ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM]hj#ubj6)}(hhh]h)}(h*Device supports 5 MHz and 10 MHz channels.h]h*Device supports 5 MHz and 10 MHz channels.}(hj%#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!#hM]hj"#ubah}(h]h ]h"]h$]h&]uh1j5hj#ubeh}(h]h ]h"]h$]h&]uh1jhj!#hM]hjubj)}(hj``WIPHY_FLAG_HAS_CHANNEL_SWITCH`` Device supports channel switch in beaconing mode (AP, IBSS, Mesh, ...). h](j)}(h!``WIPHY_FLAG_HAS_CHANNEL_SWITCH``h]j)}(hjE#h]hWIPHY_FLAG_HAS_CHANNEL_SWITCH}(hjG#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjC#ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMahj?#ubj6)}(hhh]h)}(hGDevice supports channel switch in beaconing mode (AP, IBSS, Mesh, ...).h]hGDevice supports channel switch in beaconing mode (AP, IBSS, Mesh, ...).}(hj^#hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM`hj[#ubah}(h]h ]h"]h$]h&]uh1j5hj?#ubeh}(h]h ]h"]h$]h&]uh1jhjZ#hMahjubj)}(hl``WIPHY_FLAG_NOTIFY_REGDOM_BY_DRIVER`` The device could handle reg notify for NL80211_REGDOM_SET_BY_DRIVER. h](j)}(h&``WIPHY_FLAG_NOTIFY_REGDOM_BY_DRIVER``h]j)}(hj#h]h"WIPHY_FLAG_NOTIFY_REGDOM_BY_DRIVER}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}#ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMehjy#ubj6)}(hhh]h)}(hDThe device could handle reg notify for NL80211_REGDOM_SET_BY_DRIVER.h]hDThe device could handle reg notify for NL80211_REGDOM_SET_BY_DRIVER.}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMdhj#ubah}(h]h ]h"]h$]h&]uh1j5hjy#ubeh}(h]h ]h"]h$]h&]uh1jhj#hMehjubj)}(h``WIPHY_FLAG_CHANNEL_CHANGE_ON_BEACON`` reg_call_notifier() is called if driver set this flag to update channels on beacon hints.h](j)}(h'``WIPHY_FLAG_CHANNEL_CHANGE_ON_BEACON``h]j)}(hj#h]h#WIPHY_FLAG_CHANNEL_CHANGE_ON_BEACON}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhhj#ubj6)}(hhh]h)}(hYreg_call_notifier() is called if driver set this flag to update channels on beacon hints.h]hYreg_call_notifier() is called if driver set this flag to update channels on beacon hints.}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#hMhhj#ubah}(h]h ]h"]h$]h&]uh1j5hj#ubeh}(h]h ]h"]h$]h&]uh1jhj#hMhhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ ieee80211_iface_limit (C struct)c.ieee80211_iface_limithNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hieee80211_iface_limith]jo)}(hstruct ieee80211_iface_limith](ju)}(hjh]hstruct}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj$hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMnubj)}(h h]h }(hj $hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$hhhj$hMnubj)}(hieee80211_iface_limith]j)}(hj $h]hieee80211_iface_limit}(hj2$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.$ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj$hhhj$hMnubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj $hhhj$hMnubah}(h]j$ah ](jjeh"]h$]h&]jj)jhuh1jhhj$hMnhj$hhubj)}(hhh]h)}(h limit on certain interface typesh]h limit on certain interface types}(hjT$hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMRhjQ$hhubah}(h]h ]h"]h$]h&]uh1jhj$hhhj$hMnubeh}(h]h ](j$structeh"]h$]h&]jj$jjl$jjl$jjjuh1jchhhhhNhNubj)}(h**Definition**:: struct ieee80211_iface_limit { u16 max; u16 types; }; **Members** ``max`` maximum number of interfaces of these types ``types`` interface types (bits)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjx$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjt$ubh:}(hjt$hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMVhjp$ubj( )}(h=struct ieee80211_iface_limit { u16 max; u16 types; };h]h=struct ieee80211_iface_limit { u16 max; u16 types; };}hj$sbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMXhjp$ubh)}(h **Members**h]j)}(hj$h]hMembers}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM]hjp$ubj)}(hhh](j)}(h4``max`` maximum number of interfaces of these types h](j)}(h``max``h]j)}(hj$h]hmax}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMThj$ubj6)}(hhh]h)}(h+maximum number of interfaces of these typesh]h+maximum number of interfaces of these types}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$hMThj$ubah}(h]h ]h"]h$]h&]uh1j5hj$ubeh}(h]h ]h"]h$]h&]uh1jhj$hMThj$ubj)}(h ``types`` interface types (bits)h](j)}(h ``types``h]j)}(hj$h]htypes}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMThj$ubj6)}(hhh]h)}(hinterface types (bits)h]hinterface types (bits)}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMUhj%ubah}(h]h ]h"]h$]h&]uh1j5hj$ubeh}(h]h ]h"]h$]h&]uh1jhj%hMThj$ubeh}(h]h ]h"]h$]h&]uh1jhjp$ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_&ieee80211_iface_combination (C struct)c.ieee80211_iface_combinationhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hieee80211_iface_combinationh]jo)}(h"struct ieee80211_iface_combinationh](ju)}(hjh]hstruct}(hjT%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjP%hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM[ubj)}(h h]h }(hjb%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjP%hhhja%hM[ubj)}(hieee80211_iface_combinationh]j)}(hjN%h]hieee80211_iface_combination}(hjt%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjp%ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjP%hhhja%hM[ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjL%hhhja%hM[ubah}(h]jG%ah ](jjeh"]h$]h&]jj)jhuh1jhhja%hM[hjI%hhubj)}(hhh]h)}(hpossible interface combinationh]hpossible interface combination}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM\hj%hhubah}(h]h ]h"]h$]h&]uh1jhjI%hhhja%hM[ubeh}(h]h ](j$structeh"]h$]h&]jj$jj%jj%jjjuh1jchhhhhNhNubj)}(hX**Definition**:: struct ieee80211_iface_combination { const struct ieee80211_iface_limit *limits; u32 num_different_channels; u16 max_interfaces; u8 n_limits; bool beacon_int_infra_match; u8 radar_detect_widths; u8 radar_detect_regions; u32 beacon_int_min_gcd; }; **Members** ``limits`` limits for the given interface types ``num_different_channels`` can use up to this many different channels ``max_interfaces`` maximum number of interfaces in total allowed in this group ``n_limits`` number of limitations ``beacon_int_infra_match`` In this combination, the beacon intervals between infrastructure and AP types must match. This is required only in special cases. ``radar_detect_widths`` bitmap of channel widths supported for radar detection ``radar_detect_regions`` bitmap of regions supported for radar detection ``beacon_int_min_gcd`` This interface combination supports different beacon intervals. = 0 all beacon intervals for different interface must be same. > 0 any beacon interval for the interface part of this combination AND GCD of all beacon intervals from beaconing interfaces of this combination must be greater or equal to this value.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%ubh:}(hj%hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM`hj%ubj( )}(hXstruct ieee80211_iface_combination { const struct ieee80211_iface_limit *limits; u32 num_different_channels; u16 max_interfaces; u8 n_limits; bool beacon_int_infra_match; u8 radar_detect_widths; u8 radar_detect_regions; u32 beacon_int_min_gcd; };h]hXstruct ieee80211_iface_combination { const struct ieee80211_iface_limit *limits; u32 num_different_channels; u16 max_interfaces; u8 n_limits; bool beacon_int_infra_match; u8 radar_detect_widths; u8 radar_detect_regions; u32 beacon_int_min_gcd; };}hj%sbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMbhj%ubh)}(h **Members**h]j)}(hj%h]hMembers}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMmhj%ubj)}(hhh](j)}(h0``limits`` limits for the given interface types h](j)}(h ``limits``h]j)}(hj&h]hlimits}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj%ubj6)}(hhh]h)}(h$limits for the given interface typesh]h$limits for the given interface types}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&hMhj&ubah}(h]h ]h"]h$]h&]uh1j5hj%ubeh}(h]h ]h"]h$]h&]uh1jhj&hMhj%ubj)}(hF``num_different_channels`` can use up to this many different channels h](j)}(h``num_different_channels``h]j)}(hj<&h]hnum_different_channels}(hj>&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:&ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj6&ubj6)}(hhh]h)}(h*can use up to this many different channelsh]h*can use up to this many different channels}(hjU&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQ&hMhjR&ubah}(h]h ]h"]h$]h&]uh1j5hj6&ubeh}(h]h ]h"]h$]h&]uh1jhjQ&hMhj%ubj)}(hO``max_interfaces`` maximum number of interfaces in total allowed in this group h](j)}(h``max_interfaces``h]j)}(hju&h]hmax_interfaces}(hjw&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjs&ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjo&ubj6)}(hhh]h)}(h;maximum number of interfaces in total allowed in this grouph]h;maximum number of interfaces in total allowed in this group}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&hMhj&ubah}(h]h ]h"]h$]h&]uh1j5hjo&ubeh}(h]h ]h"]h$]h&]uh1jhj&hMhj%ubj)}(h#``n_limits`` number of limitations h](j)}(h ``n_limits``h]j)}(hj&h]hn_limits}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj&ubj6)}(hhh]h)}(hnumber of limitationsh]hnumber of limitations}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&hMhj&ubah}(h]h ]h"]h$]h&]uh1j5hj&ubeh}(h]h ]h"]h$]h&]uh1jhj&hMhj%ubj)}(h``beacon_int_infra_match`` In this combination, the beacon intervals between infrastructure and AP types must match. This is required only in special cases. h](j)}(h``beacon_int_infra_match``h]j)}(hj&h]hbeacon_int_infra_match}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj&ubj6)}(hhh]h)}(hIn this combination, the beacon intervals between infrastructure and AP types must match. This is required only in special cases.h]hIn this combination, the beacon intervals between infrastructure and AP types must match. This is required only in special cases.}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj&ubah}(h]h ]h"]h$]h&]uh1j5hj&ubeh}(h]h ]h"]h$]h&]uh1jhj&hMhj%ubj)}(hO``radar_detect_widths`` bitmap of channel widths supported for radar detection h](j)}(h``radar_detect_widths``h]j)}(hj!'h]hradar_detect_widths}(hj#'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj'ubj6)}(hhh]h)}(h6bitmap of channel widths supported for radar detectionh]h6bitmap of channel widths supported for radar detection}(hj:'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6'hMhj7'ubah}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhj6'hMhj%ubj)}(hI``radar_detect_regions`` bitmap of regions supported for radar detection h](j)}(h``radar_detect_regions``h]j)}(hjZ'h]hradar_detect_regions}(hj\'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjX'ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjT'ubj6)}(hhh]h)}(h/bitmap of regions supported for radar detectionh]h/bitmap of regions supported for radar detection}(hjs'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjo'hMhjp'ubah}(h]h ]h"]h$]h&]uh1j5hjT'ubeh}(h]h ]h"]h$]h&]uh1jhjo'hMhj%ubj)}(hXW``beacon_int_min_gcd`` This interface combination supports different beacon intervals. = 0 all beacon intervals for different interface must be same. > 0 any beacon interval for the interface part of this combination AND GCD of all beacon intervals from beaconing interfaces of this combination must be greater or equal to this value.h](j)}(h``beacon_int_min_gcd``h]j)}(hj'h]hbeacon_int_min_gcd}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj'ubj6)}(hhh](h)}(h?This interface combination supports different beacon intervals.h]h?This interface combination supports different beacon intervals.}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj'ubj)}(hhh](j)}(h>= 0 all beacon intervals for different interface must be same.h](j)}(h= 0h]h= 0}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj'ubj6)}(hhh]h)}(h:all beacon intervals for different interface must be same.h]h:all beacon intervals for different interface must be same.}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj'ubah}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'hMhj'ubj)}(h> 0 any beacon interval for the interface part of this combination AND GCD of all beacon intervals from beaconing interfaces of this combination must be greater or equal to this value.h](j)}(h> 0h]h> 0}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'hMhj'ubj6)}(hhh]h)}(hany beacon interval for the interface part of this combination AND GCD of all beacon intervals from beaconing interfaces of this combination must be greater or equal to this value.h]hany beacon interval for the interface part of this combination AND GCD of all beacon intervals from beaconing interfaces of this combination must be greater or equal to this value.}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj(ubah}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'hMhj'ubeh}(h]h ]h"]h$]h&]uh1jhj'ubeh}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'hMhj%ubeh}(h]h ]h"]h$]h&]uh1jhj%ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hj@(h]h Description}(hjB(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>(ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhhhhubh)}(hWith this structure the driver can describe which interface combinations it supports concurrently. When set in a struct wiphy_radio, the combinations refer to combinations of interfaces currently active on that radio.h]hWith this structure the driver can describe which interface combinations it supports concurrently. When set in a struct wiphy_radio, the combinations refer to combinations of interfaces currently active on that radio.}(hjV(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM]hhhhubh)}(h **Examples**h]j)}(hjg(h]hExamples}(hji(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhje(ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMbhhhhubhenumerated_list)}(hhh](h list_item)}(hXAllow #STA <= 1, #AP <= 1, matching BI, channels = 1, 2 total: .. code-block:: c struct ieee80211_iface_limit limits1[] = { { .max = 1, .types = BIT(NL80211_IFTYPE_STATION), }, { .max = 1, .types = BIT(NL80211_IFTYPE_AP), }, }; struct ieee80211_iface_combination combination1 = { .limits = limits1, .n_limits = ARRAY_SIZE(limits1), .max_interfaces = 2, .beacon_int_infra_match = true, }; h](h)}(h>Allow #STA <= 1, #AP <= 1, matching BI, channels = 1, 2 total:h]h>Allow #STA <= 1, #AP <= 1, matching BI, channels = 1, 2 total:}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMchj(ubj( )}(hXbstruct ieee80211_iface_limit limits1[] = { { .max = 1, .types = BIT(NL80211_IFTYPE_STATION), }, { .max = 1, .types = BIT(NL80211_IFTYPE_AP), }, }; struct ieee80211_iface_combination combination1 = { .limits = limits1, .n_limits = ARRAY_SIZE(limits1), .max_interfaces = 2, .beacon_int_infra_match = true, };h]hXbstruct ieee80211_iface_limit limits1[] = { { .max = 1, .types = BIT(NL80211_IFTYPE_STATION), }, { .max = 1, .types = BIT(NL80211_IFTYPE_AP), }, }; struct ieee80211_iface_combination combination1 = { .limits = limits1, .n_limits = ARRAY_SIZE(limits1), .max_interfaces = 2, .beacon_int_infra_match = true, };}hj(sbah}(h]h ]h"]h$]h&]jjforcelanguagej$highlight_args}uh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMehj(ubeh}(h]h ]h"]h$]h&]uh1j(hj(ubj()}(hXAllow #{AP, P2P-GO} <= 8, channels = 1, 8 total: .. code-block:: c struct ieee80211_iface_limit limits2[] = { { .max = 8, .types = BIT(NL80211_IFTYPE_AP) | BIT(NL80211_IFTYPE_P2P_GO), }, }; struct ieee80211_iface_combination combination2 = { .limits = limits2, .n_limits = ARRAY_SIZE(limits2), .max_interfaces = 8, .num_different_channels = 1, }; h](h)}(h0Allow #{AP, P2P-GO} <= 8, channels = 1, 8 total:h]h0Allow #{AP, P2P-GO} <= 8, channels = 1, 8 total:}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMshj(ubj( )}(hX\struct ieee80211_iface_limit limits2[] = { { .max = 8, .types = BIT(NL80211_IFTYPE_AP) | BIT(NL80211_IFTYPE_P2P_GO), }, }; struct ieee80211_iface_combination combination2 = { .limits = limits2, .n_limits = ARRAY_SIZE(limits2), .max_interfaces = 8, .num_different_channels = 1, };h]hX\struct ieee80211_iface_limit limits2[] = { { .max = 8, .types = BIT(NL80211_IFTYPE_AP) | BIT(NL80211_IFTYPE_P2P_GO), }, }; struct ieee80211_iface_combination combination2 = { .limits = limits2, .n_limits = ARRAY_SIZE(limits2), .max_interfaces = 8, .num_different_channels = 1, };}hj(sbah}(h]h ]h"]h$]h&]jjj(j(j$j(}uh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMuhj(ubeh}(h]h ]h"]h$]h&]uh1j(hj(ubj()}(hX]Allow #STA <= 1, #{P2P-client,P2P-GO} <= 3 on two channels, 4 total. This allows for an infrastructure connection and three P2P connections. .. code-block:: c struct ieee80211_iface_limit limits3[] = { { .max = 1, .types = BIT(NL80211_IFTYPE_STATION), }, { .max = 3, .types = BIT(NL80211_IFTYPE_P2P_GO) | BIT(NL80211_IFTYPE_P2P_CLIENT), }, }; struct ieee80211_iface_combination combination3 = { .limits = limits3, .n_limits = ARRAY_SIZE(limits3), .max_interfaces = 4, .num_different_channels = 2, }; h](h)}(hDAllow #STA <= 1, #{P2P-client,P2P-GO} <= 3 on two channels, 4 total.h]hDAllow #STA <= 1, #{P2P-client,P2P-GO} <= 3 on two channels, 4 total.}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj(ubh)}(hGThis allows for an infrastructure connection and three P2P connections.h]hGThis allows for an infrastructure connection and three P2P connections.}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj(ubj( )}(hXstruct ieee80211_iface_limit limits3[] = { { .max = 1, .types = BIT(NL80211_IFTYPE_STATION), }, { .max = 3, .types = BIT(NL80211_IFTYPE_P2P_GO) | BIT(NL80211_IFTYPE_P2P_CLIENT), }, }; struct ieee80211_iface_combination combination3 = { .limits = limits3, .n_limits = ARRAY_SIZE(limits3), .max_interfaces = 4, .num_different_channels = 2, };h]hXstruct ieee80211_iface_limit limits3[] = { { .max = 1, .types = BIT(NL80211_IFTYPE_STATION), }, { .max = 3, .types = BIT(NL80211_IFTYPE_P2P_GO) | BIT(NL80211_IFTYPE_P2P_CLIENT), }, }; struct ieee80211_iface_combination combination3 = { .limits = limits3, .n_limits = ARRAY_SIZE(limits3), .max_interfaces = 4, .num_different_channels = 2, };}hj(sbah}(h]h ]h"]h$]h&]jjj(j(j$j(}uh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj(ubeh}(h]h ]h"]h$]h&]uh1j(hj(ubeh}(h]h ]h"]h$]h&]enumtypearabicprefixhsuffix.uh1j}(hhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wiphy (C struct)c.wiphyhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hwiphyh]jo)}(h struct wiphyh](ju)}(hjh]hstruct}(hj5)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj1)hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjC)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1)hhhjB)hMubj)}(hwiphyh]j)}(hj/)h]hwiphy}(hjU)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQ)ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj1)hhhjB)hMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj-)hhhjB)hMubah}(h]j()ah ](jjeh"]h$]h&]jj)jhuh1jhhjB)hMhj*)hhubj)}(hhh]h)}(hwireless hardware descriptionh]hwireless hardware description}(hjw)hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjt)hhubah}(h]h ]h"]h$]h&]uh1jhj*)hhhjB)hMubeh}(h]h ](j$structeh"]h$]h&]jj$jj)jj)jjjuh1jchhhhhNhNubj)}(hX <**Definition**:: struct wiphy { struct mutex mtx; u8 perm_addr[ETH_ALEN]; u8 addr_mask[ETH_ALEN]; struct mac_address *addresses; const struct ieee80211_txrx_stypes *mgmt_stypes; const struct ieee80211_iface_combination *iface_combinations; int n_iface_combinations; u16 software_iftypes; u16 n_addresses; u16 interface_modes; u16 max_acl_mac_addrs; u32 flags, regulatory_flags, features; u8 ext_features[DIV_ROUND_UP(NUM_NL80211_EXT_FEATURES, 8)]; u32 ap_sme_capa; enum cfg80211_signal_type signal_type; int bss_priv_size; u8 max_scan_ssids; u8 max_sched_scan_reqs; u8 max_sched_scan_ssids; u8 max_match_sets; u16 max_scan_ie_len; u16 max_sched_scan_ie_len; u32 max_sched_scan_plans; u32 max_sched_scan_plan_interval; u32 max_sched_scan_plan_iterations; int n_cipher_suites; const u32 *cipher_suites; int n_akm_suites; const u32 *akm_suites; const struct wiphy_iftype_akm_suites *iftype_akm_suites; unsigned int num_iftype_akm_suites; u8 retry_short; u8 retry_long; u32 frag_threshold; u32 rts_threshold; u8 coverage_class; char fw_version[ETHTOOL_FWVERS_LEN]; u32 hw_version; #ifdef CONFIG_PM; const struct wiphy_wowlan_support *wowlan; struct cfg80211_wowlan *wowlan_config; #endif; u16 max_remain_on_channel_duration; u8 max_num_pmkids; u32 available_antennas_tx; u32 available_antennas_rx; u32 probe_resp_offload; const u8 *extended_capabilities, *extended_capabilities_mask; u8 extended_capabilities_len; const struct wiphy_iftype_ext_capab *iftype_ext_capab; unsigned int num_iftype_ext_capab; const void *privid; struct ieee80211_supported_band *bands[NUM_NL80211_BANDS]; void (*reg_notifier)(struct wiphy *wiphy, struct regulatory_request *request); struct wiphy_radio_cfg *radio_cfg; const struct ieee80211_regdomain __rcu *regd; struct device dev; bool registered; struct dentry *debugfsdir; const struct ieee80211_ht_cap *ht_capa_mod_mask; const struct ieee80211_vht_cap *vht_capa_mod_mask; struct list_head wdev_list; possible_net_t _net; #ifdef CONFIG_CFG80211_WEXT; const struct iw_handler_def *wext; #endif; const struct wiphy_coalesce_support *coalesce; const struct wiphy_vendor_command *vendor_commands; const struct nl80211_vendor_cmd_info *vendor_events; int n_vendor_commands, n_vendor_events; u16 max_ap_assoc_sta; u8 max_num_csa_counters; u32 bss_select_support; u8 nan_supported_bands; u32 txq_limit; u32 txq_memory_limit; u32 txq_quantum; unsigned long tx_queue_len; u8 support_mbssid:1, support_only_he_mbssid:1; const struct cfg80211_pmsr_capabilities *pmsr_capa; struct { u64 peer, vif; u8 max_retry; } tid_config_support; u8 max_data_retry_count; const struct cfg80211_sar_capa *sar_capa; struct rfkill *rfkill; u8 mbssid_max_interfaces; u8 ema_max_profile_periodicity; u16 max_num_akm_suites; u16 hw_timestamp_max_peers; int n_radio; const struct wiphy_radio *radio; char priv[] ; }; **Members** ``mtx`` mutex for the data (structures) of this device ``perm_addr`` permanent MAC address of this device ``addr_mask`` If the device supports multiple MAC addresses by masking, set this to a mask with variable bits set to 1, e.g. if the last four bits are variable then set it to 00-00-00-00-00-0f. The actual variable bits shall be determined by the interfaces added, with interfaces not matching the mask being rejected to be brought up. ``addresses`` If the device has more than one address, set this pointer to a list of addresses (6 bytes each). The first one will be used by default for perm_addr. In this case, the mask should be set to all-zeroes. In this case it is assumed that the device can handle the same number of arbitrary MAC addresses. ``mgmt_stypes`` bitmasks of frame subtypes that can be subscribed to or transmitted through nl80211, points to an array indexed by interface type ``iface_combinations`` Valid interface combinations array, should not list single interface types. ``n_iface_combinations`` number of entries in **iface_combinations** array. ``software_iftypes`` bitmask of software interface types, these are not subject to any restrictions since they are purely managed in SW. ``n_addresses`` number of addresses in **addresses**. ``interface_modes`` bitmask of interfaces types valid for this wiphy, must be set by driver ``max_acl_mac_addrs`` Maximum number of MAC addresses that the device supports for ACL. ``flags`` wiphy flags, see :c:type:`enum wiphy_flags ` ``regulatory_flags`` wiphy regulatory flags, see :c:type:`enum ieee80211_regulatory_flags ` ``features`` features advertised to nl80211, see :c:type:`enum nl80211_feature_flags `. ``ext_features`` extended features advertised to nl80211, see :c:type:`enum nl80211_ext_feature_index `. ``ap_sme_capa`` AP SME capabilities, flags from :c:type:`enum nl80211_ap_sme_features `. ``signal_type`` signal type reported in :c:type:`struct cfg80211_bss `. ``bss_priv_size`` each BSS struct has private data allocated with it, this variable determines its size ``max_scan_ssids`` maximum number of SSIDs the device can scan for in any given scan ``max_sched_scan_reqs`` maximum number of scheduled scan requests that the device can run concurrently. ``max_sched_scan_ssids`` maximum number of SSIDs the device can scan for in any given scheduled scan ``max_match_sets`` maximum number of match sets the device can handle when performing a scheduled scan, 0 if filtering is not supported. ``max_scan_ie_len`` maximum length of user-controlled IEs device can add to probe request frames transmitted during a scan, must not include fixed IEs like supported rates ``max_sched_scan_ie_len`` same as max_scan_ie_len, but for scheduled scans ``max_sched_scan_plans`` maximum number of scan plans (scan interval and number of iterations) for scheduled scan supported by the device. ``max_sched_scan_plan_interval`` maximum interval (in seconds) for a single scan plan supported by the device. ``max_sched_scan_plan_iterations`` maximum number of iterations for a single scan plan supported by the device. ``n_cipher_suites`` number of supported cipher suites ``cipher_suites`` supported cipher suites ``n_akm_suites`` number of supported AKM suites ``akm_suites`` supported AKM suites. These are the default AKMs supported if the supported AKMs not advertized for a specific interface type in iftype_akm_suites. ``iftype_akm_suites`` array of supported akm suites info per interface type. Note that the bits in **iftypes_mask** inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_akm_suites). ``num_iftype_akm_suites`` number of interface types for which supported akm suites are specified separately. ``retry_short`` Retry limit for short frames (dot11ShortRetryLimit) ``retry_long`` Retry limit for long frames (dot11LongRetryLimit) ``frag_threshold`` Fragmentation threshold (dot11FragmentationThreshold); -1 = fragmentation disabled, only odd values >= 256 used ``rts_threshold`` RTS threshold (dot11RTSThreshold); -1 = RTS/CTS disabled ``coverage_class`` current coverage class ``fw_version`` firmware version for ethtool reporting ``hw_version`` hardware version for ethtool reporting ``wowlan`` WoWLAN support information ``wowlan_config`` current WoWLAN configuration; this should usually not be used since access to it is necessarily racy, use the parameter passed to the suspend() operation instead. ``max_remain_on_channel_duration`` Maximum time a remain-on-channel operation may request, if implemented. ``max_num_pmkids`` maximum number of PMKIDs supported by device ``available_antennas_tx`` bitmap of antennas which are available to be configured as TX antennas. Antenna configuration commands will be rejected unless this or **available_antennas_rx** is set. ``available_antennas_rx`` bitmap of antennas which are available to be configured as RX antennas. Antenna configuration commands will be rejected unless this or **available_antennas_tx** is set. ``probe_resp_offload`` Bitmap of supported protocols for probe response offloading. See :c:type:`enum nl80211_probe_resp_offload_support_attr `. Only valid when the wiphy flag **WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD** is set. ``extended_capabilities`` extended capabilities supported by the driver, additional capabilities might be supported by userspace; these are the 802.11 extended capabilities ("Extended Capabilities element") and are in the same format as in the information element. See 802.11-2012 8.4.2.29 for the defined fields. These are the default extended capabilities to be used if the capabilities are not specified for a specific interface type in iftype_ext_capab. ``extended_capabilities_mask`` mask of the valid values ``extended_capabilities_len`` length of the extended capabilities ``iftype_ext_capab`` array of extended capabilities per interface type ``num_iftype_ext_capab`` number of interface types for which extended capabilities are specified separately. ``privid`` a pointer that drivers can use to identify if an arbitrary wiphy is theirs, e.g. in global notifiers ``bands`` information about bands/channels supported by this device ``reg_notifier`` the driver's regulatory notification callback, note that if your driver uses wiphy_apply_custom_regulatory() the reg_notifier's request can be passed as NULL ``radio_cfg`` configuration of radios belonging to a muli-radio wiphy. This struct contains a list of all radio specific attributes and should be used only for multi-radio wiphy. ``regd`` the driver's regulatory domain, if one was requested via the regulatory_hint() API. This can be used by the driver on the reg_notifier() if it chooses to ignore future regulatory domain changes caused by other drivers. ``dev`` (virtual) struct device for this wiphy. The item in /sys/class/ieee80211/ points to this. You need use set_wiphy_dev() (see below). ``registered`` protects ->resume and ->suspend sysfs callbacks against unregister hardware ``debugfsdir`` debugfs directory used for this wiphy (ieee80211/). It will be renamed automatically on wiphy renames ``ht_capa_mod_mask`` Specify what ht_cap values can be over-ridden. If null, then none can be over-ridden. ``vht_capa_mod_mask`` Specify what VHT capabilities can be over-ridden. If null, then none can be over-ridden. ``wdev_list`` the list of associated (virtual) interfaces; this list must not be modified by the driver, but can be read with RTNL/RCU protection. ``_net`` the network namespace this wiphy currently lives in ``wext`` wireless extension handlers ``coalesce`` packet coalescing support information ``vendor_commands`` array of vendor commands supported by the hardware ``vendor_events`` array of vendor events supported by the hardware ``n_vendor_commands`` number of vendor commands ``n_vendor_events`` number of vendor events ``max_ap_assoc_sta`` maximum number of associated stations supported in AP mode (including P2P GO) or 0 to indicate no such limit is advertised. The driver is allowed to advertise a theoretical limit that it can reach in some cases, but may not always reach. ``max_num_csa_counters`` Number of supported csa_counters in beacons and probe responses. This value should be set if the driver wishes to limit the number of csa counters. Default (0) means infinite. ``bss_select_support`` bitmask indicating the BSS selection criteria supported by the driver in the .connect() callback. The bit position maps to the attribute indices defined in :c:type:`enum nl80211_bss_select_attr `. ``nan_supported_bands`` bands supported by the device in NAN mode, a bitmap of :c:type:`enum nl80211_band ` values. For instance, for NL80211_BAND_2GHZ, bit 0 would be set (i.e. BIT(NL80211_BAND_2GHZ)). ``txq_limit`` configuration of internal TX queue frame limit ``txq_memory_limit`` configuration internal TX queue memory limit ``txq_quantum`` configuration of internal TX queue scheduler quantum ``tx_queue_len`` allow setting transmit queue len for drivers not using wake_tx_queue ``support_mbssid`` can HW support association with nontransmitted AP ``support_only_he_mbssid`` don't parse MBSSID elements if it is not HE AP, in order to avoid compatibility issues. **support_mbssid** must be set for this to have any effect. ``pmsr_capa`` peer measurement capabilities ``tid_config_support`` describes the per-TID config support that the device has ``tid_config_support.peer`` bitmap of attributes (configurations) supported by the driver for each peer ``tid_config_support.vif`` bitmap of attributes (configurations) supported by the driver for each vif ``tid_config_support.max_retry`` maximum supported retry count for long/short retry configuration ``max_data_retry_count`` maximum supported per TID retry count for configuration through the ``NL80211_TID_CONFIG_ATTR_RETRY_SHORT`` and ``NL80211_TID_CONFIG_ATTR_RETRY_LONG`` attributes ``sar_capa`` SAR control capabilities ``rfkill`` a pointer to the rfkill structure ``mbssid_max_interfaces`` maximum number of interfaces supported by the driver in a multiple BSSID set. This field must be set to a non-zero value by the driver to advertise MBSSID support. ``ema_max_profile_periodicity`` maximum profile periodicity supported by the driver. Setting this field to a non-zero value indicates that the driver supports enhanced multi-BSSID advertisements (EMA AP). ``max_num_akm_suites`` maximum number of AKM suites allowed for configuration through ``NL80211_CMD_CONNECT``, ``NL80211_CMD_ASSOCIATE`` and ``NL80211_CMD_START_AP``. Set to NL80211_MAX_NR_AKM_SUITES if not set by driver. If set by driver minimum allowed value is NL80211_MAX_NR_AKM_SUITES in order to avoid compatibility issues with legacy userspace and maximum allowed value is CFG80211_MAX_NUM_AKM_SUITES. ``hw_timestamp_max_peers`` maximum number of peers that the driver supports enabling HW timestamping for concurrently. Setting this field to a non-zero value indicates that the driver supports HW timestamping. A value of ``CFG80211_HW_TIMESTAMP_ALL_PEERS`` indicates the driver supports enabling HW timestamping for all peers (i.e. no need to specify a mac address). ``n_radio`` number of radios ``radio`` radios belonging to this wiphy ``priv`` driver private data (sized according to wiphy_new() parameter)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj)ubh:}(hj)hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj)ubj( )}(hX\ struct wiphy { struct mutex mtx; u8 perm_addr[ETH_ALEN]; u8 addr_mask[ETH_ALEN]; struct mac_address *addresses; const struct ieee80211_txrx_stypes *mgmt_stypes; const struct ieee80211_iface_combination *iface_combinations; int n_iface_combinations; u16 software_iftypes; u16 n_addresses; u16 interface_modes; u16 max_acl_mac_addrs; u32 flags, regulatory_flags, features; u8 ext_features[DIV_ROUND_UP(NUM_NL80211_EXT_FEATURES, 8)]; u32 ap_sme_capa; enum cfg80211_signal_type signal_type; int bss_priv_size; u8 max_scan_ssids; u8 max_sched_scan_reqs; u8 max_sched_scan_ssids; u8 max_match_sets; u16 max_scan_ie_len; u16 max_sched_scan_ie_len; u32 max_sched_scan_plans; u32 max_sched_scan_plan_interval; u32 max_sched_scan_plan_iterations; int n_cipher_suites; const u32 *cipher_suites; int n_akm_suites; const u32 *akm_suites; const struct wiphy_iftype_akm_suites *iftype_akm_suites; unsigned int num_iftype_akm_suites; u8 retry_short; u8 retry_long; u32 frag_threshold; u32 rts_threshold; u8 coverage_class; char fw_version[ETHTOOL_FWVERS_LEN]; u32 hw_version; #ifdef CONFIG_PM; const struct wiphy_wowlan_support *wowlan; struct cfg80211_wowlan *wowlan_config; #endif; u16 max_remain_on_channel_duration; u8 max_num_pmkids; u32 available_antennas_tx; u32 available_antennas_rx; u32 probe_resp_offload; const u8 *extended_capabilities, *extended_capabilities_mask; u8 extended_capabilities_len; const struct wiphy_iftype_ext_capab *iftype_ext_capab; unsigned int num_iftype_ext_capab; const void *privid; struct ieee80211_supported_band *bands[NUM_NL80211_BANDS]; void (*reg_notifier)(struct wiphy *wiphy, struct regulatory_request *request); struct wiphy_radio_cfg *radio_cfg; const struct ieee80211_regdomain __rcu *regd; struct device dev; bool registered; struct dentry *debugfsdir; const struct ieee80211_ht_cap *ht_capa_mod_mask; const struct ieee80211_vht_cap *vht_capa_mod_mask; struct list_head wdev_list; possible_net_t _net; #ifdef CONFIG_CFG80211_WEXT; const struct iw_handler_def *wext; #endif; const struct wiphy_coalesce_support *coalesce; const struct wiphy_vendor_command *vendor_commands; const struct nl80211_vendor_cmd_info *vendor_events; int n_vendor_commands, n_vendor_events; u16 max_ap_assoc_sta; u8 max_num_csa_counters; u32 bss_select_support; u8 nan_supported_bands; u32 txq_limit; u32 txq_memory_limit; u32 txq_quantum; unsigned long tx_queue_len; u8 support_mbssid:1, support_only_he_mbssid:1; const struct cfg80211_pmsr_capabilities *pmsr_capa; struct { u64 peer, vif; u8 max_retry; } tid_config_support; u8 max_data_retry_count; const struct cfg80211_sar_capa *sar_capa; struct rfkill *rfkill; u8 mbssid_max_interfaces; u8 ema_max_profile_periodicity; u16 max_num_akm_suites; u16 hw_timestamp_max_peers; int n_radio; const struct wiphy_radio *radio; char priv[] ; };h]hX\ struct wiphy { struct mutex mtx; u8 perm_addr[ETH_ALEN]; u8 addr_mask[ETH_ALEN]; struct mac_address *addresses; const struct ieee80211_txrx_stypes *mgmt_stypes; const struct ieee80211_iface_combination *iface_combinations; int n_iface_combinations; u16 software_iftypes; u16 n_addresses; u16 interface_modes; u16 max_acl_mac_addrs; u32 flags, regulatory_flags, features; u8 ext_features[DIV_ROUND_UP(NUM_NL80211_EXT_FEATURES, 8)]; u32 ap_sme_capa; enum cfg80211_signal_type signal_type; int bss_priv_size; u8 max_scan_ssids; u8 max_sched_scan_reqs; u8 max_sched_scan_ssids; u8 max_match_sets; u16 max_scan_ie_len; u16 max_sched_scan_ie_len; u32 max_sched_scan_plans; u32 max_sched_scan_plan_interval; u32 max_sched_scan_plan_iterations; int n_cipher_suites; const u32 *cipher_suites; int n_akm_suites; const u32 *akm_suites; const struct wiphy_iftype_akm_suites *iftype_akm_suites; unsigned int num_iftype_akm_suites; u8 retry_short; u8 retry_long; u32 frag_threshold; u32 rts_threshold; u8 coverage_class; char fw_version[ETHTOOL_FWVERS_LEN]; u32 hw_version; #ifdef CONFIG_PM; const struct wiphy_wowlan_support *wowlan; struct cfg80211_wowlan *wowlan_config; #endif; u16 max_remain_on_channel_duration; u8 max_num_pmkids; u32 available_antennas_tx; u32 available_antennas_rx; u32 probe_resp_offload; const u8 *extended_capabilities, *extended_capabilities_mask; u8 extended_capabilities_len; const struct wiphy_iftype_ext_capab *iftype_ext_capab; unsigned int num_iftype_ext_capab; const void *privid; struct ieee80211_supported_band *bands[NUM_NL80211_BANDS]; void (*reg_notifier)(struct wiphy *wiphy, struct regulatory_request *request); struct wiphy_radio_cfg *radio_cfg; const struct ieee80211_regdomain __rcu *regd; struct device dev; bool registered; struct dentry *debugfsdir; const struct ieee80211_ht_cap *ht_capa_mod_mask; const struct ieee80211_vht_cap *vht_capa_mod_mask; struct list_head wdev_list; possible_net_t _net; #ifdef CONFIG_CFG80211_WEXT; const struct iw_handler_def *wext; #endif; const struct wiphy_coalesce_support *coalesce; const struct wiphy_vendor_command *vendor_commands; const struct nl80211_vendor_cmd_info *vendor_events; int n_vendor_commands, n_vendor_events; u16 max_ap_assoc_sta; u8 max_num_csa_counters; u32 bss_select_support; u8 nan_supported_bands; u32 txq_limit; u32 txq_memory_limit; u32 txq_quantum; unsigned long tx_queue_len; u8 support_mbssid:1, support_only_he_mbssid:1; const struct cfg80211_pmsr_capabilities *pmsr_capa; struct { u64 peer, vif; u8 max_retry; } tid_config_support; u8 max_data_retry_count; const struct cfg80211_sar_capa *sar_capa; struct rfkill *rfkill; u8 mbssid_max_interfaces; u8 ema_max_profile_periodicity; u16 max_num_akm_suites; u16 hw_timestamp_max_peers; int n_radio; const struct wiphy_radio *radio; char priv[] ; };}hj)sbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj)ubh)}(h **Members**h]j)}(hj)h]hMembers}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj)ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMchj)ubj)}(hhh](j)}(h7``mtx`` mutex for the data (structures) of this device h](j)}(h``mtx``h]j)}(hj)h]hmtx}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj)ubj6)}(hhh]h)}(h.mutex for the data (structures) of this deviceh]h.mutex for the data (structures) of this device}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj)hMhj)ubah}(h]h ]h"]h$]h&]uh1j5hj)ubeh}(h]h ]h"]h$]h&]uh1jhj)hMhj)ubj)}(h3``perm_addr`` permanent MAC address of this device h](j)}(h ``perm_addr``h]j)}(hj*h]h perm_addr}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj*ubj6)}(hhh]h)}(h$permanent MAC address of this deviceh]h$permanent MAC address of this device}(hj6*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2*hMhj3*ubah}(h]h ]h"]h$]h&]uh1j5hj*ubeh}(h]h ]h"]h$]h&]uh1jhj2*hMhj)ubj)}(hXO``addr_mask`` If the device supports multiple MAC addresses by masking, set this to a mask with variable bits set to 1, e.g. if the last four bits are variable then set it to 00-00-00-00-00-0f. The actual variable bits shall be determined by the interfaces added, with interfaces not matching the mask being rejected to be brought up. h](j)}(h ``addr_mask``h]j)}(hjV*h]h addr_mask}(hjX*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjT*ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjP*ubj6)}(hhh]h)}(hX@If the device supports multiple MAC addresses by masking, set this to a mask with variable bits set to 1, e.g. if the last four bits are variable then set it to 00-00-00-00-00-0f. The actual variable bits shall be determined by the interfaces added, with interfaces not matching the mask being rejected to be brought up.h]hX@If the device supports multiple MAC addresses by masking, set this to a mask with variable bits set to 1, e.g. if the last four bits are variable then set it to 00-00-00-00-00-0f. The actual variable bits shall be determined by the interfaces added, with interfaces not matching the mask being rejected to be brought up.}(hjo*hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjl*ubah}(h]h ]h"]h$]h&]uh1j5hjP*ubeh}(h]h ]h"]h$]h&]uh1jhjk*hMhj)ubj)}(hX:``addresses`` If the device has more than one address, set this pointer to a list of addresses (6 bytes each). The first one will be used by default for perm_addr. In this case, the mask should be set to all-zeroes. In this case it is assumed that the device can handle the same number of arbitrary MAC addresses. h](j)}(h ``addresses``h]j)}(hj*h]h addresses}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM$hj*ubj6)}(hhh]h)}(hX+If the device has more than one address, set this pointer to a list of addresses (6 bytes each). The first one will be used by default for perm_addr. In this case, the mask should be set to all-zeroes. In this case it is assumed that the device can handle the same number of arbitrary MAC addresses.h]hX+If the device has more than one address, set this pointer to a list of addresses (6 bytes each). The first one will be used by default for perm_addr. In this case, the mask should be set to all-zeroes. In this case it is assumed that the device can handle the same number of arbitrary MAC addresses.}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj*ubah}(h]h ]h"]h$]h&]uh1j5hj*ubeh}(h]h ]h"]h$]h&]uh1jhj*hM$hj)ubj)}(h``mgmt_stypes`` bitmasks of frame subtypes that can be subscribed to or transmitted through nl80211, points to an array indexed by interface type h](j)}(h``mgmt_stypes``h]j)}(hj*h]h mgmt_stypes}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM[hj*ubj6)}(hhh]h)}(hbitmasks of frame subtypes that can be subscribed to or transmitted through nl80211, points to an array indexed by interface typeh]hbitmasks of frame subtypes that can be subscribed to or transmitted through nl80211, points to an array indexed by interface type}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMYhj*ubah}(h]h ]h"]h$]h&]uh1j5hj*ubeh}(h]h ]h"]h$]h&]uh1jhj*hM[hj)ubj)}(hc``iface_combinations`` Valid interface combinations array, should not list single interface types. h](j)}(h``iface_combinations``h]j)}(hj+h]hiface_combinations}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM1hj*ubj6)}(hhh]h)}(hKValid interface combinations array, should not list single interface types.h]hKValid interface combinations array, should not list single interface types.}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM0hj+ubah}(h]h ]h"]h$]h&]uh1j5hj*ubeh}(h]h ]h"]h$]h&]uh1jhj+hM1hj)ubj)}(hL``n_iface_combinations`` number of entries in **iface_combinations** array. h](j)}(h``n_iface_combinations``h]j)}(hj>+h]hn_iface_combinations}(hj@+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<+ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM2hj8+ubj6)}(hhh]h)}(h2number of entries in **iface_combinations** array.h](hnumber of entries in }(hjW+hhhNhNubj)}(h**iface_combinations**h]hiface_combinations}(hj_+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjW+ubh array.}(hjW+hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjS+hM2hjT+ubah}(h]h ]h"]h$]h&]uh1j5hj8+ubeh}(h]h ]h"]h$]h&]uh1jhjS+hM2hj)ubj)}(h``software_iftypes`` bitmask of software interface types, these are not subject to any restrictions since they are purely managed in SW. h](j)}(h``software_iftypes``h]j)}(hj+h]hsoftware_iftypes}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM4hj+ubj6)}(hhh]h)}(hsbitmask of software interface types, these are not subject to any restrictions since they are purely managed in SW.h]hsbitmask of software interface types, these are not subject to any restrictions since they are purely managed in SW.}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM3hj+ubah}(h]h ]h"]h$]h&]uh1j5hj+ubeh}(h]h ]h"]h$]h&]uh1jhj+hM4hj)ubj)}(h6``n_addresses`` number of addresses in **addresses**. *h](j)}(h``n_addresses``h]j)}(hj+h]h n_addresses}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj+ubj6)}(hhh]h)}(h%number of addresses in **addresses**.h](hnumber of addresses in }(hj+hhhNhNubj)}(h **addresses**h]h addresses}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj+ubh.}(hj+hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj+hMhj+ubah}(h]h ]h"]h$]h&]uh1j5hj+ubeh}(h]h ]h"]h$]h&]uh1jhj+hMhj)ubj)}(h\``interface_modes`` bitmask of interfaces types valid for this wiphy, must be set by driver h](j)}(h``interface_modes``h]j)}(hj,h]hinterface_modes}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ,ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM/hj,ubj6)}(hhh]h)}(hGbitmask of interfaces types valid for this wiphy, must be set by driverh]hGbitmask of interfaces types valid for this wiphy, must be set by driver}(hj',hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM.hj$,ubah}(h]h ]h"]h$]h&]uh1j5hj,ubeh}(h]h ]h"]h$]h&]uh1jhj#,hM/hj)ubj)}(hX``max_acl_mac_addrs`` Maximum number of MAC addresses that the device supports for ACL. h](j)}(h``max_acl_mac_addrs``h]j)}(hjH,h]hmax_acl_mac_addrs}(hjJ,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjF,ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM|hjB,ubj6)}(hhh]h)}(hAMaximum number of MAC addresses that the device supports for ACL.h]hAMaximum number of MAC addresses that the device supports for ACL.}(hja,hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM{hj^,ubah}(h]h ]h"]h$]h&]uh1j5hjB,ubeh}(h]h ]h"]h$]h&]uh1jhj],hM|hj)ubj)}(hD``flags`` wiphy flags, see :c:type:`enum wiphy_flags ` h](j)}(h ``flags``h]j)}(hj,h]hflags}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM5hj|,ubj6)}(hhh]h)}(h9wiphy flags, see :c:type:`enum wiphy_flags `h](hwiphy flags, see }(hj,hhhNhNubh)}(h(:c:type:`enum wiphy_flags `h]j)}(hj,h]henum wiphy_flags}(hj,hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6 wiphy_flagsuh1hhj,hM5hj,ubeh}(h]h ]h"]h$]h&]uh1hhj,hM5hj,ubah}(h]h ]h"]h$]h&]uh1j5hj|,ubeh}(h]h ]h"]h$]h&]uh1jhj,hM5hj)ubj)}(hx``regulatory_flags`` wiphy regulatory flags, see :c:type:`enum ieee80211_regulatory_flags ` h](j)}(h``regulatory_flags``h]j)}(hj,h]hregulatory_flags}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM7hj,ubj6)}(hhh]h)}(hbwiphy regulatory flags, see :c:type:`enum ieee80211_regulatory_flags `h](hwiphy regulatory flags, see }(hj,hhhNhNubh)}(hF:c:type:`enum ieee80211_regulatory_flags `h]j)}(hj,h]henum ieee80211_regulatory_flags}(hj,hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6ieee80211_regulatory_flagsuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM6hj,ubeh}(h]h ]h"]h$]h&]uh1hhj-hM6hj,ubah}(h]h ]h"]h$]h&]uh1j5hj,ubeh}(h]h ]h"]h$]h&]uh1jhj,hM7hj)ubj)}(ho``features`` features advertised to nl80211, see :c:type:`enum nl80211_feature_flags `. h](j)}(h ``features``h]j)}(hj3-h]hfeatures}(hj5-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1-ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM8hj--ubj6)}(hhh]h)}(hafeatures advertised to nl80211, see :c:type:`enum nl80211_feature_flags `.h](h$features advertised to nl80211, see }(hjL-hhhNhNubh)}(h<:c:type:`enum nl80211_feature_flags `h]j)}(hjV-h]henum nl80211_feature_flags}(hjX-hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjT-ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_feature_flagsuh1hhjH-hM8hjL-ubh.}(hjL-hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjH-hM8hjI-ubah}(h]h ]h"]h$]h&]uh1j5hj--ubeh}(h]h ]h"]h$]h&]uh1jhjH-hM8hj)ubj)}(h``ext_features`` extended features advertised to nl80211, see :c:type:`enum nl80211_ext_feature_index `. h](j)}(h``ext_features``h]j)}(hj-h]h ext_features}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM:hj-ubj6)}(hhh]h)}(hrextended features advertised to nl80211, see :c:type:`enum nl80211_ext_feature_index `.h](h-extended features advertised to nl80211, see }(hj-hhhNhNubh)}(hD:c:type:`enum nl80211_ext_feature_index `h]j)}(hj-h]henum nl80211_ext_feature_index}(hj-hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_ext_feature_indexuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM9hj-ubh.}(hj-hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj-hM9hj-ubah}(h]h ]h"]h$]h&]uh1j5hj-ubeh}(h]h ]h"]h$]h&]uh1jhj-hM:hj)ubj)}(hr``ap_sme_capa`` AP SME capabilities, flags from :c:type:`enum nl80211_ap_sme_features `. h](j)}(h``ap_sme_capa``h]j)}(hj-h]h ap_sme_capa}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMrhj-ubj6)}(hhh]h)}(haAP SME capabilities, flags from :c:type:`enum nl80211_ap_sme_features `.h](h AP SME capabilities, flags from }(hj.hhhNhNubh)}(h@:c:type:`enum nl80211_ap_sme_features `h]j)}(hj.h]henum nl80211_ap_sme_features}(hj.hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj .ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_ap_sme_featuresuh1hhj.hMrhj.ubh.}(hj.hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj.hMrhj.ubah}(h]h ]h"]h$]h&]uh1j5hj-ubeh}(h]h ]h"]h$]h&]uh1jhj.hMrhj)ubj)}(hV``signal_type`` signal type reported in :c:type:`struct cfg80211_bss `. h](j)}(h``signal_type``h]j)}(hjH.h]h signal_type}(hjJ.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjF.ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjB.ubj6)}(hhh]h)}(hEsignal type reported in :c:type:`struct cfg80211_bss `.h](hsignal type reported in }(hja.hhhNhNubh)}(h,:c:type:`struct cfg80211_bss `h]j)}(hjk.h]hstruct cfg80211_bss}(hjm.hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhji.ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6 cfg80211_bssuh1hhj].hMhja.ubh.}(hja.hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj].hMhj^.ubah}(h]h ]h"]h$]h&]uh1j5hjB.ubeh}(h]h ]h"]h$]h&]uh1jhj].hMhj)ubj)}(hh``bss_priv_size`` each BSS struct has private data allocated with it, this variable determines its size h](j)}(h``bss_priv_size``h]j)}(hj.h]h bss_priv_size}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM<hj.ubj6)}(hhh]h)}(hUeach BSS struct has private data allocated with it, this variable determines its sizeh]hUeach BSS struct has private data allocated with it, this variable determines its size}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM;hj.ubah}(h]h ]h"]h$]h&]uh1j5hj.ubeh}(h]h ]h"]h$]h&]uh1jhj.hM<hj)ubj)}(hU``max_scan_ssids`` maximum number of SSIDs the device can scan for in any given scan h](j)}(h``max_scan_ssids``h]j)}(hj.h]hmax_scan_ssids}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM>hj.ubj6)}(hhh]h)}(hAmaximum number of SSIDs the device can scan for in any given scanh]hAmaximum number of SSIDs the device can scan for in any given scan}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM=hj.ubah}(h]h ]h"]h$]h&]uh1j5hj.ubeh}(h]h ]h"]h$]h&]uh1jhj.hM>hj)ubj)}(hh``max_sched_scan_reqs`` maximum number of scheduled scan requests that the device can run concurrently. h](j)}(h``max_sched_scan_reqs``h]j)}(hj/h]hmax_sched_scan_reqs}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM@hj/ubj6)}(hhh]h)}(hOmaximum number of scheduled scan requests that the device can run concurrently.h]hOmaximum number of scheduled scan requests that the device can run concurrently.}(hj1/hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM?hj./ubah}(h]h ]h"]h$]h&]uh1j5hj/ubeh}(h]h ]h"]h$]h&]uh1jhj-/hM@hj)ubj)}(he``max_sched_scan_ssids`` maximum number of SSIDs the device can scan for in any given scheduled scan h](j)}(h``max_sched_scan_ssids``h]j)}(hjR/h]hmax_sched_scan_ssids}(hjT/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjP/ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMBhjL/ubj6)}(hhh]h)}(hKmaximum number of SSIDs the device can scan for in any given scheduled scanh]hKmaximum number of SSIDs the device can scan for in any given scheduled scan}(hjk/hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMAhjh/ubah}(h]h ]h"]h$]h&]uh1j5hjL/ubeh}(h]h ]h"]h$]h&]uh1jhjg/hMBhj)ubj)}(h``max_match_sets`` maximum number of match sets the device can handle when performing a scheduled scan, 0 if filtering is not supported. h](j)}(h``max_match_sets``h]j)}(hj/h]hmax_match_sets}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMEhj/ubj6)}(hhh]h)}(humaximum number of match sets the device can handle when performing a scheduled scan, 0 if filtering is not supported.h]humaximum number of match sets the device can handle when performing a scheduled scan, 0 if filtering is not supported.}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMChj/ubah}(h]h ]h"]h$]h&]uh1j5hj/ubeh}(h]h ]h"]h$]h&]uh1jhj/hMEhj)ubj)}(h``max_scan_ie_len`` maximum length of user-controlled IEs device can add to probe request frames transmitted during a scan, must not include fixed IEs like supported rates h](j)}(h``max_scan_ie_len``h]j)}(hj/h]hmax_scan_ie_len}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMHhj/ubj6)}(hhh]h)}(hmaximum length of user-controlled IEs device can add to probe request frames transmitted during a scan, must not include fixed IEs like supported ratesh]hmaximum length of user-controlled IEs device can add to probe request frames transmitted during a scan, must not include fixed IEs like supported rates}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMFhj/ubah}(h]h ]h"]h$]h&]uh1j5hj/ubeh}(h]h ]h"]h$]h&]uh1jhj/hMHhj)ubj)}(hK``max_sched_scan_ie_len`` same as max_scan_ie_len, but for scheduled scans h](j)}(h``max_sched_scan_ie_len``h]j)}(hj0h]hmax_sched_scan_ie_len}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMJhj/ubj6)}(hhh]h)}(h0same as max_scan_ie_len, but for scheduled scansh]h0same as max_scan_ie_len, but for scheduled scans}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMIhj0ubah}(h]h ]h"]h$]h&]uh1j5hj/ubeh}(h]h ]h"]h$]h&]uh1jhj0hMJhj)ubj)}(h``max_sched_scan_plans`` maximum number of scan plans (scan interval and number of iterations) for scheduled scan supported by the device. h](j)}(h``max_sched_scan_plans``h]j)}(hj:0h]hmax_sched_scan_plans}(hj<0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj80ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMLhj40ubj6)}(hhh]h)}(hqmaximum number of scan plans (scan interval and number of iterations) for scheduled scan supported by the device.h]hqmaximum number of scan plans (scan interval and number of iterations) for scheduled scan supported by the device.}(hjS0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMKhjP0ubah}(h]h ]h"]h$]h&]uh1j5hj40ubeh}(h]h ]h"]h$]h&]uh1jhjO0hMLhj)ubj)}(ho``max_sched_scan_plan_interval`` maximum interval (in seconds) for a single scan plan supported by the device. h](j)}(h ``max_sched_scan_plan_interval``h]j)}(hjt0h]hmax_sched_scan_plan_interval}(hjv0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjr0ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMNhjn0ubj6)}(hhh]h)}(hMmaximum interval (in seconds) for a single scan plan supported by the device.h]hMmaximum interval (in seconds) for a single scan plan supported by the device.}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMMhj0ubah}(h]h ]h"]h$]h&]uh1j5hjn0ubeh}(h]h ]h"]h$]h&]uh1jhj0hMNhj)ubj)}(hp``max_sched_scan_plan_iterations`` maximum number of iterations for a single scan plan supported by the device. h](j)}(h"``max_sched_scan_plan_iterations``h]j)}(hj0h]hmax_sched_scan_plan_iterations}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMPhj0ubj6)}(hhh]h)}(hLmaximum number of iterations for a single scan plan supported by the device.h]hLmaximum number of iterations for a single scan plan supported by the device.}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMOhj0ubah}(h]h ]h"]h$]h&]uh1j5hj0ubeh}(h]h ]h"]h$]h&]uh1jhj0hMPhj)ubj)}(h6``n_cipher_suites`` number of supported cipher suites h](j)}(h``n_cipher_suites``h]j)}(hj0h]hn_cipher_suites}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj0ubj6)}(hhh]h)}(h!number of supported cipher suitesh]h!number of supported cipher suites}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0hMhj0ubah}(h]h ]h"]h$]h&]uh1j5hj0ubeh}(h]h ]h"]h$]h&]uh1jhj0hMhj)ubj)}(h*``cipher_suites`` supported cipher suites h](j)}(h``cipher_suites``h]j)}(hj!1h]h cipher_suites}(hj#1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj1ubj6)}(hhh]h)}(hsupported cipher suitesh]hsupported cipher suites}(hj:1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj61hMhj71ubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhj61hMhj)ubj)}(h0``n_akm_suites`` number of supported AKM suites h](j)}(h``n_akm_suites``h]j)}(hjZ1h]h n_akm_suites}(hj\1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjX1ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjT1ubj6)}(hhh]h)}(hnumber of supported AKM suitesh]hnumber of supported AKM suites}(hjs1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjo1hM hjp1ubah}(h]h ]h"]h$]h&]uh1j5hjT1ubeh}(h]h ]h"]h$]h&]uh1jhjo1hM hj)ubj)}(h``akm_suites`` supported AKM suites. These are the default AKMs supported if the supported AKMs not advertized for a specific interface type in iftype_akm_suites. h](j)}(h``akm_suites``h]j)}(hj1h]h akm_suites}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj1ubj6)}(hhh]h)}(hsupported AKM suites. These are the default AKMs supported if the supported AKMs not advertized for a specific interface type in iftype_akm_suites.h]hsupported AKM suites. These are the default AKMs supported if the supported AKMs not advertized for a specific interface type in iftype_akm_suites.}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj1ubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhj1hM hj)ubj)}(h``iftype_akm_suites`` array of supported akm suites info per interface type. Note that the bits in **iftypes_mask** inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_akm_suites). h](j)}(h``iftype_akm_suites``h]j)}(hj1h]hiftype_akm_suites}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj1ubj6)}(hhh]h)}(harray of supported akm suites info per interface type. Note that the bits in **iftypes_mask** inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_akm_suites).h](hMarray of supported akm suites info per interface type. Note that the bits in }(hj1hhhNhNubj)}(h**iftypes_mask**h]h iftypes_mask}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1ubh inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_akm_suites).}(hj1hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj1ubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhj1hMhj)ubj)}(hm``num_iftype_akm_suites`` number of interface types for which supported akm suites are specified separately. h](j)}(h``num_iftype_akm_suites``h]j)}(hj2h]hnum_iftype_akm_suites}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj2ubj6)}(hhh]h)}(hRnumber of interface types for which supported akm suites are specified separately.h]hRnumber of interface types for which supported akm suites are specified separately.}(hj22hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj/2ubah}(h]h ]h"]h$]h&]uh1j5hj2ubeh}(h]h ]h"]h$]h&]uh1jhj.2hMhj)ubj)}(hD``retry_short`` Retry limit for short frames (dot11ShortRetryLimit) h](j)}(h``retry_short``h]j)}(hjS2h]h retry_short}(hjU2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQ2ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjM2ubj6)}(hhh]h)}(h3Retry limit for short frames (dot11ShortRetryLimit)h]h3Retry limit for short frames (dot11ShortRetryLimit)}(hjl2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjh2hMhji2ubah}(h]h ]h"]h$]h&]uh1j5hjM2ubeh}(h]h ]h"]h$]h&]uh1jhjh2hMhj)ubj)}(hA``retry_long`` Retry limit for long frames (dot11LongRetryLimit) h](j)}(h``retry_long``h]j)}(hj2h]h retry_long}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj2ubj6)}(hhh]h)}(h1Retry limit for long frames (dot11LongRetryLimit)h]h1Retry limit for long frames (dot11LongRetryLimit)}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2hMhj2ubah}(h]h ]h"]h$]h&]uh1j5hj2ubeh}(h]h ]h"]h$]h&]uh1jhj2hMhj)ubj)}(h``frag_threshold`` Fragmentation threshold (dot11FragmentationThreshold); -1 = fragmentation disabled, only odd values >= 256 used h](j)}(h``frag_threshold``h]j)}(hj2h]hfrag_threshold}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj2ubj6)}(hhh]h)}(hoFragmentation threshold (dot11FragmentationThreshold); -1 = fragmentation disabled, only odd values >= 256 usedh]hoFragmentation threshold (dot11FragmentationThreshold); -1 = fragmentation disabled, only odd values >= 256 used}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj2ubah}(h]h ]h"]h$]h&]uh1j5hj2ubeh}(h]h ]h"]h$]h&]uh1jhj2hMhj)ubj)}(hK``rts_threshold`` RTS threshold (dot11RTSThreshold); -1 = RTS/CTS disabled h](j)}(h``rts_threshold``h]j)}(hj2h]h rts_threshold}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj2ubj6)}(hhh]h)}(h8RTS threshold (dot11RTSThreshold); -1 = RTS/CTS disabledh]h8RTS threshold (dot11RTSThreshold); -1 = RTS/CTS disabled}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMhj3ubah}(h]h ]h"]h$]h&]uh1j5hj2ubeh}(h]h ]h"]h$]h&]uh1jhj3hMhj)ubj)}(h*``coverage_class`` current coverage class h](j)}(h``coverage_class``h]j)}(hj83h]hcoverage_class}(hj:3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj63ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMQhj23ubj6)}(hhh]h)}(hcurrent coverage classh]hcurrent coverage class}(hjQ3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjM3hMQhjN3ubah}(h]h ]h"]h$]h&]uh1j5hj23ubeh}(h]h ]h"]h$]h&]uh1jhjM3hMQhj)ubj)}(h6``fw_version`` firmware version for ethtool reporting h](j)}(h``fw_version``h]j)}(hjq3h]h fw_version}(hjs3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjo3ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMRhjk3ubj6)}(hhh]h)}(h&firmware version for ethtool reportingh]h&firmware version for ethtool reporting}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMRhj3ubah}(h]h ]h"]h$]h&]uh1j5hjk3ubeh}(h]h ]h"]h$]h&]uh1jhj3hMRhj)ubj)}(h6``hw_version`` hardware version for ethtool reporting h](j)}(h``hw_version``h]j)}(hj3h]h hw_version}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMShj3ubj6)}(hhh]h)}(h&hardware version for ethtool reportingh]h&hardware version for ethtool reporting}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMShj3ubah}(h]h ]h"]h$]h&]uh1j5hj3ubeh}(h]h ]h"]h$]h&]uh1jhj3hMShj)ubj)}(h&``wowlan`` WoWLAN support information h](j)}(h ``wowlan``h]j)}(hj3h]hwowlan}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMmhj3ubj6)}(hhh]h)}(hWoWLAN support informationh]hWoWLAN support information}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMmhj3ubah}(h]h ]h"]h$]h&]uh1j5hj3ubeh}(h]h ]h"]h$]h&]uh1jhj3hMmhj)ubj)}(h``wowlan_config`` current WoWLAN configuration; this should usually not be used since access to it is necessarily racy, use the parameter passed to the suspend() operation instead. h](j)}(h``wowlan_config``h]j)}(hj4h]h wowlan_config}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMphj4ubj6)}(hhh]h)}(hcurrent WoWLAN configuration; this should usually not be used since access to it is necessarily racy, use the parameter passed to the suspend() operation instead.h]hcurrent WoWLAN configuration; this should usually not be used since access to it is necessarily racy, use the parameter passed to the suspend() operation instead.}(hj54hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMnhj24ubah}(h]h ]h"]h$]h&]uh1j5hj4ubeh}(h]h ]h"]h$]h&]uh1jhj14hMphj)ubj)}(hk``max_remain_on_channel_duration`` Maximum time a remain-on-channel operation may request, if implemented. h](j)}(h"``max_remain_on_channel_duration``h]j)}(hjV4h]hmax_remain_on_channel_duration}(hjX4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjT4ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMkhjP4ubj6)}(hhh]h)}(hGMaximum time a remain-on-channel operation may request, if implemented.h]hGMaximum time a remain-on-channel operation may request, if implemented.}(hjo4hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMjhjl4ubah}(h]h ]h"]h$]h&]uh1j5hjP4ubeh}(h]h ]h"]h$]h&]uh1jhjk4hMkhj)ubj)}(h@``max_num_pmkids`` maximum number of PMKIDs supported by device h](j)}(h``max_num_pmkids``h]j)}(hj4h]hmax_num_pmkids}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMThj4ubj6)}(hhh]h)}(h,maximum number of PMKIDs supported by deviceh]h,maximum number of PMKIDs supported by device}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4hMThj4ubah}(h]h ]h"]h$]h&]uh1j5hj4ubeh}(h]h ]h"]h$]h&]uh1jhj4hMThj)ubj)}(h``available_antennas_tx`` bitmap of antennas which are available to be configured as TX antennas. Antenna configuration commands will be rejected unless this or **available_antennas_rx** is set. h](j)}(h``available_antennas_tx``h]j)}(hj4h]havailable_antennas_tx}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM_hj4ubj6)}(hhh]h)}(hbitmap of antennas which are available to be configured as TX antennas. Antenna configuration commands will be rejected unless this or **available_antennas_rx** is set.h](hbitmap of antennas which are available to be configured as TX antennas. Antenna configuration commands will be rejected unless this or }(hj4hhhNhNubj)}(h**available_antennas_rx**h]havailable_antennas_rx}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4ubh is set.}(hj4hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM]hj4ubah}(h]h ]h"]h$]h&]uh1j5hj4ubeh}(h]h ]h"]h$]h&]uh1jhj4hM_hj)ubj)}(h``available_antennas_rx`` bitmap of antennas which are available to be configured as RX antennas. Antenna configuration commands will be rejected unless this or **available_antennas_tx** is set. h](j)}(h``available_antennas_rx``h]j)}(hj5h]havailable_antennas_rx}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMchj5ubj6)}(hhh]h)}(hbitmap of antennas which are available to be configured as RX antennas. Antenna configuration commands will be rejected unless this or **available_antennas_tx** is set.h](hbitmap of antennas which are available to be configured as RX antennas. Antenna configuration commands will be rejected unless this or }(hj.5hhhNhNubj)}(h**available_antennas_tx**h]havailable_antennas_tx}(hj65hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.5ubh is set.}(hj.5hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMahj+5ubah}(h]h ]h"]h$]h&]uh1j5hj5ubeh}(h]h ]h"]h$]h&]uh1jhj*5hMchj)ubj)}(hX``probe_resp_offload`` Bitmap of supported protocols for probe response offloading. See :c:type:`enum nl80211_probe_resp_offload_support_attr `. Only valid when the wiphy flag **WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD** is set. h](j)}(h``probe_resp_offload``h]j)}(hja5h]hprobe_resp_offload}(hjc5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_5ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMghj[5ubj6)}(hhh]h)}(hBitmap of supported protocols for probe response offloading. See :c:type:`enum nl80211_probe_resp_offload_support_attr `. Only valid when the wiphy flag **WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD** is set.h](hABitmap of supported protocols for probe response offloading. See }(hjz5hhhNhNubh)}(h`:c:type:`enum nl80211_probe_resp_offload_support_attr `h]j)}(hj5h]h,enum nl80211_probe_resp_offload_support_attr}(hj5hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6'nl80211_probe_resp_offload_support_attruh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMehjz5ubh!. Only valid when the wiphy flag }(hjz5hhhNhNubj)}(h$**WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD**h]h WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjz5ubh is set.}(hjz5hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj5hMehjw5ubah}(h]h ]h"]h$]h&]uh1j5hj[5ubeh}(h]h ]h"]h$]h&]uh1jhjv5hMghj)ubj)}(hX``extended_capabilities`` extended capabilities supported by the driver, additional capabilities might be supported by userspace; these are the 802.11 extended capabilities ("Extended Capabilities element") and are in the same format as in the information element. See 802.11-2012 8.4.2.29 for the defined fields. These are the default extended capabilities to be used if the capabilities are not specified for a specific interface type in iftype_ext_capab. h](j)}(h``extended_capabilities``h]j)}(hj5h]hextended_capabilities}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj5ubj6)}(hhh]h)}(hXextended capabilities supported by the driver, additional capabilities might be supported by userspace; these are the 802.11 extended capabilities ("Extended Capabilities element") and are in the same format as in the information element. See 802.11-2012 8.4.2.29 for the defined fields. These are the default extended capabilities to be used if the capabilities are not specified for a specific interface type in iftype_ext_capab.h]hXextended capabilities supported by the driver, additional capabilities might be supported by userspace; these are the 802.11 extended capabilities (“Extended Capabilities element”) and are in the same format as in the information element. See 802.11-2012 8.4.2.29 for the defined fields. These are the default extended capabilities to be used if the capabilities are not specified for a specific interface type in iftype_ext_capab.}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM~hj5ubah}(h]h ]h"]h$]h&]uh1j5hj5ubeh}(h]h ]h"]h$]h&]uh1jhj5hMhj)ubj)}(h8``extended_capabilities_mask`` mask of the valid values h](j)}(h``extended_capabilities_mask``h]j)}(hj 6h]hextended_capabilities_mask}(hj 6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj6ubj6)}(hhh]h)}(hmask of the valid valuesh]hmask of the valid values}(hj#6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hMhj 6ubah}(h]h ]h"]h$]h&]uh1j5hj6ubeh}(h]h ]h"]h$]h&]uh1jhj6hMhj)ubj)}(hB``extended_capabilities_len`` length of the extended capabilities h](j)}(h``extended_capabilities_len``h]j)}(hjC6h]hextended_capabilities_len}(hjE6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjA6ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj=6ubj6)}(hhh]h)}(h#length of the extended capabilitiesh]h#length of the extended capabilities}(hj\6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjX6hMhjY6ubah}(h]h ]h"]h$]h&]uh1j5hj=6ubeh}(h]h ]h"]h$]h&]uh1jhjX6hMhj)ubj)}(hG``iftype_ext_capab`` array of extended capabilities per interface type h](j)}(h``iftype_ext_capab``h]j)}(hj|6h]hiftype_ext_capab}(hj~6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjz6ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjv6ubj6)}(hhh]h)}(h1array of extended capabilities per interface typeh]h1array of extended capabilities per interface type}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hMhj6ubah}(h]h ]h"]h$]h&]uh1j5hjv6ubeh}(h]h ]h"]h$]h&]uh1jhj6hMhj)ubj)}(hm``num_iftype_ext_capab`` number of interface types for which extended capabilities are specified separately. h](j)}(h``num_iftype_ext_capab``h]j)}(hj6h]hnum_iftype_ext_capab}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj6ubj6)}(hhh]h)}(hSnumber of interface types for which extended capabilities are specified separately.h]hSnumber of interface types for which extended capabilities are specified separately.}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj6ubah}(h]h ]h"]h$]h&]uh1j5hj6ubeh}(h]h ]h"]h$]h&]uh1jhj6hMhj)ubj)}(hp``privid`` a pointer that drivers can use to identify if an arbitrary wiphy is theirs, e.g. in global notifiers h](j)}(h ``privid``h]j)}(hj6h]hprivid}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMVhj6ubj6)}(hhh]h)}(hda pointer that drivers can use to identify if an arbitrary wiphy is theirs, e.g. in global notifiersh]hda pointer that drivers can use to identify if an arbitrary wiphy is theirs, e.g. in global notifiers}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMUhj7ubah}(h]h ]h"]h$]h&]uh1j5hj6ubeh}(h]h ]h"]h$]h&]uh1jhj7hMVhj)ubj)}(hD``bands`` information about bands/channels supported by this device h](j)}(h ``bands``h]j)}(hj)7h]hbands}(hj+7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'7ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMWhj#7ubj6)}(hhh]h)}(h9information about bands/channels supported by this deviceh]h9information about bands/channels supported by this device}(hjB7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>7hMWhj?7ubah}(h]h ]h"]h$]h&]uh1j5hj#7ubeh}(h]h ]h"]h$]h&]uh1jhj>7hMWhj)ubj)}(h``reg_notifier`` the driver's regulatory notification callback, note that if your driver uses wiphy_apply_custom_regulatory() the reg_notifier's request can be passed as NULL h](j)}(h``reg_notifier``h]j)}(hjb7h]h reg_notifier}(hjd7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`7ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj\7ubj6)}(hhh]h)}(hthe driver's regulatory notification callback, note that if your driver uses wiphy_apply_custom_regulatory() the reg_notifier's request can be passed as NULLh]hthe driver’s regulatory notification callback, note that if your driver uses wiphy_apply_custom_regulatory() the reg_notifier’s request can be passed as NULL}(hj{7hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjx7ubah}(h]h ]h"]h$]h&]uh1j5hj\7ubeh}(h]h ]h"]h$]h&]uh1jhjw7hMhj)ubj)}(h``radio_cfg`` configuration of radios belonging to a muli-radio wiphy. This struct contains a list of all radio specific attributes and should be used only for multi-radio wiphy. h](j)}(h ``radio_cfg``h]j)}(hj7h]h radio_cfg}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj7ubj6)}(hhh]h)}(hconfiguration of radios belonging to a muli-radio wiphy. This struct contains a list of all radio specific attributes and should be used only for multi-radio wiphy.h]hconfiguration of radios belonging to a muli-radio wiphy. This struct contains a list of all radio specific attributes and should be used only for multi-radio wiphy.}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj7ubah}(h]h ]h"]h$]h&]uh1j5hj7ubeh}(h]h ]h"]h$]h&]uh1jhj7hMhj)ubj)}(h``regd`` the driver's regulatory domain, if one was requested via the regulatory_hint() API. This can be used by the driver on the reg_notifier() if it chooses to ignore future regulatory domain changes caused by other drivers. h](j)}(h``regd``h]j)}(hj7h]hregd}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj7ubj6)}(hhh]h)}(hthe driver's regulatory domain, if one was requested via the regulatory_hint() API. This can be used by the driver on the reg_notifier() if it chooses to ignore future regulatory domain changes caused by other drivers.h]hthe driver’s regulatory domain, if one was requested via the regulatory_hint() API. This can be used by the driver on the reg_notifier() if it chooses to ignore future regulatory domain changes caused by other drivers.}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj7ubah}(h]h ]h"]h$]h&]uh1j5hj7ubeh}(h]h ]h"]h$]h&]uh1jhj7hMhj)ubj)}(h``dev`` (virtual) struct device for this wiphy. The item in /sys/class/ieee80211/ points to this. You need use set_wiphy_dev() (see below). h](j)}(h``dev``h]j)}(hj8h]hdev}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM+hj 8ubj6)}(hhh]h)}(h(virtual) struct device for this wiphy. The item in /sys/class/ieee80211/ points to this. You need use set_wiphy_dev() (see below).h]h(virtual) struct device for this wiphy. The item in /sys/class/ieee80211/ points to this. You need use set_wiphy_dev() (see below).}(hj)8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM)hj&8ubah}(h]h ]h"]h$]h&]uh1j5hj 8ubeh}(h]h ]h"]h$]h&]uh1jhj%8hM+hj)ubj)}(h[``registered`` protects ->resume and ->suspend sysfs callbacks against unregister hardware h](j)}(h``registered``h]j)}(hjJ8h]h registered}(hjL8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjH8ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM&hjD8ubj6)}(hhh]h)}(hKprotects ->resume and ->suspend sysfs callbacks against unregister hardwareh]hKprotects ->resume and ->suspend sysfs callbacks against unregister hardware}(hjc8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM%hj`8ubah}(h]h ]h"]h$]h&]uh1j5hjD8ubeh}(h]h ]h"]h$]h&]uh1jhj_8hM&hj)ubj)}(h``debugfsdir`` debugfs directory used for this wiphy (ieee80211/). It will be renamed automatically on wiphy renames h](j)}(h``debugfsdir``h]j)}(hj8h]h debugfsdir}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM(hj~8ubj6)}(hhh]h)}(hpdebugfs directory used for this wiphy (ieee80211/). It will be renamed automatically on wiphy renamesh]hpdebugfs directory used for this wiphy (ieee80211/). It will be renamed automatically on wiphy renames}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM'hj8ubah}(h]h ]h"]h$]h&]uh1j5hj~8ubeh}(h]h ]h"]h$]h&]uh1jhj8hM(hj)ubj)}(hk``ht_capa_mod_mask`` Specify what ht_cap values can be over-ridden. If null, then none can be over-ridden. h](j)}(h``ht_capa_mod_mask``h]j)}(hj8h]hht_capa_mod_mask}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMthj8ubj6)}(hhh]h)}(hUSpecify what ht_cap values can be over-ridden. If null, then none can be over-ridden.h]hUSpecify what ht_cap values can be over-ridden. If null, then none can be over-ridden.}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMshj8ubah}(h]h ]h"]h$]h&]uh1j5hj8ubeh}(h]h ]h"]h$]h&]uh1jhj8hMthj)ubj)}(ho``vht_capa_mod_mask`` Specify what VHT capabilities can be over-ridden. If null, then none can be over-ridden. h](j)}(h``vht_capa_mod_mask``h]j)}(hj8h]hvht_capa_mod_mask}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMvhj8ubj6)}(hhh]h)}(hXSpecify what VHT capabilities can be over-ridden. If null, then none can be over-ridden.h]hXSpecify what VHT capabilities can be over-ridden. If null, then none can be over-ridden.}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMuhj9ubah}(h]h ]h"]h$]h&]uh1j5hj8ubeh}(h]h ]h"]h$]h&]uh1jhj 9hMvhj)ubj)}(h``wdev_list`` the list of associated (virtual) interfaces; this list must not be modified by the driver, but can be read with RTNL/RCU protection. h](j)}(h ``wdev_list``h]j)}(hj29h]h wdev_list}(hj49hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj09ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMyhj,9ubj6)}(hhh]h)}(hthe list of associated (virtual) interfaces; this list must not be modified by the driver, but can be read with RTNL/RCU protection.h]hthe list of associated (virtual) interfaces; this list must not be modified by the driver, but can be read with RTNL/RCU protection.}(hjK9hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMxhjH9ubah}(h]h ]h"]h$]h&]uh1j5hj,9ubeh}(h]h ]h"]h$]h&]uh1jhjG9hMyhj)ubj)}(h=``_net`` the network namespace this wiphy currently lives in h](j)}(h``_net``h]j)}(hjl9h]h_net}(hjn9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjj9ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjf9ubj6)}(hhh]h)}(h3the network namespace this wiphy currently lives inh]h3the network namespace this wiphy currently lives in}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hMhj9ubah}(h]h ]h"]h$]h&]uh1j5hjf9ubeh}(h]h ]h"]h$]h&]uh1jhj9hMhj)ubj)}(h%``wext`` wireless extension handlers h](j)}(h``wext``h]j)}(hj9h]hwext}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM,hj9ubj6)}(hhh]h)}(hwireless extension handlersh]hwireless extension handlers}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hM,hj9ubah}(h]h ]h"]h$]h&]uh1j5hj9ubeh}(h]h ]h"]h$]h&]uh1jhj9hM,hj)ubj)}(h3``coalesce`` packet coalescing support information h](j)}(h ``coalesce``h]j)}(hj9h]hcoalesce}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj9ubj6)}(hhh]h)}(h%packet coalescing support informationh]h%packet coalescing support information}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hMhj9ubah}(h]h ]h"]h$]h&]uh1j5hj9ubeh}(h]h ]h"]h$]h&]uh1jhj9hMhj)ubj)}(hG``vendor_commands`` array of vendor commands supported by the hardware h](j)}(h``vendor_commands``h]j)}(hj:h]hvendor_commands}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj:ubj6)}(hhh]h)}(h2array of vendor commands supported by the hardwareh]h2array of vendor commands supported by the hardware}(hj0:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,:hMhj-:ubah}(h]h ]h"]h$]h&]uh1j5hj:ubeh}(h]h ]h"]h$]h&]uh1jhj,:hMhj)ubj)}(hC``vendor_events`` array of vendor events supported by the hardware h](j)}(h``vendor_events``h]j)}(hjP:h]h vendor_events}(hjR:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjN:ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjJ:ubj6)}(hhh]h)}(h0array of vendor events supported by the hardwareh]h0array of vendor events supported by the hardware}(hji:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhje:hMhjf:ubah}(h]h ]h"]h$]h&]uh1j5hjJ:ubeh}(h]h ]h"]h$]h&]uh1jhje:hMhj)ubj)}(h0``n_vendor_commands`` number of vendor commands h](j)}(h``n_vendor_commands``h]j)}(hj:h]hn_vendor_commands}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj:ubj6)}(hhh]h)}(hnumber of vendor commandsh]hnumber of vendor commands}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:hMhj:ubah}(h]h ]h"]h$]h&]uh1j5hj:ubeh}(h]h ]h"]h$]h&]uh1jhj:hMhj)ubj)}(h,``n_vendor_events`` number of vendor events h](j)}(h``n_vendor_events``h]j)}(hj:h]hn_vendor_events}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj:ubj6)}(hhh]h)}(hnumber of vendor eventsh]hnumber of vendor events}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:hMhj:ubah}(h]h ]h"]h$]h&]uh1j5hj:ubeh}(h]h ]h"]h$]h&]uh1jhj:hMhj)ubj)}(hX``max_ap_assoc_sta`` maximum number of associated stations supported in AP mode (including P2P GO) or 0 to indicate no such limit is advertised. The driver is allowed to advertise a theoretical limit that it can reach in some cases, but may not always reach. h](j)}(h``max_ap_assoc_sta``h]j)}(hj:h]hmax_ap_assoc_sta}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj:ubj6)}(hhh]h)}(hmaximum number of associated stations supported in AP mode (including P2P GO) or 0 to indicate no such limit is advertised. The driver is allowed to advertise a theoretical limit that it can reach in some cases, but may not always reach.h]hmaximum number of associated stations supported in AP mode (including P2P GO) or 0 to indicate no such limit is advertised. The driver is allowed to advertise a theoretical limit that it can reach in some cases, but may not always reach.}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj;ubah}(h]h ]h"]h$]h&]uh1j5hj:ubeh}(h]h ]h"]h$]h&]uh1jhj;hMhj)ubj)}(h``max_num_csa_counters`` Number of supported csa_counters in beacons and probe responses. This value should be set if the driver wishes to limit the number of csa counters. Default (0) means infinite. h](j)}(h``max_num_csa_counters``h]j)}(hj5;h]hmax_num_csa_counters}(hj7;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3;ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj/;ubj6)}(hhh]h)}(hNumber of supported csa_counters in beacons and probe responses. This value should be set if the driver wishes to limit the number of csa counters. Default (0) means infinite.h]hNumber of supported csa_counters in beacons and probe responses. This value should be set if the driver wishes to limit the number of csa counters. Default (0) means infinite.}(hjN;hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjK;ubah}(h]h ]h"]h$]h&]uh1j5hj/;ubeh}(h]h ]h"]h$]h&]uh1jhjJ;hMhj)ubj)}(h``bss_select_support`` bitmask indicating the BSS selection criteria supported by the driver in the .connect() callback. The bit position maps to the attribute indices defined in :c:type:`enum nl80211_bss_select_attr `. h](j)}(h``bss_select_support``h]j)}(hjo;h]hbss_select_support}(hjq;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjm;ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhji;ubj6)}(hhh]h)}(hbitmask indicating the BSS selection criteria supported by the driver in the .connect() callback. The bit position maps to the attribute indices defined in :c:type:`enum nl80211_bss_select_attr `.h](hbitmask indicating the BSS selection criteria supported by the driver in the .connect() callback. The bit position maps to the attribute indices defined in }(hj;hhhNhNubh)}(h@:c:type:`enum nl80211_bss_select_attr `h]j)}(hj;h]henum nl80211_bss_select_attr}(hj;hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_bss_select_attruh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj;ubh.}(hj;hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj;hMhj;ubah}(h]h ]h"]h$]h&]uh1j5hji;ubeh}(h]h ]h"]h$]h&]uh1jhj;hMhj)ubj)}(h``nan_supported_bands`` bands supported by the device in NAN mode, a bitmap of :c:type:`enum nl80211_band ` values. For instance, for NL80211_BAND_2GHZ, bit 0 would be set (i.e. BIT(NL80211_BAND_2GHZ)). h](j)}(h``nan_supported_bands``h]j)}(hj;h]hnan_supported_bands}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj;ubj6)}(hhh]h)}(hbands supported by the device in NAN mode, a bitmap of :c:type:`enum nl80211_band ` values. For instance, for NL80211_BAND_2GHZ, bit 0 would be set (i.e. BIT(NL80211_BAND_2GHZ)).h](h7bands supported by the device in NAN mode, a bitmap of }(hj;hhhNhNubh)}(h*:c:type:`enum nl80211_band `h]j)}(hj;h]henum nl80211_band}(hj;hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6 nl80211_banduh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj;ubh` values. For instance, for NL80211_BAND_2GHZ, bit 0 would be set (i.e. BIT(NL80211_BAND_2GHZ)).}(hj;hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj <hMhj;ubah}(h]h ]h"]h$]h&]uh1j5hj;ubeh}(h]h ]h"]h$]h&]uh1jhj;hMhj)ubj)}(h=``txq_limit`` configuration of internal TX queue frame limit h](j)}(h ``txq_limit``h]j)}(hj)<h]h txq_limit}(hj+<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'<ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj#<ubj6)}(hhh]h)}(h.configuration of internal TX queue frame limith]h.configuration of internal TX queue frame limit}(hjB<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj><hMhj?<ubah}(h]h ]h"]h$]h&]uh1j5hj#<ubeh}(h]h ]h"]h$]h&]uh1jhj><hMhj)ubj)}(hB``txq_memory_limit`` configuration internal TX queue memory limit h](j)}(h``txq_memory_limit``h]j)}(hjb<h]htxq_memory_limit}(hjd<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`<ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj\<ubj6)}(hhh]h)}(h,configuration internal TX queue memory limith]h,configuration internal TX queue memory limit}(hj{<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjw<hMhjx<ubah}(h]h ]h"]h$]h&]uh1j5hj\<ubeh}(h]h ]h"]h$]h&]uh1jhjw<hMhj)ubj)}(hE``txq_quantum`` configuration of internal TX queue scheduler quantum h](j)}(h``txq_quantum``h]j)}(hj<h]h txq_quantum}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj<ubj6)}(hhh]h)}(h4configuration of internal TX queue scheduler quantumh]h4configuration of internal TX queue scheduler quantum}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hMhj<ubah}(h]h ]h"]h$]h&]uh1j5hj<ubeh}(h]h ]h"]h$]h&]uh1jhj<hMhj)ubj)}(hV``tx_queue_len`` allow setting transmit queue len for drivers not using wake_tx_queue h](j)}(h``tx_queue_len``h]j)}(hj<h]h tx_queue_len}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj<ubj6)}(hhh]h)}(hDallow setting transmit queue len for drivers not using wake_tx_queueh]hDallow setting transmit queue len for drivers not using wake_tx_queue}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj<ubah}(h]h ]h"]h$]h&]uh1j5hj<ubeh}(h]h ]h"]h$]h&]uh1jhj<hMhj)ubj)}(hE``support_mbssid`` can HW support association with nontransmitted AP h](j)}(h``support_mbssid``h]j)}(hj=h]hsupport_mbssid}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj =ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj=ubj6)}(hhh]h)}(h1can HW support association with nontransmitted APh]h1can HW support association with nontransmitted AP}(hj'=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#=hMhj$=ubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhj#=hMhj)ubj)}(h``support_only_he_mbssid`` don't parse MBSSID elements if it is not HE AP, in order to avoid compatibility issues. **support_mbssid** must be set for this to have any effect. h](j)}(h``support_only_he_mbssid``h]j)}(hjG=h]hsupport_only_he_mbssid}(hjI=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjE=ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjA=ubj6)}(hhh]h)}(hdon't parse MBSSID elements if it is not HE AP, in order to avoid compatibility issues. **support_mbssid** must be set for this to have any effect.h](hZdon’t parse MBSSID elements if it is not HE AP, in order to avoid compatibility issues. }(hj`=hhhNhNubj)}(h**support_mbssid**h]hsupport_mbssid}(hjh=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`=ubh) must be set for this to have any effect.}(hj`=hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj]=ubah}(h]h ]h"]h$]h&]uh1j5hjA=ubeh}(h]h ]h"]h$]h&]uh1jhj\=hMhj)ubj)}(h,``pmsr_capa`` peer measurement capabilities h](j)}(h ``pmsr_capa``h]j)}(hj=h]h pmsr_capa}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj=ubj6)}(hhh]h)}(hpeer measurement capabilitiesh]hpeer measurement capabilities}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=hMhj=ubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhj=hMhj)ubj)}(hP``tid_config_support`` describes the per-TID config support that the device has h](j)}(h``tid_config_support``h]j)}(hj=h]htid_config_support}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj=ubj6)}(hhh]h)}(h8describes the per-TID config support that the device hash]h8describes the per-TID config support that the device has}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj=ubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhj=hMhj)ubj)}(hh``tid_config_support.peer`` bitmap of attributes (configurations) supported by the driver for each peer h](j)}(h``tid_config_support.peer``h]j)}(hj>h]htid_config_support.peer}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj>ubj6)}(hhh]h)}(hKbitmap of attributes (configurations) supported by the driver for each peerh]hKbitmap of attributes (configurations) supported by the driver for each peer}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj>ubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhj>hMhj)ubj)}(hf``tid_config_support.vif`` bitmap of attributes (configurations) supported by the driver for each vif h](j)}(h``tid_config_support.vif``h]j)}(hj@>h]htid_config_support.vif}(hjB>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>>ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj:>ubj6)}(hhh]h)}(hJbitmap of attributes (configurations) supported by the driver for each vifh]hJbitmap of attributes (configurations) supported by the driver for each vif}(hjY>hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjV>ubah}(h]h ]h"]h$]h&]uh1j5hj:>ubeh}(h]h ]h"]h$]h&]uh1jhjU>hMhj)ubj)}(hb``tid_config_support.max_retry`` maximum supported retry count for long/short retry configuration h](j)}(h ``tid_config_support.max_retry``h]j)}(hjz>h]htid_config_support.max_retry}(hj|>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjx>ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjt>ubj6)}(hhh]h)}(h@maximum supported retry count for long/short retry configurationh]h@maximum supported retry count for long/short retry configuration}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj>ubah}(h]h ]h"]h$]h&]uh1j5hjt>ubeh}(h]h ]h"]h$]h&]uh1jhj>hMhj)ubj)}(h``max_data_retry_count`` maximum supported per TID retry count for configuration through the ``NL80211_TID_CONFIG_ATTR_RETRY_SHORT`` and ``NL80211_TID_CONFIG_ATTR_RETRY_LONG`` attributes h](j)}(h``max_data_retry_count``h]j)}(hj>h]hmax_data_retry_count}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj>ubj6)}(hhh]h)}(hmaximum supported per TID retry count for configuration through the ``NL80211_TID_CONFIG_ATTR_RETRY_SHORT`` and ``NL80211_TID_CONFIG_ATTR_RETRY_LONG`` attributesh](hDmaximum supported per TID retry count for configuration through the }(hj>hhhNhNubj)}(h'``NL80211_TID_CONFIG_ATTR_RETRY_SHORT``h]h#NL80211_TID_CONFIG_ATTR_RETRY_SHORT}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubh and }(hj>hhhNhNubj)}(h&``NL80211_TID_CONFIG_ATTR_RETRY_LONG``h]h"NL80211_TID_CONFIG_ATTR_RETRY_LONG}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubh attributes}(hj>hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj>ubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhj>hMhj)ubj)}(h&``sar_capa`` SAR control capabilities h](j)}(h ``sar_capa``h]j)}(hj?h]hsar_capa}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj ?ubj6)}(hhh]h)}(hSAR control capabilitiesh]hSAR control capabilities}(hj+?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'?hMhj(?ubah}(h]h ]h"]h$]h&]uh1j5hj ?ubeh}(h]h ]h"]h$]h&]uh1jhj'?hMhj)ubj)}(h-``rfkill`` a pointer to the rfkill structure h](j)}(h ``rfkill``h]j)}(hjK?h]hrfkill}(hjM?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjI?ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjE?ubj6)}(hhh]h)}(h!a pointer to the rfkill structureh]h!a pointer to the rfkill structure}(hjd?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`?hMhja?ubah}(h]h ]h"]h$]h&]uh1j5hjE?ubeh}(h]h ]h"]h$]h&]uh1jhj`?hMhj)ubj)}(h``mbssid_max_interfaces`` maximum number of interfaces supported by the driver in a multiple BSSID set. This field must be set to a non-zero value by the driver to advertise MBSSID support. h](j)}(h``mbssid_max_interfaces``h]j)}(hj?h]hmbssid_max_interfaces}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj~?ubj6)}(hhh]h)}(hmaximum number of interfaces supported by the driver in a multiple BSSID set. This field must be set to a non-zero value by the driver to advertise MBSSID support.h]hmaximum number of interfaces supported by the driver in a multiple BSSID set. This field must be set to a non-zero value by the driver to advertise MBSSID support.}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj?ubah}(h]h ]h"]h$]h&]uh1j5hj~?ubeh}(h]h ]h"]h$]h&]uh1jhj?hMhj)ubj)}(h``ema_max_profile_periodicity`` maximum profile periodicity supported by the driver. Setting this field to a non-zero value indicates that the driver supports enhanced multi-BSSID advertisements (EMA AP). h](j)}(h``ema_max_profile_periodicity``h]j)}(hj?h]hema_max_profile_periodicity}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj?ubj6)}(hhh]h)}(hmaximum profile periodicity supported by the driver. Setting this field to a non-zero value indicates that the driver supports enhanced multi-BSSID advertisements (EMA AP).h]hmaximum profile periodicity supported by the driver. Setting this field to a non-zero value indicates that the driver supports enhanced multi-BSSID advertisements (EMA AP).}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj?ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhj?hMhj)ubj)}(hX``max_num_akm_suites`` maximum number of AKM suites allowed for configuration through ``NL80211_CMD_CONNECT``, ``NL80211_CMD_ASSOCIATE`` and ``NL80211_CMD_START_AP``. Set to NL80211_MAX_NR_AKM_SUITES if not set by driver. If set by driver minimum allowed value is NL80211_MAX_NR_AKM_SUITES in order to avoid compatibility issues with legacy userspace and maximum allowed value is CFG80211_MAX_NUM_AKM_SUITES. h](j)}(h``max_num_akm_suites``h]j)}(hj?h]hmax_num_akm_suites}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj?ubj6)}(hhh]h)}(hXmaximum number of AKM suites allowed for configuration through ``NL80211_CMD_CONNECT``, ``NL80211_CMD_ASSOCIATE`` and ``NL80211_CMD_START_AP``. Set to NL80211_MAX_NR_AKM_SUITES if not set by driver. If set by driver minimum allowed value is NL80211_MAX_NR_AKM_SUITES in order to avoid compatibility issues with legacy userspace and maximum allowed value is CFG80211_MAX_NUM_AKM_SUITES.h](h?maximum number of AKM suites allowed for configuration through }(hj@hhhNhNubj)}(h``NL80211_CMD_CONNECT``h]hNL80211_CMD_CONNECT}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubh, }(hj@hhhNhNubj)}(h``NL80211_CMD_ASSOCIATE``h]hNL80211_CMD_ASSOCIATE}(hj+@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubh and }(hj@hhhNhNubj)}(h``NL80211_CMD_START_AP``h]hNL80211_CMD_START_AP}(hj=@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubh. Set to NL80211_MAX_NR_AKM_SUITES if not set by driver. If set by driver minimum allowed value is NL80211_MAX_NR_AKM_SUITES in order to avoid compatibility issues with legacy userspace and maximum allowed value is CFG80211_MAX_NUM_AKM_SUITES.}(hj@hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj@ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhj @hMhj)ubj)}(hXo``hw_timestamp_max_peers`` maximum number of peers that the driver supports enabling HW timestamping for concurrently. Setting this field to a non-zero value indicates that the driver supports HW timestamping. A value of ``CFG80211_HW_TIMESTAMP_ALL_PEERS`` indicates the driver supports enabling HW timestamping for all peers (i.e. no need to specify a mac address). h](j)}(h``hw_timestamp_max_peers``h]j)}(hjh@h]hhw_timestamp_max_peers}(hjj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjf@ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjb@ubj6)}(hhh]h)}(hXSmaximum number of peers that the driver supports enabling HW timestamping for concurrently. Setting this field to a non-zero value indicates that the driver supports HW timestamping. A value of ``CFG80211_HW_TIMESTAMP_ALL_PEERS`` indicates the driver supports enabling HW timestamping for all peers (i.e. no need to specify a mac address).h](hmaximum number of peers that the driver supports enabling HW timestamping for concurrently. Setting this field to a non-zero value indicates that the driver supports HW timestamping. A value of }(hj@hhhNhNubj)}(h#``CFG80211_HW_TIMESTAMP_ALL_PEERS``h]hCFG80211_HW_TIMESTAMP_ALL_PEERS}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubhn indicates the driver supports enabling HW timestamping for all peers (i.e. no need to specify a mac address).}(hj@hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj~@ubah}(h]h ]h"]h$]h&]uh1j5hjb@ubeh}(h]h ]h"]h$]h&]uh1jhj}@hMhj)ubj)}(h``n_radio`` number of radios h](j)}(h ``n_radio``h]j)}(hj@h]hn_radio}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj@ubj6)}(hhh]h)}(hnumber of radiosh]hnumber of radios}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@hMhj@ubah}(h]h ]h"]h$]h&]uh1j5hj@ubeh}(h]h ]h"]h$]h&]uh1jhj@hMhj)ubj)}(h)``radio`` radios belonging to this wiphy h](j)}(h ``radio``h]j)}(hj@h]hradio}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj@ubj6)}(hhh]h)}(hradios belonging to this wiphyh]hradios belonging to this wiphy}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjAhMhjAubah}(h]h ]h"]h$]h&]uh1j5hj@ubeh}(h]h ]h"]h$]h&]uh1jhjAhMhj)ubj)}(hG``priv`` driver private data (sized according to wiphy_new() parameter)h](j)}(h``priv``h]j)}(hj&Ah]hpriv}(hj(AhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$Aubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM,hj Aubj6)}(hhh]h)}(h>driver private data (sized according to wiphy_new() parameter)h]h>driver private data (sized according to wiphy_new() parameter)}(hj?AhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM-hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj:Gubj)}(h h]h }(hjKGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:Gubh)}(hhh]j)}(hwiphyh]hwiphy}(hj\GhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjYGubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj^GmodnameN classnameNj j )}j ]jF c.wiphy_devasbuh1hhj:Gubj)}(h h]h }(hjzGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:Gubj.)}(hj1h]h*}(hjGhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj:Gubj)}(hwiphyh]hwiphy}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:Gubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj6Gubah}(h]h ]h"]h$]h&]jjuh1jhjFhhhjFhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjFhhhjFhMubah}(h]jFah ](jjeh"]h$]h&]jj)jhuh1jhhjFhMhjFhhubj)}(hhh]h)}(hget wiphy dev pointerh]hget wiphy dev pointer}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjGhhubah}(h]h ]h"]h$]h&]uh1jhjFhhhjFhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjGjjGjjjuh1jchhhhhNhNubj)}(hu**Parameters** ``struct wiphy *wiphy`` The wiphy whose device struct to look up **Return** The dev of **wiphy**.h](h)}(h**Parameters**h]j)}(hjGh]h Parameters}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjGubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjGubj)}(hhh]j)}(hA``struct wiphy *wiphy`` The wiphy whose device struct to look up h](j)}(h``struct wiphy *wiphy``h]j)}(hjHh]hstruct wiphy *wiphy}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjGubj6)}(hhh]h)}(h(The wiphy whose device struct to look uph]h(The wiphy whose device struct to look up}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHhMhjHubah}(h]h ]h"]h$]h&]uh1j5hjGubeh}(h]h ]h"]h$]h&]uh1jhjHhMhjGubah}(h]h ]h"]h$]h&]uh1jhjGubh)}(h **Return**h]j)}(hj;Hh]hReturn}(hj=HhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9Hubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjGubh)}(hThe dev of **wiphy**.h](h The dev of }(hjQHhhhNhNubj)}(h **wiphy**h]hwiphy}(hjYHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQHubh.}(hjQHhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjGubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wiphy_name (C function) c.wiphy_namehNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(h3const char * wiphy_name (const struct wiphy *wiphy)h]jo)}(h1const char *wiphy_name(const struct wiphy *wiphy)h](ju)}(hconsth]hconst}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjHhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHhhhjHhMubj)}(hcharh]hchar}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHhhhjHhMubj)}(h h]h }(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHhhhjHhMubj.)}(hj1h]h*}(hjHhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjHhhhjHhMubj)}(h wiphy_nameh]j)}(h wiphy_nameh]h wiphy_name}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHubah}(h]h ](jjeh"]h$]h&]jjuh1jhjHhhhjHhMubj)}(h(const struct wiphy *wiphy)h]j)}(hconst struct wiphy *wiphyh](ju)}(hjHh]hconst}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjHubj)}(h h]h }(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHubju)}(hjh]hstruct}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjHubj)}(h h]h }(hj IhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHubh)}(hhh]j)}(hwiphyh]hwiphy}(hj1IhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.Iubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj3ImodnameN classnameNj j )}j ]j)}jjHsb c.wiphy_nameasbuh1hhjHubj)}(h h]h }(hjQIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHubj.)}(hj1h]h*}(hj_IhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjHubj)}(hwiphyh]hwiphy}(hjlIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjHubah}(h]h ]h"]h$]h&]jjuh1jhjHhhhjHhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjHhhhjHhMubah}(h]jHah ](jjeh"]h$]h&]jj)jhuh1jhhjHhMhjHhhubj)}(hhh]h)}(hget wiphy nameh]hget wiphy name}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjIhhubah}(h]h ]h"]h$]h&]uh1jhjHhhhjHhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjIjjIjjjuh1jchhhhhNhNubj)}(hr**Parameters** ``const struct wiphy *wiphy`` The wiphy whose name to return **Return** The name of **wiphy**.h](h)}(h**Parameters**h]j)}(hjIh]h Parameters}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjIubj)}(hhh]j)}(h=``const struct wiphy *wiphy`` The wiphy whose name to return h](j)}(h``const struct wiphy *wiphy``h]j)}(hjIh]hconst struct wiphy *wiphy}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjIubj6)}(hhh]h)}(hThe wiphy whose name to returnh]hThe wiphy whose name to return}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIhMhjIubah}(h]h ]h"]h$]h&]uh1j5hjIubeh}(h]h ]h"]h$]h&]uh1jhjIhMhjIubah}(h]h ]h"]h$]h&]uh1jhjIubh)}(h **Return**h]j)}(hjJh]hReturn}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjIubh)}(hThe name of **wiphy**.h](h The name of }(hj(JhhhNhNubj)}(h **wiphy**h]hwiphy}(hj0JhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj(Jubh.}(hj(JhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjIubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wiphy_new (C function) c.wiphy_newhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hJstruct wiphy * wiphy_new (const struct cfg80211_ops *ops, int sizeof_priv)h]jo)}(hHstruct wiphy *wiphy_new(const struct cfg80211_ops *ops, int sizeof_priv)h](ju)}(hjh]hstruct}(hjiJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjeJhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjwJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeJhhhjvJhMubh)}(hhh]j)}(hwiphyh]hwiphy}(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjJmodnameN classnameNj j )}j ]j)}j wiphy_newsb c.wiphy_newasbuh1hhjeJhhhjvJhMubj)}(h h]h }(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeJhhhjvJhMubj.)}(hj1h]h*}(hjJhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjeJhhhjvJhMubj)}(h wiphy_newh]j)}(hjJh]h wiphy_new}(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJubah}(h]h ](jjeh"]h$]h&]jjuh1jhjeJhhhjvJhMubj)}(h1(const struct cfg80211_ops *ops, int sizeof_priv)h](j)}(hconst struct cfg80211_ops *opsh](ju)}(hjHh]hconst}(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjJubj)}(h h]h }(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJubju)}(hjh]hstruct}(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjJubj)}(h h]h }(hj KhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJubh)}(hhh]j)}(h cfg80211_opsh]h cfg80211_ops}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjKmodnameN classnameNj j )}j ]jJ c.wiphy_newasbuh1hhjJubj)}(h h]h }(hj:KhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJubj.)}(hj1h]h*}(hjHKhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjJubj)}(hopsh]hops}(hjUKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjJubj)}(hint sizeof_privh](j)}(hinth]hint}(hjnKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjKubj)}(h h]h }(hj|KhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjKubj)}(h sizeof_privh]h sizeof_priv}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjKubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjJubeh}(h]h ]h"]h$]h&]jjuh1jhjeJhhhjvJhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjaJhhhjvJhMubah}(h]j\Jah ](jjeh"]h$]h&]jj)jhuh1jhhjvJhMhj^Jhhubj)}(hhh]h)}(h(create a new wiphy for use with cfg80211h]h(create a new wiphy for use with cfg80211}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjKhhubah}(h]h ]h"]h$]h&]uh1jhj^JhhhjvJhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjKjjKjjjuh1jchhhhhNhNubj)}(hX**Parameters** ``const struct cfg80211_ops *ops`` The configuration operations for this device ``int sizeof_priv`` The size of the private area to allocate **Description** Create a new wiphy and associate the given operations with it. **sizeof_priv** bytes are allocated for private use. **Return** A pointer to the new wiphy. This pointer must be assigned to each netdev's ieee80211_ptr for proper operation.h](h)}(h**Parameters**h]j)}(hjKh]h Parameters}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjKubj)}(hhh](j)}(hP``const struct cfg80211_ops *ops`` The configuration operations for this device h](j)}(h"``const struct cfg80211_ops *ops``h]j)}(hjKh]hconst struct cfg80211_ops *ops}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjKubj6)}(hhh]h)}(h,The configuration operations for this deviceh]h,The configuration operations for this device}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj LhMhj Lubah}(h]h ]h"]h$]h&]uh1j5hjKubeh}(h]h ]h"]h$]h&]uh1jhj LhMhjKubj)}(h=``int sizeof_priv`` The size of the private area to allocate h](j)}(h``int sizeof_priv``h]j)}(hj.Lh]hint sizeof_priv}(hj0LhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,Lubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj(Lubj6)}(hhh]h)}(h(The size of the private area to allocateh]h(The size of the private area to allocate}(hjGLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjCLhMhjDLubah}(h]h ]h"]h$]h&]uh1j5hj(Lubeh}(h]h ]h"]h$]h&]uh1jhjCLhMhjKubeh}(h]h ]h"]h$]h&]uh1jhjKubh)}(h**Description**h]j)}(hjiLh]h Description}(hjkLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjgLubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjKubh)}(hsCreate a new wiphy and associate the given operations with it. **sizeof_priv** bytes are allocated for private use.h](h?Create a new wiphy and associate the given operations with it. }(hjLhhhNhNubj)}(h**sizeof_priv**h]h sizeof_priv}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLubh% bytes are allocated for private use.}(hjLhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjKubh)}(h **Return**h]j)}(hjLh]hReturn}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjKubh)}(hnA pointer to the new wiphy. This pointer must be assigned to each netdev's ieee80211_ptr for proper operation.h]hpA pointer to the new wiphy. This pointer must be assigned to each netdev’s ieee80211_ptr for proper operation.}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjKubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wiphy_register (C function)c.wiphy_registerhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(h(int wiphy_register (struct wiphy *wiphy)h]jo)}(h'int wiphy_register(struct wiphy *wiphy)h](j)}(hinth]hint}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLhhhjLhMubj)}(hwiphy_registerh]j)}(hwiphy_registerh]hwiphy_register}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjMubah}(h]h ](jjeh"]h$]h&]jjuh1jhjLhhhjLhMubj)}(h(struct wiphy *wiphy)h]j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hj$MhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj Mubj)}(h h]h }(hj1MhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj Mubh)}(hhh]j)}(hwiphyh]hwiphy}(hjBMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj?Mubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjDMmodnameN classnameNj j )}j ]j)}jj Msbc.wiphy_registerasbuh1hhj Mubj)}(h h]h }(hjbMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj Mubj.)}(hj1h]h*}(hjpMhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj Mubj)}(hwiphyh]hwiphy}(hj}MhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj Mubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjMubah}(h]h ]h"]h$]h&]jjuh1jhjLhhhjLhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjLhhhjLhMubah}(h]jLah ](jjeh"]h$]h&]jj)jhuh1jhhjLhMhjLhhubj)}(hhh]h)}(hregister a wiphy with cfg80211h]hregister a wiphy with cfg80211}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjMhhubah}(h]h ]h"]h$]h&]uh1jhjLhhhjLhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjMjjMjjjuh1jchhhhhNhNubj)}(h**Parameters** ``struct wiphy *wiphy`` The wiphy to register. **Return** A non-negative wiphy index or a negative error code.h](h)}(h**Parameters**h]j)}(hjMh]h Parameters}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjMubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjMubj)}(hhh]j)}(h/``struct wiphy *wiphy`` The wiphy to register. h](j)}(h``struct wiphy *wiphy``h]j)}(hjMh]hstruct wiphy *wiphy}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjMubj6)}(hhh]h)}(hThe wiphy to register.h]hThe wiphy to register.}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjMhMhjMubah}(h]h ]h"]h$]h&]uh1j5hjMubeh}(h]h ]h"]h$]h&]uh1jhjMhMhjMubah}(h]h ]h"]h$]h&]uh1jhjMubh)}(h **Return**h]j)}(hj#Nh]hReturn}(hj%NhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!Nubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjMubh)}(h4A non-negative wiphy index or a negative error code.h]h4A non-negative wiphy index or a negative error code.}(hj9NhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjMubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wiphy_unregister (C function)c.wiphy_unregisterhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(h+void wiphy_unregister (struct wiphy *wiphy)h]jo)}(h*void wiphy_unregister(struct wiphy *wiphy)h](j)}(hvoidh]hvoid}(hjhNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdNhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjwNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdNhhhjvNhM ubj)}(hwiphy_unregisterh]j)}(hwiphy_unregisterh]hwiphy_unregister}(hjNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNubah}(h]h ](jjeh"]h$]h&]jjuh1jhjdNhhhjvNhM ubj)}(h(struct wiphy *wiphy)h]j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjNubj)}(h h]h }(hjNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNubh)}(hhh]j)}(hwiphyh]hwiphy}(hjNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjNmodnameN classnameNj j )}j ]j)}jjNsbc.wiphy_unregisterasbuh1hhjNubj)}(h h]h }(hjNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNubj.)}(hj1h]h*}(hjNhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjNubj)}(hwiphyh]hwiphy}(hjNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjNubah}(h]h ]h"]h$]h&]jjuh1jhjdNhhhjvNhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj`NhhhjvNhM ubah}(h]j[Nah ](jjeh"]h$]h&]jj)jhuh1jhhjvNhM hj]Nhhubj)}(hhh]h)}(h deregister a wiphy from cfg80211h]h deregister a wiphy from cfg80211}(hj(OhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj%Ohhubah}(h]h ]h"]h$]h&]uh1jhj]NhhhjvNhM ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj@Ojj@Ojjjuh1jchhhhhNhNubj)}(h**Parameters** ``struct wiphy *wiphy`` The wiphy to unregister. **Description** After this call, no more requests can be made with this priv pointer, but the call may sleep to wait for an outstanding request that is being handled.h](h)}(h**Parameters**h]j)}(hjJOh]h Parameters}(hjLOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHOubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjDOubj)}(hhh]j)}(h1``struct wiphy *wiphy`` The wiphy to unregister. h](j)}(h``struct wiphy *wiphy``h]j)}(hjiOh]hstruct wiphy *wiphy}(hjkOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgOubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjcOubj6)}(hhh]h)}(hThe wiphy to unregister.h]hThe wiphy to unregister.}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~OhM hjOubah}(h]h ]h"]h$]h&]uh1j5hjcOubeh}(h]h ]h"]h$]h&]uh1jhj~OhM hj`Oubah}(h]h ]h"]h$]h&]uh1jhjDOubh)}(h**Description**h]j)}(hjOh]h Description}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjOubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjDOubh)}(hAfter this call, no more requests can be made with this priv pointer, but the call may sleep to wait for an outstanding request that is being handled.h]hAfter this call, no more requests can be made with this priv pointer, but the call may sleep to wait for an outstanding request that is being handled.}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjDOubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wiphy_free (C function) c.wiphy_freehNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(h%void wiphy_free (struct wiphy *wiphy)h]jo)}(h$void wiphy_free(struct wiphy *wiphy)h](j)}(hvoidh]hvoid}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOhhhjOhMubj)}(h wiphy_freeh]j)}(h wiphy_freeh]h wiphy_free}(hj PhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjPubah}(h]h ](jjeh"]h$]h&]jjuh1jhjOhhhjOhMubj)}(h(struct wiphy *wiphy)h]j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hj&PhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj"Pubj)}(h h]h }(hj3PhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"Pubh)}(hhh]j)}(hwiphyh]hwiphy}(hjDPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAPubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjFPmodnameN classnameNj j )}j ]j)}jj Psb c.wiphy_freeasbuh1hhj"Pubj)}(h h]h }(hjdPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"Pubj.)}(hj1h]h*}(hjrPhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj"Pubj)}(hwiphyh]hwiphy}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"Pubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjPubah}(h]h ]h"]h$]h&]jjuh1jhjOhhhjOhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjOhhhjOhMubah}(h]jOah ](jjeh"]h$]h&]jj)jhuh1jhhjOhMhjOhhubj)}(hhh]h)}(h free wiphyh]h free wiphy}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjPhhubah}(h]h ]h"]h$]h&]uh1jhjOhhhjOhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjPjjPjjjuh1jchhhhhNhNubj)}(h;**Parameters** ``struct wiphy *wiphy`` The wiphy to freeh](h)}(h**Parameters**h]j)}(hjPh]h Parameters}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjPubj)}(hhh]j)}(h)``struct wiphy *wiphy`` The wiphy to freeh](j)}(h``struct wiphy *wiphy``h]j)}(hjPh]hstruct wiphy *wiphy}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjPubj6)}(hhh]h)}(hThe wiphy to freeh]hThe wiphy to free}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjQubah}(h]h ]h"]h$]h&]uh1j5hjPubeh}(h]h ]h"]h$]h&]uh1jhjPhMhjPubah}(h]h ]h"]h$]h&]uh1jhjPubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wireless_dev (C struct)c.wireless_devhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(h wireless_devh]jo)}(hstruct wireless_devh](ju)}(hjh]hstruct}(hjDQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj@Qhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjRQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@QhhhjQQhMubj)}(h wireless_devh]j)}(hj>Qh]h wireless_dev}(hjdQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`Qubah}(h]h ](jjeh"]h$]h&]jjuh1jhj@QhhhjQQhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjUubj6)}(hhh]h)}(hconnecting/connected BSS typeh]hconnecting/connected BSS type}(hj]UhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYUhM#hjZUubah}(h]h ]h"]h$]h&]uh1j5hj>Uubeh}(h]h ]h"]h$]h&]uh1jhjYUhM#hjQubj)}(hB``conn_owner_nlportid`` (private) connection owner socket port ID h](j)}(h``conn_owner_nlportid``h]j)}(hj}Uh]hconn_owner_nlportid}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{Uubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM$hjwUubj6)}(hhh]h)}(h)(private) connection owner socket port IDh]h)(private) connection owner socket port ID}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUhM$hjUubah}(h]h ]h"]h$]h&]uh1j5hjwUubeh}(h]h ]h"]h$]h&]uh1jhjUhM$hjQubj)}(h1``disconnect_wk`` (private) auto-disconnect work h](j)}(h``disconnect_wk``h]j)}(hjUh]h disconnect_wk}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM%hjUubj6)}(hhh]h)}(h(private) auto-disconnect workh]h(private) auto-disconnect work}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUhM%hjUubah}(h]h ]h"]h$]h&]uh1j5hjUubeh}(h]h ]h"]h$]h&]uh1jhjUhM%hjQubj)}(hD``disconnect_bssid`` (private) the BSSID to use for auto-disconnect h](j)}(h``disconnect_bssid``h]j)}(hjUh]hdisconnect_bssid}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM&hjUubj6)}(hhh]h)}(h.(private) the BSSID to use for auto-disconnecth]h.(private) the BSSID to use for auto-disconnect}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhM&hjVubah}(h]h ]h"]h$]h&]uh1j5hjUubeh}(h]h ]h"]h$]h&]uh1jhjVhM&hjQubj)}(h<``event_list`` (private) list for internal event processing h](j)}(h``event_list``h]j)}(hj(Vh]h event_list}(hj*VhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&Vubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM'hj"Vubj6)}(hhh]h)}(h,(private) list for internal event processingh]h,(private) list for internal event processing}(hjAVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=VhM'hj>Vubah}(h]h ]h"]h$]h&]uh1j5hj"Vubeh}(h]h ]h"]h$]h&]uh1jhj=VhM'hjQubj)}(h-``event_lock`` (private) lock for event list h](j)}(h``event_lock``h]j)}(hjaVh]h event_lock}(hjcVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_Vubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM(hj[Vubj6)}(hhh]h)}(h(private) lock for event listh]h(private) lock for event list}(hjzVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvVhM(hjwVubah}(h]h ]h"]h$]h&]uh1j5hj[Vubeh}(h]h ]h"]h$]h&]uh1jhjvVhM(hjQubj)}(h7``connected`` indicates if connected or not (STA mode) h](j)}(h ``connected``h]j)}(hjVh]h connected}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjVubj6)}(hhh]h)}(h(indicates if connected or not (STA mode)h]h(indicates if connected or not (STA mode)}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhMhjVubah}(h]h ]h"]h$]h&]uh1j5hjVubeh}(h]h ]h"]h$]h&]uh1jhjVhMhjQubj)}(h!``ps`` powersave mode is enabled h](j)}(h``ps``h]j)}(hjVh]hps}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjVubj6)}(hhh]h)}(hpowersave mode is enabledh]hpowersave mode is enabled}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhMhjVubah}(h]h ]h"]h$]h&]uh1j5hjVubeh}(h]h ]h"]h$]h&]uh1jhjVhMhjQubj)}(h)``ps_timeout`` dynamic powersave timeout h](j)}(h``ps_timeout``h]j)}(hj Wh]h ps_timeout}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Wubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjWubj6)}(hhh]h)}(hdynamic powersave timeouth]hdynamic powersave timeout}(hj%WhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!WhMhj"Wubah}(h]h ]h"]h$]h&]uh1j5hjWubeh}(h]h ]h"]h$]h&]uh1jhj!WhMhjQubj)}(hw``ap_unexpected_nlportid`` (private) netlink port ID of application registered for unexpected class 3 frames (AP mode) h](j)}(h``ap_unexpected_nlportid``h]j)}(hjEWh]hap_unexpected_nlportid}(hjGWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCWubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj?Wubj6)}(hhh]h)}(h[(private) netlink port ID of application registered for unexpected class 3 frames (AP mode)h]h[(private) netlink port ID of application registered for unexpected class 3 frames (AP mode)}(hj^WhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj[Wubah}(h]h ]h"]h$]h&]uh1j5hj?Wubeh}(h]h ]h"]h$]h&]uh1jhjZWhM hjQubj)}(h2``owner_nlportid`` (private) owner socket port ID h](j)}(h``owner_nlportid``h]j)}(hjWh]howner_nlportid}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}Wubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM)hjyWubj6)}(hhh]h)}(h(private) owner socket port IDh]h(private) owner socket port ID}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjWhM)hjWubah}(h]h ]h"]h$]h&]uh1j5hjyWubeh}(h]h ]h"]h$]h&]uh1jhjWhM)hjQubj)}(h3``nl_owner_dead`` (private) owner socket went away h](j)}(h``nl_owner_dead``h]j)}(hjWh]h nl_owner_dead}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM*hjWubj6)}(hhh]h)}(h (private) owner socket went awayh]h (private) owner socket went away}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjWhM*hjWubah}(h]h ]h"]h$]h&]uh1j5hjWubeh}(h]h ]h"]h$]h&]uh1jhjWhM*hjQubj)}(hH``wext`` (private) Used by the internal wireless extensions compat code h](j)}(h``wext``h]j)}(hjWh]hwext}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjWubj6)}(hhh]h)}(h>(private) Used by the internal wireless extensions compat codeh]h>(private) Used by the internal wireless extensions compat code}(hj XhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhMhjXubah}(h]h ]h"]h$]h&]uh1j5hjWubeh}(h]h ]h"]h$]h&]uh1jhjXhMhjQubj)}(h8``wext.ibss`` (private) IBSS data part of wext handling h](j)}(h ``wext.ibss``h]j)}(hj*Xh]h wext.ibss}(hj,XhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(Xubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj$Xubj6)}(hhh]h)}(h)(private) IBSS data part of wext handlingh]h)(private) IBSS data part of wext handling}(hjCXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?XhMhj@Xubah}(h]h ]h"]h$]h&]uh1j5hj$Xubeh}(h]h ]h"]h$]h&]uh1jhj?XhMhjQubj)}(h4``wext.connect`` (private) connection handling data h](j)}(h``wext.connect``h]j)}(hjcXh]h wext.connect}(hjeXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaXubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj]Xubj6)}(hhh]h)}(h"(private) connection handling datah]h"(private) connection handling data}(hj|XhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxXhM hjyXubah}(h]h ]h"]h$]h&]uh1j5hj]Xubeh}(h]h ]h"]h$]h&]uh1jhjxXhM hjQubj)}(h'``wext.keys`` (private) (WEP) key data h](j)}(h ``wext.keys``h]j)}(hjXh]h wext.keys}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjXubj6)}(hhh]h)}(h(private) (WEP) key datah]h(private) (WEP) key data}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhM hjXubah}(h]h ]h"]h$]h&]uh1j5hjXubeh}(h]h ]h"]h$]h&]uh1jhjXhM hjQubj)}(h5``wext.ie`` (private) extra elements for association h](j)}(h ``wext.ie``h]j)}(hjXh]hwext.ie}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjXubj6)}(hhh]h)}(h((private) extra elements for associationh]h((private) extra elements for association}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhM hjXubah}(h]h ]h"]h$]h&]uh1j5hjXubeh}(h]h ]h"]h$]h&]uh1jhjXhM hjQubj)}(h3``wext.ie_len`` (private) length of extra elements h](j)}(h``wext.ie_len``h]j)}(hjYh]h wext.ie_len}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Yubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjYubj6)}(hhh]h)}(h"(private) length of extra elementsh]h"(private) length of extra elements}(hj'YhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#YhM hj$Yubah}(h]h ]h"]h$]h&]uh1j5hjYubeh}(h]h ]h"]h$]h&]uh1jhj#YhM hjQubj)}(h0``wext.bssid`` (private) selected network BSSID h](j)}(h``wext.bssid``h]j)}(hjGYh]h wext.bssid}(hjIYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEYubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjAYubj6)}(hhh]h)}(h (private) selected network BSSIDh]h (private) selected network BSSID}(hj`YhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\YhM hj]Yubah}(h]h ]h"]h$]h&]uh1j5hjAYubeh}(h]h ]h"]h$]h&]uh1jhj\YhM hjQubj)}(h?``wext.prev_bssid`` (private) previous BSSID for reassociation h](j)}(h``wext.prev_bssid``h]j)}(hjYh]hwext.prev_bssid}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~Yubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjzYubj6)}(hhh]h)}(h*(private) previous BSSID for reassociationh]h*(private) previous BSSID for reassociation}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYhMhjYubah}(h]h ]h"]h$]h&]uh1j5hjzYubeh}(h]h ]h"]h$]h&]uh1jhjYhMhjQubj)}(h.``wext.ssid`` (private) selected network SSID h](j)}(h ``wext.ssid``h]j)}(hjYh]h wext.ssid}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjYubj6)}(hhh]h)}(h(private) selected network SSIDh]h(private) selected network SSID}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYhMhjYubah}(h]h ]h"]h$]h&]uh1j5hjYubeh}(h]h ]h"]h$]h&]uh1jhjYhMhjQubj)}(h:``wext.default_key`` (private) selected default key index h](j)}(h``wext.default_key``h]j)}(hjYh]hwext.default_key}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjYubj6)}(hhh]h)}(h$(private) selected default key indexh]h$(private) selected default key index}(hj ZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhMhjZubah}(h]h ]h"]h$]h&]uh1j5hjYubeh}(h]h ]h"]h$]h&]uh1jhjZhMhjQubj)}(hJ``wext.default_mgmt_key`` (private) selected default management key index h](j)}(h``wext.default_mgmt_key``h]j)}(hj+Zh]hwext.default_mgmt_key}(hj-ZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)Zubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj%Zubj6)}(hhh]h)}(h/(private) selected default management key indexh]h/(private) selected default management key index}(hjDZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@ZhMhjAZubah}(h]h ]h"]h$]h&]uh1j5hj%Zubeh}(h]h ]h"]h$]h&]uh1jhj@ZhMhjQubj)}(h<``wext.prev_bssid_valid`` (private) previous BSSID validity h](j)}(h``wext.prev_bssid_valid``h]j)}(hjdZh]hwext.prev_bssid_valid}(hjfZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbZubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj^Zubj6)}(hhh]h)}(h!(private) previous BSSID validityh]h!(private) previous BSSID validity}(hj}ZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyZhMhjzZubah}(h]h ]h"]h$]h&]uh1j5hj^Zubeh}(h]h ]h"]h$]h&]uh1jhjyZhMhjQubj)}(h4``cqm_rssi_work`` (private) CQM RSSI reporting work h](j)}(h``cqm_rssi_work``h]j)}(hjZh]h cqm_rssi_work}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM+hjZubj6)}(hhh]h)}(h!(private) CQM RSSI reporting workh]h!(private) CQM RSSI reporting work}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhM+hjZubah}(h]h ]h"]h$]h&]uh1j5hjZubeh}(h]h ]h"]h$]h&]uh1jhjZhM+hjQubj)}(h4``cqm_config`` (private) nl80211 RSSI monitor state h](j)}(h``cqm_config``h]j)}(hjZh]h cqm_config}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM,hjZubj6)}(hhh]h)}(h$(private) nl80211 RSSI monitor stateh]h$(private) nl80211 RSSI monitor state}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhM,hjZubah}(h]h ]h"]h$]h&]uh1j5hjZubeh}(h]h ]h"]h$]h&]uh1jhjZhM,hjQubj)}(h2``pmsr_list`` (private) peer measurement requests h](j)}(h ``pmsr_list``h]j)}(hj[h]h pmsr_list}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj [ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM-hj [ubj6)}(hhh]h)}(h#(private) peer measurement requestsh]h#(private) peer measurement requests}(hj([hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$[hM-hj%[ubah}(h]h ]h"]h$]h&]uh1j5hj [ubeh}(h]h ]h"]h$]h&]uh1jhj$[hM-hjQubj)}(h@``pmsr_lock`` (private) peer measurements requests/results lock h](j)}(h ``pmsr_lock``h]j)}(hjH[h]h pmsr_lock}(hjJ[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjF[ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM.hjB[ubj6)}(hhh]h)}(h1(private) peer measurements requests/results lockh]h1(private) peer measurements requests/results lock}(hja[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj][hM.hj^[ubah}(h]h ]h"]h$]h&]uh1j5hjB[ubeh}(h]h ]h"]h$]h&]uh1jhj][hM.hjQubj)}(h:``pmsr_free_wk`` (private) peer measurements cleanup work h](j)}(h``pmsr_free_wk``h]j)}(hj[h]h pmsr_free_wk}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM/hj{[ubj6)}(hhh]h)}(h((private) peer measurements cleanup workh]h((private) peer measurements cleanup work}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hM/hj[ubah}(h]h ]h"]h$]h&]uh1j5hj{[ubeh}(h]h ]h"]h$]h&]uh1jhj[hM/hjQubj)}(hQ``unprot_beacon_reported`` (private) timestamp of last unprotected beacon report h](j)}(h``unprot_beacon_reported``h]j)}(hj[h]hunprot_beacon_reported}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM1hj[ubj6)}(hhh]h)}(h5(private) timestamp of last unprotected beacon reporth]h5(private) timestamp of last unprotected beacon report}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM0hj[ubah}(h]h ]h"]h$]h&]uh1j5hj[ubeh}(h]h ]h"]h$]h&]uh1jhj[hM1hjQubj)}(h3``u`` union containing data specific to **iftype** h](j)}(h``u``h]j)}(hj[h]hu}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj[ubj6)}(hhh]h)}(h,union containing data specific to **iftype**h](h"union containing data specific to }(hj \hhhNhNubj)}(h **iftype**h]hiftype}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj \ubeh}(h]h ]h"]h$]h&]uh1hhj \hMhj \ubah}(h]h ]h"]h$]h&]uh1j5hj[ubeh}(h]h ]h"]h$]h&]uh1jhj \hMhjQubj)}(ht``links`` array of ``IEEE80211_MLD_MAX_NUM_LINKS`` elements containing **addr** **ap** and **client** for each link h](j)}(h ``links``h]j)}(hj;\h]hlinks}(hj=\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9\ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM3hj5\ubj6)}(hhh]h)}(hiarray of ``IEEE80211_MLD_MAX_NUM_LINKS`` elements containing **addr** **ap** and **client** for each linkh](h array of }(hjT\hhhNhNubj)}(h``IEEE80211_MLD_MAX_NUM_LINKS``h]hIEEE80211_MLD_MAX_NUM_LINKS}(hj\\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjT\ubh elements containing }(hjT\hhhNhNubj)}(h**addr**h]haddr}(hjn\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjT\ubh }(hjT\hhhNhNubj)}(h**ap**h]hap}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjT\ubh and }(hjT\hhhNhNubj)}(h **client**h]hclient}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjT\ubh for each link}(hjT\hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM2hjQ\ubah}(h]h ]h"]h$]h&]uh1j5hj5\ubeh}(h]h ]h"]h$]h&]uh1jhjP\hM3hjQubj)}(h``{unnamed_union}`` anonymous h](j)}(h``{unnamed_union}``h]j)}(hj\h]h{unnamed_union}}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj\ubj6)}(hhh]h)}(h anonymoush]h anonymous}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\hKhj\ubah}(h]h ]h"]h$]h&]uh1j5hj\ubeh}(h]h ]h"]h$]h&]uh1jhj\hKhjQubj)}(hN``links.cac_started`` true if DFS channel availability check has been started h](j)}(h``links.cac_started``h]j)}(hj\h]hlinks.cac_started}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM5hj\ubj6)}(hhh]h)}(h7true if DFS channel availability check has been startedh]h7true if DFS channel availability check has been started}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM4hj ]ubah}(h]h ]h"]h$]h&]uh1j5hj\ubeh}(h]h ]h"]h$]h&]uh1jhj ]hM5hjQubj)}(hM``links.cac_start_time`` timestamp (jiffies) when the dfs state was entered. h](j)}(h``links.cac_start_time``h]j)}(hj0]h]hlinks.cac_start_time}(hj2]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.]ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM7hj*]ubj6)}(hhh]h)}(h3timestamp (jiffies) when the dfs state was entered.h]h3timestamp (jiffies) when the dfs state was entered.}(hjI]hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM6hjF]ubah}(h]h ]h"]h$]h&]uh1j5hj*]ubeh}(h]h ]h"]h$]h&]uh1jhjE]hM7hjQubj)}(h%``links.cac_time_ms`` CAC time in ms h](j)}(h``links.cac_time_ms``h]j)}(hjj]h]hlinks.cac_time_ms}(hjl]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjh]ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM8hjd]ubj6)}(hhh]h)}(hCAC time in msh]hCAC time in ms}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]hM8hj]ubah}(h]h ]h"]h$]h&]uh1j5hjd]ubeh}(h]h ]h"]h$]h&]uh1jhj]hM8hjQubj)}(hG``valid_links`` bitmap describing what elements of **links** are valid h](j)}(h``valid_links``h]j)}(hj]h]h valid_links}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM9hj]ubj6)}(hhh]h)}(h6bitmap describing what elements of **links** are validh](h#bitmap describing what elements of }(hj]hhhNhNubj)}(h **links**h]hlinks}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]ubh are valid}(hj]hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj]hM9hj]ubah}(h]h ]h"]h$]h&]uh1j5hj]ubeh}(h]h ]h"]h$]h&]uh1jhj]hM9hjQubj)}(hN``radio_mask`` Bitmask of radios that this interface is allowed to operate on.h](j)}(h``radio_mask``h]j)}(hj]h]h radio_mask}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM9hj]ubj6)}(hhh]h)}(h?Bitmask of radios that this interface is allowed to operate on.h]h?Bitmask of radios that this interface is allowed to operate on.}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM:hj^ubah}(h]h ]h"]h$]h&]uh1j5hj]ubeh}(h]h ]h"]h$]h&]uh1jhj^hM9hjQubeh}(h]h ]h"]h$]h&]uh1jhjQubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hj1^h]h Description}(hj3^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/^ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM=hhhhubh)}(hXFor netdevs, this structure must be allocated by the driver that uses the ieee80211_ptr field in struct net_device (this is intentional so it can be allocated along with the netdev.) It need not be registered then as netdev registration will be intercepted by cfg80211 to see the new wireless device, however, drivers must lock the wiphy before registering or unregistering netdevs if they pre-create any netdevs (in ops called from cfg80211, the wiphy is already locked.)h]hXFor netdevs, this structure must be allocated by the driver that uses the ieee80211_ptr field in struct net_device (this is intentional so it can be allocated along with the netdev.) It need not be registered then as netdev registration will be intercepted by cfg80211 to see the new wireless device, however, drivers must lock the wiphy before registering or unregistering netdevs if they pre-create any netdevs (in ops called from cfg80211, the wiphy is already locked.)}(hjG^hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhhhhubh)}(hFor non-netdev uses, it must also be allocated by the driver in response to the cfg80211 callbacks that require it, as there's no netdev registration in that case it may not be allocated outside of callback operations that return it.h]hFor non-netdev uses, it must also be allocated by the driver in response to the cfg80211 callbacks that require it, as there’s no netdev registration in that case it may not be allocated outside of callback operations that return it.}(hjV^hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhhhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wdev_priv (C function) c.wdev_privhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(h,void * wdev_priv (struct wireless_dev *wdev)h]jo)}(h*void *wdev_priv(struct wireless_dev *wdev)h](j)}(hvoidh]hvoid}(hj~^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjz^hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjz^hhhj^hMubj.)}(hj1h]h*}(hj^hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjz^hhhj^hMubj)}(h wdev_privh]j)}(h wdev_privh]h wdev_priv}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjz^hhhj^hMubj)}(h(struct wireless_dev *wdev)h]j)}(hstruct wireless_dev *wdevh](ju)}(hjh]hstruct}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj^ubj)}(h h]h }(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubh)}(hhh]j)}(h wireless_devh]h wireless_dev}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj^modnameN classnameNj j )}j ]j)}jj^sb c.wdev_privasbuh1hhj^ubj)}(h h]h }(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubj.)}(hj1h]h*}(hj_hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj^ubj)}(hwdevh]hwdev}(hj!_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj^ubah}(h]h ]h"]h$]h&]jjuh1jhjz^hhhj^hMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjv^hhhj^hMubah}(h]jq^ah ](jjeh"]h$]h&]jj)jhuh1jhhj^hMhjs^hhubj)}(hhh]h)}(h#return wiphy priv from wireless_devh]h#return wiphy priv from wireless_dev}(hjK_hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjH_hhubah}(h]h ]h"]h$]h&]uh1jhjs^hhhj^hMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjc_jjc_jjjuh1jchhhhhNhNubj)}(h**Parameters** ``struct wireless_dev *wdev`` The wireless device whose wiphy's priv pointer to return **Return** The wiphy priv of **wdev**.h](h)}(h**Parameters**h]j)}(hjm_h]h Parameters}(hjo_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjk_ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjg_ubj)}(hhh]j)}(hW``struct wireless_dev *wdev`` The wireless device whose wiphy's priv pointer to return h](j)}(h``struct wireless_dev *wdev``h]j)}(hj_h]hstruct wireless_dev *wdev}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj_ubj6)}(hhh]h)}(h8The wireless device whose wiphy's priv pointer to returnh]h:The wireless device whose wiphy’s priv pointer to return}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_hMhj_ubah}(h]h ]h"]h$]h&]uh1j5hj_ubeh}(h]h ]h"]h$]h&]uh1jhj_hMhj_ubah}(h]h ]h"]h$]h&]uh1jhjg_ubh)}(h **Return**h]j)}(hj_h]hReturn}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjg_ubh)}(hThe wiphy priv of **wdev**.h](hThe wiphy priv of }(hj_hhhNhNubj)}(h**wdev**h]hwdev}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_ubh.}(hj_hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjg_ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_(cfg80211_check_combinations (C function)c.cfg80211_check_combinationshNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(h^int cfg80211_check_combinations (struct wiphy *wiphy, struct iface_combination_params *params)h]jo)}(h]int cfg80211_check_combinations(struct wiphy *wiphy, struct iface_combination_params *params)h](j)}(hinth]hint}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM(%ubj)}(h h]h }(hj-`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`hhhj,`hM(%ubj)}(hcfg80211_check_combinationsh]j)}(hcfg80211_check_combinationsh]hcfg80211_check_combinations}(hj?`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj;`ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj`hhhj,`hM(%ubj)}(h>(struct wiphy *wiphy, struct iface_combination_params *params)h](j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hj[`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjW`ubj)}(h h]h }(hjh`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjW`ubh)}(hhh]j)}(hwiphyh]hwiphy}(hjy`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjv`ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj{`modnameN classnameNj j )}j ]j)}jjA`sbc.cfg80211_check_combinationsasbuh1hhjW`ubj)}(h h]h }(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjW`ubj.)}(hj1h]h*}(hj`hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjW`ubj)}(hwiphyh]hwiphy}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjW`ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjS`ubj)}(h'struct iface_combination_params *paramsh](ju)}(hjh]hstruct}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj`ubj)}(h h]h }(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubh)}(hhh]j)}(hiface_combination_paramsh]hiface_combination_params}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj`modnameN classnameNj j )}j ]j`c.cfg80211_check_combinationsasbuh1hhj`ubj)}(h h]h }(hj ahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubj.)}(hj1h]h*}(hjahhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj`ubj)}(hparamsh]hparams}(hj$ahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjS`ubeh}(h]h ]h"]h$]h&]jjuh1jhj`hhhj,`hM(%ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj`hhhj,`hM(%ubah}(h]j`ah ](jjeh"]h$]h&]jj)jhuh1jhhj,`hM(%hj`hhubj)}(hhh]h)}(hcheck interface combinationsh]hcheck interface combinations}(hjNahhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM(%hjKahhubah}(h]h ]h"]h$]h&]uh1jhj`hhhj,`hM(%ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjfajjfajjjuh1jchhhhhNhNubj)}(hXt**Parameters** ``struct wiphy *wiphy`` the wiphy ``struct iface_combination_params *params`` the interface combinations parameter **Description** This function can be called by the driver to check whether a combination of interfaces and their types are allowed according to the interface combinations. **Return** 0 if combinations are allowed. Non-zero on error.h](h)}(h**Parameters**h]j)}(hjpah]h Parameters}(hjrahhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnaubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM,%hjjaubj)}(hhh](j)}(h"``struct wiphy *wiphy`` the wiphy h](j)}(h``struct wiphy *wiphy``h]j)}(hjah]hstruct wiphy *wiphy}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM*%hjaubj6)}(hhh]h)}(h the wiphyh]h the wiphy}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhjahM*%hjaubah}(h]h ]h"]h$]h&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhjahM*%hjaubj)}(hQ``struct iface_combination_params *params`` the interface combinations parameter h](j)}(h+``struct iface_combination_params *params``h]j)}(hjah]h'struct iface_combination_params *params}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM+%hjaubj6)}(hhh]h)}(h$the interface combinations parameterh]h$the interface combinations parameter}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhjahM+%hjaubah}(h]h ]h"]h$]h&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhjahM+%hjaubeh}(h]h ]h"]h$]h&]uh1jhjjaubh)}(h**Description**h]j)}(hjbh]h Description}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM-%hjjaubh)}(hThis function can be called by the driver to check whether a combination of interfaces and their types are allowed according to the interface combinations.h]hThis function can be called by the driver to check whether a combination of interfaces and their types are allowed according to the interface combinations.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM,%hjjaubh)}(h **Return**h]j)}(hj*bh]hReturn}(hj,bhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj(bubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM0%hjjaubh)}(h10 if combinations are allowed. Non-zero on error.h]h10 if combinations are allowed. Non-zero on error.}(hj@bhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM1%hjjaubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubeh}(h]device-registrationah ]h"]device registrationah$]h&]uh1hhhhhhhhK ubh)}(hhh](h)}(hActions and configurationh]hActions and configuration}(hjabhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^bhhhhhK+ubh)}(hX Each wireless device and each virtual interface offer a set of configuration operations and other actions that are invoked by userspace. Each of these actions is described in the operations structure, and the parameters these operations use are described separately.h]hX Each wireless device and each virtual interface offer a set of configuration operations and other actions that are invoked by userspace. Each of these actions is described in the operations structure, and the parameters these operations use are described separately.}(hjobhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:45: ./include/net/cfg80211.hhMhj^bhhubh)}(hAdditionally, some operations are asynchronous and expect to get status information via some functions that drivers need to call.h]hAdditionally, some operations are asynchronous and expect to get status information via some functions that drivers need to call.}(hj~bhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:45: ./include/net/cfg80211.hhMhj^bhhubh)}(hdScanning and BSS list handling with its associated functionality is described in a separate chapter.h]hdScanning and BSS list handling with its associated functionality is described in a separate chapter.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:45: ./include/net/cfg80211.hhMhj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_vif_params (C struct) c.vif_paramshNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(h vif_paramsh]jo)}(hstruct vif_paramsh](ju)}(hjh]hstruct}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjbhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhKubj)}(h h]h }(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjbhhhjbhKubj)}(h vif_paramsh]j)}(hjbh]h vif_params}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjbubah}(h]h ](jjeh"]h$]h&]jjuh1jhjbhhhjbhKubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjbhhhjbhKubah}(h]jbah ](jjeh"]h$]h&]jj)jhuh1jhhjbhKhjbhhubj)}(hhh]h)}(h&describes virtual interface parametersh]h&describes virtual interface parameters}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjbhhubah}(h]h ]h"]h$]h&]uh1jhjbhhhjbhKubeh}(h]h ](j$structeh"]h$]h&]jj$jjcjjcjjjuh1jchhhj^bhNhNubj)}(hX**Definition**:: struct vif_params { u32 flags; int use_4addr; u8 macaddr[ETH_ALEN]; const u8 *vht_mumimo_groups; const u8 *vht_mumimo_follow_addr; }; **Members** ``flags`` monitor interface flags, unchanged if 0, otherwise ``MONITOR_FLAG_CHANGED`` will be set ``use_4addr`` use 4-address frames ``macaddr`` address to use for this virtual interface. If this parameter is set to zero address the driver may determine the address as needed. This feature is only fully supported by drivers that enable the ``NL80211_FEATURE_MAC_ON_CREATE`` flag. Others may support creating * only p2p devices with specified MAC. ``vht_mumimo_groups`` MU-MIMO groupID, used for monitoring MU-MIMO packets belonging to that MU-MIMO groupID; ``NULL`` if not changed ``vht_mumimo_follow_addr`` MU-MIMO follow address, used for monitoring MU-MIMO packets going to the specified station; ``NULL`` if not changedh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhjcubh:}(hjchhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcubj( )}(hstruct vif_params { u32 flags; int use_4addr; u8 macaddr[ETH_ALEN]; const u8 *vht_mumimo_groups; const u8 *vht_mumimo_follow_addr; };h]hstruct vif_params { u32 flags; int use_4addr; u8 macaddr[ETH_ALEN]; const u8 *vht_mumimo_groups; const u8 *vht_mumimo_follow_addr; };}hj4csbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcubh)}(h **Members**h]j)}(hjEch]hMembers}(hjGchhhNhNubah}(h]h ]h"]h$]h&]uh1hhjCcubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcubj)}(hhh](j)}(hb``flags`` monitor interface flags, unchanged if 0, otherwise ``MONITOR_FLAG_CHANGED`` will be set h](j)}(h ``flags``h]j)}(hjdch]hflags}(hjfchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbcubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^cubj6)}(hhh]h)}(hWmonitor interface flags, unchanged if 0, otherwise ``MONITOR_FLAG_CHANGED`` will be seth](h3monitor interface flags, unchanged if 0, otherwise }(hj}chhhNhNubj)}(h``MONITOR_FLAG_CHANGED``h]hMONITOR_FLAG_CHANGED}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}cubh will be set}(hj}chhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjzcubah}(h]h ]h"]h$]h&]uh1j5hj^cubeh}(h]h ]h"]h$]h&]uh1jhjychMhj[cubj)}(h#``use_4addr`` use 4-address frames h](j)}(h ``use_4addr``h]j)}(hjch]h use_4addr}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcubj6)}(hhh]h)}(huse 4-address framesh]huse 4-address frames}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhjchMhjcubah}(h]h ]h"]h$]h&]uh1j5hjcubeh}(h]h ]h"]h$]h&]uh1jhjchMhj[cubj)}(hX@``macaddr`` address to use for this virtual interface. If this parameter is set to zero address the driver may determine the address as needed. This feature is only fully supported by drivers that enable the ``NL80211_FEATURE_MAC_ON_CREATE`` flag. Others may support creating * only p2p devices with specified MAC. h](j)}(h ``macaddr``h]j)}(hjch]hmacaddr}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcubj6)}(hhh]h)}(hX3address to use for this virtual interface. If this parameter is set to zero address the driver may determine the address as needed. This feature is only fully supported by drivers that enable the ``NL80211_FEATURE_MAC_ON_CREATE`` flag. Others may support creating * only p2p devices with specified MAC.h](haddress to use for this virtual interface. If this parameter is set to zero address the driver may determine the address as needed. This feature is only fully supported by drivers that enable the }(hjdhhhNhNubj)}(h!``NL80211_FEATURE_MAC_ON_CREATE``h]hNL80211_FEATURE_MAC_ON_CREATE}(hj dhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubhN flag. Others may support creating * only p2p devices with specified MAC.}(hjdhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcubah}(h]h ]h"]h$]h&]uh1j5hjcubeh}(h]h ]h"]h$]h&]uh1jhjchMhj[cubj)}(h``vht_mumimo_groups`` MU-MIMO groupID, used for monitoring MU-MIMO packets belonging to that MU-MIMO groupID; ``NULL`` if not changed h](j)}(h``vht_mumimo_groups``h]j)}(hj5dh]hvht_mumimo_groups}(hj7dhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3dubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj/dubj6)}(hhh]h)}(hoMU-MIMO groupID, used for monitoring MU-MIMO packets belonging to that MU-MIMO groupID; ``NULL`` if not changedh](hXMU-MIMO groupID, used for monitoring MU-MIMO packets belonging to that MU-MIMO groupID; }(hjNdhhhNhNubj)}(h``NULL``h]hNULL}(hjVdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNdubh if not changed}(hjNdhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjKdubah}(h]h ]h"]h$]h&]uh1j5hj/dubeh}(h]h ]h"]h$]h&]uh1jhjJdhMhj[cubj)}(h``vht_mumimo_follow_addr`` MU-MIMO follow address, used for monitoring MU-MIMO packets going to the specified station; ``NULL`` if not changedh](j)}(h``vht_mumimo_follow_addr``h]j)}(hjdh]hvht_mumimo_follow_addr}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj{dubj6)}(hhh]h)}(hsMU-MIMO follow address, used for monitoring MU-MIMO packets going to the specified station; ``NULL`` if not changedh](h\MU-MIMO follow address, used for monitoring MU-MIMO packets going to the specified station; }(hjdhhhNhNubj)}(h``NULL``h]hNULL}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubh if not changed}(hjdhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjdhMhjdubah}(h]h ]h"]h$]h&]uh1j5hj{dubeh}(h]h ]h"]h$]h&]uh1jhjdhMhj[cubeh}(h]h ]h"]h$]h&]uh1jhjcubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_key_params (C struct) c.key_paramshNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(h key_paramsh]jo)}(hstruct key_paramsh](ju)}(hjh]hstruct}(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjdhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdhhhjdhM ubj)}(h key_paramsh]j)}(hjdh]h key_params}(hj ehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubah}(h]h ](jjeh"]h$]h&]jjuh1jhjdhhhjdhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjdhhhjdhM ubah}(h]jdah ](jjeh"]h$]h&]jj)jhuh1jhhjdhM hjdhhubj)}(hhh]h)}(hkey informationh]hkey information}(hj.ehhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj+ehhubah}(h]h ]h"]h$]h&]uh1jhjdhhhjdhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjFejjFejjjuh1jchhhj^bhNhNubj)}(hX_**Definition**:: struct key_params { const u8 *key; const u8 *seq; int key_len; int seq_len; u16 vlan_id; u32 cipher; enum nl80211_key_mode mode; }; **Members** ``key`` key material ``seq`` sequence counter (IV/PN) for TKIP and CCMP keys, only used with the get_key() callback, must be in little endian, length given by **seq_len**. ``key_len`` length of key material ``seq_len`` length of **seq**. ``vlan_id`` vlan_id for VLAN group key (if nonzero) ``cipher`` cipher suite selector ``mode`` key install mode (RX_TX, NO_TX or SET_TX)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjRehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjNeubh:}(hjNehhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjJeubj( )}(hstruct key_params { const u8 *key; const u8 *seq; int key_len; int seq_len; u16 vlan_id; u32 cipher; enum nl80211_key_mode mode; };h]hstruct key_params { const u8 *key; const u8 *seq; int key_len; int seq_len; u16 vlan_id; u32 cipher; enum nl80211_key_mode mode; };}hjkesbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjJeubh)}(h **Members**h]j)}(hj|eh]hMembers}(hj~ehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzeubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjJeubj)}(hhh](j)}(h``key`` key material h](j)}(h``key``h]j)}(hjeh]hkey}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjeubj6)}(hhh]h)}(h key materialh]h key material}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehMhjeubah}(h]h ]h"]h$]h&]uh1j5hjeubeh}(h]h ]h"]h$]h&]uh1jhjehMhjeubj)}(h``seq`` sequence counter (IV/PN) for TKIP and CCMP keys, only used with the get_key() callback, must be in little endian, length given by **seq_len**. h](j)}(h``seq``h]j)}(hjeh]hseq}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjeubj6)}(hhh]h)}(hsequence counter (IV/PN) for TKIP and CCMP keys, only used with the get_key() callback, must be in little endian, length given by **seq_len**.h](hsequence counter (IV/PN) for TKIP and CCMP keys, only used with the get_key() callback, must be in little endian, length given by }(hjehhhNhNubj)}(h **seq_len**h]hseq_len}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjeubh.}(hjehhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjeubah}(h]h ]h"]h$]h&]uh1j5hjeubeh}(h]h ]h"]h$]h&]uh1jhjehMhjeubj)}(h#``key_len`` length of key material h](j)}(h ``key_len``h]j)}(hj fh]hkey_len}(hj"fhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjfubj6)}(hhh]h)}(hlength of key materialh]hlength of key material}(hj9fhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5fhMhj6fubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhj5fhMhjeubj)}(h``seq_len`` length of **seq**. h](j)}(h ``seq_len``h]j)}(hjYfh]hseq_len}(hj[fhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWfubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjSfubj6)}(hhh]h)}(hlength of **seq**.h](h length of }(hjrfhhhNhNubj)}(h**seq**h]hseq}(hjzfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjrfubh.}(hjrfhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjnfhMhjofubah}(h]h ]h"]h$]h&]uh1j5hjSfubeh}(h]h ]h"]h$]h&]uh1jhjnfhMhjeubj)}(h4``vlan_id`` vlan_id for VLAN group key (if nonzero) h](j)}(h ``vlan_id``h]j)}(hjfh]hvlan_id}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjfubj6)}(hhh]h)}(h'vlan_id for VLAN group key (if nonzero)h]h'vlan_id for VLAN group key (if nonzero)}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhMhjfubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhjfhMhjeubj)}(h!``cipher`` cipher suite selector h](j)}(h ``cipher``h]j)}(hjfh]hcipher}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjfubj6)}(hhh]h)}(hcipher suite selectorh]hcipher suite selector}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhMhjfubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhjfhMhjeubj)}(h2``mode`` key install mode (RX_TX, NO_TX or SET_TX)h](j)}(h``mode``h]j)}(hjgh]hmode}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjgubj6)}(hhh]h)}(h)key install mode (RX_TX, NO_TX or SET_TX)h]h)key install mode (RX_TX, NO_TX or SET_TX)}(hj/ghhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj,gubah}(h]h ]h"]h$]h&]uh1j5hjgubeh}(h]h ]h"]h$]h&]uh1jhj+ghMhjeubeh}(h]h ]h"]h$]h&]uh1jhjJeubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hjYgh]h Description}(hj[ghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjWgubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj^bhhubh)}(hInformation about a keyh]hInformation about a key}(hjoghhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_survey_info_flags (C enum)c.survey_info_flagshNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hsurvey_info_flagsh]jo)}(henum survey_info_flagsh](ju)}(hjxh]henum}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjghhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjghhhjghMubj)}(hsurvey_info_flagsh]j)}(hjgh]hsurvey_info_flags}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjgubah}(h]h ](jjeh"]h$]h&]jjuh1jhjghhhjghMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjghhhjghMubah}(h]jgah ](jjeh"]h$]h&]jj)jhuh1jhhjghMhjghhubj)}(hhh]h)}(hsurvey information flagsh]hsurvey information flags}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMthjghhubah}(h]h ]h"]h$]h&]uh1jhjghhhjghMubeh}(h]h ](j$enumeh"]h$]h&]jj$jjgjjgjjjuh1jchhhj^bhNhNubj)}(hX!**Constants** ``SURVEY_INFO_NOISE_DBM`` noise (in dBm) was filled in ``SURVEY_INFO_IN_USE`` channel is currently being used ``SURVEY_INFO_TIME`` active time (in ms) was filled in ``SURVEY_INFO_TIME_BUSY`` busy time was filled in ``SURVEY_INFO_TIME_EXT_BUSY`` extension channel busy time was filled in ``SURVEY_INFO_TIME_RX`` receive time was filled in ``SURVEY_INFO_TIME_TX`` transmit time was filled in ``SURVEY_INFO_TIME_SCAN`` scan time was filled in ``SURVEY_INFO_TIME_BSS_RX`` local BSS receive time was filled inh](h)}(h **Constants**h]j)}(hjgh]h Constants}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjgubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMxhjgubj)}(hhh](j)}(h7``SURVEY_INFO_NOISE_DBM`` noise (in dBm) was filled in h](j)}(h``SURVEY_INFO_NOISE_DBM``h]j)}(hjhh]hSURVEY_INFO_NOISE_DBM}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM{hjhubj6)}(hhh]h)}(hnoise (in dBm) was filled inh]hnoise (in dBm) was filled in}(hj3hhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hhM{hj0hubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhj/hhM{hjhubj)}(h7``SURVEY_INFO_IN_USE`` channel is currently being used h](j)}(h``SURVEY_INFO_IN_USE``h]j)}(hjShh]hSURVEY_INFO_IN_USE}(hjUhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQhubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM~hjMhubj6)}(hhh]h)}(hchannel is currently being usedh]hchannel is currently being used}(hjlhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhM~hjihubah}(h]h ]h"]h$]h&]uh1j5hjMhubeh}(h]h ]h"]h$]h&]uh1jhjhhhM~hjhubj)}(h7``SURVEY_INFO_TIME`` active time (in ms) was filled in h](j)}(h``SURVEY_INFO_TIME``h]j)}(hjhh]hSURVEY_INFO_TIME}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhubj6)}(hhh]h)}(h!active time (in ms) was filled inh]h!active time (in ms) was filled in}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhMhjhubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhhMhjhubj)}(h2``SURVEY_INFO_TIME_BUSY`` busy time was filled in h](j)}(h``SURVEY_INFO_TIME_BUSY``h]j)}(hjhh]hSURVEY_INFO_TIME_BUSY}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhubj6)}(hhh]h)}(hbusy time was filled inh]hbusy time was filled in}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhMhjhubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhhMhjhubj)}(hH``SURVEY_INFO_TIME_EXT_BUSY`` extension channel busy time was filled in h](j)}(h``SURVEY_INFO_TIME_EXT_BUSY``h]j)}(hjhh]hSURVEY_INFO_TIME_EXT_BUSY}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhubj6)}(hhh]h)}(h)extension channel busy time was filled inh]h)extension channel busy time was filled in}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihMhjiubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjihMhjhubj)}(h3``SURVEY_INFO_TIME_RX`` receive time was filled in h](j)}(h``SURVEY_INFO_TIME_RX``h]j)}(hj7ih]hSURVEY_INFO_TIME_RX}(hj9ihhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5iubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj1iubj6)}(hhh]h)}(hreceive time was filled inh]hreceive time was filled in}(hjPihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLihMhjMiubah}(h]h ]h"]h$]h&]uh1j5hj1iubeh}(h]h ]h"]h$]h&]uh1jhjLihMhjhubj)}(h4``SURVEY_INFO_TIME_TX`` transmit time was filled in h](j)}(h``SURVEY_INFO_TIME_TX``h]j)}(hjpih]hSURVEY_INFO_TIME_TX}(hjrihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjniubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjiubj6)}(hhh]h)}(htransmit time was filled inh]htransmit time was filled in}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihMhjiubah}(h]h ]h"]h$]h&]uh1j5hjjiubeh}(h]h ]h"]h$]h&]uh1jhjihMhjhubj)}(h2``SURVEY_INFO_TIME_SCAN`` scan time was filled in h](j)}(h``SURVEY_INFO_TIME_SCAN``h]j)}(hjih]hSURVEY_INFO_TIME_SCAN}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjiubj6)}(hhh]h)}(hscan time was filled inh]hscan time was filled in}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihMhjiubah}(h]h ]h"]h$]h&]uh1j5hjiubeh}(h]h ]h"]h$]h&]uh1jhjihMhjhubj)}(h@``SURVEY_INFO_TIME_BSS_RX`` local BSS receive time was filled inh](j)}(h``SURVEY_INFO_TIME_BSS_RX``h]j)}(hjih]hSURVEY_INFO_TIME_BSS_RX}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjiubj6)}(hhh]h)}(h$local BSS receive time was filled inh]h$local BSS receive time was filled in}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjiubah}(h]h ]h"]h$]h&]uh1j5hjiubeh}(h]h ]h"]h$]h&]uh1jhjihMhjhubeh}(h]h ]h"]h$]h&]uh1jhjgubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hj%jh]h Description}(hj'jhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#jubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubh)}(hUsed by the driver to indicate which info in :c:type:`struct survey_info ` it has filled in during the get_survey().h](h-Used by the driver to indicate which info in }(hj;jhhhNhNubh)}(h*:c:type:`struct survey_info `h]j)}(hjEjh]hstruct survey_info}(hjGjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjCjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6 survey_infouh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj;jubh* it has filled in during the get_survey().}(hj;jhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjbjhMhj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_survey_info (C struct) c.survey_infohNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(h survey_infoh]jo)}(hstruct survey_infoh](ju)}(hjh]hstruct}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjhhhjjhMubj)}(h survey_infoh]j)}(hjjh]h survey_info}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjjhhhjjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj~jhhhjjhMubah}(h]jyjah ](jjeh"]h$]h&]jj)jhuh1jhhjjhMhj{jhhubj)}(hhh]h)}(hchannel survey responseh]hchannel survey response}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjhhubah}(h]h ]h"]h$]h&]uh1jhj{jhhhjjhMubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjjjuh1jchhhj^bhNhNubj)}(hX**Definition**:: struct survey_info { struct ieee80211_channel *channel; u64 time; u64 time_busy; u64 time_ext_busy; u64 time_rx; u64 time_tx; u64 time_scan; u64 time_bss_rx; u32 filled; s8 noise; }; **Members** ``channel`` the channel this survey record reports, may be ``NULL`` for a single record to report global statistics ``time`` amount of time in ms the radio was turn on (on the channel) ``time_busy`` amount of time the primary channel was sensed busy ``time_ext_busy`` amount of time the extension channel was sensed busy ``time_rx`` amount of time the radio spent receiving data ``time_tx`` amount of time the radio spent transmitting data ``time_scan`` amount of time the radio spent for scanning ``time_bss_rx`` amount of time the radio spent receiving data on a local BSS ``filled`` bitflag of flags from :c:type:`enum survey_info_flags ` ``noise`` channel noise in dBm. This and all following fields are optionalh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjubh:}(hjjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubj( )}(hstruct survey_info { struct ieee80211_channel *channel; u64 time; u64 time_busy; u64 time_ext_busy; u64 time_rx; u64 time_tx; u64 time_scan; u64 time_bss_rx; u32 filled; s8 noise; };h]hstruct survey_info { struct ieee80211_channel *channel; u64 time; u64 time_busy; u64 time_ext_busy; u64 time_rx; u64 time_tx; u64 time_scan; u64 time_bss_rx; u32 filled; s8 noise; };}hjksbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubh)}(h **Members**h]j)}(hjkh]hMembers}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubj)}(hhh](j)}(ht``channel`` the channel this survey record reports, may be ``NULL`` for a single record to report global statistics h](j)}(h ``channel``h]j)}(hj5kh]hchannel}(hj7khhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3kubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj/kubj6)}(hhh]h)}(hgthe channel this survey record reports, may be ``NULL`` for a single record to report global statisticsh](h/the channel this survey record reports, may be }(hjNkhhhNhNubj)}(h``NULL``h]hNULL}(hjVkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNkubh0 for a single record to report global statistics}(hjNkhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjKkubah}(h]h ]h"]h$]h&]uh1j5hj/kubeh}(h]h ]h"]h$]h&]uh1jhjJkhMhj,kubj)}(hE``time`` amount of time in ms the radio was turn on (on the channel) h](j)}(h``time``h]j)}(hjkh]htime}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj{kubj6)}(hhh]h)}(h;amount of time in ms the radio was turn on (on the channel)h]h;amount of time in ms the radio was turn on (on the channel)}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkhMhjkubah}(h]h ]h"]h$]h&]uh1j5hj{kubeh}(h]h ]h"]h$]h&]uh1jhjkhMhj,kubj)}(hA``time_busy`` amount of time the primary channel was sensed busy h](j)}(h ``time_busy``h]j)}(hjkh]h time_busy}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjkubj6)}(hhh]h)}(h2amount of time the primary channel was sensed busyh]h2amount of time the primary channel was sensed busy}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkhMhjkubah}(h]h ]h"]h$]h&]uh1j5hjkubeh}(h]h ]h"]h$]h&]uh1jhjkhMhj,kubj)}(hG``time_ext_busy`` amount of time the extension channel was sensed busy h](j)}(h``time_ext_busy``h]j)}(hjkh]h time_ext_busy}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjkubj6)}(hhh]h)}(h4amount of time the extension channel was sensed busyh]h4amount of time the extension channel was sensed busy}(hj lhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhMhj lubah}(h]h ]h"]h$]h&]uh1j5hjkubeh}(h]h ]h"]h$]h&]uh1jhjlhMhj,kubj)}(h:``time_rx`` amount of time the radio spent receiving data h](j)}(h ``time_rx``h]j)}(hj,lh]htime_rx}(hj.lhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*lubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj&lubj6)}(hhh]h)}(h-amount of time the radio spent receiving datah]h-amount of time the radio spent receiving data}(hjElhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjAlhMhjBlubah}(h]h ]h"]h$]h&]uh1j5hj&lubeh}(h]h ]h"]h$]h&]uh1jhjAlhMhj,kubj)}(h=``time_tx`` amount of time the radio spent transmitting data h](j)}(h ``time_tx``h]j)}(hjelh]htime_tx}(hjglhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjclubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj_lubj6)}(hhh]h)}(h0amount of time the radio spent transmitting datah]h0amount of time the radio spent transmitting data}(hj~lhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzlhMhj{lubah}(h]h ]h"]h$]h&]uh1j5hj_lubeh}(h]h ]h"]h$]h&]uh1jhjzlhMhj,kubj)}(h:``time_scan`` amount of time the radio spent for scanning h](j)}(h ``time_scan``h]j)}(hjlh]h time_scan}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjlubj6)}(hhh]h)}(h+amount of time the radio spent for scanningh]h+amount of time the radio spent for scanning}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhMhjlubah}(h]h ]h"]h$]h&]uh1j5hjlubeh}(h]h ]h"]h$]h&]uh1jhjlhMhj,kubj)}(hM``time_bss_rx`` amount of time the radio spent receiving data on a local BSS h](j)}(h``time_bss_rx``h]j)}(hjlh]h time_bss_rx}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjlubj6)}(hhh]h)}(h` h](j)}(h ``filled``h]j)}(hjmh]hfilled}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj mubj6)}(hhh]h)}(hJbitflag of flags from :c:type:`enum survey_info_flags `h](hbitflag of flags from }(hj)mhhhNhNubh)}(h4:c:type:`enum survey_info_flags `h]j)}(hj3mh]henum survey_info_flags}(hj5mhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj1mubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6survey_info_flagsuh1hhj%mhMhj)mubeh}(h]h ]h"]h$]h&]uh1hhj%mhMhj&mubah}(h]h ]h"]h$]h&]uh1j5hj mubeh}(h]h ]h"]h$]h&]uh1jhj%mhMhj,kubj)}(hJ``noise`` channel noise in dBm. This and all following fields are optionalh](j)}(h ``noise``h]j)}(hjhmh]hnoise}(hjjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfmubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjbmubj6)}(hhh]h)}(h@channel noise in dBm. This and all following fields are optionalh]h@channel noise in dBm. This and all following fields are optional}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj}mhMhj~mubah}(h]h ]h"]h$]h&]uh1j5hjbmubeh}(h]h ]h"]h$]h&]uh1jhj}mhMhj,kubeh}(h]h ]h"]h$]h&]uh1jhjjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hjmh]h Description}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubh)}(hDUsed by dump_survey() to report back per-channel survey information.h]hDUsed by dump_survey() to report back per-channel survey information.}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubh)}(hMThis structure can later be expanded with things like channel duty cycle etc.h]hMThis structure can later be expanded with things like channel duty cycle etc.}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_#cfg80211_crypto_settings (C struct)c.cfg80211_crypto_settingshNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hcfg80211_crypto_settingsh]jo)}(hstruct cfg80211_crypto_settingsh](ju)}(hjh]hstruct}(hjmhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjmhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjmhhhjnhMubj)}(hcfg80211_crypto_settingsh]j)}(hjmh]hcfg80211_crypto_settings}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjnubah}(h]h ](jjeh"]h$]h&]jjuh1jhjmhhhjnhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjmhhhjnhMubah}(h]jmah ](jjeh"]h$]h&]jj)jhuh1jhhjnhMhjmhhubj)}(hhh]h)}(hCrypto settingsh]hCrypto settings}(hj9nhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj6nhhubah}(h]h ]h"]h$]h&]uh1jhjmhhhjnhMubeh}(h]h ](j$structeh"]h$]h&]jj$jjQnjjQnjjjuh1jchhhj^bhNhNubj)}(hX**Definition**:: struct cfg80211_crypto_settings { u32 wpa_versions; u32 cipher_group; int n_ciphers_pairwise; u32 ciphers_pairwise[NL80211_MAX_NR_CIPHER_SUITES]; int n_akm_suites; u32 akm_suites[CFG80211_MAX_NUM_AKM_SUITES]; bool control_port; __be16 control_port_ethertype; bool control_port_no_encrypt; bool control_port_over_nl80211; bool control_port_no_preauth; const u8 *psk; const u8 *sae_pwd; u8 sae_pwd_len; enum nl80211_sae_pwe_mechanism sae_pwe; }; **Members** ``wpa_versions`` indicates which, if any, WPA versions are enabled (from enum nl80211_wpa_versions) ``cipher_group`` group key cipher suite (or 0 if unset) ``n_ciphers_pairwise`` number of AP supported unicast ciphers ``ciphers_pairwise`` unicast key cipher suites ``n_akm_suites`` number of AKM suites ``akm_suites`` AKM suites ``control_port`` Whether user space controls IEEE 802.1X port, i.e., sets/clears ``NL80211_STA_FLAG_AUTHORIZED``. If true, the driver is required to assume that the port is unauthorized until authorized by user space. Otherwise, port is marked authorized by default. ``control_port_ethertype`` the control port protocol that should be allowed through even on unauthorized ports ``control_port_no_encrypt`` TRUE to prevent encryption of control port protocol frames. ``control_port_over_nl80211`` TRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface. ``control_port_no_preauth`` disables pre-auth rx over the nl80211 control port for mac80211 ``psk`` PSK (for devices supporting 4-way-handshake offload) ``sae_pwd`` password for SAE authentication (for devices supporting SAE offload) ``sae_pwd_len`` length of SAE password (for devices supporting SAE offload) ``sae_pwe`` The mechanisms allowed for SAE PWE derivation:h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj]nhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYnubh:}(hjYnhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjUnubj( )}(hXstruct cfg80211_crypto_settings { u32 wpa_versions; u32 cipher_group; int n_ciphers_pairwise; u32 ciphers_pairwise[NL80211_MAX_NR_CIPHER_SUITES]; int n_akm_suites; u32 akm_suites[CFG80211_MAX_NUM_AKM_SUITES]; bool control_port; __be16 control_port_ethertype; bool control_port_no_encrypt; bool control_port_over_nl80211; bool control_port_no_preauth; const u8 *psk; const u8 *sae_pwd; u8 sae_pwd_len; enum nl80211_sae_pwe_mechanism sae_pwe; };h]hXstruct cfg80211_crypto_settings { u32 wpa_versions; u32 cipher_group; int n_ciphers_pairwise; u32 ciphers_pairwise[NL80211_MAX_NR_CIPHER_SUITES]; int n_akm_suites; u32 akm_suites[CFG80211_MAX_NUM_AKM_SUITES]; bool control_port; __be16 control_port_ethertype; bool control_port_no_encrypt; bool control_port_over_nl80211; bool control_port_no_preauth; const u8 *psk; const u8 *sae_pwd; u8 sae_pwd_len; enum nl80211_sae_pwe_mechanism sae_pwe; };}hjvnsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjUnubh)}(h **Members**h]j)}(hjnh]hMembers}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjUnubj)}(hhh](j)}(hd``wpa_versions`` indicates which, if any, WPA versions are enabled (from enum nl80211_wpa_versions) h](j)}(h``wpa_versions``h]j)}(hjnh]h wpa_versions}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjnubj6)}(hhh]h)}(hRindicates which, if any, WPA versions are enabled (from enum nl80211_wpa_versions)h]hRindicates which, if any, WPA versions are enabled (from enum nl80211_wpa_versions)}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjnubah}(h]h ]h"]h$]h&]uh1j5hjnubeh}(h]h ]h"]h$]h&]uh1jhjnhMhjnubj)}(h8``cipher_group`` group key cipher suite (or 0 if unset) h](j)}(h``cipher_group``h]j)}(hjnh]h cipher_group}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjnubj6)}(hhh]h)}(h&group key cipher suite (or 0 if unset)h]h&group key cipher suite (or 0 if unset)}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhMhjnubah}(h]h ]h"]h$]h&]uh1j5hjnubeh}(h]h ]h"]h$]h&]uh1jhjnhMhjnubj)}(h>``n_ciphers_pairwise`` number of AP supported unicast ciphers h](j)}(h``n_ciphers_pairwise``h]j)}(hjoh]hn_ciphers_pairwise}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjoubj6)}(hhh]h)}(h&number of AP supported unicast ciphersh]h&number of AP supported unicast ciphers}(hj2ohhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.ohMhj/oubah}(h]h ]h"]h$]h&]uh1j5hjoubeh}(h]h ]h"]h$]h&]uh1jhj.ohMhjnubj)}(h/``ciphers_pairwise`` unicast key cipher suites h](j)}(h``ciphers_pairwise``h]j)}(hjRoh]hciphers_pairwise}(hjTohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPoubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjLoubj6)}(hhh]h)}(hunicast key cipher suitesh]hunicast key cipher suites}(hjkohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjgohMhjhoubah}(h]h ]h"]h$]h&]uh1j5hjLoubeh}(h]h ]h"]h$]h&]uh1jhjgohMhjnubj)}(h&``n_akm_suites`` number of AKM suites h](j)}(h``n_akm_suites``h]j)}(hjoh]h n_akm_suites}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjoubj6)}(hhh]h)}(hnumber of AKM suitesh]hnumber of AKM suites}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjohMhjoubah}(h]h ]h"]h$]h&]uh1j5hjoubeh}(h]h ]h"]h$]h&]uh1jhjohMhjnubj)}(h``akm_suites`` AKM suites h](j)}(h``akm_suites``h]j)}(hjoh]h akm_suites}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjoubj6)}(hhh]h)}(h AKM suitesh]h AKM suites}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjohMhjoubah}(h]h ]h"]h$]h&]uh1j5hjoubeh}(h]h ]h"]h$]h&]uh1jhjohMhjnubj)}(hX ``control_port`` Whether user space controls IEEE 802.1X port, i.e., sets/clears ``NL80211_STA_FLAG_AUTHORIZED``. If true, the driver is required to assume that the port is unauthorized until authorized by user space. Otherwise, port is marked authorized by default. h](j)}(h``control_port``h]j)}(hjoh]h control_port}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjoubj6)}(hhh]h)}(hWhether user space controls IEEE 802.1X port, i.e., sets/clears ``NL80211_STA_FLAG_AUTHORIZED``. If true, the driver is required to assume that the port is unauthorized until authorized by user space. Otherwise, port is marked authorized by default.h](h@Whether user space controls IEEE 802.1X port, i.e., sets/clears }(hjphhhNhNubj)}(h``NL80211_STA_FLAG_AUTHORIZED``h]hNL80211_STA_FLAG_AUTHORIZED}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubh. If true, the driver is required to assume that the port is unauthorized until authorized by user space. Otherwise, port is marked authorized by default.}(hjphhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjpubah}(h]h ]h"]h$]h&]uh1j5hjoubeh}(h]h ]h"]h$]h&]uh1jhjphMhjnubj)}(ho``control_port_ethertype`` the control port protocol that should be allowed through even on unauthorized ports h](j)}(h``control_port_ethertype``h]j)}(hjIph]hcontrol_port_ethertype}(hjKphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGpubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjCpubj6)}(hhh]h)}(hSthe control port protocol that should be allowed through even on unauthorized portsh]hSthe control port protocol that should be allowed through even on unauthorized ports}(hjbphhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj_pubah}(h]h ]h"]h$]h&]uh1j5hjCpubeh}(h]h ]h"]h$]h&]uh1jhj^phMhjnubj)}(hX``control_port_no_encrypt`` TRUE to prevent encryption of control port protocol frames. h](j)}(h``control_port_no_encrypt``h]j)}(hjph]hcontrol_port_no_encrypt}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj}pubj6)}(hhh]h)}(h;TRUE to prevent encryption of control port protocol frames.h]h;TRUE to prevent encryption of control port protocol frames.}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjpubah}(h]h ]h"]h$]h&]uh1j5hj}pubeh}(h]h ]h"]h$]h&]uh1jhjphMhjnubj)}(h``control_port_over_nl80211`` TRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface. h](j)}(h``control_port_over_nl80211``h]j)}(hjph]hcontrol_port_over_nl80211}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjpubj6)}(hhh]h)}(hhTRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface.h]hhTRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface.}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjpubah}(h]h ]h"]h$]h&]uh1j5hjpubeh}(h]h ]h"]h$]h&]uh1jhjphMhjnubj)}(h\``control_port_no_preauth`` disables pre-auth rx over the nl80211 control port for mac80211 h](j)}(h``control_port_no_preauth``h]j)}(hjph]hcontrol_port_no_preauth}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjpubj6)}(hhh]h)}(h?disables pre-auth rx over the nl80211 control port for mac80211h]h?disables pre-auth rx over the nl80211 control port for mac80211}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj qubah}(h]h ]h"]h$]h&]uh1j5hjpubeh}(h]h ]h"]h$]h&]uh1jhj qhMhjnubj)}(h=``psk`` PSK (for devices supporting 4-way-handshake offload) h](j)}(h``psk``h]j)}(hj1qh]hpsk}(hj3qhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/qubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj+qubj6)}(hhh]h)}(h4PSK (for devices supporting 4-way-handshake offload)h]h4PSK (for devices supporting 4-way-handshake offload)}(hjJqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFqhMhjGqubah}(h]h ]h"]h$]h&]uh1j5hj+qubeh}(h]h ]h"]h$]h&]uh1jhjFqhMhjnubj)}(hQ``sae_pwd`` password for SAE authentication (for devices supporting SAE offload) h](j)}(h ``sae_pwd``h]j)}(hjjqh]hsae_pwd}(hjlqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhqubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjdqubj6)}(hhh]h)}(hDpassword for SAE authentication (for devices supporting SAE offload)h]hDpassword for SAE authentication (for devices supporting SAE offload)}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqubah}(h]h ]h"]h$]h&]uh1j5hjdqubeh}(h]h ]h"]h$]h&]uh1jhjqhMhjnubj)}(hL``sae_pwd_len`` length of SAE password (for devices supporting SAE offload) h](j)}(h``sae_pwd_len``h]j)}(hjqh]h sae_pwd_len}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqubj6)}(hhh]h)}(h;length of SAE password (for devices supporting SAE offload)h]h;length of SAE password (for devices supporting SAE offload)}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjqhMhjqubah}(h]h ]h"]h$]h&]uh1j5hjqubeh}(h]h ]h"]h$]h&]uh1jhjqhMhjnubj)}(h:``sae_pwe`` The mechanisms allowed for SAE PWE derivation:h](j)}(h ``sae_pwe``h]j)}(hjqh]hsae_pwe}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqubj6)}(hhh]h)}(h.The mechanisms allowed for SAE PWE derivation:h]h.The mechanisms allowed for SAE PWE derivation:}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqubah}(h]h ]h"]h$]h&]uh1j5hjqubeh}(h]h ]h"]h$]h&]uh1jhjqhMhjnubeh}(h]h ]h"]h$]h&]uh1jhjUnubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hj rh]h Description}(hj"rhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjrubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubh block_quote)}(hXNL80211_SAE_PWE_UNSPECIFIED Not-specified, used to indicate userspace did not specify any preference. The driver should follow its internal policy in such a scenario. NL80211_SAE_PWE_HUNT_AND_PECK Allow hunting-and-pecking loop only NL80211_SAE_PWE_HASH_TO_ELEMENT Allow hash-to-element only NL80211_SAE_PWE_BOTH Allow either hunting-and-pecking loop or hash-to-element h]j)}(hhh](j)}(hNL80211_SAE_PWE_UNSPECIFIED Not-specified, used to indicate userspace did not specify any preference. The driver should follow its internal policy in such a scenario. h](j)}(hNL80211_SAE_PWE_UNSPECIFIEDh]hNL80211_SAE_PWE_UNSPECIFIED}(hjCrhhhNhNubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj?rubj6)}(hhh]h)}(hNot-specified, used to indicate userspace did not specify any preference. The driver should follow its internal policy in such a scenario.h]hNot-specified, used to indicate userspace did not specify any preference. The driver should follow its internal policy in such a scenario.}(hjUrhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjRrubah}(h]h ]h"]h$]h&]uh1j5hj?rubeh}(h]h ]h"]h$]h&]uh1jhjQrhMhjhjyubj6)}(hhh]h)}(hGindicates whether bss color attribute is present in beacon data or not.h]hGindicates whether bss color attribute is present in beacon data or not.}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyhM>hjyubah}(h]h ]h"]h$]h&]uh1j5hjyubeh}(h]h ]h"]h$]h&]uh1jhjyhM>hjsubeh}(h]h ]h"]h$]h&]uh1jhjsubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_ap_settings (C struct)c.cfg80211_ap_settingshNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hcfg80211_ap_settingsh]jo)}(hstruct cfg80211_ap_settingsh](ju)}(hjh]hstruct}(hj_yhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj[yhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMEubj)}(h h]h }(hjmyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[yhhhjlyhMEubj)}(hcfg80211_ap_settingsh]j)}(hjYyh]hcfg80211_ap_settings}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{yubah}(h]h ](jjeh"]h$]h&]jjuh1jhj[yhhhjlyhMEubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjWyhhhjlyhMEubah}(h]jRyah ](jjeh"]h$]h&]jj)jhuh1jhhjlyhMEhjTyhhubj)}(hhh]h)}(hAP configurationh]hAP configuration}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjyhhubah}(h]h ]h"]h$]h&]uh1jhjTyhhhjlyhMEubeh}(h]h ](j$structeh"]h$]h&]jj$jjyjjyjjjuh1jchhhj^bhNhNubj)}(hX **Definition**:: struct cfg80211_ap_settings { struct cfg80211_chan_def chandef; struct cfg80211_beacon_data beacon; int beacon_interval, dtim_period; const u8 *ssid; size_t ssid_len; enum nl80211_hidden_ssid hidden_ssid; struct cfg80211_crypto_settings crypto; bool privacy; enum nl80211_auth_type auth_type; int inactivity_timeout; u8 p2p_ctwindow; bool p2p_opp_ps; const struct cfg80211_acl_data *acl; bool pbss; struct cfg80211_bitrate_mask beacon_rate; const struct ieee80211_ht_cap *ht_cap; const struct ieee80211_vht_cap *vht_cap; const struct ieee80211_he_cap_elem *he_cap; const struct ieee80211_he_operation *he_oper; const struct ieee80211_eht_cap_elem *eht_cap; const struct ieee80211_eht_operation *eht_oper; bool ht_required, vht_required, he_required, sae_h2e_required; bool twt_responder; u32 flags; struct ieee80211_he_obss_pd he_obss_pd; struct cfg80211_fils_discovery fils_discovery; struct cfg80211_unsol_bcast_probe_resp unsol_bcast_probe_resp; struct cfg80211_mbssid_config mbssid_config; u8 s1g_long_beacon_period; struct cfg80211_s1g_short_beacon s1g_short_beacon; }; **Members** ``chandef`` defines the channel to use ``beacon`` beacon data ``beacon_interval`` beacon interval ``dtim_period`` DTIM period ``ssid`` SSID to be used in the BSS (note: may be ``NULL`` if not provided from user space) ``ssid_len`` length of **ssid** ``hidden_ssid`` whether to hide the SSID in Beacon/Probe Response frames ``crypto`` crypto settings ``privacy`` the BSS uses privacy ``auth_type`` Authentication type (algorithm) ``inactivity_timeout`` time in seconds to determine station's inactivity. ``p2p_ctwindow`` P2P CT Window ``p2p_opp_ps`` P2P opportunistic PS ``acl`` ACL configuration used by the drivers which has support for MAC address based access control ``pbss`` If set, start as a PCP instead of AP. Relevant for DMG networks. ``beacon_rate`` bitrate to be used for beacons ``ht_cap`` HT capabilities (or ``NULL`` if HT isn't enabled) ``vht_cap`` VHT capabilities (or ``NULL`` if VHT isn't enabled) ``he_cap`` HE capabilities (or ``NULL`` if HE isn't enabled) ``he_oper`` HE operation IE (or ``NULL`` if HE isn't enabled) ``eht_cap`` EHT capabilities (or ``NULL`` if EHT isn't enabled) ``eht_oper`` EHT operation IE (or ``NULL`` if EHT isn't enabled) ``ht_required`` stations must support HT ``vht_required`` stations must support VHT ``he_required`` stations must support HE ``sae_h2e_required`` stations must support direct H2E technique in SAE ``twt_responder`` Enable Target Wait Time ``flags`` flags, as defined in :c:type:`enum nl80211_ap_settings_flags ` ``he_obss_pd`` OBSS Packet Detection settings ``fils_discovery`` FILS discovery transmission parameters ``unsol_bcast_probe_resp`` Unsolicited broadcast probe response parameters ``mbssid_config`` AP settings for multiple bssid ``s1g_long_beacon_period`` S1G long beacon period ``s1g_short_beacon`` S1G short beacon datah](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyubh:}(hjyhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjyubj( )}(hXstruct cfg80211_ap_settings { struct cfg80211_chan_def chandef; struct cfg80211_beacon_data beacon; int beacon_interval, dtim_period; const u8 *ssid; size_t ssid_len; enum nl80211_hidden_ssid hidden_ssid; struct cfg80211_crypto_settings crypto; bool privacy; enum nl80211_auth_type auth_type; int inactivity_timeout; u8 p2p_ctwindow; bool p2p_opp_ps; const struct cfg80211_acl_data *acl; bool pbss; struct cfg80211_bitrate_mask beacon_rate; const struct ieee80211_ht_cap *ht_cap; const struct ieee80211_vht_cap *vht_cap; const struct ieee80211_he_cap_elem *he_cap; const struct ieee80211_he_operation *he_oper; const struct ieee80211_eht_cap_elem *eht_cap; const struct ieee80211_eht_operation *eht_oper; bool ht_required, vht_required, he_required, sae_h2e_required; bool twt_responder; u32 flags; struct ieee80211_he_obss_pd he_obss_pd; struct cfg80211_fils_discovery fils_discovery; struct cfg80211_unsol_bcast_probe_resp unsol_bcast_probe_resp; struct cfg80211_mbssid_config mbssid_config; u8 s1g_long_beacon_period; struct cfg80211_s1g_short_beacon s1g_short_beacon; };h]hXstruct cfg80211_ap_settings { struct cfg80211_chan_def chandef; struct cfg80211_beacon_data beacon; int beacon_interval, dtim_period; const u8 *ssid; size_t ssid_len; enum nl80211_hidden_ssid hidden_ssid; struct cfg80211_crypto_settings crypto; bool privacy; enum nl80211_auth_type auth_type; int inactivity_timeout; u8 p2p_ctwindow; bool p2p_opp_ps; const struct cfg80211_acl_data *acl; bool pbss; struct cfg80211_bitrate_mask beacon_rate; const struct ieee80211_ht_cap *ht_cap; const struct ieee80211_vht_cap *vht_cap; const struct ieee80211_he_cap_elem *he_cap; const struct ieee80211_he_operation *he_oper; const struct ieee80211_eht_cap_elem *eht_cap; const struct ieee80211_eht_operation *eht_oper; bool ht_required, vht_required, he_required, sae_h2e_required; bool twt_responder; u32 flags; struct ieee80211_he_obss_pd he_obss_pd; struct cfg80211_fils_discovery fils_discovery; struct cfg80211_unsol_bcast_probe_resp unsol_bcast_probe_resp; struct cfg80211_mbssid_config mbssid_config; u8 s1g_long_beacon_period; struct cfg80211_s1g_short_beacon s1g_short_beacon; };}hjysbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjyubh)}(h **Members**h]j)}(hjyh]hMembers}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjyubj)}(hhh](j)}(h'``chandef`` defines the channel to use h](j)}(h ``chandef``h]j)}(hjzh]hchandef}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj zubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjzubj6)}(hhh]h)}(hdefines the channel to useh]hdefines the channel to use}(hj'zhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#zhMhj$zubah}(h]h ]h"]h$]h&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhj#zhMhjzubj)}(h``beacon`` beacon data h](j)}(h ``beacon``h]j)}(hjGzh]hbeacon}(hjIzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEzubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjAzubj6)}(hhh]h)}(h beacon datah]h beacon data}(hj`zhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\zhMhj]zubah}(h]h ]h"]h$]h&]uh1j5hjAzubeh}(h]h ]h"]h$]h&]uh1jhj\zhMhjzubj)}(h$``beacon_interval`` beacon interval h](j)}(h``beacon_interval``h]j)}(hjzh]hbeacon_interval}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~zubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjzzubj6)}(hhh]h)}(hbeacon intervalh]hbeacon interval}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzhMhjzubah}(h]h ]h"]h$]h&]uh1j5hjzzubeh}(h]h ]h"]h$]h&]uh1jhjzhMhjzubj)}(h``dtim_period`` DTIM period h](j)}(h``dtim_period``h]j)}(hjzh]h dtim_period}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjzubj6)}(hhh]h)}(h DTIM periodh]h DTIM period}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzhMhjzubah}(h]h ]h"]h$]h&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhjzhMhjzubj)}(h\``ssid`` SSID to be used in the BSS (note: may be ``NULL`` if not provided from user space) h](j)}(h``ssid``h]j)}(hjzh]hssid}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjzubj6)}(hhh]h)}(hRSSID to be used in the BSS (note: may be ``NULL`` if not provided from user space)h](h)SSID to be used in the BSS (note: may be }(hj {hhhNhNubj)}(h``NULL``h]hNULL}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj {ubh! if not provided from user space)}(hj {hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj{ubah}(h]h ]h"]h$]h&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhj{hMhjzubj)}(h ``ssid_len`` length of **ssid** h](j)}(h ``ssid_len``h]j)}(hj>{h]hssid_len}(hj@{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<{ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj8{ubj6)}(hhh]h)}(hlength of **ssid**h](h length of }(hjW{hhhNhNubj)}(h**ssid**h]hssid}(hj_{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjW{ubeh}(h]h ]h"]h$]h&]uh1hhjS{hMhjT{ubah}(h]h ]h"]h$]h&]uh1j5hj8{ubeh}(h]h ]h"]h$]h&]uh1jhjS{hMhjzubj)}(hI``hidden_ssid`` whether to hide the SSID in Beacon/Probe Response frames h](j)}(h``hidden_ssid``h]j)}(hj{h]h hidden_ssid}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj{ubj6)}(hhh]h)}(h8whether to hide the SSID in Beacon/Probe Response framesh]h8whether to hide the SSID in Beacon/Probe Response frames}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{hMhj{ubah}(h]h ]h"]h$]h&]uh1j5hj{ubeh}(h]h ]h"]h$]h&]uh1jhj{hMhjzubj)}(h``crypto`` crypto settings h](j)}(h ``crypto``h]j)}(hj{h]hcrypto}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj{ubj6)}(hhh]h)}(hcrypto settingsh]hcrypto settings}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{hMhj{ubah}(h]h ]h"]h$]h&]uh1j5hj{ubeh}(h]h ]h"]h$]h&]uh1jhj{hMhjzubj)}(h!``privacy`` the BSS uses privacy h](j)}(h ``privacy``h]j)}(hj{h]hprivacy}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj{ubj6)}(hhh]h)}(hthe BSS uses privacyh]hthe BSS uses privacy}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj |hMhj |ubah}(h]h ]h"]h$]h&]uh1j5hj{ubeh}(h]h ]h"]h$]h&]uh1jhj |hMhjzubj)}(h.``auth_type`` Authentication type (algorithm) h](j)}(h ``auth_type``h]j)}(hj0|h]h auth_type}(hj2|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.|ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj*|ubj6)}(hhh]h)}(hAuthentication type (algorithm)h]hAuthentication type (algorithm)}(hjI|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjE|hMhjF|ubah}(h]h ]h"]h$]h&]uh1j5hj*|ubeh}(h]h ]h"]h$]h&]uh1jhjE|hMhjzubj)}(hJ``inactivity_timeout`` time in seconds to determine station's inactivity. h](j)}(h``inactivity_timeout``h]j)}(hji|h]hinactivity_timeout}(hjk|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjg|ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjc|ubj6)}(hhh]h)}(h2time in seconds to determine station's inactivity.h]h4time in seconds to determine station’s inactivity.}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~|hMhj|ubah}(h]h ]h"]h$]h&]uh1j5hjc|ubeh}(h]h ]h"]h$]h&]uh1jhj~|hMhjzubj)}(h``p2p_ctwindow`` P2P CT Window h](j)}(h``p2p_ctwindow``h]j)}(hj|h]h p2p_ctwindow}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj|ubj6)}(hhh]h)}(h P2P CT Windowh]h P2P CT Window}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hMhj|ubah}(h]h ]h"]h$]h&]uh1j5hj|ubeh}(h]h ]h"]h$]h&]uh1jhj|hMhjzubj)}(h$``p2p_opp_ps`` P2P opportunistic PS h](j)}(h``p2p_opp_ps``h]j)}(hj|h]h p2p_opp_ps}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj|ubj6)}(hhh]h)}(hP2P opportunistic PSh]hP2P opportunistic PS}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hMhj|ubah}(h]h ]h"]h$]h&]uh1j5hj|ubeh}(h]h ]h"]h$]h&]uh1jhj|hMhjzubj)}(he``acl`` ACL configuration used by the drivers which has support for MAC address based access control h](j)}(h``acl``h]j)}(hj}h]hacl}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj}ubj6)}(hhh]h)}(h\ACL configuration used by the drivers which has support for MAC address based access controlh]h\ACL configuration used by the drivers which has support for MAC address based access control}(hj-}hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj*}ubah}(h]h ]h"]h$]h&]uh1j5hj}ubeh}(h]h ]h"]h$]h&]uh1jhj)}hMhjzubj)}(hJ``pbss`` If set, start as a PCP instead of AP. Relevant for DMG networks. h](j)}(h``pbss``h]j)}(hjN}h]hpbss}(hjP}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjL}ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjH}ubj6)}(hhh]h)}(h@If set, start as a PCP instead of AP. Relevant for DMG networks.h]h@If set, start as a PCP instead of AP. Relevant for DMG networks.}(hjg}hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjd}ubah}(h]h ]h"]h$]h&]uh1j5hjH}ubeh}(h]h ]h"]h$]h&]uh1jhjc}hMhjzubj)}(h/``beacon_rate`` bitrate to be used for beacons h](j)}(h``beacon_rate``h]j)}(hj}h]h beacon_rate}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj}ubj6)}(hhh]h)}(hbitrate to be used for beaconsh]hbitrate to be used for beacons}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj}hMhj}ubah}(h]h ]h"]h$]h&]uh1j5hj}ubeh}(h]h ]h"]h$]h&]uh1jhj}hMhjzubj)}(h=``ht_cap`` HT capabilities (or ``NULL`` if HT isn't enabled) h](j)}(h ``ht_cap``h]j)}(hj}h]hht_cap}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj}ubj6)}(hhh]h)}(h1HT capabilities (or ``NULL`` if HT isn't enabled)h](hHT capabilities (or }(hj}hhhNhNubj)}(h``NULL``h]hNULL}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubh if HT isn’t enabled)}(hj}hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj}hMhj}ubah}(h]h ]h"]h$]h&]uh1j5hj}ubeh}(h]h ]h"]h$]h&]uh1jhj}hMhjzubj)}(h@``vht_cap`` VHT capabilities (or ``NULL`` if VHT isn't enabled) h](j)}(h ``vht_cap``h]j)}(hj ~h]hvht_cap}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ~ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj~ubj6)}(hhh]h)}(h3VHT capabilities (or ``NULL`` if VHT isn't enabled)h](hVHT capabilities (or }(hj%~hhhNhNubj)}(h``NULL``h]hNULL}(hj-~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%~ubh if VHT isn’t enabled)}(hj%~hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj!~hMhj"~ubah}(h]h ]h"]h$]h&]uh1j5hj~ubeh}(h]h ]h"]h$]h&]uh1jhj!~hMhjzubj)}(h=``he_cap`` HE capabilities (or ``NULL`` if HE isn't enabled) h](j)}(h ``he_cap``h]j)}(hjW~h]hhe_cap}(hjY~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjU~ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjQ~ubj6)}(hhh]h)}(h1HE capabilities (or ``NULL`` if HE isn't enabled)h](hHE capabilities (or }(hjp~hhhNhNubj)}(h``NULL``h]hNULL}(hjx~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjp~ubh if HE isn’t enabled)}(hjp~hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjl~hMhjm~ubah}(h]h ]h"]h$]h&]uh1j5hjQ~ubeh}(h]h ]h"]h$]h&]uh1jhjl~hMhjzubj)}(h>``he_oper`` HE operation IE (or ``NULL`` if HE isn't enabled) h](j)}(h ``he_oper``h]j)}(hj~h]hhe_oper}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj~ubj6)}(hhh]h)}(h1HE operation IE (or ``NULL`` if HE isn't enabled)h](hHE operation IE (or }(hj~hhhNhNubj)}(h``NULL``h]hNULL}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubh if HE isn’t enabled)}(hj~hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj~hMhj~ubah}(h]h ]h"]h$]h&]uh1j5hj~ubeh}(h]h ]h"]h$]h&]uh1jhj~hMhjzubj)}(h@``eht_cap`` EHT capabilities (or ``NULL`` if EHT isn't enabled) h](j)}(h ``eht_cap``h]j)}(hj~h]heht_cap}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj~ubj6)}(hhh]h)}(h3EHT capabilities (or ``NULL`` if EHT isn't enabled)h](hEHT capabilities (or }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh if EHT isn’t enabled)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hj~ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjzubj)}(hA``eht_oper`` EHT operation IE (or ``NULL`` if EHT isn't enabled) h](j)}(h ``eht_oper``h]j)}(hj8h]heht_oper}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj2ubj6)}(hhh]h)}(h3EHT operation IE (or ``NULL`` if EHT isn't enabled)h](hEHT operation IE (or }(hjQhhhNhNubj)}(h``NULL``h]hNULL}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubh if EHT isn’t enabled)}(hjQhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjMhMhjNubah}(h]h ]h"]h$]h&]uh1j5hj2ubeh}(h]h ]h"]h$]h&]uh1jhjMhMhjzubj)}(h)``ht_required`` stations must support HT h](j)}(h``ht_required``h]j)}(hjh]h ht_required}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj}ubj6)}(hhh]h)}(hstations must support HTh]hstations must support HT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hj}ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjzubj)}(h+``vht_required`` stations must support VHT h](j)}(h``vht_required``h]j)}(hjh]h vht_required}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hstations must support VHTh]hstations must support VHT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjzubj)}(h)``he_required`` stations must support HE h](j)}(h``he_required``h]j)}(hjh]h he_required}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hstations must support HEh]hstations must support HE}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjzubj)}(hG``sae_h2e_required`` stations must support direct H2E technique in SAE h](j)}(h``sae_h2e_required``h]j)}(hj.h]hsae_h2e_required}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj(ubj6)}(hhh]h)}(h1stations must support direct H2E technique in SAEh]h1stations must support direct H2E technique in SAE}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChMhjDubah}(h]h ]h"]h$]h&]uh1j5hj(ubeh}(h]h ]h"]h$]h&]uh1jhjChMhjzubj)}(h*``twt_responder`` Enable Target Wait Time h](j)}(h``twt_responder``h]j)}(hjgh]h twt_responder}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjaubj6)}(hhh]h)}(hEnable Target Wait Timeh]hEnable Target Wait Time}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hMhj}ubah}(h]h ]h"]h$]h&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hMhjzubj)}(hd``flags`` flags, as defined in :c:type:`enum nl80211_ap_settings_flags ` h](j)}(h ``flags``h]j)}(hjh]hflags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hYflags, as defined in :c:type:`enum nl80211_ap_settings_flags `h](hflags, as defined in }(hjhhhNhNubh)}(hD:c:type:`enum nl80211_ap_settings_flags `h]j)}(hjÀh]henum nl80211_ap_settings_flags}(hjŀhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_ap_settings_flagsuh1hhjhMhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjzubj)}(h.``he_obss_pd`` OBSS Packet Detection settings h](j)}(h``he_obss_pd``h]j)}(hjh]h he_obss_pd}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hOBSS Packet Detection settingsh]hOBSS Packet Detection settings}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjzubj)}(h:``fils_discovery`` FILS discovery transmission parameters h](j)}(h``fils_discovery``h]j)}(hj1h]hfils_discovery}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj+ubj6)}(hhh]h)}(h&FILS discovery transmission parametersh]h&FILS discovery transmission parameters}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFhMhjGubah}(h]h ]h"]h$]h&]uh1j5hj+ubeh}(h]h ]h"]h$]h&]uh1jhjFhMhjzubj)}(hK``unsol_bcast_probe_resp`` Unsolicited broadcast probe response parameters h](j)}(h``unsol_bcast_probe_resp``h]j)}(hjjh]hunsol_bcast_probe_resp}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjdubj6)}(hhh]h)}(h/Unsolicited broadcast probe response parametersh]h/Unsolicited broadcast probe response parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjdubeh}(h]h ]h"]h$]h&]uh1jhjhMhjzubj)}(h1``mbssid_config`` AP settings for multiple bssid h](j)}(h``mbssid_config``h]j)}(hjh]h mbssid_config}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hAP settings for multiple bssidh]hAP settings for multiple bssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjzubj)}(h2``s1g_long_beacon_period`` S1G long beacon period h](j)}(h``s1g_long_beacon_period``h]j)}(hj܁h]hs1g_long_beacon_period}(hjށhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjځubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjցubj6)}(hhh]h)}(hS1G long beacon periodh]hS1G long beacon period}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjցubeh}(h]h ]h"]h$]h&]uh1jhjhMhjzubj)}(h*``s1g_short_beacon`` S1G short beacon datah](j)}(h``s1g_short_beacon``h]j)}(hjh]hs1g_short_beacon}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hS1G short beacon datah]hS1G short beacon data}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj+ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj*hMhjzubeh}(h]h ]h"]h$]h&]uh1jhjyubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hjXh]h Description}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubh)}(h"Used to configure an AP interface.h]h"Used to configure an AP interface.}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_station_parameters (C struct)c.station_parametershNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hstation_parametersh]jo)}(hstruct station_parametersh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubj)}(hstation_parametersh]j)}(hjh]hstation_parameters}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMhjhhubj)}(hhh]h)}(hstation parametersh]hstation parameters}(hj؂hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjՂhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhj^bhNhNubj)}(hX **Definition**:: struct station_parameters { struct net_device *vlan; u32 sta_flags_mask, sta_flags_set; u32 sta_modify_mask; int listen_interval; u16 aid; u16 vlan_id; u16 peer_aid; u8 plink_action; u8 plink_state; u8 uapsd_queues; u8 max_sp; enum nl80211_mesh_power_mode local_pm; u16 capability; const u8 *ext_capab; u8 ext_capab_len; const u8 *supported_channels; u8 supported_channels_len; const u8 *supported_oper_classes; u8 supported_oper_classes_len; int support_p2p_ps; u16 airtime_weight; bool eml_cap_present; u16 eml_cap; struct link_station_parameters link_sta_params; }; **Members** ``vlan`` vlan interface station should belong to ``sta_flags_mask`` station flags that changed (bitmask of BIT(``NL80211_STA_FLAG_``...)) ``sta_flags_set`` station flags values (bitmask of BIT(``NL80211_STA_FLAG_``...)) ``sta_modify_mask`` bitmap indicating which parameters changed (for those that don't have a natural "no change" value), see :c:type:`enum station_parameters_apply_mask ` ``listen_interval`` listen interval or -1 for no change ``aid`` AID or zero for no change ``vlan_id`` VLAN ID for station (if nonzero) ``peer_aid`` mesh peer AID or zero for no change ``plink_action`` plink action to take ``plink_state`` set the peer link state for a station ``uapsd_queues`` bitmap of queues configured for uapsd. same format as the AC bitmap in the QoS info field ``max_sp`` max Service Period. same format as the MAX_SP in the QoS info field (but already shifted down) ``local_pm`` local link-specific mesh power save mode (no change when set to unknown) ``capability`` station capability ``ext_capab`` extended capabilities of the station ``ext_capab_len`` number of extended capabilities ``supported_channels`` supported channels in IEEE 802.11 format ``supported_channels_len`` number of supported channels ``supported_oper_classes`` supported oper classes in IEEE 802.11 format ``supported_oper_classes_len`` number of supported operating classes ``support_p2p_ps`` information if station supports P2P PS mechanism ``airtime_weight`` airtime scheduler weight for this station ``eml_cap_present`` Specifies if EML capabilities field (**eml_cap**) is present/updated ``eml_cap`` EML capabilities of this station ``link_sta_params`` link related params.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj( )}(hXstruct station_parameters { struct net_device *vlan; u32 sta_flags_mask, sta_flags_set; u32 sta_modify_mask; int listen_interval; u16 aid; u16 vlan_id; u16 peer_aid; u8 plink_action; u8 plink_state; u8 uapsd_queues; u8 max_sp; enum nl80211_mesh_power_mode local_pm; u16 capability; const u8 *ext_capab; u8 ext_capab_len; const u8 *supported_channels; u8 supported_channels_len; const u8 *supported_oper_classes; u8 supported_oper_classes_len; int support_p2p_ps; u16 airtime_weight; bool eml_cap_present; u16 eml_cap; struct link_station_parameters link_sta_params; };h]hXstruct station_parameters { struct net_device *vlan; u32 sta_flags_mask, sta_flags_set; u32 sta_modify_mask; int listen_interval; u16 aid; u16 vlan_id; u16 peer_aid; u8 plink_action; u8 plink_state; u8 uapsd_queues; u8 max_sp; enum nl80211_mesh_power_mode local_pm; u16 capability; const u8 *ext_capab; u8 ext_capab_len; const u8 *supported_channels; u8 supported_channels_len; const u8 *supported_oper_classes; u8 supported_oper_classes_len; int support_p2p_ps; u16 airtime_weight; bool eml_cap_present; u16 eml_cap; struct link_station_parameters link_sta_params; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh)}(h **Members**h]j)}(hj&h]hMembers}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj)}(hhh](j)}(h1``vlan`` vlan interface station should belong to h](j)}(h``vlan``h]j)}(hjEh]hvlan}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj?ubj6)}(hhh]h)}(h'vlan interface station should belong toh]h'vlan interface station should belong to}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhMhj[ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhjZhMhj<ubj)}(hY``sta_flags_mask`` station flags that changed (bitmask of BIT(``NL80211_STA_FLAG_``...)) h](j)}(h``sta_flags_mask``h]j)}(hj~h]hsta_flags_mask}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjxubj6)}(hhh]h)}(hEstation flags that changed (bitmask of BIT(``NL80211_STA_FLAG_``...))h](h+station flags that changed (bitmask of BIT(}(hjhhhNhNubj)}(h``NL80211_STA_FLAG_``h]hNL80211_STA_FLAG_}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh...))}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjxubeh}(h]h ]h"]h$]h&]uh1jhjhMhj<ubj)}(hR``sta_flags_set`` station flags values (bitmask of BIT(``NL80211_STA_FLAG_``...)) h](j)}(h``sta_flags_set``h]j)}(hjʃh]h sta_flags_set}(hj̃hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjȃubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjăubj6)}(hhh]h)}(h?station flags values (bitmask of BIT(``NL80211_STA_FLAG_``...))h](h%station flags values (bitmask of BIT(}(hjhhhNhNubj)}(h``NL80211_STA_FLAG_``h]hNL80211_STA_FLAG_}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh...))}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjăubeh}(h]h ]h"]h$]h&]uh1jhj߃hMhj<ubj)}(h``sta_modify_mask`` bitmap indicating which parameters changed (for those that don't have a natural "no change" value), see :c:type:`enum station_parameters_apply_mask ` h](j)}(h``sta_modify_mask``h]j)}(hjh]hsta_modify_mask}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hbitmap indicating which parameters changed (for those that don't have a natural "no change" value), see :c:type:`enum station_parameters_apply_mask `h](hnbitmap indicating which parameters changed (for those that don’t have a natural “no change” value), see }(hj/hhhNhNubh)}(hL:c:type:`enum station_parameters_apply_mask `h]j)}(hj9h]h"enum station_parameters_apply_mask}(hj;hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6station_parameters_apply_maskuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj/ubeh}(h]h ]h"]h$]h&]uh1hhjVhMhj,ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj+hMhj<ubj)}(h8``listen_interval`` listen interval or -1 for no change h](j)}(h``listen_interval``h]j)}(hjoh]hlisten_interval}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjiubj6)}(hhh]h)}(h#listen interval or -1 for no changeh]h#listen interval or -1 for no change}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjiubeh}(h]h ]h"]h$]h&]uh1jhjhMhj<ubj)}(h"``aid`` AID or zero for no change h](j)}(h``aid``h]j)}(hjh]haid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hAID or zero for no changeh]hAID or zero for no change}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj<ubj)}(h-``vlan_id`` VLAN ID for station (if nonzero) h](j)}(h ``vlan_id``h]j)}(hjh]hvlan_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj߄ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjۄubj6)}(hhh]h)}(h VLAN ID for station (if nonzero)h]h VLAN ID for station (if nonzero)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjۄubeh}(h]h ]h"]h$]h&]uh1jhjhMhj<ubj)}(h1``peer_aid`` mesh peer AID or zero for no change h](j)}(h ``peer_aid``h]j)}(hjh]hpeer_aid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h#mesh peer AID or zero for no changeh]h#mesh peer AID or zero for no change}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hMhj0ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj/hMhj<ubj)}(h&``plink_action`` plink action to take h](j)}(h``plink_action``h]j)}(hjSh]h plink_action}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjMubj6)}(hhh]h)}(hplink action to takeh]hplink action to take}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhMhjiubah}(h]h ]h"]h$]h&]uh1j5hjMubeh}(h]h ]h"]h$]h&]uh1jhjhhMhj<ubj)}(h6``plink_state`` set the peer link state for a station h](j)}(h``plink_state``h]j)}(hjh]h plink_state}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h%set the peer link state for a stationh]h%set the peer link state for a station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj<ubj)}(hk``uapsd_queues`` bitmap of queues configured for uapsd. same format as the AC bitmap in the QoS info field h](j)}(h``uapsd_queues``h]j)}(hjŅh]h uapsd_queues}(hjDžhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjÅubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hYbitmap of queues configured for uapsd. same format as the AC bitmap in the QoS info fieldh]hYbitmap of queues configured for uapsd. same format as the AC bitmap in the QoS info field}(hjޅhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjۅubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjڅhMhj<ubj)}(hj``max_sp`` max Service Period. same format as the MAX_SP in the QoS info field (but already shifted down) h](j)}(h ``max_sp``h]j)}(hjh]hmax_sp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h^max Service Period. same format as the MAX_SP in the QoS info field (but already shifted down)h]h^max Service Period. same format as the MAX_SP in the QoS info field (but already shifted down)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj<ubj)}(hV``local_pm`` local link-specific mesh power save mode (no change when set to unknown) h](j)}(h ``local_pm``h]j)}(hj9h]hlocal_pm}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj3ubj6)}(hhh]h)}(hHlocal link-specific mesh power save mode (no change when set to unknown)h]hHlocal link-specific mesh power save mode (no change when set to unknown)}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjOubah}(h]h ]h"]h$]h&]uh1j5hj3ubeh}(h]h ]h"]h$]h&]uh1jhjNhMhj<ubj)}(h"``capability`` station capability h](j)}(h``capability``h]j)}(hjsh]h capability}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjmubj6)}(hhh]h)}(hstation capabilityh]hstation capability}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjmubeh}(h]h ]h"]h$]h&]uh1jhjhMhj<ubj)}(h3``ext_capab`` extended capabilities of the station h](j)}(h ``ext_capab``h]j)}(hjh]h ext_capab}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h$extended capabilities of the stationh]h$extended capabilities of the station}(hjņhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhj†ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj<ubj)}(h2``ext_capab_len`` number of extended capabilities h](j)}(h``ext_capab_len``h]j)}(hjh]h ext_capab_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj߆ubj6)}(hhh]h)}(hnumber of extended capabilitiesh]hnumber of extended capabilities}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hj߆ubeh}(h]h ]h"]h$]h&]uh1jhjhMhj<ubj)}(h@``supported_channels`` supported channels in IEEE 802.11 format h](j)}(h``supported_channels``h]j)}(hjh]hsupported_channels}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h(supported channels in IEEE 802.11 formath]h(supported channels in IEEE 802.11 format}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMhj4ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}($h]h ]h"]h$]h&]uh1jhj3hMhj<ubj)}(h8``supported_channels_len`` number of supported channels h](j)}(h``supported_channels_len``h]j)}(hjWh]hsupported_channels_len}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjQubj6)}(hhh]h)}(hnumber of supported channelsh]hnumber of supported channels}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhMhjmubah}(h]h ]h"]h$]h&]uh1j5hjQubeh}(h]h ]h"]h$]h&]uh1jhjlhMhj<ubj)}(hH``supported_oper_classes`` supported oper classes in IEEE 802.11 format h](j)}(h``supported_oper_classes``h]j)}(hjh]hsupported_oper_classes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h,supported oper classes in IEEE 802.11 formath]h,supported oper classes in IEEE 802.11 format}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj<ubj)}(hE``supported_oper_classes_len`` number of supported operating classes h](j)}(h``supported_oper_classes_len``h]j)}(hjɇh]hsupported_oper_classes_len}(hjˇhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLJubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjÇubj6)}(hhh]h)}(h%number of supported operating classesh]h%number of supported operating classes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjއhMhj߇ubah}(h]h ]h"]h$]h&]uh1j5hjÇubeh}(h]h ]h"]h$]h&]uh1jhjއhMhj<ubj)}(hD``support_p2p_ps`` information if station supports P2P PS mechanism h](j)}(h``support_p2p_ps``h]j)}(hjh]hsupport_p2p_ps}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h0information if station supports P2P PS mechanismh]h0information if station supports P2P PS mechanism}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj<ubj)}(h=``airtime_weight`` airtime scheduler weight for this station h](j)}(h``airtime_weight``h]j)}(hj;h]hairtime_weight}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj5ubj6)}(hhh]h)}(h)airtime scheduler weight for this stationh]h)airtime scheduler weight for this station}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPhMhjQubah}(h]h ]h"]h$]h&]uh1j5hj5ubeh}(h]h ]h"]h$]h&]uh1jhjPhMhj<ubj)}(hY``eml_cap_present`` Specifies if EML capabilities field (**eml_cap**) is present/updated h](j)}(h``eml_cap_present``h]j)}(hjth]heml_cap_present}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjnubj6)}(hhh]h)}(hDSpecifies if EML capabilities field (**eml_cap**) is present/updatedh](h%Specifies if EML capabilities field (}(hjhhhNhNubj)}(h **eml_cap**h]heml_cap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh) is present/updated}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjnubeh}(h]h ]h"]h$]h&]uh1jhjhMhj<ubj)}(h-``eml_cap`` EML capabilities of this station h](j)}(h ``eml_cap``h]j)}(hjh]heml_cap}(hjˆhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h EML capabilities of this stationh]h EML capabilities of this station}(hjوhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjՈhMhjֈubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjՈhMhj<ubj)}(h(``link_sta_params`` link related params.h](j)}(h``link_sta_params``h]j)}(hjh]hlink_sta_params}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hlink related params.h]hlink related params.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj<ubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hj<h]h Description}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubh)}(h(Used to change and create a new station.h]h(Used to change and create a new station.}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_rate_info_flags (C enum)c.rate_info_flagshNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hrate_info_flagsh]jo)}(henum rate_info_flagsh](ju)}(hjxh]henum}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjvhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvhhhjhMubj)}(hrate_info_flagsh]j)}(hjth]hrate_info_flags}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjvhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjrhhhjhMubah}(h]jmah ](jjeh"]h$]h&]jj)jhuh1jhhjhMhjohhubj)}(hhh]h)}(hbitrate info flagsh]hbitrate info flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMLhjhhubah}(h]h ]h"]h$]h&]uh1jhjohhhjhMubeh}(h]h ](j$enumeh"]h$]h&]jj$jjԉjjԉjjjuh1jchhhj^bhNhNubj)}(hX**Constants** ``RATE_INFO_FLAGS_MCS`` mcs field filled with HT MCS ``RATE_INFO_FLAGS_VHT_MCS`` mcs field filled with VHT MCS ``RATE_INFO_FLAGS_SHORT_GI`` 400ns guard interval ``RATE_INFO_FLAGS_DMG`` 60GHz MCS ``RATE_INFO_FLAGS_HE_MCS`` HE MCS information ``RATE_INFO_FLAGS_EDMG`` 60GHz MCS in EDMG mode ``RATE_INFO_FLAGS_EXTENDED_SC_DMG`` 60GHz extended SC MCS ``RATE_INFO_FLAGS_EHT_MCS`` EHT MCS information ``RATE_INFO_FLAGS_S1G_MCS`` MCS field filled with S1G MCSh](h)}(h **Constants**h]j)}(hjމh]h Constants}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj܉ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMPhj؉ubj)}(hhh](j)}(h5``RATE_INFO_FLAGS_MCS`` mcs field filled with HT MCS h](j)}(h``RATE_INFO_FLAGS_MCS``h]j)}(hjh]hRATE_INFO_FLAGS_MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMShjubj6)}(hhh]h)}(hmcs field filled with HT MCSh]hmcs field filled with HT MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMShjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMShjubj)}(h:``RATE_INFO_FLAGS_VHT_MCS`` mcs field filled with VHT MCS h](j)}(h``RATE_INFO_FLAGS_VHT_MCS``h]j)}(hj6h]hRATE_INFO_FLAGS_VHT_MCS}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMVhj0ubj6)}(hhh]h)}(hmcs field filled with VHT MCSh]hmcs field filled with VHT MCS}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKhMVhjLubah}(h]h ]h"]h$]h&]uh1j5hj0ubeh}(h]h ]h"]h$]h&]uh1jhjKhMVhjubj)}(h2``RATE_INFO_FLAGS_SHORT_GI`` 400ns guard interval h](j)}(h``RATE_INFO_FLAGS_SHORT_GI``h]j)}(hjoh]hRATE_INFO_FLAGS_SHORT_GI}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMYhjiubj6)}(hhh]h)}(h400ns guard intervalh]h400ns guard interval}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMYhjubah}(h]h ]h"]h$]h&]uh1j5hjiubeh}(h]h ]h"]h$]h&]uh1jhjhMYhjubj)}(h"``RATE_INFO_FLAGS_DMG`` 60GHz MCS h](j)}(h``RATE_INFO_FLAGS_DMG``h]j)}(hjh]hRATE_INFO_FLAGS_DMG}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM\hjubj6)}(hhh]h)}(h 60GHz MCSh]h 60GHz MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM\hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM\hjubj)}(h.``RATE_INFO_FLAGS_HE_MCS`` HE MCS information h](j)}(h``RATE_INFO_FLAGS_HE_MCS``h]j)}(hjh]hRATE_INFO_FLAGS_HE_MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjߊubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM_hjۊubj6)}(hhh]h)}(hHE MCS informationh]hHE MCS information}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM_hjubah}(h]h ]h"]h$]h&]uh1j5hjۊubeh}(h]h ]h"]h$]h&]uh1jhjhM_hjubj)}(h0``RATE_INFO_FLAGS_EDMG`` 60GHz MCS in EDMG mode h](j)}(h``RATE_INFO_FLAGS_EDMG``h]j)}(hjh]hRATE_INFO_FLAGS_EDMG}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMbhjubj6)}(hhh]h)}(h60GHz MCS in EDMG modeh]h60GHz MCS in EDMG mode}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hMbhj0ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj/hMbhjubj)}(h:``RATE_INFO_FLAGS_EXTENDED_SC_DMG`` 60GHz extended SC MCS h](j)}(h#``RATE_INFO_FLAGS_EXTENDED_SC_DMG``h]j)}(hjSh]hRATE_INFO_FLAGS_EXTENDED_SC_DMG}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMehjMubj6)}(hhh]h)}(h60GHz extended SC MCSh]h60GHz extended SC MCS}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhMehjiubah}(h]h ]h"]h$]h&]uh1j5hjMubeh}(h]h ]h"]h$]h&]uh1jhjhhMehjubj)}(h0``RATE_INFO_FLAGS_EHT_MCS`` EHT MCS information h](j)}(h``RATE_INFO_FLAGS_EHT_MCS``h]j)}(hjh]hRATE_INFO_FLAGS_EHT_MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhhjubj6)}(hhh]h)}(hEHT MCS informationh]hEHT MCS information}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhhjubj)}(h9``RATE_INFO_FLAGS_S1G_MCS`` MCS field filled with S1G MCSh](j)}(h``RATE_INFO_FLAGS_S1G_MCS``h]j)}(hjŋh]hRATE_INFO_FLAGS_S1G_MCS}(hjNjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjËubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMjhjubj6)}(hhh]h)}(hMCS field filled with S1G MCSh]hMCS field filled with S1G MCS}(hjދhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMkhjۋubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjڋhMjhjubeh}(h]h ]h"]h$]h&]uh1jhj؉ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMmhj^bhhubh)}(h]Used by the driver to indicate the specific rate transmission type for 802.11n transmissions.h]h]Used by the driver to indicate the specific rate transmission type for 802.11n transmissions.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMMhj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_rate_info (C struct) c.rate_infohNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(h rate_infoh]jo)}(hstruct rate_infoh](ju)}(hjh]hstruct}(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjBhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMSubj)}(h h]h }(hjThhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBhhhjShMSubj)}(h rate_infoh]j)}(hj@h]h rate_info}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjbubah}(h]h ](jjeh"]h$]h&]jjuh1jhjBhhhjShMSubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj>hhhjShMSubah}(h]j9ah ](jjeh"]h$]h&]jj)jhuh1jhhjShMShj;hhubj)}(hhh]h)}(hbitrate informationh]hbitrate information}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhj;hhhjShMSubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhj^bhNhNubj)}(hXi**Definition**:: struct rate_info { u16 flags; u16 legacy; u8 mcs; u8 nss; u8 bw; u8 he_gi; u8 he_dcm; u8 he_ru_alloc; u8 n_bonded_ch; u8 eht_gi; u8 eht_ru_alloc; }; **Members** ``flags`` bitflag of flags from :c:type:`enum rate_info_flags ` ``legacy`` bitrate in 100kbit/s for 802.11abg ``mcs`` mcs index if struct describes an HT/VHT/HE/EHT/S1G rate ``nss`` number of streams (VHT & HE only) ``bw`` bandwidth (from :c:type:`enum rate_info_bw `) ``he_gi`` HE guard interval (from :c:type:`enum nl80211_he_gi `) ``he_dcm`` HE DCM value ``he_ru_alloc`` HE RU allocation (from :c:type:`enum nl80211_he_ru_alloc `, only valid if bw is ``RATE_INFO_BW_HE_RU``) ``n_bonded_ch`` In case of EDMG the number of bonded channels (1-4) ``eht_gi`` EHT guard interval (from :c:type:`enum nl80211_eht_gi `) ``eht_ru_alloc`` EHT RU allocation (from :c:type:`enum nl80211_eht_ru_alloc `, only valid if bw is ``RATE_INFO_BW_EHT_RU``)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj( )}(hstruct rate_info { u16 flags; u16 legacy; u8 mcs; u8 nss; u8 bw; u8 he_gi; u8 he_dcm; u8 he_ru_alloc; u8 n_bonded_ch; u8 eht_gi; u8 eht_ru_alloc; };h]hstruct rate_info { u16 flags; u16 legacy; u8 mcs; u8 nss; u8 bw; u8 he_gi; u8 he_dcm; u8 he_ru_alloc; u8 n_bonded_ch; u8 eht_gi; u8 eht_ru_alloc; };}hjŌsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh)}(h **Members**h]j)}(hj֌h]hMembers}(hj،hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjԌubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj)}(hhh](j)}(hQ``flags`` bitflag of flags from :c:type:`enum rate_info_flags ` h](j)}(h ``flags``h]j)}(hjh]hflags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hFbitflag of flags from :c:type:`enum rate_info_flags `h](hbitflag of flags from }(hjhhhNhNubh)}(h0:c:type:`enum rate_info_flags `h]j)}(hjh]henum rate_info_flags}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6rate_info_flagsuh1hhj hMhjubeh}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubj)}(h.``legacy`` bitrate in 100kbit/s for 802.11abg h](j)}(h ``legacy``h]j)}(hjMh]hlegacy}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjGubj6)}(hhh]h)}(h"bitrate in 100kbit/s for 802.11abgh]h"bitrate in 100kbit/s for 802.11abg}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbhMhjcubah}(h]h ]h"]h$]h&]uh1j5hjGubeh}(h]h ]h"]h$]h&]uh1jhjbhMhjubj)}(h@``mcs`` mcs index if struct describes an HT/VHT/HE/EHT/S1G rate h](j)}(h``mcs``h]j)}(hjh]hmcs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h7mcs index if struct describes an HT/VHT/HE/EHT/S1G rateh]h7mcs index if struct describes an HT/VHT/HE/EHT/S1G rate}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h*``nss`` number of streams (VHT & HE only) h](j)}(h``nss``h]j)}(hjh]hnss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h!number of streams (VHT & HE only)h]h!number of streams (VHT & HE only)}(hj؍hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjԍhMhjՍubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjԍhMhjubj)}(hC``bw`` bandwidth (from :c:type:`enum rate_info_bw `) h](j)}(h``bw``h]j)}(hjh]hbw}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h;bandwidth (from :c:type:`enum rate_info_bw `)h](hbandwidth (from }(hjhhhNhNubh)}(h*:c:type:`enum rate_info_bw `h]j)}(hjh]henum rate_info_bw}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6 rate_info_bwuh1hhj hMhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubj)}(hP``he_gi`` HE guard interval (from :c:type:`enum nl80211_he_gi `) h](j)}(h ``he_gi``h]j)}(hjTh]hhe_gi}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjNubj6)}(hhh]h)}(hEHE guard interval (from :c:type:`enum nl80211_he_gi `)h](hHE guard interval (from }(hjmhhhNhNubh)}(h,:c:type:`enum nl80211_he_gi `h]j)}(hjwh]henum nl80211_he_gi}(hjyhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6 nl80211_he_giuh1hhjihMhjmubh)}(hjmhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjihMhjjubah}(h]h ]h"]h$]h&]uh1j5hjNubeh}(h]h ]h"]h$]h&]uh1jhjihMhjubj)}(h``he_dcm`` HE DCM value h](j)}(h ``he_dcm``h]j)}(hjh]hhe_dcm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h HE DCM valueh]h HE DCM value}(hjɎhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjŎhMhjƎubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjŎhMhjubj)}(h``he_ru_alloc`` HE RU allocation (from :c:type:`enum nl80211_he_ru_alloc `, only valid if bw is ``RATE_INFO_BW_HE_RU``) h](j)}(h``he_ru_alloc``h]j)}(hjh]h he_ru_alloc}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h|HE RU allocation (from :c:type:`enum nl80211_he_ru_alloc `, only valid if bw is ``RATE_INFO_BW_HE_RU``)h](hHE RU allocation (from }(hjhhhNhNubh)}(h8:c:type:`enum nl80211_he_ru_alloc `h]j)}(hj h]henum nl80211_he_ru_alloc}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_he_ru_allocuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh, only valid if bw is }(hjhhhNhNubj)}(h``RATE_INFO_BW_HE_RU``h]hRATE_INFO_BW_HE_RU}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj)hMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hD``n_bonded_ch`` In case of EDMG the number of bonded channels (1-4) h](j)}(h``n_bonded_ch``h]j)}(hjXh]h n_bonded_ch}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjRubj6)}(hhh]h)}(h3In case of EDMG the number of bonded channels (1-4)h]h3In case of EDMG the number of bonded channels (1-4)}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmhMhjnubah}(h]h ]h"]h$]h&]uh1j5hjRubeh}(h]h ]h"]h$]h&]uh1jhjmhMhjubj)}(hT``eht_gi`` EHT guard interval (from :c:type:`enum nl80211_eht_gi `) h](j)}(h ``eht_gi``h]j)}(hjh]heht_gi}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hHEHT guard interval (from :c:type:`enum nl80211_eht_gi `)h](hEHT guard interval (from }(hjhhhNhNubh)}(h.:c:type:`enum nl80211_eht_gi `h]j)}(hjh]henum nl80211_eht_gi}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_eht_giuh1hhjhMhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``eht_ru_alloc`` EHT RU allocation (from :c:type:`enum nl80211_eht_ru_alloc `, only valid if bw is ``RATE_INFO_BW_EHT_RU``)h](j)}(h``eht_ru_alloc``h]j)}(hjh]h eht_ru_alloc}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hEHT RU allocation (from :c:type:`enum nl80211_eht_ru_alloc `, only valid if bw is ``RATE_INFO_BW_EHT_RU``)h](hEHT RU allocation (from }(hjhhhNhNubh)}(h::c:type:`enum nl80211_eht_ru_alloc `h]j)}(hjh]henum nl80211_eht_ru_alloc}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_eht_ru_allocuh1hhjhMhjubh, only valid if bw is }(hjhhhNhNubj)}(h``RATE_INFO_BW_EHT_RU``h]hRATE_INFO_BW_EHT_RU}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hjdh]h Description}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubh)}(h5Information about a receiving or transmitting bitrateh]h5Information about a receiving or transmitting bitrate}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_station_info (C struct)c.station_infohNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(h station_infoh]jo)}(hstruct station_infoh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubj)}(h station_infoh]j)}(hjh]h station_info}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMhjhhubj)}(hhh]h)}(hstation informationh]hstation information}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM_hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhj^bhNhNubj)}(hX**Definition**:: struct station_info { u64 filled; u32 connected_time; u32 inactive_time; u64 assoc_at; u64 rx_bytes; u64 tx_bytes; s8 signal; s8 signal_avg; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; s8 chain_signal_avg[IEEE80211_MAX_CHAINS]; struct rate_info txrate; struct rate_info rxrate; u32 rx_packets; u32 tx_packets; u32 tx_retries; u32 tx_failed; u32 rx_dropped_misc; struct sta_bss_parameters bss_param; struct nl80211_sta_flag_update sta_flags; int generation; u32 beacon_loss_count; const u8 *assoc_req_ies; size_t assoc_req_ies_len; s64 t_offset; u16 llid; u16 plid; u8 plink_state; u8 connected_to_gate; u8 connected_to_as; u32 airtime_link_metric; enum nl80211_mesh_power_mode local_pm; enum nl80211_mesh_power_mode peer_pm; enum nl80211_mesh_power_mode nonpeer_pm; u32 expected_throughput; u16 airtime_weight; s8 ack_signal; s8 avg_ack_signal; struct cfg80211_tid_stats *pertid; u64 tx_duration; u64 rx_duration; u64 rx_beacon; u8 rx_beacon_signal_avg; u32 rx_mpdu_count; u32 fcs_err_count; bool mlo_params_valid; u8 assoc_link_id; u8 mld_addr[ETH_ALEN] ; const u8 *assoc_resp_ies; size_t assoc_resp_ies_len; u16 valid_links; struct link_station_info *links[IEEE80211_MLD_MAX_NUM_LINKS]; }; **Members** ``filled`` bitflag of flags using the bits of :c:type:`enum nl80211_sta_info ` to indicate the relevant values in this struct for them ``connected_time`` time(in secs) since a station is last connected ``inactive_time`` time since last station activity (tx/rx) in milliseconds ``assoc_at`` bootime (ns) of the last association ``rx_bytes`` bytes (size of MPDUs) received from this station ``tx_bytes`` bytes (size of MPDUs) transmitted to this station ``signal`` The signal strength, type depends on the wiphy's signal_type. For CFG80211_SIGNAL_TYPE_MBM, value is expressed in _dBm_. ``signal_avg`` Average signal strength, type depends on the wiphy's signal_type. For CFG80211_SIGNAL_TYPE_MBM, value is expressed in _dBm_. ``chains`` bitmask for filled values in **chain_signal**, **chain_signal_avg** ``chain_signal`` per-chain signal strength of last received packet in dBm ``chain_signal_avg`` per-chain signal strength average in dBm ``txrate`` current unicast bitrate from this station ``rxrate`` current unicast bitrate to this station ``rx_packets`` packets (MSDUs & MMPDUs) received from this station ``tx_packets`` packets (MSDUs & MMPDUs) transmitted to this station ``tx_retries`` cumulative retry counts (MPDUs) ``tx_failed`` number of failed transmissions (MPDUs) (retries exceeded, no ACK) ``rx_dropped_misc`` Dropped for un-specified reason. ``bss_param`` current BSS parameters ``sta_flags`` station flags mask & values ``generation`` generation number for nl80211 dumps. This number should increase every time the list of stations changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot. ``beacon_loss_count`` Number of times beacon loss event has triggered. ``assoc_req_ies`` IEs from (Re)Association Request. This is used only when in AP mode with drivers that do not use user space MLME/SME implementation. The information is provided for the cfg80211_new_sta() calls to notify user space of the IEs. ``assoc_req_ies_len`` Length of assoc_req_ies buffer in octets. ``t_offset`` Time offset of the station relative to this host. ``llid`` mesh local link id ``plid`` mesh peer link id ``plink_state`` mesh peer link state ``connected_to_gate`` true if mesh STA has a path to mesh gate ``connected_to_as`` true if mesh STA has a path to authentication server ``airtime_link_metric`` mesh airtime link metric. ``local_pm`` local mesh STA power save mode ``peer_pm`` peer mesh STA power save mode ``nonpeer_pm`` non-peer mesh STA power save mode ``expected_throughput`` expected throughput in kbps (including 802.11 headers) towards this station. ``airtime_weight`` current airtime scheduling weight ``ack_signal`` signal strength (in dBm) of the last ACK frame. ``avg_ack_signal`` average rssi value of ack packet for the no of msdu's has been sent. ``pertid`` per-TID statistics, see :c:type:`struct cfg80211_tid_stats `, using the last (IEEE80211_NUM_TIDS) index for MSDUs not encapsulated in QoS-MPDUs. Note that this doesn't use the **filled** bit, but is used if non-NULL. ``tx_duration`` aggregate PPDU duration(usecs) for all the frames to a peer ``rx_duration`` aggregate PPDU duration(usecs) for all the frames from a peer ``rx_beacon`` number of beacons received from this peer ``rx_beacon_signal_avg`` signal strength average (in dBm) for beacons received from this peer ``rx_mpdu_count`` number of MPDUs received from this station ``fcs_err_count`` number of packets (MPDUs) received from this station with an FCS error. This counter should be incremented only when TA of the received packet with an FCS error matches the peer MAC address. ``mlo_params_valid`` Indicates **assoc_link_id** and **mld_addr** fields are filled by driver. Drivers use this only in cfg80211_new_sta() calls when AP MLD's MLME/SME is offload to driver. Drivers won't fill this information in cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks. ``assoc_link_id`` Indicates MLO link ID of the AP, with which the station completed (re)association. This information filled for both MLO and non-MLO STA connections when the AP affiliated with an MLD. ``mld_addr`` For MLO STA connection, filled with MLD address of the station. For non-MLO STA connection, filled with all zeros. ``assoc_resp_ies`` IEs from (Re)Association Response. This is used only when in AP mode with drivers that do not use user space MLME/SME implementation. The information is provided only for the cfg80211_new_sta() calls to notify user space of the IEs. Drivers won't fill this information in cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks. User space needs this information to determine the accepted and rejected affiliated links of the connected station. ``assoc_resp_ies_len`` Length of **assoc_resp_ies** buffer in octets. ``valid_links`` bitmap of valid links, or 0 for non-MLO. Drivers fill this information in cfg80211_new_sta(), cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks. ``links`` reference to Link sta entries for MLO STA, all link specific information is accessed through links[link_id].h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMchjubj( )}(hX}struct station_info { u64 filled; u32 connected_time; u32 inactive_time; u64 assoc_at; u64 rx_bytes; u64 tx_bytes; s8 signal; s8 signal_avg; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; s8 chain_signal_avg[IEEE80211_MAX_CHAINS]; struct rate_info txrate; struct rate_info rxrate; u32 rx_packets; u32 tx_packets; u32 tx_retries; u32 tx_failed; u32 rx_dropped_misc; struct sta_bss_parameters bss_param; struct nl80211_sta_flag_update sta_flags; int generation; u32 beacon_loss_count; const u8 *assoc_req_ies; size_t assoc_req_ies_len; s64 t_offset; u16 llid; u16 plid; u8 plink_state; u8 connected_to_gate; u8 connected_to_as; u32 airtime_link_metric; enum nl80211_mesh_power_mode local_pm; enum nl80211_mesh_power_mode peer_pm; enum nl80211_mesh_power_mode nonpeer_pm; u32 expected_throughput; u16 airtime_weight; s8 ack_signal; s8 avg_ack_signal; struct cfg80211_tid_stats *pertid; u64 tx_duration; u64 rx_duration; u64 rx_beacon; u8 rx_beacon_signal_avg; u32 rx_mpdu_count; u32 fcs_err_count; bool mlo_params_valid; u8 assoc_link_id; u8 mld_addr[ETH_ALEN] ; const u8 *assoc_resp_ies; size_t assoc_resp_ies_len; u16 valid_links; struct link_station_info *links[IEEE80211_MLD_MAX_NUM_LINKS]; };h]hX}struct station_info { u64 filled; u32 connected_time; u32 inactive_time; u64 assoc_at; u64 rx_bytes; u64 tx_bytes; s8 signal; s8 signal_avg; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; s8 chain_signal_avg[IEEE80211_MAX_CHAINS]; struct rate_info txrate; struct rate_info rxrate; u32 rx_packets; u32 tx_packets; u32 tx_retries; u32 tx_failed; u32 rx_dropped_misc; struct sta_bss_parameters bss_param; struct nl80211_sta_flag_update sta_flags; int generation; u32 beacon_loss_count; const u8 *assoc_req_ies; size_t assoc_req_ies_len; s64 t_offset; u16 llid; u16 plid; u8 plink_state; u8 connected_to_gate; u8 connected_to_as; u32 airtime_link_metric; enum nl80211_mesh_power_mode local_pm; enum nl80211_mesh_power_mode peer_pm; enum nl80211_mesh_power_mode nonpeer_pm; u32 expected_throughput; u16 airtime_weight; s8 ack_signal; s8 avg_ack_signal; struct cfg80211_tid_stats *pertid; u64 tx_duration; u64 rx_duration; u64 rx_beacon; u8 rx_beacon_signal_avg; u32 rx_mpdu_count; u32 fcs_err_count; bool mlo_params_valid; u8 assoc_link_id; u8 mld_addr[ETH_ALEN] ; const u8 *assoc_resp_ies; size_t assoc_resp_ies_len; u16 valid_links; struct link_station_info *links[IEEE80211_MLD_MAX_NUM_LINKS]; };}hj!sbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMehjubh)}(h **Members**h]j)}(hj2h]hMembers}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj)}(hhh](j)}(h``filled`` bitflag of flags using the bits of :c:type:`enum nl80211_sta_info ` to indicate the relevant values in this struct for them h](j)}(h ``filled``h]j)}(hjQh]hfilled}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMehjKubj6)}(hhh]h)}(hbitflag of flags using the bits of :c:type:`enum nl80211_sta_info ` to indicate the relevant values in this struct for themh](h#bitflag of flags using the bits of }(hjjhhhNhNubh)}(h2:c:type:`enum nl80211_sta_info `h]j)}(hjth]henum nl80211_sta_info}(hjvhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_sta_infouh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMdhjjubh8 to indicate the relevant values in this struct for them}(hjjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMdhjgubah}(h]h ]h"]h$]h&]uh1j5hjKubeh}(h]h ]h"]h$]h&]uh1jhjfhMehjHubj)}(hC``connected_time`` time(in secs) since a station is last connected h](j)}(h``connected_time``h]j)}(hjh]hconnected_time}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMfhjubj6)}(hhh]h)}(h/time(in secs) since a station is last connectedh]h/time(in secs) since a station is last connected}(hjǑhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjÑhMfhjđubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjÑhMfhjHubj)}(hK``inactive_time`` time since last station activity (tx/rx) in milliseconds h](j)}(h``inactive_time``h]j)}(hjh]h inactive_time}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMghjubj6)}(hhh]h)}(h8time since last station activity (tx/rx) in millisecondsh]h8time since last station activity (tx/rx) in milliseconds}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMghjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMghjHubj)}(h2``assoc_at`` bootime (ns) of the last association h](j)}(h ``assoc_at``h]j)}(hj h]hassoc_at}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhhjubj6)}(hhh]h)}(h$bootime (ns) of the last associationh]h$bootime (ns) of the last association}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5hMhhj6ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj5hMhhjHubj)}(h>``rx_bytes`` bytes (size of MPDUs) received from this station h](j)}(h ``rx_bytes``h]j)}(hjYh]hrx_bytes}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMihjSubj6)}(hhh]h)}(h0bytes (size of MPDUs) received from this stationh]h0bytes (size of MPDUs) received from this station}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhMihjoubah}(h]h ]h"]h$]h&]uh1j5hjSubeh}(h]h ]h"]h$]h&]uh1jhjnhMihjHubj)}(h?``tx_bytes`` bytes (size of MPDUs) transmitted to this station h](j)}(h ``tx_bytes``h]j)}(hjh]htx_bytes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMjhjubj6)}(hhh]h)}(h1bytes (size of MPDUs) transmitted to this stationh]h1bytes (size of MPDUs) transmitted to this station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMjhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMjhjHubj)}(h``signal`` The signal strength, type depends on the wiphy's signal_type. For CFG80211_SIGNAL_TYPE_MBM, value is expressed in _dBm_. h](j)}(h ``signal``h]j)}(hj˒h]hsignal}(hj͒hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjɒubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMlhjŒubj6)}(hhh]h)}(hxThe signal strength, type depends on the wiphy's signal_type. For CFG80211_SIGNAL_TYPE_MBM, value is expressed in _dBm_.h]hzThe signal strength, type depends on the wiphy’s signal_type. For CFG80211_SIGNAL_TYPE_MBM, value is expressed in _dBm_.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMkhjubah}(h]h ]h"]h$]h&]uh1j5hjŒubeh}(h]h ]h"]h$]h&]uh1jhjhMlhjHubj)}(h``signal_avg`` Average signal strength, type depends on the wiphy's signal_type. For CFG80211_SIGNAL_TYPE_MBM, value is expressed in _dBm_. h](j)}(h``signal_avg``h]j)}(hjh]h signal_avg}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMnhjubj6)}(hhh]h)}(h|Average signal strength, type depends on the wiphy's signal_type. For CFG80211_SIGNAL_TYPE_MBM, value is expressed in _dBm_.h]h~Average signal strength, type depends on the wiphy’s signal_type. For CFG80211_SIGNAL_TYPE_MBM, value is expressed in _dBm_.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMmhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMnhjHubj)}(hO``chains`` bitmask for filled values in **chain_signal**, **chain_signal_avg** h](j)}(h ``chains``h]j)}(hj?h]hchains}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMohj9ubj6)}(hhh]h)}(hCbitmask for filled values in **chain_signal**, **chain_signal_avg**h](hbitmask for filled values in }(hjXhhhNhNubj)}(h**chain_signal**h]h chain_signal}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXubh, }(hjXhhhNhNubj)}(h**chain_signal_avg**h]hchain_signal_avg}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXubeh}(h]h ]h"]h$]h&]uh1hhjThMohjUubah}(h]h ]h"]h$]h&]uh1j5hj9ubeh}(h]h ]h"]h$]h&]uh1jhjThMohjHubj)}(hJ``chain_signal`` per-chain signal strength of last received packet in dBm h](j)}(h``chain_signal``h]j)}(hjh]h chain_signal}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMphjubj6)}(hhh]h)}(h8per-chain signal strength of last received packet in dBmh]h8per-chain signal strength of last received packet in dBm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMphjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMphjHubj)}(h>``chain_signal_avg`` per-chain signal strength average in dBm h](j)}(h``chain_signal_avg``h]j)}(hjѓh]hchain_signal_avg}(hjӓhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjϓubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMqhj˓ubj6)}(hhh]h)}(h(per-chain signal strength average in dBmh]h(per-chain signal strength average in dBm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMqhjubah}(h]h ]h"]h$]h&]uh1j5hj˓ubeh}(h]h ]h"]h$]h&]uh1jhjhMqhjHubj)}(h5``txrate`` current unicast bitrate from this station h](j)}(h ``txrate``h]j)}(hj h]htxrate}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMrhjubj6)}(hhh]h)}(h)current unicast bitrate from this stationh]h)current unicast bitrate from this station}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMrhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMrhjHubj)}(h3``rxrate`` current unicast bitrate to this station h](j)}(h ``rxrate``h]j)}(hjCh]hrxrate}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMshj=ubj6)}(hhh]h)}(h'current unicast bitrate to this stationh]h'current unicast bitrate to this station}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhMshjYubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhjXhMshjHubj)}(hC``rx_packets`` packets (MSDUs & MMPDUs) received from this station h](j)}(h``rx_packets``h]j)}(hj|h]h rx_packets}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMthjvubj6)}(hhh]h)}(h3packets (MSDUs & MMPDUs) received from this stationh]h3packets (MSDUs & MMPDUs) received from this station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMthjubah}(h]h ]h"]h$]h&]uh1j5hjvubeh}(h]h ]h"]h$]h&]uh1jhjhMthjHubj)}(hD``tx_packets`` packets (MSDUs & MMPDUs) transmitted to this station h](j)}(h``tx_packets``h]j)}(hjh]h tx_packets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMuhjubj6)}(hhh]h)}(h4packets (MSDUs & MMPDUs) transmitted to this stationh]h4packets (MSDUs & MMPDUs) transmitted to this station}(hjΔhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjʔhMuhj˔ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjʔhMuhjHubj)}(h/``tx_retries`` cumulative retry counts (MPDUs) h](j)}(h``tx_retries``h]j)}(hjh]h tx_retries}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMvhjubj6)}(hhh]h)}(hcumulative retry counts (MPDUs)h]hcumulative retry counts (MPDUs)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMvhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMvhjHubj)}(hP``tx_failed`` number of failed transmissions (MPDUs) (retries exceeded, no ACK) h](j)}(h ``tx_failed``h]j)}(hj'h]h tx_failed}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMwhj!ubj6)}(hhh]h)}(hAnumber of failed transmissions (MPDUs) (retries exceeded, no ACK)h]hAnumber of failed transmissions (MPDUs) (retries exceeded, no ACK)}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hMwhj=ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj<hMwhjHubj)}(h5``rx_dropped_misc`` Dropped for un-specified reason. h](j)}(h``rx_dropped_misc``h]j)}(hj`h]hrx_dropped_misc}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMxhjZubj6)}(hhh]h)}(h Dropped for un-specified reason.h]h Dropped for un-specified reason.}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuhMxhjvubah}(h]h ]h"]h$]h&]uh1j5hjZubeh}(h]h ]h"]h$]h&]uh1jhjuhMxhjHubj)}(h%``bss_param`` current BSS parameters h](j)}(h ``bss_param``h]j)}(hjh]h bss_param}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMyhjubj6)}(hhh]h)}(hcurrent BSS parametersh]hcurrent BSS parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMyhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMyhjHubj)}(h*``sta_flags`` station flags mask & values h](j)}(h ``sta_flags``h]j)}(hjҕh]h sta_flags}(hjԕhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjЕubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj̕ubj6)}(hhh]h)}(hstation flags mask & valuesh]hstation flags mask & values}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hj̕ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjHubj)}(h``generation`` generation number for nl80211 dumps. This number should increase every time the list of stations changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot. h](j)}(h``generation``h]j)}(hj h]h generation}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM}hjubj6)}(hhh]h)}(hgeneration number for nl80211 dumps. This number should increase every time the list of stations changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.h]hgeneration number for nl80211 dumps. This number should increase every time the list of stations changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMzhj!ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hM}hjHubj)}(hG``beacon_loss_count`` Number of times beacon loss event has triggered. h](j)}(h``beacon_loss_count``h]j)}(hjEh]hbeacon_loss_count}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM~hj?ubj6)}(hhh]h)}(h0Number of times beacon loss event has triggered.h]h0Number of times beacon loss event has triggered.}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhM~hj[ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhjZhM~hjHubj)}(h``assoc_req_ies`` IEs from (Re)Association Request. This is used only when in AP mode with drivers that do not use user space MLME/SME implementation. The information is provided for the cfg80211_new_sta() calls to notify user space of the IEs. h](j)}(h``assoc_req_ies``h]j)}(hj~h]h assoc_req_ies}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjxubj6)}(hhh]h)}(hIEs from (Re)Association Request. This is used only when in AP mode with drivers that do not use user space MLME/SME implementation. The information is provided for the cfg80211_new_sta() calls to notify user space of the IEs.h]hIEs from (Re)Association Request. This is used only when in AP mode with drivers that do not use user space MLME/SME implementation. The information is provided for the cfg80211_new_sta() calls to notify user space of the IEs.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjxubeh}(h]h ]h"]h$]h&]uh1jhjhMhjHubj)}(h@``assoc_req_ies_len`` Length of assoc_req_ies buffer in octets. h](j)}(h``assoc_req_ies_len``h]j)}(hjh]hassoc_req_ies_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h)Length of assoc_req_ies buffer in octets.h]h)Length of assoc_req_ies buffer in octets.}(hjіhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj͖hMhjΖubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj͖hMhjHubj)}(h?``t_offset`` Time offset of the station relative to this host. h](j)}(h ``t_offset``h]j)}(hjh]ht_offset}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h1Time offset of the station relative to this host.h]h1Time offset of the station relative to this host.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjHubj)}(h``llid`` mesh local link id h](j)}(h``llid``h]j)}(hj*h]hllid}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$ubj6)}(hhh]h)}(hmesh local link idh]hmesh local link id}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hMhj@ubah}(h]h ]h"]h$]h&]uh1j5hj$ubeh}(h]h ]h"]h$]h&]uh1jhj?hMhjHubj)}(h``plid`` mesh peer link id h](j)}(h``plid``h]j)}(hjch]hplid}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj]ubj6)}(hhh]h)}(hmesh peer link idh]hmesh peer link id}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxhMhjyubah}(h]h ]h"]h$]h&]uh1j5hj]ubeh}(h]h ]h"]h$]h&]uh1jhjxhMhjHubj)}(h%``plink_state`` mesh peer link state h](j)}(h``plink_state``h]j)}(hjh]h plink_state}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hmesh peer link stateh]hmesh peer link state}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjHubj)}(h?``connected_to_gate`` true if mesh STA has a path to mesh gate h](j)}(h``connected_to_gate``h]j)}(hj՗h]hconnected_to_gate}(hjחhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjӗubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjϗubj6)}(hhh]h)}(h(true if mesh STA has a path to mesh gateh]h(true if mesh STA has a path to mesh gate}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjϗubeh}(h]h ]h"]h$]h&]uh1jhjhMhjHubj)}(hI``connected_to_as`` true if mesh STA has a path to authentication server h](j)}(h``connected_to_as``h]j)}(hjh]hconnected_to_as}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h4true if mesh STA has a path to authentication serverh]h4true if mesh STA has a path to authentication server}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#hMhj$ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj#hMhjHubj)}(h2``airtime_link_metric`` mesh airtime link metric. h](j)}(h``airtime_link_metric``h]j)}(hjGh]hairtime_link_metric}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjAubj6)}(hhh]h)}(hmesh airtime link metric.h]hmesh airtime link metric.}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\hMhj]ubah}(h]h ]h"]h$]h&]uh1j5hjAubeh}(h]h ]h"]h$]h&]uh1jhj\hMhjHubj)}(h,``local_pm`` local mesh STA power save mode h](j)}(h ``local_pm``h]j)}(hjh]hlocal_pm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjzubj6)}(hhh]h)}(hlocal mesh STA power save modeh]hlocal mesh STA power save mode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhjhMhjHubj)}(h*``peer_pm`` peer mesh STA power save mode h](j)}(h ``peer_pm``h]j)}(hjh]hpeer_pm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hpeer mesh STA power save modeh]hpeer mesh STA power save mode}(hjҘhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjΘhMhjϘubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjΘhMhjHubj)}(h1``nonpeer_pm`` non-peer mesh STA power save mode h](j)}(h``nonpeer_pm``h]j)}(hjh]h nonpeer_pm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h!non-peer mesh STA power save modeh]h!non-peer mesh STA power save mode}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjHubj)}(he``expected_throughput`` expected throughput in kbps (including 802.11 headers) towards this station. h](j)}(h``expected_throughput``h]j)}(hj+h]hexpected_throughput}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj%ubj6)}(hhh]h)}(hLexpected throughput in kbps (including 802.11 headers) towards this station.h]hLexpected throughput in kbps (including 802.11 headers) towards this station.}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjAubah}(h]h ]h"]h$]h&]uh1j5hj%ubeh}(h]h ]h"]h$]h&]uh1jhj@hMhjHubj)}(h5``airtime_weight`` current airtime scheduling weight h](j)}(h``airtime_weight``h]j)}(hjeh]hairtime_weight}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj_ubj6)}(hhh]h)}(h!current airtime scheduling weighth]h!current airtime scheduling weight}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzhMhj{ubah}(h]h ]h"]h$]h&]uh1j5hj_ubeh}(h]h ]h"]h$]h&]uh1jhjzhMhjHubj)}(h?``ack_signal`` signal strength (in dBm) of the last ACK frame. h](j)}(h``ack_signal``h]j)}(hjh]h ack_signal}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h/signal strength (in dBm) of the last ACK frame.h]h/signal strength (in dBm) of the last ACK frame.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjHubj)}(hX``avg_ack_signal`` average rssi value of ack packet for the no of msdu's has been sent. h](j)}(h``avg_ack_signal``h]j)}(hjיh]havg_ack_signal}(hjٙhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjՙubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjљubj6)}(hhh]h)}(hDaverage rssi value of ack packet for the no of msdu's has been sent.h]hFaverage rssi value of ack packet for the no of msdu’s has been sent.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjљubeh}(h]h ]h"]h$]h&]uh1jhjhMhjHubj)}(h``pertid`` per-TID statistics, see :c:type:`struct cfg80211_tid_stats `, using the last (IEEE80211_NUM_TIDS) index for MSDUs not encapsulated in QoS-MPDUs. Note that this doesn't use the **filled** bit, but is used if non-NULL. h](j)}(h ``pertid``h]j)}(hjh]hpertid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj ubj6)}(hhh]h)}(hper-TID statistics, see :c:type:`struct cfg80211_tid_stats `, using the last (IEEE80211_NUM_TIDS) index for MSDUs not encapsulated in QoS-MPDUs. Note that this doesn't use the **filled** bit, but is used if non-NULL.h](hper-TID statistics, see }(hj*hhhNhNubh)}(h8:c:type:`struct cfg80211_tid_stats `h]j)}(hj4h]hstruct cfg80211_tid_stats}(hj6hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6cfg80211_tid_statsuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj*ubhv, using the last (IEEE80211_NUM_TIDS) index for MSDUs not encapsulated in QoS-MPDUs. Note that this doesn’t use the }(hj*hhhNhNubj)}(h **filled**h]hfilled}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*ubh bit, but is used if non-NULL.}(hj*hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjQhMhj'ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj&hMhjHubj)}(hL``tx_duration`` aggregate PPDU duration(usecs) for all the frames to a peer h](j)}(h``tx_duration``h]j)}(hjh]h tx_duration}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjzubj6)}(hhh]h)}(h;aggregate PPDU duration(usecs) for all the frames to a peerh]h;aggregate PPDU duration(usecs) for all the frames to a peer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhjhMhjHubj)}(hN``rx_duration`` aggregate PPDU duration(usecs) for all the frames from a peer h](j)}(h``rx_duration``h]j)}(hjh]h rx_duration}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h=aggregate PPDU duration(usecs) for all the frames from a peerh]h=aggregate PPDU duration(usecs) for all the frames from a peer}(hjҚhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjΚhMhjϚubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjΚhMhjHubj)}(h8``rx_beacon`` number of beacons received from this peer h](j)}(h ``rx_beacon``h]j)}(hjh]h rx_beacon}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h)number of beacons received from this peerh]h)number of beacons received from this peer}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjHubj)}(h^``rx_beacon_signal_avg`` signal strength average (in dBm) for beacons received from this peer h](j)}(h``rx_beacon_signal_avg``h]j)}(hj+h]hrx_beacon_signal_avg}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj%ubj6)}(hhh]h)}(hDsignal strength average (in dBm) for beacons received from this peerh]hDsignal strength average (in dBm) for beacons received from this peer}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjAubah}(h]h ]h"]h$]h&]uh1j5hj%ubeh}(h]h ]h"]h$]h&]uh1jhj@hMhjHubj)}(h=``rx_mpdu_count`` number of MPDUs received from this station h](j)}(h``rx_mpdu_count``h]j)}(hjeh]h rx_mpdu_count}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj_ubj6)}(hhh]h)}(h*number of MPDUs received from this stationh]h*number of MPDUs received from this station}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzhMhj{ubah}(h]h ]h"]h$]h&]uh1j5hj_ubeh}(h]h ]h"]h$]h&]uh1jhjzhMhjHubj)}(h``fcs_err_count`` number of packets (MPDUs) received from this station with an FCS error. This counter should be incremented only when TA of the received packet with an FCS error matches the peer MAC address. h](j)}(h``fcs_err_count``h]j)}(hjh]h fcs_err_count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hnumber of packets (MPDUs) received from this station with an FCS error. This counter should be incremented only when TA of the received packet with an FCS error matches the peer MAC address.h]hnumber of packets (MPDUs) received from this station with an FCS error. This counter should be incremented only when TA of the received packet with an FCS error matches the peer MAC address.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjHubj)}(hX+``mlo_params_valid`` Indicates **assoc_link_id** and **mld_addr** fields are filled by driver. Drivers use this only in cfg80211_new_sta() calls when AP MLD's MLME/SME is offload to driver. Drivers won't fill this information in cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks. h](j)}(h``mlo_params_valid``h]j)}(hj؛h]hmlo_params_valid}(hjڛhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj֛ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjқubj6)}(hhh]h)}(hXIndicates **assoc_link_id** and **mld_addr** fields are filled by driver. Drivers use this only in cfg80211_new_sta() calls when AP MLD's MLME/SME is offload to driver. Drivers won't fill this information in cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks.h](h Indicates }(hjhhhNhNubj)}(h**assoc_link_id**h]h assoc_link_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh and }(hjhhhNhNubj)}(h **mld_addr**h]hmld_addr}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh fields are filled by driver. Drivers use this only in cfg80211_new_sta() calls when AP MLD’s MLME/SME is offload to driver. Drivers won’t fill this information in cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjқubeh}(h]h ]h"]h$]h&]uh1jhjhMhjHubj)}(h``assoc_link_id`` Indicates MLO link ID of the AP, with which the station completed (re)association. This information filled for both MLO and non-MLO STA connections when the AP affiliated with an MLD. h](j)}(h``assoc_link_id``h]j)}(hj6h]h assoc_link_id}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj0ubj6)}(hhh]h)}(hIndicates MLO link ID of the AP, with which the station completed (re)association. This information filled for both MLO and non-MLO STA connections when the AP affiliated with an MLD.h]hIndicates MLO link ID of the AP, with which the station completed (re)association. This information filled for both MLO and non-MLO STA connections when the AP affiliated with an MLD.}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjLubah}(h]h ]h"]h$]h&]uh1j5hj0ubeh}(h]h ]h"]h$]h&]uh1jhjKhMhjHubj)}(h``mld_addr`` For MLO STA connection, filled with MLD address of the station. For non-MLO STA connection, filled with all zeros. h](j)}(h ``mld_addr``h]j)}(hjph]hmld_addr}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubj6)}(hhh]h)}(hrFor MLO STA connection, filled with MLD address of the station. For non-MLO STA connection, filled with all zeros.h]hrFor MLO STA connection, filled with MLD address of the station. For non-MLO STA connection, filled with all zeros.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjHubj)}(hX``assoc_resp_ies`` IEs from (Re)Association Response. This is used only when in AP mode with drivers that do not use user space MLME/SME implementation. The information is provided only for the cfg80211_new_sta() calls to notify user space of the IEs. Drivers won't fill this information in cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks. User space needs this information to determine the accepted and rejected affiliated links of the connected station. h](j)}(h``assoc_resp_ies``h]j)}(hjh]hassoc_resp_ies}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hXIEs from (Re)Association Response. This is used only when in AP mode with drivers that do not use user space MLME/SME implementation. The information is provided only for the cfg80211_new_sta() calls to notify user space of the IEs. Drivers won't fill this information in cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks. User space needs this information to determine the accepted and rejected affiliated links of the connected station.h]hXIEs from (Re)Association Response. This is used only when in AP mode with drivers that do not use user space MLME/SME implementation. The information is provided only for the cfg80211_new_sta() calls to notify user space of the IEs. Drivers won’t fill this information in cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks. User space needs this information to determine the accepted and rejected affiliated links of the connected station.}(hjÜhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjHubj)}(hF``assoc_resp_ies_len`` Length of **assoc_resp_ies** buffer in octets. h](j)}(h``assoc_resp_ies_len``h]j)}(hjh]hassoc_resp_ies_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjޜubj6)}(hhh]h)}(h.Length of **assoc_resp_ies** buffer in octets.h](h Length of }(hjhhhNhNubj)}(h**assoc_resp_ies**h]hassoc_resp_ies}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh buffer in octets.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjޜubeh}(h]h ]h"]h$]h&]uh1jhjhMhjHubj)}(h``valid_links`` bitmap of valid links, or 0 for non-MLO. Drivers fill this information in cfg80211_new_sta(), cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks. h](j)}(h``valid_links``h]j)}(hj/h]h valid_links}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj)ubj6)}(hhh]h)}(hbitmap of valid links, or 0 for non-MLO. Drivers fill this information in cfg80211_new_sta(), cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks.h]hbitmap of valid links, or 0 for non-MLO. Drivers fill this information in cfg80211_new_sta(), cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks.}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjEubah}(h]h ]h"]h$]h&]uh1j5hj)ubeh}(h]h ]h"]h$]h&]uh1jhjDhMhjHubj)}(hv``links`` reference to Link sta entries for MLO STA, all link specific information is accessed through links[link_id].h](j)}(h ``links``h]j)}(hjih]hlinks}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcubj6)}(hhh]h)}(hlreference to Link sta entries for MLO STA, all link specific information is accessed through links[link_id].h]hlreference to Link sta entries for MLO STA, all link specific information is accessed through links[link_id].}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~hMhjubah}(h]h ]h"]h$]h&]uh1j5hjcubeh}(h]h ]h"]h$]h&]uh1jhj~hMhjHubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubh)}(hHStation information filled by driver for get_station() and dump_station.h]hHStation information filled by driver for get_station() and dump_station.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM`hj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_monitor_flags (C enum)c.monitor_flagshNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(h monitor_flagsh]jo)}(henum monitor_flagsh](ju)}(hjxh]henum}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMeubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMeubj)}(h monitor_flagsh]j)}(hjh]h monitor_flags}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMeubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMeubah}(h]jܝah ](jjeh"]h$]h&]jj)jhuh1jhhjhMehjޝhhubj)}(hhh]h)}(h monitor flagsh]h monitor flags}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMC hj(hhubah}(h]h ]h"]h$]h&]uh1jhjޝhhhjhMeubeh}(h]h ](j$enumeh"]h$]h&]jj$jjCjjCjjjuh1jchhhj^bhNhNubj)}(hX**Constants** ``MONITOR_FLAG_CHANGED`` set if the flags were changed ``MONITOR_FLAG_FCSFAIL`` pass frames with bad FCS ``MONITOR_FLAG_PLCPFAIL`` pass frames with bad PLCP ``MONITOR_FLAG_CONTROL`` pass control frames ``MONITOR_FLAG_OTHER_BSS`` disable BSSID filtering ``MONITOR_FLAG_COOK_FRAMES`` deprecated, will unconditionally be refused ``MONITOR_FLAG_ACTIVE`` active monitor, ACKs frames on its MAC address ``MONITOR_FLAG_SKIP_TX`` do not pass locally transmitted framesh](h)}(h **Constants**h]j)}(hjMh]h Constants}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMG hjGubj)}(hhh](j)}(h7``MONITOR_FLAG_CHANGED`` set if the flags were changed h](j)}(h``MONITOR_FLAG_CHANGED``h]j)}(hjlh]hMONITOR_FLAG_CHANGED}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMJ hjfubj6)}(hhh]h)}(hset if the flags were changedh]hset if the flags were changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMJ hjubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhjhMJ hjcubj)}(h2``MONITOR_FLAG_FCSFAIL`` pass frames with bad FCS h](j)}(h``MONITOR_FLAG_FCSFAIL``h]j)}(hjh]hMONITOR_FLAG_FCSFAIL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMM hjubj6)}(hhh]h)}(hpass frames with bad FCSh]hpass frames with bad FCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMM hjcubj)}(h4``MONITOR_FLAG_PLCPFAIL`` pass frames with bad PLCP h](j)}(h``MONITOR_FLAG_PLCPFAIL``h]j)}(hjޞh]hMONITOR_FLAG_PLCPFAIL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjܞubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMP hj؞ubj6)}(hhh]h)}(hpass frames with bad PLCPh]hpass frames with bad PLCP}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMP hjubah}(h]h ]h"]h$]h&]uh1j5hj؞ubeh}(h]h ]h"]h$]h&]uh1jhjhMP hjcubj)}(h-``MONITOR_FLAG_CONTROL`` pass control frames h](j)}(h``MONITOR_FLAG_CONTROL``h]j)}(hjh]hMONITOR_FLAG_CONTROL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMS hjubj6)}(hhh]h)}(hpass control framesh]hpass control frames}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,hMS hj-ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj,hMS hjcubj)}(h3``MONITOR_FLAG_OTHER_BSS`` disable BSSID filtering h](j)}(h``MONITOR_FLAG_OTHER_BSS``h]j)}(hjPh]hMONITOR_FLAG_OTHER_BSS}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMV hjJubj6)}(hhh]h)}(hdisable BSSID filteringh]hdisable BSSID filtering}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehMV hjfubah}(h]h ]h"]h$]h&]uh1j5hjJubeh}(h]h ]h"]h$]h&]uh1jhjehMV hjcubj)}(hI``MONITOR_FLAG_COOK_FRAMES`` deprecated, will unconditionally be refused h](j)}(h``MONITOR_FLAG_COOK_FRAMES``h]j)}(hjh]hMONITOR_FLAG_COOK_FRAMES}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMY hjubj6)}(hhh]h)}(h+deprecated, will unconditionally be refusedh]h+deprecated, will unconditionally be refused}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMY hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMY hjcubj)}(hG``MONITOR_FLAG_ACTIVE`` active monitor, ACKs frames on its MAC address h](j)}(h``MONITOR_FLAG_ACTIVE``h]j)}(hjŸh]hMONITOR_FLAG_ACTIVE}(hjğhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM\ hjubj6)}(hhh]h)}(h.active monitor, ACKs frames on its MAC addressh]h.active monitor, ACKs frames on its MAC address}(hj۟hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjןhM\ hj؟ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjןhM\ hjcubj)}(h?``MONITOR_FLAG_SKIP_TX`` do not pass locally transmitted framesh](j)}(h``MONITOR_FLAG_SKIP_TX``h]j)}(hjh]hMONITOR_FLAG_SKIP_TX}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM^ hjubj6)}(hhh]h)}(h&do not pass locally transmitted framesh]h&do not pass locally transmitted frames}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM_ hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM^ hjcubeh}(h]h ]h"]h$]h&]uh1jhjGubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hj>h]h Description}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMa hj^bhhubh)}(hgMonitor interface configuration flags. Note that these must be the bits according to the nl80211 flags.h]hgMonitor interface configuration flags. Note that these must be the bits according to the nl80211 flags.}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMD hj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_mpath_info_flags (C enum)c.mpath_info_flagshNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hmpath_info_flagsh]jo)}(henum mpath_info_flagsh](ju)}(hjxh]henum}(hj|hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjxhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMJ ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxhhhjhMJ ubj)}(hmpath_info_flagsh]j)}(hjvh]hmpath_info_flags}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjxhhhjhMJ ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjthhhjhMJ ubah}(h]joah ](jjeh"]h$]h&]jj)jhuh1jhhjhMJ hjqhhubj)}(hhh]h)}(hmesh path information flagsh]hmesh path information flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM] hjhhubah}(h]h ]h"]h$]h&]uh1jhjqhhhjhMJ ubeh}(h]h ](j$enumeh"]h$]h&]jj$jj֠jj֠jjjuh1jchhhj^bhNhNubj)}(hX**Constants** ``MPATH_INFO_FRAME_QLEN`` **frame_qlen** filled ``MPATH_INFO_SN`` **sn** filled ``MPATH_INFO_METRIC`` **metric** filled ``MPATH_INFO_EXPTIME`` **exptime** filled ``MPATH_INFO_DISCOVERY_TIMEOUT`` **discovery_timeout** filled ``MPATH_INFO_DISCOVERY_RETRIES`` **discovery_retries** filled ``MPATH_INFO_FLAGS`` **flags** filled ``MPATH_INFO_HOP_COUNT`` **hop_count** filled ``MPATH_INFO_PATH_CHANGE`` **path_change_count** filledh](h)}(h **Constants**h]j)}(hjh]h Constants}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjޠubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMa hjڠubj)}(hhh](j)}(h0``MPATH_INFO_FRAME_QLEN`` **frame_qlen** filled h](j)}(h``MPATH_INFO_FRAME_QLEN``h]j)}(hjh]hMPATH_INFO_FRAME_QLEN}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMd hjubj6)}(hhh]h)}(h**frame_qlen** filledh](j)}(h**frame_qlen**h]h frame_qlen}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh filled}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMd hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMd hjubj)}(h ``MPATH_INFO_SN`` **sn** filled h](j)}(h``MPATH_INFO_SN``h]j)}(hjFh]h MPATH_INFO_SN}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMg hj@ubj6)}(hhh]h)}(h **sn** filledh](j)}(h**sn**h]hsn}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_ubh filled}(hj_hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj[hMg hj\ubah}(h]h ]h"]h$]h&]uh1j5hj@ubeh}(h]h ]h"]h$]h&]uh1jhj[hMg hjubj)}(h(``MPATH_INFO_METRIC`` **metric** filled h](j)}(h``MPATH_INFO_METRIC``h]j)}(hjh]hMPATH_INFO_METRIC}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMj hjubj6)}(hhh]h)}(h**metric** filledh](j)}(h **metric**h]hmetric}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh filled}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMj hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMj hjubj)}(h*``MPATH_INFO_EXPTIME`` **exptime** filled h](j)}(h``MPATH_INFO_EXPTIME``h]j)}(hjԡh]hMPATH_INFO_EXPTIME}(hj֡hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjҡubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMm hjΡubj6)}(hhh]h)}(h**exptime** filledh](j)}(h **exptime**h]hexptime}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh filled}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMm hjubah}(h]h ]h"]h$]h&]uh1j5hjΡubeh}(h]h ]h"]h$]h&]uh1jhjhMm hjubj)}(h>``MPATH_INFO_DISCOVERY_TIMEOUT`` **discovery_timeout** filled h](j)}(h ``MPATH_INFO_DISCOVERY_TIMEOUT``h]j)}(hjh]hMPATH_INFO_DISCOVERY_TIMEOUT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMp hjubj6)}(hhh]h)}(h**discovery_timeout** filledh](j)}(h**discovery_timeout**h]hdiscovery_timeout}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4ubh filled}(hj4hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj0hMp hj1ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj0hMp hjubj)}(h>``MPATH_INFO_DISCOVERY_RETRIES`` **discovery_retries** filled h](j)}(h ``MPATH_INFO_DISCOVERY_RETRIES``h]j)}(hjbh]hMPATH_INFO_DISCOVERY_RETRIES}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMs hj\ubj6)}(hhh]h)}(h**discovery_retries** filledh](j)}(h**discovery_retries**h]hdiscovery_retries}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{ubh filled}(hj{hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjwhMs hjxubah}(h]h ]h"]h$]h&]uh1j5hj\ubeh}(h]h ]h"]h$]h&]uh1jhjwhMs hjubj)}(h&``MPATH_INFO_FLAGS`` **flags** filled h](j)}(h``MPATH_INFO_FLAGS``h]j)}(hjh]hMPATH_INFO_FLAGS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMv hjubj6)}(hhh]h)}(h**flags** filledh](j)}(h **flags**h]hflags}(hjƢhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj¢ubh filled}(hj¢hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMv hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMv hjubj)}(h.``MPATH_INFO_HOP_COUNT`` **hop_count** filled h](j)}(h``MPATH_INFO_HOP_COUNT``h]j)}(hjh]hMPATH_INFO_HOP_COUNT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMy hjubj6)}(hhh]h)}(h**hop_count** filledh](j)}(h **hop_count**h]h hop_count}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubh filled}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMy hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMy hjubj)}(h7``MPATH_INFO_PATH_CHANGE`` **path_change_count** filledh](j)}(h``MPATH_INFO_PATH_CHANGE``h]j)}(hj7h]hMPATH_INFO_PATH_CHANGE}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM{ hj1ubj6)}(hhh]h)}(h**path_change_count** filledh](j)}(h**path_change_count**h]hpath_change_count}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPubh filled}(hjPhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM| hjMubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhjLhM{ hjubeh}(h]h ]h"]h$]h&]uh1jhjڠubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM~ hj^bhhubh)}(hUsed by the driver to indicate which info in :c:type:`struct mpath_info ` it has filled in during get_station() or dump_station().h](h-Used by the driver to indicate which info in }(hjhhhNhNubh)}(h(:c:type:`struct mpath_info `h]j)}(hjh]hstruct mpath_info}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6 mpath_infouh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM^ hjubh9 it has filled in during get_station() or dump_station().}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjţhM^ hj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_mpath_info (C struct) c.mpath_infohNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(h mpath_infoh]jo)}(hstruct mpath_infoh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMd ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMd ubj)}(h mpath_infoh]j)}(hjh]h mpath_info}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMd ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMd ubah}(h]jܣah ](jjeh"]h$]h&]jj)jhuh1jhhjhMd hjޣhhubj)}(hhh]h)}(hmesh path informationh]hmesh path information}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMy hj(hhubah}(h]h ]h"]h$]h&]uh1jhjޣhhhjhMd ubeh}(h]h ](j$structeh"]h$]h&]jj$jjCjjCjjjuh1jchhhj^bhNhNubj)}(hXs**Definition**:: struct mpath_info { u32 filled; u32 frame_qlen; u32 sn; u32 metric; u32 exptime; u32 discovery_timeout; u8 discovery_retries; u8 flags; u8 hop_count; u32 path_change_count; int generation; }; **Members** ``filled`` bitfield of flags from :c:type:`enum mpath_info_flags ` ``frame_qlen`` number of queued frames for this destination ``sn`` target sequence number ``metric`` metric (cost) of this mesh path ``exptime`` expiration time for the mesh path from now, in msecs ``discovery_timeout`` total mesh path discovery timeout, in msecs ``discovery_retries`` mesh path discovery retries ``flags`` mesh path flags from :c:type:`enum mesh_path_flags ` ``hop_count`` hops to destination ``path_change_count`` total number of path changes to destination ``generation`` generation number for nl80211 dumps. This number should increase every time the list of mesh paths changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKubh:}(hjKhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM} hjGubj( )}(hstruct mpath_info { u32 filled; u32 frame_qlen; u32 sn; u32 metric; u32 exptime; u32 discovery_timeout; u8 discovery_retries; u8 flags; u8 hop_count; u32 path_change_count; int generation; };h]hstruct mpath_info { u32 filled; u32 frame_qlen; u32 sn; u32 metric; u32 exptime; u32 discovery_timeout; u8 discovery_retries; u8 flags; u8 hop_count; u32 path_change_count; int generation; };}hjhsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjGubh)}(h **Members**h]j)}(hjyh]hMembers}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjGubj)}(hhh](j)}(hU``filled`` bitfield of flags from :c:type:`enum mpath_info_flags ` h](j)}(h ``filled``h]j)}(hjh]hfilled}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM~ hjubj6)}(hhh]h)}(hIbitfield of flags from :c:type:`enum mpath_info_flags `h](hbitfield of flags from }(hjhhhNhNubh)}(h2:c:type:`enum mpath_info_flags `h]j)}(hjh]henum mpath_info_flags}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6mpath_info_flagsuh1hhjhM~ hjubeh}(h]h ]h"]h$]h&]uh1hhjhM~ hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM~ hjubj)}(h<``frame_qlen`` number of queued frames for this destination h](j)}(h``frame_qlen``h]j)}(hjh]h frame_qlen}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h,number of queued frames for this destinationh]h,number of queued frames for this destination}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h``sn`` target sequence number h](j)}(h``sn``h]j)}(hj)h]hsn}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj#ubj6)}(hhh]h)}(htarget sequence numberh]htarget sequence number}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hM hj?ubah}(h]h ]h"]h$]h&]uh1j5hj#ubeh}(h]h ]h"]h$]h&]uh1jhj>hM hjubj)}(h+``metric`` metric (cost) of this mesh path h](j)}(h ``metric``h]j)}(hjbh]hmetric}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj\ubj6)}(hhh]h)}(hmetric (cost) of this mesh pathh]hmetric (cost) of this mesh path}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwhM hjxubah}(h]h ]h"]h$]h&]uh1j5hj\ubeh}(h]h ]h"]h$]h&]uh1jhjwhM hjubj)}(hA``exptime`` expiration time for the mesh path from now, in msecs h](j)}(h ``exptime``h]j)}(hjh]hexptime}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h4expiration time for the mesh path from now, in msecsh]h4expiration time for the mesh path from now, in msecs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hB``discovery_timeout`` total mesh path discovery timeout, in msecs h](j)}(h``discovery_timeout``h]j)}(hjԥh]hdiscovery_timeout}(hj֥hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjҥubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjΥubj6)}(hhh]h)}(h+total mesh path discovery timeout, in msecsh]h+total mesh path discovery timeout, in msecs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjΥubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h2``discovery_retries`` mesh path discovery retries h](j)}(h``discovery_retries``h]j)}(hj h]hdiscovery_retries}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hmesh path discovery retriesh]hmesh path discovery retries}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hM hj#ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj"hM hjubj)}(hP``flags`` mesh path flags from :c:type:`enum mesh_path_flags ` h](j)}(h ``flags``h]j)}(hjFh]hflags}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj@ubj6)}(hhh]h)}(hEmesh path flags from :c:type:`enum mesh_path_flags `h](hmesh path flags from }(hj_hhhNhNubh)}(h0:c:type:`enum mesh_path_flags `h]j)}(hjih]henum mesh_path_flags}(hjkhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6mesh_path_flagsuh1hhj[hM hj_ubeh}(h]h ]h"]h$]h&]uh1hhj[hM hj\ubah}(h]h ]h"]h$]h&]uh1j5hj@ubeh}(h]h ]h"]h$]h&]uh1jhj[hM hjubj)}(h"``hop_count`` hops to destination h](j)}(h ``hop_count``h]j)}(hjh]h hop_count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hhops to destinationh]hhops to destination}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hB``path_change_count`` total number of path changes to destination h](j)}(h``path_change_count``h]j)}(hjצh]hpath_change_count}(hj٦hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjզubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjѦubj6)}(hhh]h)}(h+total number of path changes to destinationh]h+total number of path changes to destination}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjѦubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h``generation`` generation number for nl80211 dumps. This number should increase every time the list of mesh paths changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.h](j)}(h``generation``h]j)}(hjh]h generation}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj ubj6)}(hhh]h)}(hgeneration number for nl80211 dumps. This number should increase every time the list of mesh paths changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.h]hgeneration number for nl80211 dumps. This number should increase every time the list of mesh paths changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj&ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj%hM hjubeh}(h]h ]h"]h$]h&]uh1jhjGubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hjSh]h Description}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^bhhubh)}(hHMesh path information filled by driver for get_mpath() and dump_mpath().h]hHMesh path information filled by driver for get_mpath() and dump_mpath().}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMz hj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_bss_parameters (C struct)c.bss_parametershNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hbss_parametersh]jo)}(hstruct bss_parametersh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(hbss_parametersh]j)}(hjh]hbss_parameters}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM hjhhubj)}(hhh]h)}(hBSS parametersh]hBSS parameters}(hjӧhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjЧhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhj^bhNhNubj)}(hX)**Definition**:: struct bss_parameters { int link_id; int use_cts_prot; int use_short_preamble; int use_short_slot_time; const u8 *basic_rates; u8 basic_rates_len; int ap_isolate; int ht_opmode; s8 p2p_ctwindow, p2p_opp_ps; }; **Members** ``link_id`` link_id or -1 for non-MLD ``use_cts_prot`` Whether to use CTS protection (0 = no, 1 = yes, -1 = do not change) ``use_short_preamble`` Whether the use of short preambles is allowed (0 = no, 1 = yes, -1 = do not change) ``use_short_slot_time`` Whether the use of short slot time is allowed (0 = no, 1 = yes, -1 = do not change) ``basic_rates`` basic rates in IEEE 802.11 format (or NULL for no change) ``basic_rates_len`` number of basic rates ``ap_isolate`` do not forward packets between connected stations (0 = no, 1 = yes, -1 = do not change) ``ht_opmode`` HT Operation mode (u16 = opmode, -1 = do not change) ``p2p_ctwindow`` P2P CT Window (-1 = no change) ``p2p_opp_ps`` P2P opportunistic PS (-1 = no change)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj( )}(hstruct bss_parameters { int link_id; int use_cts_prot; int use_short_preamble; int use_short_slot_time; const u8 *basic_rates; u8 basic_rates_len; int ap_isolate; int ht_opmode; s8 p2p_ctwindow, p2p_opp_ps; };h]hstruct bss_parameters { int link_id; int use_cts_prot; int use_short_preamble; int use_short_slot_time; const u8 *basic_rates; u8 basic_rates_len; int ap_isolate; int ht_opmode; s8 p2p_ctwindow, p2p_opp_ps; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubh)}(h **Members**h]j)}(hj!h]hMembers}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj)}(hhh](j)}(h&``link_id`` link_id or -1 for non-MLD h](j)}(h ``link_id``h]j)}(hj@h]hlink_id}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj:ubj6)}(hhh]h)}(hlink_id or -1 for non-MLDh]hlink_id or -1 for non-MLD}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUhM hjVubah}(h]h ]h"]h$]h&]uh1j5hj:ubeh}(h]h ]h"]h$]h&]uh1jhjUhM hj7ubj)}(hU``use_cts_prot`` Whether to use CTS protection (0 = no, 1 = yes, -1 = do not change) h](j)}(h``use_cts_prot``h]j)}(hjyh]h use_cts_prot}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjsubj6)}(hhh]h)}(hCWhether to use CTS protection (0 = no, 1 = yes, -1 = do not change)h]hCWhether to use CTS protection (0 = no, 1 = yes, -1 = do not change)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjsubeh}(h]h ]h"]h$]h&]uh1jhjhM hj7ubj)}(hk``use_short_preamble`` Whether the use of short preambles is allowed (0 = no, 1 = yes, -1 = do not change) h](j)}(h``use_short_preamble``h]j)}(hjh]huse_short_preamble}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hSWhether the use of short preambles is allowed (0 = no, 1 = yes, -1 = do not change)h]hSWhether the use of short preambles is allowed (0 = no, 1 = yes, -1 = do not change)}(hj̨hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjɨubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjȨhM hj7ubj)}(hl``use_short_slot_time`` Whether the use of short slot time is allowed (0 = no, 1 = yes, -1 = do not change) h](j)}(h``use_short_slot_time``h]j)}(hjh]huse_short_slot_time}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hSWhether the use of short slot time is allowed (0 = no, 1 = yes, -1 = do not change)h]hSWhether the use of short slot time is allowed (0 = no, 1 = yes, -1 = do not change)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj7ubj)}(hJ``basic_rates`` basic rates in IEEE 802.11 format (or NULL for no change) h](j)}(h``basic_rates``h]j)}(hj'h]h basic_rates}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj!ubj6)}(hhh]h)}(h9basic rates in IEEE 802.11 format (or NULL for no change)h]h9basic rates in IEEE 802.11 format (or NULL for no change)}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj=ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj<hM hj7ubj)}(h*``basic_rates_len`` number of basic rates h](j)}(h``basic_rates_len``h]j)}(hjah]hbasic_rates_len}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj[ubj6)}(hhh]h)}(hnumber of basic ratesh]hnumber of basic rates}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvhM hjwubah}(h]h ]h"]h$]h&]uh1j5hj[ubeh}(h]h ]h"]h$]h&]uh1jhjvhM hj7ubj)}(hg``ap_isolate`` do not forward packets between connected stations (0 = no, 1 = yes, -1 = do not change) h](j)}(h``ap_isolate``h]j)}(hjh]h ap_isolate}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hWdo not forward packets between connected stations (0 = no, 1 = yes, -1 = do not change)h]hWdo not forward packets between connected stations (0 = no, 1 = yes, -1 = do not change)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj7ubj)}(hC``ht_opmode`` HT Operation mode (u16 = opmode, -1 = do not change) h](j)}(h ``ht_opmode``h]j)}(hjԩh]h ht_opmode}(hj֩hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjҩubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjΩubj6)}(hhh]h)}(h4HT Operation mode (u16 = opmode, -1 = do not change)h]h4HT Operation mode (u16 = opmode, -1 = do not change)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjΩubeh}(h]h ]h"]h$]h&]uh1jhjhM hj7ubj)}(h0``p2p_ctwindow`` P2P CT Window (-1 = no change) h](j)}(h``p2p_ctwindow``h]j)}(hjh]h p2p_ctwindow}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hP2P CT Window (-1 = no change)h]hP2P CT Window (-1 = no change)}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#hM hj$ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj#hM hj7ubj)}(h4``p2p_opp_ps`` P2P opportunistic PS (-1 = no change)h](j)}(h``p2p_opp_ps``h]j)}(hjGh]h p2p_opp_ps}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjAubj6)}(hhh]h)}(h%P2P opportunistic PS (-1 = no change)h]h%P2P opportunistic PS (-1 = no change)}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj]ubah}(h]h ]h"]h$]h&]uh1j5hjAubeh}(h]h ]h"]h$]h&]uh1jhj\hM hj7ubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^bhhubh)}(h3Used to change BSS parameters (mainly for AP mode).h]h3Used to change BSS parameters (mainly for AP mode).}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ieee80211_txq_params (C struct)c.ieee80211_txq_paramshNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hieee80211_txq_paramsh]jo)}(hstruct ieee80211_txq_paramsh](ju)}(hjh]hstruct}(hjȪhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjĪhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hj֪hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjĪhhhjժhM ubj)}(hieee80211_txq_paramsh]j)}(hjªh]hieee80211_txq_params}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjĪhhhjժhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjժhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjժhM hjhhubj)}(hhh]h)}(hTX queue parametersh]hTX queue parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMm hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjժhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jj"jj"jjjuh1jchhhj^bhNhNubj)}(hX"**Definition**:: struct ieee80211_txq_params { enum nl80211_ac ac; u16 txop; u16 cwmin; u16 cwmax; u8 aifs; int link_id; }; **Members** ``ac`` AC identifier ``txop`` Maximum burst time in units of 32 usecs, 0 meaning disabled ``cwmin`` Minimum contention window [a value of the form 2^n-1 in the range 1..32767] ``cwmax`` Maximum contention window [a value of the form 2^n-1 in the range 1..32767] ``aifs`` Arbitration interframe space [0..255] ``link_id`` link_id or -1 for non-MLDh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*ubh:}(hj*hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMq hj&ubj( )}(hstruct ieee80211_txq_params { enum nl80211_ac ac; u16 txop; u16 cwmin; u16 cwmax; u8 aifs; int link_id; };h]hstruct ieee80211_txq_params { enum nl80211_ac ac; u16 txop; u16 cwmin; u16 cwmax; u8 aifs; int link_id; };}hjGsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMs hj&ubh)}(h **Members**h]j)}(hjXh]hMembers}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM| hj&ubj)}(hhh](j)}(h``ac`` AC identifier h](j)}(h``ac``h]j)}(hjwh]hac}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMo hjqubj6)}(hhh]h)}(h AC identifierh]h AC identifier}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMo hjubah}(h]h ]h"]h$]h&]uh1j5hjqubeh}(h]h ]h"]h$]h&]uh1jhjhMo hjnubj)}(hE``txop`` Maximum burst time in units of 32 usecs, 0 meaning disabled h](j)}(h``txop``h]j)}(hjh]htxop}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMp hjubj6)}(hhh]h)}(h;Maximum burst time in units of 32 usecs, 0 meaning disabledh]h;Maximum burst time in units of 32 usecs, 0 meaning disabled}(hjɫhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjūhMp hjƫubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjūhMp hjnubj)}(hV``cwmin`` Minimum contention window [a value of the form 2^n-1 in the range 1..32767] h](j)}(h ``cwmin``h]j)}(hjh]hcwmin}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMr hjubj6)}(hhh]h)}(hKMinimum contention window [a value of the form 2^n-1 in the range 1..32767]h]hKMinimum contention window [a value of the form 2^n-1 in the range 1..32767]}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMq hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMr hjnubj)}(hV``cwmax`` Maximum contention window [a value of the form 2^n-1 in the range 1..32767] h](j)}(h ``cwmax``h]j)}(hj#h]hcwmax}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMt hjubj6)}(hhh]h)}(hKMaximum contention window [a value of the form 2^n-1 in the range 1..32767]h]hKMaximum contention window [a value of the form 2^n-1 in the range 1..32767]}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMs hj9ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj8hMt hjnubj)}(h/``aifs`` Arbitration interframe space [0..255] h](j)}(h``aifs``h]j)}(hj]h]haifs}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMu hjWubj6)}(hhh]h)}(h%Arbitration interframe space [0..255]h]h%Arbitration interframe space [0..255]}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjrhMu hjsubah}(h]h ]h"]h$]h&]uh1j5hjWubeh}(h]h ]h"]h$]h&]uh1jhjrhMu hjnubj)}(h%``link_id`` link_id or -1 for non-MLDh](j)}(h ``link_id``h]j)}(hjh]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMu hjubj6)}(hhh]h)}(hlink_id or -1 for non-MLDh]hlink_id or -1 for non-MLD}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMv hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMu hjnubeh}(h]h ]h"]h$]h&]uh1jhj&ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ cfg80211_auth_request (C struct)c.cfg80211_auth_requesthNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hcfg80211_auth_requesth]jo)}(hstruct cfg80211_auth_requesth](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM| ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM| ubj)}(hcfg80211_auth_requesth]j)}(hjh]hcfg80211_auth_request}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM| ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM| ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM| hjhhubj)}(hhh]h)}(hAuthentication request datah]hAuthentication request data}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM= hj/hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM| ubeh}(h]h ](j$structeh"]h$]h&]jj$jjJjjJjjjuh1jchhhj^bhNhNubj)}(hX**Definition**:: struct cfg80211_auth_request { struct cfg80211_bss *bss; const u8 *ie; size_t ie_len; const u8 *supported_selectors; u8 supported_selectors_len; enum nl80211_auth_type auth_type; const u8 *key; u8 key_len; s8 key_idx; const u8 *auth_data; size_t auth_data_len; s8 link_id; const u8 *ap_mld_addr; }; **Members** ``bss`` The BSS to authenticate with, the callee must obtain a reference to it if it needs to keep it. ``ie`` Extra IEs to add to Authentication frame or ``NULL`` ``ie_len`` Length of ie buffer in octets ``supported_selectors`` List of selectors that should be assumed to be supported by the station. SAE_H2E must be assumed supported if set to ``NULL``. ``supported_selectors_len`` Length of supported_selectors in octets. ``auth_type`` Authentication type (algorithm) ``key`` WEP key for shared key authentication ``key_len`` length of WEP key for shared key authentication ``key_idx`` index of WEP key for shared key authentication ``auth_data`` Fields and elements in Authentication frames. This contains the authentication frame body (non-IE and IE data), excluding the Authentication algorithm number, i.e., starting at the Authentication transaction sequence number field. ``auth_data_len`` Length of auth_data buffer in octets ``link_id`` if >= 0, indicates authentication should be done as an MLD, the interface address is included as the MLD address and the necessary link (with the given link_id) will be created (and given an MLD address) by the driver ``ap_mld_addr`` AP MLD address in case of authentication request with an AP MLD, valid iff **link_id** >= 0h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRubh:}(hjRhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMA hjNubj( )}(hX^struct cfg80211_auth_request { struct cfg80211_bss *bss; const u8 *ie; size_t ie_len; const u8 *supported_selectors; u8 supported_selectors_len; enum nl80211_auth_type auth_type; const u8 *key; u8 key_len; s8 key_idx; const u8 *auth_data; size_t auth_data_len; s8 link_id; const u8 *ap_mld_addr; };h]hX^struct cfg80211_auth_request { struct cfg80211_bss *bss; const u8 *ie; size_t ie_len; const u8 *supported_selectors; u8 supported_selectors_len; enum nl80211_auth_type auth_type; const u8 *key; u8 key_len; s8 key_idx; const u8 *auth_data; size_t auth_data_len; s8 link_id; const u8 *ap_mld_addr; };}hjosbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMC hjNubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMS hjNubj)}(hhh](j)}(hg``bss`` The BSS to authenticate with, the callee must obtain a reference to it if it needs to keep it. h](j)}(h``bss``h]j)}(hjh]hbss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMD hjubj6)}(hhh]h)}(h^The BSS to authenticate with, the callee must obtain a reference to it if it needs to keep it.h]h^The BSS to authenticate with, the callee must obtain a reference to it if it needs to keep it.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMC hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMD hjubj)}(h<``ie`` Extra IEs to add to Authentication frame or ``NULL`` h](j)}(h``ie``h]j)}(hj٭h]hie}(hjۭhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj׭ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMJ hjӭubj6)}(hhh]h)}(h4Extra IEs to add to Authentication frame or ``NULL``h](h,Extra IEs to add to Authentication frame or }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1hhjhMJ hjubah}(h]h ]h"]h$]h&]uh1j5hjӭubeh}(h]h ]h"]h$]h&]uh1jhjhMJ hjubj)}(h)``ie_len`` Length of ie buffer in octets h](j)}(h ``ie_len``h]j)}(hj h]hie_len}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMK hjubj6)}(hhh]h)}(hLength of ie buffer in octetsh]hLength of ie buffer in octets}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5hMK hj6ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj5hMK hjubj)}(h``supported_selectors`` List of selectors that should be assumed to be supported by the station. SAE_H2E must be assumed supported if set to ``NULL``. h](j)}(h``supported_selectors``h]j)}(hjYh]hsupported_selectors}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMG hjSubj6)}(hhh]h)}(h~List of selectors that should be assumed to be supported by the station. SAE_H2E must be assumed supported if set to ``NULL``.h](huList of selectors that should be assumed to be supported by the station. SAE_H2E must be assumed supported if set to }(hjrhhhNhNubj)}(h``NULL``h]hNULL}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubh.}(hjrhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhME hjoubah}(h]h ]h"]h$]h&]uh1j5hjSubeh}(h]h ]h"]h$]h&]uh1jhjnhMG hjubj)}(hE``supported_selectors_len`` Length of supported_selectors in octets. h](j)}(h``supported_selectors_len``h]j)}(hjh]hsupported_selectors_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMH hjubj6)}(hhh]h)}(h(Length of supported_selectors in octets.h]h(Length of supported_selectors in octets.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMH hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMH hjubj)}(h.``auth_type`` Authentication type (algorithm) h](j)}(h ``auth_type``h]j)}(hjޮh]h auth_type}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjܮubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMI hjخubj6)}(hhh]h)}(hAuthentication type (algorithm)h]hAuthentication type (algorithm)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMI hjubah}(h]h ]h"]h$]h&]uh1j5hjخubeh}(h]h ]h"]h$]h&]uh1jhjhMI hjubj)}(h.``key`` WEP key for shared key authentication h](j)}(h``key``h]j)}(hjh]hkey}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMN hjubj6)}(hhh]h)}(h%WEP key for shared key authenticationh]h%WEP key for shared key authentication}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,hMN hj-ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj,hMN hjubj)}(h<``key_len`` length of WEP key for shared key authentication h](j)}(h ``key_len``h]j)}(hjPh]hkey_len}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhML hjJubj6)}(hhh]h)}(h/length of WEP key for shared key authenticationh]h/length of WEP key for shared key authentication}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehML hjfubah}(h]h ]h"]h$]h&]uh1j5hjJubeh}(h]h ]h"]h$]h&]uh1jhjehML hjubj)}(h;``key_idx`` index of WEP key for shared key authentication h](j)}(h ``key_idx``h]j)}(hjh]hkey_idx}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMM hjubj6)}(hhh]h)}(h.index of WEP key for shared key authenticationh]h.index of WEP key for shared key authentication}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMM hjubj)}(h``auth_data`` Fields and elements in Authentication frames. This contains the authentication frame body (non-IE and IE data), excluding the Authentication algorithm number, i.e., starting at the Authentication transaction sequence number field. h](j)}(h ``auth_data``h]j)}(hj¯h]h auth_data}(hjįhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMR hjubj6)}(hhh]h)}(hFields and elements in Authentication frames. This contains the authentication frame body (non-IE and IE data), excluding the Authentication algorithm number, i.e., starting at the Authentication transaction sequence number field.h]hFields and elements in Authentication frames. This contains the authentication frame body (non-IE and IE data), excluding the Authentication algorithm number, i.e., starting at the Authentication transaction sequence number field.}(hjۯhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMO hjدubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjׯhMR hjubj)}(h7``auth_data_len`` Length of auth_data buffer in octets h](j)}(h``auth_data_len``h]j)}(hjh]h auth_data_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMS hjubj6)}(hhh]h)}(h$Length of auth_data buffer in octetsh]h$Length of auth_data buffer in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMS hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMS hjubj)}(h``link_id`` if >= 0, indicates authentication should be done as an MLD, the interface address is included as the MLD address and the necessary link (with the given link_id) will be created (and given an MLD address) by the driver h](j)}(h ``link_id``h]j)}(hj5h]hlink_id}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMW hj/ubj6)}(hhh]h)}(hif >= 0, indicates authentication should be done as an MLD, the interface address is included as the MLD address and the necessary link (with the given link_id) will be created (and given an MLD address) by the driverh]hif >= 0, indicates authentication should be done as an MLD, the interface address is included as the MLD address and the necessary link (with the given link_id) will be created (and given an MLD address) by the driver}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMT hjKubah}(h]h ]h"]h$]h&]uh1j5hj/ubeh}(h]h ]h"]h$]h&]uh1jhjJhMW hjubj)}(hk``ap_mld_addr`` AP MLD address in case of authentication request with an AP MLD, valid iff **link_id** >= 0h](j)}(h``ap_mld_addr``h]j)}(hjoh]h ap_mld_addr}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMX hjiubj6)}(hhh]h)}(h[AP MLD address in case of authentication request with an AP MLD, valid iff **link_id** >= 0h](hKAP MLD address in case of authentication request with an AP MLD, valid iff }(hjhhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh >= 0}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMX hjubah}(h]h ]h"]h$]h&]uh1j5hjiubeh}(h]h ]h"]h$]h&]uh1jhjhMX hjubeh}(h]h ]h"]h$]h&]uh1jhjNubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hjðh]h Description}(hjŰhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM\ hj^bhhubh)}(hRThis structure provides information needed to complete IEEE 802.11 authentication.h]hRThis structure provides information needed to complete IEEE 802.11 authentication.}(hjٰhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM> hj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_!cfg80211_assoc_request (C struct)c.cfg80211_assoc_requesthNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hcfg80211_assoc_requesth]jo)}(hstruct cfg80211_assoc_requesth](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMD ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMD ubj)}(hcfg80211_assoc_requesth]j)}(hjh]hcfg80211_assoc_request}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMD ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMD ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMD hjhhubj)}(hhh]h)}(h(Re)Association request datah]h(Re)Association request data}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj@hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMD ubeh}(h]h ](j$structeh"]h$]h&]jj$jj[jj[jjjuh1jchhhj^bhNhNubj)}(hX **Definition**:: struct cfg80211_assoc_request { struct cfg80211_bss *bss; const u8 *ie, *prev_bssid; size_t ie_len; struct cfg80211_crypto_settings crypto; bool use_mfp; u32 flags; const u8 *supported_selectors; u8 supported_selectors_len; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct ieee80211_vht_cap vht_capa, vht_capa_mask; const u8 *fils_kek; size_t fils_kek_len; const u8 *fils_nonces; struct ieee80211_s1g_cap s1g_capa, s1g_capa_mask; struct cfg80211_assoc_link links[IEEE80211_MLD_MAX_NUM_LINKS]; const u8 *ap_mld_addr; s8 link_id; u16 ext_mld_capa_ops; }; **Members** ``bss`` The BSS to associate with. If the call is successful the driver is given a reference that it must give back to cfg80211_send_rx_assoc() or to cfg80211_assoc_timeout(). To ensure proper refcounting, new association requests while already associating must be rejected. This also applies to the **links.bss** parameter, which is used instead of this one (it is ``NULL``) for MLO associations. ``ie`` Extra IEs to add to (Re)Association Request frame or ``NULL`` ``prev_bssid`` previous BSSID, if not ``NULL`` use reassociate frame. This is used to indicate a request to reassociate within the ESS instead of a request do the initial association with the ESS. When included, this is set to the BSSID of the current association, i.e., to the value that is included in the Current AP address field of the Reassociation Request frame. ``ie_len`` Length of ie buffer in octets ``crypto`` crypto settings ``use_mfp`` Use management frame protection (IEEE 802.11w) in this association ``flags`` See :c:type:`enum cfg80211_assoc_req_flags ` ``supported_selectors`` supported BSS selectors in IEEE 802.11 format (or ``NULL`` for no change). If ``NULL``, then support for SAE_H2E should be assumed. ``supported_selectors_len`` number of supported BSS selectors ``ht_capa`` HT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored. ``ht_capa_mask`` The bits of ht_capa which are to be used. ``vht_capa`` VHT capability override ``vht_capa_mask`` VHT capability mask indicating which fields to use ``fils_kek`` FILS KEK for protecting (Re)Association Request/Response frame or ``NULL`` if FILS is not used. ``fils_kek_len`` Length of fils_kek in octets ``fils_nonces`` FILS nonces (part of AAD) for protecting (Re)Association Request/Response frame or ``NULL`` if FILS is not used. This field starts with 16 octets of STA Nonce followed by 16 octets of AP Nonce. ``s1g_capa`` S1G capability override ``s1g_capa_mask`` S1G capability override mask ``links`` per-link information for MLO connections ``ap_mld_addr`` AP MLD address in case of MLO association request, valid iff **link_id** >= 0 ``link_id`` >= 0 for MLO connections, where links are given, and indicates the link on which the association request should be sent ``ext_mld_capa_ops`` extended MLD capabilities and operations set by userspace for the associationh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjcubh:}(hjchhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj_ubj( )}(hXstruct cfg80211_assoc_request { struct cfg80211_bss *bss; const u8 *ie, *prev_bssid; size_t ie_len; struct cfg80211_crypto_settings crypto; bool use_mfp; u32 flags; const u8 *supported_selectors; u8 supported_selectors_len; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct ieee80211_vht_cap vht_capa, vht_capa_mask; const u8 *fils_kek; size_t fils_kek_len; const u8 *fils_nonces; struct ieee80211_s1g_cap s1g_capa, s1g_capa_mask; struct cfg80211_assoc_link links[IEEE80211_MLD_MAX_NUM_LINKS]; const u8 *ap_mld_addr; s8 link_id; u16 ext_mld_capa_ops; };h]hXstruct cfg80211_assoc_request { struct cfg80211_bss *bss; const u8 *ie, *prev_bssid; size_t ie_len; struct cfg80211_crypto_settings crypto; bool use_mfp; u32 flags; const u8 *supported_selectors; u8 supported_selectors_len; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct ieee80211_vht_cap vht_capa, vht_capa_mask; const u8 *fils_kek; size_t fils_kek_len; const u8 *fils_nonces; struct ieee80211_s1g_cap s1g_capa, s1g_capa_mask; struct cfg80211_assoc_link links[IEEE80211_MLD_MAX_NUM_LINKS]; const u8 *ap_mld_addr; s8 link_id; u16 ext_mld_capa_ops; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj_ubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj_ubj)}(hhh](j)}(hX``bss`` The BSS to associate with. If the call is successful the driver is given a reference that it must give back to cfg80211_send_rx_assoc() or to cfg80211_assoc_timeout(). To ensure proper refcounting, new association requests while already associating must be rejected. This also applies to the **links.bss** parameter, which is used instead of this one (it is ``NULL``) for MLO associations. h](j)}(h``bss``h]j)}(hjh]hbss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hXThe BSS to associate with. If the call is successful the driver is given a reference that it must give back to cfg80211_send_rx_assoc() or to cfg80211_assoc_timeout(). To ensure proper refcounting, new association requests while already associating must be rejected. This also applies to the **links.bss** parameter, which is used instead of this one (it is ``NULL``) for MLO associations.h](hX$The BSS to associate with. If the call is successful the driver is given a reference that it must give back to cfg80211_send_rx_assoc() or to cfg80211_assoc_timeout(). To ensure proper refcounting, new association requests while already associating must be rejected. This also applies to the }(hjɱhhhNhNubj)}(h **links.bss**h]h links.bss}(hjѱhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjɱubh5 parameter, which is used instead of this one (it is }(hjɱhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjɱubh) for MLO associations.}(hjɱhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjƱubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjűhM hjubj)}(hE``ie`` Extra IEs to add to (Re)Association Request frame or ``NULL`` h](j)}(h``ie``h]j)}(hjh]hie}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h=Extra IEs to add to (Re)Association Request frame or ``NULL``h](h5Extra IEs to add to (Re)Association Request frame or }(hj'hhhNhNubj)}(h``NULL``h]hNULL}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubeh}(h]h ]h"]h$]h&]uh1hhj#hM hj$ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj#hM hjubj)}(hXq``prev_bssid`` previous BSSID, if not ``NULL`` use reassociate frame. This is used to indicate a request to reassociate within the ESS instead of a request do the initial association with the ESS. When included, this is set to the BSSID of the current association, i.e., to the value that is included in the Current AP address field of the Reassociation Request frame. h](j)}(h``prev_bssid``h]j)}(hjUh]h prev_bssid}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjOubj6)}(hhh]h)}(hXaprevious BSSID, if not ``NULL`` use reassociate frame. This is used to indicate a request to reassociate within the ESS instead of a request do the initial association with the ESS. When included, this is set to the BSSID of the current association, i.e., to the value that is included in the Current AP address field of the Reassociation Request frame.h](hprevious BSSID, if not }(hjnhhhNhNubj)}(h``NULL``h]hNULL}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubhXB use reassociate frame. This is used to indicate a request to reassociate within the ESS instead of a request do the initial association with the ESS. When included, this is set to the BSSID of the current association, i.e., to the value that is included in the Current AP address field of the Reassociation Request frame.}(hjnhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjkubah}(h]h ]h"]h$]h&]uh1j5hjOubeh}(h]h ]h"]h$]h&]uh1jhjjhM hjubj)}(h)``ie_len`` Length of ie buffer in octets h](j)}(h ``ie_len``h]j)}(hjh]hie_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hLength of ie buffer in octetsh]hLength of ie buffer in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h``crypto`` crypto settings h](j)}(h ``crypto``h]j)}(hjڲh]hcrypto}(hjܲhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjزubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjԲubj6)}(hhh]h)}(hcrypto settingsh]hcrypto settings}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjԲubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hO``use_mfp`` Use management frame protection (IEEE 802.11w) in this association h](j)}(h ``use_mfp``h]j)}(hjh]huse_mfp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj ubj6)}(hhh]h)}(hBUse management frame protection (IEEE 802.11w) in this associationh]hBUse management frame protection (IEEE 802.11w) in this association}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj(hM hj)ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj(hM hjubj)}(hQ``flags`` See :c:type:`enum cfg80211_assoc_req_flags ` h](j)}(h ``flags``h]j)}(hjLh]hflags}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjFubj6)}(hhh]h)}(hFSee :c:type:`enum cfg80211_assoc_req_flags `h](hSee }(hjehhhNhNubh)}(hB:c:type:`enum cfg80211_assoc_req_flags `h]j)}(hjoh]henum cfg80211_assoc_req_flags}(hjqhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6cfg80211_assoc_req_flagsuh1hhjahM hjeubeh}(h]h ]h"]h$]h&]uh1hhjahM hjbubah}(h]h ]h"]h$]h&]uh1j5hjFubeh}(h]h ]h"]h$]h&]uh1jhjahM hjubj)}(h``supported_selectors`` supported BSS selectors in IEEE 802.11 format (or ``NULL`` for no change). If ``NULL``, then support for SAE_H2E should be assumed. h](j)}(h``supported_selectors``h]j)}(hjh]hsupported_selectors}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hsupported BSS selectors in IEEE 802.11 format (or ``NULL`` for no change). If ``NULL``, then support for SAE_H2E should be assumed.h](h2supported BSS selectors in IEEE 802.11 format (or }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjųhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh for no change). If }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hj׳hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh-, then support for SAE_H2E should be assumed.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h>``supported_selectors_len`` number of supported BSS selectors h](j)}(h``supported_selectors_len``h]j)}(hjh]hsupported_selectors_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h!number of supported BSS selectorsh]h!number of supported BSS selectors}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h``ht_capa`` HT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored. h](j)}(h ``ht_capa``h]j)}(hj;h]hht_capa}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj5ubj6)}(hhh]h)}(hvHT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored.h]hvHT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored.}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjQubah}(h]h ]h"]h$]h&]uh1j5hj5ubeh}(h]h ]h"]h$]h&]uh1jhjPhM hjubj)}(h;``ht_capa_mask`` The bits of ht_capa which are to be used. h](j)}(h``ht_capa_mask``h]j)}(hjuh]h ht_capa_mask}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjoubj6)}(hhh]h)}(h)The bits of ht_capa which are to be used.h]h)The bits of ht_capa which are to be used.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjoubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h%``vht_capa`` VHT capability override h](j)}(h ``vht_capa``h]j)}(hjh]hvht_capa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hVHT capability overrideh]hVHT capability override}(hjǴhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjôhM hjĴubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjôhM hjubj)}(hE``vht_capa_mask`` VHT capability mask indicating which fields to use h](j)}(h``vht_capa_mask``h]j)}(hjh]h vht_capa_mask}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h2VHT capability mask indicating which fields to useh]h2VHT capability mask indicating which fields to use}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hm``fils_kek`` FILS KEK for protecting (Re)Association Request/Response frame or ``NULL`` if FILS is not used. h](j)}(h ``fils_kek``h]j)}(hj h]hfils_kek}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h_FILS KEK for protecting (Re)Association Request/Response frame or ``NULL`` if FILS is not used.h](hBFILS KEK for protecting (Re)Association Request/Response frame or }(hj9hhhNhNubj)}(h``NULL``h]hNULL}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubh if FILS is not used.}(hj9hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj6ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj5hM hjubj)}(h.``fils_kek_len`` Length of fils_kek in octets h](j)}(h``fils_kek_len``h]j)}(hjlh]h fils_kek_len}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjfubj6)}(hhh]h)}(hLength of fils_kek in octetsh]hLength of fils_kek in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h``fils_nonces`` FILS nonces (part of AAD) for protecting (Re)Association Request/Response frame or ``NULL`` if FILS is not used. This field starts with 16 octets of STA Nonce followed by 16 octets of AP Nonce. h](j)}(h``fils_nonces``h]j)}(hjh]h fils_nonces}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hFILS nonces (part of AAD) for protecting (Re)Association Request/Response frame or ``NULL`` if FILS is not used. This field starts with 16 octets of STA Nonce followed by 16 octets of AP Nonce.h](hSFILS nonces (part of AAD) for protecting (Re)Association Request/Response frame or }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjƵhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhf if FILS is not used. This field starts with 16 octets of STA Nonce followed by 16 octets of AP Nonce.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h%``s1g_capa`` S1G capability override h](j)}(h ``s1g_capa``h]j)}(hjh]hs1g_capa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hS1G capability overrideh]hS1G capability override}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h/``s1g_capa_mask`` S1G capability override mask h](j)}(h``s1g_capa_mask``h]j)}(hj*h]h s1g_capa_mask}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj$ubj6)}(hhh]h)}(hS1G capability override maskh]hS1G capability override mask}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hM hj@ubah}(h]h ]h"]h$]h&]uh1j5hj$ubeh}(h]h ]h"]h$]h&]uh1jhj?hM hjubj)}(h3``links`` per-link information for MLO connections h](j)}(h ``links``h]j)}(hjch]hlinks}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj]ubj6)}(hhh]h)}(h(per-link information for MLO connectionsh]h(per-link information for MLO connections}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxhM hjyubah}(h]h ]h"]h$]h&]uh1j5hj]ubeh}(h]h ]h"]h$]h&]uh1jhjxhM hjubj)}(h^``ap_mld_addr`` AP MLD address in case of MLO association request, valid iff **link_id** >= 0 h](j)}(h``ap_mld_addr``h]j)}(hjh]h ap_mld_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hMAP MLD address in case of MLO association request, valid iff **link_id** >= 0h](h=AP MLD address in case of MLO association request, valid iff }(hjhhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh >= 0}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h``link_id`` >= 0 for MLO connections, where links are given, and indicates the link on which the association request should be sent h](j)}(h ``link_id``h]j)}(hjh]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hw>= 0 for MLO connections, where links are given, and indicates the link on which the association request should be senth]hw>= 0 for MLO connections, where links are given, and indicates the link on which the association request should be sent}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hb``ext_mld_capa_ops`` extended MLD capabilities and operations set by userspace for the associationh](j)}(h``ext_mld_capa_ops``h]j)}(hj"h]hext_mld_capa_ops}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hMextended MLD capabilities and operations set by userspace for the associationh]hMextended MLD capabilities and operations set by userspace for the association}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7hM hj8ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj7hM hjubeh}(h]h ]h"]h$]h&]uh1jhj_ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hjdh]h Description}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^bhhubh)}(hSThis structure provides information needed to complete IEEE 802.11 (re)association.h]hSThis structure provides information needed to complete IEEE 802.11 (re)association.}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_deauth_request (C struct)c.cfg80211_deauth_requesthNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hcfg80211_deauth_requesth]jo)}(hstruct cfg80211_deauth_requesth](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(hcfg80211_deauth_requesth]j)}(hjh]hcfg80211_deauth_request}(hj·hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM hjhhubj)}(hhh]h)}(hDeauthentication request datah]hDeauthentication request data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhj^bhNhNubj)}(hX**Definition**:: struct cfg80211_deauth_request { const u8 *bssid; const u8 *ie; size_t ie_len; u16 reason_code; bool local_state_change; }; **Members** ``bssid`` the BSSID or AP MLD address to deauthenticate from ``ie`` Extra IEs to add to Deauthentication frame or ``NULL`` ``ie_len`` Length of ie buffer in octets ``reason_code`` The reason code for the deauthentication ``local_state_change`` if set, change local state only and do not set a deauth frameh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj( )}(hstruct cfg80211_deauth_request { const u8 *bssid; const u8 *ie; size_t ie_len; u16 reason_code; bool local_state_change; };h]hstruct cfg80211_deauth_request { const u8 *bssid; const u8 *ie; size_t ie_len; u16 reason_code; bool local_state_change; };}hj!sbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubh)}(h **Members**h]j)}(hj2h]hMembers}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj)}(hhh](j)}(h=``bssid`` the BSSID or AP MLD address to deauthenticate from h](j)}(h ``bssid``h]j)}(hjQh]hbssid}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjKubj6)}(hhh]h)}(h2the BSSID or AP MLD address to deauthenticate fromh]h2the BSSID or AP MLD address to deauthenticate from}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhM hjgubah}(h]h ]h"]h$]h&]uh1j5hjKubeh}(h]h ]h"]h$]h&]uh1jhjfhM hjHubj)}(h>``ie`` Extra IEs to add to Deauthentication frame or ``NULL`` h](j)}(h``ie``h]j)}(hjh]hie}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h6Extra IEs to add to Deauthentication frame or ``NULL``h](h.Extra IEs to add to Deauthentication frame or }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjHubj)}(h)``ie_len`` Length of ie buffer in octets h](j)}(h ``ie_len``h]j)}(hjѸh]hie_len}(hjӸhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjϸubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj˸ubj6)}(hhh]h)}(hLength of ie buffer in octetsh]hLength of ie buffer in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hj˸ubeh}(h]h ]h"]h$]h&]uh1jhjhM hjHubj)}(h9``reason_code`` The reason code for the deauthentication h](j)}(h``reason_code``h]j)}(hj h]h reason_code}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h(The reason code for the deauthenticationh]h(The reason code for the deauthentication}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjHubj)}(hT``local_state_change`` if set, change local state only and do not set a deauth frameh](j)}(h``local_state_change``h]j)}(hjCh]hlocal_state_change}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj=ubj6)}(hhh]h)}(h=if set, change local state only and do not set a deauth frameh]h=if set, change local state only and do not set a deauth frame}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhM hjYubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhjXhM hjHubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^bhhubh)}(hTThis structure provides information needed to complete IEEE 802.11 deauthentication.h]hTThis structure provides information needed to complete IEEE 802.11 deauthentication.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_$cfg80211_disassoc_request (C struct)c.cfg80211_disassoc_requesthNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hcfg80211_disassoc_requesth]jo)}(h struct cfg80211_disassoc_requesth](ju)}(hjh]hstruct}(hjùhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjѹhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjйhM ubj)}(hcfg80211_disassoc_requesth]j)}(hjh]hcfg80211_disassoc_request}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj߹ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjйhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjйhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjйhM hjhhubj)}(hhh]h)}(hDisassociation request datah]hDisassociation request data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjйhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhj^bhNhNubj)}(hX**Definition**:: struct cfg80211_disassoc_request { const u8 *ap_addr; const u8 *ie; size_t ie_len; u16 reason_code; bool local_state_change; }; **Members** ``ap_addr`` the BSSID or AP MLD address to disassociate from ``ie`` Extra IEs to add to Disassociation frame or ``NULL`` ``ie_len`` Length of ie buffer in octets ``reason_code`` The reason code for the disassociation ``local_state_change`` This is a request for a local state only, i.e., no Disassociation frame is to be transmitted.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%ubh:}(hj%hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj!ubj( )}(hstruct cfg80211_disassoc_request { const u8 *ap_addr; const u8 *ie; size_t ie_len; u16 reason_code; bool local_state_change; };h]hstruct cfg80211_disassoc_request { const u8 *ap_addr; const u8 *ie; size_t ie_len; u16 reason_code; bool local_state_change; };}hjBsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj!ubh)}(h **Members**h]j)}(hjSh]hMembers}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj!ubj)}(hhh](j)}(h=``ap_addr`` the BSSID or AP MLD address to disassociate from h](j)}(h ``ap_addr``h]j)}(hjrh]hap_addr}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjlubj6)}(hhh]h)}(h0the BSSID or AP MLD address to disassociate fromh]h0the BSSID or AP MLD address to disassociate from}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjlubeh}(h]h ]h"]h$]h&]uh1jhjhM hjiubj)}(h<``ie`` Extra IEs to add to Disassociation frame or ``NULL`` h](j)}(h``ie``h]j)}(hjh]hie}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h4Extra IEs to add to Disassociation frame or ``NULL``h](h,Extra IEs to add to Disassociation frame or }(hjĺhhhNhNubj)}(h``NULL``h]hNULL}(hj̺hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjĺubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjiubj)}(h)``ie_len`` Length of ie buffer in octets h](j)}(h ``ie_len``h]j)}(hjh]hie_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hLength of ie buffer in octetsh]hLength of ie buffer in octets}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjiubj)}(h7``reason_code`` The reason code for the disassociation h](j)}(h``reason_code``h]j)}(hj+h]h reason_code}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj%ubj6)}(hhh]h)}(h&The reason code for the disassociationh]h&The reason code for the disassociation}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@hM hjAubah}(h]h ]h"]h$]h&]uh1j5hj%ubeh}(h]h ]h"]h$]h&]uh1jhj@hM hjiubj)}(ht``local_state_change`` This is a request for a local state only, i.e., no Disassociation frame is to be transmitted.h](j)}(h``local_state_change``h]j)}(hjdh]hlocal_state_change}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^ubj6)}(hhh]h)}(h]This is a request for a local state only, i.e., no Disassociation frame is to be transmitted.h]h]This is a request for a local state only, i.e., no Disassociation frame is to be transmitted.}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyhM hjzubah}(h]h ]h"]h$]h&]uh1j5hj^ubeh}(h]h ]h"]h$]h&]uh1jhjyhM hjiubeh}(h]h ]h"]h$]h&]uh1jhj!ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^bhhubh)}(hRThis structure provides information needed to complete IEEE 802.11 disassociation.h]hRThis structure provides information needed to complete IEEE 802.11 disassociation.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_ibss_params (C struct)c.cfg80211_ibss_paramshNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hcfg80211_ibss_paramsh]jo)}(hstruct cfg80211_ibss_paramsh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(hcfg80211_ibss_paramsh]j)}(hj޻h]hcfg80211_ibss_params}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjܻhhhjhM ubah}(h]j׻ah ](jjeh"]h$]h&]jj)jhuh1jhhjhM hjٻhhubj)}(hhh]h)}(hIBSS parametersh]hIBSS parameters}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj#hhubah}(h]h ]h"]h$]h&]uh1jhjٻhhhjhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jj>jj>jjjuh1jchhhj^bhNhNubj)}(hX**Definition**:: struct cfg80211_ibss_params { const u8 *ssid; const u8 *bssid; struct cfg80211_chan_def chandef; const u8 *ie; u8 ssid_len, ie_len; u16 beacon_interval; u32 basic_rates; bool channel_fixed; bool privacy; bool control_port; bool control_port_over_nl80211; bool userspace_handles_dfs; int mcast_rate[NUM_NL80211_BANDS]; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct key_params *wep_keys; int wep_tx_key; }; **Members** ``ssid`` The SSID, will always be non-null. ``bssid`` Fixed BSSID requested, maybe be ``NULL``, if set do not search for IBSSs with a different BSSID. ``chandef`` defines the channel to use if no other IBSS to join can be found ``ie`` information element(s) to include in the beacon ``ssid_len`` The length of the SSID, will always be non-zero. ``ie_len`` length of that ``beacon_interval`` beacon interval to use ``basic_rates`` bitmap of basic rates to use when creating the IBSS ``channel_fixed`` The channel should be fixed -- do not search for IBSSs to join on other channels. ``privacy`` this is a protected network, keys will be configured after joining ``control_port`` whether user space controls IEEE 802.1X port, i.e., sets/clears ``NL80211_STA_FLAG_AUTHORIZED``. If true, the driver is required to assume that the port is unauthorized until authorized by user space. Otherwise, port is marked authorized by default. ``control_port_over_nl80211`` TRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface. ``userspace_handles_dfs`` whether user space controls DFS operation, i.e. changes the channel when a radar is detected. This is required to operate on DFS channels. ``mcast_rate`` per-band multicast rate index + 1 (0: disabled) ``ht_capa`` HT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored. ``ht_capa_mask`` The bits of ht_capa which are to be used. ``wep_keys`` static WEP keys, if not NULL points to an array of CFG80211_MAX_WEP_KEYS WEP keys ``wep_tx_key`` key index (0..3) of the default TX static WEP keyh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFubh:}(hjFhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjBubj( )}(hXstruct cfg80211_ibss_params { const u8 *ssid; const u8 *bssid; struct cfg80211_chan_def chandef; const u8 *ie; u8 ssid_len, ie_len; u16 beacon_interval; u32 basic_rates; bool channel_fixed; bool privacy; bool control_port; bool control_port_over_nl80211; bool userspace_handles_dfs; int mcast_rate[NUM_NL80211_BANDS]; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct key_params *wep_keys; int wep_tx_key; };h]hXstruct cfg80211_ibss_params { const u8 *ssid; const u8 *bssid; struct cfg80211_chan_def chandef; const u8 *ie; u8 ssid_len, ie_len; u16 beacon_interval; u32 basic_rates; bool channel_fixed; bool privacy; bool control_port; bool control_port_over_nl80211; bool userspace_handles_dfs; int mcast_rate[NUM_NL80211_BANDS]; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct key_params *wep_keys; int wep_tx_key; };}hjcsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjBubh)}(h **Members**h]j)}(hjth]hMembers}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjrubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM0 hjBubj)}(hhh](j)}(h,``ssid`` The SSID, will always be non-null. h](j)}(h``ssid``h]j)}(hjh]hssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h"The SSID, will always be non-null.h]h"The SSID, will always be non-null.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hk``bssid`` Fixed BSSID requested, maybe be ``NULL``, if set do not search for IBSSs with a different BSSID. h](j)}(h ``bssid``h]j)}(hj̼h]hbssid}(hjμhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjʼubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjƼubj6)}(hhh]h)}(h`Fixed BSSID requested, maybe be ``NULL``, if set do not search for IBSSs with a different BSSID.h](h Fixed BSSID requested, maybe be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh8, if set do not search for IBSSs with a different BSSID.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjƼubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hM``chandef`` defines the channel to use if no other IBSS to join can be found h](j)}(h ``chandef``h]j)}(hjh]hchandef}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h@defines the channel to use if no other IBSS to join can be foundh]h@defines the channel to use if no other IBSS to join can be found}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-hM hj.ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj-hM hjubj)}(h7``ie`` information element(s) to include in the beacon h](j)}(h``ie``h]j)}(hjQh]hie}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM# hjKubj6)}(hhh]h)}(h/information element(s) to include in the beaconh]h/information element(s) to include in the beacon}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhM# hjgubah}(h]h ]h"]h$]h&]uh1j5hjKubeh}(h]h ]h"]h$]h&]uh1jhjfhM# hjubj)}(h>``ssid_len`` The length of the SSID, will always be non-zero. h](j)}(h ``ssid_len``h]j)}(hjh]hssid_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h0The length of the SSID, will always be non-zero.h]h0The length of the SSID, will always be non-zero.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h``ie_len`` length of that h](j)}(h ``ie_len``h]j)}(hjýh]hie_len}(hjŽhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$ hjubj6)}(hhh]h)}(hlength of thath]hlength of that}(hjܽhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjؽhM$ hjٽubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjؽhM$ hjubj)}(h+``beacon_interval`` beacon interval to use h](j)}(h``beacon_interval``h]j)}(hjh]hbeacon_interval}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM% hjubj6)}(hhh]h)}(hbeacon interval to useh]hbeacon interval to use}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM% hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM% hjubj)}(hD``basic_rates`` bitmap of basic rates to use when creating the IBSS h](j)}(h``basic_rates``h]j)}(hj5h]h basic_rates}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM1 hj/ubj6)}(hhh]h)}(h3bitmap of basic rates to use when creating the IBSSh]h3bitmap of basic rates to use when creating the IBSS}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJhM1 hjKubah}(h]h ]h"]h$]h&]uh1j5hj/ubeh}(h]h ]h"]h$]h&]uh1jhjJhM1 hjubj)}(hd``channel_fixed`` The channel should be fixed -- do not search for IBSSs to join on other channels. h](j)}(h``channel_fixed``h]j)}(hjnh]h channel_fixed}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM" hjhubj6)}(hhh]h)}(hQThe channel should be fixed -- do not search for IBSSs to join on other channels.h]hQThe channel should be fixed -- do not search for IBSSs to join on other channels.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM! hjubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhM" hjubj)}(hO``privacy`` this is a protected network, keys will be configured after joining h](j)}(h ``privacy``h]j)}(hjh]hprivacy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM' hjubj6)}(hhh]h)}(hBthis is a protected network, keys will be configured after joiningh]hBthis is a protected network, keys will be configured after joining}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM& hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM' hjubj)}(hX ``control_port`` whether user space controls IEEE 802.1X port, i.e., sets/clears ``NL80211_STA_FLAG_AUTHORIZED``. If true, the driver is required to assume that the port is unauthorized until authorized by user space. Otherwise, port is marked authorized by default. h](j)}(h``control_port``h]j)}(hjh]h control_port}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM+ hjܾubj6)}(hhh]h)}(hwhether user space controls IEEE 802.1X port, i.e., sets/clears ``NL80211_STA_FLAG_AUTHORIZED``. If true, the driver is required to assume that the port is unauthorized until authorized by user space. Otherwise, port is marked authorized by default.h](h@whether user space controls IEEE 802.1X port, i.e., sets/clears }(hjhhhNhNubj)}(h``NL80211_STA_FLAG_AUTHORIZED``h]hNL80211_STA_FLAG_AUTHORIZED}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh. If true, the driver is required to assume that the port is unauthorized until authorized by user space. Otherwise, port is marked authorized by default.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM( hjubah}(h]h ]h"]h$]h&]uh1j5hjܾubeh}(h]h ]h"]h$]h&]uh1jhjhM+ hjubj)}(h``control_port_over_nl80211`` TRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface. h](j)}(h``control_port_over_nl80211``h]j)}(hj.h]hcontrol_port_over_nl80211}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM- hj(ubj6)}(hhh]h)}(hhTRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface.h]hhTRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface.}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM, hjDubah}(h]h ]h"]h$]h&]uh1j5hj(ubeh}(h]h ]h"]h$]h&]uh1jhjChM- hjubj)}(h``userspace_handles_dfs`` whether user space controls DFS operation, i.e. changes the channel when a radar is detected. This is required to operate on DFS channels. h](j)}(h``userspace_handles_dfs``h]j)}(hjhh]huserspace_handles_dfs}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM0 hjbubj6)}(hhh]h)}(hwhether user space controls DFS operation, i.e. changes the channel when a radar is detected. This is required to operate on DFS channels.h]hwhether user space controls DFS operation, i.e. changes the channel when a radar is detected. This is required to operate on DFS channels.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM. hj~ubah}(h]h ]h"]h$]h&]uh1j5hjbubeh}(h]h ]h"]h$]h&]uh1jhj}hM0 hjubj)}(h?``mcast_rate`` per-band multicast rate index + 1 (0: disabled) h](j)}(h``mcast_rate``h]j)}(hjh]h mcast_rate}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM2 hjubj6)}(hhh]h)}(h/per-band multicast rate index + 1 (0: disabled)h]h/per-band multicast rate index + 1 (0: disabled)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM2 hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM2 hjubj)}(h``ht_capa`` HT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored. h](j)}(h ``ht_capa``h]j)}(hjۿh]hht_capa}(hjݿhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjٿubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM4 hjտubj6)}(hhh]h)}(hvHT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored.h]hvHT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM3 hjubah}(h]h ]h"]h$]h&]uh1j5hjտubeh}(h]h ]h"]h$]h&]uh1jhjhM4 hjubj)}(h;``ht_capa_mask`` The bits of ht_capa which are to be used. h](j)}(h``ht_capa_mask``h]j)}(hjh]h ht_capa_mask}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM5 hjubj6)}(hhh]h)}(h)The bits of ht_capa which are to be used.h]h)The bits of ht_capa which are to be used.}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hM5 hj+ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj*hM5 hjubj)}(h_``wep_keys`` static WEP keys, if not NULL points to an array of CFG80211_MAX_WEP_KEYS WEP keys h](j)}(h ``wep_keys``h]j)}(hjNh]hwep_keys}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM7 hjHubj6)}(hhh]h)}(hQstatic WEP keys, if not NULL points to an array of CFG80211_MAX_WEP_KEYS WEP keysh]hQstatic WEP keys, if not NULL points to an array of CFG80211_MAX_WEP_KEYS WEP keys}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM6 hjdubah}(h]h ]h"]h$]h&]uh1j5hjHubeh}(h]h ]h"]h$]h&]uh1jhjchM7 hjubj)}(h@``wep_tx_key`` key index (0..3) of the default TX static WEP keyh](j)}(h``wep_tx_key``h]j)}(hjh]h wep_tx_key}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM7 hjubj6)}(hhh]h)}(h1key index (0..3) of the default TX static WEP keyh]h1key index (0..3) of the default TX static WEP key}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM8 hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM7 hjubeh}(h]h ]h"]h$]h&]uh1jhjBubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM; hj^bhhubh)}(hFThis structure defines the IBSS parameters for the join_ibss() method.h]hFThis structure defines the IBSS parameters for the join_ibss() method.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_connect_params (C struct)c.cfg80211_connect_paramshNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hcfg80211_connect_paramsh]jo)}(hstruct cfg80211_connect_paramsh](ju)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(hcfg80211_connect_paramsh]j)}(hjh]hcfg80211_connect_params}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM hjhhubj)}(hhh]h)}(hConnection parametersh]hConnection parameters}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM^ hjHhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjcjjcjjjuh1jchhhj^bhNhNubj)}(hX**Definition**:: struct cfg80211_connect_params { struct ieee80211_channel *channel; struct ieee80211_channel *channel_hint; const u8 *bssid; const u8 *bssid_hint; const u8 *ssid; size_t ssid_len; enum nl80211_auth_type auth_type; const u8 *ie; size_t ie_len; bool privacy; enum nl80211_mfp mfp; struct cfg80211_crypto_settings crypto; const u8 *key; u8 key_len, key_idx; u32 flags; int bg_scan_period; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct ieee80211_vht_cap vht_capa; struct ieee80211_vht_cap vht_capa_mask; bool pbss; struct cfg80211_bss_selection bss_select; const u8 *prev_bssid; const u8 *fils_erp_username; size_t fils_erp_username_len; const u8 *fils_erp_realm; size_t fils_erp_realm_len; u16 fils_erp_next_seq_num; const u8 *fils_erp_rrk; size_t fils_erp_rrk_len; bool want_1x; struct ieee80211_edmg edmg; }; **Members** ``channel`` The channel to use or ``NULL`` if not specified (auto-select based on scan results) ``channel_hint`` The channel of the recommended BSS for initial connection or ``NULL`` if not specified ``bssid`` The AP BSSID or ``NULL`` if not specified (auto-select based on scan results) ``bssid_hint`` The recommended AP BSSID for initial connection to the BSS or ``NULL`` if not specified. Unlike the **bssid** parameter, the driver is allowed to ignore this **bssid_hint** if it has knowledge of a better BSS to use. ``ssid`` SSID ``ssid_len`` Length of ssid in octets ``auth_type`` Authentication type (algorithm) ``ie`` IEs for association request ``ie_len`` Length of assoc_ie in octets ``privacy`` indicates whether privacy-enabled APs should be used ``mfp`` indicate whether management frame protection is used ``crypto`` crypto settings ``key`` WEP key for shared key authentication ``key_len`` length of WEP key for shared key authentication ``key_idx`` index of WEP key for shared key authentication ``flags`` See :c:type:`enum cfg80211_assoc_req_flags ` ``bg_scan_period`` Background scan period in seconds or -1 to indicate that default value is to be used. ``ht_capa`` HT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored. ``ht_capa_mask`` The bits of ht_capa which are to be used. ``vht_capa`` VHT Capability overrides ``vht_capa_mask`` The bits of vht_capa which are to be used. ``pbss`` if set, connect to a PCP instead of AP. Valid for DMG networks. ``bss_select`` criteria to be used for BSS selection. ``prev_bssid`` previous BSSID, if not ``NULL`` use reassociate frame. This is used to indicate a request to reassociate within the ESS instead of a request do the initial association with the ESS. When included, this is set to the BSSID of the current association, i.e., to the value that is included in the Current AP address field of the Reassociation Request frame. ``fils_erp_username`` EAP re-authentication protocol (ERP) username part of the NAI or ``NULL`` if not specified. This is used to construct FILS wrapped data IE. ``fils_erp_username_len`` Length of **fils_erp_username** in octets. ``fils_erp_realm`` EAP re-authentication protocol (ERP) realm part of NAI or ``NULL`` if not specified. This specifies the domain name of ER server and is used to construct FILS wrapped data IE. ``fils_erp_realm_len`` Length of **fils_erp_realm** in octets. ``fils_erp_next_seq_num`` The next sequence number to use in the FILS ERP messages. This is also used to construct FILS wrapped data IE. ``fils_erp_rrk`` ERP re-authentication Root Key (rRK) used to derive additional keys in FILS or ``NULL`` if not specified. ``fils_erp_rrk_len`` Length of **fils_erp_rrk** in octets. ``want_1x`` indicates user-space supports and wants to use 802.1X driver offload of 4-way handshake. ``edmg`` define the EDMG channels. This may specify multiple channels and bonding options for the driver to choose from, based on BSS configuration.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkubh:}(hjkhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMb hjgubj( )}(hXstruct cfg80211_connect_params { struct ieee80211_channel *channel; struct ieee80211_channel *channel_hint; const u8 *bssid; const u8 *bssid_hint; const u8 *ssid; size_t ssid_len; enum nl80211_auth_type auth_type; const u8 *ie; size_t ie_len; bool privacy; enum nl80211_mfp mfp; struct cfg80211_crypto_settings crypto; const u8 *key; u8 key_len, key_idx; u32 flags; int bg_scan_period; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct ieee80211_vht_cap vht_capa; struct ieee80211_vht_cap vht_capa_mask; bool pbss; struct cfg80211_bss_selection bss_select; const u8 *prev_bssid; const u8 *fils_erp_username; size_t fils_erp_username_len; const u8 *fils_erp_realm; size_t fils_erp_realm_len; u16 fils_erp_next_seq_num; const u8 *fils_erp_rrk; size_t fils_erp_rrk_len; bool want_1x; struct ieee80211_edmg edmg; };h]hXstruct cfg80211_connect_params { struct ieee80211_channel *channel; struct ieee80211_channel *channel_hint; const u8 *bssid; const u8 *bssid_hint; const u8 *ssid; size_t ssid_len; enum nl80211_auth_type auth_type; const u8 *ie; size_t ie_len; bool privacy; enum nl80211_mfp mfp; struct cfg80211_crypto_settings crypto; const u8 *key; u8 key_len, key_idx; u32 flags; int bg_scan_period; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct ieee80211_vht_cap vht_capa; struct ieee80211_vht_cap vht_capa_mask; bool pbss; struct cfg80211_bss_selection bss_select; const u8 *prev_bssid; const u8 *fils_erp_username; size_t fils_erp_username_len; const u8 *fils_erp_realm; size_t fils_erp_realm_len; u16 fils_erp_next_seq_num; const u8 *fils_erp_rrk; size_t fils_erp_rrk_len; bool want_1x; struct ieee80211_edmg edmg; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMd hjgubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjgubj)}(hhh](j)}(h```channel`` The channel to use or ``NULL`` if not specified (auto-select based on scan results) h](j)}(h ``channel``h]j)}(hjh]hchannel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMe hjubj6)}(hhh]h)}(hSThe channel to use or ``NULL`` if not specified (auto-select based on scan results)h](hThe channel to use or }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh5 if not specified (auto-select based on scan results)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMd hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMe hjubj)}(hh``channel_hint`` The channel of the recommended BSS for initial connection or ``NULL`` if not specified h](j)}(h``channel_hint``h]j)}(hjh]h channel_hint}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMg hjubj6)}(hhh]h)}(hVThe channel of the recommended BSS for initial connection or ``NULL`` if not specifiedh](h=The channel of the recommended BSS for initial connection or }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh if not specified}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMf hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMg hjubj)}(hX``bssid`` The AP BSSID or ``NULL`` if not specified (auto-select based on scan results) h](j)}(h ``bssid``h]j)}(hjPh]hbssid}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMi hjJubj6)}(hhh]h)}(hMThe AP BSSID or ``NULL`` if not specified (auto-select based on scan results)h](hThe AP BSSID or }(hjihhhNhNubj)}(h``NULL``h]hNULL}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubh5 if not specified (auto-select based on scan results)}(hjihhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMh hjfubah}(h]h ]h"]h$]h&]uh1j5hjJubeh}(h]h ]h"]h$]h&]uh1jhjehMi hjubj)}(h``bssid_hint`` The recommended AP BSSID for initial connection to the BSS or ``NULL`` if not specified. Unlike the **bssid** parameter, the driver is allowed to ignore this **bssid_hint** if it has knowledge of a better BSS to use. h](j)}(h``bssid_hint``h]j)}(hjh]h bssid_hint}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMm hjubj6)}(hhh]h)}(hThe recommended AP BSSID for initial connection to the BSS or ``NULL`` if not specified. Unlike the **bssid** parameter, the driver is allowed to ignore this **bssid_hint** if it has knowledge of a better BSS to use.h](h>The recommended AP BSSID for initial connection to the BSS or }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh if not specified. Unlike the }(hjhhhNhNubj)}(h **bssid**h]hbssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh1 parameter, the driver is allowed to ignore this }(hjhhhNhNubj)}(h**bssid_hint**h]h bssid_hint}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh, if it has knowledge of a better BSS to use.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMj hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMm hjubj)}(h``ssid`` SSID h](j)}(h``ssid``h]j)}(hj h]hssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMn hjubj6)}(hhh]h)}(hSSIDh]hSSID}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hMn hj"ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj!hMn hjubj)}(h&``ssid_len`` Length of ssid in octets h](j)}(h ``ssid_len``h]j)}(hjEh]hssid_len}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMo hj?ubj6)}(hhh]h)}(hLength of ssid in octetsh]hLength of ssid in octets}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhMo hj[ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhjZhMo hjubj)}(h.``auth_type`` Authentication type (algorithm) h](j)}(h ``auth_type``h]j)}(hj~h]h auth_type}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMp hjxubj6)}(hhh]h)}(hAuthentication type (algorithm)h]hAuthentication type (algorithm)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMp hjubah}(h]h ]h"]h$]h&]uh1j5hjxubeh}(h]h ]h"]h$]h&]uh1jhjhMp hjubj)}(h#``ie`` IEs for association request h](j)}(h``ie``h]j)}(hjh]hie}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMq hjubj6)}(hhh]h)}(hIEs for association requesth]hIEs for association request}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMq hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMq hjubj)}(h(``ie_len`` Length of assoc_ie in octets h](j)}(h ``ie_len``h]j)}(hjh]hie_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMr hjubj6)}(hhh]h)}(hLength of assoc_ie in octetsh]hLength of assoc_ie in octets}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMr hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMr hjubj)}(hA``privacy`` indicates whether privacy-enabled APs should be used h](j)}(h ``privacy``h]j)}(hj)h]hprivacy}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMs hj#ubj6)}(hhh]h)}(h4indicates whether privacy-enabled APs should be usedh]h4indicates whether privacy-enabled APs should be used}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hMs hj?ubah}(h]h ]h"]h$]h&]uh1j5hj#ubeh}(h]h ]h"]h$]h&]uh1jhj>hMs hjubj)}(h=``mfp`` indicate whether management frame protection is used h](j)}(h``mfp``h]j)}(hjbh]hmfp}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMt hj\ubj6)}(hhh]h)}(h4indicate whether management frame protection is usedh]h4indicate whether management frame protection is used}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwhMt hjxubah}(h]h ]h"]h$]h&]uh1j5hj\ubeh}(h]h ]h"]h$]h&]uh1jhjwhMt hjubj)}(h``crypto`` crypto settings h](j)}(h ``crypto``h]j)}(hjh]hcrypto}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMu hjubj6)}(hhh]h)}(hcrypto settingsh]hcrypto settings}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMu hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMu hjubj)}(h.``key`` WEP key for shared key authentication h](j)}(h``key``h]j)}(hjh]hkey}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMx hjubj6)}(hhh]h)}(h%WEP key for shared key authenticationh]h%WEP key for shared key authentication}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMx hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMx hjubj)}(h<``key_len`` length of WEP key for shared key authentication h](j)}(h ``key_len``h]j)}(hj h]hkey_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMv hjubj6)}(hhh]h)}(h/length of WEP key for shared key authenticationh]h/length of WEP key for shared key authentication}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hMv hj#ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj"hMv hjubj)}(h;``key_idx`` index of WEP key for shared key authentication h](j)}(h ``key_idx``h]j)}(hjFh]hkey_idx}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMw hj@ubj6)}(hhh]h)}(h.index of WEP key for shared key authenticationh]h.index of WEP key for shared key authentication}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hMw hj\ubah}(h]h ]h"]h$]h&]uh1j5hj@ubeh}(h]h ]h"]h$]h&]uh1jhj[hMw hjubj)}(hQ``flags`` See :c:type:`enum cfg80211_assoc_req_flags ` h](j)}(h ``flags``h]j)}(hjh]hflags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMy hjyubj6)}(hhh]h)}(hFSee :c:type:`enum cfg80211_assoc_req_flags `h](hSee }(hjhhhNhNubh)}(hB:c:type:`enum cfg80211_assoc_req_flags `h]j)}(hjh]henum cfg80211_assoc_req_flags}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6cfg80211_assoc_req_flagsuh1hhjhMy hjubeh}(h]h ]h"]h$]h&]uh1hhjhMy hjubah}(h]h ]h"]h$]h&]uh1j5hjyubeh}(h]h ]h"]h$]h&]uh1jhjhMy hjubj)}(hi``bg_scan_period`` Background scan period in seconds or -1 to indicate that default value is to be used. h](j)}(h``bg_scan_period``h]j)}(hjh]hbg_scan_period}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM{ hjubj6)}(hhh]h)}(hUBackground scan period in seconds or -1 to indicate that default value is to be used.h]hUBackground scan period in seconds or -1 to indicate that default value is to be used.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMz hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM{ hjubj)}(h``ht_capa`` HT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored. h](j)}(h ``ht_capa``h]j)}(hjh]hht_capa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM} hj ubj6)}(hhh]h)}(hvHT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored.h]hvHT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored.}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM| hj'ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj&hM} hjubj)}(h;``ht_capa_mask`` The bits of ht_capa which are to be used. h](j)}(h``ht_capa_mask``h]j)}(hjKh]h ht_capa_mask}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM~ hjEubj6)}(hhh]h)}(h)The bits of ht_capa which are to be used.h]h)The bits of ht_capa which are to be used.}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`hM~ hjaubah}(h]h ]h"]h$]h&]uh1j5hjEubeh}(h]h ]h"]h$]h&]uh1jhj`hM~ hjubj)}(h&``vht_capa`` VHT Capability overrides h](j)}(h ``vht_capa``h]j)}(hjh]hvht_capa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj~ubj6)}(hhh]h)}(hVHT Capability overridesh]hVHT Capability overrides}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hj~ubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h=``vht_capa_mask`` The bits of vht_capa which are to be used. h](j)}(h``vht_capa_mask``h]j)}(hjh]h vht_capa_mask}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h*The bits of vht_capa which are to be used.h]h*The bits of vht_capa which are to be used.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hI``pbss`` if set, connect to a PCP instead of AP. Valid for DMG networks. h](j)}(h``pbss``h]j)}(hjh]hpbss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h?if set, connect to a PCP instead of AP. Valid for DMG networks.h]h?if set, connect to a PCP instead of AP. Valid for DMG networks.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hM hjubj)}(h6``bss_select`` criteria to be used for BSS selection. h](j)}(h``bss_select``h]j)}(hj0h]h bss_select}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj*ubj6)}(hhh]h)}(h&criteria to be used for BSS selection.h]h&criteria to be used for BSS selection.}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjEhM hjFubah}(h]h ]h"]h$]h&]uh1j5hj*ubeh}(h]h ]h"]h$]h&]uh1jhjEhM hjubj)}(hXq``prev_bssid`` previous BSSID, if not ``NULL`` use reassociate frame. This is used to indicate a request to reassociate within the ESS instead of a request do the initial association with the ESS. When included, this is set to the BSSID of the current association, i.e., to the value that is included in the Current AP address field of the Reassociation Request frame. h](j)}(h``prev_bssid``h]j)}(hjih]h prev_bssid}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcubj6)}(hhh]h)}(hXaprevious BSSID, if not ``NULL`` use reassociate frame. This is used to indicate a request to reassociate within the ESS instead of a request do the initial association with the ESS. When included, this is set to the BSSID of the current association, i.e., to the value that is included in the Current AP address field of the Reassociation Request frame.h](hprevious BSSID, if not }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhXB use reassociate frame. This is used to indicate a request to reassociate within the ESS instead of a request do the initial association with the ESS. When included, this is set to the BSSID of the current association, i.e., to the value that is included in the Current AP address field of the Reassociation Request frame.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjcubeh}(h]h ]h"]h$]h&]uh1jhj~hM hjubj)}(h``fils_erp_username`` EAP re-authentication protocol (ERP) username part of the NAI or ``NULL`` if not specified. This is used to construct FILS wrapped data IE. h](j)}(h``fils_erp_username``h]j)}(hjh]hfils_erp_username}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hEAP re-authentication protocol (ERP) username part of the NAI or ``NULL`` if not specified. This is used to construct FILS wrapped data IE.h](hAEAP re-authentication protocol (ERP) username part of the NAI or }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhB if not specified. This is used to construct FILS wrapped data IE.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hE``fils_erp_username_len`` Length of **fils_erp_username** in octets. h](j)}(h``fils_erp_username_len``h]j)}(hjh]hfils_erp_username_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h*Length of **fils_erp_username** in octets.h](h Length of }(hjhhhNhNubj)}(h**fils_erp_username**h]hfils_erp_username}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh in octets.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h``fils_erp_realm`` EAP re-authentication protocol (ERP) realm part of NAI or ``NULL`` if not specified. This specifies the domain name of ER server and is used to construct FILS wrapped data IE. h](j)}(h``fils_erp_realm``h]j)}(hjLh]hfils_erp_realm}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjFubj6)}(hhh]h)}(hEAP re-authentication protocol (ERP) realm part of NAI or ``NULL`` if not specified. This specifies the domain name of ER server and is used to construct FILS wrapped data IE.h](h:EAP re-authentication protocol (ERP) realm part of NAI or }(hjehhhNhNubj)}(h``NULL``h]hNULL}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubhm if not specified. This specifies the domain name of ER server and is used to construct FILS wrapped data IE.}(hjehhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjbubah}(h]h ]h"]h$]h&]uh1j5hjFubeh}(h]h ]h"]h$]h&]uh1jhjahM hjubj)}(h?``fils_erp_realm_len`` Length of **fils_erp_realm** in octets. h](j)}(h``fils_erp_realm_len``h]j)}(hjh]hfils_erp_realm_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h'Length of **fils_erp_realm** in octets.h](h Length of }(hjhhhNhNubj)}(h**fils_erp_realm**h]hfils_erp_realm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh in octets.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h``fils_erp_next_seq_num`` The next sequence number to use in the FILS ERP messages. This is also used to construct FILS wrapped data IE. h](j)}(h``fils_erp_next_seq_num``h]j)}(hjh]hfils_erp_next_seq_num}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hnThe next sequence number to use in the FILS ERP messages. This is also used to construct FILS wrapped data IE.h]hnThe next sequence number to use in the FILS ERP messages. This is also used to construct FILS wrapped data IE.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h{``fils_erp_rrk`` ERP re-authentication Root Key (rRK) used to derive additional keys in FILS or ``NULL`` if not specified. h](j)}(h``fils_erp_rrk``h]j)}(hjh]h fils_erp_rrk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hiERP re-authentication Root Key (rRK) used to derive additional keys in FILS or ``NULL`` if not specified.h](hOERP re-authentication Root Key (rRK) used to derive additional keys in FILS or }(hj6hhhNhNubj)}(h``NULL``h]hNULL}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubh if not specified.}(hj6hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj3ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj2hM hjubj)}(h;``fils_erp_rrk_len`` Length of **fils_erp_rrk** in octets. h](j)}(h``fils_erp_rrk_len``h]j)}(hjih]hfils_erp_rrk_len}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcubj6)}(hhh]h)}(h%Length of **fils_erp_rrk** in octets.h](h Length of }(hjhhhNhNubj)}(h**fils_erp_rrk**h]h fils_erp_rrk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh in octets.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj~hM hjubah}(h]h ]h"]h$]h&]uh1j5hjcubeh}(h]h ]h"]h$]h&]uh1jhj~hM hjubj)}(he``want_1x`` indicates user-space supports and wants to use 802.1X driver offload of 4-way handshake. h](j)}(h ``want_1x``h]j)}(hjh]hwant_1x}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hXindicates user-space supports and wants to use 802.1X driver offload of 4-way handshake.h]hXindicates user-space supports and wants to use 802.1X driver offload of 4-way handshake.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h``edmg`` define the EDMG channels. This may specify multiple channels and bonding options for the driver to choose from, based on BSS configuration.h](j)}(h``edmg``h]j)}(hjh]hedmg}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hdefine the EDMG channels. This may specify multiple channels and bonding options for the driver to choose from, based on BSS configuration.h]hdefine the EDMG channels. This may specify multiple channels and bonding options for the driver to choose from, based on BSS configuration.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubeh}(h]h ]h"]h$]h&]uh1jhjgubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hj1h]h Description}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^bhhubh)}(hbThis structure provides information needed to complete IEEE 802.11 authentication and association.h]hbThis structure provides information needed to complete IEEE 802.11 authentication and association.}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM_ hj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_pmksa (C struct)c.cfg80211_pmksahNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hcfg80211_pmksah]jo)}(hstruct cfg80211_pmksah](ju)}(hjh]hstruct}(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjkhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMe ubj)}(h h]h }(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjkhhhj|hMe ubj)}(hcfg80211_pmksah]j)}(hjih]hcfg80211_pmksa}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjkhhhj|hMe ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjghhhj|hMe ubah}(h]jbah ](jjeh"]h$]h&]jj)jhuh1jhhj|hMe hjdhhubj)}(hhh]h)}(hPMK Security Associationh]hPMK Security Association}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhjdhhhj|hMe ubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhj^bhNhNubj)}(hXz**Definition**:: struct cfg80211_pmksa { const u8 *bssid; const u8 *pmkid; const u8 *pmk; size_t pmk_len; const u8 *ssid; size_t ssid_len; const u8 *cache_id; u32 pmk_lifetime; u8 pmk_reauth_threshold; }; **Members** ``bssid`` The AP's BSSID (may be ``NULL``). ``pmkid`` The identifier to refer a PMKSA. ``pmk`` The PMK for the PMKSA identified by **pmkid**. This is used for key derivation by a FILS STA. Otherwise, ``NULL``. ``pmk_len`` Length of the **pmk**. The length of **pmk** can differ depending on the hash algorithm used to generate this. ``ssid`` SSID to specify the ESS within which a PMKSA is valid when using FILS cache identifier (may be ``NULL``). ``ssid_len`` Length of the **ssid** in octets. ``cache_id`` 2-octet cache identifier advertized by a FILS AP identifying the scope of PMKSA. This is valid only if **ssid_len** is non-zero (may be ``NULL``). ``pmk_lifetime`` Maximum lifetime for PMKSA in seconds (dot11RSNAConfigPMKLifetime) or 0 if not specified. The configured PMKSA must not be used for PMKSA caching after expiration and any keys derived from this PMK become invalid on expiration, i.e., the current association must be dropped if the PMK used for it expires. ``pmk_reauth_threshold`` Threshold time for reauthentication (percentage of PMK lifetime, dot11RSNAConfigPMKReauthThreshold) or 0 if not specified. Drivers are expected to trigger a full authentication instead of using this PMKSA for caching when reassociating to a new BSS after this threshold to generate a new PMK before the current one expires.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj( )}(hstruct cfg80211_pmksa { const u8 *bssid; const u8 *pmkid; const u8 *pmk; size_t pmk_len; const u8 *ssid; size_t ssid_len; const u8 *cache_id; u32 pmk_lifetime; u8 pmk_reauth_threshold; };h]hstruct cfg80211_pmksa { const u8 *bssid; const u8 *pmkid; const u8 *pmk; size_t pmk_len; const u8 *ssid; size_t ssid_len; const u8 *cache_id; u32 pmk_lifetime; u8 pmk_reauth_threshold; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj)}(hhh](j)}(h,``bssid`` The AP's BSSID (may be ``NULL``). h](j)}(h ``bssid``h]j)}(hjh]hbssid}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)#}(h!The AP's BSSID (may be ``NULL``).h](hThe AP’s BSSID (may be }(hj7hhhNhNubj)}(h``NULL``h]hNULL}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubh).}(hj7hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj3hM hj4ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj3hM hjubj)}(h+``pmkid`` The identifier to refer a PMKSA. h](j)}(h ``pmkid``h]j)}(hjih]hpmkid}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcubj6)}(hhh]h)}(h The identifier to refer a PMKSA.h]h The identifier to refer a PMKSA.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~hM hjubah}(h]h ]h"]h$]h&]uh1j5hjcubeh}(h]h ]h"]h$]h&]uh1jhj~hM hjubj)}(h{``pmk`` The PMK for the PMKSA identified by **pmkid**. This is used for key derivation by a FILS STA. Otherwise, ``NULL``. h](j)}(h``pmk``h]j)}(hjh]hpmk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hrThe PMK for the PMKSA identified by **pmkid**. This is used for key derivation by a FILS STA. Otherwise, ``NULL``.h](h$The PMK for the PMKSA identified by }(hjhhhNhNubj)}(h **pmkid**h]hpmkid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh<. This is used for key derivation by a FILS STA. Otherwise, }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h{``pmk_len`` Length of the **pmk**. The length of **pmk** can differ depending on the hash algorithm used to generate this. h](j)}(h ``pmk_len``h]j)}(hjh]hpmk_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hnLength of the **pmk**. The length of **pmk** can differ depending on the hash algorithm used to generate this.h](hLength of the }(hjhhhNhNubj)}(h**pmk**h]hpmk}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh. The length of }(hjhhhNhNubj)}(h**pmk**h]hpmk}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubhB can differ depending on the hash algorithm used to generate this.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hs``ssid`` SSID to specify the ESS within which a PMKSA is valid when using FILS cache identifier (may be ``NULL``). h](j)}(h``ssid``h]j)}(hj^h]hssid}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjXubj6)}(hhh]h)}(hiSSID to specify the ESS within which a PMKSA is valid when using FILS cache identifier (may be ``NULL``).h](h_SSID to specify the ESS within which a PMKSA is valid when using FILS cache identifier (may be }(hjwhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubh).}(hjwhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjtubah}(h]h ]h"]h$]h&]uh1j5hjXubeh}(h]h ]h"]h$]h&]uh1jhjshM hjubj)}(h/``ssid_len`` Length of the **ssid** in octets. h](j)}(h ``ssid_len``h]j)}(hjh]hssid_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h!Length of the **ssid** in octets.h](hLength of the }(hjhhhNhNubj)}(h**ssid**h]hssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh in octets.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``cache_id`` 2-octet cache identifier advertized by a FILS AP identifying the scope of PMKSA. This is valid only if **ssid_len** is non-zero (may be ``NULL``). h](j)}(h ``cache_id``h]j)}(hjh]hcache_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h2-octet cache identifier advertized by a FILS AP identifying the scope of PMKSA. This is valid only if **ssid_len** is non-zero (may be ``NULL``).h](hg2-octet cache identifier advertized by a FILS AP identifying the scope of PMKSA. This is valid only if }(hjhhhNhNubj)}(h **ssid_len**h]hssid_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh is non-zero (may be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh).}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubj)}(hXC``pmk_lifetime`` Maximum lifetime for PMKSA in seconds (dot11RSNAConfigPMKLifetime) or 0 if not specified. The configured PMKSA must not be used for PMKSA caching after expiration and any keys derived from this PMK become invalid on expiration, i.e., the current association must be dropped if the PMK used for it expires. h](j)}(h``pmk_lifetime``h]j)}(hjSh]h pmk_lifetime}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjMubj6)}(hhh]h)}(hX1Maximum lifetime for PMKSA in seconds (dot11RSNAConfigPMKLifetime) or 0 if not specified. The configured PMKSA must not be used for PMKSA caching after expiration and any keys derived from this PMK become invalid on expiration, i.e., the current association must be dropped if the PMK used for it expires.h]hX1Maximum lifetime for PMKSA in seconds (dot11RSNAConfigPMKLifetime) or 0 if not specified. The configured PMKSA must not be used for PMKSA caching after expiration and any keys derived from this PMK become invalid on expiration, i.e., the current association must be dropped if the PMK used for it expires.}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjiubah}(h]h ]h"]h$]h&]uh1j5hjMubeh}(h]h ]h"]h$]h&]uh1jhjhhM hjubj)}(hX\``pmk_reauth_threshold`` Threshold time for reauthentication (percentage of PMK lifetime, dot11RSNAConfigPMKReauthThreshold) or 0 if not specified. Drivers are expected to trigger a full authentication instead of using this PMKSA for caching when reassociating to a new BSS after this threshold to generate a new PMK before the current one expires.h](j)}(h``pmk_reauth_threshold``h]j)}(hjh]hpmk_reauth_threshold}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hXCThreshold time for reauthentication (percentage of PMK lifetime, dot11RSNAConfigPMKReauthThreshold) or 0 if not specified. Drivers are expected to trigger a full authentication instead of using this PMKSA for caching when reassociating to a new BSS after this threshold to generate a new PMK before the current one expires.h]hXCThreshold time for reauthentication (percentage of PMK lifetime, dot11RSNAConfigPMKReauthThreshold) or 0 if not specified. Drivers are expected to trigger a full authentication instead of using this PMKSA for caching when reassociating to a new BSS after this threshold to generate a new PMK before the current one expires.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubh)}(hIThis structure is passed to the set/del_pmksa() method for PMKSA caching.h]hIThis structure is passed to the set/del_pmksa() method for PMKSA caching.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_ops (C struct)c.cfg80211_opshNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(h cfg80211_opsh]jo)}(hstruct cfg80211_opsh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhjhM ubj)}(h cfg80211_opsh]j)}(hjh]h cfg80211_ops}(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj*ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj hhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM hjhhubj)}(hhh]h)}(h.backend description for wireless configurationh]h.backend description for wireless configuration}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjMhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjhjjhjjjuh1jchhhj^bhNhNubj)}(hX**Definition**:: struct cfg80211_ops { int (*suspend)(struct wiphy *wiphy, struct cfg80211_wowlan *wow); int (*resume)(struct wiphy *wiphy); void (*set_wakeup)(struct wiphy *wiphy, bool enabled); struct wireless_dev * (*add_virtual_intf)(struct wiphy *wiphy, const char *name, unsigned char name_assign_type, enum nl80211_iftype type, struct vif_params *params); int (*del_virtual_intf)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*change_virtual_intf)(struct wiphy *wiphy, struct net_device *dev, enum nl80211_iftype type, struct vif_params *params); int (*add_intf_link)(struct wiphy *wiphy, struct wireless_dev *wdev, unsigned int link_id); void (*del_intf_link)(struct wiphy *wiphy, struct wireless_dev *wdev, unsigned int link_id); int (*add_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index, bool pairwise, const u8 *mac_addr, struct key_params *params); int (*get_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index, bool pairwise, const u8 *mac_addr, void *cookie, void (*callback)(void *cookie, struct key_params*)); int (*del_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index, bool pairwise, const u8 *mac_addr); int (*set_default_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index, bool unicast, bool multicast); int (*set_default_mgmt_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index); int (*set_default_beacon_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index); int (*start_ap)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ap_settings *settings); int (*change_beacon)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ap_update *info); int (*stop_ap)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id); int (*add_station)(struct wiphy *wiphy, struct net_device *dev, const u8 *mac, struct station_parameters *params); int (*del_station)(struct wiphy *wiphy, struct net_device *dev, struct station_del_parameters *params); int (*change_station)(struct wiphy *wiphy, struct net_device *dev, const u8 *mac, struct station_parameters *params); int (*get_station)(struct wiphy *wiphy, struct net_device *dev, const u8 *mac, struct station_info *sinfo); int (*dump_station)(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *mac, struct station_info *sinfo); int (*add_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst, const u8 *next_hop); int (*del_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst); int (*change_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst, const u8 *next_hop); int (*get_mpath)(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *next_hop, struct mpath_info *pinfo); int (*dump_mpath)(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *next_hop, struct mpath_info *pinfo); int (*get_mpp)(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *mpp, struct mpath_info *pinfo); int (*dump_mpp)(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *mpp, struct mpath_info *pinfo); int (*get_mesh_config)(struct wiphy *wiphy, struct net_device *dev, struct mesh_config *conf); int (*update_mesh_config)(struct wiphy *wiphy, struct net_device *dev, u32 mask, const struct mesh_config *nconf); int (*join_mesh)(struct wiphy *wiphy, struct net_device *dev, const struct mesh_config *conf, const struct mesh_setup *setup); int (*leave_mesh)(struct wiphy *wiphy, struct net_device *dev); int (*join_ocb)(struct wiphy *wiphy, struct net_device *dev, struct ocb_setup *setup); int (*leave_ocb)(struct wiphy *wiphy, struct net_device *dev); int (*change_bss)(struct wiphy *wiphy, struct net_device *dev, struct bss_parameters *params); void (*inform_bss)(struct wiphy *wiphy, struct cfg80211_bss *bss, const struct cfg80211_bss_ies *ies, void *data); int (*set_txq_params)(struct wiphy *wiphy, struct net_device *dev, struct ieee80211_txq_params *params); int (*libertas_set_mesh_channel)(struct wiphy *wiphy, struct net_device *dev, struct ieee80211_channel *chan); int (*set_monitor_channel)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_chan_def *chandef); int (*scan)(struct wiphy *wiphy, struct cfg80211_scan_request *request); void (*abort_scan)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*auth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_auth_request *req); int (*assoc)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_assoc_request *req); int (*deauth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_deauth_request *req); int (*disassoc)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_disassoc_request *req); int (*connect)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_connect_params *sme); int (*update_connect_params)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_connect_params *sme, u32 changed); int (*disconnect)(struct wiphy *wiphy, struct net_device *dev, u16 reason_code); int (*join_ibss)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ibss_params *params); int (*leave_ibss)(struct wiphy *wiphy, struct net_device *dev); int (*set_mcast_rate)(struct wiphy *wiphy, struct net_device *dev, int rate[NUM_NL80211_BANDS]); int (*set_wiphy_params)(struct wiphy *wiphy, int radio_idx, u32 changed); int (*set_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, int radio_idx, enum nl80211_tx_power_setting type, int mbm); int (*get_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, int radio_idx, unsigned int link_id, int *dbm); void (*rfkill_poll)(struct wiphy *wiphy); #ifdef CONFIG_NL80211_TESTMODE; int (*testmode_cmd)(struct wiphy *wiphy, struct wireless_dev *wdev, void *data, int len); int (*testmode_dump)(struct wiphy *wiphy, struct sk_buff *skb, struct netlink_callback *cb, void *data, int len); #endif; int (*set_bitrate_mask)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id, const u8 *peer, const struct cfg80211_bitrate_mask *mask); int (*dump_survey)(struct wiphy *wiphy, struct net_device *netdev, int idx, struct survey_info *info); int (*set_pmksa)(struct wiphy *wiphy, struct net_device *netdev, struct cfg80211_pmksa *pmksa); int (*del_pmksa)(struct wiphy *wiphy, struct net_device *netdev, struct cfg80211_pmksa *pmksa); int (*flush_pmksa)(struct wiphy *wiphy, struct net_device *netdev); int (*remain_on_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, struct ieee80211_channel *chan, unsigned int duration, u64 *cookie); int (*cancel_remain_on_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*mgmt_tx)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_mgmt_tx_params *params, u64 *cookie); int (*mgmt_tx_cancel_wait)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*set_power_mgmt)(struct wiphy *wiphy, struct net_device *dev, bool enabled, int timeout); int (*set_cqm_rssi_config)(struct wiphy *wiphy, struct net_device *dev, s32 rssi_thold, u32 rssi_hyst); int (*set_cqm_rssi_range_config)(struct wiphy *wiphy, struct net_device *dev, s32 rssi_low, s32 rssi_high); int (*set_cqm_txe_config)(struct wiphy *wiphy, struct net_device *dev, u32 rate, u32 pkts, u32 intvl); void (*update_mgmt_frame_registrations)(struct wiphy *wiphy, struct wireless_dev *wdev, struct mgmt_frame_regs *upd); int (*set_antenna)(struct wiphy *wiphy, int radio_idx, u32 tx_ant, u32 rx_ant); int (*get_antenna)(struct wiphy *wiphy, int radio_idx, u32 *tx_ant, u32 *rx_ant); int (*sched_scan_start)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_sched_scan_request *request); int (*sched_scan_stop)(struct wiphy *wiphy, struct net_device *dev, u64 reqid); int (*set_rekey_data)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_gtk_rekey_data *data); int (*tdls_mgmt)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, int link_id, u8 action_code, u8 dialog_token, u16 status_code, u32 peer_capability, bool initiator, const u8 *buf, size_t len); int (*tdls_oper)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, enum nl80211_tdls_operation oper); int (*probe_client)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, u64 *cookie); int (*set_noack_map)(struct wiphy *wiphy, struct net_device *dev, u16 noack_map); int (*get_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, unsigned int link_id, struct cfg80211_chan_def *chandef); int (*start_p2p_device)(struct wiphy *wiphy, struct wireless_dev *wdev); void (*stop_p2p_device)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*set_mac_acl)(struct wiphy *wiphy, struct net_device *dev, const struct cfg80211_acl_data *params); int (*start_radar_detection)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_chan_def *chandef, u32 cac_time_ms, int link_id); void (*end_cac)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id); int (*update_ft_ies)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_update_ft_ies_params *ftie); int (*crit_proto_start)(struct wiphy *wiphy, struct wireless_dev *wdev, enum nl80211_crit_proto_id protocol, u16 duration); void (*crit_proto_stop)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*set_coalesce)(struct wiphy *wiphy, struct cfg80211_coalesce *coalesce); int (*channel_switch)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_csa_settings *params); int (*set_qos_map)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_qos_map *qos_map); int (*set_ap_chanwidth)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id, struct cfg80211_chan_def *chandef); int (*add_tx_ts)(struct wiphy *wiphy, struct net_device *dev, u8 tsid, const u8 *peer, u8 user_prio, u16 admitted_time); int (*del_tx_ts)(struct wiphy *wiphy, struct net_device *dev, u8 tsid, const u8 *peer); int (*tdls_channel_switch)(struct wiphy *wiphy, struct net_device *dev, const u8 *addr, u8 oper_class, struct cfg80211_chan_def *chandef); void (*tdls_cancel_channel_switch)(struct wiphy *wiphy, struct net_device *dev, const u8 *addr); int (*start_nan)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_conf *conf); void (*stop_nan)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*add_nan_func)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_func *nan_func); void (*del_nan_func)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*nan_change_conf)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_conf *conf, u32 changes); int (*set_multicast_to_unicast)(struct wiphy *wiphy, struct net_device *dev, const bool enabled); int (*get_txq_stats)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_txq_stats *txqstats); int (*set_pmk)(struct wiphy *wiphy, struct net_device *dev, const struct cfg80211_pmk_conf *conf); int (*del_pmk)(struct wiphy *wiphy, struct net_device *dev, const u8 *aa); int (*external_auth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_external_auth_params *params); int (*tx_control_port)(struct wiphy *wiphy, struct net_device *dev, const u8 *buf, size_t len, const u8 *dest, const __be16 proto, const bool noencrypt, int link_id, u64 *cookie); int (*get_ftm_responder_stats)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ftm_responder_stats *ftm_stats); int (*start_pmsr)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_pmsr_request *request); void (*abort_pmsr)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_pmsr_request *request); int (*update_owe_info)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_update_owe_info *owe_info); int (*probe_mesh_link)(struct wiphy *wiphy, struct net_device *dev, const u8 *buf, size_t len); int (*set_tid_config)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_tid_config *tid_conf); int (*reset_tid_config)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, u8 tids); int (*set_sar_specs)(struct wiphy *wiphy, struct cfg80211_sar_specs *sar); int (*color_change)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_color_change_settings *params); int (*set_fils_aad)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_fils_aad *fils_aad); int (*set_radar_background)(struct wiphy *wiphy, struct cfg80211_chan_def *chandef); int (*add_link_station)(struct wiphy *wiphy, struct net_device *dev, struct link_station_parameters *params); int (*mod_link_station)(struct wiphy *wiphy, struct net_device *dev, struct link_station_parameters *params); int (*del_link_station)(struct wiphy *wiphy, struct net_device *dev, struct link_station_del_parameters *params); int (*set_hw_timestamp)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_set_hw_timestamp *hwts); int (*set_ttlm)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ttlm_params *params); u32 (*get_radio_mask)(struct wiphy *wiphy, struct net_device *dev); int (*assoc_ml_reconf)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ml_reconf_req *req); int (*set_epcs)(struct wiphy *wiphy, struct net_device *dev, bool val); }; **Members** ``suspend`` wiphy device needs to be suspended. The variable **wow** will be ``NULL`` or contain the enabled Wake-on-Wireless triggers that are configured for the device. ``resume`` wiphy device needs to be resumed ``set_wakeup`` Called when WoWLAN is enabled/disabled, use this callback to call device_set_wakeup_enable() to enable/disable wakeup from the device. ``add_virtual_intf`` create a new virtual interface with the given name, must set the struct wireless_dev's iftype. Beware: You must create the new netdev in the wiphy's network namespace! Returns the struct wireless_dev, or an ERR_PTR. For P2P device wdevs, the driver must also set the address member in the wdev. This additionally holds the RTNL to be able to do netdev changes. ``del_virtual_intf`` remove the virtual interface This additionally holds the RTNL to be able to do netdev changes. ``change_virtual_intf`` change type/configuration of virtual interface, keep the struct wireless_dev's iftype updated. This additionally holds the RTNL to be able to do netdev changes. ``add_intf_link`` Add a new MLO link to the given interface. Note that the wdev->link[] data structure has been updated, so the new link address is available. ``del_intf_link`` Remove an MLO link from the given interface. ``add_key`` add a key with the given parameters. **mac_addr** will be ``NULL`` when adding a group key. **link_id** will be -1 for non-MLO connection. For MLO connection, **link_id** will be >= 0 for group key and -1 for pairwise key, **mac_addr** will be peer's MLD address for MLO pairwise key. ``get_key`` get information about the key with the given parameters. **mac_addr** will be ``NULL`` when requesting information for a group key. All pointers given to the **callback** function need not be valid after it returns. This function should return an error if it is not possible to retrieve the key, -ENOENT if it doesn't exist. **link_id** will be -1 for non-MLO connection. For MLO connection, **link_id** will be >= 0 for group key and -1 for pairwise key, **mac_addr** will be peer's MLD address for MLO pairwise key. ``del_key`` remove a key given the **mac_addr** (``NULL`` for a group key) and **key_index**, return -ENOENT if the key doesn't exist. **link_id** will be -1 for non-MLO connection. For MLO connection, **link_id** will be >= 0 for group key and -1 for pairwise key, **mac_addr** will be peer's MLD address for MLO pairwise key. ``set_default_key`` set the default key on an interface. **link_id** will be >= 0 for MLO connection and -1 for non-MLO connection. ``set_default_mgmt_key`` set the default management frame key on an interface. **link_id** will be >= 0 for MLO connection and -1 for non-MLO connection. ``set_default_beacon_key`` set the default Beacon frame key on an interface. **link_id** will be >= 0 for MLO connection and -1 for non-MLO connection. ``start_ap`` Start acting in AP mode defined by the parameters. ``change_beacon`` Change the beacon parameters for an access point mode interface. This should reject the call when AP mode wasn't started. ``stop_ap`` Stop being an AP, including stopping beaconing. ``add_station`` Add a new station. ``del_station`` Remove a station ``change_station`` Modify a given station. Note that flags changes are not much validated in cfg80211, in particular the auth/assoc/authorized flags might come to the driver in invalid combinations -- make sure to check them, also against the existing state! Drivers must call cfg80211_check_station_change() to validate the information. ``get_station`` get station information for the station identified by **mac** ``dump_station`` dump station callback -- resume dump at index **idx** ``add_mpath`` add a fixed mesh path ``del_mpath`` delete a given mesh path ``change_mpath`` change a given mesh path ``get_mpath`` get a mesh path for the given parameters ``dump_mpath`` dump mesh path callback -- resume dump at index **idx** ``get_mpp`` get a mesh proxy path for the given parameters ``dump_mpp`` dump mesh proxy path callback -- resume dump at index **idx** ``get_mesh_config`` Get the current mesh configuration ``update_mesh_config`` Update mesh parameters on a running mesh. The mask is a bitfield which tells us which parameters to set, and which to leave alone. ``join_mesh`` join the mesh network with the specified parameters (invoked with the wireless_dev mutex held) ``leave_mesh`` leave the current mesh network (invoked with the wireless_dev mutex held) ``join_ocb`` join the OCB network with the specified parameters (invoked with the wireless_dev mutex held) ``leave_ocb`` leave the current OCB network (invoked with the wireless_dev mutex held) ``change_bss`` Modify parameters for a given BSS. ``inform_bss`` Called by cfg80211 while being informed about new BSS data for every BSS found within the reported data or frame. This is called from within the cfg8011 inform_bss handlers while holding the bss_lock. The data parameter is passed through from drv_data inside struct cfg80211_inform_bss. The new IE data for the BSS is explicitly passed. ``set_txq_params`` Set TX queue parameters ``libertas_set_mesh_channel`` Only for backward compatibility for libertas, as it doesn't implement join_mesh and needs to set the channel to join the mesh instead. ``set_monitor_channel`` Set the monitor mode channel for the device. If other interfaces are active this callback should reject the configuration. If no interfaces are active or the device is down, the channel should be stored for when a monitor interface becomes active. ``scan`` Request to do a scan. If returning zero, the scan request is given the driver, and will be valid until passed to cfg80211_scan_done(). For scan results, call cfg80211_inform_bss(); you can call this outside the scan/scan_done bracket too. ``abort_scan`` Tell the driver to abort an ongoing scan. The driver shall indicate the status of the scan through cfg80211_scan_done(). ``auth`` Request to authenticate with the specified peer (invoked with the wireless_dev mutex held) ``assoc`` Request to (re)associate with the specified peer (invoked with the wireless_dev mutex held) ``deauth`` Request to deauthenticate from the specified peer (invoked with the wireless_dev mutex held) ``disassoc`` Request to disassociate from the specified peer (invoked with the wireless_dev mutex held) ``connect`` Connect to the ESS with the specified parameters. When connected, call cfg80211_connect_result()/cfg80211_connect_bss() with status code ``WLAN_STATUS_SUCCESS``. If the connection fails for some reason, call cfg80211_connect_result()/cfg80211_connect_bss() with the status code from the AP or cfg80211_connect_timeout() if no frame with status code was received. The driver is allowed to roam to other BSSes within the ESS when the other BSS matches the connect parameters. When such roaming is initiated by the driver, the driver is expected to verify that the target matches the configured security parameters and to use Reassociation Request frame instead of Association Request frame. The connect function can also be used to request the driver to perform a specific roam when connected to an ESS. In that case, the prev_bssid parameter is set to the BSSID of the currently associated BSS as an indication of requesting reassociation. In both the driver-initiated and new connect() call initiated roaming cases, the result of roaming is indicated with a call to cfg80211_roamed(). (invoked with the wireless_dev mutex held) ``update_connect_params`` Update the connect parameters while connected to a BSS. The updated parameters can be used by driver/firmware for subsequent BSS selection (roaming) decisions and to form the Authentication/(Re)Association Request frames. This call does not request an immediate disassociation or reassociation with the current BSS, i.e., this impacts only subsequent (re)associations. The bits in changed are defined in :c:type:`enum cfg80211_connect_params_changed `. (invoked with the wireless_dev mutex held) ``disconnect`` Disconnect from the BSS/ESS or stop connection attempts if connection is in progress. Once done, call cfg80211_disconnected() in case connection was already established (invoked with the wireless_dev mutex held), otherwise call cfg80211_connect_timeout(). ``join_ibss`` Join the specified IBSS (or create if necessary). Once done, call cfg80211_ibss_joined(), also call that function when changing BSSID due to a merge. (invoked with the wireless_dev mutex held) ``leave_ibss`` Leave the IBSS. (invoked with the wireless_dev mutex held) ``set_mcast_rate`` Set the specified multicast rate (only if vif is in ADHOC or MESH mode) ``set_wiphy_params`` Notify that wiphy parameters have changed; **changed** bitfield (see :c:type:`enum wiphy_params_flags `) describes which values have changed. The actual parameter values are available in struct wiphy. If returning an error, no value should be changed. ``set_tx_power`` set the transmit power according to the parameters, the power passed is in mBm, to get dBm use MBM_TO_DBM(). The wdev may be ``NULL`` if power was set for the wiphy, and will always be ``NULL`` unless the driver supports per-vif TX power (as advertised by the nl80211 feature flag.) ``get_tx_power`` store the current TX power into the dbm variable; return 0 if successful ``rfkill_poll`` polls the hw rfkill line, use cfg80211 reporting functions to adjust rfkill hw state ``testmode_cmd`` run a test mode command; **wdev** may be ``NULL`` ``testmode_dump`` Implement a test mode dump. The cb->args[2] and up may be used by the function, but 0 and 1 must not be touched. Additionally, return error codes other than -ENOBUFS and -ENOENT will terminate the dump and return to userspace with an error, so be careful. If any data was passed in from userspace then the data/len arguments will be present and point to the data contained in ``NL80211_ATTR_TESTDATA``. ``set_bitrate_mask`` set the bitrate mask configuration ``dump_survey`` get site survey information. ``set_pmksa`` Cache a PMKID for a BSSID. This is mostly useful for fullmac devices running firmwares capable of generating the (re) association RSN IE. It allows for faster roaming between WPA2 BSSIDs. ``del_pmksa`` Delete a cached PMKID. ``flush_pmksa`` Flush all cached PMKIDs. ``remain_on_channel`` Request the driver to remain awake on the specified channel for the specified duration to complete an off-channel operation (e.g., public action frame exchange). When the driver is ready on the requested channel, it must indicate this with an event notification by calling cfg80211_ready_on_channel(). ``cancel_remain_on_channel`` Cancel an on-going remain-on-channel operation. This allows the operation to be terminated prior to timeout based on the duration value. ``mgmt_tx`` Transmit a management frame. ``mgmt_tx_cancel_wait`` Cancel the wait time from transmitting a management frame on another channel ``set_power_mgmt`` Configure WLAN power management. A timeout value of -1 allows the driver to adjust the dynamic ps timeout value. ``set_cqm_rssi_config`` Configure connection quality monitor RSSI threshold. After configuration, the driver should (soon) send an event indicating the current level is above/below the configured threshold; this may need some care when the configuration is changed (without first being disabled.) ``set_cqm_rssi_range_config`` Configure two RSSI thresholds in the connection quality monitor. An event is to be sent only when the signal level is found to be outside the two values. The driver should set ``NL80211_EXT_FEATURE_CQM_RSSI_LIST`` if this method is implemented. If it is provided then there's no point providing **set_cqm_rssi_config**. ``set_cqm_txe_config`` Configure connection quality monitor TX error thresholds. ``update_mgmt_frame_registrations`` Notify the driver that management frame registrations were updated. The callback is allowed to sleep. ``set_antenna`` Set antenna configuration (tx_ant, rx_ant) on the device. Parameters are bitmaps of allowed antennas to use for TX/RX. Drivers may reject TX/RX mask combinations they cannot support by returning -EINVAL (also see nl80211.h **NL80211_ATTR_WIPHY_ANTENNA_TX**). ``get_antenna`` Get current antenna configuration from device (tx_ant, rx_ant). ``sched_scan_start`` Tell the driver to start a scheduled scan. ``sched_scan_stop`` Tell the driver to stop an ongoing scheduled scan with given request id. This call must stop the scheduled scan and be ready for starting a new one before it returns, i.e. **sched_scan_start** may be called immediately after that again and should not fail in that case. The driver should not call cfg80211_sched_scan_stopped() for a requested stop (when this method returns 0). ``set_rekey_data`` give the data necessary for GTK rekeying to the driver ``tdls_mgmt`` Transmit a TDLS management frame. ``tdls_oper`` Perform a high-level TDLS operation (e.g. TDLS link setup). ``probe_client`` probe an associated client, must return a cookie that it later passes to cfg80211_probe_status(). ``set_noack_map`` Set the NoAck Map for the TIDs. ``get_channel`` Get the current operating channel for the virtual interface. For monitor interfaces, it should return ``NULL`` unless there's a single current monitoring channel. ``start_p2p_device`` Start the given P2P device. ``stop_p2p_device`` Stop the given P2P device. ``set_mac_acl`` Sets MAC address control list in AP and P2P GO mode. Parameters include ACL policy, an array of MAC address of stations and the number of MAC addresses. If there is already a list in driver this new list replaces the existing one. Driver has to clear its ACL when number of MAC addresses entries is passed as 0. Drivers which advertise the support for MAC based ACL have to implement this callback. ``start_radar_detection`` Start radar detection in the driver. ``end_cac`` End running CAC, probably because a related CAC was finished on another phy. ``update_ft_ies`` Provide updated Fast BSS Transition information to the driver. If the SME is in the driver/firmware, this information can be used in building Authentication and Reassociation Request frames. ``crit_proto_start`` Indicates a critical protocol needs more link reliability for a given duration (milliseconds). The protocol is provided so the driver can take the most appropriate actions. ``crit_proto_stop`` Indicates critical protocol no longer needs increased link reliability. This operation can not fail. ``set_coalesce`` Set coalesce parameters. ``channel_switch`` initiate channel-switch procedure (with CSA). Driver is responsible for veryfing if the switch is possible. Since this is inherently tricky driver may decide to disconnect an interface later with cfg80211_stop_iface(). This doesn't mean driver can accept everything. It should do it's best to verify requests and reject them as soon as possible. ``set_qos_map`` Set QoS mapping information to the driver ``set_ap_chanwidth`` Set the AP (including P2P GO) mode channel width for the given interface This is used e.g. for dynamic HT 20/40 MHz channel width changes during the lifetime of the BSS. ``add_tx_ts`` validate (if admitted_time is 0) or add a TX TS to the device with the given parameters; action frame exchange has been handled by userspace so this just has to modify the TX path to take the TS into account. If the admitted time is 0 just validate the parameters to make sure the session can be created at all; it is valid to just always return success for that but that may result in inefficient behaviour (handshake with the peer followed by immediate teardown when the addition is later rejected) ``del_tx_ts`` remove an existing TX TS ``tdls_channel_switch`` Start channel-switching with a TDLS peer. The driver is responsible for continually initiating channel-switching operations and returning to the base channel for communication with the AP. ``tdls_cancel_channel_switch`` Stop channel-switching with a TDLS peer. Both peers must be on the base channel when the call completes. ``start_nan`` Start the NAN interface. ``stop_nan`` Stop the NAN interface. ``add_nan_func`` Add a NAN function. Returns negative value on failure. On success **nan_func** ownership is transferred to the driver and it may access it outside of the scope of this function. The driver should free the **nan_func** when no longer needed by calling cfg80211_free_nan_func(). On success the driver should assign an instance_id in the provided **nan_func**. ``del_nan_func`` Delete a NAN function. ``nan_change_conf`` changes NAN configuration. The changed parameters must be specified in **changes** (using :c:type:`enum cfg80211_nan_conf_changes `); All other parameters must be ignored. ``set_multicast_to_unicast`` configure multicast to unicast conversion for BSS ``get_txq_stats`` Get TXQ stats for interface or phy. If wdev is ``NULL``, this function should return phy stats, and interface stats otherwise. ``set_pmk`` configure the PMK to be used for offloaded 802.1X 4-Way handshake. If not deleted through **del_pmk** the PMK remains valid until disconnect upon which the driver should clear it. (invoked with the wireless_dev mutex held) ``del_pmk`` delete the previously configured PMK for the given authenticator. (invoked with the wireless_dev mutex held) ``external_auth`` indicates result of offloaded authentication processing from user space ``tx_control_port`` TX a control port frame (EAPoL). The noencrypt parameter tells the driver that the frame should not be encrypted. ``get_ftm_responder_stats`` Retrieve FTM responder statistics, if available. Statistics should be cumulative, currently no way to reset is provided. ``start_pmsr`` start peer measurement (e.g. FTM) ``abort_pmsr`` abort peer measurement ``update_owe_info`` Provide updated OWE info to driver. Driver implementing SME but offloading OWE processing to the user space will get the updated DH IE through this interface. ``probe_mesh_link`` Probe direct Mesh peer's link quality by sending data frame and overrule HWMP path selection algorithm. ``set_tid_config`` TID specific configuration, this can be peer or BSS specific This callback may sleep. ``reset_tid_config`` Reset TID specific configuration for the peer, for the given TIDs. This callback may sleep. ``set_sar_specs`` Update the SAR (TX power) settings. ``color_change`` Initiate a color change. ``set_fils_aad`` Set FILS AAD data to the AP driver so that the driver can use those to decrypt (Re)Association Request and encrypt (Re)Association Response frame. ``set_radar_background`` Configure dedicated offchannel chain available for radar/CAC detection on some hw. This chain can't be used to transmit or receive frames and it is bounded to a running wdev. Background radar/CAC detection allows to avoid the CAC downtime switching to a different channel during CAC detection on the selected radar channel. The caller is expected to set chandef pointer to NULL in order to disable background CAC/radar detection. ``add_link_station`` Add a link to a station. ``mod_link_station`` Modify a link of a station. ``del_link_station`` Remove a link of a station. ``set_hw_timestamp`` Enable/disable HW timestamping of TM/FTM frames. ``set_ttlm`` set the TID to link mapping. ``get_radio_mask`` get bitmask of radios in use. (invoked with the wiphy mutex held) ``assoc_ml_reconf`` Request a non-AP MLO connection to perform ML reconfiguration, i.e., add and/or remove links to/from the association using ML reconfiguration action frames. Successfully added links will be added to the set of valid links. Successfully removed links will be removed from the set of valid links. The driver must indicate removed links by calling cfg80211_links_removed() and added links by calling cfg80211_mlo_reconf_add_done(). When calling cfg80211_mlo_reconf_add_done() the bss pointer must be given for each link for which MLO reconfiguration 'add' operation was requested. ``set_epcs`` Enable/Disable EPCS for station mode.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1hhjpubh:}(hjphhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjlubj( )}(hX]5struct cfg80211_ops { int (*suspend)(struct wiphy *wiphy, struct cfg80211_wowlan *wow); int (*resume)(struct wiphy *wiphy); void (*set_wakeup)(struct wiphy *wiphy, bool enabled); struct wireless_dev * (*add_virtual_intf)(struct wiphy *wiphy, const char *name, unsigned char name_assign_type, enum nl80211_iftype type, struct vif_params *params); int (*del_virtual_intf)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*change_virtual_intf)(struct wiphy *wiphy, struct net_device *dev, enum nl80211_iftype type, struct vif_params *params); int (*add_intf_link)(struct wiphy *wiphy, struct wireless_dev *wdev, unsigned int link_id); void (*del_intf_link)(struct wiphy *wiphy, struct wireless_dev *wdev, unsigned int link_id); int (*add_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index, bool pairwise, const u8 *mac_addr, struct key_params *params); int (*get_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index, bool pairwise, const u8 *mac_addr, void *cookie, void (*callback)(void *cookie, struct key_params*)); int (*del_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index, bool pairwise, const u8 *mac_addr); int (*set_default_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index, bool unicast, bool multicast); int (*set_default_mgmt_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index); int (*set_default_beacon_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index); int (*start_ap)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ap_settings *settings); int (*change_beacon)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ap_update *info); int (*stop_ap)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id); int (*add_station)(struct wiphy *wiphy, struct net_device *dev, const u8 *mac, struct station_parameters *params); int (*del_station)(struct wiphy *wiphy, struct net_device *dev, struct station_del_parameters *params); int (*change_station)(struct wiphy *wiphy, struct net_device *dev, const u8 *mac, struct station_parameters *params); int (*get_station)(struct wiphy *wiphy, struct net_device *dev, const u8 *mac, struct station_info *sinfo); int (*dump_station)(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *mac, struct station_info *sinfo); int (*add_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst, const u8 *next_hop); int (*del_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst); int (*change_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst, const u8 *next_hop); int (*get_mpath)(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *next_hop, struct mpath_info *pinfo); int (*dump_mpath)(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *next_hop, struct mpath_info *pinfo); int (*get_mpp)(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *mpp, struct mpath_info *pinfo); int (*dump_mpp)(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *mpp, struct mpath_info *pinfo); int (*get_mesh_config)(struct wiphy *wiphy, struct net_device *dev, struct mesh_config *conf); int (*update_mesh_config)(struct wiphy *wiphy, struct net_device *dev, u32 mask, const struct mesh_config *nconf); int (*join_mesh)(struct wiphy *wiphy, struct net_device *dev, const struct mesh_config *conf, const struct mesh_setup *setup); int (*leave_mesh)(struct wiphy *wiphy, struct net_device *dev); int (*join_ocb)(struct wiphy *wiphy, struct net_device *dev, struct ocb_setup *setup); int (*leave_ocb)(struct wiphy *wiphy, struct net_device *dev); int (*change_bss)(struct wiphy *wiphy, struct net_device *dev, struct bss_parameters *params); void (*inform_bss)(struct wiphy *wiphy, struct cfg80211_bss *bss, const struct cfg80211_bss_ies *ies, void *data); int (*set_txq_params)(struct wiphy *wiphy, struct net_device *dev, struct ieee80211_txq_params *params); int (*libertas_set_mesh_channel)(struct wiphy *wiphy, struct net_device *dev, struct ieee80211_channel *chan); int (*set_monitor_channel)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_chan_def *chandef); int (*scan)(struct wiphy *wiphy, struct cfg80211_scan_request *request); void (*abort_scan)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*auth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_auth_request *req); int (*assoc)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_assoc_request *req); int (*deauth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_deauth_request *req); int (*disassoc)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_disassoc_request *req); int (*connect)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_connect_params *sme); int (*update_connect_params)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_connect_params *sme, u32 changed); int (*disconnect)(struct wiphy *wiphy, struct net_device *dev, u16 reason_code); int (*join_ibss)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ibss_params *params); int (*leave_ibss)(struct wiphy *wiphy, struct net_device *dev); int (*set_mcast_rate)(struct wiphy *wiphy, struct net_device *dev, int rate[NUM_NL80211_BANDS]); int (*set_wiphy_params)(struct wiphy *wiphy, int radio_idx, u32 changed); int (*set_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, int radio_idx, enum nl80211_tx_power_setting type, int mbm); int (*get_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, int radio_idx, unsigned int link_id, int *dbm); void (*rfkill_poll)(struct wiphy *wiphy); #ifdef CONFIG_NL80211_TESTMODE; int (*testmode_cmd)(struct wiphy *wiphy, struct wireless_dev *wdev, void *data, int len); int (*testmode_dump)(struct wiphy *wiphy, struct sk_buff *skb, struct netlink_callback *cb, void *data, int len); #endif; int (*set_bitrate_mask)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id, const u8 *peer, const struct cfg80211_bitrate_mask *mask); int (*dump_survey)(struct wiphy *wiphy, struct net_device *netdev, int idx, struct survey_info *info); int (*set_pmksa)(struct wiphy *wiphy, struct net_device *netdev, struct cfg80211_pmksa *pmksa); int (*del_pmksa)(struct wiphy *wiphy, struct net_device *netdev, struct cfg80211_pmksa *pmksa); int (*flush_pmksa)(struct wiphy *wiphy, struct net_device *netdev); int (*remain_on_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, struct ieee80211_channel *chan, unsigned int duration, u64 *cookie); int (*cancel_remain_on_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*mgmt_tx)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_mgmt_tx_params *params, u64 *cookie); int (*mgmt_tx_cancel_wait)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*set_power_mgmt)(struct wiphy *wiphy, struct net_device *dev, bool enabled, int timeout); int (*set_cqm_rssi_config)(struct wiphy *wiphy, struct net_device *dev, s32 rssi_thold, u32 rssi_hyst); int (*set_cqm_rssi_range_config)(struct wiphy *wiphy, struct net_device *dev, s32 rssi_low, s32 rssi_high); int (*set_cqm_txe_config)(struct wiphy *wiphy, struct net_device *dev, u32 rate, u32 pkts, u32 intvl); void (*update_mgmt_frame_registrations)(struct wiphy *wiphy, struct wireless_dev *wdev, struct mgmt_frame_regs *upd); int (*set_antenna)(struct wiphy *wiphy, int radio_idx, u32 tx_ant, u32 rx_ant); int (*get_antenna)(struct wiphy *wiphy, int radio_idx, u32 *tx_ant, u32 *rx_ant); int (*sched_scan_start)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_sched_scan_request *request); int (*sched_scan_stop)(struct wiphy *wiphy, struct net_device *dev, u64 reqid); int (*set_rekey_data)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_gtk_rekey_data *data); int (*tdls_mgmt)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, int link_id, u8 action_code, u8 dialog_token, u16 status_code, u32 peer_capability, bool initiator, const u8 *buf, size_t len); int (*tdls_oper)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, enum nl80211_tdls_operation oper); int (*probe_client)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, u64 *cookie); int (*set_noack_map)(struct wiphy *wiphy, struct net_device *dev, u16 noack_map); int (*get_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, unsigned int link_id, struct cfg80211_chan_def *chandef); int (*start_p2p_device)(struct wiphy *wiphy, struct wireless_dev *wdev); void (*stop_p2p_device)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*set_mac_acl)(struct wiphy *wiphy, struct net_device *dev, const struct cfg80211_acl_data *params); int (*start_radar_detection)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_chan_def *chandef, u32 cac_time_ms, int link_id); void (*end_cac)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id); int (*update_ft_ies)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_update_ft_ies_params *ftie); int (*crit_proto_start)(struct wiphy *wiphy, struct wireless_dev *wdev, enum nl80211_crit_proto_id protocol, u16 duration); void (*crit_proto_stop)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*set_coalesce)(struct wiphy *wiphy, struct cfg80211_coalesce *coalesce); int (*channel_switch)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_csa_settings *params); int (*set_qos_map)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_qos_map *qos_map); int (*set_ap_chanwidth)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id, struct cfg80211_chan_def *chandef); int (*add_tx_ts)(struct wiphy *wiphy, struct net_device *dev, u8 tsid, const u8 *peer, u8 user_prio, u16 admitted_time); int (*del_tx_ts)(struct wiphy *wiphy, struct net_device *dev, u8 tsid, const u8 *peer); int (*tdls_channel_switch)(struct wiphy *wiphy, struct net_device *dev, const u8 *addr, u8 oper_class, struct cfg80211_chan_def *chandef); void (*tdls_cancel_channel_switch)(struct wiphy *wiphy, struct net_device *dev, const u8 *addr); int (*start_nan)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_conf *conf); void (*stop_nan)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*add_nan_func)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_func *nan_func); void (*del_nan_func)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*nan_change_conf)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_conf *conf, u32 changes); int (*set_multicast_to_unicast)(struct wiphy *wiphy, struct net_device *dev, const bool enabled); int (*get_txq_stats)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_txq_stats *txqstats); int (*set_pmk)(struct wiphy *wiphy, struct net_device *dev, const struct cfg80211_pmk_conf *conf); int (*del_pmk)(struct wiphy *wiphy, struct net_device *dev, const u8 *aa); int (*external_auth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_external_auth_params *params); int (*tx_control_port)(struct wiphy *wiphy, struct net_device *dev, const u8 *buf, size_t len, const u8 *dest, const __be16 proto, const bool noencrypt, int link_id, u64 *cookie); int (*get_ftm_responder_stats)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ftm_responder_stats *ftm_stats); int (*start_pmsr)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_pmsr_request *request); void (*abort_pmsr)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_pmsr_request *request); int (*update_owe_info)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_update_owe_info *owe_info); int (*probe_mesh_link)(struct wiphy *wiphy, struct net_device *dev, const u8 *buf, size_t len); int (*set_tid_config)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_tid_config *tid_conf); int (*reset_tid_config)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, u8 tids); int (*set_sar_specs)(struct wiphy *wiphy, struct cfg80211_sar_specs *sar); int (*color_change)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_color_change_settings *params); int (*set_fils_aad)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_fils_aad *fils_aad); int (*set_radar_background)(struct wiphy *wiphy, struct cfg80211_chan_def *chandef); int (*add_link_station)(struct wiphy *wiphy, struct net_device *dev, struct link_station_parameters *params); int (*mod_link_station)(struct wiphy *wiphy, struct net_device *dev, struct link_station_parameters *params); int (*del_link_station)(struct wiphy *wiphy, struct net_device *dev, struct link_station_del_parameters *params); int (*set_hw_timestamp)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_set_hw_timestamp *hwts); int (*set_ttlm)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ttlm_params *params); u32 (*get_radio_mask)(struct wiphy *wiphy, struct net_device *dev); int (*assoc_ml_reconf)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ml_reconf_req *req); int (*set_epcs)(struct wiphy *wiphy, struct net_device *dev, bool val); };h]hX]5struct cfg80211_ops { int (*suspend)(struct wiphy *wiphy, struct cfg80211_wowlan *wow); int (*resume)(struct wiphy *wiphy); void (*set_wakeup)(struct wiphy *wiphy, bool enabled); struct wireless_dev * (*add_virtual_intf)(struct wiphy *wiphy, const char *name, unsigned char name_assign_type, enum nl80211_iftype type, struct vif_params *params); int (*del_virtual_intf)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*change_virtual_intf)(struct wiphy *wiphy, struct net_device *dev, enum nl80211_iftype type, struct vif_params *params); int (*add_intf_link)(struct wiphy *wiphy, struct wireless_dev *wdev, unsigned int link_id); void (*del_intf_link)(struct wiphy *wiphy, struct wireless_dev *wdev, unsigned int link_id); int (*add_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index, bool pairwise, const u8 *mac_addr, struct key_params *params); int (*get_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index, bool pairwise, const u8 *mac_addr, void *cookie, void (*callback)(void *cookie, struct key_params*)); int (*del_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index, bool pairwise, const u8 *mac_addr); int (*set_default_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index, bool unicast, bool multicast); int (*set_default_mgmt_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index); int (*set_default_beacon_key)(struct wiphy *wiphy, struct net_device *netdev, int link_id, u8 key_index); int (*start_ap)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ap_settings *settings); int (*change_beacon)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ap_update *info); int (*stop_ap)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id); int (*add_station)(struct wiphy *wiphy, struct net_device *dev, const u8 *mac, struct station_parameters *params); int (*del_station)(struct wiphy *wiphy, struct net_device *dev, struct station_del_parameters *params); int (*change_station)(struct wiphy *wiphy, struct net_device *dev, const u8 *mac, struct station_parameters *params); int (*get_station)(struct wiphy *wiphy, struct net_device *dev, const u8 *mac, struct station_info *sinfo); int (*dump_station)(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *mac, struct station_info *sinfo); int (*add_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst, const u8 *next_hop); int (*del_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst); int (*change_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst, const u8 *next_hop); int (*get_mpath)(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *next_hop, struct mpath_info *pinfo); int (*dump_mpath)(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *next_hop, struct mpath_info *pinfo); int (*get_mpp)(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *mpp, struct mpath_info *pinfo); int (*dump_mpp)(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *mpp, struct mpath_info *pinfo); int (*get_mesh_config)(struct wiphy *wiphy, struct net_device *dev, struct mesh_config *conf); int (*update_mesh_config)(struct wiphy *wiphy, struct net_device *dev, u32 mask, const struct mesh_config *nconf); int (*join_mesh)(struct wiphy *wiphy, struct net_device *dev, const struct mesh_config *conf, const struct mesh_setup *setup); int (*leave_mesh)(struct wiphy *wiphy, struct net_device *dev); int (*join_ocb)(struct wiphy *wiphy, struct net_device *dev, struct ocb_setup *setup); int (*leave_ocb)(struct wiphy *wiphy, struct net_device *dev); int (*change_bss)(struct wiphy *wiphy, struct net_device *dev, struct bss_parameters *params); void (*inform_bss)(struct wiphy *wiphy, struct cfg80211_bss *bss, const struct cfg80211_bss_ies *ies, void *data); int (*set_txq_params)(struct wiphy *wiphy, struct net_device *dev, struct ieee80211_txq_params *params); int (*libertas_set_mesh_channel)(struct wiphy *wiphy, struct net_device *dev, struct ieee80211_channel *chan); int (*set_monitor_channel)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_chan_def *chandef); int (*scan)(struct wiphy *wiphy, struct cfg80211_scan_request *request); void (*abort_scan)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*auth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_auth_request *req); int (*assoc)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_assoc_request *req); int (*deauth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_deauth_request *req); int (*disassoc)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_disassoc_request *req); int (*connect)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_connect_params *sme); int (*update_connect_params)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_connect_params *sme, u32 changed); int (*disconnect)(struct wiphy *wiphy, struct net_device *dev, u16 reason_code); int (*join_ibss)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ibss_params *params); int (*leave_ibss)(struct wiphy *wiphy, struct net_device *dev); int (*set_mcast_rate)(struct wiphy *wiphy, struct net_device *dev, int rate[NUM_NL80211_BANDS]); int (*set_wiphy_params)(struct wiphy *wiphy, int radio_idx, u32 changed); int (*set_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, int radio_idx, enum nl80211_tx_power_setting type, int mbm); int (*get_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, int radio_idx, unsigned int link_id, int *dbm); void (*rfkill_poll)(struct wiphy *wiphy); #ifdef CONFIG_NL80211_TESTMODE; int (*testmode_cmd)(struct wiphy *wiphy, struct wireless_dev *wdev, void *data, int len); int (*testmode_dump)(struct wiphy *wiphy, struct sk_buff *skb, struct netlink_callback *cb, void *data, int len); #endif; int (*set_bitrate_mask)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id, const u8 *peer, const struct cfg80211_bitrate_mask *mask); int (*dump_survey)(struct wiphy *wiphy, struct net_device *netdev, int idx, struct survey_info *info); int (*set_pmksa)(struct wiphy *wiphy, struct net_device *netdev, struct cfg80211_pmksa *pmksa); int (*del_pmksa)(struct wiphy *wiphy, struct net_device *netdev, struct cfg80211_pmksa *pmksa); int (*flush_pmksa)(struct wiphy *wiphy, struct net_device *netdev); int (*remain_on_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, struct ieee80211_channel *chan, unsigned int duration, u64 *cookie); int (*cancel_remain_on_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*mgmt_tx)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_mgmt_tx_params *params, u64 *cookie); int (*mgmt_tx_cancel_wait)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*set_power_mgmt)(struct wiphy *wiphy, struct net_device *dev, bool enabled, int timeout); int (*set_cqm_rssi_config)(struct wiphy *wiphy, struct net_device *dev, s32 rssi_thold, u32 rssi_hyst); int (*set_cqm_rssi_range_config)(struct wiphy *wiphy, struct net_device *dev, s32 rssi_low, s32 rssi_high); int (*set_cqm_txe_config)(struct wiphy *wiphy, struct net_device *dev, u32 rate, u32 pkts, u32 intvl); void (*update_mgmt_frame_registrations)(struct wiphy *wiphy, struct wireless_dev *wdev, struct mgmt_frame_regs *upd); int (*set_antenna)(struct wiphy *wiphy, int radio_idx, u32 tx_ant, u32 rx_ant); int (*get_antenna)(struct wiphy *wiphy, int radio_idx, u32 *tx_ant, u32 *rx_ant); int (*sched_scan_start)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_sched_scan_request *request); int (*sched_scan_stop)(struct wiphy *wiphy, struct net_device *dev, u64 reqid); int (*set_rekey_data)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_gtk_rekey_data *data); int (*tdls_mgmt)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, int link_id, u8 action_code, u8 dialog_token, u16 status_code, u32 peer_capability, bool initiator, const u8 *buf, size_t len); int (*tdls_oper)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, enum nl80211_tdls_operation oper); int (*probe_client)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, u64 *cookie); int (*set_noack_map)(struct wiphy *wiphy, struct net_device *dev, u16 noack_map); int (*get_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, unsigned int link_id, struct cfg80211_chan_def *chandef); int (*start_p2p_device)(struct wiphy *wiphy, struct wireless_dev *wdev); void (*stop_p2p_device)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*set_mac_acl)(struct wiphy *wiphy, struct net_device *dev, const struct cfg80211_acl_data *params); int (*start_radar_detection)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_chan_def *chandef, u32 cac_time_ms, int link_id); void (*end_cac)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id); int (*update_ft_ies)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_update_ft_ies_params *ftie); int (*crit_proto_start)(struct wiphy *wiphy, struct wireless_dev *wdev, enum nl80211_crit_proto_id protocol, u16 duration); void (*crit_proto_stop)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*set_coalesce)(struct wiphy *wiphy, struct cfg80211_coalesce *coalesce); int (*channel_switch)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_csa_settings *params); int (*set_qos_map)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_qos_map *qos_map); int (*set_ap_chanwidth)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id, struct cfg80211_chan_def *chandef); int (*add_tx_ts)(struct wiphy *wiphy, struct net_device *dev, u8 tsid, const u8 *peer, u8 user_prio, u16 admitted_time); int (*del_tx_ts)(struct wiphy *wiphy, struct net_device *dev, u8 tsid, const u8 *peer); int (*tdls_channel_switch)(struct wiphy *wiphy, struct net_device *dev, const u8 *addr, u8 oper_class, struct cfg80211_chan_def *chandef); void (*tdls_cancel_channel_switch)(struct wiphy *wiphy, struct net_device *dev, const u8 *addr); int (*start_nan)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_conf *conf); void (*stop_nan)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*add_nan_func)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_func *nan_func); void (*del_nan_func)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*nan_change_conf)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_conf *conf, u32 changes); int (*set_multicast_to_unicast)(struct wiphy *wiphy, struct net_device *dev, const bool enabled); int (*get_txq_stats)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_txq_stats *txqstats); int (*set_pmk)(struct wiphy *wiphy, struct net_device *dev, const struct cfg80211_pmk_conf *conf); int (*del_pmk)(struct wiphy *wiphy, struct net_device *dev, const u8 *aa); int (*external_auth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_external_auth_params *params); int (*tx_control_port)(struct wiphy *wiphy, struct net_device *dev, const u8 *buf, size_t len, const u8 *dest, const __be16 proto, const bool noencrypt, int link_id, u64 *cookie); int (*get_ftm_responder_stats)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ftm_responder_stats *ftm_stats); int (*start_pmsr)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_pmsr_request *request); void (*abort_pmsr)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_pmsr_request *request); int (*update_owe_info)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_update_owe_info *owe_info); int (*probe_mesh_link)(struct wiphy *wiphy, struct net_device *dev, const u8 *buf, size_t len); int (*set_tid_config)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_tid_config *tid_conf); int (*reset_tid_config)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, u8 tids); int (*set_sar_specs)(struct wiphy *wiphy, struct cfg80211_sar_specs *sar); int (*color_change)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_color_change_settings *params); int (*set_fils_aad)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_fils_aad *fils_aad); int (*set_radar_background)(struct wiphy *wiphy, struct cfg80211_chan_def *chandef); int (*add_link_station)(struct wiphy *wiphy, struct net_device *dev, struct link_station_parameters *params); int (*mod_link_station)(struct wiphy *wiphy, struct net_device *dev, struct link_station_parameters *params); int (*del_link_station)(struct wiphy *wiphy, struct net_device *dev, struct link_station_del_parameters *params); int (*set_hw_timestamp)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_set_hw_timestamp *hwts); int (*set_ttlm)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ttlm_params *params); u32 (*get_radio_mask)(struct wiphy *wiphy, struct net_device *dev); int (*assoc_ml_reconf)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ml_reconf_req *req); int (*set_epcs)(struct wiphy *wiphy, struct net_device *dev, bool val); };}hjsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjlubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMrhjlubj)}(hhh](j)}(h``suspend`` wiphy device needs to be suspended. The variable **wow** will be ``NULL`` or contain the enabled Wake-on-Wireless triggers that are configured for the device. h](j)}(h ``suspend``h]j)}(hjh]hsuspend}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hwiphy device needs to be suspended. The variable **wow** will be ``NULL`` or contain the enabled Wake-on-Wireless triggers that are configured for the device.h](h1wiphy device needs to be suspended. The variable }(hjhhhNhNubj)}(h**wow**h]hwow}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh will be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhU or contain the enabled Wake-on-Wireless triggers that are configured for the device.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h,``resume`` wiphy device needs to be resumed h](j)}(h ``resume``h]j)}(hjh]hresume}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h wiphy device needs to be resumedh]h wiphy device needs to be resumed}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0hMhj1ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj0hMhjubj)}(h``set_wakeup`` Called when WoWLAN is enabled/disabled, use this callback to call device_set_wakeup_enable() to enable/disable wakeup from the device. h](j)}(h``set_wakeup``h]j)}(hjTh]h set_wakeup}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjNubj6)}(hhh]h)}(hCalled when WoWLAN is enabled/disabled, use this callback to call device_set_wakeup_enable() to enable/disable wakeup from the device.h]hCalled when WoWLAN is enabled/disabled, use this callback to call device_set_wakeup_enable() to enable/disable wakeup from the device.}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubah}(h]h ]h"]h$]h&]uh1j5hjNubeh}(h]h ]h"]h$]h&]uh1jhjihMhjubj)}(hX~``add_virtual_intf`` create a new virtual interface with the given name, must set the struct wireless_dev's iftype. Beware: You must create the new netdev in the wiphy's network namespace! Returns the struct wireless_dev, or an ERR_PTR. For P2P device wdevs, the driver must also set the address member in the wdev. This additionally holds the RTNL to be able to do netdev changes. h](j)}(h``add_virtual_intf``h]j)}(hjh]hadd_virtual_intf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hXhcreate a new virtual interface with the given name, must set the struct wireless_dev's iftype. Beware: You must create the new netdev in the wiphy's network namespace! Returns the struct wireless_dev, or an ERR_PTR. For P2P device wdevs, the driver must also set the address member in the wdev. This additionally holds the RTNL to be able to do netdev changes.h]hXlcreate a new virtual interface with the given name, must set the struct wireless_dev’s iftype. Beware: You must create the new netdev in the wiphy’s network namespace! Returns the struct wireless_dev, or an ERR_PTR. For P2P device wdevs, the driver must also set the address member in the wdev. This additionally holds the RTNL to be able to do netdev changes.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(ht``del_virtual_intf`` remove the virtual interface This additionally holds the RTNL to be able to do netdev changes. h](j)}(h``del_virtual_intf``h]j)}(hjh]hdel_virtual_intf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h^remove the virtual interface This additionally holds the RTNL to be able to do netdev changes.h]h^remove the virtual interface This additionally holds the RTNL to be able to do netdev changes.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``change_virtual_intf`` change type/configuration of virtual interface, keep the struct wireless_dev's iftype updated. This additionally holds the RTNL to be able to do netdev changes. h](j)}(h``change_virtual_intf``h]j)}(hjh]hchange_virtual_intf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hchange type/configuration of virtual interface, keep the struct wireless_dev's iftype updated. This additionally holds the RTNL to be able to do netdev changes.h]hchange type/configuration of virtual interface, keep the struct wireless_dev’s iftype updated. This additionally holds the RTNL to be able to do netdev changes.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h``add_intf_link`` Add a new MLO link to the given interface. Note that the wdev->link[] data structure has been updated, so the new link address is available. h](j)}(h``add_intf_link``h]j)}(hj<h]h add_intf_link}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj6ubj6)}(hhh]h)}(hAdd a new MLO link to the given interface. Note that the wdev->link[] data structure has been updated, so the new link address is available.h]hAdd a new MLO link to the given interface. Note that the wdev->link[] data structure has been updated, so the new link address is available.}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjRubah}(h]h ]h"]h$]h&]uh1j5hj6ubeh}(h]h ]h"]h$]h&]uh1jhjQhM hjubj)}(h?``del_intf_link`` Remove an MLO link from the given interface. h](j)}(h``del_intf_link``h]j)}(hjvh]h del_intf_link}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjpubj6)}(hhh]h)}(h,Remove an MLO link from the given interface.h]h,Remove an MLO link from the given interface.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjpubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX)``add_key`` add a key with the given parameters. **mac_addr** will be ``NULL`` when adding a group key. **link_id** will be -1 for non-MLO connection. For MLO connection, **link_id** will be >= 0 for group key and -1 for pairwise key, **mac_addr** will be peer's MLD address for MLO pairwise key. h](j)}(h ``add_key``h]j)}(hjh]hadd_key}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hXadd a key with the given parameters. **mac_addr** will be ``NULL`` when adding a group key. **link_id** will be -1 for non-MLO connection. For MLO connection, **link_id** will be >= 0 for group key and -1 for pairwise key, **mac_addr** will be peer's MLD address for MLO pairwise key.h](h%add a key with the given parameters. }(hjhhhNhNubj)}(h **mac_addr**h]hmac_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh will be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh when adding a group key. }(hjhhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh8 will be -1 for non-MLO connection. For MLO connection, }(hjhhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh5 will be >= 0 for group key and -1 for pairwise key, }(hjhhhNhNubj)}(h **mac_addr**h]hmac_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh3 will be peer’s MLD address for MLO pairwise key.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX``get_key`` get information about the key with the given parameters. **mac_addr** will be ``NULL`` when requesting information for a group key. All pointers given to the **callback** function need not be valid after it returns. This function should return an error if it is not possible to retrieve the key, -ENOENT if it doesn't exist. **link_id** will be -1 for non-MLO connection. For MLO connection, **link_id** will be >= 0 for group key and -1 for pairwise key, **mac_addr** will be peer's MLD address for MLO pairwise key. h](j)}(h ``get_key``h]j)}(hjCh]hget_key}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj=ubj6)}(hhh]h)}(hXget information about the key with the given parameters. **mac_addr** will be ``NULL`` when requesting information for a group key. All pointers given to the **callback** function need not be valid after it returns. This function should return an error if it is not possible to retrieve the key, -ENOENT if it doesn't exist. **link_id** will be -1 for non-MLO connection. For MLO connection, **link_id** will be >= 0 for group key and -1 for pairwise key, **mac_addr** will be peer's MLD address for MLO pairwise key.h](h9get information about the key with the given parameters. }(hj\hhhNhNubj)}(h **mac_addr**h]hmac_addr}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\ubh will be }(hj\hhhNhNubj)}(h``NULL``h]hNULL}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubhH when requesting information for a group key. All pointers given to the }(hj\hhhNhNubj)}(h **callback**h]hcallback}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\ubh function need not be valid after it returns. This function should return an error if it is not possible to retrieve the key, -ENOENT if it doesn’t exist. }(hj\hhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\ubh8 will be -1 for non-MLO connection. For MLO connection, }(hj\hhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\ubh5 will be >= 0 for group key and -1 for pairwise key, }(hj\hhhNhNubj)}(h **mac_addr**h]hmac_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\ubh3 will be peer’s MLD address for MLO pairwise key.}(hj\hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjYubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhjXhMhjubj)}(hXH``del_key`` remove a key given the **mac_addr** (``NULL`` for a group key) and **key_index**, return -ENOENT if the key doesn't exist. **link_id** will be -1 for non-MLO connection. For MLO connection, **link_id** will be >= 0 for group key and -1 for pairwise key, **mac_addr** will be peer's MLD address for MLO pairwise key. h](j)}(h ``del_key``h]j)}(hjh]hdel_key}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjubj6)}(hhh]h)}(hX;remove a key given the **mac_addr** (``NULL`` for a group key) and **key_index**, return -ENOENT if the key doesn't exist. **link_id** will be -1 for non-MLO connection. For MLO connection, **link_id** will be >= 0 for group key and -1 for pairwise key, **mac_addr** will be peer's MLD address for MLO pairwise key.h](hremove a key given the }(hjhhhNhNubj)}(h **mac_addr**h]hmac_addr}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh (}(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh for a group key) and }(hjhhhNhNubj)}(h **key_index**h]h key_index}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh-, return -ENOENT if the key doesn’t exist. }(hjhhhNhNubj)}(h **link_id**h]hlink_id}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh8 will be -1 for non-MLO connection. For MLO connection, }(hjhhhNhNubj)}(h **link_id**h]hlink_id}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh5 will be >= 0 for group key and -1 for pairwise key, }(hjhhhNhNubj)}(h **mac_addr**h]hmac_addr}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh3 will be peer’s MLD address for MLO pairwise key.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM"hjubj)}(h``set_default_key`` set the default key on an interface. **link_id** will be >= 0 for MLO connection and -1 for non-MLO connection. h](j)}(h``set_default_key``h]j)}(hjh]hset_default_key}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM%hjubj6)}(hhh]h)}(hoset the default key on an interface. **link_id** will be >= 0 for MLO connection and -1 for non-MLO connection.h](h%set the default key on an interface. }(hjhhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh? will be >= 0 for MLO connection and -1 for non-MLO connection.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM%hjubj)}(h``set_default_mgmt_key`` set the default management frame key on an interface. **link_id** will be >= 0 for MLO connection and -1 for non-MLO connection. h](j)}(h``set_default_mgmt_key``h]j)}(hjh]hset_default_mgmt_key}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM(hjubj6)}(hhh]h)}(hset the default management frame key on an interface. **link_id** will be >= 0 for MLO connection and -1 for non-MLO connection.h](h6set the default management frame key on an interface. }(hjhhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh? will be >= 0 for MLO connection and -1 for non-MLO connection.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM'hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM(hjubj)}(h``set_default_beacon_key`` set the default Beacon frame key on an interface. **link_id** will be >= 0 for MLO connection and -1 for non-MLO connection. h](j)}(h``set_default_beacon_key``h]j)}(hj'h]hset_default_beacon_key}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM+hj!ubj6)}(hhh]h)}(h|set the default Beacon frame key on an interface. **link_id** will be >= 0 for MLO connection and -1 for non-MLO connection.h](h2set the default Beacon frame key on an interface. }(hj@hhhNhNubj)}(h **link_id**h]hlink_id}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@ubh? will be >= 0 for MLO connection and -1 for non-MLO connection.}(hj@hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM*hj=ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj<hM+hjubj)}(h@``start_ap`` Start acting in AP mode defined by the parameters. h](j)}(h ``start_ap``h]j)}(hjsh]hstart_ap}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM/hjmubj6)}(hhh]h)}(h2Start acting in AP mode defined by the parameters.h]h2Start acting in AP mode defined by the parameters.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM/hjubah}(h]h ]h"]h$]h&]uh1j5hjmubeh}(h]h ]h"]h$]h&]uh1jhjhM/hjubj)}(h``change_beacon`` Change the beacon parameters for an access point mode interface. This should reject the call when AP mode wasn't started. h](j)}(h``change_beacon``h]j)}(hjh]h change_beacon}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM1hjubj6)}(hhh]h)}(hyChange the beacon parameters for an access point mode interface. This should reject the call when AP mode wasn't started.h]h{Change the beacon parameters for an access point mode interface. This should reject the call when AP mode wasn’t started.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM0hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM1hjubj)}(h<``stop_ap`` Stop being an AP, including stopping beaconing. h](j)}(h ``stop_ap``h]j)}(hjh]hstop_ap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM2hjubj6)}(hhh]h)}(h/Stop being an AP, including stopping beaconing.h]h/Stop being an AP, including stopping beaconing.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM2hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM2hjubj)}(h#``add_station`` Add a new station. h](j)}(h``add_station``h]j)}(hjh]h add_station}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM4hjubj6)}(hhh]h)}(hAdd a new station.h]hAdd a new station.}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4hM4hj5ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj4hM4hjubj)}(h!``del_station`` Remove a station h](j)}(h``del_station``h]j)}(hjXh]h del_station}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM5hjRubj6)}(hhh]h)}(hRemove a stationh]hRemove a station}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmhM5hjnubah}(h]h ]h"]h$]h&]uh1j5hjRubeh}(h]h ]h"]h$]h&]uh1jhjmhM5hjubj)}(hXR``change_station`` Modify a given station. Note that flags changes are not much validated in cfg80211, in particular the auth/assoc/authorized flags might come to the driver in invalid combinations -- make sure to check them, also against the existing state! Drivers must call cfg80211_check_station_change() to validate the information. h](j)}(h``change_station``h]j)}(hjh]hchange_station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM:hjubj6)}(hhh]h)}(hX>Modify a given station. Note that flags changes are not much validated in cfg80211, in particular the auth/assoc/authorized flags might come to the driver in invalid combinations -- make sure to check them, also against the existing state! Drivers must call cfg80211_check_station_change() to validate the information.h]hX>Modify a given station. Note that flags changes are not much validated in cfg80211, in particular the auth/assoc/authorized flags might come to the driver in invalid combinations -- make sure to check them, also against the existing state! Drivers must call cfg80211_check_station_change() to validate the information.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM6hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM:hjubj)}(hN``get_station`` get station information for the station identified by **mac** h](j)}(h``get_station``h]j)}(hjh]h get_station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM;hjubj6)}(hhh]h)}(h=get station information for the station identified by **mac**h](h6get station information for the station identified by }(hjhhhNhNubj)}(h**mac**h]hmac}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubeh}(h]h ]h"]h$]h&]uh1hhjhM;hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM;hjubj)}(hG``dump_station`` dump station callback -- resume dump at index **idx** h](j)}(h``dump_station``h]j)}(hjh]h dump_station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM<hj ubj6)}(hhh]h)}(h5dump station callback -- resume dump at index **idx**h](h.dump station callback -- resume dump at index }(hj+hhhNhNubj)}(h**idx**h]hidx}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj+ubeh}(h]h ]h"]h$]h&]uh1hhj'hM<hj(ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj'hM<hjubj)}(h$``add_mpath`` add a fixed mesh path h](j)}(h ``add_mpath``h]j)}(hjYh]h add_mpath}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM>hjSubj6)}(hhh]h)}(hadd a fixed mesh pathh]hadd a fixed mesh path}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhM>hjoubah}(h]h ]h"]h$]h&]uh1j5hjSubeh}(h]h ]h"]h$]h&]uh1jhjnhM>hjubj)}(h'``del_mpath`` delete a given mesh path h](j)}(h ``del_mpath``h]j)}(hjh]h del_mpath}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM?hjubj6)}(hhh]h)}(hdelete a given mesh pathh]hdelete a given mesh path}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM?hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM?hjubj)}(h*``change_mpath`` change a given mesh path h](j)}(h``change_mpath``h]j)}(hjh]h change_mpath}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM@hjubj6)}(hhh]h)}(hchange a given mesh pathh]hchange a given mesh path}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM@hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM@hjubj)}(h7``get_mpath`` get a mesh path for the given parameters h](j)}(h ``get_mpath``h]j)}(hjh]h get_mpath}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMAhjubj6)}(hhh]h)}(h(get a mesh path for the given parametersh]h(get a mesh path for the given parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMAhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMAhjubj)}(hG``dump_mpath`` dump mesh path callback -- resume dump at index **idx** h](j)}(h``dump_mpath``h]j)}(hj=h]h dump_mpath}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMBhj7ubj6)}(hhh]h)}(h7dump mesh path callback -- resume dump at index **idx**h](h0dump mesh path callback -- resume dump at index }(hjVhhhNhNubj)}(h**idx**h]hidx}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVubeh}(h]h ]h"]h$]h&]uh1hhjRhMBhjSubah}(h]h ]h"]h$]h&]uh1j5hj7ubeh}(h]h ]h"]h$]h&]uh1jhjRhMBhjubj)}(h;``get_mpp`` get a mesh proxy path for the given parameters h](j)}(h ``get_mpp``h]j)}(hjh]hget_mpp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMChj~ubj6)}(hhh]h)}(h.get a mesh proxy path for the given parametersh]h.get a mesh proxy path for the given parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMChjubah}(h]h ]h"]h$]h&]uh1j5hj~ubeh}(h]h ]h"]h$]h&]uh1jhjhMChjubj)}(hK``dump_mpp`` dump mesh proxy path callback -- resume dump at index **idx** h](j)}(h ``dump_mpp``h]j)}(hjh]hdump_mpp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMDhjubj6)}(hhh]h)}(h=dump mesh proxy path callback -- resume dump at index **idx**h](h6dump mesh proxy path callback -- resume dump at index }(hjhhhNhNubj)}(h**idx**h]hidx}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubeh}(h]h ]h"]h$]h&]uh1hhjhMDhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMDhjubj)}(h7``get_mesh_config`` Get the current mesh configuration h](j)}(h``get_mesh_config``h]j)}(hjh]hget_mesh_config}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMJhjubj6)}(hhh]h)}(h"Get the current mesh configurationh]h"Get the current mesh configuration}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMJhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMJhjubj)}(h``update_mesh_config`` Update mesh parameters on a running mesh. The mask is a bitfield which tells us which parameters to set, and which to leave alone. h](j)}(h``update_mesh_config``h]j)}(hj=h]hupdate_mesh_config}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMNhj7ubj6)}(hhh]h)}(hUpdate mesh parameters on a running mesh. The mask is a bitfield which tells us which parameters to set, and which to leave alone.h]hUpdate mesh parameters on a running mesh. The mask is a bitfield which tells us which parameters to set, and which to leave alone.}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMLhjSubah}(h]h ]h"]h$]h&]uh1j5hj7ubeh}(h]h ]h"]h$]h&]uh1jhjRhMNhjubj)}(hm``join_mesh`` join the mesh network with the specified parameters (invoked with the wireless_dev mutex held) h](j)}(h ``join_mesh``h]j)}(hjwh]h join_mesh}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMFhjqubj6)}(hhh]h)}(h^join the mesh network with the specified parameters (invoked with the wireless_dev mutex held)h]h^join the mesh network with the specified parameters (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMEhjubah}(h]h ]h"]h$]h&]uh1j5hjqubeh}(h]h ]h"]h$]h&]uh1jhjhMFhjubj)}(hY``leave_mesh`` leave the current mesh network (invoked with the wireless_dev mutex held) h](j)}(h``leave_mesh``h]j)}(hjh]h leave_mesh}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMHhjubj6)}(hhh]h)}(hIleave the current mesh network (invoked with the wireless_dev mutex held)h]hIleave the current mesh network (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMGhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMHhjubj)}(hk``join_ocb`` join the OCB network with the specified parameters (invoked with the wireless_dev mutex held) h](j)}(h ``join_ocb``h]j)}(hjh]hjoin_ocb}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM)hjubj6)}(hhh]h)}(h]join the OCB network with the specified parameters (invoked with the wireless_dev mutex held)h]h]join the OCB network with the specified parameters (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM(hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM)hjubj)}(hW``leave_ocb`` leave the current OCB network (invoked with the wireless_dev mutex held) h](j)}(h ``leave_ocb``h]j)}(hj%h]h leave_ocb}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM+hjubj6)}(hhh]h)}(hHleave the current OCB network (invoked with the wireless_dev mutex held)h]hHleave the current OCB network (invoked with the wireless_dev mutex held)}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM*hj;ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj:hM+hjubj)}(h2``change_bss`` Modify parameters for a given BSS. h](j)}(h``change_bss``h]j)}(hj_h]h change_bss}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMPhjYubj6)}(hhh]h)}(h"Modify parameters for a given BSS.h]h"Modify parameters for a given BSS.}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjthMPhjuubah}(h]h ]h"]h$]h&]uh1j5hjYubeh}(h]h ]h"]h$]h&]uh1jhjthMPhjubj)}(hX```inform_bss`` Called by cfg80211 while being informed about new BSS data for every BSS found within the reported data or frame. This is called from within the cfg8011 inform_bss handlers while holding the bss_lock. The data parameter is passed through from drv_data inside struct cfg80211_inform_bss. The new IE data for the BSS is explicitly passed. h](j)}(h``inform_bss``h]j)}(hjh]h inform_bss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMWhjubj6)}(hhh]h)}(hXPCalled by cfg80211 while being informed about new BSS data for every BSS found within the reported data or frame. This is called from within the cfg8011 inform_bss handlers while holding the bss_lock. The data parameter is passed through from drv_data inside struct cfg80211_inform_bss. The new IE data for the BSS is explicitly passed.h]hXPCalled by cfg80211 while being informed about new BSS data for every BSS found within the reported data or frame. This is called from within the cfg8011 inform_bss handlers while holding the bss_lock. The data parameter is passed through from drv_data inside struct cfg80211_inform_bss. The new IE data for the BSS is explicitly passed.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMRhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMWhjubj)}(h+``set_txq_params`` Set TX queue parameters h](j)}(h``set_txq_params``h]j)}(hjh]hset_txq_params}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMYhjubj6)}(hhh]h)}(hSet TX queue parametersh]hSet TX queue parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMYhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMYhjubj)}(h``libertas_set_mesh_channel`` Only for backward compatibility for libertas, as it doesn't implement join_mesh and needs to set the channel to join the mesh instead. h](j)}(h``libertas_set_mesh_channel``h]j)}(hj h]hlibertas_set_mesh_channel}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM]hjubj6)}(hhh]h)}(hOnly for backward compatibility for libertas, as it doesn't implement join_mesh and needs to set the channel to join the mesh instead.h]hOnly for backward compatibility for libertas, as it doesn’t implement join_mesh and needs to set the channel to join the mesh instead.}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM[hj!ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hM]hjubj)}(hX``set_monitor_channel`` Set the monitor mode channel for the device. If other interfaces are active this callback should reject the configuration. If no interfaces are active or the device is down, the channel should be stored for when a monitor interface becomes active. h](j)}(h``set_monitor_channel``h]j)}(hjEh]hset_monitor_channel}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMbhj?ubj6)}(hhh]h)}(hSet the monitor mode channel for the device. If other interfaces are active this callback should reject the configuration. If no interfaces are active or the device is down, the channel should be stored for when a monitor interface becomes active.h]hSet the monitor mode channel for the device. If other interfaces are active this callback should reject the configuration. If no interfaces are active or the device is down, the channel should be stored for when a monitor interface becomes active.}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM_hj[ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhjZhMbhjubj)}(h``scan`` Request to do a scan. If returning zero, the scan request is given the driver, and will be valid until passed to cfg80211_scan_done(). For scan results, call cfg80211_inform_bss(); you can call this outside the scan/scan_done bracket too. h](j)}(h``scan``h]j)}(hjh]hscan}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMghjyubj6)}(hhh]h)}(hRequest to do a scan. If returning zero, the scan request is given the driver, and will be valid until passed to cfg80211_scan_done(). For scan results, call cfg80211_inform_bss(); you can call this outside the scan/scan_done bracket too.h]hRequest to do a scan. If returning zero, the scan request is given the driver, and will be valid until passed to cfg80211_scan_done(). For scan results, call cfg80211_inform_bss(); you can call this outside the scan/scan_done bracket too.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMdhjubah}(h]h ]h"]h$]h&]uh1j5hjyubeh}(h]h ]h"]h$]h&]uh1jhjhMghjubj)}(h``abort_scan`` Tell the driver to abort an ongoing scan. The driver shall indicate the status of the scan through cfg80211_scan_done(). h](j)}(h``abort_scan``h]j)}(hjh]h abort_scan}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMihjubj6)}(hhh]h)}(hxTell the driver to abort an ongoing scan. The driver shall indicate the status of the scan through cfg80211_scan_done().h]hxTell the driver to abort an ongoing scan. The driver shall indicate the status of the scan through cfg80211_scan_done().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMihjubj)}(hd``auth`` Request to authenticate with the specified peer (invoked with the wireless_dev mutex held) h](j)}(h``auth``h]j)}(hjh]hauth}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMlhjubj6)}(hhh]h)}(hZRequest to authenticate with the specified peer (invoked with the wireless_dev mutex held)h]hZRequest to authenticate with the specified peer (invoked with the wireless_dev mutex held)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMkhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMlhjubj)}(hf``assoc`` Request to (re)associate with the specified peer (invoked with the wireless_dev mutex held) h](j)}(h ``assoc``h]j)}(hj-h]hassoc}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMnhj'ubj6)}(hhh]h)}(h[Request to (re)associate with the specified peer (invoked with the wireless_dev mutex held)h]h[Request to (re)associate with the specified peer (invoked with the wireless_dev mutex held)}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMmhjCubah}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhjBhMnhjubj)}(hh``deauth`` Request to deauthenticate from the specified peer (invoked with the wireless_dev mutex held) h](j)}(h ``deauth``h]j)}(hjgh]hdeauth}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMphjaubj6)}(hhh]h)}(h\Request to deauthenticate from the specified peer (invoked with the wireless_dev mutex held)h]h\Request to deauthenticate from the specified peer (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMohj}ubah}(h]h ]h"]h$]h&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hMphjubj)}(hh``disassoc`` Request to disassociate from the specified peer (invoked with the wireless_dev mutex held) h](j)}(h ``disassoc``h]j)}(hjh]hdisassoc}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMrhjubj6)}(hhh]h)}(hZRequest to disassociate from the specified peer (invoked with the wireless_dev mutex held)h]hZRequest to disassociate from the specified peer (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMqhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMrhjubj)}(hXt``connect`` Connect to the ESS with the specified parameters. When connected, call cfg80211_connect_result()/cfg80211_connect_bss() with status code ``WLAN_STATUS_SUCCESS``. If the connection fails for some reason, call cfg80211_connect_result()/cfg80211_connect_bss() with the status code from the AP or cfg80211_connect_timeout() if no frame with status code was received. The driver is allowed to roam to other BSSes within the ESS when the other BSS matches the connect parameters. When such roaming is initiated by the driver, the driver is expected to verify that the target matches the configured security parameters and to use Reassociation Request frame instead of Association Request frame. The connect function can also be used to request the driver to perform a specific roam when connected to an ESS. In that case, the prev_bssid parameter is set to the BSSID of the currently associated BSS as an indication of requesting reassociation. In both the driver-initiated and new connect() call initiated roaming cases, the result of roaming is indicated with a call to cfg80211_roamed(). (invoked with the wireless_dev mutex held) h](j)}(h ``connect``h]j)}(hjh]hconnect}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hXgConnect to the ESS with the specified parameters. When connected, call cfg80211_connect_result()/cfg80211_connect_bss() with status code ``WLAN_STATUS_SUCCESS``. If the connection fails for some reason, call cfg80211_connect_result()/cfg80211_connect_bss() with the status code from the AP or cfg80211_connect_timeout() if no frame with status code was received. The driver is allowed to roam to other BSSes within the ESS when the other BSS matches the connect parameters. When such roaming is initiated by the driver, the driver is expected to verify that the target matches the configured security parameters and to use Reassociation Request frame instead of Association Request frame. The connect function can also be used to request the driver to perform a specific roam when connected to an ESS. In that case, the prev_bssid parameter is set to the BSSID of the currently associated BSS as an indication of requesting reassociation. In both the driver-initiated and new connect() call initiated roaming cases, the result of roaming is indicated with a call to cfg80211_roamed(). (invoked with the wireless_dev mutex held)h](hConnect to the ESS with the specified parameters. When connected, call cfg80211_connect_result()/cfg80211_connect_bss() with status code }(hjhhhNhNubj)}(h``WLAN_STATUS_SUCCESS``h]hWLAN_STATUS_SUCCESS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhX. If the connection fails for some reason, call cfg80211_connect_result()/cfg80211_connect_bss() with the status code from the AP or cfg80211_connect_timeout() if no frame with status code was received. The driver is allowed to roam to other BSSes within the ESS when the other BSS matches the connect parameters. When such roaming is initiated by the driver, the driver is expected to verify that the target matches the configured security parameters and to use Reassociation Request frame instead of Association Request frame. The connect function can also be used to request the driver to perform a specific roam when connected to an ESS. In that case, the prev_bssid parameter is set to the BSSID of the currently associated BSS as an indication of requesting reassociation. In both the driver-initiated and new connect() call initiated roaming cases, the result of roaming is indicated with a call to cfg80211_roamed(). (invoked with the wireless_dev mutex held)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMthjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX+``update_connect_params`` Update the connect parameters while connected to a BSS. The updated parameters can be used by driver/firmware for subsequent BSS selection (roaming) decisions and to form the Authentication/(Re)Association Request frames. This call does not request an immediate disassociation or reassociation with the current BSS, i.e., this impacts only subsequent (re)associations. The bits in changed are defined in :c:type:`enum cfg80211_connect_params_changed `. (invoked with the wireless_dev mutex held) h](j)}(h``update_connect_params``h]j)}(hj'h]hupdate_connect_params}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj!ubj6)}(hhh]h)}(hXUpdate the connect parameters while connected to a BSS. The updated parameters can be used by driver/firmware for subsequent BSS selection (roaming) decisions and to form the Authentication/(Re)Association Request frames. This call does not request an immediate disassociation or reassociation with the current BSS, i.e., this impacts only subsequent (re)associations. The bits in changed are defined in :c:type:`enum cfg80211_connect_params_changed `. (invoked with the wireless_dev mutex held)h](hXUpdate the connect parameters while connected to a BSS. The updated parameters can be used by driver/firmware for subsequent BSS selection (roaming) decisions and to form the Authentication/(Re)Association Request frames. This call does not request an immediate disassociation or reassociation with the current BSS, i.e., this impacts only subsequent (re)associations. The bits in changed are defined in }(hj@hhhNhNubh)}(hP:c:type:`enum cfg80211_connect_params_changed `h]j)}(hjJh]h$enum cfg80211_connect_params_changed}(hjLhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6cfg80211_connect_params_changeduh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj@ubh,. (invoked with the wireless_dev mutex held)}(hj@hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjghMhj=ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj<hMhjubj)}(hX``disconnect`` Disconnect from the BSS/ESS or stop connection attempts if connection is in progress. Once done, call cfg80211_disconnected() in case connection was already established (invoked with the wireless_dev mutex held), otherwise call cfg80211_connect_timeout(). h](j)}(h``disconnect``h]j)}(hjh]h disconnect}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj~ubj6)}(hhh]h)}(hDisconnect from the BSS/ESS or stop connection attempts if connection is in progress. Once done, call cfg80211_disconnected() in case connection was already established (invoked with the wireless_dev mutex held), otherwise call cfg80211_connect_timeout().h]hDisconnect from the BSS/ESS or stop connection attempts if connection is in progress. Once done, call cfg80211_disconnected() in case connection was already established (invoked with the wireless_dev mutex held), otherwise call cfg80211_connect_timeout().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hj~ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``join_ibss`` Join the specified IBSS (or create if necessary). Once done, call cfg80211_ibss_joined(), also call that function when changing BSSID due to a merge. (invoked with the wireless_dev mutex held) h](j)}(h ``join_ibss``h]j)}(hjh]h join_ibss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hJoin the specified IBSS (or create if necessary). Once done, call cfg80211_ibss_joined(), also call that function when changing BSSID due to a merge. (invoked with the wireless_dev mutex held)h]hJoin the specified IBSS (or create if necessary). Once done, call cfg80211_ibss_joined(), also call that function when changing BSSID due to a merge. (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hJ``leave_ibss`` Leave the IBSS. (invoked with the wireless_dev mutex held) h](j)}(h``leave_ibss``h]j)}(hjh]h leave_ibss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h:Leave the IBSS. (invoked with the wireless_dev mutex held)h]h:Leave the IBSS. (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubj)}(h[``set_mcast_rate`` Set the specified multicast rate (only if vif is in ADHOC or MESH mode) h](j)}(h``set_mcast_rate``h]j)}(hj2h]hset_mcast_rate}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj,ubj6)}(hhh]h)}(hGSet the specified multicast rate (only if vif is in ADHOC or MESH mode)h]hGSet the specified multicast rate (only if vif is in ADHOC or MESH mode)}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjHubah}(h]h ]h"]h$]h&]uh1j5hj,ubeh}(h]h ]h"]h$]h&]uh1jhjGhMhjubj)}(hX%``set_wiphy_params`` Notify that wiphy parameters have changed; **changed** bitfield (see :c:type:`enum wiphy_params_flags `) describes which values have changed. The actual parameter values are available in struct wiphy. If returning an error, no value should be changed. h](j)}(h``set_wiphy_params``h]j)}(hjlh]hset_wiphy_params}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjfubj6)}(hhh]h)}(hXNotify that wiphy parameters have changed; **changed** bitfield (see :c:type:`enum wiphy_params_flags `) describes which values have changed. The actual parameter values are available in struct wiphy. If returning an error, no value should be changed.h](h+Notify that wiphy parameters have changed; }(hjhhhNhNubj)}(h **changed**h]hchanged}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh bitfield (see }(hjhhhNhNubh)}(h6:c:type:`enum wiphy_params_flags `h]j)}(hjh]henum wiphy_params_flags}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6wiphy_params_flagsuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh) describes which values have changed. The actual parameter values are available in struct wiphy. If returning an error, no value should be changed.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX,``set_tx_power`` set the transmit power according to the parameters, the power passed is in mBm, to get dBm use MBM_TO_DBM(). The wdev may be ``NULL`` if power was set for the wiphy, and will always be ``NULL`` unless the driver supports per-vif TX power (as advertised by the nl80211 feature flag.) h](j)}(h``set_tx_power``h]j)}(hjh]h set_tx_power}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hXset the transmit power according to the parameters, the power passed is in mBm, to get dBm use MBM_TO_DBM(). The wdev may be ``NULL`` if power was set for the wiphy, and will always be ``NULL`` unless the driver supports per-vif TX power (as advertised by the nl80211 feature flag.)h](h}set the transmit power according to the parameters, the power passed is in mBm, to get dBm use MBM_TO_DBM(). The wdev may be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh4 if power was set for the wiphy, and will always be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhY unless the driver supports per-vif TX power (as advertised by the nl80211 feature flag.)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hZ``get_tx_power`` store the current TX power into the dbm variable; return 0 if successful h](j)}(h``get_tx_power``h]j)}(hj9h]h get_tx_power}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj3ubj6)}(hhh]h)}(hHstore the current TX power into the dbm variable; return 0 if successfulh]hHstore the current TX power into the dbm variable; return 0 if successful}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjOubah}(h]h ]h"]h$]h&]uh1j5hj3ubeh}(h]h ]h"]h$]h&]uh1jhjNhMhjubj)}(he``rfkill_poll`` polls the hw rfkill line, use cfg80211 reporting functions to adjust rfkill hw state h](j)}(h``rfkill_poll``h]j)}(hjsh]h rfkill_poll}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjmubj6)}(hhh]h)}(hTpolls the hw rfkill line, use cfg80211 reporting functions to adjust rfkill hw stateh]hTpolls the hw rfkill line, use cfg80211 reporting functions to adjust rfkill hw state}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjmubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hC``testmode_cmd`` run a test mode command; **wdev** may be ``NULL`` h](j)}(h``testmode_cmd``h]j)}(hjh]h testmode_cmd}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h1run a test mode command; **wdev** may be ``NULL``h](hrun a test mode command; }(hjhhhNhNubj)}(h**wdev**h]hwdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh may be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX``testmode_dump`` Implement a test mode dump. The cb->args[2] and up may be used by the function, but 0 and 1 must not be touched. Additionally, return error codes other than -ENOBUFS and -ENOENT will terminate the dump and return to userspace with an error, so be careful. If any data was passed in from userspace then the data/len arguments will be present and point to the data contained in ``NL80211_ATTR_TESTDATA``. h](j)}(h``testmode_dump``h]j)}(hjh]h testmode_dump}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hXImplement a test mode dump. The cb->args[2] and up may be used by the function, but 0 and 1 must not be touched. Additionally, return error codes other than -ENOBUFS and -ENOENT will terminate the dump and return to userspace with an error, so be careful. If any data was passed in from userspace then the data/len arguments will be present and point to the data contained in ``NL80211_ATTR_TESTDATA``.h](hXxImplement a test mode dump. The cb->args[2] and up may be used by the function, but 0 and 1 must not be touched. Additionally, return error codes other than -ENOBUFS and -ENOENT will terminate the dump and return to userspace with an error, so be careful. If any data was passed in from userspace then the data/len arguments will be present and point to the data contained in }(hjhhhNhNubj)}(h``NL80211_ATTR_TESTDATA``h]hNL80211_ATTR_TESTDATA}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h8``set_bitrate_mask`` set the bitrate mask configuration h](j)}(h``set_bitrate_mask``h]j)}(hjRh]hset_bitrate_mask}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjLubj6)}(hhh]h)}(h"set the bitrate mask configurationh]h"set the bitrate mask configuration}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjghMhjhubah}(h]h ]h"]h$]h&]uh1j5hjLubeh}(h]h ]h"]h$]h&]uh1jhjghMhjubj)}(h-``dump_survey`` get site survey information. h](j)}(h``dump_survey``h]j)}(hjh]h dump_survey}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hget site survey information.h]hget site survey information.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``set_pmksa`` Cache a PMKID for a BSSID. This is mostly useful for fullmac devices running firmwares capable of generating the (re) association RSN IE. It allows for faster roaming between WPA2 BSSIDs. h](j)}(h ``set_pmksa``h]j)}(hjh]h set_pmksa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hCache a PMKID for a BSSID. This is mostly useful for fullmac devices running firmwares capable of generating the (re) association RSN IE. It allows for faster roaming between WPA2 BSSIDs.h]hCache a PMKID for a BSSID. This is mostly useful for fullmac devices running firmwares capable of generating the (re) association RSN IE. It allows for faster roaming between WPA2 BSSIDs.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h%``del_pmksa`` Delete a cached PMKID. h](j)}(h ``del_pmksa``h]j)}(hjh]h del_pmksa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hDelete a cached PMKID.h]hDelete a cached PMKID.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h)``flush_pmksa`` Flush all cached PMKIDs. h](j)}(h``flush_pmksa``h]j)}(hj7h]h flush_pmksa}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj1ubj6)}(hhh]h)}(hFlush all cached PMKIDs.h]hFlush all cached PMKIDs.}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhMhjMubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhjLhMhjubj)}(hXD``remain_on_channel`` Request the driver to remain awake on the specified channel for the specified duration to complete an off-channel operation (e.g., public action frame exchange). When the driver is ready on the requested channel, it must indicate this with an event notification by calling cfg80211_ready_on_channel(). h](j)}(h``remain_on_channel``h]j)}(hjph]hremain_on_channel}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubj6)}(hhh]h)}(hX-Request the driver to remain awake on the specified channel for the specified duration to complete an off-channel operation (e.g., public action frame exchange). When the driver is ready on the requested channel, it must indicate this with an event notification by calling cfg80211_ready_on_channel().h]hX-Request the driver to remain awake on the specified channel for the specified duration to complete an off-channel operation (e.g., public action frame exchange). When the driver is ready on the requested channel, it must indicate this with an event notification by calling cfg80211_ready_on_channel().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``cancel_remain_on_channel`` Cancel an on-going remain-on-channel operation. This allows the operation to be terminated prior to timeout based on the duration value. h](j)}(h``cancel_remain_on_channel``h]j)}(hjh]hcancel_remain_on_channel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hCancel an on-going remain-on-channel operation. This allows the operation to be terminated prior to timeout based on the duration value.h]hCancel an on-going remain-on-channel operation. This allows the operation to be terminated prior to timeout based on the duration value.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h)``mgmt_tx`` Transmit a management frame. h](j)}(h ``mgmt_tx``h]j)}(hjh]hmgmt_tx}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hTransmit a management frame.h]hTransmit a management frame.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(he``mgmt_tx_cancel_wait`` Cancel the wait time from transmitting a management frame on another channel h](j)}(h``mgmt_tx_cancel_wait``h]j)}(hjh]hmgmt_tx_cancel_wait}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hLCancel the wait time from transmitting a management frame on another channelh]hLCancel the wait time from transmitting a management frame on another channel}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj3ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj2hMhjubj)}(h``set_power_mgmt`` Configure WLAN power management. A timeout value of -1 allows the driver to adjust the dynamic ps timeout value. h](j)}(h``set_power_mgmt``h]j)}(hjWh]hset_power_mgmt}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjQubj6)}(hhh]h)}(hpConfigure WLAN power management. A timeout value of -1 allows the driver to adjust the dynamic ps timeout value.h]hpConfigure WLAN power management. A timeout value of -1 allows the driver to adjust the dynamic ps timeout value.}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjmubah}(h]h ]h"]h$]h&]uh1j5hjQubeh}(h]h ]h"]h$]h&]uh1jhjlhMhjubj)}(hX)``set_cqm_rssi_config`` Configure connection quality monitor RSSI threshold. After configuration, the driver should (soon) send an event indicating the current level is above/below the configured threshold; this may need some care when the configuration is changed (without first being disabled.) h](j)}(h``set_cqm_rssi_config``h]j)}(hjh]hset_cqm_rssi_config}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hXConfigure connection quality monitor RSSI threshold. After configuration, the driver should (soon) send an event indicating the current level is above/below the configured threshold; this may need some care when the configuration is changed (without first being disabled.)h]hXConfigure connection quality monitor RSSI threshold. After configuration, the driver should (soon) send an event indicating the current level is above/below the configured threshold; this may need some care when the configuration is changed (without first being disabled.)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX```set_cqm_rssi_range_config`` Configure two RSSI thresholds in the connection quality monitor. An event is to be sent only when the signal level is found to be outside the two values. The driver should set ``NL80211_EXT_FEATURE_CQM_RSSI_LIST`` if this method is implemented. If it is provided then there's no point providing **set_cqm_rssi_config**. h](j)}(h``set_cqm_rssi_range_config``h]j)}(hjh]hset_cqm_rssi_range_config}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hXAConfigure two RSSI thresholds in the connection quality monitor. An event is to be sent only when the signal level is found to be outside the two values. The driver should set ``NL80211_EXT_FEATURE_CQM_RSSI_LIST`` if this method is implemented. If it is provided then there's no point providing **set_cqm_rssi_config**.h](hConfigure two RSSI thresholds in the connection quality monitor. An event is to be sent only when the signal level is found to be outside the two values. The driver should set }(hjhhhNhNubj)}(h%``NL80211_EXT_FEATURE_CQM_RSSI_LIST``h]h!NL80211_EXT_FEATURE_CQM_RSSI_LIST}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhT if this method is implemented. If it is provided then there’s no point providing }(hjhhhNhNubj)}(h**set_cqm_rssi_config**h]hset_cqm_rssi_config}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hQ``set_cqm_txe_config`` Configure connection quality monitor TX error thresholds. h](j)}(h``set_cqm_txe_config``h]j)}(hj)h]hset_cqm_txe_config}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj#ubj6)}(hhh]h)}(h9Configure connection quality monitor TX error thresholds.h]h9Configure connection quality monitor TX error thresholds.}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj?ubah}(h]h ]h"]h$]h&]uh1j5hj#ubeh}(h]h ]h"]h$]h&]uh1jhj>hMhjubj)}(h``update_mgmt_frame_registrations`` Notify the driver that management frame registrations were updated. The callback is allowed to sleep. h](j)}(h#``update_mgmt_frame_registrations``h]j)}(hjch]hupdate_mgmt_frame_registrations}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj]ubj6)}(hhh]h)}(heNotify the driver that management frame registrations were updated. The callback is allowed to sleep.h]heNotify the driver that management frame registrations were updated. The callback is allowed to sleep.}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjyubah}(h]h ]h"]h$]h&]uh1j5hj]ubeh}(h]h ]h"]h$]h&]uh1jhjxhMhjubj)}(hX``set_antenna`` Set antenna configuration (tx_ant, rx_ant) on the device. Parameters are bitmaps of allowed antennas to use for TX/RX. Drivers may reject TX/RX mask combinations they cannot support by returning -EINVAL (also see nl80211.h **NL80211_ATTR_WIPHY_ANTENNA_TX**). h](j)}(h``set_antenna``h]j)}(hjh]h set_antenna}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hXSet antenna configuration (tx_ant, rx_ant) on the device. Parameters are bitmaps of allowed antennas to use for TX/RX. Drivers may reject TX/RX mask combinations they cannot support by returning -EINVAL (also see nl80211.h **NL80211_ATTR_WIPHY_ANTENNA_TX**).h](hSet antenna configuration (tx_ant, rx_ant) on the device. Parameters are bitmaps of allowed antennas to use for TX/RX. Drivers may reject TX/RX mask combinations they cannot support by returning -EINVAL (also see nl80211.h }(hjhhhNhNubj)}(h!**NL80211_ATTR_WIPHY_ANTENNA_TX**h]hNL80211_ATTR_WIPHY_ANTENNA_TX}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh).}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hP``get_antenna`` Get current antenna configuration from device (tx_ant, rx_ant). h](j)}(h``get_antenna``h]j)}(hjh]h get_antenna}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h?Get current antenna configuration from device (tx_ant, rx_ant).h]h?Get current antenna configuration from device (tx_ant, rx_ant).}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h@``sched_scan_start`` Tell the driver to start a scheduled scan. h](j)}(h``sched_scan_start``h]j)}(hj"h]hsched_scan_start}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h*Tell the driver to start a scheduled scan.h]h*Tell the driver to start a scheduled scan.}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7hMhj8ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj7hMhjubj)}(hX``sched_scan_stop`` Tell the driver to stop an ongoing scheduled scan with given request id. This call must stop the scheduled scan and be ready for starting a new one before it returns, i.e. **sched_scan_start** may be called immediately after that again and should not fail in that case. The driver should not call cfg80211_sched_scan_stopped() for a requested stop (when this method returns 0). h](j)}(h``sched_scan_stop``h]j)}(hj[h]hsched_scan_stop}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjUubj6)}(hhh]h)}(hXyTell the driver to stop an ongoing scheduled scan with given request id. This call must stop the scheduled scan and be ready for starting a new one before it returns, i.e. **sched_scan_start** may be called immediately after that again and should not fail in that case. The driver should not call cfg80211_sched_scan_stopped() for a requested stop (when this method returns 0).h](hTell the driver to stop an ongoing scheduled scan with given request id. This call must stop the scheduled scan and be ready for starting a new one before it returns, i.e. }(hjthhhNhNubj)}(h**sched_scan_start**h]hsched_scan_start}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjtubh may be called immediately after that again and should not fail in that case. The driver should not call cfg80211_sched_scan_stopped() for a requested stop (when this method returns 0).}(hjthhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqubah}(h]h ]h"]h$]h&]uh1j5hjUubeh}(h]h ]h"]h$]h&]uh1jhjphMhjubj)}(hJ``set_rekey_data`` give the data necessary for GTK rekeying to the driver h](j)}(h``set_rekey_data``h]j)}(hjh]hset_rekey_data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM-hjubj6)}(hhh]h)}(h6give the data necessary for GTK rekeying to the driverh]h6give the data necessary for GTK rekeying to the driver}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM-hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM-hjubj)}(h0``tdls_mgmt`` Transmit a TDLS management frame. h](j)}(h ``tdls_mgmt``h]j)}(hjh]h tdls_mgmt}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h!Transmit a TDLS management frame.h]h!Transmit a TDLS management frame.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hJ``tdls_oper`` Perform a high-level TDLS operation (e.g. TDLS link setup). h](j)}(h ``tdls_oper``h]j)}(hjh]h tdls_oper}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h;Perform a high-level TDLS operation (e.g. TDLS link setup).h]h;Perform a high-level TDLS operation (e.g. TDLS link setup).}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.hMhj/ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj.hMhjubj)}(hs``probe_client`` probe an associated client, must return a cookie that it later passes to cfg80211_probe_status(). h](j)}(h``probe_client``h]j)}(hjRh]h probe_client}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjLubj6)}(hhh]h)}(haprobe an associated client, must return a cookie that it later passes to cfg80211_probe_status().h]haprobe an associated client, must return a cookie that it later passes to cfg80211_probe_status().}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhubah}(h]h ]h"]h$]h&]uh1j5hjLubeh}(h]h ]h"]h$]h&]uh1jhjghMhjubj)}(h2``set_noack_map`` Set the NoAck Map for the TIDs. h](j)}(h``set_noack_map``h]j)}(hjh]h set_noack_map}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hSet the NoAck Map for the TIDs.h]hSet the NoAck Map for the TIDs.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``get_channel`` Get the current operating channel for the virtual interface. For monitor interfaces, it should return ``NULL`` unless there's a single current monitoring channel. h](j)}(h``get_channel``h]j)}(hjh]h get_channel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hGet the current operating channel for the virtual interface. For monitor interfaces, it should return ``NULL`` unless there's a single current monitoring channel.h](hfGet the current operating channel for the virtual interface. For monitor interfaces, it should return }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh6 unless there’s a single current monitoring channel.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h1``start_p2p_device`` Start the given P2P device. h](j)}(h``start_p2p_device``h]j)}(hjh]hstart_p2p_device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj ubj6)}(hhh]h)}(hStart the given P2P device.h]hStart the given P2P device.}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&hMhj'ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj&hMhjubj)}(h/``stop_p2p_device`` Stop the given P2P device. h](j)}(h``stop_p2p_device``h]j)}(hjJh]hstop_p2p_device}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjDubj6)}(hhh]h)}(hStop the given P2P device.h]hStop the given P2P device.}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_hMhj`ubah}(h]h ]h"]h$]h&]uh1j5hjDubeh}(h]h ]h"]h$]h&]uh1jhj_hMhjubj)}(hX``set_mac_acl`` Sets MAC address control list in AP and P2P GO mode. Parameters include ACL policy, an array of MAC address of stations and the number of MAC addresses. If there is already a list in driver this new list replaces the existing one. Driver has to clear its ACL when number of MAC addresses entries is passed as 0. Drivers which advertise the support for MAC based ACL have to implement this callback. h](j)}(h``set_mac_acl``h]j)}(hjh]h set_mac_acl}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj}ubj6)}(hhh]h)}(hXSets MAC address control list in AP and P2P GO mode. Parameters include ACL policy, an array of MAC address of stations and the number of MAC addresses. If there is already a list in driver this new list replaces the existing one. Driver has to clear its ACL when number of MAC addresses entries is passed as 0. Drivers which advertise the support for MAC based ACL have to implement this callback.h]hXSets MAC address control list in AP and P2P GO mode. Parameters include ACL policy, an array of MAC address of stations and the number of MAC addresses. If there is already a list in driver this new list replaces the existing one. Driver has to clear its ACL when number of MAC addresses entries is passed as 0. Drivers which advertise the support for MAC based ACL have to implement this callback.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hj}ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h?``start_radar_detection`` Start radar detection in the driver. h](j)}(h``start_radar_detection``h]j)}(hjh]hstart_radar_detection}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h$Start radar detection in the driver.h]h$Start radar detection in the driver.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hY``end_cac`` End running CAC, probably because a related CAC was finished on another phy. h](j)}(h ``end_cac``h]j)}(hjh]hend_cac}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hLEnd running CAC, probably because a related CAC was finished on another phy.h]hLEnd running CAC, probably because a related CAC was finished on another phy.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubj)}(h``update_ft_ies`` Provide updated Fast BSS Transition information to the driver. If the SME is in the driver/firmware, this information can be used in building Authentication and Reassociation Request frames. h](j)}(h``update_ft_ies``h]j)}(hj0h]h update_ft_ies}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj*ubj6)}(hhh]h)}(hProvide updated Fast BSS Transition information to the driver. If the SME is in the driver/firmware, this information can be used in building Authentication and Reassociation Request frames.h]hProvide updated Fast BSS Transition information to the driver. If the SME is in the driver/firmware, this information can be used in building Authentication and Reassociation Request frames.}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjFubah}(h]h ]h"]h$]h&]uh1j5hj*ubeh}(h]h ]h"]h$]h&]uh1jhjEhMhjubj)}(h``crit_proto_start`` Indicates a critical protocol needs more link reliability for a given duration (milliseconds). The protocol is provided so the driver can take the most appropriate actions. h](j)}(h``crit_proto_start``h]j)}(hjjh]hcrit_proto_start}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjdubj6)}(hhh]h)}(hIndicates a critical protocol needs more link reliability for a given duration (milliseconds). The protocol is provided so the driver can take the most appropriate actions.h]hIndicates a critical protocol needs more link reliability for a given duration (milliseconds). The protocol is provided so the driver can take the most appropriate actions.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjdubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hy``crit_proto_stop`` Indicates critical protocol no longer needs increased link reliability. This operation can not fail. h](j)}(h``crit_proto_stop``h]j)}(hjh]hcrit_proto_stop}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hdIndicates critical protocol no longer needs increased link reliability. This operation can not fail.h]hdIndicates critical protocol no longer needs increased link reliability. This operation can not fail.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h*``set_coalesce`` Set coalesce parameters. h](j)}(h``set_coalesce``h]j)}(hjh]h set_coalesce}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hSet coalesce parameters.h]hSet coalesce parameters.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hXm``channel_switch`` initiate channel-switch procedure (with CSA). Driver is responsible for veryfing if the switch is possible. Since this is inherently tricky driver may decide to disconnect an interface later with cfg80211_stop_iface(). This doesn't mean driver can accept everything. It should do it's best to verify requests and reject them as soon as possible. h](j)}(h``channel_switch``h]j)}(hjh]hchannel_switch}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hXYinitiate channel-switch procedure (with CSA). Driver is responsible for veryfing if the switch is possible. Since this is inherently tricky driver may decide to disconnect an interface later with cfg80211_stop_iface(). This doesn't mean driver can accept everything. It should do it's best to verify requests and reject them as soon as possible.h]hX]initiate channel-switch procedure (with CSA). Driver is responsible for veryfing if the switch is possible. Since this is inherently tricky driver may decide to disconnect an interface later with cfg80211_stop_iface(). This doesn’t mean driver can accept everything. It should do it’s best to verify requests and reject them as soon as possible.}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj-ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj,hMhjubj)}(h:``set_qos_map`` Set QoS mapping information to the driver h](j)}(h``set_qos_map``h]j)}(hjQh]h set_qos_map}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjKubj6)}(hhh]h)}(h)Set QoS mapping information to the driverh]h)Set QoS mapping information to the driver}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhMhjgubah}(h]h ]h"]h$]h&]uh1j5hjKubeh}(h]h ]h"]h$]h&]uh1jhjfhMhjubj)}(h``set_ap_chanwidth`` Set the AP (including P2P GO) mode channel width for the given interface This is used e.g. for dynamic HT 20/40 MHz channel width changes during the lifetime of the BSS. h](j)}(h``set_ap_chanwidth``h]j)}(hjh]hset_ap_chanwidth}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hSet the AP (including P2P GO) mode channel width for the given interface This is used e.g. for dynamic HT 20/40 MHz channel width changes during the lifetime of the BSS.h]hSet the AP (including P2P GO) mode channel width for the given interface This is used e.g. for dynamic HT 20/40 MHz channel width changes during the lifetime of the BSS.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX``add_tx_ts`` validate (if admitted_time is 0) or add a TX TS to the device with the given parameters; action frame exchange has been handled by userspace so this just has to modify the TX path to take the TS into account. If the admitted time is 0 just validate the parameters to make sure the session can be created at all; it is valid to just always return success for that but that may result in inefficient behaviour (handshake with the peer followed by immediate teardown when the addition is later rejected) h](j)}(h ``add_tx_ts``h]j)}(hjh]h add_tx_ts}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM%hjubj6)}(hhh]h)}(hXvalidate (if admitted_time is 0) or add a TX TS to the device with the given parameters; action frame exchange has been handled by userspace so this just has to modify the TX path to take the TS into account. If the admitted time is 0 just validate the parameters to make sure the session can be created at all; it is valid to just always return success for that but that may result in inefficient behaviour (handshake with the peer followed by immediate teardown when the addition is later rejected)h]hXvalidate (if admitted_time is 0) or add a TX TS to the device with the given parameters; action frame exchange has been handled by userspace so this just has to modify the TX path to take the TS into account. If the admitted time is 0 just validate the parameters to make sure the session can be created at all; it is valid to just always return success for that but that may result in inefficient behaviour (handshake with the peer followed by immediate teardown when the addition is later rejected)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM%hjubj)}(h'``del_tx_ts`` remove an existing TX TS h](j)}(h ``del_tx_ts``h]j)}(hjh]h del_tx_ts}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM&hjubj6)}(hhh]h)}(hremove an existing TX TSh]hremove an existing TX TS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM&hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM&hjubj)}(h``tdls_channel_switch`` Start channel-switching with a TDLS peer. The driver is responsible for continually initiating channel-switching operations and returning to the base channel for communication with the AP. h](j)}(h``tdls_channel_switch``h]j)}(hj7h]htdls_channel_switch}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM/hj1ubj6)}(hhh]h)}(hStart channel-switching with a TDLS peer. The driver is responsible for continually initiating channel-switching operations and returning to the base channel for communication with the AP.h]hStart channel-switching with a TDLS peer. The driver is responsible for continually initiating channel-switching operations and returning to the base channel for communication with the AP.}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM-hjMubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhjLhM/hjubj)}(h``tdls_cancel_channel_switch`` Stop channel-switching with a TDLS peer. Both peers must be on the base channel when the call completes. h](j)}(h``tdls_cancel_channel_switch``h]j)}(hjqh]htdls_cancel_channel_switch}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM1hjkubj6)}(hhh]h)}(hhStop channel-switching with a TDLS peer. Both peers must be on the base channel when the call completes.h]hhStop channel-switching with a TDLS peer. Both peers must be on the base channel when the call completes.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM0hjubah}(h]h ]h"]h$]h&]uh1j5hjkubeh}(h]h ]h"]h$]h&]uh1jhjhM1hjubj)}(h'``start_nan`` Start the NAN interface. h](j)}(h ``start_nan``h]j)}(hjh]h start_nan}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM2hjubj6)}(hhh]h)}(hStart the NAN interface.h]hStart the NAN interface.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM2hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM2hjubj)}(h%``stop_nan`` Stop the NAN interface. h](j)}(h ``stop_nan``h]j)}(hjh]hstop_nan}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM3hjubj6)}(hhh]h)}(hStop the NAN interface.h]hStop the NAN interface.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM3hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM3hjubj)}(hXw``add_nan_func`` Add a NAN function. Returns negative value on failure. On success **nan_func** ownership is transferred to the driver and it may access it outside of the scope of this function. The driver should free the **nan_func** when no longer needed by calling cfg80211_free_nan_func(). On success the driver should assign an instance_id in the provided **nan_func**. h](j)}(h``add_nan_func``h]j)}(hjh]h add_nan_func}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM:hjubj6)}(hhh]h)}(hXeAdd a NAN function. Returns negative value on failure. On success **nan_func** ownership is transferred to the driver and it may access it outside of the scope of this function. The driver should free the **nan_func** when no longer needed by calling cfg80211_free_nan_func(). On success the driver should assign an instance_id in the provided **nan_func**.h](hBAdd a NAN function. Returns negative value on failure. On success }(hj6hhhNhNubj)}(h **nan_func**h]hnan_func}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6ubh ownership is transferred to the driver and it may access it outside of the scope of this function. The driver should free the }(hj6hhhNhNubj)}(h **nan_func**h]hnan_func}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6ubh when no longer needed by calling cfg80211_free_nan_func(). On success the driver should assign an instance_id in the provided }(hj6hhhNhNubj)}(h **nan_func**h]hnan_func}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6ubh.}(hj6hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM4hj3ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj2hM:hjubj)}(h(``del_nan_func`` Delete a NAN function. h](j)}(h``del_nan_func``h]j)}(hjh]h del_nan_func}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM;hjubj6)}(hhh]h)}(hDelete a NAN function.h]hDelete a NAN function.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM;hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM;hjubj)}(h``nan_change_conf`` changes NAN configuration. The changed parameters must be specified in **changes** (using :c:type:`enum cfg80211_nan_conf_changes `); All other parameters must be ignored. h](j)}(h``nan_change_conf``h]j)}(hjh]hnan_change_conf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM>hjubj6)}(hhh]h)}(hchanges NAN configuration. The changed parameters must be specified in **changes** (using :c:type:`enum cfg80211_nan_conf_changes `); All other parameters must be ignored.h](hGchanges NAN configuration. The changed parameters must be specified in }(hjhhhNhNubj)}(h **changes**h]hchanges}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh (using }(hjhhhNhNubh)}(hD:c:type:`enum cfg80211_nan_conf_changes `h]j)}(hjh]henum cfg80211_nan_conf_changes}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6cfg80211_nan_conf_changesuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM<hjubh(); All other parameters must be ignored.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM<hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM>hjubj)}(hO``set_multicast_to_unicast`` configure multicast to unicast conversion for BSS h](j)}(h``set_multicast_to_unicast``h]j)}(hj5h]hset_multicast_to_unicast}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM@hj/ubj6)}(hhh]h)}(h1configure multicast to unicast conversion for BSSh]h1configure multicast to unicast conversion for BSS}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJhM@hjKubah}(h]h ]h"]h$]h&]uh1j5hj/ubeh}(h]h ]h"]h$]h&]uh1jhjJhM@hjubj)}(h``get_txq_stats`` Get TXQ stats for interface or phy. If wdev is ``NULL``, this function should return phy stats, and interface stats otherwise. h](j)}(h``get_txq_stats``h]j)}(hjnh]h get_txq_stats}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMChjhubj6)}(hhh]h)}(h~Get TXQ stats for interface or phy. If wdev is ``NULL``, this function should return phy stats, and interface stats otherwise.h](h/Get TXQ stats for interface or phy. If wdev is }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhG, this function should return phy stats, and interface stats otherwise.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMBhjubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhMChjubj)}(h``set_pmk`` configure the PMK to be used for offloaded 802.1X 4-Way handshake. If not deleted through **del_pmk** the PMK remains valid until disconnect upon which the driver should clear it. (invoked with the wireless_dev mutex held) h](j)}(h ``set_pmk``h]j)}(hjh]hset_pmk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMHhjubj6)}(hhh]h)}(hconfigure the PMK to be used for offloaded 802.1X 4-Way handshake. If not deleted through **del_pmk** the PMK remains valid until disconnect upon which the driver should clear it. (invoked with the wireless_dev mutex held)h](hZconfigure the PMK to be used for offloaded 802.1X 4-Way handshake. If not deleted through }(hjhhhNhNubj)}(h **del_pmk**h]hdel_pmk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubhy the PMK remains valid until disconnect upon which the driver should clear it. (invoked with the wireless_dev mutex held)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMEhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMHhjubj)}(hy``del_pmk`` delete the previously configured PMK for the given authenticator. (invoked with the wireless_dev mutex held) h](j)}(h ``del_pmk``h]j)}(hjh]hdel_pmk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMJhjubj6)}(hhh]h)}(hldelete the previously configured PMK for the given authenticator. (invoked with the wireless_dev mutex held)h]hldelete the previously configured PMK for the given authenticator. (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMIhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMJhjubj)}(hZ``external_auth`` indicates result of offloaded authentication processing from user space h](j)}(h``external_auth``h]j)}(hj@h]h external_auth}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMMhj:ubj6)}(hhh]h)}(hGindicates result of offloaded authentication processing from user spaceh]hGindicates result of offloaded authentication processing from user space}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMLhjVubah}(h]h ]h"]h$]h&]uh1j5hj:ubeh}(h]h ]h"]h$]h&]uh1jhjUhMMhjubj)}(h``tx_control_port`` TX a control port frame (EAPoL). The noencrypt parameter tells the driver that the frame should not be encrypted. h](j)}(h``tx_control_port``h]j)}(hjzh]htx_control_port}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMPhjtubj6)}(hhh]h)}(hrTX a control port frame (EAPoL). The noencrypt parameter tells the driver that the frame should not be encrypted.h]hrTX a control port frame (EAPoL). The noencrypt parameter tells the driver that the frame should not be encrypted.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMOhjubah}(h]h ]h"]h$]h&]uh1j5hjtubeh}(h]h ]h"]h$]h&]uh1jhjhMPhjubj)}(h``get_ftm_responder_stats`` Retrieve FTM responder statistics, if available. Statistics should be cumulative, currently no way to reset is provided. h](j)}(h``get_ftm_responder_stats``h]j)}(hjh]hget_ftm_responder_stats}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMShjubj6)}(hhh]h)}(hxRetrieve FTM responder statistics, if available. Statistics should be cumulative, currently no way to reset is provided.h]hxRetrieve FTM responder statistics, if available. Statistics should be cumulative, currently no way to reset is provided.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMRhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMShjubj)}(h1``start_pmsr`` start peer measurement (e.g. FTM) h](j)}(h``start_pmsr``h]j)}(hjh]h start_pmsr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMThjubj6)}(hhh]h)}(h!start peer measurement (e.g. FTM)h]h!start peer measurement (e.g. FTM)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMThjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMThjubj)}(h&``abort_pmsr`` abort peer measurement h](j)}(h``abort_pmsr``h]j)}(hj'h]h abort_pmsr}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMUhj!ubj6)}(hhh]h)}(habort peer measurementh]habort peer measurement}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hMUhj=ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj<hMUhjubj)}(h``update_owe_info`` Provide updated OWE info to driver. Driver implementing SME but offloading OWE processing to the user space will get the updated DH IE through this interface. h](j)}(h``update_owe_info``h]j)}(hj`h]hupdate_owe_info}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMYhjZubj6)}(hhh]h)}(hProvide updated OWE info to driver. Driver implementing SME but offloading OWE processing to the user space will get the updated DH IE through this interface.h]hProvide updated OWE info to driver. Driver implementing SME but offloading OWE processing to the user space will get the updated DH IE through this interface.}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMWhjvubah}(h]h ]h"]h$]h&]uh1j5hjZubeh}(h]h ]h"]h$]h&]uh1jhjuhMYhjubj)}(h|``probe_mesh_link`` Probe direct Mesh peer's link quality by sending data frame and overrule HWMP path selection algorithm. h](j)}(h``probe_mesh_link``h]j)}(hjh]hprobe_mesh_link}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM\hjubj6)}(hhh]h)}(hgProbe direct Mesh peer's link quality by sending data frame and overrule HWMP path selection algorithm.h]hiProbe direct Mesh peer’s link quality by sending data frame and overrule HWMP path selection algorithm.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM[hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM\hjubj)}(hi``set_tid_config`` TID specific configuration, this can be peer or BSS specific This callback may sleep. h](j)}(h``set_tid_config``h]j)}(hjh]hset_tid_config}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM^hjubj6)}(hhh]h)}(hUTID specific configuration, this can be peer or BSS specific This callback may sleep.h]hUTID specific configuration, this can be peer or BSS specific This callback may sleep.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM]hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM^hjubj)}(hq``reset_tid_config`` Reset TID specific configuration for the peer, for the given TIDs. This callback may sleep. h](j)}(h``reset_tid_config``h]j)}(hjh]hreset_tid_config}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM`hjubj6)}(hhh]h)}(h[Reset TID specific configuration for the peer, for the given TIDs. This callback may sleep.h]h[Reset TID specific configuration for the peer, for the given TIDs. This callback may sleep.}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM_hj$ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj#hM`hjubj)}(h6``set_sar_specs`` Update the SAR (TX power) settings. h](j)}(h``set_sar_specs``h]j)}(hjHh]h set_sar_specs}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMbhjBubj6)}(hhh]h)}(h#Update the SAR (TX power) settings.h]h#Update the SAR (TX power) settings.}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]hMbhj^ubah}(h]h ]h"]h$]h&]uh1j5hjBubeh}(h]h ]h"]h$]h&]uh1jhj]hMbhjubj)}(h*``color_change`` Initiate a color change. h](j)}(h``color_change``h]j)}(hjh]h color_change}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMdhj{ubj6)}(hhh]h)}(hInitiate a color change.h]hInitiate a color change.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMdhjubah}(h]h ]h"]h$]h&]uh1j5hj{ubeh}(h]h ]h"]h$]h&]uh1jhjhMdhjubj)}(h``set_fils_aad`` Set FILS AAD data to the AP driver so that the driver can use those to decrypt (Re)Association Request and encrypt (Re)Association Response frame. h](j)}(h``set_fils_aad``h]j)}(hjh]h set_fils_aad}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhhjubj6)}(hhh]h)}(hSet FILS AAD data to the AP driver so that the driver can use those to decrypt (Re)Association Request and encrypt (Re)Association Response frame.h]hSet FILS AAD data to the AP driver so that the driver can use those to decrypt (Re)Association Request and encrypt (Re)Association Response frame.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMfhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhhjubj)}(hX``set_radar_background`` Configure dedicated offchannel chain available for radar/CAC detection on some hw. This chain can't be used to transmit or receive frames and it is bounded to a running wdev. Background radar/CAC detection allows to avoid the CAC downtime switching to a different channel during CAC detection on the selected radar channel. The caller is expected to set chandef pointer to NULL in order to disable background CAC/radar detection. h](j)}(h``set_radar_background``h]j)}(hjh]hset_radar_background}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMqhjubj6)}(hhh]h)}(hXConfigure dedicated offchannel chain available for radar/CAC detection on some hw. This chain can't be used to transmit or receive frames and it is bounded to a running wdev. Background radar/CAC detection allows to avoid the CAC downtime switching to a different channel during CAC detection on the selected radar channel. The caller is expected to set chandef pointer to NULL in order to disable background CAC/radar detection.h]hXConfigure dedicated offchannel chain available for radar/CAC detection on some hw. This chain can’t be used to transmit or receive frames and it is bounded to a running wdev. Background radar/CAC detection allows to avoid the CAC downtime switching to a different channel during CAC detection on the selected radar channel. The caller is expected to set chandef pointer to NULL in order to disable background CAC/radar detection.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMjhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMqhjubj)}(h.``add_link_station`` Add a link to a station. h](j)}(h``add_link_station``h]j)}(hj.h]hadd_link_station}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMrhj(ubj6)}(hhh]h)}(hAdd a link to a station.h]hAdd a link to a station.}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChMrhjDubah}(h]h ]h"]h$]h&]uh1j5hj(ubeh}(h]h ]h"]h$]h&]uh1jhjChMrhjubj)}(h1``mod_link_station`` Modify a link of a station. h](j)}(h``mod_link_station``h]j)}(hjgh]hmod_link_station}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMshjaubj6)}(hhh]h)}(hModify a link of a station.h]hModify a link of a station.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hMshj}ubah}(h]h ]h"]h$]h&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hMshjubj)}(h1``del_link_station`` Remove a link of a station. h](j)}(h``del_link_station``h]j)}(hjh]hdel_link_station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMthjubj6)}(hhh]h)}(hRemove a link of a station.h]hRemove a link of a station.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMthjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMthjubj)}(hF``set_hw_timestamp`` Enable/disable HW timestamping of TM/FTM frames. h](j)}(h``set_hw_timestamp``h]j)}(hjh]hset_hw_timestamp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMvhjubj6)}(hhh]h)}(h0Enable/disable HW timestamping of TM/FTM frames.h]h0Enable/disable HW timestamping of TM/FTM frames.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMvhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMvhjubj)}(h*``set_ttlm`` set the TID to link mapping. h](j)}(h ``set_ttlm``h]j)}(hjh]hset_ttlm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMwhj ubj6)}(hhh]h)}(hset the TID to link mapping.h]hset the TID to link mapping.}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hMwhj(ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj'hMwhjubj)}(hU``get_radio_mask`` get bitmask of radios in use. (invoked with the wiphy mutex held) h](j)}(h``get_radio_mask``h]j)}(hjKh]hget_radio_mask}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMzhjEubj6)}(hhh]h)}(hAget bitmask of radios in use. (invoked with the wiphy mutex held)h]hAget bitmask of radios in use. (invoked with the wiphy mutex held)}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMyhjaubah}(h]h ]h"]h$]h&]uh1j5hjEubeh}(h]h ]h"]h$]h&]uh1jhj`hMzhjubj)}(hXV``assoc_ml_reconf`` Request a non-AP MLO connection to perform ML reconfiguration, i.e., add and/or remove links to/from the association using ML reconfiguration action frames. Successfully added links will be added to the set of valid links. Successfully removed links will be removed from the set of valid links. The driver must indicate removed links by calling cfg80211_links_removed() and added links by calling cfg80211_mlo_reconf_add_done(). When calling cfg80211_mlo_reconf_add_done() the bss pointer must be given for each link for which MLO reconfiguration 'add' operation was requested. h](j)}(h``assoc_ml_reconf``h]j)}(hjh]hassoc_ml_reconf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hXARequest a non-AP MLO connection to perform ML reconfiguration, i.e., add and/or remove links to/from the association using ML reconfiguration action frames. Successfully added links will be added to the set of valid links. Successfully removed links will be removed from the set of valid links. The driver must indicate removed links by calling cfg80211_links_removed() and added links by calling cfg80211_mlo_reconf_add_done(). When calling cfg80211_mlo_reconf_add_done() the bss pointer must be given for each link for which MLO reconfiguration 'add' operation was requested.h]hXERequest a non-AP MLO connection to perform ML reconfiguration, i.e., add and/or remove links to/from the association using ML reconfiguration action frames. Successfully added links will be added to the set of valid links. Successfully removed links will be removed from the set of valid links. The driver must indicate removed links by calling cfg80211_links_removed() and added links by calling cfg80211_mlo_reconf_add_done(). When calling cfg80211_mlo_reconf_add_done() the bss pointer must be given for each link for which MLO reconfiguration ‘add’ operation was requested.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM{hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h2``set_epcs`` Enable/Disable EPCS for station mode.h](j)}(h ``set_epcs``h]j)}(hjh]hset_epcs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMwhjubj6)}(hhh]h)}(h%Enable/Disable EPCS for station mode.h]h%Enable/Disable EPCS for station mode.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMxhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMwhjubeh}(h]h ]h"]h$]h&]uh1jhjlubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM{hj^bhhubh)}(hThis struct is registered by fullmac card drivers and/or wireless stacks in order to handle configuration requests on their interfaces.h]hThis struct is registered by fullmac card drivers and/or wireless stacks in order to handle configuration requests on their interfaces.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubh)}(h_All callbacks except where otherwise noted should return 0 on success or a negative error code.h]h_All callbacks except where otherwise noted should return 0 on success or a negative error code.}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubh)}(hXAll operations are invoked with the wiphy mutex held. The RTNL may be held in addition (due to wireless extensions) but this cannot be relied upon except in cases where documented below. Note that due to ordering, the RTNL also cannot be acquired in any handlers.h]hXAll operations are invoked with the wiphy mutex held. The RTNL may be held in addition (due to wireless extensions) but this cannot be relied upon except in cases where documented below. Note that due to ordering, the RTNL also cannot be acquired in any handlers.}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_rx_mlme_mgmt (C function)c.cfg80211_rx_mlme_mgmthNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hNvoid cfg80211_rx_mlme_mgmt (struct net_device *dev, const u8 *buf, size_t len)h]jo)}(hMvoid cfg80211_rx_mlme_mgmt(struct net_device *dev, const u8 *buf, size_t len)h](j)}(hvoidh]hvoid}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMCubj)}(h h]h }(hjmhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZhhhjlhMCubj)}(hcfg80211_rx_mlme_mgmth]j)}(hcfg80211_rx_mlme_mgmth]hcfg80211_rx_mlme_mgmt}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjZhhhjlhMCubj)}(h3(struct net_device *dev, const u8 *buf, size_t len)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}jjsbc.cfg80211_rx_mlme_mgmtasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h const u8 *bufh](ju)}(hjHh]hconst}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(hu8h]hu8}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj-modnameN classnameNj j )}j ]jc.cfg80211_rx_mlme_mgmtasbuh1hhj ubj)}(h h]h }(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj.)}(hj1h]h*}(hjWhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj ubj)}(hbufh]hbuf}(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h size_t lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_rx_mlme_mgmtasbuh1hhjyubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjyubj)}(hlenh]hlen}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjyubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjZhhhjlhMCubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjVhhhjlhMCubah}(h]jQah ](jjeh"]h$]h&]jj)jhuh1jhhjlhMChjShhubj)}(hhh]h)}(h/notification of processed MLME management frameh]h/notification of processed MLME management frame}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMChjhhubah}(h]h ]h"]h$]h&]uh1jhjShhhjlhMCubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhj^bhNhNubj)}(hX**Parameters** ``struct net_device *dev`` network device ``const u8 *buf`` authentication frame (header + body) ``size_t len`` length of the frame data **Description** This function is called whenever an authentication, disassociation or deauthentication frame has been received and processed in station mode. After being asked to authenticate via cfg80211_ops::auth() the driver must call either this function or cfg80211_auth_timeout(). After being asked to associate via cfg80211_ops::assoc() the driver must call either this function or cfg80211_auth_timeout(). While connected, the driver must calls this for received and processed disassociation and deauthentication frames. If the frame couldn't be used because it was unprotected, the driver must call the function cfg80211_rx_unprot_mlme_mgmt() instead. This function may sleep. The caller must hold the corresponding wdev's mutex.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMGhjubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hjh]hstruct net_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMDhjubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,hMDhj-ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj,hMDhjubj)}(h7``const u8 *buf`` authentication frame (header + body) h](j)}(h``const u8 *buf``h]j)}(hjPh]h const u8 *buf}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMEhjJubj6)}(hhh]h)}(h$authentication frame (header + body)h]h$authentication frame (header + body)}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehMEhjfubah}(h]h ]h"]h$]h&]uh1j5hjJubeh}(h]h ]h"]h$]h&]uh1jhjehMEhjubj)}(h(``size_t len`` length of the frame data h](j)}(h``size_t len``h]j)}(hjh]h size_t len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMFhjubj6)}(hhh]h)}(hlength of the frame datah]hlength of the frame data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMFhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMFhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMHhjubh)}(hXThis function is called whenever an authentication, disassociation or deauthentication frame has been received and processed in station mode. After being asked to authenticate via cfg80211_ops::auth() the driver must call either this function or cfg80211_auth_timeout(). After being asked to associate via cfg80211_ops::assoc() the driver must call either this function or cfg80211_auth_timeout(). While connected, the driver must calls this for received and processed disassociation and deauthentication frames. If the frame couldn't be used because it was unprotected, the driver must call the function cfg80211_rx_unprot_mlme_mgmt() instead.h]hXThis function is called whenever an authentication, disassociation or deauthentication frame has been received and processed in station mode. After being asked to authenticate via cfg80211_ops::auth() the driver must call either this function or cfg80211_auth_timeout(). After being asked to associate via cfg80211_ops::assoc() the driver must call either this function or cfg80211_auth_timeout(). While connected, the driver must calls this for received and processed disassociation and deauthentication frames. If the frame couldn’t be used because it was unprotected, the driver must call the function cfg80211_rx_unprot_mlme_mgmt() instead.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMGhjubh)}(hMThis function may sleep. The caller must hold the corresponding wdev's mutex.h]hOThis function may sleep. The caller must hold the corresponding wdev’s mutex.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMRhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_auth_timeout (C function)c.cfg80211_auth_timeouthNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hCvoid cfg80211_auth_timeout (struct net_device *dev, const u8 *addr)h]jo)}(hBvoid cfg80211_auth_timeout(struct net_device *dev, const u8 *addr)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMXubj)}(h h]h }(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhj&hMXubj)}(hcfg80211_auth_timeouth]j)}(hcfg80211_auth_timeouth]hcfg80211_auth_timeout}(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhj&hMXubj)}(h((struct net_device *dev, const u8 *addr)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjQubj)}(h h]h }(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQubh)}(hhh]j)}(h net_deviceh]h net_device}(hjshhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjumodnameN classnameNj j )}j ]j)}jj;sbc.cfg80211_auth_timeoutasbuh1hhjQubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjQubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjMubj)}(hconst u8 *addrh](ju)}(hjHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_auth_timeoutasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(haddrh]haddr}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjMubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhj&hMXubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhj&hMXubah}(h]j ah ](jjeh"]h$]h&]jj)jhuh1jhhj&hMXhj hhubj)}(hhh]h)}(h(notification of timed out authenticationh]h(notification of timed out authentication}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMXhjEhhubah}(h]h ]h"]h$]h&]uh1jhj hhhj&hMXubeh}(h]h ](j$functioneh"]h$]h&]jj$jj`jj`jjjuh1jchhhj^bhNhNubj)}(h**Parameters** ``struct net_device *dev`` network device ``const u8 *addr`` The MAC address of the device with which the authentication timed out **Description** This function may sleep. The caller must hold the corresponding wdev's mutex.h](h)}(h**Parameters**h]j)}(hjjh]h Parameters}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM\hjdubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hjh]hstruct net_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMYhjubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMYhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMYhjubj)}(hY``const u8 *addr`` The MAC address of the device with which the authentication timed out h](j)}(h``const u8 *addr``h]j)}(hjh]hconst u8 *addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMZhjubj6)}(hhh]h)}(hEThe MAC address of the device with which the authentication timed outh]hEThe MAC address of the device with which the authentication timed out}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMZhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMZhjubeh}(h]h ]h"]h$]h&]uh1jhjdubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM\hjdubh)}(hMThis function may sleep. The caller must hold the corresponding wdev's mutex.h]hOThis function may sleep. The caller must hold the corresponding wdev’s mutex.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM[hjdubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_#cfg80211_rx_assoc_resp (C function)c.cfg80211_rx_assoc_resphNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hdvoid cfg80211_rx_assoc_resp (struct net_device *dev, const struct cfg80211_rx_assoc_resp_data *data)h]jo)}(hcvoid cfg80211_rx_assoc_resp(struct net_device *dev, const struct cfg80211_rx_assoc_resp_data *data)h](j)}(hvoidh]hvoid}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>hhhjPhMubj)}(hcfg80211_rx_assoc_resph]j)}(hcfg80211_rx_assoc_resph]hcfg80211_rx_assoc_resp}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj>hhhjPhMubj)}(hH(struct net_device *dev, const struct cfg80211_rx_assoc_resp_data *data)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj{ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}jjesbc.cfg80211_rx_assoc_respasbuh1hhj{ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj{ubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjwubj)}(h.const struct cfg80211_rx_assoc_resp_data *datah](ju)}(hjHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubju)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hcfg80211_rx_assoc_resp_datah]hcfg80211_rx_assoc_resp_data}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj,modnameN classnameNj j )}j ]jc.cfg80211_rx_assoc_respasbuh1hhjubj)}(h h]h }(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjVhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hdatah]hdata}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjwubeh}(h]h ]h"]h$]h&]jjuh1jhj>hhhjPhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj:hhhjPhMubah}(h]j5ah ](jjeh"]h$]h&]jj)jhuh1jhhjPhMhj7hhubj)}(hhh]h)}(h.notification of processed association responseh]h.notification of processed association response}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhj7hhhjPhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhj^bhNhNubj)}(hX**Parameters** ``struct net_device *dev`` network device ``const struct cfg80211_rx_assoc_resp_data *data`` association response data, :c:type:`struct cfg80211_rx_assoc_resp_data ` **Description** After being asked to associate via cfg80211_ops::assoc() the driver must call either this function or cfg80211_auth_timeout(). This function may sleep. The caller must hold the corresponding wdev's mutex.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hjh]hstruct net_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``const struct cfg80211_rx_assoc_resp_data *data`` association response data, :c:type:`struct cfg80211_rx_assoc_resp_data ` h](j)}(h2``const struct cfg80211_rx_assoc_resp_data *data``h]j)}(hjh]h.const struct cfg80211_rx_assoc_resp_data *data}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(heassociation response data, :c:type:`struct cfg80211_rx_assoc_resp_data `h](hassociation response data, }(hj hhhNhNubh)}(hJ:c:type:`struct cfg80211_rx_assoc_resp_data `h]j)}(hj*h]h"struct cfg80211_rx_assoc_resp_data}(hj,hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6cfg80211_rx_assoc_resp_datauh1hhjhMhj ubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjah]h Description}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh)}(h~After being asked to associate via cfg80211_ops::assoc() the driver must call either this function or cfg80211_auth_timeout().h]h~After being asked to associate via cfg80211_ops::assoc() the driver must call either this function or cfg80211_auth_timeout().}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh)}(hMThis function may sleep. The caller must hold the corresponding wdev's mutex.h]hOThis function may sleep. The caller must hold the corresponding wdev’s mutex.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_tx_mlme_mgmt (C function)c.cfg80211_tx_mlme_mgmthNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(h^void cfg80211_tx_mlme_mgmt (struct net_device *dev, const u8 *buf, size_t len, bool reconnect)h]jo)}(h]void cfg80211_tx_mlme_mgmt(struct net_device *dev, const u8 *buf, size_t len, bool reconnect)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubj)}(hcfg80211_tx_mlme_mgmth]j)}(hcfg80211_tx_mlme_mgmth]hcfg80211_tx_mlme_mgmt}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMubj)}(hC(struct net_device *dev, const u8 *buf, size_t len, bool reconnect)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}jjsbc.cfg80211_tx_mlme_mgmtasbuh1hhjubj)}(h h]h }(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hj>hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hdevh]hdev}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h const u8 *bufh](ju)}(hjHh]hconst}(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj`ubj)}(h h]h }(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j,c.cfg80211_tx_mlme_mgmtasbuh1hhj`ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj`ubj)}(hbufh]hbuf}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h size_t lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j,c.cfg80211_tx_mlme_mgmtasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hlenh]hlen}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hbool reconnecth](j)}(hboolh]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h reconnecth]h reconnect}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMhjhhubj)}(hhh]h)}(h1notification of transmitted deauth/disassoc frameh]h1notification of transmitted deauth/disassoc frame}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj_hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjzjjzjjjuh1jchhhj^bhNhNubj)}(hX**Parameters** ``struct net_device *dev`` network device ``const u8 *buf`` 802.11 frame (header + body) ``size_t len`` length of the frame data ``bool reconnect`` immediate reconnect is desired (include the nl80211 attribute) **Description** This function is called whenever deauthentication has been processed in station mode. This includes both received deauthentication frames and locally generated ones. This function may sleep. The caller must hold the corresponding wdev's mutex.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj~ubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hjh]hstruct net_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h/``const u8 *buf`` 802.11 frame (header + body) h](j)}(h``const u8 *buf``h]j)}(hjh]h const u8 *buf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h802.11 frame (header + body)h]h802.11 frame (header + body)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h(``size_t len`` length of the frame data h](j)}(h``size_t len``h]j)}(hjh]h size_t len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hlength of the frame datah]hlength of the frame data}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hMhj+ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj*hMhjubj)}(hR``bool reconnect`` immediate reconnect is desired (include the nl80211 attribute) h](j)}(h``bool reconnect``h]j)}(hjNh]hbool reconnect}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjHubj6)}(hhh]h)}(h>immediate reconnect is desired (include the nl80211 attribute)h]h>immediate reconnect is desired (include the nl80211 attribute)}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjchMhjdubah}(h]h ]h"]h$]h&]uh1j5hjHubeh}(h]h ]h"]h$]h&]uh1jhjchMhjubeh}(h]h ]h"]h$]h&]uh1jhj~ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj~ubh)}(hThis function is called whenever deauthentication has been processed in station mode. This includes both received deauthentication frames and locally generated ones. This function may sleep. The caller must hold the corresponding wdev's mutex.h]hThis function is called whenever deauthentication has been processed in station mode. This includes both received deauthentication frames and locally generated ones. This function may sleep. The caller must hold the corresponding wdev’s mutex.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj~ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_)cfg80211_michael_mic_failure (C function)c.cfg80211_michael_mic_failurehNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hvoid cfg80211_michael_mic_failure (struct net_device *dev, const u8 *addr, enum nl80211_key_type key_type, int key_id, const u8 *tsc, gfp_t gfp)h]jo)}(hvoid cfg80211_michael_mic_failure(struct net_device *dev, const u8 *addr, enum nl80211_key_type key_type, int key_id, const u8 *tsc, gfp_t gfp)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubj)}(hcfg80211_michael_mic_failureh]j)}(hcfg80211_michael_mic_failureh]hcfg80211_michael_mic_failure}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMubj)}(hn(struct net_device *dev, const u8 *addr, enum nl80211_key_type key_type, int key_id, const u8 *tsc, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(h net_deviceh]h net_device}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj+modnameN classnameNj j )}j ]j)}jjsbc.cfg80211_michael_mic_failureasbuh1hhjubj)}(h h]h }(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjWhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hdevh]hdev}(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *addrh](ju)}(hjHh]hconst}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjyubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjyubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jEc.cfg80211_michael_mic_failureasbuh1hhjyubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjyubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjyubj)}(haddrh]haddr}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjyubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(henum nl80211_key_type key_typeh](ju)}(hjxh]henum}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hnl80211_key_typeh]hnl80211_key_type}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNj j )}j ]jEc.cfg80211_michael_mic_failureasbuh1hhjubj)}(h h]h }(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hkey_typeh]hkey_type}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h int key_idh](j)}(hinth]hint}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLubj)}(h h]h }(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLubj)}(hkey_idh]hkey_id}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h const u8 *tsch](ju)}(hjHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jEc.cfg80211_michael_mic_failureasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(htsch]htsc}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jEc.cfg80211_michael_mic_failureasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMhjhhubj)}(hhh]h)}(h*notification of Michael MIC failure (TKIP)h]h*notification of Michael MIC failure (TKIP)}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjKhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjfjjfjjjuh1jchhhj^bhNhNubj)}(hX-**Parameters** ``struct net_device *dev`` network device ``const u8 *addr`` The source MAC address of the frame ``enum nl80211_key_type key_type`` The key type that the received frame used ``int key_id`` Key identifier (0..3). Can be -1 if missing. ``const u8 *tsc`` The TSC value of the frame that generated the MIC failure (6 octets) ``gfp_t gfp`` allocation flags **Description** This function is called whenever the local MAC detects a MIC failure in a received frame. This matches with MLME-MICHAELMICFAILURE.indication() primitive.h](h)}(h**Parameters**h]j)}(hjph]h Parameters}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hjh]hstruct net_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h7``const u8 *addr`` The source MAC address of the frame h](j)}(h``const u8 *addr``h]j)}(hjh]hconst u8 *addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h#The source MAC address of the frameh]h#The source MAC address of the frame}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hM``enum nl80211_key_type key_type`` The key type that the received frame used h](j)}(h"``enum nl80211_key_type key_type``h]j)}(hjh]henum nl80211_key_type key_type}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h)The key type that the received frame usedh]h)The key type that the received frame used}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h<``int key_id`` Key identifier (0..3). Can be -1 if missing. h](j)}(h``int key_id``h]j)}(hj:h]h int key_id}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj4ubj6)}(hhh]h)}(h,Key identifier (0..3). Can be -1 if missing.h]h,Key identifier (0..3). Can be -1 if missing.}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhjOhMhjPubah}(h]h ]h"]h$]h&]uh1j5hj4ubeh}(h]h ]h"]h$]h&]uh1jhjOhMhjubj)}(hW``const u8 *tsc`` The TSC value of the frame that generated the MIC failure (6 octets) h](j)}(h``const u8 *tsc``h]j)}(hjsh]h const u8 *tsc}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjmubj6)}(hhh]h)}(hDThe TSC value of the frame that generated the MIC failure (6 octets)h]hDThe TSC value of the frame that generated the MIC failure (6 octets)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjmubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``gfp_t gfp`` allocation flags h](j)}(h ``gfp_t gfp``h]j)}(hjh]h gfp_t gfp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubh)}(hThis function is called whenever the local MAC detects a MIC failure in a received frame. This matches with MLME-MICHAELMICFAILURE.indication() primitive.h]hThis function is called whenever the local MAC detects a MIC failure in a received frame. This matches with MLME-MICHAELMICFAILURE.indication() primitive.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_!cfg80211_ibss_joined (C function)c.cfg80211_ibss_joinedhNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hqvoid cfg80211_ibss_joined (struct net_device *dev, const u8 *bssid, struct ieee80211_channel *channel, gfp_t gfp)h]jo)}(hpvoid cfg80211_ibss_joined(struct net_device *dev, const u8 *bssid, struct ieee80211_channel *channel, gfp_t gfp)h](j)}(hvoidh]hvoid}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(hhhj:hMubj)}(hcfg80211_ibss_joinedh]j)}(hcfg80211_ibss_joinedh]hcfg80211_ibss_joined}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIubah}(h]h ](jjeh"]h$]h&]jjuh1jhj(hhhj:hMubj)}(hW(struct net_device *dev, const u8 *bssid, struct ieee80211_channel *channel, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjeubj)}(h h]h }(hjvhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}jjOsbc.cfg80211_ibss_joinedasbuh1hhjeubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjeubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjaubj)}(hconst u8 *bssidh](ju)}(hjHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_ibss_joinedasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hj%hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hbssidh]hbssid}(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjaubj)}(h!struct ieee80211_channel *channelh](ju)}(hjh]hstruct}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjGubj)}(h h]h }(hjXhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGubh)}(hhh]j)}(hieee80211_channelh]hieee80211_channel}(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjkmodnameN classnameNj j )}j ]jc.cfg80211_ibss_joinedasbuh1hhjGubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjGubj)}(hchannelh]hchannel}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjaubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_ibss_joinedasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjaubeh}(h]h ]h"]h$]h&]jjuh1jhj(hhhj:hMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj$hhhj:hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhj:hMhj!hhubj)}(hhh]h)}(h*notify cfg80211 that device joined an IBSSh]h*notify cfg80211 that device joined an IBSS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhj!hhhj:hMubeh}(h]h ](j$functioneh"]h$]h&]jj$jj,jj,jjjuh1jchhhj^bhNhNubj)}(hXz**Parameters** ``struct net_device *dev`` network device ``const u8 *bssid`` the BSSID of the IBSS joined ``struct ieee80211_channel *channel`` the channel of the IBSS joined ``gfp_t gfp`` allocation flags **Description** This function notifies cfg80211 that the device joined an IBSS or switched to a different BSSID. Before this function can be called, either a beacon has to have been received from the IBSS, or one of the cfg80211_inform_bss{,_frame} functions must have been called with the locally generated beacon -- this guarantees that there is always a scan result for this IBSS. cfg80211 will handle the rest.h](h)}(h**Parameters**h]j)}(hj6h]h Parameters}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj0ubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hjUh]hstruct net_device *dev}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjOubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjhMhjkubah}(h]h ]h"]h$]h&]uh1j5hjOubeh}(h]h ]h"]h$]h&]uh1jhjjhMhjLubj)}(h1``const u8 *bssid`` the BSSID of the IBSS joined h](j)}(h``const u8 *bssid``h]j)}(hjh]hconst u8 *bssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hthe BSSID of the IBSS joinedh]hthe BSSID of the IBSS joined}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjLubj)}(hE``struct ieee80211_channel *channel`` the channel of the IBSS joined h](j)}(h%``struct ieee80211_channel *channel``h]j)}(hjh]h!struct ieee80211_channel *channel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hthe channel of the IBSS joinedh]hthe channel of the IBSS joined}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjLubj)}(h``gfp_t gfp`` allocation flags h](j)}(h ``gfp_t gfp``h]j)}(hjh]h gfp_t gfp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjLubeh}(h]h ]h"]h$]h&]uh1jhj0ubh)}(h**Description**h]j)}(hj;h]h Description}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj0ubh)}(hXThis function notifies cfg80211 that the device joined an IBSS or switched to a different BSSID. Before this function can be called, either a beacon has to have been received from the IBSS, or one of the cfg80211_inform_bss{,_frame} functions must have been called with the locally generated beacon -- this guarantees that there is always a scan result for this IBSS. cfg80211 will handle the rest.h]hXThis function notifies cfg80211 that the device joined an IBSS or switched to a different BSSID. Before this function can be called, either a beacon has to have been received from the IBSS, or one of the cfg80211_inform_bss{,_frame} functions must have been called with the locally generated beacon -- this guarantees that there is always a scan result for this IBSS. cfg80211 will handle the rest.}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj0ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_'cfg80211_connect_resp_params (C struct)c.cfg80211_connect_resp_paramshNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hcfg80211_connect_resp_paramsh]jo)}(h#struct cfg80211_connect_resp_paramsh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj|hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj|hhhjhMubj)}(hcfg80211_connect_resp_paramsh]j)}(hjzh]hcfg80211_connect_resp_params}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhj|hhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjxhhhjhMubah}(h]jsah ](jjeh"]h$]h&]jj)jhuh1jhhjhMhjuhhubj)}(hhh]h)}(hConnection response paramsh]hConnection response params}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMU hjhhubah}(h]h ]h"]h$]h&]uh1jhjuhhhjhMubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhj^bhNhNubj)}(hX **Definition**:: struct cfg80211_connect_resp_params { int status; const u8 *req_ie; size_t req_ie_len; const u8 *resp_ie; size_t resp_ie_len; struct cfg80211_fils_resp_params fils; enum nl80211_timeout_reason timeout_reason; const u8 *ap_mld_addr; u16 valid_links; struct { const u8 *addr; const u8 *bssid; struct cfg80211_bss *bss; u16 status; } links[IEEE80211_MLD_MAX_NUM_LINKS]; }; **Members** ``status`` Status code, ``WLAN_STATUS_SUCCESS`` for successful connection, use ``WLAN_STATUS_UNSPECIFIED_FAILURE`` if your device cannot give you the real status code for failures. If this call is used to report a failure due to a timeout (e.g., not receiving an Authentication frame from the AP) instead of an explicit rejection by the AP, -1 is used to indicate that this is a failure, but without a status code. **timeout_reason** is used to report the reason for the timeout in that case. ``req_ie`` Association request IEs (may be ``NULL``) ``req_ie_len`` Association request IEs length ``resp_ie`` Association response IEs (may be ``NULL``) ``resp_ie_len`` Association response IEs length ``fils`` FILS connection response parameters. ``timeout_reason`` Reason for connection timeout. This is used when the connection fails due to a timeout instead of an explicit rejection from the AP. ``NL80211_TIMEOUT_UNSPECIFIED`` is used when the timeout reason is not known. This value is used only if **status** < 0 to indicate that the failure is due to a timeout and not due to explicit rejection by the AP. This value is ignored in other cases (**status** >= 0). ``ap_mld_addr`` For MLO connection, MLD address of the AP. Otherwise ``NULL``. ``valid_links`` For MLO connection, BIT mask of the valid link ids. Otherwise zero. ``links`` For MLO connection, contains link info for the valid links indicated using **valid_links**. For non-MLO connection, links[0] contains the connected AP info. ``links.addr`` For MLO connection, MAC address of the STA link. Otherwise ``NULL``. ``links.bssid`` For MLO connection, MAC address of the AP link. For non-MLO connection, links[0].bssid points to the BSSID of the AP (may be ``NULL``). ``links.bss`` For MLO connection, entry of bss to which STA link is connected. For non-MLO connection, links[0].bss points to entry of bss to which STA is connected. It can be obtained through cfg80211_get_bss() (may be ``NULL``). It is recommended to store the bss from the connect_request and hold a reference to it and return through this param to avoid a warning if the bss is expired during the connection, esp. for those drivers implementing connect op. Only one parameter among **bssid** and **bss** needs to be specified. ``links.status`` per-link status code, to report a status code that's not ``WLAN_STATUS_SUCCESS`` for a given link, it must also be in the **valid_links** bitmap and may have a BSS pointer (which is then released)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMY hjubj( )}(hXstruct cfg80211_connect_resp_params { int status; const u8 *req_ie; size_t req_ie_len; const u8 *resp_ie; size_t resp_ie_len; struct cfg80211_fils_resp_params fils; enum nl80211_timeout_reason timeout_reason; const u8 *ap_mld_addr; u16 valid_links; struct { const u8 *addr; const u8 *bssid; struct cfg80211_bss *bss; u16 status; } links[IEEE80211_MLD_MAX_NUM_LINKS]; };h]hXstruct cfg80211_connect_resp_params { int status; const u8 *req_ie; size_t req_ie_len; const u8 *resp_ie; size_t resp_ie_len; struct cfg80211_fils_resp_params fils; enum nl80211_timeout_reason timeout_reason; const u8 *ap_mld_addr; u16 valid_links; struct { const u8 *addr; const u8 *bssid; struct cfg80211_bss *bss; u16 status; } links[IEEE80211_MLD_MAX_NUM_LINKS]; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM[ hjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMm hjubj)}(hhh](j)}(hX``status`` Status code, ``WLAN_STATUS_SUCCESS`` for successful connection, use ``WLAN_STATUS_UNSPECIFIED_FAILURE`` if your device cannot give you the real status code for failures. If this call is used to report a failure due to a timeout (e.g., not receiving an Authentication frame from the AP) instead of an explicit rejection by the AP, -1 is used to indicate that this is a failure, but without a status code. **timeout_reason** is used to report the reason for the timeout in that case. h](j)}(h ``status``h]j)}(hj/h]hstatus}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM^ hj)ubj6)}(hhh]h)}(hXStatus code, ``WLAN_STATUS_SUCCESS`` for successful connection, use ``WLAN_STATUS_UNSPECIFIED_FAILURE`` if your device cannot give you the real status code for failures. If this call is used to report a failure due to a timeout (e.g., not receiving an Authentication frame from the AP) instead of an explicit rejection by the AP, -1 is used to indicate that this is a failure, but without a status code. **timeout_reason** is used to report the reason for the timeout in that case.h](h Status code, }(hjHhhhNhNubj)}(h``WLAN_STATUS_SUCCESS``h]hWLAN_STATUS_SUCCESS}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubh for successful connection, use }(hjHhhhNhNubj)}(h#``WLAN_STATUS_UNSPECIFIED_FAILURE``h]hWLAN_STATUS_UNSPECIFIED_FAILURE}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubhX- if your device cannot give you the real status code for failures. If this call is used to report a failure due to a timeout (e.g., not receiving an Authentication frame from the AP) instead of an explicit rejection by the AP, -1 is used to indicate that this is a failure, but without a status code. }(hjHhhhNhNubj)}(h**timeout_reason**h]htimeout_reason}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHubh; is used to report the reason for the timeout in that case.}(hjHhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMW hjEubah}(h]h ]h"]h$]h&]uh1j5hj)ubeh}(h]h ]h"]h$]h&]uh1jhjDhM^ hj&ubj)}(h5``req_ie`` Association request IEs (may be ``NULL``) h](j)}(h ``req_ie``h]j)}(hjh]hreq_ie}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM_ hjubj6)}(hhh]h)}(h)Association request IEs (may be ``NULL``)h](h Association request IEs (may be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM_ hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM_ hj&ubj)}(h.``req_ie_len`` Association request IEs length h](j)}(h``req_ie_len``h]j)}(hjh]h req_ie_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM` hjubj6)}(hhh]h)}(hAssociation request IEs lengthh]hAssociation request IEs length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM` hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM` hj&ubj)}(h7``resp_ie`` Association response IEs (may be ``NULL``) h](j)}(h ``resp_ie``h]j)}(hj#h]hresp_ie}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMa hjubj6)}(hhh]h)}(h*Association response IEs (may be ``NULL``)h](h!Association response IEs (may be }(hj<hhhNhNubj)}(h``NULL``h]hNULL}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubh)}(hj<hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj8hMa hj9ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj8hMa hj&ubj)}(h0``resp_ie_len`` Association response IEs length h](j)}(h``resp_ie_len``h]j)}(hjnh]h resp_ie_len}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMb hjhubj6)}(hhh]h)}(hAssociation response IEs lengthh]hAssociation response IEs length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMb hjubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhMb hj&ubj)}(h.``fils`` FILS connection response parameters. h](j)}(h``fils``h]j)}(hjh]hfils}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMc hjubj6)}(hhh]h)}(h$FILS connection response parameters.h]h$FILS connection response parameters.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMc hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMc hj&ubj)}(hX``timeout_reason`` Reason for connection timeout. This is used when the connection fails due to a timeout instead of an explicit rejection from the AP. ``NL80211_TIMEOUT_UNSPECIFIED`` is used when the timeout reason is not known. This value is used only if **status** < 0 to indicate that the failure is due to a timeout and not due to explicit rejection by the AP. This value is ignored in other cases (**status** >= 0). h](j)}(h``timeout_reason``h]j)}(hjh]htimeout_reason}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMi hjubj6)}(hhh]h)}(hXReason for connection timeout. This is used when the connection fails due to a timeout instead of an explicit rejection from the AP. ``NL80211_TIMEOUT_UNSPECIFIED`` is used when the timeout reason is not known. This value is used only if **status** < 0 to indicate that the failure is due to a timeout and not due to explicit rejection by the AP. This value is ignored in other cases (**status** >= 0).h](hReason for connection timeout. This is used when the connection fails due to a timeout instead of an explicit rejection from the AP. }(hjhhhNhNubj)}(h``NL80211_TIMEOUT_UNSPECIFIED``h]hNL80211_TIMEOUT_UNSPECIFIED}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhJ is used when the timeout reason is not known. This value is used only if }(hjhhhNhNubj)}(h **status**h]hstatus}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh < 0 to indicate that the failure is due to a timeout and not due to explicit rejection by the AP. This value is ignored in other cases (}(hjhhhNhNubj)}(h **status**h]hstatus}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh >= 0).}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMd hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMi hj&ubj)}(hO``ap_mld_addr`` For MLO connection, MLD address of the AP. Otherwise ``NULL``. h](j)}(h``ap_mld_addr``h]j)}(hjPh]h ap_mld_addr}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMl hjJubj6)}(hhh]h)}(h>For MLO connection, MLD address of the AP. Otherwise ``NULL``.h](h5For MLO connection, MLD address of the AP. Otherwise }(hjihhhNhNubj)}(h``NULL``h]hNULL}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubh.}(hjihhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjehMl hjfubah}(h]h ]h"]h$]h&]uh1j5hjJubeh}(h]h ]h"]h$]h&]uh1jhjehMl hj&ubj)}(hT``valid_links`` For MLO connection, BIT mask of the valid link ids. Otherwise zero. h](j)}(h``valid_links``h]j)}(hjh]h valid_links}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMk hjubj6)}(hhh]h)}(hCFor MLO connection, BIT mask of the valid link ids. Otherwise zero.h]hCFor MLO connection, BIT mask of the valid link ids. Otherwise zero.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMj hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMk hj&ubj)}(h``links`` For MLO connection, contains link info for the valid links indicated using **valid_links**. For non-MLO connection, links[0] contains the connected AP info. h](j)}(h ``links``h]j)}(hjh]hlinks}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMo hjubj6)}(hhh]h)}(hFor MLO connection, contains link info for the valid links indicated using **valid_links**. For non-MLO connection, links[0] contains the connected AP info.h](hKFor MLO connection, contains link info for the valid links indicated using }(hjhhhNhNubj)}(h**valid_links**h]h valid_links}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubhB. For non-MLO connection, links[0] contains the connected AP info.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMm hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMo hj&ubj)}(hT``links.addr`` For MLO connection, MAC address of the STA link. Otherwise ``NULL``. h](j)}(h``links.addr``h]j)}(hj!h]h links.addr}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMq hjubj6)}(hhh]h)}(hDFor MLO connection, MAC address of the STA link. Otherwise ``NULL``.h](h;For MLO connection, MAC address of the STA link. Otherwise }(hj:hhhNhNubj)}(h``NULL``h]hNULL}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubh.}(hj:hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMp hj7ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj6hMq hj&ubj)}(h``links.bssid`` For MLO connection, MAC address of the AP link. For non-MLO connection, links[0].bssid points to the BSSID of the AP (may be ``NULL``). h](j)}(h``links.bssid``h]j)}(hjmh]h links.bssid}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMs hjgubj6)}(hhh]h)}(hFor MLO connection, MAC address of the AP link. For non-MLO connection, links[0].bssid points to the BSSID of the AP (may be ``NULL``).h](h}For MLO connection, MAC address of the AP link. For non-MLO connection, links[0].bssid points to the BSSID of the AP (may be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh).}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMr hjubah}(h]h ]h"]h$]h&]uh1j5hjgubeh}(h]h ]h"]h$]h&]uh1jhjhMs hj&ubj)}(hX``links.bss`` For MLO connection, entry of bss to which STA link is connected. For non-MLO connection, links[0].bss points to entry of bss to which STA is connected. It can be obtained through cfg80211_get_bss() (may be ``NULL``). It is recommended to store the bss from the connect_request and hold a reference to it and return through this param to avoid a warning if the bss is expired during the connection, esp. for those drivers implementing connect op. Only one parameter among **bssid** and **bss** needs to be specified. h](j)}(h ``links.bss``h]j)}(hjh]h links.bss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM{ hjubj6)}(hhh]h)}(hXFor MLO connection, entry of bss to which STA link is connected. For non-MLO connection, links[0].bss points to entry of bss to which STA is connected. It can be obtained through cfg80211_get_bss() (may be ``NULL``). It is recommended to store the bss from the connect_request and hold a reference to it and return through this param to avoid a warning if the bss is expired during the connection, esp. for those drivers implementing connect op. Only one parameter among **bssid** and **bss** needs to be specified.h](hFor MLO connection, entry of bss to which STA link is connected. For non-MLO connection, links[0].bss points to entry of bss to which STA is connected. It can be obtained through cfg80211_get_bss() (may be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhX). It is recommended to store the bss from the connect_request and hold a reference to it and return through this param to avoid a warning if the bss is expired during the connection, esp. for those drivers implementing connect op. Only one parameter among }(hjhhhNhNubj)}(h **bssid**h]hbssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh and }(hjhhhNhNubj)}(h**bss**h]hbss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh needs to be specified.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMt hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM{ hj&ubj)}(h``links.status`` per-link status code, to report a status code that's not ``WLAN_STATUS_SUCCESS`` for a given link, it must also be in the **valid_links** bitmap and may have a BSS pointer (which is then released)h](j)}(h``links.status``h]j)}(hj)h]h links.status}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM} hj#ubj6)}(hhh]h)}(hper-link status code, to report a status code that's not ``WLAN_STATUS_SUCCESS`` for a given link, it must also be in the **valid_links** bitmap and may have a BSS pointer (which is then released)h](h;per-link status code, to report a status code that’s not }(hjBhhhNhNubj)}(h``WLAN_STATUS_SUCCESS``h]hWLAN_STATUS_SUCCESS}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubh* for a given link, it must also be in the }(hjBhhhNhNubj)}(h**valid_links**h]h valid_links}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBubh; bitmap and may have a BSS pointer (which is then released)}(hjBhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM| hj?ubah}(h]h ]h"]h$]h&]uh1j5hj#ubeh}(h]h ]h"]h$]h&]uh1jhj>hM} hj&ubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_connect_done (C function)c.cfg80211_connect_donehNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hkvoid cfg80211_connect_done (struct net_device *dev, struct cfg80211_connect_resp_params *params, gfp_t gfp)h]jo)}(hjvoid cfg80211_connect_done(struct net_device *dev, struct cfg80211_connect_resp_params *params, gfp_t gfp)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(hcfg80211_connect_doneh]j)}(hcfg80211_connect_doneh]hcfg80211_connect_done}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubj)}(hP(struct net_device *dev, struct cfg80211_connect_resp_params *params, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}jjsbc.cfg80211_connect_doneasbuh1hhjubj)}(h h]h }(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hj0hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hdevh]hdev}(hj=hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h+struct cfg80211_connect_resp_params *paramsh](ju)}(hjh]hstruct}(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjRubj)}(h h]h }(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRubh)}(hhh]j)}(hcfg80211_connect_resp_paramsh]hcfg80211_connect_resp_params}(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjvmodnameN classnameNj j )}j ]jc.cfg80211_connect_doneasbuh1hhjRubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjRubj)}(hparamsh]hparams}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_connect_doneasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM hjhhubj)}(hhh]h)}(h$notify cfg80211 of connection resulth]h$notify cfg80211 of connection result}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj7jj7jjjuh1jchhhj^bhNhNubj)}(hXD**Parameters** ``struct net_device *dev`` network device ``struct cfg80211_connect_resp_params *params`` connection response parameters ``gfp_t gfp`` allocation flags **Description** It should be called by the underlying driver once execution of the connection request from connect() has been completed. This is similar to cfg80211_connect_bss(), but takes a structure pointer for connection response parameters. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.h](h)}(h**Parameters**h]j)}(hjAh]h Parameters}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj;ubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hj`h]hstruct net_device *dev}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjZubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuhM hjvubah}(h]h ]h"]h$]h&]uh1j5hjZubeh}(h]h ]h"]h$]h&]uh1jhjuhM hjWubj)}(hO``struct cfg80211_connect_resp_params *params`` connection response parameters h](j)}(h/``struct cfg80211_connect_resp_params *params``h]j)}(hjh]h+struct cfg80211_connect_resp_params *params}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hconnection response parametersh]hconnection response parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjWubj)}(h``gfp_t gfp`` allocation flags h](j)}(h ``gfp_t gfp``h]j)}(hjh]h gfp_t gfp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjWubeh}(h]h ]h"]h$]h&]uh1jhj;ubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj;ubh)}(hXIt should be called by the underlying driver once execution of the connection request from connect() has been completed. This is similar to cfg80211_connect_bss(), but takes a structure pointer for connection response parameters. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.h]hXIt should be called by the underlying driver once execution of the connection request from connect() has been completed. This is similar to cfg80211_connect_bss(), but takes a structure pointer for connection response parameters. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.}(hj# hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj;ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_!cfg80211_connect_bss (C function)c.cfg80211_connect_bsshNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hvoid cfg80211_connect_bss (struct net_device *dev, const u8 *bssid, struct cfg80211_bss *bss, const u8 *req_ie, size_t req_ie_len, const u8 *resp_ie, size_t resp_ie_len, int status, gfp_t gfp, enum nl80211_timeout_reason timeout_reason)h]jo)}(hvoid cfg80211_connect_bss(struct net_device *dev, const u8 *bssid, struct cfg80211_bss *bss, const u8 *req_ie, size_t req_ie_len, const u8 *resp_ie, size_t resp_ie_len, int status, gfp_t gfp, enum nl80211_timeout_reason timeout_reason)h](j)}(hvoidh]hvoid}(hjR hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjN hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hja hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjN hhhj` hM ubj)}(hcfg80211_connect_bssh]j)}(hcfg80211_connect_bssh]hcfg80211_connect_bss}(hjs hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjo ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjN hhhj` hM ubj)}(h(struct net_device *dev, const u8 *bssid, struct cfg80211_bss *bss, const u8 *req_ie, size_t req_ie_len, const u8 *resp_ie, size_t resp_ie_len, int status, gfp_t gfp, enum nl80211_timeout_reason timeout_reason)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(h net_deviceh]h net_device}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNj j )}j ]j)}jju sbc.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj.)}(hj1h]h*}(hj hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj ubj)}(hdevh]hdev}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hconst u8 *bssidh](ju)}(hjHh]hconst}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(hu8h]hu8}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj! modnameN classnameNj j )}j ]j c.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hj= hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj.)}(hj1h]h*}(hjK hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj ubj)}(hbssidh]hbssid}(hjX hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hstruct cfg80211_bss *bssh](ju)}(hjh]hstruct}(hjq hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjm ubj)}(h h]h }(hj~ hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjm ubh)}(hhh]j)}(h cfg80211_bssh]h cfg80211_bss}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNj j )}j ]j c.cfg80211_connect_bssasbuh1hhjm ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjm ubj.)}(hj1h]h*}(hj hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjm ubj)}(hbssh]hbss}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjm ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hconst u8 *req_ieh](ju)}(hjHh]hconst}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(hu8h]hu8}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNj j )}j ]j c.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj.)}(hj1h]h*}(hj+ hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj ubj)}(hreq_ieh]hreq_ie}(hj8 hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hsize_t req_ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjT hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQ ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjV modnameN classnameNj j )}j ]j c.cfg80211_connect_bssasbuh1hhjM ubj)}(h h]h }(hjr hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjM ubj)}(h req_ie_lenh]h req_ie_len}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjM ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hconst u8 *resp_ieh](ju)}(hjHh]hconst}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(hu8h]hu8}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNj j )}j ]j c.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj.)}(hj1h]h*}(hj hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj ubj)}(hresp_ieh]hresp_ie}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hsize_t resp_ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNj j )}j ]j c.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hj* hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(h resp_ie_lenh]h resp_ie_len}(hj8 hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h int statush](j)}(hinth]hint}(hjQ hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjM ubj)}(h h]h }(hj_ hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjM ubj)}(hstatush]hstatus}(hjm hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjM ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNj j )}j ]j c.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(hgfph]hgfp}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h*enum nl80211_timeout_reason timeout_reasonh](ju)}(hjxh]henum}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(hnl80211_timeout_reasonh]hnl80211_timeout_reason}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNj j )}j ]j c.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(htimeout_reasonh]htimeout_reason}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubeh}(h]h ]h"]h$]h&]jjuh1jhjN hhhj` hM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjJ hhhj` hM ubah}(h]jE ah ](jjeh"]h$]h&]jj)jhuh1jhhj` hM hjG hhubj)}(hhh]h)}(h$notify cfg80211 of connection resulth]h$notify cfg80211 of connection result}(hjB hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj? hhubah}(h]h ]h"]h$]h&]uh1jhjG hhhj` hM ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjZ jjZ jjjuh1jchhhj^bhNhNubj)}(hX**Parameters** ``struct net_device *dev`` network device ``const u8 *bssid`` the BSSID of the AP ``struct cfg80211_bss *bss`` Entry of bss to which STA got connected to, can be obtained through cfg80211_get_bss() (may be ``NULL``). But it is recommended to store the bss from the connect_request and hold a reference to it and return through this param to avoid a warning if the bss is expired during the connection, esp. for those drivers implementing connect op. Only one parameter among **bssid** and **bss** needs to be specified. ``const u8 *req_ie`` association request IEs (maybe be ``NULL``) ``size_t req_ie_len`` association request IEs length ``const u8 *resp_ie`` association response IEs (may be ``NULL``) ``size_t resp_ie_len`` assoc response IEs length ``int status`` status code, ``WLAN_STATUS_SUCCESS`` for successful connection, use ``WLAN_STATUS_UNSPECIFIED_FAILURE`` if your device cannot give you the real status code for failures. If this call is used to report a failure due to a timeout (e.g., not receiving an Authentication frame from the AP) instead of an explicit rejection by the AP, -1 is used to indicate that this is a failure, but without a status code. **timeout_reason** is used to report the reason for the timeout in that case. ``gfp_t gfp`` allocation flags ``enum nl80211_timeout_reason timeout_reason`` reason for connection timeout. This is used when the connection fails due to a timeout instead of an explicit rejection from the AP. ``NL80211_TIMEOUT_UNSPECIFIED`` is used when the timeout reason is not known. This value is used only if **status** < 0 to indicate that the failure is due to a timeout and not due to explicit rejection by the AP. This value is ignored in other cases (**status** >= 0). **Description** It should be called by the underlying driver once execution of the connection request from connect() has been completed. This is similar to cfg80211_connect_result(), but with the option of identifying the exact bss entry for the connection. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.h](h)}(h**Parameters**h]j)}(hjd h]h Parameters}(hjf hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjb ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^ ubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hj h]hstruct net_device *dev}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj} ubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM hj ubah}(h]h ]h"]h$]h&]uh1j5hj} ubeh}(h]h ]h"]h$]h&]uh1jhj hM hjz ubj)}(h(``const u8 *bssid`` the BSSID of the AP h](j)}(h``const u8 *bssid``h]j)}(hj h]hconst u8 *bssid}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj ubj6)}(hhh]h)}(hthe BSSID of the APh]hthe BSSID of the AP}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM hj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hM hjz ubj)}(hX``struct cfg80211_bss *bss`` Entry of bss to which STA got connected to, can be obtained through cfg80211_get_bss() (may be ``NULL``). But it is recommended to store the bss from the connect_request and hold a reference to it and return through this param to avoid a warning if the bss is expired during the connection, esp. for those drivers implementing connect op. Only one parameter among **bssid** and **bss** needs to be specified. h](j)}(h``struct cfg80211_bss *bss``h]j)}(hj h]hstruct cfg80211_bss *bss}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj ubj6)}(hhh]h)}(hXEntry of bss to which STA got connected to, can be obtained through cfg80211_get_bss() (may be ``NULL``). But it is recommended to store the bss from the connect_request and hold a reference to it and return through this param to avoid a warning if the bss is expired during the connection, esp. for those drivers implementing connect op. Only one parameter among **bssid** and **bss** needs to be specified.h](h_Entry of bss to which STA got connected to, can be obtained through cfg80211_get_bss() (may be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhX). But it is recommended to store the bss from the connect_request and hold a reference to it and return through this param to avoid a warning if the bss is expired during the connection, esp. for those drivers implementing connect op. Only one parameter among }(hjhhhNhNubj)}(h **bssid**h]hbssid}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh and }(hjhhhNhNubj)}(h**bss**h]hbss}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh needs to be specified.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hM hjz ubj)}(hA``const u8 *req_ie`` association request IEs (maybe be ``NULL``) h](j)}(h``const u8 *req_ie``h]j)}(hjeh]hconst u8 *req_ie}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj_ubj6)}(hhh]h)}(h+association request IEs (maybe be ``NULL``)h](h"association request IEs (maybe be }(hj~hhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubh)}(hj~hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjzhM hj{ubah}(h]h ]h"]h$]h&]uh1j5hj_ubeh}(h]h ]h"]h$]h&]uh1jhjzhM hjz ubj)}(h5``size_t req_ie_len`` association request IEs length h](j)}(h``size_t req_ie_len``h]j)}(hjh]hsize_t req_ie_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hassociation request IEs lengthh]hassociation request IEs length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjz ubj)}(hA``const u8 *resp_ie`` association response IEs (may be ``NULL``) h](j)}(h``const u8 *resp_ie``h]j)}(hjh]hconst u8 *resp_ie}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h*association response IEs (may be ``NULL``)h](h!association response IEs (may be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjz ubj)}(h1``size_t resp_ie_len`` assoc response IEs length h](j)}(h``size_t resp_ie_len``h]j)}(hj4h]hsize_t resp_ie_len}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj.ubj6)}(hhh]h)}(hassoc response IEs lengthh]hassoc response IEs length}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIhM hjJubah}(h]h ]h"]h$]h&]uh1j5hj.ubeh}(h]h ]h"]h$]h&]uh1jhjIhM hjz ubj)}(hX``int status`` status code, ``WLAN_STATUS_SUCCESS`` for successful connection, use ``WLAN_STATUS_UNSPECIFIED_FAILURE`` if your device cannot give you the real status code for failures. If this call is used to report a failure due to a timeout (e.g., not receiving an Authentication frame from the AP) instead of an explicit rejection by the AP, -1 is used to indicate that this is a failure, but without a status code. **timeout_reason** is used to report the reason for the timeout in that case. h](j)}(h``int status``h]j)}(hjmh]h int status}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjgubj6)}(hhh]h)}(hXstatus code, ``WLAN_STATUS_SUCCESS`` for successful connection, use ``WLAN_STATUS_UNSPECIFIED_FAILURE`` if your device cannot give you the real status code for failures. If this call is used to report a failure due to a timeout (e.g., not receiving an Authentication frame from the AP) instead of an explicit rejection by the AP, -1 is used to indicate that this is a failure, but without a status code. **timeout_reason** is used to report the reason for the timeout in that case.h](h status code, }(hjhhhNhNubj)}(h``WLAN_STATUS_SUCCESS``h]hWLAN_STATUS_SUCCESS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh for successful connection, use }(hjhhhNhNubj)}(h#``WLAN_STATUS_UNSPECIFIED_FAILURE``h]hWLAN_STATUS_UNSPECIFIED_FAILURE}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhX- if your device cannot give you the real status code for failures. If this call is used to report a failure due to a timeout (e.g., not receiving an Authentication frame from the AP) instead of an explicit rejection by the AP, -1 is used to indicate that this is a failure, but without a status code. }(hjhhhNhNubj)}(h**timeout_reason**h]htimeout_reason}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh; is used to report the reason for the timeout in that case.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjgubeh}(h]h ]h"]h$]h&]uh1jhjhM hjz ubj)}(h``gfp_t gfp`` allocation flags h](j)}(h ``gfp_t gfp``h]j)}(hjh]h gfp_t gfp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjz ubj)}(hX``enum nl80211_timeout_reason timeout_reason`` reason for connection timeout. This is used when the connection fails due to a timeout instead of an explicit rejection from the AP. ``NL80211_TIMEOUT_UNSPECIFIED`` is used when the timeout reason is not known. This value is used only if **status** < 0 to indicate that the failure is due to a timeout and not due to explicit rejection by the AP. This value is ignored in other cases (**status** >= 0). h](j)}(h.``enum nl80211_timeout_reason timeout_reason``h]j)}(hjh]h*enum nl80211_timeout_reason timeout_reason}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hXreason for connection timeout. This is used when the connection fails due to a timeout instead of an explicit rejection from the AP. ``NL80211_TIMEOUT_UNSPECIFIED`` is used when the timeout reason is not known. This value is used only if **status** < 0 to indicate that the failure is due to a timeout and not due to explicit rejection by the AP. This value is ignored in other cases (**status** >= 0).h](hreason for connection timeout. This is used when the connection fails due to a timeout instead of an explicit rejection from the AP. }(hj/hhhNhNubj)}(h``NL80211_TIMEOUT_UNSPECIFIED``h]hNL80211_TIMEOUT_UNSPECIFIED}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubhJ is used when the timeout reason is not known. This value is used only if }(hj/hhhNhNubj)}(h **status**h]hstatus}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/ubh < 0 to indicate that the failure is due to a timeout and not due to explicit rejection by the AP. This value is ignored in other cases (}(hj/hhhNhNubj)}(h **status**h]hstatus}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/ubh >= 0).}(hj/hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj,ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj+hM hjz ubeh}(h]h ]h"]h$]h&]uh1jhj^ ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^ ubh)}(hXIt should be called by the underlying driver once execution of the connection request from connect() has been completed. This is similar to cfg80211_connect_result(), but with the option of identifying the exact bss entry for the connection. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.h]hXIt should be called by the underlying driver once execution of the connection request from connect() has been completed. This is similar to cfg80211_connect_result(), but with the option of identifying the exact bss entry for the connection. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^ ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_$cfg80211_connect_result (C function)c.cfg80211_connect_resulthNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hvoid cfg80211_connect_result (struct net_device *dev, const u8 *bssid, const u8 *req_ie, size_t req_ie_len, const u8 *resp_ie, size_t resp_ie_len, u16 status, gfp_t gfp)h]jo)}(hvoid cfg80211_connect_result(struct net_device *dev, const u8 *bssid, const u8 *req_ie, size_t req_ie_len, const u8 *resp_ie, size_t resp_ie_len, u16 status, gfp_t gfp)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(hcfg80211_connect_resulth]j)}(hcfg80211_connect_resulth]hcfg80211_connect_result}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubj)}(h(struct net_device *dev, const u8 *bssid, const u8 *req_ie, size_t req_ie_len, const u8 *resp_ie, size_t resp_ie_len, u16 status, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(h net_deviceh]h net_device}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj*modnameN classnameNj j )}j ]j)}jjsbc.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjVhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hdevh]hdev}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *bssidh](ju)}(hjHh]hconst}(hj|hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjxubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jDc.cfg80211_connect_resultasbuh1hhjxubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjxubj)}(hbssidh]hbssid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *req_ieh](ju)}(hjHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNj j )}j ]jDc.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hj6hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hreq_ieh]hreq_ie}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hsize_t req_ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjamodnameN classnameNj j )}j ]jDc.cfg80211_connect_resultasbuh1hhjXubj)}(h h]h }(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubj)}(h req_ie_lenh]h req_ie_len}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *resp_ieh](ju)}(hjHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jDc.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hresp_ieh]hresp_ie}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hsize_t resp_ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jDc.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h resp_ie_lenh]h resp_ie_len}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u16 statush](h)}(hhh]j)}(hu16h]hu16}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjamodnameN classnameNj j )}j ]jDc.cfg80211_connect_resultasbuh1hhjXubj)}(h h]h }(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubj)}(hstatush]hstatus}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jDc.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM hjhhubj)}(hhh]h)}(h$notify cfg80211 of connection resulth]h$notify cfg80211 of connection result}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhj^bhNhNubj)}(hX**Parameters** ``struct net_device *dev`` network device ``const u8 *bssid`` the BSSID of the AP ``const u8 *req_ie`` association request IEs (maybe be ``NULL``) ``size_t req_ie_len`` association request IEs length ``const u8 *resp_ie`` association response IEs (may be ``NULL``) ``size_t resp_ie_len`` assoc response IEs length ``u16 status`` status code, ``WLAN_STATUS_SUCCESS`` for successful connection, use ``WLAN_STATUS_UNSPECIFIED_FAILURE`` if your device cannot give you the real status code for failures. ``gfp_t gfp`` allocation flags **Description** It should be called by the underlying driver once execution of the connection request from connect() has been completed. This is similar to cfg80211_connect_bss() which allows the exact bss entry to be specified. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hj>h]hstruct net_device *dev}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj8ubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShM hjTubah}(h]h ]h"]h$]h&]uh1j5hj8ubeh}(h]h ]h"]h$]h&]uh1jhjShM hj5ubj)}(h(``const u8 *bssid`` the BSSID of the AP h](j)}(h``const u8 *bssid``h]j)}(hjwh]hconst u8 *bssid}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjqubj6)}(hhh]h)}(hthe BSSID of the APh]hthe BSSID of the AP}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjqubeh}(h]h ]h"]h$]h&]uh1jhjhM hj5ubj)}(hA``const u8 *req_ie`` association request IEs (maybe be ``NULL``) h](j)}(h``const u8 *req_ie``h]j)}(hjh]hconst u8 *req_ie}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h+association request IEs (maybe be ``NULL``)h](h"association request IEs (maybe be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj5ubj)}(h5``size_t req_ie_len`` association request IEs length h](j)}(h``size_t req_ie_len``h]j)}(hjh]hsize_t req_ie_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hassociation request IEs lengthh]hassociation request IEs length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj5ubj)}(hA``const u8 *resp_ie`` association response IEs (may be ``NULL``) h](j)}(h``const u8 *resp_ie``h]j)}(hj4h]hconst u8 *resp_ie}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj.ubj6)}(hhh]h)}(h*association response IEs (may be ``NULL``)h](h!association response IEs (may be }(hjMhhhNhNubj)}(h``NULL``h]hNULL}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMubh)}(hjMhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjIhM hjJubah}(h]h ]h"]h$]h&]uh1j5hj.ubeh}(h]h ]h"]h$]h&]uh1jhjIhM hj5ubj)}(h1``size_t resp_ie_len`` assoc response IEs length h](j)}(h``size_t resp_ie_len``h]j)}(hjh]hsize_t resp_ie_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjyubj6)}(hhh]h)}(hassoc response IEs lengthh]hassoc response IEs length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjyubeh}(h]h ]h"]h$]h&]uh1jhjhM hj5ubj)}(h``u16 status`` status code, ``WLAN_STATUS_SUCCESS`` for successful connection, use ``WLAN_STATUS_UNSPECIFIED_FAILURE`` if your device cannot give you the real status code for failures. h](j)}(h``u16 status``h]j)}(hjh]h u16 status}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hstatus code, ``WLAN_STATUS_SUCCESS`` for successful connection, use ``WLAN_STATUS_UNSPECIFIED_FAILURE`` if your device cannot give you the real status code for failures.h](h status code, }(hjhhhNhNubj)}(h``WLAN_STATUS_SUCCESS``h]hWLAN_STATUS_SUCCESS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh for successful connection, use }(hjhhhNhNubj)}(h#``WLAN_STATUS_UNSPECIFIED_FAILURE``h]hWLAN_STATUS_UNSPECIFIED_FAILURE}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhB if your device cannot give you the real status code for failures.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj5ubj)}(h``gfp_t gfp`` allocation flags h](j)}(h ``gfp_t gfp``h]j)}(hjh]h gfp_t gfp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj+hM hj,ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj+hM hj5ubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjQh]h Description}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhjOubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubh)}(hXqIt should be called by the underlying driver once execution of the connection request from connect() has been completed. This is similar to cfg80211_connect_bss() which allows the exact bss entry to be specified. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.h]hXqIt should be called by the underlying driver once execution of the connection request from connect() has been completed. This is similar to cfg80211_connect_bss() which allows the exact bss entry to be specified. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_%cfg80211_connect_timeout (C function)c.cfg80211_connect_timeouthNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hvoid cfg80211_connect_timeout (struct net_device *dev, const u8 *bssid, const u8 *req_ie, size_t req_ie_len, gfp_t gfp, enum nl80211_timeout_reason timeout_reason)h]jo)}(hvoid cfg80211_connect_timeout(struct net_device *dev, const u8 *bssid, const u8 *req_ie, size_t req_ie_len, gfp_t gfp, enum nl80211_timeout_reason timeout_reason)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM!ubj)}(hcfg80211_connect_timeouth]j)}(hcfg80211_connect_timeouth]hcfg80211_connect_timeout}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM!ubj)}(h(struct net_device *dev, const u8 *bssid, const u8 *req_ie, size_t req_ie_len, gfp_t gfp, enum nl80211_timeout_reason timeout_reason)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}jjsbc.cfg80211_connect_timeoutasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hdevh]hdev}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *bssidh](ju)}(hjHh]hconst}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjAubj)}(h h]h }(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAubh)}(hhh]j)}(hu8h]hu8}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjemodnameN classnameNj j )}j ]j c.cfg80211_connect_timeoutasbuh1hhjAubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjAubj)}(hbssidh]hbssid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *req_ieh](ju)}(hjHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j c.cfg80211_connect_timeoutasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hreq_ieh]hreq_ie}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hsize_t req_ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj*modnameN classnameNj j )}j ]j c.cfg80211_connect_timeoutasbuh1hhj!ubj)}(h h]h }(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubj)}(h req_ie_lenh]h req_ie_len}(hjThhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjphhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjrmodnameN classnameNj j )}j ]j c.cfg80211_connect_timeoutasbuh1hhjiubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjiubj)}(hgfph]hgfp}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjiubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h*enum nl80211_timeout_reason timeout_reasonh](ju)}(hjxh]henum}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hnl80211_timeout_reasonh]hnl80211_timeout_reason}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j c.cfg80211_connect_timeoutasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(htimeout_reasonh]htimeout_reason}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM!ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM!ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM!hjhhubj)}(hhh]h)}(h%notify cfg80211 of connection timeouth]h%notify cfg80211 of connection timeout}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj&hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM!ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjAjjAjjjuh1jchhhj^bhNhNubj)}(hXG**Parameters** ``struct net_device *dev`` network device ``const u8 *bssid`` the BSSID of the AP ``const u8 *req_ie`` association request IEs (maybe be ``NULL``) ``size_t req_ie_len`` association request IEs length ``gfp_t gfp`` allocation flags ``enum nl80211_timeout_reason timeout_reason`` reason for connection timeout. **Description** It should be called by the underlying driver whenever connect() has failed in a sequence where no explicit authentication/association rejection was received from the AP. This could happen, e.g., due to not being able to send out the Authentication or Association Request frame or timing out while waiting for the response. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.h](h)}(h**Parameters**h]j)}(hjKh]h Parameters}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjEubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hjjh]hstruct net_device *dev}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjdubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1j5hjdubeh}(h]h ]h"]h$]h&]uh1jhjhM!hjaubj)}(h(``const u8 *bssid`` the BSSID of the AP h](j)}(h``const u8 *bssid``h]j)}(hjh]hconst u8 *bssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjubj6)}(hhh]h)}(hthe BSSID of the APh]hthe BSSID of the AP}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM!hjaubj)}(hA``const u8 *req_ie`` association request IEs (maybe be ``NULL``) h](j)}(h``const u8 *req_ie``h]j)}(hjh]hconst u8 *req_ie}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjubj6)}(hhh]h)}(h+association request IEs (maybe be ``NULL``)h](h"association request IEs (maybe be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM!hjaubj)}(h5``size_t req_ie_len`` association request IEs length h](j)}(h``size_t req_ie_len``h]j)}(hj'h]hsize_t req_ie_len}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj!ubj6)}(hhh]h)}(hassociation request IEs lengthh]hassociation request IEs length}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hM!hj=ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj<hM!hjaubj)}(h``gfp_t gfp`` allocation flags h](j)}(h ``gfp_t gfp``h]j)}(hj`h]h gfp_t gfp}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjZubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuhM!hjvubah}(h]h ]h"]h$]h&]uh1j5hjZubeh}(h]h ]h"]h$]h&]uh1jhjuhM!hjaubj)}(hN``enum nl80211_timeout_reason timeout_reason`` reason for connection timeout. h](j)}(h.``enum nl80211_timeout_reason timeout_reason``h]j)}(hjh]h*enum nl80211_timeout_reason timeout_reason}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjubj6)}(hhh]h)}(hreason for connection timeout.h]hreason for connection timeout.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM!hjaubeh}(h]h ]h"]h$]h&]uh1jhjEubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM !hjEubh)}(hXIt should be called by the underlying driver whenever connect() has failed in a sequence where no explicit authentication/association rejection was received from the AP. This could happen, e.g., due to not being able to send out the Authentication or Association Request frame or timing out while waiting for the response. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.h]hXIt should be called by the underlying driver whenever connect() has failed in a sequence where no explicit authentication/association rejection was received from the AP. This could happen, e.g., due to not being able to send out the Authentication or Association Request frame or timing out while waiting for the response. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjEubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_roamed (C function)c.cfg80211_roamedhNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hYvoid cfg80211_roamed (struct net_device *dev, struct cfg80211_roam_info *info, gfp_t gfp)h]jo)}(hXvoid cfg80211_roamed(struct net_device *dev, struct cfg80211_roam_info *info, gfp_t gfp)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMB!ubj)}(h h]h }(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhj'hMB!ubj)}(hcfg80211_roamedh]j)}(hcfg80211_roamedh]hcfg80211_roamed}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhj'hMB!ubj)}(hD(struct net_device *dev, struct cfg80211_roam_info *info, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjRubj)}(h h]h }(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRubh)}(hhh]j)}(h net_deviceh]h net_device}(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjvmodnameN classnameNj j )}j ]j)}jj<sbc.cfg80211_roamedasbuh1hhjRubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjRubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjNubj)}(hstruct cfg80211_roam_info *infoh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hcfg80211_roam_infoh]hcfg80211_roam_info}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_roamedasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hinfoh]hinfo}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjNubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj=modnameN classnameNj j )}j ]jc.cfg80211_roamedasbuh1hhj4ubj)}(h h]h }(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubj)}(hgfph]hgfp}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjNubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhj'hMB!ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhj'hMB!ubah}(h]j ah ](jjeh"]h$]h&]jj)jhuh1jhhj'hMB!hjhhubj)}(hhh]h)}(hnotify cfg80211 of roamingh]hnotify cfg80211 of roaming}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMB!hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj'hMB!ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhj^bhNhNubj)}(hX**Parameters** ``struct net_device *dev`` network device ``struct cfg80211_roam_info *info`` information about the new BSS. struct :c:type:`cfg80211_roam_info`. ``gfp_t gfp`` allocation flags **Description** This function may be called with the driver passing either the BSSID of the new AP or passing the bss entry to avoid a race in timeout of the bss entry. It should be called by the underlying driver whenever it roamed from one AP to another while connected. Drivers which have roaming implemented in firmware should pass the bss entry to avoid a race in bss entry timeout where the bss entry of the new AP is seen in the driver, but gets timed out by the time it is accessed in __cfg80211_roamed() due to delay in scheduling rdev->event_work. In case of any failures, the reference is released either in cfg80211_roamed() or in __cfg80211_romed(), Otherwise, it will be released while disconnecting from the current bss.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMF!hjubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hjh]hstruct net_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMD!hjubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMD!hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMD!hjubj)}(hh``struct cfg80211_roam_info *info`` information about the new BSS. struct :c:type:`cfg80211_roam_info`. h](j)}(h#``struct cfg80211_roam_info *info``h]j)}(hj h]hstruct cfg80211_roam_info *info}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhME!hjubj6)}(hhh]h)}(hCinformation about the new BSS. struct :c:type:`cfg80211_roam_info`.h](h&information about the new BSS. struct }(hj$hhhNhNubh)}(h:c:type:`cfg80211_roam_info`h]j)}(hj.h]hcfg80211_roam_info}(hj0hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6cfg80211_roam_infouh1hhj hME!hj$ubh.}(hj$hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hME!hj!ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hME!hjubj)}(h``gfp_t gfp`` allocation flags h](j)}(h ``gfp_t gfp``h]j)}(hjgh]h gfp_t gfp}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMF!hjaubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hMF!hj}ubah}(h]h ]h"]h$]h&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hMF!hjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMH!hjubh)}(hXThis function may be called with the driver passing either the BSSID of the new AP or passing the bss entry to avoid a race in timeout of the bss entry. It should be called by the underlying driver whenever it roamed from one AP to another while connected. Drivers which have roaming implemented in firmware should pass the bss entry to avoid a race in bss entry timeout where the bss entry of the new AP is seen in the driver, but gets timed out by the time it is accessed in __cfg80211_roamed() due to delay in scheduling rdev->event_work. In case of any failures, the reference is released either in cfg80211_roamed() or in __cfg80211_romed(), Otherwise, it will be released while disconnecting from the current bss.h]hXThis function may be called with the driver passing either the BSSID of the new AP or passing the bss entry to avoid a race in timeout of the bss entry. It should be called by the underlying driver whenever it roamed from one AP to another while connected. Drivers which have roaming implemented in firmware should pass the bss entry to avoid a race in bss entry timeout where the bss entry of the new AP is seen in the driver, but gets timed out by the time it is accessed in __cfg80211_roamed() due to delay in scheduling rdev->event_work. In case of any failures, the reference is released either in cfg80211_roamed() or in __cfg80211_romed(), Otherwise, it will be released while disconnecting from the current bss.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMG!hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_disconnected (C function)c.cfg80211_disconnectedhNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hvoid cfg80211_disconnected (struct net_device *dev, u16 reason, const u8 *ie, size_t ie_len, bool locally_generated, gfp_t gfp)h]jo)}(h~void cfg80211_disconnected(struct net_device *dev, u16 reason, const u8 *ie, size_t ie_len, bool locally_generated, gfp_t gfp)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMn!ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMn!ubj)}(hcfg80211_disconnectedh]j)}(hcfg80211_disconnectedh]hcfg80211_disconnected}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMn!ubj)}(hd(struct net_device *dev, u16 reason, const u8 *ie, size_t ie_len, bool locally_generated, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj ubj)}(h h]h }(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(h net_deviceh]h net_device}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjDmodnameN classnameNj j )}j ]j)}jj sbc.cfg80211_disconnectedasbuh1hhj ubj)}(h h]h }(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj.)}(hj1h]h*}(hjphhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj ubj)}(hdevh]hdev}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u16 reasonh](h)}(hhh]j)}(hu16h]hu16}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j^c.cfg80211_disconnectedasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hreasonh]hreason}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h const u8 *ieh](ju)}(hjHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j^c.cfg80211_disconnectedasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hj(hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hieh]hie}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h size_t ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjSmodnameN classnameNj j )}j ]j^c.cfg80211_disconnectedasbuh1hhjJubj)}(h h]h }(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJubj)}(hie_lenh]hie_len}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hbool locally_generatedh](j)}(hjh]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hlocally_generatedh]hlocally_generated}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j^c.cfg80211_disconnectedasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMn!ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMn!ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMn!hjhhubj)}(hhh]h)}(h+notify cfg80211 that connection was droppedh]h+notify cfg80211 that connection was dropped}(hj# hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMn!hj hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMn!ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj; jj; jjjuh1jchhhj^bhNhNubj)}(hX**Parameters** ``struct net_device *dev`` network device ``u16 reason`` reason code for the disconnection, set it to 0 if unknown ``const u8 *ie`` information elements of the deauth/disassoc frame (may be ``NULL``) ``size_t ie_len`` length of IEs ``bool locally_generated`` disconnection was requested locally ``gfp_t gfp`` allocation flags **Description** After it calls this function, the driver should enter an idle state and not try to connect to any AP any more.h](h)}(h**Parameters**h]j)}(hjE h]h Parameters}(hjG hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjC ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMr!hj? ubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hjd h]hstruct net_device *dev}(hjf hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjb ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMp!hj^ ubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hj} hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjy hMp!hjz ubah}(h]h ]h"]h$]h&]uh1j5hj^ ubeh}(h]h ]h"]h$]h&]uh1jhjy hMp!hj[ ubj)}(hI``u16 reason`` reason code for the disconnection, set it to 0 if unknown h](j)}(h``u16 reason``h]j)}(hj h]h u16 reason}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMs!hj ubj6)}(hhh]h)}(h9reason code for the disconnection, set it to 0 if unknownh]h9reason code for the disconnection, set it to 0 if unknown}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMs!hj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hMs!hj[ ubj)}(hU``const u8 *ie`` information elements of the deauth/disassoc frame (may be ``NULL``) h](j)}(h``const u8 *ie``h]j)}(hj h]h const u8 *ie}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMq!hj ubj6)}(hhh]h)}(hCinformation elements of the deauth/disassoc frame (may be ``NULL``)h](h:information elements of the deauth/disassoc frame (may be }(hj hhhNhNubj)}(h``NULL``h]hNULL}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh)}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hMq!hj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hMq!hj[ ubj)}(h ``size_t ie_len`` length of IEs h](j)}(h``size_t ie_len``h]j)}(hj!!h]h size_t ie_len}(hj#!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMr!hj!ubj6)}(hhh]h)}(h length of IEsh]h length of IEs}(hj:!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6!hMr!hj7!ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj6!hMr!hj[ ubj)}(h?``bool locally_generated`` disconnection was requested locally h](j)}(h``bool locally_generated``h]j)}(hjZ!h]hbool locally_generated}(hj\!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjX!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMt!hjT!ubj6)}(hhh]h)}(h#disconnection was requested locallyh]h#disconnection was requested locally}(hjs!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjo!hMt!hjp!ubah}(h]h ]h"]h$]h&]uh1j5hjT!ubeh}(h]h ]h"]h$]h&]uh1jhjo!hMt!hj[ ubj)}(h``gfp_t gfp`` allocation flags h](j)}(h ``gfp_t gfp``h]j)}(hj!h]h gfp_t gfp}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMu!hj!ubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hMu!hj!ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj!hMu!hj[ ubeh}(h]h ]h"]h$]h&]uh1jhj? ubh)}(h**Description**h]j)}(hj!h]h Description}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMw!hj? ubh)}(hnAfter it calls this function, the driver should enter an idle state and not try to connect to any AP any more.h]hnAfter it calls this function, the driver should enter an idle state and not try to connect to any AP any more.}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMv!hj? ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_&cfg80211_ready_on_channel (C function)c.cfg80211_ready_on_channelhNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hvoid cfg80211_ready_on_channel (struct wireless_dev *wdev, u64 cookie, struct ieee80211_channel *chan, unsigned int duration, gfp_t gfp)h]jo)}(hvoid cfg80211_ready_on_channel(struct wireless_dev *wdev, u64 cookie, struct ieee80211_channel *chan, unsigned int duration, gfp_t gfp)h](j)}(hvoidh]hvoid}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!ubj)}(h h]h }(hj""hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"hhhj!"hM!ubj)}(hcfg80211_ready_on_channelh]j)}(hcfg80211_ready_on_channelh]hcfg80211_ready_on_channel}(hj4"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0"ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj"hhhj!"hM!ubj)}(hi(struct wireless_dev *wdev, u64 cookie, struct ieee80211_channel *chan, unsigned int duration, gfp_t gfp)h](j)}(hstruct wireless_dev *wdevh](ju)}(hjh]hstruct}(hjP"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjL"ubj)}(h h]h }(hj]"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjL"ubh)}(hhh]j)}(h wireless_devh]h wireless_dev}(hjn"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjk"ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjp"modnameN classnameNj j )}j ]j)}jj6"sbc.cfg80211_ready_on_channelasbuh1hhjL"ubj)}(h h]h }(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjL"ubj.)}(hj1h]h*}(hj"hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjL"ubj)}(hwdevh]hwdev}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjL"ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjH"ubj)}(h u64 cookieh](h)}(hhh]j)}(hu64h]hu64}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj"modnameN classnameNj j )}j ]j"c.cfg80211_ready_on_channelasbuh1hhj"ubj)}(h h]h }(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"ubj)}(hcookieh]hcookie}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjH"ubj)}(hstruct ieee80211_channel *chanh](ju)}(hjh]hstruct}(hj #hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj#ubj)}(h h]h }(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#ubh)}(hhh]j)}(hieee80211_channelh]hieee80211_channel}(hj(#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%#ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj*#modnameN classnameNj j )}j ]j"c.cfg80211_ready_on_channelasbuh1hhj#ubj)}(h h]h }(hjF#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#ubj.)}(hj1h]h*}(hjT#hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj#ubj)}(hchanh]hchan}(hja#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjH"ubj)}(hunsigned int durationh](j)}(hunsignedh]hunsigned}(hjz#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjv#ubj)}(h h]h }(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjv#ubj)}(hinth]hint}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjv#ubj)}(h h]h }(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjv#ubj)}(hdurationh]hduration}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjv#ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjH"ubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj#modnameN classnameNj j )}j ]j"c.cfg80211_ready_on_channelasbuh1hhj#ubj)}(h h]h }(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#ubj)}(hgfph]hgfp}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjH"ubeh}(h]h ]h"]h$]h&]jjuh1jhj"hhhj!"hM!ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj "hhhj!"hM!ubah}(h]j"ah ](jjeh"]h$]h&]jj)jhuh1jhhj!"hM!hj"hhubj)}(hhh]h)}(h'notification of remain_on_channel starth]h'notification of remain_on_channel start}(hj$$hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj!$hhubah}(h]h ]h"]h$]h&]uh1jhj"hhhj!"hM!ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj<$jj<$jjjuh1jchhhj^bhNhNubj)}(hXJ**Parameters** ``struct wireless_dev *wdev`` wireless device ``u64 cookie`` the request cookie ``struct ieee80211_channel *chan`` The current channel (from remain_on_channel request) ``unsigned int duration`` Duration in milliseconds that the driver intents to remain on the channel ``gfp_t gfp`` allocation flagsh](h)}(h**Parameters**h]j)}(hjF$h]h Parameters}(hjH$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjD$ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj@$ubj)}(hhh](j)}(h.``struct wireless_dev *wdev`` wireless device h](j)}(h``struct wireless_dev *wdev``h]j)}(hje$h]hstruct wireless_dev *wdev}(hjg$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjc$ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj_$ubj6)}(hhh]h)}(hwireless deviceh]hwireless device}(hj~$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjz$hM!hj{$ubah}(h]h ]h"]h$]h&]uh1j5hj_$ubeh}(h]h ]h"]h$]h&]uh1jhjz$hM!hj\$ubj)}(h"``u64 cookie`` the request cookie h](j)}(h``u64 cookie``h]j)}(hj$h]h u64 cookie}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj$ubj6)}(hhh]h)}(hthe request cookieh]hthe request cookie}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$hM!hj$ubah}(h]h ]h"]h$]h&]uh1j5hj$ubeh}(h]h ]h"]h$]h&]uh1jhj$hM!hj\$ubj)}(hX``struct ieee80211_channel *chan`` The current channel (from remain_on_channel request) h](j)}(h"``struct ieee80211_channel *chan``h]j)}(hj$h]hstruct ieee80211_channel *chan}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj$ubj6)}(hhh]h)}(h4The current channel (from remain_on_channel request)h]h4The current channel (from remain_on_channel request)}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$hM!hj$ubah}(h]h ]h"]h$]h&]uh1j5hj$ubeh}(h]h ]h"]h$]h&]uh1jhj$hM!hj\$ubj)}(hd``unsigned int duration`` Duration in milliseconds that the driver intents to remain on the channel h](j)}(h``unsigned int duration``h]j)}(hj%h]hunsigned int duration}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj %ubj6)}(hhh]h)}(hIDuration in milliseconds that the driver intents to remain on the channelh]hIDuration in milliseconds that the driver intents to remain on the channel}(hj)%hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj&%ubah}(h]h ]h"]h$]h&]uh1j5hj %ubeh}(h]h ]h"]h$]h&]uh1jhj%%hM!hj\$ubj)}(h``gfp_t gfp`` allocation flagsh](j)}(h ``gfp_t gfp``h]j)}(hjJ%h]h gfp_t gfp}(hjL%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjH%ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjD%ubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjc%hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj`%ubah}(h]h ]h"]h$]h&]uh1j5hjD%ubeh}(h]h ]h"]h$]h&]uh1jhj_%hM!hj\$ubeh}(h]h ]h"]h$]h&]uh1jhj@$ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_/cfg80211_remain_on_channel_expired (C function)$c.cfg80211_remain_on_channel_expiredhNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hzvoid cfg80211_remain_on_channel_expired (struct wireless_dev *wdev, u64 cookie, struct ieee80211_channel *chan, gfp_t gfp)h]jo)}(hyvoid cfg80211_remain_on_channel_expired(struct wireless_dev *wdev, u64 cookie, struct ieee80211_channel *chan, gfp_t gfp)h](j)}(hvoidh]hvoid}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!ubj)}(h h]h }(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%hhhj%hM!ubj)}(h"cfg80211_remain_on_channel_expiredh]j)}(h"cfg80211_remain_on_channel_expiredh]h"cfg80211_remain_on_channel_expired}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj%hhhj%hM!ubj)}(hR(struct wireless_dev *wdev, u64 cookie, struct ieee80211_channel *chan, gfp_t gfp)h](j)}(hstruct wireless_dev *wdevh](ju)}(hjh]hstruct}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj%ubj)}(h h]h }(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubh)}(hhh]j)}(h wireless_devh]h wireless_dev}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj&modnameN classnameNj j )}j ]j)}jj%sb$c.cfg80211_remain_on_channel_expiredasbuh1hhj%ubj)}(h h]h }(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubj.)}(hj1h]h*}(hj-&hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj%ubj)}(hwdevh]hwdev}(hj:&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj%ubj)}(h u64 cookieh](h)}(hhh]j)}(hu64h]hu64}(hjV&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjS&ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjX&modnameN classnameNj j )}j ]j&$c.cfg80211_remain_on_channel_expiredasbuh1hhjO&ubj)}(h h]h }(hjt&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjO&ubj)}(hcookieh]hcookie}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjO&ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj%ubj)}(hstruct ieee80211_channel *chanh](ju)}(hjh]hstruct}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj&ubj)}(h h]h }(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubh)}(hhh]j)}(hieee80211_channelh]hieee80211_channel}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj&modnameN classnameNj j )}j ]j&$c.cfg80211_remain_on_channel_expiredasbuh1hhj&ubj)}(h h]h }(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubj.)}(hj1h]h*}(hj&hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj&ubj)}(hchanh]hchan}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj%ubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj 'ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj'modnameN classnameNj j )}j ]j&$c.cfg80211_remain_on_channel_expiredasbuh1hhj'ubj)}(h h]h }(hj,'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubj)}(hgfph]hgfp}(hj:'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj%ubeh}(h]h ]h"]h$]h&]jjuh1jhj%hhhj%hM!ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj%hhhj%hM!ubah}(h]j%ah ](jjeh"]h$]h&]jj)jhuh1jhhj%hM!hj%hhubj)}(hhh]h)}(h"remain_on_channel duration expiredh]h"remain_on_channel duration expired}(hjd'hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hja'hhubah}(h]h ]h"]h$]h&]uh1jhj%hhhj%hM!ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj|'jj|'jjjuh1jchhhj^bhNhNubj)}(h**Parameters** ``struct wireless_dev *wdev`` wireless device ``u64 cookie`` the request cookie ``struct ieee80211_channel *chan`` The current channel (from remain_on_channel request) ``gfp_t gfp`` allocation flagsh](h)}(h**Parameters**h]j)}(hj'h]h Parameters}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj'ubj)}(hhh](j)}(h.``struct wireless_dev *wdev`` wireless device h](j)}(h``struct wireless_dev *wdev``h]j)}(hj'h]hstruct wireless_dev *wdev}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj'ubj6)}(hhh]h)}(hwireless deviceh]hwireless device}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hM!hj'ubah}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'hM!hj'ubj)}(h"``u64 cookie`` the request cookie h](j)}(h``u64 cookie``h]j)}(hj'h]h u64 cookie}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj'ubj6)}(hhh]h)}(hthe request cookieh]hthe request cookie}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hM!hj'ubah}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'hM!hj'ubj)}(hX``struct ieee80211_channel *chan`` The current channel (from remain_on_channel request) h](j)}(h"``struct ieee80211_channel *chan``h]j)}(hj(h]hstruct ieee80211_channel *chan}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj(ubj6)}(hhh]h)}(h4The current channel (from remain_on_channel request)h]h4The current channel (from remain_on_channel request)}(hj0(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,(hM!hj-(ubah}(h]h ]h"]h$]h&]uh1j5hj(ubeh}(h]h ]h"]h$]h&]uh1jhj,(hM!hj'ubj)}(h``gfp_t gfp`` allocation flagsh](j)}(h ``gfp_t gfp``h]j)}(hjP(h]h gfp_t gfp}(hjR(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjN(ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjJ(ubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hji(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjf(ubah}(h]h ]h"]h$]h&]uh1j5hjJ(ubeh}(h]h ]h"]h$]h&]uh1jhje(hM!hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_new_sta (C function)c.cfg80211_new_stahNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hivoid cfg80211_new_sta (struct net_device *dev, const u8 *mac_addr, struct station_info *sinfo, gfp_t gfp)h]jo)}(hhvoid cfg80211_new_sta(struct net_device *dev, const u8 *mac_addr, struct station_info *sinfo, gfp_t gfp)h](j)}(hvoidh]hvoid}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!ubj)}(h h]h }(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(hhhj(hM!ubj)}(hcfg80211_new_stah]j)}(hcfg80211_new_stah]hcfg80211_new_sta}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj(hhhj(hM!ubj)}(hS(struct net_device *dev, const u8 *mac_addr, struct station_info *sinfo, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj(ubj)}(h h]h }(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(ubh)}(hhh]j)}(h net_deviceh]h net_device}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj)modnameN classnameNj j )}j ]j)}jj(sbc.cfg80211_new_staasbuh1hhj(ubj)}(h h]h }(hj%)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(ubj.)}(hj1h]h*}(hj3)hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj(ubj)}(hdevh]hdev}(hj@)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj(ubj)}(hconst u8 *mac_addrh](ju)}(hjHh]hconst}(hjY)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjU)ubj)}(h h]h }(hjf)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjU)ubh)}(hhh]j)}(hu8h]hu8}(hjw)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjt)ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftarget.jy)modnameN classnameNj j )}j ]j!)c.cfg80211_new_staasbuh1hhjU)ubj)}(h h]h }(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjU)ubj.)}(hj1h]h*}(hj)hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjU)ubj)}(hmac_addrh]hmac_addr}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjU)ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj(ubj)}(hstruct station_info *sinfoh](ju)}(hjh]hstruct}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj)ubj)}(h h]h }(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubh)}(hhh]j)}(h station_infoh]h station_info}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj)modnameN classnameNj j )}j ]j!)c.cfg80211_new_staasbuh1hhj)ubj)}(h h]h }(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubj.)}(hj1h]h*}(hj*hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj)ubj)}(hsinfoh]hsinfo}(hj *hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj(ubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hj<*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj9*ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj>*modnameN classnameNj j )}j ]j!)c.cfg80211_new_staasbuh1hhj5*ubj)}(h h]h }(hjZ*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5*ubj)}(hgfph]hgfp}(hjh*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5*ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj(ubeh}(h]h ]h"]h$]h&]jjuh1jhj(hhhj(hM!ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj(hhhj(hM!ubah}(h]j(ah ](jjeh"]h$]h&]jj)jhuh1jhhj(hM!hj(hhubj)}(hhh]h)}(hnotify userspace about stationh]hnotify userspace about station}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj*hhubah}(h]h ]h"]h$]h&]uh1jhj(hhhj(hM!ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj*jj*jjjuh1jchhhj^bhNhNubj)}(h**Parameters** ``struct net_device *dev`` the netdev ``const u8 *mac_addr`` the station's address ``struct station_info *sinfo`` the station information ``gfp_t gfp`` allocation flagsh](h)}(h**Parameters**h]j)}(hj*h]h Parameters}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj*ubj)}(hhh](j)}(h&``struct net_device *dev`` the netdev h](j)}(h``struct net_device *dev``h]j)}(hj*h]hstruct net_device *dev}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj*ubj6)}(hhh]h)}(h the netdevh]h the netdev}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hM!hj*ubah}(h]h ]h"]h$]h&]uh1j5hj*ubeh}(h]h ]h"]h$]h&]uh1jhj*hM!hj*ubj)}(h-``const u8 *mac_addr`` the station's address h](j)}(h``const u8 *mac_addr``h]j)}(hj +h]hconst u8 *mac_addr}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj +ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj+ubj6)}(hhh]h)}(hthe station's addressh]hthe station’s address}(hj%+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!+hM!hj"+ubah}(h]h ]h"]h$]h&]uh1j5hj+ubeh}(h]h ]h"]h$]h&]uh1jhj!+hM!hj*ubj)}(h7``struct station_info *sinfo`` the station information h](j)}(h``struct station_info *sinfo``h]j)}(hjE+h]hstruct station_info *sinfo}(hjG+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjC+ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj?+ubj6)}(hhh]h)}(hthe station informationh]hthe station information}(hj^+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZ+hM!hj[+ubah}(h]h ]h"]h$]h&]uh1j5hj?+ubeh}(h]h ]h"]h$]h&]uh1jhjZ+hM!hj*ubj)}(h``gfp_t gfp`` allocation flagsh](j)}(h ``gfp_t gfp``h]j)}(hj~+h]h gfp_t gfp}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|+ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjx+ubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj+ubah}(h]h ]h"]h$]h&]uh1j5hjx+ubeh}(h]h ]h"]h$]h&]uh1jhj+hM!hj*ubeh}(h]h ]h"]h$]h&]uh1jhj*ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_rx_mgmt (C function)c.cfg80211_rx_mgmthNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hnbool cfg80211_rx_mgmt (struct wireless_dev *wdev, int freq, int sig_dbm, const u8 *buf, size_t len, u32 flags)h]jo)}(hmbool cfg80211_rx_mgmt(struct wireless_dev *wdev, int freq, int sig_dbm, const u8 *buf, size_t len, u32 flags)h](j)}(hjh]hbool}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMI"ubj)}(h h]h }(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+hhhj+hMI"ubj)}(hcfg80211_rx_mgmth]j)}(hcfg80211_rx_mgmth]hcfg80211_rx_mgmt}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj+hhhj+hMI"ubj)}(hX(struct wireless_dev *wdev, int freq, int sig_dbm, const u8 *buf, size_t len, u32 flags)h](j)}(hstruct wireless_dev *wdevh](ju)}(hjh]hstruct}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj,ubj)}(h h]h }(hj!,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubh)}(hhh]j)}(h wireless_devh]h wireless_dev}(hj2,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/,ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj4,modnameN classnameNj j )}j ]j)}jj+sbc.cfg80211_rx_mgmtasbuh1hhj,ubj)}(h h]h }(hjR,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubj.)}(hj1h]h*}(hj`,hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj,ubj)}(hwdevh]hwdev}(hjm,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ,ubj)}(hint freqh](j)}(hinth]hint}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubj)}(h h]h }(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubj)}(hfreqh]hfreq}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ,ubj)}(h int sig_dbmh](j)}(hinth]hint}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubj)}(h h]h }(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubj)}(hsig_dbmh]hsig_dbm}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ,ubj)}(h const u8 *bufh](ju)}(hjHh]hconst}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj,ubj)}(h h]h }(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubh)}(hhh]j)}(hu8h]hu8}(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj -ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj-modnameN classnameNj j )}j ]jN,c.cfg80211_rx_mgmtasbuh1hhj,ubj)}(h h]h }(hj,-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubj.)}(hj1h]h*}(hj:-hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj,ubj)}(hbufh]hbuf}(hjG-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ,ubj)}(h size_t lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjc-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`-ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetje-modnameN classnameNj j )}j ]jN,c.cfg80211_rx_mgmtasbuh1hhj\-ubj)}(h h]h }(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\-ubj)}(hlenh]hlen}(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\-ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ,ubj)}(h u32 flagsh](h)}(hhh]j)}(hu32h]hu32}(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj-modnameN classnameNj j )}j ]jN,c.cfg80211_rx_mgmtasbuh1hhj-ubj)}(h h]h }(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj-ubj)}(hflagsh]hflags}(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj-ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ,ubeh}(h]h ]h"]h$]h&]jjuh1jhj+hhhj+hMI"ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj+hhhj+hMI"ubah}(h]j+ah ](jjeh"]h$]h&]jj)jhuh1jhhj+hMI"hj+hhubj)}(hhh]h)}(h6notification of received, unprocessed management frameh]h6notification of received, unprocessed management frame}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMI"hj-hhubah}(h]h ]h"]h$]h&]uh1jhj+hhhj+hMI"ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj.jj.jjjuh1jchhhj^bhNhNubj)}(hX **Parameters** ``struct wireless_dev *wdev`` wireless device receiving the frame ``int freq`` Frequency on which the frame was received in MHz ``int sig_dbm`` signal strength in dBm, or 0 if unknown ``const u8 *buf`` Management frame (header + body) ``size_t len`` length of the frame data ``u32 flags`` flags, as defined in enum nl80211_rxmgmt_flags **Description** This function is called whenever an Action frame is received for a station mode interface, but is not processed in kernel. **Return** ``true`` if a user space application has registered for this frame. For action frames, that makes it responsible for rejecting unrecognized action frames; ``false`` otherwise, in which case for action frames the driver is responsible for rejecting the frame.h](h)}(h**Parameters**h]j)}(hj#.h]h Parameters}(hj%.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!.ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMM"hj.ubj)}(hhh](j)}(hB``struct wireless_dev *wdev`` wireless device receiving the frame h](j)}(h``struct wireless_dev *wdev``h]j)}(hjB.h]hstruct wireless_dev *wdev}(hjD.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@.ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMJ"hj<.ubj6)}(hhh]h)}(h#wireless device receiving the frameh]h#wireless device receiving the frame}(hj[.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjW.hMJ"hjX.ubah}(h]h ]h"]h$]h&]uh1j5hj<.ubeh}(h]h ]h"]h$]h&]uh1jhjW.hMJ"hj9.ubj)}(h>``int freq`` Frequency on which the frame was received in MHz h](j)}(h ``int freq``h]j)}(hj{.h]hint freq}(hj}.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjy.ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMK"hju.ubj6)}(hhh]h)}(h0Frequency on which the frame was received in MHzh]h0Frequency on which the frame was received in MHz}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.hMK"hj.ubah}(h]h ]h"]h$]h&]uh1j5hju.ubeh}(h]h ]h"]h$]h&]uh1jhj.hMK"hj9.ubj)}(h8``int sig_dbm`` signal strength in dBm, or 0 if unknown h](j)}(h``int sig_dbm``h]j)}(hj.h]h int sig_dbm}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhML"hj.ubj6)}(hhh]h)}(h'signal strength in dBm, or 0 if unknownh]h'signal strength in dBm, or 0 if unknown}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.hML"hj.ubah}(h]h ]h"]h$]h&]uh1j5hj.ubeh}(h]h ]h"]h$]h&]uh1jhj.hML"hj9.ubj)}(h3``const u8 *buf`` Management frame (header + body) h](j)}(h``const u8 *buf``h]j)}(hj.h]h const u8 *buf}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMM"hj.ubj6)}(hhh]h)}(h Management frame (header + body)h]h Management frame (header + body)}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hMM"hj/ubah}(h]h ]h"]h$]h&]uh1j5hj.ubeh}(h]h ]h"]h$]h&]uh1jhj/hMM"hj9.ubj)}(h(``size_t len`` length of the frame data h](j)}(h``size_t len``h]j)}(hj&/h]h size_t len}(hj(/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$/ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMN"hj /ubj6)}(hhh]h)}(hlength of the frame datah]hlength of the frame data}(hj?/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj;/hMN"hj``s32 rssi_level`` new RSSI level value or 0 if not available h](j)}(h``s32 rssi_level``h]j)}(hj6h]hs32 rssi_level}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj6ubj6)}(hhh]h)}(h*new RSSI level value or 0 if not availableh]h*new RSSI level value or 0 if not available}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hM"hj6ubah}(h]h ]h"]h$]h&]uh1j5hj6ubeh}(h]h ]h"]h$]h&]uh1jhj6hM"hj+6ubj)}(h``gfp_t gfp`` context flags h](j)}(h ``gfp_t gfp``h]j)}(hj6h]h gfp_t gfp}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj6ubj6)}(hhh]h)}(h context flagsh]h context flags}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hM"hj6ubah}(h]h ]h"]h$]h&]uh1j5hj6ubeh}(h]h ]h"]h$]h&]uh1jhj6hM"hj+6ubeh}(h]h ]h"]h$]h&]uh1jhj6ubh)}(h**Description**h]j)}(hj7h]h Description}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj6ubh)}(hlThis function is called when a configured connection quality monitoring rssi threshold reached event occurs.h]hlThis function is called when a configured connection quality monitoring rssi threshold reached event occurs.}(hj07hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj6ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_(cfg80211_cqm_pktloss_notify (C function)c.cfg80211_cqm_pktloss_notifyhNtauh1jRhj^bhhhNhNubjd)}(hhh](ji)}(hevoid cfg80211_cqm_pktloss_notify (struct net_device *dev, const u8 *peer, u32 num_packets, gfp_t gfp)h]jo)}(hdvoid cfg80211_cqm_pktloss_notify(struct net_device *dev, const u8 *peer, u32 num_packets, gfp_t gfp)h](j)}(hvoidh]hvoid}(hj_7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[7hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"ubj)}(h h]h }(hjn7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[7hhhjm7hM"ubj)}(hcfg80211_cqm_pktloss_notifyh]j)}(hcfg80211_cqm_pktloss_notifyh]hcfg80211_cqm_pktloss_notify}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj|7ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj[7hhhjm7hM"ubj)}(hD(struct net_device *dev, const u8 *peer, u32 num_packets, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj7ubj)}(h h]h }(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7ubh)}(hhh]j)}(h net_deviceh]h net_device}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj7modnameN classnameNj j )}j ]j)}jj7sbc.cfg80211_cqm_pktloss_notifyasbuh1hhj7ubj)}(h h]h }(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7ubj.)}(hj1h]h*}(hj7hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj7ubj)}(hdevh]hdev}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj7ubj)}(hconst u8 *peerh](ju)}(hjHh]hconst}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj 8ubj)}(h h]h }(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj 8ubh)}(hhh]j)}(hu8h]hu8}(hj,8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)8ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj.8modnameN classnameNj j )}j ]j7c.cfg80211_cqm_pktloss_notifyasbuh1hhj 8ubj)}(h h]h }(hjJ8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj 8ubj.)}(hj1h]h*}(hjX8hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj 8ubj)}(hpeerh]hpeer}(hje8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj 8ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj7ubj)}(hu32 num_packetsh](h)}(hhh]j)}(hu32h]hu32}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj~8ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj8modnameN classnameNj j )}j ]j7c.cfg80211_cqm_pktloss_notifyasbuh1hhjz8ubj)}(h h]h }(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjz8ubj)}(h num_packetsh]h num_packets}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjz8ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj7ubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj8modnameN classnameNj j )}j ]j7c.cfg80211_cqm_pktloss_notifyasbuh1hhj8ubj)}(h h]h }(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubj)}(hgfph]hgfp}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj7ubeh}(h]h ]h"]h$]h&]jjuh1jhj[7hhhjm7hM"ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjW7hhhjm7hM"ubah}(h]jR7ah ](jjeh"]h$]h&]jj)jhuh1jhhjm7hM"hjT7hhubj)}(hhh]h)}(h)notify userspace about packetloss to peerh]h)notify userspace about packetloss to peer}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj9hhubah}(h]h ]h"]h$]h&]uh1jhjT7hhhjm7hM"ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj79jj79jjjuh1jchhhj^bhNhNubj)}(hXN**Parameters** ``struct net_device *dev`` network device ``const u8 *peer`` peer's MAC address ``u32 num_packets`` how many packets were lost -- should be a fixed threshold but probably no less than maybe 50, or maybe a throughput dependent threshold (to account for temporary interference) ``gfp_t gfp`` context flagsh](h)}(h**Parameters**h]j)}(hjA9h]h Parameters}(hjC9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?9ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj;9ubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hj`9h]hstruct net_device *dev}(hjb9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^9ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjZ9ubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjy9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhju9hM"hjv9ubah}(h]h ]h"]h$]h&]uh1j5hjZ9ubeh}(h]h ]h"]h$]h&]uh1jhju9hM"hjW9ubj)}(h&``const u8 *peer`` peer's MAC address h](j)}(h``const u8 *peer``h]j)}(hj9h]hconst u8 *peer}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj9ubj6)}(hhh]h)}(hpeer's MAC addressh]hpeer’s MAC address}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hM"hj9ubah}(h]h ]h"]h$]h&]uh1j5hj9ubeh}(h]h ]h"]h$]h&]uh1jhj9hM"hjW9ubj)}(h``u32 num_packets`` how many packets were lost -- should be a fixed threshold but probably no less than maybe 50, or maybe a throughput dependent threshold (to account for temporary interference) h](j)}(h``u32 num_packets``h]j)}(hj9h]hu32 num_packets}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj9ubj6)}(hhh]h)}(hhow many packets were lost -- should be a fixed threshold but probably no less than maybe 50, or maybe a throughput dependent threshold (to account for temporary interference)h]hhow many packets were lost -- should be a fixed threshold but probably no less than maybe 50, or maybe a throughput dependent threshold (to account for temporary interference)}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj9ubah}(h]h ]h"]h$]h&]uh1j5hj9ubeh}(h]h ]h"]h$]h&]uh1jhj9hM"hjW9ubj)}(h``gfp_t gfp`` context flagsh](j)}(h ``gfp_t gfp``h]j)}(hj :h]h gfp_t gfp}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj :ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj:ubj6)}(hhh]h)}(h context flagsh]h context flags}(hj%:hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj":ubah}(h]h ]h"]h$]h&]uh1j5hj:ubeh}(h]h ]h"]h$]h&]uh1jhj!:hM"hjW9ubeh}(h]h ]h"]h$]h&]uh1jhj;9ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^bhhhNhNubeh}(h]actions-and-configurationah ]h"]actions and configurationah$]h&]uh1hhhhhhhhK+ubh)}(hhh](h)}(hScanning and BSS list handlingh]hScanning and BSS list handling}(hjX:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjU:hhhhhKaubh)}(hX\The scanning process itself is fairly simple, but cfg80211 offers quite a bit of helper functionality. To start a scan, the scan operation will be invoked with a scan definition. This scan definition contains the channels to scan, and the SSIDs to send probe requests for (including the wildcard, if desired). A passive scan is indicated by having no SSIDs to probe. Additionally, a scan request may contain extra information elements that should be added to the probe request. The IEs are guaranteed to be well-formed, and will not exceed the maximum length the driver advertised in the wiphy structure.h]hX\The scanning process itself is fairly simple, but cfg80211 offers quite a bit of helper functionality. To start a scan, the scan operation will be invoked with a scan definition. This scan definition contains the channels to scan, and the SSIDs to send probe requests for (including the wildcard, if desired). A passive scan is indicated by having no SSIDs to probe. Additionally, a scan request may contain extra information elements that should be added to the probe request. The IEs are guaranteed to be well-formed, and will not exceed the maximum length the driver advertised in the wiphy structure.}(hjf:hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:99: ./include/net/cfg80211.hhM hjU:hhubh)}(hWhen scanning finds a BSS, cfg80211 needs to be notified of that, because it is responsible for maintaining the BSS list; the driver should not maintain a list itself. For this notification, various functions exist.h]hWhen scanning finds a BSS, cfg80211 needs to be notified of that, because it is responsible for maintaining the BSS list; the driver should not maintain a list itself. For this notification, various functions exist.}(hju:hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:99: ./include/net/cfg80211.hhM hjU:hhubh)}(hSince drivers do not maintain a BSS list, there are also a number of functions to search for a BSS and obtain information about it from the BSS structure cfg80211 maintains. The BSS list is also made available to userspace.h]hSince drivers do not maintain a BSS list, there are also a number of functions to search for a BSS and obtain information about it from the BSS structure cfg80211 maintains. The BSS list is also made available to userspace.}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:99: ./include/net/cfg80211.hhM hjU:hhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_ssid (C struct)c.cfg80211_ssidhNtauh1jRhjU:hhhNhNubjd)}(hhh](ji)}(h cfg80211_ssidh]jo)}(hstruct cfg80211_ssidh](ju)}(hjh]hstruct}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj:hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhKubj)}(h h]h }(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:hhhj:hKubj)}(h cfg80211_ssidh]j)}(hj:h]h cfg80211_ssid}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj:hhhj:hKubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj:hhhj:hKubah}(h]j:ah ](jjeh"]h$]h&]jj)jhuh1jhhj:hKhj:hhubj)}(hhh]h)}(hSSID descriptionh]hSSID description}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj:hhubah}(h]h ]h"]h$]h&]uh1jhj:hhhj:hKubeh}(h]h ](j$structeh"]h$]h&]jj$jj;jj;jjjuh1jchhhjU:hNhNubj)}(h**Definition**:: struct cfg80211_ssid { u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; }; **Members** ``ssid`` the SSID ``ssid_len`` length of the ssidh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj;ubh:}(hj;hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj ;ubj( )}(hOstruct cfg80211_ssid { u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; };h]hOstruct cfg80211_ssid { u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; };}hj+;sbah}(h]h ]h"]h$]h&]jjuh1j' ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj ;ubh)}(h **Members**h]j)}(hj<;h]hMembers}(hj>;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:;ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj ;ubj)}(hhh](j)}(h``ssid`` the SSID h](j)}(h``ssid``h]j)}(hj[;h]hssid}(hj];hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjY;ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjU;ubj6)}(hhh]h)}(hthe SSIDh]hthe SSID}(hjt;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjp;hM hjq;ubah}(h]h ]h"]h$]h&]uh1j5hjU;ubeh}(h]h ]h"]h$]h&]uh1jhjp;hM hjR;ubj)}(h``ssid_len`` length of the ssidh](j)}(h ``ssid_len``h]j)}(hj;h]hssid_len}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj;ubj6)}(hhh]h)}(hlength of the ssidh]hlength of the ssid}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj;ubah}(h]h ]h"]h$]h&]uh1j5hj;ubeh}(h]h ]h"]h$]h&]uh1jhj;hM hjR;ubeh}(h]h ]h"]h$]h&]uh1jhj ;ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjU:hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ cfg80211_scan_request (C struct)c.cfg80211_scan_requesthNtauh1jRhjU:hhhNhNubjd)}(hhh](ji)}(hcfg80211_scan_requesth]jo)}(hstruct cfg80211_scan_requesth](ju)}(hjh]hstruct}(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj;hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM ubj)}(h h]h }(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj;hhhj;hM ubj)}(hcfg80211_scan_requesth]j)}(hj;h]hcfg80211_scan_request}(hj<hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj <ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj;hhhj;hM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj;hhhj;hM ubah}(h]j;ah ](jjeh"]h$]h&]jj)jhuh1jhhj;hM hj;hhubj)}(hhh]h)}(hscan request descriptionh]hscan request description}(hj0<hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj-<hhubah}(h]h ]h"]h$]h&]uh1jhj;hhhj;hM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjH<jjH<jjjuh1jchhhjU:hNhNubj)}(hXn **Definition**:: struct cfg80211_scan_request { struct cfg80211_ssid *ssids; int n_ssids; u32 n_channels; const u8 *ie; size_t ie_len; u16 duration; bool duration_mandatory; u32 flags; u32 rates[NUM_NL80211_BANDS]; struct wireless_dev *wdev; u8 mac_addr[ETH_ALEN] ; u8 mac_addr_mask[ETH_ALEN] ; u8 bssid[ETH_ALEN] ; struct wiphy *wiphy; unsigned long scan_start; bool no_cck; bool scan_6ghz; bool first_part; u32 n_6ghz_params; struct cfg80211_scan_6ghz_params *scan_6ghz_params; s8 tsf_report_link_id; struct ieee80211_channel *channels[]; }; **Members** ``ssids`` SSIDs to scan for (active scan only) ``n_ssids`` number of SSIDs ``n_channels`` total number of channels to scan ``ie`` optional information element(s) to add into Probe Request or ``NULL`` ``ie_len`` length of ie in octets ``duration`` how long to listen on each channel, in TUs. If ``duration_mandatory`` is not set, this is the maximum dwell time and the actual dwell time may be shorter. ``duration_mandatory`` if set, the scan duration must be as specified by the ``duration`` field. ``flags`` control flags from :c:type:`enum nl80211_scan_flags ` ``rates`` bitmap of rates to advertise for each band ``wdev`` the wireless device to scan for ``mac_addr`` MAC address used with randomisation ``mac_addr_mask`` MAC address mask used with randomisation, bits that are 0 in the mask should be randomised, bits that are 1 should be taken from the **mac_addr** ``bssid`` BSSID to scan for (most commonly, the wildcard BSSID) ``wiphy`` the wiphy this was for ``scan_start`` time (in jiffies) when the scan started ``no_cck`` used to send probe requests at non CCK rate in 2GHz band ``scan_6ghz`` relevant for split scan request only, true if this is a 6 GHz scan request ``first_part`` ``true`` if this is the first part of a split scan request or a scan that was not split. May be ``true`` for a **scan_6ghz** scan if no other channels were requested ``n_6ghz_params`` number of 6 GHz params ``scan_6ghz_params`` 6 GHz params ``tsf_report_link_id`` for MLO, indicates the link ID of the BSS that should be used for TSF reporting. Can be set to -1 to indicate no preference. ``channels`` channels to scan on.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjT<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjP<ubh:}(hjP<hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjL<ubj( )}(hXfstruct cfg80211_scan_request { struct cfg80211_ssid *ssids; int n_ssids; u32 n_channels; const u8 *ie; size_t ie_len; u16 duration; bool duration_mandatory; u32 flags; u32 rates[NUM_NL80211_BANDS]; struct wireless_dev *wdev; u8 mac_addr[ETH_ALEN] ; u8 mac_addr_mask[ETH_ALEN] ; u8 bssid[ETH_ALEN] ; struct wiphy *wiphy; unsigned long scan_start; bool no_cck; bool scan_6ghz; bool first_part; u32 n_6ghz_params; struct cfg80211_scan_6ghz_params *scan_6ghz_params; s8 tsf_report_link_id; struct ieee80211_channel *channels[]; };h]hXfstruct cfg80211_scan_request { struct cfg80211_ssid *ssids; int n_ssids; u32 n_channels; const u8 *ie; size_t ie_len; u16 duration; bool duration_mandatory; u32 flags; u32 rates[NUM_NL80211_BANDS]; struct wireless_dev *wdev; u8 mac_addr[ETH_ALEN] ; u8 mac_addr_mask[ETH_ALEN] ; u8 bssid[ETH_ALEN] ; struct wiphy *wiphy; unsigned long scan_start; bool no_cck; bool scan_6ghz; bool first_part; u32 n_6ghz_params; struct cfg80211_scan_6ghz_params *scan_6ghz_params; s8 tsf_report_link_id; struct ieee80211_channel *channels[]; };}hjm<sbah}(h]h ]h"]h$]h&]jjuh1j' ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjL<ubh)}(h **Members**h]j)}(hj~<h]hMembers}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|<ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjL<ubj)}(hhh](j)}(h/``ssids`` SSIDs to scan for (active scan only) h](j)}(h ``ssids``h]j)}(hj<h]hssids}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj<ubj6)}(hhh]h)}(h$SSIDs to scan for (active scan only)h]h$SSIDs to scan for (active scan only)}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hM hj<ubah}(h]h ]h"]h$]h&]uh1j5hj<ubeh}(h]h ]h"]h$]h&]uh1jhj<hM hj<ubj)}(h``n_ssids`` number of SSIDs h](j)}(h ``n_ssids``h]j)}(hj<h]hn_ssids}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj<ubj6)}(hhh]h)}(hnumber of SSIDsh]hnumber of SSIDs}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hM hj<ubah}(h]h ]h"]h$]h&]uh1j5hj<ubeh}(h]h ]h"]h$]h&]uh1jhj<hM hj<ubj)}(h0``n_channels`` total number of channels to scan h](j)}(h``n_channels``h]j)}(hj=h]h n_channels}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj =ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj =ubj6)}(hhh]h)}(h total number of channels to scanh]h total number of channels to scan}(hj(=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$=hM hj%=ubah}(h]h ]h"]h$]h&]uh1j5hj =ubeh}(h]h ]h"]h$]h&]uh1jhj$=hM hj<ubj)}(hM``ie`` optional information element(s) to add into Probe Request or ``NULL`` h](j)}(h``ie``h]j)}(hjH=h]hie}(hjJ=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjF=ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjB=ubj6)}(hhh]h)}(hEoptional information element(s) to add into Probe Request or ``NULL``h](h=optional information element(s) to add into Probe Request or }(hja=hhhNhNubj)}(h``NULL``h]hNULL}(hji=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhja=ubeh}(h]h ]h"]h$]h&]uh1hhj]=hM hj^=ubah}(h]h ]h"]h$]h&]uh1j5hjB=ubeh}(h]h ]h"]h$]h&]uh1jhj]=hM hj<ubj)}(h"``ie_len`` length of ie in octets h](j)}(h ``ie_len``h]j)}(hj=h]hie_len}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj=ubj6)}(hhh]h)}(hlength of ie in octetsh]hlength of ie in octets}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=hM hj=ubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhj=hM hj<ubj)}(h``duration`` how long to listen on each channel, in TUs. If ``duration_mandatory`` is not set, this is the maximum dwell time and the actual dwell time may be shorter. h](j)}(h ``duration``h]j)}(hj=h]hduration}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj=ubj6)}(hhh]h)}(hhow long to listen on each channel, in TUs. If ``duration_mandatory`` is not set, this is the maximum dwell time and the actual dwell time may be shorter.h](h/how long to listen on each channel, in TUs. If }(hj=hhhNhNubj)}(h``duration_mandatory``h]hduration_mandatory}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubhU is not set, this is the maximum dwell time and the actual dwell time may be shorter.}(hj=hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj=ubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhj=hM hj<ubj)}(ha``duration_mandatory`` if set, the scan duration must be as specified by the ``duration`` field. h](j)}(h``duration_mandatory``h]j)}(hj>h]hduration_mandatory}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj>ubj6)}(hhh]h)}(hIif set, the scan duration must be as specified by the ``duration`` field.h](h6if set, the scan duration must be as specified by the }(hj->hhhNhNubj)}(h ``duration``h]hduration}(hj5>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj->ubh field.}(hj->hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj*>ubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhj)>hM hj<ubj)}(hT``flags`` control flags from :c:type:`enum nl80211_scan_flags ` h](j)}(h ``flags``h]j)}(hj`>h]hflags}(hjb>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^>ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjZ>ubj6)}(hhh]h)}(hIcontrol flags from :c:type:`enum nl80211_scan_flags `h](hcontrol flags from }(hjy>hhhNhNubh)}(h6:c:type:`enum nl80211_scan_flags `h]j)}(hj>h]henum nl80211_scan_flags}(hj>hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_scan_flagsuh1hhju>hM hjy>ubeh}(h]h ]h"]h$]h&]uh1hhju>hM hjv>ubah}(h]h ]h"]h$]h&]uh1j5hjZ>ubeh}(h]h ]h"]h$]h&]uh1jhju>hM hj<ubj)}(h5``rates`` bitmap of rates to advertise for each band h](j)}(h ``rates``h]j)}(hj>h]hrates}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj>ubj6)}(hhh]h)}(h*bitmap of rates to advertise for each bandh]h*bitmap of rates to advertise for each band}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hM hj>ubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhj>hM hj<ubj)}(h)``wdev`` the wireless device to scan for h](j)}(h``wdev``h]j)}(hj>h]hwdev}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj>ubj6)}(hhh]h)}(hthe wireless device to scan forh]hthe wireless device to scan for}(hj ?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hM hj?ubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhj?hM hj<ubj)}(h1``mac_addr`` MAC address used with randomisation h](j)}(h ``mac_addr``h]j)}(hj*?h]hmac_addr}(hj,?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(?ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj$?ubj6)}(hhh]h)}(h#MAC address used with randomisationh]h#MAC address used with randomisation}(hjC?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj??hM hj@?ubah}(h]h ]h"]h$]h&]uh1j5hj$?ubeh}(h]h ]h"]h$]h&]uh1jhj??hM hj<ubj)}(h``mac_addr_mask`` MAC address mask used with randomisation, bits that are 0 in the mask should be randomised, bits that are 1 should be taken from the **mac_addr** h](j)}(h``mac_addr_mask``h]j)}(hjc?h]h mac_addr_mask}(hje?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhja?ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj]?ubj6)}(hhh]h)}(hMAC address mask used with randomisation, bits that are 0 in the mask should be randomised, bits that are 1 should be taken from the **mac_addr**h](hMAC address mask used with randomisation, bits that are 0 in the mask should be randomised, bits that are 1 should be taken from the }(hj|?hhhNhNubj)}(h **mac_addr**h]hmac_addr}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|?ubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjy?ubah}(h]h ]h"]h$]h&]uh1j5hj]?ubeh}(h]h ]h"]h$]h&]uh1jhjx?hM hj<ubj)}(h@``bssid`` BSSID to scan for (most commonly, the wildcard BSSID) h](j)}(h ``bssid``h]j)}(hj?h]hbssid}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj?ubj6)}(hhh]h)}(h5BSSID to scan for (most commonly, the wildcard BSSID)h]h5BSSID to scan for (most commonly, the wildcard BSSID)}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hM hj?ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhj?hM hj<ubj)}(h!``wiphy`` the wiphy this was for h](j)}(h ``wiphy``h]j)}(hj?h]hwiphy}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj?ubj6)}(hhh]h)}(hthe wiphy this was forh]hthe wiphy this was for}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hM hj?ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhj?hM hj<ubj)}(h7``scan_start`` time (in jiffies) when the scan started h](j)}(h``scan_start``h]j)}(hj@h]h scan_start}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj@ubj6)}(hhh]h)}(h'time (in jiffies) when the scan startedh]h'time (in jiffies) when the scan started}(hj6@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2@hM hj3@ubah}(h]h ]h"]h$]h&]uh1j5hj@ubeh}(h]h ]h"]h$]h&]uh1jhj2@hM hj<ubj)}(hD``no_cck`` used to send probe requests at non CCK rate in 2GHz band h](j)}(h ``no_cck``h]j)}(hjV@h]hno_cck}(hjX@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjT@ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjP@ubj6)}(hhh]h)}(h8used to send probe requests at non CCK rate in 2GHz bandh]h8used to send probe requests at non CCK rate in 2GHz band}(hjo@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjk@hM hjl@ubah}(h]h ]h"]h$]h&]uh1j5hjP@ubeh}(h]h ]h"]h$]h&]uh1jhjk@hM hj<ubj)}(hY``scan_6ghz`` relevant for split scan request only, true if this is a 6 GHz scan request h](j)}(h ``scan_6ghz``h]j)}(hj@h]h scan_6ghz}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj@ubj6)}(hhh]h)}(hJrelevant for split scan request only, true if this is a 6 GHz scan requesth]hJrelevant for split scan request only, true if this is a 6 GHz scan request}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj@ubah}(h]h ]h"]h$]h&]uh1j5hj@ubeh}(h]h ]h"]h$]h&]uh1jhj@hM hj<ubj)}(h``first_part`` ``true`` if this is the first part of a split scan request or a scan that was not split. May be ``true`` for a **scan_6ghz** scan if no other channels were requested h](j)}(h``first_part``h]j)}(hj@h]h first_part}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj@ubj6)}(hhh]h)}(h``true`` if this is the first part of a split scan request or a scan that was not split. May be ``true`` for a **scan_6ghz** scan if no other channels were requestedh](j)}(h``true``h]htrue}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubhX if this is the first part of a split scan request or a scan that was not split. May be }(hj@hhhNhNubj)}(h``true``h]htrue}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubh for a }(hj@hhhNhNubj)}(h **scan_6ghz**h]h scan_6ghz}(hj AhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@ubh) scan if no other channels were requested}(hj@hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj@ubah}(h]h ]h"]h$]h&]uh1j5hj@ubeh}(h]h ]h"]h$]h&]uh1jhj@hM hj<ubj)}(h)``n_6ghz_params`` number of 6 GHz params h](j)}(h``n_6ghz_params``h]j)}(hj5Ah]h n_6ghz_params}(hj7AhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3Aubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj/Aubj6)}(hhh]h)}(hnumber of 6 GHz paramsh]hnumber of 6 GHz params}(hjNAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJAhM hjKAubah}(h]h ]h"]h$]h&]uh1j5hj/Aubeh}(h]h ]h"]h$]h&]uh1jhjJAhM hj<ubj)}(h"``scan_6ghz_params`` 6 GHz params h](j)}(h``scan_6ghz_params``h]j)}(hjnAh]hscan_6ghz_params}(hjpAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlAubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjhAubj6)}(hhh]h)}(h 6 GHz paramsh]h 6 GHz params}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjAhM hjAubah}(h]h ]h"]h$]h&]uh1j5hjhAubeh}(h]h ]h"]h$]h&]uh1jhjAhM hj<ubj)}(h``tsf_report_link_id`` for MLO, indicates the link ID of the BSS that should be used for TSF reporting. Can be set to -1 to indicate no preference. h](j)}(h``tsf_report_link_id``h]j)}(hjAh]htsf_report_link_id}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjAubj6)}(hhh]h)}(h|for MLO, indicates the link ID of the BSS that should be used for TSF reporting. Can be set to -1 to indicate no preference.h]h|for MLO, indicates the link ID of the BSS that should be used for TSF reporting. Can be set to -1 to indicate no preference.}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjAubah}(h]h ]h"]h$]h&]uh1j5hjAubeh}(h]h ]h"]h$]h&]uh1jhjAhM hj<ubj)}(h!``channels`` channels to scan on.h](j)}(h ``channels``h]j)}(hjAh]hchannels}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjAubj6)}(hhh]h)}(hchannels to scan on.h]hchannels to scan on.}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjAubah}(h]h ]h"]h$]h&]uh1j5hjAubeh}(h]h ]h"]h$]h&]uh1jhjAhM hj<ubeh}(h]h ]h"]h$]h&]uh1jhjL<ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjU:hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_inform_bss (C struct)c.cfg80211_inform_bsshNtauh1jRhjU:hhhNhNubjd)}(hhh](ji)}(hcfg80211_inform_bssh]jo)}(hstruct cfg80211_inform_bssh](ju)}(hjh]hstruct}(hj;BhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj7Bhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjIBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7BhhhjHBhM ubj)}(hcfg80211_inform_bssh]j)}(hj5Bh]hcfg80211_inform_bss}(hj[BhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjWBubah}(h]h ](jjeh"]h$]h&]jjuh1jhj7BhhhjHBhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj3BhhhjHBhM ubah}(h]j.Bah ](jjeh"]h$]h&]jj)jhuh1jhhjHBhM hj0Bhhubj)}(hhh]h)}(hBSS inform datah]hBSS inform data}(hj}BhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjzBhhubah}(h]h ]h"]h$]h&]uh1jhj0BhhhjHBhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjBjjBjjjuh1jchhhjU:hNhNubj)}(hX8**Definition**:: struct cfg80211_inform_bss { struct ieee80211_channel *chan; s32 signal; u64 boottime_ns; u64 parent_tsf; u8 parent_bssid[ETH_ALEN] ; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; u8 restrict_use:1, use_for:7; u8 cannot_use_reasons; void *drv_data; }; **Members** ``chan`` channel the frame was received on ``signal`` signal strength value, according to the wiphy's signal type ``boottime_ns`` timestamp (CLOCK_BOOTTIME) when the information was received; should match the time when the frame was actually received by the device (not just by the host, in case it was buffered on the device) and be accurate to about 10ms. If the frame isn't buffered, just passing the return value of ktime_get_boottime_ns() is likely appropriate. ``parent_tsf`` the time at the start of reception of the first octet of the timestamp field of the frame. The time is the TSF of the BSS specified by ``parent_bssid``. ``parent_bssid`` the BSS according to which ``parent_tsf`` is set. This is set to the BSS that requested the scan in which the beacon/probe was received. ``chains`` bitmask for filled values in **chain_signal**. ``chain_signal`` per-chain signal strength of last received BSS in dBm. ``restrict_use`` restrict usage, if not set, assume **use_for** is ``NL80211_BSS_USE_FOR_NORMAL``. ``use_for`` bitmap of possible usage for this BSS, see :c:type:`enum nl80211_bss_use_for ` ``cannot_use_reasons`` the reasons (bitmap) for not being able to connect, if **restrict_use** is set and **use_for** is zero (empty); may be 0 for unspecified reasons; see :c:type:`enum nl80211_bss_cannot_use_reasons ` ``drv_data`` Data to be passed through to **inform_bss**h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBubh:}(hjBhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjBubj( )}(hX'struct cfg80211_inform_bss { struct ieee80211_channel *chan; s32 signal; u64 boottime_ns; u64 parent_tsf; u8 parent_bssid[ETH_ALEN] ; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; u8 restrict_use:1, use_for:7; u8 cannot_use_reasons; void *drv_data; };h]hX'struct cfg80211_inform_bss { struct ieee80211_channel *chan; s32 signal; u64 boottime_ns; u64 parent_tsf; u8 parent_bssid[ETH_ALEN] ; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; u8 restrict_use:1, use_for:7; u8 cannot_use_reasons; void *drv_data; };}hjBsbah}(h]h ]h"]h$]h&]jjuh1j' ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjBubh)}(h **Members**h]j)}(hjBh]hMembers}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjBubj)}(hhh](j)}(h+``chan`` channel the frame was received on h](j)}(h``chan``h]j)}(hjBh]hchan}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjBubj6)}(hhh]h)}(h!channel the frame was received onh]h!channel the frame was received on}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBhM hjCubah}(h]h ]h"]h$]h&]uh1j5hjBubeh}(h]h ]h"]h$]h&]uh1jhjBhM hjBubj)}(hG``signal`` signal strength value, according to the wiphy's signal type h](j)}(h ``signal``h]j)}(hj#Ch]hsignal}(hj%ChhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!Cubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjCubj6)}(hhh]h)}(h;signal strength value, according to the wiphy's signal typeh]h=signal strength value, according to the wiphy’s signal type}(hj` h](j)}(h ``use_for``h]j)}(hjEh]huse_for}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj Eubj6)}(hhh]h)}(hcbitmap of possible usage for this BSS, see :c:type:`enum nl80211_bss_use_for `h](h+bitmap of possible usage for this BSS, see }(hj*EhhhNhNubh)}(h8:c:type:`enum nl80211_bss_use_for `h]j)}(hj4Eh]henum nl80211_bss_use_for}(hj6EhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj2Eubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_bss_use_foruh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj*Eubeh}(h]h ]h"]h$]h&]uh1hhjQEhM hj'Eubah}(h]h ]h"]h$]h&]uh1j5hj Eubeh}(h]h ]h"]h$]h&]uh1jhj&EhM hjBubj)}(h``cannot_use_reasons`` the reasons (bitmap) for not being able to connect, if **restrict_use** is set and **use_for** is zero (empty); may be 0 for unspecified reasons; see :c:type:`enum nl80211_bss_cannot_use_reasons ` h](j)}(h``cannot_use_reasons``h]j)}(hjjEh]hcannot_use_reasons}(hjlEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhEubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjdEubj6)}(hhh]h)}(hthe reasons (bitmap) for not being able to connect, if **restrict_use** is set and **use_for** is zero (empty); may be 0 for unspecified reasons; see :c:type:`enum nl80211_bss_cannot_use_reasons `h](h7the reasons (bitmap) for not being able to connect, if }(hjEhhhNhNubj)}(h**restrict_use**h]h restrict_use}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjEubh is set and }(hjEhhhNhNubj)}(h **use_for**h]huse_for}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjEubh8 is zero (empty); may be 0 for unspecified reasons; see }(hjEhhhNhNubh)}(hN:c:type:`enum nl80211_bss_cannot_use_reasons `h]j)}(hjEh]h#enum nl80211_bss_cannot_use_reasons}(hjEhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_bss_cannot_use_reasonsuh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjEubeh}(h]h ]h"]h$]h&]uh1hhjEhM hjEubah}(h]h ]h"]h$]h&]uh1j5hjdEubeh}(h]h ]h"]h$]h&]uh1jhjEhM hjBubj)}(h8``drv_data`` Data to be passed through to **inform_bss**h](j)}(h ``drv_data``h]j)}(hjEh]hdrv_data}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjEubj6)}(hhh]h)}(h+Data to be passed through to **inform_bss**h](hData to be passed through to }(hjFhhhNhNubj)}(h**inform_bss**h]h inform_bss}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjEubah}(h]h ]h"]h$]h&]uh1j5hjEubeh}(h]h ]h"]h$]h&]uh1jhjEhM hjBubeh}(h]h ]h"]h$]h&]uh1jhjBubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjU:hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_bss (C struct)c.cfg80211_bsshNtauh1jRhjU:hhhNhNubjd)}(hhh](ji)}(h cfg80211_bssh]jo)}(hstruct cfg80211_bssh](ju)}(hjh]hstruct}(hjOFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjKFhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM ubj)}(h h]h }(hj]FhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKFhhhj\FhM ubj)}(h cfg80211_bssh]j)}(hjIFh]h cfg80211_bss}(hjoFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjkFubah}(h]h ](jjeh"]h$]h&]jjuh1jhjKFhhhj\FhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjGFhhhj\FhM ubah}(h]jBFah ](jjeh"]h$]h&]jj)jhuh1jhhj\FhM hjDFhhubj)}(hhh]h)}(hBSS descriptionh]hBSS description}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjFhhubah}(h]h ]h"]h$]h&]uh1jhjDFhhhj\FhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjFjjFjjjuh1jchhhjU:hNhNubj)}(hX **Definition**:: struct cfg80211_bss { struct ieee80211_channel *channel; const struct cfg80211_bss_ies __rcu *ies; const struct cfg80211_bss_ies __rcu *beacon_ies; const struct cfg80211_bss_ies __rcu *proberesp_ies; struct cfg80211_bss *hidden_beacon_bss; struct cfg80211_bss *transmitted_bss; struct list_head nontrans_list; s32 signal; u64 ts_boottime; u16 beacon_interval; u16 capability; u8 bssid[ETH_ALEN]; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; u8 proberesp_ecsa_stuck:1; u8 bssid_index; u8 max_bssid_indicator; u8 use_for; u8 cannot_use_reasons; u8 priv[] ; }; **Members** ``channel`` channel this BSS is on ``ies`` the information elements (Note that there is no guarantee that these are well-formed!); this is a pointer to either the beacon_ies or proberesp_ies depending on whether Probe Response frame has been received. It is always non-``NULL``. ``beacon_ies`` the information elements from the last Beacon frame (implementation note: if **hidden_beacon_bss** is set this struct doesn't own the beacon_ies, but they're just pointers to the ones from the **hidden_beacon_bss** struct) ``proberesp_ies`` the information elements from the last Probe Response frame ``hidden_beacon_bss`` in case this BSS struct represents a probe response from a BSS that hides the SSID in its beacon, this points to the BSS struct that holds the beacon data. **beacon_ies** is still valid, of course, and points to the same data as hidden_beacon_bss->beacon_ies in that case. ``transmitted_bss`` pointer to the transmitted BSS, if this is a non-transmitted one (multi-BSSID support) ``nontrans_list`` list of non-transmitted BSS, if this is a transmitted one (multi-BSSID support) ``signal`` signal strength value (type depends on the wiphy's signal_type) ``ts_boottime`` timestamp of the last BSS update in nanoseconds since boot ``beacon_interval`` the beacon interval as from the frame ``capability`` the capability field in host byte order ``bssid`` BSSID of the BSS ``chains`` bitmask for filled values in **chain_signal**. ``chain_signal`` per-chain signal strength of last received BSS in dBm. ``proberesp_ecsa_stuck`` ECSA element is stuck in the Probe Response frame, cannot rely on it having valid data ``bssid_index`` index in the multiple BSS set ``max_bssid_indicator`` max number of members in the BSS set ``use_for`` bitmap of possible usage for this BSS, see :c:type:`enum nl80211_bss_use_for ` ``cannot_use_reasons`` the reasons (bitmap) for not being able to connect, if **restrict_use** is set and **use_for** is zero (empty); may be 0 for unspecified reasons; see :c:type:`enum nl80211_bss_cannot_use_reasons ` ``priv`` private area for driver use, has at least wiphy->bss_priv_size bytesh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFubh:}(hjFhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjFubj( )}(hXstruct cfg80211_bss { struct ieee80211_channel *channel; const struct cfg80211_bss_ies __rcu *ies; const struct cfg80211_bss_ies __rcu *beacon_ies; const struct cfg80211_bss_ies __rcu *proberesp_ies; struct cfg80211_bss *hidden_beacon_bss; struct cfg80211_bss *transmitted_bss; struct list_head nontrans_list; s32 signal; u64 ts_boottime; u16 beacon_interval; u16 capability; u8 bssid[ETH_ALEN]; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; u8 proberesp_ecsa_stuck:1; u8 bssid_index; u8 max_bssid_indicator; u8 use_for; u8 cannot_use_reasons; u8 priv[] ; };h]hXstruct cfg80211_bss { struct ieee80211_channel *channel; const struct cfg80211_bss_ies __rcu *ies; const struct cfg80211_bss_ies __rcu *beacon_ies; const struct cfg80211_bss_ies __rcu *proberesp_ies; struct cfg80211_bss *hidden_beacon_bss; struct cfg80211_bss *transmitted_bss; struct list_head nontrans_list; s32 signal; u64 ts_boottime; u16 beacon_interval; u16 capability; u8 bssid[ETH_ALEN]; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; u8 proberesp_ecsa_stuck:1; u8 bssid_index; u8 max_bssid_indicator; u8 use_for; u8 cannot_use_reasons; u8 priv[] ; };}hjFsbah}(h]h ]h"]h$]h&]jjuh1j' ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjFubh)}(h **Members**h]j)}(hjFh]hMembers}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjFubj)}(hhh](j)}(h#``channel`` channel this BSS is on h](j)}(h ``channel``h]j)}(hjFh]hchannel}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjFubj6)}(hhh]h)}(hchannel this BSS is onh]hchannel this BSS is on}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjGhM hjGubah}(h]h ]h"]h$]h&]uh1j5hjFubeh}(h]h ]h"]h$]h&]uh1jhjGhM hjFubj)}(h``ies`` the information elements (Note that there is no guarantee that these are well-formed!); this is a pointer to either the beacon_ies or proberesp_ies depending on whether Probe Response frame has been received. It is always non-``NULL``. h](j)}(h``ies``h]j)}(hj7Gh]hies}(hj9GhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5Gubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj1Gubj6)}(hhh]h)}(hthe information elements (Note that there is no guarantee that these are well-formed!); this is a pointer to either the beacon_ies or proberesp_ies depending on whether Probe Response frame has been received. It is always non-``NULL``.h](hthe information elements (Note that there is no guarantee that these are well-formed!); this is a pointer to either the beacon_ies or proberesp_ies depending on whether Probe Response frame has been received. It is always non-}(hjPGhhhNhNubj)}(h``NULL``h]hNULL}(hjXGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPGubh.}(hjPGhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjMGubah}(h]h ]h"]h$]h&]uh1j5hj1Gubeh}(h]h ]h"]h$]h&]uh1jhjLGhM hjFubj)}(h``beacon_ies`` the information elements from the last Beacon frame (implementation note: if **hidden_beacon_bss** is set this struct doesn't own the beacon_ies, but they're just pointers to the ones from the **hidden_beacon_bss** struct) h](j)}(h``beacon_ies``h]j)}(hjGh]h beacon_ies}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj}Gubj6)}(hhh]h)}(hthe information elements from the last Beacon frame (implementation note: if **hidden_beacon_bss** is set this struct doesn't own the beacon_ies, but they're just pointers to the ones from the **hidden_beacon_bss** struct)h](hMthe information elements from the last Beacon frame (implementation note: if }(hjGhhhNhNubj)}(h**hidden_beacon_bss**h]hhidden_beacon_bss}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjGubhc is set this struct doesn’t own the beacon_ies, but they’re just pointers to the ones from the }(hjGhhhNhNubj)}(h**hidden_beacon_bss**h]hhidden_beacon_bss}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjGubh struct)}(hjGhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjGubah}(h]h ]h"]h$]h&]uh1j5hj}Gubeh}(h]h ]h"]h$]h&]uh1jhjGhM hjFubj)}(hN``proberesp_ies`` the information elements from the last Probe Response frame h](j)}(h``proberesp_ies``h]j)}(hjGh]h proberesp_ies}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjGubj6)}(hhh]h)}(h;the information elements from the last Probe Response frameh]h;the information elements from the last Probe Response frame}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjGhM hjGubah}(h]h ]h"]h$]h&]uh1j5hjGubeh}(h]h ]h"]h$]h&]uh1jhjGhM hjFubj)}(hX'``hidden_beacon_bss`` in case this BSS struct represents a probe response from a BSS that hides the SSID in its beacon, this points to the BSS struct that holds the beacon data. **beacon_ies** is still valid, of course, and points to the same data as hidden_beacon_bss->beacon_ies in that case. h](j)}(h``hidden_beacon_bss``h]j)}(hjHh]hhidden_beacon_bss}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjHubj6)}(hhh]h)}(hXin case this BSS struct represents a probe response from a BSS that hides the SSID in its beacon, this points to the BSS struct that holds the beacon data. **beacon_ies** is still valid, of course, and points to the same data as hidden_beacon_bss->beacon_ies in that case.h](hin case this BSS struct represents a probe response from a BSS that hides the SSID in its beacon, this points to the BSS struct that holds the beacon data. }(hj3HhhhNhNubj)}(h**beacon_ies**h]h beacon_ies}(hj;HhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3Hubhf is still valid, of course, and points to the same data as hidden_beacon_bss->beacon_ies in that case.}(hj3HhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj0Hubah}(h]h ]h"]h$]h&]uh1j5hjHubeh}(h]h ]h"]h$]h&]uh1jhj/HhM hjFubj)}(hk``transmitted_bss`` pointer to the transmitted BSS, if this is a non-transmitted one (multi-BSSID support) h](j)}(h``transmitted_bss``h]j)}(hjfHh]htransmitted_bss}(hjhHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdHubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj`Hubj6)}(hhh]h)}(hVpointer to the transmitted BSS, if this is a non-transmitted one (multi-BSSID support)h]hVpointer to the transmitted BSS, if this is a non-transmitted one (multi-BSSID support)}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj|Hubah}(h]h ]h"]h$]h&]uh1j5hj`Hubeh}(h]h ]h"]h$]h&]uh1jhj{HhM hjFubj)}(hb``nontrans_list`` list of non-transmitted BSS, if this is a transmitted one (multi-BSSID support) h](j)}(h``nontrans_list``h]j)}(hjHh]h nontrans_list}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjHubj6)}(hhh]h)}(hOlist of non-transmitted BSS, if this is a transmitted one (multi-BSSID support)h]hOlist of non-transmitted BSS, if this is a transmitted one (multi-BSSID support)}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjHubah}(h]h ]h"]h$]h&]uh1j5hjHubeh}(h]h ]h"]h$]h&]uh1jhjHhM hjFubj)}(hK``signal`` signal strength value (type depends on the wiphy's signal_type) h](j)}(h ``signal``h]j)}(hjHh]hsignal}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjHubj6)}(hhh]h)}(h?signal strength value (type depends on the wiphy's signal_type)h]hAsignal strength value (type depends on the wiphy’s signal_type)}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHhM hjHubah}(h]h ]h"]h$]h&]uh1j5hjHubeh}(h]h ]h"]h$]h&]uh1jhjHhM hjFubj)}(hK``ts_boottime`` timestamp of the last BSS update in nanoseconds since boot h](j)}(h``ts_boottime``h]j)}(hjIh]h ts_boottime}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj Iubj6)}(hhh]h)}(h:timestamp of the last BSS update in nanoseconds since booth]h:timestamp of the last BSS update in nanoseconds since boot}(hj,IhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj(IhM hj)Iubah}(h]h ]h"]h$]h&]uh1j5hj Iubeh}(h]h ]h"]h$]h&]uh1jhj(IhM hjFubj)}(h:``beacon_interval`` the beacon interval as from the frame h](j)}(h``beacon_interval``h]j)}(hjLIh]hbeacon_interval}(hjNIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJIubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjFIubj6)}(hhh]h)}(h%the beacon interval as from the frameh]h%the beacon interval as from the frame}(hjeIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjaIhM hjbIubah}(h]h ]h"]h$]h&]uh1j5hjFIubeh}(h]h ]h"]h$]h&]uh1jhjaIhM hjFubj)}(h7``capability`` the capability field in host byte order h](j)}(h``capability``h]j)}(hjIh]h capability}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjIubj6)}(hhh]h)}(h'the capability field in host byte orderh]h'the capability field in host byte order}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIhM hjIubah}(h]h ]h"]h$]h&]uh1j5hjIubeh}(h]h ]h"]h$]h&]uh1jhjIhM hjFubj)}(h``bssid`` BSSID of the BSS h](j)}(h ``bssid``h]j)}(hjIh]hbssid}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjIubj6)}(hhh]h)}(hBSSID of the BSSh]hBSSID of the BSS}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIhM hjIubah}(h]h ]h"]h$]h&]uh1j5hjIubeh}(h]h ]h"]h$]h&]uh1jhjIhM hjFubj)}(h:``chains`` bitmask for filled values in **chain_signal**. h](j)}(h ``chains``h]j)}(hjIh]hchains}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjIubj6)}(hhh]h)}(h.bitmask for filled values in **chain_signal**.h](hbitmask for filled values in }(hjJhhhNhNubj)}(h**chain_signal**h]h chain_signal}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJubh.}(hjJhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj JhM hj Jubah}(h]h ]h"]h$]h&]uh1j5hjIubeh}(h]h ]h"]h$]h&]uh1jhj JhM hjFubj)}(hH``chain_signal`` per-chain signal strength of last received BSS in dBm. h](j)}(h``chain_signal``h]j)}(hjBJh]h chain_signal}(hjDJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@Jubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj` h](j)}(h ``use_for``h]j)}(hj'Kh]huse_for}(hj)KhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%Kubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj!Kubj6)}(hhh]h)}(hcbitmap of possible usage for this BSS, see :c:type:`enum nl80211_bss_use_for `h](h+bitmap of possible usage for this BSS, see }(hj@KhhhNhNubh)}(h8:c:type:`enum nl80211_bss_use_for `h]j)}(hjJKh]henum nl80211_bss_use_for}(hjLKhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjHKubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_bss_use_foruh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj@Kubeh}(h]h ]h"]h$]h&]uh1hhjgKhM hj=Kubah}(h]h ]h"]h$]h&]uh1j5hj!Kubeh}(h]h ]h"]h$]h&]uh1jhj` h](j)}(h``cannot_use_reasons``h]j)}(hjKh]hcannot_use_reasons}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~Kubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjzKubj6)}(hhh]h)}(hthe reasons (bitmap) for not being able to connect, if **restrict_use** is set and **use_for** is zero (empty); may be 0 for unspecified reasons; see :c:type:`enum nl80211_bss_cannot_use_reasons `h](h7the reasons (bitmap) for not being able to connect, if }(hjKhhhNhNubj)}(h**restrict_use**h]h restrict_use}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKubh is set and }(hjKhhhNhNubj)}(h **use_for**h]huse_for}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKubh8 is zero (empty); may be 0 for unspecified reasons; see }(hjKhhhNhNubh)}(hN:c:type:`enum nl80211_bss_cannot_use_reasons `h]j)}(hjKh]h#enum nl80211_bss_cannot_use_reasons}(hjKhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_bss_cannot_use_reasonsuh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjKubeh}(h]h ]h"]h$]h&]uh1hhjKhM hjKubah}(h]h ]h"]h$]h&]uh1j5hjzKubeh}(h]h ]h"]h$]h&]uh1jhjKhM hjFubj)}(hM``priv`` private area for driver use, has at least wiphy->bss_priv_size bytesh](j)}(h``priv``h]j)}(hjKh]hpriv}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjKubj6)}(hhh]h)}(hDprivate area for driver use, has at least wiphy->bss_priv_size bytesh]hDprivate area for driver use, has at least wiphy->bss_priv_size bytes}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjLubah}(h]h ]h"]h$]h&]uh1j5hjKubeh}(h]h ]h"]h$]h&]uh1jhjLhM hjFubeh}(h]h ]h"]h$]h&]uh1jhjFubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjU:hhhNhNubh)}(h**Description**h]j)}(hj@Lh]h Description}(hjBLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>Lubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjU:hhubh)}(hfThis structure describes a BSS (which may also be a mesh network) for use in scan results and similar.h]hfThis structure describes a BSS (which may also be a mesh network) for use in scan results and similar.}(hjVLhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjU:hhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_!ieee80211_bss_get_ie (C function)c.ieee80211_bss_get_iehNtauh1jRhjU:hhhNhNubjd)}(hhh](ji)}(hAconst u8 * ieee80211_bss_get_ie (struct cfg80211_bss *bss, u8 id)h]jo)}(h?const u8 *ieee80211_bss_get_ie(struct cfg80211_bss *bss, u8 id)h](ju)}(hjHh]hconst}(hj~LhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjzLhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM. ubj)}(h h]h }(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjzLhhhjLhM. ubh)}(hhh]j)}(hu8h]hu8}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjLmodnameN classnameNj j )}j ]j)}jieee80211_bss_get_iesbc.ieee80211_bss_get_ieasbuh1hhjzLhhhjLhM. ubj)}(h h]h }(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjzLhhhjLhM. ubj.)}(hj1h]h*}(hjLhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjzLhhhjLhM. ubj)}(hieee80211_bss_get_ieh]j)}(hjLh]hieee80211_bss_get_ie}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLubah}(h]h ](jjeh"]h$]h&]jjuh1jhjzLhhhjLhM. ubj)}(h!(struct cfg80211_bss *bss, u8 id)h](j)}(hstruct cfg80211_bss *bssh](ju)}(hjh]hstruct}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjLubj)}(h h]h }(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLubh)}(hhh]j)}(h cfg80211_bssh]h cfg80211_bss}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjMmodnameN classnameNj j )}j ]jLc.ieee80211_bss_get_ieasbuh1hhjLubj)}(h h]h }(hj4MhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLubj.)}(hj1h]h*}(hjBMhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjLubj)}(hbssh]hbss}(hjOMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjLubj)}(hu8 idh](h)}(hhh]j)}(hu8h]hu8}(hjkMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhMubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmMmodnameN classnameNj j )}j ]jLc.ieee80211_bss_get_ieasbuh1hhjdMubj)}(h h]h }(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdMubj)}(hidh]hid}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdMubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjLubeh}(h]h ]h"]h$]h&]jjuh1jhjzLhhhjLhM. ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjvLhhhjLhM. ubah}(h]jqLah ](jjeh"]h$]h&]jj)jhuh1jhhjLhM. hjsLhhubj)}(hhh]h)}(hfind IE with given IDh]hfind IE with given ID}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM. hjMhhubah}(h]h ]h"]h$]h&]uh1jhjsLhhhjLhM. ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjMjjMjjjuh1jchhhjU:hNhNubj)}(hX**Parameters** ``struct cfg80211_bss *bss`` the bss to search ``u8 id`` the element ID **Description** Note that the return value is an RCU-protected pointer, so rcu_read_lock() must be held when calling this function. **Return** ``NULL`` if not found.h](h)}(h**Parameters**h]j)}(hjMh]h Parameters}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjMubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM2 hjMubj)}(hhh](j)}(h/``struct cfg80211_bss *bss`` the bss to search h](j)}(h``struct cfg80211_bss *bss``h]j)}(hjNh]hstruct cfg80211_bss *bss}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM/ hjMubj6)}(hhh]h)}(hthe bss to searchh]hthe bss to search}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjNhM/ hjNubah}(h]h ]h"]h$]h&]uh1j5hjMubeh}(h]h ]h"]h$]h&]uh1jhjNhM/ hjMubj)}(h``u8 id`` the element ID h](j)}(h ``u8 id``h]j)}(hj;Nh]hu8 id}(hj=NhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9Nubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM0 hj5Nubj6)}(hhh]h)}(hthe element IDh]hthe element ID}(hjTNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPNhM0 hjQNubah}(h]h ]h"]h$]h&]uh1j5hj5Nubeh}(h]h ]h"]h$]h&]uh1jhjPNhM0 hjMubeh}(h]h ]h"]h$]h&]uh1jhjMubh)}(h**Description**h]j)}(hjvNh]h Description}(hjxNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjtNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM2 hjMubh)}(hsNote that the return value is an RCU-protected pointer, so rcu_read_lock() must be held when calling this function.h]hsNote that the return value is an RCU-protected pointer, so rcu_read_lock() must be held when calling this function.}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM1 hjMubh)}(h **Return**h]j)}(hjNh]hReturn}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM4 hjMubh)}(h``NULL`` if not found.h](j)}(h``NULL``h]hNULL}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubh if not found.}(hjNhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM4 hjMubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjU:hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_find_ie (C function)c.cfg80211_find_iehNtauh1jRhjU:hhhNhNubjd)}(hhh](ji)}(hOhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjNhhhjNhMubj)}(hcfg80211_find_ieh]j)}(hj-Oh]hcfg80211_find_ie}(hjOOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKOubah}(h]h ](jjeh"]h$]h&]jjuh1jhjNhhhjNhMubj)}(h (u8 eid, const u8 *ies, int len)h](j)}(hu8 eidh](h)}(hhh]j)}(hu8h]hu8}(hjmOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjOubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjoOmodnameN classnameNj j )}j ]j+Oc.cfg80211_find_ieasbuh1hhjfOubj)}(h h]h }(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfOubj)}(heidh]heid}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfOubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjbOubj)}(h const u8 *iesh](ju)}(hjHh]hconst}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjOubj)}(h h]h }(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubh)}(hhh]j)}(hu8h]hu8}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjOmodnameN classnameNj j )}j ]j+Oc.cfg80211_find_ieasbuh1hhjOubj)}(h h]h }(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubj.)}(hj1h]h*}(hjOhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjOubj)}(hiesh]hies}(hj PhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjbOubj)}(hint lenh](j)}(hinth]hint}(hj"PhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjPubj)}(h h]h }(hj0PhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjPubj)}(hlenh]hlen}(hj>PhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjPubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjbOubeh}(h]h ]h"]h$]h&]jjuh1jhjNhhhjNhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjNhhhjNhMubah}(h]jNah ](jjeh"]h$]h&]jj)jhuh1jhhjNhMhjNhhubj)}(hhh]h)}(h find information element in datah]h find information element in data}(hjhPhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjePhhubah}(h]h ]h"]h$]h&]uh1jhjNhhhjNhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjPjjPjjjuh1jchhhjU:hNhNubj)}(hX**Parameters** ``u8 eid`` element ID ``const u8 *ies`` data consisting of IEs ``int len`` length of data **Return** ``NULL`` if the element ID could not be found or if the element is invalid (claims to be longer than the given data), or a pointer to the first byte of the requested element, that is the byte containing the element ID. **Note** There are no checks on the element length other than having to fit into the given data.h](h)}(h**Parameters**h]j)}(hjPh]h Parameters}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjPubj)}(hhh](j)}(h``u8 eid`` element ID h](j)}(h ``u8 eid``h]j)}(hjPh]hu8 eid}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjPubj6)}(hhh]h)}(h element IDh]h element ID}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPhMhjPubah}(h]h ]h"]h$]h&]uh1j5hjPubeh}(h]h ]h"]h$]h&]uh1jhjPhMhjPubj)}(h)``const u8 *ies`` data consisting of IEs h](j)}(h``const u8 *ies``h]j)}(hjPh]h const u8 *ies}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjPubj6)}(hhh]h)}(hdata consisting of IEsh]hdata consisting of IEs}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPhMhjPubah}(h]h ]h"]h$]h&]uh1j5hjPubeh}(h]h ]h"]h$]h&]uh1jhjPhMhjPubj)}(h``int len`` length of data h](j)}(h ``int len``h]j)}(hjQh]hint len}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjQubj6)}(hhh]h)}(hlength of datah]hlength of data}(hj4QhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0QhMhj1Qubah}(h]h ]h"]h$]h&]uh1j5hjQubeh}(h]h ]h"]h$]h&]uh1jhj0QhMhjPubeh}(h]h ]h"]h$]h&]uh1jhjPubh)}(h **Return**h]j)}(hjVQh]hReturn}(hjXQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjTQubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjPubh)}(h``NULL`` if the element ID could not be found or if the element is invalid (claims to be longer than the given data), or a pointer to the first byte of the requested element, that is the byte containing the element ID.h](j)}(h``NULL``h]hNULL}(hjpQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlQubh if the element ID could not be found or if the element is invalid (claims to be longer than the given data), or a pointer to the first byte of the requested element, that is the byte containing the element ID.}(hjlQhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjPubh)}(h**Note**h]j)}(hjQh]hNote}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjPubh)}(hWThere are no checks on the element length other than having to fit into the given data.h]hWThere are no checks on the element length other than having to fit into the given data.}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjPubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjU:hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_scan_done (C function)c.cfg80211_scan_donehNtauh1jRhjU:hhhNhNubjd)}(hhh](ji)}(h`void cfg80211_scan_done (struct cfg80211_scan_request *request, struct cfg80211_scan_info *info)h]jo)}(h_void cfg80211_scan_done(struct cfg80211_scan_request *request, struct cfg80211_scan_info *info)h](j)}(hvoidh]hvoid}(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMubj)}(h h]h }(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQhhhjQhMubj)}(hcfg80211_scan_doneh]j)}(hcfg80211_scan_doneh]hcfg80211_scan_done}(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQubah}(h]h ](jjeh"]h$]h&]jjuh1jhjQhhhjQhMubj)}(hH(struct cfg80211_scan_request *request, struct cfg80211_scan_info *info)h](j)}(h%struct cfg80211_scan_request *requesth](ju)}(hjh]hstruct}(hj RhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj Rubj)}(h h]h }(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj Rubh)}(hhh]j)}(hcfg80211_scan_requesth]hcfg80211_scan_request}(hj+RhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(Rubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj-RmodnameN classnameNj j )}j ]j)}jjQsbc.cfg80211_scan_doneasbuh1hhj Rubj)}(h h]h }(hjKRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj Rubj.)}(hj1h]h*}(hjYRhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj Rubj)}(hrequesth]hrequest}(hjfRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj Rubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjRubj)}(hstruct cfg80211_scan_info *infoh](ju)}(hjh]hstruct}(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj{Rubj)}(h h]h }(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{Rubh)}(hhh]j)}(hcfg80211_scan_infoh]hcfg80211_scan_info}(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjRmodnameN classnameNj j )}j ]jGRc.cfg80211_scan_doneasbuh1hhj{Rubj)}(h h]h }(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{Rubj.)}(hj1h]h*}(hjRhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj{Rubj)}(hinfoh]hinfo}(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{Rubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjRubeh}(h]h ]h"]h$]h&]jjuh1jhjQhhhjQhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjQhhhjQhMubah}(h]jQah ](jjeh"]h$]h&]jj)jhuh1jhhjQhMhjQhhubj)}(hhh]h)}(hnotify that scan finishedh]hnotify that scan finished}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjRhhubah}(h]h ]h"]h$]h&]uh1jhjQhhhjQhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjSjjSjjjuh1jchhhjU:hNhNubj)}(h**Parameters** ``struct cfg80211_scan_request *request`` the corresponding scan request ``struct cfg80211_scan_info *info`` information about the completed scanh](h)}(h**Parameters**h]j)}(hj"Sh]h Parameters}(hj$ShhhNhNubah}(h]h ]h"]h$]h&]uh1hhj Subah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjSubj)}(hhh](j)}(hI``struct cfg80211_scan_request *request`` the corresponding scan request h](j)}(h)``struct cfg80211_scan_request *request``h]j)}(hjASh]h%struct cfg80211_scan_request *request}(hjCShhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?Subah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhj;Subj6)}(hhh]h)}(hthe corresponding scan requesth]hthe corresponding scan request}(hjZShhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVShMhjWSubah}(h]h ]h"]h$]h&]uh1j5hj;Subeh}(h]h ]h"]h$]h&]uh1jhjVShMhj8Subj)}(hH``struct cfg80211_scan_info *info`` information about the completed scanh](j)}(h#``struct cfg80211_scan_info *info``h]j)}(hjzSh]hstruct cfg80211_scan_info *info}(hj|ShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxSubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjtSubj6)}(hhh]h)}(h$information about the completed scanh]h$information about the completed scan}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjSubah}(h]h ]h"]h$]h&]uh1j5hjtSubeh}(h]h ]h"]h$]h&]uh1jhjShM hj8Subeh}(h]h ]h"]h$]h&]uh1jhjSubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjU:hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_+cfg80211_inform_bss_frame_data (C function) c.cfg80211_inform_bss_frame_datahNtauh1jRhjU:hhhNhNubjd)}(hhh](ji)}(hstruct cfg80211_bss * cfg80211_inform_bss_frame_data (struct wiphy *wiphy, struct cfg80211_inform_bss *data, struct ieee80211_mgmt *mgmt, size_t len, gfp_t gfp)h]jo)}(hstruct cfg80211_bss *cfg80211_inform_bss_frame_data(struct wiphy *wiphy, struct cfg80211_inform_bss *data, struct ieee80211_mgmt *mgmt, size_t len, gfp_t gfp)h](ju)}(hjh]hstruct}(hjShhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjShhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM/ubj)}(h h]h }(hjShhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjShhhjShM/ubh)}(hhh]j)}(h cfg80211_bssh]h cfg80211_bss}(hjShhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjSmodnameN classnameNj j )}j ]j)}jcfg80211_inform_bss_frame_datasb c.cfg80211_inform_bss_frame_dataasbuh1hhjShhhjShM/ubj)}(h h]h }(hjThhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjShhhjShM/ubj.)}(hj1h]h*}(hj"ThhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjShhhjShM/ubj)}(hcfg80211_inform_bss_frame_datah]j)}(hjTh]hcfg80211_inform_bss_frame_data}(hj3ThhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/Tubah}(h]h ](jjeh"]h$]h&]jjuh1jhjShhhjShM/ubj)}(hk(struct wiphy *wiphy, struct cfg80211_inform_bss *data, struct ieee80211_mgmt *mgmt, size_t len, gfp_t gfp)h](j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjNThhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjJTubj)}(h h]h }(hj[ThhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJTubh)}(hhh]j)}(hwiphyh]hwiphy}(hjlThhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjiTubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjnTmodnameN classnameNj j )}j ]jT c.cfg80211_inform_bss_frame_dataasbuh1hhjJTubj)}(h h]h }(hjThhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJTubj.)}(hj1h]h*}(hjThhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjJTubj)}(hwiphyh]hwiphy}(hjThhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJTubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjFTubj)}(h struct cfg80211_inform_bss *datah](ju)}(hjh]hstruct}(hjThhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjTubj)}(h h]h }(hjThhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjTubh)}(hhh]j)}(hcfg80211_inform_bssh]hcfg80211_inform_bss}(hjThhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjTmodnameN classnameNj j )}j ]jT c.cfg80211_inform_bss_frame_dataasbuh1hhjTubj)}(h h]h }(hjThhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjTubj.)}(hj1h]h*}(hjUhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjTubj)}(hdatah]hdata}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjTubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjFTubj)}(hstruct ieee80211_mgmt *mgmth](ju)}(hjh]hstruct}(hj.UhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj*Uubj)}(h h]h }(hj;UhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj*Uubh)}(hhh]j)}(hieee80211_mgmth]hieee80211_mgmt}(hjLUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIUubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjNUmodnameN classnameNj j )}j ]jT c.cfg80211_inform_bss_frame_dataasbuh1hhj*Uubj)}(h h]h }(hjjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj*Uubj.)}(hj1h]h*}(hjxUhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj*Uubj)}(hmgmth]hmgmt}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj*Uubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjFTubj)}(h size_t lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjUmodnameN classnameNj j )}j ]jT c.cfg80211_inform_bss_frame_dataasbuh1hhjUubj)}(h h]h }(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUubj)}(hlenh]hlen}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjFTubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjUmodnameN classnameNj j )}j ]jT c.cfg80211_inform_bss_frame_dataasbuh1hhjUubj)}(h h]h }(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUubj)}(hgfph]hgfp}(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjFTubeh}(h]h ]h"]h$]h&]jjuh1jhjShhhjShM/ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjShhhjShM/ubah}(h]jSah ](jjeh"]h$]h&]jj)jhuh1jhhjShM/hjShhubj)}(hhh]h)}(h'inform cfg80211 of a received BSS frameh]h'inform cfg80211 of a received BSS frame}(hj?VhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM/hjXmodnameN classnameNj j )}j ]j)}jcfg80211_inform_bss_datasbc.cfg80211_inform_bss_dataasbuh1hhjXhhhj*XhMubj)}(h h]h }(hj]XhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXhhhj*XhMubj.)}(hj1h]h*}(hjkXhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjXhhhj*XhMubj)}(hcfg80211_inform_bss_datah]j)}(hjZXh]hcfg80211_inform_bss_data}(hj|XhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxXubah}(h]h ](jjeh"]h$]h&]jjuh1jhjXhhhj*XhMubj)}(h(struct wiphy *wiphy, struct cfg80211_inform_bss *data, enum cfg80211_bss_frame_type ftype, const u8 *bssid, u64 tsf, u16 capability, u16 beacon_interval, const u8 *ie, size_t ielen, gfp_t gfp)h](j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjXhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjXubj)}(h h]h }(hjXhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubh)}(hhh]j)}(hwiphyh]hwiphy}(hjXhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjXmodnameN classnameNj j )}j ]jXXc.cfg80211_inform_bss_dataasbuh1hhjXubj)}(h h]h }(hjXhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubj.)}(hj1h]h*}(hjXhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjXubj)}(hwiphyh]hwiphy}(hjXhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubj)}(h struct cfg80211_inform_bss *datah](ju)}(hjh]hstruct}(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjYubj)}(h h]h }(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjYubh)}(hhh]j)}(hcfg80211_inform_bssh]hcfg80211_inform_bss}(hj%YhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"Yubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj'YmodnameN classnameNj j )}j ]jXXc.cfg80211_inform_bss_dataasbuh1hhjYubj)}(h h]h }(hjCYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjYubj.)}(hj1h]h*}(hjQYhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjYubj)}(hdatah]hdata}(hj^YhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjYubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubj)}(h"enum cfg80211_bss_frame_type ftypeh](ju)}(hjxh]henum}(hjwYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjsYubj)}(h h]h }(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjsYubh)}(hhh]j)}(hcfg80211_bss_frame_typeh]hcfg80211_bss_frame_type}(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjYmodnameN classnameNj j )}j ]jXXc.cfg80211_inform_bss_dataasbuh1hhjsYubj)}(h h]h }(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjsYubj)}(hftypeh]hftype}(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjsYubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubj)}(hconst u8 *bssidh](ju)}(hjHh]hconst}(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjYubj)}(h h]h }(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjYubh)}(hhh]j)}(hu8h]hu8}(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjYmodnameN classnameNj j )}j ]jXXc.cfg80211_inform_bss_dataasbuh1hhjYubj)}(h h]h }(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjYubj.)}(hj1h]h*}(hj$ZhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjYubj)}(hbssidh]hbssid}(hj1ZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjYubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubj)}(hu64 tsfh](h)}(hhh]j)}(hu64h]hu64}(hjMZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJZubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjOZmodnameN classnameNj j )}j ]jXXc.cfg80211_inform_bss_dataasbuh1hhjFZubj)}(h h]h }(hjkZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjFZubj)}(htsfh]htsf}(hjyZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjFZubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubj)}(hu16 capabilityh](h)}(hhh]j)}(hu16h]hu16}(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjZmodnameN classnameNj j )}j ]jXXc.cfg80211_inform_bss_dataasbuh1hhjZubj)}(h h]h }(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZubj)}(h capabilityh]h capability}(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubj)}(hu16 beacon_intervalh](h)}(hhh]j)}(hu16h]hu16}(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjZmodnameN classnameNj j )}j ]jXXc.cfg80211_inform_bss_dataasbuh1hhjZubj)}(h h]h }(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZubj)}(hbeacon_intervalh]hbeacon_interval}(hj [hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubj)}(h const u8 *ieh](ju)}(hjHh]hconst}(hj"[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj[ubj)}(h h]h }(hj/[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ubh)}(hhh]j)}(hu8h]hu8}(hj@[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=[ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjB[modnameN classnameNj j )}j ]jXXc.cfg80211_inform_bss_dataasbuh1hhj[ubj)}(h h]h }(hj^[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ubj.)}(hj1h]h*}(hjl[hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj[ubj)}(hieh]hie}(hjy[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubj)}(h size_t ielenh](h)}(hhh]j)}(hsize_th]hsize_t}(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj[modnameN classnameNj j )}j ]jXXc.cfg80211_inform_bss_dataasbuh1hhj[ubj)}(h h]h }(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ubj)}(hielenh]hielen}(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj[modnameN classnameNj j )}j ]jXXc.cfg80211_inform_bss_dataasbuh1hhj[ubj)}(h h]h }(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ubj)}(hgfph]hgfp}(hj \hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubeh}(h]h ]h"]h$]h&]jjuh1jhjXhhhj*XhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjXhhhj*XhMubah}(h]jXah ](jjeh"]h$]h&]jj)jhuh1jhhj*XhMhjXhhubj)}(hhh]h)}(hinform cfg80211 of a new BSSh]hinform cfg80211 of a new BSS}(hj3\hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhj0\hhubah}(h]h ]h"]h$]h&]uh1jhjXhhhj*XhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjK\jjK\jjjuh1jchhhjU:hNhNubj)}(hX **Parameters** ``struct wiphy *wiphy`` the wiphy reporting the BSS ``struct cfg80211_inform_bss *data`` the BSS metadata ``enum cfg80211_bss_frame_type ftype`` frame type (if known) ``const u8 *bssid`` the BSSID of the BSS ``u64 tsf`` the TSF sent by the peer in the beacon/probe response (or 0) ``u16 capability`` the capability field sent by the peer ``u16 beacon_interval`` the beacon interval announced by the peer ``const u8 *ie`` additional IEs sent by the peer ``size_t ielen`` length of the additional IEs ``gfp_t gfp`` context flags **Description** This informs cfg80211 that BSS information was found and the BSS should be updated/added. **Return** A referenced struct, must be released with cfg80211_put_bss()! Or ``NULL`` on error.h](h)}(h**Parameters**h]j)}(hjU\h]h Parameters}(hjW\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjS\ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjO\ubj)}(hhh](j)}(h4``struct wiphy *wiphy`` the wiphy reporting the BSS h](j)}(h``struct wiphy *wiphy``h]j)}(hjt\h]hstruct wiphy *wiphy}(hjv\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjr\ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjn\ubj6)}(hhh]h)}(hthe wiphy reporting the BSSh]hthe wiphy reporting the BSS}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\hMhj\ubah}(h]h ]h"]h$]h&]uh1j5hjn\ubeh}(h]h ]h"]h$]h&]uh1jhj\hMhjk\ubj)}(h6``struct cfg80211_inform_bss *data`` the BSS metadata h](j)}(h$``struct cfg80211_inform_bss *data``h]j)}(hj\h]h struct cfg80211_inform_bss *data}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhj\ubj6)}(hhh]h)}(hthe BSS metadatah]hthe BSS metadata}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\hMhj\ubah}(h]h ]h"]h$]h&]uh1j5hj\ubeh}(h]h ]h"]h$]h&]uh1jhj\hMhjk\ubj)}(h=``enum cfg80211_bss_frame_type ftype`` frame type (if known) h](j)}(h&``enum cfg80211_bss_frame_type ftype``h]j)}(hj\h]h"enum cfg80211_bss_frame_type ftype}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhj\ubj6)}(hhh]h)}(hframe type (if known)h]hframe type (if known)}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\hMhj\ubah}(h]h ]h"]h$]h&]uh1j5hj\ubeh}(h]h ]h"]h$]h&]uh1jhj\hMhjk\ubj)}(h)``const u8 *bssid`` the BSSID of the BSS h](j)}(h``const u8 *bssid``h]j)}(hj]h]hconst u8 *bssid}(hj!]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhj]ubj6)}(hhh]h)}(hthe BSSID of the BSSh]hthe BSSID of the BSS}(hj8]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4]hMhj5]ubah}(h]h ]h"]h$]h&]uh1j5hj]ubeh}(h]h ]h"]h$]h&]uh1jhj4]hMhjk\ubj)}(hI``u64 tsf`` the TSF sent by the peer in the beacon/probe response (or 0) h](j)}(h ``u64 tsf``h]j)}(hjX]h]hu64 tsf}(hjZ]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjV]ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjR]ubj6)}(hhh]h)}(h^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:^ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhj6^ubj6)}(hhh]h)}(hlength of the additional IEsh]hlength of the additional IEs}(hjU^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQ^hMhjR^ubah}(h]h ]h"]h$]h&]uh1j5hj6^ubeh}(h]h ]h"]h$]h&]uh1jhjQ^hMhjk\ubj)}(h``gfp_t gfp`` context flags h](j)}(h ``gfp_t gfp``h]j)}(hju^h]h gfp_t gfp}(hjw^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjs^ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjo^ubj6)}(hhh]h)}(h context flagsh]h context flags}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hMhj^ubah}(h]h ]h"]h$]h&]uh1j5hjo^ubeh}(h]h ]h"]h$]h&]uh1jhj^hMhjk\ubeh}(h]h ]h"]h$]h&]uh1jhjO\ubh)}(h**Description**h]j)}(hj^h]h Description}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjO\ubh)}(hYThis informs cfg80211 that BSS information was found and the BSS should be updated/added.h]hYThis informs cfg80211 that BSS information was found and the BSS should be updated/added.}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjO\ubh)}(h **Return**h]j)}(hj^h]hReturn}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjO\ubh)}(hTA referenced struct, must be released with cfg80211_put_bss()! Or ``NULL`` on error.h](hBA referenced struct, must be released with cfg80211_put_bss()! Or }(hj^hhhNhNubj)}(h``NULL``h]hNULL}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubh on error.}(hj^hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjO\ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjU:hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ cfg80211_unlink_bss (C function)c.cfg80211_unlink_bsshNtauh1jRhjU:hhhNhNubjd)}(hhh](ji)}(hHvoid cfg80211_unlink_bss (struct wiphy *wiphy, struct cfg80211_bss *bss)h]jo)}(hGvoid cfg80211_unlink_bss(struct wiphy *wiphy, struct cfg80211_bss *bss)h](j)}(hvoidh]hvoid}(hj._hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj*_hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM#ubj)}(h h]h }(hj=_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj*_hhhj<_hM#ubj)}(hcfg80211_unlink_bssh]j)}(hcfg80211_unlink_bssh]hcfg80211_unlink_bss}(hjO_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjK_ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj*_hhhj<_hM#ubj)}(h/(struct wiphy *wiphy, struct cfg80211_bss *bss)h](j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjk_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjg_ubj)}(h h]h }(hjx_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjg_ubh)}(hhh]j)}(hwiphyh]hwiphy}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj_modnameN classnameNj j )}j ]j)}jjQ_sbc.cfg80211_unlink_bssasbuh1hhjg_ubj)}(h h]h }(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjg_ubj.)}(hj1h]h*}(hj_hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjg_ubj)}(hwiphyh]hwiphy}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjg_ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjc_ubj)}(hstruct cfg80211_bss *bssh](ju)}(hjh]hstruct}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj_ubj)}(h h]h }(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_ubh)}(hhh]j)}(h cfg80211_bssh]h cfg80211_bss}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj_modnameN classnameNj j )}j ]j_c.cfg80211_unlink_bssasbuh1hhj_ubj)}(h h]h }(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_ubj.)}(hj1h]h*}(hj'`hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj_ubj)}(hbssh]hbss}(hj4`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjc_ubeh}(h]h ]h"]h$]h&]jjuh1jhj*_hhhj<_hM#ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj&_hhhj<_hM#ubah}(h]j!_ah ](jjeh"]h$]h&]jj)jhuh1jhhj<_hM#hj#_hhubj)}(hhh]h)}(h(unlink BSS from internal data structuresh]h(unlink BSS from internal data structures}(hj^`hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM#hj[`hhubah}(h]h ]h"]h$]h&]uh1jhj#_hhhj<_hM#ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjv`jjv`jjjuh1jchhhjU:hNhNubj)}(hX~**Parameters** ``struct wiphy *wiphy`` the wiphy ``struct cfg80211_bss *bss`` the bss to remove **Description** This function removes the given BSS from the internal data structures thereby making it no longer show up in scan results etc. Use this function when you detect a BSS is gone. Normally BSSes will also time out, so it is not necessary to use this function at all.h](h)}(h**Parameters**h]j)}(hj`h]h Parameters}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~`ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM'hjz`ubj)}(hhh](j)}(h"``struct wiphy *wiphy`` the wiphy h](j)}(h``struct wiphy *wiphy``h]j)}(hj`h]hstruct wiphy *wiphy}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM$hj`ubj6)}(hhh]h)}(h the wiphyh]h the wiphy}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`hM$hj`ubah}(h]h ]h"]h$]h&]uh1j5hj`ubeh}(h]h ]h"]h$]h&]uh1jhj`hM$hj`ubj)}(h/``struct cfg80211_bss *bss`` the bss to remove h](j)}(h``struct cfg80211_bss *bss``h]j)}(hj`h]hstruct cfg80211_bss *bss}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM%hj`ubj6)}(hhh]h)}(hthe bss to removeh]hthe bss to remove}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`hM%hj`ubah}(h]h ]h"]h$]h&]uh1j5hj`ubeh}(h]h ]h"]h$]h&]uh1jhj`hM%hj`ubeh}(h]h ]h"]h$]h&]uh1jhjz`ubh)}(h**Description**h]j)}(hjah]h Description}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhjaubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM'hjz`ubh)}(hXThis function removes the given BSS from the internal data structures thereby making it no longer show up in scan results etc. Use this function when you detect a BSS is gone. Normally BSSes will also time out, so it is not necessary to use this function at all.h]hXThis function removes the given BSS from the internal data structures thereby making it no longer show up in scan results etc. Use this function when you detect a BSS is gone. Normally BSSes will also time out, so it is not necessary to use this function at all.}(hj)ahhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM&hjz`ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjU:hhhNhNubeh}(h]scanning-and-bss-list-handlingah ]h"]scanning and bss list handlingah$]h&]uh1hhhhhhhhKaubh)}(hhh](h)}(hUtility functionsh]hUtility functions}(hjJahhhNhNubah}(h]h ]h"]h$]h&]uh1hhjGahhhhhKtubh)}(hAcfg80211 offers a number of utility functions that can be useful.h]hAcfg80211 offers a number of utility functions that can be useful.}(hjXahhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:118: ./include/net/cfg80211.hhMhjGahhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_+ieee80211_channel_to_frequency (C function) c.ieee80211_channel_to_frequencyhNtauh1jRhjGahhhNhNubjd)}(hhh](ji)}(hEint ieee80211_channel_to_frequency (int chan, enum nl80211_band band)h]jo)}(hDint ieee80211_channel_to_frequency(int chan, enum nl80211_band band)h](j)}(hinth]hint}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj|ahhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMubj)}(h h]h }(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj|ahhhjahMubj)}(hieee80211_channel_to_frequencyh]j)}(hieee80211_channel_to_frequencyh]hieee80211_channel_to_frequency}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubah}(h]h ](jjeh"]h$]h&]jjuh1jhj|ahhhjahMubj)}(h"(int chan, enum nl80211_band band)h](j)}(hint chanh](j)}(hinth]hint}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubj)}(h h]h }(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubj)}(hchanh]hchan}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjaubj)}(henum nl80211_band bandh](ju)}(hjxh]henum}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjaubj)}(h h]h }(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubh)}(hhh]j)}(h nl80211_bandh]h nl80211_band}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj bubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjbmodnameN classnameNj j )}j ]j)}jjasb c.ieee80211_channel_to_frequencyasbuh1hhjaubj)}(h h]h }(hj0bhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubj)}(hbandh]hband}(hj>bhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjaubeh}(h]h ]h"]h$]h&]jjuh1jhj|ahhhjahMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjxahhhjahMubah}(h]jsaah ](jjeh"]h$]h&]jj)jhuh1jhhjahMhjuahhubj)}(hhh]h)}(h#convert channel number to frequencyh]h#convert channel number to frequency}(hjhbhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjebhhubah}(h]h ]h"]h$]h&]uh1jhjuahhhjahMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjbjjbjjjuh1jchhhjGahNhNubj)}(h**Parameters** ``int chan`` channel number ``enum nl80211_band band`` band, necessary due to channel number overlap **Return** The corresponding frequency (in MHz), or 0 if the conversion failed.h](h)}(h**Parameters**h]j)}(hjbh]h Parameters}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjbubj)}(hhh](j)}(h``int chan`` channel number h](j)}(h ``int chan``h]j)}(hjbh]hint chan}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjbubj6)}(hhh]h)}(hchannel numberh]hchannel number}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbhMhjbubah}(h]h ]h"]h$]h&]uh1j5hjbubeh}(h]h ]h"]h$]h&]uh1jhjbhMhjbubj)}(hI``enum nl80211_band band`` band, necessary due to channel number overlap h](j)}(h``enum nl80211_band band``h]j)}(hjbh]henum nl80211_band band}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjbubj6)}(hhh]h)}(h-band, necessary due to channel number overlaph]h-band, necessary due to channel number overlap}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbhMhjbubah}(h]h ]h"]h$]h&]uh1j5hjbubeh}(h]h ]h"]h$]h&]uh1jhjbhMhjbubeh}(h]h ]h"]h$]h&]uh1jhjbubh)}(h **Return**h]j)}(hjch]hReturn}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhjcubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjbubh)}(hDThe corresponding frequency (in MHz), or 0 if the conversion failed.h]hDThe corresponding frequency (in MHz), or 0 if the conversion failed.}(hj3chhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjbubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjGahhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_+ieee80211_frequency_to_channel (C function) c.ieee80211_frequency_to_channelhNtauh1jRhjGahhhNhNubjd)}(hhh](ji)}(h-int ieee80211_frequency_to_channel (int freq)h]jo)}(h,int ieee80211_frequency_to_channel(int freq)h](j)}(hinth]hint}(hjbchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^chhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM(ubj)}(h h]h }(hjqchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^chhhjpchM(ubj)}(hieee80211_frequency_to_channelh]j)}(hieee80211_frequency_to_channelh]hieee80211_frequency_to_channel}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjcubah}(h]h ](jjeh"]h$]h&]jjuh1jhj^chhhjpchM(ubj)}(h (int freq)h]j)}(hint freqh](j)}(hinth]hint}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjcubj)}(h h]h }(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjcubj)}(hfreqh]hfreq}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjcubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjcubah}(h]h ]h"]h$]h&]jjuh1jhj^chhhjpchM(ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjZchhhjpchM(ubah}(h]jUcah ](jjeh"]h$]h&]jj)jhuh1jhhjpchM(hjWchhubj)}(hhh]h)}(h#convert frequency to channel numberh]h#convert frequency to channel number}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM(hjchhubah}(h]h ]h"]h$]h&]uh1jhjWchhhjpchM(ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjcjjcjjjuh1jchhhjGahNhNubj)}(h}**Parameters** ``int freq`` center frequency in MHz **Return** The corresponding channel, or 0 if the conversion failed.h](h)}(h**Parameters**h]j)}(hjdh]h Parameters}(hj dhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM,hjdubj)}(hhh]j)}(h%``int freq`` center frequency in MHz h](j)}(h ``int freq``h]j)}(hj&dh]hint freq}(hj(dhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$dubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM)hj dubj6)}(hhh]h)}(hcenter frequency in MHzh]hcenter frequency in MHz}(hj?dhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj;dhM)hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj;eubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj@emodnameN classnameNj j )}j ]jdc.ieee80211_get_channelasbuh1hhjeubj)}(h h]h }(hj\ehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubj.)}(hj1h]h*}(hjjehhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjeubj)}(hwiphyh]hwiphy}(hjwehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjeubj)}(hint freqh](j)}(hinth]hint}(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubj)}(h h]h }(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubj)}(hfreqh]hfreq}(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjeubeh}(h]h ]h"]h$]h&]jjuh1jhjdhhhjdhM=ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjdhhhjdhM=ubah}(h]jdah ](jjeh"]h$]h&]jj)jhuh1jhhjdhM=hjdhhubj)}(hhh]h)}(h5get channel struct from wiphy for specified frequencyh]h5get channel struct from wiphy for specified frequency}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM=hjehhubah}(h]h ]h"]h$]h&]uh1jhjdhhhjdhM=ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjejjejjjuh1jchhhjGahNhNubj)}(h**Parameters** ``struct wiphy *wiphy`` the struct wiphy to get the channel for ``int freq`` the center frequency (in MHz) of the channel **Return** The channel struct from **wiphy** at **freq**.h](h)}(h**Parameters**h]j)}(hjeh]h Parameters}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjeubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMAhjeubj)}(hhh](j)}(h@``struct wiphy *wiphy`` the struct wiphy to get the channel for h](j)}(h``struct wiphy *wiphy``h]j)}(hjfh]hstruct wiphy *wiphy}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM?hjfubj6)}(hhh]h)}(h'the struct wiphy to get the channel forh]h'the struct wiphy to get the channel for}(hj0fhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,fhM?hj-fubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhj,fhM?hjfubj)}(h:``int freq`` the center frequency (in MHz) of the channel h](j)}(h ``int freq``h]j)}(hjPfh]hint freq}(hjRfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNfubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM@hjJfubj6)}(hhh]h)}(h,the center frequency (in MHz) of the channelh]h,the center frequency (in MHz) of the channel}(hjifhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjefhM@hjffubah}(h]h ]h"]h$]h&]uh1j5hjJfubeh}(h]h ]h"]h$]h&]uh1jhjefhM@hjfubeh}(h]h ]h"]h$]h&]uh1jhjeubh)}(h **Return**h]j)}(hjfh]hReturn}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMBhjeubh)}(h.The channel struct from **wiphy** at **freq**.h](hThe channel struct from }(hjfhhhNhNubj)}(h **wiphy**h]hwiphy}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfubh at }(hjfhhhNhNubj)}(h**freq**h]hfreq}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfubh.}(hjfhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMAhjeubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjGahhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_(ieee80211_get_response_rate (C function)c.ieee80211_get_response_ratehNtauh1jRhjGahhhNhNubjd)}(hhh](ji)}(hconst struct ieee80211_rate * ieee80211_get_response_rate (struct ieee80211_supported_band *sband, u32 basic_rates, int bitrate)h]jo)}(h~const struct ieee80211_rate *ieee80211_get_response_rate(struct ieee80211_supported_band *sband, u32 basic_rates, int bitrate)h](ju)}(hjHh]hconst}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjfhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMqubj)}(h h]h }(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfhhhjghMqubju)}(hjh]hstruct}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjfhhhjghMqubj)}(h h]h }(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfhhhjghMqubh)}(hhh]j)}(hieee80211_rateh]hieee80211_rate}(hj.ghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+gubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj0gmodnameN classnameNj j )}j ]j)}jieee80211_get_response_ratesbc.ieee80211_get_response_rateasbuh1hhjfhhhjghMqubj)}(h h]h }(hjOghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfhhhjghMqubj.)}(hj1h]h*}(hj]ghhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjfhhhjghMqubj)}(hieee80211_get_response_rateh]j)}(hjLgh]hieee80211_get_response_rate}(hjnghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjgubah}(h]h ](jjeh"]h$]h&]jjuh1jhjfhhhjghMqubj)}(hF(struct ieee80211_supported_band *sband, u32 basic_rates, int bitrate)h](j)}(h&struct ieee80211_supported_band *sbandh](ju)}(hjh]hstruct}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjgubj)}(h h]h }(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjgubh)}(hhh]j)}(hieee80211_supported_bandh]hieee80211_supported_band}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjgmodnameN classnameNj j )}j ]jJgc.ieee80211_get_response_rateasbuh1hhjgubj)}(h h]h }(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjgubj.)}(hj1h]h*}(hjghhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjgubj)}(hsbandh]hsband}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjgubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjgubj)}(hu32 basic_ratesh](h)}(hhh]j)}(hu32h]hu32}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjgmodnameN classnameNj j )}j ]jJgc.ieee80211_get_response_rateasbuh1hhjgubj)}(h h]h }(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjgubj)}(h basic_ratesh]h basic_rates}(hj(hhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjgubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjgubj)}(h int bitrateh](j)}(hinth]hint}(hjAhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=hubj)}(h h]h }(hjOhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=hubj)}(hbitrateh]hbitrate}(hj]hhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=hubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjgubeh}(h]h ]h"]h$]h&]jjuh1jhjfhhhjghMqubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjfhhhjghMqubah}(h]jfah ](jjeh"]h$]h&]jj)jhuh1jhhjghMqhjfhhubj)}(hhh]h)}(hget basic rate for a given rateh]hget basic rate for a given rate}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMqhjhhhubah}(h]h ]h"]h$]h&]uh1jhjfhhhjghMqubeh}(h]h ](j$functioneh"]h$]h&]jj$jjhjjhjjjuh1jchhhjGahNhNubj)}(hX**Parameters** ``struct ieee80211_supported_band *sband`` the band to look for rates in ``u32 basic_rates`` bitmap of basic rates ``int bitrate`` the bitrate for which to find the basic rate **Return** The basic rate corresponding to a given bitrate, that is the next lower bitrate contained in the basic rate map, which is, for this function, given as a bitmap of indices of rates in the band's bitrate table.h](h)}(h**Parameters**h]j)}(hjhh]h Parameters}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMuhjhubj)}(hhh](j)}(hI``struct ieee80211_supported_band *sband`` the band to look for rates in h](j)}(h*``struct ieee80211_supported_band *sband``h]j)}(hjhh]h&struct ieee80211_supported_band *sband}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMshjhubj6)}(hhh]h)}(hthe band to look for rates inh]hthe band to look for rates in}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhMshjhubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhhMshjhubj)}(h*``u32 basic_rates`` bitmap of basic rates h](j)}(h``u32 basic_rates``h]j)}(hjih]hu32 basic_rates}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMthjhubj6)}(hhh]h)}(hbitmap of basic ratesh]hbitmap of basic rates}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihMthjiubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjihMthjhubj)}(h=``int bitrate`` the bitrate for which to find the basic rate h](j)}(h``int bitrate``h]j)}(hj:ih]h int bitrate}(hjwhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjvubj)}(hcheck_sah]hcheck_sa}(hjKwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj[tubj)}(hu8 mesh_controlh](h)}(hhh]j)}(hu8h]hu8}(hjgwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdwubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjiwmodnameN classnameNj j )}j ]jtc.ieee80211_amsdu_to_8023sasbuh1hhj`wubj)}(h h]h }(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`wubj)}(h mesh_controlh]h mesh_control}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`wubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj[tubeh}(h]h ]h"]h$]h&]jjuh1jhj"thhhj4thM1ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjthhhj4thM1ubah}(h]jtah ](jjeh"]h$]h&]jj)jhuh1jhhj4thM1hjthhubj)}(hhh]h)}(h#decode an IEEE 802.11n A-MSDU frameh]h#decode an IEEE 802.11n A-MSDU frame}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM1hjwhhubah}(h]h ]h"]h$]h&]uh1jhjthhhj4thM1ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjwjjwjjjuh1jchhhj'qhNhNubj)}(hXY**Parameters** ``struct sk_buff *skb`` The input A-MSDU frame without any headers. ``struct sk_buff_head *list`` The output list of 802.3 frames. It must be allocated and initialized by the caller. ``const u8 *addr`` The device MAC address. ``enum nl80211_iftype iftype`` The device interface type. ``const unsigned int extra_headroom`` The hardware extra headroom for SKBs in the **list**. ``const u8 *check_da`` DA to check in the inner ethernet header, or NULL ``const u8 *check_sa`` SA to check in the inner ethernet header, or NULL ``u8 mesh_control`` see mesh_hdr in ieee80211_is_valid_amsdu **Description** Decode an IEEE 802.11 A-MSDU and convert it to a list of 802.3 frames. The **list** will be empty if the decode fails. The **skb** must be fully header-less before being passed in here; it is freed in this function.h](h)}(h**Parameters**h]j)}(hjwh]h Parameters}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM5hjwubj)}(hhh](j)}(hD``struct sk_buff *skb`` The input A-MSDU frame without any headers. h](j)}(h``struct sk_buff *skb``h]j)}(hjwh]hstruct sk_buff *skb}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM7hjwubj6)}(hhh]h)}(h+The input A-MSDU frame without any headers.h]h+The input A-MSDU frame without any headers.}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxhM7hjxubah}(h]h ]h"]h$]h&]uh1j5hjwubeh}(h]h ]h"]h$]h&]uh1jhjxhM7hjwubj)}(hs``struct sk_buff_head *list`` The output list of 802.3 frames. It must be allocated and initialized by the caller. h](j)}(h``struct sk_buff_head *list``h]j)}(hj7xh]hstruct sk_buff_head *list}(hj9xhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5xubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM9hj1xubj6)}(hhh]h)}(hTThe output list of 802.3 frames. It must be allocated and initialized by the caller.h]hTThe output list of 802.3 frames. It must be allocated and initialized by the caller.}(hjPxhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM8hjMxubah}(h]h ]h"]h$]h&]uh1j5hj1xubeh}(h]h ]h"]h$]h&]uh1jhjLxhM9hjwubj)}(h+``const u8 *addr`` The device MAC address. h](j)}(h``const u8 *addr``h]j)}(hjqxh]hconst u8 *addr}(hjsxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoxubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM:hjkxubj6)}(hhh]h)}(hThe device MAC address.h]hThe device MAC address.}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxhM:hjxubah}(h]h ]h"]h$]h&]uh1j5hjkxubeh}(h]h ]h"]h$]h&]uh1jhjxhM:hjwubj)}(h:``enum nl80211_iftype iftype`` The device interface type. h](j)}(h``enum nl80211_iftype iftype``h]j)}(hjxh]henum nl80211_iftype iftype}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM;hjxubj6)}(hhh]h)}(hThe device interface type.h]hThe device interface type.}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxhM;hjxubah}(h]h ]h"]h$]h&]uh1j5hjxubeh}(h]h ]h"]h$]h&]uh1jhjxhM;hjwubj)}(h\``const unsigned int extra_headroom`` The hardware extra headroom for SKBs in the **list**. h](j)}(h%``const unsigned int extra_headroom``h]j)}(hjxh]h!const unsigned int extra_headroom}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM<hjxubj6)}(hhh]h)}(h5The hardware extra headroom for SKBs in the **list**.h](h,The hardware extra headroom for SKBs in the }(hjxhhhNhNubj)}(h**list**h]hlist}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxubh.}(hjxhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjxhM<hjxubah}(h]h ]h"]h$]h&]uh1j5hjxubeh}(h]h ]h"]h$]h&]uh1jhjxhM<hjwubj)}(hI``const u8 *check_da`` DA to check in the inner ethernet header, or NULL h](j)}(h``const u8 *check_da``h]j)}(hj.yh]hconst u8 *check_da}(hj0yhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,yubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM=hj(yubj6)}(hhh]h)}(h1DA to check in the inner ethernet header, or NULLh]h1DA to check in the inner ethernet header, or NULL}(hjGyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjCyhM=hjDyubah}(h]h ]h"]h$]h&]uh1j5hj(yubeh}(h]h ]h"]h$]h&]uh1jhjCyhM=hjwubj)}(hI``const u8 *check_sa`` SA to check in the inner ethernet header, or NULL h](j)}(h``const u8 *check_sa``h]j)}(hjgyh]hconst u8 *check_sa}(hjiyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeyubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM>hjayubj6)}(hhh]h)}(h1SA to check in the inner ethernet header, or NULLh]h1SA to check in the inner ethernet header, or NULL}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|yhM>hj}yubah}(h]h ]h"]h$]h&]uh1j5hjayubeh}(h]h ]h"]h$]h&]uh1jhj|yhM>hjwubj)}(h=``u8 mesh_control`` see mesh_hdr in ieee80211_is_valid_amsdu h](j)}(h``u8 mesh_control``h]j)}(hjyh]hu8 mesh_control}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM?hjyubj6)}(hhh]h)}(h(see mesh_hdr in ieee80211_is_valid_amsduh]h(see mesh_hdr in ieee80211_is_valid_amsdu}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyhM?hjyubah}(h]h ]h"]h$]h&]uh1j5hjyubeh}(h]h ]h"]h$]h&]uh1jhjyhM?hjwubeh}(h]h ]h"]h$]h&]uh1jhjwubh)}(h**Description**h]j)}(hjyh]h Description}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMAhjwubh)}(hDecode an IEEE 802.11 A-MSDU and convert it to a list of 802.3 frames. The **list** will be empty if the decode fails. The **skb** must be fully header-less before being passed in here; it is freed in this function.h](hKDecode an IEEE 802.11 A-MSDU and convert it to a list of 802.3 frames. The }(hjyhhhNhNubj)}(h**list**h]hlist}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyubh( will be empty if the decode fails. The }(hjyhhhNhNubj)}(h**skb**h]hskb}(hj zhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyubhU must be fully header-less before being passed in here; it is freed in this function.}(hjyhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM2hjwubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj'qhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_#cfg80211_classify8021d (C function)c.cfg80211_classify8021dhNtauh1jRhj'qhhhNhNubjd)}(hhh](ji)}(h[unsigned int cfg80211_classify8021d (struct sk_buff *skb, struct cfg80211_qos_map *qos_map)h]jo)}(hZunsigned int cfg80211_classify8021d(struct sk_buff *skb, struct cfg80211_qos_map *qos_map)h](j)}(hunsignedh]hunsigned}(hjDzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@zhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMaubj)}(h h]h }(hjSzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@zhhhjRzhMaubj)}(hinth]hint}(hjazhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@zhhhjRzhMaubj)}(h h]h }(hjozhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@zhhhjRzhMaubj)}(hcfg80211_classify8021dh]j)}(hcfg80211_classify8021dh]hcfg80211_classify8021d}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}zubah}(h]h ](jjeh"]h$]h&]jjuh1jhj@zhhhjRzhMaubj)}(h7(struct sk_buff *skb, struct cfg80211_qos_map *qos_map)h](j)}(hstruct sk_buff *skbh](ju)}(hjh]hstruct}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjzubj)}(h h]h }(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjzubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjzmodnameN classnameNj j )}j ]j)}jjzsbc.cfg80211_classify8021dasbuh1hhjzubj)}(h h]h }(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjzubj.)}(hj1h]h*}(hjzhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjzubj)}(hskbh]hskb}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjzubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjzubj)}(h struct cfg80211_qos_map *qos_maph](ju)}(hjh]hstruct}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj {ubj)}(h h]h }(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj {ubh)}(hhh]j)}(hcfg80211_qos_maph]hcfg80211_qos_map}(hj-{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj*{ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj/{modnameN classnameNj j )}j ]jzc.cfg80211_classify8021dasbuh1hhj {ubj)}(h h]h }(hjK{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj {ubj.)}(hj1h]h*}(hjY{hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj {ubj)}(hqos_maph]hqos_map}(hjf{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj {ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjzubeh}(h]h ]h"]h$]h&]jjuh1jhj@zhhhjRzhMaubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjalpha2 to some accepted alpha2. **Description** Wireless drivers can use this function to hint to the wireless core what it believes should be the current regulatory domain by giving it an ISO/IEC 3166 alpha2 country code it knows its regulatory domain should be in or by providing a completely build regulatory domain. If the driver provides an ISO/IEC 3166 alpha2 userspace will be queried for a regulatory domain structure for the respective country. The wiphy must have been registered to cfg80211 prior to this call. For cfg80211 drivers this means you must first use wiphy_register(), for mac80211 drivers you must first use ieee80211_register_hw(). Drivers should check the return value, its possible you can get an -ENOMEM. **Return** 0 on success. -ENOMEM.h](h)}(h**Parameters**h]j)}(hj~h]h Parameters}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMxhj}ubj)}(hhh](j)}(h```struct wiphy *wiphy`` the wireless device giving the hint (used only for reporting conflicts) h](j)}(h``struct wiphy *wiphy``h]j)}(hj"~h]hstruct wiphy *wiphy}(hj$~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ~ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMvhj~ubj6)}(hhh]h)}(hGthe wireless device giving the hint (used only for reporting conflicts)h]hGthe wireless device giving the hint (used only for reporting conflicts)}(hj;~hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMuhj8~ubah}(h]h ]h"]h$]h&]uh1j5hj~ubeh}(h]h ]h"]h$]h&]uh1jhj7~hMvhj~ubj)}(h``const char *alpha2`` the ISO/IEC 3166 alpha2 the driver claims its regulatory domain should be in. If **rd** is set this should be NULL. Note that if you set this to NULL you should still set rd->alpha2 to some accepted alpha2. h](j)}(h``const char *alpha2``h]j)}(hj\~h]hconst char *alpha2}(hj^~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZ~ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMzhjV~ubj6)}(hhh]h)}(hthe ISO/IEC 3166 alpha2 the driver claims its regulatory domain should be in. If **rd** is set this should be NULL. Note that if you set this to NULL you should still set rd->alpha2 to some accepted alpha2.h](hQthe ISO/IEC 3166 alpha2 the driver claims its regulatory domain should be in. If }(hju~hhhNhNubj)}(h**rd**h]hrd}(hj}~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhju~ubhw is set this should be NULL. Note that if you set this to NULL you should still set rd->alpha2 to some accepted alpha2.}(hju~hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMwhjr~ubah}(h]h ]h"]h$]h&]uh1j5hjV~ubeh}(h]h ]h"]h$]h&]uh1jhjq~hMzhj~ubeh}(h]h ]h"]h$]h&]uh1jhj}ubh)}(h**Description**h]j)}(hj~h]h Description}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhM|hj}ubh)}(hXWireless drivers can use this function to hint to the wireless core what it believes should be the current regulatory domain by giving it an ISO/IEC 3166 alpha2 country code it knows its regulatory domain should be in or by providing a completely build regulatory domain. If the driver provides an ISO/IEC 3166 alpha2 userspace will be queried for a regulatory domain structure for the respective country.h]hXWireless drivers can use this function to hint to the wireless core what it believes should be the current regulatory domain by giving it an ISO/IEC 3166 alpha2 country code it knows its regulatory domain should be in or by providing a completely build regulatory domain. If the driver provides an ISO/IEC 3166 alpha2 userspace will be queried for a regulatory domain structure for the respective country.}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhM{hj}ubh)}(hThe wiphy must have been registered to cfg80211 prior to this call. For cfg80211 drivers this means you must first use wiphy_register(), for mac80211 drivers you must first use ieee80211_register_hw().h]hThe wiphy must have been registered to cfg80211 prior to this call. For cfg80211 drivers this means you must first use wiphy_register(), for mac80211 drivers you must first use ieee80211_register_hw().}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhj}ubh)}(hKDrivers should check the return value, its possible you can get an -ENOMEM.h]hKDrivers should check the return value, its possible you can get an -ENOMEM.}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhj}ubh)}(h **Return**h]j)}(hj~h]hReturn}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhj}ubh)}(h0 on success. -ENOMEM.h]h0 on success. -ENOMEM.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhj}ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj|hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_*wiphy_apply_custom_regulatory (C function)c.wiphy_apply_custom_regulatoryhNtauh1jRhj|hhhNhNubjd)}(hhh](ji)}(h`void wiphy_apply_custom_regulatory (struct wiphy *wiphy, const struct ieee80211_regdomain *regd)h]jo)}(h_void wiphy_apply_custom_regulatory(struct wiphy *wiphy, const struct ieee80211_regdomain *regd)h](j)}(hvoidh]hvoid}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMubj)}(h h]h }(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0hhhjBhMubj)}(hwiphy_apply_custom_regulatoryh]j)}(hwiphy_apply_custom_regulatoryh]hwiphy_apply_custom_regulatory}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQubah}(h]h ](jjeh"]h$]h&]jjuh1jhj0hhhjBhMubj)}(h=(struct wiphy *wiphy, const struct ieee80211_regdomain *regd)h](j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjmubj)}(h h]h }(hj~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjmubh)}(hhh]j)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}jjWsbc.wiphy_apply_custom_regulatoryasbuh1hhjmubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjmubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjmubj)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjmubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjiubj)}(h&const struct ieee80211_regdomain *regdh](ju)}(hjHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hieee80211_regdomainh]hieee80211_regdomain}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jc.wiphy_apply_custom_regulatoryasbuh1hhjubj)}(h h]h }(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjHhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hregdh]hregd}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjiubeh}(h]h ]h"]h$]h&]jjuh1jhj0hhhjBhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj,hhhjBhMubah}(h]j'ah ](jjeh"]h$]h&]jj)jhuh1jhhjBhMhj)hhubj)}(hhh]h)}(h'apply a custom driver regulatory domainh]h'apply a custom driver regulatory domain}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhj|hhubah}(h]h ]h"]h$]h&]uh1jhj)hhhjBhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhj|hNhNubj)}(hX**Parameters** ``struct wiphy *wiphy`` the wireless device we want to process the regulatory domain on ``const struct ieee80211_regdomain *regd`` the custom regulatory domain to use for this wiphy **Description** Drivers can sometimes have custom regulatory domains which do not apply to a specific country. Drivers can use this to apply such custom regulatory domains. This routine must be called prior to wiphy registration. The custom regulatory domain will be trusted completely and as such previous default channel settings will be disregarded. If no rule is found for a channel on the regulatory domain the channel will be disabled. Drivers using this for a wiphy should also set the wiphy flag REGULATORY_CUSTOM_REG or cfg80211 will set it for the wiphy that called this helper.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubj)}(hhh](j)}(hX``struct wiphy *wiphy`` the wireless device we want to process the regulatory domain on h](j)}(h``struct wiphy *wiphy``h]j)}(hjh]hstruct wiphy *wiphy}(hj€hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h?the wireless device we want to process the regulatory domain onh]h?the wireless device we want to process the regulatory domain on}(hjـhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjՀhMhjրubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjՀhMhjubj)}(h^``const struct ieee80211_regdomain *regd`` the custom regulatory domain to use for this wiphy h](j)}(h*``const struct ieee80211_regdomain *regd``h]j)}(hjh]h&const struct ieee80211_regdomain *regd}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h2the custom regulatory domain to use for this wiphyh]h2the custom regulatory domain to use for this wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj4h]h Description}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubh)}(hX<Drivers can sometimes have custom regulatory domains which do not apply to a specific country. Drivers can use this to apply such custom regulatory domains. This routine must be called prior to wiphy registration. The custom regulatory domain will be trusted completely and as such previous default channel settings will be disregarded. If no rule is found for a channel on the regulatory domain the channel will be disabled. Drivers using this for a wiphy should also set the wiphy flag REGULATORY_CUSTOM_REG or cfg80211 will set it for the wiphy that called this helper.h]hX<Drivers can sometimes have custom regulatory domains which do not apply to a specific country. Drivers can use this to apply such custom regulatory domains. This routine must be called prior to wiphy registration. The custom regulatory domain will be trusted completely and as such previous default channel settings will be disregarded. If no rule is found for a channel on the regulatory domain the channel will be disabled. Drivers using this for a wiphy should also set the wiphy flag REGULATORY_CUSTOM_REG or cfg80211 will set it for the wiphy that called this helper.}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj|hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_freq_reg_info (C function)c.freq_reg_infohNtauh1jRhj|hhhNhNubjd)}(hhh](ji)}(hVconst struct ieee80211_reg_rule * freq_reg_info (struct wiphy *wiphy, u32 center_freq)h]jo)}(hTconst struct ieee80211_reg_rule *freq_reg_info(struct wiphy *wiphy, u32 center_freq)h](ju)}(hjHh]hconst}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjuhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuhhhjhMubju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjuhhhjhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuhhhjhMubh)}(hhh]j)}(hieee80211_reg_ruleh]hieee80211_reg_rule}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}j freq_reg_infosbc.freq_reg_infoasbuh1hhjuhhhjhMubj)}(h h]h }(hjԁhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuhhhjhMubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjuhhhjhMubj)}(h freq_reg_infoh]j)}(hjсh]h freq_reg_info}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjuhhhjhMubj)}(h&(struct wiphy *wiphy, u32 center_freq)h](j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(hwiphyh]hwiphy}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj.modnameN classnameNj j )}j ]jρc.freq_reg_infoasbuh1hhj ubj)}(h h]h }(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj.)}(hj1h]h*}(hjXhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj ubj)}(hwiphyh]hwiphy}(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu32 center_freqh](h)}(hhh]j)}(hu32h]hu32}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jρc.freq_reg_infoasbuh1hhjzubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjzubj)}(h center_freqh]h center_freq}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjzubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjuhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjqhhhjhMubah}(h]jlah ](jjeh"]h$]h&]jj)jhuh1jhhjhMhjnhhubj)}(hhh]h)}(h2get regulatory information for the given frequencyh]h2get regulatory information for the given frequency}(hjׂhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjԂhhubah}(h]h ]h"]h$]h&]uh1jhjnhhhjhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhj|hNhNubj)}(hX**Parameters** ``struct wiphy *wiphy`` the wiphy for which we want to process this rule for ``u32 center_freq`` Frequency in KHz for which we want regulatory information for **Description** Use this function to get the regulatory rule for a specific frequency on a given wireless device. If the device has a specific regulatory domain it wants to follow we respect that unless a country IE has been received and processed already. **Return** A valid pointer, or, when an error occurs, for example if no rule can be found, the return value is encoded using ERR_PTR(). Use IS_ERR() to check and PTR_ERR() to obtain the numeric return value. The numeric return value will be -ERANGE if we determine the given center_freq does not even have a regulatory rule for a frequency range in the center_freq's band. See freq_in_rule_band() for our current definition of a band -- this is purely subjective and right now it's 802.11 specific.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubj)}(hhh](j)}(hM``struct wiphy *wiphy`` the wiphy for which we want to process this rule for h](j)}(h``struct wiphy *wiphy``h]j)}(hjh]hstruct wiphy *wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h4the wiphy for which we want to process this rule forh]h4the wiphy for which we want to process this rule for}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-hMhj.ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj-hMhjubj)}(hR``u32 center_freq`` Frequency in KHz for which we want regulatory information for h](j)}(h``u32 center_freq``h]j)}(hjQh]hu32 center_freq}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjKubj6)}(hhh]h)}(h=Frequency in KHz for which we want regulatory information forh]h=Frequency in KHz for which we want regulatory information for}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhMhjgubah}(h]h ]h"]h$]h&]uh1j5hjKubeh}(h]h ]h"]h$]h&]uh1jhjfhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubh)}(hUse this function to get the regulatory rule for a specific frequency on a given wireless device. If the device has a specific regulatory domain it wants to follow we respect that unless a country IE has been received and processed already.h]hUse this function to get the regulatory rule for a specific frequency on a given wireless device. If the device has a specific regulatory domain it wants to follow we respect that unless a country IE has been received and processed already.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubh)}(hXA valid pointer, or, when an error occurs, for example if no rule can be found, the return value is encoded using ERR_PTR(). Use IS_ERR() to check and PTR_ERR() to obtain the numeric return value. The numeric return value will be -ERANGE if we determine the given center_freq does not even have a regulatory rule for a frequency range in the center_freq's band. See freq_in_rule_band() for our current definition of a band -- this is purely subjective and right now it's 802.11 specific.h]hXA valid pointer, or, when an error occurs, for example if no rule can be found, the return value is encoded using ERR_PTR(). Use IS_ERR() to check and PTR_ERR() to obtain the numeric return value. The numeric return value will be -ERANGE if we determine the given center_freq does not even have a regulatory rule for a frequency range in the center_freq’s band. See freq_in_rule_band() for our current definition of a band -- this is purely subjective and right now it’s 802.11 specific.}(hjɃhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj|hhhNhNubeh}(h]%regulatory-enforcement-infrastructureah ]h"]%regulatory enforcement infrastructureah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(hRFkill integrationh]hRFkill integration}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhKubh)}(hX8RFkill integration in cfg80211 is almost invisible to drivers, as cfg80211 automatically registers an rfkill instance for each wireless device it knows about. Soft kill is also translated into disconnecting and turning all interfaces off. Drivers are expected to turn off the device when all interfaces are down.h]hX8RFkill integration in cfg80211 is almost invisible to drivers, as cfg80211 automatically registers an rfkill instance for each wireless device it knows about. Soft kill is also translated into disconnecting and turning all interfaces off. Drivers are expected to turn off the device when all interfaces are down.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:158: ./include/net/cfg80211.hhMhjhhubh)}(hHowever, devices may have a hard RFkill line, in which case they also need to interact with the rfkill subsystem, via cfg80211. They can do this with a few helper functions documented here.h]hHowever, devices may have a hard RFkill line, in which case they also need to interact with the rfkill subsystem, via cfg80211. They can do this with a few helper functions documented here.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:158: ./include/net/cfg80211.hhMhjhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_'wiphy_rfkill_start_polling (C function)c.wiphy_rfkill_start_pollinghNtauh1jRhjhhhNhNubjd)}(hhh](ji)}(h5void wiphy_rfkill_start_polling (struct wiphy *wiphy)h]jo)}(h4void wiphy_rfkill_start_polling(struct wiphy *wiphy)h](j)}(hvoidh]hvoid}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhMubj)}(h h]h }(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+hhhj=hMubj)}(hwiphy_rfkill_start_pollingh]j)}(hwiphy_rfkill_start_pollingh]hwiphy_rfkill_start_polling}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLubah}(h]h ](jjeh"]h$]h&]jjuh1jhj+hhhj=hMubj)}(h(struct wiphy *wiphy)h]j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhubj)}(h h]h }(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubh)}(hhh]j)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}jjRsbc.wiphy_rfkill_start_pollingasbuh1hhjhubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjhubj)}(hwiphyh]hwiphy}(hjńhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjdubah}(h]h ]h"]h$]h&]jjuh1jhj+hhhj=hMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj'hhhj=hMubah}(h]j"ah ](jjeh"]h$]h&]jj)jhuh1jhhj=hMhj$hhubj)}(hhh]h)}(hstart polling rfkillh]hstart polling rfkill}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhj$hhhj=hMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhjhNhNubj)}(h3**Parameters** ``struct wiphy *wiphy`` the wiphyh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhMhj ubj)}(hhh]j)}(h!``struct wiphy *wiphy`` the wiphyh](j)}(h``struct wiphy *wiphy``h]j)}(hj0h]hstruct wiphy *wiphy}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhMhj*ubj6)}(hhh]h)}(h the wiphyh]h the wiphy}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhMhjFubah}(h]h ]h"]h$]h&]uh1j5hj*ubeh}(h]h ]h"]h$]h&]uh1jhjEhMhj'ubah}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_&wiphy_rfkill_stop_polling (C function)c.wiphy_rfkill_stop_pollinghNtauh1jRhjhhhNhNubjd)}(hhh](ji)}(h4void wiphy_rfkill_stop_polling (struct wiphy *wiphy)h]jo)}(h3void wiphy_rfkill_stop_polling(struct wiphy *wiphy)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubj)}(hwiphy_rfkill_stop_pollingh]j)}(hwiphy_rfkill_stop_pollingh]hwiphy_rfkill_stop_polling}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMubj)}(h(struct wiphy *wiphy)h]j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjDžhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjÅubj)}(h h]h }(hjԅhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjÅubh)}(hhh]j)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}jjsbc.wiphy_rfkill_stop_pollingasbuh1hhjÅubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjÅubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjÅubj)}(hwiphyh]hwiphy}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjÅubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMubah}(h]j}ah ](jjeh"]h$]h&]jj)jhuh1jhhjhMhjhhubj)}(hhh]h)}(hstop polling rfkillh]hstop polling rfkill}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhMhjGhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjbjjbjjjuh1jchhhjhNhNubj)}(h3**Parameters** ``struct wiphy *wiphy`` the wiphyh](h)}(h**Parameters**h]j)}(hjlh]h Parameters}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM#hjfubj)}(hhh]j)}(h!``struct wiphy *wiphy`` the wiphyh](j)}(h``struct wiphy *wiphy``h]j)}(hjh]hstruct wiphy *wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM%hjubj6)}(hhh]h)}(h the wiphyh]h the wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM%hjubah}(h]h ]h"]h$]h&]uh1jhjfubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubeh}(h]rfkill-integrationah ]h"]rfkill integrationah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(h Test modeh]h Test mode}(hj׆hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjԆhhhhhKubh)}(hTest mode is a set of utility functions to allow drivers to interact with driver-specific tools to aid, for instance, factory programming.h]hTest mode is a set of utility functions to allow drivers to interact with driver-specific tools to aid, for instance, factory programming.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:170: ./include/net/cfg80211.hhMhjԆhhubh)}(hoThis chapter describes how drivers interact with it. For more information see the nl80211 book's chapter on it.h]hqThis chapter describes how drivers interact with it. For more information see the nl80211 book’s chapter on it.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:170: ./include/net/cfg80211.hhMhjԆhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_.cfg80211_testmode_alloc_reply_skb (C function)#c.cfg80211_testmode_alloc_reply_skbhNtauh1jRhjԆhhhNhNubjd)}(hhh](ji)}(hWstruct sk_buff * cfg80211_testmode_alloc_reply_skb (struct wiphy *wiphy, int approxlen)h]jo)}(hUstruct sk_buff *cfg80211_testmode_alloc_reply_skb(struct wiphy *wiphy, int approxlen)h](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMubj)}(h h]h }(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhj)hMubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj=modnameN classnameNj j )}j ]j)}j!cfg80211_testmode_alloc_reply_skbsb#c.cfg80211_testmode_alloc_reply_skbasbuh1hhjhhhj)hMubj)}(h h]h }(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhj)hMubj.)}(hj1h]h*}(hjjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjhhhj)hMubj)}(h!cfg80211_testmode_alloc_reply_skbh]j)}(hjYh]h!cfg80211_testmode_alloc_reply_skb}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhj)hMubj)}(h$(struct wiphy *wiphy, int approxlen)h](j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jW#c.cfg80211_testmode_alloc_reply_skbasbuh1hhjubj)}(h h]h }(hj҇hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h int approxlenh](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h approxlenh]h approxlen}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhj)hMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhj)hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhj)hMhjhhubj)}(hhh]h)}(hallocate testmode replyh]hallocate testmode reply}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjIhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj)hMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjdjjdjjjuh1jchhhjԆhNhNubj)}(hX**Parameters** ``struct wiphy *wiphy`` the wiphy ``int approxlen`` an upper bound of the length of the data that will be put into the skb **Description** This function allocates and pre-fills an skb for a reply to the testmode command. Since it is intended for a reply, calling it outside of the **testmode_cmd** operation is invalid. The returned skb is pre-filled with the wiphy index and set up in a way that any data that is put into the skb (with skb_put(), nla_put() or similar) will end up being within the ``NL80211_ATTR_TESTDATA`` attribute, so all that needs to be done with the skb is adding data for the corresponding userspace tool which can then read that data out of the testdata attribute. You must not modify the skb in any other way. When done, call cfg80211_testmode_reply() with the skb and return its error code as the result of the **testmode_cmd** operation. **Return** An allocated and pre-filled skb. ``NULL`` if any errors happen.h](h)}(h**Parameters**h]j)}(hjnh]h Parameters}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjhubj)}(hhh](j)}(h"``struct wiphy *wiphy`` the wiphy h](j)}(h``struct wiphy *wiphy``h]j)}(hjh]hstruct wiphy *wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h the wiphyh]h the wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hY``int approxlen`` an upper bound of the length of the data that will be put into the skb h](j)}(h``int approxlen``h]j)}(hjƈh]h int approxlen}(hjȈhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjĈubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hFan upper bound of the length of the data that will be put into the skbh]hFan upper bound of the length of the data that will be put into the skb}(hj߈hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhj܈ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjۈhMhjubeh}(h]h ]h"]h$]h&]uh1jhjhubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjhubh)}(hThis function allocates and pre-fills an skb for a reply to the testmode command. Since it is intended for a reply, calling it outside of the **testmode_cmd** operation is invalid.h](hThis function allocates and pre-fills an skb for a reply to the testmode command. Since it is intended for a reply, calling it outside of the }(hjhhhNhNubj)}(h**testmode_cmd**h]h testmode_cmd}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh operation is invalid.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjhubh)}(hXThe returned skb is pre-filled with the wiphy index and set up in a way that any data that is put into the skb (with skb_put(), nla_put() or similar) will end up being within the ``NL80211_ATTR_TESTDATA`` attribute, so all that needs to be done with the skb is adding data for the corresponding userspace tool which can then read that data out of the testdata attribute. You must not modify the skb in any other way.h](hThe returned skb is pre-filled with the wiphy index and set up in a way that any data that is put into the skb (with skb_put(), nla_put() or similar) will end up being within the }(hj9hhhNhNubj)}(h``NL80211_ATTR_TESTDATA``h]hNL80211_ATTR_TESTDATA}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubh attribute, so all that needs to be done with the skb is adding data for the corresponding userspace tool which can then read that data out of the testdata attribute. You must not modify the skb in any other way.}(hj9hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjhubh)}(hWhen done, call cfg80211_testmode_reply() with the skb and return its error code as the result of the **testmode_cmd** operation.h](hfWhen done, call cfg80211_testmode_reply() with the skb and return its error code as the result of the }(hjZhhhNhNubj)}(h**testmode_cmd**h]h testmode_cmd}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZubh operation.}(hjZhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjhubh)}(h **Return**h]j)}(hj}h]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjhubh)}(h?An allocated and pre-filled skb. ``NULL`` if any errors happen.h](h!An allocated and pre-filled skb. }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh if any errors happen.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjhubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjԆhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_$cfg80211_testmode_reply (C function)c.cfg80211_testmode_replyhNtauh1jRhjԆhhhNhNubjd)}(hhh](ji)}(h1int cfg80211_testmode_reply (struct sk_buff *skb)h]jo)}(h0int cfg80211_testmode_reply(struct sk_buff *skb)h](j)}(hinth]hint}(hjԉhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjЉhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjЉhhhjhMubj)}(hcfg80211_testmode_replyh]j)}(hcfg80211_testmode_replyh]hcfg80211_testmode_reply}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjЉhhhjhMubj)}(h(struct sk_buff *skb)h]j)}(hstruct sk_buff *skbh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj1modnameN classnameNj j )}j ]j)}jjsbc.cfg80211_testmode_replyasbuh1hhj ubj)}(h h]h }(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj.)}(hj1h]h*}(hj]hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj ubj)}(hskbh]hskb}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubah}(h]h ]h"]h$]h&]jjuh1jhjЉhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj̉hhhjhMubah}(h]jljah ](jjeh"]h$]h&]jj)jhuh1jhhjhMhjɉhhubj)}(hhh]h)}(hsend the reply skbh]hsend the reply skb}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjɉhhhjhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhjԆhNhNubj)}(hX**Parameters** ``struct sk_buff *skb`` The skb, must have been allocated with cfg80211_testmode_alloc_reply_skb() **Description** Since calling this function will usually be the last thing before returning from the **testmode_cmd** you should return the error code. Note that this function consumes the skb regardless of the return value. **Return** An error code or 0 on success.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjubj)}(hhh]j)}(hc``struct sk_buff *skb`` The skb, must have been allocated with cfg80211_testmode_alloc_reply_skb() h](j)}(h``struct sk_buff *skb``h]j)}(hjՊh]hstruct sk_buff *skb}(hj׊hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjӊubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjϊubj6)}(hhh]h)}(hJThe skb, must have been allocated with cfg80211_testmode_alloc_reply_skb()h]hJThe skb, must have been allocated with cfg80211_testmode_alloc_reply_skb()}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjϊubeh}(h]h ]h"]h$]h&]uh1jhjhMhj̊ubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjubh)}(hSince calling this function will usually be the last thing before returning from the **testmode_cmd** you should return the error code. Note that this function consumes the skb regardless of the return value.h](hUSince calling this function will usually be the last thing before returning from the }(hj'hhhNhNubj)}(h**testmode_cmd**h]h testmode_cmd}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'ubhl you should return the error code. Note that this function consumes the skb regardless of the return value.}(hj'hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjubh)}(h **Return**h]j)}(hjJh]hReturn}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hjubh)}(hAn error code or 0 on success.h]hAn error code or 0 on success.}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjԆhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_.cfg80211_testmode_alloc_event_skb (C function)#c.cfg80211_testmode_alloc_event_skbhNtauh1jRhjԆhhhNhNubjd)}(hhh](ji)}(hbstruct sk_buff * cfg80211_testmode_alloc_event_skb (struct wiphy *wiphy, int approxlen, gfp_t gfp)h]jo)}(h`struct sk_buff *cfg80211_testmode_alloc_event_skb(struct wiphy *wiphy, int approxlen, gfp_t gfp)h](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}j!cfg80211_testmode_alloc_event_skbsb#c.cfg80211_testmode_alloc_event_skbasbuh1hhjhhhjhM ubj)}(h h]h }(hjϋhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj.)}(hj1h]h*}(hj݋hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjhhhjhM ubj)}(h!cfg80211_testmode_alloc_event_skbh]j)}(hj̋h]h!cfg80211_testmode_alloc_event_skb}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubj)}(h/(struct wiphy *wiphy, int approxlen, gfp_t gfp)h](j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hwiphyh]hwiphy}(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj)modnameN classnameNj j )}j ]jʋ#c.cfg80211_testmode_alloc_event_skbasbuh1hhjubj)}(h h]h }(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjShhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hwiphyh]hwiphy}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h int approxlenh](j)}(hinth]hint}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuubj)}(h approxlenh]h approxlen}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jʋ#c.cfg80211_testmode_alloc_event_skbasbuh1hhjubj)}(h h]h }(hjόhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hj݌hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM hjhhubj)}(hhh]h)}(hallocate testmode eventh]hallocate testmode event}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhjԆhNhNubj)}(hX**Parameters** ``struct wiphy *wiphy`` the wiphy ``int approxlen`` an upper bound of the length of the data that will be put into the skb ``gfp_t gfp`` allocation flags **Description** This function allocates and pre-fills an skb for an event on the testmode multicast group. The returned skb is set up in the same way as with cfg80211_testmode_alloc_reply_skb() but prepared for an event. As there, you should simply add data to it that will then end up in the ``NL80211_ATTR_TESTDATA`` attribute. Again, you must not modify the skb in any other way. When done filling the skb, call cfg80211_testmode_event() with the skb to send the event. **Return** An allocated and pre-filled skb. ``NULL`` if any errors happen.h](h)}(h**Parameters**h]j)}(hj)h]h Parameters}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hj#ubj)}(hhh](j)}(h"``struct wiphy *wiphy`` the wiphy h](j)}(h``struct wiphy *wiphy``h]j)}(hjHh]hstruct wiphy *wiphy}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hjBubj6)}(hhh]h)}(h the wiphyh]h the wiphy}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]hM hj^ubah}(h]h ]h"]h$]h&]uh1j5hjBubeh}(h]h ]h"]h$]h&]uh1jhj]hM hj?ubj)}(hY``int approxlen`` an upper bound of the length of the data that will be put into the skb h](j)}(h``int approxlen``h]j)}(hjh]h int approxlen}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuba95h}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hj{ubj6)}(hhh]h)}(hFan upper bound of the length of the data that will be put into the skbh]hFan upper bound of the length of the data that will be put into the skb}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hj{ubeh}(h]h ]h"]h$]h&]uh1jhjhM hj?ubj)}(h``gfp_t gfp`` allocation flags h](j)}(h ``gfp_t gfp``h]j)}(hjh]h gfp_t gfp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjԍhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjЍhM hjэubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjЍhM hj?ubeh}(h]h ]h"]h$]h&]uh1jhj#ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hj#ubh)}(hZThis function allocates and pre-fills an skb for an event on the testmode multicast group.h]hZThis function allocates and pre-fills an skb for an event on the testmode multicast group.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hj#ubh)}(hXThe returned skb is set up in the same way as with cfg80211_testmode_alloc_reply_skb() but prepared for an event. As there, you should simply add data to it that will then end up in the ``NL80211_ATTR_TESTDATA`` attribute. Again, you must not modify the skb in any other way.h](hThe returned skb is set up in the same way as with cfg80211_testmode_alloc_reply_skb() but prepared for an event. As there, you should simply add data to it that will then end up in the }(hjhhhNhNubj)}(h``NL80211_ATTR_TESTDATA``h]hNL80211_ATTR_TESTDATA}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh@ attribute. Again, you must not modify the skb in any other way.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hj#ubh)}(hYWhen done filling the skb, call cfg80211_testmode_event() with the skb to send the event.h]hYWhen done filling the skb, call cfg80211_testmode_event() with the skb to send the event.}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hj#ubh)}(h **Return**h]j)}(hjMh]hReturn}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hj#ubh)}(h?An allocated and pre-filled skb. ``NULL`` if any errors happen.h](h!An allocated and pre-filled skb. }(hjchhhNhNubj)}(h``NULL``h]hNULL}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubh if any errors happen.}(hjchhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hj#ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjԆhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_$cfg80211_testmode_event (C function)c.cfg80211_testmode_eventhNtauh1jRhjԆhhhNhNubjd)}(hhh](ji)}(h=void cfg80211_testmode_event (struct sk_buff *skb, gfp_t gfp)h]jo)}(hjjjܝjjojtjܣjjjjjjjjjjjjjj׻jܻjjjbjgjjjQjVj jj5j:jjjjjj$jsjxjjjE jJ jjjjj jjjj"j "j%j%j(j(j+j+j0j0j34j84jR7jW7jAajU:j:j:j;j;j.Bj3BjBFjGFjqLjvLjNjNjQjQjSjSjXjXj!_j&_j!qjGajsajxajUcjZcjdjdjfjfjijijmjmjojoj|j'qjSqjXqjtjtj7zj