_sphinx.addnodesdocument)}( rawsourcechildren]( translations LanguagesNode)}(hhh](h pending_xref)}(hhh]docutils.nodesTextChinese (Simplified)}parenthsba attributes}(ids]classes]names]dupnames]backrefs] refdomainstdreftypedoc reftarget-/translations/zh_CN/driver-api/80211/cfg80211modnameN classnameN refexplicitutagnamehhh ubh)}(hhh]hChinese (Traditional)}hh2sbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget-/translations/zh_TW/driver-api/80211/cfg80211modnameN classnameN refexplicituh1hhh ubh)}(hhh]hItalian}hhFsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget-/translations/it_IT/driver-api/80211/cfg80211modnameN classnameN refexplicituh1hhh ubh)}(hhh]hJapanese}hhZsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget-/translations/ja_JP/driver-api/80211/cfg80211modnameN classnameN refexplicituh1hhh ubh)}(hhh]hKorean}hhnsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget-/translations/ko_KR/driver-api/80211/cfg80211modnameN classnameN refexplicituh1hhh ubh)}(hhh]hSpanish}hhsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget-/translations/sp_SP/driver-api/80211/cfg80211modnameN classnameN refexplicituh1hhh ubeh}(h]h ]h"]h$]h&]current_languageEnglishuh1h hh _documenthsourceNlineNubhsection)}(hhh](htitle)}(hcfg80211 subsystemh]hcfg80211 subsystem}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhhhG/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211.rsthKubh paragraph)}(hXcfg80211 is the configuration API for 802.11 devices in Linux. It bridges userspace and drivers, and offers some utility functionality associated with 802.11. cfg80211 must, directly or indirectly via mac80211, be used by all modern wireless drivers in Linux, so that they offer a consistent API through nl80211. For backward compatibility, cfg80211 also offers wireless extensions to userspace, but hides them from drivers completely.h]hXcfg80211 is the configuration API for 802.11 devices in Linux. It bridges userspace and drivers, and offers some utility functionality associated with 802.11. cfg80211 must, directly or indirectly via mac80211, be used by all modern wireless drivers in Linux, so that they offer a consistent API through nl80211. For backward compatibility, cfg80211 also offers wireless extensions to userspace, but hides them from drivers completely.}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hh_/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:5: ./include/net/cfg80211.hhKhhhhubh)}(hZAdditionally, cfg80211 contains code to help enforce regulatory spectrum use restrictions.h]hZAdditionally, cfg80211 contains code to help enforce regulatory spectrum use restrictions.}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hh_/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:5: ./include/net/cfg80211.hhK$hhhhubh)}(hhh](h)}(hDevice registrationh]hDevice registration}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhhhhhK ubh)}(hIn order for a driver to use cfg80211, it must register the hardware device with cfg80211. This happens through a number of hardware capability structs described below.h]hIn order for a driver to use cfg80211, it must register the hardware device with cfg80211. This happens through a number of hardware capability structs described below.}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:11: ./include/net/cfg80211.hhK,hhhhubh)}(hXThe fundamental structure for each device is the 'wiphy', of which each instance describes a physical wireless device connected to the system. Each such wiphy can have zero, one, or many virtual interfaces associated with it, which need to be identified as such by pointing the network interface's **ieee80211_ptr** pointer to a :c:type:`struct wireless_dev ` which further describes the wireless part of the interface. Normally this struct is embedded in the network interface's private data area. Drivers can optionally allow creating or destroying virtual interfaces on the fly, but without at least one or the ability to create some the wireless device isn't useful.h](hX0The fundamental structure for each device is the ‘wiphy’, of which each instance describes a physical wireless device connected to the system. Each such wiphy can have zero, one, or many virtual interfaces associated with it, which need to be identified as such by pointing the network interface’s }(hhhhhNhNubhstrong)}(h**ieee80211_ptr**h]h ieee80211_ptr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhubh pointer to a }(hhhhhNhNubh)}(h,:c:type:`struct wireless_dev `h]hliteral)}(hjh]hstruct wireless_dev}(hjhhhNhNubah}(h]h ](xrefcc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocdriver-api/80211/cfg80211 refdomainj$reftypetype refexplicitrefwarn reftarget wireless_devuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:11: ./include/net/cfg80211.hhK0hhubhX; which further describes the wireless part of the interface. Normally this struct is embedded in the network interface’s private data area. Drivers can optionally allow creating or destroying virtual interfaces on the fly, but without at least one or the ability to create some the wireless device isn’t useful.}(hhhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj8hK0hhhhubh)}(hEach wiphy structure contains device capability information, and also has a pointer to the various operations the driver offers. The definitions and structures here describe these capabilities in detail.h]hEach wiphy structure contains device capability information, and also has a pointer to the various operations the driver offers. The definitions and structures here describe these capabilities in detail.}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:11: ./include/net/cfg80211.hhK:hhhhubhindex)}(hhh]h}(h]h ]h"]h$]h&]entries](single ieee80211_channel_flags (C enum)c.ieee80211_channel_flagshNtauh1jRhhhhhNhNubhdesc)}(hhh](hdesc_signature)}(hieee80211_channel_flagsh]hdesc_signature_line)}(henum ieee80211_channel_flagsh](hdesc_sig_keyword)}(henumh]henum}(hjvhhhNhNubah}(h]h ]kah"]h$]h&]uh1jthjphhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKubhdesc_sig_space)}(h h]h }(hjhhhNhNubah}(h]h ]wah"]h$]h&]uh1jhjphhhjhKubh desc_name)}(hieee80211_channel_flagsh]h desc_sig_name)}(hjlh]hieee80211_channel_flags}(hjhhhNhNubah}(h]h ]nah"]h$]h&]uh1jhjubah}(h]h ](sig-namedescnameeh"]h$]h&] xml:spacepreserveuh1jhjphhhjhKubeh}(h]h ]h"]h$]h&]jj add_permalinkuh1jnsphinx_line_type declaratorhjjhhhjhKubah}(h]jaah ](sig sig-objecteh"]h$]h&] is_multiline _toc_parts) _toc_namehuh1jhhjhKhjehhubh desc_content)}(hhh]h)}(h channel flagsh]h channel flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKHhjhhubah}(h]h ]h"]h$]h&]uh1jhjehhhjhKubeh}(h]h ](j$enumeh"]h$]h&]domainj$objtypejdesctypejnoindex noindexentrynocontentsentryuh1jchhhhhNhNubh container)}(hX **Constants** ``IEEE80211_CHAN_DISABLED`` This channel is disabled. ``IEEE80211_CHAN_NO_IR`` do not initiate radiation, this includes sending probe requests or beaconing. ``IEEE80211_CHAN_PSD`` Power spectral density (in dBm) is set for this channel. ``IEEE80211_CHAN_RADAR`` Radar detection is required on this channel. ``IEEE80211_CHAN_NO_HT40PLUS`` extension channel above this channel is not permitted. ``IEEE80211_CHAN_NO_HT40MINUS`` extension channel below this channel is not permitted. ``IEEE80211_CHAN_NO_OFDM`` OFDM is not allowed on this channel. ``IEEE80211_CHAN_NO_80MHZ`` If the driver supports 80 MHz on the band, this flag indicates that an 80 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions. ``IEEE80211_CHAN_NO_160MHZ`` If the driver supports 160 MHz on the band, this flag indicates that an 160 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions. ``IEEE80211_CHAN_INDOOR_ONLY`` see ``NL80211_FREQUENCY_ATTR_INDOOR_ONLY`` ``IEEE80211_CHAN_IR_CONCURRENT`` see ``NL80211_FREQUENCY_ATTR_IR_CONCURRENT`` ``IEEE80211_CHAN_NO_20MHZ`` 20 MHz bandwidth is not permitted on this channel. ``IEEE80211_CHAN_NO_10MHZ`` 10 MHz bandwidth is not permitted on this channel. ``IEEE80211_CHAN_NO_HE`` HE operation is not permitted on this channel. ``IEEE80211_CHAN_1MHZ`` 1 MHz bandwidth is permitted on this channel. ``IEEE80211_CHAN_2MHZ`` 2 MHz bandwidth is permitted on this channel. ``IEEE80211_CHAN_4MHZ`` 4 MHz bandwidth is permitted on this channel. ``IEEE80211_CHAN_8MHZ`` 8 MHz bandwidth is permitted on this channel. ``IEEE80211_CHAN_16MHZ`` 16 MHz bandwidth is permitted on this channel. ``IEEE80211_CHAN_NO_320MHZ`` If the driver supports 320 MHz on the band, this flag indicates that a 320 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions. ``IEEE80211_CHAN_NO_EHT`` EHT operation is not permitted on this channel. ``IEEE80211_CHAN_DFS_CONCURRENT`` See ``NL80211_RRF_DFS_CONCURRENT`` ``IEEE80211_CHAN_NO_6GHZ_VLP_CLIENT`` Client connection with VLP AP not permitted using this channel ``IEEE80211_CHAN_NO_6GHZ_AFC_CLIENT`` Client connection with AFC AP not permitted using this channel ``IEEE80211_CHAN_CAN_MONITOR`` This channel can be used for monitor mode even in the presence of other (regulatory) restrictions, even if it is otherwise disabled. ``IEEE80211_CHAN_ALLOW_6GHZ_VLP_AP`` Allow using this channel for AP operation with very low power (VLP), even if otherwise set to NO_IR. ``IEEE80211_CHAN_ALLOW_20MHZ_ACTIVITY`` Allow activity on a 20 MHz channel, even if otherwise set to NO_IR.h](h)}(h **Constants**h]j)}(hjh]h Constants}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKLhjubhdefinition_list)}(hhh](hdefinition_list_item)}(h6``IEEE80211_CHAN_DISABLED`` This channel is disabled. h](hterm)}(h``IEEE80211_CHAN_DISABLED``h]j)}(hjh]hIEEE80211_CHAN_DISABLED}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKOhjubh definition)}(hhh]h)}(hThis channel is disabled.h]hThis channel is disabled.}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4hKOhj7ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj4hKOhjubj)}(hg``IEEE80211_CHAN_NO_IR`` do not initiate radiation, this includes sending probe requests or beaconing. h](j)}(h``IEEE80211_CHAN_NO_IR``h]j)}(hjZh]hIEEE80211_CHAN_NO_IR}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKShjTubj6)}(hhh]h)}(hMdo not initiate radiation, this includes sending probe requests or beaconing.h]hMdo not initiate radiation, this includes sending probe requests or beaconing.}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKRhjpubah}(h]h ]h"]h$]h&]uh1j5hjTubeh}(h]h ]h"]h$]h&]uh1jhjohKShjubj)}(hP``IEEE80211_CHAN_PSD`` Power spectral density (in dBm) is set for this channel. h](j)}(h``IEEE80211_CHAN_PSD``h]j)}(hjh]hIEEE80211_CHAN_PSD}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKWhjubj6)}(hhh]h)}(h8Power spectral density (in dBm) is set for this channel.h]h8Power spectral density (in dBm) is set for this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKVhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKWhjubj)}(hF``IEEE80211_CHAN_RADAR`` Radar detection is required on this channel. h](j)}(h``IEEE80211_CHAN_RADAR``h]j)}(hjh]hIEEE80211_CHAN_RADAR}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKZhjubj6)}(hhh]h)}(h,Radar detection is required on this channel.h]h,Radar detection is required on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKZhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKZhjubj)}(hV``IEEE80211_CHAN_NO_HT40PLUS`` extension channel above this channel is not permitted. h](j)}(h``IEEE80211_CHAN_NO_HT40PLUS``h]j)}(hjh]hIEEE80211_CHAN_NO_HT40PLUS}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhK^hjubj6)}(hhh]h)}(h6extension channel above this channel is not permitted.h]h6extension channel above this channel is not permitted.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhK]hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhK^hjubj)}(hW``IEEE80211_CHAN_NO_HT40MINUS`` extension channel below this channel is not permitted. h](j)}(h``IEEE80211_CHAN_NO_HT40MINUS``h]j)}(hjAh]hIEEE80211_CHAN_NO_HT40MINUS}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKbhj;ubj6)}(hhh]h)}(h6extension channel below this channel is not permitted.h]h6extension channel below this channel is not permitted.}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKahjWubah}(h]h ]h"]h$]h&]uh1j5hj;ubeh}(h]h ]h"]h$]h&]uh1jhjVhKbhjubj)}(h@``IEEE80211_CHAN_NO_OFDM`` OFDM is not allowed on this channel. h](j)}(h``IEEE80211_CHAN_NO_OFDM``h]j)}(hj{h]hIEEE80211_CHAN_NO_OFDM}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKehjuubj6)}(hhh]h)}(h$OFDM is not allowed on this channel.h]h$OFDM is not allowed on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKehjubah}(h]h ]h"]h$]h&]uh1j5hjuubeh}(h]h ]h"]h$]h&]uh1jhjhKehjubj)}(hX``IEEE80211_CHAN_NO_80MHZ`` If the driver supports 80 MHz on the band, this flag indicates that an 80 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions. h](j)}(h``IEEE80211_CHAN_NO_80MHZ``h]j)}(hjh]hIEEE80211_CHAN_NO_80MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKlhjubj6)}(hhh]h)}(hIf the driver supports 80 MHz on the band, this flag indicates that an 80 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions.h]hIf the driver supports 80 MHz on the band, this flag indicates that an 80 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKlhjubj)}(hX ``IEEE80211_CHAN_NO_160MHZ`` If the driver supports 160 MHz on the band, this flag indicates that an 160 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions. h](j)}(h``IEEE80211_CHAN_NO_160MHZ``h]j)}(hjh]hIEEE80211_CHAN_NO_160MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKshjubj6)}(hhh]h)}(hIf the driver supports 160 MHz on the band, this flag indicates that an 160 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions.h]hIf the driver supports 160 MHz on the band, this flag indicates that an 160 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKohjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKshjubj)}(hJ``IEEE80211_CHAN_INDOOR_ONLY`` see ``NL80211_FREQUENCY_ATTR_INDOOR_ONLY`` h](j)}(h``IEEE80211_CHAN_INDOOR_ONLY``h]j)}(hj(h]hIEEE80211_CHAN_INDOOR_ONLY}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKvhj"ubj6)}(hhh]h)}(h*see ``NL80211_FREQUENCY_ATTR_INDOOR_ONLY``h](hsee }(hjAhhhNhNubj)}(h&``NL80211_FREQUENCY_ATTR_INDOOR_ONLY``h]h"NL80211_FREQUENCY_ATTR_INDOOR_ONLY}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAubeh}(h]h ]h"]h$]h&]uh1hhj=hKvhj>ubah}(h]h ]h"]h$]h&]uh1j5hj"ubeh}(h]h ]h"]h$]h&]uh1jhj=hKvhjubj)}(hN``IEEE80211_CHAN_IR_CONCURRENT`` see ``NL80211_FREQUENCY_ATTR_IR_CONCURRENT`` h](j)}(h ``IEEE80211_CHAN_IR_CONCURRENT``h]j)}(hjoh]hIEEE80211_CHAN_IR_CONCURRENT}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKyhjiubj6)}(hhh]h)}(h,see ``NL80211_FREQUENCY_ATTR_IR_CONCURRENT``h](hsee }(hjhhhNhNubj)}(h(``NL80211_FREQUENCY_ATTR_IR_CONCURRENT``h]h$NL80211_FREQUENCY_ATTR_IR_CONCURRENT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1hhjhKyhjubah}(h]h ]h"]h$]h&]uh1j5hjiubeh}(h]h ]h"]h$]h&]uh1jhjhKyhjubj)}(hO``IEEE80211_CHAN_NO_20MHZ`` 20 MHz bandwidth is not permitted on this channel. h](j)}(h``IEEE80211_CHAN_NO_20MHZ``h]j)}(hjh]hIEEE80211_CHAN_NO_20MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhK}hjubj6)}(hhh]h)}(h220 MHz bandwidth is not permitted on this channel.h]h220 MHz bandwidth is not permitted on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhK|hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhK}hjubj)}(hO``IEEE80211_CHAN_NO_10MHZ`` 10 MHz bandwidth is not permitted on this channel. h](j)}(h``IEEE80211_CHAN_NO_10MHZ``h]j)}(hjh]hIEEE80211_CHAN_NO_10MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(h210 MHz bandwidth is not permitted on this channel.h]h210 MHz bandwidth is not permitted on this channel.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hH``IEEE80211_CHAN_NO_HE`` HE operation is not permitted on this channel. h](j)}(h``IEEE80211_CHAN_NO_HE``h]j)}(hj*h]hIEEE80211_CHAN_NO_HE}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj$ubj6)}(hhh]h)}(h.HE operation is not permitted on this channel.h]h.HE operation is not permitted on this channel.}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hKhj@ubah}(h]h ]h"]h$]h&]uh1j5hj$ubeh}(h]h ]h"]h$]h&]uh1jhj?hKhjubj)}(hF``IEEE80211_CHAN_1MHZ`` 1 MHz bandwidth is permitted on this channel. h](j)}(h``IEEE80211_CHAN_1MHZ``h]j)}(hjch]hIEEE80211_CHAN_1MHZ}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj]ubj6)}(hhh]h)}(h-1 MHz bandwidth is permitted on this channel.h]h-1 MHz bandwidth is permitted on this channel.}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjyubah}(h]h ]h"]h$]h&]uh1j5hj]ubeh}(h]h ]h"]h$]h&]uh1jhjxhKhjubj)}(hF``IEEE80211_CHAN_2MHZ`` 2 MHz bandwidth is permitted on this channel. h](j)}(h``IEEE80211_CHAN_2MHZ``h]j)}(hjh]hIEEE80211_CHAN_2MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(h-2 MHz bandwidth is permitted on this channel.h]h-2 MHz bandwidth is permitted on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hF``IEEE80211_CHAN_4MHZ`` 4 MHz bandwidth is permitted on this channel. h](j)}(h``IEEE80211_CHAN_4MHZ``h]j)}(hjh]hIEEE80211_CHAN_4MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(h-4 MHz bandwidth is permitted on this channel.h]h-4 MHz bandwidth is permitted on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hF``IEEE80211_CHAN_8MHZ`` 8 MHz bandwidth is permitted on this channel. h](j)}(h``IEEE80211_CHAN_8MHZ``h]j)}(hjh]hIEEE80211_CHAN_8MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(h-8 MHz bandwidth is permitted on this channel.h]h-8 MHz bandwidth is permitted on this channel.}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj'ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj&hKhjubj)}(hH``IEEE80211_CHAN_16MHZ`` 16 MHz bandwidth is permitted on this channel. h](j)}(h``IEEE80211_CHAN_16MHZ``h]j)}(hjKh]hIEEE80211_CHAN_16MHZ}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjEubj6)}(hhh]h)}(h.16 MHz bandwidth is permitted on this channel.h]h.16 MHz bandwidth is permitted on this channel.}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjaubah}(h]h ]h"]h$]h&]uh1j5hjEubeh}(h]h ]h"]h$]h&]uh1jhj`hKhjubj)}(hX``IEEE80211_CHAN_NO_320MHZ`` If the driver supports 320 MHz on the band, this flag indicates that a 320 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions. h](j)}(h``IEEE80211_CHAN_NO_320MHZ``h]j)}(hjh]hIEEE80211_CHAN_NO_320MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(hIf the driver supports 320 MHz on the band, this flag indicates that a 320 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions.h]hIf the driver supports 320 MHz on the band, this flag indicates that a 320 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hJ``IEEE80211_CHAN_NO_EHT`` EHT operation is not permitted on this channel. h](j)}(h``IEEE80211_CHAN_NO_EHT``h]j)}(hjh]hIEEE80211_CHAN_NO_EHT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(h/EHT operation is not permitted on this channel.h]h/EHT operation is not permitted on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hE``IEEE80211_CHAN_DFS_CONCURRENT`` See ``NL80211_RRF_DFS_CONCURRENT`` h](j)}(h!``IEEE80211_CHAN_DFS_CONCURRENT``h]j)}(hjh]hIEEE80211_CHAN_DFS_CONCURRENT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(h"See ``NL80211_RRF_DFS_CONCURRENT``h](hSee }(hjhhhNhNubj)}(h``NL80211_RRF_DFS_CONCURRENT``h]hNL80211_RRF_DFS_CONCURRENT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1hhj hKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hKhjubj)}(he``IEEE80211_CHAN_NO_6GHZ_VLP_CLIENT`` Client connection with VLP AP not permitted using this channel h](j)}(h%``IEEE80211_CHAN_NO_6GHZ_VLP_CLIENT``h]j)}(hj?h]h!IEEE80211_CHAN_NO_6GHZ_VLP_CLIENT}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj9ubj6)}(hhh]h)}(h>Client connection with VLP AP not permitted using this channelh]h>Client connection with VLP AP not permitted using this channel}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjUubah}(h]h ]h"]h$]h&]uh1j5hj9ubeh}(h]h ]h"]h$]h&]uh1jhjThKhjubj)}(he``IEEE80211_CHAN_NO_6GHZ_AFC_CLIENT`` Client connection with AFC AP not permitted using this channel h](j)}(h%``IEEE80211_CHAN_NO_6GHZ_AFC_CLIENT``h]j)}(hjyh]h!IEEE80211_CHAN_NO_6GHZ_AFC_CLIENT}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjsubj6)}(hhh]h)}(h>Client connection with AFC AP not permitted using this channelh]h>Client connection with AFC AP not permitted using this channel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjsubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h``IEEE80211_CHAN_CAN_MONITOR`` This channel can be used for monitor mode even in the presence of other (regulatory) restrictions, even if it is otherwise disabled. h](j)}(h``IEEE80211_CHAN_CAN_MONITOR``h]j)}(hjh]hIEEE80211_CHAN_CAN_MONITOR}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(hThis channel can be used for monitor mode even in the presence of other (regulatory) restrictions, even if it is otherwise disabled.h]hThis channel can be used for monitor mode even in the presence of other (regulatory) restrictions, even if it is otherwise disabled.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h``IEEE80211_CHAN_ALLOW_6GHZ_VLP_AP`` Allow using this channel for AP operation with very low power (VLP), even if otherwise set to NO_IR. h](j)}(h$``IEEE80211_CHAN_ALLOW_6GHZ_VLP_AP``h]j)}(hjh]h IEEE80211_CHAN_ALLOW_6GHZ_VLP_AP}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(hdAllow using this channel for AP operation with very low power (VLP), even if otherwise set to NO_IR.h]hdAllow using this channel for AP operation with very low power (VLP), even if otherwise set to NO_IR.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hk``IEEE80211_CHAN_ALLOW_20MHZ_ACTIVITY`` Allow activity on a 20 MHz channel, even if otherwise set to NO_IR.h](j)}(h'``IEEE80211_CHAN_ALLOW_20MHZ_ACTIVITY``h]j)}(hj'h]h#IEEE80211_CHAN_ALLOW_20MHZ_ACTIVITY}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj!ubj6)}(hhh]h)}(hCAllow activity on a 20 MHz channel, even if otherwise set to NO_IR.h]hCAllow activity on a 20 MHz channel, even if otherwise set to NO_IR.}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hKhj=ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj<hKhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hjih]h Description}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjgubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhhhhubh)}(h1Channel flags set by the regulatory control code.h]h1Channel flags set by the regulatory control code.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKIhhhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ieee80211_channel (C struct)c.ieee80211_channelhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hieee80211_channelh]jo)}(hstruct ieee80211_channelh](ju)}(hstructh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKNubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhKNubj)}(hieee80211_channelh]j)}(hjh]hieee80211_channel}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhKNubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhKNubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhKNhjhhubj)}(hhh]h)}(hchannel definitionh]hchannel definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKNubeh}(h]h ](j$structeh"]h$]h&]jj$jj jj jjjuh1jchhhhhNhNubj)}(hXC**Definition**:: struct ieee80211_channel { enum nl80211_band band; u32 center_freq; u16 freq_offset; u16 hw_value; u32 flags; int max_antenna_gain; int max_power; int max_reg_power; bool beacon_found; u32 orig_flags; int orig_mag, orig_mpwr; enum nl80211_dfs_state dfs_state; unsigned long dfs_state_entered; unsigned int dfs_cac_ms; s8 psd; }; **Members** ``band`` band this channel belongs to. ``center_freq`` center frequency in MHz ``freq_offset`` offset from **center_freq**, in KHz ``hw_value`` hardware-specific value for the channel ``flags`` channel flags from :c:type:`enum ieee80211_channel_flags `. ``max_antenna_gain`` maximum antenna gain in dBi ``max_power`` maximum transmission power (in dBm) ``max_reg_power`` maximum regulatory transmission power (in dBm) ``beacon_found`` helper to regulatory code to indicate when a beacon has been found on this channel. Use regulatory_hint_found_beacon() to enable this, this is useful only on 5 GHz band. ``orig_flags`` channel flags at registration time, used by regulatory code to support devices with additional restrictions ``orig_mag`` internal use ``orig_mpwr`` internal use ``dfs_state`` current state of this channel. Only relevant if radar is required on this channel. ``dfs_state_entered`` timestamp (jiffies) when the dfs state was entered. ``dfs_cac_ms`` DFS CAC time in milliseconds, this is valid for DFS channels. ``psd`` power spectral density (in dBm)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubh:}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubh literal_block)}(hXstruct ieee80211_channel { enum nl80211_band band; u32 center_freq; u16 freq_offset; u16 hw_value; u32 flags; int max_antenna_gain; int max_power; int max_reg_power; bool beacon_found; u32 orig_flags; int orig_mag, orig_mpwr; enum nl80211_dfs_state dfs_state; unsigned long dfs_state_entered; unsigned int dfs_cac_ms; s8 psd; };h]hXstruct ieee80211_channel { enum nl80211_band band; u32 center_freq; u16 freq_offset; u16 hw_value; u32 flags; int max_antenna_gain; int max_power; int max_reg_power; bool beacon_found; u32 orig_flags; int orig_mag, orig_mpwr; enum nl80211_dfs_state dfs_state; unsigned long dfs_state_entered; unsigned int dfs_cac_ms; s8 psd; };}hj) sbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubh)}(h **Members**h]j)}(hj: h]hMembers}(hj< hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8 ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj)}(hhh](j)}(h'``band`` band this channel belongs to. h](j)}(h``band``h]j)}(hjY h]hband}(hj[ hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjW ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjS ubj6)}(hhh]h)}(hband this channel belongs to.h]hband this channel belongs to.}(hjr hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjn hKhjo ubah}(h]h ]h"]h$]h&]uh1j5hjS ubeh}(h]h ]h"]h$]h&]uh1jhjn hKhjP ubj)}(h(``center_freq`` center frequency in MHz h](j)}(h``center_freq``h]j)}(hj h]h center_freq}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(hcenter frequency in MHzh]hcenter frequency in MHz}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(h4``freq_offset`` offset from **center_freq**, in KHz h](j)}(h``freq_offset``h]j)}(hj h]h freq_offset}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(h#offset from **center_freq**, in KHzh](h offset from }(hj hhhNhNubj)}(h**center_freq**h]h center_freq}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubh, in KHz}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(h5``hw_value`` hardware-specific value for the channel h](j)}(h ``hw_value``h]j)}(hj h]hhw_value}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(h'hardware-specific value for the channelh]h'hardware-specific value for the channel}(hj/ hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj+ hKhj, ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj+ hKhjP ubj)}(h_``flags`` channel flags from :c:type:`enum ieee80211_channel_flags `. h](j)}(h ``flags``h]j)}(hjO h]hflags}(hjQ hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjM ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjI ubj6)}(hhh]h)}(hTchannel flags from :c:type:`enum ieee80211_channel_flags `.h](hchannel flags from }(hjh hhhNhNubh)}(h@:c:type:`enum ieee80211_channel_flags `h]j)}(hjr h]henum ieee80211_channel_flags}(hjt hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjp ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarn c:parent_keysphinx.domains.c LookupKey)}data]sbj6ieee80211_channel_flagsuh1hhjd hKhjh ubh.}(hjh hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjd hKhje ubah}(h]h ]h"]h$]h&]uh1j5hjI ubeh}(h]h ]h"]h$]h&]uh1jhjd hKhjP ubj)}(h1``max_antenna_gain`` maximum antenna gain in dBi h](j)}(h``max_antenna_gain``h]j)}(hj h]hmax_antenna_gain}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(hmaximum antenna gain in dBih]hmaximum antenna gain in dBi}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(h2``max_power`` maximum transmission power (in dBm) h](j)}(h ``max_power``h]j)}(hj h]h max_power}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(h#maximum transmission power (in dBm)h]h#maximum transmission power (in dBm)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(hA``max_reg_power`` maximum regulatory transmission power (in dBm) h](j)}(h``max_reg_power``h]j)}(hj% h]h max_reg_power}(hj' hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj# ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(h.maximum regulatory transmission power (in dBm)h]h.maximum regulatory transmission power (in dBm)}(hj> hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj: hKhj; ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj: hKhjP ubj)}(h``beacon_found`` helper to regulatory code to indicate when a beacon has been found on this channel. Use regulatory_hint_found_beacon() to enable this, this is useful only on 5 GHz band. h](j)}(h``beacon_found``h]j)}(hj^ h]h beacon_found}(hj` hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjX ubj6)}(hhh]h)}(hhelper to regulatory code to indicate when a beacon has been found on this channel. Use regulatory_hint_found_beacon() to enable this, this is useful only on 5 GHz band.h]hhelper to regulatory code to indicate when a beacon has been found on this channel. Use regulatory_hint_found_beacon() to enable this, this is useful only on 5 GHz band.}(hjw hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjt ubah}(h]h ]h"]h$]h&]uh1j5hjX ubeh}(h]h ]h"]h$]h&]uh1jhjs hKhjP ubj)}(h{``orig_flags`` channel flags at registration time, used by regulatory code to support devices with additional restrictions h](j)}(h``orig_flags``h]j)}(hj h]h orig_flags}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(hkchannel flags at registration time, used by regulatory code to support devices with additional restrictionsh]hkchannel flags at registration time, used by regulatory code to support devices with additional restrictions}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(h``orig_mag`` internal use h](j)}(h ``orig_mag``h]j)}(hj h]horig_mag}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(h internal useh]h internal use}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(h``orig_mpwr`` internal use h](j)}(h ``orig_mpwr``h]j)}(hj h]h orig_mpwr}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(h internal useh]h internal use}(hj$ hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj! ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(ha``dfs_state`` current state of this channel. Only relevant if radar is required on this channel. h](j)}(h ``dfs_state``h]j)}(hjD h]h dfs_state}(hjF hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjB ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj> ubj6)}(hhh]h)}(hRcurrent state of this channel. Only relevant if radar is required on this channel.h]hRcurrent state of this channel. Only relevant if radar is required on this channel.}(hj] hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjZ ubah}(h]h ]h"]h$]h&]uh1j5hj> ubeh}(h]h ]h"]h$]h&]uh1jhjY hKhjP ubj)}(hJ``dfs_state_entered`` timestamp (jiffies) when the dfs state was entered. h](j)}(h``dfs_state_entered``h]j)}(hj~ h]hdfs_state_entered}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj| ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjx ubj6)}(hhh]h)}(h3timestamp (jiffies) when the dfs state was entered.h]h3timestamp (jiffies) when the dfs state was entered.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j5hjx ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(hM``dfs_cac_ms`` DFS CAC time in milliseconds, this is valid for DFS channels. h](j)}(h``dfs_cac_ms``h]j)}(hj h]h dfs_cac_ms}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(h=DFS CAC time in milliseconds, this is valid for DFS channels.h]h=DFS CAC time in milliseconds, this is valid for DFS channels.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubj)}(h'``psd`` power spectral density (in dBm)h](j)}(h``psd``h]j)}(hj h]hpsd}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(hpower spectral density (in dBm)h]hpower spectral density (in dBm)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjP ubeh}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hj3 h]h Description}(hj5 hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1 ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhhhhubh)}(h@This structure describes a single channel for use with cfg80211.h]h@This structure describes a single channel for use with cfg80211.}(hjI hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhhhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ieee80211_rate_flags (C enum)c.ieee80211_rate_flagshNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hieee80211_rate_flagsh]jo)}(henum ieee80211_rate_flagsh](ju)}(hjxh]henum}(hjq hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjm hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjm hhhj~ hKubj)}(hieee80211_rate_flagsh]j)}(hjk h]hieee80211_rate_flags}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjm hhhj~ hKubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhji hhhj~ hKubah}(h]jd ah ](jjeh"]h$]h&]jj)jhuh1jhhj~ hKhjf hhubj)}(hhh]h)}(h rate flagsh]h rate flags}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj hhubah}(h]h ]h"]h$]h&]uh1jhjf hhhj~ hKubeh}(h]h ](j$enumeh"]h$]h&]jj$jj jj jjjuh1jchhhhhNhNubj)}(hX`**Constants** ``IEEE80211_RATE_SHORT_PREAMBLE`` Hardware can send with short preamble on this bitrate; only relevant in 2.4GHz band and with CCK rates. ``IEEE80211_RATE_MANDATORY_A`` This bitrate is a mandatory rate when used with 802.11a (on the 5 GHz band); filled by the core code when registering the wiphy. ``IEEE80211_RATE_MANDATORY_B`` This bitrate is a mandatory rate when used with 802.11b (on the 2.4 GHz band); filled by the core code when registering the wiphy. ``IEEE80211_RATE_MANDATORY_G`` This bitrate is a mandatory rate when used with 802.11g (on the 2.4 GHz band); filled by the core code when registering the wiphy. ``IEEE80211_RATE_ERP_G`` This is an ERP rate in 802.11g mode. ``IEEE80211_RATE_SUPPORTS_5MHZ`` Rate can be used in 5 MHz mode ``IEEE80211_RATE_SUPPORTS_10MHZ`` Rate can be used in 10 MHz modeh](h)}(h **Constants**h]j)}(hj h]h Constants}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj)}(hhh](j)}(h``IEEE80211_RATE_SHORT_PREAMBLE`` Hardware can send with short preamble on this bitrate; only relevant in 2.4GHz band and with CCK rates. h](j)}(h!``IEEE80211_RATE_SHORT_PREAMBLE``h]j)}(hj h]hIEEE80211_RATE_SHORT_PREAMBLE}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubj6)}(hhh]h)}(hgHardware can send with short preamble on this bitrate; only relevant in 2.4GHz band and with CCK rates.h]hgHardware can send with short preamble on this bitrate; only relevant in 2.4GHz band and with CCK rates.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhj ubj)}(h``IEEE80211_RATE_MANDATORY_A`` This bitrate is a mandatory rate when used with 802.11a (on the 5 GHz band); filled by the core code when registering the wiphy. h](j)}(h``IEEE80211_RATE_MANDATORY_A``h]j)}(hj.h]hIEEE80211_RATE_MANDATORY_A}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj(ubj6)}(hhh]h)}(hThis bitrate is a mandatory rate when used with 802.11a (on the 5 GHz band); filled by the core code when registering the wiphy.h]hThis bitrate is a mandatory rate when used with 802.11a (on the 5 GHz band); filled by the core code when registering the wiphy.}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjDubah}(h]h ]h"]h$]h&]uh1j5hj(ubeh}(h]h ]h"]h$]h&]uh1jhjChKhj ubj)}(h``IEEE80211_RATE_MANDATORY_B`` This bitrate is a mandatory rate when used with 802.11b (on the 2.4 GHz band); filled by the core code when registering the wiphy. h](j)}(h``IEEE80211_RATE_MANDATORY_B``h]j)}(hjhh]hIEEE80211_RATE_MANDATORY_B}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjbubj6)}(hhh]h)}(hThis bitrate is a mandatory rate when used with 802.11b (on the 2.4 GHz band); filled by the core code when registering the wiphy.h]hThis bitrate is a mandatory rate when used with 802.11b (on the 2.4 GHz band); filled by the core code when registering the wiphy.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj~ubah}(h]h ]h"]h$]h&]uh1j5hjbubeh}(h]h ]h"]h$]h&]uh1jhj}hKhj ubj)}(h``IEEE80211_RATE_MANDATORY_G`` This bitrate is a mandatory rate when used with 802.11g (on the 2.4 GHz band); filled by the core code when registering the wiphy. h](j)}(h``IEEE80211_RATE_MANDATORY_G``h]j)}(hjh]hIEEE80211_RATE_MANDATORY_G}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(hThis bitrate is a mandatory rate when used with 802.11g (on the 2.4 GHz band); filled by the core code when registering the wiphy.h]hThis bitrate is a mandatory rate when used with 802.11g (on the 2.4 GHz band); filled by the core code when registering the wiphy.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhj ubj)}(h>``IEEE80211_RATE_ERP_G`` This is an ERP rate in 802.11g mode. h](j)}(h``IEEE80211_RATE_ERP_G``h]j)}(hjh]hIEEE80211_RATE_ERP_G}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(h$This is an ERP rate in 802.11g mode.h]h$This is an ERP rate in 802.11g mode.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhj ubj)}(h@``IEEE80211_RATE_SUPPORTS_5MHZ`` Rate can be used in 5 MHz mode h](j)}(h ``IEEE80211_RATE_SUPPORTS_5MHZ``h]j)}(hjh]hIEEE80211_RATE_SUPPORTS_5MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj6)}(hhh]h)}(hRate can be used in 5 MHz modeh]hRate can be used in 5 MHz mode}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hKhj+ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj*hKhj ubj)}(hA``IEEE80211_RATE_SUPPORTS_10MHZ`` Rate can be used in 10 MHz modeh](j)}(h!``IEEE80211_RATE_SUPPORTS_10MHZ``h]j)}(hjNh]hIEEE80211_RATE_SUPPORTS_10MHZ}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjHubj6)}(hhh]h)}(hRate can be used in 10 MHz modeh]hRate can be used in 10 MHz mode}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjdubah}(h]h ]h"]h$]h&]uh1j5hjHubeh}(h]h ]h"]h$]h&]uh1jhjchKhj ubeh}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhhhhubh)}(hHardware/specification flags for rates. These are structured in a way that allows using the same bitrate structure for different bands/PHY modes.h]hHardware/specification flags for rates. These are structured in a way that allows using the same bitrate structure for different bands/PHY modes.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhhhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ieee80211_rate (C struct)c.ieee80211_ratehNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hieee80211_rateh]jo)}(hstruct ieee80211_rateh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhKubj)}(hieee80211_rateh]j)}(hjh]hieee80211_rate}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhKhjhhubj)}(hhh]h)}(hbitrate definitionh]hbitrate definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](j$structeh"]h$]h&]jj$jj)jj)jjjuh1jchhhhhNhNubj)}(hX**Definition**:: struct ieee80211_rate { u32 flags; u16 bitrate; u16 hw_value, hw_value_short; }; **Members** ``flags`` rate-specific flags from :c:type:`enum ieee80211_rate_flags ` ``bitrate`` bitrate in units of 100 Kbps ``hw_value`` driver/hardware value for this rate ``hw_value_short`` driver/hardware value for this rate when short preamble is usedh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1ubh:}(hj1hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj-ubj( )}(h\struct ieee80211_rate { u32 flags; u16 bitrate; u16 hw_value, hw_value_short; };h]h\struct ieee80211_rate { u32 flags; u16 bitrate; u16 hw_value, hw_value_short; };}hjNsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj-ubh)}(h **Members**h]j)}(hj_h]hMembers}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM%hj-ubj)}(hhh](j)}(h^``flags`` rate-specific flags from :c:type:`enum ieee80211_rate_flags ` h](j)}(h ``flags``h]j)}(hj~h]hflags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM!hjxubj6)}(hhh]h)}(hSrate-specific flags from :c:type:`enum ieee80211_rate_flags `h](hrate-specific flags from }(hjhhhNhNubh)}(h::c:type:`enum ieee80211_rate_flags `h]j)}(hjh]henum ieee80211_rate_flags}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6ieee80211_rate_flagsuh1hhjhM!hjubeh}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1j5hjxubeh}(h]h ]h"]h$]h&]uh1jhjhM!hjuubj)}(h)``bitrate`` bitrate in units of 100 Kbps h](j)}(h ``bitrate``h]j)}(hjh]hbitrate}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM"hjubj6)}(hhh]h)}(hbitrate in units of 100 Kbpsh]hbitrate in units of 100 Kbps}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM"hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM"hjuubj)}(h1``hw_value`` driver/hardware value for this rate h](j)}(h ``hw_value``h]j)}(hjh]hhw_value}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM#hj ubj6)}(hhh]h)}(h#driver/hardware value for this rateh]h#driver/hardware value for this rate}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$hM#hj%ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj$hM#hjuubj)}(hR``hw_value_short`` driver/hardware value for this rate when short preamble is usedh](j)}(h``hw_value_short``h]j)}(hjHh]hhw_value_short}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM$hjBubj6)}(hhh]h)}(h?driver/hardware value for this rate when short preamble is usedh]h?driver/hardware value for this rate when short preamble is used}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]hM$hj^ubah}(h]h ]h"]h$]h&]uh1j5hjBubeh}(h]h ]h"]h$]h&]uh1jhj]hM$hjuubeh}(h]h ]h"]h$]h&]uh1jhj-ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM(hhhhubh)}(hThis structure describes a bitrate that an 802.11 PHY can operate with. The two values **hw_value** and **hw_value_short** are only for driver use when pointers to this structure are passed around.h](hWThis structure describes a bitrate that an 802.11 PHY can operate with. The two values }(hjhhhNhNubj)}(h **hw_value**h]hhw_value}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh and }(hjhhhNhNubj)}(h**hw_value_short**h]hhw_value_short}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubhK are only for driver use when pointers to this structure are passed around.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhhhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ieee80211_sta_ht_cap (C struct)c.ieee80211_sta_ht_caphNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hieee80211_sta_ht_caph]jo)}(hstruct ieee80211_sta_ht_caph](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM"ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM"ubj)}(hieee80211_sta_ht_caph]j)}(hjh]hieee80211_sta_ht_cap}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM"ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM"ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM"hjhhubj)}(hhh]h)}(hSTA's HT capabilitiesh]hSTA’s HT capabilities}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMQhj+hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM"ubeh}(h]h ](j$structeh"]h$]h&]jj$jjFjjFjjjuh1jchhhhhNhNubj)}(hX**Definition**:: struct ieee80211_sta_ht_cap { u16 cap; bool ht_supported; u8 ampdu_factor; u8 ampdu_density; struct ieee80211_mcs_info mcs; }; **Members** ``cap`` HT capabilities map as described in 802.11n spec ``ht_supported`` is HT supported by the STA ``ampdu_factor`` Maximum A-MPDU length factor ``ampdu_density`` Minimum A-MPDU spacing ``mcs`` Supported MCS ratesh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjNubh:}(hjNhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMUhjJubj( )}(hstruct ieee80211_sta_ht_cap { u16 cap; bool ht_supported; u8 ampdu_factor; u8 ampdu_density; struct ieee80211_mcs_info mcs; };h]hstruct ieee80211_sta_ht_cap { u16 cap; bool ht_supported; u8 ampdu_factor; u8 ampdu_density; struct ieee80211_mcs_info mcs; };}hjksbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMWhjJubh)}(h **Members**h]j)}(hj|h]hMembers}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM_hjJubj)}(hhh](j)}(h9``cap`` HT capabilities map as described in 802.11n spec h](j)}(h``cap``h]j)}(hjh]hcap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMXhjubj6)}(hhh]h)}(h0HT capabilities map as described in 802.11n spech]h0HT capabilities map as described in 802.11n spec}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMXhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMXhjubj)}(h,``ht_supported`` is HT supported by the STA h](j)}(h``ht_supported``h]j)}(hjh]h ht_supported}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMWhjubj6)}(hhh]h)}(his HT supported by the STAh]his HT supported by the STA}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMWhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMWhjubj)}(h.``ampdu_factor`` Maximum A-MPDU length factor h](j)}(h``ampdu_factor``h]j)}(hj h]h ampdu_factor}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMYhjubj6)}(hhh]h)}(hMaximum A-MPDU length factorh]hMaximum A-MPDU length factor}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hMYhj#ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj"hMYhjubj)}(h)``ampdu_density`` Minimum A-MPDU spacing h](j)}(h``ampdu_density``h]j)}(hjFh]h ampdu_density}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMZhj@ubj6)}(hhh]h)}(hMinimum A-MPDU spacingh]hMinimum A-MPDU spacing}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hMZhj\ubah}(h]h ]h"]h$]h&]uh1j5hj@ubeh}(h]h ]h"]h$]h&]uh1jhj[hMZhjubj)}(h``mcs`` Supported MCS ratesh](j)}(h``mcs``h]j)}(hjh]hmcs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMZhjyubj6)}(hhh]h)}(hSupported MCS ratesh]hSupported MCS rates}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM[hjubah}(h]h ]h"]h$]h&]uh1j5hjyubeh}(h]h ]h"]h$]h&]uh1jhjhMZhjubeh}(h]h ]h"]h$]h&]uh1jhjJubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM^hhhhubh)}(hiThis structure describes most essential parameters needed to describe 802.11n HT capabilities for an STA.h]hiThis structure describes most essential parameters needed to describe 802.11n HT capabilities for an STA.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMRhhhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_#ieee80211_supported_band (C struct)c.ieee80211_supported_bandhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hieee80211_supported_bandh]jo)}(hstruct ieee80211_supported_bandh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMXubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhj hMXubj)}(hieee80211_supported_bandh]j)}(hjh]hieee80211_supported_band}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhj hMXubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhj hMXubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhj hMXhjhhubj)}(hhh]h)}(hfrequency band definitionh]hfrequency band definition}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM"hj?hhubah}(h]h ]h"]h$]h&]uh1jhjhhhj hMXubeh}(h]h ](j$structeh"]h$]h&]jj$jjZjjZjjjuh1jchhhhhNhNubj)}(hXS**Definition**:: struct ieee80211_supported_band { struct ieee80211_channel *channels; struct ieee80211_rate *bitrates; enum nl80211_band band; int n_channels; int n_bitrates; struct ieee80211_sta_ht_cap ht_cap; struct ieee80211_sta_vht_cap vht_cap; struct ieee80211_sta_s1g_cap s1g_cap; struct ieee80211_edmg edmg_cap; u16 n_iftype_data; const struct ieee80211_sband_iftype_data __iftd *iftype_data; }; **Members** ``channels`` Array of channels the hardware can operate with in this band. ``bitrates`` Array of bitrates the hardware can operate with in this band. Must be sorted to give a valid "supported rates" IE, i.e. CCK rates first, then OFDM. ``band`` the band this structure represents ``n_channels`` Number of channels in **channels** ``n_bitrates`` Number of bitrates in **bitrates** ``ht_cap`` HT capabilities in this band ``vht_cap`` VHT capabilities in this band ``s1g_cap`` S1G capabilities in this band (S1B band only, of course) ``edmg_cap`` EDMG capabilities in this band ``n_iftype_data`` number of iftype data entries ``iftype_data`` interface type data entries. Note that the bits in **types_mask** inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_data).h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbubh:}(hjbhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM&hj^ubj( )}(hXstruct ieee80211_supported_band { struct ieee80211_channel *channels; struct ieee80211_rate *bitrates; enum nl80211_band band; int n_channels; int n_bitrates; struct ieee80211_sta_ht_cap ht_cap; struct ieee80211_sta_vht_cap vht_cap; struct ieee80211_sta_s1g_cap s1g_cap; struct ieee80211_edmg edmg_cap; u16 n_iftype_data; const struct ieee80211_sband_iftype_data __iftd *iftype_data; };h]hXstruct ieee80211_supported_band { struct ieee80211_channel *channels; struct ieee80211_rate *bitrates; enum nl80211_band band; int n_channels; int n_bitrates; struct ieee80211_sta_ht_cap ht_cap; struct ieee80211_sta_vht_cap vht_cap; struct ieee80211_sta_s1g_cap s1g_cap; struct ieee80211_edmg edmg_cap; u16 n_iftype_data; const struct ieee80211_sband_iftype_data __iftd *iftype_data; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM(hj^ubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM6hj^ubj)}(hhh](j)}(hK``channels`` Array of channels the hardware can operate with in this band. h](j)}(h ``channels``h]j)}(hjh]hchannels}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM)hjubj6)}(hhh]h)}(h=Array of channels the hardware can operate with in this band.h]h=Array of channels the hardware can operate with in this band.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM(hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM)hjubj)}(h``bitrates`` Array of bitrates the hardware can operate with in this band. Must be sorted to give a valid "supported rates" IE, i.e. CCK rates first, then OFDM. h](j)}(h ``bitrates``h]j)}(hjh]hbitrates}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM.hjubj6)}(hhh]h)}(hArray of bitrates the hardware can operate with in this band. Must be sorted to give a valid "supported rates" IE, i.e. CCK rates first, then OFDM.h]hArray of bitrates the hardware can operate with in this band. Must be sorted to give a valid “supported rates” IE, i.e. CCK rates first, then OFDM.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM,hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM.hjubj)}(h,``band`` the band this structure represents h](j)}(h``band``h]j)}(hj#h]hband}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM*hjubj6)}(hhh]h)}(h"the band this structure representsh]h"the band this structure represents}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8hM*hj9ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj8hM*hjubj)}(h2``n_channels`` Number of channels in **channels** h](j)}(h``n_channels``h]j)}(hj\h]h n_channels}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM+hjVubj6)}(hhh]h)}(h"Number of channels in **channels**h](hNumber of channels in }(hjuhhhNhNubj)}(h **channels**h]hchannels}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuubeh}(h]h ]h"]h$]h&]uh1hhjqhM+hjrubah}(h]h ]h"]h$]h&]uh1j5hjVubeh}(h]h ]h"]h$]h&]uh1jhjqhM+hjubj)}(h2``n_bitrates`` Number of bitrates in **bitrates** h](j)}(h``n_bitrates``h]j)}(hjh]h n_bitrates}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM/hjubj6)}(hhh]h)}(h"Number of bitrates in **bitrates**h](hNumber of bitrates in }(hjhhhNhNubj)}(h **bitrates**h]hbitrates}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubeh}(h]h ]h"]h$]h&]uh1hhjhM/hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM/hjubj)}(h(``ht_cap`` HT capabilities in this band h](j)}(h ``ht_cap``h]j)}(hjh]hht_cap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM0hjubj6)}(hhh]h)}(hHT capabilities in this bandh]hHT capabilities in this band}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM0hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM0hjubj)}(h*``vht_cap`` VHT capabilities in this band h](j)}(h ``vht_cap``h]j)}(hj#h]hvht_cap}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM1hjubj6)}(hhh]h)}(hVHT capabilities in this bandh]hVHT capabilities in this band}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8hM1hj9ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj8hM1hjubj)}(hE``s1g_cap`` S1G capabilities in this band (S1B band only, of course) h](j)}(h ``s1g_cap``h]j)}(hj\h]hs1g_cap}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM4hjVubj6)}(hhh]h)}(h8S1G capabilities in this band (S1B band only, of course)h]h8S1G capabilities in this band (S1B band only, of course)}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjqhM4hjrubah}(h]h ]h"]h$]h&]uh1j5hjVubeh}(h]h ]h"]h$]h&]uh1jhjqhM4hjubj)}(h,``edmg_cap`` EDMG capabilities in this band h](j)}(h ``edmg_cap``h]j)}(hjh]hedmg_cap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM3hjubj6)}(hhh]h)}(hEDMG capabilities in this bandh]hEDMG capabilities in this band}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM3hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM3hjubj)}(h0``n_iftype_data`` number of iftype data entries h](j)}(h``n_iftype_data``h]j)}(hjh]h n_iftype_data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM5hjubj6)}(hhh]h)}(hnumber of iftype data entriesh]hnumber of iftype data entries}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM5hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM5hjubj)}(h``iftype_data`` interface type data entries. Note that the bits in **types_mask** inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_data).h](j)}(h``iftype_data``h]j)}(hjh]h iftype_data}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM8hjubj6)}(hhh]h)}(hinterface type data entries. Note that the bits in **types_mask** inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_data).h](h4interface type data entries. Note that the bits in }(hj hhhNhNubj)}(h**types_mask**h]h types_mask}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubh} inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_data).}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM6hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM8hjubeh}(h]h ]h"]h$]h&]uh1jhj^ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hj\h]h Description}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM<hhhhubh)}(hHThis structure describes a frequency band a wiphy is able to operate in.h]hHThis structure describes a frequency band a wiphy is able to operate in.}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM#hhhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_&wiphy_read_of_freq_limits (C function)c.wiphy_read_of_freq_limitshNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(h4void wiphy_read_of_freq_limits (struct wiphy *wiphy)h]jo)}(h3void wiphy_read_of_freq_limits(struct wiphy *wiphy)h](hdesc_sig_keyword_type)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]ktah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubj)}(hwiphy_read_of_freq_limitsh]j)}(hwiphy_read_of_freq_limitsh]hwiphy_read_of_freq_limits}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMubhdesc_parameterlist)}(h(struct wiphy *wiphy)h]hdesc_parameter)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftype identifier reftargetjmodnameN classnameNj j )}j ]j ASTIdentifier)}jjsbc.wiphy_read_of_freq_limitsasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubhdesc_sig_punctuation)}(h*h]h*}(hj/hhhNhNubah}(h]h ]pah"]h$]h&]uh1j-hjubj)}(hwiphyh]hwiphy}(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMhjhhubj)}(hhh]h)}(h&read frequency limits from device treeh]h&read frequency limits from device tree}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjehhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhhhNhNubj)}(hX:**Parameters** ``struct wiphy *wiphy`` the wireless device to get extra limits for **Description** Some devices may have extra limitations specified in DT. This may be useful for chipsets that normally support more bands but are limited due to board design (e.g. by antennas or external power amplifier). This function reads info from DT and uses it to *modify* channels (disable unavailable ones). It's usually a *bad* idea to use it in drivers with shared channel data as DT limitations are device specific. You should make sure to call it only if channels in wiphy are copied and can be modified without affecting other devices. As this function access device node it has to be called after set_wiphy_dev. It also modifies channels so they have to be set first. If using this helper, call it before wiphy_register().h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj)}(hhh]j)}(hD``struct wiphy *wiphy`` the wireless device to get extra limits for h](j)}(h``struct wiphy *wiphy``h]j)}(hjh]hstruct wiphy *wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h+the wireless device to get extra limits forh]h+the wireless device to get extra limits for}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubh)}(hSome devices may have extra limitations specified in DT. This may be useful for chipsets that normally support more bands but are limited due to board design (e.g. by antennas or external power amplifier).h]hSome devices may have extra limitations specified in DT. This may be useful for chipsets that normally support more bands but are limited due to board design (e.g. by antennas or external power amplifier).}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubh)}(hXFThis function reads info from DT and uses it to *modify* channels (disable unavailable ones). It's usually a *bad* idea to use it in drivers with shared channel data as DT limitations are device specific. You should make sure to call it only if channels in wiphy are copied and can be modified without affecting other devices.h](h0This function reads info from DT and uses it to }(hj hhhNhNubhemphasis)}(h*modify*h]hmodify}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh7 channels (disable unavailable ones). It’s usually a }(hj hhhNhNubj)}(h*bad*h]hbad}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh idea to use it in drivers with shared channel data as DT limitations are device specific. You should make sure to call it only if channels in wiphy are copied and can be modified without affecting other devices.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubh)}(hAs this function access device node it has to be called after set_wiphy_dev. It also modifies channels so they have to be set first. If using this helper, call it before wiphy_register().h]hAs this function access device node it has to be called after set_wiphy_dev. It also modifies channels so they have to be set first. If using this helper, call it before wiphy_register().}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_signal_type (C enum)c.cfg80211_signal_typehNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hcfg80211_signal_typeh]jo)}(henum cfg80211_signal_typeh](ju)}(hjxh]henum}(hjmhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjihhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjihhhjzhMubj)}(hcfg80211_signal_typeh]j)}(hjgh]hcfg80211_signal_type}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjihhhjzhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjehhhjzhMubah}(h]j`ah ](jjeh"]h$]h&]jj)jhuh1jhhjzhMhjbhhubj)}(hhh]h)}(h signal typeh]h signal type}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM/ hjhhubah}(h]h ]h"]h$]h&]uh1jhjbhhhjzhMubeh}(h]h ](j$enumeh"]h$]h&]jj$jjjjjjjuh1jchhhhhNhNubj)}(h**Constants** ``CFG80211_SIGNAL_TYPE_NONE`` no signal strength information available ``CFG80211_SIGNAL_TYPE_MBM`` signal strength in mBm (100*dBm) ``CFG80211_SIGNAL_TYPE_UNSPEC`` signal strength, increasing from 0 through 100h](h)}(h **Constants**h]j)}(hjh]h Constants}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM3 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.hhM6 hjubj6)}(hhh]h)}(h(no signal strength information availableh]h(no signal strength information available}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM6 hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM6 hjubj)}(h>``CFG80211_SIGNAL_TYPE_MBM`` signal strength in mBm (100*dBm) h](j)}(h``CFG80211_SIGNAL_TYPE_MBM``h]j)}(hj)h]hCFG80211_SIGNAL_TYPE_MBM}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM9 hj#ubj6)}(hhh]h)}(h signal strength in mBm (100*dBm)h]h signal strength in mBm (100*dBm)}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hM9 hj?ubah}(h]h ]h"]h$]h&]uh1j5hj#ubeh}(h]h ]h"]h$]h&]uh1jhj>hM9 hjubj)}(hN``CFG80211_SIGNAL_TYPE_UNSPEC`` signal strength, increasing from 0 through 100h](j)}(h``CFG80211_SIGNAL_TYPE_UNSPEC``h]j)}(hjbh]hCFG80211_SIGNAL_TYPE_UNSPEC}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM; hj\ubj6)}(hhh]h)}(h.signal strength, increasing from 0 through 100h]h.signal strength, increasing from 0 through 100}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM< hjxubah}(h]h ]h"]h$]h&]uh1j5hj\ubeh}(h]h ]h"]h$]h&]uh1jhjwhM; hjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wiphy_params_flags (C enum)c.wiphy_params_flagshNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hwiphy_params_flagsh]jo)}(henum wiphy_params_flagsh](ju)}(hjxh]henum}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(hwiphy_params_flagsh]j)}(hjh]hwiphy_params_flags}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM hjhhubj)}(hhh]h)}(h set_wiphy_params bitfield valuesh]h set_wiphy_params bitfield values}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMo hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j$enumeh"]h$]h&]jj$jjjjjjjuh1jchhhhhNhNubj)}(hX3**Constants** ``WIPHY_PARAM_RETRY_SHORT`` wiphy->retry_short has changed ``WIPHY_PARAM_RETRY_LONG`` wiphy->retry_long has changed ``WIPHY_PARAM_FRAG_THRESHOLD`` wiphy->frag_threshold has changed ``WIPHY_PARAM_RTS_THRESHOLD`` wiphy->rts_threshold has changed ``WIPHY_PARAM_COVERAGE_CLASS`` coverage class changed ``WIPHY_PARAM_DYN_ACK`` dynack has been enabled ``WIPHY_PARAM_TXQ_LIMIT`` TXQ packet limit has been changed ``WIPHY_PARAM_TXQ_MEMORY_LIMIT`` TXQ memory limit has been changed ``WIPHY_PARAM_TXQ_QUANTUM`` TXQ scheduler quantumh](h)}(h **Constants**h]j)}(hj h]h Constants}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMs hjubj)}(hhh](j)}(h;``WIPHY_PARAM_RETRY_SHORT`` wiphy->retry_short has changed h](j)}(h``WIPHY_PARAM_RETRY_SHORT``h]j)}(hj?h]hWIPHY_PARAM_RETRY_SHORT}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMv hj9ubj6)}(hhh]h)}(hwiphy->retry_short has changedh]hwiphy->retry_short has changed}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjThMv hjUubah}(h]h ]h"]h$]h&]uh1j5hj9ubeh}(h]h ]h"]h$]h&]uh1jhjThMv hj6ubj)}(h9``WIPHY_PARAM_RETRY_LONG`` wiphy->retry_long has changed h](j)}(h``WIPHY_PARAM_RETRY_LONG``h]j)}(hjxh]hWIPHY_PARAM_RETRY_LONG}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMy hjrubj6)}(hhh]h)}(hwiphy->retry_long has changedh]hwiphy->retry_long has changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMy hjubah}(h]h ]h"]h$]h&]uh1j5hjrubeh}(h]h ]h"]h$]h&]uh1jhjhMy hj6ubj)}(hA``WIPHY_PARAM_FRAG_THRESHOLD`` wiphy->frag_threshold has changed h](j)}(h``WIPHY_PARAM_FRAG_THRESHOLD``h]j)}(hjh]hWIPHY_PARAM_FRAG_THRESHOLD}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM| hjubj6)}(hhh]h)}(h!wiphy->frag_threshold has changedh]h!wiphy->frag_threshold has changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM| hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM| hj6ubj)}(h?``WIPHY_PARAM_RTS_THRESHOLD`` wiphy->rts_threshold has changed h](j)}(h``WIPHY_PARAM_RTS_THRESHOLD``h]j)}(hjh]hWIPHY_PARAM_RTS_THRESHOLD}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h wiphy->rts_threshold has changedh]h wiphy->rts_threshold has changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj6ubj)}(h6``WIPHY_PARAM_COVERAGE_CLASS`` coverage class changed h](j)}(h``WIPHY_PARAM_COVERAGE_CLASS``h]j)}(hj#h]hWIPHY_PARAM_COVERAGE_CLASS}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hcoverage class changedh]hcoverage class changed}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8hM hj9ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj8hM hj6ubj)}(h0``WIPHY_PARAM_DYN_ACK`` dynack has been enabled h](j)}(h``WIPHY_PARAM_DYN_ACK``h]j)}(hj\h]hWIPHY_PARAM_DYN_ACK}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjVubj6)}(hhh]h)}(hdynack has been enabledh]hdynack has been enabled}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjqhM hjrubah}(h]h ]h"]h$]h&]uh1j5hjVubeh}(h]h ]h"]h$]h&]uh1jhjqhM hj6ubj)}(h<``WIPHY_PARAM_TXQ_LIMIT`` TXQ packet limit has been changed h](j)}(h``WIPHY_PARAM_TXQ_LIMIT``h]j)}(hjh]hWIPHY_PARAM_TXQ_LIMIT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h!TXQ packet limit has been changedh]h!TXQ packet limit has been changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj6ubj)}(hC``WIPHY_PARAM_TXQ_MEMORY_LIMIT`` TXQ memory limit has been changed h](j)}(h ``WIPHY_PARAM_TXQ_MEMORY_LIMIT``h]j)}(hjh]hWIPHY_PARAM_TXQ_MEMORY_LIMIT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h!TXQ memory limit has been changedh]h!TXQ memory limit has been changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj6ubj)}(h1``WIPHY_PARAM_TXQ_QUANTUM`` TXQ scheduler quantumh](j)}(h``WIPHY_PARAM_TXQ_QUANTUM``h]j)}(hjh]hWIPHY_PARAM_TXQ_QUANTUM}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hTXQ scheduler quantumh]hTXQ scheduler quantum}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj6ubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wiphy_flags (C enum) c.wiphy_flagshNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(h wiphy_flagsh]jo)}(henum wiphy_flagsh](ju)}(hjxh]henum}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj]hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]hhhjnhM ubj)}(h wiphy_flagsh]j)}(hj[h]h wiphy_flags}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj]hhhjnhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjYhhhjnhM ubah}(h]jTah ](jjeh"]h$]h&]jj)jhuh1jhhjnhM hjVhhubj)}(hhh]h)}(hwiphy capability flagsh]hwiphy capability flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjVhhhjnhM ubeh}(h]h ](j$enumeh"]h$]h&]jj$jjjjjjjuh1jchhhhhNhNubj)}(hX **Constants** ``WIPHY_FLAG_SUPPORTS_EXT_KEK_KCK`` The device supports bigger kek and kck keys ``WIPHY_FLAG_SUPPORTS_MLO`` This is a temporary flag gating the MLO APIs, in order to not have them reachable in normal drivers, until we have complete feature/interface combinations/etc. advertisement. No driver should set this flag for now. ``WIPHY_FLAG_SPLIT_SCAN_6GHZ`` if set to true, the scan request will be split into two, first for legacy bands and second for 6 GHz. ``WIPHY_FLAG_NETNS_OK`` if not set, do not allow changing the netns of this wiphy at all ``WIPHY_FLAG_PS_ON_BY_DEFAULT`` if set to true, powersave will be enabled by default -- this flag will be set depending on the kernel's default on wiphy_new(), but can be changed by the driver if it has a good reason to override the default ``WIPHY_FLAG_4ADDR_AP`` supports 4addr mode even on AP (with a single station on a VLAN interface). This flag also serves an extra purpose of supporting 4ADDR AP mode on devices which do not support AP/VLAN iftype. ``WIPHY_FLAG_4ADDR_STATION`` supports 4addr mode even as a station ``WIPHY_FLAG_CONTROL_PORT_PROTOCOL`` This device supports setting the control port protocol ethertype. The device also honours the control_port_no_encrypt flag. ``WIPHY_FLAG_IBSS_RSN`` The device supports IBSS RSN. ``WIPHY_FLAG_DISABLE_WEXT`` disable wireless extensions for this device ``WIPHY_FLAG_MESH_AUTH`` The device supports mesh authentication by routing auth frames to userspace. See **NL80211_MESH_SETUP_USERSPACE_AUTH**. ``WIPHY_FLAG_SUPPORTS_EXT_KCK_32`` The device supports 32-byte KCK keys. ``WIPHY_FLAG_SUPPORTS_NSTR_NONPRIMARY`` support connection to non-primary link of an NSTR mobile AP MLD. ``WIPHY_FLAG_SUPPORTS_FW_ROAM`` The device supports roaming feature in the firmware. ``WIPHY_FLAG_AP_UAPSD`` The device supports uapsd on AP. ``WIPHY_FLAG_SUPPORTS_TDLS`` The device supports TDLS (802.11z) operation. ``WIPHY_FLAG_TDLS_EXTERNAL_SETUP`` The device does not handle TDLS (802.11z) link setup/discovery operations internally. Setup, discovery and teardown packets should be sent through the **NL80211_CMD_TDLS_MGMT** command. When this flag is not set, **NL80211_CMD_TDLS_OPER** should be used for asking the driver/firmware to perform a TDLS operation. ``WIPHY_FLAG_HAVE_AP_SME`` device integrates AP SME ``WIPHY_FLAG_REPORTS_OBSS`` the device will report beacons from other BSSes when there are virtual interfaces in AP mode by calling cfg80211_report_obss_beacon(). ``WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD`` When operating as an AP, the device responds to probe-requests in hardware. ``WIPHY_FLAG_OFFCHAN_TX`` Device supports direct off-channel TX. ``WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL`` Device supports remain-on-channel call. ``WIPHY_FLAG_SUPPORTS_5_10_MHZ`` Device supports 5 MHz and 10 MHz channels. ``WIPHY_FLAG_HAS_CHANNEL_SWITCH`` Device supports channel switch in beaconing mode (AP, IBSS, Mesh, ...). ``WIPHY_FLAG_NOTIFY_REGDOM_BY_DRIVER`` The device could handle reg notify for NL80211_REGDOM_SET_BY_DRIVER. ``WIPHY_FLAG_CHANNEL_CHANGE_ON_BEACON`` reg_call_notifier() is called if driver set this flag to update channels on beacon hints.h](h)}(h **Constants**h]j)}(hjh]h Constants}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj)}(hhh](j)}(hP``WIPHY_FLAG_SUPPORTS_EXT_KEK_KCK`` The device supports bigger kek and kck keys h](j)}(h#``WIPHY_FLAG_SUPPORTS_EXT_KEK_KCK``h]j)}(hjh]hWIPHY_FLAG_SUPPORTS_EXT_KEK_KCK}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h+The device supports bigger kek and kck keysh]h+The device supports bigger kek and kck keys}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``WIPHY_FLAG_SUPPORTS_MLO`` This is a temporary flag gating the MLO APIs, in order to not have them reachable in normal drivers, until we have complete feature/interface combinations/etc. advertisement. No driver should set this flag for now. h](j)}(h``WIPHY_FLAG_SUPPORTS_MLO``h]j)}(hjh]hWIPHY_FLAG_SUPPORTS_MLO}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hThis is a temporary flag gating the MLO APIs, in order to not have them reachable in normal drivers, until we have complete feature/interface combinations/etc. advertisement. No driver should set this flag for now.h]hThis is a temporary flag gating the MLO APIs, in order to not have them reachable in normal drivers, until we have complete feature/interface combinations/etc. advertisement. No driver should set this flag for now.}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj3ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj2hMhjubj)}(h``WIPHY_FLAG_SPLIT_SCAN_6GHZ`` if set to true, the scan request will be split into two, first for legacy bands and second for 6 GHz. h](j)}(h``WIPHY_FLAG_SPLIT_SCAN_6GHZ``h]j)}(hjWh]hWIPHY_FLAG_SPLIT_SCAN_6GHZ}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjQubj6)}(hhh]h)}(heif set to true, the scan request will be split into two, first for legacy bands and second for 6 GHz.h]heif set to true, the scan request will be split into two, first for legacy bands and second for 6 GHz.}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjmubah}(h]h ]h"]h$]h&]uh1j5hjQubeh}(h]h ]h"]h$]h&]uh1jhjlhMhjubj)}(hY``WIPHY_FLAG_NETNS_OK`` if not set, do not allow changing the netns of this wiphy at all h](j)}(h``WIPHY_FLAG_NETNS_OK``h]j)}(hjh]hWIPHY_FLAG_NETNS_OK}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h@if not set, do not allow changing the netns of this wiphy at allh]h@if not set, do not allow changing the netns of this wiphy at all}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``WIPHY_FLAG_PS_ON_BY_DEFAULT`` if set to true, powersave will be enabled by default -- this flag will be set depending on the kernel's default on wiphy_new(), but can be changed by the driver if it has a good reason to override the default h](j)}(h``WIPHY_FLAG_PS_ON_BY_DEFAULT``h]j)}(hjh]hWIPHY_FLAG_PS_ON_BY_DEFAULT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hif set to true, powersave will be enabled by default -- this flag will be set depending on the kernel's default on wiphy_new(), but can be changed by the driver if it has a good reason to override the defaulth]hif set to true, powersave will be enabled by default -- this flag will be set depending on the kernel’s default on wiphy_new(), but can be changed by the driver if it has a good reason to override the default}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``WIPHY_FLAG_4ADDR_AP`` supports 4addr mode even on AP (with a single station on a VLAN interface). This flag also serves an extra purpose of supporting 4ADDR AP mode on devices which do not support AP/VLAN iftype. h](j)}(h``WIPHY_FLAG_4ADDR_AP``h]j)}(hjh]hWIPHY_FLAG_4ADDR_AP}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hsupports 4addr mode even on AP (with a single station on a VLAN interface). This flag also serves an extra purpose of supporting 4ADDR AP mode on devices which do not support AP/VLAN iftype.h]hsupports 4addr mode even on AP (with a single station on a VLAN interface). This flag also serves an extra purpose of supporting 4ADDR AP mode on devices which do not support AP/VLAN iftype.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hC``WIPHY_FLAG_4ADDR_STATION`` supports 4addr mode even as a station h](j)}(h``WIPHY_FLAG_4ADDR_STATION``h]j)}(hj?h]hWIPHY_FLAG_4ADDR_STATION}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj9ubj6)}(hhh]h)}(h%supports 4addr mode even as a stationh]h%supports 4addr mode even as a station}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjThMhjUubah}(h]h ]h"]h$]h&]uh1j5hj9ubeh}(h]h ]h"]h$]h&]uh1jhjThMhjubj)}(h``WIPHY_FLAG_CONTROL_PORT_PROTOCOL`` This device supports setting the control port protocol ethertype. The device also honours the control_port_no_encrypt flag. h](j)}(h$``WIPHY_FLAG_CONTROL_PORT_PROTOCOL``h]j)}(hjxh]h WIPHY_FLAG_CONTROL_PORT_PROTOCOL}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjrubj6)}(hhh]h)}(h{This device supports setting the control port protocol ethertype. The device also honours the control_port_no_encrypt flag.h]h{This device supports setting the control port protocol ethertype. The device also honours the control_port_no_encrypt flag.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjrubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h6``WIPHY_FLAG_IBSS_RSN`` The device supports IBSS RSN. h](j)}(h``WIPHY_FLAG_IBSS_RSN``h]j)}(hjh]hWIPHY_FLAG_IBSS_RSN}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubj6)}(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&]uh1j5hjubeh}(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}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubj)}(h``WIPHY_FLAG_MESH_AUTH`` The device supports mesh authentication by routing auth frames to userspace. See **NL80211_MESH_SETUP_USERSPACE_AUTH**. h](j)}(h``WIPHY_FLAG_MESH_AUTH``h]j)}(hj$ h]hWIPHY_FLAG_MESH_AUTH}(hj& hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj" ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj ubj6)}(hhh]h)}(hwThe device supports mesh authentication by routing auth frames to userspace. See **NL80211_MESH_SETUP_USERSPACE_AUTH**.h](hQThe device supports mesh authentication by routing auth frames to userspace. See }(hj= hhhNhNubj)}(h%**NL80211_MESH_SETUP_USERSPACE_AUTH**h]h!NL80211_MESH_SETUP_USERSPACE_AUTH}(hjE hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj= ubh.}(hj= hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj: ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj9 hMhjubj)}(hI``WIPHY_FLAG_SUPPORTS_EXT_KCK_32`` The device supports 32-byte KCK keys. h](j)}(h"``WIPHY_FLAG_SUPPORTS_EXT_KCK_32``h]j)}(hjp h]hWIPHY_FLAG_SUPPORTS_EXT_KCK_32}(hjr hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjn ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjj ubj6)}(hhh]h)}(h%The device supports 32-byte KCK keys.h]h%The device supports 32-byte KCK keys.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j5hjj ubeh}(h]h ]h"]h$]h&]uh1jhj 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)}(hj h]h#WIPHY_FLAG_SUPPORTS_NSTR_NONPRIMARY}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj 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&]uh1j5hj 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.}(hj6!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2!hMhj3!ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj2!hMhjubj)}(hK``WIPHY_FLAG_SUPPORTS_TDLS`` The device supports TDLS (802.11z) operation. h](j)}(h``WIPHY_FLAG_SUPPORTS_TDLS``h]j)}(hjV!h]hWIPHY_FLAG_SUPPORTS_TDLS}(hjX!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjT!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjP!ubj6)}(hhh]h)}(h-The device supports TDLS (802.11z) operation.h]h-The device supports TDLS (802.11z) operation.}(hjo!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjk!hMhjl!ubah}(h]h ]h"]h$]h&]uh1j5hjP!ubeh}(h]h ]h"]h$]h&]uh1jhjk!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)}(hj!h]hWIPHY_FLAG_TDLS_EXTERNAL_SETUP}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj!ubj6)}(hhh]h)}(hX9The device does not handle TDLS (802.11z) link setup/discovery operations internally. Setup, discovery and teardown packets should be sent through the **NL80211_CMD_TDLS_MGMT** command. When this flag is not set, **NL80211_CMD_TDLS_OPER** should be used for asking the driver/firmware to perform a TDLS operation.h](hThe device does not handle TDLS (802.11z) link setup/discovery operations internally. Setup, discovery and teardown packets should be sent through the }(hj!hhhNhNubj)}(h**NL80211_CMD_TDLS_MGMT**h]hNL80211_CMD_TDLS_MGMT}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!ubh% command. When this flag is not set, }(hj!hhhNhNubj)}(h**NL80211_CMD_TDLS_OPER**h]hNL80211_CMD_TDLS_OPER}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!ubhK should be used for asking the driver/firmware to perform a TDLS operation.}(hj!hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj!ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj!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}(hjb"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^"ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjZ"ubj6)}(hhh]h)}(hKWhen operating as an AP, the device responds to probe-requests in hardware.h]hKWhen operating as an AP, the device responds to probe-requests in hardware.}(hjy"hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjv"ubah}(h]h ]h"]h$]h&]uh1j5hjZ"ubeh}(h]h ]h"]h$]h&]uh1jhju"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}(hj"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 direct off-channel TX.h]h&Device supports direct off-channel TX.}(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``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)}(hjE#h]hWIPHY_FLAG_HAS_CHANNEL_SWITCH}(hjG#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjC#ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.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&]uh1jhjZ#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)}(hj#h]h"WIPHY_FLAG_NOTIFY_REGDOM_BY_DRIVER}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}#ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjy#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.hhMhj#ubah}(h]h ]h"]h$]h&]uh1j5hjy#ubeh}(h]h ]h"]h$]h&]uh1jhj#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.hhMhj#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&]uh1j5hj#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)}(hjh]hstruct}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj$hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM ubj)}(h h]h }(hj $hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$hhhj$hM ubj)}(hieee80211_iface_limith]j)}(hj $h]hieee80211_iface_limit}(hj2$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.$ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj$hhhj$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 limit on certain interface typesh]h limit on certain interface types}(hjT$hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjQ$hhubah}(h]h ]h"]h$]h&]uh1jhj$hhhj$hM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjl$jjl$jjjuh1jchhhhhNhNubj)}(h**Definition**:: struct ieee80211_iface_limit { u16 max; u16 types; }; **Members** ``max`` maximum number of interfaces of these types ``types`` interface types (bits)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjx$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjt$ubh:}(hjt$hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjp$ubj( )}(h=struct ieee80211_iface_limit { u16 max; u16 types; };h]h=struct ieee80211_iface_limit { u16 max; u16 types; };}hj$sbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjp$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.hhMhjp$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&]uh1jhjp$ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_&ieee80211_iface_combination (C struct)c.ieee80211_iface_combinationhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hieee80211_iface_combinationh]jo)}(h"struct ieee80211_iface_combinationh](ju)}(hjh]hstruct}(hjT%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjP%hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjb%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjP%hhhja%hMubj)}(hieee80211_iface_combinationh]j)}(hjN%h]hieee80211_iface_combination}(hjt%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjp%ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjP%hhhja%hMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjL%hhhja%hMubah}(h]jG%ah ](jjeh"]h$]h&]jj)jhuh1jhhja%hMhjI%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.hhMhj%hhubah}(h]h ]h"]h$]h&]uh1jhjI%hhhja%hMubeh}(h]h ](j$structeh"]h$]h&]jj$jj%jj%jjjuh1jchhhhhNhNubj)}(hX**Definition**:: struct ieee80211_iface_combination { const struct ieee80211_iface_limit *limits; u32 num_different_channels; u16 max_interfaces; u8 n_limits; bool beacon_int_infra_match; u8 radar_detect_widths; u8 radar_detect_regions; u32 beacon_int_min_gcd; }; **Members** ``limits`` limits for the given interface types ``num_different_channels`` can use up to this many different channels ``max_interfaces`` maximum number of interfaces in total allowed in this group ``n_limits`` number of limitations ``beacon_int_infra_match`` In this combination, the beacon intervals between infrastructure and AP types must match. This is required only in special cases. ``radar_detect_widths`` bitmap of channel widths supported for radar detection ``radar_detect_regions`` bitmap of regions supported for radar detection ``beacon_int_min_gcd`` This interface combination supports different beacon intervals. = 0 all beacon intervals for different interface must be same. > 0 any beacon interval for the interface part of this combination AND GCD of all beacon intervals from beaconing interfaces of this combination must be greater or equal to this value.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%ubh:}(hj%hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj%ubj( )}(hXstruct ieee80211_iface_combination { const struct ieee80211_iface_limit *limits; u32 num_different_channels; u16 max_interfaces; u8 n_limits; bool beacon_int_infra_match; u8 radar_detect_widths; u8 radar_detect_regions; u32 beacon_int_min_gcd; };h]hXstruct ieee80211_iface_combination { const struct ieee80211_iface_limit *limits; u32 num_different_channels; u16 max_interfaces; u8 n_limits; bool beacon_int_infra_match; u8 radar_detect_widths; u8 radar_detect_regions; u32 beacon_int_min_gcd; };}hj%sbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj%ubh)}(h **Members**h]j)}(hj%h]hMembers}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj%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.hhM5hj%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&hM5hj&ubah}(h]h ]h"]h$]h&]uh1j5hj%ubeh}(h]h ]h"]h$]h&]uh1jhj&hM5hj%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.hhM;hj6&ubj6)}(hhh]h)}(h*can use up to this many different channelsh]h*can use up to this many different channels}(hjU&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQ&hM;hjR&ubah}(h]h ]h"]h$]h&]uh1j5hj6&ubeh}(h]h ]h"]h$]h&]uh1jhjQ&hM;hj%ubj)}(hO``max_interfaces`` maximum number of interfaces in total allowed in this group h](j)}(h``max_interfaces``h]j)}(hju&h]hmax_interfaces}(hjw&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjs&ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMAhjo&ubj6)}(hhh]h)}(h;maximum number of interfaces in total allowed in this grouph]h;maximum number of interfaces in total allowed in this group}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&hMAhj&ubah}(h]h ]h"]h$]h&]uh1j5hjo&ubeh}(h]h ]h"]h$]h&]uh1jhj&hMAhj%ubj)}(h#``n_limits`` number of limitations h](j)}(h ``n_limits``h]j)}(hj&h]hn_limits}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMGhj&ubj6)}(hhh]h)}(hnumber of limitationsh]hnumber of limitations}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&hMGhj&ubah}(h]h ]h"]h$]h&]uh1j5hj&ubeh}(h]h ]h"]h$]h&]uh1jhj&hMGhj%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.hhMNhj&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.hhMMhj&ubah}(h]h ]h"]h$]h&]uh1j5hj&ubeh}(h]h ]h"]h$]h&]uh1jhj&hMNhj%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.hhMThj'ubj6)}(hhh]h)}(h6bitmap of channel widths supported for radar detectionh]h6bitmap of channel widths supported for radar detection}(hj:'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6'hMThj7'ubah}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhj6'hMThj%ubj)}(hI``radar_detect_regions`` bitmap of regions supported for radar detection h](j)}(h``radar_detect_regions``h]j)}(hjZ'h]hradar_detect_regions}(hj\'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjX'ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMZhjT'ubj6)}(hhh]h)}(h/bitmap of regions supported for radar detectionh]h/bitmap of regions supported for radar detection}(hjs'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjo'hMZhjp'ubah}(h]h ]h"]h$]h&]uh1j5hjT'ubeh}(h]h ]h"]h$]h&]uh1jhjo'hMZhj%ubj)}(hXW``beacon_int_min_gcd`` This interface combination supports different beacon intervals. = 0 all beacon intervals for different interface must be same. > 0 any beacon interval for the interface part of this combination AND GCD of all beacon intervals from beaconing interfaces of this combination must be greater or equal to this value.h](j)}(h``beacon_int_min_gcd``h]j)}(hj'h]hbeacon_int_min_gcd}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMfhj'ubj6)}(hhh](h)}(h?This interface combination supports different beacon intervals.h]h?This interface combination supports different beacon intervals.}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM`hj'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.hhMbhj'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.hhMchj'ubah}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'hMbhj'ubj)}(h> 0 any beacon interval for the interface part of this combination AND GCD of all beacon intervals from beaconing interfaces of this combination must be greater or equal to this value.h](j)}(h> 0h]h> 0}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'hMfhj'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.hhMehj(ubah}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'hMfhj'ubeh}(h]h ]h"]h$]h&]uh1jhj'ubeh}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'hMfhj%ubeh}(h]h ]h"]h$]h&]uh1jhj%ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hj@(h]h Description}(hjB(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>(ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMjhhhhubh)}(hWith this structure the driver can describe which interface combinations it supports concurrently. When set in a struct wiphy_radio, the combinations refer to combinations of interfaces currently active on that radio.h]hWith this structure the driver can describe which interface combinations it supports concurrently. When set in a struct wiphy_radio, the combinations refer to combinations of interfaces currently active on that radio.}(hjV(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.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:}(hjp(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjl(ubj( )}(hXbstruct ieee80211_iface_limit limits1[] = { { .max = 1, .types = BIT(NL80211_IFTYPE_STATION), }, { .max = 1, .types = BIT(NL80211_IFTYPE_AP), }, }; struct ieee80211_iface_combination combination1 = { .limits = limits1, .n_limits = ARRAY_SIZE(limits1), .max_interfaces = 2, .beacon_int_infra_match = true, };h]hXbstruct ieee80211_iface_limit limits1[] = { { .max = 1, .types = BIT(NL80211_IFTYPE_STATION), }, { .max = 1, .types = BIT(NL80211_IFTYPE_AP), }, }; struct ieee80211_iface_combination combination1 = { .limits = limits1, .n_limits = ARRAY_SIZE(limits1), .max_interfaces = 2, .beacon_int_infra_match = true, };}hj(sbah}(h]h ]h"]h$]h&]jjforcelanguagej$highlight_args}uh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjl(ubeh}(h]h ]h"]h$]h&]uh1jj(hjg(ubjk()}(hXAllow #{AP, P2P-GO} <= 8, channels = 1, 8 total: .. code-block:: c struct ieee80211_iface_limit limits2[] = { { .max = 8, .types = BIT(NL80211_IFTYPE_AP) | BIT(NL80211_IFTYPE_P2P_GO), }, }; struct ieee80211_iface_combination combination2 = { .limits = limits2, .n_limits = ARRAY_SIZE(limits2), .max_interfaces = 8, .num_different_channels = 1, }; h](h)}(h0Allow #{AP, P2P-GO} <= 8, channels = 1, 8 total:h]h0Allow #{AP, P2P-GO} <= 8, channels = 1, 8 total:}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj(ubj( )}(hX\struct ieee80211_iface_limit limits2[] = { { .max = 8, .types = BIT(NL80211_IFTYPE_AP) | BIT(NL80211_IFTYPE_P2P_GO), }, }; struct ieee80211_iface_combination combination2 = { .limits = limits2, .n_limits = ARRAY_SIZE(limits2), .max_interfaces = 8, .num_different_channels = 1, };h]hX\struct ieee80211_iface_limit limits2[] = { { .max = 8, .types = BIT(NL80211_IFTYPE_AP) | BIT(NL80211_IFTYPE_P2P_GO), }, }; struct ieee80211_iface_combination combination2 = { .limits = limits2, .n_limits = ARRAY_SIZE(limits2), .max_interfaces = 8, .num_different_channels = 1, };}hj(sbah}(h]h ]h"]h$]h&]jjj(j(j$j(}uh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj(ubeh}(h]h ]h"]h$]h&]uh1jj(hjg(ubjk()}(hXZAllow #STA <= 1, #{P2P-client,P2P-GO} <= 3 on two channels, 4 total. This allows for an infrastructure connection and three P2P connections. .. code-block:: c struct ieee80211_iface_limit limits3[] = { { .max = 1, .types = BIT(NL80211_IFTYPE_STATION), }, { .max = 3, .types = BIT(NL80211_IFTYPE_P2P_GO) | BIT(NL80211_IFTYPE_P2P_CLIENT), }, }; struct ieee80211_iface_combination combination3 = { .limits = limits3, .n_limits = ARRAY_SIZE(limits3), .max_interfaces = 4, .num_different_channels = 2, }; h](h)}(hDAllow #STA <= 1, #{P2P-client,P2P-GO} <= 3 on two channels, 4 total.h]hDAllow #STA <= 1, #{P2P-client,P2P-GO} <= 3 on two channels, 4 total.}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj(ubh)}(hGThis allows for an infrastructure connection and three P2P connections.h]hGThis allows for an infrastructure connection and three P2P connections.}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj(ubj( )}(hXstruct ieee80211_iface_limit limits3[] = { { .max = 1, .types = BIT(NL80211_IFTYPE_STATION), }, { .max = 3, .types = BIT(NL80211_IFTYPE_P2P_GO) | BIT(NL80211_IFTYPE_P2P_CLIENT), }, }; struct ieee80211_iface_combination combination3 = { .limits = limits3, .n_limits = ARRAY_SIZE(limits3), .max_interfaces = 4, .num_different_channels = 2, };h]hXstruct ieee80211_iface_limit limits3[] = { { .max = 1, .types = BIT(NL80211_IFTYPE_STATION), }, { .max = 3, .types = BIT(NL80211_IFTYPE_P2P_GO) | BIT(NL80211_IFTYPE_P2P_CLIENT), }, }; struct ieee80211_iface_combination combination3 = { .limits = limits3, .n_limits = ARRAY_SIZE(limits3), .max_interfaces = 4, .num_different_channels = 2, };}hj(sbah}(h]h ]h"]h$]h&]jjj(j(j$j(}uh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj(ubeh}(h]h ]h"]h$]h&]uh1jj(hjg(ubeh}(h]h ]h"]h$]h&]enumtypearabicprefixhsuffix.uh1je(hhhhhNhNubh)}(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.hhM.hhhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wiphy (C struct)c.wiphyhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hwiphyh]jo)}(h struct wiphyh](ju)}(hjh]hstruct}(hj5)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj1)hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM*ubj)}(h h]h }(hjC)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1)hhhjB)hM*ubj)}(hwiphyh]j)}(hj/)h]hwiphy}(hjU)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQ)ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj1)hhhjB)hM*ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj-)hhhjB)hM*ubah}(h]j()ah ](jjeh"]h$]h&]jj)jhuh1jhhjB)hM*hj*)hhubj)}(hhh]h)}(hwireless hardware descriptionh]hwireless hardware description}(hjw)hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjt)hhubah}(h]h ]h"]h$]h&]uh1jhj*)hhhjB)hM*ubeh}(h]h ](j$structeh"]h$]h&]jj$jj)jj)jjjuh1jchhhhhNhNubj)}(hX);**Definition**:: struct wiphy { struct mutex mtx; u8 perm_addr[ETH_ALEN]; u8 addr_mask[ETH_ALEN]; struct mac_address *addresses; const struct ieee80211_txrx_stypes *mgmt_stypes; const struct ieee80211_iface_combination *iface_combinations; int n_iface_combinations; u16 software_iftypes; u16 n_addresses; u16 interface_modes; u16 max_acl_mac_addrs; u32 flags, regulatory_flags, features; u8 ext_features[DIV_ROUND_UP(NUM_NL80211_EXT_FEATURES, 8)]; u32 ap_sme_capa; enum cfg80211_signal_type signal_type; int bss_priv_size; u8 max_scan_ssids; u8 max_sched_scan_reqs; u8 max_sched_scan_ssids; u8 max_match_sets; u16 max_scan_ie_len; u16 max_sched_scan_ie_len; u32 max_sched_scan_plans; u32 max_sched_scan_plan_interval; u32 max_sched_scan_plan_iterations; int n_cipher_suites; const u32 *cipher_suites; int n_akm_suites; const u32 *akm_suites; const struct wiphy_iftype_akm_suites *iftype_akm_suites; unsigned int num_iftype_akm_suites; u8 retry_short; u8 retry_long; u32 frag_threshold; u32 rts_threshold; u8 coverage_class; char fw_version[ETHTOOL_FWVERS_LEN]; u32 hw_version; #ifdef CONFIG_PM; const struct wiphy_wowlan_support *wowlan; struct cfg80211_wowlan *wowlan_config; #endif; u16 max_remain_on_channel_duration; u8 max_num_pmkids; u32 available_antennas_tx; u32 available_antennas_rx; u32 probe_resp_offload; const u8 *extended_capabilities, *extended_capabilities_mask; u8 extended_capabilities_len; const struct wiphy_iftype_ext_capab *iftype_ext_capab; unsigned int num_iftype_ext_capab; const void *privid; struct ieee80211_supported_band *bands[NUM_NL80211_BANDS]; void (*reg_notifier)(struct wiphy *wiphy, struct regulatory_request *request); const struct ieee80211_regdomain __rcu *regd; struct device dev; bool registered; struct dentry *debugfsdir; const struct ieee80211_ht_cap *ht_capa_mod_mask; const struct ieee80211_vht_cap *vht_capa_mod_mask; struct list_head wdev_list; possible_net_t _net; #ifdef CONFIG_CFG80211_WEXT; const struct iw_handler_def *wext; #endif; const struct wiphy_coalesce_support *coalesce; const struct wiphy_vendor_command *vendor_commands; const struct nl80211_vendor_cmd_info *vendor_events; int n_vendor_commands, n_vendor_events; u16 max_ap_assoc_sta; u8 max_num_csa_counters; u32 bss_select_support; u8 nan_supported_bands; u32 txq_limit; u32 txq_memory_limit; u32 txq_quantum; unsigned long tx_queue_len; u8 support_mbssid:1, support_only_he_mbssid:1; const struct cfg80211_pmsr_capabilities *pmsr_capa; struct { u64 peer, vif; u8 max_retry; } tid_config_support; u8 max_data_retry_count; const struct cfg80211_sar_capa *sar_capa; struct rfkill *rfkill; u8 mbssid_max_interfaces; u8 ema_max_profile_periodicity; u16 max_num_akm_suites; u16 hw_timestamp_max_peers; int n_radio; const struct wiphy_radio *radio; char priv[] ; }; **Members** ``mtx`` mutex for the data (structures) of this device ``perm_addr`` permanent MAC address of this device ``addr_mask`` If the device supports multiple MAC addresses by masking, set this to a mask with variable bits set to 1, e.g. if the last four bits are variable then set it to 00-00-00-00-00-0f. The actual variable bits shall be determined by the interfaces added, with interfaces not matching the mask being rejected to be brought up. ``addresses`` If the device has more than one address, set this pointer to a list of addresses (6 bytes each). The first one will be used by default for perm_addr. In this case, the mask should be set to all-zeroes. In this case it is assumed that the device can handle the same number of arbitrary MAC addresses. ``mgmt_stypes`` bitmasks of frame subtypes that can be subscribed to or transmitted through nl80211, points to an array indexed by interface type ``iface_combinations`` Valid interface combinations array, should not list single interface types. ``n_iface_combinations`` number of entries in **iface_combinations** array. ``software_iftypes`` bitmask of software interface types, these are not subject to any restrictions since they are purely managed in SW. ``n_addresses`` number of addresses in **addresses**. ``interface_modes`` bitmask of interfaces types valid for this wiphy, must be set by driver ``max_acl_mac_addrs`` Maximum number of MAC addresses that the device supports for ACL. ``flags`` wiphy flags, see :c:type:`enum wiphy_flags ` ``regulatory_flags`` wiphy regulatory flags, see :c:type:`enum ieee80211_regulatory_flags ` ``features`` features advertised to nl80211, see :c:type:`enum nl80211_feature_flags `. ``ext_features`` extended features advertised to nl80211, see :c:type:`enum nl80211_ext_feature_index `. ``ap_sme_capa`` AP SME capabilities, flags from :c:type:`enum nl80211_ap_sme_features `. ``signal_type`` signal type reported in :c:type:`struct cfg80211_bss `. ``bss_priv_size`` each BSS struct has private data allocated with it, this variable determines its size ``max_scan_ssids`` maximum number of SSIDs the device can scan for in any given scan ``max_sched_scan_reqs`` maximum number of scheduled scan requests that the device can run concurrently. ``max_sched_scan_ssids`` maximum number of SSIDs the device can scan for in any given scheduled scan ``max_match_sets`` maximum number of match sets the device can handle when performing a scheduled scan, 0 if filtering is not supported. ``max_scan_ie_len`` maximum length of user-controlled IEs device can add to probe request frames transmitted during a scan, must not include fixed IEs like supported rates ``max_sched_scan_ie_len`` same as max_scan_ie_len, but for scheduled scans ``max_sched_scan_plans`` maximum number of scan plans (scan interval and number of iterations) for scheduled scan supported by the device. ``max_sched_scan_plan_interval`` maximum interval (in seconds) for a single scan plan supported by the device. ``max_sched_scan_plan_iterations`` maximum number of iterations for a single scan plan supported by the device. ``n_cipher_suites`` number of supported cipher suites ``cipher_suites`` supported cipher suites ``n_akm_suites`` number of supported AKM suites ``akm_suites`` supported AKM suites. These are the default AKMs supported if the supported AKMs not advertized for a specific interface type in iftype_akm_suites. ``iftype_akm_suites`` array of supported akm suites info per interface type. Note that the bits in **iftypes_mask** inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_akm_suites). ``num_iftype_akm_suites`` number of interface types for which supported akm suites are specified separately. ``retry_short`` Retry limit for short frames (dot11ShortRetryLimit) ``retry_long`` Retry limit for long frames (dot11LongRetryLimit) ``frag_threshold`` Fragmentation threshold (dot11FragmentationThreshold); -1 = fragmentation disabled, only odd values >= 256 used ``rts_threshold`` RTS threshold (dot11RTSThreshold); -1 = RTS/CTS disabled ``coverage_class`` current coverage class ``fw_version`` firmware version for ethtool reporting ``hw_version`` hardware version for ethtool reporting ``wowlan`` WoWLAN support information ``wowlan_config`` current WoWLAN configuration; this should usually not be used since access to it is necessarily racy, use the parameter passed to the suspend() operation instead. ``max_remain_on_channel_duration`` Maximum time a remain-on-channel operation may request, if implemented. ``max_num_pmkids`` maximum number of PMKIDs supported by device ``available_antennas_tx`` bitmap of antennas which are available to be configured as TX antennas. Antenna configuration commands will be rejected unless this or **available_antennas_rx** is set. ``available_antennas_rx`` bitmap of antennas which are available to be configured as RX antennas. Antenna configuration commands will be rejected unless this or **available_antennas_tx** is set. ``probe_resp_offload`` Bitmap of supported protocols for probe response offloading. See :c:type:`enum nl80211_probe_resp_offload_support_attr `. Only valid when the wiphy flag **WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD** is set. ``extended_capabilities`` extended capabilities supported by the driver, additional capabilities might be supported by userspace; these are the 802.11 extended capabilities ("Extended Capabilities element") and are in the same format as in the information element. See 802.11-2012 8.4.2.29 for the defined fields. These are the default extended capabilities to be used if the capabilities are not specified for a specific interface type in iftype_ext_capab. ``extended_capabilities_mask`` mask of the valid values ``extended_capabilities_len`` length of the extended capabilities ``iftype_ext_capab`` array of extended capabilities per interface type ``num_iftype_ext_capab`` number of interface types for which extended capabilities are specified separately. ``privid`` a pointer that drivers can use to identify if an arbitrary wiphy is theirs, e.g. in global notifiers ``bands`` information about bands/channels supported by this device ``reg_notifier`` the driver's regulatory notification callback, note that if your driver uses wiphy_apply_custom_regulatory() the reg_notifier's request can be passed as NULL ``regd`` the driver's regulatory domain, if one was requested via the regulatory_hint() API. This can be used by the driver on the reg_notifier() if it chooses to ignore future regulatory domain changes caused by other drivers. ``dev`` (virtual) struct device for this wiphy. The item in /sys/class/ieee80211/ points to this. You need use set_wiphy_dev() (see below). ``registered`` protects ->resume and ->suspend sysfs callbacks against unregister hardware ``debugfsdir`` debugfs directory used for this wiphy (ieee80211/). It will be renamed automatically on wiphy renames ``ht_capa_mod_mask`` Specify what ht_cap values can be over-ridden. If null, then none can be over-ridden. ``vht_capa_mod_mask`` Specify what VHT capabilities can be over-ridden. If null, then none can be over-ridden. ``wdev_list`` the list of associated (virtual) interfaces; this list must not be modified by the driver, but can be read with RTNL/RCU protection. ``_net`` the network namespace this wiphy currently lives in ``wext`` wireless extension handlers ``coalesce`` packet coalescing support information ``vendor_commands`` array of vendor commands supported by the hardware ``vendor_events`` array of vendor events supported by the hardware ``n_vendor_commands`` number of vendor commands ``n_vendor_events`` number of vendor events ``max_ap_assoc_sta`` maximum number of associated stations supported in AP mode (including P2P GO) or 0 to indicate no such limit is advertised. The driver is allowed to advertise a theoretical limit that it can reach in some cases, but may not always reach. ``max_num_csa_counters`` Number of supported csa_counters in beacons and probe responses. This value should be set if the driver wishes to limit the number of csa counters. Default (0) means infinite. ``bss_select_support`` bitmask indicating the BSS selection criteria supported by the driver in the .connect() callback. The bit position maps to the attribute indices defined in :c:type:`enum nl80211_bss_select_attr `. ``nan_supported_bands`` bands supported by the device in NAN mode, a bitmap of :c:type:`enum nl80211_band ` values. For instance, for NL80211_BAND_2GHZ, bit 0 would be set (i.e. BIT(NL80211_BAND_2GHZ)). ``txq_limit`` configuration of internal TX queue frame limit ``txq_memory_limit`` configuration internal TX queue memory limit ``txq_quantum`` configuration of internal TX queue scheduler quantum ``tx_queue_len`` allow setting transmit queue len for drivers not using wake_tx_queue ``support_mbssid`` can HW support association with nontransmitted AP ``support_only_he_mbssid`` don't parse MBSSID elements if it is not HE AP, in order to avoid compatibility issues. **support_mbssid** must be set for this to have any effect. ``pmsr_capa`` peer measurement capabilities ``tid_config_support`` describes the per-TID config support that the device has ``tid_config_support.peer`` bitmap of attributes (configurations) supported by the driver for each peer ``tid_config_support.vif`` bitmap of attributes (configurations) supported by the driver for each vif ``tid_config_support.max_retry`` maximum supported retry count for long/short retry configuration ``max_data_retry_count`` maximum supported per TID retry count for configuration through the ``NL80211_TID_CONFIG_ATTR_RETRY_SHORT`` and ``NL80211_TID_CONFIG_ATTR_RETRY_LONG`` attributes ``sar_capa`` SAR control capabilities ``rfkill`` a pointer to the rfkill structure ``mbssid_max_interfaces`` maximum number of interfaces supported by the driver in a multiple BSSID set. This field must be set to a non-zero value by the driver to advertise MBSSID support. ``ema_max_profile_periodicity`` maximum profile periodicity supported by the driver. Setting this field to a non-zero value indicates that the driver supports enhanced multi-BSSID advertisements (EMA AP). ``max_num_akm_suites`` maximum number of AKM suites allowed for configuration through ``NL80211_CMD_CONNECT``, ``NL80211_CMD_ASSOCIATE`` and ``NL80211_CMD_START_AP``. Set to NL80211_MAX_NR_AKM_SUITES if not set by driver. If set by driver minimum allowed value is NL80211_MAX_NR_AKM_SUITES in order to avoid compatibility issues with legacy userspace and maximum allowed value is CFG80211_MAX_NUM_AKM_SUITES. ``hw_timestamp_max_peers`` maximum number of peers that the driver supports enabling HW timestamping for concurrently. Setting this field to a non-zero value indicates that the driver supports HW timestamping. A value of ``CFG80211_HW_TIMESTAMP_ALL_PEERS`` indicates the driver supports enabling HW timestamping for all peers (i.e. no need to specify a mac address). ``n_radio`` number of radios ``radio`` radios belonging to this wiphy ``priv`` driver private data (sized according to wiphy_new() parameter)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj)ubh:}(hj)hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj)ubj( )}(hX5 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); const struct ieee80211_regdomain __rcu *regd; struct device dev; bool registered; struct dentry *debugfsdir; const struct ieee80211_ht_cap *ht_capa_mod_mask; const struct ieee80211_vht_cap *vht_capa_mod_mask; struct list_head wdev_list; possible_net_t _net; #ifdef CONFIG_CFG80211_WEXT; const struct iw_handler_def *wext; #endif; const struct wiphy_coalesce_support *coalesce; const struct wiphy_vendor_command *vendor_commands; const struct nl80211_vendor_cmd_info *vendor_events; int n_vendor_commands, n_vendor_events; u16 max_ap_assoc_sta; u8 max_num_csa_counters; u32 bss_select_support; u8 nan_supported_bands; u32 txq_limit; u32 txq_memory_limit; u32 txq_quantum; unsigned long tx_queue_len; u8 support_mbssid:1, support_only_he_mbssid:1; const struct cfg80211_pmsr_capabilities *pmsr_capa; struct { u64 peer, vif; u8 max_retry; } tid_config_support; u8 max_data_retry_count; const struct cfg80211_sar_capa *sar_capa; struct rfkill *rfkill; u8 mbssid_max_interfaces; u8 ema_max_profile_periodicity; u16 max_num_akm_suites; u16 hw_timestamp_max_peers; int n_radio; const struct wiphy_radio *radio; char priv[] ; };h]hX5 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); const struct ieee80211_regdomain __rcu *regd; struct device dev; bool registered; struct dentry *debugfsdir; const struct ieee80211_ht_cap *ht_capa_mod_mask; const struct ieee80211_vht_cap *vht_capa_mod_mask; struct list_head wdev_list; possible_net_t _net; #ifdef CONFIG_CFG80211_WEXT; const struct iw_handler_def *wext; #endif; const struct wiphy_coalesce_support *coalesce; const struct wiphy_vendor_command *vendor_commands; const struct nl80211_vendor_cmd_info *vendor_events; int n_vendor_commands, n_vendor_events; u16 max_ap_assoc_sta; u8 max_num_csa_counters; u32 bss_select_support; u8 nan_supported_bands; u32 txq_limit; u32 txq_memory_limit; u32 txq_quantum; unsigned long tx_queue_len; u8 support_mbssid:1, support_only_he_mbssid:1; const struct cfg80211_pmsr_capabilities *pmsr_capa; struct { u64 peer, vif; u8 max_retry; } tid_config_support; u8 max_data_retry_count; const struct cfg80211_sar_capa *sar_capa; struct rfkill *rfkill; u8 mbssid_max_interfaces; u8 ema_max_profile_periodicity; u16 max_num_akm_suites; u16 hw_timestamp_max_peers; int n_radio; const struct wiphy_radio *radio; char priv[] ; };}hj)sbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj)ubh)}(h **Members**h]j)}(hj)h]hMembers}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj)ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj)ubj)}(hhh](j)}(h7``mtx`` mutex for the data (structures) of this device h](j)}(h``mtx``h]j)}(hj)h]hmtx}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj)ubj6)}(hhh]h)}(h.mutex for the data (structures) of this deviceh]h.mutex for the data (structures) of this device}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj)hMhj)ubah}(h]h ]h"]h$]h&]uh1j5hj)ubeh}(h]h ]h"]h$]h&]uh1jhj)hMhj)ubj)}(h3``perm_addr`` permanent MAC address of this device h](j)}(h ``perm_addr``h]j)}(hj*h]h perm_addr}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj*ubj6)}(hhh]h)}(h$permanent MAC address of this deviceh]h$permanent MAC address of this device}(hj6*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2*hMhj3*ubah}(h]h ]h"]h$]h&]uh1j5hj*ubeh}(h]h ]h"]h$]h&]uh1jhj2*hMhj)ubj)}(hXO``addr_mask`` If the device supports multiple MAC addresses by masking, set this to a mask with variable bits set to 1, e.g. if the last four bits are variable then set it to 00-00-00-00-00-0f. The actual variable bits shall be determined by the interfaces added, with interfaces not matching the mask being rejected to be brought up. h](j)}(h ``addr_mask``h]j)}(hjV*h]h addr_mask}(hjX*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjT*ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjP*ubj6)}(hhh]h)}(hX@If the device supports multiple MAC addresses by masking, set this to a mask with variable bits set to 1, e.g. if the last four bits are variable then set it to 00-00-00-00-00-0f. The actual variable bits shall be determined by the interfaces added, with interfaces not matching the mask being rejected to be brought up.h]hX@If the device supports multiple MAC addresses by masking, set this to a mask with variable bits set to 1, e.g. if the last four bits are variable then set it to 00-00-00-00-00-0f. The actual variable bits shall be determined by the interfaces added, with interfaces not matching the mask being rejected to be brought up.}(hjo*hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjl*ubah}(h]h ]h"]h$]h&]uh1j5hjP*ubeh}(h]h ]h"]h$]h&]uh1jhjk*hMhj)ubj)}(hX:``addresses`` If the device has more than one address, set this pointer to a list of addresses (6 bytes each). The first one will be used by default for perm_addr. In this case, the mask should be set to all-zeroes. In this case it is assumed that the device can handle the same number of arbitrary MAC addresses. h](j)}(h ``addresses``h]j)}(hj*h]h addresses}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj*ubj6)}(hhh]h)}(hX+If the device has more than one address, set this pointer to a list of addresses (6 bytes each). The first one will be used by default for perm_addr. In this case, the mask should be set to all-zeroes. In this case it is assumed that the device can handle the same number of arbitrary MAC addresses.h]hX+If the device has more than one address, set this pointer to a list of addresses (6 bytes each). The first one will be used by default for perm_addr. In this case, the mask should be set to all-zeroes. In this case it is assumed that the device can handle the same number of arbitrary MAC addresses.}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj*ubah}(h]h ]h"]h$]h&]uh1j5hj*ubeh}(h]h ]h"]h$]h&]uh1jhj*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.hhMhj8+ubj6)}(hhh]h)}(h2number of entries in **iface_combinations** array.h](hnumber of entries in }(hjW+hhhNhNubj)}(h**iface_combinations**h]hiface_combinations}(hj_+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjW+ubh array.}(hjW+hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjS+hMhjT+ubah}(h]h ]h"]h$]h&]uh1j5hj8+ubeh}(h]h ]h"]h$]h&]uh1jhjS+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)}(hj+h]hsoftware_iftypes}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj+ubj6)}(hhh]h)}(hsbitmask of software interface types, these are not subject to any restrictions since they are purely managed in SW.h]hsbitmask of software interface types, these are not subject to any restrictions since they are purely managed in SW.}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj+ubah}(h]h ]h"]h$]h&]uh1j5hj+ubeh}(h]h ]h"]h$]h&]uh1jhj+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)}(hjH,h]hmax_acl_mac_addrs}(hjJ,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjF,ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjB,ubj6)}(hhh]h)}(hAMaximum number of MAC addresses that the device supports for ACL.h]hAMaximum number of MAC addresses that the device supports for ACL.}(hja,hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj^,ubah}(h]h ]h"]h$]h&]uh1j5hjB,ubeh}(h]h ]h"]h$]h&]uh1jhj],hM hj)ubj)}(hD``flags`` wiphy flags, see :c:type:`enum wiphy_flags ` h](j)}(h ``flags``h]j)}(hj,h]hflags}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj|,ubj6)}(hhh]h)}(h9wiphy flags, see :c:type:`enum wiphy_flags `h](hwiphy flags, see }(hj,hhhNhNubh)}(h(:c:type:`enum wiphy_flags `h]j)}(hj,h]henum wiphy_flags}(hj,hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6 wiphy_flagsuh1hhj,hMhj,ubeh}(h]h ]h"]h$]h&]uh1hhj,hMhj,ubah}(h]h ]h"]h$]h&]uh1j5hj|,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 refexplicitrefwarnj j 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)}(hj3-h]hfeatures}(hj5-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1-ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj--ubj6)}(hhh]h)}(hafeatures advertised to nl80211, see :c:type:`enum nl80211_feature_flags `.h](h$features advertised to nl80211, see }(hjL-hhhNhNubh)}(h<:c:type:`enum nl80211_feature_flags `h]j)}(hjV-h]henum nl80211_feature_flags}(hjX-hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjT-ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_feature_flagsuh1hhjH-hMhjL-ubh.}(hjL-hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjH-hMhjI-ubah}(h]h ]h"]h$]h&]uh1j5hj--ubeh}(h]h ]h"]h$]h&]uh1jhjH-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)}(hj-h]h ext_features}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj-ubj6)}(hhh]h)}(hrextended features advertised to nl80211, see :c:type:`enum nl80211_ext_feature_index `.h](h-extended features advertised to nl80211, see }(hj-hhhNhNubh)}(hD:c:type:`enum nl80211_ext_feature_index `h]j)}(hj-h]henum nl80211_ext_feature_index}(hj-hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_ext_feature_indexuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj-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)}(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 refexplicitrefwarnj j 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)}(hjH.h]h signal_type}(hjJ.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjF.ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjB.ubj6)}(hhh]h)}(hEsignal type reported in :c:type:`struct cfg80211_bss `.h](hsignal type reported in }(hja.hhhNhNubh)}(h,:c:type:`struct cfg80211_bss `h]j)}(hjk.h]hstruct cfg80211_bss}(hjm.hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhji.ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6 cfg80211_bssuh1hhj].hMhja.ubh.}(hja.hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj].hMhj^.ubah}(h]h ]h"]h$]h&]uh1j5hjB.ubeh}(h]h ]h"]h$]h&]uh1jhj].hMhj)ubj)}(hh``bss_priv_size`` each BSS struct has private data allocated with it, this variable determines its size h](j)}(h``bss_priv_size``h]j)}(hj.h]h bss_priv_size}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj.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&]uh1j5hj.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.}(hj1/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)}(hjR/h]hmax_sched_scan_ssids}(hjT/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjP/ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjL/ubj6)}(hhh]h)}(hKmaximum number of SSIDs the device can scan for in any given scheduled scanh]hKmaximum number of SSIDs the device can scan for in any given scheduled scan}(hjk/hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjh/ubah}(h]h ]h"]h$]h&]uh1j5hjL/ubeh}(h]h ]h"]h$]h&]uh1jhjg/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)}(hj/h]hmax_match_sets}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj/ubj6)}(hhh]h)}(humaximum number of match sets the device can handle when performing a scheduled scan, 0 if filtering is not supported.h]humaximum number of match sets the device can handle when performing a scheduled scan, 0 if filtering is not supported.}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj/ubah}(h]h ]h"]h$]h&]uh1j5hj/ubeh}(h]h ]h"]h$]h&]uh1jhj/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)}(hj0h]hmax_sched_scan_ie_len}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj/ubj6)}(hhh]h)}(h0same as max_scan_ie_len, but for scheduled scansh]h0same as max_scan_ie_len, but for scheduled scans}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj0ubah}(h]h ]h"]h$]h&]uh1j5hj/ubeh}(h]h ]h"]h$]h&]uh1jhj0hMhj)ubj)}(h``max_sched_scan_plans`` maximum number of scan plans (scan interval and number of iterations) for scheduled scan supported by the device. h](j)}(h``max_sched_scan_plans``h]j)}(hj:0h]hmax_sched_scan_plans}(hj<0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj80ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj40ubj6)}(hhh]h)}(hqmaximum number of scan plans (scan interval and number of iterations) for scheduled scan supported by the device.h]hqmaximum number of scan plans (scan interval and number of iterations) for scheduled scan supported by the device.}(hjS0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjP0ubah}(h]h ]h"]h$]h&]uh1j5hj40ubeh}(h]h ]h"]h$]h&]uh1jhjO0hMhj)ubj)}(ho``max_sched_scan_plan_interval`` maximum interval (in seconds) for a single scan plan supported by the device. h](j)}(h ``max_sched_scan_plan_interval``h]j)}(hjt0h]hmax_sched_scan_plan_interval}(hjv0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjr0ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjn0ubj6)}(hhh]h)}(hMmaximum interval (in seconds) for a single scan plan supported by the device.h]hMmaximum interval (in seconds) for a single scan plan supported by the device.}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj0ubah}(h]h ]h"]h$]h&]uh1j5hjn0ubeh}(h]h ]h"]h$]h&]uh1jhj0hMhj)ubj)}(hp``max_sched_scan_plan_iterations`` maximum number of iterations for a single scan plan supported by the device. h](j)}(h"``max_sched_scan_plan_iterations``h]j)}(hj0h]hmax_sched_scan_plan_iterations}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj0ubj6)}(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&]uh1j5hj0ubeh}(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}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0hMhj0ubah}(h]h ]h"]h$]h&]uh1j5hj0ubeh}(h]h ]h"]h$]h&]uh1jhj0hMhj)ubj)}(h*``cipher_suites`` supported cipher suites h](j)}(h``cipher_suites``h]j)}(hj!1h]h cipher_suites}(hj#1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj1ubj6)}(hhh]h)}(hsupported cipher suitesh]hsupported cipher suites}(hj:1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj61hMhj71ubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhj61hMhj)ubj)}(h0``n_akm_suites`` number of supported AKM suites h](j)}(h``n_akm_suites``h]j)}(hjZ1h]h n_akm_suites}(hj\1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjX1ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjT1ubj6)}(hhh]h)}(hnumber of supported AKM suitesh]hnumber of supported AKM suites}(hjs1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjo1hMhjp1ubah}(h]h ]h"]h$]h&]uh1j5hjT1ubeh}(h]h ]h"]h$]h&]uh1jhjo1hMhj)ubj)}(h``akm_suites`` supported AKM suites. These are the default AKMs supported if the supported AKMs not advertized for a specific interface type in iftype_akm_suites. h](j)}(h``akm_suites``h]j)}(hj1h]h akm_suites}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj1ubj6)}(hhh]h)}(hsupported AKM suites. These are the default AKMs supported if the supported AKMs not advertized for a specific interface type in iftype_akm_suites.h]hsupported AKM suites. These are the default AKMs supported if the supported AKMs not advertized for a specific interface type in iftype_akm_suites.}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj1ubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhj1hMhj)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)}(hj2h]hnum_iftype_akm_suites}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj2ubj6)}(hhh]h)}(hRnumber of interface types for which supported akm suites are specified separately.h]hRnumber of interface types for which supported akm suites are specified separately.}(hj22hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj/2ubah}(h]h ]h"]h$]h&]uh1j5hj2ubeh}(h]h ]h"]h$]h&]uh1jhj.2hMhj)ubj)}(hD``retry_short`` Retry limit for short frames (dot11ShortRetryLimit) h](j)}(h``retry_short``h]j)}(hjS2h]h retry_short}(hjU2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQ2ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjM2ubj6)}(hhh]h)}(h3Retry limit for short frames (dot11ShortRetryLimit)h]h3Retry limit for short frames (dot11ShortRetryLimit)}(hjl2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjh2hMhji2ubah}(h]h ]h"]h$]h&]uh1j5hjM2ubeh}(h]h ]h"]h$]h&]uh1jhjh2hMhj)ubj)}(hA``retry_long`` Retry limit for long frames (dot11LongRetryLimit) h](j)}(h``retry_long``h]j)}(hj2h]h retry_long}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj2ubj6)}(hhh]h)}(h1Retry limit for long frames (dot11LongRetryLimit)h]h1Retry limit for long frames (dot11LongRetryLimit)}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2hMhj2ubah}(h]h ]h"]h$]h&]uh1j5hj2ubeh}(h]h ]h"]h$]h&]uh1jhj2hMhj)ubj)}(h``frag_threshold`` Fragmentation threshold (dot11FragmentationThreshold); -1 = fragmentation disabled, only odd values >= 256 used h](j)}(h``frag_threshold``h]j)}(hj2h]hfrag_threshold}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj2ubj6)}(hhh]h)}(hoFragmentation threshold (dot11FragmentationThreshold); -1 = fragmentation disabled, only odd values >= 256 usedh]hoFragmentation threshold (dot11FragmentationThreshold); -1 = fragmentation disabled, only odd values >= 256 used}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj2ubah}(h]h ]h"]h$]h&]uh1j5hj2ubeh}(h]h ]h"]h$]h&]uh1jhj2hMhj)ubj)}(hK``rts_threshold`` RTS threshold (dot11RTSThreshold); -1 = RTS/CTS disabled h](j)}(h``rts_threshold``h]j)}(hj2h]h rts_threshold}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj2ubj6)}(hhh]h)}(h8RTS threshold (dot11RTSThreshold); -1 = RTS/CTS disabledh]h8RTS threshold (dot11RTSThreshold); -1 = RTS/CTS disabled}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMhj3ubah}(h]h ]h"]h$]h&]uh1j5hj2ubeh}(h]h ]h"]h$]h&]uh1jhj3hMhj)ubj)}(h*``coverage_class`` current coverage class h](j)}(h``coverage_class``h]j)}(hj83h]hcoverage_class}(hj:3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj63ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj23ubj6)}(hhh]h)}(hcurrent coverage classh]hcurrent coverage class}(hjQ3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjM3hMhjN3ubah}(h]h ]h"]h$]h&]uh1j5hj23ubeh}(h]h ]h"]h$]h&]uh1jhjM3hMhj)ubj)}(h6``fw_version`` firmware version for ethtool reporting h](j)}(h``fw_version``h]j)}(hjq3h]h fw_version}(hjs3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjo3ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjk3ubj6)}(hhh]h)}(h&firmware version for ethtool reportingh]h&firmware version for ethtool reporting}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMhj3ubah}(h]h ]h"]h$]h&]uh1j5hjk3ubeh}(h]h ]h"]h$]h&]uh1jhj3hMhj)ubj)}(h6``hw_version`` hardware version for ethtool reporting h](j)}(h``hw_version``h]j)}(hj3h]h hw_version}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj3ubj6)}(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&]uh1j5hj3ubeh}(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)}(hj4h]h wowlan_config}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj4ubj6)}(hhh]h)}(hcurrent WoWLAN configuration; this should usually not be used since access to it is necessarily racy, use the parameter passed to the suspend() operation instead.h]hcurrent WoWLAN configuration; this should usually not be used since access to it is necessarily racy, use the parameter passed to the suspend() operation instead.}(hj54hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj24ubah}(h]h ]h"]h$]h&]uh1j5hj4ubeh}(h]h ]h"]h$]h&]uh1jhj14hMhj)ubj)}(hk``max_remain_on_channel_duration`` Maximum time a remain-on-channel operation may request, if implemented. h](j)}(h"``max_remain_on_channel_duration``h]j)}(hjV4h]hmax_remain_on_channel_duration}(hjX4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjT4ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjP4ubj6)}(hhh]h)}(hGMaximum time a remain-on-channel operation may request, if implemented.h]hGMaximum time a remain-on-channel operation may request, if implemented.}(hjo4hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjl4ubah}(h]h ]h"]h$]h&]uh1j5hjP4ubeh}(h]h ]h"]h$]h&]uh1jhjk4hMhj)ubj)}(h@``max_num_pmkids`` maximum number of PMKIDs supported by device h](j)}(h``max_num_pmkids``h]j)}(hj4h]hmax_num_pmkids}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj4ubj6)}(hhh]h)}(h,maximum number of PMKIDs supported by deviceh]h,maximum number of PMKIDs supported by device}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4hMhj4ubah}(h]h ]h"]h$]h&]uh1j5hj4ubeh}(h]h ]h"]h$]h&]uh1jhj4hMhj)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)}(hj5h]havailable_antennas_rx}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj5ubj6)}(hhh]h)}(hbitmap of antennas which are available to be configured as RX antennas. Antenna configuration commands will be rejected unless this or **available_antennas_tx** is set.h](hbitmap of antennas which are available to be configured as RX antennas. Antenna configuration commands will be rejected unless this or }(hj.5hhhNhNubj)}(h**available_antennas_tx**h]havailable_antennas_tx}(hj65hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.5ubh is set.}(hj.5hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj+5ubah}(h]h ]h"]h$]h&]uh1j5hj5ubeh}(h]h ]h"]h$]h&]uh1jhj*5hMhj)ubj)}(hX``probe_resp_offload`` Bitmap of supported protocols for probe response offloading. See :c:type:`enum nl80211_probe_resp_offload_support_attr `. Only valid when the wiphy flag **WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD** is set. h](j)}(h``probe_resp_offload``h]j)}(hja5h]hprobe_resp_offload}(hjc5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_5ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.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 }(hjz5hhhNhNubh)}(h`:c:type:`enum nl80211_probe_resp_offload_support_attr `h]j)}(hj5h]h,enum nl80211_probe_resp_offload_support_attr}(hj5hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6'nl80211_probe_resp_offload_support_attruh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjz5ubh!. Only valid when the wiphy flag }(hjz5hhhNhNubj)}(h$**WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD**h]h WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjz5ubh is set.}(hjz5hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj5hMhjw5ubah}(h]h ]h"]h$]h&]uh1j5hj[5ubeh}(h]h ]h"]h$]h&]uh1jhjv5hMhj)ubj)}(hX``extended_capabilities`` extended capabilities supported by the driver, additional capabilities might be supported by userspace; these are the 802.11 extended capabilities ("Extended Capabilities element") and are in the same format as in the information element. See 802.11-2012 8.4.2.29 for the defined fields. These are the default extended capabilities to be used if the capabilities are not specified for a specific interface type in iftype_ext_capab. h](j)}(h``extended_capabilities``h]j)}(hj5h]hextended_capabilities}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj5ubj6)}(hhh]h)}(hXextended capabilities supported by the driver, additional capabilities might be supported by userspace; these are the 802.11 extended capabilities ("Extended Capabilities element") and are in the same format as in the information element. See 802.11-2012 8.4.2.29 for the defined fields. These are the default extended capabilities to be used if the capabilities are not specified for a specific interface type in iftype_ext_capab.h]hXextended capabilities supported by the driver, additional capabilities might be supported by userspace; these are the 802.11 extended capabilities (“Extended Capabilities element”) and are in the same format as in the information element. See 802.11-2012 8.4.2.29 for the defined fields. These are the default extended capabilities to be used if the capabilities are not specified for a specific interface type in iftype_ext_capab.}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj5ubah}(h]h ]h"]h$]h&]uh1j5hj5ubeh}(h]h ]h"]h$]h&]uh1jhj5hMhj)ubj)}(h8``extended_capabilities_mask`` mask of the valid values h](j)}(h``extended_capabilities_mask``h]j)}(hj 6h]hextended_capabilities_mask}(hj 6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj6ubj6)}(hhh]h)}(hmask of the valid valuesh]hmask of the valid values}(hj#6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hMhj 6ubah}(h]h ]h"]h$]h&]uh1j5hj6ubeh}(h]h ]h"]h$]h&]uh1jhj6hMhj)ubj)}(hB``extended_capabilities_len`` length of the extended capabilities h](j)}(h``extended_capabilities_len``h]j)}(hjC6h]hextended_capabilities_len}(hjE6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjA6ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj=6ubj6)}(hhh]h)}(h#length of the extended capabilitiesh]h#length of the extended capabilities}(hj\6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjX6hMhjY6ubah}(h]h ]h"]h$]h&]uh1j5hj=6ubeh}(h]h ]h"]h$]h&]uh1jhjX6hMhj)ubj)}(hG``iftype_ext_capab`` array of extended capabilities per interface type h](j)}(h``iftype_ext_capab``h]j)}(hj|6h]hiftype_ext_capab}(hj~6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjz6ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjv6ubj6)}(hhh]h)}(h1array of extended capabilities per interface typeh]h1array of extended capabilities per interface type}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hMhj6ubah}(h]h ]h"]h$]h&]uh1j5hjv6ubeh}(h]h ]h"]h$]h&]uh1jhj6hMhj)ubj)}(hm``num_iftype_ext_capab`` number of interface types for which extended capabilities are specified separately. h](j)}(h``num_iftype_ext_capab``h]j)}(hj6h]hnum_iftype_ext_capab}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj6ubj6)}(hhh]h)}(hSnumber of interface types for which extended capabilities are specified separately.h]hSnumber of interface types for which extended capabilities are specified separately.}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj6ubah}(h]h ]h"]h$]h&]uh1j5hj6ubeh}(h]h ]h"]h$]h&]uh1jhj6hMhj)ubj)}(hp``privid`` a pointer that drivers can use to identify if an arbitrary wiphy is theirs, e.g. in global notifiers h](j)}(h ``privid``h]j)}(hj6h]hprivid}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.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}(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&]uh1j5hj6ubeh}(h]h ]h"]h$]h&]uh1jhj7hMhj)ubj)}(hD``bands`` information about bands/channels supported by this device h](j)}(h ``bands``h]j)}(hj)7h]hbands}(hj+7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'7ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj#7ubj6)}(hhh]h)}(h9information about bands/channels supported by this deviceh]h9information about bands/channels supported by this device}(hjB7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>7hMhj?7ubah}(h]h ]h"]h$]h&]uh1j5hj#7ubeh}(h]h ]h"]h$]h&]uh1jhj>7hMhj)ubj)}(h``reg_notifier`` the driver's regulatory notification callback, note that if your driver uses wiphy_apply_custom_regulatory() the reg_notifier's request can be passed as NULL h](j)}(h``reg_notifier``h]j)}(hjb7h]h reg_notifier}(hjd7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`7ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj\7ubj6)}(hhh]h)}(hthe driver's regulatory notification callback, note that if your driver uses wiphy_apply_custom_regulatory() the reg_notifier's request can be passed as NULLh]hthe driver’s regulatory notification callback, note that if your driver uses wiphy_apply_custom_regulatory() the reg_notifier’s request can be passed as NULL}(hj{7hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjx7ubah}(h]h ]h"]h$]h&]uh1j5hj\7ubeh}(h]h ]h"]h$]h&]uh1jhjw7hMhj)ubj)}(h``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&]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)}(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)}(hjJ8h]h debugfsdir}(hjL8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjH8ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjD8ubj6)}(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}(hjc8hhhNhNubah}(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&]uh1j5hjD8ubeh}(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.hhMhj9ubah}(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)}(hj29h]h_net}(hj49hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj09ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj,9ubj6)}(hhh]h)}(h3the network namespace this wiphy currently lives inh]h3the network namespace this wiphy currently lives in}(hjK9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjG9hMhjH9ubah}(h]h ]h"]h$]h&]uh1j5hj,9ubeh}(h]h ]h"]h$]h&]uh1jhjG9hMhj)ubj)}(h%``wext`` wireless extension handlers h](j)}(h``wext``h]j)}(hjk9h]hwext}(hjm9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhji9ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhje9ubj6)}(hhh]h)}(hwireless extension handlersh]hwireless extension handlers}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hMhj9ubah}(h]h ]h"]h$]h&]uh1j5hje9ubeh}(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)}(hjO:h]hn_vendor_commands}(hjQ:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjM:ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjI:ubj6)}(hhh]h)}(hnumber of vendor commandsh]hnumber of vendor commands}(hjh:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjd:hMhje:ubah}(h]h ]h"]h$]h&]uh1j5hjI:ubeh}(h]h ]h"]h$]h&]uh1jhjd: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.hhMhj: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)}(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)}(hj5;h]hbss_select_support}(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.hhM*hj/;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 }(hjN;hhhNhNubh)}(h@:c:type:`enum nl80211_bss_select_attr `h]j)}(hjX;h]henum nl80211_bss_select_attr}(hjZ;hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjV;ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_bss_select_attruh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM(hjN;ubh.}(hjN;hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhju;hM(hjK;ubah}(h]h ]h"]h$]h&]uh1j5hj/;ubeh}(h]h ]h"]h$]h&]uh1jhjJ;hM*hj)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.hhM/hj;ubj6)}(hhh]h)}(hbands supported by the device in NAN mode, a bitmap of :c:type:`enum nl80211_band ` values. For instance, for NL80211_BAND_2GHZ, bit 0 would be set (i.e. BIT(NL80211_BAND_2GHZ)).h](h7bands supported by the device in NAN mode, a bitmap of }(hj;hhhNhNubh)}(h*:c:type:`enum nl80211_band `h]j)}(hj;h]henum nl80211_band}(hj;hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6 nl80211_banduh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM,hj;ubh` values. For instance, for NL80211_BAND_2GHZ, bit 0 would be set (i.e. BIT(NL80211_BAND_2GHZ)).}(hj;hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj;hM,hj;ubah}(h]h ]h"]h$]h&]uh1j5hj;ubeh}(h]h ]h"]h$]h&]uh1jhj;hM/hj)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.hhM1hj;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<hM1hj<ubah}(h]h ]h"]h$]h&]uh1j5hj;ubeh}(h]h ]h"]h$]h&]uh1jhj<hM1hj)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.hhM2hj"<ubj6)}(hhh]h)}(h,configuration internal TX queue memory limith]h,configuration internal TX queue memory limit}(hjA<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=<hM2hj><ubah}(h]h ]h"]h$]h&]uh1j5hj"<ubeh}(h]h ]h"]h$]h&]uh1jhj=<hM2hj)ubj)}(hE``txq_quantum`` configuration of internal TX queue scheduler quantum h](j)}(h``txq_quantum``h]j)}(hja<h]h txq_quantum}(hjc<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.hhM3hj[<ubj6)}(hhh]h)}(h4configuration of internal TX queue scheduler quantumh]h4configuration of internal TX queue scheduler quantum}(hjz<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjv<hM3hjw<ubah}(h]h ]h"]h$]h&]uh1j5hj[<ubeh}(h]h ]h"]h$]h&]uh1jhjv<hM3hj)ubj)}(hV``tx_queue_len`` allow setting transmit queue len for drivers not using wake_tx_queue h](j)}(h``tx_queue_len``h]j)}(hj<h]h tx_queue_len}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM6hj<ubj6)}(hhh]h)}(hDallow setting transmit queue len for drivers not using wake_tx_queueh]hDallow setting transmit queue len for drivers not using wake_tx_queue}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM5hj<ubah}(h]h ]h"]h$]h&]uh1j5hj<ubeh}(h]h ]h"]h$]h&]uh1jhj<hM6hj)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.hhM8hj<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<hM8hj<ubah}(h]h ]h"]h$]h&]uh1j5hj<ubeh}(h]h ]h"]h$]h&]uh1jhj<hM8hj)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.hhM;hj=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.hhM9hj#=ubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhj"=hM;hj)ubj)}(h,``pmsr_capa`` peer measurement capabilities h](j)}(h ``pmsr_capa``h]j)}(hjY=h]h pmsr_capa}(hj[=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjW=ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM=hjS=ubj6)}(hhh]h)}(hpeer measurement capabilitiesh]hpeer measurement capabilities}(hjr=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjn=hM=hjo=ubah}(h]h ]h"]h$]h&]uh1j5hjS=ubeh}(h]h ]h"]h$]h&]uh1jhjn=hM=hj)ubj)}(hP``tid_config_support`` describes the per-TID config support that the device has h](j)}(h``tid_config_support``h]j)}(hj=h]htid_config_support}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM@hj=ubj6)}(hhh]h)}(h8describes the per-TID config support that the device hash]h8describes the per-TID config support that the device has}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM?hj=ubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhj=hM@hj)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.hhMDhj=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.hhMChj=ubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhj=hMDhj)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.hhMBhj>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.hhMAhj>ubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhj>hMBhj)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}(hjB>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>>ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMFhj:>ubj6)}(hhh]h)}(h@maximum supported retry count for long/short retry configurationh]h@maximum supported retry count for long/short retry configuration}(hjY>hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMEhjV>ubah}(h]h ]h"]h$]h&]uh1j5hj:>ubeh}(h]h ]h"]h$]h&]uh1jhjU>hMFhj)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)}(hjz>h]hmax_data_retry_count}(hj|>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjx>ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMJhjt>ubj6)}(hhh]h)}(hmaximum supported per TID retry count for configuration through the ``NL80211_TID_CONFIG_ATTR_RETRY_SHORT`` and ``NL80211_TID_CONFIG_ATTR_RETRY_LONG`` attributesh](hDmaximum supported per TID retry count for configuration through the }(hj>hhhNhNubj)}(h'``NL80211_TID_CONFIG_ATTR_RETRY_SHORT``h]h#NL80211_TID_CONFIG_ATTR_RETRY_SHORT}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubh and }(hj>hhhNhNubj)}(h&``NL80211_TID_CONFIG_ATTR_RETRY_LONG``h]h"NL80211_TID_CONFIG_ATTR_RETRY_LONG}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubh attributes}(hj>hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMHhj>ubah}(h]h ]h"]h$]h&]uh1j5hjt>ubeh}(h]h ]h"]h$]h&]uh1jhj>hMJhj)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.hhMKhj>ubj6)}(hhh]h)}(hSAR control capabilitiesh]hSAR control capabilities}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hMKhj>ubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhj>hMKhj)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.hhMLhj ?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&?hMLhj'?ubah}(h]h ]h"]h$]h&]uh1j5hj ?ubeh}(h]h ]h"]h$]h&]uh1jhj&?hMLhj)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)}(hjJ?h]hmbssid_max_interfaces}(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.hhMPhjD?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.}(hjc?hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMNhj`?ubah}(h]h ]h"]h$]h&]uh1j5hjD?ubeh}(h]h ]h"]h$]h&]uh1jhj_?hMPhj)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.hhMShj~?ubj6)}(hhh]h)}(hmaximum profile periodicity supported by the driver. Setting this field to a non-zero value indicates that the driver supports enhanced multi-BSSID advertisements (EMA AP).h]hmaximum profile periodicity supported by the driver. Setting this field to a non-zero value indicates that the driver supports enhanced multi-BSSID advertisements (EMA AP).}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMQhj?ubah}(h]h ]h"]h$]h&]uh1j5hj~?ubeh}(h]h ]h"]h$]h&]uh1jhj?hMShj)ubj)}(hX``max_num_akm_suites`` maximum number of AKM suites allowed for configuration through ``NL80211_CMD_CONNECT``, ``NL80211_CMD_ASSOCIATE`` and ``NL80211_CMD_START_AP``. Set to NL80211_MAX_NR_AKM_SUITES if not set by driver. If set by driver minimum allowed value is NL80211_MAX_NR_AKM_SUITES in order to avoid compatibility issues with legacy userspace and maximum allowed value is CFG80211_MAX_NUM_AKM_SUITES. h](j)}(h``max_num_akm_suites``h]j)}(hj?h]hmax_num_akm_suites}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMZhj?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.hhMThj?ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhj?hMZhj)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}(hj0@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.hhMahj(@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 }(hjG@hhhNhNubj)}(h#``CFG80211_HW_TIMESTAMP_ALL_PEERS``h]hCFG80211_HW_TIMESTAMP_ALL_PEERS}(hjO@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjG@ubhn indicates the driver supports enabling HW timestamping for all peers (i.e. no need to specify a mac address).}(hjG@hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM\hjD@ubah}(h]h ]h"]h$]h&]uh1j5hj(@ubeh}(h]h ]h"]h$]h&]uh1jhjC@hMahj)ubj)}(h``n_radio`` number of radios h](j)}(h ``n_radio``h]j)}(hjz@h]hn_radio}(hj|@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjx@ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMdhjt@ubj6)}(hhh]h)}(hnumber of radiosh]hnumber of radios}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@hMdhj@ubah}(h]h ]h"]h$]h&]uh1j5hjt@ubeh}(h]h ]h"]h$]h&]uh1jhj@hMdhj)ubj)}(h)``radio`` radios belonging to this wiphy h](j)}(h ``radio``h]j)}(hj@h]hradio}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMchj@ubj6)}(hhh]h)}(hradios belonging to this wiphyh]hradios belonging to this wiphy}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@hMchj@ubah}(h]h ]h"]h$]h&]uh1j5hj@ubeh}(h]h ]h"]h$]h&]uh1jhj@hMchj)ubj)}(hG``priv`` driver private data (sized according to wiphy_new() parameter)h](j)}(h``priv``h]j)}(hj@h]hpriv}(hj@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>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&]uh1j5hj@ubeh}(h]h ]h"]h$]h&]uh1jhjAhMhj)ubeh}(h]h ]h"]h$]h&]uh1jhj)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}(hjFAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBAhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjUAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBAhhhjTAhMubj.)}(hj1h]h*}(hjcAhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjBAhhhjTAhMubj)}(h wiphy_privh]j)}(h wiphy_privh]h wiphy_priv}(hjtAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjpAubah}(h]h ](jjeh"]h$]h&]jjuh1jhjBAhhhjTAhMubj)}(h(struct wiphy *wiphy)h]j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjAubj)}(h h]h }(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAubh)}(hhh]j)}(hwiphyh]hwiphy}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjAmodnameN classnameNj j )}j ]j)}jjvAsb c.wiphy_privasbuh1hhjAubj)}(h h]h }(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAubj.)}(hj1h]h*}(hjAhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjAubj)}(hwiphyh]hwiphy}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjAubah}(h]h ]h"]h$]h&]jjuh1jhjBAhhhjTAhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj>AhhhjTAhMubah}(h]j9Aah ](jjeh"]h$]h&]jj)jhuh1jhhjTAhMhj;Ahhubj)}(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.hhM hjBhhubah}(h]h ]h"]h$]h&]uh1jhj;AhhhjTAhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jj+Bjj+Bjjjuh1jchhhhhNhNubj)}(ht**Parameters** ``struct wiphy *wiphy`` the wiphy whose priv pointer to return **Return** The priv of **wiphy**.h](h)}(h**Parameters**h]j)}(hj5Bh]h Parameters}(hj7BhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3Bubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj/Bubj)}(hhh]j)}(h?``struct wiphy *wiphy`` the wiphy whose priv pointer to return h](j)}(h``struct wiphy *wiphy``h]j)}(hjTBh]hstruct wiphy *wiphy}(hjVBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRBubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjNBubj6)}(hhh]h)}(h&the wiphy whose priv pointer to returnh]h&the wiphy whose priv pointer to return}(hjmBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjiBhM hjjBubah}(h]h ]h"]h$]h&]uh1j5hjNBubeh}(h]h ]h"]h$]h&]uh1jhjiBhM hjKBubah}(h]h ]h"]h$]h&]uh1jhj/Bubh)}(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.hhMhj/Bubh)}(hThe priv of **wiphy**.h](h The priv of }(hjBhhhNhNubj)}(h **wiphy**h]hwiphy}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBubh.}(hjBhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj/Bubeh}(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)}(hjh]hstruct}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjBhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBhhhjBhMubh)}(hhh]j)}(hwiphyh]hwiphy}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjCmodnameN classnameNj j )}j ]j)}j priv_to_wiphysbc.priv_to_wiphyasbuh1hhjBhhhjBhMubj)}(h h]h }(hj&ChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBhhhjBhMubj.)}(hj1h]h*}(hj4ChhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjBhhhjBhMubj)}(h priv_to_wiphyh]j)}(hj#Ch]h priv_to_wiphy}(hjEChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjACubah}(h]h ](jjeh"]h$]h&]jjuh1jhjBhhhjBhMubj)}(h (void *priv)h]j)}(h void *privh](j)}(hvoidh]hvoid}(hj`ChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\Cubj)}(h h]h }(hjnChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\Cubj.)}(hj1h]h*}(hj|ChhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj\Cubj)}(hprivh]hpriv}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\Cubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXCubah}(h]h ]h"]h$]h&]jjuh1jhjBhhhjBhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjBhhhjBhMubah}(h]jBah ](jjeh"]h$]h&]jj)jhuh1jhhjBhMhjBhhubj)}(hhh]h)}(h$return the wiphy containing the privh]h$return the wiphy containing the priv}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjChhubah}(h]h ]h"]h$]h&]uh1jhjBhhhjBhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjCjjCjjjuh1jchhhhhNhNubj)}(hp**Parameters** ``void *priv`` a pointer previously returned by wiphy_priv **Return** The wiphy of **priv**.h](h)}(h**Parameters**h]j)}(hjCh]h Parameters}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjCubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjCubj)}(hhh]j)}(h;``void *priv`` a pointer previously returned by wiphy_priv h](j)}(h``void *priv``h]j)}(hjCh]h void *priv}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjCubj6)}(hhh]h)}(h+a pointer previously returned by wiphy_privh]h+a pointer previously returned by wiphy_priv}(hj DhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj DhMhj Dubah}(h]h ]h"]h$]h&]uh1j5hjCubeh}(h]h ]h"]h$]h&]uh1jhj DhMhjCubah}(h]h ]h"]h$]h&]uh1jhjCubh)}(h **Return**h]j)}(hj/Dh]hReturn}(hj1DhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-Dubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjCubh)}(hThe wiphy of **priv**.h](h The wiphy of }(hjEDhhhNhNubj)}(h**priv**h]hpriv}(hjMDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjEDubh.}(hjEDhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjCubeh}(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)}(hubj)}(h h]h }(hjgHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjTHhhhjfHhM>ubj)}(hcharh]hchar}(hjuHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjTHhhhjfHhM>ubj)}(h h]h }(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjTHhhhjfHhM>ubj.)}(hj1h]h*}(hjHhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjTHhhhjfHhM>ubj)}(h wiphy_nameh]j)}(h wiphy_nameh]h wiphy_name}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHubah}(h]h ](jjeh"]h$]h&]jjuh1jhjTHhhhjfHhM>ubj)}(h(const struct wiphy *wiphy)h]j)}(hconst struct wiphy *wiphyh](ju)}(hjZHh]hconst}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjHubj)}(h h]h }(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHubju)}(hjh]hstruct}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjHubj)}(h h]h }(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHubh)}(hhh]j)}(hwiphyh]hwiphy}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjHmodnameN classnameNj j )}j ]j)}jjHsb c.wiphy_nameasbuh1hhjHubj)}(h h]h }(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHubj.)}(hj1h]h*}(hj%IhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjHubj)}(hwiphyh]hwiphy}(hj2IhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjHubah}(h]h ]h"]h$]h&]jjuh1jhjTHhhhjfHhM>ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjPHhhhjfHhM>ubah}(h]jKHah ](jjeh"]h$]h&]jj)jhuh1jhhjfHhM>hjMHhhubj)}(hhh]h)}(hget wiphy nameh]hget wiphy name}(hj\IhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM9hjYIhhubah}(h]h ]h"]h$]h&]uh1jhjMHhhhjfHhM>ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjtIjjtIjjjuh1jchhhhhNhNubj)}(hr**Parameters** ``const struct wiphy *wiphy`` The wiphy whose name to return **Return** The name of **wiphy**.h](h)}(h**Parameters**h]j)}(hj~Ih]h Parameters}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|Iubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM=hjxIubj)}(hhh]j)}(h=``const struct wiphy *wiphy`` The wiphy whose name to return h](j)}(h``const struct wiphy *wiphy``h]j)}(hjIh]hconst struct wiphy *wiphy}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM;hjIubj6)}(hhh]h)}(hThe wiphy whose name to returnh]hThe wiphy whose name to return}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIhM;hjIubah}(h]h ]h"]h$]h&]uh1j5hjIubeh}(h]h ]h"]h$]h&]uh1jhjIhM;hjIubah}(h]h ]h"]h$]h&]uh1jhjxIubh)}(h **Return**h]j)}(hjIh]hReturn}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM=hjxIubh)}(hThe name of **wiphy**.h](h The name of }(hjIhhhNhNubj)}(h **wiphy**h]hwiphy}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIubh.}(hjIhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM<hjxIubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_wiphy_new (C function) c.wiphy_newhNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(hJstruct wiphy * wiphy_new (const struct cfg80211_ops *ops, int sizeof_priv)h]jo)}(hHstruct wiphy *wiphy_new(const struct cfg80211_ops *ops, int sizeof_priv)h](ju)}(hjh]hstruct}(hj/JhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj+Jhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM`ubj)}(h h]h }(hj=JhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+Jhhhj(private) Used by the internal wireless extensions compat codeh]h>(private) Used by the internal wireless extensions compat code}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjWhMhjWubah}(h]h ]h"]h$]h&]uh1j5hjWubeh}(h]h ]h"]h$]h&]uh1jhjWhMhjQubj)}(h8``wext.ibss`` (private) IBSS data part of wext handling h](j)}(h ``wext.ibss``h]j)}(hjWh]h wext.ibss}(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) IBSS data part of wext handlingh]h)(private) IBSS data part of wext handling}(hj XhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhMhjXubah}(h]h ]h"]h$]h&]uh1j5hjWubeh}(h]h ]h"]h$]h&]uh1jhjXhMhjQubj)}(h4``wext.connect`` (private) connection handling data h](j)}(h``wext.connect``h]j)}(hj)Xh]h wext.connect}(hj+XhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'Xubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj#Xubj6)}(hhh]h)}(h"(private) connection handling datah]h"(private) connection handling data}(hjBXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>XhMhj?Xubah}(h]h ]h"]h$]h&]uh1j5hj#Xubeh}(h]h ]h"]h$]h&]uh1jhj>XhMhjQubj)}(h'``wext.keys`` (private) (WEP) key data h](j)}(h ``wext.keys``h]j)}(hjbXh]h wext.keys}(hjdXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`Xubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj\Xubj6)}(hhh]h)}(h(private) (WEP) key datah]h(private) (WEP) key data}(hj{XhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwXhMhjxXubah}(h]h ]h"]h$]h&]uh1j5hj\Xubeh}(h]h ]h"]h$]h&]uh1jhjwXhMhjQubj)}(h5``wext.ie`` (private) extra elements for association h](j)}(h ``wext.ie``h]j)}(hjXh]hwext.ie}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjXubj6)}(hhh]h)}(h((private) extra elements for associationh]h((private) extra elements for association}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhMhjXubah}(h]h ]h"]h$]h&]uh1j5hjXubeh}(h]h ]h"]h$]h&]uh1jhjXhMhjQubj)}(h3``wext.ie_len`` (private) length of extra elements h](j)}(h``wext.ie_len``h]j)}(hjXh]h wext.ie_len}(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) length of extra elementsh]h"(private) length of extra elements}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhMhjXubah}(h]h ]h"]h$]h&]uh1j5hjXubeh}(h]h ]h"]h$]h&]uh1jhjXhMhjQubj)}(h0``wext.bssid`` (private) selected network BSSID h](j)}(h``wext.bssid``h]j)}(hj Yh]h wext.bssid}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Yubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjYubj6)}(hhh]h)}(h (private) selected network BSSIDh]h (private) selected network BSSID}(hj&YhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"YhMhj#Yubah}(h]h ]h"]h$]h&]uh1j5hjYubeh}(h]h ]h"]h$]h&]uh1jhj"YhMhjQubj)}(h?``wext.prev_bssid`` (private) previous BSSID for reassociation h](j)}(h``wext.prev_bssid``h]j)}(hjFYh]hwext.prev_bssid}(hjHYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDYubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj@Yubj6)}(hhh]h)}(h*(private) previous BSSID for reassociationh]h*(private) previous BSSID for reassociation}(hj_YhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[YhMhj\Yubah}(h]h ]h"]h$]h&]uh1j5hj@Yubeh}(h]h ]h"]h$]h&]uh1jhj[YhMhjQubj)}(h.``wext.ssid`` (private) selected network SSID h](j)}(h ``wext.ssid``h]j)}(hjYh]h wext.ssid}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}Yubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjyYubj6)}(hhh]h)}(h(private) selected network SSIDh]h(private) selected network SSID}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYhMhjYubah}(h]h ]h"]h$]h&]uh1j5hjyYubeh}(h]h ]h"]h$]h&]uh1jhjYhMhjQubj)}(h:``wext.default_key`` (private) selected default key index h](j)}(h``wext.default_key``h]j)}(hjYh]hwext.default_key}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjYubj6)}(hhh]h)}(h$(private) selected default key indexh]h$(private) selected default key index}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYhMhjYubah}(h]h ]h"]h$]h&]uh1j5hjYubeh}(h]h ]h"]h$]h&]uh1jhjYhMhjQubj)}(hJ``wext.default_mgmt_key`` (private) selected default management key index h](j)}(h``wext.default_mgmt_key``h]j)}(hjYh]hwext.default_mgmt_key}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjYubj6)}(hhh]h)}(h/(private) selected default management key indexh]h/(private) selected default management key index}(hj ZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhMhjZubah}(h]h ]h"]h$]h&]uh1j5hjYubeh}(h]h ]h"]h$]h&]uh1jhjZhMhjQubj)}(h<``wext.prev_bssid_valid`` (private) previous BSSID validity h](j)}(h``wext.prev_bssid_valid``h]j)}(hj*Zh]hwext.prev_bssid_valid}(hj,ZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(Zubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj$Zubj6)}(hhh]h)}(h!(private) previous BSSID validityh]h!(private) previous BSSID validity}(hjCZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?ZhMhj@Zubah}(h]h ]h"]h$]h&]uh1j5hj$Zubeh}(h]h ]h"]h$]h&]uh1jhj?ZhMhjQubj)}(h4``cqm_rssi_work`` (private) CQM RSSI reporting work h](j)}(h``cqm_rssi_work``h]j)}(hjcZh]h cqm_rssi_work}(hjeZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaZubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj]Zubj6)}(hhh]h)}(h!(private) CQM RSSI reporting workh]h!(private) CQM RSSI reporting work}(hj|ZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxZhMhjyZubah}(h]h ]h"]h$]h&]uh1j5hj]Zubeh}(h]h ]h"]h$]h&]uh1jhjxZhMhjQubj)}(h4``cqm_config`` (private) nl80211 RSSI monitor state h](j)}(h``cqm_config``h]j)}(hjZh]h cqm_config}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjZubj6)}(hhh]h)}(h$(private) nl80211 RSSI monitor stateh]h$(private) nl80211 RSSI monitor state}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhMhjZubah}(h]h ]h"]h$]h&]uh1j5hjZubeh}(h]h ]h"]h$]h&]uh1jhjZhMhjQubj)}(h2``pmsr_list`` (private) peer measurement requests h](j)}(h ``pmsr_list``h]j)}(hjZh]h pmsr_list}(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) peer measurement requestsh]h#(private) peer measurement requests}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhMhjZubah}(h]h ]h"]h$]h&]uh1j5hjZubeh}(h]h ]h"]h$]h&]uh1jhjZhMhjQubj)}(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#[hMhjQubj)}(h:``pmsr_free_wk`` (private) peer measurements cleanup work h](j)}(h``pmsr_free_wk``h]j)}(hjG[h]h pmsr_free_wk}(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)}(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&]uh1j5hjA[ubeh}(h]h ]h"]h$]h&]uh1jhj\[hMhjQubj)}(hQ``unprot_beacon_reported`` (private) timestamp of last unprotected beacon report h](j)}(h``unprot_beacon_reported``h]j)}(hj[h]hunprot_beacon_reported}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~[ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjz[ubj6)}(hhh]h)}(h5(private) timestamp of last unprotected beacon reporth]h5(private) timestamp of last unprotected beacon report}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj[ubah}(h]h ]h"]h$]h&]uh1j5hjz[ubeh}(h]h ]h"]h$]h&]uh1jhj[hMhjQubj)}(h3``u`` union containing data specific to **iftype** h](j)}(h``u``h]j)}(hj[h]hu}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj[ubj6)}(hhh]h)}(h,union containing data specific to **iftype**h](h"union containing data specific to }(hj[hhhNhNubj)}(h **iftype**h]hiftype}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[ubeh}(h]h ]h"]h$]h&]uh1hhj[hMhj[ubah}(h]h ]h"]h$]h&]uh1j5hj[ubeh}(h]h ]h"]h$]h&]uh1jhj[hMhjQubj)}(ht``links`` array of ``IEEE80211_MLD_MAX_NUM_LINKS`` elements containing **addr** **ap** and **client** for each link h](j)}(h ``links``h]j)}(hj\h]hlinks}(hj\hhhNhNubah}(h]h ]h"]h$]h&]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}(hj4\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\ubh }(hj\hhhNhNubj)}(h**ap**h]hap}(hjF\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\ubh and }(hj\hhhNhNubj)}(h **client**h]hclient}(hjX\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\hMhjQubj)}(h``{unnamed_union}`` anonymous h](j)}(h``{unnamed_union}``h]j)}(hj\h]h{unnamed_union}}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj}\ubj6)}(hhh]h)}(h anonymoush]h anonymous}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\hMhj\ubah}(h]h ]h"]h$]h&]uh1j5hj}\ubeh}(h]h ]h"]h$]h&]uh1jhj\hMhjQubj)}(hN``links.cac_started`` true if DFS channel availability check has been started h](j)}(h``links.cac_started``h]j)}(hj\h]hlinks.cac_started}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj\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&]uh1j5hj\ubeh}(h]h ]h"]h$]h&]uh1jhj\hMhjQubj)}(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 ]hMhjQubj)}(h%``links.cac_time_ms`` CAC time in ms h](j)}(h``links.cac_time_ms``h]j)}(hj0]h]hlinks.cac_time_ms}(hj2]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.]ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj*]ubj6)}(hhh]h)}(hCAC time in msh]hCAC time in ms}(hjI]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjE]hMhjF]ubah}(h]h ]h"]h$]h&]uh1j5hj*]ubeh}(h]h ]h"]h$]h&]uh1jhjE]hMhjQubj)}(hG``valid_links`` bitmap describing what elements of **links** are valid h](j)}(h``valid_links``h]j)}(hji]h]h valid_links}(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)}(h6bitmap describing what elements of **links** are validh](h#bitmap describing what elements of }(hj]hhhNhNubj)}(h **links**h]hlinks}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]ubh are valid}(hj]hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj~]hMhj]ubah}(h]h ]h"]h$]h&]uh1j5hjc]ubeh}(h]h ]h"]h$]h&]uh1jhj~]hMhjQubj)}(hN``radio_mask`` Bitmask of radios that this interface is allowed to operate on.h](j)}(h``radio_mask``h]j)}(hj]h]h radio_mask}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj]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&]uh1j5hj]ubeh}(h]h ]h"]h$]h&]uh1jhj]hMhjQubeh}(h]h ]h"]h$]h&]uh1jhjhQubeh}(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.hhMhhhhubh)}(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.hhMthhhhubh)}(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.hhM}hhhhubjS)}(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}(hjD^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@^hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMJubj)}(h h]h }(hjS^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@^hhhjR^hMJubj.)}(hj1h]h*}(hja^hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj@^hhhjR^hMJubj)}(h wdev_privh]j)}(h wdev_privh]h wdev_priv}(hjr^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjn^ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj@^hhhjR^hMJubj)}(h(struct wireless_dev *wdev)h]j)}(hstruct wireless_dev *wdevh](ju)}(hjh]hstruct}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj^ubj)}(h h]h }(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubh)}(hhh]j)}(h wireless_devh]h wireless_dev}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj^modnameN classnameNj j )}j ]j)}jjt^sb c.wdev_privasbuh1hhj^ubj)}(h h]h }(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubj.)}(hj1h]h*}(hj^hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj^ubj)}(hwdevh]hwdev}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj^ubah}(h]h ]h"]h$]h&]jjuh1jhj@^hhhjR^hMJubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj<^hhhjR^hMJubah}(h]j7^ah ](jjeh"]h$]h&]jj)jhuh1jhhjR^hMJhj9^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.hhMEhj_hhubah}(h]h ]h"]h$]h&]uh1jhj9^hhhjR^hMJubeh}(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)}(hj3_h]h Parameters}(hj5_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1_ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMIhj-_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)}(hjR_h]hstruct wireless_dev *wdev}(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.hhMGhjL_ubj6)}(hhh]h)}(h8The wireless device whose wiphy's priv pointer to returnh]h:The wireless device whose wiphy’s priv pointer to return}(hjk_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjg_hMGhjh_ubah}(h]h ]h"]h$]h&]uh1j5hjL_ubeh}(h]h ]h"]h$]h&]uh1jhjg_hMGhjI_ubah}(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&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMIhj-_ubh)}(hThe wiphy priv of **wdev**.h](hThe wiphy priv of }(hj_hhhNhNubj)}(h**wdev**h]hwdev}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_ubh.}(hj_hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMHhj-_ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_(cfg80211_check_combinations (C function)c.cfg80211_check_combinationshNtauh1jRhhhhhNhNubjd)}(hhh](ji)}(h^int cfg80211_check_combinations (struct wiphy *wiphy, struct iface_combination_params *params)h]jo)}(h]int cfg80211_check_combinations(struct wiphy *wiphy, struct iface_combination_params *params)h](j)}(hinth]hint}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM$ubj)}(h h]h }(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_hhhj_hM$ubj)}(hcfg80211_check_combinationsh]j)}(hcfg80211_check_combinationsh]hcfg80211_check_combinations}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj_hhhj_hM$ubj)}(h>(struct wiphy *wiphy, struct iface_combination_params *params)h](j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hj!`hhhNhNubah}(h]h ]jah"]h$]h&]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 reftargetjA`modnameN classnameNj j )}j ]j)}jj`sbc.cfg80211_check_combinationsasbuh1hhj`ubj)}(h h]h }(hj_`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubj.)}(hj1h]h*}(hjm`hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj`ubj)}(hwiphyh]hwiphy}(hjz`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj`ubj)}(h'struct iface_combination_params *paramsh](ju)}(hjh]hstruct}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj`ubj)}(h h]h }(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubh)}(hhh]j)}(hiface_combination_paramsh]hiface_combination_params}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj`modnameN classnameNj j )}j ]j[`c.cfg80211_check_combinationsasbuh1hhj`ubj)}(h h]h }(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubj.)}(hj1h]h*}(hj`hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj`ubj)}(hparamsh]hparams}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj`ubeh}(h]h ]h"]h$]h&]jjuh1jhj_hhhj_hM$ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj_hhhj_hM$ubah}(h]j_ah ](jjeh"]h$]h&]jj)jhuh1jhhj_hM$hj_hhubj)}(hhh]h)}(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$jj,ajj,ajjjuh1jchhhhhNhNubj)}(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)}(hj6ah]h Parameters}(hj8ahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4aubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM$hj0aubj)}(hhh](j)}(h"``struct wiphy *wiphy`` the wiphy h](j)}(h``struct wiphy *wiphy``h]j)}(hjUah]hstruct wiphy *wiphy}(hjWahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSaubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM$hjOaubj6)}(hhh]h)}(h the wiphyh]h the wiphy}(hjnahhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjahM$hjkaubah}(h]h ]h"]h$]h&]uh1j5hjOaubeh}(h]h ]h"]h$]h&]uh1jhjjahM$hjLaubj)}(hQ``struct iface_combination_params *params`` the interface combinations parameter h](j)}(h+``struct iface_combination_params *params``h]j)}(hjah]h'struct iface_combination_params *params}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM$hjaubj6)}(hhh]h)}(h$the interface combinations parameterh]h$the interface combinations parameter}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhjahM$hjaubah}(h]h ]h"]h$]h&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhjahM$hjLaubeh}(h]h ]h"]h$]h&]uh1jhj0aubh)}(h**Description**h]j)}(hjah]h Description}(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$hj0aubh)}(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.}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM$hj0aubh)}(h **Return**h]j)}(hjah]hReturn}(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$hj0aubh)}(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$hj0aubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubeh}(h]device-registrationah ]h"]device registrationah$]h&]uh1hhhhhhhhK ubh)}(hhh](h)}(hActions and configurationh]hActions and configuration}(hj'bhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$bhhhhhK+ubh)}(hX Each wireless device and each virtual interface offer a set of configuration operations and other actions that are invoked by userspace. Each of these actions is described in the operations structure, and the parameters these operations use are described separately.h]hX Each wireless device and each virtual interface offer a set of configuration operations and other actions that are invoked by userspace. Each of these actions is described in the operations structure, and the parameters these operations use are described separately.}(hj5bhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:45: ./include/net/cfg80211.hhMhj$bhhubh)}(hAdditionally, some operations are asynchronous and expect to get status information via some functions that drivers need to call.h]hAdditionally, some operations are asynchronous and expect to get status information via some functions that drivers need to call.}(hjDbhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:45: ./include/net/cfg80211.hhMhj$bhhubh)}(hdScanning and BSS list handling with its associated functionality is described in a separate chapter.h]hdScanning and BSS list handling with its associated functionality is described in a separate chapter.}(hjSbhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:45: ./include/net/cfg80211.hhMhj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_vif_params (C struct) c.vif_paramshNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(h vif_paramsh]jo)}(hstruct vif_paramsh](ju)}(hjh]hstruct}(hj{bhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjwbhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwbhhhjbhMubj)}(h vif_paramsh]j)}(hjubh]h vif_params}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjbubah}(h]h ](jjeh"]h$]h&]jjuh1jhjwbhhhjbhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjsbhhhjbhMubah}(h]jnbah ](jjeh"]h$]h&]jj)jhuh1jhhjbhMhjpbhhubj)}(hhh]h)}(h&describes virtual interface parametersh]h&describes virtual interface parameters}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjbhhubah}(h]h ]h"]h$]h&]uh1jhjpbhhhjbhMubeh}(h]h ](j$structeh"]h$]h&]jj$jjbjjbjjjuh1jchhhj$bhNhNubj)}(hX**Definition**:: struct vif_params { u32 flags; int use_4addr; u8 macaddr[ETH_ALEN]; const u8 *vht_mumimo_groups; const u8 *vht_mumimo_follow_addr; }; **Members** ``flags`` monitor interface flags, unchanged if 0, otherwise ``MONITOR_FLAG_CHANGED`` will be set ``use_4addr`` use 4-address frames ``macaddr`` address to use for this virtual interface. If this parameter is set to zero address the driver may determine the address as needed. This feature is only fully supported by drivers that enable the ``NL80211_FEATURE_MAC_ON_CREATE`` flag. Others may support creating * only p2p devices with specified MAC. ``vht_mumimo_groups`` MU-MIMO groupID, used for monitoring MU-MIMO packets belonging to that MU-MIMO groupID; ``NULL`` if not changed ``vht_mumimo_follow_addr`` MU-MIMO follow address, used for monitoring MU-MIMO packets going to the specified station; ``NULL`` if not changedh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjbhhhNhNubah}(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.hhMhjbubj( )}(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; };}hjbsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjbubh)}(h **Members**h]j)}(hj ch]hMembers}(hj chhhNhNubah}(h]h ]h"]h$]h&]uh1hhj cubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjbubj)}(hhh](j)}(hb``flags`` monitor interface flags, unchanged if 0, otherwise ``MONITOR_FLAG_CHANGED`` will be set h](j)}(h ``flags``h]j)}(hj*ch]hflags}(hj,chhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(cubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$cubj6)}(hhh]h)}(hWmonitor interface flags, unchanged if 0, otherwise ``MONITOR_FLAG_CHANGED`` will be seth](h3monitor interface flags, unchanged if 0, otherwise }(hjCchhhNhNubj)}(h``MONITOR_FLAG_CHANGED``h]hMONITOR_FLAG_CHANGED}(hjKchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCcubh will be set}(hjCchhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj@cubah}(h]h ]h"]h$]h&]uh1j5hj$cubeh}(h]h ]h"]h$]h&]uh1jhj?chMhj!cubj)}(h#``use_4addr`` use 4-address frames h](j)}(h ``use_4addr``h]j)}(hjvch]h use_4addr}(hjxchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtcubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjpcubj6)}(hhh]h)}(huse 4-address framesh]huse 4-address frames}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhjchMhjcubah}(h]h ]h"]h$]h&]uh1j5hjpcubeh}(Hh]h ]h"]h$]h&]uh1jhjchMhj!cubj)}(hX@``macaddr`` address to use for this virtual interface. If this parameter is set to zero address the driver may determine the address as needed. This feature is only fully supported by drivers that enable the ``NL80211_FEATURE_MAC_ON_CREATE`` flag. Others may support creating * only p2p devices with specified MAC. h](j)}(h ``macaddr``h]j)}(hjch]hmacaddr}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcubj6)}(hhh]h)}(hX3address to use for this virtual interface. If this parameter is set to zero address the driver may determine the address as needed. This feature is only fully supported by drivers that enable the ``NL80211_FEATURE_MAC_ON_CREATE`` flag. Others may support creating * only p2p devices with specified MAC.h](haddress to use for this virtual interface. If this parameter is set to zero address the driver may determine the address as needed. This feature is only fully supported by drivers that enable the }(hjchhhNhNubj)}(h!``NL80211_FEATURE_MAC_ON_CREATE``h]hNL80211_FEATURE_MAC_ON_CREATE}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubhN flag. Others may support creating * only p2p devices with specified MAC.}(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&]uh1jhjchMhj!cubj)}(h``vht_mumimo_groups`` MU-MIMO groupID, used for monitoring MU-MIMO packets belonging to that MU-MIMO groupID; ``NULL`` if not changed h](j)}(h``vht_mumimo_groups``h]j)}(hjch]hvht_mumimo_groups}(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)}(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&]uh1j5hjcubeh}(h]h ]h"]h$]h&]uh1jhjdhMhj!cubj)}(h``vht_mumimo_follow_addr`` MU-MIMO follow address, used for monitoring MU-MIMO packets going to the specified station; ``NULL`` if not changedh](j)}(h``vht_mumimo_follow_addr``h]j)}(hjGdh]hvht_mumimo_follow_addr}(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)}(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; }(hj`dhhhNhNubj)}(h``NULL``h]hNULL}(hjhdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`dubh if not changed}(hj`dhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj\dhMhj]dubah}(h]h ]h"]h$]h&]uh1j5hjAdubeh}(h]h ]h"]h$]h&]uh1jhj\dhMhj!cubeh}(h]h ]h"]h$]h&]uh1jhjbubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_key_params (C struct) c.key_paramshNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(h key_paramsh]jo)}(hstruct key_paramsh](ju)}(hjh]hstruct}(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjdhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdhhhjdhM ubj)}(h key_paramsh]j)}(hjdh]h key_params}(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdubah}(h]h ](jjeh"]h$]h&]jjuh1jhjdhhhjdhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjdhhhjdhM ubah}(h]jdah ](jjeh"]h$]h&]jj)jhuh1jhhjdhM hjdhhubj)}(hhh]h)}(hkey informationh]hkey information}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjdhhubah}(h]h ]h"]h$]h&]uh1jhjdhhhjdhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jj ejj ejjjuh1jchhhj$bhNhNubj)}(hX_**Definition**:: struct key_params { const u8 *key; const u8 *seq; int key_len; int seq_len; u16 vlan_id; u32 cipher; enum nl80211_key_mode mode; }; **Members** ``key`` key material ``seq`` sequence counter (IV/PN) for TKIP and CCMP keys, only used with the get_key() callback, must be in little endian, length given by **seq_len**. ``key_len`` length of key material ``seq_len`` length of **seq**. ``vlan_id`` vlan_id for VLAN group key (if nonzero) ``cipher`` cipher suite selector ``mode`` key install mode (RX_TX, NO_TX or SET_TX)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(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; };}hj1esbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjeubh)}(h **Members**h]j)}(hjBeh]hMembers}(hjDehhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@eubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjeubj)}(hhh](j)}(h``key`` key material h](j)}(h``key``h]j)}(hjaeh]hkey}(hjcehhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_eubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj[eubj6)}(hhh]h)}(h key materialh]h key material}(hjzehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvehMhjweubah}(h]h ]h"]h$]h&]uh1j5hj[eubeh}(h]h ]h"]h$]h&]uh1jhjvehMhjXeubj)}(h``seq`` sequence counter (IV/PN) for TKIP and CCMP keys, only used with the get_key() callback, must be in little endian, length given by **seq_len**. h](j)}(h``seq``h]j)}(hjeh]hseq}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjeubj6)}(hhh]h)}(hsequence counter (IV/PN) for TKIP and CCMP keys, only used with the get_key() callback, must be in little endian, length given by **seq_len**.h](hsequence counter (IV/PN) for TKIP and CCMP keys, only used with the get_key() callback, must be in little endian, length given by }(hjehhhNhNubj)}(h **seq_len**h]hseq_len}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjeubh.}(hjehhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjeubah}(h]h ]h"]h$]h&]uh1j5hjeubeh}(h]h ]h"]h$]h&]uh1jhjehMhjXeubj)}(h#``key_len`` length of key material h](j)}(h ``key_len``h]j)}(hjeh]hkey_len}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjeubj6)}(hhh]h)}(hlength of key materialh]hlength of key material}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehMhjeubah}(h]h ]h"]h$]h&]uh1j5hjeubeh}(h]h ]h"]h$]h&]uh1jhjehMhjXeubj)}(h``seq_len`` length of **seq**. h](j)}(h ``seq_len``h]j)}(hjfh]hseq_len}(hj!fhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjfubj6)}(hhh]h)}(hlength of **seq**.h](h length of }(hj8fhhhNhNubj)}(h**seq**h]hseq}(hj@fhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8fubh.}(hj8fhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj4fhMhj5fubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhj4fhMhjXeubj)}(h4``vlan_id`` vlan_id for VLAN group key (if nonzero) h](j)}(h ``vlan_id``h]j)}(hjjfh]hvlan_id}(hjlfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhfubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjdfubj6)}(hhh]h)}(h'vlan_id for VLAN group key (if nonzero)h]h'vlan_id for VLAN group key (if nonzero)}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhMhjfubah}(h]h ]h"]h$]h&]uh1j5hjdfubeh}(h]h ]h"]h$]h&]uh1jhjfhMhjXeubj)}(h!``cipher`` cipher suite selector h](j)}(h ``cipher``h]j)}(hjfh]hcipher}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjfubj6)}(hhh]h)}(hcipher suite selectorh]hcipher suite selector}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhMhjfubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhjfhMhjXeubj)}(h2``mode`` key install mode (RX_TX, NO_TX or SET_TX)h](j)}(h``mode``h]j)}(hjfh]hmode}(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 install mode (RX_TX, NO_TX or SET_TX)h]h)key install mode (RX_TX, NO_TX or SET_TX)}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjfubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhjfhMhjXeubeh}(h]h ]h"]h$]h&]uh1jhjeubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjgh]h Description}(hj!ghhhNhNubah}(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.hhM!hj$bhhubh)}(hInformation about a keyh]hInformation about a key}(hj5ghhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_survey_info_flags (C enum)c.survey_info_flagshNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hsurvey_info_flagsh]jo)}(henum survey_info_flagsh](ju)}(hjxh]henum}(hj]ghhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjYghhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjkghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjYghhhjjghMubj)}(hsurvey_info_flagsh]j)}(hjWgh]hsurvey_info_flags}(hj}ghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjygubah}(h]h ](jjeh"]h$]h&]jjuh1jhjYghhhjjghMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjUghhhjjghMubah}(h]jPgah ](jjeh"]h$]h&]jj)jhuh1jhhjjghMhjRghhubj)}(hhh]h)}(hsurvey information flagsh]hsurvey information flags}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjghhubah}(h]h ]h"]h$]h&]uh1jhjRghhhjjghMubeh}(h]h ](j$enumeh"]h$]h&]jj$jjgjjgjjjuh1jchhhj$bhNhNubj)}(hX!**Constants** ``SURVEY_INFO_NOISE_DBM`` noise (in dBm) was filled in ``SURVEY_INFO_IN_USE`` channel is currently being used ``SURVEY_INFO_TIME`` active time (in ms) was filled in ``SURVEY_INFO_TIME_BUSY`` busy time was filled in ``SURVEY_INFO_TIME_EXT_BUSY`` extension channel busy time was filled in ``SURVEY_INFO_TIME_RX`` receive time was filled in ``SURVEY_INFO_TIME_TX`` transmit time was filled in ``SURVEY_INFO_TIME_SCAN`` scan time was filled in ``SURVEY_INFO_TIME_BSS_RX`` local BSS receive time was filled inh](h)}(h **Constants**h]j)}(hjgh]h Constants}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjgubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjgubj)}(hhh](j)}(h7``SURVEY_INFO_NOISE_DBM`` noise (in dBm) was filled in h](j)}(h``SURVEY_INFO_NOISE_DBM``h]j)}(hjgh]hSURVEY_INFO_NOISE_DBM}(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)}(hnoise (in dBm) was filled inh]hnoise (in dBm) was filled in}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjghMhjgubah}(h]h ]h"]h$]h&]uh1j5hjgubeh}(h]h ]h"]h$]h&]uh1jhjghMhjgubj)}(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}(hj2hhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.hhMhj/hubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhj.hhMhjgubj)}(h7``SURVEY_INFO_TIME`` active time (in ms) was filled in h](j)}(h``SURVEY_INFO_TIME``h]j)}(hjRhh]hSURVEY_INFO_TIME}(hjThhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPhubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjLhubj6)}(hhh]h)}(h!active time (in ms) was filled inh]h!active time (in ms) was filled in}(hjkhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjghhMhjhhubah}(h]h ]h"]h$]h&]uh1j5hjLhubeh}(h]h ]h"]h$]h&]uh1jhjghhMhjgubj)}(h2``SURVEY_INFO_TIME_BUSY`` busy time was filled in h](j)}(h``SURVEY_INFO_TIME_BUSY``h]j)}(hjhh]hSURVEY_INFO_TIME_BUSY}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhubj6)}(hhh]h)}(hbusy time was filled inh]hbusy time was filled in}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhMhjhubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhhMhjgubj)}(hH``SURVEY_INFO_TIME_EXT_BUSY`` extension channel busy time was filled in h](j)}(h``SURVEY_INFO_TIME_EXT_BUSY``h]j)}(hjhh]hSURVEY_INFO_TIME_EXT_BUSY}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhubj6)}(hhh]h)}(h)extension channel busy time was filled inh]h)extension channel busy time was filled in}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhMhjhubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhhMhjgubj)}(h3``SURVEY_INFO_TIME_RX`` receive time was filled in h](j)}(h``SURVEY_INFO_TIME_RX``h]j)}(hjhh]hSURVEY_INFO_TIME_RX}(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)}(hreceive time was filled inh]hreceive time was filled in}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihMhjiubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjihMhjgubj)}(h4``SURVEY_INFO_TIME_TX`` transmit time was filled in h](j)}(h``SURVEY_INFO_TIME_TX``h]j)}(hj6ih]hSURVEY_INFO_TIME_TX}(hj8ihhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4iubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj0iubj6)}(hhh]h)}(htransmit time was filled inh]htransmit time was filled in}(hjOihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKihMhjLiubah}(h]h ]h"]h$]h&]uh1j5hj0iubeh}(h]h ]h"]h$]h&]uh1jhjKihMhjgubj)}(h2``SURVEY_INFO_TIME_SCAN`` scan time was filled in h](j)}(h``SURVEY_INFO_TIME_SCAN``h]j)}(hjoih]hSURVEY_INFO_TIME_SCAN}(hjqihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmiubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjiiubj6)}(hhh]h)}(hscan time was filled inh]hscan time was filled in}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihMhjiubah}(h]h ]h"]h$]h&]uh1j5hjiiubeh}(h]h ]h"]h$]h&]uh1jhjihMhjgubj)}(h@``SURVEY_INFO_TIME_BSS_RX`` local BSS receive time was filled inh](j)}(h``SURVEY_INFO_TIME_BSS_RX``h]j)}(hjih]hSURVEY_INFO_TIME_BSS_RX}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjiubj6)}(hhh]h)}(h$local BSS receive time was filled inh]h$local BSS receive time was filled in}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjiubah}(h]h ]h"]h$]h&]uh1j5hjiubeh}(h]h ]h"]h$]h&]uh1jhjihMhjgubeh}(h]h ]h"]h$]h&]uh1jhjgubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjih]h Description}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjiubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$bhhubh)}(hUsed by the driver to indicate which info in :c:type:`struct survey_info ` it has filled in during the get_survey().h](h-Used by the driver to indicate which info in }(hjjhhhNhNubh)}(h*:c:type:`struct survey_info `h]j)}(hj jh]hstruct survey_info}(hj jhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj jubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6 survey_infouh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubh* it has filled in during the get_survey().}(hjjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj(jhMhj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_survey_info (C struct) c.survey_infohNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(h survey_infoh]jo)}(hstruct survey_infoh](ju)}(hjh]hstruct}(hjLjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjHjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjZjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHjhhhjYjhMubj)}(h survey_infoh]j)}(hjFjh]h survey_info}(hjljhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjHjhhhjYjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjDjhhhjYjhMubah}(h]j?jah ](jjeh"]h$]h&]jj)jhuh1jhhjYjhMhjAjhhubj)}(hhh]h)}(hchannel survey responseh]hchannel survey response}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjhhubah}(h]h ]h"]h$]h&]uh1jhjAjhhhjYjhMubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjjjuh1jchhhj$bhNhNubj)}(hX**Definition**:: struct survey_info { struct ieee80211_channel *channel; u64 time; u64 time_busy; u64 time_ext_busy; u64 time_rx; u64 time_tx; u64 time_scan; u64 time_bss_rx; u32 filled; s8 noise; }; **Members** ``channel`` the channel this survey record reports, may be ``NULL`` for a single record to report global statistics ``time`` amount of time in ms the radio was turn on (on the channel) ``time_busy`` amount of time the primary channel was sensed busy ``time_ext_busy`` amount of time the extension channel was sensed busy ``time_rx`` amount of time the radio spent receiving data ``time_tx`` amount of time the radio spent transmitting data ``time_scan`` amount of time the radio spent for scanning ``time_bss_rx`` amount of time the radio spent receiving data on a local BSS ``filled`` bitflag of flags from :c:type:`enum survey_info_flags ` ``noise`` channel noise in dBm. This and all following fields are optionalh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjubh:}(hjjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubj( )}(hstruct survey_info { struct ieee80211_channel *channel; u64 time; u64 time_busy; u64 time_ext_busy; u64 time_rx; u64 time_tx; u64 time_scan; u64 time_bss_rx; u32 filled; s8 noise; };h]hstruct survey_info { struct ieee80211_channel *channel; u64 time; u64 time_busy; u64 time_ext_busy; u64 time_rx; u64 time_tx; u64 time_scan; u64 time_bss_rx; u32 filled; s8 noise; };}hjjsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubh)}(h **Members**h]j)}(hjjh]hMembers}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubj)}(hhh](j)}(ht``channel`` the channel this survey record reports, may be ``NULL`` for a single record to report global statistics h](j)}(h ``channel``h]j)}(hjjh]hchannel}(hjjhhhNhNubah}(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.hhMhjjubj6)}(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&]uh1j5hjjubeh}(h]h ]h"]h$]h&]uh1jhjkhMhjjubj)}(hE``time`` amount of time in ms the radio was turn on (on the channel) h](j)}(h``time``h]j)}(hjGkh]htime}(hjIkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEkubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjAkubj6)}(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)}(hj`khhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\khMhj]kubah}(h]h ]h"]h$]h&]uh1j5hjAkubeh}(h]h ]h"]h$]h&]uh1jhj\khMhjjubj)}(hA``time_busy`` amount of time the primary channel was sensed busy h](j)}(h ``time_busy``h]j)}(hjkh]h time_busy}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~kubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjzkubj6)}(hhh]h)}(h2amount of time the primary channel was sensed busyh]h2amount of time the primary channel was sensed busy}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkhMhjkubah}(h]h ]h"]h$]h&]uh1j5hjzkubeh}(h]h ]h"]h$]h&]uh1jhjkhMhjjubj)}(hG``time_ext_busy`` amount of time the extension channel was sensed busy h](j)}(h``time_ext_busy``h]j)}(hjkh]h time_ext_busy}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjkubj6)}(hhh]h)}(h4amount of time the extension channel was sensed busyh]h4amount of time the extension channel was sensed busy}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkhMhjkubah}(h]h ]h"]h$]h&]uh1j5hjkubeh}(h]h ]h"]h$]h&]uh1jhjkhMhjjubj)}(h:``time_rx`` amount of time the radio spent receiving data h](j)}(h ``time_rx``h]j)}(hjkh]htime_rx}(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)}(h-amount of time the radio spent receiving datah]h-amount of time the radio spent receiving data}(hj lhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhMhjlubah}(h]h ]h"]h$]h&]uh1j5hjkubeh}(h]h ]h"]h$]h&]uh1jhjlhMhjjubj)}(h=``time_tx`` amount of time the radio spent transmitting data h](j)}(h ``time_tx``h]j)}(hj+lh]htime_tx}(hj-lhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)lubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj%lubj6)}(hhh]h)}(h0amount of time the radio spent transmitting datah]h0amount of time the radio spent transmitting data}(hjDlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@lhMhjAlubah}(h]h ]h"]h$]h&]uh1j5hj%lubeh}(h]h ]h"]h$]h&]uh1jhj@lhMhjjubj)}(h:``time_scan`` amount of time the radio spent for scanning h](j)}(h ``time_scan``h]j)}(hjdlh]h time_scan}(hjflhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjblubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^lubj6)}(hhh]h)}(h+amount of time the radio spent for scanningh]h+amount of time the radio spent for scanning}(hj}lhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjylhMhjzlubah}(h]h ]h"]h$]h&]uh1j5hj^lubeh}(h]h ]h"]h$]h&]uh1jhjylhMhjjubj)}(hM``time_bss_rx`` amount of time the radio spent receiving data on a local BSS h](j)}(h``time_bss_rx``h]j)}(hjlh]h time_bss_rx}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjlubj6)}(hhh]h)}(h` h](j)}(h ``filled``h]j)}(hjlh]hfilled}(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)}(hJbitflag of flags from :c:type:`enum survey_info_flags `h](hbitflag of flags from }(hjlhhhNhNubh)}(h4:c:type:`enum survey_info_flags `h]j)}(hjlh]henum survey_info_flags}(hjlhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6survey_info_flagsuh1hhjlhMhjlubeh}(h]h ]h"]h$]h&]uh1hhjlhMhjlubah}(h]h ]h"]h$]h&]uh1j5hjlubeh}(h]h ]h"]h$]h&]uh1jhjlhMhjjubj)}(hJ``noise`` channel noise in dBm. This and all following fields are optionalh](j)}(h ``noise``h]j)}(hj.mh]hnoise}(hj0mhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,mubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj(mubj6)}(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}(hjGmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjCmhMhjDmubah}(h]h ]h"]h$]h&]uh1j5hj(mubeh}(h]h ]h"]h$]h&]uh1jhjCmhMhjjubeh}(h]h ]h"]h$]h&]uh1jhjjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjpmh]h Description}(hjrmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnmubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$bhhubh)}(hDUsed by dump_survey() to report back per-channel survey information.h]hDUsed by dump_survey() to report back per-channel survey information.}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$bhhubh)}(hMThis structure can later be expanded with things like channel duty cycle etc.h]hMThis structure can later be expanded with things like channel duty cycle etc.}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_#cfg80211_crypto_settings (C struct)c.cfg80211_crypto_settingshNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hcfg80211_crypto_settingsh]jo)}(hstruct cfg80211_crypto_settingsh](ju)}(hjh]hstruct}(hjmhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjmhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjmhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjmhhhjmhMubj)}(hcfg80211_crypto_settingsh]j)}(hjmh]hcfg80211_crypto_settings}(hjmhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjmubah}(h]h ](jjeh"]h$]h&]jjuh1jhjmhhhjmhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjmhhhjmhMubah}(h]jmah ](jjeh"]h$]h&]jj)jhuh1jhhjmhMhjmhhubj)}(hhh]h)}(hCrypto settingsh]hCrypto settings}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjmhhubah}(h]h ]h"]h$]h&]uh1jhjmhhhjmhMubeh}(h]h ](j$structeh"]h$]h&]jj$jjnjjnjjjuh1jchhhj$bhNhNubj)}(hX **Definition**:: struct cfg80211_crypto_settings { u32 wpa_versions; u32 cipher_group; int n_ciphers_pairwise; u32 ciphers_pairwise[NL80211_MAX_NR_CIPHER_SUITES]; int n_akm_suites; u32 akm_suites[CFG80211_MAX_NUM_AKM_SUITES]; bool control_port; __be16 control_port_ethertype; bool control_port_no_encrypt; bool control_port_over_nl80211; bool control_port_no_preauth; const u8 *psk; const u8 *sae_pwd; u8 sae_pwd_len; enum nl80211_sae_pwe_mechanism sae_pwe; }; **Members** ``wpa_versions`` indicates which, if any, WPA versions are enabled (from enum nl80211_wpa_versions) ``cipher_group`` group key cipher suite (or 0 if unset) ``n_ciphers_pairwise`` number of AP supported unicast ciphers ``ciphers_pairwise`` unicast key cipher suites ``n_akm_suites`` number of AKM suites ``akm_suites`` AKM suites ``control_port`` Whether user space controls IEEE 802.1X port, i.e., sets/clears ``NL80211_STA_FLAG_AUTHORIZED``. If true, the driver is required to assume that the port is unauthorized until authorized by user space. Otherwise, port is marked authorized by default. ``control_port_ethertype`` the control port protocol that should be allowed through even on unauthorized ports ``control_port_no_encrypt`` TRUE to prevent encryption of control port protocol frames. ``control_port_over_nl80211`` TRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface. ``control_port_no_preauth`` disables pre-auth rx over the nl80211 control port for mac80211 ``psk`` PSK (for devices supporting 4-way-handshake offload) ``sae_pwd`` password for SAE authentication (for devices supporting SAE offload) ``sae_pwd_len`` length of SAE password (for devices supporting SAE offload) ``sae_pwe`` The mechanisms allowed for SAE PWE derivation: NL80211_SAE_PWE_UNSPECIFIED Not-specified, used to indicate userspace did not specify any preference. The driver should follow its internal policy in such a scenario. NL80211_SAE_PWE_HUNT_AND_PECK Allow hunting-and-pecking loop only NL80211_SAE_PWE_HASH_TO_ELEMENT Allow hash-to-element only NL80211_SAE_PWE_BOTH Allow either hunting-and-pecking loop or hash-to-elementh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj#nhhhNhNubah}(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; };}hj``n_ciphers_pairwise`` number of AP supported unicast ciphers h](j)}(h``n_ciphers_pairwise``h]j)}(hjnh]hn_ciphers_pairwise}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjnubj6)}(hhh]h)}(h&number of AP supported unicast ciphersh]h&number of AP supported unicast ciphers}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhMhjnubah}(h]h ]h"]h$]h&]uh1j5hjnubeh}(h]h ]h"]h$]h&]uh1jhjnhMhjcnubj)}(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}(hj1ohhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-ohMhj.oubah}(h]h ]h"]h$]h&]uh1j5hjoubeh}(h]h ]h"]h$]h&]uh1jhj-ohMhjcnubj)}(h&``n_akm_suites`` number of AKM suites h](j)}(h``n_akm_suites``h]j)}(hjQoh]h n_akm_suites}(hjSohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOoubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjKoubj6)}(hhh]h)}(hnumber of AKM suitesh]hnumber of AKM suites}(hjjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfohMhjgoubah}(h]h ]h"]h$]h&]uh1j5hjKoubeh}(h]h ]h"]h$]h&]uh1jhjfohMhjcnubj)}(h``akm_suites`` AKM suites h](j)}(h``akm_suites``h]j)}(hjoh]h akm_suites}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjoubj6)}(hhh]h)}(h AKM suitesh]h AKM suites}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjohMhjoubah}(h]h ]h"]h$]h&]uh1j5hjoubeh}(h]h ]h"]h$]h&]uh1jhjohMhjcnubj)}(hX ``control_port`` Whether user space controls IEEE 802.1X port, i.e., sets/clears ``NL80211_STA_FLAG_AUTHORIZED``. If true, the driver is required to assume that the port is unauthorized until authorized by user space. Otherwise, port is marked authorized by default. h](j)}(h``control_port``h]j)}(hjoh]h control_port}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjoubj6)}(hhh]h)}(hWhether user space controls IEEE 802.1X port, i.e., sets/clears ``NL80211_STA_FLAG_AUTHORIZED``. If true, the driver is required to assume that the port is unauthorized until authorized by user space. Otherwise, port is marked authorized by default.h](h@Whether user space controls IEEE 802.1X port, i.e., sets/clears }(hjohhhNhNubj)}(h``NL80211_STA_FLAG_AUTHORIZED``h]hNL80211_STA_FLAG_AUTHORIZED}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubh. 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.}(hjohhhNhNubeh}(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&]uh1j5hjoubeh}(h]h ]h"]h$]h&]uh1jhjohMhjcnubj)}(ho``control_port_ethertype`` the control port protocol that should be allowed through even on unauthorized ports h](j)}(h``control_port_ethertype``h]j)}(hjph]hcontrol_port_ethertype}(hjphhhNhNubah}(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.hhMhj pubj6)}(hhh]h)}(hSthe control port protocol that should be allowed through even on unauthorized portsh]hSthe control port protocol that should be allowed through even on unauthorized ports}(hj(phhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj%pubah}(h]h ]h"]h$]h&]uh1j5hj pubeh}(h]h ]h"]h$]h&]uh1jhj$phMhjcnubj)}(hX``control_port_no_encrypt`` TRUE to prevent encryption of control port protocol frames. h](j)}(h``control_port_no_encrypt``h]j)}(hjIph]hcontrol_port_no_encrypt}(hjKphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGpubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjCpubj6)}(hhh]h)}(h;TRUE to prevent encryption of control port protocol frames.h]h;TRUE to prevent encryption of control port protocol frames.}(hjbphhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj_pubah}(h]h ]h"]h$]h&]uh1j5hjCpubeh}(h]h ]h"]h$]h&]uh1jhj^phMhjcnubj)}(h``control_port_over_nl80211`` TRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface. h](j)}(h``control_port_over_nl80211``h]j)}(hjph]hcontrol_port_over_nl80211}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj}pubj6)}(hhh]h)}(hhTRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface.h]hhTRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface.}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjpubah}(h]h ]h"]h$]h&]uh1j5hj}pubeh}(h]h ]h"]h$]h&]uh1jhjphMhjcnubj)}(h\``control_port_no_preauth`` disables pre-auth rx over the nl80211 control port for mac80211 h](j)}(h``control_port_no_preauth``h]j)}(hjph]hcontrol_port_no_preauth}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjpubj6)}(hhh]h)}(h?disables pre-auth rx over the nl80211 control port for mac80211h]h?disables pre-auth rx over the nl80211 control port for mac80211}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjpubah}(h]h ]h"]h$]h&]uh1j5hjpubeh}(h]h ]h"]h$]h&]uh1jhjphMhjcnubj)}(h=``psk`` PSK (for devices supporting 4-way-handshake offload) h](j)}(h``psk``h]j)}(hjph]hpsk}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjpubj6)}(hhh]h)}(h4PSK (for devices supporting 4-way-handshake offload)h]h4PSK (for devices supporting 4-way-handshake offload)}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj qhMhj qubah}(h]h ]h"]h$]h&]uh1j5hjpubeh}(h]h ]h"]h$]h&]uh1jhj qhMhjcnubj)}(hQ``sae_pwd`` password for SAE authentication (for devices supporting SAE offload) h](j)}(h ``sae_pwd``h]j)}(hj0qh]hsae_pwd}(hj2qhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.qubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj*qubj6)}(hhh]h)}(hDpassword for SAE authentication (for devices supporting SAE offload)h]hDpassword for SAE authentication (for devices supporting SAE offload)}(hjIqhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjFqubah}(h]h ]h"]h$]h&]uh1j5hj*qubeh}(h]h ]h"]h$]h&]uh1jhjEqhMhjcnubj)}(hL``sae_pwd_len`` length of SAE password (for devices supporting SAE offload) h](j)}(h``sae_pwd_len``h]j)}(hjjqh]h sae_pwd_len}(hjlqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhqubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjdqubj6)}(hhh]h)}(h;length of SAE password (for devices supporting SAE offload)h]h;length of SAE password (for devices supporting SAE offload)}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjqhMhjqubah}(h]h ]h"]h$]h&]uh1j5hjdqubeh}(h]h ]h"]h$]h&]uh1jhjqhMhjcnubj)}(hX``sae_pwe`` The mechanisms allowed for SAE PWE derivation: NL80211_SAE_PWE_UNSPECIFIED Not-specified, used to indicate userspace did not specify any preference. The driver should follow its internal policy in such a scenario. NL80211_SAE_PWE_HUNT_AND_PECK Allow hunting-and-pecking loop only NL80211_SAE_PWE_HASH_TO_ELEMENT Allow hash-to-element only NL80211_SAE_PWE_BOTH Allow either hunting-and-pecking loop or hash-to-elementh](j)}(h ``sae_pwe``h]j)}(hjqh]hsae_pwe}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqubj6)}(hhh](h)}(h.The mechanisms allowed for SAE PWE derivation:h]h.The mechanisms allowed for SAE PWE derivation:}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqubj)}(hhh](j)}(hNL80211_SAE_PWE_UNSPECIFIED Not-specified, used to indicate userspace did not specify any preference. The driver should follow its internal policy in such a scenario. h](j)}(hNL80211_SAE_PWE_UNSPECIFIEDh]hNL80211_SAE_PWE_UNSPECIFIED}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqubj6)}(hhh]h)}(hNot-specified, used to indicate userspace did not specify any preference. The driver should follow its internal policy in such a scenario.h]hNot-specified, used to indicate userspace did not specify any preference. The driver should follow its internal policy in such a scenario.}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqubah}(h]h ]h"]h$]h&]uh1j5hjqubeh}(h]h ]h"]h$]h&]uh1jhjqhMhjqubj)}(hBNL80211_SAE_PWE_HUNT_AND_PECK Allow hunting-and-pecking loop only h](j)}(hNL80211_SAE_PWE_HUNT_AND_PECKh]hNL80211_SAE_PWE_HUNT_AND_PECK}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqubj6)}(hhh]h)}(h#Allow hunting-and-pecking loop onlyh]h#Allow hunting-and-pecking loop only}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjrhMhjrubah}(h]h ]h"]h$]h&]uh1j5hjqubeh}(h]h ]h"]h$]h&]uh1jhjrhMhjqubj)}(h;NL80211_SAE_PWE_HASH_TO_ELEMENT Allow hash-to-element only h](j)}(hNL80211_SAE_PWE_HASH_TO_ELEMENTh]hNL80211_SAE_PWE_HASH_TO_ELEMENT}(hj3rhhhNhNubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj/rubj6)}(hhh]h)}(hAllow hash-to-element onlyh]hAllow hash-to-element only}(hjErhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjArhMhjBrubah}(h]h ]h"]h$]h&]uh1j5hj/rubeh}(h]h ]h"]h$]h&]uh1jhjArhMhjqubj)}(hMNL80211_SAE_PWE_BOTH Allow either hunting-and-pecking loop or hash-to-elementh](j)}(hNL80211_SAE_PWE_BOTHh]hNL80211_SAE_PWE_BOTH}(hjcrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqhMhj_rubj6)}(hhh]h)}(h8Allow either hunting-and-pecking loop or hash-to-elementh]h8Allow either hunting-and-pecking loop or hash-to-element}(hjtrhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqrubah}(h]h ]h"]h$]h&]uh1j5hj_rubeh}(h]h ]h"]h$]h&]uh1jhjqhMhjqubeh}(h]h ]h"]h$]h&]uh1jhjqubeh}(h]h ]h"]h$]h&]uh1j5hjqubeh}(h]h ]h"]h$]h&]uh1jhjqhMhjcnubeh}(h]h ]h"]h$]h&]uh1jhjnubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_beacon_data (C struct)c.cfg80211_beacon_datahNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hcfg80211_beacon_datah]jo)}(hstruct cfg80211_beacon_datah](ju)}(hjh]hstruct}(hjrhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjrhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjrhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjrhhhjrhMubj)}(hcfg80211_beacon_datah]j)}(hjrh]hcfg80211_beacon_data}(hjrhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjrubah}(h]h ](jjeh"]h$]h&]jjuh1jhjrhhhjrhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjrhhhjrhMubah}(h]jrah ](jjeh"]h$]h&]jj)jhuh1jhhjrhMhjrhhubj)}(hhh]h)}(h beacon datah]h beacon data}(hj shhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMChjshhubah}(h]h ]h"]h$]h&]uh1jhjrhhhjrhMubeh}(h]h ](j$structeh"]h$]h&]jj$jj!sjj!sjjjuh1jchhhj$bhNhNubj)}(hX**Definition**:: struct cfg80211_beacon_data { unsigned int link_id; const u8 *head, *tail; const u8 *beacon_ies; const u8 *proberesp_ies; const u8 *assocresp_ies; const u8 *probe_resp; const u8 *lci; const u8 *civicloc; struct cfg80211_mbssid_elems *mbssid_ies; struct cfg80211_rnr_elems *rnr_ies; s8 ftm_responder; size_t head_len, tail_len; size_t beacon_ies_len; size_t proberesp_ies_len; size_t assocresp_ies_len; size_t probe_resp_len; size_t lci_len; size_t civicloc_len; struct cfg80211_he_bss_color he_bss_color; bool he_bss_color_valid; }; **Members** ``link_id`` the link ID for the AP MLD link sending this beacon ``head`` head portion of beacon (before TIM IE) or ``NULL`` if not changed ``tail`` tail portion of beacon (after TIM IE) or ``NULL`` if not changed ``beacon_ies`` extra information element(s) to add into Beacon frames or ``NULL`` ``proberesp_ies`` extra information element(s) to add into Probe Response frames or ``NULL`` ``assocresp_ies`` extra information element(s) to add into (Re)Association Response frames or ``NULL`` ``probe_resp`` probe response template (AP mode only) ``lci`` Measurement Report element content, starting with Measurement Token (measurement type 8) ``civicloc`` Measurement Report element content, starting with Measurement Token (measurement type 11) ``mbssid_ies`` multiple BSSID elements ``rnr_ies`` reduced neighbor report elements ``ftm_responder`` enable FTM responder functionality; -1 for no change (which also implies no change in LCI/civic location data) ``head_len`` length of **head** ``tail_len`` length of **tail** ``beacon_ies_len`` length of beacon_ies in octets ``proberesp_ies_len`` length of proberesp_ies in octets ``assocresp_ies_len`` length of assocresp_ies in octets ``probe_resp_len`` length of probe response template (**probe_resp**) ``lci_len`` LCI data length ``civicloc_len`` Civic location data length ``he_bss_color`` BSS Color settings ``he_bss_color_valid`` indicates whether bss color attribute is present in beacon data or not.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj-shhhNhNubah}(h]h ]h"]h$]h&]uh1hhj)subh:}(hj)shhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMGhj%subj( )}(hXdstruct cfg80211_beacon_data { unsigned int link_id; const u8 *head, *tail; const u8 *beacon_ies; const u8 *proberesp_ies; const u8 *assocresp_ies; const u8 *probe_resp; const u8 *lci; const u8 *civicloc; struct cfg80211_mbssid_elems *mbssid_ies; struct cfg80211_rnr_elems *rnr_ies; s8 ftm_responder; size_t head_len, tail_len; size_t beacon_ies_len; size_t proberesp_ies_len; size_t assocresp_ies_len; size_t probe_resp_len; size_t lci_len; size_t civicloc_len; struct cfg80211_he_bss_color he_bss_color; bool he_bss_color_valid; };h]hXdstruct cfg80211_beacon_data { unsigned int link_id; const u8 *head, *tail; const u8 *beacon_ies; const u8 *proberesp_ies; const u8 *assocresp_ies; const u8 *probe_resp; const u8 *lci; const u8 *civicloc; struct cfg80211_mbssid_elems *mbssid_ies; struct cfg80211_rnr_elems *rnr_ies; s8 ftm_responder; size_t head_len, tail_len; size_t beacon_ies_len; size_t proberesp_ies_len; size_t assocresp_ies_len; size_t probe_resp_len; size_t lci_len; size_t civicloc_len; struct cfg80211_he_bss_color he_bss_color; bool he_bss_color_valid; };}hjFssbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMIhj%subh)}(h **Members**h]j)}(hjWsh]hMembers}(hjYshhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUsubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM`hj%subj)}(hhh](j)}(h@``link_id`` the link ID for the AP MLD link sending this beacon h](j)}(h ``link_id``h]j)}(hjvsh]hlink_id}(hjxshhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtsubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMEhjpsubj6)}(hhh]h)}(h3the link ID for the AP MLD link sending this beaconh]h3the link ID for the AP MLD link sending this beacon}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhjshMEhjsubah}(h]h ]h"]h$]h&]uh1j5hjpsubeh}(h]h ]h"]h$]h&]uh1jhjshMEhjmsubj)}(hK``head`` head portion of beacon (before TIM IE) or ``NULL`` if not changed h](j)}(h``head``h]j)}(hjsh]hhead}(hjshhhNhNubah}(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.hhMGhjsubj6)}(hhh]h)}(hAhead portion of beacon (before TIM IE) or ``NULL`` if not changedh](h*head portion of beacon (before TIM IE) or }(hjshhhNhNubj)}(h``NULL``h]hNULL}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubh if not changed}(hjshhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMFhjsubah}(h]h ]h"]h$]h&]uh1j5hjsubeh}(h]h ]h"]h$]h&]uh1jhjshMGhjmsubj)}(hJ``tail`` tail portion of beacon (after TIM IE) or ``NULL`` if not changed h](j)}(h``tail``h]j)}(hjsh]htail}(hjshhhNhNubah}(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.hhMIhjsubj6)}(hhh]h)}(h@tail portion of beacon (after TIM IE) or ``NULL`` if not changedh](h)tail portion of beacon (after TIM IE) or }(hjthhhNhNubj)}(h``NULL``h]hNULL}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtubh if not changed}(hjthhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMHhjtubah}(h]h ]h"]h$]h&]uh1j5hjsubeh}(h]h ]h"]h$]h&]uh1jhjthMIhjmsubj)}(hR``beacon_ies`` extra information element(s) to add into Beacon frames or ``NULL`` h](j)}(h``beacon_ies``h]j)}(hjGth]h beacon_ies}(hjIthhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEtubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMLhjAtubj6)}(hhh]h)}(hBextra information element(s) to add into Beacon frames or ``NULL``h](h:extra information element(s) to add into Beacon frames or }(hj`thhhNhNubj)}(h``NULL``h]hNULL}(hjhthhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`tubeh}(h]h ]h"]h$]h&]uh1hhj\thMLhj]tubah}(h]h ]h"]h$]h&]uh1j5hjAtubeh}(h]h ]h"]h$]h&]uh1jhj\thMLhjmsubj)}(h]``proberesp_ies`` extra information element(s) to add into Probe Response frames or ``NULL`` h](j)}(h``proberesp_ies``h]j)}(hjth]h proberesp_ies}(hjthhhNhNubah}(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.hhMOhjtubj6)}(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 }(hjthhhNhNubj)}(h``NULL``h]hNULL}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMNhjtubah}(h]h ]h"]h$]h&]uh1j5hjtubeh}(h]h ]h"]h$]h&]uh1jhjthMOhjmsubj)}(hg``assocresp_ies`` extra information element(s) to add into (Re)Association Response frames or ``NULL`` h](j)}(h``assocresp_ies``h]j)}(hjth]h assocresp_ies}(hjthhhNhNubah}(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.hhMRhjtubj6)}(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 }(hjthhhNhNubj)}(h``NULL``h]hNULL}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMQhjtubah}(h]h ]h"]h$]h&]uh1j5hjtubeh}(h]h ]h"]h$]h&]uh1jhjthMRhjmsubj)}(h6``probe_resp`` probe response template (AP mode only) h](j)}(h``probe_resp``h]j)}(hjuh]h probe_resp}(hj uhhhNhNubah}(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.hhMUhjuubj6)}(hhh]h)}(h&probe response template (AP mode only)h]h&probe response template (AP mode only)}(hj7uhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3uhMUhj4uubah}(h]h ]h"]h$]h&]uh1j5hjuubeh}(h]h ]h"]h$]h&]uh1jhj3uhMUhjmsubj)}(ha``lci`` Measurement Report element content, starting with Measurement Token (measurement type 8) h](j)}(h``lci``h]j)}(hjWuh]hlci}(hjYuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUuubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM[hjQuubj6)}(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)}(hjpuhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMZhjmuubah}(h]h ]h"]h$]h&]uh1j5hjQuubeh}(h]h ]h"]h$]h&]uh1jhjluhM[hjmsubj)}(hg``civicloc`` Measurement Report element content, starting with Measurement Token (measurement type 11) h](j)}(h ``civicloc``h]j)}(hjuh]hcivicloc}(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)}(hYMeasurement Report element content, starting with Measurement Token (measurement type 11)h]hYMeasurement Report element content, starting with Measurement Token (measurement type 11)}(hjuhhhNhNubah}(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]hjmsubj)}(h'``mbssid_ies`` multiple BSSID elements h](j)}(h``mbssid_ies``h]j)}(hjuh]h mbssid_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.hhMVhjuubj6)}(hhh]h)}(hmultiple BSSID elementsh]hmultiple BSSID elements}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuhMVhjuubah}(h]h ]h"]h$]h&]uh1j5hjuubeh}(h]h ]h"]h$]h&]uh1jhjuhMVhjmsubj)}(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.hhMWhjuubj6)}(hhh]h)}(h reduced neighbor report elementsh]h reduced neighbor report elements}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvhMWhjvubah}(h]h ]h"]h$]h&]uh1j5hjuubeh}(h]h ]h"]h$]h&]uh1jhjvhMWhjmsubj)}(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)}(hj=vh]h ftm_responder}(hj?vhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;vubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMYhj7vubj6)}(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)}(hjVvhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMXhjSvubah}(h]h ]h"]h$]h&]uh1j5hj7vubeh}(h]h ]h"]h$]h&]uh1jhjRvhMYhjmsubj)}(h ``head_len`` length of **head** h](j)}(h ``head_len``h]j)}(hjwvh]hhead_len}(hjyvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuvubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMJhjqvubj6)}(hhh]h)}(hlength of **head**h](h length of }(hjvhhhNhNubj)}(h**head**h]hhead}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvubeh}(h]h ]h"]h$]h&]uh1hhjvhMJhjvubah}(h]h ]h"]h$]h&]uh1j5hjqvubeh}(h]h ]h"]h$]h&]uh1jhjvhMJhjmsubj)}(h ``tail_len`` length of **tail** h](j)}(h ``tail_len``h]j)}(hjvh]htail_len}(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.hhMKhjvubj6)}(hhh]h)}(hlength of **tail**h](h length of }(hjvhhhNhNubj)}(h**tail**h]htail}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvubeh}(h]h ]h"]h$]h&]uh1hhjvhMKhjvubah}(h]h ]h"]h$]h&]uh1j5hjvubeh}(h]h ]h"]h$]h&]uh1jhjvhMKhjmsubj)}(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.hhMMhjvubj6)}(hhh]h)}(hlength of beacon_ies in octetsh]hlength of beacon_ies in octets}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwhMMhjwubah}(h]h ]h"]h$]h&]uh1j5hjvubeh}(h]h ]h"]h$]h&]uh1jhjwhMMhjmsubj)}(h8``proberesp_ies_len`` length of proberesp_ies in octets h](j)}(h``proberesp_ies_len``h]j)}(hj>wh]hproberesp_ies_len}(hj@whhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyhhubah}(h]h ]h"]h$]h&]uh1jhjxhhhj yhMhubeh}(h]h ](j$structeh"]h$]h&]jj$jjYyjjYyjjjuh1jchhhj$bhNhNubj)}(hX **Definition**:: struct cfg80211_ap_settings { struct cfg80211_chan_def chandef; struct cfg80211_beacon_data beacon; int beacon_interval, dtim_period; const u8 *ssid; size_t ssid_len; enum nl80211_hidden_ssid hidden_ssid; struct cfg80211_crypto_settings crypto; bool privacy; enum nl80211_auth_type auth_type; int inactivity_timeout; u8 p2p_ctwindow; bool p2p_opp_ps; const struct cfg80211_acl_data *acl; bool pbss; struct cfg80211_bitrate_mask beacon_rate; const struct ieee80211_ht_cap *ht_cap; const struct ieee80211_vht_cap *vht_cap; const struct ieee80211_he_cap_elem *he_cap; const struct ieee80211_he_operation *he_oper; const struct ieee80211_eht_cap_elem *eht_cap; const struct ieee80211_eht_operation *eht_oper; bool ht_required, vht_required, he_required, sae_h2e_required; bool twt_responder; u32 flags; struct ieee80211_he_obss_pd he_obss_pd; struct cfg80211_fils_discovery fils_discovery; struct cfg80211_unsol_bcast_probe_resp unsol_bcast_probe_resp; struct cfg80211_mbssid_config mbssid_config; }; **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 bssidh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjeyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjayubh:}(hjayhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj]yubj( )}(hXTstruct 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; };h]hXTstruct 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; };}hj~ysbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj]yubh)}(h **Members**h]j)}(hjyh]hMembers}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj]yubj)}(hhh](j)}(h'``chandef`` defines the channel to use h](j)}(h ``chandef``h]j)}(hjyh]hchandef}(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.hhMhjyubj6)}(hhh]h)}(hdefines the channel to useh]hdefines the channel to use}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyhMhjyubah}(h]h ]h"]h$]h&]uh1j5hjyubeh}(h]h ]h"]h$]h&]uh1jhjyhMhjyubj)}(h``beacon`` beacon data h](j)}(h ``beacon``h]j)}(hjyh]hbeacon}(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.hhMhjyubj6)}(hhh]h)}(h beacon datah]h beacon data}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyhMhjyubah}(h]h ]h"]h$]h&]uh1j5hjyubeh}(h]h ]h"]h$]h&]uh1jhjyhMhjyubj)}(h$``beacon_interval`` beacon interval h](j)}(h``beacon_interval``h]j)}(hj zh]hbeacon_interval}(hj"zhhhNhNubah}(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}(hj9zhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5zhMhj6zubah}(h]h ]h"]h$]h&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhj5zhMhjyubj)}(h``dtim_period`` DTIM period h](j)}(h``dtim_period``h]j)}(hjYzh]h dtim_period}(hj[zhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWzubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjSzubj6)}(hhh]h)}(h DTIM periodh]h DTIM period}(hjrzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnzhMhjozubah}(h]h ]h"]h$]h&]uh1j5hjSzubeh}(h]h ]h"]h$]h&]uh1jhjnzhMhjyubj)}(h\``ssid`` SSID to be used in the BSS (note: may be ``NULL`` if not provided from user space) h](j)}(h``ssid``h]j)}(hjzh]hssid}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjzubj6)}(hhh]h)}(hRSSID to be used in the BSS (note: may be ``NULL`` if not provided from user space)h](h)SSID to be used in the BSS (note: may be }(hjzhhhNhNubj)}(h``NULL``h]hNULL}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubh! if not provided from user space)}(hjzhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjzubah}(h]h ]h"]h$]h&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhjzhMhjyubj)}(h ``ssid_len`` length of **ssid** h](j)}(h ``ssid_len``h]j)}(hjzh]hssid_len}(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)}(hlength of **ssid**h](h length of }(hjzhhhNhNubj)}(h**ssid**h]hssid}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzubeh}(h]h ]h"]h$]h&]uh1hhjzhMhjzubah}(h]h ]h"]h$]h&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhjzhMhjyubj)}(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:{hMhjyubj)}(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.hhMhjX{ubj6)}(hhh]h)}(hcrypto settingsh]hcrypto settings}(hjw{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjs{hMhjt{ubah}(h]h ]h"]h$]h&]uh1j5hjX{ubeh}(h]h ]h"]h$]h&]uh1jhjs{hMhjyubj)}(h!``privacy`` the BSS uses privacy h](j)}(h ``privacy``h]j)}(hj{h]hprivacy}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj{ubj6)}(hhh]h)}(hthe BSS uses privacyh]hthe BSS uses privacy}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{hMhj{ubah}(h]h ]h"]h$]h&]uh1j5hj{ubeh}(h]h ]h"]h$]h&]uh1jhj{hMhjyubj)}(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{hMhjyubj)}(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|hMhjyubj)}(h``p2p_ctwindow`` P2P CT Window h](j)}(h``p2p_ctwindow``h]j)}(hjB|h]h p2p_ctwindow}(hjD|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@|ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj<|ubj6)}(hhh]h)}(h P2P CT Windowh]h P2P CT Window}(hj[|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjW|hMhjX|ubah}(h]h ]h"]h$]h&]uh1j5hj<|ubeh}(h]h ]h"]h$]h&]uh1jhjW|hMhjyubj)}(h$``p2p_opp_ps`` P2P opportunistic PS h](j)}(h``p2p_opp_ps``h]j)}(hj{|h]h p2p_opp_ps}(hj}|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjy|ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhju|ubj6)}(hhh]h)}(hP2P opportunistic PSh]hP2P opportunistic PS}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hMhj|ubah}(h]h ]h"]h$]h&]uh1j5hju|ubeh}(h]h ]h"]h$]h&]uh1jhj|hMhjyubj)}(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|hMhjyubj)}(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}hMhjyubj)}(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}(hjA}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=}hMhj>}ubah}(h]h ]h"]h$]h&]uh1j5hj"}ubeh}(h]h ]h"]h$]h&]uh1jhj=}hMhjyubj)}(h=``ht_cap`` HT capabilities (or ``NULL`` if HT isn't enabled) h](j)}(h ``ht_cap``h]j)}(hja}h]hht_cap}(hjc}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_}ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj[}ubj6)}(hhh]h)}(h1HT capabilities (or ``NULL`` if HT isn't enabled)h](hHT capabilities (or }(hjz}hhhNhNubj)}(h``NULL``h]hNULL}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjz}ubh if HT isn’t enabled)}(hjz}hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjv}hMhjw}ubah}(h]h ]h"]h$]h&]uh1j5hj[}ubeh}(h]h ]h"]h$]h&]uh1jhjv}hMhjyubj)}(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}hMhjyubj)}(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 ~hMhjyubj)}(h>``he_oper`` HE operation IE (or ``NULL`` if HE isn't enabled) h](j)}(h ``he_oper``h]j)}(hjB~h]hhe_oper}(hjD~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@~ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj<~ubj6)}(hhh]h)}(h1HE operation IE (or ``NULL`` if HE isn't enabled)h](hHE operation IE (or }(hj[~hhhNhNubj)}(h``NULL``h]hNULL}(hjc~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[~ubh if HE isn’t enabled)}(hj[~hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjW~hMhjX~ubah}(h]h ]h"]h$]h&]uh1j5hj<~ubeh}(h]h ]h"]h$]h&]uh1jhjW~hMhjyubj)}(h@``eht_cap`` EHT capabilities (or ``NULL`` if EHT isn't enabled) h](j)}(h ``eht_cap``h]j)}(hj~h]heht_cap}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj~ubj6)}(hhh]h)}(h3EHT capabilities (or ``NULL`` if EHT isn't enabled)h](hEHT capabilities (or }(hj~hhhNhNubj)}(h``NULL``h]hNULL}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubh if EHT 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~hMhjyubj)}(hA``eht_oper`` EHT operation IE (or ``NULL`` if EHT isn't enabled) h](j)}(h ``eht_oper``h]j)}(hj~h]heht_oper}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj~ubj6)}(hhh]h)}(h3EHT operation IE (or ``NULL`` if EHT isn't enabled)h](hEHT operation IE (or }(hj~hhhNhNubj)}(h``NULL``h]hNULL}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubh if EHT 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~hMhjyubj)}(h)``ht_required`` stations must support HT h](j)}(h``ht_required``h]j)}(hj#h]h ht_required}(hj%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)}(hstations must support HTh]hstations must support HT}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8hMhj9ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj8hMhjyubj)}(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&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjVubj6)}(hhh]h)}(hstations must support VHTh]hstations must support VHT}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjqhMhjrubah}(h]h ]h"]h$]h&]uh1j5hjVubeh}(h]h ]h"]h$]h&]uh1jhjqhMhjyubj)}(h)``he_required`` stations must support HE h](j)}(h``he_required``h]j)}(hjh]h he_required}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hstations must support HEh]hstations must support HE}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjyubj)}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjyubj)}(h*``twt_responder`` Enable Target Wait Time h](j)}(h``twt_responder``h]j)}(hjh]h twt_responder}(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)}(hEnable Target Wait Timeh]hEnable Target Wait Time}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjyubj)}(hd``flags`` flags, as defined in :c:type:`enum nl80211_ap_settings_flags ` h](j)}(h ``flags``h]j)}(hj@h]hflags}(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.hhMhj:ubj6)}(hhh]h)}(hYflags, as defined in :c:type:`enum nl80211_ap_settings_flags `h](hflags, as defined in }(hjYhhhNhNubh)}(hD:c:type:`enum nl80211_ap_settings_flags `h]j)}(hjch]henum nl80211_ap_settings_flags}(hjehhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_ap_settings_flagsuh1hhjUhMhjYubeh}(h]h ]h"]h$]h&]uh1hhjUhMhjVubah}(h]h ]h"]h$]h&]uh1j5hj:ubeh}(h]h ]h"]h$]h&]uh1jhjUhMhjyubj)}(h.``he_obss_pd`` OBSS Packet Detection settings h](j)}(h``he_obss_pd``h]j)}(hjh]h he_obss_pd}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hOBSS Packet Detection settingsh]hOBSS Packet Detection settings}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjyubj)}(h:``fils_discovery`` FILS discovery transmission parameters h](j)}(h``fils_discovery``h]j)}(hjрh]hfils_discovery}(hjӀ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&FILS discovery transmission parametersh]h&FILS discovery transmission parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjˀubeh}(h]h ]h"]h$]h&]uh1jhjhMhjyubj)}(hK``unsol_bcast_probe_resp`` Unsolicited broadcast probe response parameters h](j)}(h``unsol_bcast_probe_resp``h]j)}(hj h]hunsol_bcast_probe_resp}(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/Unsolicited broadcast probe response parametersh]h/Unsolicited broadcast probe response parameters}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjyubj)}(h0``mbssid_config`` AP settings for multiple bssidh](j)}(h``mbssid_config``h]j)}(hjCh]h mbssid_config}(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)}(hAP settings for multiple bssidh]hAP settings for multiple bssid}(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&]uh1jhjXhMhjyubeh}(h]h ]h"]h$]h&]uh1jhj]yubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$bhhubh)}(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.hhMhj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_station_parameters (C struct)c.station_parametershNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hstation_parametersh]jo)}(hstruct station_parametersh](ju)}(hjh]hstruct}(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)}(hstation_parametersh]j)}(hjh]hstation_parameters}(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)}(hstation parametersh]hstation parameters}(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сhMubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhj$bhNhNubj)}(hX) **Definition**:: struct station_parameters { struct net_device *vlan; u32 sta_flags_mask, sta_flags_set; u32 sta_modify_mask; int listen_interval; u16 aid; u16 vlan_id; u16 peer_aid; u8 plink_action; u8 plink_state; u8 uapsd_queues; u8 max_sp; enum nl80211_mesh_power_mode local_pm; u16 capability; const u8 *ext_capab; u8 ext_capab_len; const u8 *supported_channels; u8 supported_channels_len; const u8 *supported_oper_classes; u8 supported_oper_classes_len; int support_p2p_ps; u16 airtime_weight; 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 ``link_sta_params`` link related params.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( )}(hXmstruct 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; struct link_station_parameters link_sta_params; };h]hXmstruct 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; struct link_station_parameters link_sta_params; };}hjCsbah}(h]h ]h"]h$]h&]jjuh1j' h`/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)}(h1``vlan`` vlan interface station should belong to h](j)}(h``vlan``h]j)}(hjsh]hvlan}(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'vlan interface station should belong toh]h'vlan interface station should belong to}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjmubeh}(h]h ]h"]h$]h&]uh1jhjhMhjjubj)}(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(}(hjłhhhNhNubj)}(h``NL80211_STA_FLAG_``h]hNL80211_STA_FLAG_}(hj͂hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjłubh...))}(hjłhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj‚ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjjubj)}(hR``sta_flags_set`` station flags values (bitmask of BIT(``NL80211_STA_FLAG_``...)) h](j)}(h``sta_flags_set``h]j)}(hjh]h sta_flags_set}(hjhhhNhNubah}(h]h ]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?station flags values (bitmask of BIT(``NL80211_STA_FLAG_``...))h](h%station flags values (bitmask of BIT(}(hjhhhNhNubj)}(h``NL80211_STA_FLAG_``h]hNL80211_STA_FLAG_}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh...))}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjjubj)}(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)}(hjDh]hsta_modify_mask}(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)}(hbitmap indicating which parameters changed (for those that don't have a natural "no change" value), see :c:type:`enum station_parameters_apply_mask `h](hnbitmap indicating which parameters changed (for those that don’t have a natural “no change” value), see }(hj]hhhNhNubh)}(hL:c:type:`enum station_parameters_apply_mask `h]j)}(hjgh]h"enum station_parameters_apply_mask}(hjihhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6station_parameters_apply_maskuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj]ubeh}(h]h ]h"]h$]h&]uh1hhjhMhjZubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhjYhMhjjubj)}(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&]uh1jhjhMhjjubj)}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjЃubeh}(h]h ]h"]h$]h&]uh1jhjhMhjjubj)}(h-``vlan_id`` VLAN ID for station (if nonzero) h](j)}(h ``vlan_id``h]j)}(hjh]hvlan_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj ubj6)}(hhh]h)}(h VLAN ID for station (if nonzero)h]h VLAN ID for station (if nonzero)}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$hMhj%ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj$hMhjjubj)}(h1``peer_aid`` mesh peer AID or zero for no change h](j)}(h ``peer_aid``h]j)}(hjHh]hpeer_aid}(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#mesh peer AID or zero for no changeh]h#mesh peer AID or zero for no change}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]hMhj^ubah}(h]h ]h"]h$]h&]uh1j5hjBubeh}(h]h ]h"]h$]h&]uh1jhj]hMhjjubj)}(h&``plink_action`` plink action to take h](j)}(h``plink_action``h]j)}(hjh]h plink_action}(hjhhhNhNubah}(h]h ]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)}(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&]uh1jhjhMhjjubj)}(h6``plink_state`` set the peer link state for a station h](j)}(h``plink_state``h]j)}(hjh]h plink_state}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h%set the peer link state for a stationh]h%set the peer link state for a station}(hjӄhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjτhMhjЄubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjτhMhjjubj)}(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)}(hjh]h uapsd_queues}(hjhhhNhNubah}(h]h ]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)}(hYbitmap of queues configured for uapsd. same format as the AC bitmap in the QoS info fieldh]hYbitmap of queues configured for uapsd. same format as the AC bitmap in the QoS info field}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjjubj)}(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}(hj/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^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)}(hjFhhhNhNubah}(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&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhjBhMhjjubj)}(hV``local_pm`` local link-specific mesh power save mode (no change when set to unknown) h](j)}(h ``local_pm``h]j)}(hjgh]hlocal_pm}(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)}(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)}(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&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hMhjjubj)}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjjubj)}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjԅubeh}(h]h ]h"]h$]h&]uh1jhjhMhjjubj)}(h2``ext_capab_len`` number of extended capabilities h](j)}(h``ext_capab_len``h]j)}(hjh]h ext_capab_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj ubj6)}(hhh]h)}(hnumber of extended capabilitiesh]hnumber of extended capabilities}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj(hMhj)ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj(hMhjjubj)}(h@``supported_channels`` supported channels in IEEE 802.11 format h](j)}(h``supported_channels``h]j)}(hjLh]hsupported_channels}(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(supported channels in IEEE 802.11 formath]h(supported channels in IEEE 802.11 format}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjahMhjbubah}(h]h ]h"]h$]h&]uh1j5hjFubeh}(h]h ]h"]h$]h&]uh1jhjahMhjjubj)}(h8``supported_channels_len`` number of supported channels h](j)}(h``supported_channels_len``h]j)}(hjh]hsupported_channels_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)}(hnumber of supported channelsh]hnumber of supported channels}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjjubj)}(hH``supported_oper_classes`` supported oper classes in IEEE 802.11 format h](j)}(h``supported_oper_classes``h]j)}(hjh]hsupported_oper_classes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h,supported oper classes in IEEE 802.11 formath]h,supported oper classes in IEEE 802.11 format}(hj׆hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjӆhMhjԆubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjӆhMhjjubj)}(hE``supported_oper_classes_len`` number of supported operating classes h](j)}(h``supported_oper_classes_len``h]j)}(hjh]hsupported_oper_classes_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h%number of supported operating classesh]h%number of supported operating classes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjjubj)}(hD``support_p2p_ps`` information if station supports P2P PS mechanism h](j)}(h``support_p2p_ps``h]j)}(hj0h]hsupport_p2p_ps}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj*ubj6)}(hhh]h)}(h0information if station supports P2P PS mechanismh]h0information if station supports P2P PS mechanism}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjEhMhjFubah}(h]h ]h"]h$]h&]uh1j5hj*ubeh}(h]h ]h"]h$]h&]uh1jhjEhMhjjubj)}(h=``airtime_weight`` airtime scheduler weight for this station h](j)}(h``airtime_weight``h]j)}(hjih]hairtime_weight}(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)airtime scheduler weight for this stationh]h)airtime scheduler weight for this station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~hMhjubah}(h]h ]h"]h$]h&]uh1j5hjcubeh}(h]h ]h"]h$]h&]uh1jhj~hMhjjubj)}(h(``link_sta_params`` link related params.h](j)}(h``link_sta_params``h]j)}(hjh]hlink_sta_params}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hlink related params.h]hlink related params.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjjubeh}(h]h ]h"]h$]h&]uh1jhj"ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$bhhubh)}(h(Used to change and create a new station.h]h(Used to change and create a new station.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_rate_info_flags (C enum)c.rate_info_flagshNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hrate_info_flagsh]jo)}(henum rate_info_flagsh](ju)}(hjxh]henum}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMJubj)}(h h]h }(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhj0hMJubj)}(hrate_info_flagsh]j)}(hjh]hrate_info_flags}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj?ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhj0hMJubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhj0hMJubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhj0hMJhjhhubj)}(hhh]h)}(hbitrate info flagsh]hbitrate info flags}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMMhjbhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj0hMJubeh}(h]h ](j$enumeh"]h$]h&]jj$jj}jj}jjjuh1jchhhj$bhNhNubj)}(hX**Constants** ``RATE_INFO_FLAGS_MCS`` mcs field filled with HT MCS ``RATE_INFO_FLAGS_VHT_MCS`` mcs field filled with VHT MCS ``RATE_INFO_FLAGS_SHORT_GI`` 400ns guard interval ``RATE_INFO_FLAGS_DMG`` 60GHz MCS ``RATE_INFO_FLAGS_HE_MCS`` HE MCS information ``RATE_INFO_FLAGS_EDMG`` 60GHz MCS in EDMG mode ``RATE_INFO_FLAGS_EXTENDED_SC_DMG`` 60GHz extended SC MCS ``RATE_INFO_FLAGS_EHT_MCS`` EHT MCS information ``RATE_INFO_FLAGS_S1G_MCS`` MCS field filled with S1G MCSh](h)}(h **Constants**h]j)}(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:48: ./include/net/cfg80211.hhMQhjubj)}(hhh](j)}(h5``RATE_INFO_FLAGS_MCS`` mcs field filled with HT MCS h](j)}(h``RATE_INFO_FLAGS_MCS``h]j)}(hjh]hRATE_INFO_FLAGS_MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMThjubj6)}(hhh]h)}(hmcs field filled with HT MCSh]hmcs field filled with HT MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMThjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMThjubj)}(h:``RATE_INFO_FLAGS_VHT_MCS`` mcs field filled with VHT MCS h](j)}(h``RATE_INFO_FLAGS_VHT_MCS``h]j)}(hj߈h]hRATE_INFO_FLAGS_VHT_MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj݈ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMWhjوubj6)}(hhh]h)}(hmcs field filled with VHT MCSh]hmcs field filled with VHT MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMWhjubah}(h]h ]h"]h$]h&]uh1j5hjوubeh}(h]h ]h"]h$]h&]uh1jhjhMWhjubj)}(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.hhMZhjubj6)}(hhh]h)}(h400ns guard intervalh]h400ns guard interval}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-hMZhj.ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj-hMZhjubj)}(h"``RATE_INFO_FLAGS_DMG`` 60GHz MCS h](j)}(h``RATE_INFO_FLAGS_DMG``h]j)}(hjQh]hRATE_INFO_FLAGS_DMG}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM]hjKubj6)}(hhh]h)}(h 60GHz MCSh]h 60GHz MCS}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhM]hjgubah}(h]h ]h"]h$]h&]uh1j5hjKubeh}(h]h ]h"]h$]h&]uh1jhjfhM]hjubj)}(h.``RATE_INFO_FLAGS_HE_MCS`` HE MCS information h](j)}(h``RATE_INFO_FLAGS_HE_MCS``h]j)}(hjh]hRATE_INFO_FLAGS_HE_MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]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)}(hHE MCS informationh]hHE MCS information}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM`hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM`hjubj)}(h0``RATE_INFO_FLAGS_EDMG`` 60GHz MCS in EDMG mode h](j)}(h``RATE_INFO_FLAGS_EDMG``h]j)}(hjÉh]hRATE_INFO_FLAGS_EDMG}(hjʼnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMchjubj6)}(hhh]h)}(h60GHz MCS in EDMG modeh]h60GHz MCS in EDMG mode}(hj܉hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj؉hMchjىubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj؉hMchjubj)}(h:``RATE_INFO_FLAGS_EXTENDED_SC_DMG`` 60GHz extended SC MCS h](j)}(h#``RATE_INFO_FLAGS_EXTENDED_SC_DMG``h]j)}(hjh]hRATE_INFO_FLAGS_EXTENDED_SC_DMG}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMfhjubj6)}(hhh]h)}(h60GHz extended SC MCSh]h60GHz extended SC MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMfhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMfhjubj)}(h0``RATE_INFO_FLAGS_EHT_MCS`` EHT MCS information h](j)}(h``RATE_INFO_FLAGS_EHT_MCS``h]j)}(hj5h]hRATE_INFO_FLAGS_EHT_MCS}(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.hhMihj/ubj6)}(hhh]h)}(hEHT MCS informationh]hEHT MCS information}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJhMihjKubah}(h]h ]h"]h$]h&]uh1j5hj/ubeh}(h]h ]h"]h$]h&]uh1jhjJhMihjubj)}(h9``RATE_INFO_FLAGS_S1G_MCS`` MCS field filled with S1G MCSh](j)}(h``RATE_INFO_FLAGS_S1G_MCS``h]j)}(hjnh]hRATE_INFO_FLAGS_S1G_MCS}(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.hhMkhjhubj6)}(hhh]h)}(hMCS field filled with S1G MCSh]hMCS field filled with S1G MCS}(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&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhMkhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMohj$bhhubh)}(h]Used by the driver to indicate the specific rate transmission type for 802.11n transmissions.h]h]Used by the driver to indicate the specific rate transmission type for 802.11n transmissions.}(hjNJhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMNhj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_rate_info (C struct) c.rate_infohNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(h rate_infoh]jo)}(hstruct rate_infoh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMTubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMTubj)}(h rate_infoh]j)}(hjh]h rate_info}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMTubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMTubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMThjhhubj)}(hhh]h)}(hbitrate informationh]hbitrate information}(hj1hhhNhNubah}(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&]uh1jhjhhhjhMTubeh}(h]h ](j$structeh"]h$]h&]jj$jjIjjIjjjuh1jchhhj$bhNhNubj)}(hXi**Definition**:: struct rate_info { u16 flags; u16 legacy; u8 mcs; u8 nss; u8 bw; u8 he_gi; u8 he_dcm; u8 he_ru_alloc; u8 n_bonded_ch; u8 eht_gi; u8 eht_ru_alloc; }; **Members** ``flags`` bitflag of flags from :c:type:`enum rate_info_flags ` ``legacy`` bitrate in 100kbit/s for 802.11abg ``mcs`` mcs index if struct describes an HT/VHT/HE/EHT/S1G rate ``nss`` number of streams (VHT & HE only) ``bw`` bandwidth (from :c:type:`enum rate_info_bw `) ``he_gi`` HE guard interval (from :c:type:`enum nl80211_he_gi `) ``he_dcm`` HE DCM value ``he_ru_alloc`` HE RU allocation (from :c:type:`enum nl80211_he_ru_alloc `, only valid if bw is ``RATE_INFO_BW_HE_RU``) ``n_bonded_ch`` In case of EDMG the number of bonded channels (1-4) ``eht_gi`` EHT guard interval (from :c:type:`enum nl80211_eht_gi `) ``eht_ru_alloc`` EHT RU allocation (from :c:type:`enum nl80211_eht_ru_alloc `, only valid if bw is ``RATE_INFO_BW_EHT_RU``)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(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.hhMhjMubj( )}(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; };}hjnsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjMubh)}(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.hhMhjMubj)}(hhh](j)}(hQ``flags`` bitflag of flags from :c:type:`enum rate_info_flags ` h](j)}(h ``flags``h]j)}(hjh]hflags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hFbitflag of flags from :c:type:`enum rate_info_flags `h](hbitflag of flags from }(hjhhhNhNubh)}(h0:c:type:`enum rate_info_flags `h]j)}(hjh]henum rate_info_flags}(hjËhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6rate_info_flagsuh1hhjhMhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h.``legacy`` bitrate in 100kbit/s for 802.11abg h](j)}(h ``legacy``h]j)}(hjh]hlegacy}(hjhhhNhNubah}(h]h ]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"bitrate in 100kbit/s for 802.11abgh]h"bitrate in 100kbit/s for 802.11abg}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubj)}(h@``mcs`` mcs index if struct describes an HT/VHT/HE/EHT/S1G rate h](j)}(h``mcs``h]j)}(hj/h]hmcs}(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)}(h7mcs index if struct describes an HT/VHT/HE/EHT/S1G rateh]h7mcs index if struct describes an HT/VHT/HE/EHT/S1G rate}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDhMhjEubah}(h]h ]h"]h$]h&]uh1j5hj)ubeh}(h]h ]h"]h$]h&]uh1jhjDhMhjubj)}(h*``nss`` number of streams (VHT & HE only) h](j)}(h``nss``h]j)}(hjhh]hnss}(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!number of streams (VHT & HE only)h]h!number of streams (VHT & HE only)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj}hMhj~ubah}(h]h ]h"]h$]h&]uh1j5hjbubeh}(h]h ]h"]h$]h&]uh1jhj}hMhjubj)}(hC``bw`` bandwidth (from :c:type:`enum rate_info_bw `) h](j)}(h``bw``h]j)}(hjh]hbw}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h;bandwidth (from :c:type:`enum rate_info_bw `)h](hbandwidth (from }(hjhhhNhNubh)}(h*:c:type:`enum rate_info_bw `h]j)}(hjČh]henum rate_info_bw}(hjƌhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjŒubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6 rate_info_bwuh1hhjhMhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hP``he_gi`` HE guard interval (from :c:type:`enum nl80211_he_gi `) h](j)}(h ``he_gi``h]j)}(hjh]hhe_gi}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(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)}(hj h]henum nl80211_he_gi}(hj"hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6 nl80211_he_giuh1hhjhMhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``he_dcm`` HE DCM value h](j)}(h ``he_dcm``h]j)}(hjYh]hhe_dcm}(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)}(h HE DCM valueh]h HE DCM value}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhMhjoubah}(h]h ]h"]h$]h&]uh1j5hjSubeh}(h]h ]h"]h$]h&]uh1jhjnhMhjubj)}(h``he_ru_alloc`` HE RU allocation (from :c:type:`enum nl80211_he_ru_alloc `, only valid if bw is ``RATE_INFO_BW_HE_RU``) h](j)}(h``he_ru_alloc``h]j)}(hjh]h he_ru_alloc}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h|HE RU allocation (from :c:type:`enum nl80211_he_ru_alloc `, only valid if bw is ``RATE_INFO_BW_HE_RU``)h](hHE RU allocation (from }(hjhhhNhNubh)}(h8:c:type:`enum nl80211_he_ru_alloc `h]j)}(hjh]henum nl80211_he_ru_alloc}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_he_ru_allocuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh, only valid if bw is }(hjhhhNhNubj)}(h``RATE_INFO_BW_HE_RU``h]hRATE_INFO_BW_HE_RU}(hj׍hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjҍhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hD``n_bonded_ch`` In case of EDMG the number of bonded channels (1-4) h](j)}(h``n_bonded_ch``h]j)}(hjh]h n_bonded_ch}(hjhhhNhNubah}(h]h ]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)}(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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hT``eht_gi`` EHT guard interval (from :c:type:`enum nl80211_eht_gi `) h](j)}(h ``eht_gi``h]j)}(hj:h]heht_gi}(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)}(hHEHT guard interval (from :c:type:`enum nl80211_eht_gi `)h](hEHT guard interval (from }(hjShhhNhNubh)}(h.:c:type:`enum nl80211_eht_gi `h]j)}(hj]h]henum nl80211_eht_gi}(hj_hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_eht_giuh1hhjOhMhjSubh)}(hjShhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjOhMhjPubah}(h]h ]h"]h$]h&]uh1j5hj4ubeh}(h]h ]h"]h$]h&]uh1jhjOhMhjubj)}(h``eht_ru_alloc`` EHT RU allocation (from :c:type:`enum nl80211_eht_ru_alloc `, only valid if bw is ``RATE_INFO_BW_EHT_RU``)h](j)}(h``eht_ru_alloc``h]j)}(hjh]h eht_ru_alloc}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hEHT RU allocation (from :c:type:`enum nl80211_eht_ru_alloc `, only valid if bw is ``RATE_INFO_BW_EHT_RU``)h](hEHT RU allocation (from }(hjhhhNhNubh)}(h::c:type:`enum nl80211_eht_ru_alloc `h]j)}(hjh]henum nl80211_eht_ru_alloc}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_eht_ru_allocuh1hhjhMhjubh, only valid if bw is }(hjhhhNhNubj)}(h``RATE_INFO_BW_EHT_RU``h]hRATE_INFO_BW_EHT_RU}(hjڎhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjMubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hj h]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.hhMhj$bhhubh)}(h5Information about a receiving or transmitting bitrateh]h5Information about a receiving or transmitting bitrate}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_station_info (C struct)c.station_infohNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(h station_infoh]jo)}(hstruct station_infoh](ju)}(hjh]hstruct}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjGhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGhhhjXhMubj)}(h station_infoh]j)}(hjEh]h station_info}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjgubah}(h]h ](jjeh"]h$]h&]jjuh1jhjGhhhjXhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjChhhjXhMubah}(h]j>ah ](jjeh"]h$]h&]jj)jhuh1jhhjXhMhj@hhubj)}(hhh]h)}(hstation informationh]hstation information}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhj@hhhjXhMubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhj$bhNhNubj)}(hXf**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; }; **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.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj( )}(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; };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; };}hjʏsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubh)}(h **Members**h]j)}(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``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)}(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)}(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 refexplicitrefwarnj j j6nl80211_sta_infouh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh8 to indicate the relevant values in this struct for them}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj:hMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hC``connected_time`` time(in secs) since a station is last connected h](j)}(h``connected_time``h]j)}(hjWh]hconnected_time}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjQubj6)}(hhh]h)}(h/time(in secs) since a station is last connectedh]h/time(in secs) since a station is last connected}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhM hjmubah}(h]h ]h"]h$]h&]uh1j5hjQubeh}(h]h ]h"]h$]h&]uh1jhjlhM hjubj)}(hK``inactive_time`` time since last station activity (tx/rx) in milliseconds h](j)}(h``inactive_time``h]j)}(hjh]h inactive_time}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h8time since last station activity (tx/rx) in millisecondsh]h8time since last station activity (tx/rx) in milliseconds}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h2``assoc_at`` bootime (ns) of the last association h](j)}(h ``assoc_at``h]j)}(hjɐh]hassoc_at}(hjːhhhNhNubah}(h]h ]h"]h$]h&]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$bootime (ns) of the last associationh]h$bootime (ns) of the last association}(hjhhhNhNubah}(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>``rx_bytes`` bytes (size of MPDUs) received from this station h](j)}(h ``rx_bytes``h]j)}(hjh]hrx_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 hjubj6)}(hhh]h)}(h0bytes (size of MPDUs) received from this stationh]h0bytes (size of MPDUs) received from this station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h?``tx_bytes`` bytes (size of MPDUs) transmitted to this station h](j)}(h ``tx_bytes``h]j)}(hj;h]htx_bytes}(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)}(h1bytes (size of MPDUs) transmitted to this stationh]h1bytes (size of MPDUs) transmitted to this station}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPhMhjQubah}(h]h ]h"]h$]h&]uh1j5hj5ubeh}(h]h ]h"]h$]h&]uh1jhjPhMhjubj)}(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)}(hjth]hsignal}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjnubj6)}(hhh]h)}(hxThe signal strength, type depends on the wiphy's signal_type. For CFG80211_SIGNAL_TYPE_MBM, value is expressed in _dBm_.h]hzThe signal strength, type depends on the wiphy’s signal_type. For CFG80211_SIGNAL_TYPE_MBM, value is expressed in _dBm_.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjnubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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.hhMhjubj6)}(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_.}(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)}(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 }(hjhhhNhNubj)}(h**chain_signal**h]h chain_signal}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh, }(hjhhhNhNubj)}(h**chain_signal_avg**h]hchain_signal_avg}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hJ``chain_signal`` per-chain signal strength of last received packet in dBm h](j)}(h``chain_signal``h]j)}(hjAh]h chain_signal}(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.hhMhj;ubj6)}(hhh]h)}(h8per-chain signal strength of last received packet in dBmh]h8per-chain signal strength of last received packet in dBm}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhMhjWubah}(h]h ]h"]h$]h&]uh1j5hj;ubeh}(h]h ]h"]h$]h&]uh1jhjVhMhjubj)}(h>``chain_signal_avg`` per-chain signal strength average in dBm h](j)}(h``chain_signal_avg``h]j)}(hjzh]hchain_signal_avg}(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)}(h(per-chain signal strength average in dBmh]h(per-chain signal strength average in dBm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjtubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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}(hj̒hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjȒhMhjɒubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjȒhMhjubj)}(h3``rxrate`` current unicast bitrate to this station h](j)}(h ``rxrate``h]j)}(hjh]hrxrate}(hjhhhNhNubah}(h]h ]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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hC``rx_packets`` packets (MSDUs & MMPDUs) received from this station h](j)}(h``rx_packets``h]j)}(hj%h]h rx_packets}(hj'hhhNhNubah}(h]h ]h"]h$]h&]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)}(h3packets (MSDUs & MMPDUs) received from this stationh]h3packets (MSDUs & MMPDUs) received from 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)}(hD``tx_packets`` packets (MSDUs & MMPDUs) transmitted to this station h](j)}(h``tx_packets``h]j)}(hj^h]h tx_packets}(hj`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.hhMhjXubj6)}(hhh]h)}(h4packets (MSDUs & MMPDUs) transmitted to this stationh]h4packets (MSDUs & MMPDUs) transmitted to this station}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjshMhjtubah}(h]h ]h"]h$]h&]uh1j5hjXubeh}(h]h ]h"]h$]h&]uh1jhjshMhjubj)}(h/``tx_retries`` cumulative retry counts (MPDUs) h](j)}(h``tx_retries``h]j)}(hjh]h tx_retries}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hcumulative retry counts (MPDUs)h]hcumulative retry counts (MPDUs)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hP``tx_failed`` number of failed transmissions (MPDUs) (retries exceeded, no ACK) h](j)}(h ``tx_failed``h]j)}(hjГh]h tx_failed}(hjғhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjΓubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjʓubj6)}(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&]uh1j5hjʓubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h5``rx_dropped_misc`` Dropped for un-specified reason. h](j)}(h``rx_dropped_misc``h]j)}(hj h]hrx_dropped_misc}(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 Dropped for un-specified reason.h]h Dropped for un-specified reason.}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h%``bss_param`` current BSS parameters h](j)}(h ``bss_param``h]j)}(hjBh]h bss_param}(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)}(hcurrent BSS parametersh]hcurrent BSS parameters}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjWhMhjXubah}(h]h ]h"]h$]h&]uh1j5hj<ubeh}(h]h ]h"]h$]h&]uh1jhjWhMhjubj)}(h*``sta_flags`` station flags mask & values h](j)}(h ``sta_flags``h]j)}(hj{h]h sta_flags}(hj}hhhNhNubah}(h]h ]h"]h$]h&]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)}(hstation flags mask & valuesh]hstation flags mask & values}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM(hjubah}(h]h ]h"]h$]h&]uh1j5hjuubeh}(h]h ]h"]h$]h&]uh1jhjhM(hjubj)}(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.hhM!hjubj6)}(hhh]h)}(hgeneration number for nl80211 dumps. This number should increase every time the list of stations changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.h]hgeneration number for nl80211 dumps. This number should increase every time the list of stations changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.}(hj͔hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjʔubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjɔhM!hjubj)}(hG``beacon_loss_count`` Number of times beacon loss event has triggered. h](j)}(h``beacon_loss_count``h]j)}(hjh]hbeacon_loss_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)}(h0Number of times beacon loss event has triggered.h]h0Number of times beacon loss event has triggered.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM"hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM"hjubj)}(h``assoc_req_ies`` IEs from (Re)Association Request. This is used only when in AP mode with drivers that do not use user space MLME/SME implementation. The information is provided for the cfg80211_new_sta() calls to notify user space of the IEs. h](j)}(h``assoc_req_ies``h]j)}(hj'h]h assoc_req_ies}(hj)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)}(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.}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hj=ubah}(h]h ]h"]h$]h&]uh1j5hj!ubeh}(h]h ]h"]h$]h&]uh1jhj<hM&hjubj)}(h@``assoc_req_ies_len`` Length of assoc_req_ies buffer in octets. h](j)}(h``assoc_req_ies_len``h]j)}(hjah]hassoc_req_ies_len}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM'hj[ubj6)}(hhh]h)}(h)Length of assoc_req_ies buffer in octets.h]h)Length of assoc_req_ies buffer in octets.}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvhM'hjwubah}(h]h ]h"]h$]h&]uh1j5hj[ubeh}(h]h ]h"]h$]h&]uh1jhjvhM'hjubj)}(h?``t_offset`` Time offset of the station relative to this host. h](j)}(h ``t_offset``h]j)}(hjh]ht_offset}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM)hjubj6)}(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&]uh1hhjhM)hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM)hjubj)}(h``llid`` mesh local link id h](j)}(h``llid``h]j)}(hjӕh]hllid}(hjՕhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjѕubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM*hj͕ubj6)}(hhh]h)}(hmesh local link idh]hmesh local link id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM*hjubah}(h]h ]h"]h$]h&]uh1j5hj͕ubeh}(h]h ]h"]h$]h&]uh1jhjhM*hjubj)}(h``plid`` mesh peer link id h](j)}(h``plid``h]j)}(hj h]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.hhM+hjubj6)}(hhh]h)}(hmesh peer link idh]hmesh peer link id}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hM+hj"ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj!hM+hjubj)}(h%``plink_state`` mesh peer link state h](j)}(h``plink_state``h]j)}(hjEh]h plink_state}(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)}(hmesh peer link stateh]hmesh peer link state}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhM,hj[ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhjZhM,hjubj)}(h?``connected_to_gate`` true if mesh STA has a path to mesh gate h](j)}(h``connected_to_gate``h]j)}(hj~h]hconnected_to_gate}(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)}(h(true if mesh STA has a path to mesh gateh]h(true if mesh STA has a path to mesh gate}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM-hjubah}(h]h ]h"]h$]h&]uh1j5hjxubeh}(h]h ]h"]h$]h&]uh1jhjhM-hjubj)}(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.hhM.hjubj6)}(hhh]h)}(h4true if mesh STA has a path to authentication serverh]h4true if mesh STA has a path to authentication server}(hjЖhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj̖hM.hj͖ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj̖hM.hjubj)}(h2``airtime_link_metric`` mesh airtime link metric. h](j)}(h``airtime_link_metric``h]j)}(hjh]hairtime_link_metric}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM/hjubj6)}(hhh]h)}(hmesh airtime link metric.h]hmesh airtime link metric.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM/hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM/hjubj)}(h,``local_pm`` local mesh STA power save mode h](j)}(h ``local_pm``h]j)}(hj)h]hlocal_pm}(hj+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.hhM0hj#ubj6)}(hhh]h)}(hlocal mesh STA power save modeh]hlocal mesh STA power save mode}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hM0hj?ubah}(h]h ]h"]h$]h&]uh1j5hj#ubeh}(h]h ]h"]h$]h&]uh1jhj>hM0hjubj)}(h*``peer_pm`` peer mesh STA power save mode h](j)}(h ``peer_pm``h]j)}(hjbh]hpeer_pm}(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.hhM1hj\ubj6)}(hhh]h)}(hpeer mesh STA power save modeh]hpeer mesh STA power save mode}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwhM1hjxubah}(h]h ]h"]h$]h&]uh1j5hj\ubeh}(h]h ]h"]h$]h&]uh1jhjwhM1hjubj)}(h1``nonpeer_pm`` non-peer mesh STA power save mode h](j)}(h``nonpeer_pm``h]j)}(hjh]h nonpeer_pm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM2hjubj6)}(hhh]h)}(h!non-peer mesh STA power save modeh]h!non-peer mesh STA power save mode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM2hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM2hjubj)}(he``expected_throughput`` expected throughput in kbps (including 802.11 headers) towards this station. h](j)}(h``expected_throughput``h]j)}(hjԗh]hexpected_throughput}(hj֗hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjҗubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM4hjΗubj6)}(hhh]h)}(hLexpected throughput in kbps (including 802.11 headers) towards this station.h]hLexpected throughput in kbps (including 802.11 headers) towards this station.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM3hjubah}(h]h ]h"]h$]h&]uh1j5hjΗubeh}(h]h ]h"]h$]h&]uh1jhjhM4hjubj)}(h5``airtime_weight`` current airtime scheduling weight h](j)}(h``airtime_weight``h]j)}(hjh]hairtime_weight}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM:hjubj6)}(hhh]h)}(h!current airtime scheduling weighth]h!current airtime scheduling weight}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#hM:hj$ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj#hM:hjubj)}(h?``ack_signal`` signal strength (in dBm) of the last ACK frame. h](j)}(h``ack_signal``h]j)}(hjGh]h ack_signal}(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/signal strength (in dBm) of the last ACK frame.h]h/signal strength (in dBm) of the last ACK frame.}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\hM>hj]ubah}(h]h ]h"]h$]h&]uh1j5hjAubeh}(h]h ]h"]h$]h&]uh1jhj\hM>hjubj)}(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)}(hjh]havg_ack_signal}(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)}(hDaverage rssi value of ack packet for the no of msdu's has been sent.h]hFaverage rssi value of ack packet for the no of msdu’s has been sent.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM?hjubah}(h]h ]h"]h$]h&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhjhM@hjubj)}(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.hhM=hjubj6)}(hhh]h)}(hper-TID statistics, see :c:type:`struct cfg80211_tid_stats `, using the last (IEEE80211_NUM_TIDS) index for MSDUs not encapsulated in QoS-MPDUs. Note that this doesn't use the **filled** bit, but is used if non-NULL.h](hper-TID statistics, see }(hjӘhhhNhNubh)}(h8:c:type:`struct cfg80211_tid_stats `h]j)}(hjݘh]hstruct cfg80211_tid_stats}(hjߘhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjۘubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6cfg80211_tid_statsuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM;hjӘubhv, using the last (IEEE80211_NUM_TIDS) index for MSDUs not encapsulated in QoS-MPDUs. Note that this doesn’t use the }(hjӘhhhNhNubj)}(h **filled**h]hfilled}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjӘubh bit, but is used if non-NULL.}(hjӘhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM;hjИubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjϘhM=hjubj)}(hL``tx_duration`` aggregate PPDU duration(usecs) for all the frames to a peer h](j)}(h``tx_duration``h]j)}(hj)h]h tx_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.hhM9hj#ubj6)}(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}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hM9hj?ubah}(h]h ]h"]h$]h&]uh1j5hj#ubeh}(h]h ]h"]h$]h&]uh1jhj>hM9hjubj)}(hN``rx_duration`` aggregate PPDU duration(usecs) for all the frames from a peer h](j)}(h``rx_duration``h]j)}(hjbh]h rx_duration}(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.hhM8hj\ubj6)}(hhh]h)}(h=aggregate PPDU duration(usecs) for all the frames from a peerh]h=aggregate PPDU duration(usecs) for all the frames from a peer}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwhM8hjxubah}(h]h ]h"]h$]h&]uh1j5hj\ubeh}(h]h ]h"]h$]h&]uh1jhjwhM8hjubj)}(h8``rx_beacon`` number of beacons received from this peer h](j)}(h ``rx_beacon``h]j)}(hjh]h rx_beacon}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM5hjubj6)}(hhh]h)}(h)number of beacons received from this peerh]h)number of beacons received from this peer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM5hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM5hjubj)}(h^``rx_beacon_signal_avg`` signal strength average (in dBm) for beacons received from this peer h](j)}(h``rx_beacon_signal_avg``h]j)}(hjԙh]hrx_beacon_signal_avg}(hj֙hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjҙubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM7hjΙubj6)}(hhh]h)}(hDsignal strength average (in dBm) for beacons received from this peerh]hDsignal strength average (in dBm) for beacons received from this peer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM6hjubah}(h]h ]h"]h$]h&]uh1j5hjΙubeh}(h]h ]h"]h$]h&]uh1jhjhM7hjubj)}(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&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMAhjubj6)}(hhh]h)}(h*number of MPDUs received from this stationh]h*number of MPDUs received from this station}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#hMAhj$ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj#hMAhjubj)}(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)}(hjGh]h fcs_err_count}(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.hhMDhjAubj6)}(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.}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMBhj]ubah}(h]h ]h"]h$]h&]uh1j5hjAubeh}(h]h ]h"]h$]h&]uh1jhj\hMDhjubj)}(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)}(hjh]hmlo_params_valid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMIhj{ubj6)}(hhh]h)}(hXIndicates **assoc_link_id** and **mld_addr** fields are filled by driver. Drivers use this only in cfg80211_new_sta() calls when AP MLD's MLME/SME is offload to driver. Drivers won't fill this information in cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks.h](h Indicates }(hjhhhNhNubj)}(h**assoc_link_id**h]h assoc_link_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh and }(hjhhhNhNubj)}(h **mld_addr**h]hmld_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh fields are filled by driver. Drivers use this only in cfg80211_new_sta() calls when AP MLD’s MLME/SME is offload to driver. Drivers won’t fill this information in cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMEhjubah}(h]h ]h"]h$]h&]uh1j5hj{ubeh}(h]h ]h"]h$]h&]uh1jhjhMIhjubj)}(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)}(hjߚh]h assoc_link_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjݚubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMLhjٚubj6)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMJhjubah}(h]h ]h"]h$]h&]uh1j5hjٚubeh}(h]h ]h"]h$]h&]uh1jhjhMLhjubj)}(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.hhMNhjubj6)}(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.}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMMhj/ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj.hMNhjubj)}(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)}(hjSh]hassoc_resp_ies}(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.hhMUhjMubj6)}(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.}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMOhjiubah}(h]h ]h"]h$]h&]uh1j5hjMubeh}(h]h ]h"]h$]h&]uh1jhjhhMUhjubj)}(hE``assoc_resp_ies_len`` Length of **assoc_resp_ies** buffer in octets.h](j)}(h``assoc_resp_ies_len``h]j)}(hjh]hassoc_resp_ies_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMUhjubj6)}(hhh]h)}(h.Length of **assoc_resp_ies** buffer in octets.h](h Length of }(hjhhhNhNubj)}(h**assoc_resp_ies**h]hassoc_resp_ies}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh buffer in octets.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMVhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMUhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMYhj$bhhubh)}(hHStation information filled by driver for get_station() and dump_station.h]hHStation information filled by driver for get_station() and dump_station.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_monitor_flags (C enum)c.monitor_flagshNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(h monitor_flagsh]jo)}(henum monitor_flagsh](ju)}(hjxh]henum}(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 monitor_flagsh]j)}(hjh]h monitor_flags}(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)}(h monitor flagsh]h monitor flags}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj_hhubah}(h]h ]h"]h$]h&]uh1jhjhhhj-hMubeh}(h]h ](j$enumeh"]h$]h&]jj$jjzjjzjjjuh1jchhhj$bhNhNubj)}(hX**Constants** ``MONITOR_FLAG_CHANGED`` set if the flags were changed ``MONITOR_FLAG_FCSFAIL`` pass frames with bad FCS ``MONITOR_FLAG_PLCPFAIL`` pass frames with bad PLCP ``MONITOR_FLAG_CONTROL`` pass control frames ``MONITOR_FLAG_OTHER_BSS`` disable BSSID filtering ``MONITOR_FLAG_COOK_FRAMES`` deprecated, will unconditionally be refused ``MONITOR_FLAG_ACTIVE`` active monitor, ACKs frames on its MAC address ``MONITOR_FLAG_SKIP_TX`` do not pass locally transmitted framesh](h)}(h **Constants**h]j)}(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:48: ./include/net/cfg80211.hhMhj~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.hhMhjubj6)}(hhh]h)}(hset if the flags were changedh]hset if the flags were changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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.hhMhj֜ubj6)}(hhh]h)}(hpass frames with bad FCSh]hpass frames with bad FCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hj֜ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h4``MONITOR_FLAG_PLCPFAIL`` pass frames with bad PLCP h](j)}(h``MONITOR_FLAG_PLCPFAIL``h]j)}(hjh]hMONITOR_FLAG_PLCPFAIL}(hjhhhNhNubah}(h]h ]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)}(hpass frames with bad PLCPh]hpass frames with bad PLCP}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hMhj+ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj*hMhjubj)}(h-``MONITOR_FLAG_CONTROL`` pass control frames h](j)}(h``MONITOR_FLAG_CONTROL``h]j)}(hjNh]hMONITOR_FLAG_CONTROL}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjHubj6)}(hhh]h)}(hpass control framesh]hpass control frames}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjchMhjdubah}(h]h ]h"]h$]h&]uh1j5hjHubeh}(h]h ]h"]h$]h&]uh1jhjchMhjubj)}(h3``MONITOR_FLAG_OTHER_BSS`` disable BSSID filtering h](j)}(h``MONITOR_FLAG_OTHER_BSS``h]j)}(hjh]hMONITOR_FLAG_OTHER_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)}(hdisable BSSID filteringh]hdisable BSSID filtering}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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.hhMhjubj6)}(hhh]h)}(h+deprecated, will unconditionally be refusedh]h+deprecated, will unconditionally be refused}(hjٝhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj՝hMhj֝ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj՝hMhjubj)}(hG``MONITOR_FLAG_ACTIVE`` active monitor, ACKs frames on its MAC address h](j)}(h``MONITOR_FLAG_ACTIVE``h]j)}(hjh]hMONITOR_FLAG_ACTIVE}(hjhhhNhNubah}(h]h ]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.active monitor, ACKs frames on its MAC addressh]h.active monitor, ACKs frames on its MAC address}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h?``MONITOR_FLAG_SKIP_TX`` do not pass locally transmitted framesh](j)}(h``MONITOR_FLAG_SKIP_TX``h]j)}(hj2h]hMONITOR_FLAG_SKIP_TX}(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)}(h&do not pass locally transmitted framesh]h&do not pass locally transmitted frames}(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&]uh1jhjGhMhjubeh}(h]h ]h"]h$]h&]uh1jhj~ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjuh]h Description}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjsubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$bhhubh)}(hgMonitor interface configuration flags. Note that these must be the bits according to the nl80211 flags.h]hgMonitor interface configuration flags. Note that these must be the bits according to the nl80211 flags.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_mpath_info_flags (C enum)c.mpath_info_flagshNtauh1jRhj$bhhhNhNubjd)}(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.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubj)}(hmpath_info_flagsh]j)}(hjh]hmpath_info_flags}(hjӞhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjϞubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMhjhhubj)}(hhh]h)}(hmesh path information flagsh]hmesh path information flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](j$enumeh"]h$]h&]jj$jj jj jjjuh1jchhhj$bhNhNubj)}(hX**Constants** ``MPATH_INFO_FRAME_QLEN`` **frame_qlen** filled ``MPATH_INFO_SN`` **sn** filled ``MPATH_INFO_METRIC`` **metric** filled ``MPATH_INFO_EXPTIME`` **exptime** filled ``MPATH_INFO_DISCOVERY_TIMEOUT`` **discovery_timeout** filled ``MPATH_INFO_DISCOVERY_RETRIES`` **discovery_retries** filled ``MPATH_INFO_FLAGS`` **flags** filled ``MPATH_INFO_HOP_COUNT`` **hop_count** filled ``MPATH_INFO_PATH_CHANGE`` **path_change_count** filledh](h)}(h **Constants**h]j)}(hjh]h Constants}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj)}(hhh](j)}(h0``MPATH_INFO_FRAME_QLEN`` **frame_qlen** filled h](j)}(h``MPATH_INFO_FRAME_QLEN``h]j)}(hj6h]hMPATH_INFO_FRAME_QLEN}(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)}(h**frame_qlen** filledh](j)}(h**frame_qlen**h]h frame_qlen}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhjOubh filled}(hjOhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjKhM hjLubah}(h]h ]h"]h$]h&]uh1j5hj0ubeh}(h]h ]h"]h$]h&]uh1jhjKhM hj-ubj)}(h ``MPATH_INFO_SN`` **sn** filled h](j)}(h``MPATH_INFO_SN``h]j)}(hj}h]h MPATH_INFO_SN}(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 hjwubj6)}(hhh]h)}(h **sn** filledh](j)}(h**sn**h]hsn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh filled}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjwubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(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}(hjhhhNhNubah}(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 hj-ubj)}(h*``MPATH_INFO_EXPTIME`` **exptime** filled h](j)}(h``MPATH_INFO_EXPTIME``h]j)}(hj h]hMPATH_INFO_EXPTIME}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h**exptime** filledh](j)}(h **exptime**h]hexptime}(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 hj-ubj)}(h>``MPATH_INFO_DISCOVERY_TIMEOUT`` **discovery_timeout** filled h](j)}(h ``MPATH_INFO_DISCOVERY_TIMEOUT``h]j)}(hjRh]hMPATH_INFO_DISCOVERY_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**discovery_timeout** filledh](j)}(h**discovery_timeout**h]hdiscovery_timeout}(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 hj-ubj)}(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&]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_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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubj)}(h&``MPATH_INFO_FLAGS`` **flags** filled h](j)}(h``MPATH_INFO_FLAGS``h]j)}(hjh]hMPATH_INFO_FLAGS}(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**flags** filledh](j)}(h **flags**h]hflags}(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 hj-ubj)}(h.``MPATH_INFO_HOP_COUNT`` **hop_count** filled h](j)}(h``MPATH_INFO_HOP_COUNT``h]j)}(hj'h]hMPATH_INFO_HOP_COUNT}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj!ubj6)}(hhh]h)}(h**hop_count** filledh](j)}(h **hop_count**h]h hop_count}(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 hj-ubj)}(h7``MPATH_INFO_PATH_CHANGE`` **path_change_count** filledh](j)}(h``MPATH_INFO_PATH_CHANGE``h]j)}(hjnh]hMPATH_INFO_PATH_CHANGE}(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**path_change_count** filledh](j)}(h**path_change_count**h]hpath_change_count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh filled}(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&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhM hj-ubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj$bhhubh)}(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 }(hjաhhhNhNubh)}(h(:c:type:`struct mpath_info `h]j)}(hjߡh]hstruct mpath_info}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjݡubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6 mpath_infouh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjաubh9 it has filled in during get_station() or dump_station().}(hjաhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_mpath_info (C struct) c.mpath_infohNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(h mpath_infoh]jo)}(hstruct mpath_infoh](ju)}(hjh]hstruct}(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)}(h mpath_infoh]j)}(hjh]h mpath_info}(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)}(hmesh path informationh]hmesh path information}(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$jjzjjzjjjuh1jchhhj$bhNhNubj)}(hXs**Definition**:: struct mpath_info { u32 filled; u32 frame_qlen; u32 sn; u32 metric; u32 exptime; u32 discovery_timeout; u8 discovery_retries; u8 flags; u8 hop_count; u32 path_change_count; int generation; }; **Members** ``filled`` bitfield of flags from :c:type:`enum mpath_info_flags ` ``frame_qlen`` number of queued frames for this destination ``sn`` target sequence number ``metric`` metric (cost) of this mesh path ``exptime`` expiration time for the mesh path from now, in msecs ``discovery_timeout`` total mesh path discovery timeout, in msecs ``discovery_retries`` mesh path discovery retries ``flags`` mesh path flags from :c:type:`enum mesh_path_flags ` ``hop_count`` hops to destination ``path_change_count`` total number of path changes to destination ``generation`` generation number for nl80211 dumps. This number should increase every time the list of mesh paths changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(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 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&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj~ubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM) hj~ubj)}(hhh](j)}(hU``filled`` bitfield of flags from :c:type:`enum mpath_info_flags ` 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.hhM hjɢubj6)}(hhh]h)}(hIbitfield of flags from :c:type:`enum mpath_info_flags `h](hbitfield of flags from }(hjhhhNhNubh)}(h2:c:type:`enum mpath_info_flags `h]j)}(hjh]henum mpath_info_flags}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6mpath_info_flagsuh1hhjhM hjubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjɢubeh}(h]h ]h"]h$]h&]uh1jhjhM hjƢubj)}(h<``frame_qlen`` number of queued frames for this destination h](j)}(h``frame_qlen``h]j)}(hj'h]h frame_qlen}(hj)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,number of queued frames for this destinationh]h,number of queued frames for this destination}(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``sn`` target sequence number h](j)}(h``sn``h]j)}(hj`h]hsn}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjZubj6)}(hhh]h)}(htarget sequence numberh]htarget sequence number}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuhM hjvubah}(h]h ]h"]h$]h&]uh1j5hjZubeh}(h]h ]h"]h$]h&]uh1jhjuhM hjƢubj)}(h+``metric`` metric (cost) of this mesh path h](j)}(h ``metric``h]j)}(hjh]hmetric}(hjhhhNhNubah}(h]h ]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)}(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&]uh1j5hjubeh}(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)}(hjңh]hexptime}(hjԣ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)}(h4expiration time for the mesh path from now, in msecsh]h4expiration time for the mesh path from now, in msecs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hj̣ubeh}(h]h ]h"]h$]h&]uh1jhjhM hjƢubj)}(hB``discovery_timeout`` total mesh path discovery timeout, in msecs h](j)}(h``discovery_timeout``h]j)}(hj h]hdiscovery_timeout}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h+total mesh path discovery timeout, in msecsh]h+total mesh path discovery timeout, in msecs}(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Ƣubj)}(h2``discovery_retries`` mesh path discovery retries h](j)}(h``discovery_retries``h]j)}(hjDh]hdiscovery_retries}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM! hj>ubj6)}(hhh]h)}(hmesh path discovery retriesh]hmesh path discovery retries}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYhM! hjZubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhjYhM! hjƢubj)}(hP``flags`` mesh path flags from :c:type:`enum mesh_path_flags ` h](j)}(h ``flags``h]j)}(hj}h]hflags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjwubj6)}(hhh]h)}(hEmesh path flags from :c:type:`enum mesh_path_flags `h](hmesh path flags from }(hjhhhNhNubh)}(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 refexplicitrefwarnj j j6mesh_path_flagsuh1hhjhM hjubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjwubeh}(h]h ]h"]h$]h&]uh1jhjhM hjƢubj)}(h"``hop_count`` hops to destination h](j)}(h ``hop_count``h]j)}(hjդh]h hop_count}(hjפhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjӤubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM& hjϤubj6)}(hhh]h)}(hhops to destinationh]hhops to destination}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM& hjubah}(h]h ]h"]h$]h&]uh1j5hjϤubeh}(h]h ]h"]h$]h&]uh1jhjhM& hjƢubj)}(hB``path_change_count`` total number of path changes to destination h](j)}(h``path_change_count``h]j)}(hjh]hpath_change_count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM' hjubj6)}(hhh]h)}(h+total number of path changes to destinationh]h+total number of path changes to destination}(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Ƣ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)}(hjGh]h generation}(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)}(hgeneration number for nl80211 dumps. This number should increase every time the list of mesh paths changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.h]hgeneration number for nl80211 dumps. This number should increase every time the list of mesh paths changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM" hj]ubah}(h]h ]h"]h$]h&]uh1j5hjAubeh}(h]h ]h"]h$]h&]uh1jhj\hM$ hjƢubeh}(h]h ]h"]h$]h&]uh1jhj~ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM( hj$bhhubh)}(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 hj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_bss_parameters (C struct)c.bss_parametershNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hbss_parametersh]jo)}(hstruct bss_parametersh](ju)}(hjh]hstruct}(hjȥhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjĥhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hj֥hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjĥhhhjեhM ubj)}(hbss_parametersh]j)}(hj¥h]hbss_parameters}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjĥhhhjեhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjեhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjեhM hjhhubj)}(hhh]h)}(hBSS parametersh]hBSS parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM8 hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjեhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jj"jj"jjjuh1jchhhj$bhNhNubj)}(hX)**Definition**:: struct bss_parameters { int link_id; int use_cts_prot; int use_short_preamble; int use_short_slot_time; const u8 *basic_rates; u8 basic_rates_len; int ap_isolate; int ht_opmode; s8 p2p_ctwindow, p2p_opp_ps; }; **Members** ``link_id`` link_id or -1 for non-MLD ``use_cts_prot`` Whether to use CTS protection (0 = no, 1 = yes, -1 = do not change) ``use_short_preamble`` Whether the use of short preambles is allowed (0 = no, 1 = yes, -1 = do not change) ``use_short_slot_time`` Whether the use of short slot time is allowed (0 = no, 1 = yes, -1 = do not change) ``basic_rates`` basic rates in IEEE 802.11 format (or NULL for no change) ``basic_rates_len`` number of basic rates ``ap_isolate`` do not forward packets between connected stations (0 = no, 1 = yes, -1 = do not change) ``ht_opmode`` HT Operation mode (u16 = opmode, -1 = do not change) ``p2p_ctwindow`` P2P CT Window (-1 = no change) ``p2p_opp_ps`` P2P opportunistic PS (-1 = no change)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(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 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; };}hjGsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM> hj&ubh)}(h **Members**h]j)}(hjXh]hMembers}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMJ hj&ubj)}(hhh](j)}(h&``link_id`` link_id or -1 for non-MLD h](j)}(h ``link_id``h]j)}(hjwh]hlink_id}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM= hjqubj6)}(hhh]h)}(hlink_id or -1 for non-MLDh]hlink_id or -1 for non-MLD}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM= hjubah}(h]h ]h"]h$]h&]uh1j5hjqubeh}(h]h ]h"]h$]h&]uh1jhjhM= hjnubj)}(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)}(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? hjnubj)}(hk``use_short_preamble`` Whether the use of short preambles is allowed (0 = no, 1 = yes, -1 = do not change) h](j)}(h``use_short_preamble``h]j)}(hjh]huse_short_preamble}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMA hjubj6)}(hhh]h)}(hSWhether the use of short preambles is allowed (0 = no, 1 = yes, -1 = do not change)h]hSWhether the use of short preambles is allowed (0 = no, 1 = yes, -1 = do not change)}(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&]uh1jhjhMA hjnubj)}(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)}(hj$h]huse_short_slot_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.hhMC hjubj6)}(hhh]h)}(hSWhether the use of short slot time is allowed (0 = no, 1 = yes, -1 = do not change)h]hSWhether the use of short slot time is allowed (0 = no, 1 = yes, -1 = do not change)}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMB hj:ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj9hMC hjnubj)}(hJ``basic_rates`` basic rates in IEEE 802.11 format (or NULL for no change) h](j)}(h``basic_rates``h]j)}(hj^h]h basic_rates}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhME hjXubj6)}(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)}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMD hjtubah}(h]h ]h"]h$]h&]uh1j5hjXubeh}(h]h ]h"]h$]h&]uh1jhjshME hjnubj)}(h*``basic_rates_len`` number of basic rates h](j)}(h``basic_rates_len``h]j)}(hjh]hbasic_rates_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.hhMF hjubj6)}(hhh]h)}(hnumber of basic ratesh]hnumber of basic rates}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMF hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMF hjnubj)}(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)}(hjѧh]h ap_isolate}(hjӧ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.hhMH hj˧ubj6)}(hhh]h)}(hWdo not forward packets between connected stations (0 = no, 1 = yes, -1 = do not change)h]hWdo not forward packets between connected stations (0 = no, 1 = yes, -1 = do not change)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMG hjubah}(h]h ]h"]h$]h&]uh1j5hj˧ubeh}(h]h ]h"]h$]h&]uh1jhjhMH hjnubj)}(hC``ht_opmode`` HT Operation mode (u16 = opmode, -1 = do not change) h](j)}(h ``ht_opmode``h]j)}(hj h]h ht_opmode}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMJ hjubj6)}(hhh]h)}(h4HT Operation mode (u16 = opmode, -1 = do not change)h]h4HT Operation mode (u16 = opmode, -1 = do not change)}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMI hj!ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMJ hjnubj)}(h0``p2p_ctwindow`` P2P CT Window (-1 = no change) h](j)}(h``p2p_ctwindow``h]j)}(hjEh]h p2p_ctwindow}(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.hhMK hj?ubj6)}(hhh]h)}(hP2P CT Window (-1 = no change)h]hP2P CT Window (-1 = no change)}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhMK hj[ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhjZhMK hjnubj)}(h4``p2p_opp_ps`` P2P opportunistic PS (-1 = no change)h](j)}(h``p2p_opp_ps``h]j)}(hj~h]h p2p_opp_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.hhMK hjxubj6)}(hhh]h)}(h%P2P opportunistic PS (-1 = no change)h]h%P2P opportunistic PS (-1 = no change)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhML hjubah}(h]h ]h"]h$]h&]uh1j5hjxubeh}(h]h ]h"]h$]h&]uh1jhjhMK hjnubeh}(h]h ]h"]h$]h&]uh1jhj&ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjèhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMO hj$bhhubh)}(h3Used to change BSS parameters (mainly for AP mode).h]h3Used to change BSS parameters (mainly for AP mode).}(hjרhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM9 hj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ieee80211_txq_params (C struct)c.ieee80211_txq_paramshNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hieee80211_txq_paramsh]jo)}(hstruct ieee80211_txq_paramsh](ju)}(hjh]hstruct}(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 }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhj hM> ubj)}(hieee80211_txq_paramsh]j)}(hjh]hieee80211_txq_params}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(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)}(hTX queue parametersh]hTX queue parameters}(hjAhhhNhNubah}(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$jjYjjYjjjuh1jchhhj$bhNhNubj)}(hX"**Definition**:: struct ieee80211_txq_params { enum nl80211_ac ac; u16 txop; u16 cwmin; u16 cwmax; u8 aifs; int link_id; }; **Members** ``ac`` AC identifier ``txop`` Maximum burst time in units of 32 usecs, 0 meaning disabled ``cwmin`` Minimum contention window [a value of the form 2^n-1 in the range 1..32767] ``cwmax`` Maximum contention window [a value of the form 2^n-1 in the range 1..32767] ``aifs`` Arbitration interframe space [0..255] ``link_id`` link_id or -1 for non-MLDh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjaubh:}(hjahhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj]ubj( )}(hstruct ieee80211_txq_params { enum nl80211_ac ac; u16 txop; u16 cwmin; u16 cwmax; u8 aifs; int link_id; };h]hstruct ieee80211_txq_params { enum nl80211_ac ac; u16 txop; u16 cwmin; u16 cwmax; u8 aifs; int link_id; };}hj~sbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj]ubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj]ubj)}(hhh](j)}(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}(hjǩhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjéhM hjĩubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjéhM hjubj)}(hE``txop`` Maximum burst time in units of 32 usecs, 0 meaning disabled h](j)}(h``txop``h]j)}(hjh]htxop}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h;Maximum burst time in units of 32 usecs, 0 meaning disabledh]h;Maximum burst time in units of 32 usecs, 0 meaning disabled}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM 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)}(hj h]hcwmin}(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)}(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]}(hj9hhhNhNubah}(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)}(hV``cwmax`` Maximum contention window [a value of the form 2^n-1 in the range 1..32767] h](j)}(h ``cwmax``h]j)}(hjZh]hcwmax}(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)}(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]}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjpubah}(h]h ]h"]h$]h&]uh1j5hjTubeh}(h]h ]h"]h$]h&]uh1jhjohM hjubj)}(h/``aifs`` Arbitration interframe space [0..255] h](j)}(oh``aifs``h]j)}(hjh]haifs}(hjhhhNhNubah}(h]h ]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%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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h%``link_id`` link_id or -1 for non-MLDh](j)}(h ``link_id``h]j)}(hjͪh]hlink_id}(hjϪ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)}(hlink_id or -1 for non-MLDh]hlink_id or -1 for non-MLD}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjǪubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubeh}(h]h ]h"]h$]h&]uh1jhj]ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ cfg80211_auth_request (C struct)c.cfg80211_auth_requesthNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hcfg80211_auth_requesth]jo)}(hstruct cfg80211_auth_requesth](ju)}(hjh]hstruct}(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj#hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#hhhj4hM ubj)}(hcfg80211_auth_requesth]j)}(hj!h]hcfg80211_auth_request}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjCubah}(h]h ](jjeh"]h$]h&]jjuh1jhj#hhhj4hM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhj4hM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhj4hM hjhhubj)}(hhh]h)}(hAuthentication request datah]hAuthentication request data}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjfhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj4hM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhj$bhNhNubj)}(hX**Definition**:: struct cfg80211_auth_request { struct cfg80211_bss *bss; const u8 *ie; size_t ie_len; const u8 *supported_selectors; u8 supported_selectors_len; enum nl80211_auth_type auth_type; const u8 *key; u8 key_len; s8 key_idx; const u8 *auth_data; size_t auth_data_len; s8 link_id; const u8 *ap_mld_addr; }; **Members** ``bss`` The BSS to authenticate with, the callee must obtain a reference to it if it needs to keep it. ``ie`` Extra IEs to add to Authentication frame or ``NULL`` ``ie_len`` Length of ie buffer in octets ``supported_selectors`` List of selectors that should be assumed to be supported by the station. SAE_H2E must be assumed supported if set to ``NULL``. ``supported_selectors_len`` Length of supported_selectors in octets. ``auth_type`` Authentication type (algorithm) ``key`` WEP key for shared key authentication ``key_len`` length of WEP key for shared key authentication ``key_idx`` index of WEP key for shared key authentication ``auth_data`` Fields and elements in Authentication frames. This contains the authentication frame body (non-IE and IE data), excluding the Authentication algorithm number, i.e., starting at the Authentication transaction sequence number field. ``auth_data_len`` Length of auth_data buffer in octets ``link_id`` if >= 0, indicates authentication should be done as an MLD, the interface address is included as the MLD address and the necessary link (with the given link_id) will be created (and given an MLD address) by the driver ``ap_mld_addr`` AP MLD address in case of authentication request with an AP MLD, valid iff **link_id** >= 0h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(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( )}(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&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj)}(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)}(hj֫h]hbss}(hjثhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjԫubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjЫubj6)}(hhh]h)}(h^The BSS to authenticate with, the callee must obtain a reference to it if it needs to keep it.h]h^The BSS to authenticate with, the callee must obtain a reference to it if it needs to keep it.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjЫubeh}(h]h ]h"]h$]h&]uh1jhjhM hjͫubj)}(h<``ie`` Extra IEs to add to Authentication 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 hj ubj6)}(hhh]h)}(h4Extra IEs to add to Authentication frame or ``NULL``h](h,Extra IEs to add to Authentication frame or }(hj)hhhNhNubj)}(h``NULL``h]hNULL}(hj1hhhNhNubah}(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 buffer in octets h](j)}(h ``ie_len``h]j)}(hjWh]hie_len}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjQubj6)}(hhh]h)}(hLength of ie buffer in octetsh]hLength of ie buffer in octets}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhM hjmubah}(h]h ]h"]h$]h&]uh1j5hjQubeh}(h]h ]h"]h$]h&]uh1jhjlhM hjͫubj)}(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)}(hjh]hsupported_selectors}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(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.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjͫubj)}(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.hhM hj֬ubj6)}(hhh]h)}(h(Length of supported_selectors in octets.h]h(Length of supported_selectors in octets.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hj֬ubeh}(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)}(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ͫubj)}(h.``key`` WEP key for shared key authentication h](j)}(h``key``h]j)}(hjNh]hkey}(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%WEP key for shared key authenticationh]h%WEP key for shared key authentication}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjchM hjdubah}(h]h ]h"]h$]h&]uh1j5hjHubeh}(h]h ]h"]h$]h&]uh1jhjchM 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}(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.index of WEP key for shared key authenticationh]h.index of WEP key for shared key authentication}(hj٭hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjխhM hj֭ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjխhM hjͫubj)}(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)}(hjh]h auth_data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(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.}(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)}(h7``auth_data_len`` Length of auth_data buffer in octets h](j)}(h``auth_data_len``h]j)}(hj3h]h auth_data_len}(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)}(h$Length of auth_data buffer in octetsh]h$Length of auth_data buffer in octets}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHhM hjIubah}(h]h ]h"]h$]h&]uh1j5hj-ubeh}(h]h ]h"]h$]h&]uh1jhjHhM hjͫubj)}(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)}(hjlh]hlink_id}(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)}(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}(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ͫubj)}(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}(hjǮhhhNhNubah}(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 hjͫubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj$bhhubh)}(hRThis structure provides information needed to complete IEEE 802.11 authentication.h]hRThis structure provides information needed to complete IEEE 802.11 authentication.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_!cfg80211_assoc_request (C struct)c.cfg80211_assoc_requesthNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hcfg80211_assoc_requesth]jo)}(hstruct cfg80211_assoc_requesth](ju)}(hjh]hstruct}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj4hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4hhhjEhM ubj)}(hcfg80211_assoc_requesth]j)}(hj2h]hcfg80211_assoc_request}(hjXhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjTubah}(h]h ](jjeh"]h$]h&]jjuh1jhj4hhhjEhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj0hhhjEhM ubah}(h]j+ah ](jjeh"]h$]h&]jj)jhuh1jhhjEhM hj-hhubj)}(hhh]h)}(h(Re)Association request datah]h(Re)Association request data}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhME hjwhhubah}(h]h ]h"]h$]h&]uh1jhj-hhhjEhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhj$bhNhNubj)}(hX **Definition**:: struct cfg80211_assoc_request { struct cfg80211_bss *bss; const u8 *ie, *prev_bssid; size_t ie_len; struct cfg80211_crypto_settings crypto; bool use_mfp; u32 flags; const u8 *supported_selectors; u8 supported_selectors_len; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct ieee80211_vht_cap vht_capa, vht_capa_mask; const u8 *fils_kek; size_t fils_kek_len; const u8 *fils_nonces; struct ieee80211_s1g_cap s1g_capa, s1g_capa_mask; struct cfg80211_assoc_link links[IEEE80211_MLD_MAX_NUM_LINKS]; const u8 *ap_mld_addr; s8 link_id; u16 ext_mld_capa_ops; }; **Members** ``bss`` The BSS to associate with. If the call is successful the driver is given a reference that it must give back to cfg80211_send_rx_assoc() or to cfg80211_assoc_timeout(). To ensure proper refcounting, new association requests while already associating must be rejected. This also applies to the **links.bss** parameter, which is used instead of this one (it is ``NULL``) for MLO associations. ``ie`` Extra IEs to add to (Re)Association Request frame or ``NULL`` ``prev_bssid`` previous BSSID, if not ``NULL`` use reassociate frame. This is used to indicate a request to reassociate within the ESS instead of a request do the initial association with the ESS. When included, this is set to the BSSID of the current association, i.e., to the value that is included in the Current AP address field of the Reassociation Request frame. ``ie_len`` Length of ie buffer in octets ``crypto`` crypto settings ``use_mfp`` Use management frame protection (IEEE 802.11w) in this association ``flags`` See :c:type:`enum cfg80211_assoc_req_flags ` ``supported_selectors`` supported BSS selectors in IEEE 802.11 format (or ``NULL`` for no change). If ``NULL``, then support for SAE_H2E should be assumed. ``supported_selectors_len`` number of supported BSS selectors ``ht_capa`` HT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored. ``ht_capa_mask`` The bits of ht_capa which are to be used. ``vht_capa`` VHT capability override ``vht_capa_mask`` VHT capability mask indicating which fields to use ``fils_kek`` FILS KEK for protecting (Re)Association Request/Response frame or ``NULL`` if FILS is not used. ``fils_kek_len`` Length of fils_kek in octets ``fils_nonces`` FILS nonces (part of AAD) for protecting (Re)Association Request/Response frame or ``NULL`` if FILS is not used. This field starts with 16 octets of STA Nonce followed by 16 octets of AP Nonce. ``s1g_capa`` S1G capability override ``s1g_capa_mask`` S1G capability override mask ``links`` per-link information for MLO connections ``ap_mld_addr`` AP MLD address in case of MLO association request, valid iff **link_id** >= 0 ``link_id`` >= 0 for MLO connections, where links are given, and indicates the link on which the association request should be sent ``ext_mld_capa_ops`` extended MLD capabilities and operations set by userspace for the associationh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(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.hhMI hjubj( )}(hXstruct cfg80211_assoc_request { struct cfg80211_bss *bss; const u8 *ie, *prev_bssid; size_t ie_len; struct cfg80211_crypto_settings crypto; bool use_mfp; u32 flags; const u8 *supported_selectors; u8 supported_selectors_len; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct ieee80211_vht_cap vht_capa, vht_capa_mask; const u8 *fils_kek; size_t fils_kek_len; const u8 *fils_nonces; struct ieee80211_s1g_cap s1g_capa, s1g_capa_mask; struct cfg80211_assoc_link links[IEEE80211_MLD_MAX_NUM_LINKS]; const u8 *ap_mld_addr; s8 link_id; u16 ext_mld_capa_ops; };h]hXstruct cfg80211_assoc_request { struct cfg80211_bss *bss; const u8 *ie, *prev_bssid; size_t ie_len; struct cfg80211_crypto_settings crypto; bool use_mfp; u32 flags; const u8 *supported_selectors; u8 supported_selectors_len; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct ieee80211_vht_cap vht_capa, vht_capa_mask; const u8 *fils_kek; size_t fils_kek_len; const u8 *fils_nonces; struct ieee80211_s1g_cap s1g_capa, s1g_capa_mask; struct cfg80211_assoc_link links[IEEE80211_MLD_MAX_NUM_LINKS]; const u8 *ap_mld_addr; s8 link_id; u16 ext_mld_capa_ops; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMK 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.hhMa hjubj)}(hhh](j)}(hX``bss`` The BSS to associate with. If the call is successful the driver is given a reference that it must give back to cfg80211_send_rx_assoc() or to cfg80211_assoc_timeout(). To ensure proper refcounting, new association requests while already associating must be rejected. This also applies to the **links.bss** parameter, which is used instead of this one (it is ``NULL``) for MLO associations. h](j)}(h``bss``h]j)}(hjh]hbss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMO hjubj6)}(hhh]h)}(hXThe BSS to associate with. If the call is successful the driver is given a reference that it must give back to cfg80211_send_rx_assoc() or to cfg80211_assoc_timeout(). To ensure proper refcounting, new association requests while already associating must be rejected. This also applies to the **links.bss** parameter, which is used instead of this one (it is ``NULL``) for MLO associations.h](hX$The BSS to associate with. If the call is successful the driver is given a reference that it must give back to cfg80211_send_rx_assoc() or to cfg80211_assoc_timeout(). To ensure proper refcounting, new association requests while already associating must be rejected. This also applies to the }(hjhhhNhNubj)}(h **links.bss**h]h links.bss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh5 parameter, which is used instead of this one (it is }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh) for MLO associations.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMJ hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMO hjޯubj)}(hE``ie`` Extra IEs to add to (Re)Association Request frame or ``NULL`` h](j)}(h``ie``h]j)}(hjEh]hie}(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.hhMP hj?ubj6)}(hhh]h)}(h=Extra IEs to add to (Re)Association Request frame or ``NULL``h](h5Extra IEs to add to (Re)Association Request frame or }(hj^hhhNhNubj)}(h``NULL``h]hNULL}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubeh}(h]h ]h"]h$]h&]uh1hhjZhMP hj[ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhjZhMP 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.hhMY 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.hhMT hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMY hjޯubj)}(h)``ie_len`` Length of ie buffer in octets h](j)}(h ``ie_len``h]j)}(hjذh]hie_len}(hjڰhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjְubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMQ hjҰubj6)}(hhh]h)}(hLength of ie buffer in octetsh]hLength of ie buffer in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMQ hjubah}(h]h ]h"]h$]h&]uh1j5hjҰubeh}(h]h ]h"]h$]h&]uh1jhjhMQ 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.hhMS hj ubj6)}(hhh]h)}(hcrypto settingsh]hcrypto settings}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&hMS hj'ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj&hMS hjޯubj)}(hO``use_mfp`` Use management frame protection (IEEE 802.11w) in this association h](j)}(h ``use_mfp``h]j)}(hjJh]huse_mfp}(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.hhMR hjDubj6)}(hhh]h)}(hBUse management frame protection (IEEE 802.11w) in this associationh]hBUse management frame protection (IEEE 802.11w) in this association}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_hMR hj`ubah}(h]h ]h"]h$]h&]uh1j5hjDubeh}(h]h ]h"]h$]h&]uh1jhj_hMR 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.hhMZ hj}ubj6)}(hhh]h)}(hFSee :c:type:`enum cfg80211_assoc_req_flags `h](hSee }(hjhhhNhNubh)}(hB:c:type:`enum cfg80211_assoc_req_flags `h]j)}(hjh]henum cfg80211_assoc_req_flags}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6cfg80211_assoc_req_flagsuh1hhjhMZ hjubeh}(h]h ]h"]h$]h&]uh1hhjhMZ hjubah}(h]h ]h"]h$]h&]uh1j5hj}ubeh}(h]h ]h"]h$]h&]uh1jhjhMZ 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] hjձubj6)}(hhh]h)}(hsupported BSS selectors in IEEE 802.11 format (or ``NULL`` for no change). If ``NULL``, then support for SAE_H2E should be assumed.h](h2supported BSS selectors in IEEE 802.11 format (or }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh for no change). If }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh-, then support for SAE_H2E should be assumed.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM[ hjubah}(h]h ]h"]h$]h&]uh1j5hjձubeh}(h]h ]h"]h$]h&]uh1jhjhM] hjޯubj)}(h>``supported_selectors_len`` number of supported BSS selectors h](j)}(h``supported_selectors_len``h]j)}(hj9h]hsupported_selectors_len}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM^ hj3ubj6)}(hhh]h)}(h!number of supported BSS selectorsh]h!number of supported BSS selectors}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjNhM^ hjOubah}(h]h ]h"]h$]h&]uh1j5hj3ubeh}(h]h ]h"]h$]h&]uh1jhjNhM^ 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)}(hjrh]hht_capa}(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)}(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&]uh1j5hjlubeh}(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.hhMa 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&]uh1hhjhMa hj²ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMa hjޯubj)}(h%``vht_capa`` VHT capability override h](j)}(h ``vht_capa``h]j)}(hjh]hvht_capa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMb hj߲ubj6)}(hhh]h)}(hVHT capability overrideh]hVHT capability override}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMb hjubah}(h]h ]h"]h$]h&]uh1j5hj߲ubeh}(h]h ]h"]h$]h&]uh1jhjhMb hjޯubj)}(hE``vht_capa_mask`` VHT capability mask indicating which fields to use h](j)}(h``vht_capa_mask``h]j)}(hjh]h vht_capa_mask}(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.hhMc hjubj6)}(hhh]h)}(h2VHT capability mask indicating which fields to useh]h2VHT capability mask indicating which fields to use}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMc hj4ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj3hMc 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)}(hjWh]hfils_kek}(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.hhMe hjQubj6)}(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 }(hjphhhNhNubj)}(h``NULL``h]hNULL}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubh if FILS is not used.}(hjphhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMd hjmubah}(h]h ]h"]h$]h&]uh1j5hjQubeh}(h]h ]h"]h$]h&]uh1jhjlhMe 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.hhMf hjubj6)}(hhh]h)}(hLength of fils_kek in octetsh]hLength of fils_kek in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMf hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMf 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.hhMi hjֳubj6)}(hhh]h)}(hFILS nonces (part of AAD) for protecting (Re)Association Request/Response frame or ``NULL`` if FILS is not used. This field starts with 16 octets of STA Nonce followed by 16 octets of AP Nonce.h](hSFILS nonces (part of AAD) for protecting (Re)Association Request/Response frame or }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhf if FILS is not used. This field starts with 16 octets of STA Nonce followed by 16 octets of AP Nonce.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMg hjubah}(h]h ]h"]h$]h&]uh1j5hjֳubeh}(h]h ]h"]h$]h&]uh1jhjhMi hjޯubj)}(h%``s1g_capa`` S1G capability override h](j)}(h ``s1g_capa``h]j)}(hj(h]hs1g_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.hhMj hj"ubj6)}(hhh]h)}(hS1G capability overrideh]hS1G capability override}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=hMj hj>ubah}(h]h ]h"]h$]h&]uh1j5hj"ubeh}(h]h ]h"]h$]h&]uh1jhj=hMj hjޯubj)}(h/``s1g_capa_mask`` S1G capability override mask h](j)}(h``s1g_capa_mask``h]j)}(hjah]h s1g_capa_mask}(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.hhMk hj[ubj6)}(hhh]h)}(hS1G capability override maskh]hS1G capability override mask}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvhMk hjwubah}(h]h ]h"]h$]h&]uh1j5hj[ubeh}(h]h ]h"]h$]h&]uh1jhjvhMk hjޯubj)}(h3``links`` per-link information for MLO connections 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.hhMl hjubj6)}(hhh]h)}(h(per-link information for MLO connectionsh]h(per-link information for MLO connections}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMl hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMl 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)}(hjӴh]h ap_mld_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.hhMp hjʹubj6)}(hhh]h)}(hMAP MLD address in case of MLO association request, valid iff **link_id** >= 0h](h=AP MLD address in case of MLO association request, valid iff }(hjhhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh >= 0}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMo hjubah}(h]h ]h"]h$]h&]uh1j5hjʹubeh}(h]h ]h"]h$]h&]uh1jhjhMp 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)}(hjh]hlink_id}(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.hhMn hjubj6)}(hhh]h)}(hw>= 0 for MLO connections, where links are given, and indicates the link on which the association request should be senth]hw>= 0 for MLO connections, where links are given, and indicates the link on which the association request should be sent}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMm hj5ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj4hMn 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)}(hjYh]hext_mld_capa_ops}(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.hhMq hjSubj6)}(hhh]h)}(hMextended MLD capabilities and operations set by userspace for the associationh]hMextended MLD capabilities and operations set by userspace for the association}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhMq hjoubah}(h]h ]h"]h$]h&]uh1j5hjSubeh}(h]h ]h"]h$]h&]uh1jhjnhMq hjޯubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMu hj$bhhubh)}(hSThis structure provides information needed to complete IEEE 802.11 (re)association.h]hSThis structure provides information needed to complete IEEE 802.11 (re)association.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMF hj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_deauth_request (C struct)c.cfg80211_deauth_requesthNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hcfg80211_deauth_requesth]jo)}(hstruct cfg80211_deauth_requesth](ju)}(hjh]hstruct}(hjٵhhhNhNubah}(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_deauth_requesth]j)}(hjӵh]hcfg80211_deauth_request}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjյhhhjhML ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjѵhhhjhML ubah}(h]j̵ah ](jjeh"]h$]h&]jj)jhuh1jhhjhML hjεhhubj)}(hhh]h)}(hDeauthentication request datah]hDeauthentication request data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhjεhhhjhML ubeh}(h]h ](j$structeh"]h$]h&]jj$jj3jj3jjjuh1jchhhj$bhNhNubj)}(hX**Definition**:: struct cfg80211_deauth_request { const u8 *bssid; const u8 *ie; size_t ie_len; u16 reason_code; bool local_state_change; }; **Members** ``bssid`` the BSSID or AP MLD address to deauthenticate from ``ie`` Extra IEs to add to Deauthentication frame or ``NULL`` ``ie_len`` Length of ie buffer in octets ``reason_code`` The reason code for the deauthentication ``local_state_change`` if set, change local state only and do not set a deauth frameh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(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 hj7ubj( )}(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; };}hjXsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj7ubh)}(h **Members**h]j)}(hjih]hMembers}(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.hhM hj7ubj)}(hhh](j)}(h=``bssid`` the BSSID or AP MLD address to deauthenticate from 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)}(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&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjڶubeh}(h]h ]h"]h$]h&]uh1hhjֶhM hj׶ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjֶhM hjubj)}(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}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h9``reason_code`` The reason code for the deauthentication h](j)}(h``reason_code``h]j)}(hjAh]h reason_code}(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)}(h(The reason code for the deauthenticationh]h(The reason code for the deauthentication}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhM hjWubah}(h]h ]h"]h$]h&]uh1j5hj;ubeh}(h]h ]h"]h$]h&]uh1jhjVhM hjubj)}(hT``local_state_change`` if set, change local state only and do not set a deauth frameh](j)}(h``local_state_change``h]j)}(hjzh]hlocal_state_change}(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=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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjtubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubeh}(h]h ]h"]h$]h&]uh1jhj7ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj$bhhubh)}(hTThis structure provides information needed to complete IEEE 802.11 deauthentication.h]hTThis structure provides information needed to complete IEEE 802.11 deauthentication.}(hjҷhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_$cfg80211_disassoc_request (C struct)c.cfg80211_disassoc_requesthNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hcfg80211_disassoc_requesth]jo)}(h struct cfg80211_disassoc_requesth](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(hcfg80211_disassoc_requesth]j)}(hjh]hcfg80211_disassoc_request}(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)}(hDisassociation request datah]hDisassociation request data}(hj<hhhNhNubah}(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&]uh1jhjhhhjhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjTjjTjjjuh1jchhhj$bhNhNubj)}(hX**Definition**:: struct cfg80211_disassoc_request { const u8 *ap_addr; const u8 *ie; size_t ie_len; u16 reason_code; bool local_state_change; }; **Members** ``ap_addr`` the BSSID or AP MLD address to disassociate from ``ie`` Extra IEs to add to Disassociation frame or ``NULL`` ``ie_len`` Length of ie buffer in octets ``reason_code`` The reason code for the disassociation ``local_state_change`` This is a request for a local state only, i.e., no Disassociation frame is to be transmitted.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\ubh:}(hj\hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjXubj( )}(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; };}hjysbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjXubh)}(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 hjXubj)}(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)}(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 hjܸubj6)}(hhh]h)}(h4Extra IEs to add to Disassociation frame or ``NULL``h](h,Extra IEs to add to Disassociation 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&]uh1j5hjܸubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h)``ie_len`` Length of ie buffer in octets h](j)}(h ``ie_len``h]j)}(hj)h]hie_len}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj#ubj6)}(hhh]h)}(hLength of ie buffer in octetsh]hLength of ie buffer in octets}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hM hj?ubah}(h]h ]h"]h$]h&]uh1j5hj#ubeh}(h]h ]h"]h$]h&]uh1jhj>hM hjubj)}(h7``reason_code`` The reason code for the disassociation h](j)}(h``reason_code``h]j)}(hjbh]h reason_code}(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)}(h&The reason code for the disassociationh]h&The reason code for the disassociation}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwhM hjxubah}(h]h ]h"]h$]h&]uh1j5hj\ubeh}(h]h ]h"]h$]h&]uh1jhjwhM 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.hhM hjubj6)}(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&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubeh}(h]h ]h"]h$]h&]uh1jhjXubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjݹh]h Description}(hj߹hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj۹ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj$bhhubh)}(hRThis structure provides information needed to complete IEEE 802.11 disassociation.h]hRThis structure provides information needed to complete IEEE 802.11 disassociation.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_ibss_params (C struct)c.cfg80211_ibss_paramshNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hcfg80211_ibss_paramsh]jo)}(hstruct cfg80211_ibss_paramsh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhj(hM ubj)}(hcfg80211_ibss_paramsh]j)}(hjh]hcfg80211_ibss_params}(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7ubah}(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)}(hIBSS parametersh]hIBSS parameters}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjZhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj(hM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjujjujjjuh1jchhhj$bhNhNubj)}(hX**Definition**:: struct cfg80211_ibss_params { const u8 *ssid; const u8 *bssid; struct cfg80211_chan_def chandef; const u8 *ie; u8 ssid_len, ie_len; u16 beacon_interval; u32 basic_rates; bool channel_fixed; bool privacy; bool control_port; bool control_port_over_nl80211; bool userspace_handles_dfs; int mcast_rate[NUM_NL80211_BANDS]; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct key_params *wep_keys; int wep_tx_key; }; **Members** ``ssid`` The SSID, will always be non-null. ``bssid`` Fixed BSSID requested, maybe be ``NULL``, if set do not search for IBSSs with a different BSSID. ``chandef`` defines the channel to use if no other IBSS to join can be found ``ie`` information element(s) to include in the beacon ``ssid_len`` The length of the SSID, will always be non-zero. ``ie_len`` length of that ``beacon_interval`` beacon interval to use ``basic_rates`` bitmap of basic rates to use when creating the IBSS ``channel_fixed`` The channel should be fixed -- do not search for IBSSs to join on other channels. ``privacy`` this is a protected network, keys will be configured after joining ``control_port`` whether user space controls IEEE 802.1X port, i.e., sets/clears ``NL80211_STA_FLAG_AUTHORIZED``. If true, the driver is required to assume that the port is unauthorized until authorized by user space. Otherwise, port is marked authorized by default. ``control_port_over_nl80211`` TRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface. ``userspace_handles_dfs`` whether user space controls DFS operation, i.e. changes the channel when a radar is detected. This is required to operate on DFS channels. ``mcast_rate`` per-band multicast rate index + 1 (0: disabled) ``ht_capa`` HT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored. ``ht_capa_mask`` The bits of ht_capa which are to be used. ``wep_keys`` static WEP keys, if not NULL points to an array of CFG80211_MAX_WEP_KEYS WEP keys ``wep_tx_key`` key index (0..3) of the default TX static WEP keyh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(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 hjyubj( )}(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&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjyubh)}(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 hjyubj)}(hhh](j)}(h,``ssid`` The SSID, will always be non-null. h](j)}(h``ssid``h]j)}(hjʺh]hssid}(hj̺hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjȺubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjĺubj6)}(hhh]h)}(h"The SSID, will always be non-null.h]h"The SSID, will always be non-null.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjߺhM hjubah}(h]h ]h"]h$]h&]uh1j5hjĺubeh}(h]h ]h"]h$]h&]uh1jhjߺhM 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)}(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`Fixed BSSID requested, maybe be ``NULL``, if set do not search for IBSSs with a different BSSID.h](h Fixed BSSID requested, maybe be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh8, if set do not search for IBSSs with a different BSSID.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hM``chandef`` defines the channel to use if no other IBSS to join can be found h](j)}(h ``chandef``h]j)}(hjOh]hchandef}(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)}(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}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdhM hjeubah}(h]h ]h"]h$]h&]uh1j5hjIubeh}(h]h ]h"]h$]h&]uh1jhjdhM hjubj)}(h7``ie`` information element(s) to include in the beacon 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/information element(s) to include in the beaconh]h/information element(s) to include in the beacon}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM 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.hhM hjubj6)}(hhh]h)}(h0The length of the SSID, will always be non-zero.h]h0The length of the SSID, will always be non-zero.}(hjڻhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjֻhM hj׻ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjֻhM hjubj)}(h``ie_len`` length of that h](j)}(h ``ie_len``h]j)}(hjh]hie_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hlength of thath]hlength of that}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h+``beacon_interval`` beacon interval to use h](j)}(h``beacon_interval``h]j)}(hj3h]hbeacon_interval}(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)}(hbeacon interval to useh]hbeacon interval to use}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHhM hjIubah}(h]h ]h"]h$]h&]uh1j5hj-ubeh}(h]h ]h"]h$]h&]uh1jhjHhM hjubj)}(hD``basic_rates`` bitmap of basic rates to use when creating the IBSS h](j)}(h``basic_rates``h]j)}(hjlh]h basic_rates}(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)}(h3bitmap of basic rates to use when creating the IBSSh]h3bitmap of basic rates to use when creating the IBSS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhjhM 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.hhM 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.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hO``privacy`` this is a protected network, keys will be configured after joining h](j)}(h ``privacy``h]j)}(hj߼h]hprivacy}(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)}(hBthis is a protected network, keys will be configured after joiningh]hBthis is a protected network, keys will be configured after joining}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjټubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hX ``control_port`` whether user space controls IEEE 802.1X port, i.e., sets/clears ``NL80211_STA_FLAG_AUTHORIZED``. If true, the driver is required to assume that the port is unauthorized until authorized by user space. Otherwise, port is marked authorized by default. h](j)}(h``control_port``h]j)}(hjh]h control_port}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(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 }(hj2hhhNhNubj)}(h``NL80211_STA_FLAG_AUTHORIZED``h]hNL80211_STA_FLAG_AUTHORIZED}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubh. 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.}(hj2hhhNhNubeh}(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)}(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)}(hjeh]hcontrol_port_over_nl80211}(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)}(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.hhM hj{ubah}(h]h ]h"]h$]h&]uh1j5hj_ubeh}(h]h ]h"]h$]h&]uh1jhjzhM 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.hhM 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.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM 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&]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-band multicast rate index + 1 (0: disabled)h]h/per-band multicast rate index + 1 (0: disabled)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjӽubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h``ht_capa`` HT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored. h](j)}(h ``ht_capa``h]j)}(hjh]hht_capa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj ubj6)}(hhh]h)}(hvHT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored.h]hvHT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored.}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj(ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj'hM hjubj)}(h;``ht_capa_mask`` The bits of ht_capa which are to be used. h](j)}(h``ht_capa_mask``h]j)}(hjLh]h ht_capa_mask}(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)}(h)The bits of ht_capa which are to be used.h]h)The bits of ht_capa which are to be used.}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjahM hjbubah}(h]h ]h"]h$]h&]uh1j5hjFubeh}(h]h ]h"]h$]h&]uh1jhjahM 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}(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&]uh1jhjyubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj$bhhubh)}(hFThis structure defines the IBSS parameters for the join_ibss() method.h]hFThis structure defines the IBSS parameters for the join_ibss() method.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_connect_params (C struct)c.cfg80211_connect_paramshNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hcfg80211_connect_paramsh]jo)}(hstruct cfg80211_connect_paramsh](ju)}(hjh]hstruct}(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj<hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj<hhhjMhM ubj)}(hcfg80211_connect_paramsh]j)}(hj:h]hcfg80211_connect_params}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj<hhhjMhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj8hhhjMhM ubah}(h]j3ah ](jjeh"]h$]h&]jj)jhuh1jhhjMhM hj5hhubj)}(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&]uh1jhj5hhhjMhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhj$bhNhNubj)}(hX**Definition**:: struct cfg80211_connect_params { struct ieee80211_channel *channel; struct ieee80211_channel *channel_hint; const u8 *bssid; const u8 *bssid_hint; const u8 *ssid; size_t ssid_len; enum nl80211_auth_type auth_type; const u8 *ie; size_t ie_len; bool privacy; enum nl80211_mfp mfp; struct cfg80211_crypto_settings crypto; const u8 *key; u8 key_len, key_idx; u32 flags; int bg_scan_period; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct ieee80211_vht_cap vht_capa; struct ieee80211_vht_cap vht_capa_mask; bool pbss; struct cfg80211_bss_selection bss_select; const u8 *prev_bssid; const u8 *fils_erp_username; size_t fils_erp_username_len; const u8 *fils_erp_realm; size_t fils_erp_realm_len; u16 fils_erp_next_seq_num; const u8 *fils_erp_rrk; size_t fils_erp_rrk_len; bool want_1x; struct ieee80211_edmg edmg; }; **Members** ``channel`` The channel to use or ``NULL`` if not specified (auto-select based on scan results) ``channel_hint`` The channel of the recommended BSS for initial connection or ``NULL`` if not specified ``bssid`` The AP BSSID or ``NULL`` if not specified (auto-select based on scan results) ``bssid_hint`` The recommended AP BSSID for initial connection to the BSS or ``NULL`` if not specified. Unlike the **bssid** parameter, the driver is allowed to ignore this **bssid_hint** if it has knowledge of a better BSS to use. ``ssid`` SSID ``ssid_len`` Length of ssid in octets ``auth_type`` Authentication type (algorithm) ``ie`` IEs for association request ``ie_len`` Length of assoc_ie in octets ``privacy`` indicates whether privacy-enabled APs should be used ``mfp`` indicate whether management frame protection is used ``crypto`` crypto settings ``key`` WEP key for shared key authentication ``key_len`` length of WEP key for shared key authentication ``key_idx`` index of WEP key for shared key authentication ``flags`` See :c:type:`enum cfg80211_assoc_req_flags ` ``bg_scan_period`` Background scan period in seconds or -1 to indicate that default value is to be used. ``ht_capa`` HT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored. ``ht_capa_mask`` The bits of ht_capa which are to be used. ``vht_capa`` VHT Capability overrides ``vht_capa_mask`` The bits of vht_capa which are to be used. ``pbss`` if set, connect to a PCP instead of AP. Valid for DMG networks. ``bss_select`` criteria to be used for BSS selection. ``prev_bssid`` previous BSSID, if not ``NULL`` use reassociate frame. This is used to indicate a request to reassociate within the ESS instead of a request do the initial association with the ESS. When included, this is set to the BSSID of the current association, i.e., to the value that is included in the Current AP address field of the Reassociation Request frame. ``fils_erp_username`` EAP re-authentication protocol (ERP) username part of the NAI or ``NULL`` if not specified. This is used to construct FILS wrapped data IE. ``fils_erp_username_len`` Length of **fils_erp_username** in octets. ``fils_erp_realm`` EAP re-authentication protocol (ERP) realm part of NAI or ``NULL`` if not specified. This specifies the domain name of ER server and is used to construct FILS wrapped data IE. ``fils_erp_realm_len`` Length of **fils_erp_realm** in octets. ``fils_erp_next_seq_num`` The next sequence number to use in the FILS ERP messages. This is also used to construct FILS wrapped data IE. ``fils_erp_rrk`` ERP re-authentication Root Key (rRK) used to derive additional keys in FILS or ``NULL`` if not specified. ``fils_erp_rrk_len`` Length of **fils_erp_rrk** in octets. ``want_1x`` indicates user-space supports and wants to use 802.1X driver offload of 4-way handshake. ``edmg`` define the EDMG channels. This may specify multiple channels and bonding options for the driver to choose from, based on BSS configuration.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(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&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubh)}(h **Members**h]j)}(hjпh]hMembers}(hjҿhhhNhNubah}(h]h ]h"]h$]h&]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```channel`` The channel to use or ``NULL`` if not specified (auto-select based on scan results) h](j)}(h ``channel``h]j)}(hjh]hchannel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hSThe channel to use or ``NULL`` if not specified (auto-select based on scan results)h](hThe channel to use or }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh5 if not specified (auto-select based on scan results)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hh``channel_hint`` The channel of the recommended BSS for initial connection or ``NULL`` if not specified h](j)}(h``channel_hint``h]j)}(hj;h]h channel_hint}(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)}(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 }(hjThhhNhNubj)}(h``NULL``h]hNULL}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubh if not specified}(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 hjubj)}(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 hjubj)}(h``bssid_hint`` The recommended AP BSSID for initial connection to the BSS or ``NULL`` if not specified. Unlike the **bssid** parameter, the driver is allowed to ignore this **bssid_hint** if it has knowledge of a better BSS to use. h](j)}(h``bssid_hint``h]j)}(hjh]h bssid_hint}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.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 }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh if not specified. Unlike the }(hjhhhNhNubj)}(h **bssid**h]hbssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh1 parameter, the driver is allowed to ignore this }(hjhhhNhNubj)}(h**bssid_hint**h]h bssid_hint}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh, if it has knowledge of a better BSS to use.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h``ssid`` SSID h](j)}(h``ssid``h]j)}(hjCh]hssid}(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)}(hSSIDh]hSSID}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhM hjYubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhjXhM hjubj)}(h&``ssid_len`` Length of ssid in octets h](j)}(h ``ssid_len``h]j)}(hj|h]hssid_len}(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)}(hLength of ssid in octetsh]hLength of ssid in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjvubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(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 hjubj)}(h#``ie`` IEs for association request h](j)}(h``ie``h]j)}(hjh]hie}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hIEs for association requesth]hIEs for association request}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h(``ie_len`` Length of assoc_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&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj!ubj6)}(hhh]h)}(hLength of assoc_ie in octetsh]hLength of assoc_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 hjubj)}(hA``privacy`` indicates whether privacy-enabled APs should be used h](j)}(h ``privacy``h]j)}(hj`h]hprivacy}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjZubj6)}(hhh]h)}(h4indicates whether privacy-enabled APs should be usedh]h4indicates whether privacy-enabled APs should be used}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuhM hjvubah}(h]h ]h"]h$]h&]uh1j5hjZubeh}(h]h ]h"]h$]h&]uh1jhjuhM hjubj)}(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 hjubj)}(h``crypto`` crypto settings h](j)}(h ``crypto``h]j)}(hjh]hcrypto}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hcrypto settingsh]hcrypto settings}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h.``key`` WEP key for shared key authentication h](j)}(h``key``h]j)}(hj h]hkey}(hj 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%WEP key for shared key authenticationh]h%WEP key for shared key authentication}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM hj!ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hM hjubj)}(h<``key_len`` length of WEP key for shared key authentication h](j)}(h ``key_len``h]j)}(hjDh]hkey_len}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj>ubj6)}(hhh]h)}(h/length of WEP key for shared key authenticationh]h/length of WEP key for shared key authentication}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYhM hjZubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhjYhM hjubj)}(h;``key_idx`` index of WEP key for shared key authentication h](j)}(h ``key_idx``h]j)}(hj}h]hkey_idx}(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 hjwubj6)}(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&]uh1j5hjwubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hQ``flags`` See :c:type:`enum cfg80211_assoc_req_flags ` h](j)}(h ``flags``h]j)}(hjh]hflags}(hjhhhNhNubah}(h]h ]h"]h$]h&]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)}(hjh]henum cfg80211_assoc_req_flags}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6cfg80211_assoc_req_flagsuh1hhjhM hjubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hi``bg_scan_period`` Background scan period in seconds or -1 to indicate that default value is to be used. h](j)}(h``bg_scan_period``h]j)}(hjh]hbg_scan_period}(hjhhhNhNubah}(h]h ]h"]h$]h&]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)}(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.}(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)}(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)}(hjHh]hht_capa}(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.hhM hjBubj6)}(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.}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^ubah}(h]h ]h"]h$]h&]uh1j5hjBubeh}(h]h ]h"]h$]h&]uh1jhj]hM 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 hj|ubj6)}(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&]uh1j5hj|ubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h&``vht_capa`` VHT Capability overrides h](j)}(h ``vht_capa``h]j)}(hjh]hvht_capa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM 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 hjubj)}(h=``vht_capa_mask`` The bits of vht_capa which are to be used. h](j)}(h``vht_capa_mask``h]j)}(hjh]h vht_capa_mask}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h*The bits of vht_capa which are to be used.h]h*The bits of vht_capa which are to be used.}(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)}(hI``pbss`` if set, connect to a PCP instead of AP. Valid 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.hhM hj'ubj6)}(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.}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjCubah}(h]h ]h"]h$]h&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhjBhM hjubj)}(h6``bss_select`` criteria to be used for BSS selection. h](j)}(h``bss_select``h]j)}(hjgh]h bss_select}(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&criteria to be used for BSS selection.h]h&criteria to be used for BSS selection.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hM! hj}ubah}(h]h ]h"]h$]h&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hM! hjubj)}(hXq``prev_bssid`` previous BSSID, if not ``NULL`` use reassociate frame. This is used to indicate a request to reassociate within the ESS instead of a request do the initial association with the ESS. When included, this is set to the BSSID of the current association, i.e., to the value that is included in the Current AP address field of the Reassociation Request frame. h](j)}(h``prev_bssid``h]j)}(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' hjubj)}(h``fils_erp_username`` EAP re-authentication protocol (ERP) username part of the NAI or ``NULL`` if not specified. This is used to construct FILS wrapped data IE. h](j)}(h``fils_erp_username``h]j)}(hjh]hfils_erp_username}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM* hjubj6)}(hhh]h)}(hEAP re-authentication protocol (ERP) username part of the NAI or ``NULL`` if not specified. This is used to construct FILS wrapped data IE.h](hAEAP re-authentication protocol (ERP) username part of the NAI or }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhB if not specified. This is used to construct FILS wrapped data IE.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM( hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM* hjubj)}(hE``fils_erp_username_len`` Length of **fils_erp_username** in octets. h](j)}(h``fils_erp_username_len``h]j)}(hj8h]hfils_erp_username_len}(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.hhM+ hj2ubj6)}(hhh]h)}(h*Length of **fils_erp_username** in octets.h](h Length of }(hjQhhhNhNubj)}(h**fils_erp_username**h]hfils_erp_username}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQubh in octets.}(hjQhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjMhM+ hjNubah}(h]h ]h"]h$]h&]uh1j5hj2ubeh}(h]h ]h"]h$]h&]uh1jhjMhM+ hjubj)}(h``fils_erp_realm`` EAP re-authentication protocol (ERP) realm part of NAI or ``NULL`` if not specified. This specifies the domain name of ER server and is used to construct FILS wrapped data IE. h](j)}(h``fils_erp_realm``h]j)}(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. hj}ubj6)}(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&]uh1j5hj}ubeh}(h]h ]h"]h$]h&]uh1jhjhM. hjubj)}(h?``fils_erp_realm_len`` Length of **fils_erp_realm** in octets. h](j)}(h``fils_erp_realm_len``h]j)}(hjh]hfils_erp_realm_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM/ hjubj6)}(hhh]h)}(h'Length of **fils_erp_realm** in octets.h](h Length of }(hjhhhNhNubj)}(h**fils_erp_realm**h]hfils_erp_realm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh in octets.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM/ hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM/ hjubj)}(h``fils_erp_next_seq_num`` The next sequence number to use in the FILS ERP messages. This is also used to construct FILS wrapped data IE. h](j)}(h``fils_erp_next_seq_num``h]j)}(hjh]hfils_erp_next_seq_num}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM1 hjubj6)}(hhh]h)}(hnThe next sequence number to use in the FILS ERP messages. This is also used to construct FILS wrapped data IE.h]hnThe next sequence number to use in the FILS ERP messages. This is also used to construct FILS wrapped data IE.}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM0 hj0ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj/hM1 hjubj)}(h{``fils_erp_rrk`` ERP re-authentication Root Key (rRK) used to derive additional keys in FILS or ``NULL`` if not specified. h](j)}(h``fils_erp_rrk``h]j)}(hjTh]h fils_erp_rrk}(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.hhM3 hjNubj6)}(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 }(hjmhhhNhNubj)}(h``NULL``h]hNULL}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubh if not specified.}(hjmhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM2 hjjubah}(h]h ]h"]h$]h&]uh1j5hjNubeh}(h]h ]h"]h$]h&]uh1jhjihM3 hjubj)}(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.hhM4 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&]uh1hhjhM4 hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM4 hjubj)}(he``want_1x`` indicates user-space supports and wants to use 802.1X driver offload of 4-way handshake. h](j)}(h ``want_1x``h]j)}(hjh]hwant_1x}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM6 hjubj6)}(hhh]h)}(hXindicates user-space supports and wants to use 802.1X driver offload of 4-way handshake.h]hXindicates user-space supports and wants to use 802.1X driver offload of 4-way handshake.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM5 hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM6 hjubj)}(h``edmg`` define the EDMG channels. This may specify multiple channels and bonding options for the driver to choose from, based on BSS configuration.h](j)}(h``edmg``h]j)}(hj%h]hedmg}(hj'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.hhM8 hjubj6)}(hhh]h)}(hdefine the EDMG channels. This may specify multiple channels and bonding options for the driver to choose from, based on BSS configuration.h]hdefine the EDMG channels. This may specify multiple channels and bonding options for the driver to choose from, based on BSS configuration.}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM7 hj;ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj:hM8 hjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjhh]h Description}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM< hj$bhhubh)}(hbThis structure provides information needed to complete IEEE 802.11 authentication and association.h]hbThis structure provides information needed to complete IEEE 802.11 authentication and association.}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_pmksa (C struct)c.cfg80211_pmksahNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hcfg80211_pmksah]jo)}(hstruct cfg80211_pmksah](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(hcfg80211_pmksah]j)}(hjh]hcfg80211_pmksa}(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)}(hPMK Security Associationh]hPMK Security Association}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhj$bhNhNubj)}(hXz**Definition**:: struct cfg80211_pmksa { const u8 *bssid; const u8 *pmkid; const u8 *pmk; size_t pmk_len; const u8 *ssid; size_t ssid_len; const u8 *cache_id; u32 pmk_lifetime; u8 pmk_reauth_threshold; }; **Members** ``bssid`` The AP's BSSID (may be ``NULL``). ``pmkid`` The identifier to refer a PMKSA. ``pmk`` The PMK for the PMKSA identified by **pmkid**. This is used for key derivation by a FILS STA. Otherwise, ``NULL``. ``pmk_len`` Length of the **pmk**. The length of **pmk** can differ depending on the hash algorithm used to generate this. ``ssid`` SSID to specify the ESS within which a PMKSA is valid when using FILS cache identifier (may be ``NULL``). ``ssid_len`` Length of the **ssid** in octets. ``cache_id`` 2-octet cache identifier advertized by a FILS AP identifying the scope of PMKSA. This is valid only if **ssid_len** is non-zero (may be ``NULL``). ``pmk_lifetime`` Maximum lifetime for PMKSA in seconds (dot11RSNAConfigPMKLifetime) or 0 if not specified. The configured PMKSA must not be used for PMKSA caching after expiration and any keys derived from this PMK become invalid on expiration, i.e., the current association must be dropped if the PMK used for it expires. ``pmk_reauth_threshold`` Threshold time for reauthentication (percentage of PMK lifetime, dot11RSNAConfigPMKReauthThreshold) or 0 if not specified. Drivers are expected to trigger a full authentication instead of using this PMKSA for caching when reassociating to a new BSS after this threshold to generate a new PMK before the current one expires.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj( )}(hstruct cfg80211_pmksa { const u8 *bssid; const u8 *pmkid; const u8 *pmk; size_t pmk_len; const u8 *ssid; size_t ssid_len; const u8 *cache_id; u32 pmk_lifetime; u8 pmk_reauth_threshold; };h]hstruct cfg80211_pmksa { const u8 *bssid; const u8 *pmkid; const u8 *pmk; size_t pmk_len; const u8 *ssid; size_t ssid_len; const u8 *cache_id; u32 pmk_lifetime; u8 pmk_reauth_threshold; };}hj%sbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubh)}(h **Members**h]j)}(hj6h]hMembers}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj)}(hhh](j)}(h,``bssid`` The AP's BSSID (may be ``NULL``). h](j)}(h ``bssid``h]j)}(hjUh]hbssid}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjOubj6)}(hhh]h)}(h!The AP's BSSID (may be ``NULL``).h](hThe AP’s BSSID (may be }(hjnhhhNhNubj)}(h``NULL``h]hNULL}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubh).}(hjnhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjjhM hjkubah}(h]h ]h"]h$]h&]uh1j5hjOubeh}(h]h ]h"]h$]h&]uh1jhjjhM hjLubj)}(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 hjLubj)}(h{``pmk`` The PMK for the PMKSA identified by **pmkid**. This is used for key derivation by a FILS STA. Otherwise, ``NULL``. h](j)}(h``pmk``h]j)}(hjh]hpmk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hrThe PMK for the PMKSA identified by **pmkid**. This is used for key derivation by a FILS STA. Otherwise, ``NULL``.h](h$The PMK for the PMKSA identified by }(hjhhhNhNubj)}(h **pmkid**h]hpmkid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh<. This is used for key derivation by a FILS STA. Otherwise, }(hjhhhNhNubj)}(h``NULL``h]hNULL}(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 hjLubj)}(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)}(hj7h]hpmk_len}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj1ubj6)}(hhh]h)}(hnLength of the **pmk**. The length of **pmk** can differ depending on the hash algorithm used to generate this.h](hLength of the }(hjPhhhNhNubj)}(h**pmk**h]hpmk}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPubh. The length of }(hjPhhhNhNubj)}(h**pmk**h]hpmk}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPubhB can differ depending on the hash algorithm used to generate this.}(hjPhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjMubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhjLhM hjLubj)}(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 hjLubj)}(h/``ssid_len`` Length of the **ssid** in octets. h](j)}(h ``ssid_len``h]j)}(hjh]hssid_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(h!Length of the **ssid** in octets.h](hLength of the }(hjhhhNhNubj)}(h**ssid**h]hssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh in octets.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjLubj)}(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)}(hj,h]hcache_id}(hj.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)}(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 }(hjEhhhNhNubj)}(h **ssid_len**h]hssid_len}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjEubh is non-zero (may be }(hjEhhhNhNubj)}(h``NULL``h]hNULL}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubh).}(hjEhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjBubah}(h]h ]h"]h$]h&]uh1j5hj&ubeh}(h]h ]h"]h$]h&]uh1jhjAhM hjLubj)}(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.hhM hjubj6)}(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&]uh1jhjhM hjLubj)}(hX\``pmk_reauth_threshold`` Threshold time for reauthentication (percentage of PMK lifetime, dot11RSNAConfigPMKReauthThreshold) or 0 if not specified. Drivers are expected to trigger a full authentication instead of using this PMKSA for caching when reassociating to a new BSS after this threshold to generate a new PMK before the current one expires.h](j)}(h``pmk_reauth_threshold``h]j)}(hjh]hpmk_reauth_threshold}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hXCThreshold time for reauthentication (percentage of PMK lifetime, dot11RSNAConfigPMKReauthThreshold) or 0 if not specified. Drivers are expected to trigger a full authentication instead of using this PMKSA for caching when reassociating to a new BSS after this threshold to generate a new PMK before the current one expires.h]hXCThreshold time for reauthentication (percentage of PMK lifetime, dot11RSNAConfigPMKReauthThreshold) or 0 if not specified. Drivers are expected to trigger a full authentication instead of using this PMKSA for caching when reassociating to a new BSS after this threshold to generate a new PMK before the current one expires.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjLubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj$bhhubh)}(hIThis structure is passed to the set/del_pmksa() method for PMKSA caching.h]hIThis structure is passed to the set/del_pmksa() method for PMKSA caching.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_ops (C struct)c.cfg80211_opshNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(h cfg80211_opsh]jo)}(hstruct cfg80211_opsh](ju)}(hjh]hstruct}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjAhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjShhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAhhhjRhM ubj)}(h cfg80211_opsh]j)}(hj?h]h cfg80211_ops}(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubah}(h]h ](jjeh"]h$]h&]jjuh1jhjAhhhjRhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj=hhhjRhM ubah}(h]j8ah ](jjeh"]h$]h&]jj)jhuh1jhhjRhM hj:hhubj)}(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.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhj:hhhjRhM ubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhj$bhNhNubj)}(hXV**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, u32 changed); int (*set_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, enum nl80211_tx_power_setting type, int mbm); int (*get_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, 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, u32 tx_ant, u32 rx_ant); int (*get_antenna)(struct wiphy *wiphy, 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.hhMhjubj( )}(hX4struct 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, u32 changed); int (*set_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, enum nl80211_tx_power_setting type, int mbm); int (*get_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, 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, u32 tx_ant, u32 rx_ant); int (*get_antenna)(struct wiphy *wiphy, 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]hX4struct 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, u32 changed); int (*set_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, enum nl80211_tx_power_setting type, int mbm); int (*get_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, 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, u32 tx_ant, u32 rx_ant); int (*get_antenna)(struct wiphy *wiphy, u32 *tx_ant, u32 *rx_ant); int (*sched_scan_start)(struct wiphy *wiphy,struct net_device *dev, struct cfg80211_sched_scan_request *request); int (*sched_scan_stop)(struct wiphy *wiphy, struct net_device *dev, u64 reqid); int (*set_rekey_data)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_gtk_rekey_data *data); int (*tdls_mgmt)(struct wiphy *wiphy, struct net_device *dev,const u8 *peer, int link_id,u8 action_code, u8 dialog_token, u16 status_code,u32 peer_capability, bool initiator, const u8 *buf, size_t len); int (*tdls_oper)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, enum nl80211_tdls_operation oper); int (*probe_client)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, u64 *cookie); int (*set_noack_map)(struct wiphy *wiphy,struct net_device *dev, u16 noack_map); int (*get_channel)(struct wiphy *wiphy,struct wireless_dev *wdev,unsigned int link_id, struct cfg80211_chan_def *chandef); int (*start_p2p_device)(struct wiphy *wiphy, struct wireless_dev *wdev); void (*stop_p2p_device)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*set_mac_acl)(struct wiphy *wiphy, struct net_device *dev, const struct cfg80211_acl_data *params); int (*start_radar_detection)(struct wiphy *wiphy,struct net_device *dev,struct cfg80211_chan_def *chandef, u32 cac_time_ms, int link_id); void (*end_cac)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id); int (*update_ft_ies)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_update_ft_ies_params *ftie); int (*crit_proto_start)(struct wiphy *wiphy,struct wireless_dev *wdev,enum nl80211_crit_proto_id protocol, u16 duration); void (*crit_proto_stop)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*set_coalesce)(struct wiphy *wiphy, struct cfg80211_coalesce *coalesce); int (*channel_switch)(struct wiphy *wiphy,struct net_device *dev, struct cfg80211_csa_settings *params); int (*set_qos_map)(struct wiphy *wiphy,struct net_device *dev, struct cfg80211_qos_map *qos_map); int (*set_ap_chanwidth)(struct wiphy *wiphy, struct net_device *dev,unsigned int link_id, struct cfg80211_chan_def *chandef); int (*add_tx_ts)(struct wiphy *wiphy, struct net_device *dev,u8 tsid, const u8 *peer, u8 user_prio, u16 admitted_time); int (*del_tx_ts)(struct wiphy *wiphy, struct net_device *dev, u8 tsid, const u8 *peer); int (*tdls_channel_switch)(struct wiphy *wiphy,struct net_device *dev,const u8 *addr, u8 oper_class, struct cfg80211_chan_def *chandef); void (*tdls_cancel_channel_switch)(struct wiphy *wiphy,struct net_device *dev, const u8 *addr); int (*start_nan)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_conf *conf); void (*stop_nan)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*add_nan_func)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_func *nan_func); void (*del_nan_func)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*nan_change_conf)(struct wiphy *wiphy,struct wireless_dev *wdev,struct cfg80211_nan_conf *conf, u32 changes); int (*set_multicast_to_unicast)(struct wiphy *wiphy,struct net_device *dev, const bool enabled); int (*get_txq_stats)(struct wiphy *wiphy,struct wireless_dev *wdev, struct cfg80211_txq_stats *txqstats); int (*set_pmk)(struct wiphy *wiphy, struct net_device *dev, const struct cfg80211_pmk_conf *conf); int (*del_pmk)(struct wiphy *wiphy, struct net_device *dev, const u8 *aa); int (*external_auth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_external_auth_params *params); int (*tx_control_port)(struct wiphy *wiphy,struct net_device *dev,const u8 *buf, size_t len,const u8 *dest, const __be16 proto,const bool noencrypt, int link_id, u64 *cookie); int (*get_ftm_responder_stats)(struct wiphy *wiphy,struct net_device *dev, struct cfg80211_ftm_responder_stats *ftm_stats); int (*start_pmsr)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_pmsr_request *request); void (*abort_pmsr)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_pmsr_request *request); int (*update_owe_info)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_update_owe_info *owe_info); int (*probe_mesh_link)(struct wiphy *wiphy, struct net_device *dev, const u8 *buf, size_t len); int (*set_tid_config)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_tid_config *tid_conf); int (*reset_tid_config)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, u8 tids); int (*set_sar_specs)(struct wiphy *wiphy, struct cfg80211_sar_specs *sar); int (*color_change)(struct wiphy *wiphy,struct net_device *dev, struct cfg80211_color_change_settings *params); int (*set_fils_aad)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_fils_aad *fils_aad); int (*set_radar_background)(struct wiphy *wiphy, struct cfg80211_chan_def *chandef); int (*add_link_station)(struct wiphy *wiphy, struct net_device *dev, struct link_station_parameters *params); int (*mod_link_station)(struct wiphy *wiphy, struct net_device *dev, struct link_station_parameters *params); int (*del_link_station)(struct wiphy *wiphy, struct net_device *dev, struct link_station_del_parameters *params); int (*set_hw_timestamp)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_set_hw_timestamp *hwts); int (*set_ttlm)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ttlm_params *params); u32 (*get_radio_mask)(struct wiphy *wiphy, struct net_device *dev); int (*assoc_ml_reconf)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ml_reconf_req *req); int (*set_epcs)(struct wiphy *wiphy, struct net_device *dev, bool val); };}hjsbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh)}(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)}(hjh]hsuspend}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hwiphy device needs to be suspended. The variable **wow** will be ``NULL`` or contain the enabled Wake-on-Wireless triggers that are configured for the device.h](h1wiphy device needs to be suspended. The variable }(hj hhhNhNubj)}(h**wow**h]hwow}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubh will be }(hj hhhNhNubj)}(h``NULL``h]hNULL}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubhU or contain the enabled Wake-on-Wireless triggers that are configured for the device.}(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 hMhjubj)}(h,``resume`` wiphy device needs to be resumed h](j)}(h ``resume``h]j)}(hjRh]hresume}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjLubj6)}(hhh]h)}(h wiphy device needs to be resumedh]h wiphy device needs to be resumed}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjghMhjhubah}(h]h ]h"]h$]h&]uh1j5hjLubeh}(h]h ]h"]h$]h&]uh1jhjghMhjubj)}(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.hhMhjubj6)}(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.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX~``add_virtual_intf`` create a new virtual interface with the given name, must set the struct wireless_dev's iftype. Beware: You must create the new netdev in the wiphy's network namespace! Returns the struct wireless_dev, or an ERR_PTR. For P2P device wdevs, the driver must also set the address member in the wdev. This additionally holds the RTNL to be able to do netdev changes. h](j)}(h``add_virtual_intf``h]j)}(hjh]hadd_virtual_intf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hXhcreate a new virtual interface with the given name, must set the struct wireless_dev's iftype. Beware: You must create the new netdev in the wiphy's network namespace! Returns the struct wireless_dev, or an ERR_PTR. For P2P device wdevs, the driver must also set the address member in the wdev. This additionally holds the RTNL to be able to do netdev changes.h]hXlcreate a new virtual interface with the given name, must set the struct wireless_dev’s iftype. Beware: You must create the new netdev in the wiphy’s network namespace! Returns the struct wireless_dev, or an ERR_PTR. For P2P device wdevs, the driver must also set the address member in the wdev. This additionally holds the RTNL to be able to do netdev changes.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(ht``del_virtual_intf`` remove the virtual interface This additionally holds the RTNL to be able to do netdev changes. h](j)}(h``del_virtual_intf``h]j)}(hjh]hdel_virtual_intf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h^remove the virtual interface This additionally holds the RTNL to be able to do netdev changes.h]h^remove the virtual interface This additionally holds the RTNL to be able to do netdev changes.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``change_virtual_intf`` change type/configuration of virtual interface, keep the struct wireless_dev's iftype updated. This additionally holds the RTNL to be able to do netdev changes. h](j)}(h``change_virtual_intf``h]j)}(hj9h]hchange_virtual_intf}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj3ubj6)}(hhh]h)}(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.}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjOubah}(h]h ]h"]h$]h&]uh1j5hj3ubeh}(h]h ]h"]h$]h&]uh1jhjNhMhjubj)}(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)}(hjsh]h add_intf_link}(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)}(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.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjmubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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.hhMhjubj6)}(hhh]h)}(h,Remove an MLO link from the given interface.h]h,Remove an MLO link from the given interface.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX)``add_key`` add a key with the given parameters. **mac_addr** will be ``NULL`` when adding a group key. **link_id** will be -1 for non-MLO connection. For MLO connection, **link_id** will be >= 0 for group key and -1 for pairwise key, **mac_addr** will be peer's MLD address for MLO pairwise key. h](j)}(h ``add_key``h]j)}(hjh]hadd_key}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hXadd a key with the given parameters. **mac_addr** will be ``NULL`` when adding a group key. **link_id** will be -1 for non-MLO connection. For MLO connection, **link_id** will be >= 0 for group key and -1 for pairwise key, **mac_addr** will be peer's MLD address for MLO pairwise key.h](h%add a key with the given parameters. }(hjhhhNhNubj)}(h **mac_addr**h]hmac_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh will be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh when adding a group key. }(hjhhhNhNubj)}(h **link_id**h]hlink_id}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh8 will be -1 for non-MLO connection. For MLO connection, }(hjhhhNhNubj)}(h **link_id**h]hlink_id}(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}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh3 will be peer’s MLD address for MLO pairwise key.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX``get_key`` get information about the key with the given parameters. **mac_addr** will be ``NULL`` when requesting information for a group key. All pointers given to the **callback** function need not be valid after it returns. This function should return an error if it is not possible to retrieve the key, -ENOENT if it doesn't exist. **link_id** will be -1 for non-MLO connection. For MLO connection, **link_id** will be >= 0 for group key and -1 for pairwise key, **mac_addr** will be peer's MLD address for MLO pairwise key. h](j)}(h ``get_key``h]j)}(hjzh]hget_key}(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)}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh5 will be >= 0 for group key and -1 for pairwise key, }(hjhhhNhNubj)}(h **mac_addr**h]hmac_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh3 will be peer’s MLD address for MLO pairwise key.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjtubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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)}(hj h]hdel_key}(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)}(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 }(hj9hhhNhNubj)}(h **mac_addr**h]hmac_addr}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9ubh (}(hj9hhhNhNubj)}(h``NULL``h]hNULL}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubh for a group key) and }(hj9hhhNhNubj)}(h **key_index**h]h key_index}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9ubh-, return -ENOENT if the key doesn’t exist. }(hj9hhhNhNubj)}(h **link_id**h]hlink_id}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9ubh8 will be -1 for non-MLO connection. For MLO connection, }(hj9hhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9ubh5 will be >= 0 for group key and -1 for pairwise key, }(hj9hhhNhNubj)}(h **mac_addr**h]hmac_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9ubh3 will be peer’s MLD address for MLO pairwise key.}(hj9hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj6ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj5hMhjubj)}(h``set_default_key`` set the default key on an interface. **link_id** will be >= 0 for MLO connection and -1 for non-MLO connection. h](j)}(h``set_default_key``h]j)}(hjh]hset_default_key}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.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. }(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&]uh1jhjhMhjubj)}(h``set_default_mgmt_key`` set the default management frame key on an interface. **link_id** will be >= 0 for MLO connection and -1 for non-MLO connection. h](j)}(h``set_default_mgmt_key``h]j)}(hjh]hset_default_mgmt_key}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj ubj6)}(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. }(hj+hhhNhNubj)}(h **link_id**h]hlink_id}(hj3hhhNhNubah}(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&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj'hMhjubj)}(h``set_default_beacon_key`` set the default Beacon frame key on an interface. **link_id** will be >= 0 for MLO connection and -1 for non-MLO connection. h](j)}(h``set_default_beacon_key``h]j)}(hj^h]hset_default_beacon_key}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjXubj6)}(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. }(hjwhhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwubh? will be >= 0 for MLO connection and -1 for non-MLO connection.}(hjwhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjtubah}(h]h ]h"]h$]h&]uh1j5hjXubeh}(h]h ]h"]h$]h&]uh1jhjshMhjubj)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``change_beacon`` Change the beacon parameters for an access point mode interface. This should reject the call when AP mode wasn't started. h](j)}(h``change_beacon``h]j)}(hjh]h change_beacon}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hyChange the beacon parameters for an access point mode interface. This should reject the call when AP mode wasn't started.h]h{Change the beacon parameters for an access point mode interface. This should reject the call when AP mode wasn’t started.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h<``stop_ap`` Stop being an AP, including stopping beaconing. h](j)}(h ``stop_ap``h]j)}(hjh]hstop_ap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h/Stop being an AP, including stopping beaconing.h]h/Stop being an AP, including stopping beaconing.}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2hMhj3ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj2hMhjubj)}(h#``add_station`` Add a new station. h](j)}(h``add_station``h]j)}(hjVh]h add_station}(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)}(hAdd a new station.h]hAdd a new station.}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkhMhjlubah}(h]h ]h"]h$]h&]uh1j5hjPubeh}(h]h ]h"]h$]h&]uh1jhjkhMhjubj)}(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&]uh1jhjhMhjubj)}(hXR``change_station`` Modify a given station. Note that flags changes are not much validated in cfg80211, in particular the auth/assoc/authorized flags might come to the driver in invalid combinations -- make sure to check them, also against the existing state! Drivers must call cfg80211_check_station_change() to validate the information. h](j)}(h``change_station``h]j)}(hjh]hchange_station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hX>Modify a given station. Note that flags changes are not much validated in cfg80211, in particular the auth/assoc/authorized flags might come to the driver in invalid combinations -- make sure to check them, also against the existing state! Drivers must call cfg80211_check_station_change() to validate the information.h]hX>Modify a given station. Note that flags changes are not much validated in cfg80211, in particular the auth/assoc/authorized flags might come to the driver in invalid combinations -- make sure to check them, also against the existing state! Drivers must call cfg80211_check_station_change() to validate the information.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hN``get_station`` get station information for the station identified by **mac** h](j)}(h``get_station``h]j)}(hjh]h get_station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h=get station information for the station identified by **mac**h](h6get station information for the station identified by }(hjhhhNhNubj)}(h**mac**h]hmac}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hG``dump_station`` dump station callback -- resume dump at index **idx** h](j)}(h``dump_station``h]j)}(hjIh]h dump_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)}(h5dump station callback -- resume dump at index **idx**h](h.dump station callback -- resume dump at index }(hjbhhhNhNubj)}(h**idx**h]hidx}(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^hMhjubj)}(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&]uh1jhjhMhjubj)}(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.hhMhjubj6)}(hhh]h)}(hdelete a given mesh pathh]hdelete a given mesh path}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h*``change_mpath`` change a given mesh path h](j)}(h``change_mpath``h]j)}(hjh]h change_mpath}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hchange a given mesh pathh]hchange a given mesh path}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h7``get_mpath`` get a mesh path for the given parameters h](j)}(h ``get_mpath``h]j)}(hj;h]h get_mpath}(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(get a mesh path for the given parametersh]h(get a mesh path for the given parameters}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPhMhjQubah}(h]h ]h"]h$]h&]uh1j5hj5ubeh}(h]h ]h"]h$]h&]uh1jhjPhMhjubj)}(hG``dump_mpath`` dump mesh path callback -- resume dump at index **idx** h](j)}(h``dump_mpath``h]j)}(hjth]h dump_mpath}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjnubj6)}(hhh]h)}(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&]uh1j5hjnubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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&]uh1jhjhMhjubj)}(hK``dump_mpp`` dump mesh proxy path callback -- resume dump at index **idx** h](j)}(h ``dump_mpp``h]j)}(hjh]hdump_mpp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h=dump mesh proxy path callback -- resume dump at index **idx**h](h6dump mesh proxy path callback -- resume dump at index }(hj hhhNhNubj)}(h**idx**h]hidx}(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 hMhjubj)}(h7``get_mesh_config`` Get the current mesh configuration h](j)}(h``get_mesh_config``h]j)}(hj;h]hget_mesh_config}(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"Get the current mesh configurationh]h"Get the current mesh configuration}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPhMhjQubah}(h]h ]h"]h$]h&]uh1j5hj5ubeh}(h]h ]h"]h$]h&]uh1jhjPhMhjubj)}(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)}(hjth]hupdate_mesh_config}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjnubj6)}(hhh]h)}(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&]uh1j5hjnubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hY``leave_mesh`` leave the current mesh network (invoked with the wireless_dev mutex held) h](j)}(h``leave_mesh``h]j)}(hjh]h leave_mesh}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hIleave the current mesh network (invoked with the wireless_dev mutex held)h]hIleave the current mesh network (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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)}(hj"h]hjoin_ocb}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(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)}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj8ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj7hMhjubj)}(hW``leave_ocb`` leave the current OCB network (invoked with the wireless_dev mutex held) h](j)}(h ``leave_ocb``h]j)}(hj\h]h leave_ocb}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjVubj6)}(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)}(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&]uh1j5hjVubeh}(h]h ]h"]h$]h&]uh1jhjqhMhjubj)}(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&]uh1jhjhMhjubj)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h+``set_txq_params`` Set TX queue parameters h](j)}(h``set_txq_params``h]j)}(hj h]hset_txq_params}(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 TX queue parametersh]hSet TX queue parameters}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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)}(hjBh]hlibertas_set_mesh_channel}(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)}(hOnly for backward compatibility for libertas, as it doesn't implement join_mesh and needs to set the channel to join the mesh instead.h]hOnly for backward compatibility for libertas, as it doesn’t implement join_mesh and needs to set the channel to join the mesh instead.}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjXubah}(h]h ]h"]h$]h&]uh1j5hj<ubeh}(h]h ]h"]h$]h&]uh1jhjWhMhjubj)}(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)}(hj|h]hset_monitor_channel}(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)}(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&]uh1j5hjvubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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&]uh1jhjhMhjubj)}(h``abort_scan`` Tell the driver to abort an ongoing scan. The driver shall indicate the status of the scan through cfg80211_scan_done(). h](j)}(h``abort_scan``h]j)}(hjh]h abort_scan}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(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().}(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&]uh1jhjhMhjubj)}(hd``auth`` Request to authenticate with the specified peer (invoked with the wireless_dev mutex held) h](j)}(h``auth``h]j)}(hj*h]hauth}(hj,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)}(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)}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj@ubah}(h]h ]h"]h$]h&]uh1j5hj$ubeh}(h]h ]h"]h$]h&]uh1jhj?hM hjubj)}(hf``assoc`` Request to (re)associate with the specified peer (invoked with the wireless_dev mutex held) h](j)}(h ``assoc``h]j)}(hjdh]hassoc}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj^ubj6)}(hhh]h)}(h[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)}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjzubah}(h]h ]h"]h$]h&]uh1j5hj^ubeh}(h]h ]h"]h$]h&]uh1jhjyhM hjubj)}(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.hhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hh``disassoc`` Request to disassociate from the specified peer (invoked with the wireless_dev mutex held) h](j)}(h ``disassoc``h]j)}(hjh]hdisassoc}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.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)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hXt``connect`` Connect to the ESS with the specified parameters. When connected, call cfg80211_connect_result()/cfg80211_connect_bss() with status code ``WLAN_STATUS_SUCCESS``. If the connection fails for some reason, call cfg80211_connect_result()/cfg80211_connect_bss() with the status code from the AP or cfg80211_connect_timeout() if no frame with status code was received. The driver is allowed to roam to other BSSes within the ESS when the other BSS matches the connect parameters. When such roaming is initiated by the driver, the driver is expected to verify that the target matches the configured security parameters and to use Reassociation Request frame instead of Association Request frame. The connect function can also be used to request the driver to perform a specific roam when connected to an ESS. In that case, the prev_bssid parameter is set to the BSSID of the currently associated BSS as an indication of requesting reassociation. In both the driver-initiated and new connect() call initiated roaming cases, the result of roaming is indicated with a call to cfg80211_roamed(). (invoked with the wireless_dev mutex held) h](j)}(h ``connect``h]j)}(hjh]hconnect}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hj ubj6)}(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 }(hj+hhhNhNubj)}(h``WLAN_STATUS_SUCCESS``h]hWLAN_STATUS_SUCCESS}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubhX. 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)}(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&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj'hM#hjubj)}(hX+``update_connect_params`` Update the connect parameters while connected to a BSS. The updated parameters can be used by driver/firmware for subsequent BSS selection (roaming) decisions and to form the Authentication/(Re)Association Request frames. This call does not request an immediate disassociation or reassociation with the current BSS, i.e., this impacts only subsequent (re)associations. The bits in changed are defined in :c:type:`enum cfg80211_connect_params_changed `. (invoked with the wireless_dev mutex held) h](j)}(h``update_connect_params``h]j)}(hj^h]hupdate_connect_params}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM+hjXubj6)}(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 }(hjwhhhNhNubh)}(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 refexplicitrefwarnj j j6cfg80211_connect_params_changeduh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hjwubh,. (invoked with the wireless_dev mutex held)}(hjwhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM$hjtubah}(h]h ]h"]h$]h&]uh1j5hjXubeh}(h]h ]h"]h$]h&]uh1jhjshM+hjubj)}(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.hhM/hjubj6)}(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.hhM,hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM/hjubj)}(h``join_ibss`` Join the specified IBSS (or create if necessary). Once done, call cfg80211_ibss_joined(), also call that function when changing BSSID due to a merge. (invoked with the wireless_dev mutex held) h](j)}(h ``join_ibss``h]j)}(hjh]h join_ibss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM4hjubj6)}(hhh]h)}(hJoin the specified IBSS (or create if necessary). Once done, call cfg80211_ibss_joined(), also call that function when changing BSSID due to a merge. (invoked with the wireless_dev mutex held)h]hJoin the specified IBSS (or create if necessary). Once done, call cfg80211_ibss_joined(), also call that function when changing BSSID due to a merge. (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM1hj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hM4hjubj)}(hJ``leave_ibss`` Leave the IBSS. (invoked with the wireless_dev mutex held) h](j)}(h``leave_ibss``h]j)}(hj/h]h leave_ibss}(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.hhM6hj)ubj6)}(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)}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM5hjEubah}(h]h ]h"]h$]h&]uh1j5hj)ubeh}(h]h ]h"]h$]h&]uh1jhjDhM6hjubj)}(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)}(hjih]hset_mcast_rate}(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.hhM9hjcubj6)}(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.hhM8hjubah}(h]h ]h"]h$]h&]uh1j5hjcubeh}(h]h ]h"]h$]h&]uh1jhj~hM9hjubj)}(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.hhM>hjubj6)}(hhh]h)}(hXNotify that wiphy parameters have changed; **changed** bitfield (see :c:type:`enum wiphy_params_flags `) describes which values have changed. The actual parameter values are available in struct wiphy. If returning an error, no value should be changed.h](h+Notify that wiphy parameters have changed; }(hjhhhNhNubj)}(h **changed**h]hchanged}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh bitfield (see }(hjhhhNhNubh)}(h6:c:type:`enum wiphy_params_flags `h]j)}(hjh]henum wiphy_params_flags}(hjhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6wiphy_params_flagsuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM;hjubh) 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&]uh1hhjhM;hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM>hjubj)}(hX,``set_tx_power`` set the transmit power according to the parameters, the power passed is in mBm, to get dBm use MBM_TO_DBM(). The wdev may be ``NULL`` if power was set for the wiphy, and will always be ``NULL`` unless the driver supports per-vif TX power (as advertised by the nl80211 feature flag.) h](j)}(h``set_tx_power``h]j)}(hjh]h set_tx_power}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMDhj ubj6)}(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 }(hj+hhhNhNubj)}(h``NULL``h]hNULL}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubh4 if power was set for the wiphy, and will always be }(hj+hhhNhNubj)}(h``NULL``h]hNULL}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubhY unless the driver supports per-vif TX power (as advertised by the nl80211 feature flag.)}(hj+hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM@hj(ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj'hMDhjubj)}(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)}(hjph]h get_tx_power}(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.hhMFhjjubj6)}(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.hhMEhjubah}(h]h ]h"]h$]h&]uh1j5hjjubeh}(h]h ]h"]h$]h&]uh1jhjhMFhjubj)}(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.hhMIhjubj6)}(hhh]h)}(hTpolls the hw rfkill line, use cfg80211 reporting functions to adjust rfkill hw stateh]hTpolls the hw rfkill line, use cfg80211 reporting functions to adjust rfkill hw state}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMHhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMIhjubj)}(hC``testmode_cmd`` run a test mode command; **wdev** may be ``NULL`` h](j)}(h``testmode_cmd``h]j)}(hjh]h testmode_cmd}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMYhjubj6)}(hhh]h)}(h1run a test mode command; **wdev** may be ``NULL``h](hrun a test mode command; }(hjhhhNhNubj)}(h**wdev**h]hwdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh may be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1hhjhMYhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMYhjubj)}(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)}(hj=h]h testmode_dump}(hj?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_hj7ubj6)}(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 }(hjVhhhNhNubj)}(h``NL80211_ATTR_TESTDATA``h]hNL80211_ATTR_TESTDATA}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubh.}(hjVhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMZhjSubah}(h]h ]h"]h$]h&]uh1j5hj7ubeh}(h]h ]h"]h$]h&]uh1jhjRhM_hjubj)}(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.hhMahjubj6)}(hhh]h)}(h"set the bitrate mask configurationh]h"set the bitrate mask configuration}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMahjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMahjubj)}(h-``dump_survey`` get site survey information. h](j)}(h``dump_survey``h]j)}(hjh]h dump_survey}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMKhjubj6)}(hhh]h)}(hget site survey information.h]hget site survey information.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMKhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMKhjubj)}(h``set_pmksa`` Cache a PMKID for a BSSID. This is mostly useful for fullmac devices running firmwares capable of generating the (re) association RSN IE. It allows for faster roaming between WPA2 BSSIDs. h](j)}(h ``set_pmksa``h]j)}(hjh]h set_pmksa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMehjubj6)}(hhh]h)}(hCache a PMKID for a BSSID. This is mostly useful for fullmac devices running firmwares capable of generating the (re) association RSN IE. It allows for faster roaming between WPA2 BSSIDs.h]hCache a PMKID for a BSSID. This is mostly useful for fullmac devices running firmwares capable of generating the (re) association RSN IE. It allows for faster roaming between WPA2 BSSIDs.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMchjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMehjubj)}(h%``del_pmksa`` Delete a cached PMKID. h](j)}(h ``del_pmksa``h]j)}(hj5h]h del_pmksa}(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.hhMfhj/ubj6)}(hhh]h)}(hDelete a cached PMKID.h]hDelete a cached PMKID.}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJhMfhjKubah}(h]h ]h"]h$]h&]uh1j5hj/ubeh}(h]h ]h"]h$]h&]uh1jhjJhMfhjubj)}(h)``flush_pmksa`` Flush all cached PMKIDs. h](j)}(h``flush_pmksa``h]j)}(hjnh]h flush_pmksa}(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.hhMghjhubj6)}(hhh]h)}(hFlush all cached PMKIDs.h]hFlush all cached PMKIDs.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMghjubah}(h]h ]h"]h$]h&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhMghjubj)}(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.hhMQhjubj6)}(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.hhMMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMQhjubj)}(h``cancel_remain_on_channel`` Cancel an on-going remain-on-channel operation. This allows the operation to be terminated prior to timeout based on the duration value. h](j)}(h``cancel_remain_on_channel``h]j)}(hjh]hcancel_remain_on_channel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMThjubj6)}(hhh]h)}(hCancel an on-going remain-on-channel operation. This allows the operation to be terminated prior to timeout based on the duration value.h]hCancel an on-going remain-on-channel operation. This allows the operation to be terminated prior to timeout based on the duration value.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMRhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMThjubj)}(h)``mgmt_tx`` Transmit a management frame. h](j)}(h ``mgmt_tx``h]j)}(hjh]hmgmt_tx}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMUhjubj6)}(hhh]h)}(hTransmit a management frame.h]hTransmit a management frame.}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0hMUhj1ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj0hMUhjubj)}(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)}(hjTh]hmgmt_tx_cancel_wait}(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.hhMWhjNubj6)}(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}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMVhjjubah}(h]h ]h"]h$]h&]uh1j5hjNubeh}(h]h ]h"]h$]h&]uh1jhjihMWhjubj)}(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.hhMihjubj6)}(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.hhMhhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMihjubj)}(hX)``set_cqm_rssi_config`` Configure connection quality monitor RSSI threshold. After configuration, the driver should (soon) send an event indicating the current level is above/below the configured threshold; this may need some care when the configuration is changed (without first being disabled.) h](j)}(h``set_cqm_rssi_config``h]j)}(hjh]hset_cqm_rssi_config}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMnhjubj6)}(hhh]h)}(hXConfigure connection quality monitor RSSI threshold. After configuration, the driver should (soon) send an event indicating the current level is above/below the configured threshold; this may need some care when the configuration is changed (without first being disabled.)h]hXConfigure connection quality monitor RSSI threshold. After configuration, the driver should (soon) send an event indicating the current level is above/below the configured threshold; this may need some care when the configuration is changed (without first being disabled.)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMjhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMnhjubj)}(hX```set_cqm_rssi_range_config`` Configure two RSSI thresholds in the connection quality monitor. An event is to be sent only when the signal level is found to be outside the two values. The driver should set ``NL80211_EXT_FEATURE_CQM_RSSI_LIST`` if this method is implemented. If it is provided then there's no point providing **set_cqm_rssi_config**. h](j)}(h``set_cqm_rssi_range_config``h]j)}(hjh]hset_cqm_rssi_range_config}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMshjubj6)}(hhh]h)}(hXAConfigure two RSSI thresholds in the connection quality monitor. An event is to be sent only when the signal level is found to be outside the two values. The driver should set ``NL80211_EXT_FEATURE_CQM_RSSI_LIST`` if this method is implemented. If it is provided then there's no point providing **set_cqm_rssi_config**.h](hConfigure two RSSI thresholds in the connection quality monitor. An event is to be sent only when the signal level is found to be outside the two values. The driver should set }(hjhhhNhNubj)}(h%``NL80211_EXT_FEATURE_CQM_RSSI_LIST``h]h!NL80211_EXT_FEATURE_CQM_RSSI_LIST}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhT if this method is implemented. If it is provided then there’s no point providing }(hjhhhNhNubj)}(h**set_cqm_rssi_config**h]hset_cqm_rssi_config}(hj5hhhNhNubah}(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.hhMohjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMshjubj)}(hQ``set_cqm_txe_config`` Configure connection quality monitor TX error thresholds. h](j)}(h``set_cqm_txe_config``h]j)}(hj`h]hset_cqm_txe_config}(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.hhMuhjZubj6)}(hhh]h)}(h9Configure connection quality monitor TX error thresholds.h]h9Configure connection quality monitor TX error thresholds.}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMthjvubah}(h]h ]h"]h$]h&]uh1j5hjZubeh}(h]h ]h"]h$]h&]uh1jhjuhMuhjubj)}(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.hhMhjubj6)}(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.hhM~hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX``set_antenna`` Set antenna configuration (tx_ant, rx_ant) on the device. Parameters are bitmaps of allowed antennas to use for TX/RX. Drivers may reject TX/RX mask combinations they cannot support by returning -EINVAL (also see nl80211.h **NL80211_ATTR_WIPHY_ANTENNA_TX**). h](j)}(h``set_antenna``h]j)}(hjh]h set_antenna}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hXSet antenna configuration (tx_ant, rx_ant) on the device. Parameters are bitmaps of allowed antennas to use for TX/RX. Drivers may reject TX/RX mask combinations they cannot support by returning -EINVAL (also see nl80211.h **NL80211_ATTR_WIPHY_ANTENNA_TX**).h](hSet antenna configuration (tx_ant, rx_ant) on the device. Parameters are bitmaps of allowed antennas to use for TX/RX. Drivers may reject TX/RX mask combinations they cannot support by returning -EINVAL (also see nl80211.h }(hjhhhNhNubj)}(h!**NL80211_ATTR_WIPHY_ANTENNA_TX**h]hNL80211_ATTR_WIPHY_ANTENNA_TX}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh).}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hP``get_antenna`` Get current antenna configuration from device (tx_ant, rx_ant). h](j)}(h``get_antenna``h]j)}(hj h]h get_antenna}(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?Get current antenna configuration from device (tx_ant, rx_ant).h]h?Get current antenna configuration from device (tx_ant, rx_ant).}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5hMhj6ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj5hMhjubj)}(h@``sched_scan_start`` Tell the driver to start a scheduled scan. h](j)}(h``sched_scan_start``h]j)}(hjYh]hsched_scan_start}(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.hhMvhjSubj6)}(hhh]h)}(h*Tell the driver to start a scheduled scan.h]h*Tell the driver to start a scheduled scan.}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhMvhjoubah}(h]h ]h"]h$]h&]uh1j5hjSubeh}(h]h ]h"]h$]h&]uh1jhjnhMvhjubj)}(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.hhM|hjubj6)}(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.hhMwhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM|hjubj)}(hJ``set_rekey_data`` give the data necessary for GTK rekeying to the driver h](j)}(h``set_rekey_data``h]j)}(hjh]hset_rekey_data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h6give the data necessary for GTK rekeying to the driverh]h6give the data necessary for GTK rekeying to the driver}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h0``tdls_mgmt`` Transmit a TDLS management frame. h](j)}(h ``tdls_mgmt``h]j)}(hjh]h tdls_mgmt}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h!Transmit a TDLS management frame.h]h!Transmit a TDLS management frame.}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,hMhj-ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj,hMhjubj)}(hJ``tdls_oper`` Perform a high-level TDLS operation (e.g. TDLS link setup). h](j)}(h ``tdls_oper``h]j)}(hjPh]h tdls_oper}(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;Perform a high-level TDLS operation (e.g. TDLS link setup).h]h;Perform a high-level TDLS operation (e.g. TDLS link setup).}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehMhjfubah}(h]h ]h"]h$]h&]uh1j5hjJubeh}(h]h ]h"]h$]h&]uh1jhjehMhjubj)}(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.hhMhjubj6)}(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.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h2``set_noack_map`` Set the NoAck Map for the TIDs. h](j)}(h``set_noack_map``h]j)}(hjh]h set_noack_map}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hSet the NoAck Map for the TIDs.h]hSet the NoAck Map for the TIDs.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``get_channel`` Get the current operating channel for the virtual interface. For monitor interfaces, it should return ``NULL`` unless there's a single current monitoring channel. h](j)}(h``get_channel``h]j)}(hjh]h get_channel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hGet the current operating channel for the virtual interface. For monitor interfaces, it should return ``NULL`` unless there's a single current monitoring channel.h](hfGet the current operating channel for the virtual interface. For monitor interfaces, it should return }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh6 unless there’s a single current monitoring channel.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h1``start_p2p_device`` Start the given P2P device. h](j)}(h``start_p2p_device``h]j)}(hjHh]hstart_p2p_device}(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)}(hStart the given P2P device.h]hStart the given P2P device.}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]hMhj^ubah}(h]h ]h"]h$]h&]uh1j5hjBubeh}(h]h ]h"]h$]h&]uh1jhj]hMhjubj)}(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.hhMhj{ubj6)}(hhh]h)}(hStop the given P2P device.h]hStop the given P2P device.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hj{ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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.hhMhjubj6)}(hhh]h)}(hXSets MAC address control list in AP and P2P GO mode. Parameters include ACL policy, an array of MAC address of stations and the number of MAC addresses. If there is already a list in driver this new list replaces the existing one. Driver has to clear its ACL when number of MAC addresses entries is passed as 0. Drivers which advertise the support for MAC based ACL have to implement this callback.h]hXSets MAC address control list in AP and P2P GO mode. Parameters include ACL policy, an array of MAC address of stations and the number of MAC addresses. If there is already a list in driver this new list replaces the existing one. Driver has to clear its ACL when number of MAC addresses entries is passed as 0. Drivers which advertise the support for MAC based ACL have to implement this callback.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h?``start_radar_detection`` Start radar detection in the driver. h](j)}(h``start_radar_detection``h]j)}(hjh]hstart_radar_detection}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h$Start radar detection in the driver.h]h$Start radar detection in the driver.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubj)}(hY``end_cac`` End running CAC, probably because a related CAC was finished on another phy. h](j)}(h ``end_cac``h]j)}(hj-h]hend_cac}(hj/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)}(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.}(hjFhhhNhNubah}(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&]uh1j5hj'ubeh}(h]h ]h"]h$]h&]uh1jhjBhMhjubj)}(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)}(hjgh]h update_ft_ies}(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)}(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.hhMhj}ubah}(h]h ]h"]h$]h&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hMhjubj)}(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.hhMhjubj6)}(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.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hy``crit_proto_stop`` Indicates critical protocol no longer needs increased link reliability. This operation can not fail. h](j)}(h``crit_proto_stop``h]j)}(hjh]hcrit_proto_stop}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hdIndicates critical protocol no longer needs increased link reliability. This operation can not fail.h]hdIndicates critical protocol no longer needs increased link reliability. This operation can not fail.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h*``set_coalesce`` Set coalesce parameters. h](j)}(h``set_coalesce``h]j)}(hjh]h set_coalesce}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hSet coalesce parameters.h]hSet coalesce parameters.}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hMhj+ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj*hMhjubj)}(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)}(hjNh]hchannel_switch}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjHubj6)}(hhh]h)}(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.}(hjghhhNhNubah}(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&]uh1j5hjHubeh}(h]h ]h"]h$]h&]uh1jhjchMhjubj)}(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.hhMhjubj6)}(hhh]h)}(h)Set QoS mapping information to the driverh]h)Set QoS mapping information to the driver}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``set_ap_chanwidth`` Set the AP (including P2P GO) mode channel width for the given interface This is used e.g. for dynamic HT 20/40 MHz channel width changes during the lifetime of the BSS. h](j)}(h``set_ap_chanwidth``h]j)}(hjh]hset_ap_chanwidth}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hSet the AP (including P2P GO) mode channel width for the given interface This is used e.g. for dynamic HT 20/40 MHz channel width changes during the lifetime of the BSS.h]hSet the AP (including P2P GO) mode channel width for the given interface This is used e.g. for dynamic HT 20/40 MHz channel width changes during the lifetime of the BSS.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX``add_tx_ts`` validate (if admitted_time is 0) or add a TX TS to the device with the given parameters; action frame exchange has been handled by userspace so this just has to modify the TX path to take the TS into account. If the admitted time is 0 just validate the parameters to make sure the session can be created at all; it is valid to just always return success for that but that may result in inefficient behaviour (handshake with the peer followed by immediate teardown when the addition is later rejected) h](j)}(h ``add_tx_ts``h]j)}(hjh]h add_tx_ts}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hXvalidate (if admitted_time is 0) or add a TX TS to the device with the given parameters; action frame exchange has been handled by userspace so this just has to modify the TX path to take the TS into account. If the admitted time is 0 just validate the parameters to make sure the session can be created at all; it is valid to just always return success for that but that may result in inefficient behaviour (handshake with the peer followed by immediate teardown when the addition is later rejected)h]hXvalidate (if admitted_time is 0) or add a TX TS to the device with the given parameters; action frame exchange has been handled by userspace so this just has to modify the TX path to take the TS into account. If the admitted time is 0 just validate the parameters to make sure the session can be created at all; it is valid to just always return success for that but that may result in inefficient behaviour (handshake with the peer followed by immediate teardown when the addition is later rejected)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h'``del_tx_ts`` remove an existing TX TS h](j)}(h ``del_tx_ts``h]j)}(hj5h]h del_tx_ts}(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.hhMhj/ubj6)}(hhh]h)}(hremove an existing TX TSh]hremove an existing TX TS}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJhMhjKubah}(h]h ]h"]h$]h&]uh1j5hj/ubeh}(h]h ]h"]h$]h&]uh1jhjJhMhjubj)}(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)}(hjnh]htdls_channel_switch}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhubj6)}(hhh]h)}(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&]uh1j5hjhubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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&]uh1jhjhMhjubj)}(h'``start_nan`` Start the NAN interface. h](j)}(h ``start_nan``h]j)}(hjh]h start_nan}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hStart the NAN interface.h]hStart the NAN interface.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h%``stop_nan`` Stop the NAN interface. h](j)}(h ``stop_nan``h]j)}(hjh]hstop_nan}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hStop the NAN interface.h]hStop the NAN interface.}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0hMhj1ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj0hMhjubj)}(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)}(hjTh]h add_nan_func}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjNubj6)}(hhh]h)}(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 }(hjmhhhNhNubj)}(h **nan_func**h]hnan_func}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmubh ownership is transferred to the driver and it may access it outside of the scope of this function. The driver should free the }(hjmhhhNhNubj)}(h **nan_func**h]hnan_func}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmubh when no longer needed by calling cfg80211_free_nan_func(). On success the driver should assign an instance_id in the provided }(hjmhhhNhNubj)}(h **nan_func**h]hnan_func}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmubh.}(hjmhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubah}(h]h ]h"]h$]h&]uh1j5hjNubeh}(h]h ]h"]h$]h&]uh1jhjihMhjubj)}(h(``del_nan_func`` Delete a NAN function. h](j)}(h``del_nan_func``h]j)}(hjh]h del_nan_func}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hDelete a NAN function.h]hDelete a NAN function.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``nan_change_conf`` changes NAN configuration. The changed parameters must be specified in **changes** (using :c:type:`enum cfg80211_nan_conf_changes `); All other parameters must be ignored. h](j)}(h``nan_change_conf``h]j)}(hjh]hnan_change_conf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hchanges NAN configuration. The changed parameters must be specified in **changes** (using :c:type:`enum cfg80211_nan_conf_changes `); All other parameters must be ignored.h](hGchanges NAN configuration. The changed parameters must be specified in }(hjhhhNhNubj)}(h **changes**h]hchanges}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh (using }(hjhhhNhNubh)}(hD:c:type:`enum cfg80211_nan_conf_changes `h]j)}(hj2h]henum cfg80211_nan_conf_changes}(hj4hhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6cfg80211_nan_conf_changesuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh(); All other parameters must be ignored.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjOhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hO``set_multicast_to_unicast`` configure multicast to unicast conversion for BSS h](j)}(h``set_multicast_to_unicast``h]j)}(hjlh]hset_multicast_to_unicast}(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)}(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&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhG, this function should return phy stats, and interface stats otherwise.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``set_pmk`` configure the PMK to be used for offloaded 802.1X 4-Way handshake. If not deleted through **del_pmk** the PMK remains valid until disconnect upon which the driver should clear it. (invoked with the wireless_dev mutex held) h](j)}(h ``set_pmk``h]j)}(hjh]hset_pmk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(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 }(hj hhhNhNubj)}(h **del_pmk**h]hdel_pmk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubhy the PMK remains valid until disconnect upon which the driver should clear it. (invoked with the wireless_dev mutex held)}(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)}(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)}(hj=h]hdel_pmk}(hj?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)}(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)}(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&]uh1jhjRhMhjubj)}(hZ``external_auth`` indicates result of offloaded authentication processing from user space h](j)}(h``external_auth``h]j)}(hjwh]h external_auth}(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)}(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&]uh1j5hjqubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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&]uh1jhjhMhjubj)}(h``get_ftm_responder_stats`` Retrieve FTM responder statistics, if available. Statistics should be cumulative, currently no way to reset is provided. h](j)}(h``get_ftm_responder_stats``h]j)}(hjh]hget_ftm_responder_stats}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hxRetrieve FTM responder statistics, if available. Statistics should be cumulative, currently no way to reset is provided.h]hxRetrieve FTM responder statistics, if available. Statistics should be cumulative, currently no way to reset is provided.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h1``start_pmsr`` start peer measurement (e.g. FTM) h](j)}(h``start_pmsr``h]j)}(hj%h]h start_pmsr}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h!start peer measurement (e.g. FTM)h]h!start peer measurement (e.g. FTM)}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:hMhj;ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj:hMhjubj)}(h&``abort_pmsr`` abort peer measurement h](j)}(h``abort_pmsr``h]j)}(hj^h]h abort_pmsr}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjXubj6)}(hhh]h)}(habort peer measurementh]habort peer measurement}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjshMhjtubah}(h]h ]h"]h$]h&]uh1j5hjXubeh}(h]h ]h"]h$]h&]uh1jhjshMhjubj)}(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&]uh1jhjhMhjubj)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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)}(hj h]hset_tid_config}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(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.}(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)}(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)}(hjEh]hreset_tid_config}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj?ubj6)}(hhh]h)}(h[Reset TID specific configuration for the peer, for the given TIDs. This callback may sleep.h]h[Reset TID specific configuration for the peer, for the given TIDs. This callback may sleep.}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj[ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhjZhMhjubj)}(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&]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#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&]uh1j5hjyubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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&]uh1jhjhMhjubj)}(h``set_fils_aad`` Set FILS AAD data to the AP driver so that the driver can use those to decrypt (Re)Association Request and encrypt (Re)Association Response frame. h](j)}(h``set_fils_aad``h]j)}(hjh]h set_fils_aad}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(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.}(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&]uh1jhjhMhjubj)}(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)}(hj+h]hset_radar_background}(hj-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)}(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.}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjAubah}(h]h ]h"]h$]h&]uh1j5hj%ubeh}(h]h ]h"]h$]h&]uh1jhj@hMhjubj)}(h.``add_link_station`` Add a link to a station. h](j)}(h``add_link_station``h]j)}(hjeh]hadd_link_station}(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)}(hAdd a link to a station.h]hAdd a link to a station.}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzhMhj{ubah}(h]h ]h"]h$]h&]uh1j5hj_ubeh}(h]h ]h"]h$]h&]uh1jhjzhMhjubj)}(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&]uh1jhjhMhjubj)}(h1``del_link_station`` Remove a link of a station. h](j)}(h``del_link_station``h]j)}(hjh]hdel_link_station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hRemove a link of a station.h]hRemove a link of a station.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hF``set_hw_timestamp`` Enable/disable HW timestamping of TM/FTM frames. h](j)}(h``set_hw_timestamp``h]j)}(hjh]hset_hw_timestamp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj ubj6)}(hhh]h)}(h0Enable/disable HW timestamping of TM/FTM frames.h]h0Enable/disable HW timestamping of TM/FTM frames.}(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*``set_ttlm`` set the TID to link mapping. h](j)}(h ``set_ttlm``h]j)}(hjIh]hset_ttlm}(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)}(hset the TID to link mapping.h]hset the TID to link mapping.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hMhj_ubah}(h]h ]h"]h$]h&]uh1j5hjCubeh}(h]h ]h"]h$]h&]uh1jhj^hMhjubj)}(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.hhMhj|ubj6)}(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&]uh1j5hj|ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(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.hhM!hjubj6)}(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&]uh1jhjhM!hjubj)}(h2``set_epcs`` Enable/Disable EPCS for station mode.h](j)}(h ``set_epcs``h]j)}(hjh]hset_epcs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h%Enable/Disable EPCS for station mode.h]h%Enable/Disable EPCS for station mode.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubh)}(h**Description**h]j)}(hj9h]h Description}(hj;hhhNhNubah}(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.hhMhj$bhhubh)}(hThis struct is registered by fullmac card drivers and/or wireless stacks in order to handle configuration requests on their interfaces.h]hThis struct is registered by fullmac card drivers and/or wireless stacks in order to handle configuration requests on their interfaces.}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$bhhubh)}(h_All callbacks except where otherwise noted should return 0 on success or a negative error code.h]h_All callbacks except where otherwise noted should return 0 on success or a negative error code.}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$bhhubh)}(hXAll operations are invoked with the wiphy mutex held. The RTNL may be held in addition (due to wireless extensions) but this cannot be relied upon except in cases where documented below. Note that due to ordering, the RTNL also cannot be acquired in any handlers.h]hXAll operations are invoked with the wiphy mutex held. The RTNL may be held in addition (due to wireless extensions) but this cannot be relied upon except in cases where documented below. Note that due to ordering, the RTNL also cannot be acquired in any handlers.}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$bhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_rx_mlme_mgmt (C function)c.cfg80211_rx_mlme_mgmthNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hNvoid cfg80211_rx_mlme_mgmt (struct net_device *dev, const u8 *buf, size_t len)h]jo)}(hMvoid cfg80211_rx_mlme_mgmt(struct net_device *dev, const u8 *buf, size_t len)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubj)}(hcfg80211_rx_mlme_mgmth]j)}(hcfg80211_rx_mlme_mgmth]hcfg80211_rx_mlme_mgmt}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMubj)}(h3(struct net_device *dev, const u8 *buf, size_t len)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}jjsbc.cfg80211_rx_mlme_mgmtasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hdevh]hdev}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h const u8 *bufh](ju)}(hjZHh]hconst}(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj@ubj)}(h h]h }(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@ubh)}(hhh]j)}(hu8h]hu8}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjdmodnameN classnameNj j )}j ]j c.cfg80211_rx_mlme_mgmtasbuh1hhj@ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@ubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj@ubj)}(hbufh]hbuf}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h size_t lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j c.cfg80211_rx_mlme_mgmtasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hlenh]hlen}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMhjhhubj)}(hhh]h)}(h/notification of processed MLME management frameh]h/notification of processed MLME management frame}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jj%jj%jjjuh1jchhhj$bhNhNubj)}(hX**Parameters** ``struct net_device *dev`` network device ``const u8 *buf`` authentication frame (header + body) ``size_t len`` length of the frame data **Description** This function is called whenever an authentication, disassociation or deauthentication frame has been received and processed in station mode. After being asked to authenticate via cfg80211_ops::auth() the driver must call either this function or cfg80211_auth_timeout(). After being asked to associate via cfg80211_ops::assoc() the driver must call either this function or cfg80211_auth_timeout(). While connected, the driver must calls this for received and processed disassociation and deauthentication frames. If the frame couldn't be used because it was unprotected, the driver must call the function cfg80211_rx_unprot_mlme_mgmt() instead. This function may sleep. The caller must hold the corresponding wdev's mutex.h](h)}(h**Parameters**h]j)}(hj/h]h Parameters}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj)ubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hjNh]hstruct net_device *dev}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjHubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjchMhjdubah}(h]h ]h"]h$]h&]uh1j5hjHubeh}(h]h ]h"]h$]h&]uh1jhjchMhjEubj)}(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.hhMhjubj6)}(hhh]h)}(h$authentication frame (header + body)h]h$authentication frame (header + body)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjEubj)}(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&]uh1jhjhMhjEubeh}(h]h ]h"]h$]h&]uh1jhj)ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj)ubh)}(hXThis function is called whenever an authentication, disassociation or deauthentication frame has been received and processed in station mode. After being asked to authenticate via cfg80211_ops::auth() the driver must call either this function or cfg80211_auth_timeout(). After being asked to associate via cfg80211_ops::assoc() the driver must call either this function or cfg80211_auth_timeout(). While connected, the driver must calls this for received and processed disassociation and deauthentication frames. If the frame couldn't be used because it was unprotected, the driver must call the function cfg80211_rx_unprot_mlme_mgmt() instead.h]hXThis function is called whenever an authentication, disassociation or deauthentication frame has been received and processed in station mode. After being asked to authenticate via cfg80211_ops::auth() the driver must call either this function or cfg80211_auth_timeout(). After being asked to associate via cfg80211_ops::assoc() the driver must call either this function or cfg80211_auth_timeout(). While connected, the driver must calls this for received and processed disassociation and deauthentication frames. If the frame couldn’t be used because it was unprotected, the driver must call the function cfg80211_rx_unprot_mlme_mgmt() instead.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj)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.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj)ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_auth_timeout (C function)c.cfg80211_auth_timeouthNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hCvoid cfg80211_auth_timeout (struct net_device *dev, const u8 *addr)h]jo)}(hBvoid cfg80211_auth_timeout(struct net_device *dev, const u8 *addr)h](j)}(hvoidh]hvoid}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKhhh`/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&]uh1jhjKhhhj]hMubj)}(hcfg80211_auth_timeouth]j)}(hcfg80211_auth_timeouth]hcfg80211_auth_timeout}(hjphhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjlubah}(h]h ](jjeh"]h$]h&]jjuh1jhjKhhhj]hMubj)}(h((struct net_device *dev, const u8 *addr)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}jjrsbc.cfg80211_auth_timeoutasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *addrh](ju)}(hjZHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_auth_timeoutasbuh1hhjubj)}(h h]h }(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjHhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(haddrh]haddr}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjKhhhj]hMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjGhhhj]hMubah}(h]jBah ](jjeh"]h$]h&]jj)jhuh1jhhj]hMhjDhhubj)}(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.hhMhj|hhubah}(h]h ]h"]h$]h&]uh1jhjDhhhj]hMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhj$bhNhNubj)}(h**Parameters** ``struct net_device *dev`` network device ``const u8 *addr`` The MAC address of the device with which the authentication timed out **Description** This function may sleep. The caller must hold the corresponding wdev's mutex.h](h)}(h**Parameters**h]j)}(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)}(hY``const u8 *addr`` The MAC address of the device with which the authentication timed out h](j)}(h``const u8 *addr``h]j)}(hjh]hconst u8 *addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hEThe MAC address of the device with which the authentication timed outh]hEThe MAC address of the device with which the authentication timed out}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj4h]h Description}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh)}(hMThis function may sleep. The caller must hold the corresponding wdev's mutex.h]hOThis function may sleep. The caller must hold the corresponding wdev’s mutex.}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_#cfg80211_rx_assoc_resp (C function)c.cfg80211_rx_assoc_resphNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hdvoid cfg80211_rx_assoc_resp (struct net_device *dev, const struct cfg80211_rx_assoc_resp_data *data)h]jo)}(hcvoid cfg80211_rx_assoc_resp(struct net_device *dev, const struct cfg80211_rx_assoc_resp_data *data)h](j)}(hvoidh]hvoid}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuhhhjhMubj)}(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&]jjuh1jhjuhhhjhMubj)}(hH(struct net_device *dev, const struct cfg80211_rx_assoc_resp_data *data)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}jjsbc.cfg80211_rx_assoc_respasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h.const struct cfg80211_rx_assoc_resp_data *datah](ju)}(hjZHh]hconst}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj$ubj)}(h h]h }(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubju)}(hjh]hstruct}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj$ubj)}(h h]h }(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubh)}(hhh]j)}(hcfg80211_rx_assoc_resp_datah]hcfg80211_rx_assoc_resp_data}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjcmodnameN classnameNj j )}j ]jc.cfg80211_rx_assoc_respasbuh1hhj$ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj$ubj)}(hdatah]hdata}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjuhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjqhhhjhMubah}(h]jlah ](jjeh"]h$]h&]jj)jhuh1jhhjhMhjnhhubj)}(hhh]h)}(h.notification of processed association responseh]h.notification of processed association response}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjnhhhjhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhj$bhNhNubj)}(hX**Parameters** ``struct net_device *dev`` network device ``const struct cfg80211_rx_assoc_resp_data *data`` association response data, :c:type:`struct cfg80211_rx_assoc_resp_data ` **Description** After being asked to associate via cfg80211_ops::assoc() the driver must call either this function or cfg80211_auth_timeout(). This function may sleep. The caller must hold the corresponding wdev's mutex.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.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 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)}(hj>h]h.const struct cfg80211_rx_assoc_resp_data *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.hhM hj8ubj6)}(hhh]h)}(heassociation response data, :c:type:`struct cfg80211_rx_assoc_resp_data `h](hassociation response data, }(hjWhhhNhNubh)}(hJ:c:type:`struct cfg80211_rx_assoc_resp_data `h]j)}(hjah]h"struct cfg80211_rx_assoc_resp_data}(hjchhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6cfg80211_rx_assoc_resp_datauh1hhjShM hjWubeh}(h]h ]h"]h$]h&]uh1hhjShM hjTubah}(h]h ]h"]h$]h&]uh1j5hj8ubeh}(h]h ]h"]h$]h&]uh1jhjShM 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)}(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.hhM hjubh)}(hMThis function may sleep. The caller must hold the corresponding wdev's mutex.h]hOThis function may sleep. The caller must hold the corresponding wdev’s mutex.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_tx_mlme_mgmt (C function)c.cfg80211_tx_mlme_mgmthNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(h^void cfg80211_tx_mlme_mgmt (struct net_device *dev, const u8 *buf, size_t len, bool reconnect)h]jo)}(h]void cfg80211_tx_mlme_mgmt(struct net_device *dev, const u8 *buf, size_t len, bool reconnect)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM9ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM9ubj)}(hcfg80211_tx_mlme_mgmth]j)}(hcfg80211_tx_mlme_mgmth]hcfg80211_tx_mlme_mgmt}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM9ubj)}(hC(struct net_device *dev, const u8 *buf, size_t len, bool reconnect)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj%ubj)}(h h]h }(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubh)}(hhh]j)}(h net_deviceh]h net_device}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjImodnameN classnameNj j )}j ]j)}jjsbc.cfg80211_tx_mlme_mgmtasbuh1hhj%ubj)}(h h]h }(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubj.)}(hj1h]h*}(hjuhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj%ubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj!ubj)}(h const u8 *bufh](ju)}(hjZHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jcc.cfg80211_tx_mlme_mgmtasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hbufh]hbuf}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj!ubj)}(h size_t lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jcc.cfg80211_tx_mlme_mgmtasbuh1hhjubj)}(h h]h }(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hlenh]hlen}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj!ubj)}(hbool reconnecth](j)}(hboolh]hbool}(hjShhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubj)}(h h]h }(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubj)}(h reconnecth]h reconnect}(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj!ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM9ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM9ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM9hjhhubj)}(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.hhM.hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM9ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhj$bhNhNubj)}(hX**Parameters** ``struct net_device *dev`` network device ``const u8 *buf`` 802.11 frame (header + body) ``size_t len`` length of the frame data ``bool reconnect`` immediate reconnect is desired (include the nl80211 attribute) **Description** This function is called whenever deauthentication has been processed in station mode. This includes both received deauthentication frames and locally generated ones. This function may sleep. The caller must hold the corresponding wdev's mutex.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM2hjubj)}(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 *buf`` 802.11 frame (header + body) h](j)}(h``const u8 *buf``h]j)}(hjh]h const u8 *buf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM0hj ubj6)}(hhh]h)}(h802.11 frame (header + body)h]h802.11 frame (header + body)}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj(hM0hj)ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj(hM0hjubj)}(h(``size_t len`` length of the frame data h](j)}(h``size_t len``h]j)}(hjLh]h size_t len}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM1hjFubj6)}(hhh]h)}(hlength of the frame datah]hlength of the frame data}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjahM1hjbubah}(h]h ]h"]h$]h&]uh1j5hjFubeh}(h]h ]h"]h$]h&]uh1jhjahM1hjubj)}(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.hhM2hjubj6)}(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&]uh1hhjhM2hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM2hjubeh}(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.hhM4hjubh)}(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.hhM4hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_)cfg80211_michael_mic_failure (C function)c.cfg80211_michael_mic_failurehNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hvoid cfg80211_michael_mic_failure (struct net_device *dev, const u8 *addr, enum nl80211_key_type key_type, int key_id, const u8 *tsc, gfp_t gfp)h]jo)}(hvoid cfg80211_michael_mic_failure(struct net_device *dev, const u8 *addr, enum nl80211_key_type key_type, int key_id, const u8 *tsc, gfp_t gfp)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMZubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMZubj)}(hcfg80211_michael_mic_failureh]j)}(hcfg80211_michael_mic_failureh]hcfg80211_michael_mic_failure}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMZubj)}(hn(struct net_device *dev, const u8 *addr, enum nl80211_key_type key_type, int key_id, const u8 *tsc, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(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}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjbmodnameN classnameNj j )}j ]j)}jj(sbc.cfg80211_michael_mic_failureasbuh1hhj>ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>ubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj>ubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj:ubj)}(hconst u8 *addrh](ju)}(hjZHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j|c.cfg80211_michael_mic_failureasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(haddrh]haddr}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj:ubj)}(henum nl80211_key_type key_typeh](ju)}(hjxh]henum}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj ubj)}(h h]h }(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(hnl80211_key_typeh]hnl80211_key_type}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjDmodnameN classnameNj j )}j ]j|c.cfg80211_michael_mic_failureasbuh1hhj ubj)}(h h]h }(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(hkey_typeh]hkey_type}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj:ubj)}(h int key_idh](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(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&]noemphjjuh1jhj:ubj)}(h const u8 *tsch](ju)}(hjZHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j|c.cfg80211_michael_mic_failureasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(htsch]htsc}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]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 reftargetj1modnameN classnameNj j )}j ]j|c.cfg80211_michael_mic_failureasbuh1hhj(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&]noemphjjuh1jhj:ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMZubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMZubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMZhjhhubj)}(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.hhMNhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMZubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhj$bhNhNubj)}(hX-**Parameters** ``struct net_device *dev`` network device ``const u8 *addr`` The source MAC address of the frame ``enum nl80211_key_type key_type`` The key type that the received frame used ``int key_id`` Key identifier (0..3). Can be -1 if missing. ``const u8 *tsc`` The TSC value of the frame that generated the MIC failure (6 octets) ``gfp_t gfp`` allocation flags **Description** This function is called whenever the local MAC detects a MIC failure in a received frame. This matches with MLME-MICHAELMICFAILURE.indication() primitive.h](h)}(h**Parameters**h]j)}(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.hhMRhjubj)}(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.hhMOhjubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMOhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMOhjubj)}(h7``const u8 *addr`` The source MAC address of the frame h](j)}(h``const u8 *addr``h]j)}(hjh]hconst u8 *addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMPhjubj6)}(hhh]h)}(h#The source MAC address of the frameh]h#The source MAC address of the frame}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMPhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMPhjubj)}(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)}(hj8h]henum nl80211_key_type key_type}(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.hhMQhj2ubj6)}(hhh]h)}(h)The key type that the received frame usedh]h)The key type that the received frame used}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjMhMQhjNubah}(h]h ]h"]h$]h&]uh1j5hj2ubeh}(h]h ]h"]h$]h&]uh1jhjMhMQhjubj)}(h<``int key_id`` Key identifier (0..3). Can be -1 if missing. h](j)}(h``int key_id``h]j)}(hjqh]h int key_id}(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.hhMRhjkubj6)}(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&]uh1hhjhMRhjubah}(h]h ]h"]h$]h&]uh1j5hjkubeh}(h]h ]h"]h$]h&]uh1jhjhMRhjubj)}(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.hhMShjubj6)}(hhh]h)}(hDThe TSC value of the frame that generated the MIC failure (6 octets)h]hDThe TSC value of the frame that generated the MIC failure (6 octets)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMShjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMShjubj)}(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.hhMThjubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMThjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMThjubeh}(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.hhMVhjubh)}(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.}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMVhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_!cfg80211_ibss_joined (C function)c.cfg80211_ibss_joinedhNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hqvoid cfg80211_ibss_joined (struct net_device *dev, const u8 *bssid, struct ieee80211_channel *channel, gfp_t gfp)h]jo)}(hpvoid cfg80211_ibss_joined(struct net_device *dev, const u8 *bssid, struct ieee80211_channel *channel, gfp_t gfp)h](j)}(hvoidh]hvoid}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMmubj)}(h h]h }(hjrhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_hhhjqhMmubj)}(hcfg80211_ibss_joinedh]j)}(hcfg80211_ibss_joinedh]hcfg80211_ibss_joined}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhj_hhhjqhMmubj)}(hW(struct net_device *dev, const u8 *bssid, struct ieee80211_channel *channel, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}jjsbc.cfg80211_ibss_joinedasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *bssidh](ju)}(hjZHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj2modnameN classnameNj j )}j ]jc.cfg80211_ibss_joinedasbuh1hhjubj)}(h h]h }(hjNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hj\hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hbssidh]hbssid}(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h!struct ieee80211_channel *channelh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj~ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj~ubh)}(hhh]j)}(hieee80211_channelh]hieee80211_channel}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_ibss_joinedasbuh1hhj~ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj~ubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj~ubj)}(hchannelh]hchannel}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj~ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_ibss_joinedasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj_hhhjqhMmubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj[hhhjqhMmubah}(h]jVah ](jjeh"]h$]h&]jj)jhuh1jhhjqhMmhjXhhubj)}(hhh]h)}(h*notify cfg80211 that device joined an IBSSh]h*notify cfg80211 that device joined an IBSS}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM_hjHhhubah}(h]h ]h"]h$]h&]uh1jhjXhhhjqhMmubeh}(h]h ](j$functioneh"]h$]h&]jj$jjcjjcjjjuh1jchhhj$bhNhNubj)}(hXz**Parameters** ``struct net_device *dev`` network device ``const u8 *bssid`` the BSSID of the IBSS joined ``struct ieee80211_channel *channel`` the channel of the IBSS joined ``gfp_t gfp`` allocation flags **Description** This function notifies cfg80211 that the device joined an IBSS or switched to a different BSSID. Before this function can be called, either a beacon has to have been received from the IBSS, or one of the cfg80211_inform_bss{,_frame} functions must have been called with the locally generated beacon -- this guarantees that there is always a scan result for this IBSS. cfg80211 will handle the rest.h](h)}(h**Parameters**h]j)}(hjmh]h Parameters}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMchjgubj)}(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.hhMahjubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMahjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMahjubj)}(h1``const u8 *bssid`` the BSSID of the IBSS joined h](j)}(h``const u8 *bssid``h]j)}(hjh]hconst u8 *bssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMbhjubj6)}(hhh]h)}(hthe BSSID of the IBSS joinedh]hthe BSSID of the IBSS joined}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMbhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMbhjubj)}(hE``struct ieee80211_channel *channel`` the channel of the IBSS joined h](j)}(h%``struct ieee80211_channel *channel``h]j)}(hjh]h!struct ieee80211_channel *channel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMchjubj6)}(hhh]h)}(hthe channel of the IBSS joinedh]hthe channel of the IBSS joined}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMchjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMchjubj)}(h``gfp_t gfp`` allocation flags h](j)}(h ``gfp_t gfp``h]j)}(hj7h]h gfp_t gfp}(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.hhMdhj1ubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhMdhjMubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhjLhMdhjubeh}(h]h ]h"]h$]h&]uh1jhjgubh)}(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.hhMfhjgubh)}(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.hhMfhjgubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_'cfg80211_connect_resp_params (C struct)c.cfg80211_connect_resp_paramshNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hcfg80211_connect_resp_paramsh]jo)}(h#struct cfg80211_connect_resp_paramsh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]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)}(hcfg80211_connect_resp_paramsh]j)}(hjh]hcfg80211_connect_resp_params}(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)}(hConnection response paramsh]hConnection response params}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](j$structeh"]h$]h&]jj$jjjjjjjuh1jchhhj$bhNhNubj)}(hX **Definition**:: struct cfg80211_connect_resp_params { int status; const u8 *req_ie; size_t req_ie_len; const u8 *resp_ie; size_t resp_ie_len; struct cfg80211_fils_resp_params fils; enum nl80211_timeout_reason timeout_reason; const u8 *ap_mld_addr; u16 valid_links; struct { const u8 *addr; const u8 *bssid; struct cfg80211_bss *bss; u16 status; } links[IEEE80211_MLD_MAX_NUM_LINKS]; }; **Members** ``status`` Status code, ``WLAN_STATUS_SUCCESS`` for successful connection, use ``WLAN_STATUS_UNSPECIFIED_FAILURE`` if your device cannot give you the real status code for failures. If this call is used to report a failure due to a timeout (e.g., not receiving an Authentication frame from the AP) instead of an explicit rejection by the AP, -1 is used to indicate that this is a failure, but without a status code. **timeout_reason** is used to report the reason for the timeout in that case. ``req_ie`` Association request IEs (may be ``NULL``) ``req_ie_len`` Association request IEs length ``resp_ie`` Association response IEs (may be ``NULL``) ``resp_ie_len`` Association response IEs length ``fils`` FILS connection response parameters. ``timeout_reason`` Reason for connection timeout. This is used when the connection fails due to a timeout instead of an explicit rejection from the AP. ``NL80211_TIMEOUT_UNSPECIFIED`` is used when the timeout reason is not known. This value is used only if **status** < 0 to indicate that the failure is due to a timeout and not due to explicit rejection by the AP. This value is ignored in other cases (**status** >= 0). ``ap_mld_addr`` For MLO connection, MLD address of the AP. Otherwise ``NULL``. ``valid_links`` For MLO connection, BIT mask of the valid link ids. Otherwise zero. ``links`` For MLO connection, contains link info for the valid links indicated using **valid_links**. For non-MLO connection, links[0] contains the connected AP info. ``links.addr`` For MLO connection, MAC address of the STA link. Otherwise ``NULL``. ``links.bssid`` For MLO connection, MAC address of the AP link. For non-MLO connection, links[0].bssid points to the BSSID of the AP (may be ``NULL``). ``links.bss`` For MLO connection, entry of bss to which STA link is connected. For non-MLO connection, links[0].bss points to entry of bss to which STA is connected. It can be obtained through cfg80211_get_bss() (may be ``NULL``). It is recommended to store the bss from the connect_request and hold a reference to it and return through this param to avoid a warning if the bss is expired during the connection, esp. for those drivers implementing connect op. Only one parameter among **bssid** and **bss** needs to be specified. ``links.status`` per-link status code, to report a status code that's not ``WLAN_STATUS_SUCCESS`` for a given link, it must also be in the **valid_links** bitmap and may have a BSS pointer (which is then released)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj( )}(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]; };}hj6sbah}(h]h ]h"]h$]h&]jjuh1j' h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh)}(h **Members**h]j)}(hjGh]hMembers}(hjIhhhNhNubah}(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.hhMhjubj)}(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)}(hjfh]hstatus}(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)}(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.hhMhj|ubah}(h]h ]h"]h$]h&]uh1j5hj`ubeh}(h]h ]h"]h$]h&]uh1jhj{hMhj]ubj)}(h5``req_ie`` Association request IEs (may be ``NULL``) h](j)}(h ``req_ie``h]j)}(hjh]hreq_ie}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h)Association request IEs (may be ``NULL``)h](h Association request IEs (may be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj]ubj)}(h.``req_ie_len`` Association request IEs length h](j)}(h``req_ie_len``h]j)}(hj!h]h req_ie_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.hhMhjubj6)}(hhh]h)}(hAssociation request IEs lengthh]hAssociation request IEs length}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hMhj7ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj6hMhj]ubj)}(h7``resp_ie`` Association response IEs (may be ``NULL``) h](j)}(h ``resp_ie``h]j)}(hjZh]hresp_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.hhMhjTubj6)}(hhh]h)}(h*Association response IEs (may be ``NULL``)h](h!Association response IEs (may be }(hjshhhNhNubj)}(h``NULL``h]hNULL}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubh)}(hjshhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjohMhjpubah}(h]h ]h"]h$]h&]uh1j5hjTubeh}(h]h ]h"]h$]h&]uh1jhjohMhj]ubj)}(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.hhMhjubj6)}(hhh]h)}(hAssociation response IEs lengthh]hAssociation response IEs length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj]ubj)}(h.``fils`` FILS connection response parameters. h](j)}(h``fils``h]j)}(hjh]hfils}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h$FILS connection response parameters.h]h$FILS connection response parameters.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj]ubj)}(hX``timeout_reason`` Reason for connection timeout. This is used when the connection fails due to a timeout instead of an explicit rejection from the AP. ``NL80211_TIMEOUT_UNSPECIFIED`` is used when the timeout reason is not known. This value is used only if **status** < 0 to indicate that the failure is due to a timeout and not due to explicit rejection by the AP. This value is ignored in other cases (**status** >= 0). h](j)}(h``timeout_reason``h]j)}(hjh]htimeout_reason}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(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. }(hj0hhhNhNubj)}(h``NL80211_TIMEOUT_UNSPECIFIED``h]hNL80211_TIMEOUT_UNSPECIFIED}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubhJ is used when the timeout reason is not known. This value is used only if }(hj0hhhNhNubj)}(h **status**h]hstatus}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0ubh < 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 (}(hj0hhhNhNubj)}(h **status**h]hstatus}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0ubh >= 0).}(hj0hhhNhNubeh}(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)}(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.hhMhjubj6)}(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&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj]ubj)}(hT``valid_links`` For MLO connection, BIT mask of the valid link ids. Otherwise zero. h](j)}(h``valid_links``h]j)}(hjh]h valid_links}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hCFor MLO connection, BIT mask of the valid link ids. Otherwise zero.h]hCFor MLO connection, BIT mask of the valid link ids. Otherwise zero.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj]ubj)}(h``links`` For MLO connection, contains link info for the valid links indicated using **valid_links**. For non-MLO connection, links[0] contains the connected AP info. h](j)}(h ``links``h]j)}(hj h]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.hhMhjubj6)}(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 }(hj%hhhNhNubj)}(h**valid_links**h]h valid_links}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%ubhB. For non-MLO connection, links[0] contains the connected AP info.}(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!hMhj]ubj)}(hT``links.addr`` For MLO connection, MAC address of the STA link. Otherwise ``NULL``. h](j)}(h``links.addr``h]j)}(hjXh]h links.addr}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjRubj6)}(hhh]h)}(hDFor MLO connection, MAC address of the STA link. Otherwise ``NULL``.h](h;For MLO connection, MAC address of the STA link. Otherwise }(hjqhhhNhNubj)}(h``NULL``h]hNULL}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubh.}(hjqhhhNhNubeh}(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&]uh1j5hjRubeh}(h]h ]h"]h$]h&]uh1jhjmhMhj]ubj)}(h``links.bssid`` For MLO connection, MAC address of the AP link. For non-MLO connection, links[0].bssid points to the BSSID of the AP (may be ``NULL``). h](j)}(h``links.bssid``h]j)}(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.hhMhjubj6)}(hhh]h)}(hFor MLO connection, MAC address of the AP link. For non-MLO connection, links[0].bssid points to the BSSID of the AP (may be ``NULL``).h](h}For MLO connection, MAC address of the AP link. For non-MLO connection, links[0].bssid points to the BSSID of the AP (may be }(hjhhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh).}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj]ubj)}(hX``links.bss`` For MLO connection, entry of bss to which STA link is connected. For non-MLO connection, links[0].bss points to entry of bss to which STA is connected. It can be obtained through cfg80211_get_bss() (may be ``NULL``). It is recommended to store the bss from the connect_request and hold a reference to it and return through this param to avoid a warning if the bss is expired during the connection, esp. for those drivers implementing connect op. Only one parameter among **bssid** and **bss** needs to be specified. h](j)}(h ``links.bss``h]j)}(hjh]h links.bss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hXFor MLO connection, entry of bss to which STA link is connected. For non-MLO connection, links[0].bss points to entry of bss to which STA is connected. It can be obtained through cfg80211_get_bss() (may be ``NULL``). It is recommended to store the bss from the connect_request and hold a reference to it and return through this param to avoid a warning if the bss is expired during the connection, esp. for those drivers implementing connect op. Only one parameter among **bssid** and **bss** needs to be specified.h](hFor MLO connection, entry of bss to which STA link is connected. For non-MLO connection, links[0].bss points to entry of bss to which STA is connected. It can be obtained through cfg80211_get_bss() (may be }(hj hhhNhNubj)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubhX). 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 }(hj hhhNhNubj)}(h **bssid**h]hbssid}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubh and }(hj hhhNhNubj)}(h**bss**h]hbss}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubh needs to be specified.}(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&]uh1jhjhM hj]ubj)}(h``links.status`` per-link status code, to report a status code that's not ``WLAN_STATUS_SUCCESS`` for a given link, it must also be in the **valid_links** bitmap and may have a BSS pointer (which is then released)h](j)}(h``links.status``h]j)}(hj`h]h links.status}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjZubj6)}(hhh]h)}(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 }(hjyhhhNhNubj)}(h``WLAN_STATUS_SUCCESS``h]hWLAN_STATUS_SUCCESS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubh* for a given link, it must also be in the }(hjyhhhNhNubj)}(h**valid_links**h]h valid_links}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyubh; bitmap and may have a BSS pointer (which is then released)}(hjyhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjvubah}(h]h ]h"]h$]h&]uh1j5hjZubeh}(h]h ]h"]h$]h&]uh1jhjuhM hj]ubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_connect_done (C function)c.cfg80211_connect_donehNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hkvoid cfg80211_connect_done (struct net_device *dev, struct cfg80211_connect_resp_params *params, gfp_t gfp)h]jo)}(hjvoid cfg80211_connect_done(struct net_device *dev, struct cfg80211_connect_resp_params *params, gfp_t gfp)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM( ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM( ubj)}(hcfg80211_connect_doneh]j)}(hcfg80211_connect_doneh]hcfg80211_connect_done}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM( ubj)}(hP(struct net_device *dev, struct cfg80211_connect_resp_params *params, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(h net_deviceh]h net_device}(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj;modnameN classnameNj j )}j ]j)}jjsbc.cfg80211_connect_doneasbuh1hhjubj)}(h h]h }(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjghhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hdevh]hdev}(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h+struct cfg80211_connect_resp_params *paramsh](ju)}(hjh]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 classnameNj j )}j ]jUc.cfg80211_connect_doneasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hparamsh]hparams}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jUc.cfg80211_connect_doneasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM( ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM( ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM( hjhhubj)}(hhh]h)}(h$notify cfg80211 of connection resulth]h$notify cfg80211 of connection result}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjShhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM( ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjnjjnjjjuh1jchhhj$bhNhNubj)}(hXD**Parameters** ``struct net_device *dev`` network device ``struct cfg80211_connect_resp_params *params`` connection response parameters ``gfp_t gfp`` allocation flags **Description** It should be called by the underlying driver once execution of the connection request from connect() has been completed. This is similar to cfg80211_connect_bss(), but takes a structure pointer for connection response parameters. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.h](h)}(h**Parameters**h]j)}(hjxh]h Parameters}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjrubj)}(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)}(hjh]h+struct cfg80211_connect_resp_params *params}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hconnection response parametersh]hconnection response parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(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&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubeh}(h]h ]h"]h$]h&]uh1jhjrubh)}(h**Description**h]j)}(hjDh]h Description}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM! hjrubh)}(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.}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM! hjrubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_!cfg80211_connect_bss (C function)c.cfg80211_connect_bsshNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hvoid cfg80211_connect_bss (struct net_device *dev, const u8 *bssid, struct cfg80211_bss *bss, const u8 *req_ie, size_t req_ie_len, const u8 *resp_ie, size_t resp_ie_len, int status, gfp_t gfp, enum nl80211_timeout_reason timeout_reason)h]jo)}(hvoid cfg80211_connect_bss(struct net_device *dev, const u8 *bssid, struct cfg80211_bss *bss, const u8 *req_ie, size_t req_ie_len, const u8 *resp_ie, size_t resp_ie_len, int status, gfp_t gfp, enum nl80211_timeout_reason timeout_reason)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMR ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMR ubj)}(hcfg80211_connect_bssh]j)}(hcfg80211_connect_bssh]hcfg80211_connect_bss}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMR ubj)}(h(struct net_device *dev, const u8 *bssid, struct cfg80211_bss *bss, const u8 *req_ie, size_t req_ie_len, const u8 *resp_ie, size_t resp_ie_len, int status, gfp_t gfp, enum nl80211_timeout_reason timeout_reason)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}jjsbc.cfg80211_connect_bssasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *bssidh](ju)}(hjZHh]hconst}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj4ubj)}(h h]h }(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubh)}(hhh]j)}(hu8h]hu8}(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjXmodnameN classnameNj j )}j ]jc.cfg80211_connect_bssasbuh1hhj4ubj)}(h h]h }(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj4ubj)}(hbssidh]hbssid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct cfg80211_bss *bssh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(h cfg80211_bssh]h cfg80211_bss}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_connect_bssasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hbssh]hbss}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *req_ieh](ju)}(hjZHh]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}(hj6 hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3 ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj8 modnameN classnameNj j )}j ]jc.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hjT hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj.)}(hj1h]h*}(hjb hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj ubj)}(hreq_ieh]hreq_ie}(hjo hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hsize_t req_ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNj j )}j ]jc.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&]noemphjjuh1jhjubj)}(hconst u8 *resp_ieh](ju)}(hjZHh]hconst}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(hu8h]hu8}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNj j )}j ]jc.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj.)}(hj1h]h*}(hj hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj ubj)}(hresp_ieh]hresp_ie}(hj' hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hsize_t resp_ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjC hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@ ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjE modnameN classnameNj j )}j ]jc.cfg80211_connect_bssasbuh1hhj< ubj)}(h h]h }(hja hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj< ubj)}(h resp_ie_lenh]h resp_ie_len}(hjo hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj< ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h int statush](j)}(hinth]hint}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj 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&]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 classnameNj j )}j ]jc.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(hgfph]hgfp}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h*enum nl80211_timeout_reason timeout_reasonh](ju)}(hjxh]henum}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(hnl80211_timeout_reasonh]hnl80211_timeout_reason}(hj# hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj% modnameN classnameNj j )}j ]jc.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hjA hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(htimeout_reasonh]htimeout_reason}(hjO hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMR ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMR ubah}(h]j|ah ](jjeh"]h$]h&]jj)jhuh1jhhjhMR hj~hhubj)}(hhh]h)}(h$notify cfg80211 of connection resulth]h$notify cfg80211 of connection result}(hjy hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM- hjv hhubah}(h]h ]h"]h$]h&]uh1jhj~hhhjhMR ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj jj jjjuh1jchhhj$bhNhNubj)}(hX**Parameters** ``struct net_device *dev`` network device ``const u8 *bssid`` the BSSID of the AP ``struct cfg80211_bss *bss`` Entry of bss to which STA got connected to, can be obtained through cfg80211_get_bss() (may be ``NULL``). But it is recommended to store the bss from the connect_request and hold a reference to it and return through this param to avoid a warning if the bss is expired during the connection, esp. for those drivers implementing connect op. Only one parameter among **bssid** and **bss** needs to be specified. ``const u8 *req_ie`` association request IEs (maybe be ``NULL``) ``size_t req_ie_len`` association request IEs length ``const u8 *resp_ie`` association response IEs (may be ``NULL``) ``size_t resp_ie_len`` assoc response IEs length ``int status`` status code, ``WLAN_STATUS_SUCCESS`` for successful connection, use ``WLAN_STATUS_UNSPECIFIED_FAILURE`` if your device cannot give you the real status code for failures. If this call is used to report a failure due to a timeout (e.g., not receiving an Authentication frame from the AP) instead of an explicit rejection by the AP, -1 is used to indicate that this is a failure, but without a status code. **timeout_reason** is used to report the reason for the timeout in that case. ``gfp_t gfp`` allocation flags ``enum nl80211_timeout_reason timeout_reason`` reason for connection timeout. This is used when the connection fails due to a timeout instead of an explicit rejection from the AP. ``NL80211_TIMEOUT_UNSPECIFIED`` is used when the timeout reason is not known. This value is used only if **status** < 0 to indicate that the failure is due to a timeout and not due to explicit rejection by the AP. This value is ignored in other cases (**status** >= 0). **Description** It should be called by the underlying driver once execution of the connection request from connect() has been completed. This is similar to cfg80211_connect_result(), but with the option of identifying the exact bss entry for the connection. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.h](h)}(h**Parameters**h]j)}(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.hhM1 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)}(h(``const u8 *bssid`` the BSSID of the AP h](j)}(h``const u8 *bssid``h]j)}(hj h]hconst u8 *bssid}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM0 hj ubj6)}(hhh]h)}(hthe BSSID of the APh]hthe BSSID of the AP}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM0 hj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hM0 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)}(hj, h]hstruct cfg80211_bss *bss}(hj. hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj* ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM6 hj& ubj6)}(hhh]h)}(hXEntry of bss to which STA got connected to, can be obtained through cfg80211_get_bss() (may be ``NULL``). But it is recommended to store the bss from the connect_request and hold a reference to it and return through this param to avoid a warning if the bss is expired during the connection, esp. for those drivers implementing connect op. Only one parameter among **bssid** and **bss** needs to be specified.h](h_Entry of bss to which STA got connected to, can be obtained through cfg80211_get_bss() (may be }(hjE hhhNhNubj)}(h``NULL``h]hNULL}(hjM hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjE ubhX). 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 }(hjE hhhNhNubj)}(h **bssid**h]hbssid}(hj_ hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjE ubh and }(hjE hhhNhNubj)}(h**bss**h]hbss}(hjq hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjE ubh needs to be specified.}(hjE hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM1 hjB ubah}(h]h ]h"]h$]h&]uh1j5hj& ubeh}(h]h ]h"]h$]h&]uh1jhjA hM6 hj ubj)}(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}(hj 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.hhM7 hj ubj6)}(hhh]h)}(h+association request IEs (maybe be ``NULL``)h](h"association request IEs (maybe be }(hj hhhNhNubj)}(h``NULL``h]hNULL}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh)}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hM7 hj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hM7 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}(hj 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.hhM8 hj ubj6)}(hhh]h)}(hassociation request IEs lengthh]hassociation request IEs length}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM8 hj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hM8 hj ubj)}(hA``const u8 *resp_ie`` association response IEs (may be ``NULL``) h](j)}(h``const u8 *resp_ie``h]j)}(hj h]hconst u8 *resp_ie}(hj" hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM9 hj ubj6)}(hhh]h)}(h*association response IEs (may be ``NULL``)h](h!association response IEs (may be }(hj9 hhhNhNubj)}(h``NULL``h]hNULL}(hjA hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9 ubh)}(hj9 hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj5 hM9 hj6 ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj5 hM9 hj ubj)}(h1``size_t resp_ie_len`` assoc response IEs length h](j)}(h``size_t resp_ie_len``h]j)}(hjk h]hsize_t resp_ie_len}(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.hhM: hje ubj6)}(hhh]h)}(hassoc response IEs lengthh]hassoc response IEs length}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM: hj ubah}(h]h ]h"]h$]h&]uh1j5hje ubeh}(h]h ]h"]h$]h&]uh1jhj hM: 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)}(hj h]h int status}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMB hj ubj6)}(hhh]h)}(hXstatus code, ``WLAN_STATUS_SUCCESS`` for successful connection, use ``WLAN_STATUS_UNSPECIFIED_FAILURE`` if your device cannot give you the real status code for failures. If this call is used to report a failure due to a timeout (e.g., not receiving an Authentication frame from the AP) instead of an explicit rejection by the AP, -1 is used to indicate that this is a failure, but without a status code. **timeout_reason** is used to report the reason for the timeout in that case.h](h status code, }(hj hhhNhNubj)}(h``WLAN_STATUS_SUCCESS``h]hWLAN_STATUS_SUCCESS}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh for successful connection, use }(hj hhhNhNubj)}(h#``WLAN_STATUS_UNSPECIFIED_FAILURE``h]hWLAN_STATUS_UNSPECIFIED_FAILURE}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubhX- 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. }(hj hhhNhNubj)}(h**timeout_reason**h]htimeout_reason}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubh; is used to report the reason for the timeout in that case.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM; hj ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj hMB hj ubj)}(h``gfp_t gfp`` allocation flags h](j)}(h ``gfp_t gfp``h]j)}(hjh]h gfp_t gfp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMC hjubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj)hMC hj*ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj)hMC 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)}(hjMh]h*enum nl80211_timeout_reason timeout_reason}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMI hjGubj6)}(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. }(hjfhhhNhNubj)}(h``NL80211_TIMEOUT_UNSPECIFIED``h]hNL80211_TIMEOUT_UNSPECIFIED}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubhJ is used when the timeout reason is not known. This value is used only if }(hjfhhhNhNubj)}(h **status**h]hstatus}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfubh < 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 (}(hjfhhhNhNubj)}(h **status**h]hstatus}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfubh >= 0).}(hjfhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMD hjcubah}(h]h ]h"]h$]h&]uh1j5hjGubeh}(h]h ]h"]h$]h&]uh1jhjbhMI 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.hhMK 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.hhMK hj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_$cfg80211_connect_result (C function)c.cfg80211_connect_resulthNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hvoid cfg80211_connect_result (struct net_device *dev, const u8 *bssid, const u8 *req_ie, size_t req_ie_len, const u8 *resp_ie, size_t resp_ie_len, u16 status, gfp_t gfp)h]jo)}(hvoid cfg80211_connect_result(struct net_device *dev, const u8 *bssid, const u8 *req_ie, size_t req_ie_len, const u8 *resp_ie, size_t resp_ie_len, u16 status, gfp_t gfp)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM| ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM| ubj)}(hcfg80211_connect_resulth]j)}(hcfg80211_connect_resulth]hcfg80211_connect_result}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM| ubj)}(h(struct net_device *dev, const u8 *bssid, const u8 *req_ie, size_t req_ie_len, const u8 *resp_ie, size_t resp_ie_len, u16 status, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj=ubj)}(h h]h }(hjNhhhNhNubah}(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 reftargetjamodnameN classnameNj j )}j ]j)}jj'sbc.cfg80211_connect_resultasbuh1hhj=ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=ubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj=ubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj9ubj)}(hconst u8 *bssidh](ju)}(hjZHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j{c.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hbssidh]hbssid}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj9ubj)}(hconst u8 *req_ieh](ju)}(hjZHh]hconst}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjCmodnameN classnameNj j )}j ]j{c.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjmhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hreq_ieh]hreq_ie}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj9ubj)}(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 classnameNj j )}j ]j{c.cfg80211_connect_resultasbuh1hhjubj)}(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&]noemphjjuh1jhj9ubj)}(hconst u8 *resp_ieh](ju)}(hjZHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j{c.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hj%hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hresp_ieh]hresp_ie}(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj9ubj)}(hsize_t resp_ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjPmodnameN classnameNj j )}j ]j{c.cfg80211_connect_resultasbuh1hhjGubj)}(h h]h }(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGubj)}(h resp_ie_lenh]h resp_ie_len}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj9ubj)}(h u16 statush](h)}(hhh]j)}(hu16h]hu16}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j{c.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hstatush]hstatus}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj9ubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j{c.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj9ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM| ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM| ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM| hjhhubj)}(hhh]h)}(h$notify cfg80211 of connection resulth]h$notify cfg80211 of connection result}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMi hj1hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM| ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjLjjLjjjuh1jchhhj$bhNhNubj)}(hX**Parameters** ``struct net_device *dev`` network device ``const u8 *bssid`` the BSSID of the AP ``const u8 *req_ie`` association request IEs (maybe be ``NULL``) ``size_t req_ie_len`` association request IEs length ``const u8 *resp_ie`` association response IEs (may be ``NULL``) ``size_t resp_ie_len`` assoc response IEs length ``u16 status`` status code, ``WLAN_STATUS_SUCCESS`` for successful connection, use ``WLAN_STATUS_UNSPECIFIED_FAILURE`` if your device cannot give you the real status code for failures. ``gfp_t gfp`` allocation flags **Description** It should be called by the underlying driver once execution of the connection request from connect() has been completed. This is similar to cfg80211_connect_bss() which allows the exact bss entry to be specified. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.h](h)}(h**Parameters**h]j)}(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.hhMm hjPubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hjuh]hstruct net_device *dev}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMk hjoubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMk hjubah}(h]h ]h"]h$]h&]uh1j5hjoubeh}(h]h ]h"]h$]h&]uh1jhjhMk hjlubj)}(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.hhMl hjubj6)}(hhh]h)}(hthe BSSID of the APh]hthe BSSID of the AP}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMl hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMl hjlubj)}(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.hhMm 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&]uh1hhjhMm hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMm hjlubj)}(h5``size_t req_ie_len`` association request IEs length h](j)}(h``size_t req_ie_len``h]j)}(hj2h]hsize_t req_ie_len}(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.hhMn hj,ubj6)}(hhh]h)}(hassociation request IEs lengthh]hassociation request IEs length}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjGhMn hjHubah}(h]h ]h"]h$]h&]uh1j5hj,ubeh}(h]h ]h"]h$]h&]uh1jhjGhMn hjlubj)}(hA``const u8 *resp_ie`` association response IEs (may be ``NULL``) h](j)}(h``const u8 *resp_ie``h]j)}(hjkh]hconst u8 *resp_ie}(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.hhMo hjeubj6)}(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&]uh1hhjhMo hjubah}(h]h ]h"]h$]h&]uh1j5hjeubeh}(h]h ]h"]h$]h&]uh1jhjhMo hjlubj)}(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.hhMp hjubj6)}(hhh]h)}(hassoc response IEs lengthh]hassoc response IEs length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMp hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMp hjlubj)}(h``u16 status`` status code, ``WLAN_STATUS_SUCCESS`` for successful connection, use ``WLAN_STATUS_UNSPECIFIED_FAILURE`` if your device cannot give you the real status code for failures. h](j)}(h``u16 status``h]j)}(hjh]h u16 status}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMs hjubj6)}(hhh]h)}(hstatus code, ``WLAN_STATUS_SUCCESS`` for successful connection, use ``WLAN_STATUS_UNSPECIFIED_FAILURE`` if your device cannot give you the real status code for failures.h](h status code, }(hjhhhNhNubj)}(h``WLAN_STATUS_SUCCESS``h]hWLAN_STATUS_SUCCESS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh for successful connection, use }(hjhhhNhNubj)}(h#``WLAN_STATUS_UNSPECIFIED_FAILURE``h]hWLAN_STATUS_UNSPECIFIED_FAILURE}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhB if your device cannot give you the real status code for failures.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMq hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMs hjlubj)}(h``gfp_t gfp`` allocation flags h](j)}(h ``gfp_t gfp``h]j)}(hjMh]h gfp_t gfp}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMt hjGubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbhMt hjcubah}(h]h ]h"]h$]h&]uh1j5hjGubeh}(h]h ]h"]h$]h&]uh1jhjbhMt hjlubeh}(h]h ]h"]h$]h&]uh1jhjPubh)}(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.hhMv hjPubh)}(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.hhMv hjPubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_%cfg80211_connect_timeout (C function)c.cfg80211_connect_timeouthNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hvoid cfg80211_connect_timeout (struct net_device *dev, const u8 *bssid, const u8 *req_ie, size_t req_ie_len, gfp_t gfp, enum nl80211_timeout_reason timeout_reason)h]jo)}(hvoid cfg80211_connect_timeout(struct net_device *dev, const u8 *bssid, const u8 *req_ie, size_t req_ie_len, gfp_t gfp, enum nl80211_timeout_reason timeout_reason)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(hcfg80211_connect_timeouth]j)}(hcfg80211_connect_timeouth]hcfg80211_connect_timeout}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubj)}(h(struct net_device *dev, const u8 *bssid, const u8 *req_ie, size_t req_ie_len, gfp_t gfp, enum nl80211_timeout_reason timeout_reason)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(h net_deviceh]h net_device}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj*modnameN classnameNj j )}j ]j)}jjsbc.cfg80211_connect_timeoutasbuh1hhjubj)}(h h]h }(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjVhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hdevh]hdev}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *bssidh](ju)}(hjZHh]hconst}(hj|hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjxubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jDc.cfg80211_connect_timeoutasbuh1hhjxubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjxubj)}(hbssidh]hbssid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst u8 *req_ieh](ju)}(hjZHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNj j )}j ]jDc.cfg80211_connect_timeoutasbuh1hhjubj)}(h h]h }(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hj6hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hreq_ieh]hreq_ie}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hsize_t req_ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjamodnameN classnameNj j )}j ]jDc.cfg80211_connect_timeoutasbuh1hhjXubj)}(h h]h }(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubj)}(h req_ie_lenh]h req_ie_len}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jDc.cfg80211_connect_timeoutasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h*enum nl80211_timeout_reason timeout_reasonh](ju)}(hjxh]henum}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hnl80211_timeout_reasonh]hnl80211_timeout_reason}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNj j )}j ]jDc.cfg80211_connect_timeoutasbuh1hhjubj)}(h h]h }(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(htimeout_reasonh]htimeout_reason}(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhM hjhhubj)}(hhh]h)}(h%notify cfg80211 of connection timeouth]h%notify cfg80211 of connection timeout}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj]hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjxjjxjjjuh1jchhhj$bhNhNubj)}(hXG**Parameters** ``struct net_device *dev`` network device ``const u8 *bssid`` the BSSID of the AP ``const u8 *req_ie`` association request IEs (maybe be ``NULL``) ``size_t req_ie_len`` association request IEs length ``gfp_t gfp`` allocation flags ``enum nl80211_timeout_reason timeout_reason`` reason for connection timeout. **Description** It should be called by the underlying driver whenever connect() has failed in a sequence where no explicit authentication/association rejection was received from the AP. This could happen, e.g., due to not being able to send out the Authentication or Association Request frame or timing out while waiting for the response. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.h](h)}(h**Parameters**h]j)}(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 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&]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&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(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 hj ubj6)}(hhh]h)}(h+association request IEs (maybe be ``NULL``)h](h"association request IEs (maybe be }(hj,hhhNhNubj)}(h``NULL``h]hNULL}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,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(hM hjubj)}(h5``size_t req_ie_len`` association request IEs length h](j)}(h``size_t req_ie_len``h]j)}(hj^h]hsize_t req_ie_len}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjXubj6)}(hhh]h)}(hassociation request IEs lengthh]hassociation request IEs length}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjshM hjtubah}(h]h ]h"]h$]h&]uh1j5hjXubeh}(h]h ]h"]h$]h&]uh1jhjshM 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.}(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&]uh1jhj|ubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj|ubh)}(hXIt should be called by the underlying driver 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.}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj|ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_roamed (C function)c.cfg80211_roamedhNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hYvoid cfg80211_roamed (struct net_device *dev, struct cfg80211_roam_info *info, gfp_t gfp)h]jo)}(hXvoid cfg80211_roamed(struct net_device *dev, struct cfg80211_roam_info *info, gfp_t gfp)h](j)}(hvoidh]hvoid}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLhhh`/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&]uh1jhjLhhhj^hM ubj)}(hcfg80211_roamedh]j)}(hcfg80211_roamedh]hcfg80211_roamed}(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjmubah}(h]h ](jjeh"]h$]h&]jjuh1jhjLhhhj^hM ubj)}(hD(struct net_device *dev, struct cfg80211_roam_info *info, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}jjssbc.cfg80211_roamedasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct cfg80211_roam_info *infoh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hcfg80211_roam_infoh]hcfg80211_roam_info}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_roamedasbuh1hhjubj)}(h h]h }(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjIhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hinfoh]hinfo}(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjrhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjtmodnameN classnameNj j )}j ]jc.cfg80211_roamedasbuh1hhjkubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjkubj)}(hgfph]hgfp}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjkubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjLhhhj^hM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjHhhhj^hM ubah}(h]jCah ](jjeh"]h$]h&]jj)jhuh1jhhj^hM hjEhhubj)}(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 hjhhubah}(h]h ]h"]h$]h&]uh1jhjEhhhj^hM ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhj$bhNhNubj)}(hX**Parameters** ``struct net_device *dev`` network device ``struct cfg80211_roam_info *info`` information about the new BSS. struct :c:type:`cfg80211_roam_info`. ``gfp_t gfp`` allocation flags **Description** This function may be called with the driver passing either the BSSID of the new AP or passing the bss entry to avoid a race in timeout of the bss entry. It should be called by the underlying driver whenever it roamed from one AP to another while connected. Drivers which have roaming implemented in firmware should pass the bss entry to avoid a race in bss entry timeout where the bss entry of the new AP is seen in the driver, but gets timed out by the time it is accessed in __cfg80211_roamed() due to delay in scheduling rdev->event_work. In case of any failures, the reference is released either in cfg80211_roamed() or in __cfg80211_romed(), Otherwise, it will be released while disconnecting from the current bss.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hj h]hstruct net_device *dev}(hj hhhNhNubah}(h]h ]h"]h$]h&]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}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hh``struct cfg80211_roam_info *info`` information about the new BSS. struct :c:type:`cfg80211_roam_info`. h](j)}(h#``struct cfg80211_roam_info *info``h]j)}(hjBh]hstruct cfg80211_roam_info *info}(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)}(hCinformation about the new BSS. struct :c:type:`cfg80211_roam_info`.h](h&information about the new BSS. struct }(hj[hhhNhNubh)}(h:c:type:`cfg80211_roam_info`h]j)}(hjeh]hcfg80211_roam_info}(hjghhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6cfg80211_roam_infouh1hhjWhM hj[ubh.}(hj[hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjWhM hjXubah}(h]h ]h"]h$]h&]uh1j5hj<ubeh}(h]h ]h"]h$]h&]uh1jhjWhM 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)}(hXThis function may be called with the driver passing either the BSSID of the new AP or passing the bss entry to avoid a race in timeout of the bss entry. It should be called by the underlying driver whenever it roamed from one AP to another while connected. Drivers which have roaming implemented in firmware should pass the bss entry to avoid a race in bss entry timeout where the bss entry of the new AP is seen in the driver, but gets timed out by the time it is accessed in __cfg80211_roamed() due to delay in scheduling rdev->event_work. In case of any failures, the reference is released either in cfg80211_roamed() or in __cfg80211_romed(), Otherwise, it will be released while disconnecting from the current bss.h]hXThis function may be called with the driver passing either the BSSID of the new AP or passing the bss entry to avoid a race in timeout of the bss entry. It should be called by the underlying driver whenever it roamed from one AP to another while connected. Drivers which have roaming implemented in firmware should pass the bss entry to avoid a race in bss entry timeout where the bss entry of the new AP is seen in the driver, but gets timed out by the time it is accessed in __cfg80211_roamed() due to delay in scheduling rdev->event_work. In case of any failures, the reference is released either in cfg80211_roamed() or in __cfg80211_romed(), Otherwise, it will be released while disconnecting from the current bss.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"cfg80211_disconnected (C function)c.cfg80211_disconnectedhNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hvoid cfg80211_disconnected (struct net_device *dev, u16 reason, const u8 *ie, size_t ie_len, bool locally_generated, gfp_t gfp)h]jo)}(h~void cfg80211_disconnected(struct net_device *dev, u16 reason, const u8 *ie, size_t ie_len, bool locally_generated, gfp_t gfp)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!ubj)}(h h]h }(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhj,hM!ubj)}(hcfg80211_disconnectedh]j)}(hcfg80211_disconnectedh]hcfg80211_disconnected}(hj?hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj;ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhj,hM!ubj)}(hd(struct net_device *dev, u16 reason, const u8 *ie, size_t ie_len, bool locally_generated, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjWubj)}(h h]h }(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjWubh)}(hhh]j)}(h net_deviceh]h net_device}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj{modnameN classnameNj j )}j ]j)}jjAsbc.cfg80211_disconnectedasbuh1hhjWubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjWubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjWubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjWubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjSubj)}(h u16 reasonh](h)}(hhh]j)}(hu16h]hu16}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_disconnectedasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hreasonh]hreason}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjSubj)}(h const u8 *ieh](ju)}(hjZHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj5modnameN classnameNj j )}j ]jc.cfg80211_disconnectedasbuh1hhjubj)}(h h]h }(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hj_hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hieh]hie}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjSubj)}(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 classnameNj j )}j ]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&]noemphjjuh1jhjSubj)}(hbool locally_generatedh](j)}(hjUh]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hlocally_generatedh]hlocally_generated}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjSubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_disconnectedasbuh1hhjubj)}(h h]h }(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjSubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhj,hM!ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhj,hM!ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhj,hM!hjhhubj)}(hhh]h)}(h+notify cfg80211 that connection was droppedh]h+notify cfg80211 that connection was dropped}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjWhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj,hM!ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjrjjrjjjuh1jchhhj$bhNhNubj)}(hX**Parameters** ``struct net_device *dev`` network device ``u16 reason`` reason code for the disconnection, set it to 0 if unknown ``const u8 *ie`` information elements of the deauth/disassoc frame (may be ``NULL``) ``size_t ie_len`` length of IEs ``bool locally_generated`` disconnection was requested locally ``gfp_t gfp`` allocation flags **Description** After it calls this function, the driver should enter an idle state and not try to connect to any AP any more.h](h)}(h**Parameters**h]j)}(hj|h]h Parameters}(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.hhM hjvubj)}(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)}(hI``u16 reason`` reason code for the disconnection, set it to 0 if unknown h](j)}(h``u16 reason``h]j)}(hjh]h u16 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)}(h9reason code for the disconnection, set it to 0 if unknownh]h9reason code for the disconnection, set it to 0 if unknown}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(hU``const u8 *ie`` information elements of the deauth/disassoc frame (may be ``NULL``) h](j)}(h``const u8 *ie``h]j)}(hj h]h const u8 *ie}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj6)}(hhh]h)}(hCinformation elements of the deauth/disassoc frame (may be ``NULL``)h](h:information elements of the deauth/disassoc frame (may be }(hj&hhhNhNubj)}(h``NULL``h]hNULL}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubh)}(hj&hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj"hM hj#ubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj"hM hjubj)}(h ``size_t ie_len`` length of IEs h](j)}(h``size_t ie_len``h]j)}(hjXh]h size_t ie_len}(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)}(h length of IEsh]h length of IEs}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmhM hjnubah}(h]h ]h"]h$]h&]uh1j5hjRubeh}(h]h ]h"]h$]h&]uh1jhjmhM hjubj)}(h?``bool locally_generated`` disconnection was requested locally h](j)}(h``bool locally_generated``h]j)}(hjh]hbool locally_generated}(hjhhhNhNubah}(h]h ]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#disconnection was requested locallyh]h#disconnection was requested locally}(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 hjubeh}(h]h ]h"]h$]h&]uh1jhjvubh)}(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 hjvubh)}(hnAfter it calls this function, the driver should enter an idle state and not try to connect to any AP any more.h]hnAfter it calls this function, the driver should enter an idle state and not try to connect to any AP any more.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjvubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_&cfg80211_ready_on_channel (C function)c.cfg80211_ready_on_channelhNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hvoid cfg80211_ready_on_channel (struct wireless_dev *wdev, u64 cookie, struct ieee80211_channel *chan, unsigned int duration, gfp_t gfp)h]jo)}(hvoid cfg80211_ready_on_channel(struct wireless_dev *wdev, u64 cookie, struct ieee80211_channel *chan, unsigned int duration, gfp_t gfp)h](j)}(hvoidh]hvoid}(hjJ hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjF hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!ubj)}(h h]h }(hjY hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjF hhhjX hM!ubj)}(hcfg80211_ready_on_channelh]j)}(hcfg80211_ready_on_channelh]hcfg80211_ready_on_channel}(hjk hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjg ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjF hhhjX hM!ubj)}(hi(struct wireless_dev *wdev, u64 cookie, struct ieee80211_channel *chan, unsigned int duration, gfp_t gfp)h](j)}(hstruct wireless_dev *wdevh](ju)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(h wireless_devh]h wireless_dev}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNj j )}j ]j)}jjm sbc.cfg80211_ready_on_channelasbuh1hhj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj.)}(hj1h]h*}(hj hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj ubj)}(hwdevh]hwdev}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h u64 cookieh](h)}(hhh]j)}(hu64h]hu64}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj modnameN classnameNj j )}j ]j c.cfg80211_ready_on_channelasbuh1hhj ubj)}(h h]h }(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(hcookieh]hcookie}(hj(!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hstruct ieee80211_channel *chanh](ju)}(hjh]hstruct}(hjA!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj=!ubj)}(h h]h }(hjN!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 reftargetja!modnameN classnameNj j )}j ]j c.cfg80211_ready_on_channelasbuh1hhj=!ubj)}(h h]h }(hj}!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=!ubj.)}(hj1h]h*}(hj!hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj=!ubj)}(hchanh]hchan}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=!ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hunsigned int durationh](j)}(hunsignedh]hunsigned}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubj)}(h h]h }(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubj)}(hinth]hint}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubj)}(h h]h }(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubj)}(hdurationh]hduration}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj"modnameN classnameNj j )}j ]j c.cfg80211_ready_on_channelasbuh1hhj!ubj)}(h h]h }(hj#"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubj)}(hgfph]hgfp}(hj1"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubeh}(h]h ]h"]h$]h&]jjuh1jhjF hhhjX hM!ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjB hhhjX hM!ubah}(h]j= ah ](jjeh"]h$]h&]jj)jhuh1jhhjX hM!hj? hhubj)}(hhh]h)}(h'notification of remain_on_channel starth]h'notification of remain_on_channel start}(hj["hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjX"hhubah}(h]h ]h"]h$]h&]uh1jhj? hhhjX hM!ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjs"jjs"jjjuh1jchhhj$bhNhNubj)}(hXJ**Parameters** ``struct wireless_dev *wdev`` wireless device ``u64 cookie`` the request cookie ``struct ieee80211_channel *chan`` The current channel (from remain_on_channel request) ``unsigned int duration`` Duration in milliseconds that the driver intents to remain on the channel ``gfp_t gfp`` allocation flagsh](h)}(h**Parameters**h]j)}(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 !hjw"ubj)}(hhh](j)}(h.``struct wireless_dev *wdev`` wireless device h](j)}(h``struct wireless_dev *wdev``h]j)}(hj"h]hstruct wireless_dev *wdev}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj"ubj6)}(hhh]h)}(hwireless deviceh]hwireless device}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hM!hj"ubah}(h]h ]h"]h$]h&]uh1j5hj"ubeh}(h]h ]h"]h$]h&]uh1jhj"hM!hj"ubj)}(h"``u64 cookie`` the request cookie h](j)}(h``u64 cookie``h]j)}(hj"h]h u64 cookie}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM !hj"ubj6)}(hhh]h)}(hthe request cookieh]hthe request cookie}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hM !hj"ubah}(h]h ]h"]h$]h&]uh1j5hj"ubeh}(h]h ]h"]h$]h&]uh1jhj"hM !hj"ubj)}(hX``struct ieee80211_channel *chan`` The current channel (from remain_on_channel request) h](j)}(h"``struct ieee80211_channel *chan``h]j)}(hj#h]hstruct ieee80211_channel *chan}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj #ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM !hj#ubj6)}(hhh]h)}(h4The current channel (from remain_on_channel request)h]h4The current channel (from remain_on_channel request)}(hj'#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj##hM !hj$#ubah}(h]h ]h"]h$]h&]uh1j5hj#ubeh}(h]h ]h"]h$]h&]uh1jhj##hM !hj"ubj)}(hd``unsigned int duration`` Duration in milliseconds that the driver intents to remain on the channel h](j)}(h``unsigned int duration``h]j)}(hjG#h]hunsigned int duration}(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:48: ./include/net/cfg80211.hhM !hjA#ubj6)}(hhh]h)}(hIDuration in milliseconds that the driver intents to remain on the channelh]hIDuration in milliseconds that the driver intents to remain on the channel}(hj`#hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM !hj]#ubah}(h]h ]h"]h$]h&]uh1j5hjA#ubeh}(h]h ]h"]h$]h&]uh1jhj\#hM !hj"ubj)}(h``gfp_t gfp`` allocation flagsh](j)}(h ``gfp_t gfp``h]j)}(hj#h]h gfp_t gfp}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!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&]uh1jhjw"ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_/cfg80211_remain_on_channel_expired (C function)$c.cfg80211_remain_on_channel_expiredhNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hzvoid cfg80211_remain_on_channel_expired (struct wireless_dev *wdev, u64 cookie, struct ieee80211_channel *chan, gfp_t gfp)h]jo)}(hyvoid cfg80211_remain_on_channel_expired(struct wireless_dev *wdev, u64 cookie, struct ieee80211_channel *chan, gfp_t gfp)h](j)}(hvoidh]hvoid}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!ubj)}(h h]h }(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#hhhj#hM!ubj)}(h"cfg80211_remain_on_channel_expiredh]j)}(h"cfg80211_remain_on_channel_expiredh]h"cfg80211_remain_on_channel_expired}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj#hhhj#hM!ubj)}(hR(struct wireless_dev *wdev, u64 cookie, struct ieee80211_channel *chan, gfp_t gfp)h](j)}(hstruct wireless_dev *wdevh](ju)}(hjh]hstruct}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj$ubj)}(h h]h }(hj%$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubh)}(hhh]j)}(h wireless_devh]h wireless_dev}(hj6$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3$ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj8$modnameN classnameNj j )}j ]j)}jj#sb$c.cfg80211_remain_on_channel_expiredasbuh1hhj$ubj)}(h h]h }(hjV$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubj.)}(hj1h]h*}(hjd$hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj$ubj)}(hwdevh]hwdev}(hjq$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj$ubj)}(h u64 cookieh](h)}(hhh]j)}(hu64h]hu64}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj$modnameN classnameNj j )}j ]jR$$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&]noemphjjuh1jhj$ubj)}(hstruct ieee80211_channel *chanh](ju)}(hjh]hstruct}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj$ubj)}(h h]h }(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubh)}(hhh]j)}(hieee80211_channelh]hieee80211_channel}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj$modnameN classnameNj j )}j ]jR$$c.cfg80211_remain_on_channel_expiredasbuh1hhj$ubj)}(h h]h }(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubj.)}(hj1h]h*}(hj%hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj$ubj)}(hchanh]hchan}(hj)%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj$ubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjE%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjB%ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjG%modnameN classnameNj j )}j ]jR$$c.cfg80211_remain_on_channel_expiredasbuh1hhj>%ubj)}(h h]h }(hjc%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>%ubj)}(hgfph]hgfp}(hjq%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>%ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj$ubeh}(h]h ]h"]h$]h&]jjuh1jhj#hhhj#hM!ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj#hhhj#hM!ubah}(h]j#ah ](jjeh"]h$]h&]jj)jhuh1jhhj#hM!hj#hhubj)}(hhh]h)}(h"remain_on_channel duration expiredh]h"remain_on_channel duration expired}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj%hhubah}(h]h ]h"]h$]h&]uh1jhj#hhhj#hM!ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj%jj%jjjuh1jchhhj$bhNhNubj)}(h**Parameters** ``struct wireless_dev *wdev`` wireless device ``u64 cookie`` the request cookie ``struct ieee80211_channel *chan`` The current channel (from remain_on_channel request) ``gfp_t gfp`` allocation flagsh](h)}(h**Parameters**h]j)}(hj%h]h Parameters}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj%ubj)}(hhh](j)}(h.``struct wireless_dev *wdev`` wireless device h](j)}(h``struct wireless_dev *wdev``h]j)}(hj%h]hstruct wireless_dev *wdev}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj%ubj6)}(hhh]h)}(hwireless deviceh]hwireless device}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%hM!hj%ubah}(h]h ]h"]h$]h&]uh1j5hj%ubeh}(h]h ]h"]h$]h&]uh1jhj%hM!hj%ubj)}(h"``u64 cookie`` the request cookie h](j)}(h``u64 cookie``h]j)}(hj&h]h u64 cookie}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj&ubj6)}(hhh]h)}(hthe request cookieh]hthe request cookie}(hj.&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*&hM!hj+&ubah}(h]h ]h"]h$]h&]uh1j5hj&ubeh}(h]h ]h"]h$]h&]uh1jhj*&hM!hj%ubj)}(hX``struct ieee80211_channel *chan`` The current channel (from remain_on_channel request) h](j)}(h"``struct ieee80211_channel *chan``h]j)}(hjN&h]hstruct ieee80211_channel *chan}(hjP&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjL&ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjH&ubj6)}(hhh]h)}(h4The current channel (from remain_on_channel request)h]h4The current channel (from remain_on_channel request)}(hjg&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjc&hM!hjd&ubah}(h]h ]h"]h$]h&]uh1j5hjH&ubeh}(h]h ]h"]h$]h&]uh1jhjc&hM!hj%ubj)}(h``gfp_t gfp`` allocation flagsh](j)}(h ``gfp_t gfp``h]j)}(hj&h]h gfp_t gfp}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!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&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_new_sta (C function)c.cfg80211_new_stahNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hivoid cfg80211_new_sta (struct net_device *dev, const u8 *mac_addr, struct station_info *sinfo, gfp_t gfp)h]jo)}(hhvoid cfg80211_new_sta(struct net_device *dev, const u8 *mac_addr, struct station_info *sinfo, gfp_t gfp)h](j)}(hvoidh]hvoid}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMG!ubj)}(h h]h }(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&hhhj&hMG!ubj)}(hcfg80211_new_stah]j)}(hcfg80211_new_stah]hcfg80211_new_sta}(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj&hhhj&hMG!ubj)}(hS(struct net_device *dev, const u8 *mac_addr, struct station_info *sinfo, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj'ubj)}(h h]h }(hj+'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubh)}(hhh]j)}(h net_deviceh]h net_device}(hj<'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj9'ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj>'modnameN classnameNj j )}j ]j)}jj'sbc.cfg80211_new_staasbuh1hhj'ubj)}(h h]h }(hj\'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubj.)}(hj1h]h*}(hjj'hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj'ubj)}(hdevh]hdev}(hjw'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj'ubj)}(hconst u8 *mac_addrh](ju)}(hjZHh]hconst}(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj'ubj)}(h h]h }(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubh)}(hhh]j)}(hu8h]hu8}(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj'modnameN classnameNj j )}j ]jX'c.cfg80211_new_staasbuh1hhj'ubj)}(h h]h }(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubj.)}(hj1h]h*}(hj'hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj'ubj)}(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)}(hjh]hstruct}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj'ubj)}(h h]h }(hj (hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubh)}(hhh]j)}(h station_infoh]h station_info}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj (modnameN classnameNj j )}j ]jX'c.cfg80211_new_staasbuh1hhj'ubj)}(h h]h }(hj<(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubj.)}(hj1h]h*}(hjJ(hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj'ubj)}(hsinfoh]hsinfo}(hjW(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}(hjs(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjp(ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetju(modnameN classnameNj j )}j ]jX'c.cfg80211_new_staasbuh1hhjl(ubj)}(h h]h }(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjl(ubj)}(hgfph]hgfp}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjl(ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj'ubeh}(h]h ]h"]h$]h&]jjuh1jhj&hhhj&hMG!ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj&hhhj&hMG!ubah}(h]j&ah ](jjeh"]h$]h&]jj)jhuh1jhhj&hMG!hj&hhubj)}(hhh]h)}(hnotify userspace about stationh]hnotify userspace about station}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM@!hj(hhubah}(h]h ]h"]h$]h&]uh1jhj&hhhj&hMG!ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj(jj(jjjuh1jchhhj$bhNhNubj)}(h**Parameters** ``struct net_device *dev`` the netdev ``const u8 *mac_addr`` the station's address ``struct station_info *sinfo`` the station information ``gfp_t gfp`` allocation flagsh](h)}(h**Parameters**h]j)}(hj(h]h Parameters}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj(ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMD!hj(ubj)}(hhh](j)}(h&``struct net_device *dev`` the netdev h](j)}(h``struct net_device *dev``h]j)}(hj )h]hstruct net_device *dev}(hj )hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMB!hj)ubj6)}(hhh]h)}(h the netdevh]h the netdev}(hj#)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj)hMB!hj )ubah}(h]h ]h"]h$]h&]uh1j5hj)ubeh}(h]h ]h"]h$]h&]uh1jhj)hMB!hj)ubj)}(h-``const u8 *mac_addr`` the station's address h](j)}(h``const u8 *mac_addr``h]j)}(hjC)h]hconst u8 *mac_addr}(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:48: ./include/net/cfg80211.hhMC!hj=)ubj6)}(hhh]h)}(hthe station's addressh]hthe station’s address}(hj\)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjX)hMC!hjY)ubah}(h]h ]h"]h$]h&]uh1j5hj=)ubeh}(h]h ]h"]h$]h&]uh1jhjX)hMC!hj)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&]uh1jhjz)ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMD!hjv)ubj6)}(hhh]h)}(hthe station informationh]hthe station information}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj)hMD!hj)ubah}(h]h ]h"]h$]h&]uh1j5hjv)ubeh}(h]h ]h"]h$]h&]uh1jhj)hMD!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.hhMF!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.hhME!hj)ubah}(h]h ]h"]h$]h&]uh1j5hj)ubeh}(h]h ]h"]h$]h&]uh1jhj)hMF!hj)ubeh}(h]h ]h"]h$]h&]uh1jhj(ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_rx_mgmt (C function)c.cfg80211_rx_mgmthNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hnbool cfg80211_rx_mgmt (struct wireless_dev *wdev, int freq, int sig_dbm, const u8 *buf, size_t len, u32 flags)h]jo)}(hmbool cfg80211_rx_mgmt(struct wireless_dev *wdev, int freq, int sig_dbm, const u8 *buf, size_t len, u32 flags)h](j)}(hjUh]hbool}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj *hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!ubj)}(h h]h }(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj *hhhj*hM!ubj)}(hcfg80211_rx_mgmth]j)}(hcfg80211_rx_mgmth]hcfg80211_rx_mgmt}(hj/*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+*ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj *hhhj*hM!ubj)}(hX(struct wireless_dev *wdev, int freq, int sig_dbm, const u8 *buf, size_t len, u32 flags)h](j)}(hstruct wireless_dev *wdevh](ju)}(hjh]hstruct}(hjK*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjG*ubj)}(h h]h }(hjX*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjG*ubh)}(hhh]j)}(h wireless_devh]h wireless_dev}(hji*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjf*ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjk*modnameN classnameNj j )}j ]j)}jj1*sbc.cfg80211_rx_mgmtasbuh1hhjG*ubj)}(h h]h }(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjG*ubj.)}(hj1h]h*}(hj*hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjG*ubj)}(hwdevh]hwdev}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjG*ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjC*ubj)}(hint freqh](j)}(hinth]hint}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj*ubj)}(h h]h }(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj*ubj)}(hfreqh]hfreq}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj*ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjC*ubj)}(h int sig_dbmh](j)}(hinth]hint}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj*ubj)}(h h]h }(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj*ubj)}(hsig_dbmh]hsig_dbm}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj*ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjC*ubj)}(h const u8 *bufh](ju)}(hjZHh]hconst}(hj'+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj#+ubj)}(h h]h }(hj4+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#+ubh)}(hhh]j)}(hu8h]hu8}(hjE+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjB+ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjG+modnameN classnameNj j )}j ]j*c.cfg80211_rx_mgmtasbuh1hhj#+ubj)}(h h]h }(hjc+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#+ubj.)}(hj1h]h*}(hjq+hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj#+ubj)}(hbufh]hbuf}(hj~+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#+ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjC*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 classnameNj j )}j ]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&]noemphjjuh1jhjC*ubj)}(h u32 flagsh](h)}(hhh]j)}(hu32h]hu32}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj+modnameN classnameNj j )}j ]j*c.cfg80211_rx_mgmtasbuh1hhj+ubj)}(h h]h }(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+ubj)}(hflagsh]hflags}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjC*ubeh}(h]h ]h"]h$]h&]jjuh1jhj *hhhj*hM!ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj*hhhj*hM!ubah}(h]j*ah ](jjeh"]h$]h&]jj)jhuh1jhhj*hM!hj*hhubj)}(hhh]h)}(h6notification of received, unprocessed management frameh]h6notification of received, unprocessed management frame}(hj8,hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj5,hhubah}(h]h ]h"]h$]h&]uh1jhj*hhhj*hM!ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjP,jjP,jjjuh1jchhhj$bhNhNubj)}(hX **Parameters** ``struct wireless_dev *wdev`` wireless device receiving the frame ``int freq`` Frequency on which the frame was received in MHz ``int sig_dbm`` signal strength in dBm, or 0 if unknown ``const u8 *buf`` Management frame (header + body) ``size_t len`` length of the frame data ``u32 flags`` flags, as defined in enum nl80211_rxmgmt_flags **Description** This function is called whenever an Action frame is received for a station mode interface, but is not processed in kernel. **Return** ``true`` if a user space application has registered for this frame. For action frames, that makes it responsible for rejecting unrecognized action frames; ``false`` otherwise, in which case for action frames the driver is responsible for rejecting the frame.h](h)}(h**Parameters**h]j)}(hjZ,h]h Parameters}(hj\,hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjX,ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjT,ubj)}(hhh](j)}(hB``struct wireless_dev *wdev`` wireless device receiving the frame h](j)}(h``struct wireless_dev *wdev``h]j)}(hjy,h]hstruct wireless_dev *wdev}(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.hhM!hjs,ubj6)}(hhh]h)}(h#wireless device receiving the frameh]h#wireless device receiving the frame}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,hM!hj,ubah}(h]h ]h"]h$]h&]uh1j5hjs,ubeh}(h]h ]h"]h$]h&]uh1jhj,hM!hjp,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.hhM!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,hM!hj,ubah}(h]h ]h"]h$]h&]uh1j5hj,ubeh}(h]h ]h"]h$]h&]uh1jhj,hM!hjp,ubj)}(h8``int sig_dbm`` signal strength in dBm, or 0 if unknown h](j)}(h``int sig_dbm``h]j)}(hj,h]h int sig_dbm}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj,ubj6)}(hhh]h)}(h'signal strength in dBm, or 0 if unknownh]h'signal strength in dBm, or 0 if unknown}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-hM!hj-ubah}(h]h ]h"]h$]h&]uh1j5hj,ubeh}(h]h ]h"]h$]h&]uh1jhj-hM!hjp,ubj)}(h3``const u8 *buf`` Management frame (header + body) h](j)}(h``const u8 *buf``h]j)}(hj$-h]h const u8 *buf}(hj&-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"-ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj-ubj6)}(hhh]h)}(h Management frame (header + body)h]h Management frame (header + body)}(hj=-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9-hM!hj:-ubah}(h]h ]h"]h$]h&]uh1j5hj-ubeh}(h]h ]h"]h$]h&]uh1jhj9-hM!hjp,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.hhM!hjW-ubj6)}(hhh]h)}(hlength of the frame datah]hlength of the frame data}(hjv-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjr-hM!hjs-ubah}(h]h ]h"]h$]h&]uh1j5hjW-ubeh}(h]h ]h"]h$]h&]uh1jhjr-hM!hjp,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!hjp,ubeh}(h]h ]h"]h$]h&]uh1jhjT,ubh)}(h**Description**h]j)}(hj-h]h Description}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjT,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-hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjT,ubh)}(h **Return**h]j)}(hj-h]hReturn}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjT,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}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubh if a user space application has registered for this frame. For action frames, that makes it responsible for rejecting unrecognized action frames; }(hj.hhhNhNubj)}(h ``false``h]hfalse}(hj$.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubh^ otherwise, in which case for action frames the driver is responsible for rejecting the frame.}(hj.hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjT,ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_$cfg80211_mgmt_tx_status (C function)c.cfg80211_mgmt_tx_statushNtauh1jRhj$bhhhNhNubjd)}(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}(hj].hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjY.hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM "ubj)}(h h]h }(hjl.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjY.hhhjk.hM "ubj)}(hcfg80211_mgmt_tx_statush]j)}(hcfg80211_mgmt_tx_statush]hcfg80211_mgmt_tx_status}(hj~.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjz.ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjY.hhhjk.hM "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)}(hjh]hstruct}(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj.ubj)}(h h]h }(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.ubh)}(hhh]j)}(h wireless_devh]h wireless_dev}(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj.modnameN classnameNj j )}j ]j)}jj.sbc.cfg80211_mgmt_tx_statusasbuh1hhj.ubj)}(h h]h }(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.ubj.)}(hj1h]h*}(hj.hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj.ubj)}(hwdevh]hwdev}(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.ubj)}(h u64 cookieh](h)}(hhh]j)}(hu64h]hu64}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj /ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj/modnameN classnameNj j )}j ]j.c.cfg80211_mgmt_tx_statusasbuh1hhj/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&]noemphjjuh1jhj.ubj)}(h const u8 *bufh](ju)}(hjZHh]hconst}(hjT/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjP/ubj)}(h h]h }(hja/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjP/ubh)}(hhh]j)}(hu8h]hu8}(hjr/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjo/ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjt/modnameN classnameNj j )}j ]j.c.cfg80211_mgmt_tx_statusasbuh1hhjP/ubj)}(h h]h }(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjP/ubj.)}(hj1h]h*}(hj/hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjP/ubj)}(hbufh]hbuf}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjP/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 classnameNj j )}j ]j.c.cfg80211_mgmt_tx_statusasbuh1hhj/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)}(hbool ackh](j)}(hjUh]hbool}(hj 0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubj)}(h h]h }(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubj)}(hackh]hack}(hj'0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.ubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjC0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@0ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjE0modnameN classnameNj j )}j ]j.c.cfg80211_mgmt_tx_statusasbuh1hhj<0ubj)}(h h]h }(hja0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj<0ubj)}(hgfph]hgfp}(hjo0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj<0ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.ubeh}(h]h ]h"]h$]h&]jjuh1jhjY.hhhjk.hM "ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjU.hhhjk.hM "ubah}(h]jP.ah ](jjeh"]h$]h&]jj)jhuh1jhhjk.hM "hjR.hhubj)}(hhh]h)}(h.notification of TX status for management frameh]h.notification of TX status for management frame}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hj0hhubah}(h]h ]h"]h$]h&]uh1jhjR.hhhjk.hM "ubeh}(h]h ](j$functioneh"]h$]h&]jj$jj0jj0jjjuh1jchhhj$bhNhNubj)}(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)}(hj0h]h Parameters}(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"hj0ubj)}(hhh](j)}(hB``struct wireless_dev *wdev`` wireless device receiving the frame h](j)}(h``struct wireless_dev *wdev``h]j)}(hj0h]hstruct wireless_dev *wdev}(hj0hhhNhNubah}(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"hj0ubj6)}(hhh]h)}(h#wireless device receiving the frameh]h#wireless device receiving the frame}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0hM"hj0ubah}(h]h ]h"]h$]h&]uh1j5hj0ubeh}(h]h ]h"]h$]h&]uh1jhj0hM"hj0ubj)}(h:``u64 cookie`` Cookie returned by cfg80211_ops::mgmt_tx() h](j)}(h``u64 cookie``h]j)}(hj1h]h u64 cookie}(hj1hhhNhNubah}(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 1ubj6)}(hhh]h)}(h*Cookie returned by cfg80211_ops::mgmt_tx()h]h*Cookie returned by cfg80211_ops::mgmt_tx()}(hj,1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj(1hM"hj)1ubah}(h]h ]h"]h$]h&]uh1j5hj 1ubeh}(h]h ]h"]h$]h&]uh1jhj(1hM"hj0ubj)}(h3``const u8 *buf`` Management frame (header + body) h](j)}(h``const u8 *buf``h]j)}(hjL1h]h const u8 *buf}(hjN1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJ1ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjF1ubj6)}(hhh]h)}(h Management frame (header + body)h]h Management frame (header + body)}(hje1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhja1hM"hjb1ubah}(h]h ]h"]h$]h&]uh1j5hjF1ubeh}(h]h ]h"]h$]h&]uh1jhja1hM"hj0ubj)}(h(``size_t len`` length of the frame data h](j)}(h``size_t len``h]j)}(hj1h]h size_t len}(hj1hhhNhNubah}(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"hj1ubj6)}(hhh]h)}(hlength of the frame datah]hlength of the frame data}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1hM"hj1ubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhj1hM"hj0ubj)}(h,``bool ack`` Whether frame was acknowledged h](j)}(h ``bool ack``h]j)}(hj1h]hbool ack}(hj1hhhNhNubah}(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"hj1ubj6)}(hhh]h)}(hWhether frame was acknowledgedh]hWhether frame was acknowledged}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1hM"hj1ubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhj1hM"hj0ubj)}(h``gfp_t gfp`` context flags h](j)}(h ``gfp_t gfp``h]j)}(hj1h]h gfp_t gfp}(hj1hhhNhNubah}(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"hj1ubj6)}(hhh]h)}(h context flagsh]h context flags}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj 2hM"hj 2ubah}(h]h ]h"]h$]h&]uh1j5hj1ubeh}(h]h ]h"]h$]h&]uh1jhj 2hM"hj0ubeh}(h]h ]h"]h$]h&]uh1jhj0ubh)}(h**Description**h]j)}(hj22h]h Description}(hj42hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj02ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj0ubh)}(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.}(hjH2hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj0ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_%cfg80211_cqm_rssi_notify (C function)c.cfg80211_cqm_rssi_notifyhNtauh1jRhj$bhhhNhNubjd)}(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}(hjw2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjs2hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhML"ubj)}(h h]h }(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjs2hhhj2hML"ubj)}(hcfg80211_cqm_rssi_notifyh]j)}(hcfg80211_cqm_rssi_notifyh]hcfg80211_cqm_rssi_notify}(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjs2hhhj2hML"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)}(hjh]hstruct}(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj2ubj)}(h h]h }(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2ubh)}(hhh]j)}(h net_deviceh]h net_device}(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj2modnameN classnameNj j )}j ]j)}jj2sbc.cfg80211_cqm_rssi_notifyasbuh1hhj2ubj)}(h h]h }(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2ubj.)}(hj1h]h*}(hj3hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj2ubj)}(hdevh]hdev}(hj 3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj2ubj)}(h0enum nl80211_cqm_rssi_threshold_event rssi_eventh](ju)}(hjxh]henum}(hj&3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj"3ubj)}(h h]h }(hj33hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"3ubh)}(hhh]j)}(h nl80211_cqm_rssi_threshold_eventh]h nl80211_cqm_rssi_threshold_event}(hjD3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjA3ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjF3modnameN classnameNj j )}j ]j2c.cfg80211_cqm_rssi_notifyasbuh1hhj"3ubj)}(h h]h }(hjb3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"3ubj)}(h rssi_eventh]h rssi_event}(hjp3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"3ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj2ubj)}(hs32 rssi_levelh](h)}(hhh]j)}(hs32h]hs32}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj3modnameN classnameNj j )}j ]j2c.cfg80211_cqm_rssi_notifyasbuh1hhj3ubj)}(h h]h }(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3ubj)}(h rssi_levelh]h rssi_level}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj2ubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj3modnameN classnameNj j )}j ]j2c.cfg80211_cqm_rssi_notifyasbuh1hhj3ubj)}(h h]h }(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3ubj)}(hgfph]hgfp}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj2ubeh}(h]h ]h"]h$]h&]jjuh1jhjs2hhhj2hML"ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjo2hhhj2hML"ubah}(h]jj2ah ](jjeh"]h$]h&]jj)jhuh1jhhj2hML"hjl2hhubj)}(hhh]h)}(h(connection quality monitoring rssi eventh]h(connection quality monitoring rssi event}(hj*4hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMC"hj'4hhubah}(h]h ]h"]h$]h&]uh1jhjl2hhhj2hML"ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjB4jjB4jjjuh1jchhhj$bhNhNubj)}(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)}(hjL4h]h Parameters}(hjN4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJ4ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMG"hjF4ubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hjk4h]hstruct net_device *dev}(hjm4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhji4ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMD"hje4ubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4hMD"hj4ubah}(h]h ]h"]h$]h&]uh1j5hje4ubeh}(h]h ]h"]h$]h&]uh1jhj4hMD"hjb4ubj)}(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)}(hj4h]h0enum nl80211_cqm_rssi_threshold_event rssi_event}(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.hhME"hj4ubj6)}(hhh]h)}(hthe triggered RSSI eventh]hthe triggered RSSI event}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4hME"hj4ubah}(h]h ]h"]h$]h&]uh1j5hj4ubeh}(h]h ]h"]h$]h&]uh1jhj4hME"hjb4ubj)}(h>``s32 rssi_level`` new RSSI level value or 0 if not available h](j)}(h``s32 rssi_level``h]j)}(hj4h]hs32 rssi_level}(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.hhMF"hj4ubj6)}(hhh]h)}(h*new RSSI level value or 0 if not availableh]h*new RSSI level value or 0 if not available}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4hMF"hj4ubah}(h]h ]h"]h$]h&]uh1j5hj4ubeh}(h]h ]h"]h$]h&]uh1jhj4hMF"hjb4ubj)}(h``gfp_t gfp`` context flags h](j)}(h ``gfp_t gfp``h]j)}(hj5h]h gfp_t gfp}(hj5hhhNhNubah}(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.hhMG"hj5ubj6)}(hhh]h)}(h context flagsh]h context flags}(hj/5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj+5hMG"hj,5ubah}(h]h ]h"]h$]h&]uh1j5hj5ubeh}(h]h ]h"]h$]h&]uh1jhj+5hMG"hjb4ubeh}(h]h ]h"]h$]h&]uh1jhjF4ubh)}(h**Description**h]j)}(hjQ5h]h Description}(hjS5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjO5ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMI"hjF4ubh)}(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.}(hjg5hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMI"hjF4ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_(cfg80211_cqm_pktloss_notify (C function)c.cfg80211_cqm_pktloss_notifyhNtauh1jRhj$bhhhNhNubjd)}(hhh](ji)}(hevoid cfg80211_cqm_pktloss_notify (struct net_device *dev, const u8 *peer, u32 num_packets, gfp_t gfp)h]jo)}(hdvoid cfg80211_cqm_pktloss_notify(struct net_device *dev, const u8 *peer, u32 num_packets, gfp_t gfp)h](j)}(hvoidh]hvoid}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMY"ubj)}(h h]h }(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5hhhj5hMY"ubj)}(hcfg80211_cqm_pktloss_notifyh]j)}(hcfg80211_cqm_pktloss_notifyh]hcfg80211_cqm_pktloss_notify}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj5hhhj5hMY"ubj)}(hD(struct net_device *dev, const u8 *peer, u32 num_packets, gfp_t gfp)h](j)}(hstruct net_device *devh](ju)}(hjh]hstruct}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj5ubj)}(h h]h }(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5ubh)}(hhh]j)}(h net_deviceh]h net_device}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj5modnameN classnameNj j )}j ]j)}jj5sbc.cfg80211_cqm_pktloss_notifyasbuh1hhj5ubj)}(h h]h }(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5ubj.)}(hj1h]h*}(hj6hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj5ubj)}(hdevh]hdev}(hj,6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj5ubj)}(hconst u8 *peerh](ju)}(hjZHh]hconst}(hjE6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjA6ubj)}(h h]h }(hjR6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjA6ubh)}(hhh]j)}(hu8h]hu8}(hjc6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`6ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetje6modnameN classnameNj j )}j ]j 6c.cfg80211_cqm_pktloss_notifyasbuh1hhjA6ubj)}(h h]h }(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjA6ubj.)}(hj1h]h*}(hj6hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjA6ubj)}(hpeerh]hpeer}(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjA6ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj5ubj)}(hu32 num_packetsh](h)}(hhh]j)}(hu32h]hu32}(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj6modnameN classnameNj j )}j ]j 6c.cfg80211_cqm_pktloss_notifyasbuh1hhj6ubj)}(h h]h }(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6ubj)}(h num_packetsh]h num_packets}(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj5ubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj7modnameN classnameNj j )}j ]j 6c.cfg80211_cqm_pktloss_notifyasbuh1hhj6ubj)}(h h]h }(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6ubj)}(hgfph]hgfp}(hj,7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj5ubeh}(h]h ]h"]h$]h&]jjuh1jhj5hhhj5hMY"ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj5hhhj5hMY"ubah}(h]j5ah ](jjeh"]h$]h&]jj)jhuh1jhhj5hMY"hj5hhubj)}(hhh]h)}(h)notify userspace about packetloss to peerh]h)notify userspace about packetloss to peer}(hjV7hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMQ"hjS7hhubah}(h]h ]h"]h$]h&]uh1jhj5hhhj5hMY"ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjn7jjn7jjjuh1jchhhj$bhNhNubj)}(hXN**Parameters** ``struct net_device *dev`` network device ``const u8 *peer`` peer's MAC address ``u32 num_packets`` how many packets were lost -- should be a fixed threshold but probably no less than maybe 50, or maybe a throughput dependent threshold (to account for temporary interference) ``gfp_t gfp`` context flagsh](h)}(h**Parameters**h]j)}(hjx7h]h Parameters}(hjz7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjv7ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMU"hjr7ubj)}(hhh](j)}(h*``struct net_device *dev`` network device h](j)}(h``struct net_device *dev``h]j)}(hj7h]hstruct net_device *dev}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMR"hj7ubj6)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7hMR"hj7ubah}(h]h ]h"]h$]h&]uh1j5hj7ubeh}(h]h ]h"]h$]h&]uh1jhj7hMR"hj7ubj)}(h&``const u8 *peer`` peer's MAC address h](j)}(h``const u8 *peer``h]j)}(hj7h]hconst u8 *peer}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMS"hj7ubj6)}(hhh]h)}(hpeer's MAC addressh]hpeer’s MAC address}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7hMS"hj7ubah}(h]h ]h"]h$]h&]uh1j5hj7ubeh}(h]h ]h"]h$]h&]uh1jhj7hMS"hj7ubj)}(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)}(hj 8h]hu32 num_packets}(hj 8hhhNhNubah}(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.hhMV"hj8ubj6)}(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)}(hj"8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMT"hj8ubah}(h]h ]h"]h$]h&]uh1j5hj8ubeh}(h]h ]h"]h$]h&]uh1jhj8hMV"hj7ubj)}(h``gfp_t gfp`` context flagsh](j)}(h ``gfp_t gfp``h]j)}(hjC8h]h gfp_t gfp}(hjE8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjA8ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMX"hj=8ubj6)}(hhh]h)}(h context flagsh]h context flags}(hj\8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMW"hjY8ubah}(h]h ]h"]h$]h&]uh1j5hj=8ubeh}(h]h ]h"]h$]h&]uh1jhjX8hMX"hj7ubeh}(h]h ]h"]h$]h&]uh1jhjr7ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$bhhhNhNubeh}(h]actions-and-configurationah ]h"]actions and configurationah$]h&]uh1hhhhhhhhK+ubh)}(hhh](h)}(hScanning and BSS list handlingh]hScanning and BSS list handling}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8hhhhhKaubh)}(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.}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:99: ./include/net/cfg80211.hhM hj8hhubh)}(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.}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:99: ./include/net/cfg80211.hhM' hj8hhubh)}(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.}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:99: ./include/net/cfg80211.hhM+ hj8hhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_ssid (C struct)c.cfg80211_ssidhNtauh1jRhj8hhhNhNubjd)}(hhh](ji)}(h cfg80211_ssidh]jo)}(hstruct cfg80211_ssidh](ju)}(hjh]hstruct}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj8hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMubj)}(h h]h }(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8hhhj8hMubj)}(h cfg80211_ssidh]j)}(hj8h]h cfg80211_ssid}(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj8hhhj8hMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj8hhhj8hMubah}(h]j8ah ](jjeh"]h$]h&]jj)jhuh1jhhj8hMhj8hhubj)}(hhh]h)}(hSSID descriptionh]hSSID description}(hj%9hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM4 hj"9hhubah}(h]h ]h"]h$]h&]uh1jhj8hhhj8hMubeh}(h]h ](j$structeh"]h$]h&]jj$jj=9jj=9jjjuh1jchhhj8hNhNubj)}(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}(hjI9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjE9ubh:}(hjE9hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM8 hjA9ubj( )}(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; };}hjb9sbah}(h]h ]h"]h$]h&]jjuh1j' ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM: hjA9ubh)}(h **Members**h]j)}(hjs9h]hMembers}(hju9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjq9ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM? hjA9ubj)}(hhh](j)}(h``ssid`` the SSID h](j)}(h``ssid``h]j)}(hj9h]hssid}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM6 hj9ubj6)}(hhh]h)}(hthe SSIDh]hthe SSID}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hM6 hj9ubah}(h]h ]h"]h$]h&]uh1j5hj9ubeh}(h]h ]h"]h$]h&]uh1jhj9hM6 hj9ubj)}(h``ssid_len`` length of the ssidh](j)}(h ``ssid_len``h]j)}(hj9h]hssid_len}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM6 hj9ubj6)}(hhh]h)}(hlength of the ssidh]hlength of the ssid}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM7 hj9ubah}(h]h ]h"]h$]h&]uh1j5hj9ubeh}(h]h ]h"]h$]h&]uh1jhj9hM6 hj9ubeh}(h]h ]h"]h$]h&]uh1jhjA9ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj8hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ cfg80211_scan_request (C struct)c.cfg80211_scan_requesthNtauh1jRhj8hhhNhNubjd)}(hhh](ji)}(hcfg80211_scan_requesth]jo)}(hstruct cfg80211_scan_requesth](ju)}(hjh]hstruct}(hj%:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj!:hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM= ubj)}(h h]h }(hj3:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!:hhhj2:hM= ubj)}(hcfg80211_scan_requesth]j)}(hj:h]hcfg80211_scan_request}(hjE:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjA:ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj!:hhhj2:hM= ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj:hhhj2:hM= ubah}(h]j:ah ](jjeh"]h$]h&]jj)jhuh1jhhj2:hM= hj:hhubj)}(hhh]h)}(hscan request descriptionh]hscan request description}(hjg:hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMd hjd:hhubah}(h]h ]h"]h$]h&]uh1jhj:hhhj2:hM= ubeh}(h]h ](j$structeh"]h$]h&]jj$jj:jj:jjjuh1jchhhj8hNhNubj)}(hXZ **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; struct cfg80211_scan_info info; bool notified; bool no_cck; bool scan_6ghz; 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 ``info`` (internal) information about completed scan ``notified`` (internal) scan request was notified as done or aborted ``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 the second scan request ``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.hhMh hj:ubj( )}(hXstruct 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; struct cfg80211_scan_info info; bool notified; bool no_cck; bool scan_6ghz; u32 n_6ghz_params; struct cfg80211_scan_6ghz_params *scan_6ghz_params; s8 tsf_report_link_id; struct ieee80211_channel *channels[] ; };h]hXstruct 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; struct cfg80211_scan_info info; bool notified; bool no_cck; bool scan_6ghz; 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&]jjuh1j' ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMj 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.hhMg hj:ubj6)}(hhh]h)}(h$SSIDs to scan for (active scan only)h]h$SSIDs to scan for (active scan only)}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:hMg hj:ubah}(h]h ]h"]h$]h&]uh1j5hj:ubeh}(h]h ]h"]h$]h&]uh1jhj:hMg hj:ubj)}(h``n_ssids`` number of SSIDs h](j)}(h ``n_ssids``h]j)}(hj ;h]hn_ssids}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ;ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMh hj;ubj6)}(hhh]h)}(hnumber of SSIDsh]hnumber of SSIDs}(hj&;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj";hMh hj#;ubah}(h]h ]h"]h$]h&]uh1j5hj;ubeh}(h]h ]h"]h$]h&]uh1jhj";hMh hj:ubj)}(h0``n_channels`` total number of channels to scan h](j)}(h``n_channels``h]j)}(hjF;h]h n_channels}(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.hhMj 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[;hMj hj\;ubah}(h]h ]h"]h$]h&]uh1j5hj@;ubeh}(h]h ]h"]h$]h&]uh1jhj[;hMj 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.hhMk hjy;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;hMk hj;ubah}(h]h ]h"]h$]h&]uh1j5hjy;ubeh}(h]h ]h"]h$]h&]uh1jhj;hMk 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.hhMl hj;ubj6)}(hhh]h)}(hlength of ie in octetsh]hlength of ie in octets}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj;hMl hj;ubah}(h]h ]h"]h$]h&]uh1j5hj;ubeh}(h]h ]h"]h$]h&]uh1jhj;hMl hj:ubj)}(h``duration`` how long to listen on each channel, in TUs. If ``duration_mandatory`` is not set, this is the maximum dwell time and the actual dwell time may be shorter. h](j)}(h ``duration``h]j)}(hj;h]hduration}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMo hj;ubj6)}(hhh]h)}(hhow long to listen on each channel, in TUs. If ``duration_mandatory`` is not set, this is the maximum dwell time and the actual dwell time may be shorter.h](h/how long to listen on each channel, in TUs. If }(hj<hhhNhNubj)}(h``duration_mandatory``h]hduration_mandatory}(hj <hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubhU is not set, this is the maximum dwell time and the actual dwell time may be shorter.}(hj<hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMm hj<ubah}(h]h ]h"]h$]h&]uh1j5hj;ubeh}(h]h ]h"]h$]h&]uh1jhj<hMo 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)}(hjK<h]hduration_mandatory}(hjM<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjI<ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMq hjE<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 }(hjd<hhhNhNubj)}(h ``duration``h]hduration}(hjl<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjd<ubh field.}(hjd<hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMp hja<ubah}(h]h ]h"]h$]h&]uh1j5hjE<ubeh}(h]h ]h"]h$]h&]uh1jhj`<hMq 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.hhMr 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 refexplicitrefwarnj j j6nl80211_scan_flagsuh1hhj<hMr hj<ubeh}(h]h ]h"]h$]h&]uh1hhj<hMr hj<ubah}(h]h ]h"]h$]h&]uh1j5hj<ubeh}(h]h ]h"]h$]h&]uh1jhj<hMr hj:ubj)}(h5``rates`` bitmap of rates to advertise for each band h](j)}(h ``rates``h]j)}(hj<h]hrates}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMs hj<ubj6)}(hhh]h)}(h*bitmap of rates to advertise for each bandh]h*bitmap of rates to advertise for each band}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=hMs hj=ubah}(h]h ]h"]h$]h&]uh1j5hj<ubeh}(h]h ]h"]h$]h&]uh1jhj=hMs hj:ubj)}(h)``wdev`` the wireless device to scan for h](j)}(h``wdev``h]j)}(hj(=h]hwdev}(hj*=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&=ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMv hj"=ubj6)}(hhh]h)}(hthe wireless device to scan forh]hthe wireless device to scan for}(hjA=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj==hMv hj>=ubah}(h]h ]h"]h$]h&]uh1j5hj"=ubeh}(h]h ]h"]h$]h&]uh1jhj==hMv hj:ubj)}(h1``mac_addr`` MAC address used with randomisation h](j)}(h ``mac_addr``h]j)}(hja=h]hmac_addr}(hjc=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.hhMz hj[=ubj6)}(hhh]h)}(h#MAC address used with randomisationh]h#MAC address used with randomisation}(hjz=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjv=hMz hjw=ubah}(h]h ]h"]h$]h&]uh1j5hj[=ubeh}(h]h ]h"]h$]h&]uh1jhjv=hMz 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)}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=hM hj=ubah}(h]h ]h"]h$]h&]uh1j5hj=ubeh}(h]h ]h"]h$]h&]uh1jhj=hM hj:ubj)}(h!``wiphy`` the wiphy this was for h](j)}(h ``wiphy``h]j)}(hj>h]hwiphy}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMt hj>ubj6)}(hhh]h)}(hthe wiphy this was forh]hthe wiphy this was for}(hj4>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0>hMt hj1>ubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhj0>hMt hj:ubj)}(h7``scan_start`` time (in jiffies) when the scan started h](j)}(h``scan_start``h]j)}(hjT>h]h scan_start}(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.hhMu hjN>ubj6)}(hhh]h)}(h'time (in jiffies) when the scan startedh]h'time (in jiffies) when the scan started}(hjm>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhji>hMu hjj>ubah}(h]h ]h"]h$]h&]uh1j5hjN>ubeh}(h]h ]h"]h$]h&]uh1jhji>hMu hj:ubj)}(h5``info`` (internal) information about completed scan h](j)}(h``info``h]j)}(hj>h]hinfo}(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.hhMw hj>ubj6)}(hhh]h)}(h+(internal) information about completed scanh]h+(internal) information about completed scan}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hMw hj>ubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhj>hMw hj:ubj)}(hE``notified`` (internal) scan request was notified as done or aborted h](j)}(h ``notified``h]j)}(hj>h]hnotified}(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.hhMx hj>ubj6)}(hhh]h)}(h7(internal) scan request was notified as done or abortedh]h7(internal) scan request was notified as done or aborted}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hMx hj>ubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhj>hMx 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.hhMy 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?hMy hj?ubah}(h]h ]h"]h$]h&]uh1j5hj>ubeh}(h]h ]h"]h$]h&]uh1jhj?hMy hj:ubj)}(h\``scan_6ghz`` relevant for split scan request only, true if this is the second scan request h](j)}(h ``scan_6ghz``h]j)}(hj8?h]h scan_6ghz}(hj:?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6?ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj2?ubj6)}(hhh]h)}(hMrelevant for split scan request only, true if this is the second scan requesth]hMrelevant for split scan request only, true if this is the second scan request}(hjQ?hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM~ hjN?ubah}(h]h ]h"]h$]h&]uh1j5hj2?ubeh}(h]h ]h"]h$]h&]uh1jhjM?hM hj:ubj)}(h)``n_6ghz_params`` number of 6 GHz params h](j)}(h``n_6ghz_params``h]j)}(hjr?h]h n_6ghz_params}(hjt?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjp?ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjl?ubj6)}(hhh]h)}(hnumber of 6 GHz paramsh]hnumber of 6 GHz params}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hM hj?ubah}(h]h ]h"]h$]h&]uh1j5hjl?ubeh}(h]h ]h"]h$]h&]uh1jhj?hM hj:ubj)}(h"``scan_6ghz_params`` 6 GHz params h](j)}(h``scan_6ghz_params``h]j)}(hj?h]hscan_6ghz_params}(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 6 GHz paramsh]h 6 GHz params}(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``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?h]htsf_report_link_id}(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|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?hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj?ubah}(h]h ]h"]h$]h&]uh1j5hj?ubeh}(h]h ]h"]h$]h&]uh1jhj?hM hj:ubj)}(h!``channels`` channels to scan on.h](j)}(h ``channels``h]j)}(hj@h]hchannels}(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.hhMh hj@ubj6)}(hhh]h)}(hchannels to scan on.h]hchannels to scan on.}(hj7@hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMi hj4@ubah}(h]h ]h"]h$]h&]uh1j5hj@ubeh}(h]h ]h"]h$]h&]uh1jhj3@hMh hj:ubeh}(h]h ]h"]h$]h&]uh1jhj:ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj8hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_inform_bss (C struct)c.cfg80211_inform_bsshNtauh1jRhj8hhhNhNubjd)}(hhh](ji)}(hcfg80211_inform_bssh]jo)}(hstruct cfg80211_inform_bssh](ju)}(hjh]hstruct}(hjx@hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjt@hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMo ubj)}(h h]h }(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjt@hhhj@hMo ubj)}(hcfg80211_inform_bssh]j)}(hjr@h]hcfg80211_inform_bss}(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjt@hhhj@hMo ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjp@hhhj@hMo ubah}(h]jk@ah ](jjeh"]h$]h&]jj)jhuh1jhhj@hMo hjm@hhubj)}(hhh]h)}(hBSS inform datah]hBSS inform data}(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&]uh1jhjm@hhhj@hMo ubeh}(h]h ](j$structeh"]h$]h&]jj$jj@jj@jjjuh1jchhhj8hNhNubj)}(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}(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( )}(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; };}hj@sbah}(h]h ]h"]h$]h&]jjuh1j' ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMB hj@ubh)}(h **Members**h]j)}(hjAh]hMembers}(hj AhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjAubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMO hj@ubj)}(hhh](j)}(h+``chan`` channel the frame was received on h](j)}(h``chan``h]j)}(hj'Ah]hchan}(hj)AhhhNhNubah}(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> hj!Aubj6)}(hhh]h)}(h!channel the frame was received onh]h!channel the frame was received on}(hj@AhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hj=Aubah}(h]h ]h"]h$]h&]uh1j5hj!Aubeh}(h]h ]h"]h$]h&]uh1jhj hjAubj)}(hG``signal`` signal strength value, according to the wiphy's signal type h](j)}(h ``signal``h]j)}(hj`Ah]hsignal}(hjbAhhhNhNubah}(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@ hjZAubj6)}(hhh]h)}(h;signal strength value, according to the wiphy's signal typeh]h=signal strength value, according to the wiphy’s signal type}(hjyAhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM? hjvAubah}(h]h ]h"]h$]h&]uh1j5hjZAubeh}(h]h ]h"]h$]h&]uh1jhjuAhM@ hjAubj)}(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)}(hjAh]h boottime_ns}(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.hhMF hjAubj6)}(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.}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMA hjAubah}(h]h ]h"]h$]h&]uh1j5hjAubeh}(h]h ]h"]h$]h&]uh1jhjAhMF hjAubj)}(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)}(hjAh]h parent_tsf}(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.hhMI hjAubj6)}(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 }(hjAhhhNhNubj)}(h``parent_bssid``h]h parent_bssid}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAubh.}(hjAhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMG hjAubah}(h]h ]h"]h$]h&]uh1j5hjAubeh}(h]h ]h"]h$]h&]uh1jhjAhMI hjAubj)}(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)}(hj Bh]h parent_bssid}(hj"BhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMK hjBubj6)}(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 }(hj9BhhhNhNubj)}(h``parent_tsf``h]h parent_tsf}(hjABhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9Bubh_ is set. This is set to the BSS that requested the scan in which the beacon/probe was received.}(hj9BhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMJ hj6Bubah}(h]h ]h"]h$]h&]uh1j5hjBubeh}(h]h ]h"]h$]h&]uh1jhj5BhMK hjAubj)}(h:``chains`` bitmask for filled values in **chain_signal**. h](j)}(h ``chains``h]j)}(hjlBh]hchains}(hjnBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjBubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhML hjfBubj6)}(hhh]h)}(h.bitmask for filled values in **chain_signal**.h](hbitmask for filled values in }(hjBhhhNhNubj)}(h**chain_signal**h]h chain_signal}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBubh.}(hjBhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjBhML hjBubah}(h]h ]h"]h$]h&]uh1j5hjfBubeh}(h]h ]h"]h$]h&]uh1jhjBhML hjAubj)}(hH``chain_signal`` per-chain signal strength of last received BSS in dBm. h](j)}(h``chain_signal``h]j)}(hjBh]h chain_signal}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMM hjBubj6)}(hhh]h)}(h6per-chain signal strength of last received BSS in dBm.h]h6per-chain signal strength of last received BSS in dBm.}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBhMM hjBubah}(h]h ]h"]h$]h&]uh1j5hjBubeh}(h]h ]h"]h$]h&]uh1jhjBhMM hjAubj)}(hc``restrict_use`` restrict usage, if not set, assume **use_for** is ``NL80211_BSS_USE_FOR_NORMAL``. h](j)}(h``restrict_use``h]j)}(hjBh]h restrict_use}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMO hjBubj6)}(hhh]h)}(hQrestrict usage, if not set, assume **use_for** is ``NL80211_BSS_USE_FOR_NORMAL``.h](h#restrict usage, if not set, assume }(hj ChhhNhNubj)}(h **use_for**h]huse_for}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhj Cubh is }(hj ChhhNhNubj)}(h``NL80211_BSS_USE_FOR_NORMAL``h]hNL80211_BSS_USE_FOR_NORMAL}(hj#ChhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Cubh.}(hj ChhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMN hjCubah}(h]h ]h"]h$]h&]uh1j5hjBubeh}(h]h ]h"]h$]h&]uh1jhjChMO hjAubj)}(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)}(hjNCh]huse_for}(hjPChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLCubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMQ hjHCubj6)}(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 }(hjgChhhNhNubh)}(h8:c:type:`enum nl80211_bss_use_for `h]j)}(hjqCh]henum nl80211_bss_use_for}(hjsChhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjoCubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_bss_use_foruh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMP hjgCubeh}(h]h ]h"]h$]h&]uh1hhjChMP hjdCubah}(h]h ]h"]h$]h&]uh1j5hjHCubeh}(h]h ]h"]h$]h&]uh1jhjcChMQ hjAubj)}(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)}(hjCh]hcannot_use_reasons}(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.hhMT hjCubj6)}(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 }(hjChhhNhNubj)}(h**restrict_use**h]h restrict_use}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjCubh is set and }(hjChhhNhNubj)}(h **use_for**h]huse_for}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjCubh8 is zero (empty); may be 0 for unspecified reasons; see }(hjChhhNhNubh)}(hN:c:type:`enum nl80211_bss_cannot_use_reasons `h]j)}(hjCh]h#enum nl80211_bss_cannot_use_reasons}(hjChhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_bss_cannot_use_reasonsuh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMR hjCubeh}(h]h ]h"]h$]h&]uh1hhj DhMR hjCubah}(h]h ]h"]h$]h&]uh1j5hjCubeh}(h]h ]h"]h$]h&]uh1jhjChMT hjAubj)}(h8``drv_data`` Data to be passed through to **inform_bss**h](j)}(h ``drv_data``h]j)}(hj$Dh]hdrv_data}(hj&DhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"Dubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMT hjDubj6)}(hhh]h)}(h+Data to be passed through to **inform_bss**h](hData to be passed through to }(hj=DhhhNhNubj)}(h**inform_bss**h]h inform_bss}(hjEDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=Dubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMU hj:Dubah}(h]h ]h"]h$]h&]uh1j5hjDubeh}(h]h ]h"]h$]h&]uh1jhj9DhMT hjAubeh}(h]h ]h"]h$]h&]uh1jhj@ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj8hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_bss (C struct)c.cfg80211_bsshNtauh1jRhj8hhhNhNubjd)}(hhh](ji)}(h cfg80211_bssh]jo)}(hstruct cfg80211_bssh](ju)}(hjh]hstruct}(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjDhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM[ ubj)}(h h]h }(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDhhhjDhM[ ubj)}(h cfg80211_bssh]j)}(hjDh]h cfg80211_bss}(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDubah}(h]h ](jjeh"]h$]h&]jjuh1jhjDhhhjDhM[ ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjDhhhjDhM[ ubah}(h]jDah ](jjeh"]h$]h&]jj)jhuh1jhhjDhM[ hjDhhubj)}(hhh]h)}(hBSS descriptionh]hBSS description}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMv hjDhhubah}(h]h ]h"]h$]h&]uh1jhjDhhhjDhM[ ubeh}(h]h ](j$structeh"]h$]h&]jj$jjDjjDjjjuh1jchhhj8hNhNubj)}(hX **Definition**:: struct cfg80211_bss { struct ieee80211_channel *channel; const struct cfg80211_bss_ies __rcu *ies; const struct cfg80211_bss_ies __rcu *beacon_ies; const struct cfg80211_bss_ies __rcu *proberesp_ies; struct cfg80211_bss *hidden_beacon_bss; struct cfg80211_bss *transmitted_bss; struct list_head nontrans_list; s32 signal; u64 ts_boottime; u16 beacon_interval; u16 capability; u8 bssid[ETH_ALEN]; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; u8 proberesp_ecsa_stuck:1; u8 bssid_index; u8 max_bssid_indicator; u8 use_for; u8 cannot_use_reasons; u8 priv[] ; }; **Members** ``channel`` channel this BSS is on ``ies`` the information elements (Note that there is no guarantee that these are well-formed!); this is a pointer to either the beacon_ies or proberesp_ies depending on whether Probe Response frame has been received. It is always non-``NULL``. ``beacon_ies`` the information elements from the last Beacon frame (implementation note: if **hidden_beacon_bss** is set this struct doesn't own the beacon_ies, but they're just pointers to the ones from the **hidden_beacon_bss** struct) ``proberesp_ies`` the information elements from the last Probe Response frame ``hidden_beacon_bss`` in case this BSS struct represents a probe response from a BSS that hides the SSID in its beacon, this points to the BSS struct that holds the beacon data. **beacon_ies** is still valid, of course, and points to the same data as hidden_beacon_bss->beacon_ies in that case. ``transmitted_bss`` pointer to the transmitted BSS, if this is a non-transmitted one (multi-BSSID support) ``nontrans_list`` list of non-transmitted BSS, if this is a transmitted one (multi-BSSID support) ``signal`` signal strength value (type depends on the wiphy's signal_type) ``ts_boottime`` timestamp of the last BSS update in nanoseconds since boot ``beacon_interval`` the beacon interval as from the frame ``capability`` the capability field in host byte order ``bssid`` BSSID of the BSS ``chains`` bitmask for filled values in **chain_signal**. ``chain_signal`` per-chain signal strength of last received BSS in dBm. ``proberesp_ecsa_stuck`` ECSA element is stuck in the Probe Response frame, cannot rely on it having valid data ``bssid_index`` index in the multiple BSS set ``max_bssid_indicator`` max number of members in the BSS set ``use_for`` bitmap of possible usage for this BSS, see :c:type:`enum nl80211_bss_use_for ` ``cannot_use_reasons`` the reasons (bitmap) for not being able to connect, if **restrict_use** is set and **use_for** is zero (empty); may be 0 for unspecified reasons; see :c:type:`enum nl80211_bss_cannot_use_reasons ` ``priv`` private area for driver use, has at least wiphy->bss_priv_size bytesh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDubh:}(hjDhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMz hjDubj( )}(hXstruct cfg80211_bss { struct ieee80211_channel *channel; const struct cfg80211_bss_ies __rcu *ies; const struct cfg80211_bss_ies __rcu *beacon_ies; const struct cfg80211_bss_ies __rcu *proberesp_ies; struct cfg80211_bss *hidden_beacon_bss; struct cfg80211_bss *transmitted_bss; struct list_head nontrans_list; s32 signal; u64 ts_boottime; u16 beacon_interval; u16 capability; u8 bssid[ETH_ALEN]; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; u8 proberesp_ecsa_stuck:1; u8 bssid_index; u8 max_bssid_indicator; u8 use_for; u8 cannot_use_reasons; u8 priv[] ; };h]hXstruct cfg80211_bss { struct ieee80211_channel *channel; const struct cfg80211_bss_ies __rcu *ies; const struct cfg80211_bss_ies __rcu *beacon_ies; const struct cfg80211_bss_ies __rcu *proberesp_ies; struct cfg80211_bss *hidden_beacon_bss; struct cfg80211_bss *transmitted_bss; struct list_head nontrans_list; s32 signal; u64 ts_boottime; u16 beacon_interval; u16 capability; u8 bssid[ETH_ALEN]; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; u8 proberesp_ecsa_stuck:1; u8 bssid_index; u8 max_bssid_indicator; u8 use_for; u8 cannot_use_reasons; u8 priv[] ; };}hj Esbah}(h]h ]h"]h$]h&]jjuh1j' ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM| hjDubh)}(h **Members**h]j)}(hjEh]hMembers}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjEubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjDubj)}(hhh](j)}(h#``channel`` channel this BSS is on h](j)}(h ``channel``h]j)}(hj;Eh]hchannel}(hj=EhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9Eubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM| hj5Eubj6)}(hhh]h)}(hchannel this BSS is onh]hchannel this BSS is on}(hjTEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPEhM| hjQEubah}(h]h ]h"]h$]h&]uh1j5hj5Eubeh}(h]h ]h"]h$]h&]uh1jhjPEhM| hj2Eubj)}(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)}(hjtEh]hies}(hjvEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrEubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjnEubj6)}(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-}(hjEhhhNhNubj)}(h``NULL``h]hNULL}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubh.}(hjEhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjEubah}(h]h ]h"]h$]h&]uh1j5hjnEubeh}(h]h ]h"]h$]h&]uh1jhjEhM hj2Eubj)}(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)}(hjEh]h beacon_ies}(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 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 }(hjEhhhNhNubj)}(h**hidden_beacon_bss**h]hhidden_beacon_bss}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjEubhc is set this struct doesn’t own the beacon_ies, but they’re just pointers to the ones from the }(hjEhhhNhNubj)}(h**hidden_beacon_bss**h]hhidden_beacon_bss}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjEubh struct)}(hjEhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjEubah}(h]h ]h"]h$]h&]uh1j5hjEubeh}(h]h ]h"]h$]h&]uh1jhjEhM hj2Eubj)}(hN``proberesp_ies`` the information elements from the last Probe Response frame h](j)}(h``proberesp_ies``h]j)}(hjFh]h proberesp_ies}(hj FhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjFubj6)}(hhh]h)}(h;the information elements from the last Probe Response frameh]h;the information elements from the last Probe Response frame}(hj7FhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3FhM hj4Fubah}(h]h ]h"]h$]h&]uh1j5hjFubeh}(h]h ]h"]h$]h&]uh1jhj3FhM hj2Eubj)}(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)}(hjWFh]hhidden_beacon_bss}(hjYFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUFubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjQFubj6)}(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. }(hjpFhhhNhNubj)}(h**beacon_ies**h]h beacon_ies}(hjxFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjpFubhf is still valid, of course, and points to the same data as hidden_beacon_bss->beacon_ies in that case.}(hjpFhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjmFubah}(h]h ]h"]h$]h&]uh1j5hjQFubeh}(h]h ]h"]h$]h&]uh1jhjlFhM hj2Eubj)}(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)}(hjFh]htransmitted_bss}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjFubj6)}(hhh]h)}(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)}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjFubah}(h]h ]h"]h$]h&]uh1j5hjFubeh}(h]h ]h"]h$]h&]uh1jhjFhM hj2Eubj)}(hb``nontrans_list`` list of non-transmitted BSS, if this is a transmitted one (multi-BSSID support) h](j)}(h``nontrans_list``h]j)}(hjFh]h nontrans_list}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjFubj6)}(hhh]h)}(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)}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjFubah}(h]h ]h"]h$]h&]uh1j5hjFubeh}(h]h ]h"]h$]h&]uh1jhjFhM hj2Eubj)}(hK``signal`` signal strength value (type depends on the wiphy's signal_type) h](j)}(h ``signal``h]j)}(hjGh]hsignal}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjGubj6)}(hhh]h)}(h?signal strength value (type depends on the wiphy's signal_type)h]hAsignal strength value (type depends on the wiphy’s signal_type)}(hj0GhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,GhM hj-Gubah}(h]h ]h"]h$]h&]uh1j5hjGubeh}(h]h ]h"]h$]h&]uh1jhj,GhM hj2Eubj)}(hK``ts_boottime`` timestamp of the last BSS update in nanoseconds since boot h](j)}(h``ts_boottime``h]j)}(hjPGh]h ts_boottime}(hjRGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNGubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjJGubj6)}(hhh]h)}(h:timestamp of the last BSS update in nanoseconds since booth]h:timestamp of the last BSS update in nanoseconds since boot}(hjiGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjeGhM hjfGubah}(h]h ]h"]h$]h&]uh1j5hjJGubeh}(h]h ]h"]h$]h&]uh1jhjeGhM hj2Eubj)}(h:``beacon_interval`` the beacon interval as from the frame h](j)}(h``beacon_interval``h]j)}(hjGh]hbeacon_interval}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM~ hjGubj6)}(hhh]h)}(h%the beacon interval as from the frameh]h%the beacon interval as from the frame}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjGhM~ hjGubah}(h]h ]h"]h$]h&]uh1j5hjGubeh}(h]h ]h"]h$]h&]uh1jhjGhM~ hj2Eubj)}(h7``capability`` the capability field in host byte order h](j)}(h``capability``h]j)}(hjGh]h capability}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjGubj6)}(hhh]h)}(h'the capability field in host byte orderh]h'the capability field in host byte order}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjGhM hjGubah}(h]h ]h"]h$]h&]uh1j5hjGubeh}(h]h ]h"]h$]h&]uh1jhjGhM hj2Eubj)}(h``bssid`` BSSID of the BSS h](j)}(h ``bssid``h]j)}(hjGh]hbssid}(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)}(hBSSID of the BSSh]hBSSID of the BSS}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHhM} hjHubah}(h]h ]h"]h$]h&]uh1j5hjGubeh}(h]h ]h"]h$]h&]uh1jhjHhM} hj2Eubj)}(h:``chains`` bitmask for filled values in **chain_signal**. h](j)}(h ``chains``h]j)}(hj4Hh]hchains}(hj6HhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2Hubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj.Hubj6)}(hhh]h)}(h.bitmask for filled values in **chain_signal**.h](hbitmask for filled values in }(hjMHhhhNhNubj)}(h**chain_signal**h]h chain_signal}(hjUHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjMHubh.}(hjMHhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjIHhM hjJHubah}(h]h ]h"]h$]h&]uh1j5hj.Hubeh}(h]h ]h"]h$]h&]uh1jhjIHhM hj2Eubj)}(hH``chain_signal`` per-chain signal strength of last received BSS in dBm. h](j)}(h``chain_signal``h]j)}(hjHh]h chain_signal}(hjHhhhNhNubah}(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)}(h6per-chain signal strength of last received BSS in dBm.h]h6per-chain signal strength of last received BSS in dBm.}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHhM hjHubah}(h]h ]h"]h$]h&]uh1j5hjyHubeh}(h]h ]h"]h$]h&]uh1jhjHhM hj2Eubj)}(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)}(hjHh]hproberesp_ecsa_stuck}(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)}(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}(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 hj2Eubj)}(h.``bssid_index`` index in the multiple BSS set h](j)}(h``bssid_index``h]j)}(hjHh]h bssid_index}(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)}(hindex in the multiple BSS seth]hindex in the multiple BSS set}(hj IhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIhM hjIubah}(h]h ]h"]h$]h&]uh1j5hjHubeh}(h]h ]h"]h$]h&]uh1jhjIhM hj2Eubj)}(h=``max_bssid_indicator`` max number of members in the BSS set h](j)}(h``max_bssid_indicator``h]j)}(hj+Ih]hmax_bssid_indicator}(hj-IhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)Iubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj%Iubj6)}(hhh]h)}(h$max number of members in the BSS seth]h$max number of members in the BSS set}(hjDIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@IhM hjAIubah}(h]h ]h"]h$]h&]uh1j5hj%Iubeh}(h]h ]h"]h$]h&]uh1jhj@IhM hj2Eubj)}(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)}(hjdIh]huse_for}(hjfIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbIubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj^Iubj6)}(hhh]h)}(hcbitmap of possible usage for this BSS, see :c:type:`enum nl80211_bss_use_for `h](h+bitmap of possible usage for this BSS, see }(hj}IhhhNhNubh)}(h8:c:type:`enum nl80211_bss_use_for `h]j)}(hjIh]henum nl80211_bss_use_for}(hjIhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_bss_use_foruh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj}Iubeh}(h]h ]h"]h$]h&]uh1hhjIhM hjzIubah}(h]h ]h"]h$]h&]uh1j5hj^Iubeh}(h]h ]h"]h$]h&]uh1jhjyIhM hj2Eubj)}(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)}(hjIh]hcannot_use_reasons}(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)}(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 }(hjIhhhNhNubj)}(h**restrict_use**h]h restrict_use}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIubh is set and }(hjIhhhNhNubj)}(h **use_for**h]huse_for}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIubh8 is zero (empty); may be 0 for unspecified reasons; see }(hjIhhhNhNubh)}(hN:c:type:`enum nl80211_bss_cannot_use_reasons `h]j)}(hjJh]h#enum nl80211_bss_cannot_use_reasons}(hjJhhhNhNubah}(h]h ](j#j$c-typeeh"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]refdocj0 refdomainj$reftypetype refexplicitrefwarnj j j6nl80211_bss_cannot_use_reasonsuh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjIubeh}(h]h ]h"]h$]h&]uh1hhj!JhM hjIubah}(h]h ]h"]h$]h&]uh1j5hjIubeh}(h]h ]h"]h$]h&]uh1jhjIhM hj2Eubj)}(hM``priv`` private area for driver use, has at least wiphy->bss_priv_size bytesh](j)}(h``priv``h]j)}(hj:Jh]hpriv}(hjbss_priv_size bytesh]hDprivate area for driver use, has at least wiphy->bss_priv_size bytes}(hjSJhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjPJubah}(h]h ]h"]h$]h&]uh1j5hj4Jubeh}(h]h ]h"]h$]h&]uh1jhjOJhM hj2Eubeh}(h]h ]h"]h$]h&]uh1jhjDubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj8hhhNhNubh)}(h**Description**h]j)}(hj}Jh]h Description}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{Jubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj8hhubh)}(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.}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMw hj8hhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_!ieee80211_bss_get_ie (C function)c.ieee80211_bss_get_iehNtauh1jRhj8hhhNhNubjd)}(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)}(hjZHh]hconst}(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjJhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJhhhjJhM ubh)}(hhh]j)}(hu8h]hu8}(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjJmodnameN classnameNj j )}j ]j)}jieee80211_bss_get_iesbc.ieee80211_bss_get_ieasbuh1hhjJhhhjJhM ubj)}(h h]h }(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJhhhjJhM ubj.)}(hj1h]h*}(hj KhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjJhhhjJhM ubj)}(hieee80211_bss_get_ieh]j)}(hjJh]hieee80211_bss_get_ie}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubah}(h]h ](jjeh"]h$]h&]jjuh1jhjJhhhjJhM ubj)}(h!(struct cfg80211_bss *bss, u8 id)h](j)}(hstruct cfg80211_bss *bssh](ju)}(hjh]hstruct}(hj5KhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj1Kubj)}(h h]h }(hjBKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1Kubh)}(hhh]j)}(h cfg80211_bssh]h cfg80211_bss}(hjSKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjPKubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjUKmodnameN classnameNj j )}j ]jJc.ieee80211_bss_get_ieasbuh1hhj1Kubj)}(h h]h }(hjqKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1Kubj.)}(hj1h]h*}(hjKhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj1Kubj)}(hbssh]hbss}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1Kubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj-Kubj)}(hu8 idh](h)}(hhh]j)}(hu8h]hu8}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjKmodnameN classnameNj j )}j ]jJc.ieee80211_bss_get_ieasbuh1hhjKubj)}(h h]h }(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubj)}(hidh]hid}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj-Kubeh}(h]h ]h"]h$]h&]jjuh1jhjJhhhjJhM ubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjJhhhjJhM ubah}(h]jJah ](jjeh"]h$]h&]jj)jhuh1jhhjJhM hjJhhubj)}(hhh]h)}(hfind IE with given IDh]hfind IE with given ID}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjKhhubah}(h]h ]h"]h$]h&]uh1jhjJhhhjJhM ubeh}(h]h ](j$functioneh"]h$]h&]jj$jjLjjLjjjuh1jchhhj8hNhNubj)}(hX**Parameters** ``struct cfg80211_bss *bss`` the bss to search ``u8 id`` the element ID **Description** Note that the return value is an RCU-protected pointer, so rcu_read_lock() must be held when calling this function. **Return** ``NULL`` if not found.h](h)}(h**Parameters**h]j)}(hj Lh]h Parameters}(hj"LhhhNhNubah}(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 hjLubj)}(hhh](j)}(h/``struct cfg80211_bss *bss`` the bss to search h](j)}(h``struct cfg80211_bss *bss``h]j)}(hj?Lh]hstruct cfg80211_bss *bss}(hjALhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=Lubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj9Lubj6)}(hhh]h)}(hthe bss to searchh]hthe bss to search}(hjXLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjTLhM hjULubah}(h]h ]h"]h$]h&]uh1j5hj9Lubeh}(h]h ]h"]h$]h&]uh1jhjTLhM hj6Lubj)}(h``u8 id`` the element ID h](j)}(h ``u8 id``h]j)}(hjxLh]hu8 id}(hjzLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvLubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjrLubj6)}(hhh]h)}(hthe element IDh]hthe element ID}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhM hjLubah}(h]h ]h"]h$]h&]uh1j5hjrLubeh}(h]h ]h"]h$]h&]uh1jhjLhM hj6Lubeh}(h]h ]h"]h$]h&]uh1jhjLubh)}(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 hjLubh)}(hsNote that the return value is an RCU-protected pointer, so rcu_read_lock() must be held when calling this function.h]hsNote that the return value is an RCU-protected pointer, so rcu_read_lock() must be held when calling this function.}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjLubh)}(h **Return**h]j)}(hjLh]hReturn}(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 hjLubh)}(h``NULL`` if not found.h](j)}(h``NULL``h]hNULL}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubh if not found.}(hjLhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjLubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj8hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_cfg80211_find_ie (C function)c.cfg80211_find_iehNtauh1jRhj8hhhNhNubjd)}(hhh](ji)}(h\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)}(hadditional IEs sent by the peerh]hadditional IEs sent by the peer}(hjY\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjU\hM<hjV\ubah}(h]h ]h"]h$]h&]uh1j5hj:\ubeh}(h]h ]h"]h$]h&]uh1jhjU\hM<hjZubj)}(h.``size_t ielen`` length of the additional IEs h](j)}(h``size_t ielen``h]j)}(hjy\h]h size_t ielen}(hj{\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjw\ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM=hjs\ubj6)}(hhh]h)}(hlength of the additional IEsh]hlength of the additional IEs}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\hM=hj\ubah}(h]h ]h"]h$]h&]uh1j5hjs\ubeh}(h]h ]h"]h$]h&]uh1jhj\hM=hjZubj)}(h``gfp_t gfp`` context 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&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM>hj\ubj6)}(hhh]h)}(h context flagsh]h context 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>hjZubeh}(h]h ]h"]h$]h&]uh1jhjZubh)}(h**Description**h]j)}(hj\h]h Description}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM@hjZubh)}(hYThis informs cfg80211 that BSS information was found and the BSS should be updated/added.h]hYThis informs cfg80211 that BSS information was found and the BSS should be updated/added.}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM@hjZubh)}(h **Return**h]j)}(hj]h]hReturn}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMChjZubh)}(hTA referenced struct, must be released with cfg80211_put_bss()! Or ``NULL`` on error.h](hBA referenced struct, must be released with cfg80211_put_bss()! Or }(hj*]hhhNhNubj)}(h``NULL``h]hNULL}(hj2]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*]ubh on error.}(hj*]hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMChjZubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj8hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_ cfg80211_unlink_bss (C function)c.cfg80211_unlink_bsshNtauh1jRhj8hhhNhNubjd)}(hhh](ji)}(hHvoid cfg80211_unlink_bss (struct wiphy *wiphy, struct cfg80211_bss *bss)h]jo)}(hGvoid cfg80211_unlink_bss(struct wiphy *wiphy, struct cfg80211_bss *bss)h](j)}(hvoidh]hvoid}(hjk]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjg]hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMubj)}(h h]h }(hjz]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjg]hhhjy]hMubj)}(hcfg80211_unlink_bssh]j)}(hcfg80211_unlink_bssh]hcfg80211_unlink_bss}(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjg]hhhjy]hMubj)}(h/(struct wiphy *wiphy, struct cfg80211_bss *bss)h](j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj]ubj)}(h h]h }(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubh)}(hhh]j)}(hwiphyh]hwiphy}(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj]modnameN classnameNj j )}j ]j)}jj]sbc.cfg80211_unlink_bssasbuh1hhj]ubj)}(h h]h }(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubj.)}(hj1h]h*}(hj]hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj]ubj)}(hwiphyh]hwiphy}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]ubj)}(hstruct cfg80211_bss *bssh](ju)}(hjh]hstruct}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj^ubj)}(h h]h }(hj'^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubh)}(hhh]j)}(h cfg80211_bssh]h cfg80211_bss}(hj8^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5^ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj:^modnameN classnameNj j )}j ]j]c.cfg80211_unlink_bssasbuh1hhj^ubj)}(h h]h }(hjV^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubj.)}(hj1h]h*}(hjd^hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj^ubj)}(hbssh]hbss}(hjq^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]ubeh}(h]h ]h"]h$]h&]jjuh1jhjg]hhhjy]hMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjc]hhhjy]hMubah}(h]j^]ah ](jjeh"]h$]h&]jj)jhuh1jhhjy]hMhj`]hhubj)}(hhh]h)}(h(unlink BSS from internal data structuresh]h(unlink BSS from internal data structures}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhj^hhubah}(h]h ]h"]h$]h&]uh1jhj`]hhhjy]hMubeh}(h]h ](j$functioneh"]h$]h&]jj$jj^jj^jjjuh1jchhhj8hNhNubj)}(hX~**Parameters** ``struct wiphy *wiphy`` the wiphy ``struct cfg80211_bss *bss`` the bss to remove **Description** This function removes the given BSS from the internal data structures thereby making it no longer show up in scan results etc. Use this function when you detect a BSS is gone. Normally BSSes will also time out, so it is not necessary to use this function at all.h](h)}(h**Parameters**h]j)}(hj^h]h Parameters}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhj^ubj)}(hhh](j)}(h"``struct wiphy *wiphy`` the wiphy h](j)}(h``struct wiphy *wiphy``h]j)}(hj^h]hstruct wiphy *wiphy}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhj^ubj6)}(hhh]h)}(h the wiphyh]h the wiphy}(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/``struct cfg80211_bss *bss`` the bss to remove h](j)}(h``struct cfg80211_bss *bss``h]j)}(hj_h]hstruct cfg80211_bss *bss}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhj_ubj6)}(hhh]h)}(hthe bss to removeh]hthe bss to remove}(hj._hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*_hMhj+_ubah}(h]h ]h"]h$]h&]uh1j5hj_ubeh}(h]h ]h"]h$]h&]uh1jhj*_hMhj^ubeh}(h]h ]h"]h$]h&]uh1jhj^ubh)}(h**Description**h]j)}(hjP_h]h Description}(hjR_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjN_ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhj^ubh)}(hXThis function removes the given BSS from the internal data structures thereby making it no longer show up in scan results etc. Use this function when you detect a BSS is gone. Normally BSSes will also time out, so it is not necessary to use this function at all.h]hXThis function removes the given BSS from the internal data structures thereby making it no longer show up in scan results etc. Use this function when you detect a BSS is gone. Normally BSSes will also time out, so it is not necessary to use this function at all.}(hjf_hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhj^ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj8hhhNhNubeh}(h]scanning-and-bss-list-handlingah ]h"]scanning and bss list handlingah$]h&]uh1hhhhhhhhKaubh)}(hhh](h)}(hUtility functionsh]hUtility functions}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_hhhhhKtubh)}(hAcfg80211 offers a number of utility functions that can be useful.h]hAcfg80211 offers a number of utility functions that can be useful.}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:118: ./include/net/cfg80211.hhMkhj_hhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_+ieee80211_channel_to_frequency (C function) c.ieee80211_channel_to_frequencyhNtauh1jRhj_hhhNhNubjd)}(hhh](ji)}(hEint ieee80211_channel_to_frequency (int chan, enum nl80211_band band)h]jo)}(hDint ieee80211_channel_to_frequency(int chan, enum nl80211_band band)h](j)}(hinth]hint}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMubj)}(h h]h }(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_hhhj_hMubj)}(hieee80211_channel_to_frequencyh]j)}(hieee80211_channel_to_frequencyh]hieee80211_channel_to_frequency}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj_hhhj_hMubj)}(h"(int chan, enum nl80211_band band)h](j)}(hint chanh](j)}(hinth]hint}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_ubj)}(h h]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)}(henum nl80211_band bandh](ju)}(hjxh]henum}(hj/`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj+`ubj)}(h h]h }(hj<`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+`ubh)}(hhh]j)}(h nl80211_bandh]h nl80211_band}(hjM`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJ`ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjO`modnameN classnameNj j )}j ]j)}jj_sb c.ieee80211_channel_to_frequencyasbuh1hhj+`ubj)}(h h]h }(hjm`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+`ubj)}(hbandh]hband}(hj{`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+`ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj_ubeh}(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#convert channel number to frequencyh]h#convert channel number to frequency}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhj`hhubah}(h]h ]h"]h$]h&]uh1jhj_hhhj_hMubeh}(h]h ](j$functioneh"]h$]h&]jj$jj`jj`jjjuh1jchhhj_hNhNubj)}(h**Parameters** ``int chan`` channel number ``enum nl80211_band band`` band, necessary due to channel number overlap **Return** The corresponding frequency (in MHz), or 0 if the conversion failed.h](h)}(h**Parameters**h]j)}(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:121: ./include/net/cfg80211.hhMhj`ubj)}(hhh](j)}(h``int chan`` channel number h](j)}(h ``int chan``h]j)}(hj`h]hint chan}(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:121: ./include/net/cfg80211.hhMhj`ubj6)}(hhh]h)}(hchannel numberh]hchannel number}(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)}(hI``enum nl80211_band band`` band, necessary due to channel number overlap h](j)}(h``enum nl80211_band band``h]j)}(hjah]henum nl80211_band band}(hj!ahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjaubj6)}(hhh]h)}(h-band, necessary due to channel number overlaph]h-band, necessary due to channel number overlap}(hj8ahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4ahMhj5aubah}(h]h ]h"]h$]h&]uh1j5hjaubeh}(h]h ]h"]h$]h&]uh1jhj4ahMhj`ubeh}(h]h ]h"]h$]h&]uh1jhj`ubh)}(h **Return**h]j)}(hjZah]hReturn}(hj\ahhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXaubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhj`ubh)}(hDThe corresponding frequency (in MHz), or 0 if the conversion failed.h]hDThe corresponding frequency (in MHz), or 0 if the conversion failed.}(hjpahhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhj`ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj_hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_+ieee80211_frequency_to_channel (C function) c.ieee80211_frequency_to_channelhNtauh1jRhj_hhhNhNubjd)}(hhh](ji)}(h-int ieee80211_frequency_to_channel (int freq)h]jo)}(h,int ieee80211_frequency_to_channel(int freq)h](j)}(hinth]hint}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjahhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMubj)}(h h]h }(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjahhhjahMubj)}(hieee80211_frequency_to_channelh]j)}(hieee80211_frequency_to_channelh]hieee80211_frequency_to_channel}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubah}(h]h ](jjeh"]h$]h&]jjuh1jhjahhhjahMubj)}(h (int freq)h]j)}(hint freqh](j)}(hinth]hint}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubj)}(h h]h }(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubj)}(hfreqh]hfreq}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjaubah}(h]h ]h"]h$]h&]jjuh1jhjahhhjahMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjahhhjahMubah}(h]jaah ](jjeh"]h$]h&]jj)jhuh1jhhjahMhjahhubj)}(hhh]h)}(h#convert frequency to channel numberh]h#convert frequency to channel number}(hj"bhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjbhhubah}(h]h ]h"]h$]h&]uh1jhjahhhjahMubeh}(h]h ](j$functioneh"]h$]h&]jj$jj:bjj:bjjjuh1jchhhj_hNhNubj)}(h}**Parameters** ``int freq`` center frequency in MHz **Return** The corresponding channel, or 0 if the conversion failed.h](h)}(h**Parameters**h]j)}(hjDbh]h Parameters}(hjFbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBbubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhj>bubj)}(hhh]j)}(h%``int freq`` center frequency in MHz h](j)}(h ``int freq``h]j)}(hjcbh]hint freq}(hjebhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjabubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhj]bubj6)}(hhh]h)}(hcenter frequency in MHzh]hcenter frequency in MHz}(hj|bhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxbhMhjybubah}(h]h ]h"]h$]h&]uh1j5hj]bubeh}(h]h ]h"]h$]h&]uh1jhjxbhMhjZbubah}(h]h ]h"]h$]h&]uh1jhj>bubh)}(h **Return**h]j)}(hjbh]hReturn}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhj>bubh)}(h9The corresponding channel, or 0 if the conversion failed.h]h9The corresponding channel, or 0 if the conversion failed.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhj>bubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj_hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_"ieee80211_get_channel (C function)c.ieee80211_get_channelhNtauh1jRhj_hhhNhNubjd)}(hhh](ji)}(hPstruct ieee80211_channel * ieee80211_get_channel (struct wiphy *wiphy, int freq)h]jo)}(hNstruct ieee80211_channel *ieee80211_get_channel(struct wiphy *wiphy, int freq)h](ju)}(hjh]hstruct}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjbhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMubj)}(h h]h }(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjbhhhjbhMubh)}(hhh]j)}(hieee80211_channelh]hieee80211_channel}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjcmodnameN classnameNj j )}j ]j)}jieee80211_get_channelsbc.ieee80211_get_channelasbuh1hhjbhhhjbhMubj)}(h h]h }(hj#chhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjbhhhjbhMubj.)}(hj1h]h*}(hj1chhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjbhhhjbhMubj)}(hieee80211_get_channelh]j)}(hj ch]hieee80211_get_channel}(hjBchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>cubah}(h]h ](jjeh"]h$]h&]jjuh1jhjbhhhjbhMubj)}(h(struct wiphy *wiphy, int freq)h](j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hj]chhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjYcubj)}(h h]h }(hjjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjYcubh)}(hhh]j)}(hwiphyh]hwiphy}(hj{chhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxcubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj}cmodnameN classnameNj j )}j ]jcc.ieee80211_get_channelasbuh1hhjYcubj)}(h h]h }(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjYcubj.)}(hj1h]h*}(hjchhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjYcubj)}(hwiphyh]hwiphy}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjYcubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjUcubj)}(hint freqh](j)}(hinth]hint}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjcubj)}(h h]h }(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjcubj)}(hfreqh]hfreq}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjcubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjUcubeh}(h]h ]h"]h$]h&]jjuh1jhjbhhhjbhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjbhhhjbhMubah}(h]jbah ](jjeh"]h$]h&]jj)jhuh1jhhjbhMhjbhhubj)}(hhh]h)}(h5get channel struct from wiphy for specified frequencyh]h5get channel struct from wiphy for specified frequency}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjdhhubah}(h]h ]h"]h$]h&]uh1jhjbhhhjbhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jj+djj+djjjuh1jchhhj_hNhNubj)}(h**Parameters** ``struct wiphy *wiphy`` the struct wiphy to get the channel for ``int freq`` the center frequency (in MHz) of the channel **Return** The channel struct from **wiphy** at **freq**.h](h)}(h**Parameters**h]j)}(hj5dh]h Parameters}(hj7dhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3dubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhj/dubj)}(hhh](j)}(h@``struct wiphy *wiphy`` the struct wiphy to get the channel for h](j)}(h``struct wiphy *wiphy``h]j)}(hjTdh]hstruct wiphy *wiphy}(hjVdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRdubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjNdubj6)}(hhh]h)}(h'the struct wiphy to get the channel forh]h'the struct wiphy to get the channel for}(hjmdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjidhMhjjdubah}(h]h ]h"]h$]h&]uh1j5hjNdubeh}(h]h ]h"]h$]h&]uh1jhjidhMhjKdubj)}(h:``int freq`` the center frequency (in MHz) of the channel h](j)}(h ``int freq``h]j)}(hjdh]hint freq}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjdubj6)}(hhh]h)}(h,the center frequency (in MHz) of the channelh]h,the center frequency (in MHz) of the channel}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdhMhjdubah}(h]h ]h"]h$]h&]uh1j5hjdubeh}(h]h ]h"]h$]h&]uh1jhjdhMhjKdubeh}(h]h ]h"]h$]h&]uh1jhj/dubh)}(h **Return**h]j)}(hjdh]hReturn}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhj/dubh)}(h.The channel struct from **wiphy** at **freq**.h](hThe channel struct from }(hjdhhhNhNubj)}(h **wiphy**h]hwiphy}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdubh at }(hjdhhhNhNubj)}(h**freq**h]hfreq}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdubh.}(hjdhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhj/dubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj_hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_(ieee80211_get_response_rate (C function)c.ieee80211_get_response_ratehNtauh1jRhj_hhhNhNubjd)}(hhh](ji)}(hconst struct ieee80211_rate * ieee80211_get_response_rate (struct ieee80211_supported_band *sband, u32 basic_rates, int bitrate)h]jo)}(h~const struct ieee80211_rate *ieee80211_get_response_rate(struct ieee80211_supported_band *sband, u32 basic_rates, int bitrate)h](ju)}(hjZHh]hconst}(hj1ehhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj-ehhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMubj)}(h h]h }(hj?ehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj-ehhhj>ehMubju)}(hjh]hstruct}(hjMehhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj-ehhhj>ehMubj)}(h h]h }(hjZehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj-ehhhj>ehMubh)}(hhh]j)}(hieee80211_rateh]hieee80211_rate}(hjkehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjheubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmemodnameN classnameNj j )}j ]j)}jieee80211_get_response_ratesbc.ieee80211_get_response_rateasbuh1hhj-ehhhj>ehMubj)}(h h]h }(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj-ehhhj>ehMubj.)}(hj1h]h*}(hjehhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj-ehhhj>ehMubj)}(hieee80211_get_response_rateh]j)}(hjeh]hieee80211_get_response_rate}(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubah}(h]h ](jjeh"]h$]h&]jjuh1jhj-ehhhj>ehMubj)}(hF(struct ieee80211_supported_band *sband, u32 basic_rates, int bitrate)h](j)}(h&struct ieee80211_supported_band *sbandh](ju)}(hjh]hstruct}(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjeubj)}(h h]h }(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubh)}(hhh]j)}(hieee80211_supported_bandh]hieee80211_supported_band}(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjemodnameN classnameNj j )}j ]jec.ieee80211_get_response_rateasbuh1hhjeubj)}(h h]h }(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubj.)}(hj1h]h*}(hjfhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjeubj)}(hsbandh]hsband}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjeubj)}(hu32 basic_ratesh](h)}(hhh]j)}(hu32h]hu32}(hj9fhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6fubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj;fmodnameN classnameNj j )}j ]jec.ieee80211_get_response_rateasbuh1hhj2fubj)}(h h]h }(hjWfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2fubj)}(h basic_ratesh]h basic_rates}(hjefhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2fubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjeubj)}(h int bitrateh](j)}(hinth]hint}(hj~fhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjzfubj)}(h h]h }(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjzfubj)}(hbitrateh]hbitrate}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjzfubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjeubeh}(h]h ]h"]h$]h&]jjuh1jhj-ehhhj>ehMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj)ehhhj>ehMubah}(h]j$eah ](jjeh"]h$]h&]jj)jhuh1jhhj>ehMhj&ehhubj)}(hhh]h)}(hget basic rate for a given rateh]hget basic rate for a given rate}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjfhhubah}(h]h ]h"]h$]h&]uh1jhj&ehhhj>ehMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjfjjfjjjuh1jchhhj_hNhNubj)}(hX**Parameters** ``struct ieee80211_supported_band *sband`` the band to look for rates in ``u32 basic_rates`` bitmap of basic rates ``int bitrate`` the bitrate for which to find the basic rate **Return** The basic rate corresponding to a given bitrate, that is the next lower bitrate contained in the basic rate map, which is, for this function, given as a bitmap of indices of rates in the band's bitrate table.h](h)}(h**Parameters**h]j)}(hjfh]h Parameters}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjfubj)}(hhh](j)}(hI``struct ieee80211_supported_band *sband`` the band to look for rates in h](j)}(h*``struct ieee80211_supported_band *sband``h]j)}(hjgh]h&struct ieee80211_supported_band *sband}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjfubj6)}(hhh]h)}(hthe band to look for rates inh]hthe band to look for rates in}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjghMhjgubah}(h]h ]h"]h$]h&]uh1j5hjfubeh}(h]h ]h"]h$]h&]uh1jhjghMhjfubj)}(h*``u32 basic_rates`` bitmap of basic rates h](j)}(h``u32 basic_rates``h]j)}(hj>gh]hu32 basic_rates}(hj@ghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhjiubj6)}(hhh]h)}(h&beginning of the next namespace's datah]h(beginning of the next namespace’s data}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihM>hjiubah}(h]h ]h"]h$]h&]uh1j5hjiubeh}(h]h ]h"]h$]h&]uh1jhjihM>hjhubj)}(h6``_next_bitmap`` internal pointer to next present u32 h](j)}(h``_next_bitmap``h]j)}(hjih]h _next_bitmap}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM;hjiubj6)}(hhh]h)}(h$internal pointer to next present u32h]h$internal pointer to next present u32}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihM;hjiubah}(h]h ]h"]h$]h&]uh1j5hjiubeh}(h]h ]h"]h$]h&]uh1jhjihM;hjhubj)}(h``this_arg`` pointer to current radiotap arg; it is valid after each call to ieee80211_radiotap_iterator_next() but also after ieee80211_radiotap_iterator_init() where it will point to the beginning of the actual data portion h](j)}(h ``this_arg``h]j)}(hjjh]hthis_arg}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj jubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM0hj jubj6)}(hhh]h)}(hpointer to current radiotap arg; it is valid after each call to ieee80211_radiotap_iterator_next() but also after ieee80211_radiotap_iterator_init() where it will point to the beginning of the actual data portionh]hpointer to current radiotap arg; it is valid after each call to ieee80211_radiotap_iterator_next() but also after ieee80211_radiotap_iterator_init() where it will point to the beginning of the actual data portion}(hj(jhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM-hj%jubah}(h]h ]h"]h$]h&]uh1j5hj jubeh}(h]h ]h"]h$]h&]uh1jhj$jhM0hjhubj)}(hp``this_arg_index`` index of current arg, valid after each successful call to ieee80211_radiotap_iterator_next() h](j)}(h``this_arg_index``h]j)}(hjIjh]hthis_arg_index}(hjKjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGjubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM,hjCjubj6)}(hhh]h)}(h\index of current arg, valid after each successful call to ieee80211_radiotap_iterator_next()h]h\index of current arg, valid after each successful call to ieee80211_radiotap_iterator_next()}(hjbjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM+hj_jubah}(h]h ]h"]h$]h&]uh1j5hjCjubeh}(h]h ]h"]h$]h&]uh1jhj^jhM,hjhubj)}(h=``this_arg_size`` length of the current arg, for convenience h](j)}(h``this_arg_size``h]j)}(hjjh]h this_arg_size}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM1hj}jubj6)}(hhh]h)}(h*length of the current arg, for convenienceh]h*length of the current arg, for convenience}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjhM1hjjubah}(h]h ]h"]h$]h&]uh1j5hj}jubeh}(h]h ]h"]h$]h&]uh1jhjjhM1hjhubj)}(hd``is_radiotap_ns`` indicates whether the current namespace is the default radiotap namespace or not h](j)}(h``is_radiotap_ns``h]j)}(hjjh]his_radiotap_ns}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM5hjjubj6)}(hhh]h)}(hPindicates whether the current namespace is the default radiotap namespace or noth]hPindicates whether the current namespace is the default radiotap namespace or not}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM4hjjubah}(h]h ]h"]h$]h&]uh1j5hjjubeh}(h]h ]h"]h$]h&]uh1jhjjhM5hjhubj)}(h?``_max_length`` length of radiotap header in cpu byte ordering h](j)}(h``_max_length``h]j)}(hjjh]h _max_length}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM8hjjubj6)}(hhh]h)}(h.length of radiotap header in cpu byte orderingh]h.length of radiotap header in cpu byte ordering}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj khM8hj kubah}(h]h ]h"]h$]h&]uh1j5hjjubeh}(h]h ]h"]h$]h&]uh1jhj khM8hjhubj)}(h#``_arg_index`` next argument index h](j)}(h``_arg_index``h]j)}(hj/kh]h _arg_index}(hj1khhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-kubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM9hj)kubj6)}(hhh]h)}(hnext argument indexh]hnext argument index}(hjHkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDkhM9hjEkubah}(h]h ]h"]h$]h&]uh1j5hj)kubeh}(h]h ]h"]h$]h&]uh1jhjDkhM9hjhubj)}(hP``_bitmap_shifter`` internal shifter for curr u32 bitmap, b0 set == arg present h](j)}(h``_bitmap_shifter``h]j)}(hjhkh]h_bitmap_shifter}(hjjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfkubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM<hjbkubj6)}(hhh]h)}(h;internal shifter for curr u32 bitmap, b0 set == arg presenth]h;internal shifter for curr u32 bitmap, b0 set == arg present}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj}khM<hj~kubah}(h]h ]h"]h$]h&]uh1j5hjbkubeh}(h]h ]h"]h$]h&]uh1jhj}khM<hjhubj)}(hW``_reset_on_ext`` internal; reset the arg index to 0 when going to the next bitmap wordh](j)}(h``_reset_on_ext``h]j)}(hjkh]h _reset_on_ext}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM?hjkubj6)}(hhh]h)}(hEinternal; reset the arg index to 0 when going to the next bitmap wordh]hEinternal; reset the arg index to 0 when going to the next bitmap word}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkhM?hjkubah}(h]h ]h"]h$]h&]uh1j5hjkubeh}(h]h ]h"]h$]h&]uh1jhjkhM?hjhubeh}(h]h ]h"]h$]h&]uh1jhjUhubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj_hhhNhNubh)}(h**Description**h]j)}(hjkh]h Description}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMChj_hhubh)}(hDescribes the radiotap parser state. Fields prefixed with an underscore must not be used by users of the parser, only by the parser internally.h]hDescribes the radiotap parser state. Fields prefixed with an underscore must not be used by users of the parser, only by the parser internally.}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMAhj_hhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_*ieee80211_get_hdrlen_from_skb (C function)c.ieee80211_get_hdrlen_from_skbhNtauh1jRhj_hhhNhNubjd)}(hhh](ji)}(hFunsigned int ieee80211_get_hdrlen_from_skb (const struct sk_buff *skb)h]jo)}(hEunsigned int ieee80211_get_hdrlen_from_skb(const struct sk_buff *skb)h](j)}(hunsignedh]hunsigned}(hj!lhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjlhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMrubj)}(h h]h }(hj0lhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjlhhhj/lhMrubj)}(hinth]hint}(hj>lhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjlhhhj/lhMrubj)}(h h]h }(hjLlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjlhhhj/lhMrubj)}(hieee80211_get_hdrlen_from_skbh]j)}(hieee80211_get_hdrlen_from_skbh]hieee80211_get_hdrlen_from_skb}(hj^lhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZlubah}(h]h ](jjeh"]h$]h&]jjuh1jhjlhhhj/lhMrubj)}(h(const struct sk_buff *skb)h]j)}(hconst struct sk_buff *skbh](ju)}(hjZHh]hconst}(hjzlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjvlubj)}(h h]h }(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvlubju)}(hjh]hstruct}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjvlubj)}(h h]h }(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvlubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjlmodnameN classnameNj j )}j ]j)}jj`lsbc.ieee80211_get_hdrlen_from_skbasbuh1hhjvlubj)}(h h]h }(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvlubj.)}(hj1h]h*}(hjlhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjvlubj)}(hskbh]hskb}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvlubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjrlubah}(h]h ]h"]h$]h&]jjuh1jhjlhhhj/lhMrubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjlhhhj/lhMrubah}(h]jlah ](jjeh"]h$]h&]jj)jhuh1jhhj/lhMrhjlhhubj)}(hhh]h)}(hget header length from datah]hget header length from data}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMghjmhhubah}(h]h ]h"]h$]h&]uh1jhjlhhhj/lhMrubeh}(h]h ](j$functioneh"]h$]h&]jj$jj0mjj0mjjjuh1jchhhj_hNhNubj)}(hXW**Parameters** ``const struct sk_buff *skb`` the frame **Description** Given an skb with a raw 802.11 header at the data pointer this function returns the 802.11 header length. **Return** The 802.11 header length in bytes (not including encryption headers). Or 0 if the data in the sk_buff is too short to contain a valid 802.11 header.h](h)}(h**Parameters**h]j)}(hj:mh]h Parameters}(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj-uubh)}(hhh]j)}(hu8h]hu8}(hjOuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLuubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjQumodnameN classnameNj j )}j ]jrc.ieee80211_amsdu_to_8023sasbuh1hhj-uubj)}(h h]h }(hjmuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj-uubj.)}(hj1h]h*}(hj{uhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj-uubj)}(hcheck_sah]hcheck_sa}(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj-uubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjrubj)}(hu8 mesh_controlh](h)}(hhh]j)}(hu8h]hu8}(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjumodnameN classnameNj j )}j ]jrc.ieee80211_amsdu_to_8023sasbuh1hhjuubj)}(h h]h }(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuubj)}(h mesh_controlh]h mesh_control}(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjrubeh}(h]h ]h"]h$]h&]jjuh1jhj_rhhhjqrhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj[rhhhjqrhMubah}(h]jVrah ](jjeh"]h$]h&]jj)jhuh1jhhjqrhMhjXrhhubj)}(hhh]h)}(h#decode an IEEE 802.11n A-MSDU frameh]h#decode an IEEE 802.11n A-MSDU frame}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjuhhubah}(h]h ]h"]h$]h&]uh1jhjXrhhhjqrhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjvjjvjjjuh1jchhhjdohNhNubj)}(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)}(hjvh]h Parameters}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjvubj)}(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;vh]hstruct sk_buff *skb}(hj=vhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9vubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhj5vubj6)}(hhh]h)}(h+The input A-MSDU frame without any headers.h]h+The input A-MSDU frame without any headers.}(hjTvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPvhMhjQvubah}(h]h ]h"]h$]h&]uh1j5hj5vubeh}(h]h ]h"]h$]h&]uh1jhjPvhMhj2vubj)}(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)}(hjtvh]hstruct sk_buff_head *list}(hjvvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrvubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjnvubj6)}(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.}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjvubah}(h]h ]h"]h$]h&]uh1j5hjnvubeh}(h]h ]h"]h$]h&]uh1jhjvhMhj2vubj)}(h+``const u8 *addr`` The device MAC address. h](j)}(h``const u8 *addr``h]j)}(hjvh]hconst u8 *addr}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjvubj6)}(hhh]h)}(hThe device MAC address.h]hThe device MAC address.}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvhMhjvubah}(h]h ]h"]h$]h&]uh1j5hjvubeh}(h]h ]h"]h$]h&]uh1jhjvhMhj2vubj)}(h:``enum nl80211_iftype iftype`` The device interface type. h](j)}(h``enum nl80211_iftype iftype``h]j)}(hjvh]henum nl80211_iftype iftype}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjvubj6)}(hhh]h)}(hThe device interface type.h]hThe device interface type.}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvhMhjvubah}(h]h ]h"]h$]h&]uh1j5hjvubeh}(h]h ]h"]h$]h&]uh1jhjvhMhj2vubj)}(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)}(hj wh]h!const unsigned int extra_headroom}(hj"whhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjwubj6)}(hhh]h)}(h5The hardware extra headroom for SKBs in the **list**.h](h,The hardware extra headroom for SKBs in the }(hj9whhhNhNubj)}(h**list**h]hlist}(hjAwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9wubh.}(hj9whhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj5whMhj6wubah}(h]h ]h"]h$]h&]uh1j5hjwubeh}(h]h ]h"]h$]h&]uh1jhj5whMhj2vubj)}(hI``const u8 *check_da`` DA to check in the inner ethernet header, or NULL h](j)}(h``const u8 *check_da``h]j)}(hjkwh]hconst u8 *check_da}(hjmwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiwubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjewubj6)}(hhh]h)}(h1DA to check in the inner ethernet header, or NULLh]h1DA to check in the inner ethernet header, or NULL}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwhMhjwubah}(h]h ]h"]h$]h&]uh1j5hjewubeh}(h]h ]h"]h$]h&]uh1jhjwhMhj2vubj)}(hI``const u8 *check_sa`` SA to check in the inner ethernet header, or NULL h](j)}(h``const u8 *check_sa``h]j)}(hjwh]hconst u8 *check_sa}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjwubj6)}(hhh]h)}(h1SA to check in the inner ethernet header, or NULLh]h1SA to check in the inner ethernet header, or NULL}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwhMhjwubah}(h]h ]h"]h$]h&]uh1j5hjwubeh}(h]h ]h"]h$]h&]uh1jhjwhMhj2vubj)}(h=``u8 mesh_control`` see mesh_hdr in ieee80211_is_valid_amsdu h](j)}(h``u8 mesh_control``h]j)}(hjwh]hu8 mesh_control}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjwubj6)}(hhh]h)}(h(see mesh_hdr in ieee80211_is_valid_amsduh]h(see mesh_hdr in ieee80211_is_valid_amsdu}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwhMhjwubah}(h]h ]h"]h$]h&]uh1j5hjwubeh}(h]h ]h"]h$]h&]uh1jhjwhMhj2vubeh}(h]h ]h"]h$]h&]uh1jhjvubh)}(h**Description**h]j)}(hjxh]h Description}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjvubh)}(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 }(hj.xhhhNhNubj)}(h**list**h]hlist}(hj6xhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.xubh( will be empty if the decode fails. The }(hj.xhhhNhNubj)}(h**skb**h]hskb}(hjHxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.xubhU must be fully header-less before being passed in here; it is freed in this function.}(hj.xhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjvubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjdohhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_#cfg80211_classify8021d (C function)c.cfg80211_classify8021dhNtauh1jRhjdohhhNhNubjd)}(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}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}xhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMubj)}(h h]h }(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}xhhhjxhMubj)}(hinth]hint}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}xhhhjxhMubj)}(h h]h }(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}xhhhjxhMubj)}(hcfg80211_classify8021dh]j)}(hcfg80211_classify8021dh]hcfg80211_classify8021d}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubah}(h]h ](jjeh"]h$]h&]jjuh1jhj}xhhhjxhMubj)}(h7(struct sk_buff *skb, struct cfg80211_qos_map *qos_map)h](j)}(hstruct sk_buff *skbh](ju)}(hjh]hstruct}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjxubj)}(h h]h }(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjxmodnameN classnameNj j )}j ]j)}jjxsbc.cfg80211_classify8021dasbuh1hhjxubj)}(h h]h }(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubj.)}(hj1h]h*}(hj&yhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjxubj)}(hskbh]hskb}(hj3yhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjxubj)}(h struct cfg80211_qos_map *qos_maph](ju)}(hjh]hstruct}(hjLyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjHyubj)}(h h]h }(hjYyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHyubh)}(hhh]j)}(hcfg80211_qos_maph]hcfg80211_qos_map}(hjjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjgyubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjlymodnameN classnameNj j )}j ]jyc.cfg80211_classify8021dasbuh1hhjHyubj)}(h h]h }(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHyubj.)}(hj1h]h*}(hjyhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjHyubj)}(hqos_maph]hqos_map}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHyubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjxubeh}(h]h ]h"]h$]h&]jjuh1jhj}xhhhjxhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjyxhhhjxhMubah}(h]jtxah ](jjeh"]h$]h&]jj)jhuh1jhhjxhMhjvxhhubj)}(hhh]h)}(h,determine the 802.1p/1d tag for a data frameh]h,determine the 802.1p/1d tag for a data frame}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjyhhubah}(h]h ]h"]h$]h&]uh1jhjvxhhhjxhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjyjjyjjjuh1jchhhjdohNhNubj)}(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)}(hjyh]h Parameters}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjyubj)}(hhh](j)}(h'``struct sk_buff *skb`` the data frame h](j)}(h``struct sk_buff *skb``h]j)}(hjzh]hstruct sk_buff *skb}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj zubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjzubj6)}(hhh]h)}(hthe data frameh]hthe data frame}(hj'zhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#zhMhj$zubah}(h]h ]h"]h$]h&]uh1j5hjzubeh}(h]h ]h"]h$]h&]uh1jhj#zhMhjzubj)}(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)}(hjGzh]h struct cfg80211_qos_map *qos_map}(hjIzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEzubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjAzubj6)}(hhh]h)}(h2Interworking QoS mapping or ``NULL`` if not in useh](hInterworking QoS mapping or }(hj`zhhhNhNubj)}(h``NULL``h]hNULL}(hjhzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`zubh if not in use}(hj`zhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj\zhMhj]zubah}(h]h ]h"]h$]h&]uh1j5hjAzubeh}(h]h ]h"]h$]h&]uh1jhj\zhMhjzubeh}(h]h ]h"]h$]h&]uh1jhjyubh)}(h **Return**h]j)}(hjzh]hReturn}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjyubh)}(hThe 802.1p/1d tag.h]hThe 802.1p/1d tag.}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjyubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjdohhhNhNubeh}(h]data-path-helpersah ]h"]data path helpersah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(h%Regulatory enforcement infrastructureh]h%Regulatory enforcement infrastructure}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzhhhhhKubh)}(hTODOh]hTODO}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:146: ./include/net/cfg80211.hhMhjzhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_regulatory_hint (C function)c.regulatory_hinthNtauh1jRhjzhhhNhNubjd)}(hhh](ji)}(h=int regulatory_hint (struct wiphy *wiphy, const char *alpha2)h]jo)}(h{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj:{ubj)}(h h]h }(hjK{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:{ubh)}(hhh]j)}(hwiphyh]hwiphy}(hj\{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjY{ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj^{modnameN classnameNj j )}j ]j)}jj${sbc.regulatory_hintasbuh1hhj:{ubj)}(h h]h }(hj|{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:{ubj.)}(hj1h]h*}(hj{hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj:{ubj)}(hwiphyh]hwiphy}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:{ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj6{ubj)}(hconst char *alpha2h](ju)}(hjZHh]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 ]jah"]h$]h&]uh1jhj{ubj)}(h h]h }(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ubj.)}(hj1h]h*}(hj{hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj{ubj)}(halpha2h]halpha2}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj6{ubeh}(h]h ]h"]h$]h&]jjuh1jhjzhhhj{hMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjzhhhj{hMubah}(h]jzah ](jjeh"]h$]h&]jj)jhuh1jhhj{hMhjzhhubj)}(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.hhMhj|hhubah}(h]h ]h"]h$]h&]uh1jhjzhhhj{hMubeh}(h]h ](j$functioneh"]h$]h&]jj$jj6|jj6|jjjuh1jchhhjzhNhNubj)}(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}(hjB|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>|ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhj:|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}(hja|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.hhMhjY|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)}(hjx|hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhju|ubah}(h]h ]h"]h$]h&]uh1j5hjY|ubeh}(h]h ]h"]h$]h&]uh1jhjt|hMhjV|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.hhMhj|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.hhMhj|ubah}(h]h ]h"]h$]h&]uh1j5hj|ubeh}(h]h ]h"]h$]h&]uh1jhj|hMhjV|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.hhMhj:|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.hhMhj:|ubh)}(hThe wiphy must have been registered to cfg80211 prior to this call. For cfg80211 drivers this means you must first use wiphy_register(), for mac80211 drivers you must first use ieee80211_register_hw().h]hThe wiphy must have been registered to cfg80211 prior to this call. For cfg80211 drivers this means you must first use wiphy_register(), for mac80211 drivers you must first use ieee80211_register_hw().}(hj }hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhM hj:|ubh)}(hKDrivers should check the return value, its possible you can get an -ENOMEM.h]hKDrivers should check the return value, its possible you can get an -ENOMEM.}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhj:|ubh)}(h **Return**h]j)}(hj,}h]hReturn}(hj.}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*}ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhj:|ubh)}(h0 on success. -ENOMEM.h]h0 on success. -ENOMEM.}(hjB}hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhj:|ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjzhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_*wiphy_apply_custom_regulatory (C function)c.wiphy_apply_custom_regulatoryhNtauh1jRhjzhhhNhNubjd)}(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}(hjq}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjm}hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMAubj)}(h h]h }(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjm}hhhj}hMAubj)}(hwiphy_apply_custom_regulatoryh]j)}(hwiphy_apply_custom_regulatoryh]hwiphy_apply_custom_regulatory}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjm}hhhj}hMAubj)}(h=(struct wiphy *wiphy, const struct ieee80211_regdomain *regd)h](j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj}ubj)}(h h]h }(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubh)}(hhh]j)}(hwiphyh]hwiphy}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj}modnameN classnameNj j )}j ]j)}jj}sbc.wiphy_apply_custom_regulatoryasbuh1hhj}ubj)}(h h]h }(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubj.)}(hj1h]h*}(hj}hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj}ubj)}(hwiphyh]hwiphy}(hj~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj}ubj)}(h&const struct ieee80211_regdomain *regdh](ju)}(hjZHh]hconst}(hj ~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj~ubj)}(h h]h }(hj-~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj~ubju)}(hjh]hstruct}(hj;~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthj~ubj)}(h h]h }(hjH~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj~ubh)}(hhh]j)}(hieee80211_regdomainh]hieee80211_regdomain}(hjY~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjV~ubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj[~modnameN classnameNj j )}j ]j}c.wiphy_apply_custom_regulatoryasbuh1hhj~ubj)}(h h]h }(hjw~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj~ubj.)}(hj1h]h*}(hj~hhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hj~ubj)}(hregdh]hregd}(hj~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj~ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj}ubeh}(h]h ]h"]h$]h&]jjuh1jhjm}hhhj}hMAubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhji}hhhj}hMAubah}(h]jd}ah ](jjeh"]h$]h&]jj)jhuh1jhhj}hMAhjf}hhubj)}(hhh]h)}(h'apply a custom driver regulatory domainh]h'apply a custom driver regulatory domain}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhM3hj~hhubah}(h]h ]h"]h$]h&]uh1jhjf}hhhj}hMAubeh}(h]h ](j$functioneh"]h$]h&]jj$jj~jj~jjjuh1jchhhjzhNhNubj)}(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)}(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.hhM7hj~ubj)}(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.hhM4hj~ubj6)}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM4hjubah}(h]h ]h"]h$]h&]uh1j5hj~ubeh}(h]h ]h"]h$]h&]uh1jhjhM4hj~ubj)}(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)}(hj6h]h&const struct ieee80211_regdomain *regd}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhM5hj0ubj6)}(hhh]h)}(h2the custom regulatory domain to use for this wiphyh]h2the custom regulatory domain to use for this wiphy}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKhM5hjLubah}(h]h ]h"]h$]h&]uh1j5hj0ubeh}(h]h ]h"]h$]h&]uh1jhjKhM5hj~ubeh}(h]h ]h"]h$]h&]uh1jhj~ubh)}(h**Description**h]j)}(hjqh]h Description}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhjoubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhM7hj~ubh)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhM7hj~ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjzhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_freq_reg_info (C function)c.freq_reg_infohNtauh1jRhjzhhhNhNubjd)}(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)}(hjZHh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMVubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMVubju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjhhhjhMVubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMVubh)}(hhh]j)}(hieee80211_reg_ruleh]hieee80211_reg_rule}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}j freq_reg_infosbc.freq_reg_infoasbuh1hhjhhhjhMVubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMVubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjhhhjhMVubj)}(h freq_reg_infoh]j)}(hjh]h freq_reg_info}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMVubj)}(h&(struct wiphy *wiphy, u32 center_freq)h](j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjGubj)}(h h]h }(hjXhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGubh)}(hhh]j)}(hwiphyh]hwiphy}(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjkmodnameN classnameNj j )}j ]j c.freq_reg_infoasbuh1hhjGubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjGubj)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjCubj)}(hu32 center_freqh](h)}(hhh]j)}(hu32h]hu32}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j c.freq_reg_infoasbuh1hhjubj)}(h h]h }(hj܀hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h center_freqh]h center_freq}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjCubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMVubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjhMVubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMVhjhhubj)}(hhh]h)}(h2get regulatory information for the given frequencyh]h2get regulatory information for the given frequency}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMEhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMVubeh}(h]h ](j$functioneh"]h$]h&]jj$jj,jj,jjjuh1jchhhjzhNhNubj)}(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)}(hj6h]h Parameters}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMIhj0ubj)}(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)}(hjUh]hstruct wiphy *wiphy}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMFhjOubj6)}(hhh]h)}(h4the wiphy for which we want to process this rule forh]h4the wiphy for which we want to process this rule for}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjhMFhjkubah}(h]h ]h"]h$]h&]uh1j5hjOubeh}(h]h ]h"]h$]h&]uh1jhjjhMFhjLubj)}(hR``u32 center_freq`` Frequency in KHz for which we want regulatory information for h](j)}(h``u32 center_freq``h]j)}(hjh]hu32 center_freq}(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.hhMGhjubj6)}(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&]uh1hhjhMGhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMGhjLubeh}(h]h ]h"]h$]h&]uh1jhj0ubh)}(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.hhMIhj0ubh)}(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.hhMIhj0ubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMNhj0ubh)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMNhj0ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjzhhhNhNubeh}(h]%regulatory-enforcement-infrastructureah ]h"]%regulatory enforcement infrastructureah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(hRFkill integrationh]hRFkill integration}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$hhhhhKubh)}(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.}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:158: ./include/net/cfg80211.hhMhj$hhubh)}(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.}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:158: ./include/net/cfg80211.hhMhj$hhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_'wiphy_rfkill_start_polling (C function)c.wiphy_rfkill_start_pollinghNtauh1jRhj$hhhNhNubjd)}(hhh](ji)}(h5void wiphy_rfkill_start_polling (struct wiphy *wiphy)h]jo)}(h4void wiphy_rfkill_start_polling(struct wiphy *wiphy)h](j)}(hvoidh]hvoid}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhMubj)}(h h]h }(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhhjzhMubj)}(hwiphy_rfkill_start_pollingh]j)}(hwiphy_rfkill_start_pollingh]hwiphy_rfkill_start_polling}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhhjzhMubj)}(h(struct wiphy *wiphy)h]j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hwiphyh]hwiphy}(hjǂhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjĂubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjɂmodnameN classnameNj j )}j ]j)}jjsbc.wiphy_rfkill_start_pollingasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhhjzhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjdhhhjzhMubah}(h]j_ah ](jjeh"]h$]h&]jj)jhuh1jhhjzhMhjahhubj)}(hhh]h)}(hstart polling rfkillh]hstart polling rfkill}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhMhj)hhubah}(h]h ]h"]h$]h&]uh1jhjahhhjzhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjDjjDjjjuh1jchhhj$hNhNubj)}(h3**Parameters** ``struct wiphy *wiphy`` the wiphyh](h)}(h**Parameters**h]j)}(hjNh]h Parameters}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhMhjHubj)}(hhh]j)}(h!``struct wiphy *wiphy`` the wiphyh](j)}(h``struct wiphy *wiphy``h]j)}(hjmh]hstruct wiphy *wiphy}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhMhjgubj6)}(hhh]h)}(h the wiphyh]h the wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1j5hjgubeh}(h]h ]h"]h$]h&]uh1jhjhMhjdubah}(h]h ]h"]h$]h&]uh1jhjHubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$hhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_&wiphy_rfkill_stop_polling (C function)c.wiphy_rfkill_stop_pollinghNtauh1jRhj$hhhNhNubjd)}(hhh](ji)}(h4void wiphy_rfkill_stop_polling (struct wiphy *wiphy)h]jo)}(h3void wiphy_rfkill_stop_polling(struct wiphy *wiphy)h](j)}(hvoidh]hvoid}(hjǃhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjÃhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhMubj)}(h h]h }(hjփhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjÃhhhjՃhMubj)}(hwiphy_rfkill_stop_pollingh]j)}(hwiphy_rfkill_stop_pollingh]hwiphy_rfkill_stop_polling}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjÃhhhjՃhMubj)}(h(struct wiphy *wiphy)h]j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hwiphyh]hwiphy}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetj$modnameN classnameNj j )}j ]j)}jjsbc.wiphy_rfkill_stop_pollingasbuh1hhjubj)}(h h]h }(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjPhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hwiphyh]hwiphy}(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjÃhhhjՃhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjhhhjՃhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjՃhMhjhhubj)}(hhh]h)}(hstop polling rfkillh]hstop polling rfkill}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjՃhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhj$hNhNubj)}(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.hhMhjubj)}(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&]uh1jhjƄubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhMhj„ubj6)}(hhh]h)}(h the wiphyh]h the wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhMhjބubah}(h]h ]h"]h$]h&]uh1j5hj„ubeh}(h]h ]h"]h$]h&]uh1jhj݄hMhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj$hhhNhNubeh}(h]rfkill-integrationah ]h"]rfkill integrationah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(h Test modeh]h Test mode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhKubh)}(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.}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:170: ./include/net/cfg80211.hhMXhjhhubh)}(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.}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:170: ./include/net/cfg80211.hhM\hjhhubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_.cfg80211_testmode_alloc_reply_skb (C function)#c.cfg80211_testmode_alloc_reply_skbhNtauh1jRhjhhhNhNubjd)}(hhh](ji)}(hWstruct sk_buff * cfg80211_testmode_alloc_reply_skb (struct wiphy *wiphy, int approxlen)h]jo)}(hUstruct sk_buff *cfg80211_testmode_alloc_reply_skb(struct wiphy *wiphy, int approxlen)h](ju)}(hjh]hstruct}(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjUhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMyubj)}(h h]h }(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUhhhjfhMyubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjzmodnameN classnameNj j )}j ]j)}j!cfg80211_testmode_alloc_reply_skbsb#c.cfg80211_testmode_alloc_reply_skbasbuh1hhjUhhhjfhMyubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUhhhjfhMyubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjUhhhjfhMyubj)}(h!cfg80211_testmode_alloc_reply_skbh]j)}(hjh]h!cfg80211_testmode_alloc_reply_skb}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjUhhhjfhMyubj)}(h$(struct wiphy *wiphy, int approxlen)h](j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjӅhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjυubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjυubh)}(hhh]j)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j#c.cfg80211_testmode_alloc_reply_skbasbuh1hhjυubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjυubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjυubj)}(hwiphyh]hwiphy}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjυubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj˅ubj)}(h int approxlenh](j)}(hinth]hint}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj?ubj)}(h h]h }(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj?ubj)}(h approxlenh]h approxlen}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj?ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj˅ubeh}(h]h ]h"]h$]h&]jjuh1jhjUhhhjfhMyubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjQhhhjfhMyubah}(h]jLah ](jjeh"]h$]h&]jj)jhuh1jhhjfhMyhjNhhubj)}(hhh]h)}(hallocate testmode replyh]hallocate testmode reply}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMchjhhubah}(h]h ]h"]h$]h&]uh1jhjNhhhjfhMyubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhjhNhNubj)}(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.hhMghjubj)}(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.hhMdhjĆubj6)}(hhh]h)}(h the wiphyh]h the wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj߆hMdhjubah}(h]h ]h"]h$]h&]uh1j5hjĆubeh}(h]h ]h"]h$]h&]uh1jhj߆hMdhjubj)}(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.hhMfhjubj6)}(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.hhMehjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMfhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj?h]h Description}(hjAhhhNhNubah}(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.hhMhhjubh)}(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 }(hjUhhhNhNubj)}(h**testmode_cmd**h]h testmode_cmd}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUubh operation is invalid.}(hjUhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhhjubh)}(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 }(hjvhhhNhNubj)}(h``NL80211_ATTR_TESTDATA``h]hNL80211_ATTR_TESTDATA}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubh 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.}(hjvhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMlhjubh)}(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 }(hjhhhNhNubj)}(h**testmode_cmd**h]h testmode_cmd}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubh operation.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMthjubh)}(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.hhMwhjubh)}(h?An allocated and pre-filled skb. ``NULL`` if any errors happen.h](h!An allocated and pre-filled skb. }(hjЇhhhNhNubj)}(h``NULL``h]hNULL}(hj؇hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjЇubh if any errors happen.}(hjЇhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMwhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_$cfg80211_testmode_reply (C function)c.cfg80211_testmode_replyhNtauh1jRhjhhhNhNubjd)}(hhh](ji)}(h1int cfg80211_testmode_reply (struct sk_buff *skb)h]jo)}(h0int cfg80211_testmode_reply(struct sk_buff *skb)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhjhMubj)}(hcfg80211_testmode_replyh]j)}(hcfg80211_testmode_replyh]hcfg80211_testmode_reply}(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj hhhjhMubj)}(h(struct sk_buff *skb)h]j)}(hstruct sk_buff *skbh](ju)}(hjh]hstruct}(hjNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjJubj)}(h h]h }(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjnmodnameN classnameNj j )}j ]j)}jj4sbc.cfg80211_testmode_replyasbuh1hhjJubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjJubj)}(hskbh]hskb}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjFubah}(h]h ]h"]h$]h&]jjuh1jhj hhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhj hhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjhMhjhhubj)}(hhh]h)}(hsend the reply skbh]hsend the reply skb}(hjшhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjΈhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhjhNhNubj)}(hX**Parameters** ``struct sk_buff *skb`` The skb, must have been allocated with cfg80211_testmode_alloc_reply_skb() **Description** Since calling this function will usually be the last thing before returning from the **testmode_cmd** you should return the error code. Note that this function consumes the skb regardless of the return value. **Return** An error code or 0 on success.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjubj)}(hhh]j)}(hc``struct sk_buff *skb`` The skb, must have been allocated with cfg80211_testmode_alloc_reply_skb() h](j)}(h``struct sk_buff *skb``h]j)}(hjh]hstruct sk_buff *skb}(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.hhMhj ubj6)}(hhh]h)}(hJThe skb, must have been allocated with cfg80211_testmode_alloc_reply_skb()h]hJThe skb, must have been allocated with cfg80211_testmode_alloc_reply_skb()}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhj(ubah}(h]h ]h"]h$]h&]uh1j5hj ubeh}(h]h ]h"]h$]h&]uh1jhj'hMhj ubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjNh]h Description}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjubh)}(hSince calling this function will usually be the last thing before returning from the **testmode_cmd** you should return the error code. Note that this function consumes the skb regardless of the return value.h](hUSince calling this function will usually be the last thing before returning from the }(hjdhhhNhNubj)}(h**testmode_cmd**h]h testmode_cmd}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdubhl you should return the error code. Note that this function consumes the skb regardless of the return value.}(hjdhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjubh)}(h **Return**h]j)}(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.hhMhjubh)}(hAn error code or 0 on success.h]hAn error code or 0 on success.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_.cfg80211_testmode_alloc_event_skb (C function)#c.cfg80211_testmode_alloc_event_skbhNtauh1jRhjhhhNhNubjd)}(hhh](ji)}(hbstruct sk_buff * cfg80211_testmode_alloc_event_skb (struct wiphy *wiphy, int approxlen, gfp_t gfp)h]jo)}(h`struct sk_buff *cfg80211_testmode_alloc_event_skb(struct wiphy *wiphy, int approxlen, gfp_t gfp)h](ju)}(hjh]hstruct}(hj̉hhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjȉhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMubj)}(h h]h }(hjډhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjȉhhhjىhMubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j)}j!cfg80211_testmode_alloc_event_skbsb#c.cfg80211_testmode_alloc_event_skbasbuh1hhjȉhhhjىhMubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjȉhhhjىhMubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjȉhhhjىhMubj)}(h!cfg80211_testmode_alloc_event_skbh]j)}(hj h]h!cfg80211_testmode_alloc_event_skb}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjȉhhhjىhMubj)}(h/(struct wiphy *wiphy, int approxlen, gfp_t gfp)h](j)}(hstruct wiphy *wiphyh](ju)}(hjh]hstruct}(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jthjBubj)}(h h]h }(hjShhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubh)}(hhh]j)}(hwiphyh]hwiphy}(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjfmodnameN classnameNj j )}j ]j#c.cfg80211_testmode_alloc_event_skbasbuh1hhjBubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubj.)}(hj1h]h*}(hjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjBubj)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj>ubj)}(h int approxlenh](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hjĊhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h approxlenh]h approxlen}(hjҊhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj>ubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]j#c.cfg80211_testmode_alloc_event_skbasbuh1hhjubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj>ubeh}(h]h ]h"]h$]h&]jjuh1jhjȉhhhjىhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjĉhhhjىhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jhhjىhMhjhhubj)}(hhh]h)}(hallocate testmode eventh]hallocate testmode event}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjAhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjىhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jj\jj\jjjuh1jchhhjhNhNubj)}(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)}(hjfh]h Parameters}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhj`ubj)}(hhh](j)}(h"``struct wiphy *wiphy`` the wiphy h](j)}(h``struct wiphy *wiphy``h]j)}(hjh]hstruct wiphy *wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(h the wiphyh]h the wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj|ubj)}(hY``int approxlen`` an upper bound of the length of the data that will be put into the skb h](j)}(h``int approxlen``h]j)}(hjh]h int approxlen}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&"5]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hFan upper bound of the length of the data that will be put into the skbh]hFan upper bound of the length of the data that will be put into the skb}(hj׋hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjԋubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhjӋhMhj|ubj)}(h``gfp_t gfp`` allocation flags h](j)}(h ``gfp_t gfp``h]j)}(hjh]h gfp_t gfp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhjubah}(h]h ]h"]h$]h&]uh1j5hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhj|ubeh}(h]h ]h"]h$]h&]uh1jhj`ubh)}(h**Description**h]j)}(hj3h]h Description}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhj`ubh)}(hZThis function allocates and pre-fills an skb for an event on the testmode multicast group.h]hZThis function allocates and pre-fills an skb for an event on the testmode multicast group.}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhj`ubh)}(hXThe returned skb is set up in the same way as with cfg80211_testmode_alloc_reply_skb() but prepared for an event. As there, you should simply add data to it that will then end up in the ``NL80211_ATTR_TESTDATA`` attribute. Again, you must not modify the skb in any other way.h](hThe returned skb is set up in the same way as with cfg80211_testmode_alloc_reply_skb() but prepared for an event. As there, you should simply add data to it that will then end up in the }(hjXhhhNhNubj)}(h``NL80211_ATTR_TESTDATA``h]hNL80211_ATTR_TESTDATA}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubh@ attribute. Again, you must not modify the skb in any other way.}(hjXhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhj`ubh)}(hYWhen done filling the skb, call cfg80211_testmode_event() with the skb to send the event.h]hYWhen done filling the skb, call cfg80211_testmode_event() with the skb to send the event.}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhj`ubh)}(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.hhMhj`ubh)}(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.hhMhj`ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubjS)}(hhh]h}(h]h ]h"]h$]h&]entries](j_$cfg80211_testmode_event (C function)c.cfg80211_testmode_eventhNtauh1jRhjhhhNhNubjd)}(hhh](ji)}(h=void cfg80211_testmode_event (struct sk_buff *skb, gfp_t gfp)h]jo)}(hmodnameN classnameNj j )}j ]j)}jjsbc.cfg80211_testmode_eventasbuh1hhjubj)}(h h]h }(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj.)}(hj1h]h*}(hjjhhhNhNubah}(h]h ]j:ah"]h$]h&]uh1j-hjubj)}(hskbh]hskb}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj$reftypej reftargetjmodnameN classnameNj j )}j ]jXc.cfg80211_testmode_eventasbuh1hhjubj)}(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&]jjuh1jhj݌hhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jnjjhjٌhhhjhMubah}(h]jԌah ](jjeh"]h$]h&]jj)jhuh1jhhjhMhj֌hhubj)}(hhh]h)}(hsend the eventh]hsend the event}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhj֌hhhjhMubeh}(h]h ](j$functioneh"]h$]h&]jj$jjjjjjjuh1jchhhjhNhNubj)}(hX<**Parameters** ``struct sk_buff *skb`` The skb, must have been allocated with cfg80211_testmode_alloc_event_skb() ``gfp_t gfp`` allocation flags **Description** This function sends the given **skb**, which must have been allocated by cfg80211_testmode_alloc_event_skb(), as an event. It always consumes it.h](h)}(h**Parameters**h]j)}(hj h]h Parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjubj)}(hhh](j)}(hc``struct sk_buff *skb`` The skb, must have been allocated with cfg80211_testmode_alloc_event_skb() h](j)}(h``struct sk_buff *skb``h]j)}(hj*h]hstruct sk_buff *skb}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhj$ubj6)}(hhh]h)}(hJThe skb, must have been allocated with cfg80211_testmode_alloc_event_skb()h]hJThe skb, must have been allocated with cfg80211_testmode_alloc_event_skb()}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhj@ubah}(h]h ]h"]h$]h&]uh1j5hj$ubeh}(h]h ]h"]h$]h&]uh1jhj?hMhj!ubj)}(h``gfp_t gfp`` allocation flags h](j)}(h ``gfp_t gfp``h]j)}(hjdh]h gfp_t gfp}(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.hhMhj^ubj6)}(hhh]h)}(hallocation flagsh]hallocation flags}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyhMhjzubah}(h]h ]h"]h$]h&]uh1j5hj^ubeh}(h]h ]h"]h$]h&]uh1jhjyhMhj!ubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjubh)}(hThis function sends the given **skb**, which must have been allocated by cfg80211_testmode_alloc_event_skb(), as an event. It always consumes it.h](hThis function sends the given }(hjhhhNhNubj)}(h**skb**h]hskb}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubhl, which must have been allocated by cfg80211_testmode_alloc_event_skb(), as an event. It always consumes it.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubeh}(h] test-modeah ]h"] test modeah$]h&]uh1hhhhhhhhKubeh}(h]cfg80211-subsystemah ]h"]cfg80211 subsystemah$]h&]uh1hhhhhhhhKubeh}(h]h ]h"]h$]h&]sourcehuh1hcurrent_sourceN current_lineNsettingsdocutils.frontendValues)}(hN generatorN datestampN source_linkN source_urlN toc_backlinksentryfootnote_backlinksK sectnum_xformKstrip_commentsNstrip_elements_with_classesN strip_classesN report_levelK halt_levelKexit_status_levelKdebugNwarning_streamN tracebackinput_encoding utf-8-siginput_encoding_error_handlerstrictoutput_encodingutf-8output_encoding_error_handlerjerror_encodingutf-8error_encoding_error_handlerbackslashreplace language_codeenrecord_dependenciesNconfigN id_prefixhauto_id_prefixid dump_settingsNdump_internalsNdump_transformsNdump_pseudo_xmlNexpose_internalsNstrict_visitorN_disable_configN_sourceh _destinationN _config_files]7/var/lib/git/docbuild/linux/Documentation/docutils.confafile_insertion_enabled raw_enabledKline_length_limitM'pep_referencesN pep_base_urlhttps://peps.python.org/pep_file_url_templatepep-%04drfc_referencesN rfc_base_url&https://datatracker.ietf.org/doc/html/ tab_widthKtrim_footnote_reference_spacesyntax_highlightlong smart_quotessmartquotes_locales]character_level_inline_markupdoctitle_xform docinfo_xformKsectsubtitle_xform image_loadinglinkembed_stylesheetcloak_email_addressessection_self_linkenvNubreporterNindirect_targets]substitution_defs}substitution_names}refnames}refids}nameids}(jjj!bjbj8j8j_j~_jaoj^ojzjzj!jjj jjߎu nametypes}(jj!bj8j_jaojzj!jjuh}(jhjbhjajjjjjd ji jjjjjjjjj`jejjjTjYj$j $jG%jL%j()j-)j9Aj>AjBjBjyDj~Dj}FjFjKHjPHj"Jj'JjLjLj!Nj&NjOjOjPjQj7^j<^j_j_j8j$bjnbjsbjdjdjPgjUgj?jjDjjmjmjrjrjxjxjjjjjjj>jCjjjjjjjjjjjjj+j0j̵jѵjjjjj3j8jjj8j=jjjBjGjljqjjjjjVj[jjjjj|jjjjjjCjHjjj= jB j#j#j&j&j*j*jP.jU.jj2jo2j5j5j~_j8j8j8j:j:jk@jp@jDjDjJjJj Mj%MjPjPjRj RjMVjRVj^]jc]j^oj_j_j_jajajbjbj$ej)ejgjgjljljmjmjzjdojojojVrj[rjtxjyxjjzjzjzjd}ji}jjj j$j_jdjjjߎjjLjQjj jjĉjԌjٌu 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.