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_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. ``IEEE80211_CHAN_S1G_NO_PRIMARY`` Prevents the channel for use as an S1G primary channel. Does not prevent the wider operating channel described by the chandef from being used. In order for a 2MHz primary to be used, both 1MHz subchannels shall not contain this flag. ``IEEE80211_CHAN_NO_4MHZ`` 4 MHz bandwidth is not permitted on this channel. ``IEEE80211_CHAN_NO_8MHZ`` 8 MHz bandwidth is not permitted on this channel. ``IEEE80211_CHAN_NO_16MHZ`` 16 MHz bandwidth is not permitted on this channel.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)}(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)}(hjch]hIEEE80211_CHAN_NO_320MHZ}(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)}(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.}(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)}(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&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(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)}(hjh]h!IEEE80211_CHAN_NO_6GHZ_VLP_CLIENT}(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>Client connection with VLP AP not permitted using this channelh]h>Client connection with VLP AP not permitted using this channel}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj3ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj2hKhjubj)}(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)}(hjWh]h!IEEE80211_CHAN_NO_6GHZ_AFC_CLIENT}(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.hhKhjQubj6)}(hhh]h)}(h>Client connection with AFC AP not permitted using this channelh]h>Client connection with AFC AP not permitted using this channel}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjmubah}(h]h ]h"]h$]h&]uh1j5hjQubeh}(h]h ]h"]h$]h&]uh1jhjlhKhjubj)}(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)}(hl``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)}(hjh]h#IEEE80211_CHAN_ALLOW_20MHZ_ACTIVITY}(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)}(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.}(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)}(hX ``IEEE80211_CHAN_S1G_NO_PRIMARY`` Prevents the channel for use as an S1G primary channel. Does not prevent the wider operating channel described by the chandef from being used. In order for a 2MHz primary to be used, both 1MHz subchannels shall not contain this flag. h](j)}(h!``IEEE80211_CHAN_S1G_NO_PRIMARY``h]j)}(hj?h]hIEEE80211_CHAN_S1G_NO_PRIMARY}(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)}(hPrevents the channel for use as an S1G primary channel. Does not prevent the wider operating channel described by the chandef from being used. In order for a 2MHz primary to be used, both 1MHz subchannels shall not contain this flag.h]hPrevents the channel for use as an S1G primary channel. Does not prevent the wider operating channel described by the chandef from being used. In order for a 2MHz primary to be used, both 1MHz subchannels shall not contain this flag.}(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)}(hM``IEEE80211_CHAN_NO_4MHZ`` 4 MHz bandwidth is not permitted on this channel. h](j)}(h``IEEE80211_CHAN_NO_4MHZ``h]j)}(hjyh]hIEEE80211_CHAN_NO_4MHZ}(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)}(h14 MHz bandwidth is not permitted on this channel.h]h14 MHz bandwidth is not permitted on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j5hjsubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hM``IEEE80211_CHAN_NO_8MHZ`` 8 MHz bandwidth is not permitted on this channel. h](j)}(h``IEEE80211_CHAN_NO_8MHZ``h]j)}(hjh]hIEEE80211_CHAN_NO_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.hhKhjubj6)}(hhh]h)}(h18 MHz bandwidth is not permitted on this channel.h]h18 MHz bandwidth 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)}(hN``IEEE80211_CHAN_NO_16MHZ`` 16 MHz bandwidth is not permitted on this channel.h](j)}(h``IEEE80211_CHAN_NO_16MHZ``h]j)}(hjh]hIEEE80211_CHAN_NO_16MHZ}(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)}(h216 MHz bandwidth is not permitted on this channel.h]h216 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.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hj.h]h Description}(hj0hhhNhNubah}(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.hhKhhhhubh)}(h1Channel flags set by the regulatory control code.h]h1Channel flags set by the regulatory control code.}(hjDhhhNhNubah}(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}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKNubj)}(h h]h }(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhhjzhKNubj)}(hieee80211_channelh]j)}(hjfh]hieee80211_channel}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhhjzhKNubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjdhhhjzhKNubah}(h]j_ah ](jjeh"]h$]h&]jj)jhuh1jhhjzhKNhjahhubj)}(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&]uh1jhjahhhjzhKNubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhhhNhNubj)}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubh 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; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubh)}(h **Members**h]j)}(hjh]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:14: ./include/net/cfg80211.hhKhjubj)}(hhh](j)}(h'``band`` band this channel belongs to. 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.hhKhj ubj6)}(hhh]h)}(hband this channel belongs to.h]hband this channel belongs to.}(hj7 hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3 hKhj4 ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj3 hKhj ubj)}(h(``center_freq`` center frequency in MHz h](j)}(h``center_freq``h]j)}(hjW h]h center_freq}(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:14: ./include/net/cfg80211.hhKhjQ ubj6)}(hhh]h)}(hcenter frequency in MHzh]hcenter frequency in MHz}(hjp hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjl hKhjm ubah}(h]h ]h"]h$]h&]uh1j5hjQ ubeh}(h]h ]h"]h$]h&]uh1jhjl hKhj 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 hKhj 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 hKhj ubj)}(h_``flags`` channel flags from :c:type:`enum ieee80211_channel_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.hhKhj ubj6)}(hhh]h)}(hTchannel flags from :c:type:`enum ieee80211_channel_flags `.h](hchannel flags from }(hj- hhhNhNubh)}(h@:c:type:`enum ieee80211_channel_flags `h]j)}(hj7 h]henum ieee80211_channel_flags}(hj9 hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj5 ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarn c:parent_keysphinx.domains.c LookupKey)}data]sbj6ieee80211_channel_flagsuh1hhj) hKhj- ubh.}(hj- hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj) hKhj* ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj) hKhj ubj)}(h1``max_antenna_gain`` maximum antenna gain in dBi h](j)}(h``max_antenna_gain``h]j)}(hjx h]hmax_antenna_gain}(hjz hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjv ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjr 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&]uh1j5hjr ubeh}(h]h ]h"]h$]h&]uh1jhj hKhj 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 hKhj 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 hKhj 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.hhKhj 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.}(hj< hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj9 ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj8 hKhj 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.hhKhjW 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}(hjv hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjs ubah}(h]h ]h"]h$]h&]uh1j5hjW ubeh}(h]h ]h"]h$]h&]uh1jhjr hKhj 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 hKhj 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 hKhj 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)}(hj h]h dfs_state}(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)}(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.hhKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhj ubj)}(hJ``dfs_state_entered`` timestamp (jiffies) when the dfs state was entered. h](j)}(h``dfs_state_entered``h]j)}(hjC h]hdfs_state_entered}(hjE hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjA 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)}(h3timestamp (jiffies) when the dfs state was entered.h]h3timestamp (jiffies) when the dfs state was entered.}(hj\ hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjX hKhjY ubah}(h]h ]h"]h$]h&]uh1j5hj= ubeh}(h]h ]h"]h$]h&]uh1jhjX hKhj 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&]uh1jhjz ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjv 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&]uh1j5hjv ubeh}(h]h ]h"]h$]h&]uh1jhj hKhj 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 hKhj ubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(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: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.}(hj 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}(hj6 hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj2 hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKubj)}(h h]h }(hjD hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2 hhhjC hKubj)}(hieee80211_rate_flagsh]j)}(hj0 h]hieee80211_rate_flags}(hjV hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjR ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj2 hhhjC hKubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj. hhhjC hKubah}(h]j) ah ](jjeh"]h$]h&]jj)jhuh1jhhjC hKhj+ hhubj)}(hhh]h)}(h rate flagsh]h rate flags}(hjx hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhju hhubah}(h]h ]h"]h$]h&]uh1jhj+ hhhjC 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}(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)}(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.}(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&]uh1jhjhKhj 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)}(hj-h]hIEEE80211_RATE_MANDATORY_B}(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)}(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.}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjCubah}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhjBhKhj 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)}(hjgh]hIEEE80211_RATE_MANDATORY_G}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjaubj6)}(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.hhKhj}ubah}(h]h ]h"]h$]h&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hKhj 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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhj ubj)}(hA``IEEE80211_RATE_SUPPORTS_10MHZ`` Rate can be used in 10 MHz modeh](j)}(h!``IEEE80211_RATE_SUPPORTS_10MHZ``h]j)}(hjh]hIEEE80211_RATE_SUPPORTS_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.hhKhj ubj6)}(hhh]h)}(hRate can be used in 10 MHz modeh]hRate can be used in 10 MHz mode}(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 ubeh}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hjVh]h Description}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjTubah}(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.}(hjlhhhNhNubah}(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)}(hjnh]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$jjjjjjjuh1jchhhhhNhNubj)}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj)}(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; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./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:14: ./include/net/cfg80211.hhM"hjubj)}(hhh](j)}(h^``flags`` rate-specific flags from :c:type:`enum ieee80211_rate_flags ` h](j)}(h ``flags``h]j)}(hjCh]hflags}(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.hhMhj=ubj6)}(hhh]h)}(hSrate-specific flags from :c:type:`enum ieee80211_rate_flags `h](hrate-specific flags from }(hj\hhhNhNubh)}(h::c:type:`enum ieee80211_rate_flags `h]j)}(hjfh]henum ieee80211_rate_flags}(hjhhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6ieee80211_rate_flagsuh1hhjXhMhj\ubeh}(h]h ]h"]h$]h&]uh1hhjXhMhjYubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhjXhMhj:ubj)}(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.hhMhjubj6)}(hhh]h)}(hbitrate in units of 100 Kbpsh]hbitrate in units of 100 Kbps}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj:ubj)}(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&]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#driver/hardware value for this rateh]h#driver/hardware value for this rate}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj:ubj)}(hR``hw_value_short`` driver/hardware value for this rate when short preamble is usedh](j)}(h``hw_value_short``h]j)}(hj h]hhw_value_short}(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!hjubj6)}(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}(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&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hjOh]h Description}(hjQhhhNhNubah}(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.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 }(hjehhhNhNubj)}(h **hw_value**h]hhw_value}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjeubh and }(hjehhhNhNubj)}(h**hw_value_short**h]hhw_value_short}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjeubhK are only for driver use when pointers to this structure are passed around.}(hjehhhNhNubeh}(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)}(hjnh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/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)}(hieee80211_sta_ht_caph]j)}(hjh]hieee80211_sta_ht_cap}(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)}(hSTA's HT capabilitiesh]hSTA’s HT capabilities}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMNhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](j$structeh"]h$]h&]jj$jj jj jjjuh1jchhhhhNhNubj)}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMRhjubj)}(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; };}hj0sbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMThjubh)}(h **Members**h]j)}(hjAh]hMembers}(hjChhhNhNubah}(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\hjubj)}(hhh](j)}(h9``cap`` HT capabilities map as described in 802.11n spec h](j)}(h``cap``h]j)}(hj`h]hcap}(hjbhhhNhNubah}(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.hhMUhjZubj6)}(hhh]h)}(h0HT capabilities map as described in 802.11n spech]h0HT capabilities map as described in 802.11n spec}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuhMUhjvubah}(h]h ]h"]h$]h&]uh1j5hjZubeh}(h]h ]h"]h$]h&]uh1jhjuhMUhjWubj)}(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.hhMThjubj6)}(hhh]h)}(his HT supported by the STAh]his HT supported by the STA}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMThjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMThjWubj)}(h.``ampdu_factor`` Maximum A-MPDU length factor h](j)}(h``ampdu_factor``h]j)}(hjh]h ampdu_factor}(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.hhMVhjubj6)}(hhh]h)}(hMaximum A-MPDU length factorh]hMaximum A-MPDU length factor}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMVhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMVhjWubj)}(h)``ampdu_density`` Minimum A-MPDU spacing h](j)}(h``ampdu_density``h]j)}(hj h]h ampdu_density}(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.hhMWhjubj6)}(hhh]h)}(hMinimum A-MPDU spacingh]hMinimum A-MPDU spacing}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMWhj!ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMWhjWubj)}(h``mcs`` Supported MCS ratesh](j)}(h``mcs``h]j)}(hjDh]hmcs}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMWhj>ubj6)}(hhh]h)}(hSupported MCS ratesh]hSupported MCS rates}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMXhjZubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhjYhMWhjWubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(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.hhMOhhhhubjS)}(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)}(hjnh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMUubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMUubj)}(hieee80211_supported_bandh]j)}(hjh]hieee80211_supported_band}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMUubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMUubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMUhjhhubj)}(hhh]h)}(hfrequency band definitionh]hfrequency band 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&]uh1jhjhhhjhMUubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhhhNhNubj)}(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}(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_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; };}hjDsbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM%hj#ubh)}(h **Members**h]j)}(hjUh]hMembers}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjSubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM3hj#ubj)}(hhh](j)}(hK``channels`` Array of channels the hardware can operate with in this band. h](j)}(h ``channels``h]j)}(hjth]hchannels}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM&hjnubj6)}(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&]uh1j5hjnubeh}(h]h ]h"]h$]h&]uh1jhjhM&hjkubj)}(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+hjkubj)}(h,``band`` the band this structure represents h](j)}(h``band``h]j)}(hjh]hband}(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"the band this structure representsh]h"the band this structure represents}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM'hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM'hjkubj)}(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&]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 channels in **channels**h](hNumber of channels in }(hj:hhhNhNubj)}(h **channels**h]hchannels}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:ubeh}(h]h ]h"]h$]h&]uh1hhj6hM(hj7ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj6hM(hjkubj)}(h2``n_bitrates`` Number of bitrates in **bitrates** h](j)}(h``n_bitrates``h]j)}(hjhh]h n_bitrates}(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"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&]uh1hhj}hM,hj~ubah}(h]h ]h"]h$]h&]uh1j5hjbubeh}(h]h ]h"]h$]h&]uh1jhj}hM,hjkubj)}(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.hhM-hjubj6)}(hhh]h)}(hHT capabilities in this bandh]hHT capabilities in this band}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM-hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM-hjkubj)}(h*``vht_cap`` VHT capabilities in this band h](j)}(h ``vht_cap``h]j)}(hjh]hvht_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.hhM.hjubj6)}(hhh]h)}(hVHT capabilities in this bandh]hVHT capabilities in this band}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM.hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM.hjkubj)}(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&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM1hjubj6)}(hhh]h)}(h8S1G capabilities in this band (S1G band only, of course)h]h8S1G capabilities in this band (S1G band only, of course)}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hM1hj7ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj6hM1hjkubj)}(h,``edmg_cap`` EDMG capabilities in this band h](j)}(h ``edmg_cap``h]j)}(hjZh]hedmg_cap}(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.hhM0hjTubj6)}(hhh]h)}(hEDMG capabilities in this bandh]hEDMG capabilities in this band}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhjohM0hjpubah}(h]h ]h"]h$]h&]uh1j5hjTubeh}(h]h ]h"]h$]h&]uh1jhjohM0hjkubj)}(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.hhM2hjubj6)}(hhh]h)}(hnumber of iftype data entriesh]hnumber of iftype data entries}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM2hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM2hjkubj)}(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}(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)}(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 }(hjhhhNhNubj)}(h**types_mask**h]h types_mask}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh} inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_data).}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM3hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM5hjkubeh}(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&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM9hhhhubh)}(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.}(hj7hhhNhNubah}(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}(hjahhhNhNubah}(h]h ]ktah"]h$]h&]uh1j_hj[hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[hhhjphMubj)}(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&]jjuh1jhj[hhhjphMubhdesc_parameterlist)}(h(struct wiphy *wiphy)h]hdesc_parameter)}(hstruct wiphy *wiphyh](ju)}(hjnh]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 classnameNjS jV )}jY ]jT ASTIdentifier)}jjsbc.wiphy_read_of_freq_limitsasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubhdesc_sig_punctuation)}(h*h]h*}(hjhhhNhNubah}(h]h ]pah"]h$]h&]uh1jhjubj)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhj[hhhjphMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjWhhhjphMubah}(h]jRah ](jjeh"]h$]h&]jj)jhuh1jhhjphMhjThhubj)}(hhh]h)}(h&read frequency limits from device treeh]h&read frequency limits from device tree}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj*hhubah}(h]h ]h"]h$]h&]uh1jhjThhhjphMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjEjjEjjjuh1jchhhhhNhNubj)}(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)}(hjOh]h Parameters}(hjQhhhNhNubah}(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.hhMhjIubj)}(hhh]j)}(hD``struct wiphy *wiphy`` the wireless device to get extra limits for h](j)}(h``struct wiphy *wiphy``h]j)}(hjnh]hstruct wiphy *wiphy}(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.hhMhjhubj6)}(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&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhMhjeubah}(h]h ]h"]h$]h&]uh1jhjIubh)}(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.hhMhjIubh)}(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.hhMhjIubh)}(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 }(hjhhhNhNubhemphasis)}(h*modify*h]hmodify}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh7 channels (disable unavailable ones). It’s usually a }(hjhhhNhNubj)}(h*bad*h]hbad}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh 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.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjIubh)}(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().}(hjhhhNhNubah}(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_cfg80211_signal_type (C enum)c.cfg80211_signal_typehNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hcfg80211_signal_typeh]jo)}(henum cfg80211_signal_typeh](ju)}(hjxh]henum}(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj.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&]uh1jhj.hhhj?hMubj)}(hcfg80211_signal_typeh]j)}(hj,h]hcfg80211_signal_type}(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNubah}(h]h ](jjeh"]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)}(h signal typeh]h signal type}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjqhhubah}(h]h ]h"]h$]h&]uh1jhj'hhhj?hMubeh}(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}(hjhhhNhNubah}(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)}(hjh]hCFG80211_SIGNAL_TYPE_MBM}(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 signal strength in mBm (100*dBm)h]h signal strength in mBm (100*dBm)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hN``CFG80211_SIGNAL_TYPE_UNSPEC`` signal strength, increasing from 0 through 100h](j)}(h``CFG80211_SIGNAL_TYPE_UNSPEC``h]j)}(hj'h]hCFG80211_SIGNAL_TYPE_UNSPEC}(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, 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 hj=ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj<hM 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&]uh1jthj}hhh`/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&]uh1jhj}hhhjhM ubj)}(hwiphy_params_flagsh]j)}(hj{h]hwiphy_params_flags}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhj}hhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjyhhhjhM ubah}(h]jtah ](jjeh"]h$]h&]jj)jhuh1jhhjhM hjvhhubj)}(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&]uh1jhjvhhhjhM 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)}(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)}(h;``WIPHY_PARAM_RETRY_SHORT`` wiphy->retry_short has changed h](j)}(h``WIPHY_PARAM_RETRY_SHORT``h]j)}(hjh]hWIPHY_PARAM_RETRY_SHORT}(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)}(hwiphy->retry_short has changedh]hwiphy->retry_short has changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h9``WIPHY_PARAM_RETRY_LONG`` wiphy->retry_long has changed h](j)}(h``WIPHY_PARAM_RETRY_LONG``h]j)}(hj=h]hWIPHY_PARAM_RETRY_LONG}(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.hhMhj7ubj6)}(hhh]h)}(hwiphy->retry_long has changedh]hwiphy->retry_long has changed}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRhMhjSubah}(h]h ]h"]h$]h&]uh1j5hj7ubeh}(h]h ]h"]h$]h&]uh1jhjRhMhjubj)}(hA``WIPHY_PARAM_FRAG_THRESHOLD`` wiphy->frag_threshold has changed h](j)}(h``WIPHY_PARAM_FRAG_THRESHOLD``h]j)}(hjvh]hWIPHY_PARAM_FRAG_THRESHOLD}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjpubj6)}(hhh]h)}(h!wiphy->frag_threshold has changedh]h!wiphy->frag_threshold has changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjpubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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 hjubj)}(h6``WIPHY_PARAM_COVERAGE_CLASS`` coverage class changed h](j)}(h``WIPHY_PARAM_COVERAGE_CLASS``h]j)}(hjh]hWIPHY_PARAM_COVERAGE_CLASS}(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)}(hcoverage class changedh]hcoverage class changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(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&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hdynack has been enabledh]hdynack has been enabled}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hMhj7ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj6hMhjubj)}(h<``WIPHY_PARAM_TXQ_LIMIT`` TXQ packet limit has been changed h](j)}(h``WIPHY_PARAM_TXQ_LIMIT``h]j)}(hjZh]hWIPHY_PARAM_TXQ_LIMIT}(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.hhMhjTubj6)}(hhh]h)}(h!TXQ packet limit has been changedh]h!TXQ packet limit has been changed}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhjohMhjpubah}(h]h ]h"]h$]h&]uh1j5hjTubeh}(h]h ]h"]h$]h&]uh1jhjohMhjubj)}(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.hhMhjubj6)}(hhh]h)}(h!TXQ memory limit has been changedh]h!TXQ memory limit has been changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h1``WIPHY_PARAM_TXQ_QUANTUM`` TXQ scheduler quantumh](j)}(h``WIPHY_PARAM_TXQ_QUANTUM``h]j)}(hjh]hWIPHY_PARAM_TXQ_QUANTUM}(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)}(hTXQ scheduler quantumh]hTXQ scheduler quantum}(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&]uh1jhjhMhjubeh}(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}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj"hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"hhhj3hMubj)}(h wiphy_flagsh]j)}(hj h]h wiphy_flags}(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubah}(h]h ](jjeh"]h$]h&]jjuh1jhj"hhhj3hMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhj3hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhj3hMhjhhubj)}(hhh]h)}(hwiphy capability flagsh]hwiphy capability flags}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMehjehhubah}(h]h ]h"]h$]h&]uh1jhjhhhj3hMubeh}(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.hhMihjubj)}(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.hhMlhjubj6)}(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&]uh1hhjhMlhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMlhjubj)}(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.hhMrhjubj6)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMohjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMrhjubj)}(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)}(hjh]hWIPHY_FLAG_SPLIT_SCAN_6GHZ}(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.hhMvhjubj6)}(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.}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMuhj2ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj1hMvhjubj)}(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)}(hjVh]hWIPHY_FLAG_NETNS_OK}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMzhjPubj6)}(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}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMyhjlubah}(h]h ]h"]h$]h&]uh1j5hjPubeh}(h]h ]h"]h$]h&]uh1jhjkhMzhjubj)}(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.hhM}hjubah}(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)}(hjh]hWIPHY_FLAG_4ADDR_STATION}(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%supports 4addr mode even as a stationh]h%supports 4addr mode even as a station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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)}(hj=h]h WIPHY_FLAG_CONTROL_PORT_PROTOCOL}(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.hhMhj7ubj6)}(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.}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjSubah}(h]h ]h"]h$]h&]uh1j5hj7ubeh}(h]h ]h"]h$]h&]uh1jhjRhMhjubj)}(h6``WIPHY_FLAG_IBSS_RSN`` The device supports IBSS RSN. h](j)}(h``WIPHY_FLAG_IBSS_RSN``h]j)}(hjwh]hWIPHY_FLAG_IBSS_RSN}(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)}(hThe device supports IBSS RSN.h]hThe device supports IBSS RSN.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjqubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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.hhMhjubj6)}(hhh]h)}(h+disable wireless extensions for this deviceh]h+disable wireless extensions for this device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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)}(hjh]hWIPHY_FLAG_MESH_AUTH}(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)}(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}(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.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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)}(hj5 h]hWIPHY_FLAG_SUPPORTS_EXT_KCK_32}(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)}(h%The device supports 32-byte KCK keys.h]h%The device supports 32-byte KCK keys.}(hjN hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJ hMhjK ubah}(h]h ]h"]h$]h&]uh1j5hj/ ubeh}(h]h ]h"]h$]h&]uh1jhjJ hMhjubj)}(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)}(hjn h]h#WIPHY_FLAG_SUPPORTS_NSTR_NONPRIMARY}(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:14: ./include/net/cfg80211.hhMhjh 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.hhMhj ubah}(h]h ]h"]h$]h&]uh1j5hjh ubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubj)}(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.hhMhj 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.hhMhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubj)}(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.hhMhj ubj6)}(hhh]h)}(h The device supports uapsd on AP.h]h The device supports uapsd on AP.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubj)}(hK``WIPHY_FLAG_SUPPORTS_TDLS`` The device supports TDLS (802.11z) operation. h](j)}(h``WIPHY_FLAG_SUPPORTS_TDLS``h]j)}(hj!h]hWIPHY_FLAG_SUPPORTS_TDLS}(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-The device supports TDLS (802.11z) operation.h]h-The device supports TDLS (802.11z) operation.}(hj4!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0!.hMhj1!ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj0!hMhjubj)}(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)}(hjT!h]hWIPHY_FLAG_TDLS_EXTERNAL_SETUP}(hjV!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjR!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjN!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 }(hjm!hhhNhNubj)}(h**NL80211_CMD_TDLS_MGMT**h]hNL80211_CMD_TDLS_MGMT}(hju!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjm!ubh% command. When this flag is not set, }(hjm!hhhNhNubj)}(h**NL80211_CMD_TDLS_OPER**h]hNL80211_CMD_TDLS_OPER}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjm!ubhK should be used for asking the driver/firmware to perform a TDLS operation.}(hjm!hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjj!ubah}(h]h ]h"]h$]h&]uh1j5hjN!ubeh}(h]h ]h"]h$]h&]uh1jhji!hMhjubj)}(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.hhMhj!ubj6)}(hhh]h)}(hdevice integrates AP SMEh]hdevice integrates AP SME}(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``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.hhMhj!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.hhMhj"ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj"hMhjubj)}(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}(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)}(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.}(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:"hMhjubj)}(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}(hja"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.hhMhjY"ubj6)}(hhh]h)}(h&Device supports direct off-channel TX.h]h&Device supports direct off-channel TX.}(hjx"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjt"hMhju"ubah}(h]h ]h"]h$]h&]uh1j5hjY"ubeh}(h]h ]h"]h$]h&]uh1jhjt"hMhjubj)}(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.hhMhj"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"hMhj"ubah}(h]h ]h"]h$]h&]uh1j5hj"ubeh}(h]h ]h"]h$]h&]uh1jhj"hMhjubj)}(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.hhMhj"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"hMhj"ubah}(h]h ]h"]h$]h&]uh1j5hj"ubeh}(h]h ]h"]h$]h&]uh1jhj"hMhjubj)}(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)}(hj #h]hWIPHY_FLAG_HAS_CHANNEL_SWITCH}(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)}(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.hhMhj #ubah}(h]h ]h"]h$]h&]uh1j5hj#ubeh}(h]h ]h"]h$]h&]uh1jhj#hMhjubj)}(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)}(hjD#h]h"WIPHY_FLAG_NOTIFY_REGDOM_BY_DRIVER}(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.hhMhj>#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.hhMhjZ#ubah}(h]h ]h"]h$]h&]uh1j5hj>#ubeh}(h]h ]h"]h$]h&]uh1jhjY#hMhjubj)}(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.hhMhjx#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#hMhj#ubah}(h]h ]h"]h$]h&]uh1j5hjx#ubeh}(h]h ]h"]h$]h&]uh1jhj#hMhjubeh}(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)}(hjnh]hstruct}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj#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&]uh1jhj#hhhj#hMubj)}(hieee80211_iface_limith]j)}(hj#h]hieee80211_iface_limit}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#ubah}(h]h ](jjeh"]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)}(h limit on certain interface typesh]h limit on certain interface types}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj$hhubah}(h]h ]h"]h$]h&]uh1jhj#hhhj#hMubeh}(h]h ](j$structeh"]h$]h&]jj$jj1$jj1$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}(hj=$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9$ubh:}(hj9$hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj5$ubj)}(h=struct ieee80211_iface_limit { u16 max; u16 types; };h]h=struct ieee80211_iface_limit { u16 max; u16 types; };}hjV$sbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj5$ubh)}(h **Members**h]j)}(hjg$h]hMembers}(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.hhMhj5$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.hhMhj$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$hMhj$ubah}(h]h ]h"]h$]h&]uh1j5hj$ubeh}(h]h ]h"]h$]h&]uh1jhj$hMhj}$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.hhMhj$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.hhMhj$ubah}(h]h ]h"]h$]h&]uh1j5hj$ubeh}(h]h ]h"]h$]h&]uh1jhj$hMhj}$ubeh}(h]h ]h"]h$]h&]uh1jhj5$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)}(hjnh]hstruct}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj%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&]uh1jhj%hhhj&%hMubj)}(hieee80211_iface_combinationh]j)}(hj%h]hieee80211_iface_combination}(hj9%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5%ubah}(h]h ](jjeh"]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)}(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.hhMhjX%hhubah}(h]h ]h"]h$]h&]uh1jhj%hhhj&%hMubeh}(h]h ](j$structeh"]h$]h&]jj$jjs%jjs%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.hhMhjw%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&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjw%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.hhMhjw%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.hhMhj%ubj6)}(hhh]h)}(h*can use up to this many different channelsh]h*can use up to this many different channels}(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)}(hO``max_interfaces`` maximum number of interfaces in total allowed in this group h](j)}(h``max_interfaces``h]j)}(hj:&h]hmax_interfaces}(hj<&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8&ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj4&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}(hjS&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjO&hMhjP&ubah}(h]h ]h"]h$]h&]uh1j5hj4&ubeh}(h]h ]h"]h$]h&]uh1jhjO&hMhj%ubj)}(h#``n_limits`` number of limitations h](j)}(h ``n_limits``h]j)}(hjs&h]hn_limits}(hju&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjq&ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjm&ubj6)}(hhh]h)}(hnumber of limitationsh]hnumber of limitations}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&hMhj&ubah}(h]h ]h"]h$]h&]uh1j5hjm&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.hhM!hj&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&]uh1hhj&hM!hj&ubah}(h]h ]h"]h$]h&]uh1j5hj&ubeh}(h]h ]h"]h$]h&]uh1jhj&hM!hj%ubj)}(hI``radar_detect_regions`` bitmap of regions supported for radar detection h](j)}(h``radar_detect_regions``h]j)}(hj'h]hradar_detect_regions}(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/bitmap of regions supported for radar detectionh]h/bitmap of regions supported for radar detection}(hj8'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4'hM'hj5'ubah}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhj4'hM'hj%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)}(hjX'h]hbeacon_int_min_gcd}(hjZ'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjV'ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM3hjR'ubj6)}(hhh](h)}(h?This interface combination supports different beacon intervals.h]h?This interface combination supports different beacon intervals.}(hjq'hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM-hjn'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.hhM/hj'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.hhM0hj'ubah}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'hM/hj'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&]uh1jhjm'hM3hj'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.hhM2hj'ubah}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhjm'hM3hj'ubeh}(h]h ]h"]h$]h&]uh1jhjn'ubeh}(h]h ]h"]h$]h&]uh1j5hjR'ubeh}(h]h ]h"]h$]h&]uh1jhjm'hM3hj%ubeh}(h]h ]h"]h$]h&]uh1jhjw%ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(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:14: ./include/net/cfg80211.hhM7hhhhubh)}(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.}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhhhhubh)}(h **Examples**h]j)}(hj,(h]hExamples}(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.hhMhhhhubhenumerated_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:}(hjM(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjI(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}uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjI(ubeh}(h]h ]h"]h$]h&]uh1jG(hjD(ubjH()}(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:}(hjy(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhju(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&]jjjj(jk(j$jl(}uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhju(ubeh}(h]h ]h"]h$]h&]uh1jG(hjD(ubjH()}(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&]jjjj(jk(j$jl(}uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj(ubeh}(h]h ]h"]h$]h&]uh1jG(hjD(ubeh}(h]h ]h"]h$]h&]enumtypearabicprefixhsuffix.uh1jB(hhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wiphy (C struct)c.wiphyhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hwiphyh]jo)}(h struct wiphyh](ju)}(hjnh]hstruct}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj(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&]uh1jhj(hhhj)hMubj)}(hwiphyh]j)}(hj(h]hwiphy}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubah}(h]h ](jjeh"]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)}(hwireless hardware descriptionh]hwireless hardware description}(hj<)hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj9)hhubah}(h]h ]h"]h$]h&]uh1jhj(hhhj)hMubeh}(h]h ](j$structeh"]h$]h&]jj$jjT)jjT)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 *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_param_support; u32 bss_select_support; u8 nan_supported_bands; struct wiphy_nan_capa nan_capa; 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_param_support`` bitmask indicating which bss_parameters as defined in :c:type:`struct bss_parameters ` the driver can actually handle in the .change_bss() callback. The bit positions are defined in :c:type:`enum wiphy_bss_param_flags `. ``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)). ``nan_capa`` NAN capabilities ``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.hhMhjX)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 *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_param_support; u32 bss_select_support; u8 nan_supported_bands; struct wiphy_nan_capa nan_capa; 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 *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_param_support; u32 bss_select_support; u8 nan_supported_bands; struct wiphy_nan_capa nan_capa; 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[] ; };}hjy)sbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjX)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.hhMhjX)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}(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)}(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)}(hj*h]h addr_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.hhMhj*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.}(hj4*hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj1*ubah}(h]h ]h"]h$]h&]uh1j5hj*ubeh}(h]h ]h"]h$]h&]uh1jhj0*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)}(hjU*h]h addresses}(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)}(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.}(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&]uh1j5hjO*ubeh}(h]h ]h"]h$]h&]uh1jhjj*hMhj)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.hhMhj*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.hhMhj*ubah}(h]h ]h"]h$]h&]uh1j5hj*ubeh}(h]h ]h"]h$]h&]uh1jhj*hMhj)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.hhMhj*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.hhMhj*ubah}(h]h ]h"]h$]h&]uh1j5hj*ubeh}(h]h ]h"]h$]h&]uh1jhj*hMhj)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.hhMhj*ubj6)}(hhh]h)}(h2number of entries in **iface_combinations** array.h](hnumber of entries in }(hj+hhhNhNubj)}(h**iface_combinations**h]hiface_combinations}(hj$+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj+ubh array.}(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``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)}(hjN+h]hsoftware_iftypes}(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:14: ./include/net/cfg80211.hhMhjH+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.}(hjg+hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjd+ubah}(h]h ]h"]h$]h&]uh1j5hjH+ubeh}(h]h ]h"]h$]h&]uh1jhjc+hMhj)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.hhMhj+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.hhMhj+ubah}(h]h ]h"]h$]h&]uh1j5hj+ubeh}(h]h ]h"]h$]h&]uh1jhj+hMhj)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)}(hj ,h]hmax_acl_mac_addrs}(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 MAC addresses that the device supports for ACL.h]hAMaximum number of MAC addresses that the device supports for ACL.}(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)}(hD``flags`` wiphy flags, see :c:type:`enum wiphy_flags ` h](j)}(h ``flags``h]j)}(hjG,h]hflags}(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)}(h9wiphy flags, see :c:type:`enum wiphy_flags `h](hwiphy flags, see }(hj`,hhhNhNubh)}(h(:c:type:`enum wiphy_flags `h]j)}(hjj,h]henum wiphy_flags}(hjl,hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjh,ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6 wiphy_flagsuh1hhj\,hMhj`,ubeh}(h]h ]h"]h$]h&]uh1hhj\,hMhj],ubah}(h]h ]h"]h$]h&]uh1j5hjA,ubeh}(h]h ]h"]h$]h&]uh1jhj\,hMhj)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.hhMhj,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 refexplicitrefwarnjS jW j6ieee80211_regulatory_flagsuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj,ubeh}(h]h ]h"]h$]h&]uh1hhj,hMhj,ubah}(h]h ]h"]h$]h&]uh1j5hj,ubeh}(h]h ]h"]h$]h&]uh1jhj,hMhj)ubj)}(ho``features`` features advertised to nl80211, see :c:type:`enum nl80211_feature_flags `. h](j)}(h ``features``h]j)}(hj,h]hfeatures}(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)}(hafeatures advertised to nl80211, see :c:type:`enum nl80211_feature_flags `.h](h$features advertised to nl80211, see }(hj-hhhNhNubh)}(h<:c:type:`enum nl80211_feature_flags `h]j)}(hj-h]henum nl80211_feature_flags}(hj-hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6nl80211_feature_flagsuh1hhj -hMhj-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``ext_features`` extended features advertised to nl80211, see :c:type:`enum nl80211_ext_feature_index `. h](j)}(h``ext_features``h]j)}(hjT-h]h ext_features}(hjV-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjR-ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjN-ubj6)}(hhh]h)}(hrextended features advertised to nl80211, see :c:type:`enum nl80211_ext_feature_index `.h](h-extended features advertised to nl80211, see }(hjm-hhhNhNubh)}(hD:c:type:`enum nl80211_ext_feature_index `h]j)}(hjw-h]henum nl80211_ext_feature_index}(hjy-hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhju-ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6nl80211_ext_feature_indexuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjm-ubh.}(hjm-hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj-hMhjj-ubah}(h]h ]h"]h$]h&]uh1j5hjN-ubeh}(h]h ]h"]h$]h&]uh1jhji-hMhj)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.hhMhj-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 refexplicitrefwarnjS jW j6nl80211_ap_sme_featuresuh1hhj-hMhj-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)}(hV``signal_type`` signal type reported in :c:type:`struct cfg80211_bss `. h](j)}(h``signal_type``h]j)}(hj .h]h signal_type}(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)}(hEsignal type reported in :c:type:`struct cfg80211_bss `.h](hsignal type reported in }(hj&.hhhNhNubh)}(h,:c:type:`struct cfg80211_bss `h]j)}(hj0.h]hstruct cfg80211_bss}(hj2.hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj..ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6 cfg80211_bssuh1hhj".hMhj&.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)}(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)}(hji.h]h bss_priv_size}(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:14: ./include/net/cfg80211.hhMhjc.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.hhMhj.ubah}(h]h ]h"]h$]h&]uh1j5hjc.ubeh}(h]h ]h"]h$]h&]uh1jhj~.hMhj)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.hhMhj.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.hhMhj.ubah}(h]h ]h"]h$]h&]uh1j5hj.ubeh}(h]h ]h"]h$]h&]uh1jhj.hMhj)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.hhMhj.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.}(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``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)}(hj/h]hmax_sched_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.hhMhj/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}(hj0/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_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)}(hjQ/h]hmax_match_sets}(hjS/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjO/ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjK/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.}(hjj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjg/ubah}(h]h ]h"]h$]h&]uh1j5hjK/ubeh}(h]h ]h"]h$]h&]uh1jhjf/hMhj)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.hhMhj/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.hhMhj/ubah}(h]h ]h"]h$]h&]uh1j5hj/ubeh}(h]h ]h"]h$]h&]uh1jhj/hMhj)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)}(hj/h]hmax_sched_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.hhMhj/ubj6)}(hhh]h)}(h0same as max_scan_ie_len, but for scheduled scansh]h0same as max_scan_ie_len, but for scheduled scans}(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_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/h]hmax_sched_scan_plans}(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.hhMhj/ubj6)}(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.}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj0ubah}(h]h ]h"]h$]h&]uh1j5hj/ubeh}(h]h ]h"]h$]h&]uh1jhj0hMhj)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)}(hj90h]hmax_sched_scan_plan_interval}(hj;0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj70ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj30ubj6)}(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.}(hjR0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjO0ubah}(h]h ]h"]h$]h&]uh1j5hj30ubeh}(h]h ]h"]h$]h&]uh1jhjN0hMhj)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)}(hjs0h]hmax_sched_scan_plan_iterations}(hju0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjq0ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjm0ubj6)}(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.hhMhj0ubah}(h]h ]h"]h$]h&]uh1j5hjm0ubeh}(h]h ]h"]h$]h&]uh1jhj0hMhj)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}(hj0hhhNhNubah}(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)}(hj0h]h 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)}(hsupported cipher suitesh]hsupported cipher suites}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0hMhj0ubah}(h]h ]h"]h$]h&]uh1j5hj0ubeh}(h]h ]h"]h$]h&]uh1jhj0hMhj)ubj)}(h0``n_akm_suites`` number of supported AKM suites h](j)}(h``n_akm_suites``h]j)}(hj1h]h n_akm_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)}(hnumber of supported AKM suitesh]hnumber of supported AKM suites}(hj81hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj41hMhj51ubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhj41hMhj)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)}(hjX1h]h akm_suites}(hjZ1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjV1ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjR1ubj6)}(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.}(hjq1hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjn1ubah}(h]h ]h"]h$]h&]uh1j5hjR1ubeh}(h]h ]h"]h$]h&]uh1jhjm1hMhj)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.hhMhj1ubah}(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)}(hj1h]hnum_iftype_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)}(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.}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj1ubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhj1hMhj)ubj)}(hD``retry_short`` Retry limit for short frames (dot11ShortRetryLimit) h](j)}(h``retry_short``h]j)}(hj2h]h retry_short}(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)}(h3Retry limit for short frames (dot11ShortRetryLimit)h]h3Retry limit for short frames (dot11ShortRetryLimit)}(hj12hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-2hMhj.2ubah}(h]h ]h"]h$]h&]uh1j5hj2ubeh}(h]h ]h"]h$]h&]uh1jhj-2hMhj)ubj)}(hA``retry_long`` Retry limit for long frames (dot11LongRetryLimit) h](j)}(h``retry_long``h]j)}(hjQ2h]h retry_long}(hjS2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjO2ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjK2ubj6)}(hhh]h)}(h1Retry limit for long frames (dot11LongRetryLimit)h]h1Retry limit for long frames (dot11LongRetryLimit)}(hjj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjf2hMhjg2ubah}(h]h ]h"]h$]h&]uh1j5hjK2ubeh}(h]h ]h"]h$]h&]uh1jhjf2hMhj)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}(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)}(h8RTS threshold (dot11RTSThreshold); -1 = RTS/CTS disabledh]h8RTS threshold (dot11RTSThreshold); -1 = RTS/CTS disabled}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2hMhj2ubah}(h]h ]h"]h$]h&]uh1j5hj2ubeh}(h]h ]h"]h$]h&]uh1jhj2hMhj)ubj)}(h*``coverage_class`` current coverage class h](j)}(h``coverage_class``h]j)}(hj2h]hcoverage_class}(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)}(hcurrent coverage classh]hcurrent coverage class}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMhj3ubah}(h]h ]h"]h$]h&]uh1j5hj2ubeh}(h]h ]h"]h$]h&]uh1jhj3hMhj)ubj)}(h6``fw_version`` firmware version for ethtool reporting h](j)}(h``fw_version``h]j)}(hj63h]h fw_version}(hj83hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj43ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj03ubj6)}(hhh]h)}(h&firmware version for ethtool reportingh]h&firmware version for ethtool reporting}(hjO3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjK3hMhjL3ubah}(h]h ]h"]h$]h&]uh1j5hj03ubeh}(h]h ]h"]h$]h&]uh1jhjK3hMhj)ubj)}(h6``hw_version`` hardware version for ethtool reporting h](j)}(h``hw_version``h]j)}(hjo3h]h hw_version}(hjq3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjm3ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhji3ubj6)}(hhh]h)}(h&hardware version for ethtool reportingh]h&hardware version for ethtool reporting}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMhj3ubah}(h]h ]h"]h$]h&]uh1j5hji3ubeh}(h]h ]h"]h$]h&]uh1jhj3hMhj)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.hhMhj3ubj6)}(hhh]h)}(hWoWLAN support informationh]hWoWLAN support information}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMhj3ubah}(h]h ]h"]h$]h&]uh1j5hj3ubeh}(h]h ]h"]h$]h&]uh1jhj3hMhj)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)}(hj3h]h wowlan_config}(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.hhMhj3ubj6)}(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.}(hj3hhhNhNubah}(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&]uh1j5hj3ubeh}(h]h ]h"]h$]h&]uh1jhj3hMhj)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)}(hj4h]hmax_remain_on_channel_duration}(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.hhMhj4ubj6)}(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.}(hj44hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj14ubah}(h]h ]h"]h$]h&]uh1j5hj4ubeh}(h]h ]h"]h$]h&]uh1jhj04hMhj)ubj)}(h@``max_num_pmkids`` maximum number of PMKIDs supported by device h](j)}(h``max_num_pmkids``h]j)}(hjU4h]hmax_num_pmkids}(hjW4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjS4ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjO4ubj6)}(hhh]h)}(h,maximum number of PMKIDs supported by deviceh]h,maximum number of PMKIDs supported by device}(hjn4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjj4hMhjk4ubah}(h]h ]h"]h$]h&]uh1j5hjO4ubeh}(h]h ]h"]h$]h&]uh1jhjj4hMhj)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.hhMhj4ubj6)}(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.hhMhj4ubah}(h]h ]h"]h$]h&]uh1j5hj4ubeh}(h]h ]h"]h$]h&]uh1jhj4hMhj)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)}(hj4h]havailable_antennas_rx}(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.hhMhj4ubj6)}(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 }(hj4hhhNhNubj)}(h**available_antennas_tx**h]havailable_antennas_tx}(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.hhMhj4ubah}(h]h ]h"]h$]h&]uh1j5hj4ubeh}(h]h ]h"]h$]h&]uh1jhj4hMhj)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)}(hj&5h]hprobe_resp_offload}(hj(5hhhNhNubah}(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.hhMhj 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 }(hj?5hhhNhNubh)}(h`:c:type:`enum nl80211_probe_resp_offload_support_attr `h]j)}(hjI5h]h,enum nl80211_probe_resp_offload_support_attr}(hjK5hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjG5ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6'nl80211_probe_resp_offload_support_attruh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj?5ubh!. Only valid when the wiphy flag }(hj?5hhhNhNubj)}(h$**WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD**h]h WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD}(hjk5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?5ubh is set.}(hj?5hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjf5hMhj<5ubah}(h]h ]h"]h$]h&]uh1j5hj 5ubeh}(h]h ]h"]h$]h&]uh1jhj;5hMhj)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)}(hj5h]hextended_capabilities_mask}(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)}(hmask of the valid valuesh]hmask of the valid values}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5hMhj5ubah}(h]h ]h"]h$]h&]uh1j5hj5ubeh}(h]h ]h"]h$]h&]uh1jhj5hMhj)ubj)}(hB``extended_capabilities_len`` length of the extended capabilities h](j)}(h``extended_capabilities_len``h]j)}(hj6h]hextended_capabilities_len}(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)}(h#length of the extended capabilitiesh]h#length of the extended capabilities}(hj!6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hMhj6ubah}(h]h ]h"]h$]h&]uh1j5hj6ubeh}(h]h ]h"]h$]h&]uh1jhj6hMhj)ubj)}(hG``iftype_ext_capab`` array of extended capabilities per interface type h](j)}(h``iftype_ext_capab``h]j)}(hjA6h]hiftype_ext_capab}(hjC6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?6ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj;6ubj6)}(hhh]h)}(h1array of extended capabilities per interface typeh]h1array of extended capabilities per interface type}(hjZ6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjV6hMhjW6ubah}(h]h ]h"]h$]h&]uh1j5hj;6ubeh}(h]h ]h"]h$]h&]uh1jhjV6hMhj)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)}(hjz6h]hnum_iftype_ext_capab}(hj|6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjx6ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjt6ubj6)}(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&]uh1j5hjt6ubeh}(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.hhMhj6ubj6)}(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}(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)}(hD``bands`` information about bands/channels supported by this device h](j)}(h ``bands``h]j)}(hj6h]hbands}(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)}(h9information about bands/channels supported by this deviceh]h9information about bands/channels supported by this device}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7hMhj7ubah}(h]h ]h"]h$]h&]uh1j5hj6ubeh}(h]h ]h"]h$]h&]uh1jhj7hMhj)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)}(hj'7h]h reg_notifier}(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.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.hhMhj=7ubah}(h]h ]h"]h$]h&]uh1j5hj!7ubeh}(h]h ]h"]h$]h&]uh1jhj<7hMhj)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)}(hja7h]h radio_cfg}(hjc7hhhNhNubah}(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.hhMlhj[7ubj6)}(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.}(hjz7hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMjhjw7ubah}(h]h ]h"]h$]h&]uh1j5hj[7ubeh}(h]h ]h"]h$]h&]uh1jhjv7hMlhj)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)}(hj7h]hdev}(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)}(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).}(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[``registered`` protects ->resume and ->suspend sysfs callbacks against unregister hardware h](j)}(h``registered``h]j)}(hj8h]h registered}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj 8ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj 8ubj6)}(hhh]h)}(hKprotects ->resume and ->suspend sysfs callbacks against unregister hardwareh]hKprotects ->resume and ->suspend sysfs callbacks against unregister hardware}(hj(8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj%8ubah}(h]h ]h"]h$]h&]uh1j5hj 8ubeh}(h]h ]h"]h$]h&]uh1jhj$8hMhj)ubj)}(h``debugfsdir`` debugfs directory used for this wiphy (ieee80211/). It will be renamed automatically on wiphy renames h](j)}(h``debugfsdir``h]j)}(hjI8h]h debugfsdir}(hjK8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjG8ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjC8ubj6)}(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}(hjb8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj_8ubah}(h]h ]h"]h$]h&]uh1j5hjC8ubeh}(h]h ]h"]h$]h&]uh1jhj^8hMhj)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.hhMhj}8ubj6)}(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.hhMhj8ubah}(h]h ]h"]h$]h&]uh1j5hj}8ubeh}(h]h ]h"]h$]h&]uh1jhj8hMhj)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.hhMhj8ubj6)}(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.}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj8ubah}(h]h ]h"]h$]h&]uh1j5hj8ubeh}(h]h ]h"]h$]h&]uh1jhj8hMhj)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)}(hj8h]h wdev_list}(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.hhMhj8ubj6)}(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.}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj 9ubah}(h]h ]h"]h$]h&]uh1j5hj8ubeh}(h]h ]h"]h$]h&]uh1jhj 9hMhj)ubj)}(h=``_net`` the network namespace this wiphy currently lives in h](j)}(h``_net``h]j)}(hj19h]h_net}(hj39hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/9ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj+9ubj6)}(hhh]h)}(h3the network namespace this wiphy currently lives inh]h3the network namespace this wiphy currently lives in}(hjJ9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjF9hMhjG9ubah}(h]h ]h"]h$]h&]uh1j5hj+9ubeh}(h]h ]h"]h$]h&]uh1jhjF9hMhj)ubj)}(h%``wext`` wireless extension handlers h](j)}(h``wext``h]j)}(hjj9h]hwext}(hjl9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjh9ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjd9ubj6)}(hhh]h)}(hwireless extension handlersh]hwireless extension handlers}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hMhj9ubah}(h]h ]h"]h$]h&]uh1j5hjd9ubeh}(h]h ]h"]h$]h&]uh1jhj9hMhj)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)}(hj9h]hvendor_commands}(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)}(h2array of vendor commands supported by the hardwareh]h2array of vendor commands supported by the hardware}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hMhj9ubah}(h]h ]h"]h$]h&]uh1j5hj9ubeh}(h]h ]h"]h$]h&]uh1jhj9hMhj)ubj)}(hC``vendor_events`` array of vendor events supported by the hardware h](j)}(h``vendor_events``h]j)}(hj:h]h 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)}(h0array of vendor events supported by the hardwareh]h0array of vendor events supported by the hardware}(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)}(h0``n_vendor_commands`` number of vendor commands h](j)}(h``n_vendor_commands``h]j)}(hjN:h]hn_vendor_commands}(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:14: ./include/net/cfg80211.hhMhjH:ubj6)}(hhh]h)}(hnumber of vendor commandsh]hnumber of vendor commands}(hjg:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjc:hMhjd:ubah}(h]h ]h"]h$]h&]uh1j5hjH:ubeh}(h]h ]h"]h$]h&]uh1jhjc: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.hhM#hj: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.hhM hj:ubah}(h]h ]h"]h$]h&]uh1j5hj:ubeh}(h]h ]h"]h$]h&]uh1jhj:hM#hj)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)}(hj:h]hmax_num_csa_counters}(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)}(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.}(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``bss_param_support`` bitmask indicating which bss_parameters as defined in :c:type:`struct bss_parameters ` the driver can actually handle in the .change_bss() callback. The bit positions are defined in :c:type:`enum wiphy_bss_param_flags `. h](j)}(h``bss_param_support``h]j)}(hj4;h]hbss_param_support}(hj6;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2;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)}(hXbitmask indicating which bss_parameters as defined in :c:type:`struct bss_parameters ` the driver can actually handle in the .change_bss() callback. The bit positions are defined in :c:type:`enum wiphy_bss_param_flags `.h](h6bitmask indicating which bss_parameters as defined in }(hjM;hhhNhNubh)}(h0:c:type:`struct bss_parameters `h]j)}(hjW;h]hstruct bss_parameters}(hjY;hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjU;ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6bss_parametersuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM)hjM;ubh` the driver can actually handle in the .change_bss() callback. The bit positions are defined in }(hjM;hhhNhNubh)}(h<:c:type:`enum wiphy_bss_param_flags `h]j)}(hj{;h]henum wiphy_bss_param_flags}(hj};hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjy;ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6wiphy_bss_param_flagsuh1hhjt;hM)hjM;ubh.}(hjM;hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjt;hM)hjJ;ubah}(h]h ]h"]h$]h&]uh1j5hj.;ubeh}(h]h ]h"]h$]h&]uh1jhjI;hM,hj)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)}(hj;h]hbss_select_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.hhM0hj;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 refexplicitrefwarnjS jW j6nl80211_bss_select_attruh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM.hj;ubh.}(hj;hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj;hM.hj;ubah}(h]h ]h"]h$]h&]uh1j5hj;ubeh}(h]h ]h"]h$]h&]uh1jhj;hM0hj)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.hhM5hj <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)}(hj4<h]henum nl80211_band}(hj6<hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj2<ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6 nl80211_banduh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM2hj*<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&]uh1hhjQ<hM2hj'<ubah}(h]h ]h"]h$]h&]uh1j5hj <ubeh}(h]h ]h"]h$]h&]uh1jhj&<hM5hj)ubj)}(h``nan_capa`` NAN capabilities h](j)}(h ``nan_capa``h]j)}(hjn<h]hnan_capa}(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:14: ./include/net/cfg80211.hhM6hjh<ubj6)}(hhh]h)}(hNAN capabilitiesh]hNAN capabilities}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hM6hj<ubah}(h]h ]h"]h$]h&]uh1j5hjh<ubeh}(h]h ]h"]h$]h&]uh1jhj<hM6hj)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.hhM8hj<ubj6)}(hhh]h)}(h.configuration of internal TX queue frame limith]h.configuration of internal TX queue frame limit}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hM8hj<ubah}(h]h ]h"]h$]h&]uh1j5hj<ubeh}(h]h ]h"]h$]h&]uh1jhj<hM8hj)ubj)}(hB``txq_memory_limit`` configuration internal TX queue memory limit h](j)}(h``txq_memory_limit``h]j)}(hj<h]htxq_memory_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.hhM9hj<ubj6)}(hhh]h)}(h,configuration internal TX queue memory limith]h,configuration internal TX queue memory limit}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hM9hj<ubah}(h]h ]h"]h$]h&]uh1j5hj<ubeh}(h]h ]h"]h$]h&]uh1jhj<hM9hj)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.hhM:hj=ubj6)}(hhh]h)}(h4configuration of internal TX queue scheduler quantumh]h4configuration of internal TX queue scheduler quantum}(hj2=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)}(hV``tx_queue_len`` allow setting transmit queue len for drivers not using wake_tx_queue h](j)}(h``tx_queue_len``h]j)}(hjR=h]h tx_queue_len}(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.hhM=hjL=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}(hjk=hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM<hjh=ubah}(h]h ]h"]h$]h&]uh1j5hjL=ubeh}(h]h ]h"]h$]h&]uh1jhjg=hM=hj)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.hhM?hj=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=hM?hj=ubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhj=hM?hj)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)}(hj=h]hsupport_only_he_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.hhMBhj=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}(hj=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.hhM@hj=ubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhj=hMBhj)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.hhMDhj >ubj6)}(hhh]h)}(hpeer measurement capabilitiesh]hpeer measurement capabilities}(hj*>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&>hMDhj'>ubah}(h]h ]h"]h$]h&]uh1j5hj >ubeh}(h]h ]h"]h$]h&]uh1jhj&>hMDhj)ubj)}(hP``tid_config_support`` describes the per-TID config support that the device has h](j)}(h``tid_config_support``h]j)}(hjJ>h]htid_config_support}(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.hhMGhjD>ubj6)}(hhh]h)}(h8describes the per-TID config support that the device hash]h8describes the per-TID config support that the device has}(hjc>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&]uh1j5hjD>ubeh}(h]h ]h"]h$]h&]uh1jhj_>hMGhj)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.hhMKhj~>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.hhMJhj>ubah}(h]h ]h"]h$]h&]uh1j5hj~>ubeh}(h]h ]h"]h$]h&]uh1jhj>hMKhj)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}(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.hhMIhj>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}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMHhj>ubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhj>hMIhj)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)}(hj>h]htid_config_support.max_retry}(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.hhMMhj>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.hhMLhj?ubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhj ?hMMhj)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)}(hj2?h]hmax_data_retry_count}(hj4?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0?ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMQhj,?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 }(hjK?hhhNhNubj)}(h'``NL80211_TID_CONFIG_ATTR_RETRY_SHORT``h]h#NL80211_TID_CONFIG_ATTR_RETRY_SHORT}(hjS?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjK?ubh and }(hjK?hhhNhNubj)}(h&``NL80211_TID_CONFIG_ATTR_RETRY_LONG``h]h"NL80211_TID_CONFIG_ATTR_RETRY_LONG}(hje?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjK?ubh attributes}(hjK?hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMOhjH?ubah}(h]h ]h"]h$]h&]uh1j5hj,?ubeh}(h]h ]h"]h$]h&]uh1jhjG?hMQhj)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.hhMRhj?ubj6)}(hhh]h)}(hSAR control capabilitiesh]hSAR control capabilities}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hMRhj?ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhj?hMRhj)ubj)}(h-``rfkill`` a pointer to the rfkill structure h](j)}(h ``rfkill``h]j)}(hj?h]hrfkill}(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.hhMShj?ubj6)}(hhh]h)}(h!a pointer to the rfkill structureh]h!a pointer to the rfkill structure}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hMShj?ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhj?hMShj)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.hhMWhj?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.hhMUhj@ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhj@hMWhj)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.hhMZhj6@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).}(hjU@hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMXhjR@ubah}(h]h ]h"]h$]h&]uh1j5hj6@ubeh}(h]h ]h"]h$]h&]uh1jhjQ@hMZhj)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)}(hjv@h]hmax_num_akm_suites}(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)}(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.hhM[hj@ubah}(h]h ]h"]h$]h&]uh1j5hjp@ubeh}(h]h ]h"]h$]h&]uh1jhj@hMahj)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)}(hj@h]hhw_timestamp_max_peers}(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)}(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}(hjAhhhNhNubah}(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.hhMchj@ubah}(h]h ]h"]h$]h&]uh1j5hj@ubeh}(h]h ]h"]h$]h&]uh1jhj@hMhhj)ubj)}(h``n_radio`` number of radios h](j)}(h ``n_radio``h]j)}(hj2Ah]hn_radio}(hj4AhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0Aubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMohj,Aubj6)}(hhh]h)}(hnumber of radiosh]hnumber of radios}(hjKAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjGAhMohjHAubah}(h]h ]h"]h$]h&]uh1j5hj,Aubeh}(h]h ]h"]h$]h&]uh1jhjGAhMohj)ubj)}(h)``radio`` radios belonging to this wiphy h](j)}(h ``radio``h]j)}(hjkAh]hradio}(hjmAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiAubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMnhjeAubj6)}(hhh]h)}(hradios belonging to this wiphyh]hradios belonging to this wiphy}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjAhMnhjAubah}(h]h ]h"]h$]h&]uh1j5hjeAubeh}(h]h ]h"]h$]h&]uh1jhjAhMnhj)ubj)}(hG``priv`` driver private data (sized according to wiphy_new() parameter)h](j)}(h``priv``h]j)}(hjAh]hpriv}(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.hhMhjAubj6)}(hhh]h)}(h>driver private data (sized according to wiphy_new() parameter)h]h>driver private data (sized according to wiphy_new() parameter)}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjAubah}(h]h ]h"]h$]h&]uh1j5hjAubeh}(h]h ]h"]h$]h&]uh1jhjAhMhj)ubeh}(h]h ]h"]h$]h&]uh1jhjX)ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wiphy_priv (C function) c.wiphy_privhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(h'void * wiphy_priv (struct wiphy *wiphy)h]jo)}(h%void *wiphy_priv(struct wiphy *wiphy)h](j`)}(hvoidh]hvoid}(hjAhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjAhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hj BhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAhhhj BhMubj)}(hjh]h*}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAhhhj BhMubj)}(h wiphy_privh]j)}(h wiphy_privh]h wiphy_priv}(hj,BhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(Bubah}(h]h ](jjeh"]h$]h&]jjuh1jhjAhhhj BhMubj)}(h(struct wiphy *wiphy)h]j)}(hstruct wiphy *wiphyh](ju)}(hjnh]hstruct}(hjHBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjDBubj)}(h h]h }(hjUBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDBubh)}(hhh]j)}(hwiphyh]hwiphy}(hjfBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjcBubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjhBmodnameN classnameNjS jV )}jY ]j)}jj.Bsb c.wiphy_privasbuh1hhjDBubj)}(h h]h }(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDBubj)}(hjh]h*}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDBubj)}(hwiphyh]hwiphy}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDBubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj@Bubah}(h]h ]h"]h$]h&]jjuh1jhjAhhhj BhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjAhhhj BhMubah}(h]jAah ](jjeh"]h$]h&]jj)jhuh1jhhj BhMhjAhhubj)}(hhh]h)}(hreturn priv from wiphyh]hreturn priv from wiphy}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjBhhubah}(h]h ]h"]h$]h&]uh1jhjAhhhj BhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjBjjBjjjuh1jchhhhhNhNubj)}(ht**Parameters** ``struct wiphy *wiphy`` the wiphy whose priv pointer to return **Return** The priv of **wiphy**.h](h)}(h**Parameters**h]j)}(hjBh]h Parameters}(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.hhMhjBubj)}(hhh]j)}(h?``struct wiphy *wiphy`` the wiphy whose priv pointer to return h](j)}(h``struct wiphy *wiphy``h]j)}(hj Ch]hstruct wiphy *wiphy}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Cubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjCubj6)}(hhh]h)}(h&the wiphy whose priv pointer to returnh]h&the wiphy whose priv pointer to return}(hj%ChhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!ChMhj"Cubah}(h]h ]h"]h$]h&]uh1j5hjCubeh}(h]h ]h"]h$]h&]uh1jhj!ChMhjCubah}(h]h ]h"]h$]h&]uh1jhjBubh)}(h **Return**h]j)}(hjGCh]hReturn}(hjIChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjECubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjBubh)}(hThe priv of **wiphy**.h](h The priv of }(hj]ChhhNhNubj)}(h **wiphy**h]hwiphy}(hjeChhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]Cubh.}(hj]ChhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjBubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_priv_to_wiphy (C function)c.priv_to_wiphyhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(h)struct wiphy * priv_to_wiphy (void *priv)h]jo)}(h'struct wiphy *priv_to_wiphy(void *priv)h](ju)}(hjnh]hstruct}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjChhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM&ubj)}(h h]h }(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjChhhjChM&ubh)}(hhh]j)}(hwiphyh]hwiphy}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjCmodnameN classnameNjS jV )}jY ]j)}j priv_to_wiphysbc.priv_to_wiphyasbuh1hhjChhhjChM&ubj)}(h h]h }(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjChhhjChM&ubj)}(hjh]h*}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjChhhjChM&ubj)}(h priv_to_wiphyh]j)}(hjCh]h priv_to_wiphy}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjCubah}(h]h ](jjeh"]h$]h&]jjuh1jhjChhhjChM&ubj)}(h (void *priv)h]j)}(h void *privh](j`)}(hvoidh]hvoid}(hjDhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjDubj)}(h h]h }(hj&DhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDubj)}(hjh]h*}(hj4DhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDubj)}(hprivh]hpriv}(hjADhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjDubah}(h]h ]h"]h$]h&]jjuh1jhjChhhjChM&ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjChhhjChM&ubah}(h]jCah ](jjeh"]h$]h&]jj)jhuh1jhhjChM&hjChhubj)}(hhh]h)}(h$return the wiphy containing the privh]h$return the wiphy containing the priv}(hjkDhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM&hjhDhhubah}(h]h ]h"]h$]h&]uh1jhjChhhjChM&ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjDjjDjjjuh1jchhhhhNhNubj)}(hp**Parameters** ``void *priv`` a pointer previously returned by wiphy_priv **Return** The wiphy of **priv**.h](h)}(h**Parameters**h]j)}(hjDh]h Parameters}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM*hjDubj)}(hhh]j)}(h;``void *priv`` a pointer previously returned by wiphy_priv h](j)}(h``void *priv``h]j)}(hjDh]h void *priv}(hjDhhhNhNubah}(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.hhM(hjDubj6)}(hhh]h)}(h+a pointer previously returned by wiphy_privh]h+a pointer previously returned by wiphy_priv}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDhM(hjDubah}(h]h ]h"]h$]h&]uh1j5hjDubeh}(h]h ]h"]h$]h&]uh1jhjDhM(hjDubah}(h]h ]h"]h$]h&]uh1jhjDubh)}(h **Return**h]j)}(hjDh]hReturn}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM*hjDubh)}(hThe wiphy of **priv**.h](h The wiphy of }(hjDhhhNhNubj)}(h**priv**h]hpriv}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDubh.}(hjDhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM)hjDubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_set_wiphy_dev (C function)c.set_wiphy_devhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hEhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hj:Ehhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM2ubj)}(h h]h }(hjMEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:EhhhjLEhM2ubj)}(h set_wiphy_devh]j)}(h set_wiphy_devh]h set_wiphy_dev}(hj_EhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[Eubah}(h]h ](jjeh"]h$]h&]jjuh1jhj:EhhhjLEhM2ubj)}(h)(struct wiphy *wiphy, struct device *dev)h](j)}(hstruct wiphy *wiphyh](ju)}(hjnh]hstruct}(hj{EhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjwEubj)}(h h]h }(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwEubh)}(hhh]j)}(hwiphyh]hwiphy}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjEmodnameN classnameNjS jV )}jY ]j)}jjaEsbc.set_wiphy_devasbuh1hhjwEubj)}(h h]h }(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwEubj)}(hjh]h*}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwEubj)}(hwiphyh]hwiphy}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwEubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjsEubj)}(hstruct device *devh](ju)}(hjnh]hstruct}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjEubj)}(h h]h }(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjEubh)}(hhh]j)}(hdeviceh]hdevice}(hj FhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj FmodnameN classnameNjS jV )}jY ]jEc.set_wiphy_devasbuh1hhjEubj)}(h h]h }(hj)FhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjEubj)}(hjh]h*}(hj7FhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjEubj)}(hdevh]hdev}(hjDFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjEubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjsEubeh}(h]h ]h"]h$]h&]jjuh1jhj:EhhhjLEhM2ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj6EhhhjLEhM2ubah}(h]j1Eah ](jjeh"]h$]h&]jj)jhuh1jhhjLEhM2hj3Ehhubj)}(hhh]h)}(hset device pointer for wiphyh]hset device pointer for wiphy}(hjnFhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM2hjkFhhubah}(h]h ]h"]h$]h&]uh1jhj3EhhhjLEhM2ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjFjjFjjjuh1jchhhhhNhNubj)}(h}**Parameters** ``struct wiphy *wiphy`` The wiphy whose device to bind ``struct device *dev`` The device to parent it toh](h)}(h**Parameters**h]j)}(hjFh]h Parameters}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM6hjFubj)}(hhh](j)}(h7``struct wiphy *wiphy`` The wiphy whose device to bind h](j)}(h``struct wiphy *wiphy``h]j)}(hjFh]hstruct wiphy *wiphy}(hjFhhhNhNubah}(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.hhM4hjFubj6)}(hhh]h)}(hThe wiphy whose device to bindh]hThe wiphy whose device to bind}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFhM4hjFubah}(h]h ]h"]h$]h&]uh1j5hjFubeh}(h]h ]h"]h$]h&]uh1jhjFhM4hjFubj)}(h1``struct device *dev`` The device to parent it toh](j)}(h``struct device *dev``h]j)}(hjFh]hstruct device *dev}(hjFhhhNhNubah}(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.hhM6hjFubj6)}(hhh]h)}(hThe device to parent it toh]hThe device to parent it to}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM5hjFubah}(h]h ]h"]h$]h&]uh1j5hjFubeh}(h]h ]h"]h$]h&]uh1jhjFhM6hjFubeh}(h]h ]h"]h$]h&]uh1jhjFubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wiphy_dev (C function) c.wiphy_devhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(h/struct device * wiphy_dev (struct wiphy *wiphy)h]jo)}(h-struct device *wiphy_dev(struct wiphy *wiphy)h](ju)}(hjnh]hstruct}(hjBGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj>Ghhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM=ubj)}(h h]h }(hjPGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>GhhhjOGhM=ubh)}(hhh]j)}(hdeviceh]hdevice}(hjaGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^Gubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjcGmodnameN classnameNjS jV )}jY ]j)}j wiphy_devsb c.wiphy_devasbuh1hhj>GhhhjOGhM=ubj)}(h h]h }(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>GhhhjOGhM=ubj)}(hjh]h*}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>GhhhjOGhM=ubj)}(h wiphy_devh]j)}(hjGh]h wiphy_dev}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGubah}(h]h ](jjeh"]h$]h&]jjuh1jhj>GhhhjOGhM=ubj)}(h(struct wiphy *wiphy)h]j)}(hstruct wiphy *wiphyh](ju)}(hjnh]hstruct}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjGubj)}(h h]h }(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGubh)}(hhh]j)}(hwiphyh]hwiphy}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjGmodnameN classnameNjS jV )}jY ]j}G c.wiphy_devasbuh1hhjGubj)}(h h]h }(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGubj)}(hjh]h*}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGubj)}(hwiphyh]hwiphy}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjGubah}(h]h ]h"]h$]h&]jjuh1jhj>GhhhjOGhM=ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj:GhhhjOGhM=ubah}(h]j5Gah ](jjeh"]h$]h&]jj)jhuh1jhhjOGhM=hj7Ghhubj)}(hhh]h)}(hget wiphy dev pointerh]hget wiphy dev pointer}(hj=HhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM=hj:Hhhubah}(h]h ]h"]h$]h&]uh1jhj7GhhhjOGhM=ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjUHjjUHjjjuh1jchhhhhNhNubj)}(hu**Parameters** ``struct wiphy *wiphy`` The wiphy whose device struct to look up **Return** The dev of **wiphy**.h](h)}(h**Parameters**h]j)}(hj_Hh]h Parameters}(hjaHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]Hubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMAhjYHubj)}(hhh]j)}(hA``struct wiphy *wiphy`` The wiphy whose device struct to look up h](j)}(h``struct wiphy *wiphy``h]j)}(hj~Hh]hstruct wiphy *wiphy}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|Hubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM?hjxHubj6)}(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&]uh1hhjHhM?hjHubah}(h]h ]h"]h$]h&]uh1j5hjxHubeh}(h]h ]h"]h$]h&]uh1jhjHhM?hjuHubah}(h]h ]h"]h$]h&]uh1jhjYHubh)}(h **Return**h]j)}(hjHh]hReturn}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMAhjYHubh)}(hThe dev of **wiphy**.h](h The dev of }(hjHhhhNhNubj)}(h **wiphy**h]hwiphy}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHubh.}(hjHhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM@hjYHubeh}(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}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj Ihhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMHubj)}(h h]h }(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj IhhhjIhMHubj`)}(hcharh]hchar}(hj-IhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hj IhhhjIhMHubj)}(h h]h }(hj;IhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj IhhhjIhMHubj)}(hjh]h*}(hjIIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj IhhhjIhMHubj)}(h wiphy_nameh]j)}(h wiphy_nameh]h wiphy_name}(hjZIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjVIubah}(h]h ](jjeh"]h$]h&]jjuh1jhj IhhhjIhMHubj)}(h(const struct wiphy *wiphy)h]j)}(hconst struct wiphy *wiphyh](ju)}(hjIh]hconst}(hjvIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjrIubj)}(h h]h }(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjrIubju)}(hjnh]hstruct}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjrIubj)}(h h]h }(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjrIubh)}(hhh]j)}(hwiphyh]hwiphy}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjImodnameN classnameNjS jV )}jY ]j)}jj\Isb c.wiphy_nameasbuh1hhjrIubj)}(h h]h }(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjrIubj)}(hjh]h*}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjrIubj)}(hwiphyh]hwiphy}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjrIubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjnIubah}(h]h ]h"]h$]h&]jjuh1jhj IhhhjIhMHubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjIhhhjIhMHubah}(h]jIah ](jjeh"]h$]h&]jj)jhuh1jhhjIhMHhjIhhubj)}(hhh]h)}(hget wiphy nameh]hget wiphy name}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMHhjJhhubah}(h]h ]h"]h$]h&]uh1jhjIhhhjIhMHubeh}(h]h ](j$functioneh"]h$]h&]jj$jj,Jjj,Jjjjuh1jchhhhhNhNubj)}(hr**Parameters** ``const struct wiphy *wiphy`` The wiphy whose name to return **Return** The name of **wiphy**.h](h)}(h**Parameters**h]j)}(hj6Jh]h Parameters}(hj8JhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4Jubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMLhj0Jubj)}(hhh]j)}(h=``const struct wiphy *wiphy`` The wiphy whose name to return h](j)}(h``const struct wiphy *wiphy``h]j)}(hjUJh]hconst struct wiphy *wiphy}(hjWJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSJubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMJhjOJubj6)}(hhh]h)}(hThe wiphy whose name to returnh]hThe wiphy whose name to return}(hjnJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjJhMJhjkJubah}(h]h ]h"]h$]h&]uh1j5hjOJubeh}(h]h ]h"]h$]h&]uh1jhjjJhMJhjLJubah}(h]h ]h"]h$]h&]uh1jhj0Jubh)}(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.hhMLhj0Jubh)}(hThe name of **wiphy**.h](h The name of }(hjJhhhNhNubj)}(h **wiphy**h]hwiphy}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJubh.}(hjJhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMKhj0Jubeh}(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)}(hjnh]hstruct}(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjJhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMdubj)}(h h]h }(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJhhhjJhMdubh)}(hhh]j)}(hwiphyh]hwiphy}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjKmodnameN classnameNjS jV )}jY ]j)}j wiphy_newsb c.wiphy_newasbuh1hhjJhhhjJhMdubj)}(h h]h }(hj'KhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJhhhjJhMdubj)}(hjh]h*}(hj5KhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJhhhjJhMdubj)}(h wiphy_newh]j)}(hj$Kh]h wiphy_new}(hjFKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBKubah}(h]h ](jjeh"]h$]h&]jjuh1jhjJhhhjJhMdubj)}(h1(const struct cfg80211_ops *ops, int sizeof_priv)h](j)}(hconst struct cfg80211_ops *opsh](ju)}(hjIh]hconst}(hjaKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj]Kubj)}(h h]h }(hjnKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]Kubju)}(hjnh]hstruct}(hj|KhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj]Kubj)}(h h]h }(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]Kubh)}(hhh]j)}(h cfg80211_opsh]h cfg80211_ops}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjKmodnameN classnameNjS jV )}jY ]j"K c.wiphy_newasbuh1hhj]Kubj)}(h h]h }(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]Kubj)}(hjh]h*}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]Kubj)}(hopsh]hops}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]Kubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjYKubj)}(hint sizeof_privh](j`)}(hinth]hint}(hjKhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjKubj)}(h h]h }(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubj)}(h sizeof_privh]h sizeof_priv}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjYKubeh}(h]h ]h"]h$]h&]jjuh1jhjJhhhjJhMdubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjJhhhjJhMdubah}(h]jJah ](jjeh"]h$]h&]jj)jhuh1jhhjJhMdhjJhhubj)}(hhh]h)}(h(create a new wiphy for use with cfg80211h]h(create a new wiphy for use with cfg80211}(hj2LhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMdhj/Lhhubah}(h]h ]h"]h$]h&]uh1jhjJhhhjJhMdubeh}(h]h ](j$functioneh"]h$]h&]jj$jjJLjjJLjjjuh1jchhhhhNhNubj)}(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)}(hjTLh]h Parameters}(hjVLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRLubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhhjNLubj)}(hhh](j)}(hP``const struct cfg80211_ops *ops`` The configuration operations for this device h](j)}(h"``const struct cfg80211_ops *ops``h]j)}(hjsLh]hconst struct cfg80211_ops *ops}(hjuLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqLubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMfhjmLubj6)}(hhh]h)}(h,The configuration operations for this deviceh]h,The configuration operations for this device}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhMfhjLubah}(h]h ]h"]h$]h&]uh1j5hjmLubeh}(h]h ]h"]h$]h&]uh1jhjLhMfhjjLubj)}(h=``int sizeof_priv`` The size of the private area to allocate h](j)}(h``int sizeof_priv``h]j)}(hjLh]hint sizeof_priv}(hjLhhhNhNubah}(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.hhMghjLubj6)}(hhh]h)}(h(The size of the private area to allocateh]h(The size of the private area to allocate}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhMghjLubah}(h]h ]h"]h$]h&]uh1j5hjLubeh}(h]h ]h"]h$]h&]uh1jhjLhMghjjLubeh}(h]h ]h"]h$]h&]uh1jhjNLubh)}(h**Description**h]j)}(hjLh]h Description}(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.hhMihjNLubh)}(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}(hjMhhhNhNubah}(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.hhMhhjNLubh)}(h **Return**h]j)}(hj Mh]hReturn}(hj"MhhhNhNubah}(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.hhMkhjNLubh)}(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.}(hj6MhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMlhjNLubeh}(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}(hjeMhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjaMhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMvubj)}(h h]h }(hjtMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaMhhhjsMhMvubj)}(hwiphy_registerh]j)}(hwiphy_registerh]hwiphy_register}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjMubah}(h]h ](jjeh"]h$]h&]jjuh1jhjaMhhhjsMhMvubj)}(h(struct wiphy *wiphy)h]j)}(hstruct wiphy *wiphyh](ju)}(hjnh]hstruct}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjMubj)}(h h]h }(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjMubh)}(hhh]j)}(hwiphyh]hwiphy}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjMmodnameN classnameNjS jV )}jY ]j)}jjMsbc.wiphy_registerasbuh1hhjMubj)}(h h]h }(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjMubj)}(hjh]h*}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjMubj)}(hwiphyh]hwiphy}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjMubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjMubah}(h]h ]h"]h$]h&]jjuh1jhjaMhhhjsMhMvubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj]MhhhjsMhMvubah}(h]jXMah ](jjeh"]h$]h&]jj)jhuh1jhhjsMhMvhjZMhhubj)}(hhh]h)}(hregister a wiphy with cfg80211h]hregister a wiphy with cfg80211}(hj%NhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMvhj"Nhhubah}(h]h ]h"]h$]h&]uh1jhjZMhhhjsMhMvubeh}(h]h ](j$functioneh"]h$]h&]jj$jj=Njj=Njjjuh1jchhhhhNhNubj)}(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)}(hjGNh]h Parameters}(hjINhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjENubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMzhjANubj)}(hhh]j)}(h/``struct wiphy *wiphy`` The wiphy to register. h](j)}(h``struct wiphy *wiphy``h]j)}(hjfNh]hstruct wiphy *wiphy}(hjhNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdNubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMxhj`Nubj6)}(hhh]h)}(hThe wiphy to register.h]hThe wiphy to register.}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{NhMxhj|Nubah}(h]h ]h"]h$]h&]uh1j5hj`Nubeh}(h]h ]h"]h$]h&]uh1jhj{NhMxhj]Nubah}(h]h ]h"]h$]h&]uh1jhjANubh)}(h **Return**h]j)}(hjNh]hReturn}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMzhjANubh)}(h4A non-negative wiphy index or a negative error code.h]h4A non-negative wiphy index or a negative error code.}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMzhjANubeh}(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}(hjNhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjNhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNhhhjNhMubj)}(hwiphy_unregisterh]j)}(hwiphy_unregisterh]hwiphy_unregister}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubah}(h]h ](jjeh"]h$]h&]jjuh1jhjNhhhjNhMubj)}(h(struct wiphy *wiphy)h]j)}(hstruct wiphy *wiphyh](ju)}(hjnh]hstruct}(hj#OhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjOubj)}(h h]h }(hj0OhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubh)}(hhh]j)}(hwiphyh]hwiphy}(hjAOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>Oubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjCOmodnameN classnameNjS jV )}jY ]j)}jj Osbc.wiphy_unregisterasbuh1hhjOubj)}(h h]h }(hjaOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubj)}(hjh]h*}(hjoOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubj)}(hwiphyh]hwiphy}(hj|OhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjOubah}(h]h ]h"]h$]h&]jjuh1jhjNhhhjNhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjNhhhjNhMubah}(h]jNah ](jjeh"]h$]h&]jj)jhuh1jhhjNhMhjNhhubj)}(hhh]h)}(h deregister a wiphy from cfg80211h]h deregister a wiphy from cfg80211}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjOhhubah}(h]h ]h"]h$]h&]uh1jhjNhhhjNhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjOjjOjjjuh1jchhhhhNhNubj)}(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)}(hjOh]h Parameters}(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.hhMhjOubj)}(hhh]j)}(h1``struct wiphy *wiphy`` The wiphy to unregister. h](j)}(h``struct wiphy *wiphy``h]j)}(hjOh]hstruct wiphy *wiphy}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjOubj6)}(hhh]h)}(hThe wiphy to unregister.h]hThe wiphy to unregister.}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjOhMhjOubah}(h]h ]h"]h$]h&]uh1j5hjOubeh}(h]h ]h"]h$]h&]uh1jhjOhMhjOubah}(h]h ]h"]h$]h&]uh1jhjOubh)}(h**Description**h]j)}(hj"Ph]h Description}(hj$PhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj Pubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjOubh)}(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.}(hj8PhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjOubeh}(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}(hjgPhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjcPhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjvPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjcPhhhjuPhMubj)}(h wiphy_freeh]j)}(h wiphy_freeh]h wiphy_free}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjPubah}(h]h ](jjeh"]h$]h&]jjuh1jhjcPhhhjuPhMubj)}(h(struct wiphy *wiphy)h]j)}(hstruct wiphy *wiphyh](ju)}(hjnh]hstruct}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjPubj)}(h h]h }(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjPubh)}(hhh]j)}(hwiphyh]hwiphy}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjPmodnameN classnameNjS jV )}jY ]j)}jjPsb c.wiphy_freeasbuh1hhjPubj)}(h h]h }(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjPubj)}(hjh]h*}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjPubj)}(hwiphyh]hwiphy}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjPubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjPubah}(h]h ]h"]h$]h&]jjuh1jhjcPhhhjuPhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj_PhhhjuPhMubah}(h]jZPah ](jjeh"]h$]h&]jj)jhuh1jhhjuPhMhj\Phhubj)}(hhh]h)}(h free wiphyh]h free wiphy}(hj'QhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj$Qhhubah}(h]h ]h"]h$]h&]uh1jhj\PhhhjuPhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jj?Qjj?Qjjjuh1jchhhhhNhNubj)}(h;**Parameters** ``struct wiphy *wiphy`` The wiphy to freeh](h)}(h**Parameters**h]j)}(hjIQh]h Parameters}(hjKQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjGQubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjCQubj)}(hhh]j)}(h)``struct wiphy *wiphy`` The wiphy to freeh](j)}(h``struct wiphy *wiphy``h]j)}(hjhQh]hstruct wiphy *wiphy}(hjjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfQubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjbQubj6)}(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.hhMhj~Qubah}(h]h ]h"]h$]h&]uh1j5hjbQubeh}(h]h ]h"]h$]h&]uh1jhj}QhMhj_Qubah}(h]h ]h"]h$]h&]uh1jhjCQubeh}(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)}(hjnh]hstruct}(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjQhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQhhhjQhMubj)}(h wireless_devh]j)}(hjQh]h wireless_dev}(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQubah}(h]h ](jjeh"]h$]h&]jjuh1jhjQhhhjQhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjQhhhjQhMubah}(h]jQah ](jjeh"]h$]h&]jj)jhuh1jhhjQhMhjQhhubj)}(hhh]h)}(hwireless device stateh]hwireless device state}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjRhhubah}(h]h ]h"]h$]h&]uh1jhjQhhhjQhMubeh}(h]h ](j$structeh"]h$]h&]jj$jjRjjRjjjuh1jchhhhhNhNubj)}(hX**Definition**:: struct wireless_dev { struct wiphy *wiphy; enum nl80211_iftype iftype; struct list_head list; struct net_device *netdev; u32 identifier; struct list_head mgmt_registrations; u8 mgmt_registrations_need_update:1; bool use_4addr, is_running, registered, registering; u8 address[ETH_ALEN] ; struct cfg80211_conn *conn; struct cfg80211_cached_keys *connect_keys; enum ieee80211_bss_type conn_bss_type; u32 conn_owner_nlportid; struct work_struct disconnect_wk; u8 disconnect_bssid[ETH_ALEN]; struct list_head event_list; spinlock_t event_lock; u8 connected:1; bool ps; int ps_timeout; u32 ap_unexpected_nlportid; u32 owner_nlportid; bool nl_owner_dead; #ifdef CONFIG_CFG80211_WEXT; struct { struct cfg80211_ibss_params ibss; struct cfg80211_connect_params connect; struct cfg80211_cached_keys *keys; const u8 *ie; size_t ie_len; u8 bssid[ETH_ALEN]; u8 prev_bssid[ETH_ALEN]; u8 ssid[IEEE80211_MAX_SSID_LEN]; s8 default_key, default_mgmt_key; bool prev_bssid_valid; } wext; #endif; struct wiphy_work cqm_rssi_work; struct cfg80211_cqm_config *cqm_config; struct list_head pmsr_list; spinlock_t pmsr_lock; struct work_struct pmsr_free_wk; unsigned long unprot_beacon_reported; union { struct { u8 connected_addr[ETH_ALEN] ; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } client; struct { int beacon_interval; struct cfg80211_chan_def preset_chandef; struct cfg80211_chan_def chandef; u8 id[IEEE80211_MAX_MESH_ID_LEN]; u8 id_len, id_up_len; } mesh; struct { struct cfg80211_chan_def preset_chandef; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } ap; struct { struct cfg80211_internal_bss *current_bss; struct cfg80211_chan_def chandef; int beacon_interval; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } ibss; struct { struct cfg80211_chan_def chandef; } ocb; struct { u8 cluster_id[ETH_ALEN] ; } nan; } u; struct { u8 addr[ETH_ALEN] ; union { struct { unsigned int beacon_interval; struct cfg80211_chan_def chandef; } ap; struct { struct cfg80211_internal_bss *current_bss; } client; }; bool cac_started; unsigned long cac_start_time; unsigned int cac_time_ms; } links[IEEE80211_MLD_MAX_NUM_LINKS]; u16 valid_links; u32 radio_mask; }; **Members** ``wiphy`` pointer to hardware description ``iftype`` interface type ``list`` (private) Used to collect the interfaces ``netdev`` (private) Used to reference back to the netdev, may be ``NULL`` ``identifier`` (private) Identifier used in nl80211 to identify this wireless device if it has no netdev ``mgmt_registrations`` list of registrations for management frames ``mgmt_registrations_need_update`` mgmt registrations were updated, need to propagate the update to the driver ``use_4addr`` indicates 4addr mode is used on this interface, must be set by driver (if supported) on add_interface BEFORE registering the netdev and may otherwise be used by driver read-only, will be update by cfg80211 on change_interface ``is_running`` true if this is a non-netdev device that has been started, e.g. the P2P Device. ``registered`` is this wdev already registered with cfg80211 ``registering`` indicates we're doing registration under wiphy lock for the notifier ``address`` The address for this device, valid only if **netdev** is ``NULL`` ``conn`` (private) cfg80211 software SME connection state machine data ``connect_keys`` (private) keys to set after connection is established ``conn_bss_type`` connecting/connected BSS type ``conn_owner_nlportid`` (private) connection owner socket port ID ``disconnect_wk`` (private) auto-disconnect work ``disconnect_bssid`` (private) the BSSID to use for auto-disconnect ``event_list`` (private) list for internal event processing ``event_lock`` (private) lock for event list ``connected`` indicates if connected or not (STA mode) ``ps`` powersave mode is enabled ``ps_timeout`` dynamic powersave timeout ``ap_unexpected_nlportid`` (private) netlink port ID of application registered for unexpected class 3 frames (AP mode) ``owner_nlportid`` (private) owner socket port ID ``nl_owner_dead`` (private) owner socket went away ``wext`` (private) Used by the internal wireless extensions compat code ``wext.ibss`` (private) IBSS data part of wext handling ``wext.connect`` (private) connection handling data ``wext.keys`` (private) (WEP) key data ``wext.ie`` (private) extra elements for association ``wext.ie_len`` (private) length of extra elements ``wext.bssid`` (private) selected network BSSID ``wext.prev_bssid`` (private) previous BSSID for reassociation ``wext.ssid`` (private) selected network SSID ``wext.default_key`` (private) selected default key index ``wext.default_mgmt_key`` (private) selected default management key index ``wext.prev_bssid_valid`` (private) previous BSSID validity ``cqm_rssi_work`` (private) CQM RSSI reporting work ``cqm_config`` (private) nl80211 RSSI monitor state ``pmsr_list`` (private) peer measurement requests ``pmsr_lock`` (private) peer measurements requests/results lock ``pmsr_free_wk`` (private) peer measurements cleanup work ``unprot_beacon_reported`` (private) timestamp of last unprotected beacon report ``u`` union containing data specific to **iftype** ``links`` array of ``IEEE80211_MLD_MAX_NUM_LINKS`` elements containing **addr** **ap** and **client** for each link ``{unnamed_union}`` anonymous ``links.cac_started`` true if DFS channel availability check has been started ``links.cac_start_time`` timestamp (jiffies) when the dfs state was entered. ``links.cac_time_ms`` CAC time in ms ``valid_links`` bitmap describing what elements of **links** are valid ``radio_mask`` Bitmask of radios that this interface is allowed to operate on.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj(RhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$Rubh:}(hj$RhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj Rubj)}(hX struct wireless_dev { struct wiphy *wiphy; enum nl80211_iftype iftype; struct list_head list; struct net_device *netdev; u32 identifier; struct list_head mgmt_registrations; u8 mgmt_registrations_need_update:1; bool use_4addr, is_running, registered, registering; u8 address[ETH_ALEN] ; struct cfg80211_conn *conn; struct cfg80211_cached_keys *connect_keys; enum ieee80211_bss_type conn_bss_type; u32 conn_owner_nlportid; struct work_struct disconnect_wk; u8 disconnect_bssid[ETH_ALEN]; struct list_head event_list; spinlock_t event_lock; u8 connected:1; bool ps; int ps_timeout; u32 ap_unexpected_nlportid; u32 owner_nlportid; bool nl_owner_dead; #ifdef CONFIG_CFG80211_WEXT; struct { struct cfg80211_ibss_params ibss; struct cfg80211_connect_params connect; struct cfg80211_cached_keys *keys; const u8 *ie; size_t ie_len; u8 bssid[ETH_ALEN]; u8 prev_bssid[ETH_ALEN]; u8 ssid[IEEE80211_MAX_SSID_LEN]; s8 default_key, default_mgmt_key; bool prev_bssid_valid; } wext; #endif; struct wiphy_work cqm_rssi_work; struct cfg80211_cqm_config *cqm_config; struct list_head pmsr_list; spinlock_t pmsr_lock; struct work_struct pmsr_free_wk; unsigned long unprot_beacon_reported; union { struct { u8 connected_addr[ETH_ALEN] ; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } client; struct { int beacon_interval; struct cfg80211_chan_def preset_chandef; struct cfg80211_chan_def chandef; u8 id[IEEE80211_MAX_MESH_ID_LEN]; u8 id_len, id_up_len; } mesh; struct { struct cfg80211_chan_def preset_chandef; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } ap; struct { struct cfg80211_internal_bss *current_bss; struct cfg80211_chan_def chandef; int beacon_interval; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } ibss; struct { struct cfg80211_chan_def chandef; } ocb; struct { u8 cluster_id[ETH_ALEN] ; } nan; } u; struct { u8 addr[ETH_ALEN] ; union { struct { unsigned int beacon_interval; struct cfg80211_chan_def chandef; } ap; struct { struct cfg80211_internal_bss *current_bss; } client; }; bool cac_started; unsigned long cac_start_time; unsigned int cac_time_ms; } links[IEEE80211_MLD_MAX_NUM_LINKS]; u16 valid_links; u32 radio_mask; };h]hX struct wireless_dev { struct wiphy *wiphy; enum nl80211_iftype iftype; struct list_head list; struct net_device *netdev; u32 identifier; struct list_head mgmt_registrations; u8 mgmt_registrations_need_update:1; bool use_4addr, is_running, registered, registering; u8 address[ETH_ALEN] ; struct cfg80211_conn *conn; struct cfg80211_cached_keys *connect_keys; enum ieee80211_bss_type conn_bss_type; u32 conn_owner_nlportid; struct work_struct disconnect_wk; u8 disconnect_bssid[ETH_ALEN]; struct list_head event_list; spinlock_t event_lock; u8 connected:1; bool ps; int ps_timeout; u32 ap_unexpected_nlportid; u32 owner_nlportid; bool nl_owner_dead; #ifdef CONFIG_CFG80211_WEXT; struct { struct cfg80211_ibss_params ibss; struct cfg80211_connect_params connect; struct cfg80211_cached_keys *keys; const u8 *ie; size_t ie_len; u8 bssid[ETH_ALEN]; u8 prev_bssid[ETH_ALEN]; u8 ssid[IEEE80211_MAX_SSID_LEN]; s8 default_key, default_mgmt_key; bool prev_bssid_valid; } wext; #endif; struct wiphy_work cqm_rssi_work; struct cfg80211_cqm_config *cqm_config; struct list_head pmsr_list; spinlock_t pmsr_lock; struct work_struct pmsr_free_wk; unsigned long unprot_beacon_reported; union { struct { u8 connected_addr[ETH_ALEN] ; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } client; struct { int beacon_interval; struct cfg80211_chan_def preset_chandef; struct cfg80211_chan_def chandef; u8 id[IEEE80211_MAX_MESH_ID_LEN]; u8 id_len, id_up_len; } mesh; struct { struct cfg80211_chan_def preset_chandef; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } ap; struct { struct cfg80211_internal_bss *current_bss; struct cfg80211_chan_def chandef; int beacon_interval; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } ibss; struct { struct cfg80211_chan_def chandef; } ocb; struct { u8 cluster_id[ETH_ALEN] ; } nan; } u; struct { u8 addr[ETH_ALEN] ; union { struct { unsigned int beacon_interval; struct cfg80211_chan_def chandef; } ap; struct { struct cfg80211_internal_bss *current_bss; } client; }; bool cac_started; unsigned long cac_start_time; unsigned int cac_time_ms; } links[IEEE80211_MLD_MAX_NUM_LINKS]; u16 valid_links; u32 radio_mask; };}hjARsbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj Rubh)}(h **Members**h]j)}(hjRRh]hMembers}(hjTRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPRubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM5hj Rubj)}(hhh](j)}(h*``wiphy`` pointer to hardware description h](j)}(h ``wiphy``h]j)}(hjqRh]hwiphy}(hjsRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoRubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjkRubj6)}(hhh]h)}(hpointer to hardware descriptionh]hpointer to hardware description}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRhMhjRubah}(h]h ]h"]h$]h&]uh1j5hjkRubeh}(h]h ]h"]h$]h&]uh1jhjRhMhjhRubj)}(h``iftype`` interface type h](j)}(h ``iftype``h]j)}(hjRh]hiftype}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjRubj6)}(hhh]h)}(hinterface typeh]hinterface type}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRhMhjRubah}(h]h ]h"]h$]h&]uh1j5hjRubeh}(h]h ]h"]h$]h&]uh1jhjRhMhjhRubj)}(h2``list`` (private) Used to collect the interfaces h](j)}(h``list``h]j)}(hjRh]hlist}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjRubj6)}(hhh]h)}(h((private) Used to collect the interfacesh]h((private) Used to collect the interfaces}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRhMhjRubah}(h]h ]h"]h$]h&]uh1j5hjRubeh}(h]h ]h"]h$]h&]uh1jhjRhMhjhRubj)}(hK``netdev`` (private) Used to reference back to the netdev, may be ``NULL`` h](j)}(h ``netdev``h]j)}(hjSh]hnetdev}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjSubj6)}(hhh]h)}(h?(private) Used to reference back to the netdev, may be ``NULL``h](h7(private) Used to reference back to the netdev, may be }(hj5ShhhNhNubj)}(h``NULL``h]hNULL}(hj=ShhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5Subeh}(h]h ]h"]h$]h&]uh1hhj1ShMhj2Subah}(h]h ]h"]h$]h&]uh1j5hjSubeh}(h]h ]h"]h$]h&]uh1jhj1ShMhjhRubj)}(hi``identifier`` (private) Identifier used in nl80211 to identify this wireless device if it has no netdev h](j)}(h``identifier``h]j)}(hjcSh]h identifier}(hjeShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaSubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj]Subj6)}(hhh]h)}(hY(private) Identifier used in nl80211 to identify this wireless device if it has no netdevh]hY(private) Identifier used in nl80211 to identify this wireless device if it has no netdev}(hj|ShhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjySubah}(h]h ]h"]h$]h&]uh1j5hj]Subeh}(h]h ]h"]h$]h&]uh1jhjxShMhjhRubj)}(hC``mgmt_registrations`` list of registrations for management frames h](j)}(h``mgmt_registrations``h]j)}(hjSh]hmgmt_registrations}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjSubj6)}(hhh]h)}(h+list of registrations for management framesh]h+list of registrations for management frames}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShMhjSubah}(h]h ]h"]h$]h&]uh1j5hjSubeh}(h]h ]h"]h$]h&]uh1jhjShMhjhRubj)}(ho``mgmt_registrations_need_update`` mgmt registrations were updated, need to propagate the update to the driver h](j)}(h"``mgmt_registrations_need_update``h]j)}(hjSh]hmgmt_registrations_need_update}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjSubj6)}(hhh]h)}(hKmgmt registrations were updated, need to propagate the update to the driverh]hKmgmt registrations were updated, need to propagate the update to the driver}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjSubah}(h]h ]h"]h$]h&]uh1j5hjSubeh}(h]h ]h"]h$]h&]uh1jhjShMhjhRubj)}(h``use_4addr`` indicates 4addr mode is used on this interface, must be set by driver (if supported) on add_interface BEFORE registering the netdev and may otherwise be used by driver read-only, will be update by cfg80211 on change_interface h](j)}(h ``use_4addr``h]j)}(hjTh]h use_4addr}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj Tubj6)}(hhh]h)}(hindicates 4addr mode is used on this interface, must be set by driver (if supported) on add_interface BEFORE registering the netdev and may otherwise be used by driver read-only, will be update by cfg80211 on change_interfaceh]hindicates 4addr mode is used on this interface, must be set by driver (if supported) on add_interface BEFORE registering the netdev and may otherwise be used by driver read-only, will be update by cfg80211 on change_interface}(hj)ThhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj&Tubah}(h]h ]h"]h$]h&]uh1j5hj Tubeh}(h]h ]h"]h$]h&]uh1jhj%ThMhjhRubj)}(h_``is_running`` true if this is a non-netdev device that has been started, e.g. the P2P Device. h](j)}(h``is_running``h]j)}(hjJTh]h is_running}(hjLThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHTubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjDTubj6)}(hhh]h)}(hOtrue if this is a non-netdev device that has been started, e.g. the P2P Device.h]hOtrue if this is a non-netdev device that has been started, e.g. the P2P Device.}(hjcThhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj`Tubah}(h]h ]h"]h$]h&]uh1j5hjDTubeh}(h]h ]h"]h$]h&]uh1jhj_ThMhjhRubj)}(h=``registered`` is this wdev already registered with cfg80211 h](j)}(h``registered``h]j)}(hjTh]h registered}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj~Tubj6)}(hhh]h)}(h-is this wdev already registered with cfg80211h]h-is this wdev already registered with cfg80211}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hhjThMhjTubah}(h]h ]h"]h$]h&]uh1j5hj~Tubeh}(h]h ]h"]h$]h&]uh1jhjThMhjhRubj)}(hU``registering`` indicates we're doing registration under wiphy lock for the notifier h](j)}(h``registering``h]j)}(hjTh]h registering}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjTubj6)}(hhh]h)}(hDindicates we're doing registration under wiphy lock for the notifierh]hFindicates we’re doing registration under wiphy lock for the notifier}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjTubah}(h]h ]h"]h$]h&]uh1j5hjTubeh}(h]h ]h"]h$]h&]uh1jhjThMhjhRubj)}(hN``address`` The address for this device, valid only if **netdev** is ``NULL`` h](j)}(h ``address``h]j)}(hjTh]haddress}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjTubj6)}(hhh]h)}(hAThe address for this device, valid only if **netdev** is ``NULL``h](h+The address for this device, valid only if }(hjUhhhNhNubj)}(h **netdev**h]hnetdev}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUubh is }(hjUhhhNhNubj)}(h``NULL``h]hNULL}(hj*UhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubeh}(h]h ]h"]h$]h&]uh1hhj UhMhj Uubah}(h]h ]h"]h$]h&]uh1j5hjTubeh}(h]h ]h"]h$]h&]uh1jhj UhMhjhRubj)}(hG``conn`` (private) cfg80211 software SME connection state machine data h](j)}(h``conn``h]j)}(hjPUh]hconn}(hjRUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNUubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjJUubj6)}(hhh]h)}(h=(private) cfg80211 software SME connection state machine datah]h=(private) cfg80211 software SME connection state machine data}(hjiUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjeUhMhjfUubah}(h]h ]h"]h$]h&]uh1j5hjJUubeh}(h]h ]h"]h$]h&]uh1jhjeUhMhjhRubj)}(hG``connect_keys`` (private) keys to set after connection is established h](j)}(h``connect_keys``h]j)}(hjUh]h connect_keys}(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.hhMhjUubj6)}(hhh]h)}(h5(private) keys to set after connection is establishedh]h5(private) keys to set after connection is established}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUhMhjUubah}(h]h ]h"]h$]h&]uh1j5hjUubeh}(h]h ]h"]h$]h&]uh1jhjUhMhjhRubj)}(h0``conn_bss_type`` connecting/connected BSS type h](j)}(h``conn_bss_type``h]j)}(hjUh]h conn_bss_type}(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.hhMhjUubj6)}(hhh]h)}(hconnecting/connected BSS typeh]hconnecting/connected BSS type}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUhMhjUubah}(h]h ]h"]h$]h&]uh1j5hjUubeh}(h]h ]h"]h$]h&]uh1jhjUhMhjhRubj)}(hB``conn_owner_nlportid`` (private) connection owner socket port ID h](j)}(h``conn_owner_nlportid``h]j)}(hjUh]hconn_owner_nlportid}(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) connection owner socket port IDh]h)(private) connection owner socket port ID}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhM hjVubah}(h]h ]h"]h$]h&]uh1j5hjUubeh}(h]h ]h"]h$]h&]uh1jhjVhM hjhRubj)}(h1``disconnect_wk`` (private) auto-disconnect work h](j)}(h``disconnect_wk``h]j)}(hj4Vh]h disconnect_wk}(hj6VhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2Vubah}(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) auto-disconnect workh]h(private) auto-disconnect work}(hjMVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIVhM hjJVubah}(h]h ]h"]h$]h&]uh1j5hj.Vubeh}(h]h ]h"]h$]h&]uh1jhjIVhM hjhRubj)}(hD``disconnect_bssid`` (private) the BSSID to use for auto-disconnect h](j)}(h``disconnect_bssid``h]j)}(hjmVh]hdisconnect_bssid}(hjoVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkVubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjgVubj6)}(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&]uh1j5hjgVubeh}(h]h ]h"]h$]h&]uh1jhjVhM hjhRubj)}(h<``event_list`` (private) list for internal event processing h](j)}(h``event_list``h]j)}(hjVh]h event_list}(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.hhM hjVubj6)}(hhh]h)}(h,(private) list for internal event processingh]h,(private) list for internal event processing}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhM hjVubah}(h]h ]h"]h$]h&]uh1j5hjVubeh}(h]h ]h"]h$]h&]uh1jhjVhM hjhRubj)}(h-``event_lock`` (private) lock for event list h](j)}(h``event_lock``h]j)}(hjVh]h event_lock}(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.hhM hjVubj6)}(hhh]h)}(h(private) lock for event listh]h(private) lock for event list}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhM hjVubah}(h]h ]h"]h$]h&]uh1j5hjVubeh}(h]h ]h"]h$]h&]uh1jhjVhM hjhRubj)}(h7``connected`` indicates if connected or not (STA mode) h](j)}(h ``connected``h]j)}(hjWh]h connected}(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(indicates if connected or not (STA mode)h]h(indicates if connected or not (STA mode)}(hj1WhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-WhMhj.Wubah}(h]h ]h"]h$]h&]uh1j5hjWubeh}(h]h ]h"]h$]h&]uh1jhj-WhMhjhRubj)}(h!``ps`` powersave mode is enabled h](j)}(h``ps``h]j)}(hjQWh]hps}(hjSWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOWubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjKWubj6)}(hhh]h)}(hpowersave mode is enabledh]hpowersave mode is enabled}(hjjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfWhMhjgWubah}(h]h ]h"]h$]h&]uh1j5hjKWubeh}(h]h ]h"]h$]h&]uh1jhjfWhMhjhRubj)}(h)``ps_timeout`` dynamic powersave timeout h](j)}(h``ps_timeout``h]j)}(hjWh]h ps_timeout}(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)}(hdynamic powersave timeouth]hdynamic powersave timeout}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjWhMhjWubah}(h]h ]h"]h$]h&]uh1j5hjWubeh}(h]h ]h"]h$]h&]uh1jhjWhMhjhRubj)}(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)}(hjWh]hap_unexpected_nlportid}(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) 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)}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjWubah}(h]h ]h"]h$]h&]uh1j5hjWubeh}(h]h ]h"]h$]h&]uh1jhjWhMhjhRubj)}(h2``owner_nlportid`` (private) owner socket port ID h](j)}(h``owner_nlportid``h]j)}(hjWh]howner_nlportid}(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) owner socket port IDh]h(private) owner socket port ID}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhMhjXubah}(h]h ]h"]h$]h&]uh1j5hjWubeh}(h]h ]h"]h$]h&]uh1jhjXhMhjhRubj)}(h3``nl_owner_dead`` (private) owner socket went away h](j)}(h``nl_owner_dead``h]j)}(hj6Xh]h nl_owner_dead}(hj8XhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4Xubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj0Xubj6)}(hhh]h)}(h (private) owner socket went awayh]h (private) owner socket went away}(hjOXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKXhMhjLXubah}(h]h ]h"]h$]h&]uh1j5hj0Xubeh}(h]h ]h"]h$]h&]uh1jhjKXhMhjhRubj)}(hH``wext`` (private) Used by the internal wireless extensions compat code h](j)}(h``wext``h]j)}(hjoXh]hwext}(hjqXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmXubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjiXubj6)}(hhh]h)}(h>(private) Used by the internal wireless extensions compat codeh]h>(private) Used by the internal wireless extensions compat code}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhMhjXubah}(h]h ]h"]h$]h&]uh1j5hjiXubeh}(h]h ]h"]h$]h&]uh1jhjXhMhjhRubj)}(h8``wext.ibss`` (private) IBSS data part of wext handling h](j)}(h ``wext.ibss``h]j)}(hjXh]h wext.ibss}(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.hhMhjXubj6)}(hhh]h)}(h)(private) IBSS data part of wext handlingh]h)(private) IBSS data part of wext handling}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhMhjXubah}(h]h ]h"]h$]h&]uh1j5hjXubeh}(h]h ]h"]h$]h&]uh1jhjXhMhjhRubj)}(h4``wext.connect`` (private) connection handling data h](j)}(h``wext.connect``h]j)}(hjXh]h wext.connect}(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.hhMhjXubj6)}(hhh]h)}(h"(private) connection handling datah]h"(private) connection handling data}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhMhjXubah}(h]h ]h"]h$]h&]uh1j5hjXubeh}(h]h ]h"]h$]h&]uh1jhjXhMhjhRubj)}(h'``wext.keys`` (private) (WEP) key data h](j)}(h ``wext.keys``h]j)}(hjYh]h wext.keys}(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) (WEP) key datah]h(private) (WEP) key data}(hj3YhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/YhMhj0Yubah}(h]h ]h"]h$]h&]uh1j5hjYubeh}(h]h ]h"]h$]h&]uh1jhj/YhMhjhRubj)}(h5``wext.ie`` (private) extra elements for association h](j)}(h ``wext.ie``h]j)}(hjSYh]hwext.ie}(hjUYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQYubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjMYubj6)}(hhh]h)}(h((private) extra elements for associationh]h((private) extra elements for association}(hjlYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhYhMhjiYubah}(h]h ]h"]h$]h&]uh1j5hjMYubeh}(h]h ]h"]h$]h&]uh1jhjhYhMhjhRubj)}(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&]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) length of extra elementsh]h"(private) length of extra elements}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYhMhjYubah}(h]h ]h"]h$]h&]uh1j5hjYubeh}(h]h ]h"]h$]h&]uh1jhjYhMhjhRubj)}(h0``wext.bssid`` (private) selected network BSSID h](j)}(h``wext.bssid``h]j)}(hjYh]h wext.bssid}(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 BSSIDh]h (private) selected network BSSID}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYhMhjYubah}(h]h ]h"]h$]h&]uh1j5hjYubeh}(h]h ]h"]h$]h&]uh1jhjYhMhjhRubj)}(h?``wext.prev_bssid`` (private) previous BSSID for reassociation h](j)}(h``wext.prev_bssid``h]j)}(hjYh]hwext.prev_bssid}(hjZhhhNhNubah}(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) previous BSSID for reassociationh]h*(private) previous BSSID for reassociation}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhMhjZubah}(h]h ]h"]h$]h&]uh1j5hjYubeh}(h]h ]h"]h$]h&]uh1jhjZhMhjhRubj)}(h.``wext.ssid`` (private) selected network SSID h](j)}(h ``wext.ssid``h]j)}(hj7Zh]h wext.ssid}(hj9ZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5Zubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj1Zubj6)}(hhh]h)}(h(private) selected network SSIDh]h(private) selected network SSID}(hjPZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLZhMhjMZubah}(h]h ]h"]h$]h&]uh1j5hj1Zubeh}(h]h ]h"]h$]h&]uh1jhjLZhMhjhRubj)}(h:``wext.default_key`` (private) selected default key index h](j)}(h``wext.default_key``h]j)}(hjpZh]hwext.default_key}(hjrZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnZubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjjZubj6)}(hhh]h)}(h$(private) selected default key indexh]h$(private) selected default key index}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhMhjZubah}(h]h ]h"]h$]h&]uh1j5hjjZubeh}(h]h ]h"]h$]h&]uh1jhjZhMhjhRubj)}(hJ``wext.default_mgmt_key`` (private) selected default management key index h](j)}(h``wext.default_mgmt_key``h]j)}(hjZh]hwext.default_mgmt_key}(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.hhMhjZubj6)}(hhh]h)}(h/(private) selected default management key indexh]h/(private) selected default management key index}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhMhjZubah}(h]h ]h"]h$]h&]uh1j5hjZubeh}(h]h ]h"]h$]h&]uh1jhjZhMhjhRubj)}(h<``wext.prev_bssid_valid`` (private) previous BSSID validity h](j)}(h``wext.prev_bssid_valid``h]j)}(hjZh]hwext.prev_bssid_valid}(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.hhMhjZubj6)}(hhh]h)}(h!(private) previous BSSID validityh]h!(private) previous BSSID validity}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhMhjZubah}(h]h ]h"]h$]h&]uh1j5hjZubeh}(h]h ]h"]h$]h&]uh1jhjZhMhjhRubj)}(h4``cqm_rssi_work`` (private) CQM RSSI reporting work h](j)}(h``cqm_rssi_work``h]j)}(hj]h cqm_rssi_work}(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!(private) CQM RSSI reporting workh]h!(private) CQM RSSI reporting work}(hj4[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0[hMhj1[ubah}(h]h ]h"]h$]h&]uh1j5hj[ubeh}(h]h ]h"]h$]h&]uh1jhj0[hMhjhRubj)}(h4``cqm_config`` (private) nl80211 RSSI monitor state h](j)}(h``cqm_config``h]j)}(hjT[h]h cqm_config}(hjV[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjR[ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjN[ubj6)}(hhh]h)}(h$(private) nl80211 RSSI monitor stateh]h$(private) nl80211 RSSI monitor state}(hjm[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhji[hMhjj[ubah}(h]h ]h"]h$]h&]uh1j5hjN[ubeh}(h]h ]h"]h$]h&]uh1jhji[hMhjhRubj)}(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.hhMhj[ubj6)}(hhh]h)}(h#(private) peer measurement requestsh]h#(private) peer measurement requests}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hMhj[ubah}(h]h ]h"]h$]h&]uh1j5hj[ubeh}(h]h ]h"]h$]h&]uh1jhj[hMhjhRubj)}(h@``pmsr_lock`` (private) peer measurements requests/results lock h](j)}(h ``pmsr_lock``h]j)}(hj[h]h pmsr_lock}(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)}(h1(private) peer measurements requests/results lockh]h1(private) peer measurements requests/results lock}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hMhj[ubah}(h]h ]h"]h$]h&]uh1j5hj[ubeh}(h]h ]h"]h$]h&]uh1jhj[hMhjhRubj)}(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.hhMhj[ubj6)}(hhh]h)}(h((private) peer measurements cleanup workh]h((private) peer measurements cleanup work}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\hMhj\ubah}(h]h ]h"]h$]h&]uh1j5hj[ubeh}(h]h ]h"]h$]h&]uh1jhj\hMhjhRubj)}(hQ``unprot_beacon_reported`` (private) timestamp of last unprotected beacon report h](j)}(h``unprot_beacon_reported``h]j)}(hj8\h]hunprot_beacon_reported}(hj:\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6\ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj2\ubj6)}(hhh]h)}(h5(private) timestamp of last unprotected beacon reporth]h5(private) timestamp of last unprotected beacon report}(hjQ\hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjN\ubah}(h]h ]h"]h$]h&]uh1j5hj2\ubeh}(h]h ]h"]h$]h&]uh1jhjM\hMhjhRubj)}(h3``u`` union containing data specific to **iftype** h](j)}(h``u``h]j)}(hjr\h]hu}(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.hhMhjl\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&]uh1j5hjl\ubeh}(h]h ]h"]h$]h&]uh1jhj\hMhjhRubj)}(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&]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)}(hiarray of ``IEEE80211_MLD_MAX_NUM_LINKS`` elements containing **addr** **ap** and **client** for each linkh](h array of }(hj\hhhNhNubj)}(h``IEEE80211_MLD_MAX_NUM_LINKS``h]hIEEE80211_MLD_MAX_NUM_LINKS}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubh elements containing }(hj\hhhNhNubj)}(h**addr**h]haddr}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\ubh }(hj\hhhNhNubj)}(h**ap**h]hap}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\ubh and }(hj\hhhNhNubj)}(h **client**h]hclient}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\ubh for each link}(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\hMhjhRubj)}(h``{unnamed_union}`` anonymous h](j)}(h``{unnamed_union}``h]j)}(hj;]h]h{unnamed_union}}(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.hhKhj5]ubj6)}(hhh]h)}(h anonymoush]h anonymous}(hjT]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjP]hKhjQ]ubah}(h]h ]h"]h$]h&]uh1j5hj5]ubeh}(h]h ]h"]h$]h&]uh1jhjP]hKhjhRubj)}(hN``links.cac_started`` true if DFS channel availability check has been started h](j)}(h``links.cac_started``h]j)}(hjt]h]hlinks.cac_started}(hjv]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjr]ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjn]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.hhMhj]ubah}(h]h ]h"]h$]h&]uh1j5hjn]ubeh}(h]h ]h"]h$]h&]uh1jhj]hMhjhRubj)}(hM``links.cac_start_time`` timestamp (jiffies) when the dfs state was entered. h](j)}(h``links.cac_start_time``h]j)}(hj]h]hlinks.cac_start_time}(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)}(h3timestamp (jiffies) when the dfs state was entered.h]h3timestamp (jiffies) when the dfs state was entered.}(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]hMhjhRubj)}(h%``links.cac_time_ms`` CAC time in ms h](j)}(h``links.cac_time_ms``h]j)}(hj]h]hlinks.cac_time_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.hhMhj]ubj6)}(hhh]h)}(hCAC time in msh]hCAC time in ms}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]hMhj]ubah}(h]h ]h"]h$]h&]uh1j5hj]ubeh}(h]h ]h"]h$]h&]uh1jhj]hMhjhRubj)}(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.hhMhj^ubj6)}(hhh]h)}(h6bitmap describing what elements of **links** are validh](h#bitmap describing what elements of }(hj:^hhhNhNubj)}(h **links**h]hlinks}(hjB^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:^ubh are valid}(hj:^hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj6^hMhj7^ubah}(h]h ]h"]h$]h&]uh1j5hj^ubeh}(h]h ]h"]h$]h&]uh1jhj6^hMhjhRubj)}(hN``radio_mask`` Bitmask of radios that this interface is allowed to operate on.h](j)}(h``radio_mask``h]j)}(hjl^h]h radio_mask}(hjn^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjj^ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjf^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.hhMhj^ubah}(h]h ]h"]h$]h&]uh1j5hjf^ubeh}(h]h ]h"]h$]h&]uh1jhj^hMhjhRubeh}(h]h ]h"]h$]h&]uh1jhj Rubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(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: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.)}(hj^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.}(hj^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 ]jlah"]h$]h&]uh1j_hj^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&]uh1jhj^hhhj _hMubj)}(hjh]h*}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^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&]jjuh1jhj^hhhj _hMubj)}(h(struct wireless_dev *wdev)h]j)}(hstruct wireless_dev *wdevh](ju)}(hjnh]hstruct}(hjF_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjB_ubj)}(h h]h }(hjS_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjB_ubh)}(hhh]j)}(h wireless_devh]h wireless_dev}(hjd_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhja_ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjf_modnameN classnameNjS jV )}jY ]j)}jj,_sb c.wdev_privasbuh1hhjB_ubj)}(h h]h }(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjB_ubj)}(hjh]h*}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjB_ubj)}(hwdevh]hwdev}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjB_ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj>_ubah}(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)}(h#return wiphy priv from wireless_devh]h#return wiphy priv from wireless_dev}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj_hhubah}(h]h ]h"]h$]h&]uh1jhj^hhhj _hMubeh}(h]h ](j$functioneh"]h$]h&]jj$jj_jj_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)}(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:14: ./include/net/cfg80211.hhMhj_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&]uh1jhj_ubh)}(h **Return**h]j)}(hjE`h]hReturn}(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:14: ./include/net/cfg80211.hhMhj_ubh)}(hThe wiphy priv of **wdev**.h](hThe wiphy priv of }(hj[`hhhNhNubj)}(h**wdev**h]hwdev}(hjc`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_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 ]jlah"]h$]h&]uh1j_hj`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)}(hjnh]hstruct}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj`ubj)}(h h]h }(hj`hhhNhNubah}(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 classnameNjS jV )}jY ]j)}jj`sbc.cfg80211_check_combinationsasbuh1hhj`ubj)}(h h]h }(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubj)}(hjh]h*}(hj%ahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubj)}(hwiphyh]hwiphy}(hj2ahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj`ubj)}(h'struct iface_combination_params *paramsh](ju)}(hjnh]hstruct}(hjKahhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjGaubj)}(h h]h }(hjXahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGaubh)}(hhh]j)}(hiface_combination_paramsh]hiface_combination_params}(hjiahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfaubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjkamodnameN classnameNjS jV )}jY ]jac.cfg80211_check_combinationsasbuh1hhjGaubj)}(h h]h }(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGaubj)}(hjh]h*}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGaubj)}(hparamsh]hparams}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGaubeh}(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)}(hcheck interface combinationsh]hcheck interface combinations}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM&hjahhubah}(h]h ]h"]h$]h&]uh1jhj`hhhj`hM&ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjajjajjjuh1jchhhhhNhNubj)}(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)}(hjah]h Parameters}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhjaubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM&hjaubj)}(hhh](j)}(h"``struct wiphy *wiphy`` the wiphy h](j)}(h``struct wiphy *wiphy``h]j)}(hj bh]hstruct wiphy *wiphy}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj bubah}(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 the wiphyh]h the wiphy}(hj&bhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"bhM&hj#bubah}(h]h ]h"]h$]h&]uh1j5hjbubeh}(h]h ]h"]h$]h&]uh1jhj"bhM&hjbubj)}(hQ``struct iface_combination_params *params`` the interface combinations parameter h](j)}(h+``struct iface_combination_params *params``h]j)}(hjFbh]h'struct iface_combination_params *params}(hjHbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDbubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM&hj@bubj6)}(hhh]h)}(h$the interface combinations parameterh]h$the interface combinations parameter}(hj_bhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[bhM&hj\bubah}(h]h ]h"]h$]h&]uh1j5hj@bubeh}(h]h ]h"]h$]h&]uh1jhj[bhM&hjbubeh}(h]h ]h"]h$]h&]uh1jhjaubh)}(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&hjaubh)}(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&hjaubh)}(h **Return**h]j)}(hjbh]hReturn}(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&hjaubh)}(h10 if combinations are allowed. Non-zero on error.h]h10 if combinations are allowed. Non-zero on error.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM&hjaubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubeh}(h]device-registrationah ]h"]device registrationah$]h&]uh1hhhhhhhhK ubh)}(hhh](h)}(hActions and configurationh]hActions and configuration}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbhhhhhK+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.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:45: ./include/net/cfg80211.hhMhjbhhubh)}(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.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:45: ./include/net/cfg80211.hhMhjbhhubh)}(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.}(hj chhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:45: ./include/net/cfg80211.hhMhjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_vif_params (C struct) c.vif_paramshNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(h vif_paramsh]jo)}(hstruct vif_paramsh](ju)}(hjnh]hstruct}(hj3chhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj/chhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhKubj)}(h h]h }(hjAchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/chhhj@chKubj)}(h vif_paramsh]j)}(hj-ch]h vif_params}(hjSchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOcubah}(h]h ](jjeh"]h$]h&]jjuh1jhj/chhhj@chKubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj+chhhj@chKubah}(h]j&cah ](jjeh"]h$]h&]jj)jhuh1jhhj@chKhj(chhubj)}(hhh]h)}(h&describes virtual interface parametersh]h&describes virtual interface parameters}(hjuchhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjrchhubah}(h]h ]h"]h$]h&]uh1jhj(chhhj@chKubeh}(h]h ](j$structeh"]h$]h&]jj$jjcjjcjjjuh1jchhhjbhNhNubj)}(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; };}hjcsbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcubh)}(h **Members**h]j)}(hjch]hMembers}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhjcubah}(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)}(hjch]hflags}(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)}(hWmonitor interface flags, unchanged if 0, otherwise ``MONITOR_FLAG_CHANGED`` will be seth](h3monitor interface flags, unchanged if 0, otherwise }(hjchhhNhNubj)}(h``MONITOR_FLAG_CHANGED``h]hMONITOR_FLAG_CHANGED}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubh will be set}(hjchhhNhNubeh}(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&]uh1jhjchMhjcubj)}(h#``use_4addr`` use 4-address frames h](j)}(h ``use_4addr``h]j)}(hj.dh]h use_4addr}(hj0dhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,dubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj(dubj6)}(hhh]h)}(huse 4-address framesh]huse 4-address frames}(hjGdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjCdhMhjDdubah}(h]h ]h"]h$]h&]uh1j5hj(dubeh}(h]h ]h"]h$]h&]uh1jhjCdhMhjcubj)}(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)}(hjgdh]hmacaddr}(hjidhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjedubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjadubj6)}(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}(hjdhhhNhNubah}(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.hhMhj}dubah}(h]h ]h"]h$]h&]uh1j5hjadubeh}(h]h ]h"]h$]h&]uh1jhj|dhMhjcubj)}(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)}(hjdh]hvht_mumimo_groups}(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.hhMhjdubj6)}(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; }(hjdhhhNhNubj)}(h``NULL``h]hNULL}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubh if not changed}(hjdhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjdubah}(h]h ]h"]h$]h&]uh1j5hjdubeh}(h]h ]h"]h$]h&]uh1jhjdhMhjcubj)}(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}(hjehhhNhNubah}(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.hhMhjdubj6)}(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; }(hjehhhNhNubj)}(h``NULL``h]hNULL}(hj ehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubh if not changed}(hjehhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjehMhjeubah}(h]h ]h"]h$]h&]uh1j5hjdubeh}(h]h ]h"]h$]h&]uh1jhjehMhjcubeh}(h]h ]h"]h$]h&]uh1jhjcubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_key_params (C struct) c.key_paramshNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(h key_paramsh]jo)}(hstruct key_paramsh](ju)}(hjnh]hstruct}(hjjehhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjfehhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjxehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfehhhjwehM ubj)}(h key_paramsh]j)}(hjdeh]h key_params}(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubah}(h]h ](jjeh"]h$]h&]jjuh1jhjfehhhjwehM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjbehhhjwehM ubah}(h]j]eah ](jjeh"]h$]h&]jj)jhuh1jhhjwehM hj_ehhubj)}(hhh]h)}(hkey informationh]hkey information}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjehhubah}(h]h ]h"]h$]h&]uh1jhj_ehhhjwehM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjejjejjjuh1jchhhjbhNhNubj)}(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), 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}(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.hhMhjeubj)}(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; };}hjesbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjeubh)}(h **Members**h]j)}(hjeh]hMembers}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjeubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjeubj)}(hhh](j)}(h``key`` key material h](j)}(h``key``h]j)}(hjfh]hkey}(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 key materialh]h key material}(hj2fhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.fhMhj/fubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhj.fhMhjfubj)}(hY``seq`` sequence counter (IV/PN), must be in little endian, length given by **seq_len**. h](j)}(h``seq``h]j)}(hjRfh]hseq}(hjTfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPfubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjLfubj6)}(hhh]h)}(hPsequence counter (IV/PN), must be in little endian, length given by **seq_len**.h](hDsequence counter (IV/PN), must be in little endian, length given by }(hjkfhhhNhNubj)}(h **seq_len**h]hseq_len}(hjsfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkfubh.}(hjkfhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhfubah}(h]h ]h"]h$]h&]uh1j5hjLfubeh}(h]h ]h"]h$]h&]uh1jhjgfhMhjfubj)}(h#``key_len`` length of key material h](j)}(h ``key_len``h]j)}(hjfh]hkey_len}(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)}(hlength of key materialh]hlength of key material}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhMhjfubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhjfhMhjfubj)}(h``seq_len`` length of **seq**. h](j)}(h ``seq_len``h]j)}(hjfh]hseq_len}(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)}(hlength of **seq**.h](h length of }(hjfhhhNhNubj)}(h**seq**h]hseq}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfubh.}(hjfhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjfhMhjfubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhjfhMhjfubj)}(h4``vlan_id`` vlan_id for VLAN group key (if nonzero) h](j)}(h ``vlan_id``h]j)}(hj"gh]hvlan_id}(hj$ghhhNhNubah}(h]h ]h"]h$]h&]uh1jhj gubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjgubj6)}(hhh]h)}(h'vlan_id for VLAN group key (if nonzero)h]h'vlan_id for VLAN group key (if nonzero)}(hj;ghhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7ghMhj8gubah}(h]h ]h"]h$]h&]uh1j5hjgubeh}(h]h ]h"]h$]h&]uh1jhj7ghMhjfubj)}(h!``cipher`` cipher suite selector h](j)}(h ``cipher``h]j)}(hj[gh]hcipher}(hj]ghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYgubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjUgubj6)}(hhh]h)}(hcipher suite selectorh]hcipher suite selector}(hjtghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjpghMhjqgubah}(h]h ]h"]h$]h&]uh1j5hjUgubeh}(h]h ]h"]h$]h&]uh1jhjpghMhjfubj)}(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)}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjgubah}(h]h ]h"]h$]h&]uh1j5hjgubeh}(h]h ]h"]h$]h&]uh1jhjghMhjfubeh}(h]h ]h"]h$]h&]uh1jhjeubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(h**Description**h]j)}(hjgh]h Description}(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.hhMhjbhhubh)}(hInformation about a keyh]hInformation about a key}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_survey_info_flags (C enum)c.survey_info_flagshNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hsurvey_info_flagsh]jo)}(henum survey_info_flagsh](ju)}(hjxh]henum}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hj#hhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhhj"hhMubj)}(hsurvey_info_flagsh]j)}(hjhh]hsurvey_info_flags}(hj5hhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1hubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhhj"hhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj hhhhj"hhMubah}(h]jhah ](jjeh"]h$]h&]jj)jhuh1jhhj"hhMhj hhhubj)}(hhh]h)}(hsurvey information flagsh]hsurvey information flags}(hjWhhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjThhhubah}(h]h ]h"]h$]h&]uh1jhj hhhhj"hhMubeh}(h]h ](j$enumeh"]h$]h&]jj$jjohjjohjjjuh1jchhhjbhNhNubj)}(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)}(hjyhh]h Constants}(hj{hhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwhubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjshubj)}(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.hhMhjhubj6)}(hhh]h)}(hnoise (in dBm) was filled inh]hnoise (in dBm) was filled in}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhMhjhubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhhMhjhubj)}(h7``SURVEY_INFO_IN_USE`` channel is currently being used h](j)}(h``SURVEY_INFO_IN_USE``h]j)}(hjhh]hSURVEY_INFO_IN_USE}(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)}(hchannel is currently being usedh]hchannel is currently being used}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhMhjhubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhhMhjhubj)}(h7``SURVEY_INFO_TIME`` active time (in ms) was filled in h](j)}(h``SURVEY_INFO_TIME``h]j)}(hj ih]hSURVEY_INFO_TIME}(hj ihhhNhNubah}(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!active time (in ms) was filled inh]h!active time (in ms) was filled in}(hj#ihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihMhj iubah}(h]h ]h"]h$]h&]uh1j5hjiubeh}(h]h ]h"]h$]h&]uh1jhjihMhjhubj)}(h2``SURVEY_INFO_TIME_BUSY`` busy time was filled in h](j)}(h``SURVEY_INFO_TIME_BUSY``h]j)}(hjCih]hSURVEY_INFO_TIME_BUSY}(hjEihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAiubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj=iubj6)}(hhh]h)}(hbusy time was filled inh]hbusy time was filled in}(hj\ihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXihMhjYiubah}(h]h ]h"]h$]h&]uh1j5hj=iubeh}(h]h ]h"]h$]h&]uh1jhjXihMhjhubj)}(hH``SURVEY_INFO_TIME_EXT_BUSY`` extension channel busy time was filled in h](j)}(h``SURVEY_INFO_TIME_EXT_BUSY``h]j)}(hj|ih]hSURVEY_INFO_TIME_EXT_BUSY}(hj~ihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjziubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjviubj6)}(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&]uh1j5hjviubeh}(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)}(hjih]hSURVEY_INFO_TIME_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)}(hreceive time was filled inh]hreceive time was filled in}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihMhjiubah}(h]h ]h"]h$]h&]uh1j5hjiubeh}(h]h ]h"]h$]h&]uh1jhjihMhjhubj)}(h4``SURVEY_INFO_TIME_TX`` transmit time was filled in h](j)}(h``SURVEY_INFO_TIME_TX``h]j)}(hjih]hSURVEY_INFO_TIME_TX}(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)}(htransmit time was filled inh]htransmit time was filled in}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjhMhjjubah}(h]h ]h"]h$]h&]uh1j5hjiubeh}(h]h ]h"]h$]h&]uh1jhjjhMhjhubj)}(h2``SURVEY_INFO_TIME_SCAN`` scan time was filled in h](j)}(h``SURVEY_INFO_TIME_SCAN``h]j)}(hj'jh]hSURVEY_INFO_TIME_SCAN}(hj)jhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%jubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj!jubj6)}(hhh]h)}(hscan time was filled inh]hscan time was filled in}(hj@jhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj` it has filled in during the get_survey().h](h-Used by the driver to indicate which info in }(hjjhhhNhNubh)}(h*:c:type:`struct survey_info `h]j)}(hjjh]hstruct survey_info}(hjjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6 survey_infouh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubh* it has filled in during the get_survey().}(hjjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjjhMhjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_survey_info (C struct) c.survey_infohNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(h survey_infoh]jo)}(hstruct survey_infoh](ju)}(hjnh]hstruct}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjkhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjkhhhjkhMubj)}(h survey_infoh]j)}(hjjh]h survey_info}(hj$khhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj kubah}(h]h ](jjeh"]h$]h&]jjuh1jhjkhhhjkhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjjhhhjkhMubah}(h]jjah ](jjeh"]h$]h&]jj)jhuh1jhhjkhMhjjhhubj)}(hhh]h)}(hchannel survey responseh]hchannel survey response}(hjFkhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjCkhhubah}(h]h ]h"]h$]h&]uh1jhjjhhhjkhMubeh}(h]h ](j$structeh"]h$]h&]jj$jj^kjj^kjjjuh1jchhhjbhNhNubj)}(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}(hjjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfkubh:}(hjfkhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjbkubj)}(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&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjbkubh)}(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.hhMhjbkubj)}(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)}(hjkh]hchannel}(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)}(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 }(hjkhhhNhNubj)}(h``NULL``h]hNULL}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubh0 for a single record to report global statistics}(hjkhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjkubah}(h]h ]h"]h$]h&]uh1j5hjkubeh}(h]h ]h"]h$]h&]uh1jhjkhMhjkubj)}(hE``time`` amount of time in ms the radio was turn on (on the channel) h](j)}(h``time``h]j)}(hjkh]htime}(hjlhhhNhNubah}(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)}(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)}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhMhjlubah}(h]h ]h"]h$]h&]uh1j5hjkubeh}(h]h ]h"]h$]h&]uh1jhjlhMhjkubj)}(hA``time_busy`` amount of time the primary channel was sensed busy h](j)}(h ``time_busy``h]j)}(hj8lh]h time_busy}(hj:lhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6lubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj2lubj6)}(hhh]h)}(h2amount of time the primary channel was sensed busyh]h2amount of time the primary channel was sensed busy}(hjQlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjMlhMhjNlubah}(h]h ]h"]h$]h&]uh1j5hj2lubeh}(h]h ]h"]h$]h&]uh1jhjMlhMhjkubj)}(hG``time_ext_busy`` amount of time the extension channel was sensed busy h](j)}(h``time_ext_busy``h]j)}(hjqlh]h time_ext_busy}(hjslhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjolubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjklubj6)}(hhh]h)}(h4amount of time the extension channel was sensed busyh]h4amount of time the extension channel was sensed busy}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhMhjlubah}(h]h ]h"]h$]h&]uh1j5hjklubeh}(h]h ]h"]h$]h&]uh1jhjlhMhjkubj)}(h:``time_rx`` amount of time the radio spent receiving data h](j)}(h ``time_rx``h]j)}(hjlh]htime_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-amount of time the radio spent receiving datah]h-amount of time the radio spent receiving data}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhMhjlubah}(h]h ]h"]h$]h&]uh1j5hjlubeh}(h]h ]h"]h$]h&]uh1jhjlhMhjkubj)}(h=``time_tx`` amount of time the radio spent transmitting data h](j)}(h ``time_tx``h]j)}(hjlh]htime_tx}(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)}(h0amount of time the radio spent transmitting datah]h0amount of time the radio spent transmitting data}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhMhjlubah}(h]h ]h"]h$]h&]uh1j5hjlubeh}(h]h ]h"]h$]h&]uh1jhjlhMhjkubj)}(h:``time_scan`` amount of time the radio spent for scanning h](j)}(h ``time_scan``h]j)}(hjmh]h time_scan}(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.hhMhjmubj6)}(hhh]h)}(h+amount of time the radio spent for scanningh]h+amount of time the radio spent for scanning}(hj5mhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1mhMhj2mubah}(h]h ]h"]h$]h&]uh1j5hjmubeh}(h]h ]h"]h$]h&]uh1jhj1mhMhjkubj)}(hM``time_bss_rx`` amount of time the radio spent receiving data on a local BSS h](j)}(h``time_bss_rx``h]j)}(hjUmh]h time_bss_rx}(hjWmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSmubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjOmubj6)}(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.hhMhjmubj6)}(hhh]h)}(hJbitflag of flags from :c:type:`enum survey_info_flags `h](hbitflag of flags from }(hjmhhhNhNubh)}(h4:c:type:`enum survey_info_flags `h]j)}(hjmh]henum survey_info_flags}(hjmhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6survey_info_flagsuh1hhjmhMhjmubeh}(h]h ]h"]h$]h&]uh1hhjmhMhjmubah}(h]h ]h"]h$]h&]uh1j5hjmubeh}(h]h ]h"]h$]h&]uh1jhjmhMhjkubj)}(hJ``noise`` channel noise in dBm. This and all following fields are optionalh](j)}(h ``noise``h]j)}(hjmh]hnoise}(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.hhMhjmubj6)}(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&]uh1hhjmhMhjmubah}(h]h ]h"]h$]h&]uh1j5hjmubeh}(h]h ]h"]h$]h&]uh1jhjmhMhjkubeh}(h]h ]h"]h$]h&]uh1jhjbkubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(h**Description**h]j)}(hj(nh]h Description}(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:48: ./include/net/cfg80211.hhMhjbhhubh)}(hDUsed by dump_survey() to report back per-channel survey information.h]hDUsed by dump_survey() to report back per-channel survey information.}(hj>nhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjbhhubh)}(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.}(hjMnhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_#cfg80211_crypto_settings (C struct)c.cfg80211_crypto_settingshNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hcfg80211_crypto_settingsh]jo)}(hstruct cfg80211_crypto_settingsh](ju)}(hjnh]hstruct}(hjunhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjqnhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjqnhhhjnhMubj)}(hcfg80211_crypto_settingsh]j)}(hjonh]hcfg80211_crypto_settings}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjnubah}(h]h ](jjeh"]h$]h&]jjuh1jhjqnhhhjnhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjmnhhhjnhMubah}(h]jhnah ](jjeh"]h$]h&]jj)jhuh1jhhjnhMhjjnhhubj)}(hhh]h)}(hCrypto settingsh]hCrypto settings}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjnhhubah}(h]h ]h"]h$]h&]uh1jhjjnhhhjnhMubeh}(h]h ](j$structeh"]h$]h&]jj$jjnjjnjjjuh1jchhhjbhNhNubj)}(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}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnubh:}(hjnhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjnubj)}(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; };}hjnsbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjnubh)}(h **Members**h]j)}(hjoh]hMembers}(hjohhhNhNubah}(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.hhMhjnubj)}(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)}(hj$oh]h wpa_versions}(hj&ohhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"oubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjoubj6)}(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)}(hj=ohhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj:oubah}(h]h ]h"]h$]h&]uh1j5hjoubeh}(h]h ]h"]h$]h&]uh1jhj9ohMhjoubj)}(h8``cipher_group`` group key cipher suite (or 0 if unset) h](j)}(h``cipher_group``h]j)}(hj^oh]h cipher_group}(hj`ohhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\oubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjXoubj6)}(hhh]h)}(h&group key cipher suite (or 0 if unset)h]h&group key cipher suite (or 0 if unset)}(hjwohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjsohMhjtoubah}(h]h ]h"]h$]h&]uh1j5hjXoubeh}(h]h ]h"]h$]h&]uh1jhjsohMhjoubj)}(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}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjohMhjoubah}(h]h ]h"]h$]h&]uh1j5hjoubeh}(h]h ]h"]h$]h&]uh1jhjohMhjoubj)}(h/``ciphers_pairwise`` unicast key cipher suites h](j)}(h``ciphers_pairwise``h]j)}(hjoh]hciphers_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)}(hunicast key cipher suitesh]hunicast key cipher suites}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjohMhjoubah}(h]h ]h"]h$]h&]uh1j5hjoubeh}(h]h ]h"]h$]h&]uh1jhjohMhjoubj)}(h&``n_akm_suites`` number of AKM suites h](j)}(h``n_akm_suites``h]j)}(hj ph]h n_akm_suites}(hj phhhNhNubah}(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)}(hnumber of AKM suitesh]hnumber of AKM suites}(hj"phhhNhNubah}(h]h ]h"]h$]h&]uh1hhjphMhjpubah}(h]h ]h"]h$]h&]uh1j5hjpubeh}(h]h ]h"]h$]h&]uh1jhjphMhjoubj)}(h``akm_suites`` AKM suites h](j)}(h``akm_suites``h]j)}(hjBph]h akm_suites}(hjDphhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@pubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjuhhhNhNubj)}(h``NULL``h]hNULL}(hjFuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>uubeh}(h]h ]h"]h$]h&]uh1hhj:uhM:hj;uubah}(h]h ]h"]h$]h&]uh1j5hjuubeh}(h]h ]h"]h$]h&]uh1jhj:uhM:hjKtubj)}(h]``proberesp_ies`` extra information element(s) to add into Probe Response frames or ``NULL`` h](j)}(h``proberesp_ies``h]j)}(hjluh]h proberesp_ies}(hjnuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjuubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM=hjfuubj6)}(hhh]h)}(hJextra information element(s) to add into Probe Response frames or ``NULL``h](hBextra information element(s) to add into Probe Response frames or }(hjuhhhNhNubj)}(h``NULL``h]hNULL}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM<hjuubah}(h]h ]h"]h$]h&]uh1j5hjfuubeh}(h]h ]h"]h$]h&]uh1jhjuhM=hjKtubj)}(hg``assocresp_ies`` extra information element(s) to add into (Re)Association Response frames or ``NULL`` h](j)}(h``assocresp_ies``h]j)}(hjuh]h assocresp_ies}(hjuhhhNhNubah}(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@hjuubj6)}(hhh]h)}(hTextra information element(s) to add into (Re)Association Response frames or ``NULL``h](hLextra information element(s) to add into (Re)Association Response frames or }(hjuhhhNhNubj)}(h``NULL``h]hNULL}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM?hjuubah}(h]h ]h"]h$]h&]uh1j5hjuubeh}(h]h ]h"]h$]h&]uh1jhjuhM@hjKtubj)}(h6``probe_resp`` probe response template (AP mode only) h](j)}(h``probe_resp``h]j)}(hjuh]h probe_resp}(hjuhhhNhNubah}(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.hhMChjuubj6)}(hhh]h)}(h&probe response template (AP mode only)h]h&probe response template (AP mode only)}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvhMChjvubah}(h]h ]h"]h$]h&]uh1j5hjuubeh}(h]h ]h"]h$]h&]uh1jhjvhMChjKtubj)}(ha``lci`` Measurement Report element content, starting with Measurement Token (measurement type 8) h](j)}(h``lci``h]j)}(hj5vh]hlci}(hj7vhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3vubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMIhj/vubj6)}(hhh]h)}(hXMeasurement Report element content, starting with Measurement Token (measurement type 8)h]hXMeasurement Report element content, starting with Measurement Token (measurement type 8)}(hjNvhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMHhjKvubah}(h]h ]h"]h$]h&]uh1j5hj/vubeh}(h]h ]h"]h$]h&]uh1jhjJvhMIhjKtubj)}(hg``civicloc`` Measurement Report element content, starting with Measurement Token (measurement type 11) h](j)}(h ``civicloc``h]j)}(hjovh]hcivicloc}(hjqvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmvubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMKhjivubj6)}(hhh]h)}(hYMeasurement Report element content, starting with Measurement Token (measurement type 11)h]hYMeasurement Report element content, starting with Measurement Token (measurement type 11)}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMJhjvubah}(h]h ]h"]h$]h&]uh1j5hjivubeh}(h]h ]h"]h$]h&]uh1jhjvhMKhjKtubj)}(h'``mbssid_ies`` multiple BSSID elements h](j)}(h``mbssid_ies``h]j)}(hjvh]h mbssid_ies}(hjvhhhNhNubah}(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.hhMDhjvubj6)}(hhh]h)}(hmultiple BSSID elementsh]hmultiple BSSID elements}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvhMDhjvubah}(h]h ]h"]h$]h&]uh1j5hjvubeh}(h]h ]h"]h$]h&]uh1jhjvhMDhjKtubj)}(h-``rnr_ies`` reduced neighbor report elements h](j)}(h ``rnr_ies``h]j)}(hjvh]hrnr_ies}(hjvhhhNhNubah}(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.hhMEhjvubj6)}(hhh]h)}(h reduced neighbor report elementsh]h reduced neighbor report elements}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvhMEhjvubah}(h]h ]h"]h$]h&]uh1j5hjvubeh}(h]h ]h"]h$]h&]uh1jhjvhMEhjKtubj)}(h``ftm_responder`` enable FTM responder functionality; -1 for no change (which also implies no change in LCI/civic location data) h](j)}(h``ftm_responder``h]j)}(hjwh]h ftm_responder}(hjwhhhNhNubah}(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.hhMGhjwubj6)}(hhh]h)}(hnenable FTM responder functionality; -1 for no change (which also implies no change in LCI/civic location data)h]hnenable FTM responder functionality; -1 for no change (which also implies no change in LCI/civic location data)}(hj4whhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMFhj1wubah}(h]h ]h"]h$]h&]uh1j5hjwubeh}(h]h ]h"]h$]h&]uh1jhj0whMGhjKtubj)}(h ``head_len`` length of **head** h](j)}(h ``head_len``h]j)}(hjUwh]hhead_len}(hjWwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSwubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM8hjOwubj6)}(hhh]h)}(hlength of **head**h](h length of }(hjnwhhhNhNubj)}(h**head**h]hhead}(hjvwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnwubeh}(h]h ]h"]h$]h&]uh1hhjjwhM8hjkwubah}(h]h ]h"]h$]h&]uh1j5hjOwubeh}(h]h ]h"]h$]h&]uh1jhjjwhM8hjKtubj)}(h ``tail_len`` length of **tail** h](j)}(h ``tail_len``h]j)}(hjwh]htail_len}(hjwhhhNhNubah}(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.hhM9hjwubj6)}(hhh]h)}(hlength of **tail**h](h length of }(hjwhhhNhNubj)}(h**tail**h]htail}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwubeh}(h]h ]h"]h$]h&]uh1hhjwhM9hjwubah}(h]h ]h"]h$]h&]uh1j5hjwubeh}(h]h ]h"]h$]h&]uh1jhjwhM9hjKtubj)}(h2``beacon_ies_len`` length of beacon_ies in octets h](j)}(h``beacon_ies_len``h]j)}(hjwh]hbeacon_ies_len}(hjwhhhNhNubah}(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;hjwubj6)}(hhh]h)}(hlength of beacon_ies in octetsh]hlength of beacon_ies in octets}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwhM;hjwubah}(h]h ]h"]h$]h&]uh1j5hjwubeh}(h]h ]h"]h$]h&]uh1jhjwhM;hjKtubj)}(h8``proberesp_ies_len`` length of proberesp_ies in octets h](j)}(h``proberesp_ies_len``h]j)}(hjxh]hproberesp_ies_len}(hjxhhhNhNubah}(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.hhM>hjxubj6)}(hhh]h)}(h!length of proberesp_ies in octetsh]h!length of proberesp_ies in octets}(hj5xhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1xhM>hj2xubah}(h]h ]h"]h$]h&]uh1j5hjxubeh}(h]h ]h"]h$]h&]uh1jhj1xhM>hjKtubj)}(h8``assocresp_ies_len`` length of assocresp_ies in octets h](j)}(h``assocresp_ies_len``h]j)}(hjUxh]hassocresp_ies_len}(hjWxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSxubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMAhjOxubj6)}(hhh]h)}(h!length of assocresp_ies in octetsh]h!length of assocresp_ies in octets}(hjnxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjxhMAhjkxubah}(h]h ]h"]h$]h&]uh1j5hjOxubeh}(h]h ]h"]h$]h&]uh1jhjjxhMAhjKtubj)}(hF``probe_resp_len`` length of probe response template (**probe_resp**) h](j)}(h``probe_resp_len``h]j)}(hjxh]hprobe_resp_len}(hjxhhhNhNubah}(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.hhMBhjxubj6)}(hhh]h)}(h2length of probe response template (**probe_resp**)h](h#length of probe response template (}(hjxhhhNhNubj)}(h**probe_resp**h]h probe_resp}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxubh)}(hjxhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjxhMBhjxubah}(h]h ]h"]h$]h&]uh1j5hjxubeh}(h]h ]h"]h$]h&]uh1jhjxhMBhjKtubj)}(h``lci_len`` LCI data length h](j)}(h ``lci_len``h]j)}(hjxh]hlci_len}(hjxhhhNhNubah}(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.hhMLhjxubj6)}(hhh]h)}(hLCI data lengthh]hLCI data length}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxhMLhjxubah}(h]h ]h"]h$]h&]uh1j5hjxubeh}(h]h ]h"]h$]h&]uh1jhjxhMLhjKtubj)}(h,``civicloc_len`` Civic location data length h](j)}(h``civicloc_len``h]j)}(hjyh]h civicloc_len}(hjyhhhNhNubah}(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.hhMMhj yubj6)}(hhh]h)}(hCivic location data lengthh]hCivic location data length}(hj+yhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'yhMMhj(yubah}(h]h ]h"]h$]h&]uh1j5hj yubeh}(h]h ]h"]h$]h&]uh1jhj'yhMMhjKtubj)}(h$``he_bss_color`` BSS Color settings h](j)}(h``he_bss_color``h]j)}(hjKyh]h he_bss_color}(hjMyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIyubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMNhjEyubj6)}(hhh]h)}(hBSS Color settingsh]hBSS Color settings}(hjdyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`yhMNhjayubah}(h]h ]h"]h$]h&]uh1j5hjEyubeh}(h]h ]h"]h$]h&]uh1jhj`yhMNhjKtubj)}(h^``he_bss_color_valid`` indicates whether bss color attribute is present in beacon data or not.h](j)}(h``he_bss_color_valid``h]j)}(hjyh]hhe_bss_color_valid}(hjyhhhNhNubah}(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.hhMOhj~yubj6)}(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&]uh1hhjyhMOhjyubah}(h]h ]h"]h$]h&]uh1j5hj~yubeh}(h]h ]h"]h$]h&]uh1jhjyhMOhjKtubeh}(h]h ]h"]h$]h&]uh1jhjtubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_ap_settings (C struct)c.cfg80211_ap_settingshNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hcfg80211_ap_settingsh]jo)}(hstruct cfg80211_ap_settingsh](ju)}(hjnh]hstruct}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjyhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMVubj)}(h h]h }(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjyhhhjyhMVubj)}(hcfg80211_ap_settingsh]j)}(hjyh]hcfg80211_ap_settings}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjyubah}(h]h ](jjeh"]h$]h&]jjuh1jhjyhhhjyhMVubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjyhhhjyhMVubah}(h]jyah ](jjeh"]h$]h&]jj)jhuh1jhhjyhMVhjyhhubj)}(hhh]h)}(hAP configurationh]hAP configuration}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjzhhubah}(h]h ]h"]h$]h&]uh1jhjyhhhjyhMVubeh}(h]h ](j$structeh"]h$]h&]jj$jj7zjj7zjjjuh1jchhhjbhNhNubj)}(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}(hjCzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?zubh:}(hj?zhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj;zubj)}(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; };}hj\zsbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj;zubh)}(h **Members**h]j)}(hjmzh]hMembers}(hjozhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkzubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj;zubj)}(hhh](j)}(h'``chandef`` defines the channel to use h](j)}(h ``chandef``h]j)}(hjzh]hchandef}(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)}(hdefines the channel to useh]hdefines the channel to use}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzhMhjzubah}(h]h ]h"]h$]h&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhjzhMhjzubj)}(h``beacon`` beacon data h](j)}(h ``beacon``h]j)}(hjzh]hbeacon}(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 beacon datah]h beacon data}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzhMhjzubah}(h]h ]h"]h$]h&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhjzhMhjzubj)}(h$``beacon_interval`` beacon interval h](j)}(h``beacon_interval``h]j)}(hjzh]hbeacon_interval}(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.hhMhjzubj6)}(hhh]h)}(hbeacon intervalh]hbeacon interval}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{hMhj{ubah}(h]h ]h"]h$]h&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhj{hMhjzubj)}(h``dtim_period`` DTIM period h](j)}(h``dtim_period``h]j)}(hj7{h]h dtim_period}(hj9{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5{ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj1{ubj6)}(hhh]h)}(h DTIM periodh]h DTIM period}(hjP{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjL{hMhjM{ubah}(h]h ]h"]h$]h&]uh1j5hj1{ubeh}(h]h ]h"]h$]h&]uh1jhjL{hMhjzubj)}(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)}(hjp{h]hssid}(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.hhMhjj{ubj6)}(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&]uh1j5hjj{ubeh}(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.hhMhj{ubj6)}(hhh]h)}(hlength of **ssid**h](h length of }(hj{hhhNhNubj)}(h**ssid**h]hssid}(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{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.hhMhj6|ubj6)}(hhh]h)}(hcrypto settingsh]hcrypto settings}(hjU|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQ|hMhjR|ubah}(h]h ]h"]h$]h&]uh1j5hj6|ubeh}(h]h ]h"]h$]h&]uh1jhjQ|hMhjzubj)}(h!``privacy`` the BSS uses privacy h](j)}(h ``privacy``h]j)}(hju|h]hprivacy}(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:48: ./include/net/cfg80211.hhMhjo|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&]uh1j5hjo|ubeh}(h]h ]h"]h$]h&]uh1jhj|hMhjzubj)}(h.``auth_type`` Authentication type (algorithm) h](j)}(h ``auth_type``h]j)}(hj|h]h auth_type}(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)}(hAuthentication type (algorithm)h]hAuthentication type (algorithm)}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hMhj|ubah}(h]h ]h"]h$]h&]uh1j5hj|ubeh}(h]h ]h"]h$]h&]uh1jhj|hMhjzubj)}(hJ``inactivity_timeout`` time in seconds to determine station's inactivity. h](j)}(h``inactivity_timeout``h]j)}(hj|h]hinactivity_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.hhMhj|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&]uh1j5hj|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}(hj9}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5}hMhj6}ubah}(h]h ]h"]h$]h&]uh1j5hj}ubeh}(h]h ]h"]h$]h&]uh1jhj5}hMhjzubj)}(h$``p2p_opp_ps`` P2P opportunistic PS h](j)}(h``p2p_opp_ps``h]j)}(hjY}h]h p2p_opp_ps}(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:48: ./include/net/cfg80211.hhMhjS}ubj6)}(hhh]h)}(hP2P opportunistic PSh]hP2P opportunistic PS}(hjr}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjn}hMhjo}ubah}(h]h ]h"]h$]h&]uh1j5hjS}ubeh}(h]h ]h"]h$]h&]uh1jhjn}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)}(hj}h]hpbss}(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@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.}(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)}(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}(hjA~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.hhMhj9~ubj6)}(hhh]h)}(h1HT capabilities (or ``NULL`` if HT isn't enabled)h](hHT capabilities (or }(hjX~hhhNhNubj)}(h``NULL``h]hNULL}(hj`~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjX~ubh if HT isn’t enabled)}(hjX~hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjT~hMhjU~ubah}(h]h ]h"]h$]h&]uh1j5hj9~ubeh}(h]h ]h"]h$]h&]uh1jhjT~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)}(hj~h]hhe_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)}(h1HE capabilities (or ``NULL`` if HE isn't enabled)h](hHE capabilities (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>``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&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h1HE operation IE (or ``NULL`` if HE isn't enabled)h](hHE operation IE (or }(hj9hhhNhNubj)}(h``NULL``h]hNULL}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubh if HE isn’t enabled)}(hj9hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj5hMhj6ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj5hMhjzubj)}(h@``eht_cap`` EHT capabilities (or ``NULL`` if EHT isn't enabled) h](j)}(h ``eht_cap``h]j)}(hjkh]heht_cap}(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.hhMhjeubj6)}(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&]uh1j5hjeubeh}(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)}(hjh]heht_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)}(h3EHT operation IE (or ``NULL`` if EHT isn't enabled)h](hEHT operation IE (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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjzubj)}(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.hhMhjubj6)}(hhh]h)}(hstations must support HTh]hstations must support HT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjzubj)}(h+``vht_required`` stations must support VHT h](j)}(h``vht_required``h]j)}(hj:h]h vht_required}(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)}(hstations must support VHTh]hstations must support VHT}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhjOhMhjPubah}(h]h ]h"]h$]h&]uh1j5hj4ubeh}(h]h ]h"]h$]h&]uh1jhjOhMhjzubj)}(h)``he_required`` stations must support HE h](j)}(h``he_required``h]j)}(hjsh]h he_required}(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)}(hstations must support HEh]hstations must support HE}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjmubeh}(h]h ]h"]h$]h&]uh1jhjhMhjzubj)}(hG``sae_h2e_required`` stations must support direct H2E technique in SAE h](j)}(h``sae_h2e_required``h]j)}(hjh]hsae_h2e_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)}(h1stations must support direct H2E technique in SAEh]h1stations must support direct H2E technique in SAE}(hjŀhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhj€ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjzubj)}(h*``twt_responder`` Enable Target Wait Time h](j)}(h``twt_responder``h]j)}(hjh]h twt_responder}(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)}(hEnable Target Wait Timeh]hEnable Target Wait Time}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hj߀ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjzubj)}(hd``flags`` flags, as defined in :c:type:`enum nl80211_ap_settings_flags ` h](j)}(h ``flags``h]j)}(hjh]hflags}(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)}(hYflags, as defined in :c:type:`enum nl80211_ap_settings_flags `h](hflags, as defined in }(hj7hhhNhNubh)}(hD:c:type:`enum nl80211_ap_settings_flags `h]j)}(hjAh]henum nl80211_ap_settings_flags}(hjChhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6nl80211_ap_settings_flagsuh1hhj3hMhj7ubeh}(h]h ]h"]h$]h&]uh1hhj3hMhj4ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj3hMhjzubj)}(h.``he_obss_pd`` OBSS Packet Detection settings h](j)}(h``he_obss_pd``h]j)}(hjvh]h he_obss_pd}(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)}(hOBSS Packet Detection settingsh]hOBSS Packet Detection settings}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjpubeh}(h]h ]h"]h$]h&]uh1jhjhMhjzubj)}(h:``fils_discovery`` FILS discovery transmission parameters h](j)}(h``fils_discovery``h]j)}(hjh]hfils_discovery}(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&FILS discovery transmission parametersh]h&FILS discovery transmission parameters}(hjȁhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjāhMhjŁubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjāhMhjzubj)}(hK``unsol_bcast_probe_resp`` Unsolicited broadcast probe response parameters h](j)}(h``unsol_bcast_probe_resp``h]j)}(hjh]hunsol_bcast_probe_resp}(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/Unsolicited broadcast probe response parametersh]h/Unsolicited broadcast probe response parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjzubj)}(h1``mbssid_config`` AP settings for multiple bssid h](j)}(h``mbssid_config``h]j)}(hj!h]h mbssid_config}(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)}(hAP settings for multiple bssidh]hAP settings for multiple bssid}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hMhj7ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj6hMhjzubj)}(h2``s1g_long_beacon_period`` S1G long beacon period h](j)}(h``s1g_long_beacon_period``h]j)}(hjZh]hs1g_long_beacon_period}(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.hhMhjTubj6)}(hhh]h)}(hS1G long beacon periodh]hS1G long beacon period}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhjohMhjpubah}(h]h ]h"]h$]h&]uh1j5hjTubeh}(h]h ]h"]h$]h&]uh1jhjohMhjzubj)}(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}(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&]uh1jhjhMhjzubeh}(h]h ]h"]h$]h&]uh1jhj;zubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(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.hhMhjbhhubh)}(h"Used to configure an AP interface.h]h"Used to configure an AP interface.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_station_parameters (C struct)c.station_parametershNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hstation_parametersh]jo)}(hstruct station_parametersh](ju)}(hjnh]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 }(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhj!hMubj)}(hstation_parametersh]j)}(hjh]hstation_parameters}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhj!hMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj hhhj!hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhj!hMhj hhubj)}(hhh]h)}(hstation parametersh]hstation parameters}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjShhubah}(h]h ]h"]h$]h&]uh1jhj hhhj!hMubeh}(h]h ](j$structeh"]h$]h&]jj$jjnjjnjjjuh1jchhhjbhNhNubj)}(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}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvubh:}(hjvhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjrubj)}(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&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjrubh)}(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.hhMhjrubj)}(hhh](j)}(h1``vlan`` vlan interface station should belong to h](j)}(h``vlan``h]j)}(hjÃh]hvlan}(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'vlan interface station should belong toh]h'vlan interface station should belong to}(hj܃hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj؃hMhjكubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj؃hMhjubj)}(hY``sta_flags_mask`` station flags that changed (bitmask of BIT(``NL80211_STA_FLAG_``...)) h](j)}(h``sta_flags_mask``h]j)}(hjh]hsta_flags_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)}(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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hR``sta_flags_set`` station flags values (bitmask of BIT(``NL80211_STA_FLAG_``...)) h](j)}(h``sta_flags_set``h]j)}(hjHh]h sta_flags_set}(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.hhMhjBubj6)}(hhh]h)}(h?station flags values (bitmask of BIT(``NL80211_STA_FLAG_``...))h](h%station flags values (bitmask of BIT(}(hjahhhNhNubj)}(h``NL80211_STA_FLAG_``h]hNL80211_STA_FLAG_}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubh...))}(hjahhhNhNubeh}(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&]uh1j5hjBubeh}(h]h ]h"]h$]h&]uh1jhj]hMhjubj)}(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 }(hjhhhNhNubh)}(hL:c:type:`enum station_parameters_apply_mask `h]j)}(hjh]h"enum station_parameters_apply_mask}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6station_parameters_apply_maskuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubeh}(h]h ]h"]h$]h&]uh1hhjԄhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h8``listen_interval`` listen interval or -1 for no change h](j)}(h``listen_interval``h]j)}(hjh]hlisten_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.hhMhjubj6)}(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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h"``aid`` AID or zero for no change h](j)}(h``aid``h]j)}(hj&h]haid}(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)}(hAID or zero for no changeh]hAID or zero for no change}(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-``vlan_id`` VLAN ID for station (if nonzero) h](j)}(h ``vlan_id``h]j)}(hj_h]hvlan_id}(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.hhMhjYubj6)}(hhh]h)}(h VLAN ID for station (if nonzero)h]h VLAN ID for station (if nonzero)}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjthMhjuubah}(h]h ]h"]h$]h&]uh1j5hjYubeh}(h]h ]h"]h$]h&]uh1jhjthMhjubj)}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h&``plink_action`` plink action to take h](j)}(h``plink_action``h]j)}(hjхh]h plink_action}(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)}(hplink action to takeh]hplink action to take}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hj˅ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h6``plink_state`` set the peer link state for a station h](j)}(h``plink_state``h]j)}(hj h]h plink_state}(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%set the peer link state for a stationh]h%set the peer link state for a station}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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)}(hjCh]h uapsd_queues}(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)}(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.hhMhjYubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhjXhMhjubj)}(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)}(hj}h]hmax_sp}(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.hhMhjwubj6)}(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&]uh1j5hjwubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hV``local_pm`` local link-specific mesh power save mode (no change when set to unknown) h](j)}(h ``local_pm``h]j)}(hjh]hlocal_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)}(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)}(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̆hMhjubj)}(h"``capability`` station capability h](j)}(h``capability``h]j)}(hjh]h capability}(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)}(hstation capabilityh]hstation capability}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h3``ext_capab`` extended capabilities of the station h](j)}(h ``ext_capab``h]j)}(hj*h]h ext_capab}(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$extended capabilities of the stationh]h$extended capabilities of the station}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hMhj@ubah}(h]h ]h"]h$]h&]uh1j5hj$ubeh}(h]h ]h"]h$]h&]uh1jhj?hMhjubj)}(h2``ext_capab_len`` number of extended capabilities h](j)}(h``ext_capab_len``h]j)}(hjch]h ext_capab_len}(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)}(hnumber of extended capabilitiesh]hnumber of extended capabilities}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxhMhjyubah}(h]h ]h"]h$]h&]uh1j5hj]ubeh}(h]h ]h"]h$]h&]uh1jhjxhMhjubj)}(h@``supported_channels`` supported channels in IEEE 802.11 format h](j)}(h``supported_channels``h]j)}(hjh]hsupported_channels}(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 channels in IEEE 802.11 formath]h(supported channels in IEEE 802.11 format}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h8``supported_channels_len`` number of supported channels h](j)}(h``supported_channels_len``h]j)}(hjՇh]hsupported_channels_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.hhMhjχubj6)}(hhh]h)}(hnumber of supported channelsh]hnumber of supported channels}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjχubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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&]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,supported oper classes in IEEE 802.11 formath]h,supported oper classes in IEEE 802.11 format}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#hMhj$ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj#hMhjubj)}(hE``supported_oper_classes_len`` number of supported operating classes h](j)}(h``supported_oper_classes_len``h]j)}(hjGh]hsupported_oper_classes_len}(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)}(h%number of supported operating classesh]h%number of supported operating classes}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\hMhj]ubah}(h]h ]h"]h$]h&]uh1j5hjAubeh}(h]h ]h"]h$]h&]uh1jhj\hMhjubj)}(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&]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)}(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&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h=``airtime_weight`` airtime scheduler weight for this station h](j)}(h``airtime_weight``h]j)}(hjh]hairtime_weight}(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)airtime scheduler weight for this stationh]h)airtime scheduler weight for this station}(hj҈hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjΈhMhjψubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjΈhMhjubj)}(hY``eml_cap_present`` Specifies if EML capabilities field (**eml_cap**) is present/updated h](j)}(h``eml_cap_present``h]j)}(hjh]heml_cap_present}(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)}(hDSpecifies if EML capabilities field (**eml_cap**) is present/updatedh](h%Specifies if EML capabilities field (}(hj hhhNhNubj)}(h **eml_cap**h]heml_cap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubh) is present/updated}(hj hhhNhNubeh}(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-``eml_cap`` EML capabilities of this station h](j)}(h ``eml_cap``h]j)}(hj>h]heml_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.hhMhj8ubj6)}(hhh]h)}(h EML capabilities of this stationh]h EML capabilities of this station}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShMhjTubah}(h]h ]h"]h$]h&]uh1j5hj8ubeh}(h]h ]h"]h$]h&]uh1jhjShMhjubj)}(h(``link_sta_params`` link related params.h](j)}(h``link_sta_params``h]j)}(hjwh]hlink_sta_params}(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)}(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&]uh1j5hjqubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjrubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(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.hhMhjbhhubh)}(h(Used to change and create a new station.h]h(Used to change and create a new station.}(hjЉhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_rate_info_flags (C enum)c.rate_info_flagshNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hrate_info_flagsh]jo)}(henum rate_info_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.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubj)}(hrate_info_flagsh]j)}(hjh]hrate_info_flags}(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)}(hbitrate info flagsh]hbitrate info flags}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM]hj7hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](j$enumeh"]h$]h&]jj$jjRjjRjjjuh1jchhhjbhNhNubj)}(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}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMahjVubj)}(hhh](j)}(h5``RATE_INFO_FLAGS_MCS`` mcs field filled with HT MCS h](j)}(h``RATE_INFO_FLAGS_MCS``h]j)}(hj{h]hRATE_INFO_FLAGS_MCS}(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.hhMdhjuubj6)}(hhh]h)}(hmcs field filled with HT MCSh]hmcs field filled with HT MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMdhjubah}(h]h ]h"]h$]h&]uh1j5hjuubeh}(h]h ]h"]h$]h&]uh1jhjhMdhjrubj)}(h:``RATE_INFO_FLAGS_VHT_MCS`` mcs field filled with VHT MCS h](j)}(h``RATE_INFO_FLAGS_VHT_MCS``h]j)}(hjh]hRATE_INFO_FLAGS_VHT_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.hhMghjubj6)}(hhh]h)}(hmcs field filled with VHT MCSh]hmcs field filled with VHT MCS}(hj͊hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjɊhMghjʊubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjɊhMghjrubj)}(h2``RATE_INFO_FLAGS_SHORT_GI`` 400ns guard interval h](j)}(h``RATE_INFO_FLAGS_SHORT_GI``h]j)}(hjh]hRATE_INFO_FLAGS_SHORT_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.hhMjhjubj6)}(hhh]h)}(h400ns guard intervalh]h400ns guard interval}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMjhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMjhjrubj)}(h"``RATE_INFO_FLAGS_DMG`` 60GHz MCS h](j)}(h``RATE_INFO_FLAGS_DMG``h]j)}(hj&h]hRATE_INFO_FLAGS_DMG}(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.hhMmhj ubj6)}(hhh]h)}(h 60GHz MCSh]h 60GHz MCS}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj;hMmhj<ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj;hMmhjrubj)}(h.``RATE_INFO_FLAGS_HE_MCS`` HE MCS information h](j)}(h``RATE_INFO_FLAGS_HE_MCS``h]j)}(hj_h]hRATE_INFO_FLAGS_HE_MCS}(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)}(hHE MCS informationh]hHE MCS information}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjthMphjuubah}(h]h ]h"]h$]h&]uh1j5hjYubeh}(h]h ]h"]h$]h&]uh1jhjthMphjrubj)}(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.hhMshjubj6)}(hhh]h)}(h60GHz MCS in EDMG modeh]h60GHz MCS in EDMG mode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMshjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMshjrubj)}(h:``RATE_INFO_FLAGS_EXTENDED_SC_DMG`` 60GHz extended SC MCS h](j)}(h#``RATE_INFO_FLAGS_EXTENDED_SC_DMG``h]j)}(hjыh]hRATE_INFO_FLAGS_EXTENDED_SC_DMG}(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.hhMvhjˋubj6)}(hhh]h)}(h60GHz extended SC MCSh]h60GHz extended SC MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMvhjubah}(h]h ]h"]h$]h&]uh1j5hjˋubeh}(h]h ]h"]h$]h&]uh1jhjhMvhjrubj)}(h0``RATE_INFO_FLAGS_EHT_MCS`` EHT MCS information h](j)}(h``RATE_INFO_FLAGS_EHT_MCS``h]j)}(hj h]hRATE_INFO_FLAGS_EHT_MCS}(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.hhMyhjubj6)}(hhh]h)}(hEHT MCS informationh]hEHT MCS information}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMyhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMyhjrubj)}(h9``RATE_INFO_FLAGS_S1G_MCS`` MCS field filled with S1G MCSh](j)}(h``RATE_INFO_FLAGS_S1G_MCS``h]j)}(hjCh]hRATE_INFO_FLAGS_S1G_MCS}(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)}(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.hhM|hjYubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhjXhM{hjrubeh}(h]h ]h"]h$]h&]uh1jhjVubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(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~hjbhhubh)}(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.hhM^hjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_rate_info (C struct) c.rate_infohNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(h rate_infoh]jo)}(hstruct rate_infoh](ju)}(hjnh]hstruct}(hjČhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMdubj)}(h h]h }(hjҌhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjьhMdubj)}(h rate_infoh]j)}(hjh]h rate_info}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjьhMdubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjьhMdubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjьhMdhjhhubj)}(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&]uh1jhjhhhjьhMdubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhjbhNhNubj)}(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}(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.hhMhj"ubj)}(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; };}hjCsbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj"ubh)}(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.hhMhj"ubj)}(hhh](j)}(hQ``flags`` bitflag of flags from :c:type:`enum rate_info_flags ` h](j)}(h ``flags``h]j)}(hjsh]hflags}(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)}(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 refexplicitrefwarnjS jW j6rate_info_flagsuh1hhjhMhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjmubeh}(h]h ]h"]h$]h&]uh1jhjhMhjjubj)}(h.``legacy`` bitrate in 100kbit/s for 802.11abg h](j)}(h ``legacy``h]j)}(hjˍh]hlegacy}(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"bitrate in 100kbit/s for 802.11abgh]h"bitrate in 100kbit/s for 802.11abg}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjōubeh}(h]h ]h"]h$]h&]uh1jhjhMhjjubj)}(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&]uh1jhjhMhjjubj)}(h*``nss`` number of streams (VHT & HE only) h](j)}(h``nss``h]j)}(hj=h]hnss}(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.hhMhj7ubj6)}(hhh]h)}(h!number of streams (VHT & HE only)h]h!number of streams (VHT & HE only)}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRhMhjSubah}(h]h ]h"]h$]h&]uh1j5hj7ubeh}(h]h ]h"]h$]h&]uh1jhjRhMhjjubj)}(hC``bw`` bandwidth (from :c:type:`enum rate_info_bw `) h](j)}(h``bw``h]j)}(hjvh]hbw}(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;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 refexplicitrefwarnjS jW j6 rate_info_bwuh1hhjhMhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjpubeh}(h]h ]h"]h$]h&]uh1jhjhMhjjubj)}(hP``he_gi`` HE guard interval (from :c:type:`enum nl80211_he_gi `) h](j)}(h ``he_gi``h]j)}(hjҎh]hhe_gi}(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)}(hEHE guard interval (from :c:type:`enum nl80211_he_gi `)h](hHE guard interval (from }(hjhhhNhNubh)}(h,:c:type:`enum nl80211_he_gi `h]j)}(hjh]henum nl80211_he_gi}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6 nl80211_he_giuh1hhjhMhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hj̎ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjjubj)}(h``he_dcm`` HE DCM value h](j)}(h ``he_dcm``h]j)}(hj.h]hhe_dcm}(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)}(h HE DCM valueh]h HE DCM value}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChMhjDubah}(h]h ]h"]h$]h&]uh1j5hj(ubeh}(h]h ]h"]h$]h&]uh1jhjChMhjjubj)}(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)}(hjgh]h he_ru_alloc}(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)}(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)}(hjh]henum nl80211_he_ru_alloc}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW 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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhj}ubah}(h]h ]h"]h$]h&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hMhjjubj)}(hD``n_bonded_ch`` In case of EDMG the number of bonded channels (1-4) h](j)}(h``n_bonded_ch``h]j)}(hj֏h]h n_bonded_ch}(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)}(h3In case of EDMG the number of bonded channels (1-4)h]h3In case of EDMG the number of bonded channels (1-4)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjЏubeh}(h]h ]h"]h$]h&]uh1jhjhMhjjubj)}(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&]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)}(hHEHT guard interval (from :c:type:`enum nl80211_eht_gi `)h](hEHT guard interval (from }(hj(hhhNhNubh)}(h.:c:type:`enum nl80211_eht_gi `h]j)}(hj2h]henum nl80211_eht_gi}(hj4hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6nl80211_eht_giuh1hhj$hMhj(ubh)}(hj(hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj$hMhj%ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj$hMhjjubj)}(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)}(hjkh]h eht_ru_alloc}(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.hhMhjeubj6)}(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 refexplicitrefwarnjS jW j6nl80211_eht_ru_allocuh1hhjhMhjubh, only valid if bw is }(hjhhhNhNubj)}(h``RATE_INFO_BW_EHT_RU``h]hRATE_INFO_BW_EHT_RU}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjeubeh}(h]h ]h"]h$]h&]uh1jhjhMhjjubeh}(h]h ]h"]h$]h&]uh1jhj"ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(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.hhMhjbhhubh)}(h5Information about a receiving or transmitting bitrateh]h5Information about a receiving or transmitting bitrate}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_station_info (C struct)c.station_infohNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(h station_infoh]jo)}(hstruct station_infoh](ju)}(hjnh]hstruct}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/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&]uh1jhjhhhj-hMubj)}(h station_infoh]j)}(hjh]h station_info}(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj<ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhj-hMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhj-hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhj-hMhjhhubj)}(hhh]h)}(hstation informationh]hstation information}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMphj_hhubah}(h]h ]h"]h$]h&]uh1jhjhhhj-hMubeh}(h]h ](j$structeh"]h$]h&]jj$jjzjjzjjjuh1jchhhjbhNhNubj)}(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.hhMthj~ubj)}(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]; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMvhj~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.hhMhj~ubj)}(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)}(hjϑh]hfilled}(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.hhMvhjɑubj6)}(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 }(hjhhhNhNubh)}(h2:c:type:`enum nl80211_sta_info `h]j)}(hjh]henum nl80211_sta_info}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6nl80211_sta_infouh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMuhjubh8 to indicate the relevant values in this struct for them}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMuhjubah}(h]h ]h"]h$]h&]uh1j5hjɑubeh}(h]h ]h"]h$]h&]uh1jhjhMvhjƑubj)}(hC``connected_time`` time(in secs) since a station is last connected h](j)}(h``connected_time``h]j)}(hj,h]hconnected_time}(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)}(h/time(in secs) since a station is last connectedh]h/time(in secs) since a station is last connected}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjAhMwhjBubah}(h]h ]h"]h$]h&]uh1j5hj&ubeh}(h]h ]h"]h$]h&]uh1jhjAhMwhjƑubj)}(hK``inactive_time`` time since last station activity (tx/rx) in milliseconds h](j)}(h``inactive_time``h]j)}(hjeh]h inactive_time}(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.hhMxhj_ubj6)}(hhh]h)}(h8time since last station activity (tx/rx) in millisecondsh]h8time since last station activity (tx/rx) in milliseconds}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzhMxhj{ubah}(h]h ]h"]h$]h&]uh1j5hj_ubeh}(h]h ]h"]h$]h&]uh1jhjzhMxhjƑubj)}(h2``assoc_at`` bootime (ns) of the last association h](j)}(h ``assoc_at``h]j)}(hjh]hassoc_at}(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)}(h$bootime (ns) of the last associationh]h$bootime (ns) of the last association}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMyhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMyhjƑubj)}(h>``rx_bytes`` bytes (size of MPDUs) received from this station h](j)}(h ``rx_bytes``h]j)}(hjגh]hrx_bytes}(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.hhMzhjђubj6)}(hhh]h)}(h0bytes (size of MPDUs) received from this stationh]h0bytes (size of MPDUs) received from this station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMzhjubah}(h]h ]h"]h$]h&]uh1j5hjђubeh}(h]h ]h"]h$]h&]uh1jhjhMzhjƑubj)}(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.hhM{hj ubj6)}(hhh]h)}(h1bytes (size of MPDUs) transmitted to this stationh]h1bytes (size of MPDUs) transmitted to this station}(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``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)}(hjIh]hsignal}(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)}(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_.}(hjbhhhNhNubah}(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&]uh1j5hjCubeh}(h]h ]h"]h$]h&]uh1jhj^hM}hjƑubj)}(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.hhMhj}ubj6)}(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.hhM~hjubah}(h]h ]h"]h$]h&]uh1j5hj}ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(hO``chains`` bitmask for filled values in **chain_signal**, **chain_signal_avg** h](j)}(h ``chains``h]j)}(hjh]hchains}(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)}(hCbitmask for filled values in **chain_signal**, **chain_signal_avg**h](hbitmask for filled values in }(hj֓hhhNhNubj)}(h**chain_signal**h]h chain_signal}(hjޓhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj֓ubh, }(hj֓hhhNhNubj)}(h**chain_signal_avg**h]hchain_signal_avg}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj֓ubeh}(h]h ]h"]h$]h&]uh1hhjғhMhjӓubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjғhMhjƑubj)}(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.hhMhjubj6)}(hhh]h)}(h8per-chain signal strength of last received packet in dBmh]h8per-chain signal strength of last received packet in dBm}(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>``chain_signal_avg`` per-chain signal strength average in dBm h](j)}(h``chain_signal_avg``h]j)}(hjOh]hchain_signal_avg}(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(per-chain signal strength average in dBmh]h(per-chain signal strength average in dBm}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdhMhjeubah}(h]h ]h"]h$]h&]uh1j5hjIubeh}(h]h ]h"]h$]h&]uh1jhjdhMhjƑubj)}(h5``txrate`` current unicast bitrate from this station h](j)}(h ``txrate``h]j)}(hjh]htxrate}(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)current unicast bitrate from this stationh]h)current unicast bitrate from this station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(h3``rxrate`` current unicast bitrate to this station h](j)}(h ``rxrate``h]j)}(hjh]hrxrate}(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'current unicast bitrate to this stationh]h'current unicast bitrate to 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)}(hC``rx_packets`` packets (MSDUs & MMPDUs) received from this station h](j)}(h``rx_packets``h]j)}(hjh]h rx_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.hhMhjubj6)}(hhh]h)}(h3packets (MSDUs & MMPDUs) received from this stationh]h3packets (MSDUs & MMPDUs) received from this station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(hD``tx_packets`` packets (MSDUs & MMPDUs) transmitted to this station h](j)}(h``tx_packets``h]j)}(hj3h]h tx_packets}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj-ubj6)}(hhh]h)}(h4packets (MSDUs & MMPDUs) transmitted to this stationh]h4packets (MSDUs & MMPDUs) transmitted to this station}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHhMhjIubah}(h]h ]h"]h$]h&]uh1j5hj-ubeh}(h]h ]h"]h$]h&]uh1jhjHhMhjƑubj)}(h/``tx_retries`` cumulative retry counts (MPDUs) h](j)}(h``tx_retries``h]j)}(hjlh]h tx_retries}(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)}(hcumulative retry counts (MPDUs)h]hcumulative retry counts (MPDUs)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(hP``tx_failed`` number of failed transmissions (MPDUs) (retries exceeded, no ACK) h](j)}(h ``tx_failed``h]j)}(hjh]h tx_failed}(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)}(hAnumber of failed transmissions (MPDUs) (retries exceeded, no ACK)h]hAnumber of failed transmissions (MPDUs) (retries exceeded, no ACK)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(h5``rx_dropped_misc`` Dropped for un-specified reason. h](j)}(h``rx_dropped_misc``h]j)}(hjޕh]hrx_dropped_misc}(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 Dropped for un-specified reason.h]h Dropped for un-specified reason.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjؕubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(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.hhMhjubj6)}(hhh]h)}(hcurrent BSS parametersh]hcurrent BSS parameters}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,hMhj-ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj,hMhjƑubj)}(h*``sta_flags`` station flags mask & values h](j)}(h ``sta_flags``h]j)}(hjPh]h sta_flags}(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)}(hstation flags mask & valuesh]hstation flags mask & values}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehMhjfubah}(h]h ]h"]h$]h&]uh1j5hjJubeh}(h]h ]h"]h$]h&]uh1jhjehMhjƑubj)}(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)}(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.hhMhjubj6)}(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.}(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)}(hG``beacon_loss_count`` Number of times beacon loss event has triggered. h](j)}(h``beacon_loss_count``h]j)}(hjÖh]hbeacon_loss_count}(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)}(h0Number of times beacon loss event has triggered.h]h0Number of times beacon loss event has triggered.}(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``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)}(hjh]h assoc_req_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)}(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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(h@``assoc_req_ies_len`` Length of assoc_req_ies buffer in octets. h](j)}(h``assoc_req_ies_len``h]j)}(hj6h]hassoc_req_ies_len}(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)}(h)Length of assoc_req_ies buffer in octets.h]h)Length of assoc_req_ies buffer in octets.}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKhMhjLubah}(h]h ]h"]h$]h&]uh1j5hj0ubeh}(h]h ]h"]h$]h&]uh1jhjKhMhjƑubj)}(h?``t_offset`` Time offset of the station relative to this host. h](j)}(h ``t_offset``h]j)}(hjoh]ht_offset}(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)}(h1Time offset of the station relative to this host.h]h1Time offset of the station relative to this host.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjiubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(h``llid`` mesh local link id h](j)}(h``llid``h]j)}(hjh]hllid}(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 local link idh]hmesh local link id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(h``plid`` mesh peer link id h](j)}(h``plid``h]j)}(hjh]hplid}(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)}(hmesh peer link idh]hmesh peer link id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjۗubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(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}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hMhj0ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj/hMhjƑubj)}(h?``connected_to_gate`` true if mesh STA has a path to mesh gate h](j)}(h``connected_to_gate``h]j)}(hjSh]hconnected_to_gate}(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)}(h(true if mesh STA has a path to mesh gateh]h(true if mesh STA has a path to mesh gate}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhMhjiubah}(h]h ]h"]h$]h&]uh1j5hjMubeh}(h]h ]h"]h$]h&]uh1jhjhhMhjƑubj)}(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&]uh1jhjubah}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(h2``airtime_link_metric`` mesh airtime link metric. h](j)}(h``airtime_link_metric``h]j)}(hjŘh]hairtime_link_metric}(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)}(hmesh airtime link metric.h]hmesh airtime link metric.}(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,``local_pm`` local mesh STA power save mode h](j)}(h ``local_pm``h]j)}(hjh]hlocal_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)}(hlocal mesh STA power save modeh]hlocal mesh STA power save mode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(h*``peer_pm`` peer mesh STA power save mode h](j)}(h ``peer_pm``h]j)}(hj7h]hpeer_pm}(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)}(hpeer mesh STA power save modeh]hpeer mesh STA power save mode}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhMhjMubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhjLhMhjƑubj)}(h1``nonpeer_pm`` non-peer mesh STA power save mode h](j)}(h``nonpeer_pm``h]j)}(hjph]h nonpeer_pm}(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)}(h!non-peer mesh STA power save modeh]h!non-peer mesh STA power save mode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(he``expected_throughput`` expected throughput in kbps (including 802.11 headers) towards this station. h](j)}(h``expected_throughput``h]j)}(hjh]hexpected_throughput}(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)}(hLexpected throughput in kbps (including 802.11 headers) towards this station.h]hLexpected throughput in kbps (including 802.11 headers) towards this 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&]uh1jhjhMhjƑubj)}(h5``airtime_weight`` current airtime scheduling weight h](j)}(h``airtime_weight``h]j)}(hjh]hairtime_weight}(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!current airtime scheduling weighth]h!current airtime scheduling weight}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjݙubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(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.}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1hMhj2ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj1hMhjƑubj)}(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)}(hjUh]havg_ack_signal}(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)}(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.}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjkubah}(h]h ]h"]h$]h&]uh1j5hjOubeh}(h]h ]h"]h$]h&]uh1jhjjhMhjƑubj)}(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.hhMhjubj6)}(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 }(hjhhhNhNubh)}(h8:c:type:`struct cfg80211_tid_stats `h]j)}(hjh]hstruct cfg80211_tid_stats}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6cfg80211_tid_statsuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubhv, using the last (IEEE80211_NUM_TIDS) index for MSDUs not encapsulated in QoS-MPDUs. Note that this doesn’t use the }(hjhhhNhNubj)}(h **filled**h]hfilled}(hjԚhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh bit, but is used if non-NULL.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjϚhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(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&]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 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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(hN``rx_duration`` aggregate PPDU duration(usecs) for all the frames from a peer h](j)}(h``rx_duration``h]j)}(hj7h]h rx_duration}(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)}(h=aggregate PPDU duration(usecs) for all the frames from a peerh]h=aggregate PPDU duration(usecs) for all the frames from a peer}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhMhjMubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhjLhMhjƑubj)}(h8``rx_beacon`` number of beacons received from this peer h](j)}(h ``rx_beacon``h]j)}(hjph]h rx_beacon}(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)}(h)number of beacons received from this peerh]h)number of beacons received from this peer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(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)}(hjh]hrx_beacon_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.hhMhjubj6)}(hhh]h)}(hDsignal strength average (in dBm) for beacons received from this peerh]hDsignal strength average (in dBm) for beacons received from this peer}(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&]uh1jhjhMhjƑubj)}(h=``rx_mpdu_count`` number of MPDUs received from this station h](j)}(h``rx_mpdu_count``h]j)}(hjh]h rx_mpdu_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.hhMhjݛubj6)}(hhh]h)}(h*number of MPDUs received from this stationh]h*number of MPDUs received from this station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjݛubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(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.}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj2ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj1hMhjƑubj)}(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)}(hjVh]hmlo_params_valid}(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)}(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 }(hjohhhNhNubj)}(h**assoc_link_id**h]h assoc_link_id}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjoubh and }(hjohhhNhNubj)}(h **mld_addr**h]hmld_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjoubh 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.}(hjohhhNhNubeh}(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&]uh1j5hjPubeh}(h]h ]h"]h$]h&]uh1jhjkhMhjƑubj)}(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)}(hjh]h assoc_link_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)}(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.}(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)}(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)}(hjh]hmld_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)}(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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubj)}(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)}(hj(h]hassoc_resp_ies}(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)}(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.}(hjAhhhNhNubah}(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=hMhjƑubj)}(hF``assoc_resp_ies_len`` Length of **assoc_resp_ies** buffer in octets. h](j)}(h``assoc_resp_ies_len``h]j)}(hjbh]hassoc_resp_ies_len}(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.hhMhj\ubj6)}(hhh]h)}(h.Length of **assoc_resp_ies** buffer in octets.h](h Length of }(hj{hhhNhNubj)}(h**assoc_resp_ies**h]hassoc_resp_ies}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{ubh buffer in octets.}(hj{hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjwhMhjxubah}(h]h ]h"]h$]h&]uh1j5hj\ubeh}(h]h ]h"]h$]h&]uh1jhjwhMhjƑubj)}(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)}(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.hhMhjubj6)}(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.}(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)}(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)}(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.hhMhjubj6)}(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&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjƑubeh}(h]h ]h"]h$]h&]uh1jhj~ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(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.hhMhjbhhubh)}(hHStation information filled by driver for get_station() and dump_station.h]hHStation information filled by driver for get_station() and dump_station.}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMqhjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_monitor_flags (C enum)c.monitor_flagshNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(h monitor_flagsh]jo)}(henum monitor_flagsh](ju)}(hjxh]henum}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjchhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMvubj)}(h h]h }(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjchhhjthMvubj)}(h monitor_flagsh]j)}(hjah]h monitor_flags}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjchhhjthMvubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj_hhhjthMvubah}(h]jZah ](jjeh"]h$]h&]jj)jhuh1jhhjthMvhj\hhubj)}(hhh]h)}(h monitor flagsh]h monitor flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMT hjhhubah}(h]h ]h"]h$]h&]uh1jhj\hhhjthMvubeh}(h]h ](j$enumeh"]h$]h&]jj$jjjjjjjuh1jchhhjbhNhNubj)}(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)}(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:48: ./include/net/cfg80211.hhMX hjŞubj)}(hhh](j)}(h7``MONITOR_FLAG_CHANGED`` set if the flags were changed h](j)}(h``MONITOR_FLAG_CHANGED``h]j)}(hjh]hMONITOR_FLAG_CHANGED}(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 if the flags were changedh]hset if the flags were changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM[ hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM[ hjubj)}(h2``MONITOR_FLAG_FCSFAIL`` pass frames with bad FCS h](j)}(h``MONITOR_FLAG_FCSFAIL``h]j)}(hj#h]hMONITOR_FLAG_FCSFAIL}(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)}(hpass frames with bad FCSh]hpass frames with bad FCS}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8hM^ hj9ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj8hM^ hjubj)}(h4``MONITOR_FLAG_PLCPFAIL`` pass frames with bad PLCP h](j)}(h``MONITOR_FLAG_PLCPFAIL``h]j)}(hj\h]hMONITOR_FLAG_PLCPFAIL}(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.hhMa hjVubj6)}(hhh]h)}(hpass frames with bad PLCPh]hpass frames with bad PLCP}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjqhMa hjrubah}(h]h ]h"]h$]h&]uh1j5hjVubeh}(h]h ]h"]h$]h&]uh1jhjqhMa hjubj)}(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.hhMd hjubj6)}(hhh]h)}(hpass control framesh]hpass control frames}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMd hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMd hjubj)}(h3``MONITOR_FLAG_OTHER_BSS`` disable BSSID filtering h](j)}(h``MONITOR_FLAG_OTHER_BSS``h]j)}(hjΟh]hMONITOR_FLAG_OTHER_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.hhMg hjȟubj6)}(hhh]h)}(hdisable BSSID filteringh]hdisable BSSID filtering}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMg hjubah}(h]h ]h"]h$]h&]uh1j5hjȟubeh}(h]h ]h"]h$]h&]uh1jhjhMg hjubj)}(hI``MONITOR_FLAG_COOK_FRAMES`` deprecated, will unconditionally be refused h](j)}(h``MONITOR_FLAG_COOK_FRAMES``h]j)}(hjh]hMONITOR_FLAG_COOK_FRAMES}(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.hhMj hjubj6)}(hhh]h)}(h+deprecated, will unconditionally be refusedh]h+deprecated, will unconditionally be refused}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMj hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMj hjubj)}(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}(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.hhMm hj:ubj6)}(hhh]h)}(h.active monitor, ACKs frames on its MAC addressh]h.active monitor, ACKs frames on its MAC address}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUhMm hjVubah}(h]h ]h"]h$]h&]uh1j5hj:ubeh}(h]h ]h"]h$]h&]uh1jhjUhMm hjubj)}(h?``MONITOR_FLAG_SKIP_TX`` do not pass locally transmitted framesh](j)}(h``MONITOR_FLAG_SKIP_TX``h]j)}(hjyh]hMONITOR_FLAG_SKIP_TX}(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.hhMo hjsubj6)}(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.hhMp hjubah}(h]h ]h"]h$]h&]uh1j5hjsubeh}(h]h ]h"]h$]h&]uh1jhjhMo hjubeh}(h]h ]h"]h$]h&]uh1jhjŞubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(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.hhMr hjbhhubh)}(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.}(hjҠhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMU hjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_mpath_info_flags (C enum)c.mpath_info_flagshNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hmpath_info_flagsh]jo)}(henum mpath_info_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.hhM[ ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM[ ubj)}(hmpath_info_flagsh]j)}(hjh]hmpath_info_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)}(hmesh path information flagsh]hmesh path information flags}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMn hj9hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM[ ubeh}(h]h ](j$enumeh"]h$]h&]jj$jjTjjTjjjuh1jchhhjbhNhNubj)}(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)}(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:48: ./include/net/cfg80211.hhMr hjXubj)}(hhh](j)}(h0``MPATH_INFO_FRAME_QLEN`` **frame_qlen** filled h](j)}(h``MPATH_INFO_FRAME_QLEN``h]j)}(hj}h]hMPATH_INFO_FRAME_QLEN}(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.hhMu hjwubj6)}(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&]uh1hhjhMu hjubah}(h]h ]h"]h$]h&]uh1j5hjwubeh}(h]h ]h"]h$]h&]uh1jhjhMu hjtubj)}(h ``MPATH_INFO_SN`` **sn** filled h](j)}(h``MPATH_INFO_SN``h]j)}(hjġh]h MPATH_INFO_SN}(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.hhMx hjubj6)}(hhh]h)}(h **sn** filledh](j)}(h**sn**h]hsn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjݡubh filled}(hjݡhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj١hMx hjڡubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj١hMx hjtubj)}(h(``MPATH_INFO_METRIC`` **metric** filled h](j)}(h``MPATH_INFO_METRIC``h]j)}(hj h]hMPATH_INFO_METRIC}(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)}(h**metric** filledh](j)}(h **metric**h]hmetric}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$ubh filled}(hj$hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hM{ hj!ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hM{ hjtubj)}(h*``MPATH_INFO_EXPTIME`` **exptime** filled h](j)}(h``MPATH_INFO_EXPTIME``h]j)}(hjRh]hMPATH_INFO_EXPTIME}(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)}(h**exptime** filledh](j)}(h **exptime**h]hexptime}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkubh filled}(hjkhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjghM~ hjhubah}(h]h ]h"]h$]h&]uh1j5hjLubeh}(h]h ]h"]h$]h&]uh1jhjghM~ hjtubj)}(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.hhM hjubj6)}(hhh]h)}(h**discovery_timeout** filledh](j)}(h**discovery_timeout**h]hdiscovery_timeout}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh filled}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjtubj)}(h>``MPATH_INFO_DISCOVERY_RETRIES`` **discovery_retries** filled h](j)}(h ``MPATH_INFO_DISCOVERY_RETRIES``h]j)}(hjh]hMPATH_INFO_DISCOVERY_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 hjڢubj6)}(hhh]h)}(h**discovery_retries** filledh](j)}(h**discovery_retries**h]hdiscovery_retries}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh filled}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjڢubeh}(h]h ]h"]h$]h&]uh1jhjhM hjtubj)}(h&``MPATH_INFO_FLAGS`` **flags** filled h](j)}(h``MPATH_INFO_FLAGS``h]j)}(hj'h]hMPATH_INFO_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.hhM hj!ubj6)}(hhh]h)}(h**flags** filledh](j)}(h **flags**h]hflags}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@ubh filled}(hj@hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj<hM hj=ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj<hM hjtubj)}(h.``MPATH_INFO_HOP_COUNT`` **hop_count** filled h](j)}(h``MPATH_INFO_HOP_COUNT``h]j)}(hjnh]hMPATH_INFO_HOP_COUNT}(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)}(h**hop_count** filledh](j)}(h **hop_count**h]h hop_count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh filled}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhM hjtubj)}(h7``MPATH_INFO_PATH_CHANGE`` **path_change_count** filledh](j)}(h``MPATH_INFO_PATH_CHANGE``h]j)}(hjh]hMPATH_INFO_PATH_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.hhM hjubj6)}(hhh]h)}(h**path_change_count** filledh](j)}(h**path_change_count**h]hpath_change_count}(hjңhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjΣubh filled}(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 hjtubeh}(h]h ]h"]h$]h&]uh1jhjXubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(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 hjbhhubh)}(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)}(hj&h]hstruct mpath_info}(hj(hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6 mpath_infouh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMo hjubh9 it has filled in during get_station() or dump_station().}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjChMo hjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_mpath_info (C struct) c.mpath_infohNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(h mpath_infoh]jo)}(hstruct mpath_infoh](ju)}(hjnh]hstruct}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjchhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMu ubj)}(h h]h }(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjchhhjthMu ubj)}(h mpath_infoh]j)}(hjah]h mpath_info}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjchhhjthMu ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj_hhhjthMu ubah}(h]jZah ](jjeh"]h$]h&]jj)jhuh1jhhjthMu hj\hhubj)}(hhh]h)}(hmesh path informationh]hmesh path 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&]uh1jhj\hhhjthMu ubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhjbhNhNubj)}(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}(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 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; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jh`/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)}(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 }(hj/hhhNhNubh)}(h2:c:type:`enum mpath_info_flags `h]j)}(hj9h]henum mpath_info_flags}(hj;hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6mpath_info_flagsuh1hhj+hM hj/ubeh}(h]h ]h"]h$]h&]uh1hhj+hM hj,ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj+hM hj ubj)}(h<``frame_qlen`` number of queued frames for this destination h](j)}(h``frame_qlen``h]j)}(hjnh]h frame_qlen}(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)}(h,number of queued frames for this destinationh]h,number of queued frames for this destination}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhM hj ubj)}(h``sn`` target sequence number h](j)}(h``sn``h]j)}(hjh]hsn}(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)}(htarget sequence numberh]htarget sequence number}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj ubj)}(h+``metric`` metric (cost) of this mesh path h](j)}(h ``metric``h]j)}(hjh]hmetric}(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)}(hmetric (cost) of this mesh pathh]hmetric (cost) of this mesh path}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjڥubeh}(h]h ]h"]h$]h&]uh1jhjhM hj ubj)}(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}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.hM hj/ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj.hM hj ubj)}(hB``discovery_timeout`` total mesh path discovery timeout, in msecs h](j)}(h``discovery_timeout``h]j)}(hjRh]hdiscovery_timeout}(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)}(h+total mesh path discovery timeout, in msecsh]h+total mesh path discovery timeout, in msecs}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjghM hjhubah}(h]h ]h"]h$]h&]uh1j5hjLubeh}(h]h ]h"]h$]h&]uh1jhjghM hj ubj)}(h2``discovery_retries`` mesh path discovery retries h](j)}(h``discovery_retries``h]j)}(hjh]hdiscovery_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.hhM hjubj6)}(hhh]h)}(hmesh path discovery retriesh]hmesh path discovery retries}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj ubj)}(hP``flags`` mesh path flags from :c:type:`enum mesh_path_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:48: ./include/net/cfg80211.hhM hjubj6)}(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)}(hjh]henum mesh_path_flags}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6mesh_path_flagsuh1hhj٦hM hjݦubeh}(h]h ]h"]h$]h&]uh1hhj٦hM hjڦubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj٦hM hj ubj)}(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}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1hM hj2ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj1hM hj ubj)}(hB``path_change_count`` total number of path changes to destination h](j)}(h``path_change_count``h]j)}(hjUh]hpath_change_count}(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+total number of path changes to destinationh]h+total number of path changes to destination}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjhM hjkubah}(h]h ]h"]h$]h&]uh1j5hjOubeh}(h]h ]h"]h$]h&]uh1jhjjhM hj ubj)}(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 hjubj6)}(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.}(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 hj ubeh}(h]h ]h"]h$]h&]uh1jhjŤubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(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 hjbhhubh)}(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().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_bss_parameters (C struct)c.bss_parametershNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hbss_parametersh]jo)}(hstruct bss_parametersh](ju)}(hjnh]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)}(hbss_parametersh]j)}(hj h]hbss_parameters}(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)}(hBSS parametersh]hBSS parameters}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjNhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjijjijjjuh1jchhhjbhNhNubj)}(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}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjqubh:}(hjqhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjmubj)}(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&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjmubh)}(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 hjmubj)}(hhh](j)}(h&``link_id`` link_id or -1 for non-MLD 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)}(hlink_id or -1 for non-MLDh]hlink_id or -1 for non-MLD}(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)}(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)}(hjh]h use_cts_prot}(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)}(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 hj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hM hjubj)}(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)}(hj1h]huse_short_preamble}(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.hhM hj+ubj6)}(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)}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjGubah}(h]h ]h"]h$]h&]uh1j5hj+ubeh}(h]h ]h"]h$]h&]uh1jhjFhM hjubj)}(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)}(hjkh]huse_short_slot_time}(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)}(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&]uh1j5hjeubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hJ``basic_rates`` basic rates in IEEE 802.11 format (or NULL for no change) h](j)}(h``basic_rates``h]j)}(hjh]h basic_rates}(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)}(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)}(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*``basic_rates_len`` number of basic rates h](j)}(h``basic_rates_len``h]j)}(hjߩh]hbasic_rates_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 hj٩ubj6)}(hhh]h)}(hnumber of basic ratesh]hnumber of basic rates}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hj٩ubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(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)}(hj1hhhNhNubah}(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)}(hC``ht_opmode`` HT Operation mode (u16 = opmode, -1 = do not change) h](j)}(h ``ht_opmode``h]j)}(hjRh]h ht_opmode}(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)}(h4HT Operation mode (u16 = opmode, -1 = do not change)h]h4HT Operation mode (u16 = opmode, -1 = do not change)}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjhubah}(h]h ]h"]h$]h&]uh1j5hjLubeh}(h]h ]h"]h$]h&]uh1jhjghM hjubj)}(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&]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)}(hP2P CT Window (-1 = no change)h]hP2P CT Window (-1 = no change)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h4``p2p_opp_ps`` P2P opportunistic PS (-1 = no change)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.hhM hjubj6)}(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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjڪhM hjubeh}(h]h ]h"]h$]h&]uh1jhjmubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(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.hhM hjbhhubh)}(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 hjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ieee80211_txq_params (C struct)c.ieee80211_txq_paramshNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hieee80211_txq_paramsh]jo)}(hstruct ieee80211_txq_paramsh](ju)}(hjnh]hstruct}(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjBhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjThhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBhhhjShM ubj)}(hieee80211_txq_paramsh]j)}(hj@h]hieee80211_txq_params}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjbubah}(h]h ](jjeh"]h$]h&]jjuh1jhjBhhhjShM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj>hhhjShM ubah}(h]j9ah ](jjeh"]h$]h&]jj)jhuh1jhhjShM hj;hhubj)}(hhh]h)}(hTX queue parametersh]hTX queue parameters}(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&]uh1jhj;hhhjShM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhjbhNhNubj)}(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}(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 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; };}hjūsbah}(h]h ]h"]h$]h&]jjuh1jh`/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&]uh1hhjԫubah}(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``ac`` AC identifier h](j)}(h``ac``h]j)}(hjh]hac}(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 AC identifierh]h AC identifier}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM hj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hM hjubj)}(hE``txop`` Maximum burst time in units of 32 usecs, 0 meaning disabled h](j)}(h``txop``h]j)}(hj.h]htxop}(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)}(h;Maximum burst time in units of 32 usecs, 0 meaning disabledh]h;Maximum burst time in units of 32 usecs, 0 meaning disabled}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChM hjDubah}(h]h ]h"]h$]h&]uh1j5hj(ubeh}(h]h ]h"]h$]h&]uh1jhjChM hjubj)}(hV``cwmin`` Minimum contention window [a value of the form 2^n-1 in the range 1..32767] h](j)}(h ``cwmin``h]j)}(hjgh]hcwmin}(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)}(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.hhM hj}ubah}(h]h ]h"]h$]h&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hM hjubj)}(hV``cwmax`` Maximum contention window [a value of the form 2^n-1 in the range 1..32767] h](j)}(h ``cwmax``h]j)}(hjh]hcwmax}(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)}(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]}(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/``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.hhM hjլubj6)}(hhh]h)}(h%Arbitration interframe space [0..255]h]h%Arbitration interframe space [0..255]}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjլubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(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.hhM hjubj6)}(hhh]h)}(hlink_id or -1 for non-MLDh]hlink_id or -1 for non-MLD}(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 hjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ cfg80211_auth_request (C struct)c.cfg80211_auth_requesthNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hcfg80211_auth_requesth]jo)}(hstruct cfg80211_auth_requesth](ju)}(hjnh]hstruct}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjjhhh`/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&]uh1jhjjhhhj{hM ubj)}(hcfg80211_auth_requesth]j)}(hjhh]hcfg80211_auth_request}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjjhhhj{hM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjfhhhj{hM ubah}(h]jaah ](jjeh"]h$]h&]jj)jhuh1jhhj{hM hjchhubj)}(hhh]h)}(hAuthentication request datah]hAuthentication request data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMe hjhhubah}(h]h ]h"]h$]h&]uh1jhjchhhj{hM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjȭjjȭjjjuh1jchhhjbhNhNubj)}(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}(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.hhMi hj̭ubj)}(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; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMk 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)}(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.hhMl 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.}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMk hj3ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj2hMl hjubj)}(h<``ie`` Extra IEs to add to Authentication frame or ``NULL`` h](j)}(h``ie``h]j)}(hjWh]hie}(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.hhMr hjQubj6)}(hhh]h)}(h4Extra IEs to add to Authentication frame or ``NULL``h](h,Extra IEs to add to Authentication frame or }(hjphhhNhNubj)}(h``NULL``h]hNULL}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubeh}(h]h ]h"]h$]h&]uh1hhjlhMr hjmubah}(h]h ]h"]h$]h&]uh1j5hjQubeh}(h]h ]h"]h$]h&]uh1jhjlhMr 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.hhMs hjubj6)}(hhh]h)}(hLength of ie buffer in octetsh]hLength of ie 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``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)}(hj׮h]hsupported_selectors}(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.hhMo hjѮubj6)}(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 }(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.hhMm hjubah}(h]h ]h"]h$]h&]uh1j5hjѮubeh}(h]h ]h"]h$]h&]uh1jhjhMo hjubj)}(hE``supported_selectors_len`` Length of supported_selectors in octets. h](j)}(h``supported_selectors_len``h]j)}(hj#h]hsupported_selectors_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.hhMp hjubj6)}(hhh]h)}(h(Length of supported_selectors in octets.h]h(Length of supported_selectors in octets.}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8hMp hj9ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj8hMp hjubj)}(h.``auth_type`` Authentication type (algorithm) h](j)}(h ``auth_type``h]j)}(hj\h]h auth_type}(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.hhMq hjVubj6)}(hhh]h)}(hAuthentication type (algorithm)h]hAuthentication type (algorithm)}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjqhMq hjrubah}(h]h ]h"]h$]h&]uh1j5hjVubeh}(h]h ]h"]h$]h&]uh1jhjqhMq 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.hhMv hjubj6)}(hhh]h)}(h%WEP key for shared key authenticationh]h%WEP key for shared key authentication}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMv hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMv hjubj)}(h<``key_len`` length of WEP key for shared key authentication h](j)}(h ``key_len``h]j)}(hjίh]hkey_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.hhMt hjȯubj6)}(hhh]h)}(h/length of WEP key for shared key authenticationh]h/length of WEP key for shared key authentication}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMt hjubah}(h]h ]h"]h$]h&]uh1j5hjȯubeh}(h]h ]h"]h$]h&]uh1jhjhMt hjubj)}(h;``key_idx`` index of WEP key for shared key authentication h](j)}(h ``key_idx``h]j)}(hjh]hkey_idx}(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.hhMu hjubj6)}(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&]uh1hhjhMu hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMu 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}(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.hhMz hj:ubj6)}(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.}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMw hjVubah}(h]h ]h"]h$]h&]uh1j5hj:ubeh}(h]h ]h"]h$]h&]uh1jhjUhMz hjubj)}(h7``auth_data_len`` Length of auth_data buffer in octets h](j)}(h``auth_data_len``h]j)}(hjzh]h auth_data_len}(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.hhM{ hjtubj6)}(hhh]h)}(h$Length of auth_data buffer in octetsh]h$Length of auth_data buffer in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM{ hjubah}(h]h ]h"]h$]h&]uh1j5hjtubeh}(h]h ]h"]h$]h&]uh1jhjhM{ 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)}(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)}(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}(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)}(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)}(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)}(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&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubeh}(h]h ]h"]h$]h&]uh1jhj̭ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(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.hhM hjbhhubh)}(hRThis structure provides information needed to complete IEEE 802.11 authentication.h]hRThis structure provides information needed to complete IEEE 802.11 authentication.}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMf hjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_!cfg80211_assoc_request (C struct)c.cfg80211_assoc_requesthNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hcfg80211_assoc_requesth]jo)}(hstruct cfg80211_assoc_requesth](ju)}(hjnh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj{hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMl ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{hhhjhMl ubj)}(hcfg80211_assoc_requesth]j)}(hjyh]hcfg80211_assoc_request}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhj{hhhjhMl ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjwhhhjhMl ubah}(h]jrah ](jjeh"]h$]h&]jj)jhuh1jhhjhMl hjthhubj)}(hhh]h)}(h(Re)Association request datah]h(Re)Association 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&]uh1jhjthhhjhMl ubeh}(h]h ](j$structeh"]h$]h&]jj$jjٱjjٱjjjuh1jchhhjbhNhNubj)}(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}(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 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&]jjuh1jh`/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&]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)}(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)}(hj.h]hbss}(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)}(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 }(hjGhhhNhNubj)}(h **links.bss**h]h links.bss}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjGubh5 parameter, which is used instead of this one (it is }(hjGhhhNhNubj)}(h``NULL``h]hNULL}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubh) for MLO associations.}(hjGhhhNhNubeh}(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 hj%ubj)}(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&]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=Extra IEs to add to (Re)Association Request frame or ``NULL``h](h5Extra IEs to add to (Re)Association Request 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 hj%ubj)}(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)}(hjӲh]h prev_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)}(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&]uh1j5hjͲubeh}(h]h ]h"]h$]h&]uh1jhjhM hj%ubj)}(h)``ie_len`` Length of ie buffer in octets h](j)}(h ``ie_len``h]j)}(hjh]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 ie buffer in octetsh]hLength of ie buffer in octets}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4hM hj5ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj4hM hj%ubj)}(h``crypto`` crypto settings h](j)}(h ``crypto``h]j)}(hjXh]hcrypto}(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.hhM hjRubj6)}(hhh]h)}(hcrypto settingsh]hcrypto settings}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmhM hjnubah}(h]h ]h"]h$]h&]uh1j5hjRubeh}(h]h ]h"]h$]h&]uh1jhjmhM hj%ubj)}(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 hjubj6)}(hhh]h)}(hBUse management frame protection (IEEE 802.11w) in this associationh]hBUse management frame protection (IEEE 802.11w) in this association}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj%ubj)}(hQ``flags`` See :c:type:`enum cfg80211_assoc_req_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:48: ./include/net/cfg80211.hhM hjijubj6)}(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 refexplicitrefwarnjS jW j6cfg80211_assoc_req_flagsuh1hhj߳hM hjubeh}(h]h ]h"]h$]h&]uh1hhj߳hM hjubah}(h]h ]h"]h$]h&]uh1j5hjijubeh}(h]h ]h"]h$]h&]uh1jhj߳hM hj%ubj)}(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)}(hj"h]hsupported_selectors}(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)}(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 }(hj;hhhNhNubj)}(h``NULL``h]hNULL}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubh for no change). If }(hj;hhhNhNubj)}(h``NULL``h]hNULL}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubh-, then support for SAE_H2E should be assumed.}(hj;hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj8ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj7hM hj%ubj)}(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&]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)}(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&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhjhM hj%ubj)}(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 hjubj6)}(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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjδhM hj%ubj)}(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.hhM 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&]uh1hhjhM hj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj%ubj)}(h%``vht_capa`` VHT capability override h](j)}(h ``vht_capa``h]j)}(hj,h]hvht_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.hhM hj&ubj6)}(hhh]h)}(hVHT capability overrideh]hVHT capability override}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjAhM hjBubah}(h]h ]h"]h$]h&]uh1j5hj&ubeh}(h]h ]h"]h$]h&]uh1jhjAhM hj%ubj)}(hE``vht_capa_mask`` VHT capability mask indicating which fields to use h](j)}(h``vht_capa_mask``h]j)}(hjeh]h vht_capa_mask}(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)}(h2VHT capability mask indicating which fields to useh]h2VHT capability mask indicating which fields to use}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzhM hj{ubah}(h]h ]h"]h$]h&]uh1j5hj_ubeh}(h]h ]h"]h$]h&]uh1jhjzhM hj%ubj)}(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)}(hjh]hfils_kek}(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_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 }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh if FILS is not used.}(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 hj%ubj)}(h.``fils_kek_len`` Length of fils_kek in octets h](j)}(h``fils_kek_len``h]j)}(hjh]h fils_kek_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 fils_kek in octetsh]hLength of fils_kek in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj%ubj)}(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)}(hj#h]h fils_nonces}(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)}(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 }(hj<hhhNhNubj)}(h``NULL``h]hNULL}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubhf if FILS is not used. This field starts with 16 octets of STA Nonce followed by 16 octets of AP Nonce.}(hj<hhhNhNubeh}(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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj8hM hj%ubj)}(h%``s1g_capa`` S1G capability override h](j)}(h ``s1g_capa``h]j)}(hjoh]hs1g_capa}(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.hhM hjiubj6)}(hhh]h)}(hS1G capability overrideh]hS1G capability override}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjiubeh}(h]h ]h"]h$]h&]uh1jhjhM hj%ubj)}(h/``s1g_capa_mask`` S1G capability override mask h](j)}(h``s1g_capa_mask``h]j)}(hjh]h s1g_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)}(hS1G capability override maskh]hS1G capability override mask}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj%ubj)}(h3``links`` per-link information for MLO connections h](j)}(h ``links``h]j)}(hjh]hlinks}(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)}(h(per-link information for MLO connectionsh]h(per-link information for MLO connections}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hj۶ubeh}(h]h ]h"]h$]h&]uh1jhjhM hj%ubj)}(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 }(hj3hhhNhNubj)}(h **link_id**h]hlink_id}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3ubh >= 0}(hj3hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj0ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj/hM hj%ubj)}(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)}(hjfh]hlink_id}(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)}(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 hj|ubah}(h]h ]h"]h$]h&]uh1j5hj`ubeh}(h]h ]h"]h$]h&]uh1jhj{hM hj%ubj)}(hb``ext_mld_capa_ops`` extended MLD capabilities and operations set by userspace for the associationh](j)}(h``ext_mld_capa_ops``h]j)}(hjh]hext_mld_capa_ops}(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)}(hMextended MLD capabilities and operations set by userspace for the associationh]hMextended MLD capabilities and operations set by userspace for the association}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj%ubeh}(h]h ]h"]h$]h&]uh1jhjݱubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(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 hjbhhubh)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_deauth_request (C struct)c.cfg80211_deauth_requesthNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hcfg80211_deauth_requesth]jo)}(hstruct cfg80211_deauth_requesth](ju)}(hjnh]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_deauth_requesth]j)}(hjh]hcfg80211_deauth_request}(hj@hhhNhNubah}(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)}(hDeauthentication request datah]hDeauthentication request data}(hjbhhhNhNubah}(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&]uh1jhjhhhj-hM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjzjjzjjjuh1jchhhjbhNhNubj)}(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 hj~ubj)}(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; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jh`/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)}(h=``bssid`` the BSSID or AP MLD address to deauthenticate from 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)}(h2the BSSID or AP MLD address to deauthenticate fromh]h2the BSSID or AP MLD address to deauthenticate from}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjɸubeh}(h]h ]h"]h$]h&]uh1jhjhM hjƸubj)}(h>``ie`` Extra IEs to add to Deauthentication frame or ``NULL`` h](j)}(h``ie``h]j)}(hjh]hie}(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)}(h6Extra IEs to add to Deauthentication frame or ``NULL``h](h.Extra IEs to add to Deauthentication 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 hjƸubj)}(h)``ie_len`` Length of ie buffer in octets h](j)}(h ``ie_len``h]j)}(hjOh]hie_len}(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.hhM hjIubj6)}(hhh]h)}(hLength of ie buffer in octetsh]hLength of ie buffer in octets}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdhM hjeubah}(h]h ]h"]h$]h& ]uh1j5hjIubeh}(h]h ]h"]h$]h&]uh1jhjdhM hjƸubj)}(h9``reason_code`` The reason code for the deauthentication h](j)}(h``reason_code``h]j)}(hjh]h reason_code}(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 reason code for the deauthenticationh]h(The reason code for the deauthentication}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjƸubj)}(hT``local_state_change`` if set, change local state only and do not set a deauth frameh](j)}(h``local_state_change``h]j)}(hjh]hlocal_state_change}(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=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&]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~ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(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" hjbhhubh)}(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 hjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_$cfg80211_disassoc_request (C struct)c.cfg80211_disassoc_requesthNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hcfg80211_disassoc_requesth]jo)}(h struct cfg80211_disassoc_requesth](ju)}(hjnh]hstruct}(hjAhhhNhNubah}(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 }(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=hhhjNhM ubj)}(hcfg80211_disassoc_requesth]j)}(hj;h]hcfg80211_disassoc_request}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj=hhhjNhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj9hhhjNhM ubah}(h]j4ah ](jjeh"]h$]h&]jj)jhuh1jhhjNhM hj6hhubj)}(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&]uh1jhj6hhhjNhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhjbhNhNubj)}(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}(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_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; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jh`/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&]uh1hhjϺubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM7 hjubj)}(hhh](j)}(h=``ap_addr`` the BSSID or AP MLD address to disassociate from h](j)}(h ``ap_addr``h]j)}(hjh]hap_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)}(h0the BSSID or AP MLD address to disassociate fromh]h0the BSSID or AP MLD address to disassociate from}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM/ hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM/ hjubj)}(h<``ie`` Extra IEs to add to Disassociation 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.hhM0 hj#ubj6)}(hhh]h)}(h4Extra IEs to add to Disassociation frame or ``NULL``h](h,Extra IEs to add to Disassociation frame or }(hjBhhhNhNubj)}(h``NULL``h]hNULL}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubeh}(h]h ]h"]h$]h&]uh1hhj>hM0 hj?ubah}(h]h ]h"]h$]h&]uh1j5hj#ubeh}(h]h ]h"]h$]h&]uh1jhj>hM0 hjubj)}(h)``ie_len`` Length of ie buffer in octets h](j)}(h ``ie_len``h]j)}(hjph]hie_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.hhM1 hjjubj6)}(hhh]h)}(hLength of ie buffer in octetsh]hLength of ie buffer in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM1 hjubah}(h]h ]h"]h$]h&]uh1j5hjjubeh}(h]h ]h"]h$]h&]uh1jhjhM1 hjubj)}(h7``reason_code`` The reason code for the disassociation h](j)}(h``reason_code``h]j)}(hjh]h reason_code}(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&The reason code for the disassociationh]h&The reason code for the disassociation}(hj»hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM2 hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM2 hjubj)}(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)}(hjh]hlocal_state_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.hhM3 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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM3 hjubah}(h]h ]h"]h$]h&]uh1j5hjܻubeh}(h]h ]h"]h$]h&]uh1jhjhM3 hjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(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.hhM7 hjbhhubh)}(hRThis structure provides information needed to complete IEEE 802.11 disassociation.h]hRThis structure provides information needed to complete IEEE 802.11 disassociation.}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM* hjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_ibss_params (C struct)c.cfg80211_ibss_paramshNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hcfg80211_ibss_paramsh]jo)}(hstruct cfg80211_ibss_paramsh](ju)}(hjnh]hstruct}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj^hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM0 ubj)}(h h]h }(hjphhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^hhhjohM0 ubj)}(hcfg80211_ibss_paramsh]j)}(hj\h]hcfg80211_ibss_params}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj~ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj^hhhjohM0 ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjZhhhjohM0 ubah}(h]jUah ](jjeh"]h$]h&]jj)jhuh1jhhjohM0 hjWhhubj)}(hhh]h)}(hIBSS parametersh]hIBSS parameters}(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&]uh1jhjWhhhjohM0 ubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhjbhNhNubj)}(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}(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.hhMB hjubj)}(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; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMD 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.hhMX hjubj)}(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.hhMD hj ubj6)}(hhh]h)}(h"The SSID, will always be non-null.h]h"The SSID, will always be non-null.}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&hMD hj'ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj&hMD 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)}(hjJh]hbssid}(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.hhMG hjDubj6)}(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 }(hjchhhNhNubj)}(h``NULL``h]hNULL}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubh8, if set do not search for IBSSs with a different BSSID.}(hjchhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMF hj`ubah}(h]h ]h"]h$]h&]uh1j5hjDubeh}(h]h ]h"]h$]h&]uh1jhj_hMG 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.hhMH 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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMH hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMH hjubj)}(h7``ie`` information element(s) to include in the beacon 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.hhMK hjɽubj6)}(hhh]h)}(h/information element(s) to include in the beaconh]h/information element(s) to include in the beacon}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMK hjubah}(h]h ]h"]h$]h&]uh1j5hjɽubeh}(h]h ]h"]h$]h&]uh1jhjhMK hjubj)}(h>``ssid_len`` The length of the SSID, will always be non-zero. h](j)}(h ``ssid_len``h]j)}(hjh]hssid_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.hhME hjubj6)}(hhh]h)}(h0The length of the SSID, will always be non-zero.h]h0The length of the SSID, will always be non-zero.}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhME hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhME hjubj)}(h``ie_len`` length of that h](j)}(h ``ie_len``h]j)}(hjAh]hie_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.hhML hj;ubj6)}(hhh]h)}(hlength of thath]hlength of that}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhML hjWubah}(h]h ]h"]h$]h&]uh1j5hj;ubeh}(h]h ]h"]h$]h&]uh1jhjVhML hjubj)}(h+``beacon_interval`` beacon interval to use h](j)}(h``beacon_interval``h]j)}(hjzh]hbeacon_interval}(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.hhMM hjtubj6)}(hhh]h)}(hbeacon interval to useh]hbeacon interval to use}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMM hjubah}(h]h ]h"]h$]h&]uh1j5hjtubeh}(h]h ]h"]h$]h&]uh1jhjhMM hjubj)}(hD``basic_rates`` bitmap of basic rates to use when creating the IBSS h](j)}(h``basic_rates``h]j)}(hjh]h basic_rates}(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)}(h3bitmap of basic rates to use when creating the IBSSh]h3bitmap of basic rates to use when creating the IBSS}(hj̾hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjȾhMY hjɾubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjȾhMY 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)}(hjh]h channel_fixed}(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)}(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.hhMI hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMJ hjubj)}(hO``privacy`` this is a protected network, keys will be configured after joining 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.hhMO hj ubj6)}(hhh]h)}(hBthis is a protected network, keys will be configured after joiningh]hBthis is a protected network, keys will be configured after joining}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMN hj<ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj;hMO 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)}(hj`h]h control_port}(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.hhMS hjZubj6)}(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 }(hjyhhhNhNubj)}(h``NL80211_STA_FLAG_AUTHORIZED``h]hNL80211_STA_FLAG_AUTHORIZED}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubh. 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.}(hjyhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMP hjvubah}(h]h ]h"]h$]h&]uh1j5hjZubeh}(h]h ]h"]h$]h&]uh1jhjuhMS 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)}(hjh]hcontrol_port_over_nl80211}(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)}(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.}(hjſhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMT hj¿ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMU 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)}(hjh]huserspace_handles_dfs}(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)}(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.hhMV hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMX hjubj)}(h?``mcast_rate`` per-band multicast rate index + 1 (0: disabled) h](j)}(h``mcast_rate``h]j)}(hj h]h mcast_rate}(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.hhMZ hjubj6)}(hhh]h)}(h/per-band multicast rate index + 1 (0: disabled)h]h/per-band multicast rate index + 1 (0: disabled)}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5hMZ hj6ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj5hMZ 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)}(hjYh]hht_capa}(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)}(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.}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM[ hjoubah}(h]h ]h"]h$]h&]uh1j5hjSubeh}(h]h ]h"]h$]h&]uh1jhjnhM\ 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.hhM] 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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM] hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM] 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)}(hjh]hwep_keys}(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)}(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}(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@``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.hhM_ 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.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&]uh1jhjbhhhNhNubh)}(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:48: ./include/net/cfg80211.hhMc hjbhhubh)}(hFThis structure defines the IBSS parameters for the join_ibss() method.h]hFThis structure defines the IBSS parameters for the join_ibss() method.}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM? hjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_connect_params (C struct)c.cfg80211_connect_paramshNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hcfg80211_connect_paramsh]jo)}(hstruct cfg80211_connect_paramsh](ju)}(hjnh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhME ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhME ubj)}(hcfg80211_connect_paramsh]j)}(hjh]hcfg80211_connect_params}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhME ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhME ubah}(h]jzah ](jjeh"]h$]h&]jj)jhuh1jhhjhME hj|hhubj)}(hhh]h)}(hConnection parametersh]hConnection parameters}(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&]uh1jhj|hhhjhME ubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhjbhNhNubj)}(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}(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)}(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&]jjuh1jh`/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.hhM hjubj)}(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)}(hj6h]hchannel}(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.hhM hj0ubj6)}(hhh]h)}(hSThe channel to use or ``NULL`` if not specified (auto-select based on scan results)h](hThe channel to use or }(hjOhhhNhNubj)}(h``NULL``h]hNULL}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubh5 if not specified (auto-select based on scan results)}(hjOhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjLubah}(h]h ]h"]h$]h&]uh1j5hj0ubeh}(h]h ]h"]h$]h&]uh1jhjKhM hj-ubj)}(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.hhM hj|ubj6)}(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}(hjhhhNhNubah}(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.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hj|ubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(hX``bssid`` The AP BSSID or ``NULL`` if not specified (auto-select based on scan results) h](j)}(h ``bssid``h]j)}(hjh]hbssid}(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)}(hMThe AP BSSID or ``NULL`` if not specified (auto-select based on scan results)h](hThe AP BSSID 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.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(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.hhM 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 }(hj3hhhNhNubj)}(h``NULL``h]hNULL}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3ubh if not specified. Unlike the }(hj3hhhNhNubj)}(h **bssid**h]hbssid}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3ubh1 parameter, the driver is allowed to ignore this }(hj3hhhNhNubj)}(h**bssid_hint**h]h bssid_hint}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3ubh, if it has knowledge of a better BSS to use.}(hj3hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj0ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj/hM hj-ubj)}(h``ssid`` SSID 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)}(hSSIDh]hSSID}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(h&``ssid_len`` Length of 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.hhM hjubj6)}(hhh]h)}(hLength of ssid in octetsh]hLength of ssid in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(h.``auth_type`` Authentication type (algorithm) h](j)}(h ``auth_type``h]j)}(hjh]h auth_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.hhM hjubj6)}(hhh]h)}(hAuthentication type (algorithm)h]hAuthentication type (algorithm)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(h#``ie`` IEs for association request h](j)}(h``ie``h]j)}(hj5h]hie}(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)}(hIEs for association requesth]hIEs for association request}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJhM hjKubah}(h]h ]h"]h$]h&]uh1j5hj/ubeh}(h]h ]h"]h$]h&]uh1jhjJhM hj-ubj)}(h(``ie_len`` Length of assoc_ie in octets h](j)}(h ``ie_len``h]j)}(hjnh]hie_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.hhM hjhubj6)}(hhh]h)}(hLength of assoc_ie in octetsh]hLength of assoc_ie in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(hA``privacy`` indicates whether privacy-enabled APs should be used 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)}(h4indicates whether privacy-enabled APs should be usedh]h4indicates whether privacy-enabled APs should be used}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(h=``mfp`` indicate whether management frame protection is used h](j)}(h``mfp``h]j)}(hjh]hmfp}(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)}(h4indicate whether management frame protection is usedh]h4indicate whether management frame protection is used}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(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.hhM hjubj6)}(hhh]h)}(hcrypto settingsh]hcrypto settings}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.hM hj/ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj.hM hj-ubj)}(h.``key`` WEP key for shared key authentication h](j)}(h``key``h]j)}(hjRh]hkey}(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)}(h%WEP key for shared key authenticationh]h%WEP key for shared key authentication}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjghM hjhubah}(h]h ]h"]h$]h&]uh1j5hjLubeh}(h]h ]h"]h$]h&]uh1jhjghM hj-ubj)}(h<``key_len`` length of WEP key for shared key authentication h](j)}(h ``key_len``h]j)}(hjh]hkey_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 WEP key for shared key authenticationh]h/length of WEP key for shared key authentication}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(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.hhM 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&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(hQ``flags`` See :c:type:`enum cfg80211_assoc_req_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.hhM hjubj6)}(hhh]h)}(hFSee :c:type:`enum cfg80211_assoc_req_flags `h](hSee }(hjhhhNhNubh)}(hB:c:type:`enum cfg80211_assoc_req_flags `h]j)}(hj h]henum cfg80211_assoc_req_flags}(hj"hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6cfg80211_assoc_req_flagsuh1hhjhM hjubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(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)}(hjUh]hbg_scan_period}(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)}(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.}(hjnhhhNhNubah}(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 hj-ubj)}(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 hjubj6)}(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.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(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.hhM 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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(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 hjubj6)}(hhh]h)}(hVHT Capability overridesh]hVHT Capability overrides}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(h=``vht_capa_mask`` The bits of vht_capa which are to be used. h](j)}(h``vht_capa_mask``h]j)}(hj;h]h vht_capa_mask}(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)}(h*The bits of vht_capa which are to be used.h]h*The bits of vht_capa which are to be used.}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPhM hjQubah}(h]h ]h"]h$]h&]uh1j5hj5ubeh}(h]h ]h"]h$]h&]uh1jhjPhM hj-ubj)}(hI``pbss`` if set, connect to a PCP instead of AP. Valid for DMG networks. h](j)}(h``pbss``h]j)}(hjth]hpbss}(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.hhM hjnubj6)}(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 hjubah}(h]h ]h"]h$]h&]uh1j5hjnubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(h6``bss_select`` criteria to be used for BSS selection. h](j)}(h``bss_select``h]j)}(hjh]h bss_select}(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&criteria to be used for BSS selection.h]h&criteria to be used for BSS selection.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(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)}(hjh]h prev_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)}(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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(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)}(hj3h]hfils_erp_username}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubah}(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)}(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 }(hjLhhhNhNubj)}(h``NULL``h]hNULL}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubhB if not specified. This is used to construct FILS wrapped data IE.}(hjLhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjIubah}(h]h ]h"]h$]h&]uh1j5hj-ubeh}(h]h ]h"]h$]h&]uh1jhjHhM hj-ubj)}(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&]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)}(h*Length of **fils_erp_username** in octets.h](h Length of }(hjhhhNhNubj)}(h**fils_erp_username**h]hfils_erp_username}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh in octets.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjyubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(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)}(hjh]hfils_erp_realm}(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) 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 }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhm if not specified. This specifies the domain name of ER server and 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 hj-ubj)}(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 }(hj/hhhNhNubj)}(h**fils_erp_realm**h]hfils_erp_realm}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/ubh in octets.}(hj/hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj+hM hj,ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj+hM hj-ubj)}(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)}(hjah]hfils_erp_next_seq_num}(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)}(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.}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjwubah}(h]h ]h"]h$]h&]uh1j5hj[ubeh}(h]h ]h"]h$]h&]uh1jhjvhM hj-ubj)}(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 }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(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.hXhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(h;``fils_erp_rrk_len`` Length of **fils_erp_rrk** in octets. h](j)}(h``fils_erp_rrk_len``h]j)}(hjh]hfils_erp_rrk_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_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&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(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)}(hj2h]hwant_1x}(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.hhM hj,ubj6)}(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.}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjHubah}(h]h ]h"]h$]h&]uh1j5hj,ubeh}(h]h ]h"]h$]h&]uh1jhjGhM hj-ubj)}(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)}(hjlh]hedmg}(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)}(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&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(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 hjbhhubh)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_pmksa (C struct)c.cfg80211_pmksahNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hcfg80211_pmksah]jo)}(hstruct cfg80211_pmksah](ju)}(hjnh]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_pmksah]j)}(hjh]hcfg80211_pmksa}(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)}(hPMK Security Associationh]hPMK Security Association}(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&]uh1jhjhhhjhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjGjjGjjjuh1jchhhjbhNhNubj)}(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}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhjOubh:}(hjOhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjKubj)}(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; };}hjlsbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjKubh)}(h **Members**h]j)}(hj}h]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.hhM,hjKubj)}(hhh](j)}(h,``bssid`` The AP's BSSID (may be ``NULL``). h](j)}(h ``bssid``h]j)}(hjh]hbssid}(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 AP's BSSID (may be ``NULL``).h](hThe AP’s BSSID (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 hjubj)}(h+``pmkid`` The identifier to refer a PMKSA. h](j)}(h ``pmkid``h]j)}(hjh]hpmkid}(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 identifier to refer a PMKSA.h]h The identifier to refer a PMKSA.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM!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)}(hj h]hpmk}(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)}(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 }(hj9hhhNhNubj)}(h **pmkid**h]hpmkid}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9ubh<. This is used for key derivation by a FILS STA. Otherwise, }(hj9hhhNhNubj)}(h``NULL``h]hNULL}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubh.}(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{``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)}(hj~h]hpmk_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%hjxubj6)}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh. The length of }(hjhhhNhNubj)}(h**pmk**h]hpmk}(hjhhhNhNubah}(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&]uh1j5hjxubeh}(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)}(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)}(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 }(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/``ssid_len`` Length of the **ssid** in octets. 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.hhM(hj"ubj6)}(hhh]h)}(h!Length of the **ssid** in octets.h](hLength of the }(hjAhhhNhNubj)}(h**ssid**h]hssid}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjAubh in octets.}(hjAhhhNhNubeh}(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``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)}(hjsh]hcache_id}(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)}(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}(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&]uh1j5hjmubeh}(h]h ]h"]h$]h&]uh1jhjhM+hjubj)}(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)}(hjh]h pmk_lifetime}(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)}(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.}(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&]uh1jhjhM1hjubj)}(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)}(hj h]hpmk_reauth_threshold}(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.hhM5hjubj6)}(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.}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM2hj!ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hM5hjubeh}(h]h ]h"]h$]h&]uh1jhjKubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(h**Description**h]j)}(hjNh]h Description}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM9hjbhhubh)}(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.}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_ops (C struct)c.cfg80211_opshNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(h cfg80211_opsh]jo)}(hstruct cfg80211_opsh](ju)}(hjnh]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)}(h cfg80211_opsh]j)}(hjh]h cfg80211_ops}(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.backend description for wireless configurationh]h.backend description for wireless configuration}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMNhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM!ubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhjbhNhNubj)}(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}(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.hhMRhjubj)}(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); };}hj sbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMThjubh)}(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``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)}(hj;h]hsuspend}(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)}(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 }(hjThhhNhNubj)}(h**wow**h]hwow}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjTubh will be }(hjThhhNhNubj)}(h``NULL``h]hNULL}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubhU or contain the enabled Wake-on-Wireless triggers that are configured for the device.}(hjThhhNhNubeh}(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^hj2ubj)}(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.hhM_hjubj6)}(hhh]h)}(h wiphy device needs to be resumedh]h wiphy device needs to be resumed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM_hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM_hj2ubj)}(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)}(hjh]h set_wakeup}(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)}(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.}(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&]uh1jhjhMbhj2ubj)}(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)}(hj h]hadd_virtual_intf}(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.hhMihjubj6)}(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.}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMdhj"ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj!hMihj2ubj)}(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)}(hjFh]hdel_virtual_intf}(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.hhMlhj@ubj6)}(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.}(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&]uh1j5hj@ubeh}(h]h ]h"]h$]h&]uh1jhj[hMlhj2ubj)}(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&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMphjzubj6)}(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.hhMnhjubah}(h]h ]h"]h$]h&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhjhMphj2ubj)}(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)}(hjh]h add_intf_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.hhMthjubj6)}(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.}(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&]uh1jhjhMthj2ubj)}(h?``del_intf_link`` Remove an MLO link from the given interface. h](j)}(h``del_intf_link``h]j)}(hjh]h del_intf_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.hhMuhjubj6)}(hhh]h)}(h,Remove an MLO link from the given interface.h]h,Remove an MLO link from the given interface.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMuhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMuhj2ubj)}(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)}(hj-h]hadd_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.hhMzhj'ubj6)}(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. }(hjFhhhNhNubj)}(h **mac_addr**h]hmac_addr}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFubh will be }(hjFhhhNhNubj)}(h``NULL``h]hNULL}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubh when adding a group key. }(hjFhhhNhNubj)}(h **link_id**h]hlink_id}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFubh8 will be -1 for non-MLO connection. For MLO connection, }(hjFhhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFubh5 will be >= 0 for group key and -1 for pairwise key, }(hjFhhhNhNubj)}(h **mac_addr**h]hmac_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFubh3 will be peer’s MLD address for MLO pairwise key.}(hjFhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMwhjCubah}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhjBhMzhj2ubj)}(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)}(hjh]hget_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)}(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. }(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&]uh1jhjubhH when requesting information for a group key. All pointers given to the }(hjhhhNhNubj)}(h **callback**h]hcallback}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh 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. }(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}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh5 will be >= 0 for group key and -1 for pairwise key, }(hjhhhNhNubj)}(h **mac_addr**h]hmac_addr}(hj<hhhNhNubah}(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.hhM|hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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)}(hjgh]hdel_key}(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)}(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}(hjhhhNhNubah}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh-, return -ENOENT if the key doesn’t exist. }(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.hhMhj}ubah}(h]h ]h"]h$]h&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hMhj2ubj)}(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)}(hj h]hset_default_key}(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)}(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. }(hj&hhhNhNubj)}(h **link_id**h]hlink_id}(hj.hhhNhNubah}(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.hhMhj#ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj"hMhj2ubj)}(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)}(hjYh]hset_default_mgmt_key}(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.hhMhjSubj6)}(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. }(hjrhhhNhNubj)}(h **link_id**h]hlink_id}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjrubh? will be >= 0 for MLO connection and -1 for non-MLO connection.}(hjrhhhNhNubeh}(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&]uh1j5hjSubeh}(h]h ]h"]h$]h&]uh1jhjnhMhj2ubj)}(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)}(hjh]hset_default_beacon_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)}(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. }(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.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(h@``start_ap`` Start acting in AP mode defined by the parameters. h](j)}(h ``start_ap``h]j)}(hjh]hstart_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.hhMhjubj6)}(hhh]h)}(h2Start acting in AP mode defined by the parameters.h]h2Start acting in AP mode defined by the parameters.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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)}(hj*h]h change_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:48: ./include/net/cfg80211.hhMhj$ubj6)}(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.}(hjChhhNhNubah}(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?hMhj2ubj)}(h<``stop_ap`` Stop being an AP, including stopping beaconing. h](j)}(h ``stop_ap``h]j)}(hjdh]hstop_ap}(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.hhMhj^ubj6)}(hhh]h)}(h/Stop being an AP, including stopping beaconing.h]h/Stop being an AP, including stopping beaconing.}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyhMhjzubah}(h]h ]h"]h$]h&]uh1j5hj^ubeh}(h]h ]h"]h$]h&]uh1jhjyhMhj2ubj)}(h#``add_station`` Add a new station. h](j)}(h``add_station``h]j)}(hjh]h add_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.hhMhjubj6)}(hhh]h)}(hAdd a new station.h]hAdd a new station.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(h!``del_station`` Remove a station h](j)}(h``del_station``h]j)}(hjh]h del_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.hhMhjubj6)}(hhh]h)}(hRemove a stationh]hRemove a station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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&]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)}(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.}(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$hMhj2ubj)}(hN``get_station`` get station information for the station identified by **mac** h](j)}(h``get_station``h]j)}(hjIh]h get_station}(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)}(h=get station information for the station identified by **mac**h](h6get station information for the station identified by }(hjbhhhNhNubj)}(h**mac**h]hmac}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbubeh}(h]h ]h"]h$]h&]uh1hhj^hMhj_ubah}(h]h ]h"]h$]h&]uh1j5hjCubeh}(h]h ]h"]h$]h&]uh1jhj^hMhj2ubj)}(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.hhMhjubj6)}(hhh]h)}(h5dump station callback -- resume dump at index **idx**h](h.dump station callback -- resume dump at index }(hjhhhNhNubj)}(h**idx**h]hidx}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(h$``add_mpath`` add a fixed mesh path h](j)}(h ``add_mpath``h]j)}(hjh]h add_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.hhMhjubj6)}(hhh]h)}(hadd a fixed mesh pathh]hadd a fixed mesh path}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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.hhMhj ubj6)}(hhh]h)}(hdelete a given mesh pathh]hdelete a given mesh path}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%hMhj&ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj%hMhj2ubj)}(h*``change_mpath`` change a given mesh path h](j)}(h``change_mpath``h]j)}(hjIh]h change_mpath}(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)}(hchange a given mesh pathh]hchange a given mesh path}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hMhj_ubah}(h]h ]h"]h$]h&]uh1j5hjCubeh}(h]h ]h"]h$]h&]uh1jhj^hMhj2ubj)}(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.hhMhj|ubj6)}(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&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hj|ubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(hG``dump_mpath`` dump mesh path callback -- resume dump at index **idx** h](j)}(h``dump_mpath``h]j)}(hjh]h dump_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.hhMhjubj6)}(hhh]h)}(h7dump mesh path callback -- resume dump at index **idx**h](h0dump mesh path callback -- resume dump at index }(hjhhhNhNubj)}(h**idx**h]hidx}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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.hhMhjubj6)}(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&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(hK``dump_mpp`` dump mesh proxy path callback -- resume dump at index **idx** h](j)}(h ``dump_mpp``h]j)}(hj;h]hdump_mpp}(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=dump mesh proxy path callback -- resume dump at index **idx**h](h6dump mesh proxy path callback -- resume dump at index }(hjThhhNhNubj)}(h**idx**h]hidx}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjTubeh}(h]h ]h"]h$]h&]uh1hhjPhMhjQubah}(h]h ]h"]h$]h&]uh1j5hj5ubeh}(h]h ]h"]h$]h&]uh1jhjPhMhj2ubj)}(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.hhMhj|ubj6)}(hhh]h)}(h"Get the current mesh configurationh]h"Get the current mesh configuration}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hj|ubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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)}(hjh]hupdate_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.hhMhjubj6)}(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.}(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&]uh1jhjhMhj2ubj)}(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)}(hjh]h join_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.hhMhjubj6)}(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.hhMhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhj2ubj)}(hY``leave_mesh`` leave the current mesh network (invoked with the wireless_dev mutex held) h](j)}(h``leave_mesh``h]j)}(hj/h]h leave_mesh}(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)}(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)}(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&]uh1jhjDhMhj2ubj)}(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)}(hjih]hjoin_ocb}(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)}(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.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjcubeh}(h]h ]h"]h$]h&]uh1jhj~hMhj2ubj)}(hW``leave_ocb`` leave the current OCB network (invoked with the wireless_dev mutex held) h](j)}(h ``leave_ocb``h]j)}(hjh]h leave_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.hhMhjubj6)}(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)}(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&]uh1jhjhMhj2ubj)}(h2``change_bss`` Modify parameters for a given BSS. h](j)}(h``change_bss``h]j)}(hjh]h change_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.hhMhjubj6)}(hhh]h)}(h"Modify parameters for a given BSS.h]h"Modify parameters for a given BSS.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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.hhMhjubj6)}(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.}(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+hMhj2ubj)}(h+``set_txq_params`` Set TX queue parameters h](j)}(h``set_txq_params``h]j)}(hjPh]hset_txq_params}(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)}(hSet TX queue parametersh]hSet TX queue parameters}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehMhjfubah}(h]h ]h"]h$]h&]uh1j5hjJubeh}(h]h ]h"]h$]h&]uh1jhjehMhj2ubj)}(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)}(hjh]hlibertas_set_mesh_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)}(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.}(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&]uh1jhjhMhj2ubj)}(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)}(hjh]hset_monitor_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)}(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.}(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&]uh1jhjhMhj2ubj)}(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&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(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.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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)}(hj7h]h abort_scan}(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)}(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().}(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&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhjLhMhj2ubj)}(hd``auth`` Request to authenticate with the specified peer (invoked with the wireless_dev mutex held) h](j)}(h``auth``h]j)}(hjqh]hauth}(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)}(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)}(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&]uh1j5hjkubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(hf``assoc`` Request to (re)associate with the specified peer (invoked with the wireless_dev mutex held) h](j)}(h ``assoc``h]j)}(hjh]hassoc}(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[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)}(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&]uh1jhjhMhj2ubj)}(hh``deauth`` Request to deauthenticate from the specified peer (invoked with the wireless_dev mutex held) h](j)}(h ``deauth``h]j)}(hjh]hdeauth}(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\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.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(hh``disassoc`` Request to disassociate from the specified peer (invoked with the wireless_dev mutex held) h](j)}(h ``disassoc``h]j)}(hjh]hdisassoc}(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)}(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)}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj5ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj4hMhj2ubj)}(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)}(hjYh]hconnect}(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.hhMhjSubj6)}(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 }(hjrhhhNhNubj)}(h``WLAN_STATUS_SUCCESS``h]hWLAN_STATUS_SUCCESS}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubhX. 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)}(hjrhhhNhNubeh}(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&]uh1j5hjSubeh}(h]h ]h"]h$]h&]uh1jhjnhMhj2ubj)}(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)}(hjh]hupdate_connect_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)}(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 }(hjhhhNhNubh)}(hP:c:type:`enum cfg80211_connect_params_changed `h]j)}(hjh]h$enum cfg80211_connect_params_changed}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6cfg80211_connect_params_changeduh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh,. (invoked with the wireless_dev mutex held)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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.hhMhjubj6)}(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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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)}(hj<h]h join_ibss}(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.hhMhj6ubj6)}(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)}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjRubah}(h]h ]h"]h$]h&]uh1j5hj6ubeh}(h]h ]h"]h$]h&]uh1jhjQhMhj2ubj)}(hJ``leave_ibss`` Leave the IBSS. (invoked with the wireless_dev mutex held) h](j)}(h``leave_ibss``h]j)}(hjvh]h leave_ibss}(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: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&]uh1j5hjpubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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)}(hjh]hset_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.hhMhjubj6)}(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)}(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&]uh1jhjhMhj2ubj)}(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)}(hjh]hset_wiphy_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)}(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}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh bitfield (see }(hjhhhNhNubh)}(h6:c:type:`enum wiphy_params_flags `h]j)}(hjh]henum wiphy_params_flags}(hj!hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW 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&]uh1hhj<hMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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)}(hjYh]h set_tx_power}(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)}(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 }(hjrhhhNhNubj)}(h``NULL``h]hNULL}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubh4 if power was set for the wiphy, and will always be }(hjrhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubhY unless the driver supports per-vif TX power (as advertised by the nl80211 feature flag.)}(hjrhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjoubah}(h]h ]h"]h$]h&]uh1j5hjSubeh}(h]h ]h"]h$]h&]uh1jhjnhM hj2ubj)}(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)}(hjh]h get_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)}(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}(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&]uh1jhjhMhj2ubj)}(he``rfkill_poll`` polls the hw rfkill line, use cfg80211 reporting functions to adjust rfkill hw state h](j)}(h``rfkill_poll``h]j)}(hjh]h rfkill_poll}(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)}(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}(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&]uh1jhjhMhj2ubj)}(hC``testmode_cmd`` run a test mode command; **wdev** may be ``NULL`` h](j)}(h``testmode_cmd``h]j)}(hj+h]h testmode_cmd}(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)}(h1run a test mode command; **wdev** may be ``NULL``h](hrun a test mode command; }(hjDhhhNhNubj)}(h**wdev**h]hwdev}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDubh may be }(hjDhhhNhNubj)}(h``NULL``h]hNULL}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubeh}(h]h ]h"]h$]h&]uh1hhj@hM"hjAubah}(h]h ]h"]h$]h&]uh1j5hj%ubeh}(h]h ]h"]h$]h&]uh1jhj@hM"hj2ubj)}(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.hhM(hj~ubj6)}(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}(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&]uh1j5hj~ubeh}(h]h ]h"]h$]h&]uh1jhjhM(hj2ubj)}(h8``set_bitrate_mask`` set the bitrate mask configuration h](j)}(h``set_bitrate_mask``h]j)}(hjh]hset_bitrate_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"set the bitrate mask configurationh]h"set the bitrate mask configuration}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM*hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM*hj2ubj)}(h-``dump_survey`` get site survey information. h](j)}(h``dump_survey``h]j)}(hj h]h dump_survey}(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)}(hget site survey information.h]hget site survey information.}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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)}(hjBh]h set_pmksa}(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)}(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.}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM,hjXubah}(h]h ]h"]h$]h&]uh1j5hj<ubeh}(h]h ]h"]h$]h&]uh1jhjWhM.hj2ubj)}(h%``del_pmksa`` Delete a cached PMKID. h](j)}(h ``del_pmksa``h]j)}(hj|h]h del_pmksa}(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.hhM/hjvubj6)}(hhh]h)}(hDelete a cached PMKID.h]hDelete a cached PMKID.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM/hjubah}(h]h ]h"]h$]h&]uh1j5hjvubeh}(h]h ]h"]h$]h&]uh1jhjhM/hj2ubj)}(h)``flush_pmksa`` Flush all cached PMKIDs. h](j)}(h``flush_pmksa``h]j)}(hjh]h flush_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.hhM0hjubj6)}(hhh]h)}(hFlush all cached PMKIDs.h]hFlush all cached PMKIDs.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM0hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM0hj2ubj)}(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)}(hjh]hremain_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)}(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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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)}(hj(h]hcancel_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:48: ./include/net/cfg80211.hhMhj"ubj6)}(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.}(hjAhhhNhNubah}(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=hMhj2ubj)}(h)``mgmt_tx`` Transmit a management frame. h](j)}(h ``mgmt_tx``h]j)}(hjbh]hmgmt_tx}(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.hhMhj\ubj6)}(hhh]h)}(hTransmit a management frame.h]hTransmit a management frame.}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwhMhjxubah}(h]h ]h"]h$]h&]uh1j5hj\ubeh}(h]h ]h"]h$]h&]uh1jhjwhMhj2ubj)}(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.hhM hjubj6)}(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}(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 hj2ubj)}(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)}(hjh]hset_power_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.hhM2hjubj6)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM1hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM2hj2ubj)}(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&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM7hj ubj6)}(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.)}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM3hj%ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj$hM7hj2ubj)}(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)}(hjIh]hset_cqm_rssi_range_config}(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)}(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 }(hjbhhhNhNubj)}(h%``NL80211_EXT_FEATURE_CQM_RSSI_LIST``h]h!NL80211_EXT_FEATURE_CQM_RSSI_LIST}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubhT if this method is implemented. If it is provided then there’s no point providing }(hjbhhhNhNubj)}(h**set_cqm_rssi_config**h]hset_cqm_rssi_config}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbubh.}(hjbhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM8hj_ubah}(h]h ]h"]h$]h&]uh1j5hjCubeh}(h]h ]h"]h$]h&]uh1jhj^hM<hj2ubj)}(hQ``set_cqm_txe_config`` Configure connection quality monitor TX error thresholds. h](j)}(h``set_cqm_txe_config``h]j)}(hjh]hset_cqm_txe_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)}(h9Configure connection quality monitor TX error thresholds.h]h9Configure connection quality monitor TX error thresholds.}(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>hj2ubj)}(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)}(hjh]hupdate_mgmt_frame_registrations}(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)}(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.}(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&]uh1jhjhMHhj2ubj)}(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.hhMMhjubj6)}(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 }(hj4hhhNhNubj)}(h!**NL80211_ATTR_WIPHY_ANTENNA_TX**h]hNL80211_ATTR_WIPHY_ANTENNA_TX}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4ubh).}(hj4hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMJhj1ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj0hMMhj2ubj)}(hP``get_antenna`` Get current antenna configuration from device (tx_ant, rx_ant). h](j)}(h``get_antenna``h]j)}(hjgh]h get_antenna}(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.hhMOhjaubj6)}(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&]uh1hhj|hMOhj}ubah}(h]h ]h"]h$]h&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hMOhj2ubj)}(h@``sched_scan_start`` Tell the driver to start a scheduled scan. h](j)}(h``sched_scan_start``h]j)}(hjh]hsched_scan_start}(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*Tell the driver to start a scheduled scan.h]h*Tell the driver to start a scheduled scan.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM?hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM?hj2ubj)}(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)}(hjh]hsched_scan_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.hhMEhjubj6)}(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. }(hjhhhNhNubj)}(h**sched_scan_start**h]hsched_scan_start}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh 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).}(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&]uh1jhjhMEhj2ubj)}(hJ``set_rekey_data`` give the data necessary for GTK rekeying to the driver h](j)}(h``set_rekey_data``h]j)}(hj%h]hset_rekey_data}(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)}(h6give the data necessary for GTK rekeying to the driverh]h6give the data necessary for GTK rekeying to the driver}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:hMhj;ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj:hMhj2ubj)}(h0``tdls_mgmt`` Transmit a TDLS management frame. h](j)}(h ``tdls_mgmt``h]j)}(hj^h]h tdls_mgmt}(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.hhMQhjXubj6)}(hhh]h)}(h!Transmit a TDLS management frame.h]h!Transmit a TDLS management frame.}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjshMQhjtubah}(h]h ]h"]h$]h&]uh1j5hjXubeh}(h]h ]h"]h$]h&]uh1jhjshMQhj2ubj)}(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.hhMRhjubj6)}(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).}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMRhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMRhj2ubj)}(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)}(hjh]h probe_client}(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)}(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().}(hjhhhNhNubah}(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&]uh1jhjhMUhj2ubj)}(h2``set_noack_map`` Set the NoAck Map for the TIDs. h](j)}(h``set_noack_map``h]j)}(hj h]h set_noack_map}(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.hhMWhjubj6)}(hhh]h)}(hSet the NoAck Map for the TIDs.h]hSet the NoAck Map for the TIDs.}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMWhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMWhj2ubj)}(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)}(hjCh]h get_channel}(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)}(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 }(hj\hhhNhNubj)}(h``NULL``h]hNULL}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubh6 unless there’s a single current monitoring channel.}(hj\hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMYhjYubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhjXhM[hj2ubj)}(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.hhM]hjubj6)}(hhh]h)}(hStart the given P2P device.h]hStart the given P2P device.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM]hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM]hj2ubj)}(h/``stop_p2p_device`` Stop the given P2P device. h](j)}(h``stop_p2p_device``h]j)}(hjh]hstop_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.hhM^hjubj6)}(hhh]h)}(hStop the given P2P device.h]hStop the given P2P device.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM^hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM^hj2ubj)}(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.hhMehjubj6)}(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.hhM`hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMehj2ubj)}(h?``start_radar_detection`` Start radar detection in the driver. h](j)}(h``start_radar_detection``h]j)}(hj;h]hstart_radar_detection}(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.hhMghj5ubj6)}(hhh]h)}(h$Start radar detection in the driver.h]h$Start radar detection in the driver.}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPhMghjQubah}(h]h ]h"]h$]h&]uh1j5hj5ubeh}(h]h ]h"]h$]h&]uh1jhjPhMghj2ubj)}(hY``end_cac`` End running CAC, probably because a related CAC was finished on another phy. h](j)}(h ``end_cac``h]j)}(hjth]hend_cac}(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.hhMjhjnubj6)}(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.hhMihjubah}(h]h ]h"]h$]h&]uh1j5hjnubeh}(h]h ]h"]h$]h&]uh1jhjhMjhj2ubj)}(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)}(hjh]h update_ft_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.hhMnhjubj6)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMlhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMnhj2ubj)}(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)}(hjh]hcrit_proto_start}(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)}(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.hhMphjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMrhj2ubj)}(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)}(hj"h]hcrit_proto_stop}(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.hhMthjubj6)}(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.}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMshj8ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj7hMthj2ubj)}(h*``set_coalesce`` Set coalesce parameters. h](j)}(h``set_coalesce``h]j)}(hj\h]h set_coalesce}(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.hhMuhjVubj6)}(hhh]h)}(hSet coalesce parameters.h]hSet coalesce parameters.}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjqhMuhjrubah}(h]h ]h"]h$]h&]uh1j5hjVubeh}(h]h ]h"]h$]h&]uh1jhjqhMuhj2ubj)}(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.hhM|hjubj6)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMwhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM|hj2ubj)}(h:``set_qos_map`` Set QoS mapping information to the driver h](j)}(h``set_qos_map``h]j)}(hjh]h set_qos_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.hhM~hjubj6)}(hhh]h)}(h)Set QoS mapping information to the driverh]h)Set QoS mapping information to the driver}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM~hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM~hj2ubj)}(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}(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)}(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.}(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&]uh1jhjhMhj2ubj)}(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)}(hjBh]h add_tx_ts}(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.hhMhj<ubj6)}(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)}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjXubah}(h]h ]h"]h$]h&]uh1j5hj<ubeh}(h]h ]h"]h$]h&]uh1jhjWhMhj2ubj)}(h'``del_tx_ts`` remove an existing TX TS h](j)}(h ``del_tx_ts``h]j)}(hj|h]h del_tx_ts}(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.hhMhjvubj6)}(hhh]h)}(hremove an existing TX TSh]hremove an existing TX TS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjvubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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)}(hjh]htdls_channel_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)}(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.}(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&]uh1jhjhMhj2ubj)}(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)}(hjh]htdls_cancel_channel_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)}(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.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(h'``start_nan`` Start the NAN interface. h](j)}(h ``start_nan``h]j)}(hj)h]h start_nan}(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)}(hStart the NAN interface.h]hStart the NAN interface.}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hMhj?ubah}(h]h ]h"]h$]h&]uh1j5hj#ubeh}(h]h ]h"]h$]h&]uh1jhj>hMhj2ubj)}(h%``stop_nan`` Stop the NAN interface. h](j)}(h ``stop_nan``h]j)}(hjbh]hstop_nan}(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.hhMhj\ubj6)}(hhh]h)}(hStop the NAN interface.h]hStop the NAN interface.}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwhMhjxubah}(h]h ]h"]h$]h&]uh1j5hj\ubeh}(h]h ]h"]h$]h&]uh1jhjwhMhj2ubj)}(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.hhMhjubj6)}(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 }(hjhhhNhNubj)}(h **nan_func**h]hnan_func}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh ownership is transferred to the driver and it may access it outside of the scope of this function. The driver should free the }(hjhhhNhNubj)}(h **nan_func**h]hnan_func}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh when no longer needed by calling cfg80211_free_nan_func(). On success the driver should assign an instance_id in the provided }(hjhhhNhNubj)}(h **nan_func**h]hnan_func}(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&]uh1jhjhMhj2ubj)}(h(``del_nan_func`` Delete a NAN function. h](j)}(h``del_nan_func``h]j)}(hj h]h del_nan_func}(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)}(hDelete a NAN function.h]hDelete a NAN function.}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj!ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhj2ubj)}(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)}(hjDh]hnan_change_conf}(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.hhMhj>ubj6)}(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 }(hj]hhhNhNubj)}(h **changes**h]hchanges}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]ubh (using }(hj]hhhNhNubh)}(hD:c:type:`enum cfg80211_nan_conf_changes `h]j)}(hjyh]henum cfg80211_nan_conf_changes}(hj{hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6cfg80211_nan_conf_changesuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj]ubh(); All other parameters must be ignored.}(hj]hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjZubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhjYhMhj2ubj)}(hO``set_multicast_to_unicast`` configure multicast to unicast conversion for BSS h](j)}(h``set_multicast_to_unicast``h]j)}(hjh]hset_multicast_to_unicast}(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)}(h1configure multicast to unicast conversion for BSSh]h1configure multicast to unicast conversion for BSS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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)}(hjh]h get_txq_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.hhMhjubj6)}(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}(hj hhhNhNubah}(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.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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)}(hj8h]hset_pmk}(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)}(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 }(hjQhhhNhNubj)}(h **del_pmk**h]hdel_pmk}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQubhy the PMK remains valid until disconnect upon which the driver should clear it. (invoked with the wireless_dev mutex held)}(hjQhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.h2hMhjNubah}(h]h ]h"]h$]h&]uh1j5hj2ubeh}(h]h ]h"]h$]h&]uh1jhjMhMhj2ubj)}(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.hhMhj~ubj6)}(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.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hj~ubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(hZ``external_auth`` indicates result of offloaded authentication processing from user space h](j)}(h``external_auth``h]j)}(hjh]h external_auth}(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)}(hGindicates result of offloaded authentication processing from user spaceh]hGindicates result of offloaded authentication processing from user space}(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&]uh1jhjhMhj2ubj)}(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)}(hjh]htx_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.hhMhjubj6)}(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.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhj2ubj)}(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)}(hj2h]hget_ftm_responder_stats}(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)}(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.}(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&]uh1jhjGhMhj2ubj)}(h1``start_pmsr`` start peer measurement (e.g. FTM) h](j)}(h``start_pmsr``h]j)}(hjlh]h start_pmsr}(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)}(h!start peer measurement (e.g. FTM)h]h!start peer measurement (e.g. FTM)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(h&``abort_pmsr`` abort peer measurement h](j)}(h``abort_pmsr``h]j)}(hjh]h abort_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.hhMhjubj6)}(hhh]h)}(habort peer measurementh]habort peer measurement}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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)}(hjh]hupdate_owe_info}(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)}(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.}(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&]uh1jhjhMhj2ubj)}(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.hhMhjubj6)}(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.}(hj1hhhNhNubah}(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-hMhj2ubj)}(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)}(hjRh]hset_tid_config}(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)}(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.}(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&]uh1jhjghMhj2ubj)}(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&]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[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.}(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&]uh1jhjhMhj2ubj)}(h6``set_sar_specs`` Update the SAR (TX power) settings. h](j)}(h``set_sar_specs``h]j)}(hjh]h set_sar_specs}(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#Update the SAR (TX power) settings.h]h#Update the SAR (TX power) settings.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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.hhMhjubj6)}(hhh]h)}(hInitiate a color change.h]hInitiate a color change.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(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)}(hj8h]h set_fils_aad}(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)}(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.}(hjQhhhNhNubah}(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&]uh1j5hj2ubeh}(h]h ]h"]h$]h&]uh1jhjMhMhj2ubj)}(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)}(hjrh]hset_radar_background}(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)}(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.}(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&]uh1j5hjlubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(h.``add_link_station`` Add a link to a station. h](j)}(h``add_link_station``h]j)}(hjh]hadd_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.hhMhjubj6)}(hhh]h)}(hAdd a link to a station.h]hAdd a link to a station.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(h1``mod_link_station`` Modify a link of a station. h](j)}(h``mod_link_station``h]j)}(hjh]hmod_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.hhMhjubj6)}(hhh]h)}(hModify a link of a station.h]hModify a link of a station.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(h1``del_link_station`` Remove a link of a station. h](j)}(h``del_link_station``h]j)}(hjh]hdel_link_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.hhMhjubj6)}(hhh]h)}(hRemove a link of a station.h]hRemove a link of a station.}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMhj4ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj3hMhj2ubj)}(hF``set_hw_timestamp`` Enable/disable HW timestamping of TM/FTM frames. h](j)}(h``set_hw_timestamp``h]j)}(hjWh]hset_hw_timestamp}(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)}(h0Enable/disable HW timestamping of TM/FTM frames.h]h0Enable/disable HW timestamping of TM/FTM frames.}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhMhjmubah}(h]h ]h"]h$]h&]uh1j5hjQubeh}(h]h ]h"]h$]h&]uh1jhjlhMhj2ubj)}(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.hhMhjubj6)}(hhh]h)}(hset the TID to link mapping.h]hset the TID to link mapping.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(hU``get_radio_mask`` get bitmask of radios in use. (invoked with the wiphy mutex held) h](j)}(h``get_radio_mask``h]j)}(hjh]hget_radio_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)}(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)}(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&]uh1jhjhMhj2ubj)}(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.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj2ubj)}(h2``set_epcs`` Enable/Disable EPCS for station mode.h](j)}(h ``set_epcs``h]j)}(hj=h]hset_epcs}(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.hhMhj7ubj6)}(hhh]h)}(h%Enable/Disable EPCS for station mode.h]h%Enable/Disable EPCS for station mode.}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjSubah}(h]h ]h"]h$]h&]uh1j5hj7ubeh}(h]h ]h"]h$]h&]uh1jhjRhMhj2ubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(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.hhMhjbhhubh)}(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.hhMOhjbhhubh)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMRhjbhhubh)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMUhjbhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_rx_mlme_mgmt (C function)c.cfg80211_rx_mlme_mgmthNtauh1jRhjbhhhNhNubjd)}(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}(hjhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjhhh`/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_rx_mlme_mgmth]j)}(hcfg80211_rx_mlme_mgmth]hcfg80211_rx_mlme_mgmt}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM.ubj)}(h3(struct net_device *dev, const u8 *buf, size_t len)h](j)}(hstruct net_device *devh](ju)}(hjnh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(h net_deviceh]h net_device}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj9modnameN classnameNjS jV )}jY ]j)}jjsbc.cfg80211_rx_mlme_mgmtasbuh1hhjubj)}(h h]h }(hjWhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hdevh]hdev}(hjrhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h const u8 *bufh](ju)}(hjIh]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 classnameNjS jV )}jY ]jSc.cfg80211_rx_mlme_mgmtasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hbufh]hbuf}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(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 classnameNjS jV )}jY ]jSc.cfg80211_rx_mlme_mgmtasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hlenh]hlen}(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)}(h/notification of processed MLME management frameh]h/notification of processed MLME management frame}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM.hjQhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM.ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjljjljjjuh1jchhhjbhNhNubj)}(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)}(hjvh]h Parameters}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjtubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM2hjpubj)}(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.hhM/hjubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM/hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM/hjubj)}(h7``const u8 *buf`` authentication 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.hhM0hjubj6)}(hhh]h)}(h$authentication frame (header + body)h]h$authentication frame (header + body)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM0hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM0hjubj)}(h(``size_t len`` length of the frame data h](j)}(h``size_t len``h]j)}(hjh]h size_t 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.hhM1hjubj6)}(hhh]h)}(hlength of the frame datah]hlength of the frame data}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM1hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM1hjubeh}(h]h ]h"]h$]h&]uh1jhjpubh)}(h**Description**h]j)}(hjBh]h Description}(hjDhhhNhNubah}(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.hhM3hjpubh)}(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.}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM2hjpubh)}(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.}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM=hjpubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_auth_timeout (C function)c.cfg80211_auth_timeouthNtauh1jRhjbhhhNhNubjd)}(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 ]jlah"]h$]h&]uh1j_hjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMCubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMCubj)}(hcfg80211_auth_timeouth]j)}(hcfg80211_auth_timeouth]hcfg80211_auth_timeout}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMCubj)}(h((struct net_device *dev, const u8 *addr)h](j)}(hstruct net_device *devh](ju)}(hjnh]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 classnameNjS jV )}jY ]j)}jjsbc.cfg80211_auth_timeoutasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hdevh]hdev}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *addrh](ju)}(hjIh]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 classnameNjS jV )}jY ]j c.cfg80211_auth_timeoutasbuh1hhjAubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAubj)}(haddrh]haddr}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMCubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMCubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMChjhhubj)}(hhh]h)}(h(notification of timed out authenticationh]h(notification of timed out authentication}(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&]uh1jhjhhhjhMCubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhjbhNhNubj)}(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)}(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}(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.hhMDhjubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMDhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMDhjubj)}(hY``const u8 *addr`` The MAC address of the device with which the authentication timed out h](j)}(h``const u8 *addr``h]j)}(hj@h]hconst u8 *addr}(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.hhMEhj:ubj6)}(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}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUhMEhjVubah}(h]h ]h"]h$]h&]uh1j5hj:ubeh}(h]h ]h"]h$]h&]uh1jhjUhMEhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj{h]h Description}(hj}hhhNhNubah}(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.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.hhMFhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_#cfg80211_rx_assoc_resp (C function)c.cfg80211_rx_assoc_resphNtauh1jRhjbhhhNhNubjd)}(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}(hjhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMkubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMkubj)}(hcfg80211_rx_assoc_resph]j)}(hcfg80211_rx_assoc_resph]hcfg80211_rx_assoc_resp}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMkubj)}(hH(struct net_device *dev, const struct cfg80211_rx_assoc_resp_data *data)h](j)}(hstruct net_device *devh](ju)}(hjnh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hj hhhNhNubah}(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 classnameNjS jV )}jY ]j)}jjsbc.cfg80211_rx_assoc_respasbuh1hhjubj)}(h h]h }(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hdevh]hdev}(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h.const struct cfg80211_rx_assoc_resp_data *datah](ju)}(hjIh]hconst}(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjkubj)}(h h]h }(hj|hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjkubju)}(hjnh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjkubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjkubh)}(hhh]j)}(hcfg80211_rx_assoc_resp_datah]hcfg80211_rx_assoc_resp_data}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNjS jV )}jY ]j7c.cfg80211_rx_assoc_respasbuh1hhjkubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjkubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjkubj)}(hdatah]hdata}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjkubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMkubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMkubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMkhjhhubj)}(hhh]h)}(h.notification of processed association responseh]h.notification of processed association response}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMkhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMkubeh}(h]h ](j$functioneh"]h$]h&]jj$jj#jj#jjjuh1jchhhjbhNhNubj)}(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)}(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.hhMohj'ubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hjLh]hstruct net_device *dev}(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.hhMlhjFubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjahMlhjbubah}(h]h ]h"]h$]h&]uh1j5hjFubeh}(h]h ]h"]h$]h&]uh1jhjahMlhjCubj)}(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}(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.hhMmhjubj6)}(hhh]h)}(heassociation response data, :c:type:`struct cfg80211_rx_assoc_resp_data `h](hassociation response data, }(hjhhhNhNubh)}(hJ:c:type:`struct cfg80211_rx_assoc_resp_data `h]j)}(hjh]h"struct cfg80211_rx_assoc_resp_data}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6cfg80211_rx_assoc_resp_datauh1hhjhMmhjubeh}(h]h ]h"]h$]h&]uh1hhjhMmhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMmhjCubeh}(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.hhMohj'ubh)}(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().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMnhj'ubh)}(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.hhMqhj'ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_tx_mlme_mgmt (C function)c.cfg80211_tx_mlme_mgmthNtauh1jRhjbhhhNhNubjd)}(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}(hj3hhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hj/hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/hhhjAhMubj)}(hcfg80211_tx_mlme_mgmth]j)}(hcfg80211_tx_mlme_mgmth]hcfg80211_tx_mlme_mgmt}(hjThhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjPubah}(h]h ](jjeh"]h$]h&]jjuh1jhj/hhhjAhMubj)}(hC(struct net_device *dev, const u8 *buf, size_t len, bool reconnect)h](j)}(hstruct net_device *devh](ju)}(hjnh]hstruct}(hjphhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjlubj)}(h h]h }(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjlubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNjS jV )}jY ]j)}jjVsbc.cfg80211_tx_mlme_mgmtasbuh1hhjlubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjlubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjlubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjlubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjhubj)}(h const u8 *bufh](ju)}(hjIh]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 classnameNjS jV )}jY ]jc.cfg80211_tx_mlme_mgmtasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hbufh]hbuf}(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjhubj)}(h size_t lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjWmodnameN classnameNjS jV )}jY ]jc.cfg80211_tx_mlme_mgmtasbuh1hhjNubj)}(h h]h }(hjshhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNubj)}(hlenh]hlen}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjhubj)}(hbool reconnecth](j`)}(hboolh]hbool}(hjhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h reconnecth]h reconnect}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjhubeh}(h]h ]h"]h$]h&]jjuh1jhj/hhhjAhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj+hhhjAhMubah}(h]j&ah ](jjeh"]h$]h&]jj)jhuh1jhhjAhMhj(hhubj)}(hhh]h)}(h1notification of transmitted deauth/disassoc frameh]h1notification of transmitted deauth/disassoc frame}(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(hhhjAhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhjbhNhNubj)}(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.hhMhjubj)}(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&]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}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hMhj7ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj6hMhjubj)}(h/``const u8 *buf`` 802.11 frame (header + body) h](j)}(h``const u8 *buf``h]j)}(hjZh]h const u8 *buf}(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.hhMhjTubj6)}(hhh]h)}(h802.11 frame (header + body)h]h802.11 frame (header + body)}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhjohMhjpubah}(h]h ]h"]h$]h&]uh1j5hjTubeh}(h]h ]h"]h$]h&]uh1jhjohMhjubj)}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hR``bool reconnect`` immediate reconnect is desired (include the nl80211 attribute) h](j)}(h``bool reconnect``h]j)}(hjh]hbool reconnect}(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>immediate reconnect is desired (include the nl80211 attribute)h]h>immediate reconnect is desired (include the nl80211 attribute)}(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)}(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.hhMhjubh)}(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.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_)cfg80211_michael_mic_failure (C function)c.cfg80211_michael_mic_failurehNtauh1jRhjbhhhNhNubjd)}(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}(hjLhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjHhhh`/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&]uh1jhjHhhhjZhMubj)}(hcfg80211_michael_mic_failureh]j)}(hcfg80211_michael_mic_failureh]hcfg80211_michael_mic_failure}(hjmhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjiubah}(h]h ](jjeh"]h$]h&]jjuh1jhjHhhhjZhMubj)}(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)}(hjnh]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 classnameNjS jV )}jY ]j)}jjosbc.cfg80211_michael_mic_failureasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *addrh](ju)}(hjIh]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 classnameNjS jV )}jY ]jc.cfg80211_michael_mic_failureasbuh1hhjubj)}(h h]h }(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(haddrh]haddr}(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(henum nl80211_key_type key_typeh](ju)}(hjxh]henum}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjgubj)}(h h]h }(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjgubh)}(hhh]j)}(hnl80211_key_typeh]hnl80211_key_type}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNjS jV )}jY ]jc.cfg80211_michael_mic_failureasbuh1hhjgubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjgubj)}(hkey_typeh]hkey_type}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjgubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h int key_idh](j`)}(hinth]hint}(hjhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hkey_idh]hkey_id}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h const u8 *tsch](ju)}(hjIh]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 classnameNjS jV )}jY ]jc.cfg80211_michael_mic_failureasbuh1hhjubj)}(h h]h }(hj?hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(htsch]htsc}(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjvhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjxmodnameN classnameNjS jV )}jY ]jc.cfg80211_michael_mic_failureasbuh1hhjoubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjoubj)}(hgfph]hgfp}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjoubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjHhhhjZhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjDhhhjZhMubah}(h]j?ah ](jjeh"]h$]h&]jj)jhuh1jhhjZhMhjAhhubj)}(hhh]h)}(h*notification of Michael MIC failure (TKIP)h]h*notification of Michael MIC failure (TKIP)}(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&]uh1jhjAhhhjZhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhjbhNhNubj)}(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)}(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)}(hj h]hstruct net_device *dev}(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)}(hnetwork deviceh]hnetwork device}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hMhj#ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj"hMhjubj)}(h7``const u8 *addr`` The source MAC address of the frame h](j)}(h``const u8 *addr``h]j)}(hjFh]hconst u8 *addr}(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.hhMhj@ubj6)}(hhh]h)}(h#The source MAC address of the frameh]h#The source MAC address of the frame}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hMhj\ubah}(h]h ]h"]h$]h&]uh1j5hj@ubeh}(h]h ]h"]h$]h&]uh1jhj[hMhjubj)}(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&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjyubj6)}(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&]uh1j5hjyubeh}(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)}(hjh]h int key_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.h6hMhjubj6)}(hhh]h)}(h,Key identifier (0..3). Can be -1 if missing.h]h,Key identifier (0..3). Can be -1 if missing.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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)}(hjh]h const u8 *tsc}(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)}(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)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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.hhMhj$ubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hMhj@ubah}(h]h ]h"]h$]h&]uh1j5hj$ubeh}(h]h ]h"]h$]h&]uh1jhj?hMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjeh]h Description}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjcubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh)}(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.}(hj{hhhNhNubah}(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&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_!cfg80211_ibss_joined (C function)c.cfg80211_ibss_joinedhNtauh1jRhjbhhhNhNubjd)}(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}(hjhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjhhh`/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_ibss_joinedh]j)}(hcfg80211_ibss_joinedh]hcfg80211_ibss_joined}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMubj)}(hW(struct net_device *dev, const u8 *bssid, struct ieee80211_channel *channel, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjnh]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 classnameNjS jV )}jY ]j)}jjsbc.cfg80211_ibss_joinedasbuh1hhjubj)}(h h]h }(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hdevh]hdev}(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *bssidh](ju)}(hjIh]hconst}(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjUubj)}(h h]h }(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUubh)}(hhh]j)}(hu8h]hu8}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjtubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjymodnameN classnameNjS jV )}jY ]j!c.cfg80211_ibss_joinedasbuh1hhjUubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUubj)}(hbssidh]hbssid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h!struct ieee80211_channel *channelh](ju)}(hjnh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hieee80211_channelh]hieee80211_channel}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNjS jV )}jY ]j!c.cfg80211_ibss_joinedasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hchannelh]hchannel}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hj<hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj>modnameN classnameNjS jV )}jY ]j!c.cfg80211_ibss_joinedasbuh1hhj5ubj)}(h h]h }(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5ubj)}(hgfph]hgfp}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5ubeh}(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*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&]uh1jhjhhhjhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhjbhNhNubj)}(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)}(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)}(h1``const u8 *bssid`` the BSSID of the IBSS joined h](j)}(h``const u8 *bssid``h]j)}(hj h]hconst u8 *bssid}(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)}(hthe BSSID of the IBSS joinedh]hthe BSSID of the IBSS joined}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hMhj"ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj!hMhjubj)}(hE``struct ieee80211_channel *channel`` the channel of the IBSS joined h](j)}(h%``struct ieee80211_channel *channel``h]j)}(hjEh]h!struct ieee80211_channel *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.hhMhj?ubj6)}(hhh]h)}(hthe channel of the IBSS joinedh]hthe channel of the IBSS joined}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhMhj[ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhjZhMhjubj)}(h``gfp_t gfp`` allocation flags h](j)}(h ``gfp_t gfp``h]j)}(hj~h]h gfp_t gfp}(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)}(hallocation flagsh]hallocation flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjxubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(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.hhMhjubh)}(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.}(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&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_'cfg80211_connect_resp_params (C struct)c.cfg80211_connect_resp_paramshNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hcfg80211_connect_resp_paramsh]jo)}(h#struct cfg80211_connect_resp_paramsh](ju)}(hjnh]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 }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhj hMubj)}(hcfg80211_connect_resp_paramsh]j)}(hjh]hcfg80211_connect_resp_params}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhj hMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhj hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhj hMhjhhubj)}(hhh]h)}(hConnection response paramsh]hConnection response params}(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&]uh1jhjhhhj hMubeh}(h]h ](j$structeh"]h$]h&]jj$jjXjjXjjjuh1jchhhjbhNhNubj)}(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}(hjdhhhNhNubah}(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.hhMD!hj\ubj)}(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]; };}hj}sbah}(h]h ]h"]h$]h&]jjuh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMF!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.hhMX!hj\ubj)}(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)}(hjh]hstatus}(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)}(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.hhMB!hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMI!hjubj)}(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.hhMJ!hjubj6)}(hhh]h)}(h)Association request IEs (may be ``NULL``)h](h Association request IEs (may be }(hj6hhhNhNubj)}(h``NULL``h]hNULL}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubh)}(hj6hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj2hMJ!hj3ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj2hMJ!hjubj)}(h.``req_ie_len`` Association request IEs length h](j)}(h``req_ie_len``h]j)}(hjhh]h req_ie_len}(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.hhMK!hjbubj6)}(hhh]h)}(hAssociation request IEs lengthh]hAssociation request IEs length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj}hMK!hj~ubah}(h]h ]h"]h$]h&]uh1j5hjbubeh}(h]h ]h"]h$]h&]uh1jhj}hMK!hjubj)}(h7``resp_ie`` Association response IEs (may be ``NULL``) h](j)}(h ``resp_ie``h]j)}(hjh]hresp_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.hhML!hjubj6)}(hhh]h)}(h*Association response IEs (may be ``NULL``)h](h!Association response IEs (may be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhML!hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhML!hjubj)}(h0``resp_ie_len`` Association response IEs length h](j)}(h``resp_ie_len``h]j)}(hjh]h resp_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.hhMM!hjubj6)}(hhh]h)}(hAssociation response IEs lengthh]hAssociation response IEs length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMM!hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMM!hjubj)}(h.``fils`` FILS connection response parameters. h](j)}(h``fils``h]j)}(hj%h]hfils}(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!hjubj6)}(hhh]h)}(h$FILS connection response parameters.h]h$FILS connection response parameters.}(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)}(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)}(hj^h]htimeout_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.hhMT!hjXubj6)}(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. }(hjwhhhNhNubj)}(h``NL80211_TIMEOUT_UNSPECIFIED``h]hNL80211_TIMEOUT_UNSPECIFIED}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubhJ is used when the timeout reason is not known. This value is used only if }(hjwhhhNhNubj)}(h **status**h]hstatus}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwubh < 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 (}(hjwhhhNhNubj)}(h **status**h]hstatus}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwubh >= 0).}(hjwhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMO!hjtubah}(h]h ]h"]h$]h&]uh1j5hjXubeh}(h]h ]h"]h$]h&]uh1jhjshMT!hjubj)}(hO``ap_mld_addr`` For MLO connection, MLD address of the AP. Otherwise ``NULL``. 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.hhMW!hjubj6)}(hhh]h)}(h>For MLO connection, MLD address of the AP. Otherwise ``NULL``.h](h5For MLO connection, MLD address of the AP. Otherwise }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMW!hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMW!hjubj)}(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.hhMV!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.}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMU!hj/ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj.hMV!hjubj)}(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)}(hjSh]hlinks}(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.hhMZ!hjMubj6)}(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 }(hjlhhhNhNubj)}(h**valid_links**h]h valid_links}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlubhB. For non-MLO connection, links[0] contains the connected AP info.}(hjlhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMX!hjiubah}(h]h ]h"]h$]h&]uh1j5hjMubeh}(h]h ]h"]h$]h&]uh1jhjhhMZ!hjubj)}(hT``links.addr`` For MLO connection, MAC address of the STA link. Otherwise ``NULL``. h](j)}(h``links.addr``h]j)}(hjh]h links.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)}(hDFor MLO connection, MAC address of the STA link. Otherwise ``NULL``.h](h;For MLO connection, MAC address of the STA link. 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``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)}(hjh]h links.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)}(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}(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.hhM]!hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM^!hjubj)}(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)}(hj7h]h links.bss}(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.hhMf!hj1ubj6)}(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 }(hjPhhhNhNubj)}(h``NULL``h]hNULL}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubhX). 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 }(hjPhhhNhNubj)}(h **bssid**h]hbssid}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPubh and }(hjPhhhNhNubj)}(h**bss**h]hbss}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPubh needs to be specified.}(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&]uh1jhjLhMf!hjubj)}(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)}(hjh]h links.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.hhMh!hjubj6)}(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 }(hjhhhNhNubj)}(h``WLAN_STATUS_SUCCESS``h]hWLAN_STATUS_SUCCESS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh* for a given link, it must also be in the }(hjhhhNhNubj)}(h**valid_links**h]h valid_links}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh; bitmap and may have a BSS pointer (which is then released)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMg!hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMh!hjubeh}(h]h ]h"]h$]h&]uh1jhj\ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_connect_done (C function)c.cfg80211_connect_donehNtauh1jRhjbhhhNhNubjd)}(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}(hj%hhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hj!hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM~!ubj)}(h h]h }(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!hhhj3hM~!ubj)}(hcfg80211_connect_doneh]j)}(hcfg80211_connect_doneh]hcfg80211_connect_done}(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubah}(h]h ](jjeh"]h$]h&]jjuh1jhj!hhhj3hM~!ubj)}(hP(struct net_device *dev, struct cfg80211_connect_resp_params *params, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjnh]hstruct}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj^ubj)}(h h]h }(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNjS jV )}jY ]j)}jjHsbc.cfg80211_connect_doneasbuh1hhj^ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjZubj)}(h+struct cfg80211_connect_resp_params *paramsh](ju)}(hjnh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hcfg80211_connect_resp_paramsh]hcfg80211_connect_resp_params}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNjS jV )}jY ]jc.cfg80211_connect_doneasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hparamsh]hparams}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjZubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjImodnameN classnameNjS jV )}jY ]jc.cfg80211_connect_doneasbuh1hhj@ubj)}(h h]h }(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@ubj)}(hgfph]hgfp}(hjshhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjZubeh}(h]h ]h"]h$]h&]jjuh1jhj!hhhj3hM~!ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhj3hM~!ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhj3hM~!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&]uh1jhjhhhj3hM~!ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhjbhNhNubj)}(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)}(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.hhM!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.hhM!hjubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM!hjubj)}(hO``struct cfg80211_connect_resp_params *params`` connection response parameters h](j)}(h/``struct cfg80211_connect_resp_params *params``h]j)}(hj h]h+struct cfg80211_connect_resp_params *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.hhM!hj ubj6)}(hhh]h)}(hconnection response parametersh]hconnection response parameters}(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!hjubj)}(h``gfp_t gfp`` allocation flags h](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&]uh1hhje hM!hjf ubah}(h]h ]h"]h$]h&]uh1j5hjJ ubeh}(h]h ]h"]h$]h&]uh1jhje hM!hjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(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!hjubh)}(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!hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_!cfg80211_connect_bss (C function)c.cfg80211_connect_bsshNtauh1jRhjbhhhNhNubjd)}(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}(hj hhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hj 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_connect_bssh]j)}(hcfg80211_connect_bssh]hcfg80211_connect_bss}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj 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)}(hjnh]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 classnameNjS jV )}jY ]j)}jj sbc.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hjK hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(hjh]h*}(hjY hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(hdevh]hdev}(hjf hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hconst u8 *bssidh](ju)}(hjIh]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 classnameNjS jV )}jY ]jG c.cfg80211_connect_bssasbuh1hhj{ ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ ubj)}(hjh]h*}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ ubj)}(hbssidh]hbssid}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hstruct cfg80211_bss *bssh](ju)}(hjnh]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 classnameNjS jV )}jY ]jG c.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hj+ hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(hjh]h*}(hj9 hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(hbssh]hbss}(hjF hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hconst u8 *req_ieh](ju)}(hjIh]hconst}(hj_ hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj[ ubj)}(h h]h }(hjl hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ ubh)}(hhh]j)}(hu8h]hu8}(hj} hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjz ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNjS jV )}jY ]jG c.cfg80211_connect_bssasbuh1hhj[ ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ ubj)}(hjh]h*}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ ubj)}(hreq_ieh]hreq_ie}(hj 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}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNjS jV )}jY ]jG c.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(h req_ie_lenh]h req_ie_len}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hconst u8 *resp_ieh](ju)}(hjIh]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}(hj5 hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2 ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj7 modnameN classnameNjS jV )}jY ]jG c.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hjS hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(hjh]h*}(hja hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(hresp_ieh]hresp_ie}(hjn 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 classnameNjS jV )}jY ]jG 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}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h int statush](j`)}(hinth]hint}(hj hhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(hstatush]hstatus}(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 classnameNjS jV )}jY ]jG c.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hj% hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(hgfph]hgfp}(hj3 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}(hjL hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjH ubj)}(h h]h }(hjY hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjH ubh)}(hhh]j)}(hnl80211_timeout_reasonh]hnl80211_timeout_reason}(hjj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjg ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjl modnameN classnameNjS jV )}jY ]jG c.cfg80211_connect_bssasbuh1hhjH ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjH ubj)}(htimeout_reasonh]htimeout_reason}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjH 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$notify cfg80211 of connection resulth]h$notify cfg80211 of connection result}(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 jjjuh1jchhhjbhNhNubj)}(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)}(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`` network device h](j)}(h``struct net_device *dev``h]j)}(hjh]hstruct net_device *dev}(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)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhjhM!hj 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&]uh1jhj8ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj4ubj6)}(hhh]h)}(hthe BSSID of the APh]hthe BSSID of the AP}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhjOhM!hjPubah}(h]h ]h"]h$]h&]uh1j5hj4ubeh}(h]h ]h"]h$]h&]uh1jhjOhM!hj 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)}(hjsh]hstruct cfg80211_bss *bss}(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)}(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}(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.hhM!hjubah}(h]h ]h"]h$]h&]uh1j5hjmubeh}(h]h ]h"]h$]h&]uh1jhjhM!hj ubj)}(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!hj ubj)}(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}(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)}(hassociation request IEs lengthh]hassociation request IEs length}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChM!hjDubah}(h]h ]h"]h$]h&]uh1j5hj(ubeh}(h]h ]h"]h$]h&]uh1jhjChM!hj ubj)}(hA``const u8 *resp_ie`` association response IEs (may be ``NULL``) h](j)}(h``const u8 *resp_ie``h]j)}(hjgh]hconst u8 *resp_ie}(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*association response IEs (may be ``NULL``)h](h!association response IEs (may be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj|hM!hj}ubah}(h]h ]h"]h$]h&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hM!hj ubj)}(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&]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)}(hassoc response IEs lengthh]hassoc response IEs length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM!hj 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)}(hjh]h int 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)}(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.Kh](h status code, }(hjhhhNhNubj)}(h``WLAN_STATUS_SUCCESS``h]hWLAN_STATUS_SUCCESS}(hj hhhNhNubah}(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}(hj0hhhNhNubah}(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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM!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&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjUubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1hhjphM!hjqubah}(h]h ]h"]h$]h&]uh1j5hjUubeh}(h]h ]h"]h$]h&]uh1jhjphM!hj 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. }(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}(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!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&]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&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_$cfg80211_connect_result (C function)c.cfg80211_connect_resulthNtauh1jRhjbhhhNhNubjd)}(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}(hjKhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjGhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!ubj)}(h h]h }(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGhhhjYhM!ubj)}(hcfg80211_connect_resulth]j)}(hcfg80211_connect_resulth]hcfg80211_connect_result}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubah}(h]h ](jjeh"]h$]h&]jjuh1jhjGhhhjYhM!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)}(hjnh]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 classnameNjS jV )}jY ]j)}jjnsbc.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *bssidh](ju)}(hjIh]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 classnameNjS jV )}jY ]jc.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hbssidh]hbssid}(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *req_ieh](ju)}(hjIh]hconst}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjfubj)}(h h]h }(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNjS jV )}jY ]jc.cfg80211_connect_resultasbuh1hhjfubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfubj)}(hreq_ieh]hreq_ie}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hsize_t req_ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNjS jV )}jY ]jc.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h req_ie_lenh]h req_ie_len}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *resp_ieh](ju)}(hjIh]hconst}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjBmodnameN classnameNjS jV )}jY ]jc.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hresp_ieh]hresp_ie}(hjyhhhNhNubah}(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 classnameNjS jV )}jY ]jc.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h resp_ie_lenh]h resp_ie_len}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u16 statush](h)}(hhh]j)}(hu16h]hu16}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNjS jV )}jY ]jc.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hstatush]hstatus}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(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 classnameNjS jV )}jY ]jc.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjGhhhjYhM!ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjChhhjYhM!ubah}(h]j>ah ](jjeh"]h$]h&]jj)jhuh1jhhjYhM!hj@hhubj)}(hhh]h)}(h$notify cfg80211 of connection resulth]h$notify cfg80211 of connection result}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjxhhubah}(h]h ]h"]h$]h&]uh1jhj@hhhjYhM!ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhjbhNhNubj)}(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}(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!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.hhM!hjubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM!hjubj)}(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&]uh1hhj hM!hj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hM!hjubj)}(hA``const u8 *req_ie`` association request IEs (maybe be ``NULL``) h](j)}(h``const u8 *req_ie``h]j)}(hj.h]hconst u8 *req_ie}(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)}(h+association request IEs (maybe be ``NULL``)h](h"association request IEs (maybe be }(hjGhhhNhNubj)}(h``NULL``h]hNULL}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubh)}(hjGhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjChM!hjDubah}(h]h ]h"]h$]h&]uh1j5hj(ubeh}(h]h ]h"]h$]h&]uh1jhjChM!hjubj)}(h5``size_t req_ie_len`` association request IEs length h](j)}(h``size_t req_ie_len``h]j)}(hjyh]hsize_t req_ie_len}(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)}(hassociation request IEs lengthh]hassociation request IEs length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1j5hjsubeh}(h]h ]h"]h$]h&]uh1jhjhM!hjubj)}(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}(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!hjubj)}(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&]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)}(hassoc response IEs lengthh]hassoc response IEs length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM!hjubj)}(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)}(hj6h]h u16 status}(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.hhM!hj0ubj6)}(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, }(hjOhhhNhNubj)}(h``WLAN_STATUS_SUCCESS``h]hWLAN_STATUS_SUCCESS}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubh for successful connection, use }(hjOhhhNhNubj)}(h#``WLAN_STATUS_UNSPECIFIED_FAILURE``h]hWLAN_STATUS_UNSPECIFIED_FAILURE}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubhB if your device cannot give you the real status code for failures.}(hjOhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjLubah}(h]h ]h"]h$]h&]uh1j5hj0ubeh}(h]h ]h"]h$]h&]uh1jhjKhM!hjubj)}(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!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.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.}(hjhhhNhNubah}(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&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_%cfg80211_connect_timeout (C function)c.cfg80211_connect_timeouthNtauh1jRhjbhhhNhNubjd)}(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 ]jlah"]h$]h&]uh1j_hjhhh`/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_connect_timeouth]j)}(hcfg80211_connect_timeouth]hcfg80211_connect_timeout}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhj"hM!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)}(hjnh]hstruct}(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjMubj)}(h h]h }(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjMubh)}(hhh]j)}(h net_deviceh]h net_device}(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjqmodnameN classnameNjS jV )}jY ]j)}jj7sbc.cfg80211_connect_timeoutasbuh1hhjMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjMubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjMubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjMubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjIubj)}(hconst u8 *bssidh](ju)}(hjIh]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 classnameNjS jV )}jY ]jc.cfg80211_connect_timeoutasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hbssidh]hbssid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjIubj)}(hconst u8 *req_ieh](ju)}(hjIh]hconst}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj/ubj)}(h h]h }(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/ubh)}(hhh]j)}(hu8h]hu8}(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjSmodnameN classnameNjS jV )}jY ]jc.cfg80211_connect_timeoutasbuh1hhj/ubj)}(h h]h }(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/ubj)}(hjh]h*}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/ubj)}(hreq_ieh]hreq_ie}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjIubj)}(hsize_t req_ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNjS jV )}jY ]jc.cfg80211_connect_timeoutasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h req_ie_lenh]h req_ie_len}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjIubj)}(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 classnameNjS jV )}jY ]jc.cfg80211_connect_timeoutasbuh1hhjubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjIubj)}(h*enum nl80211_timeout_reason timeout_reasonh](ju)}(hjxh]henum}(hj3hhhNhNubah}(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}(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjSmodnameN classnameNjS jV )}jY ]jc.cfg80211_connect_timeoutasbuh1hhj/ubj)}(h h]h }(hjohhhNhNubah}(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&]noemphjjuh1jhjIubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhj"hM!ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj hhhj"hM!ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhj"hM!hj hhubj)}(hhh]h)}(h%notify cfg80211 of connection timeouth]h%notify cfg80211 of connection timeout}(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&]uh1jhj hhhj"hM!ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhjbhNhNubj)}(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)}(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.hhM!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.hhM!hjubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM!hjubj)}(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&]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}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hM!hj7ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj6hM!hjubj)}(hA``const u8 *req_ie`` association request IEs (maybe be ``NULL``) h](j)}(h``const u8 *req_ie``h]j)}(hjZh]hconst u8 *req_ie}(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.hhM!hjTubj6)}(hhh]h)}(h+association request IEs (maybe be ``NULL``)h](h"association request IEs (maybe be }(hjshhhNhNubj)}(h``NULL``h]hNULL}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubh)}(hjshhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjohM!hjpubah}(h]h ]h"]h$]h&]uh1j5hjTubeh}(h]h ]h"]h$]h&]uh1jhjohM!hjubj)}(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!hjubj)}(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!hjubj)}(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.}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,hM!hj-ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj,hM!hjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjRh]h Description}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjubh)}(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.}(hjhhhhNhNubah}(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&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_roamed (C function)c.cfg80211_roamedhNtauh1jRhjbhhhNhNubjd)}(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 ]jlah"]h$]h&]uh1j_hjhhh`/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_roamedh]j)}(hcfg80211_roamedh]hcfg80211_roamed}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM-"ubj)}(hD(struct net_device *dev, struct cfg80211_roam_info *info, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjnh]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 classnameNjS jV )}jY ]j)}jjsbc.cfg80211_roamedasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hdevh]hdev}(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct cfg80211_roam_info *infoh](ju)}(hjnh]hstruct}(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjBubj)}(h h]h }(hjShhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubh)}(hhh]j)}(hcfg80211_roam_infoh]hcfg80211_roam_info}(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjfmodnameN classnameNjS jV )}jY ]jc.cfg80211_roamedasbuh1hhjBubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubj)}(hinfoh]hinfo}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubeh}(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 classnameNjS jV )}jY ]jc.cfg80211_roamedasbuh1hhjubj)}(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)}(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.hhM-"hj hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM-"ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj'jj'jjjuh1jchhhjbhNhNubj)}(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)}(hj1h]h Parameters}(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.hhM1"hj+ubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hjPh]hstruct net_device *dev}(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.hhM/"hjJubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehM/"hjfubah}(h]h ]h"]h$]h&]uh1j5hjJubeh}(h]h ]h"]h$]h&]uh1jhjehM/"hjGubj)}(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)}(hjh]hstruct cfg80211_roam_info *info}(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.hhM0"hjubj6)}(hhh]h)}(hCinformation about the new BSS. struct :c:type:`cfg80211_roam_info`.h](h&information about the new BSS. struct }(hjhhhNhNubh)}(h:c:type:`cfg80211_roam_info`h]j)}(hjh]hcfg80211_roam_info}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6cfg80211_roam_infouh1hhjhM0"hjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM0"hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM0"hjGubj)}(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.hhM1"hjubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM1"hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM1"hjGubeh}(h]h ]h"]h$]h&]uh1jhj+ubh)}(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.hhM3"hj+ubh)}(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.}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM2"hj+ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_disconnected (C function)c.cfg80211_disconnectedhNtauh1jRhjbhhhNhNubjd)}(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}(hjehhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjahhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMY"ubj)}(h h]h }(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjahhhjshMY"ubj)}(hcfg80211_disconnectedh]j)}(hcfg80211_disconnectedh]hcfg80211_disconnected}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjahhhjshMY"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)}(hjnh]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 classnameNjS jV )}jY ]j)}jjsbc.cfg80211_disconnectedasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(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 classnameNjS jV )}jY ]jc.cfg80211_disconnectedasbuh1hhjubj)}(h h]h }(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hreasonh]hreason}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h const u8 *ieh](ju)}(hjIh]hconst}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjXubj)}(h h]h }(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubh)}(hhh]j)}(hu8h]hu8}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj|modnameN classnameNjS jV )}jY ]jc.cfg80211_disconnectedasbuh1hhjXubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubj)}(hieh]hie}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h size_t ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNjS jV )}jY ]jc.cfg80211_disconnectedasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hie_lenh]hie_len}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hbool locally_generatedh](j`)}(hjh]hbool}(hj hhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hj ubj)}(h h]h }(hj! hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(hlocally_generatedh]hlocally_generated}(hj/ hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjK hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjH ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjM modnameN classnameNjS jV )}jY ]jc.cfg80211_disconnectedasbuh1hhjD ubj)}(h h]h }(hji hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjD ubj)}(hgfph]hgfp}(hjw hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjD ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjahhhjshMY"ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj]hhhjshMY"ubah}(h]jXah ](jjeh"]h$]h&]jj)jhuh1jhhjshMY"hjZhhubj)}(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.hhMY"hj hhubah}(h]h ]h"]h$]h&]uh1jhjZhhhjshMY"ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj jj jjjuh1jchhhjbhNhNubj)}(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)}(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`` 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["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.hhM^"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}(hj4!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0!hM^"hj1!ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj0!hM^"hj ubj)}(hU``const u8 *ie`` information elements of the deauth/disassoc frame (may be ``NULL``) h](j)}(h``const u8 *ie``h]j)}(hjT!h]h const u8 *ie}(hjV!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjR!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM\"hjN!ubj6)}(hhh]h)}(hCinformation elements of the deauth/disassoc frame (may be ``NULL``)h](h:information elements of the deauth/disassoc frame (may be }(hjm!hhhNhNubj)}(h``NULL``h]hNULL}(hju!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjm!ubh)}(hjm!hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhji!hM\"hjj!ubah}(h]h ]h"]h$]h&]uh1j5hjN!ubeh}(h]h ]h"]h$]h&]uh1jhji!hM\"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.hhM]"hj!ubj6)}(hhh]h)}(h length of IEsh]h length of IEs}(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?``bool locally_generated`` disconnection was requested locally h](j)}(h``bool locally_generated``h]j)}(hj!h]hbool locally_generated}(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#disconnection was requested locallyh]h#disconnection was requested locally}(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``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.hhM`"hj "ubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(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&]uh1jhj ubh)}(h**Description**h]j)}(hjL"h]h Description}(hjN"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJ"ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMb"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.}(hjb"hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMa"hj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_&cfg80211_ready_on_channel (C function)c.cfg80211_ready_on_channelhNtauh1jRhjbhhhNhNubjd)}(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 ]jlah"]h$]h&]uh1j_hj"hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMj"ubj)}(h h]h }(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"hhhj"hMj"ubj)}(hcfg80211_ready_on_channelh]j)}(hcfg80211_ready_on_channelh]hcfg80211_ready_on_channel}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj"hhhj"hMj"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)}(hjnh]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 classnameNjS jV )}jY ]j)}jj"sbc.cfg80211_ready_on_channelasbuh1hhj"ubj)}(h h]h }(hj #hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"ubj)}(hjh]h*}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"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}(hjC#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@#ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjE#modnameN classnameNjS jV )}jY ]j#c.cfg80211_ready_on_channelasbuh1hhj<#ubj)}(h h]h }(hja#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj<#ubj)}(hcookieh]hcookie}(hjo#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj<#ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj"ubj)}(hstruct ieee80211_channel *chanh](ju)}(hjnh]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 classnameNjS jV )}jY ]j#c.cfg80211_ready_on_channelasbuh1hhj#ubj)}(h h]h }(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#ubj)}(hjh]h*}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#ubj)}(hchanh]hchan}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj"ubj)}(hunsigned int durationh](j`)}(hunsignedh]hunsigned}(hj#hhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hj#ubj)}(h h]h }(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#ubj`)}(hinth]hint}(hj$hhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hj#ubj)}(h h]h }(hj"$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#ubj)}(hdurationh]hduration}(hj0$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}(hjL$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjI$ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjN$modnameN classnameNjS jV )}jY ]j#c.cfg80211_ready_on_channelasbuh1hhjE$ubj)}(h h]h }(hjj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjE$ubj)}(hgfph]hgfp}(hjx$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjE$ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj"ubeh}(h]h ]h"]h$]h&]jjuh1jhj"hhhj"hMj"ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj"hhhj"hMj"ubah}(h]j"ah ](jjeh"]h$]h&]jj)jhuh1jhhj"hMj"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.hhMj"hj$hhubah}(h]h ]h"]h$]h&]uh1jhj"hhhj"hMj"ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj$jj$jjjuh1jchhhjbhNhNubj)}(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)}(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.hhMn"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.hhMk"hj$ubj6)}(hhh]h)}(hwireless deviceh]hwireless device}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$hMk"hj$ubah}(h]h ]h"]h$]h&]uh1j5hj$ubeh}(h]h ]h"]h$]h&]uh1jhj$hMk"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.hhMl"hj%ubj6)}(hhh]h)}(hthe request cookieh]hthe request cookie}(hj5%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1%hMl"hj2%ubah}(h]h ]h"]h$]h&]uh1j5hj%ubeh}(h]h ]h"]h$]h&]uh1jhj1%hMl"hj$ubj)}(hX``struct ieee80211_channel *chan`` The current channel (from remain_on_channel request) h](j)}(h"``struct ieee80211_channel *chan``h]j)}(hjU%h]hstruct ieee80211_channel *chan}(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:48: ./include/net/cfg80211.hhMm"hjO%ubj6)}(hhh]h)}(h4The current channel (from remain_on_channel request)h]h4The current channel (from remain_on_channel request)}(hjn%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjj%hMm"hjk%ubah}(h]h ]h"]h$]h&]uh1j5hjO%ubeh}(h]h ]h"]h$]h&]uh1jhjj%hMm"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.hhMo"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.hhMn"hj%ubah}(h]h ]h"]h$]h&]uh1j5hj%ubeh}(h]h ]h"]h$]h&]uh1jhj%hMo"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.hhMq"hj%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.hhMp"hj%ubah}(h]h ]h"]h$]h&]uh1j5hj%ubeh}(h]h ]h"]h$]h&]uh1jhj%hMq"hj$ubeh}(h]h ]h"]h$]h&]uh1jhj$ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_/cfg80211_remain_on_channel_expired (C function)$c.cfg80211_remain_on_channel_expiredhNtauh1jRhjbhhhNhNubjd)}(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 ]jlah"]h$]h&]uh1j_hj&hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMw"ubj)}(h h]h }(hj1&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&hhhj0&hMw"ubj)}(h"cfg80211_remain_on_channel_expiredh]j)}(h"cfg80211_remain_on_channel_expiredh]h"cfg80211_remain_on_channel_expired}(hjC&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj?&ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj&hhhj0&hMw"ubj)}(hR(struct wireless_dev *wdev, u64 cookie, struct ieee80211_channel *chan, gfp_t gfp)h](j)}(hstruct wireless_dev *wdevh](ju)}(hjnh]hstruct}(hj_&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj[&ubj)}(h h]h }(hjl&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[&ubh)}(hhh]j)}(h wireless_devh]h wireless_dev}(hj}&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjz&ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj&modnameN classnameNjS jV )}jY ]j)}jjE&sb$c.cfg80211_remain_on_channel_expiredasbuh1hhj[&ubj)}(h h]h }(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[&ubj)}(hjh]h*}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[&ubj)}(hwdevh]hwdev}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[&ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjW&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 classnameNjS jV )}jY ]j&$c.cfg80211_remain_on_channel_expiredasbuh1hhj&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&]noemphjjuh1jhjW&ubj)}(hstruct ieee80211_channel *chanh](ju)}(hjnh]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}(hj7'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4'ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj9'modnameN classnameNjS jV )}jY ]j&$c.cfg80211_remain_on_channel_expiredasbuh1hhj'ubj)}(h h]h }(hjU'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubj)}(hjh]h*}(hjc'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubj)}(hchanh]hchan}(hjp'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjW&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 classnameNjS jV )}jY ]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&]noemphjjuh1jhjW&ubeh}(h]h ]h"]h$]h&]jjuh1jhj&hhhj0&hMw"ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj&hhhj0&hMw"ubah}(h]j&ah ](jjeh"]h$]h&]jj)jhuh1jhhj0&hMw"hj&hhubj)}(hhh]h)}(h"remain_on_channel duration expiredh]h"remain_on_channel duration expired}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMw"hj'hhubah}(h]h ]h"]h$]h&]uh1jhj&hhhj0&hMw"ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj'jj'jjjuh1jchhhjbhNhNubj)}(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.hhMx"hj(ubj6)}(hhh]h)}(hwireless deviceh]hwireless device}(hj<(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8(hMx"hj9(ubah}(h]h ]h"]h$]h&]uh1j5hj(ubeh}(h]h ]h"]h$]h&]uh1jhj8(hMx"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&]uh1jhjZ(ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMy"hjV(ubj6)}(hhh]h)}(hthe request cookieh]hthe request cookie}(hju(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjq(hMy"hjr(ubah}(h]h ]h"]h$]h&]uh1j5hjV(ubeh}(h]h ]h"]h$]h&]uh1jhjq(hMy"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.hhMz"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(hMz"hj(ubah}(h]h ]h"]h$]h&]uh1j5hj(ubeh}(h]h ]h"]h$]h&]uh1jhj(hMz"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|"hj(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&]uh1j5hj(ubeh}(h]h ]h"]h$]h&]uh1jhj(hM|"hj(ubeh}(h]h ]h"]h$]h&]uh1jhj'ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_new_sta (C function)c.cfg80211_new_stahNtauh1jRhjbhhhNhNubjd)}(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 ]jlah"]h$]h&]uh1j_hj$)hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"ubj)}(h h]h }(hj7)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$)hhhj6)hM"ubj)}(hcfg80211_new_stah]j)}(hcfg80211_new_stah]hcfg80211_new_sta}(hjI)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjE)ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj$)hhhj6)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)}(hjnh]hstruct}(hje)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthja)ubj)}(h h]h }(hjr)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhja)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 classnameNjS jV )}jY ]j)}jjK)sbc.cfg80211_new_staasbuh1hhja)ubj)}(h h]h }(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhja)ubj)}(hjh]h*}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhja)ubj)}(hdevh]hdev}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhja)ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj])ubj)}(hconst u8 *mac_addrh](ju)}(hjIh]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 classnameNjS jV )}jY ]j)c.cfg80211_new_staasbuh1hhj)ubj)}(h h]h }(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubj)}(hjh]h*}(hj!*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubj)}(hmac_addrh]hmac_addr}(hj.*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj])ubj)}(hstruct station_info *sinfoh](ju)}(hjnh]hstruct}(hjG*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjC*ubj)}(h h]h }(hjT*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjC*ubh)}(hhh]j)}(h station_infoh]h station_info}(hje*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjb*ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjg*modnameN classnameNjS jV )}jY ]j)c.cfg80211_new_staasbuh1hhjC*ubj)}(h h]h }(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjC*ubj)}(hjh]h*}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjC*ubj)}(hsinfoh]hsinfo}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjC*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 classnameNjS jV )}jY ]j)c.cfg80211_new_staasbuh1hhj*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$)hhhj6)hM"ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj )hhhj6)hM"ubah}(h]j)ah ](jjeh"]h$]h&]jj)jhuh1jhhj6)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)hhhj6)hM"ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj(+jj(+jjjuh1jchhhjbhNhNubj)}(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)}(hj2+h]h Parameters}(hj4+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0+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)}(hjQ+h]hstruct net_device *dev}(hjS+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjO+ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjK+ubj6)}(hhh]h)}(h the netdevh]h the netdev}(hjj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjf+hM"hjg+ubah}(h]h ]h"]h$]h&]uh1j5hjK+ubeh}(h]h ]h"]h$]h&]uh1jhjf+hM"hjH+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"hjH+ubj)}(h7``struct station_info *sinfo`` the station information h](j)}(h``struct station_info *sinfo``h]j)}(hj+h]hstruct station_info *sinfo}(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 informationh]hthe station information}(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"hjH+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"hj+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&]uh1j5hj+ubeh}(h]h ]h"]h$]h&]uh1jhj,hM"hjH+ubeh}(h]h ]h"]h$]h&]uh1jhj,+ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_rx_mgmt (C function)c.cfg80211_rx_mgmthNtauh1jRhjbhhhNhNubjd)}(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}(hjV,hhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjR,hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM4#ubj)}(h h]h }(hjd,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjR,hhhjc,hM4#ubj)}(hcfg80211_rx_mgmth]j)}(hcfg80211_rx_mgmth]hcfg80211_rx_mgmt}(hjv,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjr,ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjR,hhhjc,hM4#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)}(hjnh]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 classnameNjS jV )}jY ]j)}jjx,sbc.cfg80211_rx_mgmtasbuh1hhj,ubj)}(h h]h }(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubj)}(hjh]h*}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubj)}(hwdevh]hwdev}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj,ubj)}(hint freqh](j`)}(hinth]hint}(hj-hhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hj-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}(hj9-hhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hj5-ubj)}(h h]h }(hjG-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5-ubj)}(hsig_dbmh]hsig_dbm}(hjU-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5-ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj,ubj)}(h const u8 *bufh](ju)}(hjIh]hconst}(hjn-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjj-ubj)}(h h]h }(hj{-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjj-ubh)}(hhh]j)}(hu8h]hu8}(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj-modnameN classnameNjS jV )}jY ]j,c.cfg80211_rx_mgmtasbuh1hhjj-ubj)}(h h]h }(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjj-ubj)}(hjh]h*}(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjj-ubj)}(hbufh]hbuf}(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjj-ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj,ubj)}(h size_t 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 classnameNjS jV )}jY ]j,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 classnameNjS jV )}jY ]j,c.cfg80211_rx_mgmtasbuh1hhj".ubj)}(h h]h }(hjG.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj".ubj)}(hflagsh]hflags}(hjU.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj".ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj,ubeh}(h]h ]h"]h$]h&]jjuh1jhjR,hhhjc,hM4#ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjN,hhhjc,hM4#ubah}(h]jI,ah ](jjeh"]h$]h&]jj)jhuh1jhhjc,hM4#hjK,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.hhM4#hj|.hhubah}(h]h ]h"]h$]h&]uh1jhjK,hhhjc,hM4#ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj.jj.jjjuh1jchhhjbhNhNubj)}(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.hhM8#hj.ubj)}(hhh](j)}(hB``struct wireless_dev *wdev`` wireless device receiving the frame 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.hhM5#hj.ubj6)}(hhh]h)}(h#wireless device receiving the frameh]h#wireless device receiving the frame}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.hM5#hj.ubah}(h]h ]h"]h$]h&]uh1j5hj.ubeh}(h]h ]h"]h$]h&]uh1jhj.hM5#hj.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&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM6#hj.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/hM6#hj/ubah}(h]h ]h"]h$]h&]uh1j5hj.ubeh}(h]h ]h"]h$]h&]uh1jhj/hM6#hj.ubj)}(h8``int sig_dbm`` signal strength in dBm, or 0 if unknown h](j)}(h``int sig_dbm``h]j)}(hj2/h]h int sig_dbm}(hj4/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0/ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM7#hj,/ubj6)}(hhh]h)}(h'signal strength in dBm, or 0 if unknownh]h'signal strength in dBm, or 0 if unknown}(hjK/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjG/hM7#hjH/ubah}(h]h ]h"]h$]h&]uh1j5hj,/ubeh}(h]h ]h"]h$]h&]uh1jhjG/hM7#hj.ubj)}(h3``const u8 *buf`` Management frame (header + body) h](j)}(h``const u8 *buf``h]j)}(hjk/h]h const u8 *buf}(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:48: ./include/net/cfg80211.hhM8#hje/ubj6)}(hhh]h)}(h Management frame (header + body)h]h Management frame (header + body)}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hM8#hj/ubah}(h]h ]h"]h$]h&]uh1j5hje/ubeh}(h]h ]h"]h$]h&]uh1jhj/hM8#hj.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.hhM9#hj/ubj6)}(hhh]h)}(hlength of the frame datah]hlength of the frame data}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hM9#hj/ubah}(h]h ]h"]h$]h&]uh1j5hj/ubeh}(h]h ]h"]h$]h&]uh1jhj/hM9#hj.ubj)}(h=``u32 flags`` flags, as defined in enum nl80211_rxmgmt_flags h](j)}(h ``u32 flags``h]j)}(hj/h]h u32 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.hhM:#hj/ubj6)}(hhh]h)}(h.flags, as defined in enum nl80211_rxmgmt_flagsh]h.flags, as defined in enum nl80211_rxmgmt_flags}(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&]uh1jhj.ubh)}(h**Description**h]j)}(hj0h]h Description}(hj0hhhNhNubah}(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<#hj.ubh)}(hzThis function is called whenever an Action frame is received for a station mode interface, but is not processed in kernel.h]hzThis function is called whenever an Action frame is received for a station mode interface, but is not processed in kernel.}(hj.0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM;#hj.ubh)}(h **Return**h]j)}(hj?0h]hReturn}(hjA0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=0ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM>#hj.ubh)}(hX``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](j)}(h``true``h]htrue}(hjY0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjU0ubh if a user space application has registered for this frame. For action frames, that makes it responsible for rejecting unrecognized action frames; }(hjU0hhhNhNubj)}(h ``false``h]hfalse}(hjk0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjU0ubh^ otherwise, in which case for action frames the driver is responsible for rejecting the frame.}(hjU0hhhNhNubeh}(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&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_$cfg80211_mgmt_tx_status (C function)c.cfg80211_mgmt_tx_statushNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(htvoid cfg80211_mgmt_tx_status (struct wireless_dev *wdev, u64 cookie, const u8 *buf, size_t len, bool ack, gfp_t gfp)h]jo)}(hsvoid cfg80211_mgmt_tx_status(struct wireless_dev *wdev, u64 cookie, const u8 *buf, size_t len, bool ack, gfp_t gfp)h](j`)}(hvoidh]hvoid}(hj0hhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hj0hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMt#ubj)}(h h]h }(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0hhhj0hMt#ubj)}(hcfg80211_mgmt_tx_statush]j)}(hcfg80211_mgmt_tx_statush]hcfg80211_mgmt_tx_status}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj0hhhj0hMt#ubj)}(hW(struct wireless_dev *wdev, u64 cookie, const u8 *buf, size_t len, bool ack, gfp_t gfp)h](j)}(hstruct wireless_dev *wdevh](ju)}(hjnh]hstruct}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj0ubj)}(h h]h }(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubh)}(hhh]j)}(h wireless_devh]h wireless_dev}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj1modnameN classnameNjS jV )}jY ]j)}jj0sbc.cfg80211_mgmt_tx_statusasbuh1hhj0ubj)}(h h]h }(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubj)}(hjh]h*}(hj-1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubj)}(hwdevh]hwdev}(hj:1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj0ubj)}(h u64 cookieh](h)}(hhh]j)}(hu64h]hu64}(hjV1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjS1ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjX1modnameN classnameNjS jV )}jY ]j1c.cfg80211_mgmt_tx_statusasbuh1hhjO1ubj)}(h h]h }(hjt1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjO1ubj)}(hcookieh]hcookie}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjO1ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj0ubj)}(h const u8 *bufh](ju)}(hjIh]hconst}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj1ubj)}(h h]h }(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1ubh)}(hhh]j)}(hu8h]hu8}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj1modnameN classnameNjS jV )}jY ]j1c.cfg80211_mgmt_tx_statusasbuh1hhj1ubj)}(h h]h }(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1ubj)}(hjh]h*}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1ubj)}(hbufh]hbuf}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj0ubj)}(h size_t lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj 2ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj2modnameN classnameNjS jV )}jY ]j1c.cfg80211_mgmt_tx_statusasbuh1hhj2ubj)}(h h]h }(hj,2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2ubj)}(hlenh]hlen}(hj:2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj0ubj)}(hbool ackh](j`)}(hjh]hbool}(hjS2hhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjO2ubj)}(h h]h }(hj`2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjO2ubj)}(hackh]hack}(hjn2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjO2ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj0ubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj2modnameN classnameNjS jV )}jY ]j1c.cfg80211_mgmt_tx_statusasbuh1hhj2ubj)}(h h]h }(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2ubj)}(hgfph]hgfp}(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj0ubeh}(h]h ]h"]h$]h&]jjuh1jhj0hhhj0hMt#ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj0hhhj0hMt#ubah}(h]j0ah ](jjeh"]h$]h&]jj)jhuh1jhhj0hMt#hj0hhubj)}(hhh]h)}(h.notification of TX status for management frameh]h.notification of TX status for management frame}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMt#hj2hhubah}(h]h ]h"]h$]h&]uh1jhj0hhhj0hMt#ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj2jj2jjjuh1jchhhjbhNhNubj)}(hX**Parameters** ``struct wireless_dev *wdev`` wireless device receiving the frame ``u64 cookie`` Cookie returned by cfg80211_ops::mgmt_tx() ``const u8 *buf`` Management frame (header + body) ``size_t len`` length of the frame data ``bool ack`` Whether frame was acknowledged ``gfp_t gfp`` context flags **Description** This function is called whenever a management frame was requested to be transmitted with cfg80211_ops::mgmt_tx() to report the TX status of the transmission attempt.h](h)}(h**Parameters**h]j)}(hj3h]h Parameters}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMx#hj2ubj)}(hhh](j)}(hB``struct wireless_dev *wdev`` wireless device receiving the frame h](j)}(h``struct wireless_dev *wdev``h]j)}(hj!3h]hstruct wireless_dev *wdev}(hj#3hhhNhNubah}(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.hhMu#hj3ubj6)}(hhh]h)}(h#wireless device receiving the frameh]h#wireless device receiving the frame}(hj:3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj63hMu#hj73ubah}(h]h ]h"]h$]h&]uh1j5hj3ubeh}(h]h ]h"]h$]h&]uh1jhj63hMu#hj3ubj)}(h:``u64 cookie`` Cookie returned by cfg80211_ops::mgmt_tx() h](j)}(h``u64 cookie``h]j)}(hjZ3h]h u64 cookie}(hj\3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjX3ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMv#hjT3ubj6)}(hhh]h)}(h*Cookie returned by cfg80211_ops::mgmt_tx()h]h*Cookie returned by cfg80211_ops::mgmt_tx()}(hjs3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjo3hMv#hjp3ubah}(h]h ]h"]h$]h&]uh1j5hjT3ubeh}(h]h ]h"]h$]h&]uh1jhjo3hMv#hj3ubj)}(h3``const u8 *buf`` Management frame (header + body) h](j)}(h``const u8 *buf``h]j)}(hj3h]h const u8 *buf}(hj3hhhNhNubah}(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#hj3ubj6)}(hhh]h)}(h Management frame (header + body)h]h Management frame (header + body)}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMw#hj3ubah}(h]h ]h"]h$]h&]uh1j5hj3ubeh}(h]h ]h"]h$]h&]uh1jhj3hMw#hj3ubj)}(h(``size_t len`` length of the frame data h](j)}(h``size_t len``h]j)}(hj3h]h size_t len}(hj3hhhNhNubah}(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.hhMx#hj3ubj6)}(hhh]h)}(hlength of the frame datah]hlength of the frame data}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMx#hj3ubah}(h]h ]h"]h$]h&]uh1j5hj3ubeh}(h]h ]h"]h$]h&]uh1jhj3hMx#hj3ubj)}(h,``bool ack`` Whether frame was acknowledged h](j)}(h ``bool ack``h]j)}(hj4h]hbool ack}(hj4hhhNhNubah}(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.hhMy#hj3ubj6)}(hhh]h)}(hWhether frame was acknowledgedh]hWhether frame was acknowledged}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4hMy#hj4ubah}(h]h ]h"]h$]h&]uh1j5hj3ubeh}(h]h ]h"]h$]h&]uh1jhj4hMy#hj3ubj)}(h``gfp_t gfp`` context flags h](j)}(h ``gfp_t gfp``h]j)}(hj>4h]h gfp_t gfp}(hj@4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<4ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMz#hj84ubj6)}(hhh]h)}(h context flagsh]h context flags}(hjW4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjS4hMz#hjT4ubah}(h]h ]h"]h$]h&]uh1j5hj84ubeh}(h]h ]h"]h$]h&]uh1jhjS4hMz#hj3ubeh}(h]h ]h"]h$]h&]uh1jhj2ubh)}(h**Description**h]j)}(hjy4h]h Description}(hj{4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjw4ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM|#hj2ubh)}(hThis function is called whenever a management frame was requested to be transmitted with cfg80211_ops::mgmt_tx() to report the TX status of the transmission attempt.h]hThis function is called whenever a management frame was requested to be transmitted with cfg80211_ops::mgmt_tx() to report the TX status of the transmission attempt.}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM{#hj2ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_%cfg80211_cqm_rssi_notify (C function)c.cfg80211_cqm_rssi_notifyhNtauh1jRhjbhhhNhNubjd)}(hhh](ji)}(hvoid cfg80211_cqm_rssi_notify (struct net_device *dev, enum nl80211_cqm_rssi_threshold_event rssi_event, s32 rssi_level, gfp_t gfp)h]jo)}(hvoid cfg80211_cqm_rssi_notify(struct net_device *dev, enum nl80211_cqm_rssi_threshold_event rssi_event, s32 rssi_level, gfp_t gfp)h](j`)}(hvoidh]hvoid}(hj4hhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hj4hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#ubj)}(h h]h }(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4hhhj4hM#ubj)}(hcfg80211_cqm_rssi_notifyh]j)}(hcfg80211_cqm_rssi_notifyh]hcfg80211_cqm_rssi_notify}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj4hhhj4hM#ubj)}(he(struct net_device *dev, enum nl80211_cqm_rssi_threshold_event rssi_event, s32 rssi_level, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjnh]hstruct}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj4ubj)}(h h]h }(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubh)}(hhh]j)}(h net_deviceh]h net_device}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj5modnameN classnameNjS jV )}jY ]j)}jj4sbc.cfg80211_cqm_rssi_notifyasbuh1hhj4ubj)}(h h]h }(hj95hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubj)}(hjh]h*}(hjG5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubj)}(hdevh]hdev}(hjT5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj4ubj)}(h0enum nl80211_cqm_rssi_threshold_event rssi_eventh](ju)}(hjxh]henum}(hjm5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthji5ubj)}(h h]h }(hjz5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhji5ubh)}(hhh]j)}(h nl80211_cqm_rssi_threshold_eventh]h nl80211_cqm_rssi_threshold_event}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj5modnameN classnameNjS jV )}jY ]j55c.cfg80211_cqm_rssi_notifyasbuh1hhji5ubj)}(h h]h }(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhji5ubj)}(h rssi_eventh]h rssi_event}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhji5ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj4ubj)}(hs32 rssi_levelh](h)}(hhh]j)}(hs32h]hs32}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj5modnameN classnameNjS jV )}jY ]j55c.cfg80211_cqm_rssi_notifyasbuh1hhj5ubj)}(h h]h }(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5ubj)}(h rssi_levelh]h rssi_level}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj4ubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj6modnameN classnameNjS jV )}jY ]j55c.cfg80211_cqm_rssi_notifyasbuh1hhj6ubj)}(h h]h }(hj96hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6ubj)}(hgfph]hgfp}(hjG6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj4ubeh}(h]h ]h"]h$]h&]jjuh1jhj4hhhj4hM#ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj4hhhj4hM#ubah}(h]j4ah ](jjeh"]h$]h&]jj)jhuh1jhhj4hM#hj4hhubj)}(hhh]h)}(h(connection quality monitoring rssi eventh]h(connection quality monitoring rssi event}(hjq6hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hjn6hhubah}(h]h ]h"]h$]h&]uh1jhj4hhhj4hM#ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj6jj6jjjuh1jchhhjbhNhNubj)}(hXk**Parameters** ``struct net_device *dev`` network device ``enum nl80211_cqm_rssi_threshold_event rssi_event`` the triggered RSSI event ``s32 rssi_level`` new RSSI level value or 0 if not available ``gfp_t gfp`` context flags **Description** This function is called when a configured connection quality monitoring rssi threshold reached event occurs.h](h)}(h**Parameters**h]j)}(hj6h]h Parameters}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hj6ubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hj6h]hstruct net_device *dev}(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)}(hnetwork deviceh]hnetwork device}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hM#hj6ubah}(h]h ]h"]h$]h&]uh1j5hj6ubeh}(h]h ]h"]h$]h&]uh1jhj6hM#hj6ubj)}(hN``enum nl80211_cqm_rssi_threshold_event rssi_event`` the triggered RSSI event h](j)}(h4``enum nl80211_cqm_rssi_threshold_event rssi_event``h]j)}(hj6h]h0enum nl80211_cqm_rssi_threshold_event rssi_event}(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)}(hthe triggered RSSI eventh]hthe triggered RSSI event}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7hM#hj7ubah}(h]h ]h"]h$]h&]uh1j5hj6ubeh}(h]h ]h"]h$]h&]uh1jhj7hM#hj6ubj)}(h>``s32 rssi_level`` new RSSI level value or 0 if not available h](j)}(h``s32 rssi_level``h]j)}(hj$7h]hs32 rssi_level}(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:48: ./include/net/cfg80211.hhM#hj7ubj6)}(hhh]h)}(h*new RSSI level value or 0 if not availableh]h*new RSSI level value or 0 if not available}(hj=7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj97hM#hj:7ubah}(h]h ]h"]h$]h&]uh1j5hj7ubeh}(h]h ]h"]h$]h&]uh1jhj97hM#hj6ubj)}(h``gfp_t gfp`` context flags h](j)}(h ``gfp_t gfp``h]j)}(hj]7h]h gfp_t gfp}(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:48: ./include/net/cfg80211.hhM#hjW7ubj6)}(hhh]h)}(h context flagsh]h context flags}(hjv7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjr7hM#hjs7ubah}(h]h ]h"]h$]h&]uh1j5hjW7ubeh}(h]h ]h"]h$]h&]uh1jhjr7hM#hj6ubeh}(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.}(hj7hhhNhNubah}(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&]uh1jhjbhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_(cfg80211_cqm_pktloss_notify (C function)c.cfg80211_cqm_pktloss_notifyhNtauh1jRhjbhhhNhNubjd)}(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}(hj7hhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hj7hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#ubj)}(h h]h }(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7hhhj7hM#ubj)}(hcfg80211_cqm_pktloss_notifyh]j)}(hcfg80211_cqm_pktloss_notifyh]hcfg80211_cqm_pktloss_notify}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj7hhhj7hM#ubj)}(hD(struct net_device *dev, const u8 *peer, u32 num_packets, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjnh]hstruct}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj8ubj)}(h h]h }(hj'8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubh)}(hhh]j)}(h net_deviceh]h net_device}(hj88hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj58ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj:8modnameN classnameNjS jV )}jY ]j)}jj8sbc.cfg80211_cqm_pktloss_notifyasbuh1hhj8ubj)}(h h]h }(hjX8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubj)}(hjh]h*}(hjf8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubj)}(hdevh]hdev}(hjs8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj8ubj)}(hconst u8 *peerh](ju)}(hjIh]hconst}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj8ubj)}(h h]h }(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubh)}(hhh]j)}(hu8h]hu8}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj8modnameN classnameNjS jV )}jY ]jT8c.cfg80211_cqm_pktloss_notifyasbuh1hhj8ubj)}(h h]h }(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubj)}(hjh]h*}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubj)}(hpeerh]hpeer}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj8ubj)}(hu32 num_packetsh](h)}(hhh]j)}(hu32h]hu32}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj9modnameN classnameNjS jV )}jY ]jT8c.cfg80211_cqm_pktloss_notifyasbuh1hhj8ubj)}(h h]h }(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubj)}(h num_packetsh]h num_packets}(hj+9hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj8ubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjG9hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjD9ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjI9modnameN classnameNjS jV )}jY ]jT8c.cfg80211_cqm_pktloss_notifyasbuh1hhj@9ubj)}(h h]h }(hje9hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@9ubj)}(hgfph]hgfp}(hjs9hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@9ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj8ubeh}(h]h ]h"]h$]h&]jjuh1jhj7hhhj7hM#ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj7hhhj7hM#ubah}(h]j7ah ](jjeh"]h$]h&]jj)jhuh1jhhj7hM#hj7hhubj)}(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&]uh1jhj7hhhj7hM#ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj9jj9jjjuh1jchhhjbhNhNubj)}(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)}(hj9h]h Parameters}(hj9hhhNhNubah}(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.hhM#hj9ubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hj9h]hstruct net_device *dev}(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)}(hnetwork deviceh]hnetwork device}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hM#hj9ubah}(h]h ]h"]h$]h&]uh1j5hj9ubeh}(h]h ]h"]h$]h&]uh1jhj9hM#hj9ubj)}(h&``const u8 *peer`` peer's MAC address h](j)}(h``const u8 *peer``h]j)}(hj:h]hconst u8 *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:48: ./include/net/cfg80211.hhM#hj:ubj6)}(hhh]h)}(hpeer's MAC addressh]hpeer’s MAC address}(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#hj9ubj)}(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)}(hjP:h]hu32 num_packets}(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)}(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)}(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#hj9ubj)}(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#hj9ubeh}(h]h ]h"]h$]h&]uh1jhj9ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjbhhhNhNubeh}(h]actions-and-configurationah ]h"]actions and configurationah$]h&]uh1hhhhhhhhK+ubh)}(hhh](h)}(hScanning and BSS list handlingh]hScanning and BSS list handling}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj: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.}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:99: ./include/net/cfg80211.hhM hj: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.}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:99: ./include/net/cfg80211.hhM hj: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 hj:hhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_ssid (C struct)c.cfg80211_ssidhNtauh1jRhj:hhhNhNubjd)}(hhh](ji)}(h cfg80211_ssidh]jo)}(hstruct cfg80211_ssidh](ju)}(hjnh]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 }(hj8;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&;hhhj7;hKubj)}(h cfg80211_ssidh]j)}(hj$;h]h cfg80211_ssid}(hjJ;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjF;ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj&;hhhj7;hKubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj";hhhj7;hKubah}(h]j;ah ](jjeh"]h$]h&]jj)jhuh1jhhj7;hKhj;hhubj)}(hhh]h)}(hSSID descriptionh]hSSID description}(hjl;hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hji;hhubah}(h]h ]h"]h$]h&]uh1jhj;hhhj7;hKubeh}(h]h ](j$structeh"]h$]h&]jj$jj;jj;jjjuh1jchhhj: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&]jjuh1jha/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&]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 SSIDh]hthe SSID}(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``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 hj;ubeh}(h]h ]h"]h$]h&]uh1jhj;ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj:hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ cfg80211_scan_request (C struct)c.cfg80211_scan_requesthNtauh1jRhj:hhhNhNubjd)}(hhh](ji)}(hcfg80211_scan_requesth]jo)}(hstruct cfg80211_scan_requesth](ju)}(hjnh]hstruct}(hjl<hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjh<hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjz<hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjh<hhhjy<hM ubj)}(hcfg80211_scan_requesth]j)}(hjf<h]hcfg80211_scan_request}(hj<hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj<ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjh<hhhjy<hM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjd<hhhjy<hM ubah}(h]j_<ah ](jjeh"]h$]h&]jj)jhuh1jhhjy<hM hja<hhubj)}(hhh]h)}(hscan request descriptionh]hscan request 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&]uh1jhja<hhhjy<hM ubeh}(h]h ](j$structeh"]h$]h&]jj$jj<jj<jjjuh1jchhhj: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}(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)}(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[]; };}hj<sbah}(h]h ]h"]h$]h&]jjuh1jha/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/``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)}(hj4=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0=hM hj1=ubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhj0=hM hj=ubj)}(h``n_ssids`` number of SSIDs h](j)}(h ``n_ssids``h]j)}(hjT=h]hn_ssids}(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.hhM hjN=ubj6)}(hhh]h)}(hnumber of SSIDsh]hnumber of SSIDs}(hjm=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhji=hM hjj=ubah}(h]h ]h"]h$]h&]uh1j5hjN=ubeh}(h]h ]h"]h$]h&]uh1jhji=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)}(hj=h]hie}(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)}(hEoptional information element(s) to add into Probe Request or ``NULL``h](h=optional information element(s) to add into Probe Request 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&]uh1j5hj=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)}(hjF>h]hduration}(hjH>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjD>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}(hjg>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}(hj>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}(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)}(hIcontrol flags from :c:type:`enum nl80211_scan_flags `h](hcontrol flags from }(hj>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 refexplicitrefwarnjS jW j6nl80211_scan_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 hj=ubj)}(h5``rates`` bitmap of rates to advertise for each band h](j)}(h ``rates``h]j)}(hj6?h]hrates}(hj8?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4?ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj0?ubj6)}(hhh]h)}(h*bitmap of rates to advertise for each bandh]h*bitmap of rates to advertise for each band}(hjO?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjK?hM hjL?ubah}(h]h ]h"]h$]h&]uh1j5hj0?ubeh}(h]h ]h"]h$]h&]uh1jhjK?hM hj=ubj)}(h)``wdev`` the wireless device to scan for h](j)}(h``wdev``h]j)}(hjo?h]hwdev}(hjq?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjm?ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hji?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&]uh1j5hji?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}(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``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)}(hj?h]h mac_addr_mask}(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)}(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 hj?ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhj?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)}(hjB@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)}(hjb@h]hwiphy}(hjd@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&]uh1hhjw@hM hjx@ubah}(h]h ]h"]h$]h&]uh1j5hj\@ubeh}(h]h ]h"]h$]h&]uh1jhjw@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}(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``no_cck`` used to send probe requests at non CCK rate in 2GHz band h](j)}(h ``no_cck``h]j)}(hj@h]hno_cck}(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)}(h8used to send probe requests at non CCK rate in 2GHz bandh]h8used to send probe requests at non CCK rate in 2GHz 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)}(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 Ah]h scan_6ghz}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Aubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjAubj6)}(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&AhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj#Aubah}(h]h ]h"]h$]h&]uh1j5hjAubeh}(h]h ]h"]h$]h&]uh1jhj"AhM 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)}(hjGAh]h first_part}(hjIAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEAubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjAAubj6)}(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}(hjdAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`AubhX if this is the first part of a split scan request or a scan that was not split. May be }(hj`AhhhNhNubj)}(h``true``h]htrue}(hjvAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`Aubh for a }(hj`AhhhNhNubj)}(h **scan_6ghz**h]h scan_6ghz}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`Aubh) scan if no other channels were requested}(hj`AhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj]Aubah}(h]h ]h"]h$]h&]uh1j5hjAAubeh}(h]h ]h"]h$]h&]uh1jhj\AhM hj=ubj)}(h)``n_6ghz_params`` number of 6 GHz params h](j)}(h``n_6ghz_params``h]j)}(hjAh]h n_6ghz_params}(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)}(hnumber of 6 GHz paramsh]hnumber of 6 GHz params}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjAhM hjAubah}(h]h ]h"]h$]h&]uh1j5hjAubeh}(h]h ]h"]h$]h&]uh1jhjAhM hj=ubj)}(h"``scan_6ghz_params`` 6 GHz params h](j)}(h``scan_6ghz_params``h]j)}(hjAh]hscan_6ghz_params}(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 6 GHz paramsh]h 6 GHz params}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBhM hjBubah}(h]h ]h"]h$]h&]uh1j5hjAubeh}(h]h ]h"]h$]h&]uh1jhjBhM 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)}(hj%Bh]htsf_report_link_id}(hj'BhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#Bubah}(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|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.}(hj>BhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj;Bubah}(h]h ]h"]h$]h&]uh1j5hjBubeh}(h]h ]h"]h$]h&]uh1jhj:BhM hj=ubj)}(h!``channels`` channels to scan on.h](j)}(h ``channels``h]j)}(hj_Bh]hchannels}(hjaBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]Bubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjYBubj6)}(hhh]h)}(hchannels to scan on.h]hchannels to scan on.}(hjxBhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjuBubah}(h]h ]h"]h$]h&]uh1j5hjYBubeh}(h]h ]h"]h$]h&]uh1jhjtBhM hj=ubeh}(h]h ]h"]h$]h&]uh1jhj<ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj:hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_inform_bss (C struct)c.cfg80211_inform_bsshNtauh1jRhj:hhhNhNubjd)}(hhh](ji)}(hcfg80211_inform_bssh]jo)}(hstruct cfg80211_inform_bssh](ju)}(hjnh]hstruct}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjBhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBhhhjBhM ubj)}(hcfg80211_inform_bssh]j)}(hjBh]hcfg80211_inform_bss}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubah}(h]h ](jjeh"]h$]h&]jjuh1jhjBhhhjBhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjBhhhjBhM ubah}(h]jBah ](jjeh"]h$]h&]jj)jhuh1jhhjBhM hjBhhubj)}(hhh]h)}(hBSS inform datah]hBSS inform data}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjBhhubah}(h]h ]h"]h$]h&]uh1jhjBhhhjBhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjCjjCjjjuh1jchhhj: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}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjCubh:}(hjChhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjCubj)}(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; };}hj8Csbah}(h]h ]h"]h$]h&]jjuh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjCubh)}(h **Members**h]j)}(hjICh]hMembers}(hjKChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjGCubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjCubj)}(hhh](j)}(h+``chan`` channel the frame was received on h](j)}(h``chan``h]j)}(hjhCh]hchan}(hjjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfCubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjbCubj6)}(hhh]h)}(h!channel the frame was received onh]h!channel the frame was received on}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhj}ChM hj~Cubah}(h]h ]h"]h$]h&]uh1j5hjbCubeh}(h]h ]h"]h$]h&]uh1jhj}ChM hj_Cubj)}(hG``signal`` signal strength value, according to the wiphy's signal type h](j)}(h ``signal``h]j)}(hjCh]hsignal}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(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}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjCubah}(h]h ]h"]h$]h&]uh1j5hjCubeh}(h]h ]h"]h$]h&]uh1jhjChM hj_Cubj)}(hXa``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. h](j)}(h``boottime_ns``h]j)}(hjCh]h boottime_ns}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjCubj6)}(hhh]h)}(hXPtimestamp (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.h]hXRtimestamp (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.}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjCubah}(h]h ]h"]h$]h&]uh1j5hjCubeh}(h]h ]h"]h$]h&]uh1jhjChM hj_Cubj)}(h``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``. h](j)}(h``parent_tsf``h]j)}(hjDh]h parent_tsf}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjDubj6)}(hhh]h)}(hthe 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``.h](hthe 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 }(hj.DhhhNhNubj)}(h``parent_bssid``h]h parent_bssid}(hj6DhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.Dubh.}(hj.DhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj+Dubah}(h]h ]h"]h$]h&]uh1j5hjDubeh}(h]h ]h"]h$]h&]uh1jhj*DhM hj_Cubj)}(h``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. h](j)}(h``parent_bssid``h]j)}(hjaDh]h parent_bssid}(hjcDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_Dubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj[Dubj6)}(hhh]h)}(hthe 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.h](hthe BSS according to which }(hjzDhhhNhNubj)}(h``parent_tsf``h]h parent_tsf}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzDubh_ is set. This is set to the BSS that requested the scan in which the beacon/probe was received.}(hjzDhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjwDubah}(h]h ]h"]h$]h&]uh1j5hj[Dubeh}(h]h ]h"]h$]h&]uh1jhjvDhM hj_Cubj)}(h:``chains`` bitmask for filled values in **chain_signal**. h](j)}(h ``chains``h]j)}(hjDh]hchains}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjDubj6)}(hhh]h)}(h.bitmask for filled values in **chain_signal**.h](hbitmask for filled values in }(hjDhhhNhNubj)}(h**chain_signal**h]h chain_signal}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDubh.}(hjDhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjDhM hjDubah}(h]h ]h"]h$]h&]uh1j5hjDubeh}(h]h ]h"]h$]h&]uh1jhjDhM hj_Cubj)}(hH``chain_signal`` per-chain signal strength of last received BSS in dBm. h](j)}(h``chain_signal``h]j)}(hjDh]h chain_signal}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjDubj6)}(hhh]h)}(h6per-chain signal strength of last received BSS in dBm.h]h6per-chain signal strength of last received BSS in dBm.}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj EhM hjEubah}(h]h ]h"]h$]h&]uh1j5hjDubeh}(h]h ]h"]h$]h&]uh1jhj EhM hj_Cubj)}(hc``restrict_use`` restrict usage, if not set, assume **use_for** is ``NL80211_BSS_USE_FOR_NORMAL``. h](j)}(h``restrict_use``h]j)}(hj1Eh]h restrict_use}(hj3EhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/Eubah}(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)}(hQrestrict usage, if not set, assume **use_for** is ``NL80211_BSS_USE_FOR_NORMAL``.h](h#restrict usage, if not set, assume }(hjJEhhhNhNubj)}(h **use_for**h]huse_for}(hjREhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJEubh is }(hjJEhhhNhNubj)}(h``NL80211_BSS_USE_FOR_NORMAL``h]hNL80211_BSS_USE_FOR_NORMAL}(hjdEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJEubh.}(hjJEhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjGEubah}(h]h ]h"]h$]h&]uh1j5hj+Eubeh}(h]h ]h"]h$]h&]uh1jhjFEhM hj_Cubj)}(hp``use_for`` bitmap of possible usage for this BSS, see :c:type:`enum nl80211_bss_use_for ` 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 hjEubj6)}(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 }(hjEhhhNhNubh)}(h8:c:type:`enum nl80211_bss_use_for `h]j)}(hjEh]henum nl80211_bss_use_for}(hjEhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6nl80211_bss_use_foruh1hha/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&]uh1j5hjEubeh}(h]h ]h"]h$]h&]uh1jhjEhM hj_Cubj)}(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)}(hjEh]hcannot_use_reasons}(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)}(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 }(hjFhhhNhNubj)}(h**restrict_use**h]h restrict_use}(hj FhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFubh is set and }(hjFhhhNhNubj)}(h **use_for**h]huse_for}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFubh8 is zero (empty); may be 0 for unspecified reasons; see }(hjFhhhNhNubh)}(hN:c:type:`enum nl80211_bss_cannot_use_reasons `h]j)}(hj/Fh]h#enum nl80211_bss_cannot_use_reasons}(hj1FhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj-Fubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6nl80211_bss_cannot_use_reasonsuh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjFubeh}(h]h ]h"]h$]h&]uh1hhjLFhM hjEubah}(h]h ]h"]h$]h&]uh1j5hjEubeh}(h]h ]h"]h$]h&]uh1jhjEhM hj_Cubj)}(h8``drv_data`` Data to be passed through to **inform_bss**h](j)}(h ``drv_data``h]j)}(hjeFh]hdrv_data}(hjgFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcFubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj_Fubj6)}(hhh]h)}(h+Data to be passed through to **inform_bss**h](hData to be passed through to }(hj~FhhhNhNubj)}(h**inform_bss**h]h inform_bss}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~Fubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj{Fubah}(h]h ]h"]h$]h&]uh1j5hj_Fubeh}(h]h ]h"]h$]h&]uh1jhjzFhM hj_Cubeh}(h]h ]h"]h$]h&]uh1jhjCubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj:hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_bss (C struct)c.cfg80211_bsshNtauh1jRhj:hhhNhNubjd)}(hhh](ji)}(h cfg80211_bssh]jo)}(hstruct cfg80211_bssh](ju)}(hjnh]hstruct}(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjFhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjFhhhjFhM ubj)}(h cfg80211_bssh]j)}(hjFh]h cfg80211_bss}(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjFubah}(h]h ](jjeh"]h$]h&]jjuh1jhjFhhhjFhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjFhhhjFhM ubah}(h]jFah ](jjeh"]h$]h&]jj)jhuh1jhhjFhM hjFhhubj)}(hhh]h)}(hBSS descriptionh]hBSS description}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj Ghhubah}(h]h ]h"]h$]h&]uh1jhjFhhhjFhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jj'Gjj'Gjjjuh1jchhhj:hNhNubj)}(hX **Definition**:: struct cfg80211_bss { struct ieee80211_channel *channel; const struct cfg80211_bss_ies *ies; const struct cfg80211_bss_ies *beacon_ies; const struct cfg80211_bss_ies *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}(hj3GhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/Gubh:}(hj/GhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj+Gubj)}(hXsstruct cfg80211_bss { struct ieee80211_channel *channel; const struct cfg80211_bss_ies *ies; const struct cfg80211_bss_ies *beacon_ies; const struct cfg80211_bss_ies *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]hXsstruct cfg80211_bss { struct ieee80211_channel *channel; const struct cfg80211_bss_ies *ies; const struct cfg80211_bss_ies *beacon_ies; const struct cfg80211_bss_ies *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[] ; };}hjLGsbah}(h]h ]h"]h$]h&]jjuh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj+Gubh)}(h **Members**h]j)}(hj]Gh]hMembers}(hj_GhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[Gubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj+Gubj)}(hhh](j)}(h#``channel`` channel this BSS is on h](j)}(h ``channel``h]j)}(hj|Gh]hchannel}(hj~GhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzGubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjvGubj6)}(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&]uh1j5hjvGubeh}(h]h ]h"]h$]h&]uh1jhjGhM hjsGubj)}(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)}(hjGh]hies}(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)}(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-}(hjGhhhNhNubj)}(h``NULL``h]hNULL}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubh.}(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&]uh1j5hjGubeh}(h]h ]h"]h$]h&]uh1jhjGhM hjsGubj)}(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)}(hjHh]h beacon_ies}(hjHhhhNhNubah}(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)}(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 }(hjHhhhNhNubj)}(h**hidden_beacon_bss**h]hhidden_beacon_bss}(hj"HhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHubhc is set this struct doesn’t own the beacon_ies, but they’re just pointers to the ones from the }(hjHhhhNhNubj)}(h**hidden_beacon_bss**h]hhidden_beacon_bss}(hj4HhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHubh struct)}(hjHhhhNhNubeh}(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&]uh1j5hjGubeh}(h]h ]h"]h$]h&]uh1jhjHhM hjsGubj)}(hN``proberesp_ies`` the information elements from the last Probe Response frame h](j)}(h``proberesp_ies``h]j)}(hj_Hh]h proberesp_ies}(hjaHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]Hubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjYHubj6)}(hhh]h)}(h;the information elements from the last Probe Response frameh]h;the information elements from the last Probe Response frame}(hjxHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjtHhM hjuHubah}(h]h ]h"]h$]h&]uh1j5hjYHubeh}(h]h ]h"]h$]h&]uh1jhjtHhM hjsGubj)}(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. }(hjHhhhNhNubj)}(h**beacon_ies**h]h beacon_ies}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHubhf is still valid, of course, and points to the same data as hidden_beacon_bss->beacon_ies in that case.}(hjHhhhNhNubeh}(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 hjsGubj)}(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)}(hjHh]htransmitted_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)}(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 hjHubah}(h]h ]h"]h$]h&]uh1j5hjHubeh}(h]h ]h"]h$]h&]uh1jhjHhM hjsGubj)}(hb``nontrans_list`` list of non-transmitted BSS, if this is a transmitted one (multi-BSSID support) h](j)}(h``nontrans_list``h]j)}(hjIh]h nontrans_list}(hj IhhhNhNubah}(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)}(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)}(hj7IhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj4Iubah}(h]h ]h"]h$]h&]uh1j5hjIubeh}(h]h ]h"]h$]h&]uh1jhj3IhM hjsGubj)}(hK``signal`` signal strength value (type depends on the wiphy's signal_type) h](j)}(h ``signal``h]j)}(hjXIh]hsignal}(hjZIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVIubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjRIubj6)}(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)}(hjqIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmIhM hjnIubah}(h]h ]h"]h$]h&]uh1j5hjRIubeh}(h]h ]h"]h$]h&]uh1jhjmIhM hjsGubj)}(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 hjIubj6)}(hhh]h)}(h:timestamp of the last BSS update in nanoseconds since booth]h:timestamp of the last BSS update in nanoseconds since boot}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIhM hjIubah}(h]h ]h"]h$]h&]uh1j5hjIubeh}(h]h ]h"]h$]h&]uh1jhjIhM hjsGubj)}(h:``beacon_interval`` the beacon interval as from the frame h](j)}(h``beacon_interval``h]j)}(hjIh]hbeacon_interval}(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 beacon interval as from the frameh]h%the beacon interval as from the frame}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIhM hjIubah}(h]h ]h"]h$]h&]uh1j5hjIubeh}(h]h ]h"]h$]h&]uh1jhjIhM hjsGubj)}(h7``capability`` the capability field in host byte order h](j)}(h``capability``h]j)}(hjJh]h capability}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(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}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJhM hjJubah}(h]h ]h"]h$]h&]uh1j5hjIubeh}(h]h ]h"]h$]h&]uh1jhjJhM hjsGubj)}(h``bssid`` BSSID of the BSS h](j)}(h ``bssid``h]j)}(hjJhhhNhNubah}(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 hj6Jubj6)}(hhh]h)}(hBSSID of the BSSh]hBSSID of the BSS}(hjUJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQJhM hjRJubah}(h]h ]h"]h$]h&]uh1j5hj6Jubeh}(h]h ]h"]h$]h&]uh1jhjQJhM hjsGubj)}(h:``chains`` bitmask for filled values in **chain_signal**. h](j)}(h ``chains``h]j)}(hjuJh]hchains}(hjwJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsJubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjoJubj6)}(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&]uh1hhjJhM hjJubah}(h]h ]h"]h$]h&]uh1j5hjoJubeh}(h]h ]h"]h$]h&]uh1jhjJhM hjsGubj)}(hH``chain_signal`` per-chain signal strength of last received BSS in dBm. h](j)}(h``chain_signal``h]j)}(hjJh]h chain_signal}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjJubj6)}(hhh]h)}(h6per-chain signal strength of last received BSS in dBm.h]h6per-chain signal strength of last received BSS in dBm.}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJhM hjJubah}(h]h ]h"]h$]h&]uh1j5hjJubeh}(h]h ]h"]h$]h&]uh1jhjJhM hjsGubj)}(hp``proberesp_ecsa_stuck`` ECSA element is stuck in the Probe Response frame, cannot rely on it having valid data h](j)}(h``proberesp_ecsa_stuck``h]j)}(hjJh]hproberesp_ecsa_stuck}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjJubj6)}(hhh]h)}(hVECSA element is stuck in the Probe Response frame, cannot rely on it having valid datah]hVECSA element is stuck in the Probe Response frame, cannot rely on it having valid data}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjKubah}(h]h ]h"]h$]h&]uh1j5hjJubeh}(h]h ]h"]h$]h&]uh1jhjKhM hjsGubj)}(h.``bssid_index`` index in the multiple BSS set h](j)}(h``bssid_index``h]j)}(hj3Kh]h bssid_index}(hj5KhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1Kubah}(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)}(hindex in the multiple BSS seth]hindex in the multiple BSS set}(hjLKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHKhM! hjIKubah}(h]h ]h"]h$]h&]uh1j5hj-Kubeh}(h]h ]h"]h$]h&]uh1jhjHKhM! hjsGubj)}(h=``max_bssid_indicator`` max number of members in the BSS set h](j)}(h``max_bssid_indicator``h]j)}(hjlKh]hmax_bssid_indicator}(hjnKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjKubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM" hjfKubj6)}(hhh]h)}(h$max number of members in the BSS seth]h$max number of members in the BSS set}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKhM" hjKubah}(h]h ]h"]h$]h&]uh1j5hjfKubeh}(h]h ]h"]h$]h&]uh1jhjKhM" hjsGubj)}(hp``use_for`` bitmap of possible usage for this BSS, see :c:type:`enum nl80211_bss_use_for ` h](j)}(h ``use_for``h]j)}(hjKh]huse_for}(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)}(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 }(hjKhhhNhNubh)}(h8:c:type:`enum nl80211_bss_use_for `h]j)}(hjKh]henum nl80211_bss_use_for}(hjKhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6nl80211_bss_use_foruh1hha/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&]uh1j5hjKubeh}(h]h ]h"]h$]h&]uh1jhjKhM$ hjsGubj)}(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)}(hjKh]hcannot_use_reasons}(hjLhhhNhNubah}(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)}(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 }(hjLhhhNhNubj)}(h**restrict_use**h]h restrict_use}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLubh is set and }(hjLhhhNhNubj)}(h **use_for**h]huse_for}(hj1LhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLubh8 is zero (empty); may be 0 for unspecified reasons; see }(hjLhhhNhNubh)}(hN:c:type:`enum nl80211_bss_cannot_use_reasons `h]j)}(hjELh]h#enum nl80211_bss_cannot_use_reasons}(hjGLhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjCLubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnjS jW j6nl80211_bss_cannot_use_reasonsuh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM% hjLubeh}(h]h ]h"]h$]h&]uh1hhjbLhM% hjLubah}(h]h ]h"]h$]h&]uh1j5hjKubeh}(h]h ]h"]h$]h&]uh1jhjLhM' hjsGubj)}(hM``priv`` private area for driver use, has at least wiphy->bss_priv_size bytesh](j)}(h``priv``h]j)}(hj{Lh]hpriv}(hj}LhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyLubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM' hjuLubj6)}(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&]uh1j5hjuLubeh}(h]h ]h"]h$]h&]uh1jhjLhM' hjsGubeh}(h]h ]h"]h$]h&]uh1jhj+Gubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj:hhhNhNubh)}(h**Description**h]j)}(hjLh]h Description}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM+ hj: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.}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj:hhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_!ieee80211_bss_get_ie (C function)c.ieee80211_bss_get_iehNtauh1jRhj: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)}(hjIh]hconst}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjLhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMV ubj)}(h h]h }(hj MhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLhhhj MhMV ubh)}(hhh]j)}(hu8h]hu8}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjMmodnameN classnameNjS jV )}jY ]j)}jieee80211_bss_get_iesbc.ieee80211_bss_get_ieasbuh1hhjLhhhj MhMV ubj)}(h h]h }(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvubj)}(hjh]h*}(hjLwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvubj)}(hcheck_dah]hcheck_da}(hjYwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjtubj)}(hconst u8 *check_sah](ju)}(hjIh]hconst}(hjrwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjnwubj)}(h h]h }(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjnwubh)}(hhh]j)}(hu8h]hu8}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjwmodnameN classnameNjS jV )}jY ]juc.ieee80211_amsdu_to_8023sasbuh1hhjnwubj)}(h h]h }(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjnwubj)}(hjh]h*}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjnwubj)}(hcheck_sah]hcheck_sa}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjnwubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjtubj)}(hu8 mesh_controlh](h)}(hhh]j)}(hu8h]hu8}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjwmodnameN classnameNjS jV )}jY ]juc.ieee80211_amsdu_to_8023sasbuh1hhjwubj)}(h h]h }(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubj)}(h mesh_controlh]h mesh_control}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjtubeh}(h]h ]h"]h$]h&]jjuh1jhjthhhjthMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjthhhjthMubah}(h]jtah ](jjeh"]h$]h&]jj)jhuh1jhhjthMhjthhubj)}(hhh]h)}(h#decode an IEEE 802.11n A-MSDU frameh]h#decode an IEEE 802.11n A-MSDU frame}(hj;xhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhj8xhhubah}(h]h ]h"]h$]h&]uh1jhjthhhjthMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjSxjjSxjjjuh1jchhhjqhNhNubj)}(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)}(hj]xh]h Parameters}(hj_xhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[xubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM hjWxubj)}(hhh](j)}(hD``struct sk_buff *skb`` The input A-MSDU frame without any headers. h](j)}(h``struct sk_buff *skb``h]j)}(hj|xh]hstruct sk_buff *skb}(hj~xhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzxubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM"hjvxubj6)}(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&]uh1hhjxhM"hjxubah}(h]h ]h"]h$]h&]uh1j5hjvxubeh}(h]h ]h"]h$]h&]uh1jhjxhM"hjsxubj)}(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)}(hjxh]hstruct sk_buff_head *list}(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)}(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.}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM#hjxubah}(h]h ]h"]h$]h&]uh1j5hjxubeh}(h]h ]h"]h$]h&]uh1jhjxhM$hjsxubj)}(h+``const u8 *addr`` The device MAC address. h](j)}(h``const u8 *addr``h]j)}(hjxh]hconst u8 *addr}(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 MAC address.h]hThe device MAC address.}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyhM%hjyubah}(h]h ]h"]h$]h&]uh1j5hjxubeh}(h]h ]h"]h$]h&]uh1jhjyhM%hjsxubj)}(h:``enum nl80211_iftype iftype`` The device interface type. h](j)}(h``enum nl80211_iftype iftype``h]j)}(hj(yh]henum nl80211_iftype iftype}(hj*yhhhNhNubah}(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)}(hThe device interface type.h]hThe device interface type.}(hjAyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=yhM&hj>yubah}(h]h ]h"]h$]h&]uh1j5hj"yubeh}(h]h ]h"]h$]h&]uh1jhj=yhM&hjsxubj)}(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)}(hjayh]h!const unsigned int extra_headroom}(hjcyhhhNhNubah}(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)}(h5The hardware extra headroom for SKBs in the **list**.h](h,The hardware extra headroom for SKBs in the }(hjzyhhhNhNubj)}(h**list**h]hlist}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzyubh.}(hjzyhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjvyhM'hjwyubah}(h]h ]h"]h$]h&]uh1j5hj[yubeh}(h]h ]h"]h$]h&]uh1jhjvyhM'hjsxubj)}(hI``const u8 *check_da`` DA to check in the inner ethernet header, or NULL h](j)}(h``const u8 *check_da``h]j)}(hjyh]hconst u8 *check_da}(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)}(h1DA to check in the inner ethernet header, or NULLh]h1DA to check in the inner ethernet header, or NULL}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyhM(hjyubah}(h]h ]h"]h$]h&]uh1j5hjyubeh}(h]h ]h"]h$]h&]uh1jhjyhM(hjsxubj)}(hI``const u8 *check_sa`` SA to check in the inner ethernet header, or NULL h](j)}(h``const u8 *check_sa``h]j)}(hjyh]hconst u8 *check_sa}(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)}(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&]uh1hhjyhM)hjyubah}(h]h ]h"]h$]h&]uh1j5hjyubeh}(h]h ]h"]h$]h&]uh1jhjyhM)hjsxubj)}(h=``u8 mesh_control`` see mesh_hdr in ieee80211_is_valid_amsdu h](j)}(h``u8 mesh_control``h]j)}(hjzh]hu8 mesh_control}(hj zhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM*hjzubj6)}(hhh]h)}(h(see mesh_hdr in ieee80211_is_valid_amsduh]h(see mesh_hdr in ieee80211_is_valid_amsdu}(hj7zhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3zhM*hj4zubah}(h]h ]h"]h$]h&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhj3zhM*hjsxubeh}(h]h ]h"]h$]h&]uh1jhjWxubh)}(h**Description**h]j)}(hjYzh]h Description}(hj[zhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjWzubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM,hjWxubh)}(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 }(hjozhhhNhNubj)}(h**list**h]hlist}(hjwzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjozubh( will be empty if the decode fails. The }(hjozhhhNhNubj)}(h**skb**h]hskb}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjozubhU must be fully header-less before being passed in here; it is freed in this function.}(hjozhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjWxubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjqhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_#cfg80211_classify8021d (C function)c.cfg80211_classify8021dhNtauh1jRhjqhhhNhNubjd)}(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}(hjzhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjzhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMLubj)}(h h]h }(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjzhhhjzhMLubj`)}(hinth]hint}(hjzhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjzhhhjzhMLubj)}(h h]h }(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjzhhhjzhMLubj)}(hcfg80211_classify8021dh]j)}(hcfg80211_classify8021dh]hcfg80211_classify8021d}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjzubah}(h]h ](jjeh"]h$]h&]jjuh1jhjzhhhjzhMLubj)}(h7(struct sk_buff *skb, struct cfg80211_qos_map *qos_map)h](j)}(hstruct sk_buff *skbh](ju)}(hjnh]hstruct}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj{ubj)}(h h]h }(hj({hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hj9{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6{ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj;{modnameN classnameNjS jV )}jY ]j)}jj{sbc.cfg80211_classify8021dasbuh1hhj{ubj)}(h h]h }(hjY{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ubj)}(hjh]h*}(hjg{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ubj)}(hskbh]hskb}(hjt{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubj)}(h struct cfg80211_qos_map *qos_maph](ju)}(hjnh]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 classnameNjS jV )}jY ]jU{c.cfg80211_classify8021dasbuh1hhj{ubj)}(h h]h }(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ubj)}(hjh]h*}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ubj)}(hqos_maph]hqos_map}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubeh}(h]h ]h"]h$]h&]jjuh1jhjzhhhjzhMLubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjzhhhjzhMLubah}(h]jzah ](jjeh"]h$]h&]jj)jhuh1jhhjzhMLhjzhhubj)}(hhh]h)}(h,determine the 802.1p/1d tag for a data frameh]h,determine the 802.1p/1d tag for a data frame}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMLhj |hhubah}(h]h ]h"]h$]h&]uh1jhjzhhhjzhMLubeh}(h]h ](j$functioneh"]h$]h&]jj$jj&|jj&|jjjuh1jchhhjqhNhNubj)}(h**Parameters** ``struct sk_buff *skb`` the data frame ``struct cfg80211_qos_map *qos_map`` Interworking QoS mapping or ``NULL`` if not in use **Return** The 802.1p/1d tag.h](h)}(h**Parameters**h]j)}(hj0|h]h Parameters}(hj2|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.|ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMPhj*|ubj)}(hhh](j)}(h'``struct sk_buff *skb`` the data frame h](j)}(h``struct sk_buff *skb``h]j)}(hjO|h]hstruct sk_buff *skb}(hjQ|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjM|ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMMhjI|ubj6)}(hhh]h)}(hthe data frameh]hthe data frame}(hjh|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjd|hMMhje|ubah}(h]h ]h"]h$]h&]uh1j5hjI|ubeh}(h]h ]h"]h$]h&]uh1jhjd|hMMhjF|ubj)}(hX``struct cfg80211_qos_map *qos_map`` Interworking QoS mapping or ``NULL`` if not in use h](j)}(h$``struct cfg80211_qos_map *qos_map``h]j)}(hj|h]h struct cfg80211_qos_map *qos_map}(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:137: ./include/net/cfg80211.hhMNhj|ubj6)}(hhh]h)}(h2Interworking QoS mapping or ``NULL`` if not in useh](hInterworking QoS mapping or }(hj|hhhNhNubj)}(h``NULL``h]hNULL}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubh if not in use}(hj|hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj|hMNhj|ubah}(h]h ]h"]h$]h&]uh1j5hj|ubeh}(h]h ]h"]h$]h&]uh1jhj|hMNhjF|ubeh}(h]h ]h"]h$]h&]uh1jhj*|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:137: ./include/net/cfg80211.hhMPhj*|ubh)}(hThe 802.1p/1d tag.h]hThe 802.1p/1d tag.}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMOhj*|ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjqhhhNhNubeh}(h]data-path-helpersah ]h"]data path helpersah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(h%Regulatory enforcement infrastructureh]h%Regulatory enforcement infrastructure}(hj }hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj }hhhhhKubh)}(hTODOh]hTODO}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:146: ./include/net/cfg80211.hhMYhj }hhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_regulatory_hint (C function)c.regulatory_hinthNtauh1jRhj }hhhNhNubjd)}(hhh](ji)}(h=int regulatory_hint (struct wiphy *wiphy, const char *alpha2)h]jo)}(h}hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhM_ubj)}(h h]h }(hjQ}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>}hhhjP}hM_ubj)}(hregulatory_hinth]j)}(hregulatory_hinth]hregulatory_hint}(hjc}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_}ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj>}hhhjP}hM_ubj)}(h)(struct wiphy *wiphy, const char *alpha2)h](j)}(hstruct wiphy *wiphyh](ju)}(hjnh]hstruct}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj{}ubj)}(h h]h }(hj}hhhNhNubah}(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 classnameNjS jV )}jY ]j)}jje}sbc.regulatory_hintasbuh1hhj{}ubj)}(h h]h }(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{}ubj)}(hjh]h*}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{}ubj)}(hwiphyh]hwiphy}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{}ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjw}ubj)}(hconst char *alpha2h](ju)}(hjIh]hconst}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj}ubj)}(h h]h }(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubj`)}(hcharh]hchar}(hj ~hhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hj}ubj)}(h h]h }(hj~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubj)}(hjh]h*}(hj(~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubj)}(halpha2h]halpha2}(hj5~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjw}ubeh}(h]h ]h"]h$]h&]jjuh1jhj>}hhhjP}hM_ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj:}hhhjP}hM_ubah}(h]j5}ah ](jjeh"]h$]h&]jj)jhuh1jhhjP}hM_hj7}hhubj)}(hhh]h)}(h4driver hint to the wireless core a regulatory domainh]h4driver hint to the wireless core a regulatory domain}(hj_~hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhM_hj\~hhubah}(h]h ]h"]h$]h&]uh1jhj7}hhhjP}hM_ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjw~jjw~jjjuh1jchhhj }hNhNubj)}(hXF**Parameters** ``struct wiphy *wiphy`` the wireless device giving the hint (used only for reporting conflicts) ``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. **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.hhMchj{~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.hhMahj~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.hhM`hj~ubah}(h]h ]h"]h$]h&]uh1j5hj~ubeh}(h]h ]h"]h$]h&]uh1jhj~hMahj~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&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMehj~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 }(hj~hhhNhNubj)}(h**rd**h]hrd}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~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.}(hj~hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMbhj~ubah}(h]h ]h"]h$]h&]uh1j5hj~ubeh}(h]h ]h"]h$]h&]uh1jhj~hMehj~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.hhMghj{~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.hhMfhj{~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().}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMmhj{~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.hhMqhj{~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:149: ./include/net/cfg80211.hhMthj{~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.hhMuhj{~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}(hjhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubj)}(hwiphy_apply_custom_regulatoryh]j)}(hwiphy_apply_custom_regulatoryh]hwiphy_apply_custom_regulatory}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMubj)}(h=(struct wiphy *wiphy, const struct ieee80211_regdomain *regd)h](j)}(hstruct wiphy *wiphyh](ju)}(hjnh]hstruct}(hjhhhNhNubah}(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 reftargetjmodnameN classnameNjS jV )}jY ]j)}jjsbc.wiphy_apply_custom_regulatoryasbuh1hhjubj)}(h h]h }(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hwiphyh]hwiphy}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h&const struct ieee80211_regdomain *regdh](ju)}(hjIh]hconst}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj]ubj)}(h h]h }(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubju)}(hjnh]hstruct}(hj|hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj]ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubh)}(hhh]j)}(hieee80211_regdomainh]hieee80211_regdomain}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNjS jV )}jY ]j)c.wiphy_apply_custom_regulatoryasbuh1hhj]ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubj)}(hjh]h*}(hjƀhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubj)}(hregdh]hregd}(hjӀhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubeh}(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'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.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(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}(hj!hhhNhNubah}(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)}(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.hhMhj8ubj6)}(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}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShMhjTubah}(h]h ]h"]h$]h&]uh1j5hj8ubeh}(h]h ]h"]h$]h&]uh1jhjShMhj5ubj)}(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)}(hjwh]h&const struct ieee80211_regdomain *regd}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjqubj6)}(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&]uh1j5hjqubeh}(h]h ]h"]h$]h&]uh1jhjhMhj5ubeh}(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)}(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.}(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 }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)}(hjIh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubju)}(hjnh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhhjhMubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubh)}(hhh]j)}(hieee80211_reg_ruleh]hieee80211_reg_rule}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj3modnameN classnameNjS jV )}jY ]j)}j freq_reg_infosbc.freq_reg_infoasbuh1hhjhhhjhMubj)}(h h]h }(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubj)}(hjh]h*}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubj)}(h freq_reg_infoh]j)}(hjOh]h freq_reg_info}(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjmubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMubj)}(h&(struct wiphy *wiphy, u32 center_freq)h](j)}(hstruct wiphy *wiphyh](ju)}(hjnh]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 classnameNjS jV )}jY ]jMc.freq_reg_infoasbuh1hhjubj)}(h h]h }(hjȂhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hjւhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu32 center_freqh](h)}(hhh]j)}(hu32h]hu32}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNjS jV )}jY ]jMc.freq_reg_infoasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h center_freqh]h center_freq}(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)}(h2get regulatory information for the given frequencyh]h2get regulatory information for the given frequency}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjRhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjmjjmjjjuh1jchhhj }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)}(hjwh]h Parameters}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjqubj)}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hR``u32 center_freq`` Frequency in KHz for which we want regulatory information for h](j)}(h``u32 center_freq``h]j)}(hjσh]hu32 center_freq}(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.hhMhjɃubj6)}(hhh]h)}(h=Frequency in KHz for which we want regulatory information forh]h=Frequency in KHz for which we want regulatory information for}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjɃubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjqubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(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.hhMhjqubh)}(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.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjqubh)}(h **Return**h]j)}(hj1h]hReturn}(hj3hhhNhNubah}(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.hhMhjqubh)}(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.}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjqubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj }hhhNhNubeh}(h]%regulatory-enforcement-infrastructureah ]h"]%regulatory enforcement infrastructureah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(hRFkill integrationh]hRFkill integration}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehhhhhKubh)}(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.}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:158: ./include/net/cfg80211.hhMhjehhubh)}(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.hhMhjehhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_'wiphy_rfkill_start_polling (C function)c.wiphy_rfkill_start_pollinghNtauh1jRhjehhhNhNubjd)}(hhh](ji)}(h5void wiphy_rfkill_start_polling (struct wiphy *wiphy)h]jo)}(h4void wiphy_rfkill_start_polling(struct wiphy *wiphy)h](j`)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(hwiphy_rfkill_start_pollingh]j)}(hwiphy_rfkill_start_pollingh]hwiphy_rfkill_start_polling}(hj΄hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjʄubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubj)}(h(struct wiphy *wiphy)h]j)}(hstruct wiphy *wiphyh](ju)}(hjnh]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 reftargetj modnameN classnameNjS jV )}jY ]j)}jjЄsbc.wiphy_rfkill_start_pollingasbuh1hhjubj)}(h h]h }(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hwiphyh]hwiphy}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM hjhhubj)}(hhh]h)}(hstart polling rfkillh]hstart polling rfkill}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM hjjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhjehNhNubj)}(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.hhM hjubj)}(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}(hjDžhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM hjąubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjÅhM hjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjehhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_&wiphy_rfkill_stop_polling (C function)c.wiphy_rfkill_stop_pollinghNtauh1jRhjehhhNhNubjd)}(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 ]jlah"]h$]h&]uh1j_hjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(hwiphy_rfkill_stop_pollingh]j)}(hwiphy_rfkill_stop_pollingh]hwiphy_rfkill_stop_polling}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubj)}(h(struct wiphy *wiphy)h]j)}(hstruct wiphy *wiphyh](ju)}(hjnh]hstruct}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjAubj)}(h h]h }(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAubh)}(hhh]j)}(hwiphyh]hwiphy}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjemodnameN classnameNjS jV )}jY ]j)}jj+sbc.wiphy_rfkill_stop_pollingasbuh1hhjAubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAubj)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj=ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM hjhhubj)}(hhh]h)}(hstop polling rfkillh]hstop polling rfkill}(hjȆhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM hjņhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhjehNhNubj)}(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.hhM hjubj)}(hhh]j)}(h!``struct wiphy *wiphy`` the wiphyh](j)}(h``struct wiphy *wiphy``h]j)}(hj h]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:161: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h the wiphyh]h the wiphy}(hj"hhhNhNubah}(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&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjehhhNhNubeh}(h]rfkill-integrationah ]h"]rfkill integrationah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(h Test modeh]h Test mode}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRhhhhhKubh)}(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.}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:170: ./include/net/cfg80211.hhM hjRhhubh)}(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.}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:170: ./include/net/cfg80211.hhM hjRhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_.cfg80211_testmode_alloc_reply_skb (C function)#c.cfg80211_testmode_alloc_reply_skbhNtauh1jRhjRhhhNhNubjd)}(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)}(hjnh]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 classnameNjS jV )}jY ]j)}j!cfg80211_testmode_alloc_reply_skbsb#c.cfg80211_testmode_alloc_reply_skbasbuh1hhjhhhjhM ubj)}(h h]h }(hjڇhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(hjh]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(h!cfg80211_testmode_alloc_reply_skbh]j)}(hjׇh]h!cfg80211_testmode_alloc_reply_skb}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubj)}(h$(struct wiphy *wiphy, int approxlen)h](j)}(hstruct wiphy *wiphyh](ju)}(hjnh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hwiphyh]hwiphy}(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj4modnameN classnameNjS jV )}jY ]jՇ#c.cfg80211_testmode_alloc_reply_skbasbuh1hhjubj)}(h h]h }(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hwiphyh]hwiphy}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h int approxlenh](j`)}(hinth]hint}(hjhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h approxlenh]h approxlen}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubeh}(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 replyh]hallocate testmode reply}(hjʈhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hjLjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhjRhNhNubj)}(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)}(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.hhM hjubj)}(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:173: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h the wiphyh]h the wiphy}(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)}(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)}(hjDh]h int approxlen}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(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}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hjZubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhjYhM hjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(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.hhM hjubh)}(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}(hjhhhNhNubah}(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.hhM hjubh)}(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 }(hjhhhNhNubj)}(h``NL80211_ATTR_TESTDATA``h]hNL80211_ATTR_TESTDATA}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh 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.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hjubh)}(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 }(hj؉hhhNihNubj)}(h**testmode_cmd**h]h testmode_cmd}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj؉ubh operation.}(hj؉hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hjubh)}(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:173: ./include/net/cfg80211.hhM hjubh)}(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.hhM hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjRhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_$cfg80211_testmode_reply (C function)c.cfg80211_testmode_replyhNtauh1jRhjRhhhNhNubjd)}(hhh](ji)}(h1int cfg80211_testmode_reply (struct sk_buff *skb)h]jo)}(h0int cfg80211_testmode_reply(struct sk_buff *skb)h](j`)}(hinth]hint}(hjRhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjNhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNhhhj`hM ubj)}(hcfg80211_testmode_replyh]j)}(hcfg80211_testmode_replyh]hcfg80211_testmode_reply}(hjshhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjoubah}(h]h ](jjeh"]h$]h&]jjuh1jhjNhhhj`hM ubj)}(h(struct sk_buff *skb)h]j)}(hstruct sk_buff *skbh](ju)}(hjnh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNjS jV )}jY ]j)}jjusbc.cfg80211_testmode_replyasbuh1hhjubj)}(h h]h }(hj͊hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hjۊhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hskbh]hskb}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjNhhhj`hM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjJhhhj`hM ubah}(h]jEah ](jjeh"]h$]h&]jj)jhuh1jhhj`hM hjGhhubj)}(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.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhjGhhhj`hM ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj*jj*jjjuh1jchhhjRhNhNubj)}(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)}(hj4h]h Parameters}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2ubah}(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)}(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)}(hjSh]hstruct sk_buff *skb}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hjMubj6)}(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()}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hjiubah}(h]h ]h"]h$]h&]uh1j5hjMubeh}(h]h ]h"]h$]h&]uh1jhjhhM hjJubah}(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)}(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 }(hjhhhNhNubj)}(h**testmode_cmd**h]h testmode_cmd}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubhl you should return the error code. Note that this function consumes the skb regardless of the return value.}(hjhhhNhNubeh}(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)}(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:173: ./include/net/cfg80211.hhM hj.ubh)}(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 hj.ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjRhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_.cfg80211_testmode_alloc_event_skb (C function)#c.cfg80211_testmode_alloc_event_skbhNtauh1jRhjRhhhNhNubjd)}(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)}(hjnh]hstruct}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj hhha/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&]uh1jhj hhhjhM ubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj.modnameN classnameNjS jV )}jY ]j)}j!cfg80211_testmode_alloc_event_skbsb#c.cfg80211_testmode_alloc_event_skbasbuh1hhj hhhjhM ubj)}(h h]h }(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhjhM ubj)}(hjh]h*}(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhjhM ubj)}(h!cfg80211_testmode_alloc_event_skbh]j)}(hjJh]h!cfg80211_testmode_alloc_event_skb}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubah}(h]h ](jjeh"]h$]h&]jjuh1jhj hhhjhM ubj)}(h/(struct wiphy *wiphy, int approxlen, gfp_t gfp)h](j)}(hstruct wiphy *wiphyh](ju)}(hjnh]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 classnameNjS jV )}jY ]jH#c.cfg80211_testmode_alloc_event_skbasbuh1hhjubj)}(h h]h }(hjÌhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]h*}(hjьhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hwiphyh]hwiphy}(hjތhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h int approxlenh](j`)}(hinth]hint}(hjhhhNhNubah}(h]h ]jlah"]h$]h&]uh1j_hjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h approxlenh]h approxlen}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(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 reftargetj1modnameN classnameNjS jV )}jY ]jH#c.cfg80211_testmode_alloc_event_skbasbuh1hhj(ubj)}(h h]h }(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(ubj)}(hgfph]hgfp}(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj hhhjhM 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$jjjjjjjuh1jchhhjRhNhNubj)}(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)}(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.hhM hjubj)}(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:173: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h the wiphyh]h the wiphy}(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)}(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&]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)}(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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h``gfp_t gfp`` allocation flags h](j)}(h ``gfp_t gfp``h]j)}(hj9h]h gfp_t gfp}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hj3ubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjNhM hjOubah}(h]h ]h"]h$]h&]uh1j5hj3ubeh}(h]h ]h"]h$]h&]uh1jhjNhM hjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjth]h Description}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjrubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hjubh)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM hjubh)}(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}(hjhhhNhNubah}(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 hjubh)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM!hjubh)}(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:173: ./include/net/cfg80211.hhM!hjubh)}(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.hhM!hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjRhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_$cfg80211_testmode_event (C function)c.cfg80211_testmode_eventhNtauh1jRhjRhhhNhNubjd)}(hhh](ji)}(h=void cfg80211_testmode_event (struct sk_buff *skb, gfp_t gfp)h]jo)}(hjajfjrjwjjj4j9jUjZjzjjjjjjjjjjjj&j+j?jDjjjjjjj j j>jCjj jjjXj]j"j"j&j&j)j )jI,jN,j0j0j4j4j7j7jaj:j;j";j_<jd<jBjBjFjFjLjLjaOjfOjARjFRjETjJTjXjXj_j_jqjajajajcjcjejejegjjgj+jj0jjUnjZnj4pj9pj}jqjqjqjtjtjzjzj_j }j5}j:}jjjjjLjejjjjj jRjjjEjJjjjju footnote_refs} citation_refs} autofootnotes]autofootnote_refs]symbol_footnotes]symbol_footnote_refs] footnotes] citations]autofootnote_startKsymbol_footnote_startK id_counter collectionsCounter}Rparse_messages]transform_messages] transformerN include_log] decorationNhhub.